@ng-nest/ui 15.0.5 → 15.0.7

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 (409) hide show
  1. package/anchor/anchor.component.d.ts +5 -5
  2. package/api/api.component.d.ts +1 -1
  3. package/auto-complete/auto-complete.component.d.ts +1 -1
  4. package/avatar/avatar.component.d.ts +3 -3
  5. package/back-top/back-top.component.d.ts +2 -2
  6. package/badge/badge.component.d.ts +2 -2
  7. package/border/border.component.d.ts +1 -1
  8. package/button/button.component.d.ts +2 -2
  9. package/button/buttons.component.d.ts +1 -1
  10. package/calendar/calendar.component.d.ts +2 -2
  11. package/card/card.component.d.ts +2 -2
  12. package/carousel/carousel-panel.component.d.ts +2 -2
  13. package/carousel/carousel.component.d.ts +4 -4
  14. package/cascade/cascade.component.d.ts +1 -1
  15. package/checkbox/checkbox.component.d.ts +3 -3
  16. package/collapse/collapse-panel.component.d.ts +2 -2
  17. package/collapse/collapse.component.d.ts +2 -2
  18. package/color/color.component.d.ts +1 -1
  19. package/color-picker/color-picker-portal.component.d.ts +4 -4
  20. package/color-picker/color-picker.component.d.ts +1 -1
  21. package/comment/comment-reply.component.d.ts +2 -2
  22. package/comment/comment.component.d.ts +2 -2
  23. package/container/aside.component.d.ts +1 -1
  24. package/container/container.component.d.ts +1 -1
  25. package/container/footer.component.d.ts +1 -1
  26. package/container/header.component.d.ts +1 -1
  27. package/container/main.component.d.ts +1 -1
  28. package/core/config/config.d.ts +1 -0
  29. package/core/functions/chunk.d.ts +1 -0
  30. package/core/functions/date.d.ts +1 -0
  31. package/core/functions/flex.d.ts +1 -1
  32. package/core/functions/group-by.d.ts +1 -0
  33. package/core/functions/guid.d.ts +4 -0
  34. package/core/functions/public-api.d.ts +4 -0
  35. package/core/{util → functions}/resize.d.ts +0 -0
  36. package/core/util/public-api.d.ts +0 -4
  37. package/date-picker/date-picker.component.d.ts +1 -1
  38. package/date-picker/date-picker.property.d.ts +129 -3
  39. package/date-picker/date-range-portal.component.d.ts +9 -8
  40. package/date-picker/date-range.component.d.ts +13 -11
  41. package/date-picker/picker-date.component.d.ts +15 -6
  42. package/dialog/dialog.component.d.ts +2 -2
  43. package/drawer/drawer.component.d.ts +2 -2
  44. package/dropdown/dropdown-portal.component.d.ts +2 -2
  45. package/dropdown/dropdown.component.d.ts +3 -3
  46. package/esm2020/anchor/anchor.component.mjs +1 -2
  47. package/esm2020/api/api.component.mjs +1 -1
  48. package/esm2020/auto-complete/auto-complete.component.mjs +1 -1
  49. package/esm2020/avatar/avatar.component.mjs +1 -1
  50. package/esm2020/back-top/back-top.component.mjs +1 -1
  51. package/esm2020/badge/badge.component.mjs +1 -1
  52. package/esm2020/base-form/base-form.component.mjs +3 -3
  53. package/esm2020/border/border.component.mjs +1 -1
  54. package/esm2020/button/button.component.mjs +1 -1
  55. package/esm2020/button/buttons.component.mjs +1 -1
  56. package/esm2020/calendar/calendar.component.mjs +1 -1
  57. package/esm2020/card/card.component.mjs +1 -1
  58. package/esm2020/carousel/carousel-panel.component.mjs +1 -1
  59. package/esm2020/carousel/carousel.component.mjs +1 -1
  60. package/esm2020/cascade/cascade.component.mjs +1 -1
  61. package/esm2020/checkbox/checkbox.component.mjs +1 -1
  62. package/esm2020/collapse/collapse-panel.component.mjs +1 -1
  63. package/esm2020/collapse/collapse.component.mjs +1 -1
  64. package/esm2020/color/color.component.mjs +1 -1
  65. package/esm2020/color-picker/color-picker-portal.component.mjs +1 -1
  66. package/esm2020/color-picker/color-picker.component.mjs +1 -1
  67. package/esm2020/comment/comment-reply.component.mjs +1 -1
  68. package/esm2020/comment/comment.component.mjs +1 -1
  69. package/esm2020/container/aside.component.mjs +1 -1
  70. package/esm2020/container/container.component.mjs +1 -1
  71. package/esm2020/container/footer.component.mjs +1 -1
  72. package/esm2020/container/header.component.mjs +1 -1
  73. package/esm2020/container/main.component.mjs +1 -1
  74. package/esm2020/core/config/config.mjs +1 -1
  75. package/esm2020/core/functions/chunk.mjs +14 -0
  76. package/esm2020/core/functions/date.mjs +20 -29
  77. package/esm2020/core/functions/flex.mjs +2 -2
  78. package/esm2020/core/functions/group-by.mjs +10 -0
  79. package/esm2020/core/functions/guid.mjs +10 -0
  80. package/esm2020/core/functions/order-by.mjs +24 -3
  81. package/esm2020/core/functions/public-api.mjs +5 -1
  82. package/esm2020/core/functions/resize.mjs +17 -0
  83. package/esm2020/core/util/public-api.mjs +1 -5
  84. package/esm2020/date-picker/date-picker-portal.component.mjs +2 -2
  85. package/esm2020/date-picker/date-picker.component.mjs +1 -1
  86. package/esm2020/date-picker/date-picker.property.mjs +23 -2
  87. package/esm2020/date-picker/date-range-portal.component.mjs +36 -33
  88. package/esm2020/date-picker/date-range.component.mjs +75 -53
  89. package/esm2020/date-picker/picker-date.component.mjs +133 -17
  90. package/esm2020/date-picker/picker-month.component.mjs +3 -3
  91. package/esm2020/date-picker/picker-year.component.mjs +3 -3
  92. package/esm2020/dialog/dialog.component.mjs +2 -2
  93. package/esm2020/drawer/drawer.component.mjs +1 -1
  94. package/esm2020/dropdown/dropdown-portal.component.mjs +1 -1
  95. package/esm2020/dropdown/dropdown.component.mjs +1 -1
  96. package/esm2020/find/find.component.mjs +1 -1
  97. package/esm2020/form/control.component.mjs +2 -2
  98. package/esm2020/form/form.component.mjs +8 -1
  99. package/esm2020/highlight/highlight.component.mjs +2 -2
  100. package/esm2020/i18n/i18n.property.mjs +1 -1
  101. package/esm2020/i18n/languages/en_GB.mjs +44 -18
  102. package/esm2020/i18n/languages/en_US.mjs +8 -2
  103. package/esm2020/i18n/languages/zh_CN.mjs +8 -2
  104. package/esm2020/i18n/languages/zh_TW.mjs +9 -3
  105. package/esm2020/icon/icon.component.mjs +1 -1
  106. package/esm2020/image/image-preview.component.mjs +1 -1
  107. package/esm2020/image/image.component.mjs +1 -1
  108. package/esm2020/inner/inner.component.mjs +1 -1
  109. package/esm2020/input/input-group.component.mjs +1 -1
  110. package/esm2020/input/input.component.mjs +2 -2
  111. package/esm2020/input-number/input-number.component.mjs +1 -1
  112. package/esm2020/link/link.component.mjs +1 -1
  113. package/esm2020/list/list-option.component.mjs +1 -1
  114. package/esm2020/list/list.component.mjs +2 -2
  115. package/esm2020/loading/loading.component.mjs +14 -7
  116. package/esm2020/loading/loading.property.mjs +1 -1
  117. package/esm2020/menu/menu-node.component.mjs +1 -1
  118. package/esm2020/menu/menu.component.mjs +3 -3
  119. package/esm2020/message/message.component.mjs +1 -1
  120. package/esm2020/message-box/message-box.component.mjs +1 -1
  121. package/esm2020/notification/notification.component.mjs +1 -1
  122. package/esm2020/pagination/pagination.component.mjs +1 -1
  123. package/esm2020/popconfirm/popconfirm.component.mjs +1 -1
  124. package/esm2020/popover/popover-portal.component.mjs +1 -1
  125. package/esm2020/progress/progress.component.mjs +1 -1
  126. package/esm2020/radio/radio.component.mjs +1 -1
  127. package/esm2020/rate/rate.component.mjs +1 -1
  128. package/esm2020/result/result.component.mjs +1 -1
  129. package/esm2020/select/select.component.mjs +3 -3
  130. package/esm2020/skeleton/skeleton.component.mjs +1 -1
  131. package/esm2020/slider/slider.component.mjs +1 -1
  132. package/esm2020/slider-select/slider-select.component.mjs +1 -1
  133. package/esm2020/steps/steps.component.mjs +1 -1
  134. package/esm2020/switch/switch.component.mjs +13 -6
  135. package/esm2020/switch/switch.module.mjs +6 -4
  136. package/esm2020/switch/switch.property.mjs +33 -4
  137. package/esm2020/table/drag.directive.mjs +13 -5
  138. package/esm2020/table/table-body.component.mjs +1 -1
  139. package/esm2020/table/table-foot.component.mjs +1 -1
  140. package/esm2020/table/table-head.component.mjs +20 -6
  141. package/esm2020/table/table.component.mjs +1 -1
  142. package/esm2020/table/table.property.mjs +23 -2
  143. package/esm2020/tabs/tab-content.component.mjs +1 -1
  144. package/esm2020/tabs/tab.component.mjs +3 -3
  145. package/esm2020/tabs/tabs.component.mjs +3 -3
  146. package/esm2020/tag/tag.component.mjs +1 -1
  147. package/esm2020/text-retract/text-retract.component.mjs +1 -1
  148. package/esm2020/textarea/textarea.component.mjs +1 -1
  149. package/esm2020/time-picker/time-picker-frame.component.mjs +188 -55
  150. package/esm2020/time-picker/time-picker-portal.component.mjs +30 -8
  151. package/esm2020/time-picker/time-picker.component.mjs +36 -9
  152. package/esm2020/time-picker/time-picker.module.mjs +8 -4
  153. package/esm2020/time-picker/time-picker.property.mjs +37 -3
  154. package/esm2020/timeline/timeline.component.mjs +1 -1
  155. package/esm2020/tooltip/tooltip-portal.component.mjs +3 -3
  156. package/esm2020/transfer/transfer.component.mjs +3 -3
  157. package/esm2020/transfer/transfer.module.mjs +8 -4
  158. package/esm2020/tree/tree-node.component.mjs +1 -1
  159. package/esm2020/tree/tree.component.mjs +1 -1
  160. package/esm2020/tree-file/tree-file.component.mjs +1 -1
  161. package/esm2020/tree-select/tree-select.component.mjs +1 -1
  162. package/esm2020/upload/upload-portal.component.mjs +5 -1
  163. package/esm2020/upload/upload.component.mjs +1 -1
  164. package/fesm2015/ng-nest-ui-anchor.mjs +0 -1
  165. package/fesm2015/ng-nest-ui-anchor.mjs.map +1 -1
  166. package/fesm2015/ng-nest-ui-api.mjs.map +1 -1
  167. package/fesm2015/ng-nest-ui-auto-complete.mjs.map +1 -1
  168. package/fesm2015/ng-nest-ui-avatar.mjs.map +1 -1
  169. package/fesm2015/ng-nest-ui-back-top.mjs.map +1 -1
  170. package/fesm2015/ng-nest-ui-badge.mjs.map +1 -1
  171. package/fesm2015/ng-nest-ui-base-form.mjs +2 -2
  172. package/fesm2015/ng-nest-ui-base-form.mjs.map +1 -1
  173. package/fesm2015/ng-nest-ui-border.mjs.map +1 -1
  174. package/fesm2015/ng-nest-ui-button.mjs.map +1 -1
  175. package/fesm2015/ng-nest-ui-calendar.mjs.map +1 -1
  176. package/fesm2015/ng-nest-ui-card.mjs.map +1 -1
  177. package/fesm2015/ng-nest-ui-carousel.mjs.map +1 -1
  178. package/fesm2015/ng-nest-ui-cascade.mjs.map +1 -1
  179. package/fesm2015/ng-nest-ui-checkbox.mjs.map +1 -1
  180. package/fesm2015/ng-nest-ui-collapse.mjs.map +1 -1
  181. package/fesm2015/ng-nest-ui-color-picker.mjs.map +1 -1
  182. package/fesm2015/ng-nest-ui-color.mjs.map +1 -1
  183. package/fesm2015/ng-nest-ui-comment.mjs.map +1 -1
  184. package/fesm2015/ng-nest-ui-container.mjs.map +1 -1
  185. package/fesm2015/ng-nest-ui-core.mjs +95 -84
  186. package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
  187. package/fesm2015/ng-nest-ui-date-picker.mjs +265 -103
  188. package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
  189. package/fesm2015/ng-nest-ui-dialog.mjs +1 -1
  190. package/fesm2015/ng-nest-ui-dialog.mjs.map +1 -1
  191. package/fesm2015/ng-nest-ui-drawer.mjs.map +1 -1
  192. package/fesm2015/ng-nest-ui-dropdown.mjs.map +1 -1
  193. package/fesm2015/ng-nest-ui-find.mjs.map +1 -1
  194. package/fesm2015/ng-nest-ui-form.mjs +8 -2
  195. package/fesm2015/ng-nest-ui-form.mjs.map +1 -1
  196. package/fesm2015/ng-nest-ui-highlight.mjs +1 -1
  197. package/fesm2015/ng-nest-ui-highlight.mjs.map +1 -1
  198. package/fesm2015/ng-nest-ui-i18n.mjs +65 -22
  199. package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
  200. package/fesm2015/ng-nest-ui-icon.mjs.map +1 -1
  201. package/fesm2015/ng-nest-ui-image.mjs.map +1 -1
  202. package/fesm2015/ng-nest-ui-inner.mjs.map +1 -1
  203. package/fesm2015/ng-nest-ui-input-number.mjs.map +1 -1
  204. package/fesm2015/ng-nest-ui-input.mjs +1 -2
  205. package/fesm2015/ng-nest-ui-input.mjs.map +1 -1
  206. package/fesm2015/ng-nest-ui-link.mjs.map +1 -1
  207. package/fesm2015/ng-nest-ui-list.mjs +1 -1
  208. package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
  209. package/fesm2015/ng-nest-ui-loading.mjs +13 -7
  210. package/fesm2015/ng-nest-ui-loading.mjs.map +1 -1
  211. package/fesm2015/ng-nest-ui-menu.mjs +2 -2
  212. package/fesm2015/ng-nest-ui-menu.mjs.map +1 -1
  213. package/fesm2015/ng-nest-ui-message-box.mjs.map +1 -1
  214. package/fesm2015/ng-nest-ui-message.mjs.map +1 -1
  215. package/fesm2015/ng-nest-ui-notification.mjs.map +1 -1
  216. package/fesm2015/ng-nest-ui-pagination.mjs.map +1 -1
  217. package/fesm2015/ng-nest-ui-popconfirm.mjs.map +1 -1
  218. package/fesm2015/ng-nest-ui-popover.mjs.map +1 -1
  219. package/fesm2015/ng-nest-ui-progress.mjs.map +1 -1
  220. package/fesm2015/ng-nest-ui-radio.mjs.map +1 -1
  221. package/fesm2015/ng-nest-ui-rate.mjs.map +1 -1
  222. package/fesm2015/ng-nest-ui-result.mjs.map +1 -1
  223. package/fesm2015/ng-nest-ui-select.mjs +2 -2
  224. package/fesm2015/ng-nest-ui-select.mjs.map +1 -1
  225. package/fesm2015/ng-nest-ui-skeleton.mjs.map +1 -1
  226. package/fesm2015/ng-nest-ui-slider-select.mjs.map +1 -1
  227. package/fesm2015/ng-nest-ui-slider.mjs.map +1 -1
  228. package/fesm2015/ng-nest-ui-steps.mjs.map +1 -1
  229. package/fesm2015/ng-nest-ui-switch.mjs +48 -12
  230. package/fesm2015/ng-nest-ui-switch.mjs.map +1 -1
  231. package/fesm2015/ng-nest-ui-table.mjs +53 -10
  232. package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
  233. package/fesm2015/ng-nest-ui-tabs.mjs +4 -4
  234. package/fesm2015/ng-nest-ui-tabs.mjs.map +1 -1
  235. package/fesm2015/ng-nest-ui-tag.mjs.map +1 -1
  236. package/fesm2015/ng-nest-ui-text-retract.mjs.map +1 -1
  237. package/fesm2015/ng-nest-ui-textarea.mjs.map +1 -1
  238. package/fesm2015/ng-nest-ui-time-picker.mjs +292 -81
  239. package/fesm2015/ng-nest-ui-time-picker.mjs.map +1 -1
  240. package/fesm2015/ng-nest-ui-timeline.mjs.map +1 -1
  241. package/fesm2015/ng-nest-ui-tooltip.mjs +2 -2
  242. package/fesm2015/ng-nest-ui-tooltip.mjs.map +1 -1
  243. package/fesm2015/ng-nest-ui-transfer.mjs +9 -5
  244. package/fesm2015/ng-nest-ui-transfer.mjs.map +1 -1
  245. package/fesm2015/ng-nest-ui-tree-file.mjs.map +1 -1
  246. package/fesm2015/ng-nest-ui-tree-select.mjs.map +1 -1
  247. package/fesm2015/ng-nest-ui-tree.mjs.map +1 -1
  248. package/fesm2015/ng-nest-ui-upload.mjs +4 -0
  249. package/fesm2015/ng-nest-ui-upload.mjs.map +1 -1
  250. package/fesm2020/ng-nest-ui-anchor.mjs +0 -1
  251. package/fesm2020/ng-nest-ui-anchor.mjs.map +1 -1
  252. package/fesm2020/ng-nest-ui-api.mjs.map +1 -1
  253. package/fesm2020/ng-nest-ui-auto-complete.mjs.map +1 -1
  254. package/fesm2020/ng-nest-ui-avatar.mjs.map +1 -1
  255. package/fesm2020/ng-nest-ui-back-top.mjs.map +1 -1
  256. package/fesm2020/ng-nest-ui-badge.mjs.map +1 -1
  257. package/fesm2020/ng-nest-ui-base-form.mjs +2 -2
  258. package/fesm2020/ng-nest-ui-base-form.mjs.map +1 -1
  259. package/fesm2020/ng-nest-ui-border.mjs.map +1 -1
  260. package/fesm2020/ng-nest-ui-button.mjs.map +1 -1
  261. package/fesm2020/ng-nest-ui-calendar.mjs.map +1 -1
  262. package/fesm2020/ng-nest-ui-card.mjs.map +1 -1
  263. package/fesm2020/ng-nest-ui-carousel.mjs.map +1 -1
  264. package/fesm2020/ng-nest-ui-cascade.mjs.map +1 -1
  265. package/fesm2020/ng-nest-ui-checkbox.mjs.map +1 -1
  266. package/fesm2020/ng-nest-ui-collapse.mjs.map +1 -1
  267. package/fesm2020/ng-nest-ui-color-picker.mjs.map +1 -1
  268. package/fesm2020/ng-nest-ui-color.mjs.map +1 -1
  269. package/fesm2020/ng-nest-ui-comment.mjs.map +1 -1
  270. package/fesm2020/ng-nest-ui-container.mjs.map +1 -1
  271. package/fesm2020/ng-nest-ui-core.mjs +95 -84
  272. package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
  273. package/fesm2020/ng-nest-ui-date-picker.mjs +264 -103
  274. package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
  275. package/fesm2020/ng-nest-ui-dialog.mjs +1 -1
  276. package/fesm2020/ng-nest-ui-dialog.mjs.map +1 -1
  277. package/fesm2020/ng-nest-ui-drawer.mjs.map +1 -1
  278. package/fesm2020/ng-nest-ui-dropdown.mjs.map +1 -1
  279. package/fesm2020/ng-nest-ui-find.mjs.map +1 -1
  280. package/fesm2020/ng-nest-ui-form.mjs +8 -2
  281. package/fesm2020/ng-nest-ui-form.mjs.map +1 -1
  282. package/fesm2020/ng-nest-ui-highlight.mjs +1 -1
  283. package/fesm2020/ng-nest-ui-highlight.mjs.map +1 -1
  284. package/fesm2020/ng-nest-ui-i18n.mjs +65 -22
  285. package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
  286. package/fesm2020/ng-nest-ui-icon.mjs.map +1 -1
  287. package/fesm2020/ng-nest-ui-image.mjs.map +1 -1
  288. package/fesm2020/ng-nest-ui-inner.mjs.map +1 -1
  289. package/fesm2020/ng-nest-ui-input-number.mjs.map +1 -1
  290. package/fesm2020/ng-nest-ui-input.mjs +1 -2
  291. package/fesm2020/ng-nest-ui-input.mjs.map +1 -1
  292. package/fesm2020/ng-nest-ui-link.mjs.map +1 -1
  293. package/fesm2020/ng-nest-ui-list.mjs +1 -1
  294. package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
  295. package/fesm2020/ng-nest-ui-loading.mjs +13 -7
  296. package/fesm2020/ng-nest-ui-loading.mjs.map +1 -1
  297. package/fesm2020/ng-nest-ui-menu.mjs +2 -2
  298. package/fesm2020/ng-nest-ui-menu.mjs.map +1 -1
  299. package/fesm2020/ng-nest-ui-message-box.mjs.map +1 -1
  300. package/fesm2020/ng-nest-ui-message.mjs.map +1 -1
  301. package/fesm2020/ng-nest-ui-notification.mjs.map +1 -1
  302. package/fesm2020/ng-nest-ui-pagination.mjs.map +1 -1
  303. package/fesm2020/ng-nest-ui-popconfirm.mjs.map +1 -1
  304. package/fesm2020/ng-nest-ui-popover.mjs.map +1 -1
  305. package/fesm2020/ng-nest-ui-progress.mjs.map +1 -1
  306. package/fesm2020/ng-nest-ui-radio.mjs.map +1 -1
  307. package/fesm2020/ng-nest-ui-rate.mjs.map +1 -1
  308. package/fesm2020/ng-nest-ui-result.mjs.map +1 -1
  309. package/fesm2020/ng-nest-ui-select.mjs +2 -2
  310. package/fesm2020/ng-nest-ui-select.mjs.map +1 -1
  311. package/fesm2020/ng-nest-ui-skeleton.mjs.map +1 -1
  312. package/fesm2020/ng-nest-ui-slider-select.mjs.map +1 -1
  313. package/fesm2020/ng-nest-ui-slider.mjs.map +1 -1
  314. package/fesm2020/ng-nest-ui-steps.mjs.map +1 -1
  315. package/fesm2020/ng-nest-ui-switch.mjs +48 -12
  316. package/fesm2020/ng-nest-ui-switch.mjs.map +1 -1
  317. package/fesm2020/ng-nest-ui-table.mjs +53 -10
  318. package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
  319. package/fesm2020/ng-nest-ui-tabs.mjs +4 -4
  320. package/fesm2020/ng-nest-ui-tabs.mjs.map +1 -1
  321. package/fesm2020/ng-nest-ui-tag.mjs.map +1 -1
  322. package/fesm2020/ng-nest-ui-text-retract.mjs.map +1 -1
  323. package/fesm2020/ng-nest-ui-textarea.mjs.map +1 -1
  324. package/fesm2020/ng-nest-ui-time-picker.mjs +291 -78
  325. package/fesm2020/ng-nest-ui-time-picker.mjs.map +1 -1
  326. package/fesm2020/ng-nest-ui-timeline.mjs.map +1 -1
  327. package/fesm2020/ng-nest-ui-tooltip.mjs +2 -2
  328. package/fesm2020/ng-nest-ui-tooltip.mjs.map +1 -1
  329. package/fesm2020/ng-nest-ui-transfer.mjs +9 -5
  330. package/fesm2020/ng-nest-ui-transfer.mjs.map +1 -1
  331. package/fesm2020/ng-nest-ui-tree-file.mjs.map +1 -1
  332. package/fesm2020/ng-nest-ui-tree-select.mjs.map +1 -1
  333. package/fesm2020/ng-nest-ui-tree.mjs.map +1 -1
  334. package/fesm2020/ng-nest-ui-upload.mjs +4 -0
  335. package/fesm2020/ng-nest-ui-upload.mjs.map +1 -1
  336. package/find/find.component.d.ts +1 -1
  337. package/form/form.component.d.ts +1 -0
  338. package/highlight/highlight.component.d.ts +3 -3
  339. package/i18n/i18n.property.d.ts +6 -0
  340. package/i18n/languages/en_GB.d.ts +26 -0
  341. package/i18n/languages/en_US.d.ts +6 -0
  342. package/i18n/languages/zh_CN.d.ts +6 -0
  343. package/i18n/languages/zh_TW.d.ts +6 -0
  344. package/icon/icon.component.d.ts +2 -2
  345. package/image/image-preview.component.d.ts +2 -2
  346. package/image/image.component.d.ts +2 -2
  347. package/inner/inner.component.d.ts +1 -1
  348. package/input/input-group.component.d.ts +2 -2
  349. package/input/input.component.d.ts +5 -5
  350. package/input-number/input-number.component.d.ts +1 -1
  351. package/link/link.component.d.ts +2 -2
  352. package/list/list-option.component.d.ts +2 -2
  353. package/list/list.component.d.ts +7 -7
  354. package/loading/loading.component.d.ts +3 -2
  355. package/loading/loading.property.d.ts +1 -1
  356. package/menu/menu-node.component.d.ts +2 -2
  357. package/menu/menu.component.d.ts +3 -3
  358. package/message/message.component.d.ts +2 -2
  359. package/message-box/message-box.component.d.ts +2 -2
  360. package/notification/notification.component.d.ts +2 -2
  361. package/package.json +1 -1
  362. package/pagination/pagination.component.d.ts +2 -2
  363. package/popconfirm/popconfirm.component.d.ts +2 -2
  364. package/popover/popover-portal.component.d.ts +2 -2
  365. package/progress/progress.component.d.ts +2 -2
  366. package/radio/radio.component.d.ts +3 -3
  367. package/rate/rate.component.d.ts +3 -3
  368. package/result/result.component.d.ts +2 -2
  369. package/select/select.component.d.ts +1 -1
  370. package/skeleton/skeleton.component.d.ts +2 -2
  371. package/slider/slider.component.d.ts +4 -4
  372. package/slider-select/slider-select.component.d.ts +6 -6
  373. package/steps/steps.component.d.ts +2 -2
  374. package/switch/switch.component.d.ts +3 -2
  375. package/switch/switch.module.d.ts +3 -1
  376. package/switch/switch.property.d.ts +42 -1
  377. package/table/drag.directive.d.ts +12 -2
  378. package/table/table-body.component.d.ts +3 -3
  379. package/table/table-foot.component.d.ts +3 -3
  380. package/table/table-head.component.d.ts +14 -4
  381. package/table/table.component.d.ts +12 -12
  382. package/table/table.property.d.ts +50 -1
  383. package/tabs/tab-content.component.d.ts +1 -1
  384. package/tabs/tabs.component.d.ts +1 -1
  385. package/tag/tag.component.d.ts +2 -2
  386. package/text-retract/text-retract.component.d.ts +2 -2
  387. package/textarea/textarea.component.d.ts +4 -4
  388. package/time-picker/time-picker-frame.component.d.ts +30 -23
  389. package/time-picker/time-picker-portal.component.d.ts +13 -3
  390. package/time-picker/time-picker.component.d.ts +6 -3
  391. package/time-picker/time-picker.module.d.ts +2 -1
  392. package/time-picker/time-picker.property.d.ts +38 -2
  393. package/timeline/timeline.component.d.ts +2 -2
  394. package/tooltip/tooltip-portal.component.d.ts +3 -3
  395. package/transfer/transfer.component.d.ts +2 -2
  396. package/transfer/transfer.module.d.ts +2 -1
  397. package/tree/tree-node.component.d.ts +2 -2
  398. package/tree/tree.component.d.ts +3 -3
  399. package/tree-file/tree-file.component.d.ts +2 -2
  400. package/tree-select/tree-select.component.d.ts +1 -1
  401. package/upload/upload-portal.component.d.ts +6 -6
  402. package/upload/upload.component.d.ts +3 -3
  403. package/core/util/chunk.d.ts +0 -1
  404. package/core/util/group-by.d.ts +0 -1
  405. package/core/util/guid.d.ts +0 -4
  406. package/esm2020/core/util/chunk.mjs +0 -14
  407. package/esm2020/core/util/group-by.mjs +0 -10
  408. package/esm2020/core/util/guid.mjs +0 -10
  409. package/esm2020/core/util/resize.mjs +0 -17
@@ -2,7 +2,7 @@ import * as i0 from '@angular/core';
2
2
  import { EventEmitter, Component, Input, Output, ViewEncapsulation, ChangeDetectionStrategy, HostBinding, HostListener, ViewChild, NgModule } from '@angular/core';
3
3
  import { __decorate } from 'tslib';
4
4
  import * as i2 from '@ng-nest/ui/core';
5
- import { XWithConfig, XInputBoolean, XDataConvert, XProperty, XIsChange, chunk, XIsEmpty, XAddDays, XConnectBaseAnimation, XIsDate, XIsNumber, XIsString, XIsNull, XClearClass, XAddMonths, XAddYears, XIsUndefined } from '@ng-nest/ui/core';
5
+ import { XWithConfig, XInputBoolean, XDataConvert, XProperty, XIsChange, XIsNull, XChunk, XIsEmpty, XAddDays, XConnectBaseAnimation, XIsDate, XIsNumber, XIsString, XClearClass, XAddMonths, XAddYears, XIsUndefined } from '@ng-nest/ui/core';
6
6
  import { XControlValueAccessor, XValueAccessor, XBaseFormModule } from '@ng-nest/ui/base-form';
7
7
  import { Subject } from 'rxjs';
8
8
  import { map, takeUntil } from 'rxjs/operators';
@@ -262,10 +262,25 @@ class XPickerDateProperty extends XProperty {
262
262
  * @en_US display date event
263
263
  */
264
264
  this.displayChange = new EventEmitter();
265
+ /**
266
+ * @zh_CN 范围日期 mouseenter 事件
267
+ * @en_US Date mouseenter event
268
+ */
269
+ this.rangeTdMouseenter = new EventEmitter();
270
+ /**
271
+ * @zh_CN 范围日期 mouseleave 事件
272
+ * @en_US Date mouseleave event
273
+ */
274
+ this.rangeTdMouseleave = new EventEmitter();
275
+ /**
276
+ * @zh_CN 范围中的日期点击事件
277
+ * @en_US Range date click event
278
+ */
279
+ this.rangeDateClick = new EventEmitter();
265
280
  }
266
281
  }
267
282
  /** @nocollapse */ XPickerDateProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XPickerDateProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
268
- /** @nocollapse */ XPickerDateProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XPickerDateProperty, selector: "ng-component", inputs: { type: "type", display: "display", model: "model", dateTemp: "dateTemp", showHeader: "showHeader", rangePicker: "rangePicker", lastYearBtn: "lastYearBtn", lastMonthBtn: "lastMonthBtn", nextYearBtn: "nextYearBtn", nextMonthBtn: "nextMonthBtn", rangeValue: "rangeValue", rangeType: "rangeType" }, outputs: { typeChange: "typeChange", modelChange: "modelChange", rangeChange: "rangeChange", yearChange: "yearChange", monthChange: "monthChange", displayChange: "displayChange" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
283
+ /** @nocollapse */ XPickerDateProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XPickerDateProperty, selector: "ng-component", inputs: { type: "type", display: "display", model: "model", dateTemp: "dateTemp", showHeader: "showHeader", rangePicker: "rangePicker", lastYearBtn: "lastYearBtn", lastMonthBtn: "lastMonthBtn", nextYearBtn: "nextYearBtn", nextMonthBtn: "nextMonthBtn", rangeValue: "rangeValue", rangeType: "rangeType" }, outputs: { typeChange: "typeChange", modelChange: "modelChange", rangeChange: "rangeChange", yearChange: "yearChange", monthChange: "monthChange", displayChange: "displayChange", rangeTdMouseenter: "rangeTdMouseenter", rangeTdMouseleave: "rangeTdMouseleave", rangeDateClick: "rangeDateClick" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
269
284
  __decorate([
270
285
  XInputBoolean()
271
286
  ], XPickerDateProperty.prototype, "showHeader", void 0);
@@ -323,6 +338,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
323
338
  type: Output
324
339
  }], displayChange: [{
325
340
  type: Output
341
+ }], rangeTdMouseenter: [{
342
+ type: Output
343
+ }], rangeTdMouseleave: [{
344
+ type: Output
345
+ }], rangeDateClick: [{
346
+ type: Output
326
347
  }] } });
327
348
  /**
328
349
  * PickerMonth
@@ -481,6 +502,7 @@ class XPickerDateComponent extends XPickerDateProperty {
481
502
  ];
482
503
  this.now = new Date();
483
504
  this.dates = [];
505
+ this.weekDates = [];
484
506
  this.locale = {};
485
507
  this._unSubject = new Subject();
486
508
  }
@@ -515,6 +537,94 @@ class XPickerDateComponent extends XPickerDateProperty {
515
537
  init() {
516
538
  this.setDays(this.display);
517
539
  }
540
+ isStartDate(date) {
541
+ if (!this.rangeType || !this.rangeValue)
542
+ return;
543
+ if (!XIsNull(this.rangeValue[0])) {
544
+ return this.datePipe.transform(this.rangeValue[0], 'yyyyMMdd') === this.datePipe.transform(date, 'yyyyMMdd');
545
+ }
546
+ return;
547
+ }
548
+ isEndDate(date) {
549
+ if (!this.rangeType || !this.rangeValue)
550
+ return;
551
+ if (!XIsNull(this.rangeValue[1])) {
552
+ return this.datePipe.transform(this.rangeValue[1], 'yyyyMMdd') === this.datePipe.transform(date, 'yyyyMMdd');
553
+ }
554
+ return;
555
+ }
556
+ setDatesState(cell) {
557
+ this.clearState(...this.dates);
558
+ for (let item of this.dates) {
559
+ this.setDayState(item);
560
+ }
561
+ this.onTdMouseenter(cell, false);
562
+ }
563
+ onTdMouseenter(cell, isEmit = true) {
564
+ const [start, end] = this.rangeValue;
565
+ if (!XIsNull(start) || !XIsNull(end)) {
566
+ const time = cell.date.getTime();
567
+ for (let item of this.dates) {
568
+ const itemTime = item.date.getTime();
569
+ this.clearState(item);
570
+ if (!XIsNull(start) && XIsNull(end)) {
571
+ item.isRangeHoverStartLeft = time < start && itemTime === start;
572
+ item.isRangeHoverStartRight = time > start && itemTime === start;
573
+ item.isRangeHover =
574
+ (time < start && itemTime >= time && itemTime < start) || (time > start && itemTime > start && itemTime <= time);
575
+ item.isRangeHoverStart = itemTime === time && time < start;
576
+ item.isRangeHoverEnd = itemTime === time && time > start;
577
+ }
578
+ else if (XIsNull(start) && !XIsNull(end)) {
579
+ item.isRangeHoverEndLeft = time < end && itemTime === end;
580
+ item.isRangeHoverEndRight = time > end && itemTime === end;
581
+ item.isRangeHover = (time < end && itemTime >= time && itemTime < end) || (time > end && itemTime > end && itemTime <= time);
582
+ item.isRangeHoverStart = itemTime === time && time < end;
583
+ item.isRangeHoverEnd = itemTime === time && time > end;
584
+ }
585
+ else if (!XIsNull(start) && !XIsNull(end)) {
586
+ item.isRangeHoverStartLeft = time < start && itemTime === start;
587
+ item.isRangeHoverEndRight = time > end && itemTime === end;
588
+ item.isRangeHover =
589
+ (time < start && itemTime >= time && itemTime < start) || (time > end && itemTime > end && itemTime <= time);
590
+ item.isRangeHoverStart = itemTime === time && time < start;
591
+ item.isRangeHoverEnd = itemTime === time && time > end;
592
+ if (this.rangeType === 'start') {
593
+ item.isInRangeHover = itemTime >= time && itemTime <= end;
594
+ }
595
+ else if (this.rangeType === 'end') {
596
+ item.isInRangeHover = itemTime >= start && itemTime <= time;
597
+ }
598
+ }
599
+ }
600
+ if (isEmit) {
601
+ this.rangeTdMouseenter.emit(cell);
602
+ }
603
+ else {
604
+ this.cdr.detectChanges();
605
+ }
606
+ }
607
+ }
608
+ onTdMouseleave(cell, isEmit = true) {
609
+ const [start, end] = this.rangeValue;
610
+ if (!XIsNull(start) || !XIsNull(end)) {
611
+ this.clearState(...this.dates);
612
+ if (isEmit)
613
+ this.rangeTdMouseleave.emit(cell);
614
+ }
615
+ }
616
+ clearState(...cells) {
617
+ for (let cell of cells) {
618
+ cell.isInRangeHover = false;
619
+ cell.isRangeHover = false;
620
+ cell.isRangeHoverStart = false;
621
+ cell.isRangeHoverEnd = false;
622
+ cell.isRangeHoverStartLeft = false;
623
+ cell.isRangeHoverStartRight = false;
624
+ cell.isRangeHoverEndLeft = false;
625
+ cell.isRangeHoverEndRight = false;
626
+ }
627
+ }
518
628
  setDays(date) {
519
629
  let dates = [];
520
630
  const year = date.getFullYear();
@@ -528,33 +638,60 @@ class XPickerDateComponent extends XPickerDateProperty {
528
638
  let index = 1;
529
639
  while (day !== 1) {
530
640
  index--;
531
- let date = new Date(year, month, index);
532
- dates = [date, ...dates];
533
- day = date.getDay();
641
+ const cell = { date: new Date(year, month, index) };
642
+ dates = [this.setDayState(cell), ...dates];
643
+ day = cell.date.getDay();
534
644
  }
535
645
  index = 1;
536
646
  do {
537
- dates = [...dates, new Date(year, month, index)];
647
+ const cell = { date: new Date(year, month, index), isFirstDay: index === 1, isLastDay: index === lastDate };
648
+ dates = [...dates, this.setDayState(cell)];
538
649
  index++;
539
650
  } while (index <= lastDate);
540
651
  index = 0;
541
652
  day = lastDay;
542
653
  while (day !== 0 || dates.length !== 7 * 6) {
543
654
  index++;
544
- let date = new Date(year, month + 1, index);
545
- dates = [...dates, date];
546
- day = date.getDay();
655
+ const cell = { date: new Date(year, month + 1, index) };
656
+ dates = [...dates, this.setDayState(cell)];
657
+ day = cell.date.getDay();
547
658
  }
548
- this.dates = chunk(dates, 7);
659
+ this.dates = dates;
660
+ this.weekDates = XChunk(dates, 7);
549
661
  if (this.dates.length > 0) {
550
- this.rangeChange.emit([dates[0], dates[dates.length - 1]]);
662
+ this.rangeChange.emit([dates[0].date, dates[dates.length - 1].date]);
551
663
  }
552
664
  this.cdr.detectChanges();
553
665
  }
554
- dateClick(date) {
555
- this.model = date;
556
- this.modelChange.emit(date);
557
- this.cdr.markForCheck();
666
+ setDayState(cell) {
667
+ const time = cell.date?.getTime();
668
+ const fdate = this.datePipe.transform(cell.date, 'yyyyMMdd');
669
+ const fdatem = this.datePipe.transform(cell.date, 'yyyyMM');
670
+ const fdisplaym = this.datePipe.transform(this.display, 'yyyyMM');
671
+ const fnow = this.datePipe.transform(this.now, 'yyyyMMdd');
672
+ cell.isLastOrNext = fdatem !== fdisplaym;
673
+ cell.isNow = fdate === fnow;
674
+ if (this.rangePicker) {
675
+ if (!this.rangeValue)
676
+ return cell;
677
+ const [start, end] = this.rangeValue;
678
+ cell.isInRange = !!start && !!end && time >= start && time <= end;
679
+ cell.isRangeStartRight = !!start && !!end && fdate === this.datePipe.transform(start, 'yyyyMMdd');
680
+ cell.isRangeEndLeft = !!start && !!end && fdate === this.datePipe.transform(end, 'yyyyMMdd');
681
+ }
682
+ return cell;
683
+ }
684
+ dateClick(cell) {
685
+ this.model = cell.date;
686
+ this.modelChange.emit(cell.date);
687
+ if (this.rangePicker) {
688
+ this.clearState(...this.dates);
689
+ for (let item of this.dates) {
690
+ this.setDayState(item);
691
+ }
692
+ this.rangeDateClick.emit(cell);
693
+ }
694
+ this.cdr.detectChanges();
558
695
  }
559
696
  getLocaleMonth(date) {
560
697
  return this.locale[this.lowerCasePipe.transform(this.datePipe.transform(date, 'LLLL'))];
@@ -597,10 +734,10 @@ class XPickerDateComponent extends XPickerDateProperty {
597
734
  }
598
735
  }
599
736
  /** @nocollapse */ XPickerDateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XPickerDateComponent, deps: [{ token: i0.Renderer2 }, { token: i1.DatePipe }, { token: i1.LowerCasePipe }, { token: i0.ChangeDetectorRef }, { token: i2.XConfigService }, { token: i3.XI18nService }], target: i0.ɵɵFactoryTarget.Component });
600
- /** @nocollapse */ XPickerDateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XPickerDateComponent, selector: "x-picker-date", providers: [DatePipe, LowerCasePipe], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"x-picker-date\" [class.x-date-picker-datetemp]=\"dateTemp\">\r\n <div class=\"x-picker-date-header\" *ngIf=\"showHeader\">\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" [class.x-visibility]=\"!lastYearBtn\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" [class.x-visibility]=\"!lastMonthBtn\"></x-button>\r\n <div class=\"x-picker-date-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeOnChange('year')\">{{ display | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeOnChange('month')\">{{ getLocaleMonth(display) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\" [class.x-visibility]=\"!nextYearBtn\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\" [class.x-visibility]=\"!nextMonthBtn\"></x-button>\r\n </div>\r\n <div class=\"x-picker-date-body\">\r\n <table cellspacing=\"0\" cellpadding=\"0\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let title of titles; trackBy: trackByNode\">{{ title | xI18n }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let weeks of dates\">\r\n <ng-container *ngFor=\"let week of weeks; trackBy: trackByNode\">\r\n <td\r\n [class.x-date-last-or-next]=\"(week | date: 'yyyyMM') !== (display | date: 'yyyyMM')\"\r\n [class.x-date-now]=\"(week | date: 'yyyyMMdd') === (now | date: 'yyyyMMdd')\"\r\n (click)=\"dateTemp && dateClick(week)\"\r\n >\r\n <x-button\r\n *ngIf=\"!dateTemp\"\r\n type=\"text\"\r\n size=\"mini\"\r\n title=\"{{ week | date: 'yyyy-MM-dd' }}\"\r\n [activated]=\"!rangePicker && (week | date: 'yyyyMMdd') === (model | date: 'yyyyMMdd')\"\r\n [disabled]=\"false\"\r\n (click)=\"dateClick(week)\"\r\n >{{ week | date: 'd' }}</x-button\r\n >\r\n <ng-container *ngIf=\"dateTemp\">\r\n <ng-container *ngTemplateOutlet=\"dateTemp; context: { date$: week }\"></ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.x-picker-date{margin:0;padding:0}.x-picker-date-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-picker-date-year-month{flex:1;text-align:center}.x-picker-date-body{padding:.5rem}.x-picker-date-body>table{width:100%;border-collapse:collapse;border-spacing:0}.x-picker-date-body>table th{font-weight:400;height:2rem;color:var(--x-text-400)}.x-picker-date-body>table td{padding:.25rem 0;text-align:center}.x-picker-date-body>table td x-button .x-button{width:1.625rem;height:1.5rem;margin:0 auto;border:.0625rem solid transparent}.x-picker-date-body>table td x-button .x-button:hover{background-color:var(--x-primary-900)}.x-picker-date-body>table td x-button .x-button-activated{color:var(--x-background-100);background-color:var(--x-primary)}.x-picker-date-body>table td x-button .x-button-activated:hover{color:var(--x-background-100);background-color:var(--x-primary)}.x-picker-date-body>table td.x-date-last-or-next x-button .x-button{color:var(--x-text-700)}.x-picker-date-body>table td.x-date-now x-button .x-button:not(.x-button-activated){color:var(--x-primary);background-color:transparent;border-color:var(--x-primary)}.x-picker-date .x-visibility{visibility:hidden}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "pipe", type: i1.DatePipe, name: "date" }, { kind: "pipe", type: i3.XI18nPipe, name: "xI18n" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
737
+ /** @nocollapse */ XPickerDateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XPickerDateComponent, selector: "x-picker-date", providers: [DatePipe, LowerCasePipe], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"x-picker-date\" [class.x-date-picker-datetemp]=\"dateTemp\">\r\n <div class=\"x-picker-date-header\" *ngIf=\"showHeader\">\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" [class.x-visibility]=\"!lastYearBtn\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" [class.x-visibility]=\"!lastMonthBtn\"></x-button>\r\n <div class=\"x-picker-date-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeOnChange('year')\">{{ display | date : 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeOnChange('month')\">{{ getLocaleMonth(display) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\" [class.x-visibility]=\"!nextYearBtn\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\" [class.x-visibility]=\"!nextMonthBtn\"></x-button>\r\n </div>\r\n <div class=\"x-picker-date-body\">\r\n <table cellspacing=\"0\" cellpadding=\"0\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let title of titles; trackBy: trackByNode\">{{ title | xI18n }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let weeks of weekDates\">\r\n <ng-container *ngFor=\"let week of weeks; trackBy: trackByNode\">\r\n <td\r\n [class.x-date-last-or-next]=\"week.isLastOrNext\"\r\n [class.x-date-now]=\"week.isNow\"\r\n [class.x-date-first-day]=\"week.isFirstDay\"\r\n [class.x-date-last-day]=\"week.isLastDay\"\r\n [class.x-date-range-start]=\"rangePicker && isStartDate(week.date!)\"\r\n [class.x-date-range-end]=\"rangePicker && isEndDate(week.date!)\"\r\n [class.x-date-range-start-left]=\"rangePicker && week.isRangeStartLeft\"\r\n [class.x-date-range-start-right]=\"rangePicker && week.isRangeStartRight\"\r\n [class.x-date-range-end-left]=\"rangePicker && week.isRangeEndLeft\"\r\n [class.x-date-range-end-right]=\"rangePicker && week.isRangeEndRight\"\r\n [class.x-date-range-hover]=\"rangePicker && week.isRangeHover\"\r\n [class.x-date-range-hover-start-left]=\"rangePicker && week.isRangeHoverStartLeft\"\r\n [class.x-date-range-hover-start-right]=\"rangePicker && week.isRangeHoverStartRight\"\r\n [class.x-date-range-hover-end-left]=\"rangePicker && week.isRangeHoverEndLeft\"\r\n [class.x-date-range-hover-end-right]=\"rangePicker && week.isRangeHoverEndRight\"\r\n [class.x-date-range-hover-start]=\"rangePicker && week.isRangeHoverStart\"\r\n [class.x-date-range-hover-end]=\"rangePicker && week.isRangeHoverEnd\"\r\n [class.x-date-in-range]=\"rangePicker && week.isInRange\"\r\n [class.x-date-in-range-hover]=\"rangePicker && week.isInRangeHover\"\r\n [class.x-date-active]=\"!rangePicker && (week.date | date : 'yyyyMMdd') === (model | date : 'yyyyMMdd')\"\r\n title=\"{{ week.date | date : 'yyyy-MM-dd' }}\"\r\n (click)=\"dateClick(week)\"\r\n (mouseenter)=\"rangePicker && onTdMouseenter(week)\"\r\n (mouseleave)=\"rangePicker && onTdMouseleave(week)\"\r\n >\r\n <div *ngIf=\"!dateTemp\" class=\"x-date-text\">\r\n {{ week.date | date : 'd' }}\r\n </div>\r\n <ng-container *ngIf=\"dateTemp\">\r\n <ng-container *ngTemplateOutlet=\"dateTemp; context: { date$: week.date }\"></ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.x-picker-date{margin:0;padding:0}.x-picker-date-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-picker-date-year-month{flex:1;text-align:center}.x-picker-date-body{padding:.5rem}.x-picker-date-body>table{width:100%;border-collapse:collapse;border-spacing:0}.x-picker-date-body>table th{font-weight:400;height:2rem;color:var(--x-text-400)}.x-picker-date-body>table td{padding:.25rem 0;text-align:center;cursor:pointer;color:var(--x-text-300);position:relative}.x-picker-date-body>table td .x-date-text{width:1.75rem;height:1.5rem;margin:0 auto;border:var(--x-border-width) var(--x-border-style) transparent;border-radius:var(--x-border-radius);transition:var(--x-animation-duration-base);position:relative}.x-picker-date-body>table td:before,.x-picker-date-body>table td:after{position:absolute;top:50%;right:0;left:0;z-index:1;height:1.5rem;border:var(--x-border-width) dashed transparent;transform:translateY(-50%);transition:var(--x-animation-duration-base);content:\"\"}.x-picker-date-body>table td:hover:not(.x-date-in-range) .x-date-text{background-color:var(--x-background-a200)}.x-picker-date-body>table td.x-date-active:not(.x-date-last-or-next),.x-picker-date-body>table td.x-date-range-start:not(.x-date-last-or-next),.x-picker-date-body>table td.x-date-range-end:not(.x-date-last-or-next){color:var(--x-background-100)}.x-picker-date-body>table td.x-date-active:not(.x-date-last-or-next) .x-date-text,.x-picker-date-body>table td.x-date-range-start:not(.x-date-last-or-next) .x-date-text,.x-picker-date-body>table td.x-date-range-end:not(.x-date-last-or-next) .x-date-text{background-color:var(--x-primary);border-color:var(--x-primary)}.x-picker-date-body>table td.x-date-active:not(.x-date-last-or-next):hover,.x-picker-date-body>table td.x-date-range-start:not(.x-date-last-or-next):hover,.x-picker-date-body>table td.x-date-range-end:not(.x-date-last-or-next):hover{color:var(--x-background-100)}.x-picker-date-body>table td.x-date-active:not(.x-date-last-or-next):hover .x-date-text,.x-picker-date-body>table td.x-date-range-start:not(.x-date-last-or-next):hover .x-date-text,.x-picker-date-body>table td.x-date-range-end:not(.x-date-last-or-next):hover .x-date-text{background-color:var(--x-primary)}.x-picker-date-body>table td.x-date-range-end-left:not(.x-date-last-or-next):not(.x-date-first-day):not(:first-child) .x-date-text{z-index:1}.x-picker-date-body>table td.x-date-range-end-left:not(.x-date-last-or-next):not(.x-date-first-day):not(:first-child):after{background-color:var(--x-primary-800);transform:translate(-.25rem,-50%);border-radius:var(--x-border-radius);z-index:0}.x-picker-date-body>table td.x-date-range-end-left:not(.x-date-last-or-next):not(.x-date-first-day):not(:first-child).x-date-in-range-hover:after{background-color:var(--x-primary-700)}.x-picker-date-body>table td.x-date-range-start-right:not(.x-date-last-or-next):not(.x-date-last-day):not(:last-child) .x-date-text{z-index:1}.x-picker-date-body>table td.x-date-range-start-right:not(.x-date-last-or-next):not(.x-date-last-day):not(:last-child):after{background-color:var(--x-primary-800);transform:translate(.25rem,-50%);border-radius:var(--x-border-radius);z-index:0}.x-picker-date-body>table td.x-date-range-start-right:not(.x-date-last-or-next):not(.x-date-last-day):not(:last-child).x-date-in-range-hover:after{background-color:var(--x-primary-700)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next) .x-date-text{position:relative;z-index:1}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next):before{background-color:var(--x-primary-800);z-index:0}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next):first-child:before{transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next):last-child:before{transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next).x-date-in-range-hover-left:before{transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next).x-date-in-range-hover-right:before{transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next).x-date-in-range-hover:before{background-color:var(--x-primary-700)}.x-picker-date-body>table td.x-date-last-or-next{color:var(--x-text-700)}.x-picker-date-body>table td.x-date-range-hover:not(.x-date-last-or-next):before{border-color:var(--x-primary);border-left-color:transparent;border-right-color:transparent;transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover:first-child:not(.x-date-last-or-next):before,.x-picker-date-body>table td.x-date-range-hover.x-date-first-day:before{border-left-color:var(--x-primary);transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover:first-child:not(.x-date-last-or-next).x-date-range-hover-end:before,.x-picker-date-body>table td.x-date-range-hover.x-date-first-day.x-date-range-hover-end:before{width:1.75rem;transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover:last-child:not(.x-date-last-or-next):before,.x-picker-date-body>table td.x-date-range-hover.x-date-last-day:before{border-right-color:var(--x-primary);transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover:last-child:not(.x-date-last-or-next).x-date-range-hover-start:before,.x-picker-date-body>table td.x-date-range-hover.x-date-last-day.x-date-range-hover-start:before{width:1.75rem;transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover-start:not(.x-date-last-or-next):before{border-left-color:var(--x-primary);transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover.x-date-range-hover-start:not(.x-date-last-or-next):before{transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover-end:not(.x-date-last-or-next):before{border-right-color:var(--x-primary);transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover-start-left:not(:first-child):not(.x-date-last-or-next):not(.x-date-first-day):before,.x-picker-date-body>table td.x-date-range-hover-end-left:not(:first-child):not(.x-date-last-or-next):not(.x-date-first-day):before{border-top-color:var(--x-primary);border-bottom-color:var(--x-primary);transform:translate(-.3125rem,-50%)}.x-picker-date-body>table td.x-date-range-hover-start-right:not(:last-child):not(.x-date-last-or-next):not(.x-date-last-day):before,.x-picker-date-body>table td.x-date-range-hover-end-right:not(:last-child):not(.x-date-last-or-next):not(.x-date-last-day):before{border-top-color:var(--x-primary);border-bottom-color:var(--x-primary);transform:translate(.3125rem,-50%)}.x-picker-date-body>table td.x-date-now:not(.x-date-active):not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next) .x-date-text{color:var(--x-primary);border-color:var(--x-primary)}.x-picker-date .x-visibility{visibility:hidden}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "pipe", type: i1.DatePipe, name: "date" }, { kind: "pipe", type: i3.XI18nPipe, name: "xI18n" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
601
738
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XPickerDateComponent, decorators: [{
602
739
  type: Component,
603
- args: [{ selector: `${XPickerDatePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-picker-date\" [class.x-date-picker-datetemp]=\"dateTemp\">\r\n <div class=\"x-picker-date-header\" *ngIf=\"showHeader\">\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" [class.x-visibility]=\"!lastYearBtn\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" [class.x-visibility]=\"!lastMonthBtn\"></x-button>\r\n <div class=\"x-picker-date-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeOnChange('year')\">{{ display | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeOnChange('month')\">{{ getLocaleMonth(display) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\" [class.x-visibility]=\"!nextYearBtn\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\" [class.x-visibility]=\"!nextMonthBtn\"></x-button>\r\n </div>\r\n <div class=\"x-picker-date-body\">\r\n <table cellspacing=\"0\" cellpadding=\"0\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let title of titles; trackBy: trackByNode\">{{ title | xI18n }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let weeks of dates\">\r\n <ng-container *ngFor=\"let week of weeks; trackBy: trackByNode\">\r\n <td\r\n [class.x-date-last-or-next]=\"(week | date: 'yyyyMM') !== (display | date: 'yyyyMM')\"\r\n [class.x-date-now]=\"(week | date: 'yyyyMMdd') === (now | date: 'yyyyMMdd')\"\r\n (click)=\"dateTemp && dateClick(week)\"\r\n >\r\n <x-button\r\n *ngIf=\"!dateTemp\"\r\n type=\"text\"\r\n size=\"mini\"\r\n title=\"{{ week | date: 'yyyy-MM-dd' }}\"\r\n [activated]=\"!rangePicker && (week | date: 'yyyyMMdd') === (model | date: 'yyyyMMdd')\"\r\n [disabled]=\"false\"\r\n (click)=\"dateClick(week)\"\r\n >{{ week | date: 'd' }}</x-button\r\n >\r\n <ng-container *ngIf=\"dateTemp\">\r\n <ng-container *ngTemplateOutlet=\"dateTemp; context: { date$: week }\"></ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.x-picker-date{margin:0;padding:0}.x-picker-date-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-picker-date-year-month{flex:1;text-align:center}.x-picker-date-body{padding:.5rem}.x-picker-date-body>table{width:100%;border-collapse:collapse;border-spacing:0}.x-picker-date-body>table th{font-weight:400;height:2rem;color:var(--x-text-400)}.x-picker-date-body>table td{padding:.25rem 0;text-align:center}.x-picker-date-body>table td x-button .x-button{width:1.625rem;height:1.5rem;margin:0 auto;border:.0625rem solid transparent}.x-picker-date-body>table td x-button .x-button:hover{background-color:var(--x-primary-900)}.x-picker-date-body>table td x-button .x-button-activated{color:var(--x-background-100);background-color:var(--x-primary)}.x-picker-date-body>table td x-button .x-button-activated:hover{color:var(--x-background-100);background-color:var(--x-primary)}.x-picker-date-body>table td.x-date-last-or-next x-button .x-button{color:var(--x-text-700)}.x-picker-date-body>table td.x-date-now x-button .x-button:not(.x-button-activated){color:var(--x-primary);background-color:transparent;border-color:var(--x-primary)}.x-picker-date .x-visibility{visibility:hidden}\n"] }]
740
+ args: [{ selector: `${XPickerDatePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-picker-date\" [class.x-date-picker-datetemp]=\"dateTemp\">\r\n <div class=\"x-picker-date-header\" *ngIf=\"showHeader\">\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" [class.x-visibility]=\"!lastYearBtn\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" [class.x-visibility]=\"!lastMonthBtn\"></x-button>\r\n <div class=\"x-picker-date-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeOnChange('year')\">{{ display | date : 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeOnChange('month')\">{{ getLocaleMonth(display) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\" [class.x-visibility]=\"!nextYearBtn\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\" [class.x-visibility]=\"!nextMonthBtn\"></x-button>\r\n </div>\r\n <div class=\"x-picker-date-body\">\r\n <table cellspacing=\"0\" cellpadding=\"0\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let title of titles; trackBy: trackByNode\">{{ title | xI18n }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let weeks of weekDates\">\r\n <ng-container *ngFor=\"let week of weeks; trackBy: trackByNode\">\r\n <td\r\n [class.x-date-last-or-next]=\"week.isLastOrNext\"\r\n [class.x-date-now]=\"week.isNow\"\r\n [class.x-date-first-day]=\"week.isFirstDay\"\r\n [class.x-date-last-day]=\"week.isLastDay\"\r\n [class.x-date-range-start]=\"rangePicker && isStartDate(week.date!)\"\r\n [class.x-date-range-end]=\"rangePicker && isEndDate(week.date!)\"\r\n [class.x-date-range-start-left]=\"rangePicker && week.isRangeStartLeft\"\r\n [class.x-date-range-start-right]=\"rangePicker && week.isRangeStartRight\"\r\n [class.x-date-range-end-left]=\"rangePicker && week.isRangeEndLeft\"\r\n [class.x-date-range-end-right]=\"rangePicker && week.isRangeEndRight\"\r\n [class.x-date-range-hover]=\"rangePicker && week.isRangeHover\"\r\n [class.x-date-range-hover-start-left]=\"rangePicker && week.isRangeHoverStartLeft\"\r\n [class.x-date-range-hover-start-right]=\"rangePicker && week.isRangeHoverStartRight\"\r\n [class.x-date-range-hover-end-left]=\"rangePicker && week.isRangeHoverEndLeft\"\r\n [class.x-date-range-hover-end-right]=\"rangePicker && week.isRangeHoverEndRight\"\r\n [class.x-date-range-hover-start]=\"rangePicker && week.isRangeHoverStart\"\r\n [class.x-date-range-hover-end]=\"rangePicker && week.isRangeHoverEnd\"\r\n [class.x-date-in-range]=\"rangePicker && week.isInRange\"\r\n [class.x-date-in-range-hover]=\"rangePicker && week.isInRangeHover\"\r\n [class.x-date-active]=\"!rangePicker && (week.date | date : 'yyyyMMdd') === (model | date : 'yyyyMMdd')\"\r\n title=\"{{ week.date | date : 'yyyy-MM-dd' }}\"\r\n (click)=\"dateClick(week)\"\r\n (mouseenter)=\"rangePicker && onTdMouseenter(week)\"\r\n (mouseleave)=\"rangePicker && onTdMouseleave(week)\"\r\n >\r\n <div *ngIf=\"!dateTemp\" class=\"x-date-text\">\r\n {{ week.date | date : 'd' }}\r\n </div>\r\n <ng-container *ngIf=\"dateTemp\">\r\n <ng-container *ngTemplateOutlet=\"dateTemp; context: { date$: week.date }\"></ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.x-picker-date{margin:0;padding:0}.x-picker-date-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-picker-date-year-month{flex:1;text-align:center}.x-picker-date-body{padding:.5rem}.x-picker-date-body>table{width:100%;border-collapse:collapse;border-spacing:0}.x-picker-date-body>table th{font-weight:400;height:2rem;color:var(--x-text-400)}.x-picker-date-body>table td{padding:.25rem 0;text-align:center;cursor:pointer;color:var(--x-text-300);position:relative}.x-picker-date-body>table td .x-date-text{width:1.75rem;height:1.5rem;margin:0 auto;border:var(--x-border-width) var(--x-border-style) transparent;border-radius:var(--x-border-radius);transition:var(--x-animation-duration-base);position:relative}.x-picker-date-body>table td:before,.x-picker-date-body>table td:after{position:absolute;top:50%;right:0;left:0;z-index:1;height:1.5rem;border:var(--x-border-width) dashed transparent;transform:translateY(-50%);transition:var(--x-animation-duration-base);content:\"\"}.x-picker-date-body>table td:hover:not(.x-date-in-range) .x-date-text{background-color:var(--x-background-a200)}.x-picker-date-body>table td.x-date-active:not(.x-date-last-or-next),.x-picker-date-body>table td.x-date-range-start:not(.x-date-last-or-next),.x-picker-date-body>table td.x-date-range-end:not(.x-date-last-or-next){color:var(--x-background-100)}.x-picker-date-body>table td.x-date-active:not(.x-date-last-or-next) .x-date-text,.x-picker-date-body>table td.x-date-range-start:not(.x-date-last-or-next) .x-date-text,.x-picker-date-body>table td.x-date-range-end:not(.x-date-last-or-next) .x-date-text{background-color:var(--x-primary);border-color:var(--x-primary)}.x-picker-date-body>table td.x-date-active:not(.x-date-last-or-next):hover,.x-picker-date-body>table td.x-date-range-start:not(.x-date-last-or-next):hover,.x-picker-date-body>table td.x-date-range-end:not(.x-date-last-or-next):hover{color:var(--x-background-100)}.x-picker-date-body>table td.x-date-active:not(.x-date-last-or-next):hover .x-date-text,.x-picker-date-body>table td.x-date-range-start:not(.x-date-last-or-next):hover .x-date-text,.x-picker-date-body>table td.x-date-range-end:not(.x-date-last-or-next):hover .x-date-text{background-color:var(--x-primary)}.x-picker-date-body>table td.x-date-range-end-left:not(.x-date-last-or-next):not(.x-date-first-day):not(:first-child) .x-date-text{z-index:1}.x-picker-date-body>table td.x-date-range-end-left:not(.x-date-last-or-next):not(.x-date-first-day):not(:first-child):after{background-color:var(--x-primary-800);transform:translate(-.25rem,-50%);border-radius:var(--x-border-radius);z-index:0}.x-picker-date-body>table td.x-date-range-end-left:not(.x-date-last-or-next):not(.x-date-first-day):not(:first-child).x-date-in-range-hover:after{background-color:var(--x-primary-700)}.x-picker-date-body>table td.x-date-range-start-right:not(.x-date-last-or-next):not(.x-date-last-day):not(:last-child) .x-date-text{z-index:1}.x-picker-date-body>table td.x-date-range-start-right:not(.x-date-last-or-next):not(.x-date-last-day):not(:last-child):after{background-color:var(--x-primary-800);transform:translate(.25rem,-50%);border-radius:var(--x-border-radius);z-index:0}.x-picker-date-body>table td.x-date-range-start-right:not(.x-date-last-or-next):not(.x-date-last-day):not(:last-child).x-date-in-range-hover:after{background-color:var(--x-primary-700)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next) .x-date-text{position:relative;z-index:1}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next):before{background-color:var(--x-primary-800);z-index:0}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next):first-child:before{transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next):last-child:before{transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next).x-date-in-range-hover-left:before{transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next).x-date-in-range-hover-right:before{transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-in-range:not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next).x-date-in-range-hover:before{background-color:var(--x-primary-700)}.x-picker-date-body>table td.x-date-last-or-next{color:var(--x-text-700)}.x-picker-date-body>table td.x-date-range-hover:not(.x-date-last-or-next):before{border-color:var(--x-primary);border-left-color:transparent;border-right-color:transparent;transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover:first-child:not(.x-date-last-or-next):before,.x-picker-date-body>table td.x-date-range-hover.x-date-first-day:before{border-left-color:var(--x-primary);transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover:first-child:not(.x-date-last-or-next).x-date-range-hover-end:before,.x-picker-date-body>table td.x-date-range-hover.x-date-first-day.x-date-range-hover-end:before{width:1.75rem;transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover:last-child:not(.x-date-last-or-next):before,.x-picker-date-body>table td.x-date-range-hover.x-date-last-day:before{border-right-color:var(--x-primary);transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover:last-child:not(.x-date-last-or-next).x-date-range-hover-start:before,.x-picker-date-body>table td.x-date-range-hover.x-date-last-day.x-date-range-hover-start:before{width:1.75rem;transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover-start:not(.x-date-last-or-next):before{border-left-color:var(--x-primary);transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover.x-date-range-hover-start:not(.x-date-last-or-next):before{transform:translate(.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover-end:not(.x-date-last-or-next):before{border-right-color:var(--x-primary);transform:translate(-.25rem,-50%)}.x-picker-date-body>table td.x-date-range-hover-start-left:not(:first-child):not(.x-date-last-or-next):not(.x-date-first-day):before,.x-picker-date-body>table td.x-date-range-hover-end-left:not(:first-child):not(.x-date-last-or-next):not(.x-date-first-day):before{border-top-color:var(--x-primary);border-bottom-color:var(--x-primary);transform:translate(-.3125rem,-50%)}.x-picker-date-body>table td.x-date-range-hover-start-right:not(:last-child):not(.x-date-last-or-next):not(.x-date-last-day):before,.x-picker-date-body>table td.x-date-range-hover-end-right:not(:last-child):not(.x-date-last-or-next):not(.x-date-last-day):before{border-top-color:var(--x-primary);border-bottom-color:var(--x-primary);transform:translate(.3125rem,-50%)}.x-picker-date-body>table td.x-date-now:not(.x-date-active):not(.x-date-range-start):not(.x-date-range-end):not(.x-date-last-or-next) .x-date-text{color:var(--x-primary);border-color:var(--x-primary)}.x-picker-date .x-visibility{visibility:hidden}\n"] }]
604
741
  }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i1.DatePipe }, { type: i1.LowerCasePipe }, { type: i0.ChangeDetectorRef }, { type: i2.XConfigService }, { type: i3.XI18nService }]; } });
605
742
 
606
743
  class XPickerMonthComponent extends XPickerMonthProperty {
@@ -638,7 +775,7 @@ class XPickerMonthComponent extends XPickerMonthProperty {
638
775
  for (let i = 0; i < 16; i++) {
639
776
  dates = [...dates, new Date(year, i, 1)];
640
777
  }
641
- this.dates = chunk(dates, 4);
778
+ this.dates = XChunk(dates, 4);
642
779
  if (this.dates.length > 0) {
643
780
  this.rangeChange.emit([dates[0], dates[dates.length - 1]]);
644
781
  }
@@ -702,7 +839,7 @@ class XPickerYearComponent extends XPickerYearProperty {
702
839
  for (let i = -3; i < 13; i++) {
703
840
  dates = [...dates, new Date(this.start + i, 1, 1)];
704
841
  }
705
- this.dates = chunk(dates, 4);
842
+ this.dates = XChunk(dates, 4);
706
843
  this.startChange.emit(this.start);
707
844
  }
708
845
  yearClick(date) {
@@ -857,7 +994,7 @@ class XDatePickerPortalComponent {
857
994
  }
858
995
  }
859
996
  /** @nocollapse */ XDatePickerPortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XDatePickerPortalComponent, deps: [{ token: i1.DatePipe }, { token: i1.LowerCasePipe }, { token: i0.ChangeDetectorRef }, { token: i3.XI18nService }], target: i0.ɵɵFactoryTarget.Component });
860
- /** @nocollapse */ XDatePickerPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XDatePickerPortalComponent, selector: "x-date-picker-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], ngImport: i0, template: "<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <x-picker-date [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"dateChange($event)\"></x-picker-date>\r\n <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n <ng-container *ngFor=\"let item of preset\">\r\n <x-button type=\"text\" *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-button>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'month'\">\r\n <x-picker-month [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"monthChange($event)\"></x-picker-month>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'year'\">\r\n <x-picker-year [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"yearChange($event)\"></x-picker-year>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-time'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-hour'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-minute'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n <div class=\"x-date-picker-portal-content\">\r\n <div class=\"x-date-picker-portal-date\">\r\n <x-picker-date [display]=\"display\" [(type)]=\"type\" [model]=\"model\" (modelChange)=\"dateChange($event)\"></x-picker-date>\r\n </div>\r\n <div class=\"x-date-picker-portal-time\">\r\n <div class=\"x-date-picker-portal-time-label\">\r\n <x-button type=\"text\" size=\"small\">{{ time | date: timeFormat }}</x-button>\r\n </div>\r\n <x-time-picker-frame [type]=\"timeType\" [value]=\"time\" (nodeEmit)=\"selectTime($event)\"></x-time-picker-frame>\r\n </div>\r\n </div>\r\n <div class=\"x-date-picker-portal-footer\">\r\n <x-button type=\"primary\" size=\"small\" (click)=\"nodeEmit(model)\">{{ locale.sure }}</x-button>\r\n </div>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-picker-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:16rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-picker-portal.date-time{width:27rem}.x-date-picker-portal.date-hour{width:19.75rem}.x-date-picker-portal.date-minute{width:23.375rem}.x-date-picker-portal-content{display:flex}.x-date-picker-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-picker-portal-preset>x-button{flex:1}.x-date-picker-portal-body{padding:.4rem}.x-date-picker-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-date{flex:1}.x-date-picker-portal-time{display:flex;flex-direction:column;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time-label{padding:.5rem;text-align:center;border-bottom:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time .x-time-picker-frame{border-width:0;box-shadow:none;margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3$1.XTimePickerFrameComponent, selector: "x-time-picker-frame", inputs: ["type", "value"], outputs: ["nodeEmit"] }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "component", type: XPickerDateComponent, selector: "x-picker-date" }, { kind: "component", type: XPickerMonthComponent, selector: "x-picker-month" }, { kind: "component", type: XPickerYearComponent, selector: "x-picker-year" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], animations: [XConnectBaseAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
997
+ /** @nocollapse */ XDatePickerPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XDatePickerPortalComponent, selector: "x-date-picker-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], ngImport: i0, template: "<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <x-picker-date [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"dateChange($event)\"></x-picker-date>\r\n <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n <ng-container *ngFor=\"let item of preset\">\r\n <x-button type=\"text\" *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-button>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'month'\">\r\n <x-picker-month [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"monthChange($event)\"></x-picker-month>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'year'\">\r\n <x-picker-year [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"yearChange($event)\"></x-picker-year>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-time'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-hour'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-minute'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n <div class=\"x-date-picker-portal-content\">\r\n <div class=\"x-date-picker-portal-date\">\r\n <x-picker-date [display]=\"display\" [(type)]=\"type\" [model]=\"model\" (modelChange)=\"dateChange($event)\"></x-picker-date>\r\n </div>\r\n <div class=\"x-date-picker-portal-time\">\r\n <div class=\"x-date-picker-portal-time-label\">\r\n <x-button type=\"text\" size=\"small\">{{ time | date: timeFormat }}</x-button>\r\n </div>\r\n <x-time-picker-frame [type]=\"timeType\" [value]=\"time\" (nodeEmit)=\"selectTime($event)\"></x-time-picker-frame>\r\n </div>\r\n </div>\r\n <div class=\"x-date-picker-portal-footer\">\r\n <x-button type=\"primary\" size=\"small\" (click)=\"nodeEmit(model)\">{{ locale.sure }}</x-button>\r\n </div>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-picker-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:16rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-picker-portal.date-time{width:27rem}.x-date-picker-portal.date-hour{width:19.75rem}.x-date-picker-portal.date-minute{width:23.375rem}.x-date-picker-portal-content{display:flex}.x-date-picker-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-picker-portal-preset>x-button{flex:1}.x-date-picker-portal-body{padding:.4rem}.x-date-picker-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-date{flex:1}.x-date-picker-portal-time{display:flex;flex-direction:column;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time-label{padding:.5rem;text-align:center;border-bottom:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time .x-time-picker-frame{border-width:0;box-shadow:none;margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3$1.XTimePickerFrameComponent, selector: "x-time-picker-frame", inputs: ["type", "value", "use12Hours", "hourStep", "minuteStep", "secondStep"], outputs: ["nodeEmit"] }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "component", type: XPickerDateComponent, selector: "x-picker-date" }, { kind: "component", type: XPickerMonthComponent, selector: "x-picker-month" }, { kind: "component", type: XPickerYearComponent, selector: "x-picker-year" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], animations: [XConnectBaseAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
861
998
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XDatePickerPortalComponent, decorators: [{
862
999
  type: Component,
863
1000
  args: [{ selector: `${XDatePickerPortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <x-picker-date [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"dateChange($event)\"></x-picker-date>\r\n <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n <ng-container *ngFor=\"let item of preset\">\r\n <x-button type=\"text\" *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-button>\r\n <x-button type=\"text\" *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-button>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'month'\">\r\n <x-picker-month [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"monthChange($event)\"></x-picker-month>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'year'\">\r\n <x-picker-year [display]=\"display\" [model]=\"model\" [(type)]=\"type\" (modelChange)=\"yearChange($event)\"></x-picker-year>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-time'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-hour'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-minute'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n <div class=\"x-date-picker-portal-content\">\r\n <div class=\"x-date-picker-portal-date\">\r\n <x-picker-date [display]=\"display\" [(type)]=\"type\" [model]=\"model\" (modelChange)=\"dateChange($event)\"></x-picker-date>\r\n </div>\r\n <div class=\"x-date-picker-portal-time\">\r\n <div class=\"x-date-picker-portal-time-label\">\r\n <x-button type=\"text\" size=\"small\">{{ time | date: timeFormat }}</x-button>\r\n </div>\r\n <x-time-picker-frame [type]=\"timeType\" [value]=\"time\" (nodeEmit)=\"selectTime($event)\"></x-time-picker-frame>\r\n </div>\r\n </div>\r\n <div class=\"x-date-picker-portal-footer\">\r\n <x-button type=\"primary\" size=\"small\" (click)=\"nodeEmit(model)\">{{ locale.sure }}</x-button>\r\n </div>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-picker-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:16rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-picker-portal.date-time{width:27rem}.x-date-picker-portal.date-hour{width:19.75rem}.x-date-picker-portal.date-minute{width:23.375rem}.x-date-picker-portal-content{display:flex}.x-date-picker-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-picker-portal-preset>x-button{flex:1}.x-date-picker-portal-body{padding:.4rem}.x-date-picker-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-date{flex:1}.x-date-picker-portal-time{display:flex;flex-direction:column;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time-label{padding:.5rem;text-align:center;border-bottom:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time .x-time-picker-frame{border-width:0;box-shadow:none;margin:0}\n"] }]
@@ -1149,6 +1286,7 @@ class XDateRangePortalComponent {
1149
1286
  this.value = [];
1150
1287
  this.locale = {};
1151
1288
  this.preset = [];
1289
+ this.nodeClickCount = 0;
1152
1290
  this._unSubject = new Subject();
1153
1291
  }
1154
1292
  done(event) {
@@ -1167,9 +1305,8 @@ class XDateRangePortalComponent {
1167
1305
  this.placement = x;
1168
1306
  this.cdr.detectChanges();
1169
1307
  });
1170
- this.inputActiveChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {
1308
+ this.activeTypeChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {
1171
1309
  this.activeType = x;
1172
- this.setDefault();
1173
1310
  });
1174
1311
  this.i18n.localeChange
1175
1312
  .pipe(map((x) => x.datePicker), takeUntil(this._unSubject))
@@ -1190,7 +1327,7 @@ class XDateRangePortalComponent {
1190
1327
  this.setDefault();
1191
1328
  }
1192
1329
  else {
1193
- this.value = [];
1330
+ this.value = [null, null];
1194
1331
  this.model = this.display;
1195
1332
  this.startModel = this.model;
1196
1333
  this.endModel = XAddMonths(this.model, 1);
@@ -1223,35 +1360,38 @@ class XDateRangePortalComponent {
1223
1360
  this.startDisplay = this.display;
1224
1361
  this.endDisplay = XAddMonths(this.display, 1);
1225
1362
  }
1226
- dateChange(date, type) {
1227
- let time = date.getTime();
1228
- if (this.value.length === 0) {
1229
- this.value = [time];
1230
- this.startNodeEmit(date);
1231
- }
1232
- else if (this.value.length === 1) {
1233
- if (time > this.value[0]) {
1234
- this.value = [...this.value, time];
1235
- this.endNodeEmit(date);
1236
- }
1237
- else {
1238
- this.value = [time, ...this.value];
1239
- this.startNodeEmit(date);
1240
- this.endNodeEmit(new Date(this.value[1]));
1363
+ dateChange(date) {
1364
+ this.nodeClickCount++;
1365
+ let close = this.nodeClickCount === 2;
1366
+ const time = date.getTime();
1367
+ if (this.activeType === 'start') {
1368
+ this.value[0] = time;
1369
+ if (!XIsNull(this.value[1]) && time > this.value[1]) {
1370
+ if (this.nodeClickCount === 2) {
1371
+ this.nodeClickCount--;
1372
+ }
1373
+ close = false;
1374
+ this.endModel = null;
1375
+ this.value[1] = null;
1376
+ this.endNodeEmit(null, close);
1241
1377
  }
1242
- this.nodeEmit(this.value.map((x) => new Date(x)));
1378
+ this.startNodeEmit(date, close);
1243
1379
  }
1244
- else {
1245
- if (type === 'start') {
1246
- this.value = [time, this.value[1]];
1247
- this.startNodeEmit(date);
1380
+ else if (this.activeType === 'end') {
1381
+ this.value[1] = time;
1382
+ if (!XIsNull(this.value[0]) && time < this.value[0]) {
1383
+ if (this.nodeClickCount === 2) {
1384
+ this.nodeClickCount--;
1385
+ }
1386
+ close = false;
1387
+ this.startModel = null;
1388
+ this.value[0] = null;
1389
+ this.startNodeEmit(null, close);
1248
1390
  }
1249
- else if (type === 'end') {
1250
- this.value = [this.value[0], time];
1251
- this.cdr.detectChanges();
1252
- this.endNodeEmit(date);
1253
- }
1254
- this.nodeEmit(this.value.map((x) => new Date(x)), type !== 'start');
1391
+ this.endNodeEmit(date, close);
1392
+ }
1393
+ if (!this.value.includes(null)) {
1394
+ this.nodeEmit(this.value.map((x) => new Date(x)), close);
1255
1395
  }
1256
1396
  }
1257
1397
  typeChange(type) {
@@ -1329,10 +1469,10 @@ class XDateRangePortalComponent {
1329
1469
  }
1330
1470
  }
1331
1471
  /** @nocollapse */ XDateRangePortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XDateRangePortalComponent, deps: [{ token: i1.DatePipe }, { token: i1.LowerCasePipe }, { token: i0.ChangeDetectorRef }, { token: i3.XI18nService }], target: i0.ɵɵFactoryTarget.Component });
1332
- /** @nocollapse */ XDateRangePortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XDateRangePortalComponent, selector: "x-date-range-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], ngImport: i0, template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-body\">\r\n <x-picker-date\r\n class=\"x-date-range-portal-start\"\r\n [(display)]=\"startDisplay\"\r\n [model]=\"startModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [nextYearBtn]=\"false\"\r\n [nextMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'start')\"\r\n (yearChange)=\"startYearChange($event)\"\r\n (monthChange)=\"startMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n <x-picker-date\r\n class=\"x-date-range-portal-end\"\r\n [(display)]=\"endDisplay\"\r\n [model]=\"endModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [lastYearBtn]=\"false\"\r\n [lastMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'end')\"\r\n (yearChange)=\"endYearChange($event)\"\r\n (monthChange)=\"endMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-range-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:34rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-range-portal.date-time{width:27rem}.x-date-range-portal.date-hour{width:19.75rem}.x-date-range-portal.date-minute{width:23.375rem}.x-date-range-portal-content{display:flex}.x-date-range-portal-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset>x-button{flex:1}.x-date-range-portal-year-month{flex:1;text-align:center}.x-date-range-portal-body{display:flex}.x-date-range-portal-start,.x-date-range-portal-end{flex:1}.x-date-range-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-range-portal-date{flex:1}.x-date-range-portal-time{display:flex;flex-direction:column}.x-date-range-portal-time-label{padding:.4rem;text-align:center;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-range-portal-time .x-time-picker-frame{border-width:var(--x-border-width) 0 0 var(--x-border-width);box-shadow:none}\n"], dependencies: [{ kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "component", type: XPickerDateComponent, selector: "x-picker-date" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], animations: [XConnectBaseAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1472
+ /** @nocollapse */ XDateRangePortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XDateRangePortalComponent, selector: "x-date-range-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], ngImport: i0, template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-body\">\r\n <x-picker-date\r\n #startPickerDate\r\n class=\"x-date-range-portal-start\"\r\n [(display)]=\"startDisplay\"\r\n [model]=\"startModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [nextYearBtn]=\"false\"\r\n [nextMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event)\"\r\n (yearChange)=\"startYearChange($event)\"\r\n (monthChange)=\"startMonthChange($event)\"\r\n (rangeTdMouseenter)=\"endPickerDate.setDatesState($event)\"\r\n (rangeDateClick)=\"endPickerDate.setDatesState($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n <x-picker-date\r\n #endPickerDate\r\n class=\"x-date-range-portal-end\"\r\n [(display)]=\"endDisplay\"\r\n [model]=\"endModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [lastYearBtn]=\"false\"\r\n [lastMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event)\"\r\n (yearChange)=\"endYearChange($event)\"\r\n (monthChange)=\"endMonthChange($event)\"\r\n (rangeTdMouseenter)=\"startPickerDate.setDatesState($event)\"\r\n (rangeDateClick)=\"startPickerDate.setDatesState($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date : 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date : 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-range-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:34rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-range-portal.date-time{width:27rem}.x-date-range-portal.date-hour{width:19.75rem}.x-date-range-portal.date-minute{width:23.375rem}.x-date-range-portal-content{display:flex}.x-date-range-portal-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset>x-button{flex:1}.x-date-range-portal-year-month{flex:1;text-align:center}.x-date-range-portal-body{display:flex}.x-date-range-portal-start,.x-date-range-portal-end{flex:1}.x-date-range-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-range-portal-date{flex:1}.x-date-range-portal-time{display:flex;flex-direction:column}.x-date-range-portal-time-label{padding:.4rem;text-align:center;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-range-portal-time .x-time-picker-frame{border-width:var(--x-border-width) 0 0 var(--x-border-width);box-shadow:none}\n"], dependencies: [{ kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "component", type: XPickerDateComponent, selector: "x-picker-date" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], animations: [XConnectBaseAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1333
1473
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XDateRangePortalComponent, decorators: [{
1334
1474
  type: Component,
1335
- args: [{ selector: `${XDateRangePortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-body\">\r\n <x-picker-date\r\n class=\"x-date-range-portal-start\"\r\n [(display)]=\"startDisplay\"\r\n [model]=\"startModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [nextYearBtn]=\"false\"\r\n [nextMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'start')\"\r\n (yearChange)=\"startYearChange($event)\"\r\n (monthChange)=\"startMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n <x-picker-date\r\n class=\"x-date-range-portal-end\"\r\n [(display)]=\"endDisplay\"\r\n [model]=\"endModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [lastYearBtn]=\"false\"\r\n [lastMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'end')\"\r\n (yearChange)=\"endYearChange($event)\"\r\n (monthChange)=\"endMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-range-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:34rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-range-portal.date-time{width:27rem}.x-date-range-portal.date-hour{width:19.75rem}.x-date-range-portal.date-minute{width:23.375rem}.x-date-range-portal-content{display:flex}.x-date-range-portal-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset>x-button{flex:1}.x-date-range-portal-year-month{flex:1;text-align:center}.x-date-range-portal-body{display:flex}.x-date-range-portal-start,.x-date-range-portal-end{flex:1}.x-date-range-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-range-portal-date{flex:1}.x-date-range-portal-time{display:flex;flex-direction:column}.x-date-range-portal-time-label{padding:.4rem;text-align:center;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-range-portal-time .x-time-picker-frame{border-width:var(--x-border-width) 0 0 var(--x-border-width);box-shadow:none}\n"] }]
1475
+ args: [{ selector: `${XDateRangePortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-body\">\r\n <x-picker-date\r\n #startPickerDate\r\n class=\"x-date-range-portal-start\"\r\n [(display)]=\"startDisplay\"\r\n [model]=\"startModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [nextYearBtn]=\"false\"\r\n [nextMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event)\"\r\n (yearChange)=\"startYearChange($event)\"\r\n (monthChange)=\"startMonthChange($event)\"\r\n (rangeTdMouseenter)=\"endPickerDate.setDatesState($event)\"\r\n (rangeDateClick)=\"endPickerDate.setDatesState($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n <x-picker-date\r\n #endPickerDate\r\n class=\"x-date-range-portal-end\"\r\n [(display)]=\"endDisplay\"\r\n [model]=\"endModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [lastYearBtn]=\"false\"\r\n [lastMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event)\"\r\n (yearChange)=\"endYearChange($event)\"\r\n (monthChange)=\"endMonthChange($event)\"\r\n (rangeTdMouseenter)=\"startPickerDate.setDatesState($event)\"\r\n (rangeDateClick)=\"startPickerDate.setDatesState($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date : 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date : 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-range-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:34rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-range-portal.date-time{width:27rem}.x-date-range-portal.date-hour{width:19.75rem}.x-date-range-portal.date-minute{width:23.375rem}.x-date-range-portal-content{display:flex}.x-date-range-portal-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset>x-button{flex:1}.x-date-range-portal-year-month{flex:1;text-align:center}.x-date-range-portal-body{display:flex}.x-date-range-portal-start,.x-date-range-portal-end{flex:1}.x-date-range-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-range-portal-date{flex:1}.x-date-range-portal-time{display:flex;flex-direction:column}.x-date-range-portal-time-label{padding:.4rem;text-align:center;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-range-portal-time .x-time-picker-frame{border-width:var(--x-border-width) 0 0 var(--x-border-width);box-shadow:none}\n"] }]
1336
1476
  }], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i1.LowerCasePipe }, { type: i0.ChangeDetectorRef }, { type: i3.XI18nService }]; }, propDecorators: { placement: [{
1337
1477
  type: HostBinding,
1338
1478
  args: ['@x-connect-base-animation']
@@ -1356,6 +1496,7 @@ class XDateRangeComponent extends XDateRangeProperty {
1356
1496
  this.overlay = overlay;
1357
1497
  this.modelType = 'date';
1358
1498
  this.isInput = false;
1499
+ this.showClearable = false;
1359
1500
  this.enter = false;
1360
1501
  this.inputClearable = false;
1361
1502
  this.animating = false;
@@ -1366,24 +1507,22 @@ class XDateRangeComponent extends XDateRangeProperty {
1366
1507
  this.valueChange = new Subject();
1367
1508
  this.dataChange = new Subject();
1368
1509
  this.positionChange = new Subject();
1369
- this.inputActiveChange = new Subject();
1370
1510
  this.closeSubject = new Subject();
1511
+ this.activeTypeChange = new Subject();
1371
1512
  this.startDisplay = '';
1372
1513
  this.endDisplay = '';
1373
- this.startActive = false;
1374
- this.endActive = false;
1375
1514
  this._unSubject = new Subject();
1376
1515
  }
1377
1516
  get getRequired() {
1378
1517
  return this.required && XIsEmpty(this.value);
1379
1518
  }
1380
1519
  writeValue(value) {
1381
- if (XIsUndefined(value))
1520
+ if (XIsUndefined(value) || XIsNull(value))
1382
1521
  value = [];
1383
1522
  if (value.length > 0) {
1384
1523
  if (XIsDate(value[0])) {
1385
1524
  this.modelType = 'date';
1386
- this.numberValue = value.getTime();
1525
+ this.numberValue = value.map((x) => x.getTime());
1387
1526
  }
1388
1527
  else if (XIsNumber(value[0])) {
1389
1528
  this.modelType = 'number';
@@ -1448,32 +1587,41 @@ class XDateRangeComponent extends XDateRangeProperty {
1448
1587
  }
1449
1588
  }
1450
1589
  menter() {
1451
- if (this.disabled)
1590
+ if (this.disabled || !this.clearable)
1452
1591
  return;
1453
1592
  this.enter = true;
1454
1593
  if (!XIsEmpty(this.numberValue)) {
1455
1594
  this.icon = '';
1456
- this.inputClearable = true;
1595
+ this.showClearable = true;
1457
1596
  this.cdr.detectChanges();
1458
1597
  }
1459
1598
  }
1460
1599
  mleave() {
1461
- if (this.disabled)
1600
+ if (this.disabled || !this.clearable)
1462
1601
  return;
1463
1602
  this.enter = false;
1464
- if (this.inputClearable) {
1603
+ if (this.clearable) {
1465
1604
  this.icon = 'fto-calendar';
1466
- this.inputClearable = false;
1605
+ this.showClearable = false;
1467
1606
  this.cdr.detectChanges();
1468
1607
  }
1469
1608
  }
1470
1609
  clearEmit() {
1471
1610
  this.value = [];
1472
1611
  this.numberValue = [];
1473
- this.displayValue = [];
1612
+ this.startDisplay = '';
1613
+ this.endDisplay = '';
1474
1614
  this.mleave();
1475
1615
  this.valueChange.next(this.numberValue);
1476
1616
  this.modelChange();
1617
+ this.inputStartCom.inputFocus();
1618
+ this.cdr.detectChanges();
1619
+ }
1620
+ onIconClick(event) {
1621
+ if (this.icon === 'fto-x') {
1622
+ this.clearEmit();
1623
+ }
1624
+ event.stopPropagation();
1477
1625
  }
1478
1626
  modelChange() {
1479
1627
  if (this.onChange) {
@@ -1487,6 +1635,13 @@ class XDateRangeComponent extends XDateRangeProperty {
1487
1635
  ? this.numberValue.map((x) => this.datePipe.transform(x, this.format))
1488
1636
  : this.numberValue;
1489
1637
  }
1638
+ getNumberValue() {
1639
+ return this.modelType === 'date'
1640
+ ? this.value.map((x) => x.getTime())
1641
+ : this.modelType === 'string'
1642
+ ? this.value.map((x) => new Date(x).getTime())
1643
+ : this.value;
1644
+ }
1490
1645
  portalAttached() {
1491
1646
  return this.portal?.overlayRef?.hasAttached();
1492
1647
  }
@@ -1494,8 +1649,17 @@ class XDateRangeComponent extends XDateRangeProperty {
1494
1649
  if (this.portalAttached()) {
1495
1650
  this.portal?.overlayRef?.detach();
1496
1651
  this.active = false;
1497
- this.startActive = false;
1498
- this.endActive = false;
1652
+ if (!this.numberValue || this.numberValue.length === 0 || this.numberValue.includes(null)) {
1653
+ if (!this.value || this.value.length === 0) {
1654
+ this.startDisplay = '';
1655
+ this.endDisplay = '';
1656
+ this.numberValue = [];
1657
+ }
1658
+ else {
1659
+ this.numberValue = this.getNumberValue();
1660
+ this.setDisplayValue(this.numberValue);
1661
+ }
1662
+ }
1499
1663
  this.cdr.detectChanges();
1500
1664
  return true;
1501
1665
  }
@@ -1508,10 +1672,8 @@ class XDateRangeComponent extends XDateRangeProperty {
1508
1672
  type && $event.stopPropagation();
1509
1673
  if (this.disabled || this.animating)
1510
1674
  return;
1511
- this.startActive = type === 'start';
1512
- this.endActive = type === 'end';
1513
- this.activeType = type;
1514
- this.activeType && this.inputActiveChange.next(this.activeType);
1675
+ this.activeType = type || 'start';
1676
+ this.activeTypeChange.next(this.activeType);
1515
1677
  if (this.active)
1516
1678
  return;
1517
1679
  this.active = true;
@@ -1532,7 +1694,6 @@ class XDateRangeComponent extends XDateRangeProperty {
1532
1694
  .subscribe((event) => {
1533
1695
  const clickTarget = event.target;
1534
1696
  if (clickTarget !== this.inputStartCom.inputRef.nativeElement && clickTarget !== this.inputEndCom.inputRef.nativeElement) {
1535
- this.setDisplayValue(this.numberValue);
1536
1697
  this.closeSubject.next();
1537
1698
  }
1538
1699
  });
@@ -1556,58 +1717,59 @@ class XDateRangeComponent extends XDateRangeProperty {
1556
1717
  preset: this.preset,
1557
1718
  valueChange: this.valueChange,
1558
1719
  positionChange: this.positionChange,
1559
- inputActiveChange: this.inputActiveChange,
1560
1720
  activeType: this.activeType,
1721
+ activeTypeChange: this.activeTypeChange,
1561
1722
  closePortal: () => this.closeSubject.next(),
1562
1723
  destroyPortal: () => this.destroyPortal(),
1563
- nodeEmit: (dates, sure = true) => this.onNodeClick(dates, sure),
1564
- startNodeEmit: (node) => this.startNodeClick(node),
1565
- endNodeEmit: (node) => this.endNodeClick(node),
1724
+ nodeEmit: (dates, close = true) => this.onNodeClick(dates, close),
1725
+ startNodeEmit: (node, close = false) => this.startNodeClick(node, close),
1726
+ endNodeEmit: (node, close = false) => this.endNodeClick(node, close),
1566
1727
  animating: (ing) => (this.animating = ing)
1567
1728
  });
1568
1729
  componentRef.changeDetectorRef.detectChanges();
1569
1730
  }
1570
- startNodeClick(node) {
1571
- this.startDisplay = this.datePipe.transform(node, this.format);
1572
- this.startActive = false;
1573
- this.endActive = true;
1574
- this.inputEndCom.inputFocus('after');
1731
+ startNodeClick(node, close = false) {
1732
+ this.startDisplay = !node ? '' : this.datePipe.transform(node, this.format);
1733
+ if (!close) {
1734
+ this.inputEndCom.inputFocus('after');
1735
+ this.activeTypeChange.next('end');
1736
+ }
1575
1737
  this.cdr.detectChanges();
1576
1738
  }
1577
- endNodeClick(node) {
1578
- this.endDisplay = this.datePipe.transform(node, this.format);
1739
+ endNodeClick(node, close = false) {
1740
+ this.endDisplay = !node ? '' : this.datePipe.transform(node, this.format);
1741
+ if (!close) {
1742
+ this.inputStartCom.inputFocus('after');
1743
+ this.activeTypeChange.next('start');
1744
+ }
1579
1745
  this.cdr.detectChanges();
1580
1746
  }
1581
- onNodeClick(dates, sure = true) {
1747
+ onNodeClick(dates, close = true) {
1582
1748
  this.isInput = false;
1583
- if (sure) {
1584
- this.numberValue = dates.map((x) => x.getTime());
1585
- this.value = this.getValue();
1586
- this.setDisplayValue(this.numberValue);
1749
+ this.numberValue = dates.map((x) => x.getTime());
1750
+ this.value = this.getValue();
1751
+ this.setDisplayValue(this.numberValue);
1752
+ if (close) {
1587
1753
  this.closeSubject.next();
1588
- this.modelChange();
1589
- this.nodeEmit.emit(this.numberValue);
1590
- }
1591
- else {
1592
- this.setDisplayValue(dates.map((x) => x.getTime()));
1593
- this.cdr.markForCheck();
1594
1754
  }
1755
+ this.modelChange();
1595
1756
  }
1596
1757
  onInput() {
1597
1758
  this.isInput = true;
1598
1759
  }
1760
+ onFocus(type) {
1761
+ this.activeType = type;
1762
+ this.activeChange.next(this.activeType);
1763
+ }
1599
1764
  setDisplayValue(dateNumber) {
1600
- // if (this.isInput && isNaN(this.startDisplay) && !isNaN(Date.parse(this.displayValue))) {
1601
- // this.displayValue = this.datePipe.transform(this.displayValue, this.format);
1602
- // this.numberValue = new Date(this.displayValue).getTime();
1603
- // this.value = this.getValue();
1604
- // this.modelChange();
1605
- // this.isInput = false;
1606
- // } else {
1607
1765
  if (!dateNumber)
1608
1766
  return;
1609
- this.displayValue = dateNumber.map((x) => this.datePipe.transform(x, this.format));
1610
- // }
1767
+ if (!XIsNull(dateNumber[0])) {
1768
+ this.startDisplay = this.datePipe.transform(dateNumber[0], this.format);
1769
+ }
1770
+ if (!XIsNull(dateNumber[1])) {
1771
+ this.endDisplay = this.datePipe.transform(dateNumber[1], this.format);
1772
+ }
1611
1773
  }
1612
1774
  setPlacement() {
1613
1775
  return this.portalService.setPlacement({
@@ -1629,10 +1791,10 @@ class XDateRangeComponent extends XDateRangeProperty {
1629
1791
  }
1630
1792
  }
1631
1793
  /** @nocollapse */ XDateRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XDateRangeComponent, deps: [{ token: i0.Renderer2 }, { token: i2.XConfigService }, { token: i0.ChangeDetectorRef }, { token: i2$1.XPortalService }, { token: i0.ViewContainerRef }, { token: i1.DatePipe }, { token: i4$1.Overlay }], target: i0.ɵɵFactoryTarget.Component });
1632
- /** @nocollapse */ XDateRangeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XDateRangeComponent, selector: "x-date-range", providers: [XValueAccessor(XDateRangeComponent), DatePipe], viewQueries: [{ propertyName: "dateRange", first: true, predicate: ["dateRange"], descendants: true, static: true }, { propertyName: "inputGroup", first: true, predicate: ["inputGroup"], descendants: true, static: true }, { propertyName: "inputStartCom", first: true, predicate: ["inputStartCom"], descendants: true, static: true }, { propertyName: "inputEndCom", first: true, predicate: ["inputEndCom"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #dateRange class=\"x-date-range\" [class.x-date-range-active]=\"active\">\r\n <div class=\"x-date-range-row\">\r\n <x-input-group #inputGroup class=\"x-date-range-group\" bordered=\"false\" (click)=\"showPortal($event)\">\r\n <x-input\r\n #inputStartCom\r\n [class.x-input-active]=\"startActive\"\r\n type=\"text\"\r\n placeholder=\"\u5F00\u59CB\u65E5\u671F\"\r\n (click)=\"showPortal($event, 'start')\"\r\n (xFocus)=\"startActive = true\"\r\n (xBlur)=\"startActive = false\"\r\n [(ngModel)]=\"startDisplay\"\r\n ></x-input>\r\n <x-icon type=\"fto-arrow-right\"></x-icon>\r\n <x-input\r\n #inputEndCom\r\n [class.x-input-active]=\"endActive\"\r\n type=\"text\"\r\n placeholder=\"\u7ED3\u675F\u65E5\u671F\"\r\n (click)=\"showPortal($event, 'end')\"\r\n (xFocus)=\"endActive = true\"\r\n (xBlur)=\"endActive = false\"\r\n [(ngModel)]=\"endDisplay\"\r\n ></x-input>\r\n <x-icon [type]=\"icon\"></x-icon>\r\n </x-input-group>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-date-range{display:inline-block}.x-date-range{margin:0;padding:0;width:100%}.x-date-range-row{flex:1;display:flex;align-items:center}.x-date-range-group{display:inline-flex;flex:1;width:100%;font-size:var(--x-font-size);background-color:var(--x-background);background-image:none;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) transparent;transition:all var(--x-animation-duration-slow)}.x-date-range-group .x-input-group{display:flex;align-items:center}.x-date-range-group .x-input-group>x-icon{color:var(--x-text-400);transition:all var(--x-animation-duration-base);z-index:2;padding:.4rem}.x-date-range-group .x-input-group>x-input{width:6rem}.x-date-range-group .x-input-group>x-input input{padding-left:0!important;padding-right:0!important;margin-left:.4rem;margin-right:.4rem;border-radius:0;border-bottom:var(--x-border-width) var(--x-border-style) transparent}.x-date-range-group .x-input-group>x-input .x-input-active input{border-color:var(--x-primary)}.x-date-range-group:hover{border-color:var(--x-primary-300)}.x-date-range-active .x-date-range-group{border-color:var(--x-primary)}\n"], dependencies: [{ kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.XInputComponent, selector: "x-input" }, { kind: "component", type: i6.XInputGroupComponent, selector: "x-input-group" }, { kind: "component", type: i7.XIconComponent, selector: "x-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1794
+ /** @nocollapse */ XDateRangeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XDateRangeComponent, selector: "x-date-range", providers: [XValueAccessor(XDateRangeComponent), DatePipe], viewQueries: [{ propertyName: "dateRange", first: true, predicate: ["dateRange"], descendants: true, static: true }, { propertyName: "inputGroup", first: true, predicate: ["inputGroup"], descendants: true, static: true }, { propertyName: "inputStartCom", first: true, predicate: ["inputStartCom"], descendants: true, static: true }, { propertyName: "inputEndCom", first: true, predicate: ["inputEndCom"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\r\n #dateRange\r\n class=\"x-date-range\"\r\n [class.x-date-range-active]=\"active\"\r\n [class.x-date-range-active-start]=\"activeType === 'start'\"\r\n [class.x-date-range-active-end]=\"activeType === 'end'\"\r\n>\r\n <div class=\"x-date-range-row\">\r\n <x-input-group #inputGroup class=\"x-date-range-group\" (mouseenter)=\"menter()\" (mouseleave)=\"mleave()\" (click)=\"showPortal($event)\">\r\n <x-input\r\n #inputStartCom\r\n class=\"x-data-range-input-start\"\r\n type=\"text\"\r\n bordered=\"false\"\r\n placeholder=\"\u5F00\u59CB\u65E5\u671F\"\r\n (xFocus)=\"onFocus('start')\"\r\n (xClick)=\"showPortal($event, 'start')\"\r\n [(ngModel)]=\"startDisplay\"\r\n ></x-input>\r\n <x-icon class=\"x-date-range-icon\" type=\"fto-arrow-right\"></x-icon>\r\n <x-input\r\n #inputEndCom\r\n class=\"x-data-range-input-end\"\r\n type=\"text\"\r\n bordered=\"false\"\r\n placeholder=\"\u7ED3\u675F\u65E5\u671F\"\r\n (xFocus)=\"onFocus('end')\"\r\n (xClick)=\"showPortal($event, 'end')\"\r\n [(ngModel)]=\"endDisplay\"\r\n [icon]=\"icon\"\r\n (clearEmit)=\"clearEmit()\"\r\n [clearable]=\"showClearable\"\r\n ></x-input>\r\n <div *ngIf=\"active\" class=\"x-date-range-active-bar\"></div>\r\n </x-input-group>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-date-range{display:inline-block}.x-date-range{margin:0;padding:0;width:100%}.x-date-range-row{flex:1;display:flex;align-items:center}.x-date-range-group{display:inline-flex;flex:1;width:100%;font-size:var(--x-font-size);background-color:var(--x-background);background-image:none;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) transparent;transition:all var(--x-animation-duration-slow)}.x-date-range-group .x-input-group{display:flex;align-items:center;position:relative}.x-date-range-group .x-input-group .x-date-range-icon{color:var(--x-text-400);transition:all var(--x-animation-duration-base);z-index:2;font-size:1rem;width:1.8rem}.x-date-range-group .x-input-group>x-input input{padding-left:0!important;padding-right:0!important;background-color:transparent;margin-left:.4rem;margin-right:.4rem;border-radius:0}.x-date-range-group .x-input-group>x-input.x-data-range-input-start{width:6rem}.x-date-range-group .x-input-group>x-input.x-data-range-input-end{width:7.8rem}.x-date-range-group:hover{border-color:var(--x-primary-300)}.x-date-range-active-bar{position:absolute;height:.125rem;margin-left:.4rem;bottom:-.0625rem;width:calc(50% - 2.2rem);background-color:var(--x-primary);transition:var(--x-animation-duration-base)}.x-date-range-active .x-date-range-group{border-color:var(--x-primary)}.x-date-range-active-start .x-date-range-active-bar{left:0}.x-date-range-active-end .x-date-range-active-bar{left:50%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.XInputComponent, selector: "x-input" }, { kind: "component", type: i6.XInputGroupComponent, selector: "x-input-group" }, { kind: "component", type: i7.XIconComponent, selector: "x-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1633
1795
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XDateRangeComponent, decorators: [{
1634
1796
  type: Component,
1635
- args: [{ selector: `${XDateRangePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XDateRangeComponent), DatePipe], template: "<div #dateRange class=\"x-date-range\" [class.x-date-range-active]=\"active\">\r\n <div class=\"x-date-range-row\">\r\n <x-input-group #inputGroup class=\"x-date-range-group\" bordered=\"false\" (click)=\"showPortal($event)\">\r\n <x-input\r\n #inputStartCom\r\n [class.x-input-active]=\"startActive\"\r\n type=\"text\"\r\n placeholder=\"\u5F00\u59CB\u65E5\u671F\"\r\n (click)=\"showPortal($event, 'start')\"\r\n (xFocus)=\"startActive = true\"\r\n (xBlur)=\"startActive = false\"\r\n [(ngModel)]=\"startDisplay\"\r\n ></x-input>\r\n <x-icon type=\"fto-arrow-right\"></x-icon>\r\n <x-input\r\n #inputEndCom\r\n [class.x-input-active]=\"endActive\"\r\n type=\"text\"\r\n placeholder=\"\u7ED3\u675F\u65E5\u671F\"\r\n (click)=\"showPortal($event, 'end')\"\r\n (xFocus)=\"endActive = true\"\r\n (xBlur)=\"endActive = false\"\r\n [(ngModel)]=\"endDisplay\"\r\n ></x-input>\r\n <x-icon [type]=\"icon\"></x-icon>\r\n </x-input-group>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-date-range{display:inline-block}.x-date-range{margin:0;padding:0;width:100%}.x-date-range-row{flex:1;display:flex;align-items:center}.x-date-range-group{display:inline-flex;flex:1;width:100%;font-size:var(--x-font-size);background-color:var(--x-background);background-image:none;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) transparent;transition:all var(--x-animation-duration-slow)}.x-date-range-group .x-input-group{display:flex;align-items:center}.x-date-range-group .x-input-group>x-icon{color:var(--x-text-400);transition:all var(--x-animation-duration-base);z-index:2;padding:.4rem}.x-date-range-group .x-input-group>x-input{width:6rem}.x-date-range-group .x-input-group>x-input input{padding-left:0!important;padding-right:0!important;margin-left:.4rem;margin-right:.4rem;border-radius:0;border-bottom:var(--x-border-width) var(--x-border-style) transparent}.x-date-range-group .x-input-group>x-input .x-input-active input{border-color:var(--x-primary)}.x-date-range-group:hover{border-color:var(--x-primary-300)}.x-date-range-active .x-date-range-group{border-color:var(--x-primary)}\n"] }]
1797
+ args: [{ selector: `${XDateRangePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XDateRangeComponent), DatePipe], template: "<div\r\n #dateRange\r\n class=\"x-date-range\"\r\n [class.x-date-range-active]=\"active\"\r\n [class.x-date-range-active-start]=\"activeType === 'start'\"\r\n [class.x-date-range-active-end]=\"activeType === 'end'\"\r\n>\r\n <div class=\"x-date-range-row\">\r\n <x-input-group #inputGroup class=\"x-date-range-group\" (mouseenter)=\"menter()\" (mouseleave)=\"mleave()\" (click)=\"showPortal($event)\">\r\n <x-input\r\n #inputStartCom\r\n class=\"x-data-range-input-start\"\r\n type=\"text\"\r\n bordered=\"false\"\r\n placeholder=\"\u5F00\u59CB\u65E5\u671F\"\r\n (xFocus)=\"onFocus('start')\"\r\n (xClick)=\"showPortal($event, 'start')\"\r\n [(ngModel)]=\"startDisplay\"\r\n ></x-input>\r\n <x-icon class=\"x-date-range-icon\" type=\"fto-arrow-right\"></x-icon>\r\n <x-input\r\n #inputEndCom\r\n class=\"x-data-range-input-end\"\r\n type=\"text\"\r\n bordered=\"false\"\r\n placeholder=\"\u7ED3\u675F\u65E5\u671F\"\r\n (xFocus)=\"onFocus('end')\"\r\n (xClick)=\"showPortal($event, 'end')\"\r\n [(ngModel)]=\"endDisplay\"\r\n [icon]=\"icon\"\r\n (clearEmit)=\"clearEmit()\"\r\n [clearable]=\"showClearable\"\r\n ></x-input>\r\n <div *ngIf=\"active\" class=\"x-date-range-active-bar\"></div>\r\n </x-input-group>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-date-range{display:inline-block}.x-date-range{margin:0;padding:0;width:100%}.x-date-range-row{flex:1;display:flex;align-items:center}.x-date-range-group{display:inline-flex;flex:1;width:100%;font-size:var(--x-font-size);background-color:var(--x-background);background-image:none;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) transparent;transition:all var(--x-animation-duration-slow)}.x-date-range-group .x-input-group{display:flex;align-items:center;position:relative}.x-date-range-group .x-input-group .x-date-range-icon{color:var(--x-text-400);transition:all var(--x-animation-duration-base);z-index:2;font-size:1rem;width:1.8rem}.x-date-range-group .x-input-group>x-input input{padding-left:0!important;padding-right:0!important;background-color:transparent;margin-left:.4rem;margin-right:.4rem;border-radius:0}.x-date-range-group .x-input-group>x-input.x-data-range-input-start{width:6rem}.x-date-range-group .x-input-group>x-input.x-data-range-input-end{width:7.8rem}.x-date-range-group:hover{border-color:var(--x-primary-300)}.x-date-range-active-bar{position:absolute;height:.125rem;margin-left:.4rem;bottom:-.0625rem;width:calc(50% - 2.2rem);background-color:var(--x-primary);transition:var(--x-animation-duration-base)}.x-date-range-active .x-date-range-group{border-color:var(--x-primary)}.x-date-range-active-start .x-date-range-active-bar{left:0}.x-date-range-active-end .x-date-range-active-bar{left:50%}\n"] }]
1636
1798
  }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i2.XConfigService }, { type: i0.ChangeDetectorRef }, { type: i2$1.XPortalService }, { type: i0.ViewContainerRef }, { type: i1.DatePipe }, { type: i4$1.Overlay }]; }, propDecorators: { dateRange: [{
1637
1799
  type: ViewChild,
1638
1800
  args: ['dateRange', { static: true }]
@@ -1732,4 +1894,3 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
1732
1894
 
1733
1895
  export { XDatePickerComponent, XDatePickerModule, XDatePickerPortalComponent, XDatePickerPortalPrefix, XDatePickerPrefix, XDatePickerProperty, XDateRangeComponent, XDateRangePortalComponent, XDateRangePortalPrefix, XDateRangePrefix, XDateRangeProperty, XPickerDateComponent, XPickerDatePrefix, XPickerDateProperty, XPickerMonthComponent, XPickerMonthPrefix, XPickerMonthProperty, XPickerYearComponent, XPickerYearPrefix, XPickerYearProperty };
1734
1896
  //# sourceMappingURL=ng-nest-ui-date-picker.mjs.map
1735
- //# sourceMappingURL=ng-nest-ui-date-picker.mjs.map