@actabldesign/bellhop-core 0.0.3

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.
Files changed (1006) hide show
  1. package/README.md +116 -0
  2. package/bellhop-core/bellhop-core.css +7 -0
  3. package/bellhop-core/bellhop-core.esm.js +2 -0
  4. package/bellhop-core/bellhop-core.esm.js.map +1 -0
  5. package/bellhop-core/bh-accordion-item.entry.esm.js.map +1 -0
  6. package/bellhop-core/bh-accordion.entry.esm.js.map +1 -0
  7. package/bellhop-core/bh-appbar.entry.esm.js.map +1 -0
  8. package/bellhop-core/bh-autocomplete-menu.bh-tag.entry.esm.js.map +1 -0
  9. package/bellhop-core/bh-avatar-add.entry.esm.js.map +1 -0
  10. package/bellhop-core/bh-avatar-stacked.entry.esm.js.map +1 -0
  11. package/bellhop-core/bh-avatar.entry.esm.js.map +1 -0
  12. package/bellhop-core/bh-badge-dot.bh-breadcrumbs.entry.esm.js.map +1 -0
  13. package/bellhop-core/bh-badge.entry.esm.js.map +1 -0
  14. package/bellhop-core/bh-bar-chart.entry.esm.js.map +1 -0
  15. package/bellhop-core/bh-button-icon.entry.esm.js.map +1 -0
  16. package/bellhop-core/bh-button.bh-loader-spinner.entry.esm.js.map +1 -0
  17. package/bellhop-core/bh-card-footer.entry.esm.js.map +1 -0
  18. package/bellhop-core/bh-card-header.entry.esm.js.map +1 -0
  19. package/bellhop-core/bh-card.entry.esm.js.map +1 -0
  20. package/bellhop-core/bh-chart-tooltip.entry.esm.js.map +1 -0
  21. package/bellhop-core/bh-checkbox-group-item.entry.esm.js.map +1 -0
  22. package/bellhop-core/bh-checkbox-group.entry.esm.js.map +1 -0
  23. package/bellhop-core/bh-checkbox.entry.esm.js.map +1 -0
  24. package/bellhop-core/bh-container-footer.entry.esm.js.map +1 -0
  25. package/bellhop-core/bh-container.entry.esm.js.map +1 -0
  26. package/bellhop-core/bh-data-grid.entry.esm.js.map +1 -0
  27. package/bellhop-core/bh-date-picker-content.bh-picker-menu.entry.esm.js.map +1 -0
  28. package/bellhop-core/bh-date-picker.bh-empty-state.entry.esm.js.map +1 -0
  29. package/bellhop-core/bh-date-range-picker-content.entry.esm.js.map +1 -0
  30. package/bellhop-core/bh-date-range-picker.entry.esm.js.map +1 -0
  31. package/bellhop-core/bh-dropdown-menu.entry.esm.js.map +1 -0
  32. package/bellhop-core/bh-dropdown.bh-logo-box.bh-nav-item.entry.esm.js.map +1 -0
  33. package/bellhop-core/bh-featured-icon.entry.esm.js.map +1 -0
  34. package/bellhop-core/bh-illustrations.entry.esm.js.map +1 -0
  35. package/bellhop-core/bh-input-autocomplete.entry.esm.js.map +1 -0
  36. package/bellhop-core/bh-input-number.entry.esm.js.map +1 -0
  37. package/bellhop-core/bh-input-password.entry.esm.js.map +1 -0
  38. package/bellhop-core/bh-input-text.entry.esm.js.map +1 -0
  39. package/bellhop-core/bh-input-verification.entry.esm.js.map +1 -0
  40. package/bellhop-core/bh-label.bh-tooltip.entry.esm.js.map +1 -0
  41. package/bellhop-core/bh-modal-actions.entry.esm.js.map +1 -0
  42. package/bellhop-core/bh-modal-header.entry.esm.js.map +1 -0
  43. package/bellhop-core/bh-modal.entry.esm.js.map +1 -0
  44. package/bellhop-core/bh-month-picker-content.entry.esm.js.map +1 -0
  45. package/bellhop-core/bh-month-picker.entry.esm.js.map +1 -0
  46. package/bellhop-core/bh-notification.entry.esm.js.map +1 -0
  47. package/bellhop-core/bh-page-navigation-child.entry.esm.js.map +1 -0
  48. package/bellhop-core/bh-page-navigation-multi-level.bh-page-navigation-single-level.entry.esm.js.map +1 -0
  49. package/bellhop-core/bh-page-navigation.entry.esm.js.map +1 -0
  50. package/bellhop-core/bh-pie-chart.entry.esm.js.map +1 -0
  51. package/bellhop-core/bh-popover.entry.esm.js.map +1 -0
  52. package/bellhop-core/bh-product-switcher.entry.esm.js.map +1 -0
  53. package/bellhop-core/bh-property-switcher.entry.esm.js.map +1 -0
  54. package/bellhop-core/bh-radio-button.entry.esm.js.map +1 -0
  55. package/bellhop-core/bh-sidebar.entry.esm.js.map +1 -0
  56. package/bellhop-core/bh-skeleton-loader.entry.esm.js.map +1 -0
  57. package/bellhop-core/bh-tab-item.entry.esm.js.map +1 -0
  58. package/bellhop-core/bh-tabs.entry.esm.js.map +1 -0
  59. package/bellhop-core/bh-textarea.entry.esm.js.map +1 -0
  60. package/bellhop-core/bh-toggle.entry.esm.js.map +1 -0
  61. package/bellhop-core/bh-trend-chart.entry.esm.js.map +1 -0
  62. package/bellhop-core/index.esm.js +2 -0
  63. package/bellhop-core/index.esm.js.map +1 -0
  64. package/bellhop-core/loader.esm.js.map +1 -0
  65. package/bellhop-core/p-051a25aa.entry.js +2 -0
  66. package/bellhop-core/p-051a25aa.entry.js.map +1 -0
  67. package/bellhop-core/p-0579ce8d.entry.js +2 -0
  68. package/bellhop-core/p-0579ce8d.entry.js.map +1 -0
  69. package/bellhop-core/p-05c13d72.entry.js +2 -0
  70. package/bellhop-core/p-05c13d72.entry.js.map +1 -0
  71. package/bellhop-core/p-0e013732.entry.js +2 -0
  72. package/bellhop-core/p-0e013732.entry.js.map +1 -0
  73. package/bellhop-core/p-1960c2d0.entry.js +2 -0
  74. package/bellhop-core/p-1960c2d0.entry.js.map +1 -0
  75. package/bellhop-core/p-2735c901.entry.js +2 -0
  76. package/bellhop-core/p-2735c901.entry.js.map +1 -0
  77. package/bellhop-core/p-2c80bc07.entry.js +2 -0
  78. package/bellhop-core/p-2c80bc07.entry.js.map +1 -0
  79. package/bellhop-core/p-2cc0c4cf.entry.js +2 -0
  80. package/bellhop-core/p-2cc0c4cf.entry.js.map +1 -0
  81. package/bellhop-core/p-3038cc1a.entry.js +2 -0
  82. package/bellhop-core/p-3038cc1a.entry.js.map +1 -0
  83. package/bellhop-core/p-324cad08.entry.js +2 -0
  84. package/bellhop-core/p-324cad08.entry.js.map +1 -0
  85. package/bellhop-core/p-3bf098fd.entry.js +2 -0
  86. package/bellhop-core/p-3bf098fd.entry.js.map +1 -0
  87. package/bellhop-core/p-3c739eea.entry.js +2 -0
  88. package/bellhop-core/p-3c739eea.entry.js.map +1 -0
  89. package/bellhop-core/p-4c71a0b6.entry.js +2 -0
  90. package/bellhop-core/p-4c71a0b6.entry.js.map +1 -0
  91. package/bellhop-core/p-5a220f12.entry.js +2 -0
  92. package/bellhop-core/p-5a220f12.entry.js.map +1 -0
  93. package/bellhop-core/p-5d844699.entry.js +2 -0
  94. package/bellhop-core/p-5d844699.entry.js.map +1 -0
  95. package/bellhop-core/p-5e8d2fc0.entry.js +2 -0
  96. package/bellhop-core/p-5e8d2fc0.entry.js.map +1 -0
  97. package/bellhop-core/p-71391701.entry.js +2 -0
  98. package/bellhop-core/p-71391701.entry.js.map +1 -0
  99. package/bellhop-core/p-7e67af77.entry.js +2 -0
  100. package/bellhop-core/p-7e67af77.entry.js.map +1 -0
  101. package/bellhop-core/p-7e908d03.entry.js +2 -0
  102. package/bellhop-core/p-7e908d03.entry.js.map +1 -0
  103. package/bellhop-core/p-8053e945.entry.js +2 -0
  104. package/bellhop-core/p-8053e945.entry.js.map +1 -0
  105. package/bellhop-core/p-852564d6.entry.js +2 -0
  106. package/bellhop-core/p-852564d6.entry.js.map +1 -0
  107. package/bellhop-core/p-86bbff38.entry.js +2 -0
  108. package/bellhop-core/p-86bbff38.entry.js.map +1 -0
  109. package/bellhop-core/p-87d1ed92.entry.js +2 -0
  110. package/bellhop-core/p-87d1ed92.entry.js.map +1 -0
  111. package/bellhop-core/p-94156013.entry.js +2 -0
  112. package/bellhop-core/p-94156013.entry.js.map +1 -0
  113. package/bellhop-core/p-954b9c38.entry.js +2 -0
  114. package/bellhop-core/p-954b9c38.entry.js.map +1 -0
  115. package/bellhop-core/p-9693180e.entry.js +2 -0
  116. package/bellhop-core/p-9693180e.entry.js.map +1 -0
  117. package/bellhop-core/p-98a336f7.entry.js +2 -0
  118. package/bellhop-core/p-98a336f7.entry.js.map +1 -0
  119. package/bellhop-core/p-98cc729f.entry.js +2 -0
  120. package/bellhop-core/p-98cc729f.entry.js.map +1 -0
  121. package/bellhop-core/p-9e7e64dc.entry.js +2 -0
  122. package/bellhop-core/p-9e7e64dc.entry.js.map +1 -0
  123. package/bellhop-core/p-9fe1fd2e.entry.js +2 -0
  124. package/bellhop-core/p-9fe1fd2e.entry.js.map +1 -0
  125. package/bellhop-core/p-CPgx0iFq.js +2 -0
  126. package/bellhop-core/p-CPgx0iFq.js.map +1 -0
  127. package/bellhop-core/p-DANVSPII.js +2 -0
  128. package/bellhop-core/p-DANVSPII.js.map +1 -0
  129. package/bellhop-core/p-DKeuA-TM.js +2 -0
  130. package/bellhop-core/p-DKeuA-TM.js.map +1 -0
  131. package/bellhop-core/p-DtVghh5W.js +3 -0
  132. package/bellhop-core/p-DtVghh5W.js.map +1 -0
  133. package/bellhop-core/p-a901ae33.entry.js +2 -0
  134. package/bellhop-core/p-a901ae33.entry.js.map +1 -0
  135. package/bellhop-core/p-abd6ade0.entry.js +2 -0
  136. package/bellhop-core/p-abd6ade0.entry.js.map +1 -0
  137. package/bellhop-core/p-abf68de4.entry.js +2 -0
  138. package/bellhop-core/p-abf68de4.entry.js.map +1 -0
  139. package/bellhop-core/p-ad15a4b9.entry.js +2 -0
  140. package/bellhop-core/p-ad15a4b9.entry.js.map +1 -0
  141. package/bellhop-core/p-b1affa8d.entry.js +2 -0
  142. package/bellhop-core/p-b1affa8d.entry.js.map +1 -0
  143. package/bellhop-core/p-b4104ae5.entry.js +2 -0
  144. package/bellhop-core/p-b4104ae5.entry.js.map +1 -0
  145. package/bellhop-core/p-c194883a.entry.js +2 -0
  146. package/bellhop-core/p-c194883a.entry.js.map +1 -0
  147. package/bellhop-core/p-c48ca590.entry.js +2 -0
  148. package/bellhop-core/p-c48ca590.entry.js.map +1 -0
  149. package/bellhop-core/p-c82e73aa.entry.js +2 -0
  150. package/bellhop-core/p-c82e73aa.entry.js.map +1 -0
  151. package/bellhop-core/p-d14192df.entry.js +2 -0
  152. package/bellhop-core/p-d14192df.entry.js.map +1 -0
  153. package/bellhop-core/p-d5fb8d0f.entry.js +2 -0
  154. package/bellhop-core/p-d5fb8d0f.entry.js.map +1 -0
  155. package/bellhop-core/p-d9106838.entry.js +2 -0
  156. package/bellhop-core/p-d9106838.entry.js.map +1 -0
  157. package/bellhop-core/p-d941cdba.entry.js +2 -0
  158. package/bellhop-core/p-d941cdba.entry.js.map +1 -0
  159. package/bellhop-core/p-d94b296e.entry.js +2 -0
  160. package/bellhop-core/p-d94b296e.entry.js.map +1 -0
  161. package/bellhop-core/p-df2728a1.entry.js +2 -0
  162. package/bellhop-core/p-df2728a1.entry.js.map +1 -0
  163. package/bellhop-core/p-df45027c.entry.js +2 -0
  164. package/bellhop-core/p-df45027c.entry.js.map +1 -0
  165. package/bellhop-core/p-dfe0574c.entry.js +2 -0
  166. package/bellhop-core/p-dfe0574c.entry.js.map +1 -0
  167. package/bellhop-core/p-e3c5d1e3.entry.js +2 -0
  168. package/bellhop-core/p-e3c5d1e3.entry.js.map +1 -0
  169. package/bellhop-core/p-e3d79592.entry.js +2 -0
  170. package/bellhop-core/p-e3d79592.entry.js.map +1 -0
  171. package/bellhop-core/p-e44539e9.entry.js +2 -0
  172. package/bellhop-core/p-e44539e9.entry.js.map +1 -0
  173. package/bellhop-core/p-e5b9a3de.entry.js +2 -0
  174. package/bellhop-core/p-e5b9a3de.entry.js.map +1 -0
  175. package/bellhop-core/p-e8e0739d.entry.js +2 -0
  176. package/bellhop-core/p-e8e0739d.entry.js.map +1 -0
  177. package/bellhop-core/p-ebb2492c.entry.js +2 -0
  178. package/bellhop-core/p-ebb2492c.entry.js.map +1 -0
  179. package/bellhop-core/p-ec894e11.entry.js +2 -0
  180. package/bellhop-core/p-ec894e11.entry.js.map +1 -0
  181. package/bellhop-core/p-f0cfc744.entry.js +2 -0
  182. package/bellhop-core/p-f0cfc744.entry.js.map +1 -0
  183. package/bellhop-core/p-f261bdae.entry.js +2 -0
  184. package/bellhop-core/p-f261bdae.entry.js.map +1 -0
  185. package/bellhop-core/p-f4c4c70d.entry.js +2 -0
  186. package/bellhop-core/p-f4c4c70d.entry.js.map +1 -0
  187. package/cjs/bellhop-core.cjs.js +25 -0
  188. package/cjs/bellhop-core.cjs.js.map +1 -0
  189. package/cjs/bh-accordion-item.cjs.entry.js +82 -0
  190. package/cjs/bh-accordion-item.entry.cjs.js.map +1 -0
  191. package/cjs/bh-accordion.cjs.entry.js +119 -0
  192. package/cjs/bh-accordion.entry.cjs.js.map +1 -0
  193. package/cjs/bh-appbar.cjs.entry.js +83 -0
  194. package/cjs/bh-appbar.entry.cjs.js.map +1 -0
  195. package/cjs/bh-autocomplete-menu.bh-tag.entry.cjs.js.map +1 -0
  196. package/cjs/bh-autocomplete-menu_2.cjs.entry.js +177 -0
  197. package/cjs/bh-avatar-add.cjs.entry.js +75 -0
  198. package/cjs/bh-avatar-add.entry.cjs.js.map +1 -0
  199. package/cjs/bh-avatar-stacked.cjs.entry.js +94 -0
  200. package/cjs/bh-avatar-stacked.entry.cjs.js.map +1 -0
  201. package/cjs/bh-avatar.cjs.entry.js +93 -0
  202. package/cjs/bh-avatar.entry.cjs.js.map +1 -0
  203. package/cjs/bh-badge-dot.bh-breadcrumbs.entry.cjs.js.map +1 -0
  204. package/cjs/bh-badge-dot_2.cjs.entry.js +134 -0
  205. package/cjs/bh-badge.cjs.entry.js +71 -0
  206. package/cjs/bh-badge.entry.cjs.js.map +1 -0
  207. package/cjs/bh-bar-chart.cjs.entry.js +164 -0
  208. package/cjs/bh-bar-chart.entry.cjs.js.map +1 -0
  209. package/cjs/bh-button-BKVcf-nK.js +117 -0
  210. package/cjs/bh-button-BKVcf-nK.js.map +1 -0
  211. package/cjs/bh-button-icon.cjs.entry.js +74 -0
  212. package/cjs/bh-button-icon.entry.cjs.js.map +1 -0
  213. package/cjs/bh-button.bh-loader-spinner.entry.cjs.js.map +1 -0
  214. package/cjs/bh-button_2.cjs.entry.js +47 -0
  215. package/cjs/bh-card-footer.cjs.entry.js +30 -0
  216. package/cjs/bh-card-footer.entry.cjs.js.map +1 -0
  217. package/cjs/bh-card-header.cjs.entry.js +74 -0
  218. package/cjs/bh-card-header.entry.cjs.js.map +1 -0
  219. package/cjs/bh-card.cjs.entry.js +48 -0
  220. package/cjs/bh-card.entry.cjs.js.map +1 -0
  221. package/cjs/bh-chart-tooltip.cjs.entry.js +57 -0
  222. package/cjs/bh-chart-tooltip.entry.cjs.js.map +1 -0
  223. package/cjs/bh-checkbox-group-item.cjs.entry.js +142 -0
  224. package/cjs/bh-checkbox-group-item.entry.cjs.js.map +1 -0
  225. package/cjs/bh-checkbox-group.cjs.entry.js +100 -0
  226. package/cjs/bh-checkbox-group.entry.cjs.js.map +1 -0
  227. package/cjs/bh-checkbox.cjs.entry.js +144 -0
  228. package/cjs/bh-checkbox.entry.cjs.js.map +1 -0
  229. package/cjs/bh-container-footer.cjs.entry.js +38 -0
  230. package/cjs/bh-container-footer.entry.cjs.js.map +1 -0
  231. package/cjs/bh-container.cjs.entry.js +26 -0
  232. package/cjs/bh-container.entry.cjs.js.map +1 -0
  233. package/cjs/bh-data-grid.cjs.entry.js +812 -0
  234. package/cjs/bh-data-grid.entry.cjs.js.map +1 -0
  235. package/cjs/bh-date-picker-content.bh-picker-menu.entry.cjs.js.map +1 -0
  236. package/cjs/bh-date-picker-content_2.cjs.entry.js +525 -0
  237. package/cjs/bh-date-picker.bh-empty-state.entry.cjs.js.map +1 -0
  238. package/cjs/bh-date-picker_2.cjs.entry.js +252 -0
  239. package/cjs/bh-date-range-picker-content.cjs.entry.js +151 -0
  240. package/cjs/bh-date-range-picker-content.entry.cjs.js.map +1 -0
  241. package/cjs/bh-date-range-picker.cjs.entry.js +167 -0
  242. package/cjs/bh-date-range-picker.entry.cjs.js.map +1 -0
  243. package/cjs/bh-dropdown-menu.cjs.entry.js +114 -0
  244. package/cjs/bh-dropdown-menu.entry.cjs.js.map +1 -0
  245. package/cjs/bh-dropdown.bh-logo-box.bh-nav-item.entry.cjs.js.map +1 -0
  246. package/cjs/bh-dropdown_3.cjs.entry.js +307 -0
  247. package/cjs/bh-featured-icon.cjs.entry.js +41 -0
  248. package/cjs/bh-featured-icon.entry.cjs.js.map +1 -0
  249. package/cjs/bh-illustrations.cjs.entry.js +65 -0
  250. package/cjs/bh-illustrations.entry.cjs.js.map +1 -0
  251. package/cjs/bh-input-autocomplete.cjs.entry.js +342 -0
  252. package/cjs/bh-input-autocomplete.entry.cjs.js.map +1 -0
  253. package/cjs/bh-input-number.cjs.entry.js +307 -0
  254. package/cjs/bh-input-number.entry.cjs.js.map +1 -0
  255. package/cjs/bh-input-password.cjs.entry.js +182 -0
  256. package/cjs/bh-input-password.entry.cjs.js.map +1 -0
  257. package/cjs/bh-input-text.cjs.entry.js +192 -0
  258. package/cjs/bh-input-text.entry.cjs.js.map +1 -0
  259. package/cjs/bh-input-verification.cjs.entry.js +203 -0
  260. package/cjs/bh-input-verification.entry.cjs.js.map +1 -0
  261. package/cjs/bh-label-DBqucnaO.js +110 -0
  262. package/cjs/bh-label-DBqucnaO.js.map +1 -0
  263. package/cjs/bh-label.bh-tooltip.entry.cjs.js.map +1 -0
  264. package/cjs/bh-label_2.cjs.entry.js +48 -0
  265. package/cjs/bh-modal-actions.cjs.entry.js +66 -0
  266. package/cjs/bh-modal-actions.entry.cjs.js.map +1 -0
  267. package/cjs/bh-modal-header.cjs.entry.js +76 -0
  268. package/cjs/bh-modal-header.entry.cjs.js.map +1 -0
  269. package/cjs/bh-modal.cjs.entry.js +56 -0
  270. package/cjs/bh-modal.entry.cjs.js.map +1 -0
  271. package/cjs/bh-month-picker-content.cjs.entry.js +189 -0
  272. package/cjs/bh-month-picker-content.entry.cjs.js.map +1 -0
  273. package/cjs/bh-month-picker.cjs.entry.js +152 -0
  274. package/cjs/bh-month-picker.entry.cjs.js.map +1 -0
  275. package/cjs/bh-notification.cjs.entry.js +128 -0
  276. package/cjs/bh-notification.entry.cjs.js.map +1 -0
  277. package/cjs/bh-page-navigation-child.cjs.entry.js +48 -0
  278. package/cjs/bh-page-navigation-child.entry.cjs.js.map +1 -0
  279. package/cjs/bh-page-navigation-multi-level.bh-page-navigation-single-level.entry.cjs.js.map +1 -0
  280. package/cjs/bh-page-navigation-multi-level_2.cjs.entry.js +146 -0
  281. package/cjs/bh-page-navigation.cjs.entry.js +72 -0
  282. package/cjs/bh-page-navigation.entry.cjs.js.map +1 -0
  283. package/cjs/bh-pie-chart.cjs.entry.js +157 -0
  284. package/cjs/bh-pie-chart.entry.cjs.js.map +1 -0
  285. package/cjs/bh-popover.cjs.entry.js +100 -0
  286. package/cjs/bh-popover.entry.cjs.js.map +1 -0
  287. package/cjs/bh-product-switcher.cjs.entry.js +102 -0
  288. package/cjs/bh-product-switcher.entry.cjs.js.map +1 -0
  289. package/cjs/bh-property-switcher.cjs.entry.js +231 -0
  290. package/cjs/bh-property-switcher.entry.cjs.js.map +1 -0
  291. package/cjs/bh-radio-button.cjs.entry.js +124 -0
  292. package/cjs/bh-radio-button.entry.cjs.js.map +1 -0
  293. package/cjs/bh-sidebar.cjs.entry.js +110 -0
  294. package/cjs/bh-sidebar.entry.cjs.js.map +1 -0
  295. package/cjs/bh-skeleton-loader.cjs.entry.js +34 -0
  296. package/cjs/bh-skeleton-loader.entry.cjs.js.map +1 -0
  297. package/cjs/bh-tab-item.cjs.entry.js +54 -0
  298. package/cjs/bh-tab-item.entry.cjs.js.map +1 -0
  299. package/cjs/bh-tabs.cjs.entry.js +52 -0
  300. package/cjs/bh-tabs.entry.cjs.js.map +1 -0
  301. package/cjs/bh-textarea.cjs.entry.js +161 -0
  302. package/cjs/bh-textarea.entry.cjs.js.map +1 -0
  303. package/cjs/bh-toggle.cjs.entry.js +141 -0
  304. package/cjs/bh-toggle.entry.cjs.js.map +1 -0
  305. package/cjs/bh-trend-chart.cjs.entry.js +121 -0
  306. package/cjs/bh-trend-chart.entry.cjs.js.map +1 -0
  307. package/cjs/form-9mbajZ3y.js +64 -0
  308. package/cjs/form-9mbajZ3y.js.map +1 -0
  309. package/cjs/index-tZqSQc8E.js +1951 -0
  310. package/cjs/index-tZqSQc8E.js.map +1 -0
  311. package/cjs/index.cjs.js +32 -0
  312. package/cjs/index.cjs.js.map +1 -0
  313. package/cjs/loader.cjs.js +13 -0
  314. package/cjs/loader.cjs.js.map +1 -0
  315. package/collection/collection-manifest.json +77 -0
  316. package/collection/components/bh-accordion/bh-accordion.css +30 -0
  317. package/collection/components/bh-accordion/bh-accordion.js +227 -0
  318. package/collection/components/bh-accordion/bh-accordion.js.map +1 -0
  319. package/collection/components/bh-accordion-item/bh-accordion-item.css +119 -0
  320. package/collection/components/bh-accordion-item/bh-accordion-item.js +207 -0
  321. package/collection/components/bh-accordion-item/bh-accordion-item.js.map +1 -0
  322. package/collection/components/bh-appbar/bh-appbar.css +80 -0
  323. package/collection/components/bh-appbar/bh-appbar.js +270 -0
  324. package/collection/components/bh-appbar/bh-appbar.js.map +1 -0
  325. package/collection/components/bh-autocomplete-menu/bh-autocomplete-menu.css +142 -0
  326. package/collection/components/bh-autocomplete-menu/bh-autocomplete-menu.js +301 -0
  327. package/collection/components/bh-autocomplete-menu/bh-autocomplete-menu.js.map +1 -0
  328. package/collection/components/bh-avatar/bh-avatar.css +257 -0
  329. package/collection/components/bh-avatar/bh-avatar.js +266 -0
  330. package/collection/components/bh-avatar/bh-avatar.js.map +1 -0
  331. package/collection/components/bh-avatar-add/bh-avatar-add.css +145 -0
  332. package/collection/components/bh-avatar-add/bh-avatar-add.js +194 -0
  333. package/collection/components/bh-avatar-add/bh-avatar-add.js.map +1 -0
  334. package/collection/components/bh-avatar-stacked/bh-avatar-stacked.css +29 -0
  335. package/collection/components/bh-avatar-stacked/bh-avatar-stacked.js +211 -0
  336. package/collection/components/bh-avatar-stacked/bh-avatar-stacked.js.map +1 -0
  337. package/collection/components/bh-badge/bh-badge.css +348 -0
  338. package/collection/components/bh-badge/bh-badge.js +250 -0
  339. package/collection/components/bh-badge/bh-badge.js.map +1 -0
  340. package/collection/components/bh-badge-dot/bh-badge-dot.css +77 -0
  341. package/collection/components/bh-badge-dot/bh-badge-dot.js +113 -0
  342. package/collection/components/bh-badge-dot/bh-badge-dot.js.map +1 -0
  343. package/collection/components/bh-bar-chart/bh-bar-chart.css +363 -0
  344. package/collection/components/bh-bar-chart/bh-bar-chart.js +316 -0
  345. package/collection/components/bh-bar-chart/bh-bar-chart.js.map +1 -0
  346. package/collection/components/bh-breadcrumbs/bh-breadcrumbs.css +158 -0
  347. package/collection/components/bh-breadcrumbs/bh-breadcrumbs.js +231 -0
  348. package/collection/components/bh-breadcrumbs/bh-breadcrumbs.js.map +1 -0
  349. package/collection/components/bh-button/bh-button.css +467 -0
  350. package/collection/components/bh-button/bh-button.js +350 -0
  351. package/collection/components/bh-button/bh-button.js.map +1 -0
  352. package/collection/components/bh-button-icon/bh-button-icon.css +187 -0
  353. package/collection/components/bh-button-icon/bh-button-icon.js +259 -0
  354. package/collection/components/bh-button-icon/bh-button-icon.js.map +1 -0
  355. package/collection/components/bh-card/bh-card.css +57 -0
  356. package/collection/components/bh-card/bh-card.js +139 -0
  357. package/collection/components/bh-card/bh-card.js.map +1 -0
  358. package/collection/components/bh-card-footer/bh-card-footer.css +54 -0
  359. package/collection/components/bh-card-footer/bh-card-footer.js +81 -0
  360. package/collection/components/bh-card-footer/bh-card-footer.js.map +1 -0
  361. package/collection/components/bh-card-header/bh-card-header.css +68 -0
  362. package/collection/components/bh-card-header/bh-card-header.js +348 -0
  363. package/collection/components/bh-card-header/bh-card-header.js.map +1 -0
  364. package/collection/components/bh-chart-tooltip/bh-chart-tooltip.css +301 -0
  365. package/collection/components/bh-chart-tooltip/bh-chart-tooltip.js +226 -0
  366. package/collection/components/bh-chart-tooltip/bh-chart-tooltip.js.map +1 -0
  367. package/collection/components/bh-checkbox/bh-checkbox.css +179 -0
  368. package/collection/components/bh-checkbox/bh-checkbox.js +378 -0
  369. package/collection/components/bh-checkbox/bh-checkbox.js.map +1 -0
  370. package/collection/components/bh-checkbox-group/bh-checkbox-group.css +10 -0
  371. package/collection/components/bh-checkbox-group/bh-checkbox-group.js +218 -0
  372. package/collection/components/bh-checkbox-group/bh-checkbox-group.js.map +1 -0
  373. package/collection/components/bh-checkbox-group-item/bh-checkbox-group-item.css +118 -0
  374. package/collection/components/bh-checkbox-group-item/bh-checkbox-group-item.js +402 -0
  375. package/collection/components/bh-checkbox-group-item/bh-checkbox-group-item.js.map +1 -0
  376. package/collection/components/bh-container/bh-container.css +21 -0
  377. package/collection/components/bh-container/bh-container.js +51 -0
  378. package/collection/components/bh-container/bh-container.js.map +1 -0
  379. package/collection/components/bh-container-footer/bh-container-footer.css +22 -0
  380. package/collection/components/bh-container-footer/bh-container-footer.js +106 -0
  381. package/collection/components/bh-container-footer/bh-container-footer.js.map +1 -0
  382. package/collection/components/bh-data-grid/bh-data-grid.css +602 -0
  383. package/collection/components/bh-data-grid/bh-data-grid.js +1488 -0
  384. package/collection/components/bh-data-grid/bh-data-grid.js.map +1 -0
  385. package/collection/components/bh-date-picker/bh-date-picker.css +251 -0
  386. package/collection/components/bh-date-picker/bh-date-picker.js +485 -0
  387. package/collection/components/bh-date-picker/bh-date-picker.js.map +1 -0
  388. package/collection/components/bh-date-picker-content/bh-date-picker-content.css +541 -0
  389. package/collection/components/bh-date-picker-content/bh-date-picker-content.js +711 -0
  390. package/collection/components/bh-date-picker-content/bh-date-picker-content.js.map +1 -0
  391. package/collection/components/bh-date-range-picker/bh-date-range-picker.css +247 -0
  392. package/collection/components/bh-date-range-picker/bh-date-range-picker.js +528 -0
  393. package/collection/components/bh-date-range-picker/bh-date-range-picker.js.map +1 -0
  394. package/collection/components/bh-date-range-picker-content/bh-date-range-picker-content.css +275 -0
  395. package/collection/components/bh-date-range-picker-content/bh-date-range-picker-content.js +338 -0
  396. package/collection/components/bh-date-range-picker-content/bh-date-range-picker-content.js.map +1 -0
  397. package/collection/components/bh-dropdown/bh-dropdown.css +64 -0
  398. package/collection/components/bh-dropdown/bh-dropdown.js +512 -0
  399. package/collection/components/bh-dropdown/bh-dropdown.js.map +1 -0
  400. package/collection/components/bh-dropdown-menu/bh-dropdown-menu.css +227 -0
  401. package/collection/components/bh-dropdown-menu/bh-dropdown-menu.js +262 -0
  402. package/collection/components/bh-dropdown-menu/bh-dropdown-menu.js.map +1 -0
  403. package/collection/components/bh-empty-state/bh-empty-state.css +89 -0
  404. package/collection/components/bh-empty-state/bh-empty-state.js +306 -0
  405. package/collection/components/bh-empty-state/bh-empty-state.js.map +1 -0
  406. package/collection/components/bh-featured-icon/bh-featured-icon.css +198 -0
  407. package/collection/components/bh-featured-icon/bh-featured-icon.js +144 -0
  408. package/collection/components/bh-featured-icon/bh-featured-icon.js.map +1 -0
  409. package/collection/components/bh-illustrations/bh-illustrations.css +328 -0
  410. package/collection/components/bh-illustrations/bh-illustrations.js +174 -0
  411. package/collection/components/bh-illustrations/bh-illustrations.js.map +1 -0
  412. package/collection/components/bh-input-autocomplete/bh-input-autocomplete.css +301 -0
  413. package/collection/components/bh-input-autocomplete/bh-input-autocomplete.js +872 -0
  414. package/collection/components/bh-input-autocomplete/bh-input-autocomplete.js.map +1 -0
  415. package/collection/components/bh-input-number/bh-input-number.css +192 -0
  416. package/collection/components/bh-input-number/bh-input-number.js +818 -0
  417. package/collection/components/bh-input-number/bh-input-number.js.map +1 -0
  418. package/collection/components/bh-input-password/bh-input-password.css +164 -0
  419. package/collection/components/bh-input-password/bh-input-password.js +581 -0
  420. package/collection/components/bh-input-password/bh-input-password.js.map +1 -0
  421. package/collection/components/bh-input-text/bh-input-text.css +153 -0
  422. package/collection/components/bh-input-text/bh-input-text.js +696 -0
  423. package/collection/components/bh-input-text/bh-input-text.js.map +1 -0
  424. package/collection/components/bh-input-verification/bh-input-verification.css +125 -0
  425. package/collection/components/bh-input-verification/bh-input-verification.js +523 -0
  426. package/collection/components/bh-input-verification/bh-input-verification.js.map +1 -0
  427. package/collection/components/bh-label/bh-label.css +143 -0
  428. package/collection/components/bh-label/bh-label.js +302 -0
  429. package/collection/components/bh-label/bh-label.js.map +1 -0
  430. package/collection/components/bh-loader-spinner/bh-loader-spinner.css +153 -0
  431. package/collection/components/bh-loader-spinner/bh-loader-spinner.js +182 -0
  432. package/collection/components/bh-loader-spinner/bh-loader-spinner.js.map +1 -0
  433. package/collection/components/bh-logo-box/bh-logo-box.css +85 -0
  434. package/collection/components/bh-logo-box/bh-logo-box.js +184 -0
  435. package/collection/components/bh-logo-box/bh-logo-box.js.map +1 -0
  436. package/collection/components/bh-modal/bh-modal.css +87 -0
  437. package/collection/components/bh-modal/bh-modal.js +144 -0
  438. package/collection/components/bh-modal/bh-modal.js.map +1 -0
  439. package/collection/components/bh-modal-actions/bh-modal-actions.css +124 -0
  440. package/collection/components/bh-modal-actions/bh-modal-actions.js +208 -0
  441. package/collection/components/bh-modal-actions/bh-modal-actions.js.map +1 -0
  442. package/collection/components/bh-modal-header/bh-modal-header.css +106 -0
  443. package/collection/components/bh-modal-header/bh-modal-header.js +275 -0
  444. package/collection/components/bh-modal-header/bh-modal-header.js.map +1 -0
  445. package/collection/components/bh-month-picker/bh-month-picker.css +251 -0
  446. package/collection/components/bh-month-picker/bh-month-picker.js +444 -0
  447. package/collection/components/bh-month-picker/bh-month-picker.js.map +1 -0
  448. package/collection/components/bh-month-picker-content/bh-month-picker-content.css +406 -0
  449. package/collection/components/bh-month-picker-content/bh-month-picker-content.js +437 -0
  450. package/collection/components/bh-month-picker-content/bh-month-picker-content.js.map +1 -0
  451. package/collection/components/bh-notification/bh-notification.css +117 -0
  452. package/collection/components/bh-notification/bh-notification.js +324 -0
  453. package/collection/components/bh-notification/bh-notification.js.map +1 -0
  454. package/collection/components/bh-page-navigation/bh-page-navigation.css +253 -0
  455. package/collection/components/bh-page-navigation/bh-page-navigation.js +146 -0
  456. package/collection/components/bh-page-navigation/bh-page-navigation.js.map +1 -0
  457. package/collection/components/bh-page-navigation-child/bh-page-navigation-child.css +281 -0
  458. package/collection/components/bh-page-navigation-child/bh-page-navigation-child.js +148 -0
  459. package/collection/components/bh-page-navigation-child/bh-page-navigation-child.js.map +1 -0
  460. package/collection/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.css +372 -0
  461. package/collection/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.js +268 -0
  462. package/collection/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.js.map +1 -0
  463. package/collection/components/bh-page-navigation-single-level/bh-page-navigation-single-level.css +294 -0
  464. package/collection/components/bh-page-navigation-single-level/bh-page-navigation-single-level.js +126 -0
  465. package/collection/components/bh-page-navigation-single-level/bh-page-navigation-single-level.js.map +1 -0
  466. package/collection/components/bh-picker-menu/bh-picker-menu.css +284 -0
  467. package/collection/components/bh-picker-menu/bh-picker-menu.js +470 -0
  468. package/collection/components/bh-picker-menu/bh-picker-menu.js.map +1 -0
  469. package/collection/components/bh-pie-chart/bh-pie-chart.css +292 -0
  470. package/collection/components/bh-pie-chart/bh-pie-chart.js +280 -0
  471. package/collection/components/bh-pie-chart/bh-pie-chart.js.map +1 -0
  472. package/collection/components/bh-popover/bh-popover.css +310 -0
  473. package/collection/components/bh-popover/bh-popover.js +326 -0
  474. package/collection/components/bh-popover/bh-popover.js.map +1 -0
  475. package/collection/components/bh-product-switcher/bh-product-switcher.css +128 -0
  476. package/collection/components/bh-product-switcher/bh-product-switcher.js +226 -0
  477. package/collection/components/bh-product-switcher/bh-product-switcher.js.map +1 -0
  478. package/collection/components/bh-property-switcher/bh-property-switcher.css +346 -0
  479. package/collection/components/bh-property-switcher/bh-property-switcher.js +360 -0
  480. package/collection/components/bh-property-switcher/bh-property-switcher.js.map +1 -0
  481. package/collection/components/bh-radio-button/bh-radio-button.css +159 -0
  482. package/collection/components/bh-radio-button/bh-radio-button.js +292 -0
  483. package/collection/components/bh-radio-button/bh-radio-button.js.map +1 -0
  484. package/collection/components/bh-sidebar/bh-nav-item.css +114 -0
  485. package/collection/components/bh-sidebar/bh-nav-item.js +157 -0
  486. package/collection/components/bh-sidebar/bh-nav-item.js.map +1 -0
  487. package/collection/components/bh-sidebar/bh-sidebar.css +178 -0
  488. package/collection/components/bh-sidebar/bh-sidebar.js +344 -0
  489. package/collection/components/bh-sidebar/bh-sidebar.js.map +1 -0
  490. package/collection/components/bh-skeleton-loader/bh-skeleton-loader.css +50 -0
  491. package/collection/components/bh-skeleton-loader/bh-skeleton-loader.js +99 -0
  492. package/collection/components/bh-skeleton-loader/bh-skeleton-loader.js.map +1 -0
  493. package/collection/components/bh-tab-item/bh-tab-item.css +132 -0
  494. package/collection/components/bh-tab-item/bh-tab-item.js +158 -0
  495. package/collection/components/bh-tab-item/bh-tab-item.js.map +1 -0
  496. package/collection/components/bh-tabs/bh-tabs.css +71 -0
  497. package/collection/components/bh-tabs/bh-tabs.js +178 -0
  498. package/collection/components/bh-tabs/bh-tabs.js.map +1 -0
  499. package/collection/components/bh-tag/bh-tag.css +180 -0
  500. package/collection/components/bh-tag/bh-tag.js +238 -0
  501. package/collection/components/bh-tag/bh-tag.js.map +1 -0
  502. package/collection/components/bh-textarea/bh-textarea.css +115 -0
  503. package/collection/components/bh-textarea/bh-textarea.js +569 -0
  504. package/collection/components/bh-textarea/bh-textarea.js.map +1 -0
  505. package/collection/components/bh-toggle/bh-toggle.css +290 -0
  506. package/collection/components/bh-toggle/bh-toggle.js +369 -0
  507. package/collection/components/bh-toggle/bh-toggle.js.map +1 -0
  508. package/collection/components/bh-tooltip/bh-tooltip.css +88 -0
  509. package/collection/components/bh-tooltip/bh-tooltip.js +162 -0
  510. package/collection/components/bh-tooltip/bh-tooltip.js.map +1 -0
  511. package/collection/components/bh-trend-chart/bh-trend-chart.css +299 -0
  512. package/collection/components/bh-trend-chart/bh-trend-chart.js +256 -0
  513. package/collection/components/bh-trend-chart/bh-trend-chart.js.map +1 -0
  514. package/collection/index.js +22 -0
  515. package/collection/index.js.map +1 -0
  516. package/collection/utils/form.js +68 -0
  517. package/collection/utils/form.js.map +1 -0
  518. package/components/bh-accordion-item.d.ts +11 -0
  519. package/components/bh-accordion-item.js +111 -0
  520. package/components/bh-accordion-item.js.map +1 -0
  521. package/components/bh-accordion.d.ts +11 -0
  522. package/components/bh-accordion.js +147 -0
  523. package/components/bh-accordion.js.map +1 -0
  524. package/components/bh-appbar.d.ts +11 -0
  525. package/components/bh-appbar.js +128 -0
  526. package/components/bh-appbar.js.map +1 -0
  527. package/components/bh-autocomplete-menu.d.ts +11 -0
  528. package/components/bh-autocomplete-menu.js +9 -0
  529. package/components/bh-autocomplete-menu.js.map +1 -0
  530. package/components/bh-avatar-add.d.ts +11 -0
  531. package/components/bh-avatar-add.js +9 -0
  532. package/components/bh-avatar-add.js.map +1 -0
  533. package/components/bh-avatar-stacked.d.ts +11 -0
  534. package/components/bh-avatar-stacked.js +141 -0
  535. package/components/bh-avatar-stacked.js.map +1 -0
  536. package/components/bh-avatar.d.ts +11 -0
  537. package/components/bh-avatar.js +9 -0
  538. package/components/bh-avatar.js.map +1 -0
  539. package/components/bh-badge-dot.d.ts +11 -0
  540. package/components/bh-badge-dot.js +9 -0
  541. package/components/bh-badge-dot.js.map +1 -0
  542. package/components/bh-badge.d.ts +11 -0
  543. package/components/bh-badge.js +9 -0
  544. package/components/bh-badge.js.map +1 -0
  545. package/components/bh-bar-chart.d.ts +11 -0
  546. package/components/bh-bar-chart.js +205 -0
  547. package/components/bh-bar-chart.js.map +1 -0
  548. package/components/bh-breadcrumbs.d.ts +11 -0
  549. package/components/bh-breadcrumbs.js +9 -0
  550. package/components/bh-breadcrumbs.js.map +1 -0
  551. package/components/bh-button-icon.d.ts +11 -0
  552. package/components/bh-button-icon.js +9 -0
  553. package/components/bh-button-icon.js.map +1 -0
  554. package/components/bh-button.d.ts +11 -0
  555. package/components/bh-button.js +9 -0
  556. package/components/bh-button.js.map +1 -0
  557. package/components/bh-card-footer.d.ts +11 -0
  558. package/components/bh-card-footer.js +9 -0
  559. package/components/bh-card-footer.js.map +1 -0
  560. package/components/bh-card-header.d.ts +11 -0
  561. package/components/bh-card-header.js +9 -0
  562. package/components/bh-card-header.js.map +1 -0
  563. package/components/bh-card.d.ts +11 -0
  564. package/components/bh-card.js +9 -0
  565. package/components/bh-card.js.map +1 -0
  566. package/components/bh-chart-tooltip.d.ts +11 -0
  567. package/components/bh-chart-tooltip.js +9 -0
  568. package/components/bh-chart-tooltip.js.map +1 -0
  569. package/components/bh-checkbox-group-item.d.ts +11 -0
  570. package/components/bh-checkbox-group-item.js +9 -0
  571. package/components/bh-checkbox-group-item.js.map +1 -0
  572. package/components/bh-checkbox-group.d.ts +11 -0
  573. package/components/bh-checkbox-group.js +9 -0
  574. package/components/bh-checkbox-group.js.map +1 -0
  575. package/components/bh-checkbox.d.ts +11 -0
  576. package/components/bh-checkbox.js +9 -0
  577. package/components/bh-checkbox.js.map +1 -0
  578. package/components/bh-container-footer.d.ts +11 -0
  579. package/components/bh-container-footer.js +74 -0
  580. package/components/bh-container-footer.js.map +1 -0
  581. package/components/bh-container.d.ts +11 -0
  582. package/components/bh-container.js +49 -0
  583. package/components/bh-container.js.map +1 -0
  584. package/components/bh-data-grid.d.ts +11 -0
  585. package/components/bh-data-grid.js +9 -0
  586. package/components/bh-data-grid.js.map +1 -0
  587. package/components/bh-date-picker-content.d.ts +11 -0
  588. package/components/bh-date-picker-content.js +9 -0
  589. package/components/bh-date-picker-content.js.map +1 -0
  590. package/components/bh-date-picker.d.ts +11 -0
  591. package/components/bh-date-picker.js +9 -0
  592. package/components/bh-date-picker.js.map +1 -0
  593. package/components/bh-date-range-picker-content.d.ts +11 -0
  594. package/components/bh-date-range-picker-content.js +9 -0
  595. package/components/bh-date-range-picker-content.js.map +1 -0
  596. package/components/bh-date-range-picker.d.ts +11 -0
  597. package/components/bh-date-range-picker.js +269 -0
  598. package/components/bh-date-range-picker.js.map +1 -0
  599. package/components/bh-dropdown-menu.d.ts +11 -0
  600. package/components/bh-dropdown-menu.js +9 -0
  601. package/components/bh-dropdown-menu.js.map +1 -0
  602. package/components/bh-dropdown.d.ts +11 -0
  603. package/components/bh-dropdown.js +9 -0
  604. package/components/bh-dropdown.js.map +1 -0
  605. package/components/bh-empty-state.d.ts +11 -0
  606. package/components/bh-empty-state.js +9 -0
  607. package/components/bh-empty-state.js.map +1 -0
  608. package/components/bh-featured-icon.d.ts +11 -0
  609. package/components/bh-featured-icon.js +9 -0
  610. package/components/bh-featured-icon.js.map +1 -0
  611. package/components/bh-illustrations.d.ts +11 -0
  612. package/components/bh-illustrations.js +92 -0
  613. package/components/bh-illustrations.js.map +1 -0
  614. package/components/bh-input-autocomplete.d.ts +11 -0
  615. package/components/bh-input-autocomplete.js +433 -0
  616. package/components/bh-input-autocomplete.js.map +1 -0
  617. package/components/bh-input-number.d.ts +11 -0
  618. package/components/bh-input-number.js +370 -0
  619. package/components/bh-input-number.js.map +1 -0
  620. package/components/bh-input-password.d.ts +11 -0
  621. package/components/bh-input-password.js +229 -0
  622. package/components/bh-input-password.js.map +1 -0
  623. package/components/bh-input-text.d.ts +11 -0
  624. package/components/bh-input-text.js +9 -0
  625. package/components/bh-input-text.js.map +1 -0
  626. package/components/bh-input-verification.d.ts +11 -0
  627. package/components/bh-input-verification.js +255 -0
  628. package/components/bh-input-verification.js.map +1 -0
  629. package/components/bh-label.d.ts +11 -0
  630. package/components/bh-label.js +9 -0
  631. package/components/bh-label.js.map +1 -0
  632. package/components/bh-loader-spinner.d.ts +11 -0
  633. package/components/bh-loader-spinner.js +9 -0
  634. package/components/bh-loader-spinner.js.map +1 -0
  635. package/components/bh-logo-box.d.ts +11 -0
  636. package/components/bh-logo-box.js +9 -0
  637. package/components/bh-logo-box.js.map +1 -0
  638. package/components/bh-modal-actions.d.ts +11 -0
  639. package/components/bh-modal-actions.js +105 -0
  640. package/components/bh-modal-actions.js.map +1 -0
  641. package/components/bh-modal-header.d.ts +11 -0
  642. package/components/bh-modal-header.js +119 -0
  643. package/components/bh-modal-header.js.map +1 -0
  644. package/components/bh-modal.d.ts +11 -0
  645. package/components/bh-modal.js +9 -0
  646. package/components/bh-modal.js.map +1 -0
  647. package/components/bh-month-picker-content.d.ts +11 -0
  648. package/components/bh-month-picker-content.js +9 -0
  649. package/components/bh-month-picker-content.js.map +1 -0
  650. package/components/bh-month-picker.d.ts +11 -0
  651. package/components/bh-month-picker.js +233 -0
  652. package/components/bh-month-picker.js.map +1 -0
  653. package/components/bh-nav-item.d.ts +11 -0
  654. package/components/bh-nav-item.js +9 -0
  655. package/components/bh-nav-item.js.map +1 -0
  656. package/components/bh-notification.d.ts +11 -0
  657. package/components/bh-notification.js +175 -0
  658. package/components/bh-notification.js.map +1 -0
  659. package/components/bh-page-navigation-child.d.ts +11 -0
  660. package/components/bh-page-navigation-child.js +9 -0
  661. package/components/bh-page-navigation-child.js.map +1 -0
  662. package/components/bh-page-navigation-multi-level.d.ts +11 -0
  663. package/components/bh-page-navigation-multi-level.js +9 -0
  664. package/components/bh-page-navigation-multi-level.js.map +1 -0
  665. package/components/bh-page-navigation-single-level.d.ts +11 -0
  666. package/components/bh-page-navigation-single-level.js +9 -0
  667. package/components/bh-page-navigation-single-level.js.map +1 -0
  668. package/components/bh-page-navigation.d.ts +11 -0
  669. package/components/bh-page-navigation.js +129 -0
  670. package/components/bh-page-navigation.js.map +1 -0
  671. package/components/bh-picker-menu.d.ts +11 -0
  672. package/components/bh-picker-menu.js +9 -0
  673. package/components/bh-picker-menu.js.map +1 -0
  674. package/components/bh-pie-chart.d.ts +11 -0
  675. package/components/bh-pie-chart.js +194 -0
  676. package/components/bh-pie-chart.js.map +1 -0
  677. package/components/bh-popover.d.ts +11 -0
  678. package/components/bh-popover.js +131 -0
  679. package/components/bh-popover.js.map +1 -0
  680. package/components/bh-product-switcher.d.ts +11 -0
  681. package/components/bh-product-switcher.js +9 -0
  682. package/components/bh-product-switcher.js.map +1 -0
  683. package/components/bh-property-switcher.d.ts +11 -0
  684. package/components/bh-property-switcher.js +261 -0
  685. package/components/bh-property-switcher.js.map +1 -0
  686. package/components/bh-radio-button.d.ts +11 -0
  687. package/components/bh-radio-button.js +9 -0
  688. package/components/bh-radio-button.js.map +1 -0
  689. package/components/bh-sidebar.d.ts +11 -0
  690. package/components/bh-sidebar.js +195 -0
  691. package/components/bh-sidebar.js.map +1 -0
  692. package/components/bh-skeleton-loader.d.ts +11 -0
  693. package/components/bh-skeleton-loader.js +59 -0
  694. package/components/bh-skeleton-loader.js.map +1 -0
  695. package/components/bh-tab-item.d.ts +11 -0
  696. package/components/bh-tab-item.js +80 -0
  697. package/components/bh-tab-item.js.map +1 -0
  698. package/components/bh-tabs.d.ts +11 -0
  699. package/components/bh-tabs.js +78 -0
  700. package/components/bh-tabs.js.map +1 -0
  701. package/components/bh-tag.d.ts +11 -0
  702. package/components/bh-tag.js +9 -0
  703. package/components/bh-tag.js.map +1 -0
  704. package/components/bh-textarea.d.ts +11 -0
  705. package/components/bh-textarea.js +207 -0
  706. package/components/bh-textarea.js.map +1 -0
  707. package/components/bh-toggle.d.ts +11 -0
  708. package/components/bh-toggle.js +9 -0
  709. package/components/bh-toggle.js.map +1 -0
  710. package/components/bh-tooltip.d.ts +11 -0
  711. package/components/bh-tooltip.js +9 -0
  712. package/components/bh-tooltip.js.map +1 -0
  713. package/components/bh-trend-chart.d.ts +11 -0
  714. package/components/bh-trend-chart.js +149 -0
  715. package/components/bh-trend-chart.js.map +1 -0
  716. package/components/index.d.ts +33 -0
  717. package/components/index.js +16 -0
  718. package/components/index.js.map +1 -0
  719. package/components/p-2KjdCYlS.js +59 -0
  720. package/components/p-2KjdCYlS.js.map +1 -0
  721. package/components/p-54wXxbeh.js +213 -0
  722. package/components/p-54wXxbeh.js.map +1 -0
  723. package/components/p-9a7sQzad.js +1463 -0
  724. package/components/p-9a7sQzad.js.map +1 -0
  725. package/components/p-B3doeS-4.js +158 -0
  726. package/components/p-B3doeS-4.js.map +1 -0
  727. package/components/p-B4TBDBoW.js +71 -0
  728. package/components/p-B4TBDBoW.js.map +1 -0
  729. package/components/p-BBenNW93.js +184 -0
  730. package/components/p-BBenNW93.js.map +1 -0
  731. package/components/p-BLRNfy0t.js +84 -0
  732. package/components/p-BLRNfy0t.js.map +1 -0
  733. package/components/p-BYhYSIIs.js +941 -0
  734. package/components/p-BYhYSIIs.js.map +1 -0
  735. package/components/p-Bbo_Dwmk.js +70 -0
  736. package/components/p-Bbo_Dwmk.js.map +1 -0
  737. package/components/p-BdcGkck5.js +72 -0
  738. package/components/p-BdcGkck5.js.map +1 -0
  739. package/components/p-Bk8GbEQp.js +132 -0
  740. package/components/p-Bk8GbEQp.js.map +1 -0
  741. package/components/p-CDPKBnfQ.js +92 -0
  742. package/components/p-CDPKBnfQ.js.map +1 -0
  743. package/components/p-CDgBIIbC.js +224 -0
  744. package/components/p-CDgBIIbC.js.map +1 -0
  745. package/components/p-CErNA5c8.js +204 -0
  746. package/components/p-CErNA5c8.js.map +1 -0
  747. package/components/p-CQBqn1IO.js +67 -0
  748. package/components/p-CQBqn1IO.js.map +1 -0
  749. package/components/p-CTjPiCcp.js +51 -0
  750. package/components/p-CTjPiCcp.js.map +1 -0
  751. package/components/p-CciWcvHP.js +123 -0
  752. package/components/p-CciWcvHP.js.map +1 -0
  753. package/components/p-CiQqgc-m.js +434 -0
  754. package/components/p-CiQqgc-m.js.map +1 -0
  755. package/components/p-CsRNKalM.js +166 -0
  756. package/components/p-CsRNKalM.js.map +1 -0
  757. package/components/p-CuVsQ9St.js +123 -0
  758. package/components/p-CuVsQ9St.js.map +1 -0
  759. package/components/p-D3OkBDd3.js +100 -0
  760. package/components/p-D3OkBDd3.js.map +1 -0
  761. package/components/p-D6cM-mvE.js +64 -0
  762. package/components/p-D6cM-mvE.js.map +1 -0
  763. package/components/p-D6kh9oF2.js +70 -0
  764. package/components/p-D6kh9oF2.js.map +1 -0
  765. package/components/p-DHSWIF-h.js +214 -0
  766. package/components/p-DHSWIF-h.js.map +1 -0
  767. package/components/p-DNhCX5eS.js +153 -0
  768. package/components/p-DNhCX5eS.js.map +1 -0
  769. package/components/p-DRGkYX1u.js +78 -0
  770. package/components/p-DRGkYX1u.js.map +1 -0
  771. package/components/p-DRJW4zBc.js +58 -0
  772. package/components/p-DRJW4zBc.js.map +1 -0
  773. package/components/p-DTgHvmlL.js +149 -0
  774. package/components/p-DTgHvmlL.js.map +1 -0
  775. package/components/p-DVhHZCku.js +220 -0
  776. package/components/p-DVhHZCku.js.map +1 -0
  777. package/components/p-DWpdUpK5.js +264 -0
  778. package/components/p-DWpdUpK5.js.map +1 -0
  779. package/components/p-D_DKZMpk.js +78 -0
  780. package/components/p-D_DKZMpk.js.map +1 -0
  781. package/components/p-Dbl0HXBJ.js +241 -0
  782. package/components/p-Dbl0HXBJ.js.map +1 -0
  783. package/components/p-DecYIvq4.js +124 -0
  784. package/components/p-DecYIvq4.js.map +1 -0
  785. package/components/p-DfXkVfrE.js +129 -0
  786. package/components/p-DfXkVfrE.js.map +1 -0
  787. package/components/p-HEcFS8Jc.js +125 -0
  788. package/components/p-HEcFS8Jc.js.map +1 -0
  789. package/components/p-MIbEYjCv.js +142 -0
  790. package/components/p-MIbEYjCv.js.map +1 -0
  791. package/components/p-NXL0pYS_.js +97 -0
  792. package/components/p-NXL0pYS_.js.map +1 -0
  793. package/components/p-X9MH3dtg.js +154 -0
  794. package/components/p-X9MH3dtg.js.map +1 -0
  795. package/components/p-YJm8-pxX.js +118 -0
  796. package/components/p-YJm8-pxX.js.map +1 -0
  797. package/components/p-ghuDbZwh.js +148 -0
  798. package/components/p-ghuDbZwh.js.map +1 -0
  799. package/components/p-p8W0xKpn.js +106 -0
  800. package/components/p-p8W0xKpn.js.map +1 -0
  801. package/esm/bellhop-core.js +21 -0
  802. package/esm/bellhop-core.js.map +1 -0
  803. package/esm/bh-accordion-item.entry.js +80 -0
  804. package/esm/bh-accordion-item.entry.js.map +1 -0
  805. package/esm/bh-accordion.entry.js +117 -0
  806. package/esm/bh-accordion.entry.js.map +1 -0
  807. package/esm/bh-appbar.entry.js +81 -0
  808. package/esm/bh-appbar.entry.js.map +1 -0
  809. package/esm/bh-autocomplete-menu.bh-tag.entry.js.map +1 -0
  810. package/esm/bh-autocomplete-menu_2.entry.js +174 -0
  811. package/esm/bh-avatar-add.entry.js +73 -0
  812. package/esm/bh-avatar-add.entry.js.map +1 -0
  813. package/esm/bh-avatar-stacked.entry.js +92 -0
  814. package/esm/bh-avatar-stacked.entry.js.map +1 -0
  815. package/esm/bh-avatar.entry.js +91 -0
  816. package/esm/bh-avatar.entry.js.map +1 -0
  817. package/esm/bh-badge-dot.bh-breadcrumbs.entry.js.map +1 -0
  818. package/esm/bh-badge-dot_2.entry.js +131 -0
  819. package/esm/bh-badge.entry.js +69 -0
  820. package/esm/bh-badge.entry.js.map +1 -0
  821. package/esm/bh-bar-chart.entry.js +162 -0
  822. package/esm/bh-bar-chart.entry.js.map +1 -0
  823. package/esm/bh-button-CBZGiLVh.js +115 -0
  824. package/esm/bh-button-CBZGiLVh.js.map +1 -0
  825. package/esm/bh-button-icon.entry.js +72 -0
  826. package/esm/bh-button-icon.entry.js.map +1 -0
  827. package/esm/bh-button.bh-loader-spinner.entry.js.map +1 -0
  828. package/esm/bh-button_2.entry.js +44 -0
  829. package/esm/bh-card-footer.entry.js +28 -0
  830. package/esm/bh-card-footer.entry.js.map +1 -0
  831. package/esm/bh-card-header.entry.js +72 -0
  832. package/esm/bh-card-header.entry.js.map +1 -0
  833. package/esm/bh-card.entry.js +46 -0
  834. package/esm/bh-card.entry.js.map +1 -0
  835. package/esm/bh-chart-tooltip.entry.js +55 -0
  836. package/esm/bh-chart-tooltip.entry.js.map +1 -0
  837. package/esm/bh-checkbox-group-item.entry.js +140 -0
  838. package/esm/bh-checkbox-group-item.entry.js.map +1 -0
  839. package/esm/bh-checkbox-group.entry.js +98 -0
  840. package/esm/bh-checkbox-group.entry.js.map +1 -0
  841. package/esm/bh-checkbox.entry.js +142 -0
  842. package/esm/bh-checkbox.entry.js.map +1 -0
  843. package/esm/bh-container-footer.entry.js +36 -0
  844. package/esm/bh-container-footer.entry.js.map +1 -0
  845. package/esm/bh-container.entry.js +24 -0
  846. package/esm/bh-container.entry.js.map +1 -0
  847. package/esm/bh-data-grid.entry.js +810 -0
  848. package/esm/bh-data-grid.entry.js.map +1 -0
  849. package/esm/bh-date-picker-content.bh-picker-menu.entry.js.map +1 -0
  850. package/esm/bh-date-picker-content_2.entry.js +522 -0
  851. package/esm/bh-date-picker.bh-empty-state.entry.js.map +1 -0
  852. package/esm/bh-date-picker_2.entry.js +249 -0
  853. package/esm/bh-date-range-picker-content.entry.js +149 -0
  854. package/esm/bh-date-range-picker-content.entry.js.map +1 -0
  855. package/esm/bh-date-range-picker.entry.js +165 -0
  856. package/esm/bh-date-range-picker.entry.js.map +1 -0
  857. package/esm/bh-dropdown-menu.entry.js +112 -0
  858. package/esm/bh-dropdown-menu.entry.js.map +1 -0
  859. package/esm/bh-dropdown.bh-logo-box.bh-nav-item.entry.js.map +1 -0
  860. package/esm/bh-dropdown_3.entry.js +303 -0
  861. package/esm/bh-featured-icon.entry.js +39 -0
  862. package/esm/bh-featured-icon.entry.js.map +1 -0
  863. package/esm/bh-illustrations.entry.js +63 -0
  864. package/esm/bh-illustrations.entry.js.map +1 -0
  865. package/esm/bh-input-autocomplete.entry.js +340 -0
  866. package/esm/bh-input-autocomplete.entry.js.map +1 -0
  867. package/esm/bh-input-number.entry.js +305 -0
  868. package/esm/bh-input-number.entry.js.map +1 -0
  869. package/esm/bh-input-password.entry.js +180 -0
  870. package/esm/bh-input-password.entry.js.map +1 -0
  871. package/esm/bh-input-text.entry.js +190 -0
  872. package/esm/bh-input-text.entry.js.map +1 -0
  873. package/esm/bh-input-verification.entry.js +201 -0
  874. package/esm/bh-input-verification.entry.js.map +1 -0
  875. package/esm/bh-label-DqsVrCg_.js +108 -0
  876. package/esm/bh-label-DqsVrCg_.js.map +1 -0
  877. package/esm/bh-label.bh-tooltip.entry.js.map +1 -0
  878. package/esm/bh-label_2.entry.js +45 -0
  879. package/esm/bh-modal-actions.entry.js +64 -0
  880. package/esm/bh-modal-actions.entry.js.map +1 -0
  881. package/esm/bh-modal-header.entry.js +74 -0
  882. package/esm/bh-modal-header.entry.js.map +1 -0
  883. package/esm/bh-modal.entry.js +54 -0
  884. package/esm/bh-modal.entry.js.map +1 -0
  885. package/esm/bh-month-picker-content.entry.js +187 -0
  886. package/esm/bh-month-picker-content.entry.js.map +1 -0
  887. package/esm/bh-month-picker.entry.js +150 -0
  888. package/esm/bh-month-picker.entry.js.map +1 -0
  889. package/esm/bh-notification.entry.js +126 -0
  890. package/esm/bh-notification.entry.js.map +1 -0
  891. package/esm/bh-page-navigation-child.entry.js +46 -0
  892. package/esm/bh-page-navigation-child.entry.js.map +1 -0
  893. package/esm/bh-page-navigation-multi-level.bh-page-navigation-single-level.entry.js.map +1 -0
  894. package/esm/bh-page-navigation-multi-level_2.entry.js +143 -0
  895. package/esm/bh-page-navigation.entry.js +70 -0
  896. package/esm/bh-page-navigation.entry.js.map +1 -0
  897. package/esm/bh-pie-chart.entry.js +155 -0
  898. package/esm/bh-pie-chart.entry.js.map +1 -0
  899. package/esm/bh-popover.entry.js +98 -0
  900. package/esm/bh-popover.entry.js.map +1 -0
  901. package/esm/bh-product-switcher.entry.js +100 -0
  902. package/esm/bh-product-switcher.entry.js.map +1 -0
  903. package/esm/bh-property-switcher.entry.js +229 -0
  904. package/esm/bh-property-switcher.entry.js.map +1 -0
  905. package/esm/bh-radio-button.entry.js +122 -0
  906. package/esm/bh-radio-button.entry.js.map +1 -0
  907. package/esm/bh-sidebar.entry.js +108 -0
  908. package/esm/bh-sidebar.entry.js.map +1 -0
  909. package/esm/bh-skeleton-loader.entry.js +32 -0
  910. package/esm/bh-skeleton-loader.entry.js.map +1 -0
  911. package/esm/bh-tab-item.entry.js +52 -0
  912. package/esm/bh-tab-item.entry.js.map +1 -0
  913. package/esm/bh-tabs.entry.js +50 -0
  914. package/esm/bh-tabs.entry.js.map +1 -0
  915. package/esm/bh-textarea.entry.js +159 -0
  916. package/esm/bh-textarea.entry.js.map +1 -0
  917. package/esm/bh-toggle.entry.js +139 -0
  918. package/esm/bh-toggle.entry.js.map +1 -0
  919. package/esm/bh-trend-chart.entry.js +119 -0
  920. package/esm/bh-trend-chart.entry.js.map +1 -0
  921. package/esm/form-CPgx0iFq.js +59 -0
  922. package/esm/form-CPgx0iFq.js.map +1 -0
  923. package/esm/index-DtVghh5W.js +1922 -0
  924. package/esm/index-DtVghh5W.js.map +1 -0
  925. package/esm/index.js +15 -0
  926. package/esm/index.js.map +1 -0
  927. package/esm/loader.js +11 -0
  928. package/esm/loader.js.map +1 -0
  929. package/index.cjs.js +1 -0
  930. package/index.js +1 -0
  931. package/loader/cdn.js +1 -0
  932. package/loader/index.cjs.js +1 -0
  933. package/loader/index.d.ts +24 -0
  934. package/loader/index.es2017.js +1 -0
  935. package/loader/index.js +2 -0
  936. package/package.json +32 -0
  937. package/types/components/bh-accordion/bh-accordion.d.ts +42 -0
  938. package/types/components/bh-accordion-item/bh-accordion-item.d.ts +41 -0
  939. package/types/components/bh-appbar/bh-appbar.d.ts +54 -0
  940. package/types/components/bh-autocomplete-menu/bh-autocomplete-menu.d.ts +54 -0
  941. package/types/components/bh-avatar/bh-avatar.d.ts +43 -0
  942. package/types/components/bh-avatar-add/bh-avatar-add.d.ts +35 -0
  943. package/types/components/bh-avatar-stacked/bh-avatar-stacked.d.ts +42 -0
  944. package/types/components/bh-badge/bh-badge.d.ts +40 -0
  945. package/types/components/bh-badge-dot/bh-badge-dot.d.ts +17 -0
  946. package/types/components/bh-bar-chart/bh-bar-chart.d.ts +50 -0
  947. package/types/components/bh-breadcrumbs/bh-breadcrumbs.d.ts +40 -0
  948. package/types/components/bh-button/bh-button.d.ts +57 -0
  949. package/types/components/bh-button-icon/bh-button-icon.d.ts +44 -0
  950. package/types/components/bh-card/bh-card.d.ts +23 -0
  951. package/types/components/bh-card-footer/bh-card-footer.d.ts +12 -0
  952. package/types/components/bh-card-header/bh-card-header.d.ts +59 -0
  953. package/types/components/bh-chart-tooltip/bh-chart-tooltip.d.ts +40 -0
  954. package/types/components/bh-checkbox/bh-checkbox.d.ts +45 -0
  955. package/types/components/bh-checkbox-group/bh-checkbox-group.d.ts +34 -0
  956. package/types/components/bh-checkbox-group-item/bh-checkbox-group-item.d.ts +67 -0
  957. package/types/components/bh-container/bh-container.d.ts +7 -0
  958. package/types/components/bh-container-footer/bh-container-footer.d.ts +18 -0
  959. package/types/components/bh-data-grid/bh-data-grid.d.ts +235 -0
  960. package/types/components/bh-date-picker/bh-date-picker.d.ts +78 -0
  961. package/types/components/bh-date-picker-content/bh-date-picker-content.d.ts +112 -0
  962. package/types/components/bh-date-range-picker/bh-date-range-picker.d.ts +85 -0
  963. package/types/components/bh-date-range-picker-content/bh-date-range-picker-content.d.ts +55 -0
  964. package/types/components/bh-dropdown/bh-dropdown.d.ts +78 -0
  965. package/types/components/bh-dropdown-menu/bh-dropdown-menu.d.ts +51 -0
  966. package/types/components/bh-empty-state/bh-empty-state.d.ts +52 -0
  967. package/types/components/bh-featured-icon/bh-featured-icon.d.ts +22 -0
  968. package/types/components/bh-illustrations/bh-illustrations.d.ts +25 -0
  969. package/types/components/bh-input-autocomplete/bh-input-autocomplete.d.ts +130 -0
  970. package/types/components/bh-input-number/bh-input-number.d.ts +137 -0
  971. package/types/components/bh-input-password/bh-input-password.d.ts +111 -0
  972. package/types/components/bh-input-text/bh-input-text.d.ts +126 -0
  973. package/types/components/bh-input-verification/bh-input-verification.d.ts +79 -0
  974. package/types/components/bh-label/bh-label.d.ts +54 -0
  975. package/types/components/bh-loader-spinner/bh-loader-spinner.d.ts +19 -0
  976. package/types/components/bh-logo-box/bh-logo-box.d.ts +28 -0
  977. package/types/components/bh-modal/bh-modal.d.ts +23 -0
  978. package/types/components/bh-modal-actions/bh-modal-actions.d.ts +38 -0
  979. package/types/components/bh-modal-header/bh-modal-header.d.ts +45 -0
  980. package/types/components/bh-month-picker/bh-month-picker.d.ts +73 -0
  981. package/types/components/bh-month-picker-content/bh-month-picker-content.d.ts +77 -0
  982. package/types/components/bh-notification/bh-notification.d.ts +51 -0
  983. package/types/components/bh-page-navigation/bh-page-navigation.d.ts +45 -0
  984. package/types/components/bh-page-navigation-child/bh-page-navigation-child.d.ts +26 -0
  985. package/types/components/bh-page-navigation-multi-level/bh-page-navigation-multi-level.d.ts +60 -0
  986. package/types/components/bh-page-navigation-single-level/bh-page-navigation-single-level.d.ts +22 -0
  987. package/types/components/bh-picker-menu/bh-picker-menu.d.ts +76 -0
  988. package/types/components/bh-pie-chart/bh-pie-chart.d.ts +50 -0
  989. package/types/components/bh-popover/bh-popover.d.ts +60 -0
  990. package/types/components/bh-product-switcher/bh-product-switcher.d.ts +40 -0
  991. package/types/components/bh-property-switcher/bh-property-switcher.d.ts +63 -0
  992. package/types/components/bh-radio-button/bh-radio-button.d.ts +56 -0
  993. package/types/components/bh-sidebar/bh-nav-item.d.ts +26 -0
  994. package/types/components/bh-sidebar/bh-sidebar.d.ts +70 -0
  995. package/types/components/bh-skeleton-loader/bh-skeleton-loader.d.ts +15 -0
  996. package/types/components/bh-tab-item/bh-tab-item.d.ts +29 -0
  997. package/types/components/bh-tabs/bh-tabs.d.ts +30 -0
  998. package/types/components/bh-tag/bh-tag.d.ts +25 -0
  999. package/types/components/bh-textarea/bh-textarea.d.ts +101 -0
  1000. package/types/components/bh-toggle/bh-toggle.d.ts +66 -0
  1001. package/types/components/bh-tooltip/bh-tooltip.d.ts +25 -0
  1002. package/types/components/bh-trend-chart/bh-trend-chart.d.ts +34 -0
  1003. package/types/components.d.ts +7199 -0
  1004. package/types/index.d.ts +12 -0
  1005. package/types/stencil-public-runtime.d.ts +1756 -0
  1006. package/types/utils/form.d.ts +39 -0
@@ -0,0 +1 @@
1
+ {"file":"p-BYhYSIIs.js","mappings":";;;;;;;;;;;;;;AAAA,MAAM,aAAa,GAAG,8oSAA8oS;;MC+GvpS,UAAU,iBAAAA,kBAAA,CAAA,MAAA,UAAA,SAAAC,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;IAQb,IAAI,GAAc,EAAE;;IAGpB,OAAO,GAAqB,EAAE;;IAG9B,MAAM,GAAW,IAAI;;;;;IAOrB,eAAe,GAAY,KAAK;;IAGhC,aAAa,GAA0B,UAAU;;IAGhC,YAAY,GAAwB,EAAE;;;;;IAOvD,aAAa,GAAY,IAAI;;IAG7B,SAAS,GAAY,KAAK;;IAGT,SAAS,GAAwB,EAAE;;;;;IAOpD,eAAe,GAAY,KAAK;;IAGhC,aAAa,GAAY,KAAK;;IAGb,WAAW,GAA0B,EAAE;;;;;IAOxD,cAAc,GAAY,KAAK;;IAG/B,OAAO,GAAa,EAAE;;;;;IAOtB,aAAa,GAAY,KAAK;;IAG9B,QAAQ,GAAqB,MAAM;;IAGnC,eAAe,GAAY,IAAI;;;;;IAO/B,UAAU,GAAY,IAAI;;IAG1B,cAAc,GAAY,IAAI;;IAG9B,OAAO,GAAY,KAAK;;IAGxB,OAAO,GAAY,KAAK;;IAGxB,YAAY,GAAW,mBAAmB;;IAG1C,OAAO,GAAY,KAAK;;;;AAMvB,IAAA,oBAAoB,GAAyB,IAAI,GAAG,EAAE;IACtD,iBAAiB,GAAwB,EAAE;IAC3C,mBAAmB,GAA0B,EAAE;IAC/C,cAAc,GAAa,EAAE;IAC7B,eAAe,GAAkB,IAAI;IACrC,iBAAiB,GAA2B,EAAE;;IAG9C,aAAa,GAA2B,IAAI;IAC5C,eAAe,GAAkB,IAAI;IACrC,aAAa,GAA4B,EAAE;IAC3C,aAAa,GAAY,KAAK;;IAG9B,kBAAkB,GAAkB,IAAI;;;;;AAOxC,IAAA,iBAAiB;;AAGjB,IAAA,YAAY;;AAGZ,IAAA,cAAc;;AAGd,IAAA,UAAU;;AAGV,IAAA,WAAW;;AAGX,IAAA,aAAa;;AAGb,IAAA,WAAW;;AAGX,IAAA,YAAY;;AAGZ,IAAA,UAAU;;AAGV,IAAA,YAAY;;;;AAOrB,IAAA,wBAAwB,CAAC,QAA6B,EAAA;QACpD,IAAI,CAAC,oBAAoB,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC;;AAI/C,IAAA,qBAAqB,CAAC,QAA6B,EAAA;AACjD,QAAA,IAAI,CAAC,iBAAiB,GAAG,CAAC,GAAG,QAAQ,CAAC;;AAIxC,IAAA,uBAAuB,CAAC,QAA+B,EAAA;AACrD,QAAA,IAAI,CAAC,mBAAmB,GAAG,CAAC,GAAG,QAAQ,CAAC;;;;;IAO1C,iBAAiB,GAAA;QACf,IAAI,CAAC,oBAAoB,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;QACtD,IAAI,CAAC,iBAAiB,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;QAC5C,IAAI,CAAC,mBAAmB,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC;;;;;IAO1C,SAAS,CAAC,GAAY,EAAE,KAAa,EAAA;AAC3C,QAAA,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,KAAK,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,GAAG,EAAE;AACjE,YAAA,OAAQ,GAA+B,CAAC,IAAI,CAAC,MAAM,CAAoB;;AAEzE,QAAA,OAAO,KAAK;;IAGN,YAAY,CAAC,GAAY,EAAE,QAAgB,EAAA;AACjD,QAAA,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,KAAK,IAAI;AAAE,YAAA,OAAO,SAAS;;QAG7D,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC;QAChC,IAAI,KAAK,GAAY,GAAG;AAExB,QAAA,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;AACtB,YAAA,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,GAAG,IAAI,KAAK,EAAE;AAC/D,gBAAA,KAAK,GAAI,KAAiC,CAAC,GAAG,CAAC;;iBAC1C;AACL,gBAAA,OAAO,SAAS;;;AAIpB,QAAA,OAAO,KAAK;;IAGN,iBAAiB,GAAA;AACvB,QAAA,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,IAAI,GAAG,CAAC,OAAO,KAAK,KAAK,CAAC;;;;;IAOlD,gBAAgB,GAAA;QACtB,IAAI,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;;AAGlC,QAAA,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,mBAAmB,CAAC,MAAM,GAAG,CAAC,EAAE;AAC/D,YAAA,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;;;AAIlD,QAAA,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE;AAC3D,YAAA,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;;AAGlD,QAAA,OAAO,aAAa;;AAGd,IAAA,YAAY,CAAC,IAAe,EAAA;AAClC,QAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,IAAG;YACvB,OAAO,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,IAAG;gBAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,QAAQ,CAAC;AAC/D,gBAAA,IAAI,CAAC,MAAM;AAAE,oBAAA,OAAO,IAAI;AAExB,gBAAA,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAkB,CAAC;AAC/D,gBAAA,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;AACvD,aAAC,CAAC;AACJ,SAAC,CAAC;;AAGI,IAAA,aAAa,CAAC,KAAc,EAAE,MAA2B,EAAE,IAAyB,EAAA;AAC1F,QAAA,IAAI,MAAM,CAAC,QAAQ,KAAK,SAAS,EAAE;YACjC,OAAO,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,EAAE;;AAE9D,QAAA,IAAI,MAAM,CAAC,QAAQ,KAAK,YAAY,EAAE;YACpC,OAAO,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,EAAE;;AAG9D,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK;AAEhC,QAAA,IAAI,IAAI,KAAK,QAAQ,EAAE;AACrB,YAAA,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC;AAC9B,YAAA,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAAC;AAErC,YAAA,QAAQ,MAAM,CAAC,QAAQ;AACrB,gBAAA,KAAK,QAAQ,EAAE,OAAO,QAAQ,KAAK,SAAS;AAC5C,gBAAA,KAAK,aAAa,EAAE,OAAO,QAAQ,GAAG,SAAS;AAC/C,gBAAA,KAAK,UAAU,EAAE,OAAO,QAAQ,GAAG,SAAS;AAC5C,gBAAA,KAAK,oBAAoB,EAAE,OAAO,QAAQ,IAAI,SAAS;AACvD,gBAAA,KAAK,iBAAiB,EAAE,OAAO,QAAQ,IAAI,SAAS;AACpD,gBAAA,KAAK,SAAS,EAAE,OAAO,QAAQ,IAAI,SAAS,IAAI,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC;AAClF,gBAAA,SAAS,OAAO,IAAI;;;AAIxB,QAAA,IAAI,IAAI,KAAK,MAAM,EAAE;YACnB,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,KAAe,CAAC,CAAC,OAAO,EAAE;YACrD,MAAM,UAAU,GAAG,IAAI,IAAI,CAAC,WAAqB,CAAC,CAAC,OAAO,EAAE;AAE5D,YAAA,QAAQ,MAAM,CAAC,QAAQ;AACrB,gBAAA,KAAK,QAAQ,EAAE,OAAO,SAAS,KAAK,UAAU;AAC9C,gBAAA,KAAK,aAAa,EAAE,OAAO,SAAS,GAAG,UAAU;AACjD,gBAAA,KAAK,UAAU,EAAE,OAAO,SAAS,GAAG,UAAU;gBAC9C,KAAK,SAAS,EAAE;AACd,oBAAA,MAAM,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,OAAiB,CAAC,CAAC,OAAO,EAAE;AAC3D,oBAAA,OAAO,SAAS,IAAI,UAAU,IAAI,SAAS,IAAI,MAAM;;AAEvD,gBAAA,SAAS,OAAO,IAAI;;;;QAKxB,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE;QAClD,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE;AAEzD,QAAA,QAAQ,MAAM,CAAC,QAAQ;YACrB,KAAK,UAAU,EAAE,OAAO,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC;AACpD,YAAA,KAAK,QAAQ,EAAE,OAAO,QAAQ,KAAK,SAAS;YAC5C,KAAK,YAAY,EAAE,OAAO,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC;YACxD,KAAK,UAAU,EAAE,OAAO,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC;AACpD,YAAA,SAAS,OAAO,IAAI;;;AAIhB,IAAA,YAAY,CAAC,IAAe,EAAA;AAClC,QAAA,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,KAAK,CAAC;AAAE,YAAA,OAAO,IAAI;AAEpD,QAAA,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAI;AAC7B,YAAA,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBACzC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,QAAQ,CAAC;AAC7D,gBAAA,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,SAAS;oBAAE;AAEhC,gBAAA,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,MAAM,CAAC,QAAkB,CAAC;AAC9D,gBAAA,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,MAAM,CAAC,QAAkB,CAAC;gBAE9D,IAAI,UAAU,GAAG,CAAC;AAElB,gBAAA,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,EAAE;AAC5B,oBAAA,UAAU,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;;AACrD,qBAAA,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE;AACjC,oBAAA,UAAU,GAAG,IAAI,IAAI,CAAC,MAAgB,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,MAAgB,CAAC,CAAC,OAAO,EAAE;;qBACnF;AACL,oBAAA,UAAU,GAAG,MAAM,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;;AAGvE,gBAAA,IAAI,UAAU,KAAK,CAAC,EAAE;AACpB,oBAAA,OAAO,IAAI,CAAC,SAAS,KAAK,MAAM,GAAG,CAAC,UAAU,GAAG,UAAU;;;AAG/D,YAAA,OAAO,CAAC;AACV,SAAC,CAAC;;;;;AAOI,IAAA,cAAc,CAAC,IAAe,EAAA;AACpC,QAAA,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;AACrD,YAAA,OAAO,EAAE;;AAGX,QAAA,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;;AAG7C,IAAA,aAAa,CAAC,IAAe,EAAE,QAAgB,EAAE,KAAa,EAAA;AACpE,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC;AACxD,QAAA,IAAI,CAAC,MAAM;AAAE,YAAA,OAAO,EAAE;AAEtB,QAAA,MAAM,MAAM,GAAG,IAAI,GAAG,EAAqB;AAE3C,QAAA,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;AACtB,YAAA,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAkB,CAAC;YAC/D,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,IAAI,SAAS,CAAC;YAEtC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;AACpB,gBAAA,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC;;YAErB,MAAM,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC,IAAI,CAAC,GAAG,CAAC;;QAG5B,MAAM,MAAM,GAAoB,EAAE;QAElC,KAAK,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,MAAM,EAAE;AAChC,YAAA,MAAM,QAAQ,GAAG,CAAA,EAAG,QAAQ,CAAI,CAAA,EAAA,GAAG,EAAE;YACrC,MAAM,CAAC,IAAI,CAAC;AACV,gBAAA,GAAG,EAAE,QAAQ;AACb,gBAAA,KAAK,EAAE,GAAG;AACV,gBAAA,YAAY,EAAE,GAAG;gBACjB,IAAI;gBACJ,KAAK;gBACL,QAAQ;AACT,aAAA,CAAC;;;QAIJ,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;AAEnF,QAAA,OAAO,MAAM;;AAGP,IAAA,iBAAiB,GAAG,CAAC,QAAgB,KAAI;QAC/C,MAAM,mBAAmB,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAElE,IAAI,mBAAmB,EAAE;AACvB,YAAA,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG,IAAI,GAAG,KAAK,QAAQ,CAAC;;aACpE;YACL,IAAI,CAAC,cAAc,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC;;AAG1D,QAAA,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,mBAAmB,EAAE,CAAC;AACvE,KAAC;;;;IAMO,eAAe,GAAG,MAAK;AAC7B,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE;QAC7C,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;AAErE,QAAA,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAE9E,IAAI,aAAa,EAAE;AACjB,YAAA,IAAI,CAAC,oBAAoB,GAAG,IAAI,GAAG,EAAE;;aAChC;YACL,IAAI,CAAC,oBAAoB,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC;;QAG9C,IAAI,CAAC,mBAAmB,EAAE;AAC5B,KAAC;AAEO,IAAA,eAAe,GAAG,CAAC,GAAY,EAAE,QAAgB,KAAI;QAC3D,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,CAAC;AAEzC,QAAA,IAAI,IAAI,CAAC,aAAa,KAAK,QAAQ,EAAE;YACnC,IAAI,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;AACtC,gBAAA,IAAI,CAAC,oBAAoB,GAAG,IAAI,GAAG,EAAE;;iBAChC;gBACL,IAAI,CAAC,oBAAoB,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;;;aAEvC;YACL,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,oBAAoB,CAAC;AACjD,YAAA,IAAI,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;AACnB,gBAAA,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC;;iBACb;AACL,gBAAA,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;;AAEjB,YAAA,IAAI,CAAC,oBAAoB,GAAG,MAAM;;QAGpC,IAAI,CAAC,mBAAmB,EAAE;AAC5B,KAAC;IAEO,mBAAmB,GAAA;QACzB,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC;AAC1D,QAAA,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,KAC3C,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CACtD;AAED,QAAA,IAAI,CAAC,YAAY,GAAG,YAAY;QAChC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC;;IAGrD,iBAAiB,GAAA;AACvB,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE;QAC7C,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACrE,MAAM,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,IAAI,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;QAEtF,OAAO;YACL,YAAY,EAAE,IAAI,CAAC,oBAAoB;YACvC,aAAa,EAAE,aAAa,KAAK,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC;YACrE,eAAe,EAAE,aAAa,GAAG,CAAC,IAAI,aAAa,GAAG,OAAO,CAAC,MAAM;SACrE;;;;;AAOK,IAAA,UAAU,GAAG,CAAC,MAAsB,KAAI;QAC9C,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK;YAAE;QAEtD,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,EAAE,CAAC;QAC/E,IAAI,YAAY,GAA0B,KAAK;QAE/C,IAAI,YAAY,EAAE;AAChB,YAAA,IAAI,YAAY,CAAC,SAAS,KAAK,KAAK,EAAE;gBACpC,YAAY,GAAG,MAAM;;AAChB,iBAAA,IAAI,YAAY,CAAC,SAAS,KAAK,MAAM,EAAE;gBAC5C,YAAY,GAAG,IAAI;;;AAIvB,QAAA,IAAI,YAAiC;AAErC,QAAA,IAAI,IAAI,CAAC,SAAS,EAAE;AAClB,YAAA,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,EAAE,CAAC;YAC3E,IAAI,YAAY,EAAE;AAChB,gBAAA,YAAY,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC;;;aAEhE;YACL,YAAY,GAAG,YAAY,GAAG,CAAC,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,GAAG,EAAE;;AAGvF,QAAA,IAAI,CAAC,iBAAiB,GAAG,YAAY;AACrC,QAAA,IAAI,CAAC,SAAS,GAAG,YAAY;AAC7B,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;AACtC,KAAC;AAEO,IAAA,gBAAgB,CAAC,QAAgB,EAAA;AACvC,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC;AACtE,QAAA,OAAO,IAAI,EAAE,SAAS,IAAI,IAAI;;;;;AAOxB,IAAA,iBAAiB,GAAG,CAAC,MAAsB,EAAE,KAAa,KAAI;AACpE,QAAA,IAAI,CAAC,iBAAiB,GAAG,EAAE,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC,MAAM,CAAC,EAAE,GAAG,KAAK,EAAE;;QAG1E,MAAM,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,EAAE,CAAC;AAErF,QAAA,IAAI,KAAK,CAAC,IAAI,EAAE,EAAE;YAChB,cAAc,CAAC,IAAI,CAAC;gBAClB,QAAQ,EAAE,MAAM,CAAC,EAAE;gBACnB,QAAQ,EAAE,MAAM,CAAC,IAAI,KAAK,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC,IAAI,KAAK,MAAM,GAAG,QAAQ,GAAG,UAAU;AAC9F,gBAAA,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE;AACpB,aAAA,CAAC;;AAGJ,QAAA,IAAI,CAAC,mBAAmB,GAAG,cAAc;AACzC,QAAA,IAAI,CAAC,WAAW,GAAG,cAAc;AACjC,QAAA,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC;AAC1C,KAAC;AAEO,IAAA,mBAAmB,GAAG,CAAC,QAAgB,KAAI;AACjD,QAAA,IAAI,IAAI,CAAC,kBAAkB,KAAK,QAAQ,EAAE;AACxC,YAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI;;aACzB;AACL,YAAA,IAAI,CAAC,kBAAkB,GAAG,QAAQ;;AAEtC,KAAC;;;;AAMO,IAAA,cAAc,GAAG,CAAC,GAAY,EAAE,QAAgB,KAAI;QAC1D,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,CAAC;AAC5C,QAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;AACjD,KAAC;IAEO,eAAe,GAAG,CAAC,GAAY,EAAE,MAAsB,EAAE,QAAgB,EAAE,WAAmB,KAAI;AACxG,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAkB,CAAC;AAC/D,QAAA,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;AACtE,KAAC;;;;IAMO,YAAY,GAAA;QAClB,IAAI,CAAC,IAAI,CAAC,UAAU;AAAE,YAAA,OAAO,IAAI;AAEjC,QAAA,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE;AAC/C,QAAA,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE;AAE/C,QAAA,QACE,WAAK,KAAK,EAAC,sBAAsB,EAAC,IAAI,EAAC,KAAK,EAAA,EACzC,IAAI,CAAC,eAAe,KACnB,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,+CAA+C,EAAC,IAAI,EAAC,cAAc,EAAA,EAC5E,CACE,CAAA,aAAA,EAAA,EAAA,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,cAAc,CAAC,aAAa,EACrC,aAAa,EAAE,cAAc,CAAC,eAAe,EAC7C,UAAU,EAAE,MAAM,IAAI,CAAC,eAAe,EAAE,EACxC,CAAA,CACE,CACP,EACA,cAAc,CAAC,GAAG,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAC1D;;AAIF,IAAA,gBAAgB,CAAC,MAAsB,EAAA;QAC7C,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE,CAAC;QACtD,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK;AAElE,QAAA,MAAM,WAAW,GAAG;AAClB,YAAA,uBAAuB,EAAE,IAAI;AAC7B,YAAA,gCAAgC,EAAE,UAAU;YAC5C,8BAA8B,EAAE,aAAa,KAAK,IAAI;YACtD,CAAC,CAAA,qBAAA,EAAwB,MAAM,CAAC,KAAK,IAAI,MAAM,CAAA,CAAE,GAAG,IAAI;SACzD;AAED,QAAA,MAAM,SAAS,GAAG,MAAM,CAAC;cACrB,EAAE,KAAK,EAAE,OAAO,MAAM,CAAC,KAAK,KAAK,QAAQ,GAAG,CAAG,EAAA,MAAM,CAAC,KAAK,CAAI,EAAA,CAAA,GAAG,MAAM,CAAC,KAAK;cAC9E,EAAE;QAEN,QACE,WACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,SAAS,EAChB,IAAI,EAAC,cAAc,EAAA,WAAA,EACR,aAAa,KAAK,KAAK,GAAG,WAAW,GAAG,aAAa,KAAK,MAAM,GAAG,YAAY,GAAG,MAAM,EACnG,OAAO,EAAE,MAAM,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAA,EAEpD,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,uBAAuB,EAAA,EAChC,MAAM,CAAC,cAAc,GAAG,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CACjE,EACN,UAAU,IAAI,aAAa,KAC1B,CAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAC,+CAA+C,EACxD,EAAA,aAAa,KAAK,KAAK,GAAG,cAAc,GAAG,gBAAgB,CACvD,CACR,CACG;;IAIF,eAAe,GAAA;QACrB,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,aAAa;AAAE,YAAA,OAAO,IAAI;AAE7D,QAAA,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE;QAE/C,QACE,WAAK,KAAK,EAAC,sBAAsB,EAAC,IAAI,EAAC,KAAK,EAAA,EACzC,IAAI,CAAC,eAAe,KACnB,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,+CAA+C,EAAC,IAAI,EAAC,MAAM,GAAG,CAC1E,EACA,cAAc,CAAC,GAAG,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAC1D;;AAIF,IAAA,gBAAgB,CAAC,MAAsB,EAAA;AAC7C,QAAA,IAAI,MAAM,CAAC,UAAU,KAAK,KAAK,EAAE;AAC/B,YAAA,OAAO,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,uBAAuB,EAAC,IAAI,EAAC,MAAM,EAAA,CAAG;;AAG1D,QAAA,MAAM,SAAS,GAAG,MAAM,CAAC;cACrB,EAAE,KAAK,EAAE,OAAO,MAAM,CAAC,KAAK,KAAK,QAAQ,GAAG,CAAG,EAAA,MAAM,CAAC,KAAK,CAAI,EAAA,CAAA,GAAG,MAAM,CAAC,KAAK;cAC9E,EAAE;AAEN,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE;QAC1D,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE;;AAG1C,QAAA,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE;AAC1B,YAAA,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,uBAAuB,EAAC,KAAK,EAAE,SAAS,EAAE,IAAI,EAAC,MAAM,EAAA,EAC9D,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,EAAE,+BAA+B,EAAE,IAAI,EAAE,yBAAyB,EAAE,SAAS,EAAE,EAAA,EACzF,CACE,CAAA,gBAAA,EAAA,EAAA,OAAO,EAAC,gBAAgB,EACxB,WAAW,EAAC,EAAE,EACd,SAAS,EAAE,KAAK,EAChB,UAAU,EAAE,KAAK,EACjB,UAAU,EAAE,CAAC,CAAc,KAAI;AAC7B,oBAAA,MAAM,IAAI,GAAG,CAAC,CAAC,MAAM;oBACrB,IAAI,IAAI,EAAE;AACR,wBAAA,MAAM,OAAO,GAAG,CAAA,EAAG,IAAI,CAAC,IAAI,CAAI,CAAA,EAAA,MAAM,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA,CAAA,EAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE;AAC9G,wBAAA,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,OAAO,CAAC;;yBAClC;AACL,wBAAA,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,EAAE,CAAC;;AAEtC,iBAAC,EACD,CAAA,CACE,CACF;;;AAKV,QAAA,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,uBAAuB,EAAC,KAAK,EAAE,SAAS,EAAE,IAAI,EAAC,MAAM,EAAA,EAC9D,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,EAAE,+BAA+B,EAAE,IAAI,EAAE,yBAAyB,EAAE,SAAS,EAAE,EAAA,EACzF,CAAA,CAAA,MAAA,EAAA,EACE,KAAK,EAAC,iDAAiD,EACvD,OAAO,EAAE,MAAM,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,EAAE,CAAC,EAG7C,EAAA,QAAA,CAAA,EACN,IAAI,CAAC,kBAAkB,KAAK,MAAM,CAAC,EAAE,KACpC,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,0BAA0B,EAAA,EACnC,CACE,CAAA,OAAA,EAAA,EAAA,IAAI,EAAE,MAAM,CAAC,IAAI,KAAK,QAAQ,GAAG,QAAQ,GAAG,MAAM,EAClD,KAAK,EAAC,gCAAgC,EACtC,WAAW,EAAE,CAAA,OAAA,EAAU,MAAM,CAAC,MAAM,CAAA,GAAA,CAAK,EACzC,KAAK,EAAE,UAAU,EACjB,OAAO,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAG,CAAC,CAAC,MAA2B,CAAC,KAAK,CAAC,EACpF,SAAS,EAAE,CAAC,CAAC,KAAI;AACf,gBAAA,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,QAAQ,EAAE;AAC3C,oBAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI;;aAEjC,EACD,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,qBAAqB,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,EAC1D,CAAA,CACE,CACP,CACG,CACF;;IAIF,UAAU,GAAA;AAChB,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE;AAC7C,QAAA,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE;AAE/C,QAAA,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE;AAC9B,YAAA,OAAO,IAAI,CAAC,gBAAgB,EAAE;;;AAIhC,QAAA,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YAClD,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;;AAEjD,YAAA,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc;YACxC,QACE,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,gBAAgB,EAAC,IAAI,EAAC,UAAU,EAAA,EACxC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,KAAI;gBACpB,MAAM,UAAU,GAAG,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC;gBACnD,OAAO,IAAI,CAAC,2BAA2B,CAAC,KAAK,EAAE,cAAc,EAAE,UAAU,CAAC;aAC3E,CAAC,CACE;;AAIV,QAAA,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,gBAAgB,EAAC,IAAI,EAAC,UAAU,IACxC,aAAa,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,QAAQ,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,EAAE,cAAc,CAAC,CAAC,CAChF;;AAIF,IAAA,2BAA2B,CAAC,KAAoB,EAAE,cAAgC,EAAE,UAAmB,EAAA;QAC7G,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,QAAQ,CAAC;QAC9D,MAAM,YAAY,GAAG,MAAM,EAAE,MAAM,IAAI,KAAK,CAAC,QAAQ;AAErD,QAAA,MAAM,cAAc,GAAG;AACrB,YAAA,yBAAyB,EAAE,IAAI;AAC/B,YAAA,kCAAkC,EAAE,UAAU;SAC/C;AAED,QAAA,QACE,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,cAAc,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAA,EACvC,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,YAAY,EAAE,UAAU,CAAC,EACrD,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,sBAAsB,EAAC,KAAK,EAAE,EAAE,OAAO,EAAE,UAAU,GAAG,UAAU,GAAG,MAAM,EAAE,EACnF,EAAA,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,QAAQ,KAAI;YAChC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,CAAC;AAC5C,YAAA,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,GAAG,EAAE,CAAA,EAAG,KAAK,CAAC,GAAG,CAAQ,KAAA,EAAA,MAAM,EAAE,EAAA,EACnC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,EAAE,cAAc,EAAE,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAC3D;AAEV,SAAC,CAAC,CACE,CACF;;AAIF,IAAA,cAAc,CAAC,KAAoB,EAAE,YAAoB,EAAE,UAAmB,EAAA;AACpF,QAAA,MAAM,YAAY,GAAG;AACnB,YAAA,qBAAqB,EAAE,IAAI;AAC3B,YAAA,8BAA8B,EAAE,UAAU;SAC3C;AAED,QAAA,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,GAAG,CAAC,GAAG,EAAE,WAAW,EAAE,CAAA,EAAG,CAAC,KAAK,CAAC,KAAK,GAAG,EAAE,IAAI,CAAC,CAAA,EAAA,CAAI,EAAE,GAAG,EAAE;QAEzF,QACE,CACE,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,YAAY,EACnB,KAAK,EAAE,WAAW,EAClB,IAAI,EAAC,KAAK,EACK,eAAA,EAAA,UAAU,GAAG,MAAM,GAAG,OAAO,EAC5C,OAAO,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,EAAA,EAE/C,IAAI,CAAC,eAAe,KACnB,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,wCAAwC,EAAC,IAAI,EAAC,MAAM,EAAA,EAC7D,CACE,CAAA,aAAA,EAAA,EAAA,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,EACvC,aAAa,EAAE,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,EAC/C,UAAU,EAAE,CAAC,CAAQ,KAAI;gBACvB,CAAC,CAAC,eAAe,EAAE;AACnB,gBAAA,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;aAC9B,EACD,OAAO,EAAE,CAAC,CAAQ,KAAK,CAAC,CAAC,eAAe,EAAE,EAAA,CAC1C,CACE,CACP,EACD,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,wBAAwB,EAAA,EACjC,CAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAC,2BAA2B,EAAA,EAAA,eAAA,CAEhC,CACH,EACN,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,uBAAuB,EAAA,EACjC,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,6BAA6B,EAAA,EAAE,YAAY,EAAU,IAAA,CAAA,EACjE,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,uBAAuB,EAAA,EAAE,KAAK,CAAC,YAAY,CAAQ,CAC1D,EACP,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,uBAAuB,EAAA,OAC/B,KAAK,CAAC,IAAI,CAAC,MAAM,OAAG,KAAK,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,GAAG,MAAM,GAAG,OAAO,EAC3D,GAAA,CAAA,CACH;;AAIF,IAAA,kBAAkB,CAAC,KAAoB,EAAA;AAC7C,QAAA,IAAI,KAAK,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC;AAAE,YAAA,OAAO,KAAK;AACzC,QAAA,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,CAAC,KAC7B,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CACtD;;AAGK,IAAA,oBAAoB,CAAC,KAAoB,EAAA;AAC/C,QAAA,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,KAC7C,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CACtD,CAAC,MAAM;QACR,OAAO,aAAa,GAAG,CAAC,IAAI,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM;;AAGvD,IAAA,iBAAiB,GAAG,CAAC,KAAoB,KAAI;QACnD,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACpE,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;QAEpD,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,oBAAoB,CAAC;QAEjD,IAAI,aAAa,EAAE;;AAEjB,YAAA,KAAK,MAAM,GAAG,IAAI,SAAS,EAAE;AAC3B,gBAAA,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC;;;aAEf;;AAEL,YAAA,KAAK,MAAM,GAAG,IAAI,SAAS,EAAE;AAC3B,gBAAA,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;;;AAInB,QAAA,IAAI,CAAC,oBAAoB,GAAG,MAAM;QAClC,IAAI,CAAC,mBAAmB,EAAE;AAC5B,KAAC;;;;IAMO,YAAY,GAAG,CAAC,GAAY,EAAE,QAAgB,EAAE,QAAiB,KAAI;QAC3E,IAAI,CAAC,IAAI,CAAC,aAAa;YAAE;QAEzB,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,CAAC;;QAG5C,MAAM,aAAa,GAA4B,EAAE;AACjD,QAAA,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE;AAC9B,YAAA,IAAI,GAAG,CAAC,QAAQ,KAAK,KAAK,EAAE;AAC1B,gBAAA,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,GAAG,CAAC,QAAkB,CAAC;;;AAI1E,QAAA,IAAI,CAAC,aAAa,GAAG,MAAM;QAC3B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,KAAK,MAAM,IAAI,QAAQ,IAAI,IAAI,IAAI,IAAI;AAC3E,QAAA,IAAI,CAAC,aAAa,GAAG,aAAa;AAElC,QAAA,IAAI,IAAI,CAAC,QAAQ,KAAK,OAAO,EAAE;AAC7B,YAAA,IAAI,CAAC,aAAa,GAAG,IAAI;;AAG3B,QAAA,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC;AAClD,KAAC;IAEO,aAAa,GAAG,MAAK;AAC3B,QAAA,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI;YAAE;AAEjC,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,aAAa,CAAC;AAEjF,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,CAAC;AAE3D,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI;AACzB,QAAA,IAAI,CAAC,eAAe,GAAG,IAAI;AAC3B,QAAA,IAAI,CAAC,aAAa,GAAG,EAAE;AACvB,QAAA,IAAI,CAAC,aAAa,GAAG,KAAK;AAC5B,KAAC;IAEO,WAAW,GAAG,MAAK;AACzB,QAAA,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI;YAAE;AAEjC,QAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,aAAa,CAAC;QAC3F,IAAI,QAAQ,KAAK,EAAE;YAAE;QAErB,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;QACvC,MAAM,OAAO,GAA4B,EAAE;;AAG3C,QAAA,KAAK,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE;AACrE,YAAA,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC;YACxD,IAAI,MAAM,EAAE;AACV,gBAAA,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,MAAM,CAAC,QAAkB,CAAC;AAC/E,gBAAA,IAAI,aAAa,KAAK,QAAQ,EAAE;AAC9B,oBAAA,OAAO,CAAC,QAAQ,CAAC,GAAG,QAAQ;;;;AAKlC,QAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YACnB,MAAM,EAAE,IAAI,CAAC,aAAa;YAC1B,QAAQ;YACR,WAAW;YACX,OAAO;AACR,SAAA,CAAC;AAEF,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI;AACzB,QAAA,IAAI,CAAC,eAAe,GAAG,IAAI;AAC3B,QAAA,IAAI,CAAC,aAAa,GAAG,EAAE;AACvB,QAAA,IAAI,CAAC,aAAa,GAAG,KAAK;AAC5B,KAAC;AAEO,IAAA,qBAAqB,GAAG,CAAC,QAAgB,EAAE,QAAiB,KAAI;QACtE,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC;QAE7C,IAAI,CAAC,aAAa,GAAG;YACnB,GAAG,IAAI,CAAC,aAAa;YACrB,CAAC,QAAQ,GAAG,QAAQ;SACrB;AAED,QAAA,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI,EAAE;AAC/B,YAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;gBACrB,MAAM,EAAE,IAAI,CAAC,aAAa;gBAC1B,QAAQ;gBACR,QAAQ;gBACR,QAAQ;AACT,aAAA,CAAC;;AAEN,KAAC;IAEO,SAAS,CAAC,MAAuB,EAAE,QAAiB,EAAA;AAC1D,QAAA,IAAI,IAAI,CAAC,aAAa,KAAK,MAAM;AAAE,YAAA,OAAO,KAAK;AAE/C,QAAA,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE;AAC5B,YAAA,OAAO,QAAQ,GAAG,IAAI,CAAC,eAAe,KAAK,QAAQ,GAAG,KAAK;;;AAI7D,QAAA,OAAO,IAAI;;IAGL,qBAAqB,GAAG,CAAC,GAAY,EAAE,MAAsB,EAAE,QAAgB,KAAI;QACzF,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK;YAAE;AAEtD,QAAA,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE;YAC5B,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC;;AAE/C,KAAC;AAEO,IAAA,iBAAiB,GAAG,CAAC,KAAoB,EAAE,MAAsB,KAAI;AAC3E,QAAA,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE;YACzB,KAAK,CAAC,cAAc,EAAE;AACtB,YAAA,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE;gBAC5B,IAAI,CAAC,WAAW,EAAE;;;AAEf,aAAA,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE;YACjC,KAAK,CAAC,cAAc,EAAE;YACtB,IAAI,CAAC,aAAa,EAAE;;AACf,aAAA,IAAI,KAAK,CAAC,GAAG,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE;;YAE1D,KAAK,CAAC,cAAc,EAAE;YACtB,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC;;AAEvD,KAAC;AAEO,IAAA,sBAAsB,GAAG,CAAC,aAA6B,EAAE,OAAgB,KAAI;QACnF,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,KAAK,KAAK,IAAI,CAAC,CAAC,OAAO,KAAK,KAAK,CAAC;AAC7F,QAAA,MAAM,YAAY,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,aAAa,CAAC,EAAE,CAAC;QAE9E,IAAI,YAAY,KAAK,EAAE;YAAE;AAEzB,QAAA,MAAM,SAAS,GAAG,OAAO,GAAG,YAAY,GAAG,CAAC,GAAG,YAAY,GAAG,CAAC;QAE/D,IAAI,SAAS,IAAI,CAAC,IAAI,SAAS,GAAG,eAAe,CAAC,MAAM,EAAE;;YAExD,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC,EAAE;;aAC/C;;YAEL,IAAI,CAAC,WAAW,EAAE;;AAEtB,KAAC;;;;IAMO,SAAS,CAAC,GAAY,EAAE,QAAgB,EAAE,cAAgC,EAAE,QAAgB,CAAC,EAAA;QACnG,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,CAAC;QAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,MAAM,CAAC;AACxD,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,KAAK,QAAQ;AACnD,QAAA,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,KAAK,MAAM;AAElD,QAAA,MAAM,UAAU,GAAG;AACjB,YAAA,eAAe,EAAE,IAAI;AACrB,YAAA,wBAAwB,EAAE,UAAU;AACpC,YAAA,qBAAqB,EAAE,SAAS;YAChC,uBAAuB,EAAE,IAAI,CAAC,OAAO,IAAI,QAAQ,GAAG,CAAC,KAAK,CAAC;YAC3D,uBAAuB,EAAE,KAAK,GAAG,CAAC;AAClC,YAAA,uBAAuB,EAAE,YAAY;SACtC;QAED,QACE,CAAA,CAAA,KAAA,EAAA,EACE,KAAK,EAAE,UAAU,EACjB,IAAI,EAAC,KAAK,EAAA,eAAA,EACK,UAAU,GAAG,MAAM,GAAG,OAAO,EAC5C,YAAY,EAAE,MAAK,EAAG,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,EAAE,EACxD,YAAY,EAAE,MAAK,EAAG,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,EAAE,EACpD,OAAO,EAAE,MAAM,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,QAAQ,CAAC,EAAA,EAEhD,IAAI,CAAC,eAAe,KACnB,CAAA,CAAA,KAAA,EAAA,EACE,KAAK,EAAC,wCAAwC,EAC9C,IAAI,EAAC,MAAM,EACX,OAAO,EAAE,CAAC,CAAC,KAAI,EAAG,CAAC,CAAC,eAAe,EAAE,CAAC,EAAE,EAAA,EAExC,CAAA,CAAA,aAAA,EAAA,EACE,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,UAAU,EACnB,UAAU,EAAE,MAAM,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,QAAQ,CAAC,EACrD,OAAO,EAAE,CAAC,CAAQ,KAAK,CAAC,CAAC,eAAe,EAAE,EAAA,CAC1C,CACE,CACP,EACA,KAAK,GAAG,CAAC,KACR,WAAK,KAAK,EAAC,sBAAsB,EAAC,KAAK,EAAE,EAAE,KAAK,EAAE,CAAA,EAAG,KAAK,GAAG,EAAE,CAAI,EAAA,CAAA,EAAE,EAAA,CAAI,CAC1E,EACA,cAAc,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,WAAW,KAAK,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC,EAChG,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,QAAQ,EAAE,YAAY,CAAC,CAC7F;;AAIF,IAAA,gBAAgB,CAAC,GAAY,EAAE,QAAgB,EAAE,SAAkB,EAAA;AACzE,QAAA,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,uCAAuC,EAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,eAAe,EAAE,EAC/F,EAAA,SAAS,IACR,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,wBAAwB,EAAA,EACjC,CAAA,CAAA,QAAA,EAAA,EACE,KAAK,EAAC,4CAA4C,EAClD,OAAO,EAAE,MAAM,IAAI,CAAC,WAAW,EAAE,EACjC,KAAK,EAAC,MAAM,EAAA,EAEZ,CAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAC,2BAA2B,EAAA,EAAA,OAAA,CAAa,CAC7C,EACT,CAAA,CAAA,QAAA,EAAA,EACE,KAAK,EAAC,8CAA8C,EACpD,OAAO,EAAE,MAAM,IAAI,CAAC,aAAa,EAAE,EACnC,KAAK,EAAC,QAAQ,EAAA,EAEd,CAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAC,2BAA2B,EAAA,EAAA,OAAA,CAAa,CAC7C,CACL,KAEN,CACE,CAAA,QAAA,EAAA,EAAA,KAAK,EAAC,4CAA4C,EAClD,OAAO,EAAE,MAAM,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,QAAQ,CAAC,EAC/C,KAAK,EAAC,MAAM,EAAA,EAEZ,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,2BAA2B,EAAA,EAAA,MAAA,CAAY,CAC5C,CACV,CACG;;AAIF,IAAA,UAAU,CAAC,GAAY,EAAE,MAAsB,EAAE,QAAgB,EAAE,WAAmB,EAAA;QAC5F,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,QAAQ,CAAC;AAC5C,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAkB,CAAC;AAC/D,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;QACvD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK;AAE/D,QAAA,MAAM,WAAW,GAAG;AAClB,YAAA,gBAAgB,EAAE,IAAI;YACtB,CAAC,CAAA,qBAAA,EAAwB,MAAM,CAAC,KAAK,IAAI,MAAM,CAAA,CAAE,GAAG,IAAI;YACxD,CAAC,CAAA,oBAAA,EAAuB,MAAM,CAAC,IAAI,IAAI,MAAM,CAAA,CAAE,GAAG,IAAI;AACtD,YAAA,wBAAwB,EAAE,aAAa;AACvC,YAAA,yBAAyB,EAAE,OAAO,IAAI,CAAC,aAAa;SACrD;AAED,QAAA,MAAM,SAAS,GAAG,MAAM,CAAC;cACrB,EAAE,KAAK,EAAE,OAAO,MAAM,CAAC,KAAK,KAAK,QAAQ,GAAG,CAAG,EAAA,MAAM,CAAC,KAAK,CAAI,EAAA,CAAA,GAAG,MAAM,CAAC,KAAK;cAC9E,EAAE;QAEN,QACE,CACE,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,SAAS,EAChB,IAAI,EAAC,MAAM,EACX,OAAO,EAAE,CAAC,CAAC,KAAI;gBACb,CAAC,CAAC,eAAe,EAAE;gBACnB,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,CAAC;AAC1D,aAAC,EACD,UAAU,EAAE,CAAC,CAAC,KAAI;gBAChB,CAAC,CAAC,eAAe,EAAE;gBACnB,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC;aAClD,IAEA;cACG,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK;cAClC,MAAM,CAAC;kBACL,MAAM,CAAC,YAAY,CAAC,KAAK,EAAE,GAAY,EAAE,QAAQ;AACnD,kBAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,CAE1C;;IAIF,eAAe,CAAC,MAAsB,EAAE,aAAsB,EAAA;AACpE,QAAA,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,aAAa;;AAGnE,QAAA,IAAI,MAAM,CAAC,gBAAgB,EAAE;YAC3B,OAAO,MAAM,CAAC,gBAAgB,CAC5B,YAAY,EACZ,EAAW;AACX,YAAA,CAAC,EACD,CAAC,QAAiB,KAAK,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,CACvE;;AAGH,QAAA,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,KAAK,QAAQ,GAAG,QAAQ;YACnC,MAAM,CAAC,IAAI,KAAK,MAAM,GAAG,MAAM;AAC/B,gBAAA,MAAM,CAAC,IAAI,KAAK,SAAS,GAAG,UAAU,GAAG,MAAM;AAEjE,QAAA,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE;AAC7B,YAAA,QACE,CACE,CAAA,aAAA,EAAA,EAAA,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,OAAO,CAAC,YAAY,CAAC,EAC9B,UAAU,EAAE,CAAC,CAAc,KAAK,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,EAAA,CACvF;;AAIN,QAAA,QACE,CAAA,CAAA,OAAA,EAAA,EACE,IAAI,EAAE,SAAS,EACf,KAAK,EAAC,sBAAsB,EAC5B,KAAK,EAAE,YAAY,IAAI,IAAI,GAAG,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,EACvD,OAAO,EAAE,CAAC,CAAC,KAAI;AACb,gBAAA,MAAM,KAAK,GAAG,CAAC,CAAC,MAA0B;gBAC1C,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,KAAK,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,KAAK;gBAC7E,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC;aAChD,EACD,SAAS,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,iBAAiB,CAAC,CAAC,EAAE,MAAM,CAAC,EACnD,GAAG,EAAE,CAAC,EAAE,KAAI;gBACV,IAAI,EAAE,EAAE;;oBAEN,qBAAqB,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC;;aAE1C,EAAA,CACD;;IAIE,eAAe,CAAC,KAAc,EAAE,IAAyB,EAAA;AAC/D,QAAA,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS;AAAE,YAAA,OAAO,EAAE;QAEpD,QAAQ,IAAI;AACV,YAAA,KAAK,MAAM;gBACT,OAAO,IAAI,IAAI,CAAC,KAAe,CAAC,CAAC,kBAAkB,EAAE;AACvD,YAAA,KAAK,QAAQ;AACX,gBAAA,OAAO,OAAO,KAAK,KAAK,QAAQ,GAAG,KAAK,CAAC,cAAc,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC;AAC3E,YAAA,KAAK,SAAS;gBACZ,OAAO,KAAK,GAAG,KAAK,GAAG,IAAI;AAC7B,YAAA;AACE,gBAAA,OAAO,MAAM,CAAC,KAAK,CAAC;;;IAIlB,gBAAgB,GAAA;AACtB,QAAA,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,uBAAuB,EAAA,EAChC,CAAA,CAAA,gBAAA,EAAA,EACE,UAAU,EAAC,SAAS,EACpB,WAAW,EAAE,IAAI,CAAC,YAAY,EAAA,CAC9B,CACE;;IAIF,aAAa,GAAA;QACnB,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,2BAA2B,EAAA,EACpC,CAAA,CAAA,mBAAA,EAAA,EAAmB,IAAI,EAAC,IAAI,EAAG,CAAA,CAC3B;;;;;IAQV,MAAM,GAAA;AACJ,QAAA,MAAM,WAAW,GAAG;AAClB,YAAA,WAAW,EAAE,IAAI;YACjB,mBAAmB,EAAE,IAAI,CAAC,OAAO;YACjC,oBAAoB,EAAE,IAAI,CAAC,cAAc;YACzC,mBAAmB,EAAE,IAAI,CAAC,OAAO;SAClC;AAED,QAAA,QACE,4DAAK,KAAK,EAAE,WAAW,EAAE,IAAI,EAAC,MAAM,EAAA,WAAA,EAAY,IAAI,CAAC,OAAO,GAAG,MAAM,GAAG,OAAO,EAAA,EAC7E,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,iBAAiB,EAAA,EACzB,IAAI,CAAC,YAAY,EAAE,EACnB,IAAI,CAAC,eAAe,EAAE,EACtB,IAAI,CAAC,UAAU,EAAE,CACd,EACL,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,aAAa,EAAE,CACjC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["__stencil_proxyCustomElement","HTMLElement"],"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"],"version":3}
@@ -0,0 +1,70 @@
1
+ import { p as proxyCustomElement, H, h } from './p-9a7sQzad.js';
2
+
3
+ const bhLoaderSpinnerCss = ":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)}";
4
+
5
+ const BhLoaderSpinner = /*@__PURE__*/ proxyCustomElement(class BhLoaderSpinner extends H {
6
+ constructor(registerHost) {
7
+ super();
8
+ if (registerHost !== false) {
9
+ this.__registerHost();
10
+ }
11
+ this.__attachShadow();
12
+ }
13
+ /** Loader size */
14
+ size = 'md';
15
+ /** Loader color variant - use 'white' for dark surfaces like buttons */
16
+ variant = 'default';
17
+ /** Whether to show as overlay */
18
+ overlay = false;
19
+ /** Message to show in overlay mode */
20
+ overlayMessage = '';
21
+ /** Whether to show message */
22
+ showMessage = false;
23
+ /** Message text */
24
+ message = 'Loading...';
25
+ renderSpinner() {
26
+ const gradientId = this.variant === 'white' ? 'bellhop-gradient-white' : 'bellhop-gradient';
27
+ return (h("div", { class: `loader-spinner variant-${this.variant}` }, h("div", { class: "spinner-gradient" }, h("svg", { class: "gradient-svg", viewBox: "0 0 50 50" }, h("defs", null, this.variant === 'white' ? (h("linearGradient", { id: "bellhop-gradient-white", x1: "0%", y1: "0%", x2: "0%", y2: "100%" }, h("stop", { offset: "0%", style: { stopColor: 'rgba(255, 255, 255, 1)' } }), h("stop", { offset: "50%", style: { stopColor: 'rgba(255, 255, 255, 0.8)' } }), h("stop", { offset: "100%", style: { stopColor: 'rgba(255, 255, 255, 0.5)' } }))) : (h("linearGradient", { id: "bellhop-gradient", x1: "0%", y1: "0%", x2: "0%", y2: "100%" }, h("stop", { offset: "0%", style: { stopColor: 'var(--color-accent-300)' } }), h("stop", { offset: "51%", style: { stopColor: 'var(--color-brand-400)' } }), h("stop", { offset: "100%", style: { stopColor: 'var(--color-brand-600)' } })))), h("circle", { class: "gradient-path", cx: "25", cy: "25", r: "20", fill: "none", stroke: `url(#${gradientId})`, "stroke-width": "4", "stroke-linecap": "round" })))));
28
+ }
29
+ renderMessage(isOverlay) {
30
+ const shouldShowMessage = isOverlay
31
+ ? (this.showMessage || this.overlayMessage)
32
+ : this.showMessage;
33
+ if (!shouldShowMessage)
34
+ return null;
35
+ return (h("div", { class: "loader-message" }, isOverlay ? (this.overlayMessage || this.message) : this.message));
36
+ }
37
+ render() {
38
+ if (this.overlay) {
39
+ return (h("div", { class: "loader-overlay" }, h("div", { class: "loader-overlay-content" }, h("div", { class: `loader-container size-${this.size}` }, this.renderSpinner()), this.renderMessage(true))));
40
+ }
41
+ return (h("div", { class: `loader-container size-${this.size}` }, this.renderSpinner(), this.renderMessage(false)));
42
+ }
43
+ static get style() { return bhLoaderSpinnerCss; }
44
+ }, [769, "bh-loader-spinner", {
45
+ "size": [1],
46
+ "variant": [1],
47
+ "overlay": [4],
48
+ "overlayMessage": [1, "overlay-message"],
49
+ "showMessage": [4, "show-message"],
50
+ "message": [1]
51
+ }]);
52
+ function defineCustomElement() {
53
+ if (typeof customElements === "undefined") {
54
+ return;
55
+ }
56
+ const components = ["bh-loader-spinner"];
57
+ components.forEach(tagName => { switch (tagName) {
58
+ case "bh-loader-spinner":
59
+ if (!customElements.get(tagName)) {
60
+ customElements.define(tagName, BhLoaderSpinner);
61
+ }
62
+ break;
63
+ } });
64
+ }
65
+ defineCustomElement();
66
+
67
+ export { BhLoaderSpinner as B, defineCustomElement as d };
68
+ //# sourceMappingURL=p-Bbo_Dwmk.js.map
69
+
70
+ //# sourceMappingURL=p-Bbo_Dwmk.js.map
@@ -0,0 +1 @@
1
+ {"file":"p-Bbo_Dwmk.js","mappings":"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","names":["__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/bh-loader-spinner/bh-loader-spinner.css?tag=bh-loader-spinner&encapsulation=shadow","src/components/bh-loader-spinner/bh-loader-spinner.tsx"],"sourcesContent":["/* ==========================================================================\n LOADER SPINNER COMPONENT - StencilJS\n ========================================================================== */\n\n:host {\n display: inline-block;\n}\n\n/* Overlay styles */\n.loader-overlay {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.3);\n backdrop-filter: blur(4px);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: 9999;\n}\n\n.loader-overlay-content {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: var(--spacing-md);\n}\n\n/* Container styles */\n.loader-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: var(--spacing-sm);\n}\n\n.loader-spinner {\n position: relative;\n display: inline-block;\n}\n\n/* Message styles */\n.loader-message {\n color: var(--color-neutral-700);\n font-size: var(--text-sm-size);\n line-height: var(--text-sm-line);\n font-weight: var(--weight-medium);\n text-align: center;\n margin-top: var(--spacing-xs);\n}\n\n.loader-overlay .loader-message {\n color: var(--color-white);\n}\n\n/* =========================\n GRADIENT VARIANT - BellhopOS Sidebar Style\n ========================= */\n.spinner-gradient {\n animation: gradient-rotate 2s linear infinite;\n will-change: transform;\n}\n\n.gradient-svg {\n display: block;\n transform-origin: 50% 50%;\n}\n\n.gradient-path {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: 0;\n animation: gradient-dash 1.5s ease-in-out infinite;\n transform-origin: 50% 50%;\n}\n\n/* Size variations for gradient */\n.size-sm .gradient-svg {\n width: 20px;\n height: 20px;\n}\n\n.size-sm .gradient-path {\n stroke-width: 5;\n}\n\n.size-md .gradient-svg {\n width: 30px;\n height: 30px;\n}\n\n.size-md .gradient-path {\n stroke-width: 5;\n}\n\n.size-lg .gradient-svg {\n width: 40px;\n height: 40px;\n}\n\n.size-lg .gradient-path {\n stroke-width: 5;\n}\n\n.size-xl .gradient-svg {\n width: 60px;\n height: 60px;\n}\n\n.size-xl .gradient-path {\n stroke-width: 6;\n}\n\n@keyframes gradient-rotate {\n 100% {\n transform: rotate(360deg);\n }\n}\n\n@keyframes gradient-dash {\n 0% {\n stroke-dasharray: 1, 150;\n stroke-dashoffset: 0;\n }\n 50% {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: -35;\n }\n 100% {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: -124;\n }\n}\n\n/* Hover effects - Ultra smooth acceleration */\n.loader-container:hover .spinner-gradient {\n animation-duration: 1s;\n}\n\n.loader-container:hover .gradient-path {\n animation-duration: 0.6s;\n}\n\n/* Performance optimizations */\n.spinner-gradient {\n backface-visibility: hidden;\n perspective: 1000px;\n}\n\n.gradient-svg {\n transform: translateZ(0);\n}\n","import { Component, Prop, h } from '@stencil/core';\n\nexport type LoaderSize = 'sm' | 'md' | 'lg' | 'xl';\nexport type LoaderVariant = 'default' | 'white';\n\n@Component({\n tag: 'bh-loader-spinner',\n styleUrl: 'bh-loader-spinner.css',\n shadow: true,\n})\nexport class BhLoaderSpinner {\n /** Loader size */\n @Prop() size: LoaderSize = 'md';\n\n /** Loader color variant - use 'white' for dark surfaces like buttons */\n @Prop() variant: LoaderVariant = 'default';\n\n /** Whether to show as overlay */\n @Prop() overlay: boolean = false;\n\n /** Message to show in overlay mode */\n @Prop() overlayMessage: string = '';\n\n /** Whether to show message */\n @Prop() showMessage: boolean = false;\n\n /** Message text */\n @Prop() message: string = 'Loading...';\n\n private renderSpinner() {\n const gradientId = this.variant === 'white' ? 'bellhop-gradient-white' : 'bellhop-gradient';\n\n return (\n <div class={`loader-spinner variant-${this.variant}`}>\n <div class=\"spinner-gradient\">\n <svg class=\"gradient-svg\" viewBox=\"0 0 50 50\">\n <defs>\n {this.variant === 'white' ? (\n <linearGradient\n id=\"bellhop-gradient-white\"\n x1=\"0%\"\n y1=\"0%\"\n x2=\"0%\"\n y2=\"100%\"\n >\n <stop offset=\"0%\" style={{ stopColor: 'rgba(255, 255, 255, 1)' }} />\n <stop offset=\"50%\" style={{ stopColor: 'rgba(255, 255, 255, 0.8)' }} />\n <stop offset=\"100%\" style={{ stopColor: 'rgba(255, 255, 255, 0.5)' }} />\n </linearGradient>\n ) : (\n <linearGradient\n id=\"bellhop-gradient\"\n x1=\"0%\"\n y1=\"0%\"\n x2=\"0%\"\n y2=\"100%\"\n >\n <stop offset=\"0%\" style={{ stopColor: 'var(--color-accent-300)' }} />\n <stop offset=\"51%\" style={{ stopColor: 'var(--color-brand-400)' }} />\n <stop offset=\"100%\" style={{ stopColor: 'var(--color-brand-600)' }} />\n </linearGradient>\n )}\n </defs>\n <circle\n class=\"gradient-path\"\n cx=\"25\"\n cy=\"25\"\n r=\"20\"\n fill=\"none\"\n stroke={`url(#${gradientId})`}\n stroke-width=\"4\"\n stroke-linecap=\"round\"\n />\n </svg>\n </div>\n </div>\n );\n }\n\n private renderMessage(isOverlay: boolean) {\n const shouldShowMessage = isOverlay\n ? (this.showMessage || this.overlayMessage)\n : this.showMessage;\n\n if (!shouldShowMessage) return null;\n\n return (\n <div class=\"loader-message\">\n {isOverlay ? (this.overlayMessage || this.message) : this.message}\n </div>\n );\n }\n\n render() {\n if (this.overlay) {\n return (\n <div class=\"loader-overlay\">\n <div class=\"loader-overlay-content\">\n <div class={`loader-container size-${this.size}`}>\n {this.renderSpinner()}\n </div>\n {this.renderMessage(true)}\n </div>\n </div>\n );\n }\n\n return (\n <div class={`loader-container size-${this.size}`}>\n {this.renderSpinner()}\n {this.renderMessage(false)}\n </div>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,72 @@
1
+ import { p as proxyCustomElement, H, h, d as Host } from './p-9a7sQzad.js';
2
+
3
+ const bhCardCss = ":host{display:block}.card{display:flex;flex-direction:column;background:var(--color-white);border:1px solid var(--color-neutral-200);border-radius:var(--radius-xl);overflow:hidden;font-family:var(--font-inter)}.card-header-slot{display:contents}.card-content{display:flex;flex-direction:column;flex:1 0 auto;padding:var(--spacing-lg) var(--spacing-xl);gap:var(--spacing-none)}.card-footer-slot{display:contents}.card-content-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:var(--spacing-md);padding:var(--spacing-xl);background:var(--color-purple-50, #f5f3ff);border:1px dashed var(--color-purple-500, #7c3aed);border-radius:var(--radius-xl);min-height:100%}.card-placeholder-icon{font-size:32px;color:var(--color-purple-500, #7c3aed)}.card-placeholder-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-purple-700, #6d28d9);text-decoration:underline;text-align:center}";
4
+
5
+ const BhCard = /*@__PURE__*/ proxyCustomElement(class BhCard extends H {
6
+ constructor(registerHost) {
7
+ super();
8
+ if (registerHost !== false) {
9
+ this.__registerHost();
10
+ }
11
+ this.__attachShadow();
12
+ }
13
+ get el() { return this; }
14
+ /**
15
+ * Whether to show the header section
16
+ */
17
+ showHeader = true;
18
+ /**
19
+ * Whether to show the footer section
20
+ */
21
+ showFooter = true;
22
+ /**
23
+ * Minimum height of the content area in pixels
24
+ */
25
+ contentMinHeight = 200;
26
+ /**
27
+ * Placeholder text shown when no content is provided
28
+ */
29
+ placeholderText = 'Card content slot';
30
+ hasContent = false;
31
+ componentWillLoad() {
32
+ this.checkForContent();
33
+ }
34
+ checkForContent() {
35
+ const children = Array.from(this.el.childNodes).filter((node) => (node.nodeType === Node.ELEMENT_NODE &&
36
+ !node.hasAttribute('slot')) ||
37
+ (node.nodeType === Node.TEXT_NODE && node.textContent?.trim()));
38
+ this.hasContent = children.length > 0;
39
+ }
40
+ render() {
41
+ const contentStyle = {
42
+ minHeight: `${this.contentMinHeight}px`,
43
+ };
44
+ return (h(Host, { key: '5bbe75e2d4ace932edc5a8d32fb450e27e67cdbe' }, h("div", { key: 'ddb19c134e32a35bc2b8a4b57ed9862faf47a53b', class: "card" }, this.showHeader && (h("div", { key: '315478a2c488b5e933c49966bccaccf8313e58b5', class: "card-header-slot" }, h("slot", { key: 'f3de383b3818feb9883c25ff150c52f0e347de86', name: "header" }))), h("div", { key: '4c6b62db9ffa61f2e0133c2af7a29a090d9c54a5', class: "card-content", style: contentStyle }, h("slot", { key: '969443dcc57fe724cbb3f1d6e1c35c8cc0312794' }), !this.hasContent && (h("div", { key: '0c5e02cf39bec9c7c1ce2ef223b1b4b0df74a372', class: "card-content-placeholder" }, h("span", { key: '0a89b768f29453dc251c3c3402ea8029bd13aaeb', class: "card-placeholder-text" }, this.placeholderText)))), this.showFooter && (h("div", { key: 'f4a2bb6df865bd1abb8f5da2d686906bddcc4c08', class: "card-footer-slot" }, h("slot", { key: '8e643371cbbbf56fb3fb87ccda3b5897f8f914bd', name: "footer" }))))));
45
+ }
46
+ static get style() { return bhCardCss; }
47
+ }, [769, "bh-card", {
48
+ "showHeader": [4, "show-header"],
49
+ "showFooter": [4, "show-footer"],
50
+ "contentMinHeight": [2, "content-min-height"],
51
+ "placeholderText": [1, "placeholder-text"],
52
+ "hasContent": [32]
53
+ }]);
54
+ function defineCustomElement() {
55
+ if (typeof customElements === "undefined") {
56
+ return;
57
+ }
58
+ const components = ["bh-card"];
59
+ components.forEach(tagName => { switch (tagName) {
60
+ case "bh-card":
61
+ if (!customElements.get(tagName)) {
62
+ customElements.define(tagName, BhCard);
63
+ }
64
+ break;
65
+ } });
66
+ }
67
+ defineCustomElement();
68
+
69
+ export { BhCard as B, defineCustomElement as d };
70
+ //# sourceMappingURL=p-BdcGkck5.js.map
71
+
72
+ //# sourceMappingURL=p-BdcGkck5.js.map
@@ -0,0 +1 @@
1
+ {"file":"p-BdcGkck5.js","mappings":";;AAAA,MAAM,SAAS,GAAG,m8BAAm8B;;MCOx8B,MAAM,iBAAAA,kBAAA,CAAA,MAAA,MAAA,SAAAC,CAAA,CAAA;;;;;;;;;AAGjB;;AAEG;IACK,UAAU,GAAY,IAAI;AAElC;;AAEG;IACK,UAAU,GAAY,IAAI;AAElC;;AAEG;IACK,gBAAgB,GAAW,GAAG;AAEtC;;AAEG;IACK,eAAe,GAAW,mBAAmB;IAE5C,UAAU,GAAY,KAAK;IAEpC,iBAAiB,GAAA;QACf,IAAI,CAAC,eAAe,EAAE;;IAGhB,eAAe,GAAA;QACrB,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,MAAM,CACpD,CAAC,IAAI,KACH,CAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,YAAY;AAClC,YAAA,CAAE,IAAgB,CAAC,YAAY,CAAC,MAAM,CAAC;AACzC,aAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CACjE;QACD,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC;;IAGvC,MAAM,GAAA;AACJ,QAAA,MAAM,YAAY,GAAG;AACnB,YAAA,SAAS,EAAE,CAAA,EAAG,IAAI,CAAC,gBAAgB,CAAI,EAAA,CAAA;SACxC;AAED,QAAA,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,MAAM,EAAA,EACd,IAAI,CAAC,UAAU,KACd,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,kBAAkB,EAAA,EAC3B,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAM,IAAI,EAAC,QAAQ,EAAA,CAAG,CAClB,CACP,EACD,CAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAC,cAAc,EAAC,KAAK,EAAE,YAAY,EAAA,EAC3C,CAAQ,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,EACP,CAAC,IAAI,CAAC,UAAU,KACf,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,0BAA0B,EAAA,EACnC,CAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,uBAAuB,EAAE,EAAA,IAAI,CAAC,eAAe,CAAQ,CAC7D,CACP,CACG,EACL,IAAI,CAAC,UAAU,KACd,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,kBAAkB,EAAA,EAC3B,CAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,IAAI,EAAC,QAAQ,EAAA,CAAG,CAClB,CACP,CACG,CACD;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/bh-card/bh-card.css?tag=bh-card&encapsulation=shadow","src/components/bh-card/bh-card.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.card {\n display: flex;\n flex-direction: column;\n background: var(--color-white);\n border: 1px solid var(--color-neutral-200);\n border-radius: var(--radius-xl);\n overflow: hidden;\n font-family: var(--font-inter);\n}\n\n.card-header-slot {\n display: contents;\n}\n\n.card-content {\n display: flex;\n flex-direction: column;\n flex: 1 0 auto;\n padding: var(--spacing-lg) var(--spacing-xl);\n gap: var(--spacing-none);\n}\n\n.card-footer-slot {\n display: contents;\n}\n\n/* Placeholder styles */\n.card-content-placeholder {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n flex: 1;\n gap: var(--spacing-md);\n padding: var(--spacing-xl);\n background: var(--color-purple-50, #f5f3ff);\n border: 1px dashed var(--color-purple-500, #7c3aed);\n border-radius: var(--radius-xl);\n min-height: 100%;\n}\n\n.card-placeholder-icon {\n font-size: 32px;\n color: var(--color-purple-500, #7c3aed);\n}\n\n.card-placeholder-text {\n font-size: var(--font-size-sm);\n font-weight: var(--font-weight-medium);\n color: var(--color-purple-700, #6d28d9);\n text-decoration: underline;\n text-align: center;\n}\n","import { Component, Prop, State, Element, h, Host } from '@stencil/core';\n\n@Component({\n tag: 'bh-card',\n styleUrl: 'bh-card.css',\n shadow: true,\n})\nexport class BhCard {\n @Element() el!: HTMLElement;\n\n /**\n * Whether to show the header section\n */\n @Prop() showHeader: boolean = true;\n\n /**\n * Whether to show the footer section\n */\n @Prop() showFooter: boolean = true;\n\n /**\n * Minimum height of the content area in pixels\n */\n @Prop() contentMinHeight: number = 200;\n\n /**\n * Placeholder text shown when no content is provided\n */\n @Prop() placeholderText: string = 'Card content slot';\n\n @State() hasContent: boolean = false;\n\n componentWillLoad() {\n this.checkForContent();\n }\n\n private checkForContent() {\n const children = Array.from(this.el.childNodes).filter(\n (node) =>\n (node.nodeType === Node.ELEMENT_NODE &&\n !(node as Element).hasAttribute('slot')) ||\n (node.nodeType === Node.TEXT_NODE && node.textContent?.trim())\n );\n this.hasContent = children.length > 0;\n }\n\n render() {\n const contentStyle = {\n minHeight: `${this.contentMinHeight}px`,\n };\n\n return (\n <Host>\n <div class=\"card\">\n {this.showHeader && (\n <div class=\"card-header-slot\">\n <slot name=\"header\" />\n </div>\n )}\n <div class=\"card-content\" style={contentStyle}>\n <slot />\n {!this.hasContent && (\n <div class=\"card-content-placeholder\">\n <span class=\"card-placeholder-text\">{this.placeholderText}</span>\n </div>\n )}\n </div>\n {this.showFooter && (\n <div class=\"card-footer-slot\">\n <slot name=\"footer\" />\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,132 @@
1
+ import { p as proxyCustomElement, H, c as createEvent, h, F as Fragment } from './p-9a7sQzad.js';
2
+ import { d as defineCustomElement$1 } from './p-D3OkBDd3.js';
3
+
4
+ const bhBreadcrumbsCss = ":host{display:block}.breadcrumbs{font-family:var(--font-inter);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.breadcrumbs-container{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.breadcrumb-item{display:flex;align-items:center}.breadcrumb-button{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs) var(--spacing-sm);border:none;background:transparent;border-radius:6px;cursor:pointer;transition:all 0.15s ease;color:var(--color-neutral-600);text-decoration:none;font-family:var(--font-inter);font-size:var(--text-sm-size);font-weight:500;line-height:1.4285714285714286em;min-height:24px;box-sizing:border-box}.breadcrumb-button:hover{background-color:var(--color-neutral-50);color:var(--color-neutral-900)}.breadcrumb-button:focus-visible{outline:2px solid var(--color-brand-500);outline-offset:2px}.breadcrumb-home{padding:var(--spacing-xs);min-width:24px;min-height:24px}.breadcrumb-current{background-color:var(--color-neutral-50);color:var(--color-neutral-800);font-weight:500;cursor:default}.breadcrumb-current:hover{background-color:var(--color-neutral-50);color:var(--color-neutral-800)}.breadcrumb-ellipsis{color:var(--color-neutral-600);font-weight:500}.breadcrumb-ellipsis:hover{background-color:var(--color-neutral-50);color:var(--color-neutral-900)}.breadcrumb-text{white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.breadcrumb-icon{flex-shrink:0;font-size:20px;width:20px;height:20px;color:var(--color-neutral-600)}.breadcrumb-home .breadcrumb-icon{font-size:20px;width:20px;height:20px}.breadcrumb-separator{display:flex;align-items:center;color:var(--color-neutral-300);font-size:20px;flex-shrink:0}.breadcrumb-separator .material-symbols-outlined{font-size:20px;width:20px;height:20px}.material-symbols-outlined{font-family:'Material Symbols Outlined';font-weight:normal;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:'liga';-webkit-font-smoothing:antialiased;font-variation-settings:'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24}@media (max-width: 640px){.breadcrumb-text{max-width:120px}.breadcrumbs-container{gap:var(--spacing-xxs)}.breadcrumb-button{padding:var(--spacing-xxs) var(--spacing-xs);font-size:12px}}";
5
+
6
+ const BhBreadcrumbs = /*@__PURE__*/ proxyCustomElement(class BhBreadcrumbs extends H {
7
+ constructor(registerHost) {
8
+ super();
9
+ if (registerHost !== false) {
10
+ this.__registerHost();
11
+ }
12
+ this.__attachShadow();
13
+ this.bhItemClick = createEvent(this, "bhItemClick");
14
+ this.bhNavigate = createEvent(this, "bhNavigate");
15
+ }
16
+ /**
17
+ * Array of breadcrumb items
18
+ */
19
+ items = [];
20
+ /**
21
+ * Separator icon name (Material Symbols)
22
+ */
23
+ separator = 'chevron_right';
24
+ /**
25
+ * Whether to show the home button
26
+ */
27
+ showHome = true;
28
+ /**
29
+ * Maximum number of visible items before collapsing
30
+ */
31
+ maxVisibleItems = 4;
32
+ /**
33
+ * Event emitted when a breadcrumb item is clicked
34
+ */
35
+ bhItemClick;
36
+ /**
37
+ * Event emitted when navigating to a path
38
+ */
39
+ bhNavigate;
40
+ get parsedItems() {
41
+ if (typeof this.items === 'string') {
42
+ try {
43
+ return JSON.parse(this.items);
44
+ }
45
+ catch {
46
+ return [];
47
+ }
48
+ }
49
+ return this.items || [];
50
+ }
51
+ get displayData() {
52
+ const items = this.parsedItems;
53
+ if (!items || items.length <= this.maxVisibleItems) {
54
+ return {
55
+ displayItems: items ? [...items] : [],
56
+ showEllipsis: false,
57
+ collapsedItems: [],
58
+ };
59
+ }
60
+ else {
61
+ const lastItems = items.slice(-(this.maxVisibleItems - 2));
62
+ return {
63
+ displayItems: [items[0], ...lastItems],
64
+ showEllipsis: true,
65
+ collapsedItems: items.slice(1, -(this.maxVisibleItems - 2)),
66
+ };
67
+ }
68
+ }
69
+ handleItemClick(item) {
70
+ if (!item.isActive && item.path) {
71
+ this.bhItemClick.emit(item);
72
+ this.bhNavigate.emit(item.path);
73
+ }
74
+ }
75
+ handleHomeClick = () => {
76
+ const homeItem = {
77
+ label: 'Home',
78
+ path: '/',
79
+ };
80
+ this.bhItemClick.emit(homeItem);
81
+ this.bhNavigate.emit('/');
82
+ };
83
+ handleEllipsisClick = () => {
84
+ const { collapsedItems } = this.displayData;
85
+ if (collapsedItems.length > 0) {
86
+ this.handleItemClick(collapsedItems[0]);
87
+ }
88
+ };
89
+ renderBreadcrumbItem(item, index) {
90
+ if (item.isActive || !item.path) {
91
+ return (h("div", { key: index, class: "breadcrumb-button breadcrumb-current", "aria-current": "page" }, h("span", { class: "breadcrumb-text" }, item.label)));
92
+ }
93
+ return (h("button", { key: index, type: "button", class: "breadcrumb-button", onClick: () => this.handleItemClick(item) }, h("span", { class: "breadcrumb-text" }, item.label)));
94
+ }
95
+ renderSeparator() {
96
+ return (h("div", { class: "breadcrumb-separator" }, h("span", { class: "material-symbols-outlined" }, this.separator)));
97
+ }
98
+ render() {
99
+ const { displayItems, showEllipsis, collapsedItems } = this.displayData;
100
+ return (h("nav", { key: 'f8fa78dc80f7e0a6d7c2161396348a892f4c9d0b', class: "breadcrumbs", "aria-label": "Breadcrumb" }, h("div", { key: 'b7a5ae9c8206992802c6be37687c41033d452d7b', class: "breadcrumbs-container" }, this.showHome && (h("div", { key: '0e5312f7c42a90f2f979be515a856d60d2ffd733', class: "breadcrumb-item" }, h("bh-button-icon", { key: 'b95e5c59a7a5800c670c0c2b05ffc482d25f084c', hierarchy: "quaternary", size: "xs", iconName: "cottage", onClick: this.handleHomeClick, "aria-label": "Home" }))), this.showHome && (displayItems.length > 0 || showEllipsis) && this.renderSeparator(), showEllipsis && displayItems.length > 0 && (h(Fragment, { key: '510adc7a0db807a4232c2d23bbdbf55de28cc0b0' }, h("div", { key: 'dafefca139a16b4ae71c6577f8885d055e7643dc', class: "breadcrumb-item" }, this.renderBreadcrumbItem(displayItems[0], 0)), this.renderSeparator(), h("div", { key: '0ea0b6c5093c551e9f927b08e3caddd2c85d64d7', class: "breadcrumb-item" }, h("button", { key: 'b14a815428f58d34a753e8b1ae841a6c7a815b15', type: "button", class: "breadcrumb-button breadcrumb-ellipsis", onClick: this.handleEllipsisClick, title: `Show ${collapsedItems.length} hidden items` }, h("span", { key: 'f22204e923c5bb60be5b578861be47c0bb8aacf0', class: "breadcrumb-text" }, "..."))), this.renderSeparator(), displayItems.slice(1).map((item, index) => (h(Fragment, null, h("div", { class: "breadcrumb-item", key: `item-${index + 1}` }, this.renderBreadcrumbItem(item, index + 1)), index < displayItems.slice(1).length - 1 && this.renderSeparator()))))), !showEllipsis && displayItems.map((item, index) => (h(Fragment, null, h("div", { class: "breadcrumb-item", key: `item-${index}` }, this.renderBreadcrumbItem(item, index)), index < displayItems.length - 1 && this.renderSeparator()))))));
101
+ }
102
+ static get style() { return bhBreadcrumbsCss; }
103
+ }, [769, "bh-breadcrumbs", {
104
+ "items": [1],
105
+ "separator": [1],
106
+ "showHome": [4, "show-home"],
107
+ "maxVisibleItems": [2, "max-visible-items"]
108
+ }]);
109
+ function defineCustomElement() {
110
+ if (typeof customElements === "undefined") {
111
+ return;
112
+ }
113
+ const components = ["bh-breadcrumbs", "bh-button-icon"];
114
+ components.forEach(tagName => { switch (tagName) {
115
+ case "bh-breadcrumbs":
116
+ if (!customElements.get(tagName)) {
117
+ customElements.define(tagName, BhBreadcrumbs);
118
+ }
119
+ break;
120
+ case "bh-button-icon":
121
+ if (!customElements.get(tagName)) {
122
+ defineCustomElement$1();
123
+ }
124
+ break;
125
+ } });
126
+ }
127
+ defineCustomElement();
128
+
129
+ export { BhBreadcrumbs as B, defineCustomElement as d };
130
+ //# sourceMappingURL=p-Bk8GbEQp.js.map
131
+
132
+ //# sourceMappingURL=p-Bk8GbEQp.js.map
@@ -0,0 +1 @@
1
+ {"file":"p-Bk8GbEQp.js","mappings":"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","names":["__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/bh-breadcrumbs/bh-breadcrumbs.css?tag=bh-breadcrumbs&encapsulation=shadow","src/components/bh-breadcrumbs/bh-breadcrumbs.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n/* Breadcrumbs Navigation - Matching Figma Design */\n.breadcrumbs {\n font-family: var(--font-inter);\n user-select: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n}\n\n.breadcrumbs-container {\n display: flex;\n align-items: center;\n gap: var(--spacing-xs);\n flex-wrap: wrap;\n}\n\n.breadcrumb-item {\n display: flex;\n align-items: center;\n}\n\n/* Breadcrumb Buttons - Matching Figma Design */\n.breadcrumb-button {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: var(--spacing-xs) var(--spacing-sm);\n border: none;\n background: transparent;\n border-radius: 6px;\n cursor: pointer;\n transition: all 0.15s ease;\n color: var(--color-neutral-600);\n text-decoration: none;\n font-family: var(--font-inter);\n font-size: var(--text-sm-size);\n font-weight: 500;\n line-height: 1.4285714285714286em;\n min-height: 24px;\n box-sizing: border-box;\n}\n\n.breadcrumb-button:hover {\n background-color: var(--color-neutral-50);\n color: var(--color-neutral-900);\n}\n\n.breadcrumb-button:focus-visible {\n outline: 2px solid var(--color-brand-500);\n outline-offset: 2px;\n}\n\n/* Home button styling */\n.breadcrumb-home {\n padding: var(--spacing-xs);\n min-width: 24px;\n min-height: 24px;\n}\n\n/* Current/Active breadcrumb item - Matching Figma highlighted state */\n.breadcrumb-current {\n background-color: var(--color-neutral-50);\n color: var(--color-neutral-800);\n font-weight: 500;\n cursor: default;\n}\n\n.breadcrumb-current:hover {\n background-color: var(--color-neutral-50);\n color: var(--color-neutral-800);\n}\n\n/* Ellipsis button */\n.breadcrumb-ellipsis {\n color: var(--color-neutral-600);\n font-weight: 500;\n}\n\n.breadcrumb-ellipsis:hover {\n background-color: var(--color-neutral-50);\n color: var(--color-neutral-900);\n}\n\n/* Breadcrumb text */\n.breadcrumb-text {\n white-space: nowrap;\n max-width: 200px;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n/* Breadcrumb icons */\n.breadcrumb-icon {\n flex-shrink: 0;\n font-size: 20px;\n width: 20px;\n height: 20px;\n color: var(--color-neutral-600);\n}\n\n.breadcrumb-home .breadcrumb-icon {\n font-size: 20px;\n width: 20px;\n height: 20px;\n}\n\n/* Separators - Matching Figma chevron color */\n.breadcrumb-separator {\n display: flex;\n align-items: center;\n color: var(--color-neutral-300);\n font-size: 20px;\n flex-shrink: 0;\n}\n\n.breadcrumb-separator .material-symbols-outlined {\n font-size: 20px;\n width: 20px;\n height: 20px;\n}\n\n/* Material Symbols Support */\n.material-symbols-outlined {\n font-family: 'Material Symbols Outlined';\n font-weight: normal;\n font-style: normal;\n font-size: 24px;\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 -webkit-font-feature-settings: 'liga';\n -webkit-font-smoothing: antialiased;\n font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;\n}\n\n/* Responsive behavior */\n@media (max-width: 640px) {\n .breadcrumb-text {\n max-width: 120px;\n }\n\n .breadcrumbs-container {\n gap: var(--spacing-xxs);\n }\n\n .breadcrumb-button {\n padding: var(--spacing-xxs) var(--spacing-xs);\n font-size: 12px;\n }\n}\n","import { Component, Prop, Event, EventEmitter, h, Fragment } from '@stencil/core';\n\nexport interface BreadcrumbItem {\n label: string;\n path?: string;\n isActive?: boolean;\n}\n\n@Component({\n tag: 'bh-breadcrumbs',\n styleUrl: 'bh-breadcrumbs.css',\n shadow: true,\n})\nexport class BhBreadcrumbs {\n /**\n * Array of breadcrumb items\n */\n @Prop() items: BreadcrumbItem[] | string = [];\n\n /**\n * Separator icon name (Material Symbols)\n */\n @Prop() separator: string = 'chevron_right';\n\n /**\n * Whether to show the home button\n */\n @Prop() showHome: boolean = true;\n\n /**\n * Maximum number of visible items before collapsing\n */\n @Prop() maxVisibleItems: number = 4;\n\n /**\n * Event emitted when a breadcrumb item is clicked\n */\n @Event() bhItemClick!: EventEmitter<BreadcrumbItem>;\n\n /**\n * Event emitted when navigating to a path\n */\n @Event() bhNavigate!: EventEmitter<string>;\n\n private get parsedItems(): BreadcrumbItem[] {\n if (typeof this.items === 'string') {\n try {\n return JSON.parse(this.items);\n } catch {\n return [];\n }\n }\n return this.items || [];\n }\n\n private get displayData() {\n const items = this.parsedItems;\n if (!items || items.length <= this.maxVisibleItems) {\n return {\n displayItems: items ? [...items] : [],\n showEllipsis: false,\n collapsedItems: [],\n };\n } else {\n const lastItems = items.slice(-(this.maxVisibleItems - 2));\n return {\n displayItems: [items[0], ...lastItems],\n showEllipsis: true,\n collapsedItems: items.slice(1, -(this.maxVisibleItems - 2)),\n };\n }\n }\n\n private handleItemClick(item: BreadcrumbItem) {\n if (!item.isActive && item.path) {\n this.bhItemClick.emit(item);\n this.bhNavigate.emit(item.path);\n }\n }\n\n private handleHomeClick = () => {\n const homeItem: BreadcrumbItem = {\n label: 'Home',\n path: '/',\n };\n this.bhItemClick.emit(homeItem);\n this.bhNavigate.emit('/');\n };\n\n private handleEllipsisClick = () => {\n const { collapsedItems } = this.displayData;\n if (collapsedItems.length > 0) {\n this.handleItemClick(collapsedItems[0]);\n }\n };\n\n private renderBreadcrumbItem(item: BreadcrumbItem, index: number) {\n if (item.isActive || !item.path) {\n return (\n <div\n key={index}\n class=\"breadcrumb-button breadcrumb-current\"\n aria-current=\"page\"\n >\n <span class=\"breadcrumb-text\">{item.label}</span>\n </div>\n );\n }\n\n return (\n <button\n key={index}\n type=\"button\"\n class=\"breadcrumb-button\"\n onClick={() => this.handleItemClick(item)}\n >\n <span class=\"breadcrumb-text\">{item.label}</span>\n </button>\n );\n }\n\n private renderSeparator() {\n return (\n <div class=\"breadcrumb-separator\">\n <span class=\"material-symbols-outlined\">{this.separator}</span>\n </div>\n );\n }\n\n render() {\n const { displayItems, showEllipsis, collapsedItems } = this.displayData;\n\n return (\n <nav class=\"breadcrumbs\" aria-label=\"Breadcrumb\">\n <div class=\"breadcrumbs-container\">\n {/* Home button */}\n {this.showHome && (\n <div class=\"breadcrumb-item\">\n <bh-button-icon\n hierarchy=\"quaternary\"\n size=\"xs\"\n iconName=\"cottage\"\n onClick={this.handleHomeClick}\n aria-label=\"Home\"\n />\n </div>\n )}\n\n {/* Separator after home */}\n {this.showHome && (displayItems.length > 0 || showEllipsis) && this.renderSeparator()}\n\n {/* With ellipsis */}\n {showEllipsis && displayItems.length > 0 && (\n <Fragment>\n <div class=\"breadcrumb-item\">\n {this.renderBreadcrumbItem(displayItems[0], 0)}\n </div>\n\n {this.renderSeparator()}\n\n {/* Ellipsis button */}\n <div class=\"breadcrumb-item\">\n <button\n type=\"button\"\n class=\"breadcrumb-button breadcrumb-ellipsis\"\n onClick={this.handleEllipsisClick}\n title={`Show ${collapsedItems.length} hidden items`}\n >\n <span class=\"breadcrumb-text\">...</span>\n </button>\n </div>\n\n {this.renderSeparator()}\n\n {/* Remaining items */}\n {displayItems.slice(1).map((item, index) => (\n <Fragment>\n <div class=\"breadcrumb-item\" key={`item-${index + 1}`}>\n {this.renderBreadcrumbItem(item, index + 1)}\n </div>\n\n {index < displayItems.slice(1).length - 1 && this.renderSeparator()}\n </Fragment>\n ))}\n </Fragment>\n )}\n\n {/* Without ellipsis */}\n {!showEllipsis && displayItems.map((item, index) => (\n <Fragment>\n <div class=\"breadcrumb-item\" key={`item-${index}`}>\n {this.renderBreadcrumbItem(item, index)}\n </div>\n\n {index < displayItems.length - 1 && this.renderSeparator()}\n </Fragment>\n ))}\n </div>\n </nav>\n );\n }\n}\n"],"version":3}