flowbite-angular 1.0.0-alpha.2 → 1.0.0-alpha.4

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