@3ddv/software-division-components 1.4.1 → 1.4.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 (635) hide show
  1. package/.claude/settings.local.json +9 -0
  2. package/.postcssrc.json +5 -0
  3. package/.storybook/main.ts +28 -0
  4. package/.storybook/manager-head.html +1 -0
  5. package/.storybook/preview.ts +30 -0
  6. package/.storybook/tsconfig.json +13 -0
  7. package/.storybook/typings.d.ts +4 -0
  8. package/LICENSE.md +21 -0
  9. package/components.json +3 -0
  10. package/{fesm2022 → dist/fesm2022}/3ddv-software-division-components.mjs +4 -2
  11. package/dist/fesm2022/3ddv-software-division-components.mjs.map +1 -0
  12. package/{generic → dist/generic}/button/button.component.d.ts +3 -1
  13. package/dist/generic/button/button.component.d.ts.map +1 -0
  14. package/dist/styles.css +2 -0
  15. package/dist/tailwind.config.js +19 -0
  16. package/documentation.json +5052 -0
  17. package/ng-package.json +10 -0
  18. package/package.json +39 -10
  19. package/public/3ddv-logo.jpg +0 -0
  20. package/public/neighbours-after.png +0 -0
  21. package/public/neighbours-before.png +0 -0
  22. package/src/backoffice/checkbox/checkbox.component.css +193 -0
  23. package/src/backoffice/checkbox/checkbox.component.html +23 -0
  24. package/src/backoffice/checkbox/checkbox.component.ts +252 -0
  25. package/src/backoffice/checkbox/index.ts +1 -0
  26. package/src/backoffice/checkbox/public-api.ts +1 -0
  27. package/src/backoffice/checkbox/story/checkbox.stories.ts +304 -0
  28. package/src/backoffice/datepicker/datepicker.component.css +262 -0
  29. package/src/backoffice/datepicker/datepicker.component.html +40 -0
  30. package/src/backoffice/datepicker/datepicker.component.ts +366 -0
  31. package/src/backoffice/datepicker/index.ts +1 -0
  32. package/src/backoffice/datepicker/public-api.ts +2 -0
  33. package/src/backoffice/datepicker/story/datepicker.stories.ts +32 -0
  34. package/src/backoffice/datepicker/ui/ui-calendar-helm/src/index.ts +14 -0
  35. package/src/backoffice/datepicker/ui/ui-calendar-helm/src/lib/hlm-calendar-multi.ts +183 -0
  36. package/src/backoffice/datepicker/ui/ui-calendar-helm/src/lib/hlm-calendar.ts +171 -0
  37. package/src/backoffice/datepicker/ui/ui-date-picker-helm/src/index.ts +16 -0
  38. package/src/backoffice/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker-multi.token.ts +43 -0
  39. package/src/backoffice/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker-multi.ts +177 -0
  40. package/src/backoffice/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker.token.ts +43 -0
  41. package/src/backoffice/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker.ts +167 -0
  42. package/src/backoffice/datepicker/ui/ui-icon-helm/src/index.ts +11 -0
  43. package/src/backoffice/datepicker/ui/ui-icon-helm/src/lib/hlm-icon.token.ts +20 -0
  44. package/src/backoffice/datepicker/ui/ui-icon-helm/src/lib/hlm-icon.ts +35 -0
  45. package/src/backoffice/datepicker/ui/ui-popover-helm/src/index.ts +15 -0
  46. package/src/backoffice/datepicker/ui/ui-popover-helm/src/lib/hlm-popover-close.ts +19 -0
  47. package/src/backoffice/datepicker/ui/ui-popover-helm/src/lib/hlm-popover-content.ts +30 -0
  48. package/src/backoffice/index.ts +1 -0
  49. package/src/backoffice/input/index.ts +1 -0
  50. package/src/backoffice/input/input.component.css +319 -0
  51. package/src/backoffice/input/input.component.html +51 -0
  52. package/src/backoffice/input/input.component.ts +497 -0
  53. package/src/backoffice/input/public-api.ts +2 -0
  54. package/src/backoffice/input/story/input.stories.ts +243 -0
  55. package/src/backoffice/package.json +8 -0
  56. package/src/backoffice/public-api.ts +5 -0
  57. package/src/backoffice/radio/index.ts +1 -0
  58. package/src/backoffice/radio/public-api.ts +1 -0
  59. package/src/backoffice/radio/radio.component.css +143 -0
  60. package/src/backoffice/radio/radio.component.html +15 -0
  61. package/src/backoffice/radio/radio.component.ts +154 -0
  62. package/src/backoffice/radio/story/radio.stories.ts +287 -0
  63. package/src/backoffice/table/_components/pagination/pagination.component.css +117 -0
  64. package/src/backoffice/table/_components/pagination/pagination.component.html +55 -0
  65. package/src/backoffice/table/_components/pagination/pagination.component.ts +79 -0
  66. package/src/backoffice/table/_components/selection-table-head/selection-table-head.component.css +0 -0
  67. package/src/backoffice/table/_components/selection-table-head/selection-table-head.component.html +6 -0
  68. package/src/backoffice/table/_components/selection-table-head/selection-table-head.component.ts +36 -0
  69. package/src/backoffice/table/_components/selection-table-row/selection-table-row.component.css +0 -0
  70. package/src/backoffice/table/_components/selection-table-row/selection-table-row.component.html +5 -0
  71. package/src/backoffice/table/_components/selection-table-row/selection-table-row.component.ts +12 -0
  72. package/src/backoffice/table/_components/sort-header-button/sort-header-button.component.css +14 -0
  73. package/src/backoffice/table/_components/sort-header-button/sort-header-button.component.html +11 -0
  74. package/src/backoffice/table/_components/sort-header-button/sort-header-button.component.ts +55 -0
  75. package/src/backoffice/table/index.ts +1 -0
  76. package/src/backoffice/table/public-api.ts +43 -0
  77. package/src/backoffice/table/story/table.stories.ts +364 -0
  78. package/src/backoffice/table/table.component.css +172 -0
  79. package/src/backoffice/table/table.component.html +53 -0
  80. package/src/backoffice/table/table.component.ts +347 -0
  81. package/src/backoffice/table/ui/ui-icon-helm/src/index.ts +11 -0
  82. package/src/backoffice/table/ui/ui-icon-helm/src/lib/hlm-icon.token.ts +20 -0
  83. package/src/backoffice/table/ui/ui-icon-helm/src/lib/hlm-icon.ts +35 -0
  84. package/src/backoffice/table/ui/ui-table-helm/src/index.ts +13 -0
  85. package/src/backoffice/table/ui/ui-table-helm/src/lib/hlm-table.ts +220 -0
  86. package/src/dvm/cart/cart.component.css +103 -0
  87. package/src/dvm/cart/cart.component.html +31 -0
  88. package/src/dvm/cart/cart.component.ts +49 -0
  89. package/src/dvm/cart/cart.stories.ts +370 -0
  90. package/src/dvm/cart/cart.types.ts +8 -0
  91. package/src/dvm/cart/index.ts +2 -0
  92. package/src/dvm/cart/public-api.ts +8 -0
  93. package/src/dvm/cart/seat-list.component.css +281 -0
  94. package/src/dvm/cart/seat-list.component.html +85 -0
  95. package/src/dvm/cart/seat-list.component.ts +76 -0
  96. package/src/dvm/cart/seat-list.stories.ts +337 -0
  97. package/src/dvm/cart-item/cart-item.component.html +1 -0
  98. package/src/dvm/cart-item/cart-item.component.ts +8 -0
  99. package/src/dvm/cart-item/cart-item.service.ts +8 -0
  100. package/src/dvm/cart-item/cart.stories.ts +31 -0
  101. package/src/dvm/cart-item/index.ts +1 -0
  102. package/src/dvm/cart-item/package.json +5 -0
  103. package/src/dvm/cart-item/public-api.ts +6 -0
  104. package/src/dvm/index.ts +1 -0
  105. package/src/dvm/legend/index.ts +1 -0
  106. package/src/dvm/legend/legend.component.css +49 -0
  107. package/src/dvm/legend/legend.component.html +8 -0
  108. package/src/dvm/legend/legend.component.ts +41 -0
  109. package/src/dvm/legend/legend.stories.ts +16 -0
  110. package/src/dvm/legend/package.json +5 -0
  111. package/src/dvm/legend/public-api.ts +7 -0
  112. package/src/dvm/legend/types.ts +6 -0
  113. package/src/dvm/legend/ui/legend-elements/index.ts +1 -0
  114. package/src/dvm/legend/ui/legend-elements/legend-elements.component.css +49 -0
  115. package/src/dvm/legend/ui/legend-elements/legend-elements.component.html +8 -0
  116. package/src/dvm/legend/ui/legend-elements/legend-elements.component.ts +41 -0
  117. package/src/dvm/loader/index.ts +1 -0
  118. package/src/dvm/loader/loader.component.html +1 -0
  119. package/src/dvm/loader/loader.component.ts +8 -0
  120. package/src/dvm/loader/loader.service.ts +8 -0
  121. package/src/dvm/loader/loader.stories.ts +31 -0
  122. package/src/dvm/loader/package.json +5 -0
  123. package/src/dvm/loader/public-api.ts +6 -0
  124. package/src/dvm/map-loader/index.ts +1 -0
  125. package/src/dvm/map-loader/map-loader.component.css +91 -0
  126. package/src/dvm/map-loader/map-loader.component.html +23 -0
  127. package/src/dvm/map-loader/map-loader.component.ts +187 -0
  128. package/src/dvm/map-loader/map-loader.stories.ts +16 -0
  129. package/src/dvm/map-loader/package.json +5 -0
  130. package/src/dvm/map-loader/public-api.ts +5 -0
  131. package/src/dvm/neighbors/index.ts +1 -0
  132. package/src/dvm/neighbors/neighbors.component.css +158 -0
  133. package/src/dvm/neighbors/neighbors.component.html +45 -0
  134. package/src/dvm/neighbors/neighbors.component.ts +218 -0
  135. package/src/dvm/neighbors/package.json +5 -0
  136. package/src/dvm/neighbors/public-api.ts +2 -0
  137. package/src/dvm/neighbors/story/arrow-left-black-icon.svg +3 -0
  138. package/src/dvm/neighbors/story/mock-data.ts +15 -0
  139. package/src/dvm/neighbors/story/neighbours.stories.css +12 -0
  140. package/src/dvm/neighbors/story/neighbours.stories.ts +117 -0
  141. package/src/dvm/neighbors/types.ts +14 -0
  142. package/src/dvm/package.json +7 -0
  143. package/src/dvm/popover/base-popover.component.ts +70 -0
  144. package/src/dvm/popover/index.ts +1 -0
  145. package/src/dvm/popover/package.json +5 -0
  146. package/src/dvm/popover/popover.component.css +227 -0
  147. package/src/dvm/popover/popover.component.html +27 -0
  148. package/src/dvm/popover/popover.component.ts +236 -0
  149. package/src/dvm/popover/popover.config.ts +30 -0
  150. package/src/dvm/popover/popover.service.ts +627 -0
  151. package/src/dvm/popover/popover.stories.ts +873 -0
  152. package/src/dvm/popover/public-api.ts +14 -0
  153. package/src/dvm/popover/seat-popover/seat-popover.component.css +89 -0
  154. package/src/dvm/popover/seat-popover/seat-popover.component.html +40 -0
  155. package/src/dvm/popover/seat-popover/seat-popover.component.ts +74 -0
  156. package/src/dvm/popover/section-popover/section-popover.component.css +157 -0
  157. package/src/dvm/popover/section-popover/section-popover.component.html +58 -0
  158. package/src/dvm/popover/section-popover/section-popover.component.ts +106 -0
  159. package/src/dvm/popover/services/dvm-popover-positioner.service.ts +73 -0
  160. package/src/dvm/popover/services/popover-manager.service.ts +88 -0
  161. package/src/dvm/popover/transformers/base-popover-data-transformer.ts +36 -0
  162. package/src/dvm/popover/types.ts +104 -0
  163. package/src/dvm/public-api.ts +9 -0
  164. package/src/dvm/stepper/index.ts +1 -0
  165. package/src/dvm/stepper/package.json +5 -0
  166. package/src/dvm/stepper/public-api.ts +5 -0
  167. package/src/dvm/stepper/stepper.component.css +142 -0
  168. package/src/dvm/stepper/stepper.component.html +9 -0
  169. package/src/dvm/stepper/stepper.component.ts +102 -0
  170. package/src/dvm/stepper/types.ts +6 -0
  171. package/src/dvm/ticket-info-item/index.ts +1 -0
  172. package/src/dvm/ticket-info-item/package.json +5 -0
  173. package/src/dvm/ticket-info-item/public-api.ts +6 -0
  174. package/src/dvm/ticket-info-item/ticket-info-item.component.html +1 -0
  175. package/src/dvm/ticket-info-item/ticket-info-item.component.ts +8 -0
  176. package/src/dvm/ticket-info-item/ticket-info-item.service.ts +8 -0
  177. package/src/dvm/ticket-info-item/ticket-info-item.stories.ts +31 -0
  178. package/src/generic/add-digital-wallet/add-digital-wallet.component.css +76 -0
  179. package/src/generic/add-digital-wallet/add-digital-wallet.component.html +46 -0
  180. package/src/generic/add-digital-wallet/add-digital-wallet.component.ts +45 -0
  181. package/src/generic/add-digital-wallet/index.ts +1 -0
  182. package/src/generic/add-digital-wallet/public-api.ts +1 -0
  183. package/src/generic/braintree/braintree.component.css +7 -0
  184. package/src/generic/braintree/braintree.component.ts +134 -0
  185. package/src/generic/braintree/index.ts +1 -0
  186. package/src/generic/braintree/package.json +5 -0
  187. package/src/generic/braintree/public-api.ts +6 -0
  188. package/src/generic/braintree/story/braintree.stories.css +3 -0
  189. package/src/generic/braintree/story/braintree.stories.ts +27 -0
  190. package/src/generic/braintree/types.ts +28 -0
  191. package/src/generic/button/button.component.css +295 -0
  192. package/src/generic/button/button.component.html +10 -0
  193. package/src/generic/button/button.component.ts +352 -0
  194. package/src/generic/button/index.ts +1 -0
  195. package/src/generic/button/package.json +5 -0
  196. package/src/generic/button/public-api.ts +5 -0
  197. package/src/generic/button/story/button.stories.ts +384 -0
  198. package/src/generic/button/ui/ui-button-helm/src/index.ts +10 -0
  199. package/src/generic/button/ui/ui-button-helm/src/lib/hlm-button.token.ts +22 -0
  200. package/src/generic/button/ui/ui-button-helm/src/lib/hlm-button.ts +62 -0
  201. package/src/generic/carousel/carousel-item.component.ts +15 -0
  202. package/src/generic/carousel/carousel-item.directive.ts +14 -0
  203. package/src/generic/carousel/carousel.component.css +90 -0
  204. package/src/generic/carousel/carousel.component.html +13 -0
  205. package/src/generic/carousel/carousel.component.ts +44 -0
  206. package/src/generic/carousel/index.ts +1 -0
  207. package/src/generic/carousel/public-api.ts +2 -0
  208. package/src/generic/carousel/ui/ui-carousel-helm/src/index.ts +29 -0
  209. package/src/generic/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-content.ts +23 -0
  210. package/src/generic/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-item.ts +25 -0
  211. package/src/generic/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-next.ts +58 -0
  212. package/src/generic/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-previous.ts +61 -0
  213. package/src/generic/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-slide-display.ts +36 -0
  214. package/src/generic/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel.ts +105 -0
  215. package/src/generic/dialog/dialog.component.css +5 -0
  216. package/src/generic/dialog/dialog.component.html +3 -0
  217. package/src/generic/dialog/dialog.component.ts +20 -0
  218. package/src/generic/dialog/dialog.stories.ts +14 -0
  219. package/src/generic/dialog/index.ts +1 -0
  220. package/src/generic/dialog/libs/ui-dialog-helm/src/index.ts +37 -0
  221. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-close.ts +20 -0
  222. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-content.ts +56 -0
  223. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-description.ts +17 -0
  224. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-footer.ts +19 -0
  225. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-header.ts +19 -0
  226. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-overlay.ts +23 -0
  227. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-title.ts +19 -0
  228. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog.service.ts +59 -0
  229. package/src/generic/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog.ts +31 -0
  230. package/src/generic/dialog/package.json +9 -0
  231. package/src/generic/dialog/public-api.ts +6 -0
  232. package/src/generic/dialog/tsconfig.json +7 -0
  233. package/src/generic/dialog/ui/dialog-close-button/dialog-close-button.component.css +0 -0
  234. package/src/generic/dialog/ui/dialog-close-button/dialog-close-button.component.html +1 -0
  235. package/src/generic/dialog/ui/dialog-close-button/dialog-close-button.component.ts +17 -0
  236. package/src/generic/dialog/ui/dialog-footer/dialog-footer.component.css +0 -0
  237. package/src/generic/dialog/ui/dialog-footer/dialog-footer.component.html +3 -0
  238. package/src/generic/dialog/ui/dialog-footer/dialog-footer.component.ts +11 -0
  239. package/src/generic/dialog/ui/dialog-header/dialog-header.component.css +0 -0
  240. package/src/generic/dialog/ui/dialog-header/dialog-header.component.html +8 -0
  241. package/src/generic/dialog/ui/dialog-header/dialog-header.component.ts +14 -0
  242. package/src/generic/drawer/drawer.component.html +1 -0
  243. package/src/generic/drawer/drawer.component.ts +8 -0
  244. package/src/generic/drawer/drawer.service.ts +8 -0
  245. package/src/generic/drawer/drawer.stories.ts +31 -0
  246. package/src/generic/drawer/index.ts +1 -0
  247. package/src/generic/drawer/package.json +5 -0
  248. package/src/generic/drawer/public-api.ts +6 -0
  249. package/src/generic/icon/icon.component.css +7 -0
  250. package/src/generic/icon/icon.component.html +3 -0
  251. package/src/generic/icon/icon.component.ts +86 -0
  252. package/src/generic/icon/icon.stories.ts +16 -0
  253. package/src/generic/icon/index.ts +1 -0
  254. package/src/generic/icon/lib/ui-icon-helm/src/index.ts +11 -0
  255. package/src/generic/icon/lib/ui-icon-helm/src/lib/hlm-icon.token.ts +20 -0
  256. package/src/generic/icon/lib/ui-icon-helm/src/lib/hlm-icon.ts +36 -0
  257. package/src/generic/icon/package.json +9 -0
  258. package/src/generic/icon/public-api.ts +5 -0
  259. package/src/generic/icon/tsconfig.json +7 -0
  260. package/src/generic/index.ts +1 -0
  261. package/src/generic/package.json +7 -0
  262. package/src/generic/public-api.ts +8 -0
  263. package/src/generic/select/index.ts +1 -0
  264. package/src/generic/select/lib/hlm-select-content.ts +29 -0
  265. package/src/generic/select/lib/hlm-select-group.ts +17 -0
  266. package/src/generic/select/lib/hlm-select-label.ts +26 -0
  267. package/src/generic/select/lib/hlm-select-option.ts +37 -0
  268. package/src/generic/select/lib/hlm-select-scroll-down.ts +24 -0
  269. package/src/generic/select/lib/hlm-select-scroll-up.ts +23 -0
  270. package/src/generic/select/lib/hlm-select-trigger.ts +53 -0
  271. package/src/generic/select/lib/hlm-select-value.ts +17 -0
  272. package/src/generic/select/lib/hlm-select.ts +15 -0
  273. package/src/generic/select/lib/index.ts +38 -0
  274. package/src/generic/select/public-api.ts +2 -0
  275. package/src/generic/select/select.component.css +65 -0
  276. package/src/generic/select/select.component.html +19 -0
  277. package/src/generic/select/select.component.ts +25 -0
  278. package/src/generic/select/types.ts +4 -0
  279. package/src/private-exports.ts +1 -0
  280. package/src/public-api.ts +10 -0
  281. package/src/shared/apply-theme-variables/apply-theme-variables.ts +35 -0
  282. package/src/shared/apply-theme-variables/index.ts +1 -0
  283. package/src/shared/format-value.pipe.ts +23 -0
  284. package/src/shared/index.ts +1 -0
  285. package/src/shared/lib-provider/config-token.ts +4 -0
  286. package/src/shared/lib-provider/index.ts +1 -0
  287. package/src/shared/lib-provider/provide-sdc.ts +24 -0
  288. package/src/shared/lib-provider/public-api.ts +1 -0
  289. package/src/shared/public-api.ts +6 -0
  290. package/src/shared/screen-observer/index.ts +2 -0
  291. package/src/shared/screen-observer/provide-screen-observer.ts +17 -0
  292. package/src/shared/screen-observer/screen-observer.ts +56 -0
  293. package/src/shared/screen-observer/sizable-base.ts +70 -0
  294. package/src/shared/theme-provider/generic-theme.ts +1 -0
  295. package/src/shared/theme-provider/index.ts +1 -0
  296. package/src/shared/theme-provider/public-api.ts +1 -0
  297. package/src/shared/theme-provider/theme-provider.directive.ts +17 -0
  298. package/src/shared/themes/sdc.css +153 -0
  299. package/src/shared/types.ts +15 -0
  300. package/src/types/sizes.type.ts +3 -0
  301. package/src/utils/index.ts +1 -0
  302. package/src/utils/public-api.ts +1 -0
  303. package/src/utils/validate-styles-for-component.ts +39 -0
  304. package/styles.css +40 -2
  305. package/tsconfig.json +30 -0
  306. package/tsconfig.spec.json +15 -0
  307. package/fesm2022/3ddv-software-division-components.mjs.map +0 -1
  308. package/generic/button/button.component.d.ts.map +0 -1
  309. /package/{3ddv-software-division-components.d.ts.map → dist/3ddv-software-division-components.d.ts.map} +0 -0
  310. /package/{README.md → dist/README.md} +0 -0
  311. /package/{backoffice → dist/backoffice}/checkbox/checkbox.component.d.ts +0 -0
  312. /package/{backoffice → dist/backoffice}/checkbox/checkbox.component.d.ts.map +0 -0
  313. /package/{backoffice → dist/backoffice}/checkbox/index.d.ts +0 -0
  314. /package/{backoffice → dist/backoffice}/checkbox/index.d.ts.map +0 -0
  315. /package/{backoffice → dist/backoffice}/checkbox/public-api.d.ts +0 -0
  316. /package/{backoffice → dist/backoffice}/checkbox/public-api.d.ts.map +0 -0
  317. /package/{backoffice → dist/backoffice}/datepicker/datepicker.component.d.ts +0 -0
  318. /package/{backoffice → dist/backoffice}/datepicker/datepicker.component.d.ts.map +0 -0
  319. /package/{backoffice → dist/backoffice}/datepicker/index.d.ts +0 -0
  320. /package/{backoffice → dist/backoffice}/datepicker/index.d.ts.map +0 -0
  321. /package/{backoffice → dist/backoffice}/datepicker/public-api.d.ts +0 -0
  322. /package/{backoffice → dist/backoffice}/datepicker/public-api.d.ts.map +0 -0
  323. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-calendar-helm/src/index.d.ts +0 -0
  324. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-calendar-helm/src/index.d.ts.map +0 -0
  325. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-calendar-helm/src/lib/hlm-calendar-multi.d.ts +0 -0
  326. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-calendar-helm/src/lib/hlm-calendar-multi.d.ts.map +0 -0
  327. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-calendar-helm/src/lib/hlm-calendar.d.ts +0 -0
  328. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-calendar-helm/src/lib/hlm-calendar.d.ts.map +0 -0
  329. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/index.d.ts +0 -0
  330. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/index.d.ts.map +0 -0
  331. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker-multi.d.ts +0 -0
  332. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker-multi.d.ts.map +0 -0
  333. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker-multi.token.d.ts +0 -0
  334. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker-multi.token.d.ts.map +0 -0
  335. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker.d.ts +0 -0
  336. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker.d.ts.map +0 -0
  337. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker.token.d.ts +0 -0
  338. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-date-picker-helm/src/lib/hlm-date-picker.token.d.ts.map +0 -0
  339. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-icon-helm/src/index.d.ts +0 -0
  340. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-icon-helm/src/index.d.ts.map +0 -0
  341. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-icon-helm/src/lib/hlm-icon.d.ts +0 -0
  342. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-icon-helm/src/lib/hlm-icon.d.ts.map +0 -0
  343. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-icon-helm/src/lib/hlm-icon.token.d.ts +0 -0
  344. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-icon-helm/src/lib/hlm-icon.token.d.ts.map +0 -0
  345. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-popover-helm/src/index.d.ts +0 -0
  346. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-popover-helm/src/index.d.ts.map +0 -0
  347. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-popover-helm/src/lib/hlm-popover-close.d.ts +0 -0
  348. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-popover-helm/src/lib/hlm-popover-close.d.ts.map +0 -0
  349. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-popover-helm/src/lib/hlm-popover-content.d.ts +0 -0
  350. /package/{backoffice → dist/backoffice}/datepicker/ui/ui-popover-helm/src/lib/hlm-popover-content.d.ts.map +0 -0
  351. /package/{backoffice → dist/backoffice}/index.d.ts +0 -0
  352. /package/{backoffice → dist/backoffice}/index.d.ts.map +0 -0
  353. /package/{backoffice → dist/backoffice}/input/index.d.ts +0 -0
  354. /package/{backoffice → dist/backoffice}/input/index.d.ts.map +0 -0
  355. /package/{backoffice → dist/backoffice}/input/input.component.d.ts +0 -0
  356. /package/{backoffice → dist/backoffice}/input/input.component.d.ts.map +0 -0
  357. /package/{backoffice → dist/backoffice}/input/public-api.d.ts +0 -0
  358. /package/{backoffice → dist/backoffice}/input/public-api.d.ts.map +0 -0
  359. /package/{backoffice → dist/backoffice}/public-api.d.ts +0 -0
  360. /package/{backoffice → dist/backoffice}/public-api.d.ts.map +0 -0
  361. /package/{backoffice → dist/backoffice}/radio/index.d.ts +0 -0
  362. /package/{backoffice → dist/backoffice}/radio/index.d.ts.map +0 -0
  363. /package/{backoffice → dist/backoffice}/radio/public-api.d.ts +0 -0
  364. /package/{backoffice → dist/backoffice}/radio/public-api.d.ts.map +0 -0
  365. /package/{backoffice → dist/backoffice}/radio/radio.component.d.ts +0 -0
  366. /package/{backoffice → dist/backoffice}/radio/radio.component.d.ts.map +0 -0
  367. /package/{backoffice → dist/backoffice}/table/_components/pagination/pagination.component.d.ts +0 -0
  368. /package/{backoffice → dist/backoffice}/table/_components/pagination/pagination.component.d.ts.map +0 -0
  369. /package/{backoffice → dist/backoffice}/table/_components/selection-table-head/selection-table-head.component.d.ts +0 -0
  370. /package/{backoffice → dist/backoffice}/table/_components/selection-table-head/selection-table-head.component.d.ts.map +0 -0
  371. /package/{backoffice → dist/backoffice}/table/_components/selection-table-row/selection-table-row.component.d.ts +0 -0
  372. /package/{backoffice → dist/backoffice}/table/_components/selection-table-row/selection-table-row.component.d.ts.map +0 -0
  373. /package/{backoffice → dist/backoffice}/table/_components/sort-header-button/sort-header-button.component.d.ts +0 -0
  374. /package/{backoffice → dist/backoffice}/table/_components/sort-header-button/sort-header-button.component.d.ts.map +0 -0
  375. /package/{backoffice → dist/backoffice}/table/index.d.ts +0 -0
  376. /package/{backoffice → dist/backoffice}/table/index.d.ts.map +0 -0
  377. /package/{backoffice → dist/backoffice}/table/public-api.d.ts +0 -0
  378. /package/{backoffice → dist/backoffice}/table/public-api.d.ts.map +0 -0
  379. /package/{backoffice → dist/backoffice}/table/table.component.d.ts +0 -0
  380. /package/{backoffice → dist/backoffice}/table/table.component.d.ts.map +0 -0
  381. /package/{backoffice → dist/backoffice}/table/ui/ui-icon-helm/src/index.d.ts +0 -0
  382. /package/{backoffice → dist/backoffice}/table/ui/ui-icon-helm/src/index.d.ts.map +0 -0
  383. /package/{backoffice → dist/backoffice}/table/ui/ui-icon-helm/src/lib/hlm-icon.d.ts +0 -0
  384. /package/{backoffice → dist/backoffice}/table/ui/ui-icon-helm/src/lib/hlm-icon.d.ts.map +0 -0
  385. /package/{backoffice → dist/backoffice}/table/ui/ui-icon-helm/src/lib/hlm-icon.token.d.ts +0 -0
  386. /package/{backoffice → dist/backoffice}/table/ui/ui-icon-helm/src/lib/hlm-icon.token.d.ts.map +0 -0
  387. /package/{backoffice → dist/backoffice}/table/ui/ui-table-helm/src/index.d.ts +0 -0
  388. /package/{backoffice → dist/backoffice}/table/ui/ui-table-helm/src/index.d.ts.map +0 -0
  389. /package/{backoffice → dist/backoffice}/table/ui/ui-table-helm/src/lib/hlm-table.d.ts +0 -0
  390. /package/{backoffice → dist/backoffice}/table/ui/ui-table-helm/src/lib/hlm-table.d.ts.map +0 -0
  391. /package/{dvm → dist/dvm}/cart/cart.component.d.ts +0 -0
  392. /package/{dvm → dist/dvm}/cart/cart.component.d.ts.map +0 -0
  393. /package/{dvm → dist/dvm}/cart/cart.types.d.ts +0 -0
  394. /package/{dvm → dist/dvm}/cart/cart.types.d.ts.map +0 -0
  395. /package/{dvm → dist/dvm}/cart/index.d.ts +0 -0
  396. /package/{dvm → dist/dvm}/cart/index.d.ts.map +0 -0
  397. /package/{dvm → dist/dvm}/cart/public-api.d.ts +0 -0
  398. /package/{dvm → dist/dvm}/cart/public-api.d.ts.map +0 -0
  399. /package/{dvm → dist/dvm}/cart/seat-list.component.d.ts +0 -0
  400. /package/{dvm → dist/dvm}/cart/seat-list.component.d.ts.map +0 -0
  401. /package/{dvm → dist/dvm}/cart-item/cart-item.component.d.ts +0 -0
  402. /package/{dvm → dist/dvm}/cart-item/cart-item.component.d.ts.map +0 -0
  403. /package/{dvm → dist/dvm}/cart-item/cart-item.service.d.ts +0 -0
  404. /package/{dvm → dist/dvm}/cart-item/cart-item.service.d.ts.map +0 -0
  405. /package/{dvm → dist/dvm}/cart-item/index.d.ts +0 -0
  406. /package/{dvm → dist/dvm}/cart-item/index.d.ts.map +0 -0
  407. /package/{dvm → dist/dvm}/cart-item/public-api.d.ts +0 -0
  408. /package/{dvm → dist/dvm}/cart-item/public-api.d.ts.map +0 -0
  409. /package/{dvm → dist/dvm}/index.d.ts +0 -0
  410. /package/{dvm → dist/dvm}/index.d.ts.map +0 -0
  411. /package/{dvm → dist/dvm}/legend/index.d.ts +0 -0
  412. /package/{dvm → dist/dvm}/legend/index.d.ts.map +0 -0
  413. /package/{dvm → dist/dvm}/legend/legend.component.d.ts +0 -0
  414. /package/{dvm → dist/dvm}/legend/legend.component.d.ts.map +0 -0
  415. /package/{dvm → dist/dvm}/legend/public-api.d.ts +0 -0
  416. /package/{dvm → dist/dvm}/legend/public-api.d.ts.map +0 -0
  417. /package/{dvm → dist/dvm}/legend/types.d.ts +0 -0
  418. /package/{dvm → dist/dvm}/legend/types.d.ts.map +0 -0
  419. /package/{dvm → dist/dvm}/legend/ui/legend-elements/index.d.ts +0 -0
  420. /package/{dvm → dist/dvm}/legend/ui/legend-elements/index.d.ts.map +0 -0
  421. /package/{dvm → dist/dvm}/legend/ui/legend-elements/legend-elements.component.d.ts +0 -0
  422. /package/{dvm → dist/dvm}/legend/ui/legend-elements/legend-elements.component.d.ts.map +0 -0
  423. /package/{dvm → dist/dvm}/loader/index.d.ts +0 -0
  424. /package/{dvm → dist/dvm}/loader/index.d.ts.map +0 -0
  425. /package/{dvm → dist/dvm}/loader/loader.component.d.ts +0 -0
  426. /package/{dvm → dist/dvm}/loader/loader.component.d.ts.map +0 -0
  427. /package/{dvm → dist/dvm}/loader/loader.service.d.ts +0 -0
  428. /package/{dvm → dist/dvm}/loader/loader.service.d.ts.map +0 -0
  429. /package/{dvm → dist/dvm}/loader/public-api.d.ts +0 -0
  430. /package/{dvm → dist/dvm}/loader/public-api.d.ts.map +0 -0
  431. /package/{dvm → dist/dvm}/map-loader/index.d.ts +0 -0
  432. /package/{dvm → dist/dvm}/map-loader/index.d.ts.map +0 -0
  433. /package/{dvm → dist/dvm}/map-loader/map-loader.component.d.ts +0 -0
  434. /package/{dvm → dist/dvm}/map-loader/map-loader.component.d.ts.map +0 -0
  435. /package/{dvm → dist/dvm}/map-loader/public-api.d.ts +0 -0
  436. /package/{dvm → dist/dvm}/map-loader/public-api.d.ts.map +0 -0
  437. /package/{dvm → dist/dvm}/neighbors/index.d.ts +0 -0
  438. /package/{dvm → dist/dvm}/neighbors/index.d.ts.map +0 -0
  439. /package/{dvm → dist/dvm}/neighbors/neighbors.component.d.ts +0 -0
  440. /package/{dvm → dist/dvm}/neighbors/neighbors.component.d.ts.map +0 -0
  441. /package/{dvm → dist/dvm}/neighbors/public-api.d.ts +0 -0
  442. /package/{dvm → dist/dvm}/neighbors/public-api.d.ts.map +0 -0
  443. /package/{dvm → dist/dvm}/neighbors/types.d.ts +0 -0
  444. /package/{dvm → dist/dvm}/neighbors/types.d.ts.map +0 -0
  445. /package/{dvm → dist/dvm}/popover/base-popover.component.d.ts +0 -0
  446. /package/{dvm → dist/dvm}/popover/base-popover.component.d.ts.map +0 -0
  447. /package/{dvm → dist/dvm}/popover/index.d.ts +0 -0
  448. /package/{dvm → dist/dvm}/popover/index.d.ts.map +0 -0
  449. /package/{dvm → dist/dvm}/popover/popover.component.d.ts +0 -0
  450. /package/{dvm → dist/dvm}/popover/popover.component.d.ts.map +0 -0
  451. /package/{dvm → dist/dvm}/popover/popover.config.d.ts +0 -0
  452. /package/{dvm → dist/dvm}/popover/popover.config.d.ts.map +0 -0
  453. /package/{dvm → dist/dvm}/popover/popover.service.d.ts +0 -0
  454. /package/{dvm → dist/dvm}/popover/popover.service.d.ts.map +0 -0
  455. /package/{dvm → dist/dvm}/popover/public-api.d.ts +0 -0
  456. /package/{dvm → dist/dvm}/popover/public-api.d.ts.map +0 -0
  457. /package/{dvm → dist/dvm}/popover/seat-popover/seat-popover.component.d.ts +0 -0
  458. /package/{dvm → dist/dvm}/popover/seat-popover/seat-popover.component.d.ts.map +0 -0
  459. /package/{dvm → dist/dvm}/popover/section-popover/section-popover.component.d.ts +0 -0
  460. /package/{dvm → dist/dvm}/popover/section-popover/section-popover.component.d.ts.map +0 -0
  461. /package/{dvm → dist/dvm}/popover/services/dvm-popover-positioner.service.d.ts +0 -0
  462. /package/{dvm → dist/dvm}/popover/services/dvm-popover-positioner.service.d.ts.map +0 -0
  463. /package/{dvm → dist/dvm}/popover/services/popover-manager.service.d.ts +0 -0
  464. /package/{dvm → dist/dvm}/popover/services/popover-manager.service.d.ts.map +0 -0
  465. /package/{dvm → dist/dvm}/popover/transformers/base-popover-data-transformer.d.ts +0 -0
  466. /package/{dvm → dist/dvm}/popover/transformers/base-popover-data-transformer.d.ts.map +0 -0
  467. /package/{dvm → dist/dvm}/popover/types.d.ts +0 -0
  468. /package/{dvm → dist/dvm}/popover/types.d.ts.map +0 -0
  469. /package/{dvm → dist/dvm}/public-api.d.ts +0 -0
  470. /package/{dvm → dist/dvm}/public-api.d.ts.map +0 -0
  471. /package/{dvm → dist/dvm}/stepper/index.d.ts +0 -0
  472. /package/{dvm → dist/dvm}/stepper/index.d.ts.map +0 -0
  473. /package/{dvm → dist/dvm}/stepper/public-api.d.ts +0 -0
  474. /package/{dvm → dist/dvm}/stepper/public-api.d.ts.map +0 -0
  475. /package/{dvm → dist/dvm}/stepper/stepper.component.d.ts +0 -0
  476. /package/{dvm → dist/dvm}/stepper/stepper.component.d.ts.map +0 -0
  477. /package/{dvm → dist/dvm}/stepper/types.d.ts +0 -0
  478. /package/{dvm → dist/dvm}/stepper/types.d.ts.map +0 -0
  479. /package/{dvm → dist/dvm}/ticket-info-item/index.d.ts +0 -0
  480. /package/{dvm → dist/dvm}/ticket-info-item/index.d.ts.map +0 -0
  481. /package/{dvm → dist/dvm}/ticket-info-item/public-api.d.ts +0 -0
  482. /package/{dvm → dist/dvm}/ticket-info-item/public-api.d.ts.map +0 -0
  483. /package/{dvm → dist/dvm}/ticket-info-item/ticket-info-item.component.d.ts +0 -0
  484. /package/{dvm → dist/dvm}/ticket-info-item/ticket-info-item.component.d.ts.map +0 -0
  485. /package/{dvm → dist/dvm}/ticket-info-item/ticket-info-item.service.d.ts +0 -0
  486. /package/{dvm → dist/dvm}/ticket-info-item/ticket-info-item.service.d.ts.map +0 -0
  487. /package/{generic → dist/generic}/add-digital-wallet/add-digital-wallet.component.d.ts +0 -0
  488. /package/{generic → dist/generic}/add-digital-wallet/add-digital-wallet.component.d.ts.map +0 -0
  489. /package/{generic → dist/generic}/add-digital-wallet/index.d.ts +0 -0
  490. /package/{generic → dist/generic}/add-digital-wallet/index.d.ts.map +0 -0
  491. /package/{generic → dist/generic}/add-digital-wallet/public-api.d.ts +0 -0
  492. /package/{generic → dist/generic}/add-digital-wallet/public-api.d.ts.map +0 -0
  493. /package/{generic → dist/generic}/braintree/braintree.component.d.ts +0 -0
  494. /package/{generic → dist/generic}/braintree/braintree.component.d.ts.map +0 -0
  495. /package/{generic → dist/generic}/braintree/index.d.ts +0 -0
  496. /package/{generic → dist/generic}/braintree/index.d.ts.map +0 -0
  497. /package/{generic → dist/generic}/braintree/public-api.d.ts +0 -0
  498. /package/{generic → dist/generic}/braintree/public-api.d.ts.map +0 -0
  499. /package/{generic → dist/generic}/braintree/types.d.ts +0 -0
  500. /package/{generic → dist/generic}/braintree/types.d.ts.map +0 -0
  501. /package/{generic → dist/generic}/button/index.d.ts +0 -0
  502. /package/{generic → dist/generic}/button/index.d.ts.map +0 -0
  503. /package/{generic → dist/generic}/button/public-api.d.ts +0 -0
  504. /package/{generic → dist/generic}/button/public-api.d.ts.map +0 -0
  505. /package/{generic → dist/generic}/button/ui/ui-button-helm/src/index.d.ts +0 -0
  506. /package/{generic → dist/generic}/button/ui/ui-button-helm/src/index.d.ts.map +0 -0
  507. /package/{generic → dist/generic}/button/ui/ui-button-helm/src/lib/hlm-button.d.ts +0 -0
  508. /package/{generic → dist/generic}/button/ui/ui-button-helm/src/lib/hlm-button.d.ts.map +0 -0
  509. /package/{generic → dist/generic}/button/ui/ui-button-helm/src/lib/hlm-button.token.d.ts +0 -0
  510. /package/{generic → dist/generic}/button/ui/ui-button-helm/src/lib/hlm-button.token.d.ts.map +0 -0
  511. /package/{generic → dist/generic}/carousel/carousel-item.component.d.ts +0 -0
  512. /package/{generic → dist/generic}/carousel/carousel-item.component.d.ts.map +0 -0
  513. /package/{generic → dist/generic}/carousel/carousel.component.d.ts +0 -0
  514. /package/{generic → dist/generic}/carousel/carousel.component.d.ts.map +0 -0
  515. /package/{generic → dist/generic}/carousel/index.d.ts +0 -0
  516. /package/{generic → dist/generic}/carousel/index.d.ts.map +0 -0
  517. /package/{generic → dist/generic}/carousel/public-api.d.ts +0 -0
  518. /package/{generic → dist/generic}/carousel/public-api.d.ts.map +0 -0
  519. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/index.d.ts +0 -0
  520. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/index.d.ts.map +0 -0
  521. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-content.d.ts +0 -0
  522. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-content.d.ts.map +0 -0
  523. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-item.d.ts +0 -0
  524. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-item.d.ts.map +0 -0
  525. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-next.d.ts +0 -0
  526. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-next.d.ts.map +0 -0
  527. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-previous.d.ts +0 -0
  528. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-previous.d.ts.map +0 -0
  529. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-slide-display.d.ts +0 -0
  530. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel-slide-display.d.ts.map +0 -0
  531. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel.d.ts +0 -0
  532. /package/{generic → dist/generic}/carousel/ui/ui-carousel-helm/src/lib/hlm-carousel.d.ts.map +0 -0
  533. /package/{generic → dist/generic}/dialog/dialog.component.d.ts +0 -0
  534. /package/{generic → dist/generic}/dialog/dialog.component.d.ts.map +0 -0
  535. /package/{generic → dist/generic}/dialog/index.d.ts +0 -0
  536. /package/{generic → dist/generic}/dialog/index.d.ts.map +0 -0
  537. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/index.d.ts +0 -0
  538. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/index.d.ts.map +0 -0
  539. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-close.d.ts +0 -0
  540. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-close.d.ts.map +0 -0
  541. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-content.d.ts +0 -0
  542. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-content.d.ts.map +0 -0
  543. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-description.d.ts +0 -0
  544. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-description.d.ts.map +0 -0
  545. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-footer.d.ts +0 -0
  546. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-footer.d.ts.map +0 -0
  547. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-header.d.ts +0 -0
  548. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-header.d.ts.map +0 -0
  549. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-overlay.d.ts +0 -0
  550. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-overlay.d.ts.map +0 -0
  551. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-title.d.ts +0 -0
  552. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog-title.d.ts.map +0 -0
  553. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog.d.ts +0 -0
  554. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog.d.ts.map +0 -0
  555. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog.service.d.ts +0 -0
  556. /package/{generic → dist/generic}/dialog/libs/ui-dialog-helm/src/lib/hlm-dialog.service.d.ts.map +0 -0
  557. /package/{generic → dist/generic}/dialog/public-api.d.ts +0 -0
  558. /package/{generic → dist/generic}/dialog/public-api.d.ts.map +0 -0
  559. /package/{generic → dist/generic}/drawer/drawer.component.d.ts +0 -0
  560. /package/{generic → dist/generic}/drawer/drawer.component.d.ts.map +0 -0
  561. /package/{generic → dist/generic}/drawer/drawer.service.d.ts +0 -0
  562. /package/{generic → dist/generic}/drawer/drawer.service.d.ts.map +0 -0
  563. /package/{generic → dist/generic}/drawer/index.d.ts +0 -0
  564. /package/{generic → dist/generic}/drawer/index.d.ts.map +0 -0
  565. /package/{generic → dist/generic}/drawer/public-api.d.ts +0 -0
  566. /package/{generic → dist/generic}/drawer/public-api.d.ts.map +0 -0
  567. /package/{generic → dist/generic}/icon/icon.component.d.ts +0 -0
  568. /package/{generic → dist/generic}/icon/icon.component.d.ts.map +0 -0
  569. /package/{generic → dist/generic}/icon/index.d.ts +0 -0
  570. /package/{generic → dist/generic}/icon/index.d.ts.map +0 -0
  571. /package/{generic → dist/generic}/icon/lib/ui-icon-helm/src/index.d.ts +0 -0
  572. /package/{generic → dist/generic}/icon/lib/ui-icon-helm/src/index.d.ts.map +0 -0
  573. /package/{generic → dist/generic}/icon/lib/ui-icon-helm/src/lib/hlm-icon.d.ts +0 -0
  574. /package/{generic → dist/generic}/icon/lib/ui-icon-helm/src/lib/hlm-icon.d.ts.map +0 -0
  575. /package/{generic → dist/generic}/icon/lib/ui-icon-helm/src/lib/hlm-icon.token.d.ts +0 -0
  576. /package/{generic → dist/generic}/icon/lib/ui-icon-helm/src/lib/hlm-icon.token.d.ts.map +0 -0
  577. /package/{generic → dist/generic}/icon/public-api.d.ts +0 -0
  578. /package/{generic → dist/generic}/icon/public-api.d.ts.map +0 -0
  579. /package/{generic → dist/generic}/index.d.ts +0 -0
  580. /package/{generic → dist/generic}/index.d.ts.map +0 -0
  581. /package/{generic → dist/generic}/public-api.d.ts +0 -0
  582. /package/{generic → dist/generic}/public-api.d.ts.map +0 -0
  583. /package/{generic → dist/generic}/select/index.d.ts +0 -0
  584. /package/{generic → dist/generic}/select/index.d.ts.map +0 -0
  585. /package/{generic → dist/generic}/select/lib/hlm-select-content.d.ts +0 -0
  586. /package/{generic → dist/generic}/select/lib/hlm-select-content.d.ts.map +0 -0
  587. /package/{generic → dist/generic}/select/lib/hlm-select-group.d.ts +0 -0
  588. /package/{generic → dist/generic}/select/lib/hlm-select-group.d.ts.map +0 -0
  589. /package/{generic → dist/generic}/select/lib/hlm-select-label.d.ts +0 -0
  590. /package/{generic → dist/generic}/select/lib/hlm-select-label.d.ts.map +0 -0
  591. /package/{generic → dist/generic}/select/lib/hlm-select-option.d.ts +0 -0
  592. /package/{generic → dist/generic}/select/lib/hlm-select-option.d.ts.map +0 -0
  593. /package/{generic → dist/generic}/select/lib/hlm-select-scroll-down.d.ts +0 -0
  594. /package/{generic → dist/generic}/select/lib/hlm-select-scroll-down.d.ts.map +0 -0
  595. /package/{generic → dist/generic}/select/lib/hlm-select-scroll-up.d.ts +0 -0
  596. /package/{generic → dist/generic}/select/lib/hlm-select-scroll-up.d.ts.map +0 -0
  597. /package/{generic → dist/generic}/select/lib/hlm-select-trigger.d.ts +0 -0
  598. /package/{generic → dist/generic}/select/lib/hlm-select-trigger.d.ts.map +0 -0
  599. /package/{generic → dist/generic}/select/lib/hlm-select-value.d.ts +0 -0
  600. /package/{generic → dist/generic}/select/lib/hlm-select-value.d.ts.map +0 -0
  601. /package/{generic → dist/generic}/select/lib/hlm-select.d.ts +0 -0
  602. /package/{generic → dist/generic}/select/lib/hlm-select.d.ts.map +0 -0
  603. /package/{generic → dist/generic}/select/lib/index.d.ts +0 -0
  604. /package/{generic → dist/generic}/select/lib/index.d.ts.map +0 -0
  605. /package/{generic → dist/generic}/select/public-api.d.ts +0 -0
  606. /package/{generic → dist/generic}/select/public-api.d.ts.map +0 -0
  607. /package/{generic → dist/generic}/select/select.component.d.ts +0 -0
  608. /package/{generic → dist/generic}/select/select.component.d.ts.map +0 -0
  609. /package/{generic → dist/generic}/select/types.d.ts +0 -0
  610. /package/{generic → dist/generic}/select/types.d.ts.map +0 -0
  611. /package/{index.d.ts → dist/index.d.ts} +0 -0
  612. /package/{public-api.d.ts → dist/public-api.d.ts} +0 -0
  613. /package/{public-api.d.ts.map → dist/public-api.d.ts.map} +0 -0
  614. /package/{shared → dist/shared}/apply-theme-variables/apply-theme-variables.d.ts +0 -0
  615. /package/{shared → dist/shared}/apply-theme-variables/apply-theme-variables.d.ts.map +0 -0
  616. /package/{shared → dist/shared}/apply-theme-variables/index.d.ts +0 -0
  617. /package/{shared → dist/shared}/apply-theme-variables/index.d.ts.map +0 -0
  618. /package/{shared → dist/shared}/lib-provider/config-token.d.ts +0 -0
  619. /package/{shared → dist/shared}/lib-provider/config-token.d.ts.map +0 -0
  620. /package/{shared → dist/shared}/lib-provider/index.d.ts +0 -0
  621. /package/{shared → dist/shared}/lib-provider/index.d.ts.map +0 -0
  622. /package/{shared → dist/shared}/lib-provider/provide-sdc.d.ts +0 -0
  623. /package/{shared → dist/shared}/lib-provider/provide-sdc.d.ts.map +0 -0
  624. /package/{shared → dist/shared}/lib-provider/public-api.d.ts +0 -0
  625. /package/{shared → dist/shared}/lib-provider/public-api.d.ts.map +0 -0
  626. /package/{shared → dist/shared}/screen-observer/index.d.ts +0 -0
  627. /package/{shared → dist/shared}/screen-observer/index.d.ts.map +0 -0
  628. /package/{shared → dist/shared}/screen-observer/provide-screen-observer.d.ts +0 -0
  629. /package/{shared → dist/shared}/screen-observer/provide-screen-observer.d.ts.map +0 -0
  630. /package/{shared → dist/shared}/screen-observer/screen-observer.d.ts +0 -0
  631. /package/{shared → dist/shared}/screen-observer/screen-observer.d.ts.map +0 -0
  632. /package/{shared → dist/shared}/types.d.ts +0 -0
  633. /package/{shared → dist/shared}/types.d.ts.map +0 -0
  634. /package/{types → dist/types}/sizes.type.d.ts +0 -0
  635. /package/{types → dist/types}/sizes.type.d.ts.map +0 -0
@@ -0,0 +1,171 @@
1
+ import { BooleanInput, NumberInput } from '@angular/cdk/coercion';
2
+ import {
3
+ ChangeDetectionStrategy,
4
+ Component,
5
+ booleanAttribute,
6
+ computed,
7
+ input,
8
+ model,
9
+ numberAttribute,
10
+ viewChild,
11
+ } from '@angular/core';
12
+ import { NgIcon, provideIcons } from '@ng-icons/core';
13
+ import { lucideChevronLeft, lucideChevronRight } from '@ng-icons/lucide';
14
+ import {
15
+ BrnCalendar,
16
+ BrnCalendarCell,
17
+ BrnCalendarCellButton,
18
+ BrnCalendarGrid,
19
+ BrnCalendarHeader,
20
+ BrnCalendarNextButton,
21
+ BrnCalendarPreviousButton,
22
+ BrnCalendarWeek,
23
+ BrnCalendarWeekday,
24
+ Weekday,
25
+ injectBrnCalendarI18n,
26
+ } from '@spartan-ng/brain/calendar';
27
+ import { hlm } from '@spartan-ng/brain/core';
28
+ import { injectDateAdapter } from '@spartan-ng/brain/date-time';
29
+ import type { ClassValue } from 'clsx';
30
+ import { buttonVariants } from '../../../../../../generic/button/ui/ui-button-helm/src';
31
+ import { HlmIcon } from '../../../ui-icon-helm/src';
32
+
33
+ @Component({
34
+ selector: 'hlm-calendar',
35
+ imports: [
36
+ BrnCalendar,
37
+ BrnCalendarHeader,
38
+ BrnCalendarNextButton,
39
+ BrnCalendarPreviousButton,
40
+ BrnCalendarWeekday,
41
+ BrnCalendarWeek,
42
+ BrnCalendarCellButton,
43
+ BrnCalendarCell,
44
+ BrnCalendarGrid,
45
+ NgIcon,
46
+ HlmIcon,
47
+ ],
48
+ viewProviders: [provideIcons({ lucideChevronLeft, lucideChevronRight })],
49
+ template: `
50
+ <div
51
+ brnCalendar
52
+ [min]="min()"
53
+ [max]="max()"
54
+ [disabled]="disabled()"
55
+ [(date)]="date"
56
+ [dateDisabled]="dateDisabled()"
57
+ [weekStartsOn]="weekStartsOn()"
58
+ [defaultFocusedDate]="defaultFocusedDate()"
59
+ [class]="_computedCalenderClass()">
60
+ <div class="inline-flex flex-col space-y-4">
61
+ <!-- Header -->
62
+ <div class="space-y-4">
63
+ <div class="relative flex items-center justify-center pt-1">
64
+ <div brnCalendarHeader class="text-sm font-medium">
65
+ {{ _heading() }}
66
+ </div>
67
+
68
+ <div class="flex items-center space-x-1">
69
+ <button
70
+ brnCalendarPreviousButton
71
+ class="focus-visible:ring-ring hover:bg-accent hover:text-accent-foreground text-popover-foreground absolute left-1 inline-flex size-8 items-center justify-center whitespace-nowrap rounded-md bg-transparent p-0 text-sm font-medium transition-colors hover:opacity-100 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50">
72
+ <ng-icon hlm name="lucideChevronLeft" size="sm" />
73
+ </button>
74
+
75
+ <button
76
+ brnCalendarNextButton
77
+ class="focus-visible:ring-ring hover:bg-accent hover:text-accent-foreground text-popover-foreground absolute right-1 inline-flex size-8 items-center justify-center whitespace-nowrap rounded-md bg-transparent p-0 text-sm font-medium transition-colors hover:opacity-100 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50">
78
+ <ng-icon hlm name="lucideChevronRight" size="sm" />
79
+ </button>
80
+ </div>
81
+ </div>
82
+ </div>
83
+
84
+ <table class="w-full border-collapse space-y-1" brnCalendarGrid>
85
+ <thead>
86
+ <tr class="flex">
87
+ <th
88
+ *brnCalendarWeekday="let weekday"
89
+ scope="col"
90
+ class="text-muted-foreground w-8 rounded-md text-[0.8rem] font-normal"
91
+ [attr.aria-label]="_i18n.labelWeekday(weekday)">
92
+ {{ _i18n.formatWeekdayName(weekday) }}
93
+ </th>
94
+ </tr>
95
+ </thead>
96
+
97
+ <tbody role="rowgroup">
98
+ <tr *brnCalendarWeek="let week" class="mt-2 flex w-full">
99
+ @for (date of week; track _dateAdapter.getTime(date)) {
100
+ <td
101
+ brnCalendarCell
102
+ class="data-[selected]:data-[outside]:bg-accent/50 data-[selected]:bg-accent relative size-8 p-0 text-center text-sm focus-within:relative focus-within:z-20 first:data-[selected]:rounded-l-md last:data-[selected]:rounded-r-md [&:has([aria-selected].day-range-end)]:rounded-r-md">
103
+ <button brnCalendarCellButton [date]="date" [class]="_btnClass">
104
+ {{ _dateAdapter.getDate(date) }}
105
+ </button>
106
+ </td>
107
+ }
108
+ </tr>
109
+ </tbody>
110
+ </table>
111
+ </div>
112
+ </div>
113
+ `,
114
+ changeDetection: ChangeDetectionStrategy.OnPush,
115
+ })
116
+ export class HlmCalendar<T> {
117
+ public readonly calendarClass = input<ClassValue>('');
118
+
119
+ protected readonly _computedCalenderClass = computed(() => hlm('rounded-md border p-3', this.calendarClass()));
120
+
121
+ /** Access the calendar i18n */
122
+ protected readonly _i18n = injectBrnCalendarI18n();
123
+
124
+ /** Access the date time adapter */
125
+ protected readonly _dateAdapter = injectDateAdapter<T>();
126
+
127
+ /** The minimum date that can be selected.*/
128
+ public readonly min = input<T>();
129
+
130
+ /** The maximum date that can be selected. */
131
+ public readonly max = input<T>();
132
+
133
+ /** Determine if the date picker is disabled. */
134
+ public readonly disabled = input<boolean, BooleanInput>(false, {
135
+ transform: booleanAttribute,
136
+ });
137
+
138
+ /** The selected value. */
139
+ public readonly date = model<T>();
140
+
141
+ /** Whether a specific date is disabled. */
142
+ public readonly dateDisabled = input<(date: T) => boolean>(() => false);
143
+
144
+ /** The day the week starts on */
145
+ public readonly weekStartsOn = input<Weekday, NumberInput>(0, {
146
+ transform: (v: unknown) => numberAttribute(v) as Weekday,
147
+ });
148
+
149
+ /** The default focused date. */
150
+ public readonly defaultFocusedDate = input<T>();
151
+
152
+ /** Access the calendar directive */
153
+ private readonly _calendar = viewChild.required(BrnCalendar);
154
+
155
+ /** Get the heading for the current month and year */
156
+ protected readonly _heading = computed(() =>
157
+ this._i18n.formatHeader(
158
+ this._dateAdapter.getMonth(this._calendar().focusedDate()),
159
+ this._dateAdapter.getYear(this._calendar().focusedDate())
160
+ )
161
+ );
162
+
163
+ protected readonly _btnClass = hlm(
164
+ buttonVariants({ variant: 'ghost' }),
165
+ 'size-8 p-0 font-normal aria-selected:opacity-100',
166
+ 'data-[outside]:text-muted-foreground data-[outside]:opacity-50 data-[outside]:aria-selected:bg-accent/50 data-[outside]:aria-selected:text-muted-foreground data-[outside]:aria-selected:opacity-30',
167
+ 'data-[today]:bg-accent data-[today]:text-accent-foreground',
168
+ 'data-[selected]:bg-primary data-[selected]:text-primary-foreground data-[selected]:hover:bg-primary dark:hover:text-accent-foreground data-[selected]:focus:bg-primary data-[selected]:focus:text-primary-foreground',
169
+ 'data-[disabled]:text-muted-foreground data-[disabled]:opacity-50'
170
+ );
171
+ }
@@ -0,0 +1,16 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { HlmDatePicker } from './lib/hlm-date-picker';
3
+ import { HlmDatePickerMulti } from './lib/hlm-date-picker-multi';
4
+
5
+ export * from './lib/hlm-date-picker.token';
6
+
7
+ export * from './lib/hlm-date-picker';
8
+ export * from './lib/hlm-date-picker-multi';
9
+
10
+ export const HlmDatePickerImports = [HlmDatePicker, HlmDatePickerMulti] as const;
11
+
12
+ @NgModule({
13
+ imports: [...HlmDatePickerImports],
14
+ exports: [...HlmDatePickerImports],
15
+ })
16
+ export class HlmDatePickerModule {}
@@ -0,0 +1,43 @@
1
+ import { inject, InjectionToken, ValueProvider } from '@angular/core';
2
+
3
+ export interface HlmDatePickerMultiConfig<T> {
4
+ /**
5
+ * If true, the date picker will close when the max selection of dates is reached.
6
+ */
7
+ autoCloseOnMaxSelection: boolean;
8
+
9
+ /**
10
+ * Defines how the date should be displayed in the UI.
11
+ *
12
+ * @param dates
13
+ * @returns formatted date
14
+ */
15
+ formatDates: (dates: T[]) => string;
16
+
17
+ /**
18
+ * Defines how the date should be transformed before saving to model/form.
19
+ *
20
+ * @param dates
21
+ * @returns transformed date
22
+ */
23
+ transformDates: (dates: T[]) => T[];
24
+ }
25
+
26
+ function getDefaultConfig<T>(): HlmDatePickerMultiConfig<T> {
27
+ return {
28
+ formatDates: (dates) => dates.map((date) => (date instanceof Date ? date.toDateString() : `${date}`)).join(', '),
29
+ transformDates: (dates) => dates,
30
+ autoCloseOnMaxSelection: false,
31
+ };
32
+ }
33
+
34
+ const HlmDatePickerMultiConfigToken = new InjectionToken<HlmDatePickerMultiConfig<unknown>>('HlmDatePickerMultiConfig');
35
+
36
+ export function provideHlmDatePickerConfig<T>(config: Partial<HlmDatePickerMultiConfig<T>>): ValueProvider {
37
+ return { provide: HlmDatePickerMultiConfigToken, useValue: { ...getDefaultConfig(), ...config } };
38
+ }
39
+
40
+ export function injectHlmDatePickerMultiConfig<T>(): HlmDatePickerMultiConfig<T> {
41
+ const injectedConfig = inject(HlmDatePickerMultiConfigToken, { optional: true });
42
+ return injectedConfig ? (injectedConfig as HlmDatePickerMultiConfig<T>) : getDefaultConfig();
43
+ }
@@ -0,0 +1,177 @@
1
+ import { BooleanInput, NumberInput } from '@angular/cdk/coercion';
2
+ import {
3
+ booleanAttribute,
4
+ ChangeDetectionStrategy,
5
+ Component,
6
+ computed,
7
+ forwardRef,
8
+ input,
9
+ model,
10
+ numberAttribute,
11
+ output,
12
+ signal,
13
+ } from '@angular/core';
14
+ import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';
15
+ import { NgIcon, provideIcons } from '@ng-icons/core';
16
+ import { lucideCalendar } from '@ng-icons/lucide';
17
+ import { hlm } from '@spartan-ng/brain/core';
18
+ import { BrnDialogState } from '@spartan-ng/brain/dialog';
19
+ import { type ChangeFn, type TouchFn } from '@spartan-ng/brain/forms';
20
+ import { BrnPopover, BrnPopoverContent, BrnPopoverTrigger } from '@spartan-ng/brain/popover';
21
+ import type { ClassValue } from 'clsx';
22
+ import { HlmCalendarMulti } from '../../../ui-calendar-helm/src';
23
+ import { HlmIcon } from '../../../ui-icon-helm/src';
24
+ import { HlmPopoverContent } from '../../../ui-popover-helm/src';
25
+ import { injectHlmDatePickerMultiConfig } from './hlm-date-picker-multi.token';
26
+
27
+ export const HLM_DATE_PICKER_MUTLI_VALUE_ACCESSOR = {
28
+ provide: NG_VALUE_ACCESSOR,
29
+ useExisting: forwardRef(() => HlmDatePickerMulti),
30
+ multi: true,
31
+ };
32
+
33
+ @Component({
34
+ selector: 'hlm-date-picker-multi',
35
+ imports: [NgIcon, HlmIcon, BrnPopover, BrnPopoverTrigger, BrnPopoverContent, HlmPopoverContent, HlmCalendarMulti],
36
+ providers: [HLM_DATE_PICKER_MUTLI_VALUE_ACCESSOR, provideIcons({ lucideCalendar })],
37
+ template: `
38
+ <brn-popover sideOffset="5" [state]="_popoverState()" (stateChanged)="_popoverState.set($event)">
39
+ <button type="button" [class]="_computedClass()" [disabled]="_state().disabled()" brnPopoverTrigger>
40
+ <ng-icon hlm size="sm" name="lucideCalendar" />
41
+
42
+ <span class="truncate">
43
+ @if (_formattedDate(); as formattedDate) {
44
+ {{ formattedDate }}
45
+ } @else {
46
+ <ng-content />
47
+ }
48
+ </span>
49
+ </button>
50
+
51
+ <div hlmPopoverContent class="w-auto p-0" *brnPopoverContent="let ctx">
52
+ <hlm-calendar-multi
53
+ calendarClass="border-0 rounded-none"
54
+ [date]="date()"
55
+ [min]="min()"
56
+ [max]="max()"
57
+ [minSelection]="minSelection()"
58
+ [maxSelection]="maxSelection()"
59
+ [disabled]="_state().disabled()"
60
+ (dateChange)="_handleChange($event)" />
61
+ </div>
62
+ </brn-popover>
63
+ `,
64
+ host: {
65
+ class: 'block',
66
+ },
67
+ changeDetection: ChangeDetectionStrategy.OnPush,
68
+ })
69
+ export class HlmDatePickerMulti<T> implements ControlValueAccessor {
70
+ private readonly _config = injectHlmDatePickerMultiConfig<T>();
71
+
72
+ public readonly userClass = input<ClassValue>('', { alias: 'class' });
73
+ protected readonly _computedClass = computed(() =>
74
+ hlm(
75
+ 'inline-flex items-center gap-2 whitespace-nowrap rounded-md text-sm ring-offset-background transition-colors border border-input bg-background hover:bg-accent hover:text-accent-foreground h-10 px-4 py-2 w-[280px] justify-start text-left font-normal',
76
+ 'focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2',
77
+ 'disabled:pointer-events-none disabled:opacity-50',
78
+ '[&_ng-icon]:pointer-events-none [&_ng-icon]:shrink-0',
79
+ !this.date() ? 'text-muted-foreground' : '',
80
+ this.userClass()
81
+ )
82
+ );
83
+
84
+ /** The minimum date that can be selected.*/
85
+ public readonly min = input<T>();
86
+
87
+ /** The maximum date that can be selected. */
88
+ public readonly max = input<T>();
89
+
90
+ /** The minimum selectable dates. */
91
+ public readonly minSelection = input<number, NumberInput>(undefined, {
92
+ transform: numberAttribute,
93
+ });
94
+
95
+ /** The maximum selectable dates. */
96
+ public readonly maxSelection = input<number, NumberInput>(undefined, {
97
+ transform: numberAttribute,
98
+ });
99
+
100
+ /** Determine if the date picker is disabled. */
101
+ public readonly disabled = input<boolean, BooleanInput>(false, {
102
+ transform: booleanAttribute,
103
+ });
104
+
105
+ /** The selected value. */
106
+ public readonly date = model<T[]>();
107
+
108
+ /** If true, the date picker will close when the max selection of dates is reached.. */
109
+ public readonly autoCloseOnMaxSelection = input<boolean, BooleanInput>(this._config.autoCloseOnMaxSelection, {
110
+ transform: booleanAttribute,
111
+ });
112
+
113
+ /** Defines how the date should be displayed in the UI. */
114
+ public readonly formatDates = input<(date: T[]) => string>(this._config.formatDates);
115
+
116
+ /** Defines how the date should be transformed before saving to model/form. */
117
+ public readonly transformDates = input<(date: T[]) => T[]>(this._config.transformDates);
118
+
119
+ protected readonly _popoverState = signal<BrnDialogState | null>(null);
120
+
121
+ protected readonly _state = computed(() => ({
122
+ disabled: signal(this.disabled()),
123
+ }));
124
+
125
+ protected readonly _formattedDate = computed(() => {
126
+ const dates = this.date();
127
+ return dates ? this.formatDates()(dates) : undefined;
128
+ });
129
+
130
+ public readonly changed = output<T[]>();
131
+
132
+ protected _onChange?: ChangeFn<T[]>;
133
+ protected _onTouched?: TouchFn;
134
+
135
+ protected _handleChange(value: T[] | undefined) {
136
+ if (value === undefined) return;
137
+
138
+ if (this._state().disabled()) return;
139
+ const transformedDate = this.transformDates()(value);
140
+
141
+ this.date.set(transformedDate);
142
+ this._onChange?.(transformedDate);
143
+ this.changed.emit(transformedDate);
144
+
145
+ if (this.autoCloseOnMaxSelection() && this.date()?.length === this.maxSelection()) {
146
+ this._popoverState.set('closed');
147
+ }
148
+ }
149
+
150
+ /** CONROL VALUE ACCESSOR */
151
+ writeValue(value: T[] | null): void {
152
+ // optional FormControl is initialized with null value
153
+ if (value === null) return;
154
+
155
+ this.date.set(this.transformDates()(value));
156
+ }
157
+
158
+ registerOnChange(fn: ChangeFn<T[]>): void {
159
+ this._onChange = fn;
160
+ }
161
+
162
+ registerOnTouched(fn: TouchFn): void {
163
+ this._onTouched = fn;
164
+ }
165
+
166
+ setDisabledState(isDisabled: boolean): void {
167
+ this._state().disabled.set(isDisabled);
168
+ }
169
+
170
+ open() {
171
+ this._popoverState.set('open');
172
+ }
173
+
174
+ close() {
175
+ this._popoverState.set('closed');
176
+ }
177
+ }
@@ -0,0 +1,43 @@
1
+ import { inject, InjectionToken, ValueProvider } from '@angular/core';
2
+
3
+ export interface HlmDatePickerConfig<T> {
4
+ /**
5
+ * If true, the date picker will close when a date is selected.
6
+ */
7
+ autoCloseOnSelect: boolean;
8
+
9
+ /**
10
+ * Defines how the date should be displayed in the UI.
11
+ *
12
+ * @param date
13
+ * @returns formatted date
14
+ */
15
+ formatDate: (date: T) => string;
16
+
17
+ /**
18
+ * Defines how the date should be transformed before saving to model/form.
19
+ *
20
+ * @param date
21
+ * @returns transformed date
22
+ */
23
+ transformDate: (date: T) => T;
24
+ }
25
+
26
+ function getDefaultConfig<T>(): HlmDatePickerConfig<T> {
27
+ return {
28
+ formatDate: (date) => (date instanceof Date ? date.toDateString() : `${date}`),
29
+ transformDate: (date) => date,
30
+ autoCloseOnSelect: false,
31
+ };
32
+ }
33
+
34
+ const HlmDatePickerConfigToken = new InjectionToken<HlmDatePickerConfig<unknown>>('HlmDatePickerConfig');
35
+
36
+ export function provideHlmDatePickerConfig<T>(config: Partial<HlmDatePickerConfig<T>>): ValueProvider {
37
+ return { provide: HlmDatePickerConfigToken, useValue: { ...getDefaultConfig(), ...config } };
38
+ }
39
+
40
+ export function injectHlmDatePickerConfig<T>(): HlmDatePickerConfig<T> {
41
+ const injectedConfig = inject(HlmDatePickerConfigToken, { optional: true });
42
+ return injectedConfig ? (injectedConfig as HlmDatePickerConfig<T>) : getDefaultConfig();
43
+ }
@@ -0,0 +1,167 @@
1
+ import { BooleanInput } from '@angular/cdk/coercion';
2
+ import {
3
+ booleanAttribute,
4
+ ChangeDetectionStrategy,
5
+ Component,
6
+ computed,
7
+ forwardRef,
8
+ input,
9
+ model,
10
+ output,
11
+ signal,
12
+ } from '@angular/core';
13
+ import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';
14
+ import { NgIcon, provideIcons } from '@ng-icons/core';
15
+ import { lucideCalendar } from '@ng-icons/lucide';
16
+ import { hlm } from '@spartan-ng/brain/core';
17
+ import { BrnDialogState } from '@spartan-ng/brain/dialog';
18
+ import { type ChangeFn, type TouchFn } from '@spartan-ng/brain/forms';
19
+ import { BrnPopover, BrnPopoverContent, BrnPopoverTrigger } from '@spartan-ng/brain/popover';
20
+ import type { ClassValue } from 'clsx';
21
+ import { HlmCalendar } from '../../../ui-calendar-helm/src';
22
+ import { HlmIcon } from '../../../ui-icon-helm/src';
23
+ import { HlmPopoverContent } from '../../../ui-popover-helm/src';
24
+ import { injectHlmDatePickerConfig } from './hlm-date-picker.token';
25
+
26
+ export const HLM_DATE_PICKER_VALUE_ACCESSOR = {
27
+ provide: NG_VALUE_ACCESSOR,
28
+ useExisting: forwardRef(() => HlmDatePicker),
29
+ multi: true,
30
+ };
31
+
32
+ @Component({
33
+ selector: 'hlm-date-picker',
34
+ imports: [NgIcon, HlmIcon, BrnPopover, BrnPopoverTrigger, BrnPopoverContent, HlmPopoverContent, HlmCalendar],
35
+ providers: [HLM_DATE_PICKER_VALUE_ACCESSOR, provideIcons({ lucideCalendar })],
36
+ template: `
37
+ <brn-popover sideOffset="5" [state]="_popoverState()" (stateChanged)="_popoverState.set($event)">
38
+ <button type="button" [class]="_computedClass()" [disabled]="_state().disabled()" brnPopoverTrigger>
39
+ <span class="truncate">
40
+ @if (_formattedDate(); as formattedDate) {
41
+ {{ formattedDate }}
42
+ } @else {
43
+ <ng-content />
44
+ }
45
+ </span>
46
+
47
+ <ng-icon hlm size="sm" name="lucideCalendar" />
48
+ </button>
49
+
50
+ <div hlmPopoverContent [class]="styleClass()" class="w-auto p-0" *brnPopoverContent="let ctx">
51
+ <hlm-calendar
52
+ calendarClass="border-0 rounded-none"
53
+ [date]="date()"
54
+ [min]="min()"
55
+ [max]="max()"
56
+ [disabled]="_state().disabled()"
57
+ (dateChange)="_handleChange($event)" />
58
+ </div>
59
+ </brn-popover>
60
+ `,
61
+ host: {
62
+ class: 'block',
63
+ },
64
+ changeDetection: ChangeDetectionStrategy.OnPush,
65
+ })
66
+ export class HlmDatePicker<T> implements ControlValueAccessor {
67
+ private readonly _config = injectHlmDatePickerConfig<T>();
68
+
69
+ public readonly userClass = input<ClassValue>('', { alias: 'class' });
70
+ protected readonly _computedClass = computed(() =>
71
+ hlm(
72
+ 'inline-flex items-center gap-2 whitespace-nowrap rounded-md text-sm transition-all disabled:pointer-events-none disabled:opacity-50 ring-offset-background transition-colors border border-input bg-background hover:bg-accent dark:bg-input/30 dark:hover:bg-input/50 hover:text-accent-foreground w-[280px] justify-start text-left font-normal cursor-default justify-between',
73
+ 'focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2',
74
+ 'disabled:pointer-events-none disabled:opacity-50',
75
+ '[&_ng-icon]:pointer-events-none [&_ng-icon]:shrink-0',
76
+ !this.date() ? 'text-muted-foreground' : '',
77
+ this.userClass()
78
+ )
79
+ );
80
+
81
+ /**
82
+ * This is used to apply the theme-sdc class to the datepicker's dialog.
83
+ */
84
+ public readonly styleClass = input<string>('');
85
+
86
+ /** The minimum date that can be selected.*/
87
+ public readonly min = input<T>();
88
+
89
+ /** The maximum date that can be selected. */
90
+ public readonly max = input<T>();
91
+
92
+ /** Determine if the date picker is disabled. */
93
+ public readonly disabled = input<boolean, BooleanInput>(false, {
94
+ transform: booleanAttribute,
95
+ });
96
+
97
+ /** The selected value. */
98
+ public readonly date = model<T>();
99
+
100
+ /** If true, the date picker will close when a date is selected. */
101
+ public readonly autoCloseOnSelect = input<boolean, BooleanInput>(this._config.autoCloseOnSelect, {
102
+ transform: booleanAttribute,
103
+ });
104
+
105
+ /** Defines how the date should be displayed in the UI. */
106
+ public readonly formatDate = input<(date: T) => string>(this._config.formatDate);
107
+
108
+ /** Defines how the date should be transformed before saving to model/form. */
109
+ public readonly transformDate = input<(date: T) => T>(this._config.transformDate);
110
+
111
+ protected readonly _popoverState = signal<BrnDialogState | null>(null);
112
+
113
+ protected readonly _state = computed(() => ({
114
+ disabled: signal(this.disabled()),
115
+ }));
116
+
117
+ protected readonly _formattedDate = computed(() => {
118
+ const date = this.date();
119
+ return date ? this.formatDate()(date) : undefined;
120
+ });
121
+
122
+ public readonly changed = output<T>();
123
+
124
+ protected _onChange?: ChangeFn<T>;
125
+ protected _onTouched?: TouchFn;
126
+
127
+ protected _handleChange(value: T) {
128
+ if (this._state().disabled()) return;
129
+ const transformedDate = this.transformDate()(value);
130
+
131
+ this.date.set(transformedDate);
132
+ this._onChange?.(transformedDate);
133
+ this.changed.emit(transformedDate);
134
+
135
+ if (this.autoCloseOnSelect()) {
136
+ this._popoverState.set('closed');
137
+ }
138
+ }
139
+
140
+ /** CONROL VALUE ACCESSOR */
141
+ writeValue(value: T | null): void {
142
+ // optional FormControl is initialized with null value
143
+ if (value === null) return;
144
+
145
+ this.date.set(this.transformDate()(value));
146
+ }
147
+
148
+ registerOnChange(fn: ChangeFn<T>): void {
149
+ this._onChange = fn;
150
+ }
151
+
152
+ registerOnTouched(fn: TouchFn): void {
153
+ this._onTouched = fn;
154
+ }
155
+
156
+ setDisabledState(isDisabled: boolean): void {
157
+ this._state().disabled.set(isDisabled);
158
+ }
159
+
160
+ open() {
161
+ this._popoverState.set('open');
162
+ }
163
+
164
+ close() {
165
+ this._popoverState.set('closed');
166
+ }
167
+ }
@@ -0,0 +1,11 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { HlmIcon } from './lib/hlm-icon';
3
+
4
+ export * from './lib/hlm-icon';
5
+ export * from './lib/hlm-icon.token';
6
+
7
+ @NgModule({
8
+ imports: [HlmIcon],
9
+ exports: [HlmIcon],
10
+ })
11
+ export class HlmIconModule {}
@@ -0,0 +1,20 @@
1
+ import { InjectionToken, ValueProvider, inject } from '@angular/core';
2
+ import type { IconSize } from './hlm-icon';
3
+
4
+ export interface HlmIconConfig {
5
+ size: IconSize;
6
+ }
7
+
8
+ const defaultConfig: HlmIconConfig = {
9
+ size: 'base',
10
+ };
11
+
12
+ const HlmIconConfigToken = new InjectionToken<HlmIconConfig>('HlmIconConfig');
13
+
14
+ export function provideHlmIconConfig(config: Partial<HlmIconConfig>): ValueProvider {
15
+ return { provide: HlmIconConfigToken, useValue: { ...defaultConfig, ...config } };
16
+ }
17
+
18
+ export function injectHlmIconConfig(): HlmIconConfig {
19
+ return inject(HlmIconConfigToken, { optional: true }) ?? defaultConfig;
20
+ }
@@ -0,0 +1,35 @@
1
+ import { Directive, computed, input } from '@angular/core';
2
+ import { injectHlmIconConfig } from './hlm-icon.token';
3
+
4
+ export type IconSize = 'xs' | 'sm' | 'base' | 'lg' | 'xl' | 'none' | (Record<never, never> & string);
5
+
6
+ @Directive({
7
+ selector: 'ng-icon[hlm]',
8
+ host: {
9
+ '[style.--ng-icon__size]': '_computedSize()',
10
+ },
11
+ })
12
+ export class HlmIcon {
13
+ private readonly _config = injectHlmIconConfig();
14
+ public readonly size = input<IconSize>(this._config.size);
15
+
16
+ protected readonly _computedSize = computed(() => {
17
+ const size = this.size();
18
+
19
+ switch (size) {
20
+ case 'xs':
21
+ return '12px';
22
+ case 'sm':
23
+ return '16px';
24
+ case 'base':
25
+ return '24px';
26
+ case 'lg':
27
+ return '32px';
28
+ case 'xl':
29
+ return '48px';
30
+ default: {
31
+ return size;
32
+ }
33
+ }
34
+ });
35
+ }