@datarailsshared/datarailsshared 1.4.122 → 1.4.124

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 (35) hide show
  1. package/bundles/datarailsshared-datarailsshared.umd.js +330 -363
  2. package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
  3. package/datarailsshared-datarailsshared-1.4.124.tgz +0 -0
  4. package/datarailsshared-datarailsshared.d.ts +13 -13
  5. package/datarailsshared-datarailsshared.metadata.json +1 -1
  6. package/esm2015/datarailsshared-datarailsshared.js +14 -14
  7. package/esm2015/lib/date-tags/date-tag.module.js +5 -18
  8. package/esm2015/lib/date-tags/day-tag/day-tag.component.js +28 -21
  9. package/esm2015/lib/date-tags/forecast-tag/forecast-tag.component.js +23 -18
  10. package/esm2015/lib/date-tags/month-tag/month-tag.component.js +25 -23
  11. package/esm2015/lib/date-tags/quarter-tag/quarter-tag.component.js +26 -21
  12. package/esm2015/lib/date-tags/week-tag/week-tag.component.js +27 -63
  13. package/esm2015/lib/date-tags/year-tag/year-tag.component.js +22 -28
  14. package/esm2015/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.js +11 -2
  15. package/esm2015/lib/dr-popover/dr-popover.component.js +31 -2
  16. package/esm2015/lib/dr-popover/dr-popover.directive.js +8 -1
  17. package/esm2015/lib/dr-popover/dr-popover.service.js +3 -2
  18. package/esm2015/lib/list-tags/list-tag.component.js +3 -8
  19. package/esm2015/lib/list-tags/list-tag.module.js +3 -9
  20. package/esm2015/lib/models/popover.js +1 -1
  21. package/fesm2015/datarailsshared-datarailsshared.js +355 -347
  22. package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
  23. package/lib/date-tags/day-tag/day-tag.component.d.ts +3 -5
  24. package/lib/date-tags/forecast-tag/forecast-tag.component.d.ts +1 -0
  25. package/lib/date-tags/month-tag/month-tag.component.d.ts +2 -6
  26. package/lib/date-tags/quarter-tag/quarter-tag.component.d.ts +2 -4
  27. package/lib/date-tags/week-tag/week-tag.component.d.ts +2 -9
  28. package/lib/date-tags/year-tag/year-tag.component.d.ts +2 -6
  29. package/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.d.ts +2 -0
  30. package/lib/dr-popover/dr-popover.component.d.ts +11 -1
  31. package/lib/dr-popover/dr-popover.directive.d.ts +2 -0
  32. package/lib/list-tags/list-tag.component.d.ts +0 -3
  33. package/lib/models/popover.d.ts +1 -0
  34. package/package.json +1 -1
  35. package/datarailsshared-datarailsshared-1.4.122.tgz +0 -0
@@ -8,27 +8,26 @@ export class QuarterTagComponent extends AnyTagComponent {
8
8
  this.lockedDate = [];
9
9
  this.selectedValue = 0;
10
10
  this.quarters = [];
11
- this.dateFilter = (date) => {
12
- let status = true;
13
- this.lockedDate.forEach(timestamp => {
11
+ this.dateFilter = (quarter) => {
12
+ const quarterDate = moment.unix(quarter.value);
13
+ return !this.lockedDate.some((timestamp) => {
14
14
  const lockDate = moment.unix(timestamp);
15
- const quarterDate = moment.unix(date.value);
16
15
  if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {
17
- date.disable = true;
18
- status = false;
16
+ quarter.disabled = true;
17
+ return true;
19
18
  }
19
+ return false;
20
20
  });
21
- return status;
22
21
  };
23
22
  }
24
23
  ngOnInit() {
25
24
  this.initName();
26
25
  this.quarters = this.getQuarterOptions();
27
26
  for (const quarter of this.quarters) {
28
- quarter.disable = false;
27
+ quarter.disabled = false;
29
28
  if (quarter.isSelected) {
30
- this.selectedValue = quarter.value;
31
- this.chosenTagHandler(quarter.value);
29
+ this.selectedValue = quarter;
30
+ this.chosenTagHandler(quarter);
32
31
  }
33
32
  this.dateFilter(quarter);
34
33
  }
@@ -38,17 +37,13 @@ export class QuarterTagComponent extends AnyTagComponent {
38
37
  this.name = 'Quarter';
39
38
  }
40
39
  }
41
- changeSelectHandler(event) {
42
- this.chosenTagHandler(event.value);
43
- }
44
- chosenTagHandler(value) {
45
- const date = new Date(value * 1000);
46
- const resultDate = moment.utc(date);
40
+ chosenTagHandler(quarter) {
41
+ const resultDate = moment.unix(quarter.value).utc();
47
42
  const resultTag = {
48
43
  name: this.name,
49
- value: parseInt(resultDate.format('X'), 10),
44
+ value: resultDate.unix(),
50
45
  label: this.getQuarterLabel(resultDate.toString()),
51
- locked: !this.dateFilter(value)
46
+ locked: !this.dateFilter(quarter)
52
47
  };
53
48
  this.dateChange.emit(resultTag);
54
49
  }
@@ -91,12 +86,22 @@ export class QuarterTagComponent extends AnyTagComponent {
91
86
  }
92
87
  QuarterTagComponent.decorators = [
93
88
  { type: Component, args: [{
94
- template: "<div>\n <mat-form-field>\n <mat-select placeholder=\"{{name}}\" (selectionChange)=\"changeSelectHandler($event)\" [(value)]=\"selectedValue\">\n <mat-option *ngFor=\"let quarter of quarters\" [value]=\"quarter.value\"\n [disabled]=\"quarter.disable\">{{quarter.label}}</mat-option>\n </mat-select>\n </mat-form-field>\n</div>\n",
95
- selector: 'quarter-tag'
89
+ template: "<div>\n <p class=\"tag__label\">{{ name }}</p>\n <dr-select placeholder=\"Select\"\n bindLabel=\"label\"\n [(ngModel)]=\"selectedValue\"\n [items]=\"quarters\"\n (ngModelChange)=\"chosenTagHandler($event)\"></dr-select>\n</div>\n",
90
+ selector: 'quarter-tag',
91
+ styles: [`
92
+ .tag__label {
93
+ margin: 0 0 4px 0;
94
+ color: #0C142B;
95
+ font-size: 14px;
96
+ font-weight: 400;
97
+ line-height: 22px;
98
+
99
+ }
100
+ `]
96
101
  },] }
97
102
  ];
98
103
  QuarterTagComponent.ctorParameters = () => [];
99
104
  QuarterTagComponent.propDecorators = {
100
105
  lockedDate: [{ type: Input }]
101
106
  };
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quarter-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/quarter-tag/quarter-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { IDateTag } from '../../models/serverTags';\nimport { Moment } from 'moment';\nimport { AnyTagComponent } from '../date-tag.component';\nimport { MatSelectChange } from '@angular/material/select';\n// @ts-ignore\nconst moment = require('moment');\n\n@Component({\n    templateUrl: 'quarter-tag.component.html',\n    selector: 'quarter-tag',\n})\nexport class QuarterTagComponent extends AnyTagComponent implements OnInit {\n    @Input() lockedDate: any[] = [];\n    selectedValue = 0;\n    quarters: any[] = [];\n\n    constructor() {\n        super();\n    }\n\n    ngOnInit() {\n        this.initName();\n        this.quarters = this.getQuarterOptions();\n\n        for (const quarter of this.quarters) {\n            quarter.disable = false;\n\n            if (quarter.isSelected) {\n                this.selectedValue = quarter.value;\n                this.chosenTagHandler(quarter.value);\n            }\n\n            this.dateFilter(quarter);\n        }\n    }\n\n    initName() {\n        if (!this.name) {\n            this.name = 'Quarter';\n        }\n    }\n\n    changeSelectHandler(event: MatSelectChange) {\n        this.chosenTagHandler(event.value);\n    }\n\n    chosenTagHandler(value) {\n        const date = new Date(value * 1000);\n        const resultDate: Moment = moment.utc(date);\n        const resultTag: IDateTag = {\n            name: this.name,\n            value: parseInt(resultDate.format('X'), 10),\n            label: this.getQuarterLabel(resultDate.toString()),\n            locked: !this.dateFilter(value)\n        };\n        this.dateChange.emit(resultTag);\n    }\n\n    getQuarterOptions() {\n        const quartersBeforeToday = 8;\n        const quartersAfterToday = 8;\n        const dateNow = new Date();\n        const dateNowUnix = this.getUTCTimestamp(dateNow);\n        let defaultValue = dateNowUnix;\n        let tempDate = new Date();\n        if (this.defaultValue) {\n            defaultValue = this.defaultValue * 1000;\n        }\n\n        let afterDefault = Math.round(Math.abs(dateNowUnix - defaultValue) / 7776000000) + quartersAfterToday;\n        afterDefault = Math.min(afterDefault, 100);\n        let i; let tempValue;\n        const to_return: any[] = [];\n        for (i = 0 - quartersBeforeToday; i <= afterDefault; i++) {\n            tempDate = new Date(defaultValue);\n            tempDate.setDate(15);\n            tempDate.setMonth(tempDate.getMonth() + 3 * i);\n            tempValue = this.getUTCTimestamp(tempDate);\n            to_return.push({\n                value: tempValue / 1000,\n                label: this.getQuarterLabel(tempValue),\n                isSelected: (i === 0),\n            });\n        }\n        return to_return;\n    }\n\n    private getQuarterLabel(timeValue) {\n        const date = new Date(timeValue);\n        return 'Q' + Math.floor((date.getMonth() / 3) + 1) + ' ' + date.getFullYear();\n    }\n\n    private getUTCTimestamp(date) {\n        const month = Math.floor(date.getMonth() / 3) * 3;\n        return Date.UTC(date.getFullYear(), month, 1, 12, 0, 0, 0);\n    }\n\n    dateFilter = (date) => {\n        let status = true;\n\n        this.lockedDate.forEach(timestamp => {\n            const lockDate = moment.unix(timestamp);\n            const quarterDate = moment.unix(date.value);\n\n            if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {\n                date.disable = true;\n                status = false;\n            }\n        });\n\n        return status;\n    };\n}\n"]}
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quarter-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/quarter-tag/quarter-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { IDateTag } from '../../models/serverTags';\nimport { AnyTagComponent } from '../date-tag.component';\n// @ts-ignore\nconst moment = require('moment');\n\n@Component({\n    templateUrl: 'quarter-tag.component.html',\n    styles: [`\n        .tag__label {\n            margin: 0 0 4px 0;\n            color: #0C142B;\n            font-size: 14px;\n            font-weight: 400;\n            line-height: 22px;\n\n        }\n    `],\n    selector: 'quarter-tag',\n})\nexport class QuarterTagComponent extends AnyTagComponent implements OnInit {\n    @Input() lockedDate: any[] = [];\n    selectedValue = 0;\n    quarters: any[] = [];\n\n    constructor() {\n        super();\n    }\n\n    ngOnInit() {\n        this.initName();\n        this.quarters = this.getQuarterOptions();\n\n        for (const quarter of this.quarters) {\n            quarter.disabled = false;\n\n            if (quarter.isSelected) {\n                this.selectedValue = quarter;\n                this.chosenTagHandler(quarter);\n            }\n\n            this.dateFilter(quarter);\n        }\n    }\n\n    initName() {\n        if (!this.name) {\n            this.name = 'Quarter';\n        }\n    }\n\n    chosenTagHandler(quarter) {\n        const resultDate = moment.unix(quarter.value).utc();\n        const resultTag: IDateTag = {\n            name: this.name,\n            value: resultDate.unix(),\n            label: this.getQuarterLabel(resultDate.toString()),\n            locked: !this.dateFilter(quarter)\n        };\n        this.dateChange.emit(resultTag);\n    }\n\n    getQuarterOptions() {\n        const quartersBeforeToday = 8;\n        const quartersAfterToday = 8;\n        const dateNow = new Date();\n        const dateNowUnix = this.getUTCTimestamp(dateNow);\n        let defaultValue = dateNowUnix;\n        let tempDate = new Date();\n        if (this.defaultValue) {\n            defaultValue = this.defaultValue * 1000;\n        }\n\n        let afterDefault = Math.round(Math.abs(dateNowUnix - defaultValue) / 7776000000) + quartersAfterToday;\n        afterDefault = Math.min(afterDefault, 100);\n        let i; let tempValue;\n        const to_return: any[] = [];\n        for (i = 0 - quartersBeforeToday; i <= afterDefault; i++) {\n            tempDate = new Date(defaultValue);\n            tempDate.setDate(15);\n            tempDate.setMonth(tempDate.getMonth() + 3 * i);\n            tempValue = this.getUTCTimestamp(tempDate);\n            to_return.push({\n                value: tempValue / 1000,\n                label: this.getQuarterLabel(tempValue),\n                isSelected: (i === 0),\n            });\n        }\n        return to_return;\n    }\n\n    private getQuarterLabel(timeValue) {\n        const date = new Date(timeValue);\n        return 'Q' + Math.floor((date.getMonth() / 3) + 1) + ' ' + date.getFullYear();\n    }\n\n    private getUTCTimestamp(date) {\n        const month = Math.floor(date.getMonth() / 3) * 3;\n        return Date.UTC(date.getFullYear(), month, 1, 12, 0, 0, 0);\n    }\n\n    dateFilter = (quarter) => {\n        const quarterDate = moment.unix(quarter.value);\n        return !this.lockedDate.some((timestamp) => {\n            const lockDate = moment.unix(timestamp);\n            if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {\n                quarter.disabled = true;\n                return true;\n            }\n\n            return false;\n        });\n    };\n}\n"]}
@@ -1,6 +1,5 @@
1
1
  import { Component, Input } from '@angular/core';
2
2
  import { AnyTagComponent } from '../date-tag.component';
3
- import { FormControl } from '@angular/forms';
4
3
  import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';
5
4
  import { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from '@angular/material-moment-adapter';
6
5
  // @ts-ignore
@@ -21,90 +20,45 @@ export class WeekTagComponent extends AnyTagComponent {
21
20
  constructor() {
22
21
  super();
23
22
  this.lockedDate = [];
24
- this.date = new FormControl(moment());
25
- this.selectedValue = '';
26
23
  this.dateFilter = (date) => {
27
- const calendarDate = moment(date);
28
- let status = true;
29
- this.lockedDate.forEach(timestamp => {
24
+ const week = date.week();
25
+ const year = date.year();
26
+ return !this.lockedDate.some((timestamp) => {
30
27
  const lockDate = moment.unix(timestamp);
31
- return status = !(lockDate.week() === calendarDate.week() && lockDate.year() === calendarDate.year());
28
+ return lockDate.week() === week && lockDate.year() === year;
32
29
  });
33
- return status;
34
30
  };
35
31
  }
36
32
  ngOnInit() {
37
33
  this.initName();
38
- const now = new Date();
39
- now.setHours(0, 0, 0, 0);
40
- const dateUnix = this.getUTCTimestamp(this.getMonday(now));
41
- let default_value_time = dateUnix;
42
- const one_day_in_seconds = 86400;
43
- if (this.defaultValue) {
44
- default_value_time = (this.defaultValue + one_day_in_seconds) * 1000;
45
- }
46
- const default_date = new Date(default_value_time);
47
- const weekNumber = this.getWeekNumberByDate(default_date);
48
- const yearNumber = default_date.getFullYear();
49
- const dateStr = `${yearNumber}-W${weekNumber}`;
50
- this.dateObj.date = dateStr;
51
- this.selectedValue = dateStr;
52
- this.chosenTagHandler(default_date);
34
+ const timestamp = this.defaultValue || moment().unix();
35
+ this.date = timestamp;
36
+ this.dateObj.date = timestamp;
37
+ this.chosenTagHandler(timestamp);
53
38
  }
54
39
  initName() {
55
40
  if (!this.name) {
56
41
  this.name = 'Week';
57
42
  }
58
43
  }
59
- chosenDateHandler(normalizedDay) {
60
- const date = moment(normalizedDay).unix();
61
- this.chosenTagHandler(date);
62
- }
63
44
  chosenTagHandler(value) {
64
- let date;
65
- console.log('chosenTag', value);
66
- if (value > 1000000000000) {
67
- date = new Date(value);
68
- }
69
- else {
70
- date = new Date(value * 1000);
71
- }
72
- const resultDate = moment(date);
45
+ const resultDate = moment.unix(value).utc();
73
46
  const resultTag = {
74
47
  name: this.name,
75
- value: parseInt(resultDate.format('X'), 10),
76
- label: this.getWeekLabel(date),
77
- locked: !this.dateFilter(value)
48
+ value: resultDate.unix(),
49
+ label: this.getWeekLabel(resultDate),
50
+ locked: !this.dateFilter(resultDate)
78
51
  };
79
52
  console.log('resultTag', resultTag);
80
53
  this.dateChange.emit(resultTag);
81
54
  }
82
- getWeekLabel(date) {
83
- return 'W' + this.pad(moment(date).isoWeek(), 2) +
84
- ' ' + moment(date).year();
85
- }
86
- getUTCTimestamp(date) {
87
- return Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), 12, 0, 0, 0);
88
- }
89
- getMonday(date) {
90
- const day = date.getDay() || 7;
91
- if (day !== 1) {
92
- date.setHours(-24 * (day - 1));
93
- }
94
- return date;
95
- }
96
- getWeekNumberByDate(date) {
97
- return this.pad(moment(date).isoWeek(), 2);
98
- }
99
- pad(n, width, z = '0') {
100
- z = z || '0';
101
- n = n + '';
102
- return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;
55
+ getWeekLabel(moment) {
56
+ return `W${moment.isoWeek()} ${moment.year()}`;
103
57
  }
104
58
  }
105
59
  WeekTagComponent.decorators = [
106
60
  { type: Component, args: [{
107
- template: "<div>\n <mat-form-field class=\"date-select-box\">\n <input\n matInput\n placeholder=\"{{name}}\"\n name=\"week\"\n [formControl]=\"date\"\n [matDatepicker]=\"datepicker\"\n [matDatepickerFilter]=\"dateFilter\"\n (ngModelChange)=\"chosenDateHandler($event)\">\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\n <mat-datepicker\n #datepicker\n startView=\"month\"\n ></mat-datepicker>\n </mat-form-field>\n</div>\n",
61
+ template: "<div>\n <p class=\"tag__label\">{{ name }}</p>\n <dr-date-picker format=\"week\"\n [(ngModel)]=\"date\"\n [datepickerFilter]=\"dateFilter\"\n (ngModelChange)=\"chosenTagHandler($event)\"></dr-date-picker>\n</div>\n",
108
62
  selector: 'week-tag',
109
63
  providers: [
110
64
  {
@@ -113,7 +67,17 @@ WeekTagComponent.decorators = [
113
67
  deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
114
68
  },
115
69
  { provide: MAT_DATE_FORMATS, useValue: ɵ0 },
116
- ]
70
+ ],
71
+ styles: [`
72
+ .tag__label {
73
+ margin: 0 0 4px 0;
74
+ color: #0C142B;
75
+ font-size: 14px;
76
+ font-weight: 400;
77
+ line-height: 22px;
78
+
79
+ }
80
+ `]
117
81
  },] }
118
82
  ];
119
83
  WeekTagComponent.ctorParameters = () => [];
@@ -121,4 +85,4 @@ WeekTagComponent.propDecorators = {
121
85
  lockedDate: [{ type: Input }]
122
86
  };
123
87
  export { ɵ0 };
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"week-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/week-tag/week-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { IDateTag } from '../../models/serverTags';\nimport { Moment } from 'moment';\nimport { AnyTagComponent } from '../date-tag.component';\nimport { FormControl } from '@angular/forms';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from '@angular/material-moment-adapter';\n// @ts-ignore\nconst moment = require('moment');\n\nconst WEEK_FORMATS = {\n    parse: {\n        dateInput: 'WW-YYYY',\n    },\n    display: {\n        dateInput: '[Week] WW, YYYY',\n        monthYearLabel: 'MMMM YYYY',\n        dateA11yLabel: 'LL',\n        monthYearA11yLabel: 'MMMM YYYY'\n    },\n};\n\n@Component({\n    templateUrl: 'week-tag.component.html',\n    selector: 'week-tag',\n    providers: [\n        {\n            provide: DateAdapter,\n            useClass: MomentDateAdapter,\n            deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],\n        },\n        { provide: MAT_DATE_FORMATS, useValue: WEEK_FORMATS },\n    ],\n})\nexport class WeekTagComponent extends AnyTagComponent implements OnInit {\n    @Input() lockedDate: any[] = [];\n\n    date = new FormControl(moment());\n    selectedValue = '';\n\n    constructor() {\n        super();\n    }\n\n    ngOnInit() {\n        this.initName();\n\n        const now = new Date();\n        now.setHours(0, 0, 0, 0);\n\n        const dateUnix = this.getUTCTimestamp(this.getMonday(now));\n        let default_value_time = dateUnix;\n        const one_day_in_seconds = 86400;\n        if (this.defaultValue) {\n            default_value_time = (this.defaultValue + one_day_in_seconds) * 1000;\n        }\n\n        const default_date = new Date(default_value_time);\n        const weekNumber = this.getWeekNumberByDate(default_date);\n        const yearNumber = default_date.getFullYear();\n        const dateStr = `${ yearNumber }-W${ weekNumber }`;\n        this.dateObj.date = dateStr;\n        this.selectedValue = dateStr;\n        this.chosenTagHandler(default_date);\n    }\n\n    initName() {\n        if (!this.name) {\n            this.name = 'Week';\n        }\n    }\n\n    chosenDateHandler(normalizedDay) {\n        const date = moment(normalizedDay).unix();\n        this.chosenTagHandler(date);\n    }\n\n    dateFilter = (date) => {\n        const calendarDate = moment(date);\n        let status = true;\n\n        this.lockedDate.forEach(timestamp => {\n            const lockDate = moment.unix(timestamp);\n\n            return status = !(lockDate.week() === calendarDate.week() && lockDate.year() === calendarDate.year());\n        });\n\n        return status;\n    };\n\n    chosenTagHandler(value) {\n        let date;\n        console.log('chosenTag', value);\n        if (value > 1000000000000) {\n            date = new Date(value);\n        } else {\n            date = new Date(value * 1000);\n        }\n\n        const resultDate: Moment = moment(date);\n        const resultTag: IDateTag = {\n            name: this.name,\n            value: parseInt(resultDate.format('X'), 10),\n            label: this.getWeekLabel(date),\n            locked: !this.dateFilter(value)\n        };\n        console.log('resultTag', resultTag);\n        this.dateChange.emit(resultTag);\n    }\n\n    private getWeekLabel(date) {\n        return 'W' + this.pad(moment(date).isoWeek(), 2) +\n            ' ' + moment(date).year();\n    }\n\n    private getUTCTimestamp(date) {\n        return Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), 12, 0, 0, 0);\n    }\n\n    private getMonday(date) {\n        const day = date.getDay() || 7;\n        if (day !== 1) {\n            date.setHours(-24 * (day - 1));\n        }\n        return date;\n    }\n\n    private getWeekNumberByDate(date: Date) {\n        return this.pad(moment(date).isoWeek(), 2);\n    }\n\n    private pad(n, width, z = '0') {\n        z = z || '0';\n        n = n + '';\n        return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;\n    }\n}\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vlay10YWcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZGF0ZS10YWdzL3dlZWstdGFnL3dlZWstdGFnLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN4RixPQUFPLEVBQUUsK0JBQStCLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0RyxhQUFhO0FBQ2IsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBRWpDLE1BQU0sWUFBWSxHQUFHO0lBQ2pCLEtBQUssRUFBRTtRQUNILFNBQVMsRUFBRSxTQUFTO0tBQ3ZCO0lBQ0QsT0FBTyxFQUFFO1FBQ0wsU0FBUyxFQUFFLGlCQUFpQjtRQUM1QixjQUFjLEVBQUUsV0FBVztRQUMzQixhQUFhLEVBQUUsSUFBSTtRQUNuQixrQkFBa0IsRUFBRSxXQUFXO0tBQ2xDO0NBQ0osQ0FBQztXQXFCNkMsWUFBWTtBQUczRCxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsZUFBZTtJQUtqRDtRQUNJLEtBQUssRUFBRSxDQUFDO1FBTEgsZUFBVSxHQUFVLEVBQUUsQ0FBQztRQXNCaEMsZUFBVSxHQUFHLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDbEIsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3pCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUV6QixPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRTtnQkFDdkMsTUFBTSxRQUFRLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztnQkFDeEMsT0FBTyxRQUFRLENBQUMsSUFBSSxFQUFFLEtBQUssSUFBSSxJQUFJLFFBQVEsQ0FBQyxJQUFJLEVBQUUsS0FBSyxJQUFJLENBQUM7WUFDaEUsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUM7SUF4QkYsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDaEIsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksSUFBSSxNQUFNLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBRTtRQUN4RCxJQUFJLENBQUMsSUFBSSxHQUFHLFNBQVMsQ0FBQztRQUN0QixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksR0FBRyxTQUFTLENBQUM7UUFDOUIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDWixJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQztTQUN0QjtJQUNMLENBQUM7SUFZRCxnQkFBZ0IsQ0FBQyxLQUFhO1FBQzFCLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDNUMsTUFBTSxTQUFTLEdBQWE7WUFDeEIsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2YsS0FBSyxFQUFFLFVBQVUsQ0FBQyxJQUFJLEVBQUU7WUFDeEIsS0FBSyxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDO1lBQ3BDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDO1NBQ3ZDLENBQUM7UUFDRixPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRU8sWUFBWSxDQUFDLE1BQU07UUFDdkIsT0FBUSxJQUFLLE1BQU0sQ0FBQyxPQUFPLEVBQUcsSUFBSyxNQUFNLENBQUMsSUFBSSxFQUFHLEVBQUUsQ0FBQztJQUN4RCxDQUFDOzs7WUFyRUosU0FBUyxTQUFDO2dCQUNQLGlTQUFzQztnQkFDdEMsUUFBUSxFQUFFLFVBQVU7Z0JBV3BCLFNBQVMsRUFBRTtvQkFDUDt3QkFDSSxPQUFPLEVBQUUsV0FBVzt3QkFDcEIsUUFBUSxFQUFFLGlCQUFpQjt3QkFDM0IsSUFBSSxFQUFFLENBQUMsZUFBZSxFQUFFLCtCQUErQixDQUFDO3FCQUMzRDtvQkFDRCxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLElBQWMsRUFBRTtpQkFDeEQ7eUJBakJROzs7Ozs7Ozs7S0FTUjthQVNKOzs7O3lCQUVJLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElEYXRlVGFnIH0gZnJvbSAnLi4vLi4vbW9kZWxzL3NlcnZlclRhZ3MnO1xuaW1wb3J0IHsgQW55VGFnQ29tcG9uZW50IH0gZnJvbSAnLi4vZGF0ZS10YWcuY29tcG9uZW50JztcbmltcG9ydCB7IERhdGVBZGFwdGVyLCBNQVRfREFURV9GT1JNQVRTLCBNQVRfREFURV9MT0NBTEUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IE1BVF9NT01FTlRfREFURV9BREFQVEVSX09QVElPTlMsIE1vbWVudERhdGVBZGFwdGVyIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwtbW9tZW50LWFkYXB0ZXInO1xuLy8gQHRzLWlnbm9yZVxuY29uc3QgbW9tZW50ID0gcmVxdWlyZSgnbW9tZW50Jyk7XG5cbmNvbnN0IFdFRUtfRk9STUFUUyA9IHtcbiAgICBwYXJzZToge1xuICAgICAgICBkYXRlSW5wdXQ6ICdXVy1ZWVlZJyxcbiAgICB9LFxuICAgIGRpc3BsYXk6IHtcbiAgICAgICAgZGF0ZUlucHV0OiAnW1dlZWtdIFdXLCBZWVlZJyxcbiAgICAgICAgbW9udGhZZWFyTGFiZWw6ICdNTU1NIFlZWVknLFxuICAgICAgICBkYXRlQTExeUxhYmVsOiAnTEwnLFxuICAgICAgICBtb250aFllYXJBMTF5TGFiZWw6ICdNTU1NIFlZWVknXG4gICAgfSxcbn07XG5cbkBDb21wb25lbnQoe1xuICAgIHRlbXBsYXRlVXJsOiAnd2Vlay10YWcuY29tcG9uZW50Lmh0bWwnLFxuICAgIHNlbGVjdG9yOiAnd2Vlay10YWcnLFxuICAgIHN0eWxlczogW2BcbiAgICAgICAgLnRhZ19fbGFiZWwge1xuICAgICAgICAgICAgbWFyZ2luOiAwIDAgNHB4IDA7XG4gICAgICAgICAgICBjb2xvcjogIzBDMTQyQjtcbiAgICAgICAgICAgIGZvbnQtc2l6ZTogMTRweDtcbiAgICAgICAgICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgICAgICAgICBsaW5lLWhlaWdodDogMjJweDtcblxuICAgICAgICB9XG4gICAgYF0sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IERhdGVBZGFwdGVyLFxuICAgICAgICAgICAgdXNlQ2xhc3M6IE1vbWVudERhdGVBZGFwdGVyLFxuICAgICAgICAgICAgZGVwczogW01BVF9EQVRFX0xPQ0FMRSwgTUFUX01PTUVOVF9EQVRFX0FEQVBURVJfT1BUSU9OU10sXG4gICAgICAgIH0sXG4gICAgICAgIHsgcHJvdmlkZTogTUFUX0RBVEVfRk9STUFUUywgdXNlVmFsdWU6IFdFRUtfRk9STUFUUyB9LFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIFdlZWtUYWdDb21wb25lbnQgZXh0ZW5kcyBBbnlUYWdDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgpIGxvY2tlZERhdGU6IGFueVtdID0gW107XG5cbiAgICBkYXRlO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuaW5pdE5hbWUoKTtcbiAgICAgICAgY29uc3QgdGltZXN0YW1wID0gdGhpcy5kZWZhdWx0VmFsdWUgfHwgbW9tZW50KCkudW5peCgpIDtcbiAgICAgICAgdGhpcy5kYXRlID0gdGltZXN0YW1wO1xuICAgICAgICB0aGlzLmRhdGVPYmouZGF0ZSA9IHRpbWVzdGFtcDtcbiAgICAgICAgdGhpcy5jaG9zZW5UYWdIYW5kbGVyKHRpbWVzdGFtcCk7XG4gICAgfVxuXG4gICAgaW5pdE5hbWUoKSB7XG4gICAgICAgIGlmICghdGhpcy5uYW1lKSB7XG4gICAgICAgICAgICB0aGlzLm5hbWUgPSAnV2Vlayc7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBkYXRlRmlsdGVyID0gKGRhdGUpID0+IHtcbiAgICAgICAgY29uc3Qgd2VlayA9IGRhdGUud2VlaygpO1xuICAgICAgICBjb25zdCB5ZWFyID0gZGF0ZS55ZWFyKCk7XG5cbiAgICAgICAgcmV0dXJuICF0aGlzLmxvY2tlZERhdGUuc29tZSgodGltZXN0YW1wKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBsb2NrRGF0ZSA9IG1vbWVudC51bml4KHRpbWVzdGFtcCk7XG4gICAgICAgICAgICByZXR1cm4gbG9ja0RhdGUud2VlaygpID09PSB3ZWVrICYmIGxvY2tEYXRlLnllYXIoKSA9PT0geWVhcjtcbiAgICAgICAgfSk7XG4gICAgfTtcblxuICAgIGNob3NlblRhZ0hhbmRsZXIodmFsdWU6IG51bWJlcikge1xuICAgICAgICBjb25zdCByZXN1bHREYXRlID0gbW9tZW50LnVuaXgodmFsdWUpLnV0YygpO1xuICAgICAgICBjb25zdCByZXN1bHRUYWc6IElEYXRlVGFnID0ge1xuICAgICAgICAgICAgbmFtZTogdGhpcy5uYW1lLFxuICAgICAgICAgICAgdmFsdWU6IHJlc3VsdERhdGUudW5peCgpLFxuICAgICAgICAgICAgbGFiZWw6IHRoaXMuZ2V0V2Vla0xhYmVsKHJlc3VsdERhdGUpLFxuICAgICAgICAgICAgbG9ja2VkOiAhdGhpcy5kYXRlRmlsdGVyKHJlc3VsdERhdGUpXG4gICAgICAgIH07XG4gICAgICAgIGNvbnNvbGUubG9nKCdyZXN1bHRUYWcnLCByZXN1bHRUYWcpO1xuICAgICAgICB0aGlzLmRhdGVDaGFuZ2UuZW1pdChyZXN1bHRUYWcpO1xuICAgIH1cblxuICAgIHByaXZhdGUgZ2V0V2Vla0xhYmVsKG1vbWVudCkge1xuICAgICAgICByZXR1cm4gIGBXJHsgbW9tZW50Lmlzb1dlZWsoKSB9ICR7IG1vbWVudC55ZWFyKCkgfWA7XG4gICAgfVxufVxuIl19
@@ -1,5 +1,4 @@
1
1
  import { Component, Input } from '@angular/core';
2
- import { FormControl } from '@angular/forms';
3
2
  import { AnyTagComponent } from '../date-tag.component';
4
3
  import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';
5
4
  import { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from '@angular/material-moment-adapter';
@@ -21,24 +20,21 @@ export class YearTagComponent extends AnyTagComponent {
21
20
  constructor() {
22
21
  super();
23
22
  this.lockedDate = [];
24
- this.date = new FormControl(moment());
25
23
  this.dateFilter = (date) => {
26
- const calendarDateYear = moment(date).year();
27
- let status = true;
28
- this.lockedDate.forEach(timestamp => {
24
+ const calendarDateYear = date.year();
25
+ return !this.lockedDate.some((timestamp) => {
29
26
  const lockDate = moment.unix(timestamp);
30
- return status = !(lockDate.year() === calendarDateYear);
27
+ return lockDate.year() === calendarDateYear;
31
28
  });
32
- return status;
33
29
  };
34
30
  }
35
31
  initDate() {
36
32
  if (this.defaultValue) {
37
- this.dateObj.date = moment(new Date(this.defaultValue * 1000)).utc().format('YYYY');
38
- this.date = new FormControl(moment(this.defaultValue * 1000));
33
+ this.date = this.defaultValue;
34
+ this.dateObj.date = this.date;
39
35
  }
40
36
  else {
41
- this.dateObj.date = moment(new Date()).format('YYYY');
37
+ this.dateObj.date = moment().unix();
42
38
  }
43
39
  }
44
40
  initName() {
@@ -47,33 +43,21 @@ export class YearTagComponent extends AnyTagComponent {
47
43
  }
48
44
  }
49
45
  chosenTagHandler(value) {
50
- const date = new Date();
51
- const year = moment(value).year();
52
- date.setTime(0);
53
- date.setFullYear(year, 0, 1);
54
- const resultDate = moment.utc(date);
46
+ const resultDate = moment.unix(value).utc();
55
47
  resultDate.hour(12);
56
48
  const resultTag = {
57
49
  name: this.name,
58
- value: parseInt(resultDate.format('X'), 10),
50
+ value: resultDate.unix(),
59
51
  label: resultDate.format('YYYY'),
60
- locked: !this.dateFilter(value)
52
+ locked: !this.dateFilter(resultDate)
61
53
  };
62
54
  console.log('resultTag', resultTag);
63
55
  this.dateChange.emit(resultTag);
64
56
  }
65
- chosenYearHandler(normalizedYear, datepicker) {
66
- const ctrlValue = this.date.value;
67
- ctrlValue.year(normalizedYear.year());
68
- this.date.setValue(ctrlValue);
69
- this.dateObj.date = this.date.value;
70
- this.chosenTagHandler(this.date.value);
71
- datepicker.close();
72
- }
73
57
  }
74
58
  YearTagComponent.decorators = [
75
59
  { type: Component, args: [{
76
- template: "<div>\n <mat-form-field class=\"date-select-box\">\n <input\n matInput\n placeholder=\"{{name}}\"\n name=\"Year\"\n [formControl]=\"date\"\n [matDatepicker]=\"datepicker\"\n [matDatepickerFilter]=\"dateFilter\">\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\n <mat-datepicker\n #datepicker\n startView=\"multi-year\"\n (yearSelected)=\"chosenYearHandler($event, datepicker)\"\n panelClass=\"date-month-picker\"\n ></mat-datepicker>\n </mat-form-field>\n</div>\n",
60
+ template: "<div>\n <p class=\"tag__label\">{{ name }}</p>\n <dr-date-picker format=\"year\"\n [(ngModel)]=\"date\"\n [datepickerFilter]=\"dateFilter\"\n (ngModelChange)=\"chosenTagHandler($event)\"></dr-date-picker>\n</div>\n",
77
61
  selector: 'year-tag',
78
62
  providers: [
79
63
  {
@@ -82,7 +66,17 @@ YearTagComponent.decorators = [
82
66
  deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
83
67
  },
84
68
  { provide: MAT_DATE_FORMATS, useValue: ɵ0 },
85
- ]
69
+ ],
70
+ styles: [`
71
+ .tag__label {
72
+ margin: 0 0 4px 0;
73
+ color: #0C142B;
74
+ font-size: 14px;
75
+ font-weight: 400;
76
+ line-height: 22px;
77
+
78
+ }
79
+ `]
86
80
  },] }
87
81
  ];
88
82
  YearTagComponent.ctorParameters = () => [];
@@ -90,4 +84,4 @@ YearTagComponent.propDecorators = {
90
84
  lockedDate: [{ type: Input }]
91
85
  };
92
86
  export { ɵ0 };
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"year-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/year-tag/year-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { MatDatepicker } from '@angular/material/datepicker';\nimport { Moment } from 'moment';\nimport { IDateTag } from '../../models/serverTags';\nimport { AnyTagComponent } from '../date-tag.component';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from '@angular/material-moment-adapter';\n// @ts-ignore\nconst moment = require('moment');\n\nconst YEAR_FORMATS = {\n    parse: {\n        dateInput: 'YYYY',\n    },\n    display: {\n        dateInput: 'YYYY',\n        monthYearLabel: 'MMMM YYYY',\n        dateA11yLabel: 'LL',\n        monthYearA11yLabel: 'MMMM YYYY'\n    },\n};\n\n@Component({\n    templateUrl: 'year-tag.component.html',\n    selector: 'year-tag',\n    providers: [\n        {\n            provide: DateAdapter,\n            useClass: MomentDateAdapter,\n            deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],\n        },\n        { provide: MAT_DATE_FORMATS, useValue: YEAR_FORMATS },\n    ],\n})\n\nexport class YearTagComponent extends AnyTagComponent {\n    @Input() lockedDate: any[] = [];\n\n    date = new FormControl(moment());\n\n    constructor() {\n        super();\n    }\n\n    initDate() {\n        if (this.defaultValue) {\n            this.dateObj.date = moment(new Date(this.defaultValue * 1000)).utc().format('YYYY');\n            this.date = new FormControl(moment(this.defaultValue * 1000));\n        } else {\n            this.dateObj.date = moment(new Date()).format('YYYY');\n        }\n    }\n\n    initName() {\n        if (!this.name) {\n            this.name = 'Year';\n        }\n    }\n\n    chosenTagHandler(value) {\n        const date = new Date();\n        const year = moment(value).year();\n        date.setTime(0);\n        date.setFullYear(year, 0, 1);\n        const resultDate: Moment = moment.utc(date);\n        resultDate.hour(12);\n        const resultTag: IDateTag = {\n            name: this.name,\n            value: parseInt(resultDate.format('X'), 10),\n            label: resultDate.format('YYYY'),\n            locked: !this.dateFilter(value)\n        };\n        console.log('resultTag', resultTag);\n        this.dateChange.emit(resultTag);\n    }\n\n    chosenYearHandler(normalizedYear: Moment, datepicker: MatDatepicker<Moment>) {\n        const ctrlValue = this.date.value;\n        ctrlValue.year(normalizedYear.year());\n\n        this.date.setValue(ctrlValue);\n        this.dateObj.date = this.date.value;\n        this.chosenTagHandler(this.date.value);\n\n        datepicker.close();\n    }\n\n    dateFilter = (date) => {\n        const calendarDateYear = moment(date).year();\n        let status = true;\n\n        this.lockedDate.forEach(timestamp => {\n            const lockDate = moment.unix(timestamp);\n\n            return status = !(lockDate.year() === calendarDateYear);\n        });\n\n        return status;\n    };\n}\n"]}
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieWVhci10YWcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZGF0ZS10YWdzL3llYXItdGFnL3llYXItdGFnLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN4RixPQUFPLEVBQUUsK0JBQStCLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0RyxhQUFhO0FBQ2IsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBRWpDLE1BQU0sWUFBWSxHQUFHO0lBQ2pCLEtBQUssRUFBRTtRQUNILFNBQVMsRUFBRSxNQUFNO0tBQ3BCO0lBQ0QsT0FBTyxFQUFFO1FBQ0wsU0FBUyxFQUFFLE1BQU07UUFDakIsY0FBYyxFQUFFLFdBQVc7UUFDM0IsYUFBYSxFQUFFLElBQUk7UUFDbkIsa0JBQWtCLEVBQUUsV0FBVztLQUNsQztDQUNKLENBQUM7V0FxQjZDLFlBQVk7QUFJM0QsTUFBTSxPQUFPLGdCQUFpQixTQUFRLGVBQWU7SUFLakQ7UUFDSSxLQUFLLEVBQUUsQ0FBQztRQUxILGVBQVUsR0FBVSxFQUFFLENBQUM7UUFxQ2hDLGVBQVUsR0FBRyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ2xCLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBRXJDLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFO2dCQUN2QyxNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO2dCQUN4QyxPQUFPLFFBQVEsQ0FBQyxJQUFJLEVBQUUsS0FBSyxnQkFBZ0IsQ0FBQztZQUNoRCxDQUFDLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQztJQXRDRixDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUNuQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUM7WUFDOUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztTQUNqQzthQUFNO1lBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsTUFBTSxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDdkM7SUFDTCxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ1osSUFBSSxDQUFDLElBQUksR0FBRyxNQUFNLENBQUM7U0FDdEI7SUFDTCxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsS0FBYTtRQUMxQixNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQzVDLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7UUFFcEIsTUFBTSxTQUFTLEdBQWE7WUFDeEIsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2YsS0FBSyxFQUFFLFVBQVUsQ0FBQyxJQUFJLEVBQUU7WUFDeEIsS0FBSyxFQUFFLFVBQVUsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDO1lBQ2hDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDO1NBQ3ZDLENBQUM7UUFDRixPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNwQyxDQUFDOzs7WUEzREosU0FBUyxTQUFDO2dCQUNQLGlTQUFzQztnQkFDdEMsUUFBUSxFQUFFLFVBQVU7Z0JBV3BCLFNBQVMsRUFBRTtvQkFDUDt3QkFDSSxPQUFPLEVBQUUsV0FBVzt3QkFDcEIsUUFBUSxFQUFFLGlCQUFpQjt3QkFDM0IsSUFBSSxFQUFFLENBQUMsZUFBZSxFQUFFLCtCQUErQixDQUFDO3FCQUMzRDtvQkFDRCxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLElBQWMsRUFBRTtpQkFDeEQ7eUJBakJROzs7Ozs7Ozs7S0FTUjthQVNKOzs7O3lCQUdJLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJRGF0ZVRhZyB9IGZyb20gJy4uLy4uL21vZGVscy9zZXJ2ZXJUYWdzJztcbmltcG9ydCB7IEFueVRhZ0NvbXBvbmVudCB9IGZyb20gJy4uL2RhdGUtdGFnLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYXRlQWRhcHRlciwgTUFUX0RBVEVfRk9STUFUUywgTUFUX0RBVEVfTE9DQUxFIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQgeyBNQVRfTU9NRU5UX0RBVEVfQURBUFRFUl9PUFRJT05TLCBNb21lbnREYXRlQWRhcHRlciB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsLW1vbWVudC1hZGFwdGVyJztcbi8vIEB0cy1pZ25vcmVcbmNvbnN0IG1vbWVudCA9IHJlcXVpcmUoJ21vbWVudCcpO1xuXG5jb25zdCBZRUFSX0ZPUk1BVFMgPSB7XG4gICAgcGFyc2U6IHtcbiAgICAgICAgZGF0ZUlucHV0OiAnWVlZWScsXG4gICAgfSxcbiAgICBkaXNwbGF5OiB7XG4gICAgICAgIGRhdGVJbnB1dDogJ1lZWVknLFxuICAgICAgICBtb250aFllYXJMYWJlbDogJ01NTU0gWVlZWScsXG4gICAgICAgIGRhdGVBMTF5TGFiZWw6ICdMTCcsXG4gICAgICAgIG1vbnRoWWVhckExMXlMYWJlbDogJ01NTU0gWVlZWSdcbiAgICB9LFxufTtcblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6ICd5ZWFyLXRhZy5jb21wb25lbnQuaHRtbCcsXG4gICAgc2VsZWN0b3I6ICd5ZWFyLXRhZycsXG4gICAgc3R5bGVzOiBbYFxuICAgICAgICAudGFnX19sYWJlbCB7XG4gICAgICAgICAgICBtYXJnaW46IDAgMCA0cHggMDtcbiAgICAgICAgICAgIGNvbG9yOiAjMEMxNDJCO1xuICAgICAgICAgICAgZm9udC1zaXplOiAxNHB4O1xuICAgICAgICAgICAgZm9udC13ZWlnaHQ6IDQwMDtcbiAgICAgICAgICAgIGxpbmUtaGVpZ2h0OiAyMnB4O1xuXG4gICAgICAgIH1cbiAgICBgXSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogRGF0ZUFkYXB0ZXIsXG4gICAgICAgICAgICB1c2VDbGFzczogTW9tZW50RGF0ZUFkYXB0ZXIsXG4gICAgICAgICAgICBkZXBzOiBbTUFUX0RBVEVfTE9DQUxFLCBNQVRfTU9NRU5UX0RBVEVfQURBUFRFUl9PUFRJT05TXSxcbiAgICAgICAgfSxcbiAgICAgICAgeyBwcm92aWRlOiBNQVRfREFURV9GT1JNQVRTLCB1c2VWYWx1ZTogWUVBUl9GT1JNQVRTIH0sXG4gICAgXSxcbn0pXG5cbmV4cG9ydCBjbGFzcyBZZWFyVGFnQ29tcG9uZW50IGV4dGVuZHMgQW55VGFnQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKSBsb2NrZWREYXRlOiBhbnlbXSA9IFtdO1xuXG4gICAgZGF0ZTtcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIGluaXREYXRlKCkge1xuICAgICAgICBpZiAodGhpcy5kZWZhdWx0VmFsdWUpIHtcbiAgICAgICAgICAgIHRoaXMuZGF0ZSA9IHRoaXMuZGVmYXVsdFZhbHVlO1xuICAgICAgICAgICAgdGhpcy5kYXRlT2JqLmRhdGUgPSB0aGlzLmRhdGU7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmRhdGVPYmouZGF0ZSA9IG1vbWVudCgpLnVuaXgoKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGluaXROYW1lKCkge1xuICAgICAgICBpZiAoIXRoaXMubmFtZSkge1xuICAgICAgICAgICAgdGhpcy5uYW1lID0gJ1llYXInO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgY2hvc2VuVGFnSGFuZGxlcih2YWx1ZTogbnVtYmVyKSB7XG4gICAgICAgIGNvbnN0IHJlc3VsdERhdGUgPSBtb21lbnQudW5peCh2YWx1ZSkudXRjKCk7XG4gICAgICAgIHJlc3VsdERhdGUuaG91cigxMik7XG5cbiAgICAgICAgY29uc3QgcmVzdWx0VGFnOiBJRGF0ZVRhZyA9IHtcbiAgICAgICAgICAgIG5hbWU6IHRoaXMubmFtZSxcbiAgICAgICAgICAgIHZhbHVlOiByZXN1bHREYXRlLnVuaXgoKSxcbiAgICAgICAgICAgIGxhYmVsOiByZXN1bHREYXRlLmZvcm1hdCgnWVlZWScpLFxuICAgICAgICAgICAgbG9ja2VkOiAhdGhpcy5kYXRlRmlsdGVyKHJlc3VsdERhdGUpXG4gICAgICAgIH07XG4gICAgICAgIGNvbnNvbGUubG9nKCdyZXN1bHRUYWcnLCByZXN1bHRUYWcpO1xuICAgICAgICB0aGlzLmRhdGVDaGFuZ2UuZW1pdChyZXN1bHRUYWcpO1xuICAgIH1cblxuICAgIGRhdGVGaWx0ZXIgPSAoZGF0ZSkgPT4ge1xuICAgICAgICBjb25zdCBjYWxlbmRhckRhdGVZZWFyID0gZGF0ZS55ZWFyKCk7XG5cbiAgICAgICAgcmV0dXJuICF0aGlzLmxvY2tlZERhdGUuc29tZSgodGltZXN0YW1wKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBsb2NrRGF0ZSA9IG1vbWVudC51bml4KHRpbWVzdGFtcCk7XG4gICAgICAgICAgICByZXR1cm4gbG9ja0RhdGUueWVhcigpID09PSBjYWxlbmRhckRhdGVZZWFyO1xuICAgICAgICB9KTtcbiAgICB9O1xufVxuIl19
@@ -6,6 +6,7 @@ import { DrDatePickerService } from '../services/dr-date-picker.service';
6
6
  import { Subject } from 'rxjs';
7
7
  import { takeUntil } from 'rxjs/operators';
8
8
  import { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';
9
+ // @ts-ignore
9
10
  const moment = require('moment');
10
11
  const noop = () => {
11
12
  };
@@ -32,6 +33,13 @@ export class DrDatePickerComponent {
32
33
  this.destroyed$ = new Subject();
33
34
  this.onTouchedCallback = noop;
34
35
  this.onChangeCallback = noop;
36
+ // Should be as arrow function to avoid lose scope
37
+ this.dateFilter = (moment) => {
38
+ if (this.datepickerFilter && moment) {
39
+ return this.datepickerFilter(moment);
40
+ }
41
+ return true;
42
+ };
35
43
  datePickerService.updatedQuarter$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {
36
44
  this.setValueFromMoment(value);
37
45
  });
@@ -174,7 +182,7 @@ export class DrDatePickerComponent {
174
182
  DrDatePickerComponent.decorators = [
175
183
  { type: Component, args: [{
176
184
  selector: 'dr-date-picker',
177
- template: "<i class=\"dr-icon-schedule\"></i>\n<input [(ngModel)]=\"value\"\n (click)=\"datePicker.open()\"\n [matDatepicker]=\"datePicker\"\n [placeholder]=\"placeholder\"\n [drDatePickerFormat]=\"datePickerService.format$ | async\"\n [readonly]=\"readonly\"\n [min]=\"_min\"\n [max]=\"_max\"/>\n<mat-datepicker #datePicker\n [calendarHeaderComponent]=\"customHeader\"\n (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR)\"\n (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH)\">\n</mat-datepicker>\n",
185
+ template: "<i class=\"dr-icon-schedule\"></i>\n<input [(ngModel)]=\"value\"\n (click)=\"datePicker.open()\"\n [matDatepicker]=\"datePicker\"\n [matDatepickerFilter]=\"dateFilter\"\n [placeholder]=\"placeholder\"\n [drDatePickerFormat]=\"datePickerService.format$ | async\"\n [readonly]=\"readonly\"\n [min]=\"_min\"\n [max]=\"_max\"/>\n<mat-datepicker #datePicker\n [calendarHeaderComponent]=\"customHeader\"\n (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR)\"\n (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH)\">\n</mat-datepicker>\n",
178
186
  changeDetection: ChangeDetectionStrategy.OnPush,
179
187
  providers: [
180
188
  { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerComponent, multi: true },
@@ -195,7 +203,8 @@ DrDatePickerComponent.propDecorators = {
195
203
  periodPosition: [{ type: Input }],
196
204
  placeholder: [{ type: Input }],
197
205
  fiscalYearMonthsModifier: [{ type: Input }],
206
+ datepickerFilter: [{ type: Input }],
198
207
  datePicker: [{ type: ViewChild, args: ['datePicker',] }]
199
208
  };
200
209
  export { ɵ0 };
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Input,\n    OnDestroy,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CalendarView, DatePickerPeriodPosition, TimeframeOption } from '../../../models/datePicker';\nimport { Moment } from 'moment';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';\nimport { MatCalendarView } from '@angular/material/datepicker';\nimport * as _ from 'lodash';\n\nconst moment = require('moment');\nconst noop = () => {\n};\n\n@Component({\n    selector: 'dr-date-picker',\n    templateUrl: './dr-date-picker.component.html',\n    styleUrls: ['./dr-date-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerComponent, multi: true },\n        { provide: DrDatePickerService }\n    ],\n})\nexport class DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\n\n    @Input() set format(value) {\n        this.datePickerService.updateTimeframeAndFormat(value);\n    }\n\n    @Input() set min(minDate: number) {\n        this._min = moment.unix(minDate).utc();\n    }\n\n    @Input() set max(maxDate: number) {\n        this._max = moment.unix(maxDate).utc();\n    }\n\n    // Whether to transform date, taking end, start, middle of preiod (i.e. set middle of month if timeframe='month')\n    @Input() periodPosition: DatePickerPeriodPosition = DatePickerPeriodPosition.DEFAULT;\n\n    @Input() placeholder = 'Select';\n\n    @Input() fiscalYearMonthsModifier = 0;\n\n    @ViewChild('datePicker') public datePicker: any;\n\n    public calendarViewsTimeframeMapping: any = {\n        year: 'multi-year',\n        month: 'year',\n        quarter: 'none',\n        day: 'month',\n    };\n\n    public customHeader = DrDatePickerCustomHeaderComponent;\n    public readonly = true;\n    public _min: Moment;\n    public _max: Moment;\n    public readonly timeframeOption = TimeframeOption;\n\n    public get value(): Moment {\n        return this.innerValue;\n    }\n\n    public set value(v: Moment) {\n        if (v !== this.innerValue) {\n            this.setValueFromMoment(v);\n        }\n        this.cdr.markForCheck();\n    }\n\n    protected innerValue: Moment = null;\n    protected destroyed$ = new Subject<void>();\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected dateAdapter: DateAdapter<any>,\n        public datePickerService: DrDatePickerService\n    ) {\n        datePickerService.updatedQuarter$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.setValueFromMoment(value);\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.datePickerService.fiscalYearMonthsModifier = this.fiscalYearMonthsModifier;\n        this.datePickerService.datePickerInstance = this.datePicker;\n        this.datePicker.startView = this.calendarViewsTimeframeMapping[this.datePickerService.timeframe];\n    }\n\n    ngOnDestroy() {\n        this.destroyed$.next();\n        this.destroyed$.complete();\n    }\n\n    /**\n     * Updating component inner value according to datepicker timeframe (day, month etc.)\n     * and date position in period (start, end, middle)\n     */\n    tryToNormalaizeTimeframe(): void {\n        const timeframe = this.datePickerService.timeframe;\n        switch (this.periodPosition) {\n            case DatePickerPeriodPosition.START_OF_PERIOD:\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    this.datePickerService.setStartOfCurrentQuarter(this.innerValue);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    this.datePickerService.setStartOfQuarter(this.innerValue, 1);\n                } else {\n                    this.innerValue.startOf(timeframe);\n                }\n                break;\n            case DatePickerPeriodPosition.END_OF_PERIOD:\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    this.datePickerService.setEndOfCurrentQuarter(this.innerValue);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    this.datePickerService.setEndOfQuarter(this.innerValue, 4);\n                } else {\n                    this.innerValue.endOf(timeframe);\n                }\n                break;\n            case DatePickerPeriodPosition.MIDDLE_OF_PERIOD:\n                let endOfPeriod: Moment;\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    endOfPeriod = this.innerValue.clone();\n                    this.datePickerService.setStartOfCurrentQuarter(this.innerValue);\n                    this.datePickerService.setEndOfCurrentQuarter(endOfPeriod);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    endOfPeriod = this.innerValue.clone();\n                    this.datePickerService.setStartOfQuarter(this.innerValue, 1);\n                    this.datePickerService.setEndOfQuarter(endOfPeriod, 4);\n                } else {\n                    this.innerValue.startOf(timeframe);\n                    endOfPeriod = this.innerValue.clone().endOf(timeframe);\n                }\n                const diff = endOfPeriod.diff(this.innerValue, 'seconds');\n                this.innerValue.add(diff / 2 + 1, 'seconds');\n                break;\n            default:\n                this.innerValue.startOf(timeframe);\n                break;\n        }\n    }\n\n    public chosenPeriodHandler(chosenDate: Moment, timeframe: TimeframeOption) {\n\n        if (timeframe === TimeframeOption.YEAR) {\n            chosenDate = this.datePickerService.addFiscalYearMonthsToDate(chosenDate);\n        }\n\n        if (this.datePickerService.timeframe === TimeframeOption.QUARTER && timeframe === TimeframeOption.YEAR) {\n            this.datePickerService.calendarInstance.currentView = CalendarView.FOR_QUARTERS as MatCalendarView;\n            this.datePickerService.calendarInstance.activeDate = chosenDate;\n            this.cdr.detectChanges();\n        } else if (this.datePickerService.timeframe === timeframe) {\n            this.setValueFromMoment(chosenDate);\n            this.datePicker.close();\n        }\n    }\n\n    /**\n     * Setting value from outside of component via ngModel or formControl updates\n     */\n    public writeValue(value: number): void {\n        this.innerValue = value ? moment.unix(value).utc() : value;\n        if (this.innerValue) {\n            this.tryToNormalaizeTimeframe();\n        }\n        this.cdr.markForCheck();\n    }\n\n    public onTouchedCallback: () => void = noop;\n    public onChangeCallback: (_: any) => void = noop;\n\n    public registerOnChange(fn: any): void {\n        this.onChangeCallback = fn;\n    }\n\n    public registerOnTouched(fn: any): void {\n        this.onTouchedCallback = fn;\n    }\n\n    /**\n     * Set inner value from Moment and propagate\n     *\n     * @param momentDate\n     */\n    protected setValueFromMoment(momentDate: Moment) {\n        this.setValue(momentDate.unix());\n    }\n\n    /**\n     * Set inner value from timestamp and propagate\n     *\n     * @param timestamp\n     */\n    protected setValue(timestamp: number): void {\n\n        // isValueUpdating is required for manage clicks on same dates: if isValueUpdating - true then\n        // days are different and subscription on calendar day click action won't trigger Accessor ngModel update\n        // one more time\n        this.datePickerService.isValueUpdating = true;\n        this.writeValue(timestamp);\n        this.onChangeCallback(this.innerValue.unix());\n        setTimeout(() => {\n            this.datePickerService.isValueUpdating = false;\n        });\n    }\n}\n"]}
210
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Input,\n    OnDestroy,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CalendarView, DatePickerPeriodPosition, TimeframeOption } from '../../../models/datePicker';\nimport { Moment } from 'moment';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';\nimport { MatCalendarView } from '@angular/material/datepicker';\n\n// @ts-ignore\nconst moment = require('moment');\nconst noop = () => {\n};\n\n@Component({\n    selector: 'dr-date-picker',\n    templateUrl: './dr-date-picker.component.html',\n    styleUrls: ['./dr-date-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerComponent, multi: true },\n        { provide: DrDatePickerService }\n    ],\n})\nexport class DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\n\n    @Input() set format(value) {\n        this.datePickerService.updateTimeframeAndFormat(value);\n    }\n\n    @Input() set min(minDate: number) {\n        this._min = moment.unix(minDate).utc();\n    }\n\n    @Input() set max(maxDate: number) {\n        this._max = moment.unix(maxDate).utc();\n    }\n\n    // Whether to transform date, taking end, start, middle of preiod (i.e. set middle of month if timeframe='month')\n    @Input() periodPosition: DatePickerPeriodPosition = DatePickerPeriodPosition.DEFAULT;\n\n    @Input() placeholder = 'Select';\n\n    @Input() fiscalYearMonthsModifier = 0;\n\n    @Input() datepickerFilter: (moment: Moment) => boolean;\n\n    @ViewChild('datePicker') public datePicker: any;\n\n    public calendarViewsTimeframeMapping: any = {\n        year: 'multi-year',\n        month: 'year',\n        quarter: 'none',\n        day: 'month',\n    };\n\n    public customHeader = DrDatePickerCustomHeaderComponent;\n    public readonly = true;\n    public _min: Moment;\n    public _max: Moment;\n    public readonly timeframeOption = TimeframeOption;\n\n    public get value(): Moment {\n        return this.innerValue;\n    }\n\n    public set value(v: Moment) {\n        if (v !== this.innerValue) {\n            this.setValueFromMoment(v);\n        }\n        this.cdr.markForCheck();\n    }\n\n    protected innerValue: Moment = null;\n    protected destroyed$ = new Subject<void>();\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected dateAdapter: DateAdapter<any>,\n        public datePickerService: DrDatePickerService\n    ) {\n        datePickerService.updatedQuarter$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.setValueFromMoment(value);\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.datePickerService.fiscalYearMonthsModifier = this.fiscalYearMonthsModifier;\n        this.datePickerService.datePickerInstance = this.datePicker;\n        this.datePicker.startView = this.calendarViewsTimeframeMapping[this.datePickerService.timeframe];\n    }\n\n    ngOnDestroy() {\n        this.destroyed$.next();\n        this.destroyed$.complete();\n    }\n\n    /**\n     * Updating component inner value according to datepicker timeframe (day, month etc.)\n     * and date position in period (start, end, middle)\n     */\n    tryToNormalaizeTimeframe(): void {\n        const timeframe = this.datePickerService.timeframe;\n        switch (this.periodPosition) {\n            case DatePickerPeriodPosition.START_OF_PERIOD:\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    this.datePickerService.setStartOfCurrentQuarter(this.innerValue);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    this.datePickerService.setStartOfQuarter(this.innerValue, 1);\n                } else {\n                    this.innerValue.startOf(timeframe);\n                }\n                break;\n            case DatePickerPeriodPosition.END_OF_PERIOD:\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    this.datePickerService.setEndOfCurrentQuarter(this.innerValue);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    this.datePickerService.setEndOfQuarter(this.innerValue, 4);\n                } else {\n                    this.innerValue.endOf(timeframe);\n                }\n                break;\n            case DatePickerPeriodPosition.MIDDLE_OF_PERIOD:\n                let endOfPeriod: Moment;\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    endOfPeriod = this.innerValue.clone();\n                    this.datePickerService.setStartOfCurrentQuarter(this.innerValue);\n                    this.datePickerService.setEndOfCurrentQuarter(endOfPeriod);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    endOfPeriod = this.innerValue.clone();\n                    this.datePickerService.setStartOfQuarter(this.innerValue, 1);\n                    this.datePickerService.setEndOfQuarter(endOfPeriod, 4);\n                } else {\n                    this.innerValue.startOf(timeframe);\n                    endOfPeriod = this.innerValue.clone().endOf(timeframe);\n                }\n                const diff = endOfPeriod.diff(this.innerValue, 'seconds');\n                this.innerValue.add(diff / 2 + 1, 'seconds');\n                break;\n            default:\n                this.innerValue.startOf(timeframe);\n                break;\n        }\n    }\n\n    public chosenPeriodHandler(chosenDate: Moment, timeframe: TimeframeOption) {\n\n        if (timeframe === TimeframeOption.YEAR) {\n            chosenDate = this.datePickerService.addFiscalYearMonthsToDate(chosenDate);\n        }\n\n        if (this.datePickerService.timeframe === TimeframeOption.QUARTER && timeframe === TimeframeOption.YEAR) {\n            this.datePickerService.calendarInstance.currentView = CalendarView.FOR_QUARTERS as MatCalendarView;\n            this.datePickerService.calendarInstance.activeDate = chosenDate;\n            this.cdr.detectChanges();\n        } else if (this.datePickerService.timeframe === timeframe) {\n            this.setValueFromMoment(chosenDate);\n            this.datePicker.close();\n        }\n    }\n\n    /**\n     * Setting value from outside of component via ngModel or formControl updates\n     */\n    public writeValue(value: number): void {\n        this.innerValue = value ? moment.unix(value).utc() : value;\n        if (this.innerValue) {\n            this.tryToNormalaizeTimeframe();\n        }\n        this.cdr.markForCheck();\n    }\n\n    public onTouchedCallback: () => void = noop;\n    public onChangeCallback: (_: any) => void = noop;\n\n    public registerOnChange(fn: any): void {\n        this.onChangeCallback = fn;\n    }\n\n    public registerOnTouched(fn: any): void {\n        this.onTouchedCallback = fn;\n    }\n\n    // Should be as arrow function to avoid lose scope\n    public dateFilter = (moment: Moment) => {\n        if (this.datepickerFilter && moment) {\n            return this.datepickerFilter(moment);\n        }\n\n        return true;\n    }\n\n    /**\n     * Set inner value from Moment and propagate\n     *\n     * @param momentDate\n     */\n    protected setValueFromMoment(momentDate: Moment) {\n        this.setValue(momentDate.unix());\n    }\n\n    /**\n     * Set inner value from timestamp and propagate\n     *\n     * @param timestamp\n     */\n    protected setValue(timestamp: number): void {\n\n        // isValueUpdating is required for manage clicks on same dates: if isValueUpdating - true then\n        // days are different and subscription on calendar day click action won't trigger Accessor ngModel update\n        // one more time\n        this.datePickerService.isValueUpdating = true;\n        this.writeValue(timestamp);\n        this.onChangeCallback(this.innerValue.unix());\n        setTimeout(() => {\n            this.datePickerService.isValueUpdating = false;\n        });\n    }\n}\n"]}