UNPKG

@dnb/eufemia

Version:

DNB Eufemia Design System UI Library

102 lines (101 loc) 4.05 kB
"use strict"; "use client"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = require("react"); var _clsx = _interopRequireDefault(require("clsx")); var _Context = _interopRequireDefault(require("../../../../shared/Context.js")); var _index = _interopRequireDefault(require("../String/index.js")); var _useId = _interopRequireDefault(require("../../../../shared/helpers/useId.js")); var _Input = require("../../../../components/Input.js"); var _view = _interopRequireDefault(require("../../../../icons/view.js")); var _hide = _interopRequireDefault(require("../../../../icons/hide.js")); var _view_medium = _interopRequireDefault(require("../../../../icons/view_medium.js")); var _hide_medium = _interopRequireDefault(require("../../../../icons/hide_medium.js")); var _useTranslation = _interopRequireDefault(require("../../hooks/useTranslation.js")); var _withComponentMarkers = _interopRequireDefault(require("../../../../shared/helpers/withComponentMarkers.js")); var _jsxRuntime = require("react/jsx-runtime"); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function Password({ id, className, ref: refProp, value, label, disabled, size, ...props }) { var _refProp$current; const generatedId = (0, _useId.default)(); const idToUse = id || generatedId; const [hidden, setHidden] = (0, _react.useState)(true); const sharedContext = (0, _react.useContext)(_Context.default); const translations = (0, _useTranslation.default)().Password; const ref = (0, _react.useRef)((_refProp$current = refProp === null || refProp === void 0 ? void 0 : refProp.current) !== null && _refProp$current !== void 0 ? _refProp$current : null); const errorMessages = (0, _react.useMemo)(() => { return { 'Field.errorRequired': translations.errorRequired, ...props.errorMessages }; }, [translations.errorRequired, props.errorMessages]); const toggleVisibility = (0, _react.useCallback)(event => { const { onShowPassword, onHidePassword } = props; const value = ref.current.value; setHidden(hidden => { hidden ? onShowPassword === null || onShowPassword === void 0 ? void 0 : onShowPassword({ ...event, value }) : onHidePassword === null || onHidePassword === void 0 ? void 0 : onHidePassword({ ...event, value }); return !hidden; }); if (ref.current) { ref.current.focus(); } }, [props]); const preventFocusChange = (0, _react.useCallback)(event => { event.preventDefault(); }, []); const toggleVisibilityButton = (0, _react.useMemo)(() => { return (0, _jsxRuntime.jsx)(_Input.SubmitButton, { id: idToUse + '-submit-button', type: "button", variant: "secondary", "aria-controls": idToUse, "aria-label": hidden ? translations.ariaLabelShow : translations.ariaLabelHide, icon: size === 'large' ? hidden ? _view_medium.default : _hide_medium.default : hidden ? _view.default : _hide.default, disabled: disabled, skeleton: sharedContext.skeleton, onMouseDown: preventFocusChange, onClick: toggleVisibility }); }, [idToUse, hidden, translations.ariaLabelShow, translations.ariaLabelHide, size, disabled, sharedContext.skeleton, preventFocusChange, toggleVisibility]); return (0, _jsxRuntime.jsx)(_index.default, { id: idToUse, className: (0, _clsx.default)('dnb-forms-field-password', className), label: label !== null && label !== void 0 ? label : translations.label, type: hidden ? 'password' : 'text', value: value, ref: ref, "aria-describedby": idToUse + '-submit-button', submitElement: toggleVisibilityButton, disabled: disabled, size: size, autoComplete: "current-password", errorMessages: errorMessages, ...props }); } var _default = exports.default = Password; (0, _withComponentMarkers.default)(Password, { _supportsSpacingProps: true }); //# sourceMappingURL=Password.js.map