@taiga-ui/kit 4.51.0 → 4.52.0-canary.1acd1eb

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 (849) hide show
  1. package/components/accordion/accordion.component.d.ts +13 -0
  2. package/components/accordion/accordion.d.ts +4 -4
  3. package/components/accordion/accordion.directive.d.ts +11 -10
  4. package/components/accordion/index.d.ts +1 -3
  5. package/components/action-bar/action-bar.component.d.ts +5 -7
  6. package/components/action-bar/index.d.ts +0 -2
  7. package/components/avatar/avatar-outline.directive.d.ts +3 -3
  8. package/components/avatar/avatar.directive.d.ts +15 -0
  9. package/components/avatar/avatar.options.d.ts +1 -4
  10. package/components/avatar/index.d.ts +1 -1
  11. package/components/badge/badge.directive.d.ts +2 -2
  12. package/components/block/block.directive.d.ts +4 -4
  13. package/components/block/block.options.d.ts +1 -1
  14. package/components/calendar-month/calendar-month.component.d.ts +1 -1
  15. package/components/calendar-month/calendar-month.options.d.ts +1 -1
  16. package/components/calendar-range/calendar-range.component.d.ts +1 -2
  17. package/components/checkbox/checkbox.component.d.ts +7 -18
  18. package/components/checkbox/checkbox.options.d.ts +5 -9
  19. package/components/chip/chip.directive.d.ts +2 -4
  20. package/components/comment/comment.directive.d.ts +2 -2
  21. package/components/confirm/confirm.component.d.ts +2 -1
  22. package/components/confirm/confirm.service.d.ts +2 -1
  23. package/{directives → components}/copy/copy.component.d.ts +1 -1
  24. package/{directives → components}/copy/copy.directive.d.ts +2 -2
  25. package/{directives → components}/copy/copy.options.d.ts +2 -2
  26. package/components/data-list-wrapper/data-list-group-wrapper.component.d.ts +2 -0
  27. package/components/files/file/file.options.d.ts +1 -1
  28. package/components/files/files/files.component.d.ts +2 -2
  29. package/components/floating-container/floating-container.directive.d.ts +2 -2
  30. package/components/fullscreen/fullscreen.component.d.ts +14 -0
  31. package/components/fullscreen/index.d.ts +1 -0
  32. package/components/index.d.ts +4 -2
  33. package/components/input-chip/input-chip.options.d.ts +1 -1
  34. package/components/input-color/input-color.component.d.ts +2 -1
  35. package/components/input-color/input-color.options.d.ts +1 -1
  36. package/components/input-date/input-date.directive.d.ts +1 -1
  37. package/components/input-date/input-date.options.d.ts +1 -1
  38. package/components/input-number/input-number.options.d.ts +1 -1
  39. package/components/input-number/quantum.directive.d.ts +2 -2
  40. package/components/input-number/step/input-number-step.component.d.ts +1 -1
  41. package/components/input-phone/input-phone.options.d.ts +1 -1
  42. package/components/input-phone-international/input-phone-international.component.d.ts +24 -30
  43. package/components/input-pin/input-pin.component.d.ts +1 -1
  44. package/components/input-range/input-range.component.d.ts +9 -12
  45. package/components/input-slider/input-slider.directive.d.ts +2 -4
  46. package/components/input-time/input-time.directive.d.ts +1 -0
  47. package/components/input-time/input-time.options.d.ts +1 -1
  48. package/components/like/like.component.d.ts +4 -11
  49. package/components/like/like.options.d.ts +3 -4
  50. package/components/line-clamp/line-clamp-box.component.d.ts +3 -4
  51. package/components/line-clamp/line-clamp.component.d.ts +12 -18
  52. package/components/multi-select/multi-select-group/multi-select-group.component.d.ts +3 -3
  53. package/components/multi-select/multi-select-option/multi-select-option.component.d.ts +1 -1
  54. package/components/notification-middle/index.d.ts +3 -0
  55. package/components/notification-middle/notification-middle.component.d.ts +16 -0
  56. package/components/notification-middle/notification-middle.directive.d.ts +7 -0
  57. package/components/notification-middle/notification-middle.service.d.ts +7 -0
  58. package/components/pager/pager.component.d.ts +1 -1
  59. package/components/pagination/pagination.component.d.ts +1 -1
  60. package/components/pin/pin.directive.d.ts +2 -2
  61. package/components/preview/pagination/preview-pagination.component.d.ts +1 -1
  62. package/components/preview/preview.component.d.ts +1 -1
  63. package/components/preview/zoom/preview-zoom.component.d.ts +1 -1
  64. package/components/progress/progress-bar/fixed-gradient/progress-fixed-gradient.directive.d.ts +1 -2
  65. package/components/progress/progress-segmented/progress-segmented.directive.d.ts +2 -2
  66. package/components/push/push-alert.component.d.ts +4 -3
  67. package/components/push/push.component.d.ts +2 -2
  68. package/components/push/push.directive.d.ts +4 -6
  69. package/components/push/push.options.d.ts +4 -8
  70. package/components/push/push.service.d.ts +6 -2
  71. package/components/radio/radio.component.d.ts +7 -8
  72. package/components/radio/radio.directive.d.ts +2 -2
  73. package/components/radio/radio.options.d.ts +2 -5
  74. package/components/range/range-change.directive.d.ts +1 -1
  75. package/components/range/range.component.d.ts +0 -5
  76. package/components/rating/rating.component.d.ts +5 -5
  77. package/components/rating/rating.options.d.ts +5 -3
  78. package/components/segmented/segmented.component.d.ts +5 -5
  79. package/components/slider/helpers/key-steps.d.ts +1 -2
  80. package/components/slider/helpers/slider-key-steps.directive.d.ts +12 -21
  81. package/components/slides/slides.directive.d.ts +4 -4
  82. package/components/status/status.directive.d.ts +2 -2
  83. package/components/switch/switch.component.d.ts +7 -19
  84. package/components/switch/switch.options.d.ts +4 -8
  85. package/components/tabs/tabs-with-more.component.d.ts +1 -1
  86. package/components/textarea/textarea-limit.directive.d.ts +4 -6
  87. package/components/textarea/textarea.options.d.ts +1 -1
  88. package/components/toast/index.d.ts +5 -0
  89. package/components/toast/toast.component.d.ts +18 -0
  90. package/components/toast/toast.d.ts +3 -0
  91. package/components/toast/toast.directive.d.ts +7 -0
  92. package/components/toast/toast.options.d.ts +9 -0
  93. package/components/toast/toast.service.d.ts +17 -0
  94. package/components/tree/components/tree-item/tree-item.component.d.ts +1 -1
  95. package/components/tree/components/tree-item-content/tree-item-content.component.d.ts +2 -7
  96. package/directives/button-select/button-select.directive.d.ts +1 -2
  97. package/directives/chevron/chevron.directive.d.ts +2 -3
  98. package/directives/fade/fade.directive.d.ts +1 -0
  99. package/directives/highlight/highlight.directive.d.ts +2 -2
  100. package/directives/index.d.ts +0 -2
  101. package/directives/password/password.options.d.ts +1 -1
  102. package/directives/sensitive/sensitive.directive.d.ts +2 -2
  103. package/directives/shimmer/shimmer.directive.d.ts +3 -3
  104. package/directives/skeleton/skeleton.directive.d.ts +3 -3
  105. package/directives/tooltip/tooltip.directive.d.ts +2 -2
  106. package/directives/tooltip/tooltip.options.d.ts +2 -2
  107. package/fesm2022/taiga-ui-kit-components-accordion.mjs +69 -145
  108. package/fesm2022/taiga-ui-kit-components-accordion.mjs.map +1 -1
  109. package/fesm2022/taiga-ui-kit-components-action-bar.mjs +22 -38
  110. package/fesm2022/taiga-ui-kit-components-action-bar.mjs.map +1 -1
  111. package/fesm2022/taiga-ui-kit-components-avatar.mjs +81 -100
  112. package/fesm2022/taiga-ui-kit-components-avatar.mjs.map +1 -1
  113. package/fesm2022/taiga-ui-kit-components-badge-notification.mjs +4 -4
  114. package/fesm2022/taiga-ui-kit-components-badge-notification.mjs.map +1 -1
  115. package/fesm2022/taiga-ui-kit-components-badge.mjs +15 -21
  116. package/fesm2022/taiga-ui-kit-components-badge.mjs.map +1 -1
  117. package/fesm2022/taiga-ui-kit-components-badged-content.mjs +8 -8
  118. package/fesm2022/taiga-ui-kit-components-badged-content.mjs.map +1 -1
  119. package/fesm2022/taiga-ui-kit-components-block.mjs +17 -24
  120. package/fesm2022/taiga-ui-kit-components-block.mjs.map +1 -1
  121. package/fesm2022/taiga-ui-kit-components-breadcrumbs.mjs +9 -12
  122. package/fesm2022/taiga-ui-kit-components-breadcrumbs.mjs.map +1 -1
  123. package/fesm2022/taiga-ui-kit-components-button-loading.mjs +4 -5
  124. package/fesm2022/taiga-ui-kit-components-button-loading.mjs.map +1 -1
  125. package/fesm2022/taiga-ui-kit-components-calendar-month.mjs +7 -10
  126. package/fesm2022/taiga-ui-kit-components-calendar-month.mjs.map +1 -1
  127. package/fesm2022/taiga-ui-kit-components-calendar-range.mjs +10 -11
  128. package/fesm2022/taiga-ui-kit-components-calendar-range.mjs.map +1 -1
  129. package/fesm2022/taiga-ui-kit-components-carousel.mjs +21 -23
  130. package/fesm2022/taiga-ui-kit-components-carousel.mjs.map +1 -1
  131. package/fesm2022/taiga-ui-kit-components-checkbox.mjs +19 -76
  132. package/fesm2022/taiga-ui-kit-components-checkbox.mjs.map +1 -1
  133. package/fesm2022/taiga-ui-kit-components-chip.mjs +22 -27
  134. package/fesm2022/taiga-ui-kit-components-chip.mjs.map +1 -1
  135. package/fesm2022/taiga-ui-kit-components-combo-box.mjs +9 -9
  136. package/fesm2022/taiga-ui-kit-components-combo-box.mjs.map +1 -1
  137. package/fesm2022/taiga-ui-kit-components-comment.mjs +13 -20
  138. package/fesm2022/taiga-ui-kit-components-comment.mjs.map +1 -1
  139. package/fesm2022/taiga-ui-kit-components-compass.mjs +4 -4
  140. package/fesm2022/taiga-ui-kit-components-compass.mjs.map +1 -1
  141. package/fesm2022/taiga-ui-kit-components-confirm.mjs +14 -16
  142. package/fesm2022/taiga-ui-kit-components-confirm.mjs.map +1 -1
  143. package/fesm2022/taiga-ui-kit-components-copy.mjs +120 -0
  144. package/fesm2022/taiga-ui-kit-components-copy.mjs.map +1 -0
  145. package/fesm2022/taiga-ui-kit-components-data-list-wrapper.mjs +21 -14
  146. package/fesm2022/taiga-ui-kit-components-data-list-wrapper.mjs.map +1 -1
  147. package/fesm2022/taiga-ui-kit-components-drawer.mjs +7 -7
  148. package/fesm2022/taiga-ui-kit-components-drawer.mjs.map +1 -1
  149. package/fesm2022/taiga-ui-kit-components-elastic-container.mjs +8 -8
  150. package/fesm2022/taiga-ui-kit-components-elastic-container.mjs.map +1 -1
  151. package/fesm2022/taiga-ui-kit-components-files.mjs +41 -42
  152. package/fesm2022/taiga-ui-kit-components-files.mjs.map +1 -1
  153. package/fesm2022/taiga-ui-kit-components-filter.mjs +7 -16
  154. package/fesm2022/taiga-ui-kit-components-filter.mjs.map +1 -1
  155. package/fesm2022/taiga-ui-kit-components-floating-container.mjs +13 -19
  156. package/fesm2022/taiga-ui-kit-components-floating-container.mjs.map +1 -1
  157. package/fesm2022/taiga-ui-kit-components-fullscreen.mjs +63 -0
  158. package/fesm2022/taiga-ui-kit-components-fullscreen.mjs.map +1 -0
  159. package/fesm2022/taiga-ui-kit-components-input-chip.mjs +22 -19
  160. package/fesm2022/taiga-ui-kit-components-input-chip.mjs.map +1 -1
  161. package/fesm2022/taiga-ui-kit-components-input-color.mjs +12 -15
  162. package/fesm2022/taiga-ui-kit-components-input-color.mjs.map +1 -1
  163. package/fesm2022/taiga-ui-kit-components-input-date-multi.mjs +7 -8
  164. package/fesm2022/taiga-ui-kit-components-input-date-multi.mjs.map +1 -1
  165. package/fesm2022/taiga-ui-kit-components-input-date-range.mjs +4 -4
  166. package/fesm2022/taiga-ui-kit-components-input-date-range.mjs.map +1 -1
  167. package/fesm2022/taiga-ui-kit-components-input-date-time.mjs +9 -11
  168. package/fesm2022/taiga-ui-kit-components-input-date-time.mjs.map +1 -1
  169. package/fesm2022/taiga-ui-kit-components-input-date.mjs +18 -20
  170. package/fesm2022/taiga-ui-kit-components-input-date.mjs.map +1 -1
  171. package/fesm2022/taiga-ui-kit-components-input-inline.mjs +6 -6
  172. package/fesm2022/taiga-ui-kit-components-input-inline.mjs.map +1 -1
  173. package/fesm2022/taiga-ui-kit-components-input-month-range.mjs +8 -9
  174. package/fesm2022/taiga-ui-kit-components-input-month-range.mjs.map +1 -1
  175. package/fesm2022/taiga-ui-kit-components-input-month.mjs +14 -16
  176. package/fesm2022/taiga-ui-kit-components-input-month.mjs.map +1 -1
  177. package/fesm2022/taiga-ui-kit-components-input-number.mjs +33 -32
  178. package/fesm2022/taiga-ui-kit-components-input-number.mjs.map +1 -1
  179. package/fesm2022/taiga-ui-kit-components-input-phone-international.mjs +108 -134
  180. package/fesm2022/taiga-ui-kit-components-input-phone-international.mjs.map +1 -1
  181. package/fesm2022/taiga-ui-kit-components-input-phone.mjs +11 -13
  182. package/fesm2022/taiga-ui-kit-components-input-phone.mjs.map +1 -1
  183. package/fesm2022/taiga-ui-kit-components-input-pin.mjs +9 -8
  184. package/fesm2022/taiga-ui-kit-components-input-pin.mjs.map +1 -1
  185. package/fesm2022/taiga-ui-kit-components-input-range.mjs +35 -39
  186. package/fesm2022/taiga-ui-kit-components-input-range.mjs.map +1 -1
  187. package/fesm2022/taiga-ui-kit-components-input-slider.mjs +28 -42
  188. package/fesm2022/taiga-ui-kit-components-input-slider.mjs.map +1 -1
  189. package/fesm2022/taiga-ui-kit-components-input-time.mjs +32 -16
  190. package/fesm2022/taiga-ui-kit-components-input-time.mjs.map +1 -1
  191. package/fesm2022/taiga-ui-kit-components-input-year.mjs +8 -9
  192. package/fesm2022/taiga-ui-kit-components-input-year.mjs.map +1 -1
  193. package/fesm2022/taiga-ui-kit-components-items-with-more.mjs +18 -18
  194. package/fesm2022/taiga-ui-kit-components-items-with-more.mjs.map +1 -1
  195. package/fesm2022/taiga-ui-kit-components-like.mjs +40 -33
  196. package/fesm2022/taiga-ui-kit-components-like.mjs.map +1 -1
  197. package/fesm2022/taiga-ui-kit-components-line-clamp.mjs +38 -83
  198. package/fesm2022/taiga-ui-kit-components-line-clamp.mjs.map +1 -1
  199. package/fesm2022/taiga-ui-kit-components-message.mjs +10 -12
  200. package/fesm2022/taiga-ui-kit-components-message.mjs.map +1 -1
  201. package/fesm2022/taiga-ui-kit-components-multi-select.mjs +45 -44
  202. package/fesm2022/taiga-ui-kit-components-multi-select.mjs.map +1 -1
  203. package/fesm2022/taiga-ui-kit-components-notification-middle.mjs +90 -0
  204. package/fesm2022/taiga-ui-kit-components-notification-middle.mjs.map +1 -0
  205. package/fesm2022/taiga-ui-kit-components-pager.mjs +8 -8
  206. package/fesm2022/taiga-ui-kit-components-pager.mjs.map +1 -1
  207. package/fesm2022/taiga-ui-kit-components-pagination.mjs +8 -9
  208. package/fesm2022/taiga-ui-kit-components-pagination.mjs.map +1 -1
  209. package/fesm2022/taiga-ui-kit-components-pin.mjs +15 -19
  210. package/fesm2022/taiga-ui-kit-components-pin.mjs.map +1 -1
  211. package/fesm2022/taiga-ui-kit-components-preview-dialog.mjs +13 -13
  212. package/fesm2022/taiga-ui-kit-components-preview-dialog.mjs.map +1 -1
  213. package/fesm2022/taiga-ui-kit-components-preview.mjs +38 -40
  214. package/fesm2022/taiga-ui-kit-components-preview.mjs.map +1 -1
  215. package/fesm2022/taiga-ui-kit-components-progress.mjs +39 -52
  216. package/fesm2022/taiga-ui-kit-components-progress.mjs.map +1 -1
  217. package/fesm2022/taiga-ui-kit-components-pulse.mjs +4 -4
  218. package/fesm2022/taiga-ui-kit-components-pulse.mjs.map +1 -1
  219. package/fesm2022/taiga-ui-kit-components-push.mjs +50 -57
  220. package/fesm2022/taiga-ui-kit-components-push.mjs.map +1 -1
  221. package/fesm2022/taiga-ui-kit-components-radio-list.mjs +7 -8
  222. package/fesm2022/taiga-ui-kit-components-radio-list.mjs.map +1 -1
  223. package/fesm2022/taiga-ui-kit-components-radio.mjs +34 -39
  224. package/fesm2022/taiga-ui-kit-components-radio.mjs.map +1 -1
  225. package/fesm2022/taiga-ui-kit-components-range.mjs +12 -21
  226. package/fesm2022/taiga-ui-kit-components-range.mjs.map +1 -1
  227. package/fesm2022/taiga-ui-kit-components-rating.mjs +17 -22
  228. package/fesm2022/taiga-ui-kit-components-rating.mjs.map +1 -1
  229. package/fesm2022/taiga-ui-kit-components-routable-dialog.mjs +5 -5
  230. package/fesm2022/taiga-ui-kit-components-routable-dialog.mjs.map +1 -1
  231. package/fesm2022/taiga-ui-kit-components-segmented.mjs +8 -8
  232. package/fesm2022/taiga-ui-kit-components-segmented.mjs.map +1 -1
  233. package/fesm2022/taiga-ui-kit-components-select.mjs +41 -34
  234. package/fesm2022/taiga-ui-kit-components-select.mjs.map +1 -1
  235. package/fesm2022/taiga-ui-kit-components-slider.mjs +71 -70
  236. package/fesm2022/taiga-ui-kit-components-slider.mjs.map +1 -1
  237. package/fesm2022/taiga-ui-kit-components-slides.mjs +14 -22
  238. package/fesm2022/taiga-ui-kit-components-slides.mjs.map +1 -1
  239. package/fesm2022/taiga-ui-kit-components-status.mjs +12 -16
  240. package/fesm2022/taiga-ui-kit-components-status.mjs.map +1 -1
  241. package/fesm2022/taiga-ui-kit-components-stepper.mjs +12 -12
  242. package/fesm2022/taiga-ui-kit-components-stepper.mjs.map +1 -1
  243. package/fesm2022/taiga-ui-kit-components-switch.mjs +19 -65
  244. package/fesm2022/taiga-ui-kit-components-switch.mjs.map +1 -1
  245. package/fesm2022/taiga-ui-kit-components-tabs.mjs +35 -38
  246. package/fesm2022/taiga-ui-kit-components-tabs.mjs.map +1 -1
  247. package/fesm2022/taiga-ui-kit-components-textarea.mjs +19 -28
  248. package/fesm2022/taiga-ui-kit-components-textarea.mjs.map +1 -1
  249. package/fesm2022/taiga-ui-kit-components-tiles.mjs +13 -13
  250. package/fesm2022/taiga-ui-kit-components-tiles.mjs.map +1 -1
  251. package/fesm2022/taiga-ui-kit-components-toast.mjs +165 -0
  252. package/fesm2022/taiga-ui-kit-components-toast.mjs.map +1 -0
  253. package/fesm2022/taiga-ui-kit-components-tree.mjs +37 -53
  254. package/fesm2022/taiga-ui-kit-components-tree.mjs.map +1 -1
  255. package/fesm2022/taiga-ui-kit-components.mjs +4 -2
  256. package/fesm2022/taiga-ui-kit-components.mjs.map +1 -1
  257. package/fesm2022/taiga-ui-kit-directives-button-close.mjs +3 -3
  258. package/fesm2022/taiga-ui-kit-directives-button-close.mjs.map +1 -1
  259. package/fesm2022/taiga-ui-kit-directives-button-group.mjs +10 -13
  260. package/fesm2022/taiga-ui-kit-directives-button-group.mjs.map +1 -1
  261. package/fesm2022/taiga-ui-kit-directives-button-select.mjs +5 -12
  262. package/fesm2022/taiga-ui-kit-directives-button-select.mjs.map +1 -1
  263. package/fesm2022/taiga-ui-kit-directives-chevron.mjs +13 -20
  264. package/fesm2022/taiga-ui-kit-directives-chevron.mjs.map +1 -1
  265. package/fesm2022/taiga-ui-kit-directives-connected.mjs +10 -15
  266. package/fesm2022/taiga-ui-kit-directives-connected.mjs.map +1 -1
  267. package/fesm2022/taiga-ui-kit-directives-data-list-dropdown-manager.mjs +4 -4
  268. package/fesm2022/taiga-ui-kit-directives-data-list-dropdown-manager.mjs.map +1 -1
  269. package/fesm2022/taiga-ui-kit-directives-fade.mjs +11 -14
  270. package/fesm2022/taiga-ui-kit-directives-fade.mjs.map +1 -1
  271. package/fesm2022/taiga-ui-kit-directives-fluid-typography.mjs +4 -4
  272. package/fesm2022/taiga-ui-kit-directives-fluid-typography.mjs.map +1 -1
  273. package/fesm2022/taiga-ui-kit-directives-highlight.mjs +5 -5
  274. package/fesm2022/taiga-ui-kit-directives-highlight.mjs.map +1 -1
  275. package/fesm2022/taiga-ui-kit-directives-lazy-loading.mjs +8 -9
  276. package/fesm2022/taiga-ui-kit-directives-lazy-loading.mjs.map +1 -1
  277. package/fesm2022/taiga-ui-kit-directives-password.mjs +8 -11
  278. package/fesm2022/taiga-ui-kit-directives-password.mjs.map +1 -1
  279. package/fesm2022/taiga-ui-kit-directives-present.mjs +4 -4
  280. package/fesm2022/taiga-ui-kit-directives-present.mjs.map +1 -1
  281. package/fesm2022/taiga-ui-kit-directives-sensitive.mjs +13 -18
  282. package/fesm2022/taiga-ui-kit-directives-sensitive.mjs.map +1 -1
  283. package/fesm2022/taiga-ui-kit-directives-shimmer.mjs +24 -34
  284. package/fesm2022/taiga-ui-kit-directives-shimmer.mjs.map +1 -1
  285. package/fesm2022/taiga-ui-kit-directives-skeleton.mjs +27 -38
  286. package/fesm2022/taiga-ui-kit-directives-skeleton.mjs.map +1 -1
  287. package/fesm2022/taiga-ui-kit-directives-tooltip.mjs +15 -20
  288. package/fesm2022/taiga-ui-kit-directives-tooltip.mjs.map +1 -1
  289. package/fesm2022/taiga-ui-kit-directives-unfinished-validator.mjs +6 -7
  290. package/fesm2022/taiga-ui-kit-directives-unfinished-validator.mjs.map +1 -1
  291. package/fesm2022/taiga-ui-kit-directives-unmask-handler.mjs +4 -4
  292. package/fesm2022/taiga-ui-kit-directives-unmask-handler.mjs.map +1 -1
  293. package/fesm2022/taiga-ui-kit-directives.mjs +0 -2
  294. package/fesm2022/taiga-ui-kit-directives.mjs.map +1 -1
  295. package/fesm2022/taiga-ui-kit-pipes-emails.mjs +3 -3
  296. package/fesm2022/taiga-ui-kit-pipes-emails.mjs.map +1 -1
  297. package/fesm2022/taiga-ui-kit-pipes-filter-by-input.mjs +3 -3
  298. package/fesm2022/taiga-ui-kit-pipes-filter-by-input.mjs.map +1 -1
  299. package/fesm2022/taiga-ui-kit-pipes-hide-selected.mjs +3 -3
  300. package/fesm2022/taiga-ui-kit-pipes-hide-selected.mjs.map +1 -1
  301. package/fesm2022/taiga-ui-kit-pipes-sort-countries.mjs +5 -4
  302. package/fesm2022/taiga-ui-kit-pipes-sort-countries.mjs.map +1 -1
  303. package/fesm2022/taiga-ui-kit-pipes-stringify-content.mjs +3 -3
  304. package/fesm2022/taiga-ui-kit-pipes-stringify-content.mjs.map +1 -1
  305. package/fesm2022/taiga-ui-kit-pipes-stringify.mjs +3 -3
  306. package/fesm2022/taiga-ui-kit-pipes-stringify.mjs.map +1 -1
  307. package/fesm2022/taiga-ui-kit-pipes.mjs +0 -1
  308. package/fesm2022/taiga-ui-kit-pipes.mjs.map +1 -1
  309. package/fesm2022/taiga-ui-kit-tokens.mjs +7 -10
  310. package/fesm2022/taiga-ui-kit-tokens.mjs.map +1 -1
  311. package/fesm2022/taiga-ui-kit-utils.mjs +1 -1
  312. package/fesm2022/taiga-ui-kit-utils.mjs.map +1 -1
  313. package/package.json +33 -246
  314. package/pipes/index.d.ts +0 -1
  315. package/styles/components/avatar.less +188 -0
  316. package/styles/components/badge.less +4 -18
  317. package/styles/components/block.less +1 -1
  318. package/styles/components/checkbox.less +17 -16
  319. package/styles/components/chip.less +19 -4
  320. package/styles/components/like.less +15 -17
  321. package/styles/components/pin.less +3 -7
  322. package/styles/components/radio.less +2 -2
  323. package/styles/components/switch.less +12 -12
  324. package/styles/components/toast.less +44 -0
  325. package/tokens/i18n.d.ts +25 -26
  326. package/tokens/index.d.ts +0 -1
  327. package/tokens/input-date-options.d.ts +1 -1
  328. package/components/accordion/accordion-item-content.directive.d.ts +0 -6
  329. package/components/accordion/accordion-item-eager-content.directive.d.ts +0 -5
  330. package/components/accordion/accordion-item.component.d.ts +0 -25
  331. package/components/action-bar/action-bar.d.ts +0 -3
  332. package/components/action-bar/action-bar.directive.d.ts +0 -6
  333. package/components/avatar/avatar.component.d.ts +0 -15
  334. package/components/input-password/index.d.ts +0 -2
  335. package/components/input-password/input-password.component.d.ts +0 -16
  336. package/components/input-password/input-password.options.d.ts +0 -24
  337. package/components/pdf-viewer/index.d.ts +0 -4
  338. package/components/pdf-viewer/pdf-viewer.component.d.ts +0 -12
  339. package/components/pdf-viewer/pdf-viewer.directive.d.ts +0 -7
  340. package/components/pdf-viewer/pdf-viewer.options.d.ts +0 -13
  341. package/components/pdf-viewer/pdf-viewer.service.d.ts +0 -13
  342. package/directives/icon-badge/icon-badge.directive.d.ts +0 -9
  343. package/directives/icon-badge/index.d.ts +0 -1
  344. package/esm2022/components/accordion/accordion-item-content.directive.mjs +0 -16
  345. package/esm2022/components/accordion/accordion-item-eager-content.directive.mjs +0 -15
  346. package/esm2022/components/accordion/accordion-item.component.mjs +0 -85
  347. package/esm2022/components/accordion/accordion.directive.mjs +0 -56
  348. package/esm2022/components/accordion/accordion.mjs +0 -11
  349. package/esm2022/components/accordion/index.mjs +0 -6
  350. package/esm2022/components/accordion/taiga-ui-kit-components-accordion.mjs +0 -5
  351. package/esm2022/components/action-bar/action-bar.component.mjs +0 -36
  352. package/esm2022/components/action-bar/action-bar.directive.mjs +0 -17
  353. package/esm2022/components/action-bar/action-bar.mjs +0 -4
  354. package/esm2022/components/action-bar/index.mjs +0 -4
  355. package/esm2022/components/action-bar/taiga-ui-kit-components-action-bar.mjs +0 -5
  356. package/esm2022/components/avatar/avatar-labeled.component.mjs +0 -47
  357. package/esm2022/components/avatar/avatar-outline.directive.mjs +0 -41
  358. package/esm2022/components/avatar/avatar-stack.component.mjs +0 -19
  359. package/esm2022/components/avatar/avatar.component.mjs +0 -59
  360. package/esm2022/components/avatar/avatar.options.mjs +0 -14
  361. package/esm2022/components/avatar/index.mjs +0 -6
  362. package/esm2022/components/avatar/taiga-ui-kit-components-avatar.mjs +0 -5
  363. package/esm2022/components/badge/badge.directive.mjs +0 -42
  364. package/esm2022/components/badge/badge.options.mjs +0 -13
  365. package/esm2022/components/badge/index.mjs +0 -3
  366. package/esm2022/components/badge/taiga-ui-kit-components-badge.mjs +0 -5
  367. package/esm2022/components/badge-notification/badge-notification.component.mjs +0 -22
  368. package/esm2022/components/badge-notification/badge-notification.options.mjs +0 -12
  369. package/esm2022/components/badge-notification/index.mjs +0 -3
  370. package/esm2022/components/badge-notification/taiga-ui-kit-components-badge-notification.mjs +0 -5
  371. package/esm2022/components/badged-content/badge-content.mjs +0 -7
  372. package/esm2022/components/badged-content/badged-content.component.mjs +0 -30
  373. package/esm2022/components/badged-content/badged-content.directive.mjs +0 -20
  374. package/esm2022/components/badged-content/index.mjs +0 -4
  375. package/esm2022/components/badged-content/taiga-ui-kit-components-badged-content.mjs +0 -5
  376. package/esm2022/components/block/block.directive.mjs +0 -58
  377. package/esm2022/components/block/block.options.mjs +0 -13
  378. package/esm2022/components/block/index.mjs +0 -3
  379. package/esm2022/components/block/taiga-ui-kit-components-block.mjs +0 -5
  380. package/esm2022/components/breadcrumbs/breadcrumbs.component.mjs +0 -69
  381. package/esm2022/components/breadcrumbs/breadcrumbs.options.mjs +0 -14
  382. package/esm2022/components/breadcrumbs/index.mjs +0 -3
  383. package/esm2022/components/breadcrumbs/taiga-ui-kit-components-breadcrumbs.mjs +0 -5
  384. package/esm2022/components/button-loading/button-loading.component.mjs +0 -70
  385. package/esm2022/components/button-loading/index.mjs +0 -2
  386. package/esm2022/components/button-loading/taiga-ui-kit-components-button-loading.mjs +0 -5
  387. package/esm2022/components/calendar-month/calendar-month.component.mjs +0 -186
  388. package/esm2022/components/calendar-month/calendar-month.options.mjs +0 -6
  389. package/esm2022/components/calendar-month/index.mjs +0 -3
  390. package/esm2022/components/calendar-month/taiga-ui-kit-components-calendar-month.mjs +0 -5
  391. package/esm2022/components/calendar-range/calculate-disabled-item-handler.mjs +0 -12
  392. package/esm2022/components/calendar-range/calendar-range.component.mjs +0 -224
  393. package/esm2022/components/calendar-range/day-caps-mapper.mjs +0 -26
  394. package/esm2022/components/calendar-range/day-range-period.mjs +0 -36
  395. package/esm2022/components/calendar-range/index.mjs +0 -5
  396. package/esm2022/components/calendar-range/taiga-ui-kit-components-calendar-range.mjs +0 -5
  397. package/esm2022/components/carousel/carousel-autoscroll.directive.mjs +0 -21
  398. package/esm2022/components/carousel/carousel-buttons.directive.mjs +0 -27
  399. package/esm2022/components/carousel/carousel-scroll.directive.mjs +0 -27
  400. package/esm2022/components/carousel/carousel.component.mjs +0 -166
  401. package/esm2022/components/carousel/carousel.directive.mjs +0 -37
  402. package/esm2022/components/carousel/carousel.mjs +0 -15
  403. package/esm2022/components/carousel/index.mjs +0 -7
  404. package/esm2022/components/carousel/taiga-ui-kit-components-carousel.mjs +0 -5
  405. package/esm2022/components/checkbox/checkbox.component.mjs +0 -74
  406. package/esm2022/components/checkbox/checkbox.options.mjs +0 -17
  407. package/esm2022/components/checkbox/index.mjs +0 -3
  408. package/esm2022/components/checkbox/taiga-ui-kit-components-checkbox.mjs +0 -5
  409. package/esm2022/components/chip/chip.directive.mjs +0 -63
  410. package/esm2022/components/chip/chip.options.mjs +0 -13
  411. package/esm2022/components/chip/index.mjs +0 -3
  412. package/esm2022/components/chip/taiga-ui-kit-components-chip.mjs +0 -5
  413. package/esm2022/components/combo-box/combo-box.directive.mjs +0 -139
  414. package/esm2022/components/combo-box/index.mjs +0 -2
  415. package/esm2022/components/combo-box/taiga-ui-kit-components-combo-box.mjs +0 -5
  416. package/esm2022/components/comment/comment.directive.mjs +0 -35
  417. package/esm2022/components/comment/index.mjs +0 -2
  418. package/esm2022/components/comment/taiga-ui-kit-components-comment.mjs +0 -5
  419. package/esm2022/components/compass/compass.component.mjs +0 -19
  420. package/esm2022/components/compass/index.mjs +0 -2
  421. package/esm2022/components/compass/taiga-ui-kit-components-compass.mjs +0 -5
  422. package/esm2022/components/confirm/confirm.component.mjs +0 -29
  423. package/esm2022/components/confirm/confirm.service.mjs +0 -32
  424. package/esm2022/components/confirm/index.mjs +0 -3
  425. package/esm2022/components/confirm/taiga-ui-kit-components-confirm.mjs +0 -5
  426. package/esm2022/components/data-list-wrapper/data-list-group-wrapper.component.mjs +0 -25
  427. package/esm2022/components/data-list-wrapper/data-list-wrapper.component.mjs +0 -86
  428. package/esm2022/components/data-list-wrapper/data-list-wrapper.module.mjs +0 -9
  429. package/esm2022/components/data-list-wrapper/index.mjs +0 -4
  430. package/esm2022/components/data-list-wrapper/taiga-ui-kit-components-data-list-wrapper.mjs +0 -5
  431. package/esm2022/components/drawer/drawer.component.mjs +0 -44
  432. package/esm2022/components/drawer/index.mjs +0 -2
  433. package/esm2022/components/drawer/taiga-ui-kit-components-drawer.mjs +0 -5
  434. package/esm2022/components/elastic-container/elastic-container.component.mjs +0 -28
  435. package/esm2022/components/elastic-container/elastic-container.directive.mjs +0 -48
  436. package/esm2022/components/elastic-container/index.mjs +0 -3
  437. package/esm2022/components/elastic-container/taiga-ui-kit-components-elastic-container.mjs +0 -5
  438. package/esm2022/components/files/file/file.component.mjs +0 -144
  439. package/esm2022/components/files/file/file.options.mjs +0 -16
  440. package/esm2022/components/files/files/files.component.mjs +0 -49
  441. package/esm2022/components/files/files.mjs +0 -15
  442. package/esm2022/components/files/files.types.mjs +0 -2
  443. package/esm2022/components/files/files.utils.mjs +0 -30
  444. package/esm2022/components/files/files.validators.mjs +0 -32
  445. package/esm2022/components/files/index.mjs +0 -13
  446. package/esm2022/components/files/input-files/input-files-validator.directive.mjs +0 -45
  447. package/esm2022/components/files/input-files/input-files.component.mjs +0 -70
  448. package/esm2022/components/files/input-files/input-files.content.mjs +0 -73
  449. package/esm2022/components/files/input-files/input-files.directive.mjs +0 -77
  450. package/esm2022/components/files/input-files/input-files.options.mjs +0 -19
  451. package/esm2022/components/files/pipes/file-rejected.pipe.mjs +0 -51
  452. package/esm2022/components/files/taiga-ui-kit-components-files.mjs +0 -5
  453. package/esm2022/components/filter/filter.component.mjs +0 -65
  454. package/esm2022/components/filter/index.mjs +0 -2
  455. package/esm2022/components/filter/taiga-ui-kit-components-filter.mjs +0 -5
  456. package/esm2022/components/floating-container/floating-container.directive.mjs +0 -37
  457. package/esm2022/components/floating-container/index.mjs +0 -2
  458. package/esm2022/components/floating-container/taiga-ui-kit-components-floating-container.mjs +0 -5
  459. package/esm2022/components/index.mjs +0 -72
  460. package/esm2022/components/input-chip/index.mjs +0 -5
  461. package/esm2022/components/input-chip/input-chip.component.mjs +0 -101
  462. package/esm2022/components/input-chip/input-chip.directive.mjs +0 -138
  463. package/esm2022/components/input-chip/input-chip.mjs +0 -4
  464. package/esm2022/components/input-chip/input-chip.options.mjs +0 -7
  465. package/esm2022/components/input-chip/taiga-ui-kit-components-input-chip.mjs +0 -5
  466. package/esm2022/components/input-color/index.mjs +0 -3
  467. package/esm2022/components/input-color/input-color.component.mjs +0 -89
  468. package/esm2022/components/input-color/input-color.options.mjs +0 -6
  469. package/esm2022/components/input-color/taiga-ui-kit-components-input-color.mjs +0 -5
  470. package/esm2022/components/input-date/date-filler.mjs +0 -20
  471. package/esm2022/components/input-date/index.mjs +0 -6
  472. package/esm2022/components/input-date/input-date.component.mjs +0 -33
  473. package/esm2022/components/input-date/input-date.directive.mjs +0 -167
  474. package/esm2022/components/input-date/input-date.mjs +0 -9
  475. package/esm2022/components/input-date/input-date.options.mjs +0 -11
  476. package/esm2022/components/input-date/taiga-ui-kit-components-input-date.mjs +0 -5
  477. package/esm2022/components/input-date-multi/index.mjs +0 -3
  478. package/esm2022/components/input-date-multi/input-date-multi.directive.mjs +0 -123
  479. package/esm2022/components/input-date-multi/input-date-multi.mjs +0 -9
  480. package/esm2022/components/input-date-multi/taiga-ui-kit-components-input-date-multi.mjs +0 -5
  481. package/esm2022/components/input-date-range/index.mjs +0 -4
  482. package/esm2022/components/input-date-range/input-date-range.directive.mjs +0 -79
  483. package/esm2022/components/input-date-range/input-date-range.mjs +0 -4
  484. package/esm2022/components/input-date-range/input-date-range.options.mjs +0 -12
  485. package/esm2022/components/input-date-range/taiga-ui-kit-components-input-date-range.mjs +0 -5
  486. package/esm2022/components/input-date-time/index.mjs +0 -5
  487. package/esm2022/components/input-date-time/input-date-time.component.mjs +0 -35
  488. package/esm2022/components/input-date-time/input-date-time.directive.mjs +0 -178
  489. package/esm2022/components/input-date-time/input-date-time.mjs +0 -9
  490. package/esm2022/components/input-date-time/input-date-time.options.mjs +0 -20
  491. package/esm2022/components/input-date-time/taiga-ui-kit-components-input-date-time.mjs +0 -5
  492. package/esm2022/components/input-inline/index.mjs +0 -2
  493. package/esm2022/components/input-inline/input-inline.component.mjs +0 -23
  494. package/esm2022/components/input-inline/taiga-ui-kit-components-input-inline.mjs +0 -5
  495. package/esm2022/components/input-month/index.mjs +0 -5
  496. package/esm2022/components/input-month/input-month.component.mjs +0 -53
  497. package/esm2022/components/input-month/input-month.directive.mjs +0 -65
  498. package/esm2022/components/input-month/input-month.mjs +0 -9
  499. package/esm2022/components/input-month/input-month.options.mjs +0 -19
  500. package/esm2022/components/input-month/taiga-ui-kit-components-input-month.mjs +0 -5
  501. package/esm2022/components/input-month-range/index.mjs +0 -4
  502. package/esm2022/components/input-month-range/input-month-range.directive.mjs +0 -86
  503. package/esm2022/components/input-month-range/input-month-range.mjs +0 -7
  504. package/esm2022/components/input-month-range/input-month-range.options.mjs +0 -13
  505. package/esm2022/components/input-month-range/taiga-ui-kit-components-input-month-range.mjs +0 -5
  506. package/esm2022/components/input-number/index.mjs +0 -6
  507. package/esm2022/components/input-number/input-number.directive.mjs +0 -196
  508. package/esm2022/components/input-number/input-number.mjs +0 -9
  509. package/esm2022/components/input-number/input-number.options.mjs +0 -15
  510. package/esm2022/components/input-number/quantum.directive.mjs +0 -68
  511. package/esm2022/components/input-number/step/input-number-step.component.mjs +0 -58
  512. package/esm2022/components/input-number/taiga-ui-kit-components-input-number.mjs +0 -5
  513. package/esm2022/components/input-password/index.mjs +0 -3
  514. package/esm2022/components/input-password/input-password.component.mjs +0 -69
  515. package/esm2022/components/input-password/input-password.options.mjs +0 -24
  516. package/esm2022/components/input-password/taiga-ui-kit-components-input-password.mjs +0 -5
  517. package/esm2022/components/input-phone/index.mjs +0 -3
  518. package/esm2022/components/input-phone/input-phone.directive.mjs +0 -137
  519. package/esm2022/components/input-phone/input-phone.options.mjs +0 -9
  520. package/esm2022/components/input-phone/taiga-ui-kit-components-input-phone.mjs +0 -5
  521. package/esm2022/components/input-phone/utils/complete-phone-insertion-preprocessor.mjs +0 -41
  522. package/esm2022/components/input-phone/utils/create-phone-mask-expression.mjs +0 -17
  523. package/esm2022/components/input-phone-international/index.mjs +0 -3
  524. package/esm2022/components/input-phone-international/input-phone-international.component.mjs +0 -210
  525. package/esm2022/components/input-phone-international/input-phone-international.options.mjs +0 -19
  526. package/esm2022/components/input-phone-international/taiga-ui-kit-components-input-phone-international.mjs +0 -5
  527. package/esm2022/components/input-pin/index.mjs +0 -2
  528. package/esm2022/components/input-pin/input-pin.component.mjs +0 -65
  529. package/esm2022/components/input-pin/taiga-ui-kit-components-input-pin.mjs +0 -5
  530. package/esm2022/components/input-range/index.mjs +0 -3
  531. package/esm2022/components/input-range/input-range.component.mjs +0 -166
  532. package/esm2022/components/input-range/input-range.mjs +0 -4
  533. package/esm2022/components/input-range/taiga-ui-kit-components-input-range.mjs +0 -5
  534. package/esm2022/components/input-slider/index.mjs +0 -3
  535. package/esm2022/components/input-slider/input-slider.directive.mjs +0 -114
  536. package/esm2022/components/input-slider/input-slider.mjs +0 -9
  537. package/esm2022/components/input-slider/taiga-ui-kit-components-input-slider.mjs +0 -5
  538. package/esm2022/components/input-time/index.mjs +0 -5
  539. package/esm2022/components/input-time/input-time.component.mjs +0 -64
  540. package/esm2022/components/input-time/input-time.directive.mjs +0 -159
  541. package/esm2022/components/input-time/input-time.mjs +0 -4
  542. package/esm2022/components/input-time/input-time.options.mjs +0 -10
  543. package/esm2022/components/input-time/taiga-ui-kit-components-input-time.mjs +0 -5
  544. package/esm2022/components/input-year/index.mjs +0 -4
  545. package/esm2022/components/input-year/input-year.directive.mjs +0 -103
  546. package/esm2022/components/input-year/input-year.mjs +0 -4
  547. package/esm2022/components/input-year/input-year.options.mjs +0 -12
  548. package/esm2022/components/input-year/taiga-ui-kit-components-input-year.mjs +0 -5
  549. package/esm2022/components/items-with-more/index.mjs +0 -6
  550. package/esm2022/components/items-with-more/items-with-more.component.mjs +0 -77
  551. package/esm2022/components/items-with-more/items-with-more.directive.mjs +0 -46
  552. package/esm2022/components/items-with-more/items-with-more.mjs +0 -11
  553. package/esm2022/components/items-with-more/items-with-more.service.mjs +0 -85
  554. package/esm2022/components/items-with-more/more.directive.mjs +0 -18
  555. package/esm2022/components/items-with-more/taiga-ui-kit-components-items-with-more.mjs +0 -5
  556. package/esm2022/components/like/index.mjs +0 -3
  557. package/esm2022/components/like/like.component.mjs +0 -46
  558. package/esm2022/components/like/like.options.mjs +0 -10
  559. package/esm2022/components/like/taiga-ui-kit-components-like.mjs +0 -5
  560. package/esm2022/components/line-clamp/index.mjs +0 -4
  561. package/esm2022/components/line-clamp/line-clamp-box.component.mjs +0 -25
  562. package/esm2022/components/line-clamp/line-clamp-position.directive.mjs +0 -27
  563. package/esm2022/components/line-clamp/line-clamp.component.mjs +0 -95
  564. package/esm2022/components/line-clamp/line-clamp.options.mjs +0 -15
  565. package/esm2022/components/line-clamp/taiga-ui-kit-components-line-clamp.mjs +0 -5
  566. package/esm2022/components/message/index.mjs +0 -2
  567. package/esm2022/components/message/message.directive.mjs +0 -43
  568. package/esm2022/components/message/taiga-ui-kit-components-message.mjs +0 -5
  569. package/esm2022/components/multi-select/index.mjs +0 -6
  570. package/esm2022/components/multi-select/multi-select-group/multi-select-group.component.mjs +0 -50
  571. package/esm2022/components/multi-select/multi-select-group/multi-select-group.directive.mjs +0 -18
  572. package/esm2022/components/multi-select/multi-select-native/multi-select-native.component.mjs +0 -56
  573. package/esm2022/components/multi-select/multi-select-option/multi-select-option.component.mjs +0 -47
  574. package/esm2022/components/multi-select/multi-select.mjs +0 -9
  575. package/esm2022/components/multi-select/taiga-ui-kit-components-multi-select.mjs +0 -5
  576. package/esm2022/components/pager/index.mjs +0 -2
  577. package/esm2022/components/pager/pager.component.mjs +0 -97
  578. package/esm2022/components/pager/taiga-ui-kit-components-pager.mjs +0 -5
  579. package/esm2022/components/pagination/index.mjs +0 -2
  580. package/esm2022/components/pagination/pagination.component.mjs +0 -213
  581. package/esm2022/components/pagination/taiga-ui-kit-components-pagination.mjs +0 -5
  582. package/esm2022/components/pdf-viewer/index.mjs +0 -5
  583. package/esm2022/components/pdf-viewer/pdf-viewer.component.mjs +0 -28
  584. package/esm2022/components/pdf-viewer/pdf-viewer.directive.mjs +0 -21
  585. package/esm2022/components/pdf-viewer/pdf-viewer.options.mjs +0 -17
  586. package/esm2022/components/pdf-viewer/pdf-viewer.service.mjs +0 -22
  587. package/esm2022/components/pdf-viewer/taiga-ui-kit-components-pdf-viewer.mjs +0 -5
  588. package/esm2022/components/pin/index.mjs +0 -2
  589. package/esm2022/components/pin/pin.directive.mjs +0 -35
  590. package/esm2022/components/pin/taiga-ui-kit-components-pin.mjs +0 -5
  591. package/esm2022/components/preview/action/preview-action.directive.mjs +0 -30
  592. package/esm2022/components/preview/dialog/index.mjs +0 -4
  593. package/esm2022/components/preview/dialog/preview-dialog.component.mjs +0 -28
  594. package/esm2022/components/preview/dialog/preview-dialog.directive.mjs +0 -21
  595. package/esm2022/components/preview/dialog/preview-dialog.service.mjs +0 -18
  596. package/esm2022/components/preview/dialog/taiga-ui-kit-components-preview-dialog.mjs +0 -5
  597. package/esm2022/components/preview/index.mjs +0 -8
  598. package/esm2022/components/preview/pagination/preview-pagination.component.mjs +0 -49
  599. package/esm2022/components/preview/preview.component.mjs +0 -142
  600. package/esm2022/components/preview/preview.mjs +0 -13
  601. package/esm2022/components/preview/taiga-ui-kit-components-preview.mjs +0 -5
  602. package/esm2022/components/preview/title/preview-title.component.mjs +0 -16
  603. package/esm2022/components/preview/zoom/preview-zoom.component.mjs +0 -81
  604. package/esm2022/components/progress/index.mjs +0 -9
  605. package/esm2022/components/progress/progress-bar/fixed-gradient/progress-fixed-gradient.directive.mjs +0 -39
  606. package/esm2022/components/progress/progress-bar/progress-bar.component.mjs +0 -25
  607. package/esm2022/components/progress/progress-bar/progress-color-segments.directive.mjs +0 -40
  608. package/esm2022/components/progress/progress-circle/progress-circle.component.mjs +0 -45
  609. package/esm2022/components/progress/progress-label/progress-label.component.mjs +0 -12
  610. package/esm2022/components/progress/progress-segmented/progress-segmented.directive.mjs +0 -34
  611. package/esm2022/components/progress/progress.mjs +0 -15
  612. package/esm2022/components/progress/progress.options.mjs +0 -13
  613. package/esm2022/components/progress/taiga-ui-kit-components-progress.mjs +0 -5
  614. package/esm2022/components/pulse/index.mjs +0 -2
  615. package/esm2022/components/pulse/pulse.component.mjs +0 -34
  616. package/esm2022/components/pulse/taiga-ui-kit-components-pulse.mjs +0 -5
  617. package/esm2022/components/push/index.mjs +0 -7
  618. package/esm2022/components/push/push-alert.component.mjs +0 -29
  619. package/esm2022/components/push/push.component.mjs +0 -39
  620. package/esm2022/components/push/push.directive.mjs +0 -33
  621. package/esm2022/components/push/push.mjs +0 -5
  622. package/esm2022/components/push/push.options.mjs +0 -21
  623. package/esm2022/components/push/push.service.mjs +0 -19
  624. package/esm2022/components/push/taiga-ui-kit-components-push.mjs +0 -5
  625. package/esm2022/components/radio/index.mjs +0 -5
  626. package/esm2022/components/radio/radio.component.mjs +0 -53
  627. package/esm2022/components/radio/radio.directive.mjs +0 -32
  628. package/esm2022/components/radio/radio.mjs +0 -4
  629. package/esm2022/components/radio/radio.options.mjs +0 -13
  630. package/esm2022/components/radio/taiga-ui-kit-components-radio.mjs +0 -5
  631. package/esm2022/components/radio-list/index.mjs +0 -2
  632. package/esm2022/components/radio-list/radio-list.component.mjs +0 -64
  633. package/esm2022/components/radio-list/taiga-ui-kit-components-radio-list.mjs +0 -5
  634. package/esm2022/components/range/index.mjs +0 -3
  635. package/esm2022/components/range/range-change.directive.mjs +0 -78
  636. package/esm2022/components/range/range.component.mjs +0 -164
  637. package/esm2022/components/range/taiga-ui-kit-components-range.mjs +0 -5
  638. package/esm2022/components/rating/index.mjs +0 -3
  639. package/esm2022/components/rating/rating.component.mjs +0 -65
  640. package/esm2022/components/rating/rating.options.mjs +0 -13
  641. package/esm2022/components/rating/taiga-ui-kit-components-rating.mjs +0 -5
  642. package/esm2022/components/routable-dialog/generate-dialogable-route.mjs +0 -17
  643. package/esm2022/components/routable-dialog/index.mjs +0 -3
  644. package/esm2022/components/routable-dialog/routable-dialog.component.mjs +0 -53
  645. package/esm2022/components/routable-dialog/taiga-ui-kit-components-routable-dialog.mjs +0 -5
  646. package/esm2022/components/segmented/index.mjs +0 -3
  647. package/esm2022/components/segmented/segmented.component.mjs +0 -67
  648. package/esm2022/components/segmented/segmented.directive.mjs +0 -65
  649. package/esm2022/components/segmented/taiga-ui-kit-components-segmented.mjs +0 -5
  650. package/esm2022/components/select/index.mjs +0 -5
  651. package/esm2022/components/select/native-select/native-select.component.mjs +0 -57
  652. package/esm2022/components/select/select-option/select-option.component.mjs +0 -51
  653. package/esm2022/components/select/select.directive.mjs +0 -56
  654. package/esm2022/components/select/select.mjs +0 -4
  655. package/esm2022/components/select/taiga-ui-kit-components-select.mjs +0 -5
  656. package/esm2022/components/slider/helpers/key-steps.mjs +0 -36
  657. package/esm2022/components/slider/helpers/slider-key-steps.directive.mjs +0 -110
  658. package/esm2022/components/slider/helpers/slider-readonly.directive.mjs +0 -75
  659. package/esm2022/components/slider/helpers/slider-thumb-label.component.mjs +0 -38
  660. package/esm2022/components/slider/index.mjs +0 -8
  661. package/esm2022/components/slider/slider.component.mjs +0 -124
  662. package/esm2022/components/slider/slider.mjs +0 -12
  663. package/esm2022/components/slider/slider.options.mjs +0 -16
  664. package/esm2022/components/slider/taiga-ui-kit-components-slider.mjs +0 -5
  665. package/esm2022/components/slides/index.mjs +0 -2
  666. package/esm2022/components/slides/slides.directive.mjs +0 -51
  667. package/esm2022/components/slides/taiga-ui-kit-components-slides.mjs +0 -5
  668. package/esm2022/components/status/index.mjs +0 -2
  669. package/esm2022/components/status/status.directive.mjs +0 -35
  670. package/esm2022/components/status/taiga-ui-kit-components-status.mjs +0 -5
  671. package/esm2022/components/stepper/index.mjs +0 -4
  672. package/esm2022/components/stepper/step.component.mjs +0 -58
  673. package/esm2022/components/stepper/stepper.component.mjs +0 -118
  674. package/esm2022/components/stepper/stepper.mjs +0 -4
  675. package/esm2022/components/stepper/taiga-ui-kit-components-stepper.mjs +0 -5
  676. package/esm2022/components/switch/index.mjs +0 -3
  677. package/esm2022/components/switch/switch.component.mjs +0 -63
  678. package/esm2022/components/switch/switch.options.mjs +0 -15
  679. package/esm2022/components/switch/taiga-ui-kit-components-switch.mjs +0 -5
  680. package/esm2022/components/tabs/index.mjs +0 -9
  681. package/esm2022/components/tabs/tab.directive.mjs +0 -47
  682. package/esm2022/components/tabs/tabs-horizontal.directive.mjs +0 -108
  683. package/esm2022/components/tabs/tabs-vertical.directive.mjs +0 -38
  684. package/esm2022/components/tabs/tabs-with-more.component.mjs +0 -211
  685. package/esm2022/components/tabs/tabs.directive.mjs +0 -79
  686. package/esm2022/components/tabs/tabs.mjs +0 -15
  687. package/esm2022/components/tabs/tabs.options.mjs +0 -19
  688. package/esm2022/components/tabs/tabs.providers.mjs +0 -35
  689. package/esm2022/components/tabs/taiga-ui-kit-components-tabs.mjs +0 -5
  690. package/esm2022/components/taiga-ui-kit-components.mjs +0 -5
  691. package/esm2022/components/textarea/index.mjs +0 -4
  692. package/esm2022/components/textarea/taiga-ui-kit-components-textarea.mjs +0 -5
  693. package/esm2022/components/textarea/textarea-limit.directive.mjs +0 -94
  694. package/esm2022/components/textarea/textarea.component.mjs +0 -58
  695. package/esm2022/components/textarea/textarea.options.mjs +0 -7
  696. package/esm2022/components/tiles/index.mjs +0 -7
  697. package/esm2022/components/tiles/taiga-ui-kit-components-tiles.mjs +0 -5
  698. package/esm2022/components/tiles/tile-handle.directive.mjs +0 -60
  699. package/esm2022/components/tiles/tile.component.mjs +0 -69
  700. package/esm2022/components/tiles/tile.service.mjs +0 -90
  701. package/esm2022/components/tiles/tiles.component.mjs +0 -70
  702. package/esm2022/components/tiles/tiles.mjs +0 -5
  703. package/esm2022/components/tiles/tiles.tokens.mjs +0 -37
  704. package/esm2022/components/tree/components/tree/tree.component.mjs +0 -64
  705. package/esm2022/components/tree/components/tree-item/tree-item.component.mjs +0 -63
  706. package/esm2022/components/tree/components/tree-item-content/tree-item-content.component.mjs +0 -44
  707. package/esm2022/components/tree/directives/tree-children.directive.mjs +0 -24
  708. package/esm2022/components/tree/directives/tree-controller.directive.mjs +0 -57
  709. package/esm2022/components/tree/directives/tree-item-controller.directive.mjs +0 -32
  710. package/esm2022/components/tree/directives/tree-node.directive.mjs +0 -32
  711. package/esm2022/components/tree/index.mjs +0 -12
  712. package/esm2022/components/tree/misc/tree.constants.mjs +0 -9
  713. package/esm2022/components/tree/misc/tree.interfaces.mjs +0 -2
  714. package/esm2022/components/tree/misc/tree.service.mjs +0 -31
  715. package/esm2022/components/tree/misc/tree.tokens.mjs +0 -43
  716. package/esm2022/components/tree/taiga-ui-kit-components-tree.mjs +0 -5
  717. package/esm2022/components/tree/tree.mjs +0 -17
  718. package/esm2022/directives/button-close/button-close.directive.mjs +0 -33
  719. package/esm2022/directives/button-close/index.mjs +0 -2
  720. package/esm2022/directives/button-close/taiga-ui-kit-directives-button-close.mjs +0 -5
  721. package/esm2022/directives/button-group/button-group.directive.mjs +0 -29
  722. package/esm2022/directives/button-group/index.mjs +0 -2
  723. package/esm2022/directives/button-group/taiga-ui-kit-directives-button-group.mjs +0 -5
  724. package/esm2022/directives/button-select/button-select.directive.mjs +0 -48
  725. package/esm2022/directives/button-select/index.mjs +0 -2
  726. package/esm2022/directives/button-select/taiga-ui-kit-directives-button-select.mjs +0 -5
  727. package/esm2022/directives/chevron/chevron.directive.mjs +0 -45
  728. package/esm2022/directives/chevron/index.mjs +0 -2
  729. package/esm2022/directives/chevron/taiga-ui-kit-directives-chevron.mjs +0 -5
  730. package/esm2022/directives/connected/connected.directive.mjs +0 -32
  731. package/esm2022/directives/connected/index.mjs +0 -2
  732. package/esm2022/directives/connected/taiga-ui-kit-directives-connected.mjs +0 -5
  733. package/esm2022/directives/copy/copy.component.mjs +0 -48
  734. package/esm2022/directives/copy/copy.directive.mjs +0 -71
  735. package/esm2022/directives/copy/copy.mjs +0 -4
  736. package/esm2022/directives/copy/copy.options.mjs +0 -3
  737. package/esm2022/directives/copy/index.mjs +0 -6
  738. package/esm2022/directives/copy/taiga-ui-kit-directives-copy.mjs +0 -5
  739. package/esm2022/directives/data-list-dropdown-manager/data-list-dropdown-manager.directive.mjs +0 -105
  740. package/esm2022/directives/data-list-dropdown-manager/index.mjs +0 -2
  741. package/esm2022/directives/data-list-dropdown-manager/taiga-ui-kit-directives-data-list-dropdown-manager.mjs +0 -5
  742. package/esm2022/directives/fade/fade.directive.mjs +0 -92
  743. package/esm2022/directives/fade/index.mjs +0 -2
  744. package/esm2022/directives/fade/taiga-ui-kit-directives-fade.mjs +0 -5
  745. package/esm2022/directives/fluid-typography/fluid-typography.directive.mjs +0 -63
  746. package/esm2022/directives/fluid-typography/fluid-typography.options.mjs +0 -13
  747. package/esm2022/directives/fluid-typography/index.mjs +0 -3
  748. package/esm2022/directives/fluid-typography/taiga-ui-kit-directives-fluid-typography.mjs +0 -5
  749. package/esm2022/directives/highlight/highlight.directive.mjs +0 -92
  750. package/esm2022/directives/highlight/index.mjs +0 -2
  751. package/esm2022/directives/highlight/taiga-ui-kit-directives-highlight.mjs +0 -5
  752. package/esm2022/directives/icon-badge/icon-badge.directive.mjs +0 -41
  753. package/esm2022/directives/icon-badge/index.mjs +0 -2
  754. package/esm2022/directives/icon-badge/taiga-ui-kit-directives-icon-badge.mjs +0 -5
  755. package/esm2022/directives/index.mjs +0 -21
  756. package/esm2022/directives/lazy-loading/index.mjs +0 -3
  757. package/esm2022/directives/lazy-loading/lazy-loading.directive.mjs +0 -58
  758. package/esm2022/directives/lazy-loading/lazy-loading.service.mjs +0 -23
  759. package/esm2022/directives/lazy-loading/taiga-ui-kit-directives-lazy-loading.mjs +0 -5
  760. package/esm2022/directives/password/index.mjs +0 -3
  761. package/esm2022/directives/password/password.directive.mjs +0 -67
  762. package/esm2022/directives/password/password.options.mjs +0 -8
  763. package/esm2022/directives/password/taiga-ui-kit-directives-password.mjs +0 -5
  764. package/esm2022/directives/present/index.mjs +0 -2
  765. package/esm2022/directives/present/present.directive.mjs +0 -33
  766. package/esm2022/directives/present/taiga-ui-kit-directives-present.mjs +0 -5
  767. package/esm2022/directives/sensitive/index.mjs +0 -2
  768. package/esm2022/directives/sensitive/sensitive.directive.mjs +0 -48
  769. package/esm2022/directives/sensitive/taiga-ui-kit-directives-sensitive.mjs +0 -5
  770. package/esm2022/directives/shimmer/index.mjs +0 -2
  771. package/esm2022/directives/shimmer/shimmer.directive.mjs +0 -68
  772. package/esm2022/directives/shimmer/taiga-ui-kit-directives-shimmer.mjs +0 -5
  773. package/esm2022/directives/skeleton/index.mjs +0 -2
  774. package/esm2022/directives/skeleton/skeleton.directive.mjs +0 -69
  775. package/esm2022/directives/skeleton/taiga-ui-kit-directives-skeleton.mjs +0 -5
  776. package/esm2022/directives/taiga-ui-kit-directives.mjs +0 -5
  777. package/esm2022/directives/tooltip/index.mjs +0 -3
  778. package/esm2022/directives/tooltip/taiga-ui-kit-directives-tooltip.mjs +0 -5
  779. package/esm2022/directives/tooltip/tooltip.directive.mjs +0 -92
  780. package/esm2022/directives/tooltip/tooltip.options.mjs +0 -6
  781. package/esm2022/directives/unfinished-validator/index.mjs +0 -3
  782. package/esm2022/directives/unfinished-validator/taiga-ui-kit-directives-unfinished-validator.mjs +0 -5
  783. package/esm2022/directives/unfinished-validator/unfinished-validator.directive.mjs +0 -36
  784. package/esm2022/directives/unfinished-validator/unfinished.validator.mjs +0 -7
  785. package/esm2022/directives/unmask-handler/index.mjs +0 -2
  786. package/esm2022/directives/unmask-handler/taiga-ui-kit-directives-unmask-handler.mjs +0 -5
  787. package/esm2022/directives/unmask-handler/unmask-handler.directive.mjs +0 -35
  788. package/esm2022/index.mjs +0 -6
  789. package/esm2022/pipes/emails/emails.options.mjs +0 -13
  790. package/esm2022/pipes/emails/emails.pipe.mjs +0 -26
  791. package/esm2022/pipes/emails/index.mjs +0 -3
  792. package/esm2022/pipes/emails/taiga-ui-kit-pipes-emails.mjs +0 -5
  793. package/esm2022/pipes/field-error/field-error-content-pipe.mjs +0 -42
  794. package/esm2022/pipes/field-error/field-error-pipe.mjs +0 -103
  795. package/esm2022/pipes/field-error/index.mjs +0 -3
  796. package/esm2022/pipes/field-error/taiga-ui-kit-pipes-field-error.mjs +0 -5
  797. package/esm2022/pipes/filter-by-input/filter-by-input.pipe.mjs +0 -68
  798. package/esm2022/pipes/filter-by-input/index.mjs +0 -2
  799. package/esm2022/pipes/filter-by-input/taiga-ui-kit-pipes-filter-by-input.mjs +0 -5
  800. package/esm2022/pipes/hide-selected/hide-selected.pipe.mjs +0 -46
  801. package/esm2022/pipes/hide-selected/index.mjs +0 -2
  802. package/esm2022/pipes/hide-selected/taiga-ui-kit-pipes-hide-selected.mjs +0 -5
  803. package/esm2022/pipes/index.mjs +0 -8
  804. package/esm2022/pipes/sort-countries/index.mjs +0 -2
  805. package/esm2022/pipes/sort-countries/sort-countries.pipe.mjs +0 -23
  806. package/esm2022/pipes/sort-countries/taiga-ui-kit-pipes-sort-countries.mjs +0 -5
  807. package/esm2022/pipes/stringify/index.mjs +0 -2
  808. package/esm2022/pipes/stringify/stringify.pipe.mjs +0 -18
  809. package/esm2022/pipes/stringify/taiga-ui-kit-pipes-stringify.mjs +0 -5
  810. package/esm2022/pipes/stringify-content/index.mjs +0 -2
  811. package/esm2022/pipes/stringify-content/stringify-content.pipe.mjs +0 -18
  812. package/esm2022/pipes/stringify-content/taiga-ui-kit-pipes-stringify-content.mjs +0 -5
  813. package/esm2022/pipes/taiga-ui-kit-pipes.mjs +0 -5
  814. package/esm2022/taiga-ui-kit.mjs +0 -5
  815. package/esm2022/tokens/calendar-date-stream.mjs +0 -25
  816. package/esm2022/tokens/date-inputs-value-transformers.mjs +0 -21
  817. package/esm2022/tokens/i18n.mjs +0 -75
  818. package/esm2022/tokens/index.mjs +0 -10
  819. package/esm2022/tokens/input-date-options.mjs +0 -13
  820. package/esm2022/tokens/items-handlers.mjs +0 -27
  821. package/esm2022/tokens/mobile-calendar.mjs +0 -13
  822. package/esm2022/tokens/month-formatter.mjs +0 -12
  823. package/esm2022/tokens/preview-icons.mjs +0 -17
  824. package/esm2022/tokens/taiga-ui-kit-tokens.mjs +0 -5
  825. package/esm2022/tokens/validation-errors.mjs +0 -6
  826. package/esm2022/utils/create-time-periods.mjs +0 -12
  827. package/esm2022/utils/index.mjs +0 -7
  828. package/esm2022/utils/inject-value.mjs +0 -11
  829. package/esm2022/utils/is-flat.mjs +0 -4
  830. package/esm2022/utils/maskito.binding.mjs +0 -6
  831. package/esm2022/utils/phone.mjs +0 -6
  832. package/esm2022/utils/taiga-ui-kit-utils.mjs +0 -5
  833. package/esm2022/utils/toggle-day.mjs +0 -6
  834. package/fesm2022/taiga-ui-kit-components-input-password.mjs +0 -96
  835. package/fesm2022/taiga-ui-kit-components-input-password.mjs.map +0 -1
  836. package/fesm2022/taiga-ui-kit-components-pdf-viewer.mjs +0 -83
  837. package/fesm2022/taiga-ui-kit-components-pdf-viewer.mjs.map +0 -1
  838. package/fesm2022/taiga-ui-kit-directives-copy.mjs +0 -120
  839. package/fesm2022/taiga-ui-kit-directives-copy.mjs.map +0 -1
  840. package/fesm2022/taiga-ui-kit-directives-icon-badge.mjs +0 -47
  841. package/fesm2022/taiga-ui-kit-directives-icon-badge.mjs.map +0 -1
  842. package/fesm2022/taiga-ui-kit-pipes-field-error.mjs +0 -147
  843. package/fesm2022/taiga-ui-kit-pipes-field-error.mjs.map +0 -1
  844. package/pipes/field-error/field-error-content-pipe.d.ts +0 -14
  845. package/pipes/field-error/field-error-pipe.d.ts +0 -29
  846. package/pipes/field-error/index.d.ts +0 -2
  847. package/tokens/validation-errors.d.ts +0 -5
  848. /package/{directives → components}/copy/copy.d.ts +0 -0
  849. /package/{directives → components}/copy/index.d.ts +0 -0
@@ -1,34 +1,33 @@
1
1
  import * as i0 from '@angular/core';
2
- import { signal, inject, computed, Component, ChangeDetectionStrategy, Input, ContentChildren, Directive } from '@angular/core';
3
- import { toSignal } from '@angular/core/rxjs-interop';
2
+ import { inject, signal, computed, ContentChildren, Input, ChangeDetectionStrategy, Component, Directive } from '@angular/core';
4
3
  import { NgControl } from '@angular/forms';
5
4
  import { tuiIsPresent } from '@taiga-ui/cdk/utils/miscellaneous';
6
- import { TuiOptionWithValue, tuiAsOptionContent } from '@taiga-ui/core/components/data-list';
5
+ import * as i3 from '@taiga-ui/core/components/data-list';
6
+ import { TuiOptionWithValue, tuiAsOptionContent, TuiDataList } from '@taiga-ui/core/components/data-list';
7
7
  import { TuiLink } from '@taiga-ui/core/components/link';
8
8
  import * as i2 from '@taiga-ui/core/components/textfield';
9
- import { TuiTextfieldComponent, TUI_TEXTFIELD_OPTIONS, TuiTextfield, TuiSelectLike } from '@taiga-ui/core/components/textfield';
9
+ import { TuiTextfieldComponent, TUI_TEXTFIELD_OPTIONS, TuiSelectLike, TuiTextfield } from '@taiga-ui/core/components/textfield';
10
10
  import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives/items-handlers';
11
11
  import { TUI_MULTI_SELECT_TEXTS } from '@taiga-ui/kit/tokens';
12
12
  import { tuiInjectValue, tuiIsFlat } from '@taiga-ui/kit/utils';
13
- import { NgIf, NgForOf, NgTemplateOutlet } from '@angular/common';
14
13
  import { TuiCheckbox } from '@taiga-ui/kit/components/checkbox';
14
+ import { NgTemplateOutlet } from '@angular/common';
15
15
  import { TuiControl } from '@taiga-ui/cdk/classes';
16
16
  import { TUI_IS_IOS, TUI_IS_ANDROID } from '@taiga-ui/cdk/tokens';
17
17
  import { tuiInjectElement, tuiIsPresent as tuiIsPresent$1 } from '@taiga-ui/cdk/utils';
18
- import * as i3 from '@taiga-ui/kit/components/data-list-wrapper';
19
- import { TuiDataListWrapper } from '@taiga-ui/kit/components/data-list-wrapper';
20
18
  import * as i1 from '@taiga-ui/kit/components/input-chip';
21
19
  import { TuiInputChipDirective } from '@taiga-ui/kit/components/input-chip';
20
+ import * as i4 from '@taiga-ui/core/directives/dropdown';
22
21
 
23
22
  class TuiMultiSelectGroupComponent {
24
23
  constructor() {
25
- this.values = signal([]);
26
24
  this.handlers = inject(TUI_ITEMS_HANDLERS);
27
25
  this.control = inject(TuiTextfieldComponent, { optional: true })?.control ||
28
26
  inject(NgControl, { optional: true });
29
- this.texts = toSignal(inject(TUI_MULTI_SELECT_TEXTS));
27
+ this.values = signal([]);
28
+ this.texts = inject(TUI_MULTI_SELECT_TEXTS);
30
29
  this.value = tuiInjectValue();
31
- this.checked = computed(() => this.values().every((item) => this.value().some((value) => this.handlers.identityMatcher()(item, value))));
30
+ this.checked = computed(() => this.values().every((item) => this.value()?.some((value) => this.handlers.identityMatcher()(item, value))));
32
31
  this.label = '';
33
32
  }
34
33
  set options(options) {
@@ -40,17 +39,18 @@ class TuiMultiSelectGroupComponent {
40
39
  toggle() {
41
40
  const values = this.values();
42
41
  const matcher = this.handlers.identityMatcher();
43
- const others = this.value().filter((current) => values.every((item) => !matcher(current, item)));
42
+ const value = this.value() || [];
43
+ const others = value.filter((a) => values.every((b) => !matcher(a, b)));
44
44
  this.control?.control?.setValue(this.checked() ? others : others.concat(values));
45
45
  }
46
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
47
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiMultiSelectGroupComponent, isStandalone: true, selector: "tui-opt-group[tuiMultiSelectGroup]", inputs: { label: "label" }, host: { properties: { "class._label": "label" } }, queries: [{ propertyName: "options", predicate: TuiOptionWithValue }], ngImport: i0, template: "<span class=\"t-wrapper\">\n <span class=\"t-label\">{{ label }}</span>\n <button\n tuiLink\n type=\"button\"\n class=\"t-button\"\n (click)=\"toggle()\"\n >\n {{ texts()?.[checked() ? 'none' : 'all'] }}\n </button>\n</span>\n<ng-content />\n", styles: [":host._label:before{display:none}:host:not(:first-of-type) .t-label:not(:empty){padding-block-start:1.25rem}:host:not(:first-of-type) .t-button{margin-block-start:1.25rem}.t-wrapper{display:flex;align-items:flex-start}.t-wrapper:last-child{display:none}.t-label:not(:empty){flex:1;padding:.75rem 1rem .25rem .625rem}.t-button{margin:.75rem 1rem 0 auto;font-weight:400}\n"], dependencies: [{ kind: "directive", type: TuiLink, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
46
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiMultiSelectGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
47
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.15", type: TuiMultiSelectGroupComponent, isStandalone: true, selector: "tui-opt-group[tuiMultiSelectGroup]", inputs: { label: "label" }, host: { properties: { "class._label": "label" } }, queries: [{ propertyName: "options", predicate: TuiOptionWithValue }], ngImport: i0, template: "@if (values().length) {\n <span class=\"t-wrapper\">\n <span class=\"t-label\">{{ label }}</span>\n <button\n tuiLink\n type=\"button\"\n class=\"t-button\"\n (click)=\"toggle()\"\n >\n {{ texts()[checked() ? 'none' : 'all'] }}\n </button>\n </span>\n}\n<ng-content />\n", styles: [":host._label:before{display:none}:host:not(:first-of-type) .t-label:not(:empty){padding-block-start:1.25rem}:host:not(:first-of-type) .t-button{margin-block-start:1.25rem}.t-wrapper{display:flex;align-items:flex-start}.t-wrapper:last-child{display:none}.t-label:not(:empty){flex:1;padding:.75rem 1rem .25rem .625rem}:host-context(tui-sheet-dialog) .t-label:not(:empty){font:var(--tui-font-heading-6);padding:.5rem 0}.t-button{margin:.75rem 1rem 0 auto;font-weight:400}:host-context(tui-sheet-dialog) .t-button{margin-inline-end:0}\n"], dependencies: [{ kind: "directive", type: TuiLink, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
48
48
  }
49
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectGroupComponent, decorators: [{
49
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiMultiSelectGroupComponent, decorators: [{
50
50
  type: Component,
51
51
  args: [{ standalone: true, selector: 'tui-opt-group[tuiMultiSelectGroup]', imports: [TuiLink], changeDetection: ChangeDetectionStrategy.OnPush, host: {
52
52
  '[class._label]': 'label',
53
- }, template: "<span class=\"t-wrapper\">\n <span class=\"t-label\">{{ label }}</span>\n <button\n tuiLink\n type=\"button\"\n class=\"t-button\"\n (click)=\"toggle()\"\n >\n {{ texts()?.[checked() ? 'none' : 'all'] }}\n </button>\n</span>\n<ng-content />\n", styles: [":host._label:before{display:none}:host:not(:first-of-type) .t-label:not(:empty){padding-block-start:1.25rem}:host:not(:first-of-type) .t-button{margin-block-start:1.25rem}.t-wrapper{display:flex;align-items:flex-start}.t-wrapper:last-child{display:none}.t-label:not(:empty){flex:1;padding:.75rem 1rem .25rem .625rem}.t-button{margin:.75rem 1rem 0 auto;font-weight:400}\n"] }]
53
+ }, template: "@if (values().length) {\n <span class=\"t-wrapper\">\n <span class=\"t-label\">{{ label }}</span>\n <button\n tuiLink\n type=\"button\"\n class=\"t-button\"\n (click)=\"toggle()\"\n >\n {{ texts()[checked() ? 'none' : 'all'] }}\n </button>\n </span>\n}\n<ng-content />\n", styles: [":host._label:before{display:none}:host:not(:first-of-type) .t-label:not(:empty){padding-block-start:1.25rem}:host:not(:first-of-type) .t-button{margin-block-start:1.25rem}.t-wrapper{display:flex;align-items:flex-start}.t-wrapper:last-child{display:none}.t-label:not(:empty){flex:1;padding:.75rem 1rem .25rem .625rem}:host-context(tui-sheet-dialog) .t-label:not(:empty){font:var(--tui-font-heading-6);padding:.5rem 0}.t-button{margin:.75rem 1rem 0 auto;font-weight:400}:host-context(tui-sheet-dialog) .t-button{margin-inline-end:0}\n"] }]
54
54
  }], propDecorators: { label: [{
55
55
  type: Input
56
56
  }], options: [{
@@ -71,38 +71,39 @@ class TuiMultiSelectOption {
71
71
  controlValue.some((item) => this.handlers?.identityMatcher()(item, optionValue) ??
72
72
  item === optionValue));
73
73
  }
74
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectOption, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
75
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiMultiSelectOption, isStandalone: true, selector: "ng-component", ngImport: i0, template: `
76
- <input
77
- *ngIf="option"
78
- tuiCheckbox
79
- type="checkbox"
80
- [checked]="selected()"
81
- [size]="size() === 'l' ? 'm' : 's'"
82
- />
83
- `, isInline: true, styles: [":host-context(tui-dropdown-mobile) input{order:100;margin-inline-start:auto}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiCheckbox, selector: "input[type=\"checkbox\"][tuiCheckbox]", inputs: ["size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
74
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiMultiSelectOption, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.15", type: TuiMultiSelectOption, isStandalone: true, selector: "ng-component", ngImport: i0, template: `
76
+ @if (option) {
77
+ <input
78
+ tuiCheckbox
79
+ type="checkbox"
80
+ [checked]="selected()"
81
+ [size]="size() === 'l' ? 'm' : 's'"
82
+ />
83
+ }
84
+ `, isInline: true, styles: [":host-context(tui-dropdown-mobile) input,:host-context(tui-sheet-dialog) input{order:100;margin-inline-start:auto}\n"], dependencies: [{ kind: "component", type: TuiCheckbox, selector: "input[type=\"checkbox\"][tuiCheckbox]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
84
85
  }
85
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectOption, decorators: [{
86
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiMultiSelectOption, decorators: [{
86
87
  type: Component,
87
- args: [{ standalone: true, imports: [NgIf, TuiCheckbox], template: `
88
- <input
89
- *ngIf="option"
90
- tuiCheckbox
91
- type="checkbox"
92
- [checked]="selected()"
93
- [size]="size() === 'l' ? 'm' : 's'"
94
- />
95
- `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host-context(tui-dropdown-mobile) input{order:100;margin-inline-start:auto}\n"] }]
88
+ args: [{ imports: [TuiCheckbox], template: `
89
+ @if (option) {
90
+ <input
91
+ tuiCheckbox
92
+ type="checkbox"
93
+ [checked]="selected()"
94
+ [size]="size() === 'l' ? 'm' : 's'"
95
+ />
96
+ }
97
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host-context(tui-dropdown-mobile) input,:host-context(tui-sheet-dialog) input{order:100;margin-inline-start:auto}\n"] }]
96
98
  }] });
97
99
 
98
100
  class TuiMultiSelectGroupDirective {
99
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectGroupDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
100
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiMultiSelectGroupDirective, isStandalone: true, selector: "[tuiMultiSelectGroup]", providers: [tuiAsOptionContent(TuiMultiSelectOption)], ngImport: i0 }); }
101
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiMultiSelectGroupDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
102
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.2.15", type: TuiMultiSelectGroupDirective, isStandalone: true, selector: "[tuiMultiSelectGroup]", providers: [tuiAsOptionContent(TuiMultiSelectOption)], ngImport: i0 }); }
101
103
  }
102
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectGroupDirective, decorators: [{
104
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiMultiSelectGroupDirective, decorators: [{
103
105
  type: Directive,
104
106
  args: [{
105
- standalone: true,
106
107
  selector: '[tuiMultiSelectGroup]',
107
108
  providers: [tuiAsOptionContent(TuiMultiSelectOption)],
108
109
  }]
@@ -129,16 +130,16 @@ class TuiMultiSelectNative {
129
130
  const options = Array.from(this.el.selectedOptions).map(({ index }) => index);
130
131
  this.textfield.cva?.onChange(items.flat().filter((_, i) => options.includes(i)));
131
132
  }
132
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectNative, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
133
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiMultiSelectNative, isStandalone: true, selector: "select[tuiMultiSelect]", inputs: { items: "items", labels: "labels", placeholder: "placeholder" }, host: { attributes: { "multiple": "" }, listeners: { "click.stop.zoneless": "0", "input": "onInput()" } }, providers: [tuiAsOptionContent(TuiMultiSelectOption)], hostDirectives: [{ directive: i1.TuiInputChipDirective }, { directive: i2.TuiSelectLike }], ngImport: i0, template: "<ng-container *ngIf=\"items && !isFlat(items); else flatItems\">\n <optgroup\n *ngFor=\"let group of labels; let index = index\"\n [label]=\"labels[index]\"\n >\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items[index]}\" />\n </optgroup>\n <ng-container *ngIf=\"!mobile\">\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n new\n [items]=\"items\"\n [labels]=\"labels\"\n />\n </ng-container>\n</ng-container>\n\n<ng-template #flatItems>\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items}\" />\n <ng-container *ngIf=\"!mobile\">\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n new\n [items]=\"$any(items)\"\n />\n </ng-container>\n</ng-template>\n\n<ng-template\n #options\n let-items\n>\n <option\n *ngFor=\"let option of items\"\n [disabled]=\"handlers.disabledItemHandler()(option)\"\n [selected]=\"isSelected()(option)\"\n [value]=\"handlers.stringify()(option)\"\n >\n {{ handlers.stringify()(option) }}\n </option>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]", inputs: ["items", "disabledItemHandler", "emptyContent", "size", "itemContent"], outputs: ["itemClick"] }, { kind: "component", type: i3.TuiDataListGroupWrapperComponent, selector: "tui-data-list-wrapper[labels]", inputs: ["labels"] }, { kind: "directive", type: i2.TuiTextfieldDropdownDirective, selector: "ng-template[tuiTextfieldDropdown]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
133
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiMultiSelectNative, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
134
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.15", type: TuiMultiSelectNative, isStandalone: true, selector: "select[tuiMultiSelect]", inputs: { items: "items", labels: "labels", placeholder: "placeholder" }, host: { attributes: { "multiple": "" }, listeners: { "click.stop.zoneless": "0", "input": "onInput()" } }, providers: [tuiAsOptionContent(TuiMultiSelectOption)], hostDirectives: [{ directive: i1.TuiInputChipDirective }, { directive: i2.TuiSelectLike }], ngImport: i0, template: "@if (items && !isFlat(items)) {\n @for (group of labels; track group) {\n <optgroup [label]=\"labels[$index]\">\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items[$index]}\" />\n </optgroup>\n }\n @if (!mobile) {\n <tui-data-list *tuiDropdown>\n @for (group of items; track $index) {\n <tui-opt-group\n tuiMultiSelectGroup\n [label]=\"labels[$index] || ''\"\n >\n @for (item of group; track $index) {\n <button\n new\n tuiOption\n type=\"button\"\n [disabled]=\"handlers.disabledItemHandler()(item)\"\n [value]=\"item\"\n >\n {{ handlers.stringify()(item) }}\n </button>\n }\n </tui-opt-group>\n }\n </tui-data-list>\n }\n} @else {\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items}\" />\n @if (!mobile) {\n <tui-data-list *tuiDropdown>\n @for (item of items; track $index) {\n <button\n new\n tuiOption\n type=\"button\"\n [disabled]=\"handlers.disabledItemHandler()(item)\"\n [value]=\"item\"\n >\n {{ handlers.stringify()(item) }}\n </button>\n }\n </tui-data-list>\n }\n}\n\n<ng-template\n #options\n let-items\n>\n @for (option of items; track option) {\n <option\n [disabled]=\"handlers.disabledItemHandler()(option)\"\n [selected]=\"isSelected()(option)\"\n [value]=\"handlers.stringify()(option)\"\n >\n {{ handlers.stringify()(option) }}\n </option>\n }\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "directive", type: i3.TuiOptionNew, selector: "button[tuiOption][new], a[tuiOption][new], label[tuiOption][new]", inputs: ["disabled"] }, { kind: "directive", type: i3.TuiOptionWithValue, selector: "button[tuiOption][value][new], a[tuiOption][value][new], label[tuiOption][value][new]", inputs: ["disabled", "value"] }, { kind: "directive", type: i3.TuiOptGroup, selector: "tui-opt-group", inputs: ["label"] }, { kind: "directive", type: i4.TuiDropdownContent, selector: "ng-template[tuiDropdown]" }, { kind: "component", type: TuiMultiSelectGroupComponent, selector: "tui-opt-group[tuiMultiSelectGroup]", inputs: ["label"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
134
135
  }
135
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectNative, decorators: [{
136
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiMultiSelectNative, decorators: [{
136
137
  type: Component,
137
- args: [{ standalone: true, selector: 'select[tuiMultiSelect]', imports: [NgForOf, NgIf, NgTemplateOutlet, TuiDataListWrapper, TuiTextfield], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsOptionContent(TuiMultiSelectOption)], hostDirectives: [TuiInputChipDirective, TuiSelectLike], host: {
138
+ args: [{ selector: 'select[tuiMultiSelect]', imports: [NgTemplateOutlet, TuiDataList, TuiTextfield, TuiMultiSelectGroupComponent], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsOptionContent(TuiMultiSelectOption)], hostDirectives: [TuiInputChipDirective, TuiSelectLike], host: {
138
139
  multiple: '',
139
140
  '(click.stop.zoneless)': '0',
140
141
  '(input)': 'onInput()',
141
- }, template: "<ng-container *ngIf=\"items && !isFlat(items); else flatItems\">\n <optgroup\n *ngFor=\"let group of labels; let index = index\"\n [label]=\"labels[index]\"\n >\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items[index]}\" />\n </optgroup>\n <ng-container *ngIf=\"!mobile\">\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n new\n [items]=\"items\"\n [labels]=\"labels\"\n />\n </ng-container>\n</ng-container>\n\n<ng-template #flatItems>\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items}\" />\n <ng-container *ngIf=\"!mobile\">\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n new\n [items]=\"$any(items)\"\n />\n </ng-container>\n</ng-template>\n\n<ng-template\n #options\n let-items\n>\n <option\n *ngFor=\"let option of items\"\n [disabled]=\"handlers.disabledItemHandler()(option)\"\n [selected]=\"isSelected()(option)\"\n [value]=\"handlers.stringify()(option)\"\n >\n {{ handlers.stringify()(option) }}\n </option>\n</ng-template>\n" }]
142
+ }, template: "@if (items && !isFlat(items)) {\n @for (group of labels; track group) {\n <optgroup [label]=\"labels[$index]\">\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items[$index]}\" />\n </optgroup>\n }\n @if (!mobile) {\n <tui-data-list *tuiDropdown>\n @for (group of items; track $index) {\n <tui-opt-group\n tuiMultiSelectGroup\n [label]=\"labels[$index] || ''\"\n >\n @for (item of group; track $index) {\n <button\n new\n tuiOption\n type=\"button\"\n [disabled]=\"handlers.disabledItemHandler()(item)\"\n [value]=\"item\"\n >\n {{ handlers.stringify()(item) }}\n </button>\n }\n </tui-opt-group>\n }\n </tui-data-list>\n }\n} @else {\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items}\" />\n @if (!mobile) {\n <tui-data-list *tuiDropdown>\n @for (item of items; track $index) {\n <button\n new\n tuiOption\n type=\"button\"\n [disabled]=\"handlers.disabledItemHandler()(item)\"\n [value]=\"item\"\n >\n {{ handlers.stringify()(item) }}\n </button>\n }\n </tui-data-list>\n }\n}\n\n<ng-template\n #options\n let-items\n>\n @for (option of items; track option) {\n <option\n [disabled]=\"handlers.disabledItemHandler()(option)\"\n [selected]=\"isSelected()(option)\"\n [value]=\"handlers.stringify()(option)\"\n >\n {{ handlers.stringify()(option) }}\n </option>\n }\n</ng-template>\n" }]
142
143
  }], propDecorators: { items: [{
143
144
  type: Input
144
145
  }], labels: [{
@@ -1 +1 @@
1
- {"version":3,"file":"taiga-ui-kit-components-multi-select.mjs","sources":["../../../projects/kit/components/multi-select/multi-select-group/multi-select-group.component.ts","../../../projects/kit/components/multi-select/multi-select-group/multi-select-group.template.html","../../../projects/kit/components/multi-select/multi-select-option/multi-select-option.component.ts","../../../projects/kit/components/multi-select/multi-select-group/multi-select-group.directive.ts","../../../projects/kit/components/multi-select/multi-select-native/multi-select-native.component.ts","../../../projects/kit/components/multi-select/multi-select-native/multi-select-native.template.html","../../../projects/kit/components/multi-select/multi-select.ts","../../../projects/kit/components/multi-select/taiga-ui-kit-components-multi-select.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n computed,\n ContentChildren,\n inject,\n Input,\n type QueryList,\n signal,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {NgControl} from '@angular/forms';\nimport {tuiIsPresent} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiOptionWithValue} from '@taiga-ui/core/components/data-list';\nimport {TuiLink} from '@taiga-ui/core/components/link';\nimport {TuiTextfieldComponent} from '@taiga-ui/core/components/textfield';\nimport {\n TUI_ITEMS_HANDLERS,\n type TuiItemsHandlers,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_MULTI_SELECT_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiInjectValue} from '@taiga-ui/kit/utils';\n\n@Component({\n standalone: true,\n selector: 'tui-opt-group[tuiMultiSelectGroup]',\n imports: [TuiLink],\n templateUrl: './multi-select-group.template.html',\n styleUrls: ['./multi-select-group.style.less'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n host: {\n '[class._label]': 'label',\n },\n})\nexport class TuiMultiSelectGroupComponent<T> {\n private readonly values = signal<readonly T[]>([]);\n private readonly handlers = inject<TuiItemsHandlers<T>>(TUI_ITEMS_HANDLERS);\n private readonly control =\n inject(TuiTextfieldComponent, {optional: true})?.control ||\n inject(NgControl, {optional: true});\n\n protected readonly texts = toSignal(inject(TUI_MULTI_SELECT_TEXTS));\n protected readonly value = tuiInjectValue<readonly T[]>();\n protected readonly checked = computed(() =>\n this.values().every((item) =>\n this.value().some((value) => this.handlers.identityMatcher()(item, value)),\n ),\n );\n\n @Input()\n public label = '';\n\n @ContentChildren(TuiOptionWithValue)\n protected set options(options: QueryList<TuiOptionWithValue<T>>) {\n this.values.set(\n options\n .toArray()\n .map(({value}) => value())\n .filter(tuiIsPresent),\n );\n }\n\n protected toggle(): void {\n const values = this.values();\n const matcher = this.handlers.identityMatcher();\n const others = this.value().filter((current) =>\n values.every((item) => !matcher(current, item)),\n );\n\n this.control?.control?.setValue(this.checked() ? others : others.concat(values));\n }\n}\n","<span class=\"t-wrapper\">\n <span class=\"t-label\">{{ label }}</span>\n <button\n tuiLink\n type=\"button\"\n class=\"t-button\"\n (click)=\"toggle()\"\n >\n {{ texts()?.[checked() ? 'none' : 'all'] }}\n </button>\n</span>\n<ng-content />\n","import {NgIf} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, computed, inject} from '@angular/core';\nimport {tuiIsPresent} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiOptionWithValue} from '@taiga-ui/core/components/data-list';\nimport {TUI_TEXTFIELD_OPTIONS} from '@taiga-ui/core/components/textfield';\nimport {\n TUI_ITEMS_HANDLERS,\n type TuiItemsHandlers,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TuiCheckbox} from '@taiga-ui/kit/components/checkbox';\nimport {tuiInjectValue} from '@taiga-ui/kit/utils';\n\n@Component({\n standalone: true,\n imports: [NgIf, TuiCheckbox],\n template: `\n <input\n *ngIf=\"option\"\n tuiCheckbox\n type=\"checkbox\"\n [checked]=\"selected()\"\n [size]=\"size() === 'l' ? 'm' : 's'\"\n />\n `,\n styles: [\n `\n :host-context(tui-dropdown-mobile) input {\n order: 100;\n margin-inline-start: auto;\n }\n `,\n ],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiMultiSelectOption<T> {\n protected readonly option = inject<TuiOptionWithValue<T>>(TuiOptionWithValue, {\n optional: true,\n });\n\n protected readonly handlers = inject<TuiItemsHandlers<T>>(TUI_ITEMS_HANDLERS);\n protected readonly value = tuiInjectValue<readonly T[]>();\n protected readonly size = inject(TUI_TEXTFIELD_OPTIONS).size;\n protected readonly selected = computed(\n (controlValue = this.value(), optionValue = this.option?.value()) =>\n tuiIsPresent(optionValue) &&\n tuiIsPresent(controlValue) &&\n controlValue.some(\n (item) =>\n this.handlers?.identityMatcher()(item, optionValue) ??\n item === optionValue,\n ),\n );\n}\n","import {Directive} from '@angular/core';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\n\nimport {TuiMultiSelectOption} from '../multi-select-option/multi-select-option.component';\n\n@Directive({\n standalone: true,\n selector: '[tuiMultiSelectGroup]',\n providers: [tuiAsOptionContent(TuiMultiSelectOption)],\n})\nexport class TuiMultiSelectGroupDirective {}\n","import {NgForOf, NgIf, NgTemplateOutlet} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, computed, inject, Input} from '@angular/core';\nimport {TuiControl} from '@taiga-ui/cdk/classes';\nimport {TUI_IS_ANDROID, TUI_IS_IOS} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement, tuiIsPresent} from '@taiga-ui/cdk/utils';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport {\n TuiSelectLike,\n TuiTextfield,\n TuiTextfieldComponent,\n} from '@taiga-ui/core/components/textfield';\nimport {\n TUI_ITEMS_HANDLERS,\n type TuiItemsHandlers,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TuiDataListWrapper} from '@taiga-ui/kit/components/data-list-wrapper';\nimport {TuiInputChipDirective} from '@taiga-ui/kit/components/input-chip';\nimport {tuiIsFlat} from '@taiga-ui/kit/utils';\n\nimport {TuiMultiSelectOption} from '../multi-select-option/multi-select-option.component';\n\n@Component({\n standalone: true,\n selector: 'select[tuiMultiSelect]',\n imports: [NgForOf, NgIf, NgTemplateOutlet, TuiDataListWrapper, TuiTextfield],\n templateUrl: './multi-select-native.template.html',\n changeDetection: ChangeDetectionStrategy.OnPush,\n providers: [tuiAsOptionContent(TuiMultiSelectOption)],\n hostDirectives: [TuiInputChipDirective, TuiSelectLike],\n host: {\n multiple: '',\n '(click.stop.zoneless)': '0',\n '(input)': 'onInput()',\n },\n})\nexport class TuiMultiSelectNative<T> {\n private readonly control: TuiControl<readonly T[]> = inject(TuiControl);\n private readonly textfield = inject(TuiTextfieldComponent);\n\n protected readonly isFlat = tuiIsFlat;\n protected readonly handlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n protected readonly el = tuiInjectElement<HTMLSelectElement>();\n protected readonly mobile =\n inject(TUI_IS_IOS) || (inject(TUI_IS_ANDROID) && 'showPicker' in this.el);\n\n protected readonly isSelected = computed(\n (value = this.control.value()) =>\n (x: T) =>\n tuiIsPresent(value) &&\n value.some((item) => this.handlers.identityMatcher()(x, item)),\n );\n\n @Input()\n public items: ReadonlyArray<readonly T[]> | readonly T[] | null = [];\n\n @Input()\n public labels: readonly string[] = [];\n\n @Input()\n public set placeholder(placeholder: string) {\n this.textfield.fillerSetter = placeholder;\n }\n\n protected onInput(): void {\n const items = this.items || [];\n const options = Array.from(this.el.selectedOptions).map(({index}) => index);\n\n this.textfield.cva?.onChange(items.flat().filter((_, i) => options.includes(i)));\n }\n}\n","<ng-container *ngIf=\"items && !isFlat(items); else flatItems\">\n <optgroup\n *ngFor=\"let group of labels; let index = index\"\n [label]=\"labels[index]\"\n >\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items[index]}\" />\n </optgroup>\n <ng-container *ngIf=\"!mobile\">\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n new\n [items]=\"items\"\n [labels]=\"labels\"\n />\n </ng-container>\n</ng-container>\n\n<ng-template #flatItems>\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items}\" />\n <ng-container *ngIf=\"!mobile\">\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n new\n [items]=\"$any(items)\"\n />\n </ng-container>\n</ng-template>\n\n<ng-template\n #options\n let-items\n>\n <option\n *ngFor=\"let option of items\"\n [disabled]=\"handlers.disabledItemHandler()(option)\"\n [selected]=\"isSelected()(option)\"\n [value]=\"handlers.stringify()(option)\"\n >\n {{ handlers.stringify()(option) }}\n </option>\n</ng-template>\n","import {TuiMultiSelectGroupComponent} from './multi-select-group/multi-select-group.component';\nimport {TuiMultiSelectGroupDirective} from './multi-select-group/multi-select-group.directive';\nimport {TuiMultiSelectNative} from './multi-select-native/multi-select-native.component';\n\nexport const TuiMultiSelect = [\n TuiMultiSelectGroupComponent,\n TuiMultiSelectGroupDirective,\n TuiMultiSelectNative,\n] as const;\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["tuiIsPresent"],"mappings":"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"}
1
+ {"version":3,"file":"taiga-ui-kit-components-multi-select.mjs","sources":["../../../projects/kit/components/multi-select/multi-select-group/multi-select-group.component.ts","../../../projects/kit/components/multi-select/multi-select-group/multi-select-group.template.html","../../../projects/kit/components/multi-select/multi-select-option/multi-select-option.component.ts","../../../projects/kit/components/multi-select/multi-select-group/multi-select-group.directive.ts","../../../projects/kit/components/multi-select/multi-select-native/multi-select-native.component.ts","../../../projects/kit/components/multi-select/multi-select-native/multi-select-native.template.html","../../../projects/kit/components/multi-select/multi-select.ts","../../../projects/kit/components/multi-select/taiga-ui-kit-components-multi-select.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n computed,\n ContentChildren,\n inject,\n Input,\n type QueryList,\n signal,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {tuiIsPresent} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiOptionWithValue} from '@taiga-ui/core/components/data-list';\nimport {TuiLink} from '@taiga-ui/core/components/link';\nimport {TuiTextfieldComponent} from '@taiga-ui/core/components/textfield';\nimport {\n TUI_ITEMS_HANDLERS,\n type TuiItemsHandlers,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_MULTI_SELECT_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiInjectValue} from '@taiga-ui/kit/utils';\n\n@Component({\n standalone: true,\n selector: 'tui-opt-group[tuiMultiSelectGroup]',\n imports: [TuiLink],\n templateUrl: './multi-select-group.template.html',\n styleUrl: './multi-select-group.style.less',\n changeDetection: ChangeDetectionStrategy.OnPush,\n host: {\n '[class._label]': 'label',\n },\n})\nexport class TuiMultiSelectGroupComponent<T> {\n private readonly handlers = inject<TuiItemsHandlers<T>>(TUI_ITEMS_HANDLERS);\n private readonly control =\n inject(TuiTextfieldComponent, {optional: true})?.control ||\n inject(NgControl, {optional: true});\n\n protected readonly values = signal<readonly T[]>([]);\n protected readonly texts = inject(TUI_MULTI_SELECT_TEXTS);\n protected readonly value = tuiInjectValue<readonly T[] | null>();\n protected readonly checked = computed(() =>\n this.values().every((item) =>\n this.value()?.some((value) => this.handlers.identityMatcher()(item, value)),\n ),\n );\n\n @Input()\n public label = '';\n\n @ContentChildren(TuiOptionWithValue)\n protected set options(options: QueryList<TuiOptionWithValue<T>>) {\n this.values.set(\n options\n .toArray()\n .map(({value}) => value())\n .filter(tuiIsPresent),\n );\n }\n\n protected toggle(): void {\n const values = this.values();\n const matcher = this.handlers.identityMatcher();\n const value = this.value() || [];\n const others = value.filter((a) => values.every((b) => !matcher(a, b)));\n\n this.control?.control?.setValue(this.checked() ? others : others.concat(values));\n }\n}\n","@if (values().length) {\n <span class=\"t-wrapper\">\n <span class=\"t-label\">{{ label }}</span>\n <button\n tuiLink\n type=\"button\"\n class=\"t-button\"\n (click)=\"toggle()\"\n >\n {{ texts()[checked() ? 'none' : 'all'] }}\n </button>\n </span>\n}\n<ng-content />\n","import {ChangeDetectionStrategy, Component, computed, inject} from '@angular/core';\nimport {tuiIsPresent} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiOptionWithValue} from '@taiga-ui/core/components/data-list';\nimport {TUI_TEXTFIELD_OPTIONS} from '@taiga-ui/core/components/textfield';\nimport {\n TUI_ITEMS_HANDLERS,\n type TuiItemsHandlers,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TuiCheckbox} from '@taiga-ui/kit/components/checkbox';\nimport {tuiInjectValue} from '@taiga-ui/kit/utils';\n\n@Component({\n imports: [TuiCheckbox],\n template: `\n @if (option) {\n <input\n tuiCheckbox\n type=\"checkbox\"\n [checked]=\"selected()\"\n [size]=\"size() === 'l' ? 'm' : 's'\"\n />\n }\n `,\n styles: `\n :host-context(tui-dropdown-mobile) input,\n :host-context(tui-sheet-dialog) input {\n order: 100;\n margin-inline-start: auto;\n }\n `,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiMultiSelectOption<T> {\n protected readonly option = inject<TuiOptionWithValue<T>>(TuiOptionWithValue, {\n optional: true,\n });\n\n protected readonly handlers = inject<TuiItemsHandlers<T>>(TUI_ITEMS_HANDLERS);\n protected readonly value = tuiInjectValue<readonly T[]>();\n protected readonly size = inject(TUI_TEXTFIELD_OPTIONS).size;\n protected readonly selected = computed(\n (controlValue = this.value(), optionValue = this.option?.value()) =>\n tuiIsPresent(optionValue) &&\n tuiIsPresent(controlValue) &&\n controlValue.some(\n (item) =>\n this.handlers?.identityMatcher()(item, optionValue) ??\n item === optionValue,\n ),\n );\n}\n","import {Directive} from '@angular/core';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\n\nimport {TuiMultiSelectOption} from '../multi-select-option/multi-select-option.component';\n\n@Directive({\n selector: '[tuiMultiSelectGroup]',\n providers: [tuiAsOptionContent(TuiMultiSelectOption)],\n})\nexport class TuiMultiSelectGroupDirective {}\n","import {NgTemplateOutlet} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, computed, inject, Input} from '@angular/core';\nimport {TuiControl} from '@taiga-ui/cdk/classes';\nimport {TUI_IS_ANDROID, TUI_IS_IOS} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement, tuiIsPresent} from '@taiga-ui/cdk/utils';\nimport {tuiAsOptionContent, TuiDataList} from '@taiga-ui/core/components/data-list';\nimport {\n TuiSelectLike,\n TuiTextfield,\n TuiTextfieldComponent,\n} from '@taiga-ui/core/components/textfield';\nimport {\n TUI_ITEMS_HANDLERS,\n type TuiItemsHandlers,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TuiInputChipDirective} from '@taiga-ui/kit/components/input-chip';\nimport {tuiIsFlat} from '@taiga-ui/kit/utils';\n\nimport {TuiMultiSelectGroupComponent} from '../multi-select-group/multi-select-group.component';\nimport {TuiMultiSelectOption} from '../multi-select-option/multi-select-option.component';\n\n@Component({\n selector: 'select[tuiMultiSelect]',\n imports: [NgTemplateOutlet, TuiDataList, TuiTextfield, TuiMultiSelectGroupComponent],\n templateUrl: './multi-select-native.template.html',\n changeDetection: ChangeDetectionStrategy.OnPush,\n providers: [tuiAsOptionContent(TuiMultiSelectOption)],\n hostDirectives: [TuiInputChipDirective, TuiSelectLike],\n host: {\n multiple: '',\n '(click.stop.zoneless)': '0',\n '(input)': 'onInput()',\n },\n})\nexport class TuiMultiSelectNative<T> {\n private readonly control: TuiControl<readonly T[]> = inject(TuiControl);\n private readonly textfield = inject(TuiTextfieldComponent);\n\n protected readonly isFlat = tuiIsFlat;\n protected readonly handlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n protected readonly el = tuiInjectElement<HTMLSelectElement>();\n protected readonly mobile =\n inject(TUI_IS_IOS) || (inject(TUI_IS_ANDROID) && 'showPicker' in this.el);\n\n protected readonly isSelected = computed(\n (value = this.control.value()) =>\n (x: T) =>\n tuiIsPresent(value) &&\n value.some((item) => this.handlers.identityMatcher()(x, item)),\n );\n\n @Input()\n public items: ReadonlyArray<readonly T[]> | readonly T[] | null = [];\n\n @Input()\n public labels: readonly string[] = [];\n\n @Input()\n public set placeholder(placeholder: string) {\n this.textfield.fillerSetter = placeholder;\n }\n\n protected onInput(): void {\n const items = this.items || [];\n const options = Array.from(this.el.selectedOptions).map(({index}) => index);\n\n this.textfield.cva?.onChange(items.flat().filter((_, i) => options.includes(i)));\n }\n}\n","@if (items && !isFlat(items)) {\n @for (group of labels; track group) {\n <optgroup [label]=\"labels[$index]\">\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items[$index]}\" />\n </optgroup>\n }\n @if (!mobile) {\n <tui-data-list *tuiDropdown>\n @for (group of items; track $index) {\n <tui-opt-group\n tuiMultiSelectGroup\n [label]=\"labels[$index] || ''\"\n >\n @for (item of group; track $index) {\n <button\n new\n tuiOption\n type=\"button\"\n [disabled]=\"handlers.disabledItemHandler()(item)\"\n [value]=\"item\"\n >\n {{ handlers.stringify()(item) }}\n </button>\n }\n </tui-opt-group>\n }\n </tui-data-list>\n }\n} @else {\n <ng-container *ngTemplateOutlet=\"options; context: {$implicit: items}\" />\n @if (!mobile) {\n <tui-data-list *tuiDropdown>\n @for (item of items; track $index) {\n <button\n new\n tuiOption\n type=\"button\"\n [disabled]=\"handlers.disabledItemHandler()(item)\"\n [value]=\"item\"\n >\n {{ handlers.stringify()(item) }}\n </button>\n }\n </tui-data-list>\n }\n}\n\n<ng-template\n #options\n let-items\n>\n @for (option of items; track option) {\n <option\n [disabled]=\"handlers.disabledItemHandler()(option)\"\n [selected]=\"isSelected()(option)\"\n [value]=\"handlers.stringify()(option)\"\n >\n {{ handlers.stringify()(option) }}\n </option>\n }\n</ng-template>\n","import {TuiMultiSelectGroupComponent} from './multi-select-group/multi-select-group.component';\nimport {TuiMultiSelectGroupDirective} from './multi-select-group/multi-select-group.directive';\nimport {TuiMultiSelectNative} from './multi-select-native/multi-select-native.component';\n\nexport const TuiMultiSelect = [\n TuiMultiSelectGroupComponent,\n TuiMultiSelectGroupDirective,\n TuiMultiSelectNative,\n] as const;\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["tuiIsPresent"],"mappings":"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"}
@@ -0,0 +1,90 @@
1
+ import * as i0 from '@angular/core';
2
+ import { isSignal, ChangeDetectionStrategy, Component, Injectable, Directive } from '@angular/core';
3
+ import * as i2 from '@ng-web-apis/resize-observer';
4
+ import { WaResizeObserver } from '@ng-web-apis/resize-observer';
5
+ import * as i1 from '@taiga-ui/cdk/directives/animated';
6
+ import { TuiAnimated } from '@taiga-ui/cdk/directives/animated';
7
+ import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
8
+ import { TuiLoader, tuiLoaderOptionsProvider } from '@taiga-ui/core/components/loader';
9
+ import { injectContext, PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
10
+ import { TuiPopoverDirective } from '@taiga-ui/cdk/directives/popover';
11
+ import { TuiPopoverService, tuiAsPopover } from '@taiga-ui/cdk/services';
12
+ import { TUI_DIALOGS } from '@taiga-ui/core/components/dialog';
13
+
14
+ class TuiNotificationMiddleComponent {
15
+ constructor() {
16
+ this.el = tuiInjectElement();
17
+ this.context = injectContext();
18
+ }
19
+ onClick(target) {
20
+ if (this.closable && !this.el.contains(target)) {
21
+ this.context.$implicit.complete();
22
+ }
23
+ }
24
+ get closable() {
25
+ return isSignal(this.context.closable)
26
+ ? this.context.closable()
27
+ : this.context.closable;
28
+ }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiNotificationMiddleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.15", type: TuiNotificationMiddleComponent, isStandalone: true, selector: "tui-notification-middle", host: { listeners: { "document:click.capture": "onClick($event.target)", "document:keydown.esc": "onClick($event.currentTarget)", "waResizeObserver": "el.style.setProperty(\"--t-width\", el.clientWidth + \"px\")" } }, providers: [tuiLoaderOptionsProvider({ size: 'l' })], hostDirectives: [{ directive: i1.TuiAnimated }, { directive: i2.WaResizeObserver, outputs: ["waResizeObserver", "waResizeObserver"] }], ngImport: i0, template: `
31
+ <tui-loader class="t-loader" />
32
+ <ng-container *polymorpheusOutlet="context.content as text">
33
+ {{ text }}
34
+ </ng-container>
35
+ `, isInline: true, styles: [":host{position:relative;display:grid;max-inline-size:18.75rem;min-inline-size:7rem;min-block-size:7rem;justify-items:center;gap:1rem;margin:auto;padding:2.25rem 2.25rem 1.75rem;border-radius:1.25rem;box-sizing:border-box;font:var(--tui-font-text-m);--tui-scale: .5}:host:before{inline-size:100%;block-size:100%;transition-property:width;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);content:\"\";z-index:-1;inline-size:var(--t-width);background:var(--tui-background-elevation-3);box-shadow:var(--tui-shadow-popup);border-radius:inherit;contain:strict}:host.tui-enter,:host.tui-leave{animation-name:tuiFade,tuiScale}:host.tui-enter ::ng-deep>.tui-enter,:host.tui-leave ::ng-deep>.tui-enter{animation-duration:0s;animation-delay:0s}:host .t-loader:not(:last-child){display:none}:host ::ng-deep>*{grid-area:2 / 1}:host ::ng-deep>*.tui-enter,:host ::ng-deep>*.tui-leave{animation-delay:var(--tui-duration);animation-name:tuiFade}:host ::ng-deep>*.tui-leave{animation-delay:0s}:host ::ng-deep>*.tui-leave~.tui-enter{opacity:0}:host ::ng-deep>tui-loader,:host ::ng-deep>[tuiAvatar],:host ::ng-deep>tui-icon,:host ::ng-deep>img{block-size:2.5rem;inline-size:2.5rem;min-inline-size:2.5rem;font-size:2.5rem;grid-area:1 / 1}\n"], dependencies: [{ kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
36
+ }
37
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiNotificationMiddleComponent, decorators: [{
38
+ type: Component,
39
+ args: [{ selector: 'tui-notification-middle', imports: [PolymorpheusOutlet, TuiLoader], template: `
40
+ <tui-loader class="t-loader" />
41
+ <ng-container *polymorpheusOutlet="context.content as text">
42
+ {{ text }}
43
+ </ng-container>
44
+ `, changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiLoaderOptionsProvider({ size: 'l' })], hostDirectives: [
45
+ TuiAnimated,
46
+ { directive: WaResizeObserver, outputs: ['waResizeObserver'] },
47
+ ], host: {
48
+ '(document:click.capture)': 'onClick($event.target)',
49
+ '(document:keydown.esc)': 'onClick($event.currentTarget)',
50
+ '(waResizeObserver)': 'el.style.setProperty("--t-width", el.clientWidth + "px")',
51
+ }, styles: [":host{position:relative;display:grid;max-inline-size:18.75rem;min-inline-size:7rem;min-block-size:7rem;justify-items:center;gap:1rem;margin:auto;padding:2.25rem 2.25rem 1.75rem;border-radius:1.25rem;box-sizing:border-box;font:var(--tui-font-text-m);--tui-scale: .5}:host:before{inline-size:100%;block-size:100%;transition-property:width;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);content:\"\";z-index:-1;inline-size:var(--t-width);background:var(--tui-background-elevation-3);box-shadow:var(--tui-shadow-popup);border-radius:inherit;contain:strict}:host.tui-enter,:host.tui-leave{animation-name:tuiFade,tuiScale}:host.tui-enter ::ng-deep>.tui-enter,:host.tui-leave ::ng-deep>.tui-enter{animation-duration:0s;animation-delay:0s}:host .t-loader:not(:last-child){display:none}:host ::ng-deep>*{grid-area:2 / 1}:host ::ng-deep>*.tui-enter,:host ::ng-deep>*.tui-leave{animation-delay:var(--tui-duration);animation-name:tuiFade}:host ::ng-deep>*.tui-leave{animation-delay:0s}:host ::ng-deep>*.tui-leave~.tui-enter{opacity:0}:host ::ng-deep>tui-loader,:host ::ng-deep>[tuiAvatar],:host ::ng-deep>tui-icon,:host ::ng-deep>img{block-size:2.5rem;inline-size:2.5rem;min-inline-size:2.5rem;font-size:2.5rem;grid-area:1 / 1}\n"] }]
52
+ }] });
53
+
54
+ class TuiNotificationMiddleService extends TuiPopoverService {
55
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiNotificationMiddleService, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
56
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiNotificationMiddleService, providedIn: 'root', useFactory: () => new TuiNotificationMiddleService(TUI_DIALOGS, TuiNotificationMiddleComponent, {
57
+ closable: false,
58
+ }) }); }
59
+ }
60
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiNotificationMiddleService, decorators: [{
61
+ type: Injectable,
62
+ args: [{
63
+ providedIn: 'root',
64
+ useFactory: () => new TuiNotificationMiddleService(TUI_DIALOGS, TuiNotificationMiddleComponent, {
65
+ closable: false,
66
+ }),
67
+ }]
68
+ }] });
69
+
70
+ class TuiNotificationMiddle extends TuiPopoverDirective {
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiNotificationMiddle, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
72
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.2.15", type: TuiNotificationMiddle, isStandalone: true, selector: "ng-template[tuiNotificationMiddle]", inputs: { options: ["tuiNotificationMiddleOptions", "options"], open: ["tuiNotificationMiddle", "open"] }, outputs: { openChange: "tuiNotificationMiddleChange" }, providers: [tuiAsPopover(TuiNotificationMiddleService)], usesInheritance: true, ngImport: i0 }); }
73
+ }
74
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiNotificationMiddle, decorators: [{
75
+ type: Directive,
76
+ args: [{
77
+ standalone: true,
78
+ selector: 'ng-template[tuiNotificationMiddle]',
79
+ inputs: ['options: tuiNotificationMiddleOptions', 'open: tuiNotificationMiddle'],
80
+ outputs: ['openChange: tuiNotificationMiddleChange'],
81
+ providers: [tuiAsPopover(TuiNotificationMiddleService)],
82
+ }]
83
+ }] });
84
+
85
+ /**
86
+ * Generated bundle index. Do not edit.
87
+ */
88
+
89
+ export { TuiNotificationMiddle, TuiNotificationMiddleComponent, TuiNotificationMiddleService };
90
+ //# sourceMappingURL=taiga-ui-kit-components-notification-middle.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"taiga-ui-kit-components-notification-middle.mjs","sources":["../../../projects/kit/components/notification-middle/notification-middle.component.ts","../../../projects/kit/components/notification-middle/notification-middle.service.ts","../../../projects/kit/components/notification-middle/notification-middle.directive.ts","../../../projects/kit/components/notification-middle/taiga-ui-kit-components-notification-middle.ts"],"sourcesContent":["import {ChangeDetectionStrategy, Component, isSignal, type Signal} from '@angular/core';\nimport {WaResizeObserver} from '@ng-web-apis/resize-observer';\nimport {TuiAnimated} from '@taiga-ui/cdk/directives/animated';\nimport {type TuiPopover} from '@taiga-ui/cdk/services';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {TuiLoader, tuiLoaderOptionsProvider} from '@taiga-ui/core/components/loader';\nimport {injectContext, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nexport interface TuiNotificationMiddleOptions {\n closable: Signal<boolean> | boolean;\n}\n\n@Component({\n selector: 'tui-notification-middle',\n imports: [PolymorpheusOutlet, TuiLoader],\n template: `\n <tui-loader class=\"t-loader\" />\n <ng-container *polymorpheusOutlet=\"context.content as text\">\n {{ text }}\n </ng-container>\n `,\n styleUrl: './notification-middle.style.less',\n changeDetection: ChangeDetectionStrategy.OnPush,\n providers: [tuiLoaderOptionsProvider({size: 'l'})],\n hostDirectives: [\n TuiAnimated,\n {directive: WaResizeObserver, outputs: ['waResizeObserver']},\n ],\n host: {\n '(document:click.capture)': 'onClick($event.target)',\n '(document:keydown.esc)': 'onClick($event.currentTarget)',\n '(waResizeObserver)': 'el.style.setProperty(\"--t-width\", el.clientWidth + \"px\")',\n },\n})\nexport class TuiNotificationMiddleComponent {\n protected readonly el = tuiInjectElement();\n protected readonly context =\n injectContext<TuiPopover<TuiNotificationMiddleOptions, void>>();\n\n protected onClick(target: HTMLElement): void {\n if (this.closable && !this.el.contains(target)) {\n this.context.$implicit.complete();\n }\n }\n\n private get closable(): boolean {\n return isSignal(this.context.closable)\n ? this.context.closable()\n : this.context.closable;\n }\n}\n","import {Injectable} from '@angular/core';\nimport {TuiPopoverService} from '@taiga-ui/cdk/services';\nimport {TUI_DIALOGS} from '@taiga-ui/core/components/dialog';\n\nimport {\n TuiNotificationMiddleComponent,\n type TuiNotificationMiddleOptions,\n} from './notification-middle.component';\n\n@Injectable({\n providedIn: 'root',\n useFactory: () =>\n new TuiNotificationMiddleService(TUI_DIALOGS, TuiNotificationMiddleComponent, {\n closable: false,\n }),\n})\nexport class TuiNotificationMiddleService extends TuiPopoverService<TuiNotificationMiddleOptions> {}\n","import {Directive} from '@angular/core';\nimport {TuiPopoverDirective} from '@taiga-ui/cdk/directives/popover';\nimport {tuiAsPopover} from '@taiga-ui/cdk/services';\n\nimport {type TuiNotificationMiddleOptions} from './notification-middle.component';\nimport {TuiNotificationMiddleService} from './notification-middle.service';\n\n@Directive({\n standalone: true,\n selector: 'ng-template[tuiNotificationMiddle]',\n inputs: ['options: tuiNotificationMiddleOptions', 'open: tuiNotificationMiddle'],\n outputs: ['openChange: tuiNotificationMiddleChange'],\n providers: [tuiAsPopover(TuiNotificationMiddleService)],\n})\nexport class TuiNotificationMiddle extends TuiPopoverDirective<TuiNotificationMiddleOptions> {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;;;;;MAkCa,8BAA8B,CAAA;AAtB3C,IAAA,WAAA,GAAA;QAuBuB,IAAE,CAAA,EAAA,GAAG,gBAAgB,EAAE;QACvB,IAAO,CAAA,OAAA,GACtB,aAAa,EAAkD;AAatE;AAXa,IAAA,OAAO,CAAC,MAAmB,EAAA;AACjC,QAAA,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;AAC5C,YAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE;;;AAIzC,IAAA,IAAY,QAAQ,GAAA;AAChB,QAAA,OAAO,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ;AACjC,cAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;AACvB,cAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;;+GAdtB,8BAA8B,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;mGAA9B,8BAA8B,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,yBAAA,EAAA,IAAA,EAAA,EAAA,SAAA,EAAA,EAAA,wBAAA,EAAA,wBAAA,EAAA,sBAAA,EAAA,+BAAA,EAAA,kBAAA,EAAA,8DAAA,EAAA,EAAA,EAAA,SAAA,EAX5B,CAAC,wBAAwB,CAAC,EAAC,IAAI,EAAE,GAAG,EAAC,CAAC,CAAC,EARxC,cAAA,EAAA,CAAA,EAAA,SAAA,EAAA,EAAA,CAAA,WAAA,EAAA,EAAA,EAAA,SAAA,EAAA,EAAA,CAAA,gBAAA,EAAA,OAAA,EAAA,CAAA,kBAAA,EAAA,kBAAA,CAAA,EAAA,CAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EAAA;;;;;KAKT,EANS,QAAA,EAAA,IAAA,EAAA,MAAA,EAAA,CAAA,0yCAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,kBAAkB,8HAAE,SAAS,EAAA,QAAA,EAAA,YAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,cAAA,EAAA,SAAA,EAAA,aAAA,EAAA,YAAA,CAAA,EAAA,CAAA,EAAA,eAAA,EAAA,EAAA,CAAA,uBAAA,CAAA,MAAA,EAAA,CAAA,CAAA;;4FAoB9B,8BAA8B,EAAA,UAAA,EAAA,CAAA;kBAtB1C,SAAS;AACI,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,yBAAyB,WAC1B,CAAC,kBAAkB,EAAE,SAAS,CAAC,EAC9B,QAAA,EAAA;;;;;AAKT,IAAA,CAAA,EAAA,eAAA,EAEgB,uBAAuB,CAAC,MAAM,EAAA,SAAA,EACpC,CAAC,wBAAwB,CAAC,EAAC,IAAI,EAAE,GAAG,EAAC,CAAC,CAAC,EAClC,cAAA,EAAA;wBACZ,WAAW;wBACX,EAAC,SAAS,EAAE,gBAAgB,EAAE,OAAO,EAAE,CAAC,kBAAkB,CAAC,EAAC;qBAC/D,EACK,IAAA,EAAA;AACF,wBAAA,0BAA0B,EAAE,wBAAwB;AACpD,wBAAA,wBAAwB,EAAE,+BAA+B;AACzD,wBAAA,oBAAoB,EAAE,0DAA0D;AACnF,qBAAA,EAAA,MAAA,EAAA,CAAA,0yCAAA,CAAA,EAAA;;;AChBC,MAAO,4BAA6B,SAAQ,iBAA+C,CAAA;+GAApF,4BAA4B,EAAA,IAAA,EAAA,IAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA,CAAA;AAA5B,IAAA,SAAA,IAAA,CAAA,KAAA,GAAA,EAAA,CAAA,qBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,4BAA4B,EANzB,UAAA,EAAA,MAAM,EACN,UAAA,EAAA,MACR,IAAI,4BAA4B,CAAC,WAAW,EAAE,8BAA8B,EAAE;AAC1E,YAAA,QAAQ,EAAE,KAAK;SAClB,CAAC,EAAA,CAAA,CAAA;;4FAEG,4BAA4B,EAAA,UAAA,EAAA,CAAA;kBAPxC,UAAU;AAAC,YAAA,IAAA,EAAA,CAAA;AACR,oBAAA,UAAU,EAAE,MAAM;oBAClB,UAAU,EAAE,MACR,iCAAiC,WAAW,EAAE,8BAA8B,EAAE;AAC1E,wBAAA,QAAQ,EAAE,KAAK;qBAClB,CAAC;AACT,iBAAA;;;ACDK,MAAO,qBAAsB,SAAQ,mBAAiD,CAAA;+GAA/E,qBAAqB,EAAA,IAAA,EAAA,IAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;AAArB,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,IAAA,EAAA,qBAAqB,oPAFnB,CAAC,YAAY,CAAC,4BAA4B,CAAC,CAAC,EAAA,eAAA,EAAA,IAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA;;4FAE9C,qBAAqB,EAAA,UAAA,EAAA,CAAA;kBAPjC,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,UAAU,EAAE,IAAI;AAChB,oBAAA,QAAQ,EAAE,oCAAoC;AAC9C,oBAAA,MAAM,EAAE,CAAC,uCAAuC,EAAE,6BAA6B,CAAC;oBAChF,OAAO,EAAE,CAAC,yCAAyC,CAAC;AACpD,oBAAA,SAAS,EAAE,CAAC,YAAY,CAAC,4BAA4B,CAAC,CAAC;AAC1D,iBAAA;;;ACbD;;AAEG;;;;"}
@@ -1,6 +1,6 @@
1
1
  import { NgTemplateOutlet } from '@angular/common';
2
2
  import * as i0 from '@angular/core';
3
- import { signal, inject, Component, ChangeDetectionStrategy, ViewChildren, Input } from '@angular/core';
3
+ import { signal, inject, Input, ViewChildren, ChangeDetectionStrategy, Component } from '@angular/core';
4
4
  import { toSignal, takeUntilDestroyed } from '@angular/core/rxjs-interop';
5
5
  import { FormsModule } from '@angular/forms';
6
6
  import { MutationObserverService, WA_MUTATION_OBSERVER_INIT } from '@ng-web-apis/mutation-observer';
@@ -13,7 +13,7 @@ class TuiPager {
13
13
  this.start = 0;
14
14
  this.end = 0;
15
15
  this.left = signal(0);
16
- this.maxWidth = toSignal(inject(MutationObserverService, { self: true }).pipe(delay(0), map(() => this.visibleWidth), tuiWatch(), takeUntilDestroyed()));
16
+ this.maxWidth = toSignal(inject(MutationObserverService, { self: true }).pipe(delay(0), map(() => this.visibleWidth), tuiWatch(), takeUntilDestroyed()), { initialValue: 0 });
17
17
  this.max = 6;
18
18
  this.count = this.max;
19
19
  this.size = 'm';
@@ -48,8 +48,8 @@ class TuiPager {
48
48
  }
49
49
  this.left.set(-1 * left);
50
50
  }
51
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiPager, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
52
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiPager, isStandalone: true, selector: "tui-pager", inputs: { max: "max", count: "count", size: "size", valueContent: "valueContent", index: "index" }, host: { properties: { "attr.data-size": "size", "style.--t-gap.px": "gap", "style.max-width.px": "maxWidth()" } }, providers: [
51
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiPager, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
52
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.15", type: TuiPager, isStandalone: true, selector: "tui-pager", inputs: { max: "max", count: "count", size: "size", valueContent: "valueContent", index: "index" }, host: { properties: { "attr.data-size": "size", "style.--t-gap.px": "gap", "style.max-width.px": "maxWidth()" } }, providers: [
53
53
  MutationObserverService,
54
54
  {
55
55
  provide: WA_MUTATION_OBSERVER_INIT,
@@ -60,11 +60,11 @@ class TuiPager {
60
60
  subtree: true,
61
61
  },
62
62
  },
63
- ], viewQueries: [{ propertyName: "items", predicate: ["item"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"t-items\"\n [style.transform]=\"'translateX(calc(var(--tui-inline) * ' + left() + 'px))'\"\n>\n <div\n *tuiRepeatTimes=\"let i of count\"\n #item\n class=\"t-item\"\n [attr.data-index]=\"i\"\n [class._active]=\"i === index\"\n [class._last]=\"i === count - 1\"\n [class._post-active]=\"i === index + 1\"\n [class._pre-active]=\"i === index - 1\"\n [class._pre-last]=\"i === count - 2\"\n [class._visible]=\"i >= start && i <= end\"\n >\n <ng-container *ngTemplateOutlet=\"valueContent || null; context: {$implicit: i}\" />\n </div>\n</div>\n", styles: [":host{--t-size: .5rem;display:flex;align-items:center;overflow:hidden}:host :host-context(tui-root._mobile){--t-size: .375rem}:host[data-size=m]{min-block-size:1.25rem;--t-small-dot: scale(.75);--t-super-small-dot: scale(.5);--t-icon-size: 1rem}:host-context(tui-root._mobile) :host[data-size=m]{--t-icon-size: .875rem}:host[data-size=s]{min-block-size:1rem;--t-small-dot: scale(.5);--t-super-small-dot: scale(.25);--t-icon-size: .875rem}:host-context(tui-root._mobile) :host[data-size=s]{--t-icon-size: .6875rem}.t-items{display:flex;gap:var(--t-gap);transition:transform var(--tui-duration-fast, .15s) var(--tui-curve-productive-standard, cubic-bezier(.2, 0, .4, .9))}.t-item{display:flex;align-self:center;align-items:center;justify-content:center;color:var(--tui-background-neutral-2)}.t-item._active{color:var(--tui-background-accent-1)}.t-item:empty:before{content:\"\";display:flex;min-inline-size:var(--t-size);min-block-size:var(--t-size);border-radius:100%;background:currentColor;transition:inherit}.t-item:empty:not(._visible):before,.t-item:empty:not(._visible)+.t-item:not(._active):not(._pre-active):empty:before,.t-item:empty:not(._last):not(._post-active):not(._active):nth-last-child(1 of._visible):before{transform:var(--t-super-small-dot)!important}.t-item:empty:not(._last)._post-active:nth-last-child(1 of._visible):before,.t-item:empty:not(._visible)+.t-item._pre-active:empty:before,.t-item:empty:not(._visible)+.t-item:empty+.t-item:not(._active):empty:before,.t-item:empty:not(._pre-last):nth-last-child(2 of._visible):not(._active):before{transform:var(--t-small-dot)}.t-item:empty+.t-item:not(:empty)._pre-last{transform:scale(.64)}.t-item:empty+.t-item:not(:empty)._pre-last:nth-last-child(2 of._visible){transform:scale(1)}.t-item::ng-deep>tui-icon{inline-size:var(--t-icon-size);block-size:var(--t-icon-size)}.t-item,.t-item::ng-deep>tui-icon{transition:all var(--tui-duration-fast, .15s) var(--tui-curve-productive-standard, cubic-bezier(.2, 0, .4, .9))}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: TuiRepeatTimes, selector: "[tuiRepeatTimes][tuiRepeatTimesOf]", inputs: ["tuiRepeatTimesOf"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
63
+ ], viewQueries: [{ propertyName: "items", predicate: ["item"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"t-items\"\n [style.transform]=\"`translateX(calc(var(--tui-inline) * ${left()}px))`\"\n>\n <div\n *tuiRepeatTimes=\"let i of count\"\n #item\n class=\"t-item\"\n [attr.data-index]=\"i\"\n [class._active]=\"i === index\"\n [class._last]=\"i === count - 1\"\n [class._post-active]=\"i === index + 1\"\n [class._pre-active]=\"i === index - 1\"\n [class._pre-last]=\"i === count - 2\"\n [class._visible]=\"i >= start && i <= end\"\n >\n <ng-container *ngTemplateOutlet=\"valueContent || null; context: {$implicit: i}\" />\n </div>\n</div>\n", styles: [":host{display:flex;align-items:center;overflow:hidden}:host[data-size=m]{--t-size: .5rem;--t-small-dot: scale(.75);--t-super-small-dot: scale(.5);--t-icon-size: 1rem;min-block-size:1.25rem}:host-context(tui-root._mobile) :host[data-size=m]{--t-icon-size: .875rem}:host[data-size=s]{--t-size: .375rem;--t-small-dot: scale(.666);--t-super-small-dot: scale(.333);--t-icon-size: .75rem;min-block-size:1rem}:host-context(tui-root._mobile) :host[data-size=s]{--t-icon-size: .6875rem}.t-items{display:flex;gap:var(--t-gap);transition:transform var(--tui-duration-fast, .15s) var(--tui-curve-productive-standard, cubic-bezier(.2, 0, .4, .9))}.t-item{display:flex;align-self:center;align-items:center;justify-content:center;color:var(--tui-background-neutral-2)}.t-item._active{color:var(--tui-background-accent-1)}.t-item:empty:before{content:\"\";display:flex;min-inline-size:var(--t-size);min-block-size:var(--t-size);border-radius:100%;background:currentColor;transition:inherit}.t-item:empty:not(._visible):before,.t-item:empty:not(._visible)+.t-item:not(._active):not(._pre-active):empty:before,.t-item:empty:not(._last):not(._post-active):not(._active):nth-last-child(1 of._visible):before{transform:var(--t-super-small-dot)!important}.t-item:empty:not(._last)._post-active:nth-last-child(1 of._visible):before,.t-item:empty:not(._visible)+.t-item._pre-active:empty:before,.t-item:empty:not(._visible)+.t-item:empty+.t-item:not(._active):empty:before,.t-item:empty:not(._pre-last):nth-last-child(2 of._visible):not(._active):before{transform:var(--t-small-dot)}.t-item:empty+.t-item:not(:empty)._pre-last{transform:scale(.64)}.t-item:empty+.t-item:not(:empty)._pre-last:nth-last-child(2 of._visible){transform:scale(1)}.t-item::ng-deep>tui-icon{inline-size:var(--t-icon-size);block-size:var(--t-icon-size)}.t-item,.t-item::ng-deep>tui-icon{transition:all var(--tui-duration-fast, .15s) var(--tui-curve-productive-standard, cubic-bezier(.2, 0, .4, .9))}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: TuiRepeatTimes, selector: "[tuiRepeatTimes][tuiRepeatTimesOf]", inputs: ["tuiRepeatTimesOf"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
64
64
  }
65
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiPager, decorators: [{
65
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.15", ngImport: i0, type: TuiPager, decorators: [{
66
66
  type: Component,
67
- args: [{ standalone: true, selector: 'tui-pager', imports: [FormsModule, NgTemplateOutlet, TuiRepeatTimes], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
67
+ args: [{ selector: 'tui-pager', imports: [FormsModule, NgTemplateOutlet, TuiRepeatTimes], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
68
68
  MutationObserverService,
69
69
  {
70
70
  provide: WA_MUTATION_OBSERVER_INIT,
@@ -79,7 +79,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
79
79
  '[attr.data-size]': 'size',
80
80
  '[style.--t-gap.px]': 'gap',
81
81
  '[style.max-width.px]': 'maxWidth()',
82
- }, template: "<div\n class=\"t-items\"\n [style.transform]=\"'translateX(calc(var(--tui-inline) * ' + left() + 'px))'\"\n>\n <div\n *tuiRepeatTimes=\"let i of count\"\n #item\n class=\"t-item\"\n [attr.data-index]=\"i\"\n [class._active]=\"i === index\"\n [class._last]=\"i === count - 1\"\n [class._post-active]=\"i === index + 1\"\n [class._pre-active]=\"i === index - 1\"\n [class._pre-last]=\"i === count - 2\"\n [class._visible]=\"i >= start && i <= end\"\n >\n <ng-container *ngTemplateOutlet=\"valueContent || null; context: {$implicit: i}\" />\n </div>\n</div>\n", styles: [":host{--t-size: .5rem;display:flex;align-items:center;overflow:hidden}:host :host-context(tui-root._mobile){--t-size: .375rem}:host[data-size=m]{min-block-size:1.25rem;--t-small-dot: scale(.75);--t-super-small-dot: scale(.5);--t-icon-size: 1rem}:host-context(tui-root._mobile) :host[data-size=m]{--t-icon-size: .875rem}:host[data-size=s]{min-block-size:1rem;--t-small-dot: scale(.5);--t-super-small-dot: scale(.25);--t-icon-size: .875rem}:host-context(tui-root._mobile) :host[data-size=s]{--t-icon-size: .6875rem}.t-items{display:flex;gap:var(--t-gap);transition:transform var(--tui-duration-fast, .15s) var(--tui-curve-productive-standard, cubic-bezier(.2, 0, .4, .9))}.t-item{display:flex;align-self:center;align-items:center;justify-content:center;color:var(--tui-background-neutral-2)}.t-item._active{color:var(--tui-background-accent-1)}.t-item:empty:before{content:\"\";display:flex;min-inline-size:var(--t-size);min-block-size:var(--t-size);border-radius:100%;background:currentColor;transition:inherit}.t-item:empty:not(._visible):before,.t-item:empty:not(._visible)+.t-item:not(._active):not(._pre-active):empty:before,.t-item:empty:not(._last):not(._post-active):not(._active):nth-last-child(1 of._visible):before{transform:var(--t-super-small-dot)!important}.t-item:empty:not(._last)._post-active:nth-last-child(1 of._visible):before,.t-item:empty:not(._visible)+.t-item._pre-active:empty:before,.t-item:empty:not(._visible)+.t-item:empty+.t-item:not(._active):empty:before,.t-item:empty:not(._pre-last):nth-last-child(2 of._visible):not(._active):before{transform:var(--t-small-dot)}.t-item:empty+.t-item:not(:empty)._pre-last{transform:scale(.64)}.t-item:empty+.t-item:not(:empty)._pre-last:nth-last-child(2 of._visible){transform:scale(1)}.t-item::ng-deep>tui-icon{inline-size:var(--t-icon-size);block-size:var(--t-icon-size)}.t-item,.t-item::ng-deep>tui-icon{transition:all var(--tui-duration-fast, .15s) var(--tui-curve-productive-standard, cubic-bezier(.2, 0, .4, .9))}\n"] }]
82
+ }, template: "<div\n class=\"t-items\"\n [style.transform]=\"`translateX(calc(var(--tui-inline) * ${left()}px))`\"\n>\n <div\n *tuiRepeatTimes=\"let i of count\"\n #item\n class=\"t-item\"\n [attr.data-index]=\"i\"\n [class._active]=\"i === index\"\n [class._last]=\"i === count - 1\"\n [class._post-active]=\"i === index + 1\"\n [class._pre-active]=\"i === index - 1\"\n [class._pre-last]=\"i === count - 2\"\n [class._visible]=\"i >= start && i <= end\"\n >\n <ng-container *ngTemplateOutlet=\"valueContent || null; context: {$implicit: i}\" />\n </div>\n</div>\n", styles: [":host{display:flex;align-items:center;overflow:hidden}:host[data-size=m]{--t-size: .5rem;--t-small-dot: scale(.75);--t-super-small-dot: scale(.5);--t-icon-size: 1rem;min-block-size:1.25rem}:host-context(tui-root._mobile) :host[data-size=m]{--t-icon-size: .875rem}:host[data-size=s]{--t-size: .375rem;--t-small-dot: scale(.666);--t-super-small-dot: scale(.333);--t-icon-size: .75rem;min-block-size:1rem}:host-context(tui-root._mobile) :host[data-size=s]{--t-icon-size: .6875rem}.t-items{display:flex;gap:var(--t-gap);transition:transform var(--tui-duration-fast, .15s) var(--tui-curve-productive-standard, cubic-bezier(.2, 0, .4, .9))}.t-item{display:flex;align-self:center;align-items:center;justify-content:center;color:var(--tui-background-neutral-2)}.t-item._active{color:var(--tui-background-accent-1)}.t-item:empty:before{content:\"\";display:flex;min-inline-size:var(--t-size);min-block-size:var(--t-size);border-radius:100%;background:currentColor;transition:inherit}.t-item:empty:not(._visible):before,.t-item:empty:not(._visible)+.t-item:not(._active):not(._pre-active):empty:before,.t-item:empty:not(._last):not(._post-active):not(._active):nth-last-child(1 of._visible):before{transform:var(--t-super-small-dot)!important}.t-item:empty:not(._last)._post-active:nth-last-child(1 of._visible):before,.t-item:empty:not(._visible)+.t-item._pre-active:empty:before,.t-item:empty:not(._visible)+.t-item:empty+.t-item:not(._active):empty:before,.t-item:empty:not(._pre-last):nth-last-child(2 of._visible):not(._active):before{transform:var(--t-small-dot)}.t-item:empty+.t-item:not(:empty)._pre-last{transform:scale(.64)}.t-item:empty+.t-item:not(:empty)._pre-last:nth-last-child(2 of._visible){transform:scale(1)}.t-item::ng-deep>tui-icon{inline-size:var(--t-icon-size);block-size:var(--t-icon-size)}.t-item,.t-item::ng-deep>tui-icon{transition:all var(--tui-duration-fast, .15s) var(--tui-curve-productive-standard, cubic-bezier(.2, 0, .4, .9))}\n"] }]
83
83
  }], propDecorators: { items: [{
84
84
  type: ViewChildren,
85
85
  args: ['item']
@@ -1 +1 @@
1
- {"version":3,"file":"taiga-ui-kit-components-pager.mjs","sources":["../../../projects/kit/components/pager/pager.component.ts","../../../projects/kit/components/pager/pager.component.html","../../../projects/kit/components/pager/taiga-ui-kit-components-pager.ts"],"sourcesContent":["import {NgTemplateOutlet} from '@angular/common';\nimport {\n type AfterViewInit,\n ChangeDetectionStrategy,\n Component,\n type ElementRef,\n inject,\n Input,\n type OnChanges,\n type QueryList,\n signal,\n type TemplateRef,\n ViewChildren,\n} from '@angular/core';\nimport {takeUntilDestroyed, toSignal} from '@angular/core/rxjs-interop';\nimport {FormsModule} from '@angular/forms';\nimport {\n MutationObserverService,\n WA_MUTATION_OBSERVER_INIT,\n} from '@ng-web-apis/mutation-observer';\nimport {TuiRepeatTimes} from '@taiga-ui/cdk/directives/repeat-times';\nimport {tuiWatch} from '@taiga-ui/cdk/observables';\nimport {type TuiSizeS} from '@taiga-ui/core/types';\nimport {delay, map} from 'rxjs';\n\n@Component({\n standalone: true,\n selector: 'tui-pager',\n imports: [FormsModule, NgTemplateOutlet, TuiRepeatTimes],\n templateUrl: './pager.component.html',\n styleUrls: ['./pager.styles.less'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n providers: [\n MutationObserverService,\n {\n provide: WA_MUTATION_OBSERVER_INIT,\n useValue: {\n attributeOldValue: true,\n characterData: true,\n childList: true,\n subtree: true,\n },\n },\n ],\n host: {\n '[attr.data-size]': 'size',\n '[style.--t-gap.px]': 'gap',\n '[style.max-width.px]': 'maxWidth()',\n },\n})\nexport class TuiPager implements OnChanges, AfterViewInit {\n @ViewChildren('item')\n protected items?: QueryList<ElementRef<HTMLElement>>;\n\n protected start = 0;\n protected end = 0;\n protected left = signal(0);\n protected readonly maxWidth = toSignal(\n inject(MutationObserverService, {self: true}).pipe(\n delay(0),\n map(() => this.visibleWidth),\n tuiWatch(),\n takeUntilDestroyed(),\n ),\n );\n\n @Input()\n public max = 6;\n\n @Input()\n public count = this.max;\n\n @Input()\n public size: TuiSizeS = 'm';\n\n @Input()\n public valueContent?: TemplateRef<unknown>;\n\n @Input()\n public index = 0;\n\n public ngOnChanges(): void {\n this.move();\n }\n\n public ngAfterViewInit(): void {\n this.move();\n }\n\n protected get gap(): number {\n return this.size === 'm' ? 9 : 7;\n }\n\n private get visibleRange(): [start: number, end: number] {\n const max = this.max > this.count ? this.count : this.max;\n\n const start = Math.min(\n Math.max(this.index - Math.floor(max / 2), 0),\n this.count - max,\n );\n\n return [start, start + (max - 1)];\n }\n\n private get visibleWidth(): number {\n return (\n (this.items?.map((item) => item.nativeElement.offsetWidth ?? 0) ?? [])\n .slice(this.start, this.end + 1)\n .reduce((sum, item) => sum + item + this.gap, 0) - this.gap\n );\n }\n\n private move(): void {\n const [start, end] = this.visibleRange;\n\n this.start = start;\n this.end = end;\n\n let left = this.start * this.gap;\n\n for (let i = 0; i < this.start; i++) {\n left += this.items?.get(i)?.nativeElement.offsetWidth ?? 0;\n }\n\n this.left.set(-1 * left);\n }\n}\n","<div\n class=\"t-items\"\n [style.transform]=\"'translateX(calc(var(--tui-inline) * ' + left() + 'px))'\"\n>\n <div\n *tuiRepeatTimes=\"let i of count\"\n #item\n class=\"t-item\"\n [attr.data-index]=\"i\"\n [class._active]=\"i === index\"\n [class._last]=\"i === count - 1\"\n [class._post-active]=\"i === index + 1\"\n [class._pre-active]=\"i === index - 1\"\n [class._pre-last]=\"i === count - 2\"\n [class._visible]=\"i >= start && i <= end\"\n >\n <ng-container *ngTemplateOutlet=\"valueContent || null; context: {$implicit: i}\" />\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-kit-components-pager.mjs","sources":["../../../projects/kit/components/pager/pager.component.ts","../../../projects/kit/components/pager/pager.component.html","../../../projects/kit/components/pager/taiga-ui-kit-components-pager.ts"],"sourcesContent":["import {NgTemplateOutlet} from '@angular/common';\nimport {\n type AfterViewInit,\n ChangeDetectionStrategy,\n Component,\n type ElementRef,\n inject,\n Input,\n type OnChanges,\n type QueryList,\n signal,\n type TemplateRef,\n ViewChildren,\n} from '@angular/core';\nimport {takeUntilDestroyed, toSignal} from '@angular/core/rxjs-interop';\nimport {FormsModule} from '@angular/forms';\nimport {\n MutationObserverService,\n WA_MUTATION_OBSERVER_INIT,\n} from '@ng-web-apis/mutation-observer';\nimport {TuiRepeatTimes} from '@taiga-ui/cdk/directives/repeat-times';\nimport {tuiWatch} from '@taiga-ui/cdk/observables';\nimport {type TuiSizeS} from '@taiga-ui/core/types';\nimport {delay, map} from 'rxjs';\n\n@Component({\n selector: 'tui-pager',\n imports: [FormsModule, NgTemplateOutlet, TuiRepeatTimes],\n templateUrl: './pager.component.html',\n styleUrl: './pager.styles.less',\n changeDetection: ChangeDetectionStrategy.OnPush,\n providers: [\n MutationObserverService,\n {\n provide: WA_MUTATION_OBSERVER_INIT,\n useValue: {\n attributeOldValue: true,\n characterData: true,\n childList: true,\n subtree: true,\n },\n },\n ],\n host: {\n '[attr.data-size]': 'size',\n '[style.--t-gap.px]': 'gap',\n '[style.max-width.px]': 'maxWidth()',\n },\n})\nexport class TuiPager implements OnChanges, AfterViewInit {\n @ViewChildren('item')\n protected items?: QueryList<ElementRef<HTMLElement>>;\n\n protected start = 0;\n protected end = 0;\n protected left = signal(0);\n protected readonly maxWidth = toSignal(\n inject(MutationObserverService, {self: true}).pipe(\n delay(0),\n map(() => this.visibleWidth),\n tuiWatch(),\n takeUntilDestroyed(),\n ),\n {initialValue: 0},\n );\n\n @Input()\n public max = 6;\n\n @Input()\n public count = this.max;\n\n @Input()\n public size: TuiSizeS = 'm';\n\n @Input()\n public valueContent?: TemplateRef<unknown>;\n\n @Input()\n public index = 0;\n\n public ngOnChanges(): void {\n this.move();\n }\n\n public ngAfterViewInit(): void {\n this.move();\n }\n\n protected get gap(): number {\n return this.size === 'm' ? 9 : 7;\n }\n\n private get visibleRange(): [start: number, end: number] {\n const max = this.max > this.count ? this.count : this.max;\n\n const start = Math.min(\n Math.max(this.index - Math.floor(max / 2), 0),\n this.count - max,\n );\n\n return [start, start + (max - 1)];\n }\n\n private get visibleWidth(): number {\n return (\n (this.items?.map((item) => item.nativeElement.offsetWidth ?? 0) ?? [])\n .slice(this.start, this.end + 1)\n .reduce((sum, item) => sum + item + this.gap, 0) - this.gap\n );\n }\n\n private move(): void {\n const [start, end] = this.visibleRange;\n\n this.start = start;\n this.end = end;\n\n let left = this.start * this.gap;\n\n for (let i = 0; i < this.start; i++) {\n left += this.items?.get(i)?.nativeElement.offsetWidth ?? 0;\n }\n\n this.left.set(-1 * left);\n }\n}\n","<div\n class=\"t-items\"\n [style.transform]=\"`translateX(calc(var(--tui-inline) * ${left()}px))`\"\n>\n <div\n *tuiRepeatTimes=\"let i of count\"\n #item\n class=\"t-item\"\n [attr.data-index]=\"i\"\n [class._active]=\"i === index\"\n [class._last]=\"i === count - 1\"\n [class._post-active]=\"i === index + 1\"\n [class._pre-active]=\"i === index - 1\"\n [class._pre-last]=\"i === count - 2\"\n [class._visible]=\"i >= start && i <= end\"\n >\n <ng-container *ngTemplateOutlet=\"valueContent || null; context: {$implicit: i}\" />\n </div>\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}