@db-ux/wc-core-components 3.0.2-copilot2-e7bf98b → 3.0.2-shell-ed0ed7c
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/README.md +0 -10
- package/dist/cjs/{constants-CTtyzyuo.js → constants-BOd99bQT.js} +7 -2
- package/dist/cjs/constants-BOd99bQT.js.map +1 -0
- package/dist/cjs/db-accordion-item.cjs.entry.js +2 -2
- package/dist/cjs/db-accordion.cjs.entry.js +2 -2
- package/dist/cjs/db-badge.cjs.entry.js +2 -2
- package/dist/cjs/db-button.cjs.entry.js +2 -2
- package/dist/cjs/db-card.cjs.entry.js +3 -3
- package/dist/cjs/db-checkbox.cjs.entry.js +6 -6
- package/dist/cjs/db-checkbox.cjs.entry.js.map +1 -1
- package/dist/cjs/db-checkbox.entry.cjs.js.map +1 -1
- package/dist/cjs/db-control-panel-brand.cjs.entry.js +57 -0
- package/dist/cjs/db-control-panel-brand.cjs.entry.js.map +1 -0
- package/dist/cjs/db-control-panel-brand.entry.cjs.js.map +1 -0
- package/dist/cjs/db-control-panel-desktop.cjs.entry.js +91 -0
- package/dist/cjs/db-control-panel-desktop.cjs.entry.js.map +1 -0
- package/dist/cjs/db-control-panel-desktop.entry.cjs.js.map +1 -0
- package/dist/cjs/db-control-panel-flat-icon-navigation.cjs.entry.js +76 -0
- package/dist/cjs/db-control-panel-flat-icon-navigation.cjs.entry.js.map +1 -0
- package/dist/cjs/db-control-panel-flat-icon-navigation.entry.cjs.js.map +1 -0
- package/dist/cjs/{db-brand.cjs.entry.js → db-control-panel-meta-navigation.cjs.entry.js} +8 -10
- package/dist/cjs/db-control-panel-meta-navigation.cjs.entry.js.map +1 -0
- package/dist/cjs/db-control-panel-meta-navigation.entry.cjs.js.map +1 -0
- package/dist/cjs/db-control-panel-mobile.cjs.entry.js +76 -0
- package/dist/cjs/db-control-panel-mobile.cjs.entry.js.map +1 -0
- package/dist/cjs/db-control-panel-mobile.entry.cjs.js.map +1 -0
- package/dist/cjs/db-control-panel-primary-actions.cjs.entry.js +55 -0
- package/dist/cjs/db-control-panel-primary-actions.cjs.entry.js.map +1 -0
- package/dist/cjs/db-control-panel-primary-actions.entry.cjs.js.map +1 -0
- package/dist/cjs/db-control-panel-secondary-actions.cjs.entry.js +55 -0
- package/dist/cjs/db-control-panel-secondary-actions.cjs.entry.js.map +1 -0
- package/dist/cjs/db-control-panel-secondary-actions.entry.cjs.js.map +1 -0
- package/dist/cjs/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.cjs.js.map +1 -1
- package/dist/cjs/db-custom-select-dropdown_5.cjs.entry.js +13 -13
- package/dist/cjs/db-custom-select-dropdown_5.cjs.entry.js.map +1 -1
- package/dist/cjs/db-custom-select-form-field.cjs.entry.js +3 -3
- package/dist/cjs/db-custom-select.cjs.entry.js +15 -15
- package/dist/cjs/db-custom-select.cjs.entry.js.map +1 -1
- package/dist/cjs/db-custom-select.entry.cjs.js.map +1 -1
- package/dist/cjs/db-divider.cjs.entry.js +2 -2
- package/dist/cjs/db-drawer.cjs.entry.js +6 -6
- package/dist/cjs/db-drawer.cjs.entry.js.map +1 -1
- package/dist/cjs/db-drawer.entry.cjs.js.map +1 -1
- package/dist/cjs/db-icon.cjs.entry.js +2 -2
- package/dist/cjs/db-infotext.cjs.entry.js +2 -2
- package/dist/cjs/db-link.cjs.entry.js +2 -2
- package/dist/cjs/db-navigation-item-group.cjs.entry.js +159 -0
- package/dist/cjs/db-navigation-item-group.cjs.entry.js.map +1 -0
- package/dist/cjs/db-navigation-item-group.entry.cjs.js.map +1 -0
- package/dist/cjs/db-navigation-item.cjs.entry.js +4 -72
- package/dist/cjs/db-navigation-item.cjs.entry.js.map +1 -1
- package/dist/cjs/db-navigation-item.entry.cjs.js.map +1 -1
- package/dist/cjs/db-navigation.cjs.entry.js +112 -6
- package/dist/cjs/db-navigation.cjs.entry.js.map +1 -1
- package/dist/cjs/db-navigation.entry.cjs.js.map +1 -1
- package/dist/cjs/db-notification.cjs.entry.js +4 -4
- package/dist/cjs/db-popover.cjs.entry.js +5 -6
- package/dist/cjs/db-popover.cjs.entry.js.map +1 -1
- package/dist/cjs/db-popover.entry.cjs.js.map +1 -1
- package/dist/cjs/db-radio.cjs.entry.js +2 -2
- package/dist/cjs/db-section.cjs.entry.js +4 -4
- package/dist/cjs/db-select.cjs.entry.js +7 -7
- package/dist/cjs/db-select.cjs.entry.js.map +1 -1
- package/dist/cjs/db-select.entry.cjs.js.map +1 -1
- package/dist/cjs/db-shell-sub-navigation.cjs.entry.js +71 -0
- package/dist/cjs/db-shell-sub-navigation.cjs.entry.js.map +1 -0
- package/dist/cjs/db-shell-sub-navigation.entry.cjs.js.map +1 -0
- package/dist/cjs/{db-page.cjs.entry.js → db-shell.cjs.entry.js} +9 -15
- package/dist/cjs/db-shell.cjs.entry.js.map +1 -0
- package/dist/cjs/db-shell.entry.cjs.js.map +1 -0
- package/dist/cjs/db-stack.cjs.entry.js +3 -3
- package/dist/cjs/db-switch.cjs.entry.js +2 -2
- package/dist/cjs/db-tab-item_3.cjs.entry.js +8 -8
- package/dist/cjs/db-tabs.cjs.entry.js +5 -5
- package/dist/cjs/db-tabs.cjs.entry.js.map +1 -1
- package/dist/cjs/db-tabs.entry.cjs.js.map +1 -1
- package/dist/cjs/db-textarea.cjs.entry.js +6 -6
- package/dist/cjs/db-textarea.cjs.entry.js.map +1 -1
- package/dist/cjs/db-textarea.entry.cjs.js.map +1 -1
- package/dist/cjs/db-tooltip.cjs.entry.js +7 -8
- package/dist/cjs/db-tooltip.cjs.entry.js.map +1 -1
- package/dist/cjs/db-tooltip.entry.cjs.js.map +1 -1
- package/dist/cjs/db-ux.cjs.js +3 -3
- package/dist/cjs/db-ux.cjs.js.map +1 -1
- package/dist/cjs/{floating-components-ogUqz72V.js → floating-components-DSENlGvK.js} +78 -50
- package/dist/cjs/floating-components-DSENlGvK.js.map +1 -0
- package/dist/cjs/{index-9urL1KCD.js → index-B1qpUQFv.js} +9 -3
- package/dist/cjs/index-B1qpUQFv.js.map +1 -0
- package/dist/cjs/index.cjs.js +21 -11
- package/dist/cjs/index.cjs.js.map +1 -1
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/{navigation-DauGE-qj.js → navigation-DWSyoPJm.js} +38 -21
- package/dist/cjs/navigation-DWSyoPJm.js.map +1 -0
- package/dist/collection/collection-manifest.json +14 -7
- package/dist/collection/components/button/button.js +1 -1
- package/dist/collection/components/card/card.js +2 -2
- package/dist/collection/components/checkbox/checkbox.js +4 -4
- package/dist/collection/components/checkbox/checkbox.js.map +1 -1
- package/dist/collection/components/{brand/brand.js → control-panel-brand/control-panel-brand.js} +22 -47
- package/dist/collection/components/control-panel-brand/control-panel-brand.js.map +1 -0
- package/dist/collection/components/control-panel-brand/index.js +3 -0
- package/dist/collection/components/control-panel-brand/index.js.map +1 -0
- package/dist/collection/components/control-panel-brand/model.js.map +1 -0
- package/dist/collection/components/control-panel-desktop/control-panel-desktop.js +267 -0
- package/dist/collection/components/control-panel-desktop/control-panel-desktop.js.map +1 -0
- package/dist/collection/components/control-panel-desktop/index.js +3 -0
- package/dist/collection/components/control-panel-desktop/index.js.map +1 -0
- package/dist/collection/components/control-panel-desktop/model.js.map +1 -0
- package/dist/collection/components/control-panel-flat-icon-navigation/control-panel-flat-icon-navigation.js +162 -0
- package/dist/collection/components/control-panel-flat-icon-navigation/control-panel-flat-icon-navigation.js.map +1 -0
- package/dist/collection/components/control-panel-flat-icon-navigation/index.js +3 -0
- package/dist/collection/components/control-panel-flat-icon-navigation/index.js.map +1 -0
- package/dist/collection/components/control-panel-flat-icon-navigation/model.js +2 -0
- package/dist/collection/components/control-panel-flat-icon-navigation/model.js.map +1 -0
- package/dist/collection/components/control-panel-meta-navigation/control-panel-meta-navigation.js +104 -0
- package/dist/collection/components/control-panel-meta-navigation/control-panel-meta-navigation.js.map +1 -0
- package/dist/collection/components/control-panel-meta-navigation/index.js +3 -0
- package/dist/collection/components/control-panel-meta-navigation/index.js.map +1 -0
- package/dist/collection/components/control-panel-meta-navigation/model.js +2 -0
- package/dist/collection/components/control-panel-meta-navigation/model.js.map +1 -0
- package/dist/collection/components/{header/header.js → control-panel-mobile/control-panel-mobile.js} +76 -76
- package/dist/collection/components/control-panel-mobile/control-panel-mobile.js.map +1 -0
- package/dist/collection/components/control-panel-mobile/index.js +3 -0
- package/dist/collection/components/control-panel-mobile/index.js.map +1 -0
- package/dist/collection/components/control-panel-mobile/model.js +2 -0
- package/dist/collection/components/control-panel-mobile/model.js.map +1 -0
- package/dist/collection/components/control-panel-primary-actions/control-panel-primary-actions.js +104 -0
- package/dist/collection/components/control-panel-primary-actions/control-panel-primary-actions.js.map +1 -0
- package/dist/collection/components/control-panel-primary-actions/index.js +3 -0
- package/dist/collection/components/control-panel-primary-actions/index.js.map +1 -0
- package/dist/collection/components/control-panel-primary-actions/model.js +2 -0
- package/dist/collection/components/control-panel-primary-actions/model.js.map +1 -0
- package/dist/collection/components/control-panel-secondary-actions/control-panel-secondary-actions.js +104 -0
- package/dist/collection/components/control-panel-secondary-actions/control-panel-secondary-actions.js.map +1 -0
- package/dist/collection/components/control-panel-secondary-actions/index.js +3 -0
- package/dist/collection/components/control-panel-secondary-actions/index.js.map +1 -0
- package/dist/collection/components/control-panel-secondary-actions/model.js +2 -0
- package/dist/collection/components/control-panel-secondary-actions/model.js.map +1 -0
- package/dist/collection/components/custom-select/custom-select.js +12 -12
- package/dist/collection/components/custom-select/custom-select.js.map +1 -1
- package/dist/collection/components/custom-select/model.js.map +1 -1
- package/dist/collection/components/custom-select-dropdown/custom-select-dropdown.js +2 -2
- package/dist/collection/components/custom-select-form-field/custom-select-form-field.js +2 -2
- package/dist/collection/components/custom-select-list/custom-select-list.js +2 -2
- package/dist/collection/components/custom-select-list-item/custom-select-list-item.js +1 -1
- package/dist/collection/components/divider/divider.js +1 -1
- package/dist/collection/components/drawer/drawer.js +30 -5
- package/dist/collection/components/drawer/drawer.js.map +1 -1
- package/dist/collection/components/drawer/model.js +1 -1
- package/dist/collection/components/drawer/model.js.map +1 -1
- package/dist/collection/components/icon/icon.js +1 -1
- package/dist/collection/components/infotext/infotext.js +1 -1
- package/dist/collection/components/input/input.js +4 -4
- package/dist/collection/components/input/input.js.map +1 -1
- package/dist/collection/components/link/link.js +1 -1
- package/dist/collection/components/navigation/model.js.map +1 -1
- package/dist/collection/components/navigation/navigation.js +206 -7
- package/dist/collection/components/navigation/navigation.js.map +1 -1
- package/dist/collection/components/navigation-item/model.js.map +1 -1
- package/dist/collection/components/navigation-item/navigation-item.js +9 -238
- package/dist/collection/components/navigation-item/navigation-item.js.map +1 -1
- package/dist/collection/components/navigation-item-group/index.js +3 -0
- package/dist/collection/components/navigation-item-group/index.js.map +1 -0
- package/dist/collection/components/navigation-item-group/model.js +2 -0
- package/dist/collection/components/navigation-item-group/model.js.map +1 -0
- package/dist/collection/components/navigation-item-group/navigation-item-group.js +453 -0
- package/dist/collection/components/navigation-item-group/navigation-item-group.js.map +1 -0
- package/dist/collection/components/notification/notification.js +2 -2
- package/dist/collection/components/popover/popover.js +28 -29
- package/dist/collection/components/popover/popover.js.map +1 -1
- package/dist/collection/components/radio/radio.js +1 -1
- package/dist/collection/components/section/section.js +2 -2
- package/dist/collection/components/select/select.js +5 -5
- package/dist/collection/components/select/select.js.map +1 -1
- package/dist/collection/components/shell/index.js +3 -0
- package/dist/collection/components/shell/index.js.map +1 -0
- package/dist/collection/components/shell/model.js +2 -0
- package/dist/collection/components/shell/model.js.map +1 -0
- package/dist/collection/components/shell/shell.js +299 -0
- package/dist/collection/components/shell/shell.js.map +1 -0
- package/dist/collection/components/shell-sub-navigation/index.js +3 -0
- package/dist/collection/components/shell-sub-navigation/index.js.map +1 -0
- package/dist/collection/components/shell-sub-navigation/model.js +2 -0
- package/dist/collection/components/shell-sub-navigation/model.js.map +1 -0
- package/dist/collection/components/{page/page.js → shell-sub-navigation/shell-sub-navigation.js} +43 -94
- package/dist/collection/components/shell-sub-navigation/shell-sub-navigation.js.map +1 -0
- package/dist/collection/components/stack/stack.js +2 -2
- package/dist/collection/components/switch/switch.js +1 -1
- package/dist/collection/components/tab-item/tab-item.js +2 -2
- package/dist/collection/components/tab-list/tab-list.js +2 -2
- package/dist/collection/components/tab-panel/tab-panel.js +2 -2
- package/dist/collection/components/tabs/model.js.map +1 -1
- package/dist/collection/components/tabs/tabs.js +4 -4
- package/dist/collection/components/tabs/tabs.js.map +1 -1
- package/dist/collection/components/tag/tag.js +2 -2
- package/dist/collection/components/textarea/textarea.js +4 -4
- package/dist/collection/components/textarea/textarea.js.map +1 -1
- package/dist/collection/components/tooltip/tooltip.js +29 -30
- package/dist/collection/components/tooltip/tooltip.js.map +1 -1
- package/dist/collection/index.js +19 -6
- package/dist/collection/index.js.map +1 -1
- package/dist/collection/shared/constants.js +3 -0
- package/dist/collection/shared/constants.js.map +1 -1
- package/dist/collection/shared/model.js +3 -0
- package/dist/collection/shared/model.js.map +1 -1
- package/dist/collection/utils/floating-components.js +76 -48
- package/dist/collection/utils/floating-components.js.map +1 -1
- package/dist/collection/utils/navigation.js +34 -22
- package/dist/collection/utils/navigation.js.map +1 -1
- package/dist/custom-elements.json +7740 -6149
- package/dist/db-ux/db-checkbox.entry.esm.js.map +1 -1
- package/dist/db-ux/db-control-panel-brand.entry.esm.js.map +1 -0
- package/dist/db-ux/db-control-panel-desktop.entry.esm.js.map +1 -0
- package/dist/db-ux/db-control-panel-flat-icon-navigation.entry.esm.js.map +1 -0
- package/dist/db-ux/db-control-panel-meta-navigation.entry.esm.js.map +1 -0
- package/dist/db-ux/db-control-panel-mobile.entry.esm.js.map +1 -0
- package/dist/db-ux/db-control-panel-primary-actions.entry.esm.js.map +1 -0
- package/dist/db-ux/db-control-panel-secondary-actions.entry.esm.js.map +1 -0
- package/dist/db-ux/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.esm.js.map +1 -1
- package/dist/db-ux/db-custom-select.entry.esm.js.map +1 -1
- package/dist/db-ux/db-drawer.entry.esm.js.map +1 -1
- package/dist/db-ux/db-navigation-item-group.entry.esm.js.map +1 -0
- package/dist/db-ux/db-navigation-item.entry.esm.js.map +1 -1
- package/dist/db-ux/db-navigation.entry.esm.js.map +1 -1
- package/dist/db-ux/db-popover.entry.esm.js.map +1 -1
- package/dist/db-ux/db-select.entry.esm.js.map +1 -1
- package/dist/db-ux/db-shell-sub-navigation.entry.esm.js.map +1 -0
- package/dist/db-ux/db-shell.entry.esm.js.map +1 -0
- package/dist/db-ux/db-tabs.entry.esm.js.map +1 -1
- package/dist/db-ux/db-textarea.entry.esm.js.map +1 -1
- package/dist/db-ux/db-tooltip.entry.esm.js.map +1 -1
- package/dist/db-ux/db-ux.esm.js +1 -1
- package/dist/db-ux/db-ux.esm.js.map +1 -1
- package/dist/db-ux/index.esm.js +1 -1
- package/dist/db-ux/index.esm.js.map +1 -1
- package/dist/db-ux/p-0262e847.entry.js +2 -0
- package/dist/db-ux/p-0262e847.entry.js.map +1 -0
- package/dist/db-ux/p-13f527fb.entry.js +2 -0
- package/dist/db-ux/p-13f527fb.entry.js.map +1 -0
- package/dist/db-ux/p-1a56dee3.entry.js +2 -0
- package/dist/db-ux/p-1a56dee3.entry.js.map +1 -0
- package/dist/db-ux/p-1b0815ab.entry.js +2 -0
- package/dist/db-ux/p-1b0815ab.entry.js.map +1 -0
- package/dist/db-ux/p-1d41f71c.entry.js +2 -0
- package/dist/db-ux/p-1d41f71c.entry.js.map +1 -0
- package/dist/db-ux/p-1dccdff4.entry.js +2 -0
- package/dist/db-ux/p-29dcb78d.entry.js +2 -0
- package/dist/db-ux/p-29dcb78d.entry.js.map +1 -0
- package/dist/db-ux/p-3f2ab801.entry.js +2 -0
- package/dist/db-ux/p-3f2ab801.entry.js.map +1 -0
- package/dist/db-ux/p-40e42146.entry.js +2 -0
- package/dist/db-ux/p-40e42146.entry.js.map +1 -0
- package/dist/db-ux/p-4645cc92.entry.js +2 -0
- package/dist/db-ux/{p-c5ff3d3f.entry.js → p-504a9cfc.entry.js} +2 -2
- package/dist/db-ux/{p-e6e7719e.entry.js → p-53682d25.entry.js} +2 -2
- package/dist/db-ux/p-5be272f0.entry.js +2 -0
- package/dist/db-ux/p-5cb180c4.entry.js +2 -0
- package/dist/db-ux/p-5cb180c4.entry.js.map +1 -0
- package/dist/db-ux/{p-16f1fa7c.entry.js → p-5d292f94.entry.js} +2 -2
- package/dist/db-ux/{p-02fcd4a8.entry.js → p-5e4ac324.entry.js} +2 -2
- package/dist/db-ux/p-6c023c87.entry.js +2 -0
- package/dist/db-ux/p-6c023c87.entry.js.map +1 -0
- package/dist/db-ux/{p-f03f7076.entry.js → p-6fd148ce.entry.js} +2 -2
- package/dist/db-ux/p-7153636c.entry.js +2 -0
- package/dist/db-ux/p-73614370.entry.js +2 -0
- package/dist/db-ux/{p-209cf793.entry.js → p-81d7921b.entry.js} +2 -2
- package/dist/db-ux/{p-d7168627.entry.js → p-8262ab69.entry.js} +2 -2
- package/dist/db-ux/p-8db3c126.entry.js +2 -0
- package/dist/db-ux/{p-d6aeabf0.entry.js.map → p-8db3c126.entry.js.map} +1 -1
- package/dist/db-ux/p-99d090b7.entry.js +2 -0
- package/dist/db-ux/p-9d18d065.entry.js +2 -0
- package/dist/db-ux/p-9d18d065.entry.js.map +1 -0
- package/dist/db-ux/p-CZxi1Pek.js +2 -0
- package/dist/db-ux/p-CZxi1Pek.js.map +1 -0
- package/dist/db-ux/p-D3kmGlOI.js +2 -0
- package/dist/db-ux/p-D3kmGlOI.js.map +1 -0
- package/dist/db-ux/p-Dst8dqRS.js +2 -0
- package/dist/db-ux/p-Dst8dqRS.js.map +1 -0
- package/dist/db-ux/p-a652e0d0.entry.js +2 -0
- package/dist/db-ux/p-a652e0d0.entry.js.map +1 -0
- package/dist/db-ux/{p-bd7d1646.entry.js → p-b713791b.entry.js} +2 -2
- package/dist/db-ux/p-b90f037e.entry.js +2 -0
- package/dist/db-ux/p-b90f037e.entry.js.map +1 -0
- package/dist/db-ux/p-bb9043b3.entry.js +2 -0
- package/dist/db-ux/p-bb9043b3.entry.js.map +1 -0
- package/dist/db-ux/p-bbbb47fe.entry.js +2 -0
- package/dist/db-ux/p-bbbb47fe.entry.js.map +1 -0
- package/dist/db-ux/p-c00303d4.entry.js +2 -0
- package/dist/db-ux/p-c00303d4.entry.js.map +1 -0
- package/dist/db-ux/p-c841ce92.entry.js +2 -0
- package/dist/db-ux/p-c841ce92.entry.js.map +1 -0
- package/dist/db-ux/{p-a2b55626.entry.js → p-d6047812.entry.js} +2 -2
- package/dist/db-ux/p-d8f87aaa.entry.js +2 -0
- package/dist/db-ux/p-d8f87aaa.entry.js.map +1 -0
- package/dist/db-ux/p-e39aeff2.entry.js +2 -0
- package/dist/db-ux/p-e39aeff2.entry.js.map +1 -0
- package/dist/db-ux/p-e418dace.entry.js +2 -0
- package/dist/db-ux/p-e418dace.entry.js.map +1 -0
- package/dist/db-ux/p-eaa14b89.entry.js +2 -0
- package/dist/db-ux/p-eaa14b89.entry.js.map +1 -0
- package/dist/db-ux/p-uOzX56mL.js +3 -0
- package/dist/db-ux/p-uOzX56mL.js.map +1 -0
- package/dist/esm/{constants-DC9V_oNU.js → constants-Dst8dqRS.js} +6 -3
- package/dist/esm/constants-Dst8dqRS.js.map +1 -0
- package/dist/esm/db-accordion-item.entry.js +2 -2
- package/dist/esm/db-accordion.entry.js +2 -2
- package/dist/esm/db-badge.entry.js +2 -2
- package/dist/esm/db-button.entry.js +2 -2
- package/dist/esm/db-card.entry.js +3 -3
- package/dist/esm/db-checkbox.entry.js +6 -6
- package/dist/esm/db-checkbox.entry.js.map +1 -1
- package/dist/esm/db-control-panel-brand.entry.js +55 -0
- package/dist/esm/db-control-panel-brand.entry.js.map +1 -0
- package/dist/esm/db-control-panel-desktop.entry.js +89 -0
- package/dist/esm/db-control-panel-desktop.entry.js.map +1 -0
- package/dist/esm/db-control-panel-flat-icon-navigation.entry.js +74 -0
- package/dist/esm/db-control-panel-flat-icon-navigation.entry.js.map +1 -0
- package/dist/esm/{db-brand.entry.js → db-control-panel-meta-navigation.entry.js} +9 -11
- package/dist/esm/db-control-panel-meta-navigation.entry.js.map +1 -0
- package/dist/esm/db-control-panel-mobile.entry.js +74 -0
- package/dist/esm/db-control-panel-mobile.entry.js.map +1 -0
- package/dist/esm/db-control-panel-primary-actions.entry.js +53 -0
- package/dist/esm/db-control-panel-primary-actions.entry.js.map +1 -0
- package/dist/esm/db-control-panel-secondary-actions.entry.js +53 -0
- package/dist/esm/db-control-panel-secondary-actions.entry.js.map +1 -0
- package/dist/esm/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.js.map +1 -1
- package/dist/esm/db-custom-select-dropdown_5.entry.js +13 -13
- package/dist/esm/db-custom-select-dropdown_5.entry.js.map +1 -1
- package/dist/esm/db-custom-select-form-field.entry.js +3 -3
- package/dist/esm/db-custom-select.entry.js +15 -15
- package/dist/esm/db-custom-select.entry.js.map +1 -1
- package/dist/esm/db-divider.entry.js +2 -2
- package/dist/esm/db-drawer.entry.js +6 -6
- package/dist/esm/db-drawer.entry.js.map +1 -1
- package/dist/esm/db-icon.entry.js +2 -2
- package/dist/esm/db-infotext.entry.js +2 -2
- package/dist/esm/db-link.entry.js +2 -2
- package/dist/esm/db-navigation-item-group.entry.js +157 -0
- package/dist/esm/db-navigation-item-group.entry.js.map +1 -0
- package/dist/esm/db-navigation-item.entry.js +5 -73
- package/dist/esm/db-navigation-item.entry.js.map +1 -1
- package/dist/esm/db-navigation.entry.js +113 -7
- package/dist/esm/db-navigation.entry.js.map +1 -1
- package/dist/esm/db-notification.entry.js +4 -4
- package/dist/esm/db-popover.entry.js +5 -6
- package/dist/esm/db-popover.entry.js.map +1 -1
- package/dist/esm/db-radio.entry.js +2 -2
- package/dist/esm/db-section.entry.js +4 -4
- package/dist/esm/db-select.entry.js +7 -7
- package/dist/esm/db-select.entry.js.map +1 -1
- package/dist/esm/db-shell-sub-navigation.entry.js +69 -0
- package/dist/esm/db-shell-sub-navigation.entry.js.map +1 -0
- package/dist/esm/{db-page.entry.js → db-shell.entry.js} +9 -15
- package/dist/esm/db-shell.entry.js.map +1 -0
- package/dist/esm/db-stack.entry.js +3 -3
- package/dist/esm/db-switch.entry.js +2 -2
- package/dist/esm/db-tab-item_3.entry.js +8 -8
- package/dist/esm/db-tabs.entry.js +5 -5
- package/dist/esm/db-tabs.entry.js.map +1 -1
- package/dist/esm/db-textarea.entry.js +6 -6
- package/dist/esm/db-textarea.entry.js.map +1 -1
- package/dist/esm/db-tooltip.entry.js +7 -8
- package/dist/esm/db-tooltip.entry.js.map +1 -1
- package/dist/esm/db-ux.js +4 -4
- package/dist/esm/db-ux.js.map +1 -1
- package/dist/esm/{floating-components-G-TursYV.js → floating-components-D3kmGlOI.js} +78 -50
- package/dist/esm/floating-components-D3kmGlOI.js.map +1 -0
- package/dist/esm/{index-CNzNv7KB.js → index-uOzX56mL.js} +9 -3
- package/dist/esm/index-uOzX56mL.js.map +1 -0
- package/dist/esm/index.js +12 -8
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/loader.js +3 -3
- package/dist/esm/{navigation--UdC9CzO.js → navigation-CJ-OxodG.js} +38 -22
- package/dist/esm/navigation-CJ-OxodG.js.map +1 -0
- package/dist/types/components/control-panel-brand/control-panel-brand.d.ts +21 -0
- package/dist/types/components/control-panel-brand/index.d.ts +2 -0
- package/dist/types/components/control-panel-brand/model.d.ts +5 -0
- package/dist/types/components/control-panel-desktop/control-panel-desktop.d.ts +33 -0
- package/dist/types/components/control-panel-desktop/index.d.ts +2 -0
- package/dist/types/components/control-panel-desktop/model.d.ts +7 -0
- package/dist/types/components/control-panel-flat-icon-navigation/control-panel-flat-icon-navigation.d.ts +22 -0
- package/dist/types/components/control-panel-flat-icon-navigation/index.d.ts +2 -0
- package/dist/types/components/control-panel-flat-icon-navigation/model.d.ts +7 -0
- package/dist/types/components/{brand/brand.d.ts → control-panel-meta-navigation/control-panel-meta-navigation.d.ts} +4 -8
- package/dist/types/components/control-panel-meta-navigation/index.d.ts +2 -0
- package/dist/types/components/control-panel-meta-navigation/model.d.ts +5 -0
- package/dist/types/components/control-panel-mobile/control-panel-mobile.d.ts +32 -0
- package/dist/types/components/control-panel-mobile/index.d.ts +2 -0
- package/dist/types/components/control-panel-mobile/model.d.ts +30 -0
- package/dist/types/components/control-panel-primary-actions/control-panel-primary-actions.d.ts +18 -0
- package/dist/types/components/control-panel-primary-actions/index.d.ts +2 -0
- package/dist/types/components/control-panel-primary-actions/model.d.ts +5 -0
- package/dist/types/components/control-panel-secondary-actions/control-panel-secondary-actions.d.ts +18 -0
- package/dist/types/components/control-panel-secondary-actions/index.d.ts +2 -0
- package/dist/types/components/control-panel-secondary-actions/model.d.ts +5 -0
- package/dist/types/components/custom-select/custom-select.d.ts +1 -1
- package/dist/types/components/custom-select/model.d.ts +4 -1
- package/dist/types/components/drawer/drawer.d.ts +1 -0
- package/dist/types/components/drawer/model.d.ts +5 -1
- package/dist/types/components/navigation/model.d.ts +14 -5
- package/dist/types/components/navigation/navigation.d.ts +19 -1
- package/dist/types/components/navigation-item/model.d.ts +9 -24
- package/dist/types/components/navigation-item/navigation-item.d.ts +2 -24
- package/dist/types/components/navigation-item-group/index.d.ts +2 -0
- package/dist/types/components/navigation-item-group/model.d.ts +26 -0
- package/dist/types/components/navigation-item-group/navigation-item-group.d.ts +50 -0
- package/dist/types/components/popover/popover.d.ts +1 -1
- package/dist/types/components/shell/index.d.ts +2 -0
- package/dist/types/components/shell/model.d.ts +50 -0
- package/dist/types/components/shell/shell.d.ts +28 -0
- package/dist/types/components/shell-sub-navigation/index.d.ts +2 -0
- package/dist/types/components/shell-sub-navigation/model.d.ts +5 -0
- package/dist/types/components/shell-sub-navigation/shell-sub-navigation.d.ts +24 -0
- package/dist/types/components/tabs/model.d.ts +3 -11
- package/dist/types/components/tooltip/tooltip.d.ts +1 -1
- package/dist/types/components.d.ts +302 -119
- package/dist/types/index.d.ts +19 -6
- package/dist/types/shared/constants.d.ts +3 -0
- package/dist/types/shared/model.d.ts +82 -3
- package/dist/types/utils/floating-components.d.ts +17 -1
- package/dist/types/utils/navigation.d.ts +2 -6
- package/dist/vscode.html-custom-data.json +532 -327
- package/dist/web-types.json +1235 -795
- package/package.json +5 -7
- package/agent/Accordion.md +0 -23
- package/agent/AccordionItem.md +0 -29
- package/agent/Badge.md +0 -32
- package/agent/Brand.md +0 -13
- package/agent/Button.md +0 -47
- package/agent/Card.md +0 -23
- package/agent/Checkbox.md +0 -41
- package/agent/CustomSelect.md +0 -54
- package/agent/Divider.md +0 -21
- package/agent/Drawer.md +0 -71
- package/agent/Header.md +0 -29
- package/agent/Icon.md +0 -20
- package/agent/Infotext.md +0 -25
- package/agent/Input.md +0 -48
- package/agent/Link.md +0 -52
- package/agent/Navigation.md +0 -19
- package/agent/NavigationItem.md +0 -29
- package/agent/Notification.md +0 -38
- package/agent/Page.md +0 -27
- package/agent/Popover.md +0 -52
- package/agent/Radio.md +0 -28
- package/agent/Section.md +0 -21
- package/agent/Select.md +0 -62
- package/agent/Stack.md +0 -35
- package/agent/Switch.md +0 -44
- package/agent/TabItem.md +0 -25
- package/agent/Tabs.md +0 -61
- package/agent/Tag.md +0 -41
- package/agent/Textarea.md +0 -44
- package/agent/Tooltip.md +0 -37
- package/agent/_instructions.md +0 -31
- package/dist/cjs/constants-CTtyzyuo.js.map +0 -1
- package/dist/cjs/db-brand.cjs.entry.js.map +0 -1
- package/dist/cjs/db-brand.entry.cjs.js.map +0 -1
- package/dist/cjs/db-header.cjs.entry.js +0 -96
- package/dist/cjs/db-header.cjs.entry.js.map +0 -1
- package/dist/cjs/db-header.entry.cjs.js.map +0 -1
- package/dist/cjs/db-page.cjs.entry.js.map +0 -1
- package/dist/cjs/db-page.entry.cjs.js.map +0 -1
- package/dist/cjs/floating-components-ogUqz72V.js.map +0 -1
- package/dist/cjs/index-9urL1KCD.js.map +0 -1
- package/dist/cjs/navigation-DauGE-qj.js.map +0 -1
- package/dist/collection/components/brand/brand.js.map +0 -1
- package/dist/collection/components/brand/index.js +0 -3
- package/dist/collection/components/brand/index.js.map +0 -1
- package/dist/collection/components/brand/model.js.map +0 -1
- package/dist/collection/components/header/header.js.map +0 -1
- package/dist/collection/components/header/index.js +0 -3
- package/dist/collection/components/header/index.js.map +0 -1
- package/dist/collection/components/header/model.js.map +0 -1
- package/dist/collection/components/page/index.js +0 -3
- package/dist/collection/components/page/index.js.map +0 -1
- package/dist/collection/components/page/model.js +0 -3
- package/dist/collection/components/page/model.js.map +0 -1
- package/dist/collection/components/page/page.js.map +0 -1
- package/dist/db-ux/db-brand.entry.esm.js.map +0 -1
- package/dist/db-ux/db-header.entry.esm.js.map +0 -1
- package/dist/db-ux/db-page.entry.esm.js.map +0 -1
- package/dist/db-ux/p-340bb722.entry.js +0 -2
- package/dist/db-ux/p-340bb722.entry.js.map +0 -1
- package/dist/db-ux/p-3d7eb768.entry.js +0 -2
- package/dist/db-ux/p-3d7eb768.entry.js.map +0 -1
- package/dist/db-ux/p-51de401e.entry.js +0 -2
- package/dist/db-ux/p-58007675.entry.js +0 -2
- package/dist/db-ux/p-58007675.entry.js.map +0 -1
- package/dist/db-ux/p-5b45664d.entry.js +0 -2
- package/dist/db-ux/p-5c6da0f3.entry.js +0 -2
- package/dist/db-ux/p-6e35a260.entry.js +0 -2
- package/dist/db-ux/p-6e35a260.entry.js.map +0 -1
- package/dist/db-ux/p-72330d25.entry.js +0 -2
- package/dist/db-ux/p-72330d25.entry.js.map +0 -1
- package/dist/db-ux/p-84dd974f.entry.js +0 -2
- package/dist/db-ux/p-84dd974f.entry.js.map +0 -1
- package/dist/db-ux/p-8b41c30e.entry.js +0 -2
- package/dist/db-ux/p-8b41c30e.entry.js.map +0 -1
- package/dist/db-ux/p-971a16c3.entry.js +0 -2
- package/dist/db-ux/p-971a16c3.entry.js.map +0 -1
- package/dist/db-ux/p-9d0996e9.entry.js +0 -2
- package/dist/db-ux/p-CNzNv7KB.js +0 -3
- package/dist/db-ux/p-CNzNv7KB.js.map +0 -1
- package/dist/db-ux/p-DC9V_oNU.js +0 -2
- package/dist/db-ux/p-DC9V_oNU.js.map +0 -1
- package/dist/db-ux/p-G-TursYV.js +0 -2
- package/dist/db-ux/p-G-TursYV.js.map +0 -1
- package/dist/db-ux/p-a3541c03.entry.js +0 -2
- package/dist/db-ux/p-a3541c03.entry.js.map +0 -1
- package/dist/db-ux/p-c8bdd952.entry.js +0 -2
- package/dist/db-ux/p-c8cdde8c.entry.js +0 -2
- package/dist/db-ux/p-ce895e0c.entry.js +0 -2
- package/dist/db-ux/p-ce895e0c.entry.js.map +0 -1
- package/dist/db-ux/p-d4e3d1db.entry.js +0 -2
- package/dist/db-ux/p-d4e3d1db.entry.js.map +0 -1
- package/dist/db-ux/p-d6aeabf0.entry.js +0 -2
- package/dist/db-ux/p-e9c323af.entry.js +0 -2
- package/dist/db-ux/p-e9c323af.entry.js.map +0 -1
- package/dist/db-ux/p-ec957247.entry.js +0 -2
- package/dist/db-ux/p-ec957247.entry.js.map +0 -1
- package/dist/db-ux/p-fdf5578d.entry.js +0 -2
- package/dist/db-ux/p-fdf5578d.entry.js.map +0 -1
- package/dist/db-ux/p-sP2NlPcu.js +0 -2
- package/dist/db-ux/p-sP2NlPcu.js.map +0 -1
- package/dist/esm/constants-DC9V_oNU.js.map +0 -1
- package/dist/esm/db-brand.entry.js.map +0 -1
- package/dist/esm/db-header.entry.js +0 -94
- package/dist/esm/db-header.entry.js.map +0 -1
- package/dist/esm/db-page.entry.js.map +0 -1
- package/dist/esm/floating-components-G-TursYV.js.map +0 -1
- package/dist/esm/index-CNzNv7KB.js.map +0 -1
- package/dist/esm/navigation--UdC9CzO.js.map +0 -1
- package/dist/types/components/brand/index.d.ts +0 -2
- package/dist/types/components/brand/model.d.ts +0 -10
- package/dist/types/components/header/header.d.ts +0 -33
- package/dist/types/components/header/index.d.ts +0 -2
- package/dist/types/components/header/model.d.ts +0 -44
- package/dist/types/components/page/index.d.ts +0 -2
- package/dist/types/components/page/model.d.ts +0 -36
- package/dist/types/components/page/page.d.ts +0 -25
- /package/dist/collection/components/{brand → control-panel-brand}/model.js +0 -0
- /package/dist/collection/components/{header → control-panel-desktop}/model.js +0 -0
- /package/dist/db-ux/{p-5c6da0f3.entry.js.map → p-1dccdff4.entry.js.map} +0 -0
- /package/dist/db-ux/{p-c8bdd952.entry.js.map → p-4645cc92.entry.js.map} +0 -0
- /package/dist/db-ux/{p-c5ff3d3f.entry.js.map → p-504a9cfc.entry.js.map} +0 -0
- /package/dist/db-ux/{p-e6e7719e.entry.js.map → p-53682d25.entry.js.map} +0 -0
- /package/dist/db-ux/{p-51de401e.entry.js.map → p-5be272f0.entry.js.map} +0 -0
- /package/dist/db-ux/{p-16f1fa7c.entry.js.map → p-5d292f94.entry.js.map} +0 -0
- /package/dist/db-ux/{p-02fcd4a8.entry.js.map → p-5e4ac324.entry.js.map} +0 -0
- /package/dist/db-ux/{p-f03f7076.entry.js.map → p-6fd148ce.entry.js.map} +0 -0
- /package/dist/db-ux/{p-5b45664d.entry.js.map → p-7153636c.entry.js.map} +0 -0
- /package/dist/db-ux/{p-9d0996e9.entry.js.map → p-73614370.entry.js.map} +0 -0
- /package/dist/db-ux/{p-209cf793.entry.js.map → p-81d7921b.entry.js.map} +0 -0
- /package/dist/db-ux/{p-d7168627.entry.js.map → p-8262ab69.entry.js.map} +0 -0
- /package/dist/db-ux/{p-c8cdde8c.entry.js.map → p-99d090b7.entry.js.map} +0 -0
- /package/dist/db-ux/{p-bd7d1646.entry.js.map → p-b713791b.entry.js.map} +0 -0
- /package/dist/db-ux/{p-a2b55626.entry.js.map → p-d6047812.entry.js.map} +0 -0
|
@@ -60,9 +60,11 @@ export const handleDataOutside = (el) => {
|
|
|
60
60
|
return dataOutsidePair;
|
|
61
61
|
};
|
|
62
62
|
export const handleFixedDropdown = (element, parent, placement) => {
|
|
63
|
-
// We skip this if we are in mobile it's already fixed
|
|
64
|
-
|
|
63
|
+
// We skip this if we are in mobile it's already fixed or if we don't have a floating dropdown
|
|
64
|
+
const computedStyle = getComputedStyle(element);
|
|
65
|
+
if (computedStyle.zIndex === '9999' || computedStyle.position !== 'fixed' && computedStyle.position !== 'absolute') {
|
|
65
66
|
return;
|
|
67
|
+
}
|
|
66
68
|
const { top, bottom, childHeight, childWidth, width, right, left, correctedPlacement } = getFloatingProps(element, parent, placement);
|
|
67
69
|
const fullWidth = element.dataset['width'] === 'full';
|
|
68
70
|
if (fullWidth) {
|
|
@@ -104,27 +106,29 @@ export const getFloatingProps = (element, parent, placement) => {
|
|
|
104
106
|
let childHeight = childRect.height;
|
|
105
107
|
let childWidth = childRect.width;
|
|
106
108
|
if (placement === 'bottom' || placement === 'top') {
|
|
107
|
-
childWidth = childWidth / 2;
|
|
109
|
+
childWidth = width > childWidth ? 0 : childWidth / 2;
|
|
108
110
|
}
|
|
109
111
|
if (placement === 'left' || placement === 'right') {
|
|
110
|
-
childHeight = childHeight / 2;
|
|
112
|
+
childHeight = height > childHeight ? 0 : childHeight / 2;
|
|
111
113
|
}
|
|
112
|
-
const outsideBottom = bottom + childHeight > innerHeight;
|
|
113
|
-
const outsideTop = top - childHeight < 0;
|
|
114
|
-
const outsideLeft = left - childWidth < 0;
|
|
115
|
-
const outsideRight = right + childWidth > innerWidth;
|
|
114
|
+
const outsideBottom = Math.floor(bottom + childHeight) > innerHeight;
|
|
115
|
+
const outsideTop = Math.ceil(top - childHeight) < 0;
|
|
116
|
+
const outsideLeft = Math.ceil(left - childWidth) < 0;
|
|
117
|
+
const outsideRight = Math.floor(right + childWidth) > innerWidth;
|
|
116
118
|
let correctedPlacement = placement;
|
|
117
119
|
if (placement.startsWith('bottom')) {
|
|
118
120
|
if (outsideBottom) {
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
121
|
+
if (!outsideTop) {
|
|
122
|
+
correctedPlacement = placement === null || placement === void 0 ? void 0 : placement.replace('bottom', 'top');
|
|
123
|
+
if (outsideLeft && outsideRight) {
|
|
124
|
+
correctedPlacement = 'top';
|
|
125
|
+
}
|
|
126
|
+
else if (outsideLeft) {
|
|
127
|
+
correctedPlacement = 'top-start';
|
|
128
|
+
}
|
|
129
|
+
else if (outsideRight) {
|
|
130
|
+
correctedPlacement = 'top-end';
|
|
131
|
+
}
|
|
128
132
|
}
|
|
129
133
|
}
|
|
130
134
|
else {
|
|
@@ -141,15 +145,17 @@ export const getFloatingProps = (element, parent, placement) => {
|
|
|
141
145
|
}
|
|
142
146
|
else if (placement.startsWith('top')) {
|
|
143
147
|
if (outsideTop) {
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
148
|
+
if (!outsideBottom) {
|
|
149
|
+
correctedPlacement = placement === null || placement === void 0 ? void 0 : placement.replace('top', 'bottom');
|
|
150
|
+
if (outsideLeft && outsideRight) {
|
|
151
|
+
correctedPlacement = 'bottom';
|
|
152
|
+
}
|
|
153
|
+
else if (outsideLeft) {
|
|
154
|
+
correctedPlacement = 'bottom-start';
|
|
155
|
+
}
|
|
156
|
+
else if (outsideRight) {
|
|
157
|
+
correctedPlacement = 'bottom-end';
|
|
158
|
+
}
|
|
153
159
|
}
|
|
154
160
|
}
|
|
155
161
|
else {
|
|
@@ -166,15 +172,17 @@ export const getFloatingProps = (element, parent, placement) => {
|
|
|
166
172
|
}
|
|
167
173
|
else if (placement.startsWith('left')) {
|
|
168
174
|
if (outsideLeft) {
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
175
|
+
if (outsideRight) {
|
|
176
|
+
correctedPlacement = placement === null || placement === void 0 ? void 0 : placement.replace('left', 'right');
|
|
177
|
+
if (outsideBottom && outsideTop) {
|
|
178
|
+
correctedPlacement = 'right';
|
|
179
|
+
}
|
|
180
|
+
else if (outsideBottom) {
|
|
181
|
+
correctedPlacement = 'right-end';
|
|
182
|
+
}
|
|
183
|
+
else if (outsideTop) {
|
|
184
|
+
correctedPlacement = 'right-start';
|
|
185
|
+
}
|
|
178
186
|
}
|
|
179
187
|
}
|
|
180
188
|
else {
|
|
@@ -191,15 +199,17 @@ export const getFloatingProps = (element, parent, placement) => {
|
|
|
191
199
|
}
|
|
192
200
|
else if (correctedPlacement.startsWith('right')) {
|
|
193
201
|
if (outsideRight) {
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
202
|
+
if (!outsideLeft) {
|
|
203
|
+
correctedPlacement = placement === null || placement === void 0 ? void 0 : placement.replace('right', 'left');
|
|
204
|
+
if (outsideBottom && outsideTop) {
|
|
205
|
+
correctedPlacement = 'left';
|
|
206
|
+
}
|
|
207
|
+
else if (outsideBottom) {
|
|
208
|
+
correctedPlacement = 'left-end';
|
|
209
|
+
}
|
|
210
|
+
else if (outsideTop) {
|
|
211
|
+
correctedPlacement = 'left-start';
|
|
212
|
+
}
|
|
203
213
|
}
|
|
204
214
|
}
|
|
205
215
|
else {
|
|
@@ -225,13 +235,24 @@ export const getFloatingProps = (element, parent, placement) => {
|
|
|
225
235
|
childWidth: childRect.width,
|
|
226
236
|
correctedPlacement,
|
|
227
237
|
innerWidth,
|
|
228
|
-
innerHeight
|
|
238
|
+
innerHeight,
|
|
239
|
+
outsideYBoth: outsideTop && outsideBottom,
|
|
240
|
+
outsideXBoth: outsideRight && outsideLeft
|
|
229
241
|
};
|
|
230
242
|
};
|
|
231
243
|
export const handleFixedPopover = (element, parent, placement) => {
|
|
232
|
-
var _a;
|
|
233
|
-
const
|
|
234
|
-
|
|
244
|
+
var _a, _b, _c;
|
|
245
|
+
const computedStyle = getComputedStyle(element);
|
|
246
|
+
// We skip if we don't have a floating popover
|
|
247
|
+
if (computedStyle.position !== 'fixed' && computedStyle.position !== 'absolute') {
|
|
248
|
+
return;
|
|
249
|
+
}
|
|
250
|
+
let distance = computedStyle.getPropertyValue('--db-popover-distance');
|
|
251
|
+
if (!distance.length) {
|
|
252
|
+
distance = '0px';
|
|
253
|
+
}
|
|
254
|
+
const elementPlacement = (_c = (_b = (_a = element === null || element === void 0 ? void 0 : element.dataset) === null || _a === void 0 ? void 0 : _a['placement']) !== null && _b !== void 0 ? _b : placement) !== null && _c !== void 0 ? _c : 'bottom';
|
|
255
|
+
const { top, height, width, childHeight, childWidth, right, left, bottom, correctedPlacement, innerWidth, innerHeight, outsideYBoth } = getFloatingProps(element, parent, elementPlacement);
|
|
235
256
|
// Tooltip arrow position
|
|
236
257
|
if (childWidth > width && (correctedPlacement.startsWith('bottom') || correctedPlacement.startsWith('top'))) {
|
|
237
258
|
const diff = width / 2 / childWidth * 100;
|
|
@@ -300,6 +321,13 @@ export const handleFixedPopover = (element, parent, placement) => {
|
|
|
300
321
|
element.style.insetBlockStart = `calc(${bottom}px + ${distance})`;
|
|
301
322
|
element.style.insetBlockEnd = `calc(${end > innerHeight ? innerHeight : end}px + ${distance})`;
|
|
302
323
|
}
|
|
324
|
+
// In this case we are outside of top and bottom so we need to scroll
|
|
325
|
+
// We use the full height in this case
|
|
326
|
+
if (outsideYBoth) {
|
|
327
|
+
element.style.overflow = 'hidden auto';
|
|
328
|
+
element.style.insetBlock = distance;
|
|
329
|
+
element.style.maxBlockSize = `calc(${innerHeight}px - 2 * ${distance})`;
|
|
330
|
+
}
|
|
303
331
|
element.style.position = 'fixed';
|
|
304
332
|
element.dataset['correctedPlacement'] = correctedPlacement;
|
|
305
333
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"floating-components.js","sourceRoot":"","sources":["../../src/utils/floating-components.ts"],"names":[],"mappings":"AAAA,0GAA0G;AAC1G,MAAM,QAAQ,GAAG,CAAC,EAAe,EAAE,EAAE;;IACnC,MAAM,EACJ,GAAG,EACH,MAAM,EACN,IAAI,EACJ,KAAK,EACN,GAAG,EAAE,CAAC,qBAAqB,EAAE,CAAC;IAC/B,MAAM,EACJ,WAAW,EACX,UAAU,EACX,GAAG,MAAM,CAAC;IACX,IAAI,MAAM,GAAG,GAAG,GAAG,CAAC,CAAC;IACrB,IAAI,SAAS,GAAG,MAAM,GAAG,WAAW,CAAC;IACrC,IAAI,OAAO,GAAG,IAAI,GAAG,CAAC,CAAC;IACvB,IAAI,QAAQ,GAAG,KAAK,GAAG,UAAU,CAAC;IAElC,6CAA6C;IAC7C,MAAM,QAAQ,GAAG,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACzC,MAAM,QAAQ,GAAG,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACzC,MAAM,UAAU,GAAG,MAAA,EAAE,aAAF,EAAE,uBAAF,EAAE,CAAE,aAAa,0CAAE,qBAAqB,EAAE,CAAC;IAC9D,IAAI,UAAU,EAAE,CAAC;QACf,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,QAAQ,GAAG,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACzC,IAAI,QAAQ,KAAK,KAAK,EAAE,CAAC;gBACvB,MAAM,GAAG,UAAU,CAAC,GAAG,GAAG,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,SAAS,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,UAAU,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,WAAW,CAAC;YACvE,CAAC;QACH,CAAC;QACD,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,QAAQ,GAAG,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACzC,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;gBACxB,OAAO,GAAG,UAAU,CAAC,IAAI,GAAG,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,QAAQ,GAAG,UAAU,CAAC,KAAK,GAAG,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,UAAU,CAAC;YACtE,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO;QACL,MAAM;QACN,SAAS;QACT,OAAO;QACP,QAAQ;KACT,CAAC;AACJ,CAAC,CAAC;AAKF,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAe,EAAqB,EAAE;IACtE,MAAM,EACJ,MAAM,EACN,SAAS,EACT,OAAO,EACP,QAAQ,EACT,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IACjB,IAAI,eAAe,GAAsB,EAAE,CAAC;IAC5C,IAAI,MAAM,IAAI,SAAS,EAAE,CAAC;QACxB,eAAe,GAAG;YAChB,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;SAC9B,CAAC;QACF,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,eAAe,CAAC,EAAG,CAAC;IAChD,CAAC;SAAM,CAAC;QACN,OAAO,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACjC,CAAC;IACD,IAAI,OAAO,IAAI,QAAQ,EAAE,CAAC;QACxB,eAAe,mCACV,eAAe,KAClB,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,GAChC,CAAC;QACF,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,eAAe,CAAC,EAAG,CAAC;IAChD,CAAC;SAAM,CAAC;QACN,OAAO,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACjC,CAAC;IACD,OAAO,eAAe,CAAC;AACzB,CAAC,CAAC;AACF,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,OAAoB,EAAE,MAAmB,EAAE,SAAiB,EAAE,EAAE;IAClG,sDAAsD;IACtD,IAAI,gBAAgB,CAAC,OAAO,CAAC,CAAC,MAAM,KAAK,MAAM;QAAE,OAAO;IACxD,MAAM,EACJ,GAAG,EACH,MAAM,EACN,WAAW,EACX,UAAU,EACV,KAAK,EACL,KAAK,EACL,IAAI,EACJ,kBAAkB,EACnB,GAAG,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;IACjD,MAAM,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,MAAM,CAAC;IACtD,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG,KAAK,IAAI,CAAC;IAC1C,CAAC;IACD,IAAI,kBAAkB,KAAK,KAAK,IAAI,kBAAkB,KAAK,QAAQ,IAAI,kBAAkB,KAAK,WAAW,IAAI,kBAAkB,KAAK,cAAc,EAAE,CAAC;QACnJ,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,GAAG,IAAI,IAAI,CAAC;IAC/C,CAAC;SAAM,IAAI,kBAAkB,KAAK,SAAS,IAAI,kBAAkB,KAAK,YAAY,EAAE,CAAC;QACnF,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,GAAG,KAAK,GAAG,UAAU,IAAI,CAAC;IAC7D,CAAC;IACD,IAAI,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1C,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,GAAG,GAAG,WAAW,IAAI,CAAC;IAC3D,CAAC;SAAM,IAAI,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QACpD,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,MAAM,IAAI,CAAC;IAChD,CAAC;IACD,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;AACnC,CAAC,CAAC;AACF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,OAAoB,EAAE,MAAmB,EAAE,SAAiB,EAAE,EAAE;IAC/F,IAAI,CAAC,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;QACxB,OAAO;YACL,GAAG,EAAE,CAAC;YACN,MAAM,EAAE,CAAC;YACT,KAAK,EAAE,CAAC;YACR,MAAM,EAAE,CAAC;YACT,KAAK,EAAE,CAAC;YACR,IAAI,EAAE,CAAC;YACP,WAAW,EAAE,CAAC;YACd,UAAU,EAAE,CAAC;YACb,kBAAkB,EAAE,SAAS;YAC7B,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,WAAW,EAAE,MAAM,CAAC,WAAW;SAChC,CAAC;IACJ,CAAC;IACD,MAAM,SAAS,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC;IAClD,MAAM,EACJ,GAAG,EACH,MAAM,EACN,MAAM,EACN,KAAK,EACL,IAAI,EACJ,KAAK,EACN,GAAG,MAAM,CAAC,qBAAqB,EAAE,CAAC;IACnC,MAAM,EACJ,WAAW,EACX,UAAU,EACX,GAAG,MAAM,CAAC;IACX,IAAI,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC;IACnC,IAAI,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC;IACjC,IAAI,SAAS,KAAK,QAAQ,IAAI,SAAS,KAAK,KAAK,EAAE,CAAC;QAClD,UAAU,GAAG,UAAU,GAAG,CAAC,CAAC;IAC9B,CAAC;IACD,IAAI,SAAS,KAAK,MAAM,IAAI,SAAS,KAAK,OAAO,EAAE,CAAC;QAClD,WAAW,GAAG,WAAW,GAAG,CAAC,CAAC;IAChC,CAAC;IACD,MAAM,aAAa,GAAG,MAAM,GAAG,WAAW,GAAG,WAAW,CAAC;IACzD,MAAM,UAAU,GAAG,GAAG,GAAG,WAAW,GAAG,CAAC,CAAC;IACzC,MAAM,WAAW,GAAG,IAAI,GAAG,UAAU,GAAG,CAAC,CAAC;IAC1C,MAAM,YAAY,GAAG,KAAK,GAAG,UAAU,GAAG,UAAU,CAAC;IACrD,IAAI,kBAAkB,GAAG,SAAS,CAAC;IACnC,IAAI,SAAS,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QACnC,IAAI,aAAa,EAAE,CAAC;YAClB,kBAAkB,GAAG,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YACzD,IAAI,WAAW,IAAI,YAAY,EAAE,CAAC;gBAChC,kBAAkB,GAAG,KAAK,CAAC;YAC7B,CAAC;iBAAM,IAAI,WAAW,EAAE,CAAC;gBACvB,kBAAkB,GAAG,WAAW,CAAC;YACnC,CAAC;iBAAM,IAAI,YAAY,EAAE,CAAC;gBACxB,kBAAkB,GAAG,SAAS,CAAC;YACjC,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,WAAW,IAAI,YAAY,EAAE,CAAC;gBAChC,kBAAkB,GAAG,QAAQ,CAAC;YAChC,CAAC;iBAAM,IAAI,WAAW,EAAE,CAAC;gBACvB,kBAAkB,GAAG,cAAc,CAAC;YACtC,CAAC;iBAAM,IAAI,YAAY,EAAE,CAAC;gBACxB,kBAAkB,GAAG,YAAY,CAAC;YACpC,CAAC;QACH,CAAC;IACH,CAAC;SAAM,IAAI,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QACvC,IAAI,UAAU,EAAE,CAAC;YACf,kBAAkB,GAAG,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;YACzD,IAAI,WAAW,IAAI,YAAY,EAAE,CAAC;gBAChC,kBAAkB,GAAG,QAAQ,CAAC;YAChC,CAAC;iBAAM,IAAI,WAAW,EAAE,CAAC;gBACvB,kBAAkB,GAAG,cAAc,CAAC;YACtC,CAAC;iBAAM,IAAI,YAAY,EAAE,CAAC;gBACxB,kBAAkB,GAAG,YAAY,CAAC;YACpC,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,WAAW,IAAI,YAAY,EAAE,CAAC;gBAChC,kBAAkB,GAAG,KAAK,CAAC;YAC7B,CAAC;iBAAM,IAAI,WAAW,EAAE,CAAC;gBACvB,kBAAkB,GAAG,WAAW,CAAC;YACnC,CAAC;iBAAM,IAAI,YAAY,EAAE,CAAC;gBACxB,kBAAkB,GAAG,SAAS,CAAC;YACjC,CAAC;QACH,CAAC;IACH,CAAC;SAAM,IAAI,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QACxC,IAAI,WAAW,EAAE,CAAC;YAChB,kBAAkB,GAAG,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;YACzD,IAAI,aAAa,IAAI,UAAU,EAAE,CAAC;gBAChC,kBAAkB,GAAG,OAAO,CAAC;YAC/B,CAAC;iBAAM,IAAI,aAAa,EAAE,CAAC;gBACzB,kBAAkB,GAAG,WAAW,CAAC;YACnC,CAAC;iBAAM,IAAI,UAAU,EAAE,CAAC;gBACtB,kBAAkB,GAAG,aAAa,CAAC;YACrC,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,aAAa,IAAI,UAAU,EAAE,CAAC;gBAChC,kBAAkB,GAAG,MAAM,CAAC;YAC9B,CAAC;iBAAM,IAAI,aAAa,EAAE,CAAC;gBACzB,kBAAkB,GAAG,UAAU,CAAC;YAClC,CAAC;iBAAM,IAAI,UAAU,EAAE,CAAC;gBACtB,kBAAkB,GAAG,YAAY,CAAC;YACpC,CAAC;QACH,CAAC;IACH,CAAC;SAAM,IAAI,kBAAkB,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAClD,IAAI,YAAY,EAAE,CAAC;YACjB,kBAAkB,GAAG,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;YACzD,IAAI,aAAa,IAAI,UAAU,EAAE,CAAC;gBAChC,kBAAkB,GAAG,MAAM,CAAC;YAC9B,CAAC;iBAAM,IAAI,aAAa,EAAE,CAAC;gBACzB,kBAAkB,GAAG,UAAU,CAAC;YAClC,CAAC;iBAAM,IAAI,UAAU,EAAE,CAAC;gBACtB,kBAAkB,GAAG,YAAY,CAAC;YACpC,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,aAAa,IAAI,UAAU,EAAE,CAAC;gBAChC,kBAAkB,GAAG,OAAO,CAAC;YAC/B,CAAC;iBAAM,IAAI,aAAa,EAAE,CAAC;gBACzB,kBAAkB,GAAG,WAAW,CAAC;YACnC,CAAC;iBAAM,IAAI,UAAU,EAAE,CAAC;gBACtB,kBAAkB,GAAG,aAAa,CAAC;YACrC,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO;QACL,GAAG;QACH,MAAM;QACN,KAAK;QACL,MAAM;QACN,KAAK;QACL,IAAI;QACJ,WAAW,EAAE,SAAS,CAAC,MAAM;QAC7B,UAAU,EAAE,SAAS,CAAC,KAAK;QAC3B,kBAAkB;QAClB,UAAU;QACV,WAAW;KACZ,CAAC;AACJ,CAAC,CAAC;AACF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,OAAoB,EAAE,MAAmB,EAAE,SAAiB,EAAE,EAAE;;IACjG,MAAM,QAAQ,GAAG,MAAA,gBAAgB,CAAC,OAAO,CAAC,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,mCAAI,KAAK,CAAC;IAC9F,MAAM,EACJ,GAAG,EACH,MAAM,EACN,KAAK,EACL,WAAW,EACX,UAAU,EACV,KAAK,EACL,IAAI,EACJ,MAAM,EACN,kBAAkB,EAClB,UAAU,EACV,WAAW,EACZ,GAAG,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;IAEjD,yBAAyB;IAEzB,IAAI,UAAU,GAAG,KAAK,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,kBAAkB,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;QAC5G,MAAM,IAAI,GAAG,KAAK,GAAG,CAAC,GAAG,UAAU,GAAG,GAAG,CAAC;QAC1C,IAAI,kBAAkB,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YACzC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,iCAAiC,EAAE,GAAG,IAAI,GAAG,CAAC,CAAC;QAC3E,CAAC;aAAM,IAAI,kBAAkB,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YAC9C,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,iCAAiC,EAAE,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC,CAAC;QACjF,CAAC;IACH,CAAC;IACD,IAAI,WAAW,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,kBAAkB,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;QAC/G,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,GAAG,WAAW,GAAG,GAAG,CAAC;QAC5C,IAAI,kBAAkB,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YACzC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,gCAAgC,EAAE,GAAG,IAAI,GAAG,CAAC,CAAC;QAC1E,CAAC;aAAM,IAAI,kBAAkB,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YAC9C,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,gCAAgC,EAAE,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC,CAAC;QAChF,CAAC;IACH,CAAC;IAED,mBAAmB;IAEnB,IAAI,kBAAkB,KAAK,OAAO,IAAI,kBAAkB,KAAK,MAAM,EAAE,CAAC;QACpE,sBAAsB;QACtB,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,GAAG,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC;IAC1D,CAAC;SAAM,IAAI,kBAAkB,KAAK,aAAa,IAAI,kBAAkB,KAAK,YAAY,EAAE,CAAC;QACvF,MAAM,GAAG,GAAG,GAAG,GAAG,WAAW,CAAC;QAC9B,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,GAAG,IAAI,CAAC;QAC3C,OAAO,CAAC,KAAK,CAAC,aAAa,GAAG,GAAG,GAAG,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAC7E,CAAC;SAAM,IAAI,kBAAkB,KAAK,WAAW,IAAI,kBAAkB,KAAK,UAAU,EAAE,CAAC;QACnF,MAAM,KAAK,GAAG,MAAM,GAAG,WAAW,CAAC;QACnC,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC;QAC7D,OAAO,CAAC,KAAK,CAAC,aAAa,GAAG,GAAG,MAAM,IAAI,CAAC;IAC9C,CAAC;SAAM,IAAI,kBAAkB,KAAK,KAAK,IAAI,kBAAkB,KAAK,QAAQ,EAAE,CAAC;QAC3E,oBAAoB;QACpB,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,GAAG,IAAI,GAAG,KAAK,GAAG,CAAC,IAAI,CAAC;IAC3D,CAAC;SAAM,IAAI,kBAAkB,KAAK,WAAW,IAAI,kBAAkB,KAAK,cAAc,EAAE,CAAC;QACvF,MAAM,GAAG,GAAG,IAAI,GAAG,UAAU,CAAC;QAC9B,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,GAAG,IAAI,IAAI,CAAC;QAC7C,OAAO,CAAC,KAAK,CAAC,cAAc,GAAG,GAAG,GAAG,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAC5E,CAAC;SAAM,IAAI,kBAAkB,KAAK,SAAS,IAAI,kBAAkB,KAAK,YAAY,EAAE,CAAC;QACnF,MAAM,KAAK,GAAG,IAAI,GAAG,UAAU,CAAC;QAChC,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,GAAG,KAAK,GAAG,UAAU,IAAI,CAAC;QAC3D,OAAO,CAAC,KAAK,CAAC,cAAc,GAAG,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC;IAC9D,CAAC;IACD,IAAI,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5C,MAAM,GAAG,GAAG,KAAK,GAAG,UAAU,CAAC;QAC/B,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,QAAQ,KAAK,QAAQ,QAAQ,GAAG,CAAC;QAClE,OAAO,CAAC,KAAK,CAAC,cAAc,GAAG,QAAQ,GAAG,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,QAAQ,QAAQ,GAAG,CAAC;IAChG,CAAC;SAAM,IAAI,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QAClD,MAAM,KAAK,GAAG,IAAI,GAAG,UAAU,CAAC;QAChC,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,QAAQ,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,QAAQ,QAAQ,GAAG,CAAC;QAClF,OAAO,CAAC,KAAK,CAAC,cAAc,GAAG,QAAQ,KAAK,QAAQ,QAAQ,GAAG,CAAC;IAClE,CAAC;SAAM,IAAI,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QACjD,MAAM,KAAK,GAAG,GAAG,GAAG,WAAW,CAAC;QAChC,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,QAAQ,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,QAAQ,QAAQ,GAAG,CAAC;QACjF,OAAO,CAAC,KAAK,CAAC,aAAa,GAAG,QAAQ,MAAM,QAAQ,QAAQ,GAAG,CAAC;IAClE,CAAC;SAAM,IAAI,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QACpD,MAAM,GAAG,GAAG,MAAM,GAAG,WAAW,CAAC;QACjC,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,QAAQ,MAAM,QAAQ,QAAQ,GAAG,CAAC;QAClE,OAAO,CAAC,KAAK,CAAC,aAAa,GAAG,QAAQ,GAAG,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,QAAQ,QAAQ,GAAG,CAAC;IACjG,CAAC;IACD,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;IACjC,OAAO,CAAC,OAAO,CAAC,oBAAoB,CAAC,GAAG,kBAAkB,CAAC;AAC7D,CAAC,CAAA","sourcesContent":["// TODO: We should reevaluate this as soon as CSS Anchor Positioning is supported in all relevant browsers\nconst isInView = (el: HTMLElement) => {\n const {\n top,\n bottom,\n left,\n right\n } = el.getBoundingClientRect();\n const {\n innerHeight,\n innerWidth\n } = window;\n let outTop = top < 0;\n let outBottom = bottom > innerHeight;\n let outLeft = left < 0;\n let outRight = right > innerWidth;\n\n // We need to check if it was already outside\n const outsideY = el.dataset['outsideVy'];\n const outsideX = el.dataset['outsideVx'];\n const parentRect = el?.parentElement?.getBoundingClientRect();\n if (parentRect) {\n if (outsideY) {\n const position = el.dataset['outsideVy'];\n if (position === 'top') {\n outTop = parentRect.top - (bottom - parentRect.bottom) < 0;\n } else {\n outBottom = parentRect.bottom + (parentRect.top - top) > innerHeight;\n }\n }\n if (outsideX) {\n const position = el.dataset['outsideVx'];\n if (position === 'left') {\n outLeft = parentRect.left - (right - parentRect.right) < 0;\n } else {\n outRight = parentRect.right + (parentRect.left - left) > innerWidth;\n }\n }\n }\n return {\n outTop,\n outBottom,\n outLeft,\n outRight\n };\n};\nexport interface DBDataOutsidePair {\n vx?: 'left' | 'right';\n vy?: 'top' | 'bottom';\n}\nexport const handleDataOutside = (el: HTMLElement): DBDataOutsidePair => {\n const {\n outTop,\n outBottom,\n outLeft,\n outRight\n } = isInView(el);\n let dataOutsidePair: DBDataOutsidePair = {};\n if (outTop || outBottom) {\n dataOutsidePair = {\n vy: outTop ? 'top' : 'bottom'\n };\n el.dataset['outsideVy'] = dataOutsidePair.vy!;\n } else {\n delete el.dataset['outsideVy'];\n }\n if (outLeft || outRight) {\n dataOutsidePair = {\n ...dataOutsidePair,\n vx: outRight ? 'right' : 'left'\n };\n el.dataset['outsideVx'] = dataOutsidePair.vx!;\n } else {\n delete el.dataset['outsideVx'];\n }\n return dataOutsidePair;\n};\nexport const handleFixedDropdown = (element: HTMLElement, parent: HTMLElement, placement: string) => {\n // We skip this if we are in mobile it's already fixed\n if (getComputedStyle(element).zIndex === '9999') return;\n const {\n top,\n bottom,\n childHeight,\n childWidth,\n width,\n right,\n left,\n correctedPlacement\n } = getFloatingProps(element, parent, placement);\n const fullWidth = element.dataset['width'] === 'full';\n if (fullWidth) {\n element.style.inlineSize = `${width}px`;\n }\n if (correctedPlacement === 'top' || correctedPlacement === 'bottom' || correctedPlacement === 'top-start' || correctedPlacement === 'bottom-start') {\n element.style.insetInlineStart = `${left}px`;\n } else if (correctedPlacement === 'top-end' || correctedPlacement === 'bottom-end') {\n element.style.insetInlineStart = `${right - childWidth}px`;\n }\n if (correctedPlacement?.startsWith('top')) {\n element.style.insetBlockStart = `${top - childHeight}px`;\n } else if (correctedPlacement?.startsWith('bottom')) {\n element.style.insetBlockStart = `${bottom}px`;\n }\n element.style.position = 'fixed';\n};\nexport const getFloatingProps = (element: HTMLElement, parent: HTMLElement, placement: string) => {\n if (!element || !parent) {\n return {\n top: 0,\n bottom: 0,\n right: 0,\n height: 0,\n width: 0,\n left: 0,\n childHeight: 0,\n childWidth: 0,\n correctedPlacement: placement,\n innerWidth: window.innerWidth,\n innerHeight: window.innerHeight\n };\n }\n const childRect = element.getBoundingClientRect();\n const {\n top,\n height,\n bottom,\n right,\n left,\n width\n } = parent.getBoundingClientRect();\n const {\n innerHeight,\n innerWidth\n } = window;\n let childHeight = childRect.height;\n let childWidth = childRect.width;\n if (placement === 'bottom' || placement === 'top') {\n childWidth = childWidth / 2;\n }\n if (placement === 'left' || placement === 'right') {\n childHeight = childHeight / 2;\n }\n const outsideBottom = bottom + childHeight > innerHeight;\n const outsideTop = top - childHeight < 0;\n const outsideLeft = left - childWidth < 0;\n const outsideRight = right + childWidth > innerWidth;\n let correctedPlacement = placement;\n if (placement.startsWith('bottom')) {\n if (outsideBottom) {\n correctedPlacement = placement?.replace('bottom', 'top');\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'top';\n } else if (outsideLeft) {\n correctedPlacement = 'top-start';\n } else if (outsideRight) {\n correctedPlacement = 'top-end';\n }\n } else {\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'bottom';\n } else if (outsideLeft) {\n correctedPlacement = 'bottom-start';\n } else if (outsideRight) {\n correctedPlacement = 'bottom-end';\n }\n }\n } else if (placement.startsWith('top')) {\n if (outsideTop) {\n correctedPlacement = placement?.replace('top', 'bottom');\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'bottom';\n } else if (outsideLeft) {\n correctedPlacement = 'bottom-start';\n } else if (outsideRight) {\n correctedPlacement = 'bottom-end';\n }\n } else {\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'top';\n } else if (outsideLeft) {\n correctedPlacement = 'top-start';\n } else if (outsideRight) {\n correctedPlacement = 'top-end';\n }\n }\n } else if (placement.startsWith('left')) {\n if (outsideLeft) {\n correctedPlacement = placement?.replace('left', 'right');\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'right';\n } else if (outsideBottom) {\n correctedPlacement = 'right-end';\n } else if (outsideTop) {\n correctedPlacement = 'right-start';\n }\n } else {\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'left';\n } else if (outsideBottom) {\n correctedPlacement = 'left-end';\n } else if (outsideTop) {\n correctedPlacement = 'left-start';\n }\n }\n } else if (correctedPlacement.startsWith('right')) {\n if (outsideRight) {\n correctedPlacement = placement?.replace('right', 'left');\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'left';\n } else if (outsideBottom) {\n correctedPlacement = 'left-end';\n } else if (outsideTop) {\n correctedPlacement = 'left-start';\n }\n } else {\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'right';\n } else if (outsideBottom) {\n correctedPlacement = 'right-end';\n } else if (outsideTop) {\n correctedPlacement = 'right-start';\n }\n }\n }\n return {\n top,\n bottom,\n right,\n height,\n width,\n left,\n childHeight: childRect.height,\n childWidth: childRect.width,\n correctedPlacement,\n innerWidth,\n innerHeight\n };\n};\nexport const handleFixedPopover = (element: HTMLElement, parent: HTMLElement, placement: string) => {\n const distance = getComputedStyle(element).getPropertyValue('--db-popover-distance') ?? '0px';\n const {\n top,\n height,\n width,\n childHeight,\n childWidth,\n right,\n left,\n bottom,\n correctedPlacement,\n innerWidth,\n innerHeight\n } = getFloatingProps(element, parent, placement);\n\n // Tooltip arrow position\n\n if (childWidth > width && (correctedPlacement.startsWith('bottom') || correctedPlacement.startsWith('top'))) {\n const diff = width / 2 / childWidth * 100;\n if (correctedPlacement.endsWith('start')) {\n element.style.setProperty('--db-tooltip-arrow-inline-start', `${diff}%`);\n } else if (correctedPlacement.endsWith('end')) {\n element.style.setProperty('--db-tooltip-arrow-inline-start', `${100 - diff}%`);\n }\n }\n if (childHeight > height && (correctedPlacement.startsWith('left') || correctedPlacement.startsWith('bottom'))) {\n const diff = height / 2 / childHeight * 100;\n if (correctedPlacement.endsWith('start')) {\n element.style.setProperty('--db-tooltip-arrow-block-start', `${diff}%`);\n } else if (correctedPlacement.endsWith('end')) {\n element.style.setProperty('--db-tooltip-arrow-block-start', `${100 - diff}%`);\n }\n }\n\n // Popover position\n\n if (correctedPlacement === 'right' || correctedPlacement === 'left') {\n // center horizontally\n element.style.insetBlockStart = `${top + height / 2}px`;\n } else if (correctedPlacement === 'right-start' || correctedPlacement === 'left-start') {\n const end = top + childHeight;\n element.style.insetBlockStart = `${top}px`;\n element.style.insetBlockEnd = `${end > innerHeight ? innerHeight : end}px`;\n } else if (correctedPlacement === 'right-end' || correctedPlacement === 'left-end') {\n const start = bottom - childHeight;\n element.style.insetBlockStart = `${start < 0 ? 0 : start}px`;\n element.style.insetBlockEnd = `${bottom}px`;\n } else if (correctedPlacement === 'top' || correctedPlacement === 'bottom') {\n // center vertically\n element.style.insetInlineStart = `${left + width / 2}px`;\n } else if (correctedPlacement === 'top-start' || correctedPlacement === 'bottom-start') {\n const end = left + childWidth;\n element.style.insetInlineStart = `${left}px`;\n element.style.insetInlineEnd = `${end > innerWidth ? innerWidth : end}px`;\n } else if (correctedPlacement === 'top-end' || correctedPlacement === 'bottom-end') {\n const start = left - childWidth;\n element.style.insetInlineStart = `${right - childWidth}px`;\n element.style.insetInlineEnd = `${start < 0 ? 0 : start}px`;\n }\n if (correctedPlacement?.startsWith('right')) {\n const end = right + childWidth;\n element.style.insetInlineStart = `calc(${right}px + ${distance})`;\n element.style.insetInlineEnd = `calc(${end > innerWidth ? innerWidth : end}px + ${distance})`;\n } else if (correctedPlacement?.startsWith('left')) {\n const start = left - childWidth;\n element.style.insetInlineStart = `calc(${start < 0 ? 0 : start}px - ${distance})`;\n element.style.insetInlineEnd = `calc(${right}px - ${distance})`;\n } else if (correctedPlacement?.startsWith('top')) {\n const start = top - childHeight;\n element.style.insetBlockStart = `calc(${start < 0 ? 0 : start}px - ${distance})`;\n element.style.insetBlockEnd = `calc(${bottom}px - ${distance})`;\n } else if (correctedPlacement?.startsWith('bottom')) {\n const end = bottom + childHeight;\n element.style.insetBlockStart = `calc(${bottom}px + ${distance})`;\n element.style.insetBlockEnd = `calc(${end > innerHeight ? innerHeight : end}px + ${distance})`;\n }\n element.style.position = 'fixed';\n element.dataset['correctedPlacement'] = correctedPlacement;\n}"]}
|
|
1
|
+
{"version":3,"file":"floating-components.js","sourceRoot":"","sources":["../../src/utils/floating-components.ts"],"names":[],"mappings":"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","sourcesContent":["// TODO: We should reevaluate this as soon as CSS Anchor Positioning is supported in all relevant browsers\nconst isInView = (el: HTMLElement) => {\n const {\n top,\n bottom,\n left,\n right\n } = el.getBoundingClientRect();\n const {\n innerHeight,\n innerWidth\n } = window;\n let outTop = top < 0;\n let outBottom = bottom > innerHeight;\n let outLeft = left < 0;\n let outRight = right > innerWidth;\n\n // We need to check if it was already outside\n const outsideY = el.dataset['outsideVy'];\n const outsideX = el.dataset['outsideVx'];\n const parentRect = el?.parentElement?.getBoundingClientRect();\n if (parentRect) {\n if (outsideY) {\n const position = el.dataset['outsideVy'];\n if (position === 'top') {\n outTop = parentRect.top - (bottom - parentRect.bottom) < 0;\n } else {\n outBottom = parentRect.bottom + (parentRect.top - top) > innerHeight;\n }\n }\n if (outsideX) {\n const position = el.dataset['outsideVx'];\n if (position === 'left') {\n outLeft = parentRect.left - (right - parentRect.right) < 0;\n } else {\n outRight = parentRect.right + (parentRect.left - left) > innerWidth;\n }\n }\n }\n return {\n outTop,\n outBottom,\n outLeft,\n outRight\n };\n};\nexport interface DBDataOutsidePair {\n vx?: 'left' | 'right';\n vy?: 'top' | 'bottom';\n}\nexport const handleDataOutside = (el: HTMLElement): DBDataOutsidePair => {\n const {\n outTop,\n outBottom,\n outLeft,\n outRight\n } = isInView(el);\n let dataOutsidePair: DBDataOutsidePair = {};\n if (outTop || outBottom) {\n dataOutsidePair = {\n vy: outTop ? 'top' : 'bottom'\n };\n el.dataset['outsideVy'] = dataOutsidePair.vy!;\n } else {\n delete el.dataset['outsideVy'];\n }\n if (outLeft || outRight) {\n dataOutsidePair = {\n ...dataOutsidePair,\n vx: outRight ? 'right' : 'left'\n };\n el.dataset['outsideVx'] = dataOutsidePair.vx!;\n } else {\n delete el.dataset['outsideVx'];\n }\n return dataOutsidePair;\n};\nexport const handleFixedDropdown = (element: HTMLElement, parent: HTMLElement, placement: string) => {\n // We skip this if we are in mobile it's already fixed or if we don't have a floating dropdown\n const computedStyle = getComputedStyle(element);\n if (computedStyle.zIndex === '9999' || computedStyle.position !== 'fixed' && computedStyle.position !== 'absolute') {\n return;\n }\n const {\n top,\n bottom,\n childHeight,\n childWidth,\n width,\n right,\n left,\n correctedPlacement\n } = getFloatingProps(element, parent, placement);\n const fullWidth = element.dataset['width'] === 'full';\n if (fullWidth) {\n element.style.inlineSize = `${width}px`;\n }\n if (correctedPlacement === 'top' || correctedPlacement === 'bottom' || correctedPlacement === 'top-start' || correctedPlacement === 'bottom-start') {\n element.style.insetInlineStart = `${left}px`;\n } else if (correctedPlacement === 'top-end' || correctedPlacement === 'bottom-end') {\n element.style.insetInlineStart = `${right - childWidth}px`;\n }\n if (correctedPlacement?.startsWith('top')) {\n element.style.insetBlockStart = `${top - childHeight}px`;\n } else if (correctedPlacement?.startsWith('bottom')) {\n element.style.insetBlockStart = `${bottom}px`;\n }\n element.style.position = 'fixed';\n};\nexport const getFloatingProps = (element: HTMLElement, parent: HTMLElement, placement: string) => {\n if (!element || !parent) {\n return {\n top: 0,\n bottom: 0,\n right: 0,\n height: 0,\n width: 0,\n left: 0,\n childHeight: 0,\n childWidth: 0,\n correctedPlacement: placement,\n innerWidth: window.innerWidth,\n innerHeight: window.innerHeight\n };\n }\n const childRect = element.getBoundingClientRect();\n const {\n top,\n height,\n bottom,\n right,\n left,\n width\n } = parent.getBoundingClientRect();\n const {\n innerHeight,\n innerWidth\n } = window;\n let childHeight = childRect.height;\n let childWidth = childRect.width;\n if (placement === 'bottom' || placement === 'top') {\n childWidth = width > childWidth ? 0 : childWidth / 2;\n }\n if (placement === 'left' || placement === 'right') {\n childHeight = height > childHeight ? 0 : childHeight / 2;\n }\n const outsideBottom = Math.floor(bottom + childHeight) > innerHeight;\n const outsideTop = Math.ceil(top - childHeight) < 0;\n const outsideLeft = Math.ceil(left - childWidth) < 0;\n const outsideRight = Math.floor(right + childWidth) > innerWidth;\n let correctedPlacement = placement;\n if (placement.startsWith('bottom')) {\n if (outsideBottom) {\n if (!outsideTop) {\n correctedPlacement = placement?.replace('bottom', 'top');\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'top';\n } else if (outsideLeft) {\n correctedPlacement = 'top-start';\n } else if (outsideRight) {\n correctedPlacement = 'top-end';\n }\n }\n } else {\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'bottom';\n } else if (outsideLeft) {\n correctedPlacement = 'bottom-start';\n } else if (outsideRight) {\n correctedPlacement = 'bottom-end';\n }\n }\n } else if (placement.startsWith('top')) {\n if (outsideTop) {\n if (!outsideBottom) {\n correctedPlacement = placement?.replace('top', 'bottom');\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'bottom';\n } else if (outsideLeft) {\n correctedPlacement = 'bottom-start';\n } else if (outsideRight) {\n correctedPlacement = 'bottom-end';\n }\n }\n } else {\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'top';\n } else if (outsideLeft) {\n correctedPlacement = 'top-start';\n } else if (outsideRight) {\n correctedPlacement = 'top-end';\n }\n }\n } else if (placement.startsWith('left')) {\n if (outsideLeft) {\n if (outsideRight) {\n correctedPlacement = placement?.replace('left', 'right');\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'right';\n } else if (outsideBottom) {\n correctedPlacement = 'right-end';\n } else if (outsideTop) {\n correctedPlacement = 'right-start';\n }\n }\n } else {\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'left';\n } else if (outsideBottom) {\n correctedPlacement = 'left-end';\n } else if (outsideTop) {\n correctedPlacement = 'left-start';\n }\n }\n } else if (correctedPlacement.startsWith('right')) {\n if (outsideRight) {\n if (!outsideLeft) {\n correctedPlacement = placement?.replace('right', 'left');\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'left';\n } else if (outsideBottom) {\n correctedPlacement = 'left-end';\n } else if (outsideTop) {\n correctedPlacement = 'left-start';\n }\n }\n } else {\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'right';\n } else if (outsideBottom) {\n correctedPlacement = 'right-end';\n } else if (outsideTop) {\n correctedPlacement = 'right-start';\n }\n }\n }\n return {\n top,\n bottom,\n right,\n height,\n width,\n left,\n childHeight: childRect.height,\n childWidth: childRect.width,\n correctedPlacement,\n innerWidth,\n innerHeight,\n outsideYBoth: outsideTop && outsideBottom,\n outsideXBoth: outsideRight && outsideLeft\n };\n};\nexport const handleFixedPopover = (element: HTMLElement, parent: HTMLElement, placement?: string) => {\n const computedStyle = getComputedStyle(element);\n\n // We skip if we don't have a floating popover\n if (computedStyle.position !== 'fixed' && computedStyle.position !== 'absolute') {\n return;\n }\n let distance = computedStyle.getPropertyValue('--db-popover-distance');\n if (!distance.length) {\n distance = '0px';\n }\n const elementPlacement = element?.dataset?.['placement'] ?? placement ?? 'bottom';\n const {\n top,\n height,\n width,\n childHeight,\n childWidth,\n right,\n left,\n bottom,\n correctedPlacement,\n innerWidth,\n innerHeight,\n outsideYBoth\n } = getFloatingProps(element, parent, elementPlacement);\n\n // Tooltip arrow position\n\n if (childWidth > width && (correctedPlacement.startsWith('bottom') || correctedPlacement.startsWith('top'))) {\n const diff = width / 2 / childWidth * 100;\n if (correctedPlacement.endsWith('start')) {\n element.style.setProperty('--db-tooltip-arrow-inline-start', `${diff}%`);\n } else if (correctedPlacement.endsWith('end')) {\n element.style.setProperty('--db-tooltip-arrow-inline-start', `${100 - diff}%`);\n }\n }\n if (childHeight > height && (correctedPlacement.startsWith('left') || correctedPlacement.startsWith('bottom'))) {\n const diff = height / 2 / childHeight * 100;\n if (correctedPlacement.endsWith('start')) {\n element.style.setProperty('--db-tooltip-arrow-block-start', `${diff}%`);\n } else if (correctedPlacement.endsWith('end')) {\n element.style.setProperty('--db-tooltip-arrow-block-start', `${100 - diff}%`);\n }\n }\n\n // Popover position\n\n if (correctedPlacement === 'right' || correctedPlacement === 'left') {\n // center horizontally\n element.style.insetBlockStart = `${top + height / 2}px`;\n } else if (correctedPlacement === 'right-start' || correctedPlacement === 'left-start') {\n const end = top + childHeight;\n element.style.insetBlockStart = `${top}px`;\n element.style.insetBlockEnd = `${end > innerHeight ? innerHeight : end}px`;\n } else if (correctedPlacement === 'right-end' || correctedPlacement === 'left-end') {\n const start = bottom - childHeight;\n element.style.insetBlockStart = `${start < 0 ? 0 : start}px`;\n element.style.insetBlockEnd = `${bottom}px`;\n } else if (correctedPlacement === 'top' || correctedPlacement === 'bottom') {\n // center vertically\n element.style.insetInlineStart = `${left + width / 2}px`;\n } else if (correctedPlacement === 'top-start' || correctedPlacement === 'bottom-start') {\n const end = left + childWidth;\n element.style.insetInlineStart = `${left}px`;\n element.style.insetInlineEnd = `${end > innerWidth ? innerWidth : end}px`;\n } else if (correctedPlacement === 'top-end' || correctedPlacement === 'bottom-end') {\n const start = left - childWidth;\n element.style.insetInlineStart = `${right - childWidth}px`;\n element.style.insetInlineEnd = `${start < 0 ? 0 : start}px`;\n }\n if (correctedPlacement?.startsWith('right')) {\n const end = right + childWidth;\n element.style.insetInlineStart = `calc(${right}px + ${distance})`;\n element.style.insetInlineEnd = `calc(${end > innerWidth ? innerWidth : end}px + ${distance})`;\n } else if (correctedPlacement?.startsWith('left')) {\n const start = left - childWidth;\n element.style.insetInlineStart = `calc(${start < 0 ? 0 : start}px - ${distance})`;\n element.style.insetInlineEnd = `calc(${right}px - ${distance})`;\n } else if (correctedPlacement?.startsWith('top')) {\n const start = top - childHeight;\n element.style.insetBlockStart = `calc(${start < 0 ? 0 : start}px - ${distance})`;\n element.style.insetBlockEnd = `calc(${bottom}px - ${distance})`;\n } else if (correctedPlacement?.startsWith('bottom')) {\n const end = bottom + childHeight;\n element.style.insetBlockStart = `calc(${bottom}px + ${distance})`;\n element.style.insetBlockEnd = `calc(${end > innerHeight ? innerHeight : end}px + ${distance})`;\n }\n\n // In this case we are outside of top and bottom so we need to scroll\n // We use the full height in this case\n if (outsideYBoth) {\n element.style.overflow = 'hidden auto';\n element.style.insetBlock = distance;\n element.style.maxBlockSize = `calc(${innerHeight}px - 2 * ${distance})`;\n }\n element.style.position = 'fixed';\n element.dataset['correctedPlacement'] = correctedPlacement;\n}"]}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { handleDataOutside } from "./floating-components";
|
|
1
|
+
import { handleDataOutside, handleFixedPopover } from "./floating-components";
|
|
2
2
|
export const isEventTargetNavigationItem = (event) => {
|
|
3
|
-
var _a
|
|
3
|
+
var _a;
|
|
4
4
|
const { target } = event;
|
|
5
|
-
return Boolean(
|
|
5
|
+
return Boolean((_a = target === null || target === void 0 ? void 0 : target.parentElement) === null || _a === void 0 ? void 0 : _a.classList.contains('db-navigation-item'));
|
|
6
6
|
};
|
|
7
7
|
export class NavigationItemSafeTriangle {
|
|
8
8
|
constructor(element, subNavigation) {
|
|
9
|
-
var _a;
|
|
9
|
+
var _a, _b;
|
|
10
10
|
this.parentSubNavigation = null;
|
|
11
11
|
this.initialized = false;
|
|
12
12
|
this.mouseX = 0;
|
|
@@ -16,13 +16,12 @@ export class NavigationItemSafeTriangle {
|
|
|
16
16
|
if (!this.element || !this.subNavigation) {
|
|
17
17
|
return;
|
|
18
18
|
}
|
|
19
|
-
this.parentSubNavigation = (_a = this.element) === null || _a === void 0 ? void 0 : _a.closest('.db-
|
|
19
|
+
this.parentSubNavigation = (_b = (_a = this.element) === null || _a === void 0 ? void 0 : _a.closest('.db-navigation-item-group-menu')) !== null && _b !== void 0 ? _b : this.element;
|
|
20
20
|
/*
|
|
21
21
|
* only initiate if:
|
|
22
|
-
* 1. item is not at root navigation level
|
|
23
22
|
* 2. item is not in the mobile navigation / within db-drawer
|
|
24
23
|
*/
|
|
25
|
-
if (
|
|
24
|
+
if (!this.element.closest('.db-drawer')) {
|
|
26
25
|
this.init();
|
|
27
26
|
}
|
|
28
27
|
}
|
|
@@ -88,20 +87,10 @@ export class NavigationItemSafeTriangle {
|
|
|
88
87
|
}
|
|
89
88
|
return false;
|
|
90
89
|
}
|
|
91
|
-
getTriangleCoordinates(
|
|
90
|
+
getTriangleCoordinates() {
|
|
92
91
|
if (!this.triangleData) {
|
|
93
92
|
return;
|
|
94
93
|
}
|
|
95
|
-
if (variant === 'fill-gap') {
|
|
96
|
-
const itemHeight = `${this.triangleData.itemRect.height + 2 * this.triangleData.padding}px`;
|
|
97
|
-
const xStart = `${this.triangleData.parentElementWidth - this.triangleData.padding}px`;
|
|
98
|
-
return {
|
|
99
|
-
lb: `${xStart} ${itemHeight}`,
|
|
100
|
-
lt: `${xStart} 0`,
|
|
101
|
-
rt: '100% 0',
|
|
102
|
-
rb: `100% ${itemHeight}`
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
94
|
const tipX = this.getTriangleTipX();
|
|
106
95
|
const tipY = this.getTriangleTipY();
|
|
107
96
|
const lb = `${tipX}px ${tipY}px`;
|
|
@@ -120,7 +109,7 @@ export class NavigationItemSafeTriangle {
|
|
|
120
109
|
this.mouseX = event.clientX - this.triangleData.itemRect.left;
|
|
121
110
|
this.mouseY = event.clientY - this.triangleData.itemRect.top;
|
|
122
111
|
const isOverSubNavigation = this.hasMouseEnteredSubNavigation();
|
|
123
|
-
const coordinates = this.getTriangleCoordinates(
|
|
112
|
+
const coordinates = this.getTriangleCoordinates();
|
|
124
113
|
if (!coordinates) {
|
|
125
114
|
return;
|
|
126
115
|
}
|
|
@@ -130,8 +119,31 @@ export class NavigationItemSafeTriangle {
|
|
|
130
119
|
}
|
|
131
120
|
}
|
|
132
121
|
}
|
|
133
|
-
export
|
|
134
|
-
|
|
135
|
-
|
|
122
|
+
export const handleSubNavigationPosition = (element, level = 0) => {
|
|
123
|
+
for (const navItem of Array.from(element.querySelectorAll('.db-navigation-item-group'))) {
|
|
124
|
+
const subNavigation = navItem.querySelector('.db-navigation-item-group-menu');
|
|
125
|
+
const button = navItem.querySelector('.db-navigation-item-group-expand-button');
|
|
126
|
+
if (subNavigation && button) {
|
|
127
|
+
/*
|
|
128
|
+
* This is set via css inside:
|
|
129
|
+
* `packages/components/src/components/navigation-item-group/navigation-item-group-menu-popover.scss`.
|
|
130
|
+
* We don't need to calculate the position of the menu as a popover.
|
|
131
|
+
*/
|
|
132
|
+
const isMobile = getComputedStyle(subNavigation).getPropertyValue('--db-navigation-item-group-menu-mobile');
|
|
133
|
+
if (isMobile)
|
|
134
|
+
return;
|
|
135
|
+
if (level > 0 || subNavigation.dataset['open'] === 'horizontal') {
|
|
136
|
+
// Sub-Navigation should be opened horizontal
|
|
137
|
+
handleFixedPopover(subNavigation, button, 'right-start');
|
|
138
|
+
subNavigation.dataset['open'] = 'horizontal';
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
// Sub-Navigation should be opened vertical
|
|
142
|
+
handleFixedPopover(subNavigation, button, 'bottom-start');
|
|
143
|
+
subNavigation.dataset['open'] = 'vertical';
|
|
144
|
+
}
|
|
145
|
+
handleSubNavigationPosition(subNavigation, level + 1);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
136
148
|
};
|
|
137
149
|
//# sourceMappingURL=navigation.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"navigation.js","sourceRoot":"","sources":["../../src/utils/navigation.ts"],"names":[],"mappings":"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","sourcesContent":["import { handleDataOutside } from './floating-components';\nexport type TriangleData = {\n itemRect: DOMRect;\n parentElementWidth: number;\n subNavigationHeight: number;\n padding: number;\n outsideVX: 'left' | 'right' | undefined;\n outsideVY: 'top' | 'bottom' | undefined;\n};\nexport const isEventTargetNavigationItem = (event: unknown): boolean => {\n const {\n target\n } = event as {\n target: HTMLElement;\n };\n return Boolean(!target?.classList?.contains('db-navigation-item-expand-button') && target?.parentElement?.classList.contains('db-navigation-item'));\n};\nexport class NavigationItemSafeTriangle {\n private readonly element: HTMLElement | null;\n private readonly subNavigation: HTMLElement | null;\n private readonly parentSubNavigation: HTMLElement | null = null;\n private triangleData?: TriangleData;\n private initialized: boolean = false;\n private mouseX: number = 0;\n private mouseY: number = 0;\n constructor(element: HTMLElement | null, subNavigation: HTMLElement | null) {\n this.element = element;\n this.subNavigation = subNavigation;\n if (!this.element || !this.subNavigation) {\n return;\n }\n this.parentSubNavigation = this.element?.closest('.db-sub-navigation');\n\n /*\n * only initiate if:\n * 1. item is not at root navigation level\n * 2. item is not in the mobile navigation / within db-drawer\n */\n if (this.parentSubNavigation && !this.element.closest('.db-drawer')) {\n this.init();\n }\n }\n private init() {\n const parentElementWidth = this.parentSubNavigation?.getBoundingClientRect().width ?? 0;\n\n // the triangle has the width of the sub-navigation, current nav-item can be wider.\n // so the width of the triangle must be adapted to a possibly wider nav-item.\n this.element?.style.setProperty('--db-navigation-item-inline-size', `${parentElementWidth}px`);\n this.initialized = true;\n }\n public enableFollow() {\n if (!this.initialized || this.triangleData || !this.element || !this.subNavigation) {\n return;\n }\n const dataOutsidePair = handleDataOutside(this.subNavigation);\n const itemRect = this.element.getBoundingClientRect();\n const parentElementWidth = this.parentSubNavigation?.getBoundingClientRect().width ?? 0;\n this.triangleData = {\n itemRect,\n parentElementWidth,\n subNavigationHeight: this.subNavigation.getBoundingClientRect().height,\n padding: (parentElementWidth - itemRect.width) / 2,\n outsideVX: dataOutsidePair.vx,\n outsideVY: dataOutsidePair.vy\n };\n }\n public disableFollow() {\n this.triangleData = undefined;\n }\n private getTriangleTipX(): number {\n if (!this.triangleData) return 0;\n if (this.triangleData.outsideVX === 'right') {\n // vertical flipped triangle needs an inverted x pos\n return this.triangleData.itemRect.width - this.mouseX;\n }\n\n // triangle stops shrinking from 75% x pos\n return Math.min(this.mouseX, this.triangleData.itemRect.width * 0.75);\n }\n private getTriangleTipY(): number {\n if (!this.triangleData) return 0;\n\n // padding must be added to the y pos of the tip so that the y pos matches the cursor\n const mouseYLimited = Math.max(Math.min(this.mouseY, this.triangleData.itemRect.height), 0) + this.triangleData.padding;\n if (this.triangleData.outsideVY === 'bottom') {\n // add offset to tip y pos to match corrected sub-navigation y pos\n return mouseYLimited + (this.triangleData.subNavigationHeight - this.triangleData.padding * 2 - this.triangleData.itemRect.height);\n }\n return mouseYLimited;\n }\n private hasMouseEnteredSubNavigation(): boolean {\n if (!this.triangleData) {\n return false;\n }\n const isSubNavigationOnLeftSide = this.triangleData.outsideVX === 'right';\n if (isSubNavigationOnLeftSide && this.mouseX < -1 * this.triangleData.padding) {\n return true;\n }\n if (!isSubNavigationOnLeftSide && this.mouseX > this.triangleData.parentElementWidth - this.triangleData.padding) {\n return true;\n }\n return false;\n }\n private getTriangleCoordinates(variant: 'safe-triangle' | 'fill-gap'): undefined | {\n lb: string;\n lt: string;\n rt: string;\n rb: string;\n } {\n if (!this.triangleData) {\n return;\n }\n if (variant === 'fill-gap') {\n const itemHeight = `${this.triangleData.itemRect.height + 2 * this.triangleData.padding}px`;\n const xStart = `${this.triangleData.parentElementWidth - this.triangleData.padding}px`;\n return {\n lb: `${xStart} ${itemHeight}`,\n lt: `${xStart} 0`,\n rt: '100% 0',\n rb: `100% ${itemHeight}`\n };\n }\n const tipX = this.getTriangleTipX();\n const tipY = this.getTriangleTipY();\n const lb = `${tipX}px ${tipY}px`;\n const lt = `${tipX}px ${tipY}px`;\n return {\n lb,\n lt,\n rt: '100% 0',\n rb: '100% 100%'\n };\n }\n public followByMouseEvent(event: MouseEvent) {\n if (!this.initialized || !this.triangleData || !this.element || !this.subNavigation) {\n return;\n }\n this.mouseX = event.clientX - this.triangleData.itemRect.left;\n this.mouseY = event.clientY - this.triangleData.itemRect.top;\n const isOverSubNavigation = this.hasMouseEnteredSubNavigation();\n const coordinates = this.getTriangleCoordinates(isOverSubNavigation ? 'fill-gap' : 'safe-triangle');\n if (!coordinates) {\n return;\n }\n this.element.style.setProperty('--db-navigation-item-clip-path', `polygon(${coordinates.lb}, ${coordinates.lt}, ${coordinates.rt}, ${coordinates.rb})`);\n if (isOverSubNavigation) {\n this.triangleData = undefined;\n }\n }\n}\nexport default {\n isEventTargetNavigationItem,\n NavigationItemSafeTriangle\n}"]}
|
|
1
|
+
{"version":3,"file":"navigation.js","sourceRoot":"","sources":["../../src/utils/navigation.ts"],"names":[],"mappings":"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","sourcesContent":["import { handleDataOutside, handleFixedPopover } from './floating-components';\nexport type TriangleData = {\n itemRect: DOMRect;\n parentElementWidth: number;\n subNavigationHeight: number;\n padding: number;\n outsideVX: 'left' | 'right' | undefined;\n outsideVY: 'top' | 'bottom' | undefined;\n};\nexport const isEventTargetNavigationItem = (event: unknown): boolean => {\n const {\n target\n } = event as {\n target: HTMLElement;\n };\n return Boolean(target?.parentElement?.classList.contains('db-navigation-item'));\n};\nexport class NavigationItemSafeTriangle {\n private readonly element: HTMLElement | null;\n private readonly subNavigation: HTMLElement | null;\n private readonly parentSubNavigation: HTMLElement | null = null;\n private triangleData?: TriangleData;\n private initialized: boolean = false;\n private mouseX: number = 0;\n private mouseY: number = 0;\n constructor(element: HTMLElement | null, subNavigation: HTMLElement | null) {\n this.element = element;\n this.subNavigation = subNavigation;\n if (!this.element || !this.subNavigation) {\n return;\n }\n this.parentSubNavigation = this.element?.closest('.db-navigation-item-group-menu') ?? this.element;\n\n /*\n * only initiate if:\n * 2. item is not in the mobile navigation / within db-drawer\n */\n if (!this.element.closest('.db-drawer')) {\n this.init();\n }\n }\n private init() {\n const parentElementWidth = this.parentSubNavigation?.getBoundingClientRect().width ?? 0;\n\n // the triangle has the width of the sub-navigation, current nav-item can be wider.\n // so the width of the triangle must be adapted to a possibly wider nav-item.\n this.element?.style.setProperty('--db-navigation-item-inline-size', `${parentElementWidth}px`);\n this.initialized = true;\n }\n public enableFollow() {\n if (!this.initialized || this.triangleData || !this.element || !this.subNavigation) {\n return;\n }\n const dataOutsidePair = handleDataOutside(this.subNavigation);\n const itemRect = this.element.getBoundingClientRect();\n const parentElementWidth = this.parentSubNavigation?.getBoundingClientRect().width ?? 0;\n this.triangleData = {\n itemRect,\n parentElementWidth,\n subNavigationHeight: this.subNavigation.getBoundingClientRect().height,\n padding: (parentElementWidth - itemRect.width) / 2,\n outsideVX: dataOutsidePair.vx,\n outsideVY: dataOutsidePair.vy\n };\n }\n public disableFollow() {\n this.triangleData = undefined;\n }\n private getTriangleTipX(): number {\n if (!this.triangleData) return 0;\n if (this.triangleData.outsideVX === 'right') {\n // vertical flipped triangle needs an inverted x pos\n return this.triangleData.itemRect.width - this.mouseX;\n }\n\n // triangle stops shrinking from 75% x pos\n return Math.min(this.mouseX, this.triangleData.itemRect.width * 0.75);\n }\n private getTriangleTipY(): number {\n if (!this.triangleData) return 0;\n\n // padding must be added to the y pos of the tip so that the y pos matches the cursor\n const mouseYLimited = Math.max(Math.min(this.mouseY, this.triangleData.itemRect.height), 0) + this.triangleData.padding;\n if (this.triangleData.outsideVY === 'bottom') {\n // add offset to tip y pos to match corrected sub-navigation y pos\n return mouseYLimited + (this.triangleData.subNavigationHeight - this.triangleData.padding * 2 - this.triangleData.itemRect.height);\n }\n return mouseYLimited;\n }\n private hasMouseEnteredSubNavigation(): boolean {\n if (!this.triangleData) {\n return false;\n }\n const isSubNavigationOnLeftSide = this.triangleData.outsideVX === 'right';\n if (isSubNavigationOnLeftSide && this.mouseX < -1 * this.triangleData.padding) {\n return true;\n }\n if (!isSubNavigationOnLeftSide && this.mouseX > this.triangleData.parentElementWidth - this.triangleData.padding) {\n return true;\n }\n return false;\n }\n private getTriangleCoordinates(): undefined | {\n lb: string;\n lt: string;\n rt: string;\n rb: string;\n } {\n if (!this.triangleData) {\n return;\n }\n const tipX = this.getTriangleTipX();\n const tipY = this.getTriangleTipY();\n const lb = `${tipX}px ${tipY}px`;\n const lt = `${tipX}px ${tipY}px`;\n return {\n lb,\n lt,\n rt: '100% 0',\n rb: '100% 100%'\n };\n }\n public followByMouseEvent(event: any) {\n if (!this.initialized || !this.triangleData || !this.element || !this.subNavigation) {\n return;\n }\n this.mouseX = event.clientX - this.triangleData.itemRect.left;\n this.mouseY = event.clientY - this.triangleData.itemRect.top;\n const isOverSubNavigation = this.hasMouseEnteredSubNavigation();\n const coordinates = this.getTriangleCoordinates();\n if (!coordinates) {\n return;\n }\n this.element.style.setProperty('--db-navigation-item-clip-path', `polygon(${coordinates.lb}, ${coordinates.lt}, ${coordinates.rt}, ${coordinates.rb})`);\n if (isOverSubNavigation) {\n this.triangleData = undefined;\n }\n }\n}\nexport const handleSubNavigationPosition = (element: HTMLElement, level: number = 0) => {\n for (const navItem of Array.from(element.querySelectorAll('.db-navigation-item-group'))) {\n const subNavigation: HTMLElement | null = navItem.querySelector('.db-navigation-item-group-menu');\n const button: HTMLElement | null = navItem.querySelector('.db-navigation-item-group-expand-button');\n if (subNavigation && button) {\n /*\n * This is set via css inside:\n * `packages/components/src/components/navigation-item-group/navigation-item-group-menu-popover.scss`.\n * We don't need to calculate the position of the menu as a popover.\n */\n const isMobile = getComputedStyle(subNavigation).getPropertyValue('--db-navigation-item-group-menu-mobile');\n if (isMobile) return;\n if (level > 0 || subNavigation.dataset['open'] === 'horizontal') {\n // Sub-Navigation should be opened horizontal\n handleFixedPopover(subNavigation, button, 'right-start');\n subNavigation.dataset['open'] = 'horizontal';\n } else {\n // Sub-Navigation should be opened vertical\n handleFixedPopover(subNavigation, button, 'bottom-start');\n subNavigation.dataset['open'] = 'vertical';\n }\n handleSubNavigationPosition(subNavigation, level + 1);\n }\n }\n}"]}
|