@pine-ds/core 3.14.0 → 3.14.2-dev.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/floating-ui.dom.js +161 -40
- package/components/floating-ui.dom.js.map +1 -1
- package/components/index.d.ts +2 -0
- package/components/index.js +1 -0
- package/components/index.js.map +1 -1
- package/components/index2.js +1 -1
- package/components/index2.js.map +1 -1
- package/components/pds-checkbox2.js +5 -4
- package/components/pds-checkbox2.js.map +1 -1
- package/components/pds-combobox.js +69 -29
- package/components/pds-combobox.js.map +1 -1
- package/components/pds-dropdown-menu-item.js +1 -1
- package/components/pds-dropdown-menu-item.js.map +1 -1
- package/components/pds-dropdown-menu.js +3 -2
- package/components/pds-dropdown-menu.js.map +1 -1
- package/components/pds-filter.js +1 -1
- package/components/pds-filter.js.map +1 -1
- package/components/pds-input.js +3 -3
- package/components/pds-input.js.map +1 -1
- package/components/pds-loader2.js +2 -2
- package/components/pds-loader2.js.map +1 -1
- package/components/pds-multiselect.d.ts +11 -0
- package/components/pds-multiselect.js +667 -0
- package/components/pds-multiselect.js.map +1 -0
- package/components/pds-popover.js +1 -1
- package/components/pds-progress.js +1 -1
- package/components/pds-property.js +1 -1
- package/components/pds-radio-group.js +3 -3
- package/components/pds-radio.js +3 -3
- package/components/pds-row.js +1 -1
- package/components/pds-select.js +3 -3
- package/components/pds-select.js.map +1 -1
- package/components/pds-sortable-item.js +1 -1
- package/components/pds-sortable.js +1 -1
- package/components/pds-switch.js +5 -4
- package/components/pds-switch.js.map +1 -1
- package/components/pds-tab.js +4 -4
- package/components/pds-tab.js.map +1 -1
- package/components/pds-table-body.js +1 -1
- package/components/pds-table-cell2.js +2 -2
- package/components/pds-table-head-cell2.js +35 -6
- package/components/pds-table-head-cell2.js.map +1 -1
- package/components/pds-table-head.js +1 -1
- package/components/pds-table-row.js +1 -1
- package/components/pds-tabpanel.js +1 -1
- package/components/pds-tabs.js +1 -1
- package/components/pds-text2.js +1 -1
- package/components/pds-textarea.js +6 -6
- package/components/pds-textarea.js.map +1 -1
- package/components/pds-toast.js +3 -3
- package/components/pds-tooltip.js +2 -2
- package/dist/cjs/{floating-ui.dom-DTAy35nv.js → floating-ui.dom-Ca6tS7ef.js} +163 -41
- package/dist/cjs/floating-ui.dom-Ca6tS7ef.js.map +1 -0
- package/dist/cjs/{index-CMeuo765.js → index-BA--jsiy.js} +3 -3
- package/dist/cjs/index-BA--jsiy.js.map +1 -0
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/pds-accordion.cjs.entry.js +1 -1
- package/dist/cjs/pds-avatar.cjs.entry.js +1 -1
- package/dist/cjs/pds-button.cjs.entry.js +1 -1
- package/dist/cjs/pds-checkbox.cjs.entry.js +6 -5
- package/dist/cjs/pds-checkbox.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-chip.cjs.entry.js +1 -1
- package/dist/cjs/pds-combobox.cjs.entry.js +70 -30
- package/dist/cjs/pds-combobox.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-copytext.cjs.entry.js +1 -1
- package/dist/cjs/pds-dropdown-menu-item.cjs.entry.js +1 -1
- package/dist/cjs/pds-dropdown-menu-item.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-dropdown-menu.cjs.entry.js +4 -3
- package/dist/cjs/pds-dropdown-menu.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-filter.cjs.entry.js +2 -2
- package/dist/cjs/pds-filter.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-input.cjs.entry.js +4 -4
- package/dist/cjs/pds-input.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-link.cjs.entry.js +1 -1
- package/dist/cjs/pds-loader.cjs.entry.js +2 -2
- package/dist/cjs/pds-loader.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-multiselect.cjs.entry.js +593 -0
- package/dist/cjs/pds-multiselect.entry.cjs.js.map +1 -0
- package/dist/cjs/pds-popover.cjs.entry.js +1 -1
- package/dist/cjs/pds-progress.cjs.entry.js +1 -1
- package/dist/cjs/pds-property.cjs.entry.js +1 -1
- package/dist/cjs/pds-radio-group.cjs.entry.js +4 -4
- package/dist/cjs/pds-radio.cjs.entry.js +4 -4
- package/dist/cjs/pds-row.cjs.entry.js +1 -1
- package/dist/cjs/pds-select.cjs.entry.js +4 -4
- package/dist/cjs/pds-select.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-sortable-item.cjs.entry.js +2 -2
- package/dist/cjs/pds-sortable.cjs.entry.js +1 -1
- package/dist/cjs/pds-switch.cjs.entry.js +6 -5
- package/dist/cjs/pds-switch.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-tab.cjs.entry.js +4 -4
- package/dist/cjs/pds-tab.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-table-body.cjs.entry.js +1 -1
- package/dist/cjs/pds-table-cell.cjs.entry.js +2 -2
- package/dist/cjs/pds-table-head-cell.cjs.entry.js +33 -6
- package/dist/cjs/pds-table-head-cell.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-table-head.cjs.entry.js +1 -1
- package/dist/cjs/pds-table-row.cjs.entry.js +1 -1
- package/dist/cjs/pds-tabpanel.cjs.entry.js +1 -1
- package/dist/cjs/pds-tabs.cjs.entry.js +1 -1
- package/dist/cjs/pds-text.cjs.entry.js +1 -1
- package/dist/cjs/pds-textarea.cjs.entry.js +7 -7
- package/dist/cjs/pds-textarea.entry.cjs.js.map +1 -1
- package/dist/cjs/pds-toast.cjs.entry.js +3 -3
- package/dist/cjs/pds-tooltip.cjs.entry.js +3 -3
- package/dist/cjs/pine-core.cjs.js +1 -1
- package/dist/collection/collection-manifest.json +1 -0
- package/dist/collection/components/pds-box/pds-box.css +0 -191
- package/dist/collection/components/pds-checkbox/pds-checkbox.js +5 -4
- package/dist/collection/components/pds-checkbox/pds-checkbox.js.map +1 -1
- package/dist/collection/components/pds-combobox/pds-combobox.js +4 -4
- package/dist/collection/components/pds-combobox/pds-combobox.js.map +1 -1
- package/dist/collection/components/pds-dropdown-menu/pds-dropdown-menu-item/pds-dropdown-menu-item.css +3 -1
- package/dist/collection/components/pds-dropdown-menu/pds-dropdown-menu.css +1 -1
- package/dist/collection/components/pds-dropdown-menu/pds-dropdown-menu.js +2 -1
- package/dist/collection/components/pds-dropdown-menu/pds-dropdown-menu.js.map +1 -1
- package/dist/collection/components/pds-filters/pds-filter/pds-filter.css +6 -2
- package/dist/collection/components/pds-input/pds-input.js +3 -3
- package/dist/collection/components/pds-input/pds-input.js.map +1 -1
- package/dist/collection/components/pds-loader/pds-loader.js +2 -2
- package/dist/collection/components/pds-loader/pds-loader.js.map +1 -1
- package/dist/collection/components/pds-multiselect/multiselect-interface.js +2 -0
- package/dist/collection/components/pds-multiselect/multiselect-interface.js.map +1 -0
- package/dist/collection/components/pds-multiselect/pds-multiselect.css +232 -0
- package/dist/collection/components/pds-multiselect/pds-multiselect.js +1153 -0
- package/dist/collection/components/pds-multiselect/pds-multiselect.js.map +1 -0
- package/dist/collection/components/pds-multiselect/stories/pds-multiselect.stories.js +371 -0
- package/dist/collection/components/pds-popover/pds-popover.js +1 -1
- package/dist/collection/components/pds-progress/pds-progress.js +1 -1
- package/dist/collection/components/pds-property/pds-property.js +1 -1
- package/dist/collection/components/pds-radio/pds-radio.js +3 -3
- package/dist/collection/components/pds-radio-group/pds-radio-group.js +3 -3
- package/dist/collection/components/pds-row/pds-row.js +1 -1
- package/dist/collection/components/pds-select/pds-select.js +3 -3
- package/dist/collection/components/pds-select/pds-select.js.map +1 -1
- package/dist/collection/components/pds-sortable/pds-sortable-item/pds-sortable-item.js +1 -1
- package/dist/collection/components/pds-sortable/pds-sortable.js +1 -1
- package/dist/collection/components/pds-switch/pds-switch.js +5 -4
- package/dist/collection/components/pds-switch/pds-switch.js.map +1 -1
- package/dist/collection/components/pds-table/pds-table-body/pds-table-body.js +1 -1
- package/dist/collection/components/pds-table/pds-table-cell/pds-table-cell.js +2 -2
- package/dist/collection/components/pds-table/pds-table-head/pds-table-head.js +1 -1
- package/dist/collection/components/pds-table/pds-table-head-cell/pds-table-head-cell.js +51 -6
- package/dist/collection/components/pds-table/pds-table-head-cell/pds-table-head-cell.js.map +1 -1
- package/dist/collection/components/pds-table/pds-table-row/pds-table-row.js +1 -1
- package/dist/collection/components/pds-table/stories/pds-table.stories.js +32 -4
- package/dist/collection/components/pds-tabs/pds-tab/pds-tab.css +6 -2
- package/dist/collection/components/pds-tabs/pds-tab/pds-tab.js +3 -3
- package/dist/collection/components/pds-tabs/pds-tabpanel/pds-tabpanel.js +1 -1
- package/dist/collection/components/pds-tabs/pds-tabs.js +1 -1
- package/dist/collection/components/pds-text/pds-text.js +1 -1
- package/dist/collection/components/pds-textarea/pds-textarea.js +6 -6
- package/dist/collection/components/pds-textarea/pds-textarea.js.map +1 -1
- package/dist/collection/components/pds-toast/pds-toast.js +3 -3
- package/dist/collection/components/pds-tooltip/pds-tooltip.js +2 -2
- package/dist/docs.json +960 -174
- package/dist/esm/{floating-ui.dom-DbQzNDdQ.js → floating-ui.dom-BO6p966C.js} +163 -42
- package/dist/esm/floating-ui.dom-BO6p966C.js.map +1 -0
- package/dist/esm/{index-xbb79yLt.js → index-DY8eSueV.js} +3 -3
- package/dist/esm/index-DY8eSueV.js.map +1 -0
- package/dist/esm/loader.js +1 -1
- package/dist/esm/pds-accordion.entry.js +1 -1
- package/dist/esm/pds-avatar.entry.js +1 -1
- package/dist/esm/pds-button.entry.js +1 -1
- package/dist/esm/pds-checkbox.entry.js +6 -5
- package/dist/esm/pds-checkbox.entry.js.map +1 -1
- package/dist/esm/pds-chip.entry.js +1 -1
- package/dist/esm/pds-combobox.entry.js +70 -30
- package/dist/esm/pds-combobox.entry.js.map +1 -1
- package/dist/esm/pds-copytext.entry.js +1 -1
- package/dist/esm/pds-dropdown-menu-item.entry.js +1 -1
- package/dist/esm/pds-dropdown-menu-item.entry.js.map +1 -1
- package/dist/esm/pds-dropdown-menu.entry.js +4 -3
- package/dist/esm/pds-dropdown-menu.entry.js.map +1 -1
- package/dist/esm/pds-filter.entry.js +2 -2
- package/dist/esm/pds-filter.entry.js.map +1 -1
- package/dist/esm/pds-input.entry.js +4 -4
- package/dist/esm/pds-input.entry.js.map +1 -1
- package/dist/esm/pds-link.entry.js +1 -1
- package/dist/esm/pds-loader.entry.js +2 -2
- package/dist/esm/pds-loader.entry.js.map +1 -1
- package/dist/esm/pds-multiselect.entry.js +591 -0
- package/dist/esm/pds-multiselect.entry.js.map +1 -0
- package/dist/esm/pds-popover.entry.js +1 -1
- package/dist/esm/pds-progress.entry.js +1 -1
- package/dist/esm/pds-property.entry.js +1 -1
- package/dist/esm/pds-radio-group.entry.js +4 -4
- package/dist/esm/pds-radio.entry.js +4 -4
- package/dist/esm/pds-row.entry.js +1 -1
- package/dist/esm/pds-select.entry.js +4 -4
- package/dist/esm/pds-select.entry.js.map +1 -1
- package/dist/esm/pds-sortable-item.entry.js +2 -2
- package/dist/esm/pds-sortable.entry.js +1 -1
- package/dist/esm/pds-switch.entry.js +6 -5
- package/dist/esm/pds-switch.entry.js.map +1 -1
- package/dist/esm/pds-tab.entry.js +4 -4
- package/dist/esm/pds-tab.entry.js.map +1 -1
- package/dist/esm/pds-table-body.entry.js +1 -1
- package/dist/esm/pds-table-cell.entry.js +2 -2
- package/dist/esm/pds-table-head-cell.entry.js +33 -6
- package/dist/esm/pds-table-head-cell.entry.js.map +1 -1
- package/dist/esm/pds-table-head.entry.js +1 -1
- package/dist/esm/pds-table-row.entry.js +1 -1
- package/dist/esm/pds-tabpanel.entry.js +1 -1
- package/dist/esm/pds-tabs.entry.js +1 -1
- package/dist/esm/pds-text.entry.js +1 -1
- package/dist/esm/pds-textarea.entry.js +7 -7
- package/dist/esm/pds-textarea.entry.js.map +1 -1
- package/dist/esm/pds-toast.entry.js +3 -3
- package/dist/esm/pds-tooltip.entry.js +3 -3
- package/dist/esm/pine-core.js +1 -1
- package/dist/esm-es5/floating-ui.dom-BO6p966C.js +2 -0
- package/dist/esm-es5/floating-ui.dom-BO6p966C.js.map +1 -0
- package/dist/esm-es5/{index-xbb79yLt.js → index-DY8eSueV.js} +1 -1
- package/dist/esm-es5/index-DY8eSueV.js.map +1 -0
- package/dist/esm-es5/loader.js +1 -1
- package/dist/esm-es5/pds-accordion.entry.js +1 -1
- package/dist/esm-es5/pds-avatar.entry.js +1 -1
- package/dist/esm-es5/pds-button.entry.js +1 -1
- package/dist/esm-es5/pds-checkbox.entry.js +1 -1
- package/dist/esm-es5/pds-checkbox.entry.js.map +1 -1
- package/dist/esm-es5/pds-chip.entry.js +1 -1
- package/dist/esm-es5/pds-combobox.entry.js +2 -2
- package/dist/esm-es5/pds-combobox.entry.js.map +1 -1
- package/dist/esm-es5/pds-copytext.entry.js +1 -1
- package/dist/esm-es5/pds-dropdown-menu-item.entry.js +1 -1
- package/dist/esm-es5/pds-dropdown-menu-item.entry.js.map +1 -1
- package/dist/esm-es5/pds-dropdown-menu.entry.js +1 -1
- package/dist/esm-es5/pds-dropdown-menu.entry.js.map +1 -1
- package/dist/esm-es5/pds-filter.entry.js +1 -1
- package/dist/esm-es5/pds-filter.entry.js.map +1 -1
- package/dist/esm-es5/pds-input.entry.js +1 -1
- package/dist/esm-es5/pds-input.entry.js.map +1 -1
- package/dist/esm-es5/pds-link.entry.js +1 -1
- package/dist/esm-es5/pds-loader.entry.js +1 -1
- package/dist/esm-es5/pds-loader.entry.js.map +1 -1
- package/dist/esm-es5/pds-multiselect.entry.js +2 -0
- package/dist/esm-es5/pds-multiselect.entry.js.map +1 -0
- package/dist/esm-es5/pds-popover.entry.js +1 -1
- package/dist/esm-es5/pds-progress.entry.js +1 -1
- package/dist/esm-es5/pds-property.entry.js +1 -1
- package/dist/esm-es5/pds-radio-group.entry.js +1 -1
- package/dist/esm-es5/pds-radio.entry.js +1 -1
- package/dist/esm-es5/pds-row.entry.js +1 -1
- package/dist/esm-es5/pds-select.entry.js +1 -1
- package/dist/esm-es5/pds-select.entry.js.map +1 -1
- package/dist/esm-es5/pds-sortable-item.entry.js +1 -1
- package/dist/esm-es5/pds-sortable.entry.js +1 -1
- package/dist/esm-es5/pds-switch.entry.js +1 -1
- package/dist/esm-es5/pds-switch.entry.js.map +1 -1
- package/dist/esm-es5/pds-tab.entry.js +1 -1
- package/dist/esm-es5/pds-tab.entry.js.map +1 -1
- package/dist/esm-es5/pds-table-body.entry.js +1 -1
- package/dist/esm-es5/pds-table-cell.entry.js +1 -1
- package/dist/esm-es5/pds-table-head-cell.entry.js +1 -1
- package/dist/esm-es5/pds-table-head-cell.entry.js.map +1 -1
- package/dist/esm-es5/pds-table-head.entry.js +1 -1
- package/dist/esm-es5/pds-table-row.entry.js +1 -1
- package/dist/esm-es5/pds-tabpanel.entry.js +1 -1
- package/dist/esm-es5/pds-tabs.entry.js +1 -1
- package/dist/esm-es5/pds-text.entry.js +1 -1
- package/dist/esm-es5/pds-textarea.entry.js +1 -1
- package/dist/esm-es5/pds-textarea.entry.js.map +1 -1
- package/dist/esm-es5/pds-toast.entry.js +1 -1
- package/dist/esm-es5/pds-tooltip.entry.js +1 -1
- package/dist/esm-es5/pine-core.js +1 -1
- package/dist/pine-core/p-02f48157.system.entry.js +2 -0
- package/dist/pine-core/{p-b30424e3.system.entry.js → p-063afa19.system.entry.js} +2 -2
- package/dist/pine-core/p-0sPVsRFU.system.js.map +1 -0
- package/dist/pine-core/{p-15202869.entry.js → p-10dbe3e2.entry.js} +2 -2
- package/dist/pine-core/{p-5b7ab891.entry.js → p-12360e47.entry.js} +2 -2
- package/dist/pine-core/{p-ac14c8e3.system.entry.js → p-137b3289.system.entry.js} +2 -2
- package/dist/pine-core/{p-a737df90.entry.js → p-154a32f4.entry.js} +2 -2
- package/dist/pine-core/{p-098cbcd7.system.entry.js → p-205ec2ac.system.entry.js} +2 -2
- package/dist/pine-core/{p-098cbcd7.system.entry.js.map → p-205ec2ac.system.entry.js.map} +1 -1
- package/dist/pine-core/{p-a847fad3.entry.js → p-2537aacb.entry.js} +2 -2
- package/dist/pine-core/{p-cd335ec2.system.entry.js → p-2fe330d0.system.entry.js} +2 -2
- package/dist/pine-core/p-30ea3668.system.entry.js +2 -0
- package/dist/pine-core/{p-1daf66d1.entry.js → p-31168da5.entry.js} +2 -2
- package/dist/pine-core/{p-732e2564.system.entry.js → p-325b3b0d.system.entry.js} +2 -2
- package/dist/pine-core/{p-4d25449c.entry.js → p-3440138d.entry.js} +2 -2
- package/dist/pine-core/{p-4d25449c.entry.js.map → p-3440138d.entry.js.map} +1 -1
- package/dist/pine-core/p-3c04c17e.system.entry.js +2 -0
- package/dist/pine-core/p-3c04c17e.system.entry.js.map +1 -0
- package/dist/pine-core/p-475bb340.entry.js +2 -0
- package/dist/pine-core/p-475bb340.entry.js.map +1 -0
- package/dist/pine-core/{p-CGo2P4Fr.system.js.map → p-4EbKXnVN.system.js.map} +1 -1
- package/dist/pine-core/{p-4SEjggIC.system.js.map → p-4alPHnzl.system.js.map} +1 -1
- package/dist/pine-core/{p-9bfaed7e.system.entry.js → p-4c23c75b.system.entry.js} +2 -2
- package/dist/pine-core/{p-bdf8bff3.system.entry.js → p-4d85945b.system.entry.js} +2 -2
- package/dist/pine-core/{p-3f8b0885.system.entry.js → p-4d9eee67.system.entry.js} +2 -2
- package/dist/pine-core/{p-4fD2iHS9.system.js.map → p-4f1cRPxE.system.js.map} +1 -1
- package/dist/pine-core/{p-e2104c31.entry.js → p-5040a872.entry.js} +2 -2
- package/dist/pine-core/p-51114c2b.system.entry.js +2 -0
- package/dist/pine-core/p-51114c2b.system.entry.js.map +1 -0
- package/dist/pine-core/p-5L_gsODn.system.js.map +1 -0
- package/dist/pine-core/{p-bbc349b3.system.entry.js → p-5b3ac18e.system.entry.js} +2 -2
- package/dist/pine-core/{p-bbc349b3.system.entry.js.map → p-5b3ac18e.system.entry.js.map} +1 -1
- package/dist/pine-core/{p-a08b60ae.entry.js → p-5b9110fe.entry.js} +2 -2
- package/dist/pine-core/{p-94b1997d.system.entry.js → p-5e92aa34.system.entry.js} +2 -2
- package/dist/pine-core/{p-41d89f20.entry.js → p-5f2865df.entry.js} +2 -2
- package/dist/pine-core/{p-41d89f20.entry.js.map → p-5f2865df.entry.js.map} +1 -1
- package/dist/pine-core/p-622f1342.system.entry.js +4 -0
- package/dist/pine-core/p-622f1342.system.entry.js.map +1 -0
- package/dist/pine-core/p-63269b89.entry.js +2 -0
- package/dist/pine-core/{p-ff182316.system.entry.js → p-6d2da3ca.system.entry.js} +2 -2
- package/dist/pine-core/{p-ff182316.system.entry.js.map → p-6d2da3ca.system.entry.js.map} +1 -1
- package/dist/pine-core/p-6e862168.system.entry.js +2 -0
- package/dist/pine-core/{p-dcc6ad67.system.entry.js.map → p-6e862168.system.entry.js.map} +1 -1
- package/dist/pine-core/{p-cf2e1c07.system.entry.js → p-70aa35fc.system.entry.js} +2 -2
- package/dist/pine-core/{p-fc0ee6da.entry.js → p-757c7b80.entry.js} +2 -2
- package/dist/pine-core/{p-1df25b57.system.entry.js → p-78ee2e08.system.entry.js} +2 -2
- package/dist/pine-core/{p-2319298c.system.entry.js → p-7b5c8248.system.entry.js} +2 -2
- package/dist/pine-core/{p-e3d76aa3.system.entry.js → p-7dd74fe2.system.entry.js} +2 -2
- package/dist/pine-core/p-7dd74fe2.system.entry.js.map +1 -0
- package/dist/pine-core/p-811e510d.system.entry.js +2 -0
- package/dist/pine-core/p-811e510d.system.entry.js.map +1 -0
- package/dist/pine-core/{p-f9ef2f74.system.entry.js → p-87eb8d4b.system.entry.js} +2 -2
- package/dist/pine-core/p-8b201c9a.system.entry.js +2 -0
- package/dist/pine-core/p-8b201c9a.system.entry.js.map +1 -0
- package/dist/pine-core/{p-711989de.entry.js → p-8c0fc8ff.entry.js} +2 -2
- package/dist/pine-core/p-8c0fc8ff.entry.js.map +1 -0
- package/dist/pine-core/p-8eb1c168.entry.js +2 -0
- package/dist/pine-core/{p-e5bc22b6.system.entry.js → p-8fdb10c4.system.entry.js} +2 -2
- package/dist/pine-core/{p-232e4282.system.entry.js → p-90615423.system.entry.js} +2 -2
- package/dist/pine-core/{p-f79f6f08.system.entry.js → p-932283cf.system.entry.js} +2 -2
- package/dist/pine-core/{p-0b05708b.entry.js → p-9ada659b.entry.js} +2 -2
- package/dist/pine-core/{p-4778ae70.entry.js → p-9bb6cc3d.entry.js} +2 -2
- package/dist/pine-core/{p-3f6b9520.entry.js → p-9c928c44.entry.js} +2 -2
- package/dist/pine-core/{p-dad604e4.system.entry.js → p-9e7cd072.system.entry.js} +2 -2
- package/dist/pine-core/p-9e7cd072.system.entry.js.map +1 -0
- package/dist/pine-core/{p-e8aad8dc.entry.js → p-9eccf7b9.entry.js} +2 -2
- package/dist/pine-core/{p-WhfStK1C.system.js.map → p-B0Otb6kF.system.js.map} +1 -1
- package/dist/pine-core/{p-CUmDvil2.system.js.map → p-BA95hFrH.system.js.map} +1 -1
- package/dist/pine-core/{p-B4EMeCRH.system.js.map → p-BHjZufAO.system.js.map} +1 -1
- package/dist/pine-core/{p-IH8oGXiE.system.js.map → p-BJtTt670.system.js.map} +1 -1
- package/dist/pine-core/p-BO6p966C.js +2 -0
- package/dist/pine-core/p-BO6p966C.js.map +1 -0
- package/dist/pine-core/{p-jBhqNO5u.system.js.map → p-BSRmAvMC.system.js.map} +1 -1
- package/dist/pine-core/{p-DyrNlfLT.system.js.map → p-BTe59phF.system.js.map} +1 -1
- package/dist/pine-core/{p-B0Y1Zs9b.system.js.map → p-Bn36FPag.system.js.map} +1 -1
- package/dist/pine-core/{p-DpeOrUYB.system.js.map → p-CG5jdxoZ.system.js.map} +1 -1
- package/dist/pine-core/{p-PMNjgK0C.system.js.map → p-CP2nsJcg.system.js.map} +1 -1
- package/dist/pine-core/{p-CKzDRRgx.system.js → p-CP48ADFM.system.js} +1 -1
- package/dist/pine-core/p-CP48ADFM.system.js.map +1 -0
- package/dist/pine-core/p-CR01VmO6.system.js.map +1 -0
- package/dist/pine-core/{p-CAnnMfDw.system.js.map → p-CSLo9qKS.system.js.map} +1 -1
- package/dist/pine-core/{p-DmVKABQy.system.js.map → p-CboCokff.system.js.map} +1 -1
- package/dist/pine-core/{p-r_cS5LMw.system.js.map → p-Civ2VHC7.system.js.map} +1 -1
- package/dist/pine-core/{p-ChiYqN-p.system.js.map → p-CmquVvkz.system.js.map} +1 -1
- package/dist/pine-core/{p-CXGuX44q.system.js.map → p-Cn_QqTXg.system.js.map} +1 -1
- package/dist/pine-core/{p-tHMXRB8d.system.js.map → p-CpyTw2IQ.system.js.map} +1 -1
- package/dist/pine-core/{p-Brpt0zl5.system.js.map → p-Ct9csNdF.system.js.map} +1 -1
- package/dist/pine-core/{p-B_Co5NfG.system.js.map → p-Cun139qe.system.js.map} +1 -1
- package/dist/pine-core/p-D2eS6fhD.system.js +2 -0
- package/dist/pine-core/p-D2eS6fhD.system.js.map +1 -0
- package/dist/pine-core/{p-CTfQ_9yC.system.js.map → p-DFXWnbHE.system.js.map} +1 -1
- package/dist/pine-core/{p-xbb79yLt.js → p-DY8eSueV.js} +1 -1
- package/dist/pine-core/p-DY8eSueV.js.map +1 -0
- package/dist/pine-core/p-DbNPEZgc.system.js.map +1 -0
- package/dist/pine-core/p-DieNsvcz.system.js.map +1 -0
- package/dist/pine-core/{p-DB45WSlG.system.js.map → p-DwQewDCV.system.js.map} +1 -1
- package/dist/pine-core/p-JAVnELnm.system.js +1 -1
- package/dist/pine-core/{p-DC2NZwtk.system.js.map → p-LM0mZTib.system.js.map} +1 -1
- package/dist/pine-core/{p-DAvCgWA9.system.js.map → p-Lk6DnEPT.system.js.map} +1 -1
- package/dist/pine-core/{p-Bjj4Pcbb.system.js.map → p-YqHO7iPZ.system.js.map} +1 -1
- package/dist/pine-core/{p-00568c20.system.entry.js → p-a07b8e45.system.entry.js} +2 -2
- package/dist/pine-core/{p-c5013d20.entry.js → p-a3cdff85.entry.js} +2 -2
- package/dist/pine-core/{p-a4b16b32.system.entry.js → p-a5b24b1d.system.entry.js} +2 -2
- package/dist/pine-core/{p-596acf65.entry.js → p-a99e8caf.entry.js} +2 -2
- package/dist/pine-core/p-aPfTGFhq.system.js.map +1 -0
- package/dist/pine-core/{p-646ac76d.entry.js → p-ab3b6e0c.entry.js} +2 -2
- package/dist/pine-core/p-ab3b6e0c.entry.js.map +1 -0
- package/dist/pine-core/{p-002fe322.system.entry.js → p-ac240034.system.entry.js} +2 -2
- package/dist/pine-core/{p-fe28b975.system.entry.js → p-ac56273a.system.entry.js} +2 -2
- package/dist/pine-core/{p-fe28b975.system.entry.js.map → p-ac56273a.system.entry.js.map} +1 -1
- package/dist/pine-core/p-b41465b8.entry.js +3 -0
- package/dist/pine-core/p-b41465b8.entry.js.map +1 -0
- package/dist/pine-core/{p-b02936d2.entry.js → p-ba623ced.entry.js} +2 -2
- package/dist/pine-core/p-ba623ced.entry.js.map +1 -0
- package/dist/pine-core/{p-f8fba315.entry.js → p-bc85016b.entry.js} +2 -2
- package/dist/pine-core/{p-61588eac.entry.js → p-bddc9c5a.entry.js} +2 -2
- package/dist/pine-core/p-bff9fb8e.entry.js +2 -0
- package/dist/pine-core/p-bff9fb8e.entry.js.map +1 -0
- package/dist/pine-core/{p--gPqixhD.system.js.map → p-bs74TBAh.system.js.map} +1 -1
- package/dist/pine-core/{p-7de73ac5.entry.js → p-c24d11c7.entry.js} +2 -2
- package/dist/pine-core/p-c292e5da.system.entry.js +2 -0
- package/dist/pine-core/{p-6bc7d67f.system.entry.js.map → p-c292e5da.system.entry.js.map} +1 -1
- package/dist/pine-core/p-c68bceb1.entry.js +2 -0
- package/dist/pine-core/{p-478d1107.entry.js.map → p-c68bceb1.entry.js.map} +1 -1
- package/dist/pine-core/{p-0ace9c16.entry.js → p-c7c00a27.entry.js} +2 -2
- package/dist/pine-core/{p-cb6c279a.system.entry.js → p-cac3128b.system.entry.js} +2 -2
- package/dist/pine-core/p-ccab748a.entry.js +2 -0
- package/dist/pine-core/p-ccab748a.entry.js.map +1 -0
- package/dist/pine-core/p-d41112ad.entry.js +2 -0
- package/dist/pine-core/{p-f82b464c.entry.js.map → p-d41112ad.entry.js.map} +1 -1
- package/dist/pine-core/{p-6cba6806.entry.js → p-d6302edd.entry.js} +2 -2
- package/dist/pine-core/{p-e011d7e5.entry.js → p-d9693048.entry.js} +2 -2
- package/dist/pine-core/{p-e011d7e5.entry.js.map → p-d9693048.entry.js.map} +1 -1
- package/dist/pine-core/{p-04294b28.system.entry.js → p-daa36570.system.entry.js} +2 -2
- package/dist/pine-core/{p-15650db8.entry.js → p-e6dc2297.entry.js} +2 -2
- package/dist/pine-core/{p-9f53eb94.system.entry.js → p-e8cf15d7.system.entry.js} +2 -2
- package/dist/pine-core/p-eb026745.entry.js +2 -0
- package/dist/pine-core/{p-95f2782c.entry.js → p-f47d6724.entry.js} +2 -2
- package/dist/pine-core/p-f47d6724.entry.js.map +1 -0
- package/dist/pine-core/{p-D8Jc24Qq.system.js.map → p-htODgUCV.system.js.map} +1 -1
- package/dist/pine-core/{p-DYq1Mef8.system.js.map → p-j0609tLE.system.js.map} +1 -1
- package/dist/pine-core/{p-DoP8Sl1O.system.js.map → p-rcUX-rt5.system.js.map} +1 -1
- package/dist/pine-core/p-ztsUkqit.system.js.map +1 -0
- package/dist/pine-core/pds-checkbox.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-combobox.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-dropdown-menu-item.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-dropdown-menu.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-filter.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-input.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-loader.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-multiselect.entry.esm.js.map +1 -0
- package/dist/pine-core/pds-select.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-switch.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-tab.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-table-head-cell.entry.esm.js.map +1 -1
- package/dist/pine-core/pds-textarea.entry.esm.js.map +1 -1
- package/dist/pine-core/pine-core.esm.js +1 -1
- package/dist/types/components/pds-loader/pds-loader.d.ts +1 -1
- package/dist/types/components/pds-multiselect/multiselect-interface.d.ts +24 -0
- package/dist/types/components/pds-multiselect/pds-multiselect.d.ts +175 -0
- package/dist/types/components/pds-table/pds-table-head-cell/pds-table-head-cell.d.ts +10 -0
- package/dist/types/components.d.ts +250 -0
- package/dist/vscode.html-data.json +156 -0
- package/hydrate/index.js +939 -118
- package/hydrate/index.mjs +939 -118
- package/package.json +5 -5
- package/dist/cjs/floating-ui.dom-DTAy35nv.js.map +0 -1
- package/dist/cjs/index-CMeuo765.js.map +0 -1
- package/dist/esm/floating-ui.dom-DbQzNDdQ.js.map +0 -1
- package/dist/esm/index-xbb79yLt.js.map +0 -1
- package/dist/esm-es5/floating-ui.dom-DbQzNDdQ.js +0 -2
- package/dist/esm-es5/floating-ui.dom-DbQzNDdQ.js.map +0 -1
- package/dist/esm-es5/index-xbb79yLt.js.map +0 -1
- package/dist/pine-core/p-43990889.entry.js +0 -2
- package/dist/pine-core/p-478d1107.entry.js +0 -2
- package/dist/pine-core/p-534e44cb.system.entry.js +0 -4
- package/dist/pine-core/p-534e44cb.system.entry.js.map +0 -1
- package/dist/pine-core/p-54a56826.entry.js +0 -3
- package/dist/pine-core/p-54a56826.entry.js.map +0 -1
- package/dist/pine-core/p-553e4543.entry.js +0 -2
- package/dist/pine-core/p-553e4543.entry.js.map +0 -1
- package/dist/pine-core/p-5f6cd30d.system.entry.js +0 -2
- package/dist/pine-core/p-5f6cd30d.system.entry.js.map +0 -1
- package/dist/pine-core/p-646ac76d.entry.js.map +0 -1
- package/dist/pine-core/p-6bc7d67f.system.entry.js +0 -2
- package/dist/pine-core/p-711989de.entry.js.map +0 -1
- package/dist/pine-core/p-8323fe69.system.entry.js +0 -2
- package/dist/pine-core/p-8323fe69.system.entry.js.map +0 -1
- package/dist/pine-core/p-95f2782c.entry.js.map +0 -1
- package/dist/pine-core/p-9e62c418.system.entry.js +0 -2
- package/dist/pine-core/p-9e62c418.system.entry.js.map +0 -1
- package/dist/pine-core/p-BOmQOnQe.system.js +0 -2
- package/dist/pine-core/p-BOmQOnQe.system.js.map +0 -1
- package/dist/pine-core/p-Bnp3zJ0T.system.js.map +0 -1
- package/dist/pine-core/p-CKzDRRgx.system.js.map +0 -1
- package/dist/pine-core/p-DSwKfctG.system.js.map +0 -1
- package/dist/pine-core/p-DbQzNDdQ.js +0 -2
- package/dist/pine-core/p-DbQzNDdQ.js.map +0 -1
- package/dist/pine-core/p-DfCCzxYg.system.js.map +0 -1
- package/dist/pine-core/p-X0_TH-op.system.js.map +0 -1
- package/dist/pine-core/p-XCTiWii8.system.js.map +0 -1
- package/dist/pine-core/p-ac2f9463.entry.js +0 -2
- package/dist/pine-core/p-ac2f9463.entry.js.map +0 -1
- package/dist/pine-core/p-b02936d2.entry.js.map +0 -1
- package/dist/pine-core/p-b59a0c6b.system.entry.js +0 -2
- package/dist/pine-core/p-d0e336b7.system.entry.js +0 -2
- package/dist/pine-core/p-dad604e4.system.entry.js.map +0 -1
- package/dist/pine-core/p-dcc6ad67.system.entry.js +0 -2
- package/dist/pine-core/p-e3d76aa3.system.entry.js.map +0 -1
- package/dist/pine-core/p-e7e25d42.entry.js +0 -2
- package/dist/pine-core/p-f82b464c.entry.js +0 -2
- package/dist/pine-core/p-f92055f3.entry.js +0 -2
- package/dist/pine-core/p-xbb79yLt.js.map +0 -1
- package/dist/pine-core/p-zgS7Vsk7.system.js.map +0 -1
- /package/dist/pine-core/{p-b59a0c6b.system.entry.js.map → p-02f48157.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-b30424e3.system.entry.js.map → p-063afa19.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-15202869.entry.js.map → p-10dbe3e2.entry.js.map} +0 -0
- /package/dist/pine-core/{p-5b7ab891.entry.js.map → p-12360e47.entry.js.map} +0 -0
- /package/dist/pine-core/{p-ac14c8e3.system.entry.js.map → p-137b3289.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-a737df90.entry.js.map → p-154a32f4.entry.js.map} +0 -0
- /package/dist/pine-core/{p-a847fad3.entry.js.map → p-2537aacb.entry.js.map} +0 -0
- /package/dist/pine-core/{p-cd335ec2.system.entry.js.map → p-2fe330d0.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-d0e336b7.system.entry.js.map → p-30ea3668.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-1daf66d1.entry.js.map → p-31168da5.entry.js.map} +0 -0
- /package/dist/pine-core/{p-732e2564.system.entry.js.map → p-325b3b0d.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-9bfaed7e.system.entry.js.map → p-4c23c75b.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-bdf8bff3.system.entry.js.map → p-4d85945b.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-3f8b0885.system.entry.js.map → p-4d9eee67.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-e2104c31.entry.js.map → p-5040a872.entry.js.map} +0 -0
- /package/dist/pine-core/{p-a08b60ae.entry.js.map → p-5b9110fe.entry.js.map} +0 -0
- /package/dist/pine-core/{p-94b1997d.system.entry.js.map → p-5e92aa34.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-43990889.entry.js.map → p-63269b89.entry.js.map} +0 -0
- /package/dist/pine-core/{p-cf2e1c07.system.entry.js.map → p-70aa35fc.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-fc0ee6da.entry.js.map → p-757c7b80.entry.js.map} +0 -0
- /package/dist/pine-core/{p-1df25b57.system.entry.js.map → p-78ee2e08.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-2319298c.system.entry.js.map → p-7b5c8248.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-f9ef2f74.system.entry.js.map → p-87eb8d4b.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-e7e25d42.entry.js.map → p-8eb1c168.entry.js.map} +0 -0
- /package/dist/pine-core/{p-e5bc22b6.system.entry.js.map → p-8fdb10c4.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-232e4282.system.entry.js.map → p-90615423.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-f79f6f08.system.entry.js.map → p-932283cf.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-0b05708b.entry.js.map → p-9ada659b.entry.js.map} +0 -0
- /package/dist/pine-core/{p-4778ae70.entry.js.map → p-9bb6cc3d.entry.js.map} +0 -0
- /package/dist/pine-core/{p-3f6b9520.entry.js.map → p-9c928c44.entry.js.map} +0 -0
- /package/dist/pine-core/{p-e8aad8dc.entry.js.map → p-9eccf7b9.entry.js.map} +0 -0
- /package/dist/pine-core/{p-00568c20.system.entry.js.map → p-a07b8e45.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-c5013d20.entry.js.map → p-a3cdff85.entry.js.map} +0 -0
- /package/dist/pine-core/{p-a4b16b32.system.entry.js.map → p-a5b24b1d.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-596acf65.entry.js.map → p-a99e8caf.entry.js.map} +0 -0
- /package/dist/pine-core/{p-002fe322.system.entry.js.map → p-ac240034.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-f8fba315.entry.js.map → p-bc85016b.entry.js.map} +0 -0
- /package/dist/pine-core/{p-61588eac.entry.js.map → p-bddc9c5a.entry.js.map} +0 -0
- /package/dist/pine-core/{p-7de73ac5.entry.js.map → p-c24d11c7.entry.js.map} +0 -0
- /package/dist/pine-core/{p-0ace9c16.entry.js.map → p-c7c00a27.entry.js.map} +0 -0
- /package/dist/pine-core/{p-cb6c279a.system.entry.js.map → p-cac3128b.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-6cba6806.entry.js.map → p-d6302edd.entry.js.map} +0 -0
- /package/dist/pine-core/{p-04294b28.system.entry.js.map → p-daa36570.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-15650db8.entry.js.map → p-e6dc2297.entry.js.map} +0 -0
- /package/dist/pine-core/{p-9f53eb94.system.entry.js.map → p-e8cf15d7.system.entry.js.map} +0 -0
- /package/dist/pine-core/{p-f92055f3.entry.js.map → p-eb026745.entry.js.map} +0 -0
|
@@ -0,0 +1,593 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var index = require('./index-CI0W8NCh.js');
|
|
4
|
+
var floatingUi_dom = require('./floating-ui.dom-Ca6tS7ef.js');
|
|
5
|
+
var utils = require('./utils-7jx8T2mW.js');
|
|
6
|
+
var form = require('./form-hmpgbT1I.js');
|
|
7
|
+
var index$1 = require('./index-BA--jsiy.js');
|
|
8
|
+
|
|
9
|
+
const pdsMultiselectCss = ":host{display:block}:host([aria-disabled=true]) .pds-multiselect__trigger{background:var(--pine-color-background-container-disabled);border-color:var(--pine-color-border-disabled);color:var(--pine-color-text-disabled);cursor:not-allowed}:host([aria-disabled=true]) .pds-multiselect__icon{color:var(--pine-color-text-disabled)}.pds-multiselect{position:relative}.pds-multiselect__label{color:var(--pine-color-text-label);display:block;font:var(--pine-typography-body-medium);letter-spacing:var(--pine-letter-spacing);-webkit-margin-after:var(--pine-dimension-2xs);margin-block-end:var(--pine-dimension-2xs)}.pds-multiselect__wrapper{position:relative}.pds-multiselect__trigger{-ms-flex-align:center;align-items:center;background:var(--pine-color-background-container);border:var(--pine-border);border-radius:var(--pine-dimension-125);cursor:pointer;display:-ms-flexbox;display:flex;font:var(--pine-typography-body);gap:var(--pine-dimension-xs);-ms-flex-pack:justify;justify-content:space-between;letter-spacing:var(--pine-letter-spacing);min-height:var(--pine-dimension-550);padding:var(--pine-dimension-xs) var(--pine-dimension-sm);position:relative;text-align:start;-webkit-transition:border-color 0.2s ease, -webkit-box-shadow 0.2s ease;transition:border-color 0.2s ease, -webkit-box-shadow 0.2s ease;transition:border-color 0.2s ease, box-shadow 0.2s ease;transition:border-color 0.2s ease, box-shadow 0.2s ease, -webkit-box-shadow 0.2s ease;width:100%}.pds-multiselect__trigger:hover:not(.pds-multiselect__trigger--disabled){border-color:var(--pine-color-border-hover)}.pds-multiselect__trigger:focus:not(.pds-multiselect__trigger--disabled){border-color:var(--pine-color-border-active);outline:var(--pine-outline-focus);outline-offset:var(--pine-border-width)}.pds-multiselect__trigger.pds-multiselect__trigger--open{border-color:var(--pine-color-border-active)}.pds-multiselect__trigger.pds-multiselect__trigger--invalid{background-color:var(--pine-color-red-050);border-color:var(--pine-color-border-danger)}.pds-multiselect__trigger.pds-multiselect__trigger--invalid:focus{outline-color:var(--pine-color-focus-ring-danger)}.pds-multiselect__trigger.pds-multiselect__trigger--disabled{background:var(--pine-color-background-container-disabled);border-color:var(--pine-color-border-disabled);color:var(--pine-color-text-disabled);cursor:not-allowed}.pds-multiselect__trigger-text{color:var(--pine-color-text-strong);-ms-flex:1;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pds-multiselect__trigger-text.pds-multiselect__trigger-text--placeholder{color:var(--pine-color-text-placeholder)}.pds-multiselect__trigger--disabled .pds-multiselect__trigger-text{color:var(--pine-color-text-disabled)}.pds-multiselect__icon{color:var(--pine-color-icon);-ms-flex-negative:var(--pine-dimension-none);flex-shrink:var(--pine-dimension-none)}.pds-multiselect__panel{background:var(--pine-color-background-container);border-radius:var(--pine-dimension-125);-webkit-box-shadow:var(--pine-box-shadow);box-shadow:var(--pine-box-shadow);-webkit-box-sizing:border-box;box-sizing:border-box;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;position:absolute;z-index:var(--pine-z-index-raised)}.pds-multiselect__search{-ms-flex-align:center;align-items:center;-webkit-border-after:var(--pine-border);border-block-end:var(--pine-border);border-block-end-color:var(--pine-color-border-subtle);display:-ms-flexbox;display:flex;gap:var(--pine-dimension-xs);padding:var(--pine-dimension-xs) var(--pine-dimension-sm)}.pds-multiselect__search pds-icon{color:var(--pine-color-text-muted);-ms-flex-negative:var(--pine-dimension-none);flex-shrink:var(--pine-dimension-none)}.pds-multiselect__search-input{background:transparent;border:var(--pine-dimension-none);color:var(--pine-color-text-strong);-ms-flex:1;flex:1;font:var(--pine-typography-body);letter-spacing:var(--pine-letter-spacing);min-width:var(--pine-dimension-none);outline:none}.pds-multiselect__search-input::-webkit-input-placeholder{color:var(--pine-color-text-placeholder)}.pds-multiselect__search-input::-moz-placeholder{color:var(--pine-color-text-placeholder)}.pds-multiselect__search-input:-ms-input-placeholder{color:var(--pine-color-text-placeholder)}.pds-multiselect__search-input::-ms-input-placeholder{color:var(--pine-color-text-placeholder)}.pds-multiselect__search-input::placeholder{color:var(--pine-color-text-placeholder)}.pds-multiselect__selected-section{-webkit-border-after:var(--pine-border);border-block-end:var(--pine-border);border-block-end-color:var(--pine-color-border-subtle);padding:var(--pine-dimension-xs)}.pds-multiselect__selected-list{list-style:none;margin:var(--pine-dimension-none);padding:var(--pine-dimension-none)}.pds-multiselect__selected-item{color:var(--pine-color-text-strong);font:var(--pine-typography-body);letter-spacing:var(--pine-letter-spacing);overflow:hidden;padding:var(--pine-dimension-2xs) var(--pine-dimension-xs);text-overflow:ellipsis;white-space:nowrap}.pds-multiselect__listbox{background:transparent;border:var(--pine-dimension-none);-webkit-box-sizing:border-box;box-sizing:border-box;list-style:none;margin:var(--pine-dimension-none);overflow-y:auto;padding:var(--pine-dimension-xs)}.pds-multiselect__option{-ms-flex-align:center;align-items:center;background:transparent;border-radius:var(--pine-dimension-xs);cursor:pointer;display:-ms-flexbox;display:flex;padding:var(--pine-dimension-2xs) var(--pine-dimension-xs);-webkit-transition:background 0.15s;transition:background 0.15s}.pds-multiselect__option pds-checkbox{pointer-events:none;width:100%}.pds-multiselect__option:hover,.pds-multiselect__option.pds-multiselect__option--highlighted{background:var(--pine-color-background-muted)}.pds-multiselect__option:focus-visible{outline:var(--pine-dimension-none)}.pds-multiselect__empty,.pds-multiselect__loading{-ms-flex-align:center;align-items:center;color:var(--pine-color-text-muted);display:-ms-flexbox;display:flex;font:var(--pine-typography-body);-ms-flex-pack:center;justify-content:center;padding:var(--pine-dimension-sm)}.pds-multiselect__load-more{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;padding:var(--pine-dimension-xs)}.pds-multiselect__helper{color:var(--pine-color-text-message);font:var(--pine-typography-body-sm);-webkit-margin-before:var(--pine-dimension-2xs);margin-block-start:var(--pine-dimension-2xs);-webkit-margin-start:var(--pine-dimension-none);margin-inline-start:var(--pine-dimension-none)}.pds-multiselect__error{-ms-flex-align:start;align-items:flex-start;color:var(--pine-color-text-message-danger);display:-ms-flexbox;display:flex;font:var(--pine-typography-body-sm);gap:var(--pine-dimension-2xs);-webkit-margin-before:var(--pine-dimension-2xs);margin-block-start:var(--pine-dimension-2xs);-webkit-margin-start:var(--pine-dimension-none);margin-inline-start:var(--pine-dimension-none)}.pds-multiselect__error pds-icon{-ms-flex-negative:var(--pine-dimension-none);flex-shrink:var(--pine-dimension-none);-webkit-margin-before:var(--pine-dimension-025);margin-block-start:var(--pine-dimension-025)}.visually-hidden{border:var(--pine-dimension-none);clip:rect(0 0 0 0);-webkit-clip-path:polygon(0 0, 0 0, 0 0);clip-path:polygon(0 0, 0 0, 0 0);height:1px;margin:-1px;overflow:hidden;padding:var(--pine-dimension-none);position:absolute;white-space:nowrap;width:1px}";
|
|
10
|
+
|
|
11
|
+
const PdsMultiselect = class {
|
|
12
|
+
constructor(hostRef) {
|
|
13
|
+
index.registerInstance(this, hostRef);
|
|
14
|
+
this.pdsMultiselectChange = index.createEvent(this, "pdsMultiselectChange");
|
|
15
|
+
this.pdsMultiselectSearch = index.createEvent(this, "pdsMultiselectSearch");
|
|
16
|
+
this.pdsMultiselectLoadOptions = index.createEvent(this, "pdsMultiselectLoadOptions");
|
|
17
|
+
/**
|
|
18
|
+
* Placeholder text for the input field.
|
|
19
|
+
*/
|
|
20
|
+
this.placeholder = 'Select...';
|
|
21
|
+
/**
|
|
22
|
+
* Array of selected option values.
|
|
23
|
+
*/
|
|
24
|
+
this.value = [];
|
|
25
|
+
/**
|
|
26
|
+
* Determines whether or not the multiselect is disabled.
|
|
27
|
+
*/
|
|
28
|
+
this.disabled = false;
|
|
29
|
+
/**
|
|
30
|
+
* HTTP method for async requests.
|
|
31
|
+
*/
|
|
32
|
+
this.asyncMethod = 'GET';
|
|
33
|
+
/**
|
|
34
|
+
* Debounce delay in milliseconds for search/fetch.
|
|
35
|
+
*/
|
|
36
|
+
this.debounce = 300;
|
|
37
|
+
/**
|
|
38
|
+
* Maximum height of the dropdown before scrolling.
|
|
39
|
+
*/
|
|
40
|
+
this.maxHeight = '300px';
|
|
41
|
+
/**
|
|
42
|
+
* Width of the trigger button (and reference for dropdown positioning).
|
|
43
|
+
*/
|
|
44
|
+
this.triggerWidth = '100%';
|
|
45
|
+
/**
|
|
46
|
+
* Minimum width of the dropdown panel.
|
|
47
|
+
*/
|
|
48
|
+
this.minWidth = '250px';
|
|
49
|
+
/**
|
|
50
|
+
* Visually hides the label but keeps it accessible.
|
|
51
|
+
*/
|
|
52
|
+
this.hideLabel = false;
|
|
53
|
+
/**
|
|
54
|
+
* If true, the multiselect is required.
|
|
55
|
+
*/
|
|
56
|
+
this.required = false;
|
|
57
|
+
/**
|
|
58
|
+
* Whether the component is currently loading async options.
|
|
59
|
+
*/
|
|
60
|
+
this.loading = false;
|
|
61
|
+
// Internal state
|
|
62
|
+
this.isOpen = false;
|
|
63
|
+
this.searchQuery = '';
|
|
64
|
+
this.highlightedIndex = -1;
|
|
65
|
+
this.internalOptions = [];
|
|
66
|
+
this.selectedItems = [];
|
|
67
|
+
this.currentPage = 1;
|
|
68
|
+
this.hasMore = false;
|
|
69
|
+
// Flag to prevent focusout from closing during open transition
|
|
70
|
+
this.isOpening = false;
|
|
71
|
+
this.handleTriggerClick = () => {
|
|
72
|
+
if (this.disabled)
|
|
73
|
+
return;
|
|
74
|
+
if (this.isOpen) {
|
|
75
|
+
this.closeDropdown();
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
this.openDropdown();
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
this.handleTriggerKeyDown = (e) => {
|
|
82
|
+
switch (e.key) {
|
|
83
|
+
case 'ArrowDown':
|
|
84
|
+
case 'ArrowUp':
|
|
85
|
+
case 'Enter':
|
|
86
|
+
case ' ':
|
|
87
|
+
e.preventDefault();
|
|
88
|
+
if (!this.isOpen) {
|
|
89
|
+
this.openDropdown();
|
|
90
|
+
}
|
|
91
|
+
break;
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
this.handleSearchInputChange = (e) => {
|
|
95
|
+
const target = e.target;
|
|
96
|
+
this.searchQuery = target.value;
|
|
97
|
+
this.highlightedIndex = -1;
|
|
98
|
+
// Emit search event for consumer-managed async
|
|
99
|
+
this.pdsMultiselectSearch.emit({ query: this.searchQuery });
|
|
100
|
+
// Fetch from async URL if configured
|
|
101
|
+
if (this.asyncUrl) {
|
|
102
|
+
this.debouncedFetchAsyncOptions(this.searchQuery, 1);
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
this.handleSearchInputKeyDown = (e) => {
|
|
106
|
+
const filteredOptions = this.getFilteredOptions();
|
|
107
|
+
switch (e.key) {
|
|
108
|
+
case 'ArrowDown':
|
|
109
|
+
e.preventDefault();
|
|
110
|
+
this.highlightedIndex = Math.min(this.highlightedIndex + 1, filteredOptions.length - 1);
|
|
111
|
+
this.scrollOptionIntoView();
|
|
112
|
+
break;
|
|
113
|
+
case 'ArrowUp':
|
|
114
|
+
e.preventDefault();
|
|
115
|
+
this.highlightedIndex = Math.max(this.highlightedIndex - 1, 0);
|
|
116
|
+
this.scrollOptionIntoView();
|
|
117
|
+
break;
|
|
118
|
+
case 'Enter':
|
|
119
|
+
e.preventDefault();
|
|
120
|
+
if (this.highlightedIndex >= 0) {
|
|
121
|
+
const option = filteredOptions[this.highlightedIndex];
|
|
122
|
+
if (option) {
|
|
123
|
+
this.selectOption(option);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
break;
|
|
127
|
+
// Escape is handled by the global @Listen('keydown') handler
|
|
128
|
+
case 'Tab':
|
|
129
|
+
this.closeDropdown();
|
|
130
|
+
break;
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
this.handleContainerFocusOut = () => {
|
|
134
|
+
// Use setTimeout to delay the check - this allows click events and focus transitions to complete
|
|
135
|
+
// before we decide to close the dropdown
|
|
136
|
+
setTimeout(() => {
|
|
137
|
+
var _a;
|
|
138
|
+
// Don't close if we're in the middle of opening or already closed
|
|
139
|
+
if (!this.isOpen || this.isOpening)
|
|
140
|
+
return;
|
|
141
|
+
const activeElement = document.activeElement;
|
|
142
|
+
// Check if focus is within our component's shadow root
|
|
143
|
+
const isInShadowRoot = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement);
|
|
144
|
+
// Also check if focus is on the host element itself
|
|
145
|
+
const isOnHost = activeElement === this.el;
|
|
146
|
+
if (!isInShadowRoot && !isOnHost) {
|
|
147
|
+
this.closeDropdown();
|
|
148
|
+
}
|
|
149
|
+
}, 0);
|
|
150
|
+
};
|
|
151
|
+
this.handleOptionMouseDown = (option) => (e) => {
|
|
152
|
+
e.preventDefault(); // Prevent focus change
|
|
153
|
+
this.toggleOption(option);
|
|
154
|
+
};
|
|
155
|
+
this.handleOptionMouseEnter = (index) => () => {
|
|
156
|
+
this.highlightedIndex = index;
|
|
157
|
+
};
|
|
158
|
+
this.handleScroll = (e) => {
|
|
159
|
+
if (!this.asyncUrl || !this.hasMore || this.loading)
|
|
160
|
+
return;
|
|
161
|
+
const target = e.target;
|
|
162
|
+
const scrollBottom = target.scrollHeight - target.scrollTop - target.clientHeight;
|
|
163
|
+
// Load more when near bottom (within 50px)
|
|
164
|
+
if (scrollBottom < 50) {
|
|
165
|
+
this.pdsMultiselectLoadOptions.emit({
|
|
166
|
+
query: this.searchQuery,
|
|
167
|
+
page: this.currentPage + 1,
|
|
168
|
+
});
|
|
169
|
+
this.debouncedFetchAsyncOptions(this.searchQuery, this.currentPage + 1);
|
|
170
|
+
}
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
connectedCallback() {
|
|
174
|
+
// Initialize ElementInternals for form association (only once per element instance)
|
|
175
|
+
if (this.el.attachInternals && !this.internals) {
|
|
176
|
+
this.internals = this.el.attachInternals();
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
componentWillLoad() {
|
|
180
|
+
this.originalSearchEmitter = this.pdsMultiselectSearch;
|
|
181
|
+
this.syncSelectedItems();
|
|
182
|
+
}
|
|
183
|
+
componentDidLoad() {
|
|
184
|
+
this.setupDebounce();
|
|
185
|
+
this.setupMutationObserver();
|
|
186
|
+
this.setupSlotChangeListener();
|
|
187
|
+
this.updateFormValue();
|
|
188
|
+
// Ensure preselected values sync after DOM is fully ready
|
|
189
|
+
// This handles cases where slot content loads after initial render (e.g., in docs/MDX)
|
|
190
|
+
requestAnimationFrame(() => {
|
|
191
|
+
this.updateOptionsFromSlot();
|
|
192
|
+
this.syncSelectedItems();
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
setupSlotChangeListener() {
|
|
196
|
+
var _a;
|
|
197
|
+
const slot = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('slot:not([name])');
|
|
198
|
+
if (slot) {
|
|
199
|
+
slot.addEventListener('slotchange', () => {
|
|
200
|
+
this.updateOptionsFromSlot();
|
|
201
|
+
this.syncSelectedItems();
|
|
202
|
+
});
|
|
203
|
+
// Also call it immediately in case content is already slotted
|
|
204
|
+
this.updateOptionsFromSlot();
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
disconnectedCallback() {
|
|
208
|
+
var _a, _b;
|
|
209
|
+
(_a = this.observer) === null || _a === void 0 ? void 0 : _a.disconnect();
|
|
210
|
+
(_b = this.cleanupAutoUpdate) === null || _b === void 0 ? void 0 : _b.call(this);
|
|
211
|
+
this.clearAsyncFetchState();
|
|
212
|
+
}
|
|
213
|
+
setupDebounce() {
|
|
214
|
+
const { pdsMultiselectSearch, debounce, originalSearchEmitter } = this;
|
|
215
|
+
this.pdsMultiselectSearch = debounce === undefined
|
|
216
|
+
? originalSearchEmitter !== null && originalSearchEmitter !== void 0 ? originalSearchEmitter : pdsMultiselectSearch
|
|
217
|
+
: utils.debounceEvent(pdsMultiselectSearch, debounce);
|
|
218
|
+
}
|
|
219
|
+
valueChanged(newValue) {
|
|
220
|
+
// Handle JSON string values (from HTML attributes)
|
|
221
|
+
if (typeof newValue === 'string') {
|
|
222
|
+
try {
|
|
223
|
+
const parsed = JSON.parse(newValue);
|
|
224
|
+
if (Array.isArray(parsed)) {
|
|
225
|
+
this.value = parsed;
|
|
226
|
+
return; // The assignment will trigger this watcher again with the array
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
catch (_a) {
|
|
230
|
+
// Not valid JSON, treat as single value
|
|
231
|
+
this.value = newValue ? [newValue] : [];
|
|
232
|
+
return;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
this.syncSelectedItems();
|
|
236
|
+
this.updateFormValue();
|
|
237
|
+
}
|
|
238
|
+
optionsChanged() {
|
|
239
|
+
if (this.options) {
|
|
240
|
+
this.internalOptions = [...this.options];
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
internalOptionsChanged() {
|
|
244
|
+
// Re-sync selected items when options become available
|
|
245
|
+
// This handles the case where value is set before options are loaded (e.g., from slot)
|
|
246
|
+
this.syncSelectedItems();
|
|
247
|
+
}
|
|
248
|
+
/**
|
|
249
|
+
* Sets focus on the trigger button.
|
|
250
|
+
*/
|
|
251
|
+
async setFocus() {
|
|
252
|
+
var _a;
|
|
253
|
+
(_a = this.triggerEl) === null || _a === void 0 ? void 0 : _a.focus();
|
|
254
|
+
}
|
|
255
|
+
/**
|
|
256
|
+
* Handle global keyboard events for accessibility.
|
|
257
|
+
* Closes dropdown on Escape key press regardless of focus location.
|
|
258
|
+
*/
|
|
259
|
+
handleWindowKeyDown(event) {
|
|
260
|
+
var _a;
|
|
261
|
+
if (!this.isOpen)
|
|
262
|
+
return;
|
|
263
|
+
if (event.key === 'Escape') {
|
|
264
|
+
event.preventDefault();
|
|
265
|
+
this.closeDropdown();
|
|
266
|
+
(_a = this.triggerEl) === null || _a === void 0 ? void 0 : _a.focus();
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
setupMutationObserver() {
|
|
270
|
+
this.observer = new MutationObserver(() => {
|
|
271
|
+
this.updateOptionsFromSlot();
|
|
272
|
+
});
|
|
273
|
+
this.observer.observe(this.el, {
|
|
274
|
+
childList: true,
|
|
275
|
+
subtree: true,
|
|
276
|
+
});
|
|
277
|
+
}
|
|
278
|
+
updateOptionsFromSlot() {
|
|
279
|
+
var _a;
|
|
280
|
+
const slot = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('slot:not([name])');
|
|
281
|
+
if (!slot)
|
|
282
|
+
return;
|
|
283
|
+
const options = slot.assignedElements({ flatten: true })
|
|
284
|
+
.filter((el) => el.tagName === 'OPTION')
|
|
285
|
+
.map(opt => ({
|
|
286
|
+
id: opt.value,
|
|
287
|
+
text: opt.textContent || opt.value,
|
|
288
|
+
}));
|
|
289
|
+
// Only update if we actually found options AND we're not using async/external options
|
|
290
|
+
// Don't clear internalOptions if slot returns empty (might be mid-DOM-update)
|
|
291
|
+
if (options.length > 0 && !this.asyncUrl && !this.options) {
|
|
292
|
+
this.internalOptions = options;
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
clearAsyncFetchState() {
|
|
296
|
+
var _a;
|
|
297
|
+
if (this.fetchDebounceTimer !== undefined) {
|
|
298
|
+
window.clearTimeout(this.fetchDebounceTimer);
|
|
299
|
+
this.fetchDebounceTimer = undefined;
|
|
300
|
+
}
|
|
301
|
+
(_a = this.abortController) === null || _a === void 0 ? void 0 : _a.abort();
|
|
302
|
+
this.abortController = undefined;
|
|
303
|
+
}
|
|
304
|
+
debouncedFetchAsyncOptions(query, page = 1) {
|
|
305
|
+
var _a;
|
|
306
|
+
if (!this.asyncUrl)
|
|
307
|
+
return;
|
|
308
|
+
if (this.fetchDebounceTimer !== undefined) {
|
|
309
|
+
window.clearTimeout(this.fetchDebounceTimer);
|
|
310
|
+
}
|
|
311
|
+
const delay = Math.max(0, (_a = this.debounce) !== null && _a !== void 0 ? _a : 0);
|
|
312
|
+
this.fetchDebounceTimer = window.setTimeout(() => {
|
|
313
|
+
this.fetchDebounceTimer = undefined;
|
|
314
|
+
this.fetchOptions(query, page);
|
|
315
|
+
}, delay);
|
|
316
|
+
}
|
|
317
|
+
syncSelectedItems() {
|
|
318
|
+
// Ensure value is an array (may be string from HTML attribute)
|
|
319
|
+
const valueArray = this.ensureValueArray();
|
|
320
|
+
const allOptions = this.getAllOptions();
|
|
321
|
+
this.selectedItems = valueArray
|
|
322
|
+
.map(val => allOptions.find(opt => String(opt.id) === String(val)))
|
|
323
|
+
.filter((opt) => opt !== undefined);
|
|
324
|
+
}
|
|
325
|
+
ensureValueArray() {
|
|
326
|
+
// Handle JSON string values passed via HTML attribute
|
|
327
|
+
if (typeof this.value === 'string') {
|
|
328
|
+
try {
|
|
329
|
+
const parsed = JSON.parse(this.value);
|
|
330
|
+
if (Array.isArray(parsed)) {
|
|
331
|
+
this.value = parsed;
|
|
332
|
+
return parsed;
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
catch (_a) {
|
|
336
|
+
// Not valid JSON, treat as single value
|
|
337
|
+
const singleValue = this.value;
|
|
338
|
+
this.value = singleValue ? [singleValue] : [];
|
|
339
|
+
return this.value;
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
return Array.isArray(this.value) ? this.value : [];
|
|
343
|
+
}
|
|
344
|
+
getAllOptions() {
|
|
345
|
+
return this.options || this.internalOptions;
|
|
346
|
+
}
|
|
347
|
+
getFilteredOptions() {
|
|
348
|
+
const allOptions = this.getAllOptions();
|
|
349
|
+
const query = this.searchQuery.toLowerCase();
|
|
350
|
+
return allOptions.filter(opt => {
|
|
351
|
+
// Filter by search query only - don't filter out selected items
|
|
352
|
+
if (query) {
|
|
353
|
+
return opt.text.toLowerCase().includes(query);
|
|
354
|
+
}
|
|
355
|
+
return true;
|
|
356
|
+
});
|
|
357
|
+
}
|
|
358
|
+
updateFormValue() {
|
|
359
|
+
var _a;
|
|
360
|
+
if ((_a = this.internals) === null || _a === void 0 ? void 0 : _a.setFormValue) {
|
|
361
|
+
// Ensure value is an array before iterating
|
|
362
|
+
const valueArray = this.ensureValueArray();
|
|
363
|
+
// Submit as multiple values with same name (native select multiple behavior)
|
|
364
|
+
const formData = new FormData();
|
|
365
|
+
valueArray.forEach(val => {
|
|
366
|
+
if (this.name) {
|
|
367
|
+
formData.append(this.name, val);
|
|
368
|
+
}
|
|
369
|
+
});
|
|
370
|
+
this.internals.setFormValue(formData);
|
|
371
|
+
// Update validity state for required validation
|
|
372
|
+
if (this.required && valueArray.length === 0) {
|
|
373
|
+
this.internals.setValidity({ valueMissing: true }, 'Please select at least one option.', this.triggerEl);
|
|
374
|
+
}
|
|
375
|
+
else {
|
|
376
|
+
this.internals.setValidity({});
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
async fetchOptions(query, page = 1) {
|
|
381
|
+
var _a;
|
|
382
|
+
if (!this.asyncUrl)
|
|
383
|
+
return;
|
|
384
|
+
(_a = this.abortController) === null || _a === void 0 ? void 0 : _a.abort();
|
|
385
|
+
this.abortController = new AbortController();
|
|
386
|
+
this.loading = true;
|
|
387
|
+
try {
|
|
388
|
+
const url = new URL(this.asyncUrl, window.location.origin);
|
|
389
|
+
if (this.asyncMethod === 'GET') {
|
|
390
|
+
url.searchParams.set('search', query);
|
|
391
|
+
url.searchParams.set('page', String(page));
|
|
392
|
+
}
|
|
393
|
+
const response = await fetch(url.toString(), Object.assign({ method: this.asyncMethod, signal: this.abortController.signal, headers: {
|
|
394
|
+
'Content-Type': 'application/json',
|
|
395
|
+
'Accept': 'application/json',
|
|
396
|
+
} }, (this.asyncMethod === 'POST' && {
|
|
397
|
+
body: JSON.stringify({ search: query, page }),
|
|
398
|
+
})));
|
|
399
|
+
if (!response.ok)
|
|
400
|
+
throw new Error('Failed to fetch options');
|
|
401
|
+
const data = await response.json();
|
|
402
|
+
const formattedResults = data.results.map(item => {
|
|
403
|
+
if (this.formatResult) {
|
|
404
|
+
return this.formatResult(item);
|
|
405
|
+
}
|
|
406
|
+
return Object.assign({ id: item.id, text: item.text }, item);
|
|
407
|
+
});
|
|
408
|
+
if (page === 1) {
|
|
409
|
+
this.internalOptions = formattedResults;
|
|
410
|
+
}
|
|
411
|
+
else {
|
|
412
|
+
this.internalOptions = [...this.internalOptions, ...formattedResults];
|
|
413
|
+
}
|
|
414
|
+
this.hasMore = data.totalCount ? this.internalOptions.length < data.totalCount : false;
|
|
415
|
+
this.currentPage = page;
|
|
416
|
+
}
|
|
417
|
+
catch (error) {
|
|
418
|
+
if (error.name !== 'AbortError') {
|
|
419
|
+
console.error('PdsMultiselect: Failed to fetch options', error);
|
|
420
|
+
}
|
|
421
|
+
}
|
|
422
|
+
finally {
|
|
423
|
+
this.loading = false;
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
openDropdown() {
|
|
427
|
+
if (this.disabled)
|
|
428
|
+
return;
|
|
429
|
+
this.isOpening = true;
|
|
430
|
+
this.isOpen = true;
|
|
431
|
+
this.highlightedIndex = -1;
|
|
432
|
+
// Trigger initial fetch if async
|
|
433
|
+
if (this.asyncUrl && this.internalOptions.length === 0) {
|
|
434
|
+
this.debouncedFetchAsyncOptions(this.searchQuery, 1);
|
|
435
|
+
}
|
|
436
|
+
requestAnimationFrame(() => {
|
|
437
|
+
var _a;
|
|
438
|
+
this.positionDropdown();
|
|
439
|
+
// Focus the search input after the panel is positioned
|
|
440
|
+
(_a = this.searchInputEl) === null || _a === void 0 ? void 0 : _a.focus();
|
|
441
|
+
// Clear the opening flag after focus has moved
|
|
442
|
+
setTimeout(() => {
|
|
443
|
+
this.isOpening = false;
|
|
444
|
+
}, 50);
|
|
445
|
+
});
|
|
446
|
+
}
|
|
447
|
+
closeDropdown() {
|
|
448
|
+
this.isOpen = false;
|
|
449
|
+
this.highlightedIndex = -1;
|
|
450
|
+
this.searchQuery = '';
|
|
451
|
+
// Clean up auto-update
|
|
452
|
+
if (this.cleanupAutoUpdate) {
|
|
453
|
+
this.cleanupAutoUpdate();
|
|
454
|
+
this.cleanupAutoUpdate = undefined;
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
positionDropdown() {
|
|
458
|
+
if (!this.containerEl || !this.panelEl)
|
|
459
|
+
return;
|
|
460
|
+
const referenceEl = this.triggerEl || this.containerEl;
|
|
461
|
+
const { minWidth, panelWidth } = this;
|
|
462
|
+
const updatePosition = () => {
|
|
463
|
+
floatingUi_dom.computePosition(referenceEl, this.panelEl, {
|
|
464
|
+
placement: 'bottom-start',
|
|
465
|
+
strategy: 'absolute',
|
|
466
|
+
middleware: [
|
|
467
|
+
floatingUi_dom.offset(12),
|
|
468
|
+
floatingUi_dom.flip(),
|
|
469
|
+
floatingUi_dom.shift({ padding: 8 }),
|
|
470
|
+
floatingUi_dom.size({
|
|
471
|
+
apply: ({ rects, elements }) => {
|
|
472
|
+
Object.assign(elements.floating.style, {
|
|
473
|
+
width: panelWidth !== null && panelWidth !== void 0 ? panelWidth : `${rects.reference.width}px`,
|
|
474
|
+
minWidth,
|
|
475
|
+
});
|
|
476
|
+
},
|
|
477
|
+
}),
|
|
478
|
+
],
|
|
479
|
+
}).then(({ x, y }) => {
|
|
480
|
+
if (this.panelEl) {
|
|
481
|
+
this.panelEl.style.left = `${x}px`;
|
|
482
|
+
this.panelEl.style.top = `${y}px`;
|
|
483
|
+
}
|
|
484
|
+
});
|
|
485
|
+
};
|
|
486
|
+
// Initial position
|
|
487
|
+
updatePosition();
|
|
488
|
+
// Set up auto-update for window resize and scroll
|
|
489
|
+
const cleanupAutoUpdate = floatingUi_dom.autoUpdate(referenceEl, this.panelEl, updatePosition);
|
|
490
|
+
this.cleanupAutoUpdate = () => {
|
|
491
|
+
cleanupAutoUpdate();
|
|
492
|
+
this.clearAsyncFetchState();
|
|
493
|
+
};
|
|
494
|
+
}
|
|
495
|
+
scrollOptionIntoView() {
|
|
496
|
+
requestAnimationFrame(() => {
|
|
497
|
+
var _a;
|
|
498
|
+
const highlighted = (_a = this.listboxEl) === null || _a === void 0 ? void 0 : _a.querySelector(`[data-index="${this.highlightedIndex}"]`);
|
|
499
|
+
highlighted === null || highlighted === void 0 ? void 0 : highlighted.scrollIntoView({ block: 'nearest', behavior: 'smooth' });
|
|
500
|
+
});
|
|
501
|
+
}
|
|
502
|
+
toggleOption(option) {
|
|
503
|
+
var _a;
|
|
504
|
+
const isSelected = this.value.includes(String(option.id));
|
|
505
|
+
if (isSelected) {
|
|
506
|
+
// Remove from selection
|
|
507
|
+
const newValue = this.value.filter(v => v !== String(option.id));
|
|
508
|
+
this.value = newValue;
|
|
509
|
+
const newSelectedItems = this.selectedItems.filter(item => String(item.id) !== String(option.id));
|
|
510
|
+
this.pdsMultiselectChange.emit({
|
|
511
|
+
values: newValue,
|
|
512
|
+
items: newSelectedItems,
|
|
513
|
+
});
|
|
514
|
+
}
|
|
515
|
+
else {
|
|
516
|
+
// Add to selection
|
|
517
|
+
if (this.maxSelections && this.value.length >= this.maxSelections) {
|
|
518
|
+
return;
|
|
519
|
+
}
|
|
520
|
+
const newValue = [...this.value, String(option.id)];
|
|
521
|
+
this.value = newValue;
|
|
522
|
+
const newSelectedItems = [...this.selectedItems, option];
|
|
523
|
+
this.pdsMultiselectChange.emit({
|
|
524
|
+
values: newValue,
|
|
525
|
+
items: newSelectedItems,
|
|
526
|
+
});
|
|
527
|
+
}
|
|
528
|
+
// Keep focus on search input, don't close dropdown
|
|
529
|
+
(_a = this.searchInputEl) === null || _a === void 0 ? void 0 : _a.focus();
|
|
530
|
+
}
|
|
531
|
+
selectOption(option) {
|
|
532
|
+
// For keyboard navigation - toggle the option
|
|
533
|
+
this.toggleOption(option);
|
|
534
|
+
}
|
|
535
|
+
renderSelectedItemsList() {
|
|
536
|
+
if (this.selectedItems.length === 0)
|
|
537
|
+
return null;
|
|
538
|
+
return (index.h("div", { class: "pds-multiselect__selected-section" }, index.h("ul", { class: "pds-multiselect__selected-list", role: "list" }, this.selectedItems.map(item => (index.h("li", { key: String(item.id), class: "pds-multiselect__selected-item" }, item.text))))));
|
|
539
|
+
}
|
|
540
|
+
renderDropdown() {
|
|
541
|
+
if (!this.isOpen)
|
|
542
|
+
return null;
|
|
543
|
+
const filteredOptions = this.getFilteredOptions();
|
|
544
|
+
const valueArray = this.ensureValueArray();
|
|
545
|
+
const hasSlottedEmpty = !!this.el.querySelector('[slot="empty"]');
|
|
546
|
+
const hasSlottedLoading = !!this.el.querySelector('[slot="loading"]');
|
|
547
|
+
return (index.h("div", { class: "pds-multiselect__panel", ref: el => (this.panelEl = el), style: { minWidth: this.minWidth } }, index.h("div", { class: "pds-multiselect__search" }, index.h("pds-icon", { name: "search", size: "small" }), index.h("input", { ref: el => (this.searchInputEl = el), type: "text", class: "pds-multiselect__search-input", placeholder: "Find...", value: this.searchQuery, "aria-label": "Search options", "aria-controls": `${this.componentId}-listbox`, "aria-activedescendant": this.highlightedIndex >= 0 ? `${this.componentId}-option-${this.highlightedIndex}` : undefined, role: "combobox", "aria-haspopup": "listbox", "aria-expanded": "true", "aria-autocomplete": "list", autocomplete: "off", onInput: this.handleSearchInputChange, onKeyDown: this.handleSearchInputKeyDown })), this.renderSelectedItemsList(), index.h("ul", { class: "pds-multiselect__listbox", role: "listbox", "aria-multiselectable": "true", "aria-label": this.label || 'Options', id: `${this.componentId}-listbox`, ref: el => (this.listboxEl = el), style: { maxHeight: this.maxHeight }, onScroll: this.handleScroll }, this.loading && (index.h("li", { class: "pds-multiselect__loading", role: "presentation" }, hasSlottedLoading ? (index.h("slot", { name: "loading" })) : (index.h("pds-loader", { size: "small" })))), !this.loading && filteredOptions.length === 0 && (index.h("li", { class: "pds-multiselect__empty", role: "presentation" }, hasSlottedEmpty ? (index.h("slot", { name: "empty" })) : (index.h("span", null, "No options found")))), filteredOptions.map((option, index$1) => {
|
|
548
|
+
const isSelected = valueArray.includes(String(option.id));
|
|
549
|
+
const isHighlighted = index$1 === this.highlightedIndex;
|
|
550
|
+
const optionId = `${this.componentId}-option-${index$1}`;
|
|
551
|
+
return (index.h("li", { key: String(option.id), id: optionId, class: {
|
|
552
|
+
'pds-multiselect__option': true,
|
|
553
|
+
'pds-multiselect__option--highlighted': isHighlighted,
|
|
554
|
+
'pds-multiselect__option--selected': isSelected,
|
|
555
|
+
}, role: "option", "aria-selected": isSelected ? 'true' : 'false', "data-index": index$1, onMouseDown: this.handleOptionMouseDown(option), onMouseEnter: this.handleOptionMouseEnter(index$1) }, index.h("pds-checkbox", { componentId: `${this.componentId}-checkbox-${index$1}`, checked: isSelected, label: option.text, style: { pointerEvents: 'none' } })));
|
|
556
|
+
}), this.hasMore && !this.loading && (index.h("li", { class: "pds-multiselect__load-more", role: "presentation" }, index.h("pds-loader", { size: "small" }))))));
|
|
557
|
+
}
|
|
558
|
+
getTriggerText() {
|
|
559
|
+
const count = this.selectedItems.length;
|
|
560
|
+
if (count === 0) {
|
|
561
|
+
return this.placeholder || 'Select...';
|
|
562
|
+
}
|
|
563
|
+
return `${count} item${count === 1 ? '' : 's'}`;
|
|
564
|
+
}
|
|
565
|
+
render() {
|
|
566
|
+
const hasSelections = this.selectedItems.length > 0;
|
|
567
|
+
return (index.h(index.Host, { key: 'e7d872fd9bedb03390eaf8a2bd9c5d6ba1cc7ecc', "aria-disabled": this.disabled ? 'true' : null }, index.h("div", { key: '141dee3c657dd17d3389d4a25979d0f748e36361', class: "pds-multiselect" }, this.label && (index.h("label", { key: '386114a823424506857a1e927a2538e88d3c82f5', htmlFor: this.componentId, class: {
|
|
568
|
+
'pds-multiselect__label': true,
|
|
569
|
+
'visually-hidden': this.hideLabel,
|
|
570
|
+
} }, this.label)), index.h("div", { key: '9fc18bf93f981ee7f72f31c20f43f5251ed647e4', class: "pds-multiselect__wrapper", ref: el => (this.containerEl = el), onFocusout: this.handleContainerFocusOut, style: { width: this.triggerWidth } }, index.h("button", { key: '74e8eb5ef5984307dce779ef63d54e49e07497ea', ref: el => (this.triggerEl = el), type: "button", class: {
|
|
571
|
+
'pds-multiselect__trigger': true,
|
|
572
|
+
'pds-multiselect__trigger--open': this.isOpen,
|
|
573
|
+
'pds-multiselect__trigger--disabled': this.disabled,
|
|
574
|
+
'pds-multiselect__trigger--invalid': this.invalid || !!this.errorMessage,
|
|
575
|
+
'pds-multiselect__trigger--has-value': hasSelections,
|
|
576
|
+
}, id: this.componentId, disabled: this.disabled, "aria-required": this.required ? 'true' : undefined, "aria-expanded": this.isOpen ? 'true' : 'false', "aria-haspopup": "listbox", "aria-describedby": form.assignDescription(this.componentId, this.invalid || !!this.errorMessage, this.errorMessage || this.helperMessage), "aria-invalid": this.invalid || !!this.errorMessage ? 'true' : undefined, onClick: this.handleTriggerClick, onKeyDown: this.handleTriggerKeyDown }, index.h("span", { key: 'fb7f9b9fffd46839ddc4ab0bb549b61de191f76c', class: {
|
|
577
|
+
'pds-multiselect__trigger-text': true,
|
|
578
|
+
'pds-multiselect__trigger-text--placeholder': !hasSelections,
|
|
579
|
+
} }, this.getTriggerText()), index.h("pds-icon", { key: '354e1c57758350d73557a6c94d0b31eb6732f12a', class: "pds-multiselect__icon", icon: index$1.enlarge })), this.renderDropdown()), this.helperMessage && !this.errorMessage && (index.h("p", { key: '3709f184a7972e1acfd3826faefc4ba139a8d518', class: "pds-multiselect__helper", id: form.messageId(this.componentId, 'helper') }, this.helperMessage)), this.errorMessage && (index.h("p", { key: '8029b58286455b7b4789a4336a79c324ca91ad74', class: "pds-multiselect__error", id: form.messageId(this.componentId, 'error') }, index.h("pds-icon", { key: 'cd781f3caed8b81deef2ce43f0a4406b6ed2d53c', icon: index$1.danger, size: "small" }), this.errorMessage)), index.h("div", { key: '7c303f4d64247b41b9e88892cfb8c02acd5d8d59', style: { display: 'none' } }, index.h("slot", { key: 'e9b384038e67bb951613933bbf68fd2b2efc71ef' })))));
|
|
580
|
+
}
|
|
581
|
+
static get formAssociated() { return true; }
|
|
582
|
+
get el() { return index.getElement(this); }
|
|
583
|
+
static get watchers() { return {
|
|
584
|
+
"debounce": ["setupDebounce"],
|
|
585
|
+
"value": ["valueChanged"],
|
|
586
|
+
"options": ["optionsChanged"],
|
|
587
|
+
"internalOptions": ["internalOptionsChanged"]
|
|
588
|
+
}; }
|
|
589
|
+
};
|
|
590
|
+
PdsMultiselect.style = pdsMultiselectCss;
|
|
591
|
+
|
|
592
|
+
exports.pds_multiselect = PdsMultiselect;
|
|
593
|
+
//# sourceMappingURL=pds-multiselect.entry.cjs.js.map
|