@amboss/design-system 3.36.3 → 3.37.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/build/cjs/components/BinaryFeedback/-types.d.ts +4 -5
  2. package/build/cjs/components/BinaryFeedback/BinaryFeedback.d.ts +1 -1
  3. package/build/cjs/components/BinaryFeedback/BinaryFeedback.js +1 -1
  4. package/build/cjs/components/BinaryFeedback/BinaryFeedbackOption.d.ts +1 -1
  5. package/build/cjs/components/BinaryFeedback/BinaryFeedbackOption.js +1 -1
  6. package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.d.ts +3 -1
  7. package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  8. package/build/cjs/components/BulkActionsToolbar/useBulkActionsToolbar.d.ts +7 -0
  9. package/build/cjs/components/BulkActionsToolbar/useBulkActionsToolbar.js +1 -0
  10. package/build/cjs/components/Content/ReferenceButton/ReferenceButton.js +1 -1
  11. package/build/cjs/components/Link/Link.js +1 -1
  12. package/build/cjs/components/ProgressBar/ProgressBar.d.ts +3 -3
  13. package/build/cjs/components/ProgressBar/ProgressBar.js +1 -1
  14. package/build/cjs/components/SegmentedProgressBar/-types.d.ts +2 -1
  15. package/build/cjs/components/SegmentedProgressBar/SegmentedProgressBar.d.ts +1 -1
  16. package/build/cjs/components/SegmentedProgressBar/SegmentedProgressBar.js +1 -1
  17. package/build/esm/components/BinaryFeedback/-types.d.ts +4 -5
  18. package/build/esm/components/BinaryFeedback/BinaryFeedback.d.ts +1 -1
  19. package/build/esm/components/BinaryFeedback/BinaryFeedback.js +1 -1
  20. package/build/esm/components/BinaryFeedback/BinaryFeedbackOption.d.ts +1 -1
  21. package/build/esm/components/BinaryFeedback/BinaryFeedbackOption.js +1 -1
  22. package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.d.ts +3 -1
  23. package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  24. package/build/esm/components/BulkActionsToolbar/useBulkActionsToolbar.d.ts +7 -0
  25. package/build/esm/components/BulkActionsToolbar/useBulkActionsToolbar.js +1 -0
  26. package/build/esm/components/Content/ReferenceButton/ReferenceButton.js +1 -1
  27. package/build/esm/components/Link/Link.js +1 -1
  28. package/build/esm/components/ProgressBar/ProgressBar.d.ts +3 -3
  29. package/build/esm/components/ProgressBar/ProgressBar.js +1 -1
  30. package/build/esm/components/SegmentedProgressBar/-types.d.ts +2 -1
  31. package/build/esm/components/SegmentedProgressBar/SegmentedProgressBar.d.ts +1 -1
  32. package/build/esm/components/SegmentedProgressBar/SegmentedProgressBar.js +1 -1
  33. package/package.json +1 -1
@@ -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__*/require("@swc/helpers/_/_interop_require_wildcard")._(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.s.value,toolbarContainerName="bulkActionsToolbar",containerSmall=`@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`,containerLarge=`@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`,StyledBulkActionsToolbarContainer=(0,_styled.default)("div",{target:"e13500ji0",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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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=(0,_styled.default)("div",{target:"e13500ji1",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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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=(0,_styled.default)("div",{target:"e13500ji2",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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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=(0,_styled.default)("div",{target:"e13500ji3",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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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=(0,_styled.default)("div",{target:"e13500ji4",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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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=(0,_styled.default)("div",{target:"e13500ji5",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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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=(0,_styled.default)(_Inline.Inline,{target:"e13500ji6",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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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=(0,_styled.default)("label",{target:"e13500ji7",label:"CheckboxStyled"})(({theme})=>({display:"block",paddingLeft: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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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=(0,_styled.default)("div",{target:"e13500ji8",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, { useId } 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 { CheckboxRaw, 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.s.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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n      {...ariaAttributes}\n    >\n      <InlineContainer>\n        <InlineItem order={[1, -1]}>\n          {checkboxProps ? (\n            <CustomInline vAlignItems=\"center\">\n              <CheckboxStyled>\n                <CheckboxRaw {...checkboxProps} size=\"s\" aria-labelledby={id} />\n              </CheckboxStyled>\n              <TotalItems id={id}>{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            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} />\n              </StyledSearch>\n            )}\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,id})=>_react.default.createElement(TotalItemsStyled,{role:"status"},_react.default.createElement(_Text.Text,{size:"s",color:"secondary",weight:"bold",id:id},children)),BulkActionsToolbar=_react.default.memo(function({actions,checkboxProps,totalItems,searchInputProps,renderRightContent,rightContentNoWrapOnMobile,hideDivider,"data-e2e-test-id":dataE2eTestId,...ariaAttributes}){let id=(0,_react.useId)();return _react.default.createElement(StyledBulkActionsToolbarContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Toolbar",...ariaAttributes},_react.default.createElement(InlineContainer,null,_react.default.createElement(InlineItem,{order:[1,-1]},checkboxProps?_react.default.createElement(CustomInline,{vAlignItems:"center"},_react.default.createElement(CheckboxStyled,null,_react.default.createElement(_Checkbox.CheckboxRaw,{...checkboxProps,size:"s","aria-labelledby":id})),_react.default.createElement(TotalItems,{id:id},totalItems)):_react.default.createElement(TotalItems,null,totalItems),_react.default.createElement(_Inline.Inline,{noWrap:!0},actions?.map(({variant="secondary",label,...buttonProps})=>_react.default.createElement(_Button.Button,{...buttonProps,key:`action-${label}`,size:"s",variant:variant},label)))),_react.default.createElement(InlineItem,{order:[-1,1]},_react.default.createElement(StyledRightSlot,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent&&_react.default.createElement(StyledRightContent,null,renderRightContent()),searchInputProps&&_react.default.createElement(StyledSearch,null,_react.default.createElement(_SearchInput.SearchInput,searchInputProps))))),!hideDivider&&_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__*/require("@swc/helpers/_/_interop_require_wildcard")._(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"),_useBulkActionsToolbar=require("./useBulkActionsToolbar"),containerSmallSize=_breakpointsjson.default.s.value,toolbarContainerName="bulkActionsToolbar",containerSmall=`@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`,containerLarge=`@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`,StyledBulkActionsToolbarContainer=(0,_styled.default)("div",{target:"e14sv2rz0",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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAuC0C"} */"),InlineContainer=(0,_styled.default)("div",{target:"e14sv2rz1",label:"InlineContainer"})(({theme})=>({display:"flex",padding:theme.variables.size.spacing.xs,gap:theme.variables.size.spacing.xs,[containerSmall]:{display:"flex",flexDirection:"column"},[containerLarge]:{paddingLeft: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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AA4CwB"} */"),ToolbarInner=(0,_styled.default)("div",{target:"e14sv2rz2",label:"ToolbarInner"})(({theme})=>({display:"flex",alignItems:"center",gap:theme.variables.size.spacing.xs,flexGrow:1,[containerSmall]:{display:"contents"}}),"/*# 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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAyDqB"} */"),ToolbarControls=(0,_styled.default)("div",{target:"e14sv2rz3",label:"ToolbarControls"})(({theme})=>({display:"flex",alignItems:"center",gap:theme.variables.size.spacing.xs,[containerSmall]:{order:3,justifyContent:"space-between"}}),"/*# 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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAmEwB"} */"),StyledSearch=(0,_styled.default)("div",{target:"e14sv2rz4",label:"StyledSearch"})({[containerSmall]:{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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AA6EqB"} */"),StyledRightSlot=(0,_styled.default)("div",{target:"e14sv2rz5",label:"StyledRightSlot"})(({theme,rightContentNoWrapOnMobile})=>({display:"flex",justifyContent:"flex-end",alignItems:"center",flex:1,gap:theme.variables.size.spacing.xs,[containerSmall]:{order:2,flex:"none",...!rightContentNoWrapOnMobile&&{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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAmFwB"} */"),StyledRightContent=(0,_styled.default)("div",{target:"e14sv2rz6",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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAoG2B"} */"),CustomInline=(0,_styled.default)(_Inline.Inline,{target:"e14sv2rz7",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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AA8GqB"} */"),CheckboxStyled=(0,_styled.default)("label",{target:"e14sv2rz8",label:"CheckboxStyled"})(({theme})=>({display:"block",paddingLeft: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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AAuHuB"} */"),TotalItemsStyled=(0,_styled.default)("div",{target:"e14sv2rz9",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, { useId } 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 { CheckboxRaw, type CheckboxProps } from \"../Form/Checkbox/Checkbox\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport {\n  SearchInput,\n  type SearchInputProps,\n} from \"../Form/SearchInput/SearchInput\";\nimport { useBulkActionsToolbar } from \"./useBulkActionsToolbar\";\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?: (toolbarContext: {\n    toolbarId: string;\n  }) => React.ReactNode;\n  rightContentNoWrapOnMobile?: boolean;\n  hideDivider?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst containerSmallSize = breakpoints.s.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  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    display: \"flex\",\n    flexDirection: \"column\",\n  },\n  [containerLarge]: {\n    paddingLeft: theme.variables.size.spacing.m,\n  },\n}));\n\nconst ToolbarInner = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  flexGrow: 1,\n  [containerSmall]: {\n    display: \"contents\",\n  },\n}));\n\nconst ToolbarControls = styled.div(({ theme }) => ({\n  display: \"flex\",\n  alignItems: \"center\",\n  gap: theme.variables.size.spacing.xs,\n  [containerSmall]: {\n    order: 3,\n    justifyContent: \"space-between\",\n  },\n}));\n\nconst StyledSearch = styled.div({\n  [containerSmall]: {\n    order: 1,\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  [containerSmall]: {\n    order: 2,\n    flex: \"none\",\n    ...(!rightContentNoWrapOnMobile && {\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.label(({ theme }) => ({\n  display: \"block\",\n  paddingLeft: 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 & { id?: string }> = ({\n  children,\n  id,\n}) => (\n  <TotalItemsStyled role=\"status\" aria-atomic=\"true\">\n    <Text size=\"s\" color=\"secondary\" weight=\"bold\" id={id}>\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  ...ariaAttributes\n}: BulkActionsToolbarProps): React.ReactElement {\n  const id = useId();\n  const { toolbarId, toolbarRef, onBlur, onFocus } = useBulkActionsToolbar();\n  const ariaControlsId = toolbarId;\n\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <ToolbarInner\n          role=\"toolbar\"\n          aria-describedby={!hasSelectionControls ? id : undefined}\n          aria-orientation=\"horizontal\"\n          id={toolbarId}\n          ref={toolbarRef}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          {...ariaAttributes}\n        >\n          <ToolbarControls>\n            {checkboxProps ? (\n              <CustomInline vAlignItems=\"center\">\n                <CheckboxStyled>\n                  <CheckboxRaw\n                    {...checkboxProps}\n                    size=\"s\"\n                    aria-labelledby={id}\n                  />\n                </CheckboxStyled>\n                <TotalItems id={id}>{totalItems}</TotalItems>\n              </CustomInline>\n            ) : (\n              <TotalItems id={id}>{totalItems}</TotalItems>\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                    aria-describedby={id}\n                  >\n                    {label}\n                  </Button>\n                )\n              )}\n            </Inline>\n          </ToolbarControls>\n          {renderRightContent && (\n            <StyledRightSlot\n              rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n            >\n              <StyledRightContent\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId: ariaControlsId })}\n              </StyledRightContent>\n            </StyledRightSlot>\n          )}\n        </ToolbarInner>\n        {searchInputProps && (\n          <StyledSearch>\n            <SearchInput {...searchInputProps} aria-describedby={id} />\n          </StyledSearch>\n        )}\n      </InlineContainer>\n      {!hideDivider && <Divider />}\n    </StyledBulkActionsToolbarContainer>\n  );\n}\n\nexport const BulkActionsToolbar = React.memo(BulkActionsToolbarUI);\n"],"names":[],"mappings":"AA+HyB"} */"),TotalItems=({children,id})=>_react.default.createElement(TotalItemsStyled,{role:"status","aria-atomic":"true"},_react.default.createElement(_Text.Text,{size:"s",color:"secondary",weight:"bold",id:id},children)),BulkActionsToolbar=_react.default.memo(function({actions,checkboxProps,totalItems,searchInputProps,renderRightContent,rightContentNoWrapOnMobile,hideDivider,"data-e2e-test-id":dataE2eTestId,...ariaAttributes}){let id=(0,_react.useId)(),{toolbarId,toolbarRef,onBlur,onFocus}=(0,_useBulkActionsToolbar.useBulkActionsToolbar)(),hasSelectionControls=!!(checkboxProps||searchInputProps);return _react.default.createElement(StyledBulkActionsToolbarContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Toolbar"},_react.default.createElement(InlineContainer,null,_react.default.createElement(ToolbarInner,{role:"toolbar","aria-describedby":hasSelectionControls?void 0:id,"aria-orientation":"horizontal",id:toolbarId,ref:toolbarRef,onBlur:onBlur,onFocus:onFocus,...ariaAttributes},_react.default.createElement(ToolbarControls,null,checkboxProps?_react.default.createElement(CustomInline,{vAlignItems:"center"},_react.default.createElement(CheckboxStyled,null,_react.default.createElement(_Checkbox.CheckboxRaw,{...checkboxProps,size:"s","aria-labelledby":id})),_react.default.createElement(TotalItems,{id:id},totalItems)):_react.default.createElement(TotalItems,{id:id},totalItems),_react.default.createElement(_Inline.Inline,{noWrap:!0},actions?.map(({variant="secondary",label,...buttonProps})=>_react.default.createElement(_Button.Button,{...buttonProps,key:`action-${label}`,size:"s",variant:variant,"aria-describedby":id},label)))),renderRightContent&&_react.default.createElement(StyledRightSlot,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},_react.default.createElement(StyledRightContent,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent({toolbarId:toolbarId})))),searchInputProps&&_react.default.createElement(StyledSearch,null,_react.default.createElement(_SearchInput.SearchInput,{...searchInputProps,"aria-describedby":id}))),!hideDivider&&_react.default.createElement(_Divider.Divider,null))});
@@ -0,0 +1,7 @@
1
+ import type { RefObject } from "react";
2
+ export declare const useBulkActionsToolbar: () => {
3
+ toolbarId: string;
4
+ toolbarRef: RefObject<HTMLDivElement>;
5
+ onBlur: (e: React.FocusEvent) => void;
6
+ onFocus: (e: React.FocusEvent) => void;
7
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"useBulkActionsToolbar",{enumerable:!0,get:function(){return useBulkActionsToolbar}});const _react=require("react"),_useKeyboard=require("../../shared/useKeyboard"),useBulkActionsToolbar=()=>{let toolbarId=(0,_react.useId)(),toolbarRef=(0,_react.useRef)(null),[focusedIndex,setFocusedIndex]=(0,_react.useState)(null),getFocusableElements=(0,_react.useCallback)(()=>Array.from(toolbarRef.current?.querySelectorAll("button:not(:disabled), [tabindex]:not([tabindex='-1']), a[href]")??[]),[toolbarRef]),updateTabIndices=(0,_react.useCallback)(activeIndex=>{getFocusableElements().forEach((el,i)=>{el.setAttribute("tabindex",i===activeIndex?"0":"-1")})},[getFocusableElements]),currentIndex=focusedIndex??0;(0,_react.useEffect)(()=>{updateTabIndices(currentIndex)},[currentIndex,updateTabIndices]);let focusAt=index=>{let elements=getFocusableElements();if(0===elements.length)return;let wrappedIndex=(index+elements.length)%elements.length;elements[wrappedIndex]?.focus(),setFocusedIndex(wrappedIndex)};return(0,_useKeyboard.useKeyboard)({ArrowRight:()=>focusAt(currentIndex+1),ArrowLeft:()=>focusAt(currentIndex-1),Home:()=>focusAt(0),End:()=>focusAt(-1)},toolbarRef,!0),{toolbarId,toolbarRef,onBlur:e=>{toolbarRef.current?.contains(e.relatedTarget)||setFocusedIndex(null)},onFocus:e=>{if(null!==focusedIndex)return;let index=getFocusableElements().indexOf(e.target);-1!==index&&setFocusedIndex(index)}}};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ReferenceButton",{enumerable:!0,get:function(){return ReferenceButton}});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")),_ContentList=require("../ContentList"),StyledButton=(0,_styled.default)("button",{target:"e1g5nlve0",label:"StyledButton"})(({theme})=>({display:"inline-flex",verticalAlign:"middle",border:"none",cursor:"pointer",marginInlineStart:1,marginInlineEnd:1,...(0,_ContentList.getReferenceListBulletStyle)(theme),"&:hover":{backgroundColor:theme.values.color.content.referenceButton.background.hover},"&:active":{backgroundColor:theme.values.color.content.referenceButton.background.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudC9SZWZlcmVuY2VCdXR0b24vUmVmZXJlbmNlQnV0dG9uLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudC9SZWZlcmVuY2VCdXR0b24vUmVmZXJlbmNlQnV0dG9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGdldFJlZmVyZW5jZUxpc3RCdWxsZXRTdHlsZSB9IGZyb20gXCIuLi9Db250ZW50TGlzdFwiO1xuXG5leHBvcnQgdHlwZSBSZWZlcmVuY2VCdXR0b25Qcm9wcyA9IFJlYWN0LkNvbXBvbmVudFByb3BzV2l0aFJlZjxcImJ1dHRvblwiPjtcblxuY29uc3QgU3R5bGVkQnV0dG9uID0gc3R5bGVkLmJ1dHRvbigoeyB0aGVtZSB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImlubGluZS1mbGV4XCIsXG4gIHZlcnRpY2FsQWxpZ246IFwibWlkZGxlXCIsXG4gIGJvcmRlcjogXCJub25lXCIsXG4gIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIG1hcmdpbklubGluZVN0YXJ0OiAxLFxuICBtYXJnaW5JbmxpbmVFbmQ6IDEsXG4gIC4uLmdldFJlZmVyZW5jZUxpc3RCdWxsZXRTdHlsZSh0aGVtZSksXG5cbiAgXCImOmhvdmVyXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6XG4gICAgICB0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudC5yZWZlcmVuY2VCdXR0b24uYmFja2dyb3VuZC5ob3ZlcixcbiAgfSxcblxuICBcIiY6YWN0aXZlXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6XG4gICAgICB0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudC5yZWZlcmVuY2VCdXR0b24uYmFja2dyb3VuZC5hY3RpdmUsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBSZWZlcmVuY2VCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MQnV0dG9uRWxlbWVudCxcbiAgUmVmZXJlbmNlQnV0dG9uUHJvcHNcbj4oKHsgdHlwZSA9IFwiYnV0dG9uXCIsIC4uLnJlc3QgfSwgcmVmKSA9PiAoXG4gIDxTdHlsZWRCdXR0b24gZGF0YS1kcy1pZD1cIlJlZmVyZW5jZUJ1dHRvblwiIHJlZj17cmVmfSB0eXBlPXt0eXBlfSB7Li4ucmVzdH0gLz5cbikpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1xQiJ9 */"),ReferenceButton=_react.default.forwardRef(({type="button",...rest},ref)=>_react.default.createElement(StyledButton,{"data-ds-id":"ReferenceButton",ref:ref,type:type,...rest}));
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ReferenceButton",{enumerable:!0,get:function(){return ReferenceButton}});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")),_ContentList=require("../ContentList"),StyledContent=(0,_styled.default)("span",{target:"eociiq20",label:"StyledContent"})(({theme})=>({...(0,_ContentList.getReferenceListBulletStyle)(theme)}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudC9SZWZlcmVuY2VCdXR0b24vUmVmZXJlbmNlQnV0dG9uLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudC9SZWZlcmVuY2VCdXR0b24vUmVmZXJlbmNlQnV0dG9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGdldFJlZmVyZW5jZUxpc3RCdWxsZXRTdHlsZSB9IGZyb20gXCIuLi9Db250ZW50TGlzdFwiO1xuXG5leHBvcnQgdHlwZSBSZWZlcmVuY2VCdXR0b25Qcm9wcyA9IFJlYWN0LkNvbXBvbmVudFByb3BzV2l0aFJlZjxcImJ1dHRvblwiPjtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5zcGFuKCh7IHRoZW1lIH0pID0+ICh7XG4gIC4uLmdldFJlZmVyZW5jZUxpc3RCdWxsZXRTdHlsZSh0aGVtZSksXG59KSk7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24oKHsgdGhlbWUgfSkgPT4gKHtcbiAgZGlzcGxheTogXCJpbmxpbmUtYmxvY2tcIixcbiAgdmVydGljYWxBbGlnbjogXCJtaWRkbGVcIixcbiAgYm9yZGVyOiBcIm5vbmVcIixcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gIGJhY2tncm91bmQ6IFwibm9uZVwiLFxuICBsaW5lSGVpZ2h0OiAwLFxuXG4gIFtgJjpob3ZlciAke1N0eWxlZENvbnRlbnR9YF06IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6XG4gICAgICB0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudC5yZWZlcmVuY2VCdXR0b24uYmFja2dyb3VuZC5ob3ZlcixcbiAgfSxcblxuICBbYCY6YWN0aXZlICR7U3R5bGVkQ29udGVudH1gXToge1xuICAgIGJhY2tncm91bmRDb2xvcjpcbiAgICAgIHRoZW1lLnZhbHVlcy5jb2xvci5jb250ZW50LnJlZmVyZW5jZUJ1dHRvbi5iYWNrZ3JvdW5kLmFjdGl2ZSxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGNvbnN0IFJlZmVyZW5jZUJ1dHRvbiA9IFJlYWN0LmZvcndhcmRSZWY8XG4gIEhUTUxCdXR0b25FbGVtZW50LFxuICBSZWZlcmVuY2VCdXR0b25Qcm9wc1xuPigoeyB0eXBlID0gXCJidXR0b25cIiwgY2hpbGRyZW4sIC4uLnJlc3QgfSwgcmVmKSA9PiAoXG4gIDxTdHlsZWRCdXR0b24gZGF0YS1kcy1pZD1cIlJlZmVyZW5jZUJ1dHRvblwiIHJlZj17cmVmfSB0eXBlPXt0eXBlfSB7Li4ucmVzdH0+XG4gICAgPFN0eWxlZENvbnRlbnQ+e2NoaWxkcmVufTwvU3R5bGVkQ29udGVudD5cbiAgPC9TdHlsZWRCdXR0b24+XG4pKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNc0IifQ== */"),StyledButton=(0,_styled.default)("button",{target:"eociiq21",label:"StyledButton"})(({theme})=>({display:"inline-block",verticalAlign:"middle",border:"none",cursor:"pointer",padding:theme.variables.size.spacing.xxs,background:"none",lineHeight:0,[`&:hover ${StyledContent}`]:{backgroundColor:theme.values.color.content.referenceButton.background.hover},[`&:active ${StyledContent}`]:{backgroundColor:theme.values.color.content.referenceButton.background.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudC9SZWZlcmVuY2VCdXR0b24vUmVmZXJlbmNlQnV0dG9uLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudC9SZWZlcmVuY2VCdXR0b24vUmVmZXJlbmNlQnV0dG9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGdldFJlZmVyZW5jZUxpc3RCdWxsZXRTdHlsZSB9IGZyb20gXCIuLi9Db250ZW50TGlzdFwiO1xuXG5leHBvcnQgdHlwZSBSZWZlcmVuY2VCdXR0b25Qcm9wcyA9IFJlYWN0LkNvbXBvbmVudFByb3BzV2l0aFJlZjxcImJ1dHRvblwiPjtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5zcGFuKCh7IHRoZW1lIH0pID0+ICh7XG4gIC4uLmdldFJlZmVyZW5jZUxpc3RCdWxsZXRTdHlsZSh0aGVtZSksXG59KSk7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24oKHsgdGhlbWUgfSkgPT4gKHtcbiAgZGlzcGxheTogXCJpbmxpbmUtYmxvY2tcIixcbiAgdmVydGljYWxBbGlnbjogXCJtaWRkbGVcIixcbiAgYm9yZGVyOiBcIm5vbmVcIixcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gIGJhY2tncm91bmQ6IFwibm9uZVwiLFxuICBsaW5lSGVpZ2h0OiAwLFxuXG4gIFtgJjpob3ZlciAke1N0eWxlZENvbnRlbnR9YF06IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6XG4gICAgICB0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudC5yZWZlcmVuY2VCdXR0b24uYmFja2dyb3VuZC5ob3ZlcixcbiAgfSxcblxuICBbYCY6YWN0aXZlICR7U3R5bGVkQ29udGVudH1gXToge1xuICAgIGJhY2tncm91bmRDb2xvcjpcbiAgICAgIHRoZW1lLnZhbHVlcy5jb2xvci5jb250ZW50LnJlZmVyZW5jZUJ1dHRvbi5iYWNrZ3JvdW5kLmFjdGl2ZSxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGNvbnN0IFJlZmVyZW5jZUJ1dHRvbiA9IFJlYWN0LmZvcndhcmRSZWY8XG4gIEhUTUxCdXR0b25FbGVtZW50LFxuICBSZWZlcmVuY2VCdXR0b25Qcm9wc1xuPigoeyB0eXBlID0gXCJidXR0b25cIiwgY2hpbGRyZW4sIC4uLnJlc3QgfSwgcmVmKSA9PiAoXG4gIDxTdHlsZWRCdXR0b24gZGF0YS1kcy1pZD1cIlJlZmVyZW5jZUJ1dHRvblwiIHJlZj17cmVmfSB0eXBlPXt0eXBlfSB7Li4ucmVzdH0+XG4gICAgPFN0eWxlZENvbnRlbnQ+e2NoaWxkcmVufTwvU3R5bGVkQ29udGVudD5cbiAgPC9TdHlsZWRCdXR0b24+XG4pKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVcUIifQ== */"),ReferenceButton=_react.default.forwardRef(({type="button",children,...rest},ref)=>_react.default.createElement(StyledButton,{"data-ds-id":"ReferenceButton",ref:ref,type:type,...rest},_react.default.createElement(StyledContent,null,children)));
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Link",{enumerable:!0,get:function(){return Link}});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")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Text=require("../Typography/Text/Text"),_Icon=require("../Icon/Icon"),StyledLink=(0,_styled.default)("a",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"inline"!==prop,target:"e14x3iba0",label:"StyledLink"})(({theme,weight,size,color,inline})=>({cursor:"pointer",background:"none",border:"none",padding:0,fontSize:theme.variables.size.font[size],fontWeight:theme.variables.weight[weight],lineHeight:({xs:theme.variables.size.lineHeight.xl,s:theme.variables.size.lineHeight.l,m:theme.variables.size.lineHeight.xl})[size],fontFamily:theme.variables.fontFamily.lato,textDecorationLine:inline?"underline":"none",color:color?theme.values.color.text[color].default:"inherit",...("primary"===color||"secondary"===color||"tertiary"===color)&&{textDecorationColor:theme.values.color.text.underline.default},"&:hover":{textDecorationLine:"underline",textDecorationThickness:"0.125em",...("primary"===color||"secondary"===color||"tertiary"===color)&&{textDecorationColor:theme.values.color.text.underline.hover,color:theme.values.color.text[color].hover}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Link/Link.tsx","sources":["src/components/Link/Link.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useContext, type AriaAttributes } from \"react\";\nimport type { CSSObject } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { TextContext } from \"../Typography/Text/Text\";\nimport type { IconProps } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  TextColors,\n  TextSize,\n  TextWeight,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n  LinkVariations,\n} from \"../../types\";\n\ntype SupplementaryIconProps = Pick<IconProps, \"name\" | \"color\">;\n\nexport type LinkConditionalProps =\n  | {\n      /** It forces to inherit color, weight, size from parent */\n      inline: true;\n      /** A color is inherited from its parent Text otherwise set as 'primary' */\n      color: TextColors;\n      /** Icons are not supported for inline links */\n      iconLeft?: never;\n      /** Icons are not supported for inline links */\n      iconRight?: never;\n    }\n  | {\n      inline?: false | undefined;\n      color?: TextColors;\n      /** Icon displayed on the left side of the link */\n      iconLeft?: SupplementaryIconProps;\n      /** Icon displayed on the right side of the link */\n      iconRight?: SupplementaryIconProps;\n    };\n\nexport type LinkProps = {\n  /** A size is inherited from its parent */\n  size?: TextSize;\n  /** A weight is inherited from its parent */\n  weight?: TextWeight;\n  /** @deprecated variant, please use \"color\" prop instead */\n  variant?: LinkVariations;\n  \"data-e2e-test-id\"?: string;\n} & LinkConditionalProps &\n  AriaAttributes;\n\nexport type LinkComponent = <C extends React.ElementType = \"a\">(\n  props: PolymorphicComponentPropsWithRef<C, LinkProps>\n) => React.ReactNode | null;\n\nconst StyledLink = styled(\"a\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"inline\",\n})<Partial<LinkProps>>(\n  ({ theme, weight, size, color, inline }) =>\n    ({\n      cursor: \"pointer\",\n      background: \"none\",\n      border: \"none\",\n      padding: 0,\n      fontSize: theme.variables.size.font[size],\n      fontWeight: theme.variables.weight[weight],\n      lineHeight: {\n        xs: theme.variables.size.lineHeight.xl,\n        s: theme.variables.size.lineHeight.l,\n        m: theme.variables.size.lineHeight.xl,\n      }[size],\n      fontFamily: theme.variables.fontFamily.lato,\n\n      textDecorationLine: inline ? \"underline\" : \"none\",\n      color: color ? theme.values.color.text[color].default : \"inherit\",\n\n      ...((color === \"primary\" ||\n        color === \"secondary\" ||\n        color === \"tertiary\") && {\n        textDecorationColor: theme.values.color.text.underline.default,\n      }),\n\n      \"&:hover\": {\n        textDecorationLine: \"underline\",\n        textDecorationThickness: \"0.125em\", // it's not working in Safari for a link as button\n        ...((color === \"primary\" ||\n          color === \"secondary\" ||\n          color === \"tertiary\") && {\n          textDecorationColor: theme.values.color.text.underline.hover,\n          color: theme.values.color.text[color].hover,\n        }),\n      },\n    } as CSSObject)\n);\n\nconst StyledIcon = styled(Icon)<{ position: \"left\" | \"right\" }>(\n  ({ position, theme }) => ({\n    ...(position === \"left\" && {\n      marginRight: theme.variables.size.spacing.xxs,\n    }),\n    ...(position === \"right\" && {\n      marginLeft: theme.variables.size.spacing.xxs,\n    }),\n  })\n);\n\nexport const Link: LinkComponent = React.forwardRef(\n  <C extends React.ElementType = \"a\">(\n    {\n      weight,\n      color: colorProp,\n      size,\n      variant,\n      inline,\n      iconLeft,\n      iconRight,\n      children,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, LinkProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const inheritPropsFromText = useContext(TextContext);\n\n    const getColor = () => {\n      if (variant) {\n        // this is going to be deleted after migration\n        if (variant === \"primary\") return \"accent\";\n        if (variant === \"secondary\") return \"primary\";\n        return variant;\n      }\n      if (colorProp) return colorProp;\n      if (inheritPropsFromText?.color) return inheritPropsFromText?.color;\n      if (!inline) return \"accent\";\n      return undefined;\n    };\n\n    const linkColor = getColor();\n\n    /* Why do we need inline prop? We inherit size and color from Text (if Link is wrapped in it), but we need to support Links within Headers and other custom components. Thus by default, size and color are not required props */\n    const isInlineLink = inline || !!inheritPropsFromText;\n\n    const hasIcons = !isInlineLink && (iconLeft || iconRight);\n\n    const linkContent = hasIcons ? (\n      <>\n        {iconLeft && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconLeft.name}\n            color={iconLeft.color ?? linkColor}\n            inline\n            position=\"left\"\n          />\n        )}\n        {children}\n        {iconRight && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconRight.name}\n            color={iconRight.color ?? linkColor}\n            inline\n            position=\"right\"\n          />\n        )}\n      </>\n    ) : (\n      children\n    );\n\n    return (\n      <StyledLink\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Link\"\n        ref={ref}\n        inline={isInlineLink}\n        color={linkColor}\n        size={size || inheritPropsFromText?.size}\n        weight={weight || inheritPropsFromText?.weight}\n        {...rest}\n      >\n        {linkContent}\n      </StyledLink>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsDmB"} */"),StyledIcon=(0,_styled.default)(_Icon.Icon,{target:"e14x3iba1",label:"StyledIcon"})(({position,theme})=>({..."left"===position&&{marginRight:theme.variables.size.spacing.xxs},..."right"===position&&{marginLeft:theme.variables.size.spacing.xxs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Link/Link.tsx","sources":["src/components/Link/Link.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useContext, type AriaAttributes } from \"react\";\nimport type { CSSObject } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { TextContext } from \"../Typography/Text/Text\";\nimport type { IconProps } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  TextColors,\n  TextSize,\n  TextWeight,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n  LinkVariations,\n} from \"../../types\";\n\ntype SupplementaryIconProps = Pick<IconProps, \"name\" | \"color\">;\n\nexport type LinkConditionalProps =\n  | {\n      /** It forces to inherit color, weight, size from parent */\n      inline: true;\n      /** A color is inherited from its parent Text otherwise set as 'primary' */\n      color: TextColors;\n      /** Icons are not supported for inline links */\n      iconLeft?: never;\n      /** Icons are not supported for inline links */\n      iconRight?: never;\n    }\n  | {\n      inline?: false | undefined;\n      color?: TextColors;\n      /** Icon displayed on the left side of the link */\n      iconLeft?: SupplementaryIconProps;\n      /** Icon displayed on the right side of the link */\n      iconRight?: SupplementaryIconProps;\n    };\n\nexport type LinkProps = {\n  /** A size is inherited from its parent */\n  size?: TextSize;\n  /** A weight is inherited from its parent */\n  weight?: TextWeight;\n  /** @deprecated variant, please use \"color\" prop instead */\n  variant?: LinkVariations;\n  \"data-e2e-test-id\"?: string;\n} & LinkConditionalProps &\n  AriaAttributes;\n\nexport type LinkComponent = <C extends React.ElementType = \"a\">(\n  props: PolymorphicComponentPropsWithRef<C, LinkProps>\n) => React.ReactNode | null;\n\nconst StyledLink = styled(\"a\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"inline\",\n})<Partial<LinkProps>>(\n  ({ theme, weight, size, color, inline }) =>\n    ({\n      cursor: \"pointer\",\n      background: \"none\",\n      border: \"none\",\n      padding: 0,\n      fontSize: theme.variables.size.font[size],\n      fontWeight: theme.variables.weight[weight],\n      lineHeight: {\n        xs: theme.variables.size.lineHeight.xl,\n        s: theme.variables.size.lineHeight.l,\n        m: theme.variables.size.lineHeight.xl,\n      }[size],\n      fontFamily: theme.variables.fontFamily.lato,\n\n      textDecorationLine: inline ? \"underline\" : \"none\",\n      color: color ? theme.values.color.text[color].default : \"inherit\",\n\n      ...((color === \"primary\" ||\n        color === \"secondary\" ||\n        color === \"tertiary\") && {\n        textDecorationColor: theme.values.color.text.underline.default,\n      }),\n\n      \"&:hover\": {\n        textDecorationLine: \"underline\",\n        textDecorationThickness: \"0.125em\", // it's not working in Safari for a link as button\n        ...((color === \"primary\" ||\n          color === \"secondary\" ||\n          color === \"tertiary\") && {\n          textDecorationColor: theme.values.color.text.underline.hover,\n          color: theme.values.color.text[color].hover,\n        }),\n      },\n    } as CSSObject)\n);\n\nconst StyledIcon = styled(Icon)<{ position: \"left\" | \"right\" }>(\n  ({ position, theme }) => ({\n    ...(position === \"left\" && {\n      marginRight: theme.variables.size.spacing.xxs,\n    }),\n    ...(position === \"right\" && {\n      marginLeft: theme.variables.size.spacing.xxs,\n    }),\n  })\n);\n\nexport const Link: LinkComponent = React.forwardRef(\n  <C extends React.ElementType = \"a\">(\n    {\n      weight,\n      color: colorProp,\n      size,\n      variant,\n      inline,\n      iconLeft,\n      iconRight,\n      children,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, LinkProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const inheritPropsFromText = useContext(TextContext);\n\n    const getColor = () => {\n      if (variant) {\n        // this is going to be deleted after migration\n        if (variant === \"primary\") return \"accent\";\n        if (variant === \"secondary\") return \"primary\";\n        return variant;\n      }\n      if (colorProp) return colorProp;\n      if (inheritPropsFromText?.color) return inheritPropsFromText?.color;\n      if (!inline) return \"accent\";\n      return undefined;\n    };\n\n    const linkColor = getColor();\n\n    /* Why do we need inline prop? We inherit size and color from Text (if Link is wrapped in it), but we need to support Links within Headers and other custom components. Thus by default, size and color are not required props */\n    const isInlineLink = inline || !!inheritPropsFromText;\n\n    const hasIcons = !isInlineLink && (iconLeft || iconRight);\n\n    const linkContent = hasIcons ? (\n      <>\n        {iconLeft && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconLeft.name}\n            color={iconLeft.color ?? linkColor}\n            inline\n            position=\"left\"\n          />\n        )}\n        {children}\n        {iconRight && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconRight.name}\n            color={iconRight.color ?? linkColor}\n            inline\n            position=\"right\"\n          />\n        )}\n      </>\n    ) : (\n      children\n    );\n\n    return (\n      <StyledLink\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Link\"\n        ref={ref}\n        inline={isInlineLink}\n        color={linkColor}\n        size={size || inheritPropsFromText?.size}\n        weight={weight || inheritPropsFromText?.weight}\n        {...rest}\n      >\n        {linkContent}\n      </StyledLink>\n    );\n  }\n);\n"],"names":[],"mappings":"AA8FmB"} */"),Link=_react.default.forwardRef(({weight,color:colorProp,size,variant,inline,iconLeft,iconRight,children,"data-e2e-test-id":dataE2eTestId,...rest},ref)=>{let inheritPropsFromText=(0,_react.useContext)(_Text.TextContext),linkColor=variant?"primary"===variant?"accent":"secondary"===variant?"primary":variant:colorProp||(inheritPropsFromText?.color?inheritPropsFromText?.color:inline?void 0:"accent"),isInlineLink=inline||!!inheritPropsFromText,linkContent=!isInlineLink&&(iconLeft||iconRight)?_react.default.createElement(_react.default.Fragment,null,iconLeft&&_react.default.createElement(StyledIcon,{"aria-hidden":!0,size:"s",name:iconLeft.name,color:iconLeft.color??linkColor,inline:!0,position:"left"}),children,iconRight&&_react.default.createElement(StyledIcon,{"aria-hidden":!0,size:"s",name:iconRight.name,color:iconRight.color??linkColor,inline:!0,position:"right"})):children;return _react.default.createElement(StyledLink,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Link",ref:ref,inline:isInlineLink,color:linkColor,size:size||inheritPropsFromText?.size,weight:weight||inheritPropsFromText?.weight,...rest},linkContent)});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Link",{enumerable:!0,get:function(){return Link}});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")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Text=require("../Typography/Text/Text"),_Icon=require("../Icon/Icon"),StyledLink=(0,_styled.default)("a",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"inline"!==prop,target:"e1qwyc000",label:"StyledLink"})(({theme,weight,size,color,inline,as})=>({cursor:"pointer",background:"none",border:"none",padding:0,fontSize:theme.variables.size.font[size]??"inherit",fontWeight:theme.variables.weight[weight]??"inherit",lineHeight:({xs:theme.variables.size.lineHeight.xl,s:theme.variables.size.lineHeight.l,m:theme.variables.size.lineHeight.xl})[size],fontFamily:theme.variables.fontFamily.lato,textDecorationLine:inline?"underline":"none",color:color?theme.values.color.text[color].default:"inherit",...("primary"===color||"secondary"===color||"tertiary"===color)&&{textDecorationColor:theme.values.color.text.underline.default},"&:hover":{textDecorationLine:"underline",textDecorationThickness:"0.125em",...("primary"===color||"secondary"===color||"tertiary"===color)&&{textDecorationColor:theme.values.color.text.underline.hover,color:theme.values.color.text[color].hover}},..."button"===as&&{whiteSpace:"pre"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Link/Link.tsx","sources":["src/components/Link/Link.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useContext, type AriaAttributes } from \"react\";\nimport type { CSSObject } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { TextContext } from \"../Typography/Text/Text\";\nimport type { IconProps } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  TextColors,\n  TextSize,\n  TextWeight,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n  LinkVariations,\n} from \"../../types\";\n\ntype SupplementaryIconProps = Pick<IconProps, \"name\" | \"color\">;\n\nexport type LinkConditionalProps =\n  | {\n      /** It forces to inherit color, weight, size from parent */\n      inline: true;\n      /** A color is inherited from its parent Text otherwise set as 'primary' */\n      color: TextColors;\n      /** Icons are not supported for inline links */\n      iconLeft?: never;\n      /** Icons are not supported for inline links */\n      iconRight?: never;\n    }\n  | {\n      inline?: false | undefined;\n      color?: TextColors;\n      /** Icon displayed on the left side of the link */\n      iconLeft?: SupplementaryIconProps;\n      /** Icon displayed on the right side of the link */\n      iconRight?: SupplementaryIconProps;\n    };\n\nexport type LinkProps = {\n  /** A size is inherited from its parent */\n  size?: TextSize;\n  /** A weight is inherited from its parent */\n  weight?: TextWeight;\n  /** @deprecated variant, please use \"color\" prop instead */\n  variant?: LinkVariations;\n  \"data-e2e-test-id\"?: string;\n} & LinkConditionalProps &\n  AriaAttributes;\n\nexport type LinkComponent = <C extends React.ElementType = \"a\">(\n  props: PolymorphicComponentPropsWithRef<C, LinkProps>\n) => React.ReactNode | null;\n\nconst StyledLink = styled(\"a\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"inline\",\n})<Partial<LinkProps>>(\n  ({ theme, weight, size, color, inline, as }) =>\n    ({\n      cursor: \"pointer\",\n      background: \"none\",\n      border: \"none\",\n      padding: 0,\n      fontSize: theme.variables.size.font[size] ?? \"inherit\",\n      fontWeight: theme.variables.weight[weight] ?? \"inherit\",\n      lineHeight: {\n        xs: theme.variables.size.lineHeight.xl,\n        s: theme.variables.size.lineHeight.l,\n        m: theme.variables.size.lineHeight.xl,\n      }[size],\n      fontFamily: theme.variables.fontFamily.lato,\n\n      textDecorationLine: inline ? \"underline\" : \"none\",\n      color: color ? theme.values.color.text[color].default : \"inherit\",\n\n      ...((color === \"primary\" ||\n        color === \"secondary\" ||\n        color === \"tertiary\") && {\n        textDecorationColor: theme.values.color.text.underline.default,\n      }),\n\n      \"&:hover\": {\n        textDecorationLine: \"underline\",\n        textDecorationThickness: \"0.125em\", // it's not working in Safari for a link as button\n        ...((color === \"primary\" ||\n          color === \"secondary\" ||\n          color === \"tertiary\") && {\n          textDecorationColor: theme.values.color.text.underline.hover,\n          color: theme.values.color.text[color].hover,\n        }),\n      },\n\n      ...(as === \"button\" && {\n        whiteSpace: \"pre\", // preserve trailing spaces\n      }),\n    } as CSSObject)\n);\n\nconst StyledIcon = styled(Icon)<{ position: \"left\" | \"right\" }>(\n  ({ position, theme }) => ({\n    ...(position === \"left\" && {\n      marginRight: theme.variables.size.spacing.xxs,\n    }),\n    ...(position === \"right\" && {\n      marginLeft: theme.variables.size.spacing.xxs,\n    }),\n  })\n);\n\nexport const Link: LinkComponent = React.forwardRef(\n  <C extends React.ElementType = \"a\">(\n    {\n      weight,\n      color: colorProp,\n      size,\n      variant,\n      inline,\n      iconLeft,\n      iconRight,\n      children,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, LinkProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const inheritPropsFromText = useContext(TextContext);\n\n    const getColor = () => {\n      if (variant) {\n        // this is going to be deleted after migration\n        if (variant === \"primary\") return \"accent\";\n        if (variant === \"secondary\") return \"primary\";\n        return variant;\n      }\n      if (colorProp) return colorProp;\n      if (inheritPropsFromText?.color) return inheritPropsFromText?.color;\n      if (!inline) return \"accent\";\n      return undefined;\n    };\n\n    const linkColor = getColor();\n\n    /* Why do we need inline prop? We inherit size and color from Text (if Link is wrapped in it), but we need to support Links within Headers and other custom components. Thus by default, size and color are not required props */\n    const isInlineLink = inline || !!inheritPropsFromText;\n\n    const hasIcons = !isInlineLink && (iconLeft || iconRight);\n\n    const linkContent = hasIcons ? (\n      <>\n        {iconLeft && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconLeft.name}\n            color={iconLeft.color ?? linkColor}\n            inline\n            position=\"left\"\n          />\n        )}\n        {children}\n        {iconRight && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconRight.name}\n            color={iconRight.color ?? linkColor}\n            inline\n            position=\"right\"\n          />\n        )}\n      </>\n    ) : (\n      children\n    );\n\n    return (\n      <StyledLink\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Link\"\n        ref={ref}\n        inline={isInlineLink}\n        color={linkColor}\n        size={size || inheritPropsFromText?.size}\n        weight={weight || inheritPropsFromText?.weight}\n        {...rest}\n      >\n        {linkContent}\n      </StyledLink>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsDmB"} */"),StyledIcon=(0,_styled.default)(_Icon.Icon,{target:"e1qwyc001",label:"StyledIcon"})(({position,theme})=>({..."left"===position&&{marginRight:theme.variables.size.spacing.xxs},..."right"===position&&{marginLeft:theme.variables.size.spacing.xxs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Link/Link.tsx","sources":["src/components/Link/Link.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useContext, type AriaAttributes } from \"react\";\nimport type { CSSObject } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { TextContext } from \"../Typography/Text/Text\";\nimport type { IconProps } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  TextColors,\n  TextSize,\n  TextWeight,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n  LinkVariations,\n} from \"../../types\";\n\ntype SupplementaryIconProps = Pick<IconProps, \"name\" | \"color\">;\n\nexport type LinkConditionalProps =\n  | {\n      /** It forces to inherit color, weight, size from parent */\n      inline: true;\n      /** A color is inherited from its parent Text otherwise set as 'primary' */\n      color: TextColors;\n      /** Icons are not supported for inline links */\n      iconLeft?: never;\n      /** Icons are not supported for inline links */\n      iconRight?: never;\n    }\n  | {\n      inline?: false | undefined;\n      color?: TextColors;\n      /** Icon displayed on the left side of the link */\n      iconLeft?: SupplementaryIconProps;\n      /** Icon displayed on the right side of the link */\n      iconRight?: SupplementaryIconProps;\n    };\n\nexport type LinkProps = {\n  /** A size is inherited from its parent */\n  size?: TextSize;\n  /** A weight is inherited from its parent */\n  weight?: TextWeight;\n  /** @deprecated variant, please use \"color\" prop instead */\n  variant?: LinkVariations;\n  \"data-e2e-test-id\"?: string;\n} & LinkConditionalProps &\n  AriaAttributes;\n\nexport type LinkComponent = <C extends React.ElementType = \"a\">(\n  props: PolymorphicComponentPropsWithRef<C, LinkProps>\n) => React.ReactNode | null;\n\nconst StyledLink = styled(\"a\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"inline\",\n})<Partial<LinkProps>>(\n  ({ theme, weight, size, color, inline, as }) =>\n    ({\n      cursor: \"pointer\",\n      background: \"none\",\n      border: \"none\",\n      padding: 0,\n      fontSize: theme.variables.size.font[size] ?? \"inherit\",\n      fontWeight: theme.variables.weight[weight] ?? \"inherit\",\n      lineHeight: {\n        xs: theme.variables.size.lineHeight.xl,\n        s: theme.variables.size.lineHeight.l,\n        m: theme.variables.size.lineHeight.xl,\n      }[size],\n      fontFamily: theme.variables.fontFamily.lato,\n\n      textDecorationLine: inline ? \"underline\" : \"none\",\n      color: color ? theme.values.color.text[color].default : \"inherit\",\n\n      ...((color === \"primary\" ||\n        color === \"secondary\" ||\n        color === \"tertiary\") && {\n        textDecorationColor: theme.values.color.text.underline.default,\n      }),\n\n      \"&:hover\": {\n        textDecorationLine: \"underline\",\n        textDecorationThickness: \"0.125em\", // it's not working in Safari for a link as button\n        ...((color === \"primary\" ||\n          color === \"secondary\" ||\n          color === \"tertiary\") && {\n          textDecorationColor: theme.values.color.text.underline.hover,\n          color: theme.values.color.text[color].hover,\n        }),\n      },\n\n      ...(as === \"button\" && {\n        whiteSpace: \"pre\", // preserve trailing spaces\n      }),\n    } as CSSObject)\n);\n\nconst StyledIcon = styled(Icon)<{ position: \"left\" | \"right\" }>(\n  ({ position, theme }) => ({\n    ...(position === \"left\" && {\n      marginRight: theme.variables.size.spacing.xxs,\n    }),\n    ...(position === \"right\" && {\n      marginLeft: theme.variables.size.spacing.xxs,\n    }),\n  })\n);\n\nexport const Link: LinkComponent = React.forwardRef(\n  <C extends React.ElementType = \"a\">(\n    {\n      weight,\n      color: colorProp,\n      size,\n      variant,\n      inline,\n      iconLeft,\n      iconRight,\n      children,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, LinkProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const inheritPropsFromText = useContext(TextContext);\n\n    const getColor = () => {\n      if (variant) {\n        // this is going to be deleted after migration\n        if (variant === \"primary\") return \"accent\";\n        if (variant === \"secondary\") return \"primary\";\n        return variant;\n      }\n      if (colorProp) return colorProp;\n      if (inheritPropsFromText?.color) return inheritPropsFromText?.color;\n      if (!inline) return \"accent\";\n      return undefined;\n    };\n\n    const linkColor = getColor();\n\n    /* Why do we need inline prop? We inherit size and color from Text (if Link is wrapped in it), but we need to support Links within Headers and other custom components. Thus by default, size and color are not required props */\n    const isInlineLink = inline || !!inheritPropsFromText;\n\n    const hasIcons = !isInlineLink && (iconLeft || iconRight);\n\n    const linkContent = hasIcons ? (\n      <>\n        {iconLeft && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconLeft.name}\n            color={iconLeft.color ?? linkColor}\n            inline\n            position=\"left\"\n          />\n        )}\n        {children}\n        {iconRight && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconRight.name}\n            color={iconRight.color ?? linkColor}\n            inline\n            position=\"right\"\n          />\n        )}\n      </>\n    ) : (\n      children\n    );\n\n    return (\n      <StyledLink\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Link\"\n        ref={ref}\n        inline={isInlineLink}\n        color={linkColor}\n        size={size || inheritPropsFromText?.size}\n        weight={weight || inheritPropsFromText?.weight}\n        {...rest}\n      >\n        {linkContent}\n      </StyledLink>\n    );\n  }\n);\n"],"names":[],"mappings":"AAkGmB"} */"),Link=_react.default.forwardRef(({weight,color:colorProp,size,variant,inline,iconLeft,iconRight,children,"data-e2e-test-id":dataE2eTestId,...rest},ref)=>{let inheritPropsFromText=(0,_react.useContext)(_Text.TextContext),linkColor=variant?"primary"===variant?"accent":"secondary"===variant?"primary":variant:colorProp||(inheritPropsFromText?.color?inheritPropsFromText?.color:inline?void 0:"accent"),isInlineLink=inline||!!inheritPropsFromText,linkContent=!isInlineLink&&(iconLeft||iconRight)?_react.default.createElement(_react.default.Fragment,null,iconLeft&&_react.default.createElement(StyledIcon,{"aria-hidden":!0,size:"s",name:iconLeft.name,color:iconLeft.color??linkColor,inline:!0,position:"left"}),children,iconRight&&_react.default.createElement(StyledIcon,{"aria-hidden":!0,size:"s",name:iconRight.name,color:iconRight.color??linkColor,inline:!0,position:"right"})):children;return _react.default.createElement(StyledLink,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Link",ref:ref,inline:isInlineLink,color:linkColor,size:size||inheritPropsFromText?.size,weight:weight||inheritPropsFromText?.weight,...rest},linkContent)});
@@ -1,4 +1,4 @@
1
- import React from "react";
1
+ import React, { type HTMLAttributes } from "react";
2
2
  import type { ProgressBarWeight } from "../SegmentedProgressBar/-types";
3
3
  export type ProgressBarProps = {
4
4
  /** The value for 100% progress. Consumer does not need to do percentage calculation. */
@@ -8,5 +8,5 @@ export type ProgressBarProps = {
8
8
  squareCorners?: boolean;
9
9
  weight?: ProgressBarWeight;
10
10
  "data-e2e-test-id"?: string;
11
- };
12
- export declare function ProgressBar({ maxValue, progress, weight, squareCorners, "data-e2e-test-id": dataE2eTestId, ...ariaAttributes }: ProgressBarProps): React.ReactElement;
11
+ } & HTMLAttributes<HTMLProgressElement>;
12
+ export declare function ProgressBar({ maxValue, progress, weight, squareCorners, "data-e2e-test-id": dataE2eTestId, id, ...ariaAttributes }: ProgressBarProps): React.ReactElement;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ProgressBar",{enumerable:!0,get:function(){return ProgressBar}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_default")._(require("react")),_SegmentedProgressBar=require("../SegmentedProgressBar/SegmentedProgressBar");function ProgressBar({maxValue,progress,weight="fat",squareCorners=!1,"data-e2e-test-id":dataE2eTestId,...ariaAttributes}){return _react.default.createElement(_SegmentedProgressBar.SegmentedProgressBar,{maxValue:maxValue,values:{success:progress},weight:weight,squareCorners:squareCorners,"data-e2e-test-id":dataE2eTestId,privateProps:{monochrome:!0},...ariaAttributes})}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ProgressBar",{enumerable:!0,get:function(){return ProgressBar}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_default")._(require("react")),_SegmentedProgressBar=require("../SegmentedProgressBar/SegmentedProgressBar");function ProgressBar({maxValue,progress,weight="fat",squareCorners=!1,"data-e2e-test-id":dataE2eTestId,id,...ariaAttributes}){return _react.default.createElement(_SegmentedProgressBar.SegmentedProgressBar,{maxValue:maxValue,values:{success:progress},weight:weight,squareCorners:squareCorners,"data-e2e-test-id":dataE2eTestId,privateProps:{monochrome:!0},id:id,...ariaAttributes})}