@amboss/design-system 3.37.0 → 3.37.2

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.
@@ -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,7 @@
1
+ import type { RefObject } from "react";
2
+ export declare const useBulkActionsToolbar: () => {
3
+ toolbarId: string;
4
+ toolbarRef: RefObject<HTMLDivElement>;
5
+ onBlur: (e: React.FocusEvent) => void;
6
+ onFocus: (e: React.FocusEvent) => void;
7
+ };
@@ -0,0 +1 @@
1
+ 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)}}};
@@ -6,6 +6,11 @@ export type LightboxProps = React.HTMLAttributes<HTMLDivElement> & {
6
6
  backdropRef?: RefObject<HTMLDivElement>;
7
7
  handleClose?: () => void;
8
8
  isDismissible?: boolean;
9
+ /**
10
+ * A ref to the element that should receive focus when the lightbox opens.
11
+ * When not provided, the first focusable element inside the lightbox is used.
12
+ */
13
+ initialFocus?: RefObject<HTMLElement | SVGElement> | string;
9
14
  justifyContent?: MQ<LightboxVerticalAlignment> | LightboxVerticalAlignment;
10
15
  privateProps?: {
11
16
  skipPortal?: boolean;
@@ -27,4 +32,4 @@ export declare const StyledChildrenWrapper: import("@emotion/styled").StyledComp
27
32
  theme?: import("@emotion/react").Theme;
28
33
  as?: React.ElementType;
29
34
  }, React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
30
- export declare function Lightbox({ backdropRef, portalContainer, isDismissible, children, handleClose, justifyContent, privateProps: { skipPortal, tabbableOptions }, }: PropsWithChildren<LightboxProps>): React.ReactElement;
35
+ export declare function Lightbox({ backdropRef, portalContainer, initialFocus, isDismissible, children, handleClose, justifyContent, privateProps: { skipPortal, tabbableOptions }, }: PropsWithChildren<LightboxProps>): React.ReactElement;
@@ -1,8 +1,8 @@
1
- import React,{useCallback,useRef}from"react";import styled from"@emotion/styled";import{keyframes}from"@emotion/react";import{Portal,usePortalContainerElement}from"../Portal/Portal";import{FocusTrapWrapper}from"../../shared/FocusTrapWrapper";import{useResponsiveStyles}from"../../shared/mediaQueries";import{DialogContext}from"../Patterns/Dialog/DialogContext";export const StyledBackdrop=styled("div",{target:"e79ud7r0",label:"StyledBackdrop"})(({theme,justifyContent})=>{let fadeInBackdrop=keyframes`
1
+ import React,{useCallback,useRef}from"react";import styled from"@emotion/styled";import{keyframes}from"@emotion/react";import{Portal,usePortalContainerElement}from"../Portal/Portal";import{FocusTrapWrapper}from"../../shared/FocusTrapWrapper";import{useResponsiveStyles}from"../../shared/mediaQueries";import{DialogContext}from"../Patterns/Dialog/DialogContext";export const StyledBackdrop=styled("div",{target:"e1v68oqn0",label:"StyledBackdrop"})(({theme,justifyContent})=>{let fadeInBackdrop=keyframes`
2
2
  from {
3
3
  opacity: ${theme.variables.opacity.hidden};
4
4
  }
5
5
  to {
6
6
  opacity: ${theme.variables.opacity.visible};
7
7
  }
8
- `;return{position:"fixed",top:0,left:0,zIndex:theme.variables.zIndex.modal,width:"100%",height:"100dvh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",...useResponsiveStyles({justifyContent:[justifyContent,{top:"flex-start",center:"center"}]}),alignItems:"center",flex:"1 0 auto",animation:`${fadeInBackdrop} ${theme.variables.animation.modalBackdrop.open.duration} ${theme.variables.animation.modalBackdrop.open.timingFunction} both`}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAganVzdGlmeUNvbnRlbnQ/OiBNUTxMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50PiB8IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQ7XG4gIHByaXZhdGVQcm9wcz86IHtcbiAgICBza2lwUG9ydGFsPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBAaW50ZXJuYWxcbiAgICAgKiBPcHRpb25zIHBhc3NlZCB0byBmb2N1cy10cmFwJ3MgdGFiYmFibGUgZGV0ZWN0aW9uLlxuICAgICAqIFVzZSBgeyBkaXNwbGF5Q2hlY2s6IFwibm9uZVwiIH1gIGZvciB0ZXN0aW5nIHRvIGF2b2lkIEpTRE9NIHZpc2liaWxpdHkgaXNzdWVzLlxuICAgICAqL1xuICAgIHRhYmJhYmxlT3B0aW9ucz86IHtcbiAgICAgIGRpc3BsYXlDaGVjaz86IFwiZnVsbFwiIHwgXCJsZWdhY3ktZnVsbFwiIHwgXCJub24temVyby1hcmVhXCIgfCBcIm5vbmVcIjtcbiAgICB9O1xuICB9O1xufSAmIFBpY2s8UG9ydGFsUHJvcHMsIFwicG9ydGFsQ29udGFpbmVyXCI+O1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQmFja2Ryb3AgPSBzdHlsZWQuZGl2PFBpY2s8TGlnaHRib3hQcm9wcywgXCJqdXN0aWZ5Q29udGVudFwiPj4oXG4gICh7IHRoZW1lLCBqdXN0aWZ5Q29udGVudCB9KSA9PiB7XG4gICAgY29uc3QgZmFkZUluQmFja2Ryb3AgPSBrZXlmcmFtZXNgXG4gICAgZnJvbSB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmhpZGRlbn07XG4gICAgfVxuICAgIHRvIHtcbiAgICAgIG9wYWNpdHk6ICR7dGhlbWUudmFyaWFibGVzLm9wYWNpdHkudmlzaWJsZX07XG4gICAgfVxuICBgO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHBvc2l0aW9uOiBcImZpeGVkXCIsXG4gICAgICB0b3A6IDAsXG4gICAgICBsZWZ0OiAwLFxuICAgICAgekluZGV4OiB0aGVtZS52YXJpYWJsZXMuekluZGV4Lm1vZGFsLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgaGVpZ2h0OiBcIjEwMGR2aFwiLFxuICAgICAgYmFja2dyb3VuZDogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuYmFja2Ryb3AuZGVmYXVsdCxcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICAgIC4uLnVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICAgIGp1c3RpZnlDb250ZW50LFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH0pLFxuICAgICAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAgICAgIGZsZXg6IFwiMSAwIGF1dG9cIixcbiAgICAgIGFuaW1hdGlvbjogYCR7ZmFkZUluQmFja2Ryb3B9ICR7dGhlbWUudmFyaWFibGVzLmFuaW1hdGlvbi5tb2RhbEJhY2tkcm9wLm9wZW4uZHVyYXRpb259ICR7dGhlbWUudmFyaWFibGVzLmFuaW1hdGlvbi5tb2RhbEJhY2tkcm9wLm9wZW4udGltaW5nRnVuY3Rpb259IGJvdGhgLFxuICAgIH07XG4gIH1cbik7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRDaGlsZHJlbldyYXBwZXIgPSBzdHlsZWQuZGl2KHtcbiAgZGlzcGxheTogXCJjb250ZW50c1wiLFxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBMaWdodGJveCh7XG4gIGJhY2tkcm9wUmVmLFxuICBwb3J0YWxDb250YWluZXIsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICBmYWxsYmFja0ZvY3VzOiAoKSA9PiBnZXRGb2N1c1RhcmdldCgpLFxuICAgICAgICAgIC4uLih0YWJiYWJsZU9wdGlvbnMgJiYgeyB0YWJiYWJsZU9wdGlvbnMgfSksXG4gICAgICAgICAgLi4uKGhhbmRsZUNsb3NlICYmIHsgb25Qb3N0RGVhY3RpdmF0ZTogaGFuZGxlQ2xvc2UgfSksXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRDaGlsZHJlbldyYXBwZXIgcmVmPXttb2RhbFJlZn0+XG4gICAgICAgICAgPERpYWxvZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU+e2NoaWxkcmVufTwvRGlhbG9nQ29udGV4dC5Qcm92aWRlcj5cbiAgICAgICAgPC9TdHlsZWRDaGlsZHJlbldyYXBwZXI+XG4gICAgICA8L0ZvY3VzVHJhcFdyYXBwZXI+XG4gICAgPC9TdHlsZWRCYWNrZHJvcD5cbiAgKTtcblxuICAvLyBGb3IgdGVzdGluZyBhbmQgTW9kYWwgc3Rvcnkgd2UgZG9uJ3Qgd2FudCB0byByZW5kZXIgdGhlIGNvbnRlbnQgaW5zaWRlIGEgcG9ydGFsXG4gIGlmIChza2lwUG9ydGFsKSB7XG4gICAgcmV0dXJuIGNvbnRlbnQ7XG4gIH1cblxuICByZXR1cm4gPFBvcnRhbCBwb3J0YWxDb250YWluZXI9e3BvcnRhbENvbnRhaW5lcn0+e2NvbnRlbnR9PC9Qb3J0YWw+O1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNDOEIifQ== */");export const StyledChildrenWrapper=styled("div",{target:"e79ud7r1",label:"StyledChildrenWrapper"})({display:"contents"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAganVzdGlmeUNvbnRlbnQ/OiBNUTxMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50PiB8IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQ7XG4gIHByaXZhdGVQcm9wcz86IHtcbiAgICBza2lwUG9ydGFsPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBAaW50ZXJuYWxcbiAgICAgKiBPcHRpb25zIHBhc3NlZCB0byBmb2N1cy10cmFwJ3MgdGFiYmFibGUgZGV0ZWN0aW9uLlxuICAgICAqIFVzZSBgeyBkaXNwbGF5Q2hlY2s6IFwibm9uZVwiIH1gIGZvciB0ZXN0aW5nIHRvIGF2b2lkIEpTRE9NIHZpc2liaWxpdHkgaXNzdWVzLlxuICAgICAqL1xuICAgIHRhYmJhYmxlT3B0aW9ucz86IHtcbiAgICAgIGRpc3BsYXlDaGVjaz86IFwiZnVsbFwiIHwgXCJsZWdhY3ktZnVsbFwiIHwgXCJub24temVyby1hcmVhXCIgfCBcIm5vbmVcIjtcbiAgICB9O1xuICB9O1xufSAmIFBpY2s8UG9ydGFsUHJvcHMsIFwicG9ydGFsQ29udGFpbmVyXCI+O1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQmFja2Ryb3AgPSBzdHlsZWQuZGl2PFBpY2s8TGlnaHRib3hQcm9wcywgXCJqdXN0aWZ5Q29udGVudFwiPj4oXG4gICh7IHRoZW1lLCBqdXN0aWZ5Q29udGVudCB9KSA9PiB7XG4gICAgY29uc3QgZmFkZUluQmFja2Ryb3AgPSBrZXlmcmFtZXNgXG4gICAgZnJvbSB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmhpZGRlbn07XG4gICAgfVxuICAgIHRvIHtcbiAgICAgIG9wYWNpdHk6ICR7dGhlbWUudmFyaWFibGVzLm9wYWNpdHkudmlzaWJsZX07XG4gICAgfVxuICBgO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHBvc2l0aW9uOiBcImZpeGVkXCIsXG4gICAgICB0b3A6IDAsXG4gICAgICBsZWZ0OiAwLFxuICAgICAgekluZGV4OiB0aGVtZS52YXJpYWJsZXMuekluZGV4Lm1vZGFsLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgaGVpZ2h0OiBcIjEwMGR2aFwiLFxuICAgICAgYmFja2dyb3VuZDogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuYmFja2Ryb3AuZGVmYXVsdCxcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICAgIC4uLnVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICAgIGp1c3RpZnlDb250ZW50LFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH0pLFxuICAgICAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAgICAgIGZsZXg6IFwiMSAwIGF1dG9cIixcbiAgICAgIGFuaW1hdGlvbjogYCR7ZmFkZUluQmFja2Ryb3B9ICR7dGhlbWUudmFyaWFibGVzLmFuaW1hdGlvbi5tb2RhbEJhY2tkcm9wLm9wZW4uZHVyYXRpb259ICR7dGhlbWUudmFyaWFibGVzLmFuaW1hdGlvbi5tb2RhbEJhY2tkcm9wLm9wZW4udGltaW5nRnVuY3Rpb259IGJvdGhgLFxuICAgIH07XG4gIH1cbik7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRDaGlsZHJlbldyYXBwZXIgPSBzdHlsZWQuZGl2KHtcbiAgZGlzcGxheTogXCJjb250ZW50c1wiLFxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBMaWdodGJveCh7XG4gIGJhY2tkcm9wUmVmLFxuICBwb3J0YWxDb250YWluZXIsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICBmYWxsYmFja0ZvY3VzOiAoKSA9PiBnZXRGb2N1c1RhcmdldCgpLFxuICAgICAgICAgIC4uLih0YWJiYWJsZU9wdGlvbnMgJiYgeyB0YWJiYWJsZU9wdGlvbnMgfSksXG4gICAgICAgICAgLi4uKGhhbmRsZUNsb3NlICYmIHsgb25Qb3N0RGVhY3RpdmF0ZTogaGFuZGxlQ2xvc2UgfSksXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRDaGlsZHJlbldyYXBwZXIgcmVmPXttb2RhbFJlZn0+XG4gICAgICAgICAgPERpYWxvZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU+e2NoaWxkcmVufTwvRGlhbG9nQ29udGV4dC5Qcm92aWRlcj5cbiAgICAgICAgPC9TdHlsZWRDaGlsZHJlbldyYXBwZXI+XG4gICAgICA8L0ZvY3VzVHJhcFdyYXBwZXI+XG4gICAgPC9TdHlsZWRCYWNrZHJvcD5cbiAgKTtcblxuICAvLyBGb3IgdGVzdGluZyBhbmQgTW9kYWwgc3Rvcnkgd2UgZG9uJ3Qgd2FudCB0byByZW5kZXIgdGhlIGNvbnRlbnQgaW5zaWRlIGEgcG9ydGFsXG4gIGlmIChza2lwUG9ydGFsKSB7XG4gICAgcmV0dXJuIGNvbnRlbnQ7XG4gIH1cblxuICByZXR1cm4gPFBvcnRhbCBwb3J0YWxDb250YWluZXI9e3BvcnRhbENvbnRhaW5lcn0+e2NvbnRlbnR9PC9Qb3J0YWw+O1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJFcUMifQ== */");export function Lightbox({backdropRef,portalContainer,isDismissible=!0,children,handleClose,justifyContent="center",privateProps:{skipPortal,tabbableOptions}={skipPortal:!1}}){let portalContainerElement=usePortalContainerElement(portalContainer),modalRef=useRef(null),handleClickOutsideDeactivates=useCallback(evt=>(!portalContainerElement.contains(evt.target)||evt.target===backdropRef?.current)&&isDismissible,[backdropRef,portalContainerElement,isDismissible]),getFocusTarget=()=>{let container=modalRef?.current?.firstElementChild,firstFocusable=container?.querySelector('a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])');return firstFocusable||container||document.body},content=React.createElement(StyledBackdrop,{ref:backdropRef,justifyContent:justifyContent,"data-ds-id":"Lightbox"},React.createElement(FocusTrapWrapper,{active:!0,focusTrapOptions:{allowOutsideClick:!0,clickOutsideDeactivates:handleClickOutsideDeactivates,escapeDeactivates:isDismissible,preventScroll:!0,initialFocus:()=>getFocusTarget(),fallbackFocus:()=>getFocusTarget(),...tabbableOptions&&{tabbableOptions},...handleClose&&{onPostDeactivate:handleClose}}},React.createElement(StyledChildrenWrapper,{ref:modalRef},React.createElement(DialogContext.Provider,{value:!0},children))));return skipPortal?content:React.createElement(Portal,{portalContainer:portalContainer},content)}
8
+ `;return{position:"fixed",top:0,left:0,zIndex:theme.variables.zIndex.modal,width:"100%",height:"100dvh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",...useResponsiveStyles({justifyContent:[justifyContent,{top:"flex-start",center:"center"}]}),alignItems:"center",flex:"1 0 auto",animation:`${fadeInBackdrop} ${theme.variables.animation.modalBackdrop.open.duration} ${theme.variables.animation.modalBackdrop.open.timingFunction} both`}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PlxuICAgICAgICAgIDxEaWFsb2dDb250ZXh0LlByb3ZpZGVyIHZhbHVlPntjaGlsZHJlbn08L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICAgICAgIDwvU3R5bGVkQ2hpbGRyZW5XcmFwcGVyPlxuICAgICAgPC9Gb2N1c1RyYXBXcmFwcGVyPlxuICAgIDwvU3R5bGVkQmFja2Ryb3A+XG4gICk7XG5cbiAgLy8gRm9yIHRlc3RpbmcgYW5kIE1vZGFsIHN0b3J5IHdlIGRvbid0IHdhbnQgdG8gcmVuZGVyIHRoZSBjb250ZW50IGluc2lkZSBhIHBvcnRhbFxuICBpZiAoc2tpcFBvcnRhbCkge1xuICAgIHJldHVybiBjb250ZW50O1xuICB9XG5cbiAgcmV0dXJuIDxQb3J0YWwgcG9ydGFsQ29udGFpbmVyPXtwb3J0YWxDb250YWluZXJ9Pntjb250ZW50fTwvUG9ydGFsPjtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQzhCIn0= */");export const StyledChildrenWrapper=styled("div",{target:"e1v68oqn1",label:"StyledChildrenWrapper"})({display:"contents"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PlxuICAgICAgICAgIDxEaWFsb2dDb250ZXh0LlByb3ZpZGVyIHZhbHVlPntjaGlsZHJlbn08L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICAgICAgIDwvU3R5bGVkQ2hpbGRyZW5XcmFwcGVyPlxuICAgICAgPC9Gb2N1c1RyYXBXcmFwcGVyPlxuICAgIDwvU3R5bGVkQmFja2Ryb3A+XG4gICk7XG5cbiAgLy8gRm9yIHRlc3RpbmcgYW5kIE1vZGFsIHN0b3J5IHdlIGRvbid0IHdhbnQgdG8gcmVuZGVyIHRoZSBjb250ZW50IGluc2lkZSBhIHBvcnRhbFxuICBpZiAoc2tpcFBvcnRhbCkge1xuICAgIHJldHVybiBjb250ZW50O1xuICB9XG5cbiAgcmV0dXJuIDxQb3J0YWwgcG9ydGFsQ29udGFpbmVyPXtwb3J0YWxDb250YWluZXJ9Pntjb250ZW50fTwvUG9ydGFsPjtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRnFDIn0= */");export function Lightbox({backdropRef,portalContainer,initialFocus,isDismissible=!0,children,handleClose,justifyContent="center",privateProps:{skipPortal,tabbableOptions}={skipPortal:!1}}){let portalContainerElement=usePortalContainerElement(portalContainer),modalRef=useRef(null),handleClickOutsideDeactivates=useCallback(evt=>(!portalContainerElement.contains(evt.target)||evt.target===backdropRef?.current)&&isDismissible,[backdropRef,portalContainerElement,isDismissible]),getFocusTarget=()=>{let container=modalRef?.current?.firstElementChild,firstFocusable=container?.querySelector('a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])');return firstFocusable||container||document.body},getInitialFocus=()=>"string"==typeof initialFocus?initialFocus:initialFocus?.current??getFocusTarget(),content=React.createElement(StyledBackdrop,{ref:backdropRef,justifyContent:justifyContent,"data-ds-id":"Lightbox"},React.createElement(FocusTrapWrapper,{active:!0,focusTrapOptions:{allowOutsideClick:!0,clickOutsideDeactivates:handleClickOutsideDeactivates,escapeDeactivates:isDismissible,preventScroll:!0,initialFocus:()=>getInitialFocus(),fallbackFocus:()=>getFocusTarget(),...tabbableOptions&&{tabbableOptions},...handleClose&&{onPostDeactivate:handleClose}}},React.createElement(StyledChildrenWrapper,{ref:modalRef},React.createElement(DialogContext.Provider,{value:!0},children))));return skipPortal?content:React.createElement(Portal,{portalContainer:portalContainer},content)}
@@ -1,8 +1,9 @@
1
- import React from "react";
1
+ import React, { type RefObject } from "react";
2
2
  import type { MQ, SpaceSizes, ButtonSize } from "../../../types";
3
3
  import type { ButtonProps } from "../../Button/Button";
4
4
  export type ButtonGroupButtonProps = {
5
5
  text: string;
6
+ ref?: RefObject<HTMLButtonElement>;
6
7
  } & ButtonProps;
7
8
  export type ButtonGroupProps = {
8
9
  /** Text and other props for action Button */