@amboss/design-system 3.37.0 → 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.
- package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
- package/build/cjs/components/BulkActionsToolbar/useBulkActionsToolbar.d.ts +7 -0
- package/build/cjs/components/BulkActionsToolbar/useBulkActionsToolbar.js +1 -0
- package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
- package/build/esm/components/BulkActionsToolbar/useBulkActionsToolbar.d.ts +7 -0
- package/build/esm/components/BulkActionsToolbar/useBulkActionsToolbar.js +1 -0
- package/package.json +1 -1
- package/build/cjs/components/BulkActionsToolbar/useToolbarFocus.d.ts +0 -9
- package/build/cjs/components/BulkActionsToolbar/useToolbarFocus.js +0 -1
- package/build/esm/components/BulkActionsToolbar/useToolbarFocus.d.ts +0 -9
- package/build/esm/components/BulkActionsToolbar/useToolbarFocus.js +0 -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"),_useToolbarFocus=require("./useToolbarFocus"),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:"e1oqw8ln0",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AAuC0C"} */"),InlineContainer=(0,_styled.default)("div",{target:"e1oqw8ln1",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA4CwB"} */"),InlineItem=(0,_styled.default)("div",{target:"e1oqw8ln2",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA0DmB"} */"),StyledSearch=(0,_styled.default)("div",{target:"e1oqw8ln3",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA0EqB"} */"),StyledRightSlot=(0,_styled.default)("div",{target:"e1oqw8ln4",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AAkFwB"} */"),StyledRightContent=(0,_styled.default)("div",{target:"e1oqw8ln5",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AAiG2B"} */"),CustomInline=(0,_styled.default)(_Inline.Inline,{target:"e1oqw8ln6",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA2GqB"} */"),CheckboxStyled=(0,_styled.default)("label",{target:"e1oqw8ln7",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AAoHuB"} */"),TotalItemsStyled=(0,_styled.default)("div",{target:"e1oqw8ln8",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA4HyB"} */"),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=(0,_react.useId)(),toolbarRef=(0,_react.useRef)(null),hasSelectionControls=!!(checkboxProps||searchInputProps),{onBlur,onFocus}=(0,_useToolbarFocus.useToolbarFocus)({toolbarRef});return _react.default.createElement(StyledBulkActionsToolbarContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Toolbar"},_react.default.createElement(InlineContainer,null,_react.default.createElement(InlineItem,{order:[1,-1],role:"toolbar","aria-describedby":hasSelectionControls?void 0:id,"aria-orientation":"horizontal",id:toolbarId,ref:toolbarRef,onBlur:onBlur,onFocus:onFocus,...ariaAttributes},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)))),_react.default.createElement(InlineItem,{order:[-1,1]},_react.default.createElement(StyledRightSlot,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent&&_react.default.createElement(StyledRightContent,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent({toolbarId})),searchInputProps&&_react.default.createElement(StyledSearch,null,_react.default.createElement(_SearchInput.SearchInput,{...searchInputProps,"aria-describedby":id}))))),!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 @@
|
|
|
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
|
-
import React,{useId,useRef}from"react";import styled from"@emotion/styled";import{Text}from"../Typography/Text/Text";import{Button}from"../Button/Button";import{Inline}from"../Inline/Inline";import{Divider}from"../Divider/Divider";import{CheckboxRaw}from"../Form/Checkbox/Checkbox";import breakpoints from"../../web-tokens/_breakpoints.json";import{SearchInput}from"../Form/SearchInput/SearchInput";import{useToolbarFocus}from"./useToolbarFocus";let containerSmallSize=breakpoints.s.value,toolbarContainerName="bulkActionsToolbar",containerSmall=`@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`,containerLarge=`@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`,StyledBulkActionsToolbarContainer=styled("div",{target:"e1oqw8ln0",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AAuC0C"} */"),InlineContainer=styled("div",{target:"e1oqw8ln1",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA4CwB"} */"),InlineItem=styled("div",{target:"e1oqw8ln2",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA0DmB"} */"),StyledSearch=styled("div",{target:"e1oqw8ln3",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA0EqB"} */"),StyledRightSlot=styled("div",{target:"e1oqw8ln4",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AAkFwB"} */"),StyledRightContent=styled("div",{target:"e1oqw8ln5",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AAiG2B"} */"),CustomInline=styled(Inline,{target:"e1oqw8ln6",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA2GqB"} */"),CheckboxStyled=styled("label",{target:"e1oqw8ln7",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AAoHuB"} */"),TotalItemsStyled=styled("div",{target:"e1oqw8ln8",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, useRef } 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 { useToolbarFocus } from \"./useToolbarFocus\";\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  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\" 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 = useId();\n  const toolbarRef = useRef<HTMLDivElement>(null);\n  const hasSelectionControls = !!(checkboxProps || searchInputProps);\n\n  const { onBlur, onFocus } = useToolbarFocus({ toolbarRef });\n\n  return (\n    <StyledBulkActionsToolbarContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"Toolbar\"\n    >\n      <InlineContainer>\n        <InlineItem\n          order={[1, -1]}\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          {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 id={id}>{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                  aria-describedby={id}\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\n                rightContentNoWrapOnMobile={rightContentNoWrapOnMobile}\n              >\n                {renderRightContent({ toolbarId })}\n              </StyledRightContent>\n            )}\n            {searchInputProps && (\n              <StyledSearch>\n                <SearchInput {...searchInputProps} aria-describedby={id} />\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":"AA4HyB"} */"),TotalItems=({children,id})=>React.createElement(TotalItemsStyled,{role:"status","aria-atomic":"true"},React.createElement(Text,{size:"s",color:"secondary",weight:"bold",id:id},children));export const BulkActionsToolbar=React.memo(function({actions,checkboxProps,totalItems,searchInputProps,renderRightContent,rightContentNoWrapOnMobile,hideDivider,"data-e2e-test-id":dataE2eTestId,...ariaAttributes}){let id=useId(),toolbarId=useId(),toolbarRef=useRef(null),hasSelectionControls=!!(checkboxProps||searchInputProps),{onBlur,onFocus}=useToolbarFocus({toolbarRef});return React.createElement(StyledBulkActionsToolbarContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Toolbar"},React.createElement(InlineContainer,null,React.createElement(InlineItem,{order:[1,-1],role:"toolbar","aria-describedby":hasSelectionControls?void 0:id,"aria-orientation":"horizontal",id:toolbarId,ref:toolbarRef,onBlur:onBlur,onFocus:onFocus,...ariaAttributes},checkboxProps?React.createElement(CustomInline,{vAlignItems:"center"},React.createElement(CheckboxStyled,null,React.createElement(CheckboxRaw,{...checkboxProps,size:"s","aria-labelledby":id})),React.createElement(TotalItems,{id:id},totalItems)):React.createElement(TotalItems,{id:id},totalItems),React.createElement(Inline,{noWrap:!0},actions?.map(({variant="secondary",label,...buttonProps})=>React.createElement(Button,{...buttonProps,key:`action-${label}`,size:"s",variant:variant,"aria-describedby":id},label)))),React.createElement(InlineItem,{order:[-1,1]},React.createElement(StyledRightSlot,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent&&React.createElement(StyledRightContent,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent({toolbarId})),searchInputProps&&React.createElement(StyledSearch,null,React.createElement(SearchInput,{...searchInputProps,"aria-describedby":id}))))),!hideDivider&&React.createElement(Divider,null))});
|
|
1
|
+
import React,{useId}from"react";import styled from"@emotion/styled";import{Text}from"../Typography/Text/Text";import{Button}from"../Button/Button";import{Inline}from"../Inline/Inline";import{Divider}from"../Divider/Divider";import{CheckboxRaw}from"../Form/Checkbox/Checkbox";import breakpoints from"../../web-tokens/_breakpoints.json";import{SearchInput}from"../Form/SearchInput/SearchInput";import{useBulkActionsToolbar}from"./useBulkActionsToolbar";let containerSmallSize=breakpoints.s.value,toolbarContainerName="bulkActionsToolbar",containerSmall=`@container ${toolbarContainerName} (min-width: 0px) and (max-width:${containerSmallSize}px)`,containerLarge=`@container ${toolbarContainerName} (min-width: ${containerSmallSize}px)`,StyledBulkActionsToolbarContainer=styled("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=styled("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=styled("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=styled("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=styled("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=styled("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=styled("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=styled(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=styled("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=styled("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.createElement(TotalItemsStyled,{role:"status","aria-atomic":"true"},React.createElement(Text,{size:"s",color:"secondary",weight:"bold",id:id},children));export const BulkActionsToolbar=React.memo(function({actions,checkboxProps,totalItems,searchInputProps,renderRightContent,rightContentNoWrapOnMobile,hideDivider,"data-e2e-test-id":dataE2eTestId,...ariaAttributes}){let id=useId(),{toolbarId,toolbarRef,onBlur,onFocus}=useBulkActionsToolbar(),hasSelectionControls=!!(checkboxProps||searchInputProps);return React.createElement(StyledBulkActionsToolbarContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Toolbar"},React.createElement(InlineContainer,null,React.createElement(ToolbarInner,{role:"toolbar","aria-describedby":hasSelectionControls?void 0:id,"aria-orientation":"horizontal",id:toolbarId,ref:toolbarRef,onBlur:onBlur,onFocus:onFocus,...ariaAttributes},React.createElement(ToolbarControls,null,checkboxProps?React.createElement(CustomInline,{vAlignItems:"center"},React.createElement(CheckboxStyled,null,React.createElement(CheckboxRaw,{...checkboxProps,size:"s","aria-labelledby":id})),React.createElement(TotalItems,{id:id},totalItems)):React.createElement(TotalItems,{id:id},totalItems),React.createElement(Inline,{noWrap:!0},actions?.map(({variant="secondary",label,...buttonProps})=>React.createElement(Button,{...buttonProps,key:`action-${label}`,size:"s",variant:variant,"aria-describedby":id},label)))),renderRightContent&&React.createElement(StyledRightSlot,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},React.createElement(StyledRightContent,{rightContentNoWrapOnMobile:rightContentNoWrapOnMobile},renderRightContent({toolbarId:toolbarId})))),searchInputProps&&React.createElement(StyledSearch,null,React.createElement(SearchInput,{...searchInputProps,"aria-describedby":id}))),!hideDivider&&React.createElement(Divider,null))});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{useCallback,useEffect,useId,useRef,useState}from"react";import{useKeyboard}from"../../shared/useKeyboard";export const useBulkActionsToolbar=()=>{let toolbarId=useId(),toolbarRef=useRef(null),[focusedIndex,setFocusedIndex]=useState(null),getFocusableElements=useCallback(()=>Array.from(toolbarRef.current?.querySelectorAll("button:not(:disabled), [tabindex]:not([tabindex='-1']), a[href]")??[]),[toolbarRef]),updateTabIndices=useCallback(activeIndex=>{getFocusableElements().forEach((el,i)=>{el.setAttribute("tabindex",i===activeIndex?"0":"-1")})},[getFocusableElements]),currentIndex=focusedIndex??0;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 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)}}};
|
package/package.json
CHANGED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { RefObject } from "react";
|
|
2
|
-
type UseToolbarFocusOptions = {
|
|
3
|
-
toolbarRef: RefObject<HTMLElement>;
|
|
4
|
-
};
|
|
5
|
-
export declare const useToolbarFocus: ({ toolbarRef, }: UseToolbarFocusOptions) => {
|
|
6
|
-
onBlur: (e: React.FocusEvent) => void;
|
|
7
|
-
onFocus: (e: React.FocusEvent) => void;
|
|
8
|
-
};
|
|
9
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"useToolbarFocus",{enumerable:!0,get:function(){return useToolbarFocus}});const _react=require("react"),_useKeyboard=require("../../shared/useKeyboard"),useToolbarFocus=({toolbarRef})=>{let[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),{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,9 +0,0 @@
|
|
|
1
|
-
import type { RefObject } from "react";
|
|
2
|
-
type UseToolbarFocusOptions = {
|
|
3
|
-
toolbarRef: RefObject<HTMLElement>;
|
|
4
|
-
};
|
|
5
|
-
export declare const useToolbarFocus: ({ toolbarRef, }: UseToolbarFocusOptions) => {
|
|
6
|
-
onBlur: (e: React.FocusEvent) => void;
|
|
7
|
-
onFocus: (e: React.FocusEvent) => void;
|
|
8
|
-
};
|
|
9
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{useCallback,useEffect,useState}from"react";import{useKeyboard}from"../../shared/useKeyboard";export const useToolbarFocus=({toolbarRef})=>{let[focusedIndex,setFocusedIndex]=useState(null),getFocusableElements=useCallback(()=>Array.from(toolbarRef.current?.querySelectorAll("button:not(:disabled), [tabindex]:not([tabindex='-1']), a[href]")??[]),[toolbarRef]),updateTabIndices=useCallback(activeIndex=>{getFocusableElements().forEach((el,i)=>{el.setAttribute("tabindex",i===activeIndex?"0":"-1")})},[getFocusableElements]),currentIndex=focusedIndex??0;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 useKeyboard({ArrowRight:()=>focusAt(currentIndex+1),ArrowLeft:()=>focusAt(currentIndex-1),Home:()=>focusAt(0),End:()=>focusAt(-1)},toolbarRef,!0),{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)}}};
|