@festo-ui/angular 3.1.0-pre-20220203.2 → 3.1.0-pre-20220217.1

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 (231) hide show
  1. package/esm2020/festo-ui-angular.mjs +5 -0
  2. package/esm2020/index.mjs +18 -0
  3. package/esm2020/lib/components/breadcrumb/breadcrumb.component.mjs +23 -0
  4. package/esm2020/lib/components/buttons/button/button.component.mjs +41 -0
  5. package/esm2020/lib/components/buttons/link-button/link-button.component.mjs +33 -0
  6. package/esm2020/lib/components/chips/chip/chip.component.mjs +37 -0
  7. package/esm2020/lib/components/chips/chip-container/chip-container.component.mjs +16 -0
  8. package/esm2020/lib/components/click-outside.directive.mjs +28 -0
  9. package/esm2020/lib/components/components.module.mjs +155 -0
  10. package/esm2020/lib/components/loading-indicator/loading-indicator.component.mjs +16 -0
  11. package/esm2020/lib/components/modals/alert/alert.component.mjs +52 -0
  12. package/esm2020/lib/components/modals/confirm/confirm.component.mjs +67 -0
  13. package/esm2020/lib/components/modals/index.mjs +2 -0
  14. package/esm2020/lib/components/modals/modal.service.mjs +112 -0
  15. package/esm2020/lib/components/modals/modals.module.mjs +28 -0
  16. package/esm2020/lib/components/modals/prompt/prompt.component.mjs +102 -0
  17. package/esm2020/lib/components/pagination/pagination.component.mjs +55 -0
  18. package/esm2020/lib/components/popovers/legend/legend.component.mjs +42 -0
  19. package/esm2020/lib/components/popovers/legend/legend.directive.mjs +31 -0
  20. package/esm2020/lib/components/popovers/popover/popover.component.mjs +31 -0
  21. package/esm2020/lib/components/popovers/popover-content/popover-content.component.mjs +82 -0
  22. package/esm2020/lib/components/popovers/popover-content/popover-content.directive.mjs +39 -0
  23. package/esm2020/lib/components/popovers/popover-menu/popover-menu.component.mjs +68 -0
  24. package/esm2020/lib/components/popovers/popover-ref.mjs +25 -0
  25. package/esm2020/lib/components/popovers/popover.defaults.mjs +60 -0
  26. package/esm2020/lib/components/popovers/popover.models.mjs +23 -0
  27. package/esm2020/lib/components/popovers/popover.service.mjs +123 -0
  28. package/esm2020/lib/components/popovers/tooltip/tooltip.directive.mjs +94 -0
  29. package/esm2020/lib/components/progress/progress.component.mjs +20 -0
  30. package/esm2020/lib/components/scroll/index.mjs +2 -0
  31. package/esm2020/lib/components/scroll/scrollable.directive.mjs +72 -0
  32. package/esm2020/lib/components/search-input/search-input.component.mjs +150 -0
  33. package/esm2020/lib/components/snackbar/snackbar-container.component.mjs +21 -0
  34. package/esm2020/lib/components/snackbar/snackbar-container.directive.mjs +83 -0
  35. package/esm2020/lib/components/snackbar/snackbar.component.mjs +79 -0
  36. package/esm2020/lib/components/snackbar/snackbar.models.mjs +2 -0
  37. package/esm2020/lib/components/snackbar/snackbar.module.mjs +26 -0
  38. package/esm2020/lib/components/snackbar/snackbar.service.mjs +23 -0
  39. package/esm2020/lib/components/stepper/stepper.component.mjs +22 -0
  40. package/esm2020/lib/components/table-header-cell/table-header-cell.directive.mjs +58 -0
  41. package/esm2020/lib/components/tabs/tab-pane/tab-pane.component.mjs +31 -0
  42. package/esm2020/lib/components/tabs/tabs.component.mjs +355 -0
  43. package/esm2020/lib/content/content.module.mjs +20 -0
  44. package/esm2020/lib/content/icon/icon.component.mjs +17 -0
  45. package/esm2020/lib/festo-angular.module.mjs +58 -0
  46. package/esm2020/lib/forms/checkbox/checkbox.component.mjs +149 -0
  47. package/esm2020/lib/forms/color-indicator/color-indicator.component.mjs +68 -0
  48. package/esm2020/lib/forms/color-picker/color-helper.mjs +121 -0
  49. package/esm2020/lib/forms/color-picker/color-picker.component.mjs +273 -0
  50. package/esm2020/lib/forms/container-host.mjs +27 -0
  51. package/esm2020/lib/forms/date-picker/date-picker.component.mjs +199 -0
  52. package/esm2020/lib/forms/date-range-picker/date-range-picker.component.mjs +224 -0
  53. package/esm2020/lib/forms/forms.module.mjs +146 -0
  54. package/esm2020/lib/forms/radio/radio.component.mjs +346 -0
  55. package/esm2020/lib/forms/segment/segment-control/segment-control.component.mjs +52 -0
  56. package/esm2020/lib/forms/segment/segment.component.mjs +109 -0
  57. package/esm2020/lib/forms/select/chip-text.pipe.mjs +34 -0
  58. package/esm2020/lib/forms/select/select-option/select-option.component.mjs +22 -0
  59. package/esm2020/lib/forms/select/select.component.mjs +257 -0
  60. package/esm2020/lib/forms/slider/slider.component.mjs +110 -0
  61. package/esm2020/lib/forms/switch/switch.component.mjs +120 -0
  62. package/esm2020/lib/forms/text-area/text-area.component.mjs +180 -0
  63. package/esm2020/lib/forms/text-editor/text-editor.component.mjs +286 -0
  64. package/esm2020/lib/forms/text-input/text-input.component.mjs +183 -0
  65. package/esm2020/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.mjs +89 -0
  66. package/esm2020/lib/forms/time-picker/time-picker.component.mjs +188 -0
  67. package/esm2020/lib/forms/unique-selection-dispatcher.mjs +39 -0
  68. package/esm2020/lib/forms/value-accessor-base.mjs +41 -0
  69. package/esm2020/lib/layout/layout.module.mjs +18 -0
  70. package/esm2020/lib/wrappers/flatpickr/flatpickr.component.mjs +59 -0
  71. package/fesm2015/{festo-ui-angular.js → festo-ui-angular.mjs} +317 -521
  72. package/fesm2015/festo-ui-angular.mjs.map +1 -0
  73. package/fesm2020/festo-ui-angular.mjs +5383 -0
  74. package/fesm2020/festo-ui-angular.mjs.map +1 -0
  75. package/package.json +31 -16
  76. package/scss/base/components/breadcrumb/breadcrumb.component.scss +0 -1
  77. package/scss/base/components/modals/prompt/prompt.component.scss +0 -1
  78. package/scss/base/components/popovers/legend/legend.component.scss +2 -2
  79. package/scss/base/components/popovers/popover/styles.scss +3 -3
  80. package/scss/base/components/popovers/popover-content/popover-content.component.scss +1 -1
  81. package/scss/base/components/scroll/scroll-story-helper.scss +1 -3
  82. package/scss/base/components/snackbar/snackbar.component.scss +1 -1
  83. package/scss/base/components/stepper/stepper.component.scss +16 -15
  84. package/scss/base/forms/color-picker/color-picker.component.scss +12 -12
  85. package/scss/base/forms/date-picker/date-picker.component.scss +1 -1
  86. package/scss/base/forms/date-range-picker/date-range-picker.component.scss +1 -1
  87. package/scss/base/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.scss +1 -1
  88. package/scss/styles.scss +2 -2
  89. package/bundles/festo-ui-angular.umd.js +0 -6429
  90. package/bundles/festo-ui-angular.umd.js.map +0 -1
  91. package/esm2015/festo-ui-angular.js +0 -5
  92. package/esm2015/festo-ui-angular.js.map +0 -1
  93. package/esm2015/index.js +0 -18
  94. package/esm2015/index.js.map +0 -1
  95. package/esm2015/lib/components/breadcrumb/breadcrumb.component.js +0 -27
  96. package/esm2015/lib/components/breadcrumb/breadcrumb.component.js.map +0 -1
  97. package/esm2015/lib/components/buttons/button/button.component.js +0 -46
  98. package/esm2015/lib/components/buttons/button/button.component.js.map +0 -1
  99. package/esm2015/lib/components/buttons/link-button/link-button.component.js +0 -38
  100. package/esm2015/lib/components/buttons/link-button/link-button.component.js.map +0 -1
  101. package/esm2015/lib/components/chips/chip/chip.component.js +0 -42
  102. package/esm2015/lib/components/chips/chip/chip.component.js.map +0 -1
  103. package/esm2015/lib/components/chips/chip-container/chip-container.component.js +0 -21
  104. package/esm2015/lib/components/chips/chip-container/chip-container.component.js.map +0 -1
  105. package/esm2015/lib/components/click-outside.directive.js +0 -28
  106. package/esm2015/lib/components/click-outside.directive.js.map +0 -1
  107. package/esm2015/lib/components/components.module.js +0 -155
  108. package/esm2015/lib/components/components.module.js.map +0 -1
  109. package/esm2015/lib/components/loading-indicator/loading-indicator.component.js +0 -21
  110. package/esm2015/lib/components/loading-indicator/loading-indicator.component.js.map +0 -1
  111. package/esm2015/lib/components/modals/alert/alert.component.js +0 -57
  112. package/esm2015/lib/components/modals/alert/alert.component.js.map +0 -1
  113. package/esm2015/lib/components/modals/confirm/confirm.component.js +0 -73
  114. package/esm2015/lib/components/modals/confirm/confirm.component.js.map +0 -1
  115. package/esm2015/lib/components/modals/index.js +0 -2
  116. package/esm2015/lib/components/modals/index.js.map +0 -1
  117. package/esm2015/lib/components/modals/modal.service.js +0 -91
  118. package/esm2015/lib/components/modals/modal.service.js.map +0 -1
  119. package/esm2015/lib/components/modals/modals.module.js +0 -28
  120. package/esm2015/lib/components/modals/modals.module.js.map +0 -1
  121. package/esm2015/lib/components/modals/prompt/prompt.component.js +0 -110
  122. package/esm2015/lib/components/modals/prompt/prompt.component.js.map +0 -1
  123. package/esm2015/lib/components/pagination/pagination.component.js +0 -60
  124. package/esm2015/lib/components/pagination/pagination.component.js.map +0 -1
  125. package/esm2015/lib/components/popovers/legend/legend.component.js +0 -46
  126. package/esm2015/lib/components/popovers/legend/legend.component.js.map +0 -1
  127. package/esm2015/lib/components/popovers/legend/legend.directive.js +0 -31
  128. package/esm2015/lib/components/popovers/legend/legend.directive.js.map +0 -1
  129. package/esm2015/lib/components/popovers/popover/popover.component.js +0 -35
  130. package/esm2015/lib/components/popovers/popover/popover.component.js.map +0 -1
  131. package/esm2015/lib/components/popovers/popover-content/popover-content.component.js +0 -86
  132. package/esm2015/lib/components/popovers/popover-content/popover-content.component.js.map +0 -1
  133. package/esm2015/lib/components/popovers/popover-content/popover-content.directive.js +0 -39
  134. package/esm2015/lib/components/popovers/popover-content/popover-content.directive.js.map +0 -1
  135. package/esm2015/lib/components/popovers/popover-menu/popover-menu.component.js +0 -72
  136. package/esm2015/lib/components/popovers/popover-menu/popover-menu.component.js.map +0 -1
  137. package/esm2015/lib/components/popovers/popover-ref.js +0 -25
  138. package/esm2015/lib/components/popovers/popover-ref.js.map +0 -1
  139. package/esm2015/lib/components/popovers/popover.defaults.js +0 -60
  140. package/esm2015/lib/components/popovers/popover.defaults.js.map +0 -1
  141. package/esm2015/lib/components/popovers/popover.models.js +0 -23
  142. package/esm2015/lib/components/popovers/popover.models.js.map +0 -1
  143. package/esm2015/lib/components/popovers/popover.service.js +0 -117
  144. package/esm2015/lib/components/popovers/popover.service.js.map +0 -1
  145. package/esm2015/lib/components/popovers/tooltip/tooltip.directive.js +0 -96
  146. package/esm2015/lib/components/popovers/tooltip/tooltip.directive.js.map +0 -1
  147. package/esm2015/lib/components/progress/progress.component.js +0 -23
  148. package/esm2015/lib/components/progress/progress.component.js.map +0 -1
  149. package/esm2015/lib/components/scroll/index.js +0 -2
  150. package/esm2015/lib/components/scroll/index.js.map +0 -1
  151. package/esm2015/lib/components/scroll/scrollable.directive.js +0 -73
  152. package/esm2015/lib/components/scroll/scrollable.directive.js.map +0 -1
  153. package/esm2015/lib/components/search-input/search-input.component.js +0 -155
  154. package/esm2015/lib/components/search-input/search-input.component.js.map +0 -1
  155. package/esm2015/lib/components/snackbar/snackbar-container.component.js +0 -26
  156. package/esm2015/lib/components/snackbar/snackbar-container.component.js.map +0 -1
  157. package/esm2015/lib/components/snackbar/snackbar-container.directive.js +0 -83
  158. package/esm2015/lib/components/snackbar/snackbar-container.directive.js.map +0 -1
  159. package/esm2015/lib/components/snackbar/snackbar.component.js +0 -85
  160. package/esm2015/lib/components/snackbar/snackbar.component.js.map +0 -1
  161. package/esm2015/lib/components/snackbar/snackbar.models.js +0 -2
  162. package/esm2015/lib/components/snackbar/snackbar.models.js.map +0 -1
  163. package/esm2015/lib/components/snackbar/snackbar.module.js +0 -26
  164. package/esm2015/lib/components/snackbar/snackbar.module.js.map +0 -1
  165. package/esm2015/lib/components/snackbar/snackbar.service.js +0 -23
  166. package/esm2015/lib/components/snackbar/snackbar.service.js.map +0 -1
  167. package/esm2015/lib/components/stepper/stepper.component.js +0 -28
  168. package/esm2015/lib/components/stepper/stepper.component.js.map +0 -1
  169. package/esm2015/lib/components/table-header-cell/table-header-cell.directive.js +0 -58
  170. package/esm2015/lib/components/table-header-cell/table-header-cell.directive.js.map +0 -1
  171. package/esm2015/lib/components/tabs/tab-pane/tab-pane.component.js +0 -35
  172. package/esm2015/lib/components/tabs/tab-pane/tab-pane.component.js.map +0 -1
  173. package/esm2015/lib/components/tabs/tabs.component.js +0 -362
  174. package/esm2015/lib/components/tabs/tabs.component.js.map +0 -1
  175. package/esm2015/lib/content/content.module.js +0 -24
  176. package/esm2015/lib/content/content.module.js.map +0 -1
  177. package/esm2015/lib/content/icon/icon.component.js +0 -23
  178. package/esm2015/lib/content/icon/icon.component.js.map +0 -1
  179. package/esm2015/lib/festo-angular.module.js +0 -58
  180. package/esm2015/lib/festo-angular.module.js.map +0 -1
  181. package/esm2015/lib/forms/checkbox/checkbox.component.js +0 -156
  182. package/esm2015/lib/forms/checkbox/checkbox.component.js.map +0 -1
  183. package/esm2015/lib/forms/color-indicator/color-indicator.component.js +0 -72
  184. package/esm2015/lib/forms/color-indicator/color-indicator.component.js.map +0 -1
  185. package/esm2015/lib/forms/color-picker/color-helper.js +0 -121
  186. package/esm2015/lib/forms/color-picker/color-helper.js.map +0 -1
  187. package/esm2015/lib/forms/color-picker/color-picker.component.js +0 -280
  188. package/esm2015/lib/forms/color-picker/color-picker.component.js.map +0 -1
  189. package/esm2015/lib/forms/container-host.js +0 -27
  190. package/esm2015/lib/forms/container-host.js.map +0 -1
  191. package/esm2015/lib/forms/date-picker/date-picker.component.js +0 -205
  192. package/esm2015/lib/forms/date-picker/date-picker.component.js.map +0 -1
  193. package/esm2015/lib/forms/date-range-picker/date-range-picker.component.js +0 -230
  194. package/esm2015/lib/forms/date-range-picker/date-range-picker.component.js.map +0 -1
  195. package/esm2015/lib/forms/forms.module.js +0 -146
  196. package/esm2015/lib/forms/forms.module.js.map +0 -1
  197. package/esm2015/lib/forms/radio/radio.component.js +0 -353
  198. package/esm2015/lib/forms/radio/radio.component.js.map +0 -1
  199. package/esm2015/lib/forms/segment/segment-control/segment-control.component.js +0 -58
  200. package/esm2015/lib/forms/segment/segment-control/segment-control.component.js.map +0 -1
  201. package/esm2015/lib/forms/segment/segment.component.js +0 -116
  202. package/esm2015/lib/forms/segment/segment.component.js.map +0 -1
  203. package/esm2015/lib/forms/select/chip-text.pipe.js +0 -34
  204. package/esm2015/lib/forms/select/chip-text.pipe.js.map +0 -1
  205. package/esm2015/lib/forms/select/select-option/select-option.component.js +0 -29
  206. package/esm2015/lib/forms/select/select-option/select-option.component.js.map +0 -1
  207. package/esm2015/lib/forms/select/select.component.js +0 -265
  208. package/esm2015/lib/forms/select/select.component.js.map +0 -1
  209. package/esm2015/lib/forms/slider/slider.component.js +0 -116
  210. package/esm2015/lib/forms/slider/slider.component.js.map +0 -1
  211. package/esm2015/lib/forms/switch/switch.component.js +0 -127
  212. package/esm2015/lib/forms/switch/switch.component.js.map +0 -1
  213. package/esm2015/lib/forms/text-area/text-area.component.js +0 -186
  214. package/esm2015/lib/forms/text-area/text-area.component.js.map +0 -1
  215. package/esm2015/lib/forms/text-editor/text-editor.component.js +0 -294
  216. package/esm2015/lib/forms/text-editor/text-editor.component.js.map +0 -1
  217. package/esm2015/lib/forms/text-input/text-input.component.js +0 -189
  218. package/esm2015/lib/forms/text-input/text-input.component.js.map +0 -1
  219. package/esm2015/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.js +0 -103
  220. package/esm2015/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.js.map +0 -1
  221. package/esm2015/lib/forms/time-picker/time-picker.component.js +0 -194
  222. package/esm2015/lib/forms/time-picker/time-picker.component.js.map +0 -1
  223. package/esm2015/lib/forms/unique-selection-dispatcher.js +0 -39
  224. package/esm2015/lib/forms/unique-selection-dispatcher.js.map +0 -1
  225. package/esm2015/lib/forms/value-accessor-base.js +0 -41
  226. package/esm2015/lib/forms/value-accessor-base.js.map +0 -1
  227. package/esm2015/lib/layout/layout.module.js +0 -18
  228. package/esm2015/lib/layout/layout.module.js.map +0 -1
  229. package/esm2015/lib/wrappers/flatpickr/flatpickr.component.js +0 -63
  230. package/esm2015/lib/wrappers/flatpickr/flatpickr.component.js.map +0 -1
  231. package/fesm2015/festo-ui-angular.js.map +0 -1
@@ -0,0 +1,199 @@
1
+ import { Component, ViewEncapsulation, forwardRef, Input, ElementRef, ViewChild, HostListener, HostBinding } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { Overlay } from '@angular/cdk/overlay';
4
+ import { ComponentPortal } from '@angular/cdk/portal';
5
+ import { FlatpickrComponent } from '../../wrappers/flatpickr/flatpickr.component';
6
+ import { Subject } from 'rxjs';
7
+ import { takeUntil } from 'rxjs/operators';
8
+ import { formatDate } from '@angular/common';
9
+ import { LOCALE_ID, Inject } from '@angular/core';
10
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/cdk/overlay";
13
+ import * as i2 from "@angular/common";
14
+ export class DatePickerComponent {
15
+ constructor(overlay, localeDefault) {
16
+ this.overlay = overlay;
17
+ this.localeDefault = localeDefault;
18
+ this.innerDisabled = false;
19
+ this.innerRequired = false;
20
+ this.display = 'block';
21
+ this.complete = new Subject();
22
+ }
23
+ get value() {
24
+ return this.innerValue;
25
+ }
26
+ set value(date) {
27
+ if (!this.disabled) {
28
+ this.innerValue = date;
29
+ if (this.onChange != null) {
30
+ this.onChange(date);
31
+ }
32
+ if (this.onTouched != null) {
33
+ this.onTouched();
34
+ }
35
+ }
36
+ }
37
+ get disabled() {
38
+ return this.innerDisabled;
39
+ }
40
+ set disabled(value) {
41
+ this.innerDisabled = coerceBooleanProperty(value);
42
+ }
43
+ get required() {
44
+ return this.innerRequired;
45
+ }
46
+ set required(value) {
47
+ this.innerRequired = coerceBooleanProperty(value);
48
+ }
49
+ get displayValue() {
50
+ if (!this.value) {
51
+ return null;
52
+ }
53
+ const format = this.format || 'mediumDate';
54
+ const locale = this.locale || this.localeDefault;
55
+ const timezone = this.timezone;
56
+ return formatDate(this.value, format, locale, timezone);
57
+ }
58
+ hide(event) {
59
+ if (event.key === 'Escape' || event.key === 'Tab') {
60
+ this.dispose();
61
+ }
62
+ }
63
+ onDateChange(date) {
64
+ this.value = date;
65
+ }
66
+ writeValue(date) {
67
+ this.innerValue = date;
68
+ }
69
+ registerOnChange(fn) {
70
+ this.onChange = fn;
71
+ }
72
+ registerOnTouched(fn) {
73
+ this.onTouched = fn;
74
+ }
75
+ setDisabledState(isDisabled) {
76
+ this.disabled = isDisabled;
77
+ }
78
+ toggle(event) {
79
+ event.preventDefault();
80
+ event.stopPropagation();
81
+ if (!this.disabled) {
82
+ if (this.datePickerRef == null) {
83
+ this.datePickerRef = this.overlay.create({
84
+ hasBackdrop: true,
85
+ backdropClass: 'fng-date-picker-backdrop',
86
+ scrollStrategy: this.overlay.scrollStrategies.block(),
87
+ positionStrategy: this.overlay
88
+ .position()
89
+ .flexibleConnectedTo(this.connector.nativeElement)
90
+ .withPositions([
91
+ {
92
+ originX: 'center',
93
+ originY: 'bottom',
94
+ overlayX: 'center',
95
+ overlayY: 'top',
96
+ offsetY: -12,
97
+ offsetX: -10,
98
+ panelClass: ['flatpickr-calendar', 'open']
99
+ },
100
+ {
101
+ originX: 'center',
102
+ originY: 'top',
103
+ overlayX: 'center',
104
+ overlayY: 'bottom',
105
+ offsetY: 4,
106
+ offsetX: -10,
107
+ panelClass: ['flatpickr-calendar', 'open']
108
+ }
109
+ ])
110
+ .withFlexibleDimensions(false)
111
+ .withPush(false)
112
+ });
113
+ const datePickerPortal = new ComponentPortal(FlatpickrComponent);
114
+ this.datePicker = this.datePickerRef.attach(datePickerPortal);
115
+ this.datePicker.instance.options = this.options;
116
+ this.datePicker.instance.date = this.value;
117
+ this.datePicker.instance.dateChange.pipe(takeUntil(this.complete)).subscribe((c) => {
118
+ this.onDateChange(c);
119
+ if (this.options == null || !this.options.keepOpenOnDateChange) {
120
+ this.dispose();
121
+ }
122
+ });
123
+ this.datePickerRef
124
+ .backdropClick()
125
+ .pipe(takeUntil(this.complete))
126
+ .subscribe(() => this.dispose());
127
+ this.datePicker.instance.ngOnInit();
128
+ }
129
+ else {
130
+ this.dispose();
131
+ }
132
+ }
133
+ }
134
+ dispose() {
135
+ if (this.datePickerRef != null) {
136
+ this.datePickerRef.detach();
137
+ this.datePickerRef.dispose();
138
+ this.datePickerRef = null;
139
+ }
140
+ if (this.complete != null) {
141
+ this.complete.next(true);
142
+ this.complete.complete();
143
+ }
144
+ }
145
+ }
146
+ DatePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DatePickerComponent, deps: [{ token: i1.Overlay }, { token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Component });
147
+ DatePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: DatePickerComponent, selector: "fng-date-picker", inputs: { value: "value", disabled: "disabled", hint: "hint", error: "error", options: "options", locale: "locale", format: "format", timezone: "timezone", required: "required", width: "width" }, host: { listeners: { "document:keydown": "hide($event)" }, properties: { "style.width": "this.width", "style.display": "this.display" } }, providers: [
148
+ {
149
+ provide: NG_VALUE_ACCESSOR,
150
+ useExisting: forwardRef(() => DatePickerComponent),
151
+ multi: true
152
+ }
153
+ ], viewQueries: [{ propertyName: "connector", first: true, predicate: ["connector"], descendants: true, static: true }], ngImport: i0, template: "<label #connector class=\"fng-date-picker fwe-input-text fwe-input-text-icon\" (click)=\"toggle($event)\">\n <i\n class=\"fwe-icon fwe-icon-time-calendar\"\n [class.fwe-color-hero]=\"datePickerRef != null\"\n [class.fwe-color-control-disabled]=\"disabled\"\n ></i>\n <input\n aria-label=\"picked date\"\n type=\"text\"\n readonly\n [required]=\"required === true || null\"\n [class.fwe-border-hero]=\"datePickerRef != null\"\n [value]=\"displayValue\"\n [disabled]=\"disabled\"\n />\n <span class=\"fwe-input-text-label\"><ng-content></ng-content></span>\n <span *ngIf=\"hint\" class=\"fwe-input-text-info\">{{ hint }}</span>\n <span *ngIf=\"error\" class=\"fwe-input-text-invalid\">{{ error }}</span>\n</label>\n", styles: [".fwe-border-hero{border-color:var(--fwe-hero)!important}\n"], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
154
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DatePickerComponent, decorators: [{
155
+ type: Component,
156
+ args: [{ selector: 'fng-date-picker', providers: [
157
+ {
158
+ provide: NG_VALUE_ACCESSOR,
159
+ useExisting: forwardRef(() => DatePickerComponent),
160
+ multi: true
161
+ }
162
+ ], encapsulation: ViewEncapsulation.None, template: "<label #connector class=\"fng-date-picker fwe-input-text fwe-input-text-icon\" (click)=\"toggle($event)\">\n <i\n class=\"fwe-icon fwe-icon-time-calendar\"\n [class.fwe-color-hero]=\"datePickerRef != null\"\n [class.fwe-color-control-disabled]=\"disabled\"\n ></i>\n <input\n aria-label=\"picked date\"\n type=\"text\"\n readonly\n [required]=\"required === true || null\"\n [class.fwe-border-hero]=\"datePickerRef != null\"\n [value]=\"displayValue\"\n [disabled]=\"disabled\"\n />\n <span class=\"fwe-input-text-label\"><ng-content></ng-content></span>\n <span *ngIf=\"hint\" class=\"fwe-input-text-info\">{{ hint }}</span>\n <span *ngIf=\"error\" class=\"fwe-input-text-invalid\">{{ error }}</span>\n</label>\n", styles: [".fwe-border-hero{border-color:var(--fwe-hero)!important}\n"] }]
163
+ }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: undefined, decorators: [{
164
+ type: Inject,
165
+ args: [LOCALE_ID]
166
+ }] }]; }, propDecorators: { value: [{
167
+ type: Input
168
+ }], disabled: [{
169
+ type: Input
170
+ }], hint: [{
171
+ type: Input
172
+ }], error: [{
173
+ type: Input
174
+ }], options: [{
175
+ type: Input
176
+ }], locale: [{
177
+ type: Input
178
+ }], format: [{
179
+ type: Input
180
+ }], timezone: [{
181
+ type: Input
182
+ }], required: [{
183
+ type: Input
184
+ }], connector: [{
185
+ type: ViewChild,
186
+ args: ['connector', { static: true }]
187
+ }], width: [{
188
+ type: Input
189
+ }, {
190
+ type: HostBinding,
191
+ args: ['style.width']
192
+ }], display: [{
193
+ type: HostBinding,
194
+ args: ['style.display']
195
+ }], hide: [{
196
+ type: HostListener,
197
+ args: ['document:keydown', ['$event']]
198
+ }] } });
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/lib/forms/date-picker/date-picker.component.ts","../../../../../../../libs/angular/src/lib/forms/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  forwardRef,\n  Input,\n  ElementRef,\n  ViewChild,\n  ComponentRef,\n  HostListener,\n  HostBinding\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { FlatpickrComponent } from '../../wrappers/flatpickr/flatpickr.component';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { formatDate } from '@angular/common';\nimport { LOCALE_ID, Inject } from '@angular/core';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\n\nexport interface DatePickerOptions {\n  maxDate?: Date;\n  minDate?: Date;\n  keepOpenOnDateChange?: boolean;\n}\n\n@Component({\n  selector: 'fng-date-picker',\n  templateUrl: './date-picker.component.html',\n  styleUrls: ['./date-picker.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class DatePickerComponent implements ControlValueAccessor {\n  get value(): Date {\n    return this.innerValue;\n  }\n  @Input()\n  set value(date: Date) {\n    if (!this.disabled) {\n      this.innerValue = date;\n      if (this.onChange != null) {\n        this.onChange(date);\n      }\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n    }\n  }\n\n  @Input()\n  get disabled(): boolean {\n    return this.innerDisabled;\n  }\n  set disabled(value: boolean) {\n    this.innerDisabled = coerceBooleanProperty(value);\n  }\n  protected innerDisabled = false;\n\n  @Input() hint: string;\n  @Input() error: string;\n  @Input() options: DatePickerOptions;\n\n  /** A locale code for the locale format rules to use. */\n  @Input() locale: string;\n\n  /* The date-time components to include. See `DatePipe` for details. */\n  @Input() format: string;\n\n  /** The time zone. A time zone offset from GMT (such as `'+0430'`) */\n  @Input() timezone: string;\n\n  @Input()\n  get required(): boolean {\n    return this.innerRequired;\n  }\n  set required(value: boolean) {\n    this.innerRequired = coerceBooleanProperty(value);\n  }\n  protected innerRequired = false;\n\n  @ViewChild('connector', { static: true }) connector: ElementRef;\n\n  @Input()\n  @HostBinding('style.width')\n  width: string;\n  @HostBinding('style.display') display: string = 'block';\n\n  get displayValue(): string {\n    if (!this.value) {\n      return null;\n    }\n    const format = this.format || 'mediumDate';\n    const locale = this.locale || this.localeDefault;\n    const timezone = this.timezone;\n    return formatDate(this.value, format, locale, timezone);\n  }\n\n  datePickerRef: OverlayRef;\n  private innerValue: Date;\n  private complete = new Subject<boolean>();\n  private datePicker: ComponentRef<FlatpickrComponent>;\n\n  constructor(private overlay: Overlay, @Inject(LOCALE_ID) private localeDefault: string) {}\n\n  onTouched: () => any;\n  onChange: (date: Date) => any;\n\n  @HostListener('document:keydown', ['$event'])\n  hide(event: KeyboardEvent) {\n    if (event.key === 'Escape' || event.key === 'Tab') {\n      this.dispose();\n    }\n  }\n\n  onDateChange(date: Date) {\n    this.value = date;\n  }\n\n  writeValue(date: Date): void {\n    this.innerValue = date;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  toggle(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n    if (!this.disabled) {\n      if (this.datePickerRef == null) {\n        this.datePickerRef = this.overlay.create({\n          hasBackdrop: true,\n          backdropClass: 'fng-date-picker-backdrop',\n          scrollStrategy: this.overlay.scrollStrategies.block(),\n          positionStrategy: this.overlay\n            .position()\n            .flexibleConnectedTo(this.connector.nativeElement)\n            .withPositions([\n              {\n                originX: 'center',\n                originY: 'bottom',\n                overlayX: 'center',\n                overlayY: 'top',\n                offsetY: -12,\n                offsetX: -10,\n                panelClass: ['flatpickr-calendar', 'open']\n              },\n              {\n                originX: 'center',\n                originY: 'top',\n                overlayX: 'center',\n                overlayY: 'bottom',\n                offsetY: 4,\n                offsetX: -10,\n                panelClass: ['flatpickr-calendar', 'open']\n              }\n            ])\n            .withFlexibleDimensions(false)\n            .withPush(false)\n        });\n        const datePickerPortal = new ComponentPortal(FlatpickrComponent);\n        this.datePicker = this.datePickerRef.attach(datePickerPortal);\n        this.datePicker.instance.options = this.options;\n        this.datePicker.instance.date = this.value;\n        this.datePicker.instance.dateChange.pipe(takeUntil(this.complete)).subscribe((c: Date) => {\n          this.onDateChange(c);\n          if (this.options == null || !this.options.keepOpenOnDateChange) {\n            this.dispose();\n          }\n        });\n        this.datePickerRef\n          .backdropClick()\n          .pipe(takeUntil(this.complete))\n          .subscribe(() => this.dispose());\n        this.datePicker.instance.ngOnInit();\n      } else {\n        this.dispose();\n      }\n    }\n  }\n\n  private dispose() {\n    if (this.datePickerRef != null) {\n      this.datePickerRef.detach();\n      this.datePickerRef.dispose();\n      this.datePickerRef = null;\n    }\n    if (this.complete != null) {\n      this.complete.next(true);\n      this.complete.complete();\n    }\n  }\n}\n","<label #connector class=\"fng-date-picker fwe-input-text fwe-input-text-icon\" (click)=\"toggle($event)\">\n  <i\n    class=\"fwe-icon fwe-icon-time-calendar\"\n    [class.fwe-color-hero]=\"datePickerRef != null\"\n    [class.fwe-color-control-disabled]=\"disabled\"\n  ></i>\n  <input\n    aria-label=\"picked date\"\n    type=\"text\"\n    readonly\n    [required]=\"required === true || null\"\n    [class.fwe-border-hero]=\"datePickerRef != null\"\n    [value]=\"displayValue\"\n    [disabled]=\"disabled\"\n  />\n  <span class=\"fwe-input-text-label\"><ng-content></ng-content></span>\n  <span *ngIf=\"hint\" class=\"fwe-input-text-info\">{{ hint }}</span>\n  <span *ngIf=\"error\" class=\"fwe-input-text-invalid\">{{ error }}</span>\n</label>\n"]}
@@ -0,0 +1,224 @@
1
+ import { Component, ViewEncapsulation, forwardRef, Input, ElementRef, ViewChild, HostListener, Output, EventEmitter, HostBinding } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { Overlay } from '@angular/cdk/overlay';
4
+ import { ComponentPortal } from '@angular/cdk/portal';
5
+ import { FlatpickrComponent } from '../../wrappers/flatpickr/flatpickr.component';
6
+ import { Subject } from 'rxjs';
7
+ import { takeUntil } from 'rxjs/operators';
8
+ import { LOCALE_ID, Inject } from '@angular/core';
9
+ import { formatDate } from '@angular/common';
10
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/cdk/overlay";
13
+ import * as i2 from "@angular/common";
14
+ export class DateRangePickerComponent {
15
+ constructor(overlay, localeDefault) {
16
+ this.overlay = overlay;
17
+ this.localeDefault = localeDefault;
18
+ this.innerDisabled = false;
19
+ this.innerRequired = false;
20
+ this.display = 'block';
21
+ this.fngChange = new EventEmitter();
22
+ this.change = new EventEmitter();
23
+ this.complete = new Subject();
24
+ }
25
+ get value() {
26
+ return this.innerValue;
27
+ }
28
+ set value(dateRange) {
29
+ if (!this.disabled) {
30
+ this.innerValue = dateRange;
31
+ if (this.onChange != null) {
32
+ this.onChange(dateRange);
33
+ }
34
+ if (this.onTouched != null) {
35
+ this.onTouched();
36
+ }
37
+ this.fngChange.emit(this.innerValue);
38
+ this.change.emit(this.innerValue);
39
+ }
40
+ }
41
+ get disabled() {
42
+ return this.innerDisabled;
43
+ }
44
+ set disabled(value) {
45
+ this.innerDisabled = coerceBooleanProperty(value);
46
+ }
47
+ get required() {
48
+ return this.innerRequired;
49
+ }
50
+ set required(value) {
51
+ this.innerRequired = coerceBooleanProperty(value);
52
+ }
53
+ get fromDateDisplayValue() {
54
+ const v = this.value;
55
+ if (!v || v.length !== 2) {
56
+ return null;
57
+ }
58
+ const from = this.value[0];
59
+ const format = this.format || 'mediumDate';
60
+ const locale = this.locale || this.localeDefault;
61
+ const timezone = this.timezone;
62
+ return formatDate(from, format, locale, timezone);
63
+ }
64
+ get toDateDisplayValue() {
65
+ const v = this.value;
66
+ if (!v || v.length !== 2) {
67
+ return null;
68
+ }
69
+ const to = this.value[1];
70
+ const format = this.format || 'mediumDate';
71
+ const locale = this.locale || this.localeDefault;
72
+ const timezone = this.timezone;
73
+ return formatDate(to, format, locale, timezone);
74
+ }
75
+ hide(event) {
76
+ if (event.key === 'Escape' || event.key === 'Tab') {
77
+ this.dispose();
78
+ }
79
+ }
80
+ onDateChange(dateRange) {
81
+ this.value = dateRange;
82
+ }
83
+ writeValue(dateRange) {
84
+ this.innerValue = dateRange;
85
+ }
86
+ registerOnChange(fn) {
87
+ this.onChange = fn;
88
+ }
89
+ registerOnTouched(fn) {
90
+ this.onTouched = fn;
91
+ }
92
+ setDisabledState(isDisabled) {
93
+ this.disabled = isDisabled;
94
+ }
95
+ toggle(event) {
96
+ event.preventDefault();
97
+ event.stopPropagation();
98
+ if (!this.disabled) {
99
+ if (this.dateRangePickerRef == null) {
100
+ this.dateRangePickerRef = this.overlay.create({
101
+ hasBackdrop: true,
102
+ backdropClass: 'fng-date-picker-backdrop',
103
+ scrollStrategy: this.overlay.scrollStrategies.block(),
104
+ positionStrategy: this.overlay
105
+ .position()
106
+ .flexibleConnectedTo(this.connector.nativeElement)
107
+ .withPositions([
108
+ {
109
+ originX: 'center',
110
+ originY: 'bottom',
111
+ overlayX: 'center',
112
+ overlayY: 'top',
113
+ offsetY: -12,
114
+ offsetX: -10,
115
+ panelClass: ['flatpickr-calendar', 'open']
116
+ },
117
+ {
118
+ originX: 'center',
119
+ originY: 'top',
120
+ overlayX: 'center',
121
+ overlayY: 'bottom',
122
+ offsetY: 4,
123
+ offsetX: -10,
124
+ panelClass: ['flatpickr-calendar', 'open']
125
+ }
126
+ ])
127
+ .withFlexibleDimensions(false)
128
+ .withPush(false)
129
+ });
130
+ const datePickerPortal = new ComponentPortal(FlatpickrComponent);
131
+ this.datePicker = this.dateRangePickerRef.attach(datePickerPortal);
132
+ this.datePicker.instance.options = {
133
+ mode: 'range',
134
+ minDate: this.options != null && this.options.minDate != null ? this.options.minDate : null,
135
+ maxDate: this.options != null && this.options.maxDate != null ? this.options.maxDate : null
136
+ };
137
+ this.datePicker.instance.date = this.value;
138
+ this.datePicker.instance.dateChange.pipe(takeUntil(this.complete)).subscribe((c) => {
139
+ this.onDateChange(c);
140
+ if (this.options == null || !this.options.keepOpenOnDateChange) {
141
+ this.dispose();
142
+ }
143
+ });
144
+ this.dateRangePickerRef
145
+ .backdropClick()
146
+ .pipe(takeUntil(this.complete))
147
+ .subscribe(() => this.dispose());
148
+ this.datePicker.instance.ngOnInit();
149
+ }
150
+ else {
151
+ this.dispose();
152
+ }
153
+ }
154
+ }
155
+ dispose() {
156
+ if (this.dateRangePickerRef != null) {
157
+ this.dateRangePickerRef.detach();
158
+ this.dateRangePickerRef.dispose();
159
+ this.dateRangePickerRef = null;
160
+ }
161
+ if (this.complete != null) {
162
+ this.complete.next(true);
163
+ this.complete.complete();
164
+ }
165
+ }
166
+ }
167
+ DateRangePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DateRangePickerComponent, deps: [{ token: i1.Overlay }, { token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Component });
168
+ DateRangePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: DateRangePickerComponent, selector: "fng-date-range-picker", inputs: { value: "value", disabled: "disabled", hint: "hint", error: "error", locale: "locale", format: "format", timezone: "timezone", options: "options", required: "required", width: "width" }, outputs: { fngChange: "fngChange", change: "change" }, host: { listeners: { "document:keydown": "hide($event)" }, properties: { "style.width": "this.width", "style.display": "this.display" } }, providers: [
169
+ {
170
+ provide: NG_VALUE_ACCESSOR,
171
+ useExisting: forwardRef(() => DateRangePickerComponent),
172
+ multi: true
173
+ }
174
+ ], viewQueries: [{ propertyName: "connector", first: true, predicate: ["connector"], descendants: true, static: true }], ngImport: i0, template: "<div #connector class=\"fng-date-range-picker\" (click)=\"toggle($event)\">\n <label class=\"fwe-input-text fwe-input-text-icon\">\n <i\n class=\"fwe-icon fwe-icon-time-calendar\"\n [class.fwe-color-hero]=\"dateRangePickerRef != null\"\n [class.fwe-color-control-disabled]=\"disabled\"\n ></i>\n <div class=\"fng-date-range-picker-inputs\" [class.fng-date-range-picker-inputs--disabled]=\"disabled\">\n <input\n aria-label=\"picked start date\"\n type=\"text\"\n readonly\n [required]=\"required === true || null\"\n [class.fwe-border-hero]=\"dateRangePickerRef != null\"\n [value]=\"fromDateDisplayValue\"\n [disabled]=\"disabled\"\n />\n <input\n aria-label=\"picked end date\"\n type=\"text\"\n readonly\n [required]=\"required === true || null\"\n [class.fwe-border-hero]=\"dateRangePickerRef != null\"\n [value]=\"toDateDisplayValue\"\n [disabled]=\"disabled\"\n />\n </div>\n <span class=\"fwe-input-text-label\" [class.fwe-color-text-disabled]=\"disabled\"><ng-content></ng-content></span>\n <span *ngIf=\"hint\" class=\"fwe-input-text-info\">{{ hint }}</span>\n <span *ngIf=\"error\" class=\"fwe-input-text-invalid\">{{ error }}</span>\n </label>\n</div>\n", styles: [".fwe-border-hero{border-color:var(--fwe-hero)!important}.fng-date-range-picker:hover input{color:var(--fwe-hero)}.fng-date-range-picker-inputs{display:flex;order:2;position:relative}.fng-date-range-picker-inputs--disabled:after{color:var(--fwe-text-disabled)}.fng-date-range-picker-inputs:after{position:absolute;content:\"-\";left:50%;top:50%;transform:translate(-50%,-50%);padding-right:32px}\n"], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
175
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DateRangePickerComponent, decorators: [{
176
+ type: Component,
177
+ args: [{ selector: 'fng-date-range-picker', providers: [
178
+ {
179
+ provide: NG_VALUE_ACCESSOR,
180
+ useExisting: forwardRef(() => DateRangePickerComponent),
181
+ multi: true
182
+ }
183
+ ], encapsulation: ViewEncapsulation.None, template: "<div #connector class=\"fng-date-range-picker\" (click)=\"toggle($event)\">\n <label class=\"fwe-input-text fwe-input-text-icon\">\n <i\n class=\"fwe-icon fwe-icon-time-calendar\"\n [class.fwe-color-hero]=\"dateRangePickerRef != null\"\n [class.fwe-color-control-disabled]=\"disabled\"\n ></i>\n <div class=\"fng-date-range-picker-inputs\" [class.fng-date-range-picker-inputs--disabled]=\"disabled\">\n <input\n aria-label=\"picked start date\"\n type=\"text\"\n readonly\n [required]=\"required === true || null\"\n [class.fwe-border-hero]=\"dateRangePickerRef != null\"\n [value]=\"fromDateDisplayValue\"\n [disabled]=\"disabled\"\n />\n <input\n aria-label=\"picked end date\"\n type=\"text\"\n readonly\n [required]=\"required === true || null\"\n [class.fwe-border-hero]=\"dateRangePickerRef != null\"\n [value]=\"toDateDisplayValue\"\n [disabled]=\"disabled\"\n />\n </div>\n <span class=\"fwe-input-text-label\" [class.fwe-color-text-disabled]=\"disabled\"><ng-content></ng-content></span>\n <span *ngIf=\"hint\" class=\"fwe-input-text-info\">{{ hint }}</span>\n <span *ngIf=\"error\" class=\"fwe-input-text-invalid\">{{ error }}</span>\n </label>\n</div>\n", styles: [".fwe-border-hero{border-color:var(--fwe-hero)!important}.fng-date-range-picker:hover input{color:var(--fwe-hero)}.fng-date-range-picker-inputs{display:flex;order:2;position:relative}.fng-date-range-picker-inputs--disabled:after{color:var(--fwe-text-disabled)}.fng-date-range-picker-inputs:after{position:absolute;content:\"-\";left:50%;top:50%;transform:translate(-50%,-50%);padding-right:32px}\n"] }]
184
+ }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: undefined, decorators: [{
185
+ type: Inject,
186
+ args: [LOCALE_ID]
187
+ }] }]; }, propDecorators: { value: [{
188
+ type: Input
189
+ }], disabled: [{
190
+ type: Input
191
+ }], hint: [{
192
+ type: Input
193
+ }], error: [{
194
+ type: Input
195
+ }], locale: [{
196
+ type: Input
197
+ }], format: [{
198
+ type: Input
199
+ }], timezone: [{
200
+ type: Input
201
+ }], options: [{
202
+ type: Input
203
+ }], required: [{
204
+ type: Input
205
+ }], width: [{
206
+ type: Input
207
+ }, {
208
+ type: HostBinding,
209
+ args: ['style.width']
210
+ }], display: [{
211
+ type: HostBinding,
212
+ args: ['style.display']
213
+ }], fngChange: [{
214
+ type: Output
215
+ }], change: [{
216
+ type: Output
217
+ }], connector: [{
218
+ type: ViewChild,
219
+ args: ['connector', { static: true }]
220
+ }], hide: [{
221
+ type: HostListener,
222
+ args: ['document:keydown', ['$event']]
223
+ }] } });
224
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/lib/forms/date-range-picker/date-range-picker.component.ts","../../../../../../../libs/angular/src/lib/forms/date-range-picker/date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  forwardRef,\n  Input,\n  ElementRef,\n  ViewChild,\n  ComponentRef,\n  HostListener,\n  Output,\n  EventEmitter,\n  HostBinding\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { FlatpickrComponent } from '../../wrappers/flatpickr/flatpickr.component';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { LOCALE_ID, Inject } from '@angular/core';\nimport { formatDate } from '@angular/common';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\n\nexport interface DateRangePickerOptions {\n  maxDate?: Date;\n  minDate?: Date;\n  keepOpenOnDateChange?: boolean;\n}\n\n@Component({\n  selector: 'fng-date-range-picker',\n  templateUrl: './date-range-picker.component.html',\n  styleUrls: ['./date-range-picker.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateRangePickerComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class DateRangePickerComponent implements ControlValueAccessor {\n  get value(): Date[] {\n    return this.innerValue;\n  }\n  @Input()\n  set value(dateRange: Date[]) {\n    if (!this.disabled) {\n      this.innerValue = dateRange;\n      if (this.onChange != null) {\n        this.onChange(dateRange);\n      }\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n      this.fngChange.emit(this.innerValue);\n      this.change.emit(this.innerValue);\n    }\n  }\n\n  @Input()\n  get disabled(): boolean {\n    return this.innerDisabled;\n  }\n  set disabled(value: boolean) {\n    this.innerDisabled = coerceBooleanProperty(value);\n  }\n  protected innerDisabled = false;\n\n  @Input() hint: string;\n  @Input() error: string;\n\n  /** A locale code for the locale format rules to use. */\n  @Input() locale: string;\n\n  /* The date-time components to include. See `DatePipe` for details. */\n  @Input() format: string;\n\n  /** The time zone. A time zone offset from GMT (such as `'+0430'`) */\n  @Input() timezone: string;\n\n  @Input() options: DateRangePickerOptions;\n\n  @Input()\n  get required(): boolean {\n    return this.innerRequired;\n  }\n  set required(value: boolean) {\n    this.innerRequired = coerceBooleanProperty(value);\n  }\n  protected innerRequired = false;\n\n  @Input()\n  @HostBinding('style.width')\n  width: string;\n  @HostBinding('style.display') display: string = 'block';\n\n  @Output() fngChange = new EventEmitter<any>();\n  @Output() change = new EventEmitter<any>();\n\n  @ViewChild('connector', { static: true }) connector: ElementRef;\n\n  get fromDateDisplayValue(): string {\n    const v = this.value;\n    if (!v || v.length !== 2) {\n      return null;\n    }\n    const from = this.value[0];\n    const format = this.format || 'mediumDate';\n    const locale = this.locale || this.localeDefault;\n    const timezone = this.timezone;\n    return formatDate(from, format, locale, timezone);\n  }\n\n  get toDateDisplayValue(): string {\n    const v = this.value;\n    if (!v || v.length !== 2) {\n      return null;\n    }\n    const to = this.value[1];\n    const format = this.format || 'mediumDate';\n    const locale = this.locale || this.localeDefault;\n    const timezone = this.timezone;\n    return formatDate(to, format, locale, timezone);\n  }\n\n  dateRangePickerRef: OverlayRef;\n\n  private innerValue: Date[];\n  private complete = new Subject<boolean>();\n  private datePicker: ComponentRef<FlatpickrComponent>;\n\n  constructor(private overlay: Overlay, @Inject(LOCALE_ID) private localeDefault: string) {}\n\n  onTouched: () => any;\n  onChange: (dateRange: Date[]) => any;\n\n  @HostListener('document:keydown', ['$event'])\n  hide(event: KeyboardEvent) {\n    if (event.key === 'Escape' || event.key === 'Tab') {\n      this.dispose();\n    }\n  }\n\n  onDateChange(dateRange: Date[]) {\n    this.value = dateRange;\n  }\n\n  writeValue(dateRange: Date[]): void {\n    this.innerValue = dateRange;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  toggle(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n\n    if (!this.disabled) {\n      if (this.dateRangePickerRef == null) {\n        this.dateRangePickerRef = this.overlay.create({\n          hasBackdrop: true,\n          backdropClass: 'fng-date-picker-backdrop',\n          scrollStrategy: this.overlay.scrollStrategies.block(),\n          positionStrategy: this.overlay\n            .position()\n            .flexibleConnectedTo(this.connector.nativeElement)\n            .withPositions([\n              {\n                originX: 'center',\n                originY: 'bottom',\n                overlayX: 'center',\n                overlayY: 'top',\n                offsetY: -12,\n                offsetX: -10,\n                panelClass: ['flatpickr-calendar', 'open']\n              },\n              {\n                originX: 'center',\n                originY: 'top',\n                overlayX: 'center',\n                overlayY: 'bottom',\n                offsetY: 4,\n                offsetX: -10,\n                panelClass: ['flatpickr-calendar', 'open']\n              }\n            ])\n            .withFlexibleDimensions(false)\n            .withPush(false)\n        });\n        const datePickerPortal = new ComponentPortal(FlatpickrComponent);\n        this.datePicker = this.dateRangePickerRef.attach(datePickerPortal);\n        this.datePicker.instance.options = {\n          mode: 'range',\n          minDate: this.options != null && this.options.minDate != null ? this.options.minDate : null,\n          maxDate: this.options != null && this.options.maxDate != null ? this.options.maxDate : null\n        };\n        this.datePicker.instance.date = this.value;\n        this.datePicker.instance.dateChange.pipe(takeUntil(this.complete)).subscribe((c: Date[]) => {\n          this.onDateChange(c);\n          if (this.options == null || !this.options.keepOpenOnDateChange) {\n            this.dispose();\n          }\n        });\n        this.dateRangePickerRef\n          .backdropClick()\n          .pipe(takeUntil(this.complete))\n          .subscribe(() => this.dispose());\n        this.datePicker.instance.ngOnInit();\n      } else {\n        this.dispose();\n      }\n    }\n  }\n\n  private dispose() {\n    if (this.dateRangePickerRef != null) {\n      this.dateRangePickerRef.detach();\n      this.dateRangePickerRef.dispose();\n      this.dateRangePickerRef = null;\n    }\n    if (this.complete != null) {\n      this.complete.next(true);\n      this.complete.complete();\n    }\n  }\n}\n","<div #connector class=\"fng-date-range-picker\" (click)=\"toggle($event)\">\n  <label class=\"fwe-input-text fwe-input-text-icon\">\n    <i\n      class=\"fwe-icon fwe-icon-time-calendar\"\n      [class.fwe-color-hero]=\"dateRangePickerRef != null\"\n      [class.fwe-color-control-disabled]=\"disabled\"\n    ></i>\n    <div class=\"fng-date-range-picker-inputs\" [class.fng-date-range-picker-inputs--disabled]=\"disabled\">\n      <input\n        aria-label=\"picked start date\"\n        type=\"text\"\n        readonly\n        [required]=\"required === true || null\"\n        [class.fwe-border-hero]=\"dateRangePickerRef != null\"\n        [value]=\"fromDateDisplayValue\"\n        [disabled]=\"disabled\"\n      />\n      <input\n        aria-label=\"picked end date\"\n        type=\"text\"\n        readonly\n        [required]=\"required === true || null\"\n        [class.fwe-border-hero]=\"dateRangePickerRef != null\"\n        [value]=\"toDateDisplayValue\"\n        [disabled]=\"disabled\"\n      />\n    </div>\n    <span class=\"fwe-input-text-label\" [class.fwe-color-text-disabled]=\"disabled\"><ng-content></ng-content></span>\n    <span *ngIf=\"hint\" class=\"fwe-input-text-info\">{{ hint }}</span>\n    <span *ngIf=\"error\" class=\"fwe-input-text-invalid\">{{ error }}</span>\n  </label>\n</div>\n"]}