@amboss/design-system 3.5.4 → 3.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/build/cjs/components/Badge/Badge.js +1 -1
  2. package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  3. package/build/cjs/components/DataTable/TableCell.js +1 -1
  4. package/build/cjs/components/EntityList/EntityListItem.js +1 -1
  5. package/build/cjs/components/EntityList/styled-components.js +1 -1
  6. package/build/cjs/components/EntityList/types.d.ts +8 -3
  7. package/build/cjs/components/EntityTree/BaseEntityTree.d.ts +4 -3
  8. package/build/cjs/components/EntityTree/BaseEntityTree.js +1 -1
  9. package/build/cjs/components/EntityTree/EntityTreeItem.js +1 -1
  10. package/build/cjs/components/EntityTree/EntityTreeItemExpandButton.d.ts +1 -1
  11. package/build/cjs/components/EntityTree/EntityTreeItemExpandButton.js +1 -1
  12. package/build/cjs/components/Form/Checkbox/Checkbox.d.ts +3 -0
  13. package/build/cjs/components/Form/Checkbox/Checkbox.js +1 -1
  14. package/build/cjs/components/Form/SearchInput/SearchInput.js +1 -1
  15. package/build/cjs/components/Form/Select/Select.js +1 -1
  16. package/build/cjs/shared/FocusTrapWrapper.d.ts +1 -1
  17. package/build/cjs/shared/FocusTrapWrapper.js +1 -1
  18. package/build/cjs/web-tokens/_colors.json +34 -80
  19. package/build/cjs/web-tokens/visualConfig.d.ts +4 -10
  20. package/build/cjs/web-tokens/visualConfig.js +1 -1
  21. package/build/esm/components/Badge/Badge.js +1 -1
  22. package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  23. package/build/esm/components/DataTable/TableCell.js +1 -1
  24. package/build/esm/components/EntityList/EntityListItem.js +1 -1
  25. package/build/esm/components/EntityList/styled-components.js +1 -1
  26. package/build/esm/components/EntityList/types.d.ts +8 -3
  27. package/build/esm/components/EntityTree/BaseEntityTree.d.ts +4 -3
  28. package/build/esm/components/EntityTree/BaseEntityTree.js +1 -1
  29. package/build/esm/components/EntityTree/EntityTreeItem.js +1 -1
  30. package/build/esm/components/EntityTree/EntityTreeItemExpandButton.d.ts +1 -1
  31. package/build/esm/components/EntityTree/EntityTreeItemExpandButton.js +1 -1
  32. package/build/esm/components/Form/Checkbox/Checkbox.d.ts +3 -0
  33. package/build/esm/components/Form/Checkbox/Checkbox.js +1 -1
  34. package/build/esm/components/Form/SearchInput/SearchInput.js +1 -1
  35. package/build/esm/components/Form/Select/Select.js +1 -1
  36. package/build/esm/shared/FocusTrapWrapper.d.ts +1 -1
  37. package/build/esm/shared/FocusTrapWrapper.js +1 -1
  38. package/build/esm/web-tokens/_colors.json +34 -80
  39. package/build/esm/web-tokens/visualConfig.d.ts +4 -10
  40. package/build/esm/web-tokens/visualConfig.js +1 -1
  41. package/build/scss/_theming.scss +9 -21
  42. package/build/scss/_variables.scss +2 -8
  43. package/package.json +1 -1
  44. package/build/cjs/components/EntityList/EntityListItemExpandButton.d.ts +0 -5
  45. package/build/cjs/components/EntityList/EntityListItemExpandButton.js +0 -1
  46. package/build/esm/components/EntityList/EntityListItemExpandButton.d.ts +0 -5
  47. package/build/esm/components/EntityList/EntityListItemExpandButton.js +0 -1
@@ -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{useEntityTreeKeyboard}from"./useEntityTreeKeyboard";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=({nodeChildrenMap,nodeCheckboxState,nodeExpandedState,handleSelectionChange,handleToggle,expandAll,hideBorder,size,showItemsCount,renderRightContent,activeId,focusedNodeId,changeFocusIndex,setFocusedNodeId,node,isFirstNode,level,renderFn,isLastNodeOfList})=>{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,{ref:itemRef,setFakeKeybordFocus,isFocused}=useEntityTreeKeyboard({isActive:focusedNodeId===node.id,config:{ArrowUp:()=>{changeFocusIndex(-1)},ArrowDown:()=>{changeFocusIndex(1)},ArrowRight:()=>{hasChildren&&!isExpanded&&handleToggle(node.id)},ArrowLeft:()=>{hasChildren&&isExpanded&&handleToggle(node.id)}}}),handleClick=readOnly?()=>handleToggle(node.id):()=>handleSelectionChange(node.id),tabIndex=isFirstNode||isFocused?0:-1;return /*#__PURE__*/React.createElement(EntityTreeItem,{ref:itemRef,key:node.id,hideBorder:hideBorder||isLastNodeOfList&&(!isExpanded||node.isFiltered),tabIndex:tabIndex,size:size,lSpaceStep:level,"aria-label":node.label,onKeyDown:()=>handleClick(),description:node.description,renderLabel:({textSize})=>/*#__PURE__*/React.createElement(React.Fragment,null,node.label,showItemsCount&&!lastLeaf&&/*#__PURE__*/React.createElement(Text,{as:"span",size:textSize,color:"tertiary"}," ",countLabel)),isActive:isFocused||activeId===node.id,isExpanded:isExpanded,isDisabledExpand:expandAll,isClickable:!readOnly,checkboxProps:!readOnly&&{size:"s",name:node.label,checked:nodeCheckboxState?.[node.id]==="checked",indeterminate:nodeCheckboxState?.[node.id]==="indeterminate",onChange:()=>handleSelectionChange(node.id)},onFocus:()=>{setFocusedNodeId(node.id),setFakeKeybordFocus(!0)},onExpandClick:e=>{e.stopPropagation(),handleToggle(node.id)},onClick:()=>handleToggle(node.id),renderRight:renderRightContent?sizeProps=>renderRightContent({...sizeProps,...node}):void 0},hasChildren&&/*#__PURE__*/React.createElement("ul",null,renderFn({data:node.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 /*#__PURE__*/React.createElement(Node,{key:node.id,level:level,node:node,isFirstNode:isFirstNode,renderFn:renderFn,isLastNodeOfList:isLastNodeOfList,...renderTreeArgs})});export const BaseEntityTree=({data,selectedIds,onSelectionChange,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),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,[focusedNodeId,setFocusedNodeId]=useState(null),listRef=React.useRef(null),handleBlur=useCallback(()=>{setTimeout(()=>{listRef.current&&!listRef.current.contains(document.activeElement)&&setFocusedNodeId(null)},0)},[listRef,setFocusedNodeId]),{hasMoreNodes,handleIncreaseMaxNodeCount,result}=useTreeTruncation({chunkSize,data:dataShown,nodeExpandedState,expandAll}),renderTreeBranches=makeRenderTreeBranches({nodeChildrenMap,nodeCheckboxState,nodeExpandedState,handleSelectionChange:targetId=>{if(onSelectionChange){let updatedSelectedIds=[];if(0===nodeChildrenMap[targetId].length)updatedSelectedIds=selectedIds.includes(targetId)?selectedIds.filter(id=>id!==targetId):selectedIds.concat([targetId]);else{let affectedLeafNodeIds=getLeafNodeIds(nodeChildrenMap,targetId);updatedSelectedIds="checked"===nodeCheckboxState[targetId]?selectedIds.filter(id=>!affectedLeafNodeIds.includes(id)):selectedIds.concat(affectedLeafNodeIds)}onSelectionChange(updatedSelectedIds)}},handleToggle:targetId=>{onToggle&&onToggle(expandedIds.includes(targetId)?expandedIds.filter(id=>id!==targetId):expandedIds.concat([targetId]))},expandAll,hideBorder,size,showItemsCount,renderRightContent,activeId:visibleActiveNodeId,focusedNodeId,changeFocusIndex:index=>{let flatTreeIds=flattenTree(dataShown,nodeExpandedState,expandAll),newIndex=index+flatTreeIds.indexOf(focusedNodeId);newIndex>=0&&newIndex<flatTreeIds.length&&setFocusedNodeId(flatTreeIds[newIndex])},setFocusedNodeId});return /*#__PURE__*/React.createElement(StyledList,{ref:listRef,role:"tree","data-e2e-test-id":dataE2eTestId,"data-ds-id":"EntityTree",size:size,onBlur:handleBlur},renderTreeBranches({data:result,level:0,renderFn:renderTreeBranches}),hasMoreNodes&&/*#__PURE__*/React.createElement(StyledShowMore,null,/*#__PURE__*/React.createElement(Box,{alignText:"center",space:"xs"},/*#__PURE__*/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{useEntityTreeKeyboard}from"./useEntityTreeKeyboard";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=({nodeChildrenMap,nodeCheckboxState,nodeExpandedState,handleSelectionChange,handleToggle,expandAll,hideBorder,size,showItemsCount,renderRightContent,activeId,focusedNodeId,changeFocusIndex,setFocusedNodeId,node,isFirstNode,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,{ref:itemRef,setFakeKeybordFocus,isFocused}=useEntityTreeKeyboard({isActive:focusedNodeId===node.id,config:{ArrowUp:()=>{changeFocusIndex(-1)},ArrowDown:()=>{changeFocusIndex(1)},ArrowRight:()=>{hasChildren&&!isExpanded&&handleToggle(node.id)},ArrowLeft:()=>{hasChildren&&isExpanded&&handleToggle(node.id)}}}),handleClick=readOnly?()=>handleToggle(node.id):()=>handleSelectionChange(node.id),tabIndex=isFirstNode||isFocused?0:-1;return /*#__PURE__*/React.createElement(EntityTreeItem,{ref:itemRef,key:node.id,hideBorder:hideBorder||isLastNodeOfList&&(!isExpanded||node.isFiltered),tabIndex:tabIndex,size:size,lSpaceStep:level,onKeyDown:()=>handleClick(),description:node.description,renderLabel:({textSize})=>/*#__PURE__*/React.createElement(React.Fragment,null,node.label,showItemsCount&&!lastLeaf&&/*#__PURE__*/React.createElement(Text,{as:"span",size:textSize,color:"tertiary"}," ",countLabel)),isActive:isFocused||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)},onFocus:()=>{setFocusedNodeId(node.id),setFakeKeybordFocus(!0)},onExpandClick:e=>{e.stopPropagation(),handleToggle(node.id)},isClickable:readOnly&&!renderRightContent,onClick:()=>handleToggle(node.id),renderRight:renderRightContent?sizeProps=>renderRightContent({...sizeProps,...node}):void 0,ariaLabelExpand:ariaLabelExpand,ariaLabelCollapse:ariaLabelCollapse,"aria-label":node.label,"aria-level":level+1},hasChildren&&/*#__PURE__*/React.createElement("ul",{role:"group"},renderFn({data:node.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 /*#__PURE__*/React.createElement(Node,{key:node.id,level:level,node:node,isFirstNode:isFirstNode,renderFn:renderFn,isLastNodeOfList:isLastNodeOfList,...renderTreeArgs})});export const BaseEntityTree=({ariaAttributes,data,selectedIds,onSelectionChange,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),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,[focusedNodeId,setFocusedNodeId]=useState(null),listRef=React.useRef(null),handleBlur=useCallback(()=>{setTimeout(()=>{listRef.current&&!listRef.current.contains(document.activeElement)&&setFocusedNodeId(null)},0)},[listRef,setFocusedNodeId]),{hasMoreNodes,handleIncreaseMaxNodeCount,result}=useTreeTruncation({chunkSize,data:dataShown,nodeExpandedState,expandAll}),renderTreeBranches=makeRenderTreeBranches({nodeChildrenMap,nodeCheckboxState,nodeExpandedState,handleSelectionChange:targetId=>{if(onSelectionChange){let updatedSelectedIds=[];if(0===nodeChildrenMap[targetId].length)updatedSelectedIds=selectedIds.includes(targetId)?selectedIds.filter(id=>id!==targetId):selectedIds.concat([targetId]);else{let affectedLeafNodeIds=getLeafNodeIds(nodeChildrenMap,targetId);updatedSelectedIds="checked"===nodeCheckboxState[targetId]?selectedIds.filter(id=>!affectedLeafNodeIds.includes(id)):selectedIds.concat(affectedLeafNodeIds)}onSelectionChange(updatedSelectedIds)}},handleToggle:targetId=>{onToggle&&onToggle(expandedIds.includes(targetId)?expandedIds.filter(id=>id!==targetId):expandedIds.concat([targetId]))},expandAll,hideBorder,size,showItemsCount,renderRightContent,activeId:visibleActiveNodeId,focusedNodeId,changeFocusIndex:index=>{let flatTreeIds=flattenTree(dataShown,nodeExpandedState,expandAll),newIndex=index+flatTreeIds.indexOf(focusedNodeId);newIndex>=0&&newIndex<flatTreeIds.length&&setFocusedNodeId(flatTreeIds[newIndex])},setFocusedNodeId,ariaLabelExpand:ariaAttributes?.ariaLabelExpand,ariaLabelCollapse:ariaAttributes?.ariaLabelCollapse});return /*#__PURE__*/React.createElement(StyledList,{ref:listRef,role:"tree","aria-multiselectable":!!nodeCheckboxState||void 0,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"EntityTree",size:size,onBlur:handleBlur},renderTreeBranches({data:result,level:0,renderFn:renderTreeBranches}),hasMoreNodes&&/*#__PURE__*/React.createElement(StyledShowMore,null,/*#__PURE__*/React.createElement(Box,{alignText:"center",space:"xs"},/*#__PURE__*/React.createElement(Button,{fullWidth:!0,size:"s",variant:"tertiary",onClick:handleIncreaseMaxNodeCount},showMoreButtonLabel))))};
@@ -1 +1 @@
1
- import React,{useCallback,useImperativeHandle,useRef}from"react";import styled from"@emotion/styled";import{mqValue}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=/*#__PURE__*/styled(StyledEntityListItemWrapper,{target:"eqtckgs0",label:"StyledEntityTreeItemWrapper"})({paddingLeft:"0 !important"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5VHJlZS9FbnRpdHlUcmVlSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eVRyZWUvRW50aXR5VHJlZUl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlSW1wZXJhdGl2ZUhhbmRsZSwgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IG1xVmFsdWUgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuaW1wb3J0IHsgRW50aXR5VHJlZUl0ZW1FeHBhbmRCdXR0b24gfSBmcm9tIFwiLi9FbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvblwiO1xuaW1wb3J0IHsgdXNlS2V5Ym9hcmQgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL3VzZUtleWJvYXJkXCI7XG5pbXBvcnQgeyBFbnRpdHlJdGVtQm9keSB9IGZyb20gXCIuLi9FbnRpdHlMaXN0L0VudGl0eUl0ZW1Cb2R5XCI7XG5pbXBvcnQge1xuICBTdHlsZWRFbnRpdHlJdGVtTGksXG4gIFN0eWxlZEVudGl0eUxpc3RJdGVtV3JhcHBlcixcbiAgU3R5bGVkRW50aXR5TGlzdEl0ZW1CdXR0b24sXG59IGZyb20gXCIuLi9FbnRpdHlMaXN0L3N0eWxlZC1jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IEVudGl0eUxpc3RJdGVtUHJvcHMgfSBmcm9tIFwiLi4vRW50aXR5TGlzdC90eXBlc1wiO1xuXG5jb25zdCBTdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXIgPSBzdHlsZWQoU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyKSh7XG4gIHBhZGRpbmdMZWZ0OiBcIjAgIWltcG9ydGFudFwiLCAvLyBcImltcG9ydGFudFwiIGlzIG5lZWRlZCB0byBvdmVycmlkZSB0aGUgQG1lZGlhIHF1ZXJ5IG9mIE1RIGZ1bmN0aW9uXG59KTtcblxuY29uc3QgU3R5bGVkRW50aXR5VHJlZUl0ZW1Db250YWluZXIgPSBzdHlsZWQoU3R5bGVkRW50aXR5TGlzdEl0ZW1CdXR0b24pPHtcbiAgaGFzRXhwYW5kYWJsZUljb246IGJvb2xlYW47XG59PigoeyB0aGVtZSwgaGFzRXhwYW5kYWJsZUljb24sIGxTcGFjZVN0ZXAgfSkgPT4ge1xuICBjb25zdCBnZXRTaXplID0gKGJhc2VPZmZzZXQ6IHN0cmluZywgZGVlcGVzdE5vZGVPZmZzZXQ6IHN0cmluZykgPT5cbiAgICBgY2FsYygke2Jhc2VPZmZzZXR9ICogJHtsU3BhY2VTdGVwfSArICR7XG4gICAgICBoYXNFeHBhbmRhYmxlSWNvbiA/IFwiMHB4XCIgOiBkZWVwZXN0Tm9kZU9mZnNldFxuICAgIH0gKyAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzfSlgO1xuXG4gIHJldHVybiB7XG4gICAgLi4ubXFWYWx1ZSh7XG4gICAgICBwYWRkaW5nTGVmdDogW1xuICAgICAgICAvLyA0MnB4IGFuZCA1NnB4IGFyZSBFeHBhbmQgYnV0dG9uIHdpZHRoICsgcGFkZGluZ1xuICAgICAgICAvLyBpdCdzIG5lZWRlZCBmb3IgYSBkZWVwZXN0IG5vZGUgd2l0aG91dCBleHBhbmRCdXR0b25cbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm0sIFwiNDJweFwiKSxcbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLCBcIjU2cHhcIiksXG4gICAgICBdLFxuICAgIH0pLFxuICB9O1xufSk7XG5cbmNvbnN0IHVzZUJ1dHRvbktleWJvYXJkID0gKHtcbiAgcmVmOiBnbG9iYWxSZWYsXG4gIGlzQWN0aXZlLFxuICBvbktleURvd24sXG59OiB7XG4gIHJlZjogUmVhY3QuUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgb25LZXlEb3duOiAoZTogS2V5Ym9hcmRFdmVudCkgPT4gdm9pZDtcbn0gJiBQYXJ0aWFsPEVudGl0eUxpc3RJdGVtUHJvcHM+KSA9PiB7XG4gIGNvbnN0IGxvY2FsUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICB1c2VLZXlib2FyZChcbiAgICB7XG4gICAgICBcIlNwYWNlIEVudGVyXCI6IG9uS2V5RG93bixcbiAgICB9LFxuICAgIGxvY2FsUmVmLFxuICAgIGlzQWN0aXZlLFxuICAgIHRydWVcbiAgKTtcblxuICB1c2VJbXBlcmF0aXZlSGFuZGxlKGdsb2JhbFJlZiwgKCkgPT4gbG9jYWxSZWYuY3VycmVudCk7XG5cbiAgcmV0dXJuIGxvY2FsUmVmO1xufTtcblxuZXhwb3J0IGNvbnN0IEVudGl0eVRyZWVJdGVtID0gUmVhY3QuZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgY2hlY2tib3hQcm9wcyxcbiAgICAgIGRlc2NyaXB0aW9uLFxuICAgICAgaGlkZUJvcmRlcixcbiAgICAgIGlzQWN0aXZlLFxuICAgICAgaXNDbGlja2FibGUsXG4gICAgICBpc0Rpc2FibGVkLFxuICAgICAgaXNEaXNhYmxlZEV4cGFuZCxcbiAgICAgIGlzRXhwYW5kZWQsXG4gICAgICBsU3BhY2VTdGVwLFxuICAgICAgb25FeHBhbmRDbGljayxcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBvbktleURvd24sXG4gICAgICBvbkZvY3VzLFxuICAgICAgcmVuZGVyTGFiZWwsXG4gICAgICByZW5kZXJMZWZ0LFxuICAgICAgcmVuZGVyUmlnaHQsXG4gICAgICBzaXplID0gXCJtXCIsXG4gICAgICB0YWJJbmRleCxcbiAgICAgIFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsXG4gICAgfTogRW50aXR5TGlzdEl0ZW1Qcm9wcyxcbiAgICByZWY6IFJlYWN0LlJlZk9iamVjdDxIVE1MRGl2RWxlbWVudD5cbiAgKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgICBjb25zdCBoYXNFeHBhbmRhYmxlSWNvbiA9IGlzRXhwYW5kZWQgIT09IHVuZGVmaW5lZDtcbiAgICBjb25zdCBoYW5kbGVPbkNsaWNrID0gdXNlQ2FsbGJhY2soXG4gICAgICAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgICAgICBpZiAoaXNDbGlja2FibGUgJiYgb25DbGljaykge1xuICAgICAgICAgIG9uQ2xpY2soZSk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBbb25DbGljaywgaXNDbGlja2FibGVdXG4gICAgKTtcblxuICAgIGNvbnN0IGJ1dHRvblJlZiA9IHVzZUJ1dHRvbktleWJvYXJkKHtcbiAgICAgIHJlZixcbiAgICAgIGlzQWN0aXZlOiBpc0FjdGl2ZSAmJiBpc0NsaWNrYWJsZSxcbiAgICAgIG9uS2V5RG93bixcbiAgICB9KTtcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkRW50aXR5SXRlbUxpXG4gICAgICAgIGFyaWEtZXhwYW5kZWQ9e2lzRXhwYW5kZWR9XG4gICAgICAgIGFyaWEtbGFiZWw9e2FyaWFMYWJlbH1cbiAgICAgICAgcm9sZT1cInRyZWVpdGVtXCJcbiAgICAgID5cbiAgICAgICAgPFN0eWxlZEVudGl0eVRyZWVJdGVtQ29udGFpbmVyXG4gICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgcm9sZT17aXNDbGlja2FibGUgPyBcImJ1dHRvblwiIDogXCJyZXByZXNlbnRhdGlvblwifVxuICAgICAgICAgIGlzQWN0aXZlPXtpc0FjdGl2ZX1cbiAgICAgICAgICByZWY9e2J1dHRvblJlZn1cbiAgICAgICAgICBoYXNFeHBhbmRhYmxlSWNvbj17aGFzRXhwYW5kYWJsZUljb259XG4gICAgICAgICAgbFNwYWNlU3RlcD17bFNwYWNlU3RlcH1cbiAgICAgICAgICBpc0Rpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZU9uQ2xpY2t9XG4gICAgICAgICAgaXNDbGlja2FibGU9e2lzQ2xpY2thYmxlfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgID5cbiAgICAgICAgICB7aGFzRXhwYW5kYWJsZUljb24gJiYgKFxuICAgICAgICAgICAgPEVudGl0eVRyZWVJdGVtRXhwYW5kQnV0dG9uXG4gICAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgICAgaXNEaXNhYmxlZD17aXNEaXNhYmxlZEV4cGFuZCB8fCBpc0Rpc2FibGVkfVxuICAgICAgICAgICAgICBpc0V4cGFuZGVkPXtpc0V4cGFuZGVkfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtvbkV4cGFuZENsaWNrfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIDxTdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXJcbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICBoaWRlQm9yZGVyPXtoaWRlQm9yZGVyIHx8IHNpemUgPT09IFwieHNcIn1cbiAgICAgICAgICA+XG4gICAgICAgICAgICA8RW50aXR5SXRlbUJvZHlcbiAgICAgICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICAgICAgICBkZXNjcmlwdGlvbj17ZGVzY3JpcHRpb259XG4gICAgICAgICAgICAgIHJlbmRlckxhYmVsPXtyZW5kZXJMYWJlbH1cbiAgICAgICAgICAgICAgcmVuZGVyTGVmdD17cmVuZGVyTGVmdH1cbiAgICAgICAgICAgICAgcmVuZGVyUmlnaHQ9e3JlbmRlclJpZ2h0fVxuICAgICAgICAgICAgICBjaGVja2JveFByb3BzPXtjaGVja2JveFByb3BzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1N0eWxlZEVudGl0eVRyZWVJdGVtV3JhcHBlcj5cbiAgICAgICAgPC9TdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lcj5cbiAgICAgICAge2lzRXhwYW5kZWQgJiYgY2hpbGRyZW59XG4gICAgICA8L1N0eWxlZEVudGl0eUl0ZW1MaT5cbiAgICApO1xuICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWFvQyJ9 */"),StyledEntityTreeItemContainer=/*#__PURE__*/styled(StyledEntityListItemButton,{target:"eqtckgs1",label:"StyledEntityTreeItemContainer"})(({theme,hasExpandableIcon,lSpaceStep})=>{let getSize=(baseOffset,deepestNodeOffset)=>`calc(${baseOffset} * ${lSpaceStep} + ${hasExpandableIcon?"0px":deepestNodeOffset} + ${theme.variables.size.spacing.xxs})`;return{...mqValue({paddingLeft:[getSize(theme.variables.size.spacing.m,"42px"),getSize(theme.variables.size.spacing.xl,"56px")]})}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5VHJlZS9FbnRpdHlUcmVlSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eVRyZWUvRW50aXR5VHJlZUl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlSW1wZXJhdGl2ZUhhbmRsZSwgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IG1xVmFsdWUgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuaW1wb3J0IHsgRW50aXR5VHJlZUl0ZW1FeHBhbmRCdXR0b24gfSBmcm9tIFwiLi9FbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvblwiO1xuaW1wb3J0IHsgdXNlS2V5Ym9hcmQgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL3VzZUtleWJvYXJkXCI7XG5pbXBvcnQgeyBFbnRpdHlJdGVtQm9keSB9IGZyb20gXCIuLi9FbnRpdHlMaXN0L0VudGl0eUl0ZW1Cb2R5XCI7XG5pbXBvcnQge1xuICBTdHlsZWRFbnRpdHlJdGVtTGksXG4gIFN0eWxlZEVudGl0eUxpc3RJdGVtV3JhcHBlcixcbiAgU3R5bGVkRW50aXR5TGlzdEl0ZW1CdXR0b24sXG59IGZyb20gXCIuLi9FbnRpdHlMaXN0L3N0eWxlZC1jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IEVudGl0eUxpc3RJdGVtUHJvcHMgfSBmcm9tIFwiLi4vRW50aXR5TGlzdC90eXBlc1wiO1xuXG5jb25zdCBTdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXIgPSBzdHlsZWQoU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyKSh7XG4gIHBhZGRpbmdMZWZ0OiBcIjAgIWltcG9ydGFudFwiLCAvLyBcImltcG9ydGFudFwiIGlzIG5lZWRlZCB0byBvdmVycmlkZSB0aGUgQG1lZGlhIHF1ZXJ5IG9mIE1RIGZ1bmN0aW9uXG59KTtcblxuY29uc3QgU3R5bGVkRW50aXR5VHJlZUl0ZW1Db250YWluZXIgPSBzdHlsZWQoU3R5bGVkRW50aXR5TGlzdEl0ZW1CdXR0b24pPHtcbiAgaGFzRXhwYW5kYWJsZUljb246IGJvb2xlYW47XG59PigoeyB0aGVtZSwgaGFzRXhwYW5kYWJsZUljb24sIGxTcGFjZVN0ZXAgfSkgPT4ge1xuICBjb25zdCBnZXRTaXplID0gKGJhc2VPZmZzZXQ6IHN0cmluZywgZGVlcGVzdE5vZGVPZmZzZXQ6IHN0cmluZykgPT5cbiAgICBgY2FsYygke2Jhc2VPZmZzZXR9ICogJHtsU3BhY2VTdGVwfSArICR7XG4gICAgICBoYXNFeHBhbmRhYmxlSWNvbiA/IFwiMHB4XCIgOiBkZWVwZXN0Tm9kZU9mZnNldFxuICAgIH0gKyAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzfSlgO1xuXG4gIHJldHVybiB7XG4gICAgLi4ubXFWYWx1ZSh7XG4gICAgICBwYWRkaW5nTGVmdDogW1xuICAgICAgICAvLyA0MnB4IGFuZCA1NnB4IGFyZSBFeHBhbmQgYnV0dG9uIHdpZHRoICsgcGFkZGluZ1xuICAgICAgICAvLyBpdCdzIG5lZWRlZCBmb3IgYSBkZWVwZXN0IG5vZGUgd2l0aG91dCBleHBhbmRCdXR0b25cbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm0sIFwiNDJweFwiKSxcbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLCBcIjU2cHhcIiksXG4gICAgICBdLFxuICAgIH0pLFxuICB9O1xufSk7XG5cbmNvbnN0IHVzZUJ1dHRvbktleWJvYXJkID0gKHtcbiAgcmVmOiBnbG9iYWxSZWYsXG4gIGlzQWN0aXZlLFxuICBvbktleURvd24sXG59OiB7XG4gIHJlZjogUmVhY3QuUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgb25LZXlEb3duOiAoZTogS2V5Ym9hcmRFdmVudCkgPT4gdm9pZDtcbn0gJiBQYXJ0aWFsPEVudGl0eUxpc3RJdGVtUHJvcHM+KSA9PiB7XG4gIGNvbnN0IGxvY2FsUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICB1c2VLZXlib2FyZChcbiAgICB7XG4gICAgICBcIlNwYWNlIEVudGVyXCI6IG9uS2V5RG93bixcbiAgICB9LFxuICAgIGxvY2FsUmVmLFxuICAgIGlzQWN0aXZlLFxuICAgIHRydWVcbiAgKTtcblxuICB1c2VJbXBlcmF0aXZlSGFuZGxlKGdsb2JhbFJlZiwgKCkgPT4gbG9jYWxSZWYuY3VycmVudCk7XG5cbiAgcmV0dXJuIGxvY2FsUmVmO1xufTtcblxuZXhwb3J0IGNvbnN0IEVudGl0eVRyZWVJdGVtID0gUmVhY3QuZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgY2hlY2tib3hQcm9wcyxcbiAgICAgIGRlc2NyaXB0aW9uLFxuICAgICAgaGlkZUJvcmRlcixcbiAgICAgIGlzQWN0aXZlLFxuICAgICAgaXNDbGlja2FibGUsXG4gICAgICBpc0Rpc2FibGVkLFxuICAgICAgaXNEaXNhYmxlZEV4cGFuZCxcbiAgICAgIGlzRXhwYW5kZWQsXG4gICAgICBsU3BhY2VTdGVwLFxuICAgICAgb25FeHBhbmRDbGljayxcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBvbktleURvd24sXG4gICAgICBvbkZvY3VzLFxuICAgICAgcmVuZGVyTGFiZWwsXG4gICAgICByZW5kZXJMZWZ0LFxuICAgICAgcmVuZGVyUmlnaHQsXG4gICAgICBzaXplID0gXCJtXCIsXG4gICAgICB0YWJJbmRleCxcbiAgICAgIFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsXG4gICAgfTogRW50aXR5TGlzdEl0ZW1Qcm9wcyxcbiAgICByZWY6IFJlYWN0LlJlZk9iamVjdDxIVE1MRGl2RWxlbWVudD5cbiAgKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgICBjb25zdCBoYXNFeHBhbmRhYmxlSWNvbiA9IGlzRXhwYW5kZWQgIT09IHVuZGVmaW5lZDtcbiAgICBjb25zdCBoYW5kbGVPbkNsaWNrID0gdXNlQ2FsbGJhY2soXG4gICAgICAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgICAgICBpZiAoaXNDbGlja2FibGUgJiYgb25DbGljaykge1xuICAgICAgICAgIG9uQ2xpY2soZSk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBbb25DbGljaywgaXNDbGlja2FibGVdXG4gICAgKTtcblxuICAgIGNvbnN0IGJ1dHRvblJlZiA9IHVzZUJ1dHRvbktleWJvYXJkKHtcbiAgICAgIHJlZixcbiAgICAgIGlzQWN0aXZlOiBpc0FjdGl2ZSAmJiBpc0NsaWNrYWJsZSxcbiAgICAgIG9uS2V5RG93bixcbiAgICB9KTtcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkRW50aXR5SXRlbUxpXG4gICAgICAgIGFyaWEtZXhwYW5kZWQ9e2lzRXhwYW5kZWR9XG4gICAgICAgIGFyaWEtbGFiZWw9e2FyaWFMYWJlbH1cbiAgICAgICAgcm9sZT1cInRyZWVpdGVtXCJcbiAgICAgID5cbiAgICAgICAgPFN0eWxlZEVudGl0eVRyZWVJdGVtQ29udGFpbmVyXG4gICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgcm9sZT17aXNDbGlja2FibGUgPyBcImJ1dHRvblwiIDogXCJyZXByZXNlbnRhdGlvblwifVxuICAgICAgICAgIGlzQWN0aXZlPXtpc0FjdGl2ZX1cbiAgICAgICAgICByZWY9e2J1dHRvblJlZn1cbiAgICAgICAgICBoYXNFeHBhbmRhYmxlSWNvbj17aGFzRXhwYW5kYWJsZUljb259XG4gICAgICAgICAgbFNwYWNlU3RlcD17bFNwYWNlU3RlcH1cbiAgICAgICAgICBpc0Rpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZU9uQ2xpY2t9XG4gICAgICAgICAgaXNDbGlja2FibGU9e2lzQ2xpY2thYmxlfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgID5cbiAgICAgICAgICB7aGFzRXhwYW5kYWJsZUljb24gJiYgKFxuICAgICAgICAgICAgPEVudGl0eVRyZWVJdGVtRXhwYW5kQnV0dG9uXG4gICAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgICAgaXNEaXNhYmxlZD17aXNEaXNhYmxlZEV4cGFuZCB8fCBpc0Rpc2FibGVkfVxuICAgICAgICAgICAgICBpc0V4cGFuZGVkPXtpc0V4cGFuZGVkfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtvbkV4cGFuZENsaWNrfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIDxTdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXJcbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICBoaWRlQm9yZGVyPXtoaWRlQm9yZGVyIHx8IHNpemUgPT09IFwieHNcIn1cbiAgICAgICAgICA+XG4gICAgICAgICAgICA8RW50aXR5SXRlbUJvZHlcbiAgICAgICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICAgICAgICBkZXNjcmlwdGlvbj17ZGVzY3JpcHRpb259XG4gICAgICAgICAgICAgIHJlbmRlckxhYmVsPXtyZW5kZXJMYWJlbH1cbiAgICAgICAgICAgICAgcmVuZGVyTGVmdD17cmVuZGVyTGVmdH1cbiAgICAgICAgICAgICAgcmVuZGVyUmlnaHQ9e3JlbmRlclJpZ2h0fVxuICAgICAgICAgICAgICBjaGVja2JveFByb3BzPXtjaGVja2JveFByb3BzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1N0eWxlZEVudGl0eVRyZWVJdGVtV3JhcHBlcj5cbiAgICAgICAgPC9TdHlsZWRFbnRpdHlUcmVlSXRlbUNvbnRhaW5lcj5cbiAgICAgICAge2lzRXhwYW5kZWQgJiYgY2hpbGRyZW59XG4gICAgICA8L1N0eWxlZEVudGl0eUl0ZW1MaT5cbiAgICApO1xuICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCc0MifQ== */"),useButtonKeyboard=({ref:globalRef,isActive,onKeyDown})=>{let localRef=useRef(null);return useKeyboard({"Space Enter":onKeyDown},localRef,isActive,!0),useImperativeHandle(globalRef,()=>localRef.current),localRef};export const EntityTreeItem=/*#__PURE__*/React.forwardRef(({children,checkboxProps,description,hideBorder,isActive,isClickable,isDisabled,isDisabledExpand,isExpanded,lSpaceStep,onExpandClick,onClick,onKeyDown,onFocus,renderLabel,renderLeft,renderRight,size="m",tabIndex,"aria-label":ariaLabel},ref)=>{let hasExpandableIcon=void 0!==isExpanded,handleOnClick=useCallback(e=>{isClickable&&onClick&&onClick(e)},[onClick,isClickable]),buttonRef=useButtonKeyboard({ref,isActive:isActive&&isClickable,onKeyDown});return /*#__PURE__*/React.createElement(StyledEntityItemLi,{"aria-expanded":isExpanded,"aria-label":ariaLabel,role:"treeitem"},/*#__PURE__*/React.createElement(StyledEntityTreeItemContainer,{size:size,tabIndex:tabIndex,role:isClickable?"button":"representation",isActive:isActive,ref:buttonRef,hasExpandableIcon:hasExpandableIcon,lSpaceStep:lSpaceStep,isDisabled:isDisabled,onClick:handleOnClick,isClickable:isClickable,onFocus:onFocus},hasExpandableIcon&&/*#__PURE__*/React.createElement(EntityTreeItemExpandButton,{size:size,tabIndex:tabIndex,isDisabled:isDisabledExpand||isDisabled,isExpanded:isExpanded,onClick:onExpandClick}),/*#__PURE__*/React.createElement(StyledEntityTreeItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},/*#__PURE__*/React.createElement(EntityItemBody,{size:size,tabIndex:tabIndex,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight,checkboxProps:checkboxProps}))),isExpanded&&children)});
1
+ import React,{useCallback,useImperativeHandle,useRef}from"react";import styled from"@emotion/styled";import{mqValue}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=/*#__PURE__*/styled(StyledEntityListItemWrapper,{target:"eeonynx0",label:"StyledEntityTreeItemWrapper"})({paddingLeft:"0 !important"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5VHJlZS9FbnRpdHlUcmVlSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eVRyZWUvRW50aXR5VHJlZUl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlSW1wZXJhdGl2ZUhhbmRsZSwgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IG1xVmFsdWUgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuaW1wb3J0IHsgRW50aXR5VHJlZUl0ZW1FeHBhbmRCdXR0b24gfSBmcm9tIFwiLi9FbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvblwiO1xuaW1wb3J0IHsgdXNlS2V5Ym9hcmQgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL3VzZUtleWJvYXJkXCI7XG5pbXBvcnQgeyBFbnRpdHlJdGVtQm9keSB9IGZyb20gXCIuLi9FbnRpdHlMaXN0L0VudGl0eUl0ZW1Cb2R5XCI7XG5pbXBvcnQge1xuICBTdHlsZWRFbnRpdHlJdGVtTGksXG4gIFN0eWxlZEVudGl0eUxpc3RJdGVtV3JhcHBlcixcbiAgU3R5bGVkRW50aXR5TGlzdEl0ZW1CdXR0b24sXG59IGZyb20gXCIuLi9FbnRpdHlMaXN0L3N0eWxlZC1jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IEVudGl0eUxpc3RJdGVtUHJvcHMgfSBmcm9tIFwiLi4vRW50aXR5TGlzdC90eXBlc1wiO1xuXG5jb25zdCBTdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXIgPSBzdHlsZWQoU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyKSh7XG4gIHBhZGRpbmdMZWZ0OiBcIjAgIWltcG9ydGFudFwiLCAvLyBcImltcG9ydGFudFwiIGlzIG5lZWRlZCB0byBvdmVycmlkZSB0aGUgQG1lZGlhIHF1ZXJ5IG9mIE1RIGZ1bmN0aW9uXG59KTtcblxuY29uc3QgU3R5bGVkRW50aXR5VHJlZUl0ZW1Db250YWluZXIgPSBzdHlsZWQoU3R5bGVkRW50aXR5TGlzdEl0ZW1CdXR0b24pPHtcbiAgaGFzRXhwYW5kYWJsZUljb246IGJvb2xlYW47XG59PigoeyB0aGVtZSwgaGFzRXhwYW5kYWJsZUljb24sIGxTcGFjZVN0ZXAgfSkgPT4ge1xuICBjb25zdCBnZXRTaXplID0gKGJhc2VPZmZzZXQ6IHN0cmluZywgZGVlcGVzdE5vZGVPZmZzZXQ6IHN0cmluZykgPT5cbiAgICBgY2FsYygke2Jhc2VPZmZzZXR9ICogJHtsU3BhY2VTdGVwfSArICR7XG4gICAgICBoYXNFeHBhbmRhYmxlSWNvbiA/IFwiMHB4XCIgOiBkZWVwZXN0Tm9kZU9mZnNldFxuICAgIH0gKyAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzfSlgO1xuXG4gIHJldHVybiB7XG4gICAgLi4ubXFWYWx1ZSh7XG4gICAgICBwYWRkaW5nTGVmdDogW1xuICAgICAgICAvLyA0MnB4IGFuZCA1NnB4IGFyZSBFeHBhbmQgYnV0dG9uIHdpZHRoICsgcGFkZGluZ1xuICAgICAgICAvLyBpdCdzIG5lZWRlZCBmb3IgYSBkZWVwZXN0IG5vZGUgd2l0aG91dCBleHBhbmRCdXR0b25cbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm0sIFwiNDJweFwiKSxcbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLCBcIjU2cHhcIiksXG4gICAgICBdLFxuICAgIH0pLFxuICB9O1xufSk7XG5cbmNvbnN0IHVzZUJ1dHRvbktleWJvYXJkID0gKHtcbiAgcmVmOiBnbG9iYWxSZWYsXG4gIGlzQWN0aXZlLFxuICBvbktleURvd24sXG59OiB7XG4gIHJlZjogUmVhY3QuUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgb25LZXlEb3duOiAoZTogS2V5Ym9hcmRFdmVudCkgPT4gdm9pZDtcbn0gJiBQYXJ0aWFsPEVudGl0eUxpc3RJdGVtUHJvcHM+KSA9PiB7XG4gIGNvbnN0IGxvY2FsUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICB1c2VLZXlib2FyZChcbiAgICB7XG4gICAgICBcIlNwYWNlIEVudGVyXCI6IG9uS2V5RG93bixcbiAgICB9LFxuICAgIGxvY2FsUmVmLFxuICAgIGlzQWN0aXZlLFxuICAgIHRydWVcbiAgKTtcblxuICB1c2VJbXBlcmF0aXZlSGFuZGxlKGdsb2JhbFJlZiwgKCkgPT4gbG9jYWxSZWYuY3VycmVudCk7XG5cbiAgcmV0dXJuIGxvY2FsUmVmO1xufTtcblxuZXhwb3J0IGNvbnN0IEVudGl0eVRyZWVJdGVtID0gUmVhY3QuZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGNoZWNrYm94UHJvcHMsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGRlc2NyaXB0aW9uLFxuICAgICAgaGlkZUJvcmRlcixcbiAgICAgIGlzQWN0aXZlLFxuICAgICAgaXNDbGlja2FibGUsXG4gICAgICBpc0Rpc2FibGVkLFxuICAgICAgaXNEaXNhYmxlZEV4cGFuZCxcbiAgICAgIGlzRXhwYW5kZWQsXG4gICAgICBsU3BhY2VTdGVwLFxuICAgICAgb25DbGljayxcbiAgICAgIG9uRXhwYW5kQ2xpY2ssXG4gICAgICBvbkZvY3VzLFxuICAgICAgb25LZXlEb3duLFxuICAgICAgcmVuZGVyTGFiZWwsXG4gICAgICByZW5kZXJMZWZ0LFxuICAgICAgcmVuZGVyUmlnaHQsXG4gICAgICBzaXplID0gXCJtXCIsXG4gICAgICB0YWJJbmRleCxcbiAgICAgIGFyaWFMYWJlbEV4cGFuZCxcbiAgICAgIGFyaWFMYWJlbENvbGxhcHNlLFxuICAgICAgXCJhcmlhLWxldmVsXCI6IGFyaWFMZXZlbCxcbiAgICAgIFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsXG4gICAgfTogRW50aXR5TGlzdEl0ZW1Qcm9wcyxcbiAgICByZWY6IFJlYWN0LlJlZk9iamVjdDxIVE1MRGl2RWxlbWVudD5cbiAgKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgICBjb25zdCBoYXNFeHBhbmRhYmxlSWNvbiA9IGlzRXhwYW5kZWQgIT09IHVuZGVmaW5lZDtcblxuICAgIGNvbnN0IGhhbmRsZU9uQ2xpY2sgPSB1c2VDYWxsYmFjayhcbiAgICAgIChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGlmIChpc0NsaWNrYWJsZSAmJiBvbkNsaWNrKSB7XG4gICAgICAgICAgb25DbGljayhlKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIFtvbkNsaWNrLCBpc0NsaWNrYWJsZV1cbiAgICApO1xuXG4gICAgY29uc3QgYnV0dG9uUmVmID0gdXNlQnV0dG9uS2V5Ym9hcmQoe1xuICAgICAgcmVmLFxuICAgICAgaXNBY3RpdmU6IGlzQWN0aXZlICYmIChpc0NsaWNrYWJsZSB8fCAhIWNoZWNrYm94UHJvcHMpLFxuICAgICAgb25LZXlEb3duLFxuICAgIH0pO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRFbnRpdHlJdGVtTGlcbiAgICAgICAgcm9sZT1cInRyZWVpdGVtXCJcbiAgICAgICAgYXJpYS1leHBhbmRlZD17aGFzRXhwYW5kYWJsZUljb24gPyBpc0V4cGFuZGVkIDogdW5kZWZpbmVkfVxuICAgICAgICBhcmlhLWNoZWNrZWQ9e2NoZWNrYm94UHJvcHM/LmNoZWNrZWR9XG4gICAgICAgIGFyaWEtbGFiZWw9e2FyaWFMYWJlbH1cbiAgICAgICAgYXJpYS1sZXZlbD17YXJpYUxldmVsfVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkRW50aXR5VHJlZUl0ZW1Db250YWluZXJcbiAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICByb2xlPVwicHJlc2VudGF0aW9uXCJcbiAgICAgICAgICBpc0FjdGl2ZT17aXNBY3RpdmV9XG4gICAgICAgICAgcmVmPXtidXR0b25SZWZ9XG4gICAgICAgICAgaGFzRXhwYW5kYWJsZUljb249e2hhc0V4cGFuZGFibGVJY29ufVxuICAgICAgICAgIGxTcGFjZVN0ZXA9e2xTcGFjZVN0ZXB9XG4gICAgICAgICAgaXNEaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZU9uQ2xpY2t9XG4gICAgICAgICAgaXNDbGlja2FibGU9e2lzQ2xpY2thYmxlfVxuICAgICAgICA+XG4gICAgICAgICAge2hhc0V4cGFuZGFibGVJY29uICYmIChcbiAgICAgICAgICAgIDxFbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvblxuICAgICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWRFeHBhbmQgfHwgaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgaXNFeHBhbmRlZD17aXNFeHBhbmRlZH1cbiAgICAgICAgICAgICAgb25DbGljaz17b25FeHBhbmRDbGlja31cbiAgICAgICAgICAgICAgYXJpYUxhYmVsRXhwYW5kPXthcmlhTGFiZWxFeHBhbmR9XG4gICAgICAgICAgICAgIGFyaWFMYWJlbENvbGxhcHNlPXthcmlhTGFiZWxDb2xsYXBzZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8U3R5bGVkRW50aXR5VHJlZUl0ZW1XcmFwcGVyXG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgaGlkZUJvcmRlcj17aGlkZUJvcmRlciB8fCBzaXplID09PSBcInhzXCJ9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPEVudGl0eUl0ZW1Cb2R5XG4gICAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgICAgZGVzY3JpcHRpb249e2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgICByZW5kZXJMYWJlbD17cmVuZGVyTGFiZWx9XG4gICAgICAgICAgICAgIHJlbmRlckxlZnQ9e3JlbmRlckxlZnR9XG4gICAgICAgICAgICAgIHJlbmRlclJpZ2h0PXtyZW5kZXJSaWdodH1cbiAgICAgICAgICAgICAgY2hlY2tib3hQcm9wcz17Y2hlY2tib3hQcm9wc31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXI+XG4gICAgICAgIDwvU3R5bGVkRW50aXR5VHJlZUl0ZW1Db250YWluZXI+XG4gICAgICAgIHtpc0V4cGFuZGVkICYmIGNoaWxkcmVufVxuICAgICAgPC9TdHlsZWRFbnRpdHlJdGVtTGk+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhb0MifQ== */"),StyledEntityTreeItemContainer=/*#__PURE__*/styled(StyledEntityListItemButton,{target:"eeonynx1",label:"StyledEntityTreeItemContainer"})(({theme,hasExpandableIcon,lSpaceStep})=>{let getSize=(baseOffset,deepestNodeOffset)=>`calc(${baseOffset} * ${lSpaceStep} + ${hasExpandableIcon?"0px":deepestNodeOffset} + ${theme.variables.size.spacing.xxs})`;return{...mqValue({paddingLeft:[getSize(theme.variables.size.spacing.m,"42px"),getSize(theme.variables.size.spacing.xl,"56px")]})}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5VHJlZS9FbnRpdHlUcmVlSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eVRyZWUvRW50aXR5VHJlZUl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlSW1wZXJhdGl2ZUhhbmRsZSwgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IG1xVmFsdWUgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuaW1wb3J0IHsgRW50aXR5VHJlZUl0ZW1FeHBhbmRCdXR0b24gfSBmcm9tIFwiLi9FbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvblwiO1xuaW1wb3J0IHsgdXNlS2V5Ym9hcmQgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL3VzZUtleWJvYXJkXCI7XG5pbXBvcnQgeyBFbnRpdHlJdGVtQm9keSB9IGZyb20gXCIuLi9FbnRpdHlMaXN0L0VudGl0eUl0ZW1Cb2R5XCI7XG5pbXBvcnQge1xuICBTdHlsZWRFbnRpdHlJdGVtTGksXG4gIFN0eWxlZEVudGl0eUxpc3RJdGVtV3JhcHBlcixcbiAgU3R5bGVkRW50aXR5TGlzdEl0ZW1CdXR0b24sXG59IGZyb20gXCIuLi9FbnRpdHlMaXN0L3N0eWxlZC1jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IEVudGl0eUxpc3RJdGVtUHJvcHMgfSBmcm9tIFwiLi4vRW50aXR5TGlzdC90eXBlc1wiO1xuXG5jb25zdCBTdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXIgPSBzdHlsZWQoU3R5bGVkRW50aXR5TGlzdEl0ZW1XcmFwcGVyKSh7XG4gIHBhZGRpbmdMZWZ0OiBcIjAgIWltcG9ydGFudFwiLCAvLyBcImltcG9ydGFudFwiIGlzIG5lZWRlZCB0byBvdmVycmlkZSB0aGUgQG1lZGlhIHF1ZXJ5IG9mIE1RIGZ1bmN0aW9uXG59KTtcblxuY29uc3QgU3R5bGVkRW50aXR5VHJlZUl0ZW1Db250YWluZXIgPSBzdHlsZWQoU3R5bGVkRW50aXR5TGlzdEl0ZW1CdXR0b24pPHtcbiAgaGFzRXhwYW5kYWJsZUljb246IGJvb2xlYW47XG59PigoeyB0aGVtZSwgaGFzRXhwYW5kYWJsZUljb24sIGxTcGFjZVN0ZXAgfSkgPT4ge1xuICBjb25zdCBnZXRTaXplID0gKGJhc2VPZmZzZXQ6IHN0cmluZywgZGVlcGVzdE5vZGVPZmZzZXQ6IHN0cmluZykgPT5cbiAgICBgY2FsYygke2Jhc2VPZmZzZXR9ICogJHtsU3BhY2VTdGVwfSArICR7XG4gICAgICBoYXNFeHBhbmRhYmxlSWNvbiA/IFwiMHB4XCIgOiBkZWVwZXN0Tm9kZU9mZnNldFxuICAgIH0gKyAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzfSlgO1xuXG4gIHJldHVybiB7XG4gICAgLi4ubXFWYWx1ZSh7XG4gICAgICBwYWRkaW5nTGVmdDogW1xuICAgICAgICAvLyA0MnB4IGFuZCA1NnB4IGFyZSBFeHBhbmQgYnV0dG9uIHdpZHRoICsgcGFkZGluZ1xuICAgICAgICAvLyBpdCdzIG5lZWRlZCBmb3IgYSBkZWVwZXN0IG5vZGUgd2l0aG91dCBleHBhbmRCdXR0b25cbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm0sIFwiNDJweFwiKSxcbiAgICAgICAgZ2V0U2l6ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLCBcIjU2cHhcIiksXG4gICAgICBdLFxuICAgIH0pLFxuICB9O1xufSk7XG5cbmNvbnN0IHVzZUJ1dHRvbktleWJvYXJkID0gKHtcbiAgcmVmOiBnbG9iYWxSZWYsXG4gIGlzQWN0aXZlLFxuICBvbktleURvd24sXG59OiB7XG4gIHJlZjogUmVhY3QuUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgb25LZXlEb3duOiAoZTogS2V5Ym9hcmRFdmVudCkgPT4gdm9pZDtcbn0gJiBQYXJ0aWFsPEVudGl0eUxpc3RJdGVtUHJvcHM+KSA9PiB7XG4gIGNvbnN0IGxvY2FsUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICB1c2VLZXlib2FyZChcbiAgICB7XG4gICAgICBcIlNwYWNlIEVudGVyXCI6IG9uS2V5RG93bixcbiAgICB9LFxuICAgIGxvY2FsUmVmLFxuICAgIGlzQWN0aXZlLFxuICAgIHRydWVcbiAgKTtcblxuICB1c2VJbXBlcmF0aXZlSGFuZGxlKGdsb2JhbFJlZiwgKCkgPT4gbG9jYWxSZWYuY3VycmVudCk7XG5cbiAgcmV0dXJuIGxvY2FsUmVmO1xufTtcblxuZXhwb3J0IGNvbnN0IEVudGl0eVRyZWVJdGVtID0gUmVhY3QuZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGNoZWNrYm94UHJvcHMsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGRlc2NyaXB0aW9uLFxuICAgICAgaGlkZUJvcmRlcixcbiAgICAgIGlzQWN0aXZlLFxuICAgICAgaXNDbGlja2FibGUsXG4gICAgICBpc0Rpc2FibGVkLFxuICAgICAgaXNEaXNhYmxlZEV4cGFuZCxcbiAgICAgIGlzRXhwYW5kZWQsXG4gICAgICBsU3BhY2VTdGVwLFxuICAgICAgb25DbGljayxcbiAgICAgIG9uRXhwYW5kQ2xpY2ssXG4gICAgICBvbkZvY3VzLFxuICAgICAgb25LZXlEb3duLFxuICAgICAgcmVuZGVyTGFiZWwsXG4gICAgICByZW5kZXJMZWZ0LFxuICAgICAgcmVuZGVyUmlnaHQsXG4gICAgICBzaXplID0gXCJtXCIsXG4gICAgICB0YWJJbmRleCxcbiAgICAgIGFyaWFMYWJlbEV4cGFuZCxcbiAgICAgIGFyaWFMYWJlbENvbGxhcHNlLFxuICAgICAgXCJhcmlhLWxldmVsXCI6IGFyaWFMZXZlbCxcbiAgICAgIFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsXG4gICAgfTogRW50aXR5TGlzdEl0ZW1Qcm9wcyxcbiAgICByZWY6IFJlYWN0LlJlZk9iamVjdDxIVE1MRGl2RWxlbWVudD5cbiAgKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgICBjb25zdCBoYXNFeHBhbmRhYmxlSWNvbiA9IGlzRXhwYW5kZWQgIT09IHVuZGVmaW5lZDtcblxuICAgIGNvbnN0IGhhbmRsZU9uQ2xpY2sgPSB1c2VDYWxsYmFjayhcbiAgICAgIChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGlmIChpc0NsaWNrYWJsZSAmJiBvbkNsaWNrKSB7XG4gICAgICAgICAgb25DbGljayhlKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIFtvbkNsaWNrLCBpc0NsaWNrYWJsZV1cbiAgICApO1xuXG4gICAgY29uc3QgYnV0dG9uUmVmID0gdXNlQnV0dG9uS2V5Ym9hcmQoe1xuICAgICAgcmVmLFxuICAgICAgaXNBY3RpdmU6IGlzQWN0aXZlICYmIChpc0NsaWNrYWJsZSB8fCAhIWNoZWNrYm94UHJvcHMpLFxuICAgICAgb25LZXlEb3duLFxuICAgIH0pO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRFbnRpdHlJdGVtTGlcbiAgICAgICAgcm9sZT1cInRyZWVpdGVtXCJcbiAgICAgICAgYXJpYS1leHBhbmRlZD17aGFzRXhwYW5kYWJsZUljb24gPyBpc0V4cGFuZGVkIDogdW5kZWZpbmVkfVxuICAgICAgICBhcmlhLWNoZWNrZWQ9e2NoZWNrYm94UHJvcHM/LmNoZWNrZWR9XG4gICAgICAgIGFyaWEtbGFiZWw9e2FyaWFMYWJlbH1cbiAgICAgICAgYXJpYS1sZXZlbD17YXJpYUxldmVsfVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkRW50aXR5VHJlZUl0ZW1Db250YWluZXJcbiAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICByb2xlPVwicHJlc2VudGF0aW9uXCJcbiAgICAgICAgICBpc0FjdGl2ZT17aXNBY3RpdmV9XG4gICAgICAgICAgcmVmPXtidXR0b25SZWZ9XG4gICAgICAgICAgaGFzRXhwYW5kYWJsZUljb249e2hhc0V4cGFuZGFibGVJY29ufVxuICAgICAgICAgIGxTcGFjZVN0ZXA9e2xTcGFjZVN0ZXB9XG4gICAgICAgICAgaXNEaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZU9uQ2xpY2t9XG4gICAgICAgICAgaXNDbGlja2FibGU9e2lzQ2xpY2thYmxlfVxuICAgICAgICA+XG4gICAgICAgICAge2hhc0V4cGFuZGFibGVJY29uICYmIChcbiAgICAgICAgICAgIDxFbnRpdHlUcmVlSXRlbUV4cGFuZEJ1dHRvblxuICAgICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWRFeHBhbmQgfHwgaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgaXNFeHBhbmRlZD17aXNFeHBhbmRlZH1cbiAgICAgICAgICAgICAgb25DbGljaz17b25FeHBhbmRDbGlja31cbiAgICAgICAgICAgICAgYXJpYUxhYmVsRXhwYW5kPXthcmlhTGFiZWxFeHBhbmR9XG4gICAgICAgICAgICAgIGFyaWFMYWJlbENvbGxhcHNlPXthcmlhTGFiZWxDb2xsYXBzZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8U3R5bGVkRW50aXR5VHJlZUl0ZW1XcmFwcGVyXG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgaGlkZUJvcmRlcj17aGlkZUJvcmRlciB8fCBzaXplID09PSBcInhzXCJ9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPEVudGl0eUl0ZW1Cb2R5XG4gICAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgICAgZGVzY3JpcHRpb249e2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgICByZW5kZXJMYWJlbD17cmVuZGVyTGFiZWx9XG4gICAgICAgICAgICAgIHJlbmRlckxlZnQ9e3JlbmRlckxlZnR9XG4gICAgICAgICAgICAgIHJlbmRlclJpZ2h0PXtyZW5kZXJSaWdodH1cbiAgICAgICAgICAgICAgY2hlY2tib3hQcm9wcz17Y2hlY2tib3hQcm9wc31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TdHlsZWRFbnRpdHlUcmVlSXRlbVdyYXBwZXI+XG4gICAgICAgIDwvU3R5bGVkRW50aXR5VHJlZUl0ZW1Db250YWluZXI+XG4gICAgICAgIHtpc0V4cGFuZGVkICYmIGNoaWxkcmVufVxuICAgICAgPC9TdHlsZWRFbnRpdHlJdGVtTGk+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQnNDIn0= */"),useButtonKeyboard=({ref:globalRef,isActive,onKeyDown})=>{let localRef=useRef(null);return useKeyboard({"Space Enter":onKeyDown},localRef,isActive,!0),useImperativeHandle(globalRef,()=>localRef.current),localRef};export const EntityTreeItem=/*#__PURE__*/React.forwardRef(({checkboxProps,children,description,hideBorder,isActive,isClickable,isDisabled,isDisabledExpand,isExpanded,lSpaceStep,onClick,onExpandClick,onFocus,onKeyDown,renderLabel,renderLeft,renderRight,size="m",tabIndex,ariaLabelExpand,ariaLabelCollapse,"aria-level":ariaLevel,"aria-label":ariaLabel},ref)=>{let hasExpandableIcon=void 0!==isExpanded,handleOnClick=useCallback(e=>{isClickable&&onClick&&onClick(e)},[onClick,isClickable]),buttonRef=useButtonKeyboard({ref,isActive:isActive&&(isClickable||!!checkboxProps),onKeyDown});return /*#__PURE__*/React.createElement(StyledEntityItemLi,{role:"treeitem","aria-expanded":hasExpandableIcon?isExpanded:void 0,"aria-checked":checkboxProps?.checked,"aria-label":ariaLabel,"aria-level":ariaLevel},/*#__PURE__*/React.createElement(StyledEntityTreeItemContainer,{size:size,tabIndex:tabIndex,role:"presentation",isActive:isActive,ref:buttonRef,hasExpandableIcon:hasExpandableIcon,lSpaceStep:lSpaceStep,isDisabled:isDisabled,onFocus:onFocus,onClick:handleOnClick,isClickable:isClickable},hasExpandableIcon&&/*#__PURE__*/React.createElement(EntityTreeItemExpandButton,{size:size,tabIndex:tabIndex,isDisabled:isDisabledExpand||isDisabled,isExpanded:isExpanded,onClick:onExpandClick,ariaLabelExpand:ariaLabelExpand,ariaLabelCollapse:ariaLabelCollapse}),/*#__PURE__*/React.createElement(StyledEntityTreeItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},/*#__PURE__*/React.createElement(EntityItemBody,{size:size,tabIndex:tabIndex,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight,checkboxProps:checkboxProps}))),isExpanded&&children)});
@@ -1,3 +1,3 @@
1
1
  import React from "react";
2
2
  import type { EntityListItemProps } from "../EntityList/types";
3
- export declare function EntityTreeItemExpandButton({ size, onClick, isExpanded, isDisabled, }: Partial<EntityListItemProps>): React.ReactElement;
3
+ export declare function EntityTreeItemExpandButton({ size, onClick, isExpanded, isDisabled, ariaLabelExpand, ariaLabelCollapse, }: Partial<EntityListItemProps>): React.ReactElement;
@@ -1 +1 @@
1
- import React from"react";import{PictogramButton}from"../PictogramButton/PictogramButton";import{Box}from"../Box/Box";import{StyledWrapperOffset}from"../EntityList/styled-components";export function EntityTreeItemExpandButton({size,onClick,isExpanded,isDisabled}){return /*#__PURE__*/React.createElement(Box,{vSpace:"zero",space:["xs","m"]},/*#__PURE__*/React.createElement(StyledWrapperOffset,{size:size},/*#__PURE__*/React.createElement(PictogramButton,{disabled:isDisabled,onClick:onClick,icon:isExpanded?"chevron-down":"chevron-right"})))}
1
+ import React from"react";import{PictogramButton}from"../PictogramButton/PictogramButton";import{Box}from"../Box/Box";import{StyledWrapperOffset}from"../EntityList/styled-components";export function EntityTreeItemExpandButton({size,onClick,isExpanded,isDisabled,ariaLabelExpand,ariaLabelCollapse}){return /*#__PURE__*/React.createElement(Box,{vSpace:"zero",space:["xs","m"]},/*#__PURE__*/React.createElement(StyledWrapperOffset,{size:size},/*#__PURE__*/React.createElement(PictogramButton,{disabled:isDisabled,onClick:onClick,icon:isExpanded?"chevron-down":"chevron-right","aria-label":isExpanded?ariaLabelExpand:ariaLabelCollapse,"aria-expanded":isExpanded})))}
@@ -1,6 +1,7 @@
1
1
  import React from "react";
2
2
  import type { FormFieldProps } from "../FormField/FormField";
3
3
  export type CheckboxProps = {
4
+ "aria-labelledby"?: string;
4
5
  name: string;
5
6
  value?: string;
6
7
  checked?: boolean | undefined;
@@ -16,6 +17,7 @@ export type CheckboxProps = {
16
17
  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;
17
18
  } & Omit<FormFieldProps, "labelHint">;
18
19
  export declare const CheckboxRaw: React.ForwardRefExoticComponent<{
20
+ "aria-labelledby"?: string;
19
21
  name: string;
20
22
  value?: string;
21
23
  checked?: boolean | undefined;
@@ -31,6 +33,7 @@ export declare const CheckboxRaw: React.ForwardRefExoticComponent<{
31
33
  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;
32
34
  } & Omit<FormFieldProps, "labelHint"> & React.RefAttributes<HTMLInputElement>>;
33
35
  export declare const Checkbox: React.ForwardRefExoticComponent<{
36
+ "aria-labelledby"?: string;
34
37
  name: string;
35
38
  value?: string;
36
39
  checked?: boolean | undefined;
@@ -1 +1 @@
1
- import React,{useRef,useLayoutEffect}from"react";import styled from"@emotion/styled";import{FormField}from"../FormField/FormField";import{Inline}from"../../Inline/Inline";import{Text}from"../../Typography/Text/Text";import{Icon}from"../../Icon/Icon";let StyledInputContainer=/*#__PURE__*/styled("div",{target:"e56y69u0",label:"StyledInputContainer"})(({theme,size})=>({userSelect:"none",display:"block",position:"relative",width:theme.variables.size.dimension.checkbox[size],height:theme.variables.size.dimension.checkbox[size],boxSizing:"border-box"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Checkbox/Checkbox.tsx","sources":["src/components/Form/Checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useRef, useLayoutEffect } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\n\nexport type CheckboxProps = {\n  name: string;\n  value?: string;\n  checked?: boolean | undefined;\n  label?: string | React.ComponentType;\n  labelHint?: string;\n  disabled?: boolean;\n  indeterminate?: boolean;\n  size?: \"s\" | \"m\";\n  tabIndex?: number;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & Omit<FormFieldProps, \"labelHint\">;\n\ntype CheckboxSizes = Pick<CheckboxProps, \"size\">;\n\nconst StyledInputContainer = styled.div<CheckboxSizes>(({ theme, size }) => ({\n  userSelect: \"none\",\n  display: \"block\",\n  position: \"relative\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  boxSizing: \"border-box\",\n}));\n\nconst StyledRealInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  cursor: \"pointer\",\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledFakeInput = styled.span<CheckboxSizes>(({ theme, size }) => ({\n  boxSizing: \"border-box\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  borderRadius: theme.variables.size.borderRadius.xs,\n  border: \"2px solid\",\n  position: \"absolute\",\n  top: size === \"s\" ? theme.variables.size.spacing.xxs : 0,\n  left: 0,\n  display: \"flex\",\n  alignItems: \"center\",\n  justifyContent: \"center\",\n  cursor: \"pointer\",\n\n  background: theme.values.color.background.primary.default,\n  color: theme.values.color.text.onAccent.default,\n  borderColor: theme.values.color.border.primary.default,\n  lineHeight: 0,\n  \"& svg\": {\n    opacity: theme.variables.opacity.hidden,\n  },\n\n  \"input: focus-visible + &\": {\n    outlineWidth: \"2px\",\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"input: focus-visible + &\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"auto\",\n    },\n  },\n\n  \"input:checked + &, input:indeterminate + &\": {\n    border: 0,\n    background: theme.values.color.background.accent.default,\n\n    svg: {\n      opacity: theme.variables.opacity.visible,\n    },\n  },\n\n  \"input:disabled + &\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    \"&:hover\": {\n      cursor: disabled ? \"not-allowed\" : \"pointer\",\n      ...(!disabled && {\n        [`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:\n          {\n            background: theme.values.color.background.accent.hover,\n          },\n      }),\n    },\n    ...(!disabled && {\n      [`&:hover ${StyledFakeInput}`]: {\n        borderColor: theme.values.color.border.primary.hover,\n      },\n    }),\n  })\n);\n\nexport const CheckboxRaw = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      label = \"\",\n      labelHint = \"\",\n      disabled = false,\n      indeterminate,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      tabIndex,\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const internalRef = useRef<HTMLInputElement | null>(null);\n    const inputRef = internalRef || ref;\n\n    useLayoutEffect(() => {\n      if (inputRef.current) {\n        internalRef.current.indeterminate = indeterminate;\n      }\n    }, [indeterminate, inputRef]);\n\n    return (\n      <StyledContainer disabled={disabled}>\n        <Inline space=\"xs\" vAlignItems=\"top\" noWrap>\n          <StyledInputContainer size={size}>\n            <StyledRealInput\n              ref={inputRef}\n              aria-checked={indeterminate ? \"mixed\" : checked}\n              type=\"checkbox\"\n              name={name}\n              value={value}\n              checked={checked}\n              disabled={disabled}\n              onChange={onChange}\n              onClick={onClick}\n              onBlur={onBlur}\n              onFocus={onFocus}\n              tabIndex={tabIndex}\n            />\n\n            <StyledFakeInput size={size}>\n              {indeterminate ? (\n                <Icon size=\"s\" name=\"minus\" />\n              ) : (\n                <Icon size=\"s\" name={size === \"m\" ? \"check\" : \"check-small\"} />\n              )}\n            </StyledFakeInput>\n          </StyledInputContainer>\n          {label && (\n            <div>\n              {typeof label === \"string\" ? <Text>{label}</Text> : label}\n              {labelHint && (\n                <Text color=\"tertiary\" size=\"s\">\n                  {labelHint}\n                </Text>\n              )}\n            </div>\n          )}\n        </Inline>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const Checkbox = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      indeterminate,\n      label,\n      labelHint,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      disabled,\n      tabIndex,\n      ...rest\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"Checkbox\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <CheckboxRaw\n        ref={ref}\n        name={name}\n        value={value}\n        checked={checked}\n        indeterminate={indeterminate}\n        size={size}\n        onChange={onChange}\n        onBlur={onBlur}\n        onClick={onClick}\n        onFocus={onFocus}\n        label={label}\n        labelHint={labelHint}\n        disabled={disabled}\n        tabIndex={tabIndex}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA4B6B"} */"),StyledRealInput=/*#__PURE__*/styled("input",{target:"e56y69u1",label:"StyledRealInput"})(({theme})=>({opacity:theme.variables.opacity.hidden,cursor:"pointer",height:0,width:0,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Checkbox/Checkbox.tsx","sources":["src/components/Form/Checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useRef, useLayoutEffect } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\n\nexport type CheckboxProps = {\n  name: string;\n  value?: string;\n  checked?: boolean | undefined;\n  label?: string | React.ComponentType;\n  labelHint?: string;\n  disabled?: boolean;\n  indeterminate?: boolean;\n  size?: \"s\" | \"m\";\n  tabIndex?: number;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & Omit<FormFieldProps, \"labelHint\">;\n\ntype CheckboxSizes = Pick<CheckboxProps, \"size\">;\n\nconst StyledInputContainer = styled.div<CheckboxSizes>(({ theme, size }) => ({\n  userSelect: \"none\",\n  display: \"block\",\n  position: \"relative\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  boxSizing: \"border-box\",\n}));\n\nconst StyledRealInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  cursor: \"pointer\",\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledFakeInput = styled.span<CheckboxSizes>(({ theme, size }) => ({\n  boxSizing: \"border-box\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  borderRadius: theme.variables.size.borderRadius.xs,\n  border: \"2px solid\",\n  position: \"absolute\",\n  top: size === \"s\" ? theme.variables.size.spacing.xxs : 0,\n  left: 0,\n  display: \"flex\",\n  alignItems: \"center\",\n  justifyContent: \"center\",\n  cursor: \"pointer\",\n\n  background: theme.values.color.background.primary.default,\n  color: theme.values.color.text.onAccent.default,\n  borderColor: theme.values.color.border.primary.default,\n  lineHeight: 0,\n  \"& svg\": {\n    opacity: theme.variables.opacity.hidden,\n  },\n\n  \"input: focus-visible + &\": {\n    outlineWidth: \"2px\",\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"input: focus-visible + &\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"auto\",\n    },\n  },\n\n  \"input:checked + &, input:indeterminate + &\": {\n    border: 0,\n    background: theme.values.color.background.accent.default,\n\n    svg: {\n      opacity: theme.variables.opacity.visible,\n    },\n  },\n\n  \"input:disabled + &\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    \"&:hover\": {\n      cursor: disabled ? \"not-allowed\" : \"pointer\",\n      ...(!disabled && {\n        [`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:\n          {\n            background: theme.values.color.background.accent.hover,\n          },\n      }),\n    },\n    ...(!disabled && {\n      [`&:hover ${StyledFakeInput}`]: {\n        borderColor: theme.values.color.border.primary.hover,\n      },\n    }),\n  })\n);\n\nexport const CheckboxRaw = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      label = \"\",\n      labelHint = \"\",\n      disabled = false,\n      indeterminate,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      tabIndex,\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const internalRef = useRef<HTMLInputElement | null>(null);\n    const inputRef = internalRef || ref;\n\n    useLayoutEffect(() => {\n      if (inputRef.current) {\n        internalRef.current.indeterminate = indeterminate;\n      }\n    }, [indeterminate, inputRef]);\n\n    return (\n      <StyledContainer disabled={disabled}>\n        <Inline space=\"xs\" vAlignItems=\"top\" noWrap>\n          <StyledInputContainer size={size}>\n            <StyledRealInput\n              ref={inputRef}\n              aria-checked={indeterminate ? \"mixed\" : checked}\n              type=\"checkbox\"\n              name={name}\n              value={value}\n              checked={checked}\n              disabled={disabled}\n              onChange={onChange}\n              onClick={onClick}\n              onBlur={onBlur}\n              onFocus={onFocus}\n              tabIndex={tabIndex}\n            />\n\n            <StyledFakeInput size={size}>\n              {indeterminate ? (\n                <Icon size=\"s\" name=\"minus\" />\n              ) : (\n                <Icon size=\"s\" name={size === \"m\" ? \"check\" : \"check-small\"} />\n              )}\n            </StyledFakeInput>\n          </StyledInputContainer>\n          {label && (\n            <div>\n              {typeof label === \"string\" ? <Text>{label}</Text> : label}\n              {labelHint && (\n                <Text color=\"tertiary\" size=\"s\">\n                  {labelHint}\n                </Text>\n              )}\n            </div>\n          )}\n        </Inline>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const Checkbox = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      indeterminate,\n      label,\n      labelHint,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      disabled,\n      tabIndex,\n      ...rest\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"Checkbox\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <CheckboxRaw\n        ref={ref}\n        name={name}\n        value={value}\n        checked={checked}\n        indeterminate={indeterminate}\n        size={size}\n        onChange={onChange}\n        onBlur={onBlur}\n        onClick={onClick}\n        onFocus={onFocus}\n        label={label}\n        labelHint={labelHint}\n        disabled={disabled}\n        tabIndex={tabIndex}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAqCwB"} */"),StyledFakeInput=/*#__PURE__*/styled("span",{target:"e56y69u2",label:"StyledFakeInput"})(({theme,size})=>({boxSizing:"border-box",width:theme.variables.size.dimension.checkbox[size],height:theme.variables.size.dimension.checkbox[size],borderRadius:theme.variables.size.borderRadius.xs,border:"2px solid",position:"absolute",top:"s"===size?theme.variables.size.spacing.xxs:0,left:0,display:"flex",alignItems:"center",justifyContent:"center",cursor:"pointer",background:theme.values.color.background.primary.default,color:theme.values.color.text.onAccent.default,borderColor:theme.values.color.border.primary.default,lineHeight:0,"& svg":{opacity:theme.variables.opacity.hidden},"input: focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}},"input:checked + &, input:indeterminate + &":{border:0,background:theme.values.color.background.accent.default,svg:{opacity:theme.variables.opacity.visible}},"input:disabled + &":{pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Checkbox/Checkbox.tsx","sources":["src/components/Form/Checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useRef, useLayoutEffect } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\n\nexport type CheckboxProps = {\n  name: string;\n  value?: string;\n  checked?: boolean | undefined;\n  label?: string | React.ComponentType;\n  labelHint?: string;\n  disabled?: boolean;\n  indeterminate?: boolean;\n  size?: \"s\" | \"m\";\n  tabIndex?: number;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & Omit<FormFieldProps, \"labelHint\">;\n\ntype CheckboxSizes = Pick<CheckboxProps, \"size\">;\n\nconst StyledInputContainer = styled.div<CheckboxSizes>(({ theme, size }) => ({\n  userSelect: \"none\",\n  display: \"block\",\n  position: \"relative\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  boxSizing: \"border-box\",\n}));\n\nconst StyledRealInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  cursor: \"pointer\",\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledFakeInput = styled.span<CheckboxSizes>(({ theme, size }) => ({\n  boxSizing: \"border-box\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  borderRadius: theme.variables.size.borderRadius.xs,\n  border: \"2px solid\",\n  position: \"absolute\",\n  top: size === \"s\" ? theme.variables.size.spacing.xxs : 0,\n  left: 0,\n  display: \"flex\",\n  alignItems: \"center\",\n  justifyContent: \"center\",\n  cursor: \"pointer\",\n\n  background: theme.values.color.background.primary.default,\n  color: theme.values.color.text.onAccent.default,\n  borderColor: theme.values.color.border.primary.default,\n  lineHeight: 0,\n  \"& svg\": {\n    opacity: theme.variables.opacity.hidden,\n  },\n\n  \"input: focus-visible + &\": {\n    outlineWidth: \"2px\",\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"input: focus-visible + &\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"auto\",\n    },\n  },\n\n  \"input:checked + &, input:indeterminate + &\": {\n    border: 0,\n    background: theme.values.color.background.accent.default,\n\n    svg: {\n      opacity: theme.variables.opacity.visible,\n    },\n  },\n\n  \"input:disabled + &\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    \"&:hover\": {\n      cursor: disabled ? \"not-allowed\" : \"pointer\",\n      ...(!disabled && {\n        [`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:\n          {\n            background: theme.values.color.background.accent.hover,\n          },\n      }),\n    },\n    ...(!disabled && {\n      [`&:hover ${StyledFakeInput}`]: {\n        borderColor: theme.values.color.border.primary.hover,\n      },\n    }),\n  })\n);\n\nexport const CheckboxRaw = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      label = \"\",\n      labelHint = \"\",\n      disabled = false,\n      indeterminate,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      tabIndex,\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const internalRef = useRef<HTMLInputElement | null>(null);\n    const inputRef = internalRef || ref;\n\n    useLayoutEffect(() => {\n      if (inputRef.current) {\n        internalRef.current.indeterminate = indeterminate;\n      }\n    }, [indeterminate, inputRef]);\n\n    return (\n      <StyledContainer disabled={disabled}>\n        <Inline space=\"xs\" vAlignItems=\"top\" noWrap>\n          <StyledInputContainer size={size}>\n            <StyledRealInput\n              ref={inputRef}\n              aria-checked={indeterminate ? \"mixed\" : checked}\n              type=\"checkbox\"\n              name={name}\n              value={value}\n              checked={checked}\n              disabled={disabled}\n              onChange={onChange}\n              onClick={onClick}\n              onBlur={onBlur}\n              onFocus={onFocus}\n              tabIndex={tabIndex}\n            />\n\n            <StyledFakeInput size={size}>\n              {indeterminate ? (\n                <Icon size=\"s\" name=\"minus\" />\n              ) : (\n                <Icon size=\"s\" name={size === \"m\" ? \"check\" : \"check-small\"} />\n              )}\n            </StyledFakeInput>\n          </StyledInputContainer>\n          {label && (\n            <div>\n              {typeof label === \"string\" ? <Text>{label}</Text> : label}\n              {labelHint && (\n                <Text color=\"tertiary\" size=\"s\">\n                  {labelHint}\n                </Text>\n              )}\n            </div>\n          )}\n        </Inline>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const Checkbox = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      indeterminate,\n      label,\n      labelHint,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      disabled,\n      tabIndex,\n      ...rest\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"Checkbox\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <CheckboxRaw\n        ref={ref}\n        name={name}\n        value={value}\n        checked={checked}\n        indeterminate={indeterminate}\n        size={size}\n        onChange={onChange}\n        onBlur={onBlur}\n        onClick={onClick}\n        onFocus={onFocus}\n        label={label}\n        labelHint={labelHint}\n        disabled={disabled}\n        tabIndex={tabIndex}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA6CwB"} */"),StyledContainer=/*#__PURE__*/styled("div",{target:"e56y69u3",label:"StyledContainer"})(({theme,disabled})=>({"&:hover":{cursor:disabled?"not-allowed":"pointer",...!disabled&&{[`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:{background:theme.values.color.background.accent.hover}}},...!disabled&&{[`&:hover ${StyledFakeInput}`]:{borderColor:theme.values.color.border.primary.hover}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Checkbox/Checkbox.tsx","sources":["src/components/Form/Checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useRef, useLayoutEffect } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\n\nexport type CheckboxProps = {\n  name: string;\n  value?: string;\n  checked?: boolean | undefined;\n  label?: string | React.ComponentType;\n  labelHint?: string;\n  disabled?: boolean;\n  indeterminate?: boolean;\n  size?: \"s\" | \"m\";\n  tabIndex?: number;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & Omit<FormFieldProps, \"labelHint\">;\n\ntype CheckboxSizes = Pick<CheckboxProps, \"size\">;\n\nconst StyledInputContainer = styled.div<CheckboxSizes>(({ theme, size }) => ({\n  userSelect: \"none\",\n  display: \"block\",\n  position: \"relative\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  boxSizing: \"border-box\",\n}));\n\nconst StyledRealInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  cursor: \"pointer\",\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledFakeInput = styled.span<CheckboxSizes>(({ theme, size }) => ({\n  boxSizing: \"border-box\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  borderRadius: theme.variables.size.borderRadius.xs,\n  border: \"2px solid\",\n  position: \"absolute\",\n  top: size === \"s\" ? theme.variables.size.spacing.xxs : 0,\n  left: 0,\n  display: \"flex\",\n  alignItems: \"center\",\n  justifyContent: \"center\",\n  cursor: \"pointer\",\n\n  background: theme.values.color.background.primary.default,\n  color: theme.values.color.text.onAccent.default,\n  borderColor: theme.values.color.border.primary.default,\n  lineHeight: 0,\n  \"& svg\": {\n    opacity: theme.variables.opacity.hidden,\n  },\n\n  \"input: focus-visible + &\": {\n    outlineWidth: \"2px\",\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"input: focus-visible + &\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"auto\",\n    },\n  },\n\n  \"input:checked + &, input:indeterminate + &\": {\n    border: 0,\n    background: theme.values.color.background.accent.default,\n\n    svg: {\n      opacity: theme.variables.opacity.visible,\n    },\n  },\n\n  \"input:disabled + &\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    \"&:hover\": {\n      cursor: disabled ? \"not-allowed\" : \"pointer\",\n      ...(!disabled && {\n        [`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:\n          {\n            background: theme.values.color.background.accent.hover,\n          },\n      }),\n    },\n    ...(!disabled && {\n      [`&:hover ${StyledFakeInput}`]: {\n        borderColor: theme.values.color.border.primary.hover,\n      },\n    }),\n  })\n);\n\nexport const CheckboxRaw = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      label = \"\",\n      labelHint = \"\",\n      disabled = false,\n      indeterminate,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      tabIndex,\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const internalRef = useRef<HTMLInputElement | null>(null);\n    const inputRef = internalRef || ref;\n\n    useLayoutEffect(() => {\n      if (inputRef.current) {\n        internalRef.current.indeterminate = indeterminate;\n      }\n    }, [indeterminate, inputRef]);\n\n    return (\n      <StyledContainer disabled={disabled}>\n        <Inline space=\"xs\" vAlignItems=\"top\" noWrap>\n          <StyledInputContainer size={size}>\n            <StyledRealInput\n              ref={inputRef}\n              aria-checked={indeterminate ? \"mixed\" : checked}\n              type=\"checkbox\"\n              name={name}\n              value={value}\n              checked={checked}\n              disabled={disabled}\n              onChange={onChange}\n              onClick={onClick}\n              onBlur={onBlur}\n              onFocus={onFocus}\n              tabIndex={tabIndex}\n            />\n\n            <StyledFakeInput size={size}>\n              {indeterminate ? (\n                <Icon size=\"s\" name=\"minus\" />\n              ) : (\n                <Icon size=\"s\" name={size === \"m\" ? \"check\" : \"check-small\"} />\n              )}\n            </StyledFakeInput>\n          </StyledInputContainer>\n          {label && (\n            <div>\n              {typeof label === \"string\" ? <Text>{label}</Text> : label}\n              {labelHint && (\n                <Text color=\"tertiary\" size=\"s\">\n                  {labelHint}\n                </Text>\n              )}\n            </div>\n          )}\n        </Inline>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const Checkbox = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      indeterminate,\n      label,\n      labelHint,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      disabled,\n      tabIndex,\n      ...rest\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"Checkbox\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <CheckboxRaw\n        ref={ref}\n        name={name}\n        value={value}\n        checked={checked}\n        indeterminate={indeterminate}\n        size={size}\n        onChange={onChange}\n        onBlur={onBlur}\n        onClick={onClick}\n        onFocus={onFocus}\n        label={label}\n        labelHint={labelHint}\n        disabled={disabled}\n        tabIndex={tabIndex}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA8FwB"} */");export const CheckboxRaw=/*#__PURE__*/React.forwardRef(({name,value="",checked,label="",labelHint="",disabled=!1,indeterminate,size="m",onChange,onClick,onBlur,onFocus,tabIndex},ref)=>{let internalRef=useRef(null),inputRef=internalRef||ref;return useLayoutEffect(()=>{inputRef.current&&(internalRef.current.indeterminate=indeterminate)},[indeterminate,inputRef]),/*#__PURE__*/React.createElement(StyledContainer,{disabled:disabled},/*#__PURE__*/React.createElement(Inline,{space:"xs",vAlignItems:"top",noWrap:!0},/*#__PURE__*/React.createElement(StyledInputContainer,{size:size},/*#__PURE__*/React.createElement(StyledRealInput,{ref:inputRef,"aria-checked":indeterminate?"mixed":checked,type:"checkbox",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus,tabIndex:tabIndex}),/*#__PURE__*/React.createElement(StyledFakeInput,{size:size},indeterminate?/*#__PURE__*/React.createElement(Icon,{size:"s",name:"minus"}):/*#__PURE__*/React.createElement(Icon,{size:"s",name:"m"===size?"check":"check-small"}))),label&&/*#__PURE__*/React.createElement("div",null,"string"==typeof label?/*#__PURE__*/React.createElement(Text,null,label):label,labelHint&&/*#__PURE__*/React.createElement(Text,{color:"tertiary",size:"s"},labelHint))))});export const Checkbox=/*#__PURE__*/React.forwardRef(({name,value="",checked,indeterminate,label,labelHint,size="m",onChange,onClick,onBlur,onFocus,disabled,tabIndex,...rest},ref)=>/*#__PURE__*/React.createElement(FormField,{"data-ds-id":"Checkbox",disabled:disabled,...rest},/*#__PURE__*/React.createElement(CheckboxRaw,{ref:ref,name:name,value:value,checked:checked,indeterminate:indeterminate,size:size,onChange:onChange,onBlur:onBlur,onClick:onClick,onFocus:onFocus,label:label,labelHint:labelHint,disabled:disabled,tabIndex:tabIndex})));
1
+ import React,{useRef,useLayoutEffect}from"react";import styled from"@emotion/styled";import{FormField}from"../FormField/FormField";import{Inline}from"../../Inline/Inline";import{Text}from"../../Typography/Text/Text";import{Icon}from"../../Icon/Icon";let StyledInputContainer=/*#__PURE__*/styled("div",{target:"ec54j8h0",label:"StyledInputContainer"})(({theme,size})=>({userSelect:"none",display:"block",position:"relative",width:theme.variables.size.dimension.checkbox[size],height:theme.variables.size.dimension.checkbox[size],boxSizing:"border-box"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Checkbox/Checkbox.tsx","sources":["src/components/Form/Checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useRef, useLayoutEffect } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\n\nexport type CheckboxProps = {\n  \"aria-labelledby\"?: string;\n  name: string;\n  value?: string;\n  checked?: boolean | undefined;\n  label?: string | React.ComponentType;\n  labelHint?: string;\n  disabled?: boolean;\n  indeterminate?: boolean;\n  size?: \"s\" | \"m\";\n  tabIndex?: number;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & Omit<FormFieldProps, \"labelHint\">;\n\ntype CheckboxSizes = Pick<CheckboxProps, \"size\">;\n\nconst StyledInputContainer = styled.div<CheckboxSizes>(({ theme, size }) => ({\n  userSelect: \"none\",\n  display: \"block\",\n  position: \"relative\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  boxSizing: \"border-box\",\n}));\n\nconst StyledRealInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  cursor: \"pointer\",\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledFakeInput = styled.span<CheckboxSizes>(({ theme, size }) => ({\n  boxSizing: \"border-box\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  borderRadius: theme.variables.size.borderRadius.xs,\n  border: \"2px solid\",\n  position: \"absolute\",\n  top: size === \"s\" ? theme.variables.size.spacing.xxs : 0,\n  left: 0,\n  display: \"flex\",\n  alignItems: \"center\",\n  justifyContent: \"center\",\n  cursor: \"pointer\",\n\n  background: theme.values.color.background.primary.default,\n  color: theme.values.color.text.onAccent.default,\n  borderColor: theme.values.color.border.primary.default,\n  lineHeight: 0,\n  \"& svg\": {\n    opacity: theme.variables.opacity.hidden,\n  },\n\n  \"input: focus-visible + &\": {\n    outlineWidth: \"2px\",\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"input: focus-visible + &\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"auto\",\n    },\n  },\n\n  \"input:checked + &, input:indeterminate + &\": {\n    border: 0,\n    background: theme.values.color.background.accent.default,\n\n    svg: {\n      opacity: theme.variables.opacity.visible,\n    },\n  },\n\n  \"input:disabled + &\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    \"&:hover\": {\n      cursor: disabled ? \"not-allowed\" : \"pointer\",\n      ...(!disabled && {\n        [`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:\n          {\n            background: theme.values.color.background.accent.hover,\n          },\n      }),\n    },\n    ...(!disabled && {\n      [`&:hover ${StyledFakeInput}`]: {\n        borderColor: theme.values.color.border.primary.hover,\n      },\n    }),\n  })\n);\n\nexport const CheckboxRaw = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      label = \"\",\n      labelHint = \"\",\n      disabled = false,\n      indeterminate,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      tabIndex,\n      \"aria-labelledby\": ariaLabelledby,\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const internalRef = useRef<HTMLInputElement | null>(null);\n    const inputRef = internalRef || ref;\n\n    useLayoutEffect(() => {\n      if (inputRef.current) {\n        internalRef.current.indeterminate = indeterminate;\n      }\n    }, [indeterminate, inputRef]);\n\n    return (\n      <StyledContainer disabled={disabled}>\n        <Inline space=\"xs\" vAlignItems=\"top\" noWrap>\n          <StyledInputContainer size={size}>\n            <StyledRealInput\n              ref={inputRef}\n              aria-checked={indeterminate ? \"mixed\" : checked}\n              aria-labelledby={ariaLabelledby}\n              type=\"checkbox\"\n              name={name}\n              value={value}\n              checked={checked}\n              disabled={disabled}\n              onChange={onChange}\n              onClick={onClick}\n              onBlur={onBlur}\n              onFocus={onFocus}\n              tabIndex={tabIndex}\n            />\n\n            <StyledFakeInput size={size}>\n              {indeterminate ? (\n                <Icon size=\"s\" name=\"minus\" />\n              ) : (\n                <Icon size=\"s\" name={size === \"m\" ? \"check\" : \"check-small\"} />\n              )}\n            </StyledFakeInput>\n          </StyledInputContainer>\n          {label && (\n            <div>\n              {typeof label === \"string\" ? <Text>{label}</Text> : label}\n              {labelHint && (\n                <Text color=\"tertiary\" size=\"s\">\n                  {labelHint}\n                </Text>\n              )}\n            </div>\n          )}\n        </Inline>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const Checkbox = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      indeterminate,\n      label,\n      labelHint,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      disabled,\n      tabIndex,\n      \"aria-labelledby\": ariaLabelledby,\n      ...rest\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"Checkbox\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <CheckboxRaw\n        ref={ref}\n        name={name}\n        value={value}\n        checked={checked}\n        indeterminate={indeterminate}\n        size={size}\n        onChange={onChange}\n        onBlur={onBlur}\n        onClick={onClick}\n        onFocus={onFocus}\n        label={label}\n        labelHint={labelHint}\n        disabled={disabled}\n        tabIndex={tabIndex}\n        aria-labelledby={ariaLabelledby}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA6B6B"} */"),StyledRealInput=/*#__PURE__*/styled("input",{target:"ec54j8h1",label:"StyledRealInput"})(({theme})=>({opacity:theme.variables.opacity.hidden,cursor:"pointer",height:0,width:0,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Checkbox/Checkbox.tsx","sources":["src/components/Form/Checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useRef, useLayoutEffect } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\n\nexport type CheckboxProps = {\n  \"aria-labelledby\"?: string;\n  name: string;\n  value?: string;\n  checked?: boolean | undefined;\n  label?: string | React.ComponentType;\n  labelHint?: string;\n  disabled?: boolean;\n  indeterminate?: boolean;\n  size?: \"s\" | \"m\";\n  tabIndex?: number;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & Omit<FormFieldProps, \"labelHint\">;\n\ntype CheckboxSizes = Pick<CheckboxProps, \"size\">;\n\nconst StyledInputContainer = styled.div<CheckboxSizes>(({ theme, size }) => ({\n  userSelect: \"none\",\n  display: \"block\",\n  position: \"relative\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  boxSizing: \"border-box\",\n}));\n\nconst StyledRealInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  cursor: \"pointer\",\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledFakeInput = styled.span<CheckboxSizes>(({ theme, size }) => ({\n  boxSizing: \"border-box\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  borderRadius: theme.variables.size.borderRadius.xs,\n  border: \"2px solid\",\n  position: \"absolute\",\n  top: size === \"s\" ? theme.variables.size.spacing.xxs : 0,\n  left: 0,\n  display: \"flex\",\n  alignItems: \"center\",\n  justifyContent: \"center\",\n  cursor: \"pointer\",\n\n  background: theme.values.color.background.primary.default,\n  color: theme.values.color.text.onAccent.default,\n  borderColor: theme.values.color.border.primary.default,\n  lineHeight: 0,\n  \"& svg\": {\n    opacity: theme.variables.opacity.hidden,\n  },\n\n  \"input: focus-visible + &\": {\n    outlineWidth: \"2px\",\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"input: focus-visible + &\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"auto\",\n    },\n  },\n\n  \"input:checked + &, input:indeterminate + &\": {\n    border: 0,\n    background: theme.values.color.background.accent.default,\n\n    svg: {\n      opacity: theme.variables.opacity.visible,\n    },\n  },\n\n  \"input:disabled + &\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    \"&:hover\": {\n      cursor: disabled ? \"not-allowed\" : \"pointer\",\n      ...(!disabled && {\n        [`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:\n          {\n            background: theme.values.color.background.accent.hover,\n          },\n      }),\n    },\n    ...(!disabled && {\n      [`&:hover ${StyledFakeInput}`]: {\n        borderColor: theme.values.color.border.primary.hover,\n      },\n    }),\n  })\n);\n\nexport const CheckboxRaw = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      label = \"\",\n      labelHint = \"\",\n      disabled = false,\n      indeterminate,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      tabIndex,\n      \"aria-labelledby\": ariaLabelledby,\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const internalRef = useRef<HTMLInputElement | null>(null);\n    const inputRef = internalRef || ref;\n\n    useLayoutEffect(() => {\n      if (inputRef.current) {\n        internalRef.current.indeterminate = indeterminate;\n      }\n    }, [indeterminate, inputRef]);\n\n    return (\n      <StyledContainer disabled={disabled}>\n        <Inline space=\"xs\" vAlignItems=\"top\" noWrap>\n          <StyledInputContainer size={size}>\n            <StyledRealInput\n              ref={inputRef}\n              aria-checked={indeterminate ? \"mixed\" : checked}\n              aria-labelledby={ariaLabelledby}\n              type=\"checkbox\"\n              name={name}\n              value={value}\n              checked={checked}\n              disabled={disabled}\n              onChange={onChange}\n              onClick={onClick}\n              onBlur={onBlur}\n              onFocus={onFocus}\n              tabIndex={tabIndex}\n            />\n\n            <StyledFakeInput size={size}>\n              {indeterminate ? (\n                <Icon size=\"s\" name=\"minus\" />\n              ) : (\n                <Icon size=\"s\" name={size === \"m\" ? \"check\" : \"check-small\"} />\n              )}\n            </StyledFakeInput>\n          </StyledInputContainer>\n          {label && (\n            <div>\n              {typeof label === \"string\" ? <Text>{label}</Text> : label}\n              {labelHint && (\n                <Text color=\"tertiary\" size=\"s\">\n                  {labelHint}\n                </Text>\n              )}\n            </div>\n          )}\n        </Inline>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const Checkbox = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      indeterminate,\n      label,\n      labelHint,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      disabled,\n      tabIndex,\n      \"aria-labelledby\": ariaLabelledby,\n      ...rest\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"Checkbox\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <CheckboxRaw\n        ref={ref}\n        name={name}\n        value={value}\n        checked={checked}\n        indeterminate={indeterminate}\n        size={size}\n        onChange={onChange}\n        onBlur={onBlur}\n        onClick={onClick}\n        onFocus={onFocus}\n        label={label}\n        labelHint={labelHint}\n        disabled={disabled}\n        tabIndex={tabIndex}\n        aria-labelledby={ariaLabelledby}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAsCwB"} */"),StyledFakeInput=/*#__PURE__*/styled("span",{target:"ec54j8h2",label:"StyledFakeInput"})(({theme,size})=>({boxSizing:"border-box",width:theme.variables.size.dimension.checkbox[size],height:theme.variables.size.dimension.checkbox[size],borderRadius:theme.variables.size.borderRadius.xs,border:"2px solid",position:"absolute",top:"s"===size?theme.variables.size.spacing.xxs:0,left:0,display:"flex",alignItems:"center",justifyContent:"center",cursor:"pointer",background:theme.values.color.background.primary.default,color:theme.values.color.text.onAccent.default,borderColor:theme.values.color.border.primary.default,lineHeight:0,"& svg":{opacity:theme.variables.opacity.hidden},"input: focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}},"input:checked + &, input:indeterminate + &":{border:0,background:theme.values.color.background.accent.default,svg:{opacity:theme.variables.opacity.visible}},"input:disabled + &":{pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Checkbox/Checkbox.tsx","sources":["src/components/Form/Checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useRef, useLayoutEffect } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\n\nexport type CheckboxProps = {\n  \"aria-labelledby\"?: string;\n  name: string;\n  value?: string;\n  checked?: boolean | undefined;\n  label?: string | React.ComponentType;\n  labelHint?: string;\n  disabled?: boolean;\n  indeterminate?: boolean;\n  size?: \"s\" | \"m\";\n  tabIndex?: number;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & Omit<FormFieldProps, \"labelHint\">;\n\ntype CheckboxSizes = Pick<CheckboxProps, \"size\">;\n\nconst StyledInputContainer = styled.div<CheckboxSizes>(({ theme, size }) => ({\n  userSelect: \"none\",\n  display: \"block\",\n  position: \"relative\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  boxSizing: \"border-box\",\n}));\n\nconst StyledRealInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  cursor: \"pointer\",\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledFakeInput = styled.span<CheckboxSizes>(({ theme, size }) => ({\n  boxSizing: \"border-box\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  borderRadius: theme.variables.size.borderRadius.xs,\n  border: \"2px solid\",\n  position: \"absolute\",\n  top: size === \"s\" ? theme.variables.size.spacing.xxs : 0,\n  left: 0,\n  display: \"flex\",\n  alignItems: \"center\",\n  justifyContent: \"center\",\n  cursor: \"pointer\",\n\n  background: theme.values.color.background.primary.default,\n  color: theme.values.color.text.onAccent.default,\n  borderColor: theme.values.color.border.primary.default,\n  lineHeight: 0,\n  \"& svg\": {\n    opacity: theme.variables.opacity.hidden,\n  },\n\n  \"input: focus-visible + &\": {\n    outlineWidth: \"2px\",\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"input: focus-visible + &\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"auto\",\n    },\n  },\n\n  \"input:checked + &, input:indeterminate + &\": {\n    border: 0,\n    background: theme.values.color.background.accent.default,\n\n    svg: {\n      opacity: theme.variables.opacity.visible,\n    },\n  },\n\n  \"input:disabled + &\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    \"&:hover\": {\n      cursor: disabled ? \"not-allowed\" : \"pointer\",\n      ...(!disabled && {\n        [`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:\n          {\n            background: theme.values.color.background.accent.hover,\n          },\n      }),\n    },\n    ...(!disabled && {\n      [`&:hover ${StyledFakeInput}`]: {\n        borderColor: theme.values.color.border.primary.hover,\n      },\n    }),\n  })\n);\n\nexport const CheckboxRaw = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      label = \"\",\n      labelHint = \"\",\n      disabled = false,\n      indeterminate,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      tabIndex,\n      \"aria-labelledby\": ariaLabelledby,\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const internalRef = useRef<HTMLInputElement | null>(null);\n    const inputRef = internalRef || ref;\n\n    useLayoutEffect(() => {\n      if (inputRef.current) {\n        internalRef.current.indeterminate = indeterminate;\n      }\n    }, [indeterminate, inputRef]);\n\n    return (\n      <StyledContainer disabled={disabled}>\n        <Inline space=\"xs\" vAlignItems=\"top\" noWrap>\n          <StyledInputContainer size={size}>\n            <StyledRealInput\n              ref={inputRef}\n              aria-checked={indeterminate ? \"mixed\" : checked}\n              aria-labelledby={ariaLabelledby}\n              type=\"checkbox\"\n              name={name}\n              value={value}\n              checked={checked}\n              disabled={disabled}\n              onChange={onChange}\n              onClick={onClick}\n              onBlur={onBlur}\n              onFocus={onFocus}\n              tabIndex={tabIndex}\n            />\n\n            <StyledFakeInput size={size}>\n              {indeterminate ? (\n                <Icon size=\"s\" name=\"minus\" />\n              ) : (\n                <Icon size=\"s\" name={size === \"m\" ? \"check\" : \"check-small\"} />\n              )}\n            </StyledFakeInput>\n          </StyledInputContainer>\n          {label && (\n            <div>\n              {typeof label === \"string\" ? <Text>{label}</Text> : label}\n              {labelHint && (\n                <Text color=\"tertiary\" size=\"s\">\n                  {labelHint}\n                </Text>\n              )}\n            </div>\n          )}\n        </Inline>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const Checkbox = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      indeterminate,\n      label,\n      labelHint,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      disabled,\n      tabIndex,\n      \"aria-labelledby\": ariaLabelledby,\n      ...rest\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"Checkbox\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <CheckboxRaw\n        ref={ref}\n        name={name}\n        value={value}\n        checked={checked}\n        indeterminate={indeterminate}\n        size={size}\n        onChange={onChange}\n        onBlur={onBlur}\n        onClick={onClick}\n        onFocus={onFocus}\n        label={label}\n        labelHint={labelHint}\n        disabled={disabled}\n        tabIndex={tabIndex}\n        aria-labelledby={ariaLabelledby}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA8CwB"} */"),StyledContainer=/*#__PURE__*/styled("div",{target:"ec54j8h3",label:"StyledContainer"})(({theme,disabled})=>({"&:hover":{cursor:disabled?"not-allowed":"pointer",...!disabled&&{[`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:{background:theme.values.color.background.accent.hover}}},...!disabled&&{[`&:hover ${StyledFakeInput}`]:{borderColor:theme.values.color.border.primary.hover}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Checkbox/Checkbox.tsx","sources":["src/components/Form/Checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useRef, useLayoutEffect } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\n\nexport type CheckboxProps = {\n  \"aria-labelledby\"?: string;\n  name: string;\n  value?: string;\n  checked?: boolean | undefined;\n  label?: string | React.ComponentType;\n  labelHint?: string;\n  disabled?: boolean;\n  indeterminate?: boolean;\n  size?: \"s\" | \"m\";\n  tabIndex?: number;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & Omit<FormFieldProps, \"labelHint\">;\n\ntype CheckboxSizes = Pick<CheckboxProps, \"size\">;\n\nconst StyledInputContainer = styled.div<CheckboxSizes>(({ theme, size }) => ({\n  userSelect: \"none\",\n  display: \"block\",\n  position: \"relative\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  boxSizing: \"border-box\",\n}));\n\nconst StyledRealInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  cursor: \"pointer\",\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledFakeInput = styled.span<CheckboxSizes>(({ theme, size }) => ({\n  boxSizing: \"border-box\",\n  width: theme.variables.size.dimension.checkbox[size],\n  height: theme.variables.size.dimension.checkbox[size],\n  borderRadius: theme.variables.size.borderRadius.xs,\n  border: \"2px solid\",\n  position: \"absolute\",\n  top: size === \"s\" ? theme.variables.size.spacing.xxs : 0,\n  left: 0,\n  display: \"flex\",\n  alignItems: \"center\",\n  justifyContent: \"center\",\n  cursor: \"pointer\",\n\n  background: theme.values.color.background.primary.default,\n  color: theme.values.color.text.onAccent.default,\n  borderColor: theme.values.color.border.primary.default,\n  lineHeight: 0,\n  \"& svg\": {\n    opacity: theme.variables.opacity.hidden,\n  },\n\n  \"input: focus-visible + &\": {\n    outlineWidth: \"2px\",\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"input: focus-visible + &\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"auto\",\n    },\n  },\n\n  \"input:checked + &, input:indeterminate + &\": {\n    border: 0,\n    background: theme.values.color.background.accent.default,\n\n    svg: {\n      opacity: theme.variables.opacity.visible,\n    },\n  },\n\n  \"input:disabled + &\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    \"&:hover\": {\n      cursor: disabled ? \"not-allowed\" : \"pointer\",\n      ...(!disabled && {\n        [`input:checked + ${StyledFakeInput}, input:indeterminate + ${StyledFakeInput}`]:\n          {\n            background: theme.values.color.background.accent.hover,\n          },\n      }),\n    },\n    ...(!disabled && {\n      [`&:hover ${StyledFakeInput}`]: {\n        borderColor: theme.values.color.border.primary.hover,\n      },\n    }),\n  })\n);\n\nexport const CheckboxRaw = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      label = \"\",\n      labelHint = \"\",\n      disabled = false,\n      indeterminate,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      tabIndex,\n      \"aria-labelledby\": ariaLabelledby,\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const internalRef = useRef<HTMLInputElement | null>(null);\n    const inputRef = internalRef || ref;\n\n    useLayoutEffect(() => {\n      if (inputRef.current) {\n        internalRef.current.indeterminate = indeterminate;\n      }\n    }, [indeterminate, inputRef]);\n\n    return (\n      <StyledContainer disabled={disabled}>\n        <Inline space=\"xs\" vAlignItems=\"top\" noWrap>\n          <StyledInputContainer size={size}>\n            <StyledRealInput\n              ref={inputRef}\n              aria-checked={indeterminate ? \"mixed\" : checked}\n              aria-labelledby={ariaLabelledby}\n              type=\"checkbox\"\n              name={name}\n              value={value}\n              checked={checked}\n              disabled={disabled}\n              onChange={onChange}\n              onClick={onClick}\n              onBlur={onBlur}\n              onFocus={onFocus}\n              tabIndex={tabIndex}\n            />\n\n            <StyledFakeInput size={size}>\n              {indeterminate ? (\n                <Icon size=\"s\" name=\"minus\" />\n              ) : (\n                <Icon size=\"s\" name={size === \"m\" ? \"check\" : \"check-small\"} />\n              )}\n            </StyledFakeInput>\n          </StyledInputContainer>\n          {label && (\n            <div>\n              {typeof label === \"string\" ? <Text>{label}</Text> : label}\n              {labelHint && (\n                <Text color=\"tertiary\" size=\"s\">\n                  {labelHint}\n                </Text>\n              )}\n            </div>\n          )}\n        </Inline>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const Checkbox = React.forwardRef(\n  (\n    {\n      name,\n      value = \"\",\n      checked = undefined,\n      indeterminate,\n      label,\n      labelHint,\n      size = \"m\",\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      disabled,\n      tabIndex,\n      \"aria-labelledby\": ariaLabelledby,\n      ...rest\n    }: CheckboxProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"Checkbox\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <CheckboxRaw\n        ref={ref}\n        name={name}\n        value={value}\n        checked={checked}\n        indeterminate={indeterminate}\n        size={size}\n        onChange={onChange}\n        onBlur={onBlur}\n        onClick={onClick}\n        onFocus={onFocus}\n        label={label}\n        labelHint={labelHint}\n        disabled={disabled}\n        tabIndex={tabIndex}\n        aria-labelledby={ariaLabelledby}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA+FwB"} */");export const CheckboxRaw=/*#__PURE__*/React.forwardRef(({name,value="",checked,label="",labelHint="",disabled=!1,indeterminate,size="m",onChange,onClick,onBlur,onFocus,tabIndex,"aria-labelledby":ariaLabelledby},ref)=>{let internalRef=useRef(null),inputRef=internalRef||ref;return useLayoutEffect(()=>{inputRef.current&&(internalRef.current.indeterminate=indeterminate)},[indeterminate,inputRef]),/*#__PURE__*/React.createElement(StyledContainer,{disabled:disabled},/*#__PURE__*/React.createElement(Inline,{space:"xs",vAlignItems:"top",noWrap:!0},/*#__PURE__*/React.createElement(StyledInputContainer,{size:size},/*#__PURE__*/React.createElement(StyledRealInput,{ref:inputRef,"aria-checked":indeterminate?"mixed":checked,"aria-labelledby":ariaLabelledby,type:"checkbox",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus,tabIndex:tabIndex}),/*#__PURE__*/React.createElement(StyledFakeInput,{size:size},indeterminate?/*#__PURE__*/React.createElement(Icon,{size:"s",name:"minus"}):/*#__PURE__*/React.createElement(Icon,{size:"s",name:"m"===size?"check":"check-small"}))),label&&/*#__PURE__*/React.createElement("div",null,"string"==typeof label?/*#__PURE__*/React.createElement(Text,null,label):label,labelHint&&/*#__PURE__*/React.createElement(Text,{color:"tertiary",size:"s"},labelHint))))});export const Checkbox=/*#__PURE__*/React.forwardRef(({name,value="",checked,indeterminate,label,labelHint,size="m",onChange,onClick,onBlur,onFocus,disabled,tabIndex,"aria-labelledby":ariaLabelledby,...rest},ref)=>/*#__PURE__*/React.createElement(FormField,{"data-ds-id":"Checkbox",disabled:disabled,...rest},/*#__PURE__*/React.createElement(CheckboxRaw,{ref:ref,name:name,value:value,checked:checked,indeterminate:indeterminate,size:size,onChange:onChange,onBlur:onBlur,onClick:onClick,onFocus:onFocus,label:label,labelHint:labelHint,disabled:disabled,tabIndex:tabIndex,"aria-labelledby":ariaLabelledby})));
@@ -1 +1 @@
1
- import React,{useRef}from"react";import styled from"@emotion/styled";import{Icon}from"../../Icon/Icon";import{PictogramButton}from"../../PictogramButton/PictogramButton";import{InputRaw}from"../Input/Input";import{FormField}from"../FormField/FormField";import iconSizesMap from"../../../web-tokens/_icon_sizes_map.json";let iconSizes=iconSizesMap.icons,StyledSearchInputContainer=/*#__PURE__*/styled("div",{target:"e12injc0",label:"StyledSearchInputContainer"})(({theme})=>({position:"relative",backgroundColor:theme.values.color.searchInput.background.default,borderRadius:theme.variables.size.borderRadius.xs,height:theme.variables.size.spacing.xl,width:"100%","& input":{backgroundColor:theme.values.color.background.transparent.default,lineHeight:theme.variables.size.lineHeight.xl,paddingTop:theme.variables.size.spacing.xxs,paddingBottom:theme.variables.size.spacing.xxs,paddingLeft:`calc(${theme.variables.size.spacing.s} + ${iconSizes.s})`,paddingRight:theme.variables.size.spacing.xl,borderWidth:0,textOverflow:"ellipsis","&::placeholder":{color:theme.values.color.text.tertiary.default,fontStyle:"italic"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uLy4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcbmltcG9ydCB0eXBlIHsgSW5wdXRQcm9wcyB9IGZyb20gXCIuLi9JbnB1dC9JbnB1dFwiO1xuaW1wb3J0IHsgSW5wdXRSYXcgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCBpY29uU2l6ZXNNYXAgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2ljb25fc2l6ZXNfbWFwLmpzb25cIjtcblxuY29uc3QgaWNvblNpemVzID0gaWNvblNpemVzTWFwLmljb25zO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5jb25zdCBTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3Iuc2VhcmNoSW5wdXQuYmFja2dyb3VuZC5kZWZhdWx0LFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgaGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICB3aWR0aDogXCIxMDAlXCIsXG4gIFwiJiBpbnB1dFwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueGwsXG4gICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgcGFkZGluZ0JvdHRvbTogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgcGFkZGluZ0xlZnQ6IGBjYWxjKCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSArICR7aWNvblNpemVzLnN9KWAsXG4gICAgcGFkZGluZ1JpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgIC8vIFRPRE8gcGxhY2Vob2xkZXIgZG9lc24ndCB0YWtlIGZ1bGwgd2lkdGggb2YgaW5wdXQsIG5lZWQgdG8gZml4IGl0XG4gICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRleHQudGVydGlhcnkuZGVmYXVsdCxcbiAgICAgIGZvbnRTdHlsZTogXCJpdGFsaWNcIixcbiAgICB9LFxuICB9LFxufSkpO1xuXG5jb25zdCBJY29uc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gIGp1c3RpZnlDb250ZW50OiBcInNwYWNlLWJldHdlZW5cIixcbiAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgaW5zZXQ6IGAwICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c31gLFxuXG4gIFwiJiA+IGRpdlwiOiB7XG4gICAgbGluZUhlaWdodDogMCxcbiAgfSxcbn0pKTtcblxuY29uc3QgU3R5bGVkQ2xlYXJCdXR0b24gPSBzdHlsZWQoUGljdG9ncmFtQnV0dG9uKSh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIHpJbmRleDogMSxcbn0pO1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIHJlYWRPbmx5LFxuICBvbkNsZWFyID0gKCkgPT4gbnVsbCxcbiAgLi4ucmVzdFxufTogU2VhcmNoSW5wdXRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBoYXNWYWx1ZSA9IEJvb2xlYW4odmFsdWUpO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrQ2xlYXIgPSAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgb25DbGVhcihlKTtcbiAgICBpbnB1dFJlZi5jdXJyZW50LmZvY3VzKCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkIGRhdGEtZHMtaWQ9XCJTZWFyY2hJbnB1dFwiIHsuLi4ocmVzdCBhcyBGb3JtRmllbGRQcm9wcyl9PlxuICAgICAgPFN0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgICAgICA8SW5wdXRSYXdcbiAgICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgbmFtZT17bmFtZX1cbiAgICAgICAgICBwbGFjZWhvbGRlcj17IXJlYWRPbmx5ICYmIHBsYWNlaG9sZGVyfVxuICAgICAgICAgIGRpc2FibGVkPXtyZXN0LmRpc2FibGVkfVxuICAgICAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICBhcmVhTGFiZWw9e2FyZWFMYWJlbH1cbiAgICAgICAgICBhdXRvQ29tcGxldGU9e2F1dG9Db21wbGV0ZX1cbiAgICAgICAgICBwcml2YXRlUHJvcHM9e3ByaXZhdGVQcm9wc31cbiAgICAgICAgICByZWFkT25seT17cmVhZE9ubHl9XG4gICAgICAgIC8+XG4gICAgICAgIDxJY29uc0NvbnRhaW5lcj5cbiAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgbmFtZT1cInNlYXJjaFwiXG4gICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICBjb2xvcj17cmVhZE9ubHkgPyBcInF1YXRlcm5hcnlcIiA6IFwidGVydGlhcnlcIn1cbiAgICAgICAgICAvPlxuICAgICAgICAgIHtoYXNWYWx1ZSAmJiAhcmVhZE9ubHkgJiYgKFxuICAgICAgICAgICAgPFN0eWxlZENsZWFyQnV0dG9uXG4gICAgICAgICAgICAgIGljb249XCJ4XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrQ2xlYXJ9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvSWNvbnNDb250YWluZXI+XG4gICAgICA8L1N0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQm1DIn0= */"),IconsContainer=/*#__PURE__*/styled("div",{target:"e12injc1",label:"IconsContainer"})(({theme})=>({display:"flex",alignItems:"center",justifyContent:"space-between",position:"absolute",inset:`0 ${theme.variables.size.spacing.xs}`,"& > div":{lineHeight:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uLy4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcbmltcG9ydCB0eXBlIHsgSW5wdXRQcm9wcyB9IGZyb20gXCIuLi9JbnB1dC9JbnB1dFwiO1xuaW1wb3J0IHsgSW5wdXRSYXcgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCBpY29uU2l6ZXNNYXAgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2ljb25fc2l6ZXNfbWFwLmpzb25cIjtcblxuY29uc3QgaWNvblNpemVzID0gaWNvblNpemVzTWFwLmljb25zO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5jb25zdCBTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3Iuc2VhcmNoSW5wdXQuYmFja2dyb3VuZC5kZWZhdWx0LFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgaGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICB3aWR0aDogXCIxMDAlXCIsXG4gIFwiJiBpbnB1dFwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueGwsXG4gICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgcGFkZGluZ0JvdHRvbTogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgcGFkZGluZ0xlZnQ6IGBjYWxjKCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSArICR7aWNvblNpemVzLnN9KWAsXG4gICAgcGFkZGluZ1JpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgIC8vIFRPRE8gcGxhY2Vob2xkZXIgZG9lc24ndCB0YWtlIGZ1bGwgd2lkdGggb2YgaW5wdXQsIG5lZWQgdG8gZml4IGl0XG4gICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRleHQudGVydGlhcnkuZGVmYXVsdCxcbiAgICAgIGZvbnRTdHlsZTogXCJpdGFsaWNcIixcbiAgICB9LFxuICB9LFxufSkpO1xuXG5jb25zdCBJY29uc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gIGp1c3RpZnlDb250ZW50OiBcInNwYWNlLWJldHdlZW5cIixcbiAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgaW5zZXQ6IGAwICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c31gLFxuXG4gIFwiJiA+IGRpdlwiOiB7XG4gICAgbGluZUhlaWdodDogMCxcbiAgfSxcbn0pKTtcblxuY29uc3QgU3R5bGVkQ2xlYXJCdXR0b24gPSBzdHlsZWQoUGljdG9ncmFtQnV0dG9uKSh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIHpJbmRleDogMSxcbn0pO1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIHJlYWRPbmx5LFxuICBvbkNsZWFyID0gKCkgPT4gbnVsbCxcbiAgLi4ucmVzdFxufTogU2VhcmNoSW5wdXRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBoYXNWYWx1ZSA9IEJvb2xlYW4odmFsdWUpO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrQ2xlYXIgPSAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgb25DbGVhcihlKTtcbiAgICBpbnB1dFJlZi5jdXJyZW50LmZvY3VzKCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkIGRhdGEtZHMtaWQ9XCJTZWFyY2hJbnB1dFwiIHsuLi4ocmVzdCBhcyBGb3JtRmllbGRQcm9wcyl9PlxuICAgICAgPFN0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgICAgICA8SW5wdXRSYXdcbiAgICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgbmFtZT17bmFtZX1cbiAgICAgICAgICBwbGFjZWhvbGRlcj17IXJlYWRPbmx5ICYmIHBsYWNlaG9sZGVyfVxuICAgICAgICAgIGRpc2FibGVkPXtyZXN0LmRpc2FibGVkfVxuICAgICAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICBhcmVhTGFiZWw9e2FyZWFMYWJlbH1cbiAgICAgICAgICBhdXRvQ29tcGxldGU9e2F1dG9Db21wbGV0ZX1cbiAgICAgICAgICBwcml2YXRlUHJvcHM9e3ByaXZhdGVQcm9wc31cbiAgICAgICAgICByZWFkT25seT17cmVhZE9ubHl9XG4gICAgICAgIC8+XG4gICAgICAgIDxJY29uc0NvbnRhaW5lcj5cbiAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgbmFtZT1cInNlYXJjaFwiXG4gICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICBjb2xvcj17cmVhZE9ubHkgPyBcInF1YXRlcm5hcnlcIiA6IFwidGVydGlhcnlcIn1cbiAgICAgICAgICAvPlxuICAgICAgICAgIHtoYXNWYWx1ZSAmJiAhcmVhZE9ubHkgJiYgKFxuICAgICAgICAgICAgPFN0eWxlZENsZWFyQnV0dG9uXG4gICAgICAgICAgICAgIGljb249XCJ4XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrQ2xlYXJ9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvSWNvbnNDb250YWluZXI+XG4gICAgICA8L1N0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQ3VCIn0= */"),StyledClearButton=/*#__PURE__*/styled(PictogramButton,{target:"e12injc2",label:"StyledClearButton"})({position:"relative",zIndex:1},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uLy4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcbmltcG9ydCB0eXBlIHsgSW5wdXRQcm9wcyB9IGZyb20gXCIuLi9JbnB1dC9JbnB1dFwiO1xuaW1wb3J0IHsgSW5wdXRSYXcgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCBpY29uU2l6ZXNNYXAgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2ljb25fc2l6ZXNfbWFwLmpzb25cIjtcblxuY29uc3QgaWNvblNpemVzID0gaWNvblNpemVzTWFwLmljb25zO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5jb25zdCBTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3Iuc2VhcmNoSW5wdXQuYmFja2dyb3VuZC5kZWZhdWx0LFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgaGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICB3aWR0aDogXCIxMDAlXCIsXG4gIFwiJiBpbnB1dFwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueGwsXG4gICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgcGFkZGluZ0JvdHRvbTogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgcGFkZGluZ0xlZnQ6IGBjYWxjKCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSArICR7aWNvblNpemVzLnN9KWAsXG4gICAgcGFkZGluZ1JpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgIC8vIFRPRE8gcGxhY2Vob2xkZXIgZG9lc24ndCB0YWtlIGZ1bGwgd2lkdGggb2YgaW5wdXQsIG5lZWQgdG8gZml4IGl0XG4gICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRleHQudGVydGlhcnkuZGVmYXVsdCxcbiAgICAgIGZvbnRTdHlsZTogXCJpdGFsaWNcIixcbiAgICB9LFxuICB9LFxufSkpO1xuXG5jb25zdCBJY29uc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gIGp1c3RpZnlDb250ZW50OiBcInNwYWNlLWJldHdlZW5cIixcbiAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgaW5zZXQ6IGAwICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c31gLFxuXG4gIFwiJiA+IGRpdlwiOiB7XG4gICAgbGluZUhlaWdodDogMCxcbiAgfSxcbn0pKTtcblxuY29uc3QgU3R5bGVkQ2xlYXJCdXR0b24gPSBzdHlsZWQoUGljdG9ncmFtQnV0dG9uKSh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIHpJbmRleDogMSxcbn0pO1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIHJlYWRPbmx5LFxuICBvbkNsZWFyID0gKCkgPT4gbnVsbCxcbiAgLi4ucmVzdFxufTogU2VhcmNoSW5wdXRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBoYXNWYWx1ZSA9IEJvb2xlYW4odmFsdWUpO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrQ2xlYXIgPSAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgb25DbGVhcihlKTtcbiAgICBpbnB1dFJlZi5jdXJyZW50LmZvY3VzKCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkIGRhdGEtZHMtaWQ9XCJTZWFyY2hJbnB1dFwiIHsuLi4ocmVzdCBhcyBGb3JtRmllbGRQcm9wcyl9PlxuICAgICAgPFN0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgICAgICA8SW5wdXRSYXdcbiAgICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgbmFtZT17bmFtZX1cbiAgICAgICAgICBwbGFjZWhvbGRlcj17IXJlYWRPbmx5ICYmIHBsYWNlaG9sZGVyfVxuICAgICAgICAgIGRpc2FibGVkPXtyZXN0LmRpc2FibGVkfVxuICAgICAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICBhcmVhTGFiZWw9e2FyZWFMYWJlbH1cbiAgICAgICAgICBhdXRvQ29tcGxldGU9e2F1dG9Db21wbGV0ZX1cbiAgICAgICAgICBwcml2YXRlUHJvcHM9e3ByaXZhdGVQcm9wc31cbiAgICAgICAgICByZWFkT25seT17cmVhZE9ubHl9XG4gICAgICAgIC8+XG4gICAgICAgIDxJY29uc0NvbnRhaW5lcj5cbiAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgbmFtZT1cInNlYXJjaFwiXG4gICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICBjb2xvcj17cmVhZE9ubHkgPyBcInF1YXRlcm5hcnlcIiA6IFwidGVydGlhcnlcIn1cbiAgICAgICAgICAvPlxuICAgICAgICAgIHtoYXNWYWx1ZSAmJiAhcmVhZE9ubHkgJiYgKFxuICAgICAgICAgICAgPFN0eWxlZENsZWFyQnV0dG9uXG4gICAgICAgICAgICAgIGljb249XCJ4XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrQ2xlYXJ9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvSWNvbnNDb250YWluZXI+XG4gICAgICA8L1N0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzRDBCIn0= */");export const SearchInput=({name,value,placeholder,hasError=!1,autoComplete="on",privateProps={},tabIndex,areaLabel,onChange,onClick,onBlur,onFocus,readOnly,onClear=()=>null,...rest})=>{let inputRef=useRef(null);return /*#__PURE__*/React.createElement(FormField,{"data-ds-id":"SearchInput",...rest},/*#__PURE__*/React.createElement(StyledSearchInputContainer,null,/*#__PURE__*/React.createElement(InputRaw,{ref:inputRef,type:"text",value:value,name:name,placeholder:!readOnly&&placeholder,disabled:rest.disabled,hasError:hasError,onClick:onClick,onChange:onChange,onBlur:onBlur,onFocus:onFocus,tabIndex:tabIndex,areaLabel:areaLabel,autoComplete:autoComplete,privateProps:privateProps,readOnly:readOnly}),/*#__PURE__*/React.createElement(IconsContainer,null,/*#__PURE__*/React.createElement(Icon,{name:"search",size:"s",color:readOnly?"quaternary":"tertiary"}),!!value&&!readOnly&&/*#__PURE__*/React.createElement(StyledClearButton,{icon:"x",size:"xs",color:"tertiary",onClick:e=>{e.preventDefault(),onClear(e),inputRef.current.focus()}}))))};
1
+ import React,{useRef}from"react";import styled from"@emotion/styled";import{Icon}from"../../Icon/Icon";import{PictogramButton}from"../../PictogramButton/PictogramButton";import{InputRaw}from"../Input/Input";import{FormField}from"../FormField/FormField";import iconSizesMap from"../../../web-tokens/_icon_sizes_map.json";let iconSizes=iconSizesMap.icons,StyledSearchInputContainer=/*#__PURE__*/styled("div",{target:"e1thwvpx0",label:"StyledSearchInputContainer"})(({theme})=>({position:"relative",backgroundColor:theme.values.color.searchInput.background.default,borderRadius:theme.variables.size.borderRadius.xs,height:theme.variables.size.spacing.xl,width:"100%","& input":{backgroundColor:theme.values.color.background.transparent.default,paddingTop:theme.variables.size.spacing.xxs,paddingBottom:theme.variables.size.spacing.xxs,paddingLeft:`calc(${theme.variables.size.spacing.s} + ${iconSizes.s})`,paddingRight:theme.variables.size.spacing.xl,borderWidth:0,textOverflow:"ellipsis","&::placeholder":{color:theme.values.color.text.tertiary.default,fontStyle:"italic"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uLy4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcbmltcG9ydCB0eXBlIHsgSW5wdXRQcm9wcyB9IGZyb20gXCIuLi9JbnB1dC9JbnB1dFwiO1xuaW1wb3J0IHsgSW5wdXRSYXcgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCBpY29uU2l6ZXNNYXAgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2ljb25fc2l6ZXNfbWFwLmpzb25cIjtcblxuY29uc3QgaWNvblNpemVzID0gaWNvblNpemVzTWFwLmljb25zO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5jb25zdCBTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3Iuc2VhcmNoSW5wdXQuYmFja2dyb3VuZC5kZWZhdWx0LFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgaGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICB3aWR0aDogXCIxMDAlXCIsXG4gIFwiJiBpbnB1dFwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgIHBhZGRpbmdUb3A6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgIHBhZGRpbmdCb3R0b206IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgIHBhZGRpbmdSaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgICBib3JkZXJXaWR0aDogMCxcbiAgICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgICAvLyBUT0RPIHBsYWNlaG9sZGVyIGRvZXNuJ3QgdGFrZSBmdWxsIHdpZHRoIG9mIGlucHV0LCBuZWVkIHRvIGZpeCBpdFxuICAgIFwiJjo6cGxhY2Vob2xkZXJcIjoge1xuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnRlcnRpYXJ5LmRlZmF1bHQsXG4gICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgfSxcbiAgfSxcbn0pKTtcblxuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gIGluc2V0OiBgMCAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHN9YCxcblxuICBcIiYgPiBkaXZcIjoge1xuICAgIGxpbmVIZWlnaHQ6IDAsXG4gIH0sXG59KSk7XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbikoe1xuICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICB6SW5kZXg6IDEsXG59KTtcblxuZXhwb3J0IGNvbnN0IFNlYXJjaElucHV0ID0gKHtcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIHBsYWNlaG9sZGVyLFxuICBoYXNFcnJvciA9IGZhbHNlLFxuICBhdXRvQ29tcGxldGUgPSBcIm9uXCIsXG4gIHByaXZhdGVQcm9wcyA9IHt9LFxuICB0YWJJbmRleCxcbiAgYXJlYUxhYmVsLFxuICBvbkNoYW5nZSxcbiAgb25DbGljayxcbiAgb25CbHVyLFxuICBvbkZvY3VzLFxuICByZWFkT25seSxcbiAgb25DbGVhciA9ICgpID0+IG51bGwsXG4gIC4uLnJlc3Rcbn06IFNlYXJjaElucHV0UHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQgPT4ge1xuICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxIVE1MSW5wdXRFbGVtZW50PihudWxsKTtcbiAgY29uc3QgaGFzVmFsdWUgPSBCb29sZWFuKHZhbHVlKTtcblxuICBjb25zdCBoYW5kbGVDbGlja0NsZWFyID0gKGU6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+KSA9PiB7XG4gICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIG9uQ2xlYXIoZSk7XG4gICAgaW5wdXRSZWYuY3VycmVudC5mb2N1cygpO1xuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VhcmNoSW5wdXRcIiB7Li4uKHJlc3QgYXMgRm9ybUZpZWxkUHJvcHMpfT5cbiAgICAgIDxTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lcj5cbiAgICAgICAgPElucHV0UmF3XG4gICAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICBuYW1lPXtuYW1lfVxuICAgICAgICAgIHBsYWNlaG9sZGVyPXshcmVhZE9ubHkgJiYgcGxhY2Vob2xkZXJ9XG4gICAgICAgICAgZGlzYWJsZWQ9e3Jlc3QuZGlzYWJsZWR9XG4gICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICAgIGFyZWFMYWJlbD17YXJlYUxhYmVsfVxuICAgICAgICAgIGF1dG9Db21wbGV0ZT17YXV0b0NvbXBsZXRlfVxuICAgICAgICAgIHByaXZhdGVQcm9wcz17cHJpdmF0ZVByb3BzfVxuICAgICAgICAgIHJlYWRPbmx5PXtyZWFkT25seX1cbiAgICAgICAgLz5cbiAgICAgICAgPEljb25zQ29udGFpbmVyPlxuICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICBuYW1lPVwic2VhcmNoXCJcbiAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgIGNvbG9yPXtyZWFkT25seSA/IFwicXVhdGVybmFyeVwiIDogXCJ0ZXJ0aWFyeVwifVxuICAgICAgICAgIC8+XG4gICAgICAgICAge2hhc1ZhbHVlICYmICFyZWFkT25seSAmJiAoXG4gICAgICAgICAgICA8U3R5bGVkQ2xlYXJCdXR0b25cbiAgICAgICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tDbGVhcn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9JY29uc0NvbnRhaW5lcj5cbiAgICAgIDwvU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXI+XG4gICAgPC9Gb3JtRmllbGQ+XG4gICk7XG59O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1CbUMifQ== */"),IconsContainer=/*#__PURE__*/styled("div",{target:"e1thwvpx1",label:"IconsContainer"})(({theme})=>({display:"flex",alignItems:"center",justifyContent:"space-between",position:"absolute",inset:`0 ${theme.variables.size.spacing.xs}`,"& > div":{lineHeight:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uLy4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcbmltcG9ydCB0eXBlIHsgSW5wdXRQcm9wcyB9IGZyb20gXCIuLi9JbnB1dC9JbnB1dFwiO1xuaW1wb3J0IHsgSW5wdXRSYXcgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCBpY29uU2l6ZXNNYXAgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2ljb25fc2l6ZXNfbWFwLmpzb25cIjtcblxuY29uc3QgaWNvblNpemVzID0gaWNvblNpemVzTWFwLmljb25zO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5jb25zdCBTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3Iuc2VhcmNoSW5wdXQuYmFja2dyb3VuZC5kZWZhdWx0LFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgaGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICB3aWR0aDogXCIxMDAlXCIsXG4gIFwiJiBpbnB1dFwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgIHBhZGRpbmdUb3A6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgIHBhZGRpbmdCb3R0b206IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgIHBhZGRpbmdSaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgICBib3JkZXJXaWR0aDogMCxcbiAgICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgICAvLyBUT0RPIHBsYWNlaG9sZGVyIGRvZXNuJ3QgdGFrZSBmdWxsIHdpZHRoIG9mIGlucHV0LCBuZWVkIHRvIGZpeCBpdFxuICAgIFwiJjo6cGxhY2Vob2xkZXJcIjoge1xuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnRlcnRpYXJ5LmRlZmF1bHQsXG4gICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgfSxcbiAgfSxcbn0pKTtcblxuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gIGluc2V0OiBgMCAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHN9YCxcblxuICBcIiYgPiBkaXZcIjoge1xuICAgIGxpbmVIZWlnaHQ6IDAsXG4gIH0sXG59KSk7XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbikoe1xuICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICB6SW5kZXg6IDEsXG59KTtcblxuZXhwb3J0IGNvbnN0IFNlYXJjaElucHV0ID0gKHtcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIHBsYWNlaG9sZGVyLFxuICBoYXNFcnJvciA9IGZhbHNlLFxuICBhdXRvQ29tcGxldGUgPSBcIm9uXCIsXG4gIHByaXZhdGVQcm9wcyA9IHt9LFxuICB0YWJJbmRleCxcbiAgYXJlYUxhYmVsLFxuICBvbkNoYW5nZSxcbiAgb25DbGljayxcbiAgb25CbHVyLFxuICBvbkZvY3VzLFxuICByZWFkT25seSxcbiAgb25DbGVhciA9ICgpID0+IG51bGwsXG4gIC4uLnJlc3Rcbn06IFNlYXJjaElucHV0UHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQgPT4ge1xuICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxIVE1MSW5wdXRFbGVtZW50PihudWxsKTtcbiAgY29uc3QgaGFzVmFsdWUgPSBCb29sZWFuKHZhbHVlKTtcblxuICBjb25zdCBoYW5kbGVDbGlja0NsZWFyID0gKGU6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+KSA9PiB7XG4gICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIG9uQ2xlYXIoZSk7XG4gICAgaW5wdXRSZWYuY3VycmVudC5mb2N1cygpO1xuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VhcmNoSW5wdXRcIiB7Li4uKHJlc3QgYXMgRm9ybUZpZWxkUHJvcHMpfT5cbiAgICAgIDxTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lcj5cbiAgICAgICAgPElucHV0UmF3XG4gICAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICBuYW1lPXtuYW1lfVxuICAgICAgICAgIHBsYWNlaG9sZGVyPXshcmVhZE9ubHkgJiYgcGxhY2Vob2xkZXJ9XG4gICAgICAgICAgZGlzYWJsZWQ9e3Jlc3QuZGlzYWJsZWR9XG4gICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICAgIGFyZWFMYWJlbD17YXJlYUxhYmVsfVxuICAgICAgICAgIGF1dG9Db21wbGV0ZT17YXV0b0NvbXBsZXRlfVxuICAgICAgICAgIHByaXZhdGVQcm9wcz17cHJpdmF0ZVByb3BzfVxuICAgICAgICAgIHJlYWRPbmx5PXtyZWFkT25seX1cbiAgICAgICAgLz5cbiAgICAgICAgPEljb25zQ29udGFpbmVyPlxuICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICBuYW1lPVwic2VhcmNoXCJcbiAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgIGNvbG9yPXtyZWFkT25seSA/IFwicXVhdGVybmFyeVwiIDogXCJ0ZXJ0aWFyeVwifVxuICAgICAgICAgIC8+XG4gICAgICAgICAge2hhc1ZhbHVlICYmICFyZWFkT25seSAmJiAoXG4gICAgICAgICAgICA8U3R5bGVkQ2xlYXJCdXR0b25cbiAgICAgICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tDbGVhcn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9JY29uc0NvbnRhaW5lcj5cbiAgICAgIDwvU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXI+XG4gICAgPC9Gb3JtRmllbGQ+XG4gICk7XG59O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlDdUIifQ== */"),StyledClearButton=/*#__PURE__*/styled(PictogramButton,{target:"e1thwvpx2",label:"StyledClearButton"})({position:"relative",zIndex:1},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uLy4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcbmltcG9ydCB0eXBlIHsgSW5wdXRQcm9wcyB9IGZyb20gXCIuLi9JbnB1dC9JbnB1dFwiO1xuaW1wb3J0IHsgSW5wdXRSYXcgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCBpY29uU2l6ZXNNYXAgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2ljb25fc2l6ZXNfbWFwLmpzb25cIjtcblxuY29uc3QgaWNvblNpemVzID0gaWNvblNpemVzTWFwLmljb25zO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5jb25zdCBTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3Iuc2VhcmNoSW5wdXQuYmFja2dyb3VuZC5kZWZhdWx0LFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgaGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhsLFxuICB3aWR0aDogXCIxMDAlXCIsXG4gIFwiJiBpbnB1dFwiOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgIHBhZGRpbmdUb3A6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgIHBhZGRpbmdCb3R0b206IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLFxuICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgIHBhZGRpbmdSaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgICBib3JkZXJXaWR0aDogMCxcbiAgICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgICAvLyBUT0RPIHBsYWNlaG9sZGVyIGRvZXNuJ3QgdGFrZSBmdWxsIHdpZHRoIG9mIGlucHV0LCBuZWVkIHRvIGZpeCBpdFxuICAgIFwiJjo6cGxhY2Vob2xkZXJcIjoge1xuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnRlcnRpYXJ5LmRlZmF1bHQsXG4gICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgfSxcbiAgfSxcbn0pKTtcblxuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gIGluc2V0OiBgMCAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHN9YCxcblxuICBcIiYgPiBkaXZcIjoge1xuICAgIGxpbmVIZWlnaHQ6IDAsXG4gIH0sXG59KSk7XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbikoe1xuICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICB6SW5kZXg6IDEsXG59KTtcblxuZXhwb3J0IGNvbnN0IFNlYXJjaElucHV0ID0gKHtcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIHBsYWNlaG9sZGVyLFxuICBoYXNFcnJvciA9IGZhbHNlLFxuICBhdXRvQ29tcGxldGUgPSBcIm9uXCIsXG4gIHByaXZhdGVQcm9wcyA9IHt9LFxuICB0YWJJbmRleCxcbiAgYXJlYUxhYmVsLFxuICBvbkNoYW5nZSxcbiAgb25DbGljayxcbiAgb25CbHVyLFxuICBvbkZvY3VzLFxuICByZWFkT25seSxcbiAgb25DbGVhciA9ICgpID0+IG51bGwsXG4gIC4uLnJlc3Rcbn06IFNlYXJjaElucHV0UHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQgPT4ge1xuICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxIVE1MSW5wdXRFbGVtZW50PihudWxsKTtcbiAgY29uc3QgaGFzVmFsdWUgPSBCb29sZWFuKHZhbHVlKTtcblxuICBjb25zdCBoYW5kbGVDbGlja0NsZWFyID0gKGU6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+KSA9PiB7XG4gICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIG9uQ2xlYXIoZSk7XG4gICAgaW5wdXRSZWYuY3VycmVudC5mb2N1cygpO1xuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VhcmNoSW5wdXRcIiB7Li4uKHJlc3QgYXMgRm9ybUZpZWxkUHJvcHMpfT5cbiAgICAgIDxTdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lcj5cbiAgICAgICAgPElucHV0UmF3XG4gICAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICBuYW1lPXtuYW1lfVxuICAgICAgICAgIHBsYWNlaG9sZGVyPXshcmVhZE9ubHkgJiYgcGxhY2Vob2xkZXJ9XG4gICAgICAgICAgZGlzYWJsZWQ9e3Jlc3QuZGlzYWJsZWR9XG4gICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgICAgICAgIGFyZWFMYWJlbD17YXJlYUxhYmVsfVxuICAgICAgICAgIGF1dG9Db21wbGV0ZT17YXV0b0NvbXBsZXRlfVxuICAgICAgICAgIHByaXZhdGVQcm9wcz17cHJpdmF0ZVByb3BzfVxuICAgICAgICAgIHJlYWRPbmx5PXtyZWFkT25seX1cbiAgICAgICAgLz5cbiAgICAgICAgPEljb25zQ29udGFpbmVyPlxuICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICBuYW1lPVwic2VhcmNoXCJcbiAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgIGNvbG9yPXtyZWFkT25seSA/IFwicXVhdGVybmFyeVwiIDogXCJ0ZXJ0aWFyeVwifVxuICAgICAgICAgIC8+XG4gICAgICAgICAge2hhc1ZhbHVlICYmICFyZWFkT25seSAmJiAoXG4gICAgICAgICAgICA8U3R5bGVkQ2xlYXJCdXR0b25cbiAgICAgICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tDbGVhcn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9JY29uc0NvbnRhaW5lcj5cbiAgICAgIDwvU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXI+XG4gICAgPC9Gb3JtRmllbGQ+XG4gICk7XG59O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFEMEIifQ== */");export const SearchInput=({name,value,placeholder,hasError=!1,autoComplete="on",privateProps={},tabIndex,areaLabel,onChange,onClick,onBlur,onFocus,readOnly,onClear=()=>null,...rest})=>{let inputRef=useRef(null);return /*#__PURE__*/React.createElement(FormField,{"data-ds-id":"SearchInput",...rest},/*#__PURE__*/React.createElement(StyledSearchInputContainer,null,/*#__PURE__*/React.createElement(InputRaw,{ref:inputRef,type:"text",size:"s",value:value,name:name,placeholder:!readOnly&&placeholder,disabled:rest.disabled,hasError:hasError,onClick:onClick,onChange:onChange,onBlur:onBlur,onFocus:onFocus,tabIndex:tabIndex,areaLabel:areaLabel,autoComplete:autoComplete,privateProps:privateProps,readOnly:readOnly}),/*#__PURE__*/React.createElement(IconsContainer,null,/*#__PURE__*/React.createElement(Icon,{name:"search",size:"s",color:readOnly?"quaternary":"tertiary"}),!!value&&!readOnly&&/*#__PURE__*/React.createElement(StyledClearButton,{icon:"x",size:"xs",color:"tertiary",onClick:e=>{e.preventDefault(),onClear(e),inputRef.current.focus()}}))))};
@@ -1 +1 @@
1
- import React from"react";import styled from"@emotion/styled";import{FormField}from"../FormField/FormField";import{SelectWithCustomTrigger}from"./SelectWithCustomTrigger";import{Icon}from"../../Icon/Icon";import{Inline}from"../../Inline/Inline";import{TextClamped}from"../../Typography/TextClamped/TextClamped";let StyledButton=/*#__PURE__*/styled("button",{target:"e1up2bc90",label:"StyledButton"})(({theme,hasError,isPlaceholderVisible,readOnly,size})=>({'&[type="button"]':{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},display:"inline-block",margin:0,borderRadius:theme.variables.size.borderRadius.xs,backgroundColor:theme.values.color.background.primary.default,borderWidth:"1px",borderStyle:"solid",width:"100%",padding:`${"s"===size?`calc(${theme.variables.size.spacing.xxs} - 1px)`:`calc(${theme.variables.size.spacing.xs} - 1px)`} ${theme.variables.size.spacing.s}`,paddingRight:theme.variables.size.spacing.xs,boxSizing:"border-box",borderColor:theme.values.color.border.primary.default,...readOnly&&{borderColor:theme.values.color.border.primary.disabled},...isPlaceholderVisible&&{fontStyle:"italic"},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`,borderColor:theme.values.color.border.error.default}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Select/Select.tsx","sources":["src/components/Form/Select/Select.tsx"],"sourcesContent":["// Customized browser select box\nimport React from \"react\";\nimport type { ReactNode, FocusEventHandler, ReactElement } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport type { SelectWithCustomTriggerProps } from \"./SelectWithCustomTrigger\";\nimport { SelectWithCustomTrigger } from \"./SelectWithCustomTrigger\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { TextClamped } from \"../../Typography/TextClamped/TextClamped\";\n\ntype StyledButtonProps = Pick<\n  TriggerButtonProps,\n  \"hasError\" | \"isPlaceholderVisible\" | \"readOnly\" | \"size\"\n>;\n\nconst StyledButton = styled.button<StyledButtonProps>(\n  ({ theme, hasError, isPlaceholderVisible, readOnly, size }) => ({\n    [`&[type=\"button\"]`]: {\n      // increase specificity\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    margin: 0,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    backgroundColor: theme.values.color.background.primary.default,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `${\n      size === \"s\"\n        ? `calc(${theme.variables.size.spacing.xxs} - 1px)`\n        : `calc(${theme.variables.size.spacing.xs} - 1px)`\n    } ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xs,\n    boxSizing: \"border-box\",\n    borderColor: theme.values.color.border.primary.default,\n\n    ...(readOnly && {\n      borderColor: theme.values.color.border.primary.disabled,\n    }),\n\n    ...(isPlaceholderVisible && {\n      fontStyle: \"italic\",\n    }),\n\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n      borderColor: theme.values.color.border.error.default,\n    }),\n  })\n);\n\nconst StyledTriggerIcon = styled(Icon)(\n  () =>\n    ({\n      pointerEvents: \"none\",\n    } as CSSObject)\n);\n\ntype TriggerButtonProps = {\n  children: ReactNode;\n  isPlaceholderVisible: boolean;\n} & Parameters<SelectWithCustomTriggerProps[\"renderTrigger\"]>[0] &\n  Pick<SelectProps, \"hasError\" | \"onFocus\" | \"onBlur\" | \"readOnly\" | \"size\">;\n\nfunction TriggerButton({\n  triggerRef,\n  disabled,\n  isOpen,\n  hasError,\n  isPlaceholderVisible,\n  role,\n  \"aria-expanded\": ariaExpanded,\n  \"aria-controls\": ariaControls,\n  \"aria-activedescendant\": ariaActiveDescendant,\n  readOnly,\n  size,\n  onFocus,\n  onBlur,\n  children,\n}: TriggerButtonProps) {\n  return (\n    <StyledButton\n      type=\"button\"\n      ref={triggerRef}\n      disabled={disabled}\n      hasError={hasError}\n      isPlaceholderVisible={isPlaceholderVisible}\n      role={role}\n      aria-expanded={ariaExpanded}\n      aria-controls={ariaControls}\n      aria-activedescendant={ariaActiveDescendant}\n      readOnly={readOnly}\n      size={size}\n      onFocus={onFocus}\n      onBlur={onBlur}\n    >\n      <Inline vAlignItems=\"center\" alignItems=\"spaceBetween\" space=\"xxs\" noWrap>\n        <TextClamped\n          color={isPlaceholderVisible ? \"tertiary\" : \"primary\"}\n          size=\"m\"\n        >\n          {readOnly && isPlaceholderVisible ? null : children}\n        </TextClamped>\n        <StyledTriggerIcon\n          size={size}\n          name={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          color={readOnly ? \"quaternary\" : \"tertiary\"}\n        />\n      </Inline>\n    </StyledButton>\n  );\n}\n\nexport type SelectProps = {\n  placeholder?: string;\n  hasError?: boolean;\n  size?: \"s\" | \"m\";\n  onFocus?: FocusEventHandler<HTMLButtonElement>;\n  onBlur?: FocusEventHandler<HTMLButtonElement>;\n} & Omit<SelectWithCustomTriggerProps, \"renderTrigger\"> &\n  FormFieldProps;\n\nexport function Select({\n  options,\n  name,\n  value,\n  placeholder,\n  hasError,\n  optionsListWidth,\n  maxHeight,\n  disabled,\n  portalContainer,\n  readOnly = false,\n  label,\n  labelHint,\n  hideLabel,\n  hint,\n  errorMessages,\n  size = \"m\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  onChange,\n  onFocus,\n  onBlur,\n}: SelectProps): ReactElement {\n  const selectedOption = options?.find((option) => option.value === value);\n  const isPlaceholderVisible = placeholder && !value;\n\n  return (\n    <SelectWithCustomTrigger\n      options={options}\n      value={value}\n      name={name}\n      optionsListWidth={optionsListWidth}\n      maxHeight={maxHeight}\n      portalContainer={portalContainer}\n      disabled={disabled}\n      readOnly={readOnly}\n      onChange={onChange}\n      renderTrigger={({\n        triggerRef,\n        isOpen,\n        role,\n        \"aria-expanded\": ariaExpanded,\n        \"aria-controls\": ariaControls,\n        \"aria-activedescendant\": ariaActiveDescendant,\n      }) => (\n        <FormField\n          disabled={disabled}\n          hideLabel={hideLabel}\n          label={label}\n          labelHint={labelHint}\n          hint={hint}\n          errorMessages={errorMessages}\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"Select\"\n        >\n          <TriggerButton\n            hasError={hasError}\n            isPlaceholderVisible={isPlaceholderVisible}\n            size={size}\n            triggerRef={triggerRef}\n            isOpen={isOpen}\n            disabled={disabled}\n            role={role}\n            aria-expanded={ariaExpanded}\n            aria-controls={ariaControls}\n            aria-activedescendant={ariaActiveDescendant}\n            readOnly={readOnly}\n            onFocus={onFocus}\n            onBlur={onBlur}\n          >\n            {selectedOption ? selectedOption.label : placeholder}\n          </TriggerButton>\n        </FormField>\n      )}\n    />\n  );\n}\n"],"names":[],"mappings":"AAkBqB"} */"),StyledTriggerIcon=/*#__PURE__*/styled(Icon,{target:"e1up2bc91",label:"StyledTriggerIcon"})(()=>({pointerEvents:"none"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Select/Select.tsx","sources":["src/components/Form/Select/Select.tsx"],"sourcesContent":["// Customized browser select box\nimport React from \"react\";\nimport type { ReactNode, FocusEventHandler, ReactElement } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport type { SelectWithCustomTriggerProps } from \"./SelectWithCustomTrigger\";\nimport { SelectWithCustomTrigger } from \"./SelectWithCustomTrigger\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { TextClamped } from \"../../Typography/TextClamped/TextClamped\";\n\ntype StyledButtonProps = Pick<\n  TriggerButtonProps,\n  \"hasError\" | \"isPlaceholderVisible\" | \"readOnly\" | \"size\"\n>;\n\nconst StyledButton = styled.button<StyledButtonProps>(\n  ({ theme, hasError, isPlaceholderVisible, readOnly, size }) => ({\n    [`&[type=\"button\"]`]: {\n      // increase specificity\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    margin: 0,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    backgroundColor: theme.values.color.background.primary.default,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `${\n      size === \"s\"\n        ? `calc(${theme.variables.size.spacing.xxs} - 1px)`\n        : `calc(${theme.variables.size.spacing.xs} - 1px)`\n    } ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xs,\n    boxSizing: \"border-box\",\n    borderColor: theme.values.color.border.primary.default,\n\n    ...(readOnly && {\n      borderColor: theme.values.color.border.primary.disabled,\n    }),\n\n    ...(isPlaceholderVisible && {\n      fontStyle: \"italic\",\n    }),\n\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n      borderColor: theme.values.color.border.error.default,\n    }),\n  })\n);\n\nconst StyledTriggerIcon = styled(Icon)(\n  () =>\n    ({\n      pointerEvents: \"none\",\n    } as CSSObject)\n);\n\ntype TriggerButtonProps = {\n  children: ReactNode;\n  isPlaceholderVisible: boolean;\n} & Parameters<SelectWithCustomTriggerProps[\"renderTrigger\"]>[0] &\n  Pick<SelectProps, \"hasError\" | \"onFocus\" | \"onBlur\" | \"readOnly\" | \"size\">;\n\nfunction TriggerButton({\n  triggerRef,\n  disabled,\n  isOpen,\n  hasError,\n  isPlaceholderVisible,\n  role,\n  \"aria-expanded\": ariaExpanded,\n  \"aria-controls\": ariaControls,\n  \"aria-activedescendant\": ariaActiveDescendant,\n  readOnly,\n  size,\n  onFocus,\n  onBlur,\n  children,\n}: TriggerButtonProps) {\n  return (\n    <StyledButton\n      type=\"button\"\n      ref={triggerRef}\n      disabled={disabled}\n      hasError={hasError}\n      isPlaceholderVisible={isPlaceholderVisible}\n      role={role}\n      aria-expanded={ariaExpanded}\n      aria-controls={ariaControls}\n      aria-activedescendant={ariaActiveDescendant}\n      readOnly={readOnly}\n      size={size}\n      onFocus={onFocus}\n      onBlur={onBlur}\n    >\n      <Inline vAlignItems=\"center\" alignItems=\"spaceBetween\" space=\"xxs\" noWrap>\n        <TextClamped\n          color={isPlaceholderVisible ? \"tertiary\" : \"primary\"}\n          size=\"m\"\n        >\n          {readOnly && isPlaceholderVisible ? null : children}\n        </TextClamped>\n        <StyledTriggerIcon\n          size={size}\n          name={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          color={readOnly ? \"quaternary\" : \"tertiary\"}\n        />\n      </Inline>\n    </StyledButton>\n  );\n}\n\nexport type SelectProps = {\n  placeholder?: string;\n  hasError?: boolean;\n  size?: \"s\" | \"m\";\n  onFocus?: FocusEventHandler<HTMLButtonElement>;\n  onBlur?: FocusEventHandler<HTMLButtonElement>;\n} & Omit<SelectWithCustomTriggerProps, \"renderTrigger\"> &\n  FormFieldProps;\n\nexport function Select({\n  options,\n  name,\n  value,\n  placeholder,\n  hasError,\n  optionsListWidth,\n  maxHeight,\n  disabled,\n  portalContainer,\n  readOnly = false,\n  label,\n  labelHint,\n  hideLabel,\n  hint,\n  errorMessages,\n  size = \"m\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  onChange,\n  onFocus,\n  onBlur,\n}: SelectProps): ReactElement {\n  const selectedOption = options?.find((option) => option.value === value);\n  const isPlaceholderVisible = placeholder && !value;\n\n  return (\n    <SelectWithCustomTrigger\n      options={options}\n      value={value}\n      name={name}\n      optionsListWidth={optionsListWidth}\n      maxHeight={maxHeight}\n      portalContainer={portalContainer}\n      disabled={disabled}\n      readOnly={readOnly}\n      onChange={onChange}\n      renderTrigger={({\n        triggerRef,\n        isOpen,\n        role,\n        \"aria-expanded\": ariaExpanded,\n        \"aria-controls\": ariaControls,\n        \"aria-activedescendant\": ariaActiveDescendant,\n      }) => (\n        <FormField\n          disabled={disabled}\n          hideLabel={hideLabel}\n          label={label}\n          labelHint={labelHint}\n          hint={hint}\n          errorMessages={errorMessages}\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"Select\"\n        >\n          <TriggerButton\n            hasError={hasError}\n            isPlaceholderVisible={isPlaceholderVisible}\n            size={size}\n            triggerRef={triggerRef}\n            isOpen={isOpen}\n            disabled={disabled}\n            role={role}\n            aria-expanded={ariaExpanded}\n            aria-controls={ariaControls}\n            aria-activedescendant={ariaActiveDescendant}\n            readOnly={readOnly}\n            onFocus={onFocus}\n            onBlur={onBlur}\n          >\n            {selectedOption ? selectedOption.label : placeholder}\n          </TriggerButton>\n        </FormField>\n      )}\n    />\n  );\n}\n"],"names":[],"mappings":"AAyD0B"} */");function TriggerButton({triggerRef,disabled,isOpen,hasError,isPlaceholderVisible,role,"aria-expanded":ariaExpanded,"aria-controls":ariaControls,"aria-activedescendant":ariaActiveDescendant,readOnly,size,onFocus,onBlur,children}){return /*#__PURE__*/React.createElement(StyledButton,{type:"button",ref:triggerRef,disabled:disabled,hasError:hasError,isPlaceholderVisible:isPlaceholderVisible,role:role,"aria-expanded":ariaExpanded,"aria-controls":ariaControls,"aria-activedescendant":ariaActiveDescendant,readOnly:readOnly,size:size,onFocus:onFocus,onBlur:onBlur},/*#__PURE__*/React.createElement(Inline,{vAlignItems:"center",alignItems:"spaceBetween",space:"xxs",noWrap:!0},/*#__PURE__*/React.createElement(TextClamped,{color:isPlaceholderVisible?"tertiary":"primary",size:"m"},readOnly&&isPlaceholderVisible?null:children),/*#__PURE__*/React.createElement(StyledTriggerIcon,{size:size,name:isOpen?"chevron-up":"chevron-down",color:readOnly?"quaternary":"tertiary"})))}export function Select({options,name,value,placeholder,hasError,optionsListWidth,maxHeight,disabled,portalContainer,readOnly=!1,label,labelHint,hideLabel,hint,errorMessages,size="m","data-e2e-test-id":dataE2eTestId,onChange,onFocus,onBlur}){let selectedOption=options?.find(option=>option.value===value),isPlaceholderVisible=placeholder&&!value;return /*#__PURE__*/React.createElement(SelectWithCustomTrigger,{options:options,value:value,name:name,optionsListWidth:optionsListWidth,maxHeight:maxHeight,portalContainer:portalContainer,disabled:disabled,readOnly:readOnly,onChange:onChange,renderTrigger:({triggerRef,isOpen,role,"aria-expanded":ariaExpanded,"aria-controls":ariaControls,"aria-activedescendant":ariaActiveDescendant})=>/*#__PURE__*/React.createElement(FormField,{disabled:disabled,hideLabel:hideLabel,label:label,labelHint:labelHint,hint:hint,errorMessages:errorMessages,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Select"},/*#__PURE__*/React.createElement(TriggerButton,{hasError:hasError,isPlaceholderVisible:isPlaceholderVisible,size:size,triggerRef:triggerRef,isOpen:isOpen,disabled:disabled,role:role,"aria-expanded":ariaExpanded,"aria-controls":ariaControls,"aria-activedescendant":ariaActiveDescendant,readOnly:readOnly,onFocus:onFocus,onBlur:onBlur},selectedOption?selectedOption.label:placeholder))})}
1
+ import React from"react";import styled from"@emotion/styled";import{FormField}from"../FormField/FormField";import{SelectWithCustomTrigger}from"./SelectWithCustomTrigger";import{Icon}from"../../Icon/Icon";import{Inline}from"../../Inline/Inline";import{TextClamped}from"../../Typography/TextClamped/TextClamped";let StyledButton=/*#__PURE__*/styled("button",{target:"e75ux8q0",label:"StyledButton"})(({theme,hasError,isPlaceholderVisible,readOnly,size})=>({'&[type="button"]':{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},display:"inline-block",margin:0,borderRadius:theme.variables.size.borderRadius.xs,backgroundColor:theme.values.color.background.primary.default,borderWidth:"1px",borderStyle:"solid",width:"100%",padding:`${"s"===size?`calc(${theme.variables.size.spacing.xxs} + 1px)`:`calc(${theme.variables.size.spacing.xs} - 1px)`} ${theme.variables.size.spacing.s}`,paddingRight:theme.variables.size.spacing.xs,boxSizing:"border-box",borderColor:theme.values.color.border.primary.default,...readOnly&&{borderColor:theme.values.color.border.primary.disabled},...isPlaceholderVisible&&{fontStyle:"italic"},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`,borderColor:theme.values.color.border.error.default}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Select/Select.tsx","sources":["src/components/Form/Select/Select.tsx"],"sourcesContent":["// Customized browser select box\nimport React from \"react\";\nimport type { ReactNode, FocusEventHandler, ReactElement } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport type { SelectWithCustomTriggerProps } from \"./SelectWithCustomTrigger\";\nimport { SelectWithCustomTrigger } from \"./SelectWithCustomTrigger\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { TextClamped } from \"../../Typography/TextClamped/TextClamped\";\n\ntype StyledButtonProps = Pick<\n  TriggerButtonProps,\n  \"hasError\" | \"isPlaceholderVisible\" | \"readOnly\" | \"size\"\n>;\n\nconst StyledButton = styled.button<StyledButtonProps>(\n  ({ theme, hasError, isPlaceholderVisible, readOnly, size }) => ({\n    [`&[type=\"button\"]`]: {\n      // increase specificity\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    margin: 0,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    backgroundColor: theme.values.color.background.primary.default,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `${\n      size === \"s\"\n        ? `calc(${theme.variables.size.spacing.xxs} + 1px)`\n        : `calc(${theme.variables.size.spacing.xs} - 1px)`\n    } ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xs,\n    boxSizing: \"border-box\",\n    borderColor: theme.values.color.border.primary.default,\n\n    ...(readOnly && {\n      borderColor: theme.values.color.border.primary.disabled,\n    }),\n\n    ...(isPlaceholderVisible && {\n      fontStyle: \"italic\",\n    }),\n\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n      borderColor: theme.values.color.border.error.default,\n    }),\n  })\n);\n\nconst StyledTriggerIcon = styled(Icon)(\n  () =>\n    ({\n      pointerEvents: \"none\",\n    } as CSSObject)\n);\n\ntype TriggerButtonProps = {\n  children: ReactNode;\n  isPlaceholderVisible: boolean;\n} & Parameters<SelectWithCustomTriggerProps[\"renderTrigger\"]>[0] &\n  Pick<SelectProps, \"hasError\" | \"onFocus\" | \"onBlur\" | \"readOnly\" | \"size\">;\n\nfunction TriggerButton({\n  triggerRef,\n  disabled,\n  isOpen,\n  hasError,\n  isPlaceholderVisible,\n  role,\n  \"aria-expanded\": ariaExpanded,\n  \"aria-controls\": ariaControls,\n  \"aria-activedescendant\": ariaActiveDescendant,\n  readOnly,\n  size,\n  onFocus,\n  onBlur,\n  children,\n}: TriggerButtonProps) {\n  return (\n    <StyledButton\n      type=\"button\"\n      ref={triggerRef}\n      disabled={disabled}\n      hasError={hasError}\n      isPlaceholderVisible={isPlaceholderVisible}\n      role={role}\n      aria-expanded={ariaExpanded}\n      aria-controls={ariaControls}\n      aria-activedescendant={ariaActiveDescendant}\n      readOnly={readOnly}\n      size={size}\n      onFocus={onFocus}\n      onBlur={onBlur}\n    >\n      <Inline vAlignItems=\"center\" alignItems=\"spaceBetween\" space=\"xxs\" noWrap>\n        <TextClamped\n          color={isPlaceholderVisible ? \"tertiary\" : \"primary\"}\n          size={size}\n        >\n          {readOnly && isPlaceholderVisible ? null : children}\n        </TextClamped>\n        <StyledTriggerIcon\n          size={size}\n          name={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          color={readOnly ? \"quaternary\" : \"tertiary\"}\n        />\n      </Inline>\n    </StyledButton>\n  );\n}\n\nexport type SelectProps = {\n  placeholder?: string;\n  hasError?: boolean;\n  size?: \"s\" | \"m\";\n  onFocus?: FocusEventHandler<HTMLButtonElement>;\n  onBlur?: FocusEventHandler<HTMLButtonElement>;\n} & Omit<SelectWithCustomTriggerProps, \"renderTrigger\"> &\n  FormFieldProps;\n\nexport function Select({\n  options,\n  name,\n  value,\n  placeholder,\n  hasError,\n  optionsListWidth,\n  maxHeight,\n  disabled,\n  portalContainer,\n  readOnly = false,\n  label,\n  labelHint,\n  hideLabel,\n  hint,\n  errorMessages,\n  size = \"m\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  onChange,\n  onFocus,\n  onBlur,\n}: SelectProps): ReactElement {\n  const selectedOption = options?.find((option) => option.value === value);\n  const isPlaceholderVisible = placeholder && !value;\n\n  return (\n    <SelectWithCustomTrigger\n      options={options}\n      value={value}\n      name={name}\n      optionsListWidth={optionsListWidth}\n      maxHeight={maxHeight}\n      portalContainer={portalContainer}\n      disabled={disabled}\n      readOnly={readOnly}\n      onChange={onChange}\n      renderTrigger={({\n        triggerRef,\n        isOpen,\n        role,\n        \"aria-expanded\": ariaExpanded,\n        \"aria-controls\": ariaControls,\n        \"aria-activedescendant\": ariaActiveDescendant,\n      }) => (\n        <FormField\n          disabled={disabled}\n          hideLabel={hideLabel}\n          label={label}\n          labelHint={labelHint}\n          hint={hint}\n          errorMessages={errorMessages}\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"Select\"\n        >\n          <TriggerButton\n            hasError={hasError}\n            isPlaceholderVisible={isPlaceholderVisible}\n            size={size}\n            triggerRef={triggerRef}\n            isOpen={isOpen}\n            disabled={disabled}\n            role={role}\n            aria-expanded={ariaExpanded}\n            aria-controls={ariaControls}\n            aria-activedescendant={ariaActiveDescendant}\n            readOnly={readOnly}\n            onFocus={onFocus}\n            onBlur={onBlur}\n          >\n            {selectedOption ? selectedOption.label : placeholder}\n          </TriggerButton>\n        </FormField>\n      )}\n    />\n  );\n}\n"],"names":[],"mappings":"AAkBqB"} */"),StyledTriggerIcon=/*#__PURE__*/styled(Icon,{target:"e75ux8q1",label:"StyledTriggerIcon"})(()=>({pointerEvents:"none"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Select/Select.tsx","sources":["src/components/Form/Select/Select.tsx"],"sourcesContent":["// Customized browser select box\nimport React from \"react\";\nimport type { ReactNode, FocusEventHandler, ReactElement } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport type { SelectWithCustomTriggerProps } from \"./SelectWithCustomTrigger\";\nimport { SelectWithCustomTrigger } from \"./SelectWithCustomTrigger\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { TextClamped } from \"../../Typography/TextClamped/TextClamped\";\n\ntype StyledButtonProps = Pick<\n  TriggerButtonProps,\n  \"hasError\" | \"isPlaceholderVisible\" | \"readOnly\" | \"size\"\n>;\n\nconst StyledButton = styled.button<StyledButtonProps>(\n  ({ theme, hasError, isPlaceholderVisible, readOnly, size }) => ({\n    [`&[type=\"button\"]`]: {\n      // increase specificity\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    margin: 0,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    backgroundColor: theme.values.color.background.primary.default,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `${\n      size === \"s\"\n        ? `calc(${theme.variables.size.spacing.xxs} + 1px)`\n        : `calc(${theme.variables.size.spacing.xs} - 1px)`\n    } ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xs,\n    boxSizing: \"border-box\",\n    borderColor: theme.values.color.border.primary.default,\n\n    ...(readOnly && {\n      borderColor: theme.values.color.border.primary.disabled,\n    }),\n\n    ...(isPlaceholderVisible && {\n      fontStyle: \"italic\",\n    }),\n\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n      borderColor: theme.values.color.border.error.default,\n    }),\n  })\n);\n\nconst StyledTriggerIcon = styled(Icon)(\n  () =>\n    ({\n      pointerEvents: \"none\",\n    } as CSSObject)\n);\n\ntype TriggerButtonProps = {\n  children: ReactNode;\n  isPlaceholderVisible: boolean;\n} & Parameters<SelectWithCustomTriggerProps[\"renderTrigger\"]>[0] &\n  Pick<SelectProps, \"hasError\" | \"onFocus\" | \"onBlur\" | \"readOnly\" | \"size\">;\n\nfunction TriggerButton({\n  triggerRef,\n  disabled,\n  isOpen,\n  hasError,\n  isPlaceholderVisible,\n  role,\n  \"aria-expanded\": ariaExpanded,\n  \"aria-controls\": ariaControls,\n  \"aria-activedescendant\": ariaActiveDescendant,\n  readOnly,\n  size,\n  onFocus,\n  onBlur,\n  children,\n}: TriggerButtonProps) {\n  return (\n    <StyledButton\n      type=\"button\"\n      ref={triggerRef}\n      disabled={disabled}\n      hasError={hasError}\n      isPlaceholderVisible={isPlaceholderVisible}\n      role={role}\n      aria-expanded={ariaExpanded}\n      aria-controls={ariaControls}\n      aria-activedescendant={ariaActiveDescendant}\n      readOnly={readOnly}\n      size={size}\n      onFocus={onFocus}\n      onBlur={onBlur}\n    >\n      <Inline vAlignItems=\"center\" alignItems=\"spaceBetween\" space=\"xxs\" noWrap>\n        <TextClamped\n          color={isPlaceholderVisible ? \"tertiary\" : \"primary\"}\n          size={size}\n        >\n          {readOnly && isPlaceholderVisible ? null : children}\n        </TextClamped>\n        <StyledTriggerIcon\n          size={size}\n          name={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          color={readOnly ? \"quaternary\" : \"tertiary\"}\n        />\n      </Inline>\n    </StyledButton>\n  );\n}\n\nexport type SelectProps = {\n  placeholder?: string;\n  hasError?: boolean;\n  size?: \"s\" | \"m\";\n  onFocus?: FocusEventHandler<HTMLButtonElement>;\n  onBlur?: FocusEventHandler<HTMLButtonElement>;\n} & Omit<SelectWithCustomTriggerProps, \"renderTrigger\"> &\n  FormFieldProps;\n\nexport function Select({\n  options,\n  name,\n  value,\n  placeholder,\n  hasError,\n  optionsListWidth,\n  maxHeight,\n  disabled,\n  portalContainer,\n  readOnly = false,\n  label,\n  labelHint,\n  hideLabel,\n  hint,\n  errorMessages,\n  size = \"m\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  onChange,\n  onFocus,\n  onBlur,\n}: SelectProps): ReactElement {\n  const selectedOption = options?.find((option) => option.value === value);\n  const isPlaceholderVisible = placeholder && !value;\n\n  return (\n    <SelectWithCustomTrigger\n      options={options}\n      value={value}\n      name={name}\n      optionsListWidth={optionsListWidth}\n      maxHeight={maxHeight}\n      portalContainer={portalContainer}\n      disabled={disabled}\n      readOnly={readOnly}\n      onChange={onChange}\n      renderTrigger={({\n        triggerRef,\n        isOpen,\n        role,\n        \"aria-expanded\": ariaExpanded,\n        \"aria-controls\": ariaControls,\n        \"aria-activedescendant\": ariaActiveDescendant,\n      }) => (\n        <FormField\n          disabled={disabled}\n          hideLabel={hideLabel}\n          label={label}\n          labelHint={labelHint}\n          hint={hint}\n          errorMessages={errorMessages}\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"Select\"\n        >\n          <TriggerButton\n            hasError={hasError}\n            isPlaceholderVisible={isPlaceholderVisible}\n            size={size}\n            triggerRef={triggerRef}\n            isOpen={isOpen}\n            disabled={disabled}\n            role={role}\n            aria-expanded={ariaExpanded}\n            aria-controls={ariaControls}\n            aria-activedescendant={ariaActiveDescendant}\n            readOnly={readOnly}\n            onFocus={onFocus}\n            onBlur={onBlur}\n          >\n            {selectedOption ? selectedOption.label : placeholder}\n          </TriggerButton>\n        </FormField>\n      )}\n    />\n  );\n}\n"],"names":[],"mappings":"AAyD0B"} */");function TriggerButton({triggerRef,disabled,isOpen,hasError,isPlaceholderVisible,role,"aria-expanded":ariaExpanded,"aria-controls":ariaControls,"aria-activedescendant":ariaActiveDescendant,readOnly,size,onFocus,onBlur,children}){return /*#__PURE__*/React.createElement(StyledButton,{type:"button",ref:triggerRef,disabled:disabled,hasError:hasError,isPlaceholderVisible:isPlaceholderVisible,role:role,"aria-expanded":ariaExpanded,"aria-controls":ariaControls,"aria-activedescendant":ariaActiveDescendant,readOnly:readOnly,size:size,onFocus:onFocus,onBlur:onBlur},/*#__PURE__*/React.createElement(Inline,{vAlignItems:"center",alignItems:"spaceBetween",space:"xxs",noWrap:!0},/*#__PURE__*/React.createElement(TextClamped,{color:isPlaceholderVisible?"tertiary":"primary",size:size},readOnly&&isPlaceholderVisible?null:children),/*#__PURE__*/React.createElement(StyledTriggerIcon,{size:size,name:isOpen?"chevron-up":"chevron-down",color:readOnly?"quaternary":"tertiary"})))}export function Select({options,name,value,placeholder,hasError,optionsListWidth,maxHeight,disabled,portalContainer,readOnly=!1,label,labelHint,hideLabel,hint,errorMessages,size="m","data-e2e-test-id":dataE2eTestId,onChange,onFocus,onBlur}){let selectedOption=options?.find(option=>option.value===value),isPlaceholderVisible=placeholder&&!value;return /*#__PURE__*/React.createElement(SelectWithCustomTrigger,{options:options,value:value,name:name,optionsListWidth:optionsListWidth,maxHeight:maxHeight,portalContainer:portalContainer,disabled:disabled,readOnly:readOnly,onChange:onChange,renderTrigger:({triggerRef,isOpen,role,"aria-expanded":ariaExpanded,"aria-controls":ariaControls,"aria-activedescendant":ariaActiveDescendant})=>/*#__PURE__*/React.createElement(FormField,{disabled:disabled,hideLabel:hideLabel,label:label,labelHint:labelHint,hint:hint,errorMessages:errorMessages,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Select"},/*#__PURE__*/React.createElement(TriggerButton,{hasError:hasError,isPlaceholderVisible:isPlaceholderVisible,size:size,triggerRef:triggerRef,isOpen:isOpen,disabled:disabled,role:role,"aria-expanded":ariaExpanded,"aria-controls":ariaControls,"aria-activedescendant":ariaActiveDescendant,readOnly:readOnly,onFocus:onFocus,onBlur:onBlur},selectedOption?selectedOption.label:placeholder))})}
@@ -3,7 +3,7 @@ import React from "react";
3
3
  This wrapper is added to handle onPostDeactivate from react-focus-trap. onPostDeactivate is fired before component unmounts. Often, onPostDeactivate is used to close the popup element (see BasePopover and Sheet). We are overriding it here to fire only when component recieves an outside click or esc key event so that popover and sheet can close correctly.
4
4
  */
5
5
  type FocusTrapWrapperProps = {
6
- active: boolean;
6
+ active?: boolean;
7
7
  focusTrapOptions: any;
8
8
  children: React.ReactNode;
9
9
  };
@@ -1 +1 @@
1
- import React,{useRef}from"react";import FocusTrap from"focus-trap-react";export const FocusTrapWrapper=({active,focusTrapOptions,children})=>{let isClickedOutside=useRef(!1),isEscaped=useRef(!1),{onPostDeactivate,clickOutsideDeactivates,escapeDeactivates,...rest}=focusTrapOptions;return /*#__PURE__*/React.createElement(FocusTrap,{active:active,focusTrapOptions:{...rest,clickOutsideDeactivates:evt=>(isClickedOutside.current=!0,"function"==typeof clickOutsideDeactivates)?clickOutsideDeactivates(evt):clickOutsideDeactivates,escapeDeactivates:evt=>(isEscaped.current=!0,"function"==typeof escapeDeactivates)?escapeDeactivates(evt):escapeDeactivates,onPostDeactivate:()=>{(isClickedOutside.current||isEscaped.current)&&onPostDeactivate(),isEscaped.current=!1,isClickedOutside.current=!1}}},children)};
1
+ import React,{useEffect,useRef}from"react";import FocusTrap from"focus-trap-react";export const FocusTrapWrapper=({active,focusTrapOptions,children})=>{let isClickedOutside=useRef(!1),isEscaped=useRef(!1),{onPostDeactivate,clickOutsideDeactivates,escapeDeactivates,...rest}=focusTrapOptions,onPostDeactivateRef=useRef(onPostDeactivate),clickOutsideDeactivatesRef=useRef(clickOutsideDeactivates),escapeDeactivatesRef=useRef(escapeDeactivates);return useEffect(()=>{onPostDeactivateRef.current=onPostDeactivate},[onPostDeactivate]),useEffect(()=>{clickOutsideDeactivatesRef.current=clickOutsideDeactivates},[clickOutsideDeactivates]),useEffect(()=>{escapeDeactivatesRef.current=escapeDeactivates},[escapeDeactivates]),/*#__PURE__*/React.createElement(FocusTrap,{active:active,focusTrapOptions:{...rest,clickOutsideDeactivates:evt=>{isClickedOutside.current=!0;let cb=clickOutsideDeactivatesRef.current;return"function"==typeof cb?cb(evt):cb},escapeDeactivates:evt=>{isEscaped.current=!0;let cb=escapeDeactivatesRef.current;return"function"==typeof cb?cb(evt):cb},onPostDeactivate:()=>{(isClickedOutside.current||isEscaped.current)&&onPostDeactivateRef.current(),isEscaped.current=!1,isClickedOutside.current=!1}}},children)};