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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (655) hide show
  1. package/README.md +1 -1
  2. package/classes/accessors.d.ts +2 -2
  3. package/classes/driver.d.ts +1 -1
  4. package/components/button/button.directive.d.ts +2 -3
  5. package/components/button/button.options.d.ts +1 -1
  6. package/components/calendar/calendar-sheet.component.d.ts +2 -7
  7. package/components/calendar/calendar-sheet.options.d.ts +1 -3
  8. package/{pipes/calendar-sheet → components/calendar}/calendar-sheet.pipe.d.ts +2 -2
  9. package/components/calendar/calendar-spin.component.d.ts +1 -0
  10. package/components/calendar/calendar-year.component.d.ts +1 -1
  11. package/components/calendar/calendar.options.d.ts +9 -0
  12. package/components/calendar/index.d.ts +3 -0
  13. package/{pipes/order-week-days → components/calendar}/order-week-days.pipe.d.ts +1 -1
  14. package/components/cell/cell.directive.d.ts +9 -0
  15. package/components/cell/cell.options.d.ts +6 -0
  16. package/components/cell/index.d.ts +2 -0
  17. package/components/data-list/data-list.component.d.ts +8 -12
  18. package/components/data-list/data-list.d.ts +3 -4
  19. package/components/data-list/data-list.tokens.d.ts +1 -20
  20. package/components/data-list/index.d.ts +3 -4
  21. package/components/data-list/opt-group.directive.d.ts +2 -2
  22. package/components/data-list/option-content.directive.d.ts +14 -0
  23. package/components/data-list/option-with-value.directive.d.ts +9 -0
  24. package/components/data-list/option.directive.d.ts +19 -0
  25. package/components/error/error.component.d.ts +6 -8
  26. package/components/error/error.d.ts +4 -0
  27. package/components/error/error.directive.d.ts +19 -0
  28. package/components/error/error.pipe.d.ts +10 -0
  29. package/components/error/index.d.ts +3 -0
  30. package/components/expand/expand.component.d.ts +9 -28
  31. package/components/expand/index.d.ts +0 -2
  32. package/components/icon/icon.component.d.ts +6 -11
  33. package/components/index.d.ts +3 -3
  34. package/components/input/index.d.ts +2 -0
  35. package/components/input/input.d.ts +5 -0
  36. package/components/input/input.directive.d.ts +29 -0
  37. package/components/label/label.directive.d.ts +1 -1
  38. package/components/link/index.d.ts +0 -1
  39. package/components/link/link.directive.d.ts +8 -6
  40. package/components/loader/loader.component.d.ts +7 -7
  41. package/components/loader/loader.options.d.ts +1 -3
  42. package/components/notification/index.d.ts +3 -0
  43. package/components/notification/notification.component.d.ts +14 -0
  44. package/components/notification/notification.d.ts +3 -0
  45. package/components/notification/notification.directive.d.ts +7 -12
  46. package/components/notification/notification.options.d.ts +10 -7
  47. package/components/notification/notification.service.d.ts +17 -0
  48. package/components/root/root.component.d.ts +4 -7
  49. package/components/scrollbar/scroll-into-view.directive.d.ts +3 -2
  50. package/components/scrollbar/scroll-ref.directive.d.ts +2 -0
  51. package/components/scrollbar/scrollbar.component.d.ts +1 -5
  52. package/components/scrollbar/scrollbar.directive.d.ts +2 -2
  53. package/components/scrollbar/scrollbar.options.d.ts +1 -1
  54. package/components/spin-button/spin-button.component.d.ts +9 -10
  55. package/components/textfield/index.d.ts +1 -4
  56. package/components/textfield/select-like.directive.d.ts +1 -0
  57. package/components/textfield/textfield-content.directive.d.ts +3 -2
  58. package/components/textfield/textfield-icon.d.ts +3 -3
  59. package/components/textfield/textfield-multi/textfield-item.component.d.ts +3 -2
  60. package/components/textfield/textfield-multi/textfield-multi.component.d.ts +9 -15
  61. package/components/textfield/textfield.component.d.ts +20 -35
  62. package/components/textfield/textfield.d.ts +2 -4
  63. package/components/textfield/textfield.options.d.ts +8 -11
  64. package/{directives → components}/title/title.directive.d.ts +2 -3
  65. package/directives/appearance/appearance.directive.d.ts +5 -13
  66. package/directives/appearance/appearance.options.d.ts +1 -2
  67. package/directives/button-x/button-x.directive.d.ts +6 -0
  68. package/directives/button-x/index.d.ts +1 -0
  69. package/directives/date-format/date-format.directive.d.ts +3 -7
  70. package/directives/group/group.directive.d.ts +7 -7
  71. package/directives/group/group.options.d.ts +1 -3
  72. package/directives/icons/icons.bindings.d.ts +5 -0
  73. package/directives/icons/icons.directive.d.ts +8 -16
  74. package/directives/icons/index.d.ts +1 -0
  75. package/directives/index.d.ts +1 -5
  76. package/directives/items-handlers/items-handlers.directive.d.ts +5 -9
  77. package/directives/items-handlers/items-handlers.tokens.d.ts +4 -4
  78. package/directives/number-format/number-format.directive.d.ts +3 -7
  79. package/fesm2022/taiga-ui-core-classes.mjs +9 -11
  80. package/fesm2022/taiga-ui-core-classes.mjs.map +1 -1
  81. package/fesm2022/taiga-ui-core-components-button.mjs +13 -21
  82. package/fesm2022/taiga-ui-core-components-button.mjs.map +1 -1
  83. package/fesm2022/taiga-ui-core-components-calendar.mjs +144 -47
  84. package/fesm2022/taiga-ui-core-components-calendar.mjs.map +1 -1
  85. package/fesm2022/taiga-ui-core-components-cell.mjs +45 -0
  86. package/fesm2022/taiga-ui-core-components-cell.mjs.map +1 -0
  87. package/fesm2022/taiga-ui-core-components-data-list.mjs +113 -284
  88. package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
  89. package/fesm2022/taiga-ui-core-components-error.mjs +110 -26
  90. package/fesm2022/taiga-ui-core-components-error.mjs.map +1 -1
  91. package/fesm2022/taiga-ui-core-components-expand.mjs +34 -132
  92. package/fesm2022/taiga-ui-core-components-expand.mjs.map +1 -1
  93. package/fesm2022/taiga-ui-core-components-icon.mjs +22 -40
  94. package/fesm2022/taiga-ui-core-components-icon.mjs.map +1 -1
  95. package/fesm2022/taiga-ui-core-components-input.mjs +100 -0
  96. package/fesm2022/taiga-ui-core-components-input.mjs.map +1 -0
  97. package/fesm2022/taiga-ui-core-components-label.mjs +13 -18
  98. package/fesm2022/taiga-ui-core-components-label.mjs.map +1 -1
  99. package/fesm2022/taiga-ui-core-components-link.mjs +16 -36
  100. package/fesm2022/taiga-ui-core-components-link.mjs.map +1 -1
  101. package/fesm2022/taiga-ui-core-components-loader.mjs +20 -40
  102. package/fesm2022/taiga-ui-core-components-loader.mjs.map +1 -1
  103. package/fesm2022/taiga-ui-core-components-notification.mjs +107 -66
  104. package/fesm2022/taiga-ui-core-components-notification.mjs.map +1 -1
  105. package/fesm2022/taiga-ui-core-components-root.mjs +23 -60
  106. package/fesm2022/taiga-ui-core-components-root.mjs.map +1 -1
  107. package/fesm2022/taiga-ui-core-components-scrollbar.mjs +73 -87
  108. package/fesm2022/taiga-ui-core-components-scrollbar.mjs.map +1 -1
  109. package/fesm2022/taiga-ui-core-components-spin-button.mjs +18 -31
  110. package/fesm2022/taiga-ui-core-components-spin-button.mjs.map +1 -1
  111. package/fesm2022/taiga-ui-core-components-textfield.mjs +165 -463
  112. package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
  113. package/fesm2022/taiga-ui-core-components-title.mjs +37 -0
  114. package/fesm2022/taiga-ui-core-components-title.mjs.map +1 -0
  115. package/fesm2022/taiga-ui-core-components.mjs +3 -3
  116. package/fesm2022/taiga-ui-core-directives-appearance.mjs +32 -69
  117. package/fesm2022/taiga-ui-core-directives-appearance.mjs.map +1 -1
  118. package/fesm2022/taiga-ui-core-directives-button-x.mjs +51 -0
  119. package/fesm2022/taiga-ui-core-directives-button-x.mjs.map +1 -0
  120. package/fesm2022/taiga-ui-core-directives-date-format.mjs +26 -20
  121. package/fesm2022/taiga-ui-core-directives-date-format.mjs.map +1 -1
  122. package/fesm2022/taiga-ui-core-directives-group.mjs +25 -40
  123. package/fesm2022/taiga-ui-core-directives-group.mjs.map +1 -1
  124. package/fesm2022/taiga-ui-core-directives-icons.mjs +35 -45
  125. package/fesm2022/taiga-ui-core-directives-icons.mjs.map +1 -1
  126. package/fesm2022/taiga-ui-core-directives-items-handlers.mjs +18 -42
  127. package/fesm2022/taiga-ui-core-directives-items-handlers.mjs.map +1 -1
  128. package/fesm2022/taiga-ui-core-directives-number-format.mjs +32 -20
  129. package/fesm2022/taiga-ui-core-directives-number-format.mjs.map +1 -1
  130. package/fesm2022/taiga-ui-core-directives.mjs +1 -5
  131. package/fesm2022/taiga-ui-core-directives.mjs.map +1 -1
  132. package/fesm2022/taiga-ui-core-pipes-format-number.mjs +21 -15
  133. package/fesm2022/taiga-ui-core-pipes-format-number.mjs.map +1 -1
  134. package/fesm2022/taiga-ui-core-pipes.mjs +0 -8
  135. package/fesm2022/taiga-ui-core-pipes.mjs.map +1 -1
  136. package/fesm2022/taiga-ui-core-portals-alert.mjs +73 -0
  137. package/fesm2022/taiga-ui-core-portals-alert.mjs.map +1 -0
  138. package/fesm2022/taiga-ui-core-portals-dialog.mjs +159 -0
  139. package/fesm2022/taiga-ui-core-portals-dialog.mjs.map +1 -0
  140. package/fesm2022/{taiga-ui-core-directives-dropdown.mjs → taiga-ui-core-portals-dropdown.mjs} +249 -414
  141. package/fesm2022/taiga-ui-core-portals-dropdown.mjs.map +1 -0
  142. package/fesm2022/taiga-ui-core-portals-hint.mjs +552 -0
  143. package/fesm2022/taiga-ui-core-portals-hint.mjs.map +1 -0
  144. package/fesm2022/taiga-ui-core-portals-modal.mjs +89 -0
  145. package/fesm2022/taiga-ui-core-portals-modal.mjs.map +1 -0
  146. package/fesm2022/taiga-ui-core-portals-popup.mjs +56 -0
  147. package/fesm2022/taiga-ui-core-portals-popup.mjs.map +1 -0
  148. package/fesm2022/taiga-ui-core-portals.mjs +11 -0
  149. package/fesm2022/taiga-ui-core-portals.mjs.map +1 -0
  150. package/fesm2022/taiga-ui-core-services.mjs +17 -81
  151. package/fesm2022/taiga-ui-core-services.mjs.map +1 -1
  152. package/fesm2022/taiga-ui-core-tokens.mjs +62 -81
  153. package/fesm2022/taiga-ui-core-tokens.mjs.map +1 -1
  154. package/fesm2022/taiga-ui-core-utils-dom.mjs.map +1 -1
  155. package/fesm2022/taiga-ui-core-utils-format.mjs +1 -22
  156. package/fesm2022/taiga-ui-core-utils-format.mjs.map +1 -1
  157. package/fesm2022/taiga-ui-core-utils-miscellaneous.mjs +55 -19
  158. package/fesm2022/taiga-ui-core-utils-miscellaneous.mjs.map +1 -1
  159. package/fesm2022/taiga-ui-core.mjs +1 -1
  160. package/index.d.ts +1 -1
  161. package/package.json +61 -182
  162. package/pipes/format-number/format-number.pipe.d.ts +6 -4
  163. package/pipes/index.d.ts +0 -8
  164. package/portals/alert/alert.directive.d.ts +11 -0
  165. package/portals/alert/alert.service.d.ts +12 -0
  166. package/portals/alert/index.d.ts +2 -0
  167. package/portals/dialog/dialog.component.d.ts +14 -0
  168. package/portals/dialog/dialog.directive.d.ts +8 -0
  169. package/{components → portals}/dialog/dialog.factory.d.ts +1 -1
  170. package/portals/dialog/dialog.options.d.ts +25 -0
  171. package/{components/dialog/dialog-close.service.d.ts → portals/dialog/dialog.providers.d.ts} +2 -0
  172. package/portals/dialog/dialog.service.d.ts +10 -0
  173. package/portals/dialog/index.d.ts +6 -0
  174. package/portals/dropdown/dropdown-close.directive.d.ts +15 -0
  175. package/portals/dropdown/dropdown-content.directive.d.ts +9 -0
  176. package/{directives → portals}/dropdown/dropdown-context.directive.d.ts +0 -1
  177. package/{directives → portals}/dropdown/dropdown-hover.directive.d.ts +5 -10
  178. package/{directives → portals}/dropdown/dropdown-hover.options.d.ts +1 -3
  179. package/{directives → portals}/dropdown/dropdown-manual.directive.d.ts +2 -2
  180. package/portals/dropdown/dropdown-open.directive.d.ts +29 -0
  181. package/{directives → portals}/dropdown/dropdown-options.directive.d.ts +1 -5
  182. package/{directives → portals}/dropdown/dropdown-position-sided.directive.d.ts +3 -3
  183. package/{directives → portals}/dropdown/dropdown-position.directive.d.ts +6 -6
  184. package/{directives → portals}/dropdown/dropdown-selection.directive.d.ts +4 -5
  185. package/{directives → portals}/dropdown/dropdown.bindings.d.ts +0 -1
  186. package/{directives → portals}/dropdown/dropdown.d.ts +2 -3
  187. package/{directives → portals}/dropdown/dropdown.directive.d.ts +6 -8
  188. package/{directives → portals}/dropdown/index.d.ts +2 -4
  189. package/{directives → portals}/hint/hint-describe.directive.d.ts +4 -6
  190. package/{directives → portals}/hint/hint-host.directive.d.ts +2 -2
  191. package/{directives → portals}/hint/hint-hover.directive.d.ts +3 -4
  192. package/{directives → portals}/hint/hint-manual.directive.d.ts +2 -2
  193. package/portals/hint/hint-options.directive.d.ts +17 -0
  194. package/{directives → portals}/hint/hint-overflow.directive.d.ts +2 -2
  195. package/{directives → portals}/hint/hint-position.directive.d.ts +7 -8
  196. package/{directives → portals}/hint/hint-unstyled.component.d.ts +2 -7
  197. package/portals/hint/hint.component.d.ts +29 -0
  198. package/{directives → portals}/hint/hint.d.ts +1 -2
  199. package/portals/hint/hint.directive.d.ts +24 -0
  200. package/{directives → portals}/hint/index.d.ts +0 -2
  201. package/portals/index.d.ts +6 -0
  202. package/portals/modal/index.d.ts +2 -0
  203. package/portals/modal/modal.component.d.ts +17 -0
  204. package/portals/modal/modal.service.d.ts +13 -0
  205. package/portals/popup/popup.directive.d.ts +12 -0
  206. package/{directives → portals}/popup/popup.service.d.ts +1 -1
  207. package/{directives → portals}/popup/popups.component.d.ts +2 -2
  208. package/services/index.d.ts +0 -3
  209. package/styles/components/appearance.less +5 -0
  210. package/styles/components/button.less +10 -22
  211. package/styles/components/icon.less +42 -21
  212. package/styles/components/icons.less +18 -13
  213. package/styles/components/label.less +3 -12
  214. package/styles/components/link.less +8 -27
  215. package/styles/components/notification.less +31 -65
  216. package/styles/components/textfield.less +128 -213
  217. package/styles/components/title.less +8 -8
  218. package/styles/mixins/appearance.less +11 -26
  219. package/styles/mixins/appearance.scss +9 -24
  220. package/styles/mixins/date-picker.less +1 -1
  221. package/styles/mixins/mixins.less +1 -7
  222. package/styles/mixins/mixins.scss +1 -7
  223. package/styles/mixins/picker.less +1 -1
  224. package/styles/mixins/picker.scss +1 -1
  225. package/styles/mixins/slider.less +28 -24
  226. package/styles/mixins/slider.scss +23 -22
  227. package/styles/taiga-ui-local.less +0 -1
  228. package/styles/taiga-ui-local.scss +0 -1
  229. package/styles/taiga-ui-theme.less +0 -1
  230. package/styles/theme/appearance/outline.less +9 -18
  231. package/styles/theme/appearance/primary.less +2 -4
  232. package/styles/theme/appearance/secondary.less +6 -14
  233. package/styles/theme/appearance/status.less +0 -4
  234. package/styles/theme/appearance/table.less +36 -35
  235. package/styles/theme/appearance/textfield.less +27 -28
  236. package/styles/theme/appearance.less +0 -1
  237. package/styles/theme/variables.less +16 -19
  238. package/styles/variables/media.less +13 -18
  239. package/styles/variables/media.scss +13 -13
  240. package/tokens/breakpoint.d.ts +4 -0
  241. package/tokens/common-icons.d.ts +3 -3
  242. package/tokens/date-format.d.ts +2 -3
  243. package/tokens/i18n.d.ts +7 -7
  244. package/tokens/icon-resolver.d.ts +1 -5
  245. package/tokens/icons.d.ts +0 -4
  246. package/tokens/index.d.ts +2 -4
  247. package/tokens/number-format.d.ts +2 -3
  248. package/tokens/validation-errors.d.ts +4 -0
  249. package/types/direction.d.ts +1 -1
  250. package/types/index.d.ts +0 -3
  251. package/types/point.d.ts +1 -1
  252. package/types/size.d.ts +0 -11
  253. package/utils/format/index.d.ts +0 -1
  254. package/utils/miscellaneous/get-duration.d.ts +2 -0
  255. package/utils/miscellaneous/index.d.ts +2 -1
  256. package/utils/miscellaneous/provide-taiga.d.ts +13 -0
  257. package/animations/animations.d.ts +0 -109
  258. package/animations/index.d.ts +0 -1
  259. package/components/alert/alert.component.d.ts +0 -15
  260. package/components/alert/alert.directive.d.ts +0 -7
  261. package/components/alert/alert.interfaces.d.ts +0 -12
  262. package/components/alert/alert.service.d.ts +0 -7
  263. package/components/alert/alert.tokens.d.ts +0 -12
  264. package/components/alert/alerts.component.d.ts +0 -12
  265. package/components/alert/index.d.ts +0 -6
  266. package/components/data-list/data-list.directive.d.ts +0 -7
  267. package/components/data-list/option/option-content.d.ts +0 -16
  268. package/components/data-list/option/option-legacy.component.d.ts +0 -24
  269. package/components/data-list/option/option.directive.d.ts +0 -27
  270. package/components/dialog/active-zone-adapter.directive.d.ts +0 -11
  271. package/components/dialog/dialog.component.d.ts +0 -20
  272. package/components/dialog/dialog.directive.d.ts +0 -7
  273. package/components/dialog/dialog.interfaces.d.ts +0 -34
  274. package/components/dialog/dialog.service.d.ts +0 -7
  275. package/components/dialog/dialog.tokens.d.ts +0 -15
  276. package/components/dialog/dialogs.component.d.ts +0 -8
  277. package/components/dialog/index.d.ts +0 -8
  278. package/components/expand/expand-content.directive.d.ts +0 -8
  279. package/components/expand/expand.d.ts +0 -6
  280. package/components/fullscreen/fullscreen.component.d.ts +0 -14
  281. package/components/fullscreen/index.d.ts +0 -1
  282. package/components/link/link.options.d.ts +0 -12
  283. package/components/textfield/select.directive.d.ts +0 -19
  284. package/components/textfield/textfield-dropdown.directive.d.ts +0 -16
  285. package/components/textfield/textfield.directive.d.ts +0 -38
  286. package/directives/dropdown/dropdown-open-legacy.directive.d.ts +0 -12
  287. package/directives/dropdown/dropdown-open.directive.d.ts +0 -33
  288. package/directives/dropdown/dropdown-portal.directive.d.ts +0 -14
  289. package/directives/dropdown/dropdown.service.d.ts +0 -6
  290. package/directives/dropdown/dropdowns.component.d.ts +0 -9
  291. package/directives/hint/hint-options.directive.d.ts +0 -36
  292. package/directives/hint/hint.component.d.ts +0 -30
  293. package/directives/hint/hint.directive.d.ts +0 -26
  294. package/directives/hint/hint.service.d.ts +0 -13
  295. package/directives/hint/hints.component.d.ts +0 -12
  296. package/directives/popup/popup.directive.d.ts +0 -11
  297. package/directives/surface/index.d.ts +0 -1
  298. package/directives/surface/surface.directive.d.ts +0 -8
  299. package/esm2022/animations/animations.mjs +0 -363
  300. package/esm2022/animations/index.mjs +0 -2
  301. package/esm2022/animations/taiga-ui-core-animations.mjs +0 -5
  302. package/esm2022/classes/accessors.mjs +0 -31
  303. package/esm2022/classes/driver.mjs +0 -36
  304. package/esm2022/classes/index.mjs +0 -4
  305. package/esm2022/classes/taiga-ui-core-classes.mjs +0 -5
  306. package/esm2022/classes/vehicle.mjs +0 -7
  307. package/esm2022/components/alert/alert.component.mjs +0 -43
  308. package/esm2022/components/alert/alert.directive.mjs +0 -21
  309. package/esm2022/components/alert/alert.interfaces.mjs +0 -2
  310. package/esm2022/components/alert/alert.service.mjs +0 -18
  311. package/esm2022/components/alert/alert.tokens.mjs +0 -51
  312. package/esm2022/components/alert/alerts.component.mjs +0 -33
  313. package/esm2022/components/alert/index.mjs +0 -6
  314. package/esm2022/components/alert/taiga-ui-core-components-alert.mjs +0 -5
  315. package/esm2022/components/button/button.directive.mjs +0 -43
  316. package/esm2022/components/button/button.options.mjs +0 -7
  317. package/esm2022/components/button/index.mjs +0 -3
  318. package/esm2022/components/button/taiga-ui-core-components-button.mjs +0 -5
  319. package/esm2022/components/calendar/calendar-sheet.component.mjs +0 -168
  320. package/esm2022/components/calendar/calendar-sheet.options.mjs +0 -12
  321. package/esm2022/components/calendar/calendar-spin.component.mjs +0 -53
  322. package/esm2022/components/calendar/calendar-year.component.mjs +0 -128
  323. package/esm2022/components/calendar/calendar.component.mjs +0 -147
  324. package/esm2022/components/calendar/index.mjs +0 -6
  325. package/esm2022/components/calendar/taiga-ui-core-components-calendar.mjs +0 -5
  326. package/esm2022/components/data-list/data-list.component.mjs +0 -139
  327. package/esm2022/components/data-list/data-list.directive.mjs +0 -19
  328. package/esm2022/components/data-list/data-list.mjs +0 -14
  329. package/esm2022/components/data-list/data-list.tokens.mjs +0 -18
  330. package/esm2022/components/data-list/index.mjs +0 -9
  331. package/esm2022/components/data-list/opt-group.directive.mjs +0 -21
  332. package/esm2022/components/data-list/option/option-content.mjs +0 -36
  333. package/esm2022/components/data-list/option/option-legacy.component.mjs +0 -90
  334. package/esm2022/components/data-list/option/option.directive.mjs +0 -109
  335. package/esm2022/components/data-list/taiga-ui-core-components-data-list.mjs +0 -5
  336. package/esm2022/components/dialog/active-zone-adapter.directive.mjs +0 -37
  337. package/esm2022/components/dialog/dialog-close.service.mjs +0 -41
  338. package/esm2022/components/dialog/dialog.component.mjs +0 -63
  339. package/esm2022/components/dialog/dialog.directive.mjs +0 -21
  340. package/esm2022/components/dialog/dialog.factory.mjs +0 -15
  341. package/esm2022/components/dialog/dialog.interfaces.mjs +0 -2
  342. package/esm2022/components/dialog/dialog.service.mjs +0 -18
  343. package/esm2022/components/dialog/dialog.tokens.mjs +0 -33
  344. package/esm2022/components/dialog/dialogs.component.mjs +0 -31
  345. package/esm2022/components/dialog/index.mjs +0 -8
  346. package/esm2022/components/dialog/taiga-ui-core-components-dialog.mjs +0 -5
  347. package/esm2022/components/error/error.component.mjs +0 -34
  348. package/esm2022/components/error/index.mjs +0 -2
  349. package/esm2022/components/error/taiga-ui-core-components-error.mjs +0 -5
  350. package/esm2022/components/expand/expand-content.directive.mjs +0 -18
  351. package/esm2022/components/expand/expand.component.mjs +0 -124
  352. package/esm2022/components/expand/expand.mjs +0 -7
  353. package/esm2022/components/expand/index.mjs +0 -4
  354. package/esm2022/components/expand/taiga-ui-core-components-expand.mjs +0 -5
  355. package/esm2022/components/fullscreen/fullscreen.component.mjs +0 -71
  356. package/esm2022/components/fullscreen/index.mjs +0 -2
  357. package/esm2022/components/fullscreen/taiga-ui-core-components-fullscreen.mjs +0 -5
  358. package/esm2022/components/icon/icon.component.mjs +0 -44
  359. package/esm2022/components/icon/icon.pipe.mjs +0 -19
  360. package/esm2022/components/icon/index.mjs +0 -3
  361. package/esm2022/components/icon/taiga-ui-core-components-icon.mjs +0 -5
  362. package/esm2022/components/index.mjs +0 -18
  363. package/esm2022/components/label/index.mjs +0 -2
  364. package/esm2022/components/label/label.directive.mjs +0 -41
  365. package/esm2022/components/label/taiga-ui-core-components-label.mjs +0 -5
  366. package/esm2022/components/link/index.mjs +0 -3
  367. package/esm2022/components/link/link.directive.mjs +0 -47
  368. package/esm2022/components/link/link.options.mjs +0 -13
  369. package/esm2022/components/link/taiga-ui-core-components-link.mjs +0 -5
  370. package/esm2022/components/loader/index.mjs +0 -3
  371. package/esm2022/components/loader/loader.component.mjs +0 -46
  372. package/esm2022/components/loader/loader.options.mjs +0 -18
  373. package/esm2022/components/loader/taiga-ui-core-components-loader.mjs +0 -5
  374. package/esm2022/components/notification/index.mjs +0 -3
  375. package/esm2022/components/notification/notification.directive.mjs +0 -81
  376. package/esm2022/components/notification/notification.options.mjs +0 -23
  377. package/esm2022/components/notification/taiga-ui-core-components-notification.mjs +0 -5
  378. package/esm2022/components/root/index.mjs +0 -2
  379. package/esm2022/components/root/root.component.mjs +0 -87
  380. package/esm2022/components/root/taiga-ui-core-components-root.mjs +0 -5
  381. package/esm2022/components/scrollbar/index.mjs +0 -9
  382. package/esm2022/components/scrollbar/scroll-controls.component.mjs +0 -32
  383. package/esm2022/components/scrollbar/scroll-into-view.directive.mjs +0 -43
  384. package/esm2022/components/scrollbar/scroll-ref.directive.mjs +0 -19
  385. package/esm2022/components/scrollbar/scrollable.directive.mjs +0 -26
  386. package/esm2022/components/scrollbar/scrollbar.component.mjs +0 -72
  387. package/esm2022/components/scrollbar/scrollbar.directive.mjs +0 -93
  388. package/esm2022/components/scrollbar/scrollbar.options.mjs +0 -6
  389. package/esm2022/components/scrollbar/scrollbar.service.mjs +0 -46
  390. package/esm2022/components/scrollbar/taiga-ui-core-components-scrollbar.mjs +0 -5
  391. package/esm2022/components/spin-button/index.mjs +0 -2
  392. package/esm2022/components/spin-button/spin-button.component.mjs +0 -51
  393. package/esm2022/components/spin-button/taiga-ui-core-components-spin-button.mjs +0 -5
  394. package/esm2022/components/taiga-ui-core-components.mjs +0 -5
  395. package/esm2022/components/textfield/index.mjs +0 -16
  396. package/esm2022/components/textfield/select-like.directive.mjs +0 -42
  397. package/esm2022/components/textfield/select.directive.mjs +0 -64
  398. package/esm2022/components/textfield/taiga-ui-core-components-textfield.mjs +0 -5
  399. package/esm2022/components/textfield/textfield-accessor.mjs +0 -7
  400. package/esm2022/components/textfield/textfield-auxiliary.mjs +0 -7
  401. package/esm2022/components/textfield/textfield-content.directive.mjs +0 -22
  402. package/esm2022/components/textfield/textfield-dropdown.directive.mjs +0 -43
  403. package/esm2022/components/textfield/textfield-icon.mjs +0 -10
  404. package/esm2022/components/textfield/textfield-multi/textfield-item.component.mjs +0 -34
  405. package/esm2022/components/textfield/textfield-multi/textfield-multi.component.mjs +0 -137
  406. package/esm2022/components/textfield/textfield.component.mjs +0 -183
  407. package/esm2022/components/textfield/textfield.directive.mjs +0 -134
  408. package/esm2022/components/textfield/textfield.mjs +0 -19
  409. package/esm2022/components/textfield/textfield.options.mjs +0 -63
  410. package/esm2022/components/textfield/with-native-picker.directive.mjs +0 -24
  411. package/esm2022/directives/appearance/appearance.bindings.mjs +0 -15
  412. package/esm2022/directives/appearance/appearance.directive.mjs +0 -79
  413. package/esm2022/directives/appearance/appearance.options.mjs +0 -12
  414. package/esm2022/directives/appearance/index.mjs +0 -5
  415. package/esm2022/directives/appearance/taiga-ui-core-directives-appearance.mjs +0 -5
  416. package/esm2022/directives/appearance/with-appearance.mjs +0 -27
  417. package/esm2022/directives/date-format/date-format.directive.mjs +0 -31
  418. package/esm2022/directives/date-format/index.mjs +0 -2
  419. package/esm2022/directives/date-format/taiga-ui-core-directives-date-format.mjs +0 -5
  420. package/esm2022/directives/dropdown/dropdown-context.directive.mjs +0 -76
  421. package/esm2022/directives/dropdown/dropdown-hover.directive.mjs +0 -70
  422. package/esm2022/directives/dropdown/dropdown-hover.options.mjs +0 -17
  423. package/esm2022/directives/dropdown/dropdown-limit-width.mjs +0 -37
  424. package/esm2022/directives/dropdown/dropdown-manual.directive.mjs +0 -27
  425. package/esm2022/directives/dropdown/dropdown-open-legacy.directive.mjs +0 -33
  426. package/esm2022/directives/dropdown/dropdown-open.directive.mjs +0 -169
  427. package/esm2022/directives/dropdown/dropdown-options.directive.mjs +0 -73
  428. package/esm2022/directives/dropdown/dropdown-portal.directive.mjs +0 -34
  429. package/esm2022/directives/dropdown/dropdown-position-sided.directive.mjs +0 -69
  430. package/esm2022/directives/dropdown/dropdown-position.directive.mjs +0 -88
  431. package/esm2022/directives/dropdown/dropdown-selection.directive.mjs +0 -159
  432. package/esm2022/directives/dropdown/dropdown.bindings.mjs +0 -19
  433. package/esm2022/directives/dropdown/dropdown.component.mjs +0 -92
  434. package/esm2022/directives/dropdown/dropdown.directive.mjs +0 -110
  435. package/esm2022/directives/dropdown/dropdown.driver.mjs +0 -32
  436. package/esm2022/directives/dropdown/dropdown.mjs +0 -29
  437. package/esm2022/directives/dropdown/dropdown.providers.mjs +0 -10
  438. package/esm2022/directives/dropdown/dropdown.service.mjs +0 -15
  439. package/esm2022/directives/dropdown/dropdowns.component.mjs +0 -24
  440. package/esm2022/directives/dropdown/index.mjs +0 -22
  441. package/esm2022/directives/dropdown/taiga-ui-core-directives-dropdown.mjs +0 -5
  442. package/esm2022/directives/dropdown/with-dropdown-open.directive.mjs +0 -23
  443. package/esm2022/directives/group/group.directive.mjs +0 -53
  444. package/esm2022/directives/group/group.options.mjs +0 -15
  445. package/esm2022/directives/group/index.mjs +0 -3
  446. package/esm2022/directives/group/taiga-ui-core-directives-group.mjs +0 -5
  447. package/esm2022/directives/hint/hint-describe.directive.mjs +0 -50
  448. package/esm2022/directives/hint/hint-driver.directive.mjs +0 -19
  449. package/esm2022/directives/hint/hint-host.directive.mjs +0 -27
  450. package/esm2022/directives/hint/hint-hover.directive.mjs +0 -59
  451. package/esm2022/directives/hint/hint-manual.directive.mjs +0 -33
  452. package/esm2022/directives/hint/hint-options.directive.mjs +0 -86
  453. package/esm2022/directives/hint/hint-overflow.directive.mjs +0 -38
  454. package/esm2022/directives/hint/hint-pointer.directive.mjs +0 -33
  455. package/esm2022/directives/hint/hint-position.directive.mjs +0 -115
  456. package/esm2022/directives/hint/hint-unstyled.component.mjs +0 -39
  457. package/esm2022/directives/hint/hint.component.mjs +0 -127
  458. package/esm2022/directives/hint/hint.directive.mjs +0 -99
  459. package/esm2022/directives/hint/hint.mjs +0 -27
  460. package/esm2022/directives/hint/hint.providers.mjs +0 -9
  461. package/esm2022/directives/hint/hint.service.mjs +0 -29
  462. package/esm2022/directives/hint/hints.component.mjs +0 -34
  463. package/esm2022/directives/hint/index.mjs +0 -17
  464. package/esm2022/directives/hint/taiga-ui-core-directives-hint.mjs +0 -5
  465. package/esm2022/directives/icons/icons.directive.mjs +0 -66
  466. package/esm2022/directives/icons/index.mjs +0 -3
  467. package/esm2022/directives/icons/taiga-ui-core-directives-icons.mjs +0 -5
  468. package/esm2022/directives/icons/with-icons.mjs +0 -22
  469. package/esm2022/directives/index.mjs +0 -12
  470. package/esm2022/directives/items-handlers/index.mjs +0 -4
  471. package/esm2022/directives/items-handlers/items-handlers.directive.mjs +0 -63
  472. package/esm2022/directives/items-handlers/items-handlers.tokens.mjs +0 -27
  473. package/esm2022/directives/items-handlers/items-handlers.validator.mjs +0 -32
  474. package/esm2022/directives/items-handlers/taiga-ui-core-directives-items-handlers.mjs +0 -5
  475. package/esm2022/directives/number-format/index.mjs +0 -2
  476. package/esm2022/directives/number-format/number-format.directive.mjs +0 -31
  477. package/esm2022/directives/number-format/taiga-ui-core-directives-number-format.mjs +0 -5
  478. package/esm2022/directives/popup/index.mjs +0 -4
  479. package/esm2022/directives/popup/popup.directive.mjs +0 -31
  480. package/esm2022/directives/popup/popup.service.mjs +0 -15
  481. package/esm2022/directives/popup/popups.component.mjs +0 -20
  482. package/esm2022/directives/popup/taiga-ui-core-directives-popup.mjs +0 -5
  483. package/esm2022/directives/surface/index.mjs +0 -2
  484. package/esm2022/directives/surface/surface.directive.mjs +0 -44
  485. package/esm2022/directives/surface/taiga-ui-core-directives-surface.mjs +0 -5
  486. package/esm2022/directives/taiga-ui-core-directives.mjs +0 -5
  487. package/esm2022/directives/title/index.mjs +0 -2
  488. package/esm2022/directives/title/taiga-ui-core-directives-title.mjs +0 -5
  489. package/esm2022/directives/title/title.directive.mjs +0 -37
  490. package/esm2022/index.mjs +0 -9
  491. package/esm2022/pipes/auto-color/auto-color.pipe.mjs +0 -19
  492. package/esm2022/pipes/auto-color/index.mjs +0 -2
  493. package/esm2022/pipes/auto-color/taiga-ui-core-pipes-auto-color.mjs +0 -5
  494. package/esm2022/pipes/calendar-sheet/calendar-sheet.pipe.mjs +0 -54
  495. package/esm2022/pipes/calendar-sheet/index.mjs +0 -2
  496. package/esm2022/pipes/calendar-sheet/taiga-ui-core-pipes-calendar-sheet.mjs +0 -5
  497. package/esm2022/pipes/calendar-sheet/utils.mjs +0 -36
  498. package/esm2022/pipes/fallback-src/fallback-src.pipe.mjs +0 -23
  499. package/esm2022/pipes/fallback-src/index.mjs +0 -2
  500. package/esm2022/pipes/fallback-src/taiga-ui-core-pipes-fallback-src.mjs +0 -5
  501. package/esm2022/pipes/flag/flag.pipe.mjs +0 -26
  502. package/esm2022/pipes/flag/index.mjs +0 -2
  503. package/esm2022/pipes/flag/taiga-ui-core-pipes-flag.mjs +0 -5
  504. package/esm2022/pipes/format-date/format-date.pipe.mjs +0 -22
  505. package/esm2022/pipes/format-date/index.mjs +0 -2
  506. package/esm2022/pipes/format-date/taiga-ui-core-pipes-format-date.mjs +0 -5
  507. package/esm2022/pipes/format-number/format-number.pipe.mjs +0 -36
  508. package/esm2022/pipes/format-number/index.mjs +0 -2
  509. package/esm2022/pipes/format-number/taiga-ui-core-pipes-format-number.mjs +0 -5
  510. package/esm2022/pipes/index.mjs +0 -10
  511. package/esm2022/pipes/initials/index.mjs +0 -2
  512. package/esm2022/pipes/initials/initials.pipe.mjs +0 -23
  513. package/esm2022/pipes/initials/taiga-ui-core-pipes-initials.mjs +0 -5
  514. package/esm2022/pipes/month/index.mjs +0 -2
  515. package/esm2022/pipes/month/month.pipe.mjs +0 -23
  516. package/esm2022/pipes/month/taiga-ui-core-pipes-month.mjs +0 -5
  517. package/esm2022/pipes/order-week-days/index.mjs +0 -2
  518. package/esm2022/pipes/order-week-days/order-week-days.pipe.mjs +0 -30
  519. package/esm2022/pipes/order-week-days/taiga-ui-core-pipes-order-week-days.mjs +0 -5
  520. package/esm2022/pipes/taiga-ui-core-pipes.mjs +0 -5
  521. package/esm2022/services/breakpoint.service.mjs +0 -31
  522. package/esm2022/services/dark-theme.service.mjs +0 -24
  523. package/esm2022/services/format-date.service.mjs +0 -24
  524. package/esm2022/services/index.mjs +0 -6
  525. package/esm2022/services/position.service.mjs +0 -26
  526. package/esm2022/services/taiga-ui-core-services.mjs +0 -5
  527. package/esm2022/services/visual-viewport.service.mjs +0 -29
  528. package/esm2022/taiga-ui-core.mjs +0 -5
  529. package/esm2022/tokens/animations-speed.mjs +0 -9
  530. package/esm2022/tokens/assets-path.mjs +0 -11
  531. package/esm2022/tokens/auxiliary.mjs +0 -9
  532. package/esm2022/tokens/common-icons.mjs +0 -18
  533. package/esm2022/tokens/dark-mode.mjs +0 -43
  534. package/esm2022/tokens/date-format.mjs +0 -20
  535. package/esm2022/tokens/day-type-handler.mjs +0 -8
  536. package/esm2022/tokens/first-day-of-week.mjs +0 -9
  537. package/esm2022/tokens/i18n.mjs +0 -45
  538. package/esm2022/tokens/icon-resolver.mjs +0 -44
  539. package/esm2022/tokens/icon.mjs +0 -8
  540. package/esm2022/tokens/icons.mjs +0 -21
  541. package/esm2022/tokens/index.mjs +0 -21
  542. package/esm2022/tokens/media.mjs +0 -12
  543. package/esm2022/tokens/number-format.mjs +0 -24
  544. package/esm2022/tokens/reduced-motion.mjs +0 -7
  545. package/esm2022/tokens/scroll-ref.mjs +0 -6
  546. package/esm2022/tokens/selection-stream.mjs +0 -14
  547. package/esm2022/tokens/spin-icons.mjs +0 -8
  548. package/esm2022/tokens/taiga-ui-core-tokens.mjs +0 -5
  549. package/esm2022/tokens/theme.mjs +0 -5
  550. package/esm2022/tokens/viewport.mjs +0 -35
  551. package/esm2022/types/direction.mjs +0 -2
  552. package/esm2022/types/index.mjs +0 -2
  553. package/esm2022/types/interactive-state.mjs +0 -2
  554. package/esm2022/types/orientation.mjs +0 -2
  555. package/esm2022/types/point.mjs +0 -2
  556. package/esm2022/types/portal-item.mjs +0 -2
  557. package/esm2022/types/range-state.mjs +0 -2
  558. package/esm2022/types/size.mjs +0 -13
  559. package/esm2022/types/taiga-ui-core-types.mjs +0 -5
  560. package/esm2022/types/value-content-context.mjs +0 -2
  561. package/esm2022/utils/dom/check-fixed-position.mjs +0 -9
  562. package/esm2022/utils/dom/get-viewport.mjs +0 -24
  563. package/esm2022/utils/dom/get-word-range.mjs +0 -51
  564. package/esm2022/utils/dom/index.mjs +0 -4
  565. package/esm2022/utils/dom/taiga-ui-core-utils-dom.mjs +0 -5
  566. package/esm2022/utils/format/format-number.mjs +0 -47
  567. package/esm2022/utils/format/get-fractional-part-padded.mjs +0 -16
  568. package/esm2022/utils/format/index.mjs +0 -5
  569. package/esm2022/utils/format/number-to-string-without-exp.mjs +0 -18
  570. package/esm2022/utils/format/string-hash-to-hsl.mjs +0 -21
  571. package/esm2022/utils/format/taiga-ui-core-utils-format.mjs +0 -5
  572. package/esm2022/utils/index.mjs +0 -4
  573. package/esm2022/utils/miscellaneous/font-scaling.mjs +0 -21
  574. package/esm2022/utils/miscellaneous/index.mjs +0 -7
  575. package/esm2022/utils/miscellaneous/is-editing-key.mjs +0 -18
  576. package/esm2022/utils/miscellaneous/is-obscured.mjs +0 -8
  577. package/esm2022/utils/miscellaneous/override-options.mjs +0 -11
  578. package/esm2022/utils/miscellaneous/size-bigger.mjs +0 -19
  579. package/esm2022/utils/miscellaneous/taiga-ui-core-utils-miscellaneous.mjs +0 -5
  580. package/esm2022/utils/miscellaneous/to-animation-options.mjs +0 -16
  581. package/esm2022/utils/taiga-ui-core-utils.mjs +0 -5
  582. package/fesm2022/taiga-ui-core-animations.mjs +0 -370
  583. package/fesm2022/taiga-ui-core-animations.mjs.map +0 -1
  584. package/fesm2022/taiga-ui-core-components-alert.mjs +0 -149
  585. package/fesm2022/taiga-ui-core-components-alert.mjs.map +0 -1
  586. package/fesm2022/taiga-ui-core-components-dialog.mjs +0 -230
  587. package/fesm2022/taiga-ui-core-components-dialog.mjs.map +0 -1
  588. package/fesm2022/taiga-ui-core-components-fullscreen.mjs +0 -77
  589. package/fesm2022/taiga-ui-core-components-fullscreen.mjs.map +0 -1
  590. package/fesm2022/taiga-ui-core-directives-dropdown.mjs.map +0 -1
  591. package/fesm2022/taiga-ui-core-directives-hint.mjs +0 -713
  592. package/fesm2022/taiga-ui-core-directives-hint.mjs.map +0 -1
  593. package/fesm2022/taiga-ui-core-directives-popup.mjs +0 -63
  594. package/fesm2022/taiga-ui-core-directives-popup.mjs.map +0 -1
  595. package/fesm2022/taiga-ui-core-directives-surface.mjs +0 -50
  596. package/fesm2022/taiga-ui-core-directives-surface.mjs.map +0 -1
  597. package/fesm2022/taiga-ui-core-directives-title.mjs +0 -43
  598. package/fesm2022/taiga-ui-core-directives-title.mjs.map +0 -1
  599. package/fesm2022/taiga-ui-core-pipes-auto-color.mjs +0 -25
  600. package/fesm2022/taiga-ui-core-pipes-auto-color.mjs.map +0 -1
  601. package/fesm2022/taiga-ui-core-pipes-calendar-sheet.mjs +0 -94
  602. package/fesm2022/taiga-ui-core-pipes-calendar-sheet.mjs.map +0 -1
  603. package/fesm2022/taiga-ui-core-pipes-fallback-src.mjs +0 -29
  604. package/fesm2022/taiga-ui-core-pipes-fallback-src.mjs.map +0 -1
  605. package/fesm2022/taiga-ui-core-pipes-flag.mjs +0 -32
  606. package/fesm2022/taiga-ui-core-pipes-flag.mjs.map +0 -1
  607. package/fesm2022/taiga-ui-core-pipes-format-date.mjs +0 -28
  608. package/fesm2022/taiga-ui-core-pipes-format-date.mjs.map +0 -1
  609. package/fesm2022/taiga-ui-core-pipes-initials.mjs +0 -29
  610. package/fesm2022/taiga-ui-core-pipes-initials.mjs.map +0 -1
  611. package/fesm2022/taiga-ui-core-pipes-month.mjs +0 -29
  612. package/fesm2022/taiga-ui-core-pipes-month.mjs.map +0 -1
  613. package/fesm2022/taiga-ui-core-pipes-order-week-days.mjs +0 -36
  614. package/fesm2022/taiga-ui-core-pipes-order-week-days.mjs.map +0 -1
  615. package/pipes/auto-color/auto-color.pipe.d.ts +0 -7
  616. package/pipes/auto-color/index.d.ts +0 -1
  617. package/pipes/calendar-sheet/index.d.ts +0 -1
  618. package/pipes/calendar-sheet/utils.d.ts +0 -20
  619. package/pipes/fallback-src/fallback-src.pipe.d.ts +0 -9
  620. package/pipes/fallback-src/index.d.ts +0 -1
  621. package/pipes/flag/flag.pipe.d.ts +0 -14
  622. package/pipes/flag/index.d.ts +0 -1
  623. package/pipes/format-date/format-date.pipe.d.ts +0 -9
  624. package/pipes/format-date/index.d.ts +0 -1
  625. package/pipes/initials/index.d.ts +0 -1
  626. package/pipes/initials/initials.pipe.d.ts +0 -7
  627. package/pipes/month/index.d.ts +0 -1
  628. package/pipes/month/month.pipe.d.ts +0 -10
  629. package/pipes/order-week-days/index.d.ts +0 -1
  630. package/services/breakpoint.service.d.ts +0 -16
  631. package/services/dark-theme.service.d.ts +0 -10
  632. package/services/format-date.service.d.ts +0 -8
  633. package/styles/mixins/wrapper.less +0 -64
  634. package/styles/mixins/wrapper.scss +0 -61
  635. package/styles/theme/appearance/opposite.less +0 -17
  636. package/styles/theme/wrapper.less +0 -211
  637. package/tokens/day-type-handler.d.ts +0 -7
  638. package/tokens/first-day-of-week.d.ts +0 -5
  639. package/tokens/scroll-ref.d.ts +0 -2
  640. package/tokens/spin-icons.d.ts +0 -6
  641. package/types/portal-item.d.ts +0 -9
  642. package/types/range-state.d.ts +0 -4
  643. package/types/value-content-context.d.ts +0 -4
  644. package/utils/format/string-hash-to-hsl.d.ts +0 -6
  645. package/utils/miscellaneous/to-animation-options.d.ts +0 -4
  646. /package/{directives → components}/title/index.d.ts +0 -0
  647. /package/{directives → portals}/dropdown/dropdown-limit-width.d.ts +0 -0
  648. /package/{directives → portals}/dropdown/dropdown.component.d.ts +0 -0
  649. /package/{directives → portals}/dropdown/dropdown.driver.d.ts +0 -0
  650. /package/{directives → portals}/dropdown/dropdown.providers.d.ts +0 -0
  651. /package/{directives → portals}/dropdown/with-dropdown-open.directive.d.ts +0 -0
  652. /package/{directives → portals}/hint/hint-driver.directive.d.ts +0 -0
  653. /package/{directives → portals}/hint/hint-pointer.directive.d.ts +0 -0
  654. /package/{directives → portals}/hint/hint.providers.d.ts +0 -0
  655. /package/{directives → portals}/popup/index.d.ts +0 -0
@@ -1,38 +1,142 @@
1
- import { AsyncPipe, NgFor, NgIf } from '@angular/common';
2
1
  import * as i0 from '@angular/core';
3
- import { InjectionToken, inject, EventEmitter, Component, ChangeDetectionStrategy, Input, Output, signal, computed, ChangeDetectorRef } from '@angular/core';
4
- import { TuiDay, TuiMonth, TuiDayRange, TUI_FIRST_DAY, TUI_LAST_DAY, MIN_YEAR, MAX_YEAR, TuiYear, TuiMonthRange, TUI_LAST_DISPLAYED_DAY } from '@taiga-ui/cdk/date-time';
2
+ import { signal, inject, Pipe, EventEmitter, Output, Input, ChangeDetectionStrategy, Component, computed, ChangeDetectorRef } from '@angular/core';
3
+ import { TuiDayOfWeek, DAYS_IN_WEEK, TuiDay, TuiMonth, TuiDayRange, TUI_FIRST_DAY, TUI_LAST_DAY, MIN_YEAR, MAX_YEAR, TuiYear, TuiMonthRange, TUI_LAST_DISPLAYED_DAY } from '@taiga-ui/cdk/date-time';
5
4
  import { TuiMapperPipe } from '@taiga-ui/cdk/pipes/mapper';
6
- import { tuiProvideOptions, tuiNullableSame, tuiPure, tuiIsNumber } from '@taiga-ui/cdk/utils/miscellaneous';
5
+ import { tuiNullableSame, tuiIsNumber } from '@taiga-ui/cdk/utils/miscellaneous';
7
6
  import { TuiScrollIntoView, TuiScrollbar } from '@taiga-ui/core/components/scrollbar';
8
- import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives';
9
- import { TUI_SHORT_WEEK_DAYS, TUI_DAY_TYPE_HANDLER, tuiAsAuxiliary } from '@taiga-ui/core/tokens';
10
- import { Subject } from 'rxjs';
11
- import { __decorate } from 'tslib';
7
+ import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives/items-handlers';
8
+ import { TUI_SHORT_WEEK_DAYS, TUI_MONTHS, tuiAsAuxiliary } from '@taiga-ui/core/tokens';
9
+ import { map, Subject } from 'rxjs';
10
+ import { AsyncPipe } from '@angular/common';
11
+ import { toObservable } from '@angular/core/rxjs-interop';
12
12
  import { TUI_FALSE_HANDLER } from '@taiga-ui/cdk/constants';
13
13
  import { TuiHovered } from '@taiga-ui/cdk/directives/hovered';
14
- import { TuiLet } from '@taiga-ui/cdk/directives/let';
15
- import { TuiRepeatTimes } from '@taiga-ui/cdk/directives/repeat-times';
16
- import { TuiCalendarSheetPipe, TuiOrderWeekDaysPipe, TuiMonthPipe } from '@taiga-ui/core/pipes';
14
+ import { tuiCreateOptions } from '@taiga-ui/cdk/utils/di';
15
+ import { tuiInRange } from '@taiga-ui/cdk/utils/math';
17
16
  import { TuiLink } from '@taiga-ui/core/components/link';
18
17
  import { TuiSpinButton } from '@taiga-ui/core/components/spin-button';
19
18
 
19
+ const TUI_CALENDAR_DEFAULT_OPTIONS = {
20
+ dayType: (day) => (day.isWeekend ? 'weekend' : 'weekday'),
21
+ weekStart: signal(TuiDayOfWeek.Monday),
22
+ };
23
+ const [TUI_CALENDAR_OPTIONS, tuiCalendarOptionsProvider] = tuiCreateOptions(TUI_CALENDAR_DEFAULT_OPTIONS);
24
+
20
25
  const TUI_CALENDAR_SHEET_DEFAULT_OPTIONS = {
21
26
  rangeMode: false,
22
27
  };
23
- const TUI_CALENDAR_SHEET_OPTIONS = new InjectionToken(ngDevMode ? 'TUI_CALENDAR_SHEET_OPTIONS' : '', {
24
- factory: () => TUI_CALENDAR_SHEET_DEFAULT_OPTIONS,
25
- });
26
- function tuiCalendarSheetOptionsProvider(options) {
27
- return tuiProvideOptions(TUI_CALENDAR_SHEET_OPTIONS, options, TUI_CALENDAR_SHEET_DEFAULT_OPTIONS);
28
+ const [TUI_CALENDAR_SHEET_OPTIONS, tuiCalendarSheetOptionsProvider] = tuiCreateOptions(TUI_CALENDAR_SHEET_DEFAULT_OPTIONS);
29
+
30
+ /// <reference types="@taiga-ui/tsconfig/ng-dev-mode" />
31
+ const CALENDAR_ROWS_COUNT = 6;
32
+ class TuiCalendarSheetPipe {
33
+ constructor() {
34
+ this.options = inject(TUI_CALENDAR_OPTIONS);
35
+ this.currentMonth = null;
36
+ this.currentSheet = [];
37
+ }
38
+ transform(month, showAdjacentDays = false) {
39
+ if (this.currentMonth?.monthSame(month)) {
40
+ return this.currentSheet;
41
+ }
42
+ const sheet = [];
43
+ for (let rowIndex = 0; rowIndex < CALENDAR_ROWS_COUNT; rowIndex++) {
44
+ const row = [];
45
+ for (let colIndex = 0; colIndex < DAYS_IN_WEEK; colIndex++) {
46
+ const day = getDayFromMonthRowCol({
47
+ month,
48
+ rowIndex,
49
+ colIndex,
50
+ firstDayOfWeek: this.options.weekStart(),
51
+ });
52
+ const isPrevMonthDay = (day, relativeToMonth = month) => day.year < relativeToMonth.year || day.month < relativeToMonth.month;
53
+ const isNextMonthDay = (day, relativeToMonth = month) => day.year > relativeToMonth.year || day.month > relativeToMonth.month;
54
+ if (isPrevMonthDay(day) && !showAdjacentDays) {
55
+ continue;
56
+ }
57
+ if (isNextMonthDay(day) && !showAdjacentDays) {
58
+ break;
59
+ }
60
+ row.push(day);
61
+ }
62
+ sheet.push(row);
63
+ }
64
+ this.currentSheet = sheet.filter((row) => row.length);
65
+ this.currentMonth = month;
66
+ return this.currentSheet;
67
+ }
68
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarSheetPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
69
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarSheetPipe, isStandalone: true, name: "tuiCalendarSheet" }); }
70
+ }
71
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarSheetPipe, decorators: [{
72
+ type: Pipe,
73
+ args: [{
74
+ name: 'tuiCalendarSheet',
75
+ }]
76
+ }] });
77
+ /**
78
+ * Computes day of week offset of the beginning of the month
79
+ */
80
+ function getMonthStartDaysOffset(month, firstDayOfWeek) {
81
+ const startMonthOffsetFromSunday = new Date(month.year, month.month, 1).getDay();
82
+ return startMonthOffsetFromSunday >= firstDayOfWeek
83
+ ? startMonthOffsetFromSunday - firstDayOfWeek
84
+ : DAYS_IN_WEEK - (firstDayOfWeek - startMonthOffsetFromSunday);
85
+ }
86
+ /**
87
+ * Calculated day on a calendar grid
88
+ * @return resulting day on these coordinates (could exceed passed month)
89
+ */
90
+ function getDayFromMonthRowCol({ month, rowIndex, colIndex, firstDayOfWeek, }) {
91
+ ngDevMode && console.assert(Number.isInteger(rowIndex));
92
+ ngDevMode && console.assert(tuiInRange(rowIndex, 0, 6));
93
+ ngDevMode && console.assert(Number.isInteger(colIndex));
94
+ ngDevMode && console.assert(tuiInRange(colIndex, 0, DAYS_IN_WEEK));
95
+ let day = rowIndex * DAYS_IN_WEEK +
96
+ colIndex -
97
+ getMonthStartDaysOffset(month, firstDayOfWeek) +
98
+ 1;
99
+ if (day > month.daysCount) {
100
+ day -= month.daysCount;
101
+ month = month.append({ month: 1 });
102
+ }
103
+ if (day <= 0) {
104
+ month = month.append({ month: -1 });
105
+ day = month.daysCount + day;
106
+ }
107
+ return new TuiDay(month.year, month.month, day);
28
108
  }
29
109
 
110
+ function convertToSundayFirstWeekFormat(weekDaysNames) {
111
+ const sundayIndex = weekDaysNames.length - 1;
112
+ return [weekDaysNames[sundayIndex] || '', ...weekDaysNames.slice(0, sundayIndex)];
113
+ }
114
+ class TuiOrderWeekDaysPipe {
115
+ constructor() {
116
+ this.options = inject(TUI_CALENDAR_OPTIONS);
117
+ }
118
+ transform(mondayFirstWeekDays$) {
119
+ return mondayFirstWeekDays$.pipe(map(convertToSundayFirstWeekFormat), map((weekDays) => [
120
+ ...weekDays.slice(this.options.weekStart()),
121
+ ...weekDays.slice(0, this.options.weekStart()),
122
+ ]));
123
+ }
124
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiOrderWeekDaysPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
125
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "19.2.17", ngImport: i0, type: TuiOrderWeekDaysPipe, isStandalone: true, name: "tuiOrderWeekDays" }); }
126
+ }
127
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiOrderWeekDaysPipe, decorators: [{
128
+ type: Pipe,
129
+ args: [{
130
+ name: 'tuiOrderWeekDays',
131
+ }]
132
+ }] });
133
+
30
134
  class TuiCalendarSheet {
31
135
  constructor() {
32
136
  this.options = inject(TUI_CALENDAR_SHEET_OPTIONS);
33
137
  this.today = TuiDay.currentLocal();
34
- this.unorderedWeekDays$ = inject(TUI_SHORT_WEEK_DAYS);
35
- this.dayTypeHandler = inject(TUI_DAY_TYPE_HANDLER);
138
+ this.unorderedWeekDays$ = toObservable(inject(TUI_SHORT_WEEK_DAYS));
139
+ this.dayType = inject(TUI_CALENDAR_OPTIONS).dayType;
36
140
  this.month = TuiMonth.currentLocal();
37
141
  this.disabledItemHandler = TUI_FALSE_HANDLER;
38
142
  this.markerHandler = null;
@@ -139,27 +243,20 @@ class TuiCalendarSheet {
139
243
  this.hoveredItem = day;
140
244
  this.hoveredItemChange.emit(day);
141
245
  }
142
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarSheet, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
143
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendarSheet, isStandalone: true, selector: "tui-calendar-sheet", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", value: "value", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent", single: "single" }, outputs: { hoveredItemChange: "hoveredItemChange", dayClick: "dayClick" }, host: { properties: { "class._picking": "isRangePicking" } }, ngImport: i0, template: "<div class=\"t-row t-row_weekday\">\n <div\n *ngFor=\"let day of unorderedWeekDays$ | tuiOrderWeekDays | async\"\n class=\"t-cell\"\n [textContent]=\"day\"\n ></div>\n</div>\n<div *tuiLet=\"month | tuiCalendarSheet: true as sheet\">\n <div\n *tuiRepeatTimes=\"let rowIndex of sheet.length\"\n automation-id=\"tui-calendar-sheet__row\"\n class=\"t-row\"\n >\n <ng-container *tuiRepeatTimes=\"let colIndex of sheet[rowIndex]?.length || 0\">\n <ng-container *tuiLet=\"sheet[rowIndex]?.[colIndex] as item\">\n <div\n *ngIf=\"item && (!itemIsUnavailable(item) || showAdjacent)\"\n automation-id=\"tui-calendar-sheet__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [attr.data-type]=\"item | tuiMapper: dayTypeHandler\"\n [class.t-cell_disabled]=\"disabledItemHandler(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [class.t-cell_unavailable]=\"itemIsUnavailable(item)\"\n (click)=\"onItemClick(item)\"\n (tuiHoveredChange)=\"onItemHovered($event && item)\"\n >\n {{ item.day }}\n <div\n *ngIf=\"\n item\n | tuiMapper\n : toMarkers\n : itemIsToday(item)\n : getItemRange(item)\n : markerHandler as markers\n \"\n class=\"t-dots\"\n >\n <div\n class=\"t-dot\"\n [style.background]=\"markers?.[0]\"\n ></div>\n <div\n *ngIf=\"markers.length > 1\"\n class=\"t-dot\"\n [style.background]=\"markers?.[1] || ''\"\n ></div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;-webkit-mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem));mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;top:0;left:0;bottom:0;right:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{-webkit-mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat;mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);-webkit-mask:none;mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}.t-cell{inline-size:calc(100% / 7)}[data-type=weekday]{color:var(--tui-text-primary)}[data-type=weekend]{color:var(--tui-text-negative)}.t-row{justify-content:flex-start}.t-row:first-child{justify-content:flex-end}.t-row_weekday{font:var(--tui-font-text-s);color:var(--tui-text-secondary);pointer-events:none}.t-cell_unavailable{opacity:var(--tui-disabled-opacity)}.t-dots{position:absolute;bottom:0;display:flex;justify-content:center;margin-block-start:-.5rem;padding-block-end:.25rem}.t-dot{display:inline-block;inline-size:.25rem;block-size:.25rem;border-radius:100%;margin:0 .0625rem}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: TuiCalendarSheetPipe, name: "tuiCalendarSheet" }, { kind: "directive", type: TuiHovered, selector: "[tuiHoveredChange]", outputs: ["tuiHoveredChange"] }, { kind: "directive", type: TuiLet, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }, { kind: "pipe", type: TuiOrderWeekDaysPipe, name: "tuiOrderWeekDays" }, { kind: "directive", type: TuiRepeatTimes, selector: "[tuiRepeatTimes][tuiRepeatTimesOf]", inputs: ["tuiRepeatTimesOf"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
246
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarSheet, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
247
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiCalendarSheet, isStandalone: true, selector: "tui-calendar-sheet", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", value: "value", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent", single: "single" }, outputs: { hoveredItemChange: "hoveredItemChange", dayClick: "dayClick" }, host: { properties: { "class._picking": "isRangePicking" } }, ngImport: i0, template: "<div class=\"t-row t-row_weekday\">\n @for (day of unorderedWeekDays$ | tuiOrderWeekDays | async; track day) {\n <div\n class=\"t-cell\"\n [textContent]=\"day\"\n ></div>\n }\n</div>\n@let sheet = month | tuiCalendarSheet: true;\n<div>\n @for (_ of '-'.repeat(sheet.length); track $index) {\n @let rowIndex = $index;\n <div\n automation-id=\"tui-calendar-sheet__row\"\n class=\"t-row\"\n >\n @for (_ of '-'.repeat(sheet[rowIndex]?.length ?? 0); track $index) {\n @let item = sheet[rowIndex]?.[$index];\n @if (item && (!itemIsUnavailable(item) || showAdjacent)) {\n <div\n automation-id=\"tui-calendar-sheet__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [attr.data-type]=\"item | tuiMapper: dayType\"\n [class.t-cell_disabled]=\"disabledItemHandler(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [class.t-cell_unavailable]=\"itemIsUnavailable(item)\"\n (click)=\"onItemClick(item)\"\n (tuiHoveredChange)=\"onItemHovered($event && item)\"\n >\n {{ item.day }}\n @if (\n item | tuiMapper: toMarkers : itemIsToday(item) : getItemRange(item) : markerHandler;\n as markers\n ) {\n <div class=\"t-dots\">\n <div\n class=\"t-dot\"\n [style.background]=\"markers?.[0]\"\n ></div>\n @if (markers.length > 1) {\n <div\n class=\"t-dot\"\n [style.background]=\"markers?.[1] || ''\"\n ></div>\n }\n </div>\n }\n </div>\n }\n }\n </div>\n }\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-body-m)}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;inset:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}.t-cell{inline-size:calc(100% / 7)}[data-type=weekday]{color:var(--tui-text-primary)}[data-type=weekend]{color:var(--tui-text-negative)}.t-row{justify-content:flex-start}.t-row:first-child{justify-content:flex-end}.t-row_weekday{font:var(--tui-font-body-s);color:var(--tui-text-secondary);pointer-events:none}.t-cell_unavailable{opacity:var(--tui-disabled-opacity)}.t-dots{position:absolute;bottom:0;display:flex;justify-content:center;margin-block-start:-.5rem;padding-block-end:.25rem}.t-dot{display:inline-block;inline-size:.25rem;block-size:.25rem;border-radius:100%;margin:0 .0625rem}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: TuiCalendarSheetPipe, name: "tuiCalendarSheet" }, { kind: "directive", type: TuiHovered, selector: "[tuiHoveredChange]", outputs: ["tuiHoveredChange"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }, { kind: "pipe", type: TuiOrderWeekDaysPipe, name: "tuiOrderWeekDays" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
144
248
  }
145
- __decorate([
146
- tuiPure
147
- ], TuiCalendarSheet.prototype, "getRange", null);
148
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarSheet, decorators: [{
249
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarSheet, decorators: [{
149
250
  type: Component,
150
- args: [{ standalone: true, selector: 'tui-calendar-sheet', imports: [
251
+ args: [{ selector: 'tui-calendar-sheet', imports: [
151
252
  AsyncPipe,
152
- NgFor,
153
- NgIf,
154
253
  TuiCalendarSheetPipe,
155
254
  TuiHovered,
156
- TuiLet,
157
255
  TuiMapperPipe,
158
256
  TuiOrderWeekDaysPipe,
159
- TuiRepeatTimes,
160
257
  ], changeDetection: ChangeDetectionStrategy.OnPush, host: {
161
258
  '[class._picking]': 'isRangePicking',
162
- }, template: "<div class=\"t-row t-row_weekday\">\n <div\n *ngFor=\"let day of unorderedWeekDays$ | tuiOrderWeekDays | async\"\n class=\"t-cell\"\n [textContent]=\"day\"\n ></div>\n</div>\n<div *tuiLet=\"month | tuiCalendarSheet: true as sheet\">\n <div\n *tuiRepeatTimes=\"let rowIndex of sheet.length\"\n automation-id=\"tui-calendar-sheet__row\"\n class=\"t-row\"\n >\n <ng-container *tuiRepeatTimes=\"let colIndex of sheet[rowIndex]?.length || 0\">\n <ng-container *tuiLet=\"sheet[rowIndex]?.[colIndex] as item\">\n <div\n *ngIf=\"item && (!itemIsUnavailable(item) || showAdjacent)\"\n automation-id=\"tui-calendar-sheet__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [attr.data-type]=\"item | tuiMapper: dayTypeHandler\"\n [class.t-cell_disabled]=\"disabledItemHandler(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [class.t-cell_unavailable]=\"itemIsUnavailable(item)\"\n (click)=\"onItemClick(item)\"\n (tuiHoveredChange)=\"onItemHovered($event && item)\"\n >\n {{ item.day }}\n <div\n *ngIf=\"\n item\n | tuiMapper\n : toMarkers\n : itemIsToday(item)\n : getItemRange(item)\n : markerHandler as markers\n \"\n class=\"t-dots\"\n >\n <div\n class=\"t-dot\"\n [style.background]=\"markers?.[0]\"\n ></div>\n <div\n *ngIf=\"markers.length > 1\"\n class=\"t-dot\"\n [style.background]=\"markers?.[1] || ''\"\n ></div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;-webkit-mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem));mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;top:0;left:0;bottom:0;right:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{-webkit-mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat;mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);-webkit-mask:none;mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}.t-cell{inline-size:calc(100% / 7)}[data-type=weekday]{color:var(--tui-text-primary)}[data-type=weekend]{color:var(--tui-text-negative)}.t-row{justify-content:flex-start}.t-row:first-child{justify-content:flex-end}.t-row_weekday{font:var(--tui-font-text-s);color:var(--tui-text-secondary);pointer-events:none}.t-cell_unavailable{opacity:var(--tui-disabled-opacity)}.t-dots{position:absolute;bottom:0;display:flex;justify-content:center;margin-block-start:-.5rem;padding-block-end:.25rem}.t-dot{display:inline-block;inline-size:.25rem;block-size:.25rem;border-radius:100%;margin:0 .0625rem}\n"] }]
259
+ }, template: "<div class=\"t-row t-row_weekday\">\n @for (day of unorderedWeekDays$ | tuiOrderWeekDays | async; track day) {\n <div\n class=\"t-cell\"\n [textContent]=\"day\"\n ></div>\n }\n</div>\n@let sheet = month | tuiCalendarSheet: true;\n<div>\n @for (_ of '-'.repeat(sheet.length); track $index) {\n @let rowIndex = $index;\n <div\n automation-id=\"tui-calendar-sheet__row\"\n class=\"t-row\"\n >\n @for (_ of '-'.repeat(sheet[rowIndex]?.length ?? 0); track $index) {\n @let item = sheet[rowIndex]?.[$index];\n @if (item && (!itemIsUnavailable(item) || showAdjacent)) {\n <div\n automation-id=\"tui-calendar-sheet__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [attr.data-type]=\"item | tuiMapper: dayType\"\n [class.t-cell_disabled]=\"disabledItemHandler(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [class.t-cell_unavailable]=\"itemIsUnavailable(item)\"\n (click)=\"onItemClick(item)\"\n (tuiHoveredChange)=\"onItemHovered($event && item)\"\n >\n {{ item.day }}\n @if (\n item | tuiMapper: toMarkers : itemIsToday(item) : getItemRange(item) : markerHandler;\n as markers\n ) {\n <div class=\"t-dots\">\n <div\n class=\"t-dot\"\n [style.background]=\"markers?.[0]\"\n ></div>\n @if (markers.length > 1) {\n <div\n class=\"t-dot\"\n [style.background]=\"markers?.[1] || ''\"\n ></div>\n }\n </div>\n }\n </div>\n }\n }\n </div>\n }\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-body-m)}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;inset:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}.t-cell{inline-size:calc(100% / 7)}[data-type=weekday]{color:var(--tui-text-primary)}[data-type=weekend]{color:var(--tui-text-negative)}.t-row{justify-content:flex-start}.t-row:first-child{justify-content:flex-end}.t-row_weekday{font:var(--tui-font-body-s);color:var(--tui-text-secondary);pointer-events:none}.t-cell_unavailable{opacity:var(--tui-disabled-opacity)}.t-dots{position:absolute;bottom:0;display:flex;justify-content:center;margin-block-start:-.5rem;padding-block-end:.25rem}.t-dot{display:inline-block;inline-size:.25rem;block-size:.25rem;border-radius:100%;margin:0 .0625rem}\n"] }]
163
260
  }], propDecorators: { month: [{
164
261
  type: Input
165
262
  }], disabledItemHandler: [{
@@ -178,10 +275,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
178
275
  type: Output
179
276
  }], dayClick: [{
180
277
  type: Output
181
- }], getRange: [] } });
278
+ }] } });
182
279
 
183
280
  class TuiCalendarSpin {
184
281
  constructor() {
282
+ this.months = inject(TUI_MONTHS);
185
283
  this.value = TuiMonth.currentLocal();
186
284
  this.min = TUI_FIRST_DAY;
187
285
  this.max = TUI_LAST_DAY;
@@ -207,12 +305,12 @@ class TuiCalendarSpin {
207
305
  this.value = value;
208
306
  this.valueChange.emit(value);
209
307
  }
210
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarSpin, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
211
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendarSpin, isStandalone: true, selector: "tui-calendar-spin", inputs: { value: "value", min: "min", max: "max" }, outputs: { valueChange: "valueChange", yearClick: "yearClick" }, ngImport: i0, template: "<tui-spin-button\n [focusable]=\"false\"\n [leftDisabled]=\"value.monthSameOrBefore(min)\"\n [rightDisabled]=\"value.monthSameOrAfter(max)\"\n (leftClick)=\"append({month: -1})\"\n (rightClick)=\"append({month: 1})\"\n>\n {{ value | tuiMonth | async }}\n <ng-container *ngIf=\"min.year === max.year; else button\">\n {{ value.formattedYear }}\n </ng-container>\n <ng-template #button>\n <button\n id=\"year-btn\"\n automation-id=\"tui-primitive-year-month-pagination__year-button\"\n tabIndex=\"-1\"\n tuiLink\n type=\"button\"\n (click)=\"onYearClick()\"\n >\n {{ value.formattedYear }}\n </button>\n </ng-template>\n</tui-spin-button>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TuiLink, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo"] }, { kind: "pipe", type: TuiMonthPipe, name: "tuiMonth" }, { kind: "component", type: TuiSpinButton, selector: "tui-spin-button", inputs: ["focusable", "disabled", "leftDisabled", "rightDisabled"], outputs: ["leftClick", "rightClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
308
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarSpin, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
309
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiCalendarSpin, isStandalone: true, selector: "tui-calendar-spin", inputs: { value: "value", min: "min", max: "max" }, outputs: { valueChange: "valueChange", yearClick: "yearClick" }, ngImport: i0, template: "<tui-spin-button\n [focusable]=\"false\"\n [leftDisabled]=\"value.monthSameOrBefore(min)\"\n [rightDisabled]=\"value.monthSameOrAfter(max)\"\n (leftClick)=\"append({month: -1})\"\n (rightClick)=\"append({month: 1})\"\n>\n {{ months()[value.month] }}\n @if (min.year === max.year) {\n {{ value.formattedYear }}\n } @else {\n <button\n tabIndex=\"-1\"\n tuiLink\n type=\"button\"\n (click)=\"onYearClick()\"\n >\n {{ value.formattedYear }}\n </button>\n }\n</tui-spin-button>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: TuiLink, selector: "a[tuiLink], button[tuiLink]" }, { kind: "component", type: TuiSpinButton, selector: "tui-spin-button", inputs: ["focusable", "disabled", "leftDisabled", "rightDisabled"], outputs: ["leftClick", "rightClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
212
310
  }
213
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarSpin, decorators: [{
311
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarSpin, decorators: [{
214
312
  type: Component,
215
- args: [{ standalone: true, selector: 'tui-calendar-spin', imports: [AsyncPipe, NgIf, TuiLink, TuiMonthPipe, TuiSpinButton], changeDetection: ChangeDetectionStrategy.OnPush, template: "<tui-spin-button\n [focusable]=\"false\"\n [leftDisabled]=\"value.monthSameOrBefore(min)\"\n [rightDisabled]=\"value.monthSameOrAfter(max)\"\n (leftClick)=\"append({month: -1})\"\n (rightClick)=\"append({month: 1})\"\n>\n {{ value | tuiMonth | async }}\n <ng-container *ngIf=\"min.year === max.year; else button\">\n {{ value.formattedYear }}\n </ng-container>\n <ng-template #button>\n <button\n id=\"year-btn\"\n automation-id=\"tui-primitive-year-month-pagination__year-button\"\n tabIndex=\"-1\"\n tuiLink\n type=\"button\"\n (click)=\"onYearClick()\"\n >\n {{ value.formattedYear }}\n </button>\n </ng-template>\n</tui-spin-button>\n", styles: [":host{display:block}\n"] }]
313
+ args: [{ selector: 'tui-calendar-spin', imports: [TuiLink, TuiSpinButton], changeDetection: ChangeDetectionStrategy.OnPush, template: "<tui-spin-button\n [focusable]=\"false\"\n [leftDisabled]=\"value.monthSameOrBefore(min)\"\n [rightDisabled]=\"value.monthSameOrAfter(max)\"\n (leftClick)=\"append({month: -1})\"\n (rightClick)=\"append({month: 1})\"\n>\n {{ months()[value.month] }}\n @if (min.year === max.year) {\n {{ value.formattedYear }}\n } @else {\n <button\n tabIndex=\"-1\"\n tuiLink\n type=\"button\"\n (click)=\"onYearClick()\"\n >\n {{ value.formattedYear }}\n </button>\n }\n</tui-spin-button>\n", styles: [":host{display:block}\n"] }]
216
314
  }], propDecorators: { value: [{
217
315
  type: Input
218
316
  }], min: [{
@@ -314,14 +412,14 @@ class TuiCalendarYear {
314
412
  const max = this.max() ?? MAX_YEAR;
315
413
  return max < initial ? max + 1 : initial;
316
414
  }
317
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarYear, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
318
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "16.2.12", type: TuiCalendarYear, isStandalone: true, selector: "tui-calendar-year", inputs: { rangeMode: "rangeMode", disabledItemHandler: "disabledItemHandler", initialItemSetter: ["initialItem", "initialItemSetter", (x) => x ?? CURRENT_YEAR], minSetter: ["min", "minSetter", (x) => x ?? MIN_YEAR], maxSetter: ["max", "maxSetter", (x) => x ?? MAX_YEAR], valueSetter: ["value", "valueSetter"] }, outputs: { yearClick: "yearClick" }, host: { properties: { "class._picking": "isRangePicking()" } }, providers: [tuiAsAuxiliary(TuiCalendarYear)], ngImport: i0, template: "<div\n *tuiRepeatTimes=\"let rowIndex of rows\"\n automation-id=\"tui-calendar-year__row\"\n class=\"t-row\"\n>\n <ng-container *tuiRepeatTimes=\"let colIndex of 4\">\n <div\n *tuiLet=\"getItem(rowIndex, colIndex) as item\"\n automation-id=\"tui-calendar-year__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [class.t-cell_disabled]=\"isDisabled(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n (click)=\"yearClick.emit(item)\"\n (tuiHoveredChange)=\"onItemHovered($event, item)\"\n >\n {{ item }}\n </div>\n </ng-container>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.t-row:first-child{justify-content:flex-end}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;-webkit-mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem));mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;top:0;left:0;bottom:0;right:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{-webkit-mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat;mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);-webkit-mask:none;mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}:host{display:block;padding-inline-end:1rem;inline-size:15.75rem;padding:0 1.125rem}.t-cell{flex:1;border-block-start-width:.5rem;border-block-end-width:.5rem}\n"], dependencies: [{ kind: "directive", type: TuiHovered, selector: "[tuiHoveredChange]", outputs: ["tuiHoveredChange"] }, { kind: "directive", type: TuiLet, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "directive", type: TuiRepeatTimes, selector: "[tuiRepeatTimes][tuiRepeatTimesOf]", inputs: ["tuiRepeatTimesOf"] }, { kind: "directive", type: TuiScrollIntoView, selector: "[tuiScrollIntoView]", inputs: ["tuiScrollIntoView"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
415
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarYear, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
416
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiCalendarYear, isStandalone: true, selector: "tui-calendar-year", inputs: { rangeMode: "rangeMode", disabledItemHandler: "disabledItemHandler", initialItemSetter: ["initialItem", "initialItemSetter", (x) => x ?? CURRENT_YEAR], minSetter: ["min", "minSetter", (x) => x ?? MIN_YEAR], maxSetter: ["max", "maxSetter", (x) => x ?? MAX_YEAR], valueSetter: ["value", "valueSetter"] }, outputs: { yearClick: "yearClick" }, host: { properties: { "class._picking": "isRangePicking()" } }, providers: [tuiAsAuxiliary(TuiCalendarYear)], ngImport: i0, template: "@for (_ of '-'.repeat(rows); track $index) {\n @let rowIndex = $index;\n <div\n automation-id=\"tui-calendar-year__row\"\n class=\"t-row\"\n >\n @for (_ of '-'.repeat(4); track $index) {\n @let item = getItem(rowIndex, $index);\n <div\n automation-id=\"tui-calendar-year__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [class.t-cell_disabled]=\"isDisabled(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n (click)=\"yearClick.emit(item)\"\n (tuiHoveredChange)=\"onItemHovered($event, item)\"\n >\n {{ item }}\n </div>\n }\n </div>\n}\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-body-m)}.t-row:first-child{justify-content:flex-end}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;inset:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}:host{display:block;padding-inline-end:1rem;inline-size:15.75rem;padding:0 1.125rem}.t-cell{flex:1;border-block-start-width:.5rem;border-block-end-width:.5rem}\n"], dependencies: [{ kind: "directive", type: TuiHovered, selector: "[tuiHoveredChange]", outputs: ["tuiHoveredChange"] }, { kind: "directive", type: TuiScrollIntoView, selector: "[tuiScrollIntoView]", inputs: ["tuiScrollIntoView"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
319
417
  }
320
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarYear, decorators: [{
418
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendarYear, decorators: [{
321
419
  type: Component,
322
- args: [{ standalone: true, selector: 'tui-calendar-year', imports: [TuiHovered, TuiLet, TuiRepeatTimes, TuiScrollIntoView], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsAuxiliary(TuiCalendarYear)], host: {
420
+ args: [{ selector: 'tui-calendar-year', imports: [TuiHovered, TuiScrollIntoView], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsAuxiliary(TuiCalendarYear)], host: {
323
421
  '[class._picking]': 'isRangePicking()',
324
- }, template: "<div\n *tuiRepeatTimes=\"let rowIndex of rows\"\n automation-id=\"tui-calendar-year__row\"\n class=\"t-row\"\n>\n <ng-container *tuiRepeatTimes=\"let colIndex of 4\">\n <div\n *tuiLet=\"getItem(rowIndex, colIndex) as item\"\n automation-id=\"tui-calendar-year__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [class.t-cell_disabled]=\"isDisabled(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n (click)=\"yearClick.emit(item)\"\n (tuiHoveredChange)=\"onItemHovered($event, item)\"\n >\n {{ item }}\n </div>\n </ng-container>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.t-row:first-child{justify-content:flex-end}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;-webkit-mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem));mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;top:0;left:0;bottom:0;right:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{-webkit-mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat;mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);-webkit-mask:none;mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}:host{display:block;padding-inline-end:1rem;inline-size:15.75rem;padding:0 1.125rem}.t-cell{flex:1;border-block-start-width:.5rem;border-block-end-width:.5rem}\n"] }]
422
+ }, template: "@for (_ of '-'.repeat(rows); track $index) {\n @let rowIndex = $index;\n <div\n automation-id=\"tui-calendar-year__row\"\n class=\"t-row\"\n >\n @for (_ of '-'.repeat(4); track $index) {\n @let item = getItem(rowIndex, $index);\n <div\n automation-id=\"tui-calendar-year__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [class.t-cell_disabled]=\"isDisabled(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n (click)=\"yearClick.emit(item)\"\n (tuiHoveredChange)=\"onItemHovered($event, item)\"\n >\n {{ item }}\n </div>\n }\n </div>\n}\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-body-m)}.t-row:first-child{justify-content:flex-end}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;inset:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}:host{display:block;padding-inline-end:1rem;inline-size:15.75rem;padding:0 1.125rem}.t-cell{flex:1;border-block-start-width:.5rem;border-block-end-width:.5rem}\n"] }]
325
423
  }], propDecorators: { rangeMode: [{
326
424
  type: Input
327
425
  }], disabledItemHandler: [{
@@ -429,13 +527,12 @@ class TuiCalendar {
429
527
  this.hoveredItem = day;
430
528
  this.hoveredItemChange.emit(day);
431
529
  }
432
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendar, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
433
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendar, isStandalone: true, selector: "tui-calendar", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", min: "min", max: "max", minViewedMonth: "minViewedMonth", maxViewedMonth: "maxViewedMonth", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent", markerHandler: "markerHandler", value: "value", initialView: "initialView" }, outputs: { dayClick: "dayClick", monthChange: "monthChange", hoveredItemChange: "hoveredItemChange" }, host: { listeners: { "pointerdown.prevent.zoneless": "0" } }, providers: [tuiAsAuxiliary(TuiCalendar)], ngImport: i0, template: "<tui-scrollbar\n *ngIf=\"isInYearView; else calendar\"\n automation-id=\"tui-calendar__scrollbar\"\n class=\"t-scrollbar\"\n>\n <tui-calendar-year\n automation-id=\"tui-calendar__year\"\n [initialItem]=\"month.year\"\n [max]=\"computedMax.year\"\n [min]=\"computedMin.year\"\n [rangeMode]=\"options.rangeMode\"\n [value]=\"value\"\n (yearClick)=\"onPickerYearClick($event)\"\n />\n</tui-scrollbar>\n<ng-template #calendar>\n <tui-calendar-spin\n automation-id=\"tui-calendar__pagination\"\n class=\"t-pagination\"\n [max]=\"computedMaxViewedMonth\"\n [min]=\"computedMinViewedMonth\"\n [value]=\"month\"\n (valueChange)=\"onPaginationValueChange($event)\"\n (yearClick)=\"onPaginationYearClick()\"\n />\n <tui-calendar-sheet\n automation-id=\"tui-calendar__calendar\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n [hoveredItem]=\"hoveredItem\"\n [markerHandler]=\"markerHandler\"\n [month]=\"month\"\n [showAdjacent]=\"showAdjacent\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (hoveredItemChange)=\"onHoveredItemChange($event)\"\n />\n</ng-template>\n", styles: [":host{display:block;min-block-size:20.25rem;inline-size:18rem;padding:1rem 1.125rem;box-sizing:border-box;flex-shrink:0}:host-context(tui-dropdown-mobile){inline-size:100%}tui-calendar-year{padding:0}.t-scrollbar{block-size:18.25rem;inline-size:calc(100% + 1rem)}.t-pagination{margin-block-end:1rem}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiCalendarSheet, selector: "tui-calendar-sheet", inputs: ["month", "disabledItemHandler", "markerHandler", "value", "hoveredItem", "showAdjacent", "single"], outputs: ["hoveredItemChange", "dayClick"] }, { kind: "component", type: TuiCalendarSpin, selector: "tui-calendar-spin", inputs: ["value", "min", "max"], outputs: ["valueChange", "yearClick"] }, { kind: "component", type: TuiCalendarYear, selector: "tui-calendar-year", inputs: ["rangeMode", "disabledItemHandler", "initialItem", "min", "max", "value"], outputs: ["yearClick"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }, { kind: "component", type: TuiScrollbar, selector: "tui-scrollbar", inputs: ["hidden"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
530
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendar, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
531
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiCalendar, isStandalone: true, selector: "tui-calendar", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", min: "min", max: "max", minViewedMonth: "minViewedMonth", maxViewedMonth: "maxViewedMonth", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent", markerHandler: "markerHandler", value: "value", initialView: "initialView" }, outputs: { dayClick: "dayClick", monthChange: "monthChange", hoveredItemChange: "hoveredItemChange" }, host: { listeners: { "pointerdown.prevent.zoneless": "0" } }, providers: [tuiAsAuxiliary(TuiCalendar)], ngImport: i0, template: "@if (isInYearView) {\n <tui-scrollbar\n automation-id=\"tui-calendar__scrollbar\"\n class=\"t-scrollbar\"\n >\n <tui-calendar-year\n automation-id=\"tui-calendar__year\"\n [initialItem]=\"month.year\"\n [max]=\"computedMax.year\"\n [min]=\"computedMin.year\"\n [rangeMode]=\"options.rangeMode\"\n [value]=\"value\"\n (yearClick)=\"onPickerYearClick($event)\"\n />\n </tui-scrollbar>\n} @else {\n <tui-calendar-spin\n automation-id=\"tui-calendar__pagination\"\n class=\"t-pagination\"\n [max]=\"computedMaxViewedMonth\"\n [min]=\"computedMinViewedMonth\"\n [value]=\"month\"\n (valueChange)=\"onPaginationValueChange($event)\"\n (yearClick)=\"onPaginationYearClick()\"\n />\n <tui-calendar-sheet\n automation-id=\"tui-calendar__calendar\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n [hoveredItem]=\"hoveredItem\"\n [markerHandler]=\"markerHandler\"\n [month]=\"month\"\n [showAdjacent]=\"showAdjacent\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (hoveredItemChange)=\"onHoveredItemChange($event)\"\n />\n}\n", styles: [":host{display:block;min-block-size:20.25rem;inline-size:18rem;padding:1rem 1.125rem;box-sizing:border-box;flex-shrink:0}:host-context(tui-sheet-dialog){inline-size:100%}tui-calendar-year{padding:0}.t-scrollbar{block-size:18.25rem;inline-size:calc(100% + 1rem)}.t-pagination{margin-block-end:1rem}\n"], dependencies: [{ kind: "component", type: TuiCalendarSheet, selector: "tui-calendar-sheet", inputs: ["month", "disabledItemHandler", "markerHandler", "value", "hoveredItem", "showAdjacent", "single"], outputs: ["hoveredItemChange", "dayClick"] }, { kind: "component", type: TuiCalendarSpin, selector: "tui-calendar-spin", inputs: ["value", "min", "max"], outputs: ["valueChange", "yearClick"] }, { kind: "component", type: TuiCalendarYear, selector: "tui-calendar-year", inputs: ["rangeMode", "disabledItemHandler", "initialItem", "min", "max", "value"], outputs: ["yearClick"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }, { kind: "component", type: TuiScrollbar, selector: "tui-scrollbar" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
434
532
  }
435
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendar, decorators: [{
533
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiCalendar, decorators: [{
436
534
  type: Component,
437
- args: [{ standalone: true, selector: 'tui-calendar', imports: [
438
- NgIf,
535
+ args: [{ selector: 'tui-calendar', imports: [
439
536
  TuiCalendarSheet,
440
537
  TuiCalendarSpin,
441
538
  TuiCalendarYear,
@@ -443,7 +540,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
443
540
  TuiScrollbar,
444
541
  ], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsAuxiliary(TuiCalendar)], host: {
445
542
  '(pointerdown.prevent.zoneless)': '0',
446
- }, template: "<tui-scrollbar\n *ngIf=\"isInYearView; else calendar\"\n automation-id=\"tui-calendar__scrollbar\"\n class=\"t-scrollbar\"\n>\n <tui-calendar-year\n automation-id=\"tui-calendar__year\"\n [initialItem]=\"month.year\"\n [max]=\"computedMax.year\"\n [min]=\"computedMin.year\"\n [rangeMode]=\"options.rangeMode\"\n [value]=\"value\"\n (yearClick)=\"onPickerYearClick($event)\"\n />\n</tui-scrollbar>\n<ng-template #calendar>\n <tui-calendar-spin\n automation-id=\"tui-calendar__pagination\"\n class=\"t-pagination\"\n [max]=\"computedMaxViewedMonth\"\n [min]=\"computedMinViewedMonth\"\n [value]=\"month\"\n (valueChange)=\"onPaginationValueChange($event)\"\n (yearClick)=\"onPaginationYearClick()\"\n />\n <tui-calendar-sheet\n automation-id=\"tui-calendar__calendar\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n [hoveredItem]=\"hoveredItem\"\n [markerHandler]=\"markerHandler\"\n [month]=\"month\"\n [showAdjacent]=\"showAdjacent\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (hoveredItemChange)=\"onHoveredItemChange($event)\"\n />\n</ng-template>\n", styles: [":host{display:block;min-block-size:20.25rem;inline-size:18rem;padding:1rem 1.125rem;box-sizing:border-box;flex-shrink:0}:host-context(tui-dropdown-mobile){inline-size:100%}tui-calendar-year{padding:0}.t-scrollbar{block-size:18.25rem;inline-size:calc(100% + 1rem)}.t-pagination{margin-block-end:1rem}\n"] }]
543
+ }, template: "@if (isInYearView) {\n <tui-scrollbar\n automation-id=\"tui-calendar__scrollbar\"\n class=\"t-scrollbar\"\n >\n <tui-calendar-year\n automation-id=\"tui-calendar__year\"\n [initialItem]=\"month.year\"\n [max]=\"computedMax.year\"\n [min]=\"computedMin.year\"\n [rangeMode]=\"options.rangeMode\"\n [value]=\"value\"\n (yearClick)=\"onPickerYearClick($event)\"\n />\n </tui-scrollbar>\n} @else {\n <tui-calendar-spin\n automation-id=\"tui-calendar__pagination\"\n class=\"t-pagination\"\n [max]=\"computedMaxViewedMonth\"\n [min]=\"computedMinViewedMonth\"\n [value]=\"month\"\n (valueChange)=\"onPaginationValueChange($event)\"\n (yearClick)=\"onPaginationYearClick()\"\n />\n <tui-calendar-sheet\n automation-id=\"tui-calendar__calendar\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n [hoveredItem]=\"hoveredItem\"\n [markerHandler]=\"markerHandler\"\n [month]=\"month\"\n [showAdjacent]=\"showAdjacent\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (hoveredItemChange)=\"onHoveredItemChange($event)\"\n />\n}\n", styles: [":host{display:block;min-block-size:20.25rem;inline-size:18rem;padding:1rem 1.125rem;box-sizing:border-box;flex-shrink:0}:host-context(tui-sheet-dialog){inline-size:100%}tui-calendar-year{padding:0}.t-scrollbar{block-size:18.25rem;inline-size:calc(100% + 1rem)}.t-pagination{margin-block-end:1rem}\n"] }]
447
544
  }], propDecorators: { month: [{
448
545
  type: Input
449
546
  }], disabledItemHandler: [{
@@ -478,5 +575,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
478
575
  * Generated bundle index. Do not edit.
479
576
  */
480
577
 
481
- export { TUI_CALENDAR_SHEET_DEFAULT_OPTIONS, TUI_CALENDAR_SHEET_OPTIONS, TuiCalendar, TuiCalendarSheet, TuiCalendarSpin, TuiCalendarYear, tuiCalendarSheetOptionsProvider };
578
+ export { TUI_CALENDAR_DEFAULT_OPTIONS, TUI_CALENDAR_OPTIONS, TUI_CALENDAR_SHEET_DEFAULT_OPTIONS, TUI_CALENDAR_SHEET_OPTIONS, TuiCalendar, TuiCalendarSheet, TuiCalendarSheetPipe, TuiCalendarSpin, TuiCalendarYear, TuiOrderWeekDaysPipe, tuiCalendarOptionsProvider, tuiCalendarSheetOptionsProvider };
482
579
  //# sourceMappingURL=taiga-ui-core-components-calendar.mjs.map