@actabldesign/bellhop-core 0.0.3 → 0.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/bellhop-core/bellhop-core.esm.js +2 -0
- package/dist/bellhop-core/bellhop-core.esm.js.map +1 -0
- package/dist/bellhop-core/bh-accordion-item.entry.esm.js.map +1 -0
- package/dist/bellhop-core/bh-button.bh-loader-spinner.entry.esm.js.map +1 -0
- package/dist/bellhop-core/bh-checkbox.bh-radio-button.entry.esm.js.map +1 -0
- package/dist/bellhop-core/bh-data-grid.entry.esm.js.map +1 -0
- package/dist/bellhop-core/bh-date-picker-content.entry.esm.js.map +1 -0
- package/dist/bellhop-core/bh-date-picker.entry.esm.js.map +1 -0
- package/dist/bellhop-core/bh-dropdown.bh-logo-box.bh-nav-item.entry.esm.js.map +1 -0
- package/dist/bellhop-core/bh-empty-state.bh-pagination.bh-skeleton-loader.entry.esm.js.map +1 -0
- package/dist/bellhop-core/bh-input-text.bh-picker-menu.entry.esm.js.map +1 -0
- package/dist/bellhop-core/index.esm.js +2 -0
- package/dist/bellhop-core/index.esm.js.map +1 -0
- package/dist/bellhop-core/p-03e93cd8.entry.js +2 -0
- package/dist/bellhop-core/p-0438e0a9.entry.js +2 -0
- package/dist/bellhop-core/p-086e8c86.entry.js +2 -0
- package/dist/bellhop-core/p-09f3464e.entry.js +2 -0
- package/dist/bellhop-core/p-10967cab.entry.js +2 -0
- package/dist/bellhop-core/p-10967cab.entry.js.map +1 -0
- package/dist/bellhop-core/p-20d680ce.entry.js +2 -0
- package/dist/bellhop-core/p-2310cb6e.entry.js +13 -0
- package/dist/bellhop-core/p-2310cb6e.entry.js.map +1 -0
- package/dist/bellhop-core/p-239c7e6b.entry.js +2 -0
- package/dist/bellhop-core/p-23b74b40.entry.js +2 -0
- package/dist/bellhop-core/p-2c796978.entry.js +2 -0
- package/dist/bellhop-core/p-356a2ed7.entry.js +2 -0
- package/dist/bellhop-core/p-363dce47.entry.js +2 -0
- package/dist/bellhop-core/p-3719852a.entry.js +2 -0
- package/dist/bellhop-core/p-44241bad.entry.js +2 -0
- package/dist/bellhop-core/p-496fca9b.entry.js +2 -0
- package/dist/bellhop-core/p-496fca9b.entry.js.map +1 -0
- package/dist/bellhop-core/p-4a14cbb5.entry.js +2 -0
- package/dist/bellhop-core/p-52e877e0.entry.js +2 -0
- package/dist/bellhop-core/p-56b857f5.entry.js +2 -0
- package/dist/bellhop-core/p-5760ce66.entry.js +2 -0
- package/dist/bellhop-core/p-57ac382d.entry.js +2 -0
- package/dist/bellhop-core/p-58879213.entry.js +2 -0
- package/dist/bellhop-core/p-5ab50add.entry.js +2 -0
- package/dist/bellhop-core/p-6433b0a7.entry.js +2 -0
- package/dist/bellhop-core/p-67452ed0.entry.js +2 -0
- package/dist/bellhop-core/p-686dea4a.entry.js +2 -0
- package/dist/bellhop-core/p-69f85850.entry.js +2 -0
- package/dist/bellhop-core/p-70ee270c.entry.js +2 -0
- package/dist/bellhop-core/p-859f45da.entry.js +2 -0
- package/dist/bellhop-core/p-860be0be.entry.js +2 -0
- package/dist/bellhop-core/p-870fc023.entry.js +2 -0
- package/dist/bellhop-core/p-87fb26a0.entry.js +2 -0
- package/dist/bellhop-core/p-8981025c.entry.js +2 -0
- package/dist/bellhop-core/p-8981025c.entry.js.map +1 -0
- package/dist/bellhop-core/p-90b9047d.entry.js +2 -0
- package/dist/bellhop-core/p-94d2d599.entry.js +2 -0
- package/dist/bellhop-core/p-9a585c1a.entry.js +2 -0
- package/dist/bellhop-core/p-CIj6YHfo.js +2 -0
- package/dist/bellhop-core/p-CIj6YHfo.js.map +1 -0
- package/dist/bellhop-core/p-DXAL-jSE.js +3 -0
- package/dist/bellhop-core/p-DXAL-jSE.js.map +1 -0
- package/dist/bellhop-core/p-DshiN5nT.js +2 -0
- package/dist/bellhop-core/p-DshiN5nT.js.map +1 -0
- package/dist/bellhop-core/p-I9CPXdBF.js +2 -0
- package/dist/bellhop-core/p-I9CPXdBF.js.map +1 -0
- package/dist/bellhop-core/p-ab2b037c.entry.js +2 -0
- package/dist/bellhop-core/p-ab9c5351.entry.js +2 -0
- package/dist/bellhop-core/p-abe24947.entry.js +2 -0
- package/dist/bellhop-core/p-adcd2e15.entry.js +2 -0
- package/dist/bellhop-core/p-afd0e309.entry.js +2 -0
- package/dist/bellhop-core/p-b1cb34e9.entry.js +2 -0
- package/dist/bellhop-core/p-b546cd23.entry.js +2 -0
- package/dist/bellhop-core/p-b546cd23.entry.js.map +1 -0
- package/dist/bellhop-core/p-b7801d25.entry.js +2 -0
- package/dist/bellhop-core/p-b7801d25.entry.js.map +1 -0
- package/dist/bellhop-core/p-c8fb7f34.entry.js +2 -0
- package/dist/bellhop-core/p-c8fb7f34.entry.js.map +1 -0
- package/dist/bellhop-core/p-cdd593fb.entry.js +2 -0
- package/dist/bellhop-core/p-d4bfd30d.entry.js +2 -0
- package/dist/bellhop-core/p-dcaa20e2.entry.js +2 -0
- package/dist/bellhop-core/p-dd43d560.entry.js +2 -0
- package/dist/bellhop-core/p-e190ac50.entry.js +2 -0
- package/dist/bellhop-core/p-e86780b6.entry.js +2 -0
- package/dist/bellhop-core/p-e99bc91a.entry.js +2 -0
- package/dist/bellhop-core/p-e9ed7c17.entry.js +2 -0
- package/dist/bellhop-core/p-ef47dcd1.entry.js +2 -0
- package/dist/bellhop-core/p-f5468da0.entry.js +2 -0
- package/dist/bellhop-core/p-f5468da0.entry.js.map +1 -0
- package/dist/bellhop-core/p-f6e1b47c.entry.js +2 -0
- package/dist/bellhop-core/p-f7c7416d.entry.js +2 -0
- package/dist/cjs/bellhop-core.cjs.js +25 -0
- package/dist/cjs/bellhop-core.cjs.js.map +1 -0
- package/dist/cjs/bh-accordion-item.cjs.entry.js +82 -0
- package/dist/cjs/bh-accordion-item.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-accordion.cjs.entry.js +119 -0
- package/dist/cjs/bh-appbar.cjs.entry.js +83 -0
- package/dist/cjs/bh-autocomplete-menu_2.cjs.entry.js +177 -0
- package/dist/cjs/bh-avatar-add.cjs.entry.js +75 -0
- package/dist/cjs/bh-avatar-stacked.cjs.entry.js +94 -0
- package/dist/cjs/bh-avatar.cjs.entry.js +93 -0
- package/dist/cjs/bh-badge-dot_2.cjs.entry.js +134 -0
- package/dist/cjs/bh-badge.cjs.entry.js +71 -0
- package/dist/cjs/bh-bar-chart.cjs.entry.js +164 -0
- package/dist/cjs/bh-button-CKYE8jYL.js +117 -0
- package/dist/cjs/bh-button-CKYE8jYL.js.map +1 -0
- package/dist/cjs/bh-button-icon.cjs.entry.js +74 -0
- package/dist/cjs/bh-button.bh-loader-spinner.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-button_2.cjs.entry.js +47 -0
- package/dist/cjs/bh-card-footer.cjs.entry.js +30 -0
- package/dist/cjs/bh-card-header.cjs.entry.js +74 -0
- package/dist/cjs/bh-card.cjs.entry.js +48 -0
- package/dist/cjs/bh-chart-tooltip.cjs.entry.js +57 -0
- package/dist/cjs/bh-checkbox-group-item.cjs.entry.js +142 -0
- package/dist/cjs/bh-checkbox-group.cjs.entry.js +100 -0
- package/dist/cjs/bh-checkbox.bh-radio-button.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-checkbox_2.cjs.entry.js +267 -0
- package/dist/cjs/bh-container-footer.cjs.entry.js +38 -0
- package/dist/cjs/bh-container.cjs.entry.js +26 -0
- package/dist/cjs/bh-data-grid.cjs.entry.js +4230 -0
- package/dist/cjs/bh-data-grid.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-date-picker-content.cjs.entry.js +370 -0
- package/dist/cjs/bh-date-picker-content.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-date-picker.cjs.entry.js +173 -0
- package/dist/cjs/bh-date-picker.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-date-range-picker-content.cjs.entry.js +151 -0
- package/dist/cjs/bh-date-range-picker.cjs.entry.js +167 -0
- package/dist/cjs/bh-dropdown-menu.cjs.entry.js +114 -0
- package/dist/cjs/bh-dropdown.bh-logo-box.bh-nav-item.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-dropdown_3.cjs.entry.js +1887 -0
- package/dist/cjs/bh-empty-state.bh-pagination.bh-skeleton-loader.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-empty-state_3.cjs.entry.js +115 -0
- package/dist/cjs/bh-featured-icon.cjs.entry.js +41 -0
- package/dist/cjs/bh-illustrations.cjs.entry.js +65 -0
- package/dist/cjs/bh-input-autocomplete.cjs.entry.js +342 -0
- package/dist/cjs/bh-input-number.cjs.entry.js +307 -0
- package/dist/cjs/bh-input-password.cjs.entry.js +182 -0
- package/dist/cjs/bh-input-text.bh-picker-menu.entry.cjs.js.map +1 -0
- package/dist/cjs/bh-input-text_2.cjs.entry.js +347 -0
- package/dist/cjs/bh-input-verification.cjs.entry.js +203 -0
- package/dist/cjs/bh-label-DRC8k-B9.js +110 -0
- package/dist/cjs/bh-label-DRC8k-B9.js.map +1 -0
- package/dist/cjs/bh-label_2.cjs.entry.js +48 -0
- package/dist/cjs/bh-modal-actions.cjs.entry.js +66 -0
- package/dist/cjs/bh-modal-header.cjs.entry.js +76 -0
- package/dist/cjs/bh-modal.cjs.entry.js +56 -0
- package/dist/cjs/bh-month-picker-content.cjs.entry.js +189 -0
- package/dist/cjs/bh-month-picker.cjs.entry.js +152 -0
- package/dist/cjs/bh-notification.cjs.entry.js +128 -0
- package/dist/cjs/bh-page-navigation-child.cjs.entry.js +48 -0
- package/dist/cjs/bh-page-navigation-multi-level_2.cjs.entry.js +146 -0
- package/dist/cjs/bh-page-navigation.cjs.entry.js +72 -0
- package/dist/cjs/bh-pagination-BJ1azyCc.js +152 -0
- package/dist/cjs/bh-pagination-BJ1azyCc.js.map +1 -0
- package/dist/cjs/bh-pie-chart.cjs.entry.js +157 -0
- package/dist/cjs/bh-popover.cjs.entry.js +100 -0
- package/dist/cjs/bh-product-switcher.cjs.entry.js +102 -0
- package/dist/cjs/bh-property-switcher.cjs.entry.js +231 -0
- package/dist/cjs/bh-sidebar.cjs.entry.js +110 -0
- package/dist/cjs/bh-tab-item.cjs.entry.js +54 -0
- package/dist/cjs/bh-tabs.cjs.entry.js +52 -0
- package/dist/cjs/bh-textarea.cjs.entry.js +161 -0
- package/dist/cjs/bh-toggle.cjs.entry.js +141 -0
- package/dist/cjs/bh-trend-chart.cjs.entry.js +121 -0
- package/dist/cjs/index-BVJ_Kket.js +1959 -0
- package/dist/cjs/index-BVJ_Kket.js.map +1 -0
- package/dist/cjs/index.cjs.js +34 -0
- package/dist/cjs/index.cjs.js.map +1 -0
- package/dist/cjs/loader.cjs.js +13 -0
- package/dist/collection/collection-manifest.json +78 -0
- package/dist/collection/components/bh-accordion/bh-accordion.js +227 -0
- package/dist/collection/components/bh-accordion-item/bh-accordion-item.css +119 -0
- package/dist/collection/components/bh-accordion-item/bh-accordion-item.js +207 -0
- package/dist/collection/components/bh-appbar/bh-appbar.js +270 -0
- package/dist/collection/components/bh-autocomplete-menu/bh-autocomplete-menu.js +301 -0
- package/dist/collection/components/bh-avatar/bh-avatar.js +266 -0
- package/dist/collection/components/bh-avatar-add/bh-avatar-add.js +194 -0
- package/dist/collection/components/bh-avatar-stacked/bh-avatar-stacked.js +211 -0
- package/dist/collection/components/bh-badge/bh-badge.js +250 -0
- package/dist/collection/components/bh-badge-dot/bh-badge-dot.js +113 -0
- package/dist/collection/components/bh-bar-chart/bh-bar-chart.css +363 -0
- package/dist/collection/components/bh-bar-chart/bh-bar-chart.js +316 -0
- package/dist/collection/components/bh-breadcrumbs/bh-breadcrumbs.js +231 -0
- package/dist/collection/components/bh-button/bh-button.js +350 -0
- package/dist/collection/components/bh-button-icon/bh-button-icon.js +259 -0
- package/dist/collection/components/bh-card/bh-card.js +139 -0
- package/dist/collection/components/bh-card-footer/bh-card-footer.js +81 -0
- package/dist/collection/components/bh-card-header/bh-card-header.js +348 -0
- package/dist/collection/components/bh-chart-tooltip/bh-chart-tooltip.css +301 -0
- package/dist/collection/components/bh-chart-tooltip/bh-chart-tooltip.js +226 -0
- package/dist/collection/components/bh-checkbox/bh-checkbox.js +383 -0
- package/dist/collection/components/bh-checkbox/bh-checkbox.js.map +1 -0
- package/dist/collection/components/bh-checkbox-group/bh-checkbox-group.js +218 -0
- package/dist/collection/components/bh-checkbox-group-item/bh-checkbox-group-item.js +402 -0
- package/dist/collection/components/bh-container/bh-container.js +51 -0
- package/dist/collection/components/bh-container-footer/bh-container-footer.js +106 -0
- package/dist/collection/components/bh-data-grid/bh-data-grid.css +610 -0
- package/dist/collection/components/bh-data-grid/bh-data-grid.js +1933 -0
- package/dist/collection/components/bh-data-grid/bh-data-grid.js.map +1 -0
- package/dist/collection/components/bh-data-grid/bh-data-grid.types.js +2 -0
- package/dist/collection/components/bh-data-grid/bh-data-grid.types.js.map +1 -0
- package/dist/collection/components/bh-date-picker/bh-date-picker.css +251 -0
- package/dist/collection/components/bh-date-picker/bh-date-picker.js +485 -0
- package/dist/collection/components/bh-date-picker-content/bh-date-picker-content.css +541 -0
- package/dist/collection/components/bh-date-picker-content/bh-date-picker-content.js +711 -0
- package/dist/collection/components/bh-date-range-picker/bh-date-range-picker.css +247 -0
- package/dist/collection/components/bh-date-range-picker/bh-date-range-picker.js +528 -0
- package/dist/collection/components/bh-date-range-picker-content/bh-date-range-picker-content.css +275 -0
- package/dist/collection/components/bh-date-range-picker-content/bh-date-range-picker-content.js +338 -0
- package/dist/collection/components/bh-dropdown/bh-dropdown.css +51 -0
- package/dist/collection/components/bh-dropdown/bh-dropdown.js +569 -0
- package/dist/collection/components/bh-dropdown/bh-dropdown.js.map +1 -0
- package/dist/collection/components/bh-dropdown-menu/bh-dropdown-menu.js +262 -0
- package/dist/collection/components/bh-empty-state/bh-empty-state.js +306 -0
- package/dist/collection/components/bh-featured-icon/bh-featured-icon.js +144 -0
- package/dist/collection/components/bh-illustrations/bh-illustrations.css +328 -0
- package/dist/collection/components/bh-illustrations/bh-illustrations.js +174 -0
- package/dist/collection/components/bh-input-autocomplete/bh-input-autocomplete.css +301 -0
- package/dist/collection/components/bh-input-autocomplete/bh-input-autocomplete.js +872 -0
- package/dist/collection/components/bh-input-number/bh-input-number.js +818 -0
- package/dist/collection/components/bh-input-password/bh-input-password.js +581 -0
- package/dist/collection/components/bh-input-text/bh-input-text.js +696 -0
- package/dist/collection/components/bh-input-verification/bh-input-verification.js +523 -0
- package/dist/collection/components/bh-label/bh-label.js +302 -0
- package/dist/collection/components/bh-loader-spinner/bh-loader-spinner.css +153 -0
- package/dist/collection/components/bh-loader-spinner/bh-loader-spinner.js +182 -0
- package/dist/collection/components/bh-logo-box/bh-logo-box.js +229 -0
- package/dist/collection/components/bh-logo-box/bh-logo-box.js.map +1 -0
- package/dist/collection/components/bh-modal/bh-modal.js +144 -0
- package/dist/collection/components/bh-modal-actions/bh-modal-actions.js +208 -0
- package/dist/collection/components/bh-modal-header/bh-modal-header.js +275 -0
- package/dist/collection/components/bh-month-picker/bh-month-picker.css +251 -0
- package/dist/collection/components/bh-month-picker/bh-month-picker.js +444 -0
- package/dist/collection/components/bh-month-picker-content/bh-month-picker-content.css +406 -0
- package/dist/collection/components/bh-month-picker-content/bh-month-picker-content.js +437 -0
- package/dist/collection/components/bh-notification/bh-notification.js +324 -0
- package/dist/collection/components/bh-page-navigation/bh-page-navigation.css +253 -0
- package/dist/collection/components/bh-page-navigation/bh-page-navigation.js +146 -0
- package/dist/collection/components/bh-page-navigation-child/bh-page-navigation-child.css +281 -0
- package/dist/collection/components/bh-page-navigation-child/bh-page-navigation-child.js +148 -0
- package/dist/collection/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.css +372 -0
- package/dist/collection/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.js +268 -0
- package/dist/collection/components/bh-page-navigation-single-level/bh-page-navigation-single-level.js +126 -0
- package/dist/collection/components/bh-pagination/bh-pagination.css +244 -0
- package/dist/collection/components/bh-pagination/bh-pagination.js +448 -0
- package/dist/collection/components/bh-pagination/bh-pagination.js.map +1 -0
- package/dist/collection/components/bh-picker-menu/bh-picker-menu.css +284 -0
- package/dist/collection/components/bh-pie-chart/bh-pie-chart.css +292 -0
- package/dist/collection/components/bh-pie-chart/bh-pie-chart.js +280 -0
- package/dist/collection/components/bh-popover/bh-popover.js +326 -0
- package/dist/collection/components/bh-product-switcher/bh-product-switcher.js +226 -0
- package/dist/collection/components/bh-property-switcher/bh-property-switcher.js +360 -0
- package/dist/collection/components/bh-radio-button/bh-radio-button.js +292 -0
- package/dist/collection/components/bh-sidebar/bh-nav-item.js +157 -0
- package/dist/collection/components/bh-sidebar/bh-sidebar.js +344 -0
- package/dist/collection/components/bh-skeleton-loader/bh-skeleton-loader.js +99 -0
- package/dist/collection/components/bh-tab-item/bh-tab-item.js +158 -0
- package/dist/collection/components/bh-tabs/bh-tabs.js +178 -0
- package/dist/collection/components/bh-tag/bh-tag.js +238 -0
- package/dist/collection/components/bh-textarea/bh-textarea.js +569 -0
- package/dist/collection/components/bh-toggle/bh-toggle.js +369 -0
- package/dist/collection/components/bh-tooltip/bh-tooltip.js +162 -0
- package/dist/collection/components/bh-trend-chart/bh-trend-chart.css +299 -0
- package/dist/collection/components/bh-trend-chart/bh-trend-chart.js +256 -0
- package/dist/collection/index.js +24 -0
- package/dist/collection/index.js.map +1 -0
- package/dist/components/bh-accordion-item.js +111 -0
- package/dist/components/bh-accordion-item.js.map +1 -0
- package/dist/components/bh-accordion.js +147 -0
- package/dist/components/bh-appbar.js +128 -0
- package/dist/components/bh-autocomplete-menu.js +9 -0
- package/dist/components/bh-avatar-add.js +9 -0
- package/dist/components/bh-avatar-stacked.js +141 -0
- package/dist/components/bh-avatar.js +9 -0
- package/dist/components/bh-badge-dot.js +9 -0
- package/dist/components/bh-badge.js +9 -0
- package/dist/components/bh-bar-chart.js +205 -0
- package/dist/components/bh-breadcrumbs.js +9 -0
- package/dist/components/bh-button-icon.js +9 -0
- package/dist/components/bh-button.js +9 -0
- package/dist/components/bh-card-footer.js +9 -0
- package/dist/components/bh-card-header.js +9 -0
- package/dist/components/bh-card.js +9 -0
- package/dist/components/bh-chart-tooltip.js +9 -0
- package/dist/components/bh-checkbox-group-item.js +9 -0
- package/dist/components/bh-checkbox-group.js +9 -0
- package/dist/components/bh-checkbox.js +9 -0
- package/dist/components/bh-container-footer.js +74 -0
- package/dist/components/bh-container.js +49 -0
- package/dist/components/bh-data-grid.js +9 -0
- package/dist/components/bh-date-picker-content.js +9 -0
- package/dist/components/bh-date-picker.js +267 -0
- package/dist/components/bh-date-picker.js.map +1 -0
- package/dist/components/bh-date-range-picker-content.js +9 -0
- package/dist/components/bh-date-range-picker.js +269 -0
- package/dist/components/bh-dropdown-menu.js +9 -0
- package/dist/components/bh-dropdown.js +9 -0
- package/dist/components/bh-empty-state.js +9 -0
- package/dist/components/bh-featured-icon.js +9 -0
- package/dist/components/bh-illustrations.js +92 -0
- package/dist/components/bh-input-autocomplete.js +433 -0
- package/dist/components/bh-input-number.js +370 -0
- package/dist/components/bh-input-password.js +229 -0
- package/dist/components/bh-input-text.js +9 -0
- package/dist/components/bh-input-verification.js +255 -0
- package/dist/components/bh-label.js +9 -0
- package/dist/components/bh-loader-spinner.js +9 -0
- package/dist/components/bh-logo-box.js +9 -0
- package/dist/components/bh-modal-actions.js +105 -0
- package/dist/components/bh-modal-header.js +119 -0
- package/dist/components/bh-modal.js +9 -0
- package/dist/components/bh-month-picker-content.js +9 -0
- package/dist/components/bh-month-picker.js +233 -0
- package/dist/components/bh-nav-item.js +9 -0
- package/dist/components/bh-notification.js +175 -0
- package/dist/components/bh-page-navigation-child.js +9 -0
- package/dist/components/bh-page-navigation-multi-level.js +9 -0
- package/dist/components/bh-page-navigation-single-level.js +9 -0
- package/dist/components/bh-page-navigation.js +129 -0
- package/dist/components/bh-pagination.d.ts +11 -0
- package/dist/components/bh-pagination.js +9 -0
- package/dist/components/bh-pagination.js.map +1 -0
- package/dist/components/bh-picker-menu.js +9 -0
- package/dist/components/bh-pie-chart.js +194 -0
- package/dist/components/bh-popover.js +131 -0
- package/dist/components/bh-product-switcher.js +9 -0
- package/dist/components/bh-property-switcher.js +261 -0
- package/dist/components/bh-radio-button.js +9 -0
- package/dist/components/bh-sidebar.js +195 -0
- package/dist/components/bh-skeleton-loader.js +9 -0
- package/dist/components/bh-skeleton-loader.js.map +1 -0
- package/dist/components/bh-tab-item.js +80 -0
- package/dist/components/bh-tabs.js +78 -0
- package/dist/components/bh-tag.js +9 -0
- package/dist/components/bh-textarea.js +207 -0
- package/dist/components/bh-toggle.js +9 -0
- package/dist/components/bh-tooltip.js +9 -0
- package/dist/components/bh-trend-chart.js +149 -0
- package/dist/components/index.js +17 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/p-3wrr5uYj.js +84 -0
- package/dist/components/p-3wrr5uYj.js.map +1 -0
- package/dist/components/p-B-oXID22.js +214 -0
- package/dist/components/p-B-oXID22.js.map +1 -0
- package/dist/components/p-B7e9Vn80.js +123 -0
- package/dist/components/p-B7e9Vn80.js.map +1 -0
- package/dist/components/p-BAKX4y5m.js +158 -0
- package/dist/components/p-BAKX4y5m.js.map +1 -0
- package/dist/components/p-BE4kximA.js +78 -0
- package/dist/components/p-BE4kximA.js.map +1 -0
- package/dist/components/p-BM_aWCWB.js +92 -0
- package/dist/components/p-BM_aWCWB.js.map +1 -0
- package/dist/components/p-BsB67vNb.js +100 -0
- package/dist/components/p-BsB67vNb.js.map +1 -0
- package/dist/components/p-BsgViq32.js +189 -0
- package/dist/components/p-BsgViq32.js.map +1 -0
- package/dist/components/p-BuUjUqUh.js +224 -0
- package/dist/components/p-BuUjUqUh.js.map +1 -0
- package/dist/components/p-C24VI6pZ.js +71 -0
- package/dist/components/p-C24VI6pZ.js.map +1 -0
- package/dist/components/p-CA0LmFbe.js +70 -0
- package/dist/components/p-CA0LmFbe.js.map +1 -0
- package/dist/components/p-CECXxls6.js +213 -0
- package/dist/components/p-CECXxls6.js.map +1 -0
- package/dist/components/p-CGw-G2Wz.js +123 -0
- package/dist/components/p-CGw-G2Wz.js.map +1 -0
- package/dist/components/p-CHuAmqhM.js +64 -0
- package/dist/components/p-CHuAmqhM.js.map +1 -0
- package/dist/components/p-CKiB8Aa8.js +97 -0
- package/dist/components/p-CKiB8Aa8.js.map +1 -0
- package/dist/components/p-CNifJXgc.js +153 -0
- package/dist/components/p-CNifJXgc.js.map +1 -0
- package/dist/components/p-CcPNBnbg.js +124 -0
- package/dist/components/p-CcPNBnbg.js.map +1 -0
- package/dist/components/p-CnQh9uSW.js +434 -0
- package/dist/components/p-CnQh9uSW.js.map +1 -0
- package/dist/components/p-CoJrxiH7.js +183 -0
- package/dist/components/p-CoJrxiH7.js.map +1 -0
- package/dist/components/p-CrB92GYh.js +241 -0
- package/dist/components/p-CrB92GYh.js.map +1 -0
- package/dist/components/p-CycIV1i_.js +51 -0
- package/dist/components/p-CycIV1i_.js.map +1 -0
- package/dist/components/p-CzM_4nyA.js +142 -0
- package/dist/components/p-CzM_4nyA.js.map +1 -0
- package/dist/components/p-DBL4ByGk.js +125 -0
- package/dist/components/p-DBL4ByGk.js.map +1 -0
- package/dist/components/p-DErr7PhS.js +78 -0
- package/dist/components/p-DErr7PhS.js.map +1 -0
- package/dist/components/p-DK1vwbmm.js +166 -0
- package/dist/components/p-DK1vwbmm.js.map +1 -0
- package/dist/components/p-DLHC5fHk.js +1474 -0
- package/dist/components/p-DLHC5fHk.js.map +1 -0
- package/dist/components/p-DLql1qMx.js +106 -0
- package/dist/components/p-DLql1qMx.js.map +1 -0
- package/dist/components/p-DXXn0saP.js +148 -0
- package/dist/components/p-DXXn0saP.js.map +1 -0
- package/dist/components/p-D_matRYZ.js +118 -0
- package/dist/components/p-D_matRYZ.js.map +1 -0
- package/dist/components/p-DcXhS_xz.js +204 -0
- package/dist/components/p-DcXhS_xz.js.map +1 -0
- package/dist/components/p-DgAfq9r9.js +56 -0
- package/dist/components/p-DgAfq9r9.js.map +1 -0
- package/dist/components/p-DjsErN85.js +72 -0
- package/dist/components/p-DjsErN85.js.map +1 -0
- package/dist/components/p-Djti9xFF.js +1797 -0
- package/dist/components/p-Djti9xFF.js.map +1 -0
- package/dist/components/p-DoORMw6u.js +67 -0
- package/dist/components/p-DoORMw6u.js.map +1 -0
- package/dist/components/p-DpK6k515.js +4357 -0
- package/dist/components/p-DpK6k515.js.map +1 -0
- package/dist/components/p-FVbfBpwz.js +132 -0
- package/dist/components/p-FVbfBpwz.js.map +1 -0
- package/dist/components/p-G4wC-s5k.js +58 -0
- package/dist/components/p-G4wC-s5k.js.map +1 -0
- package/dist/components/p-QjxdVLPX.js +149 -0
- package/dist/components/p-QjxdVLPX.js.map +1 -0
- package/dist/components/p-UG_h-ztP.js +70 -0
- package/dist/components/p-UG_h-ztP.js.map +1 -0
- package/dist/components/p-l5G-q5dj.js +137 -0
- package/dist/components/p-l5G-q5dj.js.map +1 -0
- package/dist/components/p-qS3vvZaC.js +154 -0
- package/dist/components/p-qS3vvZaC.js.map +1 -0
- package/dist/esm/bellhop-core.js +21 -0
- package/dist/esm/bellhop-core.js.map +1 -0
- package/dist/esm/bh-accordion-item.entry.js +80 -0
- package/dist/esm/bh-accordion-item.entry.js.map +1 -0
- package/dist/esm/bh-accordion.entry.js +117 -0
- package/dist/esm/bh-appbar.entry.js +81 -0
- package/dist/esm/bh-autocomplete-menu_2.entry.js +174 -0
- package/dist/esm/bh-avatar-add.entry.js +73 -0
- package/dist/esm/bh-avatar-stacked.entry.js +92 -0
- package/dist/esm/bh-avatar.entry.js +91 -0
- package/dist/esm/bh-badge-dot_2.entry.js +131 -0
- package/dist/esm/bh-badge.entry.js +69 -0
- package/dist/esm/bh-bar-chart.entry.js +162 -0
- package/dist/esm/bh-button-icon.entry.js +72 -0
- package/dist/esm/bh-button-n5gkWRSP.js +115 -0
- package/dist/esm/bh-button-n5gkWRSP.js.map +1 -0
- package/dist/esm/bh-button.bh-loader-spinner.entry.js.map +1 -0
- package/dist/esm/bh-button_2.entry.js +44 -0
- package/dist/esm/bh-card-footer.entry.js +28 -0
- package/dist/esm/bh-card-header.entry.js +72 -0
- package/dist/esm/bh-card.entry.js +46 -0
- package/dist/esm/bh-chart-tooltip.entry.js +55 -0
- package/dist/esm/bh-checkbox-group-item.entry.js +140 -0
- package/dist/esm/bh-checkbox-group.entry.js +98 -0
- package/dist/esm/bh-checkbox.bh-radio-button.entry.js.map +1 -0
- package/dist/esm/bh-checkbox_2.entry.js +264 -0
- package/dist/esm/bh-container-footer.entry.js +36 -0
- package/dist/esm/bh-container.entry.js +24 -0
- package/dist/esm/bh-data-grid.entry.js +4228 -0
- package/dist/esm/bh-data-grid.entry.js.map +1 -0
- package/dist/esm/bh-date-picker-content.entry.js +368 -0
- package/dist/esm/bh-date-picker-content.entry.js.map +1 -0
- package/dist/esm/bh-date-picker.entry.js +171 -0
- package/dist/esm/bh-date-picker.entry.js.map +1 -0
- package/dist/esm/bh-date-range-picker-content.entry.js +149 -0
- package/dist/esm/bh-date-range-picker.entry.js +165 -0
- package/dist/esm/bh-dropdown-menu.entry.js +112 -0
- package/dist/esm/bh-dropdown.bh-logo-box.bh-nav-item.entry.js.map +1 -0
- package/dist/esm/bh-dropdown_3.entry.js +1883 -0
- package/dist/esm/bh-empty-state.bh-pagination.bh-skeleton-loader.entry.js.map +1 -0
- package/dist/esm/bh-empty-state_3.entry.js +111 -0
- package/dist/esm/bh-featured-icon.entry.js +39 -0
- package/dist/esm/bh-illustrations.entry.js +63 -0
- package/dist/esm/bh-input-autocomplete.entry.js +340 -0
- package/dist/esm/bh-input-number.entry.js +305 -0
- package/dist/esm/bh-input-password.entry.js +180 -0
- package/dist/esm/bh-input-text.bh-picker-menu.entry.js.map +1 -0
- package/dist/esm/bh-input-text_2.entry.js +344 -0
- package/dist/esm/bh-input-verification.entry.js +201 -0
- package/dist/esm/bh-label-fV57YpXm.js +108 -0
- package/dist/esm/bh-label-fV57YpXm.js.map +1 -0
- package/dist/esm/bh-label_2.entry.js +45 -0
- package/dist/esm/bh-modal-actions.entry.js +64 -0
- package/dist/esm/bh-modal-header.entry.js +74 -0
- package/dist/esm/bh-modal.entry.js +54 -0
- package/dist/esm/bh-month-picker-content.entry.js +187 -0
- package/dist/esm/bh-month-picker.entry.js +150 -0
- package/dist/esm/bh-notification.entry.js +126 -0
- package/dist/esm/bh-page-navigation-child.entry.js +46 -0
- package/dist/esm/bh-page-navigation-multi-level_2.entry.js +143 -0
- package/dist/esm/bh-page-navigation.entry.js +70 -0
- package/dist/esm/bh-pagination-BtbbslVs.js +150 -0
- package/dist/esm/bh-pagination-BtbbslVs.js.map +1 -0
- package/dist/esm/bh-pie-chart.entry.js +155 -0
- package/dist/esm/bh-popover.entry.js +98 -0
- package/dist/esm/bh-product-switcher.entry.js +100 -0
- package/dist/esm/bh-property-switcher.entry.js +229 -0
- package/dist/esm/bh-sidebar.entry.js +108 -0
- package/dist/esm/bh-tab-item.entry.js +52 -0
- package/dist/esm/bh-tabs.entry.js +50 -0
- package/dist/esm/bh-textarea.entry.js +159 -0
- package/dist/esm/bh-toggle.entry.js +139 -0
- package/dist/esm/bh-trend-chart.entry.js +119 -0
- package/dist/esm/index-DXAL-jSE.js +1929 -0
- package/dist/esm/index-DXAL-jSE.js.map +1 -0
- package/dist/esm/index.js +16 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/loader.js +11 -0
- package/dist/types/components/bh-checkbox/bh-checkbox.d.ts +46 -0
- package/dist/types/components/bh-data-grid/bh-data-grid.d.ts +155 -0
- package/dist/types/components/bh-data-grid/bh-data-grid.types.d.ts +93 -0
- package/dist/types/components/bh-dropdown/bh-dropdown.d.ts +89 -0
- package/dist/types/components/bh-logo-box/bh-logo-box.d.ts +36 -0
- package/dist/types/components/bh-pagination/bh-pagination.d.ts +80 -0
- package/dist/types/components.d.ts +7496 -0
- package/dist/types/index.d.ts +13 -0
- package/llms.txt +41649 -0
- package/package.json +63 -16
- package/react.d.ts +253 -0
- package/bellhop-core/bellhop-core.esm.js +0 -2
- package/bellhop-core/bellhop-core.esm.js.map +0 -1
- package/bellhop-core/bh-accordion-item.entry.esm.js.map +0 -1
- package/bellhop-core/bh-button.bh-loader-spinner.entry.esm.js.map +0 -1
- package/bellhop-core/bh-checkbox.entry.esm.js.map +0 -1
- package/bellhop-core/bh-data-grid.entry.esm.js.map +0 -1
- package/bellhop-core/bh-date-picker-content.bh-picker-menu.entry.esm.js.map +0 -1
- package/bellhop-core/bh-date-picker.bh-empty-state.entry.esm.js.map +0 -1
- package/bellhop-core/bh-dropdown.bh-logo-box.bh-nav-item.entry.esm.js.map +0 -1
- package/bellhop-core/bh-input-text.entry.esm.js.map +0 -1
- package/bellhop-core/bh-radio-button.entry.esm.js.map +0 -1
- package/bellhop-core/bh-skeleton-loader.entry.esm.js.map +0 -1
- package/bellhop-core/index.esm.js +0 -2
- package/bellhop-core/index.esm.js.map +0 -1
- package/bellhop-core/p-051a25aa.entry.js +0 -2
- package/bellhop-core/p-0579ce8d.entry.js +0 -2
- package/bellhop-core/p-05c13d72.entry.js +0 -2
- package/bellhop-core/p-0e013732.entry.js +0 -2
- package/bellhop-core/p-1960c2d0.entry.js +0 -2
- package/bellhop-core/p-2735c901.entry.js +0 -2
- package/bellhop-core/p-2735c901.entry.js.map +0 -1
- package/bellhop-core/p-2c80bc07.entry.js +0 -2
- package/bellhop-core/p-2cc0c4cf.entry.js +0 -2
- package/bellhop-core/p-3038cc1a.entry.js +0 -2
- package/bellhop-core/p-324cad08.entry.js +0 -2
- package/bellhop-core/p-324cad08.entry.js.map +0 -1
- package/bellhop-core/p-3bf098fd.entry.js +0 -2
- package/bellhop-core/p-3c739eea.entry.js +0 -2
- package/bellhop-core/p-4c71a0b6.entry.js +0 -2
- package/bellhop-core/p-5a220f12.entry.js +0 -2
- package/bellhop-core/p-5d844699.entry.js +0 -2
- package/bellhop-core/p-5e8d2fc0.entry.js +0 -2
- package/bellhop-core/p-71391701.entry.js +0 -2
- package/bellhop-core/p-7e67af77.entry.js +0 -2
- package/bellhop-core/p-7e908d03.entry.js +0 -2
- package/bellhop-core/p-7e908d03.entry.js.map +0 -1
- package/bellhop-core/p-8053e945.entry.js +0 -2
- package/bellhop-core/p-852564d6.entry.js +0 -2
- package/bellhop-core/p-86bbff38.entry.js +0 -2
- package/bellhop-core/p-87d1ed92.entry.js +0 -2
- package/bellhop-core/p-94156013.entry.js +0 -2
- package/bellhop-core/p-954b9c38.entry.js +0 -2
- package/bellhop-core/p-9693180e.entry.js +0 -2
- package/bellhop-core/p-98a336f7.entry.js +0 -2
- package/bellhop-core/p-98cc729f.entry.js +0 -2
- package/bellhop-core/p-9e7e64dc.entry.js +0 -2
- package/bellhop-core/p-9fe1fd2e.entry.js +0 -2
- package/bellhop-core/p-DANVSPII.js +0 -2
- package/bellhop-core/p-DANVSPII.js.map +0 -1
- package/bellhop-core/p-DKeuA-TM.js +0 -2
- package/bellhop-core/p-DKeuA-TM.js.map +0 -1
- package/bellhop-core/p-DtVghh5W.js +0 -3
- package/bellhop-core/p-DtVghh5W.js.map +0 -1
- package/bellhop-core/p-a901ae33.entry.js +0 -2
- package/bellhop-core/p-a901ae33.entry.js.map +0 -1
- package/bellhop-core/p-abd6ade0.entry.js +0 -2
- package/bellhop-core/p-abd6ade0.entry.js.map +0 -1
- package/bellhop-core/p-abf68de4.entry.js +0 -2
- package/bellhop-core/p-ad15a4b9.entry.js +0 -2
- package/bellhop-core/p-b1affa8d.entry.js +0 -2
- package/bellhop-core/p-b1affa8d.entry.js.map +0 -1
- package/bellhop-core/p-b4104ae5.entry.js +0 -2
- package/bellhop-core/p-c194883a.entry.js +0 -2
- package/bellhop-core/p-c48ca590.entry.js +0 -2
- package/bellhop-core/p-c82e73aa.entry.js +0 -2
- package/bellhop-core/p-d14192df.entry.js +0 -2
- package/bellhop-core/p-d5fb8d0f.entry.js +0 -2
- package/bellhop-core/p-d9106838.entry.js +0 -2
- package/bellhop-core/p-d941cdba.entry.js +0 -2
- package/bellhop-core/p-d94b296e.entry.js +0 -2
- package/bellhop-core/p-df2728a1.entry.js +0 -2
- package/bellhop-core/p-df45027c.entry.js +0 -2
- package/bellhop-core/p-df45027c.entry.js.map +0 -1
- package/bellhop-core/p-dfe0574c.entry.js +0 -2
- package/bellhop-core/p-e3c5d1e3.entry.js +0 -2
- package/bellhop-core/p-e3d79592.entry.js +0 -2
- package/bellhop-core/p-e44539e9.entry.js +0 -2
- package/bellhop-core/p-e5b9a3de.entry.js +0 -2
- package/bellhop-core/p-e8e0739d.entry.js +0 -2
- package/bellhop-core/p-ebb2492c.entry.js +0 -2
- package/bellhop-core/p-ec894e11.entry.js +0 -2
- package/bellhop-core/p-f0cfc744.entry.js +0 -2
- package/bellhop-core/p-f0cfc744.entry.js.map +0 -1
- package/bellhop-core/p-f261bdae.entry.js +0 -2
- package/bellhop-core/p-f261bdae.entry.js.map +0 -1
- package/bellhop-core/p-f4c4c70d.entry.js +0 -2
- package/cjs/bellhop-core.cjs.js +0 -25
- package/cjs/bellhop-core.cjs.js.map +0 -1
- package/cjs/bh-accordion-item.cjs.entry.js +0 -82
- package/cjs/bh-accordion-item.entry.cjs.js.map +0 -1
- package/cjs/bh-accordion.cjs.entry.js +0 -119
- package/cjs/bh-appbar.cjs.entry.js +0 -83
- package/cjs/bh-autocomplete-menu_2.cjs.entry.js +0 -177
- package/cjs/bh-avatar-add.cjs.entry.js +0 -75
- package/cjs/bh-avatar-stacked.cjs.entry.js +0 -94
- package/cjs/bh-avatar.cjs.entry.js +0 -93
- package/cjs/bh-badge-dot_2.cjs.entry.js +0 -134
- package/cjs/bh-badge.cjs.entry.js +0 -71
- package/cjs/bh-bar-chart.cjs.entry.js +0 -164
- package/cjs/bh-button-BKVcf-nK.js +0 -117
- package/cjs/bh-button-BKVcf-nK.js.map +0 -1
- package/cjs/bh-button-icon.cjs.entry.js +0 -74
- package/cjs/bh-button.bh-loader-spinner.entry.cjs.js.map +0 -1
- package/cjs/bh-button_2.cjs.entry.js +0 -47
- package/cjs/bh-card-footer.cjs.entry.js +0 -30
- package/cjs/bh-card-header.cjs.entry.js +0 -74
- package/cjs/bh-card.cjs.entry.js +0 -48
- package/cjs/bh-chart-tooltip.cjs.entry.js +0 -57
- package/cjs/bh-checkbox-group-item.cjs.entry.js +0 -142
- package/cjs/bh-checkbox-group.cjs.entry.js +0 -100
- package/cjs/bh-checkbox.cjs.entry.js +0 -144
- package/cjs/bh-checkbox.entry.cjs.js.map +0 -1
- package/cjs/bh-container-footer.cjs.entry.js +0 -38
- package/cjs/bh-container.cjs.entry.js +0 -26
- package/cjs/bh-data-grid.cjs.entry.js +0 -812
- package/cjs/bh-data-grid.entry.cjs.js.map +0 -1
- package/cjs/bh-date-picker-content.bh-picker-menu.entry.cjs.js.map +0 -1
- package/cjs/bh-date-picker-content_2.cjs.entry.js +0 -525
- package/cjs/bh-date-picker.bh-empty-state.entry.cjs.js.map +0 -1
- package/cjs/bh-date-picker_2.cjs.entry.js +0 -252
- package/cjs/bh-date-range-picker-content.cjs.entry.js +0 -151
- package/cjs/bh-date-range-picker.cjs.entry.js +0 -167
- package/cjs/bh-dropdown-menu.cjs.entry.js +0 -114
- package/cjs/bh-dropdown.bh-logo-box.bh-nav-item.entry.cjs.js.map +0 -1
- package/cjs/bh-dropdown_3.cjs.entry.js +0 -307
- package/cjs/bh-featured-icon.cjs.entry.js +0 -41
- package/cjs/bh-illustrations.cjs.entry.js +0 -65
- package/cjs/bh-input-autocomplete.cjs.entry.js +0 -342
- package/cjs/bh-input-number.cjs.entry.js +0 -307
- package/cjs/bh-input-password.cjs.entry.js +0 -182
- package/cjs/bh-input-text.cjs.entry.js +0 -192
- package/cjs/bh-input-text.entry.cjs.js.map +0 -1
- package/cjs/bh-input-verification.cjs.entry.js +0 -203
- package/cjs/bh-label-DBqucnaO.js +0 -110
- package/cjs/bh-label-DBqucnaO.js.map +0 -1
- package/cjs/bh-label_2.cjs.entry.js +0 -48
- package/cjs/bh-modal-actions.cjs.entry.js +0 -66
- package/cjs/bh-modal-header.cjs.entry.js +0 -76
- package/cjs/bh-modal.cjs.entry.js +0 -56
- package/cjs/bh-month-picker-content.cjs.entry.js +0 -189
- package/cjs/bh-month-picker.cjs.entry.js +0 -152
- package/cjs/bh-notification.cjs.entry.js +0 -128
- package/cjs/bh-page-navigation-child.cjs.entry.js +0 -48
- package/cjs/bh-page-navigation-multi-level_2.cjs.entry.js +0 -146
- package/cjs/bh-page-navigation.cjs.entry.js +0 -72
- package/cjs/bh-pie-chart.cjs.entry.js +0 -157
- package/cjs/bh-popover.cjs.entry.js +0 -100
- package/cjs/bh-product-switcher.cjs.entry.js +0 -102
- package/cjs/bh-property-switcher.cjs.entry.js +0 -231
- package/cjs/bh-radio-button.cjs.entry.js +0 -124
- package/cjs/bh-radio-button.entry.cjs.js.map +0 -1
- package/cjs/bh-sidebar.cjs.entry.js +0 -110
- package/cjs/bh-skeleton-loader.cjs.entry.js +0 -34
- package/cjs/bh-skeleton-loader.entry.cjs.js.map +0 -1
- package/cjs/bh-tab-item.cjs.entry.js +0 -54
- package/cjs/bh-tabs.cjs.entry.js +0 -52
- package/cjs/bh-textarea.cjs.entry.js +0 -161
- package/cjs/bh-toggle.cjs.entry.js +0 -141
- package/cjs/bh-trend-chart.cjs.entry.js +0 -121
- package/cjs/index-tZqSQc8E.js +0 -1951
- package/cjs/index-tZqSQc8E.js.map +0 -1
- package/cjs/index.cjs.js +0 -32
- package/cjs/index.cjs.js.map +0 -1
- package/cjs/loader.cjs.js +0 -13
- package/collection/collection-manifest.json +0 -77
- package/collection/components/bh-accordion/bh-accordion.js +0 -227
- package/collection/components/bh-accordion-item/bh-accordion-item.css +0 -119
- package/collection/components/bh-accordion-item/bh-accordion-item.js +0 -207
- package/collection/components/bh-appbar/bh-appbar.js +0 -270
- package/collection/components/bh-autocomplete-menu/bh-autocomplete-menu.js +0 -301
- package/collection/components/bh-avatar/bh-avatar.js +0 -266
- package/collection/components/bh-avatar-add/bh-avatar-add.js +0 -194
- package/collection/components/bh-avatar-stacked/bh-avatar-stacked.js +0 -211
- package/collection/components/bh-badge/bh-badge.js +0 -250
- package/collection/components/bh-badge-dot/bh-badge-dot.js +0 -113
- package/collection/components/bh-bar-chart/bh-bar-chart.css +0 -363
- package/collection/components/bh-bar-chart/bh-bar-chart.js +0 -316
- package/collection/components/bh-breadcrumbs/bh-breadcrumbs.js +0 -231
- package/collection/components/bh-button/bh-button.js +0 -350
- package/collection/components/bh-button-icon/bh-button-icon.js +0 -259
- package/collection/components/bh-card/bh-card.js +0 -139
- package/collection/components/bh-card-footer/bh-card-footer.js +0 -81
- package/collection/components/bh-card-header/bh-card-header.js +0 -348
- package/collection/components/bh-chart-tooltip/bh-chart-tooltip.css +0 -301
- package/collection/components/bh-chart-tooltip/bh-chart-tooltip.js +0 -226
- package/collection/components/bh-checkbox/bh-checkbox.js +0 -378
- package/collection/components/bh-checkbox/bh-checkbox.js.map +0 -1
- package/collection/components/bh-checkbox-group/bh-checkbox-group.js +0 -218
- package/collection/components/bh-checkbox-group-item/bh-checkbox-group-item.js +0 -402
- package/collection/components/bh-container/bh-container.js +0 -51
- package/collection/components/bh-container-footer/bh-container-footer.js +0 -106
- package/collection/components/bh-data-grid/bh-data-grid.css +0 -602
- package/collection/components/bh-data-grid/bh-data-grid.js +0 -1488
- package/collection/components/bh-data-grid/bh-data-grid.js.map +0 -1
- package/collection/components/bh-date-picker/bh-date-picker.css +0 -251
- package/collection/components/bh-date-picker/bh-date-picker.js +0 -485
- package/collection/components/bh-date-picker-content/bh-date-picker-content.css +0 -541
- package/collection/components/bh-date-picker-content/bh-date-picker-content.js +0 -711
- package/collection/components/bh-date-range-picker/bh-date-range-picker.css +0 -247
- package/collection/components/bh-date-range-picker/bh-date-range-picker.js +0 -528
- package/collection/components/bh-date-range-picker-content/bh-date-range-picker-content.css +0 -275
- package/collection/components/bh-date-range-picker-content/bh-date-range-picker-content.js +0 -338
- package/collection/components/bh-dropdown/bh-dropdown.css +0 -64
- package/collection/components/bh-dropdown/bh-dropdown.js +0 -512
- package/collection/components/bh-dropdown/bh-dropdown.js.map +0 -1
- package/collection/components/bh-dropdown-menu/bh-dropdown-menu.js +0 -262
- package/collection/components/bh-empty-state/bh-empty-state.js +0 -306
- package/collection/components/bh-featured-icon/bh-featured-icon.js +0 -144
- package/collection/components/bh-illustrations/bh-illustrations.css +0 -328
- package/collection/components/bh-illustrations/bh-illustrations.js +0 -174
- package/collection/components/bh-input-autocomplete/bh-input-autocomplete.css +0 -301
- package/collection/components/bh-input-autocomplete/bh-input-autocomplete.js +0 -872
- package/collection/components/bh-input-number/bh-input-number.js +0 -818
- package/collection/components/bh-input-password/bh-input-password.js +0 -581
- package/collection/components/bh-input-text/bh-input-text.js +0 -696
- package/collection/components/bh-input-verification/bh-input-verification.js +0 -523
- package/collection/components/bh-label/bh-label.js +0 -302
- package/collection/components/bh-loader-spinner/bh-loader-spinner.css +0 -153
- package/collection/components/bh-loader-spinner/bh-loader-spinner.js +0 -182
- package/collection/components/bh-logo-box/bh-logo-box.js +0 -184
- package/collection/components/bh-logo-box/bh-logo-box.js.map +0 -1
- package/collection/components/bh-modal/bh-modal.js +0 -144
- package/collection/components/bh-modal-actions/bh-modal-actions.js +0 -208
- package/collection/components/bh-modal-header/bh-modal-header.js +0 -275
- package/collection/components/bh-month-picker/bh-month-picker.css +0 -251
- package/collection/components/bh-month-picker/bh-month-picker.js +0 -444
- package/collection/components/bh-month-picker-content/bh-month-picker-content.css +0 -406
- package/collection/components/bh-month-picker-content/bh-month-picker-content.js +0 -437
- package/collection/components/bh-notification/bh-notification.js +0 -324
- package/collection/components/bh-page-navigation/bh-page-navigation.css +0 -253
- package/collection/components/bh-page-navigation/bh-page-navigation.js +0 -146
- package/collection/components/bh-page-navigation-child/bh-page-navigation-child.css +0 -281
- package/collection/components/bh-page-navigation-child/bh-page-navigation-child.js +0 -148
- package/collection/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.css +0 -372
- package/collection/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.js +0 -268
- package/collection/components/bh-page-navigation-single-level/bh-page-navigation-single-level.js +0 -126
- package/collection/components/bh-picker-menu/bh-picker-menu.css +0 -284
- package/collection/components/bh-pie-chart/bh-pie-chart.css +0 -292
- package/collection/components/bh-pie-chart/bh-pie-chart.js +0 -280
- package/collection/components/bh-popover/bh-popover.js +0 -326
- package/collection/components/bh-product-switcher/bh-product-switcher.js +0 -226
- package/collection/components/bh-property-switcher/bh-property-switcher.js +0 -360
- package/collection/components/bh-radio-button/bh-radio-button.js +0 -292
- package/collection/components/bh-sidebar/bh-nav-item.js +0 -157
- package/collection/components/bh-sidebar/bh-sidebar.js +0 -344
- package/collection/components/bh-skeleton-loader/bh-skeleton-loader.js +0 -99
- package/collection/components/bh-tab-item/bh-tab-item.js +0 -158
- package/collection/components/bh-tabs/bh-tabs.js +0 -178
- package/collection/components/bh-tag/bh-tag.js +0 -238
- package/collection/components/bh-textarea/bh-textarea.js +0 -569
- package/collection/components/bh-toggle/bh-toggle.js +0 -369
- package/collection/components/bh-tooltip/bh-tooltip.js +0 -162
- package/collection/components/bh-trend-chart/bh-trend-chart.css +0 -299
- package/collection/components/bh-trend-chart/bh-trend-chart.js +0 -256
- package/collection/index.js +0 -22
- package/collection/index.js.map +0 -1
- package/components/bh-accordion-item.js +0 -111
- package/components/bh-accordion-item.js.map +0 -1
- package/components/bh-accordion.js +0 -147
- package/components/bh-appbar.js +0 -128
- package/components/bh-autocomplete-menu.js +0 -9
- package/components/bh-avatar-add.js +0 -9
- package/components/bh-avatar-stacked.js +0 -141
- package/components/bh-avatar.js +0 -9
- package/components/bh-badge-dot.js +0 -9
- package/components/bh-badge.js +0 -9
- package/components/bh-bar-chart.js +0 -205
- package/components/bh-breadcrumbs.js +0 -9
- package/components/bh-button-icon.js +0 -9
- package/components/bh-button.js +0 -9
- package/components/bh-card-footer.js +0 -9
- package/components/bh-card-header.js +0 -9
- package/components/bh-card.js +0 -9
- package/components/bh-chart-tooltip.js +0 -9
- package/components/bh-checkbox-group-item.js +0 -9
- package/components/bh-checkbox-group.js +0 -9
- package/components/bh-checkbox.js +0 -9
- package/components/bh-container-footer.js +0 -74
- package/components/bh-container.js +0 -49
- package/components/bh-data-grid.js +0 -9
- package/components/bh-date-picker-content.js +0 -9
- package/components/bh-date-picker.js +0 -9
- package/components/bh-date-picker.js.map +0 -1
- package/components/bh-date-range-picker-content.js +0 -9
- package/components/bh-date-range-picker.js +0 -269
- package/components/bh-dropdown-menu.js +0 -9
- package/components/bh-dropdown.js +0 -9
- package/components/bh-empty-state.js +0 -9
- package/components/bh-featured-icon.js +0 -9
- package/components/bh-illustrations.js +0 -92
- package/components/bh-input-autocomplete.js +0 -433
- package/components/bh-input-number.js +0 -370
- package/components/bh-input-password.js +0 -229
- package/components/bh-input-text.js +0 -9
- package/components/bh-input-verification.js +0 -255
- package/components/bh-label.js +0 -9
- package/components/bh-loader-spinner.js +0 -9
- package/components/bh-logo-box.js +0 -9
- package/components/bh-modal-actions.js +0 -105
- package/components/bh-modal-header.js +0 -119
- package/components/bh-modal.js +0 -9
- package/components/bh-month-picker-content.js +0 -9
- package/components/bh-month-picker.js +0 -233
- package/components/bh-nav-item.js +0 -9
- package/components/bh-notification.js +0 -175
- package/components/bh-page-navigation-child.js +0 -9
- package/components/bh-page-navigation-multi-level.js +0 -9
- package/components/bh-page-navigation-single-level.js +0 -9
- package/components/bh-page-navigation.js +0 -129
- package/components/bh-picker-menu.js +0 -9
- package/components/bh-pie-chart.js +0 -194
- package/components/bh-popover.js +0 -131
- package/components/bh-product-switcher.js +0 -9
- package/components/bh-property-switcher.js +0 -261
- package/components/bh-radio-button.js +0 -9
- package/components/bh-sidebar.js +0 -195
- package/components/bh-skeleton-loader.js +0 -59
- package/components/bh-skeleton-loader.js.map +0 -1
- package/components/bh-tab-item.js +0 -80
- package/components/bh-tabs.js +0 -78
- package/components/bh-tag.js +0 -9
- package/components/bh-textarea.js +0 -207
- package/components/bh-toggle.js +0 -9
- package/components/bh-tooltip.js +0 -9
- package/components/bh-trend-chart.js +0 -149
- package/components/index.js +0 -16
- package/components/index.js.map +0 -1
- package/components/p-54wXxbeh.js +0 -213
- package/components/p-54wXxbeh.js.map +0 -1
- package/components/p-9a7sQzad.js +0 -1463
- package/components/p-9a7sQzad.js.map +0 -1
- package/components/p-B3doeS-4.js +0 -158
- package/components/p-B3doeS-4.js.map +0 -1
- package/components/p-B4TBDBoW.js +0 -71
- package/components/p-B4TBDBoW.js.map +0 -1
- package/components/p-BBenNW93.js +0 -184
- package/components/p-BBenNW93.js.map +0 -1
- package/components/p-BLRNfy0t.js +0 -84
- package/components/p-BLRNfy0t.js.map +0 -1
- package/components/p-BYhYSIIs.js +0 -941
- package/components/p-BYhYSIIs.js.map +0 -1
- package/components/p-Bbo_Dwmk.js +0 -70
- package/components/p-Bbo_Dwmk.js.map +0 -1
- package/components/p-BdcGkck5.js +0 -72
- package/components/p-BdcGkck5.js.map +0 -1
- package/components/p-Bk8GbEQp.js +0 -132
- package/components/p-Bk8GbEQp.js.map +0 -1
- package/components/p-CDPKBnfQ.js +0 -92
- package/components/p-CDPKBnfQ.js.map +0 -1
- package/components/p-CDgBIIbC.js +0 -224
- package/components/p-CDgBIIbC.js.map +0 -1
- package/components/p-CErNA5c8.js +0 -204
- package/components/p-CErNA5c8.js.map +0 -1
- package/components/p-CQBqn1IO.js +0 -67
- package/components/p-CQBqn1IO.js.map +0 -1
- package/components/p-CTjPiCcp.js +0 -51
- package/components/p-CTjPiCcp.js.map +0 -1
- package/components/p-CciWcvHP.js +0 -123
- package/components/p-CciWcvHP.js.map +0 -1
- package/components/p-CiQqgc-m.js +0 -434
- package/components/p-CiQqgc-m.js.map +0 -1
- package/components/p-CsRNKalM.js +0 -166
- package/components/p-CsRNKalM.js.map +0 -1
- package/components/p-CuVsQ9St.js +0 -123
- package/components/p-CuVsQ9St.js.map +0 -1
- package/components/p-D3OkBDd3.js +0 -100
- package/components/p-D3OkBDd3.js.map +0 -1
- package/components/p-D6cM-mvE.js +0 -64
- package/components/p-D6cM-mvE.js.map +0 -1
- package/components/p-D6kh9oF2.js +0 -70
- package/components/p-D6kh9oF2.js.map +0 -1
- package/components/p-DHSWIF-h.js +0 -214
- package/components/p-DHSWIF-h.js.map +0 -1
- package/components/p-DNhCX5eS.js +0 -153
- package/components/p-DNhCX5eS.js.map +0 -1
- package/components/p-DRGkYX1u.js +0 -78
- package/components/p-DRGkYX1u.js.map +0 -1
- package/components/p-DRJW4zBc.js +0 -58
- package/components/p-DRJW4zBc.js.map +0 -1
- package/components/p-DTgHvmlL.js +0 -149
- package/components/p-DTgHvmlL.js.map +0 -1
- package/components/p-DVhHZCku.js +0 -220
- package/components/p-DVhHZCku.js.map +0 -1
- package/components/p-DWpdUpK5.js +0 -264
- package/components/p-DWpdUpK5.js.map +0 -1
- package/components/p-D_DKZMpk.js +0 -78
- package/components/p-D_DKZMpk.js.map +0 -1
- package/components/p-Dbl0HXBJ.js +0 -241
- package/components/p-Dbl0HXBJ.js.map +0 -1
- package/components/p-DecYIvq4.js +0 -124
- package/components/p-DecYIvq4.js.map +0 -1
- package/components/p-DfXkVfrE.js +0 -129
- package/components/p-DfXkVfrE.js.map +0 -1
- package/components/p-HEcFS8Jc.js +0 -125
- package/components/p-HEcFS8Jc.js.map +0 -1
- package/components/p-MIbEYjCv.js +0 -142
- package/components/p-MIbEYjCv.js.map +0 -1
- package/components/p-NXL0pYS_.js +0 -97
- package/components/p-NXL0pYS_.js.map +0 -1
- package/components/p-X9MH3dtg.js +0 -154
- package/components/p-X9MH3dtg.js.map +0 -1
- package/components/p-YJm8-pxX.js +0 -118
- package/components/p-YJm8-pxX.js.map +0 -1
- package/components/p-ghuDbZwh.js +0 -148
- package/components/p-ghuDbZwh.js.map +0 -1
- package/components/p-p8W0xKpn.js +0 -106
- package/components/p-p8W0xKpn.js.map +0 -1
- package/esm/bellhop-core.js +0 -21
- package/esm/bellhop-core.js.map +0 -1
- package/esm/bh-accordion-item.entry.js +0 -80
- package/esm/bh-accordion-item.entry.js.map +0 -1
- package/esm/bh-accordion.entry.js +0 -117
- package/esm/bh-appbar.entry.js +0 -81
- package/esm/bh-autocomplete-menu_2.entry.js +0 -174
- package/esm/bh-avatar-add.entry.js +0 -73
- package/esm/bh-avatar-stacked.entry.js +0 -92
- package/esm/bh-avatar.entry.js +0 -91
- package/esm/bh-badge-dot_2.entry.js +0 -131
- package/esm/bh-badge.entry.js +0 -69
- package/esm/bh-bar-chart.entry.js +0 -162
- package/esm/bh-button-CBZGiLVh.js +0 -115
- package/esm/bh-button-CBZGiLVh.js.map +0 -1
- package/esm/bh-button-icon.entry.js +0 -72
- package/esm/bh-button.bh-loader-spinner.entry.js.map +0 -1
- package/esm/bh-button_2.entry.js +0 -44
- package/esm/bh-card-footer.entry.js +0 -28
- package/esm/bh-card-header.entry.js +0 -72
- package/esm/bh-card.entry.js +0 -46
- package/esm/bh-chart-tooltip.entry.js +0 -55
- package/esm/bh-checkbox-group-item.entry.js +0 -140
- package/esm/bh-checkbox-group.entry.js +0 -98
- package/esm/bh-checkbox.entry.js +0 -142
- package/esm/bh-checkbox.entry.js.map +0 -1
- package/esm/bh-container-footer.entry.js +0 -36
- package/esm/bh-container.entry.js +0 -24
- package/esm/bh-data-grid.entry.js +0 -810
- package/esm/bh-data-grid.entry.js.map +0 -1
- package/esm/bh-date-picker-content.bh-picker-menu.entry.js.map +0 -1
- package/esm/bh-date-picker-content_2.entry.js +0 -522
- package/esm/bh-date-picker.bh-empty-state.entry.js.map +0 -1
- package/esm/bh-date-picker_2.entry.js +0 -249
- package/esm/bh-date-range-picker-content.entry.js +0 -149
- package/esm/bh-date-range-picker.entry.js +0 -165
- package/esm/bh-dropdown-menu.entry.js +0 -112
- package/esm/bh-dropdown.bh-logo-box.bh-nav-item.entry.js.map +0 -1
- package/esm/bh-dropdown_3.entry.js +0 -303
- package/esm/bh-featured-icon.entry.js +0 -39
- package/esm/bh-illustrations.entry.js +0 -63
- package/esm/bh-input-autocomplete.entry.js +0 -340
- package/esm/bh-input-number.entry.js +0 -305
- package/esm/bh-input-password.entry.js +0 -180
- package/esm/bh-input-text.entry.js +0 -190
- package/esm/bh-input-text.entry.js.map +0 -1
- package/esm/bh-input-verification.entry.js +0 -201
- package/esm/bh-label-DqsVrCg_.js +0 -108
- package/esm/bh-label-DqsVrCg_.js.map +0 -1
- package/esm/bh-label_2.entry.js +0 -45
- package/esm/bh-modal-actions.entry.js +0 -64
- package/esm/bh-modal-header.entry.js +0 -74
- package/esm/bh-modal.entry.js +0 -54
- package/esm/bh-month-picker-content.entry.js +0 -187
- package/esm/bh-month-picker.entry.js +0 -150
- package/esm/bh-notification.entry.js +0 -126
- package/esm/bh-page-navigation-child.entry.js +0 -46
- package/esm/bh-page-navigation-multi-level_2.entry.js +0 -143
- package/esm/bh-page-navigation.entry.js +0 -70
- package/esm/bh-pie-chart.entry.js +0 -155
- package/esm/bh-popover.entry.js +0 -98
- package/esm/bh-product-switcher.entry.js +0 -100
- package/esm/bh-property-switcher.entry.js +0 -229
- package/esm/bh-radio-button.entry.js +0 -122
- package/esm/bh-radio-button.entry.js.map +0 -1
- package/esm/bh-sidebar.entry.js +0 -108
- package/esm/bh-skeleton-loader.entry.js +0 -32
- package/esm/bh-skeleton-loader.entry.js.map +0 -1
- package/esm/bh-tab-item.entry.js +0 -52
- package/esm/bh-tabs.entry.js +0 -50
- package/esm/bh-textarea.entry.js +0 -159
- package/esm/bh-toggle.entry.js +0 -139
- package/esm/bh-trend-chart.entry.js +0 -119
- package/esm/index-DtVghh5W.js +0 -1922
- package/esm/index-DtVghh5W.js.map +0 -1
- package/esm/index.js +0 -15
- package/esm/index.js.map +0 -1
- package/esm/loader.js +0 -11
- package/types/components/bh-checkbox/bh-checkbox.d.ts +0 -45
- package/types/components/bh-data-grid/bh-data-grid.d.ts +0 -235
- package/types/components/bh-dropdown/bh-dropdown.d.ts +0 -78
- package/types/components/bh-logo-box/bh-logo-box.d.ts +0 -28
- package/types/components.d.ts +0 -7199
- package/types/index.d.ts +0 -12
- /package/{bellhop-core → dist/bellhop-core}/bellhop-core.css +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-accordion.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-appbar.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-autocomplete-menu.bh-tag.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-avatar-add.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-avatar-stacked.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-avatar.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-badge-dot.bh-breadcrumbs.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-badge.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-bar-chart.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-button-icon.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-card-footer.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-card-header.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-card.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-chart-tooltip.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-checkbox-group-item.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-checkbox-group.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-container-footer.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-container.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-date-range-picker-content.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-date-range-picker.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-dropdown-menu.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-featured-icon.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-illustrations.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-input-autocomplete.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-input-number.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-input-password.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-input-verification.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-label.bh-tooltip.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-modal-actions.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-modal-header.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-modal.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-month-picker-content.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-month-picker.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-notification.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-page-navigation-child.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-page-navigation-multi-level.bh-page-navigation-single-level.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-page-navigation.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-pie-chart.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-popover.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-product-switcher.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-property-switcher.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-sidebar.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-tab-item.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-tabs.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-textarea.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-toggle.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/bh-trend-chart.entry.esm.js.map +0 -0
- /package/{bellhop-core → dist/bellhop-core}/loader.esm.js.map +0 -0
- /package/{bellhop-core/p-c48ca590.entry.js.map → dist/bellhop-core/p-03e93cd8.entry.js.map} +0 -0
- /package/{bellhop-core/p-86bbff38.entry.js.map → dist/bellhop-core/p-0438e0a9.entry.js.map} +0 -0
- /package/{bellhop-core/p-b4104ae5.entry.js.map → dist/bellhop-core/p-086e8c86.entry.js.map} +0 -0
- /package/{bellhop-core/p-852564d6.entry.js.map → dist/bellhop-core/p-09f3464e.entry.js.map} +0 -0
- /package/{bellhop-core/p-3c739eea.entry.js.map → dist/bellhop-core/p-20d680ce.entry.js.map} +0 -0
- /package/{bellhop-core/p-d5fb8d0f.entry.js.map → dist/bellhop-core/p-239c7e6b.entry.js.map} +0 -0
- /package/{bellhop-core/p-abf68de4.entry.js.map → dist/bellhop-core/p-23b74b40.entry.js.map} +0 -0
- /package/{bellhop-core/p-e44539e9.entry.js.map → dist/bellhop-core/p-2c796978.entry.js.map} +0 -0
- /package/{bellhop-core/p-98cc729f.entry.js.map → dist/bellhop-core/p-356a2ed7.entry.js.map} +0 -0
- /package/{bellhop-core/p-9e7e64dc.entry.js.map → dist/bellhop-core/p-363dce47.entry.js.map} +0 -0
- /package/{bellhop-core/p-9fe1fd2e.entry.js.map → dist/bellhop-core/p-3719852a.entry.js.map} +0 -0
- /package/{bellhop-core/p-05c13d72.entry.js.map → dist/bellhop-core/p-44241bad.entry.js.map} +0 -0
- /package/{bellhop-core/p-c194883a.entry.js.map → dist/bellhop-core/p-4a14cbb5.entry.js.map} +0 -0
- /package/{bellhop-core/p-df2728a1.entry.js.map → dist/bellhop-core/p-52e877e0.entry.js.map} +0 -0
- /package/{bellhop-core/p-98a336f7.entry.js.map → dist/bellhop-core/p-56b857f5.entry.js.map} +0 -0
- /package/{bellhop-core/p-8053e945.entry.js.map → dist/bellhop-core/p-5760ce66.entry.js.map} +0 -0
- /package/{bellhop-core/p-e5b9a3de.entry.js.map → dist/bellhop-core/p-57ac382d.entry.js.map} +0 -0
- /package/{bellhop-core/p-dfe0574c.entry.js.map → dist/bellhop-core/p-58879213.entry.js.map} +0 -0
- /package/{bellhop-core/p-d9106838.entry.js.map → dist/bellhop-core/p-5ab50add.entry.js.map} +0 -0
- /package/{bellhop-core/p-ebb2492c.entry.js.map → dist/bellhop-core/p-6433b0a7.entry.js.map} +0 -0
- /package/{bellhop-core/p-5d844699.entry.js.map → dist/bellhop-core/p-67452ed0.entry.js.map} +0 -0
- /package/{bellhop-core/p-e3c5d1e3.entry.js.map → dist/bellhop-core/p-686dea4a.entry.js.map} +0 -0
- /package/{bellhop-core/p-e3d79592.entry.js.map → dist/bellhop-core/p-69f85850.entry.js.map} +0 -0
- /package/{bellhop-core/p-5e8d2fc0.entry.js.map → dist/bellhop-core/p-70ee270c.entry.js.map} +0 -0
- /package/{bellhop-core/p-2c80bc07.entry.js.map → dist/bellhop-core/p-859f45da.entry.js.map} +0 -0
- /package/{bellhop-core/p-0e013732.entry.js.map → dist/bellhop-core/p-860be0be.entry.js.map} +0 -0
- /package/{bellhop-core/p-d941cdba.entry.js.map → dist/bellhop-core/p-870fc023.entry.js.map} +0 -0
- /package/{bellhop-core/p-1960c2d0.entry.js.map → dist/bellhop-core/p-87fb26a0.entry.js.map} +0 -0
- /package/{bellhop-core/p-9693180e.entry.js.map → dist/bellhop-core/p-90b9047d.entry.js.map} +0 -0
- /package/{bellhop-core/p-3bf098fd.entry.js.map → dist/bellhop-core/p-94d2d599.entry.js.map} +0 -0
- /package/{bellhop-core/p-d14192df.entry.js.map → dist/bellhop-core/p-9a585c1a.entry.js.map} +0 -0
- /package/{bellhop-core → dist/bellhop-core}/p-CPgx0iFq.js +0 -0
- /package/{bellhop-core → dist/bellhop-core}/p-CPgx0iFq.js.map +0 -0
- /package/{bellhop-core/p-87d1ed92.entry.js.map → dist/bellhop-core/p-ab2b037c.entry.js.map} +0 -0
- /package/{bellhop-core/p-051a25aa.entry.js.map → dist/bellhop-core/p-ab9c5351.entry.js.map} +0 -0
- /package/{bellhop-core/p-5a220f12.entry.js.map → dist/bellhop-core/p-abe24947.entry.js.map} +0 -0
- /package/{bellhop-core/p-c82e73aa.entry.js.map → dist/bellhop-core/p-adcd2e15.entry.js.map} +0 -0
- /package/{bellhop-core/p-e8e0739d.entry.js.map → dist/bellhop-core/p-afd0e309.entry.js.map} +0 -0
- /package/{bellhop-core/p-ad15a4b9.entry.js.map → dist/bellhop-core/p-b1cb34e9.entry.js.map} +0 -0
- /package/{bellhop-core/p-3038cc1a.entry.js.map → dist/bellhop-core/p-cdd593fb.entry.js.map} +0 -0
- /package/{bellhop-core/p-94156013.entry.js.map → dist/bellhop-core/p-d4bfd30d.entry.js.map} +0 -0
- /package/{bellhop-core/p-954b9c38.entry.js.map → dist/bellhop-core/p-dcaa20e2.entry.js.map} +0 -0
- /package/{bellhop-core/p-ec894e11.entry.js.map → dist/bellhop-core/p-dd43d560.entry.js.map} +0 -0
- /package/{bellhop-core/p-4c71a0b6.entry.js.map → dist/bellhop-core/p-e190ac50.entry.js.map} +0 -0
- /package/{bellhop-core/p-f4c4c70d.entry.js.map → dist/bellhop-core/p-e86780b6.entry.js.map} +0 -0
- /package/{bellhop-core/p-71391701.entry.js.map → dist/bellhop-core/p-e99bc91a.entry.js.map} +0 -0
- /package/{bellhop-core/p-0579ce8d.entry.js.map → dist/bellhop-core/p-e9ed7c17.entry.js.map} +0 -0
- /package/{bellhop-core/p-d94b296e.entry.js.map → dist/bellhop-core/p-ef47dcd1.entry.js.map} +0 -0
- /package/{bellhop-core/p-2cc0c4cf.entry.js.map → dist/bellhop-core/p-f6e1b47c.entry.js.map} +0 -0
- /package/{bellhop-core/p-7e67af77.entry.js.map → dist/bellhop-core/p-f7c7416d.entry.js.map} +0 -0
- /package/{cjs → dist/cjs}/bh-accordion.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-appbar.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-autocomplete-menu.bh-tag.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-avatar-add.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-avatar-stacked.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-avatar.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-badge-dot.bh-breadcrumbs.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-badge.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-bar-chart.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-button-icon.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-card-footer.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-card-header.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-card.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-chart-tooltip.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-checkbox-group-item.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-checkbox-group.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-container-footer.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-container.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-date-range-picker-content.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-date-range-picker.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-dropdown-menu.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-featured-icon.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-illustrations.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-input-autocomplete.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-input-number.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-input-password.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-input-verification.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-label.bh-tooltip.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-modal-actions.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-modal-header.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-modal.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-month-picker-content.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-month-picker.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-notification.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-page-navigation-child.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-page-navigation-multi-level.bh-page-navigation-single-level.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-page-navigation.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-pie-chart.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-popover.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-product-switcher.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-property-switcher.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-sidebar.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-tab-item.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-tabs.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-textarea.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-toggle.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/bh-trend-chart.entry.cjs.js.map +0 -0
- /package/{cjs → dist/cjs}/form-9mbajZ3y.js +0 -0
- /package/{cjs → dist/cjs}/form-9mbajZ3y.js.map +0 -0
- /package/{cjs → dist/cjs}/loader.cjs.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-accordion/bh-accordion.css +0 -0
- /package/{collection → dist/collection}/components/bh-accordion/bh-accordion.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-accordion-item/bh-accordion-item.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-appbar/bh-appbar.css +0 -0
- /package/{collection → dist/collection}/components/bh-appbar/bh-appbar.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-autocomplete-menu/bh-autocomplete-menu.css +0 -0
- /package/{collection → dist/collection}/components/bh-autocomplete-menu/bh-autocomplete-menu.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-avatar/bh-avatar.css +0 -0
- /package/{collection → dist/collection}/components/bh-avatar/bh-avatar.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-avatar-add/bh-avatar-add.css +0 -0
- /package/{collection → dist/collection}/components/bh-avatar-add/bh-avatar-add.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-avatar-stacked/bh-avatar-stacked.css +0 -0
- /package/{collection → dist/collection}/components/bh-avatar-stacked/bh-avatar-stacked.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-badge/bh-badge.css +0 -0
- /package/{collection → dist/collection}/components/bh-badge/bh-badge.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-badge-dot/bh-badge-dot.css +0 -0
- /package/{collection → dist/collection}/components/bh-badge-dot/bh-badge-dot.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-bar-chart/bh-bar-chart.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-breadcrumbs/bh-breadcrumbs.css +0 -0
- /package/{collection → dist/collection}/components/bh-breadcrumbs/bh-breadcrumbs.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-button/bh-button.css +0 -0
- /package/{collection → dist/collection}/components/bh-button/bh-button.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-button-icon/bh-button-icon.css +0 -0
- /package/{collection → dist/collection}/components/bh-button-icon/bh-button-icon.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-card/bh-card.css +0 -0
- /package/{collection → dist/collection}/components/bh-card/bh-card.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-card-footer/bh-card-footer.css +0 -0
- /package/{collection → dist/collection}/components/bh-card-footer/bh-card-footer.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-card-header/bh-card-header.css +0 -0
- /package/{collection → dist/collection}/components/bh-card-header/bh-card-header.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-chart-tooltip/bh-chart-tooltip.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-checkbox/bh-checkbox.css +0 -0
- /package/{collection → dist/collection}/components/bh-checkbox-group/bh-checkbox-group.css +0 -0
- /package/{collection → dist/collection}/components/bh-checkbox-group/bh-checkbox-group.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-checkbox-group-item/bh-checkbox-group-item.css +0 -0
- /package/{collection → dist/collection}/components/bh-checkbox-group-item/bh-checkbox-group-item.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-container/bh-container.css +0 -0
- /package/{collection → dist/collection}/components/bh-container/bh-container.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-container-footer/bh-container-footer.css +0 -0
- /package/{collection → dist/collection}/components/bh-container-footer/bh-container-footer.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-date-picker/bh-date-picker.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-date-picker-content/bh-date-picker-content.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-date-range-picker/bh-date-range-picker.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-date-range-picker-content/bh-date-range-picker-content.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-dropdown-menu/bh-dropdown-menu.css +0 -0
- /package/{collection → dist/collection}/components/bh-dropdown-menu/bh-dropdown-menu.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-empty-state/bh-empty-state.css +0 -0
- /package/{collection → dist/collection}/components/bh-empty-state/bh-empty-state.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-featured-icon/bh-featured-icon.css +0 -0
- /package/{collection → dist/collection}/components/bh-featured-icon/bh-featured-icon.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-illustrations/bh-illustrations.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-input-autocomplete/bh-input-autocomplete.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-input-number/bh-input-number.css +0 -0
- /package/{collection → dist/collection}/components/bh-input-number/bh-input-number.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-input-password/bh-input-password.css +0 -0
- /package/{collection → dist/collection}/components/bh-input-password/bh-input-password.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-input-text/bh-input-text.css +0 -0
- /package/{collection → dist/collection}/components/bh-input-text/bh-input-text.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-input-verification/bh-input-verification.css +0 -0
- /package/{collection → dist/collection}/components/bh-input-verification/bh-input-verification.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-label/bh-label.css +0 -0
- /package/{collection → dist/collection}/components/bh-label/bh-label.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-loader-spinner/bh-loader-spinner.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-logo-box/bh-logo-box.css +0 -0
- /package/{collection → dist/collection}/components/bh-modal/bh-modal.css +0 -0
- /package/{collection → dist/collection}/components/bh-modal/bh-modal.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-modal-actions/bh-modal-actions.css +0 -0
- /package/{collection → dist/collection}/components/bh-modal-actions/bh-modal-actions.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-modal-header/bh-modal-header.css +0 -0
- /package/{collection → dist/collection}/components/bh-modal-header/bh-modal-header.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-month-picker/bh-month-picker.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-month-picker-content/bh-month-picker-content.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-notification/bh-notification.css +0 -0
- /package/{collection → dist/collection}/components/bh-notification/bh-notification.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-page-navigation/bh-page-navigation.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-page-navigation-child/bh-page-navigation-child.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-page-navigation-single-level/bh-page-navigation-single-level.css +0 -0
- /package/{collection → dist/collection}/components/bh-page-navigation-single-level/bh-page-navigation-single-level.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-picker-menu/bh-picker-menu.js +0 -0
- /package/{collection → dist/collection}/components/bh-picker-menu/bh-picker-menu.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-pie-chart/bh-pie-chart.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-popover/bh-popover.css +0 -0
- /package/{collection → dist/collection}/components/bh-popover/bh-popover.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-product-switcher/bh-product-switcher.css +0 -0
- /package/{collection → dist/collection}/components/bh-product-switcher/bh-product-switcher.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-property-switcher/bh-property-switcher.css +0 -0
- /package/{collection → dist/collection}/components/bh-property-switcher/bh-property-switcher.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-radio-button/bh-radio-button.css +0 -0
- /package/{collection → dist/collection}/components/bh-radio-button/bh-radio-button.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-sidebar/bh-nav-item.css +0 -0
- /package/{collection → dist/collection}/components/bh-sidebar/bh-nav-item.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-sidebar/bh-sidebar.css +0 -0
- /package/{collection → dist/collection}/components/bh-sidebar/bh-sidebar.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-skeleton-loader/bh-skeleton-loader.css +0 -0
- /package/{collection → dist/collection}/components/bh-skeleton-loader/bh-skeleton-loader.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-tab-item/bh-tab-item.css +0 -0
- /package/{collection → dist/collection}/components/bh-tab-item/bh-tab-item.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-tabs/bh-tabs.css +0 -0
- /package/{collection → dist/collection}/components/bh-tabs/bh-tabs.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-tag/bh-tag.css +0 -0
- /package/{collection → dist/collection}/components/bh-tag/bh-tag.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-textarea/bh-textarea.css +0 -0
- /package/{collection → dist/collection}/components/bh-textarea/bh-textarea.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-toggle/bh-toggle.css +0 -0
- /package/{collection → dist/collection}/components/bh-toggle/bh-toggle.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-tooltip/bh-tooltip.css +0 -0
- /package/{collection → dist/collection}/components/bh-tooltip/bh-tooltip.js.map +0 -0
- /package/{collection → dist/collection}/components/bh-trend-chart/bh-trend-chart.js.map +0 -0
- /package/{collection → dist/collection}/utils/form.js +0 -0
- /package/{collection → dist/collection}/utils/form.js.map +0 -0
- /package/{components → dist/components}/bh-accordion-item.d.ts +0 -0
- /package/{components → dist/components}/bh-accordion.d.ts +0 -0
- /package/{components → dist/components}/bh-accordion.js.map +0 -0
- /package/{components → dist/components}/bh-appbar.d.ts +0 -0
- /package/{components → dist/components}/bh-appbar.js.map +0 -0
- /package/{components → dist/components}/bh-autocomplete-menu.d.ts +0 -0
- /package/{components → dist/components}/bh-autocomplete-menu.js.map +0 -0
- /package/{components → dist/components}/bh-avatar-add.d.ts +0 -0
- /package/{components → dist/components}/bh-avatar-add.js.map +0 -0
- /package/{components → dist/components}/bh-avatar-stacked.d.ts +0 -0
- /package/{components → dist/components}/bh-avatar-stacked.js.map +0 -0
- /package/{components → dist/components}/bh-avatar.d.ts +0 -0
- /package/{components → dist/components}/bh-avatar.js.map +0 -0
- /package/{components → dist/components}/bh-badge-dot.d.ts +0 -0
- /package/{components → dist/components}/bh-badge-dot.js.map +0 -0
- /package/{components → dist/components}/bh-badge.d.ts +0 -0
- /package/{components → dist/components}/bh-badge.js.map +0 -0
- /package/{components → dist/components}/bh-bar-chart.d.ts +0 -0
- /package/{components → dist/components}/bh-bar-chart.js.map +0 -0
- /package/{components → dist/components}/bh-breadcrumbs.d.ts +0 -0
- /package/{components → dist/components}/bh-breadcrumbs.js.map +0 -0
- /package/{components → dist/components}/bh-button-icon.d.ts +0 -0
- /package/{components → dist/components}/bh-button-icon.js.map +0 -0
- /package/{components → dist/components}/bh-button.d.ts +0 -0
- /package/{components → dist/components}/bh-button.js.map +0 -0
- /package/{components → dist/components}/bh-card-footer.d.ts +0 -0
- /package/{components → dist/components}/bh-card-footer.js.map +0 -0
- /package/{components → dist/components}/bh-card-header.d.ts +0 -0
- /package/{components → dist/components}/bh-card-header.js.map +0 -0
- /package/{components → dist/components}/bh-card.d.ts +0 -0
- /package/{components → dist/components}/bh-card.js.map +0 -0
- /package/{components → dist/components}/bh-chart-tooltip.d.ts +0 -0
- /package/{components → dist/components}/bh-chart-tooltip.js.map +0 -0
- /package/{components → dist/components}/bh-checkbox-group-item.d.ts +0 -0
- /package/{components → dist/components}/bh-checkbox-group-item.js.map +0 -0
- /package/{components → dist/components}/bh-checkbox-group.d.ts +0 -0
- /package/{components → dist/components}/bh-checkbox-group.js.map +0 -0
- /package/{components → dist/components}/bh-checkbox.d.ts +0 -0
- /package/{components → dist/components}/bh-checkbox.js.map +0 -0
- /package/{components → dist/components}/bh-container-footer.d.ts +0 -0
- /package/{components → dist/components}/bh-container-footer.js.map +0 -0
- /package/{components → dist/components}/bh-container.d.ts +0 -0
- /package/{components → dist/components}/bh-container.js.map +0 -0
- /package/{components → dist/components}/bh-data-grid.d.ts +0 -0
- /package/{components → dist/components}/bh-data-grid.js.map +0 -0
- /package/{components → dist/components}/bh-date-picker-content.d.ts +0 -0
- /package/{components → dist/components}/bh-date-picker-content.js.map +0 -0
- /package/{components → dist/components}/bh-date-picker.d.ts +0 -0
- /package/{components → dist/components}/bh-date-range-picker-content.d.ts +0 -0
- /package/{components → dist/components}/bh-date-range-picker-content.js.map +0 -0
- /package/{components → dist/components}/bh-date-range-picker.d.ts +0 -0
- /package/{components → dist/components}/bh-date-range-picker.js.map +0 -0
- /package/{components → dist/components}/bh-dropdown-menu.d.ts +0 -0
- /package/{components → dist/components}/bh-dropdown-menu.js.map +0 -0
- /package/{components → dist/components}/bh-dropdown.d.ts +0 -0
- /package/{components → dist/components}/bh-dropdown.js.map +0 -0
- /package/{components → dist/components}/bh-empty-state.d.ts +0 -0
- /package/{components → dist/components}/bh-empty-state.js.map +0 -0
- /package/{components → dist/components}/bh-featured-icon.d.ts +0 -0
- /package/{components → dist/components}/bh-featured-icon.js.map +0 -0
- /package/{components → dist/components}/bh-illustrations.d.ts +0 -0
- /package/{components → dist/components}/bh-illustrations.js.map +0 -0
- /package/{components → dist/components}/bh-input-autocomplete.d.ts +0 -0
- /package/{components → dist/components}/bh-input-autocomplete.js.map +0 -0
- /package/{components → dist/components}/bh-input-number.d.ts +0 -0
- /package/{components → dist/components}/bh-input-number.js.map +0 -0
- /package/{components → dist/components}/bh-input-password.d.ts +0 -0
- /package/{components → dist/components}/bh-input-password.js.map +0 -0
- /package/{components → dist/components}/bh-input-text.d.ts +0 -0
- /package/{components → dist/components}/bh-input-text.js.map +0 -0
- /package/{components → dist/components}/bh-input-verification.d.ts +0 -0
- /package/{components → dist/components}/bh-input-verification.js.map +0 -0
- /package/{components → dist/components}/bh-label.d.ts +0 -0
- /package/{components → dist/components}/bh-label.js.map +0 -0
- /package/{components → dist/components}/bh-loader-spinner.d.ts +0 -0
- /package/{components → dist/components}/bh-loader-spinner.js.map +0 -0
- /package/{components → dist/components}/bh-logo-box.d.ts +0 -0
- /package/{components → dist/components}/bh-logo-box.js.map +0 -0
- /package/{components → dist/components}/bh-modal-actions.d.ts +0 -0
- /package/{components → dist/components}/bh-modal-actions.js.map +0 -0
- /package/{components → dist/components}/bh-modal-header.d.ts +0 -0
- /package/{components → dist/components}/bh-modal-header.js.map +0 -0
- /package/{components → dist/components}/bh-modal.d.ts +0 -0
- /package/{components → dist/components}/bh-modal.js.map +0 -0
- /package/{components → dist/components}/bh-month-picker-content.d.ts +0 -0
- /package/{components → dist/components}/bh-month-picker-content.js.map +0 -0
- /package/{components → dist/components}/bh-month-picker.d.ts +0 -0
- /package/{components → dist/components}/bh-month-picker.js.map +0 -0
- /package/{components → dist/components}/bh-nav-item.d.ts +0 -0
- /package/{components → dist/components}/bh-nav-item.js.map +0 -0
- /package/{components → dist/components}/bh-notification.d.ts +0 -0
- /package/{components → dist/components}/bh-notification.js.map +0 -0
- /package/{components → dist/components}/bh-page-navigation-child.d.ts +0 -0
- /package/{components → dist/components}/bh-page-navigation-child.js.map +0 -0
- /package/{components → dist/components}/bh-page-navigation-multi-level.d.ts +0 -0
- /package/{components → dist/components}/bh-page-navigation-multi-level.js.map +0 -0
- /package/{components → dist/components}/bh-page-navigation-single-level.d.ts +0 -0
- /package/{components → dist/components}/bh-page-navigation-single-level.js.map +0 -0
- /package/{components → dist/components}/bh-page-navigation.d.ts +0 -0
- /package/{components → dist/components}/bh-page-navigation.js.map +0 -0
- /package/{components → dist/components}/bh-picker-menu.d.ts +0 -0
- /package/{components → dist/components}/bh-picker-menu.js.map +0 -0
- /package/{components → dist/components}/bh-pie-chart.d.ts +0 -0
- /package/{components → dist/components}/bh-pie-chart.js.map +0 -0
- /package/{components → dist/components}/bh-popover.d.ts +0 -0
- /package/{components → dist/components}/bh-popover.js.map +0 -0
- /package/{components → dist/components}/bh-product-switcher.d.ts +0 -0
- /package/{components → dist/components}/bh-product-switcher.js.map +0 -0
- /package/{components → dist/components}/bh-property-switcher.d.ts +0 -0
- /package/{components → dist/components}/bh-property-switcher.js.map +0 -0
- /package/{components → dist/components}/bh-radio-button.d.ts +0 -0
- /package/{components → dist/components}/bh-radio-button.js.map +0 -0
- /package/{components → dist/components}/bh-sidebar.d.ts +0 -0
- /package/{components → dist/components}/bh-sidebar.js.map +0 -0
- /package/{components → dist/components}/bh-skeleton-loader.d.ts +0 -0
- /package/{components → dist/components}/bh-tab-item.d.ts +0 -0
- /package/{components → dist/components}/bh-tab-item.js.map +0 -0
- /package/{components → dist/components}/bh-tabs.d.ts +0 -0
- /package/{components → dist/components}/bh-tabs.js.map +0 -0
- /package/{components → dist/components}/bh-tag.d.ts +0 -0
- /package/{components → dist/components}/bh-tag.js.map +0 -0
- /package/{components → dist/components}/bh-textarea.d.ts +0 -0
- /package/{components → dist/components}/bh-textarea.js.map +0 -0
- /package/{components → dist/components}/bh-toggle.d.ts +0 -0
- /package/{components → dist/components}/bh-toggle.js.map +0 -0
- /package/{components → dist/components}/bh-tooltip.d.ts +0 -0
- /package/{components → dist/components}/bh-tooltip.js.map +0 -0
- /package/{components → dist/components}/bh-trend-chart.d.ts +0 -0
- /package/{components → dist/components}/bh-trend-chart.js.map +0 -0
- /package/{components → dist/components}/index.d.ts +0 -0
- /package/{components → dist/components}/p-2KjdCYlS.js +0 -0
- /package/{components → dist/components}/p-2KjdCYlS.js.map +0 -0
- /package/{esm → dist/esm}/bh-accordion.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-appbar.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-autocomplete-menu.bh-tag.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-avatar-add.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-avatar-stacked.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-avatar.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-badge-dot.bh-breadcrumbs.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-badge.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-bar-chart.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-button-icon.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-card-footer.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-card-header.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-card.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-chart-tooltip.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-checkbox-group-item.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-checkbox-group.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-container-footer.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-container.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-date-range-picker-content.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-date-range-picker.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-dropdown-menu.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-featured-icon.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-illustrations.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-input-autocomplete.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-input-number.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-input-password.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-input-verification.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-label.bh-tooltip.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-modal-actions.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-modal-header.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-modal.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-month-picker-content.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-month-picker.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-notification.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-page-navigation-child.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-page-navigation-multi-level.bh-page-navigation-single-level.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-page-navigation.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-pie-chart.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-popover.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-product-switcher.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-property-switcher.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-sidebar.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-tab-item.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-tabs.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-textarea.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-toggle.entry.js.map +0 -0
- /package/{esm → dist/esm}/bh-trend-chart.entry.js.map +0 -0
- /package/{esm → dist/esm}/form-CPgx0iFq.js +0 -0
- /package/{esm → dist/esm}/form-CPgx0iFq.js.map +0 -0
- /package/{esm → dist/esm}/loader.js.map +0 -0
- /package/{index.cjs.js → dist/index.cjs.js} +0 -0
- /package/{index.js → dist/index.js} +0 -0
- /package/{types → dist/types}/components/bh-accordion/bh-accordion.d.ts +0 -0
- /package/{types → dist/types}/components/bh-accordion-item/bh-accordion-item.d.ts +0 -0
- /package/{types → dist/types}/components/bh-appbar/bh-appbar.d.ts +0 -0
- /package/{types → dist/types}/components/bh-autocomplete-menu/bh-autocomplete-menu.d.ts +0 -0
- /package/{types → dist/types}/components/bh-avatar/bh-avatar.d.ts +0 -0
- /package/{types → dist/types}/components/bh-avatar-add/bh-avatar-add.d.ts +0 -0
- /package/{types → dist/types}/components/bh-avatar-stacked/bh-avatar-stacked.d.ts +0 -0
- /package/{types → dist/types}/components/bh-badge/bh-badge.d.ts +0 -0
- /package/{types → dist/types}/components/bh-badge-dot/bh-badge-dot.d.ts +0 -0
- /package/{types → dist/types}/components/bh-bar-chart/bh-bar-chart.d.ts +0 -0
- /package/{types → dist/types}/components/bh-breadcrumbs/bh-breadcrumbs.d.ts +0 -0
- /package/{types → dist/types}/components/bh-button/bh-button.d.ts +0 -0
- /package/{types → dist/types}/components/bh-button-icon/bh-button-icon.d.ts +0 -0
- /package/{types → dist/types}/components/bh-card/bh-card.d.ts +0 -0
- /package/{types → dist/types}/components/bh-card-footer/bh-card-footer.d.ts +0 -0
- /package/{types → dist/types}/components/bh-card-header/bh-card-header.d.ts +0 -0
- /package/{types → dist/types}/components/bh-chart-tooltip/bh-chart-tooltip.d.ts +0 -0
- /package/{types → dist/types}/components/bh-checkbox-group/bh-checkbox-group.d.ts +0 -0
- /package/{types → dist/types}/components/bh-checkbox-group-item/bh-checkbox-group-item.d.ts +0 -0
- /package/{types → dist/types}/components/bh-container/bh-container.d.ts +0 -0
- /package/{types → dist/types}/components/bh-container-footer/bh-container-footer.d.ts +0 -0
- /package/{types → dist/types}/components/bh-date-picker/bh-date-picker.d.ts +0 -0
- /package/{types → dist/types}/components/bh-date-picker-content/bh-date-picker-content.d.ts +0 -0
- /package/{types → dist/types}/components/bh-date-range-picker/bh-date-range-picker.d.ts +0 -0
- /package/{types → dist/types}/components/bh-date-range-picker-content/bh-date-range-picker-content.d.ts +0 -0
- /package/{types → dist/types}/components/bh-dropdown-menu/bh-dropdown-menu.d.ts +0 -0
- /package/{types → dist/types}/components/bh-empty-state/bh-empty-state.d.ts +0 -0
- /package/{types → dist/types}/components/bh-featured-icon/bh-featured-icon.d.ts +0 -0
- /package/{types → dist/types}/components/bh-illustrations/bh-illustrations.d.ts +0 -0
- /package/{types → dist/types}/components/bh-input-autocomplete/bh-input-autocomplete.d.ts +0 -0
- /package/{types → dist/types}/components/bh-input-number/bh-input-number.d.ts +0 -0
- /package/{types → dist/types}/components/bh-input-password/bh-input-password.d.ts +0 -0
- /package/{types → dist/types}/components/bh-input-text/bh-input-text.d.ts +0 -0
- /package/{types → dist/types}/components/bh-input-verification/bh-input-verification.d.ts +0 -0
- /package/{types → dist/types}/components/bh-label/bh-label.d.ts +0 -0
- /package/{types → dist/types}/components/bh-loader-spinner/bh-loader-spinner.d.ts +0 -0
- /package/{types → dist/types}/components/bh-modal/bh-modal.d.ts +0 -0
- /package/{types → dist/types}/components/bh-modal-actions/bh-modal-actions.d.ts +0 -0
- /package/{types → dist/types}/components/bh-modal-header/bh-modal-header.d.ts +0 -0
- /package/{types → dist/types}/components/bh-month-picker/bh-month-picker.d.ts +0 -0
- /package/{types → dist/types}/components/bh-month-picker-content/bh-month-picker-content.d.ts +0 -0
- /package/{types → dist/types}/components/bh-notification/bh-notification.d.ts +0 -0
- /package/{types → dist/types}/components/bh-page-navigation/bh-page-navigation.d.ts +0 -0
- /package/{types → dist/types}/components/bh-page-navigation-child/bh-page-navigation-child.d.ts +0 -0
- /package/{types → dist/types}/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.d.ts +0 -0
- /package/{types → dist/types}/components/bh-page-navigation-single-level/bh-page-navigation-single-level.d.ts +0 -0
- /package/{types → dist/types}/components/bh-picker-menu/bh-picker-menu.d.ts +0 -0
- /package/{types → dist/types}/components/bh-pie-chart/bh-pie-chart.d.ts +0 -0
- /package/{types → dist/types}/components/bh-popover/bh-popover.d.ts +0 -0
- /package/{types → dist/types}/components/bh-product-switcher/bh-product-switcher.d.ts +0 -0
- /package/{types → dist/types}/components/bh-property-switcher/bh-property-switcher.d.ts +0 -0
- /package/{types → dist/types}/components/bh-radio-button/bh-radio-button.d.ts +0 -0
- /package/{types → dist/types}/components/bh-sidebar/bh-nav-item.d.ts +0 -0
- /package/{types → dist/types}/components/bh-sidebar/bh-sidebar.d.ts +0 -0
- /package/{types → dist/types}/components/bh-skeleton-loader/bh-skeleton-loader.d.ts +0 -0
- /package/{types → dist/types}/components/bh-tab-item/bh-tab-item.d.ts +0 -0
- /package/{types → dist/types}/components/bh-tabs/bh-tabs.d.ts +0 -0
- /package/{types → dist/types}/components/bh-tag/bh-tag.d.ts +0 -0
- /package/{types → dist/types}/components/bh-textarea/bh-textarea.d.ts +0 -0
- /package/{types → dist/types}/components/bh-toggle/bh-toggle.d.ts +0 -0
- /package/{types → dist/types}/components/bh-tooltip/bh-tooltip.d.ts +0 -0
- /package/{types → dist/types}/components/bh-trend-chart/bh-trend-chart.d.ts +0 -0
- /package/{types → dist/types}/stencil-public-runtime.d.ts +0 -0
- /package/{types → dist/types}/utils/form.d.ts +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bh-data-grid.entry.esm.js","sources":["src/components/bh-data-grid/bh-data-grid.css?tag=bh-data-grid&encapsulation=shadow","src/components/bh-data-grid/bh-data-grid.tsx"],"sourcesContent":["/* ==========================================================================\n Data Grid Component\n Based on Figma design tokens\n ========================================================================== */\n\n:host {\n display: block;\n width: 100%;\n}\n\n/* ==========================================================================\n Container\n ========================================================================== */\n\n.data-grid {\n position: relative;\n width: 100%;\n font-family: var(--font-inter, 'Inter', sans-serif);\n background-color: var(--color-white);\n overflow: auto;\n}\n\n.data-grid-table {\n display: flex;\n flex-direction: column;\n min-width: 100%;\n}\n\n/* ==========================================================================\n Header Row\n ========================================================================== */\n\n.data-grid-header-row {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 32px;\n background-color: var(--color-neutral-50);\n border-bottom: 1px solid var(--color-neutral-200);\n position: sticky;\n top: 0;\n z-index: 2;\n}\n\n.data-grid-header-cell {\n display: flex;\n align-items: center;\n gap: var(--spacing-xs, 4px);\n padding: 0 var(--spacing-sm, 8px);\n height: 100%;\n font-size: var(--text-xs-size, 12px);\n font-weight: var(--weight-semibold, 600);\n line-height: var(--text-xs-line, 18px);\n color: var(--color-neutral-600);\n user-select: none;\n flex: 1;\n min-width: 0;\n}\n\n.data-grid-header-cell-sortable {\n cursor: pointer;\n transition: background-color 0.15s ease;\n}\n\n.data-grid-header-cell-sortable:hover {\n background-color: var(--color-neutral-100);\n}\n\n.data-grid-header-cell-sorted {\n color: var(--color-neutral-700);\n}\n\n.data-grid-header-text {\n flex: 1;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.data-grid-sort-icon {\n font-size: 12px;\n color: var(--color-neutral-400);\n flex-shrink: 0;\n font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 20;\n}\n\n.data-grid-header-cell-sorted .data-grid-sort-icon {\n color: var(--color-neutral-600);\n}\n\n/* ==========================================================================\n Filter Row\n ========================================================================== */\n\n.data-grid-filter-row {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 36px;\n background-color: var(--color-white);\n border-bottom: 1px solid var(--color-neutral-200);\n position: sticky;\n top: 32px;\n z-index: 1;\n}\n\n.data-grid-filter-cell {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 0 var(--spacing-sm, 8px);\n height: 100%;\n flex: 1;\n min-width: 0;\n}\n\n/* Filter icon wrapper */\n.data-grid-filter-icon-wrapper {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n/* Filter search icon */\n.data-grid-filter-icon {\n font-size: 18px;\n color: var(--color-neutral-400);\n cursor: pointer;\n transition: color 0.15s ease;\n font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 20;\n}\n\n.data-grid-filter-icon:hover {\n color: var(--color-neutral-600);\n}\n\n.data-grid-filter-active .data-grid-filter-icon {\n color: var(--color-brand-500);\n}\n\n/* Filter popover */\n.data-grid-filter-popover {\n position: absolute;\n top: calc(100% + 4px);\n left: 50%;\n transform: translateX(-50%);\n z-index: 100;\n background-color: var(--color-white);\n border: 1px solid var(--color-neutral-200);\n border-radius: var(--radius-md, 8px);\n box-shadow: var(--shadow-lg, 0 4px 16px rgba(0, 0, 0, 0.12));\n padding: var(--spacing-sm, 8px);\n min-width: 180px;\n}\n\n.data-grid-filter-popover-input {\n width: 100%;\n height: 32px;\n padding: 0 var(--spacing-sm, 8px);\n font-size: var(--text-sm-size, 14px);\n font-family: var(--font-inter, 'Inter', sans-serif);\n color: var(--color-neutral-900);\n background-color: var(--color-white);\n border: 1px solid var(--color-neutral-200);\n border-radius: var(--radius-sm, 6px);\n outline: none;\n transition: border-color 0.15s ease, box-shadow 0.15s ease;\n}\n\n.data-grid-filter-popover-input::placeholder {\n color: var(--color-neutral-400);\n}\n\n.data-grid-filter-popover-input:focus {\n border-color: var(--color-brand-500);\n box-shadow: 0 0 0 3px var(--color-brand-100);\n}\n\n/* Style date picker inside filter */\n.data-grid-filter-icon-wrapper bh-date-picker {\n --bh-button-padding: 0;\n}\n\n.data-grid-filter-icon-wrapper bh-date-picker::part(trigger) {\n padding: 0;\n}\n\n/* ==========================================================================\n Body\n ========================================================================== */\n\n.data-grid-body {\n display: flex;\n flex-direction: column;\n}\n\n/* ==========================================================================\n Data Rows\n ========================================================================== */\n\n.data-grid-row {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 40px;\n border-bottom: 1px solid var(--color-neutral-100);\n background-color: var(--color-white);\n transition: background-color 0.1s ease;\n}\n\n.data-grid-bordered .data-grid-row {\n border-bottom-color: var(--color-neutral-200);\n}\n\n.data-grid-row-hover,\n.data-grid-row:hover {\n background-color: var(--color-neutral-25);\n}\n\n.data-grid-row-selected {\n background-color: var(--color-brand-50);\n}\n\n.data-grid-row-selected:hover {\n background-color: var(--color-brand-100);\n}\n\n.data-grid-row-striped {\n background-color: var(--color-neutral-25);\n}\n\n.data-grid-row-striped:hover {\n background-color: var(--color-neutral-50);\n}\n\n/* Compact mode */\n.data-grid-compact .data-grid-row {\n height: 32px;\n}\n\n.data-grid-compact .data-grid-header-row {\n height: 28px;\n}\n\n/* ==========================================================================\n Cells\n ========================================================================== */\n\n.data-grid-cell {\n display: flex;\n align-items: center;\n padding: 0 var(--spacing-sm, 8px);\n height: 100%;\n font-size: var(--text-sm-size, 14px);\n font-weight: var(--weight-regular, 400);\n line-height: var(--text-sm-line, 20px);\n color: var(--color-neutral-900);\n flex: 1;\n min-width: 0;\n overflow: hidden;\n}\n\n.data-grid-cell > * {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n/* Cell alignment */\n.data-grid-cell-align-left {\n justify-content: flex-start;\n text-align: left;\n}\n\n.data-grid-cell-align-center {\n justify-content: center;\n text-align: center;\n}\n\n.data-grid-cell-align-right {\n justify-content: flex-end;\n text-align: right;\n}\n\n/* Cell types */\n.data-grid-cell-type-number {\n font-variant-numeric: tabular-nums;\n}\n\n.data-grid-cell-type-date {\n font-variant-numeric: tabular-nums;\n}\n\n/* Checkbox cells */\n.data-grid-cell-checkbox {\n flex: 0 0 40px;\n width: 40px;\n min-width: 40px;\n max-width: 40px;\n justify-content: center;\n}\n\n/* ==========================================================================\n Empty State\n ========================================================================== */\n\n.data-grid-empty-state {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: var(--spacing-3xl, 48px) var(--spacing-xl, 24px);\n background-color: var(--color-white);\n}\n\n/* ==========================================================================\n Loading State\n ========================================================================== */\n\n.data-grid-loading {\n position: relative;\n pointer-events: none;\n}\n\n.data-grid-loading .data-grid-body {\n opacity: 0.5;\n}\n\n.data-grid-loading-overlay {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background-color: rgba(255, 255, 255, 0.7);\n z-index: 10;\n}\n\n/* ==========================================================================\n Group Row\n ========================================================================== */\n\n.data-grid-group-section {\n display: contents;\n}\n\n.data-grid-group-row {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 36px;\n padding: 0 var(--spacing-sm, 8px);\n background-color: var(--color-neutral-50);\n border-bottom: 1px solid var(--color-neutral-200);\n font-size: var(--text-sm-size, 14px);\n font-weight: var(--weight-medium, 500);\n color: var(--color-neutral-700);\n cursor: pointer;\n user-select: none;\n}\n\n.data-grid-group-row:hover {\n background-color: var(--color-neutral-100);\n}\n\n.data-grid-group-toggle {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 20px;\n height: 20px;\n margin-right: var(--spacing-sm, 8px);\n color: var(--color-neutral-500);\n}\n\n.data-grid-group-toggle .material-symbols-outlined {\n font-size: 18px;\n transition: transform 0.2s ease;\n}\n\n.data-grid-group-row-expanded .data-grid-group-toggle .material-symbols-outlined {\n transform: rotate(90deg);\n}\n\n.data-grid-group-label {\n flex: 1;\n}\n\n.data-grid-group-column-name {\n color: var(--color-neutral-500);\n}\n\n.data-grid-group-value {\n color: var(--color-neutral-900);\n font-weight: var(--weight-semibold, 600);\n}\n\n.data-grid-group-count {\n color: var(--color-neutral-500);\n margin-left: var(--spacing-sm, 8px);\n font-weight: var(--weight-regular, 400);\n font-size: var(--text-xs-size, 12px);\n}\n\n/* Grouped row indent */\n.data-grid-row-grouped {\n background-color: var(--color-white);\n}\n\n.data-grid-row-indent {\n flex-shrink: 0;\n}\n\n/* ==========================================================================\n Scrollbar Styling\n ========================================================================== */\n\n.data-grid::-webkit-scrollbar {\n width: 8px;\n height: 8px;\n}\n\n.data-grid::-webkit-scrollbar-track {\n background: var(--color-neutral-100);\n border-radius: 4px;\n}\n\n.data-grid::-webkit-scrollbar-thumb {\n background: var(--color-neutral-300);\n border-radius: 4px;\n}\n\n.data-grid::-webkit-scrollbar-thumb:hover {\n background: var(--color-neutral-400);\n}\n\n/* ==========================================================================\n Editing\n ========================================================================== */\n\n/* Row in edit mode */\n.data-grid-row-editing {\n background-color: var(--color-brand-25, #fefcff);\n box-shadow: inset 0 0 0 1px var(--color-brand-200);\n}\n\n.data-grid-row-editing:hover {\n background-color: var(--color-brand-25, #fefcff);\n}\n\n/* Editable cell (can be double-clicked to edit) */\n.data-grid-cell-editable {\n cursor: text;\n}\n\n.data-grid-cell-editable:hover {\n background-color: var(--color-neutral-50);\n}\n\n/* Cell being edited */\n.data-grid-cell-editing {\n padding: 0 var(--spacing-xs, 4px);\n}\n\n/* Edit input */\n.data-grid-edit-input {\n width: 100%;\n height: calc(100% - 4px);\n padding: 0 var(--spacing-xs, 4px);\n font-size: var(--text-sm-size, 14px);\n font-family: var(--font-inter, 'Inter', sans-serif);\n color: var(--color-neutral-900);\n background-color: var(--color-white);\n border: 1px solid var(--color-brand-500);\n border-radius: var(--radius-sm, 4px);\n outline: none;\n box-shadow: 0 0 0 2px var(--color-brand-100);\n}\n\n.data-grid-edit-input:focus {\n border-color: var(--color-brand-600);\n box-shadow: 0 0 0 3px var(--color-brand-100);\n}\n\n.data-grid-edit-input::placeholder {\n color: var(--color-neutral-400);\n}\n\n/* Remove number input spinners */\n.data-grid-edit-input[type='number']::-webkit-outer-spin-button,\n.data-grid-edit-input[type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n\n.data-grid-edit-input[type='number'] {\n -moz-appearance: textfield;\n}\n\n/* Actions column */\n.data-grid-cell-actions {\n flex: 0 0 auto;\n width: auto;\n min-width: 40px;\n padding: 0 var(--spacing-xs, 4px);\n justify-content: flex-end;\n gap: var(--spacing-xs, 4px);\n}\n\n.data-grid-edit-actions {\n display: flex;\n align-items: center;\n gap: var(--spacing-xs, 4px);\n}\n\n/* Action buttons */\n.data-grid-action-btn {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 28px;\n height: 28px;\n padding: 0;\n border: none;\n border-radius: var(--radius-sm, 4px);\n background-color: transparent;\n color: var(--color-neutral-500);\n cursor: pointer;\n transition: all 0.15s ease;\n}\n\n.data-grid-action-btn:hover {\n background-color: var(--color-neutral-100);\n color: var(--color-neutral-700);\n}\n\n.data-grid-action-btn .material-symbols-outlined {\n font-size: 18px;\n font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 20;\n}\n\n/* Edit button */\n.data-grid-action-edit:hover {\n background-color: var(--color-neutral-100);\n color: var(--color-neutral-700);\n}\n\n/* Save button */\n.data-grid-action-save {\n color: var(--color-success-600);\n}\n\n.data-grid-action-save:hover {\n background-color: var(--color-success-50);\n color: var(--color-success-700);\n}\n\n/* Cancel button */\n.data-grid-action-cancel {\n color: var(--color-error-600);\n}\n\n.data-grid-action-cancel:hover {\n background-color: var(--color-error-50);\n color: var(--color-error-700);\n}\n\n/* Header actions column */\n.data-grid-header-cell-actions {\n flex: 0 0 auto;\n width: auto;\n min-width: 40px;\n padding: 0 var(--spacing-xs, 4px);\n}\n\n/* ==========================================================================\n Responsive\n ========================================================================== */\n\n@media (max-width: 768px) {\n .data-grid-header-cell,\n .data-grid-cell {\n padding: 0 var(--spacing-xs, 4px);\n }\n\n .data-grid-filter-input {\n height: 24px;\n font-size: 11px;\n }\n\n .data-grid-action-btn {\n width: 24px;\n height: 24px;\n }\n\n .data-grid-action-btn .material-symbols-outlined {\n font-size: 16px;\n }\n}\n","import { Component, Prop, State, Event, EventEmitter, h, Watch, Element } from '@stencil/core';\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport type DataGridColumnType = 'text' | 'number' | 'date' | 'boolean' | 'custom';\nexport type DataGridSortDirection = 'asc' | 'desc' | null;\nexport type DataGridSelectionMode = 'none' | 'single' | 'multiple';\nexport type DataGridEditMode = 'none' | 'cell' | 'row' | 'popup';\nexport type DataGridFilterOperator =\n | 'contains'\n | 'equals'\n | 'startsWith'\n | 'endsWith'\n | 'greaterThan'\n | 'lessThan'\n | 'greaterThanOrEqual'\n | 'lessThanOrEqual'\n | 'between'\n | 'isEmpty'\n | 'isNotEmpty';\n\nexport interface DataGridColumn<T = unknown> {\n /** Unique identifier for the column */\n id: string;\n /** Header text to display */\n header: string;\n /** Property key to access data (supports dot notation: 'user.name') */\n accessor: keyof T | string;\n /** Column data type for filtering and formatting */\n type?: DataGridColumnType;\n /** Column width (px, %, or 'auto') */\n width?: string | number;\n /** Minimum column width */\n minWidth?: number;\n /** Enable sorting for this column */\n sortable?: boolean;\n /** Enable filtering for this column */\n filterable?: boolean;\n /** Enable editing for this column */\n editable?: boolean;\n /** Text alignment */\n align?: 'left' | 'center' | 'right';\n /** Custom cell render function (returns HTML string or VNode) */\n cellRenderer?: (value: unknown, row: T, rowIndex: number) => unknown;\n /** Custom header render function */\n headerRenderer?: (column: DataGridColumn<T>) => unknown;\n /** Custom edit cell render function */\n editCellRenderer?: (value: unknown, row: T, rowIndex: number, onChange: (newValue: unknown) => void) => unknown;\n /** Whether column is visible */\n visible?: boolean;\n /** Pin column to left or right */\n pinned?: 'left' | 'right' | null;\n}\n\nexport interface DataGridSortState {\n columnId: string;\n direction: DataGridSortDirection;\n}\n\nexport interface DataGridFilterState {\n columnId: string;\n operator: DataGridFilterOperator;\n value: unknown;\n valueTo?: unknown; // For 'between' operator\n}\n\nexport interface DataGridGroupState {\n columnId: string;\n expanded: Set<string>;\n}\n\nexport interface DataGridRowSelection {\n selectedRows: Set<string | number>;\n isAllSelected: boolean;\n isIndeterminate: boolean;\n}\n\nexport interface DataGridGroup {\n key: string;\n value: unknown;\n displayValue: string;\n rows: unknown[];\n depth: number;\n columnId: string;\n}\n\nexport interface DataGridEditState {\n rowKey: string | number;\n columnId: string | null; // null means entire row is being edited\n originalValue: unknown;\n currentValue: unknown;\n}\n\nexport interface DataGridRowChanges {\n rowKey: string | number;\n rowIndex: number;\n originalRow: unknown;\n changes: Record<string, unknown>;\n}\n\n// ============================================================================\n// Component\n// ============================================================================\n\n@Component({\n tag: 'bh-data-grid',\n styleUrl: 'bh-data-grid.css',\n shadow: true,\n})\nexport class BhDataGrid {\n @Element() el!: HTMLElement;\n\n // -------------------------------------------------------------------------\n // Props - Data\n // -------------------------------------------------------------------------\n\n /** Array of data objects to display */\n @Prop() data: unknown[] = [];\n\n /** Column definitions */\n @Prop() columns: DataGridColumn[] = [];\n\n /** Unique identifier property for each row (for selection tracking) */\n @Prop() rowKey: string = 'id';\n\n // -------------------------------------------------------------------------\n // Props - Selection\n // -------------------------------------------------------------------------\n\n /** Enable row selection */\n @Prop() enableSelection: boolean = false;\n\n /** Selection mode */\n @Prop() selectionMode: DataGridSelectionMode = 'multiple';\n\n /** Currently selected row keys (controlled) */\n @Prop({ mutable: true }) selectedKeys: (string | number)[] = [];\n\n // -------------------------------------------------------------------------\n // Props - Sorting\n // -------------------------------------------------------------------------\n\n /** Enable sorting */\n @Prop() enableSorting: boolean = true;\n\n /** Allow multi-column sorting */\n @Prop() multiSort: boolean = false;\n\n /** Current sort state (controlled) */\n @Prop({ mutable: true }) sortState: DataGridSortState[] = [];\n\n // -------------------------------------------------------------------------\n // Props - Filtering\n // -------------------------------------------------------------------------\n\n /** Enable filtering */\n @Prop() enableFiltering: boolean = false;\n\n /** Show filter row below header */\n @Prop() showFilterRow: boolean = false;\n\n /** Current filter state (controlled) */\n @Prop({ mutable: true }) filterState: DataGridFilterState[] = [];\n\n // -------------------------------------------------------------------------\n // Props - Grouping\n // -------------------------------------------------------------------------\n\n /** Enable row grouping */\n @Prop() enableGrouping: boolean = false;\n\n /** Columns to group by */\n @Prop() groupBy: string[] = [];\n\n // -------------------------------------------------------------------------\n // Props - Editing\n // -------------------------------------------------------------------------\n\n /** Enable editing */\n @Prop() enableEditing: boolean = false;\n\n /** Edit mode: cell (individual cells), row (entire row), popup (modal form) */\n @Prop() editMode: DataGridEditMode = 'cell';\n\n /** Whether to show edit/save/cancel buttons in row actions */\n @Prop() showEditActions: boolean = true;\n\n // -------------------------------------------------------------------------\n // Props - Display\n // -------------------------------------------------------------------------\n\n /** Show header row */\n @Prop() showHeader: boolean = true;\n\n /** Show row borders */\n @Prop() showRowBorders: boolean = true;\n\n /** Striped rows */\n @Prop() striped: boolean = false;\n\n /** Compact row height */\n @Prop() compact: boolean = false;\n\n /** Empty state message */\n @Prop() emptyMessage: string = 'No data available';\n\n /** Loading state */\n @Prop() loading: boolean = false;\n\n // -------------------------------------------------------------------------\n // State\n // -------------------------------------------------------------------------\n\n @State() internalSelectedKeys: Set<string | number> = new Set();\n @State() internalSortState: DataGridSortState[] = [];\n @State() internalFilterState: DataGridFilterState[] = [];\n @State() expandedGroups: string[] = [];\n @State() hoveredRowIndex: number | null = null;\n @State() filterInputValues: Record<string, string> = {};\n\n // Editing state\n @State() editingRowKey: string | number | null = null;\n @State() editingColumnId: string | null = null;\n @State() editingValues: Record<string, unknown> = {};\n @State() showEditPopup: boolean = false;\n\n // Filter popover state\n @State() activeFilterColumn: string | null = null;\n\n // -------------------------------------------------------------------------\n // Events\n // -------------------------------------------------------------------------\n\n /** Emitted when row selection changes */\n @Event() bhSelectionChange!: EventEmitter<{ selectedKeys: (string | number)[]; selectedRows: unknown[] }>;\n\n /** Emitted when sort state changes */\n @Event() bhSortChange!: EventEmitter<DataGridSortState[]>;\n\n /** Emitted when filter state changes */\n @Event() bhFilterChange!: EventEmitter<DataGridFilterState[]>;\n\n /** Emitted when a row is clicked */\n @Event() bhRowClick!: EventEmitter<{ row: unknown; rowIndex: number; rowKey: string | number }>;\n\n /** Emitted when a cell is clicked */\n @Event() bhCellClick!: EventEmitter<{ row: unknown; column: DataGridColumn; value: unknown; rowIndex: number; columnIndex: number }>;\n\n /** Emitted when group expand/collapse changes */\n @Event() bhGroupToggle!: EventEmitter<{ groupKey: string; expanded: boolean }>;\n\n /** Emitted when editing starts */\n @Event() bhEditStart!: EventEmitter<{ rowKey: string | number; row: unknown; columnId?: string }>;\n\n /** Emitted when editing is cancelled */\n @Event() bhEditCancel!: EventEmitter<{ rowKey: string | number; row: unknown }>;\n\n /** Emitted when changes are saved */\n @Event() bhEditSave!: EventEmitter<DataGridRowChanges>;\n\n /** Emitted when a cell value changes during editing (before save) */\n @Event() bhCellChange!: EventEmitter<{ rowKey: string | number; columnId: string; oldValue: unknown; newValue: unknown }>;\n\n // -------------------------------------------------------------------------\n // Watchers\n // -------------------------------------------------------------------------\n\n @Watch('selectedKeys')\n handleSelectedKeysChange(newValue: (string | number)[]) {\n this.internalSelectedKeys = new Set(newValue);\n }\n\n @Watch('sortState')\n handleSortStateChange(newValue: DataGridSortState[]) {\n this.internalSortState = [...newValue];\n }\n\n @Watch('filterState')\n handleFilterStateChange(newValue: DataGridFilterState[]) {\n this.internalFilterState = [...newValue];\n }\n\n // -------------------------------------------------------------------------\n // Lifecycle\n // -------------------------------------------------------------------------\n\n componentWillLoad() {\n this.internalSelectedKeys = new Set(this.selectedKeys);\n this.internalSortState = [...this.sortState];\n this.internalFilterState = [...this.filterState];\n }\n\n // -------------------------------------------------------------------------\n // Helpers\n // -------------------------------------------------------------------------\n\n private getRowKey(row: unknown, index: number): string | number {\n if (typeof row === 'object' && row !== null && this.rowKey in row) {\n return (row as Record<string, unknown>)[this.rowKey] as string | number;\n }\n return index;\n }\n\n private getCellValue(row: unknown, accessor: string): unknown {\n if (typeof row !== 'object' || row === null) return undefined;\n\n // Support dot notation for nested properties\n const keys = accessor.split('.');\n let value: unknown = row;\n\n for (const key of keys) {\n if (typeof value === 'object' && value !== null && key in value) {\n value = (value as Record<string, unknown>)[key];\n } else {\n return undefined;\n }\n }\n\n return value;\n }\n\n private getVisibleColumns(): DataGridColumn[] {\n return this.columns.filter(col => col.visible !== false);\n }\n\n // -------------------------------------------------------------------------\n // Data Processing\n // -------------------------------------------------------------------------\n\n private getProcessedData(): unknown[] {\n let processedData = [...this.data];\n\n // Apply filtering\n if (this.enableFiltering && this.internalFilterState.length > 0) {\n processedData = this.applyFilters(processedData);\n }\n\n // Apply sorting\n if (this.enableSorting && this.internalSortState.length > 0) {\n processedData = this.applySorting(processedData);\n }\n\n return processedData;\n }\n\n private applyFilters(data: unknown[]): unknown[] {\n return data.filter(row => {\n return this.internalFilterState.every(filter => {\n const column = this.columns.find(c => c.id === filter.columnId);\n if (!column) return true;\n\n const value = this.getCellValue(row, column.accessor as string);\n return this.matchesFilter(value, filter, column.type);\n });\n });\n }\n\n private matchesFilter(value: unknown, filter: DataGridFilterState, type?: DataGridColumnType): boolean {\n if (filter.operator === 'isEmpty') {\n return value === null || value === undefined || value === '';\n }\n if (filter.operator === 'isNotEmpty') {\n return value !== null && value !== undefined && value !== '';\n }\n\n const filterValue = filter.value;\n\n if (type === 'number') {\n const numValue = Number(value);\n const numFilter = Number(filterValue);\n\n switch (filter.operator) {\n case 'equals': return numValue === numFilter;\n case 'greaterThan': return numValue > numFilter;\n case 'lessThan': return numValue < numFilter;\n case 'greaterThanOrEqual': return numValue >= numFilter;\n case 'lessThanOrEqual': return numValue <= numFilter;\n case 'between': return numValue >= numFilter && numValue <= Number(filter.valueTo);\n default: return true;\n }\n }\n\n if (type === 'date') {\n const dateValue = new Date(value as string).getTime();\n const dateFilter = new Date(filterValue as string).getTime();\n\n switch (filter.operator) {\n case 'equals': return dateValue === dateFilter;\n case 'greaterThan': return dateValue > dateFilter;\n case 'lessThan': return dateValue < dateFilter;\n case 'between': {\n const dateTo = new Date(filter.valueTo as string).getTime();\n return dateValue >= dateFilter && dateValue <= dateTo;\n }\n default: return true;\n }\n }\n\n // Text filtering\n const strValue = String(value ?? '').toLowerCase();\n const strFilter = String(filterValue ?? '').toLowerCase();\n\n switch (filter.operator) {\n case 'contains': return strValue.includes(strFilter);\n case 'equals': return strValue === strFilter;\n case 'startsWith': return strValue.startsWith(strFilter);\n case 'endsWith': return strValue.endsWith(strFilter);\n default: return true;\n }\n }\n\n private applySorting(data: unknown[]): unknown[] {\n if (this.internalSortState.length === 0) return data;\n\n return [...data].sort((a, b) => {\n for (const sort of this.internalSortState) {\n const column = this.columns.find(c => c.id === sort.columnId);\n if (!column || !sort.direction) continue;\n\n const aValue = this.getCellValue(a, column.accessor as string);\n const bValue = this.getCellValue(b, column.accessor as string);\n\n let comparison = 0;\n\n if (column.type === 'number') {\n comparison = (Number(aValue) || 0) - (Number(bValue) || 0);\n } else if (column.type === 'date') {\n comparison = new Date(aValue as string).getTime() - new Date(bValue as string).getTime();\n } else {\n comparison = String(aValue ?? '').localeCompare(String(bValue ?? ''));\n }\n\n if (comparison !== 0) {\n return sort.direction === 'desc' ? -comparison : comparison;\n }\n }\n return 0;\n });\n }\n\n // -------------------------------------------------------------------------\n // Grouping Logic\n // -------------------------------------------------------------------------\n\n private getGroupedData(data: unknown[]): DataGridGroup[] {\n if (!this.enableGrouping || this.groupBy.length === 0) {\n return [];\n }\n\n return this.groupByColumn(data, this.groupBy[0], 0);\n }\n\n private groupByColumn(data: unknown[], columnId: string, depth: number): DataGridGroup[] {\n const column = this.columns.find(c => c.id === columnId);\n if (!column) return [];\n\n const groups = new Map<string, unknown[]>();\n\n for (const row of data) {\n const value = this.getCellValue(row, column.accessor as string);\n const key = String(value ?? '(Empty)');\n\n if (!groups.has(key)) {\n groups.set(key, []);\n }\n groups.get(key)!.push(row);\n }\n\n const result: DataGridGroup[] = [];\n\n for (const [key, rows] of groups) {\n const groupKey = `${columnId}:${key}`;\n result.push({\n key: groupKey,\n value: key,\n displayValue: key,\n rows,\n depth,\n columnId,\n });\n }\n\n // Sort groups alphabetically\n result.sort((a, b) => String(a.displayValue).localeCompare(String(b.displayValue)));\n\n return result;\n }\n\n private handleGroupToggle = (groupKey: string) => {\n const isCurrentlyExpanded = this.expandedGroups.includes(groupKey);\n\n if (isCurrentlyExpanded) {\n this.expandedGroups = this.expandedGroups.filter(key => key !== groupKey);\n } else {\n this.expandedGroups = [...this.expandedGroups, groupKey];\n }\n\n this.bhGroupToggle.emit({ groupKey, expanded: !isCurrentlyExpanded });\n };\n\n // -------------------------------------------------------------------------\n // Selection Handlers\n // -------------------------------------------------------------------------\n\n private handleSelectAll = () => {\n const processedData = this.getProcessedData();\n const allKeys = processedData.map((row, i) => this.getRowKey(row, i));\n\n const isAllSelected = allKeys.every(key => this.internalSelectedKeys.has(key));\n\n if (isAllSelected) {\n this.internalSelectedKeys = new Set();\n } else {\n this.internalSelectedKeys = new Set(allKeys);\n }\n\n this.emitSelectionChange();\n };\n\n private handleRowSelect = (row: unknown, rowIndex: number) => {\n const key = this.getRowKey(row, rowIndex);\n\n if (this.selectionMode === 'single') {\n if (this.internalSelectedKeys.has(key)) {\n this.internalSelectedKeys = new Set();\n } else {\n this.internalSelectedKeys = new Set([key]);\n }\n } else {\n const newSet = new Set(this.internalSelectedKeys);\n if (newSet.has(key)) {\n newSet.delete(key);\n } else {\n newSet.add(key);\n }\n this.internalSelectedKeys = newSet;\n }\n\n this.emitSelectionChange();\n };\n\n private emitSelectionChange() {\n const selectedKeys = Array.from(this.internalSelectedKeys);\n const selectedRows = this.data.filter((row, i) =>\n this.internalSelectedKeys.has(this.getRowKey(row, i))\n );\n\n this.selectedKeys = selectedKeys;\n this.bhSelectionChange.emit({ selectedKeys, selectedRows });\n }\n\n private getSelectionState(): DataGridRowSelection {\n const processedData = this.getProcessedData();\n const allKeys = processedData.map((row, i) => this.getRowKey(row, i));\n const selectedCount = allKeys.filter(key => this.internalSelectedKeys.has(key)).length;\n\n return {\n selectedRows: this.internalSelectedKeys,\n isAllSelected: selectedCount === allKeys.length && allKeys.length > 0,\n isIndeterminate: selectedCount > 0 && selectedCount < allKeys.length,\n };\n }\n\n // -------------------------------------------------------------------------\n // Sort Handlers\n // -------------------------------------------------------------------------\n\n private handleSort = (column: DataGridColumn) => {\n if (!this.enableSorting || column.sortable === false) return;\n\n const existingSort = this.internalSortState.find(s => s.columnId === column.id);\n let newDirection: DataGridSortDirection = 'asc';\n\n if (existingSort) {\n if (existingSort.direction === 'asc') {\n newDirection = 'desc';\n } else if (existingSort.direction === 'desc') {\n newDirection = null;\n }\n }\n\n let newSortState: DataGridSortState[];\n\n if (this.multiSort) {\n newSortState = this.internalSortState.filter(s => s.columnId !== column.id);\n if (newDirection) {\n newSortState.push({ columnId: column.id, direction: newDirection });\n }\n } else {\n newSortState = newDirection ? [{ columnId: column.id, direction: newDirection }] : [];\n }\n\n this.internalSortState = newSortState;\n this.sortState = newSortState;\n this.bhSortChange.emit(newSortState);\n };\n\n private getSortDirection(columnId: string): DataGridSortDirection {\n const sort = this.internalSortState.find(s => s.columnId === columnId);\n return sort?.direction ?? null;\n }\n\n // -------------------------------------------------------------------------\n // Filter Handlers\n // -------------------------------------------------------------------------\n\n private handleFilterInput = (column: DataGridColumn, value: string) => {\n this.filterInputValues = { ...this.filterInputValues, [column.id]: value };\n\n // Debounced filter application\n const newFilterState = this.internalFilterState.filter(f => f.columnId !== column.id);\n\n if (value.trim()) {\n newFilterState.push({\n columnId: column.id,\n operator: column.type === 'number' ? 'equals' : column.type === 'date' ? 'equals' : 'contains',\n value: value.trim(),\n });\n }\n\n this.internalFilterState = newFilterState;\n this.filterState = newFilterState;\n this.bhFilterChange.emit(newFilterState);\n };\n\n private toggleFilterPopover = (columnId: string) => {\n if (this.activeFilterColumn === columnId) {\n this.activeFilterColumn = null;\n } else {\n this.activeFilterColumn = columnId;\n }\n };\n\n // -------------------------------------------------------------------------\n // Row/Cell Handlers\n // -------------------------------------------------------------------------\n\n private handleRowClick = (row: unknown, rowIndex: number) => {\n const rowKey = this.getRowKey(row, rowIndex);\n this.bhRowClick.emit({ row, rowIndex, rowKey });\n };\n\n private handleCellClick = (row: unknown, column: DataGridColumn, rowIndex: number, columnIndex: number) => {\n const value = this.getCellValue(row, column.accessor as string);\n this.bhCellClick.emit({ row, column, value, rowIndex, columnIndex });\n };\n\n // -------------------------------------------------------------------------\n // Render Methods\n // -------------------------------------------------------------------------\n\n private renderHeader() {\n if (!this.showHeader) return null;\n\n const visibleColumns = this.getVisibleColumns();\n const selectionState = this.getSelectionState();\n\n return (\n <div class=\"data-grid-header-row\" role=\"row\">\n {this.enableSelection && (\n <div class=\"data-grid-header-cell data-grid-cell-checkbox\" role=\"columnheader\">\n <bh-checkbox\n size=\"sm\"\n checked={selectionState.isAllSelected}\n indeterminate={selectionState.isIndeterminate}\n onBhChange={() => this.handleSelectAll()}\n />\n </div>\n )}\n {visibleColumns.map((column) => this.renderHeaderCell(column))}\n </div>\n );\n }\n\n private renderHeaderCell(column: DataGridColumn) {\n const sortDirection = this.getSortDirection(column.id);\n const isSortable = this.enableSorting && column.sortable !== false;\n\n const cellClasses = {\n 'data-grid-header-cell': true,\n 'data-grid-header-cell-sortable': isSortable,\n 'data-grid-header-cell-sorted': sortDirection !== null,\n [`data-grid-cell-align-${column.align || 'left'}`]: true,\n };\n\n const cellStyle = column.width\n ? { width: typeof column.width === 'number' ? `${column.width}px` : column.width }\n : {};\n\n return (\n <div\n class={cellClasses}\n style={cellStyle}\n role=\"columnheader\"\n aria-sort={sortDirection === 'asc' ? 'ascending' : sortDirection === 'desc' ? 'descending' : 'none'}\n onClick={() => isSortable && this.handleSort(column)}\n >\n <span class=\"data-grid-header-text\">\n {column.headerRenderer ? column.headerRenderer(column) : column.header}\n </span>\n {isSortable && sortDirection && (\n <span class=\"data-grid-sort-icon material-symbols-outlined\">\n {sortDirection === 'asc' ? 'arrow_upward' : 'arrow_downward'}\n </span>\n )}\n </div>\n );\n }\n\n private renderFilterRow() {\n if (!this.enableFiltering || !this.showFilterRow) return null;\n\n const visibleColumns = this.getVisibleColumns();\n\n return (\n <div class=\"data-grid-filter-row\" role=\"row\">\n {this.enableSelection && (\n <div class=\"data-grid-filter-cell data-grid-cell-checkbox\" role=\"cell\" />\n )}\n {visibleColumns.map((column) => this.renderFilterCell(column))}\n </div>\n );\n }\n\n private renderFilterCell(column: DataGridColumn) {\n if (column.filterable === false) {\n return <div class=\"data-grid-filter-cell\" role=\"cell\" />;\n }\n\n const cellStyle = column.width\n ? { width: typeof column.width === 'number' ? `${column.width}px` : column.width }\n : {};\n\n const inputValue = this.filterInputValues[column.id] || '';\n const hasFilter = inputValue.trim() !== '';\n\n // For date columns, use date picker\n if (column.type === 'date') {\n return (\n <div class=\"data-grid-filter-cell\" style={cellStyle} role=\"cell\">\n <div class={{ 'data-grid-filter-icon-wrapper': true, 'data-grid-filter-active': hasFilter }}>\n <bh-date-picker\n variant=\"dropdown-ghost\"\n placeholder=\"\"\n showLabel={false}\n showFooter={false}\n onBhChange={(e: CustomEvent) => {\n const date = e.detail;\n if (date) {\n const dateStr = `${date.year}-${String(date.month + 1).padStart(2, '0')}-${String(date.day).padStart(2, '0')}`;\n this.handleFilterInput(column, dateStr);\n } else {\n this.handleFilterInput(column, '');\n }\n }}\n />\n </div>\n </div>\n );\n }\n\n // For text/number columns, use search icon with popover input\n return (\n <div class=\"data-grid-filter-cell\" style={cellStyle} role=\"cell\">\n <div class={{ 'data-grid-filter-icon-wrapper': true, 'data-grid-filter-active': hasFilter }}>\n <span\n class=\"data-grid-filter-icon material-symbols-outlined\"\n onClick={() => this.toggleFilterPopover(column.id)}\n >\n search\n </span>\n {this.activeFilterColumn === column.id && (\n <div class=\"data-grid-filter-popover\">\n <input\n type={column.type === 'number' ? 'number' : 'text'}\n class=\"data-grid-filter-popover-input\"\n placeholder={`Filter ${column.header}...`}\n value={inputValue}\n onInput={(e) => this.handleFilterInput(column, (e.target as HTMLInputElement).value)}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === 'Escape') {\n this.activeFilterColumn = null;\n }\n }}\n ref={(el) => el && requestAnimationFrame(() => el.focus())}\n />\n </div>\n )}\n </div>\n </div>\n );\n }\n\n private renderBody() {\n const processedData = this.getProcessedData();\n const visibleColumns = this.getVisibleColumns();\n\n if (processedData.length === 0) {\n return this.renderEmptyState();\n }\n\n // Check if grouping is enabled\n if (this.enableGrouping && this.groupBy.length > 0) {\n const groups = this.getGroupedData(processedData);\n // Use expandedGroups directly in map for proper Stencil reactivity\n const expandedKeys = this.expandedGroups;\n return (\n <div class=\"data-grid-body\" role=\"rowgroup\">\n {groups.map((group) => {\n const isExpanded = expandedKeys.includes(group.key);\n return this.renderGroupSectionWithState(group, visibleColumns, isExpanded);\n })}\n </div>\n );\n }\n\n return (\n <div class=\"data-grid-body\" role=\"rowgroup\">\n {processedData.map((row, rowIndex) => this.renderRow(row, rowIndex, visibleColumns))}\n </div>\n );\n }\n\n private renderGroupSectionWithState(group: DataGridGroup, visibleColumns: DataGridColumn[], isExpanded: boolean) {\n const column = this.columns.find(c => c.id === group.columnId);\n const columnHeader = column?.header || group.columnId;\n\n const sectionClasses = {\n 'data-grid-group-section': true,\n 'data-grid-group-section-expanded': isExpanded,\n };\n\n return (\n <div class={sectionClasses} key={group.key}>\n {this.renderGroupRow(group, columnHeader, isExpanded)}\n <div class=\"data-grid-group-rows\" style={{ display: isExpanded ? 'contents' : 'none' }}>\n {group.rows.map((row, rowIndex) => {\n const rowKey = this.getRowKey(row, rowIndex);\n return (\n <div key={`${group.key}-row-${rowKey}`}>\n {this.renderRow(row, rowIndex, visibleColumns, group.depth + 1)}\n </div>\n );\n })}\n </div>\n </div>\n );\n }\n\n private renderGroupRow(group: DataGridGroup, columnHeader: string, isExpanded: boolean) {\n const groupClasses = {\n 'data-grid-group-row': true,\n 'data-grid-group-row-expanded': isExpanded,\n };\n\n const indentStyle = group.depth > 0 ? { paddingLeft: `${(group.depth * 24) + 8}px` } : {};\n\n return (\n <div\n class={groupClasses}\n style={indentStyle}\n role=\"row\"\n aria-expanded={isExpanded ? 'true' : 'false'}\n onClick={() => this.handleGroupToggle(group.key)}\n >\n {this.enableSelection && (\n <div class=\"data-grid-cell data-grid-cell-checkbox\" role=\"cell\">\n <bh-checkbox\n size=\"sm\"\n checked={this.isGroupAllSelected(group)}\n indeterminate={this.isGroupIndeterminate(group)}\n onBhChange={(e: Event) => {\n e.stopPropagation();\n this.handleGroupSelect(group);\n }}\n onClick={(e: Event) => e.stopPropagation()}\n />\n </div>\n )}\n <div class=\"data-grid-group-toggle\">\n <span class=\"material-symbols-outlined\">\n chevron_right\n </span>\n </div>\n <span class=\"data-grid-group-label\">\n <span class=\"data-grid-group-column-name\">{columnHeader}: </span>\n <span class=\"data-grid-group-value\">{group.displayValue}</span>\n </span>\n <span class=\"data-grid-group-count\">\n ({group.rows.length} {group.rows.length === 1 ? 'item' : 'items'})\n </span>\n </div>\n );\n }\n\n private isGroupAllSelected(group: DataGridGroup): boolean {\n if (group.rows.length === 0) return false;\n return group.rows.every((row, i) =>\n this.internalSelectedKeys.has(this.getRowKey(row, i))\n );\n }\n\n private isGroupIndeterminate(group: DataGridGroup): boolean {\n const selectedCount = group.rows.filter((row, i) =>\n this.internalSelectedKeys.has(this.getRowKey(row, i))\n ).length;\n return selectedCount > 0 && selectedCount < group.rows.length;\n }\n\n private handleGroupSelect = (group: DataGridGroup) => {\n const groupKeys = group.rows.map((row, i) => this.getRowKey(row, i));\n const isAllSelected = this.isGroupAllSelected(group);\n\n const newSet = new Set(this.internalSelectedKeys);\n\n if (isAllSelected) {\n // Deselect all in group\n for (const key of groupKeys) {\n newSet.delete(key);\n }\n } else {\n // Select all in group\n for (const key of groupKeys) {\n newSet.add(key);\n }\n }\n\n this.internalSelectedKeys = newSet;\n this.emitSelectionChange();\n };\n\n // -------------------------------------------------------------------------\n // Editing Handlers\n // -------------------------------------------------------------------------\n\n private startEditing = (row: unknown, rowIndex: number, columnId?: string) => {\n if (!this.enableEditing) return;\n\n const rowKey = this.getRowKey(row, rowIndex);\n\n // Initialize editing values from current row\n const initialValues: Record<string, unknown> = {};\n for (const col of this.columns) {\n if (col.editable !== false) {\n initialValues[col.id] = this.getCellValue(row, col.accessor as string);\n }\n }\n\n this.editingRowKey = rowKey;\n this.editingColumnId = this.editMode === 'cell' ? (columnId || null) : null;\n this.editingValues = initialValues;\n\n if (this.editMode === 'popup') {\n this.showEditPopup = true;\n }\n\n this.bhEditStart.emit({ rowKey, row, columnId });\n };\n\n private cancelEditing = () => {\n if (this.editingRowKey === null) return;\n\n const row = this.data.find((r, i) => this.getRowKey(r, i) === this.editingRowKey);\n\n this.bhEditCancel.emit({ rowKey: this.editingRowKey, row });\n\n this.editingRowKey = null;\n this.editingColumnId = null;\n this.editingValues = {};\n this.showEditPopup = false;\n };\n\n private saveEditing = () => {\n if (this.editingRowKey === null) return;\n\n const rowIndex = this.data.findIndex((r, i) => this.getRowKey(r, i) === this.editingRowKey);\n if (rowIndex === -1) return;\n\n const originalRow = this.data[rowIndex];\n const changes: Record<string, unknown> = {};\n\n // Determine what changed\n for (const [columnId, newValue] of Object.entries(this.editingValues)) {\n const column = this.columns.find(c => c.id === columnId);\n if (column) {\n const originalValue = this.getCellValue(originalRow, column.accessor as string);\n if (originalValue !== newValue) {\n changes[columnId] = newValue;\n }\n }\n }\n\n this.bhEditSave.emit({\n rowKey: this.editingRowKey,\n rowIndex,\n originalRow,\n changes,\n });\n\n this.editingRowKey = null;\n this.editingColumnId = null;\n this.editingValues = {};\n this.showEditPopup = false;\n };\n\n private handleEditValueChange = (columnId: string, newValue: unknown) => {\n const oldValue = this.editingValues[columnId];\n\n this.editingValues = {\n ...this.editingValues,\n [columnId]: newValue,\n };\n\n if (this.editingRowKey !== null) {\n this.bhCellChange.emit({\n rowKey: this.editingRowKey,\n columnId,\n oldValue,\n newValue,\n });\n }\n };\n\n private isEditing(rowKey: string | number, columnId?: string): boolean {\n if (this.editingRowKey !== rowKey) return false;\n\n if (this.editMode === 'cell') {\n return columnId ? this.editingColumnId === columnId : false;\n }\n\n // Row or popup mode - entire row is in edit mode\n return true;\n }\n\n private handleCellDoubleClick = (row: unknown, column: DataGridColumn, rowIndex: number) => {\n if (!this.enableEditing || column.editable === false) return;\n\n if (this.editMode === 'cell') {\n this.startEditing(row, rowIndex, column.id);\n }\n };\n\n private handleEditKeyDown = (event: KeyboardEvent, column: DataGridColumn) => {\n if (event.key === 'Enter') {\n event.preventDefault();\n if (this.editMode === 'cell') {\n this.saveEditing();\n }\n } else if (event.key === 'Escape') {\n event.preventDefault();\n this.cancelEditing();\n } else if (event.key === 'Tab' && this.editMode === 'cell') {\n // Move to next editable cell\n event.preventDefault();\n this.moveToNextEditableCell(column, event.shiftKey);\n }\n };\n\n private moveToNextEditableCell = (currentColumn: DataGridColumn, reverse: boolean) => {\n const editableColumns = this.columns.filter(c => c.editable !== false && c.visible !== false);\n const currentIndex = editableColumns.findIndex(c => c.id === currentColumn.id);\n\n if (currentIndex === -1) return;\n\n const nextIndex = reverse ? currentIndex - 1 : currentIndex + 1;\n\n if (nextIndex >= 0 && nextIndex < editableColumns.length) {\n // Same row, different column\n this.editingColumnId = editableColumns[nextIndex].id;\n } else {\n // Save and potentially move to next/prev row\n this.saveEditing();\n }\n };\n\n // -------------------------------------------------------------------------\n // Render Methods\n // -------------------------------------------------------------------------\n\n private renderRow(row: unknown, rowIndex: number, visibleColumns: DataGridColumn[], depth: number = 0) {\n const rowKey = this.getRowKey(row, rowIndex);\n const isSelected = this.internalSelectedKeys.has(rowKey);\n const isHovered = this.hoveredRowIndex === rowIndex;\n const isRowEditing = this.editingRowKey === rowKey;\n\n const rowClasses = {\n 'data-grid-row': true,\n 'data-grid-row-selected': isSelected,\n 'data-grid-row-hover': isHovered,\n 'data-grid-row-striped': this.striped && rowIndex % 2 === 1,\n 'data-grid-row-grouped': depth > 0,\n 'data-grid-row-editing': isRowEditing,\n };\n\n return (\n <div\n class={rowClasses}\n role=\"row\"\n aria-selected={isSelected ? 'true' : 'false'}\n onMouseEnter={() => { this.hoveredRowIndex = rowIndex; }}\n onMouseLeave={() => { this.hoveredRowIndex = null; }}\n onClick={() => this.handleRowClick(row, rowIndex)}\n >\n {this.enableSelection && (\n <div\n class=\"data-grid-cell data-grid-cell-checkbox\"\n role=\"cell\"\n onClick={(e) => { e.stopPropagation(); }}\n >\n <bh-checkbox\n size=\"sm\"\n checked={isSelected}\n onBhChange={() => this.handleRowSelect(row, rowIndex)}\n onClick={(e: Event) => e.stopPropagation()}\n />\n </div>\n )}\n {depth > 0 && (\n <div class=\"data-grid-row-indent\" style={{ width: `${depth * 24}px` }} />\n )}\n {visibleColumns.map((column, columnIndex) => this.renderCell(row, column, rowIndex, columnIndex))}\n {this.enableEditing && this.showEditActions && this.renderRowActions(row, rowIndex, isRowEditing)}\n </div>\n );\n }\n\n private renderRowActions(row: unknown, rowIndex: number, isEditing: boolean) {\n return (\n <div class=\"data-grid-cell data-grid-cell-actions\" role=\"cell\" onClick={(e) => e.stopPropagation()}>\n {isEditing ? (\n <div class=\"data-grid-edit-actions\">\n <button\n class=\"data-grid-action-btn data-grid-action-save\"\n onClick={() => this.saveEditing()}\n title=\"Save\"\n >\n <span class=\"material-symbols-outlined\">check</span>\n </button>\n <button\n class=\"data-grid-action-btn data-grid-action-cancel\"\n onClick={() => this.cancelEditing()}\n title=\"Cancel\"\n >\n <span class=\"material-symbols-outlined\">close</span>\n </button>\n </div>\n ) : (\n <button\n class=\"data-grid-action-btn data-grid-action-edit\"\n onClick={() => this.startEditing(row, rowIndex)}\n title=\"Edit\"\n >\n <span class=\"material-symbols-outlined\">edit</span>\n </button>\n )}\n </div>\n );\n }\n\n private renderCell(row: unknown, column: DataGridColumn, rowIndex: number, columnIndex: number) {\n const rowKey = this.getRowKey(row, rowIndex);\n const value = this.getCellValue(row, column.accessor as string);\n const isEditingCell = this.isEditing(rowKey, column.id);\n const canEdit = this.enableEditing && column.editable !== false;\n\n const cellClasses = {\n 'data-grid-cell': true,\n [`data-grid-cell-align-${column.align || 'left'}`]: true,\n [`data-grid-cell-type-${column.type || 'text'}`]: true,\n 'data-grid-cell-editing': isEditingCell,\n 'data-grid-cell-editable': canEdit && !isEditingCell,\n };\n\n const cellStyle = column.width\n ? { width: typeof column.width === 'number' ? `${column.width}px` : column.width }\n : {};\n\n return (\n <div\n class={cellClasses}\n style={cellStyle}\n role=\"cell\"\n onClick={(e) => {\n e.stopPropagation();\n this.handleCellClick(row, column, rowIndex, columnIndex);\n }}\n onDblClick={(e) => {\n e.stopPropagation();\n this.handleCellDoubleClick(row, column, rowIndex);\n }}\n >\n {isEditingCell\n ? this.renderEditInput(column, value)\n : column.cellRenderer\n ? column.cellRenderer(value, row as never, rowIndex)\n : this.formatCellValue(value, column.type)\n }\n </div>\n );\n }\n\n private renderEditInput(column: DataGridColumn, originalValue: unknown) {\n const currentValue = this.editingValues[column.id] ?? originalValue;\n\n // Custom edit renderer takes precedence\n if (column.editCellRenderer) {\n return column.editCellRenderer(\n currentValue,\n {} as never, // row not needed for most custom renderers\n 0,\n (newValue: unknown) => this.handleEditValueChange(column.id, newValue)\n );\n }\n\n const inputType = column.type === 'number' ? 'number' :\n column.type === 'date' ? 'date' :\n column.type === 'boolean' ? 'checkbox' : 'text';\n\n if (column.type === 'boolean') {\n return (\n <bh-checkbox\n size=\"sm\"\n checked={Boolean(currentValue)}\n onBhChange={(e: CustomEvent) => this.handleEditValueChange(column.id, e.detail.checked)}\n />\n );\n }\n\n return (\n <input\n type={inputType}\n class=\"data-grid-edit-input\"\n value={currentValue != null ? String(currentValue) : ''}\n onInput={(e) => {\n const input = e.target as HTMLInputElement;\n const newValue = column.type === 'number' ? Number(input.value) : input.value;\n this.handleEditValueChange(column.id, newValue);\n }}\n onKeyDown={(e) => this.handleEditKeyDown(e, column)}\n ref={(el) => {\n if (el) {\n // Auto-focus on the first editable input\n requestAnimationFrame(() => el.focus());\n }\n }}\n />\n );\n }\n\n private formatCellValue(value: unknown, type?: DataGridColumnType): string {\n if (value === null || value === undefined) return '';\n\n switch (type) {\n case 'date':\n return new Date(value as string).toLocaleDateString();\n case 'number':\n return typeof value === 'number' ? value.toLocaleString() : String(value);\n case 'boolean':\n return value ? 'Yes' : 'No';\n default:\n return String(value);\n }\n }\n\n private renderEmptyState() {\n return (\n <div class=\"data-grid-empty-state\">\n <bh-empty-state\n emptyTitle=\"No data\"\n description={this.emptyMessage}\n />\n </div>\n );\n }\n\n private renderLoading() {\n return (\n <div class=\"data-grid-loading-overlay\">\n <bh-loader-spinner size=\"lg\" />\n </div>\n );\n }\n\n // -------------------------------------------------------------------------\n // Main Render\n // -------------------------------------------------------------------------\n\n render() {\n const gridClasses = {\n 'data-grid': true,\n 'data-grid-compact': this.compact,\n 'data-grid-bordered': this.showRowBorders,\n 'data-grid-loading': this.loading,\n };\n\n return (\n <div class={gridClasses} role=\"grid\" aria-busy={this.loading ? 'true' : 'false'}>\n <div class=\"data-grid-table\">\n {this.renderHeader()}\n {this.renderFilterRow()}\n {this.renderBody()}\n </div>\n {this.loading && this.renderLoading()}\n </div>\n );\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bh-date-picker-content.bh-picker-menu.entry.esm.js","sources":["src/components/bh-date-picker-content/bh-date-picker-content.css?tag=bh-date-picker-content&encapsulation=shadow","src/components/bh-date-picker-content/bh-date-picker-content.tsx","src/components/bh-picker-menu/bh-picker-menu.css?tag=bh-picker-menu&encapsulation=shadow","src/components/bh-picker-menu/bh-picker-menu.tsx"],"sourcesContent":["@import '../../global/global.css';\n\n:host {\n display: block;\n}\n\n/* Content area - reusable calendar content */\n.date-picker-content {\n width: 100%;\n font-family: var(--font-inter);\n display: flex;\n flex-direction: column;\n}\n\n/* Month Navigation */\n.month-navigation {\n display: flex;\n justify-content: space-between;\n align-items: center;\n gap: var(--spacing-sm);\n padding: var(--spacing-md);\n}\n\n/* Inline Month Picker - constrain to container */\n.month-picker-inline {\n flex: 1;\n overflow: hidden;\n max-height: 270px;\n animation: fadeIn 150ms ease-out;\n}\n\n@keyframes fadeIn {\n from {\n opacity: 0;\n transform: translateY(-10px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n}\n\n.month-picker-inline.animate-fade-out {\n animation: fadeOut 150ms ease-out;\n}\n\n@keyframes fadeOut {\n from {\n opacity: 1;\n transform: translateY(0);\n }\n to {\n opacity: 0;\n transform: translateY(-10px);\n }\n}\n\n/* Calendar Grid */\n.calendar-grid {\n padding: 0 var(--spacing-md) var(--spacing-md);\n flex: 1;\n}\n\n.day-names {\n display: grid;\n grid-template-columns: repeat(7, 1fr);\n width: 280px;\n gap: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.day-name {\n width: 40px;\n height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n font-family: var(--font-inter);\n font-weight: var(--weight-medium);\n font-size: var(--text-sm-size);\n line-height: var(--text-sm-line);\n color: var(--color-neutral-500);\n}\n\n.date-cells {\n display: grid;\n grid-template-columns: repeat(7, 1fr);\n width: 280px;\n row-gap: var(--spacing-xs, 4px);\n column-gap: 0;\n justify-items: center;\n align-items: center;\n}\n\n/* Calendar Cell States */\n.calendar-cell {\n width: 40px;\n height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n position: relative;\n border-radius: var(--radius-full);\n font-family: var(--font-inter);\n font-weight: var(--weight-medium);\n font-size: var(--text-sm-size);\n line-height: var(--text-sm-line);\n cursor: pointer;\n transition: all var(--animation-duration-fast, 0.1s) var(--animation-easing-ease, ease);\n}\n\n.calendar-cell.other-month .date-number {\n color: var(--color-neutral-400);\n}\n\n.calendar-cell.other-month.disabled .date-number {\n color: var(--color-neutral-300);\n}\n\n.calendar-cell.selectable .date-number {\n color: var(--color-neutral-500);\n}\n\n.calendar-cell.selectable:hover {\n background: var(--color-neutral-50);\n}\n\n.calendar-cell.selectable:hover .date-number {\n color: var(--color-neutral-800);\n}\n\n.calendar-cell.today {\n border: 2px solid var(--color-brand-600);\n}\n\n.calendar-cell.today .date-number {\n color: var(--color-neutral-500);\n}\n\n.calendar-cell.today:hover {\n background: var(--color-brand-100);\n}\n\n.calendar-cell.today:hover .date-number {\n color: var(--color-brand-600);\n}\n\n.calendar-cell.selected {\n background: var(--color-brand-600);\n}\n\n.calendar-cell.selected .date-number {\n color: var(--color-white);\n font-weight: var(--weight-semibold);\n}\n\n.calendar-cell.selected:hover {\n background: var(--color-brand-800);\n}\n\n.calendar-cell.selected:hover .date-number {\n color: var(--color-white);\n font-weight: var(--weight-semibold);\n}\n\n/* Range states - in-range background */\n.calendar-cell.in-range {\n background: var(--color-neutral-100);\n border-radius: 0;\n position: relative;\n}\n\n.calendar-cell.in-range .date-number {\n color: var(--color-neutral-800);\n font-weight: var(--weight-medium);\n}\n\n.calendar-cell.in-range:hover {\n background: var(--color-neutral-100);\n}\n\n.calendar-cell.in-range:hover .date-number {\n background: var(--color-neutral-200);\n border-radius: var(--radius-full);\n width: 40px;\n height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n/* Range start and end styling */\n.calendar-cell.range-start,\n.calendar-cell.range-end {\n position: relative;\n}\n\n.calendar-cell.range-start .date-number,\n.calendar-cell.range-end .date-number {\n background: var(--color-brand-600);\n color: var(--color-white);\n font-weight: var(--weight-semibold);\n border-radius: var(--radius-full);\n width: 40px;\n height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n.calendar-cell.range-start:hover .date-number,\n.calendar-cell.range-start.selectable:hover .date-number,\n.calendar-cell.range-end:hover .date-number,\n.calendar-cell.range-end.selectable:hover .date-number {\n background: var(--color-brand-800);\n color: var(--color-white);\n}\n\n/* Range start - extend background to the right */\n.calendar-cell.range-start {\n background: transparent;\n}\n\n.calendar-cell.range-start::after {\n content: '';\n position: absolute;\n left: 50%;\n top: 0;\n width: 50%;\n height: 100%;\n background: var(--color-neutral-100);\n border-radius: var(--radius-full) 0 0 var(--radius-full);\n z-index: 0;\n}\n\n.calendar-cell.range-start:hover::after,\n.calendar-cell.range-start.selectable:hover::after {\n background: var(--color-neutral-200);\n}\n\n/* Range end - extend background to the left */\n.calendar-cell.range-end {\n background: transparent;\n}\n\n.calendar-cell.range-end::after {\n content: '';\n position: absolute;\n left: 0;\n top: 0;\n width: 50%;\n height: 100%;\n background: var(--color-neutral-100);\n border-radius: 0 var(--radius-full) var(--radius-full) 0;\n z-index: 0;\n}\n\n.calendar-cell.range-end:hover::after,\n.calendar-cell.range-end.selectable:hover::after {\n background: var(--color-neutral-200);\n}\n\n/* When both start and end are the same day */\n.calendar-cell.range-start.range-end {\n background: transparent;\n}\n\n.calendar-cell.range-start.range-end::after {\n display: none;\n}\n\n.calendar-cell.range-start.range-end .date-number {\n border-radius: var(--radius-full);\n}\n\n/* Range start without end (first selection only) */\n.calendar-cell.range-start:not(.in-range):not(:has(~ .range-end))::after {\n display: none;\n}\n\n/* Row start/end rounding for in-range cells */\n.calendar-cell.in-range:nth-child(7n+1) {\n border-top-left-radius: var(--radius-full);\n border-bottom-left-radius: var(--radius-full);\n}\n\n.calendar-cell.in-range:nth-child(7n) {\n border-top-right-radius: var(--radius-full);\n border-bottom-right-radius: var(--radius-full);\n}\n\n/* Range start at end of row */\n.calendar-cell.range-start:nth-child(7n)::after {\n display: none;\n}\n\n/* Range end at start of row */\n.calendar-cell.range-end:nth-child(7n+1)::after {\n display: none;\n}\n\n/* Today in range */\n.calendar-cell.today.in-range {\n background: var(--color-brand-50);\n}\n\n.calendar-cell.today.in-range .date-number {\n color: var(--color-brand-600);\n font-weight: var(--weight-medium);\n background: transparent;\n border: 2px solid var(--color-brand-600);\n}\n\n.calendar-cell.today.in-range:hover {\n background: var(--color-brand-100);\n}\n\n/* Today as range start/end */\n.calendar-cell.today.range-start .date-number,\n.calendar-cell.today.range-end .date-number {\n background: var(--color-brand-600);\n color: var(--color-white);\n border: none;\n}\n\n.calendar-cell.disabled {\n cursor: not-allowed;\n}\n\n.calendar-cell.disabled .date-number {\n color: var(--color-neutral-300);\n}\n\n.date-number {\n position: relative;\n z-index: 1;\n}\n","import { Component, Prop, State, Event, EventEmitter, Watch, h, Host } from '@stencil/core';\nimport { MonthYear } from '../bh-month-picker-content/bh-month-picker-content';\n\nexport interface SelectedDate {\n year: number;\n month: number; // 0-11\n day: number; // 1-31\n}\n\nexport interface DisabledDate {\n year: number;\n month: number;\n day: number;\n}\n\ninterface CalendarCell {\n day: number;\n isCurrentMonth: boolean;\n isToday: boolean;\n isSelected: boolean;\n isDisabled: boolean;\n isRangeStart: boolean;\n isRangeEnd: boolean;\n isInRange: boolean;\n date: Date;\n}\n\n@Component({\n tag: 'bh-date-picker-content',\n styleUrl: 'bh-date-picker-content.css',\n shadow: true,\n})\nexport class BhDatePickerContent {\n /**\n * Minimum year in the picker\n */\n @Prop() minYear: number = 1998;\n\n /**\n * Maximum year in the picker\n */\n @Prop() maxYear: number = 2060;\n\n /**\n * Whether the picker is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Array of disabled dates\n */\n @Prop() disabledDates: DisabledDate[] = [];\n\n /**\n * Initial month to display (0-11)\n */\n @Prop() initialMonth?: number;\n\n /**\n * Initial year to display\n */\n @Prop() initialYear?: number;\n\n /**\n * Display month (for external control, 0-11)\n */\n @Prop() displayMonth?: number;\n\n /**\n * Display year (for external control)\n */\n @Prop() displayYear?: number;\n\n /**\n * Range start date (for date range picker)\n */\n @Prop() rangeStart?: SelectedDate;\n\n /**\n * Range end date (for date range picker)\n */\n @Prop() rangeEnd?: SelectedDate;\n\n /**\n * Currently selected value\n */\n @Prop() value?: SelectedDate;\n\n /**\n * Whether to show days from other months\n */\n @Prop() showOtherMonthDays: boolean = true;\n\n @State() selectedDate: SelectedDate | null = null;\n @State() currentMonth: number = new Date().getMonth();\n @State() currentYear: number = new Date().getFullYear();\n @State() isMonthDropdownOpen: boolean = false;\n @State() isMonthDropdownClosing: boolean = false;\n\n private today = new Date();\n private monthNames = [\n 'January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December',\n ];\n private dayNames = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];\n\n /**\n * Event emitted when value changes\n */\n @Event({ bubbles: true, composed: true }) bhChange!: EventEmitter<SelectedDate | null>;\n\n /**\n * Event emitted when a date is selected\n */\n @Event({ bubbles: true, composed: true }) bhDateSelect!: EventEmitter<SelectedDate | null>;\n\n /**\n * Event emitted when month changes\n */\n @Event({ bubbles: true, composed: true }) bhMonthChange!: EventEmitter<{ month: number; year: number }>;\n\n /**\n * Event emitted when month/year changes\n */\n @Event({ bubbles: true, composed: true }) bhMonthYearChange!: EventEmitter<{ month: number; year: number }>;\n\n @Watch('value')\n handleValueChange(newValue: SelectedDate | undefined) {\n if (newValue) {\n this.selectedDate = newValue;\n if (this.displayMonth === undefined && this.displayYear === undefined) {\n this.currentMonth = newValue.month;\n this.currentYear = newValue.year;\n }\n } else {\n this.selectedDate = null;\n }\n }\n\n @Watch('displayMonth')\n handleDisplayMonthChange(newValue: number | undefined) {\n if (newValue !== undefined) {\n this.currentMonth = newValue;\n }\n }\n\n @Watch('displayYear')\n handleDisplayYearChange(newValue: number | undefined) {\n if (newValue !== undefined) {\n this.currentYear = newValue;\n }\n }\n\n componentWillLoad() {\n // Initialize month/year\n if (this.displayMonth !== undefined) {\n this.currentMonth = this.displayMonth;\n } else if (this.initialMonth !== undefined) {\n this.currentMonth = this.initialMonth;\n } else {\n this.currentMonth = this.today.getMonth();\n }\n\n if (this.displayYear !== undefined) {\n this.currentYear = this.displayYear;\n } else if (this.initialYear !== undefined) {\n this.currentYear = this.initialYear;\n } else {\n this.currentYear = this.today.getFullYear();\n }\n\n // Initialize selected date\n if (this.value) {\n this.selectedDate = this.value;\n }\n }\n\n private get isInRangeMode(): boolean {\n return this.rangeStart !== undefined || this.rangeEnd !== undefined;\n }\n\n private get calendarCells(): CalendarCell[] {\n const cells: CalendarCell[] = [];\n const firstDay = new Date(this.currentYear, this.currentMonth, 1);\n const lastDay = new Date(this.currentYear, this.currentMonth + 1, 0);\n\n // Get the day of the week for the first day (0 = Sunday, 6 = Saturday)\n let firstDayOfWeek = firstDay.getDay();\n // Convert to Monday start (0 = Monday, 6 = Sunday)\n firstDayOfWeek = firstDayOfWeek === 0 ? 6 : firstDayOfWeek - 1;\n\n // Add cells for days before the first of the month\n if (this.showOtherMonthDays) {\n for (let i = 0; i < firstDayOfWeek; i++) {\n const prevMonthLastDay = new Date(this.currentYear, this.currentMonth, -i);\n cells.unshift(this.createCell(prevMonthLastDay, false));\n }\n } else {\n for (let i = 0; i < firstDayOfWeek; i++) {\n cells.unshift({\n day: 0,\n isCurrentMonth: false,\n isToday: false,\n isSelected: false,\n isDisabled: true,\n isRangeStart: false,\n isRangeEnd: false,\n isInRange: false,\n date: new Date(this.currentYear, this.currentMonth, -i),\n });\n }\n }\n\n // Add cells for current month\n for (let day = 1; day <= lastDay.getDate(); day++) {\n const date = new Date(this.currentYear, this.currentMonth, day);\n cells.push(this.createCell(date, true));\n }\n\n // Add next month days to fill the grid\n if (this.showOtherMonthDays) {\n const totalCells = cells.length;\n const remainingCells = 42 - totalCells;\n\n for (let day = 1; day <= remainingCells; day++) {\n const nextMonthDay = new Date(this.currentYear, this.currentMonth + 1, day);\n cells.push(this.createCell(nextMonthDay, false));\n\n if (cells.length % 7 === 0) break;\n }\n }\n\n return cells;\n }\n\n private createCell(date: Date, isCurrentMonth: boolean): CalendarCell {\n const isRangeStart = this.isDateRangeStart(date);\n const isRangeEnd = this.isDateRangeEnd(date);\n const isInRange = this.isDateInRange(date);\n\n return {\n day: date.getDate(),\n isCurrentMonth,\n isToday: this.isSameDay(date, this.today),\n isSelected: this.isDateSelected(date),\n isDisabled: !isCurrentMonth || this.isDateDisabled(date),\n isRangeStart,\n isRangeEnd,\n isInRange,\n date,\n };\n }\n\n private isSameDay(date1: Date, date2: Date): boolean {\n return (\n date1.getFullYear() === date2.getFullYear() &&\n date1.getMonth() === date2.getMonth() &&\n date1.getDate() === date2.getDate()\n );\n }\n\n private isDateDisabled(date: Date): boolean {\n if (!this.disabledDates || !Array.isArray(this.disabledDates)) {\n return false;\n }\n const year = date.getFullYear();\n const month = date.getMonth();\n const day = date.getDate();\n return this.disabledDates.some(\n disabled => disabled.year === year && disabled.month === month && disabled.day === day\n );\n }\n\n private isDateSelected(date: Date): boolean {\n if (this.isInRangeMode) return false;\n if (!this.selectedDate) return false;\n\n return (\n date.getFullYear() === this.selectedDate.year &&\n date.getMonth() === this.selectedDate.month &&\n date.getDate() === this.selectedDate.day\n );\n }\n\n private isDateRangeStart(date: Date): boolean {\n if (!this.rangeStart) return false;\n\n return (\n date.getFullYear() === this.rangeStart.year &&\n date.getMonth() === this.rangeStart.month &&\n date.getDate() === this.rangeStart.day\n );\n }\n\n private isDateRangeEnd(date: Date): boolean {\n if (!this.rangeEnd) return false;\n\n return (\n date.getFullYear() === this.rangeEnd.year &&\n date.getMonth() === this.rangeEnd.month &&\n date.getDate() === this.rangeEnd.day\n );\n }\n\n private isDateInRange(date: Date): boolean {\n if (!this.rangeStart || !this.rangeEnd) return false;\n\n const dateTime = date.getTime();\n const startTime = new Date(this.rangeStart.year, this.rangeStart.month, this.rangeStart.day).getTime();\n const endTime = new Date(this.rangeEnd.year, this.rangeEnd.month, this.rangeEnd.day).getTime();\n\n return dateTime > startTime && dateTime < endTime;\n }\n\n private handleCellClick(cell: CalendarCell) {\n if (cell.isDisabled || this.disabled || !cell.isCurrentMonth) {\n return;\n }\n\n const newSelectedDate: SelectedDate = {\n year: cell.date.getFullYear(),\n month: cell.date.getMonth(),\n day: cell.date.getDate(),\n };\n\n // If we're in range mode, let the parent handle it\n if (this.isInRangeMode) {\n this.bhChange.emit(newSelectedDate);\n this.bhDateSelect.emit(newSelectedDate);\n return;\n }\n\n // Toggle selection\n const isCurrentlySelected = this.selectedDate &&\n this.selectedDate.year === newSelectedDate.year &&\n this.selectedDate.month === newSelectedDate.month &&\n this.selectedDate.day === newSelectedDate.day;\n\n if (isCurrentlySelected) {\n this.selectedDate = null;\n this.bhChange.emit(null);\n this.bhDateSelect.emit(null);\n } else {\n this.selectedDate = newSelectedDate;\n this.bhChange.emit(newSelectedDate);\n this.bhDateSelect.emit(newSelectedDate);\n }\n }\n\n private handleMonthDropdownToggle = () => {\n if (this.isMonthDropdownOpen) {\n this.closeMonthDropdown();\n } else {\n this.isMonthDropdownOpen = true;\n }\n };\n\n private closeMonthDropdown() {\n this.isMonthDropdownClosing = true;\n setTimeout(() => {\n this.isMonthDropdownOpen = false;\n this.isMonthDropdownClosing = false;\n }, 150);\n }\n\n private handleMonthYearSelect = (event: CustomEvent<MonthYear>) => {\n this.closeMonthDropdown();\n\n setTimeout(() => {\n const monthYear = event.detail;\n this.currentMonth = monthYear.month;\n this.currentYear = monthYear.year;\n this.bhMonthChange.emit({ month: monthYear.month, year: monthYear.year });\n this.bhMonthYearChange.emit({ month: monthYear.month, year: monthYear.year });\n }, 100);\n };\n\n private handlePreviousMonth = () => {\n if (this.disabled) return;\n\n let newMonth = this.currentMonth - 1;\n let newYear = this.currentYear;\n\n if (newMonth < 0) {\n newMonth = 11;\n newYear = this.currentYear - 1;\n }\n\n if (newYear >= this.minYear) {\n this.currentMonth = newMonth;\n this.currentYear = newYear;\n this.bhMonthChange.emit({ month: newMonth, year: newYear });\n this.bhMonthYearChange.emit({ month: newMonth, year: newYear });\n }\n };\n\n private handleNextMonth = () => {\n if (this.disabled) return;\n\n let newMonth = this.currentMonth + 1;\n let newYear = this.currentYear;\n\n if (newMonth > 11) {\n newMonth = 0;\n newYear = this.currentYear + 1;\n }\n\n if (newYear <= this.maxYear) {\n this.currentMonth = newMonth;\n this.currentYear = newYear;\n this.bhMonthChange.emit({ month: newMonth, year: newYear });\n this.bhMonthYearChange.emit({ month: newMonth, year: newYear });\n }\n };\n\n private getCellClass(cell: CalendarCell): string {\n const classes = ['calendar-cell'];\n\n if (!cell.isCurrentMonth) classes.push('other-month');\n if (cell.isToday) classes.push('today');\n if (cell.isRangeStart) classes.push('range-start');\n if (cell.isRangeEnd) classes.push('range-end');\n if (cell.isInRange) classes.push('in-range');\n if (cell.isSelected) classes.push('selected');\n if (cell.isDisabled) classes.push('disabled');\n else if (cell.isCurrentMonth) classes.push('selectable');\n\n return classes.join(' ');\n }\n\n render() {\n const currentMonthYear = `${this.monthNames[this.currentMonth]} ${this.currentYear}`;\n\n return (\n <Host>\n <div class=\"date-picker-content\">\n {/* Month Navigation */}\n <div class=\"month-navigation\">\n <bh-button-icon\n hierarchy=\"tertiary\"\n size=\"md\"\n iconName=\"chevron_left\"\n onBhClick={this.handlePreviousMonth}\n disabled={this.disabled || (this.currentYear === this.minYear && this.currentMonth === 0)}\n ></bh-button-icon>\n\n <bh-button\n hierarchy=\"tertiary\"\n size=\"sm\"\n label={currentMonthYear}\n icon=\"trailing\"\n iconName=\"expand_more\"\n onBhClick={this.handleMonthDropdownToggle}\n ></bh-button>\n\n <bh-button-icon\n hierarchy=\"tertiary\"\n size=\"md\"\n iconName=\"chevron_right\"\n onBhClick={this.handleNextMonth}\n disabled={this.disabled || (this.currentYear === this.maxYear && this.currentMonth === 11)}\n ></bh-button-icon>\n </div>\n\n {/* Calendar Grid or Month Picker */}\n {!this.isMonthDropdownOpen && (\n <div class=\"calendar-grid\">\n {/* Day Names Header */}\n <div class=\"day-names\">\n {this.dayNames.map(dayName => (\n <div key={dayName} class=\"day-name\">{dayName}</div>\n ))}\n </div>\n\n {/* Date Cells */}\n <div class=\"date-cells\">\n {this.calendarCells.map((cell, index) => (\n <div\n key={index}\n class={this.getCellClass(cell)}\n onClick={() => this.handleCellClick(cell)}\n >\n <span class=\"date-number\">{cell.day === 0 ? '' : cell.day}</span>\n </div>\n ))}\n </div>\n </div>\n )}\n\n {/* Month Picker Content */}\n {(this.isMonthDropdownOpen || this.isMonthDropdownClosing) && (\n <div class={`month-picker-inline ${this.isMonthDropdownClosing ? 'animate-fade-out' : ''}`}>\n <bh-month-picker-content\n scrollable={true}\n height=\"275px\"\n selectedMonth={this.currentMonth}\n selectedYear={this.currentYear}\n onBhChange={this.handleMonthYearSelect}\n minYear={this.minYear}\n maxYear={this.maxYear}\n ></bh-month-picker-content>\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n","@import '../../global/global.css';\n\n:host {\n display: block;\n}\n\n/* Base picker menu styles - matching dropdown menu */\n.picker-menu {\n width: fit-content;\n min-width: 320px;\n background: var(--color-white);\n border-radius: var(--radius-md);\n box-shadow: 0px 32px 64px -12px rgba(64, 73, 104, 0.14),\n 0px 0px 1px 1px rgba(64, 73, 104, 0.1);\n border: 1px solid var(--color-neutral-200);\n overflow: hidden;\n flex-shrink: 0;\n position: relative;\n box-sizing: border-box;\n}\n\n/* Animation classes */\n.picker-menu.animate-dropdown-enter {\n animation: dropdownEnter 0.15s ease-out forwards;\n}\n\n.picker-menu.animate-dropdown-exit {\n animation: dropdownExit 0.15s ease-out forwards;\n}\n\n@keyframes dropdownEnter {\n from {\n opacity: 0;\n transform: translateY(-8px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n}\n\n@keyframes dropdownExit {\n from {\n opacity: 1;\n transform: translateY(0);\n }\n to {\n opacity: 0;\n transform: translateY(-8px);\n }\n}\n\n/* No footer variant */\n.picker-menu.no-footer {\n padding-bottom: var(--spacing-md);\n}\n\n/* Footer - following dropdown menu pattern */\n.picker-menu-footer {\n border-top: 1px solid var(--color-neutral-200);\n padding: var(--spacing-xl) var(--spacing-xl);\n background: var(--color-white);\n}\n\n.picker-menu-actions {\n display: flex;\n justify-content: flex-end;\n align-items: center;\n gap: var(--spacing-lg);\n}\n\n/* When today button is present, use space-between layout */\n.picker-menu-actions.has-today-button {\n justify-content: space-between;\n}\n\n.picker-menu-main-actions {\n display: flex;\n gap: var(--spacing-lg);\n}\n","import { Component, Prop, State, Event, EventEmitter, Watch, h, Host } from '@stencil/core';\nimport { MonthYear, DisabledMonth } from '../bh-month-picker-content/bh-month-picker-content';\n\n@Component({\n tag: 'bh-picker-menu',\n styleUrl: 'bh-picker-menu.css',\n shadow: true,\n})\nexport class BhPickerMenu {\n /**\n * Minimum year in the picker\n */\n @Prop() minYear: number = 1998;\n\n /**\n * Maximum year in the picker\n */\n @Prop() maxYear: number = 2060;\n\n /**\n * Whether the picker is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Array of disabled months\n */\n @Prop() disabledMonths: DisabledMonth[] = [];\n\n /**\n * Animation class for the menu\n */\n @Prop() animationClass: string = 'animate-dropdown-enter';\n\n /**\n * Whether the menu is visible\n */\n @Prop() visible: boolean = true;\n\n /**\n * Whether to show the footer with action buttons\n */\n @Prop() showFooter: boolean = true;\n\n /**\n * Whether to show the today button\n */\n @Prop() showTodayButton: boolean = false;\n\n /**\n * Whether the apply button is disabled\n */\n @Prop() disableApply: boolean = false;\n\n /**\n * Current value\n */\n @Prop() value?: MonthYear;\n\n @State() isClosing: boolean = false;\n @State() shouldRender: boolean = true;\n @State() selectedMonth: number | null = null;\n @State() selectedYear: number | null = null;\n\n /**\n * Event emitted when value changes\n */\n @Event() bhChange!: EventEmitter<MonthYear | null>;\n\n /**\n * Event emitted when a month/year is selected\n */\n @Event() bhMonthYearSelect!: EventEmitter<MonthYear>;\n\n /**\n * Event emitted when cancel is clicked\n */\n @Event() bhCancel!: EventEmitter<void>;\n\n /**\n * Event emitted when apply is clicked\n */\n @Event() bhApply!: EventEmitter<void>;\n\n /**\n * Event emitted when today button is clicked\n */\n @Event() bhToday!: EventEmitter<void>;\n\n @Watch('visible')\n handleVisibleChange(newValue: boolean) {\n if (newValue) {\n this.shouldRender = true;\n this.isClosing = false;\n } else {\n this.isClosing = true;\n setTimeout(() => {\n this.shouldRender = false;\n this.isClosing = false;\n }, 150);\n }\n }\n\n @Watch('value')\n handleValueChange(newValue: MonthYear | undefined) {\n if (newValue) {\n this.selectedMonth = newValue.month;\n this.selectedYear = newValue.year;\n }\n }\n\n componentWillLoad() {\n this.shouldRender = this.visible;\n\n if (this.value) {\n this.selectedMonth = this.value.month;\n this.selectedYear = this.value.year;\n } else {\n // Initialize with current date\n const now = new Date();\n const currentMonth = now.getMonth();\n const currentYear = now.getFullYear();\n\n if (currentYear >= this.minYear && currentYear <= this.maxYear) {\n this.selectedMonth = currentMonth;\n this.selectedYear = currentYear;\n } else if (currentYear < this.minYear) {\n this.selectedYear = this.minYear;\n this.selectedMonth = currentMonth;\n } else {\n this.selectedYear = this.maxYear;\n this.selectedMonth = currentMonth;\n }\n }\n }\n\n private handleMonthYearSelect = (event: CustomEvent<MonthYear>) => {\n const selection = event.detail;\n this.selectedMonth = selection.month;\n this.selectedYear = selection.year;\n this.bhChange.emit(selection);\n this.bhMonthYearSelect.emit(selection);\n };\n\n private handleCancel = () => {\n this.bhCancel.emit();\n };\n\n private handleApply = () => {\n this.bhApply.emit();\n };\n\n private handleToday = () => {\n this.bhToday.emit();\n };\n\n render() {\n if (!this.shouldRender) {\n return null;\n }\n\n const menuClasses = {\n 'picker-menu': true,\n 'animate-dropdown-exit': this.isClosing,\n [this.animationClass]: !this.isClosing,\n 'no-footer': !this.showFooter,\n };\n\n return (\n <Host>\n <div class={menuClasses}>\n {/* Main Content Area - render slot if provided, otherwise MonthPickerContent */}\n <slot>\n <bh-month-picker-content\n minYear={this.minYear}\n maxYear={this.maxYear}\n disabled={this.disabled}\n disabledMonths={this.disabledMonths}\n scrollable={true}\n selectedMonth={this.selectedMonth ?? undefined}\n selectedYear={this.selectedYear ?? undefined}\n onBhChange={this.handleMonthYearSelect}\n ></bh-month-picker-content>\n </slot>\n\n {/* Footer Actions - conditionally rendered */}\n {this.showFooter && (\n <div class=\"picker-menu-footer\">\n <div class={`picker-menu-actions ${this.showTodayButton ? 'has-today-button' : ''}`}>\n {/* Today button on the left */}\n {this.showTodayButton && (\n <bh-button\n hierarchy=\"secondary\"\n size=\"sm\"\n icon=\"only\"\n iconName=\"today\"\n onBhClick={this.handleToday}\n ></bh-button>\n )}\n\n {/* Cancel and Apply buttons always on the right */}\n <div class=\"picker-menu-main-actions\">\n <bh-button\n hierarchy=\"secondary\"\n size=\"sm\"\n label=\"Cancel\"\n onBhClick={this.handleCancel}\n ></bh-button>\n <bh-button\n hierarchy=\"primary\"\n size=\"sm\"\n label=\"Apply\"\n disabled={this.disableApply}\n onBhClick={this.handleApply}\n ></bh-button>\n </div>\n </div>\n </div>\n )}\n </div>\n </Host>\n );\n }\n\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bh-date-picker.bh-empty-state.entry.esm.js","sources":["src/components/bh-date-picker/bh-date-picker.css?tag=bh-date-picker&encapsulation=shadow","src/components/bh-date-picker/bh-date-picker.tsx","src/components/bh-empty-state/bh-empty-state.css?tag=bh-empty-state&encapsulation=shadow","src/components/bh-empty-state/bh-empty-state.tsx"],"sourcesContent":["@import '../../global/global.css';\n\n:host {\n display: inline-block;\n position: relative;\n}\n\n.date-picker-container {\n position: relative;\n display: inline-block;\n}\n\n.date-picker-trigger {\n cursor: pointer;\n}\n\n.date-picker-trigger.input-field-container {\n position: relative;\n}\n\n.calendar-icon-overlay {\n position: absolute;\n top: 0;\n right: 0;\n width: 40px;\n height: 100%;\n cursor: pointer;\n z-index: 1;\n}\n\n.date-picker-menu-container {\n position: absolute;\n top: 100%;\n left: 0;\n z-index: 1000;\n margin-top: var(--spacing-xs);\n}\n\n.date-picker-backdrop {\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n z-index: 999;\n background: transparent;\n}\n","import { Component, Prop, State, Event, EventEmitter, Watch, h, Host } from '@stencil/core';\nimport { SelectedDate, DisabledDate } from '../bh-date-picker-content/bh-date-picker-content';\n\nexport type DatePickerVariant = 'dropdown-outlined' | 'dropdown-ghost' | 'input';\n\n@Component({\n tag: 'bh-date-picker',\n styleUrl: 'bh-date-picker.css',\n shadow: true,\n})\nexport class BhDatePicker {\n /**\n * Variant of the date picker trigger\n */\n @Prop() variant: DatePickerVariant = 'input';\n\n /**\n * Minimum year in the picker\n */\n @Prop() minYear: number = 1998;\n\n /**\n * Maximum year in the picker\n */\n @Prop() maxYear: number = 2060;\n\n /**\n * Whether the picker is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Array of disabled dates\n */\n @Prop() disabledDates: DisabledDate[] = [];\n\n /**\n * Label for input variant\n */\n @Prop() label: string = 'Select Date';\n\n /**\n * Placeholder text\n */\n @Prop() placeholder: string = 'Choose date';\n\n /**\n * Width for input variant\n */\n @Prop() inputWidth: string = '200px';\n\n /**\n * Whether to show the label\n */\n @Prop() showLabel: boolean = true;\n\n /**\n * Whether to show the footer\n */\n @Prop() showFooter: boolean = false;\n\n /**\n * Whether to show days from other months\n */\n @Prop() showOtherMonthDays: boolean = true;\n\n /**\n * Currently selected value\n */\n @Prop() value?: SelectedDate;\n\n @State() selectedValue: SelectedDate | null = null;\n @State() tempSelection: SelectedDate | null = null;\n @State() isMenuOpen: boolean = false;\n @State() isMenuClosing: boolean = false;\n\n /**\n * Event emitted when value changes\n */\n @Event() bhChange!: EventEmitter<SelectedDate | null>;\n\n /**\n * Event emitted when a date is selected\n */\n @Event() bhDateSelect!: EventEmitter<SelectedDate | null>;\n\n @Watch('value')\n handleValueChange(newValue: SelectedDate | undefined) {\n if (newValue !== undefined) {\n this.selectedValue = newValue;\n }\n }\n\n componentWillLoad() {\n if (this.value) {\n this.selectedValue = this.value;\n }\n }\n\n private getDisplayValue(): string {\n if (!this.selectedValue) return '';\n const month = (this.selectedValue.month + 1).toString().padStart(2, '0');\n const day = this.selectedValue.day.toString().padStart(2, '0');\n return `${month}/${day}/${this.selectedValue.year}`;\n }\n\n private getButtonLabel(): string {\n return this.getDisplayValue() || this.placeholder;\n }\n\n private handleTriggerClick = () => {\n if (this.disabled) return;\n if (!this.isMenuOpen && this.showFooter) {\n this.tempSelection = this.selectedValue;\n }\n this.isMenuOpen = !this.isMenuOpen;\n };\n\n private handleInputFocus = () => {\n if (this.disabled) return;\n if (!this.isMenuOpen && this.showFooter) {\n this.tempSelection = this.selectedValue;\n }\n this.isMenuOpen = true;\n };\n\n private handleDateSelect = (event: CustomEvent<SelectedDate | null>) => {\n const date = event.detail;\n if (this.showFooter && date) {\n this.tempSelection = date;\n } else {\n this.selectedValue = date;\n this.bhChange.emit(date);\n this.bhDateSelect.emit(date);\n if (!this.showFooter) {\n this.closeMenu();\n }\n }\n };\n\n private handleMenuCancel = () => {\n this.tempSelection = null;\n this.closeMenu();\n };\n\n private handleMenuApply = () => {\n if (this.tempSelection) {\n this.selectedValue = this.tempSelection;\n this.tempSelection = null;\n this.bhChange.emit(this.selectedValue);\n this.bhDateSelect.emit(this.selectedValue);\n }\n this.closeMenu();\n };\n\n private handleToday = () => {\n const today = new Date();\n const todayDate: SelectedDate = {\n year: today.getFullYear(),\n month: today.getMonth(),\n day: today.getDate(),\n };\n\n if (this.showFooter) {\n this.tempSelection = todayDate;\n } else {\n this.selectedValue = todayDate;\n this.bhChange.emit(todayDate);\n this.bhDateSelect.emit(todayDate);\n this.closeMenu();\n }\n };\n\n private closeMenu() {\n this.isMenuClosing = true;\n setTimeout(() => {\n this.isMenuOpen = false;\n this.isMenuClosing = false;\n }, 150);\n }\n\n private handleBackdropClick = () => {\n this.handleMenuCancel();\n };\n\n render() {\n return (\n <Host>\n <div class=\"date-picker-container\">\n {/* Dropdown Outlined Variant */}\n {this.variant === 'dropdown-outlined' && (\n <div class=\"date-picker-trigger\" onClick={this.handleTriggerClick}>\n <bh-button\n hierarchy=\"secondary\"\n \n size=\"sm\"\n icon=\"trailing\"\n label={this.getButtonLabel()}\n iconName=\"expand_more\"\n disabled={this.disabled}\n ></bh-button>\n </div>\n )}\n\n {/* Dropdown Ghost Variant */}\n {this.variant === 'dropdown-ghost' && (\n <div class=\"date-picker-trigger\" onClick={this.handleTriggerClick}>\n <bh-button\n hierarchy=\"tertiary\"\n \n size=\"sm\"\n icon=\"trailing\"\n label={this.getButtonLabel()}\n iconName=\"expand_more\"\n disabled={this.disabled}\n ></bh-button>\n </div>\n )}\n\n {/* Input Variant */}\n {this.variant === 'input' && (\n <div class=\"date-picker-trigger input-field-container\">\n <bh-input-text\n label={this.label}\n placeholder={this.placeholder}\n value={this.getDisplayValue()}\n disabled={this.disabled}\n showTrailingIcon={true}\n trailingIcon=\"calendar_today\"\n showHelpIcon={false}\n showHintText={false}\n showLabel={this.showLabel}\n width={this.inputWidth}\n onBhFocus={this.handleInputFocus}\n ></bh-input-text>\n <div class=\"calendar-icon-overlay\" onClick={this.handleTriggerClick}></div>\n </div>\n )}\n\n {/* Date Picker Menu */}\n <div class=\"date-picker-menu-container\">\n <bh-picker-menu\n visible={this.isMenuOpen}\n showFooter={this.showFooter}\n showTodayButton={this.showFooter}\n disableApply={this.showFooter && this.tempSelection === null}\n onBhCancel={this.handleMenuCancel}\n onBhApply={this.handleMenuApply}\n onBhToday={this.handleToday}\n >\n <bh-date-picker-content\n minYear={this.minYear}\n maxYear={this.maxYear}\n disabled={this.disabled}\n disabledDates={this.disabledDates}\n showOtherMonthDays={this.showOtherMonthDays}\n value={this.tempSelection ?? this.selectedValue ?? undefined}\n onBhDateSelect={this.handleDateSelect}\n ></bh-date-picker-content>\n </bh-picker-menu>\n </div>\n </div>\n\n {/* Backdrop */}\n {(this.isMenuOpen || this.isMenuClosing) && (\n <div class=\"date-picker-backdrop\" onClick={this.handleBackdropClick}></div>\n )}\n </Host>\n );\n }\n}\n",":host {\n display: block;\n font-family: var(\n --font-inter,\n 'Inter',\n -apple-system,\n BlinkMacSystemFont,\n sans-serif\n );\n}\n\n/* Container */\n.empty-state {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 32px;\n padding: 48px 24px;\n text-align: center;\n}\n\n/* Content */\n.empty-state-content {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 24px;\n}\n\n/* Illustration */\n.empty-state-illustration {\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n.empty-state-illustration img {\n object-fit: contain;\n}\n\n/* Text */\n.empty-state-text {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 8px;\n}\n\n.empty-state-title {\n font-size: var(--text-lg-size, 18px);\n font-weight: 600;\n color: var(--color-neutral-900, #101828);\n margin: 0;\n line-height: 1.33;\n}\n\n.empty-state-description {\n font-size: var(--text-sm-size, 14px);\n font-weight: 400;\n color: var(--color-neutral-600, #475467);\n margin: 0;\n line-height: 1.43;\n max-width: 400px;\n}\n\n/* Actions */\n.empty-state-actions {\n display: flex;\n gap: 12px;\n flex-wrap: wrap;\n justify-content: center;\n}\n\n/* Material Symbols */\n.material-symbols-outlined {\n font-family: 'Material Symbols Outlined';\n font-weight: normal;\n font-style: normal;\n line-height: 1;\n letter-spacing: normal;\n text-transform: none;\n display: inline-block;\n white-space: nowrap;\n word-wrap: normal;\n direction: ltr;\n font-feature-settings: 'liga';\n -webkit-font-smoothing: antialiased;\n font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;\n}\n","import { Component, Prop, Event, EventEmitter, h } from '@stencil/core';\n\nexport type EmptyStateIllustrationSize = 'sm' | 'md' | 'lg';\n\n@Component({\n tag: 'bh-empty-state',\n styleUrl: 'bh-empty-state.css',\n shadow: true,\n})\nexport class BhEmptyState {\n /**\n * Title text\n */\n @Prop() emptyTitle: string = 'No items found';\n\n /**\n * Description text\n */\n @Prop() description: string = 'There are no items to display at the moment.';\n\n /**\n * Size of the illustration\n */\n @Prop() illustrationSize: EmptyStateIllustrationSize = 'md';\n\n /**\n * Path to the illustration SVG\n */\n @Prop() illustrationPath: string = '';\n\n /**\n * Primary action button text\n */\n @Prop() primaryActionText: string = '';\n\n /**\n * Primary action icon name\n */\n @Prop() primaryActionIcon: string = '';\n\n /**\n * Secondary action button text\n */\n @Prop() secondaryActionText: string = '';\n\n /**\n * Secondary action icon name\n */\n @Prop() secondaryActionIcon: string = '';\n\n /**\n * Max width of the component\n */\n @Prop() maxWidth: string = '512px';\n\n /**\n * Emitted when primary action is clicked\n */\n @Event() bhPrimaryAction!: EventEmitter<void>;\n\n /**\n * Emitted when secondary action is clicked\n */\n @Event() bhSecondaryAction!: EventEmitter<void>;\n\n private handlePrimaryAction = (): void => {\n this.bhPrimaryAction.emit();\n };\n\n private handleSecondaryAction = (): void => {\n this.bhSecondaryAction.emit();\n };\n\n private getIllustrationDimensions(): { width: string; height: string } {\n switch (this.illustrationSize) {\n case 'sm':\n return { width: '120px', height: '120px' };\n case 'md':\n return { width: '200px', height: '200px' };\n case 'lg':\n return { width: '280px', height: '280px' };\n default:\n return { width: '200px', height: '200px' };\n }\n }\n\n render() {\n const dimensions = this.getIllustrationDimensions();\n const hasActions = this.primaryActionText || this.secondaryActionText;\n\n return (\n <div\n class=\"empty-state\"\n style={{ maxWidth: this.maxWidth }}\n part=\"container\"\n >\n <div class=\"empty-state-content\">\n {/* Illustration */}\n {this.illustrationPath && (\n <div class=\"empty-state-illustration\">\n <img\n src={this.illustrationPath}\n alt=\"Empty state illustration\"\n style={{ width: dimensions.width, height: dimensions.height }}\n />\n </div>\n )}\n\n {/* Text Content */}\n <div class=\"empty-state-text\">\n <h3 class=\"empty-state-title\">{this.emptyTitle}</h3>\n <p class=\"empty-state-description\">{this.description}</p>\n </div>\n </div>\n\n {/* Actions */}\n {hasActions && (\n <div class=\"empty-state-actions\">\n {this.secondaryActionText && (\n <bh-button\n hierarchy=\"secondary\"\n size=\"md\"\n label={this.secondaryActionText}\n icon={this.secondaryActionIcon ? 'leading' : 'none'}\n iconName={this.secondaryActionIcon}\n onBhClick={this.handleSecondaryAction}\n />\n )}\n {this.primaryActionText && (\n <bh-button\n hierarchy=\"primary\"\n size=\"md\"\n label={this.primaryActionText}\n icon={this.primaryActionIcon ? 'leading' : 'none'}\n iconName={this.primaryActionIcon}\n onBhClick={this.handlePrimaryAction}\n />\n )}\n </div>\n )}\n </div>\n );\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bh-dropdown.bh-logo-box.bh-nav-item.entry.esm.js","sources":["src/components/bh-dropdown/bh-dropdown.css?tag=bh-dropdown&encapsulation=shadow","src/components/bh-dropdown/bh-dropdown.tsx","src/components/bh-logo-box/bh-logo-box.css?tag=bh-logo-box&encapsulation=shadow","src/components/bh-logo-box/bh-logo-box.tsx","src/components/bh-sidebar/bh-nav-item.css?tag=bh-nav-item&encapsulation=shadow","src/components/bh-sidebar/bh-nav-item.tsx"],"sourcesContent":["/* ==========================================================================\n BH-DROPDOWN COMPONENT STYLES\n ========================================================================== */\n\n:host {\n display: inline-block;\n position: relative;\n}\n\n.dropdown-container {\n position: relative;\n display: inline-block;\n}\n\n/* Position the dropdown menu */\n.dropdown-container bh-dropdown-menu {\n position: absolute;\n z-index: 1000;\n}\n\n/* Default positioning for button variants (below trigger) */\n.dropdown-container:not(.dropdown-avatar-variant) bh-dropdown-menu {\n top: 100%;\n right: 0;\n margin-top: var(--spacing-sm);\n}\n\n/* Avatar variant positioning (to the left of avatar for sidebars) */\n.dropdown-avatar-variant bh-dropdown-menu {\n bottom: 0;\n left: calc(100% + var(--spacing-sm));\n}\n\n/* Avatar trigger styles */\n.dropdown-avatar {\n cursor: pointer;\n border-radius: 50%;\n transition: box-shadow 0.2s ease;\n outline: none;\n display: inline-block;\n user-select: none;\n}\n\n.dropdown-avatar:hover:not(.dropdown-avatar-disabled) {\n box-shadow: 0 0 0 2px var(--color-neutral-200);\n}\n\n.dropdown-avatar:focus:not(.dropdown-avatar-disabled) {\n box-shadow: 0 0 0 2px var(--color-brand-500);\n}\n\n.dropdown-avatar-focus {\n box-shadow: 0 0 0 2px var(--color-brand-500);\n}\n\n.dropdown-avatar-disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n\n/* Button state when dropdown is open */\n.dropdown-open bh-button {\n --button-focus-ring: 0 0 0 2px var(--color-brand-100);\n}\n","import {\n Component,\n Prop,\n State,\n Event,\n EventEmitter,\n Element,\n h,\n Listen,\n} from '@stencil/core';\nimport type {\n DropdownMenuItem,\n DropdownMenuHeader,\n} from '../bh-dropdown-menu/bh-dropdown-menu';\n\nexport type DropdownSize = 'sm' | 'md';\nexport type DropdownState = 'default' | 'focus' | 'disabled';\nexport type DropdownVariant =\n | 'outlined'\n | 'ghost'\n | 'icon-only-outlined'\n | 'icon-only-ghost'\n | 'avatar';\n\n@Component({\n tag: 'bh-dropdown',\n styleUrl: 'bh-dropdown.css',\n shadow: true,\n})\nexport class BhDropdown {\n @Element() el!: HTMLElement;\n\n /**\n * Size of the dropdown trigger\n */\n @Prop() size: DropdownSize = 'md';\n\n /**\n * State of the dropdown\n */\n @Prop() state: DropdownState = 'default';\n\n /**\n * Visual variant of the dropdown trigger\n */\n @Prop() variant: DropdownVariant = 'outlined';\n\n /**\n * Label for the dropdown button\n */\n @Prop() label: string = 'Options';\n\n /**\n * Icon name for icon-only variants\n */\n @Prop() iconName: string = 'more_vert';\n\n /**\n * Whether the dropdown is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Menu items (JSON string or array)\n */\n @Prop() menuItems: DropdownMenuItem[] | string = [];\n\n /**\n * Header configuration (JSON string or object)\n */\n @Prop() header?: DropdownMenuHeader | string;\n\n /**\n * Avatar image source for avatar variant\n */\n @Prop() avatarSrc: string = '';\n\n /**\n * Avatar alt text\n */\n @Prop() avatarAlt: string = 'Avatar';\n\n /**\n * Avatar size for avatar variant\n */\n @Prop() avatarSize: 'sm' | 'md' | 'lg' = 'md';\n\n /**\n * Avatar name for header\n */\n @Prop() avatarName?: string;\n\n /**\n * Avatar email for header\n */\n @Prop() avatarEmail?: string;\n\n /**\n * Whether to show icons in menu items\n */\n @Prop() showIcons: boolean = true;\n\n @State() isOpen: boolean = false;\n\n /**\n * Event emitted when a menu item is clicked\n */\n @Event() bhItemClick!: EventEmitter<DropdownMenuItem>;\n\n @Listen('click', { target: 'document' })\n handleClickOutside(event: MouseEvent) {\n if (this.isOpen && !this.el.contains(event.target as Node)) {\n this.isOpen = false;\n }\n }\n\n private get parsedMenuItems(): DropdownMenuItem[] {\n if (typeof this.menuItems === 'string') {\n try {\n return JSON.parse(this.menuItems);\n } catch {\n return [];\n }\n }\n return this.menuItems || [];\n }\n\n private get parsedHeader(): DropdownMenuHeader | undefined {\n if (this.variant === 'avatar') {\n return {\n avatarGroup: true,\n avatarSrc: this.avatarSrc,\n name: this.avatarName,\n email: this.avatarEmail,\n };\n }\n if (!this.header) return undefined;\n if (typeof this.header === 'string') {\n try {\n return JSON.parse(this.header);\n } catch {\n return undefined;\n }\n }\n return this.header;\n }\n\n private toggleDropdown = () => {\n if (this.disabled) return;\n this.isOpen = !this.isOpen;\n };\n\n private handleMenuItemClick = (event: CustomEvent<DropdownMenuItem>) => {\n const item = event.detail;\n if (!item.disabled) {\n this.bhItemClick.emit(item);\n this.isOpen = false;\n }\n };\n\n private get isIconOnly(): boolean {\n return (\n this.variant === 'icon-only-outlined' ||\n this.variant === 'icon-only-ghost'\n );\n }\n\n private get showAvatar(): boolean {\n return this.variant === 'avatar';\n }\n\n private get buttonHierarchy(): 'secondary' | 'tertiary' {\n return this.variant === 'ghost' || this.variant === 'icon-only-ghost'\n ? 'tertiary'\n : 'secondary';\n }\n\n render() {\n const containerClasses = {\n 'dropdown-container': true,\n 'dropdown-open': this.isOpen,\n 'dropdown-avatar-variant': this.variant === 'avatar',\n };\n\n const avatarClasses = {\n 'dropdown-avatar': true,\n 'dropdown-avatar-focus': this.isOpen,\n 'dropdown-avatar-disabled': this.disabled,\n };\n\n return (\n <div class={containerClasses}>\n {/* Button variants */}\n {!this.showAvatar && (\n <bh-button\n hierarchy={this.buttonHierarchy}\n icon={this.isIconOnly ? 'only' : 'trailing'}\n size={this.size}\n label={this.isIconOnly ? '' : this.label}\n iconName={this.isIconOnly ? this.iconName : 'expand_more'}\n disabled={this.disabled}\n onClick={this.toggleDropdown}\n />\n )}\n\n {/* Avatar variant */}\n {this.showAvatar && (\n <div\n class={avatarClasses}\n onClick={(e) => {\n if (!this.disabled) {\n e.stopPropagation();\n this.toggleDropdown();\n }\n }}\n role=\"button\"\n tabindex={this.disabled ? -1 : 0}\n onKeyDown={(e: KeyboardEvent) => {\n if (!this.disabled && (e.key === 'Enter' || e.key === ' ')) {\n e.preventDefault();\n this.toggleDropdown();\n }\n }}\n >\n <bh-avatar\n type=\"image\"\n size={this.avatarSize}\n imageSrc={this.avatarSrc}\n alt={this.avatarAlt}\n />\n </div>\n )}\n\n {/* Menu */}\n <bh-dropdown-menu\n visible={this.isOpen}\n showIcons={this.showIcons}\n menuItems={JSON.stringify(this.parsedMenuItems)}\n header={\n this.parsedHeader ? JSON.stringify(this.parsedHeader) : undefined\n }\n onBhItemClick={this.handleMenuItemClick}\n />\n </div>\n );\n }\n}\n",".logo-box {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: flex-start;\n position: relative;\n width: 40px;\n flex-shrink: 0;\n isolation: isolate;\n}\n\n.logo-active {\n background-color: var(--color-brand-600);\n box-sizing: border-box;\n display: flex;\n gap: var(--spacing-lg);\n align-items: center;\n justify-content: center;\n padding: var(--spacing-sm);\n position: relative;\n border-radius: var(--radius-md);\n flex-shrink: 0;\n width: 40px;\n height: 40px;\n z-index: 2;\n transition: background-color 0.3s ease;\n cursor: pointer;\n}\n\n/* Hover effect for logo-active */\n.logo-box:hover .logo-active,\n.logo-box.dropdown-open .logo-active {\n background-color: var(--color-brand-700);\n}\n\n.logo {\n overflow: hidden;\n position: relative;\n flex-shrink: 0;\n width: 32px;\n height: 32px;\n background-size: contain;\n background-repeat: no-repeat;\n background-position: center;\n transition: background-image 0.4s cubic-bezier(0.08, 0.52, 0.52, 1);\n}\n\n/* Logo variations - Background images must be configured by the consuming application */\n.logo-actabl {\n /* background-image should be set by consuming application */\n}\n\n.logo-al {\n /* background-image should be set by consuming application */\n}\n\n.logo-he {\n /* background-image should be set by consuming application */\n}\n\n.logo-ps {\n /* background-image should be set by consuming application */\n}\n\n.logo-tr {\n /* background-image should be set by consuming application */\n}\n\n.logo-more-products {\n position: absolute;\n background-color: var(--color-brand-200);\n right: 2px;\n bottom: -4px;\n border-radius: 5px;\n width: 36px;\n height: 35px;\n z-index: 1;\n transition: transform 0.3s ease;\n}\n\n/* Slide-up animation for logo-more-products */\n.logo-box:hover .logo-more-products,\n.logo-box.dropdown-open .logo-more-products {\n transform: translateY(-4px);\n}\n","import { Component, Prop, Event, EventEmitter, State, h, Host } from '@stencil/core';\nimport { BhProduct } from '../bh-product-switcher/bh-product-switcher';\n\nexport type LogoType = 'actabl' | 'al' | 'he' | 'ps' | 'tr';\n\n@Component({\n tag: 'bh-logo-box',\n styleUrl: 'bh-logo-box.css',\n shadow: true,\n})\nexport class BhLogoBox {\n /**\n * Type of logo to display\n */\n @Prop() logoType: LogoType = 'actabl';\n\n /**\n * Array of products to display in the switcher\n */\n @Prop() products: BhProduct[] = [\n {\n id: 'alice',\n name: 'Alice',\n description: 'Housekeeping & Guest Services',\n logo: './assets/logos/AL.svg',\n },\n {\n id: 'hotel-effectiveness',\n name: 'Hotel Effectiveness',\n description: 'Labor planning',\n logo: './assets/logos/HE.svg',\n },\n {\n id: 'profit-sword',\n name: 'ProfitSword',\n description: 'B.I and Finance',\n logo: './assets/logos/PS.svg',\n },\n {\n id: 'transcendent',\n name: 'Transcendent',\n description: 'Asset Management & CapEx',\n logo: './assets/logos/TR.svg',\n },\n ];\n\n /**\n * Event emitted when a product is selected\n */\n @Event() bhProductSelect!: EventEmitter<BhProduct>;\n\n @State() isOpen: boolean = false;\n @State() anchorPosition = { top: 0, left: 0 };\n\n private logoActiveRef?: HTMLDivElement;\n\n private handleLogoClick = () => {\n if (this.logoActiveRef) {\n const rect = this.logoActiveRef.getBoundingClientRect();\n this.anchorPosition = {\n top: rect.bottom + 8,\n left: rect.left,\n };\n this.isOpen = !this.isOpen;\n }\n };\n\n private handleClose = () => {\n this.isOpen = false;\n };\n\n private handleProductSelect = (event: CustomEvent<BhProduct>) => {\n this.bhProductSelect.emit(event.detail);\n this.isOpen = false;\n };\n\n private getLogoSrc = () => {\n switch (this.logoType) {\n case 'actabl':\n return './assets/logos/actabl.svg';\n case 'al':\n return './assets/logos/AL.svg';\n case 'he':\n return './assets/logos/HE.svg';\n case 'ps':\n return './assets/logos/PS.svg';\n case 'tr':\n return './assets/logos/TR.svg';\n default:\n return './assets/logos/actabl.svg';\n }\n };\n\n render() {\n const logoBoxClasses = {\n 'logo-box': true,\n 'dropdown-open': this.isOpen,\n };\n\n const logoClasses = {\n 'logo': true,\n [`logo-${this.logoType}`]: true,\n };\n\n return (\n <Host>\n <div class={logoBoxClasses}>\n <div\n ref={(el) => (this.logoActiveRef = el)}\n class=\"logo-active\"\n onClick={this.handleLogoClick}\n >\n <img\n src={this.getLogoSrc()}\n alt={`${this.logoType} logo`}\n class={logoClasses}\n />\n </div>\n <div class=\"logo-more-products\"></div>\n </div>\n\n <bh-product-switcher\n isOpen={this.isOpen}\n anchorPosition={this.anchorPosition}\n products={this.products}\n onBhClose={this.handleClose}\n onBhProductSelect={this.handleProductSelect}\n ></bh-product-switcher>\n </Host>\n );\n }\n}\n","/* ==========================================================================\n BH-NAV-ITEM COMPONENT STYLES\n Navigation item for sidebar navigation\n ========================================================================== */\n\n:host {\n display: inline-block;\n}\n\n.nav-item {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: flex-start;\n position: relative;\n flex-shrink: 0;\n width: 100%;\n max-width: 52px;\n height: fit-content;\n}\n\n.nav-item-button {\n background-color: var(--color-white);\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n overflow: hidden;\n padding: var(--spacing-md);\n position: relative;\n border-radius: var(--radius-sm);\n flex-shrink: 0;\n transition: background-color 0.2s ease;\n cursor: pointer;\n border: none;\n outline: none;\n}\n\n.nav-item-button:hover {\n background-color: var(--color-neutral-50);\n}\n\n.nav-item-button:focus-visible {\n box-shadow: 0 0 0 2px var(--color-brand-100);\n}\n\n.nav-item.active .nav-item-button {\n background-color: var(--color-brand-50);\n}\n\n.nav-item-button .icon {\n width: 20px;\n height: 20px;\n display: block;\n flex-shrink: 0;\n color: var(--color-neutral-500);\n transition: color 0.2s ease;\n font-size: 20px;\n font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 20;\n}\n\n.nav-item-button:hover .icon {\n color: var(--color-neutral-700);\n}\n\n.nav-item.active .nav-item-button .icon {\n color: var(--color-brand-600);\n font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 20;\n}\n\n.nav-item-label {\n font-family: var(--font-inter);\n font-weight: var(--weight-medium);\n height: 18px;\n line-height: 18px;\n font-style: normal;\n overflow: hidden;\n text-overflow: ellipsis;\n position: relative;\n flex-shrink: 0;\n color: var(--color-neutral-700);\n font-size: 10px;\n text-align: center;\n white-space: nowrap;\n width: 100%;\n max-width: 100%;\n margin: var(--spacing-none);\n margin-top: var(--spacing-xxs);\n box-sizing: border-box;\n direction: ltr;\n}\n\n.nav-item.active .nav-item-label {\n color: var(--color-neutral-700);\n font-weight: var(--weight-semibold);\n}\n\n/* Disabled state */\n.nav-item.disabled .nav-item-button {\n cursor: not-allowed;\n opacity: 0.5;\n}\n\n.nav-item.disabled .nav-item-button:hover {\n background-color: var(--color-white);\n}\n\n.nav-item.disabled .nav-item-button .icon {\n color: var(--color-neutral-400);\n}\n\n.nav-item.disabled .nav-item-label {\n color: var(--color-neutral-400);\n}\n","import { Component, Prop, Event, EventEmitter, h } from '@stencil/core';\n\n@Component({\n tag: 'bh-nav-item',\n styleUrl: 'bh-nav-item.css',\n shadow: true,\n})\nexport class BhNavItem {\n /**\n * Material Symbols icon name\n */\n @Prop() icon: string = 'home';\n\n /**\n * Label text displayed below the icon\n */\n @Prop() label: string = 'Home';\n\n /**\n * Whether the nav item is active/selected\n */\n @Prop() isActive: boolean = false;\n\n /**\n * Whether the nav item is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Event emitted when the nav item is clicked\n */\n @Event() bhClick!: EventEmitter<void>;\n\n private handleClick = () => {\n if (!this.disabled) {\n this.bhClick.emit();\n }\n };\n\n private handleKeyDown = (event: KeyboardEvent) => {\n if ((event.key === 'Enter' || event.key === ' ') && !this.disabled) {\n event.preventDefault();\n this.bhClick.emit();\n }\n };\n\n render() {\n const navItemClasses = {\n 'nav-item': true,\n 'active': this.isActive,\n 'disabled': this.disabled,\n };\n\n return (\n <div class={navItemClasses}>\n <button\n class=\"nav-item-button\"\n aria-label={this.label}\n type=\"button\"\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n disabled={this.disabled}\n tabIndex={this.disabled ? -1 : 0}\n >\n <span class=\"material-symbols-outlined icon\">{this.icon}</span>\n </button>\n <p class=\"nav-item-label\">{this.label}</p>\n </div>\n );\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bh-input-text.entry.esm.js","sources":["src/components/bh-input-text/bh-input-text.css?tag=bh-input-text&encapsulation=shadow","src/components/bh-input-text/bh-input-text.tsx"],"sourcesContent":[":host {\n display: block;\n font-family: var(\n --font-inter,\n 'Inter',\n -apple-system,\n BlinkMacSystemFont,\n sans-serif\n );\n}\n\n/* Input Wrapper */\n.input-wrapper {\n display: flex;\n flex-direction: column;\n gap: var(--spacing-sm, 8px);\n width: 100%;\n}\n\n/* Input Container */\n.input-container {\n display: flex;\n align-items: center;\n gap: var(--spacing-md, 12px);\n padding: var(--spacing-md, 12px);\n height: 36px;\n width: 100%;\n background: var(--color-white, #ffffff);\n border: 1px solid var(--color-neutral-300, #d0d5dd);\n border-radius: var(--spacing-md, 8px);\n transition: all 0.2s ease-in-out;\n cursor: text;\n box-sizing: border-box;\n}\n\n.input-container.input-container-with-leading {\n padding: var(--spacing-md, 12px) var(--spacing-lg, 16px);\n}\n\n/* Input States */\n.input-container.input-container-hover {\n border-color: var(--color-brand-500, #7f56d9);\n}\n\n.input-container.input-container-focused {\n border-color: var(--color-brand-500, #7f56d9);\n box-shadow: 0 0 0 1px var(--color-brand-500, #7f56d9);\n}\n\n.input-container.input-container-disabled {\n opacity: 0.5;\n cursor: not-allowed;\n background: var(--color-neutral-50, #f9fafb);\n}\n\n.input-container.input-container-error {\n border-color: var(--color-error-300, #fda29b);\n}\n\n.input-container.input-container-error.input-container-hover {\n border-color: var(--color-error-500, #f05250);\n}\n\n.input-container.input-container-error.input-container-focused {\n border-color: var(--color-brand-600, #6941c6);\n}\n\n/* Input Content */\n.input-content {\n display: flex;\n align-items: center;\n gap: var(--spacing-md, 12px);\n flex: 1;\n height: 100%;\n min-width: 0;\n}\n\n/* Input Element */\n.input-element {\n flex: 1;\n height: 100%;\n border: none;\n outline: none;\n background: transparent;\n font-family: inherit;\n font-weight: 400;\n font-size: var(--text-sm-size, 14px);\n line-height: 1.43;\n color: var(--color-neutral-800, #1d2939);\n min-width: 60px;\n padding: 0;\n}\n\n.input-element:focus {\n outline: none;\n border: none;\n box-shadow: none;\n}\n\n.input-element::placeholder {\n color: var(--color-neutral-500, #667085);\n}\n\n.input-element:disabled {\n cursor: not-allowed;\n}\n\n/* Icons */\n.leading-icon,\n.trailing-icon {\n font-size: var(--text-xl-size, 20px);\n color: var(--color-neutral-500, #667085);\n user-select: none;\n flex-shrink: 0;\n cursor: default;\n transition: color 0.2s ease-in-out;\n}\n\n.input-container-focused .leading-icon,\n.input-container-focused .trailing-icon {\n color: var(--color-brand-600, #6941c6);\n}\n\n/* Hint Text */\n.hint-text {\n font-family: inherit;\n font-weight: 400;\n font-size: var(--text-sm-size, 14px);\n line-height: 1.43;\n color: var(--color-neutral-600, #475467);\n}\n\n.hint-text.hint-error {\n color: var(--color-error-600, #dc2626);\n}\n\n/* Material Symbols */\n.material-symbols-outlined {\n font-family: 'Material Symbols Outlined';\n font-weight: normal;\n font-style: normal;\n font-size: 20px;\n line-height: 1;\n letter-spacing: normal;\n text-transform: none;\n display: inline-block;\n white-space: nowrap;\n word-wrap: normal;\n direction: ltr;\n font-feature-settings: 'liga';\n -webkit-font-smoothing: antialiased;\n font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;\n}\n","import { Component, Prop, State, Event, EventEmitter, h, AttachInternals } from '@stencil/core';\nimport { syncFormValue, updateValidity } from '../../utils/form';\n\n@Component({\n tag: 'bh-input-text',\n styleUrl: 'bh-input-text.css',\n shadow: true,\n formAssociated: true,\n})\nexport class BhInputText {\n @AttachInternals() internals!: ElementInternals;\n\n private inputEl?: HTMLInputElement;\n /**\n * The label for the input\n */\n @Prop() label: string = 'Email';\n\n /**\n * Placeholder text\n */\n @Prop() placeholder: string = 'fujiwara@act-hq.com';\n\n /**\n * Hint text shown below the input\n */\n @Prop() hintText: string = '';\n\n /**\n * Whether to show the label\n */\n @Prop() showLabel: boolean = true;\n\n /**\n * Whether to show hint text\n */\n @Prop() showHintText: boolean = true;\n\n /**\n * Whether to show the help icon\n */\n @Prop() showHelpIcon: boolean = false;\n\n /**\n * Whether to show a leading icon\n */\n @Prop() showLeadingIcon: boolean = false;\n\n /**\n * Whether to show a trailing icon\n */\n @Prop() showTrailingIcon: boolean = false;\n\n /**\n * Whether the field has an error\n */\n @Prop() error: boolean = false;\n\n /**\n * Whether the input is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Whether the field is required\n */\n @Prop() required: boolean = false;\n\n /**\n * Tooltip text for the help icon\n */\n @Prop() helpIconTooltip: string = 'Help';\n\n /**\n * Leading icon name (Material Symbols)\n */\n @Prop() leadingIcon: string = 'mail';\n\n /**\n * Trailing icon name (Material Symbols)\n */\n @Prop() trailingIcon: string = 'search';\n\n /**\n * The input value\n */\n @Prop({ mutable: true }) value: string = '';\n\n /**\n * Name attribute for form submission\n */\n @Prop() name: string = '';\n\n /**\n * Default value for form reset\n */\n @Prop() defaultValue: string = '';\n\n /**\n * Custom validation message\n */\n @Prop() validationMessage: string = '';\n\n /**\n * Input type (text, email, tel, url, etc.)\n */\n @Prop() type: string = 'text';\n\n /**\n * Width of the input (e.g., '100%', '200px')\n */\n @Prop() width: string = '';\n\n /**\n * Whether the input is read-only\n */\n @Prop() readOnly: boolean = false;\n\n /**\n * Visual state of the input (for programmatic control)\n */\n @Prop() state: 'default' | 'error' | 'disabled' | 'focus' | 'filled' | 'hover' = 'default';\n\n /**\n * Track focus state\n */\n @State() isFocused: boolean = false;\n\n /**\n * Track hover state\n */\n @State() isHovered: boolean = false;\n\n /**\n * Emitted when the value changes\n */\n @Event() bhInput!: EventEmitter<string>;\n\n /**\n * Emitted when the input gains focus\n */\n @Event() bhFocus!: EventEmitter<void>;\n\n /**\n * Emitted when the input loses focus\n */\n @Event() bhBlur!: EventEmitter<void>;\n\n /**\n * Emitted when the help icon is clicked\n */\n @Event() bhHelpClick!: EventEmitter<void>;\n\n private handleInput = (event: Event): void => {\n const target = event.target as HTMLInputElement;\n this.value = target.value;\n this.bhInput.emit(this.value);\n syncFormValue(this);\n updateValidity(this.internals, this.inputEl, this.validationMessage);\n };\n\n componentDidLoad() {\n syncFormValue(this);\n updateValidity(this.internals, this.inputEl, this.validationMessage);\n }\n\n formResetCallback() {\n this.value = this.defaultValue;\n if (this.inputEl) {\n this.inputEl.value = this.defaultValue;\n }\n syncFormValue(this);\n updateValidity(this.internals, this.inputEl);\n }\n\n private handleFocus = (): void => {\n this.isFocused = true;\n this.bhFocus.emit();\n };\n\n private handleBlur = (): void => {\n this.isFocused = false;\n this.bhBlur.emit();\n };\n\n private handleMouseEnter = (): void => {\n if (!this.isFocused) {\n this.isHovered = true;\n }\n };\n\n private handleMouseLeave = (): void => {\n this.isHovered = false;\n };\n\n private handleHelpClick = (): void => {\n this.bhHelpClick.emit();\n };\n\n render() {\n const containerClasses = {\n 'input-container': true,\n 'input-container-focused': this.isFocused,\n 'input-container-hover': this.isHovered && !this.isFocused,\n 'input-container-error': this.error,\n 'input-container-disabled': this.disabled,\n 'input-container-with-leading': this.showLeadingIcon,\n };\n\n const wrapperStyle = this.width ? { width: this.width } : {};\n\n return (\n <div class=\"input-wrapper\" part=\"wrapper\" style={wrapperStyle}>\n <bh-label\n label={this.showLabel ? this.label : ''}\n required={this.required}\n showHelpIcon={this.showHelpIcon}\n helpIconTooltip={this.helpIconTooltip}\n disabled={this.disabled}\n onBhHelpClick={this.handleHelpClick}\n >\n <div\n class={containerClasses}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n >\n <div class=\"input-content\">\n {this.showLeadingIcon && (\n <span class=\"material-symbols-outlined leading-icon\">\n {this.leadingIcon}\n </span>\n )}\n <input\n ref={(el) => (this.inputEl = el)}\n type={this.type}\n class=\"input-element\"\n name={this.name}\n value={this.value}\n placeholder={this.placeholder}\n disabled={this.disabled}\n readOnly={this.readOnly}\n required={this.required}\n aria-label={this.label}\n aria-describedby={\n this.showHintText && this.hintText ? 'hint-text' : undefined\n }\n aria-invalid={String(this.error)}\n onInput={this.handleInput}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n part=\"input\"\n />\n {this.showTrailingIcon && (\n <span class=\"material-symbols-outlined trailing-icon\">\n {this.trailingIcon}\n </span>\n )}\n </div>\n </div>\n </bh-label>\n\n {this.showHintText && this.hintText && (\n <div\n class={{ 'hint-text': true, 'hint-error': this.error }}\n id=\"hint-text\"\n >\n {this.hintText}\n </div>\n )}\n </div>\n );\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bh-radio-button.entry.esm.js","sources":["src/components/bh-radio-button/bh-radio-button.css?tag=bh-radio-button&encapsulation=shadow","src/components/bh-radio-button/bh-radio-button.tsx"],"sourcesContent":["/* ==========================================================================\n BH-RADIO-BUTTON COMPONENT STYLES\n ========================================================================== */\n\n:host {\n display: inline-block;\n font-family: var(--font-inter, 'Inter', -apple-system, BlinkMacSystemFont, sans-serif);\n}\n\n/* ==========================================================================\n RADIO BUTTON STYLES\n ========================================================================== */\n\n.radio {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n outline: none;\n user-select: none;\n transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1),\n border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.2s ease;\n box-sizing: border-box;\n background: var(--color-white);\n border: 2px solid var(--color-neutral-300);\n border-radius: var(--radius-full);\n position: relative;\n flex-shrink: 0;\n}\n\n/* Size Variants */\n.radio-sm {\n width: 16px;\n height: 16px;\n}\n\n.radio-md {\n width: 20px;\n height: 20px;\n}\n\n/* State: Selected */\n.radio.radio-selected {\n background: var(--color-brand-600);\n border-color: var(--color-brand-600);\n animation: fillExpand 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n}\n\n/* State: Hover */\n.radio:hover:not(.radio-disabled) {\n background: var(--color-neutral-100);\n border-color: var(--color-neutral-300);\n}\n\n.radio.radio-selected:hover:not(.radio-disabled) {\n background: var(--color-brand-600);\n border-color: var(--color-brand-600);\n}\n\n/* State: Focused */\n.radio.radio-focused:not(.radio-disabled) {\n border-color: var(--color-neutral-300);\n box-shadow: 0px 0px 0px 4px var(--color-brand-100),\n 0px 0px 0px 2px var(--color-white);\n}\n\n.radio.radio-selected.radio-focused:not(.radio-disabled) {\n background: var(--color-brand-600);\n border-color: var(--color-brand-600);\n box-shadow: 0px 0px 0px 4px var(--color-brand-100),\n 0px 0px 0px 2px var(--color-white);\n}\n\n/* State: Disabled */\n.radio.radio-disabled {\n background: var(--color-neutral-50);\n border-color: var(--color-neutral-300);\n cursor: not-allowed;\n opacity: 1;\n}\n\n.radio.radio-selected.radio-disabled {\n background: var(--color-neutral-50);\n border: 2px solid var(--color-neutral-300);\n}\n\n/* Radio Dot (inner circle) */\n.radio-dot {\n width: 6px;\n height: 6px;\n border-radius: var(--radius-full);\n background: var(--color-white);\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n}\n\n/* Radio Dot for small size */\n.radio-sm .radio-dot {\n width: 4px;\n height: 4px;\n}\n\n/* Disabled radio dot */\n.radio-disabled .radio-dot {\n background: var(--color-neutral-300);\n}\n\n/* Focus outline for accessibility */\n.radio:focus {\n outline: none;\n}\n\n.radio:focus:not(.radio-disabled) {\n box-shadow: 0px 0px 0px 4px var(--color-brand-100),\n 0px 0px 0px 2px var(--color-white);\n}\n\n/* Animation for fill effect */\n@keyframes fillExpand {\n 0% {\n transform: scale(0.95);\n }\n 50% {\n transform: scale(1.05);\n }\n 100% {\n transform: scale(1);\n }\n}\n\n/* ==========================================================================\n RADIO CONTROL AND WRAPPER STYLES\n ========================================================================== */\n\n.radio-wrapper {\n display: inline-block;\n}\n\n.radio-control {\n display: inline-flex;\n align-items: flex-start;\n cursor: pointer;\n outline: none;\n}\n\n.radio-wrapper-disabled .radio-control {\n cursor: not-allowed;\n}\n\n/* Adjust radio position when with label */\n.radio-wrapper-with-label .radio-sm {\n margin-top: 3px;\n}\n\n.radio-wrapper-with-label .radio-md {\n margin-top: 2px;\n}\n","import { Component, Prop, State, Event, EventEmitter, h, AttachInternals } from '@stencil/core';\nimport { syncCheckableFormValue } from '../../utils/form';\n\nexport type RadioButtonSize = 'sm' | 'md';\n\n@Component({\n tag: 'bh-radio-button',\n styleUrl: 'bh-radio-button.css',\n shadow: true,\n formAssociated: true,\n})\nexport class BhRadioButton {\n @AttachInternals() internals!: ElementInternals;\n /**\n * The size of the radio button\n */\n @Prop() size: RadioButtonSize = 'md';\n\n /**\n * Whether the radio button is selected\n */\n @Prop({ mutable: true }) selected: boolean = false;\n\n /**\n * Whether the radio button is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * The value associated with this radio button\n */\n @Prop() value: string = '';\n\n /**\n * The name of the radio group\n */\n @Prop() name: string = '';\n\n /**\n * Optional label text - when provided, renders radio with label\n */\n @Prop() label: string = '';\n\n /**\n * Optional supporting text below the label\n */\n @Prop() supportingText: string = '';\n\n /**\n * Track focus state internally\n */\n @State() isFocused: boolean = false;\n\n /**\n * Track hover state internally\n */\n @State() isHovered: boolean = false;\n\n /**\n * Emitted when the radio button selection changes\n */\n @Event() bhChange!: EventEmitter<string>;\n\n componentDidLoad() {\n syncCheckableFormValue(this.internals, this.name, this.selected, this.value);\n }\n\n formResetCallback() {\n this.selected = false;\n syncCheckableFormValue(this.internals, this.name, this.selected, this.value);\n }\n\n private handleClick = (): void => {\n if (this.disabled || this.selected) return;\n\n this.selected = true;\n syncCheckableFormValue(this.internals, this.name, this.selected, this.value);\n this.bhChange.emit(this.value);\n };\n\n private handleKeyDown = (event: KeyboardEvent): void => {\n if (event.key === ' ' || event.key === 'Enter') {\n event.preventDefault();\n this.handleClick();\n }\n };\n\n private handleFocus = (): void => {\n this.isFocused = true;\n };\n\n private handleBlur = (): void => {\n this.isFocused = false;\n };\n\n private handleMouseEnter = (): void => {\n this.isHovered = true;\n };\n\n private handleMouseLeave = (): void => {\n this.isHovered = false;\n };\n\n private uniqueId = `bh-radio-${Math.random().toString(36).substring(2, 9)}`;\n\n private renderRadioControl() {\n const radioClasses = {\n 'radio': true,\n [`radio-${this.size}`]: true,\n 'radio-selected': this.selected,\n 'radio-disabled': this.disabled,\n 'radio-focused': this.isFocused && !this.disabled,\n 'radio-hover': this.isHovered && !this.disabled,\n };\n\n return (\n <div\n class=\"radio-control\"\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n tabIndex={this.disabled ? -1 : 0}\n role=\"radio\"\n aria-checked={String(this.selected)}\n aria-disabled={String(this.disabled)}\n >\n <div class={radioClasses} part=\"radio\">\n {this.selected && <div class=\"radio-dot\"></div>}\n </div>\n </div>\n );\n }\n\n render() {\n const hasLabel = this.label || this.supportingText;\n\n const wrapperClasses = {\n 'radio-wrapper': true,\n 'radio-wrapper-with-label': !!hasLabel,\n 'radio-wrapper-disabled': this.disabled,\n };\n\n // Render with bh-label when label/supportingText is provided\n if (hasLabel) {\n return (\n <div class={wrapperClasses} part=\"wrapper\">\n <bh-label\n layout=\"inline-start\"\n label={this.label}\n supportingText={this.supportingText}\n disabled={this.disabled}\n for={this.uniqueId}\n >\n {this.renderRadioControl()}\n </bh-label>\n </div>\n );\n }\n\n // Standalone radio button without label\n return (\n <div class={wrapperClasses} part=\"wrapper\">\n {this.renderRadioControl()}\n </div>\n );\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bh-skeleton-loader.entry.esm.js","sources":["src/components/bh-skeleton-loader/bh-skeleton-loader.css?tag=bh-skeleton-loader&encapsulation=shadow","src/components/bh-skeleton-loader/bh-skeleton-loader.tsx"],"sourcesContent":["/* ==========================================================================\n BH-SKELETON-LOADER COMPONENT STYLES\n ========================================================================== */\n\n:host {\n display: inline-block;\n}\n\n.skeleton {\n display: inline-block;\n background: linear-gradient(\n 90deg,\n rgba(0, 0, 0, 0.06) 25%,\n rgba(0, 0, 0, 0.03) 50%,\n rgba(0, 0, 0, 0.06) 75%\n );\n background-size: 400% 100%;\n animation: shimmer 1.5s ease-in-out infinite;\n border-radius: var(--radius-sm);\n line-height: 1;\n}\n\n.skeleton-circle {\n border-radius: 50%;\n}\n\n.skeleton::before {\n content: '\\00a0';\n}\n\n@keyframes shimmer {\n 0% {\n background-position: 100% 50%;\n }\n 100% {\n background-position: 0 50%;\n }\n}\n\n.visually-hidden {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n}\n","import { Component, Prop, h } from '@stencil/core';\n\n@Component({\n tag: 'bh-skeleton-loader',\n styleUrl: 'bh-skeleton-loader.css',\n shadow: true,\n})\nexport class BhSkeletonLoader {\n /**\n * Width of the skeleton (CSS value)\n */\n @Prop() width: string = '100%';\n\n /**\n * Height of the skeleton (CSS value)\n */\n @Prop() height: string = '1em';\n\n /**\n * Whether the skeleton should be circular\n */\n @Prop() circle: boolean = false;\n\n render() {\n const skeletonClasses = {\n 'skeleton': true,\n 'skeleton-circle': this.circle,\n };\n\n return (\n <span\n class={skeletonClasses}\n style={{ width: this.width, height: this.height }}\n role=\"status\"\n aria-live=\"polite\"\n aria-busy=\"true\"\n part=\"skeleton\"\n >\n <span class=\"visually-hidden\">Loading...</span>\n </span>\n );\n }\n}\n"],"names":[],"mappings":";;AAAA,MAAM,mBAAmB,GAAG,8lBAA8lB;;MCO7mB,gBAAgB,GAAA,MAAA;;;;AAC3B;;AAEG;IACK,KAAK,GAAW,MAAM;AAE9B;;AAEG;IACK,MAAM,GAAW,KAAK;AAE9B;;AAEG;IACK,MAAM,GAAY,KAAK;IAE/B,MAAM,GAAA;AACJ,QAAA,MAAM,eAAe,GAAG;AACtB,YAAA,UAAU,EAAE,IAAI;YAChB,iBAAiB,EAAE,IAAI,CAAC,MAAM;SAC/B;AAED,QAAA,QACE,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE,eAAe,EACtB,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EACjD,IAAI,EAAC,QAAQ,EACH,WAAA,EAAA,QAAQ,EACR,WAAA,EAAA,MAAM,EAChB,IAAI,EAAC,UAAU,EAAA,EAEf,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAM,KAAK,EAAC,iBAAiB,EAAkB,EAAA,YAAA,CAAA,CAC1C;;;;;;;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export{B as BhButton}from"./p-DKeuA-TM.js";export{bh_badge as BhBadge}from"./p-c82e73aa.entry.js";export{B as BhLabel}from"./p-DANVSPII.js";export{bh_modal as BhModal}from"./p-852564d6.entry.js";export{bh_avatar as BhAvatar}from"./p-5a220f12.entry.js";export{bh_toggle as BhToggle}from"./p-1960c2d0.entry.js";export{bh_card as BhCard}from"./p-94156013.entry.js";export{bh_card_header as BhCardHeader}from"./p-0579ce8d.entry.js";export{bh_card_footer as BhCardFooter}from"./p-d94b296e.entry.js";export{bh_checkbox_group as BhCheckboxGroup}from"./p-3038cc1a.entry.js";export{bh_checkbox_group_item as BhCheckboxGroupItem}from"./p-86bbff38.entry.js";export{bh_data_grid as BhDataGrid}from"./p-f0cfc744.entry.js";import"./p-DtVghh5W.js";import"./p-CPgx0iFq.js";
|
|
2
|
-
//# sourceMappingURL=index.esm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export{B as bh_button}from"./p-DKeuA-TM.js";import{r as e,h as t}from"./p-DtVghh5W.js";const r=":host{display:inline-block}.loader-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0, 0, 0, 0.3);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999}.loader-overlay-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.loader-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.loader-spinner{position:relative;display:inline-block}.loader-message{color:var(--color-neutral-700);font-size:var(--text-sm-size);line-height:var(--text-sm-line);font-weight:var(--weight-medium);text-align:center;margin-top:var(--spacing-xs)}.loader-overlay .loader-message{color:var(--color-white)}.spinner-gradient{animation:gradient-rotate 2s linear infinite;will-change:transform}.gradient-svg{display:block;transform-origin:50% 50%}.gradient-path{stroke-dasharray:90, 150;stroke-dashoffset:0;animation:gradient-dash 1.5s ease-in-out infinite;transform-origin:50% 50%}.size-sm .gradient-svg{width:20px;height:20px}.size-sm .gradient-path{stroke-width:5}.size-md .gradient-svg{width:30px;height:30px}.size-md .gradient-path{stroke-width:5}.size-lg .gradient-svg{width:40px;height:40px}.size-lg .gradient-path{stroke-width:5}.size-xl .gradient-svg{width:60px;height:60px}.size-xl .gradient-path{stroke-width:6}@keyframes gradient-rotate{100%{transform:rotate(360deg)}}@keyframes gradient-dash{0%{stroke-dasharray:1, 150;stroke-dashoffset:0}50%{stroke-dasharray:90, 150;stroke-dashoffset:-35}100%{stroke-dasharray:90, 150;stroke-dashoffset:-124}}.loader-container:hover .spinner-gradient{animation-duration:1s}.loader-container:hover .gradient-path{animation-duration:0.6s}.spinner-gradient{backface-visibility:hidden;perspective:1000px}.gradient-svg{transform:translateZ(0)}";const s=class{constructor(t){e(this,t)}size="md";variant="default";overlay=false;overlayMessage="";showMessage=false;message="Loading...";renderSpinner(){const e=this.variant==="white"?"bellhop-gradient-white":"bellhop-gradient";return t("div",{class:`loader-spinner variant-${this.variant}`},t("div",{class:"spinner-gradient"},t("svg",{class:"gradient-svg",viewBox:"0 0 50 50"},t("defs",null,this.variant==="white"?t("linearGradient",{id:"bellhop-gradient-white",x1:"0%",y1:"0%",x2:"0%",y2:"100%"},t("stop",{offset:"0%",style:{stopColor:"rgba(255, 255, 255, 1)"}}),t("stop",{offset:"50%",style:{stopColor:"rgba(255, 255, 255, 0.8)"}}),t("stop",{offset:"100%",style:{stopColor:"rgba(255, 255, 255, 0.5)"}})):t("linearGradient",{id:"bellhop-gradient",x1:"0%",y1:"0%",x2:"0%",y2:"100%"},t("stop",{offset:"0%",style:{stopColor:"var(--color-accent-300)"}}),t("stop",{offset:"51%",style:{stopColor:"var(--color-brand-400)"}}),t("stop",{offset:"100%",style:{stopColor:"var(--color-brand-600)"}}))),t("circle",{class:"gradient-path",cx:"25",cy:"25",r:"20",fill:"none",stroke:`url(#${e})`,"stroke-width":"4","stroke-linecap":"round"}))))}renderMessage(e){const r=e?this.showMessage||this.overlayMessage:this.showMessage;if(!r)return null;return t("div",{class:"loader-message"},e?this.overlayMessage||this.message:this.message)}render(){if(this.overlay){return t("div",{class:"loader-overlay"},t("div",{class:"loader-overlay-content"},t("div",{class:`loader-container size-${this.size}`},this.renderSpinner()),this.renderMessage(true)))}return t("div",{class:`loader-container size-${this.size}`},this.renderSpinner(),this.renderMessage(false))}};s.style=r;export{s as bh_loader_spinner};
|
|
2
|
-
//# sourceMappingURL=p-051a25aa.entry.js.map
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{r as e,c as a,h as r,H as t}from"./p-DtVghh5W.js";const d=":host{display:block}.card-header{display:flex;flex-direction:column;gap:var(--spacing-lg);background:var(--color-white)}.card-header-content{display:flex;gap:var(--spacing-md);align-items:flex-start;padding:var(--spacing-lg) var(--spacing-xl) 0 var(--spacing-xl)}.card-header-text-container{display:flex;flex-direction:column;flex:1 0 0;gap:var(--spacing-xxs);min-width:0}.card-header-title-row{display:flex;align-items:center;gap:var(--spacing-lg)}.card-header-title{font-family:var(--font-inter);font-size:var(--text-md-size);font-weight:var(--weight-semibold);line-height:var(--text-md-line);color:var(--color-neutral-900)}.card-header-supporting-row{display:flex;align-items:center;gap:var(--spacing-lg);width:100%}.card-header-spacer{width:32px;flex-shrink:0}.card-header-supporting-text{flex:1 0 0;font-family:var(--font-inter);font-size:var(--text-sm-size);font-weight:var(--weight-regular);line-height:var(--text-sm-line);color:var(--color-neutral-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-header-divider{height:1px;background:var(--color-neutral-200)}";const i=class{constructor(r){e(this,r);this.bhDropdownClick=a(this,"bhDropdownClick")}showFeaturedIcon=true;featuredIcon="star";featuredIconStyle="outlined";featuredIconColor="gray";showTitle=true;headerTitle="Card title";showBadge=false;badgeText="";showSupportingText=true;supportingText="Card description";showDropdown=true;showDivider=true;bhDropdownClick;handleDropdownClick=()=>{this.bhDropdownClick.emit()};render(){return r(t,{key:"58db2d5c1ca47600da5c07ea2750ecb1c2f2a4a7"},r("div",{key:"70cbc0d9779b1f5e75a774f40715001c904f2670",class:"card-header"},r("div",{key:"fb602ff3a92aa06d51df870ea4e5b3a6f11e9309",class:"card-header-content"},r("div",{key:"00a315a07bc10dc72c36cbc79e0d24c9570dcdc7",class:"card-header-text-container"},r("div",{key:"42d15bc872bf00216be3fcff6bee772bcab7b14e",class:"card-header-title-row"},this.showFeaturedIcon&&r("bh-featured-icon",{key:"d9294c5035425329806b0b575cf4799defed83f9",size:"sm",icon:this.featuredIcon,iconStyle:this.featuredIconStyle,color:this.featuredIconColor}),this.showTitle&&r("span",{key:"96399bb209d70a9694fab80e0e0c4ece3025ade5",class:"card-header-title"},this.headerTitle),this.showBadge&&this.badgeText&&r("bh-badge",{key:"e030d01179a3e0cc3dbbc972a7251dd49a661533",variant:"blue",size:"sm",emphasis:"medium",label:this.badgeText})),this.showSupportingText&&r("div",{key:"e4a1253d649a77d9d6a5f12313f279e18b509304",class:"card-header-supporting-row"},this.showFeaturedIcon&&r("div",{key:"bf5f6482b25ad7c35f6f42f18001064f1a5f8be9",class:"card-header-spacer"}),r("span",{key:"256fa43537b957a80190ce8683484cbaef0ade56",class:"card-header-supporting-text"},this.supportingText))),this.showDropdown&&r("bh-button-icon",{key:"ab3df5c4b4fd8dbeb56c1860d2b38334ed6fa29e",hierarchy:"quaternary",size:"sm",iconName:"more_vert",ariaLabel:"More options",onBhClick:this.handleDropdownClick})),r("slot",{key:"836d525ba14a3f7020fecdcf3660e2e50353a9de",name:"tabs"}),this.showDivider&&r("div",{key:"9b96114d09fb987fe710de8a6438141c380c07e3",class:"card-header-divider"})))}};i.style=d;export{i as bh_card_header};
|
|
2
|
-
//# sourceMappingURL=p-0579ce8d.entry.js.map
|