@amboss/design-system 3.1.5 → 3.2.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.
- package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.d.ts +2 -1
- package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
- package/build/cjs/components/Column/Columns.d.ts +2 -0
- package/build/cjs/components/Column/Columns.js +1 -1
- package/build/cjs/components/Form/PasswordInput/PasswordInput.js +1 -1
- package/build/cjs/components/Grid/Grid.d.ts +36 -0
- package/build/cjs/components/Grid/Grid.js +1 -0
- package/build/cjs/components/Grid/GridItem.d.ts +32 -0
- package/build/cjs/components/Grid/GridItem.js +1 -0
- package/build/cjs/index.d.ts +1 -0
- package/build/cjs/index.js +1 -1
- package/build/cjs/shared/mediaQueries.d.ts +2 -2
- package/build/cjs/shared/mediaQueries.js +1 -1
- package/build/cjs/web-tokens/assets/icons16.json +1 -1
- package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.d.ts +2 -1
- package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
- package/build/esm/components/Column/Columns.d.ts +2 -0
- package/build/esm/components/Column/Columns.js +1 -1
- package/build/esm/components/Form/PasswordInput/PasswordInput.js +1 -1
- package/build/esm/components/Grid/Grid.d.ts +36 -0
- package/build/esm/components/Grid/Grid.js +1 -0
- package/build/esm/components/Grid/GridItem.d.ts +32 -0
- package/build/esm/components/Grid/GridItem.js +1 -0
- package/build/esm/index.d.ts +1 -0
- package/build/esm/index.js +1 -1
- package/build/esm/shared/mediaQueries.d.ts +2 -2
- package/build/esm/shared/mediaQueries.js +1 -1
- package/build/esm/web-tokens/assets/icons16.json +1 -1
- package/package.json +1 -1
- package/build/cjs/components/Toolbar/Toolbar.d.ts +0 -7
- package/build/cjs/components/Toolbar/Toolbar.js +0 -1
- package/build/cjs/components/Toolbar/ToolbarGroup.d.ts +0 -5
- package/build/cjs/components/Toolbar/ToolbarGroup.js +0 -1
- package/build/cjs/components/Toolbar/index.d.ts +0 -4
- package/build/cjs/components/Toolbar/index.js +0 -1
- package/build/esm/components/Toolbar/Toolbar.d.ts +0 -7
- package/build/esm/components/Toolbar/Toolbar.js +0 -1
- package/build/esm/components/Toolbar/ToolbarGroup.d.ts +0 -5
- package/build/esm/components/Toolbar/ToolbarGroup.js +0 -1
- package/build/esm/components/Toolbar/index.d.ts +0 -4
- package/build/esm/components/Toolbar/index.js +0 -1
|
@@ -13,7 +13,8 @@ export type BulkActionsToolbarProps = {
|
|
|
13
13
|
renderRightContent?: () => React.ReactNode;
|
|
14
14
|
rightContentNoWrapOnMobile?: boolean;
|
|
15
15
|
hideDivider?: boolean;
|
|
16
|
+
"data-e2e-test-id"?: string;
|
|
16
17
|
};
|
|
17
|
-
declare function BulkActionsToolbarUI({ actions, checkboxProps, totalItems, searchInputProps, renderRightContent, rightContentNoWrapOnMobile, hideDivider, }: BulkActionsToolbarProps): React.ReactElement;
|
|
18
|
+
declare function BulkActionsToolbarUI({ actions, checkboxProps, totalItems, searchInputProps, renderRightContent, rightContentNoWrapOnMobile, hideDivider, "data-e2e-test-id": dataE2eTestId, }: BulkActionsToolbarProps): React.ReactElement;
|
|
18
19
|
export declare const BulkActionsToolbar: React.MemoExoticComponent<typeof BulkActionsToolbarUI>;
|
|
19
20
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BulkActionsToolbar",{enumerable:!0,get:function(){return BulkActionsToolbar}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Text=require("../Typography/Text/Text"),_Button=require("../Button/Button"),_Box=require("../Box/Box"),_Inline=require("../Inline/Inline"),_Divider=require("../Divider/Divider"),_Checkbox=require("../Form/Checkbox/Checkbox"),_Toolbar=require("../Toolbar"),_mediaQueries=require("../../shared/mediaQueries"),_SearchInput=require("../Form/SearchInput/SearchInput"),TotalItems=({children})=>/*#__PURE__*/_react.default.createElement(_Box.Box,{space:["xs","zero"]},/*#__PURE__*/_react.default.createElement(_Text.Text,{size:"s",color:"secondary",weight:"bold"},children)),CheckboxContainer=props=>/*#__PURE__*/_react.default.createElement(_Box.Box,{space:"xs",tSpace:"zero",rSpace:["zero","xxs"]},/*#__PURE__*/_react.default.createElement(_Checkbox.Checkbox,{size:"s",...props})),StyledInline=/*#__PURE__*/(0,_styled.default)("div",{target:"ectldzb0",label:"StyledInline"})(({theme,rightContentNoWrapOnMobile})=>({display:"flex",...(0,_mediaQueries.mqValue)({flexWrap:[rightContentNoWrapOnMobile?"nowrap":"wrap","nowrap"]}),justifyContent:"center",alignItems:"center",gap:theme.variables.size.spacing.xs}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQnVsa0FjdGlvbnNUb29sYmFyL0J1bGtBY3Rpb25zVG9vbGJhci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0J1bGtBY3Rpb25zVG9vbGJhci9CdWxrQWN0aW9uc1Rvb2xiYXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBGQywgUHJvcHNXaXRoQ2hpbGRyZW4gfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJ1dHRvbiwgdHlwZSBCdXR0b25Qcm9wcyB9IGZyb20gXCIuLi9CdXR0b24vQnV0dG9uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IERpdmlkZXIgfSBmcm9tIFwiLi4vRGl2aWRlci9EaXZpZGVyXCI7XG5pbXBvcnQgeyBDaGVja2JveCwgdHlwZSBDaGVja2JveFByb3BzIH0gZnJvbSBcIi4uL0Zvcm0vQ2hlY2tib3gvQ2hlY2tib3hcIjtcbmltcG9ydCB7IFRvb2xiYXIsIFRvb2xiYXJHcm91cCB9IGZyb20gXCIuLi9Ub29sYmFyXCI7XG5pbXBvcnQgeyBtcVZhbHVlIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB7XG4gIFNlYXJjaElucHV0LFxuICB0eXBlIFNlYXJjaElucHV0UHJvcHMsXG59IGZyb20gXCIuLi9Gb3JtL1NlYXJjaElucHV0L1NlYXJjaElucHV0XCI7XG5cbnR5cGUgQWN0aW9uUHJvcCA9IHtcbiAgbGFiZWw6IHN0cmluZztcbn0gJiBPbWl0PEJ1dHRvblByb3BzLCBcImNoaWxkcmVuXCIgfCBcInNpemVcIj47XG5cbmV4cG9ydCB0eXBlIEJ1bGtBY3Rpb25zVG9vbGJhclByb3BzID0ge1xuICBhY3Rpb25zPzogQWN0aW9uUHJvcFtdO1xuICAvLyBzaG91bGQgYmUgYWx3YXlzIHdyYXBwZWQgaW50byB1c2VNZW1vIGluIG9yZGVyIHRvIGF2b2lkIHVubmVjZXNzYXJ5IHJlLXJlbmRlcnNcbiAgc2VhcmNoSW5wdXRQcm9wczogU2VhcmNoSW5wdXRQcm9wcztcbiAgY2hlY2tib3hQcm9wcz86IENoZWNrYm94UHJvcHM7XG4gIHRvdGFsSXRlbXM6IHN0cmluZztcbiAgcmVuZGVyUmlnaHRDb250ZW50PzogKCkgPT4gUmVhY3QuUmVhY3ROb2RlO1xuICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZT86IGJvb2xlYW47XG4gIGhpZGVEaXZpZGVyPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFRvdGFsSXRlbXM6IEZDPFByb3BzV2l0aENoaWxkcmVuPiA9ICh7IGNoaWxkcmVuIH0pID0+IChcbiAgPEJveCBzcGFjZT17W1wieHNcIiwgXCJ6ZXJvXCJdfT5cbiAgICA8VGV4dCBzaXplPVwic1wiIGNvbG9yPVwic2Vjb25kYXJ5XCIgd2VpZ2h0PVwiYm9sZFwiPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvVGV4dD5cbiAgPC9Cb3g+XG4pO1xuXG5jb25zdCBDaGVja2JveENvbnRhaW5lcjogRkM8Q2hlY2tib3hQcm9wcz4gPSAocHJvcHMpID0+IChcbiAgPEJveCBzcGFjZT1cInhzXCIgdFNwYWNlPVwiemVyb1wiIHJTcGFjZT17W1wiemVyb1wiLCBcInh4c1wiXX0+XG4gICAgPENoZWNrYm94IHNpemU9XCJzXCIgey4uLnByb3BzfSAvPlxuICA8L0JveD5cbik7XG5cbmNvbnN0IFN0eWxlZElubGluZSA9IHN0eWxlZC5kaXY8XG4gIFBpY2s8QnVsa0FjdGlvbnNUb29sYmFyUHJvcHMsIFwicmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGVcIj5cbj4oKHsgdGhlbWUsIHJpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlIH0pID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICAuLi5tcVZhbHVlKHtcbiAgICBmbGV4V3JhcDogW3JpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlID8gXCJub3dyYXBcIiA6IFwid3JhcFwiLCBcIm5vd3JhcFwiXSxcbiAgfSksXG4gIGp1c3RpZnlDb250ZW50OiBcImNlbnRlclwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBnYXA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG59KSk7XG5cbmNvbnN0IFN0eWxlZElubGluZUl0ZW0gPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIC4uLm1xVmFsdWUoe1xuICAgIG9yZGVyOiBbMiwgMV0sXG4gICAgZmxleEdyb3c6IFsxLCAwXSxcbiAgfSksXG59KSk7XG5cbmNvbnN0IFN0eWxlZElubGluZUl0ZW1TZWFyY2ggPSBzdHlsZWQoU3R5bGVkSW5saW5lSXRlbSk8XG4gIFBpY2s8QnVsa0FjdGlvbnNUb29sYmFyUHJvcHMsIFwicmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGVcIj5cbj4oKCkgPT4gKHtcbiAgLi4ubXFWYWx1ZSh7XG4gICAgZmxleEJhc2lzOiBbXCIxMDAlXCIsIFwiYXV0b1wiXSxcbiAgICBvcmRlcjogWzEsIDJdLFxuICB9KSxcbiAgZmxleEdyb3c6IDEsXG59KSk7XG5cbmZ1bmN0aW9uIEJ1bGtBY3Rpb25zVG9vbGJhclVJKHtcbiAgYWN0aW9ucyxcbiAgY2hlY2tib3hQcm9wcyxcbiAgdG90YWxJdGVtcyxcbiAgc2VhcmNoSW5wdXRQcm9wcyxcbiAgcmVuZGVyUmlnaHRDb250ZW50LFxuICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZSxcbiAgaGlkZURpdmlkZXIsXG59OiBCdWxrQWN0aW9uc1Rvb2xiYXJQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIDxUb29sYmFyPlxuICAgICAgICA8VG9vbGJhckdyb3VwIG9yZGVyPXtbXCJsYXN0XCIsIFwiZmlyc3RcIl19IHNpemU9e1sxMiwgXCJmaWxsXCJdfT5cbiAgICAgICAgICB7Y2hlY2tib3hQcm9wcyA/IChcbiAgICAgICAgICAgIDxJbmxpbmUgdkFsaWduSXRlbXM9XCJjZW50ZXJcIiBzcGFjZT17W1wieHhzXCIsIFwibVwiXX0+XG4gICAgICAgICAgICAgIDxDaGVja2JveENvbnRhaW5lciB7Li4uY2hlY2tib3hQcm9wc30gLz5cbiAgICAgICAgICAgICAgPFRvdGFsSXRlbXM+e3RvdGFsSXRlbXN9PC9Ub3RhbEl0ZW1zPlxuICAgICAgICAgICAgPC9JbmxpbmU+XG4gICAgICAgICAgKSA6IChcbiAgICAgICAgICAgIDxUb3RhbEl0ZW1zPnt0b3RhbEl0ZW1zfTwvVG90YWxJdGVtcz5cbiAgICAgICAgICApfVxuXG4gICAgICAgICAgPElubGluZT5cbiAgICAgICAgICAgIHthY3Rpb25zPy5tYXAoXG4gICAgICAgICAgICAgICh7IHZhcmlhbnQgPSBcInNlY29uZGFyeVwiLCBsYWJlbCwgLi4uYnV0dG9uUHJvcHMgfSkgPT4gKFxuICAgICAgICAgICAgICAgIDxCdXR0b25cbiAgICAgICAgICAgICAgICAgIHsuLi5idXR0b25Qcm9wc31cbiAgICAgICAgICAgICAgICAgIGtleT17YGFjdGlvbi0ke2xhYmVsfWB9XG4gICAgICAgICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PXt2YXJpYW50fVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9Ub29sYmFyR3JvdXA+XG5cbiAgICAgICAgPFRvb2xiYXJHcm91cCBvcmRlcj17W1wiZmlyc3RcIiwgXCJsYXN0XCJdfSBzaXplPXtbMTIsIFwibmFycm93XCJdfT5cbiAgICAgICAgICA8U3R5bGVkSW5saW5lIHJpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlPXtyaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZX0+XG4gICAgICAgICAgICB7cmVuZGVyUmlnaHRDb250ZW50ICYmIChcbiAgICAgICAgICAgICAgPFN0eWxlZElubGluZUl0ZW0+e3JlbmRlclJpZ2h0Q29udGVudCgpfTwvU3R5bGVkSW5saW5lSXRlbT5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8U3R5bGVkSW5saW5lSXRlbVNlYXJjaFxuICAgICAgICAgICAgICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZT17cmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGV9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTZWFyY2hJbnB1dCB7Li4uc2VhcmNoSW5wdXRQcm9wc30gLz5cbiAgICAgICAgICAgIDwvU3R5bGVkSW5saW5lSXRlbVNlYXJjaD5cbiAgICAgICAgICA8L1N0eWxlZElubGluZT5cbiAgICAgICAgPC9Ub29sYmFyR3JvdXA+XG4gICAgICA8L1Rvb2xiYXI+XG5cbiAgICAgIHshaGlkZURpdmlkZXIgJiYgPERpdmlkZXIgLz59XG4gICAgPC8+XG4gICk7XG59XG5cbmV4cG9ydCBjb25zdCBCdWxrQWN0aW9uc1Rvb2xiYXIgPSBSZWFjdC5tZW1vKEJ1bGtBY3Rpb25zVG9vbGJhclVJKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4Q3FCIn0= */"),StyledInlineItem=/*#__PURE__*/(0,_styled.default)("div",{target:"ectldzb1",label:"StyledInlineItem"})(()=>({...(0,_mediaQueries.mqValue)({order:[2,1],flexGrow:[1,0]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQnVsa0FjdGlvbnNUb29sYmFyL0J1bGtBY3Rpb25zVG9vbGJhci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0J1bGtBY3Rpb25zVG9vbGJhci9CdWxrQWN0aW9uc1Rvb2xiYXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBGQywgUHJvcHNXaXRoQ2hpbGRyZW4gfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJ1dHRvbiwgdHlwZSBCdXR0b25Qcm9wcyB9IGZyb20gXCIuLi9CdXR0b24vQnV0dG9uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IERpdmlkZXIgfSBmcm9tIFwiLi4vRGl2aWRlci9EaXZpZGVyXCI7XG5pbXBvcnQgeyBDaGVja2JveCwgdHlwZSBDaGVja2JveFByb3BzIH0gZnJvbSBcIi4uL0Zvcm0vQ2hlY2tib3gvQ2hlY2tib3hcIjtcbmltcG9ydCB7IFRvb2xiYXIsIFRvb2xiYXJHcm91cCB9IGZyb20gXCIuLi9Ub29sYmFyXCI7XG5pbXBvcnQgeyBtcVZhbHVlIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB7XG4gIFNlYXJjaElucHV0LFxuICB0eXBlIFNlYXJjaElucHV0UHJvcHMsXG59IGZyb20gXCIuLi9Gb3JtL1NlYXJjaElucHV0L1NlYXJjaElucHV0XCI7XG5cbnR5cGUgQWN0aW9uUHJvcCA9IHtcbiAgbGFiZWw6IHN0cmluZztcbn0gJiBPbWl0PEJ1dHRvblByb3BzLCBcImNoaWxkcmVuXCIgfCBcInNpemVcIj47XG5cbmV4cG9ydCB0eXBlIEJ1bGtBY3Rpb25zVG9vbGJhclByb3BzID0ge1xuICBhY3Rpb25zPzogQWN0aW9uUHJvcFtdO1xuICAvLyBzaG91bGQgYmUgYWx3YXlzIHdyYXBwZWQgaW50byB1c2VNZW1vIGluIG9yZGVyIHRvIGF2b2lkIHVubmVjZXNzYXJ5IHJlLXJlbmRlcnNcbiAgc2VhcmNoSW5wdXRQcm9wczogU2VhcmNoSW5wdXRQcm9wcztcbiAgY2hlY2tib3hQcm9wcz86IENoZWNrYm94UHJvcHM7XG4gIHRvdGFsSXRlbXM6IHN0cmluZztcbiAgcmVuZGVyUmlnaHRDb250ZW50PzogKCkgPT4gUmVhY3QuUmVhY3ROb2RlO1xuICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZT86IGJvb2xlYW47XG4gIGhpZGVEaXZpZGVyPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFRvdGFsSXRlbXM6IEZDPFByb3BzV2l0aENoaWxkcmVuPiA9ICh7IGNoaWxkcmVuIH0pID0+IChcbiAgPEJveCBzcGFjZT17W1wieHNcIiwgXCJ6ZXJvXCJdfT5cbiAgICA8VGV4dCBzaXplPVwic1wiIGNvbG9yPVwic2Vjb25kYXJ5XCIgd2VpZ2h0PVwiYm9sZFwiPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvVGV4dD5cbiAgPC9Cb3g+XG4pO1xuXG5jb25zdCBDaGVja2JveENvbnRhaW5lcjogRkM8Q2hlY2tib3hQcm9wcz4gPSAocHJvcHMpID0+IChcbiAgPEJveCBzcGFjZT1cInhzXCIgdFNwYWNlPVwiemVyb1wiIHJTcGFjZT17W1wiemVyb1wiLCBcInh4c1wiXX0+XG4gICAgPENoZWNrYm94IHNpemU9XCJzXCIgey4uLnByb3BzfSAvPlxuICA8L0JveD5cbik7XG5cbmNvbnN0IFN0eWxlZElubGluZSA9IHN0eWxlZC5kaXY8XG4gIFBpY2s8QnVsa0FjdGlvbnNUb29sYmFyUHJvcHMsIFwicmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGVcIj5cbj4oKHsgdGhlbWUsIHJpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlIH0pID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICAuLi5tcVZhbHVlKHtcbiAgICBmbGV4V3JhcDogW3JpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlID8gXCJub3dyYXBcIiA6IFwid3JhcFwiLCBcIm5vd3JhcFwiXSxcbiAgfSksXG4gIGp1c3RpZnlDb250ZW50OiBcImNlbnRlclwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBnYXA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG59KSk7XG5cbmNvbnN0IFN0eWxlZElubGluZUl0ZW0gPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIC4uLm1xVmFsdWUoe1xuICAgIG9yZGVyOiBbMiwgMV0sXG4gICAgZmxleEdyb3c6IFsxLCAwXSxcbiAgfSksXG59KSk7XG5cbmNvbnN0IFN0eWxlZElubGluZUl0ZW1TZWFyY2ggPSBzdHlsZWQoU3R5bGVkSW5saW5lSXRlbSk8XG4gIFBpY2s8QnVsa0FjdGlvbnNUb29sYmFyUHJvcHMsIFwicmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGVcIj5cbj4oKCkgPT4gKHtcbiAgLi4ubXFWYWx1ZSh7XG4gICAgZmxleEJhc2lzOiBbXCIxMDAlXCIsIFwiYXV0b1wiXSxcbiAgICBvcmRlcjogWzEsIDJdLFxuICB9KSxcbiAgZmxleEdyb3c6IDEsXG59KSk7XG5cbmZ1bmN0aW9uIEJ1bGtBY3Rpb25zVG9vbGJhclVJKHtcbiAgYWN0aW9ucyxcbiAgY2hlY2tib3hQcm9wcyxcbiAgdG90YWxJdGVtcyxcbiAgc2VhcmNoSW5wdXRQcm9wcyxcbiAgcmVuZGVyUmlnaHRDb250ZW50LFxuICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZSxcbiAgaGlkZURpdmlkZXIsXG59OiBCdWxrQWN0aW9uc1Rvb2xiYXJQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIDxUb29sYmFyPlxuICAgICAgICA8VG9vbGJhckdyb3VwIG9yZGVyPXtbXCJsYXN0XCIsIFwiZmlyc3RcIl19IHNpemU9e1sxMiwgXCJmaWxsXCJdfT5cbiAgICAgICAgICB7Y2hlY2tib3hQcm9wcyA/IChcbiAgICAgICAgICAgIDxJbmxpbmUgdkFsaWduSXRlbXM9XCJjZW50ZXJcIiBzcGFjZT17W1wieHhzXCIsIFwibVwiXX0+XG4gICAgICAgICAgICAgIDxDaGVja2JveENvbnRhaW5lciB7Li4uY2hlY2tib3hQcm9wc30gLz5cbiAgICAgICAgICAgICAgPFRvdGFsSXRlbXM+e3RvdGFsSXRlbXN9PC9Ub3RhbEl0ZW1zPlxuICAgICAgICAgICAgPC9JbmxpbmU+XG4gICAgICAgICAgKSA6IChcbiAgICAgICAgICAgIDxUb3RhbEl0ZW1zPnt0b3RhbEl0ZW1zfTwvVG90YWxJdGVtcz5cbiAgICAgICAgICApfVxuXG4gICAgICAgICAgPElubGluZT5cbiAgICAgICAgICAgIHthY3Rpb25zPy5tYXAoXG4gICAgICAgICAgICAgICh7IHZhcmlhbnQgPSBcInNlY29uZGFyeVwiLCBsYWJlbCwgLi4uYnV0dG9uUHJvcHMgfSkgPT4gKFxuICAgICAgICAgICAgICAgIDxCdXR0b25cbiAgICAgICAgICAgICAgICAgIHsuLi5idXR0b25Qcm9wc31cbiAgICAgICAgICAgICAgICAgIGtleT17YGFjdGlvbi0ke2xhYmVsfWB9XG4gICAgICAgICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PXt2YXJpYW50fVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9Ub29sYmFyR3JvdXA+XG5cbiAgICAgICAgPFRvb2xiYXJHcm91cCBvcmRlcj17W1wiZmlyc3RcIiwgXCJsYXN0XCJdfSBzaXplPXtbMTIsIFwibmFycm93XCJdfT5cbiAgICAgICAgICA8U3R5bGVkSW5saW5lIHJpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlPXtyaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZX0+XG4gICAgICAgICAgICB7cmVuZGVyUmlnaHRDb250ZW50ICYmIChcbiAgICAgICAgICAgICAgPFN0eWxlZElubGluZUl0ZW0+e3JlbmRlclJpZ2h0Q29udGVudCgpfTwvU3R5bGVkSW5saW5lSXRlbT5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8U3R5bGVkSW5saW5lSXRlbVNlYXJjaFxuICAgICAgICAgICAgICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZT17cmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGV9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTZWFyY2hJbnB1dCB7Li4uc2VhcmNoSW5wdXRQcm9wc30gLz5cbiAgICAgICAgICAgIDwvU3R5bGVkSW5saW5lSXRlbVNlYXJjaD5cbiAgICAgICAgICA8L1N0eWxlZElubGluZT5cbiAgICAgICAgPC9Ub29sYmFyR3JvdXA+XG4gICAgICA8L1Rvb2xiYXI+XG5cbiAgICAgIHshaGlkZURpdmlkZXIgJiYgPERpdmlkZXIgLz59XG4gICAgPC8+XG4gICk7XG59XG5cbmV4cG9ydCBjb25zdCBCdWxrQWN0aW9uc1Rvb2xiYXIgPSBSZWFjdC5tZW1vKEJ1bGtBY3Rpb25zVG9vbGJhclVJKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRHlCIn0= */"),StyledInlineItemSearch=/*#__PURE__*/(0,_styled.default)(StyledInlineItem,{target:"ectldzb2",label:"StyledInlineItemSearch"})(()=>({...(0,_mediaQueries.mqValue)({flexBasis:["100%","auto"],order:[1,2]}),flexGrow:1}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQnVsa0FjdGlvbnNUb29sYmFyL0J1bGtBY3Rpb25zVG9vbGJhci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0J1bGtBY3Rpb25zVG9vbGJhci9CdWxrQWN0aW9uc1Rvb2xiYXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBGQywgUHJvcHNXaXRoQ2hpbGRyZW4gfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJ1dHRvbiwgdHlwZSBCdXR0b25Qcm9wcyB9IGZyb20gXCIuLi9CdXR0b24vQnV0dG9uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IERpdmlkZXIgfSBmcm9tIFwiLi4vRGl2aWRlci9EaXZpZGVyXCI7XG5pbXBvcnQgeyBDaGVja2JveCwgdHlwZSBDaGVja2JveFByb3BzIH0gZnJvbSBcIi4uL0Zvcm0vQ2hlY2tib3gvQ2hlY2tib3hcIjtcbmltcG9ydCB7IFRvb2xiYXIsIFRvb2xiYXJHcm91cCB9IGZyb20gXCIuLi9Ub29sYmFyXCI7XG5pbXBvcnQgeyBtcVZhbHVlIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB7XG4gIFNlYXJjaElucHV0LFxuICB0eXBlIFNlYXJjaElucHV0UHJvcHMsXG59IGZyb20gXCIuLi9Gb3JtL1NlYXJjaElucHV0L1NlYXJjaElucHV0XCI7XG5cbnR5cGUgQWN0aW9uUHJvcCA9IHtcbiAgbGFiZWw6IHN0cmluZztcbn0gJiBPbWl0PEJ1dHRvblByb3BzLCBcImNoaWxkcmVuXCIgfCBcInNpemVcIj47XG5cbmV4cG9ydCB0eXBlIEJ1bGtBY3Rpb25zVG9vbGJhclByb3BzID0ge1xuICBhY3Rpb25zPzogQWN0aW9uUHJvcFtdO1xuICAvLyBzaG91bGQgYmUgYWx3YXlzIHdyYXBwZWQgaW50byB1c2VNZW1vIGluIG9yZGVyIHRvIGF2b2lkIHVubmVjZXNzYXJ5IHJlLXJlbmRlcnNcbiAgc2VhcmNoSW5wdXRQcm9wczogU2VhcmNoSW5wdXRQcm9wcztcbiAgY2hlY2tib3hQcm9wcz86IENoZWNrYm94UHJvcHM7XG4gIHRvdGFsSXRlbXM6IHN0cmluZztcbiAgcmVuZGVyUmlnaHRDb250ZW50PzogKCkgPT4gUmVhY3QuUmVhY3ROb2RlO1xuICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZT86IGJvb2xlYW47XG4gIGhpZGVEaXZpZGVyPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFRvdGFsSXRlbXM6IEZDPFByb3BzV2l0aENoaWxkcmVuPiA9ICh7IGNoaWxkcmVuIH0pID0+IChcbiAgPEJveCBzcGFjZT17W1wieHNcIiwgXCJ6ZXJvXCJdfT5cbiAgICA8VGV4dCBzaXplPVwic1wiIGNvbG9yPVwic2Vjb25kYXJ5XCIgd2VpZ2h0PVwiYm9sZFwiPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvVGV4dD5cbiAgPC9Cb3g+XG4pO1xuXG5jb25zdCBDaGVja2JveENvbnRhaW5lcjogRkM8Q2hlY2tib3hQcm9wcz4gPSAocHJvcHMpID0+IChcbiAgPEJveCBzcGFjZT1cInhzXCIgdFNwYWNlPVwiemVyb1wiIHJTcGFjZT17W1wiemVyb1wiLCBcInh4c1wiXX0+XG4gICAgPENoZWNrYm94IHNpemU9XCJzXCIgey4uLnByb3BzfSAvPlxuICA8L0JveD5cbik7XG5cbmNvbnN0IFN0eWxlZElubGluZSA9IHN0eWxlZC5kaXY8XG4gIFBpY2s8QnVsa0FjdGlvbnNUb29sYmFyUHJvcHMsIFwicmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGVcIj5cbj4oKHsgdGhlbWUsIHJpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlIH0pID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICAuLi5tcVZhbHVlKHtcbiAgICBmbGV4V3JhcDogW3JpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlID8gXCJub3dyYXBcIiA6IFwid3JhcFwiLCBcIm5vd3JhcFwiXSxcbiAgfSksXG4gIGp1c3RpZnlDb250ZW50OiBcImNlbnRlclwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBnYXA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG59KSk7XG5cbmNvbnN0IFN0eWxlZElubGluZUl0ZW0gPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIC4uLm1xVmFsdWUoe1xuICAgIG9yZGVyOiBbMiwgMV0sXG4gICAgZmxleEdyb3c6IFsxLCAwXSxcbiAgfSksXG59KSk7XG5cbmNvbnN0IFN0eWxlZElubGluZUl0ZW1TZWFyY2ggPSBzdHlsZWQoU3R5bGVkSW5saW5lSXRlbSk8XG4gIFBpY2s8QnVsa0FjdGlvbnNUb29sYmFyUHJvcHMsIFwicmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGVcIj5cbj4oKCkgPT4gKHtcbiAgLi4ubXFWYWx1ZSh7XG4gICAgZmxleEJhc2lzOiBbXCIxMDAlXCIsIFwiYXV0b1wiXSxcbiAgICBvcmRlcjogWzEsIDJdLFxuICB9KSxcbiAgZmxleEdyb3c6IDEsXG59KSk7XG5cbmZ1bmN0aW9uIEJ1bGtBY3Rpb25zVG9vbGJhclVJKHtcbiAgYWN0aW9ucyxcbiAgY2hlY2tib3hQcm9wcyxcbiAgdG90YWxJdGVtcyxcbiAgc2VhcmNoSW5wdXRQcm9wcyxcbiAgcmVuZGVyUmlnaHRDb250ZW50LFxuICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZSxcbiAgaGlkZURpdmlkZXIsXG59OiBCdWxrQWN0aW9uc1Rvb2xiYXJQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIDxUb29sYmFyPlxuICAgICAgICA8VG9vbGJhckdyb3VwIG9yZGVyPXtbXCJsYXN0XCIsIFwiZmlyc3RcIl19IHNpemU9e1sxMiwgXCJmaWxsXCJdfT5cbiAgICAgICAgICB7Y2hlY2tib3hQcm9wcyA/IChcbiAgICAgICAgICAgIDxJbmxpbmUgdkFsaWduSXRlbXM9XCJjZW50ZXJcIiBzcGFjZT17W1wieHhzXCIsIFwibVwiXX0+XG4gICAgICAgICAgICAgIDxDaGVja2JveENvbnRhaW5lciB7Li4uY2hlY2tib3hQcm9wc30gLz5cbiAgICAgICAgICAgICAgPFRvdGFsSXRlbXM+e3RvdGFsSXRlbXN9PC9Ub3RhbEl0ZW1zPlxuICAgICAgICAgICAgPC9JbmxpbmU+XG4gICAgICAgICAgKSA6IChcbiAgICAgICAgICAgIDxUb3RhbEl0ZW1zPnt0b3RhbEl0ZW1zfTwvVG90YWxJdGVtcz5cbiAgICAgICAgICApfVxuXG4gICAgICAgICAgPElubGluZT5cbiAgICAgICAgICAgIHthY3Rpb25zPy5tYXAoXG4gICAgICAgICAgICAgICh7IHZhcmlhbnQgPSBcInNlY29uZGFyeVwiLCBsYWJlbCwgLi4uYnV0dG9uUHJvcHMgfSkgPT4gKFxuICAgICAgICAgICAgICAgIDxCdXR0b25cbiAgICAgICAgICAgICAgICAgIHsuLi5idXR0b25Qcm9wc31cbiAgICAgICAgICAgICAgICAgIGtleT17YGFjdGlvbi0ke2xhYmVsfWB9XG4gICAgICAgICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PXt2YXJpYW50fVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9Ub29sYmFyR3JvdXA+XG5cbiAgICAgICAgPFRvb2xiYXJHcm91cCBvcmRlcj17W1wiZmlyc3RcIiwgXCJsYXN0XCJdfSBzaXplPXtbMTIsIFwibmFycm93XCJdfT5cbiAgICAgICAgICA8U3R5bGVkSW5saW5lIHJpZ2h0Q29udGVudE5vV3JhcE9uTW9iaWxlPXtyaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZX0+XG4gICAgICAgICAgICB7cmVuZGVyUmlnaHRDb250ZW50ICYmIChcbiAgICAgICAgICAgICAgPFN0eWxlZElubGluZUl0ZW0+e3JlbmRlclJpZ2h0Q29udGVudCgpfTwvU3R5bGVkSW5saW5lSXRlbT5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8U3R5bGVkSW5saW5lSXRlbVNlYXJjaFxuICAgICAgICAgICAgICByaWdodENvbnRlbnROb1dyYXBPbk1vYmlsZT17cmlnaHRDb250ZW50Tm9XcmFwT25Nb2JpbGV9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTZWFyY2hJbnB1dCB7Li4uc2VhcmNoSW5wdXRQcm9wc30gLz5cbiAgICAgICAgICAgIDwvU3R5bGVkSW5saW5lSXRlbVNlYXJjaD5cbiAgICAgICAgICA8L1N0eWxlZElubGluZT5cbiAgICAgICAgPC9Ub29sYmFyR3JvdXA+XG4gICAgICA8L1Rvb2xiYXI+XG5cbiAgICAgIHshaGlkZURpdmlkZXIgJiYgPERpdmlkZXIgLz59XG4gICAgPC8+XG4gICk7XG59XG5cbmV4cG9ydCBjb25zdCBCdWxrQWN0aW9uc1Rvb2xiYXIgPSBSZWFjdC5tZW1vKEJ1bGtBY3Rpb25zVG9vbGJhclVJKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRStCIn0= */"),BulkActionsToolbar=/*#__PURE__*/_react.default.memo(function({actions,checkboxProps,totalItems,searchInputProps,renderRightContent,rightContentNoWrapOnMobile,hideDivider}){return /*#__PURE__*/_react.default.createElement(_react.default.Fragment,null,/*#__PURE__*/_react.default.createElement(_Toolbar.Toolbar,null,/*#__PURE__*/_react.default.createElement(_Toolbar.ToolbarGroup,{order:["last","first"],size:[12,"fill"]},checkboxProps?/*#__PURE__*/_react.default.createElement(_Inline.Inline,{vAlignItems:"center",space:["xxs","m"]},/*#__PURE__*/_react.default.createElement(CheckboxContainer,checkboxProps),/*#__PURE__*/_react.default.createElement(TotalItems,null,totalItems)):/*#__PURE__*/_react.default.createElement(TotalItems,null,totalItems),/*#__PURE__*/_react.default.createElement(_Inline.Inline,null,actions?.map(({variant="secondary",label,...buttonProps})=>/*#__PURE__*/_react.default.createElement(_Button.Button,{...buttonProps,key:`action-${label}`,size:"s",variant:variant},label)))),/*#__PURE__*/_react.default.createElement(_Toolbar.ToolbarGroup,{order:["first","last"],size:[12,"narrow"]},/*#__PURE__*/_react.default.createElement(StyledInline,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent&&/*#__PURE__*/_react.default.createElement(StyledInlineItem,null,renderRightContent()),/*#__PURE__*/_react.default.createElement(StyledInlineItemSearch,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},/*#__PURE__*/_react.default.createElement(_SearchInput.SearchInput,searchInputProps))))),!hideDivider&&/*#__PURE__*/_react.default.createElement(_Divider.Divider,null))});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BulkActionsToolbar",{enumerable:!0,get:function(){return BulkActionsToolbar}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Text=require("../Typography/Text/Text"),_Button=require("../Button/Button"),_Inline=require("../Inline/Inline"),_Divider=require("../Divider/Divider"),_Checkbox=require("../Form/Checkbox/Checkbox"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),_SearchInput=require("../Form/SearchInput/SearchInput"),containerSmallSize=_breakpointsjson.default.small.value,toolbarContainerName="bulkActionsToolbar",containerSmall=`@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`,containerLarge=`@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`,StyledBulkActionsToolbarContainer=/*#__PURE__*/(0,_styled.default)("div",{target:"ecwacyn0",label:"StyledBulkActionsToolbarContainer"})({containerType:"inline-size",containerName:toolbarContainerName},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAoC0C"} */"),InlineContainer=/*#__PURE__*/(0,_styled.default)("div",{target:"ecwacyn1",label:"InlineContainer"})(({theme})=>({display:"flex",padding:theme.variables.size.spacing.xs,justifyContent:"space-between",[containerSmall]:{flexWrap:"wrap",gap:theme.variables.size.spacing.xs},[containerLarge]:{paddingLeft:theme.variables.size.spacing.m,gap:theme.variables.size.spacing.m}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAyCwB"} */"),InlineItem=/*#__PURE__*/(0,_styled.default)("div",{target:"ecwacyn2",label:"InlineItem"})(({order,theme})=>({display:"flex",flexWrap:"nowrap",alignItems:"center",gap:theme.variables.size.spacing.xs,[containerSmall]:{flexBasis:"100%",order:order?.[0],justifyContent:"space-between"},[containerLarge]:{order:order?.[1]}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAuDmB"} */"),StyledSearch=/*#__PURE__*/(0,_styled.default)("div",{target:"ecwacyn3",label:"StyledSearch"})({[containerSmall]:{flexGrow:1,order:-1,flexBasis:"100%"}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAuEqB"} */"),StyledRightSlot=/*#__PURE__*/(0,_styled.default)("div",{target:"ecwacyn4",label:"StyledRightSlot"})(({theme,rightContentNoWrapOnMobile})=>({display:"flex",justifyContent:"flex-end",alignItems:"center",flex:1,gap:theme.variables.size.spacing.xs,...!rightContentNoWrapOnMobile&&{[containerSmall]:{flexWrap:"wrap"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AA+EwB"} */"),StyledRightContent=/*#__PURE__*/(0,_styled.default)("div",{target:"ecwacyn5",label:"StyledRightContent"})(({rightContentNoWrapOnMobile})=>({...!rightContentNoWrapOnMobile&&{[containerSmall]:{flexGrow:1}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AA8F2B"} */"),CustomInline=/*#__PURE__*/(0,_styled.default)(_Inline.Inline,{target:"ecwacyn6",label:"CustomInline"})(({theme})=>({[containerSmall]:{gap:theme.variables.size.spacing.xxs},[containerLarge]:{gap:theme.variables.size.spacing.m}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAwGqB"} */"),CheckboxStyled=/*#__PURE__*/(0,_styled.default)("div",{target:"ecwacyn7",label:"CheckboxStyled"})(({theme})=>({paddingLeft:theme.variables.size.spacing.xs,paddingBottom:theme.variables.size.spacing.xs,[containerLarge]:{paddingRight:theme.variables.size.spacing.xxs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAiHuB"} */"),TotalItemsStyled=/*#__PURE__*/(0,_styled.default)("div",{target:"ecwacyn8",label:"TotalItemsStyled"})(({theme})=>({[containerSmall]:{padding:theme.variables.size.spacing.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/BulkActionsToolbar/BulkActionsToolbar.tsx","sources":["src/components/BulkActionsToolbar/BulkActionsToolbar.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FC, PropsWithChildren } from \"react\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Button, type ButtonProps } from \"../Button/Button\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Divider } from \"../Divider/Divider\";\nimport { Checkbox, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\n\ntype ActionProp = {\n  label: string;\n} & Omit<ButtonProps, \"children\" | \"size\">;\n\nexport type BulkActionsToolbarProps = {\n  actions?: ActionProp[];\n  // should be always wrapped into useMemo in order to avoid unnecessary re-renders\n  searchInputProps: SearchInputProps;\n  checkboxProps?: CheckboxProps;\n  totalItems: string;\n  renderRightContent?: () => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.small.value;\nconst toolbarContainerName = \"bulkActionsToolbar\";\nconst containerSmall = `@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`;\nconst containerLarge = `@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`;\n\nconst StyledBulkActionsToolbarContainer = styled.div({\n  containerType: \"inline-size\",\n  containerName: toolbarContainerName,\n});\n\nconst InlineContainer = styled.div(({ theme }) => ({\n  display: \"flex\",\n  padding: theme.variables.size.spacing.xs,\n  justifyContent: \"space-between\",\n  [containerSmall]: {\n    flexWrap: \"wrap\",\n    gap: theme.variables.size.spacing.xs,\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst InlineItem = styled.div<{ order?: number[] }>(({ order, theme }) => ({\n  display: \"flex\",\n  flexWrap: \"nowrap\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n\n  [containerSmall]: {\n    flexBasis: \"100%\",\n    order: order?.[0],\n    justifyContent: \"space-between\",\n  },\n  [containerLarge]: {\n    order: order?.[1],\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    flexGrow: 1,\n    order: -1,\n    flexBasis: \"100%\",\n  },\n});\n\nconst StyledRightSlot = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ theme, rightContentNoWrapOnMobile }) => ({\n  display: \"flex\",\n  justifyContent: \"flex-end\",\n  alignItems: \"center\",\n  flex: 1,\n  gap: theme.variables.size.spacing.xs,\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexWrap: \"wrap\",\n    },\n  }),\n}));\n\nconst StyledRightContent = styled.div<\n  Pick<BulkActionsToolbarProps, \"rightContentNoWrapOnMobile\">\n>(({ rightContentNoWrapOnMobile }) => ({\n  ...(!rightContentNoWrapOnMobile && {\n    [containerSmall]: {\n      flexGrow: 1,\n    },\n  }),\n}));\n\nconst CustomInline = styled(Inline)(({ theme }) => ({\n  [containerSmall]: {\n    gap: theme.variables.size.spacing.xxs,\n  },\n  [containerLarge]: {\n    gap: theme.variables.size.spacing.m,\n  },\n}));\n\nconst CheckboxStyled = styled.div(({ theme }) => ({\n  paddingLeft: theme.variables.size.spacing.xs,\n  paddingBottom: theme.variables.size.spacing.xs,\n  [containerLarge]: {\n    paddingRight: theme.variables.size.spacing.xxs,\n  },\n}));\n\nconst TotalItemsStyled = styled.div(({ theme }) => ({\n  [containerSmall]: {\n    padding: theme.variables.size.spacing.xs,\n  },\n}));\n\nconst TotalItems: FC<PropsWithChildren> = ({ children }) => (\n  <TotalItemsStyled>\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\">\n      {children}\n    </Text>\n  </TotalItemsStyled>\n);\n\nfunction BulkActionsToolbarUI({\n  actions,\n  checkboxProps,\n  totalItems,\n  searchInputProps,\n  renderRightContent,\n  rightContentNoWrapOnMobile,\n  hideDivider,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: BulkActionsToolbarProps): React.ReactElement {\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <Checkbox size=\"s\" {...checkboxProps} />\n              </CheckboxStyled>\n              <TotalItems>{totalItems}</TotalItems>\n            </CustomInline>\n          ) : (\n            <TotalItems>{totalItems}</TotalItems>\n          )}\n\n          <Inline noWrap>\n            {actions?.map(\n              ({ variant = \"secondary\", label, ...buttonProps }) => (\n                <Button\n                  {...buttonProps}\n                  key={`action-${label}`}\n                  size=\"s\"\n                  variant={variant}\n                >\n                  {label}\n                </Button>\n              )\n            )}\n          </Inline>\n        </InlineItem>\n\n        <InlineItem order={[-1, 1]}>\n          <StyledRightSlot\n            rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n          >\n            {renderRightContent && (\n              <StyledRightContent>{renderRightContent()}</StyledRightContent>\n            )}\n            <StyledSearch>\n              <SearchInput {...searchInputProps} />\n            </StyledSearch>\n          </StyledRightSlot>\n        </InlineItem>\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAyHyB"} */"),TotalItems=({children})=>/*#__PURE__*/_react.default.createElement(TotalItemsStyled,null,/*#__PURE__*/_react.default.createElement(_Text.Text,{size:"s",color:"secondary",weight:"bold"},children)),BulkActionsToolbar=/*#__PURE__*/_react.default.memo(function({actions,checkboxProps,totalItems,searchInputProps,renderRightContent,rightContentNoWrapOnMobile,hideDivider,"data-e2e-test-id":dataE2eTestId}){return /*#__PURE__*/_react.default.createElement(StyledBulkActionsToolbarContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Toolbar"},/*#__PURE__*/_react.default.createElement(InlineContainer,null,/*#__PURE__*/_react.default.createElement(InlineItem,{order:[1,-1]},checkboxProps?/*#__PURE__*/_react.default.createElement(CustomInline,{vAlignItems:"center"},/*#__PURE__*/_react.default.createElement(CheckboxStyled,null,/*#__PURE__*/_react.default.createElement(_Checkbox.Checkbox,{size:"s",...checkboxProps})),/*#__PURE__*/_react.default.createElement(TotalItems,null,totalItems)):/*#__PURE__*/_react.default.createElement(TotalItems,null,totalItems),/*#__PURE__*/_react.default.createElement(_Inline.Inline,{noWrap:!0},actions?.map(({variant="secondary",label,...buttonProps})=>/*#__PURE__*/_react.default.createElement(_Button.Button,{...buttonProps,key:`action-${label}`,size:"s",variant:variant},label)))),/*#__PURE__*/_react.default.createElement(InlineItem,{order:[-1,1]},/*#__PURE__*/_react.default.createElement(StyledRightSlot,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent&&/*#__PURE__*/_react.default.createElement(StyledRightContent,null,renderRightContent()),/*#__PURE__*/_react.default.createElement(StyledSearch,null,/*#__PURE__*/_react.default.createElement(_SearchInput.SearchInput,searchInputProps))))),!hideDivider&&/*#__PURE__*/_react.default.createElement(_Divider.Divider,null))});
|
|
@@ -31,6 +31,8 @@ export type ColumnProps = {
|
|
|
31
31
|
*/
|
|
32
32
|
order?: Order | MQ<Order>;
|
|
33
33
|
alignSelf?: ColumnAlignment | MQ<ColumnAlignment>;
|
|
34
|
+
/** display column at given breakpoint */
|
|
35
|
+
show?: boolean | MQ<boolean>;
|
|
34
36
|
"data-e2e-test-id"?: string;
|
|
35
37
|
/** @ignore */
|
|
36
38
|
"data-ds-id"?: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{Column:function(){return Column},Columns:function(){return Columns}});const _styled=/*#__PURE__*/require("@swc/helpers/_/_interop_require_default")._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),columnWidthObject=Array(12).fill("").reduce((acc,_,index)=>({...acc,[index+1]:`${(index+1)*100/12}%`}),{}),makeNegative=obj=>Object.entries(obj).map(([key,value])=>[key,`-${value}`]).reduce((acc,[key,value])=>(acc[key]=value,acc),{}),Column=/*#__PURE__*/(0,_styled.default)("div",{target:"e1ostpc10",label:"Column"})(({size,order,alignSelf})=>({...(0,_mediaQueries.mq)({width:[size,{...columnWidthObject,fill:"1px"}],flex:[size,{narrow:"none",auto:"1",fill:void 0}],order:[order,{first:"-1",last:"1",unset:"0"}],flexShrink:[size,{fill:1,auto:void 0,narrow:void 0}],flexGrow:[size,{fill:1,auto:void 0,narrow:void 0}],alignSelf:[alignSelf,{auto:"auto",start:"start",center:"center",end:"end"}]}),boxSizing:"border-box","&:empty":{width:0,flex:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sdW1uL0NvbHVtbnMudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2x1bW4vQ29sdW1ucy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IG1xIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB0eXBlIHtcbiAgTVEsXG4gIEhvcml6b250YWxBbGlnbm1lbnQsXG4gIFNwYWNlU2l6ZXMsXG4gIFZlcnRpY2FsQWxpZ25tZW50LFxuICBDb2x1bW5TaXplcyxcbiAgQ29sdW1uQWxpZ25tZW50LFxuICBPcmRlcixcbn0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIENvbHVtbnNQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVtdIHwgUmVhY3QuUmVhY3ROb2RlO1xuXG4gIC8qKiByZXByZXNlbnRzIHRoZSBzaXplIG9mIGJvdGggaG9yaXpvbnRhbCBhbmQgdmVydGljYWwgZ2FwIGJldHdlZW4gY2hpbGRyZW4sIGNhbiBiZSBhIHNpbmdsZSBzdHJpbmcgb3IgYW4gYXJyYXkgb2YgMyBzdHJpbmdzXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBnYXAgc2l6ZSwgbWVkaXVtIHNjcmVlbiBnYXAgc2l6ZSwgbGFyZ2Ugc2NyZWVuIGdhcCBzaXplXSB0byBhcHBseSBkaWZmZXJlbnQgZ2FwIHNpemVzIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBnYXA/OiBTcGFjZVNpemVzIHwgTVE8U3BhY2VTaXplcz47XG5cbiAgLyoqIHNldCB0byB0cnVlIGlmIHlvdSB3YW50IHRoZSBsYXN0IGVsZW1lbnQgdG8gZmlsbCB0aGUgc3BhY2VcbiAgICovXG4gIGFsd2F5c0ZpbGxTcGFjZT86IGJvb2xlYW47XG5cbiAgLyoqIHNwZWNpZnkgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIHRvIGFwcGx5IGRpZmZlcmVudCBhbGlnbkl0ZW1zIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogSG9yaXpvbnRhbEFsaWdubWVudCB8IE1RPEhvcml6b250YWxBbGlnbm1lbnQ+O1xuXG4gIC8qKiBzcGVjaWZ5IHZlcnRpY2FsIGFsaWdubWVudFxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gdkFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gdkFsaWduSXRlbXMsIGxhcmdlIHNjcmVlbiB2QWxpZ25JdGVtc10gdG8gYXBwbHkgZGlmZmVyZW50IHZBbGlnbkl0ZW1zIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICB2QWxpZ25JdGVtcz86IFZlcnRpY2FsQWxpZ25tZW50IHwgTVE8VmVydGljYWxBbGlnbm1lbnQ+O1xuXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuXG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQYXJ0aWFsPENvbHVtbnNQcm9wcz4gPSB7XG4gIGdhcDogXCJ6ZXJvXCIsXG4gIGFsd2F5c0ZpbGxTcGFjZTogZmFsc2UsXG4gIGFsaWduSXRlbXM6IFwibGVmdFwiLFxuICB2QWxpZ25JdGVtczogXCJ0b3BcIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbiAgXCJkYXRhLWRzLWlkXCI6IFwiQ29sdW1uc1wiLFxufTtcblxuZXhwb3J0IHR5cGUgQ29sdW1uUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0Tm9kZTtcblxuICAvKiogcmVwcmVzZW50cyB0aGUgc2l6ZSBvZiB0aGUgY29sdW1uLCBjYW4gYmUgYSBzaW5nbGUgbnVtYmVyIG9yIGFuIGFycmF5IG9mIDMgbnVtYmVycyB3aXRoIGEgdmFsdWUgcmFuZ2luZyBmcm9tIDEgdG8gMTJcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGNvbHVtbiBzaXplLCBtZWRpdW0gc2NyZWVuIGNvbHVtbiBzaXplLCBsYXJnZSBzY3JlZW4gY29sdW1uIHNpemVdIHRvIGFwcGx5IGRpZmZlcmVudCB2YWx1ZXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNpemU/OiBDb2x1bW5TaXplcyB8IE1RPENvbHVtblNpemVzPjtcblxuICAvKiogc3BlY2lmeSB0aGUgdmlzdWFsIHBvc2l0aW9uaW5nIG9mIHRoZSBjb2x1bW4uIFtzbWFsbCBzY3JlZW4gY29sdW1uIG9yZGVyLCBtZWRpdW0gc2NyZWVuIGNvbHVtbiBvcmRlciwgbGFyZ2Ugc2NyZWVuIGNvbHVtbiBvcmRlcl0gdG8gYXBwbHkgZGlmZmVyZW50IG9yZGVyIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBvcmRlcj86IE9yZGVyIHwgTVE8T3JkZXI+O1xuXG4gIGFsaWduU2VsZj86IENvbHVtbkFsaWdubWVudCB8IE1RPENvbHVtbkFsaWdubWVudD47XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBjb2x1bW5EZWZhdWx0UHJvcHM6IFBhcnRpYWw8Q29sdW1uUHJvcHM+ID0ge1xuICBzaXplOiBcImF1dG9cIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbiAgYWxpZ25TZWxmOiBcImF1dG9cIixcbiAgXCJkYXRhLWRzLWlkXCI6IFwiQ29sdW1uXCIsXG59O1xuXG5jb25zdCBjb2x1bW5XaWR0aE9iamVjdCA9IG5ldyBBcnJheSgxMikuZmlsbChcIlwiKS5yZWR1Y2UoXG4gIChhY2MsIF8sIGluZGV4KSA9PiAoe1xuICAgIC4uLmFjYyxcbiAgICBbaW5kZXggKyAxXTogYCR7KChpbmRleCArIDEpICogMTAwKSAvIDEyfSVgLFxuICB9KSxcbiAge31cbik7XG5cbmNvbnN0IG1ha2VOZWdhdGl2ZSA9IChvYmo6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4pOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0+XG4gIE9iamVjdC5lbnRyaWVzKG9iailcbiAgICAubWFwKChba2V5LCB2YWx1ZV0pID0+IFtrZXksIGAtJHt2YWx1ZX1gXSlcbiAgICAucmVkdWNlKChhY2MsIFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgYWNjW2tleV0gPSB2YWx1ZTtcbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSwge30gYXMgUmVjb3JkPHN0cmluZywgc3RyaW5nPik7XG5cbmV4cG9ydCBjb25zdCBDb2x1bW4gPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q29sdW1uUHJvcHM+PihcbiAgKHsgc2l6ZSwgb3JkZXIsIGFsaWduU2VsZiB9KSA9PiAoe1xuICAgIC4uLm1xKHtcbiAgICAgIHdpZHRoOiBbc2l6ZSwgeyAuLi5jb2x1bW5XaWR0aE9iamVjdCwgZmlsbDogXCIxcHhcIiB9XSxcbiAgICAgIGZsZXg6IFtzaXplLCB7IG5hcnJvdzogXCJub25lXCIsIGF1dG86IFwiMVwiLCBmaWxsOiB1bmRlZmluZWQgfV0sXG4gICAgICBvcmRlcjogW29yZGVyLCB7IGZpcnN0OiBcIi0xXCIsIGxhc3Q6IFwiMVwiLCB1bnNldDogXCIwXCIgfV0sXG4gICAgICBmbGV4U2hyaW5rOiBbc2l6ZSwgeyBmaWxsOiAxLCBhdXRvOiB1bmRlZmluZWQsIG5hcnJvdzogdW5kZWZpbmVkIH1dLFxuICAgICAgZmxleEdyb3c6IFtzaXplLCB7IGZpbGw6IDEsIGF1dG86IHVuZGVmaW5lZCwgbmFycm93OiB1bmRlZmluZWQgfV0sXG4gICAgICBhbGlnblNlbGY6IFtcbiAgICAgICAgYWxpZ25TZWxmLFxuICAgICAgICB7XG4gICAgICAgICAgYXV0bzogXCJhdXRvXCIsXG4gICAgICAgICAgc3RhcnQ6IFwic3RhcnRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgZW5kOiBcImVuZFwiLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9KSxcbiAgICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxuICAgIFwiJjplbXB0eVwiOiB7XG4gICAgICB3aWR0aDogMCxcbiAgICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIH0sXG4gIH0pXG4pO1xuXG5Db2x1bW4uZGVmYXVsdFByb3BzID0gY29sdW1uRGVmYXVsdFByb3BzO1xuXG5leHBvcnQgY29uc3QgQ29sdW1ucyA9IHN0eWxlZC5kaXY8UGFydGlhbDxDb2x1bW5zUHJvcHM+PihcbiAgKHsgdGhlbWUsIGFsaWduSXRlbXMsIHZBbGlnbkl0ZW1zLCBnYXAgfSkgPT4gKHtcbiAgICB3aWR0aDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAganVzdGlmeUl0ZW1zOiBcInN0cmV0Y2hcIixcbiAgICBqdXN0aWZ5Q29udGVudDogXCJzdHJldGNoXCIsXG4gICAgYWxpZ25JdGVtczogXCJzdHJldGNoXCIsXG4gICAgZmxleFdyYXA6IFwid3JhcFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgLi4ubXEoe1xuICAgICAgYWxpZ25JdGVtczogW1xuICAgICAgICB2QWxpZ25JdGVtcyxcbiAgICAgICAge1xuICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgYm90dG9tOiBcImZsZXgtZW5kXCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIHN0cmV0Y2g6IFwic3RyZXRjaFwiLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIGp1c3RpZnlDb250ZW50OiBbXG4gICAgICAgIGFsaWduSXRlbXMsXG4gICAgICAgIHtcbiAgICAgICAgICBsZWZ0OiBcImZsZXgtc3RhcnRcIixcbiAgICAgICAgICByaWdodDogXCJmbGV4LWVuZFwiLFxuICAgICAgICAgIGNlbnRlcjogXCJjZW50ZXJcIixcbiAgICAgICAgICBzcGFjZUJldHdlZW46IFwic3BhY2UtYmV0d2VlblwiLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIG1hcmdpblJpZ2h0OiBbZ2FwLCBtYWtlTmVnYXRpdmUodGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZyldLFxuICAgICAgbWFyZ2luQm90dG9tOiBbZ2FwLCBtYWtlTmVnYXRpdmUodGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZyldLFxuICAgIH0pLFxuXG4gICAgW2AmID4gJHtDb2x1bW59YF06IHtcbiAgICAgIC4uLm1xKHtcbiAgICAgICAgbWFyZ2luQm90dG9tOiBbZ2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgICAgcGFkZGluZ1JpZ2h0OiBbZ2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIH0pLFxuICAgIH0sXG4gIH0pLFxuICAoeyBhbHdheXNGaWxsU3BhY2UgfSkgPT5cbiAgICBhbHdheXNGaWxsU3BhY2UgJiYge1xuICAgICAgW2AmID4gJHtDb2x1bW59YF06IHtcbiAgICAgICAgXCImOmxhc3QtY2hpbGRcIjoge1xuICAgICAgICAgIGZsZXhHcm93OiAxLFxuICAgICAgICAgIGZsZXhTaHJpbms6IDEsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH1cbik7XG5cbkNvbHVtbnMuZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZGc0IifQ== */");Column.defaultProps={size:"auto","data-e2e-test-id":void 0,alignSelf:"auto","data-ds-id":"Column"};const Columns=/*#__PURE__*/(0,_styled.default)("div",{target:"e1ostpc11",label:"Columns"})(({theme,alignItems,vAlignItems,gap})=>({width:"auto",display:"flex",justifyItems:"stretch",justifyContent:"stretch",alignItems:"stretch",flexWrap:"wrap",flexDirection:"row",...(0,_mediaQueries.mq)({alignItems:[vAlignItems,{top:"flex-start",bottom:"flex-end",center:"center",stretch:"stretch"}],justifyContent:[alignItems,{left:"flex-start",right:"flex-end",center:"center",spaceBetween:"space-between"}],marginRight:[gap,makeNegative(theme.variables.size.spacing)],marginBottom:[gap,makeNegative(theme.variables.size.spacing)]}),[`& > ${Column}`]:{...(0,_mediaQueries.mq)({marginBottom:[gap,theme.variables.size.spacing],paddingRight:[gap,theme.variables.size.spacing]})}}),({alwaysFillSpace})=>alwaysFillSpace&&{[`& > ${Column}`]:{"&:last-child":{flexGrow:1,flexShrink:1}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sdW1uL0NvbHVtbnMudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2x1bW4vQ29sdW1ucy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IG1xIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB0eXBlIHtcbiAgTVEsXG4gIEhvcml6b250YWxBbGlnbm1lbnQsXG4gIFNwYWNlU2l6ZXMsXG4gIFZlcnRpY2FsQWxpZ25tZW50LFxuICBDb2x1bW5TaXplcyxcbiAgQ29sdW1uQWxpZ25tZW50LFxuICBPcmRlcixcbn0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIENvbHVtbnNQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVtdIHwgUmVhY3QuUmVhY3ROb2RlO1xuXG4gIC8qKiByZXByZXNlbnRzIHRoZSBzaXplIG9mIGJvdGggaG9yaXpvbnRhbCBhbmQgdmVydGljYWwgZ2FwIGJldHdlZW4gY2hpbGRyZW4sIGNhbiBiZSBhIHNpbmdsZSBzdHJpbmcgb3IgYW4gYXJyYXkgb2YgMyBzdHJpbmdzXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBnYXAgc2l6ZSwgbWVkaXVtIHNjcmVlbiBnYXAgc2l6ZSwgbGFyZ2Ugc2NyZWVuIGdhcCBzaXplXSB0byBhcHBseSBkaWZmZXJlbnQgZ2FwIHNpemVzIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBnYXA/OiBTcGFjZVNpemVzIHwgTVE8U3BhY2VTaXplcz47XG5cbiAgLyoqIHNldCB0byB0cnVlIGlmIHlvdSB3YW50IHRoZSBsYXN0IGVsZW1lbnQgdG8gZmlsbCB0aGUgc3BhY2VcbiAgICovXG4gIGFsd2F5c0ZpbGxTcGFjZT86IGJvb2xlYW47XG5cbiAgLyoqIHNwZWNpZnkgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIHRvIGFwcGx5IGRpZmZlcmVudCBhbGlnbkl0ZW1zIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogSG9yaXpvbnRhbEFsaWdubWVudCB8IE1RPEhvcml6b250YWxBbGlnbm1lbnQ+O1xuXG4gIC8qKiBzcGVjaWZ5IHZlcnRpY2FsIGFsaWdubWVudFxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gdkFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gdkFsaWduSXRlbXMsIGxhcmdlIHNjcmVlbiB2QWxpZ25JdGVtc10gdG8gYXBwbHkgZGlmZmVyZW50IHZBbGlnbkl0ZW1zIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICB2QWxpZ25JdGVtcz86IFZlcnRpY2FsQWxpZ25tZW50IHwgTVE8VmVydGljYWxBbGlnbm1lbnQ+O1xuXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuXG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQYXJ0aWFsPENvbHVtbnNQcm9wcz4gPSB7XG4gIGdhcDogXCJ6ZXJvXCIsXG4gIGFsd2F5c0ZpbGxTcGFjZTogZmFsc2UsXG4gIGFsaWduSXRlbXM6IFwibGVmdFwiLFxuICB2QWxpZ25JdGVtczogXCJ0b3BcIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbiAgXCJkYXRhLWRzLWlkXCI6IFwiQ29sdW1uc1wiLFxufTtcblxuZXhwb3J0IHR5cGUgQ29sdW1uUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0Tm9kZTtcblxuICAvKiogcmVwcmVzZW50cyB0aGUgc2l6ZSBvZiB0aGUgY29sdW1uLCBjYW4gYmUgYSBzaW5nbGUgbnVtYmVyIG9yIGFuIGFycmF5IG9mIDMgbnVtYmVycyB3aXRoIGEgdmFsdWUgcmFuZ2luZyBmcm9tIDEgdG8gMTJcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGNvbHVtbiBzaXplLCBtZWRpdW0gc2NyZWVuIGNvbHVtbiBzaXplLCBsYXJnZSBzY3JlZW4gY29sdW1uIHNpemVdIHRvIGFwcGx5IGRpZmZlcmVudCB2YWx1ZXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNpemU/OiBDb2x1bW5TaXplcyB8IE1RPENvbHVtblNpemVzPjtcblxuICAvKiogc3BlY2lmeSB0aGUgdmlzdWFsIHBvc2l0aW9uaW5nIG9mIHRoZSBjb2x1bW4uIFtzbWFsbCBzY3JlZW4gY29sdW1uIG9yZGVyLCBtZWRpdW0gc2NyZWVuIGNvbHVtbiBvcmRlciwgbGFyZ2Ugc2NyZWVuIGNvbHVtbiBvcmRlcl0gdG8gYXBwbHkgZGlmZmVyZW50IG9yZGVyIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBvcmRlcj86IE9yZGVyIHwgTVE8T3JkZXI+O1xuXG4gIGFsaWduU2VsZj86IENvbHVtbkFsaWdubWVudCB8IE1RPENvbHVtbkFsaWdubWVudD47XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBjb2x1bW5EZWZhdWx0UHJvcHM6IFBhcnRpYWw8Q29sdW1uUHJvcHM+ID0ge1xuICBzaXplOiBcImF1dG9cIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbiAgYWxpZ25TZWxmOiBcImF1dG9cIixcbiAgXCJkYXRhLWRzLWlkXCI6IFwiQ29sdW1uXCIsXG59O1xuXG5jb25zdCBjb2x1bW5XaWR0aE9iamVjdCA9IG5ldyBBcnJheSgxMikuZmlsbChcIlwiKS5yZWR1Y2UoXG4gIChhY2MsIF8sIGluZGV4KSA9PiAoe1xuICAgIC4uLmFjYyxcbiAgICBbaW5kZXggKyAxXTogYCR7KChpbmRleCArIDEpICogMTAwKSAvIDEyfSVgLFxuICB9KSxcbiAge31cbik7XG5cbmNvbnN0IG1ha2VOZWdhdGl2ZSA9IChvYmo6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4pOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0+XG4gIE9iamVjdC5lbnRyaWVzKG9iailcbiAgICAubWFwKChba2V5LCB2YWx1ZV0pID0+IFtrZXksIGAtJHt2YWx1ZX1gXSlcbiAgICAucmVkdWNlKChhY2MsIFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgYWNjW2tleV0gPSB2YWx1ZTtcbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSwge30gYXMgUmVjb3JkPHN0cmluZywgc3RyaW5nPik7XG5cbmV4cG9ydCBjb25zdCBDb2x1bW4gPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q29sdW1uUHJvcHM+PihcbiAgKHsgc2l6ZSwgb3JkZXIsIGFsaWduU2VsZiB9KSA9PiAoe1xuICAgIC4uLm1xKHtcbiAgICAgIHdpZHRoOiBbc2l6ZSwgeyAuLi5jb2x1bW5XaWR0aE9iamVjdCwgZmlsbDogXCIxcHhcIiB9XSxcbiAgICAgIGZsZXg6IFtzaXplLCB7IG5hcnJvdzogXCJub25lXCIsIGF1dG86IFwiMVwiLCBmaWxsOiB1bmRlZmluZWQgfV0sXG4gICAgICBvcmRlcjogW29yZGVyLCB7IGZpcnN0OiBcIi0xXCIsIGxhc3Q6IFwiMVwiLCB1bnNldDogXCIwXCIgfV0sXG4gICAgICBmbGV4U2hyaW5rOiBbc2l6ZSwgeyBmaWxsOiAxLCBhdXRvOiB1bmRlZmluZWQsIG5hcnJvdzogdW5kZWZpbmVkIH1dLFxuICAgICAgZmxleEdyb3c6IFtzaXplLCB7IGZpbGw6IDEsIGF1dG86IHVuZGVmaW5lZCwgbmFycm93OiB1bmRlZmluZWQgfV0sXG4gICAgICBhbGlnblNlbGY6IFtcbiAgICAgICAgYWxpZ25TZWxmLFxuICAgICAgICB7XG4gICAgICAgICAgYXV0bzogXCJhdXRvXCIsXG4gICAgICAgICAgc3RhcnQ6IFwic3RhcnRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgZW5kOiBcImVuZFwiLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9KSxcbiAgICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxuICAgIFwiJjplbXB0eVwiOiB7XG4gICAgICB3aWR0aDogMCxcbiAgICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIH0sXG4gIH0pXG4pO1xuXG5Db2x1bW4uZGVmYXVsdFByb3BzID0gY29sdW1uRGVmYXVsdFByb3BzO1xuXG5leHBvcnQgY29uc3QgQ29sdW1ucyA9IHN0eWxlZC5kaXY8UGFydGlhbDxDb2x1bW5zUHJvcHM+PihcbiAgKHsgdGhlbWUsIGFsaWduSXRlbXMsIHZBbGlnbkl0ZW1zLCBnYXAgfSkgPT4gKHtcbiAgICB3aWR0aDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAganVzdGlmeUl0ZW1zOiBcInN0cmV0Y2hcIixcbiAgICBqdXN0aWZ5Q29udGVudDogXCJzdHJldGNoXCIsXG4gICAgYWxpZ25JdGVtczogXCJzdHJldGNoXCIsXG4gICAgZmxleFdyYXA6IFwid3JhcFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgLi4ubXEoe1xuICAgICAgYWxpZ25JdGVtczogW1xuICAgICAgICB2QWxpZ25JdGVtcyxcbiAgICAgICAge1xuICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgYm90dG9tOiBcImZsZXgtZW5kXCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIHN0cmV0Y2g6IFwic3RyZXRjaFwiLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIGp1c3RpZnlDb250ZW50OiBbXG4gICAgICAgIGFsaWduSXRlbXMsXG4gICAgICAgIHtcbiAgICAgICAgICBsZWZ0OiBcImZsZXgtc3RhcnRcIixcbiAgICAgICAgICByaWdodDogXCJmbGV4LWVuZFwiLFxuICAgICAgICAgIGNlbnRlcjogXCJjZW50ZXJcIixcbiAgICAgICAgICBzcGFjZUJldHdlZW46IFwic3BhY2UtYmV0d2VlblwiLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIG1hcmdpblJpZ2h0OiBbZ2FwLCBtYWtlTmVnYXRpdmUodGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZyldLFxuICAgICAgbWFyZ2luQm90dG9tOiBbZ2FwLCBtYWtlTmVnYXRpdmUodGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZyldLFxuICAgIH0pLFxuXG4gICAgW2AmID4gJHtDb2x1bW59YF06IHtcbiAgICAgIC4uLm1xKHtcbiAgICAgICAgbWFyZ2luQm90dG9tOiBbZ2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgICAgcGFkZGluZ1JpZ2h0OiBbZ2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIH0pLFxuICAgIH0sXG4gIH0pLFxuICAoeyBhbHdheXNGaWxsU3BhY2UgfSkgPT5cbiAgICBhbHdheXNGaWxsU3BhY2UgJiYge1xuICAgICAgW2AmID4gJHtDb2x1bW59YF06IHtcbiAgICAgICAgXCImOmxhc3QtY2hpbGRcIjoge1xuICAgICAgICAgIGZsZXhHcm93OiAxLFxuICAgICAgICAgIGZsZXhTaHJpbms6IDEsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH1cbik7XG5cbkNvbHVtbnMuZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlIdUIifQ== */");Columns.defaultProps={gap:"zero",alwaysFillSpace:!1,alignItems:"left",vAlignItems:"top","data-e2e-test-id":void 0,"data-ds-id":"Columns"};
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{Column:function(){return Column},Columns:function(){return Columns}});const _styled=/*#__PURE__*/require("@swc/helpers/_/_interop_require_default")._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),columnWidthObject=Array(12).fill("").reduce((acc,_,index)=>({...acc,[index+1]:`${(index+1)*100/12}%`}),{}),makeNegative=obj=>Object.entries(obj).map(([key,value])=>[key,`-${value}`]).reduce((acc,[key,value])=>(acc[key]=value,acc),{}),Column=/*#__PURE__*/(0,_styled.default)("div",{target:"e1xdzf2i0",label:"Column"})(({size,order,alignSelf,show})=>({...(0,_mediaQueries.mq)({width:[size,{...columnWidthObject,fill:"1px"}],flex:[size,{narrow:"none",auto:"1",fill:void 0}],order:[order,{first:"-1",last:"1",unset:"0"}],flexShrink:[size,{fill:1,auto:void 0,narrow:void 0}],flexGrow:[size,{fill:1,auto:void 0,narrow:void 0}],alignSelf:[alignSelf,{auto:"auto",start:"start",center:"center",end:"end"}],display:[show,value=>value?"block":"none"]}),boxSizing:"border-box","&:empty":{width:0,flex:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sdW1uL0NvbHVtbnMudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2x1bW4vQ29sdW1ucy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IG1xIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB0eXBlIHtcbiAgTVEsXG4gIEhvcml6b250YWxBbGlnbm1lbnQsXG4gIFNwYWNlU2l6ZXMsXG4gIFZlcnRpY2FsQWxpZ25tZW50LFxuICBDb2x1bW5TaXplcyxcbiAgQ29sdW1uQWxpZ25tZW50LFxuICBPcmRlcixcbn0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIENvbHVtbnNQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVtdIHwgUmVhY3QuUmVhY3ROb2RlO1xuXG4gIC8qKiByZXByZXNlbnRzIHRoZSBzaXplIG9mIGJvdGggaG9yaXpvbnRhbCBhbmQgdmVydGljYWwgZ2FwIGJldHdlZW4gY2hpbGRyZW4sIGNhbiBiZSBhIHNpbmdsZSBzdHJpbmcgb3IgYW4gYXJyYXkgb2YgMyBzdHJpbmdzXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBnYXAgc2l6ZSwgbWVkaXVtIHNjcmVlbiBnYXAgc2l6ZSwgbGFyZ2Ugc2NyZWVuIGdhcCBzaXplXSB0byBhcHBseSBkaWZmZXJlbnQgZ2FwIHNpemVzIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBnYXA/OiBTcGFjZVNpemVzIHwgTVE8U3BhY2VTaXplcz47XG5cbiAgLyoqIHNldCB0byB0cnVlIGlmIHlvdSB3YW50IHRoZSBsYXN0IGVsZW1lbnQgdG8gZmlsbCB0aGUgc3BhY2VcbiAgICovXG4gIGFsd2F5c0ZpbGxTcGFjZT86IGJvb2xlYW47XG5cbiAgLyoqIHNwZWNpZnkgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIHRvIGFwcGx5IGRpZmZlcmVudCBhbGlnbkl0ZW1zIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogSG9yaXpvbnRhbEFsaWdubWVudCB8IE1RPEhvcml6b250YWxBbGlnbm1lbnQ+O1xuXG4gIC8qKiBzcGVjaWZ5IHZlcnRpY2FsIGFsaWdubWVudFxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gdkFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gdkFsaWduSXRlbXMsIGxhcmdlIHNjcmVlbiB2QWxpZ25JdGVtc10gdG8gYXBwbHkgZGlmZmVyZW50IHZBbGlnbkl0ZW1zIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICB2QWxpZ25JdGVtcz86IFZlcnRpY2FsQWxpZ25tZW50IHwgTVE8VmVydGljYWxBbGlnbm1lbnQ+O1xuXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuXG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQYXJ0aWFsPENvbHVtbnNQcm9wcz4gPSB7XG4gIGdhcDogXCJ6ZXJvXCIsXG4gIGFsd2F5c0ZpbGxTcGFjZTogZmFsc2UsXG4gIGFsaWduSXRlbXM6IFwibGVmdFwiLFxuICB2QWxpZ25JdGVtczogXCJ0b3BcIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbiAgXCJkYXRhLWRzLWlkXCI6IFwiQ29sdW1uc1wiLFxufTtcblxuZXhwb3J0IHR5cGUgQ29sdW1uUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0Tm9kZTtcblxuICAvKiogcmVwcmVzZW50cyB0aGUgc2l6ZSBvZiB0aGUgY29sdW1uLCBjYW4gYmUgYSBzaW5nbGUgbnVtYmVyIG9yIGFuIGFycmF5IG9mIDMgbnVtYmVycyB3aXRoIGEgdmFsdWUgcmFuZ2luZyBmcm9tIDEgdG8gMTJcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGNvbHVtbiBzaXplLCBtZWRpdW0gc2NyZWVuIGNvbHVtbiBzaXplLCBsYXJnZSBzY3JlZW4gY29sdW1uIHNpemVdIHRvIGFwcGx5IGRpZmZlcmVudCB2YWx1ZXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNpemU/OiBDb2x1bW5TaXplcyB8IE1RPENvbHVtblNpemVzPjtcblxuICAvKiogc3BlY2lmeSB0aGUgdmlzdWFsIHBvc2l0aW9uaW5nIG9mIHRoZSBjb2x1bW4uIFtzbWFsbCBzY3JlZW4gY29sdW1uIG9yZGVyLCBtZWRpdW0gc2NyZWVuIGNvbHVtbiBvcmRlciwgbGFyZ2Ugc2NyZWVuIGNvbHVtbiBvcmRlcl0gdG8gYXBwbHkgZGlmZmVyZW50IG9yZGVyIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBvcmRlcj86IE9yZGVyIHwgTVE8T3JkZXI+O1xuXG4gIGFsaWduU2VsZj86IENvbHVtbkFsaWdubWVudCB8IE1RPENvbHVtbkFsaWdubWVudD47XG4gIC8qKiBkaXNwbGF5IGNvbHVtbiBhdCBnaXZlbiBicmVha3BvaW50ICovXG4gIHNob3c/OiBib29sZWFuIHwgTVE8Ym9vbGVhbj47XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBjb2x1bW5EZWZhdWx0UHJvcHM6IFBhcnRpYWw8Q29sdW1uUHJvcHM+ID0ge1xuICBzaXplOiBcImF1dG9cIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbiAgYWxpZ25TZWxmOiBcImF1dG9cIixcbiAgXCJkYXRhLWRzLWlkXCI6IFwiQ29sdW1uXCIsXG59O1xuXG5jb25zdCBjb2x1bW5XaWR0aE9iamVjdCA9IG5ldyBBcnJheSgxMikuZmlsbChcIlwiKS5yZWR1Y2UoXG4gIChhY2MsIF8sIGluZGV4KSA9PiAoe1xuICAgIC4uLmFjYyxcbiAgICBbaW5kZXggKyAxXTogYCR7KChpbmRleCArIDEpICogMTAwKSAvIDEyfSVgLFxuICB9KSxcbiAge31cbik7XG5cbmNvbnN0IG1ha2VOZWdhdGl2ZSA9IChvYmo6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4pOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0+XG4gIE9iamVjdC5lbnRyaWVzKG9iailcbiAgICAubWFwKChba2V5LCB2YWx1ZV0pID0+IFtrZXksIGAtJHt2YWx1ZX1gXSlcbiAgICAucmVkdWNlKChhY2MsIFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgYWNjW2tleV0gPSB2YWx1ZTtcbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSwge30gYXMgUmVjb3JkPHN0cmluZywgc3RyaW5nPik7XG5cbmV4cG9ydCBjb25zdCBDb2x1bW4gPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q29sdW1uUHJvcHM+PihcbiAgKHsgc2l6ZSwgb3JkZXIsIGFsaWduU2VsZiwgc2hvdyB9KSA9PiAoe1xuICAgIC4uLm1xKHtcbiAgICAgIHdpZHRoOiBbc2l6ZSwgeyAuLi5jb2x1bW5XaWR0aE9iamVjdCwgZmlsbDogXCIxcHhcIiB9XSxcbiAgICAgIGZsZXg6IFtzaXplLCB7IG5hcnJvdzogXCJub25lXCIsIGF1dG86IFwiMVwiLCBmaWxsOiB1bmRlZmluZWQgfV0sXG4gICAgICBvcmRlcjogW29yZGVyLCB7IGZpcnN0OiBcIi0xXCIsIGxhc3Q6IFwiMVwiLCB1bnNldDogXCIwXCIgfV0sXG4gICAgICBmbGV4U2hyaW5rOiBbc2l6ZSwgeyBmaWxsOiAxLCBhdXRvOiB1bmRlZmluZWQsIG5hcnJvdzogdW5kZWZpbmVkIH1dLFxuICAgICAgZmxleEdyb3c6IFtzaXplLCB7IGZpbGw6IDEsIGF1dG86IHVuZGVmaW5lZCwgbmFycm93OiB1bmRlZmluZWQgfV0sXG4gICAgICBhbGlnblNlbGY6IFtcbiAgICAgICAgYWxpZ25TZWxmLFxuICAgICAgICB7XG4gICAgICAgICAgYXV0bzogXCJhdXRvXCIsXG4gICAgICAgICAgc3RhcnQ6IFwic3RhcnRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgZW5kOiBcImVuZFwiLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIGRpc3BsYXk6IFtzaG93LCAodmFsdWU6IGJvb2xlYW4pID0+ICh2YWx1ZSA/IFwiYmxvY2tcIiA6IFwibm9uZVwiKV0sXG4gICAgfSksXG4gICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICBcIiY6ZW1wdHlcIjoge1xuICAgICAgd2lkdGg6IDAsXG4gICAgICBmbGV4OiBcIm5vbmVcIixcbiAgICB9LFxuICB9KVxuKTtcblxuQ29sdW1uLmRlZmF1bHRQcm9wcyA9IGNvbHVtbkRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGNvbnN0IENvbHVtbnMgPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q29sdW1uc1Byb3BzPj4oXG4gICh7IHRoZW1lLCBhbGlnbkl0ZW1zLCB2QWxpZ25JdGVtcywgZ2FwIH0pID0+ICh7XG4gICAgd2lkdGg6IFwiYXV0b1wiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGp1c3RpZnlJdGVtczogXCJzdHJldGNoXCIsXG4gICAganVzdGlmeUNvbnRlbnQ6IFwic3RyZXRjaFwiLFxuICAgIGFsaWduSXRlbXM6IFwic3RyZXRjaFwiLFxuICAgIGZsZXhXcmFwOiBcIndyYXBcIixcbiAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgIC4uLm1xKHtcbiAgICAgIGFsaWduSXRlbXM6IFtcbiAgICAgICAgdkFsaWduSXRlbXMsXG4gICAgICAgIHtcbiAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgIGJvdHRvbTogXCJmbGV4LWVuZFwiLFxuICAgICAgICAgIGNlbnRlcjogXCJjZW50ZXJcIixcbiAgICAgICAgICBzdHJldGNoOiBcInN0cmV0Y2hcIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgbGVmdDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgcmlnaHQ6IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3BhY2VCZXR3ZWVuOiBcInNwYWNlLWJldHdlZW5cIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBtYXJnaW5SaWdodDogW2dhcCwgbWFrZU5lZ2F0aXZlKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcpXSxcbiAgICAgIG1hcmdpbkJvdHRvbTogW2dhcCwgbWFrZU5lZ2F0aXZlKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcpXSxcbiAgICB9KSxcblxuICAgIFtgJiA+ICR7Q29sdW1ufWBdOiB7XG4gICAgICAuLi5tcSh7XG4gICAgICAgIG1hcmdpbkJvdHRvbTogW2dhcCwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICAgIHBhZGRpbmdSaWdodDogW2dhcCwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICB9KSxcbiAgICB9LFxuICB9KSxcbiAgKHsgYWx3YXlzRmlsbFNwYWNlIH0pID0+XG4gICAgYWx3YXlzRmlsbFNwYWNlICYmIHtcbiAgICAgIFtgJiA+ICR7Q29sdW1ufWBdOiB7XG4gICAgICAgIFwiJjpsYXN0LWNoaWxkXCI6IHtcbiAgICAgICAgICBmbGV4R3JvdzogMSxcbiAgICAgICAgICBmbGV4U2hyaW5rOiAxLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9XG4pO1xuXG5Db2x1bW5zLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRnNCIn0= */");Column.defaultProps={size:"auto","data-e2e-test-id":void 0,alignSelf:"auto","data-ds-id":"Column"};const Columns=/*#__PURE__*/(0,_styled.default)("div",{target:"e1xdzf2i1",label:"Columns"})(({theme,alignItems,vAlignItems,gap})=>({width:"auto",display:"flex",justifyItems:"stretch",justifyContent:"stretch",alignItems:"stretch",flexWrap:"wrap",flexDirection:"row",...(0,_mediaQueries.mq)({alignItems:[vAlignItems,{top:"flex-start",bottom:"flex-end",center:"center",stretch:"stretch"}],justifyContent:[alignItems,{left:"flex-start",right:"flex-end",center:"center",spaceBetween:"space-between"}],marginRight:[gap,makeNegative(theme.variables.size.spacing)],marginBottom:[gap,makeNegative(theme.variables.size.spacing)]}),[`& > ${Column}`]:{...(0,_mediaQueries.mq)({marginBottom:[gap,theme.variables.size.spacing],paddingRight:[gap,theme.variables.size.spacing]})}}),({alwaysFillSpace})=>alwaysFillSpace&&{[`& > ${Column}`]:{"&:last-child":{flexGrow:1,flexShrink:1}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sdW1uL0NvbHVtbnMudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2x1bW4vQ29sdW1ucy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IG1xIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB0eXBlIHtcbiAgTVEsXG4gIEhvcml6b250YWxBbGlnbm1lbnQsXG4gIFNwYWNlU2l6ZXMsXG4gIFZlcnRpY2FsQWxpZ25tZW50LFxuICBDb2x1bW5TaXplcyxcbiAgQ29sdW1uQWxpZ25tZW50LFxuICBPcmRlcixcbn0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIENvbHVtbnNQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVtdIHwgUmVhY3QuUmVhY3ROb2RlO1xuXG4gIC8qKiByZXByZXNlbnRzIHRoZSBzaXplIG9mIGJvdGggaG9yaXpvbnRhbCBhbmQgdmVydGljYWwgZ2FwIGJldHdlZW4gY2hpbGRyZW4sIGNhbiBiZSBhIHNpbmdsZSBzdHJpbmcgb3IgYW4gYXJyYXkgb2YgMyBzdHJpbmdzXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBnYXAgc2l6ZSwgbWVkaXVtIHNjcmVlbiBnYXAgc2l6ZSwgbGFyZ2Ugc2NyZWVuIGdhcCBzaXplXSB0byBhcHBseSBkaWZmZXJlbnQgZ2FwIHNpemVzIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBnYXA/OiBTcGFjZVNpemVzIHwgTVE8U3BhY2VTaXplcz47XG5cbiAgLyoqIHNldCB0byB0cnVlIGlmIHlvdSB3YW50IHRoZSBsYXN0IGVsZW1lbnQgdG8gZmlsbCB0aGUgc3BhY2VcbiAgICovXG4gIGFsd2F5c0ZpbGxTcGFjZT86IGJvb2xlYW47XG5cbiAgLyoqIHNwZWNpZnkgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIHRvIGFwcGx5IGRpZmZlcmVudCBhbGlnbkl0ZW1zIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogSG9yaXpvbnRhbEFsaWdubWVudCB8IE1RPEhvcml6b250YWxBbGlnbm1lbnQ+O1xuXG4gIC8qKiBzcGVjaWZ5IHZlcnRpY2FsIGFsaWdubWVudFxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gdkFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gdkFsaWduSXRlbXMsIGxhcmdlIHNjcmVlbiB2QWxpZ25JdGVtc10gdG8gYXBwbHkgZGlmZmVyZW50IHZBbGlnbkl0ZW1zIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICB2QWxpZ25JdGVtcz86IFZlcnRpY2FsQWxpZ25tZW50IHwgTVE8VmVydGljYWxBbGlnbm1lbnQ+O1xuXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuXG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQYXJ0aWFsPENvbHVtbnNQcm9wcz4gPSB7XG4gIGdhcDogXCJ6ZXJvXCIsXG4gIGFsd2F5c0ZpbGxTcGFjZTogZmFsc2UsXG4gIGFsaWduSXRlbXM6IFwibGVmdFwiLFxuICB2QWxpZ25JdGVtczogXCJ0b3BcIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbiAgXCJkYXRhLWRzLWlkXCI6IFwiQ29sdW1uc1wiLFxufTtcblxuZXhwb3J0IHR5cGUgQ29sdW1uUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0Tm9kZTtcblxuICAvKiogcmVwcmVzZW50cyB0aGUgc2l6ZSBvZiB0aGUgY29sdW1uLCBjYW4gYmUgYSBzaW5nbGUgbnVtYmVyIG9yIGFuIGFycmF5IG9mIDMgbnVtYmVycyB3aXRoIGEgdmFsdWUgcmFuZ2luZyBmcm9tIDEgdG8gMTJcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGNvbHVtbiBzaXplLCBtZWRpdW0gc2NyZWVuIGNvbHVtbiBzaXplLCBsYXJnZSBzY3JlZW4gY29sdW1uIHNpemVdIHRvIGFwcGx5IGRpZmZlcmVudCB2YWx1ZXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNpemU/OiBDb2x1bW5TaXplcyB8IE1RPENvbHVtblNpemVzPjtcblxuICAvKiogc3BlY2lmeSB0aGUgdmlzdWFsIHBvc2l0aW9uaW5nIG9mIHRoZSBjb2x1bW4uIFtzbWFsbCBzY3JlZW4gY29sdW1uIG9yZGVyLCBtZWRpdW0gc2NyZWVuIGNvbHVtbiBvcmRlciwgbGFyZ2Ugc2NyZWVuIGNvbHVtbiBvcmRlcl0gdG8gYXBwbHkgZGlmZmVyZW50IG9yZGVyIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBvcmRlcj86IE9yZGVyIHwgTVE8T3JkZXI+O1xuXG4gIGFsaWduU2VsZj86IENvbHVtbkFsaWdubWVudCB8IE1RPENvbHVtbkFsaWdubWVudD47XG4gIC8qKiBkaXNwbGF5IGNvbHVtbiBhdCBnaXZlbiBicmVha3BvaW50ICovXG4gIHNob3c/OiBib29sZWFuIHwgTVE8Ym9vbGVhbj47XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBjb2x1bW5EZWZhdWx0UHJvcHM6IFBhcnRpYWw8Q29sdW1uUHJvcHM+ID0ge1xuICBzaXplOiBcImF1dG9cIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbiAgYWxpZ25TZWxmOiBcImF1dG9cIixcbiAgXCJkYXRhLWRzLWlkXCI6IFwiQ29sdW1uXCIsXG59O1xuXG5jb25zdCBjb2x1bW5XaWR0aE9iamVjdCA9IG5ldyBBcnJheSgxMikuZmlsbChcIlwiKS5yZWR1Y2UoXG4gIChhY2MsIF8sIGluZGV4KSA9PiAoe1xuICAgIC4uLmFjYyxcbiAgICBbaW5kZXggKyAxXTogYCR7KChpbmRleCArIDEpICogMTAwKSAvIDEyfSVgLFxuICB9KSxcbiAge31cbik7XG5cbmNvbnN0IG1ha2VOZWdhdGl2ZSA9IChvYmo6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4pOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0+XG4gIE9iamVjdC5lbnRyaWVzKG9iailcbiAgICAubWFwKChba2V5LCB2YWx1ZV0pID0+IFtrZXksIGAtJHt2YWx1ZX1gXSlcbiAgICAucmVkdWNlKChhY2MsIFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgYWNjW2tleV0gPSB2YWx1ZTtcbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSwge30gYXMgUmVjb3JkPHN0cmluZywgc3RyaW5nPik7XG5cbmV4cG9ydCBjb25zdCBDb2x1bW4gPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q29sdW1uUHJvcHM+PihcbiAgKHsgc2l6ZSwgb3JkZXIsIGFsaWduU2VsZiwgc2hvdyB9KSA9PiAoe1xuICAgIC4uLm1xKHtcbiAgICAgIHdpZHRoOiBbc2l6ZSwgeyAuLi5jb2x1bW5XaWR0aE9iamVjdCwgZmlsbDogXCIxcHhcIiB9XSxcbiAgICAgIGZsZXg6IFtzaXplLCB7IG5hcnJvdzogXCJub25lXCIsIGF1dG86IFwiMVwiLCBmaWxsOiB1bmRlZmluZWQgfV0sXG4gICAgICBvcmRlcjogW29yZGVyLCB7IGZpcnN0OiBcIi0xXCIsIGxhc3Q6IFwiMVwiLCB1bnNldDogXCIwXCIgfV0sXG4gICAgICBmbGV4U2hyaW5rOiBbc2l6ZSwgeyBmaWxsOiAxLCBhdXRvOiB1bmRlZmluZWQsIG5hcnJvdzogdW5kZWZpbmVkIH1dLFxuICAgICAgZmxleEdyb3c6IFtzaXplLCB7IGZpbGw6IDEsIGF1dG86IHVuZGVmaW5lZCwgbmFycm93OiB1bmRlZmluZWQgfV0sXG4gICAgICBhbGlnblNlbGY6IFtcbiAgICAgICAgYWxpZ25TZWxmLFxuICAgICAgICB7XG4gICAgICAgICAgYXV0bzogXCJhdXRvXCIsXG4gICAgICAgICAgc3RhcnQ6IFwic3RhcnRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgZW5kOiBcImVuZFwiLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIGRpc3BsYXk6IFtzaG93LCAodmFsdWU6IGJvb2xlYW4pID0+ICh2YWx1ZSA/IFwiYmxvY2tcIiA6IFwibm9uZVwiKV0sXG4gICAgfSksXG4gICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICBcIiY6ZW1wdHlcIjoge1xuICAgICAgd2lkdGg6IDAsXG4gICAgICBmbGV4OiBcIm5vbmVcIixcbiAgICB9LFxuICB9KVxuKTtcblxuQ29sdW1uLmRlZmF1bHRQcm9wcyA9IGNvbHVtbkRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGNvbnN0IENvbHVtbnMgPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q29sdW1uc1Byb3BzPj4oXG4gICh7IHRoZW1lLCBhbGlnbkl0ZW1zLCB2QWxpZ25JdGVtcywgZ2FwIH0pID0+ICh7XG4gICAgd2lkdGg6IFwiYXV0b1wiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGp1c3RpZnlJdGVtczogXCJzdHJldGNoXCIsXG4gICAganVzdGlmeUNvbnRlbnQ6IFwic3RyZXRjaFwiLFxuICAgIGFsaWduSXRlbXM6IFwic3RyZXRjaFwiLFxuICAgIGZsZXhXcmFwOiBcIndyYXBcIixcbiAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgIC4uLm1xKHtcbiAgICAgIGFsaWduSXRlbXM6IFtcbiAgICAgICAgdkFsaWduSXRlbXMsXG4gICAgICAgIHtcbiAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgIGJvdHRvbTogXCJmbGV4LWVuZFwiLFxuICAgICAgICAgIGNlbnRlcjogXCJjZW50ZXJcIixcbiAgICAgICAgICBzdHJldGNoOiBcInN0cmV0Y2hcIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgbGVmdDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgcmlnaHQ6IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3BhY2VCZXR3ZWVuOiBcInNwYWNlLWJldHdlZW5cIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBtYXJnaW5SaWdodDogW2dhcCwgbWFrZU5lZ2F0aXZlKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcpXSxcbiAgICAgIG1hcmdpbkJvdHRvbTogW2dhcCwgbWFrZU5lZ2F0aXZlKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcpXSxcbiAgICB9KSxcblxuICAgIFtgJiA+ICR7Q29sdW1ufWBdOiB7XG4gICAgICAuLi5tcSh7XG4gICAgICAgIG1hcmdpbkJvdHRvbTogW2dhcCwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICAgIHBhZGRpbmdSaWdodDogW2dhcCwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICB9KSxcbiAgICB9LFxuICB9KSxcbiAgKHsgYWx3YXlzRmlsbFNwYWNlIH0pID0+XG4gICAgYWx3YXlzRmlsbFNwYWNlICYmIHtcbiAgICAgIFtgJiA+ICR7Q29sdW1ufWBdOiB7XG4gICAgICAgIFwiJjpsYXN0LWNoaWxkXCI6IHtcbiAgICAgICAgICBmbGV4R3JvdzogMSxcbiAgICAgICAgICBmbGV4U2hyaW5rOiAxLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9XG4pO1xuXG5Db2x1bW5zLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0SHVCIn0= */");Columns.defaultProps={gap:"zero",alwaysFillSpace:!1,alignItems:"left",vAlignItems:"top","data-e2e-test-id":void 0,"data-ds-id":"Columns"};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{PasswordInput:function(){return PasswordInput},PasswordInputRaw:function(){return PasswordInputRaw}});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"),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=/*#__PURE__*/(0,_styled.default)("div",{target:"ecgpf3y0",label:"StyledContainer"})(()=>({width:"100%",display:"flex",alignItems:"center",flexDirection:"row",position:"relative",zIndex:1}),"/*# 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 } 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\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\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      zIndex: 1,\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  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: 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.default,\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      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\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          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\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      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAiEwB"} */"),StyledIconBtn=/*#__PURE__*/(0,_styled.default)("button",{target:"ecgpf3y1",label:"StyledIconBtn"})(({theme,hasError})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},position:"absolute",top:0,right:0,zIndex:2,border:"1px solid",borderColor:handleIconBorderColor(theme,hasError),borderLeftColor:handleIconLeftBorderColor(theme,hasError),padding: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.default},"&: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 } 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\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\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      zIndex: 1,\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  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: 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.default,\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      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\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          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\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      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA6EsB"} */"),StyledPasswordInput=/*#__PURE__*/(0,_styled.default)("input",{target:"ecgpf3y2",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 } 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\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\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      zIndex: 1,\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  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: 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.default,\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      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\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          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\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      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAuH4B"} */"),PasswordInputRaw=/*#__PURE__*/(0,_react.forwardRef)(({name,value,placeholder,hasError=!1,disabled,onChange,onClick,onBlur,onFocus,onIconClick,areaLabel,tabIndex,autoComplete,iconAriaLabel,readOnly},ref)=>{let[inputType,setInputType]=(0,_react.useState)("password"),currentType="password"===inputType?"text":"password";return /*#__PURE__*/_react.default.createElement(StyledContainer,null,/*#__PURE__*/_react.default.createElement(StyledPasswordInput,{type:inputType,value:value,placeholder:!readOnly&&placeholder,name:name,disabled:disabled,onClick:onClick,onChange:onChange,onBlur:onBlur,onFocus:onFocus,"aria-label":areaLabel,ref:ref,tabIndex:tabIndex,autoComplete:autoComplete,hasError:hasError,readOnly:readOnly}),/*#__PURE__*/_react.default.createElement(StyledIconBtn,{onClick:e=>{disabled&&e.preventDefault(),onIconClick&&onIconClick(e),setInputType(currentType)},hasError:hasError,disabled:readOnly||disabled,"aria-label":iconAriaLabel,type:"button"},/*#__PURE__*/_react.default.createElement(_Icon.Icon,{name:"password"===inputType?"eye-off":"eye",size:"s",color:readOnly?"quaternary":"tertiary"})))}),PasswordInput=/*#__PURE__*/_react.default.forwardRef(({name,value,placeholder="••••••••",hasError=!1,onChange,onClick,onBlur,onFocus,onIconClick,tabIndex,areaLabel,autoComplete="on",iconAriaLabel,disabled,readOnly,...rest},ref)=>/*#__PURE__*/_react.default.createElement(_FormField.FormField,{"data-ds-id":"PasswordInput",disabled:disabled,...rest},/*#__PURE__*/_react.default.createElement(PasswordInputRaw,{ref:ref,name:name,value:value,placeholder:placeholder,hasError:hasError,disabled:disabled,onChange:onChange,onBlur:onBlur,onFocus:onFocus,onClick:onClick,onIconClick:onIconClick,tabIndex:tabIndex,areaLabel:areaLabel,autoComplete:autoComplete,iconAriaLabel:iconAriaLabel,readOnly:readOnly})));
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{PasswordInput:function(){return PasswordInput},PasswordInputRaw:function(){return PasswordInputRaw}});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"),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=/*#__PURE__*/(0,_styled.default)("div",{target:"e12olo7k0",label:"StyledContainer"})(()=>({width:"100%",display:"flex",alignItems:"center",flexDirection:"row",position:"relative",zIndex:1}),"/*# 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 } 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\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\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      zIndex: 1,\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  zIndex: 2,\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.default,\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      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\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          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\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      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAiEwB"} */"),StyledIconBtn=/*#__PURE__*/(0,_styled.default)("button",{target:"e12olo7k1",label:"StyledIconBtn"})(({theme,hasError})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},position:"absolute",top:0,right:0,zIndex:2,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.default},"&: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 } 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\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\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      zIndex: 1,\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  zIndex: 2,\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.default,\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      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\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          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\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      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA6EsB"} */"),StyledPasswordInput=/*#__PURE__*/(0,_styled.default)("input",{target:"e12olo7k2",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 } 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\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\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      zIndex: 1,\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  zIndex: 2,\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.default,\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      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\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          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\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      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAuH4B"} */"),PasswordInputRaw=/*#__PURE__*/(0,_react.forwardRef)(({name,value,placeholder,hasError=!1,disabled,onChange,onClick,onBlur,onFocus,onIconClick,areaLabel,tabIndex,autoComplete,iconAriaLabel,readOnly},ref)=>{let[inputType,setInputType]=(0,_react.useState)("password"),currentType="password"===inputType?"text":"password";return /*#__PURE__*/_react.default.createElement(StyledContainer,null,/*#__PURE__*/_react.default.createElement(StyledPasswordInput,{type:inputType,value:value,placeholder:!readOnly&&placeholder,name:name,disabled:disabled,onClick:onClick,onChange:onChange,onBlur:onBlur,onFocus:onFocus,"aria-label":areaLabel,ref:ref,tabIndex:tabIndex,autoComplete:autoComplete,hasError:hasError,readOnly:readOnly}),/*#__PURE__*/_react.default.createElement(StyledIconBtn,{onClick:e=>{disabled&&e.preventDefault(),onIconClick&&onIconClick(e),setInputType(currentType)},hasError:hasError,disabled:readOnly||disabled,"aria-label":iconAriaLabel,type:"button"},/*#__PURE__*/_react.default.createElement(_Icon.Icon,{name:"password"===inputType?"eye-off":"eye",size:"s",color:readOnly?"quaternary":"tertiary"})))}),PasswordInput=/*#__PURE__*/_react.default.forwardRef(({name,value,placeholder="••••••••",hasError=!1,onChange,onClick,onBlur,onFocus,onIconClick,tabIndex,areaLabel,autoComplete="on",iconAriaLabel,disabled,readOnly,...rest},ref)=>/*#__PURE__*/_react.default.createElement(_FormField.FormField,{"data-ds-id":"PasswordInput",disabled:disabled,...rest},/*#__PURE__*/_react.default.createElement(PasswordInputRaw,{ref:ref,name:name,value:value,placeholder:placeholder,hasError:hasError,disabled:disabled,onChange:onChange,onBlur:onBlur,onFocus:onFocus,onClick:onClick,onIconClick:onIconClick,tabIndex:tabIndex,areaLabel:areaLabel,autoComplete:autoComplete,iconAriaLabel:iconAriaLabel,readOnly:readOnly})));
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import type { HTMLAttributes, ReactElement } from "react";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import type { Property } from "csstype";
|
|
4
|
+
import type { MQ, SpaceSizes } from "../../types";
|
|
5
|
+
import type { GridItemProps } from "./GridItem";
|
|
6
|
+
import { GridItem } from "./GridItem";
|
|
7
|
+
export type GridProps = {
|
|
8
|
+
/** Define spacing between columns */
|
|
9
|
+
columnGap?: SpaceSizes | MQ<SpaceSizes>;
|
|
10
|
+
/** Define spacing between rows */
|
|
11
|
+
rowGap?: SpaceSizes | MQ<SpaceSizes>;
|
|
12
|
+
/** Define track sizing for explicit grid row tracks, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-rows */
|
|
13
|
+
templateRows?: Property.GridTemplateRows | MQ<Property.GridTemplateRows>;
|
|
14
|
+
/** Define track sizing for explicit grid column tracks, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-columns
|
|
15
|
+
* Overrides 12 column grid
|
|
16
|
+
*/
|
|
17
|
+
templateColumns?: Property.GridTemplateColumns | MQ<Property.GridTemplateColumns>;
|
|
18
|
+
/** Define layout with areas, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-areas */
|
|
19
|
+
templateAreas?: Property.GridTemplateAreas | MQ<Property.GridTemplateAreas>;
|
|
20
|
+
/** Define row track size for implicit grid rows, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-auto-rows */
|
|
21
|
+
autoRows?: Property.GridAutoRows | MQ<Property.GridAutoRows>;
|
|
22
|
+
/** Aligns grid items along the block (column) axis, see https://developer.mozilla.org/en-US/docs/Web/CSS/align-items */
|
|
23
|
+
alignItems?: Property.AlignItems | MQ<Property.AlignItems>;
|
|
24
|
+
/** Aligns grid items along the inline (row) axis, see https://developer.mozilla.org/en-US/docs/Web/CSS/justify-items */
|
|
25
|
+
justifyItems?: Property.JustifyItems | MQ<Property.JustifyItems>;
|
|
26
|
+
/** Displays an inline grid */
|
|
27
|
+
inline?: boolean;
|
|
28
|
+
/** If set to true, it will share parent column tracks */
|
|
29
|
+
isSubgrid?: boolean;
|
|
30
|
+
"data-e2e-test-id"?: string;
|
|
31
|
+
children: ReactElement<GridItemProps>[];
|
|
32
|
+
} & HTMLAttributes<HTMLDivElement>;
|
|
33
|
+
export declare function Grid({ columnGap, rowGap, "data-e2e-test-id": dataE2eTestId, children, ...rest }: GridProps): React.ReactElement;
|
|
34
|
+
export declare namespace Grid {
|
|
35
|
+
var Item: typeof GridItem;
|
|
36
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Grid",{enumerable:!0,get:function(){return Grid}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),_GridItem=require("./GridItem"),StyledContainer=/*#__PURE__*/(0,_styled.default)("div",{target:"eksqp4f0",label:"StyledContainer"})(({theme,templateColumns,templateRows,autoRows,templateAreas,inline,columnGap,alignItems,justifyItems,isSubgrid})=>{function getTrackSize(size){return`calc((100% - 11 * ${theme.variables.size.spacing[size]}) / 12)`}return{width:"100%",display:inline?"inline-grid":"grid",gridAutoFlow:"row",...(0,_mediaQueries.mqValue)({gridTemplateColumns:templateColumns||(isSubgrid?"subgrid":Array.isArray(columnGap)?columnGap.map(value=>`repeat(12, ${getTrackSize(value)})`):`repeat(12, ${getTrackSize(columnGap)})`),gridTemplateRows:templateRows,gridAutoRows:autoRows,gridTemplateAreas:templateAreas,alignItems,justifyItems})}},({theme,columnGap,rowGap})=>(0,_mediaQueries.mq)({gridColumnGap:[columnGap,theme.variables.size.spacing],gridRowGap:[rowGap,theme.variables.size.spacing]}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvR3JpZC9HcmlkLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvR3JpZC9HcmlkLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEhUTUxBdHRyaWJ1dGVzLCBSZWFjdEVsZW1lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBQcm9wZXJ0eSB9IGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQgeyBtcVZhbHVlLCBtcSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgdHlwZSB7IE1RLCBTcGFjZVNpemVzIH0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5pbXBvcnQgdHlwZSB7IEdyaWRJdGVtUHJvcHMgfSBmcm9tIFwiLi9HcmlkSXRlbVwiO1xuaW1wb3J0IHsgR3JpZEl0ZW0gfSBmcm9tIFwiLi9HcmlkSXRlbVwiO1xuXG5leHBvcnQgdHlwZSBHcmlkUHJvcHMgPSB7XG4gIC8qKiBEZWZpbmUgc3BhY2luZyBiZXR3ZWVuIGNvbHVtbnMgKi9cbiAgY29sdW1uR2FwPzogU3BhY2VTaXplcyB8IE1RPFNwYWNlU2l6ZXM+O1xuICAvKiogRGVmaW5lIHNwYWNpbmcgYmV0d2VlbiByb3dzICovXG4gIHJvd0dhcD86IFNwYWNlU2l6ZXMgfCBNUTxTcGFjZVNpemVzPjtcbiAgLyoqIERlZmluZSB0cmFjayBzaXppbmcgZm9yIGV4cGxpY2l0IGdyaWQgcm93IHRyYWNrcywgc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9ncmlkLXRlbXBsYXRlLXJvd3MgKi9cbiAgdGVtcGxhdGVSb3dzPzogUHJvcGVydHkuR3JpZFRlbXBsYXRlUm93cyB8IE1RPFByb3BlcnR5LkdyaWRUZW1wbGF0ZVJvd3M+O1xuICAvKiogRGVmaW5lIHRyYWNrIHNpemluZyBmb3IgZXhwbGljaXQgZ3JpZCBjb2x1bW4gdHJhY2tzLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtdGVtcGxhdGUtY29sdW1uc1xuICAgKiBPdmVycmlkZXMgMTIgY29sdW1uIGdyaWRcbiAgICovXG4gIHRlbXBsYXRlQ29sdW1ucz86XG4gICAgfCBQcm9wZXJ0eS5HcmlkVGVtcGxhdGVDb2x1bW5zXG4gICAgfCBNUTxQcm9wZXJ0eS5HcmlkVGVtcGxhdGVDb2x1bW5zPjtcbiAgLyoqIERlZmluZSBsYXlvdXQgd2l0aCBhcmVhcywgc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9ncmlkLXRlbXBsYXRlLWFyZWFzICovXG4gIHRlbXBsYXRlQXJlYXM/OiBQcm9wZXJ0eS5HcmlkVGVtcGxhdGVBcmVhcyB8IE1RPFByb3BlcnR5LkdyaWRUZW1wbGF0ZUFyZWFzPjtcbiAgLyoqIERlZmluZSByb3cgdHJhY2sgc2l6ZSBmb3IgaW1wbGljaXQgZ3JpZCByb3dzLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtYXV0by1yb3dzICovXG4gIGF1dG9Sb3dzPzogUHJvcGVydHkuR3JpZEF1dG9Sb3dzIHwgTVE8UHJvcGVydHkuR3JpZEF1dG9Sb3dzPjtcbiAgLyoqIEFsaWducyBncmlkIGl0ZW1zIGFsb25nIHRoZSBibG9jayAoY29sdW1uKSBheGlzLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2FsaWduLWl0ZW1zICovXG4gIGFsaWduSXRlbXM/OiBQcm9wZXJ0eS5BbGlnbkl0ZW1zIHwgTVE8UHJvcGVydHkuQWxpZ25JdGVtcz47XG4gIC8qKiBBbGlnbnMgZ3JpZCBpdGVtcyBhbG9uZyB0aGUgaW5saW5lIChyb3cpIGF4aXMsIHNlZSBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvanVzdGlmeS1pdGVtcyAqL1xuICBqdXN0aWZ5SXRlbXM/OiBQcm9wZXJ0eS5KdXN0aWZ5SXRlbXMgfCBNUTxQcm9wZXJ0eS5KdXN0aWZ5SXRlbXM+O1xuICAvKiogRGlzcGxheXMgYW4gaW5saW5lIGdyaWQgKi9cbiAgaW5saW5lPzogYm9vbGVhbjtcbiAgLyoqIElmIHNldCB0byB0cnVlLCBpdCB3aWxsIHNoYXJlIHBhcmVudCBjb2x1bW4gdHJhY2tzICovXG4gIGlzU3ViZ3JpZD86IGJvb2xlYW47XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICBjaGlsZHJlbjogUmVhY3RFbGVtZW50PEdyaWRJdGVtUHJvcHM+W107XG59ICYgSFRNTEF0dHJpYnV0ZXM8SFRNTERpdkVsZW1lbnQ+O1xuXG5jb25zdCBUT1RBTF9DT0xVTU5TID0gMTI7XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8R3JpZFByb3BzPihcbiAgKHtcbiAgICB0aGVtZSxcbiAgICB0ZW1wbGF0ZUNvbHVtbnMsXG4gICAgdGVtcGxhdGVSb3dzLFxuICAgIGF1dG9Sb3dzLFxuICAgIHRlbXBsYXRlQXJlYXMsXG4gICAgaW5saW5lLFxuICAgIGNvbHVtbkdhcCxcbiAgICBhbGlnbkl0ZW1zLFxuICAgIGp1c3RpZnlJdGVtcyxcbiAgICBpc1N1YmdyaWQsXG4gIH0pID0+IHtcbiAgICBmdW5jdGlvbiBnZXRUcmFja1NpemUoc2l6ZTogU3BhY2VTaXplcykge1xuICAgICAgcmV0dXJuIGBjYWxjKCgxMDAlIC0gJHtUT1RBTF9DT0xVTU5TIC0gMX0gKiAke1xuICAgICAgICB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nW3NpemVdXG4gICAgICB9KSAvICR7VE9UQUxfQ09MVU1OU30pYDtcbiAgICB9XG5cbiAgICBmdW5jdGlvbiBnZXRUZW1wbGF0ZUNvbHVtbnNWYWx1ZXMoKSB7XG4gICAgICBpZiAodGVtcGxhdGVDb2x1bW5zKSB7XG4gICAgICAgIHJldHVybiB0ZW1wbGF0ZUNvbHVtbnM7XG4gICAgICB9XG5cbiAgICAgIGlmIChpc1N1YmdyaWQpIHtcbiAgICAgICAgcmV0dXJuIFwic3ViZ3JpZFwiO1xuICAgICAgfVxuXG4gICAgICBpZiAoQXJyYXkuaXNBcnJheShjb2x1bW5HYXApKSB7XG4gICAgICAgIHJldHVybiBjb2x1bW5HYXAubWFwKFxuICAgICAgICAgICh2YWx1ZSkgPT4gYHJlcGVhdCgke1RPVEFMX0NPTFVNTlN9LCAke2dldFRyYWNrU2l6ZSh2YWx1ZSl9KWBcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGByZXBlYXQoJHtUT1RBTF9DT0xVTU5TfSwgJHtnZXRUcmFja1NpemUoXG4gICAgICAgIGNvbHVtbkdhcCBhcyBTcGFjZVNpemVzXG4gICAgICApfSlgO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgICBkaXNwbGF5OiBpbmxpbmUgPyBcImlubGluZS1ncmlkXCIgOiBcImdyaWRcIixcbiAgICAgIGdyaWRBdXRvRmxvdzogXCJyb3dcIixcblxuICAgICAgLi4ubXFWYWx1ZSh7XG4gICAgICAgIGdyaWRUZW1wbGF0ZUNvbHVtbnM6IGdldFRlbXBsYXRlQ29sdW1uc1ZhbHVlcygpLFxuICAgICAgICBncmlkVGVtcGxhdGVSb3dzOiB0ZW1wbGF0ZVJvd3MsXG4gICAgICAgIGdyaWRBdXRvUm93czogYXV0b1Jvd3MsXG4gICAgICAgIGdyaWRUZW1wbGF0ZUFyZWFzOiB0ZW1wbGF0ZUFyZWFzLFxuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICBqdXN0aWZ5SXRlbXMsXG4gICAgICB9KSxcbiAgICB9O1xuICB9LFxuICAoeyB0aGVtZSwgY29sdW1uR2FwLCByb3dHYXAgfSkgPT5cbiAgICBtcSh7XG4gICAgICBncmlkQ29sdW1uR2FwOiBbY29sdW1uR2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIGdyaWRSb3dHYXA6IFtyb3dHYXAsIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmddLFxuICAgIH0pXG4pO1xuXG4vKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG5cbmV4cG9ydCBmdW5jdGlvbiBHcmlkKHtcbiAgY29sdW1uR2FwID0gXCJtXCIsXG4gIHJvd0dhcCA9IFwibVwiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgY2hpbGRyZW4sXG4gIC4uLnJlc3Rcbn06IEdyaWRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJHcmlkXCJcbiAgICAgIGNvbHVtbkdhcD17Y29sdW1uR2FwfVxuICAgICAgcm93R2FwPXtyb3dHYXB9XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRDb250YWluZXI+XG4gICk7XG59XG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cblxuR3JpZC5JdGVtID0gR3JpZEl0ZW07XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0N3QiJ9 */");function Grid({columnGap="m",rowGap="m","data-e2e-test-id":dataE2eTestId,children,...rest}){return /*#__PURE__*/_react.default.createElement(StyledContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Grid",columnGap:columnGap,rowGap:rowGap,...rest},children)}Grid.Item=_GridItem.GridItem;
|