@ariakit/react-components 0.1.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/CHANGELOG.md +20 -0
- package/dist/button/button.d.ts +2 -0
- package/dist/button/button.js +53 -0
- package/dist/button/button.js.map +1 -0
- package/dist/button-Cp853csH.d.ts +34 -0
- package/dist/button-Cp853csH.d.ts.map +1 -0
- package/dist/checkbox/checkbox-check.d.ts +56 -0
- package/dist/checkbox/checkbox-check.d.ts.map +1 -0
- package/dist/checkbox/checkbox-check.js +77 -0
- package/dist/checkbox/checkbox-check.js.map +1 -0
- package/dist/checkbox/checkbox-checked-context.d.ts +5 -0
- package/dist/checkbox/checkbox-checked-context.d.ts.map +1 -0
- package/dist/checkbox/checkbox-checked-context.js +8 -0
- package/dist/checkbox/checkbox-checked-context.js.map +1 -0
- package/dist/checkbox/checkbox-context.d.ts +24 -0
- package/dist/checkbox/checkbox-context.d.ts.map +1 -0
- package/dist/checkbox/checkbox-context.js +26 -0
- package/dist/checkbox/checkbox-context.js.map +1 -0
- package/dist/checkbox/checkbox-provider.d.ts +35 -0
- package/dist/checkbox/checkbox-provider.d.ts.map +1 -0
- package/dist/checkbox/checkbox-provider.js +15 -0
- package/dist/checkbox/checkbox-provider.js.map +1 -0
- package/dist/checkbox/checkbox-store.d.ts +2 -0
- package/dist/checkbox/checkbox-store.js +18 -0
- package/dist/checkbox/checkbox-store.js.map +1 -0
- package/dist/checkbox/checkbox.d.ts +91 -0
- package/dist/checkbox/checkbox.d.ts.map +1 -0
- package/dist/checkbox/checkbox.js +148 -0
- package/dist/checkbox/checkbox.js.map +1 -0
- package/dist/checkbox-store-CYZPR4N4.d.ts +38 -0
- package/dist/checkbox-store-CYZPR4N4.d.ts.map +1 -0
- package/dist/collection/collection-context.d.ts +24 -0
- package/dist/collection/collection-context.d.ts.map +1 -0
- package/dist/collection/collection-context.js +26 -0
- package/dist/collection/collection-context.js.map +1 -0
- package/dist/collection/collection-item-offscreen.d.ts +2 -0
- package/dist/collection/collection-item-offscreen.js +88 -0
- package/dist/collection/collection-item-offscreen.js.map +1 -0
- package/dist/collection/collection-item.d.ts +2 -0
- package/dist/collection/collection-item.js +69 -0
- package/dist/collection/collection-item.js.map +1 -0
- package/dist/collection/collection-provider.d.ts +26 -0
- package/dist/collection/collection-provider.d.ts.map +1 -0
- package/dist/collection/collection-provider.js +15 -0
- package/dist/collection/collection-provider.js.map +1 -0
- package/dist/collection/collection-renderer.d.ts +2 -0
- package/dist/collection/collection-renderer.js +580 -0
- package/dist/collection/collection-renderer.js.map +1 -0
- package/dist/collection/collection-store.d.ts +2 -0
- package/dist/collection/collection-store.js +18 -0
- package/dist/collection/collection-store.js.map +1 -0
- package/dist/collection/collection.d.ts +55 -0
- package/dist/collection/collection.d.ts.map +1 -0
- package/dist/collection/collection.js +55 -0
- package/dist/collection/collection.js.map +1 -0
- package/dist/collection-item-C-g2BwVF.d.ts +84 -0
- package/dist/collection-item-C-g2BwVF.d.ts.map +1 -0
- package/dist/collection-item-offscreen-DyXa-sqj.d.ts +30 -0
- package/dist/collection-item-offscreen-DyXa-sqj.d.ts.map +1 -0
- package/dist/collection-renderer-DsPD9ksD.d.ts +469 -0
- package/dist/collection-renderer-DsPD9ksD.d.ts.map +1 -0
- package/dist/collection-store-CbwzYsWf.d.ts +42 -0
- package/dist/collection-store-CbwzYsWf.d.ts.map +1 -0
- package/dist/combobox/combobox-cancel.d.ts +62 -0
- package/dist/combobox/combobox-cancel.d.ts.map +1 -0
- package/dist/combobox/combobox-cancel.js +98 -0
- package/dist/combobox/combobox-cancel.js.map +1 -0
- package/dist/combobox/combobox-context.d.ts +27 -0
- package/dist/combobox/combobox-context.d.ts.map +1 -0
- package/dist/combobox/combobox-context.js +32 -0
- package/dist/combobox/combobox-context.js.map +1 -0
- package/dist/combobox/combobox-disclosure.d.ts +63 -0
- package/dist/combobox/combobox-disclosure.d.ts.map +1 -0
- package/dist/combobox/combobox-disclosure.js +108 -0
- package/dist/combobox/combobox-disclosure.js.map +1 -0
- package/dist/combobox/combobox-group-label.d.ts +56 -0
- package/dist/combobox/combobox-group-label.d.ts.map +1 -0
- package/dist/combobox/combobox-group-label.js +47 -0
- package/dist/combobox/combobox-group-label.js.map +1 -0
- package/dist/combobox/combobox-group.d.ts +63 -0
- package/dist/combobox/combobox-group.d.ts.map +1 -0
- package/dist/combobox/combobox-group.js +67 -0
- package/dist/combobox/combobox-group.js.map +1 -0
- package/dist/combobox/combobox-item-check.d.ts +61 -0
- package/dist/combobox/combobox-item-check.d.ts.map +1 -0
- package/dist/combobox/combobox-item-check.js +62 -0
- package/dist/combobox/combobox-item-check.js.map +1 -0
- package/dist/combobox/combobox-item-offscreen.d.ts +34 -0
- package/dist/combobox/combobox-item-offscreen.d.ts.map +1 -0
- package/dist/combobox/combobox-item-offscreen.js +53 -0
- package/dist/combobox/combobox-item-offscreen.js.map +1 -0
- package/dist/combobox/combobox-item-value.d.ts +103 -0
- package/dist/combobox/combobox-item-value.d.ts.map +1 -0
- package/dist/combobox/combobox-item-value.js +143 -0
- package/dist/combobox/combobox-item-value.js.map +1 -0
- package/dist/combobox/combobox-item.d.ts +146 -0
- package/dist/combobox/combobox-item.d.ts.map +1 -0
- package/dist/combobox/combobox-item.js +157 -0
- package/dist/combobox/combobox-item.js.map +1 -0
- package/dist/combobox/combobox-label.d.ts +50 -0
- package/dist/combobox/combobox-label.d.ts.map +1 -0
- package/dist/combobox/combobox-label.js +51 -0
- package/dist/combobox/combobox-label.js.map +1 -0
- package/dist/combobox/combobox-list.d.ts +55 -0
- package/dist/combobox/combobox-list.d.ts.map +1 -0
- package/dist/combobox/combobox-list.js +106 -0
- package/dist/combobox/combobox-list.js.map +1 -0
- package/dist/combobox/combobox-popover.d.ts +46 -0
- package/dist/combobox/combobox-popover.d.ts.map +1 -0
- package/dist/combobox/combobox-popover.js +115 -0
- package/dist/combobox/combobox-popover.js.map +1 -0
- package/dist/combobox/combobox-provider.d.ts +30 -0
- package/dist/combobox/combobox-provider.d.ts.map +1 -0
- package/dist/combobox/combobox-provider.js +15 -0
- package/dist/combobox/combobox-provider.js.map +1 -0
- package/dist/combobox/combobox-row.d.ts +66 -0
- package/dist/combobox/combobox-row.d.ts.map +1 -0
- package/dist/combobox/combobox-row.js +70 -0
- package/dist/combobox/combobox-row.js.map +1 -0
- package/dist/combobox/combobox-separator.d.ts +61 -0
- package/dist/combobox/combobox-separator.d.ts.map +1 -0
- package/dist/combobox/combobox-separator.js +60 -0
- package/dist/combobox/combobox-separator.js.map +1 -0
- package/dist/combobox/combobox-store.d.ts +2 -0
- package/dist/combobox/combobox-store.js +33 -0
- package/dist/combobox/combobox-store.js.map +1 -0
- package/dist/combobox/combobox-value.d.ts +49 -0
- package/dist/combobox/combobox-value.d.ts.map +1 -0
- package/dist/combobox/combobox-value.js +40 -0
- package/dist/combobox/combobox-value.js.map +1 -0
- package/dist/combobox/combobox.d.ts +268 -0
- package/dist/combobox/combobox.d.ts.map +1 -0
- package/dist/combobox/combobox.js +399 -0
- package/dist/combobox/combobox.js.map +1 -0
- package/dist/combobox-store-DEVQ45mZ.d.ts +80 -0
- package/dist/combobox-store-DEVQ45mZ.d.ts.map +1 -0
- package/dist/command/command.d.ts +2 -0
- package/dist/command/command.js +130 -0
- package/dist/command/command.js.map +1 -0
- package/dist/command-DckndCUK.d.ts +59 -0
- package/dist/command-DckndCUK.d.ts.map +1 -0
- package/dist/composite/composite-container.d.ts +59 -0
- package/dist/composite/composite-container.d.ts.map +1 -0
- package/dist/composite/composite-container.js +164 -0
- package/dist/composite/composite-container.js.map +1 -0
- package/dist/composite/composite-context.d.ts +34 -0
- package/dist/composite/composite-context.d.ts.map +1 -0
- package/dist/composite/composite-context.js +30 -0
- package/dist/composite/composite-context.js.map +1 -0
- package/dist/composite/composite-group-label.d.ts +55 -0
- package/dist/composite/composite-group-label.d.ts.map +1 -0
- package/dist/composite/composite-group-label.js +46 -0
- package/dist/composite/composite-group-label.js.map +1 -0
- package/dist/composite/composite-group.d.ts +60 -0
- package/dist/composite/composite-group.d.ts.map +1 -0
- package/dist/composite/composite-group.js +51 -0
- package/dist/composite/composite-group.js.map +1 -0
- package/dist/composite/composite-hover.d.ts +2 -0
- package/dist/composite/composite-hover.js +114 -0
- package/dist/composite/composite-hover.js.map +1 -0
- package/dist/composite/composite-input.d.ts +55 -0
- package/dist/composite/composite-input.d.ts.map +1 -0
- package/dist/composite/composite-input.js +91 -0
- package/dist/composite/composite-input.js.map +1 -0
- package/dist/composite/composite-item-offscreen.d.ts +39 -0
- package/dist/composite/composite-item-offscreen.d.ts.map +1 -0
- package/dist/composite/composite-item-offscreen.js +72 -0
- package/dist/composite/composite-item-offscreen.js.map +1 -0
- package/dist/composite/composite-item.d.ts +2 -0
- package/dist/composite/composite-item.js +290 -0
- package/dist/composite/composite-item.js.map +1 -0
- package/dist/composite/composite-overflow-disclosure.d.ts +53 -0
- package/dist/composite/composite-overflow-disclosure.d.ts.map +1 -0
- package/dist/composite/composite-overflow-disclosure.js +84 -0
- package/dist/composite/composite-overflow-disclosure.js.map +1 -0
- package/dist/composite/composite-overflow-store.d.ts +38 -0
- package/dist/composite/composite-overflow-store.d.ts.map +1 -0
- package/dist/composite/composite-overflow-store.js +36 -0
- package/dist/composite/composite-overflow-store.js.map +1 -0
- package/dist/composite/composite-overflow.d.ts +54 -0
- package/dist/composite/composite-overflow.d.ts.map +1 -0
- package/dist/composite/composite-overflow.js +82 -0
- package/dist/composite/composite-overflow.js.map +1 -0
- package/dist/composite/composite-provider.d.ts +28 -0
- package/dist/composite/composite-provider.d.ts.map +1 -0
- package/dist/composite/composite-provider.js +15 -0
- package/dist/composite/composite-provider.js.map +1 -0
- package/dist/composite/composite-renderer.d.ts +329 -0
- package/dist/composite/composite-renderer.d.ts.map +1 -0
- package/dist/composite/composite-renderer.js +121 -0
- package/dist/composite/composite-renderer.js.map +1 -0
- package/dist/composite/composite-row.d.ts +67 -0
- package/dist/composite/composite-row.d.ts.map +1 -0
- package/dist/composite/composite-row.js +86 -0
- package/dist/composite/composite-row.js.map +1 -0
- package/dist/composite/composite-separator.d.ts +61 -0
- package/dist/composite/composite-separator.d.ts.map +1 -0
- package/dist/composite/composite-separator.js +55 -0
- package/dist/composite/composite-separator.js.map +1 -0
- package/dist/composite/composite-store.d.ts +2 -0
- package/dist/composite/composite-store.js +33 -0
- package/dist/composite/composite-store.js.map +1 -0
- package/dist/composite/composite-typeahead.d.ts +2 -0
- package/dist/composite/composite-typeahead.js +126 -0
- package/dist/composite/composite-typeahead.js.map +1 -0
- package/dist/composite/composite.d.ts +2 -0
- package/dist/composite/composite.js +273 -0
- package/dist/composite/composite.js.map +1 -0
- package/dist/composite/utils.d.ts +52 -0
- package/dist/composite/utils.d.ts.map +1 -0
- package/dist/composite/utils.js +93 -0
- package/dist/composite/utils.js.map +1 -0
- package/dist/composite-DLvyFHMq.d.ts +124 -0
- package/dist/composite-DLvyFHMq.d.ts.map +1 -0
- package/dist/composite-hover-C7ul163w.d.ts +103 -0
- package/dist/composite-hover-C7ul163w.d.ts.map +1 -0
- package/dist/composite-item-B4WTelVz.d.ts +141 -0
- package/dist/composite-item-B4WTelVz.d.ts.map +1 -0
- package/dist/composite-store-DyJc-XRA.d.ts +43 -0
- package/dist/composite-store-DyJc-XRA.d.ts.map +1 -0
- package/dist/composite-typeahead-DDhpyKqm.d.ts +63 -0
- package/dist/composite-typeahead-DDhpyKqm.d.ts.map +1 -0
- package/dist/dialog/dialog-backdrop.d.ts +16 -0
- package/dist/dialog/dialog-backdrop.d.ts.map +1 -0
- package/dist/dialog/dialog-backdrop.js +58 -0
- package/dist/dialog/dialog-backdrop.js.map +1 -0
- package/dist/dialog/dialog-context.d.ts +27 -0
- package/dist/dialog/dialog-context.d.ts.map +1 -0
- package/dist/dialog/dialog-context.js +30 -0
- package/dist/dialog/dialog-context.js.map +1 -0
- package/dist/dialog/dialog-description.d.ts +2 -0
- package/dist/dialog/dialog-description.js +53 -0
- package/dist/dialog/dialog-description.js.map +1 -0
- package/dist/dialog/dialog-disclosure.d.ts +2 -0
- package/dist/dialog/dialog-disclosure.js +52 -0
- package/dist/dialog/dialog-disclosure.js.map +1 -0
- package/dist/dialog/dialog-dismiss.d.ts +2 -0
- package/dist/dialog/dialog-dismiss.js +80 -0
- package/dist/dialog/dialog-dismiss.js.map +1 -0
- package/dist/dialog/dialog-heading.d.ts +2 -0
- package/dist/dialog/dialog-heading.js +54 -0
- package/dist/dialog/dialog-heading.js.map +1 -0
- package/dist/dialog/dialog-provider.d.ts +22 -0
- package/dist/dialog/dialog-provider.d.ts.map +1 -0
- package/dist/dialog/dialog-provider.js +26 -0
- package/dist/dialog/dialog-provider.js.map +1 -0
- package/dist/dialog/dialog-store.d.ts +2 -0
- package/dist/dialog/dialog-store.js +28 -0
- package/dist/dialog/dialog-store.js.map +1 -0
- package/dist/dialog/dialog.d.ts +2 -0
- package/dist/dialog/dialog.js +429 -0
- package/dist/dialog/dialog.js.map +1 -0
- package/dist/dialog/utils/disable-accessibility-tree-outside.d.ts +7 -0
- package/dist/dialog/utils/disable-accessibility-tree-outside.d.ts.map +1 -0
- package/dist/dialog/utils/disable-accessibility-tree-outside.js +24 -0
- package/dist/dialog/utils/disable-accessibility-tree-outside.js.map +1 -0
- package/dist/dialog/utils/disable-tree.d.ts +9 -0
- package/dist/dialog/utils/disable-tree.d.ts.map +1 -0
- package/dist/dialog/utils/disable-tree.js +48 -0
- package/dist/dialog/utils/disable-tree.js.map +1 -0
- package/dist/dialog/utils/is-backdrop.d.ts +5 -0
- package/dist/dialog/utils/is-backdrop.d.ts.map +1 -0
- package/dist/dialog/utils/is-backdrop.js +15 -0
- package/dist/dialog/utils/is-backdrop.js.map +1 -0
- package/dist/dialog/utils/is-focus-trap.d.ts +5 -0
- package/dist/dialog/utils/is-focus-trap.d.ts.map +1 -0
- package/dist/dialog/utils/is-focus-trap.js +14 -0
- package/dist/dialog/utils/is-focus-trap.js.map +1 -0
- package/dist/dialog/utils/mark-tree-outside.d.ts +9 -0
- package/dist/dialog/utils/mark-tree-outside.d.ts.map +1 -0
- package/dist/dialog/utils/mark-tree-outside.js +44 -0
- package/dist/dialog/utils/mark-tree-outside.js.map +1 -0
- package/dist/dialog/utils/orchestrate.d.ts +9 -0
- package/dist/dialog/utils/orchestrate.d.ts.map +1 -0
- package/dist/dialog/utils/orchestrate.js +77 -0
- package/dist/dialog/utils/orchestrate.js.map +1 -0
- package/dist/dialog/utils/prepend-hidden-dismiss.d.ts +5 -0
- package/dist/dialog/utils/prepend-hidden-dismiss.d.ts.map +1 -0
- package/dist/dialog/utils/prepend-hidden-dismiss.js +31 -0
- package/dist/dialog/utils/prepend-hidden-dismiss.js.map +1 -0
- package/dist/dialog/utils/supports-inert.d.ts +5 -0
- package/dist/dialog/utils/supports-inert.d.ts.map +1 -0
- package/dist/dialog/utils/supports-inert.js +9 -0
- package/dist/dialog/utils/supports-inert.js.map +1 -0
- package/dist/dialog/utils/use-hide-on-interact-outside.d.ts +9 -0
- package/dist/dialog/utils/use-hide-on-interact-outside.d.ts.map +1 -0
- package/dist/dialog/utils/use-hide-on-interact-outside.js +123 -0
- package/dist/dialog/utils/use-hide-on-interact-outside.js.map +1 -0
- package/dist/dialog/utils/use-nested-dialogs.d.ts +11 -0
- package/dist/dialog/utils/use-nested-dialogs.d.ts.map +1 -0
- package/dist/dialog/utils/use-nested-dialogs.js +40 -0
- package/dist/dialog/utils/use-nested-dialogs.js.map +1 -0
- package/dist/dialog/utils/use-prevent-body-scroll.d.ts +5 -0
- package/dist/dialog/utils/use-prevent-body-scroll.d.ts.map +1 -0
- package/dist/dialog/utils/use-prevent-body-scroll.js +60 -0
- package/dist/dialog/utils/use-prevent-body-scroll.js.map +1 -0
- package/dist/dialog/utils/use-previous-mouse-down-ref.d.ts +5 -0
- package/dist/dialog/utils/use-previous-mouse-down-ref.d.ts.map +1 -0
- package/dist/dialog/utils/use-previous-mouse-down-ref.js +22 -0
- package/dist/dialog/utils/use-previous-mouse-down-ref.js.map +1 -0
- package/dist/dialog/utils/use-root-dialog.d.ts +16 -0
- package/dist/dialog/utils/use-root-dialog.d.ts.map +1 -0
- package/dist/dialog/utils/use-root-dialog.js +47 -0
- package/dist/dialog/utils/use-root-dialog.js.map +1 -0
- package/dist/dialog/utils/walk-tree-outside.d.ts +8 -0
- package/dist/dialog/utils/walk-tree-outside.d.ts.map +1 -0
- package/dist/dialog/utils/walk-tree-outside.js +58 -0
- package/dist/dialog/utils/walk-tree-outside.js.map +1 -0
- package/dist/dialog-C__C-zX2.d.ts +267 -0
- package/dist/dialog-C__C-zX2.d.ts.map +1 -0
- package/dist/dialog-description-BCZJ1Kyd.d.ts +48 -0
- package/dist/dialog-description-BCZJ1Kyd.d.ts.map +1 -0
- package/dist/dialog-disclosure-DLD10zlb.d.ts +47 -0
- package/dist/dialog-disclosure-DLD10zlb.d.ts.map +1 -0
- package/dist/dialog-dismiss-CnwEbzc6.d.ts +48 -0
- package/dist/dialog-dismiss-CnwEbzc6.d.ts.map +1 -0
- package/dist/dialog-heading-DQvnOfZH.d.ts +49 -0
- package/dist/dialog-heading-DQvnOfZH.d.ts.map +1 -0
- package/dist/dialog-store-Cjt12T_Y.d.ts +29 -0
- package/dist/dialog-store-Cjt12T_Y.d.ts.map +1 -0
- package/dist/disclosure/disclosure-content.d.ts +2 -0
- package/dist/disclosure/disclosure-content.js +171 -0
- package/dist/disclosure/disclosure-content.js.map +1 -0
- package/dist/disclosure/disclosure-context.d.ts +24 -0
- package/dist/disclosure/disclosure-context.d.ts.map +1 -0
- package/dist/disclosure/disclosure-context.js +26 -0
- package/dist/disclosure/disclosure-context.js.map +1 -0
- package/dist/disclosure/disclosure-provider.d.ts +23 -0
- package/dist/disclosure/disclosure-provider.d.ts.map +1 -0
- package/dist/disclosure/disclosure-provider.js +27 -0
- package/dist/disclosure/disclosure-provider.js.map +1 -0
- package/dist/disclosure/disclosure-store.d.ts +2 -0
- package/dist/disclosure/disclosure-store.js +32 -0
- package/dist/disclosure/disclosure-store.js.map +1 -0
- package/dist/disclosure/disclosure.d.ts +2 -0
- package/dist/disclosure/disclosure.js +83 -0
- package/dist/disclosure/disclosure.js.map +1 -0
- package/dist/disclosure-CQ37hPVP.d.ts +60 -0
- package/dist/disclosure-CQ37hPVP.d.ts.map +1 -0
- package/dist/disclosure-content-BbPkZgAc.d.ts +88 -0
- package/dist/disclosure-content-BbPkZgAc.d.ts.map +1 -0
- package/dist/disclosure-store-BsaBaRKv.d.ts +58 -0
- package/dist/disclosure-store-BsaBaRKv.d.ts.map +1 -0
- package/dist/focus-trap/focus-trap-region.d.ts +42 -0
- package/dist/focus-trap/focus-trap-region.d.ts.map +1 -0
- package/dist/focus-trap/focus-trap-region.js +69 -0
- package/dist/focus-trap/focus-trap-region.js.map +1 -0
- package/dist/focus-trap/focus-trap.d.ts +31 -0
- package/dist/focus-trap/focus-trap.d.ts.map +1 -0
- package/dist/focus-trap/focus-trap.js +45 -0
- package/dist/focus-trap/focus-trap.js.map +1 -0
- package/dist/focusable/focusable-container.d.ts +43 -0
- package/dist/focusable/focusable-container.d.ts.map +1 -0
- package/dist/focusable/focusable-container.js +41 -0
- package/dist/focusable/focusable-container.js.map +1 -0
- package/dist/focusable/focusable-context.d.ts +5 -0
- package/dist/focusable/focusable-context.d.ts.map +1 -0
- package/dist/focusable/focusable-context.js +8 -0
- package/dist/focusable/focusable-context.js.map +1 -0
- package/dist/focusable/focusable.d.ts +2 -0
- package/dist/focusable/focusable.js +273 -0
- package/dist/focusable/focusable.js.map +1 -0
- package/dist/focusable-B00tOxtB.d.ts +142 -0
- package/dist/focusable-B00tOxtB.d.ts.map +1 -0
- package/dist/form/form-checkbox.d.ts +50 -0
- package/dist/form/form-checkbox.d.ts.map +1 -0
- package/dist/form/form-checkbox.js +73 -0
- package/dist/form/form-checkbox.js.map +1 -0
- package/dist/form/form-context.d.ts +24 -0
- package/dist/form/form-context.d.ts.map +1 -0
- package/dist/form/form-context.js +27 -0
- package/dist/form/form-context.js.map +1 -0
- package/dist/form/form-control.d.ts +100 -0
- package/dist/form/form-control.d.ts.map +1 -0
- package/dist/form/form-control.js +139 -0
- package/dist/form/form-control.js.map +1 -0
- package/dist/form/form-description.d.ts +73 -0
- package/dist/form/form-description.d.ts.map +1 -0
- package/dist/form/form-description.js +83 -0
- package/dist/form/form-description.js.map +1 -0
- package/dist/form/form-error.d.ts +82 -0
- package/dist/form/form-error.d.ts.map +1 -0
- package/dist/form/form-error.js +102 -0
- package/dist/form/form-error.js.map +1 -0
- package/dist/form/form-field.d.ts +73 -0
- package/dist/form/form-field.d.ts.map +1 -0
- package/dist/form/form-field.js +74 -0
- package/dist/form/form-field.js.map +1 -0
- package/dist/form/form-group-label.d.ts +62 -0
- package/dist/form/form-group-label.d.ts.map +1 -0
- package/dist/form/form-group-label.js +54 -0
- package/dist/form/form-group-label.js.map +1 -0
- package/dist/form/form-group.d.ts +64 -0
- package/dist/form/form-group.d.ts.map +1 -0
- package/dist/form/form-group.js +56 -0
- package/dist/form/form-group.js.map +1 -0
- package/dist/form/form-input.d.ts +50 -0
- package/dist/form/form-input.d.ts.map +1 -0
- package/dist/form/form-input.js +74 -0
- package/dist/form/form-input.js.map +1 -0
- package/dist/form/form-label.d.ts +77 -0
- package/dist/form/form-label.d.ts.map +1 -0
- package/dist/form/form-label.js +120 -0
- package/dist/form/form-label.js.map +1 -0
- package/dist/form/form-provider.d.ts +28 -0
- package/dist/form/form-provider.d.ts.map +1 -0
- package/dist/form/form-provider.js +15 -0
- package/dist/form/form-provider.js.map +1 -0
- package/dist/form/form-push.d.ts +102 -0
- package/dist/form/form-push.d.ts.map +1 -0
- package/dist/form/form-push.js +134 -0
- package/dist/form/form-push.js.map +1 -0
- package/dist/form/form-radio-group.d.ts +56 -0
- package/dist/form/form-radio-group.d.ts.map +1 -0
- package/dist/form/form-radio-group.js +68 -0
- package/dist/form/form-radio-group.js.map +1 -0
- package/dist/form/form-radio.d.ts +58 -0
- package/dist/form/form-radio.d.ts.map +1 -0
- package/dist/form/form-radio.js +90 -0
- package/dist/form/form-radio.js.map +1 -0
- package/dist/form/form-remove.d.ts +102 -0
- package/dist/form/form-remove.d.ts.map +1 -0
- package/dist/form/form-remove.js +116 -0
- package/dist/form/form-remove.js.map +1 -0
- package/dist/form/form-reset.d.ts +51 -0
- package/dist/form/form-reset.d.ts.map +1 -0
- package/dist/form/form-reset.js +54 -0
- package/dist/form/form-reset.js.map +1 -0
- package/dist/form/form-store.d.ts +2 -0
- package/dist/form/form-store.js +41 -0
- package/dist/form/form-store.js.map +1 -0
- package/dist/form/form-submit.d.ts +57 -0
- package/dist/form/form-submit.d.ts.map +1 -0
- package/dist/form/form-submit.js +59 -0
- package/dist/form/form-submit.js.map +1 -0
- package/dist/form/form.d.ts +101 -0
- package/dist/form/form.d.ts.map +1 -0
- package/dist/form/form.js +146 -0
- package/dist/form/form.js.map +1 -0
- package/dist/form-store-C4Kf5QHm.d.ts +120 -0
- package/dist/form-store-C4Kf5QHm.d.ts.map +1 -0
- package/dist/group/group-label-context.d.ts +7 -0
- package/dist/group/group-label-context.d.ts.map +1 -0
- package/dist/group/group-label-context.js +8 -0
- package/dist/group/group-label-context.js.map +1 -0
- package/dist/group/group-label.d.ts +2 -0
- package/dist/group/group-label.js +52 -0
- package/dist/group/group-label.js.map +1 -0
- package/dist/group/group.d.ts +2 -0
- package/dist/group/group.js +47 -0
- package/dist/group/group.js.map +1 -0
- package/dist/group-CamegDJA.d.ts +32 -0
- package/dist/group-CamegDJA.d.ts.map +1 -0
- package/dist/group-label-C16IDs1b.d.ts +37 -0
- package/dist/group-label-C16IDs1b.d.ts.map +1 -0
- package/dist/heading/heading-context.d.ts +7 -0
- package/dist/heading/heading-context.d.ts.map +1 -0
- package/dist/heading/heading-context.js +8 -0
- package/dist/heading/heading-context.js.map +1 -0
- package/dist/heading/heading-level.d.ts +35 -0
- package/dist/heading/heading-level.d.ts.map +1 -0
- package/dist/heading/heading-level.js +33 -0
- package/dist/heading/heading-level.js.map +1 -0
- package/dist/heading/heading.d.ts +2 -0
- package/dist/heading/heading.js +56 -0
- package/dist/heading/heading.js.map +1 -0
- package/dist/heading/utils.d.ts +2 -0
- package/dist/heading/utils.js +1 -0
- package/dist/heading-zY9g_9K-.d.ts +42 -0
- package/dist/heading-zY9g_9K-.d.ts.map +1 -0
- package/dist/hovercard/hovercard-anchor.d.ts +59 -0
- package/dist/hovercard/hovercard-anchor.d.ts.map +1 -0
- package/dist/hovercard/hovercard-anchor.js +106 -0
- package/dist/hovercard/hovercard-anchor.js.map +1 -0
- package/dist/hovercard/hovercard-arrow.d.ts +54 -0
- package/dist/hovercard/hovercard-arrow.d.ts.map +1 -0
- package/dist/hovercard/hovercard-arrow.js +51 -0
- package/dist/hovercard/hovercard-arrow.js.map +1 -0
- package/dist/hovercard/hovercard-context.d.ts +24 -0
- package/dist/hovercard/hovercard-context.d.ts.map +1 -0
- package/dist/hovercard/hovercard-context.js +27 -0
- package/dist/hovercard/hovercard-context.js.map +1 -0
- package/dist/hovercard/hovercard-description.d.ts +51 -0
- package/dist/hovercard/hovercard-description.d.ts.map +1 -0
- package/dist/hovercard/hovercard-description.js +42 -0
- package/dist/hovercard/hovercard-description.js.map +1 -0
- package/dist/hovercard/hovercard-disclosure.d.ts +51 -0
- package/dist/hovercard/hovercard-disclosure.d.ts.map +1 -0
- package/dist/hovercard/hovercard-disclosure.js +122 -0
- package/dist/hovercard/hovercard-disclosure.js.map +1 -0
- package/dist/hovercard/hovercard-dismiss.d.ts +50 -0
- package/dist/hovercard/hovercard-dismiss.d.ts.map +1 -0
- package/dist/hovercard/hovercard-dismiss.js +47 -0
- package/dist/hovercard/hovercard-dismiss.js.map +1 -0
- package/dist/hovercard/hovercard-heading.d.ts +51 -0
- package/dist/hovercard/hovercard-heading.d.ts.map +1 -0
- package/dist/hovercard/hovercard-heading.js +42 -0
- package/dist/hovercard/hovercard-heading.js.map +1 -0
- package/dist/hovercard/hovercard-provider.d.ts +23 -0
- package/dist/hovercard/hovercard-provider.d.ts.map +1 -0
- package/dist/hovercard/hovercard-provider.js +27 -0
- package/dist/hovercard/hovercard-provider.js.map +1 -0
- package/dist/hovercard/hovercard-store.d.ts +2 -0
- package/dist/hovercard/hovercard-store.js +31 -0
- package/dist/hovercard/hovercard-store.js.map +1 -0
- package/dist/hovercard/hovercard.d.ts +80 -0
- package/dist/hovercard/hovercard.d.ts.map +1 -0
- package/dist/hovercard/hovercard.js +240 -0
- package/dist/hovercard/hovercard.js.map +1 -0
- package/dist/hovercard/utils/debug-polygon.d.ts +7 -0
- package/dist/hovercard/utils/debug-polygon.d.ts.map +1 -0
- package/dist/hovercard/utils/debug-polygon.js +33 -0
- package/dist/hovercard/utils/debug-polygon.js.map +1 -0
- package/dist/hovercard/utils/polygon.d.ts +9 -0
- package/dist/hovercard/utils/polygon.d.ts.map +1 -0
- package/dist/hovercard/utils/polygon.js +70 -0
- package/dist/hovercard/utils/polygon.js.map +1 -0
- package/dist/hovercard-store-gIeoQEn_.d.ts +30 -0
- package/dist/hovercard-store-gIeoQEn_.d.ts.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/menu/menu-arrow.d.ts +52 -0
- package/dist/menu/menu-arrow.d.ts.map +1 -0
- package/dist/menu/menu-arrow.js +49 -0
- package/dist/menu/menu-arrow.js.map +1 -0
- package/dist/menu/menu-bar-provider.d.ts +35 -0
- package/dist/menu/menu-bar-provider.d.ts.map +1 -0
- package/dist/menu/menu-bar-provider.js +42 -0
- package/dist/menu/menu-bar-provider.js.map +1 -0
- package/dist/menu/menu-bar-store.d.ts +25 -0
- package/dist/menu/menu-bar-store.d.ts.map +1 -0
- package/dist/menu/menu-bar-store.js +28 -0
- package/dist/menu/menu-bar-store.js.map +1 -0
- package/dist/menu/menu-bar.d.ts +61 -0
- package/dist/menu/menu-bar.d.ts.map +1 -0
- package/dist/menu/menu-bar.js +66 -0
- package/dist/menu/menu-bar.js.map +1 -0
- package/dist/menu/menu-button-arrow.d.ts +65 -0
- package/dist/menu/menu-button-arrow.d.ts.map +1 -0
- package/dist/menu/menu-button-arrow.js +62 -0
- package/dist/menu/menu-button-arrow.js.map +1 -0
- package/dist/menu/menu-button.d.ts +67 -0
- package/dist/menu/menu-button.d.ts.map +1 -0
- package/dist/menu/menu-button.js +183 -0
- package/dist/menu/menu-button.js.map +1 -0
- package/dist/menu/menu-context.d.ts +47 -0
- package/dist/menu/menu-context.d.ts.map +1 -0
- package/dist/menu/menu-context.js +52 -0
- package/dist/menu/menu-context.js.map +1 -0
- package/dist/menu/menu-description.d.ts +50 -0
- package/dist/menu/menu-description.d.ts.map +1 -0
- package/dist/menu/menu-description.js +42 -0
- package/dist/menu/menu-description.js.map +1 -0
- package/dist/menu/menu-dismiss.d.ts +49 -0
- package/dist/menu/menu-dismiss.d.ts.map +1 -0
- package/dist/menu/menu-dismiss.js +47 -0
- package/dist/menu/menu-dismiss.js.map +1 -0
- package/dist/menu/menu-group-label.d.ts +55 -0
- package/dist/menu/menu-group-label.d.ts.map +1 -0
- package/dist/menu/menu-group-label.js +47 -0
- package/dist/menu/menu-group-label.js.map +1 -0
- package/dist/menu/menu-group.d.ts +61 -0
- package/dist/menu/menu-group.d.ts.map +1 -0
- package/dist/menu/menu-group.js +53 -0
- package/dist/menu/menu-group.js.map +1 -0
- package/dist/menu/menu-heading.d.ts +50 -0
- package/dist/menu/menu-heading.d.ts.map +1 -0
- package/dist/menu/menu-heading.js +42 -0
- package/dist/menu/menu-heading.js.map +1 -0
- package/dist/menu/menu-item-check.d.ts +58 -0
- package/dist/menu/menu-item-check.d.ts.map +1 -0
- package/dist/menu/menu-item-check.js +60 -0
- package/dist/menu/menu-item-check.js.map +1 -0
- package/dist/menu/menu-item-checkbox.d.ts +104 -0
- package/dist/menu/menu-item-checkbox.d.ts.map +1 -0
- package/dist/menu/menu-item-checkbox.js +151 -0
- package/dist/menu/menu-item-checkbox.js.map +1 -0
- package/dist/menu/menu-item-radio.d.ts +91 -0
- package/dist/menu/menu-item-radio.d.ts.map +1 -0
- package/dist/menu/menu-item-radio.js +121 -0
- package/dist/menu/menu-item-radio.js.map +1 -0
- package/dist/menu/menu-item.d.ts +75 -0
- package/dist/menu/menu-item.d.ts.map +1 -0
- package/dist/menu/menu-item.js +122 -0
- package/dist/menu/menu-item.js.map +1 -0
- package/dist/menu/menu-list.d.ts +59 -0
- package/dist/menu/menu-list.d.ts.map +1 -0
- package/dist/menu/menu-list.js +168 -0
- package/dist/menu/menu-list.js.map +1 -0
- package/dist/menu/menu-provider.d.ts +29 -0
- package/dist/menu/menu-provider.d.ts.map +1 -0
- package/dist/menu/menu-provider.js +15 -0
- package/dist/menu/menu-provider.js.map +1 -0
- package/dist/menu/menu-separator.d.ts +59 -0
- package/dist/menu/menu-separator.d.ts.map +1 -0
- package/dist/menu/menu-separator.js +57 -0
- package/dist/menu/menu-separator.js.map +1 -0
- package/dist/menu/menu-store.d.ts +2 -0
- package/dist/menu/menu-store.js +40 -0
- package/dist/menu/menu-store.js.map +1 -0
- package/dist/menu/menu.d.ts +49 -0
- package/dist/menu/menu.d.ts.map +1 -0
- package/dist/menu/menu.js +169 -0
- package/dist/menu/menu.js.map +1 -0
- package/dist/menu-store-0CKKmNek.d.ts +83 -0
- package/dist/menu-store-0CKKmNek.d.ts.map +1 -0
- package/dist/menubar/menubar-context.d.ts +25 -0
- package/dist/menubar/menubar-context.d.ts.map +1 -0
- package/dist/menubar/menubar-context.js +29 -0
- package/dist/menubar/menubar-context.js.map +1 -0
- package/dist/menubar/menubar-provider.d.ts +37 -0
- package/dist/menubar/menubar-provider.d.ts.map +1 -0
- package/dist/menubar/menubar-provider.js +41 -0
- package/dist/menubar/menubar-provider.js.map +1 -0
- package/dist/menubar/menubar-store.d.ts +2 -0
- package/dist/menubar/menubar-store.js +27 -0
- package/dist/menubar/menubar-store.js.map +1 -0
- package/dist/menubar/menubar.d.ts +71 -0
- package/dist/menubar/menubar.d.ts.map +1 -0
- package/dist/menubar/menubar.js +88 -0
- package/dist/menubar/menubar.js.map +1 -0
- package/dist/menubar-store-3h0eNIbS.d.ts +26 -0
- package/dist/menubar-store-3h0eNIbS.d.ts.map +1 -0
- package/dist/popover/popover-anchor.d.ts +2 -0
- package/dist/popover/popover-anchor.js +45 -0
- package/dist/popover/popover-anchor.js.map +1 -0
- package/dist/popover/popover-arrow-path.d.ts +5 -0
- package/dist/popover/popover-arrow-path.d.ts.map +1 -0
- package/dist/popover/popover-arrow-path.js +7 -0
- package/dist/popover/popover-arrow-path.js.map +1 -0
- package/dist/popover/popover-arrow.d.ts +65 -0
- package/dist/popover/popover-arrow.d.ts.map +1 -0
- package/dist/popover/popover-arrow.js +160 -0
- package/dist/popover/popover-arrow.js.map +1 -0
- package/dist/popover/popover-context.d.ts +24 -0
- package/dist/popover/popover-context.d.ts.map +1 -0
- package/dist/popover/popover-context.js +27 -0
- package/dist/popover/popover-context.js.map +1 -0
- package/dist/popover/popover-description.d.ts +2 -0
- package/dist/popover/popover-description.js +42 -0
- package/dist/popover/popover-description.js.map +1 -0
- package/dist/popover/popover-disclosure-arrow.d.ts +62 -0
- package/dist/popover/popover-disclosure-arrow.d.ts.map +1 -0
- package/dist/popover/popover-disclosure-arrow.js +81 -0
- package/dist/popover/popover-disclosure-arrow.js.map +1 -0
- package/dist/popover/popover-disclosure.d.ts +38 -0
- package/dist/popover/popover-disclosure.d.ts.map +1 -0
- package/dist/popover/popover-disclosure.js +66 -0
- package/dist/popover/popover-disclosure.js.map +1 -0
- package/dist/popover/popover-dismiss.d.ts +2 -0
- package/dist/popover/popover-dismiss.js +47 -0
- package/dist/popover/popover-dismiss.js.map +1 -0
- package/dist/popover/popover-heading.d.ts +2 -0
- package/dist/popover/popover-heading.js +42 -0
- package/dist/popover/popover-heading.js.map +1 -0
- package/dist/popover/popover-provider.d.ts +23 -0
- package/dist/popover/popover-provider.d.ts.map +1 -0
- package/dist/popover/popover-provider.js +27 -0
- package/dist/popover/popover-provider.js.map +1 -0
- package/dist/popover/popover-store.d.ts +2 -0
- package/dist/popover/popover-store.js +30 -0
- package/dist/popover/popover-store.js.map +1 -0
- package/dist/popover/popover.d.ts +2 -0
- package/dist/popover/popover.js +312 -0
- package/dist/popover/popover.js.map +1 -0
- package/dist/popover-CCqiRKqg.d.ts +181 -0
- package/dist/popover-CCqiRKqg.d.ts.map +1 -0
- package/dist/popover-anchor-PgfeXyzs.d.ts +47 -0
- package/dist/popover-anchor-PgfeXyzs.d.ts.map +1 -0
- package/dist/popover-description-DU753dah.d.ts +51 -0
- package/dist/popover-description-DU753dah.d.ts.map +1 -0
- package/dist/popover-dismiss-DPeI6Zse.d.ts +50 -0
- package/dist/popover-dismiss-DPeI6Zse.d.ts.map +1 -0
- package/dist/popover-heading-DGsr6D5W.d.ts +51 -0
- package/dist/popover-heading-DGsr6D5W.d.ts.map +1 -0
- package/dist/popover-store-Bc-l5VVO.d.ts +29 -0
- package/dist/popover-store-Bc-l5VVO.d.ts.map +1 -0
- package/dist/portal/portal-context.d.ts +21 -0
- package/dist/portal/portal-context.d.ts.map +1 -0
- package/dist/portal/portal-context.js +24 -0
- package/dist/portal/portal-context.js.map +1 -0
- package/dist/portal/portal.d.ts +2 -0
- package/dist/portal/portal.js +242 -0
- package/dist/portal/portal.js.map +1 -0
- package/dist/portal-CMBWiayp.d.ts +149 -0
- package/dist/portal-CMBWiayp.d.ts.map +1 -0
- package/dist/radio/radio-context.d.ts +24 -0
- package/dist/radio/radio-context.d.ts.map +1 -0
- package/dist/radio/radio-context.js +27 -0
- package/dist/radio/radio-context.js.map +1 -0
- package/dist/radio/radio-group.d.ts +51 -0
- package/dist/radio/radio-group.d.ts.map +1 -0
- package/dist/radio/radio-group.js +60 -0
- package/dist/radio/radio-group.js.map +1 -0
- package/dist/radio/radio-provider.d.ts +25 -0
- package/dist/radio/radio-provider.d.ts.map +1 -0
- package/dist/radio/radio-provider.js +29 -0
- package/dist/radio/radio-provider.js.map +1 -0
- package/dist/radio/radio-store.d.ts +2 -0
- package/dist/radio/radio-store.js +33 -0
- package/dist/radio/radio-store.js.map +1 -0
- package/dist/radio/radio.d.ts +76 -0
- package/dist/radio/radio.d.ts.map +1 -0
- package/dist/radio/radio.js +143 -0
- package/dist/radio/radio.js.map +1 -0
- package/dist/radio-store-DOZ_1RSk.d.ts +36 -0
- package/dist/radio-store-DOZ_1RSk.d.ts.map +1 -0
- package/dist/role/role.d.ts +34 -0
- package/dist/role/role.d.ts.map +1 -0
- package/dist/role/role.js +68 -0
- package/dist/role/role.js.map +1 -0
- package/dist/select/select-arrow.d.ts +60 -0
- package/dist/select/select-arrow.d.ts.map +1 -0
- package/dist/select/select-arrow.js +58 -0
- package/dist/select/select-arrow.js.map +1 -0
- package/dist/select/select-context.d.ts +27 -0
- package/dist/select/select-context.d.ts.map +1 -0
- package/dist/select/select-context.js +31 -0
- package/dist/select/select-context.js.map +1 -0
- package/dist/select/select-dismiss.d.ts +59 -0
- package/dist/select/select-dismiss.d.ts.map +1 -0
- package/dist/select/select-dismiss.js +56 -0
- package/dist/select/select-dismiss.js.map +1 -0
- package/dist/select/select-group-label.d.ts +61 -0
- package/dist/select/select-group-label.d.ts.map +1 -0
- package/dist/select/select-group-label.js +52 -0
- package/dist/select/select-group-label.js.map +1 -0
- package/dist/select/select-group.d.ts +62 -0
- package/dist/select/select-group.d.ts.map +1 -0
- package/dist/select/select-group.js +53 -0
- package/dist/select/select-group.js.map +1 -0
- package/dist/select/select-heading.d.ts +59 -0
- package/dist/select/select-heading.d.ts.map +1 -0
- package/dist/select/select-heading.js +62 -0
- package/dist/select/select-heading.js.map +1 -0
- package/dist/select/select-item-check.d.ts +59 -0
- package/dist/select/select-item-check.d.ts.map +1 -0
- package/dist/select/select-item-check.js +61 -0
- package/dist/select/select-item-check.js.map +1 -0
- package/dist/select/select-item-offscreen.d.ts +37 -0
- package/dist/select/select-item-offscreen.d.ts.map +1 -0
- package/dist/select/select-item-offscreen.js +38 -0
- package/dist/select/select-item-offscreen.js.map +1 -0
- package/dist/select/select-item.d.ts +108 -0
- package/dist/select/select-item.d.ts.map +1 -0
- package/dist/select/select-item.js +143 -0
- package/dist/select/select-item.js.map +1 -0
- package/dist/select/select-label.d.ts +55 -0
- package/dist/select/select-label.d.ts.map +1 -0
- package/dist/select/select-label.js +70 -0
- package/dist/select/select-label.js.map +1 -0
- package/dist/select/select-list.d.ts +80 -0
- package/dist/select/select-list.d.ts.map +1 -0
- package/dist/select/select-list.js +143 -0
- package/dist/select/select-list.js.map +1 -0
- package/dist/select/select-popover.d.ts +44 -0
- package/dist/select/select-popover.d.ts.map +1 -0
- package/dist/select/select-popover.js +59 -0
- package/dist/select/select-popover.js.map +1 -0
- package/dist/select/select-provider.d.ts +30 -0
- package/dist/select/select-provider.d.ts.map +1 -0
- package/dist/select/select-provider.js +15 -0
- package/dist/select/select-provider.js.map +1 -0
- package/dist/select/select-renderer.d.ts +44 -0
- package/dist/select/select-renderer.d.ts.map +1 -0
- package/dist/select/select-renderer.js +61 -0
- package/dist/select/select-renderer.js.map +1 -0
- package/dist/select/select-row.d.ts +63 -0
- package/dist/select/select-row.d.ts.map +1 -0
- package/dist/select/select-row.js +67 -0
- package/dist/select/select-row.js.map +1 -0
- package/dist/select/select-separator.d.ts +60 -0
- package/dist/select/select-separator.d.ts.map +1 -0
- package/dist/select/select-separator.js +57 -0
- package/dist/select/select-separator.js.map +1 -0
- package/dist/select/select-store.d.ts +2 -0
- package/dist/select/select-store.js +31 -0
- package/dist/select/select-store.js.map +1 -0
- package/dist/select/select-value.d.ts +84 -0
- package/dist/select/select-value.d.ts.map +1 -0
- package/dist/select/select-value.js +18 -0
- package/dist/select/select-value.js.map +1 -0
- package/dist/select/select.d.ts +89 -0
- package/dist/select/select.d.ts.map +1 -0
- package/dist/select/select.js +211 -0
- package/dist/select/select.js.map +1 -0
- package/dist/select-store-BsLTAyKh.d.ts +68 -0
- package/dist/select-store-BsLTAyKh.d.ts.map +1 -0
- package/dist/separator/separator.d.ts +2 -0
- package/dist/separator/separator.js +36 -0
- package/dist/separator/separator.js.map +1 -0
- package/dist/separator--ozQfMcK.d.ts +36 -0
- package/dist/separator--ozQfMcK.d.ts.map +1 -0
- package/dist/store.d.ts +1 -0
- package/dist/store.js +2 -0
- package/dist/tab/tab-context.d.ts +24 -0
- package/dist/tab/tab-context.d.ts.map +1 -0
- package/dist/tab/tab-context.js +27 -0
- package/dist/tab/tab-context.js.map +1 -0
- package/dist/tab/tab-list.d.ts +55 -0
- package/dist/tab/tab-list.d.ts.map +1 -0
- package/dist/tab/tab-list.js +71 -0
- package/dist/tab/tab-list.js.map +1 -0
- package/dist/tab/tab-panel.d.ts +122 -0
- package/dist/tab/tab-panel.d.ts.map +1 -0
- package/dist/tab/tab-panel.js +169 -0
- package/dist/tab/tab-panel.js.map +1 -0
- package/dist/tab/tab-provider.d.ts +26 -0
- package/dist/tab/tab-provider.d.ts.map +1 -0
- package/dist/tab/tab-provider.js +30 -0
- package/dist/tab/tab-provider.js.map +1 -0
- package/dist/tab/tab-store.d.ts +77 -0
- package/dist/tab/tab-store.d.ts.map +1 -0
- package/dist/tab/tab-store.js +55 -0
- package/dist/tab/tab-store.js.map +1 -0
- package/dist/tab/tab.d.ts +56 -0
- package/dist/tab/tab.d.ts.map +1 -0
- package/dist/tab/tab.js +115 -0
- package/dist/tab/tab.js.map +1 -0
- package/dist/tag/tag-context.d.ts +26 -0
- package/dist/tag/tag-context.d.ts.map +1 -0
- package/dist/tag/tag-context.js +30 -0
- package/dist/tag/tag-context.js.map +1 -0
- package/dist/tag/tag-input.d.ts +126 -0
- package/dist/tag/tag-input.d.ts.map +1 -0
- package/dist/tag/tag-input.js +162 -0
- package/dist/tag/tag-input.js.map +1 -0
- package/dist/tag/tag-list-label.d.ts +59 -0
- package/dist/tag/tag-list-label.d.ts.map +1 -0
- package/dist/tag/tag-list-label.js +62 -0
- package/dist/tag/tag-list-label.js.map +1 -0
- package/dist/tag/tag-list.d.ts +62 -0
- package/dist/tag/tag-list.d.ts.map +1 -0
- package/dist/tag/tag-list.js +127 -0
- package/dist/tag/tag-list.js.map +1 -0
- package/dist/tag/tag-provider.d.ts +34 -0
- package/dist/tag/tag-provider.d.ts.map +1 -0
- package/dist/tag/tag-provider.js +38 -0
- package/dist/tag/tag-provider.js.map +1 -0
- package/dist/tag/tag-remove.d.ts +71 -0
- package/dist/tag/tag-remove.d.ts.map +1 -0
- package/dist/tag/tag-remove.js +102 -0
- package/dist/tag/tag-remove.js.map +1 -0
- package/dist/tag/tag-store.d.ts +2 -0
- package/dist/tag/tag-store.js +38 -0
- package/dist/tag/tag-store.js.map +1 -0
- package/dist/tag/tag-value.d.ts +49 -0
- package/dist/tag/tag-value.d.ts.map +1 -0
- package/dist/tag/tag-value.js +40 -0
- package/dist/tag/tag-value.js.map +1 -0
- package/dist/tag/tag-values.d.ts +60 -0
- package/dist/tag/tag-values.d.ts.map +1 -0
- package/dist/tag/tag-values.js +50 -0
- package/dist/tag/tag-values.js.map +1 -0
- package/dist/tag/tag.d.ts +78 -0
- package/dist/tag/tag.d.ts.map +1 -0
- package/dist/tag/tag.js +114 -0
- package/dist/tag/tag.js.map +1 -0
- package/dist/tag/utils.d.ts +5 -0
- package/dist/tag/utils.d.ts.map +1 -0
- package/dist/tag/utils.js +15 -0
- package/dist/tag/utils.js.map +1 -0
- package/dist/tag-store-xANOvuGo.d.ts +49 -0
- package/dist/tag-store-xANOvuGo.d.ts.map +1 -0
- package/dist/toolbar/toolbar-container.d.ts +41 -0
- package/dist/toolbar/toolbar-container.d.ts.map +1 -0
- package/dist/toolbar/toolbar-container.js +53 -0
- package/dist/toolbar/toolbar-container.js.map +1 -0
- package/dist/toolbar/toolbar-context.d.ts +24 -0
- package/dist/toolbar/toolbar-context.d.ts.map +1 -0
- package/dist/toolbar/toolbar-context.js +27 -0
- package/dist/toolbar/toolbar-context.js.map +1 -0
- package/dist/toolbar/toolbar-input.d.ts +39 -0
- package/dist/toolbar/toolbar-input.d.ts.map +1 -0
- package/dist/toolbar/toolbar-input.js +47 -0
- package/dist/toolbar/toolbar-input.js.map +1 -0
- package/dist/toolbar/toolbar-item.d.ts +47 -0
- package/dist/toolbar/toolbar-item.d.ts.map +1 -0
- package/dist/toolbar/toolbar-item.js +45 -0
- package/dist/toolbar/toolbar-item.js.map +1 -0
- package/dist/toolbar/toolbar-provider.d.ts +26 -0
- package/dist/toolbar/toolbar-provider.d.ts.map +1 -0
- package/dist/toolbar/toolbar-provider.js +30 -0
- package/dist/toolbar/toolbar-provider.js.map +1 -0
- package/dist/toolbar/toolbar-separator.d.ts +51 -0
- package/dist/toolbar/toolbar-separator.d.ts.map +1 -0
- package/dist/toolbar/toolbar-separator.js +49 -0
- package/dist/toolbar/toolbar-separator.js.map +1 -0
- package/dist/toolbar/toolbar-store.d.ts +2 -0
- package/dist/toolbar/toolbar-store.js +31 -0
- package/dist/toolbar/toolbar-store.js.map +1 -0
- package/dist/toolbar/toolbar.d.ts +50 -0
- package/dist/toolbar/toolbar.d.ts.map +1 -0
- package/dist/toolbar/toolbar.js +66 -0
- package/dist/toolbar/toolbar.js.map +1 -0
- package/dist/toolbar-store-Cs-9cGHx.d.ts +30 -0
- package/dist/toolbar-store-Cs-9cGHx.d.ts.map +1 -0
- package/dist/tooltip/tooltip-anchor.d.ts +53 -0
- package/dist/tooltip/tooltip-anchor.d.ts.map +1 -0
- package/dist/tooltip/tooltip-anchor.js +121 -0
- package/dist/tooltip/tooltip-anchor.js.map +1 -0
- package/dist/tooltip/tooltip-arrow.d.ts +54 -0
- package/dist/tooltip/tooltip-arrow.d.ts.map +1 -0
- package/dist/tooltip/tooltip-arrow.js +54 -0
- package/dist/tooltip/tooltip-arrow.js.map +1 -0
- package/dist/tooltip/tooltip-context.d.ts +24 -0
- package/dist/tooltip/tooltip-context.d.ts.map +1 -0
- package/dist/tooltip/tooltip-context.js +27 -0
- package/dist/tooltip/tooltip-context.js.map +1 -0
- package/dist/tooltip/tooltip-provider.d.ts +23 -0
- package/dist/tooltip/tooltip-provider.d.ts.map +1 -0
- package/dist/tooltip/tooltip-provider.js +27 -0
- package/dist/tooltip/tooltip-provider.js.map +1 -0
- package/dist/tooltip/tooltip-store.d.ts +30 -0
- package/dist/tooltip/tooltip-store.d.ts.map +1 -0
- package/dist/tooltip/tooltip-store.js +30 -0
- package/dist/tooltip/tooltip-store.js.map +1 -0
- package/dist/tooltip/tooltip.d.ts +61 -0
- package/dist/tooltip/tooltip.d.ts.map +1 -0
- package/dist/tooltip/tooltip.js +81 -0
- package/dist/tooltip/tooltip.js.map +1 -0
- package/dist/utils-DUF1aMov.d.ts +5 -0
- package/dist/utils-DUF1aMov.d.ts.map +1 -0
- package/dist/visually-hidden/visually-hidden.d.ts +37 -0
- package/dist/visually-hidden/visually-hidden.d.ts.map +1 -0
- package/dist/visually-hidden/visually-hidden.js +53 -0
- package/dist/visually-hidden/visually-hidden.js.map +1 -0
- package/license +21 -0
- package/package.json +936 -0
- package/readme.md +19 -0
- package/src/button/button.tsx +76 -0
- package/src/checkbox/checkbox-check.tsx +116 -0
- package/src/checkbox/checkbox-checked-context.tsx +3 -0
- package/src/checkbox/checkbox-context.tsx +27 -0
- package/src/checkbox/checkbox-provider.tsx +53 -0
- package/src/checkbox/checkbox-store.ts +76 -0
- package/src/checkbox/checkbox.tsx +271 -0
- package/src/collection/collection-context.tsx +27 -0
- package/src/collection/collection-item-offscreen.tsx +157 -0
- package/src/collection/collection-item.tsx +136 -0
- package/src/collection/collection-provider.tsx +47 -0
- package/src/collection/collection-renderer.tsx +994 -0
- package/src/collection/collection-store.ts +84 -0
- package/src/collection/collection.tsx +93 -0
- package/src/combobox/combobox-cancel.tsx +153 -0
- package/src/combobox/combobox-context.tsx +49 -0
- package/src/combobox/combobox-disclosure.tsx +162 -0
- package/src/combobox/combobox-group-label.tsx +74 -0
- package/src/combobox/combobox-group.tsx +100 -0
- package/src/combobox/combobox-item-check.tsx +83 -0
- package/src/combobox/combobox-item-offscreen.tsx +87 -0
- package/src/combobox/combobox-item-value.tsx +231 -0
- package/src/combobox/combobox-item.tsx +363 -0
- package/src/combobox/combobox-label.tsx +89 -0
- package/src/combobox/combobox-list.tsx +176 -0
- package/src/combobox/combobox-popover.tsx +179 -0
- package/src/combobox/combobox-provider.tsx +50 -0
- package/src/combobox/combobox-row.tsx +102 -0
- package/src/combobox/combobox-separator.tsx +90 -0
- package/src/combobox/combobox-store.ts +168 -0
- package/src/combobox/combobox-value.tsx +63 -0
- package/src/combobox/combobox.tsx +900 -0
- package/src/command/command.tsx +215 -0
- package/src/composite/composite-container.tsx +278 -0
- package/src/composite/composite-context.tsx +53 -0
- package/src/composite/composite-group-label.tsx +73 -0
- package/src/composite/composite-group.tsx +77 -0
- package/src/composite/composite-hover.tsx +230 -0
- package/src/composite/composite-input.tsx +147 -0
- package/src/composite/composite-item-offscreen.tsx +112 -0
- package/src/composite/composite-item.tsx +567 -0
- package/src/composite/composite-overflow-disclosure.ts +117 -0
- package/src/composite/composite-overflow-store.ts +61 -0
- package/src/composite/composite-overflow.tsx +123 -0
- package/src/composite/composite-provider.tsx +47 -0
- package/src/composite/composite-renderer.tsx +231 -0
- package/src/composite/composite-row.tsx +133 -0
- package/src/composite/composite-separator.tsx +96 -0
- package/src/composite/composite-store.ts +101 -0
- package/src/composite/composite-typeahead.tsx +246 -0
- package/src/composite/composite.tsx +592 -0
- package/src/composite/utils.ts +121 -0
- package/src/dialog/dialog-backdrop.tsx +71 -0
- package/src/dialog/dialog-context.tsx +43 -0
- package/src/dialog/dialog-description.tsx +86 -0
- package/src/dialog/dialog-disclosure.tsx +84 -0
- package/src/dialog/dialog-dismiss.tsx +113 -0
- package/src/dialog/dialog-heading.tsx +88 -0
- package/src/dialog/dialog-provider.tsx +28 -0
- package/src/dialog/dialog-store.ts +51 -0
- package/src/dialog/dialog.tsx +866 -0
- package/src/dialog/utils/disable-accessibility-tree-outside.ts +30 -0
- package/src/dialog/utils/disable-tree.ts +81 -0
- package/src/dialog/utils/is-backdrop.ts +12 -0
- package/src/dialog/utils/is-focus-trap.ts +11 -0
- package/src/dialog/utils/mark-tree-outside.ts +67 -0
- package/src/dialog/utils/orchestrate.ts +123 -0
- package/src/dialog/utils/prepend-hidden-dismiss.ts +35 -0
- package/src/dialog/utils/supports-inert.ts +5 -0
- package/src/dialog/utils/use-hide-on-interact-outside.ts +181 -0
- package/src/dialog/utils/use-nested-dialogs.tsx +55 -0
- package/src/dialog/utils/use-prevent-body-scroll.ts +86 -0
- package/src/dialog/utils/use-previous-mouse-down-ref.ts +19 -0
- package/src/dialog/utils/use-root-dialog.ts +49 -0
- package/src/dialog/utils/walk-tree-outside.ts +85 -0
- package/src/disclosure/disclosure-content.tsx +344 -0
- package/src/disclosure/disclosure-context.tsx +27 -0
- package/src/disclosure/disclosure-provider.tsx +29 -0
- package/src/disclosure/disclosure-store.ts +85 -0
- package/src/disclosure/disclosure.tsx +144 -0
- package/src/focus-trap/focus-trap-region.tsx +112 -0
- package/src/focus-trap/focus-trap.tsx +60 -0
- package/src/focusable/focusable-container.tsx +75 -0
- package/src/focusable/focusable-context.tsx +3 -0
- package/src/focusable/focusable.tsx +559 -0
- package/src/form/form-checkbox.tsx +106 -0
- package/src/form/form-context.tsx +34 -0
- package/src/form/form-control.tsx +227 -0
- package/src/form/form-description.tsx +142 -0
- package/src/form/form-error.tsx +156 -0
- package/src/form/form-field.tsx +94 -0
- package/src/form/form-group-label.tsx +79 -0
- package/src/form/form-group.tsx +79 -0
- package/src/form/form-input.tsx +104 -0
- package/src/form/form-label.tsx +192 -0
- package/src/form/form-provider.tsx +49 -0
- package/src/form/form-push.tsx +200 -0
- package/src/form/form-radio-group.tsx +93 -0
- package/src/form/form-radio.tsx +122 -0
- package/src/form/form-remove.tsx +198 -0
- package/src/form/form-reset.tsx +85 -0
- package/src/form/form-store.ts +195 -0
- package/src/form/form-submit.tsx +93 -0
- package/src/form/form.tsx +249 -0
- package/src/group/group-label-context.tsx +6 -0
- package/src/group/group-label.tsx +75 -0
- package/src/group/group.tsx +69 -0
- package/src/heading/heading-context.tsx +4 -0
- package/src/heading/heading-level.tsx +42 -0
- package/src/heading/heading.tsx +81 -0
- package/src/heading/utils.ts +1 -0
- package/src/hovercard/hovercard-anchor.tsx +195 -0
- package/src/hovercard/hovercard-arrow.tsx +74 -0
- package/src/hovercard/hovercard-context.tsx +34 -0
- package/src/hovercard/hovercard-description.tsx +69 -0
- package/src/hovercard/hovercard-disclosure.tsx +196 -0
- package/src/hovercard/hovercard-dismiss.tsx +70 -0
- package/src/hovercard/hovercard-heading.tsx +68 -0
- package/src/hovercard/hovercard-provider.tsx +29 -0
- package/src/hovercard/hovercard-store.ts +58 -0
- package/src/hovercard/hovercard.tsx +445 -0
- package/src/hovercard/utils/__tests__/polygon-test.ts +66 -0
- package/src/hovercard/utils/debug-polygon.ts +37 -0
- package/src/hovercard/utils/polygon.ts +96 -0
- package/src/index.ts +1 -0
- package/src/menu/menu-arrow.tsx +69 -0
- package/src/menu/menu-bar-provider.tsx +44 -0
- package/src/menu/menu-bar-store.ts +54 -0
- package/src/menu/menu-bar.tsx +84 -0
- package/src/menu/menu-button-arrow.tsx +85 -0
- package/src/menu/menu-button.tsx +338 -0
- package/src/menu/menu-context.tsx +76 -0
- package/src/menu/menu-description.tsx +67 -0
- package/src/menu/menu-dismiss.tsx +69 -0
- package/src/menu/menu-group-label.tsx +72 -0
- package/src/menu/menu-group.tsx +76 -0
- package/src/menu/menu-heading.tsx +67 -0
- package/src/menu/menu-item-check.tsx +79 -0
- package/src/menu/menu-item-checkbox.tsx +227 -0
- package/src/menu/menu-item-radio.tsx +198 -0
- package/src/menu/menu-item.tsx +223 -0
- package/src/menu/menu-list.tsx +230 -0
- package/src/menu/menu-provider.tsx +42 -0
- package/src/menu/menu-separator.tsx +79 -0
- package/src/menu/menu-store.ts +155 -0
- package/src/menu/menu.tsx +274 -0
- package/src/menubar/menubar-context.tsx +39 -0
- package/src/menubar/menubar-provider.tsx +43 -0
- package/src/menubar/menubar-store.ts +48 -0
- package/src/menubar/menubar.tsx +145 -0
- package/src/popover/popover-anchor.tsx +74 -0
- package/src/popover/popover-arrow-path.ts +21 -0
- package/src/popover/popover-arrow.tsx +228 -0
- package/src/popover/popover-context.tsx +34 -0
- package/src/popover/popover-description.tsx +69 -0
- package/src/popover/popover-disclosure-arrow.tsx +135 -0
- package/src/popover/popover-disclosure.tsx +101 -0
- package/src/popover/popover-dismiss.tsx +70 -0
- package/src/popover/popover-heading.tsx +68 -0
- package/src/popover/popover-provider.tsx +29 -0
- package/src/popover/popover-store.ts +53 -0
- package/src/popover/popover.tsx +649 -0
- package/src/portal/portal-context.tsx +19 -0
- package/src/portal/portal.tsx +493 -0
- package/src/radio/radio-context.tsx +34 -0
- package/src/radio/radio-group.tsx +103 -0
- package/src/radio/radio-provider.tsx +29 -0
- package/src/radio/radio-store.ts +64 -0
- package/src/radio/radio.tsx +242 -0
- package/src/role/role.tsx +88 -0
- package/src/select/select-arrow.tsx +80 -0
- package/src/select/select-context.tsx +46 -0
- package/src/select/select-dismiss.tsx +79 -0
- package/src/select/select-group-label.tsx +78 -0
- package/src/select/select-group.tsx +79 -0
- package/src/select/select-heading.tsx +98 -0
- package/src/select/select-item-check.tsx +80 -0
- package/src/select/select-item-offscreen.tsx +59 -0
- package/src/select/select-item.tsx +294 -0
- package/src/select/select-label.tsx +117 -0
- package/src/select/select-list.tsx +251 -0
- package/src/select/select-popover.tsx +67 -0
- package/src/select/select-provider.tsx +45 -0
- package/src/select/select-renderer.tsx +160 -0
- package/src/select/select-row.tsx +97 -0
- package/src/select/select-separator.tsx +80 -0
- package/src/select/select-store.ts +139 -0
- package/src/select/select-value.tsx +108 -0
- package/src/select/select.tsx +371 -0
- package/src/separator/separator.tsx +54 -0
- package/src/store.ts +1 -0
- package/src/tab/tab-context.tsx +34 -0
- package/src/tab/tab-list.tsx +120 -0
- package/src/tab/tab-panel.tsx +314 -0
- package/src/tab/tab-provider.tsx +30 -0
- package/src/tab/tab-store.ts +124 -0
- package/src/tab/tab.tsx +208 -0
- package/src/tag/tag-context.tsx +40 -0
- package/src/tag/tag-input.tsx +321 -0
- package/src/tag/tag-list-label.tsx +102 -0
- package/src/tag/tag-list.tsx +210 -0
- package/src/tag/tag-provider.tsx +38 -0
- package/src/tag/tag-remove.tsx +174 -0
- package/src/tag/tag-store.ts +72 -0
- package/src/tag/tag-value.tsx +63 -0
- package/src/tag/tag-values.tsx +74 -0
- package/src/tag/tag.tsx +199 -0
- package/src/tag/utils.ts +12 -0
- package/src/toolbar/toolbar-container.tsx +67 -0
- package/src/toolbar/toolbar-context.tsx +34 -0
- package/src/toolbar/toolbar-input.tsx +64 -0
- package/src/toolbar/toolbar-item.tsx +72 -0
- package/src/toolbar/toolbar-provider.tsx +32 -0
- package/src/toolbar/toolbar-separator.tsx +71 -0
- package/src/toolbar/toolbar-store.ts +52 -0
- package/src/toolbar/toolbar.tsx +119 -0
- package/src/tooltip/tooltip-anchor.tsx +210 -0
- package/src/tooltip/tooltip-arrow.tsx +84 -0
- package/src/tooltip/tooltip-context.tsx +34 -0
- package/src/tooltip/tooltip-provider.tsx +29 -0
- package/src/tooltip/tooltip-store.ts +53 -0
- package/src/tooltip/tooltip.tsx +153 -0
- package/src/visually-hidden/visually-hidden.tsx +67 -0
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useCommand } from "../command/command.js";
|
|
3
|
+
import { CheckboxCheckedContext } from "./checkbox-checked-context.js";
|
|
4
|
+
import { useCheckboxContext } from "./checkbox-context.js";
|
|
5
|
+
import { createElement, createHook, forwardRef, useEvent, useForceUpdate, useMergeRefs, useTagName, useWrapElement } from "@ariakit/react-utils";
|
|
6
|
+
import { disabledFromProps, removeUndefinedValues } from "@ariakit/utils";
|
|
7
|
+
import { useEffect, useRef, useState } from "react";
|
|
8
|
+
import { jsx } from "react/jsx-runtime";
|
|
9
|
+
import { useStoreState } from "@ariakit/react-store";
|
|
10
|
+
//#region src/checkbox/checkbox.tsx
|
|
11
|
+
const TagName = "input";
|
|
12
|
+
function setMixed(element, mixed) {
|
|
13
|
+
if (mixed) element.indeterminate = true;
|
|
14
|
+
else if (element.indeterminate) element.indeterminate = false;
|
|
15
|
+
}
|
|
16
|
+
function isNativeCheckbox(tagName, type) {
|
|
17
|
+
return tagName === "input" && (!type || type === "checkbox");
|
|
18
|
+
}
|
|
19
|
+
function getPrimitiveValue(value) {
|
|
20
|
+
if (Array.isArray(value)) return value.toString();
|
|
21
|
+
return value;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Returns props to create a `Checkbox` component. If the element is not a
|
|
25
|
+
* native checkbox, the hook will return additional props to make sure it's
|
|
26
|
+
* accessible.
|
|
27
|
+
* @see https://ariakit.com/components/checkbox
|
|
28
|
+
* @example
|
|
29
|
+
* ```jsx
|
|
30
|
+
* const props = useCheckbox({ render: <div /> });
|
|
31
|
+
* <Role {...props}>Accessible checkbox</Role>
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
const useCheckbox = createHook(function useCheckbox({ store, name, value: valueProp, checked: checkedProp, defaultChecked, ...props }) {
|
|
35
|
+
const context = useCheckboxContext();
|
|
36
|
+
store = store || context;
|
|
37
|
+
const [_checked, setChecked] = useState(defaultChecked ?? false);
|
|
38
|
+
const checked = useStoreState(store, (state) => {
|
|
39
|
+
if (checkedProp !== void 0) return checkedProp;
|
|
40
|
+
if (state?.value === void 0) return _checked;
|
|
41
|
+
if (valueProp != null) {
|
|
42
|
+
if (Array.isArray(state.value)) {
|
|
43
|
+
const primitiveValue = getPrimitiveValue(valueProp);
|
|
44
|
+
return state.value.includes(primitiveValue);
|
|
45
|
+
}
|
|
46
|
+
return state.value === valueProp;
|
|
47
|
+
}
|
|
48
|
+
if (Array.isArray(state.value)) return false;
|
|
49
|
+
if (typeof state.value === "boolean") return state.value;
|
|
50
|
+
return false;
|
|
51
|
+
});
|
|
52
|
+
const ref = useRef(null);
|
|
53
|
+
const nativeCheckbox = isNativeCheckbox(useTagName(ref, TagName), props.type);
|
|
54
|
+
const mixed = checked ? checked === "mixed" : void 0;
|
|
55
|
+
const isChecked = checked === "mixed" ? false : checked;
|
|
56
|
+
const disabled = disabledFromProps(props);
|
|
57
|
+
const [propertyUpdated, schedulePropertyUpdate] = useForceUpdate();
|
|
58
|
+
useEffect(() => {
|
|
59
|
+
const element = ref.current;
|
|
60
|
+
if (!element) return;
|
|
61
|
+
setMixed(element, mixed);
|
|
62
|
+
if (nativeCheckbox) return;
|
|
63
|
+
element.checked = isChecked;
|
|
64
|
+
if (name !== void 0) element.name = name;
|
|
65
|
+
if (valueProp !== void 0) element.value = String(valueProp);
|
|
66
|
+
}, [
|
|
67
|
+
propertyUpdated,
|
|
68
|
+
mixed,
|
|
69
|
+
nativeCheckbox,
|
|
70
|
+
isChecked,
|
|
71
|
+
name,
|
|
72
|
+
valueProp
|
|
73
|
+
]);
|
|
74
|
+
const onChangeProp = props.onChange;
|
|
75
|
+
const onChange = useEvent((event) => {
|
|
76
|
+
if (disabled) {
|
|
77
|
+
event.stopPropagation();
|
|
78
|
+
event.preventDefault();
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
setMixed(event.currentTarget, mixed);
|
|
82
|
+
if (!nativeCheckbox) {
|
|
83
|
+
event.currentTarget.checked = !event.currentTarget.checked;
|
|
84
|
+
schedulePropertyUpdate();
|
|
85
|
+
}
|
|
86
|
+
onChangeProp?.(event);
|
|
87
|
+
if (event.defaultPrevented) return;
|
|
88
|
+
const elementChecked = event.currentTarget.checked;
|
|
89
|
+
setChecked(elementChecked);
|
|
90
|
+
store?.setValue((prevValue) => {
|
|
91
|
+
if (valueProp == null) return elementChecked;
|
|
92
|
+
const primitiveValue = getPrimitiveValue(valueProp);
|
|
93
|
+
if (!Array.isArray(prevValue)) return prevValue === primitiveValue ? false : primitiveValue;
|
|
94
|
+
if (elementChecked) {
|
|
95
|
+
if (prevValue.includes(primitiveValue)) return prevValue;
|
|
96
|
+
return [...prevValue, primitiveValue];
|
|
97
|
+
}
|
|
98
|
+
return prevValue.filter((v) => v !== primitiveValue);
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
const onClickProp = props.onClick;
|
|
102
|
+
const onClick = useEvent((event) => {
|
|
103
|
+
onClickProp?.(event);
|
|
104
|
+
if (event.defaultPrevented) return;
|
|
105
|
+
if (nativeCheckbox) return;
|
|
106
|
+
onChange(event);
|
|
107
|
+
});
|
|
108
|
+
props = useWrapElement(props, (element) => /* @__PURE__ */ jsx(CheckboxCheckedContext.Provider, {
|
|
109
|
+
value: isChecked,
|
|
110
|
+
children: element
|
|
111
|
+
}), [isChecked]);
|
|
112
|
+
props = {
|
|
113
|
+
role: !nativeCheckbox ? "checkbox" : void 0,
|
|
114
|
+
type: nativeCheckbox ? "checkbox" : void 0,
|
|
115
|
+
"aria-checked": checked,
|
|
116
|
+
...props,
|
|
117
|
+
ref: useMergeRefs(ref, props.ref),
|
|
118
|
+
onChange,
|
|
119
|
+
onClick
|
|
120
|
+
};
|
|
121
|
+
props = useCommand({
|
|
122
|
+
clickOnEnter: !nativeCheckbox,
|
|
123
|
+
...props
|
|
124
|
+
});
|
|
125
|
+
return removeUndefinedValues({
|
|
126
|
+
name: nativeCheckbox ? name : void 0,
|
|
127
|
+
value: nativeCheckbox ? valueProp : void 0,
|
|
128
|
+
checked: isChecked,
|
|
129
|
+
...props
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
/**
|
|
133
|
+
* Renders an accessible checkbox element. If the underlying element is not a
|
|
134
|
+
* native checkbox, this component will pass additional attributes to make sure
|
|
135
|
+
* it's accessible.
|
|
136
|
+
* @see https://ariakit.com/components/checkbox
|
|
137
|
+
* @example
|
|
138
|
+
* ```jsx
|
|
139
|
+
* <Checkbox render={<div />}>Accessible checkbox</Checkbox>
|
|
140
|
+
* ```
|
|
141
|
+
*/
|
|
142
|
+
const Checkbox = forwardRef(function Checkbox(props) {
|
|
143
|
+
return createElement(TagName, useCheckbox(props));
|
|
144
|
+
});
|
|
145
|
+
//#endregion
|
|
146
|
+
export { Checkbox, useCheckbox };
|
|
147
|
+
|
|
148
|
+
//# sourceMappingURL=checkbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkbox.js","names":[],"sources":["../../src/checkbox/checkbox.tsx"],"sourcesContent":["import { useStoreState } from \"@ariakit/react-store\";\nimport {\n useEvent,\n useForceUpdate,\n useMergeRefs,\n useTagName,\n useWrapElement,\n createElement,\n createHook,\n forwardRef,\n} from \"@ariakit/react-utils\";\nimport type { Props } from \"@ariakit/react-utils\";\nimport { disabledFromProps, removeUndefinedValues } from \"@ariakit/utils\";\nimport type {\n ChangeEvent,\n ComponentPropsWithoutRef,\n ElementType,\n MouseEvent,\n} from \"react\";\nimport { useEffect, useRef, useState } from \"react\";\nimport type { CommandOptions } from \"../command/command.tsx\";\nimport { useCommand } from \"../command/command.tsx\";\nimport { CheckboxCheckedContext } from \"./checkbox-checked-context.tsx\";\nimport { useCheckboxContext } from \"./checkbox-context.tsx\";\nimport type { CheckboxStore } from \"./checkbox-store.ts\";\n\nconst TagName = \"input\" satisfies ElementType;\ntype TagName = typeof TagName;\ntype HTMLType = HTMLElementTagNameMap[TagName];\n\nfunction setMixed(element: HTMLType, mixed?: boolean) {\n if (mixed) {\n element.indeterminate = true;\n } else if (element.indeterminate) {\n element.indeterminate = false;\n }\n}\n\nfunction isNativeCheckbox(tagName?: string, type?: string) {\n return tagName === \"input\" && (!type || type === \"checkbox\");\n}\n\nfunction getPrimitiveValue<T>(value: T) {\n if (Array.isArray(value)) {\n return value.toString();\n }\n return value as Exclude<T, readonly any[]>;\n}\n\n/**\n * Returns props to create a `Checkbox` component. If the element is not a\n * native checkbox, the hook will return additional props to make sure it's\n * accessible.\n * @see https://ariakit.com/components/checkbox\n * @example\n * ```jsx\n * const props = useCheckbox({ render: <div /> });\n * <Role {...props}>Accessible checkbox</Role>\n * ```\n */\nexport const useCheckbox = createHook<TagName, CheckboxOptions>(\n function useCheckbox({\n store,\n name,\n value: valueProp,\n checked: checkedProp,\n defaultChecked,\n ...props\n }) {\n const context = useCheckboxContext();\n store = store || context;\n\n const [_checked, setChecked] = useState(defaultChecked ?? false);\n\n const checked = useStoreState(store, (state) => {\n if (checkedProp !== undefined) return checkedProp;\n if (state?.value === undefined) return _checked;\n if (valueProp != null) {\n if (Array.isArray(state.value)) {\n const primitiveValue = getPrimitiveValue(valueProp);\n return state.value.includes(primitiveValue);\n }\n return state.value === valueProp;\n }\n if (Array.isArray(state.value)) return false;\n if (typeof state.value === \"boolean\") return state.value;\n return false;\n });\n\n const ref = useRef<HTMLType>(null);\n const tagName = useTagName(ref, TagName);\n const nativeCheckbox = isNativeCheckbox(tagName, props.type);\n const mixed = checked ? checked === \"mixed\" : undefined;\n const isChecked = checked === \"mixed\" ? false : checked;\n const disabled = disabledFromProps(props);\n // When the checked property is programmatically set on the change event, we\n // need to schedule the element's property update, so the controlled\n // isChecked state can be taken into account.\n const [propertyUpdated, schedulePropertyUpdate] = useForceUpdate();\n\n useEffect(() => {\n const element = ref.current;\n if (!element) return;\n setMixed(element, mixed);\n if (nativeCheckbox) return;\n element.checked = isChecked;\n if (name !== undefined) {\n element.name = name;\n }\n if (valueProp !== undefined) {\n element.value = String(valueProp);\n }\n }, [propertyUpdated, mixed, nativeCheckbox, isChecked, name, valueProp]);\n\n const onChangeProp = props.onChange;\n\n const onChange = useEvent((event: ChangeEvent<HTMLType>) => {\n if (disabled) {\n event.stopPropagation();\n event.preventDefault();\n return;\n }\n setMixed(event.currentTarget, mixed);\n if (!nativeCheckbox) {\n // If the element is not a native checkbox, we need to manually update\n // its checked property.\n event.currentTarget.checked = !event.currentTarget.checked;\n schedulePropertyUpdate();\n }\n onChangeProp?.(event);\n if (event.defaultPrevented) return;\n\n const elementChecked = event.currentTarget.checked;\n setChecked(elementChecked);\n\n store?.setValue((prevValue) => {\n if (valueProp == null) return elementChecked;\n const primitiveValue = getPrimitiveValue(valueProp);\n if (!Array.isArray(prevValue)) {\n return prevValue === primitiveValue ? false : primitiveValue;\n }\n if (elementChecked) {\n if (prevValue.includes(primitiveValue)) {\n return prevValue;\n }\n return [...prevValue, primitiveValue];\n }\n return prevValue.filter((v) => v !== primitiveValue);\n });\n });\n\n const onClickProp = props.onClick;\n\n const onClick = useEvent((event: MouseEvent<HTMLType>) => {\n onClickProp?.(event);\n if (event.defaultPrevented) return;\n if (nativeCheckbox) return;\n // @ts-expect-error The onChange event expects a ChangeEvent, but here we\n // need to pass a MouseEvent.\n onChange(event);\n });\n\n props = useWrapElement(\n props,\n (element) => (\n <CheckboxCheckedContext.Provider value={isChecked}>\n {element}\n </CheckboxCheckedContext.Provider>\n ),\n [isChecked],\n );\n\n props = {\n role: !nativeCheckbox ? \"checkbox\" : undefined,\n type: nativeCheckbox ? \"checkbox\" : undefined,\n \"aria-checked\": checked,\n ...props,\n ref: useMergeRefs(ref, props.ref),\n onChange,\n onClick,\n };\n\n props = useCommand<TagName>({ clickOnEnter: !nativeCheckbox, ...props });\n\n return removeUndefinedValues({\n name: nativeCheckbox ? name : undefined,\n value: nativeCheckbox ? valueProp : undefined,\n checked: isChecked,\n ...props,\n });\n },\n);\n\n/**\n * Renders an accessible checkbox element. If the underlying element is not a\n * native checkbox, this component will pass additional attributes to make sure\n * it's accessible.\n * @see https://ariakit.com/components/checkbox\n * @example\n * ```jsx\n * <Checkbox render={<div />}>Accessible checkbox</Checkbox>\n * ```\n */\nexport const Checkbox = forwardRef(function Checkbox(props: CheckboxProps) {\n const htmlProps = useCheckbox(props);\n return createElement(TagName, htmlProps);\n});\n\nexport interface CheckboxOptions<\n T extends ElementType = TagName,\n> extends CommandOptions<T> {\n /**\n * Object returned by the\n * [`useCheckboxStore`](https://ariakit.com/reference/use-checkbox-store)\n * hook. If not provided, the closest\n * [`CheckboxProvider`](https://ariakit.com/reference/checkbox-provider)\n * component's context will be used. Otherwise, the component will fall back\n * to an internal store.\n *\n * Live examples:\n * - [Checkbox as button](https://ariakit.com/examples/checkbox-as-button)\n */\n store?: CheckboxStore;\n /**\n * The native `name` attribute.\n *\n * Live examples:\n * - [MenuItemCheckbox](https://ariakit.com/examples/menu-item-checkbox)\n */\n name?: string;\n /**\n * The value of the checkbox. This is useful when the same checkbox store is\n * used for multiple [`Checkbox`](https://ariakit.com/reference/checkbox)\n * elements, in which case the value will be an array of checked values.\n *\n * Live examples:\n * - [Checkbox group](https://ariakit.com/examples/checkbox-group)\n * - [MenuItemCheckbox](https://ariakit.com/examples/menu-item-checkbox)\n * @example\n * ```jsx \"value\"\n * <CheckboxProvider defaultValue={[\"Apple\", \"Orange\"]}>\n * <Checkbox value=\"Apple\" />\n * <Checkbox value=\"Orange\" />\n * <Checkbox value=\"Watermelon\" />\n * </CheckboxProvider>\n * ```\n */\n value?: ComponentPropsWithoutRef<TagName>[\"value\"];\n /**\n * The default checked state of the checkbox. This prop is ignored if the\n * [`checked`](https://ariakit.com/reference/checkbox#checked) or the\n * [`store`](https://ariakit.com/reference/checkbox#store) props are provided.\n */\n defaultChecked?: \"mixed\" | boolean;\n /**\n * The checked state of the checkbox. This will override the value inferred\n * from [`store`](https://ariakit.com/reference/checkbox#store) prop, if\n * provided. This can be `\"mixed\"` to indicate that the checkbox is partially\n * checked.\n */\n checked?: \"mixed\" | boolean;\n /**\n * A function that is called when the checkbox's checked state changes.\n */\n onChange?: ComponentPropsWithoutRef<TagName>[\"onChange\"];\n}\n\nexport type CheckboxProps<T extends ElementType = TagName> = Props<\n T,\n CheckboxOptions<T>\n>;\n"],"mappings":";;;;;;;;;;AA8BA,MAAA,UAAS;SACH,SACF,SAAQ,OAAA;YACC,QAAQ,gBACjB;MAEJ,IAAA,QAAA,eAAA,QAAA,gBAAA;AAEA;SACS,iBAAY,SAAa,MAAQ;CAC1C,OAAA,YAAA,YAAA,CAAA,QAAA,SAAA;AAEA;SACM,kBACF,OAAO;CAET,IAAA,MAAO,QAAA,KAAA,GAAA,OAAA,MAAA,SAAA;CACT,OAAA;;;;;;;;;;;;;MAsBI,cAAgB,WAAA,SAAmB,YAAA,EAAA,OAAA,MAAA,OAAA,WAAA,SAAA,aAAA,gBAAA,GAAA,SAAA;CACnC,MAAA,UAAQ,mBAAS;CAEjB,QAAO,SAAU;CAEjB,MAAM,CAAA,UAAU,cAAc,SAAQ,kBAAU,KAAA;OAC1C,UAAA,cAA2B,QAAO,UAAA;EACtC,IAAI,gBAAO,KAAU,GAAA,OAAW;EAChC,IAAI,OAAA,UAAa,KAAM,GAAA,OAAA;MACrB,aAAU,MAAQ;OAChB,MAAM,QAAA,MAAiB,KAAA,GAAA;IACvB,MAAA,iBAAmB,kBAAS,SAAc;IAC5C,OAAA,MAAA,MAAA,SAAA,cAAA;GACA;GACF,OAAA,MAAA,UAAA;EACA;EACA,IAAI,MAAA,QAAa,MAAA,KAAU,GAAA,OAAW;EACtC,IAAA,OAAO,MAAA,UAAA,WAAA,OAAA,MAAA;EACR,OAAA;CAED,CAAA;CAEA,MAAM,MAAA,OAAA,IAAiB;CACvB,MAAM,iBAAQ,iBAAsB,WAAU,KAAA,OAAA,GAAA,MAAA,IAAA;CAC9C,MAAM,QAAA,UAAY,YAAY,UAAU,KAAQ;CAChD,MAAM,YAAW,YAAA,UAAuB,QAAA;CAIxC,MAAM,WAAC,kBAAiB,KAAA;CAExB,MAAA,CAAA,iBAAgB,0BAAA,eAAA;iBACR;EACN,MAAK,UAAS,IAAA;EACd,IAAA,CAAA,SAAS;EACT,SAAI,SAAA,KAAgB;EACpB,IAAA,gBAAkB;EAClB,QAAI,UAAS;EAGb,IAAI,SAAA,KAAc,GAAA,QAChB,OAAQ;EAEZ,IAAG,cAAA,KAAA,GAAA,QAAA,QAAA,OAAA,SAAA;IAAC;EAAiB;EAAO;EAAgB;EAAW;EAAM;EAAU;CAEvE,CAAA;CAEA,MAAM,eAAW,MAAU;OACrB,WAAU,UAAA,UAAA;MACZ,UAAM;GACN,MAAM,gBAAe;GACrB,MAAA,eAAA;GACF;EACA;EACA,SAAK,MAAA,eAAgB,KAAA;MAGnB,CAAA,gBAAoB;GACpB,MAAA,cAAA,UAAuB,CAAA,MAAA,cAAA;GACzB,uBAAA;EACA;EACA,eAAU,KAAA;EAEV,IAAA,MAAM,kBAAiB;EACvB,MAAA,iBAAW,MAAc,cAAA;EAEzB,WAAO,cAAU;SACX,UAAA,cAA0B;GAC9B,IAAA,aAAM,MAAiB,OAAA;GACvB,MAAK,iBAAc,kBACV,SAAA;GAET,IAAI,CAAA,MAAA,QAAA,SAAgB,GAAA,OAAA,cAAA,iBAAA,QAAA;OAClB,gBAAc;IAGd,IAAA,UAAW,SAAW,cAAc,GAAA,OAAA;IACtC,OAAA,CAAA,GAAA,WAAA,cAAA;GACA;GACD,OAAA,UAAA,QAAA,MAAA,MAAA,cAAA;EACF,CAAA;CAED,CAAA;CAEA,MAAM,cAAU,MAAU;OACxB,UAAc,UAAK,UAAA;EACnB,cAAU,KAAA;EACV,IAAI,MAAA,kBAAgB;EAGpB,IAAA,gBAAc;EACf,SAAA,KAAA;CAED,CAAA;SAG4C,eAAA,QAAA,YAAA,oBAAA,uBAAA,UAAA;;EAEP,UAElC;CAGH,CAAA,GAAA,CAAA,SAAQ,CAAA;SACC;EACP,MAAM,CAAA,iBAAiB,aAAa,KAAA;EACpC,MAAA,iBAAgB,aAAA,KAAA;EAChB,gBAAG;EACH,GAAA;EACA,KAAA,aAAA,KAAA,MAAA,GAAA;EACA;EACF;CAEA;SAA8B,WAAe;EAAgB,cAAG,CAAA;EAAO,GAAA;CAEvE,CAAA;QACQ,sBAAiB;EACvB,MAAA,iBAAO,OAAiB,KAAA;EACxB,OAAA,iBAAS,YAAA,KAAA;EACT,SAAG;EACJ,GAAA;CAEL,CAAA;;;;;;;;;;;;MAcE,WAAO,WAAc,SADH,SAAY,OACS;CACxC,OAAA,cAAA,SAAA,YAAA,KAAA,CAAA"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { BivariantCallback, PickRequired } from "@ariakit/utils";
|
|
2
|
+
import * as Core from "@ariakit/components/checkbox/checkbox-store";
|
|
3
|
+
import { Store } from "@ariakit/react-store";
|
|
4
|
+
|
|
5
|
+
//#region src/checkbox/checkbox-store.d.ts
|
|
6
|
+
declare function useCheckboxStoreProps<T extends Core.CheckboxStore>(store: T, update: () => void, props: CheckboxStoreProps): T;
|
|
7
|
+
/**
|
|
8
|
+
* Creates a checkbox store to conveniently manage a checkbox value,
|
|
9
|
+
* whether it's a string, number, boolean, or an array of strings or numbers.
|
|
10
|
+
* @see https://ariakit.com/components/checkbox
|
|
11
|
+
* @example
|
|
12
|
+
* ```jsx
|
|
13
|
+
* const checkbox = useCheckboxStore({ defaultValue: true });
|
|
14
|
+
* <Checkbox store={checkbox} />
|
|
15
|
+
* ```
|
|
16
|
+
*/
|
|
17
|
+
declare function useCheckboxStore<T extends CheckboxStoreValue = CheckboxStoreValue>(props: PickRequired<CheckboxStoreProps<T>, "value" | "defaultValue">): CheckboxStore<T>;
|
|
18
|
+
declare function useCheckboxStore(props?: CheckboxStoreProps): CheckboxStore;
|
|
19
|
+
type CheckboxStoreValue = Core.CheckboxStoreValue;
|
|
20
|
+
type CheckboxStoreState<T extends CheckboxStoreValue = CheckboxStoreValue> = Core.CheckboxStoreState<T>;
|
|
21
|
+
type CheckboxStoreFunctions<T extends CheckboxStoreValue = CheckboxStoreValue> = Core.CheckboxStoreFunctions<T>;
|
|
22
|
+
interface CheckboxStoreOptions<T extends CheckboxStoreValue = CheckboxStoreValue> extends Core.CheckboxStoreOptions<T> {
|
|
23
|
+
/**
|
|
24
|
+
* A callback that gets called when the
|
|
25
|
+
* [`value`](https://ariakit.com/reference/checkbox-provider#value) state
|
|
26
|
+
* changes.
|
|
27
|
+
* @example
|
|
28
|
+
* function MyCheckbox({ value, onChange }) {
|
|
29
|
+
* const checkbox = useCheckboxStore({ value, setValue: onChange });
|
|
30
|
+
* }
|
|
31
|
+
*/
|
|
32
|
+
setValue?: BivariantCallback<(value: CheckboxStoreState<T>["value"]) => void>;
|
|
33
|
+
}
|
|
34
|
+
interface CheckboxStoreProps<T extends CheckboxStoreValue = CheckboxStoreValue> extends CheckboxStoreOptions<T>, Core.CheckboxStoreProps<T> {}
|
|
35
|
+
interface CheckboxStore<T extends CheckboxStoreValue = CheckboxStoreValue> extends CheckboxStoreFunctions<T>, Store<Core.CheckboxStore<T>> {}
|
|
36
|
+
//#endregion
|
|
37
|
+
export { CheckboxStoreState as a, useCheckboxStoreProps as c, CheckboxStoreProps as i, CheckboxStoreFunctions as n, CheckboxStoreValue as o, CheckboxStoreOptions as r, useCheckboxStore as s, CheckboxStore as t };
|
|
38
|
+
//# sourceMappingURL=checkbox-store-CYZPR4N4.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkbox-store-CYZPR4N4.d.ts","names":["Core","Store","BivariantCallback","PickRequired","useCheckboxStoreProps","T","CheckboxStore","CheckboxStoreProps","store","update","props","useCheckboxStore","CheckboxStoreValue","CheckboxStoreState","CheckboxStoreFunctions","CheckboxStoreOptions","setValue","value"],"sources":["../src/checkbox/checkbox-store.d.ts"],"mappings":";;;;;iBAGwBI,qBAAAA,WAAgCJ,IAAAA,CAAKM,aAAAA,CAAAA,CAAeE,KAAAA,EAAOH,CAAAA,EAAGI,MAAAA,cAAoBC,KAAAA,EAAOH,kBAAAA,GAAqBF,CAAAA;;AAAtI;;;;;;;;;iBAWwBM,gBAAAA,WAA2BC,kBAAAA,GAAqBA,kBAAAA,CAAAA,CAAoBF,KAAAA,EAAOP,YAAAA,CAAaI,kBAAAA,CAAmBF,CAAAA,+BAAgCC,aAAAA,CAAcD,CAAAA;AAAAA,iBACzJM,gBAAAA,CAAiBD,KAAAA,GAAQH,kBAAAA,GAAqBD,aAAa;AAAA,KACvEM,kBAAAA,GAAqBZ,IAAAA,CAAKY,kBAAkB;AAAA,KAC5CC,kBAAAA,WAA6BD,kBAAAA,GAAqBA,kBAAAA,IAAsBZ,IAAAA,CAAKa,kBAAAA,CAAmBR,CAAAA;AAAAA,KAChGS,sBAAAA,WAAiCF,kBAAAA,GAAqBA,kBAAAA,IAAsBZ,IAAAA,CAAKc,sBAAAA,CAAuBT,CAAAA;AAAAA,UACnGU,oBAAAA,WAA+BH,kBAAAA,GAAqBA,kBAAAA,UAA4BZ,IAAAA,CAAKe,oBAAAA,CAAqBV,CAAAA;EAhBVE;;;;AAAsB;AAWvI;;;;EAeIS,QAAAA,GAAWd,iBAAAA,EAAmBe,KAAAA,EAAOJ,kBAAAA,CAAmBR,CAAAA;AAAAA;AAAAA,UAE3CE,kBAAAA,WAA6BK,kBAAAA,GAAqBA,kBAAAA,UAA4BG,oBAAAA,CAAqBV,CAAAA,GAAIL,IAAAA,CAAKO,kBAAAA,CAAmBF,CAAAA;AAAAA,UAE/HC,aAAAA,WAAwBM,kBAAAA,GAAqBA,kBAAAA,UAA4BE,sBAAAA,CAAuBT,CAAAA,GAAIJ,KAAAA,CAAMD,IAAAA,CAAKM,aAAAA,CAAcD,CAAAA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { r as CollectionStoreItem, t as CollectionStore } from "../collection-store-CbwzYsWf.js";
|
|
2
|
+
|
|
3
|
+
//#region src/collection/collection-context.d.ts
|
|
4
|
+
/**
|
|
5
|
+
* Returns the collection store from the nearest collection container.
|
|
6
|
+
* @example
|
|
7
|
+
* function CollectionItem() {
|
|
8
|
+
* const store = useCollectionContext();
|
|
9
|
+
*
|
|
10
|
+
* if (!store) {
|
|
11
|
+
* throw new Error("CollectionItem must be wrapped in CollectionProvider");
|
|
12
|
+
* }
|
|
13
|
+
*
|
|
14
|
+
* // Use the store...
|
|
15
|
+
* }
|
|
16
|
+
*/
|
|
17
|
+
declare const useCollectionContext: () => CollectionStore<CollectionStoreItem> | undefined;
|
|
18
|
+
declare const useCollectionScopedContext: (onlyScoped?: boolean) => CollectionStore<CollectionStoreItem> | undefined;
|
|
19
|
+
declare const useCollectionProviderContext: () => CollectionStore<CollectionStoreItem> | undefined;
|
|
20
|
+
declare const CollectionContextProvider: (props: import("react").ProviderProps<CollectionStore<CollectionStoreItem> | undefined>) => import("react/jsx-runtime").JSX.Element;
|
|
21
|
+
declare const CollectionScopedContextProvider: (props: import("react").ProviderProps<CollectionStore<CollectionStoreItem> | undefined>) => import("react/jsx-runtime").JSX.Element;
|
|
22
|
+
//#endregion
|
|
23
|
+
export { CollectionContextProvider, CollectionScopedContextProvider, useCollectionContext, useCollectionProviderContext, useCollectionScopedContext };
|
|
24
|
+
//# sourceMappingURL=collection-context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collection-context.d.ts","names":["CollectionStore","useCollectionContext","_$__collection_store_ts0","CollectionStoreItem","useCollectionScopedContext","onlyScoped","useCollectionProviderContext","CollectionContextProvider","ProviderProps","props","JSX","Element","CollectionScopedContextProvider"],"sources":["../../src/collection/collection-context.d.ts"],"mappings":";;;;;AAcA;;;;AAAgE;AAChE;;;;;;cADqBC,oBAAAA,QAA4BD,eAAe,CAAiEE,mBAAAA;AAAAA,cAC5GE,0BAAAA,GAA6BC,UAAAA,eAAyBL,eAAe,CAAiEE,mBAAAA;AAAAA,cACtII,4BAAAA,QAAoCN,eAAe,CAAiEE,mBAAAA;AAAAA,cACpHK,yBAAAA,GAA4BE,KAAAA,kBAAuBD,aAAAA,CAAcR,eAAe,CAA8GE,mBAAAA,+CAAXQ,GAAAA,CAAIC,OAAAA;AAAAA,cACvLC,+BAAAA,GAAkCH,KAAAA,kBAAuBD,aAAAA,CAAcR,eAAe,CAA8GE,mBAAAA,+CAAXQ,GAAAA,CAAIC,OAAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { createStoreContext } from "@ariakit/react-utils";
|
|
3
|
+
//#region src/collection/collection-context.tsx
|
|
4
|
+
const ctx = createStoreContext();
|
|
5
|
+
/**
|
|
6
|
+
* Returns the collection store from the nearest collection container.
|
|
7
|
+
* @example
|
|
8
|
+
* function CollectionItem() {
|
|
9
|
+
* const store = useCollectionContext();
|
|
10
|
+
*
|
|
11
|
+
* if (!store) {
|
|
12
|
+
* throw new Error("CollectionItem must be wrapped in CollectionProvider");
|
|
13
|
+
* }
|
|
14
|
+
*
|
|
15
|
+
* // Use the store...
|
|
16
|
+
* }
|
|
17
|
+
*/
|
|
18
|
+
const useCollectionContext = ctx.useContext;
|
|
19
|
+
const useCollectionScopedContext = ctx.useScopedContext;
|
|
20
|
+
const useCollectionProviderContext = ctx.useProviderContext;
|
|
21
|
+
const CollectionContextProvider = ctx.ContextProvider;
|
|
22
|
+
const CollectionScopedContextProvider = ctx.ScopedContextProvider;
|
|
23
|
+
//#endregion
|
|
24
|
+
export { CollectionContextProvider, CollectionScopedContextProvider, useCollectionContext, useCollectionProviderContext, useCollectionScopedContext };
|
|
25
|
+
|
|
26
|
+
//# sourceMappingURL=collection-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collection-context.js","names":[],"sources":["../../src/collection/collection-context.tsx"],"sourcesContent":["import { createStoreContext } from \"@ariakit/react-utils\";\nimport type { CollectionStore } from \"./collection-store.ts\";\n\nconst ctx = createStoreContext<CollectionStore>();\n\n/**\n * Returns the collection store from the nearest collection container.\n * @example\n * function CollectionItem() {\n * const store = useCollectionContext();\n *\n * if (!store) {\n * throw new Error(\"CollectionItem must be wrapped in CollectionProvider\");\n * }\n *\n * // Use the store...\n * }\n */\nexport const useCollectionContext = ctx.useContext;\n\nexport const useCollectionScopedContext = ctx.useScopedContext;\n\nexport const useCollectionProviderContext = ctx.useProviderContext;\n\nexport const CollectionContextProvider = ctx.ContextProvider;\n\nexport const CollectionScopedContextProvider = ctx.ScopedContextProvider;\n"],"mappings":";;;;;;;;;;;;;;;;;AAoBA,MAAa,uBAAA,IAAA;AAEb,MAAa,6BAAA,IAA+B;AAE5C,MAAa,+BAA4B,IAAI;AAE7C,MAAa,4BAAA,IAAA"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { Role } from "../role/role.js";
|
|
3
|
+
import { CollectionItem as CollectionItem$1 } from "./collection-item.js";
|
|
4
|
+
import { forwardRef, useForceUpdate, useId, useMergeRefs } from "@ariakit/react-utils";
|
|
5
|
+
import { invariant } from "@ariakit/utils";
|
|
6
|
+
import { useCallback, useRef, useState } from "react";
|
|
7
|
+
import { jsx } from "react/jsx-runtime";
|
|
8
|
+
//#region src/collection/collection-item-offscreen.tsx
|
|
9
|
+
const TagName = "div";
|
|
10
|
+
function requestIdleCallback(callback) {
|
|
11
|
+
if (typeof window.requestIdleCallback === "function") return window.requestIdleCallback(callback);
|
|
12
|
+
callback();
|
|
13
|
+
return 0;
|
|
14
|
+
}
|
|
15
|
+
function cancelIdleCallback(id) {
|
|
16
|
+
if (typeof window.cancelIdleCallback === "function") window.cancelIdleCallback(id);
|
|
17
|
+
}
|
|
18
|
+
function useCollectionItemOffscreen({ offscreenMode = "active", offscreenRoot, ...props }) {
|
|
19
|
+
const id = useId(props.id);
|
|
20
|
+
const [updated, forceUpdate] = useForceUpdate();
|
|
21
|
+
const forcedUpdatesCountRef = useRef(0);
|
|
22
|
+
const [_active, setActive] = useState(offscreenMode === "active");
|
|
23
|
+
const active = _active || offscreenMode === "active";
|
|
24
|
+
const observerRef = useRef(null);
|
|
25
|
+
const idleCallbackIdRef = useRef(0);
|
|
26
|
+
return {
|
|
27
|
+
id,
|
|
28
|
+
active,
|
|
29
|
+
ref: useCallback((element) => {
|
|
30
|
+
if (!element || offscreenMode === "active") {
|
|
31
|
+
cancelIdleCallback(idleCallbackIdRef.current);
|
|
32
|
+
observerRef.current?.disconnect();
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
invariant(offscreenRoot !== void 0, "The offscreenRoot prop must provided.");
|
|
36
|
+
const getOffscreenRoot = () => {
|
|
37
|
+
if (!offscreenRoot) return null;
|
|
38
|
+
if (typeof offscreenRoot === "function") return offscreenRoot(element);
|
|
39
|
+
if ("current" in offscreenRoot) return offscreenRoot.current;
|
|
40
|
+
return offscreenRoot;
|
|
41
|
+
};
|
|
42
|
+
const root = getOffscreenRoot();
|
|
43
|
+
if (!root) {
|
|
44
|
+
forcedUpdatesCountRef.current++;
|
|
45
|
+
if (forcedUpdatesCountRef.current > 3) throw new Error("The offscreenRoot is not available. Please make sure the root element is mounted.");
|
|
46
|
+
forceUpdate();
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
if (!observerRef.current || observerRef.current.root !== root) observerRef.current = new IntersectionObserver(([entry]) => {
|
|
50
|
+
cancelIdleCallback(idleCallbackIdRef.current);
|
|
51
|
+
const isIntersecting = !!entry?.isIntersecting;
|
|
52
|
+
idleCallbackIdRef.current = requestIdleCallback(() => {
|
|
53
|
+
if (!isIntersecting && offscreenMode === "lazy") return;
|
|
54
|
+
setActive(isIntersecting);
|
|
55
|
+
});
|
|
56
|
+
}, {
|
|
57
|
+
root,
|
|
58
|
+
rootMargin: "40%"
|
|
59
|
+
});
|
|
60
|
+
observerRef.current.observe(element);
|
|
61
|
+
}, [
|
|
62
|
+
updated,
|
|
63
|
+
offscreenMode,
|
|
64
|
+
offscreenRoot
|
|
65
|
+
]),
|
|
66
|
+
"data-offscreen": !active || void 0
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
const CollectionItem = forwardRef(function CollectionItem({ offscreenMode, offscreenRoot, ...props }) {
|
|
70
|
+
const { active, ref, ...rest } = useCollectionItemOffscreen({
|
|
71
|
+
offscreenMode,
|
|
72
|
+
offscreenRoot,
|
|
73
|
+
...props
|
|
74
|
+
});
|
|
75
|
+
const allProps = {
|
|
76
|
+
...rest,
|
|
77
|
+
...props,
|
|
78
|
+
ref: useMergeRefs(ref, props.ref)
|
|
79
|
+
};
|
|
80
|
+
if (active) return /* @__PURE__ */ jsx(CollectionItem$1, { ...allProps });
|
|
81
|
+
const { store, shouldRegisterItem, getItem, element, ...htmlProps } = allProps;
|
|
82
|
+
const Component = Role[TagName];
|
|
83
|
+
return /* @__PURE__ */ jsx(Component, { ...htmlProps });
|
|
84
|
+
});
|
|
85
|
+
//#endregion
|
|
86
|
+
export { CollectionItem, useCollectionItemOffscreen };
|
|
87
|
+
|
|
88
|
+
//# sourceMappingURL=collection-item-offscreen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collection-item-offscreen.js","names":["Base.CollectionItem"],"sources":["../../src/collection/collection-item-offscreen.tsx"],"sourcesContent":["import {\n useForceUpdate,\n useId,\n useMergeRefs,\n forwardRef,\n} from \"@ariakit/react-utils\";\nimport type { Props } from \"@ariakit/react-utils\";\nimport { invariant } from \"@ariakit/utils\";\nimport type { ElementType, RefCallback, RefObject } from \"react\";\nimport { useCallback, useRef, useState } from \"react\";\nimport { Role } from \"../role/role.tsx\";\nimport * as Base from \"./collection-item.tsx\";\n\nconst TagName = \"div\" satisfies ElementType;\ntype TagName = typeof TagName;\ntype HTMLType = HTMLElementTagNameMap[TagName];\n\nfunction requestIdleCallback(callback: () => void) {\n if (typeof window.requestIdleCallback === \"function\") {\n return window.requestIdleCallback(callback);\n }\n callback();\n return 0;\n}\n\nfunction cancelIdleCallback(id: number) {\n if (typeof window.cancelIdleCallback === \"function\") {\n window.cancelIdleCallback(id);\n }\n}\n\nexport function useCollectionItemOffscreen<\n T extends ElementType,\n // oxlint-disable-next-line no-unnecessary-type-parameters\n P extends CollectionItemProps<T>,\n>({ offscreenMode = \"active\", offscreenRoot, ...props }: P) {\n const id = useId(props.id);\n const [updated, forceUpdate] = useForceUpdate();\n const forcedUpdatesCountRef = useRef(0);\n\n const [_active, setActive] = useState(offscreenMode === \"active\");\n const active = _active || offscreenMode === \"active\";\n\n const observerRef = useRef<IntersectionObserver | null>(null);\n const idleCallbackIdRef = useRef(0);\n\n const ref = useCallback<RefCallback<HTMLType>>(\n (element) => {\n if (!element || offscreenMode === \"active\") {\n cancelIdleCallback(idleCallbackIdRef.current);\n observerRef.current?.disconnect();\n return;\n }\n\n invariant(\n offscreenRoot !== undefined,\n process.env.NODE_ENV !== \"production\" &&\n \"The offscreenRoot prop must provided.\",\n );\n\n const getOffscreenRoot = () => {\n if (!offscreenRoot) return null;\n if (typeof offscreenRoot === \"function\") {\n return offscreenRoot(element);\n }\n if (\"current\" in offscreenRoot) {\n return offscreenRoot.current;\n }\n return offscreenRoot;\n };\n\n const root = getOffscreenRoot();\n\n if (!root) {\n forcedUpdatesCountRef.current++;\n if (forcedUpdatesCountRef.current > 3) {\n throw new Error(\n \"The offscreenRoot is not available. Please make sure the root element is mounted.\",\n );\n }\n forceUpdate();\n return;\n }\n\n if (!observerRef.current || observerRef.current.root !== root) {\n observerRef.current = new IntersectionObserver(\n ([entry]) => {\n cancelIdleCallback(idleCallbackIdRef.current);\n const isIntersecting = !!entry?.isIntersecting;\n idleCallbackIdRef.current = requestIdleCallback(() => {\n if (!isIntersecting && offscreenMode === \"lazy\") return;\n setActive(isIntersecting);\n });\n },\n { root, rootMargin: \"40%\" },\n );\n }\n\n observerRef.current.observe(element);\n },\n // This callback intentionally depends on `updated` so `forceUpdate()`\n // causes React to re-run the ref callback when the offscreen root becomes\n // available.\n // oxlint-disable-next-line exhaustive-deps\n [updated, offscreenMode, offscreenRoot],\n );\n\n return {\n id,\n active,\n ref,\n \"data-offscreen\": !active || undefined,\n };\n}\n\nexport const CollectionItem = forwardRef(function CollectionItem({\n offscreenMode,\n offscreenRoot,\n ...props\n}: CollectionItemProps) {\n const { active, ref, ...rest } = useCollectionItemOffscreen({\n offscreenMode,\n offscreenRoot,\n ...props,\n });\n const allProps = { ...rest, ...props, ref: useMergeRefs(ref, props.ref) };\n if (active) {\n return <Base.CollectionItem {...allProps} />;\n }\n // Remove CompositeItem props\n const {\n store,\n shouldRegisterItem,\n getItem,\n // @ts-expect-error This prop may come from a collection renderer.\n element,\n ...htmlProps\n } = allProps;\n const Component = Role[TagName];\n return <Component {...htmlProps} />;\n});\n\nexport interface CollectionItemOptions<\n T extends ElementType = TagName,\n> extends Base.CollectionItemOptions<T> {\n offscreenMode?: \"active\" | \"passive\" | \"lazy\";\n offscreenRoot?:\n | HTMLElement\n | RefObject<HTMLElement | null>\n | ((element: HTMLElement) => HTMLElement | null)\n | null;\n}\n\nexport type CollectionItemProps<T extends ElementType = TagName> = Props<\n T,\n CollectionItemOptions<T>\n>;\n"],"mappings":";;;;;;;;AAiBA,MAAA,UAAS;SACH,oBAAc,UAAA;CAGlB,IAAA,OAAS,OAAA,wBAAA,YAAA,OAAA,OAAA,oBAAA,QAAA;CACT,SAAO;CACT,OAAA;AAEA;SACM,mBAAc,IAAA;CAGpB,IAAA,OAAA,OAAA,uBAAA,YAAA,OAAA,mBAAA,EAAA;AAEA;SAKQ,2BAAmB,EAAA,gBAAA,UAAA,eAAA,GAAA,SAAA;CACzB,MAAM,KAAC,MAAS,MAAA,EAAA;CAChB,MAAM,CAAA,SAAA,eAAwB,eAAQ;CAEtC,MAAM,wBAAuB,OAAA,CAAS;CACtC,MAAM,CAAA,SAAS,aAAW,SAAA,kBAAkB,QAAA;CAE5C,MAAM,SAAA,WAAc,kBAAwC;CAC5D,MAAM,cAAA,OAAoB,IAAA;CA+D1B,MAAA,oBAAO,OAAA,CAAA;QACL;EACA;EACA;OA9DM,aAAY,YAAA;OACd,CAAA,WAAA,kBAAmB,UAAkB;IACrC,mBAAY,kBAAoB,OAAA;IAChC,YAAA,SAAA,WAAA;IACF;GAEA;GAMA,UAAM,kBAAA,KAAyB,GAAA,uCAAA;SACxB,yBAAsB;IAC3B,IAAI,CAAA,eAAO,OAAA;IAGX,IAAI,OAAA,kBAAa,YACR,OAAA,cAAc,OAAA;IAEvB,IAAA,aAAO,eAAA,OAAA,cAAA;IACT,OAAA;GAEA;GAEA,MAAK,OAAM,iBAAA;OACT,CAAA,MAAA;IACA,sBAAI;IAKJ,IAAA,sBAAY,UAAA,GAAA,MAAA,IAAA,MAAA,mFAAA;IACZ,YAAA;IACF;GAEA;OAGM,CAAA,YAAA,WAAmB,YAAkB,QAAO,SAAA,MAAA,YAAA,UAAA,IAAA,sBAAA,CAAA,WAAA;IAC5C,mBAAM,kBAA0B,OAAA;IAChC,MAAA,iBAAkB,CAAA,CAAA,OAAU;sBACrB,UAAkB,0BAA0B;KACjD,IAAA,CAAA,kBAAU,kBAAc,QAAA;KACzB,UAAA,cAAA;IACH,CAAA;MACE;IAAM;IACV,YAAA;GAGF,CAAA;GACF,YAKA,QAAA,QAAA,OAAA;KAAC;GAAS;GAAe;GAMvB;EACF,CAAA;EACF,kBAAA,CAAA,UAAA,KAAA;CACF;AAEA;MAKE,iBAAqB,WAAY,SAAA,eAAA,EAAA,eAA2B,eAAA,GAAA,SAAA;OAC1D,EAAA,QAAA,KAAA,GAAA,SAAA,2BAAA;EACA;EACA;EACD,GAAA;CACD,CAAA;OAAsB,WAAA;EAAM,GAAG;EAAO,GAAA;EAAkC,KAAA,aAAA,KAAA,MAAA,GAAA;CACxE;CAIA,IAAA,QACE,OAEA,oBAAA,kBAGG,EAAA,GAAA,SACD,CAAA;CACJ,MAAM,EAAA,OAAA,oBAAiB,SAAA,SAAA,GAAA,cAAA;CACvB,MAAA,YAAO,KAAA;CACR,OAAA,oBAAA,WAAA,EAAA,GAAA,UAAA,CAAA"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useCollectionContext } from "./collection-context.js";
|
|
3
|
+
import { createElement, createHook, forwardRef, useId, useMergeRefs } from "@ariakit/react-utils";
|
|
4
|
+
import { identity, removeUndefinedValues } from "@ariakit/utils";
|
|
5
|
+
import { useEffect, useRef } from "react";
|
|
6
|
+
//#region src/collection/collection-item.tsx
|
|
7
|
+
const TagName = "div";
|
|
8
|
+
/**
|
|
9
|
+
* Returns props to create a `CollectionItem` component. This hook will register
|
|
10
|
+
* the item in the collection store. If this hook is used in a component that is
|
|
11
|
+
* wrapped by `Collection` or a component that implements `useCollection`,
|
|
12
|
+
* there's no need to explicitly pass the `store` prop.
|
|
13
|
+
* @see https://ariakit.com/components/collection
|
|
14
|
+
* @example
|
|
15
|
+
* ```jsx
|
|
16
|
+
* const store = useCollectionStore();
|
|
17
|
+
* const props = useCollectionItem({ store });
|
|
18
|
+
* <Role {...props}>Item</Role>
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
const useCollectionItem = createHook(function useCollectionItem({ store, shouldRegisterItem = true, getItem = identity, element, ...props }) {
|
|
22
|
+
const context = useCollectionContext();
|
|
23
|
+
store = store || context;
|
|
24
|
+
const id = useId(props.id);
|
|
25
|
+
const ref = useRef(element);
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
const element = ref.current;
|
|
28
|
+
if (!id) return;
|
|
29
|
+
if (!element) return;
|
|
30
|
+
if (!shouldRegisterItem) return;
|
|
31
|
+
const item = getItem({
|
|
32
|
+
id,
|
|
33
|
+
element
|
|
34
|
+
});
|
|
35
|
+
return store?.renderItem(item);
|
|
36
|
+
}, [
|
|
37
|
+
id,
|
|
38
|
+
shouldRegisterItem,
|
|
39
|
+
getItem,
|
|
40
|
+
store
|
|
41
|
+
]);
|
|
42
|
+
props = {
|
|
43
|
+
...props,
|
|
44
|
+
ref: useMergeRefs(ref, props.ref)
|
|
45
|
+
};
|
|
46
|
+
return removeUndefinedValues(props);
|
|
47
|
+
});
|
|
48
|
+
/**
|
|
49
|
+
* Renders an item in a collection. The collection store can be passed
|
|
50
|
+
* explicitly through the
|
|
51
|
+
* [`store`](https://ariakit.com/reference/collection-item#store) prop or
|
|
52
|
+
* implicitly through the parent
|
|
53
|
+
* [`Collection`](https://ariakit.com/reference/collection) component.
|
|
54
|
+
* @see https://ariakit.com/components/collection
|
|
55
|
+
* @example
|
|
56
|
+
* ```jsx
|
|
57
|
+
* const store = useCollectionStore();
|
|
58
|
+
* <CollectionItem store={store}>Item 1</CollectionItem>
|
|
59
|
+
* <CollectionItem store={store}>Item 2</CollectionItem>
|
|
60
|
+
* <CollectionItem store={store}>Item 3</CollectionItem>
|
|
61
|
+
* ```
|
|
62
|
+
*/
|
|
63
|
+
const CollectionItem = forwardRef(function CollectionItem(props) {
|
|
64
|
+
return createElement(TagName, useCollectionItem(props));
|
|
65
|
+
});
|
|
66
|
+
//#endregion
|
|
67
|
+
export { CollectionItem, useCollectionItem };
|
|
68
|
+
|
|
69
|
+
//# sourceMappingURL=collection-item.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collection-item.js","names":[],"sources":["../../src/collection/collection-item.tsx"],"sourcesContent":["import type { CollectionStoreItem } from \"@ariakit/components/collection/collection-store\";\nimport {\n useId,\n useMergeRefs,\n createElement,\n createHook,\n forwardRef,\n} from \"@ariakit/react-utils\";\nimport type { Options, Props } from \"@ariakit/react-utils\";\nimport { identity, removeUndefinedValues } from \"@ariakit/utils\";\nimport type { ElementType } from \"react\";\nimport { useEffect, useRef } from \"react\";\nimport { useCollectionContext } from \"./collection-context.tsx\";\nimport type { CollectionStore } from \"./collection-store.ts\";\n\nconst TagName = \"div\" satisfies ElementType;\ntype TagName = typeof TagName;\ntype HTMLType = HTMLElementTagNameMap[TagName];\n\n/**\n * Returns props to create a `CollectionItem` component. This hook will register\n * the item in the collection store. If this hook is used in a component that is\n * wrapped by `Collection` or a component that implements `useCollection`,\n * there's no need to explicitly pass the `store` prop.\n * @see https://ariakit.com/components/collection\n * @example\n * ```jsx\n * const store = useCollectionStore();\n * const props = useCollectionItem({ store });\n * <Role {...props}>Item</Role>\n * ```\n */\nexport const useCollectionItem = createHook<TagName, CollectionItemOptions>(\n function useCollectionItem({\n store,\n shouldRegisterItem = true,\n getItem = identity,\n // @ts-expect-error This prop may come from a collection renderer.\n element,\n ...props\n }) {\n const context = useCollectionContext();\n store = store || context;\n\n const id = useId(props.id);\n const ref = useRef<HTMLType>(element);\n\n useEffect(() => {\n const element = ref.current;\n if (!id) return;\n if (!element) return;\n if (!shouldRegisterItem) return;\n const item = getItem({ id, element });\n return store?.renderItem(item);\n }, [id, shouldRegisterItem, getItem, store]);\n\n props = {\n ...props,\n ref: useMergeRefs(ref, props.ref),\n };\n\n return removeUndefinedValues(props);\n },\n);\n\n/**\n * Renders an item in a collection. The collection store can be passed\n * explicitly through the\n * [`store`](https://ariakit.com/reference/collection-item#store) prop or\n * implicitly through the parent\n * [`Collection`](https://ariakit.com/reference/collection) component.\n * @see https://ariakit.com/components/collection\n * @example\n * ```jsx\n * const store = useCollectionStore();\n * <CollectionItem store={store}>Item 1</CollectionItem>\n * <CollectionItem store={store}>Item 2</CollectionItem>\n * <CollectionItem store={store}>Item 3</CollectionItem>\n * ```\n */\nexport const CollectionItem = forwardRef(function CollectionItem(\n props: CollectionItemProps,\n) {\n const htmlProps = useCollectionItem(props);\n return createElement(TagName, htmlProps);\n});\n\nexport interface CollectionItemOptions<\n _T extends ElementType = TagName,\n> extends Options {\n /**\n * Object returned by the\n * [`useCollectionStore`](https://ariakit.com/reference/use-collection-store)\n * hook. If not provided, the closest\n * [`Collection`](https://ariakit.com/reference/collection) or\n * [`CollectionProvider`](https://ariakit.com/reference/collection-provider)\n * components' context will be used.\n *\n * Live examples:\n * - [Navigation Menubar](https://ariakit.com/examples/menubar-navigation)\n */\n store?: CollectionStore;\n /**\n * The unique ID of the item. This will be used to register the item in the\n * store and for the element's `id` attribute. If not provided, a unique ID\n * will be automatically generated.\n *\n * Live examples:\n * - [Combobox with Tabs](https://ariakit.com/examples/combobox-tabs)\n * - [Tab with React Router](https://ariakit.com/examples/tab-react-router)\n * - [Animated TabPanel](https://ariakit.com/examples/tab-panel-animated)\n * - [Select with Combobox and\n * Tabs](https://ariakit.com/examples/select-combobox-tab)\n */\n id?: string;\n /**\n * Whether the item should be registered as part of the collection.\n * @default true\n */\n shouldRegisterItem?: boolean;\n /**\n * A memoized function that returns props to be passed with the item during\n * its registration in the store.\n * @example\n * ```jsx\n * const getItem = useCallback((data) => ({ ...data, custom: true }), []);\n * <CollectionItem getItem={getItem} />\n * ```\n */\n getItem?: (props: CollectionStoreItem) => CollectionStoreItem;\n}\n\nexport type CollectionItemProps<T extends ElementType = TagName> = Props<\n T,\n CollectionItemOptions<T>\n>;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;MAyCI,oBAAgB,WAAA,SAAqB,kBAAA,EAAA,OAAA,qBAAA,MAAA,UAAA,UAAA,SAAA,GAAA,SAAA;CACrC,MAAA,UAAQ,qBAAS;CAEjB,QAAM,SAAW;CACjB,MAAM,KAAA,MAAM,MAAiB,EAAA;CAE7B,MAAA,MAAA,OAAgB,OAAA;iBACR;EACN,MAAK,UAAI,IAAA;EACT,IAAI,CAAC,IAAA;EACL,IAAI,CAAC,SAAA;EACL,IAAA,CAAA,oBAAqB;QAAE,OAAA,QAAA;GAAI;GAAS;EACpC,CAAA;EACF,OAAG,OAAA,WAAA,IAAA;IAAC;EAAI;EAAoB;EAAS;EAAM;CAE3C,CAAA;SACK;EACH,GAAA;EACF,KAAA,aAAA,KAAA,MAAA,GAAA;CAEA;CAEJ,OAAA,sBAAA,KAAA;;;;;;;;;;;;;;;;;MAqBE,iBAAqB,WADH,SAAA,eACqB,OAAA;CACxC,OAAA,cAAA,SAAA,kBAAA,KAAA,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { a as CollectionStoreProps, r as CollectionStoreItem } from "../collection-store-CbwzYsWf.js";
|
|
2
|
+
import { ReactElement, ReactNode } from "react";
|
|
3
|
+
import { PickRequired } from "@ariakit/utils";
|
|
4
|
+
|
|
5
|
+
//#region src/collection/collection-provider.d.ts
|
|
6
|
+
/**
|
|
7
|
+
* Provides a collection store to
|
|
8
|
+
* [`CollectionItem`](https://ariakit.com/reference/collection-item) components.
|
|
9
|
+
* @see https://ariakit.com/components/collection
|
|
10
|
+
* @example
|
|
11
|
+
* ```jsx
|
|
12
|
+
* <CollectionProvider>
|
|
13
|
+
* <CollectionItem />
|
|
14
|
+
* <CollectionItem />
|
|
15
|
+
* <CollectionItem />
|
|
16
|
+
* </CollectionProvider>
|
|
17
|
+
* ```
|
|
18
|
+
*/
|
|
19
|
+
declare function CollectionProvider<T extends CollectionStoreItem = CollectionStoreItem>(props: PickRequired<CollectionProviderProps<T>, "items" | "defaultItems">): ReactElement;
|
|
20
|
+
declare function CollectionProvider(props?: CollectionProviderProps): ReactElement;
|
|
21
|
+
interface CollectionProviderProps<T extends CollectionStoreItem = CollectionStoreItem> extends CollectionStoreProps<T> {
|
|
22
|
+
children?: ReactNode;
|
|
23
|
+
}
|
|
24
|
+
//#endregion
|
|
25
|
+
export { CollectionProvider, CollectionProviderProps };
|
|
26
|
+
//# sourceMappingURL=collection-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collection-provider.d.ts","names":["PickRequired","ReactElement","ReactNode","CollectionStoreItem","CollectionStoreProps","CollectionProvider","T","CollectionProviderProps","props","children"],"sources":["../../src/collection/collection-provider.d.ts"],"mappings":";;;;;;;AAgBA;;;;;;;;;;;iBAAwBK,kBAAAA,WAA6BF,mBAAAA,GAAsBA,mBAAAA,CAAAA,CAAqBK,KAAAA,EAAOR,YAAAA,CAAaO,uBAAAA,CAAwBD,CAAAA,+BAAgCL,YAAAA;AAAAA,iBACpJI,kBAAAA,CAAmBG,KAAAA,GAAQD,uBAAAA,GAA0BN,YAAY;AAAA,UACxEM,uBAAAA,WAAkCJ,mBAAAA,GAAsBA,mBAAAA,UAA6BC,oBAAAA,CAAqBE,CAAAA;EACvHG,QAAAA,GAAWP,SAAAA;AAAAA"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { CollectionContextProvider } from "./collection-context.js";
|
|
3
|
+
import { useCollectionStore } from "./collection-store.js";
|
|
4
|
+
import { jsx } from "react/jsx-runtime";
|
|
5
|
+
//#region src/collection/collection-provider.tsx
|
|
6
|
+
function CollectionProvider(props = {}) {
|
|
7
|
+
return /* @__PURE__ */ jsx(CollectionContextProvider, {
|
|
8
|
+
value: useCollectionStore(props),
|
|
9
|
+
children: props.children
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
//#endregion
|
|
13
|
+
export { CollectionProvider };
|
|
14
|
+
|
|
15
|
+
//# sourceMappingURL=collection-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collection-provider.js","names":[],"sources":["../../src/collection/collection-provider.tsx"],"sourcesContent":["import type { PickRequired } from \"@ariakit/utils\";\nimport type { ReactElement, ReactNode } from \"react\";\nimport { CollectionContextProvider } from \"./collection-context.tsx\";\nimport type {\n CollectionStoreItem,\n CollectionStoreProps,\n} from \"./collection-store.ts\";\nimport { useCollectionStore } from \"./collection-store.ts\";\n\n/**\n * Provides a collection store to\n * [`CollectionItem`](https://ariakit.com/reference/collection-item) components.\n * @see https://ariakit.com/components/collection\n * @example\n * ```jsx\n * <CollectionProvider>\n * <CollectionItem />\n * <CollectionItem />\n * <CollectionItem />\n * </CollectionProvider>\n * ```\n */\n\nexport function CollectionProvider<\n T extends CollectionStoreItem = CollectionStoreItem,\n>(\n props: PickRequired<CollectionProviderProps<T>, \"items\" | \"defaultItems\">,\n): ReactElement;\n\nexport function CollectionProvider(\n props?: CollectionProviderProps,\n): ReactElement;\n\nexport function CollectionProvider(props: CollectionProviderProps = {}) {\n const store = useCollectionStore(props);\n return (\n <CollectionContextProvider value={store}>\n {props.children}\n </CollectionContextProvider>\n );\n}\n\nexport interface CollectionProviderProps<\n T extends CollectionStoreItem = CollectionStoreItem,\n> extends CollectionStoreProps<T> {\n children?: ReactNode;\n}\n"],"mappings":";;;;;SAoCI,mBAAC,QAAA,CAAA,GAAA;QAFW,oBAAmB,2BAEO;4BAC7B,KAAA;EACkB,UAAA,MAAA;CAE/B,CAAA"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { a as CollectionRendererItemProps, c as getCollectionRendererItem, i as CollectionRendererItemObject, l as getCollectionRendererItemId, n as CollectionRendererBaseItemProps, o as CollectionRendererOptions, r as CollectionRendererItem, s as CollectionRendererProps, t as CollectionRenderer, u as useCollectionRenderer } from "../collection-renderer-DsPD9ksD.js";
|
|
2
|
+
export { CollectionRenderer, CollectionRendererBaseItemProps, CollectionRendererItem, CollectionRendererItemObject, CollectionRendererItemProps, CollectionRendererOptions, CollectionRendererProps, getCollectionRendererItem, getCollectionRendererItemId, useCollectionRenderer };
|