flowbite-angular 1.0.0-alpha.2 → 1.0.0-alpha.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 (579) hide show
  1. package/accordion/README.md +3 -0
  2. package/{lib/components/accordion → accordion}/accordion-content.component.d.ts +1 -1
  3. package/{lib/components/accordion → accordion}/accordion-content.theme.d.ts +1 -1
  4. package/{lib/components/accordion → accordion}/accordion-content.theme.service.d.ts +1 -1
  5. package/{lib/components/accordion → accordion}/accordion-panel.component.d.ts +1 -1
  6. package/{lib/components/accordion → accordion}/accordion-panel.theme.d.ts +1 -1
  7. package/{lib/components/accordion → accordion}/accordion-panel.theme.service.d.ts +1 -1
  8. package/{lib/components/accordion → accordion}/accordion-title.component.d.ts +2 -2
  9. package/{lib/components/accordion → accordion}/accordion-title.theme.d.ts +1 -2
  10. package/{lib/components/accordion → accordion}/accordion-title.theme.service.d.ts +1 -1
  11. package/{lib/components/accordion → accordion}/accordion.component.d.ts +1 -1
  12. package/{lib/components/accordion → accordion}/accordion.theme.d.ts +1 -4
  13. package/{lib/components/accordion → accordion}/accordion.theme.service.d.ts +1 -1
  14. package/alert/README.md +3 -0
  15. package/{lib/components/alert → alert}/alert.component.d.ts +5 -5
  16. package/{lib/components/alert → alert}/alert.theme.d.ts +1 -4
  17. package/{lib/components/alert → alert}/alert.theme.service.d.ts +1 -1
  18. package/badge/README.md +3 -0
  19. package/{lib/components/badge → badge}/badge.component.d.ts +4 -4
  20. package/{lib/components/badge → badge}/badge.theme.d.ts +1 -6
  21. package/{lib/components/badge → badge}/badge.theme.service.d.ts +1 -1
  22. package/{lib/components/base-component.directive.d.ts → base-component.directive.d.ts} +2 -2
  23. package/breadcrumb/README.md +3 -0
  24. package/{lib/components/breadcrumb → breadcrumb}/breadcrumb-item.component.d.ts +4 -4
  25. package/{lib/components/breadcrumb → breadcrumb}/breadcrumb-item.theme.d.ts +1 -2
  26. package/{lib/components/breadcrumb → breadcrumb}/breadcrumb-item.theme.service.d.ts +1 -1
  27. package/{lib/components/breadcrumb → breadcrumb}/breadcrumb.component.d.ts +1 -1
  28. package/{lib/components/breadcrumb → breadcrumb}/breadcrumb.theme.d.ts +1 -1
  29. package/{lib/components/breadcrumb → breadcrumb}/breadcrumb.theme.service.d.ts +1 -1
  30. package/button/README.md +3 -0
  31. package/{lib/components/button → button}/button.component.d.ts +2 -2
  32. package/{lib/components/button → button}/button.theme.d.ts +1 -8
  33. package/{lib/components/button → button}/button.theme.service.d.ts +1 -1
  34. package/core/README.md +3 -0
  35. package/core/index.d.ts +1 -0
  36. package/dark-theme-toggle/README.md +3 -0
  37. package/{lib/components/dark-theme-toggle → dark-theme-toggle}/dark-theme-toggle.component.d.ts +2 -2
  38. package/{lib/components/dark-theme-toggle → dark-theme-toggle}/dark-theme-toggle.theme.d.ts +1 -1
  39. package/{lib/components/dark-theme-toggle → dark-theme-toggle}/dark-theme-toggle.theme.service.d.ts +1 -1
  40. package/{lib/components/dark-theme-toggle → dark-theme-toggle}/index.d.ts +1 -2
  41. package/dropdown/README.md +3 -0
  42. package/{lib/components/dropdown → dropdown}/dropdown-divider.component.d.ts +1 -1
  43. package/{lib/components/dropdown → dropdown}/dropdown-divider.theme.d.ts +1 -1
  44. package/{lib/components/dropdown → dropdown}/dropdown-divider.theme.service.d.ts +1 -1
  45. package/{lib/components/dropdown → dropdown}/dropdown-header.component.d.ts +1 -1
  46. package/{lib/components/dropdown → dropdown}/dropdown-header.theme.d.ts +1 -1
  47. package/{lib/components/dropdown → dropdown}/dropdown-header.theme.service.d.ts +1 -1
  48. package/{lib/components/dropdown → dropdown}/dropdown-item.component.d.ts +1 -1
  49. package/{lib/components/dropdown → dropdown}/dropdown-item.theme.d.ts +1 -1
  50. package/{lib/components/dropdown → dropdown}/dropdown-item.theme.service.d.ts +1 -1
  51. package/{lib/components/dropdown → dropdown}/dropdown.component.d.ts +2 -2
  52. package/{lib/components/dropdown → dropdown}/dropdown.theme.d.ts +1 -4
  53. package/{lib/components/dropdown → dropdown}/dropdown.theme.service.d.ts +1 -1
  54. package/esm2022/accordion/accordion-content.component.mjs +47 -0
  55. package/esm2022/accordion/accordion-content.theme.mjs +19 -0
  56. package/esm2022/accordion/accordion-content.theme.service.mjs +17 -0
  57. package/esm2022/accordion/accordion-panel.component.mjs +59 -0
  58. package/esm2022/accordion/accordion-panel.theme.mjs +7 -0
  59. package/esm2022/accordion/accordion-panel.theme.service.mjs +17 -0
  60. package/esm2022/accordion/accordion-title.component.mjs +71 -0
  61. package/esm2022/accordion/accordion-title.theme.mjs +26 -0
  62. package/esm2022/accordion/accordion-title.theme.service.mjs +18 -0
  63. package/esm2022/accordion/accordion.component.mjs +50 -0
  64. package/esm2022/accordion/accordion.theme.mjs +19 -0
  65. package/esm2022/accordion/accordion.theme.service.mjs +17 -0
  66. package/esm2022/accordion/flowbite-angular-accordion.mjs +5 -0
  67. package/esm2022/accordion/index.mjs +13 -0
  68. package/esm2022/alert/alert.component.mjs +96 -0
  69. package/esm2022/alert/alert.theme.mjs +34 -0
  70. package/esm2022/alert/alert.theme.service.mjs +18 -0
  71. package/esm2022/alert/flowbite-angular-alert.mjs +5 -0
  72. package/esm2022/alert/index.mjs +4 -0
  73. package/esm2022/badge/badge.component.mjs +48 -0
  74. package/esm2022/badge/badge.theme.mjs +34 -0
  75. package/esm2022/badge/badge.theme.service.mjs +19 -0
  76. package/esm2022/badge/flowbite-angular-badge.mjs +5 -0
  77. package/esm2022/badge/index.mjs +4 -0
  78. package/esm2022/base-component.directive.mjs +34 -0
  79. package/esm2022/breadcrumb/breadcrumb-item.component.mjs +59 -0
  80. package/esm2022/breadcrumb/breadcrumb-item.theme.mjs +18 -0
  81. package/esm2022/breadcrumb/breadcrumb-item.theme.service.mjs +18 -0
  82. package/esm2022/breadcrumb/breadcrumb.component.mjs +48 -0
  83. package/esm2022/breadcrumb/breadcrumb.theme.mjs +7 -0
  84. package/esm2022/breadcrumb/breadcrumb.theme.service.mjs +17 -0
  85. package/esm2022/breadcrumb/flowbite-angular-breadcrumb.mjs +5 -0
  86. package/esm2022/breadcrumb/index.mjs +7 -0
  87. package/esm2022/{lib/components/button → button}/button.component.mjs +6 -5
  88. package/esm2022/button/button.theme.mjs +113 -0
  89. package/esm2022/button/button.theme.service.mjs +24 -0
  90. package/esm2022/button/flowbite-angular-button.mjs +5 -0
  91. package/esm2022/button/index.mjs +4 -0
  92. package/esm2022/core/flowbite-angular-core.mjs +5 -0
  93. package/esm2022/core/flowbite.theme.init.mjs +281 -0
  94. package/esm2022/core/index.mjs +2 -0
  95. package/esm2022/{lib/components/dark-theme-toggle → dark-theme-toggle}/dark-theme-toggle.component.mjs +8 -6
  96. package/esm2022/dark-theme-toggle/dark-theme-toggle.theme.mjs +7 -0
  97. package/esm2022/dark-theme-toggle/dark-theme-toggle.theme.service.mjs +17 -0
  98. package/esm2022/dark-theme-toggle/flowbite-angular-dark-theme-toggle.mjs +5 -0
  99. package/esm2022/dark-theme-toggle/index.mjs +4 -0
  100. package/esm2022/dropdown/dropdown-divider.component.mjs +36 -0
  101. package/esm2022/dropdown/dropdown-divider.theme.mjs +7 -0
  102. package/esm2022/dropdown/dropdown-divider.theme.service.mjs +17 -0
  103. package/esm2022/dropdown/dropdown-header.component.mjs +46 -0
  104. package/esm2022/dropdown/dropdown-header.theme.mjs +10 -0
  105. package/esm2022/dropdown/dropdown-header.theme.service.mjs +18 -0
  106. package/esm2022/dropdown/dropdown-item.component.mjs +36 -0
  107. package/esm2022/dropdown/dropdown-item.theme.mjs +6 -0
  108. package/esm2022/dropdown/dropdown-item.theme.service.mjs +17 -0
  109. package/esm2022/dropdown/dropdown.component.mjs +150 -0
  110. package/esm2022/dropdown/dropdown.theme.mjs +32 -0
  111. package/esm2022/dropdown/dropdown.theme.service.mjs +22 -0
  112. package/esm2022/dropdown/flowbite-angular-dropdown.mjs +5 -0
  113. package/esm2022/dropdown/index.mjs +13 -0
  114. package/esm2022/flowbite-angular.mjs +2 -2
  115. package/esm2022/flowbite.theme.service.mjs +16 -0
  116. package/esm2022/icon/flowbite-angular-icon.mjs +5 -0
  117. package/esm2022/icon/icon-registry.mjs +159 -0
  118. package/esm2022/icon/icon.component.mjs +72 -0
  119. package/esm2022/icon/index.mjs +4 -0
  120. package/esm2022/icon/trusted-types.mjs +21 -0
  121. package/esm2022/index.mjs +4 -0
  122. package/esm2022/indicator/flowbite-angular-indicator.mjs +5 -0
  123. package/esm2022/indicator/index.mjs +4 -0
  124. package/esm2022/indicator/indicators.component.mjs +55 -0
  125. package/esm2022/indicator/indicators.theme.mjs +68 -0
  126. package/esm2022/indicator/indicators.theme.service.mjs +19 -0
  127. package/esm2022/modal/flowbite-angular-modal.mjs +5 -0
  128. package/esm2022/modal/index.mjs +13 -0
  129. package/esm2022/modal/modal-body.component.mjs +36 -0
  130. package/esm2022/modal/modal-body.theme.mjs +7 -0
  131. package/esm2022/modal/modal-body.theme.service.mjs +17 -0
  132. package/esm2022/modal/modal-footer.component.mjs +36 -0
  133. package/esm2022/modal/modal-footer.theme.mjs +7 -0
  134. package/esm2022/modal/modal-footer.theme.service.mjs +17 -0
  135. package/esm2022/modal/modal-header.component.mjs +68 -0
  136. package/esm2022/modal/modal-header.theme.mjs +13 -0
  137. package/esm2022/modal/modal-header.theme.service.mjs +19 -0
  138. package/esm2022/modal/modal.component.mjs +143 -0
  139. package/esm2022/modal/modal.theme.mjs +33 -0
  140. package/esm2022/modal/modal.theme.service.mjs +20 -0
  141. package/esm2022/navbar/flowbite-angular-navbar.mjs +5 -0
  142. package/esm2022/navbar/index.mjs +19 -0
  143. package/esm2022/navbar/navbar-brand.component.mjs +36 -0
  144. package/esm2022/navbar/navbar-brand.theme.mjs +7 -0
  145. package/esm2022/navbar/navbar-brand.theme.service.mjs +17 -0
  146. package/esm2022/navbar/navbar-content.component.mjs +46 -0
  147. package/esm2022/navbar/navbar-content.theme.mjs +14 -0
  148. package/esm2022/navbar/navbar-content.theme.service.mjs +18 -0
  149. package/esm2022/navbar/navbar-icon-button.component.mjs +44 -0
  150. package/esm2022/navbar/navbar-icon-button.theme.mjs +15 -0
  151. package/esm2022/navbar/navbar-icon-button.theme.service.mjs +17 -0
  152. package/esm2022/navbar/navbar-item.component.mjs +51 -0
  153. package/esm2022/{lib/components/navbar → navbar}/navbar-item.theme.mjs +2 -2
  154. package/esm2022/navbar/navbar-item.theme.service.mjs +17 -0
  155. package/esm2022/navbar/navbar-toggle.component.mjs +52 -0
  156. package/esm2022/navbar/navbar-toggle.theme.mjs +7 -0
  157. package/esm2022/navbar/navbar-toggle.theme.service.mjs +17 -0
  158. package/esm2022/navbar/navbar.component.mjs +63 -0
  159. package/esm2022/navbar/navbar.theme.mjs +23 -0
  160. package/esm2022/navbar/navbar.theme.service.mjs +17 -0
  161. package/esm2022/router-link/flowbite-angular-router-link.mjs +5 -0
  162. package/esm2022/router-link/flowbite-router-link.directive.mjs +54 -0
  163. package/esm2022/router-link/index.mjs +2 -0
  164. package/esm2022/router-link-active/flowbite-angular-router-link-active.mjs +5 -0
  165. package/esm2022/router-link-active/flowbite-router-link-active.directive.mjs +49 -0
  166. package/esm2022/router-link-active/index.mjs +2 -0
  167. package/esm2022/sanitize-html/flowbite-angular-sanitize-html.mjs +5 -0
  168. package/esm2022/sanitize-html/index.mjs +2 -0
  169. package/esm2022/sanitize-html/sanitize-html.pipe.mjs +32 -0
  170. package/esm2022/scroll-top/flowbite-angular-scroll-top.mjs +5 -0
  171. package/esm2022/scroll-top/index.mjs +4 -0
  172. package/esm2022/scroll-top/scroll-top.component.mjs +52 -0
  173. package/esm2022/scroll-top/scroll-top.theme.mjs +27 -0
  174. package/esm2022/scroll-top/scroll-top.theme.service.mjs +17 -0
  175. package/esm2022/sidebar/flowbite-angular-sidebar.mjs +5 -0
  176. package/esm2022/sidebar/index.mjs +19 -0
  177. package/esm2022/sidebar/sidebar-item-group.component.mjs +83 -0
  178. package/esm2022/sidebar/sidebar-item-group.theme.mjs +18 -0
  179. package/esm2022/sidebar/sidebar-item-group.theme.service.mjs +18 -0
  180. package/esm2022/sidebar/sidebar-item.component.mjs +79 -0
  181. package/esm2022/sidebar/sidebar-item.theme.mjs +18 -0
  182. package/esm2022/sidebar/sidebar-item.theme.service.mjs +18 -0
  183. package/esm2022/sidebar/sidebar-menu.component.mjs +50 -0
  184. package/esm2022/sidebar/sidebar-menu.theme.mjs +24 -0
  185. package/esm2022/sidebar/sidebar-menu.theme.service.mjs +17 -0
  186. package/esm2022/sidebar/sidebar-page-content.component.mjs +37 -0
  187. package/esm2022/sidebar/sidebar-page-content.theme.mjs +12 -0
  188. package/esm2022/sidebar/sidebar-page-content.theme.service.mjs +17 -0
  189. package/esm2022/sidebar/sidebar-toggle.component.mjs +55 -0
  190. package/esm2022/sidebar/sidebar-toggle.theme.mjs +18 -0
  191. package/esm2022/sidebar/sidebar-toggle.theme.service.mjs +17 -0
  192. package/esm2022/sidebar/sidebar.component.mjs +62 -0
  193. package/esm2022/sidebar/sidebar.theme.mjs +11 -0
  194. package/esm2022/sidebar/sidebar.theme.service.mjs +17 -0
  195. package/esm2022/type-definitions/colors/flowbite.colors.mjs +2 -0
  196. package/esm2022/type-definitions/colors/flowbite.gradient-colors.mjs +2 -0
  197. package/esm2022/type-definitions/colors/flowbite.gradient-duo-tone-colors.mjs +2 -0
  198. package/esm2022/type-definitions/colors/index.mjs +2 -0
  199. package/esm2022/type-definitions/flowbite.boolean.mjs +10 -0
  200. package/esm2022/type-definitions/flowbite.class.mjs +2 -0
  201. package/esm2022/type-definitions/flowbite.combination.mjs +5 -0
  202. package/esm2022/type-definitions/flowbite.content-positions.mjs +2 -0
  203. package/esm2022/type-definitions/flowbite.deep-partial.mjs +2 -0
  204. package/esm2022/type-definitions/flowbite.heading-levels.mjs +2 -0
  205. package/esm2022/type-definitions/flowbite.positions.mjs +2 -0
  206. package/esm2022/type-definitions/flowbite.router-link-parameter.mjs +2 -0
  207. package/esm2022/type-definitions/flowbite.sizes.mjs +2 -0
  208. package/esm2022/type-definitions/flowbite.themes.mjs +2 -0
  209. package/esm2022/type-definitions/index.mjs +3 -0
  210. package/esm2022/utils/flowbite-angular-utils.mjs +5 -0
  211. package/esm2022/utils/icon.list.mjs +39 -0
  212. package/esm2022/utils/id.generator.mjs +81 -0
  213. package/esm2022/utils/index.mjs +9 -0
  214. package/esm2022/utils/theme/clone-deep.mjs +18 -0
  215. package/esm2022/utils/theme/create-class.mjs +10 -0
  216. package/esm2022/utils/theme/create-theme.mjs +10 -0
  217. package/esm2022/utils/theme/is-object.mjs +10 -0
  218. package/esm2022/utils/theme/merge-theme.mjs +29 -0
  219. package/esm2022/utils/theme/to-string.mjs +10 -0
  220. package/fesm2022/flowbite-angular-accordion.mjs +338 -0
  221. package/fesm2022/flowbite-angular-accordion.mjs.map +1 -0
  222. package/fesm2022/flowbite-angular-alert.mjs +151 -0
  223. package/fesm2022/flowbite-angular-alert.mjs.map +1 -0
  224. package/fesm2022/flowbite-angular-badge.mjs +105 -0
  225. package/fesm2022/flowbite-angular-badge.mjs.map +1 -0
  226. package/fesm2022/flowbite-angular-breadcrumb.mjs +159 -0
  227. package/fesm2022/flowbite-angular-breadcrumb.mjs.map +1 -0
  228. package/fesm2022/flowbite-angular-button.mjs +223 -0
  229. package/fesm2022/flowbite-angular-button.mjs.map +1 -0
  230. package/fesm2022/flowbite-angular-core.mjs +288 -0
  231. package/fesm2022/flowbite-angular-core.mjs.map +1 -0
  232. package/fesm2022/flowbite-angular-dark-theme-toggle.mjs +105 -0
  233. package/fesm2022/flowbite-angular-dark-theme-toggle.mjs.map +1 -0
  234. package/fesm2022/flowbite-angular-dropdown.mjs +368 -0
  235. package/fesm2022/flowbite-angular-dropdown.mjs.map +1 -0
  236. package/fesm2022/flowbite-angular-icon.mjs +254 -0
  237. package/fesm2022/flowbite-angular-icon.mjs.map +1 -0
  238. package/fesm2022/flowbite-angular-indicator.mjs +146 -0
  239. package/fesm2022/flowbite-angular-indicator.mjs.map +1 -0
  240. package/fesm2022/flowbite-angular-modal.mjs +386 -0
  241. package/fesm2022/flowbite-angular-modal.mjs.map +1 -0
  242. package/fesm2022/flowbite-angular-navbar.mjs +422 -0
  243. package/fesm2022/flowbite-angular-navbar.mjs.map +1 -0
  244. package/fesm2022/flowbite-angular-router-link-active.mjs +56 -0
  245. package/fesm2022/flowbite-angular-router-link-active.mjs.map +1 -0
  246. package/fesm2022/flowbite-angular-router-link.mjs +61 -0
  247. package/fesm2022/flowbite-angular-router-link.mjs.map +1 -0
  248. package/fesm2022/flowbite-angular-sanitize-html.mjs +39 -0
  249. package/fesm2022/flowbite-angular-sanitize-html.mjs.map +1 -0
  250. package/fesm2022/flowbite-angular-scroll-top.mjs +99 -0
  251. package/fesm2022/flowbite-angular-scroll-top.mjs.map +1 -0
  252. package/fesm2022/flowbite-angular-sidebar.mjs +518 -0
  253. package/fesm2022/flowbite-angular-sidebar.mjs.map +1 -0
  254. package/fesm2022/flowbite-angular-utils.mjs +210 -0
  255. package/fesm2022/flowbite-angular-utils.mjs.map +1 -0
  256. package/fesm2022/flowbite-angular.mjs +13 -4176
  257. package/fesm2022/flowbite-angular.mjs.map +1 -1
  258. package/{lib/services/flowbite.theme.service.d.ts → flowbite.theme.service.d.ts} +1 -1
  259. package/icon/README.md +3 -0
  260. package/{lib/components/icon → icon}/icon.component.d.ts +2 -2
  261. package/index.d.ts +3 -5
  262. package/indicator/README.md +3 -0
  263. package/{lib/components/indicators → indicator}/indicators.component.d.ts +14 -14
  264. package/{lib/components/indicators → indicator}/indicators.theme.d.ts +1 -6
  265. package/{lib/components/indicators → indicator}/indicators.theme.service.d.ts +1 -1
  266. package/modal/README.md +3 -0
  267. package/{lib/components/modal → modal}/modal-body.component.d.ts +1 -1
  268. package/{lib/components/modal → modal}/modal-body.theme.d.ts +1 -1
  269. package/{lib/components/modal → modal}/modal-body.theme.service.d.ts +1 -1
  270. package/{lib/components/modal → modal}/modal-footer.component.d.ts +1 -1
  271. package/{lib/components/modal → modal}/modal-footer.theme.d.ts +1 -1
  272. package/{lib/components/modal → modal}/modal-footer.theme.service.d.ts +1 -1
  273. package/{lib/components/modal → modal}/modal-header.component.d.ts +2 -2
  274. package/{lib/components/modal → modal}/modal-header.theme.d.ts +1 -1
  275. package/{lib/components/modal → modal}/modal-header.theme.service.d.ts +1 -1
  276. package/{lib/components/modal → modal}/modal.component.d.ts +6 -6
  277. package/{lib/components/modal → modal}/modal.theme.d.ts +1 -5
  278. package/{lib/components/modal → modal}/modal.theme.service.d.ts +1 -1
  279. package/navbar/README.md +3 -0
  280. package/{lib/components/navbar → navbar}/navbar-brand.component.d.ts +1 -1
  281. package/{lib/components/navbar → navbar}/navbar-brand.theme.d.ts +1 -1
  282. package/{lib/components/navbar → navbar}/navbar-brand.theme.service.d.ts +1 -1
  283. package/{lib/components/navbar → navbar}/navbar-content.component.d.ts +1 -1
  284. package/{lib/components/navbar → navbar}/navbar-content.theme.d.ts +1 -1
  285. package/{lib/components/navbar → navbar}/navbar-content.theme.service.d.ts +1 -1
  286. package/{lib/components/navbar → navbar}/navbar-icon-button.component.d.ts +1 -1
  287. package/{lib/components/navbar → navbar}/navbar-icon-button.theme.d.ts +1 -1
  288. package/{lib/components/navbar → navbar}/navbar-icon-button.theme.service.d.ts +1 -1
  289. package/{lib/components/navbar → navbar}/navbar-item.component.d.ts +3 -3
  290. package/{lib/components/navbar → navbar}/navbar-item.theme.d.ts +1 -2
  291. package/{lib/components/navbar → navbar}/navbar-item.theme.service.d.ts +1 -1
  292. package/{lib/components/navbar → navbar}/navbar-toggle.component.d.ts +2 -2
  293. package/{lib/components/navbar → navbar}/navbar-toggle.theme.d.ts +1 -1
  294. package/{lib/components/navbar → navbar}/navbar-toggle.theme.service.d.ts +1 -1
  295. package/{lib/components/navbar → navbar}/navbar.component.d.ts +1 -1
  296. package/{lib/components/navbar → navbar}/navbar.theme.d.ts +1 -4
  297. package/{lib/components/navbar → navbar}/navbar.theme.service.d.ts +1 -1
  298. package/package.json +110 -2
  299. package/router-link/README.md +3 -0
  300. package/router-link/index.d.ts +1 -0
  301. package/router-link-active/README.md +3 -0
  302. package/{lib/directives → router-link-active}/index.d.ts +0 -1
  303. package/sanitize-html/README.md +3 -0
  304. package/scroll-top/README.md +3 -0
  305. package/{lib/components/scroll-top → scroll-top}/scroll-top.component.d.ts +7 -7
  306. package/{lib/components/scroll-top → scroll-top}/scroll-top.theme.d.ts +1 -1
  307. package/{lib/components/scroll-top → scroll-top}/scroll-top.theme.service.d.ts +1 -1
  308. package/sidebar/README.md +3 -0
  309. package/{lib/components/sidebar → sidebar}/sidebar-item-group.component.d.ts +3 -3
  310. package/{lib/components/sidebar → sidebar}/sidebar-item-group.theme.d.ts +1 -1
  311. package/{lib/components/sidebar → sidebar}/sidebar-item-group.theme.service.d.ts +1 -1
  312. package/{lib/components/sidebar → sidebar}/sidebar-item.component.d.ts +4 -4
  313. package/{lib/components/sidebar → sidebar}/sidebar-item.theme.d.ts +1 -2
  314. package/{lib/components/sidebar → sidebar}/sidebar-item.theme.service.d.ts +1 -1
  315. package/{lib/components/sidebar → sidebar}/sidebar-menu.component.d.ts +2 -2
  316. package/{lib/components/sidebar → sidebar}/sidebar-menu.theme.d.ts +1 -1
  317. package/{lib/components/sidebar → sidebar}/sidebar-menu.theme.service.d.ts +1 -1
  318. package/{lib/components/sidebar → sidebar}/sidebar-page-content.component.d.ts +1 -1
  319. package/{lib/components/sidebar → sidebar}/sidebar-page-content.theme.d.ts +1 -1
  320. package/{lib/components/sidebar → sidebar}/sidebar-page-content.theme.service.d.ts +1 -1
  321. package/{lib/components/sidebar → sidebar}/sidebar-toggle.component.d.ts +3 -3
  322. package/{lib/components/sidebar → sidebar}/sidebar-toggle.theme.d.ts +1 -1
  323. package/{lib/components/sidebar → sidebar}/sidebar-toggle.theme.service.d.ts +1 -1
  324. package/{lib/components/sidebar → sidebar}/sidebar.component.d.ts +1 -1
  325. package/{lib/components/sidebar → sidebar}/sidebar.theme.d.ts +1 -4
  326. package/{lib/components/sidebar → sidebar}/sidebar.theme.service.d.ts +1 -1
  327. package/{lib/utils/boolean.util.d.ts → type-definitions/flowbite.boolean.d.ts} +7 -1
  328. package/{lib/common/type-definitions → type-definitions}/index.d.ts +1 -0
  329. package/utils/README.md +3 -0
  330. package/{lib/utils → utils}/index.d.ts +1 -1
  331. package/esm2022/lib/common/flowbite.theme.init.mjs +0 -318
  332. package/esm2022/lib/common/index.mjs +0 -3
  333. package/esm2022/lib/common/type-definitions/colors/flowbite.colors.mjs +0 -2
  334. package/esm2022/lib/common/type-definitions/colors/flowbite.gradient-colors.mjs +0 -2
  335. package/esm2022/lib/common/type-definitions/colors/flowbite.gradient-duo-tone-colors.mjs +0 -2
  336. package/esm2022/lib/common/type-definitions/colors/index.mjs +0 -2
  337. package/esm2022/lib/common/type-definitions/flowbite.boolean.mjs +0 -2
  338. package/esm2022/lib/common/type-definitions/flowbite.class.mjs +0 -2
  339. package/esm2022/lib/common/type-definitions/flowbite.combination.mjs +0 -5
  340. package/esm2022/lib/common/type-definitions/flowbite.content-positions.mjs +0 -2
  341. package/esm2022/lib/common/type-definitions/flowbite.deep-partial.mjs +0 -2
  342. package/esm2022/lib/common/type-definitions/flowbite.heading-levels.mjs +0 -2
  343. package/esm2022/lib/common/type-definitions/flowbite.positions.mjs +0 -2
  344. package/esm2022/lib/common/type-definitions/flowbite.router-link-parameter.mjs +0 -2
  345. package/esm2022/lib/common/type-definitions/flowbite.sizes.mjs +0 -2
  346. package/esm2022/lib/common/type-definitions/flowbite.themes.mjs +0 -2
  347. package/esm2022/lib/common/type-definitions/index.mjs +0 -2
  348. package/esm2022/lib/components/accordion/accordion-content.component.mjs +0 -46
  349. package/esm2022/lib/components/accordion/accordion-content.theme.mjs +0 -19
  350. package/esm2022/lib/components/accordion/accordion-content.theme.service.mjs +0 -17
  351. package/esm2022/lib/components/accordion/accordion-panel.component.mjs +0 -57
  352. package/esm2022/lib/components/accordion/accordion-panel.theme.mjs +0 -7
  353. package/esm2022/lib/components/accordion/accordion-panel.theme.service.mjs +0 -17
  354. package/esm2022/lib/components/accordion/accordion-title.component.mjs +0 -70
  355. package/esm2022/lib/components/accordion/accordion-title.theme.mjs +0 -26
  356. package/esm2022/lib/components/accordion/accordion-title.theme.service.mjs +0 -18
  357. package/esm2022/lib/components/accordion/accordion.component.mjs +0 -49
  358. package/esm2022/lib/components/accordion/accordion.theme.mjs +0 -19
  359. package/esm2022/lib/components/accordion/accordion.theme.service.mjs +0 -17
  360. package/esm2022/lib/components/accordion/index.mjs +0 -13
  361. package/esm2022/lib/components/alert/alert.component.mjs +0 -95
  362. package/esm2022/lib/components/alert/alert.theme.mjs +0 -34
  363. package/esm2022/lib/components/alert/alert.theme.service.mjs +0 -18
  364. package/esm2022/lib/components/alert/index.mjs +0 -4
  365. package/esm2022/lib/components/badge/badge.component.mjs +0 -47
  366. package/esm2022/lib/components/badge/badge.theme.mjs +0 -34
  367. package/esm2022/lib/components/badge/badge.theme.service.mjs +0 -19
  368. package/esm2022/lib/components/badge/index.mjs +0 -4
  369. package/esm2022/lib/components/base-component.directive.mjs +0 -34
  370. package/esm2022/lib/components/breadcrumb/breadcrumb-item.component.mjs +0 -57
  371. package/esm2022/lib/components/breadcrumb/breadcrumb-item.theme.mjs +0 -18
  372. package/esm2022/lib/components/breadcrumb/breadcrumb-item.theme.service.mjs +0 -18
  373. package/esm2022/lib/components/breadcrumb/breadcrumb.component.mjs +0 -46
  374. package/esm2022/lib/components/breadcrumb/breadcrumb.theme.mjs +0 -7
  375. package/esm2022/lib/components/breadcrumb/breadcrumb.theme.service.mjs +0 -17
  376. package/esm2022/lib/components/breadcrumb/index.mjs +0 -7
  377. package/esm2022/lib/components/button/button.theme.mjs +0 -113
  378. package/esm2022/lib/components/button/button.theme.service.mjs +0 -24
  379. package/esm2022/lib/components/button/index.mjs +0 -4
  380. package/esm2022/lib/components/dark-theme-toggle/dark-theme-toggle.theme.mjs +0 -7
  381. package/esm2022/lib/components/dark-theme-toggle/dark-theme-toggle.theme.service.mjs +0 -17
  382. package/esm2022/lib/components/dark-theme-toggle/index.mjs +0 -4
  383. package/esm2022/lib/components/dropdown/dropdown-divider.component.mjs +0 -34
  384. package/esm2022/lib/components/dropdown/dropdown-divider.theme.mjs +0 -7
  385. package/esm2022/lib/components/dropdown/dropdown-divider.theme.service.mjs +0 -17
  386. package/esm2022/lib/components/dropdown/dropdown-header.component.mjs +0 -44
  387. package/esm2022/lib/components/dropdown/dropdown-header.theme.mjs +0 -10
  388. package/esm2022/lib/components/dropdown/dropdown-header.theme.service.mjs +0 -18
  389. package/esm2022/lib/components/dropdown/dropdown-item.component.mjs +0 -34
  390. package/esm2022/lib/components/dropdown/dropdown-item.theme.mjs +0 -6
  391. package/esm2022/lib/components/dropdown/dropdown-item.theme.service.mjs +0 -17
  392. package/esm2022/lib/components/dropdown/dropdown.component.mjs +0 -149
  393. package/esm2022/lib/components/dropdown/dropdown.theme.mjs +0 -32
  394. package/esm2022/lib/components/dropdown/dropdown.theme.service.mjs +0 -22
  395. package/esm2022/lib/components/dropdown/index.mjs +0 -13
  396. package/esm2022/lib/components/form-field/directives/addon.directive.mjs +0 -32
  397. package/esm2022/lib/components/form-field/directives/addon.directive.theme.mjs +0 -8
  398. package/esm2022/lib/components/form-field/directives/addon.directive.theme.service.mjs +0 -17
  399. package/esm2022/lib/components/form-field/directives/base-input.directive.mjs +0 -26
  400. package/esm2022/lib/components/form-field/directives/helper.directive.mjs +0 -34
  401. package/esm2022/lib/components/form-field/directives/helper.directive.theme.mjs +0 -12
  402. package/esm2022/lib/components/form-field/directives/helper.directive.theme.service.mjs +0 -17
  403. package/esm2022/lib/components/form-field/directives/icon.directive.mjs +0 -32
  404. package/esm2022/lib/components/form-field/directives/icon.directive.theme.mjs +0 -8
  405. package/esm2022/lib/components/form-field/directives/icon.directive.theme.service.mjs +0 -17
  406. package/esm2022/lib/components/form-field/directives/index.mjs +0 -17
  407. package/esm2022/lib/components/form-field/directives/input.directive.mjs +0 -41
  408. package/esm2022/lib/components/form-field/directives/input.directive.theme.mjs +0 -79
  409. package/esm2022/lib/components/form-field/directives/input.directive.theme.service.mjs +0 -32
  410. package/esm2022/lib/components/form-field/directives/label.directive.mjs +0 -41
  411. package/esm2022/lib/components/form-field/directives/label.directive.theme.mjs +0 -51
  412. package/esm2022/lib/components/form-field/directives/label.directive.theme.service.mjs +0 -23
  413. package/esm2022/lib/components/form-field/form-field.component.mjs +0 -40
  414. package/esm2022/lib/components/form-field/form-field.theme.mjs +0 -8
  415. package/esm2022/lib/components/form-field/form-field.theme.service.mjs +0 -17
  416. package/esm2022/lib/components/form-field/index.mjs +0 -5
  417. package/esm2022/lib/components/icon/icon-registry.mjs +0 -159
  418. package/esm2022/lib/components/icon/icon.component.mjs +0 -67
  419. package/esm2022/lib/components/icon/index.mjs +0 -4
  420. package/esm2022/lib/components/icon/trusted-types.mjs +0 -21
  421. package/esm2022/lib/components/index.mjs +0 -16
  422. package/esm2022/lib/components/indicators/index.mjs +0 -4
  423. package/esm2022/lib/components/indicators/indicators.component.mjs +0 -54
  424. package/esm2022/lib/components/indicators/indicators.theme.mjs +0 -68
  425. package/esm2022/lib/components/indicators/indicators.theme.service.mjs +0 -19
  426. package/esm2022/lib/components/modal/index.mjs +0 -13
  427. package/esm2022/lib/components/modal/modal-body.component.mjs +0 -34
  428. package/esm2022/lib/components/modal/modal-body.theme.mjs +0 -7
  429. package/esm2022/lib/components/modal/modal-body.theme.service.mjs +0 -17
  430. package/esm2022/lib/components/modal/modal-footer.component.mjs +0 -34
  431. package/esm2022/lib/components/modal/modal-footer.theme.mjs +0 -7
  432. package/esm2022/lib/components/modal/modal-footer.theme.service.mjs +0 -17
  433. package/esm2022/lib/components/modal/modal-header.component.mjs +0 -66
  434. package/esm2022/lib/components/modal/modal-header.theme.mjs +0 -13
  435. package/esm2022/lib/components/modal/modal-header.theme.service.mjs +0 -19
  436. package/esm2022/lib/components/modal/modal.component.mjs +0 -142
  437. package/esm2022/lib/components/modal/modal.theme.mjs +0 -33
  438. package/esm2022/lib/components/modal/modal.theme.service.mjs +0 -20
  439. package/esm2022/lib/components/navbar/index.mjs +0 -19
  440. package/esm2022/lib/components/navbar/navbar-brand.component.mjs +0 -34
  441. package/esm2022/lib/components/navbar/navbar-brand.theme.mjs +0 -7
  442. package/esm2022/lib/components/navbar/navbar-brand.theme.service.mjs +0 -17
  443. package/esm2022/lib/components/navbar/navbar-content.component.mjs +0 -45
  444. package/esm2022/lib/components/navbar/navbar-content.theme.mjs +0 -14
  445. package/esm2022/lib/components/navbar/navbar-content.theme.service.mjs +0 -18
  446. package/esm2022/lib/components/navbar/navbar-icon-button.component.mjs +0 -42
  447. package/esm2022/lib/components/navbar/navbar-icon-button.theme.mjs +0 -15
  448. package/esm2022/lib/components/navbar/navbar-icon-button.theme.service.mjs +0 -17
  449. package/esm2022/lib/components/navbar/navbar-item.component.mjs +0 -49
  450. package/esm2022/lib/components/navbar/navbar-item.theme.service.mjs +0 -17
  451. package/esm2022/lib/components/navbar/navbar-toggle.component.mjs +0 -50
  452. package/esm2022/lib/components/navbar/navbar-toggle.theme.mjs +0 -7
  453. package/esm2022/lib/components/navbar/navbar-toggle.theme.service.mjs +0 -17
  454. package/esm2022/lib/components/navbar/navbar.component.mjs +0 -62
  455. package/esm2022/lib/components/navbar/navbar.theme.mjs +0 -23
  456. package/esm2022/lib/components/navbar/navbar.theme.service.mjs +0 -17
  457. package/esm2022/lib/components/scroll-top/index.mjs +0 -4
  458. package/esm2022/lib/components/scroll-top/scroll-top.component.mjs +0 -50
  459. package/esm2022/lib/components/scroll-top/scroll-top.theme.mjs +0 -27
  460. package/esm2022/lib/components/scroll-top/scroll-top.theme.service.mjs +0 -17
  461. package/esm2022/lib/components/sidebar/index.mjs +0 -19
  462. package/esm2022/lib/components/sidebar/sidebar-item-group.component.mjs +0 -81
  463. package/esm2022/lib/components/sidebar/sidebar-item-group.theme.mjs +0 -18
  464. package/esm2022/lib/components/sidebar/sidebar-item-group.theme.service.mjs +0 -18
  465. package/esm2022/lib/components/sidebar/sidebar-item.component.mjs +0 -77
  466. package/esm2022/lib/components/sidebar/sidebar-item.theme.mjs +0 -18
  467. package/esm2022/lib/components/sidebar/sidebar-item.theme.service.mjs +0 -18
  468. package/esm2022/lib/components/sidebar/sidebar-menu.component.mjs +0 -49
  469. package/esm2022/lib/components/sidebar/sidebar-menu.theme.mjs +0 -24
  470. package/esm2022/lib/components/sidebar/sidebar-menu.theme.service.mjs +0 -17
  471. package/esm2022/lib/components/sidebar/sidebar-page-content.component.mjs +0 -36
  472. package/esm2022/lib/components/sidebar/sidebar-page-content.theme.mjs +0 -12
  473. package/esm2022/lib/components/sidebar/sidebar-page-content.theme.service.mjs +0 -17
  474. package/esm2022/lib/components/sidebar/sidebar-toggle.component.mjs +0 -53
  475. package/esm2022/lib/components/sidebar/sidebar-toggle.theme.mjs +0 -18
  476. package/esm2022/lib/components/sidebar/sidebar-toggle.theme.service.mjs +0 -17
  477. package/esm2022/lib/components/sidebar/sidebar.component.mjs +0 -61
  478. package/esm2022/lib/components/sidebar/sidebar.theme.mjs +0 -11
  479. package/esm2022/lib/components/sidebar/sidebar.theme.service.mjs +0 -17
  480. package/esm2022/lib/directives/flowbite-router-link-active.directive.mjs +0 -51
  481. package/esm2022/lib/directives/flowbite-router-link.directive.mjs +0 -44
  482. package/esm2022/lib/directives/index.mjs +0 -3
  483. package/esm2022/lib/pipes/index.mjs +0 -2
  484. package/esm2022/lib/pipes/sanitize-html/index.mjs +0 -2
  485. package/esm2022/lib/pipes/sanitize-html/sanitize-html.pipe.mjs +0 -32
  486. package/esm2022/lib/services/flowbite.theme.service.mjs +0 -16
  487. package/esm2022/lib/services/index.mjs +0 -2
  488. package/esm2022/lib/utils/boolean.util.mjs +0 -10
  489. package/esm2022/lib/utils/directives/index.mjs +0 -3
  490. package/esm2022/lib/utils/directives/inputs/index.mjs +0 -3
  491. package/esm2022/lib/utils/directives/inputs/router-link-active.input.mjs +0 -8
  492. package/esm2022/lib/utils/directives/inputs/router-link.inputs.mjs +0 -20
  493. package/esm2022/lib/utils/directives/outputs/index.mjs +0 -3
  494. package/esm2022/lib/utils/directives/outputs/router-link-active.output.mjs +0 -8
  495. package/esm2022/lib/utils/directives/outputs/router-link.output.mjs +0 -8
  496. package/esm2022/lib/utils/icon.list.mjs +0 -39
  497. package/esm2022/lib/utils/id.generator.mjs +0 -81
  498. package/esm2022/lib/utils/index.mjs +0 -9
  499. package/esm2022/lib/utils/theme/clone-deep.mjs +0 -18
  500. package/esm2022/lib/utils/theme/create-class.mjs +0 -10
  501. package/esm2022/lib/utils/theme/create-theme.mjs +0 -10
  502. package/esm2022/lib/utils/theme/is-object.mjs +0 -10
  503. package/esm2022/lib/utils/theme/merge-theme.mjs +0 -29
  504. package/esm2022/lib/utils/theme/to-string.mjs +0 -10
  505. package/esm2022/public-api.mjs +0 -7
  506. package/lib/common/index.d.ts +0 -2
  507. package/lib/common/type-definitions/flowbite.boolean.d.ts +0 -7
  508. package/lib/components/form-field/directives/addon.directive.d.ts +0 -13
  509. package/lib/components/form-field/directives/addon.directive.theme.d.ts +0 -10
  510. package/lib/components/form-field/directives/addon.directive.theme.service.d.ts +0 -8
  511. package/lib/components/form-field/directives/base-input.directive.d.ts +0 -14
  512. package/lib/components/form-field/directives/helper.directive.d.ts +0 -18
  513. package/lib/components/form-field/directives/helper.directive.theme.d.ts +0 -13
  514. package/lib/components/form-field/directives/helper.directive.theme.service.d.ts +0 -8
  515. package/lib/components/form-field/directives/icon.directive.d.ts +0 -13
  516. package/lib/components/form-field/directives/icon.directive.theme.d.ts +0 -10
  517. package/lib/components/form-field/directives/icon.directive.theme.service.d.ts +0 -8
  518. package/lib/components/form-field/directives/index.d.ts +0 -21
  519. package/lib/components/form-field/directives/input.directive.d.ts +0 -100
  520. package/lib/components/form-field/directives/input.directive.theme.d.ts +0 -24
  521. package/lib/components/form-field/directives/input.directive.theme.service.d.ts +0 -8
  522. package/lib/components/form-field/directives/label.directive.d.ts +0 -62
  523. package/lib/components/form-field/directives/label.directive.theme.d.ts +0 -20
  524. package/lib/components/form-field/directives/label.directive.theme.service.d.ts +0 -8
  525. package/lib/components/form-field/form-field.component.d.ts +0 -20
  526. package/lib/components/form-field/form-field.theme.d.ts +0 -45
  527. package/lib/components/form-field/form-field.theme.service.d.ts +0 -8
  528. package/lib/components/form-field/index.d.ts +0 -5
  529. package/lib/components/index.d.ts +0 -15
  530. package/lib/pipes/index.d.ts +0 -1
  531. package/lib/services/index.d.ts +0 -1
  532. package/lib/utils/directives/index.d.ts +0 -2
  533. package/lib/utils/directives/inputs/index.d.ts +0 -2
  534. package/lib/utils/directives/inputs/router-link-active.input.d.ts +0 -8
  535. package/lib/utils/directives/inputs/router-link.inputs.d.ts +0 -8
  536. package/lib/utils/directives/outputs/index.d.ts +0 -2
  537. package/lib/utils/directives/outputs/router-link-active.output.d.ts +0 -8
  538. package/lib/utils/directives/outputs/router-link.output.d.ts +0 -8
  539. package/public-api.d.ts +0 -6
  540. /package/{lib/components/accordion → accordion}/index.d.ts +0 -0
  541. /package/{lib/components/alert → alert}/index.d.ts +0 -0
  542. /package/{lib/components/badge → badge}/index.d.ts +0 -0
  543. /package/{lib/components/breadcrumb → breadcrumb}/index.d.ts +0 -0
  544. /package/{lib/components/button → button}/index.d.ts +0 -0
  545. /package/{lib/common → core}/flowbite.theme.init.d.ts +0 -0
  546. /package/{lib/components/dropdown → dropdown}/index.d.ts +0 -0
  547. /package/{lib/components/icon → icon}/icon-registry.d.ts +0 -0
  548. /package/{lib/components/icon → icon}/index.d.ts +0 -0
  549. /package/{lib/components/icon → icon}/trusted-types.d.ts +0 -0
  550. /package/{lib/components/indicators → indicator}/index.d.ts +0 -0
  551. /package/{lib/components/modal → modal}/index.d.ts +0 -0
  552. /package/{lib/components/navbar → navbar}/index.d.ts +0 -0
  553. /package/{lib/directives → router-link}/flowbite-router-link.directive.d.ts +0 -0
  554. /package/{lib/directives → router-link-active}/flowbite-router-link-active.directive.d.ts +0 -0
  555. /package/{lib/pipes/sanitize-html → sanitize-html}/index.d.ts +0 -0
  556. /package/{lib/pipes/sanitize-html → sanitize-html}/sanitize-html.pipe.d.ts +0 -0
  557. /package/{lib/components/scroll-top → scroll-top}/index.d.ts +0 -0
  558. /package/{lib/components/sidebar → sidebar}/index.d.ts +0 -0
  559. /package/{lib/common/type-definitions → type-definitions}/colors/flowbite.colors.d.ts +0 -0
  560. /package/{lib/common/type-definitions → type-definitions}/colors/flowbite.gradient-colors.d.ts +0 -0
  561. /package/{lib/common/type-definitions → type-definitions}/colors/flowbite.gradient-duo-tone-colors.d.ts +0 -0
  562. /package/{lib/common/type-definitions → type-definitions}/colors/index.d.ts +0 -0
  563. /package/{lib/common/type-definitions → type-definitions}/flowbite.class.d.ts +0 -0
  564. /package/{lib/common/type-definitions → type-definitions}/flowbite.combination.d.ts +0 -0
  565. /package/{lib/common/type-definitions → type-definitions}/flowbite.content-positions.d.ts +0 -0
  566. /package/{lib/common/type-definitions → type-definitions}/flowbite.deep-partial.d.ts +0 -0
  567. /package/{lib/common/type-definitions → type-definitions}/flowbite.heading-levels.d.ts +0 -0
  568. /package/{lib/common/type-definitions → type-definitions}/flowbite.positions.d.ts +0 -0
  569. /package/{lib/common/type-definitions → type-definitions}/flowbite.router-link-parameter.d.ts +0 -0
  570. /package/{lib/common/type-definitions → type-definitions}/flowbite.sizes.d.ts +0 -0
  571. /package/{lib/common/type-definitions → type-definitions}/flowbite.themes.d.ts +0 -0
  572. /package/{lib/utils → utils}/icon.list.d.ts +0 -0
  573. /package/{lib/utils → utils}/id.generator.d.ts +0 -0
  574. /package/{lib/utils → utils}/theme/clone-deep.d.ts +0 -0
  575. /package/{lib/utils → utils}/theme/create-class.d.ts +0 -0
  576. /package/{lib/utils → utils}/theme/create-theme.d.ts +0 -0
  577. /package/{lib/utils → utils}/theme/is-object.d.ts +0 -0
  578. /package/{lib/utils → utils}/theme/merge-theme.d.ts +0 -0
  579. /package/{lib/utils → utils}/theme/to-string.d.ts +0 -0
@@ -0,0 +1,151 @@
1
+ import { mergeTheme, CLOSE_SVG_ICON, createTheme } from 'flowbite-angular/utils';
2
+ import * as i0 from '@angular/core';
3
+ import { InjectionToken, inject, model, Component, ViewEncapsulation, ChangeDetectionStrategy } from '@angular/core';
4
+ import { twMerge } from 'tailwind-merge';
5
+ import { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';
6
+ import { ButtonComponent } from 'flowbite-angular/button';
7
+ import { IconRegistry, IconComponent } from 'flowbite-angular/icon';
8
+ import { NgIf, NgClass, NgTemplateOutlet } from '@angular/common';
9
+ import { DomSanitizer } from '@angular/platform-browser';
10
+
11
+ const FLOWBITE_ALERT_THEME_TOKEN = new InjectionToken('FLOWBITE_ALERT_THEME_TOKEN');
12
+ class AlertThemeService {
13
+ constructor() {
14
+ this.baseTheme = inject(FLOWBITE_ALERT_THEME_TOKEN);
15
+ }
16
+ getClasses(properties) {
17
+ const theme = mergeTheme(this.baseTheme, properties.customStyle);
18
+ const output = {
19
+ rootClass: twMerge(theme.root.base, theme.root.color[properties.color], theme.root.hasBorder[properties.hasBorder], theme.root.hasBorderAccent[properties.hasBorderAccent]),
20
+ closeButtonClass: twMerge(theme.closeButton.base, theme.closeButton.color[properties.color]),
21
+ };
22
+ return output;
23
+ }
24
+ }
25
+
26
+ class AlertComponent extends BaseComponent {
27
+ constructor() {
28
+ super(...arguments);
29
+ this.themeService = inject(AlertThemeService);
30
+ this.iconRegistry = inject(IconRegistry);
31
+ this.domSanitizer = inject(DomSanitizer);
32
+ //#region properties
33
+ this.color = model('primary');
34
+ this.hasBorder = model(false);
35
+ this.hasBorderAccent = model(false);
36
+ this.customStyle = model({});
37
+ this.icon = model(null);
38
+ this.additionalContent = model(null);
39
+ this.isDismissable = model(false);
40
+ this.onDismiss = model();
41
+ }
42
+ //#endregion
43
+ //#region BaseComponent implementation
44
+ fetchClass() {
45
+ return this.themeService.getClasses({
46
+ color: this.color(),
47
+ hasBorder: booleanToFlowbiteBoolean(this.hasBorder()),
48
+ hasBorderAccent: booleanToFlowbiteBoolean(this.hasBorderAccent()),
49
+ customStyle: this.customStyle(),
50
+ });
51
+ }
52
+ init() {
53
+ this.iconRegistry.addRawSvgIconInNamepsace('flowbite-angular', 'close', this.domSanitizer.bypassSecurityTrustHtml(CLOSE_SVG_ICON));
54
+ }
55
+ //#endregion
56
+ onDismissClick() {
57
+ const func = this.onDismiss();
58
+ if (func)
59
+ func();
60
+ }
61
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AlertComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
62
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.0", type: AlertComponent, isStandalone: true, selector: "flowbite-alert", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, hasBorder: { classPropertyName: "hasBorder", publicName: "hasBorder", isSignal: true, isRequired: false, transformFunction: null }, hasBorderAccent: { classPropertyName: "hasBorderAccent", publicName: "hasBorderAccent", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, additionalContent: { classPropertyName: "additionalContent", publicName: "additionalContent", isSignal: true, isRequired: false, transformFunction: null }, isDismissable: { classPropertyName: "isDismissable", publicName: "isDismissable", isSignal: true, isRequired: false, transformFunction: null }, onDismiss: { classPropertyName: "onDismiss", publicName: "onDismiss", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { color: "colorChange", hasBorder: "hasBorderChange", hasBorderAccent: "hasBorderAccentChange", customStyle: "customStyleChange", icon: "iconChange", additionalContent: "additionalContentChange", isDismissable: "isDismissableChange", onDismiss: "onDismissChange" }, host: { properties: { "attr.role": "alert" } }, usesInheritance: true, ngImport: i0, template: `
63
+ <div class="flex items-center">
64
+ <ng-container [ngTemplateOutlet]="icon()"></ng-container>
65
+ <div>
66
+ <ng-content />
67
+ </div>
68
+ <button
69
+ type="button"
70
+ [ngClass]="contentClasses()!.closeButtonClass"
71
+ *ngIf="isDismissable()"
72
+ aria-label="Close"
73
+ (click)="onDismissClick()">
74
+ <span class="sr-only">Close</span>
75
+ <flowbite-icon svgIcon="flowbite-angular:close" class="h-5 w-5" />
76
+ </button>
77
+ </div>
78
+ <ng-container [ngTemplateOutlet]="additionalContent()"></ng-container>
79
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: IconComponent, selector: "flowbite-icon", inputs: ["svgIcon"], outputs: ["svgIconChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
80
+ }
81
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AlertComponent, decorators: [{
82
+ type: Component,
83
+ args: [{
84
+ standalone: true,
85
+ imports: [NgIf, NgClass, NgTemplateOutlet, IconComponent, ButtonComponent],
86
+ selector: 'flowbite-alert',
87
+ template: `
88
+ <div class="flex items-center">
89
+ <ng-container [ngTemplateOutlet]="icon()"></ng-container>
90
+ <div>
91
+ <ng-content />
92
+ </div>
93
+ <button
94
+ type="button"
95
+ [ngClass]="contentClasses()!.closeButtonClass"
96
+ *ngIf="isDismissable()"
97
+ aria-label="Close"
98
+ (click)="onDismissClick()">
99
+ <span class="sr-only">Close</span>
100
+ <flowbite-icon svgIcon="flowbite-angular:close" class="h-5 w-5" />
101
+ </button>
102
+ </div>
103
+ <ng-container [ngTemplateOutlet]="additionalContent()"></ng-container>
104
+ `,
105
+ host: {
106
+ '[attr.role]': 'alert',
107
+ },
108
+ encapsulation: ViewEncapsulation.None,
109
+ changeDetection: ChangeDetectionStrategy.OnPush,
110
+ }]
111
+ }] });
112
+
113
+ const alertTheme = createTheme({
114
+ root: {
115
+ base: 'flex flex-col gap-2 p-4 text-sm rounded-lg',
116
+ color: {
117
+ primary: 'text-primary-800 dark:text-primary-400 bg-primary-50 dark:bg-gray-800 border-primary-300 dark:border-primary-800',
118
+ dark: 'text-gray-800 dark:text-gray-300 bg-gray-100 dark:bg-gray-800 border-gray-300 dark:border-gray-600',
119
+ blue: 'text-blue-800 dark:text-blue-400 bg-blue-50 dark:bg-gray-800 border-blue-300 dark:border-blue-800',
120
+ red: 'text-red-800 dark:text-red-400 bg-red-100 dark:bg-gray-800 border-red-300 dark:border-red-800',
121
+ green: 'text-green-800 dark:text-green-400 bg-green-100 dark:bg-gray-800 border-green-300 dark:border-green-800',
122
+ yellow: 'text-yellow-800 dark:text-yellow-300 bg-yellow-100 dark:bg-gray-800 border-yellow-300 dark:border-yellow-800',
123
+ },
124
+ hasBorder: {
125
+ enabled: 'border',
126
+ disabled: 'border-0',
127
+ },
128
+ hasBorderAccent: {
129
+ enabled: 'border-t-4',
130
+ disabled: '',
131
+ },
132
+ },
133
+ closeButton: {
134
+ base: '-mx-1.5 -my-1.5 ml-auto inline-flex h-8 w-8 rounded-lg p-1.5 focus:ring-2',
135
+ color: {
136
+ primary: 'text-primary-500 dark:text-primary-600 hover:bg-primary-200 dark:hover:bg-primary-300',
137
+ dark: 'text-gray-500 dark:text-gray-600 hover:bg-gray-200 dark:hover:bg-gray-300',
138
+ blue: 'text-blue-500 dark:text-blue-600 hover:bg-blue-200 dark:hover:bg-blue-300',
139
+ red: 'text-red-500 dark:text-red-600 hover:bg-red-200 dark:hover:bg-red-300',
140
+ green: 'text-green-500 dark:text-green-600 hover:bg-green-200 dark:hover:bg-green-300',
141
+ yellow: 'text-yellow-500 dark:text-yellow-600 hover:bg-yellow-200 dark:hover:bg-yellow-300',
142
+ },
143
+ },
144
+ });
145
+
146
+ /**
147
+ * Generated bundle index. Do not edit.
148
+ */
149
+
150
+ export { AlertComponent, AlertThemeService, FLOWBITE_ALERT_THEME_TOKEN, alertTheme };
151
+ //# sourceMappingURL=flowbite-angular-alert.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flowbite-angular-alert.mjs","sources":["../../../../libs/flowbite-angular/alert/alert.theme.service.ts","../../../../libs/flowbite-angular/alert/alert.component.ts","../../../../libs/flowbite-angular/alert/alert.theme.ts","../../../../libs/flowbite-angular/alert/flowbite-angular-alert.ts"],"sourcesContent":["import type { AlertClass, AlertProperties, AlertTheme } from './alert.theme';\n\nimport type { FlowbiteThemeService } from 'flowbite-angular';\nimport { mergeTheme } from 'flowbite-angular/utils';\n\nimport { inject, InjectionToken } from '@angular/core';\nimport { twMerge } from 'tailwind-merge';\n\nexport const FLOWBITE_ALERT_THEME_TOKEN = new InjectionToken<AlertTheme>(\n 'FLOWBITE_ALERT_THEME_TOKEN'\n);\n\nexport class AlertThemeService implements FlowbiteThemeService<AlertProperties> {\n private readonly baseTheme = inject(FLOWBITE_ALERT_THEME_TOKEN);\n\n public getClasses(properties: AlertProperties): AlertClass {\n const theme: AlertTheme = mergeTheme(this.baseTheme, properties.customStyle);\n\n const output: AlertClass = {\n rootClass: twMerge(\n theme.root.base,\n theme.root.color[properties.color],\n theme.root.hasBorder[properties.hasBorder],\n theme.root.hasBorderAccent[properties.hasBorderAccent]\n ),\n closeButtonClass: twMerge(theme.closeButton.base, theme.closeButton.color[properties.color]),\n };\n\n return output;\n }\n}\n","import type { AlertClass, AlertColors, AlertTheme } from './alert.theme';\nimport { AlertThemeService } from './alert.theme.service';\n\nimport { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';\nimport type { DeepPartial } from 'flowbite-angular';\nimport { ButtonComponent } from 'flowbite-angular/button';\nimport { IconComponent, IconRegistry } from 'flowbite-angular/icon';\nimport { CLOSE_SVG_ICON } from 'flowbite-angular/utils';\n\nimport { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport type { OnInit, TemplateRef } from '@angular/core';\nimport {\n ChangeDetectionStrategy,\n Component,\n inject,\n model,\n ViewEncapsulation,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\n@Component({\n standalone: true,\n imports: [NgIf, NgClass, NgTemplateOutlet, IconComponent, ButtonComponent],\n selector: 'flowbite-alert',\n template: `\n <div class=\"flex items-center\">\n <ng-container [ngTemplateOutlet]=\"icon()\"></ng-container>\n <div>\n <ng-content />\n </div>\n <button\n type=\"button\"\n [ngClass]=\"contentClasses()!.closeButtonClass\"\n *ngIf=\"isDismissable()\"\n aria-label=\"Close\"\n (click)=\"onDismissClick()\">\n <span class=\"sr-only\">Close</span>\n <flowbite-icon svgIcon=\"flowbite-angular:close\" class=\"h-5 w-5\" />\n </button>\n </div>\n <ng-container [ngTemplateOutlet]=\"additionalContent()\"></ng-container>\n `,\n host: {\n '[attr.role]': 'alert',\n },\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AlertComponent extends BaseComponent<AlertClass> implements OnInit {\n public readonly themeService = inject(AlertThemeService);\n public readonly iconRegistry = inject(IconRegistry);\n public readonly domSanitizer = inject(DomSanitizer);\n\n //#region properties\n public color = model<keyof AlertColors>('primary');\n public hasBorder = model<boolean>(false);\n public hasBorderAccent = model<boolean>(false);\n public customStyle = model<DeepPartial<AlertTheme>>({});\n public icon = model<TemplateRef<unknown> | null>(null);\n public additionalContent = model<TemplateRef<unknown> | null>(null);\n public isDismissable = model<boolean>(false);\n public onDismiss = model<() => void | undefined>();\n //#endregion\n\n //#region BaseComponent implementation\n public override fetchClass(): AlertClass {\n return this.themeService.getClasses({\n color: this.color(),\n hasBorder: booleanToFlowbiteBoolean(this.hasBorder()),\n hasBorderAccent: booleanToFlowbiteBoolean(this.hasBorderAccent()),\n customStyle: this.customStyle(),\n });\n }\n\n public override init(): void {\n this.iconRegistry.addRawSvgIconInNamepsace(\n 'flowbite-angular',\n 'close',\n this.domSanitizer.bypassSecurityTrustHtml(CLOSE_SVG_ICON)\n );\n }\n //#endregion\n\n public onDismissClick() {\n const func = this.onDismiss();\n\n if (func) func();\n }\n}\n","import type { DeepPartial, FlowbiteBoolean, FlowbiteClass, FlowbiteColors } from 'flowbite-angular';\nimport { createTheme } from 'flowbite-angular/utils';\n\n//#region Component theme option\nexport type AlertColors = Pick<\n FlowbiteColors,\n 'primary' | 'dark' | 'blue' | 'red' | 'green' | 'yellow'\n>;\n//#endregion\n\nexport interface AlertProperties {\n color: keyof AlertColors;\n hasBorder: keyof FlowbiteBoolean;\n hasBorderAccent: keyof FlowbiteBoolean;\n customStyle: DeepPartial<AlertTheme>;\n}\n\nexport interface AlertTheme {\n root: {\n base: string;\n color: AlertColors;\n hasBorder: FlowbiteBoolean;\n hasBorderAccent: FlowbiteBoolean;\n };\n closeButton: {\n base: string;\n color: AlertColors;\n };\n}\n\nexport const alertTheme: AlertTheme = createTheme({\n root: {\n base: 'flex flex-col gap-2 p-4 text-sm rounded-lg',\n color: {\n primary:\n 'text-primary-800 dark:text-primary-400 bg-primary-50 dark:bg-gray-800 border-primary-300 dark:border-primary-800',\n dark: 'text-gray-800 dark:text-gray-300 bg-gray-100 dark:bg-gray-800 border-gray-300 dark:border-gray-600',\n blue: 'text-blue-800 dark:text-blue-400 bg-blue-50 dark:bg-gray-800 border-blue-300 dark:border-blue-800',\n red: 'text-red-800 dark:text-red-400 bg-red-100 dark:bg-gray-800 border-red-300 dark:border-red-800',\n green:\n 'text-green-800 dark:text-green-400 bg-green-100 dark:bg-gray-800 border-green-300 dark:border-green-800',\n yellow:\n 'text-yellow-800 dark:text-yellow-300 bg-yellow-100 dark:bg-gray-800 border-yellow-300 dark:border-yellow-800',\n },\n hasBorder: {\n enabled: 'border',\n disabled: 'border-0',\n },\n hasBorderAccent: {\n enabled: 'border-t-4',\n disabled: '',\n },\n },\n closeButton: {\n base: '-mx-1.5 -my-1.5 ml-auto inline-flex h-8 w-8 rounded-lg p-1.5 focus:ring-2',\n color: {\n primary:\n 'text-primary-500 dark:text-primary-600 hover:bg-primary-200 dark:hover:bg-primary-300',\n dark: 'text-gray-500 dark:text-gray-600 hover:bg-gray-200 dark:hover:bg-gray-300',\n blue: 'text-blue-500 dark:text-blue-600 hover:bg-blue-200 dark:hover:bg-blue-300',\n red: 'text-red-500 dark:text-red-600 hover:bg-red-200 dark:hover:bg-red-300',\n green: 'text-green-500 dark:text-green-600 hover:bg-green-200 dark:hover:bg-green-300',\n yellow: 'text-yellow-500 dark:text-yellow-600 hover:bg-yellow-200 dark:hover:bg-yellow-300',\n },\n },\n});\n\nexport interface AlertClass extends FlowbiteClass {\n closeButtonClass: string;\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,105 @@
1
+ import { mergeTheme, createTheme } from 'flowbite-angular/utils';
2
+ import * as i0 from '@angular/core';
3
+ import { InjectionToken, inject, model, Component, ViewEncapsulation, ChangeDetectionStrategy } from '@angular/core';
4
+ import { twMerge } from 'tailwind-merge';
5
+ import { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';
6
+ import { FlowbiteRouterLinkDirective } from 'flowbite-angular/router-link';
7
+ import { NgClass } from '@angular/common';
8
+
9
+ const FLOWBITE_BADGE_THEME_TOKEN = new InjectionToken('FLOWBITE_BADGE_THEME_TOKEN');
10
+ class BadgeThemeService {
11
+ constructor() {
12
+ this.baseTheme = inject(FLOWBITE_BADGE_THEME_TOKEN);
13
+ }
14
+ getClasses(properties) {
15
+ const theme = mergeTheme(this.baseTheme, properties.customStyle);
16
+ const output = {
17
+ rootClass: twMerge(theme.root.base, theme.root.color[properties.color], theme.root.size[properties.size], theme.root.isPill[properties.isPill == 'enabled' || properties.isIconOnly == 'enabled'
18
+ ? 'enabled'
19
+ : properties.isPill], theme.root.isIconOnly[properties.isIconOnly], theme.root.link[properties.link ? 'enabled' : 'disabled']),
20
+ };
21
+ return output;
22
+ }
23
+ }
24
+
25
+ /**
26
+ * @see https://flowbite.com/docs/components/badge/
27
+ */
28
+ class BadgeComponent extends BaseComponent {
29
+ constructor() {
30
+ super(...arguments);
31
+ this.flowbiteRouterLink = inject(FlowbiteRouterLinkDirective, { optional: true });
32
+ this.themeService = inject(BadgeThemeService);
33
+ //#region properties
34
+ this.color = model('primary');
35
+ this.size = model('xs');
36
+ this.isIconOnly = model(false);
37
+ this.isPill = model(false);
38
+ this.customStyle = model({});
39
+ }
40
+ //#endregion
41
+ //#region BaseComponent implementation
42
+ fetchClass() {
43
+ return this.themeService.getClasses({
44
+ color: this.color(),
45
+ size: this.size(),
46
+ isIconOnly: booleanToFlowbiteBoolean(this.isIconOnly()),
47
+ isPill: booleanToFlowbiteBoolean(this.isPill()),
48
+ link: this.flowbiteRouterLink?.routerLink.urlTree ?? null,
49
+ customStyle: this.customStyle(),
50
+ });
51
+ }
52
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: BadgeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
53
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.0", type: BadgeComponent, isStandalone: true, selector: "flowbite-badge", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, isIconOnly: { classPropertyName: "isIconOnly", publicName: "isIconOnly", isSignal: true, isRequired: false, transformFunction: null }, isPill: { classPropertyName: "isPill", publicName: "isPill", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { color: "colorChange", size: "sizeChange", isIconOnly: "isIconOnlyChange", isPill: "isPillChange", customStyle: "customStyleChange" }, usesInheritance: true, ngImport: i0, template: `<ng-content />`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
54
+ }
55
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: BadgeComponent, decorators: [{
56
+ type: Component,
57
+ args: [{
58
+ standalone: true,
59
+ imports: [NgClass],
60
+ selector: 'flowbite-badge',
61
+ template: `<ng-content />`,
62
+ encapsulation: ViewEncapsulation.None,
63
+ changeDetection: ChangeDetectionStrategy.OnPush,
64
+ }]
65
+ }] });
66
+
67
+ const badgeTheme = createTheme({
68
+ root: {
69
+ base: 'flex h-fit items-center gap-1 font-semibold',
70
+ color: {
71
+ primary: 'bg-primary-100 dark:bg-primary-700 text-primary-800 dark:text-primary-300 group-hover:bg-primary-200 dark:group-hover:bg-primary-600',
72
+ dark: 'bg-gray-100 dark:bg-gray-700 text-gray-800 dark:text-gray-300 group-hover:bg-gray-200 dark:group-hover:bg-gray-600',
73
+ blue: 'bg-blue-100 dark:bg-blue-200 text-blue-800 dark:text-blue-800 group-hover:bg-blue-200 dark:group-hover:bg-blue-300',
74
+ red: 'bg-red-100 dark:bg-red-200 text-red-800 dark:text-red-900 group-hover:bg-red-200 dark:group-hover:bg-red-300',
75
+ green: 'bg-green-100 dark:bg-green-200 text-green-800 dark:text-green-900 group-hover:bg-green-200 dark:group-hover:bg-green-300',
76
+ yellow: 'bg-yellow-100 dark:bg-yellow-200 text-yellow-800 dark:text-yellow-900 group-hover:bg-yellow-200 dark:group-hover:bg-yellow-300',
77
+ indigo: 'bg-indigo-100 dark:bg-indigo-200 text-indigo-800 dark:text-indigo-900 group-hover:bg-indigo-200 dark:group-hover:bg-indigo-300',
78
+ purple: 'bg-purple-100 dark:bg-purple-200 text-purple-800 dark:text-purple-900 group-hover:bg-purple-200 dark:group-hover:bg-purple-300',
79
+ pink: 'bg-pink-100 dark:bg-pink-200 text-pink-800 dark:text-pink-900 group-hover:bg-pink-200 dark:group-hover:bg-pink-300',
80
+ },
81
+ size: {
82
+ xs: 'text-xs p-1',
83
+ sm: 'text-sm p-1.5',
84
+ },
85
+ isPill: {
86
+ enabled: 'rounded-full',
87
+ disabled: 'rounded',
88
+ },
89
+ link: {
90
+ enabled: 'group cursor-pointer',
91
+ disabled: '',
92
+ },
93
+ isIconOnly: {
94
+ enabled: '',
95
+ disabled: 'px-2 py-0.5',
96
+ },
97
+ },
98
+ });
99
+
100
+ /**
101
+ * Generated bundle index. Do not edit.
102
+ */
103
+
104
+ export { BadgeComponent, BadgeThemeService, FLOWBITE_BADGE_THEME_TOKEN, badgeTheme };
105
+ //# sourceMappingURL=flowbite-angular-badge.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flowbite-angular-badge.mjs","sources":["../../../../libs/flowbite-angular/badge/badge.theme.service.ts","../../../../libs/flowbite-angular/badge/badge.component.ts","../../../../libs/flowbite-angular/badge/badge.theme.ts","../../../../libs/flowbite-angular/badge/flowbite-angular-badge.ts"],"sourcesContent":["import type { BadgeClass, BadgeProperties, BadgeTheme } from './badge.theme';\n\nimport type { FlowbiteThemeService } from 'flowbite-angular';\nimport { mergeTheme } from 'flowbite-angular/utils';\n\nimport { inject, InjectionToken } from '@angular/core';\nimport { twMerge } from 'tailwind-merge';\n\nexport const FLOWBITE_BADGE_THEME_TOKEN = new InjectionToken<BadgeTheme>(\n 'FLOWBITE_BADGE_THEME_TOKEN'\n);\n\nexport class BadgeThemeService implements FlowbiteThemeService<BadgeProperties> {\n private readonly baseTheme = inject(FLOWBITE_BADGE_THEME_TOKEN);\n\n public getClasses(properties: BadgeProperties): BadgeClass {\n const theme: BadgeTheme = mergeTheme(this.baseTheme, properties.customStyle);\n\n const output: BadgeClass = {\n rootClass: twMerge(\n theme.root.base,\n theme.root.color[properties.color],\n theme.root.size[properties.size],\n theme.root.isPill[\n properties.isPill == 'enabled' || properties.isIconOnly == 'enabled'\n ? 'enabled'\n : properties.isPill\n ],\n theme.root.isIconOnly[properties.isIconOnly],\n theme.root.link[properties.link ? 'enabled' : 'disabled']\n ),\n };\n\n return output;\n }\n}\n","import type { BadgeClass, BadgeColors, BadgeSizes, BadgeTheme } from './badge.theme';\nimport { BadgeThemeService } from './badge.theme.service';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';\nimport { FlowbiteRouterLinkDirective } from 'flowbite-angular/router-link';\n\nimport { NgClass } from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n inject,\n model,\n ViewEncapsulation,\n} from '@angular/core';\n\n/**\n * @see https://flowbite.com/docs/components/badge/\n */\n@Component({\n standalone: true,\n imports: [NgClass],\n selector: 'flowbite-badge',\n template: `<ng-content />`,\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BadgeComponent extends BaseComponent<BadgeClass> {\n public readonly flowbiteRouterLink = inject(FlowbiteRouterLinkDirective, { optional: true });\n public readonly themeService = inject(BadgeThemeService);\n\n //#region properties\n public color = model<keyof BadgeColors>('primary');\n public size = model<keyof BadgeSizes>('xs');\n public isIconOnly = model<boolean>(false);\n public isPill = model<boolean>(false);\n public customStyle = model<DeepPartial<BadgeTheme>>({});\n //#endregion\n\n //#region BaseComponent implementation\n public override fetchClass(): BadgeClass {\n return this.themeService.getClasses({\n color: this.color(),\n size: this.size(),\n isIconOnly: booleanToFlowbiteBoolean(this.isIconOnly()),\n isPill: booleanToFlowbiteBoolean(this.isPill()),\n link: this.flowbiteRouterLink?.routerLink.urlTree ?? null,\n customStyle: this.customStyle(),\n });\n }\n //#endregion\n}\n","import type {\n DeepPartial,\n FlowbiteBoolean,\n FlowbiteClass,\n FlowbiteColors,\n FlowbiteSizes,\n RouterLinkParameter,\n} from 'flowbite-angular';\nimport { createTheme } from 'flowbite-angular/utils';\n\n//#region Component theme option\nexport interface BadgeColors\n extends Pick<\n FlowbiteColors,\n 'primary' | 'dark' | 'blue' | 'red' | 'green' | 'yellow' | 'indigo' | 'purple' | 'pink'\n > {\n [key: string]: string;\n}\n\nexport interface BadgeSizes extends Pick<FlowbiteSizes, 'xs' | 'sm'> {\n [key: string]: string;\n}\n//#endregion\n\nexport interface BadgeProperties {\n color: keyof BadgeColors;\n size: keyof BadgeSizes;\n isIconOnly: keyof FlowbiteBoolean;\n isPill: keyof FlowbiteBoolean;\n link: RouterLinkParameter;\n customStyle: DeepPartial<BadgeTheme>;\n}\n\nexport interface BadgeTheme {\n root: {\n base: string;\n color: BadgeColors;\n size: BadgeSizes;\n isPill: FlowbiteBoolean;\n isIconOnly: FlowbiteBoolean;\n link: FlowbiteBoolean;\n };\n}\n\nexport const badgeTheme: BadgeTheme = createTheme({\n root: {\n base: 'flex h-fit items-center gap-1 font-semibold',\n color: {\n primary:\n 'bg-primary-100 dark:bg-primary-700 text-primary-800 dark:text-primary-300 group-hover:bg-primary-200 dark:group-hover:bg-primary-600',\n dark: 'bg-gray-100 dark:bg-gray-700 text-gray-800 dark:text-gray-300 group-hover:bg-gray-200 dark:group-hover:bg-gray-600',\n blue: 'bg-blue-100 dark:bg-blue-200 text-blue-800 dark:text-blue-800 group-hover:bg-blue-200 dark:group-hover:bg-blue-300',\n red: 'bg-red-100 dark:bg-red-200 text-red-800 dark:text-red-900 group-hover:bg-red-200 dark:group-hover:bg-red-300',\n green:\n 'bg-green-100 dark:bg-green-200 text-green-800 dark:text-green-900 group-hover:bg-green-200 dark:group-hover:bg-green-300',\n yellow:\n 'bg-yellow-100 dark:bg-yellow-200 text-yellow-800 dark:text-yellow-900 group-hover:bg-yellow-200 dark:group-hover:bg-yellow-300',\n indigo:\n 'bg-indigo-100 dark:bg-indigo-200 text-indigo-800 dark:text-indigo-900 group-hover:bg-indigo-200 dark:group-hover:bg-indigo-300',\n purple:\n 'bg-purple-100 dark:bg-purple-200 text-purple-800 dark:text-purple-900 group-hover:bg-purple-200 dark:group-hover:bg-purple-300',\n pink: 'bg-pink-100 dark:bg-pink-200 text-pink-800 dark:text-pink-900 group-hover:bg-pink-200 dark:group-hover:bg-pink-300',\n },\n size: {\n xs: 'text-xs p-1',\n sm: 'text-sm p-1.5',\n },\n isPill: {\n enabled: 'rounded-full',\n disabled: 'rounded',\n },\n link: {\n enabled: 'group cursor-pointer',\n disabled: '',\n },\n isIconOnly: {\n enabled: '',\n disabled: 'px-2 py-0.5',\n },\n },\n});\n\nexport type BadgeClass = FlowbiteClass;\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,159 @@
1
+ import { mergeTheme, CHEVRON_RIGHT_SVG_ICON, createTheme } from 'flowbite-angular/utils';
2
+ import * as i0 from '@angular/core';
3
+ import { InjectionToken, inject, model, Component, ViewEncapsulation, ChangeDetectionStrategy, contentChildren } from '@angular/core';
4
+ import { twMerge } from 'tailwind-merge';
5
+ import { BaseComponent } from 'flowbite-angular';
6
+ import { IconRegistry, IconComponent } from 'flowbite-angular/icon';
7
+ import { FlowbiteRouterLinkDirective } from 'flowbite-angular/router-link';
8
+ import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';
9
+ import { DomSanitizer } from '@angular/platform-browser';
10
+
11
+ const FLOWBITE_BREADCRUMB_ITEM_THEME_TOKEN = new InjectionToken('FLOWBITE_BREADCRUMB_ITEM_THEME_TOKEN');
12
+ class BreadcrumbItemThemeService {
13
+ constructor() {
14
+ this.baseTheme = inject(FLOWBITE_BREADCRUMB_ITEM_THEME_TOKEN);
15
+ }
16
+ getClasses(properties) {
17
+ const theme = mergeTheme(this.baseTheme, properties.customStyle);
18
+ const output = {
19
+ rootClass: twMerge(theme.root.base, theme.root.color[properties.color]),
20
+ breadcrumbIconClass: twMerge(theme.icon.base),
21
+ };
22
+ return output;
23
+ }
24
+ }
25
+
26
+ class BreadcrumbItemComponent extends BaseComponent {
27
+ constructor() {
28
+ super(...arguments);
29
+ this.themeService = inject(BreadcrumbItemThemeService);
30
+ this.breadcrumbComponent = inject(BreadcrumbComponent);
31
+ this.flowbiteRouterLink = inject(FlowbiteRouterLinkDirective, { optional: true });
32
+ this.iconRegistry = inject(IconRegistry);
33
+ this.domSanitizer = inject(DomSanitizer);
34
+ //#region properties
35
+ this.color = model(this.breadcrumbComponent.color());
36
+ this.customStyle = model({});
37
+ }
38
+ //#endregion
39
+ //#region BaseComponent implementation
40
+ fetchClass() {
41
+ return this.themeService.getClasses({
42
+ color: this.color(),
43
+ link: this.flowbiteRouterLink?.routerLink.urlTree ?? null,
44
+ customStyle: this.customStyle(),
45
+ });
46
+ }
47
+ init() {
48
+ this.iconRegistry.addRawSvgIconInNamepsace('flowbite-angular', 'chevron-right', this.domSanitizer.bypassSecurityTrustHtml(CHEVRON_RIGHT_SVG_ICON));
49
+ }
50
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: BreadcrumbItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
51
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.0", type: BreadcrumbItemComponent, isStandalone: true, selector: "flowbite-breadcrumb-item", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { color: "colorChange", customStyle: "customStyleChange" }, usesInheritance: true, ngImport: i0, template: `
52
+ <flowbite-icon
53
+ [ngClass]="contentClasses().breadcrumbIconClass"
54
+ svgIcon="flowbite-angular:chevron-right" />
55
+ <ng-content />
56
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: IconComponent, selector: "flowbite-icon", inputs: ["svgIcon"], outputs: ["svgIconChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
57
+ }
58
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: BreadcrumbItemComponent, decorators: [{
59
+ type: Component,
60
+ args: [{
61
+ standalone: true,
62
+ imports: [NgIf, NgClass, NgTemplateOutlet, IconComponent],
63
+ selector: 'flowbite-breadcrumb-item',
64
+ template: `
65
+ <flowbite-icon
66
+ [ngClass]="contentClasses().breadcrumbIconClass"
67
+ svgIcon="flowbite-angular:chevron-right" />
68
+ <ng-content />
69
+ `,
70
+ encapsulation: ViewEncapsulation.None,
71
+ changeDetection: ChangeDetectionStrategy.OnPush,
72
+ }]
73
+ }] });
74
+
75
+ const FLOWBITE_BREADCRUMB_THEME_TOKEN = new InjectionToken('FLOWBITE_BREADCRUMB_THEME_TOKEN');
76
+ class BreadcrumbThemeService {
77
+ constructor() {
78
+ this.baseTheme = inject(FLOWBITE_BREADCRUMB_THEME_TOKEN);
79
+ }
80
+ getClasses(properties) {
81
+ const theme = mergeTheme(this.baseTheme, properties.customStyle);
82
+ const output = {
83
+ rootClass: twMerge(theme.root.base),
84
+ };
85
+ return output;
86
+ }
87
+ }
88
+
89
+ /**
90
+ * @see https://flowbite.com/docs/components/breadcrumb/
91
+ */
92
+ class BreadcrumbComponent extends BaseComponent {
93
+ constructor() {
94
+ super(...arguments);
95
+ this.themeService = inject(BreadcrumbThemeService);
96
+ this.breadcrumbItemChildren = contentChildren(BreadcrumbItemComponent);
97
+ //#region properties
98
+ this.color = model('primary');
99
+ this.customStyle = model({});
100
+ }
101
+ //#endregion
102
+ //#region BaseComponent implementation
103
+ fetchClass() {
104
+ return this.themeService.getClasses({
105
+ customStyle: this.customStyle(),
106
+ });
107
+ }
108
+ verify() {
109
+ if (this.breadcrumbItemChildren().length === 0) {
110
+ throw new Error('No BreadcrumbItemComponent available');
111
+ }
112
+ }
113
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: BreadcrumbComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
114
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.0.0", type: BreadcrumbComponent, isStandalone: true, selector: "flowbite-breadcrumb", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { color: "colorChange", customStyle: "customStyleChange" }, host: { properties: { "attr.aria-label": "breadcrumb" } }, queries: [{ propertyName: "breadcrumbItemChildren", predicate: BreadcrumbItemComponent, isSignal: true }], usesInheritance: true, ngImport: i0, template: `<ng-content />`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
115
+ }
116
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: BreadcrumbComponent, decorators: [{
117
+ type: Component,
118
+ args: [{
119
+ standalone: true,
120
+ imports: [NgClass],
121
+ selector: 'flowbite-breadcrumb',
122
+ template: `<ng-content />`,
123
+ host: {
124
+ '[attr.aria-label]': 'breadcrumb',
125
+ },
126
+ encapsulation: ViewEncapsulation.None,
127
+ changeDetection: ChangeDetectionStrategy.OnPush,
128
+ }]
129
+ }] });
130
+
131
+ const breadcrumbTheme = createTheme({
132
+ root: {
133
+ base: 'flex items-center',
134
+ },
135
+ });
136
+
137
+ const breadcrumbItemTheme = createTheme({
138
+ root: {
139
+ base: 'group flex items-center text-sm font-medium cursor-pointer',
140
+ color: {
141
+ primary: 'text-primary-700 dark:text-primary-400 hover:text-primary-900 dark:hover:text-primary-500',
142
+ dark: 'text-gray-700 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white',
143
+ blue: 'text-blue-700 dark:text-blue-400 hover:text-blue-900 dark:hover:text-blue-500',
144
+ red: 'text-red-700 dark:text-red-400 hover:text-red-900 dark:hover:text-red-500',
145
+ green: 'text-green-700 dark:text-green-400 hover:text-green-900 dark:hover:text-green-500',
146
+ yellow: 'text-yellow-700 dark:text-yellow-400 hover:text-yellow-900 dark:hover:text-yellow-500',
147
+ },
148
+ },
149
+ icon: {
150
+ base: 'mx-1 h-6 w-6 md:mx-2 group-first:hidden',
151
+ },
152
+ });
153
+
154
+ /**
155
+ * Generated bundle index. Do not edit.
156
+ */
157
+
158
+ export { BreadcrumbComponent, BreadcrumbItemComponent, BreadcrumbItemThemeService, BreadcrumbThemeService, FLOWBITE_BREADCRUMB_ITEM_THEME_TOKEN, FLOWBITE_BREADCRUMB_THEME_TOKEN, breadcrumbItemTheme, breadcrumbTheme };
159
+ //# sourceMappingURL=flowbite-angular-breadcrumb.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flowbite-angular-breadcrumb.mjs","sources":["../../../../libs/flowbite-angular/breadcrumb/breadcrumb-item.theme.service.ts","../../../../libs/flowbite-angular/breadcrumb/breadcrumb-item.component.ts","../../../../libs/flowbite-angular/breadcrumb/breadcrumb.theme.service.ts","../../../../libs/flowbite-angular/breadcrumb/breadcrumb.component.ts","../../../../libs/flowbite-angular/breadcrumb/breadcrumb.theme.ts","../../../../libs/flowbite-angular/breadcrumb/breadcrumb-item.theme.ts","../../../../libs/flowbite-angular/breadcrumb/flowbite-angular-breadcrumb.ts"],"sourcesContent":["import type {\n BreadcrumbItemClass,\n BreadcrumbItemProperties,\n BreadcrumbItemTheme,\n} from './breadcrumb-item.theme';\n\nimport type { FlowbiteThemeService } from 'flowbite-angular';\nimport { mergeTheme } from 'flowbite-angular/utils';\n\nimport { inject, InjectionToken } from '@angular/core';\nimport { twMerge } from 'tailwind-merge';\n\nexport const FLOWBITE_BREADCRUMB_ITEM_THEME_TOKEN = new InjectionToken<BreadcrumbItemTheme>(\n 'FLOWBITE_BREADCRUMB_ITEM_THEME_TOKEN'\n);\n\nexport class BreadcrumbItemThemeService implements FlowbiteThemeService<BreadcrumbItemProperties> {\n private readonly baseTheme = inject(FLOWBITE_BREADCRUMB_ITEM_THEME_TOKEN);\n\n public getClasses(properties: BreadcrumbItemProperties): BreadcrumbItemClass {\n const theme: BreadcrumbItemTheme = mergeTheme(this.baseTheme, properties.customStyle);\n\n const output: BreadcrumbItemClass = {\n rootClass: twMerge(theme.root.base, theme.root.color[properties.color]),\n breadcrumbIconClass: twMerge(theme.icon.base),\n };\n\n return output;\n }\n}\n","import type { BreadcrumbItemClass, BreadcrumbItemTheme } from './breadcrumb-item.theme';\nimport { BreadcrumbItemThemeService } from './breadcrumb-item.theme.service';\nimport { BreadcrumbComponent } from './breadcrumb.component';\nimport type { BreadcrumbColors } from './breadcrumb.theme';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent } from 'flowbite-angular';\nimport { IconComponent, IconRegistry } from 'flowbite-angular/icon';\nimport { FlowbiteRouterLinkDirective } from 'flowbite-angular/router-link';\nimport { CHEVRON_RIGHT_SVG_ICON } from 'flowbite-angular/utils';\n\nimport { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport type { OnInit } from '@angular/core';\nimport {\n ChangeDetectionStrategy,\n Component,\n inject,\n model,\n ViewEncapsulation,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\n@Component({\n standalone: true,\n imports: [NgIf, NgClass, NgTemplateOutlet, IconComponent],\n selector: 'flowbite-breadcrumb-item',\n template: `\n <flowbite-icon\n [ngClass]=\"contentClasses().breadcrumbIconClass\"\n svgIcon=\"flowbite-angular:chevron-right\" />\n <ng-content />\n `,\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BreadcrumbItemComponent extends BaseComponent<BreadcrumbItemClass> implements OnInit {\n public readonly themeService = inject(BreadcrumbItemThemeService);\n public readonly breadcrumbComponent = inject(BreadcrumbComponent);\n public readonly flowbiteRouterLink = inject(FlowbiteRouterLinkDirective, { optional: true });\n public readonly iconRegistry = inject(IconRegistry);\n public readonly domSanitizer = inject(DomSanitizer);\n\n //#region properties\n public color = model<keyof BreadcrumbColors>(this.breadcrumbComponent.color());\n public customStyle = model<DeepPartial<BreadcrumbItemTheme>>({});\n //#endregion\n\n //#region BaseComponent implementation\n public override fetchClass(): BreadcrumbItemClass {\n return this.themeService.getClasses({\n color: this.color(),\n link: this.flowbiteRouterLink?.routerLink.urlTree ?? null,\n customStyle: this.customStyle(),\n });\n }\n\n public override init(): void {\n this.iconRegistry.addRawSvgIconInNamepsace(\n 'flowbite-angular',\n 'chevron-right',\n this.domSanitizer.bypassSecurityTrustHtml(CHEVRON_RIGHT_SVG_ICON)\n );\n }\n //#endregion\n}\n","import type { BreadcrumbClass, BreadcrumbProperties, BreadcrumbTheme } from './breadcrumb.theme';\n\nimport type { FlowbiteThemeService } from 'flowbite-angular';\nimport { mergeTheme } from 'flowbite-angular/utils';\n\nimport { inject, InjectionToken } from '@angular/core';\nimport { twMerge } from 'tailwind-merge';\n\nexport const FLOWBITE_BREADCRUMB_THEME_TOKEN = new InjectionToken<BreadcrumbTheme>(\n 'FLOWBITE_BREADCRUMB_THEME_TOKEN'\n);\n\nexport class BreadcrumbThemeService implements FlowbiteThemeService<BreadcrumbProperties> {\n private readonly baseTheme = inject(FLOWBITE_BREADCRUMB_THEME_TOKEN);\n\n public getClasses(properties: BreadcrumbProperties): BreadcrumbClass {\n const theme: BreadcrumbTheme = mergeTheme(this.baseTheme, properties.customStyle);\n\n const output: BreadcrumbClass = {\n rootClass: twMerge(theme.root.base),\n };\n\n return output;\n }\n}\n","import { BreadcrumbItemComponent } from './breadcrumb-item.component';\nimport type { BreadcrumbClass, BreadcrumbColors, BreadcrumbTheme } from './breadcrumb.theme';\nimport { BreadcrumbThemeService } from './breadcrumb.theme.service';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent } from 'flowbite-angular';\n\nimport { NgClass } from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n contentChildren,\n inject,\n model,\n ViewEncapsulation,\n} from '@angular/core';\n\n/**\n * @see https://flowbite.com/docs/components/breadcrumb/\n */\n@Component({\n standalone: true,\n imports: [NgClass],\n selector: 'flowbite-breadcrumb',\n template: `<ng-content />`,\n host: {\n '[attr.aria-label]': 'breadcrumb',\n },\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BreadcrumbComponent extends BaseComponent<BreadcrumbClass> {\n public readonly themeService = inject(BreadcrumbThemeService);\n public readonly breadcrumbItemChildren = contentChildren(BreadcrumbItemComponent);\n\n //#region properties\n public color = model<keyof BreadcrumbColors>('primary');\n public customStyle = model<DeepPartial<BreadcrumbTheme>>({});\n //#endregion\n\n //#region BaseComponent implementation\n public override fetchClass(): BreadcrumbClass {\n return this.themeService.getClasses({\n customStyle: this.customStyle(),\n });\n }\n\n public override verify(): void {\n if (this.breadcrumbItemChildren().length === 0) {\n throw new Error('No BreadcrumbItemComponent available');\n }\n }\n //#endregion\n}\n","import type { DeepPartial, FlowbiteClass, FlowbiteColors } from 'flowbite-angular';\nimport { createTheme } from 'flowbite-angular/utils';\n\nexport interface BreadcrumbColors\n extends Pick<FlowbiteColors, 'primary' | 'dark' | 'blue' | 'red' | 'green' | 'yellow'> {\n [key: string]: string;\n}\n\nexport interface BreadcrumbProperties {\n customStyle: DeepPartial<BreadcrumbTheme>;\n}\n\nexport interface BreadcrumbTheme {\n root: {\n base: string;\n };\n}\n\nexport const breadcrumbTheme: BreadcrumbTheme = createTheme({\n root: {\n base: 'flex items-center',\n },\n});\n\nexport type BreadcrumbClass = FlowbiteClass;\n","import type { BreadcrumbColors } from './breadcrumb.theme';\n\nimport type { DeepPartial, FlowbiteClass } from 'flowbite-angular';\nimport { createTheme } from 'flowbite-angular/utils';\n\nimport type { UrlTree } from '@angular/router';\n\nexport interface BreadcrumbItemProperties {\n color: keyof BreadcrumbColors;\n link: UrlTree | null;\n customStyle: DeepPartial<BreadcrumbItemTheme>;\n}\n\nexport interface BreadcrumbItemTheme {\n root: {\n base: string;\n color: BreadcrumbColors;\n };\n icon: {\n base: string;\n };\n}\n\nexport const breadcrumbItemTheme: BreadcrumbItemTheme = createTheme({\n root: {\n base: 'group flex items-center text-sm font-medium cursor-pointer',\n color: {\n primary:\n 'text-primary-700 dark:text-primary-400 hover:text-primary-900 dark:hover:text-primary-500',\n dark: 'text-gray-700 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white',\n blue: 'text-blue-700 dark:text-blue-400 hover:text-blue-900 dark:hover:text-blue-500',\n red: 'text-red-700 dark:text-red-400 hover:text-red-900 dark:hover:text-red-500',\n green: 'text-green-700 dark:text-green-400 hover:text-green-900 dark:hover:text-green-500',\n yellow:\n 'text-yellow-700 dark:text-yellow-400 hover:text-yellow-900 dark:hover:text-yellow-500',\n },\n },\n icon: {\n base: 'mx-1 h-6 w-6 md:mx-2 group-first:hidden',\n },\n});\n\nexport interface BreadcrumbItemClass extends FlowbiteClass {\n breadcrumbIconClass: string;\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}