@datarailsshared/datarailsshared 1.4.46-rocket → 1.4.48-bratans

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 (30) hide show
  1. package/bundles/datarailsshared-datarailsshared.umd.js +124 -48
  2. package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
  3. package/datarailsshared-datarailsshared-1.4.48-bratans.tgz +0 -0
  4. package/datarailsshared-datarailsshared.d.ts +1 -0
  5. package/datarailsshared-datarailsshared.metadata.json +1 -1
  6. package/esm2015/datarailsshared-datarailsshared.js +2 -1
  7. package/esm2015/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.js +30 -10
  8. package/esm2015/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.js +26 -10
  9. package/esm2015/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.js +12 -0
  10. package/esm2015/lib/dr-inputs/date-pickers/services/dr-date-picker.service.js +15 -2
  11. package/esm2015/lib/dr-inputs/dr-inputs.module.js +4 -2
  12. package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +1 -1
  13. package/esm2015/lib/dr-spinner/dr-spinner.component.js +6 -17
  14. package/esm2015/lib/dr-spinner/dr-spinner.directive.js +7 -3
  15. package/esm2015/lib/models/datePicker.js +3 -1
  16. package/esm2015/lib/models/spinnerOptions.js +13 -0
  17. package/esm2015/public-api.js +2 -1
  18. package/fesm2015/datarailsshared-datarailsshared.js +107 -39
  19. package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
  20. package/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.d.ts +5 -2
  21. package/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +2 -1
  22. package/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.d.ts +6 -0
  23. package/lib/dr-inputs/date-pickers/services/dr-date-picker.service.d.ts +2 -0
  24. package/lib/dr-spinner/dr-spinner.component.d.ts +3 -7
  25. package/lib/dr-spinner/dr-spinner.directive.d.ts +3 -1
  26. package/lib/models/datePicker.d.ts +4 -1
  27. package/lib/models/spinnerOptions.d.ts +14 -0
  28. package/package.json +1 -1
  29. package/public-api.d.ts +1 -0
  30. package/datarailsshared-datarailsshared-1.4.46-rocket.tgz +0 -0
@@ -7,6 +7,7 @@ export { DrDatePickerFormatDirective as ɵf } from './lib/dr-inputs/date-pickers
7
7
  export { DrDatePickerWithTimeframeComponent as ɵe } from './lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component';
8
8
  export { DrDatePickerComponent as ɵc } from './lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component';
9
9
  export { DrDatePickerCustomHeaderComponent as ɵg } from './lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component';
10
+ export { DrShowTimeframePipe as ɵh } from './lib/dr-inputs/date-pickers/dr-show-timeframe.pipe';
10
11
  export { DrDatePickerService as ɵd } from './lib/dr-inputs/date-pickers/services/dr-date-picker.service';
11
12
  export { POPUP_ANIMATION as ɵb } from './lib/models/constants';
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YXJhaWxzc2hhcmVkLWRhdGFyYWlsc3NoYXJlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvZGF0YXJhaWxzc2hhcmVkLWRhdGFyYWlsc3NoYXJlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxVQUFVLElBQUksRUFBRSxFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDakUsT0FBTyxFQUFDLDJCQUEyQixJQUFJLEVBQUUsRUFBQyxNQUFNLHlFQUF5RSxDQUFDO0FBQzFILE9BQU8sRUFBQyxrQ0FBa0MsSUFBSSxFQUFFLEVBQUMsTUFBTSxvR0FBb0csQ0FBQztBQUM1SixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sc0VBQXNFLENBQUM7QUFDakgsT0FBTyxFQUFDLGlDQUFpQyxJQUFJLEVBQUUsRUFBQyxNQUFNLGtHQUFrRyxDQUFDO0FBQ3pKLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSw4REFBOEQsQ0FBQztBQUN2RyxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuXG5leHBvcnQge2NvbXBvbmVudHMgYXMgybVhfSBmcm9tICcuL2xpYi9kYXRlLXRhZ3MvZGF0ZS10YWcubW9kdWxlJztcbmV4cG9ydCB7RHJEYXRlUGlja2VyRm9ybWF0RGlyZWN0aXZlIGFzIMm1Zn0gZnJvbSAnLi9saWIvZHItaW5wdXRzL2RhdGUtcGlja2Vycy9kaXJlY3RpdmVzL2RyLWRhdGUtcGlja2VyLWZvcm1hdC5kaXJlY3RpdmUnO1xuZXhwb3J0IHtEckRhdGVQaWNrZXJXaXRoVGltZWZyYW1lQ29tcG9uZW50IGFzIMm1ZX0gZnJvbSAnLi9saWIvZHItaW5wdXRzL2RhdGUtcGlja2Vycy9kci1kYXRlLXBpY2tlci13aXRoLXRpbWVmcmFtZS9kci1kYXRlLXBpY2tlci13aXRoLXRpbWVmcmFtZS5jb21wb25lbnQnO1xuZXhwb3J0IHtEckRhdGVQaWNrZXJDb21wb25lbnQgYXMgybVjfSBmcm9tICcuL2xpYi9kci1pbnB1dHMvZGF0ZS1waWNrZXJzL2RyLWRhdGUtcGlja2VyL2RyLWRhdGUtcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQge0RyRGF0ZVBpY2tlckN1c3RvbUhlYWRlckNvbXBvbmVudCBhcyDJtWd9IGZyb20gJy4vbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXJfY3VzdG9tLWhlYWRlci9kci1kYXRlLXBpY2tlcl9jdXN0b20taGVhZGVyLmNvbXBvbmVudCc7XG5leHBvcnQge0RyRGF0ZVBpY2tlclNlcnZpY2UgYXMgybVkfSBmcm9tICcuL2xpYi9kci1pbnB1dHMvZGF0ZS1waWNrZXJzL3NlcnZpY2VzL2RyLWRhdGUtcGlja2VyLnNlcnZpY2UnO1xuZXhwb3J0IHtQT1BVUF9BTklNQVRJT04gYXMgybVifSBmcm9tICcuL2xpYi9tb2RlbHMvY29uc3RhbnRzJzsiXX0=
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YXJhaWxzc2hhcmVkLWRhdGFyYWlsc3NoYXJlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvZGF0YXJhaWxzc2hhcmVkLWRhdGFyYWlsc3NoYXJlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxVQUFVLElBQUksRUFBRSxFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDakUsT0FBTyxFQUFDLDJCQUEyQixJQUFJLEVBQUUsRUFBQyxNQUFNLHlFQUF5RSxDQUFDO0FBQzFILE9BQU8sRUFBQyxrQ0FBa0MsSUFBSSxFQUFFLEVBQUMsTUFBTSxvR0FBb0csQ0FBQztBQUM1SixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sc0VBQXNFLENBQUM7QUFDakgsT0FBTyxFQUFDLGlDQUFpQyxJQUFJLEVBQUUsRUFBQyxNQUFNLGtHQUFrRyxDQUFDO0FBQ3pKLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUM5RixPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0sOERBQThELENBQUM7QUFDdkcsT0FBTyxFQUFDLGVBQWUsSUFBSSxFQUFFLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtjb21wb25lbnRzIGFzIMm1YX0gZnJvbSAnLi9saWIvZGF0ZS10YWdzL2RhdGUtdGFnLm1vZHVsZSc7XG5leHBvcnQge0RyRGF0ZVBpY2tlckZvcm1hdERpcmVjdGl2ZSBhcyDJtWZ9IGZyb20gJy4vbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZGlyZWN0aXZlcy9kci1kYXRlLXBpY2tlci1mb3JtYXQuZGlyZWN0aXZlJztcbmV4cG9ydCB7RHJEYXRlUGlja2VyV2l0aFRpbWVmcmFtZUNvbXBvbmVudCBhcyDJtWV9IGZyb20gJy4vbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUuY29tcG9uZW50JztcbmV4cG9ydCB7RHJEYXRlUGlja2VyQ29tcG9uZW50IGFzIMm1Y30gZnJvbSAnLi9saWIvZHItaW5wdXRzL2RhdGUtcGlja2Vycy9kci1kYXRlLXBpY2tlci9kci1kYXRlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0IHtEckRhdGVQaWNrZXJDdXN0b21IZWFkZXJDb21wb25lbnQgYXMgybVnfSBmcm9tICcuL2xpYi9kci1pbnB1dHMvZGF0ZS1waWNrZXJzL2RyLWRhdGUtcGlja2VyX2N1c3RvbS1oZWFkZXIvZHItZGF0ZS1waWNrZXJfY3VzdG9tLWhlYWRlci5jb21wb25lbnQnO1xuZXhwb3J0IHtEclNob3dUaW1lZnJhbWVQaXBlIGFzIMm1aH0gZnJvbSAnLi9saWIvZHItaW5wdXRzL2RhdGUtcGlja2Vycy9kci1zaG93LXRpbWVmcmFtZS5waXBlJztcbmV4cG9ydCB7RHJEYXRlUGlja2VyU2VydmljZSBhcyDJtWR9IGZyb20gJy4vbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvc2VydmljZXMvZHItZGF0ZS1waWNrZXIuc2VydmljZSc7XG5leHBvcnQge1BPUFVQX0FOSU1BVElPTiBhcyDJtWJ9IGZyb20gJy4vbGliL21vZGVscy9jb25zdGFudHMnOyJdfQ==
@@ -12,17 +12,20 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
12
12
  this.dateAdapter = dateAdapter;
13
13
  this.datePickerService = datePickerService;
14
14
  this.isDashboardDatepicker = false;
15
+ this.canSelectTimeframe = true;
15
16
  this.onChangeFormat = new EventEmitter();
16
17
  this.pagingSetup = {
17
18
  [TimeframeOption.YEAR]: (forward) => this.pagingDateChange('addCalendarYears', 1, forward),
18
19
  [TimeframeOption.QUARTER]: (forward) => this.pagingDateChange('addCalendarMonths', 3, forward),
19
20
  [TimeframeOption.MONTH]: (forward) => this.pagingDateChange('addCalendarMonths', 1, forward),
20
- [TimeframeOption.DAY]: (forward) => this.pagingDateChange('addCalendarDays', 1, forward)
21
+ [TimeframeOption.DAY]: (forward) => this.pagingDateChange('addCalendarDays', 1, forward),
22
+ [TimeframeOption.WEEK]: (forward) => this.pagingDateChange('addCalendarDays', 7, forward)
21
23
  };
22
24
  datePickerService.isTimeframeSelectionEnabled = true;
23
25
  datePickerService.format$
24
26
  .pipe(takeUntil(this.destroyed$))
25
27
  .subscribe((value) => {
28
+ datePickerService.format$.getValue();
26
29
  this.onChangeFormat.emit(datePickerService.normalizeValue(value));
27
30
  });
28
31
  }
@@ -30,19 +33,34 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
30
33
  return this.isDashboardDatepicker;
31
34
  }
32
35
  ;
36
+ set dateFormatConfig(value) {
37
+ if (value) {
38
+ this.datePickerService.formatConfig = Object.assign(Object.assign({}, this.datePickerService.formatConfig), value);
39
+ this.cdr.markForCheck();
40
+ }
41
+ }
42
+ set availableTimeframes(value) {
43
+ if (value && value.length) {
44
+ this.datePickerService.availableTimeframes = value;
45
+ }
46
+ }
33
47
  get displayedFormattedValue() {
34
- var _a;
35
48
  if (!this.value) {
36
49
  return this.placeholder;
37
50
  }
38
- return ((_a = this.datePickerService.format$.getValue()) === null || _a === void 0 ? void 0 : _a.includes('Q'))
39
- ? this.datePickerService.getQuarterDisplay(this.value)
40
- : this.value.format(this.datePickerService.format$.getValue());
51
+ const formatCached = this.datePickerService.format$.getValue();
52
+ switch (true) {
53
+ case formatCached === null || formatCached === void 0 ? void 0 : formatCached.includes('Q'):
54
+ return this.datePickerService.getQuarterDisplay(this.value);
55
+ case formatCached === null || formatCached === void 0 ? void 0 : formatCached.includes('W'):
56
+ return this.datePickerService.getWeekDisplay(this.value);
57
+ default:
58
+ return this.value.format(formatCached);
59
+ }
41
60
  }
42
61
  ngOnInit() {
43
- if (this.dateFormatConfig) {
44
- this.datePickerService.formatConfig = Object.assign(Object.assign({}, this.datePickerService.formatConfig), this.dateFormatConfig);
45
- }
62
+ this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;
63
+ this.cdr.markForCheck();
46
64
  }
47
65
  pagingClicked(forward) {
48
66
  this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);
@@ -62,7 +80,7 @@ DrDatePickerWithTimeframeComponent.decorators = [
62
80
  { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },
63
81
  { provide: DrDatePickerService }
64
82
  ],
65
- styles: [":host{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:\"Poppins\",sans-serif;background-color:#fff;border:1px solid #C3C4CE;border-radius:6px;color:#85889c;overflow:hidden;outline:none;cursor:pointer}:host:hover{border-color:#85889c}:host:focus-within{border-color:#21b8f1!important;color:#151b3f}:host.disabled{pointer-events:none;border:none;color:#85889c;background:#E5E6EA}:host.ng-valid.ng-dirty{border-color:#03a678}:host.ng-invalid.ng-dirty:not(:focus-within){border-color:#de2833!important}:host.ng-untouched.ng-valid{border-color:#c3c4ce}:host:after,:host:before{position:absolute;display:flex;border-color:#999999 transparent transparent;color:#999}:host:after{content:\"\";height:0;width:0;border-style:solid;border-width:5px 5px 2.5px;right:11px;top:13px}:host i{position:absolute;color:#999;left:8px;top:3px}:host input{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}:host input.when-quarter{position:absolute;visibility:hidden}:host input:disabled{border:none;color:#85889c;background:transparent}:host input::-webkit-search-decoration,:host input::-webkit-search-cancel-button,:host input::-webkit-search-results-button,:host input::-webkit-search-results-decoration{-webkit-appearance:none}::ng-deep .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important}::ng-deep .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit}::ng-deep .mat-datepicker-content button[disabled]:hover{border:inherit}::ng-deep .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#F2F2FB;color:#4646ce;font-weight:600}::ng-deep .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600}::ng-deep .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none}::ng-deep .mat-button-focus-overlay{background:#F3F7FF}::ng-deep .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#F3F7FF;transition:opacity .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-calendar-controls .mat-calendar-period-button:hover{background:#F3F7FF;transition:background .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#19181a}::ng-deep .mat-calendar-table-header-divider{display:none}::ng-deep .mat-calendar-body-label{color:#fff;padding:0}:host{border:none;display:flex;align-items:center}:host.dr-date-picker-on-dashboard{width:180px;justify-content:space-between}:host.dr-date-picker-on-dashboard mat-datepicker{position:absolute}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container{display:flex;flex-direction:row;justify-content:center;align-items:center;margin-left:-10px}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container__formatted-value-display{font-weight:600;width:auto;margin-left:5px}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container .dr-icon-date{display:block;position:relative;top:0;margin-right:8px;color:#4e566c}:host .dr-datepicker-input-container input{visibility:hidden;position:absolute;width:100%}:host .dr-datepicker-input-container__formatted-value-display{width:90px;height:22px;padding-left:0;text-align:center;line-height:22px;color:#0c142b;-webkit-text-decoration-line:underline;text-decoration-line:underline}:host .dr-datepicker-input-container__formatted-value-display:hover{background-color:#f2f2fb;border-radius:5px;cursor:pointer;-webkit-text-decoration-line:underline;text-decoration-line:underline;color:#4646ce}\n"]
83
+ styles: [":host{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:\"Poppins\",sans-serif;background-color:#fff;border:1px solid #C3C4CE;border-radius:6px;color:#85889c;overflow:hidden;outline:none;cursor:pointer}:host:hover{border-color:#85889c}:host:focus-within{border-color:#21b8f1!important;color:#151b3f}:host.disabled{pointer-events:none;border:none;color:#85889c;background:#E5E6EA}:host.ng-valid.ng-dirty{border-color:#03a678}:host.ng-invalid.ng-dirty:not(:focus-within){border-color:#de2833!important}:host.ng-untouched.ng-valid{border-color:#c3c4ce}:host:after,:host:before{position:absolute;display:flex;border-color:#999999 transparent transparent;color:#999}:host:after{content:\"\";height:0;width:0;border-style:solid;border-width:5px 5px 2.5px;right:11px;top:13px}:host i{position:absolute;color:#999;left:8px;top:3px}:host input{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}:host input.when-quarter{position:absolute;visibility:hidden}:host input:disabled{border:none;color:#85889c;background:transparent}:host input::-webkit-search-decoration,:host input::-webkit-search-cancel-button,:host input::-webkit-search-results-button,:host input::-webkit-search-results-decoration{-webkit-appearance:none}::ng-deep .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important}::ng-deep .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit}::ng-deep .mat-datepicker-content button[disabled]:hover{border:inherit}::ng-deep .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#F2F2FB;color:#4646ce;font-weight:600}::ng-deep .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600}::ng-deep .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none}::ng-deep .mat-button-focus-overlay{background:#F3F7FF}::ng-deep .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#F3F7FF;transition:opacity .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-calendar-controls .mat-calendar-period-button:hover{background:#F3F7FF;transition:background .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#19181a}::ng-deep .mat-calendar-table-header-divider{display:none}::ng-deep .mat-calendar-body-label{color:#fff;padding:0}:host{border:none;display:flex;align-items:center}:host.dr-date-picker-on-dashboard{width:180px;justify-content:space-between}:host.dr-date-picker-on-dashboard mat-datepicker{position:absolute}:host.dr-date-picker-on-dashboard:after{visibility:hidden}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container{display:flex;flex-direction:row;justify-content:center;align-items:center;margin-left:-10px}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container__formatted-value-display{font-weight:600;width:auto;margin-left:5px}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container .dr-icon-date{display:block;position:relative;top:0;margin-right:8px;color:#4e566c}:host .dr-datepicker-input-container input{visibility:hidden;position:absolute;width:100%}:host .dr-datepicker-input-container__formatted-value-display{width:90px;height:22px;padding-left:0;text-align:center;line-height:22px;color:#0c142b;-webkit-text-decoration-line:underline;text-decoration-line:underline}:host .dr-datepicker-input-container__formatted-value-display:hover{background-color:#f2f2fb;border-radius:5px;cursor:pointer;-webkit-text-decoration-line:underline;text-decoration-line:underline;color:#4646ce}\n"]
66
84
  },] }
67
85
  ];
68
86
  DrDatePickerWithTimeframeComponent.ctorParameters = () => [
@@ -74,6 +92,8 @@ DrDatePickerWithTimeframeComponent.propDecorators = {
74
92
  isDashboardClassDisplayed: [{ type: HostBinding, args: ['class.dr-date-picker-on-dashboard',] }],
75
93
  isDashboardDatepicker: [{ type: Input }],
76
94
  dateFormatConfig: [{ type: Input }],
95
+ canSelectTimeframe: [{ type: Input }],
96
+ availableTimeframes: [{ type: Input }],
77
97
  onChangeFormat: [{ type: Output }]
78
98
  };
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker-with-timeframe.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAqB,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAClK,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AACnF,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAA2B,eAAe,EAAE,MAAM,4BAA4B,CAAC;AACtF,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAY3C,MAAM,OAAO,kCAAmC,SAAQ,qBAAqB;IA2B3E,YACY,GAAsB,EACtB,WAA6B,EAChC,iBAAsC;QAE7C,KAAK,CAAC,GAAG,EAAE,WAAW,EAAE,iBAAiB,CAAC,CAAC;QAJjC,QAAG,GAAH,GAAG,CAAmB;QACtB,gBAAW,GAAX,WAAW,CAAkB;QAChC,sBAAiB,GAAjB,iBAAiB,CAAqB;QAxBtC,0BAAqB,GAAG,KAAK,CAAC;QAG7B,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QAEtC,gBAAW,GAAG;YAC5B,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAE,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,CAAC,EAAE,OAAO,CAAC;YAC3F,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAE,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,EAAE,CAAC,EAAE,OAAO,CAAC;YAC/F,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAE,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,EAAE,CAAC,EAAE,OAAO,CAAC;YAC7F,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAE,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,CAAC,EAAE,OAAO,CAAC;SAC1F,CAAA;QAiBC,iBAAiB,CAAC,2BAA2B,GAAG,IAAI,CAAC;QAErD,iBAAiB,CAAC,OAAO;aACtB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAChC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;QACpE,CAAC,CAAC,CAAC;IACP,CAAC;IAtCD,IAAsD,yBAAyB;QAC7E,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IAAA,CAAC;IAcF,IAAW,uBAAuB;;QAChC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,OAAO,IAAI,CAAC,WAAW,CAAC;SACzB;QACD,OAAO,CAAA,MAAA,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,QAAQ,EAAE,0CAAE,QAAQ,CAAC,GAAG,CAAC;YAC7D,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC;YACtD,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAA;IAClE,CAAC;IAiBD,QAAQ;QACN,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,IAAI,CAAC,iBAAiB,CAAC,YAAY,mCAAQ,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAK,IAAI,CAAC,gBAAgB,CAAE,CAAC;SAC5G;IACH,CAAC;IAED,aAAa,CAAC,OAAgB;QAC5B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC;QAClH,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,UAAkB,EAAE,MAAc,EAAE,OAAgB;QACnE,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAC3F,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;;;YAlEF,SAAS,SAAC;gBACT,QAAQ,EAAE,+BAA+B;gBACzC,uhCAA6D;gBAE7D,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,SAAS,EAAE;oBACT,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,kCAAkC,EAAE,KAAK,EAAE,IAAI,EAAE;oBAC5F,EAAE,OAAO,EAAE,mBAAmB,EAAE;iBACjC;;aACF;;;YAjBgD,iBAAiB;YAEzD,WAAW;YACX,mBAAmB;;;wCAiBzB,WAAW,SAAC,mCAAmC;oCAI/C,KAAK;+BACL,KAAK;6BAEL,MAAM","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, Input, OnInit, OnDestroy, Output, EventEmitter } from '@angular/core';\nimport { DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { takeUntil } from 'rxjs/operators';\n\n@Component({\n  selector: 'dr-date-picker-with-timeframe',\n  templateUrl: './dr-date-picker-with-timeframe.component.html',\n  styleUrls: ['./dr-date-picker-with-timeframe.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },\n    { provide: DrDatePickerService }\n  ],\n})\nexport class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\n\n  @HostBinding('class.dr-date-picker-on-dashboard') get isDashboardClassDisplayed(): boolean {\n    return this.isDashboardDatepicker;\n  };\n\n  @Input() isDashboardDatepicker = false;\n  @Input() dateFormatConfig: IDatePickerFormatConfig;\n\n  @Output() onChangeFormat = new EventEmitter<string>();\n\n  public readonly pagingSetup = {\n    [TimeframeOption.YEAR]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n    [TimeframeOption.QUARTER]: (forward) =>  this.pagingDateChange('addCalendarMonths', 3, forward),\n    [TimeframeOption.MONTH]: (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n    [TimeframeOption.DAY]: (forward) =>  this.pagingDateChange('addCalendarDays', 1, forward)\n  }\n\n  public get displayedFormattedValue(): string {\n    if (!this.value) {\n      return this.placeholder;\n    }\n    return this.datePickerService.format$.getValue()?.includes('Q')\n      ? this.datePickerService.getQuarterDisplay(this.value)\n      : this.value.format(this.datePickerService.format$.getValue())\n  }\n\n  constructor(\n    protected cdr: ChangeDetectorRef,\n    protected dateAdapter: DateAdapter<any>,\n    public datePickerService: DrDatePickerService\n  ) {\n    super(cdr, dateAdapter, datePickerService);\n    datePickerService.isTimeframeSelectionEnabled = true;\n\n    datePickerService.format$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((value) => {\n        this.onChangeFormat.emit(datePickerService.normalizeValue(value));\n      });\n  }\n\n  ngOnInit() {\n    if (this.dateFormatConfig) {\n      this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...this.dateFormatConfig };\n    }\n  }\n\n  pagingClicked(forward: boolean): void {\n    this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);\n    this.datePicker.close();\n  }\n\n  pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n    const newValue = this.dateAdapter[actionCall](this.innerValue, forward ? amount : -amount);\n    this.setValueFromMoment(newValue);\n  }\n}\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker-with-timeframe.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, Input, OnInit, OnDestroy, Output, EventEmitter } from '@angular/core';\nimport { DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { takeUntil } from 'rxjs/operators';\n\n@Component({\n  selector: 'dr-date-picker-with-timeframe',\n  templateUrl: './dr-date-picker-with-timeframe.component.html',\n  styleUrls: ['./dr-date-picker-with-timeframe.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },\n    { provide: DrDatePickerService }\n  ],\n})\nexport class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\n\n  @HostBinding('class.dr-date-picker-on-dashboard') get isDashboardClassDisplayed(): boolean {\n    return this.isDashboardDatepicker;\n  };\n\n  @Input() isDashboardDatepicker = false;\n  @Input() set dateFormatConfig (value: IDatePickerFormatConfig) {\n    if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n    @Input() canSelectTimeframe = true;\n    @Input() set availableTimeframes (value: TimeframeOption[]){\n            if (value && value.length) {\n                this.datePickerService.availableTimeframes = value;\n            }\n        }\n\n  @Output() onChangeFormat = new EventEmitter<string>();\n\n  public readonly pagingSetup = {\n    [TimeframeOption.YEAR]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n    [TimeframeOption.QUARTER]: (forward) =>  this.pagingDateChange('addCalendarMonths', 3, forward),\n    [TimeframeOption.MONTH]: (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n    [TimeframeOption.DAY]: (forward) =>  this.pagingDateChange('addCalendarDays', 1, forward),\n    [TimeframeOption.WEEK]: (forward) =>  this.pagingDateChange('addCalendarDays', 7, forward)\n\n  }\n\n  public get displayedFormattedValue(): string {\n    if (!this.value) {\n      return this.placeholder;\n    }\n    const formatCached = this.datePickerService.format$.getValue()\n    switch (true) {\n        case formatCached?.includes('Q'):\n            return this.datePickerService.getQuarterDisplay(this.value);\n        case formatCached?.includes('W'):\n            return this.datePickerService.getWeekDisplay(this.value);\n        default:\n            return this.value.format(formatCached);\n    }\n  }\n\n  constructor(\n    protected cdr: ChangeDetectorRef,\n    protected dateAdapter: DateAdapter<any>,\n    public datePickerService: DrDatePickerService\n  ) {\n    super(cdr, dateAdapter, datePickerService);\n    datePickerService.isTimeframeSelectionEnabled = true;\n\n    datePickerService.format$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((value) => {\n        datePickerService.format$.getValue();\n        this.onChangeFormat.emit(datePickerService.normalizeValue(value));\n      });\n  }\n\n  ngOnInit() {\n    this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;\n    this.cdr.markForCheck();\n  }\n\n  pagingClicked(forward: boolean): void {\n    this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);\n    this.datePicker.close();\n  }\n\n  pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n    const newValue = this.dateAdapter[actionCall](this.innerValue, forward ? amount : -amount);\n    this.setValueFromMoment(newValue);\n  }\n}\n"]}
@@ -1,9 +1,9 @@
1
1
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject } from "@angular/core";
2
2
  import { Subject } from "rxjs";
3
- import { take, takeUntil } from 'rxjs/operators';
3
+ import { takeUntil } from 'rxjs/operators';
4
4
  import { MatCalendar } from '@angular/material/datepicker';
5
5
  import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
6
- import { CalendarView, CustomDateFormat } from "../../../models/datePicker";
6
+ import { CalendarView, CustomDateFormat, TimeframeOption } from "../../../models/datePicker";
7
7
  import { DrDatePickerService } from "../services/dr-date-picker.service";
8
8
  const moment = require('moment');
9
9
  export class DrDatePickerCustomHeaderComponent {
@@ -17,25 +17,37 @@ export class DrDatePickerCustomHeaderComponent {
17
17
  this.quarters = [1, 2, 3, 4];
18
18
  this.selectedQuarter = 1;
19
19
  this.timeframeOptions = [{
20
- title: 'Day',
20
+ timeframe: TimeframeOption.DAY,
21
21
  value: CalendarView.FOR_DAYS,
22
+ title: 'Day',
22
23
  format: this.datePickerService.formatConfig.day,
23
24
  periodLabel: () => this._dateAdapter
24
25
  .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)
25
26
  .toLocaleUpperCase()
26
27
  }, {
27
- title: 'Month',
28
+ timeframe: TimeframeOption.WEEK,
29
+ value: CalendarView.FOR_DAYS,
30
+ title: 'Week',
31
+ format: this.datePickerService.formatConfig.week,
32
+ periodLabel: () => this._dateAdapter
33
+ .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)
34
+ .toLocaleUpperCase()
35
+ }, {
36
+ timeframe: TimeframeOption.MONTH,
28
37
  value: CalendarView.FOR_MONTHS,
38
+ title: 'Month',
29
39
  format: this.datePickerService.formatConfig.month,
30
40
  periodLabel: () => String(moment(this._calendar.activeDate).year())
31
41
  }, {
32
- title: 'Quarter',
42
+ timeframe: TimeframeOption.QUARTER,
33
43
  value: CalendarView.FOR_QUARTERS,
44
+ title: 'Quarter',
34
45
  format: this.datePickerService.formatConfig.quarter,
35
46
  periodLabel: () => String(moment(this._calendar.activeDate).year())
36
47
  }, {
37
- title: 'Year',
48
+ timeframe: TimeframeOption.YEAR,
38
49
  value: CalendarView.FOR_YEARS,
50
+ title: 'Year',
39
51
  format: this.datePickerService.formatConfig.year,
40
52
  periodLabel: () => {
41
53
  const currentYear = moment(this._calendar.activeDate).year();
@@ -56,10 +68,14 @@ export class DrDatePickerCustomHeaderComponent {
56
68
  this.calendarView = CalendarView;
57
69
  _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
58
70
  this.datePickerService.format$
59
- .pipe(take(1))
71
+ .pipe(takeUntil(this._destroyed))
60
72
  .subscribe(value => {
61
73
  this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;
74
+ _calendar.currentView = this.selectedTimeframe;
62
75
  this.setPeriodLabels();
76
+ if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {
77
+ this.selectedQuarter = moment(this._calendar.activeDate).quarter();
78
+ }
63
79
  });
64
80
  _calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
65
81
  }
@@ -70,7 +86,7 @@ export class DrDatePickerCustomHeaderComponent {
70
86
  setPeriodLabels() {
71
87
  const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];
72
88
  const fullPeriodLabel = currentTimeframeOption.periodLabel();
73
- if (this._calendar.currentView === 'month') {
89
+ if (this._calendar.currentView === CalendarView.FOR_DAYS) {
74
90
  this.periodMonthLabel = fullPeriodLabel.slice(0, 3);
75
91
  this.periodYearLabel = fullPeriodLabel.slice(4);
76
92
  }
@@ -114,7 +130,7 @@ export class DrDatePickerCustomHeaderComponent {
114
130
  DrDatePickerCustomHeaderComponent.decorators = [
115
131
  { type: Component, args: [{
116
132
  selector: 'dr-date-picker_custom-header.component',
117
- template: "<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n <dr-select\n class=\"dr-datepicker__timeframe-select\"\n [(ngModel)]=\"selectedTimeframe\"\n [items]=\"timeframeOptions\"\n bindLabel=\"title\"\n bindValue=\"value\"\n (ngModelChange)=\"setTimeframe()\">\n </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n <div class=\"dr-date-paging flip-page-button\"\n (click)=\"pagingClicked(false)\">\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n </div>\n <span class=\"example-header-label\">\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{periodMonthLabel + ' '}}</span>\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{periodYearLabel}}</span>\n </span>\n <div class=\"dr-date-paging flip-page-button\"\n (click)=\"pagingClicked(true)\">\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n <div *ngFor=\"let quarter of quarters\"\n class=\"quarter-selector\" (click)=\"onSelectQuarter(quarter)\"\n [class]=\"quarter == selectedQuarter ? 'selected' : ''\"\n >Q{{quarter}}</div>\n</div>\n\n",
133
+ template: "<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n <dr-select\n class=\"dr-datepicker__timeframe-select\"\n [(ngModel)]=\"selectedTimeframe\"\n [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n bindLabel=\"title\"\n bindValue=\"value\"\n (ngModelChange)=\"setTimeframe()\">\n </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n <div class=\"dr-date-paging flip-page-button\"\n (click)=\"pagingClicked(false)\">\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n </div>\n <span class=\"example-header-label\">\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{periodMonthLabel + ' '}}</span>\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{periodYearLabel}}</span>\n </span>\n <div class=\"dr-date-paging flip-page-button\"\n (click)=\"pagingClicked(true)\">\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n <div *ngFor=\"let quarter of quarters\"\n class=\"quarter-selector\" (click)=\"onSelectQuarter(quarter)\"\n [class]=\"quarter == selectedQuarter ? 'selected' : ''\"\n >Q{{quarter}}</div>\n</div>\n\n",
118
134
  changeDetection: ChangeDetectionStrategy.OnPush,
119
135
  styles: [":host{height:54px;align-items:center;font-family:\"Poppins\";font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 8px;grid-gap:4px;gap:4px}.dr-date-paging.flip-page-button{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button:hover{border-radius:50%;background:#F2F2FB;color:#4646ce}.example-header-label{cursor:pointer}.dr-quarterly-datepicker{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker .quarter-selector{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker .quarter-selector:hover{background:#F2F2FB;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker .quarter-selector.selected{background-color:#4646ce;color:#f3f7ff;font-weight:600}\n"]
120
136
  },] }
@@ -126,4 +142,4 @@ DrDatePickerCustomHeaderComponent.ctorParameters = () => [
126
142
  { type: ChangeDetectorRef },
127
143
  { type: DrDatePickerService }
128
144
  ];
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, OnDestroy, ChangeDetectorRef, Component, Inject } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { take, takeUntil } from 'rxjs/operators';\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\nimport { DateAdapter, MAT_DATE_FORMATS} from '@angular/material/core';\nimport { CalendarView, CustomDateFormat, TCalendarView } from \"../../../models/datePicker\";\nimport { DrDatePickerService } from \"../services/dr-date-picker.service\";\n\nconst moment = require('moment');\n\nexport interface ITimeframeOption {\n      title: string,\n      value: TCalendarView,\n      format: string,\n      periodLabel: () => string\n}\n\n@Component({\n    selector: 'dr-date-picker_custom-header.component',\n    templateUrl: 'dr-date-picker_custom-header.component.html',\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n  })\n\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy {\n    private _destroyed = new Subject<void>();\n    quarters = [1, 2, 3, 4];\n    selectedQuarter = 1;\n    timeframeOptions: ITimeframeOption[] = [{\n      title: 'Day',\n      value: CalendarView.FOR_DAYS,\n      format: this.datePickerService.formatConfig.day,\n      periodLabel: () => this._dateAdapter\n        .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\n        .toLocaleUpperCase()\n    },{\n      title: 'Month',\n      value: CalendarView.FOR_MONTHS,\n      format: this.datePickerService.formatConfig.month,\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n      title: 'Quarter',\n      value: CalendarView.FOR_QUARTERS,\n      format: this.datePickerService.formatConfig.quarter,\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n      title: 'Year',\n      value: CalendarView.FOR_YEARS,\n      format: this.datePickerService.formatConfig.year,\n      periodLabel:  () => {\n        const currentYear = moment(this._calendar.activeDate).year();\n        const startPeriod = Math.floor(currentYear/24)*24;\n        return startPeriod + '-' + (startPeriod + 23);\n      }\n    }]\n\n    pagingSetup = {\n      [CalendarView.FOR_MONTHS]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n      [CalendarView.FOR_QUARTERS]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n      [CalendarView.FOR_DAYS]: (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n      [CalendarView.FOR_YEARS]: (forward) =>  this.pagingDateChange('addCalendarYears', 24, forward)\n    }\n\n    selectedTimeframe: TCalendarView = CalendarView.FOR_DAYS;\n    timeframeSelection = false;\n    periodMonthLabel = '';\n    periodYearLabel = '';\n\n    public readonly calendarView = CalendarView;\n\n    constructor(\n        private _calendar: MatCalendar<Moment>,\n        private _dateAdapter: DateAdapter<Moment>,\n        @Inject(MAT_DATE_FORMATS) private _dateFormats: CustomDateFormat,\n        private cdr: ChangeDetectorRef,\n        public datePickerService: DrDatePickerService) {\n          _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n          this.datePickerService.format$\n            .pipe(take(1))\n            .subscribe( value => {\n              this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;\n              this.setPeriodLabels();\n            });\n          _calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n    }\n\n    ngOnDestroy() {\n      this._destroyed.next();\n      this._destroyed.complete();\n    }\n\n    setPeriodLabels() {\n      const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];\n      const fullPeriodLabel = currentTimeframeOption.periodLabel();\n      if (this._calendar.currentView === 'month') {\n        this.periodMonthLabel = fullPeriodLabel.slice(0,3);\n        this.periodYearLabel = fullPeriodLabel.slice(4);\n      } else {\n        this.periodMonthLabel = '';\n        this.periodYearLabel = fullPeriodLabel;\n      }\n      this.cdr.markForCheck();\n    }\n\n    setTimeframe() {\n      this.timeframeSelection = false;\n      this._calendar.currentView = this.selectedTimeframe as MatCalendarView;\n      const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\n      this.datePickerService.updateTimeframeAndFormat(chosenTimeframeOption.format);\n\n      if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n      }\n    }\n\n    get currentViewIsQuarter() {\n      return ![CalendarView.FOR_DAYS, CalendarView.FOR_MONTHS, CalendarView.FOR_YEARS].includes(this._calendar.currentView as CalendarView);\n    }\n\n    switchViewOnClickOnPeriodLabel(view: CalendarView.FOR_MONTHS | CalendarView.FOR_YEARS) {\n      this._calendar.currentView = view;\n    }\n\n    onSelectQuarter(quarterNumber: number) {\n      const monthsInQuarter = 3;\n      this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n\n      const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate,\n      monthsInQuarter * (quarterNumber - this.selectedQuarter));\n      this._calendar.activeDate = unadaptedDate;\n      this.datePickerService.updatedQuarter$.next(moment(unadaptedDate));\n      this.datePickerService.calendarInstance.close();\n    }\n\n    pagingClicked(forward) {\n      this.pagingSetup[this._calendar.currentView] && this.pagingSetup[this._calendar.currentView](forward);\n    }\n\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n      this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward? amount: - amount);\n      this.setPeriodLabels();\n    }\n  }\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, OnDestroy, ChangeDetectorRef, Component, Inject } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { take, takeUntil } from 'rxjs/operators';\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\nimport { DateAdapter, MAT_DATE_FORMATS} from '@angular/material/core';\nimport { CalendarView, CustomDateFormat, TCalendarView, TimeframeOption } from \"../../../models/datePicker\";\nimport { DrDatePickerService } from \"../services/dr-date-picker.service\";\n\nconst moment = require('moment');\n\nexport interface ITimeframeOption {\n    timeframe:TimeframeOption,\n    title: string,\n    value: TCalendarView,\n    format: string,\n    periodLabel: () => string\n}\n\n@Component({\n    selector: 'dr-date-picker_custom-header.component',\n    templateUrl: 'dr-date-picker_custom-header.component.html',\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n  })\n\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy {\n    private _destroyed = new Subject<void>();\n    quarters = [1, 2, 3, 4];\n    selectedQuarter = 1;\n    timeframeOptions: ITimeframeOption[] = [{\n        timeframe: TimeframeOption.DAY,\n        value: CalendarView.FOR_DAYS,\n        title: 'Day',\n        format: this.datePickerService.formatConfig.day,\n        periodLabel: () => this._dateAdapter\n            .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\n            .toLocaleUpperCase()\n    },{\n        timeframe: TimeframeOption.WEEK,\n        value: CalendarView.FOR_DAYS,\n        title: 'Week',\n        format: this.datePickerService.formatConfig.week,\n        periodLabel: () => this._dateAdapter\n          .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\n          .toLocaleUpperCase()\n    },{\n        timeframe: TimeframeOption.MONTH,\n        value: CalendarView.FOR_MONTHS,\n        title: 'Month',\n        format: this.datePickerService.formatConfig.month,\n        periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n        timeframe: TimeframeOption.QUARTER,\n        value: CalendarView.FOR_QUARTERS,\n        title: 'Quarter',\n        format: this.datePickerService.formatConfig.quarter,\n        periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n        timeframe: TimeframeOption.YEAR,\n        value: CalendarView.FOR_YEARS,\n        title: 'Year',\n        format: this.datePickerService.formatConfig.year,\n        periodLabel:  () => {\n            const currentYear = moment(this._calendar.activeDate).year();\n            const startPeriod = Math.floor(currentYear/24)*24;\n            return startPeriod + '-' + (startPeriod + 23);\n        }\n    }]\n\n    pagingSetup = {\n        [CalendarView.FOR_MONTHS]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n        [CalendarView.FOR_QUARTERS]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n        [CalendarView.FOR_DAYS]: (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n        [CalendarView.FOR_YEARS]: (forward) =>  this.pagingDateChange('addCalendarYears', 24, forward)\n    }\n\n    selectedTimeframe: TCalendarView = CalendarView.FOR_DAYS;\n    timeframeSelection = false;\n    periodMonthLabel = '';\n    periodYearLabel = '';\n\n    public readonly calendarView = CalendarView;\n\n    constructor(\n        private _calendar: MatCalendar<Moment>,\n        private _dateAdapter: DateAdapter<Moment>,\n        @Inject(MAT_DATE_FORMATS) private _dateFormats: CustomDateFormat,\n        private cdr: ChangeDetectorRef,\n        public datePickerService: DrDatePickerService) {\n            _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n            this.datePickerService.format$\n                .pipe(takeUntil(this._destroyed))\n                .subscribe( value => {\n                    this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;\n                    _calendar.currentView = this.selectedTimeframe as MatCalendarView;\n                    this.setPeriodLabels();\n                    if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n                        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n                    }\n                });\n                _calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n    }\n\n    ngOnDestroy() {\n        this._destroyed.next();\n        this._destroyed.complete();\n    }\n\n    setPeriodLabels() {\n        const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];\n        const fullPeriodLabel = currentTimeframeOption.periodLabel();\n        if (this._calendar.currentView === CalendarView.FOR_DAYS) {\n            this.periodMonthLabel = fullPeriodLabel.slice(0,3);\n            this.periodYearLabel = fullPeriodLabel.slice(4);\n        } else {\n            this.periodMonthLabel = '';\n            this.periodYearLabel = fullPeriodLabel;\n        }\n        this.cdr.markForCheck();\n    }\n\n    setTimeframe() {\n        this.timeframeSelection = false;\n        this._calendar.currentView = this.selectedTimeframe as MatCalendarView;\n        const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\n        this.datePickerService.updateTimeframeAndFormat(chosenTimeframeOption.format);\n\n        if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n            this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n        }\n    }\n\n    get currentViewIsQuarter() {\n        return ![CalendarView.FOR_DAYS, CalendarView.FOR_MONTHS, CalendarView.FOR_YEARS].includes(this._calendar.currentView as CalendarView);\n    }\n\n    switchViewOnClickOnPeriodLabel(view: CalendarView.FOR_MONTHS | CalendarView.FOR_YEARS) {\n        this._calendar.currentView = view;\n    }\n\n    onSelectQuarter(quarterNumber: number) {\n        const monthsInQuarter = 3;\n        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n\n        const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate,\n        monthsInQuarter * (quarterNumber - this.selectedQuarter));\n        this._calendar.activeDate = unadaptedDate;\n        this.datePickerService.updatedQuarter$.next(moment(unadaptedDate));\n        this.datePickerService.calendarInstance.close();\n    }\n\n    pagingClicked(forward) {\n        this.pagingSetup[this._calendar.currentView] && this.pagingSetup[this._calendar.currentView](forward);\n    }\n\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n        this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward? amount: - amount);\n        this.setPeriodLabels();\n    }\n  }\n"]}
@@ -0,0 +1,12 @@
1
+ import { Pipe } from '@angular/core';
2
+ export class DrShowTimeframePipe {
3
+ transform(arr, showOptions) {
4
+ return arr.filter(item => showOptions.includes(item.timeframe));
5
+ }
6
+ }
7
+ DrShowTimeframePipe.decorators = [
8
+ { type: Pipe, args: [{
9
+ name: 'drShowTimeframePipe'
10
+ },] }
11
+ ];
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc2hvdy10aW1lZnJhbWUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZHItc2hvdy10aW1lZnJhbWUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQU9wRCxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCLFNBQVMsQ0FBQyxHQUF1QixFQUFFLFdBQThCO1FBQy9ELE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDbEUsQ0FBQzs7O1lBTkYsSUFBSSxTQUFDO2dCQUNKLElBQUksRUFBRSxxQkFBcUI7YUFDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaW1lZnJhbWVPcHRpb24gfSBmcm9tICcuLi8uLi9tb2RlbHMvZGF0ZVBpY2tlcic7XG5pbXBvcnQgeyBJVGltZWZyYW1lT3B0aW9uIH0gZnJvbSAnLi9kci1kYXRlLXBpY2tlcl9jdXN0b20taGVhZGVyL2RyLWRhdGUtcGlja2VyX2N1c3RvbS1oZWFkZXIuY29tcG9uZW50JztcblxuQFBpcGUoe1xuICBuYW1lOiAnZHJTaG93VGltZWZyYW1lUGlwZSdcbn0pXG5leHBvcnQgY2xhc3MgRHJTaG93VGltZWZyYW1lUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oYXJyOiBJVGltZWZyYW1lT3B0aW9uW10sIHNob3dPcHRpb25zOiBUaW1lZnJhbWVPcHRpb25bXSk6IElUaW1lZnJhbWVPcHRpb25bXSB7XG4gICAgcmV0dXJuIGFyci5maWx0ZXIoaXRlbSA9PiBzaG93T3B0aW9ucy5pbmNsdWRlcyhpdGVtLnRpbWVmcmFtZSkpO1xuICB9XG59Il19
@@ -7,15 +7,26 @@ export class DrDatePickerService {
7
7
  this.timeframe = TimeframeOption.DAY;
8
8
  this.format$ = new BehaviorSubject(DateFromats.MAT_DEFAULT_DATE_FORMAT);
9
9
  this.updatedQuarter$ = new Subject();
10
+ this.availableTimeframes = [
11
+ TimeframeOption.DAY,
12
+ TimeframeOption.WEEK,
13
+ TimeframeOption.MONTH,
14
+ TimeframeOption.QUARTER,
15
+ TimeframeOption.YEAR
16
+ ];
10
17
  this.formatConfig = {
11
18
  day: DateFromats.MAT_DEFAULT_DATE_FORMAT,
12
19
  month: DateFromats.MONTH_YEAR_FORMAT,
13
20
  year: DateFromats.YEAR_FORMAT,
14
21
  quarter: DateFromats.QUARTER_FORMAT,
22
+ week: DateFromats.WEEK_FORMAT
15
23
  };
16
24
  }
17
25
  getQuarterDisplay(value) {
18
- return 'Q' + value.quarter() + this.format$.getValue().charAt(1) + value.year();
26
+ return 'Q' + value.format(this.formatConfig.quarter);
27
+ }
28
+ getWeekDisplay(value) {
29
+ return 'W' + value.format(this.formatConfig.week);
19
30
  }
20
31
  getTimeframe(format) {
21
32
  const defaultFrame = TimeframeOption.DAY;
@@ -30,6 +41,8 @@ export class DrDatePickerService {
30
41
  return TimeframeOption.DAY;
31
42
  case lowerCaseFormat.includes('m'):
32
43
  return TimeframeOption.MONTH;
44
+ case lowerCaseFormat.includes('w'):
45
+ return TimeframeOption.WEEK;
33
46
  case lowerCaseFormat.includes('y'):
34
47
  return TimeframeOption.YEAR;
35
48
  default:
@@ -51,4 +64,4 @@ export class DrDatePickerService {
51
64
  DrDatePickerService.decorators = [
52
65
  { type: Injectable }
53
66
  ];
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZGF0ZS1waWNrZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvc2VydmljZXMvZHItZGF0ZS1waWNrZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzNDLE9BQU8sRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2hELE9BQU8sRUFBMkIsV0FBVyxFQUFvQixlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUdySCxNQUFNLE9BQU8sbUJBQW1CO0lBRGhDO1FBRUksZ0NBQTJCLEdBQUcsS0FBSyxDQUFDO1FBQ3BDLGNBQVMsR0FBcUIsZUFBZSxDQUFDLEdBQUcsQ0FBQztRQUNsRCxZQUFPLEdBQUcsSUFBSSxlQUFlLENBQVMsV0FBVyxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDM0Usb0JBQWUsR0FBRyxJQUFJLE9BQU8sRUFBVSxDQUFDO1FBR2pDLGlCQUFZLEdBQTRCO1lBQzdDLEdBQUcsRUFBRSxXQUFXLENBQUMsdUJBQXVCO1lBQ3hDLEtBQUssRUFBRSxXQUFXLENBQUMsaUJBQWlCO1lBQ3BDLElBQUksRUFBRSxXQUFXLENBQUMsV0FBVztZQUM3QixPQUFPLEVBQUUsV0FBVyxDQUFDLGNBQWM7U0FDcEMsQ0FBQztJQTBDTixDQUFDO0lBeENHLGlCQUFpQixDQUFDLEtBQWE7UUFDN0IsT0FBTyxHQUFHLEdBQUcsS0FBSyxDQUFDLE9BQU8sRUFBRSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNsRixDQUFDO0lBRUQsWUFBWSxDQUFDLE1BQWM7UUFFekIsTUFBTSxZQUFZLEdBQUcsZUFBZSxDQUFDLEdBQUcsQ0FBQztRQUV6QyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsT0FBTyxZQUFZLENBQUM7U0FDckI7UUFFRCxNQUFNLGVBQWUsR0FBRyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDN0MsUUFBUSxJQUFJLEVBQUU7WUFDWixLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO2dCQUNoQyxPQUFPLGVBQWUsQ0FBQyxPQUFPLENBQUM7WUFDakMsS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQztnQkFDaEMsT0FBTyxlQUFlLENBQUMsR0FBRyxDQUFDO1lBQzdCLEtBQUssZUFBZSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUM7Z0JBQ2hDLE9BQU8sZUFBZSxDQUFDLEtBQUssQ0FBQztZQUMvQixLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO2dCQUNoQyxPQUFPLGVBQWUsQ0FBQyxJQUFJLENBQUM7WUFDOUI7Z0JBQ0UsT0FBTyxZQUFZLENBQUM7U0FDdkI7SUFDSCxDQUFDO0lBRUQsbUJBQW1CLENBQUMsU0FBMkI7UUFDN0MsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCx3QkFBd0IsQ0FBQyxNQUFjO1FBQ3JDLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFBO1FBQy9FLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ3JELElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsY0FBYyxDQUFDLEtBQUs7UUFDbEIsT0FBTyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztJQUNsQyxDQUFDOzs7WUF0REosVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgTWF0RGF0ZXBpY2tlciB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kYXRlcGlja2VyXCI7XG5pbXBvcnQgeyBNb21lbnQgfSBmcm9tICdtb21lbnQnO1xuaW1wb3J0IHsgU3ViamVjdCwgQmVoYXZpb3JTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7IElEYXRlUGlja2VyRm9ybWF0Q29uZmlnLCBEYXRlRnJvbWF0cywgVFRpbWVmcmFtZU9wdGlvbiwgVGltZWZyYW1lT3B0aW9uIH0gZnJvbSBcIi4uLy4uLy4uL21vZGVscy9kYXRlUGlja2VyXCI7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBEckRhdGVQaWNrZXJTZXJ2aWNlIHtcbiAgICBpc1RpbWVmcmFtZVNlbGVjdGlvbkVuYWJsZWQgPSBmYWxzZTtcbiAgICB0aW1lZnJhbWU6IFRUaW1lZnJhbWVPcHRpb24gPSBUaW1lZnJhbWVPcHRpb24uREFZO1xuICAgIGZvcm1hdCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PHN0cmluZz4oRGF0ZUZyb21hdHMuTUFUX0RFRkFVTFRfREFURV9GT1JNQVQpO1xuICAgIHVwZGF0ZWRRdWFydGVyJCA9IG5ldyBTdWJqZWN0PE1vbWVudD4oKTtcbiAgICBjYWxlbmRhckluc3RhbmNlOiBNYXREYXRlcGlja2VyPGFueT47XG5cbiAgICBwdWJsaWMgZm9ybWF0Q29uZmlnOiBJRGF0ZVBpY2tlckZvcm1hdENvbmZpZyA9IHtcbiAgICAgIGRheTogRGF0ZUZyb21hdHMuTUFUX0RFRkFVTFRfREFURV9GT1JNQVQsXG4gICAgICBtb250aDogRGF0ZUZyb21hdHMuTU9OVEhfWUVBUl9GT1JNQVQsXG4gICAgICB5ZWFyOiBEYXRlRnJvbWF0cy5ZRUFSX0ZPUk1BVCxcbiAgICAgIHF1YXJ0ZXI6IERhdGVGcm9tYXRzLlFVQVJURVJfRk9STUFULFxuICAgIH07XG5cbiAgICBnZXRRdWFydGVyRGlzcGxheSh2YWx1ZTogTW9tZW50KTogc3RyaW5nIHtcbiAgICAgIHJldHVybiAnUScgKyB2YWx1ZS5xdWFydGVyKCkgKyB0aGlzLmZvcm1hdCQuZ2V0VmFsdWUoKS5jaGFyQXQoMSkgKyB2YWx1ZS55ZWFyKCk7XG4gICAgfVxuXG4gICAgZ2V0VGltZWZyYW1lKGZvcm1hdDogc3RyaW5nKSB7XG5cbiAgICAgIGNvbnN0IGRlZmF1bHRGcmFtZSA9IFRpbWVmcmFtZU9wdGlvbi5EQVk7XG5cbiAgICAgIGlmICghZm9ybWF0KSB7XG4gICAgICAgIHJldHVybiBkZWZhdWx0RnJhbWU7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGxvd2VyQ2FzZUZvcm1hdCA9IGZvcm1hdC50b0xvd2VyQ2FzZSgpO1xuICAgICAgc3dpdGNoICh0cnVlKSB7XG4gICAgICAgIGNhc2UgbG93ZXJDYXNlRm9ybWF0LmluY2x1ZGVzKCdxJyk6XG4gICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5RVUFSVEVSO1xuICAgICAgICBjYXNlIGxvd2VyQ2FzZUZvcm1hdC5pbmNsdWRlcygnZCcpOlxuICAgICAgICAgIHJldHVybiBUaW1lZnJhbWVPcHRpb24uREFZO1xuICAgICAgICBjYXNlIGxvd2VyQ2FzZUZvcm1hdC5pbmNsdWRlcygnbScpOlxuICAgICAgICAgIHJldHVybiBUaW1lZnJhbWVPcHRpb24uTU9OVEg7XG4gICAgICAgIGNhc2UgbG93ZXJDYXNlRm9ybWF0LmluY2x1ZGVzKCd5Jyk6XG4gICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5ZRUFSO1xuICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgIHJldHVybiBkZWZhdWx0RnJhbWU7XG4gICAgICB9XG4gICAgfVxuXG4gICAgZ2V0Q29uZmlndXJlZEZvcm1hdCh0aW1lZnJhbWU6IFRUaW1lZnJhbWVPcHRpb24pIHtcbiAgICAgIHJldHVybiB0aGlzLmZvcm1hdENvbmZpZ1t0aW1lZnJhbWVdO1xuICAgIH1cblxuICAgIHVwZGF0ZVRpbWVmcmFtZUFuZEZvcm1hdChmb3JtYXQ6IHN0cmluZyk6IHZvaWQge1xuICAgICAgY29uc3Qgbm9ybWFsaXplZEZvcm1hdCA9IHRoaXMubm9ybWFsaXplVmFsdWUoZm9ybWF0IHx8IHRoaXMuZm9ybWF0JC5nZXRWYWx1ZSgpKVxuICAgICAgdGhpcy50aW1lZnJhbWUgPSB0aGlzLmdldFRpbWVmcmFtZShub3JtYWxpemVkRm9ybWF0KTtcbiAgICAgIHRoaXMuZm9ybWF0JC5uZXh0KHRoaXMuZ2V0Q29uZmlndXJlZEZvcm1hdCh0aGlzLnRpbWVmcmFtZSkpO1xuICAgIH1cblxuICAgIG5vcm1hbGl6ZVZhbHVlKHZhbHVlKSB7XG4gICAgICByZXR1cm4gdmFsdWUucmVwbGFjZSgvZC9nLCAnRCcpO1xuICAgIH1cbn1cbiJdfQ==
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZGF0ZS1waWNrZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvc2VydmljZXMvZHItZGF0ZS1waWNrZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzNDLE9BQU8sRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2hELE9BQU8sRUFBMkIsV0FBVyxFQUFvQixlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUdySCxNQUFNLE9BQU8sbUJBQW1CO0lBRGhDO1FBRUksZ0NBQTJCLEdBQUcsS0FBSyxDQUFDO1FBQ3BDLGNBQVMsR0FBcUIsZUFBZSxDQUFDLEdBQUcsQ0FBQztRQUNsRCxZQUFPLEdBQUcsSUFBSSxlQUFlLENBQVMsV0FBVyxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDM0Usb0JBQWUsR0FBRyxJQUFJLE9BQU8sRUFBVSxDQUFDO1FBRXhDLHdCQUFtQixHQUFHO1lBQ2xCLGVBQWUsQ0FBQyxHQUFHO1lBQ25CLGVBQWUsQ0FBQyxJQUFJO1lBQ3BCLGVBQWUsQ0FBQyxLQUFLO1lBQ3JCLGVBQWUsQ0FBQyxPQUFPO1lBQ3ZCLGVBQWUsQ0FBQyxJQUFJO1NBQ3ZCLENBQUM7UUFFSyxpQkFBWSxHQUE0QjtZQUMzQyxHQUFHLEVBQUUsV0FBVyxDQUFDLHVCQUF1QjtZQUN4QyxLQUFLLEVBQUUsV0FBVyxDQUFDLGlCQUFpQjtZQUNwQyxJQUFJLEVBQUUsV0FBVyxDQUFDLFdBQVc7WUFDN0IsT0FBTyxFQUFFLFdBQVcsQ0FBQyxjQUFjO1lBQ25DLElBQUksRUFBRSxXQUFXLENBQUMsV0FBVztTQUNoQyxDQUFDO0lBK0NOLENBQUM7SUE3Q0csaUJBQWlCLENBQUMsS0FBYTtRQUMzQixPQUFPLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFhO1FBQ3hCLE9BQU8sR0FBRyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRUQsWUFBWSxDQUFDLE1BQWM7UUFDdkIsTUFBTSxZQUFZLEdBQUcsZUFBZSxDQUFDLEdBQUcsQ0FBQztRQUV6QyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1QsT0FBTyxZQUFZLENBQUM7U0FDdkI7UUFFRCxNQUFNLGVBQWUsR0FBRyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDekMsUUFBUSxJQUFJLEVBQUU7WUFDVixLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO2dCQUM5QixPQUFPLGVBQWUsQ0FBQyxPQUFPLENBQUM7WUFDbkMsS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQztnQkFDOUIsT0FBTyxlQUFlLENBQUMsR0FBRyxDQUFDO1lBQy9CLEtBQUssZUFBZSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUM7Z0JBQzlCLE9BQU8sZUFBZSxDQUFDLEtBQUssQ0FBQztZQUNqQyxLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO2dCQUM5QixPQUFPLGVBQWUsQ0FBQyxJQUFJLENBQUM7WUFDaEMsS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQztnQkFDOUIsT0FBTyxlQUFlLENBQUMsSUFBSSxDQUFDO1lBQ2hDO2dCQUNJLE9BQU8sWUFBWSxDQUFDO1NBQzNCO0lBQ1QsQ0FBQztJQUVELG1CQUFtQixDQUFDLFNBQTJCO1FBQzNDLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsd0JBQXdCLENBQUMsTUFBYztRQUNuQyxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtRQUMvRSxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUNyRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFLO1FBQ2hCLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDcEMsQ0FBQzs7O1lBbkVKLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1hdERhdGVwaWNrZXIgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZGF0ZXBpY2tlclwiO1xuaW1wb3J0IHsgTW9tZW50IH0gZnJvbSAnbW9tZW50JztcbmltcG9ydCB7IFN1YmplY3QsIEJlaGF2aW9yU3ViamVjdCB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyBJRGF0ZVBpY2tlckZvcm1hdENvbmZpZywgRGF0ZUZyb21hdHMsIFRUaW1lZnJhbWVPcHRpb24sIFRpbWVmcmFtZU9wdGlvbiB9IGZyb20gXCIuLi8uLi8uLi9tb2RlbHMvZGF0ZVBpY2tlclwiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRHJEYXRlUGlja2VyU2VydmljZSB7XG4gICAgaXNUaW1lZnJhbWVTZWxlY3Rpb25FbmFibGVkID0gZmFsc2U7XG4gICAgdGltZWZyYW1lOiBUVGltZWZyYW1lT3B0aW9uID0gVGltZWZyYW1lT3B0aW9uLkRBWTtcbiAgICBmb3JtYXQkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxzdHJpbmc+KERhdGVGcm9tYXRzLk1BVF9ERUZBVUxUX0RBVEVfRk9STUFUKTtcbiAgICB1cGRhdGVkUXVhcnRlciQgPSBuZXcgU3ViamVjdDxNb21lbnQ+KCk7XG4gICAgY2FsZW5kYXJJbnN0YW5jZTogTWF0RGF0ZXBpY2tlcjxhbnk+O1xuICAgIGF2YWlsYWJsZVRpbWVmcmFtZXMgPSBbXG4gICAgICAgIFRpbWVmcmFtZU9wdGlvbi5EQVksXG4gICAgICAgIFRpbWVmcmFtZU9wdGlvbi5XRUVLLFxuICAgICAgICBUaW1lZnJhbWVPcHRpb24uTU9OVEgsXG4gICAgICAgIFRpbWVmcmFtZU9wdGlvbi5RVUFSVEVSLFxuICAgICAgICBUaW1lZnJhbWVPcHRpb24uWUVBUlxuICAgIF07XG5cbiAgICBwdWJsaWMgZm9ybWF0Q29uZmlnOiBJRGF0ZVBpY2tlckZvcm1hdENvbmZpZyA9IHtcbiAgICAgICAgZGF5OiBEYXRlRnJvbWF0cy5NQVRfREVGQVVMVF9EQVRFX0ZPUk1BVCxcbiAgICAgICAgbW9udGg6IERhdGVGcm9tYXRzLk1PTlRIX1lFQVJfRk9STUFULFxuICAgICAgICB5ZWFyOiBEYXRlRnJvbWF0cy5ZRUFSX0ZPUk1BVCxcbiAgICAgICAgcXVhcnRlcjogRGF0ZUZyb21hdHMuUVVBUlRFUl9GT1JNQVQsXG4gICAgICAgIHdlZWs6IERhdGVGcm9tYXRzLldFRUtfRk9STUFUXG4gICAgfTtcblxuICAgIGdldFF1YXJ0ZXJEaXNwbGF5KHZhbHVlOiBNb21lbnQpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gJ1EnICsgdmFsdWUuZm9ybWF0KHRoaXMuZm9ybWF0Q29uZmlnLnF1YXJ0ZXIpO1xuICAgIH1cblxuICAgIGdldFdlZWtEaXNwbGF5KHZhbHVlOiBNb21lbnQpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gJ1cnICsgdmFsdWUuZm9ybWF0KHRoaXMuZm9ybWF0Q29uZmlnLndlZWspO1xuICAgIH1cblxuICAgIGdldFRpbWVmcmFtZShmb3JtYXQ6IHN0cmluZykge1xuICAgICAgICBjb25zdCBkZWZhdWx0RnJhbWUgPSBUaW1lZnJhbWVPcHRpb24uREFZO1xuXG4gICAgICAgIGlmICghZm9ybWF0KSB7XG4gICAgICAgICAgICByZXR1cm4gZGVmYXVsdEZyYW1lO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgbG93ZXJDYXNlRm9ybWF0ID0gZm9ybWF0LnRvTG93ZXJDYXNlKCk7XG4gICAgICAgICAgICBzd2l0Y2ggKHRydWUpIHtcbiAgICAgICAgICAgICAgICBjYXNlIGxvd2VyQ2FzZUZvcm1hdC5pbmNsdWRlcygncScpOlxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gVGltZWZyYW1lT3B0aW9uLlFVQVJURVI7XG4gICAgICAgICAgICAgICAgY2FzZSBsb3dlckNhc2VGb3JtYXQuaW5jbHVkZXMoJ2QnKTpcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5EQVk7XG4gICAgICAgICAgICAgICAgY2FzZSBsb3dlckNhc2VGb3JtYXQuaW5jbHVkZXMoJ20nKTpcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5NT05USDtcbiAgICAgICAgICAgICAgICBjYXNlIGxvd2VyQ2FzZUZvcm1hdC5pbmNsdWRlcygndycpOlxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gVGltZWZyYW1lT3B0aW9uLldFRUs7IFxuICAgICAgICAgICAgICAgIGNhc2UgbG93ZXJDYXNlRm9ybWF0LmluY2x1ZGVzKCd5Jyk6XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBUaW1lZnJhbWVPcHRpb24uWUVBUjtcbiAgICAgICAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gZGVmYXVsdEZyYW1lO1xuICAgICAgICAgICAgfVxuICAgIH1cblxuICAgIGdldENvbmZpZ3VyZWRGb3JtYXQodGltZWZyYW1lOiBUVGltZWZyYW1lT3B0aW9uKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmZvcm1hdENvbmZpZ1t0aW1lZnJhbWVdO1xuICAgIH1cblxuICAgIHVwZGF0ZVRpbWVmcmFtZUFuZEZvcm1hdChmb3JtYXQ6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICBjb25zdCBub3JtYWxpemVkRm9ybWF0ID0gdGhpcy5ub3JtYWxpemVWYWx1ZShmb3JtYXQgfHwgdGhpcy5mb3JtYXQkLmdldFZhbHVlKCkpXG4gICAgICAgIHRoaXMudGltZWZyYW1lID0gdGhpcy5nZXRUaW1lZnJhbWUobm9ybWFsaXplZEZvcm1hdCk7XG4gICAgICAgIHRoaXMuZm9ybWF0JC5uZXh0KHRoaXMuZ2V0Q29uZmlndXJlZEZvcm1hdCh0aGlzLnRpbWVmcmFtZSkpO1xuICAgIH1cblxuICAgIG5vcm1hbGl6ZVZhbHVlKHZhbHVlKSB7XG4gICAgICAgIHJldHVybiB2YWx1ZS5yZXBsYWNlKC9kL2csICdEJyk7XG4gICAgfVxufVxuIl19
@@ -16,6 +16,7 @@ import { DrDatePickerFormatDirective } from './date-pickers/directives/dr-date-p
16
16
  import { DrToggleButtonComponent } from './dr-toggle-button/dr-toggle-button.component';
17
17
  import { DrModelDebounceChangeDirective } from './dr-model-debounce-change.directive';
18
18
  import { DrDatePickerCustomHeaderComponent } from './date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component';
19
+ import { DrShowTimeframePipe } from './date-pickers/dr-show-timeframe.pipe';
19
20
  // !!! Please do not use such approach in other places
20
21
  // Hard fix for 'none' calendar view selection
21
22
  MatCalendar.prototype.focusActiveCell = function () {
@@ -35,7 +36,8 @@ const components = [
35
36
  DrDatePickerWithTimeframeComponent,
36
37
  DrDatePickerFormatDirective,
37
38
  DrDatePickerCustomHeaderComponent,
38
- DrModelDebounceChangeDirective
39
+ DrModelDebounceChangeDirective,
40
+ DrShowTimeframePipe
39
41
  ];
40
42
  export class DrInputsModule {
41
43
  }
@@ -52,4 +54,4 @@ DrInputsModule.decorators = [
52
54
  ]
53
55
  },] }
54
56
  ];
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItaW5wdXRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDM0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQy9GLE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLHNGQUFzRixDQUFDO0FBQzFJLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3hHLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLG9GQUFvRixDQUFDO0FBR3ZJLHNEQUFzRDtBQUN0RCw4Q0FBOEM7QUFDOUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxlQUFlLEdBQUc7O0lBQ3RDLE1BQUEsSUFBSSxDQUFDLHdCQUF3QixFQUFFLDBDQUFFLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQzNELENBQUMsQ0FBQTtBQUVELE1BQU0sVUFBVSxHQUFHO0lBQ2pCLGlCQUFpQjtJQUNqQixvQkFBb0I7SUFDcEIsbUJBQW1CO0lBQ25CLGlCQUFpQjtJQUNqQixnQkFBZ0I7SUFDaEIsaUJBQWlCO0lBQ2pCLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIscUJBQXFCO0lBQ3JCLGtDQUFrQztJQUNsQywyQkFBMkI7SUFDM0IsaUNBQWlDO0lBQ2pDLDhCQUE4QjtDQUMvQixDQUFDO0FBY0YsTUFBTSxPQUFPLGNBQWM7OztZQVoxQixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFLFVBQVU7Z0JBQ3hCLE9BQU8sRUFBRSxVQUFVO2dCQUNuQixPQUFPLEVBQUU7b0JBQ1AsV0FBVztvQkFDWCxtQkFBbUI7b0JBQ25CLFlBQVk7b0JBQ1osY0FBYztvQkFDZCxtQkFBbUI7aUJBQ3BCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5pbXBvcnQgeyBOZ1NlbGVjdE1vZHVsZSB9IGZyb20gJ0BuZy1zZWxlY3Qvbmctc2VsZWN0JztcblxuaW1wb3J0IHsgRHJJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vZHItaW5wdXQvZHItaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7IERyU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9kci1zZWxlY3QvZHItc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDaGVja2JveENvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcbmltcG9ydCB7IFJhZGlvQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9yYWRpby1idXR0b24vcmFkaW8tYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSYWRpb0dyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi9yYWRpby1idXR0b24vcmFkaW8tZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IERyVG9nZ2xlQ29tcG9uZW50IH0gZnJvbSAnLi9kci10b2dnbGUvZHItdG9nZ2xlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEckJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuXG5pbXBvcnQgeyBNYXRDYWxlbmRhciwgTWF0RGF0ZXBpY2tlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXInO1xuaW1wb3J0IHsgRHJEYXRlUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXIvZHItZGF0ZS1waWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7IERyRGF0ZVBpY2tlcldpdGhUaW1lZnJhbWVDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtcGlja2Vycy9kci1kYXRlLXBpY2tlci13aXRoLXRpbWVmcmFtZS9kci1kYXRlLXBpY2tlci13aXRoLXRpbWVmcmFtZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJEYXRlUGlja2VyRm9ybWF0RGlyZWN0aXZlIH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZGlyZWN0aXZlcy9kci1kYXRlLXBpY2tlci1mb3JtYXQuZGlyZWN0aXZlJztcbmltcG9ydCB7IERyVG9nZ2xlQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9kci10b2dnbGUtYnV0dG9uL2RyLXRvZ2dsZS1idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IERyTW9kZWxEZWJvdW5jZUNoYW5nZURpcmVjdGl2ZSB9IGZyb20gJy4vZHItbW9kZWwtZGVib3VuY2UtY2hhbmdlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEckRhdGVQaWNrZXJDdXN0b21IZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtcGlja2Vycy9kci1kYXRlLXBpY2tlcl9jdXN0b20taGVhZGVyL2RyLWRhdGUtcGlja2VyX2N1c3RvbS1oZWFkZXIuY29tcG9uZW50JztcbmltcG9ydCB7IERyRGF0ZVBpY2tlclNlcnZpY2UgfSBmcm9tICcuL2RhdGUtcGlja2Vycy9zZXJ2aWNlcy9kci1kYXRlLXBpY2tlci5zZXJ2aWNlJztcblxuLy8gISEhIFBsZWFzZSBkbyBub3QgdXNlIHN1Y2ggYXBwcm9hY2ggaW4gb3RoZXIgcGxhY2VzXG4vLyBIYXJkIGZpeCBmb3IgJ25vbmUnIGNhbGVuZGFyIHZpZXcgc2VsZWN0aW9uXG5NYXRDYWxlbmRhci5wcm90b3R5cGUuZm9jdXNBY3RpdmVDZWxsID0gZnVuY3Rpb24oKSB7XG4gIHRoaXMuX2dldEN1cnJlbnRWaWV3Q29tcG9uZW50KCk/Ll9mb2N1c0FjdGl2ZUNlbGwoZmFsc2UpO1xufVxuXG5jb25zdCBjb21wb25lbnRzID0gW1xuICBEckJ1dHRvbkNvbXBvbmVudCxcbiAgUmFkaW9CdXR0b25Db21wb25lbnQsXG4gIFJhZGlvR3JvdXBDb21wb25lbnQsXG4gIENoZWNrYm94Q29tcG9uZW50LFxuICBEcklucHV0Q29tcG9uZW50LFxuICBEclNlbGVjdENvbXBvbmVudCxcbiAgRHJUb2dnbGVDb21wb25lbnQsXG4gIERyVG9nZ2xlQnV0dG9uQ29tcG9uZW50LFxuICBEckRhdGVQaWNrZXJDb21wb25lbnQsXG4gIERyRGF0ZVBpY2tlcldpdGhUaW1lZnJhbWVDb21wb25lbnQsXG4gIERyRGF0ZVBpY2tlckZvcm1hdERpcmVjdGl2ZSxcbiAgRHJEYXRlUGlja2VyQ3VzdG9tSGVhZGVyQ29tcG9uZW50LFxuICBEck1vZGVsRGVib3VuY2VDaGFuZ2VEaXJlY3RpdmVcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogY29tcG9uZW50cyxcbiAgZXhwb3J0czogY29tcG9uZW50cyxcbiAgaW1wb3J0czogW1xuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE5nU2VsZWN0TW9kdWxlLFxuICAgIE1hdERhdGVwaWNrZXJNb2R1bGVcbiAgXVxufSlcblxuZXhwb3J0IGNsYXNzIERySW5wdXRzTW9kdWxlIHtcblxufVxuIl19
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItaW5wdXRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDM0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQy9GLE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLHNGQUFzRixDQUFDO0FBQzFJLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3hHLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLG9GQUFvRixDQUFDO0FBRXZJLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRTVFLHNEQUFzRDtBQUN0RCw4Q0FBOEM7QUFDOUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxlQUFlLEdBQUc7O0lBQ3RDLE1BQUEsSUFBSSxDQUFDLHdCQUF3QixFQUFFLDBDQUFFLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQzNELENBQUMsQ0FBQTtBQUVELE1BQU0sVUFBVSxHQUFHO0lBQ2pCLGlCQUFpQjtJQUNqQixvQkFBb0I7SUFDcEIsbUJBQW1CO0lBQ25CLGlCQUFpQjtJQUNqQixnQkFBZ0I7SUFDaEIsaUJBQWlCO0lBQ2pCLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIscUJBQXFCO0lBQ3JCLGtDQUFrQztJQUNsQywyQkFBMkI7SUFDM0IsaUNBQWlDO0lBQ2pDLDhCQUE4QjtJQUM5QixtQkFBbUI7Q0FDcEIsQ0FBQztBQWNGLE1BQU0sT0FBTyxjQUFjOzs7WUFaMUIsUUFBUSxTQUFDO2dCQUNSLFlBQVksRUFBRSxVQUFVO2dCQUN4QixPQUFPLEVBQUUsVUFBVTtnQkFDbkIsT0FBTyxFQUFFO29CQUNQLFdBQVc7b0JBQ1gsbUJBQW1CO29CQUNuQixZQUFZO29CQUNaLGNBQWM7b0JBQ2QsbUJBQW1CO2lCQUNwQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgTmdTZWxlY3RNb2R1bGUgfSBmcm9tICdAbmctc2VsZWN0L25nLXNlbGVjdCc7XG5cbmltcG9ydCB7IERySW5wdXRDb21wb25lbnQgfSBmcm9tICcuL2RyLWlucHV0L2RyLWlucHV0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEclNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vZHItc2VsZWN0L2RyLXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSYWRpb0J1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgUmFkaW9Hcm91cENvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8tYnV0dG9uL3JhZGlvLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEclRvZ2dsZUNvbXBvbmVudCB9IGZyb20gJy4vZHItdG9nZ2xlL2RyLXRvZ2dsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcblxuaW1wb3J0IHsgTWF0Q2FsZW5kYXIsIE1hdERhdGVwaWNrZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kYXRlcGlja2VyJztcbmltcG9ydCB7IERyRGF0ZVBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RyLWRhdGUtcGlja2VyL2RyLWRhdGUtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEckRhdGVQaWNrZXJXaXRoVGltZWZyYW1lQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUuY29tcG9uZW50JztcbmltcG9ydCB7IERyRGF0ZVBpY2tlckZvcm1hdERpcmVjdGl2ZSB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RpcmVjdGl2ZXMvZHItZGF0ZS1waWNrZXItZm9ybWF0LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEclRvZ2dsZUJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vZHItdG9nZ2xlLWJ1dHRvbi9kci10b2dnbGUtYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEck1vZGVsRGVib3VuY2VDaGFuZ2VEaXJlY3RpdmUgfSBmcm9tICcuL2RyLW1vZGVsLWRlYm91bmNlLWNoYW5nZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJEYXRlUGlja2VyQ3VzdG9tSGVhZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXJfY3VzdG9tLWhlYWRlci9kci1kYXRlLXBpY2tlcl9jdXN0b20taGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEckRhdGVQaWNrZXJTZXJ2aWNlIH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvc2VydmljZXMvZHItZGF0ZS1waWNrZXIuc2VydmljZSc7XG5pbXBvcnQgeyBEclNob3dUaW1lZnJhbWVQaXBlIH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItc2hvdy10aW1lZnJhbWUucGlwZSc7XG5cbi8vICEhISBQbGVhc2UgZG8gbm90IHVzZSBzdWNoIGFwcHJvYWNoIGluIG90aGVyIHBsYWNlc1xuLy8gSGFyZCBmaXggZm9yICdub25lJyBjYWxlbmRhciB2aWV3IHNlbGVjdGlvblxuTWF0Q2FsZW5kYXIucHJvdG90eXBlLmZvY3VzQWN0aXZlQ2VsbCA9IGZ1bmN0aW9uKCkge1xuICB0aGlzLl9nZXRDdXJyZW50Vmlld0NvbXBvbmVudCgpPy5fZm9jdXNBY3RpdmVDZWxsKGZhbHNlKTtcbn1cblxuY29uc3QgY29tcG9uZW50cyA9IFtcbiAgRHJCdXR0b25Db21wb25lbnQsXG4gIFJhZGlvQnV0dG9uQ29tcG9uZW50LFxuICBSYWRpb0dyb3VwQ29tcG9uZW50LFxuICBDaGVja2JveENvbXBvbmVudCxcbiAgRHJJbnB1dENvbXBvbmVudCxcbiAgRHJTZWxlY3RDb21wb25lbnQsXG4gIERyVG9nZ2xlQ29tcG9uZW50LFxuICBEclRvZ2dsZUJ1dHRvbkNvbXBvbmVudCxcbiAgRHJEYXRlUGlja2VyQ29tcG9uZW50LFxuICBEckRhdGVQaWNrZXJXaXRoVGltZWZyYW1lQ29tcG9uZW50LFxuICBEckRhdGVQaWNrZXJGb3JtYXREaXJlY3RpdmUsXG4gIERyRGF0ZVBpY2tlckN1c3RvbUhlYWRlckNvbXBvbmVudCxcbiAgRHJNb2RlbERlYm91bmNlQ2hhbmdlRGlyZWN0aXZlLFxuICBEclNob3dUaW1lZnJhbWVQaXBlXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IGNvbXBvbmVudHMsXG4gIGV4cG9ydHM6IGNvbXBvbmVudHMsXG4gIGltcG9ydHM6IFtcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIENvbW1vbk1vZHVsZSxcbiAgICBOZ1NlbGVjdE1vZHVsZSxcbiAgICBNYXREYXRlcGlja2VyTW9kdWxlXG4gIF1cbn0pXG5cbmV4cG9ydCBjbGFzcyBEcklucHV0c01vZHVsZSB7XG5cbn1cbiJdfQ==
@@ -49,7 +49,7 @@ export class DrSelectComponent {
49
49
  DrSelectComponent.decorators = [
50
50
  { type: Component, args: [{
51
51
  selector: 'dr-select',
52
- template: " <ng-select [(ngModel)]=\"selectedItem\"\n [items]=\"items\"\n [bindLabel]=\"bindLabel\"\n [bindValue]=\"bindValue\"\n [multiple]=\"multiple\"\n [addTag]=\"addTag\"\n [appendTo]=\"appendTo\"\n [clearable]=\"clearable\"\n [searchable]=\"searchable\"\n [hideSelected]=\"hideSelected\"\n [placeholder]=\"placeholder\"\n [loading]=\"loading\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [id]=\"id\"\n [keyDownFn]=\"keyDownFn\"\n [searchFn]=\"searchFn\"\n (change)=\"onChange(selectedItem); change.emit(selectedItem)\"\n class=\"dr-select\">\n <ng-template *ngIf=\"optionHeaderTemplate\" ng-header-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"optionHeaderTemplate\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"labelTemplate\" ng-label-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"labelTemplate\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"optionWithDescription\" ng-option-tmp let-item=\"item\">\n <div class=\"dr-select__option-with-desc__wrapper\">\n <div>{{ item.name }}</div>\n <div class=\"dr-select__option-with-desc__description\"\n >{{ item?.description }}</div>\n </div>\n </ng-template>\n <ng-template *ngIf=\"optionFooterTemplate\" ng-footer-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"optionFooterTemplate\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n </ng-template>\n </ng-select>\n",
52
+ template: " <ng-select [(ngModel)]=\"selectedItem\"\n [items]=\"items\"\n [bindLabel]=\"bindLabel\"\n [bindValue]=\"bindValue\"\n [multiple]=\"multiple\"\n [addTag]=\"addTag\"\n [appendTo]=\"appendTo\"\n [clearable]=\"clearable\"\n [searchable]=\"searchable\"\n [hideSelected]=\"hideSelected\"\n [placeholder]=\"placeholder\"\n [loading]=\"loading\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [id]=\"id\"\n [keyDownFn]=\"keyDownFn\"\n [searchFn]=\"searchFn\"\n (change)=\"change.emit(selectedItem); onChange(selectedItem)\"\n class=\"dr-select\">\n <ng-template *ngIf=\"optionHeaderTemplate\" ng-header-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"optionHeaderTemplate\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"labelTemplate\" ng-label-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"labelTemplate\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"optionWithDescription\" ng-option-tmp let-item=\"item\">\n <div class=\"dr-select__option-with-desc__wrapper\">\n <div>{{ item.name }}</div>\n <div class=\"dr-select__option-with-desc__description\"\n >{{ item?.description }}</div>\n </div>\n </ng-template>\n <ng-template *ngIf=\"optionFooterTemplate\" ng-footer-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"optionFooterTemplate\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n </ng-template>\n </ng-select>\n",
53
53
  providers: [{
54
54
  provide: NG_VALUE_ACCESSOR,
55
55
  useExisting: DrSelectComponent,