@amboss/design-system 3.29.8 → 3.31.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/build/cjs/components/EntityList/EntityItemBody.js +1 -1
  2. package/build/cjs/components/Form/PasswordInput/PasswordInput.d.ts +48 -6
  3. package/build/cjs/components/Form/PasswordInput/PasswordInput.js +1 -1
  4. package/build/cjs/components/Form/PasswordInput/PasswordInputButton.d.ts +13 -0
  5. package/build/cjs/components/Form/PasswordInput/PasswordInputButton.js +1 -0
  6. package/build/cjs/components/Lightbox/Lightbox.d.ts +30 -0
  7. package/build/cjs/components/Lightbox/Lightbox.js +8 -0
  8. package/build/cjs/components/Patterns/Dialog/DialogContext.d.ts +1 -0
  9. package/build/cjs/components/Patterns/Dialog/DialogContext.js +1 -0
  10. package/build/cjs/components/Patterns/Modal/Modal.d.ts +0 -5
  11. package/build/cjs/components/Patterns/Modal/Modal.js +2 -9
  12. package/build/cjs/components/Portal/Portal.js +1 -1
  13. package/build/cjs/components/Sheet/Sheet.js +1 -1
  14. package/build/cjs/index.d.ts +1 -0
  15. package/build/cjs/index.js +1 -1
  16. package/build/cjs/shared/mediaQueries.d.ts +2 -2
  17. package/build/cjs/types/index.d.ts +2 -0
  18. package/build/cjs/types/index.js +1 -1
  19. package/build/esm/components/EntityList/EntityItemBody.js +1 -1
  20. package/build/esm/components/Form/PasswordInput/PasswordInput.d.ts +48 -6
  21. package/build/esm/components/Form/PasswordInput/PasswordInput.js +1 -1
  22. package/build/esm/components/Form/PasswordInput/PasswordInputButton.d.ts +13 -0
  23. package/build/esm/components/Form/PasswordInput/PasswordInputButton.js +1 -0
  24. package/build/esm/components/Lightbox/Lightbox.d.ts +30 -0
  25. package/build/esm/components/Lightbox/Lightbox.js +8 -0
  26. package/build/esm/components/Patterns/Dialog/DialogContext.d.ts +1 -0
  27. package/build/esm/components/Patterns/Dialog/DialogContext.js +1 -0
  28. package/build/esm/components/Patterns/Modal/Modal.d.ts +0 -5
  29. package/build/esm/components/Patterns/Modal/Modal.js +2 -9
  30. package/build/esm/components/Portal/Portal.js +1 -1
  31. package/build/esm/components/Sheet/Sheet.js +1 -1
  32. package/build/esm/index.d.ts +1 -0
  33. package/build/esm/index.js +1 -1
  34. package/build/esm/shared/mediaQueries.d.ts +2 -2
  35. package/build/esm/types/index.d.ts +2 -0
  36. package/build/esm/types/index.js +1 -1
  37. package/package.json +2 -2
  38. package/build/cjs/components/Patterns/Modal/ModalContext.d.ts +0 -1
  39. package/build/cjs/components/Patterns/Modal/ModalContext.js +0 -1
  40. package/build/esm/components/Patterns/Modal/ModalContext.d.ts +0 -1
  41. package/build/esm/components/Patterns/Modal/ModalContext.js +0 -1
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"EntityItemBody",{enumerable:!0,get:function(){return EntityItemBody}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Checkbox=require("../Form/Checkbox/Checkbox"),_EntityListItemText=require("./EntityListItemText"),_Inline=require("../Inline/Inline"),_styledcomponents=require("./styled-components"),StyledLabel=(0,_styled.default)(_styledcomponents.StyledWrapperOffset,{target:"e14o5jq10",label:"StyledLabel"})(({theme,size})=>({cursor:"pointer",display:"block",margin:`-${theme.variables.size.spacing["xs"===size?"xxs":size]} 0`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9FbnRpdHlJdGVtQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyBjbG9uZUVsZW1lbnQsIGlzVmFsaWRFbGVtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IENoZWNrYm94UmF3IH0gZnJvbSBcIi4uL0Zvcm0vQ2hlY2tib3gvQ2hlY2tib3hcIjtcbmltcG9ydCB7IEVudGl0eUxpc3RJdGVtVGV4dCB9IGZyb20gXCIuL0VudGl0eUxpc3RJdGVtVGV4dFwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFN0eWxlZFdyYXBwZXJPZmZzZXQgfSBmcm9tIFwiLi9zdHlsZWQtY29tcG9uZW50c1wiO1xuaW1wb3J0IHR5cGUgeyBFbnRpdHlMaXN0SXRlbVByb3BzIH0gZnJvbSBcIi4vdHlwZXNcIjtcblxuY29uc3QgU3R5bGVkTGFiZWwgPSBzdHlsZWQoU3R5bGVkV3JhcHBlck9mZnNldCkoKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJibG9ja1wiLFxuICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nW3NpemUgPT09IFwieHNcIiA/IFwieHhzXCIgOiBzaXplXX0gMGAsXG59KSk7XG5cbmNvbnN0IGlzQ2xpY2thYmxlRWxlbWVudCA9IChcbiAgZWxlbWVudDogUmVhY3QuUmVhY3ROb2RlXG4pOiBlbGVtZW50IGlzIFJlYWN0LlJlYWN0RWxlbWVudDxIVE1MQXR0cmlidXRlczxIVE1MRWxlbWVudD4+ID0+XG4gIGlzVmFsaWRFbGVtZW50KGVsZW1lbnQpICYmIHR5cGVvZiBlbGVtZW50LnByb3BzPy5vbkNsaWNrID09PSBcImZ1bmN0aW9uXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBFbnRpdHlJdGVtQm9keSh7XG4gIGNoZWNrYm94UHJvcHMsXG4gIGRlc2NyaXB0aW9uLFxuICByZW5kZXJMYWJlbCxcbiAgcmVuZGVyTGVmdCxcbiAgcmVuZGVyUmlnaHQsXG4gIHRhYkluZGV4LFxuICBzaXplID0gXCJtXCIsXG59OiBQYXJ0aWFsPEVudGl0eUxpc3RJdGVtUHJvcHM+KTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgdGV4dFNpemUgPSBzaXplID09PSBcInhzXCIgPyBcInNcIiA6IFwibVwiO1xuICBjb25zdCBhY3Rpb25TaXplID0gc2l6ZSA9PT0gXCJsXCIgPyBcIm1cIiA6IFwic1wiO1xuICBjb25zdCByaWdodEVsZW1lbnQgPSByZW5kZXJSaWdodD8uKHsgdGV4dFNpemUsIGFjdGlvblNpemUgfSk7XG5cbiAgcmV0dXJuIChcbiAgICA8SW5saW5lIG5vV3JhcCBhbGlnbkl0ZW1zPVwic3BhY2VCZXR3ZWVuXCIgc3BhY2U9e1tcInhzXCIsIFwibVwiXX0+XG4gICAgICB7Y2hlY2tib3hQcm9wcyA/IChcbiAgICAgICAgPFN0eWxlZExhYmVsIGFzPVwibGFiZWxcIiBzaXplPXtzaXplfT5cbiAgICAgICAgICA8SW5saW5lIG5vV3JhcCBzcGFjZT17W1wieHNcIiwgXCJtXCJdfT5cbiAgICAgICAgICAgIDxDaGVja2JveFJhdyB7Li4uY2hlY2tib3hQcm9wc30gdGFiSW5kZXg9ey0xfSAvPlxuICAgICAgICAgICAgPEVudGl0eUxpc3RJdGVtVGV4dCBzaXplPXt0ZXh0U2l6ZX0gZGVzY3JpcHRpb249e2Rlc2NyaXB0aW9ufT5cbiAgICAgICAgICAgICAge3JlbmRlckxhYmVsKHsgdGV4dFNpemUgfSl9XG4gICAgICAgICAgICA8L0VudGl0eUxpc3RJdGVtVGV4dD5cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRMYWJlbD5cbiAgICAgICkgOiAoXG4gICAgICAgIDxJbmxpbmUgbm9XcmFwIHNwYWNlPXtbXCJ4c1wiLCBcIm1cIl19PlxuICAgICAgICAgIHtyZW5kZXJMZWZ0ICYmIHJlbmRlckxlZnQoeyB0ZXh0U2l6ZSB9KX1cbiAgICAgICAgICA8RW50aXR5TGlzdEl0ZW1UZXh0IHNpemU9e3RleHRTaXplfSBkZXNjcmlwdGlvbj17ZGVzY3JpcHRpb259PlxuICAgICAgICAgICAge3JlbmRlckxhYmVsKHsgdGV4dFNpemUgfSl9XG4gICAgICAgICAgPC9FbnRpdHlMaXN0SXRlbVRleHQ+XG4gICAgICAgIDwvSW5saW5lPlxuICAgICAgKX1cblxuICAgICAge2lzQ2xpY2thYmxlRWxlbWVudChyaWdodEVsZW1lbnQpXG4gICAgICAgID8gY2xvbmVFbGVtZW50KHJpZ2h0RWxlbWVudCwge1xuICAgICAgICAgICAgdGFiSW5kZXgsXG4gICAgICAgICAgICBvbkNsaWNrOiAoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQ8SFRNTEVsZW1lbnQ+KSA9PiB7XG4gICAgICAgICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICByaWdodEVsZW1lbnQucHJvcHMub25DbGljaz8uKGV2ZW50KTtcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgfSlcbiAgICAgICAgOiByaWdodEVsZW1lbnR9XG4gICAgPC9JbmxpbmU+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9CIn0= */"),isClickableElement=element=>(0,_react.isValidElement)(element)&&"function"==typeof element.props?.onClick;function EntityItemBody({checkboxProps,description,renderLabel,renderLeft,renderRight,tabIndex,size="m"}){let textSize="xs"===size?"s":"m",rightElement=renderRight?.({textSize,actionSize:"l"===size?"m":"s"});return _react.default.createElement(_Inline.Inline,{noWrap:!0,alignItems:"spaceBetween",space:["xs","m"]},checkboxProps?_react.default.createElement(StyledLabel,{as:"label",size:size},_react.default.createElement(_Inline.Inline,{noWrap:!0,space:["xs","m"]},_react.default.createElement(_Checkbox.CheckboxRaw,{...checkboxProps,tabIndex:-1}),_react.default.createElement(_EntityListItemText.EntityListItemText,{size:textSize,description:description},renderLabel({textSize})))):_react.default.createElement(_Inline.Inline,{noWrap:!0,space:["xs","m"]},renderLeft&&renderLeft({textSize}),_react.default.createElement(_EntityListItemText.EntityListItemText,{size:textSize,description:description},renderLabel({textSize}))),isClickableElement(rightElement)?(0,_react.cloneElement)(rightElement,{tabIndex,onClick:event=>{event.stopPropagation(),rightElement.props.onClick?.(event)}}):rightElement)}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"EntityItemBody",{enumerable:!0,get:function(){return EntityItemBody}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Checkbox=require("../Form/Checkbox/Checkbox"),_EntityListItemText=require("./EntityListItemText"),_Inline=require("../Inline/Inline"),_styledcomponents=require("./styled-components"),StyledLabel=(0,_styled.default)(_styledcomponents.StyledWrapperOffset,{target:"e6yichu0",label:"StyledLabel"})(({theme,size})=>({cursor:"pointer",display:"block",margin:`-${theme.variables.size.spacing["xs"===size?"xxs":size]} 0`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9FbnRpdHlJdGVtQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyBjbG9uZUVsZW1lbnQsIGlzVmFsaWRFbGVtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IENoZWNrYm94UmF3IH0gZnJvbSBcIi4uL0Zvcm0vQ2hlY2tib3gvQ2hlY2tib3hcIjtcbmltcG9ydCB7IEVudGl0eUxpc3RJdGVtVGV4dCB9IGZyb20gXCIuL0VudGl0eUxpc3RJdGVtVGV4dFwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFN0eWxlZFdyYXBwZXJPZmZzZXQgfSBmcm9tIFwiLi9zdHlsZWQtY29tcG9uZW50c1wiO1xuaW1wb3J0IHR5cGUgeyBFbnRpdHlMaXN0SXRlbVByb3BzIH0gZnJvbSBcIi4vdHlwZXNcIjtcblxuY29uc3QgU3R5bGVkTGFiZWwgPSBzdHlsZWQoU3R5bGVkV3JhcHBlck9mZnNldCkoKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJibG9ja1wiLFxuICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nW3NpemUgPT09IFwieHNcIiA/IFwieHhzXCIgOiBzaXplXX0gMGAsXG59KSk7XG5cbmNvbnN0IGhhc0ludGVyYWN0aXZlUHJvcHMgPSAoZWxlbWVudDogUmVhY3QuUmVhY3RFbGVtZW50KTogYm9vbGVhbiA9PlxuICBbXCJvbkNsaWNrXCIsIFwib25Nb3VzZURvd25cIiwgXCJvblBvaW50ZXJEb3duXCJdLnNvbWUoXG4gICAgKHApID0+IHR5cGVvZiBlbGVtZW50LnByb3BzPy5bcF0gPT09IFwiZnVuY3Rpb25cIlxuICApO1xuXG5jb25zdCBpc0ludGVyYWN0aXZlRWxlbWVudCA9IChcbiAgZWxlbWVudDogUmVhY3QuUmVhY3ROb2RlXG4pOiBlbGVtZW50IGlzIFJlYWN0LlJlYWN0RWxlbWVudDxIVE1MQXR0cmlidXRlczxIVE1MRWxlbWVudD4+ID0+XG4gIGlzVmFsaWRFbGVtZW50KGVsZW1lbnQpICYmXG4gIChoYXNJbnRlcmFjdGl2ZVByb3BzKGVsZW1lbnQpIHx8IFwiaHJlZlwiIGluIChlbGVtZW50LnByb3BzID8/IHt9KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBFbnRpdHlJdGVtQm9keSh7XG4gIGNoZWNrYm94UHJvcHMsXG4gIGRlc2NyaXB0aW9uLFxuICByZW5kZXJMYWJlbCxcbiAgcmVuZGVyTGVmdCxcbiAgcmVuZGVyUmlnaHQsXG4gIHRhYkluZGV4LFxuICBzaXplID0gXCJtXCIsXG59OiBQYXJ0aWFsPEVudGl0eUxpc3RJdGVtUHJvcHM+KTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgdGV4dFNpemUgPSBzaXplID09PSBcInhzXCIgPyBcInNcIiA6IFwibVwiO1xuICBjb25zdCBhY3Rpb25TaXplID0gc2l6ZSA9PT0gXCJsXCIgPyBcIm1cIiA6IFwic1wiO1xuICBjb25zdCByaWdodEVsZW1lbnQgPSByZW5kZXJSaWdodD8uKHsgdGV4dFNpemUsIGFjdGlvblNpemUgfSk7XG5cbiAgcmV0dXJuIChcbiAgICA8SW5saW5lIG5vV3JhcCBhbGlnbkl0ZW1zPVwic3BhY2VCZXR3ZWVuXCIgc3BhY2U9e1tcInhzXCIsIFwibVwiXX0+XG4gICAgICB7Y2hlY2tib3hQcm9wcyA/IChcbiAgICAgICAgPFN0eWxlZExhYmVsIGFzPVwibGFiZWxcIiBzaXplPXtzaXplfT5cbiAgICAgICAgICA8SW5saW5lIG5vV3JhcCBzcGFjZT17W1wieHNcIiwgXCJtXCJdfT5cbiAgICAgICAgICAgIDxDaGVja2JveFJhdyB7Li4uY2hlY2tib3hQcm9wc30gdGFiSW5kZXg9ey0xfSAvPlxuICAgICAgICAgICAgPEVudGl0eUxpc3RJdGVtVGV4dCBzaXplPXt0ZXh0U2l6ZX0gZGVzY3JpcHRpb249e2Rlc2NyaXB0aW9ufT5cbiAgICAgICAgICAgICAge3JlbmRlckxhYmVsKHsgdGV4dFNpemUgfSl9XG4gICAgICAgICAgICA8L0VudGl0eUxpc3RJdGVtVGV4dD5cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRMYWJlbD5cbiAgICAgICkgOiAoXG4gICAgICAgIDxJbmxpbmUgbm9XcmFwIHNwYWNlPXtbXCJ4c1wiLCBcIm1cIl19PlxuICAgICAgICAgIHtyZW5kZXJMZWZ0ICYmIHJlbmRlckxlZnQoeyB0ZXh0U2l6ZSB9KX1cbiAgICAgICAgICA8RW50aXR5TGlzdEl0ZW1UZXh0IHNpemU9e3RleHRTaXplfSBkZXNjcmlwdGlvbj17ZGVzY3JpcHRpb259PlxuICAgICAgICAgICAge3JlbmRlckxhYmVsKHsgdGV4dFNpemUgfSl9XG4gICAgICAgICAgPC9FbnRpdHlMaXN0SXRlbVRleHQ+XG4gICAgICAgIDwvSW5saW5lPlxuICAgICAgKX1cblxuICAgICAge2lzSW50ZXJhY3RpdmVFbGVtZW50KHJpZ2h0RWxlbWVudClcbiAgICAgICAgPyBjbG9uZUVsZW1lbnQocmlnaHRFbGVtZW50LCB7XG4gICAgICAgICAgICB0YWJJbmRleCxcbiAgICAgICAgICAgIG9uQ2xpY2s6IChldmVudDogUmVhY3QuTW91c2VFdmVudDxIVE1MRWxlbWVudD4pID0+IHtcbiAgICAgICAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgICAgICAgIHJpZ2h0RWxlbWVudC5wcm9wcy5vbkNsaWNrPy4oZXZlbnQpO1xuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIC4uLihyaWdodEVsZW1lbnQucHJvcHMub25Nb3VzZURvd24gJiYge1xuICAgICAgICAgICAgICBvbk1vdXNlRG93bjogKGV2ZW50OiBSZWFjdC5Nb3VzZUV2ZW50PEhUTUxFbGVtZW50PikgPT4ge1xuICAgICAgICAgICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICAgIHJpZ2h0RWxlbWVudC5wcm9wcy5vbk1vdXNlRG93bj8uKGV2ZW50KTtcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgLi4uKHJpZ2h0RWxlbWVudC5wcm9wcy5vblBvaW50ZXJEb3duICYmIHtcbiAgICAgICAgICAgICAgb25Qb2ludGVyRG93bjogKGV2ZW50OiBSZWFjdC5Qb2ludGVyRXZlbnQ8SFRNTEVsZW1lbnQ+KSA9PiB7XG4gICAgICAgICAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgICAgICAgICAgcmlnaHRFbGVtZW50LnByb3BzLm9uUG9pbnRlckRvd24/LihldmVudCk7XG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9KSxcbiAgICAgICAgICB9KVxuICAgICAgICA6IHJpZ2h0RWxlbWVudH1cbiAgICA8L0lubGluZT5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVb0IifQ== */"),hasInteractiveProps=element=>["onClick","onMouseDown","onPointerDown"].some(p=>"function"==typeof element.props?.[p]),isInteractiveElement=element=>(0,_react.isValidElement)(element)&&(hasInteractiveProps(element)||"href"in(element.props??{}));function EntityItemBody({checkboxProps,description,renderLabel,renderLeft,renderRight,tabIndex,size="m"}){let textSize="xs"===size?"s":"m",rightElement=renderRight?.({textSize,actionSize:"l"===size?"m":"s"});return _react.default.createElement(_Inline.Inline,{noWrap:!0,alignItems:"spaceBetween",space:["xs","m"]},checkboxProps?_react.default.createElement(StyledLabel,{as:"label",size:size},_react.default.createElement(_Inline.Inline,{noWrap:!0,space:["xs","m"]},_react.default.createElement(_Checkbox.CheckboxRaw,{...checkboxProps,tabIndex:-1}),_react.default.createElement(_EntityListItemText.EntityListItemText,{size:textSize,description:description},renderLabel({textSize})))):_react.default.createElement(_Inline.Inline,{noWrap:!0,space:["xs","m"]},renderLeft&&renderLeft({textSize}),_react.default.createElement(_EntityListItemText.EntityListItemText,{size:textSize,description:description},renderLabel({textSize}))),isInteractiveElement(rightElement)?(0,_react.cloneElement)(rightElement,{tabIndex,onClick:event=>{event.stopPropagation(),rightElement.props.onClick?.(event)},...rightElement.props.onMouseDown&&{onMouseDown:event=>{event.stopPropagation(),rightElement.props.onMouseDown?.(event)}},...rightElement.props.onPointerDown&&{onPointerDown:event=>{event.stopPropagation(),rightElement.props.onPointerDown?.(event)}}}):rightElement)}
@@ -2,7 +2,21 @@ import type { InputHTMLAttributes } from "react";
2
2
  import React from "react";
3
3
  import type { FormFieldProps } from "../FormField/FormField";
4
4
  export type PasswordInputProps = {
5
- iconAriaLabel: string;
5
+ /**
6
+ * Props for sub-components.
7
+ *
8
+ * - `toggleVisibility.ariaLabelShow` — Label for screen readers when the icon can be toggled to show the password
9
+ *
10
+ * - `toggleVisibility.ariaLabelHide` — Label for screen readers when the icon can be toggled to hide the password
11
+ */
12
+ slotProps: {
13
+ toggleVisibility: {
14
+ /** Label for screen readers when icon can be toggled to show password */
15
+ ariaLabelShow: string;
16
+ /** Label for screen readers when icon can be toggled to hide password */
17
+ ariaLabelHide: string;
18
+ };
19
+ };
6
20
  } & InputProps;
7
21
  type InputProps = {
8
22
  /**
@@ -10,31 +24,59 @@ type InputProps = {
10
24
  */
11
25
  hasError?: boolean;
12
26
  /**
13
- * Set to true to disabled input
27
+ * Function for on icon click behavior
14
28
  */
15
29
  onIconClick?: (e: React.MouseEvent) => void;
16
30
  } & FormFieldProps & Omit<InputHTMLAttributes<HTMLInputElement>, "type">;
17
31
  export declare const PasswordInputRaw: React.ForwardRefExoticComponent<{
18
- iconAriaLabel: string;
32
+ /**
33
+ * Props for sub-components.
34
+ *
35
+ * - `toggleVisibility.ariaLabelShow` — Label for screen readers when the icon can be toggled to show the password
36
+ *
37
+ * - `toggleVisibility.ariaLabelHide` — Label for screen readers when the icon can be toggled to hide the password
38
+ */
39
+ slotProps: {
40
+ toggleVisibility: {
41
+ /** Label for screen readers when icon can be toggled to show password */
42
+ ariaLabelShow: string;
43
+ /** Label for screen readers when icon can be toggled to hide password */
44
+ ariaLabelHide: string;
45
+ };
46
+ };
19
47
  } & {
20
48
  /**
21
49
  * Set to true to toggle error state
22
50
  */
23
51
  hasError?: boolean;
24
52
  /**
25
- * Set to true to disabled input
53
+ * Function for on icon click behavior
26
54
  */
27
55
  onIconClick?: (e: React.MouseEvent) => void;
28
56
  } & FormFieldProps & Omit<InputHTMLAttributes<HTMLInputElement>, "type"> & React.RefAttributes<HTMLInputElement>>;
29
57
  export declare const PasswordInput: React.ForwardRefExoticComponent<{
30
- iconAriaLabel: string;
58
+ /**
59
+ * Props for sub-components.
60
+ *
61
+ * - `toggleVisibility.ariaLabelShow` — Label for screen readers when the icon can be toggled to show the password
62
+ *
63
+ * - `toggleVisibility.ariaLabelHide` — Label for screen readers when the icon can be toggled to hide the password
64
+ */
65
+ slotProps: {
66
+ toggleVisibility: {
67
+ /** Label for screen readers when icon can be toggled to show password */
68
+ ariaLabelShow: string;
69
+ /** Label for screen readers when icon can be toggled to hide password */
70
+ ariaLabelHide: string;
71
+ };
72
+ };
31
73
  } & {
32
74
  /**
33
75
  * Set to true to toggle error state
34
76
  */
35
77
  hasError?: boolean;
36
78
  /**
37
- * Set to true to disabled input
79
+ * Function for on icon click behavior
38
80
  */
39
81
  onIconClick?: (e: React.MouseEvent) => void;
40
82
  } & FormFieldProps & Omit<InputHTMLAttributes<HTMLInputElement>, "type"> & React.RefAttributes<HTMLInputElement>>;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get PasswordInput(){return PasswordInput},get PasswordInputRaw(){return PasswordInputRaw}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../../Icon/Icon"),_FormField=require("../FormField/FormField"),_useFormFieldMessageId=require("../FormField/useFormFieldMessageId"),handleBorderColor=(theme,hasError,readOnly)=>hasError?theme.values.color.border.error.default:readOnly?theme.values.color.border.primary.disabled:theme.values.color.border.primary.default,handleIconBorderColor=(theme,hasError)=>hasError?theme.values.color.icon.error.default:"transparent",handleIconLeftBorderColor=(theme,hasError)=>hasError?theme.values.color.border.error.default:theme.values.color.border.primary.default,StyledContainer=(0,_styled.default)("div",{target:"e1ro5src0",label:"StyledContainer"})(()=>({width:"100%",display:"flex",alignItems:"center",flexDirection:"row",position:"relative"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.hover,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuDwB"} */"),StyledIconBtn=(0,_styled.default)("button",{target:"e1ro5src1",label:"StyledIconBtn"})(({theme,hasError})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},position:"absolute",top:0,right:0,border:"1px solid",borderColor:handleIconBorderColor(theme,hasError),borderLeftColor:handleIconLeftBorderColor(theme,hasError),padding:`calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,borderRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:"0",borderTopLeftRadius:"0",color:theme.values.color.text.secondary.default,backgroundColor:"inherit",cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover,borderColor:theme.values.color.border.primary.hover},"&:active":{color:theme.values.color.text.primary.default,backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default,borderLeftColor:theme.values.color.border.primary.disabled,pointerEvents:"none"},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`},"& svg":{pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.hover,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AAkEsB"} */"),StyledPasswordInput=(0,_styled.default)("input",{target:"e1ro5src2",label:"StyledPasswordInput"})(({theme,hasError,readOnly})=>({fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,borderRadius:theme.variables.size.borderRadius.xs,borderWidth:"1px",borderStyle:"solid",width:"100%",padding:`calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,paddingRight:theme.variables.size.spacing.xxl,boxSizing:"border-box",color:theme.values.color.text.secondary.default,borderColor:handleBorderColor(theme,hasError,readOnly),backgroundColor:theme.values.color.background.primary.default,"&.error":{borderColor:theme.values.color.border.error.default},"&.has-icon":{paddingRight:theme.variables.size.spacing.xs+theme.variables.size.dimension.icon.m},"&::placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default,opacity:theme.variables.opacity.visible},"&:-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},"&::-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.hover,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AA2G4B"} */"),PasswordInputRaw=(0,_react.forwardRef)(({placeholder,hasError=!1,onIconClick,iconAriaLabel,readOnly,disabled,...rest},ref)=>{let[inputType,setInputType]=(0,_react.useState)("password"),currentType="password"===inputType?"text":"password";return _react.default.createElement(StyledContainer,null,_react.default.createElement(StyledPasswordInput,{...rest,type:inputType,placeholder:!readOnly&&placeholder,ref:ref,hasError:hasError,readOnly:readOnly,disabled:disabled,"aria-invalid":hasError}),_react.default.createElement(StyledIconBtn,{onClick:e=>{disabled&&e.preventDefault(),onIconClick&&onIconClick(e),setInputType(currentType)},hasError:hasError,disabled:readOnly||disabled,"aria-label":iconAriaLabel,type:"button"},_react.default.createElement(_Icon.Icon,{name:"password"===inputType?"eye-off":"eye",size:"s",color:readOnly?"quaternary":"tertiary"})))}),PasswordInput=_react.default.forwardRef(({placeholder="••••••••",hasError=!1,onIconClick,autoComplete="on",iconAriaLabel,disabled,label,labelHint,hideLabel,hint,errorMessages,"aria-describedby":ariaDescribedBy,"data-e2e-test-id":dataE2eTestId,...rest},ref)=>{let{id,ariaDescribedByProp}=(0,_useFormFieldMessageId.useFormFieldMessageId)({ariaDescribedBy,errorMessages,hint});return _react.default.createElement(_FormField.FormField,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PasswordInput",disabled:disabled,label:label,labelHint:labelHint,hideLabel:hideLabel,hint:hint,errorMessages:errorMessages,messageId:id},_react.default.createElement(PasswordInputRaw,{...rest,ref:ref,placeholder:placeholder,hasError:hasError,disabled:disabled,onIconClick:onIconClick,autoComplete:autoComplete,iconAriaLabel:iconAriaLabel,...ariaDescribedByProp}))});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get PasswordInput(){return PasswordInput},get PasswordInputRaw(){return PasswordInputRaw}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_FormField=require("../FormField/FormField"),_useFormFieldMessageId=require("../FormField/useFormFieldMessageId"),_PasswordInputButton=require("./PasswordInputButton"),handleBorderColor=(theme,hasError,readOnly)=>hasError?theme.values.color.border.error.default:readOnly?theme.values.color.border.primary.disabled:theme.values.color.border.primary.default,StyledContainer=(0,_styled.default)("div",{target:"e3t34vm0",label:"StyledContainer"})(()=>({width:"100%",display:"flex",alignItems:"center",flexDirection:"row",position:"relative"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\nimport { PasswordInputButton } from \"./PasswordInputButton\";\n\nexport type PasswordInputProps = {\n  /**\n   * Props for sub-components.\n   *\n   * - `toggleVisibility.ariaLabelShow` — Label for screen readers when the icon can be toggled to show the password\n   *\n   * - `toggleVisibility.ariaLabelHide` — Label for screen readers when the icon can be toggled to hide the password\n   */\n  slotProps: {\n    toggleVisibility: {\n      /** Label for screen readers when icon can be toggled to show password */\n      ariaLabelShow: string;\n      /** Label for screen readers when icon can be toggled to hide password */\n      ariaLabelHide: string;\n    };\n  };\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Function for on icon click behavior\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      readOnly,\n      disabled,\n      slotProps: {\n        toggleVisibility: { ariaLabelShow, ariaLabelHide },\n      },\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [isPasswordVisible, setIsPasswordVisible] = useState(false);\n    const inputType = isPasswordVisible ? \"text\" : \"password\";\n    const ariaLabel = isPasswordVisible ? ariaLabelHide : ariaLabelShow;\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <PasswordInputButton\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          isPasswordVisible={isPasswordVisible}\n          readOnly={readOnly}\n          ariaLabel={ariaLabel}\n          onToggle={() => setIsPasswordVisible((prev) => !prev)}\n        />\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      slotProps,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          slotProps={slotProps}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AAoDwB"} */"),StyledPasswordInput=(0,_styled.default)("input",{target:"e3t34vm1",label:"StyledPasswordInput"})(({theme,hasError,readOnly})=>({fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,borderRadius:theme.variables.size.borderRadius.xs,borderWidth:"1px",borderStyle:"solid",width:"100%",padding:`calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,paddingRight:theme.variables.size.spacing.xxl,boxSizing:"border-box",color:theme.values.color.text.secondary.default,borderColor:handleBorderColor(theme,hasError,readOnly),backgroundColor:theme.values.color.background.primary.default,"&.error":{borderColor:theme.values.color.border.error.default},"&.has-icon":{paddingRight:theme.variables.size.spacing.xs+theme.variables.size.dimension.icon.m},"&::placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default,opacity:theme.variables.opacity.visible},"&:-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},"&::-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\nimport { PasswordInputButton } from \"./PasswordInputButton\";\n\nexport type PasswordInputProps = {\n  /**\n   * Props for sub-components.\n   *\n   * - `toggleVisibility.ariaLabelShow` — Label for screen readers when the icon can be toggled to show the password\n   *\n   * - `toggleVisibility.ariaLabelHide` — Label for screen readers when the icon can be toggled to hide the password\n   */\n  slotProps: {\n    toggleVisibility: {\n      /** Label for screen readers when icon can be toggled to show password */\n      ariaLabelShow: string;\n      /** Label for screen readers when icon can be toggled to hide password */\n      ariaLabelHide: string;\n    };\n  };\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Function for on icon click behavior\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      readOnly,\n      disabled,\n      slotProps: {\n        toggleVisibility: { ariaLabelShow, ariaLabelHide },\n      },\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [isPasswordVisible, setIsPasswordVisible] = useState(false);\n    const inputType = isPasswordVisible ? \"text\" : \"password\";\n    const ariaLabel = isPasswordVisible ? ariaLabelHide : ariaLabelShow;\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <PasswordInputButton\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          isPasswordVisible={isPasswordVisible}\n          readOnly={readOnly}\n          ariaLabel={ariaLabel}\n          onToggle={() => setIsPasswordVisible((prev) => !prev)}\n        />\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      slotProps,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          slotProps={slotProps}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AA+D4B"} */"),PasswordInputRaw=(0,_react.forwardRef)(({placeholder,hasError=!1,onIconClick,readOnly,disabled,slotProps:{toggleVisibility:{ariaLabelShow,ariaLabelHide}},...rest},ref)=>{let[isPasswordVisible,setIsPasswordVisible]=(0,_react.useState)(!1);return _react.default.createElement(StyledContainer,null,_react.default.createElement(StyledPasswordInput,{...rest,type:isPasswordVisible?"text":"password",placeholder:!readOnly&&placeholder,ref:ref,hasError:hasError,readOnly:readOnly,disabled:disabled,"aria-invalid":hasError}),_react.default.createElement(_PasswordInputButton.PasswordInputButton,{hasError:hasError,disabled:disabled,onIconClick:onIconClick,isPasswordVisible:isPasswordVisible,readOnly:readOnly,ariaLabel:isPasswordVisible?ariaLabelHide:ariaLabelShow,onToggle:()=>setIsPasswordVisible(prev=>!prev)}))}),PasswordInput=_react.default.forwardRef(({placeholder="••••••••",hasError=!1,onIconClick,autoComplete="on",slotProps,disabled,label,labelHint,hideLabel,hint,errorMessages,"aria-describedby":ariaDescribedBy,"data-e2e-test-id":dataE2eTestId,...rest},ref)=>{let{id,ariaDescribedByProp}=(0,_useFormFieldMessageId.useFormFieldMessageId)({ariaDescribedBy,errorMessages,hint});return _react.default.createElement(_FormField.FormField,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PasswordInput",disabled:disabled,label:label,labelHint:labelHint,hideLabel:hideLabel,hint:hint,errorMessages:errorMessages,messageId:id},_react.default.createElement(PasswordInputRaw,{...rest,ref:ref,placeholder:placeholder,hasError:hasError,disabled:disabled,onIconClick:onIconClick,autoComplete:autoComplete,slotProps:slotProps,...ariaDescribedByProp}))});
@@ -0,0 +1,13 @@
1
+ import type { ReactElement } from "react";
2
+ import React from "react";
3
+ type PasswordInputButtonProps = {
4
+ onIconClick?: (e: React.MouseEvent) => void;
5
+ hasError: boolean;
6
+ disabled: boolean;
7
+ readOnly: boolean;
8
+ ariaLabel: string;
9
+ isPasswordVisible: boolean;
10
+ onToggle: () => void;
11
+ };
12
+ export declare const PasswordInputButton: ({ hasError, disabled, onIconClick, readOnly, ariaLabel, isPasswordVisible, onToggle, }: PasswordInputButtonProps) => ReactElement;
13
+ export {};
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PasswordInputButton",{enumerable:!0,get:function(){return PasswordInputButton}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../../Icon/Icon"),_ScreenReaderText=require("../../Utilities/ScreenReaderText/ScreenReaderText"),handleIconBorderColor=(theme,hasError)=>hasError?theme.values.color.icon.error.default:"transparent",handleIconLeftBorderColor=(theme,hasError)=>hasError?theme.values.color.border.error.default:theme.values.color.border.primary.default,handleClick=({e,disabled,onIconClick,onToggle})=>{disabled&&e.preventDefault(),onIconClick?.(e),onToggle()},StyledIconBtn=(0,_styled.default)("button",{target:"e94fqmq0",label:"StyledIconBtn"})(({theme,hasError})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},position:"absolute",top:0,right:0,border:"1px solid",borderColor:handleIconBorderColor(theme,hasError),borderLeftColor:handleIconLeftBorderColor(theme,hasError),padding:`calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,borderRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:"0",borderTopLeftRadius:"0",color:theme.values.color.text.secondary.default,backgroundColor:"inherit",cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover,borderColor:theme.values.color.border.primary.hover},"&:active":{color:theme.values.color.text.primary.default,backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default,borderLeftColor:theme.values.color.border.primary.disabled,pointerEvents:"none"},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`},"& svg":{pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9QYXNzd29yZElucHV0L1Bhc3N3b3JkSW5wdXRCdXR0b24udHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1Bhc3N3b3JkSW5wdXQvUGFzc3dvcmRJbnB1dEJ1dHRvbi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZWFjdEVsZW1lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyB1c2VJZCwgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gXCIuLi8uLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFNjcmVlblJlYWRlclRleHQgfSBmcm9tIFwiLi4vLi4vVXRpbGl0aWVzL1NjcmVlblJlYWRlclRleHQvU2NyZWVuUmVhZGVyVGV4dFwiO1xuXG50eXBlIFBhc3N3b3JkSW5wdXRCdXR0b25Qcm9wcyA9IHtcbiAgb25JY29uQ2xpY2s/OiAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4gdm9pZDtcbiAgaGFzRXJyb3I6IGJvb2xlYW47XG4gIGRpc2FibGVkOiBib29sZWFuO1xuICByZWFkT25seTogYm9vbGVhbjtcbiAgYXJpYUxhYmVsOiBzdHJpbmc7XG4gIGlzUGFzc3dvcmRWaXNpYmxlOiBib29sZWFuO1xuICBvblRvZ2dsZTogKCkgPT4gdm9pZDtcbn07XG5cbnR5cGUgSWNvblByb3BzID0ge1xuICBoYXNFcnJvcj86IGJvb2xlYW47XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgb25DaGFuZ2U/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICB0YWJJbmRleD86IG51bWJlcjtcbn07XG5cbmNvbnN0IGhhbmRsZUljb25Cb3JkZXJDb2xvciA9ICh0aGVtZTogVGhlbWUsIGhhc0Vycm9yOiBib29sZWFuKSA9PiB7XG4gIGlmIChoYXNFcnJvcikgcmV0dXJuIHRoZW1lLnZhbHVlcy5jb2xvci5pY29uLmVycm9yLmRlZmF1bHQ7XG4gIHJldHVybiBcInRyYW5zcGFyZW50XCI7XG59O1xuXG5jb25zdCBoYW5kbGVJY29uTGVmdEJvcmRlckNvbG9yID0gKHRoZW1lOiBUaGVtZSwgaGFzRXJyb3I6IGJvb2xlYW4pID0+IHtcbiAgaWYgKGhhc0Vycm9yKSByZXR1cm4gdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5lcnJvci5kZWZhdWx0O1xuICByZXR1cm4gdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmRlZmF1bHQ7XG59O1xuXG5jb25zdCBoYW5kbGVDbGljayA9ICh7XG4gIGUsXG4gIGRpc2FibGVkLFxuICBvbkljb25DbGljayxcbiAgb25Ub2dnbGUsXG59OiB7XG4gIGU6IFJlYWN0Lk1vdXNlRXZlbnQ7XG4gIGRpc2FibGVkOiBQYXNzd29yZElucHV0QnV0dG9uUHJvcHNbXCJkaXNhYmxlZFwiXTtcbiAgb25JY29uQ2xpY2s6IFBhc3N3b3JkSW5wdXRCdXR0b25Qcm9wc1tcIm9uSWNvbkNsaWNrXCJdO1xuICBvblRvZ2dsZTogUGFzc3dvcmRJbnB1dEJ1dHRvblByb3BzW1wib25Ub2dnbGVcIl07XG59KSA9PiB7XG4gIGlmIChkaXNhYmxlZCkge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgfVxuICBvbkljb25DbGljaz8uKGUpO1xuICBvblRvZ2dsZSgpO1xufTtcblxuY29uc3QgU3R5bGVkSWNvbkJ0biA9IHN0eWxlZC5idXR0b248SWNvblByb3BzPigoeyB0aGVtZSwgaGFzRXJyb3IgfSkgPT4gKHtcbiAgXCImW3R5cGU9J2J1dHRvbiddXCI6IHtcbiAgICBhcHBlYXJhbmNlOiBcIm5vbmVcIixcbiAgICBNb3pBcHBlYXJhbmNlOiBcIm5vbmVcIixcbiAgICBXZWJraXRBcHBlYXJhbmNlOiBcIm5vbmVcIixcbiAgfSxcbiAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgdG9wOiAwLFxuICByaWdodDogMCxcbiAgYm9yZGVyOiBcIjFweCBzb2xpZFwiLFxuICBib3JkZXJDb2xvcjogaGFuZGxlSWNvbkJvcmRlckNvbG9yKHRoZW1lLCBoYXNFcnJvciksXG4gIGJvcmRlckxlZnRDb2xvcjogaGFuZGxlSWNvbkxlZnRCb3JkZXJDb2xvcih0aGVtZSwgaGFzRXJyb3IpLFxuICBwYWRkaW5nOiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gLSAxcHgpICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcIjBcIixcbiAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCIwXCIsXG4gIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5zZWNvbmRhcnkuZGVmYXVsdCxcbiAgYmFja2dyb3VuZENvbG9yOiBcImluaGVyaXRcIixcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmhvdmVyLFxuICAgIGJvcmRlckNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnByaW1hcnkuaG92ZXIsXG4gIH0sXG4gIFwiJjphY3RpdmVcIjoge1xuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5hY3RpdmUsXG4gICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIucHJpbWFyeS5hY3RpdmUsXG4gIH0sXG4gIFwiJjpkaXNhYmxlZFwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgIGJvcmRlckxlZnRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmRpc2FibGVkLFxuICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICB9LFxuICAuLi4oaGFzRXJyb3IgJiYge1xuICAgIGJveFNoYWRvdzogYDAgMCAwIDFweCBpbnNldCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuZXJyb3IuZGVmYXVsdH1gLFxuICB9KSxcbiAgXCImIHN2Z1wiOiB7XG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCIsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBQYXNzd29yZElucHV0QnV0dG9uID0gKHtcbiAgaGFzRXJyb3IsXG4gIGRpc2FibGVkLFxuICBvbkljb25DbGljayxcbiAgcmVhZE9ubHksXG4gIGFyaWFMYWJlbCxcbiAgaXNQYXNzd29yZFZpc2libGUsXG4gIG9uVG9nZ2xlLFxufTogUGFzc3dvcmRJbnB1dEJ1dHRvblByb3BzKTogUmVhY3RFbGVtZW50ID0+IHtcbiAgY29uc3QgW2lzQnV0dG9uRm9jdXNlZCwgc2V0SXNCdXR0b25Gb2N1c2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3Qgc2NyZWVuUmVhZGVyVGV4dElkID0gdXNlSWQoKTtcbiAgY29uc3Qgc2NyZWVuUmVhZGVyVGV4dCA9IGlzQnV0dG9uRm9jdXNlZCA/IGFyaWFMYWJlbCA6IFwiXCI7XG4gIGNvbnN0IGV5ZUljb24gPSBpc1Bhc3N3b3JkVmlzaWJsZSA/IFwiZXllXCIgOiBcImV5ZS1vZmZcIjtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8U2NyZWVuUmVhZGVyVGV4dCBpZD17c2NyZWVuUmVhZGVyVGV4dElkfT5cbiAgICAgICAge3NjcmVlblJlYWRlclRleHR9XG4gICAgICA8L1NjcmVlblJlYWRlclRleHQ+XG4gICAgICA8U3R5bGVkSWNvbkJ0blxuICAgICAgICBvbkNsaWNrPXsoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgICAgICAgIGhhbmRsZUNsaWNrKHsgZSwgZGlzYWJsZWQsIG9uSWNvbkNsaWNrLCBvblRvZ2dsZSB9KTtcbiAgICAgICAgfX1cbiAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICBvbkZvY3VzPXsoKSA9PiBzZXRJc0J1dHRvbkZvY3VzZWQodHJ1ZSl9XG4gICAgICAgIG9uQmx1cj17KCkgPT4gc2V0SXNCdXR0b25Gb2N1c2VkKGZhbHNlKX1cbiAgICAgICAgZGlzYWJsZWQ9e3JlYWRPbmx5IHx8IGRpc2FibGVkfVxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgYXJpYS1sYWJlbGxlZGJ5PXtzY3JlZW5SZWFkZXJUZXh0SWR9XG4gICAgICA+XG4gICAgICAgIDxJY29uXG4gICAgICAgICAgbmFtZT17ZXllSWNvbn1cbiAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgY29sb3I9e3JlYWRPbmx5ID8gXCJxdWF0ZXJuYXJ5XCIgOiBcInRlcnRpYXJ5XCJ9XG4gICAgICAgIC8+XG4gICAgICA8L1N0eWxlZEljb25CdG4+XG4gICAgPC8+XG4gICk7XG59O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9Ec0IifQ== */"),PasswordInputButton=({hasError,disabled,onIconClick,readOnly,ariaLabel,isPasswordVisible,onToggle})=>{let[isButtonFocused,setIsButtonFocused]=(0,_react.useState)(!1),screenReaderTextId=(0,_react.useId)();return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(_ScreenReaderText.ScreenReaderText,{id:screenReaderTextId},isButtonFocused?ariaLabel:""),_react.default.createElement(StyledIconBtn,{onClick:e=>{handleClick({e,disabled,onIconClick,onToggle})},hasError:hasError,onFocus:()=>setIsButtonFocused(!0),onBlur:()=>setIsButtonFocused(!1),disabled:readOnly||disabled,type:"button","aria-labelledby":screenReaderTextId},_react.default.createElement(_Icon.Icon,{name:isPasswordVisible?"eye":"eye-off",size:"s",color:readOnly?"quaternary":"tertiary"})))};
@@ -0,0 +1,30 @@
1
+ import React, { type PropsWithChildren, type RefObject } from "react";
2
+ import type { LightboxVerticalAlignment, MQ } from "src/types";
3
+ import { type PortalProps } from "../Portal/Portal";
4
+ export type LightboxProps = React.HTMLAttributes<HTMLDivElement> & {
5
+ children?: React.ReactNode[] | React.ReactNode;
6
+ backdropRef?: RefObject<HTMLDivElement>;
7
+ handleClose?: () => void;
8
+ isDismissible?: boolean;
9
+ justifyContent?: MQ<LightboxVerticalAlignment> | LightboxVerticalAlignment;
10
+ privateProps?: {
11
+ skipPortal?: boolean;
12
+ /**
13
+ * @internal
14
+ * Options passed to focus-trap's tabbable detection.
15
+ * Use `{ displayCheck: "none" }` for testing to avoid JSDOM visibility issues.
16
+ */
17
+ tabbableOptions?: {
18
+ displayCheck?: "full" | "legacy-full" | "non-zero-area" | "none";
19
+ };
20
+ };
21
+ } & Pick<PortalProps, "portalContainer">;
22
+ export declare const StyledBackdrop: import("@emotion/styled").StyledComponent<{
23
+ theme?: import("@emotion/react").Theme;
24
+ as?: React.ElementType;
25
+ } & Pick<LightboxProps, "justifyContent">, React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
26
+ export declare const StyledChildrenWrapper: import("@emotion/styled").StyledComponent<{
27
+ theme?: import("@emotion/react").Theme;
28
+ as?: React.ElementType;
29
+ }, React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
30
+ export declare function Lightbox({ backdropRef, portalContainer, isDismissible, children, handleClose, justifyContent, privateProps: { skipPortal, tabbableOptions }, }: PropsWithChildren<LightboxProps>): React.ReactElement;
@@ -0,0 +1,8 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get Lightbox(){return Lightbox},get StyledBackdrop(){return StyledBackdrop},get StyledChildrenWrapper(){return StyledChildrenWrapper}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_Portal=require("../Portal/Portal"),_FocusTrapWrapper=require("../../shared/FocusTrapWrapper"),_mediaQueries=require("../../shared/mediaQueries"),_DialogContext=require("../Patterns/Dialog/DialogContext"),StyledBackdrop=(0,_styled.default)("div",{target:"e1575mg10",label:"StyledBackdrop"})(({theme,justifyContent})=>{let fadeInBackdrop=(0,_react1.keyframes)`
2
+ from {
3
+ opacity: ${theme.variables.opacity.hidden};
4
+ }
5
+ to {
6
+ opacity: ${theme.variables.opacity.visible};
7
+ }
8
+ `;return{position:"fixed",top:0,left:0,zIndex:theme.variables.zIndex.modal,width:"100%",height:"100dvh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",...(0,_mediaQueries.useResponsiveStyles)({justifyContent:[justifyContent,{top:"flex-start",center:"center"}]}),alignItems:"center",flex:"1 0 auto",animation:`${fadeInBackdrop} ${theme.variables.animation.modalBackdrop.open.duration} ${theme.variables.animation.modalBackdrop.open.timingFunction} both`}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAganVzdGlmeUNvbnRlbnQ/OiBNUTxMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50PiB8IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQ7XG4gIHByaXZhdGVQcm9wcz86IHtcbiAgICBza2lwUG9ydGFsPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBAaW50ZXJuYWxcbiAgICAgKiBPcHRpb25zIHBhc3NlZCB0byBmb2N1cy10cmFwJ3MgdGFiYmFibGUgZGV0ZWN0aW9uLlxuICAgICAqIFVzZSBgeyBkaXNwbGF5Q2hlY2s6IFwibm9uZVwiIH1gIGZvciB0ZXN0aW5nIHRvIGF2b2lkIEpTRE9NIHZpc2liaWxpdHkgaXNzdWVzLlxuICAgICAqL1xuICAgIHRhYmJhYmxlT3B0aW9ucz86IHtcbiAgICAgIGRpc3BsYXlDaGVjaz86IFwiZnVsbFwiIHwgXCJsZWdhY3ktZnVsbFwiIHwgXCJub24temVyby1hcmVhXCIgfCBcIm5vbmVcIjtcbiAgICB9O1xuICB9O1xufSAmIFBpY2s8UG9ydGFsUHJvcHMsIFwicG9ydGFsQ29udGFpbmVyXCI+O1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQmFja2Ryb3AgPSBzdHlsZWQuZGl2PFBpY2s8TGlnaHRib3hQcm9wcywgXCJqdXN0aWZ5Q29udGVudFwiPj4oXG4gICh7IHRoZW1lLCBqdXN0aWZ5Q29udGVudCB9KSA9PiB7XG4gICAgY29uc3QgZmFkZUluQmFja2Ryb3AgPSBrZXlmcmFtZXNgXG4gICAgZnJvbSB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmhpZGRlbn07XG4gICAgfVxuICAgIHRvIHtcbiAgICAgIG9wYWNpdHk6ICR7dGhlbWUudmFyaWFibGVzLm9wYWNpdHkudmlzaWJsZX07XG4gICAgfVxuICBgO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHBvc2l0aW9uOiBcImZpeGVkXCIsXG4gICAgICB0b3A6IDAsXG4gICAgICBsZWZ0OiAwLFxuICAgICAgekluZGV4OiB0aGVtZS52YXJpYWJsZXMuekluZGV4Lm1vZGFsLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgaGVpZ2h0OiBcIjEwMGR2aFwiLFxuICAgICAgYmFja2dyb3VuZDogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuYmFja2Ryb3AuZGVmYXVsdCxcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICAgIC4uLnVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICAgIGp1c3RpZnlDb250ZW50LFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH0pLFxuICAgICAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAgICAgIGZsZXg6IFwiMSAwIGF1dG9cIixcbiAgICAgIGFuaW1hdGlvbjogYCR7ZmFkZUluQmFja2Ryb3B9ICR7dGhlbWUudmFyaWFibGVzLmFuaW1hdGlvbi5tb2RhbEJhY2tkcm9wLm9wZW4uZHVyYXRpb259ICR7dGhlbWUudmFyaWFibGVzLmFuaW1hdGlvbi5tb2RhbEJhY2tkcm9wLm9wZW4udGltaW5nRnVuY3Rpb259IGJvdGhgLFxuICAgIH07XG4gIH1cbik7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRDaGlsZHJlbldyYXBwZXIgPSBzdHlsZWQuZGl2KHtcbiAgZGlzcGxheTogXCJjb250ZW50c1wiLFxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBMaWdodGJveCh7XG4gIGJhY2tkcm9wUmVmLFxuICBwb3J0YWxDb250YWluZXIsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGNvbnRlbnQgPSAoXG4gICAgPFN0eWxlZEJhY2tkcm9wXG4gICAgICByZWY9e2JhY2tkcm9wUmVmfVxuICAgICAganVzdGlmeUNvbnRlbnQ9e2p1c3RpZnlDb250ZW50fVxuICAgICAgZGF0YS1kcy1pZD1cIkxpZ2h0Ym94XCJcbiAgICA+XG4gICAgICA8Rm9jdXNUcmFwV3JhcHBlclxuICAgICAgICBhY3RpdmVcbiAgICAgICAgZm9jdXNUcmFwT3B0aW9ucz17e1xuICAgICAgICAgIGFsbG93T3V0c2lkZUNsaWNrOiB0cnVlLCAvLyBhbGxvdyBjbGljayBvbiBtb2JpbGUgaW4gYW55IGRyb3Bkb3duc1xuICAgICAgICAgIGNsaWNrT3V0c2lkZURlYWN0aXZhdGVzOiBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyxcbiAgICAgICAgICBlc2NhcGVEZWFjdGl2YXRlczogaXNEaXNtaXNzaWJsZSwgLy8gZGUtYWN0aXZhdGUgZm9jdXMgdHJhcCBvbiBlc2NhcGUga2V5XG4gICAgICAgICAgcHJldmVudFNjcm9sbDogdHJ1ZSxcbiAgICAgICAgICBmYWxsYmFja0ZvY3VzOiAoKSA9PiBtb2RhbFJlZj8uY3VycmVudCB8fCBkb2N1bWVudC5ib2R5LFxuICAgICAgICAgIC4uLih0YWJiYWJsZU9wdGlvbnMgJiYgeyB0YWJiYWJsZU9wdGlvbnMgfSksXG4gICAgICAgICAgLi4uKGhhbmRsZUNsb3NlICYmIHsgb25Qb3N0RGVhY3RpdmF0ZTogaGFuZGxlQ2xvc2UgfSksXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRDaGlsZHJlbldyYXBwZXIgcmVmPXttb2RhbFJlZn0+XG4gICAgICAgICAgPERpYWxvZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU+e2NoaWxkcmVufTwvRGlhbG9nQ29udGV4dC5Qcm92aWRlcj5cbiAgICAgICAgPC9TdHlsZWRDaGlsZHJlbldyYXBwZXI+XG4gICAgICA8L0ZvY3VzVHJhcFdyYXBwZXI+XG4gICAgPC9TdHlsZWRCYWNrZHJvcD5cbiAgKTtcblxuICAvLyBGb3IgdGVzdGluZyBhbmQgTW9kYWwgc3Rvcnkgd2UgZG9uJ3Qgd2FudCB0byByZW5kZXIgdGhlIGNvbnRlbnQgaW5zaWRlIGEgcG9ydGFsXG4gIGlmIChza2lwUG9ydGFsKSB7XG4gICAgcmV0dXJuIGNvbnRlbnQ7XG4gIH1cblxuICByZXR1cm4gPFBvcnRhbCBwb3J0YWxDb250YWluZXI9e3BvcnRhbENvbnRhaW5lcn0+e2NvbnRlbnR9PC9Qb3J0YWw+O1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNDOEIifQ== */"),StyledChildrenWrapper=(0,_styled.default)("div",{target:"e1575mg11",label:"StyledChildrenWrapper"})({display:"contents"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAganVzdGlmeUNvbnRlbnQ/OiBNUTxMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50PiB8IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQ7XG4gIHByaXZhdGVQcm9wcz86IHtcbiAgICBza2lwUG9ydGFsPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBAaW50ZXJuYWxcbiAgICAgKiBPcHRpb25zIHBhc3NlZCB0byBmb2N1cy10cmFwJ3MgdGFiYmFibGUgZGV0ZWN0aW9uLlxuICAgICAqIFVzZSBgeyBkaXNwbGF5Q2hlY2s6IFwibm9uZVwiIH1gIGZvciB0ZXN0aW5nIHRvIGF2b2lkIEpTRE9NIHZpc2liaWxpdHkgaXNzdWVzLlxuICAgICAqL1xuICAgIHRhYmJhYmxlT3B0aW9ucz86IHtcbiAgICAgIGRpc3BsYXlDaGVjaz86IFwiZnVsbFwiIHwgXCJsZWdhY3ktZnVsbFwiIHwgXCJub24temVyby1hcmVhXCIgfCBcIm5vbmVcIjtcbiAgICB9O1xuICB9O1xufSAmIFBpY2s8UG9ydGFsUHJvcHMsIFwicG9ydGFsQ29udGFpbmVyXCI+O1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQmFja2Ryb3AgPSBzdHlsZWQuZGl2PFBpY2s8TGlnaHRib3hQcm9wcywgXCJqdXN0aWZ5Q29udGVudFwiPj4oXG4gICh7IHRoZW1lLCBqdXN0aWZ5Q29udGVudCB9KSA9PiB7XG4gICAgY29uc3QgZmFkZUluQmFja2Ryb3AgPSBrZXlmcmFtZXNgXG4gICAgZnJvbSB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmhpZGRlbn07XG4gICAgfVxuICAgIHRvIHtcbiAgICAgIG9wYWNpdHk6ICR7dGhlbWUudmFyaWFibGVzLm9wYWNpdHkudmlzaWJsZX07XG4gICAgfVxuICBgO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHBvc2l0aW9uOiBcImZpeGVkXCIsXG4gICAgICB0b3A6IDAsXG4gICAgICBsZWZ0OiAwLFxuICAgICAgekluZGV4OiB0aGVtZS52YXJpYWJsZXMuekluZGV4Lm1vZGFsLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgaGVpZ2h0OiBcIjEwMGR2aFwiLFxuICAgICAgYmFja2dyb3VuZDogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuYmFja2Ryb3AuZGVmYXVsdCxcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICAgIC4uLnVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICAgIGp1c3RpZnlDb250ZW50LFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH0pLFxuICAgICAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAgICAgIGZsZXg6IFwiMSAwIGF1dG9cIixcbiAgICAgIGFuaW1hdGlvbjogYCR7ZmFkZUluQmFja2Ryb3B9ICR7dGhlbWUudmFyaWFibGVzLmFuaW1hdGlvbi5tb2RhbEJhY2tkcm9wLm9wZW4uZHVyYXRpb259ICR7dGhlbWUudmFyaWFibGVzLmFuaW1hdGlvbi5tb2RhbEJhY2tkcm9wLm9wZW4udGltaW5nRnVuY3Rpb259IGJvdGhgLFxuICAgIH07XG4gIH1cbik7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRDaGlsZHJlbldyYXBwZXIgPSBzdHlsZWQuZGl2KHtcbiAgZGlzcGxheTogXCJjb250ZW50c1wiLFxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBMaWdodGJveCh7XG4gIGJhY2tkcm9wUmVmLFxuICBwb3J0YWxDb250YWluZXIsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGNvbnRlbnQgPSAoXG4gICAgPFN0eWxlZEJhY2tkcm9wXG4gICAgICByZWY9e2JhY2tkcm9wUmVmfVxuICAgICAganVzdGlmeUNvbnRlbnQ9e2p1c3RpZnlDb250ZW50fVxuICAgICAgZGF0YS1kcy1pZD1cIkxpZ2h0Ym94XCJcbiAgICA+XG4gICAgICA8Rm9jdXNUcmFwV3JhcHBlclxuICAgICAgICBhY3RpdmVcbiAgICAgICAgZm9jdXNUcmFwT3B0aW9ucz17e1xuICAgICAgICAgIGFsbG93T3V0c2lkZUNsaWNrOiB0cnVlLCAvLyBhbGxvdyBjbGljayBvbiBtb2JpbGUgaW4gYW55IGRyb3Bkb3duc1xuICAgICAgICAgIGNsaWNrT3V0c2lkZURlYWN0aXZhdGVzOiBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyxcbiAgICAgICAgICBlc2NhcGVEZWFjdGl2YXRlczogaXNEaXNtaXNzaWJsZSwgLy8gZGUtYWN0aXZhdGUgZm9jdXMgdHJhcCBvbiBlc2NhcGUga2V5XG4gICAgICAgICAgcHJldmVudFNjcm9sbDogdHJ1ZSxcbiAgICAgICAgICBmYWxsYmFja0ZvY3VzOiAoKSA9PiBtb2RhbFJlZj8uY3VycmVudCB8fCBkb2N1bWVudC5ib2R5LFxuICAgICAgICAgIC4uLih0YWJiYWJsZU9wdGlvbnMgJiYgeyB0YWJiYWJsZU9wdGlvbnMgfSksXG4gICAgICAgICAgLi4uKGhhbmRsZUNsb3NlICYmIHsgb25Qb3N0RGVhY3RpdmF0ZTogaGFuZGxlQ2xvc2UgfSksXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRDaGlsZHJlbldyYXBwZXIgcmVmPXttb2RhbFJlZn0+XG4gICAgICAgICAgPERpYWxvZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU+e2NoaWxkcmVufTwvRGlhbG9nQ29udGV4dC5Qcm92aWRlcj5cbiAgICAgICAgPC9TdHlsZWRDaGlsZHJlbldyYXBwZXI+XG4gICAgICA8L0ZvY3VzVHJhcFdyYXBwZXI+XG4gICAgPC9TdHlsZWRCYWNrZHJvcD5cbiAgKTtcblxuICAvLyBGb3IgdGVzdGluZyBhbmQgTW9kYWwgc3Rvcnkgd2UgZG9uJ3Qgd2FudCB0byByZW5kZXIgdGhlIGNvbnRlbnQgaW5zaWRlIGEgcG9ydGFsXG4gIGlmIChza2lwUG9ydGFsKSB7XG4gICAgcmV0dXJuIGNvbnRlbnQ7XG4gIH1cblxuICByZXR1cm4gPFBvcnRhbCBwb3J0YWxDb250YWluZXI9e3BvcnRhbENvbnRhaW5lcn0+e2NvbnRlbnR9PC9Qb3J0YWw+O1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJFcUMifQ== */");function Lightbox({backdropRef,portalContainer,isDismissible=!0,children,handleClose,justifyContent="center",privateProps:{skipPortal,tabbableOptions}={skipPortal:!1}}){let portalContainerElement=(0,_Portal.usePortalContainerElement)(portalContainer),modalRef=(0,_react.useRef)(null),handleClickOutsideDeactivates=(0,_react.useCallback)(evt=>(!portalContainerElement.contains(evt.target)||evt.target===backdropRef?.current)&&isDismissible,[backdropRef,portalContainerElement,isDismissible]),content=_react.default.createElement(StyledBackdrop,{ref:backdropRef,justifyContent:justifyContent,"data-ds-id":"Lightbox"},_react.default.createElement(_FocusTrapWrapper.FocusTrapWrapper,{active:!0,focusTrapOptions:{allowOutsideClick:!0,clickOutsideDeactivates:handleClickOutsideDeactivates,escapeDeactivates:isDismissible,preventScroll:!0,fallbackFocus:()=>modalRef?.current||document.body,...tabbableOptions&&{tabbableOptions},...handleClose&&{onPostDeactivate:handleClose}}},_react.default.createElement(StyledChildrenWrapper,{ref:modalRef},_react.default.createElement(_DialogContext.DialogContext.Provider,{value:!0},children))));return skipPortal?content:_react.default.createElement(_Portal.Portal,{portalContainer:portalContainer},content)}
@@ -0,0 +1 @@
1
+ export declare const DialogContext: import("react").Context<boolean>;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"DialogContext",{enumerable:!0,get:function(){return DialogContext}});const DialogContext=(0,require("react").createContext)(!1);
@@ -1,7 +1,6 @@
1
1
  import type { AriaAttributes } from "react";
2
2
  import React from "react";
3
3
  import type { Property } from "csstype";
4
- import type { Theme } from "@emotion/react";
5
4
  import type { PortalProps } from "../../Portal/Portal";
6
5
  import type { StackProps } from "../../Stack/Stack";
7
6
  import type { ButtonGroupButtonProps } from "../ButtonGroup/ButtonGroup";
@@ -65,10 +64,6 @@ type ConditionalProps = {
65
64
  ImageComponent?: React.ElementType<any>;
66
65
  };
67
66
  export type ModalProps = BaseProps & ConditionalProps & Pick<PortalProps, "portalContainer">;
68
- export declare const StyledBackdrop: import("@emotion/styled").StyledComponent<{
69
- theme?: Theme;
70
- as?: React.ElementType;
71
- } & Partial<BaseProps>, React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
72
67
  export declare function Modal({ header, subHeader, labelHeader, children, imageUrl, ImageComponent, secondaryButton, cancelButtonLabel, isDismissible, isFullScreen, isMaxWidthLimit, actionButton, role, onAction, size, privateProps: { skipPortal, height, zeroPadding, tabbableOptions }, portalContainer, closeButtonAriaLabel, "data-e2e-test-id": dataE2eTestId, imageAlt, ...ariaAttributes }: ModalProps): React.ReactElement;
73
68
  export declare namespace Modal {
74
69
  var Stack: ({ children, ...rest }: Omit<StackProps, "space">) => React.JSX.Element;