@datarailsshared/datarailsshared 1.3.49 → 1.3.51

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 (133) hide show
  1. package/_datarailsshared.styles.css +3 -3
  2. package/assets/styles/_styles.scss +2 -2
  3. package/assets/styles/img/default-avatar.svg +5 -5
  4. package/bundles/datarailsshared-datarailsshared.umd.js +3984 -3995
  5. package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
  6. package/datarailsshared-datarailsshared-1.3.51.tgz +0 -0
  7. package/datarailsshared-datarailsshared.d.ts +9 -9
  8. package/datarailsshared-datarailsshared.metadata.json +1 -1
  9. package/esm2015/datarailsshared-datarailsshared.js +9 -9
  10. package/esm2015/lib/date-tags/date-tag.component.js +70 -70
  11. package/esm2015/lib/date-tags/date-tag.module.js +50 -50
  12. package/esm2015/lib/date-tags/day-tag/day-tag.component.js +81 -81
  13. package/esm2015/lib/date-tags/forecast-tag/forecast-tag.component.js +143 -143
  14. package/esm2015/lib/date-tags/month-tag/month-tag.component.js +87 -87
  15. package/esm2015/lib/date-tags/quarter-tag/quarter-tag.component.js +101 -101
  16. package/esm2015/lib/date-tags/week-tag/week-tag.component.js +124 -124
  17. package/esm2015/lib/date-tags/year-tag/year-tag.component.js +93 -93
  18. package/esm2015/lib/dr-accordion/accordion-item-body.component.js +57 -57
  19. package/esm2015/lib/dr-accordion/accordion-item-header.component.js +79 -79
  20. package/esm2015/lib/dr-accordion/accordion-item.component.js +123 -123
  21. package/esm2015/lib/dr-accordion/accordion.component.js +43 -43
  22. package/esm2015/lib/dr-accordion/accordion.module.js +23 -23
  23. package/esm2015/lib/dr-avatar/dr-avatar.component.js +42 -42
  24. package/esm2015/lib/dr-avatar/dr-avatar.module.js +26 -26
  25. package/esm2015/lib/dr-avatar/dr-avatar.pipe.js +15 -15
  26. package/esm2015/lib/dr-dropdown/dr-dropdown-item-show.pipe.js +12 -12
  27. package/esm2015/lib/dr-dropdown/dr-dropdown-position.directive.js +97 -97
  28. package/esm2015/lib/dr-dropdown/dr-dropdown.component.js +110 -110
  29. package/esm2015/lib/dr-dropdown/dr-dropdown.directive.js +89 -89
  30. package/esm2015/lib/dr-dropdown/dr-dropdown.module.js +34 -34
  31. package/esm2015/lib/dr-dropdown/dr-dropdown.service.js +24 -24
  32. package/esm2015/lib/dr-inputs/button/button.component.js +80 -80
  33. package/esm2015/lib/dr-inputs/checkbox/checkbox.component.js +63 -63
  34. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.js +47 -47
  35. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.component.js +183 -186
  36. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.service.js +41 -41
  37. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.js +129 -129
  38. package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +185 -185
  39. package/esm2015/lib/dr-inputs/dr-inputs.module.js +51 -51
  40. package/esm2015/lib/dr-inputs/dr-model-debounce-change.directive.js +31 -31
  41. package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +90 -90
  42. package/esm2015/lib/dr-inputs/dr-toggle/dr-toggle.component.js +64 -64
  43. package/esm2015/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.js +56 -56
  44. package/esm2015/lib/dr-inputs/radio-button/radio-button.component.js +64 -64
  45. package/esm2015/lib/dr-inputs/radio-button/radio-group.component.js +164 -164
  46. package/esm2015/lib/dr-popover/dr-popover-ref.js +20 -20
  47. package/esm2015/lib/dr-popover/dr-popover.component.js +77 -77
  48. package/esm2015/lib/dr-popover/dr-popover.directive.js +72 -72
  49. package/esm2015/lib/dr-popover/dr-popover.module.js +23 -23
  50. package/esm2015/lib/dr-popover/dr-popover.service.js +102 -102
  51. package/esm2015/lib/dr-spinner/dr-spinner.component.js +29 -29
  52. package/esm2015/lib/dr-spinner/dr-spinner.directive.js +53 -53
  53. package/esm2015/lib/dr-spinner/dr-spinner.module.js +18 -18
  54. package/esm2015/lib/dr-tabs/dr-tab.component.js +23 -23
  55. package/esm2015/lib/dr-tabs/dr-tabs.component.js +28 -28
  56. package/esm2015/lib/dr-tabs/dr-tabs.module.js +30 -30
  57. package/esm2015/lib/dr-tags/dr-tag.component.js +54 -54
  58. package/esm2015/lib/dr-tags/dr-tag.module.js +22 -22
  59. package/esm2015/lib/dr-tooltip/dr-tooltip.component.js +30 -30
  60. package/esm2015/lib/dr-tooltip/dr-tooltip.directive.js +102 -102
  61. package/esm2015/lib/dr-tooltip/dr-tooltip.module.js +23 -23
  62. package/esm2015/lib/list-tags/list-tag.component.js +41 -41
  63. package/esm2015/lib/list-tags/list-tag.module.js +29 -29
  64. package/esm2015/lib/models/constants.js +97 -97
  65. package/esm2015/lib/models/datePicker.js +40 -40
  66. package/esm2015/lib/models/dropdown.js +2 -2
  67. package/esm2015/lib/models/popover.js +27 -27
  68. package/esm2015/lib/models/serverTags.js +2 -2
  69. package/esm2015/public-api.js +57 -57
  70. package/fesm2015/datarailsshared-datarailsshared.js +3365 -3368
  71. package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
  72. package/lib/date-tags/date-tag.component.d.ts +27 -27
  73. package/lib/date-tags/date-tag.module.d.ts +4 -4
  74. package/lib/date-tags/day-tag/day-tag.component.d.ts +12 -12
  75. package/lib/date-tags/forecast-tag/forecast-tag.component.d.ts +21 -21
  76. package/lib/date-tags/month-tag/month-tag.component.d.ts +14 -14
  77. package/lib/date-tags/quarter-tag/quarter-tag.component.d.ts +17 -17
  78. package/lib/date-tags/week-tag/week-tag.component.d.ts +19 -19
  79. package/lib/date-tags/year-tag/year-tag.component.d.ts +14 -14
  80. package/lib/dr-accordion/accordion-item-body.component.d.ts +11 -11
  81. package/lib/dr-accordion/accordion-item-header.component.d.ts +16 -16
  82. package/lib/dr-accordion/accordion-item.component.d.ts +53 -53
  83. package/lib/dr-accordion/accordion.component.d.ts +19 -19
  84. package/lib/dr-accordion/accordion.module.d.ts +2 -2
  85. package/lib/dr-avatar/dr-avatar.component.d.ts +10 -10
  86. package/lib/dr-avatar/dr-avatar.module.d.ts +2 -2
  87. package/lib/dr-avatar/dr-avatar.pipe.d.ts +4 -4
  88. package/lib/dr-dropdown/dr-dropdown-item-show.pipe.d.ts +5 -5
  89. package/lib/dr-dropdown/dr-dropdown-position.directive.d.ts +12 -12
  90. package/lib/dr-dropdown/dr-dropdown.component.d.ts +26 -26
  91. package/lib/dr-dropdown/dr-dropdown.directive.d.ts +23 -23
  92. package/lib/dr-dropdown/dr-dropdown.module.d.ts +2 -2
  93. package/lib/dr-dropdown/dr-dropdown.service.d.ts +11 -11
  94. package/lib/dr-inputs/button/button.component.d.ts +21 -21
  95. package/lib/dr-inputs/checkbox/checkbox.component.d.ts +20 -20
  96. package/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.d.ts +10 -10
  97. package/lib/dr-inputs/dr-date-picker/dr-date-picker.component.d.ts +54 -54
  98. package/lib/dr-inputs/dr-date-picker/dr-date-picker.service.d.ts +12 -12
  99. package/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +41 -41
  100. package/lib/dr-inputs/dr-input/dr-input.component.d.ts +58 -58
  101. package/lib/dr-inputs/dr-inputs.module.d.ts +2 -2
  102. package/lib/dr-inputs/dr-model-debounce-change.directive.d.ts +11 -11
  103. package/lib/dr-inputs/dr-select/dr-select.component.d.ts +38 -38
  104. package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +23 -23
  105. package/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.d.ts +19 -19
  106. package/lib/dr-inputs/radio-button/radio-button.component.d.ts +21 -21
  107. package/lib/dr-inputs/radio-button/radio-group.component.d.ts +39 -39
  108. package/lib/dr-popover/dr-popover-ref.d.ts +16 -16
  109. package/lib/dr-popover/dr-popover.component.d.ts +26 -26
  110. package/lib/dr-popover/dr-popover.directive.d.ts +26 -26
  111. package/lib/dr-popover/dr-popover.module.d.ts +2 -2
  112. package/lib/dr-popover/dr-popover.service.d.ts +17 -17
  113. package/lib/dr-spinner/dr-spinner.component.d.ts +10 -10
  114. package/lib/dr-spinner/dr-spinner.directive.d.ts +15 -15
  115. package/lib/dr-spinner/dr-spinner.module.d.ts +2 -2
  116. package/lib/dr-tabs/dr-tab.component.d.ts +8 -8
  117. package/lib/dr-tabs/dr-tabs.component.d.ts +11 -11
  118. package/lib/dr-tabs/dr-tabs.module.d.ts +2 -2
  119. package/lib/dr-tags/dr-tag.component.d.ts +15 -15
  120. package/lib/dr-tags/dr-tag.module.d.ts +2 -2
  121. package/lib/dr-tooltip/dr-tooltip.component.d.ts +16 -16
  122. package/lib/dr-tooltip/dr-tooltip.directive.d.ts +23 -23
  123. package/lib/dr-tooltip/dr-tooltip.module.d.ts +2 -2
  124. package/lib/list-tags/list-tag.component.d.ts +14 -14
  125. package/lib/list-tags/list-tag.module.d.ts +2 -2
  126. package/lib/models/constants.d.ts +87 -87
  127. package/lib/models/datePicker.d.ts +25 -25
  128. package/lib/models/dropdown.d.ts +48 -48
  129. package/lib/models/popover.d.ts +32 -32
  130. package/lib/models/serverTags.d.ts +28 -28
  131. package/package.json +1 -1
  132. package/public-api.d.ts +55 -55
  133. package/datarailsshared-datarailsshared-1.3.49.tgz +0 -0
@@ -1,129 +1,129 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject } from "@angular/core";
2
- import { Subject } from "rxjs";
3
- import { take, takeUntil } from 'rxjs/operators';
4
- import { MatCalendar } from '@angular/material/datepicker';
5
- import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
6
- import { CustomDateFormat, MAT_DEFAULT_DATE_FORMAT, MONTH_YEAR_FORMAT, QUARTER_FORMAT, YEAR_FORMAT } from "../../../models/datePicker";
7
- import { DrDatePickerService } from "../dr-date-picker.service";
8
- const moment = require('moment');
9
- export class DrDatePickerCustomHeaderComponent {
10
- constructor(_calendar, _dateAdapter, _dateFormats, cdr, datePickerService) {
11
- this._calendar = _calendar;
12
- this._dateAdapter = _dateAdapter;
13
- this._dateFormats = _dateFormats;
14
- this.cdr = cdr;
15
- this.datePickerService = datePickerService;
16
- this._destroyed = new Subject();
17
- this.quarters = [1, 2, 3, 4];
18
- this.selectedQuarter = 1;
19
- this.timeframeOptions = [{
20
- title: 'Day',
21
- value: 'month',
22
- format: MAT_DEFAULT_DATE_FORMAT,
23
- periodLabel: () => this._dateAdapter
24
- .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)
25
- .toLocaleUpperCase()
26
- }, {
27
- title: 'Month',
28
- value: 'year',
29
- format: MONTH_YEAR_FORMAT,
30
- periodLabel: () => String(moment(this._calendar.activeDate).year())
31
- }, {
32
- title: 'Quarter',
33
- value: 'none',
34
- format: QUARTER_FORMAT,
35
- periodLabel: () => String(moment(this._calendar.activeDate).year())
36
- }, {
37
- title: 'Year',
38
- value: 'multi-year',
39
- format: YEAR_FORMAT,
40
- periodLabel: () => {
41
- const currentYear = moment(this._calendar.activeDate).year();
42
- const startPeriod = Math.floor(currentYear / 24) * 24;
43
- return startPeriod + '-' + (startPeriod + 23);
44
- }
45
- }];
46
- this.pagingSetup = {
47
- 'year': (forward) => this.pagingDateChange('addCalendarYears', 1, forward),
48
- 'none': (forward) => this.pagingDateChange('addCalendarYears', 1, forward),
49
- 'month': (forward) => this.pagingDateChange('addCalendarMonths', 1, forward),
50
- 'multi-year': (forward) => this.pagingDateChange('addCalendarYears', 24, forward)
51
- };
52
- this.selectedTimeframe = 'month';
53
- this.timeframeSelection = false;
54
- this.periodMonthLabel = '';
55
- this.periodYearLabel = '';
56
- _calendar.stateChanges
57
- .pipe(takeUntil(this._destroyed))
58
- .subscribe(() => cdr.markForCheck());
59
- this.datePickerService.format
60
- .pipe(take(1))
61
- .subscribe(value => {
62
- this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;
63
- });
64
- }
65
- ngOnDestroy() {
66
- this._destroyed.next();
67
- this._destroyed.complete();
68
- }
69
- setPeriodLabels(currentTimeframeOption) {
70
- const fullPeriodLabel = currentTimeframeOption.periodLabel();
71
- if (this.selectedTimeframe === 'month') {
72
- this.periodMonthLabel = fullPeriodLabel.slice(0, 3);
73
- this.periodYearLabel = fullPeriodLabel.slice(4);
74
- }
75
- else {
76
- this.periodMonthLabel = '';
77
- this.periodYearLabel = fullPeriodLabel;
78
- }
79
- }
80
- setTimeframe() {
81
- this.timeframeSelection = false;
82
- this._calendar.currentView = this.selectedTimeframe;
83
- const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];
84
- this.setPeriodLabels(chosenTimeframeOption);
85
- this.datePickerService.format.next(chosenTimeframeOption.format);
86
- this.datePickerService.setTimeframe(chosenTimeframeOption.format);
87
- if (this.selectedTimeframe == 'none') {
88
- this.selectedQuarter = moment(this._calendar.activeDate).quarter();
89
- }
90
- }
91
- get currentViewIsQuater() {
92
- return !['month', 'year', 'multi-year'].includes(this._calendar.currentView);
93
- }
94
- switchViewOnClickOnPeriodLabel(view) {
95
- this._calendar.currentView = view;
96
- }
97
- onSelectQuater(quarterNumber) {
98
- const monthsInQuarter = 3;
99
- this.selectedQuarter = moment(this._calendar.activeDate).quarter();
100
- const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate, monthsInQuarter * (quarterNumber - this.selectedQuarter));
101
- this._calendar.activeDate = unadaptedDate;
102
- this.datePickerService.updatedQuater.next(moment(unadaptedDate));
103
- this.datePickerService.calendarInstance.close();
104
- }
105
- pagingClicked(forward) {
106
- this.pagingSetup[this.selectedTimeframe] && this.pagingSetup[this.selectedTimeframe](forward);
107
- }
108
- pagingDateChange(actionCall, amount, forward) {
109
- this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward ? amount : -amount);
110
- const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];
111
- this.setPeriodLabels(chosenTimeframeOption);
112
- }
113
- }
114
- DrDatePickerCustomHeaderComponent.decorators = [
115
- { type: Component, args: [{
116
- selector: 'dr-date-picker_custom-header.component',
117
- template: "<div class=\"dr-datepicker__timeframe-select__wrapper\">\r\n <dr-select \r\n class=\"dr-datepicker__timeframe-select\"\r\n [(ngModel)]=\"selectedTimeframe\"\r\n [items]=\"timeframeOptions\"\r\n bindLabel=\"title\"\r\n bindValue=\"value\"\r\n (ngModelChange)=\"setTimeframe()\">\r\n </dr-select>\r\n</div>\r\n\r\n<div class=\"dr-date-paging\">\r\n <div class=\"dr-date-paging flip-page-button\"\r\n (click)=\"pagingClicked(false)\">\r\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i> \r\n </div>\r\n <span class=\"example-header-label\">\r\n <span (click)=\"switchViewOnClickOnPeriodLabel('year')\">{{periodMonthLabel + ' '}}</span> \r\n <span (click)=\"switchViewOnClickOnPeriodLabel('multi-year')\">{{periodYearLabel}}</span>\r\n </span>\r\n <div class=\"dr-date-paging flip-page-button\"\r\n (click)=\"pagingClicked(true)\">\r\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\r\n </div>\r\n</div>\r\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuater\">\r\n <div *ngFor=\"let quarter of quarters\" \r\n class=\"quarter-selector\" (click)=\"onSelectQuater(quarter)\"\r\n [class]=\"quarter == selectedQuarter ? 'selected' : ''\"\r\n >Q{{quarter}}</div>\r\n</div>\r\n\r\n",
118
- changeDetection: ChangeDetectionStrategy.OnPush,
119
- 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}.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
- },] }
121
- ];
122
- DrDatePickerCustomHeaderComponent.ctorParameters = () => [
123
- { type: MatCalendar },
124
- { type: DateAdapter },
125
- { type: CustomDateFormat, decorators: [{ type: Inject, args: [MAT_DATE_FORMATS,] }] },
126
- { type: ChangeDetectorRef },
127
- { type: DrDatePickerService }
128
- ];
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-date-picker/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\";\r\nimport { Subject } from \"rxjs\";\r\nimport { take, takeUntil } from 'rxjs/operators';\r\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\r\nimport { DateAdapter, MAT_DATE_FORMATS} from '@angular/material/core';\r\nimport { CustomDateFormat, MAT_DEFAULT_DATE_FORMAT, MONTH_YEAR_FORMAT, QUARTER_FORMAT, YEAR_FORMAT } from \"../../../models/datePicker\";\r\nimport { DrDatePickerService } from \"../dr-date-picker.service\";\r\n\r\nconst moment = require('moment');\r\n\r\nexport interface ITimeframeOption {\r\n      title: string,\r\n      value: MatCalendarView,\r\n      format: string,\r\n      periodLabel: () => string\r\n}\r\n\r\n@Component({\r\n    selector: 'dr-date-picker_custom-header.component',\r\n    templateUrl: 'dr-date-picker_custom-header.component.html',\r\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n    \r\n  })\r\n\r\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy {\r\n    private _destroyed = new Subject<void>();\r\n    quarters = [1, 2, 3, 4];\r\n    selectedQuarter = 1;\r\n    timeframeOptions: ITimeframeOption[] = [{\r\n      title: 'Day',\r\n      value: 'month',\r\n      format: MAT_DEFAULT_DATE_FORMAT,\r\n      periodLabel: () => this._dateAdapter\r\n                            .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\r\n                            .toLocaleUpperCase()\r\n    },{\r\n      title: 'Month',\r\n      value: 'year',\r\n      format: MONTH_YEAR_FORMAT,\r\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\r\n    },{\r\n      title: 'Quarter',\r\n      value: <MatCalendarView> 'none',\r\n      format: QUARTER_FORMAT,\r\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\r\n    },{\r\n      title: 'Year',\r\n      value: 'multi-year',\r\n      format: YEAR_FORMAT,\r\n      periodLabel:  () => {\r\n        const currentYear = moment(this._calendar.activeDate).year();\r\n        const startPeriod = Math.floor(currentYear/24)*24;\r\n        return startPeriod + '-' + (startPeriod + 23);\r\n      }\r\n    }]\r\n\r\n    pagingSetup = {\r\n      'year': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\r\n      'none': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\r\n      'month': (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\r\n      'multi-year': (forward) =>  this.pagingDateChange('addCalendarYears', 24, forward)\r\n    }\r\n     \r\n    selectedTimeframe: MatCalendarView = 'month';\r\n    timeframeSelection = false;\r\n    periodMonthLabel = '';\r\n    periodYearLabel = '';\r\n    constructor(\r\n        private _calendar: MatCalendar<Moment>,\r\n        private _dateAdapter: DateAdapter<Moment>,\r\n        @Inject(MAT_DATE_FORMATS) private _dateFormats: CustomDateFormat,\r\n        private cdr: ChangeDetectorRef,\r\n        private datePickerService: DrDatePickerService) {\r\n          _calendar.stateChanges\r\n            .pipe(takeUntil(this._destroyed))\r\n            .subscribe(() => cdr.markForCheck());\r\n          this.datePickerService.format\r\n            .pipe(take(1))\r\n            .subscribe( value => {\r\n              this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;\r\n            })\r\n    }\r\n\r\n    ngOnDestroy() {\r\n      this._destroyed.next();\r\n      this._destroyed.complete();\r\n    }\r\n\r\n    setPeriodLabels(currentTimeframeOption) {\r\n      const fullPeriodLabel = currentTimeframeOption.periodLabel();\r\n      if (this.selectedTimeframe === 'month') {\r\n        this.periodMonthLabel = fullPeriodLabel.slice(0,3);\r\n        this.periodYearLabel = fullPeriodLabel.slice(4);\r\n      } else {\r\n        this.periodMonthLabel = '';\r\n        this.periodYearLabel = fullPeriodLabel;\r\n      }\r\n    }\r\n    \r\n    setTimeframe() {\r\n      this.timeframeSelection = false;\r\n      this._calendar.currentView = this.selectedTimeframe;\r\n      const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\r\n      this.setPeriodLabels(chosenTimeframeOption);\r\n      this.datePickerService.format.next(chosenTimeframeOption.format);  \r\n      this.datePickerService.setTimeframe(chosenTimeframeOption.format);\r\n      if (this.selectedTimeframe == <MatCalendarView>'none') {\r\n        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\r\n      }\r\n    }\r\n\r\n    get currentViewIsQuater() {\r\n      return !['month', 'year', 'multi-year'].includes(this._calendar.currentView);\r\n    }\r\n \r\n    switchViewOnClickOnPeriodLabel(view: 'year' | 'multi-year') {\r\n      this._calendar.currentView = view;\r\n    }\r\n\r\n    onSelectQuater(quarterNumber: number) {\r\n      const monthsInQuarter = 3;\r\n      this.selectedQuarter = moment(this._calendar.activeDate).quarter();\r\n\r\n      const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate,\r\n        monthsInQuarter * (quarterNumber - this.selectedQuarter));\r\n      this._calendar.activeDate = unadaptedDate;\r\n      this.datePickerService.updatedQuater.next(moment(unadaptedDate));\r\n      this.datePickerService.calendarInstance.close();\r\n    }\r\n\r\n    pagingClicked(forward) {\r\n      this.pagingSetup[this.selectedTimeframe] && this.pagingSetup[this.selectedTimeframe](forward);\r\n    }\r\n\r\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\r\n      this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward? amount: - amount);\r\n      const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\r\n      this.setPeriodLabels(chosenTimeframeOption);\r\n    }\r\n  }"]}
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject } from "@angular/core";
2
+ import { Subject } from "rxjs";
3
+ import { take, takeUntil } from 'rxjs/operators';
4
+ import { MatCalendar } from '@angular/material/datepicker';
5
+ import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
6
+ import { CustomDateFormat, MAT_DEFAULT_DATE_FORMAT, MONTH_YEAR_FORMAT, QUARTER_FORMAT, YEAR_FORMAT } from "../../../models/datePicker";
7
+ import { DrDatePickerService } from "../dr-date-picker.service";
8
+ const moment = require('moment');
9
+ export class DrDatePickerCustomHeaderComponent {
10
+ constructor(_calendar, _dateAdapter, _dateFormats, cdr, datePickerService) {
11
+ this._calendar = _calendar;
12
+ this._dateAdapter = _dateAdapter;
13
+ this._dateFormats = _dateFormats;
14
+ this.cdr = cdr;
15
+ this.datePickerService = datePickerService;
16
+ this._destroyed = new Subject();
17
+ this.quarters = [1, 2, 3, 4];
18
+ this.selectedQuarter = 1;
19
+ this.timeframeOptions = [{
20
+ title: 'Day',
21
+ value: 'month',
22
+ format: MAT_DEFAULT_DATE_FORMAT,
23
+ periodLabel: () => this._dateAdapter
24
+ .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)
25
+ .toLocaleUpperCase()
26
+ }, {
27
+ title: 'Month',
28
+ value: 'year',
29
+ format: MONTH_YEAR_FORMAT,
30
+ periodLabel: () => String(moment(this._calendar.activeDate).year())
31
+ }, {
32
+ title: 'Quarter',
33
+ value: 'none',
34
+ format: QUARTER_FORMAT,
35
+ periodLabel: () => String(moment(this._calendar.activeDate).year())
36
+ }, {
37
+ title: 'Year',
38
+ value: 'multi-year',
39
+ format: YEAR_FORMAT,
40
+ periodLabel: () => {
41
+ const currentYear = moment(this._calendar.activeDate).year();
42
+ const startPeriod = Math.floor(currentYear / 24) * 24;
43
+ return startPeriod + '-' + (startPeriod + 23);
44
+ }
45
+ }];
46
+ this.pagingSetup = {
47
+ 'year': (forward) => this.pagingDateChange('addCalendarYears', 1, forward),
48
+ 'none': (forward) => this.pagingDateChange('addCalendarYears', 1, forward),
49
+ 'month': (forward) => this.pagingDateChange('addCalendarMonths', 1, forward),
50
+ 'multi-year': (forward) => this.pagingDateChange('addCalendarYears', 24, forward)
51
+ };
52
+ this.selectedTimeframe = 'month';
53
+ this.timeframeSelection = false;
54
+ this.periodMonthLabel = '';
55
+ this.periodYearLabel = '';
56
+ _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
57
+ this.datePickerService.format
58
+ .pipe(take(1))
59
+ .subscribe(value => {
60
+ this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;
61
+ this.setPeriodLabels();
62
+ });
63
+ _calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
64
+ }
65
+ ngOnDestroy() {
66
+ this._destroyed.next();
67
+ this._destroyed.complete();
68
+ }
69
+ setPeriodLabels() {
70
+ const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];
71
+ const fullPeriodLabel = currentTimeframeOption.periodLabel();
72
+ if (this._calendar.currentView === 'month') {
73
+ this.periodMonthLabel = fullPeriodLabel.slice(0, 3);
74
+ this.periodYearLabel = fullPeriodLabel.slice(4);
75
+ }
76
+ else {
77
+ this.periodMonthLabel = '';
78
+ this.periodYearLabel = fullPeriodLabel;
79
+ }
80
+ this.cdr.markForCheck();
81
+ }
82
+ setTimeframe() {
83
+ this.timeframeSelection = false;
84
+ this._calendar.currentView = this.selectedTimeframe;
85
+ const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];
86
+ this.datePickerService.format.next(chosenTimeframeOption.format);
87
+ this.datePickerService.setTimeframe(chosenTimeframeOption.format);
88
+ if (this.selectedTimeframe == 'none') {
89
+ this.selectedQuarter = moment(this._calendar.activeDate).quarter();
90
+ }
91
+ }
92
+ get currentViewIsQuater() {
93
+ return !['month', 'year', 'multi-year'].includes(this._calendar.currentView);
94
+ }
95
+ switchViewOnClickOnPeriodLabel(view) {
96
+ this._calendar.currentView = view;
97
+ }
98
+ onSelectQuater(quarterNumber) {
99
+ const monthsInQuarter = 3;
100
+ this.selectedQuarter = moment(this._calendar.activeDate).quarter();
101
+ const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate, monthsInQuarter * (quarterNumber - this.selectedQuarter));
102
+ this._calendar.activeDate = unadaptedDate;
103
+ this.datePickerService.updatedQuater.next(moment(unadaptedDate));
104
+ this.datePickerService.calendarInstance.close();
105
+ }
106
+ pagingClicked(forward) {
107
+ this.pagingSetup[this._calendar.currentView] && this.pagingSetup[this._calendar.currentView](forward);
108
+ }
109
+ pagingDateChange(actionCall, amount, forward) {
110
+ this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward ? amount : -amount);
111
+ this.setPeriodLabels();
112
+ }
113
+ }
114
+ DrDatePickerCustomHeaderComponent.decorators = [
115
+ { type: Component, args: [{
116
+ selector: 'dr-date-picker_custom-header.component',
117
+ template: "<div 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('year')\">{{periodMonthLabel + ' '}}</span> \n <span (click)=\"switchViewOnClickOnPeriodLabel('multi-year')\">{{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=\"currentViewIsQuater\">\n <div *ngFor=\"let quarter of quarters\" \n class=\"quarter-selector\" (click)=\"onSelectQuater(quarter)\"\n [class]=\"quarter == selectedQuarter ? 'selected' : ''\"\n >Q{{quarter}}</div>\n</div>\n\n",
118
+ changeDetection: ChangeDetectionStrategy.OnPush,
119
+ 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
+ },] }
121
+ ];
122
+ DrDatePickerCustomHeaderComponent.ctorParameters = () => [
123
+ { type: MatCalendar },
124
+ { type: DateAdapter },
125
+ { type: CustomDateFormat, decorators: [{ type: Inject, args: [MAT_DATE_FORMATS,] }] },
126
+ { type: ChangeDetectorRef },
127
+ { type: DrDatePickerService }
128
+ ];
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-date-picker/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 { CustomDateFormat, MAT_DEFAULT_DATE_FORMAT, MONTH_YEAR_FORMAT, QUARTER_FORMAT, YEAR_FORMAT } from \"../../../models/datePicker\";\nimport { DrDatePickerService } from \"../dr-date-picker.service\";\n\nconst moment = require('moment');\n\nexport interface ITimeframeOption {\n      title: string,\n      value: MatCalendarView,\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  })\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: 'month',\n      format: MAT_DEFAULT_DATE_FORMAT,\n      periodLabel: () => this._dateAdapter\n                            .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\n                            .toLocaleUpperCase()\n    },{\n      title: 'Month',\n      value: 'year',\n      format: MONTH_YEAR_FORMAT,\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n      title: 'Quarter',\n      value: <MatCalendarView> 'none',\n      format: QUARTER_FORMAT,\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n      title: 'Year',\n      value: 'multi-year',\n      format: YEAR_FORMAT,\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      'year': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n      'none': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n      'month': (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n      'multi-year': (forward) =>  this.pagingDateChange('addCalendarYears', 24, forward)\n    }\n     \n    selectedTimeframe: MatCalendarView = 'month';\n    timeframeSelection = false;\n    periodMonthLabel = '';\n    periodYearLabel = '';\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        private 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;\n      const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\n      this.datePickerService.format.next(chosenTimeframeOption.format);  \n      this.datePickerService.setTimeframe(chosenTimeframeOption.format);\n      if (this.selectedTimeframe == <MatCalendarView>'none') {\n        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n      }\n    }\n\n    get currentViewIsQuater() {\n      return !['month', 'year', 'multi-year'].includes(this._calendar.currentView);\n    }\n \n    switchViewOnClickOnPeriodLabel(view: 'year' | 'multi-year') {\n      this._calendar.currentView = view;\n    }\n\n    onSelectQuater(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.updatedQuater.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  }"]}