@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
103 lines (102 loc) • 4.69 kB
JavaScript
;
"use client";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(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 _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
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