Password.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. "use strict";
  2. "use client";
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. exports.default = void 0;
  9. var _react = _interopRequireWildcard(require("react"));
  10. var React = _react;
  11. var _EyeInvisibleOutlined = _interopRequireDefault(require("@ant-design/icons/EyeInvisibleOutlined"));
  12. var _EyeOutlined = _interopRequireDefault(require("@ant-design/icons/EyeOutlined"));
  13. var _classnames = _interopRequireDefault(require("classnames"));
  14. var _omit = _interopRequireDefault(require("rc-util/lib/omit"));
  15. var _ref = require("rc-util/lib/ref");
  16. var _configProvider = require("../config-provider");
  17. var _DisabledContext = _interopRequireDefault(require("../config-provider/DisabledContext"));
  18. var _useRemovePasswordTimeout = _interopRequireDefault(require("./hooks/useRemovePasswordTimeout"));
  19. var _Input = _interopRequireDefault(require("./Input"));
  20. var __rest = void 0 && (void 0).__rest || function (s, e) {
  21. var t = {};
  22. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  23. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  24. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  25. }
  26. return t;
  27. };
  28. const defaultIconRender = visible => visible ? /*#__PURE__*/React.createElement(_EyeOutlined.default, null) : /*#__PURE__*/React.createElement(_EyeInvisibleOutlined.default, null);
  29. const actionMap = {
  30. click: 'onClick',
  31. hover: 'onMouseOver'
  32. };
  33. const Password = /*#__PURE__*/React.forwardRef((props, ref) => {
  34. const {
  35. disabled: customDisabled,
  36. action = 'click',
  37. visibilityToggle = true,
  38. iconRender = defaultIconRender,
  39. suffix
  40. } = props;
  41. // ===================== Disabled =====================
  42. const disabled = React.useContext(_DisabledContext.default);
  43. const mergedDisabled = customDisabled !== null && customDisabled !== void 0 ? customDisabled : disabled;
  44. const visibilityControlled = typeof visibilityToggle === 'object' && visibilityToggle.visible !== undefined;
  45. const [visible, setVisible] = (0, _react.useState)(() => visibilityControlled ? visibilityToggle.visible : false);
  46. const inputRef = (0, _react.useRef)(null);
  47. React.useEffect(() => {
  48. if (visibilityControlled) {
  49. setVisible(visibilityToggle.visible);
  50. }
  51. }, [visibilityControlled, visibilityToggle]);
  52. // Remove Password value
  53. const removePasswordTimeout = (0, _useRemovePasswordTimeout.default)(inputRef);
  54. const onVisibleChange = () => {
  55. var _a;
  56. if (mergedDisabled) {
  57. return;
  58. }
  59. if (visible) {
  60. removePasswordTimeout();
  61. }
  62. const nextVisible = !visible;
  63. setVisible(nextVisible);
  64. if (typeof visibilityToggle === 'object') {
  65. (_a = visibilityToggle.onVisibleChange) === null || _a === void 0 ? void 0 : _a.call(visibilityToggle, nextVisible);
  66. }
  67. };
  68. const getIcon = prefixCls => {
  69. const iconTrigger = actionMap[action] || '';
  70. const icon = iconRender(visible);
  71. const iconProps = {
  72. [iconTrigger]: onVisibleChange,
  73. className: `${prefixCls}-icon`,
  74. key: 'passwordIcon',
  75. onMouseDown: e => {
  76. // Prevent focused state lost
  77. // https://github.com/ant-design/ant-design/issues/15173
  78. e.preventDefault();
  79. },
  80. onMouseUp: e => {
  81. // Prevent caret position change
  82. // https://github.com/ant-design/ant-design/issues/23524
  83. e.preventDefault();
  84. }
  85. };
  86. return /*#__PURE__*/React.cloneElement(/*#__PURE__*/React.isValidElement(icon) ? icon : /*#__PURE__*/React.createElement("span", null, icon), iconProps);
  87. };
  88. const {
  89. className,
  90. prefixCls: customizePrefixCls,
  91. inputPrefixCls: customizeInputPrefixCls,
  92. size
  93. } = props,
  94. restProps = __rest(props, ["className", "prefixCls", "inputPrefixCls", "size"]);
  95. const {
  96. getPrefixCls
  97. } = React.useContext(_configProvider.ConfigContext);
  98. const inputPrefixCls = getPrefixCls('input', customizeInputPrefixCls);
  99. const prefixCls = getPrefixCls('input-password', customizePrefixCls);
  100. const suffixIcon = visibilityToggle && getIcon(prefixCls);
  101. const inputClassName = (0, _classnames.default)(prefixCls, className, {
  102. [`${prefixCls}-${size}`]: !!size
  103. });
  104. const omittedProps = Object.assign(Object.assign({}, (0, _omit.default)(restProps, ['suffix', 'iconRender', 'visibilityToggle'])), {
  105. type: visible ? 'text' : 'password',
  106. className: inputClassName,
  107. prefixCls: inputPrefixCls,
  108. suffix: (/*#__PURE__*/React.createElement(React.Fragment, null, suffixIcon, suffix))
  109. });
  110. if (size) {
  111. omittedProps.size = size;
  112. }
  113. return /*#__PURE__*/React.createElement(_Input.default, Object.assign({
  114. ref: (0, _ref.composeRef)(ref, inputRef)
  115. }, omittedProps));
  116. });
  117. if (process.env.NODE_ENV !== 'production') {
  118. Password.displayName = 'Input.Password';
  119. }
  120. var _default = exports.default = Password;