@purpur/library 9.1.3 → 9.2.1
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/.lintstagedrc.mts +10 -0
- package/CHANGELOG.json +59 -0
- package/CHANGELOG.md +29 -1
- package/dist/LICENSE.txt +66 -8
- package/dist/{ThemeProvider-ipAIFRUi.js → ThemeProvider-5r7lDX-h.js} +2 -2
- package/dist/{ThemeProvider-ipAIFRUi.js.map → ThemeProvider-5r7lDX-h.js.map} +1 -1
- package/dist/{ThemeProvider-BR1hJQOD.mjs → ThemeProvider-bkyFCeo6.mjs} +3 -3
- package/dist/{ThemeProvider-BR1hJQOD.mjs.map → ThemeProvider-bkyFCeo6.mjs.map} +1 -1
- package/dist/accordion-OsA0HvdA.js +2 -0
- package/dist/{accordion-DX8efWOt.js.map → accordion-OsA0HvdA.js.map} +1 -1
- package/dist/{accordion-BKTz9DM6.mjs → accordion-OtFSShSB.mjs} +37 -37
- package/dist/{accordion-BKTz9DM6.mjs.map → accordion-OtFSShSB.mjs.map} +1 -1
- package/dist/accordion.cjs.js +1 -1
- package/dist/accordion.es.js +1 -1
- package/dist/arrow-left.es-CCWJyrcQ.js +2 -0
- package/dist/arrow-left.es-CCWJyrcQ.js.map +1 -0
- package/dist/arrow-left.es-DU-PX-Il.mjs +13 -0
- package/dist/arrow-left.es-DU-PX-Il.mjs.map +1 -0
- package/dist/{autocomplete-B8L-dTmF.mjs → autocomplete-BipmyKf0.mjs} +2 -2
- package/dist/{autocomplete-B8L-dTmF.mjs.map → autocomplete-BipmyKf0.mjs.map} +1 -1
- package/dist/{autocomplete-B421J7CS.js → autocomplete-D9uCJzjY.js} +2 -2
- package/dist/{autocomplete-B421J7CS.js.map → autocomplete-D9uCJzjY.js.map} +1 -1
- package/dist/autocomplete.cjs.js +1 -1
- package/dist/autocomplete.es.js +1 -1
- package/dist/button-4-yWOgtD.mjs +109 -0
- package/dist/{button-Cv7NlYbv.mjs.map → button-4-yWOgtD.mjs.map} +1 -1
- package/dist/button-DmybVApa.js +2 -0
- package/dist/{button-Dqxdc3nC.js.map → button-DmybVApa.js.map} +1 -1
- package/dist/button.cjs.js +1 -1
- package/dist/button.es.js +1 -1
- package/dist/{calendar-CoP1dGpQ.js → calendar-CBBV8n3x.js} +2 -2
- package/dist/{calendar-CoP1dGpQ.js.map → calendar-CBBV8n3x.js.map} +1 -1
- package/dist/{calendar-D_sZrR92.mjs → calendar-DEXw83mu.mjs} +2 -2
- package/dist/{calendar-D_sZrR92.mjs.map → calendar-DEXw83mu.mjs.map} +1 -1
- package/dist/calendar.cjs.js +1 -1
- package/dist/calendar.es.js +1 -1
- package/dist/card-CRHXm5NR.js +2 -0
- package/dist/{card-VMa3cGCP.js.map → card-CRHXm5NR.js.map} +1 -1
- package/dist/{card-CkZQZOz1.mjs → card-DR2hvxjZ.mjs} +75 -75
- package/dist/{card-CkZQZOz1.mjs.map → card-DR2hvxjZ.mjs.map} +1 -1
- package/dist/card.cjs.js +1 -1
- package/dist/card.es.js +1 -1
- package/dist/carousel-BCw-5u92.js +2 -0
- package/dist/carousel-BCw-5u92.js.map +1 -0
- package/dist/carousel-BkxojLwn.mjs +1633 -0
- package/dist/carousel-BkxojLwn.mjs.map +1 -0
- package/dist/carousel.cjs.js +2 -0
- package/dist/carousel.cjs.js.map +1 -0
- package/dist/carousel.es.js +5 -0
- package/dist/carousel.es.js.map +1 -0
- package/dist/{chat-field-yK-TwW0D.mjs → chat-field-CVF4DooY.mjs} +2 -2
- package/dist/{chat-field-yK-TwW0D.mjs.map → chat-field-CVF4DooY.mjs.map} +1 -1
- package/dist/{chat-field-CxOqk0-9.js → chat-field-Wjvh2J6C.js} +2 -2
- package/dist/{chat-field-CxOqk0-9.js.map → chat-field-Wjvh2J6C.js.map} +1 -1
- package/dist/chat-field.cjs.js +1 -1
- package/dist/chat-field.es.js +1 -1
- package/dist/comparison-table-B8w65g43.js +2 -0
- package/dist/comparison-table-B8w65g43.js.map +1 -0
- package/dist/comparison-table-D1zJpdLL.mjs +275 -0
- package/dist/comparison-table-D1zJpdLL.mjs.map +1 -0
- package/dist/comparison-table.cjs.js +2 -0
- package/dist/comparison-table.cjs.js.map +1 -0
- package/dist/comparison-table.es.js +5 -0
- package/dist/comparison-table.es.js.map +1 -0
- package/dist/components/carousel/src/carousel.d.ts +43 -0
- package/dist/components/carousel/src/carousel.d.ts.map +1 -0
- package/dist/components/carousel/src/components/PageIndicator.d.ts +12 -0
- package/dist/components/carousel/src/components/PageIndicator.d.ts.map +1 -0
- package/dist/components/carousel/src/hooks/useAutoplay.d.ts +8 -0
- package/dist/components/carousel/src/hooks/useAutoplay.d.ts.map +1 -0
- package/dist/components/carousel/src/hooks/usePageIndicators.d.ts +9 -0
- package/dist/components/carousel/src/hooks/usePageIndicators.d.ts.map +1 -0
- package/dist/components/carousel/src/hooks/usePrefersReducedMotion.d.ts +2 -0
- package/dist/components/carousel/src/hooks/usePrefersReducedMotion.d.ts.map +1 -0
- package/dist/components/carousel/src/hooks/usePrevNextButtons.d.ts +11 -0
- package/dist/components/carousel/src/hooks/usePrevNextButtons.d.ts.map +1 -0
- package/dist/components/comparison-table/src/comparison-table.d.ts +64 -0
- package/dist/components/comparison-table/src/comparison-table.d.ts.map +1 -0
- package/dist/components/comparison-table/src/components/Cell/cell.d.ts +7 -0
- package/dist/components/comparison-table/src/components/Cell/cell.d.ts.map +1 -0
- package/dist/components/comparison-table/src/components/LeadCell/lead-cell.d.ts +8 -0
- package/dist/components/comparison-table/src/components/LeadCell/lead-cell.d.ts.map +1 -0
- package/dist/components/comparison-table/src/components/OptionCard/option-card.d.ts +26 -0
- package/dist/components/comparison-table/src/components/OptionCard/option-card.d.ts.map +1 -0
- package/dist/components/comparison-table/src/components/ScrollProgress/scroll-progress.d.ts +11 -0
- package/dist/components/comparison-table/src/components/ScrollProgress/scroll-progress.d.ts.map +1 -0
- package/dist/components/content-block/src/content-block.d.ts +2 -2
- package/dist/components/content-block/src/content-block.d.ts.map +1 -1
- package/dist/components/dropdown/src/dropdown-combobox.d.ts +2 -1
- package/dist/components/dropdown/src/dropdown-combobox.d.ts.map +1 -1
- package/dist/components/dropdown/src/dropdown-select.d.ts +2 -1
- package/dist/components/dropdown/src/dropdown-select.d.ts.map +1 -1
- package/dist/components/dropdown/src/dropdown-shared.d.ts +12 -1
- package/dist/components/dropdown/src/dropdown-shared.d.ts.map +1 -1
- package/dist/components/dropdown/src/dropdown.d.ts +1 -1
- package/dist/components/dropdown/src/dropdown.d.ts.map +1 -1
- package/dist/components/dropdown/src/dropdown.types.d.ts +10 -5
- package/dist/components/dropdown/src/dropdown.types.d.ts.map +1 -1
- package/dist/components/dropdown/src/useDropdown.d.ts +1 -1
- package/dist/components/dropdown/src/useDropdown.d.ts.map +1 -1
- package/dist/components-metadata.js +18 -2
- package/dist/{content-block-Cd7xSE8t.js → content-block-CDRUH0pg.js} +2 -2
- package/dist/content-block-CDRUH0pg.js.map +1 -0
- package/dist/{content-block-BMOvlH7a.mjs → content-block-Dm3L4g8w.mjs} +2 -2
- package/dist/content-block-Dm3L4g8w.mjs.map +1 -0
- package/dist/content-block.cjs.js +1 -1
- package/dist/content-block.es.js +1 -1
- package/dist/{cta-link-BHU6irMG.js → cta-link-B1qMjH76.js} +2 -2
- package/dist/{cta-link-BHU6irMG.js.map → cta-link-B1qMjH76.js.map} +1 -1
- package/dist/{cta-link-B_FfwflB.mjs → cta-link-pwva2f2r.mjs} +43 -43
- package/dist/{cta-link-B_FfwflB.mjs.map → cta-link-pwva2f2r.mjs.map} +1 -1
- package/dist/cta-link.cjs.js +1 -1
- package/dist/cta-link.es.js +1 -1
- package/dist/{date-field-B7ipm5sH.js → date-field-BJaomFjs.js} +2 -2
- package/dist/{date-field-B7ipm5sH.js.map → date-field-BJaomFjs.js.map} +1 -1
- package/dist/{date-field-4tYMPw89.mjs → date-field-D3rTtf9Y.mjs} +2 -2
- package/dist/{date-field-4tYMPw89.mjs.map → date-field-D3rTtf9Y.mjs.map} +1 -1
- package/dist/date-field.cjs.js +1 -1
- package/dist/date-field.es.js +1 -1
- package/dist/{date-picker-D7EisjDG.mjs → date-picker-CpDZ0gK9.mjs} +4 -4
- package/dist/{date-picker-D7EisjDG.mjs.map → date-picker-CpDZ0gK9.mjs.map} +1 -1
- package/dist/{date-picker-BWW4xzyc.js → date-picker-D3uJGCjl.js} +2 -2
- package/dist/{date-picker-BWW4xzyc.js.map → date-picker-D3uJGCjl.js.map} +1 -1
- package/dist/date-picker.cjs.js +1 -1
- package/dist/date-picker.es.js +1 -1
- package/dist/{drawer-Vi9H2O3N.mjs → drawer-BJ8xwriz.mjs} +2 -2
- package/dist/{drawer-Vi9H2O3N.mjs.map → drawer-BJ8xwriz.mjs.map} +1 -1
- package/dist/{drawer-UdK-u7IX.js → drawer-CNs9K8Ca.js} +2 -2
- package/dist/{drawer-UdK-u7IX.js.map → drawer-CNs9K8Ca.js.map} +1 -1
- package/dist/drawer.cjs.js +1 -1
- package/dist/drawer.es.js +1 -1
- package/dist/dropdown-BsqVnd7z.js +2 -0
- package/dist/dropdown-BsqVnd7z.js.map +1 -0
- package/dist/dropdown-TO3Mh0bk.mjs +910 -0
- package/dist/dropdown-TO3Mh0bk.mjs.map +1 -0
- package/dist/dropdown.cjs.js +1 -1
- package/dist/dropdown.es.js +1 -1
- package/dist/{footer-cH07Xqil.mjs → footer-BXs8uzTA.mjs} +4 -4
- package/dist/{footer-cH07Xqil.mjs.map → footer-BXs8uzTA.mjs.map} +1 -1
- package/dist/{footer-BL0ewBZT.js → footer-DF9adlni.js} +2 -2
- package/dist/{footer-BL0ewBZT.js.map → footer-DF9adlni.js.map} +1 -1
- package/dist/footer.cjs.js +1 -1
- package/dist/footer.es.js +1 -1
- package/dist/{hero-banner-yGRM4OlS.js → hero-banner-BfxclVFT.js} +2 -2
- package/dist/{hero-banner-yGRM4OlS.js.map → hero-banner-BfxclVFT.js.map} +1 -1
- package/dist/{hero-banner-BjwICxaJ.mjs → hero-banner-CxPvhXD2.mjs} +3 -3
- package/dist/{hero-banner-BjwICxaJ.mjs.map → hero-banner-CxPvhXD2.mjs.map} +1 -1
- package/dist/hero-banner.cjs.js +1 -1
- package/dist/hero-banner.es.js +1 -1
- package/dist/libraries/library/src/carousel.d.ts +6 -0
- package/dist/libraries/library/src/carousel.d.ts.map +1 -0
- package/dist/libraries/library/src/comparison-table.d.ts +6 -0
- package/dist/libraries/library/src/comparison-table.d.ts.map +1 -0
- package/dist/libraries/library/src/library.d.ts +2 -0
- package/dist/libraries/library/src/library.d.ts.map +1 -1
- package/dist/library.cjs.js +1 -1
- package/dist/library.es.js +609 -605
- package/dist/library.es.js.map +1 -1
- package/dist/minus.es-BK9qA9iJ.mjs +13 -0
- package/dist/minus.es-BK9qA9iJ.mjs.map +1 -0
- package/dist/minus.es-DtXArdKK.js +2 -0
- package/dist/minus.es-DtXArdKK.js.map +1 -0
- package/dist/{modal-fTWvPEPW.mjs → modal-DCfN6q8I.mjs} +28 -28
- package/dist/modal-DCfN6q8I.mjs.map +1 -0
- package/dist/{modal-DMeRO1wE.js → modal-DZIdw9xy.js} +2 -2
- package/dist/modal-DZIdw9xy.js.map +1 -0
- package/dist/modal.cjs.js +1 -1
- package/dist/modal.es.js +1 -1
- package/dist/{notification-DE1pvk9W.js → notification-BqjaT4E7.js} +2 -2
- package/dist/{notification-DE1pvk9W.js.map → notification-BqjaT4E7.js.map} +1 -1
- package/dist/{notification-BvoL7BIW.mjs → notification-DdRS5BF2.mjs} +2 -2
- package/dist/{notification-BvoL7BIW.mjs.map → notification-DdRS5BF2.mjs.map} +1 -1
- package/dist/{notification-banner-C4gkkSlf.mjs → notification-banner-BOclxqFu.mjs} +2 -2
- package/dist/{notification-banner-C4gkkSlf.mjs.map → notification-banner-BOclxqFu.mjs.map} +1 -1
- package/dist/{notification-banner-COH7wJu2.js → notification-banner-jY8rQH2M.js} +2 -2
- package/dist/{notification-banner-COH7wJu2.js.map → notification-banner-jY8rQH2M.js.map} +1 -1
- package/dist/notification-banner.cjs.js +1 -1
- package/dist/notification-banner.es.js +1 -1
- package/dist/notification.cjs.js +1 -1
- package/dist/notification.es.js +1 -1
- package/dist/pagination-Bwlkvqye.js +2 -0
- package/dist/pagination-Bwlkvqye.js.map +1 -0
- package/dist/{pagination-BdCjh1Pi.mjs → pagination-CVYUacXN.mjs} +235 -242
- package/dist/pagination-CVYUacXN.mjs.map +1 -0
- package/dist/pagination.cjs.js +1 -1
- package/dist/pagination.es.js +1 -1
- package/dist/{popover-lxTyKALA.mjs → popover-Dwqs1wGH.mjs} +2 -2
- package/dist/{popover-lxTyKALA.mjs.map → popover-Dwqs1wGH.mjs.map} +1 -1
- package/dist/{popover-BnUVNqSi.js → popover-XCUa2GfC.js} +2 -2
- package/dist/{popover-BnUVNqSi.js.map → popover-XCUa2GfC.js.map} +1 -1
- package/dist/popover.cjs.js +1 -1
- package/dist/popover.es.js +1 -1
- package/dist/{product-card-BU1ThhCx.mjs → product-card-BfB82XpS.mjs} +2 -2
- package/dist/{product-card-BU1ThhCx.mjs.map → product-card-BfB82XpS.mjs.map} +1 -1
- package/dist/{product-card-CNBegEBW.js → product-card-bVQ7JhHj.js} +2 -2
- package/dist/{product-card-CNBegEBW.js.map → product-card-bVQ7JhHj.js.map} +1 -1
- package/dist/product-card.cjs.js +1 -1
- package/dist/product-card.es.js +1 -1
- package/dist/{promotion-card-_bPyVr9t.mjs → promotion-card-BhNw94sC.mjs} +4 -4
- package/dist/{promotion-card-_bPyVr9t.mjs.map → promotion-card-BhNw94sC.mjs.map} +1 -1
- package/dist/{promotion-card-CXNhskRl.js → promotion-card-DqBBt2sz.js} +2 -2
- package/dist/{promotion-card-CXNhskRl.js.map → promotion-card-DqBBt2sz.js.map} +1 -1
- package/dist/promotion-card.cjs.js +1 -1
- package/dist/promotion-card.es.js +1 -1
- package/dist/purpur.css +1 -1
- package/dist/quantity-selector-8AkKNDik.js +2 -0
- package/dist/quantity-selector-8AkKNDik.js.map +1 -0
- package/dist/{quantity-selector-CGhJ2DjO.mjs → quantity-selector-C23kU1hF.mjs} +73 -79
- package/dist/quantity-selector-C23kU1hF.mjs.map +1 -0
- package/dist/quantity-selector.cjs.js +1 -1
- package/dist/quantity-selector.es.js +1 -1
- package/dist/scss/action.scss +1 -0
- package/dist/{search-field-DTuEiK-M.mjs → search-field-CMBDkydb.mjs} +3 -3
- package/dist/{search-field-DTuEiK-M.mjs.map → search-field-CMBDkydb.mjs.map} +1 -1
- package/dist/{search-field-Bst9d-wX.js → search-field-CU_tsmHb.js} +2 -2
- package/dist/{search-field-Bst9d-wX.js.map → search-field-CU_tsmHb.js.map} +1 -1
- package/dist/search-field.cjs.js +1 -1
- package/dist/search-field.es.js +1 -1
- package/dist/{stepper-k0bX9m4t.mjs → stepper-uBfDdIju.mjs} +3 -3
- package/dist/{stepper-k0bX9m4t.mjs.map → stepper-uBfDdIju.mjs.map} +1 -1
- package/dist/{stepper-ClLQuoXr.js → stepper-w-raIwqJ.js} +2 -2
- package/dist/{stepper-ClLQuoXr.js.map → stepper-w-raIwqJ.js.map} +1 -1
- package/dist/stepper.cjs.js +1 -1
- package/dist/stepper.es.js +1 -1
- package/dist/{table-Ddv6BKo9.js → table-BVSBvTYG.js} +2 -2
- package/dist/{table-Ddv6BKo9.js.map → table-BVSBvTYG.js.map} +1 -1
- package/dist/{table-D_XW4smf.mjs → table-CuV3Gda_.mjs} +6 -6
- package/dist/{table-D_XW4smf.mjs.map → table-CuV3Gda_.mjs.map} +1 -1
- package/dist/table.cjs.js +1 -1
- package/dist/table.es.js +1 -1
- package/dist/{text-area-9ggiIWtJ.js → text-area-C6W0fDiQ.js} +2 -2
- package/dist/{text-area-9ggiIWtJ.js.map → text-area-C6W0fDiQ.js.map} +1 -1
- package/dist/{text-area-CpYWt99s.mjs → text-area-DDZ_GQPW.mjs} +3 -3
- package/dist/{text-area-CpYWt99s.mjs.map → text-area-DDZ_GQPW.mjs.map} +1 -1
- package/dist/text-area.cjs.js +1 -1
- package/dist/text-area.es.js +1 -1
- package/dist/{text-field-BQYzwIrG.mjs → text-field-BQfxJobW.mjs} +2 -2
- package/dist/{text-field-BQYzwIrG.mjs.map → text-field-BQfxJobW.mjs.map} +1 -1
- package/dist/{text-field-BwxGMWds.js → text-field-CYJzQG3h.js} +2 -2
- package/dist/{text-field-BwxGMWds.js.map → text-field-CYJzQG3h.js.map} +1 -1
- package/dist/text-field.cjs.js +1 -1
- package/dist/text-field.es.js +1 -1
- package/dist/theme.cjs.js +1 -1
- package/dist/theme.es.js +2 -2
- package/dist/tokens/color/variables.css +12 -12
- package/dist/tokens/color/variables.dark.css +13 -13
- package/dist/tokens/color/variables.dark.js +13 -13
- package/dist/tokens/color/variables.dark.json +13 -13
- package/dist/tokens/color/variables.dark.scss +13 -13
- package/dist/tokens/color/variables.js +12 -12
- package/dist/tokens/color/variables.json +12 -12
- package/dist/tokens/color/variables.scss +12 -12
- package/dist/tokens/gradient/variables.dark.js +4 -4
- package/dist/tokens/gradient/variables.dark.json +4 -4
- package/dist/tokens/gradient/variables.dark.scss +4 -4
- package/dist/tokens/gradient/variables.js +4 -4
- package/dist/tokens/gradient/variables.json +4 -4
- package/dist/tokens/gradient/variables.scss +4 -4
- package/dist/tokens.cjs.js +1 -1
- package/dist/tokens.cjs.js.map +1 -1
- package/dist/tokens.es.js +41 -41
- package/dist/tokens.es.js.map +1 -1
- package/dist/{tooltip-BatXMflw.js → tooltip-0pLBlDG3.js} +2 -2
- package/dist/{tooltip-BatXMflw.js.map → tooltip-0pLBlDG3.js.map} +1 -1
- package/dist/{tooltip-CZzwHkea.mjs → tooltip-Kom0VfOC.mjs} +2 -2
- package/dist/{tooltip-CZzwHkea.mjs.map → tooltip-Kom0VfOC.mjs.map} +1 -1
- package/dist/tooltip.cjs.js +1 -1
- package/dist/tooltip.es.js +1 -1
- package/dist/useColorScheme-0GMDl2GF.js +2 -0
- package/dist/{useColorScheme-DNNu9bz0.js.map → useColorScheme-0GMDl2GF.js.map} +1 -1
- package/dist/{useColorScheme-9rgSgG0N.mjs → useColorScheme-Di_Q0JR4.mjs} +2 -2
- package/dist/{useColorScheme-9rgSgG0N.mjs.map → useColorScheme-Di_Q0JR4.mjs.map} +1 -1
- package/dist/{variables-BVgnpUH9.mjs → variables-CKp4o9Tn.mjs} +2 -2
- package/dist/{variables-BVgnpUH9.mjs.map → variables-CKp4o9Tn.mjs.map} +1 -1
- package/dist/{variables-CMzMXeor.js → variables-DH61hVNE.js} +2 -2
- package/dist/{variables-CMzMXeor.js.map → variables-DH61hVNE.js.map} +1 -1
- package/package.json +42 -40
- package/src/aliases.ts +11 -0
- package/src/carousel.ts +6 -0
- package/src/comparison-table.ts +6 -0
- package/src/entries.js +2 -0
- package/src/library.ts +4 -0
- package/tokens/color/variables.css +12 -12
- package/tokens/color/variables.dark.css +13 -13
- package/tokens/color/variables.dark.js +13 -13
- package/tokens/color/variables.dark.json +13 -13
- package/tokens/color/variables.dark.scss +13 -13
- package/tokens/color/variables.js +12 -12
- package/tokens/color/variables.json +12 -12
- package/tokens/color/variables.scss +12 -12
- package/tokens/gradient/variables.dark.js +4 -4
- package/tokens/gradient/variables.dark.json +4 -4
- package/tokens/gradient/variables.dark.scss +4 -4
- package/tokens/gradient/variables.js +4 -4
- package/tokens/gradient/variables.json +4 -4
- package/tokens/gradient/variables.scss +4 -4
- package/dist/accordion-DX8efWOt.js +0 -2
- package/dist/button-Cv7NlYbv.mjs +0 -109
- package/dist/button-Dqxdc3nC.js +0 -2
- package/dist/card-VMa3cGCP.js +0 -2
- package/dist/content-block-BMOvlH7a.mjs.map +0 -1
- package/dist/content-block-Cd7xSE8t.js.map +0 -1
- package/dist/dropdown-BQOY21kI.js +0 -2
- package/dist/dropdown-BQOY21kI.js.map +0 -1
- package/dist/dropdown-CBYTBaMW.mjs +0 -779
- package/dist/dropdown-CBYTBaMW.mjs.map +0 -1
- package/dist/modal-DMeRO1wE.js.map +0 -1
- package/dist/modal-fTWvPEPW.mjs.map +0 -1
- package/dist/pagination-BdCjh1Pi.mjs.map +0 -1
- package/dist/pagination-C2A8NPol.js +0 -2
- package/dist/pagination-C2A8NPol.js.map +0 -1
- package/dist/quantity-selector-BV7QwVlT.js +0 -2
- package/dist/quantity-selector-BV7QwVlT.js.map +0 -1
- package/dist/quantity-selector-CGhJ2DjO.mjs.map +0 -1
- package/dist/useColorScheme-DNNu9bz0.js +0 -2
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
$purpur-gradient-ai-text-interactive-primary: linear-gradient(289deg, #62b2e7 -13%, #
|
|
1
|
+
$purpur-gradient-ai-text-interactive-primary: linear-gradient(289deg, #62b2e7 -13%, #f4e0ff 58%);
|
|
2
2
|
$purpur-gradient-ai-text-interactive-primary-negative: linear-gradient(
|
|
3
3
|
289deg,
|
|
4
4
|
#3694d3 -13%,
|
|
5
|
-
#
|
|
5
|
+
#6d02a3 58%
|
|
6
6
|
);
|
|
7
7
|
$purpur-gradient-ai-background-interactive-expressive: linear-gradient(
|
|
8
8
|
291deg,
|
|
@@ -28,9 +28,9 @@ $purpur-gradient-ai-background-interactive-primary-negative: linear-gradient(
|
|
|
28
28
|
#3694d3
|
|
29
29
|
);
|
|
30
30
|
$purpur-gradient-ai-background-primary-negative: linear-gradient(291deg, #b12df4, #ffffff, #3694d3);
|
|
31
|
-
$purpur-gradient-ai-border-interactive-primary: linear-gradient(289deg, #62b2e7 -13%, #
|
|
31
|
+
$purpur-gradient-ai-border-interactive-primary: linear-gradient(289deg, #62b2e7 -13%, #f4e0ff 58%);
|
|
32
32
|
$purpur-gradient-ai-border-interactive-primary-negative: linear-gradient(
|
|
33
33
|
289deg,
|
|
34
34
|
#3694d3 -13%,
|
|
35
|
-
#
|
|
35
|
+
#6d02a3 58%
|
|
36
36
|
);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export const purpurGradientAiTextInteractivePrimary =
|
|
2
|
-
"linear-gradient(289deg, #3694d3 -13%, #
|
|
2
|
+
"linear-gradient(289deg, #3694d3 -13%, #6d02a3 58%)";
|
|
3
3
|
export const purpurGradientAiTextInteractivePrimaryNegative =
|
|
4
|
-
"linear-gradient(289deg, #62b2e7 -13%, #
|
|
4
|
+
"linear-gradient(289deg, #62b2e7 -13%, #f4e0ff 58%)";
|
|
5
5
|
export const purpurGradientAiBackgroundInteractiveExpressive =
|
|
6
6
|
"linear-gradient(291deg, #3694d3 -15%, #990ae3 44%)";
|
|
7
7
|
export const purpurGradientAiBackgroundInteractiveExpressiveNegative =
|
|
@@ -13,6 +13,6 @@ export const purpurGradientAiBackgroundInteractivePrimaryNegative =
|
|
|
13
13
|
export const purpurGradientAiBackgroundPrimaryNegative =
|
|
14
14
|
"linear-gradient(352deg, #62b2e7 -69%, #1f002e 15%, #1f002e 87%, #d58df9 183%)";
|
|
15
15
|
export const purpurGradientAiBorderInteractivePrimary =
|
|
16
|
-
"linear-gradient(289deg, #3694d3 -13%, #
|
|
16
|
+
"linear-gradient(289deg, #3694d3 -13%, #6d02a3 58%)";
|
|
17
17
|
export const purpurGradientAiBorderInteractivePrimaryNegative =
|
|
18
|
-
"linear-gradient(289deg, #62b2e7 -13%, #
|
|
18
|
+
"linear-gradient(289deg, #62b2e7 -13%, #f4e0ff 58%)";
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
"ai": {
|
|
4
4
|
"text": {
|
|
5
5
|
"interactive": {
|
|
6
|
-
"primary": "linear-gradient(289deg, #3694d3 -13%, #
|
|
7
|
-
"primary-negative": "linear-gradient(289deg, #62b2e7 -13%, #
|
|
6
|
+
"primary": "linear-gradient(289deg, #3694d3 -13%, #6d02a3 58%)",
|
|
7
|
+
"primary-negative": "linear-gradient(289deg, #62b2e7 -13%, #f4e0ff 58%)"
|
|
8
8
|
}
|
|
9
9
|
},
|
|
10
10
|
"background": {
|
|
@@ -18,8 +18,8 @@
|
|
|
18
18
|
},
|
|
19
19
|
"border": {
|
|
20
20
|
"interactive": {
|
|
21
|
-
"primary": "linear-gradient(289deg, #3694d3 -13%, #
|
|
22
|
-
"primary-negative": "linear-gradient(289deg, #62b2e7 -13%, #
|
|
21
|
+
"primary": "linear-gradient(289deg, #3694d3 -13%, #6d02a3 58%)",
|
|
22
|
+
"primary-negative": "linear-gradient(289deg, #62b2e7 -13%, #f4e0ff 58%)"
|
|
23
23
|
}
|
|
24
24
|
}
|
|
25
25
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
$purpur-gradient-ai-text-interactive-primary: linear-gradient(289deg, #3694d3 -13%, #
|
|
1
|
+
$purpur-gradient-ai-text-interactive-primary: linear-gradient(289deg, #3694d3 -13%, #6d02a3 58%);
|
|
2
2
|
$purpur-gradient-ai-text-interactive-primary-negative: linear-gradient(
|
|
3
3
|
289deg,
|
|
4
4
|
#62b2e7 -13%,
|
|
5
|
-
#
|
|
5
|
+
#f4e0ff 58%
|
|
6
6
|
);
|
|
7
7
|
$purpur-gradient-ai-background-interactive-expressive: linear-gradient(
|
|
8
8
|
291deg,
|
|
@@ -34,9 +34,9 @@ $purpur-gradient-ai-background-primary-negative: linear-gradient(
|
|
|
34
34
|
#1f002e 87%,
|
|
35
35
|
#d58df9 183%
|
|
36
36
|
);
|
|
37
|
-
$purpur-gradient-ai-border-interactive-primary: linear-gradient(289deg, #3694d3 -13%, #
|
|
37
|
+
$purpur-gradient-ai-border-interactive-primary: linear-gradient(289deg, #3694d3 -13%, #6d02a3 58%);
|
|
38
38
|
$purpur-gradient-ai-border-interactive-primary-negative: linear-gradient(
|
|
39
39
|
289deg,
|
|
40
40
|
#62b2e7 -13%,
|
|
41
|
-
#
|
|
41
|
+
#f4e0ff 58%
|
|
42
42
|
);
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";const r=require("react/jsx-runtime"),p=require("react"),$=require("./heading-drD5ugCC.js"),j=require("./bind-DeUYJ6m9.js"),f=require("./chevron-down.es-BMjgiS3F.js"),q=require("./paragraph-BsI53OR0.js"),C={"purpur-accordion":"_purpur-accordion_mwmy0_1","purpur-accordion__title":"_purpur-accordion__title_mwmy0_4","purpur-accordion--negative":"_purpur-accordion--negative_mwmy0_13"},A={"purpur-accordion-item":"_purpur-accordion-item_1du2l_1","purpur-accordion-item__trigger":"_purpur-accordion-item__trigger_1du2l_4","purpur-accordion-item__header":"_purpur-accordion-item__header_1du2l_10","purpur-accordion-item__trigger__icon":"_purpur-accordion-item__trigger__icon_1du2l_43","purpur-accordion-item__title":"_purpur-accordion-item__title_1du2l_49","purpur-accordion-item__icon":"_purpur-accordion-item__icon_1du2l_50","purpur-accordion-item__rotate":"_purpur-accordion-item__rotate_1du2l_64","purpur-accordion-item__content":"_purpur-accordion-item__content_1du2l_67","purpur-accordion-item__contentText":"_purpur-accordion-item__contentText_1du2l_82","purpur-accordion-item__contentText--limit-width":"_purpur-accordion-item__contentText--limit-width_1du2l_85","purpur-accordion-item--negative":"_purpur-accordion-item--negative_1du2l_107"},i=j.c.bind(A),t="purpur-accordion-item",H=({children:o,className:c,fullWidth:a=!1,title:_,titleTag:l="h3",initialOpen:m=!1,onClick:n,onOpen:u,onClose:d,...y})=>{const N=p.useContext(x),s=p.useId(),[e,b]=p.useState(!m),w=i([t,{[`${t}--negative`]:N},c]);return r.jsxs("div",{className:w,...y,children:[r.jsx($.Heading,{tag:l,variant:"title-100",className:i([`${t}__header`,`${t}__title`]),children:r.jsxs("button",{type:"button","data-state":e?"open":"close",onClick:T=>{n&&n(T),e?u&&u():d&&d(),b(!e)},className:i(`${t}__trigger`,c,{[`${t}__rotate`]:!e}),"aria-expanded":!e,"aria-controls":s,id:s+"button",children:[_,r.jsx(f.l,{size:"md",className:i(`${t}__icon`),"aria-hidden":!0})]})}),r.jsx("div",{className:i(`${t}__content`,c),"aria-hidden":e,id:s,"aria-labelledby":s+"button",role:"region",children:r.jsx("div",{className:i(`${t}__contentText`,{[`${t}__contentText--limit-width`]:!a}),children:typeof o=="string"?r.jsx(q.Paragraph,{variant:"paragraph-200",children:o}):o})})]})},v=j.c.bind(C),g="purpur-accordion",x=p.createContext(!1),h=({children:o,className:c,negative:a=!1,title:_,titleTag:l="h2",titleVariant:m="title-300",schema:n,...u})=>{const d=v([g,{[`${g}--negative`]:a},c]);return r.jsxs("div",{className:d,...u,children:[_&&r.jsx($.Heading,{tag:l,variant:m,className:v(`${g}__title`),children:_}),r.jsx(x.Provider,{value:a,children:o}),n&&r.jsx("script",{type:"application/ld+json",dangerouslySetInnerHTML:{__html:n}})]})};h.Item=H;h.displayName="Accordion";exports.Accordion=h;exports.NegativeContext=x;
|
|
2
|
-
//# sourceMappingURL=accordion-DX8efWOt.js.map
|
package/dist/button-Cv7NlYbv.mjs
DELETED
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
import { jsxs as g, jsx as f } from "react/jsx-runtime";
|
|
2
|
-
import { forwardRef as T } from "react";
|
|
3
|
-
import { a as R } from "./spinner-DRQN6YdK.mjs";
|
|
4
|
-
import { c as $ } from "./bind-CU-R61T-.mjs";
|
|
5
|
-
const E = {
|
|
6
|
-
PRIMARY: "primary",
|
|
7
|
-
SECONDARY: "secondary",
|
|
8
|
-
EXPRESSIVE: "expressive"
|
|
9
|
-
}, N = {
|
|
10
|
-
LG: "lg"
|
|
11
|
-
}, A = {
|
|
12
|
-
"purpur-button": "_purpur-button_zehbw_1",
|
|
13
|
-
"purpur-button--xs": "_purpur-button--xs_zehbw_22",
|
|
14
|
-
"purpur-button--icon-only": "_purpur-button--icon-only_zehbw_25",
|
|
15
|
-
"purpur-button--sm": "_purpur-button--sm_zehbw_28",
|
|
16
|
-
"purpur-button--md": "_purpur-button--md_zehbw_34",
|
|
17
|
-
"purpur-button--lg": "_purpur-button--lg_zehbw_40",
|
|
18
|
-
"purpur-button--full-width": "_purpur-button--full-width_zehbw_46",
|
|
19
|
-
"purpur-button--primary": "_purpur-button--primary_zehbw_64",
|
|
20
|
-
"purpur-button--disabled": "_purpur-button--disabled_zehbw_68",
|
|
21
|
-
"purpur-button--primary-negative": "_purpur-button--primary-negative_zehbw_74",
|
|
22
|
-
"purpur-button--secondary": "_purpur-button--secondary_zehbw_86",
|
|
23
|
-
"purpur-button--secondary-negative": "_purpur-button--secondary-negative_zehbw_97",
|
|
24
|
-
"purpur-button--expressive": "_purpur-button--expressive_zehbw_108",
|
|
25
|
-
"purpur-button--expressive-negative": "_purpur-button--expressive-negative_zehbw_118",
|
|
26
|
-
"purpur-button--negative": "_purpur-button--negative_zehbw_130",
|
|
27
|
-
"purpur-button--destructive": "_purpur-button--destructive_zehbw_137",
|
|
28
|
-
"purpur-button--destructive-negative": "_purpur-button--destructive-negative_zehbw_147",
|
|
29
|
-
"purpur-button--tertiary-purple": "_purpur-button--tertiary-purple_zehbw_157",
|
|
30
|
-
"purpur-button--tertiary-purple-negative": "_purpur-button--tertiary-purple-negative_zehbw_170",
|
|
31
|
-
"purpur-button--text": "_purpur-button--text_zehbw_185",
|
|
32
|
-
"purpur-button--text-negative": "_purpur-button--text-negative_zehbw_207",
|
|
33
|
-
"purpur-button--primary-ai": "_purpur-button--primary-ai_zehbw_230",
|
|
34
|
-
"purpur-button--primary-ai-negative": "_purpur-button--primary-ai-negative_zehbw_276",
|
|
35
|
-
"purpur-button--secondary-ai": "_purpur-button--secondary-ai_zehbw_323",
|
|
36
|
-
"purpur-button__spinner": "_purpur-button__spinner_zehbw_348",
|
|
37
|
-
"purpur-button--secondary-ai-negative": "_purpur-button--secondary-ai-negative_zehbw_416",
|
|
38
|
-
"purpur-button--expressive-ai": "_purpur-button--expressive-ai_zehbw_509",
|
|
39
|
-
"purpur-button--expressive-ai-negative": "_purpur-button--expressive-ai-negative_zehbw_556",
|
|
40
|
-
"purpur-button--text-ai": "_purpur-button--text-ai_zehbw_606",
|
|
41
|
-
"purpur-button--text-ai-negative": "_purpur-button--text-ai-negative_zehbw_679"
|
|
42
|
-
}, C = {
|
|
43
|
-
...E,
|
|
44
|
-
DESTRUCTIVE: "destructive",
|
|
45
|
-
TERTIARY_PURPLE: "tertiary-purple",
|
|
46
|
-
TEXT: "text"
|
|
47
|
-
}, Y = Object.values(C), c = $.bind(A), t = "purpur-button", j = ["button", "submit", "reset"], I = ({ iconOnly: r, loading: e }) => !(r && e), S = T(
|
|
48
|
-
({
|
|
49
|
-
ai: r = !1,
|
|
50
|
-
children: e,
|
|
51
|
-
className: v,
|
|
52
|
-
disabled: p = !1,
|
|
53
|
-
fullWidth: h = !1,
|
|
54
|
-
iconOnly: n,
|
|
55
|
-
loading: u = !1,
|
|
56
|
-
negative: o = !1,
|
|
57
|
-
onClick: b,
|
|
58
|
-
size: _ = "md",
|
|
59
|
-
variant: a,
|
|
60
|
-
type: d = "button",
|
|
61
|
-
...i
|
|
62
|
-
}, w) => {
|
|
63
|
-
if (n && a === "destructive")
|
|
64
|
-
return null;
|
|
65
|
-
const z = `${a}${r ? "-ai" : ""}${o ? "-negative" : ""}`, m = c(
|
|
66
|
-
[t, `${t}--${z}`, `${t}--${_}`],
|
|
67
|
-
{
|
|
68
|
-
[`${t}--icon-only`]: n,
|
|
69
|
-
[`${t}--negative`]: o,
|
|
70
|
-
[`${t}--full-width`]: h,
|
|
71
|
-
[`${t}--disabled`]: p || u
|
|
72
|
-
},
|
|
73
|
-
v
|
|
74
|
-
), x = (l) => {
|
|
75
|
-
p || u ? l.preventDefault() : b && b(l);
|
|
76
|
-
}, s = !!i["aria-disabled"] || p || u, y = I({ iconOnly: n, loading: u });
|
|
77
|
-
return /* @__PURE__ */ g(
|
|
78
|
-
"button",
|
|
79
|
-
{
|
|
80
|
-
className: m,
|
|
81
|
-
type: d,
|
|
82
|
-
ref: w,
|
|
83
|
-
"aria-disabled": s,
|
|
84
|
-
onClick: x,
|
|
85
|
-
...i,
|
|
86
|
-
children: [
|
|
87
|
-
u && /* @__PURE__ */ f(
|
|
88
|
-
R,
|
|
89
|
-
{
|
|
90
|
-
size: _ === N.LG ? "xs" : "xxs",
|
|
91
|
-
negative: o,
|
|
92
|
-
disabled: s,
|
|
93
|
-
className: c(`${t}__spinner`)
|
|
94
|
-
}
|
|
95
|
-
),
|
|
96
|
-
y ? e : null
|
|
97
|
-
]
|
|
98
|
-
}
|
|
99
|
-
);
|
|
100
|
-
}
|
|
101
|
-
);
|
|
102
|
-
S.displayName = "Button";
|
|
103
|
-
export {
|
|
104
|
-
j as B,
|
|
105
|
-
C as a,
|
|
106
|
-
S as b,
|
|
107
|
-
Y as c
|
|
108
|
-
};
|
|
109
|
-
//# sourceMappingURL=button-Cv7NlYbv.mjs.map
|
package/dist/button-Dqxdc3nC.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";const l=require("react/jsx-runtime"),f=require("react"),E=require("./spinner-tKunS_o-.js"),N=require("./bind-DeUYJ6m9.js"),$={PRIMARY:"primary",SECONDARY:"secondary",EXPRESSIVE:"expressive"},A={LG:"lg"},B={"purpur-button":"_purpur-button_zehbw_1","purpur-button--xs":"_purpur-button--xs_zehbw_22","purpur-button--icon-only":"_purpur-button--icon-only_zehbw_25","purpur-button--sm":"_purpur-button--sm_zehbw_28","purpur-button--md":"_purpur-button--md_zehbw_34","purpur-button--lg":"_purpur-button--lg_zehbw_40","purpur-button--full-width":"_purpur-button--full-width_zehbw_46","purpur-button--primary":"_purpur-button--primary_zehbw_64","purpur-button--disabled":"_purpur-button--disabled_zehbw_68","purpur-button--primary-negative":"_purpur-button--primary-negative_zehbw_74","purpur-button--secondary":"_purpur-button--secondary_zehbw_86","purpur-button--secondary-negative":"_purpur-button--secondary-negative_zehbw_97","purpur-button--expressive":"_purpur-button--expressive_zehbw_108","purpur-button--expressive-negative":"_purpur-button--expressive-negative_zehbw_118","purpur-button--negative":"_purpur-button--negative_zehbw_130","purpur-button--destructive":"_purpur-button--destructive_zehbw_137","purpur-button--destructive-negative":"_purpur-button--destructive-negative_zehbw_147","purpur-button--tertiary-purple":"_purpur-button--tertiary-purple_zehbw_157","purpur-button--tertiary-purple-negative":"_purpur-button--tertiary-purple-negative_zehbw_170","purpur-button--text":"_purpur-button--text_zehbw_185","purpur-button--text-negative":"_purpur-button--text-negative_zehbw_207","purpur-button--primary-ai":"_purpur-button--primary-ai_zehbw_230","purpur-button--primary-ai-negative":"_purpur-button--primary-ai-negative_zehbw_276","purpur-button--secondary-ai":"_purpur-button--secondary-ai_zehbw_323","purpur-button__spinner":"_purpur-button__spinner_zehbw_348","purpur-button--secondary-ai-negative":"_purpur-button--secondary-ai-negative_zehbw_416","purpur-button--expressive-ai":"_purpur-button--expressive-ai_zehbw_509","purpur-button--expressive-ai-negative":"_purpur-button--expressive-ai-negative_zehbw_556","purpur-button--text-ai":"_purpur-button--text-ai_zehbw_606","purpur-button--text-ai-negative":"_purpur-button--text-ai-negative_zehbw_679"},d={...$,DESTRUCTIVE:"destructive",TERTIARY_PURPLE:"tertiary-purple",TEXT:"text"},I=Object.values(d),v=N.c.bind(B),t="purpur-button",S=["button","submit","reset"],C=({iconOnly:r,loading:e})=>!(r&&e),h=f.forwardRef(({ai:r=!1,children:e,className:w,disabled:p=!1,fullWidth:z=!1,iconOnly:n,loading:u=!1,negative:b=!1,onClick:o,size:_="md",variant:i,type:x="button",...s},y)=>{if(n&&i==="destructive")return null;const g=`${i}${r?"-ai":""}${b?"-negative":""}`,m=v([t,`${t}--${g}`,`${t}--${_}`],{[`${t}--icon-only`]:n,[`${t}--negative`]:b,[`${t}--full-width`]:z,[`${t}--disabled`]:p||u},w),T=c=>{p||u?c.preventDefault():o&&o(c)},a=!!s["aria-disabled"]||p||u,R=C({iconOnly:n,loading:u});return l.jsxs("button",{className:m,type:x,ref:y,"aria-disabled":a,onClick:T,...s,children:[u&&l.jsx(E.Spinner,{size:_===A.LG?"xs":"xxs",negative:b,disabled:a,className:v(`${t}__spinner`)}),R?e:null]})});h.displayName="Button";exports.BUTTON_TYPES=S;exports.BUTTON_VARIANT=d;exports.Button=h;exports.buttonVariants=I;
|
|
2
|
-
//# sourceMappingURL=button-Dqxdc3nC.js.map
|
package/dist/card-VMa3cGCP.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";const e=require("react/jsx-runtime"),n=require("./bind-DeUYJ6m9.js"),R=require("./badge-CQ0SS_t8.js"),B=require("./spinner-tKunS_o-.js"),F=require("./checkmark.es-lYntWFA3.js"),v=require("./paragraph-BsI53OR0.js"),L=require("./heading-drD5ugCC.js"),M=require("react"),O={"purpur-card__container--full-height":"_purpur-card__container--full-height_1a0g7_1","purpur-card__container--use-container-queries":"_purpur-card__container--use-container-queries_1a0g7_4","purpur-card":"_purpur-card_1a0g7_1","purpur-card__container--use-media-queries":"_purpur-card__container--use-media-queries_1a0g7_25"},D={"purpur-card-badge":"_purpur-card-badge_k9ziu_1"},E=n.c.bind(D),P="purpur-card-badge",A=({["data-testid"]:a="purpur-card-badge",variant:t,text:r})=>t&&r?e.jsx(R.Badge,{className:E(P),variant:t,showIcon:!1,"data-testid":a,children:r}):null,G={"purpur-card-content":"_purpur-card-content_2uc00_1"},J=n.c.bind(G),K="purpur-card-content",U=({["data-testid"]:a="purpur-card-content",children:t,className:r,...u})=>e.jsx("div",{className:J(K,r),"data-testid":a,...u,children:t}),V={"purpur-card-content-container":"_purpur-card-content-container_1soww_1","purpur-card-content-container--full-height":"_purpur-card-content-container--full-height_1soww_6","purpur-card-content-container--footer":"_purpur-card-content-container--footer_1soww_31","purpur-card-content-container--gap-size--sm":"_purpur-card-content-container--gap-size--sm_1soww_46","purpur-card-content-container--gap-size--md":"_purpur-card-content-container--gap-size--md_1soww_49","purpur-card-content-container--gap-size--lg":"_purpur-card-content-container--gap-size--lg_1soww_52","purpur-card-content-container--gap-size--xl":"_purpur-card-content-container--gap-size--xl_1soww_55"},W=n.c.bind(V),$="purpur-card-content-container",X=({["data-testid"]:a="purpur-card-content-container",children:t,className:r,isFooter:u=!1,fullHeight:c=!1,gapSize:p="md",...d})=>e.jsx("div",{className:W([$,r,`${$}--gap-size--${p}`,{[`${$}--full-height`]:c,[`${$}--footer`]:u}]),"data-testid":a,...d,children:t}),Y={"purpur-card-cta--button-styling":"_purpur-card-cta--button-styling_1stkr_1","purpur-card-cta--button-styling--xs":"_purpur-card-cta--button-styling--xs_1stkr_22","purpur-card-cta--button-styling--icon-only":"_purpur-card-cta--button-styling--icon-only_1stkr_25","purpur-card-cta--button-styling--sm":"_purpur-card-cta--button-styling--sm_1stkr_28","purpur-card-cta--button-styling--md":"_purpur-card-cta--button-styling--md_1stkr_34","purpur-card-cta--button-styling--lg":"_purpur-card-cta--button-styling--lg_1stkr_40","purpur-card-cta--button-styling--full-width":"_purpur-card-cta--button-styling--full-width_1stkr_46","purpur-card-cta--button-styling--primary":"_purpur-card-cta--button-styling--primary_1stkr_64","purpur-card-cta--button-styling--disabled":"_purpur-card-cta--button-styling--disabled_1stkr_68","purpur-card-cta--button-styling--primary-negative":"_purpur-card-cta--button-styling--primary-negative_1stkr_74","purpur-card-cta--button-styling--secondary":"_purpur-card-cta--button-styling--secondary_1stkr_86","purpur-card-cta--button-styling--secondary-negative":"_purpur-card-cta--button-styling--secondary-negative_1stkr_97","purpur-card-cta--button-styling--expressive":"_purpur-card-cta--button-styling--expressive_1stkr_108","purpur-card-cta--button-styling--expressive-negative":"_purpur-card-cta--button-styling--expressive-negative_1stkr_118","purpur-card-cta--cta-styling":"_purpur-card-cta--cta-styling_1stkr_130","purpur-card-cta--secondary":"_purpur-card-cta--secondary_1stkr_135","purpur-card-cta--disabled":"_purpur-card-cta--disabled_1stkr_135","purpur-card-cta--text":"_purpur-card-cta--text_1stkr_143"},Z=n.c.bind(Y),o="purpur-card-cta",Q=({["data-testid"]:a="purpur-card-cta",className:t,children:r,disabled:u=!1,iconPosition:c="right",loading:p=!1,text:d,linkStyling:s=!1,..._})=>e.jsx("div",{className:`${Z([o,t,{[`${o}--disabled`]:u,[`${o}--text`]:!!d,[`${o}--cta-styling`]:s,[`${o}--button-styling`]:!s,[`${o}--button-styling--md`]:!s,[`${o}--button-styling--secondary`]:!s,[`${o}--button-styling--icon-only`]:!s&&!d}])} ${o}`,"data-testid":a,..._,children:p?e.jsx(B.Spinner,{"data-testid":`${a}-spinner`,size:"xs",disabled:u}):e.jsxs(e.Fragment,{children:[c==="left"&&r,d,c==="right"&&r]})}),T={"purpur-card-feature-list":"_purpur-card-feature-list_1hnss_1","purpur-card-feature-list__list-item":"_purpur-card-feature-list__list-item_1hnss_7","purpur-card-feature-list__icon":"_purpur-card-feature-list__icon_1hnss_12"},h=n.c.bind(T),x="purpur-card-feature-list",I=({["data-testid"]:a="purpur-card-feature-list",listItems:t})=>t&&t.length>0?e.jsx("ul",{className:h(x),"data-testid":a,children:t.map(r=>e.jsxs("li",{className:h(`${x}__list-item`),"data-testid":`${a}-item`,children:[e.jsx(F.a,{size:"xs",className:h(`${x}__icon`)}),e.jsx(v.Paragraph,{children:r})]},r))}):null,S={"purpur-card-heading":"_purpur-card-heading_j3j6u_1","purpur-card-heading__header":"_purpur-card-heading__header_j3j6u_6","purpur-card-heading__heading":"_purpur-card-heading__heading_j3j6u_11","purpur-card-heading__icon":"_purpur-card-heading__icon_j3j6u_14"},rr={"purpur-card-trigger-item--link":"_purpur-card-trigger-item--link_t6ena_1","purpur-card-trigger-item--button":"_purpur-card-trigger-item--button_t6ena_5","purpur-card-trigger-item--disabled":"_purpur-card-trigger-item--disabled_t6ena_18","purpur-card-trigger-item":"_purpur-card-trigger-item_t6ena_1"},N=n.c.bind(rr),l="purpur-card-trigger-item",tr=({["data-testid"]:a="purpur-card-trigger-item",["aria-label"]:t,disabled:r=!1,href:u,onClick:c,children:p,linkElement:d="a"})=>{const s=y=>{r?y.preventDefault():c&&c()},_=`${l} ${r?`${l}--disabled`:""}`;return u?e.jsx(d,{"aria-disabled":r,"aria-label":t,className:`${N([l,`${l}--link`,{[`${l}--disabled`]:r}])} ${_}`,"data-testid":a,href:r?void 0:u,tabIndex:r?0:void 0,onClick:s,children:p}):e.jsx("button",{"aria-disabled":r,"aria-label":t,className:`${N([l,`${l}--button`,{[`${l}--disabled`]:r}])} ${_}`,"data-testid":a,type:"button",onClick:s,children:p})},b=n.c.bind(S),g="purpur-card-heading",ar=({["data-testid"]:a="purpur-card-heading",["aria-label"]:t,title:r,icon:u,children:c,titleTag:p="h2",enableHyphenation:d,onClick:s=void 0,href:_=void 0,disabled:y=!1,linkElement:k="a",variant:q="title-100",...z})=>{const H=b(g,{[`${g}--is-interactive`]:s||_,[`${g}--disabled`]:y});return e.jsxs("div",{className:H,"data-testid":a,children:[e.jsxs("div",{className:b(`${g}__header`),children:[u&&e.jsx("div",{className:b(`${g}__icon`),children:u}),e.jsx(L.Heading,{tag:p,className:b(`${g}__heading`),variant:q,enableHyphenation:d,...z,children:s||_?e.jsx(tr,{"aria-label":t,disabled:y,href:_,onClick:s,linkElement:k,children:r}):r})]}),c]})},er={"purpur-card-media":"_purpur-card-media_1om4o_1"},ur=n.c.bind(er),cr="purpur-card-media",sr=({["data-testid"]:a="purpur-card-media",className:t,children:r,...u})=>e.jsx("div",{...u,className:ur([cr,t]),"data-testid":a,children:r}),nr={"purpur-card-media-layout":"_purpur-card-media-layout_1c4sy_1","purpur-card-media-layout--image-top":"_purpur-card-media-layout--image-top_1c4sy_11"},dr=n.c.bind(nr),j="purpur-card-media-layout",ir=({["data-testid"]:a="purpur-card-media-layout",className:t,children:r,imageTop:u=!1,...c})=>e.jsx("div",{...c,className:dr(j,t,{[`${j}--image-top`]:u}),"data-testid":a,children:r}),pr={"purpur-card-overline":"_purpur-card-overline_qhfj0_1"},or=n.c.bind(pr),_r="purpur-card-overline",lr=({["data-testid"]:a="purpur-card-overline",overline:t})=>t?e.jsx(v.Paragraph,{variant:"overline-100",className:or(_r),"data-testid":a,children:t}):null,gr={"purpur-card-root":"_purpur-card-root_eupww_1","purpur-card-root--primary":"_purpur-card-root--primary_eupww_7","purpur-card-root--secondary":"_purpur-card-root--secondary_eupww_10","purpur-card-root--full-height":"_purpur-card-root--full-height_eupww_13"},mr=n.c.bind(gr),f="purpur-card-root",w=M.forwardRef(({["data-testid"]:a="purpur-card-root",children:t,className:r,fullHeight:u=!0,variant:c,...p},d)=>{const s=mr([f,{[`${f}--${c}`]:c,[`${f}--full-height`]:u},r]);return e.jsx("div",{className:s,"data-testid":a,ref:d,...p,children:t})});w.displayName="CardRoot";const C=n.c.bind(O),m="purpur-card",i=({children:a,className:t,useMediaQueries:r,...u})=>{const c=C([m,t]);return e.jsx("div",{className:C(`${m}__container`,{[`${m}__container--full-height`]:u.fullHeight,[`${m}__container--use-container-queries`]:!r,[`${m}__container--use-media-queries`]:r}),children:e.jsx(w,{className:C(c),...u,children:a})})};i.Badge=A;i.Content=U;i.ContentContainer=X;i.Cta=Q;i.FeatureList=I;i.Overline=lr;i.Heading=ar;i.Media=sr;i.MediaLayout=ir;i.displayName="Card";exports.Card=i;
|
|
2
|
-
//# sourceMappingURL=card-VMa3cGCP.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"content-block-BMOvlH7a.mjs","sources":["../../../components/content-block/src/content-block-group.tsx","../../../components/content-block/src/content-block.tsx"],"sourcesContent":["import React, { createContext, type ReactNode } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./content-block-group.module.scss\";\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-content-block-group\";\n\nexport const ContentBlockGroupContext = createContext<{\n negative?: boolean;\n reverse?: boolean;\n} | null>(null);\n\nexport type ContentBlockGroupProps = Omit<BaseProps, \"children\"> & {\n children: ReactNode;\n negative?: boolean;\n mediaStartPosition?: \"left\" | \"right\";\n};\n\nexport const ContentBlockGroup = ({\n children,\n className,\n negative,\n mediaStartPosition = \"left\",\n ...props\n}: ContentBlockGroupProps) => {\n const classes = cx([\n rootClassName,\n {\n [`${rootClassName}--negative`]: negative,\n },\n className,\n ]);\n\n return (\n <div className={classes} {...props}>\n <ContentBlockGroupContext.Provider\n value={{ negative, reverse: mediaStartPosition === \"right\" }}\n >\n {children}\n </ContentBlockGroupContext.Provider>\n </div>\n );\n};\n\nContentBlockGroup.displayName = \"ContentBlockGroup\";\n","import React, { type ReactNode, useContext } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { Heading, type HeadingTagType } from \"@purpur/heading\";\nimport { IconCheckmark } from \"@purpur/icon/checkmark\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./content-block.module.scss\";\nimport { ContentBlockGroup, ContentBlockGroupContext } from \"./content-block-group\";\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-content-block\";\n\nexport type ContentBlockProps = BaseProps & {\n /**\n * @deprecated Set negative on ContentBlockGroup instead\n */\n negative?: boolean;\n image?: ReactNode;\n video?: ReactNode;\n /**\n * @deprecated Use beforeTitle instead\n */\n badge?: ReactNode;\n actions?: ReactNode;\n listItems?: string[];\n beforeTitle?: ReactNode;\n title?: string;\n headingTag?: HeadingTagType;\n headingVariant?: \"title-100\" | \"title-200\" | \"title-300\";\n};\n\nexport const ContentBlock = ({\n className,\n negative,\n image,\n video,\n badge,\n beforeTitle,\n title,\n actions,\n listItems,\n headingTag = \"h2\",\n headingVariant = \"title-300\",\n children,\n ...props\n}: ContentBlockProps) => {\n const context = useContext(ContentBlockGroupContext);\n\n const classes = cx([\n rootClassName,\n {\n [`${rootClassName}--negative`]: context?.negative || negative,\n [`${rootClassName}--reverse`]: context?.reverse,\n },\n className,\n ]);\n\n return (\n <div className={classes} {...props}>\n <div className={cx(`${rootClassName}__section`)}>\n {video ? (\n <div className={cx(`${rootClassName}__video-wrapper`)}>{video}</div>\n ) : (\n <div className={cx(`${rootClassName}__image-wrapper`)}>{image}</div>\n )}\n </div>\n <div className={cx(`${rootClassName}__section`)}>\n <div className={cx(`${rootClassName}__content-wrapper`)}>\n {badge && <div className={cx(`${rootClassName}__badge-wrapper`)}>{badge}</div>}\n {beforeTitle}\n {title?.trim() && (\n <Heading variant={headingVariant} tag={headingTag} negative={negative}>\n {title}\n </Heading>\n )}\n <div className={cx(`${rootClassName}__content`)}>{children}</div>\n {!!listItems?.length && (\n <ul className={cx(`${rootClassName}__list`)}>\n {listItems.map(\n (item) =>\n item && (\n <li className={cx(`${rootClassName}__list-item`)} key={item}>\n <IconCheckmark size=\"xs\" className={cx(`${rootClassName}__list-item-icon`)} />\n <Paragraph negative={negative}>{item}</Paragraph>\n </li>\n )\n )}\n </ul>\n )}\n {actions && <div className={cx(`${rootClassName}__actions`)}>{actions}</div>}\n </div>\n </div>\n </div>\n );\n};\n\nContentBlock.Group = ContentBlockGroup;\nContentBlock.displayName = \"ContentBlock\";\n"],"names":["cx","c","styles","rootClassName","ContentBlockGroupContext","createContext","ContentBlockGroup","children","className","negative","mediaStartPosition","props","classes","jsx","ContentBlock","image","video","badge","beforeTitle","title","actions","listItems","headingTag","headingVariant","context","useContext","jsxs","Heading","item","IconCheckmark","Paragraph"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"content-block-Cd7xSE8t.js","sources":["../../../components/content-block/src/content-block-group.tsx","../../../components/content-block/src/content-block.tsx"],"sourcesContent":["import React, { createContext, type ReactNode } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./content-block-group.module.scss\";\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-content-block-group\";\n\nexport const ContentBlockGroupContext = createContext<{\n negative?: boolean;\n reverse?: boolean;\n} | null>(null);\n\nexport type ContentBlockGroupProps = Omit<BaseProps, \"children\"> & {\n children: ReactNode;\n negative?: boolean;\n mediaStartPosition?: \"left\" | \"right\";\n};\n\nexport const ContentBlockGroup = ({\n children,\n className,\n negative,\n mediaStartPosition = \"left\",\n ...props\n}: ContentBlockGroupProps) => {\n const classes = cx([\n rootClassName,\n {\n [`${rootClassName}--negative`]: negative,\n },\n className,\n ]);\n\n return (\n <div className={classes} {...props}>\n <ContentBlockGroupContext.Provider\n value={{ negative, reverse: mediaStartPosition === \"right\" }}\n >\n {children}\n </ContentBlockGroupContext.Provider>\n </div>\n );\n};\n\nContentBlockGroup.displayName = \"ContentBlockGroup\";\n","import React, { type ReactNode, useContext } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { Heading, type HeadingTagType } from \"@purpur/heading\";\nimport { IconCheckmark } from \"@purpur/icon/checkmark\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./content-block.module.scss\";\nimport { ContentBlockGroup, ContentBlockGroupContext } from \"./content-block-group\";\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-content-block\";\n\nexport type ContentBlockProps = BaseProps & {\n /**\n * @deprecated Set negative on ContentBlockGroup instead\n */\n negative?: boolean;\n image?: ReactNode;\n video?: ReactNode;\n /**\n * @deprecated Use beforeTitle instead\n */\n badge?: ReactNode;\n actions?: ReactNode;\n listItems?: string[];\n beforeTitle?: ReactNode;\n title?: string;\n headingTag?: HeadingTagType;\n headingVariant?: \"title-100\" | \"title-200\" | \"title-300\";\n};\n\nexport const ContentBlock = ({\n className,\n negative,\n image,\n video,\n badge,\n beforeTitle,\n title,\n actions,\n listItems,\n headingTag = \"h2\",\n headingVariant = \"title-300\",\n children,\n ...props\n}: ContentBlockProps) => {\n const context = useContext(ContentBlockGroupContext);\n\n const classes = cx([\n rootClassName,\n {\n [`${rootClassName}--negative`]: context?.negative || negative,\n [`${rootClassName}--reverse`]: context?.reverse,\n },\n className,\n ]);\n\n return (\n <div className={classes} {...props}>\n <div className={cx(`${rootClassName}__section`)}>\n {video ? (\n <div className={cx(`${rootClassName}__video-wrapper`)}>{video}</div>\n ) : (\n <div className={cx(`${rootClassName}__image-wrapper`)}>{image}</div>\n )}\n </div>\n <div className={cx(`${rootClassName}__section`)}>\n <div className={cx(`${rootClassName}__content-wrapper`)}>\n {badge && <div className={cx(`${rootClassName}__badge-wrapper`)}>{badge}</div>}\n {beforeTitle}\n {title?.trim() && (\n <Heading variant={headingVariant} tag={headingTag} negative={negative}>\n {title}\n </Heading>\n )}\n <div className={cx(`${rootClassName}__content`)}>{children}</div>\n {!!listItems?.length && (\n <ul className={cx(`${rootClassName}__list`)}>\n {listItems.map(\n (item) =>\n item && (\n <li className={cx(`${rootClassName}__list-item`)} key={item}>\n <IconCheckmark size=\"xs\" className={cx(`${rootClassName}__list-item-icon`)} />\n <Paragraph negative={negative}>{item}</Paragraph>\n </li>\n )\n )}\n </ul>\n )}\n {actions && <div className={cx(`${rootClassName}__actions`)}>{actions}</div>}\n </div>\n </div>\n </div>\n );\n};\n\nContentBlock.Group = ContentBlockGroup;\nContentBlock.displayName = \"ContentBlock\";\n"],"names":["cx","c","styles","rootClassName","ContentBlockGroupContext","createContext","ContentBlockGroup","children","className","negative","mediaStartPosition","props","classes","jsx","ContentBlock","image","video","badge","beforeTitle","title","actions","listItems","headingTag","headingVariant","context","useContext","jsxs","Heading","item","IconCheckmark","Paragraph"],"mappings":"q2CAMMA,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAClBC,EAAgB,6BAETC,EAA2BC,EAAAA,cAG9B,IAAI,EAQDC,EAAoB,CAAC,CAChC,SAAAC,EACA,UAAAC,EACA,SAAAC,EACA,mBAAAC,EAAqB,OACrB,GAAGC,CACL,IAA8B,CAC5B,MAAMC,EAAUZ,EAAG,CACjBG,EACA,CACE,CAAC,GAAGA,CAAa,YAAY,EAAGM,CAAA,EAElCD,CAAA,CACD,EAED,OACEK,EAAAA,IAAC,MAAA,CAAI,UAAWD,EAAU,GAAGD,EAC3B,SAAAE,EAAAA,IAACT,EAAyB,SAAzB,CACC,MAAO,CAAE,SAAAK,EAAU,QAASC,IAAuB,OAAA,EAElD,SAAAH,CAAA,CAAA,EAEL,CAEJ,EAEAD,EAAkB,YAAc,oBCpChC,MAAMN,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAClBC,EAAgB,uBAqBTW,EAAe,CAAC,CAC3B,UAAAN,EACA,SAAAC,EACA,MAAAM,EACA,MAAAC,EACA,MAAAC,EACA,YAAAC,EACA,MAAAC,EACA,QAAAC,EACA,UAAAC,EACA,WAAAC,EAAa,KACb,eAAAC,EAAiB,YACjB,SAAAhB,EACA,GAAGI,CACL,IAAyB,CACvB,MAAMa,EAAUC,EAAAA,WAAWrB,CAAwB,EAE7CQ,EAAUZ,EAAG,CACjBG,EACA,CACE,CAAC,GAAGA,CAAa,YAAY,EAAGqB,GAAS,UAAYf,EACrD,CAAC,GAAGN,CAAa,WAAW,EAAGqB,GAAS,OAAA,EAE1ChB,CAAA,CACD,EAED,OACEkB,EAAAA,KAAC,MAAA,CAAI,UAAWd,EAAU,GAAGD,EAC3B,SAAA,CAAAE,EAAAA,IAAC,MAAA,CAAI,UAAWb,EAAG,GAAGG,CAAa,WAAW,EAC3C,SAAAa,EACCH,MAAC,MAAA,CAAI,UAAWb,EAAG,GAAGG,CAAa,iBAAiB,EAAI,SAAAa,CAAA,CAAM,EAE9DH,EAAAA,IAAC,MAAA,CAAI,UAAWb,EAAG,GAAGG,CAAa,iBAAiB,EAAI,SAAAY,CAAA,CAAM,EAElE,EACAF,MAAC,MAAA,CAAI,UAAWb,EAAG,GAAGG,CAAa,WAAW,EAC5C,SAAAuB,EAAAA,KAAC,OAAI,UAAW1B,EAAG,GAAGG,CAAa,mBAAmB,EACnD,SAAA,CAAAc,GAASJ,EAAAA,IAAC,OAAI,UAAWb,EAAG,GAAGG,CAAa,iBAAiB,EAAI,SAAAc,CAAA,CAAM,EACvEC,EACAC,GAAO,KAAA,GACNN,MAACc,EAAAA,QAAA,CAAQ,QAASJ,EAAgB,IAAKD,EAAY,SAAAb,EAChD,SAAAU,CAAA,CACH,EAEFN,MAAC,OAAI,UAAWb,EAAG,GAAGG,CAAa,WAAW,EAAI,SAAAI,EAAS,EAC1D,CAAC,CAACc,GAAW,QACZR,EAAAA,IAAC,KAAA,CAAG,UAAWb,EAAG,GAAGG,CAAa,QAAQ,EACvC,SAAAkB,EAAU,IACRO,GACCA,GACEF,EAAAA,KAAC,KAAA,CAAG,UAAW1B,EAAG,GAAGG,CAAa,aAAa,EAC7C,SAAA,CAAAU,EAAAA,IAACgB,EAAAA,EAAA,CAAc,KAAK,KAAK,UAAW7B,EAAG,GAAGG,CAAa,kBAAkB,CAAA,CAAG,EAC5EU,EAAAA,IAACiB,EAAAA,UAAA,CAAU,SAAArB,EAAqB,SAAAmB,CAAA,CAAK,CAAA,CAAA,EAFgBA,CAGvD,CAAA,EAGR,EAEDR,SAAY,MAAA,CAAI,UAAWpB,EAAG,GAAGG,CAAa,WAAW,EAAI,SAAAiB,CAAA,CAAQ,CAAA,CAAA,CACxE,CAAA,CACF,CAAA,EACF,CAEJ,EAEAN,EAAa,MAAQR,EACrBQ,EAAa,YAAc"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";const t=require("react/jsx-runtime"),m=require("react"),oe=require("./listbox-COBHLRtB.js"),$e=require("./use-autocomplete.es-BHDgQLae.js"),Ie=require("./checkbox-Dk3bZkZ3.js"),pe=require("./dismissable-chip-group-Cd23yjBa.js"),Ce=require("./field-error-text-FhQulSV5.js"),Re=require("./field-helper-text-DSKO-Tce.js"),ke=require("./check-circle-filled.es-5-GXE9l4.js"),De=require("./chevron-down.es-BMjgiS3F.js"),Oe=require("./label-yHK80hhV.js"),Se=require("./spinner-tKunS_o-.js"),Ne=require("./bind-DeUYJ6m9.js"),Le={"purpur-dropdown":"_purpur-dropdown_ixl3j_1","purpur-dropdown--negative":"_purpur-dropdown--negative_ixl3j_11","purpur-dropdown__label":"_purpur-dropdown__label_ixl3j_14","purpur-dropdown__field-row":"_purpur-dropdown__field-row_ixl3j_19","purpur-dropdown__frame":"_purpur-dropdown__frame_ixl3j_23","purpur-dropdown__frame--negative":"_purpur-dropdown__frame--negative_ixl3j_30","purpur-dropdown__trigger-container":"_purpur-dropdown__trigger-container_ixl3j_33","purpur-dropdown__chip-group":"_purpur-dropdown__chip-group_ixl3j_45","purpur-dropdown__trigger-container--has-tags":"_purpur-dropdown__trigger-container--has-tags_ixl3j_50","purpur-dropdown__trigger-container--disabled":"_purpur-dropdown__trigger-container--disabled_ixl3j_53","purpur-dropdown__trigger-container--readonly":"_purpur-dropdown__trigger-container--readonly_ixl3j_53","purpur-dropdown__trigger-container--negative":"_purpur-dropdown__trigger-container--negative_ixl3j_60","purpur-dropdown__trigger-container--error":"_purpur-dropdown__trigger-container--error_ixl3j_63","purpur-dropdown__trigger-container--is-valid":"_purpur-dropdown__trigger-container--is-valid_ixl3j_66","purpur-dropdown__input":"_purpur-dropdown__input_ixl3j_69","purpur-dropdown__trigger":"_purpur-dropdown__trigger_ixl3j_33","purpur-dropdown__trigger--placeholder":"_purpur-dropdown__trigger--placeholder_ixl3j_117","purpur-dropdown__trigger--is-valid":"_purpur-dropdown__trigger--is-valid_ixl3j_120","purpur-dropdown__trigger--disabled":"_purpur-dropdown__trigger--disabled_ixl3j_123","purpur-dropdown__trigger--readonly":"_purpur-dropdown__trigger--readonly_ixl3j_127","purpur-dropdown__trigger--negative":"_purpur-dropdown__trigger--negative_ixl3j_131","purpur-dropdown__trigger-text":"_purpur-dropdown__trigger-text_ixl3j_144","purpur-dropdown__combobox-container":"_purpur-dropdown__combobox-container_ixl3j_150","purpur-dropdown__combobox-container--disabled":"_purpur-dropdown__combobox-container--disabled_ixl3j_160","purpur-dropdown__combobox-container--readonly":"_purpur-dropdown__combobox-container--readonly_ixl3j_167","purpur-dropdown__combobox-container--error":"_purpur-dropdown__combobox-container--error_ixl3j_174","purpur-dropdown__combobox-container--is-valid":"_purpur-dropdown__combobox-container--is-valid_ixl3j_177","purpur-dropdown__combobox-container--negative":"_purpur-dropdown__combobox-container--negative_ixl3j_180","purpur-dropdown__input--negative":"_purpur-dropdown__input--negative_ixl3j_219","purpur-dropdown__chip-group--select":"_purpur-dropdown__chip-group--select_ixl3j_236","purpur-dropdown__end-adornments":"_purpur-dropdown__end-adornments_ixl3j_239","purpur-dropdown__chevron-icon":"_purpur-dropdown__chevron-icon_ixl3j_250","purpur-dropdown__chevron-icon--open":"_purpur-dropdown__chevron-icon--open_ixl3j_255","purpur-dropdown__chevron-icon--disabled":"_purpur-dropdown__chevron-icon--disabled_ixl3j_258","purpur-dropdown__chevron-icon--readonly":"_purpur-dropdown__chevron-icon--readonly_ixl3j_261","purpur-dropdown__chevron-icon--negative":"_purpur-dropdown__chevron-icon--negative_ixl3j_264","purpur-dropdown__valid-icon":"_purpur-dropdown__valid-icon_ixl3j_267","purpur-dropdown__listbox":"_purpur-dropdown__listbox_ixl3j_270","purpur-dropdown__checkbox-item-multiple":"_purpur-dropdown__checkbox-item-multiple_ixl3j_280","purpur-dropdown__checkbox-container":"_purpur-dropdown__checkbox-container_ixl3j_283"},x=Ne.c.bind(Le),o="purpur-dropdown",ue=({fieldId:r,htmlForSuffix:n,label:s,getTestId:l,disabled:d,negative:i,required:h})=>s?t.jsxs(Oe.Label,{htmlFor:n?`${r}-${n}`:r,className:x(`${o}__label`),"data-testid":l("label"),disabled:d,negative:i,children:[h&&t.jsx("span",{"aria-hidden":!0,children:"*"}),s]}):null,_e=({getTestId:r,loading:n,disabled:s,negative:l,isValid:d,isOpen:i,readOnly:h,showChevronOpen:C})=>t.jsx("span",{className:x(`${o}__end-adornments`),children:n?t.jsx(Se.Spinner,{disabled:s,size:"xxs",negative:l,"data-testid":r("spinner")}):t.jsxs(t.Fragment,{children:[d&&t.jsx(ke.r,{"data-testid":r("valid-icon"),className:x(`${o}__valid-icon`)}),t.jsx(De.l,{className:x(`${o}__chevron-icon`,{[`${o}__chevron-icon--open`]:C&&i,[`${o}__chevron-icon--disabled`]:s,[`${o}__chevron-icon--readonly`]:h&&!s,[`${o}__chevron-icon--is-valid`]:d,[`${o}__chevron-icon--negative`]:l}),"data-testid":r("dropdown-icon"),size:"sm"})]})}),ge=({selectedItems:r,getTestId:n,disabled:s,onRemove:l,isSelect:d})=>r.length?t.jsx(pe.DismissableChipGroup,{className:x(`${o}__chip-group`,{[`${o}__chip-group--select`]:d}),"data-testid":n("tags"),size:"sm",children:r.map(i=>t.jsx(pe.DismissableChipGroup.Item,{id:i.id,"data-testid":n(`tag-${i.id}`),"aria-label":`Remove ${i.label}`,onDismiss:()=>{l(i)},disabled:s,children:i.label},i.id))}):null,he=({errorText:r,helperText:n,helperTextId:s,negative:l})=>t.jsxs(t.Fragment,{children:[r&&t.jsx(Ce.FieldErrorText,{negative:l,children:r}),n&&!r&&t.jsx(Re.FieldHelperText,{id:s,negative:l,children:n})]}),xe=({optionsToShow:r,getListboxItemProps:n,multiple:s,fieldId:l,noOptionsText:d})=>d!==void 0&&!r.length?t.jsx(oe.Listbox.Item,{noninteractive:!0,children:d}):r.map((i,h)=>{const{key:C,selected:y,...g}=n(i,h);return s?t.jsx(oe.Listbox.Item,{...g,className:x(`${o}__checkbox-item-multiple`),selected:!!y,hideSelectedIcon:!0,children:t.jsxs("span",{className:x(`${o}__checkbox-container`),children:[t.jsx(Ie.Checkbox,{id:`${l}-checkbox-${i.id}`,checked:!!y,"aria-hidden":!0}),i.label]})},C):t.jsx(oe.Listbox.Item,{...g,selected:!!y,children:i.label},C)}),Te=(r,n,s)=>{if(s)return r.filter(d=>s(n,d));if(!n)return r;const l=n.toUpperCase().split(" ");return r.filter(d=>l.every(i=>(d.value||d.label).toUpperCase().includes(i)))},be=({options:r,searchTerm:n,filterOption:s,selectedOption:l,multiple:d})=>!d&&l&&l.label===n?r:Te(r,n,s),fe=({controlledInputValue:r,defaultInputValue:n,selectedOption:s,onInputChange:l})=>{const[d,i]=m.useState((typeof r=="string"?r:n??s?.label)??"");return{displayInputValue:typeof r=="string"?r:d,populateInputField:y=>{l?.(y),i(y)}}},we=m.forwardRef((r,n)=>{const{id:s,label:l,options:d,className:i,errorText:h,helperText:C,placeholder:y,negative:g=!1,readOnly:S=!1,disabled:b=!1,required:_=!1,valid:R,loading:f,multiple:p=!1,selectedOption:u,selectedOptions:N=[],onSelect:E,openOnFocus:$=!1,listboxMaxHeight:Q,listboxLabel:Y,filterOption:F,inputValue:A,defaultInputValue:c,onInputChange:H,noOptionsText:L,highlightFirstOption:T=!1,["data-testid"]:P}=r,k=m.useId(),v=s??k,D=a=>P?`${P}-${a}`:void 0,V=!!R&&!h,I=`${v}-helper-text`,j=p?N:u?[u]:[],{displayInputValue:q,populateInputField:B}=fe({controlledInputValue:A,defaultInputValue:c,selectedOption:u,onInputChange:H}),M=be({options:d,searchTerm:q,filterOption:F,selectedOption:u,multiple:p}),z=a=>{if(p){const e=j.some(w=>w.id===a.id)?j.filter(w=>w.id!==a.id):[...j,a];E?.(a,e),B("")}else E?.(a,[a]),B(a.label)},{rootRef:X,inputRef:Z,inputProps:G,listboxProps:O,getListboxItemProps:ee,isOpen:U,openListbox:re,anchorStyle:te}=$e.ee({id:v,options:M,listboxLabel:Y||l||"Options",selectedOption:p?void 0:u,disabled:b,readOnly:S,openOnFocus:$,listboxMaxHeight:Q,highlightFirstOption:T,closeOnSelect:!p,noOptionsText:L,onSelect:z,"data-testid":P}),ne=a=>{X.current=a,typeof n=="function"?n(a):n&&(n.current=a)},ie=(a,W)=>{const e=ee(a,W);if(p){const w=j.some(J=>J.id===a.id);return{...e,selected:w,"aria-selected":w}}return e},se=a=>{const W=j.filter(e=>e.id!==a.id);E?.(a,W)},le=a=>{p&&a.key==="Backspace"&&a.currentTarget.value===""&&j.length>0&&se(j[j.length-1]),G?.onKeyDown?.(a)},ae=a=>{B(a.target.value),U||re()},ce=x(o,i,{[`${o}--negative`]:g});return t.jsxs("div",{ref:ne,className:ce,children:[t.jsx(ue,{fieldId:v,htmlForSuffix:"input",label:l,getTestId:D,disabled:b,negative:g,required:_}),t.jsx("div",{className:x(`${o}__field-row`),children:t.jsxs("div",{className:x(`${o}__combobox-container`,{[`${o}__combobox-container--error`]:!!h,[`${o}__combobox-container--is-valid`]:V,[`${o}__combobox-container--negative`]:g,[`${o}__combobox-container--disabled`]:b,[`${o}__combobox-container--readonly`]:S&&!b}),style:te,children:[p&&t.jsx(ge,{selectedItems:j,getTestId:D,disabled:b,onRemove:se}),t.jsx("input",{...G,ref:Z,id:`${v}-input`,"data-testid":D("input"),onKeyDown:le,onChange:ae,value:q,placeholder:y,className:x(`${o}__input`,{[`${o}__input--negative`]:g}),"aria-describedby":I,"aria-invalid":!!h,disabled:b,readOnly:S}),t.jsx(_e,{getTestId:D,loading:f,disabled:b,negative:g,isValid:V,isOpen:U,showChevronOpen:!0}),t.jsx("span",{className:x(`${o}__frame`,{[`${o}__frame--negative`]:g})})]})}),U&&t.jsx(oe.Listbox,{...O,className:x(`${o}__listbox`),children:xe({optionsToShow:M,getListboxItemProps:ie,multiple:p,fieldId:v,noOptionsText:L})}),t.jsx(he,{errorText:h,helperText:C,helperTextId:I,negative:g})]})});we.displayName="DropdownCombobox";const Be=({options:r,highlightFirstOption:n})=>{const s=m.useRef(null),l=m.useRef({}),[d,i]=m.useState(n?r[0]:void 0),h=_=>{if(_){const R=_.getBoundingClientRect(),f=s.current?.getBoundingClientRect()||{top:0,bottom:0};(R.top<f.top||R.bottom>f.bottom)&&_.scrollIntoView({block:"nearest"})}};return{highlightedOption:d,listboxRef:s,optionRefs:l,findNextOption:(_,R)=>{const f=R.filter(u=>!u.disabled);if(!f.length)return;const p=d?f.findIndex(u=>u.id===d.id):-1;return _==="ArrowDown"?f[(p+1)%f.length]:f[(p-1+f.length)%f.length]},highlightOption:_=>{i(_?{..._}:void 0),_&&h(l.current[_.id])},highlightByClick:_=>{_.id!==d?.id&&i({..._,isSetByClickEvent:!0})},highlightSelected:(_,R)=>{requestAnimationFrame(()=>{i({..._,isSetByClickEvent:R==="CLICK"}),h(l.current[_.id])})},resetHighlight:()=>{i(void 0)}}},Ee=(r,n)=>{const s=m.useCallback(l=>{r&&!r.contains(l.target)&&n()},[n,r]);m.useEffect(()=>(document.addEventListener("mousedown",s),()=>{document.removeEventListener("mousedown",s)}),[s])},me=({id:r,variant:n,options:s,listboxLabel:l,multiple:d=!1,selectedOption:i,selectedOptions:h=[],onSelect:C,filterOption:y,inputValue:g,defaultInputValue:S,onInputChange:b,noOptionsText:_,highlightFirstOption:R=!1,openOnFocus:f=!1,listboxMaxHeight:p,disabled:u=!1,readOnly:N=!1,["data-testid"]:E})=>{const $=n==="combobox",Q=m.useId(),Y=m.useRef(null),F=m.useRef(null),A=m.useRef(null),c=Be({options:s,highlightFirstOption:R}),{displayInputValue:H,populateInputField:L}=fe({controlledInputValue:g,defaultInputValue:S,selectedOption:i,onInputChange:b}),[T,P]=m.useState(!1),k=()=>{P(!1),c.resetHighlight()};Ee(Y.current,k);const v=({eventType:e})=>{P(!0);const w=d?void 0:i;w&&c.highlightSelected(w,e)},D=d?h:i?[i]:[],V=$?be({options:s,searchTerm:H,filterOption:y,selectedOption:i,multiple:d}):s,I=T&&(!!V.length||!!_),j=e=>E?`${E}-${e}`:void 0,q=e=>{if(!(!e||e.disabled))if(d){const J=D.some(K=>K.id===e.id)?D.filter(K=>K.id!==e.id):[...D,e];C?.(e,J),$&&(L(""),A.current?.focus())}else C?.(e,[e]),$&&L(e.label),k(),($?A:F).current?.focus()},B=e=>{I||v({eventType:"KEYBOARD"});const w=c.findNextOption(e,V);c.highlightOption(w)},M=e=>{if(!(u||N))switch(e.key){case"ArrowUp":case"ArrowDown":e.preventDefault(),B(e.key);break;case"Enter":{e.preventDefault(),I&&c.highlightedOption?q(c.highlightedOption):I||v({eventType:"KEYBOARD"});break}case" ":{$||(e.preventDefault(),I&&c.highlightedOption?q(c.highlightedOption):I||v({eventType:"KEYBOARD"}));break}case"Escape":e.preventDefault(),k();break;case"Tab":k();break;case"Home":case"End":$&&k();break}},z=e=>{L(e.target.value),c.resetHighlight(),T||v({eventType:"KEYBOARD"})},X=()=>{u||N||(T?k():v({eventType:"CLICK"}))},Z=()=>{!T&&f&&!u&&!N&&v({eventType:"KEYBOARD"}),A.current?.select()},G=()=>{setTimeout(()=>{const e=document.activeElement;e!==document.body&&!A.current?.contains(e)&&!c.listboxRef.current?.contains(e)&&!Y.current?.contains(e)&&(k(),$&&!d&&L(i?i.label:""))})},O=()=>{u||N||(T?k():v({eventType:"CLICK"}))},ee=e=>{if(u||N)return;const w=e.target.closest("button");w&&w!==F.current||O()},U=()=>{!T&&f&&!u&&!N&&v({eventType:"KEYBOARD"})},re=`${r}-listbox`,te=e=>`${r}-listbox-item-${e.id}`,ne=`--purpur-dropdown-${Q.replace(/:/g,"")}`,ie={anchorName:ne},se=$?null:{onClick:ee},le=m.useCallback(e=>{if(c.listboxRef.current=e,e&&typeof e.showPopover=="function")try{e.showPopover()}catch{}},[c.listboxRef]),ae={"aria-label":l,"aria-expanded":I,"data-testid":j("listbox"),id:re,ref:le,onMouseLeave:()=>c.resetHighlight(),popover:"manual",style:{...p?{maxHeight:typeof p=="number"?`${p}px`:p}:{},positionAnchor:ne}},ce=(e,w)=>{const J=D.some(de=>de.id===e.id),{highlightedOption:K}=c,ye=(e.id===K?.id||R&&!K&&w===0)&&!K?.isSetByClickEvent;return{"data-testid":j(`listbox-item-${e.id}`),id:te(e),key:e.id,onMouseMove:()=>c.highlightByClick(e),onMouseUp:()=>q(e),ref:de=>{de&&(c.optionRefs.current[e.id]=de)},tabIndex:-1,selected:J,disabled:e.disabled,highlighted:ye,hovered:e.id===K?.id&&!!K?.isSetByClickEvent,"aria-selected":J}},a=$?{}:{ref:F,type:"button",role:"combobox","aria-haspopup":"listbox","aria-expanded":I,"aria-controls":re,"aria-disabled":u,"data-testid":j("trigger"),id:`${r}-trigger`,onKeyDown:M,onFocus:U,disabled:u,tabIndex:u?-1:0,style:ie},W=$?{ref:A,role:"combobox","aria-autocomplete":"list","aria-expanded":I,"aria-controls":re,"aria-activedescendant":c.highlightedOption?te(c.highlightedOption):void 0,"data-testid":j("input"),autoComplete:"off",id:`${r}-input`,type:"text",value:H,onChange:z,onMouseDown:X,onFocus:Z,onBlur:G,onKeyDown:M,disabled:u,readOnly:N}:null;return{rootRef:Y,triggerContainerProps:se,triggerProps:a,inputProps:W,listboxProps:ae,getListboxItemProps:ce,optionsToShow:V,isOpen:I,highlightedOption:c.highlightedOption,selectedItems:D,anchorStyle:ie}},ve=m.forwardRef((r,n)=>{const{id:s,label:l,options:d,className:i,errorText:h,helperText:C,placeholder:y,negative:g=!1,readOnly:S=!1,disabled:b=!1,required:_=!1,valid:R=!1,loading:f=!1,multiple:p=!1,selectedOption:u,selectedOptions:N=[],onSelect:E,openOnFocus:$=!1,listboxMaxHeight:Q,listboxLabel:Y,["data-testid"]:F}=r,A=m.useId(),c=s??A,H=O=>F?`${F}-${O}`:void 0,L=!!R&&!h,T=`${c}-helper-text`,P=me({id:c,variant:"select",options:d,listboxLabel:Y||l||"Options",multiple:p,selectedOption:u,selectedOptions:N,onSelect:E,openOnFocus:$,listboxMaxHeight:Q,disabled:b,readOnly:S,"data-testid":F}),k=O=>{P.rootRef.current=O,typeof n=="function"?n(O):n&&(n.current=O)},{triggerContainerProps:v,triggerProps:D,listboxProps:V,getListboxItemProps:I,optionsToShow:j,isOpen:q,selectedItems:B,anchorStyle:M}=P,z={...D};delete z.style;const X=O=>{const ee=B.filter(U=>U.id!==O.id);E?.(O,ee)},Z=p?B.length===0&&y||"":u?.label||y||"",G=x(o,i,{[`${o}--negative`]:g});return t.jsxs("div",{ref:k,className:G,children:[t.jsx(ue,{fieldId:c,htmlForSuffix:"trigger",label:l,getTestId:H,disabled:b,negative:g,required:_}),t.jsx("div",{className:x(`${o}__field-row`),children:t.jsxs("div",{...v,className:x(`${o}__trigger-container`,{[`${o}__trigger-container--error`]:!!h,[`${o}__trigger-container--is-valid`]:L,[`${o}__trigger-container--negative`]:g,[`${o}__trigger-container--disabled`]:b,[`${o}__trigger-container--readonly`]:S&&!b,[`${o}__trigger-container--has-tags`]:p&&B.length>0}),style:M,children:[p&&t.jsx(ge,{selectedItems:B,getTestId:H,disabled:b,onRemove:X,isSelect:!0}),t.jsx("button",{...z,className:x(`${o}__trigger`,{[`${o}__trigger--is-valid`]:L,[`${o}__trigger--negative`]:g,[`${o}__trigger--disabled`]:b,[`${o}__trigger--readonly`]:S&&!b,[`${o}__trigger--placeholder`]:!B.length}),"aria-describedby":T,children:t.jsx("span",{className:x(`${o}__trigger-text`),children:Z})}),t.jsx(_e,{getTestId:H,loading:f,disabled:b,negative:g,isValid:L,isOpen:q,readOnly:S,showChevronOpen:!0}),t.jsx("span",{className:x(`${o}__frame`,{[`${o}__frame--negative`]:g})})]})}),q&&t.jsx(oe.Listbox,{...V,className:x(`${o}__listbox`),children:xe({optionsToShow:j,getListboxItemProps:I,multiple:p,fieldId:c})}),t.jsx(he,{errorText:h,helperText:C,helperTextId:T,negative:g})]})});ve.displayName="DropdownSelect";const je=m.forwardRef((r,n)=>r.combobox?t.jsx(we,{ref:n,...r}):t.jsx(ve,{ref:n,...r}));je.displayName="Dropdown";exports.Dropdown=je;exports.useDropdown=me;
|
|
2
|
-
//# sourceMappingURL=dropdown-BQOY21kI.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dropdown-BQOY21kI.js","sources":["../../../components/dropdown/src/dropdown-shared.tsx","../../../components/dropdown/src/useDropdownFilter.ts","../../../components/dropdown/src/useDropdownInput.ts","../../../components/dropdown/src/dropdown-combobox.tsx","../../../components/dropdown/src/useDropdownHighlight.ts","../../../components/dropdown/src/useOnClickOutside.ts","../../../components/dropdown/src/useDropdown.ts","../../../components/dropdown/src/dropdown-select.tsx","../../../components/dropdown/src/dropdown.tsx"],"sourcesContent":["import React from \"react\";\nimport { Checkbox } from \"@purpur/checkbox\";\nimport { DismissableChipGroup } from \"@purpur/dismissable-chip-group\";\nimport { FieldErrorText } from \"@purpur/field-error-text\";\nimport { FieldHelperText } from \"@purpur/field-helper-text\";\nimport { IconCheckCircleFilled } from \"@purpur/icon/check-circle-filled\";\nimport { IconChevronDown } from \"@purpur/icon/chevron-down\";\nimport { Label } from \"@purpur/label\";\nimport { Listbox } from \"@purpur/listbox\";\nimport { Spinner } from \"@purpur/spinner\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./dropdown.module.scss\";\nimport type { DropdownOption } from \"./dropdown.types\";\n\nconst cx = c.bind(styles);\nexport const rootClassName = \"purpur-dropdown\";\n\ntype GetTestId = (name: string) => string | undefined;\n\ntype DropdownLabelProps = {\n fieldId: string;\n htmlForSuffix?: string;\n label?: string;\n getTestId: GetTestId;\n disabled: boolean;\n negative: boolean;\n required: boolean;\n};\n\nexport const DropdownLabel = ({\n fieldId,\n htmlForSuffix,\n label,\n getTestId,\n disabled,\n negative,\n required,\n}: DropdownLabelProps) => {\n if (!label) return null;\n\n return (\n <Label\n htmlFor={htmlForSuffix ? `${fieldId}-${htmlForSuffix}` : fieldId}\n className={cx(`${rootClassName}__label`)}\n data-testid={getTestId(\"label\")}\n disabled={disabled}\n negative={negative}\n >\n {required && <span aria-hidden>*</span>}\n {label}\n </Label>\n );\n};\n\ntype DropdownEndAdornmentsProps = {\n getTestId: GetTestId;\n loading?: boolean;\n disabled: boolean;\n negative: boolean;\n isValid: boolean;\n isOpen?: boolean;\n readOnly?: boolean;\n showChevronOpen: boolean;\n};\n\nexport const DropdownEndAdornments = ({\n getTestId,\n loading,\n disabled,\n negative,\n isValid,\n isOpen,\n readOnly,\n showChevronOpen,\n}: DropdownEndAdornmentsProps) => (\n <span className={cx(`${rootClassName}__end-adornments`)}>\n {loading ? (\n <Spinner\n disabled={disabled}\n size=\"xxs\"\n negative={negative}\n data-testid={getTestId(\"spinner\")}\n />\n ) : (\n <>\n {isValid && (\n <IconCheckCircleFilled\n data-testid={getTestId(\"valid-icon\")}\n className={cx(`${rootClassName}__valid-icon`)}\n />\n )}\n <IconChevronDown\n className={cx(`${rootClassName}__chevron-icon`, {\n [`${rootClassName}__chevron-icon--open`]: showChevronOpen && isOpen,\n [`${rootClassName}__chevron-icon--disabled`]: disabled,\n [`${rootClassName}__chevron-icon--readonly`]: readOnly && !disabled,\n [`${rootClassName}__chevron-icon--is-valid`]: isValid,\n [`${rootClassName}__chevron-icon--negative`]: negative,\n })}\n data-testid={getTestId(\"dropdown-icon\")}\n size=\"sm\"\n />\n </>\n )}\n </span>\n);\n\ntype DropdownTagsProps = {\n selectedItems: DropdownOption[];\n getTestId: GetTestId;\n disabled: boolean;\n onRemove: (option: DropdownOption) => void;\n isSelect?: boolean;\n};\n\nexport const DropdownTags = ({\n selectedItems,\n getTestId,\n disabled,\n onRemove,\n isSelect,\n}: DropdownTagsProps) => {\n if (!selectedItems.length) return null;\n\n return (\n <DismissableChipGroup\n className={cx(`${rootClassName}__chip-group`, {\n [`${rootClassName}__chip-group--select`]: isSelect,\n })}\n data-testid={getTestId(\"tags\")}\n size=\"sm\"\n >\n {selectedItems.map((item) => (\n <DismissableChipGroup.Item\n key={item.id}\n id={item.id}\n data-testid={getTestId(`tag-${item.id}`)}\n aria-label={`Remove ${item.label}`}\n onDismiss={() => {\n onRemove(item);\n }}\n disabled={disabled}\n >\n {item.label}\n </DismissableChipGroup.Item>\n ))}\n </DismissableChipGroup>\n );\n};\n\ntype DropdownFooterProps = {\n errorText?: string;\n helperText?: string;\n helperTextId: string;\n negative: boolean;\n};\n\nexport const DropdownFooter = ({\n errorText,\n helperText,\n helperTextId,\n negative,\n}: DropdownFooterProps) => (\n <>\n {errorText && <FieldErrorText negative={negative}>{errorText}</FieldErrorText>}\n {helperText && !errorText && (\n <FieldHelperText id={helperTextId} negative={negative}>\n {helperText}\n </FieldHelperText>\n )}\n </>\n);\n\ntype DropdownListboxItemsProps = {\n optionsToShow: DropdownOption[];\n getListboxItemProps: (option: DropdownOption, index: number) => Record<string, unknown>;\n multiple?: boolean;\n fieldId: string;\n noOptionsText?: React.ReactNode;\n};\n\nexport const DropdownListboxItems = ({\n optionsToShow,\n getListboxItemProps,\n multiple,\n fieldId,\n noOptionsText,\n}: DropdownListboxItemsProps) => {\n if (noOptionsText !== undefined && !optionsToShow.length) {\n return <Listbox.Item noninteractive>{noOptionsText}</Listbox.Item>;\n }\n\n return optionsToShow.map((option, index) => {\n const { key, selected, ...itemProps } = getListboxItemProps(option, index);\n\n if (multiple) {\n return (\n <Listbox.Item\n key={key as string}\n {...itemProps}\n className={cx(`${rootClassName}__checkbox-item-multiple`)}\n selected={!!selected}\n hideSelectedIcon\n >\n <span className={cx(`${rootClassName}__checkbox-container`)}>\n <Checkbox id={`${fieldId}-checkbox-${option.id}`} checked={!!selected} aria-hidden />\n {option.label}\n </span>\n </Listbox.Item>\n );\n }\n\n return (\n <Listbox.Item key={key as string} {...itemProps} selected={!!selected}>\n {option.label}\n </Listbox.Item>\n );\n });\n};\n\nexport { cx };\n","import type { DropdownOption } from \"./dropdown.types\";\n\nconst filterOptions = (\n options: DropdownOption[],\n searchTerm: string | undefined,\n filterOption?: (inputValue: string | undefined, option: DropdownOption) => boolean\n): DropdownOption[] => {\n if (filterOption) {\n return options.filter((option) => filterOption(searchTerm, option));\n }\n if (!searchTerm) return options;\n const chunks = searchTerm.toUpperCase().split(\" \");\n return options.filter((option) =>\n chunks.every((chunk) => (option.value || option.label).toUpperCase().includes(chunk))\n );\n};\n\nexport const getFilteredOptions = ({\n options,\n searchTerm,\n filterOption,\n selectedOption,\n multiple,\n}: {\n options: DropdownOption[];\n searchTerm: string | undefined;\n filterOption?: (inputValue: string | undefined, option: DropdownOption) => boolean;\n selectedOption?: DropdownOption;\n multiple: boolean;\n}): DropdownOption[] => {\n if (!multiple && selectedOption && selectedOption.label === searchTerm) {\n return options;\n }\n return filterOptions(options, searchTerm, filterOption);\n};\n","import { useState } from \"react\";\n\nimport type { DropdownOption } from \"./dropdown.types\";\n\nexport type UseDropdownInputParams = {\n controlledInputValue?: string;\n defaultInputValue?: string;\n selectedOption?: DropdownOption;\n onInputChange?: (value: string) => void;\n};\n\nexport const useDropdownInput = ({\n controlledInputValue,\n defaultInputValue,\n selectedOption,\n onInputChange,\n}: UseDropdownInputParams) => {\n const [internalInputValue, setInternalInputValue] = useState(\n (typeof controlledInputValue === \"string\"\n ? controlledInputValue\n : defaultInputValue ?? selectedOption?.label) ?? \"\"\n );\n\n const displayInputValue =\n typeof controlledInputValue === \"string\" ? controlledInputValue : internalInputValue;\n\n const populateInputField = (value: string) => {\n onInputChange?.(value);\n setInternalInputValue(value);\n };\n\n return {\n displayInputValue,\n populateInputField,\n };\n};\n","import React, { forwardRef, useId } from \"react\";\nimport { Listbox } from \"@purpur/listbox\";\nimport { useAutocomplete } from \"@purpur/use-autocomplete\";\n\nimport type { ComboboxProps, DropdownOption } from \"./dropdown.types\";\nimport {\n cx,\n DropdownEndAdornments,\n DropdownFooter,\n DropdownLabel,\n DropdownListboxItems,\n DropdownTags,\n rootClassName,\n} from \"./dropdown-shared\";\nimport { getFilteredOptions } from \"./useDropdownFilter\";\nimport { useDropdownInput } from \"./useDropdownInput\";\n\nexport const DropdownCombobox = forwardRef<HTMLDivElement, ComboboxProps>((props, ref) => {\n const {\n id: propId,\n label,\n options,\n className,\n errorText,\n helperText,\n placeholder,\n negative = false,\n readOnly = false,\n disabled = false,\n required = false,\n valid,\n loading,\n multiple = false,\n selectedOption,\n selectedOptions = [],\n onSelect,\n openOnFocus = false,\n listboxMaxHeight,\n listboxLabel,\n filterOption,\n inputValue,\n defaultInputValue,\n onInputChange,\n noOptionsText,\n highlightFirstOption = false,\n [\"data-testid\"]: dataTestId,\n } = props;\n\n const randomId = useId();\n const fieldId = propId ?? randomId;\n const getTestId = (name: string) => (dataTestId ? `${dataTestId}-${name}` : undefined);\n const isValid = !!valid && !errorText;\n const helperTextId = `${fieldId}-helper-text`;\n\n const selectedItems = multiple ? selectedOptions : selectedOption ? [selectedOption] : [];\n\n const { displayInputValue, populateInputField } = useDropdownInput({\n controlledInputValue: inputValue,\n defaultInputValue,\n selectedOption,\n onInputChange,\n });\n\n const optionsToShow = getFilteredOptions({\n options,\n searchTerm: displayInputValue,\n filterOption,\n selectedOption,\n multiple,\n });\n\n const handleAutocompleteSelect = (option: DropdownOption) => {\n if (multiple) {\n const isAlreadySelected = selectedItems.some((o) => o.id === option.id);\n const next = isAlreadySelected\n ? selectedItems.filter((o) => o.id !== option.id)\n : [...selectedItems, option];\n onSelect?.(option, next);\n populateInputField(\"\");\n } else {\n onSelect?.(option, [option]);\n populateInputField(option.label);\n }\n };\n\n const {\n rootRef,\n inputRef,\n inputProps,\n listboxProps,\n getListboxItemProps,\n isOpen,\n openListbox,\n anchorStyle,\n } = useAutocomplete({\n id: fieldId,\n options: optionsToShow,\n listboxLabel: listboxLabel || label || \"Options\",\n selectedOption: multiple ? undefined : selectedOption,\n disabled,\n readOnly,\n openOnFocus,\n listboxMaxHeight,\n highlightFirstOption,\n closeOnSelect: !multiple,\n noOptionsText,\n onSelect: handleAutocompleteSelect,\n [\"data-testid\"]: dataTestId,\n });\n\n const setRootRef = (node: HTMLDivElement | null) => {\n (rootRef as React.RefObject<HTMLDivElement | null>).current = node;\n if (typeof ref === \"function\") ref(node);\n else if (ref) (ref as React.RefObject<HTMLDivElement | null>).current = node;\n };\n\n // For multi-select the hook doesn't know about selectedOptions, so inject\n // the correct `selected` state here based on selectedItems.\n const getListboxItemPropsWithSelection = (option: DropdownOption, index: number) => {\n const props = getListboxItemProps(option, index);\n if (multiple) {\n const isSelected = selectedItems.some((o) => o.id === option.id);\n return { ...props, selected: isSelected, \"aria-selected\": isSelected };\n }\n return props;\n };\n\n const handleRemoveTag = (option: DropdownOption) => {\n const next = selectedItems.filter((o) => o.id !== option.id);\n onSelect?.(option, next);\n };\n\n const handleInputKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (\n multiple &&\n event.key === \"Backspace\" &&\n event.currentTarget.value === \"\" &&\n selectedItems.length > 0\n ) {\n handleRemoveTag(selectedItems[selectedItems.length - 1]);\n }\n (inputProps as React.InputHTMLAttributes<HTMLInputElement>)?.onKeyDown?.(event);\n };\n\n const handleInputChange: React.ChangeEventHandler<HTMLInputElement> = (e) => {\n populateInputField(e.target.value);\n if (!isOpen) {\n openListbox();\n }\n };\n\n const wrapperClassName = cx(rootClassName, className, {\n [`${rootClassName}--negative`]: negative,\n });\n\n return (\n <div ref={setRootRef} className={wrapperClassName}>\n <DropdownLabel\n fieldId={fieldId}\n htmlForSuffix=\"input\"\n label={label}\n getTestId={getTestId}\n disabled={disabled}\n negative={negative}\n required={required}\n />\n <div className={cx(`${rootClassName}__field-row`)}>\n <div\n className={cx(`${rootClassName}__combobox-container`, {\n [`${rootClassName}__combobox-container--error`]: !!errorText,\n [`${rootClassName}__combobox-container--is-valid`]: isValid,\n [`${rootClassName}__combobox-container--negative`]: negative,\n [`${rootClassName}__combobox-container--disabled`]: disabled,\n [`${rootClassName}__combobox-container--readonly`]: readOnly && !disabled,\n })}\n style={anchorStyle}\n >\n {multiple && (\n <DropdownTags\n selectedItems={selectedItems}\n getTestId={getTestId}\n disabled={disabled}\n onRemove={handleRemoveTag}\n />\n )}\n <input\n {...(inputProps as React.InputHTMLAttributes<HTMLInputElement>)}\n ref={inputRef as React.RefObject<HTMLInputElement>}\n id={`${fieldId}-input`}\n data-testid={getTestId(\"input\")}\n onKeyDown={handleInputKeyDown}\n onChange={handleInputChange}\n value={displayInputValue}\n placeholder={placeholder}\n className={cx(`${rootClassName}__input`, {\n [`${rootClassName}__input--negative`]: negative,\n })}\n aria-describedby={helperTextId}\n aria-invalid={!!errorText}\n disabled={disabled}\n readOnly={readOnly}\n />\n <DropdownEndAdornments\n getTestId={getTestId}\n loading={loading}\n disabled={disabled}\n negative={negative}\n isValid={isValid}\n isOpen={isOpen}\n showChevronOpen\n />\n <span\n className={cx(`${rootClassName}__frame`, {\n [`${rootClassName}__frame--negative`]: negative,\n })}\n />\n </div>\n </div>\n {isOpen && (\n <Listbox {...listboxProps} className={cx(`${rootClassName}__listbox`)}>\n {DropdownListboxItems({\n optionsToShow,\n getListboxItemProps: getListboxItemPropsWithSelection,\n multiple,\n fieldId,\n noOptionsText,\n })}\n </Listbox>\n )}\n <DropdownFooter\n errorText={errorText}\n helperText={helperText}\n helperTextId={helperTextId}\n negative={negative}\n />\n </div>\n );\n});\n\nDropdownCombobox.displayName = \"DropdownCombobox\";\n","import { useRef, useState } from \"react\";\n\nimport type { DropdownOption } from \"./dropdown.types\";\n\nexport type HighlightedOption = DropdownOption & { isSetByClickEvent?: boolean };\n\nexport type UseDropdownHighlightParams = {\n options: DropdownOption[];\n highlightFirstOption: boolean;\n};\n\nexport const useDropdownHighlight = ({\n options,\n highlightFirstOption,\n}: UseDropdownHighlightParams) => {\n const listboxRef = useRef<HTMLUListElement>(null);\n const optionRefs = useRef<Record<string, HTMLLIElement>>({});\n\n const [highlightedOption, setHighlightedOption] = useState<HighlightedOption | undefined>(\n highlightFirstOption ? options[0] : undefined\n );\n\n const scrollOptionIntoView = (optionEl: HTMLLIElement | undefined) => {\n if (optionEl) {\n const optionRect = optionEl.getBoundingClientRect();\n const listboxRect = listboxRef.current?.getBoundingClientRect() || { top: 0, bottom: 0 };\n const isOutside = optionRect.top < listboxRect.top || optionRect.bottom > listboxRect.bottom;\n if (isOutside) {\n optionEl.scrollIntoView({ block: \"nearest\" });\n }\n }\n };\n\n const findNextOption = (\n direction: \"ArrowUp\" | \"ArrowDown\",\n optionsToShow: DropdownOption[]\n ): DropdownOption | undefined => {\n const enabledList = optionsToShow.filter((o) => !o.disabled);\n if (!enabledList.length) return undefined;\n\n const currentIndex = highlightedOption\n ? enabledList.findIndex((o) => o.id === highlightedOption.id)\n : -1;\n\n if (direction === \"ArrowDown\") {\n return enabledList[(currentIndex + 1) % enabledList.length];\n }\n return enabledList[(currentIndex - 1 + enabledList.length) % enabledList.length];\n };\n\n const highlightOption = (option: DropdownOption | undefined) => {\n setHighlightedOption(option ? { ...option } : undefined);\n if (option) scrollOptionIntoView(optionRefs.current[option.id]);\n };\n\n const highlightByClick = (option: DropdownOption) => {\n if (option.id !== highlightedOption?.id) {\n setHighlightedOption({ ...option, isSetByClickEvent: true });\n }\n };\n\n const highlightSelected = (option: DropdownOption, eventType: \"CLICK\" | \"KEYBOARD\") => {\n requestAnimationFrame(() => {\n const isSetByClickEvent = eventType === \"CLICK\";\n setHighlightedOption({ ...option, isSetByClickEvent });\n scrollOptionIntoView(optionRefs.current[option.id]);\n });\n };\n\n const resetHighlight = () => {\n setHighlightedOption(undefined);\n };\n\n return {\n highlightedOption,\n listboxRef,\n optionRefs,\n findNextOption,\n highlightOption,\n highlightByClick,\n highlightSelected,\n resetHighlight,\n };\n};\n","import { useCallback, useEffect } from \"react\";\n\nexport const useOnClickOutside = (element: HTMLElement | null, callback: () => void) => {\n const handleClickOutside = useCallback(\n (event: MouseEvent) => {\n if (element && !element.contains(event.target as Node)) {\n callback();\n }\n },\n [callback, element]\n );\n\n useEffect(() => {\n document.addEventListener(\"mousedown\", handleClickOutside);\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n };\n }, [handleClickOutside]);\n};\n","import type { CSSProperties } from \"react\";\nimport { useCallback, useId, useRef, useState } from \"react\";\nimport type { ListboxItemProps, ListboxProps } from \"@purpur/listbox\";\n\nimport type { DropdownOption } from \"./dropdown.types\";\nimport { getFilteredOptions } from \"./useDropdownFilter\";\nimport { useDropdownHighlight } from \"./useDropdownHighlight\";\nimport { useDropdownInput } from \"./useDropdownInput\";\nimport { useOnClickOutside } from \"./useOnClickOutside\";\n\n// ── Hook params ────────────────────────────────────────────────────────\n\nexport type UseDropdownParams = {\n id: string;\n variant: \"select\" | \"combobox\";\n options: DropdownOption[];\n listboxLabel: string;\n multiple?: boolean;\n\n // Selection\n selectedOption?: DropdownOption;\n selectedOptions?: DropdownOption[];\n onSelect?: (option: DropdownOption | undefined, selectedOptions: DropdownOption[]) => void;\n\n // Combobox-specific\n filterOption?: (inputValue: string | undefined, option: DropdownOption) => boolean;\n inputValue?: string;\n defaultInputValue?: string;\n onInputChange?: (value: string) => void;\n noOptionsText?: React.ReactNode;\n highlightFirstOption?: boolean;\n\n // Shared behaviour\n openOnFocus?: boolean;\n listboxMaxHeight?: string | number;\n disabled?: boolean;\n readOnly?: boolean;\n\n [\"data-testid\"]?: string;\n};\n\n// ── Return type ────────────────────────────────────────────────────────\n\nexport type UseDropdownReturn = {\n rootRef: React.RefObject<HTMLDivElement | null>;\n triggerContainerProps: Record<string, unknown> | null;\n triggerProps: Record<string, unknown>;\n inputProps: Record<string, unknown> | null;\n listboxProps: ListboxProps;\n getListboxItemProps: (option: DropdownOption, index: number) => ListboxItemProps;\n optionsToShow: DropdownOption[];\n isOpen: boolean;\n highlightedOption: DropdownOption | undefined;\n selectedItems: DropdownOption[];\n anchorStyle: CSSProperties;\n};\n\n// ── Hook ───────────────────────────────────────────────────────────────\n\nexport const useDropdown = ({\n id,\n variant,\n options,\n listboxLabel,\n multiple = false,\n selectedOption,\n selectedOptions = [],\n onSelect,\n filterOption,\n inputValue: controlledInputValue,\n defaultInputValue,\n onInputChange,\n noOptionsText,\n highlightFirstOption = false,\n openOnFocus = false,\n listboxMaxHeight,\n disabled = false,\n readOnly = false,\n [\"data-testid\"]: dataTestId,\n}: UseDropdownParams): UseDropdownReturn => {\n const isCombobox = variant === \"combobox\";\n const uniqueId = useId();\n\n // ── Refs ─────────────────────────────────────────────────────────────\n const rootRef = useRef<HTMLDivElement | null>(null);\n const triggerRef = useRef<HTMLButtonElement | null>(null);\n const inputRef = useRef<HTMLInputElement | null>(null);\n\n // ── Sub-hooks ────────────────────────────────────────────────────────\n const highlight = useDropdownHighlight({ options, highlightFirstOption });\n const { displayInputValue, populateInputField } = useDropdownInput({\n controlledInputValue,\n defaultInputValue,\n selectedOption,\n onInputChange,\n });\n\n // ── Open / close ────────────────────────────────────────────────────\n const [isOpen, setIsOpen] = useState(false);\n\n const closeListbox = () => {\n setIsOpen(false);\n highlight.resetHighlight();\n };\n\n useOnClickOutside(rootRef.current, closeListbox);\n\n const openListbox = ({ eventType }: { eventType: \"CLICK\" | \"KEYBOARD\" }) => {\n setIsOpen(true);\n const current = multiple ? undefined : selectedOption;\n if (current) {\n highlight.highlightSelected(current, eventType);\n }\n };\n\n // ── Derived state ───────────────────────────────────────────────────\n const resolvedSelected = multiple ? selectedOptions : selectedOption ? [selectedOption] : [];\n\n const optionsToShow = isCombobox\n ? getFilteredOptions({\n options,\n searchTerm: displayInputValue,\n filterOption,\n selectedOption,\n multiple,\n })\n : options;\n\n const showListbox = isOpen && (!!optionsToShow.length || !!noOptionsText);\n\n // ── Helpers ──────────────────────────────────────────────────────────\n const getTestId = (name: string) => (dataTestId ? `${dataTestId}-${name}` : undefined);\n\n // ── Selection ────────────────────────────────────────────────────────\n const selectOption = (option: DropdownOption | undefined) => {\n if (!option || option.disabled) return;\n\n if (multiple) {\n const isAlreadySelected = resolvedSelected.some((o) => o.id === option.id);\n const next = isAlreadySelected\n ? resolvedSelected.filter((o) => o.id !== option.id)\n : [...resolvedSelected, option];\n onSelect?.(option, next);\n if (isCombobox) {\n populateInputField(\"\");\n inputRef.current?.focus();\n }\n } else {\n onSelect?.(option, [option]);\n if (isCombobox) {\n populateInputField(option.label);\n }\n closeListbox();\n (isCombobox ? inputRef : triggerRef).current?.focus();\n }\n };\n\n // ── Navigation ───────────────────────────────────────────────────────\n const highlightNextOption = (direction: \"ArrowUp\" | \"ArrowDown\") => {\n if (!showListbox) openListbox({ eventType: \"KEYBOARD\" });\n const next = highlight.findNextOption(direction, optionsToShow);\n highlight.highlightOption(next);\n };\n\n // ── Keyboard ─────────────────────────────────────────────────────────\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (disabled || readOnly) return;\n\n switch (event.key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n event.preventDefault();\n highlightNextOption(event.key);\n break;\n case \"Enter\": {\n event.preventDefault();\n if (showListbox && highlight.highlightedOption) {\n selectOption(highlight.highlightedOption);\n } else if (!showListbox) {\n openListbox({ eventType: \"KEYBOARD\" });\n }\n break;\n }\n case \" \": {\n if (!isCombobox) {\n event.preventDefault();\n if (showListbox && highlight.highlightedOption) {\n selectOption(highlight.highlightedOption);\n } else if (!showListbox) {\n openListbox({ eventType: \"KEYBOARD\" });\n }\n }\n break;\n }\n case \"Escape\":\n event.preventDefault();\n closeListbox();\n break;\n case \"Tab\":\n closeListbox();\n break;\n case \"Home\":\n case \"End\":\n if (isCombobox) closeListbox();\n break;\n }\n };\n\n // ── Combobox input handlers ─────────────────────────────────────────\n const handleInputChange: React.ChangeEventHandler<HTMLInputElement> = (e) => {\n populateInputField(e.target.value);\n highlight.resetHighlight();\n if (!isOpen) openListbox({ eventType: \"KEYBOARD\" });\n };\n\n const handleInputMouseDown = () => {\n if (disabled || readOnly) return;\n isOpen ? closeListbox() : openListbox({ eventType: \"CLICK\" });\n };\n\n const handleInputFocus = () => {\n if (!isOpen && openOnFocus && !disabled && !readOnly) {\n openListbox({ eventType: \"KEYBOARD\" });\n }\n inputRef.current?.select();\n };\n\n const handleInputBlur = () => {\n setTimeout(() => {\n const activeEl = document.activeElement;\n // Only close when focus has moved to a real element outside the dropdown.\n // Guarding against document.body prevents a false-positive close when a\n // screen reader navigates with its virtual cursor: the input blurs but no\n // DOM element receives physical focus (activeElement falls back to body).\n if (\n activeEl !== document.body &&\n !inputRef.current?.contains(activeEl) &&\n !highlight.listboxRef.current?.contains(activeEl) &&\n !rootRef.current?.contains(activeEl)\n ) {\n closeListbox();\n if (isCombobox && !multiple) {\n populateInputField(selectedOption ? selectedOption.label : \"\");\n }\n }\n });\n };\n\n // ── Select trigger handlers ─────────────────────────────────────────\n const handleTriggerClick = () => {\n if (disabled || readOnly) return;\n isOpen ? closeListbox() : openListbox({ eventType: \"CLICK\" });\n };\n\n const handleTriggerContainerClick: React.MouseEventHandler<HTMLDivElement> = (event) => {\n if (disabled || readOnly) return;\n\n const clickedButton = (event.target as HTMLElement).closest(\"button\");\n if (clickedButton && clickedButton !== triggerRef.current) {\n return;\n }\n\n handleTriggerClick();\n };\n\n const handleTriggerFocus = () => {\n if (!isOpen && openOnFocus && !disabled && !readOnly) {\n openListbox({ eventType: \"KEYBOARD\" });\n }\n };\n\n // ── Build props ──────────────────────────────────────────────────────\n const listboxId = `${id}-listbox`;\n const createListboxItemId = (option: DropdownOption) => `${id}-listbox-item-${option.id}`;\n const anchorName = `--purpur-dropdown-${uniqueId.replace(/:/g, \"\")}`;\n const anchorStyle = { anchorName } as CSSProperties;\n const triggerContainerProps: Record<string, unknown> | null = isCombobox\n ? null\n : {\n onClick: handleTriggerContainerClick,\n };\n\n // ── Popover sync ────────────────────────────────────────────────────\n const listboxCallbackRef = useCallback(\n (node: HTMLUListElement | null) => {\n (highlight.listboxRef as React.MutableRefObject<HTMLUListElement | null>).current = node;\n if (node && typeof node.showPopover === \"function\") {\n try {\n node.showPopover();\n } catch {\n // Popover not supported or already open\n }\n }\n },\n [highlight.listboxRef]\n );\n\n const listboxProps = {\n \"aria-label\": listboxLabel,\n \"aria-expanded\": showListbox,\n \"data-testid\": getTestId(\"listbox\"),\n id: listboxId,\n ref: listboxCallbackRef,\n onMouseLeave: () => highlight.resetHighlight(),\n popover: \"manual\",\n style: {\n ...(listboxMaxHeight\n ? {\n maxHeight:\n typeof listboxMaxHeight === \"number\" ? `${listboxMaxHeight}px` : listboxMaxHeight,\n }\n : {}),\n positionAnchor: anchorName,\n } as CSSProperties,\n } as ListboxProps;\n\n const getListboxItemProps = (option: DropdownOption, index: number): ListboxItemProps => {\n const isSelected = resolvedSelected.some((o) => o.id === option.id);\n const { highlightedOption } = highlight;\n\n const highlighted =\n (option.id === highlightedOption?.id ||\n (highlightFirstOption && !highlightedOption && index === 0)) &&\n !highlightedOption?.isSetByClickEvent;\n\n return {\n \"data-testid\": getTestId(`listbox-item-${option.id}`),\n id: createListboxItemId(option),\n key: option.id,\n onMouseMove: () => highlight.highlightByClick(option),\n onMouseUp: () => selectOption(option),\n ref: (el) => {\n if (el) highlight.optionRefs.current[option.id] = el;\n },\n tabIndex: -1,\n selected: isSelected,\n disabled: option.disabled,\n highlighted,\n hovered: option.id === highlightedOption?.id && !!highlightedOption?.isSetByClickEvent,\n \"aria-selected\": isSelected,\n };\n };\n\n const triggerProps: Record<string, unknown> = isCombobox\n ? {}\n : {\n ref: triggerRef,\n type: \"button\" as const,\n role: \"combobox\",\n \"aria-haspopup\": \"listbox\",\n \"aria-expanded\": showListbox,\n \"aria-controls\": listboxId,\n \"aria-disabled\": disabled,\n \"data-testid\": getTestId(\"trigger\"),\n id: `${id}-trigger`,\n onKeyDown: handleKeyDown,\n onFocus: handleTriggerFocus,\n disabled,\n tabIndex: disabled ? -1 : 0,\n style: anchorStyle,\n };\n\n const inputProps: Record<string, unknown> | null = isCombobox\n ? {\n ref: inputRef,\n role: \"combobox\",\n \"aria-autocomplete\": \"list\" as const,\n \"aria-expanded\": showListbox,\n \"aria-controls\": listboxId,\n \"aria-activedescendant\": highlight.highlightedOption\n ? createListboxItemId(highlight.highlightedOption)\n : undefined,\n \"data-testid\": getTestId(\"input\"),\n autoComplete: \"off\",\n id: `${id}-input`,\n type: \"text\",\n value: displayInputValue,\n onChange: handleInputChange,\n onMouseDown: handleInputMouseDown,\n onFocus: handleInputFocus,\n onBlur: handleInputBlur,\n onKeyDown: handleKeyDown,\n disabled,\n readOnly,\n }\n : null;\n\n return {\n rootRef,\n triggerContainerProps,\n triggerProps,\n inputProps,\n listboxProps,\n getListboxItemProps,\n optionsToShow,\n isOpen: showListbox,\n highlightedOption: highlight.highlightedOption,\n selectedItems: resolvedSelected,\n anchorStyle,\n };\n};\n","import React, { forwardRef, useId } from \"react\";\nimport { Listbox } from \"@purpur/listbox\";\n\nimport type { DropdownOption, SelectProps } from \"./dropdown.types\";\nimport {\n cx,\n DropdownEndAdornments,\n DropdownFooter,\n DropdownLabel,\n DropdownListboxItems,\n DropdownTags,\n rootClassName,\n} from \"./dropdown-shared\";\nimport { useDropdown } from \"./useDropdown\";\n\nexport const DropdownSelect = forwardRef<HTMLDivElement, SelectProps>((props, ref) => {\n const {\n id: propId,\n label,\n options,\n className,\n errorText,\n helperText,\n placeholder,\n negative = false,\n readOnly = false,\n disabled = false,\n required = false,\n valid = false,\n loading = false,\n multiple = false,\n selectedOption,\n selectedOptions = [],\n onSelect,\n openOnFocus = false,\n listboxMaxHeight,\n listboxLabel,\n [\"data-testid\"]: dataTestId,\n } = props;\n\n const randomId = useId();\n const fieldId = propId ?? randomId;\n const getTestId = (name: string) => (dataTestId ? `${dataTestId}-${name}` : undefined);\n const isValid = !!valid && !errorText;\n const helperTextId = `${fieldId}-helper-text`;\n\n const dropdown = useDropdown({\n id: fieldId,\n variant: \"select\",\n options,\n listboxLabel: listboxLabel || label || \"Options\",\n multiple,\n selectedOption,\n selectedOptions,\n onSelect,\n openOnFocus,\n listboxMaxHeight,\n disabled,\n readOnly,\n [\"data-testid\"]: dataTestId,\n });\n\n const setRootRef = (node: HTMLDivElement | null) => {\n (dropdown.rootRef as React.RefObject<HTMLDivElement | null>).current = node;\n if (typeof ref === \"function\") ref(node);\n else if (ref) (ref as React.RefObject<HTMLDivElement | null>).current = node;\n };\n\n const {\n triggerContainerProps,\n triggerProps,\n listboxProps,\n getListboxItemProps,\n optionsToShow,\n isOpen,\n selectedItems,\n anchorStyle,\n } = dropdown;\n\n const triggerButtonProps = {\n ...(triggerProps as React.ButtonHTMLAttributes<HTMLButtonElement>),\n };\n delete triggerButtonProps.style;\n\n const handleRemoveTag = (option: DropdownOption) => {\n const next = selectedItems.filter((o) => o.id !== option.id);\n onSelect?.(option, next);\n };\n\n const displayLabel = multiple\n ? selectedItems.length === 0\n ? placeholder || \"\"\n : \"\"\n : selectedOption?.label || placeholder || \"\";\n\n const wrapperClassName = cx(rootClassName, className, {\n [`${rootClassName}--negative`]: negative,\n });\n\n return (\n <div ref={setRootRef} className={wrapperClassName}>\n <DropdownLabel\n fieldId={fieldId}\n htmlForSuffix=\"trigger\"\n label={label}\n getTestId={getTestId}\n disabled={disabled}\n negative={negative}\n required={required}\n />\n <div className={cx(`${rootClassName}__field-row`)}>\n <div\n {...(triggerContainerProps as React.HTMLAttributes<HTMLDivElement>)}\n className={cx(`${rootClassName}__trigger-container`, {\n [`${rootClassName}__trigger-container--error`]: !!errorText,\n [`${rootClassName}__trigger-container--is-valid`]: isValid,\n [`${rootClassName}__trigger-container--negative`]: negative,\n [`${rootClassName}__trigger-container--disabled`]: disabled,\n [`${rootClassName}__trigger-container--readonly`]: readOnly && !disabled,\n [`${rootClassName}__trigger-container--has-tags`]: multiple && selectedItems.length > 0,\n })}\n style={anchorStyle}\n >\n {multiple && (\n <DropdownTags\n selectedItems={selectedItems}\n getTestId={getTestId}\n disabled={disabled}\n onRemove={handleRemoveTag}\n isSelect\n />\n )}\n <button\n {...triggerButtonProps}\n className={cx(`${rootClassName}__trigger`, {\n [`${rootClassName}__trigger--is-valid`]: isValid,\n [`${rootClassName}__trigger--negative`]: negative,\n [`${rootClassName}__trigger--disabled`]: disabled,\n [`${rootClassName}__trigger--readonly`]: readOnly && !disabled,\n [`${rootClassName}__trigger--placeholder`]: !selectedItems.length,\n })}\n aria-describedby={helperTextId}\n >\n <span className={cx(`${rootClassName}__trigger-text`)}>{displayLabel}</span>\n </button>\n <DropdownEndAdornments\n getTestId={getTestId}\n loading={loading}\n disabled={disabled}\n negative={negative}\n isValid={isValid}\n isOpen={isOpen}\n readOnly={readOnly}\n showChevronOpen\n />\n <span\n className={cx(`${rootClassName}__frame`, {\n [`${rootClassName}__frame--negative`]: negative,\n })}\n />\n </div>\n </div>\n {isOpen && (\n <Listbox {...listboxProps} className={cx(`${rootClassName}__listbox`)}>\n {DropdownListboxItems({\n optionsToShow,\n getListboxItemProps,\n multiple,\n fieldId,\n })}\n </Listbox>\n )}\n <DropdownFooter\n errorText={errorText}\n helperText={helperText}\n helperTextId={helperTextId}\n negative={negative}\n />\n </div>\n );\n});\n\nDropdownSelect.displayName = \"DropdownSelect\";\n","import React, { forwardRef } from \"react\";\n\nimport type { ComboboxProps, DropdownProps, SelectProps } from \"./dropdown.types\";\nimport { DropdownCombobox } from \"./dropdown-combobox\";\nimport { DropdownSelect } from \"./dropdown-select\";\n\nexport const Dropdown = forwardRef<HTMLDivElement, DropdownProps>((props, ref) => {\n if (props.combobox) {\n return <DropdownCombobox ref={ref} {...(props as ComboboxProps)} />;\n }\n\n return <DropdownSelect ref={ref} {...(props as SelectProps)} />;\n});\n\nDropdown.displayName = \"Dropdown\";\n\nexport type { ComboboxProps, DropdownOption, DropdownProps, SelectProps } from \"./dropdown.types\";\nexport { useDropdown } from \"./useDropdown\";\n"],"names":["cx","c","styles","rootClassName","DropdownLabel","fieldId","htmlForSuffix","label","getTestId","disabled","negative","required","jsxs","Label","jsx","DropdownEndAdornments","loading","isValid","isOpen","readOnly","showChevronOpen","Spinner","Fragment","IconCheckCircleFilled","IconChevronDown","DropdownTags","selectedItems","onRemove","isSelect","DismissableChipGroup","item","DropdownFooter","errorText","helperText","helperTextId","FieldErrorText","FieldHelperText","DropdownListboxItems","optionsToShow","getListboxItemProps","multiple","noOptionsText","Listbox","option","index","key","selected","itemProps","Checkbox","filterOptions","options","searchTerm","filterOption","chunks","chunk","getFilteredOptions","selectedOption","useDropdownInput","controlledInputValue","defaultInputValue","onInputChange","internalInputValue","setInternalInputValue","useState","value","DropdownCombobox","forwardRef","props","ref","propId","className","placeholder","valid","selectedOptions","onSelect","openOnFocus","listboxMaxHeight","listboxLabel","inputValue","highlightFirstOption","dataTestId","randomId","useId","name","displayInputValue","populateInputField","handleAutocompleteSelect","next","o","rootRef","inputRef","inputProps","listboxProps","openListbox","anchorStyle","useAutocomplete","setRootRef","node","getListboxItemPropsWithSelection","isSelected","handleRemoveTag","handleInputKeyDown","event","handleInputChange","e","wrapperClassName","useDropdownHighlight","listboxRef","useRef","optionRefs","highlightedOption","setHighlightedOption","scrollOptionIntoView","optionEl","optionRect","listboxRect","direction","enabledList","currentIndex","eventType","useOnClickOutside","element","callback","handleClickOutside","useCallback","useEffect","useDropdown","id","variant","isCombobox","uniqueId","triggerRef","highlight","setIsOpen","closeListbox","current","resolvedSelected","showListbox","selectOption","highlightNextOption","handleKeyDown","handleInputMouseDown","handleInputFocus","handleInputBlur","activeEl","handleTriggerClick","handleTriggerContainerClick","clickedButton","handleTriggerFocus","listboxId","createListboxItemId","anchorName","triggerContainerProps","listboxCallbackRef","highlighted","el","triggerProps","DropdownSelect","dropdown","triggerButtonProps","displayLabel","Dropdown"],"mappings":"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"}
|