@amboss/design-system 3.8.4-react19 → 3.8.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/BinaryFeedback/BinaryFeedbackOption.js +1 -1
- package/build/cjs/components/Column/Columns.js +1 -1
- package/build/cjs/components/Form/Checkbox/Checkbox.d.ts +2 -2
- package/build/cjs/components/Form/FormFieldGroup/FormFieldGroup.js +1 -1
- package/build/cjs/components/Form/MaskedInput/MaskedInput.d.ts +1 -1
- package/build/cjs/components/Form/MaskedInput/MaskedInput.js +1 -1
- package/build/cjs/components/Form/Radio/Radio.d.ts +2 -2
- package/build/cjs/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
- package/build/cjs/components/Form/Toggle/Toggle.d.ts +2 -2
- package/build/cjs/components/SegmentedProgressBar/SegmentedProgressBar.d.ts +0 -1
- package/build/cjs/components/SegmentedProgressBar/SegmentedProgressBar.js +1 -1
- package/build/cjs/components/ShadowWebComponent/ShadowWebComponent.d.ts +9 -0
- package/build/cjs/components/ShadowWebComponent/ShadowWebComponent.js +1 -1
- package/build/cjs/components/TagGroup/TagGroup.js +1 -1
- package/build/cjs/components/Toggletip/BasePopover.d.ts +3 -13
- package/build/cjs/components/Toggletip/BasePopover.js +1 -1
- package/build/cjs/components/Tooltip/BaseTooltip.d.ts +2 -15
- package/build/cjs/components/Typography/Header/Header.d.ts +6 -18
- package/build/cjs/components/Typography/Header/Header.js +1 -1
- package/build/cjs/shared/flattenChildren.d.ts +10 -1
- package/build/cjs/shared/flattenChildren.js +1 -1
- package/build/esm/components/BinaryFeedback/BinaryFeedbackOption.js +1 -1
- package/build/esm/components/Column/Columns.js +1 -1
- package/build/esm/components/Form/Checkbox/Checkbox.d.ts +2 -2
- package/build/esm/components/Form/FormFieldGroup/FormFieldGroup.js +1 -1
- package/build/esm/components/Form/MaskedInput/MaskedInput.d.ts +1 -1
- package/build/esm/components/Form/MaskedInput/MaskedInput.js +1 -1
- package/build/esm/components/Form/Radio/Radio.d.ts +2 -2
- package/build/esm/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
- package/build/esm/components/Form/Toggle/Toggle.d.ts +2 -2
- package/build/esm/components/SegmentedProgressBar/SegmentedProgressBar.d.ts +0 -1
- package/build/esm/components/SegmentedProgressBar/SegmentedProgressBar.js +1 -1
- package/build/esm/components/ShadowWebComponent/ShadowWebComponent.d.ts +9 -0
- package/build/esm/components/ShadowWebComponent/ShadowWebComponent.js +1 -1
- package/build/esm/components/TagGroup/TagGroup.js +1 -1
- package/build/esm/components/Toggletip/BasePopover.d.ts +3 -13
- package/build/esm/components/Toggletip/BasePopover.js +1 -1
- package/build/esm/components/Tooltip/BaseTooltip.d.ts +2 -15
- package/build/esm/components/Typography/Header/Header.d.ts +6 -18
- package/build/esm/components/Typography/Header/Header.js +1 -1
- package/build/esm/shared/flattenChildren.d.ts +10 -1
- package/build/esm/shared/flattenChildren.js +1 -1
- package/package.json +18 -17
|
@@ -1 +1 @@
|
|
|
1
|
-
import styled from"@emotion/styled";import{useResponsiveStyles}from"../../shared/mediaQueries";let COLUMN_DEFAULT_SIZE="auto",COLUMN_DEFAULT_ALIGN_SELF="auto",COLUMN_DEFAULT_DS_ID="Column",COLUMNS_DEFAULT_GAP="zero",COLUMNS_DEFAULT_ALWAYS_FILL_SPACE=!1,COLUMNS_DEFAULT_ALIGN_ITEMS="left",COLUMNS_DEFAULT_V_ALIGN_ITEMS="top",COLUMNS_DEFAULT_DS_ID="Columns",columnWidthObject=Array(12).fill("").reduce((acc,_,index)=>({...acc,[index+1]:`${(index+1)*100/12}%`}),{}),makeNegative=obj=>Object.entries(obj).map(([key,value])=>[key,`-${value}`]).reduce((acc,[key,value])=>(acc[key]=value,acc),{});export const Column=styled("div",{target:"e1u9kfnd0",label:"Column"})(({size=COLUMN_DEFAULT_SIZE,order,alignSelf=COLUMN_DEFAULT_ALIGN_SELF,show,"data-ds-id":dataDsId=COLUMN_DEFAULT_DS_ID})=>({...useResponsiveStyles({width:[size,{...columnWidthObject,fill:"1px"}],flex:[size,{narrow:"none",auto:"1",fill:void 0}],order:[order,{first:"-1",last:"1",unset:"0"}],flexShrink:[size,{fill:1,auto:void 0,narrow:void 0}],flexGrow:[size,{fill:1,auto:void 0,narrow:void 0}],alignSelf:[alignSelf,{auto:"auto",start:"start",center:"center",end:"end"}],display:[show,value=>value?"block":"none"]}),"data-ds-id":dataDsId,boxSizing:"border-box","&:empty":{width:0,flex:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sdW1uL0NvbHVtbnMudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2x1bW4vQ29sdW1ucy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuaW1wb3J0IHR5cGUge1xuICBNUSxcbiAgSG9yaXpvbnRhbEFsaWdubWVudCxcbiAgU3BhY2VTaXplcyxcbiAgVmVydGljYWxBbGlnbm1lbnQsXG4gIENvbHVtblNpemVzLFxuICBDb2x1bW5BbGlnbm1lbnQsXG4gIE9yZGVyLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgQ29sdW1uc1Byb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG5cbiAgLyoqIHJlcHJlc2VudHMgdGhlIHNpemUgb2YgYm90aCBob3Jpem9udGFsIGFuZCB2ZXJ0aWNhbCBnYXAgYmV0d2VlbiBjaGlsZHJlbiwgY2FuIGJlIGEgc2luZ2xlIHN0cmluZyBvciBhbiBhcnJheSBvZiAzIHN0cmluZ3NcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGdhcCBzaXplLCBtZWRpdW0gc2NyZWVuIGdhcCBzaXplLCBsYXJnZSBzY3JlZW4gZ2FwIHNpemVdIHRvIGFwcGx5IGRpZmZlcmVudCBnYXAgc2l6ZXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIGdhcD86IFNwYWNlU2l6ZXMgfCBNUTxTcGFjZVNpemVzPjtcblxuICAvKiogc2V0IHRvIHRydWUgaWYgeW91IHdhbnQgdGhlIGxhc3QgZWxlbWVudCB0byBmaWxsIHRoZSBzcGFjZVxuICAgKi9cbiAgYWx3YXlzRmlsbFNwYWNlPzogYm9vbGVhbjtcblxuICAvKiogc3BlY2lmeSBob3Jpem9udGFsIGFsaWdubWVudFxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gYWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiBhbGlnbkl0ZW1zLCBsYXJnZSBzY3JlZW4gYWxpZ25JdGVtc10gdG8gYXBwbHkgZGlmZmVyZW50IGFsaWduSXRlbXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIGFsaWduSXRlbXM/OiBIb3Jpem9udGFsQWxpZ25tZW50IHwgTVE8SG9yaXpvbnRhbEFsaWdubWVudD47XG5cbiAgLyoqIHNwZWNpZnkgdmVydGljYWwgYWxpZ25tZW50XG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2QWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiB2QWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIHZBbGlnbkl0ZW1zXSB0byBhcHBseSBkaWZmZXJlbnQgdkFsaWduSXRlbXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHZBbGlnbkl0ZW1zPzogVmVydGljYWxBbGlnbm1lbnQgfCBNUTxWZXJ0aWNhbEFsaWdubWVudD47XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG4vLyBEZWZhdWx0IHZhbHVlcyBmb3IgQ29sdW1uIHByb3BzXG5jb25zdCBDT0xVTU5fREVGQVVMVF9TSVpFID0gXCJhdXRvXCI7XG5jb25zdCBDT0xVTU5fREVGQVVMVF9BTElHTl9TRUxGID0gXCJhdXRvXCI7XG5jb25zdCBDT0xVTU5fREVGQVVMVF9EU19JRCA9IFwiQ29sdW1uXCI7XG5cbi8vIERlZmF1bHQgdmFsdWVzIGZvciBDb2x1bW5zIHByb3BzXG5jb25zdCBDT0xVTU5TX0RFRkFVTFRfR0FQID0gXCJ6ZXJvXCI7XG5jb25zdCBDT0xVTU5TX0RFRkFVTFRfQUxXQVlTX0ZJTExfU1BBQ0UgPSBmYWxzZTtcbmNvbnN0IENPTFVNTlNfREVGQVVMVF9BTElHTl9JVEVNUyA9IFwibGVmdFwiO1xuY29uc3QgQ09MVU1OU19ERUZBVUxUX1ZfQUxJR05fSVRFTVMgPSBcInRvcFwiO1xuY29uc3QgQ09MVU1OU19ERUZBVUxUX0RTX0lEID0gXCJDb2x1bW5zXCI7XG5cbmV4cG9ydCB0eXBlIENvbHVtblByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG5cbiAgLyoqIHJlcHJlc2VudHMgdGhlIHNpemUgb2YgdGhlIGNvbHVtbiwgY2FuIGJlIGEgc2luZ2xlIG51bWJlciBvciBhbiBhcnJheSBvZiAzIG51bWJlcnMgd2l0aCBhIHZhbHVlIHJhbmdpbmcgZnJvbSAxIHRvIDEyXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBjb2x1bW4gc2l6ZSwgbWVkaXVtIHNjcmVlbiBjb2x1bW4gc2l6ZSwgbGFyZ2Ugc2NyZWVuIGNvbHVtbiBzaXplXSB0byBhcHBseSBkaWZmZXJlbnQgdmFsdWVzIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBzaXplPzogQ29sdW1uU2l6ZXMgfCBNUTxDb2x1bW5TaXplcz47XG5cbiAgLyoqIHNwZWNpZnkgdGhlIHZpc3VhbCBwb3NpdGlvbmluZyBvZiB0aGUgY29sdW1uLiBbc21hbGwgc2NyZWVuIGNvbHVtbiBvcmRlciwgbWVkaXVtIHNjcmVlbiBjb2x1bW4gb3JkZXIsIGxhcmdlIHNjcmVlbiBjb2x1bW4gb3JkZXJdIHRvIGFwcGx5IGRpZmZlcmVudCBvcmRlciBmb3IgZGlmZmVyZW50IHNjcmVlbiBzaXplc1xuICAgKi9cbiAgb3JkZXI/OiBPcmRlciB8IE1RPE9yZGVyPjtcblxuICBhbGlnblNlbGY/OiBDb2x1bW5BbGlnbm1lbnQgfCBNUTxDb2x1bW5BbGlnbm1lbnQ+O1xuICAvKiogZGlzcGxheSBjb2x1bW4gYXQgZ2l2ZW4gYnJlYWtwb2ludCAqL1xuICBzaG93PzogYm9vbGVhbiB8IE1RPGJvb2xlYW4+O1xuXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuXG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgY29sdW1uV2lkdGhPYmplY3QgPSBuZXcgQXJyYXkoMTIpLmZpbGwoXCJcIikucmVkdWNlKFxuICAoYWNjLCBfLCBpbmRleCkgPT4gKHtcbiAgICAuLi5hY2MsXG4gICAgW2luZGV4ICsgMV06IGAkeygoaW5kZXggKyAxKSAqIDEwMCkgLyAxMn0lYCxcbiAgfSksXG4gIHt9XG4pO1xuXG5jb25zdCBtYWtlTmVnYXRpdmUgPSAob2JqOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9PlxuICBPYmplY3QuZW50cmllcyhvYmopXG4gICAgLm1hcCgoW2tleSwgdmFsdWVdKSA9PiBba2V5LCBgLSR7dmFsdWV9YF0pXG4gICAgLnJlZHVjZSgoYWNjLCBba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgIGFjY1trZXldID0gdmFsdWU7XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9IGFzIFJlY29yZDxzdHJpbmcsIHN0cmluZz4pO1xuXG5leHBvcnQgY29uc3QgQ29sdW1uID0gc3R5bGVkLmRpdjxQYXJ0aWFsPENvbHVtblByb3BzPj4oXG4gICh7XG4gICAgc2l6ZSA9IENPTFVNTl9ERUZBVUxUX1NJWkUsXG4gICAgb3JkZXIsXG4gICAgYWxpZ25TZWxmID0gQ09MVU1OX0RFRkFVTFRfQUxJR05fU0VMRixcbiAgICBzaG93LFxuICAgIFwiZGF0YS1kcy1pZFwiOiBkYXRhRHNJZCA9IENPTFVNTl9ERUZBVUxUX0RTX0lELFxuICB9KSA9PiAoe1xuICAgIC4uLnVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgd2lkdGg6IFtzaXplLCB7IC4uLmNvbHVtbldpZHRoT2JqZWN0LCBmaWxsOiBcIjFweFwiIH1dLFxuICAgICAgZmxleDogW3NpemUsIHsgbmFycm93OiBcIm5vbmVcIiwgYXV0bzogXCIxXCIsIGZpbGw6IHVuZGVmaW5lZCB9XSxcbiAgICAgIG9yZGVyOiBbb3JkZXIsIHsgZmlyc3Q6IFwiLTFcIiwgbGFzdDogXCIxXCIsIHVuc2V0OiBcIjBcIiB9XSxcbiAgICAgIGZsZXhTaHJpbms6IFtzaXplLCB7IGZpbGw6IDEsIGF1dG86IHVuZGVmaW5lZCwgbmFycm93OiB1bmRlZmluZWQgfV0sXG4gICAgICBmbGV4R3JvdzogW3NpemUsIHsgZmlsbDogMSwgYXV0bzogdW5kZWZpbmVkLCBuYXJyb3c6IHVuZGVmaW5lZCB9XSxcbiAgICAgIGFsaWduU2VsZjogW1xuICAgICAgICBhbGlnblNlbGYsXG4gICAgICAgIHtcbiAgICAgICAgICBhdXRvOiBcImF1dG9cIixcbiAgICAgICAgICBzdGFydDogXCJzdGFydFwiLFxuICAgICAgICAgIGNlbnRlcjogXCJjZW50ZXJcIixcbiAgICAgICAgICBlbmQ6IFwiZW5kXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAgZGlzcGxheTogW3Nob3csICh2YWx1ZTogYm9vbGVhbikgPT4gKHZhbHVlID8gXCJibG9ja1wiIDogXCJub25lXCIpXSxcbiAgICB9KSxcbiAgICBcImRhdGEtZHMtaWRcIjogZGF0YURzSWQsXG4gICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICBcIiY6ZW1wdHlcIjoge1xuICAgICAgd2lkdGg6IDAsXG4gICAgICBmbGV4OiBcIm5vbmVcIixcbiAgICB9LFxuICB9KVxuKTtcblxuZXhwb3J0IGNvbnN0IENvbHVtbnMgPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q29sdW1uc1Byb3BzPj4oXG4gICh7XG4gICAgdGhlbWUsXG4gICAgYWxpZ25JdGVtcyA9IENPTFVNTlNfREVGQVVMVF9BTElHTl9JVEVNUyxcbiAgICB2QWxpZ25JdGVtcyA9IENPTFVNTlNfREVGQVVMVF9WX0FMSUdOX0lURU1TLFxuICAgIGdhcCA9IENPTFVNTlNfREVGQVVMVF9HQVAsXG4gICAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkID0gQ09MVU1OU19ERUZBVUxUX0RTX0lELFxuICB9KSA9PiAoe1xuICAgIHdpZHRoOiBcImF1dG9cIixcbiAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICBqdXN0aWZ5SXRlbXM6IFwic3RyZXRjaFwiLFxuICAgIGp1c3RpZnlDb250ZW50OiBcInN0cmV0Y2hcIixcbiAgICBhbGlnbkl0ZW1zOiBcInN0cmV0Y2hcIixcbiAgICBmbGV4V3JhcDogXCJ3cmFwXCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICBcImRhdGEtZHMtaWRcIjogZGF0YURzSWQsXG4gICAgLi4udXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICBhbGlnbkl0ZW1zOiBbXG4gICAgICAgIHZBbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgdG9wOiBcImZsZXgtc3RhcnRcIixcbiAgICAgICAgICBib3R0b206IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3RyZXRjaDogXCJzdHJldGNoXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgYWxpZ25JdGVtcyxcbiAgICAgICAge1xuICAgICAgICAgIGxlZnQ6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgIHJpZ2h0OiBcImZsZXgtZW5kXCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAgbWFyZ2luUmlnaHQ6IFtnYXAsIG1ha2VOZWdhdGl2ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nKV0sXG4gICAgICBtYXJnaW5Cb3R0b206IFtnYXAsIG1ha2VOZWdhdGl2ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nKV0sXG4gICAgfSksXG5cbiAgICBbYCYgPiAke0NvbHVtbn1gXToge1xuICAgICAgLi4udXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICAgIG1hcmdpbkJvdHRvbTogW2dhcCwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICAgIHBhZGRpbmdSaWdodDogW2dhcCwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICB9KSxcbiAgICB9LFxuICB9KSxcbiAgKHsgYWx3YXlzRmlsbFNwYWNlID0gQ09MVU1OU19ERUZBVUxUX0FMV0FZU19GSUxMX1NQQUNFIH0pID0+XG4gICAgYWx3YXlzRmlsbFNwYWNlICYmIHtcbiAgICAgIFtgJiA+ICR7Q29sdW1ufWBdOiB7XG4gICAgICAgIFwiJjpsYXN0LWNoaWxkXCI6IHtcbiAgICAgICAgICBmbGV4R3JvdzogMSxcbiAgICAgICAgICBmbGV4U2hyaW5rOiAxLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJGc0IifQ== */");export const Columns=styled("div",{target:"e1u9kfnd1",label:"Columns"})(({theme,alignItems=COLUMNS_DEFAULT_ALIGN_ITEMS,vAlignItems=COLUMNS_DEFAULT_V_ALIGN_ITEMS,gap=COLUMNS_DEFAULT_GAP,"data-ds-id":dataDsId=COLUMNS_DEFAULT_DS_ID})=>({width:"auto",display:"flex",justifyItems:"stretch",justifyContent:"stretch",alignItems:"stretch",flexWrap:"wrap",flexDirection:"row","data-ds-id":dataDsId,...useResponsiveStyles({alignItems:[vAlignItems,{top:"flex-start",bottom:"flex-end",center:"center",stretch:"stretch"}],justifyContent:[alignItems,{left:"flex-start",right:"flex-end",center:"center",spaceBetween:"space-between"}],marginRight:[gap,makeNegative(theme.variables.size.spacing)],marginBottom:[gap,makeNegative(theme.variables.size.spacing)]}),[`& > ${Column}`]:{...useResponsiveStyles({marginBottom:[gap,theme.variables.size.spacing],paddingRight:[gap,theme.variables.size.spacing]})}}),({alwaysFillSpace=COLUMNS_DEFAULT_ALWAYS_FILL_SPACE})=>alwaysFillSpace&&{[`& > ${Column}`]:{"&:last-child":{flexGrow:1,flexShrink:1}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sdW1uL0NvbHVtbnMudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2x1bW4vQ29sdW1ucy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuaW1wb3J0IHR5cGUge1xuICBNUSxcbiAgSG9yaXpvbnRhbEFsaWdubWVudCxcbiAgU3BhY2VTaXplcyxcbiAgVmVydGljYWxBbGlnbm1lbnQsXG4gIENvbHVtblNpemVzLFxuICBDb2x1bW5BbGlnbm1lbnQsXG4gIE9yZGVyLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgQ29sdW1uc1Byb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG5cbiAgLyoqIHJlcHJlc2VudHMgdGhlIHNpemUgb2YgYm90aCBob3Jpem9udGFsIGFuZCB2ZXJ0aWNhbCBnYXAgYmV0d2VlbiBjaGlsZHJlbiwgY2FuIGJlIGEgc2luZ2xlIHN0cmluZyBvciBhbiBhcnJheSBvZiAzIHN0cmluZ3NcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGdhcCBzaXplLCBtZWRpdW0gc2NyZWVuIGdhcCBzaXplLCBsYXJnZSBzY3JlZW4gZ2FwIHNpemVdIHRvIGFwcGx5IGRpZmZlcmVudCBnYXAgc2l6ZXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIGdhcD86IFNwYWNlU2l6ZXMgfCBNUTxTcGFjZVNpemVzPjtcblxuICAvKiogc2V0IHRvIHRydWUgaWYgeW91IHdhbnQgdGhlIGxhc3QgZWxlbWVudCB0byBmaWxsIHRoZSBzcGFjZVxuICAgKi9cbiAgYWx3YXlzRmlsbFNwYWNlPzogYm9vbGVhbjtcblxuICAvKiogc3BlY2lmeSBob3Jpem9udGFsIGFsaWdubWVudFxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gYWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiBhbGlnbkl0ZW1zLCBsYXJnZSBzY3JlZW4gYWxpZ25JdGVtc10gdG8gYXBwbHkgZGlmZmVyZW50IGFsaWduSXRlbXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIGFsaWduSXRlbXM/OiBIb3Jpem9udGFsQWxpZ25tZW50IHwgTVE8SG9yaXpvbnRhbEFsaWdubWVudD47XG5cbiAgLyoqIHNwZWNpZnkgdmVydGljYWwgYWxpZ25tZW50XG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2QWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiB2QWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIHZBbGlnbkl0ZW1zXSB0byBhcHBseSBkaWZmZXJlbnQgdkFsaWduSXRlbXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHZBbGlnbkl0ZW1zPzogVmVydGljYWxBbGlnbm1lbnQgfCBNUTxWZXJ0aWNhbEFsaWdubWVudD47XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG4vLyBEZWZhdWx0IHZhbHVlcyBmb3IgQ29sdW1uIHByb3BzXG5jb25zdCBDT0xVTU5fREVGQVVMVF9TSVpFID0gXCJhdXRvXCI7XG5jb25zdCBDT0xVTU5fREVGQVVMVF9BTElHTl9TRUxGID0gXCJhdXRvXCI7XG5jb25zdCBDT0xVTU5fREVGQVVMVF9EU19JRCA9IFwiQ29sdW1uXCI7XG5cbi8vIERlZmF1bHQgdmFsdWVzIGZvciBDb2x1bW5zIHByb3BzXG5jb25zdCBDT0xVTU5TX0RFRkFVTFRfR0FQID0gXCJ6ZXJvXCI7XG5jb25zdCBDT0xVTU5TX0RFRkFVTFRfQUxXQVlTX0ZJTExfU1BBQ0UgPSBmYWxzZTtcbmNvbnN0IENPTFVNTlNfREVGQVVMVF9BTElHTl9JVEVNUyA9IFwibGVmdFwiO1xuY29uc3QgQ09MVU1OU19ERUZBVUxUX1ZfQUxJR05fSVRFTVMgPSBcInRvcFwiO1xuY29uc3QgQ09MVU1OU19ERUZBVUxUX0RTX0lEID0gXCJDb2x1bW5zXCI7XG5cbmV4cG9ydCB0eXBlIENvbHVtblByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG5cbiAgLyoqIHJlcHJlc2VudHMgdGhlIHNpemUgb2YgdGhlIGNvbHVtbiwgY2FuIGJlIGEgc2luZ2xlIG51bWJlciBvciBhbiBhcnJheSBvZiAzIG51bWJlcnMgd2l0aCBhIHZhbHVlIHJhbmdpbmcgZnJvbSAxIHRvIDEyXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBjb2x1bW4gc2l6ZSwgbWVkaXVtIHNjcmVlbiBjb2x1bW4gc2l6ZSwgbGFyZ2Ugc2NyZWVuIGNvbHVtbiBzaXplXSB0byBhcHBseSBkaWZmZXJlbnQgdmFsdWVzIGZvciBkaWZmZXJlbnQgc2NyZWVuIHNpemVzXG4gICAqL1xuICBzaXplPzogQ29sdW1uU2l6ZXMgfCBNUTxDb2x1bW5TaXplcz47XG5cbiAgLyoqIHNwZWNpZnkgdGhlIHZpc3VhbCBwb3NpdGlvbmluZyBvZiB0aGUgY29sdW1uLiBbc21hbGwgc2NyZWVuIGNvbHVtbiBvcmRlciwgbWVkaXVtIHNjcmVlbiBjb2x1bW4gb3JkZXIsIGxhcmdlIHNjcmVlbiBjb2x1bW4gb3JkZXJdIHRvIGFwcGx5IGRpZmZlcmVudCBvcmRlciBmb3IgZGlmZmVyZW50IHNjcmVlbiBzaXplc1xuICAgKi9cbiAgb3JkZXI/OiBPcmRlciB8IE1RPE9yZGVyPjtcblxuICBhbGlnblNlbGY/OiBDb2x1bW5BbGlnbm1lbnQgfCBNUTxDb2x1bW5BbGlnbm1lbnQ+O1xuICAvKiogZGlzcGxheSBjb2x1bW4gYXQgZ2l2ZW4gYnJlYWtwb2ludCAqL1xuICBzaG93PzogYm9vbGVhbiB8IE1RPGJvb2xlYW4+O1xuXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuXG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgY29sdW1uV2lkdGhPYmplY3QgPSBuZXcgQXJyYXkoMTIpLmZpbGwoXCJcIikucmVkdWNlKFxuICAoYWNjLCBfLCBpbmRleCkgPT4gKHtcbiAgICAuLi5hY2MsXG4gICAgW2luZGV4ICsgMV06IGAkeygoaW5kZXggKyAxKSAqIDEwMCkgLyAxMn0lYCxcbiAgfSksXG4gIHt9XG4pO1xuXG5jb25zdCBtYWtlTmVnYXRpdmUgPSAob2JqOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9PlxuICBPYmplY3QuZW50cmllcyhvYmopXG4gICAgLm1hcCgoW2tleSwgdmFsdWVdKSA9PiBba2V5LCBgLSR7dmFsdWV9YF0pXG4gICAgLnJlZHVjZSgoYWNjLCBba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgIGFjY1trZXldID0gdmFsdWU7XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9IGFzIFJlY29yZDxzdHJpbmcsIHN0cmluZz4pO1xuXG5leHBvcnQgY29uc3QgQ29sdW1uID0gc3R5bGVkLmRpdjxQYXJ0aWFsPENvbHVtblByb3BzPj4oXG4gICh7XG4gICAgc2l6ZSA9IENPTFVNTl9ERUZBVUxUX1NJWkUsXG4gICAgb3JkZXIsXG4gICAgYWxpZ25TZWxmID0gQ09MVU1OX0RFRkFVTFRfQUxJR05fU0VMRixcbiAgICBzaG93LFxuICAgIFwiZGF0YS1kcy1pZFwiOiBkYXRhRHNJZCA9IENPTFVNTl9ERUZBVUxUX0RTX0lELFxuICB9KSA9PiAoe1xuICAgIC4uLnVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgd2lkdGg6IFtzaXplLCB7IC4uLmNvbHVtbldpZHRoT2JqZWN0LCBmaWxsOiBcIjFweFwiIH1dLFxuICAgICAgZmxleDogW3NpemUsIHsgbmFycm93OiBcIm5vbmVcIiwgYXV0bzogXCIxXCIsIGZpbGw6IHVuZGVmaW5lZCB9XSxcbiAgICAgIG9yZGVyOiBbb3JkZXIsIHsgZmlyc3Q6IFwiLTFcIiwgbGFzdDogXCIxXCIsIHVuc2V0OiBcIjBcIiB9XSxcbiAgICAgIGZsZXhTaHJpbms6IFtzaXplLCB7IGZpbGw6IDEsIGF1dG86IHVuZGVmaW5lZCwgbmFycm93OiB1bmRlZmluZWQgfV0sXG4gICAgICBmbGV4R3JvdzogW3NpemUsIHsgZmlsbDogMSwgYXV0bzogdW5kZWZpbmVkLCBuYXJyb3c6IHVuZGVmaW5lZCB9XSxcbiAgICAgIGFsaWduU2VsZjogW1xuICAgICAgICBhbGlnblNlbGYsXG4gICAgICAgIHtcbiAgICAgICAgICBhdXRvOiBcImF1dG9cIixcbiAgICAgICAgICBzdGFydDogXCJzdGFydFwiLFxuICAgICAgICAgIGNlbnRlcjogXCJjZW50ZXJcIixcbiAgICAgICAgICBlbmQ6IFwiZW5kXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAgZGlzcGxheTogW3Nob3csICh2YWx1ZTogYm9vbGVhbikgPT4gKHZhbHVlID8gXCJibG9ja1wiIDogXCJub25lXCIpXSxcbiAgICB9KSxcbiAgICBcImRhdGEtZHMtaWRcIjogZGF0YURzSWQsXG4gICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICBcIiY6ZW1wdHlcIjoge1xuICAgICAgd2lkdGg6IDAsXG4gICAgICBmbGV4OiBcIm5vbmVcIixcbiAgICB9LFxuICB9KVxuKTtcblxuZXhwb3J0IGNvbnN0IENvbHVtbnMgPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q29sdW1uc1Byb3BzPj4oXG4gICh7XG4gICAgdGhlbWUsXG4gICAgYWxpZ25JdGVtcyA9IENPTFVNTlNfREVGQVVMVF9BTElHTl9JVEVNUyxcbiAgICB2QWxpZ25JdGVtcyA9IENPTFVNTlNfREVGQVVMVF9WX0FMSUdOX0lURU1TLFxuICAgIGdhcCA9IENPTFVNTlNfREVGQVVMVF9HQVAsXG4gICAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkID0gQ09MVU1OU19ERUZBVUxUX0RTX0lELFxuICB9KSA9PiAoe1xuICAgIHdpZHRoOiBcImF1dG9cIixcbiAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICBqdXN0aWZ5SXRlbXM6IFwic3RyZXRjaFwiLFxuICAgIGp1c3RpZnlDb250ZW50OiBcInN0cmV0Y2hcIixcbiAgICBhbGlnbkl0ZW1zOiBcInN0cmV0Y2hcIixcbiAgICBmbGV4V3JhcDogXCJ3cmFwXCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICBcImRhdGEtZHMtaWRcIjogZGF0YURzSWQsXG4gICAgLi4udXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICBhbGlnbkl0ZW1zOiBbXG4gICAgICAgIHZBbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgdG9wOiBcImZsZXgtc3RhcnRcIixcbiAgICAgICAgICBib3R0b206IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3RyZXRjaDogXCJzdHJldGNoXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgYWxpZ25JdGVtcyxcbiAgICAgICAge1xuICAgICAgICAgIGxlZnQ6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgIHJpZ2h0OiBcImZsZXgtZW5kXCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAgbWFyZ2luUmlnaHQ6IFtnYXAsIG1ha2VOZWdhdGl2ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nKV0sXG4gICAgICBtYXJnaW5Cb3R0b206IFtnYXAsIG1ha2VOZWdhdGl2ZSh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nKV0sXG4gICAgfSksXG5cbiAgICBbYCYgPiAke0NvbHVtbn1gXToge1xuICAgICAgLi4udXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICAgIG1hcmdpbkJvdHRvbTogW2dhcCwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICAgIHBhZGRpbmdSaWdodDogW2dhcCwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICB9KSxcbiAgICB9LFxuICB9KSxcbiAgKHsgYWx3YXlzRmlsbFNwYWNlID0gQ09MVU1OU19ERUZBVUxUX0FMV0FZU19GSUxMX1NQQUNFIH0pID0+XG4gICAgYWx3YXlzRmlsbFNwYWNlICYmIHtcbiAgICAgIFtgJiA+ICR7Q29sdW1ufWBdOiB7XG4gICAgICAgIFwiJjpsYXN0LWNoaWxkXCI6IHtcbiAgICAgICAgICBmbGV4R3JvdzogMSxcbiAgICAgICAgICBmbGV4U2hyaW5rOiAxLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZIdUIifQ== */");
|
|
1
|
+
import styled from"@emotion/styled";import{useResponsiveStyles}from"../../shared/mediaQueries";let columnWidthObject=Array(12).fill("").reduce((acc,_,index)=>({...acc,[index+1]:`${(index+1)*100/12}%`}),{}),makeNegative=obj=>Object.entries(obj).map(([key,value])=>[key,`-${value}`]).reduce((acc,[key,value])=>(acc[key]=value,acc),{});export const Column=styled("div",{target:"e1shkepj0",label:"Column"})(({size,order,alignSelf,show})=>({...useResponsiveStyles({width:[size,{...columnWidthObject,fill:"1px"}],flex:[size,{narrow:"none",auto:"1",fill:void 0}],order:[order,{first:"-1",last:"1",unset:"0"}],flexShrink:[size,{fill:1,auto:void 0,narrow:void 0}],flexGrow:[size,{fill:1,auto:void 0,narrow:void 0}],alignSelf:[alignSelf,{auto:"auto",start:"start",center:"center",end:"end"}],display:[show,value=>value?"block":"none"]}),boxSizing:"border-box","&:empty":{width:0,flex:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sdW1uL0NvbHVtbnMudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2x1bW4vQ29sdW1ucy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuaW1wb3J0IHR5cGUge1xuICBNUSxcbiAgSG9yaXpvbnRhbEFsaWdubWVudCxcbiAgU3BhY2VTaXplcyxcbiAgVmVydGljYWxBbGlnbm1lbnQsXG4gIENvbHVtblNpemVzLFxuICBDb2x1bW5BbGlnbm1lbnQsXG4gIE9yZGVyLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgQ29sdW1uc1Byb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG5cbiAgLyoqIHJlcHJlc2VudHMgdGhlIHNpemUgb2YgYm90aCBob3Jpem9udGFsIGFuZCB2ZXJ0aWNhbCBnYXAgYmV0d2VlbiBjaGlsZHJlbiwgY2FuIGJlIGEgc2luZ2xlIHN0cmluZyBvciBhbiBhcnJheSBvZiAzIHN0cmluZ3NcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGdhcCBzaXplLCBtZWRpdW0gc2NyZWVuIGdhcCBzaXplLCBsYXJnZSBzY3JlZW4gZ2FwIHNpemVdIHRvIGFwcGx5IGRpZmZlcmVudCBnYXAgc2l6ZXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIGdhcD86IFNwYWNlU2l6ZXMgfCBNUTxTcGFjZVNpemVzPjtcblxuICAvKiogc2V0IHRvIHRydWUgaWYgeW91IHdhbnQgdGhlIGxhc3QgZWxlbWVudCB0byBmaWxsIHRoZSBzcGFjZVxuICAgKi9cbiAgYWx3YXlzRmlsbFNwYWNlPzogYm9vbGVhbjtcblxuICAvKiogc3BlY2lmeSBob3Jpem9udGFsIGFsaWdubWVudFxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gYWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiBhbGlnbkl0ZW1zLCBsYXJnZSBzY3JlZW4gYWxpZ25JdGVtc10gdG8gYXBwbHkgZGlmZmVyZW50IGFsaWduSXRlbXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIGFsaWduSXRlbXM/OiBIb3Jpem9udGFsQWxpZ25tZW50IHwgTVE8SG9yaXpvbnRhbEFsaWdubWVudD47XG5cbiAgLyoqIHNwZWNpZnkgdmVydGljYWwgYWxpZ25tZW50XG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2QWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiB2QWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIHZBbGlnbkl0ZW1zXSB0byBhcHBseSBkaWZmZXJlbnQgdkFsaWduSXRlbXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHZBbGlnbkl0ZW1zPzogVmVydGljYWxBbGlnbm1lbnQgfCBNUTxWZXJ0aWNhbEFsaWdubWVudD47XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBhcnRpYWw8Q29sdW1uc1Byb3BzPiA9IHtcbiAgZ2FwOiBcInplcm9cIixcbiAgYWx3YXlzRmlsbFNwYWNlOiBmYWxzZSxcbiAgYWxpZ25JdGVtczogXCJsZWZ0XCIsXG4gIHZBbGlnbkl0ZW1zOiBcInRvcFwiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogdW5kZWZpbmVkLFxuICBcImRhdGEtZHMtaWRcIjogXCJDb2x1bW5zXCIsXG59O1xuXG5leHBvcnQgdHlwZSBDb2x1bW5Qcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVtdIHwgUmVhY3QuUmVhY3ROb2RlO1xuXG4gIC8qKiByZXByZXNlbnRzIHRoZSBzaXplIG9mIHRoZSBjb2x1bW4sIGNhbiBiZSBhIHNpbmdsZSBudW1iZXIgb3IgYW4gYXJyYXkgb2YgMyBudW1iZXJzIHdpdGggYSB2YWx1ZSByYW5naW5nIGZyb20gMSB0byAxMlxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gY29sdW1uIHNpemUsIG1lZGl1bSBzY3JlZW4gY29sdW1uIHNpemUsIGxhcmdlIHNjcmVlbiBjb2x1bW4gc2l6ZV0gdG8gYXBwbHkgZGlmZmVyZW50IHZhbHVlcyBmb3IgZGlmZmVyZW50IHNjcmVlbiBzaXplc1xuICAgKi9cbiAgc2l6ZT86IENvbHVtblNpemVzIHwgTVE8Q29sdW1uU2l6ZXM+O1xuXG4gIC8qKiBzcGVjaWZ5IHRoZSB2aXN1YWwgcG9zaXRpb25pbmcgb2YgdGhlIGNvbHVtbi4gW3NtYWxsIHNjcmVlbiBjb2x1bW4gb3JkZXIsIG1lZGl1bSBzY3JlZW4gY29sdW1uIG9yZGVyLCBsYXJnZSBzY3JlZW4gY29sdW1uIG9yZGVyXSB0byBhcHBseSBkaWZmZXJlbnQgb3JkZXIgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIG9yZGVyPzogT3JkZXIgfCBNUTxPcmRlcj47XG5cbiAgYWxpZ25TZWxmPzogQ29sdW1uQWxpZ25tZW50IHwgTVE8Q29sdW1uQWxpZ25tZW50PjtcbiAgLyoqIGRpc3BsYXkgY29sdW1uIGF0IGdpdmVuIGJyZWFrcG9pbnQgKi9cbiAgc2hvdz86IGJvb2xlYW4gfCBNUTxib29sZWFuPjtcblxuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcblxuICAvKiogQGlnbm9yZSAqL1xuICBcImRhdGEtZHMtaWRcIj86IHN0cmluZztcbn07XG5cbmNvbnN0IGNvbHVtbkRlZmF1bHRQcm9wczogUGFydGlhbDxDb2x1bW5Qcm9wcz4gPSB7XG4gIHNpemU6IFwiYXV0b1wiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogdW5kZWZpbmVkLFxuICBhbGlnblNlbGY6IFwiYXV0b1wiLFxuICBcImRhdGEtZHMtaWRcIjogXCJDb2x1bW5cIixcbn07XG5cbmNvbnN0IGNvbHVtbldpZHRoT2JqZWN0ID0gbmV3IEFycmF5KDEyKS5maWxsKFwiXCIpLnJlZHVjZShcbiAgKGFjYywgXywgaW5kZXgpID0+ICh7XG4gICAgLi4uYWNjLFxuICAgIFtpbmRleCArIDFdOiBgJHsoKGluZGV4ICsgMSkgKiAxMDApIC8gMTJ9JWAsXG4gIH0pLFxuICB7fVxuKTtcblxuY29uc3QgbWFrZU5lZ2F0aXZlID0gKG9iajogUmVjb3JkPHN0cmluZywgc3RyaW5nPik6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPT5cbiAgT2JqZWN0LmVudHJpZXMob2JqKVxuICAgIC5tYXAoKFtrZXksIHZhbHVlXSkgPT4gW2tleSwgYC0ke3ZhbHVlfWBdKVxuICAgIC5yZWR1Y2UoKGFjYywgW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgICBhY2Nba2V5XSA9IHZhbHVlO1xuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSBhcyBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTtcblxuZXhwb3J0IGNvbnN0IENvbHVtbiA9IHN0eWxlZC5kaXY8UGFydGlhbDxDb2x1bW5Qcm9wcz4+KFxuICAoeyBzaXplLCBvcmRlciwgYWxpZ25TZWxmLCBzaG93IH0pID0+ICh7XG4gICAgLi4udXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICB3aWR0aDogW3NpemUsIHsgLi4uY29sdW1uV2lkdGhPYmplY3QsIGZpbGw6IFwiMXB4XCIgfV0sXG4gICAgICBmbGV4OiBbc2l6ZSwgeyBuYXJyb3c6IFwibm9uZVwiLCBhdXRvOiBcIjFcIiwgZmlsbDogdW5kZWZpbmVkIH1dLFxuICAgICAgb3JkZXI6IFtvcmRlciwgeyBmaXJzdDogXCItMVwiLCBsYXN0OiBcIjFcIiwgdW5zZXQ6IFwiMFwiIH1dLFxuICAgICAgZmxleFNocmluazogW3NpemUsIHsgZmlsbDogMSwgYXV0bzogdW5kZWZpbmVkLCBuYXJyb3c6IHVuZGVmaW5lZCB9XSxcbiAgICAgIGZsZXhHcm93OiBbc2l6ZSwgeyBmaWxsOiAxLCBhdXRvOiB1bmRlZmluZWQsIG5hcnJvdzogdW5kZWZpbmVkIH1dLFxuICAgICAgYWxpZ25TZWxmOiBbXG4gICAgICAgIGFsaWduU2VsZixcbiAgICAgICAge1xuICAgICAgICAgIGF1dG86IFwiYXV0b1wiLFxuICAgICAgICAgIHN0YXJ0OiBcInN0YXJ0XCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIGVuZDogXCJlbmRcIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBkaXNwbGF5OiBbc2hvdywgKHZhbHVlOiBib29sZWFuKSA9PiAodmFsdWUgPyBcImJsb2NrXCIgOiBcIm5vbmVcIildLFxuICAgIH0pLFxuICAgIGJveFNpemluZzogXCJib3JkZXItYm94XCIsXG4gICAgXCImOmVtcHR5XCI6IHtcbiAgICAgIHdpZHRoOiAwLFxuICAgICAgZmxleDogXCJub25lXCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbkNvbHVtbi5kZWZhdWx0UHJvcHMgPSBjb2x1bW5EZWZhdWx0UHJvcHM7XG5cbmV4cG9ydCBjb25zdCBDb2x1bW5zID0gc3R5bGVkLmRpdjxQYXJ0aWFsPENvbHVtbnNQcm9wcz4+KFxuICAoeyB0aGVtZSwgYWxpZ25JdGVtcywgdkFsaWduSXRlbXMsIGdhcCB9KSA9PiAoe1xuICAgIHdpZHRoOiBcImF1dG9cIixcbiAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICBqdXN0aWZ5SXRlbXM6IFwic3RyZXRjaFwiLFxuICAgIGp1c3RpZnlDb250ZW50OiBcInN0cmV0Y2hcIixcbiAgICBhbGlnbkl0ZW1zOiBcInN0cmV0Y2hcIixcbiAgICBmbGV4V3JhcDogXCJ3cmFwXCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgIGFsaWduSXRlbXM6IFtcbiAgICAgICAgdkFsaWduSXRlbXMsXG4gICAgICAgIHtcbiAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgIGJvdHRvbTogXCJmbGV4LWVuZFwiLFxuICAgICAgICAgIGNlbnRlcjogXCJjZW50ZXJcIixcbiAgICAgICAgICBzdHJldGNoOiBcInN0cmV0Y2hcIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgbGVmdDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgcmlnaHQ6IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3BhY2VCZXR3ZWVuOiBcInNwYWNlLWJldHdlZW5cIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBtYXJnaW5SaWdodDogW2dhcCwgbWFrZU5lZ2F0aXZlKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcpXSxcbiAgICAgIG1hcmdpbkJvdHRvbTogW2dhcCwgbWFrZU5lZ2F0aXZlKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcpXSxcbiAgICB9KSxcblxuICAgIFtgJiA+ICR7Q29sdW1ufWBdOiB7XG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAgbWFyZ2luQm90dG9tOiBbZ2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgICAgcGFkZGluZ1JpZ2h0OiBbZ2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIH0pLFxuICAgIH0sXG4gIH0pLFxuICAoeyBhbHdheXNGaWxsU3BhY2UgfSkgPT5cbiAgICBhbHdheXNGaWxsU3BhY2UgJiYge1xuICAgICAgW2AmID4gJHtDb2x1bW59YF06IHtcbiAgICAgICAgXCImOmxhc3QtY2hpbGRcIjoge1xuICAgICAgICAgIGZsZXhHcm93OiAxLFxuICAgICAgICAgIGZsZXhTaHJpbms6IDEsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH1cbik7XG5cbkNvbHVtbnMuZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStGc0IifQ== */");Column.defaultProps={size:"auto","data-e2e-test-id":void 0,alignSelf:"auto","data-ds-id":"Column"};export const Columns=styled("div",{target:"e1shkepj1",label:"Columns"})(({theme,alignItems,vAlignItems,gap})=>({width:"auto",display:"flex",justifyItems:"stretch",justifyContent:"stretch",alignItems:"stretch",flexWrap:"wrap",flexDirection:"row",...useResponsiveStyles({alignItems:[vAlignItems,{top:"flex-start",bottom:"flex-end",center:"center",stretch:"stretch"}],justifyContent:[alignItems,{left:"flex-start",right:"flex-end",center:"center",spaceBetween:"space-between"}],marginRight:[gap,makeNegative(theme.variables.size.spacing)],marginBottom:[gap,makeNegative(theme.variables.size.spacing)]}),[`& > ${Column}`]:{...useResponsiveStyles({marginBottom:[gap,theme.variables.size.spacing],paddingRight:[gap,theme.variables.size.spacing]})}}),({alwaysFillSpace})=>alwaysFillSpace&&{[`& > ${Column}`]:{"&:last-child":{flexGrow:1,flexShrink:1}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sdW1uL0NvbHVtbnMudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2x1bW4vQ29sdW1ucy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuaW1wb3J0IHR5cGUge1xuICBNUSxcbiAgSG9yaXpvbnRhbEFsaWdubWVudCxcbiAgU3BhY2VTaXplcyxcbiAgVmVydGljYWxBbGlnbm1lbnQsXG4gIENvbHVtblNpemVzLFxuICBDb2x1bW5BbGlnbm1lbnQsXG4gIE9yZGVyLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgQ29sdW1uc1Byb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG5cbiAgLyoqIHJlcHJlc2VudHMgdGhlIHNpemUgb2YgYm90aCBob3Jpem9udGFsIGFuZCB2ZXJ0aWNhbCBnYXAgYmV0d2VlbiBjaGlsZHJlbiwgY2FuIGJlIGEgc2luZ2xlIHN0cmluZyBvciBhbiBhcnJheSBvZiAzIHN0cmluZ3NcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGdhcCBzaXplLCBtZWRpdW0gc2NyZWVuIGdhcCBzaXplLCBsYXJnZSBzY3JlZW4gZ2FwIHNpemVdIHRvIGFwcGx5IGRpZmZlcmVudCBnYXAgc2l6ZXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIGdhcD86IFNwYWNlU2l6ZXMgfCBNUTxTcGFjZVNpemVzPjtcblxuICAvKiogc2V0IHRvIHRydWUgaWYgeW91IHdhbnQgdGhlIGxhc3QgZWxlbWVudCB0byBmaWxsIHRoZSBzcGFjZVxuICAgKi9cbiAgYWx3YXlzRmlsbFNwYWNlPzogYm9vbGVhbjtcblxuICAvKiogc3BlY2lmeSBob3Jpem9udGFsIGFsaWdubWVudFxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gYWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiBhbGlnbkl0ZW1zLCBsYXJnZSBzY3JlZW4gYWxpZ25JdGVtc10gdG8gYXBwbHkgZGlmZmVyZW50IGFsaWduSXRlbXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIGFsaWduSXRlbXM/OiBIb3Jpem9udGFsQWxpZ25tZW50IHwgTVE8SG9yaXpvbnRhbEFsaWdubWVudD47XG5cbiAgLyoqIHNwZWNpZnkgdmVydGljYWwgYWxpZ25tZW50XG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2QWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiB2QWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIHZBbGlnbkl0ZW1zXSB0byBhcHBseSBkaWZmZXJlbnQgdkFsaWduSXRlbXMgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHZBbGlnbkl0ZW1zPzogVmVydGljYWxBbGlnbm1lbnQgfCBNUTxWZXJ0aWNhbEFsaWdubWVudD47XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBhcnRpYWw8Q29sdW1uc1Byb3BzPiA9IHtcbiAgZ2FwOiBcInplcm9cIixcbiAgYWx3YXlzRmlsbFNwYWNlOiBmYWxzZSxcbiAgYWxpZ25JdGVtczogXCJsZWZ0XCIsXG4gIHZBbGlnbkl0ZW1zOiBcInRvcFwiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogdW5kZWZpbmVkLFxuICBcImRhdGEtZHMtaWRcIjogXCJDb2x1bW5zXCIsXG59O1xuXG5leHBvcnQgdHlwZSBDb2x1bW5Qcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVtdIHwgUmVhY3QuUmVhY3ROb2RlO1xuXG4gIC8qKiByZXByZXNlbnRzIHRoZSBzaXplIG9mIHRoZSBjb2x1bW4sIGNhbiBiZSBhIHNpbmdsZSBudW1iZXIgb3IgYW4gYXJyYXkgb2YgMyBudW1iZXJzIHdpdGggYSB2YWx1ZSByYW5naW5nIGZyb20gMSB0byAxMlxuICAgKiBzcGVjaWZ5IFtzbWFsbCBzY3JlZW4gY29sdW1uIHNpemUsIG1lZGl1bSBzY3JlZW4gY29sdW1uIHNpemUsIGxhcmdlIHNjcmVlbiBjb2x1bW4gc2l6ZV0gdG8gYXBwbHkgZGlmZmVyZW50IHZhbHVlcyBmb3IgZGlmZmVyZW50IHNjcmVlbiBzaXplc1xuICAgKi9cbiAgc2l6ZT86IENvbHVtblNpemVzIHwgTVE8Q29sdW1uU2l6ZXM+O1xuXG4gIC8qKiBzcGVjaWZ5IHRoZSB2aXN1YWwgcG9zaXRpb25pbmcgb2YgdGhlIGNvbHVtbi4gW3NtYWxsIHNjcmVlbiBjb2x1bW4gb3JkZXIsIG1lZGl1bSBzY3JlZW4gY29sdW1uIG9yZGVyLCBsYXJnZSBzY3JlZW4gY29sdW1uIG9yZGVyXSB0byBhcHBseSBkaWZmZXJlbnQgb3JkZXIgZm9yIGRpZmZlcmVudCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIG9yZGVyPzogT3JkZXIgfCBNUTxPcmRlcj47XG5cbiAgYWxpZ25TZWxmPzogQ29sdW1uQWxpZ25tZW50IHwgTVE8Q29sdW1uQWxpZ25tZW50PjtcbiAgLyoqIGRpc3BsYXkgY29sdW1uIGF0IGdpdmVuIGJyZWFrcG9pbnQgKi9cbiAgc2hvdz86IGJvb2xlYW4gfCBNUTxib29sZWFuPjtcblxuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcblxuICAvKiogQGlnbm9yZSAqL1xuICBcImRhdGEtZHMtaWRcIj86IHN0cmluZztcbn07XG5cbmNvbnN0IGNvbHVtbkRlZmF1bHRQcm9wczogUGFydGlhbDxDb2x1bW5Qcm9wcz4gPSB7XG4gIHNpemU6IFwiYXV0b1wiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogdW5kZWZpbmVkLFxuICBhbGlnblNlbGY6IFwiYXV0b1wiLFxuICBcImRhdGEtZHMtaWRcIjogXCJDb2x1bW5cIixcbn07XG5cbmNvbnN0IGNvbHVtbldpZHRoT2JqZWN0ID0gbmV3IEFycmF5KDEyKS5maWxsKFwiXCIpLnJlZHVjZShcbiAgKGFjYywgXywgaW5kZXgpID0+ICh7XG4gICAgLi4uYWNjLFxuICAgIFtpbmRleCArIDFdOiBgJHsoKGluZGV4ICsgMSkgKiAxMDApIC8gMTJ9JWAsXG4gIH0pLFxuICB7fVxuKTtcblxuY29uc3QgbWFrZU5lZ2F0aXZlID0gKG9iajogUmVjb3JkPHN0cmluZywgc3RyaW5nPik6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPT5cbiAgT2JqZWN0LmVudHJpZXMob2JqKVxuICAgIC5tYXAoKFtrZXksIHZhbHVlXSkgPT4gW2tleSwgYC0ke3ZhbHVlfWBdKVxuICAgIC5yZWR1Y2UoKGFjYywgW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgICBhY2Nba2V5XSA9IHZhbHVlO1xuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSBhcyBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTtcblxuZXhwb3J0IGNvbnN0IENvbHVtbiA9IHN0eWxlZC5kaXY8UGFydGlhbDxDb2x1bW5Qcm9wcz4+KFxuICAoeyBzaXplLCBvcmRlciwgYWxpZ25TZWxmLCBzaG93IH0pID0+ICh7XG4gICAgLi4udXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICB3aWR0aDogW3NpemUsIHsgLi4uY29sdW1uV2lkdGhPYmplY3QsIGZpbGw6IFwiMXB4XCIgfV0sXG4gICAgICBmbGV4OiBbc2l6ZSwgeyBuYXJyb3c6IFwibm9uZVwiLCBhdXRvOiBcIjFcIiwgZmlsbDogdW5kZWZpbmVkIH1dLFxuICAgICAgb3JkZXI6IFtvcmRlciwgeyBmaXJzdDogXCItMVwiLCBsYXN0OiBcIjFcIiwgdW5zZXQ6IFwiMFwiIH1dLFxuICAgICAgZmxleFNocmluazogW3NpemUsIHsgZmlsbDogMSwgYXV0bzogdW5kZWZpbmVkLCBuYXJyb3c6IHVuZGVmaW5lZCB9XSxcbiAgICAgIGZsZXhHcm93OiBbc2l6ZSwgeyBmaWxsOiAxLCBhdXRvOiB1bmRlZmluZWQsIG5hcnJvdzogdW5kZWZpbmVkIH1dLFxuICAgICAgYWxpZ25TZWxmOiBbXG4gICAgICAgIGFsaWduU2VsZixcbiAgICAgICAge1xuICAgICAgICAgIGF1dG86IFwiYXV0b1wiLFxuICAgICAgICAgIHN0YXJ0OiBcInN0YXJ0XCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIGVuZDogXCJlbmRcIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBkaXNwbGF5OiBbc2hvdywgKHZhbHVlOiBib29sZWFuKSA9PiAodmFsdWUgPyBcImJsb2NrXCIgOiBcIm5vbmVcIildLFxuICAgIH0pLFxuICAgIGJveFNpemluZzogXCJib3JkZXItYm94XCIsXG4gICAgXCImOmVtcHR5XCI6IHtcbiAgICAgIHdpZHRoOiAwLFxuICAgICAgZmxleDogXCJub25lXCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbkNvbHVtbi5kZWZhdWx0UHJvcHMgPSBjb2x1bW5EZWZhdWx0UHJvcHM7XG5cbmV4cG9ydCBjb25zdCBDb2x1bW5zID0gc3R5bGVkLmRpdjxQYXJ0aWFsPENvbHVtbnNQcm9wcz4+KFxuICAoeyB0aGVtZSwgYWxpZ25JdGVtcywgdkFsaWduSXRlbXMsIGdhcCB9KSA9PiAoe1xuICAgIHdpZHRoOiBcImF1dG9cIixcbiAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICBqdXN0aWZ5SXRlbXM6IFwic3RyZXRjaFwiLFxuICAgIGp1c3RpZnlDb250ZW50OiBcInN0cmV0Y2hcIixcbiAgICBhbGlnbkl0ZW1zOiBcInN0cmV0Y2hcIixcbiAgICBmbGV4V3JhcDogXCJ3cmFwXCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgIGFsaWduSXRlbXM6IFtcbiAgICAgICAgdkFsaWduSXRlbXMsXG4gICAgICAgIHtcbiAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgIGJvdHRvbTogXCJmbGV4LWVuZFwiLFxuICAgICAgICAgIGNlbnRlcjogXCJjZW50ZXJcIixcbiAgICAgICAgICBzdHJldGNoOiBcInN0cmV0Y2hcIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgbGVmdDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgcmlnaHQ6IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3BhY2VCZXR3ZWVuOiBcInNwYWNlLWJldHdlZW5cIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBtYXJnaW5SaWdodDogW2dhcCwgbWFrZU5lZ2F0aXZlKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcpXSxcbiAgICAgIG1hcmdpbkJvdHRvbTogW2dhcCwgbWFrZU5lZ2F0aXZlKHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcpXSxcbiAgICB9KSxcblxuICAgIFtgJiA+ICR7Q29sdW1ufWBdOiB7XG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAgbWFyZ2luQm90dG9tOiBbZ2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgICAgcGFkZGluZ1JpZ2h0OiBbZ2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIH0pLFxuICAgIH0sXG4gIH0pLFxuICAoeyBhbHdheXNGaWxsU3BhY2UgfSkgPT5cbiAgICBhbHdheXNGaWxsU3BhY2UgJiYge1xuICAgICAgW2AmID4gJHtDb2x1bW59YF06IHtcbiAgICAgICAgXCImOmxhc3QtY2hpbGRcIjoge1xuICAgICAgICAgIGZsZXhHcm93OiAxLFxuICAgICAgICAgIGZsZXhTaHJpbms6IDEsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH1cbik7XG5cbkNvbHVtbnMuZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRIdUIifQ== */");Columns.defaultProps={gap:"zero",alwaysFillSpace:!1,alignItems:"left",vAlignItems:"top","data-e2e-test-id":void 0,"data-ds-id":"Columns"};
|
|
@@ -17,12 +17,12 @@ export declare const CheckboxRaw: React.ForwardRefExoticComponent<{
|
|
|
17
17
|
label?: string | React.ReactElement;
|
|
18
18
|
indeterminate?: boolean;
|
|
19
19
|
size?: CheckboxSizes;
|
|
20
|
-
} & Omit<FormFieldProps, "label" | "hideLabel"> & Omit<InputHTMLAttributes<HTMLInputElement>, "
|
|
20
|
+
} & Omit<FormFieldProps, "label" | "hideLabel"> & Omit<InputHTMLAttributes<HTMLInputElement>, "type" | "size"> & {
|
|
21
21
|
labelSize?: CheckboxSizes;
|
|
22
22
|
} & React.RefAttributes<HTMLInputElement>>;
|
|
23
23
|
export declare const Checkbox: React.ForwardRefExoticComponent<{
|
|
24
24
|
label?: string | React.ReactElement;
|
|
25
25
|
indeterminate?: boolean;
|
|
26
26
|
size?: CheckboxSizes;
|
|
27
|
-
} & Omit<FormFieldProps, "label" | "hideLabel"> & Omit<InputHTMLAttributes<HTMLInputElement>, "
|
|
27
|
+
} & Omit<FormFieldProps, "label" | "hideLabel"> & Omit<InputHTMLAttributes<HTMLInputElement>, "type" | "size"> & React.RefAttributes<HTMLInputElement>>;
|
|
28
28
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{useEffect,useRef,useState,useId,isValidElement}from"react";import styled from"@emotion/styled";import{Stack}from"../../Stack/Stack";import{Text}from"../../Typography/Text/Text";import{FormErrorMessages}from"../FormErrorMessages/FormErrorMessages";import{FormLabelText}from"../FormLabelText/FormLabelText";import{flattenChildren}from"../../../shared/flattenChildren";import{ScreenReaderText}from"../../Utilities/ScreenReaderText/ScreenReaderText";import{useResponsiveStyles}from"../../../shared/mediaQueries";let StyledFieldset=styled("fieldset",{target:"e178710d0",label:"StyledFieldset"})(({isObserverDone,disabled})=>({border:0,margin:0,padding:0,visibility:isObserverDone?"visible":"hidden",...disabled&&{cursor:"not-allowed"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAmCuB"} */"),InlineChildren=styled("div",{target:"e178710d1",label:"InlineChildren"})({display:"flex",flexDirection:"row",flexWrap:"nowrap"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AA+CuB"} */"),FormChildren=styled("div",{target:"e178710d2",label:"FormChildren"})(({theme,shouldLabelWrap,space})=>({...useResponsiveStyles({marginRight:[space,theme.variables.size.spacing]}),whiteSpace:shouldLabelWrap?"normal":"nowrap"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAqDqB"} */"),StyledTextContainer=styled("div",{target:"e178710d3",label:"StyledTextContainer"})(({theme,disabled})=>({...disabled&&{opacity:theme.variables.opacity.disabled,pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AA8D4B"} */"),StyledLabelContainer=styled("div",{target:"e178710d4",label:"StyledLabelContainer"})(({theme,disabled})=>({...disabled&&{opacity:theme.variables.opacity.disabled,pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAuE6B"} */");export function FormFieldGroup({children,label="",labelAs="div",isLabelHidden=!1,labelHint="",errorMessages=[],hint="",disabled=!1,inline=!1,space="xl","data-e2e-test-id":dataE2eTestId}){let messageId=useId(),radioGroupRef=useRef(null),[isOverflowing,setIsOverflowing]=useState(!1),[isObserverDone,setIsObserverDone]=useState(!inline),[shouldLabelWrap,setShouldLabelWrap]=useState(!1);useEffect(()=>{let observer;return inline&&"undefined"!=typeof IntersectionObserver&&radioGroupRef&&radioGroupRef.current&&(observer=new IntersectionObserver(entries=>entries.forEach(entry=>{entry.isIntersecting||(setIsOverflowing(!0),setShouldLabelWrap(!0)),setIsObserverDone(!0)}),{root:radioGroupRef.current,threshold:1}),Object.entries(radioGroupRef.current.children).forEach(radio=>{let radioElement=radio[1];observer.observe(radioElement)})),()=>{observer&&observer.disconnect()}},[inline]);let validErrorMessages=errorMessages.filter(message=>message),messagesElm=(!!validErrorMessages.length||hint)&&React.createElement(Stack,{space:"xxs",id:messageId},!!validErrorMessages.length&&React.createElement(StyledTextContainer,{disabled:disabled},React.createElement(FormErrorMessages,{messages:validErrorMessages})),hint&&React.createElement(StyledTextContainer,{disabled:disabled},React.createElement(Text,{size:"s",color:"tertiary"},hint))),ariaDescribedBy=messagesElm?{"aria-describedby":messageId}:{};return React.createElement(StyledFieldset,{disabled:disabled,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"FormFieldGroup",isObserverDone:isObserverDone,...ariaDescribedBy},React.createElement(ScreenReaderText,{as:"legend"},label),React.createElement(Stack,{space:"xs"},label&&!isLabelHidden&&React.createElement(StyledLabelContainer,{disabled:disabled},React.createElement(FormLabelText,{labelHint:labelHint,labelAs:labelAs},label)),inline&&!isOverflowing?React.createElement(InlineChildren,{ref:radioGroupRef},React.Children.map(flattenChildren(children),child=>child&&isValidElement(child)?React.createElement(FormChildren,{shouldLabelWrap:shouldLabelWrap,space:space},child):child)):React.Children.map(flattenChildren(children),child=>child),messagesElm))}
|
|
1
|
+
import React,{useEffect,useRef,useState,useId}from"react";import styled from"@emotion/styled";import{Stack}from"../../Stack/Stack";import{Text}from"../../Typography/Text/Text";import{FormErrorMessages}from"../FormErrorMessages/FormErrorMessages";import{FormLabelText}from"../FormLabelText/FormLabelText";import{flattenChildren}from"../../../shared/flattenChildren";import{ScreenReaderText}from"../../Utilities/ScreenReaderText/ScreenReaderText";import{useResponsiveStyles}from"../../../shared/mediaQueries";let StyledFieldset=styled("fieldset",{target:"e1qfpi550",label:"StyledFieldset"})(({isObserverDone,disabled})=>({border:0,margin:0,padding:0,visibility:isObserverDone?"visible":"hidden",...disabled&&{cursor:"not-allowed"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAkCuB"} */"),InlineChildren=styled("div",{target:"e1qfpi551",label:"InlineChildren"})({display:"flex",flexDirection:"row",flexWrap:"nowrap"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AA8CuB"} */"),FormChildren=styled("div",{target:"e1qfpi552",label:"FormChildren"})(({theme,shouldLabelWrap,space})=>({...useResponsiveStyles({marginRight:[space,theme.variables.size.spacing]}),whiteSpace:shouldLabelWrap?"normal":"nowrap"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAoDqB"} */"),StyledTextContainer=styled("div",{target:"e1qfpi553",label:"StyledTextContainer"})(({theme,disabled})=>({...disabled&&{opacity:theme.variables.opacity.disabled,pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AA6D4B"} */"),StyledLabelContainer=styled("div",{target:"e1qfpi554",label:"StyledLabelContainer"})(({theme,disabled})=>({...disabled&&{opacity:theme.variables.opacity.disabled,pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAsE6B"} */");export function FormFieldGroup({children,label="",labelAs="div",isLabelHidden=!1,labelHint="",errorMessages=[],hint="",disabled=!1,inline=!1,space="xl","data-e2e-test-id":dataE2eTestId}){let messageId=useId(),radioGroupRef=useRef(null),[isOverflowing,setIsOverflowing]=useState(!1),[isObserverDone,setIsObserverDone]=useState(!inline),[shouldLabelWrap,setShouldLabelWrap]=useState(!1);useEffect(()=>{let observer;return inline&&"undefined"!=typeof IntersectionObserver&&radioGroupRef&&radioGroupRef.current&&(observer=new IntersectionObserver(entries=>entries.forEach(entry=>{entry.isIntersecting||(setIsOverflowing(!0),setShouldLabelWrap(!0)),setIsObserverDone(!0)}),{root:radioGroupRef.current,threshold:1}),Object.entries(radioGroupRef.current.children).forEach(radio=>{let radioElement=radio[1];observer.observe(radioElement)})),()=>{observer&&observer.disconnect()}},[inline]);let validErrorMessages=errorMessages.filter(message=>message),messagesElm=(!!validErrorMessages.length||hint)&&React.createElement(Stack,{space:"xxs",id:messageId},!!validErrorMessages.length&&React.createElement(StyledTextContainer,{disabled:disabled},React.createElement(FormErrorMessages,{messages:validErrorMessages})),hint&&React.createElement(StyledTextContainer,{disabled:disabled},React.createElement(Text,{size:"s",color:"tertiary"},hint))),ariaDescribedBy=messagesElm?{"aria-describedby":messageId}:{};return React.createElement(StyledFieldset,{disabled:disabled,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"FormFieldGroup",isObserverDone:isObserverDone,...ariaDescribedBy},React.createElement(ScreenReaderText,{as:"legend"},label),React.createElement(Stack,{space:"xs"},label&&!isLabelHidden&&React.createElement(StyledLabelContainer,{disabled:disabled},React.createElement(FormLabelText,{labelHint:labelHint,labelAs:labelAs},label)),inline&&!isOverflowing?React.createElement(InlineChildren,{ref:radioGroupRef},React.Children.map(flattenChildren(children),child=>child&&React.createElement(FormChildren,{shouldLabelWrap:shouldLabelWrap,space:space},React.cloneElement(child,{disabled:disabled||child.props.disabled})))):React.Children.map(flattenChildren(children),child=>React.cloneElement(child,{disabled:disabled||child.props.disabled})),messagesElm))}
|
|
@@ -10,4 +10,4 @@ export type MaskedInputProps = {
|
|
|
10
10
|
export declare const MaskedInput: React.ForwardRefExoticComponent<{
|
|
11
11
|
maskOptions: FactoryArg;
|
|
12
12
|
onAccept: (value: string, unmaskedValue: string, typedValue: string) => void;
|
|
13
|
-
} & Omit<InputProps, "
|
|
13
|
+
} & Omit<InputProps, "type" | "onChange" | "placeholder"> & React.RefAttributes<HTMLInputElement>>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{useRef,useEffect}from"react";import IMask from"imask";import{Input}from"../Input";export const MaskedInput=React.forwardRef(({maskOptions,value,onAccept,...rest},ref)=>{let internalRef=useRef(
|
|
1
|
+
import React,{useRef,useEffect}from"react";import IMask from"imask";import{Input}from"../Input";export const MaskedInput=React.forwardRef(({maskOptions,value,onAccept,...rest},ref)=>{let internalRef=useRef(),maskRef=useRef(null),inputRef=ref||internalRef;return useEffect(()=>(inputRef?.current&&(maskRef.current=IMask(inputRef.current,maskOptions)),()=>{maskRef.current&&maskRef.current.destroy()}),[inputRef]),useEffect(()=>{maskRef.current.updateOptions(maskOptions)},[maskOptions]),useEffect(()=>{let handleAccept=()=>{onAccept(maskRef.current.value,maskRef.current.unmaskedValue,maskRef.current.typedValue)};return maskRef.current.on("accept",handleAccept),()=>{maskRef.current.off("accept",handleAccept)}},[onAccept]),useEffect(()=>{void 0!==value&&(maskRef.current.value=value)},[value]),React.createElement(Input,{...rest,ref:inputRef,type:"text"})});export{IMask};
|
|
@@ -18,7 +18,7 @@ export declare const RadioRaw: React.ForwardRefExoticComponent<{
|
|
|
18
18
|
/** Display hint below the label specific for the radio */
|
|
19
19
|
labelHint?: string | React.ReactElement;
|
|
20
20
|
size?: RadioSizes;
|
|
21
|
-
} & Omit<FormFieldProps, "label" | "labelHint" | "hideLabel"> & Omit<React.InputHTMLAttributes<HTMLInputElement>, "
|
|
21
|
+
} & Omit<FormFieldProps, "label" | "labelHint" | "hideLabel"> & Omit<React.InputHTMLAttributes<HTMLInputElement>, "type" | "size"> & {
|
|
22
22
|
labelSize?: RadioSizes;
|
|
23
23
|
} & React.RefAttributes<HTMLInputElement>>;
|
|
24
24
|
export declare const Radio: React.ForwardRefExoticComponent<{
|
|
@@ -26,5 +26,5 @@ export declare const Radio: React.ForwardRefExoticComponent<{
|
|
|
26
26
|
/** Display hint below the label specific for the radio */
|
|
27
27
|
labelHint?: string | React.ReactElement;
|
|
28
28
|
size?: RadioSizes;
|
|
29
|
-
} & Omit<FormFieldProps, "label" | "labelHint" | "hideLabel"> & Omit<React.InputHTMLAttributes<HTMLInputElement>, "
|
|
29
|
+
} & Omit<FormFieldProps, "label" | "labelHint" | "hideLabel"> & Omit<React.InputHTMLAttributes<HTMLInputElement>, "type" | "size"> & React.RefAttributes<HTMLInputElement>>;
|
|
30
30
|
export {};
|