@taiga-ui/core 4.66.0 → 5.0.0-canary.8b64ec1

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 (654) hide show
  1. package/README.md +1 -1
  2. package/classes/accessors.d.ts +2 -2
  3. package/classes/driver.d.ts +1 -1
  4. package/components/button/button.directive.d.ts +2 -3
  5. package/components/button/button.options.d.ts +1 -1
  6. package/components/calendar/calendar-sheet.component.d.ts +2 -7
  7. package/components/calendar/calendar-sheet.options.d.ts +1 -3
  8. package/{pipes/calendar-sheet → components/calendar}/calendar-sheet.pipe.d.ts +2 -2
  9. package/components/calendar/calendar-spin.component.d.ts +1 -0
  10. package/components/calendar/calendar-year.component.d.ts +1 -1
  11. package/components/calendar/calendar.options.d.ts +9 -0
  12. package/components/calendar/index.d.ts +3 -0
  13. package/{pipes/order-week-days → components/calendar}/order-week-days.pipe.d.ts +1 -1
  14. package/components/cell/cell.directive.d.ts +9 -0
  15. package/components/cell/cell.options.d.ts +6 -0
  16. package/components/cell/index.d.ts +2 -0
  17. package/components/data-list/data-list.component.d.ts +8 -12
  18. package/components/data-list/data-list.d.ts +3 -4
  19. package/components/data-list/data-list.tokens.d.ts +1 -20
  20. package/components/data-list/index.d.ts +3 -4
  21. package/components/data-list/opt-group.directive.d.ts +2 -2
  22. package/components/data-list/option-content.directive.d.ts +14 -0
  23. package/components/data-list/option-with-value.directive.d.ts +9 -0
  24. package/components/data-list/option.directive.d.ts +19 -0
  25. package/components/error/error.component.d.ts +6 -8
  26. package/components/error/error.d.ts +4 -0
  27. package/components/error/error.directive.d.ts +19 -0
  28. package/components/error/error.pipe.d.ts +10 -0
  29. package/components/error/index.d.ts +3 -0
  30. package/components/expand/expand.component.d.ts +9 -28
  31. package/components/expand/index.d.ts +0 -2
  32. package/components/icon/icon.component.d.ts +6 -11
  33. package/components/index.d.ts +3 -3
  34. package/components/input/index.d.ts +2 -0
  35. package/components/input/input.d.ts +5 -0
  36. package/components/input/input.directive.d.ts +29 -0
  37. package/components/label/label.directive.d.ts +1 -1
  38. package/components/link/index.d.ts +0 -1
  39. package/components/link/link.directive.d.ts +8 -6
  40. package/components/loader/loader.component.d.ts +7 -7
  41. package/components/loader/loader.options.d.ts +1 -3
  42. package/components/notification/index.d.ts +3 -0
  43. package/components/notification/notification.component.d.ts +14 -0
  44. package/components/notification/notification.d.ts +3 -0
  45. package/components/notification/notification.directive.d.ts +7 -12
  46. package/components/notification/notification.options.d.ts +10 -7
  47. package/components/notification/notification.service.d.ts +17 -0
  48. package/components/root/root.component.d.ts +4 -7
  49. package/components/scrollbar/scroll-into-view.directive.d.ts +3 -2
  50. package/components/scrollbar/scroll-ref.directive.d.ts +2 -0
  51. package/components/scrollbar/scrollbar.component.d.ts +1 -5
  52. package/components/scrollbar/scrollbar.directive.d.ts +2 -2
  53. package/components/scrollbar/scrollbar.options.d.ts +1 -1
  54. package/components/spin-button/spin-button.component.d.ts +9 -10
  55. package/components/textfield/index.d.ts +1 -4
  56. package/components/textfield/textfield-content.directive.d.ts +3 -2
  57. package/components/textfield/textfield-icon.d.ts +3 -3
  58. package/components/textfield/textfield-multi/textfield-item.component.d.ts +3 -2
  59. package/components/textfield/textfield-multi/textfield-multi.component.d.ts +9 -15
  60. package/components/textfield/textfield.component.d.ts +20 -35
  61. package/components/textfield/textfield.d.ts +2 -4
  62. package/components/textfield/textfield.options.d.ts +8 -11
  63. package/{directives → components}/title/title.directive.d.ts +2 -3
  64. package/directives/appearance/appearance.directive.d.ts +5 -13
  65. package/directives/appearance/appearance.options.d.ts +1 -2
  66. package/directives/button-x/button-x.directive.d.ts +6 -0
  67. package/directives/button-x/index.d.ts +1 -0
  68. package/directives/date-format/date-format.directive.d.ts +3 -7
  69. package/directives/group/group.directive.d.ts +7 -7
  70. package/directives/group/group.options.d.ts +1 -3
  71. package/directives/icons/icons.bindings.d.ts +5 -0
  72. package/directives/icons/icons.directive.d.ts +8 -16
  73. package/directives/icons/index.d.ts +1 -0
  74. package/directives/index.d.ts +1 -5
  75. package/directives/items-handlers/items-handlers.directive.d.ts +5 -9
  76. package/directives/items-handlers/items-handlers.tokens.d.ts +4 -4
  77. package/directives/number-format/number-format.directive.d.ts +3 -7
  78. package/fesm2022/taiga-ui-core-classes.mjs +9 -11
  79. package/fesm2022/taiga-ui-core-classes.mjs.map +1 -1
  80. package/fesm2022/taiga-ui-core-components-button.mjs +13 -21
  81. package/fesm2022/taiga-ui-core-components-button.mjs.map +1 -1
  82. package/fesm2022/taiga-ui-core-components-calendar.mjs +144 -47
  83. package/fesm2022/taiga-ui-core-components-calendar.mjs.map +1 -1
  84. package/fesm2022/taiga-ui-core-components-cell.mjs +45 -0
  85. package/fesm2022/taiga-ui-core-components-cell.mjs.map +1 -0
  86. package/fesm2022/taiga-ui-core-components-data-list.mjs +113 -284
  87. package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
  88. package/fesm2022/taiga-ui-core-components-error.mjs +110 -26
  89. package/fesm2022/taiga-ui-core-components-error.mjs.map +1 -1
  90. package/fesm2022/taiga-ui-core-components-expand.mjs +34 -132
  91. package/fesm2022/taiga-ui-core-components-expand.mjs.map +1 -1
  92. package/fesm2022/taiga-ui-core-components-icon.mjs +22 -40
  93. package/fesm2022/taiga-ui-core-components-icon.mjs.map +1 -1
  94. package/fesm2022/taiga-ui-core-components-input.mjs +100 -0
  95. package/fesm2022/taiga-ui-core-components-input.mjs.map +1 -0
  96. package/fesm2022/taiga-ui-core-components-label.mjs +13 -18
  97. package/fesm2022/taiga-ui-core-components-label.mjs.map +1 -1
  98. package/fesm2022/taiga-ui-core-components-link.mjs +16 -36
  99. package/fesm2022/taiga-ui-core-components-link.mjs.map +1 -1
  100. package/fesm2022/taiga-ui-core-components-loader.mjs +20 -40
  101. package/fesm2022/taiga-ui-core-components-loader.mjs.map +1 -1
  102. package/fesm2022/taiga-ui-core-components-notification.mjs +107 -66
  103. package/fesm2022/taiga-ui-core-components-notification.mjs.map +1 -1
  104. package/fesm2022/taiga-ui-core-components-root.mjs +23 -60
  105. package/fesm2022/taiga-ui-core-components-root.mjs.map +1 -1
  106. package/fesm2022/taiga-ui-core-components-scrollbar.mjs +73 -87
  107. package/fesm2022/taiga-ui-core-components-scrollbar.mjs.map +1 -1
  108. package/fesm2022/taiga-ui-core-components-spin-button.mjs +18 -31
  109. package/fesm2022/taiga-ui-core-components-spin-button.mjs.map +1 -1
  110. package/fesm2022/taiga-ui-core-components-textfield.mjs +136 -435
  111. package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
  112. package/fesm2022/taiga-ui-core-components-title.mjs +37 -0
  113. package/fesm2022/taiga-ui-core-components-title.mjs.map +1 -0
  114. package/fesm2022/taiga-ui-core-components.mjs +3 -3
  115. package/fesm2022/taiga-ui-core-directives-appearance.mjs +32 -69
  116. package/fesm2022/taiga-ui-core-directives-appearance.mjs.map +1 -1
  117. package/fesm2022/taiga-ui-core-directives-button-x.mjs +51 -0
  118. package/fesm2022/taiga-ui-core-directives-button-x.mjs.map +1 -0
  119. package/fesm2022/taiga-ui-core-directives-date-format.mjs +26 -20
  120. package/fesm2022/taiga-ui-core-directives-date-format.mjs.map +1 -1
  121. package/fesm2022/taiga-ui-core-directives-group.mjs +25 -40
  122. package/fesm2022/taiga-ui-core-directives-group.mjs.map +1 -1
  123. package/fesm2022/taiga-ui-core-directives-icons.mjs +35 -45
  124. package/fesm2022/taiga-ui-core-directives-icons.mjs.map +1 -1
  125. package/fesm2022/taiga-ui-core-directives-items-handlers.mjs +18 -42
  126. package/fesm2022/taiga-ui-core-directives-items-handlers.mjs.map +1 -1
  127. package/fesm2022/taiga-ui-core-directives-number-format.mjs +32 -20
  128. package/fesm2022/taiga-ui-core-directives-number-format.mjs.map +1 -1
  129. package/fesm2022/taiga-ui-core-directives.mjs +1 -5
  130. package/fesm2022/taiga-ui-core-directives.mjs.map +1 -1
  131. package/fesm2022/taiga-ui-core-pipes-format-number.mjs +21 -15
  132. package/fesm2022/taiga-ui-core-pipes-format-number.mjs.map +1 -1
  133. package/fesm2022/taiga-ui-core-pipes.mjs +0 -8
  134. package/fesm2022/taiga-ui-core-pipes.mjs.map +1 -1
  135. package/fesm2022/taiga-ui-core-portals-alert.mjs +73 -0
  136. package/fesm2022/taiga-ui-core-portals-alert.mjs.map +1 -0
  137. package/fesm2022/taiga-ui-core-portals-dialog.mjs +159 -0
  138. package/fesm2022/taiga-ui-core-portals-dialog.mjs.map +1 -0
  139. package/fesm2022/{taiga-ui-core-directives-dropdown.mjs → taiga-ui-core-portals-dropdown.mjs} +249 -414
  140. package/fesm2022/taiga-ui-core-portals-dropdown.mjs.map +1 -0
  141. package/fesm2022/taiga-ui-core-portals-hint.mjs +552 -0
  142. package/fesm2022/taiga-ui-core-portals-hint.mjs.map +1 -0
  143. package/fesm2022/taiga-ui-core-portals-modal.mjs +89 -0
  144. package/fesm2022/taiga-ui-core-portals-modal.mjs.map +1 -0
  145. package/fesm2022/taiga-ui-core-portals-popup.mjs +56 -0
  146. package/fesm2022/taiga-ui-core-portals-popup.mjs.map +1 -0
  147. package/fesm2022/taiga-ui-core-portals.mjs +11 -0
  148. package/fesm2022/taiga-ui-core-portals.mjs.map +1 -0
  149. package/fesm2022/taiga-ui-core-services.mjs +17 -81
  150. package/fesm2022/taiga-ui-core-services.mjs.map +1 -1
  151. package/fesm2022/taiga-ui-core-tokens.mjs +62 -81
  152. package/fesm2022/taiga-ui-core-tokens.mjs.map +1 -1
  153. package/fesm2022/taiga-ui-core-utils-dom.mjs.map +1 -1
  154. package/fesm2022/taiga-ui-core-utils-format.mjs +1 -22
  155. package/fesm2022/taiga-ui-core-utils-format.mjs.map +1 -1
  156. package/fesm2022/taiga-ui-core-utils-miscellaneous.mjs +55 -19
  157. package/fesm2022/taiga-ui-core-utils-miscellaneous.mjs.map +1 -1
  158. package/fesm2022/taiga-ui-core.mjs +1 -1
  159. package/index.d.ts +1 -1
  160. package/package.json +61 -182
  161. package/pipes/format-number/format-number.pipe.d.ts +6 -4
  162. package/pipes/index.d.ts +0 -8
  163. package/portals/alert/alert.directive.d.ts +11 -0
  164. package/portals/alert/alert.service.d.ts +12 -0
  165. package/portals/alert/index.d.ts +2 -0
  166. package/portals/dialog/dialog.component.d.ts +14 -0
  167. package/portals/dialog/dialog.directive.d.ts +8 -0
  168. package/{components → portals}/dialog/dialog.factory.d.ts +1 -1
  169. package/portals/dialog/dialog.options.d.ts +25 -0
  170. package/{components/dialog/dialog-close.service.d.ts → portals/dialog/dialog.providers.d.ts} +2 -0
  171. package/portals/dialog/dialog.service.d.ts +10 -0
  172. package/portals/dialog/index.d.ts +6 -0
  173. package/portals/dropdown/dropdown-close.directive.d.ts +15 -0
  174. package/portals/dropdown/dropdown-content.directive.d.ts +9 -0
  175. package/{directives → portals}/dropdown/dropdown-context.directive.d.ts +0 -1
  176. package/{directives → portals}/dropdown/dropdown-hover.directive.d.ts +5 -10
  177. package/{directives → portals}/dropdown/dropdown-hover.options.d.ts +1 -3
  178. package/{directives → portals}/dropdown/dropdown-manual.directive.d.ts +2 -2
  179. package/portals/dropdown/dropdown-open.directive.d.ts +29 -0
  180. package/{directives → portals}/dropdown/dropdown-options.directive.d.ts +1 -5
  181. package/{directives → portals}/dropdown/dropdown-position-sided.directive.d.ts +3 -3
  182. package/{directives → portals}/dropdown/dropdown-position.directive.d.ts +6 -6
  183. package/{directives → portals}/dropdown/dropdown-selection.directive.d.ts +4 -5
  184. package/{directives → portals}/dropdown/dropdown.bindings.d.ts +0 -1
  185. package/{directives → portals}/dropdown/dropdown.d.ts +2 -3
  186. package/{directives → portals}/dropdown/dropdown.directive.d.ts +6 -8
  187. package/{directives → portals}/dropdown/index.d.ts +2 -4
  188. package/{directives → portals}/hint/hint-describe.directive.d.ts +4 -6
  189. package/{directives → portals}/hint/hint-host.directive.d.ts +2 -2
  190. package/{directives → portals}/hint/hint-hover.directive.d.ts +3 -4
  191. package/{directives → portals}/hint/hint-manual.directive.d.ts +2 -2
  192. package/portals/hint/hint-options.directive.d.ts +17 -0
  193. package/{directives → portals}/hint/hint-overflow.directive.d.ts +2 -2
  194. package/{directives → portals}/hint/hint-position.directive.d.ts +7 -8
  195. package/{directives → portals}/hint/hint-unstyled.component.d.ts +2 -7
  196. package/portals/hint/hint.component.d.ts +29 -0
  197. package/{directives → portals}/hint/hint.d.ts +1 -2
  198. package/portals/hint/hint.directive.d.ts +24 -0
  199. package/{directives → portals}/hint/index.d.ts +0 -2
  200. package/portals/index.d.ts +6 -0
  201. package/portals/modal/index.d.ts +2 -0
  202. package/portals/modal/modal.component.d.ts +17 -0
  203. package/portals/modal/modal.service.d.ts +13 -0
  204. package/portals/popup/popup.directive.d.ts +12 -0
  205. package/{directives → portals}/popup/popup.service.d.ts +1 -1
  206. package/{directives → portals}/popup/popups.component.d.ts +2 -2
  207. package/services/index.d.ts +0 -3
  208. package/styles/components/appearance.less +5 -0
  209. package/styles/components/button.less +10 -22
  210. package/styles/components/icon.less +42 -21
  211. package/styles/components/icons.less +18 -13
  212. package/styles/components/label.less +3 -12
  213. package/styles/components/link.less +8 -27
  214. package/styles/components/notification.less +31 -65
  215. package/styles/components/textfield.less +128 -213
  216. package/styles/components/title.less +8 -8
  217. package/styles/mixins/appearance.less +11 -26
  218. package/styles/mixins/appearance.scss +9 -24
  219. package/styles/mixins/date-picker.less +1 -1
  220. package/styles/mixins/mixins.less +1 -7
  221. package/styles/mixins/mixins.scss +1 -7
  222. package/styles/mixins/picker.less +1 -1
  223. package/styles/mixins/picker.scss +1 -1
  224. package/styles/mixins/slider.less +28 -24
  225. package/styles/mixins/slider.scss +23 -22
  226. package/styles/taiga-ui-local.less +0 -1
  227. package/styles/taiga-ui-local.scss +0 -1
  228. package/styles/taiga-ui-theme.less +0 -1
  229. package/styles/theme/appearance/outline.less +9 -18
  230. package/styles/theme/appearance/primary.less +2 -4
  231. package/styles/theme/appearance/secondary.less +6 -14
  232. package/styles/theme/appearance/status.less +0 -4
  233. package/styles/theme/appearance/table.less +36 -35
  234. package/styles/theme/appearance/textfield.less +27 -28
  235. package/styles/theme/appearance.less +0 -1
  236. package/styles/theme/variables.less +16 -19
  237. package/styles/variables/media.less +13 -18
  238. package/styles/variables/media.scss +13 -13
  239. package/tokens/breakpoint.d.ts +4 -0
  240. package/tokens/common-icons.d.ts +3 -3
  241. package/tokens/date-format.d.ts +2 -3
  242. package/tokens/i18n.d.ts +7 -7
  243. package/tokens/icon-resolver.d.ts +1 -5
  244. package/tokens/icons.d.ts +0 -4
  245. package/tokens/index.d.ts +2 -4
  246. package/tokens/number-format.d.ts +2 -3
  247. package/tokens/validation-errors.d.ts +4 -0
  248. package/types/direction.d.ts +1 -1
  249. package/types/index.d.ts +0 -3
  250. package/types/point.d.ts +1 -1
  251. package/types/size.d.ts +0 -11
  252. package/utils/format/index.d.ts +0 -1
  253. package/utils/miscellaneous/get-duration.d.ts +2 -0
  254. package/utils/miscellaneous/index.d.ts +2 -1
  255. package/utils/miscellaneous/provide-taiga.d.ts +13 -0
  256. package/animations/animations.d.ts +0 -109
  257. package/animations/index.d.ts +0 -1
  258. package/components/alert/alert.component.d.ts +0 -15
  259. package/components/alert/alert.directive.d.ts +0 -7
  260. package/components/alert/alert.interfaces.d.ts +0 -12
  261. package/components/alert/alert.service.d.ts +0 -7
  262. package/components/alert/alert.tokens.d.ts +0 -12
  263. package/components/alert/alerts.component.d.ts +0 -12
  264. package/components/alert/index.d.ts +0 -6
  265. package/components/data-list/data-list.directive.d.ts +0 -7
  266. package/components/data-list/option/option-content.d.ts +0 -16
  267. package/components/data-list/option/option-legacy.component.d.ts +0 -24
  268. package/components/data-list/option/option.directive.d.ts +0 -27
  269. package/components/dialog/active-zone-adapter.directive.d.ts +0 -11
  270. package/components/dialog/dialog.component.d.ts +0 -20
  271. package/components/dialog/dialog.directive.d.ts +0 -7
  272. package/components/dialog/dialog.interfaces.d.ts +0 -34
  273. package/components/dialog/dialog.service.d.ts +0 -7
  274. package/components/dialog/dialog.tokens.d.ts +0 -15
  275. package/components/dialog/dialogs.component.d.ts +0 -8
  276. package/components/dialog/index.d.ts +0 -8
  277. package/components/expand/expand-content.directive.d.ts +0 -8
  278. package/components/expand/expand.d.ts +0 -6
  279. package/components/fullscreen/fullscreen.component.d.ts +0 -14
  280. package/components/fullscreen/index.d.ts +0 -1
  281. package/components/link/link.options.d.ts +0 -12
  282. package/components/textfield/select.directive.d.ts +0 -19
  283. package/components/textfield/textfield-dropdown.directive.d.ts +0 -16
  284. package/components/textfield/textfield.directive.d.ts +0 -38
  285. package/directives/dropdown/dropdown-open-legacy.directive.d.ts +0 -12
  286. package/directives/dropdown/dropdown-open.directive.d.ts +0 -33
  287. package/directives/dropdown/dropdown-portal.directive.d.ts +0 -14
  288. package/directives/dropdown/dropdown.service.d.ts +0 -6
  289. package/directives/dropdown/dropdowns.component.d.ts +0 -9
  290. package/directives/hint/hint-options.directive.d.ts +0 -36
  291. package/directives/hint/hint.component.d.ts +0 -30
  292. package/directives/hint/hint.directive.d.ts +0 -26
  293. package/directives/hint/hint.service.d.ts +0 -13
  294. package/directives/hint/hints.component.d.ts +0 -12
  295. package/directives/popup/popup.directive.d.ts +0 -11
  296. package/directives/surface/index.d.ts +0 -1
  297. package/directives/surface/surface.directive.d.ts +0 -8
  298. package/esm2022/animations/animations.mjs +0 -363
  299. package/esm2022/animations/index.mjs +0 -2
  300. package/esm2022/animations/taiga-ui-core-animations.mjs +0 -5
  301. package/esm2022/classes/accessors.mjs +0 -31
  302. package/esm2022/classes/driver.mjs +0 -36
  303. package/esm2022/classes/index.mjs +0 -4
  304. package/esm2022/classes/taiga-ui-core-classes.mjs +0 -5
  305. package/esm2022/classes/vehicle.mjs +0 -7
  306. package/esm2022/components/alert/alert.component.mjs +0 -43
  307. package/esm2022/components/alert/alert.directive.mjs +0 -21
  308. package/esm2022/components/alert/alert.interfaces.mjs +0 -2
  309. package/esm2022/components/alert/alert.service.mjs +0 -18
  310. package/esm2022/components/alert/alert.tokens.mjs +0 -51
  311. package/esm2022/components/alert/alerts.component.mjs +0 -33
  312. package/esm2022/components/alert/index.mjs +0 -6
  313. package/esm2022/components/alert/taiga-ui-core-components-alert.mjs +0 -5
  314. package/esm2022/components/button/button.directive.mjs +0 -43
  315. package/esm2022/components/button/button.options.mjs +0 -7
  316. package/esm2022/components/button/index.mjs +0 -3
  317. package/esm2022/components/button/taiga-ui-core-components-button.mjs +0 -5
  318. package/esm2022/components/calendar/calendar-sheet.component.mjs +0 -168
  319. package/esm2022/components/calendar/calendar-sheet.options.mjs +0 -12
  320. package/esm2022/components/calendar/calendar-spin.component.mjs +0 -53
  321. package/esm2022/components/calendar/calendar-year.component.mjs +0 -128
  322. package/esm2022/components/calendar/calendar.component.mjs +0 -147
  323. package/esm2022/components/calendar/index.mjs +0 -6
  324. package/esm2022/components/calendar/taiga-ui-core-components-calendar.mjs +0 -5
  325. package/esm2022/components/data-list/data-list.component.mjs +0 -139
  326. package/esm2022/components/data-list/data-list.directive.mjs +0 -19
  327. package/esm2022/components/data-list/data-list.mjs +0 -14
  328. package/esm2022/components/data-list/data-list.tokens.mjs +0 -18
  329. package/esm2022/components/data-list/index.mjs +0 -9
  330. package/esm2022/components/data-list/opt-group.directive.mjs +0 -21
  331. package/esm2022/components/data-list/option/option-content.mjs +0 -36
  332. package/esm2022/components/data-list/option/option-legacy.component.mjs +0 -90
  333. package/esm2022/components/data-list/option/option.directive.mjs +0 -109
  334. package/esm2022/components/data-list/taiga-ui-core-components-data-list.mjs +0 -5
  335. package/esm2022/components/dialog/active-zone-adapter.directive.mjs +0 -37
  336. package/esm2022/components/dialog/dialog-close.service.mjs +0 -41
  337. package/esm2022/components/dialog/dialog.component.mjs +0 -63
  338. package/esm2022/components/dialog/dialog.directive.mjs +0 -21
  339. package/esm2022/components/dialog/dialog.factory.mjs +0 -15
  340. package/esm2022/components/dialog/dialog.interfaces.mjs +0 -2
  341. package/esm2022/components/dialog/dialog.service.mjs +0 -18
  342. package/esm2022/components/dialog/dialog.tokens.mjs +0 -33
  343. package/esm2022/components/dialog/dialogs.component.mjs +0 -31
  344. package/esm2022/components/dialog/index.mjs +0 -8
  345. package/esm2022/components/dialog/taiga-ui-core-components-dialog.mjs +0 -5
  346. package/esm2022/components/error/error.component.mjs +0 -34
  347. package/esm2022/components/error/index.mjs +0 -2
  348. package/esm2022/components/error/taiga-ui-core-components-error.mjs +0 -5
  349. package/esm2022/components/expand/expand-content.directive.mjs +0 -18
  350. package/esm2022/components/expand/expand.component.mjs +0 -124
  351. package/esm2022/components/expand/expand.mjs +0 -7
  352. package/esm2022/components/expand/index.mjs +0 -4
  353. package/esm2022/components/expand/taiga-ui-core-components-expand.mjs +0 -5
  354. package/esm2022/components/fullscreen/fullscreen.component.mjs +0 -71
  355. package/esm2022/components/fullscreen/index.mjs +0 -2
  356. package/esm2022/components/fullscreen/taiga-ui-core-components-fullscreen.mjs +0 -5
  357. package/esm2022/components/icon/icon.component.mjs +0 -44
  358. package/esm2022/components/icon/icon.pipe.mjs +0 -19
  359. package/esm2022/components/icon/index.mjs +0 -3
  360. package/esm2022/components/icon/taiga-ui-core-components-icon.mjs +0 -5
  361. package/esm2022/components/index.mjs +0 -18
  362. package/esm2022/components/label/index.mjs +0 -2
  363. package/esm2022/components/label/label.directive.mjs +0 -41
  364. package/esm2022/components/label/taiga-ui-core-components-label.mjs +0 -5
  365. package/esm2022/components/link/index.mjs +0 -3
  366. package/esm2022/components/link/link.directive.mjs +0 -47
  367. package/esm2022/components/link/link.options.mjs +0 -13
  368. package/esm2022/components/link/taiga-ui-core-components-link.mjs +0 -5
  369. package/esm2022/components/loader/index.mjs +0 -3
  370. package/esm2022/components/loader/loader.component.mjs +0 -46
  371. package/esm2022/components/loader/loader.options.mjs +0 -18
  372. package/esm2022/components/loader/taiga-ui-core-components-loader.mjs +0 -5
  373. package/esm2022/components/notification/index.mjs +0 -3
  374. package/esm2022/components/notification/notification.directive.mjs +0 -81
  375. package/esm2022/components/notification/notification.options.mjs +0 -23
  376. package/esm2022/components/notification/taiga-ui-core-components-notification.mjs +0 -5
  377. package/esm2022/components/root/index.mjs +0 -2
  378. package/esm2022/components/root/root.component.mjs +0 -87
  379. package/esm2022/components/root/taiga-ui-core-components-root.mjs +0 -5
  380. package/esm2022/components/scrollbar/index.mjs +0 -9
  381. package/esm2022/components/scrollbar/scroll-controls.component.mjs +0 -32
  382. package/esm2022/components/scrollbar/scroll-into-view.directive.mjs +0 -43
  383. package/esm2022/components/scrollbar/scroll-ref.directive.mjs +0 -19
  384. package/esm2022/components/scrollbar/scrollable.directive.mjs +0 -26
  385. package/esm2022/components/scrollbar/scrollbar.component.mjs +0 -72
  386. package/esm2022/components/scrollbar/scrollbar.directive.mjs +0 -93
  387. package/esm2022/components/scrollbar/scrollbar.options.mjs +0 -6
  388. package/esm2022/components/scrollbar/scrollbar.service.mjs +0 -46
  389. package/esm2022/components/scrollbar/taiga-ui-core-components-scrollbar.mjs +0 -5
  390. package/esm2022/components/spin-button/index.mjs +0 -2
  391. package/esm2022/components/spin-button/spin-button.component.mjs +0 -51
  392. package/esm2022/components/spin-button/taiga-ui-core-components-spin-button.mjs +0 -5
  393. package/esm2022/components/taiga-ui-core-components.mjs +0 -5
  394. package/esm2022/components/textfield/index.mjs +0 -16
  395. package/esm2022/components/textfield/select-like.directive.mjs +0 -44
  396. package/esm2022/components/textfield/select.directive.mjs +0 -64
  397. package/esm2022/components/textfield/taiga-ui-core-components-textfield.mjs +0 -5
  398. package/esm2022/components/textfield/textfield-accessor.mjs +0 -7
  399. package/esm2022/components/textfield/textfield-auxiliary.mjs +0 -7
  400. package/esm2022/components/textfield/textfield-content.directive.mjs +0 -22
  401. package/esm2022/components/textfield/textfield-dropdown.directive.mjs +0 -43
  402. package/esm2022/components/textfield/textfield-icon.mjs +0 -10
  403. package/esm2022/components/textfield/textfield-multi/textfield-item.component.mjs +0 -34
  404. package/esm2022/components/textfield/textfield-multi/textfield-multi.component.mjs +0 -137
  405. package/esm2022/components/textfield/textfield.component.mjs +0 -183
  406. package/esm2022/components/textfield/textfield.directive.mjs +0 -134
  407. package/esm2022/components/textfield/textfield.mjs +0 -19
  408. package/esm2022/components/textfield/textfield.options.mjs +0 -63
  409. package/esm2022/components/textfield/with-native-picker.directive.mjs +0 -24
  410. package/esm2022/directives/appearance/appearance.bindings.mjs +0 -15
  411. package/esm2022/directives/appearance/appearance.directive.mjs +0 -79
  412. package/esm2022/directives/appearance/appearance.options.mjs +0 -12
  413. package/esm2022/directives/appearance/index.mjs +0 -5
  414. package/esm2022/directives/appearance/taiga-ui-core-directives-appearance.mjs +0 -5
  415. package/esm2022/directives/appearance/with-appearance.mjs +0 -27
  416. package/esm2022/directives/date-format/date-format.directive.mjs +0 -31
  417. package/esm2022/directives/date-format/index.mjs +0 -2
  418. package/esm2022/directives/date-format/taiga-ui-core-directives-date-format.mjs +0 -5
  419. package/esm2022/directives/dropdown/dropdown-context.directive.mjs +0 -76
  420. package/esm2022/directives/dropdown/dropdown-hover.directive.mjs +0 -70
  421. package/esm2022/directives/dropdown/dropdown-hover.options.mjs +0 -17
  422. package/esm2022/directives/dropdown/dropdown-limit-width.mjs +0 -37
  423. package/esm2022/directives/dropdown/dropdown-manual.directive.mjs +0 -27
  424. package/esm2022/directives/dropdown/dropdown-open-legacy.directive.mjs +0 -33
  425. package/esm2022/directives/dropdown/dropdown-open.directive.mjs +0 -169
  426. package/esm2022/directives/dropdown/dropdown-options.directive.mjs +0 -73
  427. package/esm2022/directives/dropdown/dropdown-portal.directive.mjs +0 -34
  428. package/esm2022/directives/dropdown/dropdown-position-sided.directive.mjs +0 -69
  429. package/esm2022/directives/dropdown/dropdown-position.directive.mjs +0 -88
  430. package/esm2022/directives/dropdown/dropdown-selection.directive.mjs +0 -159
  431. package/esm2022/directives/dropdown/dropdown.bindings.mjs +0 -19
  432. package/esm2022/directives/dropdown/dropdown.component.mjs +0 -92
  433. package/esm2022/directives/dropdown/dropdown.directive.mjs +0 -110
  434. package/esm2022/directives/dropdown/dropdown.driver.mjs +0 -32
  435. package/esm2022/directives/dropdown/dropdown.mjs +0 -29
  436. package/esm2022/directives/dropdown/dropdown.providers.mjs +0 -10
  437. package/esm2022/directives/dropdown/dropdown.service.mjs +0 -15
  438. package/esm2022/directives/dropdown/dropdowns.component.mjs +0 -24
  439. package/esm2022/directives/dropdown/index.mjs +0 -22
  440. package/esm2022/directives/dropdown/taiga-ui-core-directives-dropdown.mjs +0 -5
  441. package/esm2022/directives/dropdown/with-dropdown-open.directive.mjs +0 -23
  442. package/esm2022/directives/group/group.directive.mjs +0 -53
  443. package/esm2022/directives/group/group.options.mjs +0 -15
  444. package/esm2022/directives/group/index.mjs +0 -3
  445. package/esm2022/directives/group/taiga-ui-core-directives-group.mjs +0 -5
  446. package/esm2022/directives/hint/hint-describe.directive.mjs +0 -50
  447. package/esm2022/directives/hint/hint-driver.directive.mjs +0 -19
  448. package/esm2022/directives/hint/hint-host.directive.mjs +0 -27
  449. package/esm2022/directives/hint/hint-hover.directive.mjs +0 -59
  450. package/esm2022/directives/hint/hint-manual.directive.mjs +0 -33
  451. package/esm2022/directives/hint/hint-options.directive.mjs +0 -86
  452. package/esm2022/directives/hint/hint-overflow.directive.mjs +0 -38
  453. package/esm2022/directives/hint/hint-pointer.directive.mjs +0 -33
  454. package/esm2022/directives/hint/hint-position.directive.mjs +0 -115
  455. package/esm2022/directives/hint/hint-unstyled.component.mjs +0 -39
  456. package/esm2022/directives/hint/hint.component.mjs +0 -127
  457. package/esm2022/directives/hint/hint.directive.mjs +0 -99
  458. package/esm2022/directives/hint/hint.mjs +0 -27
  459. package/esm2022/directives/hint/hint.providers.mjs +0 -9
  460. package/esm2022/directives/hint/hint.service.mjs +0 -29
  461. package/esm2022/directives/hint/hints.component.mjs +0 -34
  462. package/esm2022/directives/hint/index.mjs +0 -17
  463. package/esm2022/directives/hint/taiga-ui-core-directives-hint.mjs +0 -5
  464. package/esm2022/directives/icons/icons.directive.mjs +0 -66
  465. package/esm2022/directives/icons/index.mjs +0 -3
  466. package/esm2022/directives/icons/taiga-ui-core-directives-icons.mjs +0 -5
  467. package/esm2022/directives/icons/with-icons.mjs +0 -22
  468. package/esm2022/directives/index.mjs +0 -12
  469. package/esm2022/directives/items-handlers/index.mjs +0 -4
  470. package/esm2022/directives/items-handlers/items-handlers.directive.mjs +0 -63
  471. package/esm2022/directives/items-handlers/items-handlers.tokens.mjs +0 -27
  472. package/esm2022/directives/items-handlers/items-handlers.validator.mjs +0 -32
  473. package/esm2022/directives/items-handlers/taiga-ui-core-directives-items-handlers.mjs +0 -5
  474. package/esm2022/directives/number-format/index.mjs +0 -2
  475. package/esm2022/directives/number-format/number-format.directive.mjs +0 -31
  476. package/esm2022/directives/number-format/taiga-ui-core-directives-number-format.mjs +0 -5
  477. package/esm2022/directives/popup/index.mjs +0 -4
  478. package/esm2022/directives/popup/popup.directive.mjs +0 -31
  479. package/esm2022/directives/popup/popup.service.mjs +0 -15
  480. package/esm2022/directives/popup/popups.component.mjs +0 -20
  481. package/esm2022/directives/popup/taiga-ui-core-directives-popup.mjs +0 -5
  482. package/esm2022/directives/surface/index.mjs +0 -2
  483. package/esm2022/directives/surface/surface.directive.mjs +0 -44
  484. package/esm2022/directives/surface/taiga-ui-core-directives-surface.mjs +0 -5
  485. package/esm2022/directives/taiga-ui-core-directives.mjs +0 -5
  486. package/esm2022/directives/title/index.mjs +0 -2
  487. package/esm2022/directives/title/taiga-ui-core-directives-title.mjs +0 -5
  488. package/esm2022/directives/title/title.directive.mjs +0 -37
  489. package/esm2022/index.mjs +0 -9
  490. package/esm2022/pipes/auto-color/auto-color.pipe.mjs +0 -19
  491. package/esm2022/pipes/auto-color/index.mjs +0 -2
  492. package/esm2022/pipes/auto-color/taiga-ui-core-pipes-auto-color.mjs +0 -5
  493. package/esm2022/pipes/calendar-sheet/calendar-sheet.pipe.mjs +0 -54
  494. package/esm2022/pipes/calendar-sheet/index.mjs +0 -2
  495. package/esm2022/pipes/calendar-sheet/taiga-ui-core-pipes-calendar-sheet.mjs +0 -5
  496. package/esm2022/pipes/calendar-sheet/utils.mjs +0 -36
  497. package/esm2022/pipes/fallback-src/fallback-src.pipe.mjs +0 -23
  498. package/esm2022/pipes/fallback-src/index.mjs +0 -2
  499. package/esm2022/pipes/fallback-src/taiga-ui-core-pipes-fallback-src.mjs +0 -5
  500. package/esm2022/pipes/flag/flag.pipe.mjs +0 -26
  501. package/esm2022/pipes/flag/index.mjs +0 -2
  502. package/esm2022/pipes/flag/taiga-ui-core-pipes-flag.mjs +0 -5
  503. package/esm2022/pipes/format-date/format-date.pipe.mjs +0 -22
  504. package/esm2022/pipes/format-date/index.mjs +0 -2
  505. package/esm2022/pipes/format-date/taiga-ui-core-pipes-format-date.mjs +0 -5
  506. package/esm2022/pipes/format-number/format-number.pipe.mjs +0 -36
  507. package/esm2022/pipes/format-number/index.mjs +0 -2
  508. package/esm2022/pipes/format-number/taiga-ui-core-pipes-format-number.mjs +0 -5
  509. package/esm2022/pipes/index.mjs +0 -10
  510. package/esm2022/pipes/initials/index.mjs +0 -2
  511. package/esm2022/pipes/initials/initials.pipe.mjs +0 -23
  512. package/esm2022/pipes/initials/taiga-ui-core-pipes-initials.mjs +0 -5
  513. package/esm2022/pipes/month/index.mjs +0 -2
  514. package/esm2022/pipes/month/month.pipe.mjs +0 -23
  515. package/esm2022/pipes/month/taiga-ui-core-pipes-month.mjs +0 -5
  516. package/esm2022/pipes/order-week-days/index.mjs +0 -2
  517. package/esm2022/pipes/order-week-days/order-week-days.pipe.mjs +0 -30
  518. package/esm2022/pipes/order-week-days/taiga-ui-core-pipes-order-week-days.mjs +0 -5
  519. package/esm2022/pipes/taiga-ui-core-pipes.mjs +0 -5
  520. package/esm2022/services/breakpoint.service.mjs +0 -31
  521. package/esm2022/services/dark-theme.service.mjs +0 -24
  522. package/esm2022/services/format-date.service.mjs +0 -24
  523. package/esm2022/services/index.mjs +0 -6
  524. package/esm2022/services/position.service.mjs +0 -26
  525. package/esm2022/services/taiga-ui-core-services.mjs +0 -5
  526. package/esm2022/services/visual-viewport.service.mjs +0 -29
  527. package/esm2022/taiga-ui-core.mjs +0 -5
  528. package/esm2022/tokens/animations-speed.mjs +0 -9
  529. package/esm2022/tokens/assets-path.mjs +0 -11
  530. package/esm2022/tokens/auxiliary.mjs +0 -9
  531. package/esm2022/tokens/common-icons.mjs +0 -18
  532. package/esm2022/tokens/dark-mode.mjs +0 -43
  533. package/esm2022/tokens/date-format.mjs +0 -20
  534. package/esm2022/tokens/day-type-handler.mjs +0 -8
  535. package/esm2022/tokens/first-day-of-week.mjs +0 -9
  536. package/esm2022/tokens/i18n.mjs +0 -45
  537. package/esm2022/tokens/icon-resolver.mjs +0 -44
  538. package/esm2022/tokens/icon.mjs +0 -8
  539. package/esm2022/tokens/icons.mjs +0 -21
  540. package/esm2022/tokens/index.mjs +0 -21
  541. package/esm2022/tokens/media.mjs +0 -12
  542. package/esm2022/tokens/number-format.mjs +0 -24
  543. package/esm2022/tokens/reduced-motion.mjs +0 -7
  544. package/esm2022/tokens/scroll-ref.mjs +0 -6
  545. package/esm2022/tokens/selection-stream.mjs +0 -14
  546. package/esm2022/tokens/spin-icons.mjs +0 -8
  547. package/esm2022/tokens/taiga-ui-core-tokens.mjs +0 -5
  548. package/esm2022/tokens/theme.mjs +0 -5
  549. package/esm2022/tokens/viewport.mjs +0 -35
  550. package/esm2022/types/direction.mjs +0 -2
  551. package/esm2022/types/index.mjs +0 -2
  552. package/esm2022/types/interactive-state.mjs +0 -2
  553. package/esm2022/types/orientation.mjs +0 -2
  554. package/esm2022/types/point.mjs +0 -2
  555. package/esm2022/types/portal-item.mjs +0 -2
  556. package/esm2022/types/range-state.mjs +0 -2
  557. package/esm2022/types/size.mjs +0 -13
  558. package/esm2022/types/taiga-ui-core-types.mjs +0 -5
  559. package/esm2022/types/value-content-context.mjs +0 -2
  560. package/esm2022/utils/dom/check-fixed-position.mjs +0 -9
  561. package/esm2022/utils/dom/get-viewport.mjs +0 -24
  562. package/esm2022/utils/dom/get-word-range.mjs +0 -51
  563. package/esm2022/utils/dom/index.mjs +0 -4
  564. package/esm2022/utils/dom/taiga-ui-core-utils-dom.mjs +0 -5
  565. package/esm2022/utils/format/format-number.mjs +0 -47
  566. package/esm2022/utils/format/get-fractional-part-padded.mjs +0 -16
  567. package/esm2022/utils/format/index.mjs +0 -5
  568. package/esm2022/utils/format/number-to-string-without-exp.mjs +0 -18
  569. package/esm2022/utils/format/string-hash-to-hsl.mjs +0 -21
  570. package/esm2022/utils/format/taiga-ui-core-utils-format.mjs +0 -5
  571. package/esm2022/utils/index.mjs +0 -4
  572. package/esm2022/utils/miscellaneous/font-scaling.mjs +0 -21
  573. package/esm2022/utils/miscellaneous/index.mjs +0 -7
  574. package/esm2022/utils/miscellaneous/is-editing-key.mjs +0 -18
  575. package/esm2022/utils/miscellaneous/is-obscured.mjs +0 -8
  576. package/esm2022/utils/miscellaneous/override-options.mjs +0 -11
  577. package/esm2022/utils/miscellaneous/size-bigger.mjs +0 -19
  578. package/esm2022/utils/miscellaneous/taiga-ui-core-utils-miscellaneous.mjs +0 -5
  579. package/esm2022/utils/miscellaneous/to-animation-options.mjs +0 -16
  580. package/esm2022/utils/taiga-ui-core-utils.mjs +0 -5
  581. package/fesm2022/taiga-ui-core-animations.mjs +0 -370
  582. package/fesm2022/taiga-ui-core-animations.mjs.map +0 -1
  583. package/fesm2022/taiga-ui-core-components-alert.mjs +0 -149
  584. package/fesm2022/taiga-ui-core-components-alert.mjs.map +0 -1
  585. package/fesm2022/taiga-ui-core-components-dialog.mjs +0 -230
  586. package/fesm2022/taiga-ui-core-components-dialog.mjs.map +0 -1
  587. package/fesm2022/taiga-ui-core-components-fullscreen.mjs +0 -77
  588. package/fesm2022/taiga-ui-core-components-fullscreen.mjs.map +0 -1
  589. package/fesm2022/taiga-ui-core-directives-dropdown.mjs.map +0 -1
  590. package/fesm2022/taiga-ui-core-directives-hint.mjs +0 -713
  591. package/fesm2022/taiga-ui-core-directives-hint.mjs.map +0 -1
  592. package/fesm2022/taiga-ui-core-directives-popup.mjs +0 -63
  593. package/fesm2022/taiga-ui-core-directives-popup.mjs.map +0 -1
  594. package/fesm2022/taiga-ui-core-directives-surface.mjs +0 -50
  595. package/fesm2022/taiga-ui-core-directives-surface.mjs.map +0 -1
  596. package/fesm2022/taiga-ui-core-directives-title.mjs +0 -43
  597. package/fesm2022/taiga-ui-core-directives-title.mjs.map +0 -1
  598. package/fesm2022/taiga-ui-core-pipes-auto-color.mjs +0 -25
  599. package/fesm2022/taiga-ui-core-pipes-auto-color.mjs.map +0 -1
  600. package/fesm2022/taiga-ui-core-pipes-calendar-sheet.mjs +0 -94
  601. package/fesm2022/taiga-ui-core-pipes-calendar-sheet.mjs.map +0 -1
  602. package/fesm2022/taiga-ui-core-pipes-fallback-src.mjs +0 -29
  603. package/fesm2022/taiga-ui-core-pipes-fallback-src.mjs.map +0 -1
  604. package/fesm2022/taiga-ui-core-pipes-flag.mjs +0 -32
  605. package/fesm2022/taiga-ui-core-pipes-flag.mjs.map +0 -1
  606. package/fesm2022/taiga-ui-core-pipes-format-date.mjs +0 -28
  607. package/fesm2022/taiga-ui-core-pipes-format-date.mjs.map +0 -1
  608. package/fesm2022/taiga-ui-core-pipes-initials.mjs +0 -29
  609. package/fesm2022/taiga-ui-core-pipes-initials.mjs.map +0 -1
  610. package/fesm2022/taiga-ui-core-pipes-month.mjs +0 -29
  611. package/fesm2022/taiga-ui-core-pipes-month.mjs.map +0 -1
  612. package/fesm2022/taiga-ui-core-pipes-order-week-days.mjs +0 -36
  613. package/fesm2022/taiga-ui-core-pipes-order-week-days.mjs.map +0 -1
  614. package/pipes/auto-color/auto-color.pipe.d.ts +0 -7
  615. package/pipes/auto-color/index.d.ts +0 -1
  616. package/pipes/calendar-sheet/index.d.ts +0 -1
  617. package/pipes/calendar-sheet/utils.d.ts +0 -20
  618. package/pipes/fallback-src/fallback-src.pipe.d.ts +0 -9
  619. package/pipes/fallback-src/index.d.ts +0 -1
  620. package/pipes/flag/flag.pipe.d.ts +0 -14
  621. package/pipes/flag/index.d.ts +0 -1
  622. package/pipes/format-date/format-date.pipe.d.ts +0 -9
  623. package/pipes/format-date/index.d.ts +0 -1
  624. package/pipes/initials/index.d.ts +0 -1
  625. package/pipes/initials/initials.pipe.d.ts +0 -7
  626. package/pipes/month/index.d.ts +0 -1
  627. package/pipes/month/month.pipe.d.ts +0 -10
  628. package/pipes/order-week-days/index.d.ts +0 -1
  629. package/services/breakpoint.service.d.ts +0 -16
  630. package/services/dark-theme.service.d.ts +0 -10
  631. package/services/format-date.service.d.ts +0 -8
  632. package/styles/mixins/wrapper.less +0 -64
  633. package/styles/mixins/wrapper.scss +0 -61
  634. package/styles/theme/appearance/opposite.less +0 -17
  635. package/styles/theme/wrapper.less +0 -211
  636. package/tokens/day-type-handler.d.ts +0 -7
  637. package/tokens/first-day-of-week.d.ts +0 -5
  638. package/tokens/scroll-ref.d.ts +0 -2
  639. package/tokens/spin-icons.d.ts +0 -6
  640. package/types/portal-item.d.ts +0 -9
  641. package/types/range-state.d.ts +0 -4
  642. package/types/value-content-context.d.ts +0 -4
  643. package/utils/format/string-hash-to-hsl.d.ts +0 -6
  644. package/utils/miscellaneous/to-animation-options.d.ts +0 -4
  645. /package/{directives → components}/title/index.d.ts +0 -0
  646. /package/{directives → portals}/dropdown/dropdown-limit-width.d.ts +0 -0
  647. /package/{directives → portals}/dropdown/dropdown.component.d.ts +0 -0
  648. /package/{directives → portals}/dropdown/dropdown.driver.d.ts +0 -0
  649. /package/{directives → portals}/dropdown/dropdown.providers.d.ts +0 -0
  650. /package/{directives → portals}/dropdown/with-dropdown-open.directive.d.ts +0 -0
  651. /package/{directives → portals}/hint/hint-driver.directive.d.ts +0 -0
  652. /package/{directives → portals}/hint/hint-pointer.directive.d.ts +0 -0
  653. /package/{directives → portals}/hint/hint.providers.d.ts +0 -0
  654. /package/{directives → portals}/popup/index.d.ts +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"taiga-ui-core-components-loader.mjs","sources":["../../../projects/core/components/loader/loader.options.ts","../../../projects/core/components/loader/loader.component.ts","../../../projects/core/components/loader/loader.template.html","../../../projects/core/components/loader/taiga-ui-core-components-loader.ts"],"sourcesContent":["import {InjectionToken, type Provider} from '@angular/core';\nimport {tuiProvideOptions} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {type TuiSizeXS, type TuiSizeXXL} from '@taiga-ui/core/types';\n\nexport interface TuiLoaderOptions {\n readonly inheritColor: boolean;\n readonly overlay: boolean;\n readonly size: TuiSizeXS | TuiSizeXXL;\n}\n\n/** Default values for the loader options. */\nexport const TUI_LOADER_DEFAULT_OPTIONS: TuiLoaderOptions = {\n size: 'm',\n inheritColor: false,\n overlay: false,\n};\n\n/**\n * Default parameters for loader component\n */\nexport const TUI_LOADER_OPTIONS = new InjectionToken(\n ngDevMode ? 'TUI_LOADER_OPTIONS' : '',\n {\n factory: () => TUI_LOADER_DEFAULT_OPTIONS,\n },\n);\n\nexport function tuiLoaderOptionsProvider(options: Partial<TuiLoaderOptions>): Provider {\n return tuiProvideOptions(TUI_LOADER_OPTIONS, options, TUI_LOADER_DEFAULT_OPTIONS);\n}\n","import {NgIf} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, inject, Input} from '@angular/core';\nimport {TUI_IS_IOS} from '@taiga-ui/cdk/tokens';\nimport {tuiIsSafari} from '@taiga-ui/cdk/utils/browser';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiSizeBigger} from '@taiga-ui/core/utils/miscellaneous';\nimport {type PolymorpheusContent, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nimport {TUI_LOADER_OPTIONS} from './loader.options';\n\n@Component({\n standalone: true,\n selector: 'tui-loader',\n imports: [NgIf, PolymorpheusOutlet],\n templateUrl: './loader.template.html',\n styleUrls: ['./loader.style.less'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n host: {\n '[class._loading]': 'loading',\n '[attr.data-size]': 'size',\n },\n})\nexport class TuiLoader {\n private readonly isIOS = inject(TUI_IS_IOS);\n private readonly options = inject(TUI_LOADER_OPTIONS);\n protected readonly isApple = tuiIsSafari(tuiInjectElement()) || this.isIOS;\n\n @Input()\n public size = this.options.size;\n\n @Input()\n public inheritColor = this.options.inheritColor;\n\n @Input()\n public overlay = this.options.overlay;\n\n @Input()\n public textContent: PolymorpheusContent;\n\n // TODO: Drop alias in v5\n @Input('showLoader')\n public loading = true;\n\n protected get isHorizontal(): boolean {\n return !tuiSizeBigger(this.size);\n }\n}\n","<fieldset\n class=\"t-content\"\n [attr.inert]=\"loading || null\"\n [class.t-content_has-overlay]=\"overlay && loading\"\n [class.t-content_loading]=\"loading\"\n [disabled]=\"loading && !isApple\"\n>\n <ng-content />\n</fieldset>\n\n<div\n *ngIf=\"loading\"\n class=\"t-loader\"\n [class.t-loader_horizontal]=\"isHorizontal\"\n [class.t-loader_inherit-color]=\"inheritColor\"\n>\n <svg\n automation-id=\"tui-loader__loader\"\n focusable=\"false\"\n height=\"100%\"\n width=\"100%\"\n class=\"t-icon\"\n >\n <circle\n cx=\"50%\"\n cy=\"50%\"\n class=\"t-circle\"\n />\n </svg>\n\n <div\n *ngIf=\"textContent\"\n automation-id=\"tui-loader__text\"\n class=\"t-text\"\n [class.t-text_horizontal]=\"isHorizontal\"\n >\n <ng-container *polymorpheusOutlet=\"textContent as text\">\n {{ text }}\n </ng-container>\n </div>\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"taiga-ui-core-components-loader.mjs","sources":["../../../projects/core/components/loader/loader.options.ts","../../../projects/core/components/loader/loader.component.ts","../../../projects/core/components/loader/loader.template.html","../../../projects/core/components/loader/taiga-ui-core-components-loader.ts"],"sourcesContent":["import {tuiCreateOptions} from '@taiga-ui/cdk/utils/di';\nimport {type TuiSizeXS, type TuiSizeXXL} from '@taiga-ui/core/types';\n\nexport interface TuiLoaderOptions {\n readonly inheritColor: boolean;\n readonly overlay: boolean;\n readonly size: TuiSizeXS | TuiSizeXXL;\n}\n\n/** Default values for the loader options. */\nexport const TUI_LOADER_DEFAULT_OPTIONS: TuiLoaderOptions = {\n size: 'm',\n inheritColor: false,\n overlay: false,\n};\n\n/**\n * Default parameters for loader component\n */\nexport const [TUI_LOADER_OPTIONS, tuiLoaderOptionsProvider] = tuiCreateOptions(\n TUI_LOADER_DEFAULT_OPTIONS,\n);\n","import {ChangeDetectionStrategy, Component, computed, inject, input} from '@angular/core';\nimport {isSafari, WA_IS_IOS} from '@ng-web-apis/platform';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiSizeBigger} from '@taiga-ui/core/utils/miscellaneous';\nimport {type PolymorpheusContent, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nimport {TUI_LOADER_OPTIONS} from './loader.options';\n\n@Component({\n selector: 'tui-loader',\n imports: [PolymorpheusOutlet],\n templateUrl: './loader.template.html',\n styleUrl: './loader.style.less',\n changeDetection: ChangeDetectionStrategy.OnPush,\n host: {\n '[class._loading]': 'loading()',\n '[attr.data-size]': 'size()',\n },\n})\nexport class TuiLoader {\n private readonly isIOS = inject(WA_IS_IOS);\n private readonly options = inject(TUI_LOADER_OPTIONS);\n protected readonly isApple = isSafari(tuiInjectElement()) || this.isIOS;\n\n protected readonly isHorizontal = computed(() => !tuiSizeBigger(this.size()));\n\n public readonly size = input(this.options.size);\n public readonly inheritColor = input(this.options.inheritColor);\n public readonly overlay = input(this.options.overlay);\n public readonly textContent = input<PolymorpheusContent>();\n public readonly loading = input(true);\n}\n","<fieldset\n class=\"t-content\"\n [attr.inert]=\"loading() || null\"\n [class.t-content_has-overlay]=\"overlay() && loading()\"\n [class.t-content_loading]=\"loading()\"\n [disabled]=\"loading() && !isApple\"\n>\n <ng-content />\n</fieldset>\n\n@if (loading()) {\n <div\n class=\"t-loader\"\n [class.t-loader_horizontal]=\"isHorizontal()\"\n [class.t-loader_inherit-color]=\"inheritColor()\"\n >\n <svg\n automation-id=\"tui-loader__loader\"\n focusable=\"false\"\n height=\"100%\"\n width=\"100%\"\n class=\"t-icon\"\n >\n <circle\n cx=\"50%\"\n cy=\"50%\"\n class=\"t-circle\"\n />\n </svg>\n @if (textContent()) {\n <div\n automation-id=\"tui-loader__text\"\n class=\"t-text\"\n [class.t-text_horizontal]=\"isHorizontal()\"\n >\n <ng-container *polymorpheusOutlet=\"textContent() as text\">\n {{ text }}\n </ng-container>\n </div>\n }\n </div>\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -1,13 +1,25 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Component, ViewEncapsulation, ChangeDetectionStrategy, inject, Directive, Input } from '@angular/core';
2
+ import { InjectionToken, ChangeDetectionStrategy, ViewEncapsulation, Component, inject, computed, input, Directive, Injectable } from '@angular/core';
3
3
  import { tuiWithStyles, tuiIsString } from '@taiga-ui/cdk/utils/miscellaneous';
4
- import { tuiButtonOptionsProvider } from '@taiga-ui/core/components/button';
4
+ import { tuiButtonOptionsProvider, TuiButton } from '@taiga-ui/core/components/button';
5
5
  import { tuiLinkOptionsProvider } from '@taiga-ui/core/components/link';
6
6
  import * as i2 from '@taiga-ui/core/directives/appearance';
7
7
  import { tuiAppearanceOptionsProvider, TuiWithAppearance } from '@taiga-ui/core/directives/appearance';
8
8
  import * as i1 from '@taiga-ui/core/directives/icons';
9
- import { TuiIcons, TuiWithIcons } from '@taiga-ui/core/directives/icons';
9
+ import { tuiIconStart, TuiWithIcons } from '@taiga-ui/core/directives/icons';
10
10
  import { tuiCreateOptions } from '@taiga-ui/cdk/utils/di';
11
+ import * as i1$2 from '@taiga-ui/cdk/portals';
12
+ import { tuiAsPortal, TuiPortalDirective } from '@taiga-ui/cdk/portals';
13
+ import * as i2$1 from '@taiga-ui/core/portals/alert';
14
+ import { TuiAlertDirective, TuiAlertService } from '@taiga-ui/core/portals/alert';
15
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
16
+ import * as i1$1 from '@taiga-ui/cdk/directives/animated';
17
+ import { TuiAnimated } from '@taiga-ui/cdk/directives/animated';
18
+ import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
19
+ import { TuiTitle } from '@taiga-ui/core/components/title';
20
+ import { TUI_COMMON_ICONS, TUI_CLOSE_WORD } from '@taiga-ui/core/tokens';
21
+ import { injectContext, PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
22
+ import { of, switchMap, timer, EMPTY, takeUntil, fromEvent, repeat } from 'rxjs';
11
23
 
12
24
  const ICONS = {
13
25
  info: '@tui.info',
@@ -15,95 +27,124 @@ const ICONS = {
15
27
  negative: '@tui.circle-x',
16
28
  warning: '@tui.circle-alert',
17
29
  neutral: '@tui.info',
18
- /* TODO @deprecated remove in v5 */
19
- success: '@tui.circle-check',
20
- /* TODO @deprecated remove in v5 */
21
- error: '@tui.circle-x',
22
30
  };
23
- /** Default values for the notification options. */
24
31
  const TUI_NOTIFICATION_DEFAULT_OPTIONS = {
25
32
  appearance: 'info',
26
33
  icon: (appearance) => ICONS[appearance] ?? '',
27
34
  size: 'l',
35
+ data: undefined,
36
+ autoClose: 3000,
37
+ label: '',
38
+ closable: true,
39
+ block: 'start',
40
+ inline: 'end',
28
41
  };
29
- /**
30
- * Default parameters for notification alert component
31
- */
32
42
  const [TUI_NOTIFICATION_OPTIONS, tuiNotificationOptionsProvider] = tuiCreateOptions(TUI_NOTIFICATION_DEFAULT_OPTIONS);
43
+ const TUI_NOTIFICATION_CONCURRENCY = new InjectionToken(ngDevMode ? 'TUI_NOTIFICATION_CONCURRENCY' : '', { factory: () => 5 });
33
44
 
34
- class TuiNotificationStyles {
35
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiNotificationStyles, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
36
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiNotificationStyles, isStandalone: true, selector: "ng-component", host: { classAttribute: "tui-notification" }, ngImport: i0, template: '', isInline: true, styles: ["tui-notification,[tuiNotification]{-webkit-appearance:none;appearance:none;padding:0;border:0;background:none;font:inherit;line-height:inherit;position:relative;display:block;max-block-size:100%;color:var(--tui-text-primary);padding:1rem;font:var(--tui-font-text-m);line-height:1.5rem;border-radius:var(--tui-radius-l);box-sizing:border-box;text-align:start;text-decoration:none;border-inline-start:var(--t-start) solid transparent;border-inline-end:var(--t-end) solid transparent;--t-start: 0;--t-end: 0}tui-notification[style*=\"--t-icon-start:\"],[tuiNotification][style*=\"--t-icon-start:\"]{--t-start: 2rem}tui-notification[style*=\"--t-icon-end:\"],[tuiNotification][style*=\"--t-icon-end:\"]{--t-end: 1.5rem}tui-notification:before,[tuiNotification]:before{position:absolute;left:-1rem;inset-inline-start:-1rem}tui-notification:after,[tuiNotification]:after{position:absolute;top:50%;transform:translateY(-50%);right:-.5rem;font-size:1rem;margin:0;margin-inline-end:-.25rem;margin-inline-start:auto;color:var(--tui-text-tertiary)!important}@supports (inset-inline-end: 0){tui-notification:after,[tuiNotification]:after{right:unset;inset-inline-end:-.5rem}}tui-notification[data-size=s],[tuiNotification][data-size=s]{padding:.375rem .625rem;font:var(--tui-font-text-s);line-height:1.25rem;border-radius:var(--tui-radius-m)}tui-notification[data-size=s][style*=\"--t-icon-start:\"],[tuiNotification][data-size=s][style*=\"--t-icon-start:\"]{--t-start: 1.5rem}tui-notification[data-size=s]:before,[tuiNotification][data-size=s]:before{top:.5rem;left:-.875rem;inset-inline-start:-.875rem;font-size:1rem}tui-notification[data-size=s]:after,[tuiNotification][data-size=s]:after{right:-.875rem}@supports (inset-inline-end: 0){tui-notification[data-size=s]:after,[tuiNotification][data-size=s]:after{right:unset;inset-inline-end:-.875rem}}tui-notification[data-size=s] tui-icon,[tuiNotification][data-size=s] tui-icon{font-size:1rem}tui-notification[data-size=s] [tuiTitle],[tuiNotification][data-size=s] [tuiTitle]{font:var(--tui-font-text-s);font-weight:700}tui-notification[data-size=s] [tuiSubtitle],[tuiNotification][data-size=s] [tuiSubtitle]{font:var(--tui-font-text-s)}tui-notification[data-size=s] [tuiSubtitle]+*,[tuiNotification][data-size=s] [tuiSubtitle]+*{gap:1rem;margin:.375rem 0 .25rem}tui-notification[data-size=s]>[tuiIconButton],[tuiNotification][data-size=s]>[tuiIconButton]{top:0;right:0}@supports (inset-inline-end: 0){tui-notification[data-size=s]>[tuiIconButton],[tuiNotification][data-size=s]>[tuiIconButton]{right:unset;inset-inline-end:0}}tui-notification[data-size=m],[tuiNotification][data-size=m]{padding:.75rem;font:var(--tui-font-text-s);line-height:1.25rem;border-radius:var(--tui-radius-m)}tui-notification[data-size=m][style*=\"--t-icon-start:\"],[tuiNotification][data-size=m][style*=\"--t-icon-start:\"]{--t-start: 1.625rem}tui-notification[data-size=m]:before,[tuiNotification][data-size=m]:before{left:-.875rem;inset-inline-start:-.875rem;font-size:1.25rem}tui-notification[data-size=m]:after,[tuiNotification][data-size=m]:after{right:-.75rem}@supports (inset-inline-end: 0){tui-notification[data-size=m]:after,[tuiNotification][data-size=m]:after{right:unset;inset-inline-end:-.75rem}}tui-notification[data-size=m] tui-icon,[tuiNotification][data-size=m] tui-icon{font-size:1.25rem}tui-notification[data-size=m] [tuiTitle],[tuiNotification][data-size=m] [tuiTitle]{font:var(--tui-font-text-ui-m);font-weight:700}tui-notification[data-size=m] [tuiSubtitle],[tuiNotification][data-size=m] [tuiSubtitle]{font:var(--tui-font-text-s)}tui-notification[data-size=m] [tuiSubtitle]+*,[tuiNotification][data-size=m] [tuiSubtitle]+*{gap:1rem;margin:.625rem 0 .25rem}tui-notification[data-size=m]>[tuiIconButton],[tuiNotification][data-size=m]>[tuiIconButton]{top:.375rem;right:.5rem}@supports (inset-inline-end: 0){tui-notification[data-size=m]>[tuiIconButton],[tuiNotification][data-size=m]>[tuiIconButton]{right:unset;inset-inline-end:.5rem}}tui-notification [tuiTitle],[tuiNotification] [tuiTitle]{gap:.125rem;font:var(--tui-font-text-ui-l);font-weight:700}tui-notification [tuiSubtitle],[tuiNotification] [tuiSubtitle]{font:var(--tui-font-text-m)}tui-notification [tuiSubtitle]+*,[tuiNotification] [tuiSubtitle]+*{display:flex;align-items:center;gap:1.25rem;margin-block-start:.625rem;font:var(--tui-font-text-s)}tui-notification>[tuiIconButton],[tuiNotification]>[tuiIconButton]{position:absolute;top:.75rem;right:.75rem;box-shadow:none!important;background:transparent!important}@supports (inset-inline-end: 0){tui-notification>[tuiIconButton],[tuiNotification]>[tuiIconButton]{right:unset;inset-inline-end:.75rem}}[tuiNotification]{cursor:pointer}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
45
+ class Styles {
46
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: Styles, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
47
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.17", type: Styles, isStandalone: true, selector: "ng-component", host: { classAttribute: "tui-notification" }, ngImport: i0, template: '', isInline: true, styles: ["[tuiNotification]{-webkit-appearance:none;appearance:none;padding:0;border:0;background:none;font:inherit;line-height:inherit;position:relative;display:block;max-block-size:100%;color:var(--tui-text-primary);padding:1rem;font:var(--tui-font-body-m);line-height:1.5rem;border-radius:var(--tui-radius-l);box-sizing:border-box;text-align:start;text-decoration:none;border-inline-start:var(--t-start) solid transparent;border-inline-end:var(--t-end) solid transparent;--t-start: 0;--t-end: 0}[tuiNotification]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled){cursor:pointer}[tuiNotification][data-icon-start]{--t-start: 2rem}[tuiNotification][data-icon-end]{--t-end: 1.5rem}[tuiNotification]:before{position:absolute;inset-inline-start:-1rem}[tuiNotification]:after{position:absolute;top:50%;transform:translateY(-50%);inset-inline-end:-.5rem;font-size:1rem;margin:0;margin-inline-end:-.25rem;margin-inline-start:auto;color:var(--tui-text-tertiary)!important}[tuiNotification][data-size=s]{padding:.375rem .625rem;font:var(--tui-font-body-s);line-height:1.25rem;border-radius:var(--tui-radius-m)}[tuiNotification][data-size=s][data-icon-start]{--t-start: 1.5rem}[tuiNotification][data-size=s]:before{inset-block-start:.5rem;inset-inline-start:-.875rem;font-size:1rem}[tuiNotification][data-size=s]:after{inset-inline-end:-.875rem}[tuiNotification][data-size=s] tui-icon{font-size:1rem}[tuiNotification][data-size=s] [tuiTitle]{font:var(--tui-font-body-s);font-weight:700}[tuiNotification][data-size=s] [tuiSubtitle]{font:var(--tui-font-body-s)}[tuiNotification][data-size=s] [tuiSubtitle]+*{gap:1rem;margin:.375rem 0 .25rem}[tuiNotification][data-size=s]>[tuiIconButton]{inset-block-start:0;inset-inline-end:0}[tuiNotification][data-size=m]{padding:.75rem;font:var(--tui-font-body-s);line-height:1.25rem;border-radius:var(--tui-radius-m)}[tuiNotification][data-size=m][data-icon-start]{--t-start: 1.625rem}[tuiNotification][data-size=m]:before{inset-inline-start:-.875rem;font-size:1.25rem}[tuiNotification][data-size=m]:after{inset-inline-end:-.75rem}[tuiNotification][data-size=m] tui-icon{font-size:1.25rem}[tuiNotification][data-size=m] [tuiTitle]{font:var(--tui-font-ui-m);font-weight:700}[tuiNotification][data-size=m] [tuiSubtitle]{font:var(--tui-font-body-s)}[tuiNotification][data-size=m] [tuiSubtitle]+*{gap:1rem;margin:.625rem 0 .25rem}[tuiNotification][data-size=m]>[tuiIconButton]{inset-block-start:.375rem;inset-inline-end:.5rem}[tuiNotification] [tuiTitle]{gap:.125rem;font:var(--tui-font-ui-l);font-weight:700}[tuiNotification] [tuiSubtitle]{font:var(--tui-font-body-m)}[tuiNotification] [tuiSubtitle]+*{display:flex;align-items:center;gap:1.25rem;margin-block-start:.625rem;font:var(--tui-font-body-s)}[tuiNotification]>[tuiIconButton]{position:absolute;inset-block-start:.75rem;inset-inline-end:.75rem;box-shadow:none!important;background:transparent!important}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
37
48
  }
38
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiNotificationStyles, decorators: [{
49
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: Styles, decorators: [{
39
50
  type: Component,
40
- args: [{ standalone: true, template: '', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
41
- class: 'tui-notification',
42
- }, styles: ["tui-notification,[tuiNotification]{-webkit-appearance:none;appearance:none;padding:0;border:0;background:none;font:inherit;line-height:inherit;position:relative;display:block;max-block-size:100%;color:var(--tui-text-primary);padding:1rem;font:var(--tui-font-text-m);line-height:1.5rem;border-radius:var(--tui-radius-l);box-sizing:border-box;text-align:start;text-decoration:none;border-inline-start:var(--t-start) solid transparent;border-inline-end:var(--t-end) solid transparent;--t-start: 0;--t-end: 0}tui-notification[style*=\"--t-icon-start:\"],[tuiNotification][style*=\"--t-icon-start:\"]{--t-start: 2rem}tui-notification[style*=\"--t-icon-end:\"],[tuiNotification][style*=\"--t-icon-end:\"]{--t-end: 1.5rem}tui-notification:before,[tuiNotification]:before{position:absolute;left:-1rem;inset-inline-start:-1rem}tui-notification:after,[tuiNotification]:after{position:absolute;top:50%;transform:translateY(-50%);right:-.5rem;font-size:1rem;margin:0;margin-inline-end:-.25rem;margin-inline-start:auto;color:var(--tui-text-tertiary)!important}@supports (inset-inline-end: 0){tui-notification:after,[tuiNotification]:after{right:unset;inset-inline-end:-.5rem}}tui-notification[data-size=s],[tuiNotification][data-size=s]{padding:.375rem .625rem;font:var(--tui-font-text-s);line-height:1.25rem;border-radius:var(--tui-radius-m)}tui-notification[data-size=s][style*=\"--t-icon-start:\"],[tuiNotification][data-size=s][style*=\"--t-icon-start:\"]{--t-start: 1.5rem}tui-notification[data-size=s]:before,[tuiNotification][data-size=s]:before{top:.5rem;left:-.875rem;inset-inline-start:-.875rem;font-size:1rem}tui-notification[data-size=s]:after,[tuiNotification][data-size=s]:after{right:-.875rem}@supports (inset-inline-end: 0){tui-notification[data-size=s]:after,[tuiNotification][data-size=s]:after{right:unset;inset-inline-end:-.875rem}}tui-notification[data-size=s] tui-icon,[tuiNotification][data-size=s] tui-icon{font-size:1rem}tui-notification[data-size=s] [tuiTitle],[tuiNotification][data-size=s] [tuiTitle]{font:var(--tui-font-text-s);font-weight:700}tui-notification[data-size=s] [tuiSubtitle],[tuiNotification][data-size=s] [tuiSubtitle]{font:var(--tui-font-text-s)}tui-notification[data-size=s] [tuiSubtitle]+*,[tuiNotification][data-size=s] [tuiSubtitle]+*{gap:1rem;margin:.375rem 0 .25rem}tui-notification[data-size=s]>[tuiIconButton],[tuiNotification][data-size=s]>[tuiIconButton]{top:0;right:0}@supports (inset-inline-end: 0){tui-notification[data-size=s]>[tuiIconButton],[tuiNotification][data-size=s]>[tuiIconButton]{right:unset;inset-inline-end:0}}tui-notification[data-size=m],[tuiNotification][data-size=m]{padding:.75rem;font:var(--tui-font-text-s);line-height:1.25rem;border-radius:var(--tui-radius-m)}tui-notification[data-size=m][style*=\"--t-icon-start:\"],[tuiNotification][data-size=m][style*=\"--t-icon-start:\"]{--t-start: 1.625rem}tui-notification[data-size=m]:before,[tuiNotification][data-size=m]:before{left:-.875rem;inset-inline-start:-.875rem;font-size:1.25rem}tui-notification[data-size=m]:after,[tuiNotification][data-size=m]:after{right:-.75rem}@supports (inset-inline-end: 0){tui-notification[data-size=m]:after,[tuiNotification][data-size=m]:after{right:unset;inset-inline-end:-.75rem}}tui-notification[data-size=m] tui-icon,[tuiNotification][data-size=m] tui-icon{font-size:1.25rem}tui-notification[data-size=m] [tuiTitle],[tuiNotification][data-size=m] [tuiTitle]{font:var(--tui-font-text-ui-m);font-weight:700}tui-notification[data-size=m] [tuiSubtitle],[tuiNotification][data-size=m] [tuiSubtitle]{font:var(--tui-font-text-s)}tui-notification[data-size=m] [tuiSubtitle]+*,[tuiNotification][data-size=m] [tuiSubtitle]+*{gap:1rem;margin:.625rem 0 .25rem}tui-notification[data-size=m]>[tuiIconButton],[tuiNotification][data-size=m]>[tuiIconButton]{top:.375rem;right:.5rem}@supports (inset-inline-end: 0){tui-notification[data-size=m]>[tuiIconButton],[tuiNotification][data-size=m]>[tuiIconButton]{right:unset;inset-inline-end:.5rem}}tui-notification [tuiTitle],[tuiNotification] [tuiTitle]{gap:.125rem;font:var(--tui-font-text-ui-l);font-weight:700}tui-notification [tuiSubtitle],[tuiNotification] [tuiSubtitle]{font:var(--tui-font-text-m)}tui-notification [tuiSubtitle]+*,[tuiNotification] [tuiSubtitle]+*{display:flex;align-items:center;gap:1.25rem;margin-block-start:.625rem;font:var(--tui-font-text-s)}tui-notification>[tuiIconButton],[tuiNotification]>[tuiIconButton]{position:absolute;top:.75rem;right:.75rem;box-shadow:none!important;background:transparent!important}@supports (inset-inline-end: 0){tui-notification>[tuiIconButton],[tuiNotification]>[tuiIconButton]{right:unset;inset-inline-end:.75rem}}[tuiNotification]{cursor:pointer}\n"] }]
51
+ args: [{ template: '', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'tui-notification' }, styles: ["[tuiNotification]{-webkit-appearance:none;appearance:none;padding:0;border:0;background:none;font:inherit;line-height:inherit;position:relative;display:block;max-block-size:100%;color:var(--tui-text-primary);padding:1rem;font:var(--tui-font-body-m);line-height:1.5rem;border-radius:var(--tui-radius-l);box-sizing:border-box;text-align:start;text-decoration:none;border-inline-start:var(--t-start) solid transparent;border-inline-end:var(--t-end) solid transparent;--t-start: 0;--t-end: 0}[tuiNotification]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled){cursor:pointer}[tuiNotification][data-icon-start]{--t-start: 2rem}[tuiNotification][data-icon-end]{--t-end: 1.5rem}[tuiNotification]:before{position:absolute;inset-inline-start:-1rem}[tuiNotification]:after{position:absolute;top:50%;transform:translateY(-50%);inset-inline-end:-.5rem;font-size:1rem;margin:0;margin-inline-end:-.25rem;margin-inline-start:auto;color:var(--tui-text-tertiary)!important}[tuiNotification][data-size=s]{padding:.375rem .625rem;font:var(--tui-font-body-s);line-height:1.25rem;border-radius:var(--tui-radius-m)}[tuiNotification][data-size=s][data-icon-start]{--t-start: 1.5rem}[tuiNotification][data-size=s]:before{inset-block-start:.5rem;inset-inline-start:-.875rem;font-size:1rem}[tuiNotification][data-size=s]:after{inset-inline-end:-.875rem}[tuiNotification][data-size=s] tui-icon{font-size:1rem}[tuiNotification][data-size=s] [tuiTitle]{font:var(--tui-font-body-s);font-weight:700}[tuiNotification][data-size=s] [tuiSubtitle]{font:var(--tui-font-body-s)}[tuiNotification][data-size=s] [tuiSubtitle]+*{gap:1rem;margin:.375rem 0 .25rem}[tuiNotification][data-size=s]>[tuiIconButton]{inset-block-start:0;inset-inline-end:0}[tuiNotification][data-size=m]{padding:.75rem;font:var(--tui-font-body-s);line-height:1.25rem;border-radius:var(--tui-radius-m)}[tuiNotification][data-size=m][data-icon-start]{--t-start: 1.625rem}[tuiNotification][data-size=m]:before{inset-inline-start:-.875rem;font-size:1.25rem}[tuiNotification][data-size=m]:after{inset-inline-end:-.75rem}[tuiNotification][data-size=m] tui-icon{font-size:1.25rem}[tuiNotification][data-size=m] [tuiTitle]{font:var(--tui-font-ui-m);font-weight:700}[tuiNotification][data-size=m] [tuiSubtitle]{font:var(--tui-font-body-s)}[tuiNotification][data-size=m] [tuiSubtitle]+*{gap:1rem;margin:.625rem 0 .25rem}[tuiNotification][data-size=m]>[tuiIconButton]{inset-block-start:.375rem;inset-inline-end:.5rem}[tuiNotification] [tuiTitle]{gap:.125rem;font:var(--tui-font-ui-l);font-weight:700}[tuiNotification] [tuiSubtitle]{font:var(--tui-font-body-m)}[tuiNotification] [tuiSubtitle]+*{display:flex;align-items:center;gap:1.25rem;margin-block-start:.625rem;font:var(--tui-font-body-s)}[tuiNotification]>[tuiIconButton]{position:absolute;inset-block-start:.75rem;inset-inline-end:.75rem;box-shadow:none!important;background:transparent!important}\n"] }]
43
52
  }] });
44
- class TuiNotification {
53
+ class TuiNotificationDirective {
45
54
  constructor() {
46
55
  this.options = inject(TUI_NOTIFICATION_OPTIONS);
47
- this.nothing = tuiWithStyles(TuiNotificationStyles);
48
- this.icons = inject(TuiIcons);
49
- this.appearance = this.options.appearance;
50
- this.icon = this.options.icon;
51
- this.size = this.options.size;
52
- }
53
- ngOnInit() {
54
- this.refresh();
55
- }
56
- ngOnChanges() {
57
- this.refresh();
56
+ this.nothing = tuiWithStyles(Styles);
57
+ this.icons = tuiIconStart(computed((icon = this.icon()) => tuiIsString(icon) ? icon : icon(this.appearance())));
58
+ this.appearance = input(this.options.appearance);
59
+ this.size = input(this.options.size);
60
+ this.icon = input(this.options.icon);
58
61
  }
59
- refresh() {
60
- this.icons.iconStart.set(tuiIsString(this.icon) ? this.icon : this.icon(this.appearance));
61
- }
62
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiNotification, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
63
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiNotification, isStandalone: true, selector: "tui-notification,a[tuiNotification],button[tuiNotification]", inputs: { appearance: "appearance", icon: "icon", size: "size" }, host: { properties: { "attr.data-size": "size" } }, providers: [
62
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
63
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "19.2.17", type: TuiNotificationDirective, isStandalone: true, selector: "[tuiNotification]:not(ng-template)", inputs: { appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.data-size": "size()" } }, providers: [
64
64
  tuiAppearanceOptionsProvider(TUI_NOTIFICATION_OPTIONS),
65
- tuiLinkOptionsProvider({
66
- appearance: '',
67
- pseudo: true,
68
- }),
69
- tuiButtonOptionsProvider({
70
- appearance: 'outline-grayscale',
71
- size: 's',
72
- }),
73
- ], usesOnChanges: true, hostDirectives: [{ directive: i1.TuiWithIcons }, { directive: i2.TuiWithAppearance }], ngImport: i0 }); }
65
+ tuiLinkOptionsProvider({ appearance: '' }),
66
+ tuiButtonOptionsProvider({ appearance: 'outline-grayscale', size: 's' }),
67
+ ], hostDirectives: [{ directive: i1.TuiWithIcons }, { directive: i2.TuiWithAppearance }], ngImport: i0 }); }
74
68
  }
75
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiNotification, decorators: [{
69
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationDirective, decorators: [{
76
70
  type: Directive,
77
71
  args: [{
78
- standalone: true,
79
- selector: 'tui-notification,a[tuiNotification],button[tuiNotification]',
72
+ selector: '[tuiNotification]:not(ng-template)',
80
73
  providers: [
81
74
  tuiAppearanceOptionsProvider(TUI_NOTIFICATION_OPTIONS),
82
- tuiLinkOptionsProvider({
83
- appearance: '',
84
- pseudo: true,
85
- }),
86
- tuiButtonOptionsProvider({
87
- appearance: 'outline-grayscale',
88
- size: 's',
89
- }),
75
+ tuiLinkOptionsProvider({ appearance: '' }),
76
+ tuiButtonOptionsProvider({ appearance: 'outline-grayscale', size: 's' }),
90
77
  ],
91
78
  hostDirectives: [TuiWithIcons, TuiWithAppearance],
92
- host: {
93
- '[attr.data-size]': 'size',
94
- },
79
+ host: { '[attr.data-size]': 'size()' },
80
+ }]
81
+ }] });
82
+
83
+ class TuiNotificationComponent {
84
+ constructor() {
85
+ this.el = tuiInjectElement();
86
+ this.icons = inject(TUI_COMMON_ICONS);
87
+ this.close = inject(TUI_CLOSE_WORD);
88
+ this.item = injectContext();
89
+ this.sub = of(typeof this.item.autoClose === 'function'
90
+ ? this.item.autoClose(this.item.appearance)
91
+ : this.item.autoClose)
92
+ .pipe(switchMap((autoClose) => (autoClose ? timer(autoClose) : EMPTY)), takeUntil(fromEvent(this.el, 'mouseenter')), repeat({ delay: () => fromEvent(this.el, 'mouseleave') }), takeUntilDestroyed())
93
+ .subscribe(() => this.item.$implicit.complete());
94
+ }
95
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
96
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiNotificationComponent, isStandalone: true, selector: "tui-notification-alert", host: { attributes: { "role": "alert" } }, hostDirectives: [{ directive: i1$1.TuiAnimated }, { directive: i2$1.TuiAlertDirective }], ngImport: i0, template: "<div class=\"t-wrapper\">\n <div\n size=\"m\"\n tuiNotification\n [appearance]=\"item.appearance\"\n [class.t-closable]=\"item.closable\"\n [icon]=\"item.icon\"\n >\n <span tuiTitle>\n <ng-container *polymorpheusOutlet=\"item.label as text; context: item\">\n {{ text }}\n </ng-container>\n <span tuiSubtitle>\n <span\n *polymorpheusOutlet=\"item.content as text; context: item\"\n [innerHTML]=\"text\"\n ></span>\n </span>\n </span>\n @if (item.closable) {\n <button\n tuiIconButton\n type=\"button\"\n [iconStart]=\"icons.close\"\n (click)=\"item.$implicit.complete()\"\n >\n {{ close() }}\n </button>\n }\n </div>\n</div>\n", styles: [":host{inline-size:18rem;margin:1.625rem 3rem;word-break:break-word;transform:translateZ(0);filter:drop-shadow(0 .375rem 1rem rgba(0,0,0,.12))}:host :host-context(tui-root._mobile){margin:.625rem 1rem}.t-wrapper{background:var(--tui-background-base);clip-path:inset(.375rem 0 round var(--tui-radius-m))}.t-closable{padding-inline-end:2.5rem}\n"], dependencies: [{ kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "directive", type: TuiNotificationDirective, selector: "[tuiNotification]:not(ng-template)", inputs: ["appearance", "size", "icon"] }, { kind: "directive", type: TuiTitle, selector: "[tuiTitle]", inputs: ["tuiTitle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
97
+ }
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationComponent, decorators: [{
99
+ type: Component,
100
+ args: [{ selector: 'tui-notification-alert', imports: [PolymorpheusOutlet, TuiButton, TuiNotificationDirective, TuiTitle], changeDetection: ChangeDetectionStrategy.OnPush, hostDirectives: [TuiAnimated, TuiAlertDirective], host: { role: 'alert' }, template: "<div class=\"t-wrapper\">\n <div\n size=\"m\"\n tuiNotification\n [appearance]=\"item.appearance\"\n [class.t-closable]=\"item.closable\"\n [icon]=\"item.icon\"\n >\n <span tuiTitle>\n <ng-container *polymorpheusOutlet=\"item.label as text; context: item\">\n {{ text }}\n </ng-container>\n <span tuiSubtitle>\n <span\n *polymorpheusOutlet=\"item.content as text; context: item\"\n [innerHTML]=\"text\"\n ></span>\n </span>\n </span>\n @if (item.closable) {\n <button\n tuiIconButton\n type=\"button\"\n [iconStart]=\"icons.close\"\n (click)=\"item.$implicit.complete()\"\n >\n {{ close() }}\n </button>\n }\n </div>\n</div>\n", styles: [":host{inline-size:18rem;margin:1.625rem 3rem;word-break:break-word;transform:translateZ(0);filter:drop-shadow(0 .375rem 1rem rgba(0,0,0,.12))}:host :host-context(tui-root._mobile){margin:.625rem 1rem}.t-wrapper{background:var(--tui-background-base);clip-path:inset(.375rem 0 round var(--tui-radius-m))}.t-closable{padding-inline-end:2.5rem}\n"] }]
101
+ }] });
102
+
103
+ class TuiNotificationService extends TuiAlertService {
104
+ constructor() {
105
+ super(inject(TUI_NOTIFICATION_CONCURRENCY));
106
+ this.options = inject(TUI_NOTIFICATION_OPTIONS);
107
+ this.component = TuiNotificationComponent;
108
+ }
109
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
110
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationService, providedIn: 'root' }); }
111
+ }
112
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationService, decorators: [{
113
+ type: Injectable,
114
+ args: [{
115
+ providedIn: 'root',
116
+ }]
117
+ }], ctorParameters: () => [] });
118
+ class TuiNotificationTemplate {
119
+ constructor() {
120
+ this.tuiNotificationOptions = input({});
121
+ }
122
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationTemplate, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
123
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "19.2.17", type: TuiNotificationTemplate, isStandalone: true, selector: "ng-template[tuiNotification]", inputs: { tuiNotificationOptions: { classPropertyName: "tuiNotificationOptions", publicName: "tuiNotificationOptions", isSignal: true, isRequired: false, transformFunction: null } }, providers: [tuiAsPortal(TuiNotificationService)], hostDirectives: [{ directive: i1$2.TuiPortalDirective, inputs: ["options", "tuiNotificationOptions", "open", "tuiNotification"], outputs: ["openChange", "tuiNotificationChange"] }], ngImport: i0 }); }
124
+ }
125
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiNotificationTemplate, decorators: [{
126
+ type: Directive,
127
+ args: [{
128
+ selector: 'ng-template[tuiNotification]',
129
+ providers: [tuiAsPortal(TuiNotificationService)],
130
+ hostDirectives: [
131
+ {
132
+ directive: TuiPortalDirective,
133
+ inputs: ['options: tuiNotificationOptions', 'open: tuiNotification'],
134
+ outputs: ['openChange: tuiNotificationChange'],
135
+ },
136
+ ],
95
137
  }]
96
- }], propDecorators: { appearance: [{
97
- type: Input
98
- }], icon: [{
99
- type: Input
100
- }], size: [{
101
- type: Input
102
- }] } });
138
+ }] });
139
+
140
+ const TuiNotification = [
141
+ TuiNotificationDirective,
142
+ TuiNotificationTemplate,
143
+ ];
103
144
 
104
145
  /**
105
146
  * Generated bundle index. Do not edit.
106
147
  */
107
148
 
108
- export { TUI_NOTIFICATION_DEFAULT_OPTIONS, TUI_NOTIFICATION_OPTIONS, TuiNotification, tuiNotificationOptionsProvider };
149
+ export { TUI_NOTIFICATION_CONCURRENCY, TUI_NOTIFICATION_DEFAULT_OPTIONS, TUI_NOTIFICATION_OPTIONS, TuiNotification, TuiNotificationComponent, TuiNotificationDirective, TuiNotificationService, TuiNotificationTemplate, tuiNotificationOptionsProvider };
109
150
  //# sourceMappingURL=taiga-ui-core-components-notification.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"taiga-ui-core-components-notification.mjs","sources":["../../../projects/core/components/notification/notification.options.ts","../../../projects/core/components/notification/notification.directive.ts","../../../projects/core/components/notification/taiga-ui-core-components-notification.ts"],"sourcesContent":["import {type TuiStringHandler} from '@taiga-ui/cdk/types';\nimport {tuiCreateOptions} from '@taiga-ui/cdk/utils/di';\nimport {type TuiAppearanceOptions} from '@taiga-ui/core/directives/appearance';\nimport {type TuiSizeL, type TuiSizeS} from '@taiga-ui/core/types';\n\nexport interface TuiNotificationOptions extends TuiAppearanceOptions {\n readonly icon: TuiStringHandler<string> | string;\n readonly size: TuiSizeL | TuiSizeS;\n}\n\nconst ICONS: Record<string, string> = {\n info: '@tui.info',\n positive: '@tui.circle-check',\n negative: '@tui.circle-x',\n warning: '@tui.circle-alert',\n neutral: '@tui.info',\n /* TODO @deprecated remove in v5 */\n success: '@tui.circle-check',\n /* TODO @deprecated remove in v5 */\n error: '@tui.circle-x',\n};\n\n/** Default values for the notification options. */\nexport const TUI_NOTIFICATION_DEFAULT_OPTIONS: TuiNotificationOptions = {\n appearance: 'info',\n icon: (appearance) => ICONS[appearance] ?? '',\n size: 'l',\n};\n\n/**\n * Default parameters for notification alert component\n */\nexport const [TUI_NOTIFICATION_OPTIONS, tuiNotificationOptionsProvider] =\n tuiCreateOptions(TUI_NOTIFICATION_DEFAULT_OPTIONS);\n","import {\n ChangeDetectionStrategy,\n Component,\n Directive,\n inject,\n Input,\n type OnChanges,\n type OnInit,\n ViewEncapsulation,\n} from '@angular/core';\nimport {type TuiStringHandler} from '@taiga-ui/cdk/types';\nimport {tuiIsString, tuiWithStyles} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiButtonOptionsProvider} from '@taiga-ui/core/components/button';\nimport {tuiLinkOptionsProvider} from '@taiga-ui/core/components/link';\nimport {\n tuiAppearanceOptionsProvider,\n TuiWithAppearance,\n} from '@taiga-ui/core/directives/appearance';\nimport {TuiIcons, TuiWithIcons} from '@taiga-ui/core/directives/icons';\n\nimport {TUI_NOTIFICATION_OPTIONS} from './notification.options';\n\n@Component({\n standalone: true,\n template: '',\n styles: ['@import \"@taiga-ui/core/styles/components/notification.less\";'],\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n host: {\n class: 'tui-notification',\n },\n})\nclass TuiNotificationStyles {}\n\n@Directive({\n standalone: true,\n selector: 'tui-notification,a[tuiNotification],button[tuiNotification]',\n providers: [\n tuiAppearanceOptionsProvider(TUI_NOTIFICATION_OPTIONS),\n tuiLinkOptionsProvider({\n appearance: '',\n pseudo: true,\n }),\n tuiButtonOptionsProvider({\n appearance: 'outline-grayscale',\n size: 's',\n }),\n ],\n hostDirectives: [TuiWithIcons, TuiWithAppearance],\n host: {\n '[attr.data-size]': 'size',\n },\n})\nexport class TuiNotification implements OnChanges, OnInit {\n private readonly options = inject(TUI_NOTIFICATION_OPTIONS);\n\n protected readonly nothing = tuiWithStyles(TuiNotificationStyles);\n protected readonly icons = inject(TuiIcons);\n\n @Input()\n public appearance = this.options.appearance;\n\n @Input()\n public icon: TuiStringHandler<string> | string = this.options.icon;\n\n @Input()\n public size = this.options.size;\n\n public ngOnInit(): void {\n this.refresh();\n }\n\n public ngOnChanges(): void {\n this.refresh();\n }\n\n private refresh(): void {\n this.icons.iconStart.set(\n tuiIsString(this.icon) ? this.icon : this.icon(this.appearance),\n );\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"taiga-ui-core-components-notification.mjs","sources":["../../../projects/core/components/notification/notification.options.ts","../../../projects/core/components/notification/notification.directive.ts","../../../projects/core/components/notification/notification.component.ts","../../../projects/core/components/notification/notification.template.html","../../../projects/core/components/notification/notification.service.ts","../../../projects/core/components/notification/notification.ts","../../../projects/core/components/notification/taiga-ui-core-components-notification.ts"],"sourcesContent":["import {InjectionToken} from '@angular/core';\nimport {type TuiNumberHandler, type TuiStringHandler} from '@taiga-ui/cdk/types';\nimport {tuiCreateOptions} from '@taiga-ui/cdk/utils/di';\nimport {type TuiAppearanceOptions} from '@taiga-ui/core/directives/appearance';\nimport {type TuiPositionOptions} from '@taiga-ui/core/portals/alert';\nimport {type TuiSizeL, type TuiSizeS} from '@taiga-ui/core/types';\n\nexport interface TuiNotificationOptions<I = undefined>\n extends TuiAppearanceOptions, TuiPositionOptions {\n readonly icon: TuiStringHandler<string> | string;\n readonly size: TuiSizeL | TuiSizeS;\n readonly autoClose: TuiNumberHandler<string> | number;\n readonly closable: boolean;\n readonly label: string;\n readonly data: I;\n}\n\nconst ICONS: Record<string, string> = {\n info: '@tui.info',\n positive: '@tui.circle-check',\n negative: '@tui.circle-x',\n warning: '@tui.circle-alert',\n neutral: '@tui.info',\n};\n\nexport const TUI_NOTIFICATION_DEFAULT_OPTIONS: TuiNotificationOptions = {\n appearance: 'info',\n icon: (appearance) => ICONS[appearance] ?? '',\n size: 'l',\n data: undefined,\n autoClose: 3000,\n label: '',\n closable: true,\n block: 'start',\n inline: 'end',\n};\n\nexport const [TUI_NOTIFICATION_OPTIONS, tuiNotificationOptionsProvider] =\n tuiCreateOptions(TUI_NOTIFICATION_DEFAULT_OPTIONS);\n\nexport const TUI_NOTIFICATION_CONCURRENCY = new InjectionToken(\n ngDevMode ? 'TUI_NOTIFICATION_CONCURRENCY' : '',\n {factory: () => 5},\n);\n","import {\n ChangeDetectionStrategy,\n Component,\n computed,\n Directive,\n inject,\n input,\n ViewEncapsulation,\n} from '@angular/core';\nimport {type TuiStringHandler} from '@taiga-ui/cdk/types';\nimport {tuiIsString, tuiWithStyles} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiButtonOptionsProvider} from '@taiga-ui/core/components/button';\nimport {tuiLinkOptionsProvider} from '@taiga-ui/core/components/link';\nimport {\n tuiAppearanceOptionsProvider,\n TuiWithAppearance,\n} from '@taiga-ui/core/directives/appearance';\nimport {tuiIconStart, TuiWithIcons} from '@taiga-ui/core/directives/icons';\n\nimport {TUI_NOTIFICATION_OPTIONS} from './notification.options';\n\n@Component({\n template: '',\n styles: '@import \"@taiga-ui/core/styles/components/notification.less\";',\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n host: {class: 'tui-notification'},\n})\nclass Styles {}\n\n@Directive({\n selector: '[tuiNotification]:not(ng-template)',\n providers: [\n tuiAppearanceOptionsProvider(TUI_NOTIFICATION_OPTIONS),\n tuiLinkOptionsProvider({appearance: ''}),\n tuiButtonOptionsProvider({appearance: 'outline-grayscale', size: 's'}),\n ],\n hostDirectives: [TuiWithIcons, TuiWithAppearance],\n host: {'[attr.data-size]': 'size()'},\n})\nexport class TuiNotificationDirective {\n private readonly options = inject(TUI_NOTIFICATION_OPTIONS);\n\n protected readonly nothing = tuiWithStyles(Styles);\n protected readonly icons = tuiIconStart(\n computed((icon = this.icon()) =>\n tuiIsString(icon) ? icon : icon(this.appearance()),\n ),\n );\n\n public readonly appearance = input(this.options.appearance);\n public readonly size = input(this.options.size);\n public readonly icon = input<TuiStringHandler<string> | string>(this.options.icon);\n}\n","import {ChangeDetectionStrategy, Component, inject} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {TuiAnimated} from '@taiga-ui/cdk/directives/animated';\nimport {type TuiPortalContext} from '@taiga-ui/cdk/portals';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport {TuiTitle} from '@taiga-ui/core/components/title';\nimport {TuiAlertDirective} from '@taiga-ui/core/portals/alert';\nimport {TUI_CLOSE_WORD, TUI_COMMON_ICONS} from '@taiga-ui/core/tokens';\nimport {injectContext, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\nimport {EMPTY, fromEvent, of, repeat, switchMap, takeUntil, timer} from 'rxjs';\n\nimport {TuiNotificationDirective} from './notification.directive';\nimport {type TuiNotificationOptions} from './notification.options';\n\n@Component({\n selector: 'tui-notification-alert',\n imports: [PolymorpheusOutlet, TuiButton, TuiNotificationDirective, TuiTitle],\n templateUrl: './notification.template.html',\n styleUrl: './notification.style.less',\n changeDetection: ChangeDetectionStrategy.OnPush,\n hostDirectives: [TuiAnimated, TuiAlertDirective],\n host: {role: 'alert'},\n})\nexport class TuiNotificationComponent<O, I> {\n private readonly el = tuiInjectElement();\n\n protected readonly icons = inject(TUI_COMMON_ICONS);\n protected readonly close = inject(TUI_CLOSE_WORD);\n protected readonly item =\n injectContext<TuiPortalContext<TuiNotificationOptions<I>, O>>();\n\n protected readonly sub = of(\n typeof this.item.autoClose === 'function'\n ? this.item.autoClose(this.item.appearance)\n : this.item.autoClose,\n )\n .pipe(\n switchMap((autoClose) => (autoClose ? timer(autoClose) : EMPTY)),\n takeUntil(fromEvent(this.el, 'mouseenter')),\n repeat({delay: () => fromEvent(this.el, 'mouseleave')}),\n takeUntilDestroyed(),\n )\n .subscribe(() => this.item.$implicit.complete());\n}\n","<div class=\"t-wrapper\">\n <div\n size=\"m\"\n tuiNotification\n [appearance]=\"item.appearance\"\n [class.t-closable]=\"item.closable\"\n [icon]=\"item.icon\"\n >\n <span tuiTitle>\n <ng-container *polymorpheusOutlet=\"item.label as text; context: item\">\n {{ text }}\n </ng-container>\n <span tuiSubtitle>\n <span\n *polymorpheusOutlet=\"item.content as text; context: item\"\n [innerHTML]=\"text\"\n ></span>\n </span>\n </span>\n @if (item.closable) {\n <button\n tuiIconButton\n type=\"button\"\n [iconStart]=\"icons.close\"\n (click)=\"item.$implicit.complete()\"\n >\n {{ close() }}\n </button>\n }\n </div>\n</div>\n","import {Directive, inject, Injectable, input} from '@angular/core';\nimport {tuiAsPortal, TuiPortalDirective} from '@taiga-ui/cdk/portals';\nimport {TuiAlertService} from '@taiga-ui/core/portals/alert';\n\nimport {TuiNotificationComponent} from './notification.component';\nimport {\n TUI_NOTIFICATION_CONCURRENCY,\n TUI_NOTIFICATION_OPTIONS,\n type TuiNotificationOptions,\n} from './notification.options';\n\n@Injectable({\n providedIn: 'root',\n})\nexport class TuiNotificationService extends TuiAlertService<TuiNotificationOptions<any>> {\n protected override readonly options = inject(TUI_NOTIFICATION_OPTIONS);\n protected override readonly component = TuiNotificationComponent;\n\n constructor() {\n super(inject(TUI_NOTIFICATION_CONCURRENCY));\n }\n}\n\n@Directive({\n selector: 'ng-template[tuiNotification]',\n providers: [tuiAsPortal(TuiNotificationService)],\n hostDirectives: [\n {\n directive: TuiPortalDirective,\n inputs: ['options: tuiNotificationOptions', 'open: tuiNotification'],\n outputs: ['openChange: tuiNotificationChange'],\n },\n ],\n})\nexport class TuiNotificationTemplate<T> {\n public readonly tuiNotificationOptions = input<Partial<TuiNotificationOptions<T>>>(\n {},\n );\n}\n","import {TuiNotificationDirective} from './notification.directive';\nimport {TuiNotificationTemplate} from './notification.service';\n\nexport const TuiNotification = [\n TuiNotificationDirective,\n TuiNotificationTemplate,\n] as const;\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["i1","i2"],"mappings":"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"}
@@ -1,89 +1,52 @@
1
- import { DOCUMENT, NgIf } from '@angular/common';
1
+ import { DOCUMENT } from '@angular/common';
2
2
  import * as i0 from '@angular/core';
3
- import { inject, signal, RendererFactory2, Component, ViewEncapsulation, ChangeDetectionStrategy } from '@angular/core';
4
- import { toSignal } from '@angular/core/rxjs-interop';
5
- import { EVENT_MANAGER_PLUGINS } from '@angular/platform-browser';
3
+ import { inject, signal, ChangeDetectionStrategy, ViewEncapsulation, Component } from '@angular/core';
4
+ import { WA_IS_MOBILE } from '@ng-web-apis/platform';
6
5
  import { TUI_VERSION } from '@taiga-ui/cdk/constants';
7
- import * as i4 from '@taiga-ui/cdk/directives/active-zone';
8
- import { TuiActiveZone } from '@taiga-ui/cdk/directives/active-zone';
9
6
  import * as i3 from '@taiga-ui/cdk/directives/font-size';
10
7
  import { TuiFontSize } from '@taiga-ui/cdk/directives/font-size';
11
8
  import * as i1 from '@taiga-ui/cdk/directives/platform';
12
9
  import { TuiPlatform } from '@taiga-ui/cdk/directives/platform';
13
10
  import * as i2 from '@taiga-ui/cdk/directives/visual-viewport';
14
11
  import { TuiVisualViewport } from '@taiga-ui/cdk/directives/visual-viewport';
15
- import { tuiWatch } from '@taiga-ui/cdk/observables';
16
- import { TUI_IS_MOBILE } from '@taiga-ui/cdk/tokens';
17
12
  import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
18
- import { TuiAlerts } from '@taiga-ui/core/components/alert';
19
- import { TuiDialogs } from '@taiga-ui/core/components/dialog';
20
13
  import { TUI_SCROLLBAR_OPTIONS, TuiScrollControls } from '@taiga-ui/core/components/scrollbar';
21
- import { TuiDropdowns } from '@taiga-ui/core/directives/dropdown';
22
- import { TuiHints } from '@taiga-ui/core/directives/hint';
23
- import { TuiPopups } from '@taiga-ui/core/directives/popup';
24
- import { TuiBreakpointService } from '@taiga-ui/core/services';
25
- import { TUI_REDUCED_MOTION, TUI_ANIMATIONS_SPEED, TUI_THEME } from '@taiga-ui/core/tokens';
26
- import { tuiGetDuration } from '@taiga-ui/core/utils';
27
- import { PreventEventPlugin } from '@taiga-ui/event-plugins';
28
- import { map } from 'rxjs';
14
+ import { TuiPopups } from '@taiga-ui/core/portals/popup';
15
+ import { TUI_REDUCED_MOTION, TUI_ANIMATIONS_SPEED, TUI_BREAKPOINT } from '@taiga-ui/core/tokens';
16
+ import { tuiGetDuration, TUI_OPTIONS } from '@taiga-ui/core/utils/miscellaneous';
29
17
 
30
- /// <reference types="@taiga-ui/tsconfig/ng-dev-mode" />
31
- /// <reference types="@taiga-ui/tsconfig/ng-dev-mode" />
32
18
  class TuiRoot {
33
19
  constructor() {
34
20
  this.doc = inject(DOCUMENT);
35
21
  this.el = tuiInjectElement();
22
+ this.child = !!inject(TuiRoot, { optional: true, skipSelf: true });
36
23
  this.reducedMotion = inject(TUI_REDUCED_MOTION);
37
24
  this.duration = tuiGetDuration(inject(TUI_ANIMATIONS_SPEED));
38
- this.isChildRoot = !!inject(TuiRoot, { optional: true, skipSelf: true });
39
- this.top = signal(!this.isChildRoot);
40
- this.isMobileRes = toSignal(inject(TuiBreakpointService).pipe(map((breakpoint) => breakpoint === 'mobile'), tuiWatch()), { initialValue: false });
41
- this.nativeScrollbar = inject(TUI_SCROLLBAR_OPTIONS).mode === 'native';
42
- this.scrollbars = !this.nativeScrollbar && !inject(TUI_IS_MOBILE) && !this.isChildRoot;
43
- // TODO move to provideTaiga in v5
44
- const factory = inject(RendererFactory2);
45
- factory.removeStylesOnCompDestroy = false;
46
- if (factory.delegate) {
47
- factory.delegate.removeStylesOnCompDestroy = false;
48
- }
49
- if (!this.top()) {
50
- return;
51
- }
52
- this.doc.documentElement.setAttribute('data-tui-theme', inject(TUI_THEME).toLowerCase());
53
- if (!this.nativeScrollbar) {
54
- this.doc.defaultView?.document.documentElement.classList.add('tui-zero-scrollbar');
55
- }
56
- ngDevMode &&
57
- console.assert(!!inject(EVENT_MANAGER_PLUGINS).find((plugin) => plugin instanceof PreventEventPlugin), 'NG_EVENT_PLUGINS is missing from global providers');
25
+ this.top = signal(this.parent);
26
+ this.breakpoint = inject(TUI_BREAKPOINT);
27
+ this.scrollbars = !inject(WA_IS_MOBILE) &&
28
+ !this.child &&
29
+ inject(TUI_SCROLLBAR_OPTIONS).mode !== 'native' &&
30
+ inject(TUI_OPTIONS).scrollbars !== 'native';
58
31
  }
59
- get isTopLayer() {
60
- return this.doc.fullscreenElement?.matches('tui-root')
61
- ? this.doc.fullscreenElement === this.el
62
- : !this.isChildRoot;
32
+ get parent() {
33
+ return this.doc.fullscreenElement === this.el || !this.child;
63
34
  }
64
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRoot, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
65
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRoot, isStandalone: true, selector: "tui-root", host: { attributes: { "data-tui-version": "4.66.0" }, listeners: { "touchstart.passive.zoneless": "0", "document:fullscreenchange": "top.set(isTopLayer)" }, properties: { "style.--tui-duration.ms": "duration", "style.--tui-scroll-behavior": "reducedMotion ? \"auto\" : \"smooth\"", "class._mobile": "isMobileRes()" } }, hostDirectives: [{ directive: i1.TuiPlatform }, { directive: i2.TuiVisualViewport }, { directive: i3.TuiFontSize }, { directive: i4.TuiActiveZone }], ngImport: i0, template: "<div class=\"t-root-content\">\n <ng-content />\n</div>\n<ng-container *ngIf=\"top()\">\n <tui-scroll-controls\n *ngIf=\"scrollbars\"\n class=\"t-root-scrollbar\"\n />\n <tui-popups />\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n <tui-dropdowns />\n <ng-content select=\"tuiOverDropdowns\" />\n <tui-hints />\n <ng-content select=\"tuiOverHints\" />\n</ng-container>\n", styles: ["@keyframes tuiSkeletonVibe{to{opacity:.5}}@keyframes tuiPresent{to{opacity:.99999}}@keyframes tuiFade{0%{opacity:0}}@keyframes tuiSlide{0%{transform:var(--tui-from, translateY(100%))}}@keyframes tuiScale{0%{transform:scale(var(--tui-scale, 0))}}@keyframes tuiCollapse{0%{grid-template-rows:0fr}to{grid-template-rows:1fr}}.tui-enter,.tui-leave{animation-duration:var(--tui-duration);animation-timing-function:ease-in-out;pointer-events:none}.tui-leave{animation-direction:reverse}\n", ".tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.tui-zero-scrollbar::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;border-image:conic-gradient(var(--tui-background-base) 0 0) fill 0/0/0 0 100vh 0;-webkit-tap-highlight-color:transparent}:root{--tui-inline-start: left;--tui-inline-end: right;--tui-inline: 1}[dir=rtl]{--tui-inline-start: right;--tui-inline-end: left;--tui-inline: -1}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;z-index:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{position:relative;top:var(--t-root-top);block-size:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiAlerts, selector: "tui-alerts" }, { kind: "component", type: TuiDialogs, selector: "tui-dialogs" }, { kind: "component", type: TuiDropdowns, selector: "tui-dropdowns" }, { kind: "component", type: TuiHints, selector: "tui-hints" }, { kind: "component", type: TuiPopups, selector: "tui-popups" }, { kind: "component", type: TuiScrollControls, selector: "tui-scroll-controls" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
35
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiRoot, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
36
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiRoot, isStandalone: true, selector: "tui-root", host: { attributes: { "data-tui-version": "5.0.0-canary.8b64ec1" }, listeners: { "touchstart.passive.zoneless": "0", "document:fullscreenchange": "top.set(parent)" }, properties: { "style.--tui-duration.ms": "duration", "style.--tui-scroll-behavior": "reducedMotion ? \"auto\" : \"smooth\"", "class._mobile": "breakpoint() === \"mobile\"" } }, hostDirectives: [{ directive: i1.TuiPlatform }, { directive: i2.TuiVisualViewport }, { directive: i3.TuiFontSize }], ngImport: i0, template: "<div class=\"t-root-content\">\n <ng-content />\n</div>\n@if (top()) {\n @if (scrollbars) {\n <tui-scroll-controls class=\"t-root-scrollbar\" />\n }\n <tui-popups>\n <ng-content select=\"tuiOverContent\" />\n </tui-popups>\n}\n", styles: ["@keyframes tuiPresent{to{opacity:.99999}}@keyframes tuiFade{0%{opacity:0}}@keyframes tuiSlide{0%{transform:var(--tui-from, translateY(100%))}}@keyframes tuiScale{0%{transform:scale(var(--tui-scale, 0))}}@keyframes tuiCollapse{0%{grid-template-rows:0fr}to{grid-template-rows:1fr}}.tui-enter,.tui-leave{animation-duration:var(--tui-duration);animation-timing-function:ease-in-out;pointer-events:none}.tui-leave{animation-direction:reverse}\n", ".tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.tui-zero-scrollbar::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-body-s);color:var(--tui-text-primary);flex:1;border-image:conic-gradient(var(--tui-background-base) 0 0) fill 0/0/0 0 100vh 0;-webkit-tap-highlight-color:transparent}:root{--tui-inline-start: left;--tui-inline-end: right;--tui-inline: 1}[dir=rtl]{--tui-inline-start: right;--tui-inline-end: left;--tui-inline: -1}tui-root>.t-root-scrollbar{position:fixed;z-index:0;inset:0}.t-root-content{position:relative;top:var(--t-root-top);block-size:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"], dependencies: [{ kind: "component", type: TuiPopups, selector: "tui-popups" }, { kind: "component", type: TuiScrollControls, selector: "tui-scroll-controls" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
66
37
  }
67
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRoot, decorators: [{
38
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiRoot, decorators: [{
68
39
  type: Component,
69
- args: [{ standalone: true, selector: 'tui-root', imports: [
70
- NgIf,
71
- TuiAlerts,
72
- TuiDialogs,
73
- TuiDropdowns,
74
- TuiHints,
75
- TuiPopups,
76
- TuiScrollControls,
77
- ], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.Default, hostDirectives: [TuiPlatform, TuiVisualViewport, TuiFontSize, TuiActiveZone], host: {
40
+ args: [{ selector: 'tui-root', imports: [TuiPopups, TuiScrollControls], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.Default, hostDirectives: [TuiPlatform, TuiVisualViewport, TuiFontSize], host: {
78
41
  'data-tui-version': TUI_VERSION,
79
42
  '[style.--tui-duration.ms]': 'duration',
80
43
  '[style.--tui-scroll-behavior]': 'reducedMotion ? "auto" : "smooth"',
81
- '[class._mobile]': 'isMobileRes()',
44
+ '[class._mobile]': 'breakpoint() === "mobile"',
82
45
  // Required for the :active state to work in Safari. https://stackoverflow.com/a/33681490
83
46
  '(touchstart.passive.zoneless)': '0',
84
- '(document:fullscreenchange)': 'top.set(isTopLayer)',
85
- }, template: "<div class=\"t-root-content\">\n <ng-content />\n</div>\n<ng-container *ngIf=\"top()\">\n <tui-scroll-controls\n *ngIf=\"scrollbars\"\n class=\"t-root-scrollbar\"\n />\n <tui-popups />\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n <tui-dropdowns />\n <ng-content select=\"tuiOverDropdowns\" />\n <tui-hints />\n <ng-content select=\"tuiOverHints\" />\n</ng-container>\n", styles: ["@keyframes tuiSkeletonVibe{to{opacity:.5}}@keyframes tuiPresent{to{opacity:.99999}}@keyframes tuiFade{0%{opacity:0}}@keyframes tuiSlide{0%{transform:var(--tui-from, translateY(100%))}}@keyframes tuiScale{0%{transform:scale(var(--tui-scale, 0))}}@keyframes tuiCollapse{0%{grid-template-rows:0fr}to{grid-template-rows:1fr}}.tui-enter,.tui-leave{animation-duration:var(--tui-duration);animation-timing-function:ease-in-out;pointer-events:none}.tui-leave{animation-direction:reverse}\n", ".tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.tui-zero-scrollbar::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;border-image:conic-gradient(var(--tui-background-base) 0 0) fill 0/0/0 0 100vh 0;-webkit-tap-highlight-color:transparent}:root{--tui-inline-start: left;--tui-inline-end: right;--tui-inline: 1}[dir=rtl]{--tui-inline-start: right;--tui-inline-end: left;--tui-inline: -1}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;z-index:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{position:relative;top:var(--t-root-top);block-size:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"] }]
86
- }], ctorParameters: function () { return []; } });
47
+ '(document:fullscreenchange)': 'top.set(parent)',
48
+ }, template: "<div class=\"t-root-content\">\n <ng-content />\n</div>\n@if (top()) {\n @if (scrollbars) {\n <tui-scroll-controls class=\"t-root-scrollbar\" />\n }\n <tui-popups>\n <ng-content select=\"tuiOverContent\" />\n </tui-popups>\n}\n", styles: ["@keyframes tuiPresent{to{opacity:.99999}}@keyframes tuiFade{0%{opacity:0}}@keyframes tuiSlide{0%{transform:var(--tui-from, translateY(100%))}}@keyframes tuiScale{0%{transform:scale(var(--tui-scale, 0))}}@keyframes tuiCollapse{0%{grid-template-rows:0fr}to{grid-template-rows:1fr}}.tui-enter,.tui-leave{animation-duration:var(--tui-duration);animation-timing-function:ease-in-out;pointer-events:none}.tui-leave{animation-direction:reverse}\n", ".tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.tui-zero-scrollbar::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-body-s);color:var(--tui-text-primary);flex:1;border-image:conic-gradient(var(--tui-background-base) 0 0) fill 0/0/0 0 100vh 0;-webkit-tap-highlight-color:transparent}:root{--tui-inline-start: left;--tui-inline-end: right;--tui-inline: 1}[dir=rtl]{--tui-inline-start: right;--tui-inline-end: left;--tui-inline: -1}tui-root>.t-root-scrollbar{position:fixed;z-index:0;inset:0}.t-root-content{position:relative;top:var(--t-root-top);block-size:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"] }]
49
+ }] });
87
50
 
88
51
  /**
89
52
  * Generated bundle index. Do not edit.
@@ -1 +1 @@
1
- {"version":3,"file":"taiga-ui-core-components-root.mjs","sources":["../../../projects/core/components/root/root.component.ts","../../../projects/core/components/root/root.template.html","../../../projects/core/components/root/taiga-ui-core-components-root.ts"],"sourcesContent":["/// <reference types=\"@taiga-ui/tsconfig/ng-dev-mode\" />\nimport {DOCUMENT, NgIf} from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n inject,\n RendererFactory2,\n signal,\n ViewEncapsulation,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {EVENT_MANAGER_PLUGINS} from '@angular/platform-browser';\nimport {TUI_VERSION} from '@taiga-ui/cdk/constants';\nimport {TuiActiveZone} from '@taiga-ui/cdk/directives/active-zone';\nimport {TuiFontSize} from '@taiga-ui/cdk/directives/font-size';\nimport {TuiPlatform} from '@taiga-ui/cdk/directives/platform';\nimport {TuiVisualViewport} from '@taiga-ui/cdk/directives/visual-viewport';\nimport {tuiWatch} from '@taiga-ui/cdk/observables';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {TuiAlerts} from '@taiga-ui/core/components/alert';\nimport {TuiDialogs} from '@taiga-ui/core/components/dialog';\nimport {\n TUI_SCROLLBAR_OPTIONS,\n TuiScrollControls,\n} from '@taiga-ui/core/components/scrollbar';\nimport {TuiDropdowns} from '@taiga-ui/core/directives/dropdown';\nimport {TuiHints} from '@taiga-ui/core/directives/hint';\nimport {TuiPopups} from '@taiga-ui/core/directives/popup';\nimport {TuiBreakpointService} from '@taiga-ui/core/services';\nimport {TUI_ANIMATIONS_SPEED, TUI_REDUCED_MOTION, TUI_THEME} from '@taiga-ui/core/tokens';\nimport {tuiGetDuration} from '@taiga-ui/core/utils';\nimport {PreventEventPlugin} from '@taiga-ui/event-plugins';\nimport {map} from 'rxjs';\n\n@Component({\n standalone: true,\n selector: 'tui-root',\n imports: [\n NgIf,\n TuiAlerts,\n TuiDialogs,\n TuiDropdowns,\n TuiHints,\n TuiPopups,\n TuiScrollControls,\n ],\n templateUrl: './root.template.html',\n styleUrls: ['./animations.less', './root.style.less'],\n encapsulation: ViewEncapsulation.None,\n // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection\n changeDetection: ChangeDetectionStrategy.Default,\n hostDirectives: [TuiPlatform, TuiVisualViewport, TuiFontSize, TuiActiveZone],\n host: {\n 'data-tui-version': TUI_VERSION,\n '[style.--tui-duration.ms]': 'duration',\n '[style.--tui-scroll-behavior]': 'reducedMotion ? \"auto\" : \"smooth\"',\n '[class._mobile]': 'isMobileRes()',\n // Required for the :active state to work in Safari. https://stackoverflow.com/a/33681490\n '(touchstart.passive.zoneless)': '0',\n '(document:fullscreenchange)': 'top.set(isTopLayer)',\n },\n})\nexport class TuiRoot {\n private readonly doc = inject(DOCUMENT);\n private readonly el = tuiInjectElement();\n protected readonly reducedMotion = inject(TUI_REDUCED_MOTION);\n protected readonly duration = tuiGetDuration(inject(TUI_ANIMATIONS_SPEED));\n protected readonly isChildRoot = !!inject(TuiRoot, {optional: true, skipSelf: true});\n protected readonly top = signal(!this.isChildRoot);\n protected readonly isMobileRes = toSignal(\n inject(TuiBreakpointService).pipe(\n map((breakpoint) => breakpoint === 'mobile'),\n tuiWatch(),\n ),\n {initialValue: false},\n );\n\n protected readonly nativeScrollbar = inject(TUI_SCROLLBAR_OPTIONS).mode === 'native';\n\n protected readonly scrollbars =\n !this.nativeScrollbar && !inject(TUI_IS_MOBILE) && !this.isChildRoot;\n\n constructor() {\n // TODO move to provideTaiga in v5\n const factory = inject<any>(RendererFactory2);\n\n factory.removeStylesOnCompDestroy = false;\n\n if (factory.delegate) {\n factory.delegate.removeStylesOnCompDestroy = false;\n }\n\n if (!this.top()) {\n return;\n }\n\n this.doc.documentElement.setAttribute(\n 'data-tui-theme',\n inject(TUI_THEME).toLowerCase(),\n );\n\n if (!this.nativeScrollbar) {\n this.doc.defaultView?.document.documentElement.classList.add(\n 'tui-zero-scrollbar',\n );\n }\n\n ngDevMode &&\n console.assert(\n !!inject<unknown[]>(EVENT_MANAGER_PLUGINS).find(\n (plugin) => plugin instanceof PreventEventPlugin,\n ),\n 'NG_EVENT_PLUGINS is missing from global providers',\n );\n }\n\n protected get isTopLayer(): boolean {\n return this.doc.fullscreenElement?.matches('tui-root')\n ? this.doc.fullscreenElement === this.el\n : !this.isChildRoot;\n }\n}\n","<div class=\"t-root-content\">\n <ng-content />\n</div>\n<ng-container *ngIf=\"top()\">\n <tui-scroll-controls\n *ngIf=\"scrollbars\"\n class=\"t-root-scrollbar\"\n />\n <tui-popups />\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n <tui-dropdowns />\n <ng-content select=\"tuiOverDropdowns\" />\n <tui-hints />\n <ng-content select=\"tuiOverHints\" />\n</ng-container>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"taiga-ui-core-components-root.mjs","sources":["../../../projects/core/components/root/root.component.ts","../../../projects/core/components/root/root.template.html","../../../projects/core/components/root/taiga-ui-core-components-root.ts"],"sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n inject,\n signal,\n ViewEncapsulation,\n} from '@angular/core';\nimport {WA_IS_MOBILE} from '@ng-web-apis/platform';\nimport {TUI_VERSION} from '@taiga-ui/cdk/constants';\nimport {TuiFontSize} from '@taiga-ui/cdk/directives/font-size';\nimport {TuiPlatform} from '@taiga-ui/cdk/directives/platform';\nimport {TuiVisualViewport} from '@taiga-ui/cdk/directives/visual-viewport';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {\n TUI_SCROLLBAR_OPTIONS,\n TuiScrollControls,\n} from '@taiga-ui/core/components/scrollbar';\nimport {TuiPopups} from '@taiga-ui/core/portals/popup';\nimport {\n TUI_ANIMATIONS_SPEED,\n TUI_BREAKPOINT,\n TUI_REDUCED_MOTION,\n} from '@taiga-ui/core/tokens';\nimport {TUI_OPTIONS, tuiGetDuration} from '@taiga-ui/core/utils/miscellaneous';\n\n@Component({\n selector: 'tui-root',\n imports: [TuiPopups, TuiScrollControls],\n templateUrl: './root.template.html',\n styleUrls: ['./animations.less', './root.style.less'],\n encapsulation: ViewEncapsulation.None,\n // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection\n changeDetection: ChangeDetectionStrategy.Default,\n hostDirectives: [TuiPlatform, TuiVisualViewport, TuiFontSize],\n host: {\n 'data-tui-version': TUI_VERSION,\n '[style.--tui-duration.ms]': 'duration',\n '[style.--tui-scroll-behavior]': 'reducedMotion ? \"auto\" : \"smooth\"',\n '[class._mobile]': 'breakpoint() === \"mobile\"',\n // Required for the :active state to work in Safari. https://stackoverflow.com/a/33681490\n '(touchstart.passive.zoneless)': '0',\n '(document:fullscreenchange)': 'top.set(parent)',\n },\n})\nexport class TuiRoot {\n private readonly doc = inject(DOCUMENT);\n private readonly el = tuiInjectElement();\n private readonly child = !!inject(TuiRoot, {optional: true, skipSelf: true});\n\n protected readonly reducedMotion = inject(TUI_REDUCED_MOTION);\n protected readonly duration = tuiGetDuration(inject(TUI_ANIMATIONS_SPEED));\n protected readonly top = signal(this.parent);\n protected readonly breakpoint = inject(TUI_BREAKPOINT);\n protected readonly scrollbars =\n !inject(WA_IS_MOBILE) &&\n !this.child &&\n inject(TUI_SCROLLBAR_OPTIONS).mode !== 'native' &&\n inject(TUI_OPTIONS).scrollbars !== 'native';\n\n protected get parent(): boolean {\n return this.doc.fullscreenElement === this.el || !this.child;\n }\n}\n","<div class=\"t-root-content\">\n <ng-content />\n</div>\n@if (top()) {\n @if (scrollbars) {\n <tui-scroll-controls class=\"t-root-scrollbar\" />\n }\n <tui-popups>\n <ng-content select=\"tuiOverContent\" />\n </tui-popups>\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}