@amboss/design-system 3.24.3 → 3.25.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.
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"AccessCardItem",{enumerable:!0,get:function(){return AccessCardItem}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Badge=require("../Badge/Badge"),_Button=require("../Button/Button"),_Columns=require("../Column/Columns"),_Inline=require("../Inline/Inline"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_Icon=require("../Icon/Icon"),_Text=require("../Typography/Text/Text"),StyledIconContainer=(0,_styled.default)("div",{target:"e1efuvnw0",label:"StyledIconContainer"})(({theme,isIconActive})=>({display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:isIconActive?theme.values.color.background.accentSubtle.default:theme.values.color.background.secondary.default,borderRadius:"50%",height:theme.variables.size.spacing.xxl,width:theme.variables.size.spacing.xxl}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQWNjZXNzQ2FyZEl0ZW0vQWNjZXNzQ2FyZEl0ZW0udHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9BY2Nlc3NDYXJkSXRlbS9BY2Nlc3NDYXJkSXRlbS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbGVtZW50VHlwZSB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBCYWRnZSwgdHlwZSBCYWRnZVByb3BzIH0gZnJvbSBcIi4uL0JhZGdlL0JhZGdlXCI7XG5pbXBvcnQgeyBCdXR0b24sIHR5cGUgQnV0dG9uUHJvcHMgfSBmcm9tIFwiLi4vQnV0dG9uL0J1dHRvblwiO1xuaW1wb3J0IHsgQ29sdW1ucywgQ29sdW1uIH0gZnJvbSBcIi4uL0NvbHVtbi9Db2x1bW5zXCI7XG5pbXBvcnQgeyBJbmxpbmUgfSBmcm9tIFwiLi4vSW5saW5lL0lubGluZVwiO1xuaW1wb3J0IHsgVGV4dENsYW1wZWQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0Q2xhbXBlZC9UZXh0Q2xhbXBlZFwiO1xuaW1wb3J0IHsgSWNvbiwgdHlwZSBJY29uUHJvcHMgfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSBcIi4uL1R5cG9ncmFwaHkvVGV4dC9UZXh0XCI7XG5cbmV4cG9ydCB0eXBlIEFjdGlvbkJ1dHRvbiA9IEJ1dHRvblByb3BzICYge1xuICBsYWJlbDogc3RyaW5nO1xuICBocmVmPzogc3RyaW5nO1xuICB0YXJnZXQ/OiBzdHJpbmc7XG4gIGFzPzogRWxlbWVudFR5cGU7XG4gIHRlc3RJZD86IEJ1dHRvblByb3BzW1wiZGF0YS1lMmUtdGVzdC1pZFwiXTtcbn07XG5cbmV4cG9ydCB0eXBlIEFjY2Vzc0NhcmRJdGVtUHJvcHMgPSB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGlzSWNvbkFjdGl2ZTogYm9vbGVhbjtcbiAgaWNvbk5hbWU6IEljb25Qcm9wc1tcIm5hbWVcIl07XG4gIHN1YlRpdGxlPzogc3RyaW5nO1xuICBiYWRnZT86IFBpY2s8QmFkZ2VQcm9wcywgXCJ0ZXh0XCIgfCBcImNvbG9yXCI+O1xuICBhZGRpdGlvbmFsSW5mbz86IHN0cmluZztcbiAgcHJpbWFyeUJ1dHRvbj86IEFjdGlvbkJ1dHRvbjtcbiAgc2Vjb25kYXJ5QnV0dG9ucz86IEFjdGlvbkJ1dHRvbltdO1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcbn07XG5cbmNvbnN0IFN0eWxlZEljb25Db250YWluZXIgPSBzdHlsZWQuZGl2PFxuICBQaWNrPEFjY2Vzc0NhcmRJdGVtUHJvcHMsIFwiaXNJY29uQWN0aXZlXCI+XG4+KCh7IHRoZW1lLCBpc0ljb25BY3RpdmUgfSkgPT4gKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gIGp1c3RpZnlDb250ZW50OiBcImNlbnRlclwiLFxuICBiYWNrZ3JvdW5kQ29sb3I6IGlzSWNvbkFjdGl2ZVxuICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuYWNjZW50U3VidGxlLmRlZmF1bHRcbiAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICBib3JkZXJSYWRpdXM6IFwiNTAlXCIsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eGwsXG4gIHdpZHRoOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4bCxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIEFjY2Vzc0NhcmRJdGVtKHtcbiAgaXNJY29uQWN0aXZlID0gdHJ1ZSxcbiAgaWNvbk5hbWUgPSBcImFjdGl2aXR5XCIsXG4gIHRpdGxlLFxuICBzdWJUaXRsZSxcbiAgYmFkZ2UsXG4gIGFkZGl0aW9uYWxJbmZvLFxuICBwcmltYXJ5QnV0dG9uLFxuICBzZWNvbmRhcnlCdXR0b25zLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCA9IFwiZGV0YWlsLWNhcmQtaXRlbS1jb21wb25lbnRcIixcbn06IEFjY2Vzc0NhcmRJdGVtUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICByZXR1cm4gKFxuICAgIDxDb2x1bW5zIGdhcD1cImxcIiB2QWxpZ25JdGVtcz1cImNlbnRlclwiIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9PlxuICAgICAgey8qIENvbHVtbiBmb3IgZWxlbWVudHMgbGVmdCBzaWRlIGZyb20gYnV0dG9uczogdGhlIGljb24sIHRpdGxlLCBzdWJ0aXRsZSBhbmQgYWRkaXRpb25hbCBpbmZvICovfVxuICAgICAgPENvbHVtbiBzaXplPVwiZmlsbFwiPlxuICAgICAgICA8Q29sdW1ucyBnYXA9XCJtXCIgdkFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICB7LyogQ29sdW1uIGZvciB0aGUgaWNvbiAqL31cbiAgICAgICAgICA8Q29sdW1uIHNpemU9XCJuYXJyb3dcIiBhbGlnblNlbGY9XCJzdGFydFwiPlxuICAgICAgICAgICAgPFN0eWxlZEljb25Db250YWluZXIgaXNJY29uQWN0aXZlPXtpc0ljb25BY3RpdmV9PlxuICAgICAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgICAgIG5hbWU9e2ljb25OYW1lfVxuICAgICAgICAgICAgICAgIGNvbG9yPXtpc0ljb25BY3RpdmUgPyBcImFjY2VudFwiIDogXCJ0ZXJ0aWFyeVwifVxuICAgICAgICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2BpY29uLWluLSR7ZGF0YUUyZVRlc3RJZH1gfVxuICAgICAgICAgICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1N0eWxlZEljb25Db250YWluZXI+XG4gICAgICAgICAgPC9Db2x1bW4+XG4gICAgICAgICAgey8qIENvbHVtbiBmb3IgdGhlIHRpdGxlLCBiYWRnZSwgc3VidGl0bGUgYW5kIGFkZGl0aW9uYWwgaW5mbyAqL31cbiAgICAgICAgICA8Q29sdW1uPlxuICAgICAgICAgICAgPENvbHVtbnMgZ2FwPVwieHNcIiB2QWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICB7LyogQ29sdW1uIGZvciB0aGUgdGl0bGUsIGJhZGdlIGFuZCBzdWJ0aXRsZSAqL31cbiAgICAgICAgICAgICAgPENvbHVtbiBzaXplPVwiZmlsbFwiPlxuICAgICAgICAgICAgICAgIDxJbmxpbmUgbm9XcmFwIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgc3BhY2U9XCJ4c1wiPlxuICAgICAgICAgICAgICAgICAgPFRleHRDbGFtcGVkIHNpemU9XCJtXCI+e3RpdGxlfTwvVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICAgICB7YmFkZ2UgJiYgKFxuICAgICAgICAgICAgICAgICAgICA8QmFkZ2VcbiAgICAgICAgICAgICAgICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtgYmFkZ2UtaW4tJHtkYXRhRTJlVGVzdElkfWB9XG4gICAgICAgICAgICAgICAgICAgICAgdGV4dD17YmFkZ2U/LnRleHR9XG4gICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2JhZGdlPy5jb2xvciA/PyBcImdyZWVuXCJ9XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDwvSW5saW5lPlxuICAgICAgICAgICAgICAgIHtzdWJUaXRsZSAmJiAoXG4gICAgICAgICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgICAgICAgZGF0YS1lMmUtdGVzdC1pZD17YHN1YnRpdGxlLWluLSR7ZGF0YUUyZVRlc3RJZH1gfVxuICAgICAgICAgICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHtzdWJUaXRsZX1cbiAgICAgICAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L0NvbHVtbj5cbiAgICAgICAgICAgICAge2FkZGl0aW9uYWxJbmZvICYmIChcbiAgICAgICAgICAgICAgICA8Q29sdW1uIHNpemU9e1sxMiwgMTIsIFwibmFycm93XCJdfT5cbiAgICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybT1cInVwcGVyY2FzZVwiXG4gICAgICAgICAgICAgICAgICAgIHdlaWdodD1cImJvbGRcIlxuICAgICAgICAgICAgICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtgYWRkaXRpb25hbC1pbmZvLWluLSR7ZGF0YUUyZVRlc3RJZH1gfVxuICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICB7YWRkaXRpb25hbEluZm99XG4gICAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICAgPC9Db2x1bW4+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L0NvbHVtbnM+XG4gICAgICAgICAgPC9Db2x1bW4+XG4gICAgICAgIDwvQ29sdW1ucz5cbiAgICAgIDwvQ29sdW1uPlxuICAgICAgey8qIENvbHVtbiBmb3IgdGhlIGJ1dHRvbnMgKi99XG4gICAgICB7KHByaW1hcnlCdXR0b24gfHwgc2Vjb25kYXJ5QnV0dG9ucz8ubGVuZ3RoID4gMCkgJiYgKFxuICAgICAgICA8Q29sdW1uIHNpemU9e1sxMiwgXCJuYXJyb3dcIl19PlxuICAgICAgICAgIDxDb2x1bW5zIGdhcD1cInhzXCI+XG4gICAgICAgICAgICB7c2Vjb25kYXJ5QnV0dG9ucz8ubWFwKCh7IGxhYmVsLCAuLi5idXR0b25Qcm9wcyB9KSA9PiAoXG4gICAgICAgICAgICAgIDxDb2x1bW4ga2V5PXtsYWJlbH0gc2l6ZT17WzEyLCBcIm5hcnJvd1wiXX0+XG4gICAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICAgICAgZnVsbFdpZHRoXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PVwic2Vjb25kYXJ5XCJcbiAgICAgICAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nXG4gICAgICAgICAgICAgICAgICB7Li4uYnV0dG9uUHJvcHN9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge2xhYmVsfVxuICAgICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgICA8L0NvbHVtbj5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgICAge3ByaW1hcnlCdXR0b24gJiYgKFxuICAgICAgICAgICAgICA8Q29sdW1uIHNpemU9e1sxMiwgXCJuYXJyb3dcIl19PlxuICAgICAgICAgICAgICAgIDxCdXR0b25cbiAgICAgICAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgICAgICAgIGZ1bGxXaWR0aFxuICAgICAgICAgICAgICAgICAgdmFyaWFudD1cInByaW1hcnlcIlxuICAgICAgICAgICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmdcbiAgICAgICAgICAgICAgICAgIHsuLi5wcmltYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtwcmltYXJ5QnV0dG9uLmxhYmVsfVxuICAgICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgICA8L0NvbHVtbj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC9Db2x1bW5zPlxuICAgICAgICA8L0NvbHVtbj5cbiAgICAgICl9XG4gICAgPC9Db2x1bW5zPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStCNEIifQ== */");function AccessCardItem({isIconActive=!0,iconName="activity",title,subTitle,badge,additionalInfo,primaryButton,secondaryButtons,"data-e2e-test-id":dataE2eTestId="detail-card-item-component"}){return _react.default.createElement(_Columns.Columns,{gap:"l",vAlignItems:"center","data-e2e-test-id":dataE2eTestId},_react.default.createElement(_Columns.Column,{size:"fill"},_react.default.createElement(_Columns.Columns,{gap:"m",vAlignItems:"center"},_react.default.createElement(_Columns.Column,{size:"narrow",alignSelf:"start"},_react.default.createElement(StyledIconContainer,{isIconActive:isIconActive},_react.default.createElement(_Icon.Icon,{name:iconName,color:isIconActive?"accent":"tertiary","data-e2e-test-id":`icon-in-${dataE2eTestId}`,"aria-hidden":"true"}))),_react.default.createElement(_Columns.Column,null,_react.default.createElement(_Columns.Columns,{gap:"xs",vAlignItems:"center"},_react.default.createElement(_Columns.Column,{size:"fill"},_react.default.createElement(_Inline.Inline,{noWrap:!0,vAlignItems:"center",space:"xs"},_react.default.createElement(_TextClamped.TextClamped,{size:"m"},title),badge&&_react.default.createElement(_Badge.Badge,{"data-e2e-test-id":`badge-in-${dataE2eTestId}`,text:badge?.text,color:badge?.color??"green"})),subTitle&&_react.default.createElement(_Text.Text,{color:"tertiary","data-e2e-test-id":`subtitle-in-${dataE2eTestId}`,size:"s"},subTitle)),additionalInfo&&_react.default.createElement(_Columns.Column,{size:[12,12,"narrow"]},_react.default.createElement(_Text.Text,{size:"xs",transform:"uppercase",weight:"bold","data-e2e-test-id":`additional-info-in-${dataE2eTestId}`},additionalInfo)))))),(primaryButton||secondaryButtons?.length>0)&&_react.default.createElement(_Columns.Column,{size:[12,"narrow"]},_react.default.createElement(_Columns.Columns,{gap:"xs"},secondaryButtons?.map(({label,...buttonProps})=>_react.default.createElement(_Columns.Column,{key:label,size:[12,"narrow"]},_react.default.createElement(_Button.Button,{size:"s",fullWidth:!0,variant:"secondary",...buttonProps},label))),primaryButton&&_react.default.createElement(_Columns.Column,{size:[12,"narrow"]},_react.default.createElement(_Button.Button,{size:"s",fullWidth:!0,variant:"primary",...primaryButton},primaryButton.label)))))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"AccessCardItem",{enumerable:!0,get:function(){return AccessCardItem}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_default")._(require("react")),_Badge=require("../Badge/Badge"),_Button=require("../Button/Button"),_Columns=require("../Column/Columns"),_Inline=require("../Inline/Inline"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_Text=require("../Typography/Text/Text"),_IconTile=require("../IconTile/IconTile");function AccessCardItem({isIconActive=!0,iconName="activity",title,subTitle,badge,additionalInfo,primaryButton,secondaryButtons,"data-e2e-test-id":dataE2eTestId="detail-card-item-component"}){return _react.default.createElement(_Columns.Columns,{gap:"l",vAlignItems:"center","data-e2e-test-id":dataE2eTestId},_react.default.createElement(_Columns.Column,{size:"fill"},_react.default.createElement(_Columns.Columns,{gap:"m",vAlignItems:"center"},_react.default.createElement(_Columns.Column,{size:"narrow",alignSelf:"start"},_react.default.createElement(_IconTile.IconTile,{icon:iconName,color:isIconActive?"brand":"gray","data-e2e-test-id":`icon-in-${dataE2eTestId}`,ariaAttributes:{"aria-hidden":"true"}})),_react.default.createElement(_Columns.Column,null,_react.default.createElement(_Columns.Columns,{gap:"xs",vAlignItems:"center"},_react.default.createElement(_Columns.Column,{size:"fill"},_react.default.createElement(_Inline.Inline,{noWrap:!0,vAlignItems:"center",space:"xs"},_react.default.createElement(_TextClamped.TextClamped,{size:"m"},title),badge&&_react.default.createElement(_Badge.Badge,{"data-e2e-test-id":`badge-in-${dataE2eTestId}`,text:badge?.text,color:badge?.color??"green"})),subTitle&&_react.default.createElement(_Text.Text,{color:"tertiary","data-e2e-test-id":`subtitle-in-${dataE2eTestId}`,size:"s"},subTitle)),additionalInfo&&_react.default.createElement(_Columns.Column,{size:[12,12,"narrow"]},_react.default.createElement(_Text.Text,{size:"xs",transform:"uppercase",weight:"bold","data-e2e-test-id":`additional-info-in-${dataE2eTestId}`},additionalInfo)))))),(primaryButton||secondaryButtons?.length>0)&&_react.default.createElement(_Columns.Column,{size:[12,"narrow"]},_react.default.createElement(_Columns.Columns,{gap:"xs"},secondaryButtons?.map(({label,...buttonProps})=>_react.default.createElement(_Columns.Column,{key:label,size:[12,"narrow"]},_react.default.createElement(_Button.Button,{size:"s",fullWidth:!0,variant:"secondary",...buttonProps},label))),primaryButton&&_react.default.createElement(_Columns.Column,{size:[12,"narrow"]},_react.default.createElement(_Button.Button,{size:"s",fullWidth:!0,variant:"primary",...primaryButton},primaryButton.label)))))}
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Badge",{enumerable:!0,get:function(){return Badge}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Box=require("../Box/Box"),_Icon=require("../Icon/Icon"),_Inline=require("../Inline/Inline"),BadgeContainer=(0,_styled.default)("div",{target:"e1jx5gpv0",label:"BadgeContainer"})(({theme,color})=>({borderRadius:theme.variables.size.borderRadius.xl,display:"inline-block",textTransform:"uppercase",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.xs,lineHeight:theme.variables.size.lineHeight.m,fontWeight:"bold",letterSpacing:theme.variables.size.letterSpacing.s,border:"solid 1px",borderColor:color?theme.values.color.badge.borderSubtle[color]:theme.values.color.badge.borderSubtle.default,backgroundColor:color?theme.values.color.badge.background[color]:theme.values.color.badge.background.default,color:color?theme.values.color.badge.foreground[color]:theme.values.color.badge.foreground.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQmFkZ2UvQmFkZ2UudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9CYWRnZS9CYWRnZS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5cbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5pbXBvcnQgdHlwZSB7IEljb25OYW1lIH0gZnJvbSBcIi4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5cbmV4cG9ydCB0eXBlIEJhZGdlUHJvcHMgPSB7XG4gIC8qKiBUaGlzIGlzIGEgdGV4dCBmb3IgYSBjb21wb25lbnQgcHJvcGVydHkgKi9cbiAgdGV4dDogc3RyaW5nO1xuICAvKiogQSBjb2xvciBkb2Vzbid0IHJlZmxlY3QgYW55IGludGVudCBvdGhlciB0aGFuIHRvIHZhcmlldHkgKi9cbiAgY29sb3I/OiBgZ3JlZW5gIHwgYGJsdWVgIHwgYHllbGxvd2AgfCBgYnJhbmRgIHwgYHB1cnBsZWAgfCBgcmVkYCB8IGBncmF5YDtcblxuICBpY29uPzogSWNvbk5hbWU7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgQmFkZ2VDb250YWluZXIgPSBzdHlsZWQuZGl2PFBhcnRpYWw8QmFkZ2VQcm9wcz4+KCh7IHRoZW1lLCBjb2xvciB9KSA9PiAoe1xuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54bCxcbiAgZGlzcGxheTogXCJpbmxpbmUtYmxvY2tcIixcbiAgdGV4dFRyYW5zZm9ybTogXCJ1cHBlcmNhc2VcIixcbiAgZm9udEZhbWlseTogdGhlbWUudmFyaWFibGVzLmZvbnRGYW1pbHkubGF0byxcbiAgZm9udFNpemU6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmZvbnQueHMsXG4gIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQubSxcbiAgZm9udFdlaWdodDogXCJib2xkXCIsXG4gIGxldHRlclNwYWNpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxldHRlclNwYWNpbmcucyxcbiAgYm9yZGVyOiBcInNvbGlkIDFweFwiLFxuICBib3JkZXJDb2xvcjogY29sb3JcbiAgICA/IHRoZW1lLnZhbHVlcy5jb2xvci5iYWRnZS5ib3JkZXJTdWJ0bGVbY29sb3JdXG4gICAgOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFkZ2UuYm9yZGVyU3VidGxlLmRlZmF1bHQsXG4gIGJhY2tncm91bmRDb2xvcjogY29sb3JcbiAgICA/IHRoZW1lLnZhbHVlcy5jb2xvci5iYWRnZS5iYWNrZ3JvdW5kW2NvbG9yXVxuICAgIDogdGhlbWUudmFsdWVzLmNvbG9yLmJhZGdlLmJhY2tncm91bmQuZGVmYXVsdCxcbiAgY29sb3I6IGNvbG9yXG4gICAgPyB0aGVtZS52YWx1ZXMuY29sb3IuYmFkZ2UuZm9yZWdyb3VuZFtjb2xvcl1cbiAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWRnZS5mb3JlZ3JvdW5kLmRlZmF1bHQsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBCYWRnZSh7XG4gIHRleHQsXG4gIGNvbG9yLFxuICBpY29uLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgLi4ucmVzdFxufTogQmFkZ2VQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPEJhZGdlQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD1cIkJhZGdlXCJcbiAgICAgIGNvbG9yPXtjb2xvcn1cbiAgICAgIHsuLi5yZXN0fVxuICAgID5cbiAgICAgIDxCb3ggc3BhY2U9XCJ4c1wiIHZTcGFjZT1cInh4c1wiPlxuICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgc3BhY2U9XCJ4eHNcIiBub1dyYXA+XG4gICAgICAgICAge2ljb24gJiYgPEljb24gbmFtZT17aWNvbn0gc2l6ZT1cInNcIiBhcmlhLWhpZGRlbiAvPn1cbiAgICAgICAgICA8c3Bhbj57dGV4dH08L3NwYW4+XG4gICAgICAgIDwvSW5saW5lPlxuICAgICAgPC9Cb3g+XG4gICAgPC9CYWRnZUNvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQnVCIn0= */");function Badge({text,color,icon,"data-e2e-test-id":dataE2eTestId,...rest}){return _react.default.createElement(BadgeContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Badge",color:color,...rest},_react.default.createElement(_Box.Box,{space:"xs",vSpace:"xxs"},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",space:"xxs",noWrap:!0},icon&&_react.default.createElement(_Icon.Icon,{name:icon,size:"s","aria-hidden":!0}),_react.default.createElement("span",null,text))))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Badge",{enumerable:!0,get:function(){return Badge}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Box=require("../Box/Box"),_Icon=require("../Icon/Icon"),_Inline=require("../Inline/Inline"),BadgeContainer=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"color"!==prop,target:"eesknrx0",label:"BadgeContainer"})(({theme,color})=>({borderRadius:theme.variables.size.borderRadius.xl,display:"inline-block",textTransform:"uppercase",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.xs,lineHeight:theme.variables.size.lineHeight.m,fontWeight:"bold",letterSpacing:theme.variables.size.letterSpacing.s,border:"solid 1px",borderColor:color?theme.values.color.badge.borderSubtle[color]:theme.values.color.badge.borderSubtle.default,backgroundColor:color?theme.values.color.badge.background[color]:theme.values.color.badge.background.default,color:color?theme.values.color.badge.foreground[color]:theme.values.color.badge.foreground.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQmFkZ2UvQmFkZ2UudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9CYWRnZS9CYWRnZS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgaXNQcm9wVmFsaWQgZnJvbSBcIkBlbW90aW9uL2lzLXByb3AtdmFsaWRcIjtcblxuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uL0JveC9Cb3hcIjtcbmltcG9ydCB0eXBlIHsgSWNvbk5hbWUgfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcblxuZXhwb3J0IHR5cGUgQmFkZ2VQcm9wcyA9IHtcbiAgLyoqIFRoaXMgaXMgYSB0ZXh0IGZvciBhIGNvbXBvbmVudCBwcm9wZXJ0eSAqL1xuICB0ZXh0OiBzdHJpbmc7XG4gIC8qKiBBIGNvbG9yIGRvZXNuJ3QgcmVmbGVjdCBhbnkgaW50ZW50IG90aGVyIHRoYW4gdG8gdmFyaWV0eSAqL1xuICBjb2xvcj86IGBncmVlbmAgfCBgYmx1ZWAgfCBgeWVsbG93YCB8IGBicmFuZGAgfCBgcHVycGxlYCB8IGByZWRgIHwgYGdyYXlgO1xuXG4gIGljb24/OiBJY29uTmFtZTtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBCYWRnZUNvbnRhaW5lciA9IHN0eWxlZChcImRpdlwiLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT4gaXNQcm9wVmFsaWQocHJvcCkgJiYgcHJvcCAhPT0gXCJjb2xvclwiLFxufSk8UGFydGlhbDxCYWRnZVByb3BzPj4oKHsgdGhlbWUsIGNvbG9yIH0pID0+ICh7XG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhsLFxuICBkaXNwbGF5OiBcImlubGluZS1ibG9ja1wiLFxuICB0ZXh0VHJhbnNmb3JtOiBcInVwcGVyY2FzZVwiLFxuICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC54cyxcbiAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC5tLFxuICBmb250V2VpZ2h0OiBcImJvbGRcIixcbiAgbGV0dGVyU3BhY2luZzogdGhlbWUudmFyaWFibGVzLnNpemUubGV0dGVyU3BhY2luZy5zLFxuICBib3JkZXI6IFwic29saWQgMXB4XCIsXG4gIGJvcmRlckNvbG9yOiBjb2xvclxuICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmJhZGdlLmJvcmRlclN1YnRsZVtjb2xvcl1cbiAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWRnZS5ib3JkZXJTdWJ0bGUuZGVmYXVsdCxcbiAgYmFja2dyb3VuZENvbG9yOiBjb2xvclxuICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmJhZGdlLmJhY2tncm91bmRbY29sb3JdXG4gICAgOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFkZ2UuYmFja2dyb3VuZC5kZWZhdWx0LFxuICBjb2xvcjogY29sb3JcbiAgICA/IHRoZW1lLnZhbHVlcy5jb2xvci5iYWRnZS5mb3JlZ3JvdW5kW2NvbG9yXVxuICAgIDogdGhlbWUudmFsdWVzLmNvbG9yLmJhZGdlLmZvcmVncm91bmQuZGVmYXVsdCxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIEJhZGdlKHtcbiAgdGV4dCxcbiAgY29sb3IsXG4gIGljb24sXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxuICAuLi5yZXN0XG59OiBCYWRnZVByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgcmV0dXJuIChcbiAgICA8QmFkZ2VDb250YWluZXJcbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiQmFkZ2VcIlxuICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgey4uLnJlc3R9XG4gICAgPlxuICAgICAgPEJveCBzcGFjZT1cInhzXCIgdlNwYWNlPVwieHhzXCI+XG4gICAgICAgIDxJbmxpbmUgdkFsaWduSXRlbXM9XCJjZW50ZXJcIiBzcGFjZT1cInh4c1wiIG5vV3JhcD5cbiAgICAgICAgICB7aWNvbiAmJiA8SWNvbiBuYW1lPXtpY29ufSBzaXplPVwic1wiIGFyaWEtaGlkZGVuIC8+fVxuICAgICAgICAgIDxzcGFuPnt0ZXh0fTwvc3Bhbj5cbiAgICAgICAgPC9JbmxpbmU+XG4gICAgICA8L0JveD5cbiAgICA8L0JhZGdlQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1CdUIifQ== */");function Badge({text,color,icon,"data-e2e-test-id":dataE2eTestId,...rest}){return _react.default.createElement(BadgeContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Badge",color:color,...rest},_react.default.createElement(_Box.Box,{space:"xs",vSpace:"xxs"},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",space:"xxs",noWrap:!0},icon&&_react.default.createElement(_Icon.Icon,{name:icon,size:"s","aria-hidden":!0}),_react.default.createElement("span",null,text))))}
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Container",{enumerable:!0,get:function(){return Container}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_mediaQueries=require("../../shared/mediaQueries"),handleElevationLevel=(theme,elevation)=>{switch(elevation-0){case 1:return theme.values.elevation[1];case 2:return theme.values.elevation[2];case 3:return theme.values.elevation[3];case 4:return theme.values.elevation[4];default:return""}},StyledContainer=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"elevation"!==prop&&"borderRadius"!==prop&&"border"!==prop,target:"e195vud10",label:"StyledContainer"})(({theme,elevation,borderRadius,squareCorners,border})=>({position:"relative",backgroundColor:theme.values.color.background.primary.default,...border&&{outline:`1px solid ${theme.values.color.border.secondary.default}`,outlineOffset:-1},...squareCorners?{borderRadius:0}:(0,_mediaQueries.useResponsiveStyles)({borderRadius:[borderRadius,theme.variables.size.borderRadius]}),":after":{content:'" "',position:"absolute",top:0,left:0,width:"100%",height:"100%",pointerEvents:"none",borderRadius:"inherit",boxShadow:handleElevationLevel(theme,elevation)}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGFpbmVyL0NvbnRhaW5lci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0NvbnRhaW5lci9Db250YWluZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IGlzUHJvcFZhbGlkIGZyb20gXCJAZW1vdGlvbi9pcy1wcm9wLXZhbGlkXCI7XG5pbXBvcnQgdHlwZSB7IEJvcmRlclJhZGl1cywgTVEgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuXG50eXBlIENvbnRhaW5lclByaXZhdGVQcm9wcyA9IHtcbiAgYm9yZGVyOiBib29sZWFuO1xufTtcblxuZXhwb3J0IHR5cGUgQ29udGFpbmVyUHJvcHMgPSB7XG4gIGVsZXZhdGlvbj86IDAgfCAxIHwgMiB8IDMgfCA0O1xuICBib3JkZXJSYWRpdXM/OiBCb3JkZXJSYWRpdXMgfCBNUTxCb3JkZXJSYWRpdXM+O1xuICBvdmVyZmxvdz86IFwiYXV0b1wiIHwgXCJoaWRkZW5cIiB8IFwidmlzaWJsZVwiO1xuICBjaGlsZHJlbj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG4gIGlkPzogc3RyaW5nO1xuICAvLyBUT0RPIGJvcmRlciBpcyBnb25uYSBiZSBpbiBtYWluIHByb3BzXG4gIHByaXZhdGVQcm9wcz86IENvbnRhaW5lclByaXZhdGVQcm9wcztcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgaGFuZGxlRWxldmF0aW9uTGV2ZWwgPSAodGhlbWU6IFRoZW1lLCBlbGV2YXRpb246IG51bWJlcikgPT4ge1xuICAvKiBQYXJzaW5nIGVsZXZhdGlvbiBwcm9wZXJ0eSB0byBudW1iZXIgKi9cbiAgc3dpdGNoIChlbGV2YXRpb24gLSAwKSB7XG4gICAgY2FzZSAxOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bMV07XG4gICAgY2FzZSAyOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bMl07XG4gICAgY2FzZSAzOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bM107XG4gICAgY2FzZSA0OlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bNF07XG4gICAgY2FzZSAwOlxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gXCJcIjtcbiAgfVxufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkKFwiZGl2XCIsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IChwcm9wKSA9PlxuICAgIGlzUHJvcFZhbGlkKHByb3ApICYmXG4gICAgcHJvcCAhPT0gXCJlbGV2YXRpb25cIiAmJlxuICAgIHByb3AgIT09IFwiYm9yZGVyUmFkaXVzXCIgJiZcbiAgICBwcm9wICE9PSBcImJvcmRlclwiLFxufSk8UGFydGlhbDxDb250YWluZXJQcm9wcz4gJiBDb250YWluZXJQcml2YXRlUHJvcHM+KFxuICAoeyB0aGVtZSwgZWxldmF0aW9uLCBib3JkZXJSYWRpdXMsIHNxdWFyZUNvcm5lcnMsIGJvcmRlciB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgLi4uKGJvcmRlciAmJiB7XG4gICAgICBvdXRsaW5lOiBgMXB4IHNvbGlkICR7dGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5zZWNvbmRhcnkuZGVmYXVsdH1gLFxuICAgICAgb3V0bGluZU9mZnNldDogLTEsXG4gICAgfSksXG5cbiAgICAuLi4oc3F1YXJlQ29ybmVyc1xuICAgICAgPyB7XG4gICAgICAgICAgYm9yZGVyUmFkaXVzOiAwLFxuICAgICAgICB9XG4gICAgICA6IHVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgICAgIGJvcmRlclJhZGl1czogW2JvcmRlclJhZGl1cywgdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzXSxcbiAgICAgICAgfSkpLFxuXG4gICAgLy8gQm94IHNoYWRvdyBpcyBhcHBsaWVkIHRvIGEgcHNldWRvIGVsZW1lbnQgdG8gbWFrZSBzdXJlIGVsZXZhdGlvbiBpbnNldCBzaGFkb3cgaW4gZGFyayBtb2RlIGlzIG5vdCBoaWRkZW4gYnkgY29udGVudCBiYWNrZ3JvdW5kXG4gICAgXCI6YWZ0ZXJcIjoge1xuICAgICAgY29udGVudDogJ1wiIFwiJyxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICB0b3A6IDAsXG4gICAgICBsZWZ0OiAwLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgaGVpZ2h0OiBcIjEwMCVcIixcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICAgIGJveFNoYWRvdzogaGFuZGxlRWxldmF0aW9uTGV2ZWwodGhlbWUsIGVsZXZhdGlvbiksXG4gICAgfSxcbiAgfSlcbik7XG5cbmNvbnN0IFN0eWxlZERpdiA9IHN0eWxlZC5kaXY8UGFydGlhbDxDb250YWluZXJQcm9wcz4+KCh7IG92ZXJmbG93IH0pID0+ICh7XG4gIGJvcmRlclJhZGl1czogXCJpbmhlcml0XCIsXG4gIG92ZXJmbG93LFxuICBoZWlnaHQ6IFwiMTAwJVwiLFxuXG4gIFwiJiA+ICo6bGFzdC1jaGlsZFwiOiB7XG4gICAgYm9yZGVyQm90dG9tTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgYm9yZGVyQm90dG9tUmlnaHRSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICB9LFxuICBcIiYgPiAqOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgIGJvcmRlclRvcExlZnRSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICAgIGJvcmRlclRvcFJpZ2h0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbnRhaW5lcih7XG4gIGNoaWxkcmVuLFxuICBlbGV2YXRpb24gPSAxLFxuICBib3JkZXJSYWRpdXMgPSBcIm1cIixcbiAgb3ZlcmZsb3csXG4gIHNxdWFyZUNvcm5lcnMgPSBmYWxzZSxcbiAgaWQsXG4gIHByaXZhdGVQcm9wcyA9IHsgYm9yZGVyOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkID0gXCJDb250YWluZXJcIixcbiAgLi4ucmVzdFxufTogQ29udGFpbmVyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IGJvcmRlciB9ID0gcHJpdmF0ZVByb3BzO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIHsuLi5yZXN0fVxuICAgICAgaWQ9e2lkfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9e2RhdGFEc0lkfVxuICAgICAgZWxldmF0aW9uPXtlbGV2YXRpb259XG4gICAgICBib3JkZXJSYWRpdXM9e2JvcmRlclJhZGl1c31cbiAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICBib3JkZXI9e2JvcmRlcn1cbiAgICA+XG4gICAgICA8U3R5bGVkRGl2IG92ZXJmbG93PXtvdmVyZmxvd30+e2NoaWxkcmVufTwvU3R5bGVkRGl2PlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBDd0IifQ== */"),StyledDiv=(0,_styled.default)("div",{target:"e195vud11",label:"StyledDiv"})(({overflow})=>({borderRadius:"inherit",overflow,height:"100%","& > *:last-child":{borderBottomLeftRadius:"inherit",borderBottomRightRadius:"inherit"},"& > *:first-of-type":{borderTopLeftRadius:"inherit",borderTopRightRadius:"inherit"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGFpbmVyL0NvbnRhaW5lci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0NvbnRhaW5lci9Db250YWluZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IGlzUHJvcFZhbGlkIGZyb20gXCJAZW1vdGlvbi9pcy1wcm9wLXZhbGlkXCI7XG5pbXBvcnQgdHlwZSB7IEJvcmRlclJhZGl1cywgTVEgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuXG50eXBlIENvbnRhaW5lclByaXZhdGVQcm9wcyA9IHtcbiAgYm9yZGVyOiBib29sZWFuO1xufTtcblxuZXhwb3J0IHR5cGUgQ29udGFpbmVyUHJvcHMgPSB7XG4gIGVsZXZhdGlvbj86IDAgfCAxIHwgMiB8IDMgfCA0O1xuICBib3JkZXJSYWRpdXM/OiBCb3JkZXJSYWRpdXMgfCBNUTxCb3JkZXJSYWRpdXM+O1xuICBvdmVyZmxvdz86IFwiYXV0b1wiIHwgXCJoaWRkZW5cIiB8IFwidmlzaWJsZVwiO1xuICBjaGlsZHJlbj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG4gIGlkPzogc3RyaW5nO1xuICAvLyBUT0RPIGJvcmRlciBpcyBnb25uYSBiZSBpbiBtYWluIHByb3BzXG4gIHByaXZhdGVQcm9wcz86IENvbnRhaW5lclByaXZhdGVQcm9wcztcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgaGFuZGxlRWxldmF0aW9uTGV2ZWwgPSAodGhlbWU6IFRoZW1lLCBlbGV2YXRpb246IG51bWJlcikgPT4ge1xuICAvKiBQYXJzaW5nIGVsZXZhdGlvbiBwcm9wZXJ0eSB0byBudW1iZXIgKi9cbiAgc3dpdGNoIChlbGV2YXRpb24gLSAwKSB7XG4gICAgY2FzZSAxOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bMV07XG4gICAgY2FzZSAyOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bMl07XG4gICAgY2FzZSAzOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bM107XG4gICAgY2FzZSA0OlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bNF07XG4gICAgY2FzZSAwOlxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gXCJcIjtcbiAgfVxufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkKFwiZGl2XCIsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IChwcm9wKSA9PlxuICAgIGlzUHJvcFZhbGlkKHByb3ApICYmXG4gICAgcHJvcCAhPT0gXCJlbGV2YXRpb25cIiAmJlxuICAgIHByb3AgIT09IFwiYm9yZGVyUmFkaXVzXCIgJiZcbiAgICBwcm9wICE9PSBcImJvcmRlclwiLFxufSk8UGFydGlhbDxDb250YWluZXJQcm9wcz4gJiBDb250YWluZXJQcml2YXRlUHJvcHM+KFxuICAoeyB0aGVtZSwgZWxldmF0aW9uLCBib3JkZXJSYWRpdXMsIHNxdWFyZUNvcm5lcnMsIGJvcmRlciB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgLi4uKGJvcmRlciAmJiB7XG4gICAgICBvdXRsaW5lOiBgMXB4IHNvbGlkICR7dGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5zZWNvbmRhcnkuZGVmYXVsdH1gLFxuICAgICAgb3V0bGluZU9mZnNldDogLTEsXG4gICAgfSksXG5cbiAgICAuLi4oc3F1YXJlQ29ybmVyc1xuICAgICAgPyB7XG4gICAgICAgICAgYm9yZGVyUmFkaXVzOiAwLFxuICAgICAgICB9XG4gICAgICA6IHVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgICAgIGJvcmRlclJhZGl1czogW2JvcmRlclJhZGl1cywgdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzXSxcbiAgICAgICAgfSkpLFxuXG4gICAgLy8gQm94IHNoYWRvdyBpcyBhcHBsaWVkIHRvIGEgcHNldWRvIGVsZW1lbnQgdG8gbWFrZSBzdXJlIGVsZXZhdGlvbiBpbnNldCBzaGFkb3cgaW4gZGFyayBtb2RlIGlzIG5vdCBoaWRkZW4gYnkgY29udGVudCBiYWNrZ3JvdW5kXG4gICAgXCI6YWZ0ZXJcIjoge1xuICAgICAgY29udGVudDogJ1wiIFwiJyxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICB0b3A6IDAsXG4gICAgICBsZWZ0OiAwLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgaGVpZ2h0OiBcIjEwMCVcIixcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICAgIGJveFNoYWRvdzogaGFuZGxlRWxldmF0aW9uTGV2ZWwodGhlbWUsIGVsZXZhdGlvbiksXG4gICAgfSxcbiAgfSlcbik7XG5cbmNvbnN0IFN0eWxlZERpdiA9IHN0eWxlZC5kaXY8UGFydGlhbDxDb250YWluZXJQcm9wcz4+KCh7IG92ZXJmbG93IH0pID0+ICh7XG4gIGJvcmRlclJhZGl1czogXCJpbmhlcml0XCIsXG4gIG92ZXJmbG93LFxuICBoZWlnaHQ6IFwiMTAwJVwiLFxuXG4gIFwiJiA+ICo6bGFzdC1jaGlsZFwiOiB7XG4gICAgYm9yZGVyQm90dG9tTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgYm9yZGVyQm90dG9tUmlnaHRSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICB9LFxuICBcIiYgPiAqOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgIGJvcmRlclRvcExlZnRSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICAgIGJvcmRlclRvcFJpZ2h0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbnRhaW5lcih7XG4gIGNoaWxkcmVuLFxuICBlbGV2YXRpb24gPSAxLFxuICBib3JkZXJSYWRpdXMgPSBcIm1cIixcbiAgb3ZlcmZsb3csXG4gIHNxdWFyZUNvcm5lcnMgPSBmYWxzZSxcbiAgaWQsXG4gIHByaXZhdGVQcm9wcyA9IHsgYm9yZGVyOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkID0gXCJDb250YWluZXJcIixcbiAgLi4ucmVzdFxufTogQ29udGFpbmVyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IGJvcmRlciB9ID0gcHJpdmF0ZVByb3BzO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIHsuLi5yZXN0fVxuICAgICAgaWQ9e2lkfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9e2RhdGFEc0lkfVxuICAgICAgZWxldmF0aW9uPXtlbGV2YXRpb259XG4gICAgICBib3JkZXJSYWRpdXM9e2JvcmRlclJhZGl1c31cbiAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICBib3JkZXI9e2JvcmRlcn1cbiAgICA+XG4gICAgICA8U3R5bGVkRGl2IG92ZXJmbG93PXtvdmVyZmxvd30+e2NoaWxkcmVufTwvU3R5bGVkRGl2PlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdGa0IifQ== */");function Container({children,elevation=1,borderRadius="m",overflow,squareCorners=!1,id,privateProps={border:!1},"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId="Container",...rest}){let{border}=privateProps;return _react.default.createElement(StyledContainer,{...rest,id:id,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,elevation:elevation,borderRadius:borderRadius,squareCorners:squareCorners,border:border},_react.default.createElement(StyledDiv,{overflow:overflow},children))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Container",{enumerable:!0,get:function(){return Container}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_mediaQueries=require("../../shared/mediaQueries"),handleElevationLevel=(theme,elevation)=>{switch(elevation-0){case 1:return theme.values.elevation[1];case 2:return theme.values.elevation[2];case 3:return theme.values.elevation[3];case 4:return theme.values.elevation[4];default:return""}},StyledContainer=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"elevation"!==prop&&"borderRadius"!==prop&&"border"!==prop,target:"evpjmzq0",label:"StyledContainer"})(({theme,elevation,borderRadius,squareCorners,border})=>({position:"relative",backgroundColor:theme.values.color.background.primary.default,...border&&{outline:`1px solid ${theme.values.color.border.secondary.default}`,outlineOffset:-1},...squareCorners?{borderRadius:0}:(0,_mediaQueries.useResponsiveStyles)({borderRadius:[borderRadius,theme.variables.size.borderRadius]}),":after":{content:'" "',position:"absolute",top:0,left:0,width:"100%",height:"100%",pointerEvents:"none",borderRadius:"inherit",boxShadow:handleElevationLevel(theme,elevation)}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGFpbmVyL0NvbnRhaW5lci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0NvbnRhaW5lci9Db250YWluZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IGlzUHJvcFZhbGlkIGZyb20gXCJAZW1vdGlvbi9pcy1wcm9wLXZhbGlkXCI7XG5pbXBvcnQgdHlwZSB7IEJvcmRlclJhZGl1cywgTVEgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuXG50eXBlIENvbnRhaW5lclByaXZhdGVQcm9wcyA9IHtcbiAgYm9yZGVyOiBib29sZWFuO1xufTtcblxuZXhwb3J0IHR5cGUgQ29udGFpbmVyUHJvcHMgPSB7XG4gIGVsZXZhdGlvbj86IDAgfCAxIHwgMiB8IDMgfCA0O1xuICBib3JkZXJSYWRpdXM/OiBCb3JkZXJSYWRpdXMgfCBNUTxCb3JkZXJSYWRpdXM+O1xuICBvdmVyZmxvdz86IFwiYXV0b1wiIHwgXCJoaWRkZW5cIiB8IFwidmlzaWJsZVwiO1xuICBjaGlsZHJlbj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG4gIGlkPzogc3RyaW5nO1xuICAvLyBUT0RPIGJvcmRlciBpcyBnb25uYSBiZSBpbiBtYWluIHByb3BzXG4gIHByaXZhdGVQcm9wcz86IENvbnRhaW5lclByaXZhdGVQcm9wcztcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgaGFuZGxlRWxldmF0aW9uTGV2ZWwgPSAodGhlbWU6IFRoZW1lLCBlbGV2YXRpb246IG51bWJlcikgPT4ge1xuICAvKiBQYXJzaW5nIGVsZXZhdGlvbiBwcm9wZXJ0eSB0byBudW1iZXIgKi9cbiAgc3dpdGNoIChlbGV2YXRpb24gLSAwKSB7XG4gICAgY2FzZSAxOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bMV07XG4gICAgY2FzZSAyOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bMl07XG4gICAgY2FzZSAzOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bM107XG4gICAgY2FzZSA0OlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bNF07XG4gICAgY2FzZSAwOlxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gXCJcIjtcbiAgfVxufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkKFwiZGl2XCIsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IChwcm9wKSA9PlxuICAgIGlzUHJvcFZhbGlkKHByb3ApICYmXG4gICAgcHJvcCAhPT0gXCJlbGV2YXRpb25cIiAmJlxuICAgIHByb3AgIT09IFwiYm9yZGVyUmFkaXVzXCIgJiZcbiAgICBwcm9wICE9PSBcImJvcmRlclwiLFxufSk8UGFydGlhbDxDb250YWluZXJQcm9wcz4gJiBDb250YWluZXJQcml2YXRlUHJvcHM+KFxuICAoeyB0aGVtZSwgZWxldmF0aW9uLCBib3JkZXJSYWRpdXMsIHNxdWFyZUNvcm5lcnMsIGJvcmRlciB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgLi4uKGJvcmRlciAmJiB7XG4gICAgICBvdXRsaW5lOiBgMXB4IHNvbGlkICR7dGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5zZWNvbmRhcnkuZGVmYXVsdH1gLFxuICAgICAgb3V0bGluZU9mZnNldDogLTEsXG4gICAgfSksXG5cbiAgICAuLi4oc3F1YXJlQ29ybmVyc1xuICAgICAgPyB7XG4gICAgICAgICAgYm9yZGVyUmFkaXVzOiAwLFxuICAgICAgICB9XG4gICAgICA6IHVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgICAgIGJvcmRlclJhZGl1czogW2JvcmRlclJhZGl1cywgdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzXSxcbiAgICAgICAgfSkpLFxuXG4gICAgLy8gQm94IHNoYWRvdyBpcyBhcHBsaWVkIHRvIGEgcHNldWRvIGVsZW1lbnQgdG8gbWFrZSBzdXJlIGVsZXZhdGlvbiBpbnNldCBzaGFkb3cgaW4gZGFyayBtb2RlIGlzIG5vdCBoaWRkZW4gYnkgY29udGVudCBiYWNrZ3JvdW5kXG4gICAgXCI6YWZ0ZXJcIjoge1xuICAgICAgY29udGVudDogJ1wiIFwiJyxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICB0b3A6IDAsXG4gICAgICBsZWZ0OiAwLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgaGVpZ2h0OiBcIjEwMCVcIixcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICAgIGJveFNoYWRvdzogaGFuZGxlRWxldmF0aW9uTGV2ZWwodGhlbWUsIGVsZXZhdGlvbiksXG4gICAgfSxcbiAgfSlcbik7XG5cbmNvbnN0IFN0eWxlZERpdiA9IHN0eWxlZChcImRpdlwiLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT4gaXNQcm9wVmFsaWQocHJvcCkgJiYgcHJvcCAhPT0gXCJvdmVyZmxvd1wiLFxufSk8UGFydGlhbDxDb250YWluZXJQcm9wcz4+KCh7IG92ZXJmbG93IH0pID0+ICh7XG4gIGJvcmRlclJhZGl1czogXCJpbmhlcml0XCIsXG4gIG92ZXJmbG93LFxuICBoZWlnaHQ6IFwiMTAwJVwiLFxuXG4gIFwiJiA+ICo6bGFzdC1jaGlsZFwiOiB7XG4gICAgYm9yZGVyQm90dG9tTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgYm9yZGVyQm90dG9tUmlnaHRSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICB9LFxuICBcIiYgPiAqOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgIGJvcmRlclRvcExlZnRSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICAgIGJvcmRlclRvcFJpZ2h0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbnRhaW5lcih7XG4gIGNoaWxkcmVuLFxuICBlbGV2YXRpb24gPSAxLFxuICBib3JkZXJSYWRpdXMgPSBcIm1cIixcbiAgb3ZlcmZsb3csXG4gIHNxdWFyZUNvcm5lcnMgPSBmYWxzZSxcbiAgaWQsXG4gIHByaXZhdGVQcm9wcyA9IHsgYm9yZGVyOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkID0gXCJDb250YWluZXJcIixcbiAgLi4ucmVzdFxufTogQ29udGFpbmVyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IGJvcmRlciB9ID0gcHJpdmF0ZVByb3BzO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIHsuLi5yZXN0fVxuICAgICAgaWQ9e2lkfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9e2RhdGFEc0lkfVxuICAgICAgZWxldmF0aW9uPXtlbGV2YXRpb259XG4gICAgICBib3JkZXJSYWRpdXM9e2JvcmRlclJhZGl1c31cbiAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICBib3JkZXI9e2JvcmRlcn1cbiAgICA+XG4gICAgICA8U3R5bGVkRGl2IG92ZXJmbG93PXtvdmVyZmxvd30+e2NoaWxkcmVufTwvU3R5bGVkRGl2PlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBDd0IifQ== */"),StyledDiv=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"overflow"!==prop,target:"evpjmzq1",label:"StyledDiv"})(({overflow})=>({borderRadius:"inherit",overflow,height:"100%","& > *:last-child":{borderBottomLeftRadius:"inherit",borderBottomRightRadius:"inherit"},"& > *:first-of-type":{borderTopLeftRadius:"inherit",borderTopRightRadius:"inherit"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGFpbmVyL0NvbnRhaW5lci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0NvbnRhaW5lci9Db250YWluZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IGlzUHJvcFZhbGlkIGZyb20gXCJAZW1vdGlvbi9pcy1wcm9wLXZhbGlkXCI7XG5pbXBvcnQgdHlwZSB7IEJvcmRlclJhZGl1cywgTVEgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuXG50eXBlIENvbnRhaW5lclByaXZhdGVQcm9wcyA9IHtcbiAgYm9yZGVyOiBib29sZWFuO1xufTtcblxuZXhwb3J0IHR5cGUgQ29udGFpbmVyUHJvcHMgPSB7XG4gIGVsZXZhdGlvbj86IDAgfCAxIHwgMiB8IDMgfCA0O1xuICBib3JkZXJSYWRpdXM/OiBCb3JkZXJSYWRpdXMgfCBNUTxCb3JkZXJSYWRpdXM+O1xuICBvdmVyZmxvdz86IFwiYXV0b1wiIHwgXCJoaWRkZW5cIiB8IFwidmlzaWJsZVwiO1xuICBjaGlsZHJlbj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG4gIGlkPzogc3RyaW5nO1xuICAvLyBUT0RPIGJvcmRlciBpcyBnb25uYSBiZSBpbiBtYWluIHByb3BzXG4gIHByaXZhdGVQcm9wcz86IENvbnRhaW5lclByaXZhdGVQcm9wcztcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgaGFuZGxlRWxldmF0aW9uTGV2ZWwgPSAodGhlbWU6IFRoZW1lLCBlbGV2YXRpb246IG51bWJlcikgPT4ge1xuICAvKiBQYXJzaW5nIGVsZXZhdGlvbiBwcm9wZXJ0eSB0byBudW1iZXIgKi9cbiAgc3dpdGNoIChlbGV2YXRpb24gLSAwKSB7XG4gICAgY2FzZSAxOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bMV07XG4gICAgY2FzZSAyOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bMl07XG4gICAgY2FzZSAzOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bM107XG4gICAgY2FzZSA0OlxuICAgICAgcmV0dXJuIHRoZW1lLnZhbHVlcy5lbGV2YXRpb25bNF07XG4gICAgY2FzZSAwOlxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gXCJcIjtcbiAgfVxufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkKFwiZGl2XCIsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IChwcm9wKSA9PlxuICAgIGlzUHJvcFZhbGlkKHByb3ApICYmXG4gICAgcHJvcCAhPT0gXCJlbGV2YXRpb25cIiAmJlxuICAgIHByb3AgIT09IFwiYm9yZGVyUmFkaXVzXCIgJiZcbiAgICBwcm9wICE9PSBcImJvcmRlclwiLFxufSk8UGFydGlhbDxDb250YWluZXJQcm9wcz4gJiBDb250YWluZXJQcml2YXRlUHJvcHM+KFxuICAoeyB0aGVtZSwgZWxldmF0aW9uLCBib3JkZXJSYWRpdXMsIHNxdWFyZUNvcm5lcnMsIGJvcmRlciB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgLi4uKGJvcmRlciAmJiB7XG4gICAgICBvdXRsaW5lOiBgMXB4IHNvbGlkICR7dGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5zZWNvbmRhcnkuZGVmYXVsdH1gLFxuICAgICAgb3V0bGluZU9mZnNldDogLTEsXG4gICAgfSksXG5cbiAgICAuLi4oc3F1YXJlQ29ybmVyc1xuICAgICAgPyB7XG4gICAgICAgICAgYm9yZGVyUmFkaXVzOiAwLFxuICAgICAgICB9XG4gICAgICA6IHVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgICAgIGJvcmRlclJhZGl1czogW2JvcmRlclJhZGl1cywgdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzXSxcbiAgICAgICAgfSkpLFxuXG4gICAgLy8gQm94IHNoYWRvdyBpcyBhcHBsaWVkIHRvIGEgcHNldWRvIGVsZW1lbnQgdG8gbWFrZSBzdXJlIGVsZXZhdGlvbiBpbnNldCBzaGFkb3cgaW4gZGFyayBtb2RlIGlzIG5vdCBoaWRkZW4gYnkgY29udGVudCBiYWNrZ3JvdW5kXG4gICAgXCI6YWZ0ZXJcIjoge1xuICAgICAgY29udGVudDogJ1wiIFwiJyxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICB0b3A6IDAsXG4gICAgICBsZWZ0OiAwLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgaGVpZ2h0OiBcIjEwMCVcIixcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICAgIGJveFNoYWRvdzogaGFuZGxlRWxldmF0aW9uTGV2ZWwodGhlbWUsIGVsZXZhdGlvbiksXG4gICAgfSxcbiAgfSlcbik7XG5cbmNvbnN0IFN0eWxlZERpdiA9IHN0eWxlZChcImRpdlwiLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT4gaXNQcm9wVmFsaWQocHJvcCkgJiYgcHJvcCAhPT0gXCJvdmVyZmxvd1wiLFxufSk8UGFydGlhbDxDb250YWluZXJQcm9wcz4+KCh7IG92ZXJmbG93IH0pID0+ICh7XG4gIGJvcmRlclJhZGl1czogXCJpbmhlcml0XCIsXG4gIG92ZXJmbG93LFxuICBoZWlnaHQ6IFwiMTAwJVwiLFxuXG4gIFwiJiA+ICo6bGFzdC1jaGlsZFwiOiB7XG4gICAgYm9yZGVyQm90dG9tTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgYm9yZGVyQm90dG9tUmlnaHRSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICB9LFxuICBcIiYgPiAqOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgIGJvcmRlclRvcExlZnRSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICAgIGJvcmRlclRvcFJpZ2h0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbnRhaW5lcih7XG4gIGNoaWxkcmVuLFxuICBlbGV2YXRpb24gPSAxLFxuICBib3JkZXJSYWRpdXMgPSBcIm1cIixcbiAgb3ZlcmZsb3csXG4gIHNxdWFyZUNvcm5lcnMgPSBmYWxzZSxcbiAgaWQsXG4gIHByaXZhdGVQcm9wcyA9IHsgYm9yZGVyOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkID0gXCJDb250YWluZXJcIixcbiAgLi4ucmVzdFxufTogQ29udGFpbmVyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IGJvcmRlciB9ID0gcHJpdmF0ZVByb3BzO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIHsuLi5yZXN0fVxuICAgICAgaWQ9e2lkfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9e2RhdGFEc0lkfVxuICAgICAgZWxldmF0aW9uPXtlbGV2YXRpb259XG4gICAgICBib3JkZXJSYWRpdXM9e2JvcmRlclJhZGl1c31cbiAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICBib3JkZXI9e2JvcmRlcn1cbiAgICA+XG4gICAgICA8U3R5bGVkRGl2IG92ZXJmbG93PXtvdmVyZmxvd30+e2NoaWxkcmVufTwvU3R5bGVkRGl2PlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdGa0IifQ== */");function Container({children,elevation=1,borderRadius="m",overflow,squareCorners=!1,id,privateProps={border:!1},"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId="Container",...rest}){let{border}=privateProps;return _react.default.createElement(StyledContainer,{...rest,id:id,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,elevation:elevation,borderRadius:borderRadius,squareCorners:squareCorners,border:border},_react.default.createElement(StyledDiv,{overflow:overflow},children))}
@@ -8,8 +8,8 @@ export type DataTableProps = {
8
8
  layout?: "auto" | "fixed";
9
9
  /** Table width */
10
10
  width?: string | MQ<string>;
11
- /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */
12
- bodyCellVerticalPadding?: "s" | "m" | "l" | MQ<"s" | "m" | "l">;
11
+ /** Vertical padding on row cells to set table density, extra extra small (xxs), extra small (xs), condensed (s), default (m), comfortable (l) */
12
+ bodyCellVerticalPadding?: "xxs" | "xs" | "s" | "m" | "l" | MQ<"xxs" | "xs" | "s" | "m" | "l">;
13
13
  /** Height of empty/error or loading table content */
14
14
  emptyTableContentHeight?: string | MQ<string>;
15
15
  /** Footer element */
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get BaseDataTable(){return BaseDataTable},get DataTable(){return DataTable}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_TableBody=/*#__PURE__*/_interop_require_default._(require("./TableBody")),_TableHeader=/*#__PURE__*/_interop_require_default._(require("./header/TableHeader")),_Container=require("../Container/Container"),_ScreenReaderText=require("../Utilities/ScreenReaderText/ScreenReaderText"),_mediaQueries=require("../../shared/mediaQueries"),_useDataTableSort=require("./useDataTableSort"),_constants=require("./constants");function getTableScrolledToRight(elm){let elmRect=elm.getBoundingClientRect();return elm.scrollLeft+elmRect.width>=elm.scrollWidth}const TableContainer=(0,_styled.default)("div",{target:"eenr0140",label:"TableContainer"})(({theme,footer,maxHeight})=>({position:"relative",zIndex:0,overflow:"auto",backgroundColor:theme.values.color.background.primary.default,borderRadius:"inherit",...(0,_mediaQueries.useResponsiveValue)({maxHeight}),...footer&&{borderBottomLeftRadius:0,borderBottomRightRadius:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import type { UIEventHandler } from \"react\";\nimport React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./header/TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport { ScreenReaderText } from \"../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\nimport { defaultSortCompareFn } from \"./useDataTableSort\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   * @param DataTableRow[].id - Unique id\n   * @param DataTableRow[].isSelectable - Whether row can be selected\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /** Renders selectable rows */\n  isSelectable?: boolean;\n\n  /** Array of selected row ids */\n  selectedRowIds?: DataTableRow[\"id\"][];\n\n  /** Indicates that all rows are selected */\n  allRowsSelected?: boolean;\n\n  selectAllRowsCheckboxAriaLabel?: string;\n\n  /** Callback to handle selection change */\n  onRowSelectionChange?: (selectedRowIds: DataTableRow[\"id\"][]) => void;\n\n  /** Callback to handle all rows selection change */\n  onAllRowsSelectionChange?: (allRowsSelected: boolean) => void;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n\n  /** Customize row  */\n  getRowProps?: (row: DataTableRow) => DataTableRowProps;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    position: \"relative\",\n    zIndex: 0, // create a stacking context for sticky headers\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...useResponsiveValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...useResponsiveValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  isSelectable,\n  selectedRowIds = [],\n  allRowsSelected,\n  selectAllRowsCheckboxAriaLabel = \"Select all rows\",\n  getRowProps = () => ({} as DataTableRowProps),\n  onRowSelectionChange,\n  onAllRowsSelectionChange,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n  const internalColumns = isSelectable\n    ? [CHECKBOX_COLUMN as DataTableColumn, ...columns]\n    : columns;\n\n  const handleScroll = useCallback<UIEventHandler<HTMLDivElement>>((evt) => {\n    const elm = evt.target as HTMLDivElement;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          if (containerRef && containerRef.current) {\n            setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n            setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n          }\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={internalColumns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            allRowsSelected={allRowsSelected}\n            selectedRowIds={selectedRowIds}\n            onAllRowsSelectionChange={onAllRowsSelectionChange}\n            selectAllRowsCheckboxAriaLabel={selectAllRowsCheckboxAriaLabel}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={internalColumns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n            selectedRowIds={selectedRowIds}\n            onRowSelectionChange={onRowSelectionChange}\n            getRowProps={getRowProps}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n/* eslint-disable  react/jsx-props-no-spreading */\nexport function DataTable({\n  children,\n  ...rest\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable {...rest}>{children}</BaseDataTable>\n    </Container>\n  );\n}\n/* eslint-enable  react/jsx-props-no-spreading */\n\nDataTable.sortCompareFn = defaultSortCompareFn;\n"],"names":[],"mappings":"AA2HuB"} */"),StyledTable=(0,_styled.default)("table",{target:"eenr0141",label:"StyledTable"})(({layout,tableWidth})=>({borderSpacing:0,tableLayout:layout,...(0,_mediaQueries.useResponsiveValue)({width:tableWidth})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import type { UIEventHandler } from \"react\";\nimport React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./header/TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport { ScreenReaderText } from \"../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\nimport { defaultSortCompareFn } from \"./useDataTableSort\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   * @param DataTableRow[].id - Unique id\n   * @param DataTableRow[].isSelectable - Whether row can be selected\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /** Renders selectable rows */\n  isSelectable?: boolean;\n\n  /** Array of selected row ids */\n  selectedRowIds?: DataTableRow[\"id\"][];\n\n  /** Indicates that all rows are selected */\n  allRowsSelected?: boolean;\n\n  selectAllRowsCheckboxAriaLabel?: string;\n\n  /** Callback to handle selection change */\n  onRowSelectionChange?: (selectedRowIds: DataTableRow[\"id\"][]) => void;\n\n  /** Callback to handle all rows selection change */\n  onAllRowsSelectionChange?: (allRowsSelected: boolean) => void;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n\n  /** Customize row  */\n  getRowProps?: (row: DataTableRow) => DataTableRowProps;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    position: \"relative\",\n    zIndex: 0, // create a stacking context for sticky headers\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...useResponsiveValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...useResponsiveValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  isSelectable,\n  selectedRowIds = [],\n  allRowsSelected,\n  selectAllRowsCheckboxAriaLabel = \"Select all rows\",\n  getRowProps = () => ({} as DataTableRowProps),\n  onRowSelectionChange,\n  onAllRowsSelectionChange,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n  const internalColumns = isSelectable\n    ? [CHECKBOX_COLUMN as DataTableColumn, ...columns]\n    : columns;\n\n  const handleScroll = useCallback<UIEventHandler<HTMLDivElement>>((evt) => {\n    const elm = evt.target as HTMLDivElement;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          if (containerRef && containerRef.current) {\n            setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n            setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n          }\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={internalColumns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            allRowsSelected={allRowsSelected}\n            selectedRowIds={selectedRowIds}\n            onAllRowsSelectionChange={onAllRowsSelectionChange}\n            selectAllRowsCheckboxAriaLabel={selectAllRowsCheckboxAriaLabel}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={internalColumns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n            selectedRowIds={selectedRowIds}\n            onRowSelectionChange={onRowSelectionChange}\n            getRowProps={getRowProps}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n/* eslint-disable  react/jsx-props-no-spreading */\nexport function DataTable({\n  children,\n  ...rest\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable {...rest}>{children}</BaseDataTable>\n    </Container>\n  );\n}\n/* eslint-enable  react/jsx-props-no-spreading */\n\nDataTable.sortCompareFn = defaultSortCompareFn;\n"],"names":[],"mappings":"AAkJoB"} */"),StyledFooter=(0,_styled.default)("div",{target:"eenr0142",label:"StyledFooter"})(({theme})=>({padding:theme.variables.size.spacing.xs,backgroundColor:theme.values.color.background.primary.default,borderBottomLeftRadius:"inherit",borderBottomRightRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import type { UIEventHandler } from \"react\";\nimport React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./header/TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport { ScreenReaderText } from \"../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\nimport { defaultSortCompareFn } from \"./useDataTableSort\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   * @param DataTableRow[].id - Unique id\n   * @param DataTableRow[].isSelectable - Whether row can be selected\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /** Renders selectable rows */\n  isSelectable?: boolean;\n\n  /** Array of selected row ids */\n  selectedRowIds?: DataTableRow[\"id\"][];\n\n  /** Indicates that all rows are selected */\n  allRowsSelected?: boolean;\n\n  selectAllRowsCheckboxAriaLabel?: string;\n\n  /** Callback to handle selection change */\n  onRowSelectionChange?: (selectedRowIds: DataTableRow[\"id\"][]) => void;\n\n  /** Callback to handle all rows selection change */\n  onAllRowsSelectionChange?: (allRowsSelected: boolean) => void;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n\n  /** Customize row  */\n  getRowProps?: (row: DataTableRow) => DataTableRowProps;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    position: \"relative\",\n    zIndex: 0, // create a stacking context for sticky headers\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...useResponsiveValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...useResponsiveValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  isSelectable,\n  selectedRowIds = [],\n  allRowsSelected,\n  selectAllRowsCheckboxAriaLabel = \"Select all rows\",\n  getRowProps = () => ({} as DataTableRowProps),\n  onRowSelectionChange,\n  onAllRowsSelectionChange,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n  const internalColumns = isSelectable\n    ? [CHECKBOX_COLUMN as DataTableColumn, ...columns]\n    : columns;\n\n  const handleScroll = useCallback<UIEventHandler<HTMLDivElement>>((evt) => {\n    const elm = evt.target as HTMLDivElement;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          if (containerRef && containerRef.current) {\n            setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n            setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n          }\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={internalColumns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            allRowsSelected={allRowsSelected}\n            selectedRowIds={selectedRowIds}\n            onAllRowsSelectionChange={onAllRowsSelectionChange}\n            selectAllRowsCheckboxAriaLabel={selectAllRowsCheckboxAriaLabel}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={internalColumns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n            selectedRowIds={selectedRowIds}\n            onRowSelectionChange={onRowSelectionChange}\n            getRowProps={getRowProps}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n/* eslint-disable  react/jsx-props-no-spreading */\nexport function DataTable({\n  children,\n  ...rest\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable {...rest}>{children}</BaseDataTable>\n    </Container>\n  );\n}\n/* eslint-enable  react/jsx-props-no-spreading */\n\nDataTable.sortCompareFn = defaultSortCompareFn;\n"],"names":[],"mappings":"AA4JqB"} */");function BaseDataTable({caption,columns,rows=[],footer,currentlySortedByColumn,isFirstColumnSticky=!0,isLastColumnSticky=!1,"data-e2e-test-id":dataE2eTestId,isLoading=!1,loadingStateScreenReaderText="Loading",isEmpty=!1,children,emptyTableContentHeight="15rem",layout="auto",width="100%",bodyCellVerticalPadding="m",emptyCellContent="--",maxHeight,isSelectable,selectedRowIds=[],allRowsSelected,selectAllRowsCheckboxAriaLabel="Select all rows",getRowProps=()=>({}),onRowSelectionChange,onAllRowsSelectionChange,onSort}){let[isScrolledToRight,setIsScrolledToRight]=(0,_react.useState)(isLastColumnSticky),[isScrolledToLeft,setIsScrolledToLeft]=(0,_react.useState)(isFirstColumnSticky),tableRef=(0,_react.useRef)(null),containerRef=(0,_react.useRef)(null),internalColumns=isSelectable?[_constants.CHECKBOX_COLUMN,...columns]:columns,handleScroll=(0,_react.useCallback)(evt=>{let elm=evt.target;setIsScrolledToLeft(0===elm.scrollLeft),setIsScrolledToRight(getTableScrolledToRight(elm))},[]);(0,_react.useEffect)(()=>{let resizeObserver;return"undefined"!=typeof ResizeObserver&&containerRef&&containerRef.current&&(resizeObserver=new ResizeObserver(entries=>{entries.forEach(()=>{containerRef&&containerRef.current&&(setIsScrolledToLeft(0===containerRef.current.scrollLeft),setIsScrolledToRight(getTableScrolledToRight(containerRef.current)))})})).observe(containerRef.current),()=>{resizeObserver&&resizeObserver.disconnect()}},[containerRef]);let footerElm=footer?_react.default.createElement(StyledFooter,null,footer):null;return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(TableContainer,{ref:containerRef,footer:footer,maxHeight:maxHeight,onScroll:handleScroll},_react.default.createElement(StyledTable,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"DataTable",ref:tableRef,layout:layout,tableWidth:width},_react.default.createElement(_ScreenReaderText.ScreenReaderText,{as:"caption"},caption),_react.default.createElement(_TableHeader.default,{columns:internalColumns,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,currentlySortedByColumn:currentlySortedByColumn,isTableScrolledToLeft:isScrolledToLeft,isTableScrolledToRight:isScrolledToRight,maxHeight:maxHeight,allRowsSelected:allRowsSelected,selectedRowIds:selectedRowIds,onAllRowsSelectionChange:onAllRowsSelectionChange,selectAllRowsCheckboxAriaLabel:selectAllRowsCheckboxAriaLabel,onSort:onSort}),_react.default.createElement(_TableBody.default,{columns:internalColumns,rows:rows,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolledToLeft:isScrolledToLeft,isTableScrolledToRight:isScrolledToRight,isEmpty:isEmpty,isLoading:isLoading,loadingStateScreenReaderText:loadingStateScreenReaderText,emptyTableContentHeight:emptyTableContentHeight,footer:footer,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,emptyCellContent:emptyCellContent,selectedRowIds:selectedRowIds,onRowSelectionChange:onRowSelectionChange,getRowProps:getRowProps},children))),footerElm)}function DataTable({children,...rest}){return _react.default.createElement(_Container.Container,{elevation:1},_react.default.createElement(BaseDataTable,rest,children))}DataTable.sortCompareFn=_useDataTableSort.defaultSortCompareFn;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get BaseDataTable(){return BaseDataTable},get DataTable(){return DataTable}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_TableBody=/*#__PURE__*/_interop_require_default._(require("./TableBody")),_TableHeader=/*#__PURE__*/_interop_require_default._(require("./header/TableHeader")),_Container=require("../Container/Container"),_ScreenReaderText=require("../Utilities/ScreenReaderText/ScreenReaderText"),_mediaQueries=require("../../shared/mediaQueries"),_useDataTableSort=require("./useDataTableSort"),_constants=require("./constants");function getTableScrolledToRight(elm){let elmRect=elm.getBoundingClientRect();return elm.scrollLeft+elmRect.width>=elm.scrollWidth}const TableContainer=(0,_styled.default)("div",{target:"e1595ok10",label:"TableContainer"})(({theme,footer,maxHeight})=>({position:"relative",zIndex:0,overflow:"auto",backgroundColor:theme.values.color.background.primary.default,borderRadius:"inherit",...(0,_mediaQueries.useResponsiveValue)({maxHeight}),...footer&&{borderBottomLeftRadius:0,borderBottomRightRadius:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import type { UIEventHandler } from \"react\";\nimport React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./header/TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport { ScreenReaderText } from \"../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\nimport { defaultSortCompareFn } from \"./useDataTableSort\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, extra extra small (xxs), extra small (xs), condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?:\n    | \"xxs\"\n    | \"xs\"\n    | \"s\"\n    | \"m\"\n    | \"l\"\n    | MQ<\"xxs\" | \"xs\" | \"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   * @param DataTableRow[].id - Unique id\n   * @param DataTableRow[].isSelectable - Whether row can be selected\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /** Renders selectable rows */\n  isSelectable?: boolean;\n\n  /** Array of selected row ids */\n  selectedRowIds?: DataTableRow[\"id\"][];\n\n  /** Indicates that all rows are selected */\n  allRowsSelected?: boolean;\n\n  selectAllRowsCheckboxAriaLabel?: string;\n\n  /** Callback to handle selection change */\n  onRowSelectionChange?: (selectedRowIds: DataTableRow[\"id\"][]) => void;\n\n  /** Callback to handle all rows selection change */\n  onAllRowsSelectionChange?: (allRowsSelected: boolean) => void;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n\n  /** Customize row  */\n  getRowProps?: (row: DataTableRow) => DataTableRowProps;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    position: \"relative\",\n    zIndex: 0, // create a stacking context for sticky headers\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...useResponsiveValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...useResponsiveValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  isSelectable,\n  selectedRowIds = [],\n  allRowsSelected,\n  selectAllRowsCheckboxAriaLabel = \"Select all rows\",\n  getRowProps = () => ({} as DataTableRowProps),\n  onRowSelectionChange,\n  onAllRowsSelectionChange,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n  const internalColumns = isSelectable\n    ? [CHECKBOX_COLUMN as DataTableColumn, ...columns]\n    : columns;\n\n  const handleScroll = useCallback<UIEventHandler<HTMLDivElement>>((evt) => {\n    const elm = evt.target as HTMLDivElement;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          if (containerRef && containerRef.current) {\n            setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n            setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n          }\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={internalColumns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            allRowsSelected={allRowsSelected}\n            selectedRowIds={selectedRowIds}\n            onAllRowsSelectionChange={onAllRowsSelectionChange}\n            selectAllRowsCheckboxAriaLabel={selectAllRowsCheckboxAriaLabel}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={internalColumns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n            selectedRowIds={selectedRowIds}\n            onRowSelectionChange={onRowSelectionChange}\n            getRowProps={getRowProps}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n/* eslint-disable  react/jsx-props-no-spreading */\nexport function DataTable({\n  children,\n  ...rest\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable {...rest}>{children}</BaseDataTable>\n    </Container>\n  );\n}\n/* eslint-enable  react/jsx-props-no-spreading */\n\nDataTable.sortCompareFn = defaultSortCompareFn;\n"],"names":[],"mappings":"AAiIuB"} */"),StyledTable=(0,_styled.default)("table",{target:"e1595ok11",label:"StyledTable"})(({layout,tableWidth})=>({borderSpacing:0,tableLayout:layout,...(0,_mediaQueries.useResponsiveValue)({width:tableWidth})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import type { UIEventHandler } from \"react\";\nimport React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./header/TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport { ScreenReaderText } from \"../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\nimport { defaultSortCompareFn } from \"./useDataTableSort\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, extra extra small (xxs), extra small (xs), condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?:\n    | \"xxs\"\n    | \"xs\"\n    | \"s\"\n    | \"m\"\n    | \"l\"\n    | MQ<\"xxs\" | \"xs\" | \"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   * @param DataTableRow[].id - Unique id\n   * @param DataTableRow[].isSelectable - Whether row can be selected\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /** Renders selectable rows */\n  isSelectable?: boolean;\n\n  /** Array of selected row ids */\n  selectedRowIds?: DataTableRow[\"id\"][];\n\n  /** Indicates that all rows are selected */\n  allRowsSelected?: boolean;\n\n  selectAllRowsCheckboxAriaLabel?: string;\n\n  /** Callback to handle selection change */\n  onRowSelectionChange?: (selectedRowIds: DataTableRow[\"id\"][]) => void;\n\n  /** Callback to handle all rows selection change */\n  onAllRowsSelectionChange?: (allRowsSelected: boolean) => void;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n\n  /** Customize row  */\n  getRowProps?: (row: DataTableRow) => DataTableRowProps;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    position: \"relative\",\n    zIndex: 0, // create a stacking context for sticky headers\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...useResponsiveValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...useResponsiveValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  isSelectable,\n  selectedRowIds = [],\n  allRowsSelected,\n  selectAllRowsCheckboxAriaLabel = \"Select all rows\",\n  getRowProps = () => ({} as DataTableRowProps),\n  onRowSelectionChange,\n  onAllRowsSelectionChange,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n  const internalColumns = isSelectable\n    ? [CHECKBOX_COLUMN as DataTableColumn, ...columns]\n    : columns;\n\n  const handleScroll = useCallback<UIEventHandler<HTMLDivElement>>((evt) => {\n    const elm = evt.target as HTMLDivElement;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          if (containerRef && containerRef.current) {\n            setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n            setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n          }\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={internalColumns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            allRowsSelected={allRowsSelected}\n            selectedRowIds={selectedRowIds}\n            onAllRowsSelectionChange={onAllRowsSelectionChange}\n            selectAllRowsCheckboxAriaLabel={selectAllRowsCheckboxAriaLabel}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={internalColumns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n            selectedRowIds={selectedRowIds}\n            onRowSelectionChange={onRowSelectionChange}\n            getRowProps={getRowProps}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n/* eslint-disable  react/jsx-props-no-spreading */\nexport function DataTable({\n  children,\n  ...rest\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable {...rest}>{children}</BaseDataTable>\n    </Container>\n  );\n}\n/* eslint-enable  react/jsx-props-no-spreading */\n\nDataTable.sortCompareFn = defaultSortCompareFn;\n"],"names":[],"mappings":"AAwJoB"} */"),StyledFooter=(0,_styled.default)("div",{target:"e1595ok12",label:"StyledFooter"})(({theme})=>({padding:theme.variables.size.spacing.xs,backgroundColor:theme.values.color.background.primary.default,borderBottomLeftRadius:"inherit",borderBottomRightRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import type { UIEventHandler } from \"react\";\nimport React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./header/TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport { ScreenReaderText } from \"../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\nimport { defaultSortCompareFn } from \"./useDataTableSort\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, extra extra small (xxs), extra small (xs), condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?:\n    | \"xxs\"\n    | \"xs\"\n    | \"s\"\n    | \"m\"\n    | \"l\"\n    | MQ<\"xxs\" | \"xs\" | \"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   * @param DataTableRow[].id - Unique id\n   * @param DataTableRow[].isSelectable - Whether row can be selected\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /** Renders selectable rows */\n  isSelectable?: boolean;\n\n  /** Array of selected row ids */\n  selectedRowIds?: DataTableRow[\"id\"][];\n\n  /** Indicates that all rows are selected */\n  allRowsSelected?: boolean;\n\n  selectAllRowsCheckboxAriaLabel?: string;\n\n  /** Callback to handle selection change */\n  onRowSelectionChange?: (selectedRowIds: DataTableRow[\"id\"][]) => void;\n\n  /** Callback to handle all rows selection change */\n  onAllRowsSelectionChange?: (allRowsSelected: boolean) => void;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n\n  /** Customize row  */\n  getRowProps?: (row: DataTableRow) => DataTableRowProps;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    position: \"relative\",\n    zIndex: 0, // create a stacking context for sticky headers\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...useResponsiveValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...useResponsiveValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  isSelectable,\n  selectedRowIds = [],\n  allRowsSelected,\n  selectAllRowsCheckboxAriaLabel = \"Select all rows\",\n  getRowProps = () => ({} as DataTableRowProps),\n  onRowSelectionChange,\n  onAllRowsSelectionChange,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n  const internalColumns = isSelectable\n    ? [CHECKBOX_COLUMN as DataTableColumn, ...columns]\n    : columns;\n\n  const handleScroll = useCallback<UIEventHandler<HTMLDivElement>>((evt) => {\n    const elm = evt.target as HTMLDivElement;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          if (containerRef && containerRef.current) {\n            setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n            setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n          }\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={internalColumns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            allRowsSelected={allRowsSelected}\n            selectedRowIds={selectedRowIds}\n            onAllRowsSelectionChange={onAllRowsSelectionChange}\n            selectAllRowsCheckboxAriaLabel={selectAllRowsCheckboxAriaLabel}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={internalColumns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n            selectedRowIds={selectedRowIds}\n            onRowSelectionChange={onRowSelectionChange}\n            getRowProps={getRowProps}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n/* eslint-disable  react/jsx-props-no-spreading */\nexport function DataTable({\n  children,\n  ...rest\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable {...rest}>{children}</BaseDataTable>\n    </Container>\n  );\n}\n/* eslint-enable  react/jsx-props-no-spreading */\n\nDataTable.sortCompareFn = defaultSortCompareFn;\n"],"names":[],"mappings":"AAkKqB"} */");function BaseDataTable({caption,columns,rows=[],footer,currentlySortedByColumn,isFirstColumnSticky=!0,isLastColumnSticky=!1,"data-e2e-test-id":dataE2eTestId,isLoading=!1,loadingStateScreenReaderText="Loading",isEmpty=!1,children,emptyTableContentHeight="15rem",layout="auto",width="100%",bodyCellVerticalPadding="m",emptyCellContent="--",maxHeight,isSelectable,selectedRowIds=[],allRowsSelected,selectAllRowsCheckboxAriaLabel="Select all rows",getRowProps=()=>({}),onRowSelectionChange,onAllRowsSelectionChange,onSort}){let[isScrolledToRight,setIsScrolledToRight]=(0,_react.useState)(isLastColumnSticky),[isScrolledToLeft,setIsScrolledToLeft]=(0,_react.useState)(isFirstColumnSticky),tableRef=(0,_react.useRef)(null),containerRef=(0,_react.useRef)(null),internalColumns=isSelectable?[_constants.CHECKBOX_COLUMN,...columns]:columns,handleScroll=(0,_react.useCallback)(evt=>{let elm=evt.target;setIsScrolledToLeft(0===elm.scrollLeft),setIsScrolledToRight(getTableScrolledToRight(elm))},[]);(0,_react.useEffect)(()=>{let resizeObserver;return"undefined"!=typeof ResizeObserver&&containerRef&&containerRef.current&&(resizeObserver=new ResizeObserver(entries=>{entries.forEach(()=>{containerRef&&containerRef.current&&(setIsScrolledToLeft(0===containerRef.current.scrollLeft),setIsScrolledToRight(getTableScrolledToRight(containerRef.current)))})})).observe(containerRef.current),()=>{resizeObserver&&resizeObserver.disconnect()}},[containerRef]);let footerElm=footer?_react.default.createElement(StyledFooter,null,footer):null;return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(TableContainer,{ref:containerRef,footer:footer,maxHeight:maxHeight,onScroll:handleScroll},_react.default.createElement(StyledTable,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"DataTable",ref:tableRef,layout:layout,tableWidth:width},_react.default.createElement(_ScreenReaderText.ScreenReaderText,{as:"caption"},caption),_react.default.createElement(_TableHeader.default,{columns:internalColumns,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,currentlySortedByColumn:currentlySortedByColumn,isTableScrolledToLeft:isScrolledToLeft,isTableScrolledToRight:isScrolledToRight,maxHeight:maxHeight,allRowsSelected:allRowsSelected,selectedRowIds:selectedRowIds,onAllRowsSelectionChange:onAllRowsSelectionChange,selectAllRowsCheckboxAriaLabel:selectAllRowsCheckboxAriaLabel,onSort:onSort}),_react.default.createElement(_TableBody.default,{columns:internalColumns,rows:rows,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolledToLeft:isScrolledToLeft,isTableScrolledToRight:isScrolledToRight,isEmpty:isEmpty,isLoading:isLoading,loadingStateScreenReaderText:loadingStateScreenReaderText,emptyTableContentHeight:emptyTableContentHeight,footer:footer,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,emptyCellContent:emptyCellContent,selectedRowIds:selectedRowIds,onRowSelectionChange:onRowSelectionChange,getRowProps:getRowProps},children))),footerElm)}function DataTable({children,...rest}){return _react.default.createElement(_Container.Container,{elevation:1},_react.default.createElement(BaseDataTable,rest,children))}DataTable.sortCompareFn=_useDataTableSort.defaultSortCompareFn;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return _default}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_TableCell=/*#__PURE__*/_interop_require_default._(require("./TableCell")),_Text=require("../Typography/Text/Text"),_LoadingSpinner=require("../LoadingSpinner/LoadingSpinner"),_mediaQueries=require("../../shared/mediaQueries"),_Checkbox=require("../Form/Checkbox/Checkbox"),_constants=require("./constants"),StyledTr=(0,_styled.default)("tr",{target:"e6k8n1r0",label:"StyledTr"})(({theme,footer,isSelected,verticalAlign})=>({...!isSelected&&{"&:hover td":{backgroundColor:theme.values.color.background.secondary.default}},verticalAlign,...!footer&&{"&:last-of-type":{td:{borderBottom:"none"}}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AA2CiB"} */"),StyledText=(0,_styled.default)(_Text.Text,{target:"e6k8n1r1",label:"StyledText"})(({alignColumn})=>({...(0,_mediaQueries.useResponsiveValue)({textAlign:alignColumn})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AAmEmB"} */"),StyledTd=(0,_styled.default)(_TableCell.default,{target:"e6k8n1r2",label:"StyledTd"})(({theme,bodyCellVerticalPadding})=>({...(0,_mediaQueries.useResponsiveStyles)({padding:[bodyCellVerticalPadding,{s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,m:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,l:`${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`}]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AA+EiB"} */"),StyledEmptyTd=(0,_styled.default)("td",{target:"e6k8n1r3",label:"StyledEmptyTd"})(({emptyTableContentHeight})=>({textAlign:"center",...(0,_mediaQueries.useResponsiveValue)({height:emptyTableContentHeight})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AAuGsB"} */");function EmptyTableBody({children,columns,emptyTableContentHeight}){return _react.default.createElement("tbody",null,_react.default.createElement("tr",null,_react.default.createElement(StyledEmptyTd,{colSpan:columns.length,emptyTableContentHeight:emptyTableContentHeight},children)))}function CheckboxColumnCellContent({selectRowCheckboxAriaLabel,selectedRowIds,onRowSelectionChange,id,isSelectable}){return _react.default.createElement(_Checkbox.Checkbox,{size:"s","aria-label":selectRowCheckboxAriaLabel,checked:selectedRowIds.includes(id),disabled:!isSelectable,onChange:evt=>{evt.target.checked?onRowSelectionChange([...selectedRowIds,id]):onRowSelectionChange(selectedRowIds.filter(item=>item!==id))}})}const _default=_react.default.memo(function({className,columns,rows=[],bodyCellVerticalPadding,isTableScrolledToLeft,isTableScrolledToRight,isLoading,loadingStateScreenReaderText="Loading",isEmpty,emptyTableContentHeight,footer,children,isFirstColumnSticky,isLastColumnSticky,emptyCellContent,selectedRowIds,onRowSelectionChange,getRowProps}){if(isLoading){let bodyContent=children&&_react.default.createElement(_react.default.Fragment,null,children)||_react.default.createElement(_LoadingSpinner.LoadingSpinner,{screenReaderText:loadingStateScreenReaderText});return _react.default.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},bodyContent)}if(isEmpty)return _react.default.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},_react.default.createElement(_react.default.Fragment,null,children));let rowElements=rows.map(row=>{let{verticalAlign=null,isActive=!1,isSelectable=!0,selectRowCheckboxAriaLabel=`Select row${row.id}`}=getRowProps?.(row)||{},isSelected=selectedRowIds.includes(row.id);return _react.default.createElement(StyledTr,{key:row.id,footer:footer,verticalAlign:verticalAlign,isSelected:isSelected},columns.map(({name,align="left",renderCell})=>{let content;return content=renderCell?renderCell(row):name===_constants.CHECKBOX_COLUMN.name?_react.default.createElement(CheckboxColumnCellContent,{selectRowCheckboxAriaLabel:selectRowCheckboxAriaLabel,selectedRowIds:selectedRowIds,onRowSelectionChange:onRowSelectionChange,id:row.id,isSelectable:isSelectable}):_react.default.createElement(StyledText,{size:"s",alignColumn:align},row[name]?row[name]:emptyCellContent),_react.default.createElement(StyledTd,{key:name,alignColumn:align,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolledToLeft:isTableScrolledToLeft,isTableScrolledToRight:isTableScrolledToRight,isActive:isActive,isSelected:isSelected},content)}))});return _react.default.createElement("tbody",{className:className},rowElements)});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return _default}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_TableCell=/*#__PURE__*/_interop_require_default._(require("./TableCell")),_Text=require("../Typography/Text/Text"),_LoadingSpinner=require("../LoadingSpinner/LoadingSpinner"),_mediaQueries=require("../../shared/mediaQueries"),_Checkbox=require("../Form/Checkbox/Checkbox"),_constants=require("./constants"),StyledTr=(0,_styled.default)("tr",{target:"efoata0",label:"StyledTr"})(({theme,footer,isSelected,verticalAlign})=>({...!isSelected&&{"&:hover td":{backgroundColor:theme.values.color.background.secondary.default}},verticalAlign,...!footer&&{"&:last-of-type":{td:{borderBottom:"none"}}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          xxs: `${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,\n          xs: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AA2CiB"} */"),StyledText=(0,_styled.default)(_Text.Text,{target:"efoata1",label:"StyledText"})(({alignColumn})=>({...(0,_mediaQueries.useResponsiveValue)({textAlign:alignColumn})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          xxs: `${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,\n          xs: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AAmEmB"} */"),StyledTd=(0,_styled.default)(_TableCell.default,{target:"efoata2",label:"StyledTd"})(({theme,bodyCellVerticalPadding})=>({...(0,_mediaQueries.useResponsiveStyles)({padding:[bodyCellVerticalPadding,{xxs:`${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,xs:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,m:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,l:`${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`}]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          xxs: `${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,\n          xs: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AA+EiB"} */"),StyledEmptyTd=(0,_styled.default)("td",{target:"efoata3",label:"StyledEmptyTd"})(({emptyTableContentHeight})=>({textAlign:"center",...(0,_mediaQueries.useResponsiveValue)({height:emptyTableContentHeight})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          xxs: `${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,\n          xs: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AAyGsB"} */");function EmptyTableBody({children,columns,emptyTableContentHeight}){return _react.default.createElement("tbody",null,_react.default.createElement("tr",null,_react.default.createElement(StyledEmptyTd,{colSpan:columns.length,emptyTableContentHeight:emptyTableContentHeight},children)))}function CheckboxColumnCellContent({selectRowCheckboxAriaLabel,selectedRowIds,onRowSelectionChange,id,isSelectable}){return _react.default.createElement(_Checkbox.Checkbox,{size:"s","aria-label":selectRowCheckboxAriaLabel,checked:selectedRowIds.includes(id),disabled:!isSelectable,onChange:evt=>{evt.target.checked?onRowSelectionChange([...selectedRowIds,id]):onRowSelectionChange(selectedRowIds.filter(item=>item!==id))}})}const _default=_react.default.memo(function({className,columns,rows=[],bodyCellVerticalPadding,isTableScrolledToLeft,isTableScrolledToRight,isLoading,loadingStateScreenReaderText="Loading",isEmpty,emptyTableContentHeight,footer,children,isFirstColumnSticky,isLastColumnSticky,emptyCellContent,selectedRowIds,onRowSelectionChange,getRowProps}){if(isLoading){let bodyContent=children&&_react.default.createElement(_react.default.Fragment,null,children)||_react.default.createElement(_LoadingSpinner.LoadingSpinner,{screenReaderText:loadingStateScreenReaderText});return _react.default.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},bodyContent)}if(isEmpty)return _react.default.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},_react.default.createElement(_react.default.Fragment,null,children));let rowElements=rows.map(row=>{let{verticalAlign=null,isActive=!1,isSelectable=!0,selectRowCheckboxAriaLabel=`Select row${row.id}`}=getRowProps?.(row)||{},isSelected=selectedRowIds.includes(row.id);return _react.default.createElement(StyledTr,{key:row.id,footer:footer,verticalAlign:verticalAlign,isSelected:isSelected},columns.map(({name,align="left",renderCell})=>{let content;return content=renderCell?renderCell(row):name===_constants.CHECKBOX_COLUMN.name?_react.default.createElement(CheckboxColumnCellContent,{selectRowCheckboxAriaLabel:selectRowCheckboxAriaLabel,selectedRowIds:selectedRowIds,onRowSelectionChange:onRowSelectionChange,id:row.id,isSelectable:isSelectable}):_react.default.createElement(StyledText,{size:"s",alignColumn:align},row[name]?row[name]:emptyCellContent),_react.default.createElement(StyledTd,{key:name,alignColumn:align,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolledToLeft:isTableScrolledToLeft,isTableScrolledToRight:isTableScrolledToRight,isActive:isActive,isSelected:isSelected},content)}))});return _react.default.createElement("tbody",{className:className},rowElements)});