@evotor-dev/ui-kit 8.0.0-beta.2 → 8.0.0-beta.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (402) hide show
  1. package/{esm2020 → esm2022}/lib/common/evo-base-control.mjs +4 -4
  2. package/{esm2020 → esm2022}/lib/components/evo-accordion/evo-accordion-content/evo-accordion-content.component.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/components/evo-accordion/evo-accordion-panel/evo-accordion-panel.component.mjs +4 -4
  4. package/esm2022/lib/components/evo-accordion/evo-accordion-title/evo-accordion-title.component.mjs +57 -0
  5. package/{esm2020 → esm2022}/lib/components/evo-accordion/evo-accordion.component.mjs +4 -4
  6. package/esm2022/lib/components/evo-accordion/evo-accordion.module.mjs +64 -0
  7. package/{esm2020 → esm2022}/lib/components/evo-alert/evo-alert.component.mjs +4 -4
  8. package/{esm2020 → esm2022}/lib/components/evo-alert/evo-alert.module.mjs +7 -7
  9. package/{esm2020 → esm2022}/lib/components/evo-autocomplete/components/evo-autocomplete.component.mjs +5 -5
  10. package/{esm2020 → esm2022}/lib/components/evo-autocomplete/components/templates/evo-autocomplete-default-option.component.mjs +5 -5
  11. package/{esm2020 → esm2022}/lib/components/evo-autocomplete/evo-autocomplete.module.mjs +21 -21
  12. package/{esm2020 → esm2022}/lib/components/evo-badge/evo-badge.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/lib/components/evo-badge/evo-badge.module.mjs +7 -7
  14. package/{esm2020 → esm2022}/lib/components/evo-banner/evo-banner.component.mjs +4 -4
  15. package/{esm2020 → esm2022}/lib/components/evo-banner/evo-banner.module.mjs +5 -5
  16. package/{esm2020 → esm2022}/lib/components/evo-button/components/evo-button/evo-button.component.mjs +4 -4
  17. package/{esm2020 → esm2022}/lib/components/evo-button/components/evo-button-old/evo-button-old.component.mjs +5 -5
  18. package/{esm2020 → esm2022}/lib/components/evo-button/evo-button.module.mjs +5 -5
  19. package/esm2022/lib/components/evo-checkbox/evo-checkbox.component.mjs +86 -0
  20. package/{esm2020 → esm2022}/lib/components/evo-checkbox/evo-checkbox.module.mjs +11 -11
  21. package/esm2022/lib/components/evo-chip/evo-chip.component.mjs +130 -0
  22. package/esm2022/lib/components/evo-chip/evo-chip.module.mjs +43 -0
  23. package/{esm2020 → esm2022}/lib/components/evo-control-error/evo-control-error.component.mjs +4 -4
  24. package/{esm2020 → esm2022}/lib/components/evo-control-error/evo-control-error.module.mjs +9 -9
  25. package/{esm2020 → esm2022}/lib/components/evo-control-label/evo-control-label.component.mjs +4 -4
  26. package/{esm2020 → esm2022}/lib/components/evo-control-label/evo-control-label.module.mjs +5 -5
  27. package/{esm2020 → esm2022}/lib/components/evo-counter/evo-counter.component.mjs +4 -4
  28. package/{esm2020 → esm2022}/lib/components/evo-counter/evo-counter.module.mjs +7 -7
  29. package/esm2022/lib/components/evo-datepicker/evo-datepicker.component.mjs +561 -0
  30. package/{esm2020 → esm2022}/lib/components/evo-datepicker/evo-datepicker.module.mjs +11 -11
  31. package/{esm2020 → esm2022}/lib/components/evo-dropdown/evo-dropdown-origin.directive.mjs +4 -4
  32. package/{esm2020 → esm2022}/lib/components/evo-dropdown/evo-dropdown.component.mjs +4 -4
  33. package/{esm2020 → esm2022}/lib/components/evo-dropdown/evo-dropdown.module.mjs +5 -5
  34. package/{esm2020 → esm2022}/lib/components/evo-icon/evo-icon.component.mjs +4 -4
  35. package/{esm2020 → esm2022}/lib/components/evo-icon/evo-icon.module.mjs +5 -5
  36. package/{esm2020 → esm2022}/lib/components/evo-icon-button/evo-icon-button.component.mjs +4 -4
  37. package/{esm2020 → esm2022}/lib/components/evo-icon-button/evo-icon-button.module.mjs +5 -5
  38. package/{esm2020 → esm2022}/lib/components/evo-icon-number/components/evo-icon-number/evo-icon-number.component.mjs +4 -4
  39. package/{esm2020 → esm2022}/lib/components/evo-icon-number/evo-icon-number.module.mjs +5 -5
  40. package/{esm2020 → esm2022}/lib/components/evo-input/evo-input-icon/evo-input-icon.directive.mjs +4 -4
  41. package/{esm2020 → esm2022}/lib/components/evo-input/evo-input.component.mjs +15 -15
  42. package/esm2022/lib/components/evo-input/evo-input.module.mjs +64 -0
  43. package/esm2022/lib/components/evo-input-contenteditable/evo-input-contenteditable.component.mjs +150 -0
  44. package/{esm2020 → esm2022}/lib/components/evo-input-contenteditable/evo-input-contenteditable.module.mjs +9 -9
  45. package/{esm2020 → esm2022}/lib/components/evo-loader/evo-circular-loader.component.mjs +4 -4
  46. package/{esm2020 → esm2022}/lib/components/evo-loader/evo-loader.component.mjs +4 -4
  47. package/{esm2020 → esm2022}/lib/components/evo-loader/evo-loader.module.mjs +9 -9
  48. package/{esm2020 → esm2022}/lib/components/evo-modal/evo-modal.component.mjs +5 -5
  49. package/{esm2020 → esm2022}/lib/components/evo-modal/evo-modal.module.mjs +9 -9
  50. package/{esm2020 → esm2022}/lib/components/evo-modal/evo-modal.service.mjs +4 -4
  51. package/{esm2020 → esm2022}/lib/components/evo-navbar/evo-navbar-item/evo-navbar-item.component.mjs +5 -5
  52. package/{esm2020 → esm2022}/lib/components/evo-navbar/evo-navbar.component.mjs +5 -5
  53. package/{esm2020 → esm2022}/lib/components/evo-navbar/evo-navbar.module.mjs +5 -5
  54. package/{esm2020 → esm2022}/lib/components/evo-navigation-button/evo-navigation-button.component.mjs +4 -4
  55. package/esm2022/lib/components/evo-navigation-button/evo-navigation-button.module.mjs +43 -0
  56. package/{esm2020 → esm2022}/lib/components/evo-note/evo-note.component.mjs +4 -4
  57. package/esm2022/lib/components/evo-note/evo-note.module.mjs +43 -0
  58. package/{esm2020 → esm2022}/lib/components/evo-paginator/evo-paginator.component.mjs +5 -5
  59. package/{esm2020 → esm2022}/lib/components/evo-paginator/evo-paginator.module.mjs +5 -5
  60. package/{esm2020 → esm2022}/lib/components/evo-plus-minus/evo-plus-minus.component.mjs +5 -5
  61. package/{esm2020 → esm2022}/lib/components/evo-plus-minus/evo-plus-minus.module.mjs +5 -5
  62. package/{esm2020 → esm2022}/lib/components/evo-popover/evo-popover.component.mjs +4 -4
  63. package/{esm2020 → esm2022}/lib/components/evo-popover/evo-popover.module.mjs +7 -7
  64. package/{esm2020 → esm2022}/lib/components/evo-portal/evo-portal-outlet.directive.mjs +4 -4
  65. package/{esm2020 → esm2022}/lib/components/evo-portal/evo-portal.module.mjs +7 -7
  66. package/{esm2020 → esm2022}/lib/components/evo-portal/evo-portal.service.mjs +4 -4
  67. package/esm2022/lib/components/evo-radio/evo-radio.component.mjs +51 -0
  68. package/{esm2020 → esm2022}/lib/components/evo-radio/evo-radio.module.mjs +7 -7
  69. package/esm2022/lib/components/evo-radio-group/evo-radio-group.component.mjs +123 -0
  70. package/{esm2020 → esm2022}/lib/components/evo-radio-group/evo-radio-group.module.mjs +11 -11
  71. package/esm2022/lib/components/evo-radioshape/components/evo-radioshape.component.mjs +56 -0
  72. package/{esm2020 → esm2022}/lib/components/evo-radioshape/evo-radioshape.module.mjs +9 -9
  73. package/{esm2020 → esm2022}/lib/components/evo-segmented-bar/evo-segmented-bar/evo-segmented-bar.component.mjs +4 -4
  74. package/esm2022/lib/components/evo-segmented-bar/evo-segmented-bar-button/evo-segmented-bar-button.component.mjs +77 -0
  75. package/{esm2020 → esm2022}/lib/components/evo-segmented-bar/evo-segmented-bar.module.mjs +5 -5
  76. package/esm2022/lib/components/evo-select/evo-select.component.mjs +115 -0
  77. package/{esm2020 → esm2022}/lib/components/evo-select/evo-select.module.mjs +11 -11
  78. package/{esm2020 → esm2022}/lib/components/evo-sidebar/evo-sidebar-content/evo-sidebar-content.component.mjs +4 -4
  79. package/{esm2020 → esm2022}/lib/components/evo-sidebar/evo-sidebar-footer/evo-sidebar-footer.component.mjs +4 -4
  80. package/{esm2020 → esm2022}/lib/components/evo-sidebar/evo-sidebar-header/evo-sidebar-header.component.mjs +4 -4
  81. package/{esm2020 → esm2022}/lib/components/evo-sidebar/evo-sidebar.component.mjs +9 -9
  82. package/esm2022/lib/components/evo-sidebar/evo-sidebar.module.mjs +88 -0
  83. package/{esm2020 → esm2022}/lib/components/evo-sidebar/evo-sidebar.service.mjs +4 -4
  84. package/{esm2020 → esm2022}/lib/components/evo-stepper/evo-stepper-events.mjs +4 -4
  85. package/{esm2020 → esm2022}/lib/components/evo-stepper/evo-stepper-item/evo-stepper-item.component.mjs +4 -4
  86. package/{esm2020 → esm2022}/lib/components/evo-stepper/evo-stepper.component.mjs +7 -7
  87. package/{esm2020 → esm2022}/lib/components/evo-stepper/evo-stepper.module.mjs +7 -7
  88. package/{esm2020 → esm2022}/lib/components/evo-submenu/evo-submenu.component.mjs +4 -4
  89. package/{esm2020 → esm2022}/lib/components/evo-submenu/evo-submenu.module.mjs +5 -5
  90. package/{esm2020 → esm2022}/lib/components/evo-switcher/components/evo-switcher-item/evo-switcher-item.component.mjs +4 -4
  91. package/{esm2020 → esm2022}/lib/components/evo-switcher/evo-switcher.component.mjs +5 -5
  92. package/{esm2020 → esm2022}/lib/components/evo-switcher/evo-switcher.module.mjs +7 -7
  93. package/{esm2020 → esm2022}/lib/components/evo-table/evo-table/evo-table.component.mjs +4 -4
  94. package/{esm2020 → esm2022}/lib/components/evo-table/evo-table-column/evo-table-column.component.mjs +4 -4
  95. package/{esm2020 → esm2022}/lib/components/evo-table/evo-table.module.mjs +5 -5
  96. package/{esm2020 → esm2022}/lib/components/evo-tabs/evo-tab/evo-tab.component.mjs +4 -4
  97. package/{esm2020 → esm2022}/lib/components/evo-tabs/evo-tab-content/evo-tab-content.component.mjs +4 -4
  98. package/{esm2020 → esm2022}/lib/components/evo-tabs/evo-tabs-size.service.mjs +4 -4
  99. package/{esm2020 → esm2022}/lib/components/evo-tabs/evo-tabs.component.mjs +4 -4
  100. package/{esm2020 → esm2022}/lib/components/evo-tabs/evo-tabs.module.mjs +7 -7
  101. package/{esm2020 → esm2022}/lib/components/evo-tabs/evo-tabs.service.mjs +4 -4
  102. package/esm2022/lib/components/evo-textarea/evo-textarea.component.mjs +79 -0
  103. package/{esm2020 → esm2022}/lib/components/evo-textarea/evo-textarea.module.mjs +13 -13
  104. package/{esm2020 → esm2022}/lib/components/evo-toast/evo-toast.component.mjs +21 -21
  105. package/esm2022/lib/components/evo-toast/evo-toast.module.mjs +43 -0
  106. package/{esm2020 → esm2022}/lib/components/evo-toast/evo-toast.service.mjs +4 -4
  107. package/esm2022/lib/components/evo-toggle/evo-toggle.component.mjs +64 -0
  108. package/{esm2020 → esm2022}/lib/components/evo-toggle/evo-toggle.module.mjs +9 -9
  109. package/esm2022/lib/components/evo-upload/evo-upload.component.mjs +287 -0
  110. package/esm2022/lib/components/evo-upload/evo-upload.module.mjs +57 -0
  111. package/{esm2020 → esm2022}/lib/directives/evo-click-outside.directive.mjs +4 -4
  112. package/{esm2020 → esm2022}/lib/directives/evo-is-expanded.directive.mjs +4 -4
  113. package/{esm2020 → esm2022}/lib/directives/evo-let/evo-let.directive.mjs +4 -4
  114. package/{esm2020 → esm2022}/lib/directives/evo-ui-class.directive.mjs +4 -4
  115. package/{esm2020 → esm2022}/lib/evo-ui-kit.module.mjs +21 -21
  116. package/{esm2020 → esm2022}/lib/pipes/declination.pipe.mjs +4 -4
  117. package/{esm2020 → esm2022}/lib/pipes/evo-pipes.module.mjs +5 -5
  118. package/{esm2020 → esm2022}/lib/pipes/safe-html.pipe.mjs +4 -4
  119. package/{esm2020 → esm2022}/lib/services/evo-expanded.service.mjs +4 -4
  120. package/{esm2020 → esm2022}/lib/services/window.service.mjs +4 -4
  121. package/{fesm2020 → fesm2022}/evotor-dev-ui-kit.mjs +780 -780
  122. package/{fesm2020 → fesm2022}/evotor-dev-ui-kit.mjs.map +1 -1
  123. package/lib/common/evo-base-control.d.ts +1 -1
  124. package/lib/components/evo-accordion/evo-accordion-title/evo-accordion-title.component.d.ts +1 -1
  125. package/lib/components/evo-alert/evo-alert.component.d.ts +1 -1
  126. package/lib/components/evo-autocomplete/components/evo-autocomplete.component.d.ts +1 -1
  127. package/lib/components/evo-autocomplete/components/templates/evo-autocomplete-default-option.component.d.ts +1 -1
  128. package/lib/components/evo-badge/evo-badge.component.d.ts +1 -1
  129. package/lib/components/evo-banner/evo-banner.component.d.ts +1 -1
  130. package/lib/components/evo-button/components/evo-button/evo-button.component.d.ts +1 -1
  131. package/lib/components/evo-button/components/evo-button-old/evo-button-old.component.d.ts +1 -1
  132. package/lib/components/evo-checkbox/evo-checkbox.component.d.ts +1 -1
  133. package/lib/components/evo-chip/evo-chip.component.d.ts +1 -1
  134. package/lib/components/evo-control-error/evo-control-error.component.d.ts +1 -1
  135. package/lib/components/evo-control-label/evo-control-label.component.d.ts +1 -1
  136. package/lib/components/evo-counter/evo-counter.component.d.ts +1 -1
  137. package/lib/components/evo-datepicker/evo-datepicker.component.d.ts +1 -1
  138. package/lib/components/evo-dropdown/evo-dropdown.component.d.ts +1 -1
  139. package/lib/components/evo-icon/evo-icon.component.d.ts +1 -1
  140. package/lib/components/evo-icon-button/evo-icon-button.component.d.ts +1 -1
  141. package/lib/components/evo-icon-number/components/evo-icon-number/evo-icon-number.component.d.ts +1 -1
  142. package/lib/components/evo-input/evo-input.component.d.ts +1 -1
  143. package/lib/components/evo-input-contenteditable/evo-input-contenteditable.component.d.ts +1 -1
  144. package/lib/components/evo-loader/evo-loader.component.d.ts +1 -1
  145. package/lib/components/evo-modal/evo-modal.component.d.ts +1 -1
  146. package/lib/components/evo-navbar/evo-navbar-item/evo-navbar-item.component.d.ts +1 -1
  147. package/lib/components/evo-navbar/evo-navbar.component.d.ts +1 -1
  148. package/lib/components/evo-note/evo-note.component.d.ts +1 -1
  149. package/lib/components/evo-paginator/evo-paginator.component.d.ts +1 -1
  150. package/lib/components/evo-plus-minus/evo-plus-minus.component.d.ts +1 -1
  151. package/lib/components/evo-popover/evo-popover.component.d.ts +1 -1
  152. package/lib/components/evo-radio/evo-radio.component.d.ts +1 -1
  153. package/lib/components/evo-radio-group/evo-radio-group.component.d.ts +1 -1
  154. package/lib/components/evo-radioshape/components/evo-radioshape.component.d.ts +1 -1
  155. package/lib/components/evo-segmented-bar/evo-segmented-bar/evo-segmented-bar.component.d.ts +1 -1
  156. package/lib/components/evo-segmented-bar/evo-segmented-bar-button/evo-segmented-bar-button.component.d.ts +1 -1
  157. package/lib/components/evo-select/evo-select.component.d.ts +1 -1
  158. package/lib/components/evo-sidebar/evo-sidebar-content/evo-sidebar-content.component.d.ts +1 -1
  159. package/lib/components/evo-sidebar/evo-sidebar-header/evo-sidebar-header.component.d.ts +1 -1
  160. package/lib/components/evo-sidebar/evo-sidebar.component.d.ts +1 -1
  161. package/lib/components/evo-stepper/evo-stepper-item/evo-stepper-item.component.d.ts +1 -1
  162. package/lib/components/evo-stepper/evo-stepper.component.d.ts +1 -1
  163. package/lib/components/evo-submenu/evo-submenu.component.d.ts +1 -1
  164. package/lib/components/evo-switcher/evo-switcher.component.d.ts +1 -1
  165. package/lib/components/evo-table/evo-table/evo-table.component.d.ts +1 -1
  166. package/lib/components/evo-table/evo-table-column/evo-table-column.component.d.ts +1 -1
  167. package/lib/components/evo-tabs/evo-tab/evo-tab.component.d.ts +1 -1
  168. package/lib/components/evo-tabs/evo-tab-content/evo-tab-content.component.d.ts +1 -1
  169. package/lib/components/evo-tabs/evo-tabs.component.d.ts +1 -1
  170. package/lib/components/evo-textarea/evo-textarea.component.d.ts +1 -1
  171. package/lib/components/evo-upload/evo-upload.component.d.ts +1 -1
  172. package/lib/directives/evo-is-expanded.directive.d.ts +1 -1
  173. package/lib/directives/evo-let/evo-let.directive.d.ts +1 -1
  174. package/lib/directives/evo-ui-class.directive.d.ts +1 -1
  175. package/package.json +42 -64
  176. package/esm2020/lib/components/evo-accordion/evo-accordion-title/evo-accordion-title.component.mjs +0 -57
  177. package/esm2020/lib/components/evo-accordion/evo-accordion.module.mjs +0 -64
  178. package/esm2020/lib/components/evo-checkbox/evo-checkbox.component.mjs +0 -86
  179. package/esm2020/lib/components/evo-chip/evo-chip.component.mjs +0 -130
  180. package/esm2020/lib/components/evo-chip/evo-chip.module.mjs +0 -43
  181. package/esm2020/lib/components/evo-datepicker/evo-datepicker.component.mjs +0 -561
  182. package/esm2020/lib/components/evo-input/evo-input.module.mjs +0 -64
  183. package/esm2020/lib/components/evo-input-contenteditable/evo-input-contenteditable.component.mjs +0 -150
  184. package/esm2020/lib/components/evo-navigation-button/evo-navigation-button.module.mjs +0 -43
  185. package/esm2020/lib/components/evo-note/evo-note.module.mjs +0 -43
  186. package/esm2020/lib/components/evo-radio/evo-radio.component.mjs +0 -51
  187. package/esm2020/lib/components/evo-radio-group/evo-radio-group.component.mjs +0 -123
  188. package/esm2020/lib/components/evo-radioshape/components/evo-radioshape.component.mjs +0 -56
  189. package/esm2020/lib/components/evo-segmented-bar/evo-segmented-bar-button/evo-segmented-bar-button.component.mjs +0 -77
  190. package/esm2020/lib/components/evo-select/evo-select.component.mjs +0 -115
  191. package/esm2020/lib/components/evo-sidebar/evo-sidebar.module.mjs +0 -88
  192. package/esm2020/lib/components/evo-textarea/evo-textarea.component.mjs +0 -79
  193. package/esm2020/lib/components/evo-toast/evo-toast.module.mjs +0 -43
  194. package/esm2020/lib/components/evo-toggle/evo-toggle.component.mjs +0 -64
  195. package/esm2020/lib/components/evo-upload/evo-upload.component.mjs +0 -287
  196. package/esm2020/lib/components/evo-upload/evo-upload.module.mjs +0 -57
  197. package/fesm2015/evotor-dev-ui-kit.mjs +0 -7395
  198. package/fesm2015/evotor-dev-ui-kit.mjs.map +0 -1
  199. package/fesm2020/evotor-dev-ui-kit-icons-category.mjs +0 -68
  200. package/fesm2020/evotor-dev-ui-kit-icons-category.mjs.map +0 -1
  201. package/fesm2020/evotor-dev-ui-kit-icons-emotions.mjs +0 -24
  202. package/fesm2020/evotor-dev-ui-kit-icons-emotions.mjs.map +0 -1
  203. package/fesm2020/evotor-dev-ui-kit-icons-header.mjs +0 -34
  204. package/fesm2020/evotor-dev-ui-kit-icons-header.mjs.map +0 -1
  205. package/fesm2020/evotor-dev-ui-kit-icons-info.mjs +0 -46
  206. package/fesm2020/evotor-dev-ui-kit-icons-info.mjs.map +0 -1
  207. package/fesm2020/evotor-dev-ui-kit-icons-navigation.mjs +0 -62
  208. package/fesm2020/evotor-dev-ui-kit-icons-navigation.mjs.map +0 -1
  209. package/fesm2020/evotor-dev-ui-kit-icons-side-menu.mjs +0 -70
  210. package/fesm2020/evotor-dev-ui-kit-icons-side-menu.mjs.map +0 -1
  211. package/fesm2020/evotor-dev-ui-kit-icons-system.mjs +0 -378
  212. package/fesm2020/evotor-dev-ui-kit-icons-system.mjs.map +0 -1
  213. package/fesm2020/evotor-dev-ui-kit-icons.mjs +0 -648
  214. package/fesm2020/evotor-dev-ui-kit-icons.mjs.map +0 -1
  215. /package/{esm2020 → esm2022}/evotor-dev-ui-kit.mjs +0 -0
  216. /package/{esm2020 → esm2022}/icons/category/evotor-dev-ui-kit-icons-category.mjs +0 -0
  217. /package/{esm2020 → esm2022}/icons/category/index.mjs +0 -0
  218. /package/{esm2020 → esm2022}/icons/emotions/evotor-dev-ui-kit-icons-emotions.mjs +0 -0
  219. /package/{esm2020 → esm2022}/icons/emotions/index.mjs +0 -0
  220. /package/{esm2020 → esm2022}/icons/evotor-dev-ui-kit-icons.mjs +0 -0
  221. /package/{esm2020 → esm2022}/icons/header/evotor-dev-ui-kit-icons-header.mjs +0 -0
  222. /package/{esm2020 → esm2022}/icons/header/index.mjs +0 -0
  223. /package/{esm2020 → esm2022}/icons/index.mjs +0 -0
  224. /package/{esm2020 → esm2022}/icons/info/evotor-dev-ui-kit-icons-info.mjs +0 -0
  225. /package/{esm2020 → esm2022}/icons/info/index.mjs +0 -0
  226. /package/{esm2020 → esm2022}/icons/navigation/evotor-dev-ui-kit-icons-navigation.mjs +0 -0
  227. /package/{esm2020 → esm2022}/icons/navigation/index.mjs +0 -0
  228. /package/{esm2020 → esm2022}/icons/side-menu/evotor-dev-ui-kit-icons-side-menu.mjs +0 -0
  229. /package/{esm2020 → esm2022}/icons/side-menu/index.mjs +0 -0
  230. /package/{esm2020 → esm2022}/icons/system/evotor-dev-ui-kit-icons-system.mjs +0 -0
  231. /package/{esm2020 → esm2022}/icons/system/index.mjs +0 -0
  232. /package/{esm2020 → esm2022}/lib/common/Serializable.mjs +0 -0
  233. /package/{esm2020 → esm2022}/lib/common/animations/expand.animation.mjs +0 -0
  234. /package/{esm2020 → esm2022}/lib/common/animations/index.mjs +0 -0
  235. /package/{esm2020 → esm2022}/lib/common/animations/sidebar.animation.mjs +0 -0
  236. /package/{esm2020 → esm2022}/lib/common/animations/skip-initial-render.animation.mjs +0 -0
  237. /package/{esm2020 → esm2022}/lib/common/collection/evo-collection-fabric.mjs +0 -0
  238. /package/{esm2020 → esm2022}/lib/common/collection/evo-collection.mjs +0 -0
  239. /package/{esm2020 → esm2022}/lib/common/collection/index.mjs +0 -0
  240. /package/{esm2020 → esm2022}/lib/common/constants/css-breakpoints.mjs +0 -0
  241. /package/{esm2020 → esm2022}/lib/common/constants/view-breakpoint-streams.mjs +0 -0
  242. /package/{esm2020 → esm2022}/lib/common/evo-control-state-manager/evo-control-state-manager.mjs +0 -0
  243. /package/{esm2020 → esm2022}/lib/common/evo-control-state-manager/evo-control-state.interface.mjs +0 -0
  244. /package/{esm2020 → esm2022}/lib/common/evo-control-state-manager/evo-control-states.enum.mjs +0 -0
  245. /package/{esm2020 → esm2022}/lib/common/form-helper/form-helper.mjs +0 -0
  246. /package/{esm2020 → esm2022}/lib/common/types/evo-color.mjs +0 -0
  247. /package/{esm2020 → esm2022}/lib/common/types/evo-size.mjs +0 -0
  248. /package/{esm2020 → esm2022}/lib/common/types/index.mjs +0 -0
  249. /package/{esm2020 → esm2022}/lib/components/evo-accordion/index.mjs +0 -0
  250. /package/{esm2020 → esm2022}/lib/components/evo-accordion/public-api.mjs +0 -0
  251. /package/{esm2020 → esm2022}/lib/components/evo-alert/index.mjs +0 -0
  252. /package/{esm2020 → esm2022}/lib/components/evo-alert/public-api.mjs +0 -0
  253. /package/{esm2020 → esm2022}/lib/components/evo-autocomplete/helpers/switch-query-to-list.mjs +0 -0
  254. /package/{esm2020 → esm2022}/lib/components/evo-autocomplete/index.mjs +0 -0
  255. /package/{esm2020 → esm2022}/lib/components/evo-autocomplete/models/DaDataParty.mjs +0 -0
  256. /package/{esm2020 → esm2022}/lib/components/evo-autocomplete/models/dadata.model.mjs +0 -0
  257. /package/{esm2020 → esm2022}/lib/components/evo-autocomplete/public-api.mjs +0 -0
  258. /package/{esm2020 → esm2022}/lib/components/evo-autocomplete/types/evo-autocomplete-size.mjs +0 -0
  259. /package/{esm2020 → esm2022}/lib/components/evo-badge/index.mjs +0 -0
  260. /package/{esm2020 → esm2022}/lib/components/evo-badge/public-api.mjs +0 -0
  261. /package/{esm2020 → esm2022}/lib/components/evo-badge/types/evo-badge-color.mjs +0 -0
  262. /package/{esm2020 → esm2022}/lib/components/evo-badge/types/evo-badge-size.mjs +0 -0
  263. /package/{esm2020 → esm2022}/lib/components/evo-badge/types/index.mjs +0 -0
  264. /package/{esm2020 → esm2022}/lib/components/evo-banner/index.mjs +0 -0
  265. /package/{esm2020 → esm2022}/lib/components/evo-banner/public-api.mjs +0 -0
  266. /package/{esm2020 → esm2022}/lib/components/evo-button/constants/evo-button-themes-map.mjs +0 -0
  267. /package/{esm2020 → esm2022}/lib/components/evo-button/index.mjs +0 -0
  268. /package/{esm2020 → esm2022}/lib/components/evo-button/public-api.mjs +0 -0
  269. /package/{esm2020 → esm2022}/lib/components/evo-button/types/evo-button-color.mjs +0 -0
  270. /package/{esm2020 → esm2022}/lib/components/evo-button/types/evo-button-shape.mjs +0 -0
  271. /package/{esm2020 → esm2022}/lib/components/evo-button/types/evo-button-size.mjs +0 -0
  272. /package/{esm2020 → esm2022}/lib/components/evo-button/types/evo-button-theme-params.mjs +0 -0
  273. /package/{esm2020 → esm2022}/lib/components/evo-button/types/evo-button-theme.mjs +0 -0
  274. /package/{esm2020 → esm2022}/lib/components/evo-button/types/index.mjs +0 -0
  275. /package/{esm2020 → esm2022}/lib/components/evo-checkbox/index.mjs +0 -0
  276. /package/{esm2020 → esm2022}/lib/components/evo-checkbox/public-api.mjs +0 -0
  277. /package/{esm2020 → esm2022}/lib/components/evo-chip/index.mjs +0 -0
  278. /package/{esm2020 → esm2022}/lib/components/evo-chip/public-api.mjs +0 -0
  279. /package/{esm2020 → esm2022}/lib/components/evo-control-error/index.mjs +0 -0
  280. /package/{esm2020 → esm2022}/lib/components/evo-control-error/public-api.mjs +0 -0
  281. /package/{esm2020 → esm2022}/lib/components/evo-control-label/index.mjs +0 -0
  282. /package/{esm2020 → esm2022}/lib/components/evo-control-label/public-api.mjs +0 -0
  283. /package/{esm2020 → esm2022}/lib/components/evo-counter/index.mjs +0 -0
  284. /package/{esm2020 → esm2022}/lib/components/evo-counter/public-api.mjs +0 -0
  285. /package/{esm2020 → esm2022}/lib/components/evo-datepicker/flatpickr-options.interface.mjs +0 -0
  286. /package/{esm2020 → esm2022}/lib/components/evo-datepicker/index.mjs +0 -0
  287. /package/{esm2020 → esm2022}/lib/components/evo-datepicker/public-api.mjs +0 -0
  288. /package/{esm2020 → esm2022}/lib/components/evo-datepicker/templates/index.mjs +0 -0
  289. /package/{esm2020 → esm2022}/lib/components/evo-dropdown/evo-dropdown-position-description.mjs +0 -0
  290. /package/{esm2020 → esm2022}/lib/components/evo-dropdown/index.mjs +0 -0
  291. /package/{esm2020 → esm2022}/lib/components/evo-dropdown/public-api.mjs +0 -0
  292. /package/{esm2020 → esm2022}/lib/components/evo-dropdown/types/evo-dropdown-positions.mjs +0 -0
  293. /package/{esm2020 → esm2022}/lib/components/evo-icon/classes/evo-icons-library.mjs +0 -0
  294. /package/{esm2020 → esm2022}/lib/components/evo-icon/index.mjs +0 -0
  295. /package/{esm2020 → esm2022}/lib/components/evo-icon/interfaces/icons-category.mjs +0 -0
  296. /package/{esm2020 → esm2022}/lib/components/evo-icon/interfaces/icons-source.mjs +0 -0
  297. /package/{esm2020 → esm2022}/lib/components/evo-icon/public-api.mjs +0 -0
  298. /package/{esm2020 → esm2022}/lib/components/evo-icon-button/index.mjs +0 -0
  299. /package/{esm2020 → esm2022}/lib/components/evo-icon-button/public-api.mjs +0 -0
  300. /package/{esm2020 → esm2022}/lib/components/evo-icon-button/types/evo-icon-button-size.mjs +0 -0
  301. /package/{esm2020 → esm2022}/lib/components/evo-icon-button/types/evo-icon-button-theme.mjs +0 -0
  302. /package/{esm2020 → esm2022}/lib/components/evo-icon-number/index.mjs +0 -0
  303. /package/{esm2020 → esm2022}/lib/components/evo-icon-number/public-api.mjs +0 -0
  304. /package/{esm2020 → esm2022}/lib/components/evo-input/index.mjs +0 -0
  305. /package/{esm2020 → esm2022}/lib/components/evo-input/public-api.mjs +0 -0
  306. /package/{esm2020 → esm2022}/lib/components/evo-input-contenteditable/index.mjs +0 -0
  307. /package/{esm2020 → esm2022}/lib/components/evo-input-contenteditable/public-api.mjs +0 -0
  308. /package/{esm2020 → esm2022}/lib/components/evo-input-contenteditable/utils/clear-multiline.mjs +0 -0
  309. /package/{esm2020 → esm2022}/lib/components/evo-loader/index.mjs +0 -0
  310. /package/{esm2020 → esm2022}/lib/components/evo-loader/public-api.mjs +0 -0
  311. /package/{esm2020 → esm2022}/lib/components/evo-modal/index.mjs +0 -0
  312. /package/{esm2020 → esm2022}/lib/components/evo-modal/public-api.mjs +0 -0
  313. /package/{esm2020 → esm2022}/lib/components/evo-navbar/index.mjs +0 -0
  314. /package/{esm2020 → esm2022}/lib/components/evo-navbar/interfaces/nav-item-main-info.mjs +0 -0
  315. /package/{esm2020 → esm2022}/lib/components/evo-navbar/interfaces/nav-item-router-link.mjs +0 -0
  316. /package/{esm2020 → esm2022}/lib/components/evo-navbar/interfaces/nav-item.href.mjs +0 -0
  317. /package/{esm2020 → esm2022}/lib/components/evo-navbar/public-api.mjs +0 -0
  318. /package/{esm2020 → esm2022}/lib/components/evo-navbar/types/nav-item.mjs +0 -0
  319. /package/{esm2020 → esm2022}/lib/components/evo-navigation-button/index.mjs +0 -0
  320. /package/{esm2020 → esm2022}/lib/components/evo-navigation-button/public-api.mjs +0 -0
  321. /package/{esm2020 → esm2022}/lib/components/evo-note/index.mjs +0 -0
  322. /package/{esm2020 → esm2022}/lib/components/evo-note/public.api.mjs +0 -0
  323. /package/{esm2020 → esm2022}/lib/components/evo-note/types/evo-note-type.mjs +0 -0
  324. /package/{esm2020 → esm2022}/lib/components/evo-paginator/index.mjs +0 -0
  325. /package/{esm2020 → esm2022}/lib/components/evo-paginator/public-api.mjs +0 -0
  326. /package/{esm2020 → esm2022}/lib/components/evo-plus-minus/index.mjs +0 -0
  327. /package/{esm2020 → esm2022}/lib/components/evo-plus-minus/public-api.mjs +0 -0
  328. /package/{esm2020 → esm2022}/lib/components/evo-popover/index.mjs +0 -0
  329. /package/{esm2020 → esm2022}/lib/components/evo-popover/public-api.mjs +0 -0
  330. /package/{esm2020 → esm2022}/lib/components/evo-portal/evo-portal-outlet.class.mjs +0 -0
  331. /package/{esm2020 → esm2022}/lib/components/evo-portal/index.mjs +0 -0
  332. /package/{esm2020 → esm2022}/lib/components/evo-portal/public-api.mjs +0 -0
  333. /package/{esm2020 → esm2022}/lib/components/evo-radio/index.mjs +0 -0
  334. /package/{esm2020 → esm2022}/lib/components/evo-radio/public-api.mjs +0 -0
  335. /package/{esm2020 → esm2022}/lib/components/evo-radio-group/index.mjs +0 -0
  336. /package/{esm2020 → esm2022}/lib/components/evo-radio-group/public-api.mjs +0 -0
  337. /package/{esm2020 → esm2022}/lib/components/evo-radio-group/typings/options.mjs +0 -0
  338. /package/{esm2020 → esm2022}/lib/components/evo-radioshape/index.mjs +0 -0
  339. /package/{esm2020 → esm2022}/lib/components/evo-radioshape/public-api.mjs +0 -0
  340. /package/{esm2020 → esm2022}/lib/components/evo-segmented-bar/index.mjs +0 -0
  341. /package/{esm2020 → esm2022}/lib/components/evo-segmented-bar/public-api.mjs +0 -0
  342. /package/{esm2020 → esm2022}/lib/components/evo-select/index.mjs +0 -0
  343. /package/{esm2020 → esm2022}/lib/components/evo-select/public-api.mjs +0 -0
  344. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/enums/evo-sidebar-close-targets.mjs +0 -0
  345. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/enums/evo-sidebar-sizes.mjs +0 -0
  346. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/enums/evo-sidebar-states.mjs +0 -0
  347. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/evo-sidebar-portal.mjs +0 -0
  348. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/index.mjs +0 -0
  349. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/interfaces.mjs +0 -0
  350. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/public-api.mjs +0 -0
  351. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/sidebar-injection-token.mjs +0 -0
  352. /package/{esm2020 → esm2022}/lib/components/evo-sidebar/tokens.mjs +0 -0
  353. /package/{esm2020 → esm2022}/lib/components/evo-stepper/index.mjs +0 -0
  354. /package/{esm2020 → esm2022}/lib/components/evo-stepper/public-api.mjs +0 -0
  355. /package/{esm2020 → esm2022}/lib/components/evo-submenu/index.mjs +0 -0
  356. /package/{esm2020 → esm2022}/lib/components/evo-submenu/public-api.mjs +0 -0
  357. /package/{esm2020 → esm2022}/lib/components/evo-switcher/index.mjs +0 -0
  358. /package/{esm2020 → esm2022}/lib/components/evo-switcher/public-api.mjs +0 -0
  359. /package/{esm2020 → esm2022}/lib/components/evo-table/index.mjs +0 -0
  360. /package/{esm2020 → esm2022}/lib/components/evo-table/public-api.mjs +0 -0
  361. /package/{esm2020 → esm2022}/lib/components/evo-tabs/enums/evo-tabs-size.mjs +0 -0
  362. /package/{esm2020 → esm2022}/lib/components/evo-tabs/evo-tab-state.collection.mjs +0 -0
  363. /package/{esm2020 → esm2022}/lib/components/evo-tabs/index.mjs +0 -0
  364. /package/{esm2020 → esm2022}/lib/components/evo-tabs/public-api.mjs +0 -0
  365. /package/{esm2020 → esm2022}/lib/components/evo-textarea/index.mjs +0 -0
  366. /package/{esm2020 → esm2022}/lib/components/evo-textarea/public-api.mjs +0 -0
  367. /package/{esm2020 → esm2022}/lib/components/evo-toast/index.mjs +0 -0
  368. /package/{esm2020 → esm2022}/lib/components/evo-toast/public-api.mjs +0 -0
  369. /package/{esm2020 → esm2022}/lib/components/evo-toggle/index.mjs +0 -0
  370. /package/{esm2020 → esm2022}/lib/components/evo-toggle/public-api.mjs +0 -0
  371. /package/{esm2020 → esm2022}/lib/components/evo-upload/index.mjs +0 -0
  372. /package/{esm2020 → esm2022}/lib/components/evo-upload/public-api.mjs +0 -0
  373. /package/{esm2020 → esm2022}/lib/decorators/deprecate-method.decorator.mjs +0 -0
  374. /package/{esm2020 → esm2022}/lib/decorators/deprecate-variable.decorator.mjs +0 -0
  375. /package/{esm2020 → esm2022}/lib/decorators/index.mjs +0 -0
  376. /package/{esm2020 → esm2022}/lib/decorators/public-api.mjs +0 -0
  377. /package/{esm2020 → esm2022}/lib/directives/index.mjs +0 -0
  378. /package/{esm2020 → esm2022}/lib/directives/public-api.mjs +0 -0
  379. /package/{esm2020 → esm2022}/lib/operators/enter-zone.operator.mjs +0 -0
  380. /package/{esm2020 → esm2022}/lib/operators/index.mjs +0 -0
  381. /package/{esm2020 → esm2022}/lib/operators/public-api.mjs +0 -0
  382. /package/{esm2020 → esm2022}/lib/pipes/index.mjs +0 -0
  383. /package/{esm2020 → esm2022}/lib/pipes/public-api.mjs +0 -0
  384. /package/{esm2020 → esm2022}/lib/services/index.mjs +0 -0
  385. /package/{esm2020 → esm2022}/lib/services/public-api.mjs +0 -0
  386. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  387. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-category.mjs +0 -0
  388. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-category.mjs.map +0 -0
  389. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-emotions.mjs +0 -0
  390. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-emotions.mjs.map +0 -0
  391. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-header.mjs +0 -0
  392. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-header.mjs.map +0 -0
  393. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-info.mjs +0 -0
  394. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-info.mjs.map +0 -0
  395. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-navigation.mjs +0 -0
  396. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-navigation.mjs.map +0 -0
  397. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-side-menu.mjs +0 -0
  398. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-side-menu.mjs.map +0 -0
  399. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-system.mjs +0 -0
  400. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons-system.mjs.map +0 -0
  401. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons.mjs +0 -0
  402. /package/{fesm2015 → fesm2022}/evotor-dev-ui-kit-icons.mjs.map +0 -0
@@ -0,0 +1,561 @@
1
+ import { Component, EventEmitter, forwardRef, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { cloneDeep, isEqual } from 'lodash-es';
4
+ import { cssClasses, renderRangeTime } from './templates';
5
+ import { EvoBaseControl } from '../../common/evo-base-control';
6
+ import { EvoControlStates } from '../../common/evo-control-state-manager/evo-control-states.enum';
7
+ import flatpickr from 'flatpickr';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/common";
10
+ import * as i2 from "../../directives/evo-ui-class.directive";
11
+ import * as i3 from "angular-imask";
12
+ import * as i4 from "../evo-control-error/evo-control-error.component";
13
+ export * from './flatpickr-options.interface';
14
+ var DatepickerModes;
15
+ (function (DatepickerModes) {
16
+ DatepickerModes["RANGE"] = "range";
17
+ })(DatepickerModes || (DatepickerModes = {}));
18
+ export class EvoDatepickerComponent extends EvoBaseControl {
19
+ constructor(zone, elementRef, injector) {
20
+ super(injector);
21
+ this.zone = zone;
22
+ this.elementRef = elementRef;
23
+ this.injector = injector;
24
+ this.folded = false;
25
+ this.placeholder = '';
26
+ this.appendToBody = true;
27
+ this.closePicker = new EventEmitter();
28
+ this.disabled = false;
29
+ this.uiState = {
30
+ isOpen: false,
31
+ isEmptyField: false,
32
+ };
33
+ this.elements = {};
34
+ this.onChange = (value) => {
35
+ };
36
+ this.onTouched = () => {
37
+ };
38
+ this.propagateChange = (_) => {
39
+ };
40
+ }
41
+ writeValue(value) {
42
+ this.updatePickerIfNeed(value);
43
+ this.propagateChange(value);
44
+ this.onChange(value);
45
+ }
46
+ registerOnChange(fn) {
47
+ this.onChange = fn;
48
+ this.propagateChange = fn;
49
+ }
50
+ registerOnTouched(fn) {
51
+ this.onTouched = fn;
52
+ }
53
+ handleMaskComplete(value) {
54
+ if (this.maskedInput) {
55
+ const date = this.flatpickrElement.nativeElement._flatpickr.parseDate(value, this.config.dateFormat);
56
+ this.setDateFromInput(date);
57
+ }
58
+ }
59
+ setDateFromInput(date) {
60
+ this.flatpickrElement.nativeElement._flatpickr.setDate(date, true);
61
+ }
62
+ ngAfterViewInit() {
63
+ const config = this.getConfig();
64
+ this.zone.runOutsideAngular(() => {
65
+ this.flatpickr = flatpickr(this.flatpickrElement.nativeElement, config);
66
+ });
67
+ if (this.setDate) {
68
+ this.setDateFromInput(this.setDate);
69
+ }
70
+ this.customizePicker();
71
+ }
72
+ ngOnChanges(changes) {
73
+ if (changes.hasOwnProperty('setDate') && changes['setDate'].currentValue) {
74
+ this.setDateFromInput(changes['setDate'].currentValue);
75
+ }
76
+ }
77
+ ngOnInit() {
78
+ this.initMask();
79
+ }
80
+ ngOnDestroy() {
81
+ this.flatpickr = null;
82
+ this.flatpickrElement.nativeElement._flatpickr.destroy();
83
+ }
84
+ get inputClass() {
85
+ return {
86
+ 'disabled': this.disabled,
87
+ 'hidden': !this.isValueExist(),
88
+ 'valid': this.currentState[EvoControlStates.valid],
89
+ 'invalid': this.currentState[EvoControlStates.invalid],
90
+ };
91
+ }
92
+ get totalClasses() {
93
+ const classes = [];
94
+ if (this.theme) {
95
+ classes.push(this.theme);
96
+ }
97
+ if (this.uiState.isOpen) {
98
+ classes.push('opened');
99
+ }
100
+ if (this.folded) {
101
+ classes.push('folded');
102
+ }
103
+ return classes;
104
+ }
105
+ initMask() {
106
+ if (this.config.allowInput && this.maskedInput) {
107
+ this.maskConfig = {
108
+ pattern: this.config.dateFormat,
109
+ max: this.config.maxDate,
110
+ mask: Date,
111
+ };
112
+ }
113
+ }
114
+ onDatepickerClick(event) {
115
+ if (this.config.allowInput &&
116
+ event.target.classList.contains(cssClasses.INPUT) ||
117
+ this.disabled) {
118
+ return;
119
+ }
120
+ this.toggleDatepicker();
121
+ }
122
+ toggleDatepicker() {
123
+ this.flatpickr.toggle();
124
+ }
125
+ setDisabledState(state) {
126
+ this.disabled = state;
127
+ }
128
+ isValueExist() {
129
+ if (!this.flatpickr) {
130
+ const defaultDate = this.config.defaultDate;
131
+ return Array.isArray(defaultDate) ?
132
+ this.config.defaultDate.length > 0 : !!defaultDate;
133
+ }
134
+ else {
135
+ return this.flatpickr.selectedDates.length > 0;
136
+ }
137
+ }
138
+ isRange() {
139
+ return this.config.mode === DatepickerModes.RANGE;
140
+ }
141
+ shouldShowEmptyText() {
142
+ return !this.isValueExist() && !this.config.altInput;
143
+ }
144
+ getDefaultFlatpickrOptions() {
145
+ return {
146
+ wrap: true,
147
+ clickOpens: false,
148
+ onChange: (selectedDates) => {
149
+ this.setEmptyFieldState(false);
150
+ this.setRangeConstraints(selectedDates);
151
+ this.setTimeConstraints(selectedDates);
152
+ this.updateLabelValues(selectedDates);
153
+ this.writeValue(selectedDates);
154
+ },
155
+ onClose: (selectedDates) => {
156
+ this.handleSingleSelectedValueInRange(selectedDates);
157
+ this.setEmptyFieldStateIfNeed();
158
+ this.resetConstraints();
159
+ this.setOpenedState(false);
160
+ this.closePicker.emit(selectedDates);
161
+ },
162
+ onOpen: () => {
163
+ this.setOpenedState(true);
164
+ this.resetTimeAfterOpen();
165
+ this.updateLabelValues(this.flatpickr.selectedDates);
166
+ this.onTouched();
167
+ },
168
+ ...(!this.appendToBody && { appendTo: this.elementRef.nativeElement }),
169
+ };
170
+ }
171
+ getConfig() {
172
+ return {
173
+ ...this.getDefaultFlatpickrOptions(),
174
+ ...(this.config || {}),
175
+ };
176
+ }
177
+ /**
178
+ * Customization of the flatpickr's view to ui-kit state
179
+ */
180
+ customizePicker() {
181
+ this.changeNextIcon();
182
+ this.addDescriptionIfNeed();
183
+ this.addTimeSelectors();
184
+ }
185
+ /**
186
+ * Sets new state of the picker openness
187
+ * @param state new state
188
+ */
189
+ setOpenedState(state) {
190
+ this.uiState.isOpen = state;
191
+ }
192
+ setEmptyFieldState(state) {
193
+ this.uiState.isEmptyField = state;
194
+ }
195
+ addTimeSelectors() {
196
+ if (this.isRangeWithTime()) {
197
+ const timeWrapper = document.createElement('div');
198
+ timeWrapper.innerHTML = renderRangeTime(cssClasses);
199
+ this.saveTimeRangeElements(timeWrapper);
200
+ this.addListenersOnTimeSelectors();
201
+ this.elements.apply.onclick = this.onApply.bind(this);
202
+ this.flatpickr.rContainer.appendChild(timeWrapper);
203
+ }
204
+ }
205
+ saveTimeRangeElements(timeWrapper) {
206
+ this.elements = {
207
+ apply: timeWrapper.getElementsByClassName(cssClasses.APPLY)[0],
208
+ from: {
209
+ hour: timeWrapper.getElementsByClassName(cssClasses.SELECTOR_HOUR)[0],
210
+ minute: timeWrapper.getElementsByClassName(cssClasses.SELECTOR_MINUTE)[0],
211
+ label: timeWrapper.getElementsByClassName(cssClasses.TIME_LABEL_FROM)[0],
212
+ },
213
+ until: {
214
+ hour: timeWrapper.getElementsByClassName(cssClasses.SELECTOR_HOUR)[1],
215
+ minute: timeWrapper.getElementsByClassName(cssClasses.SELECTOR_MINUTE)[1],
216
+ label: timeWrapper.getElementsByClassName(cssClasses.TIME_LABEL_UNTIL)[0],
217
+ }
218
+ };
219
+ this.elements.from.hourField = this.elements.from.hour.previousElementSibling;
220
+ this.elements.from.minuteField = this.elements.from.minute.previousElementSibling;
221
+ this.elements.until.hourField = this.elements.until.hour.previousElementSibling;
222
+ this.elements.until.minuteField = this.elements.until.minute.previousElementSibling;
223
+ }
224
+ onApply() {
225
+ this.setTime();
226
+ this.flatpickr.close();
227
+ }
228
+ setTime() {
229
+ const { fromHour, fromMinute } = this.getSelectedFrom();
230
+ const { untilHour, untilMinute } = this.getSelectedUntil();
231
+ const selectedDates = cloneDeep(this.flatpickr.selectedDates);
232
+ selectedDates[0].setHours(fromHour, fromMinute);
233
+ if (selectedDates[1]) {
234
+ selectedDates[1].setHours(untilHour, untilMinute);
235
+ }
236
+ this.setDateFromInput(selectedDates);
237
+ }
238
+ updateLabelValues(selectedDates) {
239
+ if (!selectedDates || !selectedDates[0] || !selectedDates[1]) {
240
+ return;
241
+ }
242
+ if (this.isRangeWithTime()) {
243
+ this.elements.from.label.innerText = `Период с ${this.flatpickr.formatDate(selectedDates[0], 'D d.m.Y')}`;
244
+ if (selectedDates[1]) {
245
+ this.elements.until.label.innerText = `по ${this.flatpickr.formatDate(selectedDates[1], 'D d.m.Y')}`;
246
+ }
247
+ }
248
+ }
249
+ setTimeConstraints(selectedDates) {
250
+ if (this.isRangeWithTime()) {
251
+ if (this.isSameDate(selectedDates[0], selectedDates[1])) {
252
+ this.resetTimeIfNeed();
253
+ this.setUntilTimeConstraint(selectedDates);
254
+ }
255
+ else {
256
+ this.resetAllConstraints();
257
+ }
258
+ }
259
+ }
260
+ resetAllConstraints() {
261
+ Array.from(this.elements.from.hour.options).forEach((option) => {
262
+ option.disabled = false;
263
+ });
264
+ Array.from(this.elements.from.minute.options).forEach((option) => {
265
+ option.disabled = false;
266
+ });
267
+ Array.from(this.elements.until.hour.options).forEach((option) => {
268
+ option.disabled = false;
269
+ });
270
+ Array.from(this.elements.until.minute.options).forEach((option) => {
271
+ option.disabled = false;
272
+ });
273
+ }
274
+ addListenersOnTimeSelectors() {
275
+ this.elements.from.hour.onchange = this.onChangeTimeFrom.bind(this);
276
+ this.elements.from.minute.onchange = this.onChangeTimeFrom.bind(this);
277
+ this.elements.until.hour.onchange = this.onChangeTimeUntil.bind(this);
278
+ this.elements.until.minute.onchange = this.onChangeTimeUntil.bind(this);
279
+ }
280
+ onChangeTimeFrom(event) {
281
+ if (this.isSameDate(this.flatpickr.selectedDates[0], this.flatpickr.selectedDates[1])) {
282
+ this.disableTimeUntilSelectors();
283
+ }
284
+ this.updateTimeFieldsContent();
285
+ }
286
+ handleSingleSelectedValueInRange(selectedDates) {
287
+ if (this.isRange() && !selectedDates[1]) {
288
+ const untilDate = new Date(selectedDates[0]);
289
+ untilDate.setHours(23, 59, 0, 0);
290
+ const updatedDates = [selectedDates[0], untilDate];
291
+ this.writeValue(updatedDates);
292
+ }
293
+ }
294
+ onChangeTimeUntil(event) {
295
+ if (this.isSameDate(this.flatpickr.selectedDates[0], this.flatpickr.selectedDates[1])) {
296
+ this.disableTimeFromSelectors();
297
+ }
298
+ this.updateTimeFieldsContent();
299
+ }
300
+ updateTimeFieldsContent() {
301
+ const { fromHour, fromMinute, untilHour, untilMinute } = this.getSelectorVaulesAsString();
302
+ this.elements.from.hourField.innerText = fromHour;
303
+ this.elements.from.minuteField.innerText = fromMinute;
304
+ this.elements.until.hourField.innerText = untilHour;
305
+ this.elements.until.minuteField.innerText = untilMinute;
306
+ }
307
+ disableTimeUntilSelectors() {
308
+ const { fromHour, fromMinute } = this.getSelectedFrom();
309
+ const { untilHour, untilMinute } = this.getSelectedUntil();
310
+ Array.from(this.elements.until.hour.options).forEach((option) => {
311
+ option.disabled = Number(option.value) < fromHour;
312
+ });
313
+ if (fromHour === untilHour) {
314
+ if (fromMinute > untilMinute) {
315
+ this.elements.until.minute.selectedIndex = 4;
316
+ Array.from(this.elements.from.minute.options).forEach((option) => {
317
+ option.disabled = false;
318
+ });
319
+ }
320
+ Array.from(this.elements.until.minute.options).forEach((option) => {
321
+ option.disabled = Number(option.value) < fromMinute;
322
+ });
323
+ }
324
+ else {
325
+ Array.from(this.elements.from.minute.options).forEach((option) => {
326
+ option.disabled = false;
327
+ });
328
+ Array.from(this.elements.until.minute.options).forEach((option) => {
329
+ option.disabled = false;
330
+ });
331
+ }
332
+ }
333
+ disableTimeFromSelectors() {
334
+ const { fromHour, fromMinute } = this.getSelectedFrom();
335
+ const { untilHour, untilMinute } = this.getSelectedUntil();
336
+ Array.from(this.elements.from.hour.options).forEach((option) => {
337
+ option.disabled = Number(option.value) > untilHour;
338
+ });
339
+ if (fromHour === untilHour) {
340
+ if (fromMinute > untilMinute) {
341
+ this.elements.until.minute.selectedIndex = 4;
342
+ }
343
+ const { untilMinute: untilMinuteAfterUpdate } = this.getSelectedUntil();
344
+ Array.from(this.elements.from.minute.options).forEach((option) => {
345
+ option.disabled = Number(option.value) > untilMinuteAfterUpdate;
346
+ });
347
+ Array.from(this.elements.until.minute.options).forEach((option) => {
348
+ option.disabled = Number(option.value) < fromMinute;
349
+ });
350
+ }
351
+ else {
352
+ Array.from(this.elements.from.minute.options).forEach((option) => {
353
+ option.disabled = false;
354
+ });
355
+ Array.from(this.elements.until.minute.options).forEach((option) => {
356
+ option.disabled = false;
357
+ });
358
+ }
359
+ }
360
+ setUntilTimeConstraint(selectedDates) {
361
+ this.disableTimeUntilSelectors();
362
+ }
363
+ resetTimeIfNeed() {
364
+ const { fromHour, fromMinute } = this.getSelectedFrom();
365
+ const { untilHour, untilMinute } = this.getSelectedUntil();
366
+ if ((fromHour > untilHour) || (fromHour === untilHour && fromMinute > untilMinute)) {
367
+ this.resetTime();
368
+ }
369
+ }
370
+ resetTime() {
371
+ this.elements.from.hour.selectedIndex = 0;
372
+ this.elements.from.minute.selectedIndex = 0;
373
+ this.elements.until.hour.selectedIndex = 23;
374
+ this.elements.until.minute.selectedIndex = 4;
375
+ this.updateTimeFieldsContent();
376
+ }
377
+ getSelectorVaulesAsString() {
378
+ return {
379
+ fromHour: this.elements.from.hour.options[this.elements.from.hour.selectedIndex].value,
380
+ fromMinute: this.elements.from.minute.options[this.elements.from.minute.selectedIndex].value,
381
+ untilHour: this.elements.until.hour.options[this.elements.until.hour.selectedIndex].value,
382
+ untilMinute: this.elements.until.minute.options[this.elements.until.minute.selectedIndex].value,
383
+ };
384
+ }
385
+ getSelectedFrom() {
386
+ return {
387
+ fromHour: Number(this.elements.from.hour.options[this.elements.from.hour.selectedIndex].value),
388
+ fromMinute: Number(this.elements.from.minute.options[this.elements.from.minute.selectedIndex].value),
389
+ };
390
+ }
391
+ getSelectedUntil() {
392
+ return {
393
+ untilHour: Number(this.elements.until.hour.options[this.elements.until.hour.selectedIndex].value),
394
+ untilMinute: Number(this.elements.until.minute.options[this.elements.until.minute.selectedIndex].value),
395
+ };
396
+ }
397
+ setRangeConstraints(selectedDates) {
398
+ if (this.isRange() && this.maxRangeDays) {
399
+ if (selectedDates.length === 1) {
400
+ const minDate = new Date(selectedDates[0]);
401
+ const maxDate = new Date(selectedDates[0]);
402
+ minDate.setDate(minDate.getDate() - this.maxRangeDays);
403
+ maxDate.setDate(maxDate.getDate() + this.maxRangeDays);
404
+ this.flatpickr.config.minDate = minDate;
405
+ this.flatpickr.config.maxDate = maxDate;
406
+ }
407
+ else {
408
+ this.resetConstraints();
409
+ }
410
+ }
411
+ }
412
+ resetConstraints() {
413
+ this.flatpickr.config.minDate = this.config.minDate;
414
+ this.flatpickr.config.maxDate = this.config.maxDate;
415
+ }
416
+ isRangeWithTime() {
417
+ return this.isRange() && this.config.enableTime;
418
+ }
419
+ setEmptyFieldStateIfNeed() {
420
+ if (this.isRange() && this.flatpickr.selectedDates.length !== 2) {
421
+ this.setEmptyFieldState(true);
422
+ }
423
+ }
424
+ updatePickerIfNeed(value) {
425
+ if (this.flatpickr) {
426
+ const selectedDates = this.getSelectedDatesWithDatePickerFormat(this.flatpickr.selectedDates);
427
+ const values = this.getSelectedDatesWithDatePickerFormat(value);
428
+ if (!isEqual(values, selectedDates)) {
429
+ this.setDateFromInput(value);
430
+ }
431
+ }
432
+ }
433
+ getSelectedDatesWithDatePickerFormat(dateRange) {
434
+ if (dateRange && dateRange.length && typeof (dateRange[0]) !== 'string') {
435
+ return dateRange.map((date) => this.toDatePickerFormat(date));
436
+ }
437
+ return dateRange;
438
+ }
439
+ toDatePickerFormat(date) {
440
+ if (!date) {
441
+ return '';
442
+ }
443
+ return `${date.getDate()}.${date.getMonth() + 1}.${date.getFullYear()}`;
444
+ }
445
+ /**
446
+ * Substitution of icons
447
+ */
448
+ changeNextIcon() {
449
+ const Icons = {
450
+ PREV: `
451
+ <svg height="16" viewBox="0 0 6 16" width="6" xmlns="http://www.w3.org/2000/svg">
452
+ <path _ngcontent-c0="" d="M6 0L0 8L6 16V0Z" fill="white" transform="translate(6 16) rotate(180)"></path>
453
+ </svg>`,
454
+ NEXT: `
455
+ <svg height="16" viewBox="0 0 6 16" width="6" xmlns="http://www.w3.org/2000/svg">
456
+ <path _ngcontent-c0="" d="M6 0L0 8L6 16V0Z" fill="white"></path>
457
+ </svg>`,
458
+ };
459
+ this.flatpickr.nextMonthNav.innerHTML = Icons.PREV;
460
+ this.flatpickr.prevMonthNav.innerHTML = Icons.NEXT;
461
+ }
462
+ addDescriptionIfNeed() {
463
+ if (this.description) {
464
+ const descriptionElement = document.createElement('p');
465
+ descriptionElement.className = cssClasses.DESCRIPTION;
466
+ descriptionElement.innerHTML = this.description;
467
+ this.flatpickr.rContainer.appendChild(descriptionElement);
468
+ }
469
+ }
470
+ isSameDate(firstDate, secondDate) {
471
+ return firstDate && secondDate && firstDate.getDate() === secondDate.getDate() &&
472
+ firstDate.getMonth() === secondDate.getMonth() &&
473
+ firstDate.getFullYear() === secondDate.getFullYear();
474
+ }
475
+ getSelectedIndexByMinutes(minutes) {
476
+ return Math.round(minutes / 5) * 5 / 15;
477
+ }
478
+ resetTimeAfterOpen() {
479
+ if (this.isRangeWithTime()) {
480
+ const selectedDates = this.flatpickr.selectedDates;
481
+ if (selectedDates[0] && selectedDates[1]) {
482
+ this.elements.from.hour.selectedIndex = selectedDates[0].getHours();
483
+ this.elements.from.minute.selectedIndex = this.getSelectedIndexByMinutes(selectedDates[0].getMinutes());
484
+ this.elements.until.hour.selectedIndex = selectedDates[1].getHours();
485
+ this.elements.until.minute.selectedIndex = this.getSelectedIndexByMinutes(selectedDates[1].getMinutes());
486
+ this.addConstraintsAfterOpen(selectedDates);
487
+ this.updateTimeFieldsContent();
488
+ }
489
+ }
490
+ }
491
+ addConstraintsAfterOpen(selectedDates) {
492
+ if (this.isSameDate(selectedDates[0], selectedDates[1])) {
493
+ const { fromHour, fromMinute } = this.getSelectedFrom();
494
+ const { untilHour, untilMinute } = this.getSelectedUntil();
495
+ Array.from(this.elements.from.hour.options).forEach((option) => {
496
+ option.disabled = Number(option.value) > untilHour;
497
+ });
498
+ Array.from(this.elements.until.hour.options).forEach((option) => {
499
+ option.disabled = Number(option.value) < fromHour;
500
+ });
501
+ if (fromHour === untilHour) {
502
+ Array.from(this.elements.from.minute.options).forEach((option) => {
503
+ option.disabled = Number(option.value) > untilMinute;
504
+ });
505
+ Array.from(this.elements.until.minute.options).forEach((option) => {
506
+ option.disabled = Number(option.value) < fromMinute;
507
+ });
508
+ }
509
+ else {
510
+ Array.from(this.elements.from.minute.options).forEach((option) => {
511
+ option.disabled = false;
512
+ });
513
+ Array.from(this.elements.until.minute.options).forEach((option) => {
514
+ option.disabled = false;
515
+ });
516
+ }
517
+ }
518
+ }
519
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EvoDatepickerComponent, deps: [{ token: i0.NgZone }, { token: i0.ElementRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
520
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EvoDatepickerComponent, selector: "evo-datepicker", inputs: { config: "config", maskedInput: "maskedInput", theme: "theme", folded: "folded", placeholder: "placeholder", setDate: "setDate", description: "description", maxRangeDays: "maxRangeDays", appendToBody: "appendToBody" }, outputs: { closePicker: "closePicker" }, providers: [
521
+ {
522
+ provide: NG_VALUE_ACCESSOR,
523
+ useExisting: forwardRef(() => EvoDatepickerComponent),
524
+ multi: true,
525
+ },
526
+ ], viewQueries: [{ propertyName: "flatpickrElement", first: true, predicate: ["flatpickr"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #flatpickr class=\"evo-datepicker\" [evoUiClass]=\"totalClasses\" (click)=\"onDatepickerClick($event)\">\n <input\n #input\n type=\"text\"\n data-input\n class=\"evo-datepicker__input\"\n [evoUiClass]=\"inputClass\"\n [imask]=\"maskConfig\"\n [placeholder]=\"placeholder\"\n [readonly]=\"disabled\"\n (complete)=\"handleMaskComplete($event)\"\n />\n\n <span *ngIf=\"isRange() && input.value\" class=\"evo-datepicker__value\">{{input.value}}</span>\n\n <span *ngIf=\"shouldShowEmptyText()\" class=\"evo-datepicker__empty-text\">{{isRange() ? '\u0417\u0430 \u043F\u0435\u0440\u0438\u043E\u0434': '\u0414\u0430\u0442\u0430'}}</span>\n\n <span *ngIf=\"!disabled\" class=\"evo-datepicker__opener\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M20 3H19V2C19 1.45 18.55 1 18 1C17.45 1 17 1.45 17 2V3H7V2C7 1.45 6.55 1 6 1C5.45 1 5 1.45 5 2V3H4C2.9 3 2 3.9 2 5V21C2 22.1 2.9 23 4 23H20C21.1 23 22 22.1 22 21V5C22 3.9 21.1 3 20 3ZM19 21H5C4.45 21 4 20.55 4 20V8H20V20C20 20.55 19.55 21 19 21Z\"\n />\n </svg>\n </span>\n <span *ngIf=\"!uiState.isEmptyField\" class=\"evo-datepicker__opener-triangle\"></span>\n</div>\n\n<evo-control-error *ngIf=\"showErrors\" [errors]=\"control.errors\" [errorsMessages]=\"errorsMessages\"></evo-control-error>\n", styles: ["@keyframes evo-fx-blink{50%{transform:scale(1);opacity:1}to{opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes gradient{0%{background-position:0 50%}50%{background-position:50vw 50%}to{background-position:100vw 50%}}:host{display:inline-block;--evo-input-prefix-content-margin: 0 12px}.evo-input{position:relative;cursor:text;--evo-input-height: 48px;--evo-input-border-radius: 4px;--evo-input-font-size: 16px;display:flex;align-items:center;height:var(--evo-input-height);color:#212121;font-weight:400;font-size:var(--evo-input-font-size);font-family:var(--evo-font);white-space:nowrap;background-color:#fff;border:1px solid #C6C6C6;border-radius:var(--evo-input-border-radius);outline:none;transition:color .3s,box-shadow .3s,background .3s,border .3s}.evo-input_focused{border:solid 1px #74706F}.evo-input_disabled{color:#b0b0b0!important;background-color:#f9fafb!important;border:1px solid #E3E3E3!important;cursor:default;pointer-events:none}.evo-input_invalid{border-color:#ff1817!important}.evo-input_theme-rounded:not(.evo-input_size-small){border-radius:256px}.evo-input_theme-rounded:not(.evo-input_size-small) .evo-input__field{border-radius:256px}.evo-input_size-small{height:32px}.evo-input_size-small .evo-input__field{padding:0 8px}.evo-input_size-small .evo-input__tooltip,.evo-input_size-small .evo-input__loading-spinner{flex:0 0 16px;width:16px;height:16px;margin:0 10px}.evo-input_size-small .evo-input__icon{margin-right:10px}.evo-input_size-small .evo-input__icon img{max-height:16px}.evo-input_size-small .evo-input__tooltip-container{top:100%}.evo-input_size-small .evo-input__tooltip-container:before{left:calc(100% - 28px)}@media (min-width: 1200px){.evo-input_size-small .evo-input__tooltip-container{top:calc(100% + 4px)}.evo-input_size-small .evo-input__tooltip-container:before{left:calc(50% - 6px)}}.evo-input_size-small .evo-input__prefix-icon{width:16px;height:16px}.evo-input_size-small .evo-input__prefix-icon:empty{display:none}.evo-input_size-small .evo-input__icon-clear{width:16px;height:16px}.evo-input__prefix-icon{display:flex;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-left:12px;fill:#91b1b8}.evo-input__prefix-icon:empty{display:none}.evo-input__prefix-content{display:inline-flex;flex-shrink:0;justify-content:center;align-items:center;margin:var(--evo-input-prefix-content-margin)}.evo-input__prefix-content:empty{display:none}.evo-input__prefix-content:not(:empty)~.evo-input__field{padding-left:0;border-top-left-radius:0;border-bottom-left-radius:0}.evo-input__field{flex-grow:1;width:100%;height:100%;margin:0;padding:0 8px 0 16px;color:inherit;font-weight:inherit;font-size:inherit;border:none;border-radius:4px;outline:none}.evo-input__field::-webkit-input-placeholder{color:#9b9b9b}.evo-input__field::-moz-placeholder{color:#9b9b9b;opacity:1}.evo-input__field:-ms-input-placeholder{color:#9b9b9b}.evo-input__field:disabled{color:#b0b0b0;background-color:#f9fafb!important}.evo-input__field:not(:last-child){padding-right:0}.evo-input__prefix{padding-left:20px;font-size:16px;transition:color .2s}.evo-input__prefix_focused{color:#000}.evo-input__prefix:not(:empty)~.evo-input__field{padding-left:0}.evo-input__tooltip,.evo-input__icon-clear{width:24px;height:24px;margin:0 10px;cursor:pointer;-webkit-user-select:none;user-select:none;fill:#91b1b8}.evo-input__icon{margin:0 20px 0 10px}.evo-input__icon img{display:block;width:100%;max-width:60px;height:auto;max-height:22px}.evo-input__tooltip-container{position:absolute;top:calc(100% - 2px);left:0;z-index:1;display:flex;width:100%;padding:10px 10px 10px 20px;color:#212121;line-height:normal;white-space:normal;background-color:#fff8e6;border-radius:4px;box-shadow:0 4px 12px #0003;cursor:default}.evo-input__tooltip-container[hidden]{display:none!important}.evo-input__tooltip-container:before{position:absolute;top:-20px;left:calc(100% - 34px);border:10px solid transparent;border-bottom:10px solid #FFF8E6;pointer-events:none;content:\"\"}@media (min-width: 1200px){.evo-input__tooltip-container{left:calc(50% - 22px)}.evo-input__tooltip-container:before{left:calc(50% - 12px)}}.evo-input__clearable{display:flex;justify-content:center;align-items:center}.evo-input__clearable+.evo-input__additional{margin-left:-10px}.evo-input__additional{display:flex;justify-content:center;align-items:center}.evo-input__additional:not(:last-child) .evo-input__icon{margin-right:10px}.evo-input__additional+.evo-input__loading-spinner{margin-left:0}.evo-input__loading-spinner{margin:0 20px;flex:0 0 16px;width:16px;height:16px;border:2px solid #C6C6C6;border-top-color:#21c68b;border-radius:50%;animation:spin .8s linear infinite}evo-datepicker{--evo-datepicker-icon-color: #212121;--evo-datepicker-range-icon-color: #212121;--evo-datepicker-range-value-white-space: nowrap}.evo-datepicker{position:relative;display:flex;flex-direction:row;flex:1 1 auto}.evo-datepicker__opener{position:absolute;top:50%;right:20px;z-index:1;margin-top:-12px;pointer-events:none}.evo-datepicker__opener svg{fill:var(--evo-datepicker-icon-color)}.evo-datepicker__input_focused{border:solid 1px #74706F}.evo-datepicker__input_disabled{color:#b0b0b0!important;background-color:#f9fafb!important;border:1px solid #E3E3E3!important;cursor:default;pointer-events:none}.evo-datepicker__input_invalid{border-color:#ff1817!important}.evo-datepicker__input_hidden{position:absolute;visibility:hidden}.evo-datepicker__opener-triangle{display:none}.evo-datepicker__description{margin-top:16px;color:#727272;text-align:center}.evo-datepicker__time-picker{margin-top:24px;text-align:left}.evo-datepicker__time-picker:last-of-type{margin-top:8px}.evo-datepicker__time-label{display:block;padding-left:25px;color:#727272}.evo-datepicker__select-wrapper{position:relative;display:flex;align-items:center}.evo-datepicker__select-wrapper:after{position:absolute;right:20px;width:8px;height:12px;background:url(\"data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 width%3D%2224%22 height%3D%2224%22 viewBox%3D%220 0 24 24%22 fill%3D%22none%22%3E %3Cmask id%3D%22mask0%22 mask-type%3D%22alpha%22 maskUnits%3D%22userSpaceOnUse%22 x%3D%228%22 y%3D%2210%22 width%3D%228%22 height%3D%225%22%3E %3Cpath d%3D%22M8.81066 10C8.14248 10 7.80786 10.8079 8.28033 11.2803L11.4697 14.4697C11.7626 14.7626 12.2374 14.7626 12.5303 14.4697L15.7197 11.2803C16.1921 10.8079 15.8575 10 15.1893 10H8.81066Z%22 fill%3D%22black%22%2F%3E %3C%2Fmask%3E %3Cg mask%3D%22url(%23mask0)%22%3E %3Crect width%3D%2224%22 height%3D%2224%22 fill%3D%22%23212121%22%2F%3E %3C%2Fg%3E%3C%2Fsvg%3E\");background-repeat:no-repeat;background-position:center;pointer-events:none;content:\"\"}.evo-datepicker__select-wrapper:first-child{margin-right:8px}.evo-datepicker__select-wrapper:last-child{margin-left:8px}.evo-datepicker__select-field{display:inline-block;align-items:center;height:48px;padding:12px 38px 12px 16px;overflow:hidden;color:#9b9b9b;font-weight:400;font-size:16px;line-height:26px;white-space:nowrap;text-overflow:ellipsis;background-color:#fff;border:1px solid #C6C6C6;border-radius:4px;outline:0}.evo-datepicker__selectors{display:flex;justify-content:center;align-items:center;margin-top:8px;color:#9b9b9b}.evo-datepicker__select{position:absolute;top:0;left:0;z-index:10;display:block;width:100%;height:100%;cursor:pointer;opacity:0;appearance:none}.evo-datepicker__empty-text{display:inline-block;margin-right:8px;font-weight:600;line-height:22px;cursor:pointer}.evo-datepicker__apply{width:100%;margin-top:24px;padding:6px 0;color:#fff;font-family:var(--evo-font-secondary);text-transform:uppercase;background-color:#21c68b;border-radius:100px}.evo-datepicker__apply:hover{background-color:#4dd1a2}.evo-datepicker__apply:active,.evo-datepicker__apply:focus{background-color:#1eb27d}.evo-datepicker_opened .evo-datepicker__opener svg{fill:var(--evo-datepicker-icon-color)}.evo-datepicker_opened .evo-datepicker__input{color:#212121;border:solid 1px #74706F}.evo-datepicker_range{display:flex;flex-direction:row;gap:8px;align-items:center;position:relative}.evo-datepicker_range .evo-datepicker__input{position:absolute;visibility:hidden}.evo-datepicker_range .evo-datepicker__value,.evo-datepicker_range .evo-datepicker__empty-text{position:relative;display:flex;font-weight:600;line-height:22px;cursor:pointer;font-size:14px;border:none;order:2;flex:1 1;white-space:var(--evo-datepicker-range-value-white-space)}.evo-datepicker_range .evo-datepicker__opener{position:relative;display:flex;width:24px;height:24px;flex:0 0 24px;flex-shrink:0;top:auto;right:auto;margin:0;order:1;cursor:pointer;pointer-events:initial;color:var(--evo-datepicker-range-icon-color)}.evo-datepicker_range .evo-datepicker__opener svg{fill:currentColor}.evo-datepicker_range .evo-datepicker__opener-triangle{display:flex;position:relative;width:24px;height:24px;flex:0 0 24px;order:3;background:url(\"data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 width%3D%2224%22 height%3D%2224%22 viewBox%3D%220 0 24 24%22 fill%3D%22none%22%3E %3Cmask id%3D%22mask0%22 mask-type%3D%22alpha%22 maskUnits%3D%22userSpaceOnUse%22 x%3D%228%22 y%3D%2210%22 width%3D%228%22 height%3D%225%22%3E %3Cpath d%3D%22M8.81066 10C8.14248 10 7.80786 10.8079 8.28033 11.2803L11.4697 14.4697C11.7626 14.7626 12.2374 14.7626 12.5303 14.4697L15.7197 11.2803C16.1921 10.8079 15.8575 10 15.1893 10H8.81066Z%22 fill%3D%22black%22%2F%3E %3C%2Fmask%3E %3Cg mask%3D%22url(%23mask0)%22%3E %3Crect width%3D%2224%22 height%3D%2224%22 fill%3D%22%23212121%22%2F%3E %3C%2Fg%3E%3C%2Fsvg%3E\");cursor:pointer}.evo-datepicker_range.evo-datepicker_opened .evo-datepicker__input{border:none!important;box-shadow:none!important}.evo-datepicker_folded .flatpickr-input{visibility:hidden}.evo-datepicker_folded .evo-datepicker__opener-triangle{display:none}.flatpickr-calendar{position:absolute;display:none;box-sizing:border-box;width:264px;margin:auto;padding:0;overflow:hidden;font-size:14px;line-height:24px;direction:ltr;text-align:center;background:#fff;border:0;border-radius:5px;box-shadow:0 8px 10px #00000024,0 3px 14px #0000001f;visibility:hidden;opacity:0;animation:none;touch-action:manipulation}.flatpickr-calendar.open,.flatpickr-calendar.inline{max-height:640px;visibility:visible;opacity:1}.flatpickr-calendar.open{z-index:5;display:inline-block}.flatpickr-calendar.animate.open{animation:fpFadeInDown .3s cubic-bezier(.23,1,.32,1)}.flatpickr-calendar.inline{position:relative;top:2px;display:block}.flatpickr-calendar.static{position:absolute;top:calc(100% + 2px)}.flatpickr-calendar.static.open{z-index:999;display:block}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7){box-shadow:none!important}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1){box-shadow:-2px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-calendar .hasWeeks .dayContainer,.flatpickr-calendar .hasTime .dayContainer{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.flatpickr-calendar .hasWeeks .dayContainer{border-left:0}.flatpickr-calendar.showTimeInput.hasTime .flatpickr-time{height:40px;border-top:1px solid #e6e6e6}.flatpickr-calendar.noCalendar.hasTime .flatpickr-time{height:auto}.flatpickr-calendar:before,.flatpickr-calendar:after{position:absolute;left:22px;display:block;width:0;height:0;border:solid transparent;pointer-events:none;content:\"\"}.flatpickr-calendar.rightMost:before,.flatpickr-calendar.rightMost:after{right:22px;left:auto}.flatpickr-calendar:before{margin:0 -5px;border-width:5px}.flatpickr-calendar:after{margin:0 -4px;border-width:4px}.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after{bottom:100%;display:none}.flatpickr-calendar.arrowTop:before{border-bottom-color:#e6e6e6}.flatpickr-calendar.arrowTop:after{border-bottom-color:#fff}.flatpickr-calendar.arrowBottom:before,.flatpickr-calendar.arrowBottom:after{top:100%}.flatpickr-calendar.arrowBottom:before{border-top-color:#e6e6e6}.flatpickr-calendar.arrowBottom:after{border-top-color:#fff}.flatpickr-calendar:focus{outline:0}.flatpickr-wrapper{position:relative;display:inline-block}.flatpickr-months{display:flex;height:50px;padding:15px 30px;color:#fff;background:#f05023}.flatpickr-months .flatpickr-month{position:relative;flex:1;height:28px;overflow:hidden;color:#000000e6;line-height:1;text-align:center;background:transparent;-webkit-user-select:none;user-select:none;fill:#000000e6}.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{position:static;top:0;z-index:3;display:flex;align-items:center;width:25px;height:30px;margin-top:-5px;color:#fff;line-height:16px;text-decoration:none;cursor:pointer;fill:#fff}@media (min-width: 768px){.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{width:initial;height:initial;margin-top:initial}}.flatpickr-months .flatpickr-next-month{justify-content:flex-end}@media (min-width: 768px){.flatpickr-months .flatpickr-next-month{justify-content:initial}}.flatpickr-months .flatpickr-prev-month.flatpickr-disabled svg,.flatpickr-months .flatpickr-next-month.flatpickr-disabled svg{fill:#c6c6c6}.flatpickr-months .flatpickr-prev-month i,.flatpickr-months .flatpickr-next-month i{position:relative}.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,.flatpickr-months .flatpickr-next-month.flatpickr-prev-month{left:0}.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,.flatpickr-months .flatpickr-next-month.flatpickr-next-month{right:0}.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{width:14px;height:14px}.flatpickr-months .flatpickr-prev-month svg path,.flatpickr-months .flatpickr-next-month svg path{transition:fill .1s;fill:inherit}.numInputWrapper{position:relative;height:auto;font-size:16px;font-family:var(--evo-font-secondary)}.numInputWrapper input,.numInputWrapper span{display:inline-block}.numInputWrapper input{width:100%}.numInputWrapper input::-ms-clear{display:none}.numInputWrapper span{position:absolute;right:0;box-sizing:border-box;width:14px;height:50%;padding:0 4px 0 2px;line-height:50%;cursor:pointer;opacity:0}.numInputWrapper span:after{position:absolute;display:block;content:\"\"}.numInputWrapper span.arrowUp{top:0;display:none;border-bottom:0}.numInputWrapper span.arrowUp:after{top:26%;border-right:4px solid transparent;border-bottom:4px solid rgba(57,57,57,.6);border-left:4px solid transparent}.numInputWrapper span.arrowDown{top:50%;display:none}.numInputWrapper span.arrowDown:after{top:40%;border-top:4px solid rgba(57,57,57,.6);border-right:4px solid transparent;border-left:4px solid transparent}.numInputWrapper span svg{width:inherit;height:auto}.numInputWrapper span svg path{fill:#00000080}.numInputWrapper:hover span{opacity:1}.flatpickr-current-month{position:absolute;right:0;left:0;display:inline-block;width:auto;height:28px;margin:auto;padding:0;color:inherit;font-weight:300;font-size:135%;line-height:inherit;line-height:1;text-align:center;transform:translateZ(0)}.flatpickr-current-month span.cur-month{display:inline-block;padding:0;color:#fff;font-weight:700;font-size:16px;font-family:var(--evo-font-secondary)}.flatpickr-current-month .numInputWrapper{display:inline-block;width:50px}.flatpickr-current-month .numInputWrapper span.arrowUp:after{border-bottom-color:#fff}.flatpickr-current-month .numInputWrapper span.arrowDown:after{border-top-color:#fff}.flatpickr-current-month input.cur-year{display:inline-block;box-sizing:border-box;width:60px;height:auto;margin:0;padding:0 0 0 .5ch;color:inherit;color:#fff;font-weight:700;font-size:inherit;font-size:14px;font-family:inherit;line-height:inherit;vertical-align:initial;background:transparent;border:0;border-radius:0;cursor:text}.flatpickr-current-month input.cur-year:focus{outline:0}.flatpickr-current-month input.cur-year[disabled],.flatpickr-current-month input.cur-year[disabled]:hover{color:#c6c6c6;background:transparent;pointer-events:none}.flatpickr-weekdays{display:flex;align-items:center;width:100%;height:28px;overflow:hidden;text-align:center;background:transparent}.flatpickr-weekdays .flatpickr-weekdaycontainer{display:flex;flex:1}span.flatpickr-weekday{display:block;width:26px;margin:0 4px 0 0;color:#9b9b9b;font-weight:400;font-size:12px;line-height:1;text-align:center;background:transparent;cursor:default}span.flatpickr-weekday:nth-child(6),span.flatpickr-weekday:nth-child(7){color:#ff1817}.dayContainer,.flatpickr-weeks{padding:1px 0 0}.flatpickr-days{position:relative;display:flex;align-items:flex-start;width:100%;overflow:hidden}.flatpickr-days:focus{outline:0}.dayContainer{display:flex;flex-wrap:wrap;box-sizing:border-box;width:100%;padding:0;text-align:left;outline:0;transform:translateZ(0);opacity:1}.dayContainer+.dayContainer{box-shadow:-1px 0 #e6e6e6}.flatpickr-day{position:relative;display:inline-block;flex-basis:14.2857143%;justify-content:center;box-sizing:border-box;width:14.2857143%;max-width:26px;height:26px;margin:5px 4px 0 0;color:#212121;font-weight:400;font-size:12px;line-height:26px;text-align:center;background:none;border:1px solid transparent;border-radius:150px;cursor:pointer}.flatpickr-day.inRange,.flatpickr-day.prevMonthDay.inRange,.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.today.inRange,.flatpickr-day.prevMonthDay.today.inRange,.flatpickr-day.nextMonthDay.today.inRange,.flatpickr-day:hover,.flatpickr-day.prevMonthDay:hover,.flatpickr-day.nextMonthDay:hover,.flatpickr-day:focus,.flatpickr-day.prevMonthDay:focus,.flatpickr-day.nextMonthDay:focus{color:#fff;background:#f05023;border-color:#f05023;outline:0;cursor:pointer}.flatpickr-day.today{border-color:#91b1b8}.flatpickr-day.today:hover,.flatpickr-day.today:focus{color:#fff;background:#91b1b8;border-color:#91b1b8}.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange,.flatpickr-day.selected.inRange,.flatpickr-day.startRange.inRange,.flatpickr-day.endRange.inRange,.flatpickr-day.selected:focus,.flatpickr-day.startRange:focus,.flatpickr-day.endRange:focus,.flatpickr-day.selected:hover,.flatpickr-day.startRange:hover,.flatpickr-day.endRange:hover,.flatpickr-day.selected.prevMonthDay,.flatpickr-day.startRange.prevMonthDay,.flatpickr-day.endRange.prevMonthDay,.flatpickr-day.selected.nextMonthDay,.flatpickr-day.startRange.nextMonthDay,.flatpickr-day.endRange.nextMonthDay{color:#fff;background:#f05023;border-color:#f05023;box-shadow:none}.flatpickr-day.selected.startRange,.flatpickr-day.startRange.startRange,.flatpickr-day.endRange.startRange{border-radius:50px 0 0 50px}.flatpickr-day.selected.endRange,.flatpickr-day.startRange.endRange,.flatpickr-day.endRange.endRange{border-radius:0 50px 50px 0}.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)){box-shadow:-10px 0 #569ff7}.flatpickr-day.selected.startRange.endRange,.flatpickr-day.startRange.startRange.endRange,.flatpickr-day.endRange.startRange.endRange{border-radius:50px}.flatpickr-day.inRange{border-radius:0;box-shadow:-5px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay,.flatpickr-day.notAllowed,.flatpickr-day.notAllowed.prevMonthDay,.flatpickr-day.notAllowed.nextMonthDay{color:#c6c6c6;background:transparent;border-color:transparent;cursor:default}.flatpickr-day.week.selected{border-radius:0;box-shadow:-5px 0 #569ff7,5px 0 #569ff7}.flatpickr-day.hidden{visibility:hidden}.rangeMode .flatpickr-day{margin-top:8px;margin-right:4px}.flatpickr-weekwrapper{display:inline-block;float:left}.flatpickr-next-month.flatpickr-disabled,.flatpickr-prev-month.flatpickr-disabled{fill:#c6c6c6}.flatpickr-weekwrapper .flatpickr-weeks{padding:0 12px;box-shadow:1px 0 #e6e6e6}.flatpickr-weekwrapper .flatpickr-weekday{float:none;width:100%;line-height:28px}.flatpickr-weekwrapper span.flatpickr-day,.flatpickr-weekwrapper span.flatpickr-day:hover{display:block;width:100%;max-width:none;color:#3939394d;background:transparent;border:none;cursor:default}.flatpickr-innerContainer{display:block;display:flex;box-sizing:border-box;overflow:hidden}.flatpickr-rContainer{display:inline-block;box-sizing:border-box;max-width:264px;padding:15px 24px}.flatpickr-time{display:none;box-sizing:border-box;height:0;max-height:40px;overflow:hidden;line-height:40px;text-align:center;outline:0}.flatpickr-time:after{content:\"\";display:table;clear:both}.flatpickr-time .numInputWrapper{flex:1;float:left;width:40%;height:40px}.flatpickr-time .numInputWrapper span.arrowUp:after{border-bottom-color:#fff}.flatpickr-time .numInputWrapper span.arrowDown:after{border-top-color:#fff}.flatpickr-time.hasSeconds .numInputWrapper{width:26%}.flatpickr-time.time24hr .numInputWrapper{width:49%}.flatpickr-time input{position:relative;box-sizing:border-box;height:inherit;margin:0;padding:0;color:#212121;font-size:14px;line-height:inherit;text-align:center;background:transparent;border:0;border-radius:0;box-shadow:none}.flatpickr-time input.flatpickr-hour{font-weight:700}.flatpickr-time input.flatpickr-minute,.flatpickr-time input.flatpickr-second{font-weight:400}.flatpickr-time input:focus{border:0;outline:0}.flatpickr-time .flatpickr-time-separator,.flatpickr-time .flatpickr-am-pm{display:inline-block;align-self:center;float:left;width:2%;height:inherit;color:#212121;font-weight:700;line-height:inherit;-webkit-user-select:none;user-select:none}.flatpickr-time .flatpickr-am-pm{width:18%;font-weight:400;text-align:center;outline:0;cursor:pointer}.flatpickr-time input:hover,.flatpickr-time .flatpickr-am-pm:hover,.flatpickr-time input:focus,.flatpickr-time .flatpickr-am-pm:focus{background:#f3f3f3}.flatpickr-input{width:100%;padding:12px 20px;font-size:16px;font-family:var(--evo-font);line-height:20px;border:1px solid #C6C6C6;border-radius:4px;cursor:pointer}.flatpickr-input[readonly]{pointer-events:none}.flatpickr-day.inRange,.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.prevMonthDay.inRange{background-color:#f05023;border-color:#f05023;box-shadow:-5px 0 #f05023,5px 0 #f05023}.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)){box-shadow:-10px 0 #f05023}.flatpickr-current-month input.cur-year[disabled]{color:#fff}.flatpickr-day.startRange.startRange.endRange.endRange,.flatpickr-day.selected.endRange{box-shadow:none}.flatpickr-day.startRange.startRange{position:relative;z-index:1}.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.nextMonthDay.endRange{box-shadow:-10px 0 #f05023,5px 0 #f05023}.flatpickr-monthDropdown-months{max-width:100px;color:#fff;font-weight:700;font-size:16px;font-family:var(--evo-font-secondary);text-indent:1px;text-overflow:\"\";background-color:#f05023;border:none;-webkit-appearance:none;-moz-appearance:none;pointer-events:none}@keyframes fpFadeInDown{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.EvoUiClassDirective, selector: "[evoUiClass]", inputs: ["class", "evoUiClass"] }, { kind: "directive", type: i3.IMaskDirective, selector: "[imask]", inputs: ["imask", "unmask", "imaskElement"], outputs: ["accept", "complete"], exportAs: ["imask"] }, { kind: "component", type: i4.EvoControlErrorComponent, selector: "evo-control-error", inputs: ["errors", "errorsMessages", "showCount"] }], encapsulation: i0.ViewEncapsulation.None }); }
527
+ }
528
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EvoDatepickerComponent, decorators: [{
529
+ type: Component,
530
+ args: [{ selector: 'evo-datepicker', encapsulation: ViewEncapsulation.None, providers: [
531
+ {
532
+ provide: NG_VALUE_ACCESSOR,
533
+ useExisting: forwardRef(() => EvoDatepickerComponent),
534
+ multi: true,
535
+ },
536
+ ], template: "<div #flatpickr class=\"evo-datepicker\" [evoUiClass]=\"totalClasses\" (click)=\"onDatepickerClick($event)\">\n <input\n #input\n type=\"text\"\n data-input\n class=\"evo-datepicker__input\"\n [evoUiClass]=\"inputClass\"\n [imask]=\"maskConfig\"\n [placeholder]=\"placeholder\"\n [readonly]=\"disabled\"\n (complete)=\"handleMaskComplete($event)\"\n />\n\n <span *ngIf=\"isRange() && input.value\" class=\"evo-datepicker__value\">{{input.value}}</span>\n\n <span *ngIf=\"shouldShowEmptyText()\" class=\"evo-datepicker__empty-text\">{{isRange() ? '\u0417\u0430 \u043F\u0435\u0440\u0438\u043E\u0434': '\u0414\u0430\u0442\u0430'}}</span>\n\n <span *ngIf=\"!disabled\" class=\"evo-datepicker__opener\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M20 3H19V2C19 1.45 18.55 1 18 1C17.45 1 17 1.45 17 2V3H7V2C7 1.45 6.55 1 6 1C5.45 1 5 1.45 5 2V3H4C2.9 3 2 3.9 2 5V21C2 22.1 2.9 23 4 23H20C21.1 23 22 22.1 22 21V5C22 3.9 21.1 3 20 3ZM19 21H5C4.45 21 4 20.55 4 20V8H20V20C20 20.55 19.55 21 19 21Z\"\n />\n </svg>\n </span>\n <span *ngIf=\"!uiState.isEmptyField\" class=\"evo-datepicker__opener-triangle\"></span>\n</div>\n\n<evo-control-error *ngIf=\"showErrors\" [errors]=\"control.errors\" [errorsMessages]=\"errorsMessages\"></evo-control-error>\n", styles: ["@keyframes evo-fx-blink{50%{transform:scale(1);opacity:1}to{opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes gradient{0%{background-position:0 50%}50%{background-position:50vw 50%}to{background-position:100vw 50%}}:host{display:inline-block;--evo-input-prefix-content-margin: 0 12px}.evo-input{position:relative;cursor:text;--evo-input-height: 48px;--evo-input-border-radius: 4px;--evo-input-font-size: 16px;display:flex;align-items:center;height:var(--evo-input-height);color:#212121;font-weight:400;font-size:var(--evo-input-font-size);font-family:var(--evo-font);white-space:nowrap;background-color:#fff;border:1px solid #C6C6C6;border-radius:var(--evo-input-border-radius);outline:none;transition:color .3s,box-shadow .3s,background .3s,border .3s}.evo-input_focused{border:solid 1px #74706F}.evo-input_disabled{color:#b0b0b0!important;background-color:#f9fafb!important;border:1px solid #E3E3E3!important;cursor:default;pointer-events:none}.evo-input_invalid{border-color:#ff1817!important}.evo-input_theme-rounded:not(.evo-input_size-small){border-radius:256px}.evo-input_theme-rounded:not(.evo-input_size-small) .evo-input__field{border-radius:256px}.evo-input_size-small{height:32px}.evo-input_size-small .evo-input__field{padding:0 8px}.evo-input_size-small .evo-input__tooltip,.evo-input_size-small .evo-input__loading-spinner{flex:0 0 16px;width:16px;height:16px;margin:0 10px}.evo-input_size-small .evo-input__icon{margin-right:10px}.evo-input_size-small .evo-input__icon img{max-height:16px}.evo-input_size-small .evo-input__tooltip-container{top:100%}.evo-input_size-small .evo-input__tooltip-container:before{left:calc(100% - 28px)}@media (min-width: 1200px){.evo-input_size-small .evo-input__tooltip-container{top:calc(100% + 4px)}.evo-input_size-small .evo-input__tooltip-container:before{left:calc(50% - 6px)}}.evo-input_size-small .evo-input__prefix-icon{width:16px;height:16px}.evo-input_size-small .evo-input__prefix-icon:empty{display:none}.evo-input_size-small .evo-input__icon-clear{width:16px;height:16px}.evo-input__prefix-icon{display:flex;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-left:12px;fill:#91b1b8}.evo-input__prefix-icon:empty{display:none}.evo-input__prefix-content{display:inline-flex;flex-shrink:0;justify-content:center;align-items:center;margin:var(--evo-input-prefix-content-margin)}.evo-input__prefix-content:empty{display:none}.evo-input__prefix-content:not(:empty)~.evo-input__field{padding-left:0;border-top-left-radius:0;border-bottom-left-radius:0}.evo-input__field{flex-grow:1;width:100%;height:100%;margin:0;padding:0 8px 0 16px;color:inherit;font-weight:inherit;font-size:inherit;border:none;border-radius:4px;outline:none}.evo-input__field::-webkit-input-placeholder{color:#9b9b9b}.evo-input__field::-moz-placeholder{color:#9b9b9b;opacity:1}.evo-input__field:-ms-input-placeholder{color:#9b9b9b}.evo-input__field:disabled{color:#b0b0b0;background-color:#f9fafb!important}.evo-input__field:not(:last-child){padding-right:0}.evo-input__prefix{padding-left:20px;font-size:16px;transition:color .2s}.evo-input__prefix_focused{color:#000}.evo-input__prefix:not(:empty)~.evo-input__field{padding-left:0}.evo-input__tooltip,.evo-input__icon-clear{width:24px;height:24px;margin:0 10px;cursor:pointer;-webkit-user-select:none;user-select:none;fill:#91b1b8}.evo-input__icon{margin:0 20px 0 10px}.evo-input__icon img{display:block;width:100%;max-width:60px;height:auto;max-height:22px}.evo-input__tooltip-container{position:absolute;top:calc(100% - 2px);left:0;z-index:1;display:flex;width:100%;padding:10px 10px 10px 20px;color:#212121;line-height:normal;white-space:normal;background-color:#fff8e6;border-radius:4px;box-shadow:0 4px 12px #0003;cursor:default}.evo-input__tooltip-container[hidden]{display:none!important}.evo-input__tooltip-container:before{position:absolute;top:-20px;left:calc(100% - 34px);border:10px solid transparent;border-bottom:10px solid #FFF8E6;pointer-events:none;content:\"\"}@media (min-width: 1200px){.evo-input__tooltip-container{left:calc(50% - 22px)}.evo-input__tooltip-container:before{left:calc(50% - 12px)}}.evo-input__clearable{display:flex;justify-content:center;align-items:center}.evo-input__clearable+.evo-input__additional{margin-left:-10px}.evo-input__additional{display:flex;justify-content:center;align-items:center}.evo-input__additional:not(:last-child) .evo-input__icon{margin-right:10px}.evo-input__additional+.evo-input__loading-spinner{margin-left:0}.evo-input__loading-spinner{margin:0 20px;flex:0 0 16px;width:16px;height:16px;border:2px solid #C6C6C6;border-top-color:#21c68b;border-radius:50%;animation:spin .8s linear infinite}evo-datepicker{--evo-datepicker-icon-color: #212121;--evo-datepicker-range-icon-color: #212121;--evo-datepicker-range-value-white-space: nowrap}.evo-datepicker{position:relative;display:flex;flex-direction:row;flex:1 1 auto}.evo-datepicker__opener{position:absolute;top:50%;right:20px;z-index:1;margin-top:-12px;pointer-events:none}.evo-datepicker__opener svg{fill:var(--evo-datepicker-icon-color)}.evo-datepicker__input_focused{border:solid 1px #74706F}.evo-datepicker__input_disabled{color:#b0b0b0!important;background-color:#f9fafb!important;border:1px solid #E3E3E3!important;cursor:default;pointer-events:none}.evo-datepicker__input_invalid{border-color:#ff1817!important}.evo-datepicker__input_hidden{position:absolute;visibility:hidden}.evo-datepicker__opener-triangle{display:none}.evo-datepicker__description{margin-top:16px;color:#727272;text-align:center}.evo-datepicker__time-picker{margin-top:24px;text-align:left}.evo-datepicker__time-picker:last-of-type{margin-top:8px}.evo-datepicker__time-label{display:block;padding-left:25px;color:#727272}.evo-datepicker__select-wrapper{position:relative;display:flex;align-items:center}.evo-datepicker__select-wrapper:after{position:absolute;right:20px;width:8px;height:12px;background:url(\"data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 width%3D%2224%22 height%3D%2224%22 viewBox%3D%220 0 24 24%22 fill%3D%22none%22%3E %3Cmask id%3D%22mask0%22 mask-type%3D%22alpha%22 maskUnits%3D%22userSpaceOnUse%22 x%3D%228%22 y%3D%2210%22 width%3D%228%22 height%3D%225%22%3E %3Cpath d%3D%22M8.81066 10C8.14248 10 7.80786 10.8079 8.28033 11.2803L11.4697 14.4697C11.7626 14.7626 12.2374 14.7626 12.5303 14.4697L15.7197 11.2803C16.1921 10.8079 15.8575 10 15.1893 10H8.81066Z%22 fill%3D%22black%22%2F%3E %3C%2Fmask%3E %3Cg mask%3D%22url(%23mask0)%22%3E %3Crect width%3D%2224%22 height%3D%2224%22 fill%3D%22%23212121%22%2F%3E %3C%2Fg%3E%3C%2Fsvg%3E\");background-repeat:no-repeat;background-position:center;pointer-events:none;content:\"\"}.evo-datepicker__select-wrapper:first-child{margin-right:8px}.evo-datepicker__select-wrapper:last-child{margin-left:8px}.evo-datepicker__select-field{display:inline-block;align-items:center;height:48px;padding:12px 38px 12px 16px;overflow:hidden;color:#9b9b9b;font-weight:400;font-size:16px;line-height:26px;white-space:nowrap;text-overflow:ellipsis;background-color:#fff;border:1px solid #C6C6C6;border-radius:4px;outline:0}.evo-datepicker__selectors{display:flex;justify-content:center;align-items:center;margin-top:8px;color:#9b9b9b}.evo-datepicker__select{position:absolute;top:0;left:0;z-index:10;display:block;width:100%;height:100%;cursor:pointer;opacity:0;appearance:none}.evo-datepicker__empty-text{display:inline-block;margin-right:8px;font-weight:600;line-height:22px;cursor:pointer}.evo-datepicker__apply{width:100%;margin-top:24px;padding:6px 0;color:#fff;font-family:var(--evo-font-secondary);text-transform:uppercase;background-color:#21c68b;border-radius:100px}.evo-datepicker__apply:hover{background-color:#4dd1a2}.evo-datepicker__apply:active,.evo-datepicker__apply:focus{background-color:#1eb27d}.evo-datepicker_opened .evo-datepicker__opener svg{fill:var(--evo-datepicker-icon-color)}.evo-datepicker_opened .evo-datepicker__input{color:#212121;border:solid 1px #74706F}.evo-datepicker_range{display:flex;flex-direction:row;gap:8px;align-items:center;position:relative}.evo-datepicker_range .evo-datepicker__input{position:absolute;visibility:hidden}.evo-datepicker_range .evo-datepicker__value,.evo-datepicker_range .evo-datepicker__empty-text{position:relative;display:flex;font-weight:600;line-height:22px;cursor:pointer;font-size:14px;border:none;order:2;flex:1 1;white-space:var(--evo-datepicker-range-value-white-space)}.evo-datepicker_range .evo-datepicker__opener{position:relative;display:flex;width:24px;height:24px;flex:0 0 24px;flex-shrink:0;top:auto;right:auto;margin:0;order:1;cursor:pointer;pointer-events:initial;color:var(--evo-datepicker-range-icon-color)}.evo-datepicker_range .evo-datepicker__opener svg{fill:currentColor}.evo-datepicker_range .evo-datepicker__opener-triangle{display:flex;position:relative;width:24px;height:24px;flex:0 0 24px;order:3;background:url(\"data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 width%3D%2224%22 height%3D%2224%22 viewBox%3D%220 0 24 24%22 fill%3D%22none%22%3E %3Cmask id%3D%22mask0%22 mask-type%3D%22alpha%22 maskUnits%3D%22userSpaceOnUse%22 x%3D%228%22 y%3D%2210%22 width%3D%228%22 height%3D%225%22%3E %3Cpath d%3D%22M8.81066 10C8.14248 10 7.80786 10.8079 8.28033 11.2803L11.4697 14.4697C11.7626 14.7626 12.2374 14.7626 12.5303 14.4697L15.7197 11.2803C16.1921 10.8079 15.8575 10 15.1893 10H8.81066Z%22 fill%3D%22black%22%2F%3E %3C%2Fmask%3E %3Cg mask%3D%22url(%23mask0)%22%3E %3Crect width%3D%2224%22 height%3D%2224%22 fill%3D%22%23212121%22%2F%3E %3C%2Fg%3E%3C%2Fsvg%3E\");cursor:pointer}.evo-datepicker_range.evo-datepicker_opened .evo-datepicker__input{border:none!important;box-shadow:none!important}.evo-datepicker_folded .flatpickr-input{visibility:hidden}.evo-datepicker_folded .evo-datepicker__opener-triangle{display:none}.flatpickr-calendar{position:absolute;display:none;box-sizing:border-box;width:264px;margin:auto;padding:0;overflow:hidden;font-size:14px;line-height:24px;direction:ltr;text-align:center;background:#fff;border:0;border-radius:5px;box-shadow:0 8px 10px #00000024,0 3px 14px #0000001f;visibility:hidden;opacity:0;animation:none;touch-action:manipulation}.flatpickr-calendar.open,.flatpickr-calendar.inline{max-height:640px;visibility:visible;opacity:1}.flatpickr-calendar.open{z-index:5;display:inline-block}.flatpickr-calendar.animate.open{animation:fpFadeInDown .3s cubic-bezier(.23,1,.32,1)}.flatpickr-calendar.inline{position:relative;top:2px;display:block}.flatpickr-calendar.static{position:absolute;top:calc(100% + 2px)}.flatpickr-calendar.static.open{z-index:999;display:block}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7){box-shadow:none!important}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1){box-shadow:-2px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-calendar .hasWeeks .dayContainer,.flatpickr-calendar .hasTime .dayContainer{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.flatpickr-calendar .hasWeeks .dayContainer{border-left:0}.flatpickr-calendar.showTimeInput.hasTime .flatpickr-time{height:40px;border-top:1px solid #e6e6e6}.flatpickr-calendar.noCalendar.hasTime .flatpickr-time{height:auto}.flatpickr-calendar:before,.flatpickr-calendar:after{position:absolute;left:22px;display:block;width:0;height:0;border:solid transparent;pointer-events:none;content:\"\"}.flatpickr-calendar.rightMost:before,.flatpickr-calendar.rightMost:after{right:22px;left:auto}.flatpickr-calendar:before{margin:0 -5px;border-width:5px}.flatpickr-calendar:after{margin:0 -4px;border-width:4px}.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after{bottom:100%;display:none}.flatpickr-calendar.arrowTop:before{border-bottom-color:#e6e6e6}.flatpickr-calendar.arrowTop:after{border-bottom-color:#fff}.flatpickr-calendar.arrowBottom:before,.flatpickr-calendar.arrowBottom:after{top:100%}.flatpickr-calendar.arrowBottom:before{border-top-color:#e6e6e6}.flatpickr-calendar.arrowBottom:after{border-top-color:#fff}.flatpickr-calendar:focus{outline:0}.flatpickr-wrapper{position:relative;display:inline-block}.flatpickr-months{display:flex;height:50px;padding:15px 30px;color:#fff;background:#f05023}.flatpickr-months .flatpickr-month{position:relative;flex:1;height:28px;overflow:hidden;color:#000000e6;line-height:1;text-align:center;background:transparent;-webkit-user-select:none;user-select:none;fill:#000000e6}.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{position:static;top:0;z-index:3;display:flex;align-items:center;width:25px;height:30px;margin-top:-5px;color:#fff;line-height:16px;text-decoration:none;cursor:pointer;fill:#fff}@media (min-width: 768px){.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{width:initial;height:initial;margin-top:initial}}.flatpickr-months .flatpickr-next-month{justify-content:flex-end}@media (min-width: 768px){.flatpickr-months .flatpickr-next-month{justify-content:initial}}.flatpickr-months .flatpickr-prev-month.flatpickr-disabled svg,.flatpickr-months .flatpickr-next-month.flatpickr-disabled svg{fill:#c6c6c6}.flatpickr-months .flatpickr-prev-month i,.flatpickr-months .flatpickr-next-month i{position:relative}.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,.flatpickr-months .flatpickr-next-month.flatpickr-prev-month{left:0}.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,.flatpickr-months .flatpickr-next-month.flatpickr-next-month{right:0}.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{width:14px;height:14px}.flatpickr-months .flatpickr-prev-month svg path,.flatpickr-months .flatpickr-next-month svg path{transition:fill .1s;fill:inherit}.numInputWrapper{position:relative;height:auto;font-size:16px;font-family:var(--evo-font-secondary)}.numInputWrapper input,.numInputWrapper span{display:inline-block}.numInputWrapper input{width:100%}.numInputWrapper input::-ms-clear{display:none}.numInputWrapper span{position:absolute;right:0;box-sizing:border-box;width:14px;height:50%;padding:0 4px 0 2px;line-height:50%;cursor:pointer;opacity:0}.numInputWrapper span:after{position:absolute;display:block;content:\"\"}.numInputWrapper span.arrowUp{top:0;display:none;border-bottom:0}.numInputWrapper span.arrowUp:after{top:26%;border-right:4px solid transparent;border-bottom:4px solid rgba(57,57,57,.6);border-left:4px solid transparent}.numInputWrapper span.arrowDown{top:50%;display:none}.numInputWrapper span.arrowDown:after{top:40%;border-top:4px solid rgba(57,57,57,.6);border-right:4px solid transparent;border-left:4px solid transparent}.numInputWrapper span svg{width:inherit;height:auto}.numInputWrapper span svg path{fill:#00000080}.numInputWrapper:hover span{opacity:1}.flatpickr-current-month{position:absolute;right:0;left:0;display:inline-block;width:auto;height:28px;margin:auto;padding:0;color:inherit;font-weight:300;font-size:135%;line-height:inherit;line-height:1;text-align:center;transform:translateZ(0)}.flatpickr-current-month span.cur-month{display:inline-block;padding:0;color:#fff;font-weight:700;font-size:16px;font-family:var(--evo-font-secondary)}.flatpickr-current-month .numInputWrapper{display:inline-block;width:50px}.flatpickr-current-month .numInputWrapper span.arrowUp:after{border-bottom-color:#fff}.flatpickr-current-month .numInputWrapper span.arrowDown:after{border-top-color:#fff}.flatpickr-current-month input.cur-year{display:inline-block;box-sizing:border-box;width:60px;height:auto;margin:0;padding:0 0 0 .5ch;color:inherit;color:#fff;font-weight:700;font-size:inherit;font-size:14px;font-family:inherit;line-height:inherit;vertical-align:initial;background:transparent;border:0;border-radius:0;cursor:text}.flatpickr-current-month input.cur-year:focus{outline:0}.flatpickr-current-month input.cur-year[disabled],.flatpickr-current-month input.cur-year[disabled]:hover{color:#c6c6c6;background:transparent;pointer-events:none}.flatpickr-weekdays{display:flex;align-items:center;width:100%;height:28px;overflow:hidden;text-align:center;background:transparent}.flatpickr-weekdays .flatpickr-weekdaycontainer{display:flex;flex:1}span.flatpickr-weekday{display:block;width:26px;margin:0 4px 0 0;color:#9b9b9b;font-weight:400;font-size:12px;line-height:1;text-align:center;background:transparent;cursor:default}span.flatpickr-weekday:nth-child(6),span.flatpickr-weekday:nth-child(7){color:#ff1817}.dayContainer,.flatpickr-weeks{padding:1px 0 0}.flatpickr-days{position:relative;display:flex;align-items:flex-start;width:100%;overflow:hidden}.flatpickr-days:focus{outline:0}.dayContainer{display:flex;flex-wrap:wrap;box-sizing:border-box;width:100%;padding:0;text-align:left;outline:0;transform:translateZ(0);opacity:1}.dayContainer+.dayContainer{box-shadow:-1px 0 #e6e6e6}.flatpickr-day{position:relative;display:inline-block;flex-basis:14.2857143%;justify-content:center;box-sizing:border-box;width:14.2857143%;max-width:26px;height:26px;margin:5px 4px 0 0;color:#212121;font-weight:400;font-size:12px;line-height:26px;text-align:center;background:none;border:1px solid transparent;border-radius:150px;cursor:pointer}.flatpickr-day.inRange,.flatpickr-day.prevMonthDay.inRange,.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.today.inRange,.flatpickr-day.prevMonthDay.today.inRange,.flatpickr-day.nextMonthDay.today.inRange,.flatpickr-day:hover,.flatpickr-day.prevMonthDay:hover,.flatpickr-day.nextMonthDay:hover,.flatpickr-day:focus,.flatpickr-day.prevMonthDay:focus,.flatpickr-day.nextMonthDay:focus{color:#fff;background:#f05023;border-color:#f05023;outline:0;cursor:pointer}.flatpickr-day.today{border-color:#91b1b8}.flatpickr-day.today:hover,.flatpickr-day.today:focus{color:#fff;background:#91b1b8;border-color:#91b1b8}.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange,.flatpickr-day.selected.inRange,.flatpickr-day.startRange.inRange,.flatpickr-day.endRange.inRange,.flatpickr-day.selected:focus,.flatpickr-day.startRange:focus,.flatpickr-day.endRange:focus,.flatpickr-day.selected:hover,.flatpickr-day.startRange:hover,.flatpickr-day.endRange:hover,.flatpickr-day.selected.prevMonthDay,.flatpickr-day.startRange.prevMonthDay,.flatpickr-day.endRange.prevMonthDay,.flatpickr-day.selected.nextMonthDay,.flatpickr-day.startRange.nextMonthDay,.flatpickr-day.endRange.nextMonthDay{color:#fff;background:#f05023;border-color:#f05023;box-shadow:none}.flatpickr-day.selected.startRange,.flatpickr-day.startRange.startRange,.flatpickr-day.endRange.startRange{border-radius:50px 0 0 50px}.flatpickr-day.selected.endRange,.flatpickr-day.startRange.endRange,.flatpickr-day.endRange.endRange{border-radius:0 50px 50px 0}.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)){box-shadow:-10px 0 #569ff7}.flatpickr-day.selected.startRange.endRange,.flatpickr-day.startRange.startRange.endRange,.flatpickr-day.endRange.startRange.endRange{border-radius:50px}.flatpickr-day.inRange{border-radius:0;box-shadow:-5px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay,.flatpickr-day.notAllowed,.flatpickr-day.notAllowed.prevMonthDay,.flatpickr-day.notAllowed.nextMonthDay{color:#c6c6c6;background:transparent;border-color:transparent;cursor:default}.flatpickr-day.week.selected{border-radius:0;box-shadow:-5px 0 #569ff7,5px 0 #569ff7}.flatpickr-day.hidden{visibility:hidden}.rangeMode .flatpickr-day{margin-top:8px;margin-right:4px}.flatpickr-weekwrapper{display:inline-block;float:left}.flatpickr-next-month.flatpickr-disabled,.flatpickr-prev-month.flatpickr-disabled{fill:#c6c6c6}.flatpickr-weekwrapper .flatpickr-weeks{padding:0 12px;box-shadow:1px 0 #e6e6e6}.flatpickr-weekwrapper .flatpickr-weekday{float:none;width:100%;line-height:28px}.flatpickr-weekwrapper span.flatpickr-day,.flatpickr-weekwrapper span.flatpickr-day:hover{display:block;width:100%;max-width:none;color:#3939394d;background:transparent;border:none;cursor:default}.flatpickr-innerContainer{display:block;display:flex;box-sizing:border-box;overflow:hidden}.flatpickr-rContainer{display:inline-block;box-sizing:border-box;max-width:264px;padding:15px 24px}.flatpickr-time{display:none;box-sizing:border-box;height:0;max-height:40px;overflow:hidden;line-height:40px;text-align:center;outline:0}.flatpickr-time:after{content:\"\";display:table;clear:both}.flatpickr-time .numInputWrapper{flex:1;float:left;width:40%;height:40px}.flatpickr-time .numInputWrapper span.arrowUp:after{border-bottom-color:#fff}.flatpickr-time .numInputWrapper span.arrowDown:after{border-top-color:#fff}.flatpickr-time.hasSeconds .numInputWrapper{width:26%}.flatpickr-time.time24hr .numInputWrapper{width:49%}.flatpickr-time input{position:relative;box-sizing:border-box;height:inherit;margin:0;padding:0;color:#212121;font-size:14px;line-height:inherit;text-align:center;background:transparent;border:0;border-radius:0;box-shadow:none}.flatpickr-time input.flatpickr-hour{font-weight:700}.flatpickr-time input.flatpickr-minute,.flatpickr-time input.flatpickr-second{font-weight:400}.flatpickr-time input:focus{border:0;outline:0}.flatpickr-time .flatpickr-time-separator,.flatpickr-time .flatpickr-am-pm{display:inline-block;align-self:center;float:left;width:2%;height:inherit;color:#212121;font-weight:700;line-height:inherit;-webkit-user-select:none;user-select:none}.flatpickr-time .flatpickr-am-pm{width:18%;font-weight:400;text-align:center;outline:0;cursor:pointer}.flatpickr-time input:hover,.flatpickr-time .flatpickr-am-pm:hover,.flatpickr-time input:focus,.flatpickr-time .flatpickr-am-pm:focus{background:#f3f3f3}.flatpickr-input{width:100%;padding:12px 20px;font-size:16px;font-family:var(--evo-font);line-height:20px;border:1px solid #C6C6C6;border-radius:4px;cursor:pointer}.flatpickr-input[readonly]{pointer-events:none}.flatpickr-day.inRange,.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.prevMonthDay.inRange{background-color:#f05023;border-color:#f05023;box-shadow:-5px 0 #f05023,5px 0 #f05023}.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)){box-shadow:-10px 0 #f05023}.flatpickr-current-month input.cur-year[disabled]{color:#fff}.flatpickr-day.startRange.startRange.endRange.endRange,.flatpickr-day.selected.endRange{box-shadow:none}.flatpickr-day.startRange.startRange{position:relative;z-index:1}.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.nextMonthDay.endRange{box-shadow:-10px 0 #f05023,5px 0 #f05023}.flatpickr-monthDropdown-months{max-width:100px;color:#fff;font-weight:700;font-size:16px;font-family:var(--evo-font-secondary);text-indent:1px;text-overflow:\"\";background-color:#f05023;border:none;-webkit-appearance:none;-moz-appearance:none;pointer-events:none}@keyframes fpFadeInDown{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}\n"] }]
537
+ }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: i0.Injector }]; }, propDecorators: { flatpickrElement: [{
538
+ type: ViewChild,
539
+ args: ['flatpickr', { static: true }]
540
+ }], config: [{
541
+ type: Input
542
+ }], maskedInput: [{
543
+ type: Input
544
+ }], theme: [{
545
+ type: Input
546
+ }], folded: [{
547
+ type: Input
548
+ }], placeholder: [{
549
+ type: Input
550
+ }], setDate: [{
551
+ type: Input
552
+ }], description: [{
553
+ type: Input
554
+ }], maxRangeDays: [{
555
+ type: Input
556
+ }], appendToBody: [{
557
+ type: Input
558
+ }], closePicker: [{
559
+ type: Output
560
+ }] } });
561
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-datepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-datepicker/evo-datepicker.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-datepicker/evo-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Injector,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { FlatpickrOptions } from './flatpickr-options.interface';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { cssClasses, renderRangeTime } from './templates';\nimport { EvoBaseControl } from '../../common/evo-base-control';\nimport { EvoControlStates } from '../../common/evo-control-state-manager/evo-control-states.enum';\nimport flatpickr from 'flatpickr';\n\nexport * from './flatpickr-options.interface';\n\nenum DatepickerModes {\n    RANGE = 'range',\n}\n\ninterface Option {\n    disabled: boolean;\n    value: string;\n}\n\ntype SelectedDates = string[] | Date[];\n\n@Component({\n    selector: 'evo-datepicker',\n    templateUrl: './evo-datepicker.component.html',\n    styleUrls: ['./evo-datepicker.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => EvoDatepickerComponent),\n            multi: true,\n        },\n    ],\n})\nexport class EvoDatepickerComponent extends EvoBaseControl implements AfterViewInit, ControlValueAccessor, OnChanges, OnInit, OnDestroy {\n\n    @ViewChild('flatpickr', {static: true})\n    flatpickrElement: ElementRef;\n\n    @Input()\n    config: FlatpickrOptions;\n\n    @Input()\n    maskedInput: boolean;\n\n    @Input() theme?: string;\n\n    @Input() folded = false;\n\n    @Input()\n    placeholder = '';\n\n    @Input()\n    setDate: SelectedDates;\n\n    @Input()\n    description: string;\n\n    @Input()\n    maxRangeDays: number;\n\n    @Input()\n    appendToBody = true;\n\n    @Output()\n    closePicker = new EventEmitter<[Date, Date]>();\n\n    disabled = false;\n\n    uiState = {\n        isOpen: false,\n        isEmptyField: false,\n    };\n\n    elements: any = {};\n\n    maskConfig: { mask: any, pattern?: string, max?: Date };\n\n    private flatpickr: any;\n\n    constructor(\n        private zone: NgZone,\n        private elementRef: ElementRef,\n        protected injector: Injector,\n    ) {\n        super(injector);\n    }\n\n    onChange = (value) => {\n    };\n    onTouched = () => {\n    };\n\n    writeValue(value: SelectedDates) {\n        this.updatePickerIfNeed(value);\n        this.propagateChange(value);\n        this.onChange(value);\n    }\n\n    registerOnChange(fn: any) {\n        this.onChange = fn;\n        this.propagateChange = fn;\n    }\n\n    registerOnTouched(fn: any) {\n        this.onTouched = fn;\n    }\n\n    propagateChange = (_: any) => {\n    }\n\n    handleMaskComplete(value) {\n        if (this.maskedInput) {\n            const date = this.flatpickrElement.nativeElement._flatpickr.parseDate(value, this.config.dateFormat);\n            this.setDateFromInput(date);\n        }\n    }\n\n    setDateFromInput(date: SelectedDates) {\n        this.flatpickrElement.nativeElement._flatpickr.setDate(date, true);\n    }\n\n    ngAfterViewInit() {\n        const config = this.getConfig();\n\n        this.zone.runOutsideAngular(() => {\n            this.flatpickr = flatpickr(this.flatpickrElement.nativeElement, config);\n        });\n\n        if (this.setDate) {\n            this.setDateFromInput(this.setDate);\n        }\n        this.customizePicker();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes.hasOwnProperty('setDate') && changes['setDate'].currentValue) {\n            this.setDateFromInput(changes['setDate'].currentValue);\n        }\n    }\n\n    ngOnInit() {\n        this.initMask();\n    }\n\n    ngOnDestroy() {\n        this.flatpickr = null;\n        this.flatpickrElement.nativeElement._flatpickr.destroy();\n    }\n\n    get inputClass(): { [cssClass: string]: boolean } {\n        return {\n            'disabled': this.disabled,\n            'hidden': !this.isValueExist(),\n            'valid': this.currentState[EvoControlStates.valid],\n            'invalid': this.currentState[EvoControlStates.invalid],\n        };\n    }\n\n    get totalClasses(): string[] {\n        const classes: string[] = [];\n\n        if (this.theme) {\n            classes.push(this.theme);\n        }\n\n        if (this.uiState.isOpen) {\n            classes.push('opened');\n        }\n\n        if (this.folded) {\n            classes.push('folded');\n        }\n\n        return classes;\n    }\n\n    initMask() {\n        if (this.config.allowInput && this.maskedInput) {\n            this.maskConfig = {\n                pattern: this.config.dateFormat,\n                max: this.config.maxDate as Date,\n                mask: Date,\n            };\n        }\n    }\n\n    onDatepickerClick(event: MouseEvent) {\n        if (this.config.allowInput &&\n            (event.target as HTMLElement).classList.contains(cssClasses.INPUT) ||\n            this.disabled\n        ) {\n            return;\n        }\n\n        this.toggleDatepicker();\n    }\n\n    toggleDatepicker(): void {\n        this.flatpickr.toggle();\n    }\n\n    setDisabledState(state: boolean) {\n        this.disabled = state;\n    }\n\n    isValueExist(): boolean {\n        if (!this.flatpickr) {\n            const defaultDate = this.config.defaultDate;\n\n            return Array.isArray(defaultDate) ?\n                (this.config.defaultDate as Date[]).length > 0 : !!defaultDate;\n        } else {\n            return this.flatpickr.selectedDates.length > 0;\n        }\n    }\n\n    isRange(): boolean {\n        return this.config.mode === DatepickerModes.RANGE;\n    }\n\n    shouldShowEmptyText(): boolean {\n        return !this.isValueExist() && !this.config.altInput;\n    }\n\n    getDefaultFlatpickrOptions(): FlatpickrOptions {\n        return {\n            wrap: true,\n            clickOpens: false,\n            onChange: (selectedDates: Date[]) => {\n                this.setEmptyFieldState(false);\n                this.setRangeConstraints(selectedDates);\n                this.setTimeConstraints(selectedDates);\n                this.updateLabelValues(selectedDates);\n\n                this.writeValue(selectedDates);\n            },\n            onClose: (selectedDates: [Date, Date]) => {\n                this.handleSingleSelectedValueInRange(selectedDates);\n                this.setEmptyFieldStateIfNeed();\n                this.resetConstraints();\n                this.setOpenedState(false);\n                this.closePicker.emit(selectedDates);\n            },\n            onOpen: () => {\n                this.setOpenedState(true);\n                this.resetTimeAfterOpen();\n                this.updateLabelValues(this.flatpickr.selectedDates);\n                this.onTouched();\n            },\n            ...(!this.appendToBody && {appendTo: this.elementRef.nativeElement}),\n        };\n    }\n\n    getConfig() {\n        return {\n            ...this.getDefaultFlatpickrOptions(),\n            ...(this.config || {}),\n        };\n    }\n\n    /**\n     * Customization of the flatpickr's view to ui-kit state\n     */\n    private customizePicker(): void {\n        this.changeNextIcon();\n        this.addDescriptionIfNeed();\n        this.addTimeSelectors();\n    }\n\n    /**\n     * Sets new state of the picker openness\n     * @param state new state\n     */\n    private setOpenedState(state: boolean): void {\n        this.uiState.isOpen = state;\n    }\n\n    private setEmptyFieldState(state: boolean): void {\n        this.uiState.isEmptyField = state;\n    }\n\n    private addTimeSelectors() {\n        if (this.isRangeWithTime()) {\n            const timeWrapper = document.createElement('div');\n            timeWrapper.innerHTML = renderRangeTime(cssClasses);\n            this.saveTimeRangeElements(timeWrapper);\n            this.addListenersOnTimeSelectors();\n            this.elements.apply.onclick = this.onApply.bind(this);\n\n            this.flatpickr.rContainer.appendChild(timeWrapper);\n        }\n    }\n\n    private saveTimeRangeElements(timeWrapper: HTMLElement) {\n        this.elements = {\n            apply: timeWrapper.getElementsByClassName(cssClasses.APPLY)[0],\n            from: {\n                hour: timeWrapper.getElementsByClassName(cssClasses.SELECTOR_HOUR)[0],\n                minute: timeWrapper.getElementsByClassName(cssClasses.SELECTOR_MINUTE)[0],\n                label: timeWrapper.getElementsByClassName(cssClasses.TIME_LABEL_FROM)[0],\n            },\n            until: {\n                hour: timeWrapper.getElementsByClassName(cssClasses.SELECTOR_HOUR)[1],\n                minute: timeWrapper.getElementsByClassName(cssClasses.SELECTOR_MINUTE)[1],\n                label: timeWrapper.getElementsByClassName(cssClasses.TIME_LABEL_UNTIL)[0],\n            }\n        };\n\n        this.elements.from.hourField = this.elements.from.hour.previousElementSibling;\n        this.elements.from.minuteField = this.elements.from.minute.previousElementSibling;\n\n        this.elements.until.hourField = this.elements.until.hour.previousElementSibling;\n        this.elements.until.minuteField = this.elements.until.minute.previousElementSibling;\n    }\n\n    private onApply() {\n        this.setTime();\n        this.flatpickr.close();\n    }\n\n    private setTime() {\n        const {fromHour, fromMinute} = this.getSelectedFrom();\n        const {untilHour, untilMinute} = this.getSelectedUntil();\n\n        const selectedDates = cloneDeep(this.flatpickr.selectedDates);\n\n        selectedDates[0].setHours(fromHour, fromMinute);\n\n        if (selectedDates[1]) {\n            selectedDates[1].setHours(untilHour, untilMinute);\n        }\n\n        this.setDateFromInput(selectedDates);\n    }\n\n    private updateLabelValues(selectedDates: Date[]) {\n        if (!selectedDates || !selectedDates[0] || !selectedDates[1]) {\n            return;\n        }\n        if (this.isRangeWithTime()) {\n            this.elements.from.label.innerText = `Период с ${this.flatpickr.formatDate(selectedDates[0], 'D d.m.Y')}`;\n\n            if (selectedDates[1]) {\n                this.elements.until.label.innerText = `по ${this.flatpickr.formatDate(selectedDates[1], 'D d.m.Y')}`;\n            }\n        }\n    }\n\n    private setTimeConstraints(selectedDates: Date[]) {\n        if (this.isRangeWithTime()) {\n            if (this.isSameDate(selectedDates[0], selectedDates[1])) {\n                this.resetTimeIfNeed();\n                this.setUntilTimeConstraint(selectedDates);\n            } else {\n                this.resetAllConstraints();\n            }\n        }\n    }\n\n    private resetAllConstraints() {\n        Array.from(this.elements.from.hour.options).forEach((option: Option) => {\n            option.disabled = false;\n        });\n\n        Array.from(this.elements.from.minute.options).forEach((option: Option) => {\n            option.disabled = false;\n        });\n\n        Array.from(this.elements.until.hour.options).forEach((option: Option) => {\n            option.disabled = false;\n        });\n\n        Array.from(this.elements.until.minute.options).forEach((option: Option) => {\n            option.disabled = false;\n        });\n    }\n\n    private addListenersOnTimeSelectors() {\n        this.elements.from.hour.onchange = this.onChangeTimeFrom.bind(this);\n        this.elements.from.minute.onchange = this.onChangeTimeFrom.bind(this);\n\n        this.elements.until.hour.onchange = this.onChangeTimeUntil.bind(this);\n        this.elements.until.minute.onchange = this.onChangeTimeUntil.bind(this);\n    }\n\n    private onChangeTimeFrom(event: Event) {\n        if (this.isSameDate(this.flatpickr.selectedDates[0], this.flatpickr.selectedDates[1])) {\n            this.disableTimeUntilSelectors();\n        }\n        this.updateTimeFieldsContent();\n    }\n\n    private handleSingleSelectedValueInRange(selectedDates: [Date, Date]) {\n        if (this.isRange() && !selectedDates[1]) {\n            const untilDate = new Date(selectedDates[0]);\n            untilDate.setHours(23, 59, 0, 0);\n\n            const updatedDates = [selectedDates[0], untilDate];\n            this.writeValue(updatedDates);\n        }\n    }\n\n    private onChangeTimeUntil(event: Event) {\n        if (this.isSameDate(this.flatpickr.selectedDates[0], this.flatpickr.selectedDates[1])) {\n            this.disableTimeFromSelectors();\n        }\n        this.updateTimeFieldsContent();\n\n    }\n\n    private updateTimeFieldsContent() {\n        const {fromHour, fromMinute, untilHour, untilMinute} = this.getSelectorVaulesAsString();\n\n        this.elements.from.hourField.innerText = fromHour;\n        this.elements.from.minuteField.innerText = fromMinute;\n\n        this.elements.until.hourField.innerText = untilHour;\n        this.elements.until.minuteField.innerText = untilMinute;\n    }\n\n    private disableTimeUntilSelectors() {\n        const {fromHour, fromMinute} = this.getSelectedFrom();\n        const {untilHour, untilMinute} = this.getSelectedUntil();\n\n        Array.from(this.elements.until.hour.options).forEach((option: Option) => {\n            option.disabled = Number(option.value) < fromHour;\n        });\n\n        if (fromHour === untilHour) {\n            if (fromMinute > untilMinute) {\n                this.elements.until.minute.selectedIndex = 4;\n\n                Array.from(this.elements.from.minute.options).forEach((option: Option) => {\n                    option.disabled = false;\n                });\n            }\n            Array.from(this.elements.until.minute.options).forEach((option: Option) => {\n                option.disabled = Number(option.value) < fromMinute;\n            });\n        } else {\n            Array.from(this.elements.from.minute.options).forEach((option: Option) => {\n                option.disabled = false;\n            });\n\n            Array.from(this.elements.until.minute.options).forEach((option: Option) => {\n                option.disabled = false;\n            });\n        }\n    }\n\n    private disableTimeFromSelectors() {\n        const {fromHour, fromMinute} = this.getSelectedFrom();\n        const {untilHour, untilMinute} = this.getSelectedUntil();\n\n        Array.from(this.elements.from.hour.options).forEach((option: Option) => {\n            option.disabled = Number(option.value) > untilHour;\n        });\n\n        if (fromHour === untilHour) {\n            if (fromMinute > untilMinute) {\n                this.elements.until.minute.selectedIndex = 4;\n            }\n            const {untilMinute: untilMinuteAfterUpdate} = this.getSelectedUntil();\n\n            Array.from(this.elements.from.minute.options).forEach((option: Option) => {\n                option.disabled = Number(option.value) > untilMinuteAfterUpdate;\n            });\n\n            Array.from(this.elements.until.minute.options).forEach((option: Option) => {\n                option.disabled = Number(option.value) < fromMinute;\n            });\n        } else {\n            Array.from(this.elements.from.minute.options).forEach((option: Option) => {\n                option.disabled = false;\n            });\n\n            Array.from(this.elements.until.minute.options).forEach((option: Option) => {\n                option.disabled = false;\n            });\n        }\n    }\n\n    private setUntilTimeConstraint(selectedDates: Date[]) {\n        this.disableTimeUntilSelectors();\n    }\n\n    private resetTimeIfNeed() {\n        const {fromHour, fromMinute} = this.getSelectedFrom();\n        const {untilHour, untilMinute} = this.getSelectedUntil();\n\n        if ((fromHour > untilHour) || (fromHour === untilHour && fromMinute > untilMinute)) {\n            this.resetTime();\n        }\n    }\n\n    private resetTime() {\n        this.elements.from.hour.selectedIndex = 0;\n        this.elements.from.minute.selectedIndex = 0;\n\n        this.elements.until.hour.selectedIndex = 23;\n        this.elements.until.minute.selectedIndex = 4;\n\n        this.updateTimeFieldsContent();\n    }\n\n    private getSelectorVaulesAsString(): { fromHour: string, fromMinute: string, untilHour: string, untilMinute: string } {\n        return {\n            fromHour: this.elements.from.hour.options[this.elements.from.hour.selectedIndex].value,\n            fromMinute: this.elements.from.minute.options[this.elements.from.minute.selectedIndex].value,\n            untilHour: this.elements.until.hour.options[this.elements.until.hour.selectedIndex].value,\n            untilMinute: this.elements.until.minute.options[this.elements.until.minute.selectedIndex].value,\n        };\n    }\n\n    private getSelectedFrom(): { fromHour: number, fromMinute: number } {\n        return {\n            fromHour: Number(this.elements.from.hour.options[this.elements.from.hour.selectedIndex].value),\n            fromMinute: Number(this.elements.from.minute.options[this.elements.from.minute.selectedIndex].value),\n        };\n    }\n\n    private getSelectedUntil(): { untilHour: number, untilMinute: number } {\n        return {\n            untilHour: Number(this.elements.until.hour.options[this.elements.until.hour.selectedIndex].value),\n            untilMinute: Number(this.elements.until.minute.options[this.elements.until.minute.selectedIndex].value),\n        };\n    }\n\n    private setRangeConstraints(selectedDates: Date[]) {\n        if (this.isRange() && this.maxRangeDays) {\n            if (selectedDates.length === 1) {\n                const minDate = new Date(selectedDates[0]);\n                const maxDate = new Date(selectedDates[0]);\n\n                minDate.setDate(minDate.getDate() - this.maxRangeDays);\n                maxDate.setDate(maxDate.getDate() + this.maxRangeDays);\n\n                this.flatpickr.config.minDate = minDate;\n                this.flatpickr.config.maxDate = maxDate;\n            } else {\n                this.resetConstraints();\n            }\n        }\n    }\n\n    private resetConstraints() {\n        this.flatpickr.config.minDate = this.config.minDate;\n        this.flatpickr.config.maxDate = this.config.maxDate;\n    }\n\n    private isRangeWithTime(): boolean {\n        return this.isRange() && this.config.enableTime;\n    }\n\n    private setEmptyFieldStateIfNeed(): void {\n        if (this.isRange() && this.flatpickr.selectedDates.length !== 2) {\n            this.setEmptyFieldState(true);\n        }\n    }\n\n    private updatePickerIfNeed(value: SelectedDates): void {\n        if (this.flatpickr) {\n            const selectedDates = this.getSelectedDatesWithDatePickerFormat(this.flatpickr.selectedDates);\n            const values = this.getSelectedDatesWithDatePickerFormat(value);\n\n            if (!isEqual(values, selectedDates)) {\n                this.setDateFromInput(value);\n            }\n        }\n    }\n\n    private getSelectedDatesWithDatePickerFormat(dateRange: SelectedDates): string[] {\n        if (dateRange && dateRange.length && typeof (dateRange[0]) !== 'string') {\n            return (dateRange as Date[]).map((date) => this.toDatePickerFormat(date));\n        }\n\n        return dateRange as string[];\n    }\n\n    private toDatePickerFormat(date?: Date): string {\n        if (!date) {\n            return '';\n        }\n\n        return `${date.getDate()}.${date.getMonth() + 1}.${date.getFullYear()}`;\n    }\n\n    /**\n     * Substitution of icons\n     */\n    private changeNextIcon(): void {\n        const Icons = {\n            PREV: `\n                <svg height=\"16\" viewBox=\"0 0 6 16\" width=\"6\" xmlns=\"http://www.w3.org/2000/svg\">\n                    <path _ngcontent-c0=\"\" d=\"M6 0L0 8L6 16V0Z\" fill=\"white\" transform=\"translate(6 16) rotate(180)\"></path>\n                </svg>`,\n            NEXT: `\n                <svg height=\"16\" viewBox=\"0 0 6 16\" width=\"6\" xmlns=\"http://www.w3.org/2000/svg\">\n                    <path _ngcontent-c0=\"\" d=\"M6 0L0 8L6 16V0Z\" fill=\"white\"></path>\n                </svg>`,\n        };\n\n        this.flatpickr.nextMonthNav.innerHTML = Icons.PREV;\n        this.flatpickr.prevMonthNav.innerHTML = Icons.NEXT;\n    }\n\n    private addDescriptionIfNeed() {\n        if (this.description) {\n            const descriptionElement = document.createElement('p');\n            descriptionElement.className = cssClasses.DESCRIPTION;\n            descriptionElement.innerHTML = this.description;\n\n            this.flatpickr.rContainer.appendChild(descriptionElement);\n        }\n    }\n\n    private isSameDate(firstDate: Date, secondDate: Date): boolean {\n        return firstDate && secondDate && firstDate.getDate() === secondDate.getDate() &&\n            firstDate.getMonth() === secondDate.getMonth() &&\n            firstDate.getFullYear() === secondDate.getFullYear();\n    }\n\n    private getSelectedIndexByMinutes(minutes: number): number {\n        return Math.round(minutes / 5) * 5 / 15;\n    }\n\n    private resetTimeAfterOpen() {\n        if (this.isRangeWithTime()) {\n            const selectedDates = this.flatpickr.selectedDates;\n            if (selectedDates[0] && selectedDates[1]) {\n                this.elements.from.hour.selectedIndex = selectedDates[0].getHours();\n                this.elements.from.minute.selectedIndex = this.getSelectedIndexByMinutes(selectedDates[0].getMinutes());\n\n                this.elements.until.hour.selectedIndex = selectedDates[1].getHours();\n                this.elements.until.minute.selectedIndex = this.getSelectedIndexByMinutes(selectedDates[1].getMinutes());\n                this.addConstraintsAfterOpen(selectedDates);\n                this.updateTimeFieldsContent();\n            }\n        }\n    }\n\n    private addConstraintsAfterOpen(selectedDates: [Date, Date]) {\n        if (this.isSameDate(selectedDates[0], selectedDates[1])) {\n            const {fromHour, fromMinute} = this.getSelectedFrom();\n            const {untilHour, untilMinute} = this.getSelectedUntil();\n\n            Array.from(this.elements.from.hour.options).forEach((option: Option) => {\n                option.disabled = Number(option.value) > untilHour;\n            });\n\n            Array.from(this.elements.until.hour.options).forEach((option: Option) => {\n                option.disabled = Number(option.value) < fromHour;\n            });\n\n            if (fromHour === untilHour) {\n                Array.from(this.elements.from.minute.options).forEach((option: Option) => {\n                    option.disabled = Number(option.value) > untilMinute;\n                });\n\n                Array.from(this.elements.until.minute.options).forEach((option: Option) => {\n                    option.disabled = Number(option.value) < fromMinute;\n                });\n            } else {\n                Array.from(this.elements.from.minute.options).forEach((option: Option) => {\n                    option.disabled = false;\n                });\n\n                Array.from(this.elements.until.minute.options).forEach((option: Option) => {\n                    option.disabled = false;\n                });\n            }\n        }\n    }\n}\n","<div #flatpickr class=\"evo-datepicker\" [evoUiClass]=\"totalClasses\" (click)=\"onDatepickerClick($event)\">\n    <input\n        #input\n        type=\"text\"\n        data-input\n        class=\"evo-datepicker__input\"\n        [evoUiClass]=\"inputClass\"\n        [imask]=\"maskConfig\"\n        [placeholder]=\"placeholder\"\n        [readonly]=\"disabled\"\n        (complete)=\"handleMaskComplete($event)\"\n    />\n\n    <span *ngIf=\"isRange() && input.value\" class=\"evo-datepicker__value\">{{input.value}}</span>\n\n    <span *ngIf=\"shouldShowEmptyText()\" class=\"evo-datepicker__empty-text\">{{isRange() ? 'За период': 'Дата'}}</span>\n\n    <span *ngIf=\"!disabled\" class=\"evo-datepicker__opener\">\n        <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path\n                d=\"M20 3H19V2C19 1.45 18.55 1 18 1C17.45 1 17 1.45 17 2V3H7V2C7 1.45 6.55 1 6 1C5.45 1 5 1.45 5 2V3H4C2.9 3 2 3.9 2 5V21C2 22.1 2.9 23 4 23H20C21.1 23 22 22.1 22 21V5C22 3.9 21.1 3 20 3ZM19 21H5C4.45 21 4 20.55 4 20V8H20V20C20 20.55 19.55 21 19 21Z\"\n            />\n        </svg>\n    </span>\n    <span *ngIf=\"!uiState.isEmptyField\" class=\"evo-datepicker__opener-triangle\"></span>\n</div>\n\n<evo-control-error *ngIf=\"showErrors\" [errors]=\"control.errors\" [errorsMessages]=\"errorsMessages\"></evo-control-error>\n"]}