@amboss/design-system 3.20.0 → 3.20.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.
Files changed (37) hide show
  1. package/build/cjs/components/EntityList/BaseEntityList.js +1 -1
  2. package/build/cjs/components/EntityList/EntityItemBody.js +1 -1
  3. package/build/cjs/components/EntityList/EntityListItem.js +1 -1
  4. package/build/cjs/components/EntityList/styled-components.js +1 -1
  5. package/build/cjs/components/EntityList/types.d.ts +2 -1
  6. package/build/cjs/components/EntityList/useFocusByIndex.d.ts +17 -0
  7. package/build/cjs/components/EntityList/useFocusByIndex.js +1 -0
  8. package/build/cjs/components/EntityTree/BaseEntityTree.js +1 -1
  9. package/build/cjs/components/EntityTree/EntityTreeItem.d.ts +1 -1
  10. package/build/cjs/components/EntityTree/EntityTreeItem.js +1 -1
  11. package/build/cjs/components/Tabs/Tabs.d.ts +1 -1
  12. package/build/cjs/components/Tabs/Tabs.js +1 -1
  13. package/build/cjs/shared/mixins/getFocusStyles.d.ts +6 -0
  14. package/build/cjs/shared/mixins/getFocusStyles.js +1 -0
  15. package/build/cjs/shared/mixins/index.d.ts +1 -1
  16. package/build/cjs/shared/mixins/index.js +1 -1
  17. package/build/esm/components/EntityList/BaseEntityList.js +1 -1
  18. package/build/esm/components/EntityList/EntityItemBody.js +1 -1
  19. package/build/esm/components/EntityList/EntityListItem.js +1 -1
  20. package/build/esm/components/EntityList/styled-components.js +1 -1
  21. package/build/esm/components/EntityList/types.d.ts +2 -1
  22. package/build/esm/components/EntityList/useFocusByIndex.d.ts +17 -0
  23. package/build/esm/components/EntityList/useFocusByIndex.js +1 -0
  24. package/build/esm/components/EntityTree/BaseEntityTree.js +1 -1
  25. package/build/esm/components/EntityTree/EntityTreeItem.d.ts +1 -1
  26. package/build/esm/components/EntityTree/EntityTreeItem.js +1 -1
  27. package/build/esm/components/Tabs/Tabs.d.ts +1 -1
  28. package/build/esm/components/Tabs/Tabs.js +1 -1
  29. package/build/esm/shared/mixins/getFocusStyles.d.ts +6 -0
  30. package/build/esm/shared/mixins/getFocusStyles.js +1 -0
  31. package/build/esm/shared/mixins/index.d.ts +1 -1
  32. package/build/esm/shared/mixins/index.js +1 -1
  33. package/package.json +1 -1
  34. package/build/cjs/shared/mixins/Button/getFocusStyles.d.ts +0 -2
  35. package/build/cjs/shared/mixins/Button/getFocusStyles.js +0 -1
  36. package/build/esm/shared/mixins/Button/getFocusStyles.d.ts +0 -2
  37. package/build/esm/shared/mixins/Button/getFocusStyles.js +0 -1
@@ -1 +1 @@
1
- import React,{useRef,useState,useEffect,useMemo,useCallback}from"react";import styled from"@emotion/styled";import{StyledList}from"./styled-components";import{useKeyboard}from"../../shared/useKeyboard";import{Icon}from"../Icon/Icon";import{EntityListItem}from"./EntityListItem";import{VirtualizedEntityList}from"./VirtualizedEntityList";let StyledMinHeightCell=styled("div",{target:"e1la67bo0",label:"StyledMinHeightCell"})(({theme,textSize})=>({minHeight:"s"===textSize?`calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`:theme.variables.size.spacing.l,display:"flex",alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/EntityList/BaseEntityList.tsx","sources":["src/components/EntityList/BaseEntityList.tsx"],"sourcesContent":["import React, {\n  useRef,\n  useState,\n  useEffect,\n  useMemo,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { StyledList } from \"./styled-components\";\nimport type { EntityListProps, ListNode, TextSizeProps } from \"./types\";\nimport { useKeyboard } from \"../../shared/useKeyboard\";\nimport { Icon } from \"../Icon/Icon\";\nimport { EntityListItem } from \"./EntityListItem\";\nimport { VirtualizedEntityList } from \"./VirtualizedEntityList\";\n\n// This minHeight is needed for align small icons in the middle of 1 row text,\n// but it should stay at the top if there is multiline text\nconst StyledMinHeightCell = styled.div<TextSizeProps>(\n  ({ theme, textSize }) => ({\n    minHeight:\n      textSize === \"s\"\n        ? `calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`\n        : theme.variables.size.spacing.l,\n    display: \"flex\",\n    alignItems: \"center\",\n  })\n);\n\nconst findEnabledItemIndex = (\n  items: ListNode[],\n  startIndex: number,\n  direction = \"next\"\n): number => {\n  if (direction === \"next\") {\n    for (let i = startIndex + 1; i < items.length; i += 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  } else if (direction === \"previous\") {\n    for (let i = startIndex - 1; i >= 0; i -= 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  }\n  return startIndex;\n};\n\nexport function BaseEntityList({\n  data,\n  size = \"m\",\n  onClick,\n  isSelectable,\n  selectedIds,\n  onSelectionChange,\n  onSelectionToggle,\n  renderRightContent,\n  getLeftIconProps,\n  hideBorder,\n  filterFn,\n  isVirtualized,\n  maxHeight,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: EntityListProps): React.ReactElement {\n  const dataShown = useMemo(() => {\n    if (!data.length) return data;\n\n    return filterFn ? data.filter(filterFn) : data;\n  }, [data, filterFn]);\n\n  const selectedIdsSet = useMemo(() => new Set(selectedIds), [selectedIds]);\n\n  const [isKeyboardFocus, setIsKeyboardFocus] = useState<boolean>(false);\n  const [selectedIndex, setSelectedIndex] = useState<number>(() =>\n    isSelectable || onClick ? findEnabledItemIndex(dataShown, -1) : -1\n  );\n  const refList = useRef<HTMLUListElement>(null);\n  useKeyboard(\n    {\n      ArrowDown: () => {\n        setIsKeyboardFocus(true);\n        const nextIndex = findEnabledItemIndex(dataShown, selectedIndex);\n        setSelectedIndex(nextIndex);\n      },\n      ArrowUp: () => {\n        setIsKeyboardFocus(true);\n        const prevIndex = findEnabledItemIndex(\n          dataShown,\n          selectedIndex,\n          \"previous\"\n        );\n        setSelectedIndex(prevIndex);\n      },\n    },\n    refList,\n    selectedIndex !== -1\n  );\n\n  useEffect(() => {\n    if (refList && refList.current && isKeyboardFocus && selectedIndex >= 0) {\n      const buttons = refList.current.querySelectorAll(\n        'div[data-id=\"list-item\"]'\n      );\n\n      (buttons[Math.abs(selectedIndex) % buttons.length] as HTMLElement).focus({\n        preventScroll: true,\n      });\n    }\n  }, [selectedIndex, isKeyboardFocus]);\n\n  const handleOnClick = useCallback(\n    (item: ListNode) => {\n      const { id } = item;\n\n      if (isSelectable) {\n        const willBeSelected = !selectedIdsSet.has(id);\n        const newSelectedIdsSet = new Set(selectedIdsSet);\n\n        if (willBeSelected) {\n          newSelectedIdsSet.add(id);\n        } else {\n          newSelectedIdsSet.delete(id);\n        }\n\n        onSelectionToggle?.(id, willBeSelected);\n        onSelectionChange?.(Array.from(newSelectedIdsSet));\n      }\n\n      onClick?.(item);\n    },\n    [\n      selectedIdsSet,\n      onSelectionChange,\n      onSelectionToggle,\n      onClick,\n      isSelectable,\n    ]\n  );\n\n  const handleBlur = useCallback(() => {\n    // Use setTimeout to wait for focus to fully propagate\n    setTimeout(() => {\n      if (\n        refList.current &&\n        !refList.current.contains(document.activeElement)\n      ) {\n        setIsKeyboardFocus(false);\n        setSelectedIndex(() => findEnabledItemIndex(dataShown, -1));\n      }\n    }, 0);\n  }, [refList, setSelectedIndex, dataShown]);\n\n  const renderEntityItem = (index: number): React.ReactNode => {\n    const item = dataShown[index];\n    if (!item) return null;\n\n    const isLastItem = index === dataShown.length - 1;\n    const tabIndex = !item.isDisabled && index === selectedIndex ? 0 : -1;\n    const isSelected = selectedIdsSet.has(item.id);\n\n    return (\n      <EntityListItem\n        key={item.id}\n        aria-label={item[\"aria-label\"] || item.label}\n        size={size}\n        hideBorder={hideBorder || isLastItem}\n        isActive={item.isActive || (isKeyboardFocus && selectedIndex === index)}\n        isDisabled={item.isDisabled}\n        isClickable={Boolean(onClick || selectedIds)}\n        description={item.description}\n        onKeyDown={() => handleOnClick(item)}\n        tabIndex={tabIndex}\n        onFocus={() => {\n          if (onClick || isSelectable) {\n            setSelectedIndex(index);\n            setIsKeyboardFocus(true);\n          }\n        }}\n        onClick={(e) => {\n          const isInsideLabel = (e.target as HTMLElement).closest(\"label\");\n          if (!isInsideLabel) {\n            handleOnClick(item);\n          }\n        }}\n        checkboxProps={\n          isSelectable && {\n            name: \"list-checkbox\",\n            size: \"s\",\n            checked: isSelected,\n            onChange: () => handleOnClick(item),\n          }\n        }\n        renderLabel={() => item.label}\n        renderLeft={\n          getLeftIconProps\n            ? ({ textSize }) => (\n                <Icon {...getLeftIconProps(item)} size={textSize} />\n              )\n            : null\n        }\n        renderRight={({ actionSize, textSize }) =>\n          renderRightContent ? (\n            <StyledMinHeightCell textSize={textSize}>\n              {renderRightContent({ textSize, actionSize, ...item })}\n            </StyledMinHeightCell>\n          ) : null\n        }\n      />\n    );\n  };\n\n  return isVirtualized && maxHeight ? (\n    <VirtualizedEntityList\n      id={dataE2eTestId}\n      maxHeight={maxHeight}\n      size={size}\n      dataShown={dataShown}\n      selectedIndex={selectedIndex}\n      itemTemplate={renderEntityItem}\n      data-e2e-test-id={dataE2eTestId}\n    />\n  ) : (\n    <StyledList\n      ref={refList}\n      size={size}\n      data-e2e-test-id={dataE2eTestId}\n      onBlur={handleBlur}\n      data-ds-id=\"EntityList\"\n      role=\"list\"\n    >\n      {dataShown.map((_item, i) => renderEntityItem(i))}\n    </StyledList>\n  );\n}\n"],"names":[],"mappings":"AAiB4B"} */"),findEnabledItemIndex=(items,startIndex,direction="next")=>{if("next"===direction){for(let i=startIndex+1;i<items.length;i+=1)if(!items[i].isDisabled)return i}else if("previous"===direction){for(let i=startIndex-1;i>=0;i-=1)if(!items[i].isDisabled)return i}return startIndex};export function BaseEntityList({data,size="m",onClick,isSelectable,selectedIds,onSelectionChange,onSelectionToggle,renderRightContent,getLeftIconProps,hideBorder,filterFn,isVirtualized,maxHeight,"data-e2e-test-id":dataE2eTestId}){let dataShown=useMemo(()=>data.length&&filterFn?data.filter(filterFn):data,[data,filterFn]),selectedIdsSet=useMemo(()=>new Set(selectedIds),[selectedIds]),[isKeyboardFocus,setIsKeyboardFocus]=useState(!1),[selectedIndex,setSelectedIndex]=useState(()=>isSelectable||onClick?findEnabledItemIndex(dataShown,-1):-1),refList=useRef(null);useKeyboard({ArrowDown:()=>{setIsKeyboardFocus(!0),setSelectedIndex(findEnabledItemIndex(dataShown,selectedIndex))},ArrowUp:()=>{setIsKeyboardFocus(!0),setSelectedIndex(findEnabledItemIndex(dataShown,selectedIndex,"previous"))}},refList,-1!==selectedIndex),useEffect(()=>{if(refList&&refList.current&&isKeyboardFocus&&selectedIndex>=0){let buttons=refList.current.querySelectorAll('div[data-id="list-item"]');buttons[Math.abs(selectedIndex)%buttons.length].focus({preventScroll:!0})}},[selectedIndex,isKeyboardFocus]);let handleOnClick=useCallback(item=>{let{id}=item;if(isSelectable){let willBeSelected=!selectedIdsSet.has(id),newSelectedIdsSet=new Set(selectedIdsSet);willBeSelected?newSelectedIdsSet.add(id):newSelectedIdsSet.delete(id),onSelectionToggle?.(id,willBeSelected),onSelectionChange?.(Array.from(newSelectedIdsSet))}onClick?.(item)},[selectedIdsSet,onSelectionChange,onSelectionToggle,onClick,isSelectable]),handleBlur=useCallback(()=>{setTimeout(()=>{refList.current&&!refList.current.contains(document.activeElement)&&(setIsKeyboardFocus(!1),setSelectedIndex(()=>findEnabledItemIndex(dataShown,-1)))},0)},[refList,setSelectedIndex,dataShown]),renderEntityItem=index=>{let item=dataShown[index];if(!item)return null;let isLastItem=index===dataShown.length-1,tabIndex=item.isDisabled||index!==selectedIndex?-1:0,isSelected=selectedIdsSet.has(item.id);return React.createElement(EntityListItem,{key:item.id,"aria-label":item["aria-label"]||item.label,size:size,hideBorder:hideBorder||isLastItem,isActive:item.isActive||isKeyboardFocus&&selectedIndex===index,isDisabled:item.isDisabled,isClickable:!!(onClick||selectedIds),description:item.description,onKeyDown:()=>handleOnClick(item),tabIndex:tabIndex,onFocus:()=>{(onClick||isSelectable)&&(setSelectedIndex(index),setIsKeyboardFocus(!0))},onClick:e=>{e.target.closest("label")||handleOnClick(item)},checkboxProps:isSelectable&&{name:"list-checkbox",size:"s",checked:isSelected,onChange:()=>handleOnClick(item)},renderLabel:()=>item.label,renderLeft:getLeftIconProps?({textSize})=>React.createElement(Icon,{...getLeftIconProps(item),size:textSize}):null,renderRight:({actionSize,textSize})=>renderRightContent?React.createElement(StyledMinHeightCell,{textSize:textSize},renderRightContent({textSize,actionSize,...item})):null})};return isVirtualized&&maxHeight?React.createElement(VirtualizedEntityList,{id:dataE2eTestId,maxHeight:maxHeight,size:size,dataShown:dataShown,selectedIndex:selectedIndex,itemTemplate:renderEntityItem,"data-e2e-test-id":dataE2eTestId}):React.createElement(StyledList,{ref:refList,size:size,"data-e2e-test-id":dataE2eTestId,onBlur:handleBlur,"data-ds-id":"EntityList",role:"list"},dataShown.map((_item,i)=>renderEntityItem(i)))}
1
+ import React,{useRef,useMemo,useCallback}from"react";import styled from"@emotion/styled";import{StyledList}from"./styled-components";import{useKeyboard}from"../../shared/useKeyboard";import{Icon}from"../Icon/Icon";import{EntityListItem}from"./EntityListItem";import{VirtualizedEntityList}from"./VirtualizedEntityList";import{useFocusByIndex}from"./useFocusByIndex";let StyledMinHeightCell=styled("div",{target:"euhhpf20",label:"StyledMinHeightCell"})(({theme,textSize})=>({minHeight:"s"===textSize?`calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`:theme.variables.size.spacing.l,display:"flex",alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9CYXNlRW50aXR5TGlzdC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eUxpc3QvQmFzZUVudGl0eUxpc3QudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VSZWYsIHVzZU1lbW8sIHVzZUNhbGxiYWNrIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IFN0eWxlZExpc3QgfSBmcm9tIFwiLi9zdHlsZWQtY29tcG9uZW50c1wiO1xuaW1wb3J0IHR5cGUgeyBFbnRpdHlMaXN0UHJvcHMsIExpc3ROb2RlLCBUZXh0U2l6ZVByb3BzIH0gZnJvbSBcIi4vdHlwZXNcIjtcbmltcG9ydCB7IHVzZUtleWJvYXJkIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC91c2VLZXlib2FyZFwiO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IEVudGl0eUxpc3RJdGVtIH0gZnJvbSBcIi4vRW50aXR5TGlzdEl0ZW1cIjtcbmltcG9ydCB7IFZpcnR1YWxpemVkRW50aXR5TGlzdCB9IGZyb20gXCIuL1ZpcnR1YWxpemVkRW50aXR5TGlzdFwiO1xuaW1wb3J0IHsgdXNlRm9jdXNCeUluZGV4IH0gZnJvbSBcIi4vdXNlRm9jdXNCeUluZGV4XCI7XG5cbi8vIFRoaXMgbWluSGVpZ2h0IGlzIG5lZWRlZCBmb3IgYWxpZ24gc21hbGwgaWNvbnMgaW4gdGhlIG1pZGRsZSBvZiAxIHJvdyB0ZXh0LFxuLy8gYnV0IGl0IHNob3VsZCBzdGF5IGF0IHRoZSB0b3AgaWYgdGhlcmUgaXMgbXVsdGlsaW5lIHRleHRcbmNvbnN0IFN0eWxlZE1pbkhlaWdodENlbGwgPSBzdHlsZWQuZGl2PFRleHRTaXplUHJvcHM+KFxuICAoeyB0aGVtZSwgdGV4dFNpemUgfSkgPT4gKHtcbiAgICBtaW5IZWlnaHQ6XG4gICAgICB0ZXh0U2l6ZSA9PT0gXCJzXCJcbiAgICAgICAgPyBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX0gKyAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzfSlgXG4gICAgICAgIDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gQmFzZUVudGl0eUxpc3Qoe1xuICBkYXRhLFxuICBzaXplID0gXCJtXCIsXG4gIG9uQ2xpY2ssXG4gIGlzU2VsZWN0YWJsZSxcbiAgc2VsZWN0ZWRJZHMsXG4gIG9uU2VsZWN0aW9uQ2hhbmdlLFxuICBvblNlbGVjdGlvblRvZ2dsZSxcbiAgcmVuZGVyUmlnaHRDb250ZW50LFxuICBnZXRMZWZ0SWNvblByb3BzLFxuICBoaWRlQm9yZGVyLFxuICBmaWx0ZXJGbixcbiAgaXNWaXJ0dWFsaXplZCxcbiAgbWF4SGVpZ2h0LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbn06IEVudGl0eUxpc3RQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGRhdGFTaG93biA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGlmICghZGF0YS5sZW5ndGgpIHJldHVybiBkYXRhO1xuXG4gICAgcmV0dXJuIGZpbHRlckZuID8gZGF0YS5maWx0ZXIoZmlsdGVyRm4pIDogZGF0YTtcbiAgfSwgW2RhdGEsIGZpbHRlckZuXSk7XG5cbiAgY29uc3Qgc2VsZWN0ZWRJZHNTZXQgPSB1c2VNZW1vKCgpID0+IG5ldyBTZXQoc2VsZWN0ZWRJZHMpLCBbc2VsZWN0ZWRJZHNdKTtcblxuICBjb25zdCBsaXN0UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c2FibGVJdGVtcyA9IHVzZU1lbW8oXG4gICAgKCkgPT5cbiAgICAgIGRhdGFTaG93bi5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgIGlkOiBpdGVtLmlkLFxuICAgICAgICBpc0Rpc2FibGVkOiBCb29sZWFuKGl0ZW0uaXNEaXNhYmxlZCksXG4gICAgICB9KSksXG4gICAgW2RhdGFTaG93bl1cbiAgKTtcblxuICBjb25zdCB7IG1vdmVGb2N1cywgZm9jdXNlZEluZGV4OiBzZWxlY3RlZEluZGV4IH0gPSB1c2VGb2N1c0J5SW5kZXgoe1xuICAgIGNvbnRhaW5lclJlZjogbGlzdFJlZixcbiAgICBub2RlU2VsZWN0b3I6IFwiZGF0YS1saXN0LWl0ZW1cIixcbiAgICBkYXRhOiBmb2N1c2FibGVJdGVtcyxcbiAgICBwcmV2ZW50U2Nyb2xsOiBpc1ZpcnR1YWxpemVkLFxuICB9KTtcblxuICB1c2VLZXlib2FyZChcbiAgICB7XG4gICAgICBBcnJvd0Rvd246ICgpID0+IHtcbiAgICAgICAgbW92ZUZvY3VzKDEpO1xuICAgICAgfSxcbiAgICAgIEFycm93VXA6ICgpID0+IHtcbiAgICAgICAgbW92ZUZvY3VzKC0xKTtcbiAgICAgIH0sXG4gICAgfSxcbiAgICBsaXN0UmVmLFxuICAgIGlzU2VsZWN0YWJsZVxuICApO1xuICBjb25zdCBoYW5kbGVPbkNsaWNrID0gdXNlQ2FsbGJhY2soXG4gICAgKGl0ZW06IExpc3ROb2RlKSA9PiB7XG4gICAgICBjb25zdCB7IGlkIH0gPSBpdGVtO1xuXG4gICAgICBpZiAoaXNTZWxlY3RhYmxlKSB7XG4gICAgICAgIGNvbnN0IHdpbGxCZVNlbGVjdGVkID0gIXNlbGVjdGVkSWRzU2V0LmhhcyhpZCk7XG4gICAgICAgIGNvbnN0IG5ld1NlbGVjdGVkSWRzU2V0ID0gbmV3IFNldChzZWxlY3RlZElkc1NldCk7XG5cbiAgICAgICAgaWYgKHdpbGxCZVNlbGVjdGVkKSB7XG4gICAgICAgICAgbmV3U2VsZWN0ZWRJZHNTZXQuYWRkKGlkKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBuZXdTZWxlY3RlZElkc1NldC5kZWxldGUoaWQpO1xuICAgICAgICB9XG5cbiAgICAgICAgb25TZWxlY3Rpb25Ub2dnbGU/LihpZCwgd2lsbEJlU2VsZWN0ZWQpO1xuICAgICAgICBvblNlbGVjdGlvbkNoYW5nZT8uKEFycmF5LmZyb20obmV3U2VsZWN0ZWRJZHNTZXQpKTtcbiAgICAgIH1cblxuICAgICAgb25DbGljaz8uKGl0ZW0pO1xuICAgIH0sXG4gICAgW1xuICAgICAgc2VsZWN0ZWRJZHNTZXQsXG4gICAgICBvblNlbGVjdGlvbkNoYW5nZSxcbiAgICAgIG9uU2VsZWN0aW9uVG9nZ2xlLFxuICAgICAgb25DbGljayxcbiAgICAgIGlzU2VsZWN0YWJsZSxcbiAgICBdXG4gICk7XG4gIGNvbnN0IHJlbmRlckVudGl0eUl0ZW0gPSAoaW5kZXg6IG51bWJlcik6IFJlYWN0LlJlYWN0Tm9kZSA9PiB7XG4gICAgY29uc3QgaXRlbSA9IGRhdGFTaG93bltpbmRleF07XG4gICAgaWYgKCFpdGVtKSByZXR1cm4gbnVsbDtcblxuICAgIGNvbnN0IGlzTGFzdEl0ZW0gPSBpbmRleCA9PT0gZGF0YVNob3duLmxlbmd0aCAtIDE7XG4gICAgY29uc3QgaXNGaXJzdEl0ZW0gPSBpbmRleCA9PT0gMDtcbiAgICBjb25zdCBkZWZhdWx0VGFiSW5kZXggPSBpc0ZpcnN0SXRlbSAmJiAhc2VsZWN0ZWRJbmRleDtcbiAgICBjb25zdCB0YWJJbmRleCA9XG4gICAgICAhaXRlbS5pc0Rpc2FibGVkICYmXG4gICAgICBpc1NlbGVjdGFibGUgJiZcbiAgICAgIChpbmRleCA9PT0gc2VsZWN0ZWRJbmRleCB8fCBkZWZhdWx0VGFiSW5kZXgpXG4gICAgICAgID8gMFxuICAgICAgICA6IC0xO1xuICAgIGNvbnN0IGlzU2VsZWN0ZWQgPSBzZWxlY3RlZElkc1NldC5oYXMoaXRlbS5pZCk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPEVudGl0eUxpc3RJdGVtXG4gICAgICAgIGtleT17aXRlbS5pZH1cbiAgICAgICAgZGF0YS1saXN0LWl0ZW09e2luZGV4fVxuICAgICAgICBhcmlhLWxhYmVsPXtpdGVtW1wiYXJpYS1sYWJlbFwiXSB8fCBpdGVtLmxhYmVsfVxuICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICBoaWRlQm9yZGVyPXtoaWRlQm9yZGVyIHx8IGlzTGFzdEl0ZW19XG4gICAgICAgIGlzQWN0aXZlPXtpdGVtLmlzQWN0aXZlfVxuICAgICAgICBpc0Rpc2FibGVkPXtpdGVtLmlzRGlzYWJsZWR9XG4gICAgICAgIGlzQ2xpY2thYmxlPXtCb29sZWFuKG9uQ2xpY2sgfHwgc2VsZWN0ZWRJZHMpfVxuICAgICAgICBkZXNjcmlwdGlvbj17aXRlbS5kZXNjcmlwdGlvbn1cbiAgICAgICAgb25TcGFjZUVudGVyUHJlc3M9eygpID0+IGhhbmRsZU9uQ2xpY2soaXRlbSl9XG4gICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgb25DbGljaz17KGUpID0+IHtcbiAgICAgICAgICBjb25zdCBpc0luc2lkZUxhYmVsID0gKGUudGFyZ2V0IGFzIEhUTUxFbGVtZW50KS5jbG9zZXN0KFwibGFiZWxcIik7XG4gICAgICAgICAgaWYgKCFpc0luc2lkZUxhYmVsKSB7XG4gICAgICAgICAgICBoYW5kbGVPbkNsaWNrKGl0ZW0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfX1cbiAgICAgICAgY2hlY2tib3hQcm9wcz17XG4gICAgICAgICAgaXNTZWxlY3RhYmxlICYmIHtcbiAgICAgICAgICAgIG5hbWU6IFwibGlzdC1jaGVja2JveFwiLFxuICAgICAgICAgICAgc2l6ZTogXCJzXCIsXG4gICAgICAgICAgICBjaGVja2VkOiBpc1NlbGVjdGVkLFxuICAgICAgICAgICAgb25DaGFuZ2U6ICgpID0+IGhhbmRsZU9uQ2xpY2soaXRlbSksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJlbmRlckxhYmVsPXsoKSA9PiBpdGVtLmxhYmVsfVxuICAgICAgICByZW5kZXJMZWZ0PXtcbiAgICAgICAgICBnZXRMZWZ0SWNvblByb3BzXG4gICAgICAgICAgICA/ICh7IHRleHRTaXplIH0pID0+IChcbiAgICAgICAgICAgICAgICA8SWNvbiB7Li4uZ2V0TGVmdEljb25Qcm9wcyhpdGVtKX0gc2l6ZT17dGV4dFNpemV9IC8+XG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgIDogbnVsbFxuICAgICAgICB9XG4gICAgICAgIHJlbmRlclJpZ2h0PXsoeyBhY3Rpb25TaXplLCB0ZXh0U2l6ZSB9KSA9PlxuICAgICAgICAgIHJlbmRlclJpZ2h0Q29udGVudCA/IChcbiAgICAgICAgICAgIDxTdHlsZWRNaW5IZWlnaHRDZWxsIHRleHRTaXplPXt0ZXh0U2l6ZX0+XG4gICAgICAgICAgICAgIHtyZW5kZXJSaWdodENvbnRlbnQoeyB0ZXh0U2l6ZSwgYWN0aW9uU2l6ZSwgLi4uaXRlbSB9KX1cbiAgICAgICAgICAgIDwvU3R5bGVkTWluSGVpZ2h0Q2VsbD5cbiAgICAgICAgICApIDogbnVsbFxuICAgICAgICB9XG4gICAgICAvPlxuICAgICk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IHJlZj17bGlzdFJlZn0+XG4gICAgICB7aXNWaXJ0dWFsaXplZCAmJiBtYXhIZWlnaHQgPyAoXG4gICAgICAgIDxWaXJ0dWFsaXplZEVudGl0eUxpc3RcbiAgICAgICAgICBpZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgICAgICBtYXhIZWlnaHQ9e21heEhlaWdodH1cbiAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgIGRhdGFTaG93bj17ZGF0YVNob3dufVxuICAgICAgICAgIHNlbGVjdGVkSW5kZXg9e3NlbGVjdGVkSW5kZXh9XG4gICAgICAgICAgaXRlbVRlbXBsYXRlPXtyZW5kZXJFbnRpdHlJdGVtfVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICAgIC8+XG4gICAgICApIDogKFxuICAgICAgICA8U3R5bGVkTGlzdFxuICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgICAgICBkYXRhLWRzLWlkPVwiRW50aXR5TGlzdFwiXG4gICAgICAgICAgcm9sZT1cImxpc3RcIlxuICAgICAgICA+XG4gICAgICAgICAge2RhdGFTaG93bi5tYXAoKF9pdGVtLCBpKSA9PiByZW5kZXJFbnRpdHlJdGVtKGkpKX1cbiAgICAgICAgPC9TdHlsZWRMaXN0PlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZNEIifQ== */");export function BaseEntityList({data,size="m",onClick,isSelectable,selectedIds,onSelectionChange,onSelectionToggle,renderRightContent,getLeftIconProps,hideBorder,filterFn,isVirtualized,maxHeight,"data-e2e-test-id":dataE2eTestId}){let dataShown=useMemo(()=>data.length&&filterFn?data.filter(filterFn):data,[data,filterFn]),selectedIdsSet=useMemo(()=>new Set(selectedIds),[selectedIds]),listRef=useRef(null),{moveFocus,focusedIndex:selectedIndex}=useFocusByIndex({containerRef:listRef,nodeSelector:"data-list-item",data:useMemo(()=>dataShown.map(item=>({id:item.id,isDisabled:!!item.isDisabled})),[dataShown]),preventScroll:isVirtualized});useKeyboard({ArrowDown:()=>{moveFocus(1)},ArrowUp:()=>{moveFocus(-1)}},listRef,isSelectable);let handleOnClick=useCallback(item=>{let{id}=item;if(isSelectable){let willBeSelected=!selectedIdsSet.has(id),newSelectedIdsSet=new Set(selectedIdsSet);willBeSelected?newSelectedIdsSet.add(id):newSelectedIdsSet.delete(id),onSelectionToggle?.(id,willBeSelected),onSelectionChange?.(Array.from(newSelectedIdsSet))}onClick?.(item)},[selectedIdsSet,onSelectionChange,onSelectionToggle,onClick,isSelectable]),renderEntityItem=index=>{let item=dataShown[index];if(!item)return null;let isLastItem=index===dataShown.length-1,tabIndex=item.isDisabled||!isSelectable||index!==selectedIndex&&(0!==index||selectedIndex)?-1:0,isSelected=selectedIdsSet.has(item.id);return React.createElement(EntityListItem,{key:item.id,"data-list-item":index,"aria-label":item["aria-label"]||item.label,size:size,hideBorder:hideBorder||isLastItem,isActive:item.isActive,isDisabled:item.isDisabled,isClickable:!!(onClick||selectedIds),description:item.description,onSpaceEnterPress:()=>handleOnClick(item),tabIndex:tabIndex,onClick:e=>{e.target.closest("label")||handleOnClick(item)},checkboxProps:isSelectable&&{name:"list-checkbox",size:"s",checked:isSelected,onChange:()=>handleOnClick(item)},renderLabel:()=>item.label,renderLeft:getLeftIconProps?({textSize})=>React.createElement(Icon,{...getLeftIconProps(item),size:textSize}):null,renderRight:({actionSize,textSize})=>renderRightContent?React.createElement(StyledMinHeightCell,{textSize:textSize},renderRightContent({textSize,actionSize,...item})):null})};return React.createElement("div",{ref:listRef},isVirtualized&&maxHeight?React.createElement(VirtualizedEntityList,{id:dataE2eTestId,maxHeight:maxHeight,size:size,dataShown:dataShown,selectedIndex:selectedIndex,itemTemplate:renderEntityItem,"data-e2e-test-id":dataE2eTestId}):React.createElement(StyledList,{size:size,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"EntityList",role:"list"},dataShown.map((_item,i)=>renderEntityItem(i))))}
@@ -1 +1 @@
1
- import React,{useCallback,isValidElement}from"react";import styled from"@emotion/styled";import{CheckboxRaw}from"../Form/Checkbox/Checkbox";import{EntityListItemText}from"./EntityListItemText";import{Inline}from"../Inline/Inline";import{StyledWrapperOffset}from"./styled-components";let StyledLabel=styled(StyledWrapperOffset,{target:"e1686uk00",label:"StyledLabel"})(({theme,size})=>({cursor:"pointer",display:"block",margin:`-${theme.variables.size.spacing["xs"===size?"xxs":size]} 0`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9FbnRpdHlJdGVtQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgaXNWYWxpZEVsZW1lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBGQywgUHJvcHNXaXRoQ2hpbGRyZW4gfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IENoZWNrYm94UmF3IH0gZnJvbSBcIi4uL0Zvcm0vQ2hlY2tib3gvQ2hlY2tib3hcIjtcbmltcG9ydCB7IEVudGl0eUxpc3RJdGVtVGV4dCB9IGZyb20gXCIuL0VudGl0eUxpc3RJdGVtVGV4dFwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFN0eWxlZFdyYXBwZXJPZmZzZXQgfSBmcm9tIFwiLi9zdHlsZWQtY29tcG9uZW50c1wiO1xuaW1wb3J0IHR5cGUgeyBFbnRpdHlMaXN0SXRlbVByb3BzIH0gZnJvbSBcIi4vdHlwZXNcIjtcblxuY29uc3QgU3R5bGVkTGFiZWwgPSBzdHlsZWQoU3R5bGVkV3JhcHBlck9mZnNldCkoKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJibG9ja1wiLFxuICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nW3NpemUgPT09IFwieHNcIiA/IFwieHhzXCIgOiBzaXplXX0gMGAsXG59KSk7XG5cbmNvbnN0IFN0b3BQcm9wYWdhdGlvbldyYXBwZXI6IEZDPFByb3BzV2l0aENoaWxkcmVuPiA9ICh7IGNoaWxkcmVuIH0pID0+IHtcbiAgY29uc3QgaGFuZGxlQ2xpY2sgPSB1c2VDYWxsYmFjaygoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgIGUuc3RvcFByb3BhZ2F0aW9uKCk7XG4gIH0sIFtdKTtcbiAgcmV0dXJuIChcbiAgICA8ZGl2IHJvbGU9XCJwcmVzZW50YXRpb25cIiBvbkNsaWNrPXtoYW5kbGVDbGlja30+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gRW50aXR5SXRlbUJvZHkoe1xuICBjaGVja2JveFByb3BzLFxuICBkZXNjcmlwdGlvbixcbiAgcmVuZGVyTGFiZWwsXG4gIHJlbmRlckxlZnQsXG4gIHJlbmRlclJpZ2h0LFxuICB0YWJJbmRleCxcbiAgc2l6ZSA9IFwibVwiLFxufTogUGFydGlhbDxFbnRpdHlMaXN0SXRlbVByb3BzPik6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IHRleHRTaXplID0gc2l6ZSA9PT0gXCJ4c1wiID8gXCJzXCIgOiBcIm1cIjtcbiAgY29uc3QgYWN0aW9uU2l6ZSA9IHNpemUgPT09IFwibFwiID8gXCJtXCIgOiBcInNcIjtcblxuICBjb25zdCByaWdodEVsZW1lbnQgPSByZW5kZXJSaWdodD8uKHsgdGV4dFNpemUsIGFjdGlvblNpemUgfSk7XG4gIGNvbnN0IGlzUmlnaHRDbGlja2FibGUgPVxuICAgIGlzVmFsaWRFbGVtZW50KHJpZ2h0RWxlbWVudCkgJiZcbiAgICByaWdodEVsZW1lbnQucHJvcHM/LmNoaWxkcmVuPy5wcm9wcz8ub25DbGljaztcblxuICByZXR1cm4gKFxuICAgIDxJbmxpbmUgbm9XcmFwIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIiBzcGFjZT17W1wieHNcIiwgXCJtXCJdfT5cbiAgICAgIHtjaGVja2JveFByb3BzID8gKFxuICAgICAgICA8U3R5bGVkTGFiZWwgYXM9XCJsYWJlbFwiIHNpemU9e3NpemV9PlxuICAgICAgICAgIDxJbmxpbmUgbm9XcmFwIHNwYWNlPXtbXCJ4c1wiLCBcIm1cIl19PlxuICAgICAgICAgICAgPENoZWNrYm94UmF3IHsuLi5jaGVja2JveFByb3BzfSB0YWJJbmRleD17dGFiSW5kZXh9IC8+XG4gICAgICAgICAgICA8RW50aXR5TGlzdEl0ZW1UZXh0IHNpemU9e3RleHRTaXplfSBkZXNjcmlwdGlvbj17ZGVzY3JpcHRpb259PlxuICAgICAgICAgICAgICB7cmVuZGVyTGFiZWwoeyB0ZXh0U2l6ZSB9KX1cbiAgICAgICAgICAgIDwvRW50aXR5TGlzdEl0ZW1UZXh0PlxuICAgICAgICAgIDwvSW5saW5lPlxuICAgICAgICA8L1N0eWxlZExhYmVsPlxuICAgICAgKSA6IChcbiAgICAgICAgPElubGluZSBub1dyYXAgc3BhY2U9e1tcInhzXCIsIFwibVwiXX0+XG4gICAgICAgICAge3JlbmRlckxlZnQgJiYgcmVuZGVyTGVmdCh7IHRleHRTaXplIH0pfVxuICAgICAgICAgIDxFbnRpdHlMaXN0SXRlbVRleHQgc2l6ZT17dGV4dFNpemV9IGRlc2NyaXB0aW9uPXtkZXNjcmlwdGlvbn0+XG4gICAgICAgICAgICB7cmVuZGVyTGFiZWwoeyB0ZXh0U2l6ZSB9KX1cbiAgICAgICAgICA8L0VudGl0eUxpc3RJdGVtVGV4dD5cbiAgICAgICAgPC9JbmxpbmU+XG4gICAgICApfVxuXG4gICAgICB7cmlnaHRFbGVtZW50ICYmXG4gICAgICAgIChpc1JpZ2h0Q2xpY2thYmxlID8gKFxuICAgICAgICAgIDxTdG9wUHJvcGFnYXRpb25XcmFwcGVyPntyaWdodEVsZW1lbnR9PC9TdG9wUHJvcGFnYXRpb25XcmFwcGVyPlxuICAgICAgICApIDogKFxuICAgICAgICAgIHJpZ2h0RWxlbWVudFxuICAgICAgICApKX1cbiAgICA8L0lubGluZT5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVb0IifQ== */"),StopPropagationWrapper=({children})=>{let handleClick=useCallback(e=>{e.stopPropagation()},[]);return React.createElement("div",{role:"presentation",onClick:handleClick},children)};export function EntityItemBody({checkboxProps,description,renderLabel,renderLeft,renderRight,tabIndex,size="m"}){let textSize="xs"===size?"s":"m",rightElement=renderRight?.({textSize,actionSize:"l"===size?"m":"s"}),isRightClickable=isValidElement(rightElement)&&rightElement.props?.children?.props?.onClick;return React.createElement(Inline,{noWrap:!0,alignItems:"spaceBetween",space:["xs","m"]},checkboxProps?React.createElement(StyledLabel,{as:"label",size:size},React.createElement(Inline,{noWrap:!0,space:["xs","m"]},React.createElement(CheckboxRaw,{...checkboxProps,tabIndex:tabIndex}),React.createElement(EntityListItemText,{size:textSize,description:description},renderLabel({textSize})))):React.createElement(Inline,{noWrap:!0,space:["xs","m"]},renderLeft&&renderLeft({textSize}),React.createElement(EntityListItemText,{size:textSize,description:description},renderLabel({textSize}))),rightElement&&(isRightClickable?React.createElement(StopPropagationWrapper,null,rightElement):rightElement))}
1
+ import React,{cloneElement,isValidElement}from"react";import styled from"@emotion/styled";import{CheckboxRaw}from"../Form/Checkbox/Checkbox";import{EntityListItemText}from"./EntityListItemText";import{Inline}from"../Inline/Inline";import{StyledWrapperOffset}from"./styled-components";let StyledLabel=styled(StyledWrapperOffset,{target:"e14o5jq10",label:"StyledLabel"})(({theme,size})=>({cursor:"pointer",display:"block",margin:`-${theme.variables.size.spacing["xs"===size?"xxs":size]} 0`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9FbnRpdHlJdGVtQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyBjbG9uZUVsZW1lbnQsIGlzVmFsaWRFbGVtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IENoZWNrYm94UmF3IH0gZnJvbSBcIi4uL0Zvcm0vQ2hlY2tib3gvQ2hlY2tib3hcIjtcbmltcG9ydCB7IEVudGl0eUxpc3RJdGVtVGV4dCB9IGZyb20gXCIuL0VudGl0eUxpc3RJdGVtVGV4dFwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFN0eWxlZFdyYXBwZXJPZmZzZXQgfSBmcm9tIFwiLi9zdHlsZWQtY29tcG9uZW50c1wiO1xuaW1wb3J0IHR5cGUgeyBFbnRpdHlMaXN0SXRlbVByb3BzIH0gZnJvbSBcIi4vdHlwZXNcIjtcblxuY29uc3QgU3R5bGVkTGFiZWwgPSBzdHlsZWQoU3R5bGVkV3JhcHBlck9mZnNldCkoKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJibG9ja1wiLFxuICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nW3NpemUgPT09IFwieHNcIiA/IFwieHhzXCIgOiBzaXplXX0gMGAsXG59KSk7XG5cbmNvbnN0IGlzQ2xpY2thYmxlRWxlbWVudCA9IChcbiAgZWxlbWVudDogUmVhY3QuUmVhY3ROb2RlXG4pOiBlbGVtZW50IGlzIFJlYWN0LlJlYWN0RWxlbWVudDxIVE1MQXR0cmlidXRlczxIVE1MRWxlbWVudD4+ID0+XG4gIGlzVmFsaWRFbGVtZW50KGVsZW1lbnQpICYmIHR5cGVvZiBlbGVtZW50LnByb3BzPy5vbkNsaWNrID09PSBcImZ1bmN0aW9uXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBFbnRpdHlJdGVtQm9keSh7XG4gIGNoZWNrYm94UHJvcHMsXG4gIGRlc2NyaXB0aW9uLFxuICByZW5kZXJMYWJlbCxcbiAgcmVuZGVyTGVmdCxcbiAgcmVuZGVyUmlnaHQsXG4gIHRhYkluZGV4LFxuICBzaXplID0gXCJtXCIsXG59OiBQYXJ0aWFsPEVudGl0eUxpc3RJdGVtUHJvcHM+KTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgdGV4dFNpemUgPSBzaXplID09PSBcInhzXCIgPyBcInNcIiA6IFwibVwiO1xuICBjb25zdCBhY3Rpb25TaXplID0gc2l6ZSA9PT0gXCJsXCIgPyBcIm1cIiA6IFwic1wiO1xuICBjb25zdCByaWdodEVsZW1lbnQgPSByZW5kZXJSaWdodD8uKHsgdGV4dFNpemUsIGFjdGlvblNpemUgfSk7XG5cbiAgcmV0dXJuIChcbiAgICA8SW5saW5lIG5vV3JhcCBhbGlnbkl0ZW1zPVwic3BhY2VCZXR3ZWVuXCIgc3BhY2U9e1tcInhzXCIsIFwibVwiXX0+XG4gICAgICB7Y2hlY2tib3hQcm9wcyA/IChcbiAgICAgICAgPFN0eWxlZExhYmVsIGFzPVwibGFiZWxcIiBzaXplPXtzaXplfT5cbiAgICAgICAgICA8SW5saW5lIG5vV3JhcCBzcGFjZT17W1wieHNcIiwgXCJtXCJdfT5cbiAgICAgICAgICAgIDxDaGVja2JveFJhdyB7Li4uY2hlY2tib3hQcm9wc30gdGFiSW5kZXg9ey0xfSAvPlxuICAgICAgICAgICAgPEVudGl0eUxpc3RJdGVtVGV4dCBzaXplPXt0ZXh0U2l6ZX0gZGVzY3JpcHRpb249e2Rlc2NyaXB0aW9ufT5cbiAgICAgICAgICAgICAge3JlbmRlckxhYmVsKHsgdGV4dFNpemUgfSl9XG4gICAgICAgICAgICA8L0VudGl0eUxpc3RJdGVtVGV4dD5cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRMYWJlbD5cbiAgICAgICkgOiAoXG4gICAgICAgIDxJbmxpbmUgbm9XcmFwIHNwYWNlPXtbXCJ4c1wiLCBcIm1cIl19PlxuICAgICAgICAgIHtyZW5kZXJMZWZ0ICYmIHJlbmRlckxlZnQoeyB0ZXh0U2l6ZSB9KX1cbiAgICAgICAgICA8RW50aXR5TGlzdEl0ZW1UZXh0IHNpemU9e3RleHRTaXplfSBkZXNjcmlwdGlvbj17ZGVzY3JpcHRpb259PlxuICAgICAgICAgICAge3JlbmRlckxhYmVsKHsgdGV4dFNpemUgfSl9XG4gICAgICAgICAgPC9FbnRpdHlMaXN0SXRlbVRleHQ+XG4gICAgICAgIDwvSW5saW5lPlxuICAgICAgKX1cblxuICAgICAge2lzQ2xpY2thYmxlRWxlbWVudChyaWdodEVsZW1lbnQpXG4gICAgICAgID8gY2xvbmVFbGVtZW50KHJpZ2h0RWxlbWVudCwge1xuICAgICAgICAgICAgdGFiSW5kZXgsXG4gICAgICAgICAgICBvbkNsaWNrOiAoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQ8SFRNTEVsZW1lbnQ+KSA9PiB7XG4gICAgICAgICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICByaWdodEVsZW1lbnQucHJvcHMub25DbGljaz8uKGV2ZW50KTtcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgfSlcbiAgICAgICAgOiByaWdodEVsZW1lbnR9XG4gICAgPC9JbmxpbmU+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9CIn0= */"),isClickableElement=element=>isValidElement(element)&&"function"==typeof element.props?.onClick;export function EntityItemBody({checkboxProps,description,renderLabel,renderLeft,renderRight,tabIndex,size="m"}){let textSize="xs"===size?"s":"m",rightElement=renderRight?.({textSize,actionSize:"l"===size?"m":"s"});return React.createElement(Inline,{noWrap:!0,alignItems:"spaceBetween",space:["xs","m"]},checkboxProps?React.createElement(StyledLabel,{as:"label",size:size},React.createElement(Inline,{noWrap:!0,space:["xs","m"]},React.createElement(CheckboxRaw,{...checkboxProps,tabIndex:-1}),React.createElement(EntityListItemText,{size:textSize,description:description},renderLabel({textSize})))):React.createElement(Inline,{noWrap:!0,space:["xs","m"]},renderLeft&&renderLeft({textSize}),React.createElement(EntityListItemText,{size:textSize,description:description},renderLabel({textSize}))),isClickableElement(rightElement)?cloneElement(rightElement,{tabIndex,onClick:event=>{event.stopPropagation(),rightElement.props.onClick?.(event)}}):rightElement)}
@@ -1 +1 @@
1
- import React,{useCallback,useImperativeHandle,useRef}from"react";import{EntityItemBody}from"./EntityItemBody";import{useKeyboard}from"../../shared/useKeyboard";import{StyledEntityItemLi,StyledEntityListItemWrapper,StyledEntityListItemButton}from"./styled-components";let useButtonKeyboard=({ref:globalRef,isActive,onKeyDown})=>{let localRef=useRef(null);return useKeyboard({"Space Enter":onKeyDown},localRef,isActive,!0),useImperativeHandle(globalRef,()=>localRef.current),localRef};export const EntityListItem=React.forwardRef(({checkboxProps,description,hideBorder,isActive,isClickable,isDisabled,onClick,renderLabel,renderLeft,renderRight,tabIndex,onKeyDown,size="m","aria-label":ariaLabel},ref)=>{let handleOnClick=useCallback(e=>{isClickable&&onClick&&onClick(e)},[onClick,isClickable]),buttonRef=useButtonKeyboard({ref,isActive:isActive&&isClickable,onKeyDown});return React.createElement(StyledEntityItemLi,{"aria-label":ariaLabel},React.createElement(StyledEntityListItemButton,{size:size,tabIndex:tabIndex,ref:buttonRef,role:"group","aria-disabled":isDisabled,"data-id":"list-item",onClick:handleOnClick,isClickable:isClickable,isActive:isActive,isDisabled:isDisabled},React.createElement(StyledEntityListItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},React.createElement(EntityItemBody,{size:size,tabIndex:tabIndex,checkboxProps:checkboxProps,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight}))))});
1
+ import React,{useCallback,useImperativeHandle,useRef}from"react";import{EntityItemBody}from"./EntityItemBody";import{useKeyboard}from"../../shared/useKeyboard";import{StyledEntityItemLi,StyledEntityListItemWrapper,StyledEntityListItemButton}from"./styled-components";let useButtonKeyboard=({ref:globalRef,isActive,onSpaceEnterPress})=>{let localRef=useRef(null);return useKeyboard({"Space Enter":onSpaceEnterPress},localRef,isActive,!0),useImperativeHandle(globalRef,()=>localRef.current),localRef};export const EntityListItem=React.forwardRef(({checkboxProps,description,hideBorder,isActive,isClickable,isDisabled,onClick,renderLabel,renderLeft,renderRight,tabIndex,onSpaceEnterPress,size="m","aria-label":ariaLabel,"data-list-item":dataListItem},ref)=>{let handleOnClick=useCallback(e=>{isClickable&&onClick&&onClick(e)},[onClick,isClickable]),buttonRef=useButtonKeyboard({ref,isActive:0===tabIndex&&isClickable,onSpaceEnterPress});return React.createElement(StyledEntityItemLi,{"aria-label":ariaLabel},React.createElement(StyledEntityListItemButton,{size:size,tabIndex:tabIndex,ref:buttonRef,role:"group","aria-disabled":isDisabled,"data-list-item":dataListItem,"data-id":"list-item",onClick:handleOnClick,isClickable:isClickable,isActive:isActive,isDisabled:isDisabled},React.createElement(StyledEntityListItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},React.createElement(EntityItemBody,{size:size,tabIndex:tabIndex,checkboxProps:checkboxProps,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight}))))});
@@ -1 +1 @@
1
- import styled from"@emotion/styled";import{mq,useResponsiveValue}from"../../shared/mediaQueries";export const getOffsetMqStyle=(cssProp,{theme,size})=>mq({[cssProp]:[size,{xs:theme.variables.size.spacing.xxs,s:theme.variables.size.spacing.s,m:theme.variables.size.spacing.m,l:theme.variables.size.spacing.l}]});export const StyledList=styled("ul",{target:"e176i2ml0",label:"StyledList"})(({theme,size})=>({..."xs"===size&&{padding:`${theme.variables.size.spacing.xs} 0`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICBcIiY6Zm9jdXNcIjoge1xuICAgIG91dGxpbmU6IFwibm9uZVwiLFxuICB9LFxuXG4gIC4uLihpc0Rpc2FibGVkICYmIHtcbiAgICBjdXJzb3I6IFwibm90LWFsbG93ZWRcIixcbiAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcblxuICAgIFtgJHtTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXJ9ID4gKmBdOiB7XG4gICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICB9LFxuICB9KSxcbn0pKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QjBCIn0= */");export const StyledEntityItemLi=styled("li",{target:"e176i2ml1",label:"StyledEntityItemLi"})({listStyleType:"none"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICBcIiY6Zm9jdXNcIjoge1xuICAgIG91dGxpbmU6IFwibm9uZVwiLFxuICB9LFxuXG4gIC4uLihpc0Rpc2FibGVkICYmIHtcbiAgICBjdXJzb3I6IFwibm90LWFsbG93ZWRcIixcbiAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcblxuICAgIFtgJHtTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXJ9ID4gKmBdOiB7XG4gICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICB9LFxuICB9KSxcbn0pKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQ2tDIn0= */");export const StyledShowMore=styled("div",{target:"e176i2ml2",label:"StyledShowMore"})(({theme})=>({marginTop:-1,borderTop:`1px solid ${theme.values.color.border.secondary.default}`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICBcIiY6Zm9jdXNcIjoge1xuICAgIG91dGxpbmU6IFwibm9uZVwiLFxuICB9LFxuXG4gIC4uLihpc0Rpc2FibGVkICYmIHtcbiAgICBjdXJzb3I6IFwibm90LWFsbG93ZWRcIixcbiAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcblxuICAgIFtgJHtTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXJ9ID4gKmBdOiB7XG4gICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICB9LFxuICB9KSxcbn0pKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQzhCIn0= */");export const StyledWrapperOffset=styled("div",{target:"e176i2ml3",label:"StyledWrapperOffset"})(({theme,size})=>({...getOffsetMqStyle("paddingBottom",{theme,size})}),({theme,size})=>({...getOffsetMqStyle("paddingTop",{theme,size})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICBcIiY6Zm9jdXNcIjoge1xuICAgIG91dGxpbmU6IFwibm9uZVwiLFxuICB9LFxuXG4gIC4uLihpc0Rpc2FibGVkICYmIHtcbiAgICBjdXJzb3I6IFwibm90LWFsbG93ZWRcIixcbiAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcblxuICAgIFtgJHtTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXJ9ID4gKmBdOiB7XG4gICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICB9LFxuICB9KSxcbn0pKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQ21DIn0= */");export const StyledEntityListItemWrapper=styled(StyledWrapperOffset,{target:"e176i2ml4",label:"StyledEntityListItemWrapper"})(({theme,hideBorder})=>({width:"100%",...!hideBorder&&{borderBottom:`1px solid ${theme.values.color.border.secondary.default}`},...useResponsiveValue({paddingLeft:[theme.variables.size.spacing.m,theme.variables.size.spacing.l],paddingRight:[theme.variables.size.spacing.m,theme.variables.size.spacing.l]}),"& button, & a":{margin:`-${theme.variables.size.spacing.xxs} 0`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICBcIiY6Zm9jdXNcIjoge1xuICAgIG91dGxpbmU6IFwibm9uZVwiLFxuICB9LFxuXG4gIC4uLihpc0Rpc2FibGVkICYmIHtcbiAgICBjdXJzb3I6IFwibm90LWFsbG93ZWRcIixcbiAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcblxuICAgIFtgJHtTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXJ9ID4gKmBdOiB7XG4gICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICB9LFxuICB9KSxcbn0pKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRDJDIn0= */");export const StyledEntityListItemButton=styled("div",{target:"e176i2ml5",label:"StyledEntityListItemButton"})(({theme,isClickable,isActive,isDisabled})=>({display:"flex",flex:"1 1 100%",flexWrap:"nowrap",transition:"background-color 0.1s ease-out",...isClickable&&{cursor:"pointer"},"&:hover":{backgroundColor:theme.values.color.background.transparent.hover},...isActive&&{backgroundColor:theme.values.color.background.transparent.active},"&:focus":{outline:"none"},...isDisabled&&{cursor:"not-allowed",pointerEvents:"none",[`${StyledEntityListItemWrapper} > *`]:{opacity:theme.variables.opacity.disabled}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICBcIiY6Zm9jdXNcIjoge1xuICAgIG91dGxpbmU6IFwibm9uZVwiLFxuICB9LFxuXG4gIC4uLihpc0Rpc2FibGVkICYmIHtcbiAgICBjdXJzb3I6IFwibm90LWFsbG93ZWRcIixcbiAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcblxuICAgIFtgJHtTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXJ9ID4gKmBdOiB7XG4gICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICB9LFxuICB9KSxcbn0pKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRTBDIn0= */");
1
+ import styled from"@emotion/styled";import{mq,useResponsiveValue}from"../../shared/mediaQueries";import{getFocusStyles}from"../../shared/mixins";export const getOffsetMqStyle=(cssProp,{theme,size})=>mq({[cssProp]:[size,{xs:theme.variables.size.spacing.xxs,s:theme.variables.size.spacing.s,m:theme.variables.size.spacing.m,l:theme.variables.size.spacing.l}]});export const StyledList=styled("ul",{target:"e3zp63p0",label:"StyledList"})(({theme,size})=>({..."xs"===size&&{padding:`${theme.variables.size.spacing.xs} 0`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBnZXRGb2N1c1N0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICAuLi5nZXRGb2N1c1N0eWxlcyh7IG9mZnNldDogLTIgfSksXG4gIFwiJjpmb2N1cy12aXNpYmxlXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgfSxcblxuICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgY3Vyc29yOiBcIm5vdC1hbGxvd2VkXCIsXG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCIsXG5cbiAgICBbYCR7U3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyfSA+ICpgXToge1xuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSxcbiAgfSksXG59KSk7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkIwQiJ9 */");export const StyledEntityItemLi=styled("li",{target:"e3zp63p1",label:"StyledEntityItemLi"})({listStyleType:"none"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBnZXRGb2N1c1N0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICAuLi5nZXRGb2N1c1N0eWxlcyh7IG9mZnNldDogLTIgfSksXG4gIFwiJjpmb2N1cy12aXNpYmxlXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgfSxcblxuICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgY3Vyc29yOiBcIm5vdC1hbGxvd2VkXCIsXG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCIsXG5cbiAgICBbYCR7U3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyfSA+ICpgXToge1xuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSxcbiAgfSksXG59KSk7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUNrQyJ9 */");export const StyledShowMore=styled("div",{target:"e3zp63p2",label:"StyledShowMore"})(({theme})=>({marginTop:-1,borderTop:`1px solid ${theme.values.color.border.secondary.default}`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBnZXRGb2N1c1N0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICAuLi5nZXRGb2N1c1N0eWxlcyh7IG9mZnNldDogLTIgfSksXG4gIFwiJjpmb2N1cy12aXNpYmxlXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgfSxcblxuICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgY3Vyc29yOiBcIm5vdC1hbGxvd2VkXCIsXG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCIsXG5cbiAgICBbYCR7U3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyfSA+ICpgXToge1xuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSxcbiAgfSksXG59KSk7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUM4QiJ9 */");export const StyledWrapperOffset=styled("div",{target:"e3zp63p3",label:"StyledWrapperOffset"})(({theme,size})=>({...getOffsetMqStyle("paddingBottom",{theme,size})}),({theme,size})=>({...getOffsetMqStyle("paddingTop",{theme,size})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBnZXRGb2N1c1N0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICAuLi5nZXRGb2N1c1N0eWxlcyh7IG9mZnNldDogLTIgfSksXG4gIFwiJjpmb2N1cy12aXNpYmxlXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgfSxcblxuICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgY3Vyc29yOiBcIm5vdC1hbGxvd2VkXCIsXG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCIsXG5cbiAgICBbYCR7U3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyfSA+ICpgXToge1xuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSxcbiAgfSksXG59KSk7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNENtQyJ9 */");export const StyledEntityListItemWrapper=styled(StyledWrapperOffset,{target:"e3zp63p4",label:"StyledEntityListItemWrapper"})(({theme,hideBorder})=>({width:"100%",...!hideBorder&&{borderBottom:`1px solid ${theme.values.color.border.secondary.default}`},...useResponsiveValue({paddingLeft:[theme.variables.size.spacing.m,theme.variables.size.spacing.l],paddingRight:[theme.variables.size.spacing.m,theme.variables.size.spacing.l]}),"& button, & a":{margin:`-${theme.variables.size.spacing.xxs} 0`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBnZXRGb2N1c1N0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICAuLi5nZXRGb2N1c1N0eWxlcyh7IG9mZnNldDogLTIgfSksXG4gIFwiJjpmb2N1cy12aXNpYmxlXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgfSxcblxuICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgY3Vyc29yOiBcIm5vdC1hbGxvd2VkXCIsXG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCIsXG5cbiAgICBbYCR7U3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyfSA+ICpgXToge1xuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSxcbiAgfSksXG59KSk7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUQyQyJ9 */");export const StyledEntityListItemButton=styled("div",{target:"e3zp63p5",label:"StyledEntityListItemButton"})(({theme,isClickable,isActive,isDisabled})=>({display:"flex",flex:"1 1 100%",flexWrap:"nowrap",transition:"background-color 0.1s ease-out",...isClickable&&{cursor:"pointer"},"&:hover":{backgroundColor:theme.values.color.background.transparent.hover},...isActive&&{backgroundColor:theme.values.color.background.transparent.active},...getFocusStyles({offset:-2}),"&:focus-visible":{backgroundColor:theme.values.color.background.transparent.active},...isDisabled&&{cursor:"not-allowed",pointerEvents:"none",[`${StyledEntityListItemWrapper} > *`]:{opacity:theme.variables.opacity.disabled}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9zdHlsZWQtY29tcG9uZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHR5cGUgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcywgRW50aXR5TGlzdEl0ZW1XcmFwcGVyUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBMaXN0U2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgbXEsIHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBnZXRGb2N1c1N0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRPZmZzZXRNcVN0eWxlID0gKFxuICBjc3NQcm9wOiBzdHJpbmcsXG4gIHtcbiAgICB0aGVtZSxcbiAgICBzaXplLFxuICB9OiB7XG4gICAgdGhlbWU6IFRoZW1lO1xuICB9ICYgUGFydGlhbDxFbnRpdHlMaXN0SXRlbVdyYXBwZXJQcm9wcz5cbikgPT5cbiAgbXEoe1xuICAgIFtjc3NQcm9wXTogW1xuICAgICAgc2l6ZSxcbiAgICAgIHtcbiAgICAgICAgeHM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgICAgICBzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICAgIG06IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgICAgbDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgICAgfSBhcyBhbnksXG4gICAgXSxcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkLnVsPHsgc2l6ZTogTGlzdFNpemUgfT4oKHsgdGhlbWUsIHNpemUgfSkgPT4gKHtcbiAgLi4uKHNpemUgPT09IFwieHNcIiAmJiB7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gMGAsXG4gIH0pLFxufSkpO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5SXRlbUxpID0gc3R5bGVkLmxpKHtcbiAgbGlzdFN0eWxlVHlwZTogXCJub25lXCIsXG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNob3dNb3JlID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBtYXJnaW5Ub3A6IC0xLFxuICBib3JkZXJUb3A6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRXcmFwcGVyT2Zmc2V0ID0gc3R5bGVkLmRpdjx7IHNpemU6IExpc3RTaXplIH0+KFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nQm90dG9tXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pLFxuICAoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICAgIC4uLmdldE9mZnNldE1xU3R5bGUoXCJwYWRkaW5nVG9wXCIsIHsgdGhlbWUsIHNpemUgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyID0gc3R5bGVkKFxuICBTdHlsZWRXcmFwcGVyT2Zmc2V0XG4pPEVudGl0eUxpc3RJdGVtV3JhcHBlclByb3BzPigoeyB0aGVtZSwgaGlkZUJvcmRlciB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG5cbiAgLi4uKCFoaWRlQm9yZGVyICYmIHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gIH0pLFxuXG4gIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgcGFkZGluZ0xlZnQ6IFtcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbiAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubCxcbiAgICBdLFxuICAgIHBhZGRpbmdSaWdodDogW1xuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5sLFxuICAgIF0sXG4gIH0pLFxuXG4gIC8vIGJ1dHRvbiBhbmQgbGlua3MgaGF2ZSBhIGdyZWF0ZWQgaGVpZ2h0IHRoYW4gbGlzdCBpdGVtXG4gIC8vIGZyb20gZGVzaWduIHNwZWNzIGl0IHNob3VsZCBub3QgZXhwYW5kIHRoZSBsaXN0IGl0ZW1cbiAgXCImIGJ1dHRvbiwgJiBhXCI6IHtcbiAgICBtYXJnaW46IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4c30gMGAsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbiA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8RW50aXR5TGlzdEl0ZW1Qcm9wcz5cbj4oKHsgdGhlbWUsIGlzQ2xpY2thYmxlLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleDogXCIxIDEgMTAwJVwiLFxuICBmbGV4V3JhcDogXCJub3dyYXBcIixcbiAgdHJhbnNpdGlvbjogXCJiYWNrZ3JvdW5kLWNvbG9yIDAuMXMgZWFzZS1vdXRcIixcblxuICAuLi4oaXNDbGlja2FibGUgJiYge1xuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIH0pLFxuXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgfSxcblxuICAuLi4oaXNBY3RpdmUgJiYge1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuYWN0aXZlLFxuICB9KSxcblxuICAuLi5nZXRGb2N1c1N0eWxlcyh7IG9mZnNldDogLTIgfSksXG4gIFwiJjpmb2N1cy12aXNpYmxlXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgfSxcblxuICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgY3Vyc29yOiBcIm5vdC1hbGxvd2VkXCIsXG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCIsXG5cbiAgICBbYCR7U3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyfSA+ICpgXToge1xuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSxcbiAgfSksXG59KSk7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0YwQyJ9 */");
@@ -100,12 +100,13 @@ export type EntityListItemProps = {
100
100
  isExpanded?: boolean;
101
101
  isDisabledExpand?: boolean;
102
102
  tabIndex?: number;
103
- onKeyDown?: (e: KeyboardEvent) => void;
103
+ onSpaceEnterPress?: (e: KeyboardEvent) => void;
104
104
  onFocus?: (e: React.FocusEvent) => void;
105
105
  ariaLabelExpand?: string;
106
106
  ariaLabelCollapse?: string;
107
107
  "aria-label": string;
108
108
  "aria-level"?: number;
109
+ "data-list-item"?: number;
109
110
  };
110
111
  export type EntityListItemLabelProps = {
111
112
  children: React.ReactNode;
@@ -0,0 +1,17 @@
1
+ import { type RefObject } from "react";
2
+ type FocusableItem = {
3
+ id: string;
4
+ isDisabled?: boolean;
5
+ };
6
+ type UseFocusByIndexResult = {
7
+ moveFocus: (offset: number) => void;
8
+ focusedIndex: number;
9
+ };
10
+ type UseFocusByIndexOptions = {
11
+ data: FocusableItem[];
12
+ containerRef: RefObject<HTMLDivElement | HTMLUListElement>;
13
+ nodeSelector: string;
14
+ preventScroll?: boolean;
15
+ };
16
+ export declare const useFocusByIndex: ({ data, containerRef, nodeSelector, preventScroll, }: UseFocusByIndexOptions) => UseFocusByIndexResult;
17
+ export {};
@@ -0,0 +1 @@
1
+ import{useCallback,useEffect,useRef,useState}from"react";let getNextEnabledIndex=(items,startIndex,direction)=>{let index=startIndex+direction;for(;index>=0&&index<items.length;){if(!items[index]?.isDisabled)return index;index+=direction}return -1},getClosestEnabledIndex=(items,currentIndex)=>{if(!items.length)return -1;if(currentIndex>=0&&currentIndex<items.length&&!items[currentIndex]?.isDisabled)return currentIndex;let forward=getNextEnabledIndex(items,currentIndex,1);return -1!==forward?forward:getNextEnabledIndex(items,currentIndex,-1)};export const useFocusByIndex=({data,containerRef,nodeSelector,preventScroll=!1})=>{let[focusedIndex,setFocusedIndex]=useState(()=>getClosestEnabledIndex(data,0)),focusedIndexRef=useRef(focusedIndex);useEffect(()=>{focusedIndexRef.current=focusedIndex},[focusedIndex]);let focusItemAtIndex=useCallback(index=>{if(-1===index)return;let container=containerRef.current;if(!container)return;let element=container.querySelector(`[${nodeSelector}="${index}"]`);!element||data[index]?.isDisabled||(element.focus({preventScroll}),setFocusedIndex(index))},[containerRef,data,nodeSelector,preventScroll]);return useEffect(()=>{let container=containerRef.current;if(!container)return;let handleContainerFocus=()=>{let nextIndex=getClosestEnabledIndex(data,focusedIndexRef.current);-1!==nextIndex&&focusItemAtIndex(nextIndex)},handleFocusIn=event=>{let target=event.target;if(!container.contains(target))return;let attributeValue=target.getAttribute(nodeSelector);if(null===attributeValue)return;let parsedIndex=Number(attributeValue);Number.isNaN(parsedIndex)||data[parsedIndex]?.isDisabled||setFocusedIndex(parsedIndex)},handleFocusOut=event=>{let nextTarget=event.relatedTarget;nextTarget&&container.contains(nextTarget)||setFocusedIndex(getClosestEnabledIndex(data,0))};return container.addEventListener("focus",handleContainerFocus),container.addEventListener("focusin",handleFocusIn),container.addEventListener("focusout",handleFocusOut),()=>{container.removeEventListener("focus",handleContainerFocus),container.removeEventListener("focusin",handleFocusIn),container.removeEventListener("focusout",handleFocusOut)}},[containerRef,data,focusItemAtIndex,nodeSelector]),{moveFocus:useCallback(offset=>{let nextIndex;if(!data.length)return;let direction=offset>0?1:-1,remainingSteps=Math.abs(offset);for(nextIndex=-1===focusedIndex?direction>0?-1:data.length:focusedIndex;remainingSteps>0;){let candidate=getNextEnabledIndex(data,nextIndex,direction);if(-1===candidate)return;nextIndex=candidate,remainingSteps-=1}nextIndex!==focusedIndex&&focusItemAtIndex(nextIndex)},[data,focusItemAtIndex,focusedIndex]),focusedIndex}};
@@ -1 +1 @@
1
- import React,{useMemo,useState,useEffect,useCallback}from"react";import{Button}from"../Button/Button";import{Box}from"../Box/Box";import{StyledList,StyledShowMore}from"../EntityList/styled-components";import{EntityTreeItem}from"./EntityTreeItem";import{useKeyboard}from"../../shared/useKeyboard";import{Text}from"../Typography/Text/Text";import{getNodeChildrenMap,getTreeCheckboxState,getVisibleActiveNodeId,getLeafNodeIds,filterTree,mapTree,trimDataByMaxSize}from"./tree";let flattenTree=(data,expandedIds,expadedAll)=>{let flattened=[];return data.forEach(node=>{flattened.push(node.id),(node.children.length>0&&expandedIds[node.id]||expadedAll)&&flattened.push(...flattenTree(node.children,expandedIds,expadedAll))}),flattened},getLastNodeOfList=({node,data,level,isParentsLastOfLvl})=>{let currentLastNodeOfLvl=node.id===data[data.length-1].id;return 0===level?currentLastNodeOfLvl:isParentsLastOfLvl&&currentLastNodeOfLvl},useTreeTruncation=({chunkSize,data,expandAll,nodeExpandedState})=>{let[maxNodesCount,setMaxNodesCount]=useState(chunkSize),{result,hasMoreNodes}=useMemo(()=>trimDataByMaxSize(data,nodeExpandedState,expandAll,maxNodesCount),[data,nodeExpandedState,expandAll,maxNodesCount]);return{handleIncreaseMaxNodeCount:useCallback(()=>{setMaxNodesCount(prev=>prev+chunkSize)},[chunkSize]),result,hasMoreNodes}},Node=({isFirstNode,nodeChildrenMap,nodeCheckboxState,nodeExpandedState,handleSelectionChange,handleToggle,expandAll,onNodeClick,hideBorder,size,showItemsCount,renderRightContent,activeId,focusedNodeId,node,level,renderFn,isLastNodeOfList,ariaLabelExpand,ariaLabelCollapse})=>{let readOnly=null===nodeCheckboxState,hasChildren=node.children.length>0,expandedState=!!expandAll||!!nodeExpandedState[node.id],leafItems=getLeafNodeIds(nodeChildrenMap,node.id),totalItemsCount=leafItems.length,selectedItemsCount=nodeCheckboxState?leafItems.filter(leafId=>"checked"===nodeCheckboxState[leafId]).length:null,countLabel=nodeCheckboxState?`(${selectedItemsCount}/${totalItemsCount})`:`(${totalItemsCount})`,lastLeaf=!hasChildren&&!node.isFiltered,isExpanded=lastLeaf?void 0:expandedState,handleClick=readOnly?()=>handleToggle(node.id):()=>handleSelectionChange(node.id),isFocused=focusedNodeId===node.id,{children,...nodeDataWithoutChildren}=node;return React.createElement(EntityTreeItem,{key:node.id,hideBorder:hideBorder||isLastNodeOfList&&(!isExpanded||node.isFiltered),tabIndex:isFocused||null===focusedNodeId&&isFirstNode?0:-1,size:size,lSpaceStep:level,onKeyDown:()=>handleClick(),description:node.description,renderLabel:({textSize})=>React.createElement(React.Fragment,null,node.label,showItemsCount&&!lastLeaf&&React.createElement(Text,{as:"span",size:textSize,color:"tertiary"}," ",countLabel)),isActive:activeId===node.id,isExpanded:isExpanded,isDisabledExpand:expandAll,checkboxProps:!readOnly&&{size:"s",name:node.label,checked:nodeCheckboxState?.[node.id]==="checked",indeterminate:nodeCheckboxState?.[node.id]==="indeterminate",onChange:()=>handleSelectionChange(node.id)},onExpandClick:e=>{e.stopPropagation(),handleToggle(node.id)},isClickable:readOnly,onClick:()=>{handleToggle(node.id),onNodeClick?.(nodeDataWithoutChildren)},renderRight:renderRightContent?sizeProps=>renderRightContent({...sizeProps,...node}):void 0,ariaLabelExpand:ariaLabelExpand,ariaLabelCollapse:ariaLabelCollapse,"aria-label":node.label,"aria-level":level+1},hasChildren&&React.createElement("ul",{role:"group"},renderFn({data:children,level:level+1,renderFn,isParentsLastOfLvl:isLastNodeOfList})))},makeRenderTreeBranches=renderTreeArgs=>({data,level,renderFn,isParentsLastOfLvl})=>data.map((node,i)=>{let isFirstNode=0===level&&0===i,isLastNodeOfList=getLastNodeOfList({node,data,level,isParentsLastOfLvl});return React.createElement(Node,{key:node.id,level:level,node:node,isFirstNode:isFirstNode,renderFn:renderFn,isLastNodeOfList:isLastNodeOfList,...renderTreeArgs})});export const BaseEntityTree=({ariaAttributes,data,selectedIds,onSelectionChange,onSelectionToggle,onNodeClick,expandedIds=[],onToggle,activeId,chunkSize=10,filterFn,onTreeChange,hideBorder=!1,size="m",showItemsCount=!0,showMoreButtonLabel,renderRightContent,"data-e2e-test-id":dataE2eTestId})=>{let nodeChildrenMap=Object.assign({},...data.map(tree=>getNodeChildrenMap(tree))),nodeCheckboxState=selectedIds?Object.assign({},...data.map(tree=>getTreeCheckboxState(nodeChildrenMap,tree.id,selectedIds))):null,nodeExpandedState=expandedIds.reduce((acc,id)=>(acc[id]=!0,acc),{}),visibleActiveNodeId=getVisibleActiveNodeId(nodeChildrenMap,nodeExpandedState,activeId),handleExpand=targetId=>{onToggle&&!expandedIds.includes(targetId)&&onToggle(expandedIds.concat([targetId]))},handleCollapse=targetId=>{onToggle&&expandedIds.includes(targetId)&&onToggle(expandedIds.filter(id=>id!==targetId))},dataShown=filterFn?data.map(tree=>filterTree(tree,filterFn)).filter(Boolean):data;useEffect(()=>{onTreeChange&&onTreeChange(dataShown.map(tree=>mapTree(tree,node=>({...node,checkedState:!!nodeCheckboxState&&nodeCheckboxState[node.id],isExpanded:!!nodeExpandedState[node.id]}))))},[dataShown,nodeCheckboxState,nodeExpandedState,onTreeChange]);let expandAll=!!filterFn,{hasMoreNodes,handleIncreaseMaxNodeCount,result}=useTreeTruncation({chunkSize,data:dataShown,nodeExpandedState,expandAll}),listRef=React.useRef(null),[focusedNodeId,setFocusedNodeId]=useState(null),[selectedIndex,setSelectedIndex]=useState(0),changeFocusIndex=index=>{let flatTreeIds=flattenTree(dataShown,nodeExpandedState,expandAll),newIndex=index+Math.max(flatTreeIds.indexOf(focusedNodeId),0);newIndex>=0&&newIndex<flatTreeIds.length&&(setSelectedIndex(newIndex),setFocusedNodeId(flatTreeIds[newIndex]))},firstNodeId=useMemo(()=>{let flatTreeIds=flattenTree(dataShown,nodeExpandedState,expandAll);return flatTreeIds.length>0?flatTreeIds[0]:null},[dataShown,nodeExpandedState,expandAll]);useKeyboard({ArrowDown:()=>{changeFocusIndex(1)},ArrowUp:()=>{changeFocusIndex(-1)},ArrowRight:()=>{expandAll||handleExpand(focusedNodeId||firstNodeId)},ArrowLeft:()=>{expandAll||handleCollapse(focusedNodeId||firstNodeId)}},listRef,!0),useEffect(()=>{if(listRef&&listRef.current&&selectedIndex>=0){let buttons=listRef.current.querySelectorAll('div[data-id="list-item"]'),button=buttons[Math.abs(selectedIndex)%buttons.length];button&&button.focus({preventScroll:!0})}},[selectedIndex]),useEffect(()=>{expandAll&&(setFocusedNodeId(null),setSelectedIndex(0))},[expandAll]);let renderTreeBranches=makeRenderTreeBranches({nodeChildrenMap,nodeCheckboxState,nodeExpandedState,handleSelectionChange:targetId=>{if(onSelectionChange){let isSelected,updatedSelectedIds=[];if(0===nodeChildrenMap[targetId].length)isSelected=!selectedIds.includes(targetId),updatedSelectedIds=selectedIds.includes(targetId)?selectedIds.filter(id=>id!==targetId):selectedIds.concat([targetId]);else{let affectedLeafNodeIds=getLeafNodeIds(nodeChildrenMap,targetId),hasUncheckedChildren=affectedLeafNodeIds.some(leafId=>!selectedIds.includes(leafId));updatedSelectedIds=hasUncheckedChildren?selectedIds.concat(affectedLeafNodeIds.filter(id=>!selectedIds.includes(id))):selectedIds.filter(id=>!affectedLeafNodeIds.includes(id)),isSelected=hasUncheckedChildren}onSelectionToggle?.(targetId,isSelected),onSelectionChange(updatedSelectedIds)}},handleToggle:targetId=>{expandedIds.includes(targetId)?handleCollapse(targetId):handleExpand(targetId)},onNodeClick:node=>{setFocusedNodeId(node.id),onNodeClick?.(node)},expandAll,hideBorder,size,showItemsCount,renderRightContent,activeId:visibleActiveNodeId,focusedNodeId,ariaLabelExpand:ariaAttributes?.ariaLabelExpand,ariaLabelCollapse:ariaAttributes?.ariaLabelCollapse});return React.createElement("div",null,React.createElement(StyledList,{ref:listRef,role:"tree","aria-multiselectable":!!nodeCheckboxState||void 0,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"EntityTree",size:size},renderTreeBranches({data:result,level:0,renderFn:renderTreeBranches})),hasMoreNodes&&React.createElement(StyledShowMore,null,React.createElement(Box,{alignText:"center",space:"xs"},React.createElement(Button,{fullWidth:!0,size:"s",variant:"tertiary",onClick:handleIncreaseMaxNodeCount},showMoreButtonLabel))))};
1
+ import React,{useMemo,useState,useEffect,useCallback}from"react";import{Button}from"../Button/Button";import{Box}from"../Box/Box";import{StyledList,StyledShowMore}from"../EntityList/styled-components";import{EntityTreeItem}from"./EntityTreeItem";import{useKeyboard}from"../../shared/useKeyboard";import{useFocusByIndex}from"../EntityList/useFocusByIndex";import{Text}from"../Typography/Text/Text";import{getNodeChildrenMap,getTreeCheckboxState,getVisibleActiveNodeId,getLeafNodeIds,filterTree,mapTree,trimDataByMaxSize}from"./tree";let flattenTree=(data,expandedIds,expadedAll)=>{let flattened=[];return data.forEach(node=>{flattened.push(node),(node.children.length>0&&expandedIds[node.id]||expadedAll)&&flattened.push(...flattenTree(node.children,expandedIds,expadedAll))}),flattened},getLastNodeOfList=({node,data,level,isParentsLastOfLvl})=>{let currentLastNodeOfLvl=node.id===data[data.length-1].id;return 0===level?currentLastNodeOfLvl:isParentsLastOfLvl&&currentLastNodeOfLvl},useTreeTruncation=({chunkSize,data,expandAll,nodeExpandedState})=>{let[maxNodesCount,setMaxNodesCount]=useState(chunkSize),{result,hasMoreNodes}=useMemo(()=>trimDataByMaxSize(data,nodeExpandedState,expandAll,maxNodesCount),[data,nodeExpandedState,expandAll,maxNodesCount]);return{handleIncreaseMaxNodeCount:useCallback(()=>{setMaxNodesCount(prev=>prev+chunkSize)},[chunkSize]),result,hasMoreNodes}},Node=({isFirstNode,nodeChildrenMap,nodeCheckboxState,nodeExpandedState,handleSelectionChange,handleToggle,expandAll,onNodeClick,hideBorder,size,showItemsCount,renderRightContent,activeId,focusedNodeId,node,level,renderFn,isLastNodeOfList,ariaLabelExpand,ariaLabelCollapse,visibleNodeIndexMap})=>{let readOnly=null===nodeCheckboxState,hasChildren=node.children.length>0,expandedState=!!expandAll||!!nodeExpandedState[node.id],leafItems=getLeafNodeIds(nodeChildrenMap,node.id),totalItemsCount=leafItems.length,selectedItemsCount=nodeCheckboxState?leafItems.filter(leafId=>"checked"===nodeCheckboxState[leafId]).length:null,countLabel=nodeCheckboxState?`(${selectedItemsCount}/${totalItemsCount})`:`(${totalItemsCount})`,lastLeaf=!hasChildren&&!node.isFiltered,isExpanded=lastLeaf?void 0:expandedState,{children,...nodeDataWithoutChildren}=node,isFocused=focusedNodeId===node.id;return React.createElement(EntityTreeItem,{key:node.id,"data-list-item":visibleNodeIndexMap[node.id],hideBorder:hideBorder||isLastNodeOfList&&(!isExpanded||node.isFiltered),tabIndex:isFocused||null===focusedNodeId&&isFirstNode?0:-1,size:size,lSpaceStep:level,onSpaceEnterPress:()=>{if(readOnly){handleToggle(node.id),onNodeClick?.(nodeDataWithoutChildren);return}handleSelectionChange(node.id)},description:node.description,renderLabel:({textSize})=>React.createElement(React.Fragment,null,node.label,showItemsCount&&!lastLeaf&&React.createElement(Text,{as:"span",size:textSize,color:"tertiary"}," ",countLabel)),isActive:activeId===node.id,isExpanded:isExpanded,isDisabledExpand:expandAll,checkboxProps:!readOnly&&{size:"s",name:node.label,checked:nodeCheckboxState?.[node.id]==="checked",indeterminate:nodeCheckboxState?.[node.id]==="indeterminate",onChange:()=>handleSelectionChange(node.id)},onExpandClick:e=>{e.stopPropagation(),handleToggle(node.id)},isClickable:readOnly,onClick:()=>{handleToggle(node.id),onNodeClick?.(nodeDataWithoutChildren)},renderRight:renderRightContent?sizeProps=>renderRightContent({...sizeProps,...node}):void 0,ariaLabelExpand:ariaLabelExpand,ariaLabelCollapse:ariaLabelCollapse,"aria-label":node.label,"aria-level":level+1},hasChildren&&React.createElement("ul",{role:"group"},renderFn({data:children,level:level+1,renderFn,isParentsLastOfLvl:isLastNodeOfList})))},makeRenderTreeBranches=renderTreeArgs=>({data,level,renderFn,isParentsLastOfLvl})=>data.map((node,i)=>{let isFirstNode=0===level&&0===i,isLastNodeOfList=getLastNodeOfList({node,data,level,isParentsLastOfLvl});return React.createElement(Node,{key:node.id,level:level,node:node,isFirstNode:isFirstNode,renderFn:renderFn,isLastNodeOfList:isLastNodeOfList,...renderTreeArgs})});export const BaseEntityTree=({ariaAttributes,data,selectedIds,onSelectionChange,onSelectionToggle,onNodeClick,expandedIds=[],onToggle,activeId,chunkSize=10,filterFn,onTreeChange,hideBorder=!1,size="m",showItemsCount=!0,showMoreButtonLabel,renderRightContent,"data-e2e-test-id":dataE2eTestId})=>{let nodeChildrenMap=Object.assign({},...data.map(tree=>getNodeChildrenMap(tree))),nodeCheckboxState=selectedIds?Object.assign({},...data.map(tree=>getTreeCheckboxState(nodeChildrenMap,tree.id,selectedIds))):null,nodeExpandedState=expandedIds.reduce((acc,id)=>(acc[id]=!0,acc),{}),visibleActiveNodeId=getVisibleActiveNodeId(nodeChildrenMap,nodeExpandedState,activeId),handleExpand=useCallback(targetId=>{onToggle&&!expandedIds.includes(targetId)&&onToggle(expandedIds.concat([targetId]))},[expandedIds,onToggle]),handleCollapse=useCallback(targetId=>{onToggle&&expandedIds.includes(targetId)&&onToggle(expandedIds.filter(id=>id!==targetId))},[expandedIds,onToggle]),handleToggle=useCallback(targetId=>{expandedIds.includes(targetId)?handleCollapse(targetId):handleExpand(targetId)},[expandedIds,handleCollapse,handleExpand]),dataShown=filterFn?data.map(tree=>filterTree(tree,filterFn)).filter(Boolean):data;useEffect(()=>{onTreeChange&&onTreeChange(dataShown.map(tree=>mapTree(tree,node=>({...node,checkedState:!!nodeCheckboxState&&nodeCheckboxState[node.id],isExpanded:!!nodeExpandedState[node.id]}))))},[dataShown,nodeCheckboxState,nodeExpandedState,onTreeChange]);let expandAll=!!filterFn,{hasMoreNodes,handleIncreaseMaxNodeCount,result}=useTreeTruncation({chunkSize,data:dataShown,nodeExpandedState,expandAll}),listRef=React.useRef(null),visibleNodes=useMemo(()=>flattenTree(result,nodeExpandedState,expandAll),[result,nodeExpandedState,expandAll]),visibleNodeIndexMap=useMemo(()=>visibleNodes.reduce((acc,node,index)=>(acc[node.id]=index,acc),{}),[visibleNodes]),{moveFocus,focusedIndex}=useFocusByIndex({containerRef:listRef,nodeSelector:"data-list-item",data:useMemo(()=>visibleNodes.map(node=>({id:node.id,isDisabled:!!node.isDisabled})),[visibleNodes])}),focusedNodeId=focusedIndex>=0?visibleNodes[focusedIndex]?.id??null:null;useKeyboard({ArrowDown:()=>{moveFocus(1)},ArrowUp:()=>{moveFocus(-1)},ArrowRight:()=>{!expandAll&&focusedNodeId&&nodeChildrenMap[focusedNodeId]?.length&&!nodeExpandedState[focusedNodeId]&&handleExpand(focusedNodeId)},ArrowLeft:()=>{!expandAll&&focusedNodeId&&nodeChildrenMap[focusedNodeId]?.length&&nodeExpandedState[focusedNodeId]&&handleCollapse(focusedNodeId)}},listRef,!!visibleNodes.length);let renderTreeBranches=makeRenderTreeBranches({nodeChildrenMap,nodeCheckboxState,nodeExpandedState,handleSelectionChange:targetId=>{if(onSelectionChange){let isSelected,updatedSelectedIds=[];if(0===nodeChildrenMap[targetId].length)isSelected=!selectedIds.includes(targetId),updatedSelectedIds=selectedIds.includes(targetId)?selectedIds.filter(id=>id!==targetId):selectedIds.concat([targetId]);else{let affectedLeafNodeIds=getLeafNodeIds(nodeChildrenMap,targetId),hasUncheckedChildren=affectedLeafNodeIds.some(leafId=>!selectedIds.includes(leafId));updatedSelectedIds=hasUncheckedChildren?selectedIds.concat(affectedLeafNodeIds.filter(id=>!selectedIds.includes(id))):selectedIds.filter(id=>!affectedLeafNodeIds.includes(id)),isSelected=hasUncheckedChildren}onSelectionToggle?.(targetId,isSelected),onSelectionChange(updatedSelectedIds)}},handleToggle,onNodeClick:node=>{onNodeClick?.(node)},expandAll,hideBorder,size,showItemsCount,renderRightContent,activeId:visibleActiveNodeId,focusedNodeId,visibleNodeIndexMap,ariaLabelExpand:ariaAttributes?.ariaLabelExpand,ariaLabelCollapse:ariaAttributes?.ariaLabelCollapse});return React.createElement("div",null,React.createElement(StyledList,{ref:listRef,role:"tree","aria-multiselectable":!!nodeCheckboxState||void 0,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"EntityTree",size:size},renderTreeBranches({data:result,level:0,renderFn:renderTreeBranches})),hasMoreNodes&&React.createElement(StyledShowMore,null,React.createElement(Box,{alignText:"center",space:"xs"},React.createElement(Button,{fullWidth:!0,size:"s",variant:"tertiary",onClick:handleIncreaseMaxNodeCount},showMoreButtonLabel))))};
@@ -1,3 +1,3 @@
1
1
  import React from "react";
2
2
  import type { EntityListItemProps } from "../EntityList/types";
3
- export declare const EntityTreeItem: ({ checkboxProps, children, description, hideBorder, isActive, isClickable, isDisabled, isDisabledExpand, isExpanded, lSpaceStep, onClick, onExpandClick, onKeyDown, renderLabel, renderLeft, renderRight, size, tabIndex, ariaLabelExpand, ariaLabelCollapse, "aria-level": ariaLevel, "aria-label": ariaLabel, }: EntityListItemProps) => React.ReactElement;
3
+ export declare const EntityTreeItem: ({ checkboxProps, children, description, hideBorder, isActive, isClickable, isDisabled, isDisabledExpand, isExpanded, lSpaceStep, onClick, onExpandClick, onSpaceEnterPress, renderLabel, renderLeft, renderRight, size, tabIndex, ariaLabelExpand, ariaLabelCollapse, "aria-level": ariaLevel, "aria-label": ariaLabel, "data-list-item": dataListItem, }: EntityListItemProps) => React.ReactElement;
@@ -1 +1 @@
1
- import React,{useCallback,useRef}from"react";import styled from"@emotion/styled";import{useResponsiveValue}from"../../shared/mediaQueries";import{EntityTreeItemExpandButton}from"./EntityTreeItemExpandButton";import{useKeyboard}from"../../shared/useKeyboard";import{EntityItemBody}from"../EntityList/EntityItemBody";import{StyledEntityItemLi,StyledEntityListItemWrapper,StyledEntityListItemButton}from"../EntityList/styled-components";let StyledEntityTreeItemWrapper=styled(StyledEntityListItemWrapper,{target:"e1i82w6s0",label:"StyledEntityTreeItemWrapper"})({paddingLeft:"0 !important"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5VHJlZS9FbnRpdHlUcmVlSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eVRyZWUvRW50aXR5VHJlZUl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBFbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvbiB9IGZyb20gXCIuL0VudGl0eVRyZWVJdGVtRXhwYW5kQnV0dG9uXCI7XG5pbXBvcnQgeyB1c2VLZXlib2FyZCB9IGZyb20gXCIuLi8uLi9zaGFyZWQvdXNlS2V5Ym9hcmRcIjtcbmltcG9ydCB7IEVudGl0eUl0ZW1Cb2R5IH0gZnJvbSBcIi4uL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHlcIjtcbmltcG9ydCB7XG4gIFN0eWxlZEVudGl0eUl0ZW1MaSxcbiAgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyLFxuICBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbixcbn0gZnJvbSBcIi4uL0VudGl0eUxpc3Qvc3R5bGVkLWNvbXBvbmVudHNcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcyB9IGZyb20gXCIuLi9FbnRpdHlMaXN0L3R5cGVzXCI7XG5cbmNvbnN0IFN0eWxlZEVudGl0eVRyZWVJdGVtV3JhcHBlciA9IHN0eWxlZChTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXIpKHtcbiAgcGFkZGluZ0xlZnQ6IFwiMCAhaW1wb3J0YW50XCIsIC8vIFwiaW1wb3J0YW50XCIgaXMgbmVlZGVkIHRvIG92ZXJyaWRlIHRoZSBAbWVkaWEgcXVlcnkgb2YgTVEgZnVuY3Rpb25cbn0pO1xuXG5jb25zdCBTdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lciA9IHN0eWxlZChTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbik8e1xuICBoYXNFeHBhbmRhYmxlSWNvbjogYm9vbGVhbjtcbn0+KCh7IHRoZW1lLCBoYXNFeHBhbmRhYmxlSWNvbiwgbFNwYWNlU3RlcCB9KSA9PiB7XG4gIGNvbnN0IGdldFNpemUgPSAoYmFzZU9mZnNldDogc3RyaW5nLCBkZWVwZXN0Tm9kZU9mZnNldDogc3RyaW5nKSA9PlxuICAgIGBjYWxjKCR7YmFzZU9mZnNldH0gKiAke2xTcGFjZVN0ZXB9ICsgJHtcbiAgICAgIGhhc0V4cGFuZGFibGVJY29uID8gXCIwcHhcIiA6IGRlZXBlc3ROb2RlT2Zmc2V0XG4gICAgfSArICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHN9KWA7XG5cbiAgcmV0dXJuIHtcbiAgICBcIiY6Zm9jdXMtdmlzaWJsZVwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgICB9LFxuICAgIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgICBwYWRkaW5nTGVmdDogW1xuICAgICAgICAvLyA0MnB4IGFuZCA1NnB4IGFyZSBFeHBhbmQgYnV0dG9uIHdpZHRoICsgcGFkZGluZ1xuICAgICAgICAvLyBpdCdzIG5lZWRlZCBmb3IgYSBkZWVwZXN0IG5vZGUgd2l0aG91dCBleHBhbmRCdXR0b25cbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm0sIFwiNDJweFwiKSxcbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLCBcIjU2cHhcIiksXG4gICAgICBdLFxuICAgIH0pLFxuICB9O1xufSk7XG5cbmV4cG9ydCBjb25zdCBFbnRpdHlUcmVlSXRlbSA9ICh7XG4gIGNoZWNrYm94UHJvcHMsXG4gIGNoaWxkcmVuLFxuICBkZXNjcmlwdGlvbixcbiAgaGlkZUJvcmRlcixcbiAgaXNBY3RpdmUsXG4gIGlzQ2xpY2thYmxlLFxuICBpc0Rpc2FibGVkLFxuICBpc0Rpc2FibGVkRXhwYW5kLFxuICBpc0V4cGFuZGVkLFxuICBsU3BhY2VTdGVwLFxuICBvbkNsaWNrLFxuICBvbkV4cGFuZENsaWNrLFxuICBvbktleURvd24sXG4gIHJlbmRlckxhYmVsLFxuICByZW5kZXJMZWZ0LFxuICByZW5kZXJSaWdodCxcbiAgc2l6ZSA9IFwibVwiLFxuICB0YWJJbmRleCxcbiAgYXJpYUxhYmVsRXhwYW5kLFxuICBhcmlhTGFiZWxDb2xsYXBzZSxcbiAgXCJhcmlhLWxldmVsXCI6IGFyaWFMZXZlbCxcbiAgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCxcbn06IEVudGl0eUxpc3RJdGVtUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQgPT4ge1xuICBjb25zdCBoYXNFeHBhbmRhYmxlSWNvbiA9IGlzRXhwYW5kZWQgIT09IHVuZGVmaW5lZDtcblxuICBjb25zdCBoYW5kbGVPbkNsaWNrID0gdXNlQ2FsbGJhY2soXG4gICAgKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHtcbiAgICAgIGlmIChvbkNsaWNrKSB7XG4gICAgICAgIG9uQ2xpY2soZSk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbb25DbGlja11cbiAgKTtcblxuICBjb25zdCBidXR0b25SZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpO1xuXG4gIHVzZUtleWJvYXJkKFxuICAgIHtcbiAgICAgIFwiU3BhY2UgRW50ZXJcIjogb25LZXlEb3duLFxuICAgIH0sXG4gICAgYnV0dG9uUmVmLFxuICAgIHRhYkluZGV4ID09PSAwICYmIChpc0NsaWNrYWJsZSB8fCAhIWNoZWNrYm94UHJvcHMpLFxuICAgIHRydWVcbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRFbnRpdHlJdGVtTGlcbiAgICAgIHJvbGU9XCJ0cmVlaXRlbVwiXG4gICAgICBhcmlhLWV4cGFuZGVkPXtoYXNFeHBhbmRhYmxlSWNvbiA/IGlzRXhwYW5kZWQgOiB1bmRlZmluZWR9XG4gICAgICBhcmlhLWNoZWNrZWQ9e2NoZWNrYm94UHJvcHM/LmNoZWNrZWR9XG4gICAgICBhcmlhLWxhYmVsPXthcmlhTGFiZWx9XG4gICAgICBhcmlhLWxldmVsPXthcmlhTGV2ZWx9XG4gICAgPlxuICAgICAgPFN0eWxlZEVudGl0eVRyZWVJdGVtQ29udGFpbmVyXG4gICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgIHJlZj17YnV0dG9uUmVmfVxuICAgICAgICBkYXRhLWlkPVwibGlzdC1pdGVtXCJcbiAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICByb2xlPVwicHJlc2VudGF0aW9uXCJcbiAgICAgICAgaXNBY3RpdmU9e2lzQWN0aXZlfVxuICAgICAgICBoYXNFeHBhbmRhYmxlSWNvbj17aGFzRXhwYW5kYWJsZUljb259XG4gICAgICAgIGxTcGFjZVN0ZXA9e2xTcGFjZVN0ZXB9XG4gICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIG9uQ2xpY2s9e2hhbmRsZU9uQ2xpY2t9XG4gICAgICAgIGlzQ2xpY2thYmxlPXtpc0NsaWNrYWJsZX1cbiAgICAgID5cbiAgICAgICAge2hhc0V4cGFuZGFibGVJY29uICYmIChcbiAgICAgICAgICA8RW50aXR5VHJlZUl0ZW1FeHBhbmRCdXR0b25cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgICBpc0Rpc2FibGVkPXtpc0Rpc2FibGVkRXhwYW5kIHx8IGlzRGlzYWJsZWR9XG4gICAgICAgICAgICBpc0V4cGFuZGVkPXtpc0V4cGFuZGVkfVxuICAgICAgICAgICAgb25DbGljaz17b25FeHBhbmRDbGlja31cbiAgICAgICAgICAgIGFyaWFMYWJlbEV4cGFuZD17YXJpYUxhYmVsRXhwYW5kfVxuICAgICAgICAgICAgYXJpYUxhYmVsQ29sbGFwc2U9e2FyaWFMYWJlbENvbGxhcHNlfVxuICAgICAgICAgIC8+XG4gICAgICAgICl9XG4gICAgICAgIDxTdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXJcbiAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgIGhpZGVCb3JkZXI9e2hpZGVCb3JkZXIgfHwgc2l6ZSA9PT0gXCJ4c1wifVxuICAgICAgICA+XG4gICAgICAgICAgPEVudGl0eUl0ZW1Cb2R5XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICAgICAgZGVzY3JpcHRpb249e2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgcmVuZGVyTGFiZWw9e3JlbmRlckxhYmVsfVxuICAgICAgICAgICAgcmVuZGVyTGVmdD17cmVuZGVyTGVmdH1cbiAgICAgICAgICAgIHJlbmRlclJpZ2h0PXtyZW5kZXJSaWdodH1cbiAgICAgICAgICAgIGNoZWNrYm94UHJvcHM9e2NoZWNrYm94UHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9TdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXI+XG4gICAgICA8L1N0eWxlZEVudGl0eVRyZWVJdGVtQ29udGFpbmVyPlxuICAgICAge2lzRXhwYW5kZWQgJiYgY2hpbGRyZW59XG4gICAgPC9TdHlsZWRFbnRpdHlJdGVtTGk+XG4gICk7XG59O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWFvQyJ9 */"),StyledEntityTreeItemContainer=styled(StyledEntityListItemButton,{target:"e1i82w6s1",label:"StyledEntityTreeItemContainer"})(({theme,hasExpandableIcon,lSpaceStep})=>{let getSize=(baseOffset,deepestNodeOffset)=>`calc(${baseOffset} * ${lSpaceStep} + ${hasExpandableIcon?"0px":deepestNodeOffset} + ${theme.variables.size.spacing.xxs})`;return{"&:focus-visible":{backgroundColor:theme.values.color.background.transparent.active},...useResponsiveValue({paddingLeft:[getSize(theme.variables.size.spacing.m,"42px"),getSize(theme.variables.size.spacing.xl,"56px")]})}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5VHJlZS9FbnRpdHlUcmVlSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eVRyZWUvRW50aXR5VHJlZUl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBFbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvbiB9IGZyb20gXCIuL0VudGl0eVRyZWVJdGVtRXhwYW5kQnV0dG9uXCI7XG5pbXBvcnQgeyB1c2VLZXlib2FyZCB9IGZyb20gXCIuLi8uLi9zaGFyZWQvdXNlS2V5Ym9hcmRcIjtcbmltcG9ydCB7IEVudGl0eUl0ZW1Cb2R5IH0gZnJvbSBcIi4uL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHlcIjtcbmltcG9ydCB7XG4gIFN0eWxlZEVudGl0eUl0ZW1MaSxcbiAgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyLFxuICBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbixcbn0gZnJvbSBcIi4uL0VudGl0eUxpc3Qvc3R5bGVkLWNvbXBvbmVudHNcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcyB9IGZyb20gXCIuLi9FbnRpdHlMaXN0L3R5cGVzXCI7XG5cbmNvbnN0IFN0eWxlZEVudGl0eVRyZWVJdGVtV3JhcHBlciA9IHN0eWxlZChTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXIpKHtcbiAgcGFkZGluZ0xlZnQ6IFwiMCAhaW1wb3J0YW50XCIsIC8vIFwiaW1wb3J0YW50XCIgaXMgbmVlZGVkIHRvIG92ZXJyaWRlIHRoZSBAbWVkaWEgcXVlcnkgb2YgTVEgZnVuY3Rpb25cbn0pO1xuXG5jb25zdCBTdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lciA9IHN0eWxlZChTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbik8e1xuICBoYXNFeHBhbmRhYmxlSWNvbjogYm9vbGVhbjtcbn0+KCh7IHRoZW1lLCBoYXNFeHBhbmRhYmxlSWNvbiwgbFNwYWNlU3RlcCB9KSA9PiB7XG4gIGNvbnN0IGdldFNpemUgPSAoYmFzZU9mZnNldDogc3RyaW5nLCBkZWVwZXN0Tm9kZU9mZnNldDogc3RyaW5nKSA9PlxuICAgIGBjYWxjKCR7YmFzZU9mZnNldH0gKiAke2xTcGFjZVN0ZXB9ICsgJHtcbiAgICAgIGhhc0V4cGFuZGFibGVJY29uID8gXCIwcHhcIiA6IGRlZXBlc3ROb2RlT2Zmc2V0XG4gICAgfSArICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHN9KWA7XG5cbiAgcmV0dXJuIHtcbiAgICBcIiY6Zm9jdXMtdmlzaWJsZVwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgICB9LFxuICAgIC4uLnVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgICBwYWRkaW5nTGVmdDogW1xuICAgICAgICAvLyA0MnB4IGFuZCA1NnB4IGFyZSBFeHBhbmQgYnV0dG9uIHdpZHRoICsgcGFkZGluZ1xuICAgICAgICAvLyBpdCdzIG5lZWRlZCBmb3IgYSBkZWVwZXN0IG5vZGUgd2l0aG91dCBleHBhbmRCdXR0b25cbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm0sIFwiNDJweFwiKSxcbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLCBcIjU2cHhcIiksXG4gICAgICBdLFxuICAgIH0pLFxuICB9O1xufSk7XG5cbmV4cG9ydCBjb25zdCBFbnRpdHlUcmVlSXRlbSA9ICh7XG4gIGNoZWNrYm94UHJvcHMsXG4gIGNoaWxkcmVuLFxuICBkZXNjcmlwdGlvbixcbiAgaGlkZUJvcmRlcixcbiAgaXNBY3RpdmUsXG4gIGlzQ2xpY2thYmxlLFxuICBpc0Rpc2FibGVkLFxuICBpc0Rpc2FibGVkRXhwYW5kLFxuICBpc0V4cGFuZGVkLFxuICBsU3BhY2VTdGVwLFxuICBvbkNsaWNrLFxuICBvbkV4cGFuZENsaWNrLFxuICBvbktleURvd24sXG4gIHJlbmRlckxhYmVsLFxuICByZW5kZXJMZWZ0LFxuICByZW5kZXJSaWdodCxcbiAgc2l6ZSA9IFwibVwiLFxuICB0YWJJbmRleCxcbiAgYXJpYUxhYmVsRXhwYW5kLFxuICBhcmlhTGFiZWxDb2xsYXBzZSxcbiAgXCJhcmlhLWxldmVsXCI6IGFyaWFMZXZlbCxcbiAgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCxcbn06IEVudGl0eUxpc3RJdGVtUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQgPT4ge1xuICBjb25zdCBoYXNFeHBhbmRhYmxlSWNvbiA9IGlzRXhwYW5kZWQgIT09IHVuZGVmaW5lZDtcblxuICBjb25zdCBoYW5kbGVPbkNsaWNrID0gdXNlQ2FsbGJhY2soXG4gICAgKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHtcbiAgICAgIGlmIChvbkNsaWNrKSB7XG4gICAgICAgIG9uQ2xpY2soZSk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbb25DbGlja11cbiAgKTtcblxuICBjb25zdCBidXR0b25SZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpO1xuXG4gIHVzZUtleWJvYXJkKFxuICAgIHtcbiAgICAgIFwiU3BhY2UgRW50ZXJcIjogb25LZXlEb3duLFxuICAgIH0sXG4gICAgYnV0dG9uUmVmLFxuICAgIHRhYkluZGV4ID09PSAwICYmIChpc0NsaWNrYWJsZSB8fCAhIWNoZWNrYm94UHJvcHMpLFxuICAgIHRydWVcbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRFbnRpdHlJdGVtTGlcbiAgICAgIHJvbGU9XCJ0cmVlaXRlbVwiXG4gICAgICBhcmlhLWV4cGFuZGVkPXtoYXNFeHBhbmRhYmxlSWNvbiA/IGlzRXhwYW5kZWQgOiB1bmRlZmluZWR9XG4gICAgICBhcmlhLWNoZWNrZWQ9e2NoZWNrYm94UHJvcHM/LmNoZWNrZWR9XG4gICAgICBhcmlhLWxhYmVsPXthcmlhTGFiZWx9XG4gICAgICBhcmlhLWxldmVsPXthcmlhTGV2ZWx9XG4gICAgPlxuICAgICAgPFN0eWxlZEVudGl0eVRyZWVJdGVtQ29udGFpbmVyXG4gICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgIHJlZj17YnV0dG9uUmVmfVxuICAgICAgICBkYXRhLWlkPVwibGlzdC1pdGVtXCJcbiAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICByb2xlPVwicHJlc2VudGF0aW9uXCJcbiAgICAgICAgaXNBY3RpdmU9e2lzQWN0aXZlfVxuICAgICAgICBoYXNFeHBhbmRhYmxlSWNvbj17aGFzRXhwYW5kYWJsZUljb259XG4gICAgICAgIGxTcGFjZVN0ZXA9e2xTcGFjZVN0ZXB9XG4gICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIG9uQ2xpY2s9e2hhbmRsZU9uQ2xpY2t9XG4gICAgICAgIGlzQ2xpY2thYmxlPXtpc0NsaWNrYWJsZX1cbiAgICAgID5cbiAgICAgICAge2hhc0V4cGFuZGFibGVJY29uICYmIChcbiAgICAgICAgICA8RW50aXR5VHJlZUl0ZW1FeHBhbmRCdXR0b25cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgICBpc0Rpc2FibGVkPXtpc0Rpc2FibGVkRXhwYW5kIHx8IGlzRGlzYWJsZWR9XG4gICAgICAgICAgICBpc0V4cGFuZGVkPXtpc0V4cGFuZGVkfVxuICAgICAgICAgICAgb25DbGljaz17b25FeHBhbmRDbGlja31cbiAgICAgICAgICAgIGFyaWFMYWJlbEV4cGFuZD17YXJpYUxhYmVsRXhwYW5kfVxuICAgICAgICAgICAgYXJpYUxhYmVsQ29sbGFwc2U9e2FyaWFMYWJlbENvbGxhcHNlfVxuICAgICAgICAgIC8+XG4gICAgICAgICl9XG4gICAgICAgIDxTdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXJcbiAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgIGhpZGVCb3JkZXI9e2hpZGVCb3JkZXIgfHwgc2l6ZSA9PT0gXCJ4c1wifVxuICAgICAgICA+XG4gICAgICAgICAgPEVudGl0eUl0ZW1Cb2R5XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICAgICAgZGVzY3JpcHRpb249e2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgcmVuZGVyTGFiZWw9e3JlbmRlckxhYmVsfVxuICAgICAgICAgICAgcmVuZGVyTGVmdD17cmVuZGVyTGVmdH1cbiAgICAgICAgICAgIHJlbmRlclJpZ2h0PXtyZW5kZXJSaWdodH1cbiAgICAgICAgICAgIGNoZWNrYm94UHJvcHM9e2NoZWNrYm94UHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9TdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXI+XG4gICAgICA8L1N0eWxlZEVudGl0eVRyZWVJdGVtQ29udGFpbmVyPlxuICAgICAge2lzRXhwYW5kZWQgJiYgY2hpbGRyZW59XG4gICAgPC9TdHlsZWRFbnRpdHlJdGVtTGk+XG4gICk7XG59O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCc0MifQ== */");export const EntityTreeItem=({checkboxProps,children,description,hideBorder,isActive,isClickable,isDisabled,isDisabledExpand,isExpanded,lSpaceStep,onClick,onExpandClick,onKeyDown,renderLabel,renderLeft,renderRight,size="m",tabIndex,ariaLabelExpand,ariaLabelCollapse,"aria-level":ariaLevel,"aria-label":ariaLabel})=>{let hasExpandableIcon=void 0!==isExpanded,handleOnClick=useCallback(e=>{onClick&&onClick(e)},[onClick]),buttonRef=useRef(null);return useKeyboard({"Space Enter":onKeyDown},buttonRef,0===tabIndex&&(isClickable||!!checkboxProps),!0),React.createElement(StyledEntityItemLi,{role:"treeitem","aria-expanded":hasExpandableIcon?isExpanded:void 0,"aria-checked":checkboxProps?.checked,"aria-label":ariaLabel,"aria-level":ariaLevel},React.createElement(StyledEntityTreeItemContainer,{size:size,ref:buttonRef,"data-id":"list-item",tabIndex:tabIndex,role:"presentation",isActive:isActive,hasExpandableIcon:hasExpandableIcon,lSpaceStep:lSpaceStep,isDisabled:isDisabled,onClick:handleOnClick,isClickable:isClickable},hasExpandableIcon&&React.createElement(EntityTreeItemExpandButton,{size:size,tabIndex:tabIndex,isDisabled:isDisabledExpand||isDisabled,isExpanded:isExpanded,onClick:onExpandClick,ariaLabelExpand:ariaLabelExpand,ariaLabelCollapse:ariaLabelCollapse}),React.createElement(StyledEntityTreeItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},React.createElement(EntityItemBody,{size:size,tabIndex:tabIndex,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight,checkboxProps:checkboxProps}))),isExpanded&&children)};
1
+ import React,{useCallback,useRef}from"react";import styled from"@emotion/styled";import{useResponsiveValue}from"../../shared/mediaQueries";import{EntityTreeItemExpandButton}from"./EntityTreeItemExpandButton";import{useKeyboard}from"../../shared/useKeyboard";import{getFocusStyles}from"../../shared/mixins";import{EntityItemBody}from"../EntityList/EntityItemBody";import{StyledEntityItemLi,StyledEntityListItemWrapper,StyledEntityListItemButton}from"../EntityList/styled-components";let StyledEntityTreeItemWrapper=styled(StyledEntityListItemWrapper,{target:"e29eivf0",label:"StyledEntityTreeItemWrapper"})({paddingLeft:"0 !important"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5VHJlZS9FbnRpdHlUcmVlSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eVRyZWUvRW50aXR5VHJlZUl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBFbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvbiB9IGZyb20gXCIuL0VudGl0eVRyZWVJdGVtRXhwYW5kQnV0dG9uXCI7XG5pbXBvcnQgeyB1c2VLZXlib2FyZCB9IGZyb20gXCIuLi8uLi9zaGFyZWQvdXNlS2V5Ym9hcmRcIjtcbmltcG9ydCB7IGdldEZvY3VzU3R5bGVzIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9taXhpbnNcIjtcbmltcG9ydCB7IEVudGl0eUl0ZW1Cb2R5IH0gZnJvbSBcIi4uL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHlcIjtcbmltcG9ydCB7XG4gIFN0eWxlZEVudGl0eUl0ZW1MaSxcbiAgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyLFxuICBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbixcbn0gZnJvbSBcIi4uL0VudGl0eUxpc3Qvc3R5bGVkLWNvbXBvbmVudHNcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcyB9IGZyb20gXCIuLi9FbnRpdHlMaXN0L3R5cGVzXCI7XG5cbmNvbnN0IFN0eWxlZEVudGl0eVRyZWVJdGVtV3JhcHBlciA9IHN0eWxlZChTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXIpKHtcbiAgcGFkZGluZ0xlZnQ6IFwiMCAhaW1wb3J0YW50XCIsIC8vIFwiaW1wb3J0YW50XCIgaXMgbmVlZGVkIHRvIG92ZXJyaWRlIHRoZSBAbWVkaWEgcXVlcnkgb2YgTVEgZnVuY3Rpb25cbn0pO1xuXG5jb25zdCBTdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lciA9IHN0eWxlZChTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbik8e1xuICBoYXNFeHBhbmRhYmxlSWNvbjogYm9vbGVhbjtcbn0+KCh7IHRoZW1lLCBoYXNFeHBhbmRhYmxlSWNvbiwgbFNwYWNlU3RlcCB9KSA9PiB7XG4gIGNvbnN0IGdldFNpemUgPSAoYmFzZU9mZnNldDogc3RyaW5nLCBkZWVwZXN0Tm9kZU9mZnNldDogc3RyaW5nKSA9PlxuICAgIGBjYWxjKCR7YmFzZU9mZnNldH0gKiAke2xTcGFjZVN0ZXB9ICsgJHtcbiAgICAgIGhhc0V4cGFuZGFibGVJY29uID8gXCIwcHhcIiA6IGRlZXBlc3ROb2RlT2Zmc2V0XG4gICAgfSArICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHN9KWA7XG5cbiAgcmV0dXJuIHtcbiAgICAuLi5nZXRGb2N1c1N0eWxlcyh7IG9mZnNldDogLTIgfSksXG4gICAgLi4udXNlUmVzcG9uc2l2ZVZhbHVlKHtcbiAgICAgIHBhZGRpbmdMZWZ0OiBbXG4gICAgICAgIC8vIDQycHggYW5kIDU2cHggYXJlIEV4cGFuZCBidXR0b24gd2lkdGggKyBwYWRkaW5nXG4gICAgICAgIC8vIGl0J3MgbmVlZGVkIGZvciBhIGRlZXBlc3Qgbm9kZSB3aXRob3V0IGV4cGFuZEJ1dHRvblxuICAgICAgICBnZXRTaXplKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSwgXCI0MnB4XCIpLFxuICAgICAgICBnZXRTaXplKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGwsIFwiNTZweFwiKSxcbiAgICAgIF0sXG4gICAgfSksXG4gIH07XG59KTtcblxuZXhwb3J0IGNvbnN0IEVudGl0eVRyZWVJdGVtID0gKHtcbiAgY2hlY2tib3hQcm9wcyxcbiAgY2hpbGRyZW4sXG4gIGRlc2NyaXB0aW9uLFxuICBoaWRlQm9yZGVyLFxuICBpc0FjdGl2ZSxcbiAgaXNDbGlja2FibGUsXG4gIGlzRGlzYWJsZWQsXG4gIGlzRGlzYWJsZWRFeHBhbmQsXG4gIGlzRXhwYW5kZWQsXG4gIGxTcGFjZVN0ZXAsXG4gIG9uQ2xpY2ssXG4gIG9uRXhwYW5kQ2xpY2ssXG4gIG9uU3BhY2VFbnRlclByZXNzLFxuICByZW5kZXJMYWJlbCxcbiAgcmVuZGVyTGVmdCxcbiAgcmVuZGVyUmlnaHQsXG4gIHNpemUgPSBcIm1cIixcbiAgdGFiSW5kZXgsXG4gIGFyaWFMYWJlbEV4cGFuZCxcbiAgYXJpYUxhYmVsQ29sbGFwc2UsXG4gIFwiYXJpYS1sZXZlbFwiOiBhcmlhTGV2ZWwsXG4gIFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsXG4gIFwiZGF0YS1saXN0LWl0ZW1cIjogZGF0YUxpc3RJdGVtLFxufTogRW50aXR5TGlzdEl0ZW1Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGhhc0V4cGFuZGFibGVJY29uID0gaXNFeHBhbmRlZCAhPT0gdW5kZWZpbmVkO1xuXG4gIGNvbnN0IGhhbmRsZU9uQ2xpY2sgPSB1c2VDYWxsYmFjayhcbiAgICAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgICAgaWYgKG9uQ2xpY2spIHtcbiAgICAgICAgb25DbGljayhlKTtcbiAgICAgIH1cbiAgICB9LFxuICAgIFtvbkNsaWNrXVxuICApO1xuXG4gIGNvbnN0IGJ1dHRvblJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG5cbiAgdXNlS2V5Ym9hcmQoXG4gICAge1xuICAgICAgXCJTcGFjZSBFbnRlclwiOiBvblNwYWNlRW50ZXJQcmVzcyxcbiAgICB9LFxuICAgIGJ1dHRvblJlZixcbiAgICB0YWJJbmRleCA9PT0gMCAmJiAoaXNDbGlja2FibGUgfHwgISFjaGVja2JveFByb3BzKSxcbiAgICB0cnVlXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRW50aXR5SXRlbUxpXG4gICAgICByb2xlPVwidHJlZWl0ZW1cIlxuICAgICAgYXJpYS1leHBhbmRlZD17aGFzRXhwYW5kYWJsZUljb24gPyBpc0V4cGFuZGVkIDogdW5kZWZpbmVkfVxuICAgICAgYXJpYS1jaGVja2VkPXtjaGVja2JveFByb3BzPy5jaGVja2VkfVxuICAgICAgYXJpYS1sYWJlbD17YXJpYUxhYmVsfVxuICAgICAgYXJpYS1sZXZlbD17YXJpYUxldmVsfVxuICAgID5cbiAgICAgIDxTdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lclxuICAgICAgICBkYXRhLWxpc3QtaXRlbT17ZGF0YUxpc3RJdGVtfVxuICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICByZWY9e2J1dHRvblJlZn1cbiAgICAgICAgZGF0YS1pZD1cImxpc3QtaXRlbVwiXG4gICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgcm9sZT1cInByZXNlbnRhdGlvblwiXG4gICAgICAgIGlzQWN0aXZlPXtpc0FjdGl2ZX1cbiAgICAgICAgaGFzRXhwYW5kYWJsZUljb249e2hhc0V4cGFuZGFibGVJY29ufVxuICAgICAgICBsU3BhY2VTdGVwPXtsU3BhY2VTdGVwfVxuICAgICAgICBpc0Rpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICBvbkNsaWNrPXtoYW5kbGVPbkNsaWNrfVxuICAgICAgICBpc0NsaWNrYWJsZT17aXNDbGlja2FibGV9XG4gICAgICA+XG4gICAgICAgIHtoYXNFeHBhbmRhYmxlSWNvbiAmJiAoXG4gICAgICAgICAgPEVudGl0eVRyZWVJdGVtRXhwYW5kQnV0dG9uXG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgdGFiSW5kZXg9ey0xfVxuICAgICAgICAgICAgaXNEaXNhYmxlZD17aXNEaXNhYmxlZEV4cGFuZCB8fCBpc0Rpc2FibGVkfVxuICAgICAgICAgICAgaXNFeHBhbmRlZD17aXNFeHBhbmRlZH1cbiAgICAgICAgICAgIG9uQ2xpY2s9e29uRXhwYW5kQ2xpY2t9XG4gICAgICAgICAgICBhcmlhTGFiZWxFeHBhbmQ9e2FyaWFMYWJlbEV4cGFuZH1cbiAgICAgICAgICAgIGFyaWFMYWJlbENvbGxhcHNlPXthcmlhTGFiZWxDb2xsYXBzZX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICA8U3R5bGVkRW50aXR5VHJlZUl0ZW1XcmFwcGVyXG4gICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICBoaWRlQm9yZGVyPXtoaWRlQm9yZGVyIHx8IHNpemUgPT09IFwieHNcIn1cbiAgICAgICAgPlxuICAgICAgICAgIDxFbnRpdHlJdGVtQm9keVxuICAgICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgIGRlc2NyaXB0aW9uPXtkZXNjcmlwdGlvbn1cbiAgICAgICAgICAgIHJlbmRlckxhYmVsPXtyZW5kZXJMYWJlbH1cbiAgICAgICAgICAgIHJlbmRlckxlZnQ9e3JlbmRlckxlZnR9XG4gICAgICAgICAgICByZW5kZXJSaWdodD17cmVuZGVyUmlnaHR9XG4gICAgICAgICAgICBjaGVja2JveFByb3BzPXtjaGVja2JveFByb3BzfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvU3R5bGVkRW50aXR5VHJlZUl0ZW1XcmFwcGVyPlxuICAgICAgPC9TdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lcj5cbiAgICAgIHtpc0V4cGFuZGVkICYmIGNoaWxkcmVufVxuICAgIDwvU3R5bGVkRW50aXR5SXRlbUxpPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjb0MifQ== */"),StyledEntityTreeItemContainer=styled(StyledEntityListItemButton,{target:"e29eivf1",label:"StyledEntityTreeItemContainer"})(({theme,hasExpandableIcon,lSpaceStep})=>{let getSize=(baseOffset,deepestNodeOffset)=>`calc(${baseOffset} * ${lSpaceStep} + ${hasExpandableIcon?"0px":deepestNodeOffset} + ${theme.variables.size.spacing.xxs})`;return{...getFocusStyles({offset:-2}),...useResponsiveValue({paddingLeft:[getSize(theme.variables.size.spacing.m,"42px"),getSize(theme.variables.size.spacing.xl,"56px")]})}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5VHJlZS9FbnRpdHlUcmVlSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eVRyZWUvRW50aXR5VHJlZUl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBFbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvbiB9IGZyb20gXCIuL0VudGl0eVRyZWVJdGVtRXhwYW5kQnV0dG9uXCI7XG5pbXBvcnQgeyB1c2VLZXlib2FyZCB9IGZyb20gXCIuLi8uLi9zaGFyZWQvdXNlS2V5Ym9hcmRcIjtcbmltcG9ydCB7IGdldEZvY3VzU3R5bGVzIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9taXhpbnNcIjtcbmltcG9ydCB7IEVudGl0eUl0ZW1Cb2R5IH0gZnJvbSBcIi4uL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHlcIjtcbmltcG9ydCB7XG4gIFN0eWxlZEVudGl0eUl0ZW1MaSxcbiAgU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyLFxuICBTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbixcbn0gZnJvbSBcIi4uL0VudGl0eUxpc3Qvc3R5bGVkLWNvbXBvbmVudHNcIjtcbmltcG9ydCB0eXBlIHsgRW50aXR5TGlzdEl0ZW1Qcm9wcyB9IGZyb20gXCIuLi9FbnRpdHlMaXN0L3R5cGVzXCI7XG5cbmNvbnN0IFN0eWxlZEVudGl0eVRyZWVJdGVtV3JhcHBlciA9IHN0eWxlZChTdHlsZWRFbnRpdHlMaXN0SXRlbVdyYXBwZXIpKHtcbiAgcGFkZGluZ0xlZnQ6IFwiMCAhaW1wb3J0YW50XCIsIC8vIFwiaW1wb3J0YW50XCIgaXMgbmVlZGVkIHRvIG92ZXJyaWRlIHRoZSBAbWVkaWEgcXVlcnkgb2YgTVEgZnVuY3Rpb25cbn0pO1xuXG5jb25zdCBTdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lciA9IHN0eWxlZChTdHlsZWRFbnRpdHlMaXN0SXRlbUJ1dHRvbik8e1xuICBoYXNFeHBhbmRhYmxlSWNvbjogYm9vbGVhbjtcbn0+KCh7IHRoZW1lLCBoYXNFeHBhbmRhYmxlSWNvbiwgbFNwYWNlU3RlcCB9KSA9PiB7XG4gIGNvbnN0IGdldFNpemUgPSAoYmFzZU9mZnNldDogc3RyaW5nLCBkZWVwZXN0Tm9kZU9mZnNldDogc3RyaW5nKSA9PlxuICAgIGBjYWxjKCR7YmFzZU9mZnNldH0gKiAke2xTcGFjZVN0ZXB9ICsgJHtcbiAgICAgIGhhc0V4cGFuZGFibGVJY29uID8gXCIwcHhcIiA6IGRlZXBlc3ROb2RlT2Zmc2V0XG4gICAgfSArICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHN9KWA7XG5cbiAgcmV0dXJuIHtcbiAgICAuLi5nZXRGb2N1c1N0eWxlcyh7IG9mZnNldDogLTIgfSksXG4gICAgLi4udXNlUmVzcG9uc2l2ZVZhbHVlKHtcbiAgICAgIHBhZGRpbmdMZWZ0OiBbXG4gICAgICAgIC8vIDQycHggYW5kIDU2cHggYXJlIEV4cGFuZCBidXR0b24gd2lkdGggKyBwYWRkaW5nXG4gICAgICAgIC8vIGl0J3MgbmVlZGVkIGZvciBhIGRlZXBlc3Qgbm9kZSB3aXRob3V0IGV4cGFuZEJ1dHRvblxuICAgICAgICBnZXRTaXplKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSwgXCI0MnB4XCIpLFxuICAgICAgICBnZXRTaXplKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGwsIFwiNTZweFwiKSxcbiAgICAgIF0sXG4gICAgfSksXG4gIH07XG59KTtcblxuZXhwb3J0IGNvbnN0IEVudGl0eVRyZWVJdGVtID0gKHtcbiAgY2hlY2tib3hQcm9wcyxcbiAgY2hpbGRyZW4sXG4gIGRlc2NyaXB0aW9uLFxuICBoaWRlQm9yZGVyLFxuICBpc0FjdGl2ZSxcbiAgaXNDbGlja2FibGUsXG4gIGlzRGlzYWJsZWQsXG4gIGlzRGlzYWJsZWRFeHBhbmQsXG4gIGlzRXhwYW5kZWQsXG4gIGxTcGFjZVN0ZXAsXG4gIG9uQ2xpY2ssXG4gIG9uRXhwYW5kQ2xpY2ssXG4gIG9uU3BhY2VFbnRlclByZXNzLFxuICByZW5kZXJMYWJlbCxcbiAgcmVuZGVyTGVmdCxcbiAgcmVuZGVyUmlnaHQsXG4gIHNpemUgPSBcIm1cIixcbiAgdGFiSW5kZXgsXG4gIGFyaWFMYWJlbEV4cGFuZCxcbiAgYXJpYUxhYmVsQ29sbGFwc2UsXG4gIFwiYXJpYS1sZXZlbFwiOiBhcmlhTGV2ZWwsXG4gIFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsXG4gIFwiZGF0YS1saXN0LWl0ZW1cIjogZGF0YUxpc3RJdGVtLFxufTogRW50aXR5TGlzdEl0ZW1Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGhhc0V4cGFuZGFibGVJY29uID0gaXNFeHBhbmRlZCAhPT0gdW5kZWZpbmVkO1xuXG4gIGNvbnN0IGhhbmRsZU9uQ2xpY2sgPSB1c2VDYWxsYmFjayhcbiAgICAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgICAgaWYgKG9uQ2xpY2spIHtcbiAgICAgICAgb25DbGljayhlKTtcbiAgICAgIH1cbiAgICB9LFxuICAgIFtvbkNsaWNrXVxuICApO1xuXG4gIGNvbnN0IGJ1dHRvblJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG5cbiAgdXNlS2V5Ym9hcmQoXG4gICAge1xuICAgICAgXCJTcGFjZSBFbnRlclwiOiBvblNwYWNlRW50ZXJQcmVzcyxcbiAgICB9LFxuICAgIGJ1dHRvblJlZixcbiAgICB0YWJJbmRleCA9PT0gMCAmJiAoaXNDbGlja2FibGUgfHwgISFjaGVja2JveFByb3BzKSxcbiAgICB0cnVlXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRW50aXR5SXRlbUxpXG4gICAgICByb2xlPVwidHJlZWl0ZW1cIlxuICAgICAgYXJpYS1leHBhbmRlZD17aGFzRXhwYW5kYWJsZUljb24gPyBpc0V4cGFuZGVkIDogdW5kZWZpbmVkfVxuICAgICAgYXJpYS1jaGVja2VkPXtjaGVja2JveFByb3BzPy5jaGVja2VkfVxuICAgICAgYXJpYS1sYWJlbD17YXJpYUxhYmVsfVxuICAgICAgYXJpYS1sZXZlbD17YXJpYUxldmVsfVxuICAgID5cbiAgICAgIDxTdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lclxuICAgICAgICBkYXRhLWxpc3QtaXRlbT17ZGF0YUxpc3RJdGVtfVxuICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICByZWY9e2J1dHRvblJlZn1cbiAgICAgICAgZGF0YS1pZD1cImxpc3QtaXRlbVwiXG4gICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgcm9sZT1cInByZXNlbnRhdGlvblwiXG4gICAgICAgIGlzQWN0aXZlPXtpc0FjdGl2ZX1cbiAgICAgICAgaGFzRXhwYW5kYWJsZUljb249e2hhc0V4cGFuZGFibGVJY29ufVxuICAgICAgICBsU3BhY2VTdGVwPXtsU3BhY2VTdGVwfVxuICAgICAgICBpc0Rpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICBvbkNsaWNrPXtoYW5kbGVPbkNsaWNrfVxuICAgICAgICBpc0NsaWNrYWJsZT17aXNDbGlja2FibGV9XG4gICAgICA+XG4gICAgICAgIHtoYXNFeHBhbmRhYmxlSWNvbiAmJiAoXG4gICAgICAgICAgPEVudGl0eVRyZWVJdGVtRXhwYW5kQnV0dG9uXG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgdGFiSW5kZXg9ey0xfVxuICAgICAgICAgICAgaXNEaXNhYmxlZD17aXNEaXNhYmxlZEV4cGFuZCB8fCBpc0Rpc2FibGVkfVxuICAgICAgICAgICAgaXNFeHBhbmRlZD17aXNFeHBhbmRlZH1cbiAgICAgICAgICAgIG9uQ2xpY2s9e29uRXhwYW5kQ2xpY2t9XG4gICAgICAgICAgICBhcmlhTGFiZWxFeHBhbmQ9e2FyaWFMYWJlbEV4cGFuZH1cbiAgICAgICAgICAgIGFyaWFMYWJlbENvbGxhcHNlPXthcmlhTGFiZWxDb2xsYXBzZX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICA8U3R5bGVkRW50aXR5VHJlZUl0ZW1XcmFwcGVyXG4gICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICBoaWRlQm9yZGVyPXtoaWRlQm9yZGVyIHx8IHNpemUgPT09IFwieHNcIn1cbiAgICAgICAgPlxuICAgICAgICAgIDxFbnRpdHlJdGVtQm9keVxuICAgICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgIGRlc2NyaXB0aW9uPXtkZXNjcmlwdGlvbn1cbiAgICAgICAgICAgIHJlbmRlckxhYmVsPXtyZW5kZXJMYWJlbH1cbiAgICAgICAgICAgIHJlbmRlckxlZnQ9e3JlbmRlckxlZnR9XG4gICAgICAgICAgICByZW5kZXJSaWdodD17cmVuZGVyUmlnaHR9XG4gICAgICAgICAgICBjaGVja2JveFByb3BzPXtjaGVja2JveFByb3BzfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvU3R5bGVkRW50aXR5VHJlZUl0ZW1XcmFwcGVyPlxuICAgICAgPC9TdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lcj5cbiAgICAgIHtpc0V4cGFuZGVkICYmIGNoaWxkcmVufVxuICAgIDwvU3R5bGVkRW50aXR5SXRlbUxpPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQnNDIn0= */");export const EntityTreeItem=({checkboxProps,children,description,hideBorder,isActive,isClickable,isDisabled,isDisabledExpand,isExpanded,lSpaceStep,onClick,onExpandClick,onSpaceEnterPress,renderLabel,renderLeft,renderRight,size="m",tabIndex,ariaLabelExpand,ariaLabelCollapse,"aria-level":ariaLevel,"aria-label":ariaLabel,"data-list-item":dataListItem})=>{let hasExpandableIcon=void 0!==isExpanded,handleOnClick=useCallback(e=>{onClick&&onClick(e)},[onClick]),buttonRef=useRef(null);return useKeyboard({"Space Enter":onSpaceEnterPress},buttonRef,0===tabIndex&&(isClickable||!!checkboxProps),!0),React.createElement(StyledEntityItemLi,{role:"treeitem","aria-expanded":hasExpandableIcon?isExpanded:void 0,"aria-checked":checkboxProps?.checked,"aria-label":ariaLabel,"aria-level":ariaLevel},React.createElement(StyledEntityTreeItemContainer,{"data-list-item":dataListItem,size:size,ref:buttonRef,"data-id":"list-item",tabIndex:tabIndex,role:"presentation",isActive:isActive,hasExpandableIcon:hasExpandableIcon,lSpaceStep:lSpaceStep,isDisabled:isDisabled,onClick:handleOnClick,isClickable:isClickable},hasExpandableIcon&&React.createElement(EntityTreeItemExpandButton,{size:size,tabIndex:-1,isDisabled:isDisabledExpand||isDisabled,isExpanded:isExpanded,onClick:onExpandClick,ariaLabelExpand:ariaLabelExpand,ariaLabelCollapse:ariaLabelCollapse}),React.createElement(StyledEntityTreeItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},React.createElement(EntityItemBody,{size:size,tabIndex:tabIndex,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight,checkboxProps:checkboxProps}))),isExpanded&&children)};
@@ -28,7 +28,7 @@ export type TabsProps = {
28
28
  tabs: Tab[];
29
29
  children?: React.ReactElement;
30
30
  /** The index of the active tab */
31
- activeTab?: number;
31
+ activeTab?: number | null;
32
32
  onTabSelect?: (selectedTab: number) => void;
33
33
  activeTabClickable?: boolean;
34
34
  tabPanelId?: string;
@@ -1 +1 @@
1
- import styled from"@emotion/styled";import isPropValid from"@emotion/is-prop-valid";import React from"react";import{useResponsiveStyles}from"../../shared/mediaQueries";import{Icon}from"../Icon/Icon";import{Stack}from"../Stack/Stack";import{Tooltip}from"../Tooltip/Tooltip";let StyledContainer=styled("div",{shouldForwardProp:prop=>isPropValid(prop),target:"eycof6h0",label:"StyledContainer"})(({theme,horizontalPadding,hideBottomBorder})=>({display:"flex",flexDirection:"row",...useResponsiveStyles({gap:[["m","l","l"],theme.variables.size.spacing],paddingInline:[horizontalPadding,theme.variables.size.spacing]}),...!hideBottomBorder&&{borderBottom:`1px solid ${theme.values.color.border.secondary.default}`},whiteSpace:"nowrap",overflow:"auto",scrollbarWidth:"none",msOverflowStyle:"none","::-webkit-scrollbar":{display:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Tabs/Tabs.tsx","sources":["src/components/Tabs/Tabs.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport React from \"react\";\nimport { useResponsiveStyles } from \"../../shared/mediaQueries\";\nimport type { MQ, SpaceSizes } from \"../../types\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Tooltip } from \"../Tooltip/Tooltip\";\n\nconst CONTAINER_BORDER_WIDTH = 1;\nconst TAB_BORDER_WIDTH = 4;\n\nconst StyledContainer = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Pick<TabsProps, \"horizontalPadding\" | \"hideBottomBorder\">>(\n  ({ theme, horizontalPadding, hideBottomBorder }) => ({\n    display: \"flex\",\n    flexDirection: \"row\",\n    ...useResponsiveStyles({\n      gap: [[\"m\", \"l\", \"l\"], theme.variables.size.spacing],\n      paddingInline: [horizontalPadding, theme.variables.size.spacing],\n    }),\n\n    ...(!hideBottomBorder && {\n      borderBottom: `${CONTAINER_BORDER_WIDTH}px solid ${theme.values.color.border.secondary.default}`,\n    }),\n\n    whiteSpace: \"nowrap\",\n\n    // Scrollbar\n    overflow: \"auto\",\n    scrollbarWidth: \"none\", // Firefox\n    msOverflowStyle: \"none\", // IE 10+\n    \"::-webkit-scrollbar\": {\n      display: \"none\", // Chrome\n    },\n  })\n);\n\nconst StyledTab = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"active\",\n})<\n  Pick<TabsProps, \"hideBottomBorder\" | \"activeTabClickable\"> &\n    Pick<Tab, \"disabled\" | \"active\">\n>(({ theme, active, disabled, hideBottomBorder, activeTabClickable }) => ({\n  display: \"flex\",\n  gap: theme.variables.size.spacing.xxs,\n  alignItems: \"center\",\n\n  background: \"none\",\n  border: 0,\n  boxSizing: \"border-box\",\n  color: theme.values.color.text.secondary.default,\n  padding: 0,\n  fontFamily: theme.variables.fontFamily.lato,\n  fontWeight: theme.variables.weight.bold,\n  fontSize: theme.variables.size.font.s,\n  lineHeight: theme.variables.size.lineHeight.xs,\n  textDecoration: \"none\",\n\n  borderBottom: `${TAB_BORDER_WIDTH}px solid transparent`,\n  // since we have a bottom border on the container,\n  // we need to add padding to the top of the tab to maintain consistent height\n  paddingTop: hideBottomBorder\n    ? theme.variables.size.spacing.m\n    : `calc(${theme.variables.size.spacing.m} - ${CONTAINER_BORDER_WIDTH}px)`,\n  paddingBottom: `calc(${theme.variables.size.spacing.m} - ${TAB_BORDER_WIDTH}px)`,\n\n  ...(active &&\n    !disabled && {\n      color: theme.values.color.text.accent.default,\n      borderBottomColor: theme.values.color.border.accent.default,\n    }),\n  ...(!active &&\n    !disabled && {\n      cursor: \"pointer\",\n      \"&:hover\": {\n        color: theme.values.color.text.primary.default,\n        borderBottomColor: theme.values.color.border.secondary.default,\n      },\n      \"&:active\": {\n        color: theme.values.color.text.primary.default,\n        borderBottomColor: theme.values.color.border.secondary.active,\n      },\n    }),\n  ...(activeTabClickable && {\n    cursor: \"pointer\",\n  }),\n  ...(disabled && {\n    opacity: theme.variables.opacity.disabled,\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst addSubtitle = (text: string) => (text ? `(${text})` : ``);\ntype IconProp = { name: IconName; position: \"left\" | \"right\" };\n\n/**\n * @param label - The text to display in the tab\n * @param sublabel - A subtext, encased in parentheses\n * @param icon - An icon to display. Can be either an icon name (defaults to left position) or an object with name and position\n * @param as - The element to render the tab as, defaults to `button`\n * @param disabled - Whether the tab is disabled\n * @param tooltipContent - The content of the tooltip to display when the tab is disabled\n */\ntype Tab = {\n  id?: string;\n  label: string;\n  sublabel?: string;\n  icon?: IconName | IconProp;\n  as?: \"a\" | \"button\" | React.ElementType;\n  disabled?: boolean;\n  active?: boolean;\n  tooltipContent?: string;\n} & Partial<React.ComponentProps<\"button\">> &\n  Partial<React.ComponentProps<\"a\">>;\n\nexport type TabsProps = {\n  /** An array of tabs, contains `header`, `subtitle`, `iconLeft`, `as` (defining the tab as a button or a link) */\n  tabs: Tab[];\n  children?: React.ReactElement;\n  /** The index of the active tab */\n  activeTab?: number;\n  onTabSelect?: (selectedTab: number) => void;\n  activeTabClickable?: boolean;\n  tabPanelId?: string;\n  /** Horizontal padding space for the tab container, suited for tabs within a Card element */\n  horizontalPadding?: SpaceSizes | MQ<SpaceSizes>; // 'm' | ['m', 'l', 'l']\n  /** Whether to show a bottom border between tabs and content */\n  hideBottomBorder?: boolean;\n  \"aria-label\"?: string;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport function Tabs({\n  tabs,\n  horizontalPadding,\n  activeTab = 0,\n  children,\n  onTabSelect,\n  activeTabClickable,\n  tabPanelId = \"tabPanel\",\n  \"aria-label\": ariaLabel,\n  \"data-e2e-test-id\": dataE2eTestId,\n  hideBottomBorder,\n}: TabsProps): React.ReactElement {\n  return (\n    <Stack data-e2e-test-id={dataE2eTestId} data-ds-id=\"Tabs\">\n      <StyledContainer\n        hideBottomBorder={hideBottomBorder}\n        horizontalPadding={horizontalPadding}\n        role=\"tablist\"\n        aria-label={ariaLabel}\n      >\n        {tabs.map(\n          (\n            {\n              id: tabId,\n              label,\n              sublabel,\n              icon,\n              as = \"button\",\n              disabled,\n              tooltipContent,\n              ...rest\n            },\n            i\n          ) => {\n            // Parse icon configuration\n            let iconConfig: IconProp;\n\n            if (icon) {\n              if (typeof icon === \"string\") {\n                iconConfig = { name: icon, position: \"left\" };\n              } else {\n                iconConfig = icon;\n              }\n            }\n\n            const Tab = (\n              <StyledTab\n                id={tabId || `tab-${i}`}\n                type={as !== \"button\" ? undefined : \"button\"}\n                role=\"tab\"\n                activeTabClickable={activeTabClickable}\n                hideBottomBorder={hideBottomBorder}\n                disabled={disabled}\n                as={as}\n                key={label}\n                active={activeTab === i}\n                aria-selected={activeTab === i}\n                aria-controls={children ? tabPanelId : undefined}\n                onClick={() => onTabSelect && onTabSelect(i)}\n                {...rest}\n              >\n                {iconConfig && iconConfig.position === \"left\" && (\n                  <Icon size=\"s\" name={iconConfig.name} />\n                )}\n                {label} {addSubtitle(sublabel)}\n                {iconConfig && iconConfig.position === \"right\" && (\n                  <Icon size=\"s\" name={iconConfig.name} />\n                )}\n              </StyledTab>\n            );\n\n            if (disabled && tooltipContent) {\n              return <Tooltip content={tooltipContent}>{Tab}</Tooltip>;\n            }\n\n            return Tab;\n          }\n        )}\n      </StyledContainer>\n      {children && (\n        <div role=\"tabpanel\" id={tabPanelId}>\n          {children}\n        </div>\n      )}\n    </Stack>\n  );\n}\n"],"names":[],"mappings":"AAewB"} */"),StyledTab=styled("button",{shouldForwardProp:prop=>isPropValid(prop)&&"active"!==prop,target:"eycof6h1",label:"StyledTab"})(({theme,active,disabled,hideBottomBorder,activeTabClickable})=>({display:"flex",gap:theme.variables.size.spacing.xxs,alignItems:"center",background:"none",border:0,boxSizing:"border-box",color:theme.values.color.text.secondary.default,padding:0,fontFamily:theme.variables.fontFamily.lato,fontWeight:theme.variables.weight.bold,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,textDecoration:"none",borderBottom:"4px solid transparent",paddingTop:hideBottomBorder?theme.variables.size.spacing.m:`calc(${theme.variables.size.spacing.m} - 1px)`,paddingBottom:`calc(${theme.variables.size.spacing.m} - 4px)`,...active&&!disabled&&{color:theme.values.color.text.accent.default,borderBottomColor:theme.values.color.border.accent.default},...!active&&!disabled&&{cursor:"pointer","&:hover":{color:theme.values.color.text.primary.default,borderBottomColor:theme.values.color.border.secondary.default},"&:active":{color:theme.values.color.text.primary.default,borderBottomColor:theme.values.color.border.secondary.active}},...activeTabClickable&&{cursor:"pointer"},...disabled&&{opacity:theme.variables.opacity.disabled,cursor:"not-allowed"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Tabs/Tabs.tsx","sources":["src/components/Tabs/Tabs.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport React from \"react\";\nimport { useResponsiveStyles } from \"../../shared/mediaQueries\";\nimport type { MQ, SpaceSizes } from \"../../types\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Tooltip } from \"../Tooltip/Tooltip\";\n\nconst CONTAINER_BORDER_WIDTH = 1;\nconst TAB_BORDER_WIDTH = 4;\n\nconst StyledContainer = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Pick<TabsProps, \"horizontalPadding\" | \"hideBottomBorder\">>(\n  ({ theme, horizontalPadding, hideBottomBorder }) => ({\n    display: \"flex\",\n    flexDirection: \"row\",\n    ...useResponsiveStyles({\n      gap: [[\"m\", \"l\", \"l\"], theme.variables.size.spacing],\n      paddingInline: [horizontalPadding, theme.variables.size.spacing],\n    }),\n\n    ...(!hideBottomBorder && {\n      borderBottom: `${CONTAINER_BORDER_WIDTH}px solid ${theme.values.color.border.secondary.default}`,\n    }),\n\n    whiteSpace: \"nowrap\",\n\n    // Scrollbar\n    overflow: \"auto\",\n    scrollbarWidth: \"none\", // Firefox\n    msOverflowStyle: \"none\", // IE 10+\n    \"::-webkit-scrollbar\": {\n      display: \"none\", // Chrome\n    },\n  })\n);\n\nconst StyledTab = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"active\",\n})<\n  Pick<TabsProps, \"hideBottomBorder\" | \"activeTabClickable\"> &\n    Pick<Tab, \"disabled\" | \"active\">\n>(({ theme, active, disabled, hideBottomBorder, activeTabClickable }) => ({\n  display: \"flex\",\n  gap: theme.variables.size.spacing.xxs,\n  alignItems: \"center\",\n\n  background: \"none\",\n  border: 0,\n  boxSizing: \"border-box\",\n  color: theme.values.color.text.secondary.default,\n  padding: 0,\n  fontFamily: theme.variables.fontFamily.lato,\n  fontWeight: theme.variables.weight.bold,\n  fontSize: theme.variables.size.font.s,\n  lineHeight: theme.variables.size.lineHeight.xs,\n  textDecoration: \"none\",\n\n  borderBottom: `${TAB_BORDER_WIDTH}px solid transparent`,\n  // since we have a bottom border on the container,\n  // we need to add padding to the top of the tab to maintain consistent height\n  paddingTop: hideBottomBorder\n    ? theme.variables.size.spacing.m\n    : `calc(${theme.variables.size.spacing.m} - ${CONTAINER_BORDER_WIDTH}px)`,\n  paddingBottom: `calc(${theme.variables.size.spacing.m} - ${TAB_BORDER_WIDTH}px)`,\n\n  ...(active &&\n    !disabled && {\n      color: theme.values.color.text.accent.default,\n      borderBottomColor: theme.values.color.border.accent.default,\n    }),\n  ...(!active &&\n    !disabled && {\n      cursor: \"pointer\",\n      \"&:hover\": {\n        color: theme.values.color.text.primary.default,\n        borderBottomColor: theme.values.color.border.secondary.default,\n      },\n      \"&:active\": {\n        color: theme.values.color.text.primary.default,\n        borderBottomColor: theme.values.color.border.secondary.active,\n      },\n    }),\n  ...(activeTabClickable && {\n    cursor: \"pointer\",\n  }),\n  ...(disabled && {\n    opacity: theme.variables.opacity.disabled,\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst addSubtitle = (text: string) => (text ? `(${text})` : ``);\ntype IconProp = { name: IconName; position: \"left\" | \"right\" };\n\n/**\n * @param label - The text to display in the tab\n * @param sublabel - A subtext, encased in parentheses\n * @param icon - An icon to display. Can be either an icon name (defaults to left position) or an object with name and position\n * @param as - The element to render the tab as, defaults to `button`\n * @param disabled - Whether the tab is disabled\n * @param tooltipContent - The content of the tooltip to display when the tab is disabled\n */\ntype Tab = {\n  id?: string;\n  label: string;\n  sublabel?: string;\n  icon?: IconName | IconProp;\n  as?: \"a\" | \"button\" | React.ElementType;\n  disabled?: boolean;\n  active?: boolean;\n  tooltipContent?: string;\n} & Partial<React.ComponentProps<\"button\">> &\n  Partial<React.ComponentProps<\"a\">>;\n\nexport type TabsProps = {\n  /** An array of tabs, contains `header`, `subtitle`, `iconLeft`, `as` (defining the tab as a button or a link) */\n  tabs: Tab[];\n  children?: React.ReactElement;\n  /** The index of the active tab */\n  activeTab?: number;\n  onTabSelect?: (selectedTab: number) => void;\n  activeTabClickable?: boolean;\n  tabPanelId?: string;\n  /** Horizontal padding space for the tab container, suited for tabs within a Card element */\n  horizontalPadding?: SpaceSizes | MQ<SpaceSizes>; // 'm' | ['m', 'l', 'l']\n  /** Whether to show a bottom border between tabs and content */\n  hideBottomBorder?: boolean;\n  \"aria-label\"?: string;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport function Tabs({\n  tabs,\n  horizontalPadding,\n  activeTab = 0,\n  children,\n  onTabSelect,\n  activeTabClickable,\n  tabPanelId = \"tabPanel\",\n  \"aria-label\": ariaLabel,\n  \"data-e2e-test-id\": dataE2eTestId,\n  hideBottomBorder,\n}: TabsProps): React.ReactElement {\n  return (\n    <Stack data-e2e-test-id={dataE2eTestId} data-ds-id=\"Tabs\">\n      <StyledContainer\n        hideBottomBorder={hideBottomBorder}\n        horizontalPadding={horizontalPadding}\n        role=\"tablist\"\n        aria-label={ariaLabel}\n      >\n        {tabs.map(\n          (\n            {\n              id: tabId,\n              label,\n              sublabel,\n              icon,\n              as = \"button\",\n              disabled,\n              tooltipContent,\n              ...rest\n            },\n            i\n          ) => {\n            // Parse icon configuration\n            let iconConfig: IconProp;\n\n            if (icon) {\n              if (typeof icon === \"string\") {\n                iconConfig = { name: icon, position: \"left\" };\n              } else {\n                iconConfig = icon;\n              }\n            }\n\n            const Tab = (\n              <StyledTab\n                id={tabId || `tab-${i}`}\n                type={as !== \"button\" ? undefined : \"button\"}\n                role=\"tab\"\n                activeTabClickable={activeTabClickable}\n                hideBottomBorder={hideBottomBorder}\n                disabled={disabled}\n                as={as}\n                key={label}\n                active={activeTab === i}\n                aria-selected={activeTab === i}\n                aria-controls={children ? tabPanelId : undefined}\n                onClick={() => onTabSelect && onTabSelect(i)}\n                {...rest}\n              >\n                {iconConfig && iconConfig.position === \"left\" && (\n                  <Icon size=\"s\" name={iconConfig.name} />\n                )}\n                {label} {addSubtitle(sublabel)}\n                {iconConfig && iconConfig.position === \"right\" && (\n                  <Icon size=\"s\" name={iconConfig.name} />\n                )}\n              </StyledTab>\n            );\n\n            if (disabled && tooltipContent) {\n              return <Tooltip content={tooltipContent}>{Tab}</Tooltip>;\n            }\n\n            return Tab;\n          }\n        )}\n      </StyledContainer>\n      {children && (\n        <div role=\"tabpanel\" id={tabPanelId}>\n          {children}\n        </div>\n      )}\n    </Stack>\n  );\n}\n"],"names":[],"mappings":"AA0CkB"} */"),addSubtitle=text=>text?`(${text})`:"";export function Tabs({tabs,horizontalPadding,activeTab=0,children,onTabSelect,activeTabClickable,tabPanelId="tabPanel","aria-label":ariaLabel,"data-e2e-test-id":dataE2eTestId,hideBottomBorder}){return React.createElement(Stack,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Tabs"},React.createElement(StyledContainer,{hideBottomBorder:hideBottomBorder,horizontalPadding:horizontalPadding,role:"tablist","aria-label":ariaLabel},tabs.map(({id:tabId,label,sublabel,icon,as="button",disabled,tooltipContent,...rest},i)=>{let iconConfig;icon&&(iconConfig="string"==typeof icon?{name:icon,position:"left"}:icon);let Tab=React.createElement(StyledTab,{id:tabId||`tab-${i}`,type:"button"!==as?void 0:"button",role:"tab",activeTabClickable:activeTabClickable,hideBottomBorder:hideBottomBorder,disabled:disabled,as:as,key:label,active:activeTab===i,"aria-selected":activeTab===i,"aria-controls":children?tabPanelId:void 0,onClick:()=>onTabSelect&&onTabSelect(i),...rest},iconConfig&&"left"===iconConfig.position&&React.createElement(Icon,{size:"s",name:iconConfig.name}),label," ",addSubtitle(sublabel),iconConfig&&"right"===iconConfig.position&&React.createElement(Icon,{size:"s",name:iconConfig.name}));return disabled&&tooltipContent?React.createElement(Tooltip,{content:tooltipContent},Tab):Tab})),children&&React.createElement("div",{role:"tabpanel",id:tabPanelId},children))}
1
+ import styled from"@emotion/styled";import isPropValid from"@emotion/is-prop-valid";import React from"react";import{useResponsiveStyles}from"../../shared/mediaQueries";import{Icon}from"../Icon/Icon";import{Stack}from"../Stack/Stack";import{Tooltip}from"../Tooltip/Tooltip";let StyledContainer=styled("div",{shouldForwardProp:prop=>isPropValid(prop),target:"e144eml00",label:"StyledContainer"})(({theme,horizontalPadding,hideBottomBorder})=>({display:"flex",flexDirection:"row",...useResponsiveStyles({gap:[["m","l","l"],theme.variables.size.spacing],paddingInline:[horizontalPadding,theme.variables.size.spacing]}),...!hideBottomBorder&&{borderBottom:`1px solid ${theme.values.color.border.secondary.default}`},whiteSpace:"nowrap",overflow:"auto",scrollbarWidth:"none",msOverflowStyle:"none","::-webkit-scrollbar":{display:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Tabs/Tabs.tsx","sources":["src/components/Tabs/Tabs.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport React from \"react\";\nimport { useResponsiveStyles } from \"../../shared/mediaQueries\";\nimport type { MQ, SpaceSizes } from \"../../types\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Tooltip } from \"../Tooltip/Tooltip\";\n\nconst CONTAINER_BORDER_WIDTH = 1;\nconst TAB_BORDER_WIDTH = 4;\n\nconst StyledContainer = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Pick<TabsProps, \"horizontalPadding\" | \"hideBottomBorder\">>(\n  ({ theme, horizontalPadding, hideBottomBorder }) => ({\n    display: \"flex\",\n    flexDirection: \"row\",\n    ...useResponsiveStyles({\n      gap: [[\"m\", \"l\", \"l\"], theme.variables.size.spacing],\n      paddingInline: [horizontalPadding, theme.variables.size.spacing],\n    }),\n\n    ...(!hideBottomBorder && {\n      borderBottom: `${CONTAINER_BORDER_WIDTH}px solid ${theme.values.color.border.secondary.default}`,\n    }),\n\n    whiteSpace: \"nowrap\",\n\n    // Scrollbar\n    overflow: \"auto\",\n    scrollbarWidth: \"none\", // Firefox\n    msOverflowStyle: \"none\", // IE 10+\n    \"::-webkit-scrollbar\": {\n      display: \"none\", // Chrome\n    },\n  })\n);\n\nconst StyledTab = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"active\",\n})<\n  Pick<TabsProps, \"hideBottomBorder\" | \"activeTabClickable\"> &\n    Pick<Tab, \"disabled\" | \"active\">\n>(({ theme, active, disabled, hideBottomBorder, activeTabClickable }) => ({\n  display: \"flex\",\n  gap: theme.variables.size.spacing.xxs,\n  alignItems: \"center\",\n\n  background: \"none\",\n  border: 0,\n  boxSizing: \"border-box\",\n  color: theme.values.color.text.secondary.default,\n  padding: 0,\n  fontFamily: theme.variables.fontFamily.lato,\n  fontWeight: theme.variables.weight.bold,\n  fontSize: theme.variables.size.font.s,\n  lineHeight: theme.variables.size.lineHeight.xs,\n  textDecoration: \"none\",\n\n  borderBottom: `${TAB_BORDER_WIDTH}px solid transparent`,\n  // since we have a bottom border on the container,\n  // we need to add padding to the top of the tab to maintain consistent height\n  paddingTop: hideBottomBorder\n    ? theme.variables.size.spacing.m\n    : `calc(${theme.variables.size.spacing.m} - ${CONTAINER_BORDER_WIDTH}px)`,\n  paddingBottom: `calc(${theme.variables.size.spacing.m} - ${TAB_BORDER_WIDTH}px)`,\n\n  ...(active &&\n    !disabled && {\n      color: theme.values.color.text.accent.default,\n      borderBottomColor: theme.values.color.border.accent.default,\n    }),\n  ...(!active &&\n    !disabled && {\n      cursor: \"pointer\",\n      \"&:hover\": {\n        color: theme.values.color.text.primary.default,\n        borderBottomColor: theme.values.color.border.secondary.default,\n      },\n      \"&:active\": {\n        color: theme.values.color.text.primary.default,\n        borderBottomColor: theme.values.color.border.secondary.active,\n      },\n    }),\n  ...(activeTabClickable && {\n    cursor: \"pointer\",\n  }),\n  ...(disabled && {\n    opacity: theme.variables.opacity.disabled,\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst addSubtitle = (text: string) => (text ? `(${text})` : ``);\ntype IconProp = { name: IconName; position: \"left\" | \"right\" };\n\n/**\n * @param label - The text to display in the tab\n * @param sublabel - A subtext, encased in parentheses\n * @param icon - An icon to display. Can be either an icon name (defaults to left position) or an object with name and position\n * @param as - The element to render the tab as, defaults to `button`\n * @param disabled - Whether the tab is disabled\n * @param tooltipContent - The content of the tooltip to display when the tab is disabled\n */\ntype Tab = {\n  id?: string;\n  label: string;\n  sublabel?: string;\n  icon?: IconName | IconProp;\n  as?: \"a\" | \"button\" | React.ElementType;\n  disabled?: boolean;\n  active?: boolean;\n  tooltipContent?: string;\n} & Partial<React.ComponentProps<\"button\">> &\n  Partial<React.ComponentProps<\"a\">>;\n\nexport type TabsProps = {\n  /** An array of tabs, contains `header`, `subtitle`, `iconLeft`, `as` (defining the tab as a button or a link) */\n  tabs: Tab[];\n  children?: React.ReactElement;\n  /** The index of the active tab */\n  activeTab?: number | null;\n  onTabSelect?: (selectedTab: number) => void;\n  activeTabClickable?: boolean;\n  tabPanelId?: string;\n  /** Horizontal padding space for the tab container, suited for tabs within a Card element */\n  horizontalPadding?: SpaceSizes | MQ<SpaceSizes>; // 'm' | ['m', 'l', 'l']\n  /** Whether to show a bottom border between tabs and content */\n  hideBottomBorder?: boolean;\n  \"aria-label\"?: string;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport function Tabs({\n  tabs,\n  horizontalPadding,\n  activeTab = 0,\n  children,\n  onTabSelect,\n  activeTabClickable,\n  tabPanelId = \"tabPanel\",\n  \"aria-label\": ariaLabel,\n  \"data-e2e-test-id\": dataE2eTestId,\n  hideBottomBorder,\n}: TabsProps): React.ReactElement {\n  return (\n    <Stack data-e2e-test-id={dataE2eTestId} data-ds-id=\"Tabs\">\n      <StyledContainer\n        hideBottomBorder={hideBottomBorder}\n        horizontalPadding={horizontalPadding}\n        role=\"tablist\"\n        aria-label={ariaLabel}\n      >\n        {tabs.map(\n          (\n            {\n              id: tabId,\n              label,\n              sublabel,\n              icon,\n              as = \"button\",\n              disabled,\n              tooltipContent,\n              ...rest\n            },\n            i\n          ) => {\n            // Parse icon configuration\n            let iconConfig: IconProp;\n\n            if (icon) {\n              if (typeof icon === \"string\") {\n                iconConfig = { name: icon, position: \"left\" };\n              } else {\n                iconConfig = icon;\n              }\n            }\n\n            const Tab = (\n              <StyledTab\n                id={tabId || `tab-${i}`}\n                type={as !== \"button\" ? undefined : \"button\"}\n                role=\"tab\"\n                activeTabClickable={activeTabClickable}\n                hideBottomBorder={hideBottomBorder}\n                disabled={disabled}\n                as={as}\n                key={label}\n                active={activeTab === i}\n                aria-selected={activeTab === i}\n                aria-controls={children ? tabPanelId : undefined}\n                onClick={() => onTabSelect && onTabSelect(i)}\n                {...rest}\n              >\n                {iconConfig && iconConfig.position === \"left\" && (\n                  <Icon size=\"s\" name={iconConfig.name} />\n                )}\n                {label} {addSubtitle(sublabel)}\n                {iconConfig && iconConfig.position === \"right\" && (\n                  <Icon size=\"s\" name={iconConfig.name} />\n                )}\n              </StyledTab>\n            );\n\n            if (disabled && tooltipContent) {\n              return <Tooltip content={tooltipContent}>{Tab}</Tooltip>;\n            }\n\n            return Tab;\n          }\n        )}\n      </StyledContainer>\n      {children && (\n        <div role=\"tabpanel\" id={tabPanelId}>\n          {children}\n        </div>\n      )}\n    </Stack>\n  );\n}\n"],"names":[],"mappings":"AAewB"} */"),StyledTab=styled("button",{shouldForwardProp:prop=>isPropValid(prop)&&"active"!==prop,target:"e144eml01",label:"StyledTab"})(({theme,active,disabled,hideBottomBorder,activeTabClickable})=>({display:"flex",gap:theme.variables.size.spacing.xxs,alignItems:"center",background:"none",border:0,boxSizing:"border-box",color:theme.values.color.text.secondary.default,padding:0,fontFamily:theme.variables.fontFamily.lato,fontWeight:theme.variables.weight.bold,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,textDecoration:"none",borderBottom:"4px solid transparent",paddingTop:hideBottomBorder?theme.variables.size.spacing.m:`calc(${theme.variables.size.spacing.m} - 1px)`,paddingBottom:`calc(${theme.variables.size.spacing.m} - 4px)`,...active&&!disabled&&{color:theme.values.color.text.accent.default,borderBottomColor:theme.values.color.border.accent.default},...!active&&!disabled&&{cursor:"pointer","&:hover":{color:theme.values.color.text.primary.default,borderBottomColor:theme.values.color.border.secondary.default},"&:active":{color:theme.values.color.text.primary.default,borderBottomColor:theme.values.color.border.secondary.active}},...activeTabClickable&&{cursor:"pointer"},...disabled&&{opacity:theme.variables.opacity.disabled,cursor:"not-allowed"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Tabs/Tabs.tsx","sources":["src/components/Tabs/Tabs.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport React from \"react\";\nimport { useResponsiveStyles } from \"../../shared/mediaQueries\";\nimport type { MQ, SpaceSizes } from \"../../types\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Tooltip } from \"../Tooltip/Tooltip\";\n\nconst CONTAINER_BORDER_WIDTH = 1;\nconst TAB_BORDER_WIDTH = 4;\n\nconst StyledContainer = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Pick<TabsProps, \"horizontalPadding\" | \"hideBottomBorder\">>(\n  ({ theme, horizontalPadding, hideBottomBorder }) => ({\n    display: \"flex\",\n    flexDirection: \"row\",\n    ...useResponsiveStyles({\n      gap: [[\"m\", \"l\", \"l\"], theme.variables.size.spacing],\n      paddingInline: [horizontalPadding, theme.variables.size.spacing],\n    }),\n\n    ...(!hideBottomBorder && {\n      borderBottom: `${CONTAINER_BORDER_WIDTH}px solid ${theme.values.color.border.secondary.default}`,\n    }),\n\n    whiteSpace: \"nowrap\",\n\n    // Scrollbar\n    overflow: \"auto\",\n    scrollbarWidth: \"none\", // Firefox\n    msOverflowStyle: \"none\", // IE 10+\n    \"::-webkit-scrollbar\": {\n      display: \"none\", // Chrome\n    },\n  })\n);\n\nconst StyledTab = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"active\",\n})<\n  Pick<TabsProps, \"hideBottomBorder\" | \"activeTabClickable\"> &\n    Pick<Tab, \"disabled\" | \"active\">\n>(({ theme, active, disabled, hideBottomBorder, activeTabClickable }) => ({\n  display: \"flex\",\n  gap: theme.variables.size.spacing.xxs,\n  alignItems: \"center\",\n\n  background: \"none\",\n  border: 0,\n  boxSizing: \"border-box\",\n  color: theme.values.color.text.secondary.default,\n  padding: 0,\n  fontFamily: theme.variables.fontFamily.lato,\n  fontWeight: theme.variables.weight.bold,\n  fontSize: theme.variables.size.font.s,\n  lineHeight: theme.variables.size.lineHeight.xs,\n  textDecoration: \"none\",\n\n  borderBottom: `${TAB_BORDER_WIDTH}px solid transparent`,\n  // since we have a bottom border on the container,\n  // we need to add padding to the top of the tab to maintain consistent height\n  paddingTop: hideBottomBorder\n    ? theme.variables.size.spacing.m\n    : `calc(${theme.variables.size.spacing.m} - ${CONTAINER_BORDER_WIDTH}px)`,\n  paddingBottom: `calc(${theme.variables.size.spacing.m} - ${TAB_BORDER_WIDTH}px)`,\n\n  ...(active &&\n    !disabled && {\n      color: theme.values.color.text.accent.default,\n      borderBottomColor: theme.values.color.border.accent.default,\n    }),\n  ...(!active &&\n    !disabled && {\n      cursor: \"pointer\",\n      \"&:hover\": {\n        color: theme.values.color.text.primary.default,\n        borderBottomColor: theme.values.color.border.secondary.default,\n      },\n      \"&:active\": {\n        color: theme.values.color.text.primary.default,\n        borderBottomColor: theme.values.color.border.secondary.active,\n      },\n    }),\n  ...(activeTabClickable && {\n    cursor: \"pointer\",\n  }),\n  ...(disabled && {\n    opacity: theme.variables.opacity.disabled,\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst addSubtitle = (text: string) => (text ? `(${text})` : ``);\ntype IconProp = { name: IconName; position: \"left\" | \"right\" };\n\n/**\n * @param label - The text to display in the tab\n * @param sublabel - A subtext, encased in parentheses\n * @param icon - An icon to display. Can be either an icon name (defaults to left position) or an object with name and position\n * @param as - The element to render the tab as, defaults to `button`\n * @param disabled - Whether the tab is disabled\n * @param tooltipContent - The content of the tooltip to display when the tab is disabled\n */\ntype Tab = {\n  id?: string;\n  label: string;\n  sublabel?: string;\n  icon?: IconName | IconProp;\n  as?: \"a\" | \"button\" | React.ElementType;\n  disabled?: boolean;\n  active?: boolean;\n  tooltipContent?: string;\n} & Partial<React.ComponentProps<\"button\">> &\n  Partial<React.ComponentProps<\"a\">>;\n\nexport type TabsProps = {\n  /** An array of tabs, contains `header`, `subtitle`, `iconLeft`, `as` (defining the tab as a button or a link) */\n  tabs: Tab[];\n  children?: React.ReactElement;\n  /** The index of the active tab */\n  activeTab?: number | null;\n  onTabSelect?: (selectedTab: number) => void;\n  activeTabClickable?: boolean;\n  tabPanelId?: string;\n  /** Horizontal padding space for the tab container, suited for tabs within a Card element */\n  horizontalPadding?: SpaceSizes | MQ<SpaceSizes>; // 'm' | ['m', 'l', 'l']\n  /** Whether to show a bottom border between tabs and content */\n  hideBottomBorder?: boolean;\n  \"aria-label\"?: string;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport function Tabs({\n  tabs,\n  horizontalPadding,\n  activeTab = 0,\n  children,\n  onTabSelect,\n  activeTabClickable,\n  tabPanelId = \"tabPanel\",\n  \"aria-label\": ariaLabel,\n  \"data-e2e-test-id\": dataE2eTestId,\n  hideBottomBorder,\n}: TabsProps): React.ReactElement {\n  return (\n    <Stack data-e2e-test-id={dataE2eTestId} data-ds-id=\"Tabs\">\n      <StyledContainer\n        hideBottomBorder={hideBottomBorder}\n        horizontalPadding={horizontalPadding}\n        role=\"tablist\"\n        aria-label={ariaLabel}\n      >\n        {tabs.map(\n          (\n            {\n              id: tabId,\n              label,\n              sublabel,\n              icon,\n              as = \"button\",\n              disabled,\n              tooltipContent,\n              ...rest\n            },\n            i\n          ) => {\n            // Parse icon configuration\n            let iconConfig: IconProp;\n\n            if (icon) {\n              if (typeof icon === \"string\") {\n                iconConfig = { name: icon, position: \"left\" };\n              } else {\n                iconConfig = icon;\n              }\n            }\n\n            const Tab = (\n              <StyledTab\n                id={tabId || `tab-${i}`}\n                type={as !== \"button\" ? undefined : \"button\"}\n                role=\"tab\"\n                activeTabClickable={activeTabClickable}\n                hideBottomBorder={hideBottomBorder}\n                disabled={disabled}\n                as={as}\n                key={label}\n                active={activeTab === i}\n                aria-selected={activeTab === i}\n                aria-controls={children ? tabPanelId : undefined}\n                onClick={() => onTabSelect && onTabSelect(i)}\n                {...rest}\n              >\n                {iconConfig && iconConfig.position === \"left\" && (\n                  <Icon size=\"s\" name={iconConfig.name} />\n                )}\n                {label} {addSubtitle(sublabel)}\n                {iconConfig && iconConfig.position === \"right\" && (\n                  <Icon size=\"s\" name={iconConfig.name} />\n                )}\n              </StyledTab>\n            );\n\n            if (disabled && tooltipContent) {\n              return <Tooltip content={tooltipContent}>{Tab}</Tooltip>;\n            }\n\n            return Tab;\n          }\n        )}\n      </StyledContainer>\n      {children && (\n        <div role=\"tabpanel\" id={tabPanelId}>\n          {children}\n        </div>\n      )}\n    </Stack>\n  );\n}\n"],"names":[],"mappings":"AA0CkB"} */"),addSubtitle=text=>text?`(${text})`:"";export function Tabs({tabs,horizontalPadding,activeTab=0,children,onTabSelect,activeTabClickable,tabPanelId="tabPanel","aria-label":ariaLabel,"data-e2e-test-id":dataE2eTestId,hideBottomBorder}){return React.createElement(Stack,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Tabs"},React.createElement(StyledContainer,{hideBottomBorder:hideBottomBorder,horizontalPadding:horizontalPadding,role:"tablist","aria-label":ariaLabel},tabs.map(({id:tabId,label,sublabel,icon,as="button",disabled,tooltipContent,...rest},i)=>{let iconConfig;icon&&(iconConfig="string"==typeof icon?{name:icon,position:"left"}:icon);let Tab=React.createElement(StyledTab,{id:tabId||`tab-${i}`,type:"button"!==as?void 0:"button",role:"tab",activeTabClickable:activeTabClickable,hideBottomBorder:hideBottomBorder,disabled:disabled,as:as,key:label,active:activeTab===i,"aria-selected":activeTab===i,"aria-controls":children?tabPanelId:void 0,onClick:()=>onTabSelect&&onTabSelect(i),...rest},iconConfig&&"left"===iconConfig.position&&React.createElement(Icon,{size:"s",name:iconConfig.name}),label," ",addSubtitle(sublabel),iconConfig&&"right"===iconConfig.position&&React.createElement(Icon,{size:"s",name:iconConfig.name}));return disabled&&tooltipContent?React.createElement(Tooltip,{content:tooltipContent},Tab):Tab})),children&&React.createElement("div",{role:"tabpanel",id:tabPanelId},children))}
@@ -0,0 +1,6 @@
1
+ import type { CSSObject } from "@emotion/react";
2
+ type GetFocusStylesOptions = {
3
+ offset?: number;
4
+ };
5
+ export declare function getFocusStyles({ offset, }?: GetFocusStylesOptions): CSSObject;
6
+ export {};
@@ -0,0 +1 @@
1
+ export function getFocusStyles({offset=-1}={}){return{"&:focus-visible":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:offset,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}}}
@@ -1,8 +1,8 @@
1
1
  export { getInputTextPlaceholder } from "./TextInput/getInputTextPlaceholder";
2
2
  export { getInputTextStyles } from "./TextInput/getInputTextStyles";
3
- export { getFocusStyles } from "./Button/getFocusStyles";
4
3
  export { getDisabledStyles } from "./Button/getDisabledStyles";
5
4
  export { getButtonAppearanceReset } from "./Button/getButtonAppearanceReset";
6
5
  export { getBaseButtonStyles } from "./Button/getBaseButtonStyles";
7
6
  export { getPressedStyles } from "./Button/getPressedStyles";
7
+ export { getFocusStyles } from "./getFocusStyles";
8
8
  export { getPrimaryVariantStyles, getSecondaryVariantStyles, getTertiaryVariantStyles, } from "./Button/getVariantStyles";
@@ -1 +1 @@
1
- export{getInputTextPlaceholder}from"./TextInput/getInputTextPlaceholder";export{getInputTextStyles}from"./TextInput/getInputTextStyles";export{getFocusStyles}from"./Button/getFocusStyles";export{getDisabledStyles}from"./Button/getDisabledStyles";export{getButtonAppearanceReset}from"./Button/getButtonAppearanceReset";export{getBaseButtonStyles}from"./Button/getBaseButtonStyles";export{getPressedStyles}from"./Button/getPressedStyles";export{getPrimaryVariantStyles,getSecondaryVariantStyles,getTertiaryVariantStyles}from"./Button/getVariantStyles";
1
+ export{getInputTextPlaceholder}from"./TextInput/getInputTextPlaceholder";export{getInputTextStyles}from"./TextInput/getInputTextStyles";export{getDisabledStyles}from"./Button/getDisabledStyles";export{getButtonAppearanceReset}from"./Button/getButtonAppearanceReset";export{getBaseButtonStyles}from"./Button/getBaseButtonStyles";export{getPressedStyles}from"./Button/getPressedStyles";export{getFocusStyles}from"./getFocusStyles";export{getPrimaryVariantStyles,getSecondaryVariantStyles,getTertiaryVariantStyles}from"./Button/getVariantStyles";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "3.20.0",
3
+ "version": "3.20.2",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",
@@ -1,2 +0,0 @@
1
- import type { CSSObject } from "@emotion/react";
2
- export declare function getFocusStyles(): CSSObject;
@@ -1 +0,0 @@
1
- "use strict";function getFocusStyles(){return{"&:focus-visible":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}}}Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"getFocusStyles",{enumerable:!0,get:function(){return getFocusStyles}});
@@ -1,2 +0,0 @@
1
- import type { CSSObject } from "@emotion/react";
2
- export declare function getFocusStyles(): CSSObject;
@@ -1 +0,0 @@
1
- export function getFocusStyles(){return{"&:focus-visible":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}}}