@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.
- package/_datarailsshared.styles.css +3 -3
- package/assets/styles/_styles.scss +2 -2
- package/assets/styles/img/default-avatar.svg +5 -5
- package/bundles/datarailsshared-datarailsshared.umd.js +3984 -3995
- package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
- package/datarailsshared-datarailsshared-1.3.51.tgz +0 -0
- package/datarailsshared-datarailsshared.d.ts +9 -9
- package/datarailsshared-datarailsshared.metadata.json +1 -1
- package/esm2015/datarailsshared-datarailsshared.js +9 -9
- package/esm2015/lib/date-tags/date-tag.component.js +70 -70
- package/esm2015/lib/date-tags/date-tag.module.js +50 -50
- package/esm2015/lib/date-tags/day-tag/day-tag.component.js +81 -81
- package/esm2015/lib/date-tags/forecast-tag/forecast-tag.component.js +143 -143
- package/esm2015/lib/date-tags/month-tag/month-tag.component.js +87 -87
- package/esm2015/lib/date-tags/quarter-tag/quarter-tag.component.js +101 -101
- package/esm2015/lib/date-tags/week-tag/week-tag.component.js +124 -124
- package/esm2015/lib/date-tags/year-tag/year-tag.component.js +93 -93
- package/esm2015/lib/dr-accordion/accordion-item-body.component.js +57 -57
- package/esm2015/lib/dr-accordion/accordion-item-header.component.js +79 -79
- package/esm2015/lib/dr-accordion/accordion-item.component.js +123 -123
- package/esm2015/lib/dr-accordion/accordion.component.js +43 -43
- package/esm2015/lib/dr-accordion/accordion.module.js +23 -23
- package/esm2015/lib/dr-avatar/dr-avatar.component.js +42 -42
- package/esm2015/lib/dr-avatar/dr-avatar.module.js +26 -26
- package/esm2015/lib/dr-avatar/dr-avatar.pipe.js +15 -15
- package/esm2015/lib/dr-dropdown/dr-dropdown-item-show.pipe.js +12 -12
- package/esm2015/lib/dr-dropdown/dr-dropdown-position.directive.js +97 -97
- package/esm2015/lib/dr-dropdown/dr-dropdown.component.js +110 -110
- package/esm2015/lib/dr-dropdown/dr-dropdown.directive.js +89 -89
- package/esm2015/lib/dr-dropdown/dr-dropdown.module.js +34 -34
- package/esm2015/lib/dr-dropdown/dr-dropdown.service.js +24 -24
- package/esm2015/lib/dr-inputs/button/button.component.js +80 -80
- package/esm2015/lib/dr-inputs/checkbox/checkbox.component.js +63 -63
- package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.js +47 -47
- package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.component.js +183 -186
- package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.service.js +41 -41
- package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.js +129 -129
- package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +185 -185
- package/esm2015/lib/dr-inputs/dr-inputs.module.js +51 -51
- package/esm2015/lib/dr-inputs/dr-model-debounce-change.directive.js +31 -31
- package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +90 -90
- package/esm2015/lib/dr-inputs/dr-toggle/dr-toggle.component.js +64 -64
- package/esm2015/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.js +56 -56
- package/esm2015/lib/dr-inputs/radio-button/radio-button.component.js +64 -64
- package/esm2015/lib/dr-inputs/radio-button/radio-group.component.js +164 -164
- package/esm2015/lib/dr-popover/dr-popover-ref.js +20 -20
- package/esm2015/lib/dr-popover/dr-popover.component.js +77 -77
- package/esm2015/lib/dr-popover/dr-popover.directive.js +72 -72
- package/esm2015/lib/dr-popover/dr-popover.module.js +23 -23
- package/esm2015/lib/dr-popover/dr-popover.service.js +102 -102
- package/esm2015/lib/dr-spinner/dr-spinner.component.js +29 -29
- package/esm2015/lib/dr-spinner/dr-spinner.directive.js +53 -53
- package/esm2015/lib/dr-spinner/dr-spinner.module.js +18 -18
- package/esm2015/lib/dr-tabs/dr-tab.component.js +23 -23
- package/esm2015/lib/dr-tabs/dr-tabs.component.js +28 -28
- package/esm2015/lib/dr-tabs/dr-tabs.module.js +30 -30
- package/esm2015/lib/dr-tags/dr-tag.component.js +54 -54
- package/esm2015/lib/dr-tags/dr-tag.module.js +22 -22
- package/esm2015/lib/dr-tooltip/dr-tooltip.component.js +30 -30
- package/esm2015/lib/dr-tooltip/dr-tooltip.directive.js +102 -102
- package/esm2015/lib/dr-tooltip/dr-tooltip.module.js +23 -23
- package/esm2015/lib/list-tags/list-tag.component.js +41 -41
- package/esm2015/lib/list-tags/list-tag.module.js +29 -29
- package/esm2015/lib/models/constants.js +97 -97
- package/esm2015/lib/models/datePicker.js +40 -40
- package/esm2015/lib/models/dropdown.js +2 -2
- package/esm2015/lib/models/popover.js +27 -27
- package/esm2015/lib/models/serverTags.js +2 -2
- package/esm2015/public-api.js +57 -57
- package/fesm2015/datarailsshared-datarailsshared.js +3365 -3368
- package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
- package/lib/date-tags/date-tag.component.d.ts +27 -27
- package/lib/date-tags/date-tag.module.d.ts +4 -4
- package/lib/date-tags/day-tag/day-tag.component.d.ts +12 -12
- package/lib/date-tags/forecast-tag/forecast-tag.component.d.ts +21 -21
- package/lib/date-tags/month-tag/month-tag.component.d.ts +14 -14
- package/lib/date-tags/quarter-tag/quarter-tag.component.d.ts +17 -17
- package/lib/date-tags/week-tag/week-tag.component.d.ts +19 -19
- package/lib/date-tags/year-tag/year-tag.component.d.ts +14 -14
- package/lib/dr-accordion/accordion-item-body.component.d.ts +11 -11
- package/lib/dr-accordion/accordion-item-header.component.d.ts +16 -16
- package/lib/dr-accordion/accordion-item.component.d.ts +53 -53
- package/lib/dr-accordion/accordion.component.d.ts +19 -19
- package/lib/dr-accordion/accordion.module.d.ts +2 -2
- package/lib/dr-avatar/dr-avatar.component.d.ts +10 -10
- package/lib/dr-avatar/dr-avatar.module.d.ts +2 -2
- package/lib/dr-avatar/dr-avatar.pipe.d.ts +4 -4
- package/lib/dr-dropdown/dr-dropdown-item-show.pipe.d.ts +5 -5
- package/lib/dr-dropdown/dr-dropdown-position.directive.d.ts +12 -12
- package/lib/dr-dropdown/dr-dropdown.component.d.ts +26 -26
- package/lib/dr-dropdown/dr-dropdown.directive.d.ts +23 -23
- package/lib/dr-dropdown/dr-dropdown.module.d.ts +2 -2
- package/lib/dr-dropdown/dr-dropdown.service.d.ts +11 -11
- package/lib/dr-inputs/button/button.component.d.ts +21 -21
- package/lib/dr-inputs/checkbox/checkbox.component.d.ts +20 -20
- package/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.d.ts +10 -10
- package/lib/dr-inputs/dr-date-picker/dr-date-picker.component.d.ts +54 -54
- package/lib/dr-inputs/dr-date-picker/dr-date-picker.service.d.ts +12 -12
- package/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +41 -41
- package/lib/dr-inputs/dr-input/dr-input.component.d.ts +58 -58
- package/lib/dr-inputs/dr-inputs.module.d.ts +2 -2
- package/lib/dr-inputs/dr-model-debounce-change.directive.d.ts +11 -11
- package/lib/dr-inputs/dr-select/dr-select.component.d.ts +38 -38
- package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +23 -23
- package/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.d.ts +19 -19
- package/lib/dr-inputs/radio-button/radio-button.component.d.ts +21 -21
- package/lib/dr-inputs/radio-button/radio-group.component.d.ts +39 -39
- package/lib/dr-popover/dr-popover-ref.d.ts +16 -16
- package/lib/dr-popover/dr-popover.component.d.ts +26 -26
- package/lib/dr-popover/dr-popover.directive.d.ts +26 -26
- package/lib/dr-popover/dr-popover.module.d.ts +2 -2
- package/lib/dr-popover/dr-popover.service.d.ts +17 -17
- package/lib/dr-spinner/dr-spinner.component.d.ts +10 -10
- package/lib/dr-spinner/dr-spinner.directive.d.ts +15 -15
- package/lib/dr-spinner/dr-spinner.module.d.ts +2 -2
- package/lib/dr-tabs/dr-tab.component.d.ts +8 -8
- package/lib/dr-tabs/dr-tabs.component.d.ts +11 -11
- package/lib/dr-tabs/dr-tabs.module.d.ts +2 -2
- package/lib/dr-tags/dr-tag.component.d.ts +15 -15
- package/lib/dr-tags/dr-tag.module.d.ts +2 -2
- package/lib/dr-tooltip/dr-tooltip.component.d.ts +16 -16
- package/lib/dr-tooltip/dr-tooltip.directive.d.ts +23 -23
- package/lib/dr-tooltip/dr-tooltip.module.d.ts +2 -2
- package/lib/list-tags/list-tag.component.d.ts +14 -14
- package/lib/list-tags/list-tag.module.d.ts +2 -2
- package/lib/models/constants.d.ts +87 -87
- package/lib/models/datePicker.d.ts +25 -25
- package/lib/models/dropdown.d.ts +48 -48
- package/lib/models/popover.d.ts +32 -32
- package/lib/models/serverTags.d.ts +28 -28
- package/package.json +1 -1
- package/public-api.d.ts +55 -55
- package/datarailsshared-datarailsshared-1.3.49.tgz +0 -0
|
@@ -1,143 +1,143 @@
|
|
|
1
|
-
import { Component, Input } from "@angular/core";
|
|
2
|
-
import { AnyTagComponent } from "../date-tag.component";
|
|
3
|
-
// @ts-ignore
|
|
4
|
-
const moment = require("moment");
|
|
5
|
-
export class ForecastTagComponent extends AnyTagComponent {
|
|
6
|
-
constructor() {
|
|
7
|
-
super();
|
|
8
|
-
this.lockedDate = [];
|
|
9
|
-
this.forecastValue = undefined;
|
|
10
|
-
this.forecastTags = [
|
|
11
|
-
{ "value": 0, "label": "0+12" },
|
|
12
|
-
{ "value": 1, "label": "1+11" },
|
|
13
|
-
{ "value": 2, "label": "2+10" },
|
|
14
|
-
{ "value": 3, "label": "3+9" },
|
|
15
|
-
{ "value": 4, "label": "4+8" },
|
|
16
|
-
{ "value": 5, "label": "5+7" },
|
|
17
|
-
{ "value": 6, "label": "6+6" },
|
|
18
|
-
{ "value": 7, "label": "7+5" },
|
|
19
|
-
{ "value": 8, "label": "8+4" },
|
|
20
|
-
{ "value": 9, "label": "9+3" },
|
|
21
|
-
{ "value": 10, "label": "10+2" },
|
|
22
|
-
{ "value": 11, "label": "11+1" }
|
|
23
|
-
];
|
|
24
|
-
this.dateFilter = (date) => {
|
|
25
|
-
const forecastDate = moment.unix(date);
|
|
26
|
-
let status = true;
|
|
27
|
-
this.lockedDate.forEach(timestamp => {
|
|
28
|
-
const locked = moment.unix(timestamp);
|
|
29
|
-
return status = !(locked.month() === forecastDate.month() && locked.year() === forecastDate.year());
|
|
30
|
-
});
|
|
31
|
-
return status;
|
|
32
|
-
};
|
|
33
|
-
}
|
|
34
|
-
initDate() {
|
|
35
|
-
let dateVal = new Date();
|
|
36
|
-
if (this.defaultValue) {
|
|
37
|
-
dateVal = new Date(this.defaultValue * 1000);
|
|
38
|
-
}
|
|
39
|
-
let fiscal_year_starts_from = this.fiscalYearStartsFrom || 1;
|
|
40
|
-
let fiscal_year_back = this.fiscalYearBack || false;
|
|
41
|
-
this.forecastValue = this.getFiscalMonthFromDate(dateVal, fiscal_year_starts_from) - 1;
|
|
42
|
-
let fiscal_year = this.getFiscalYearFromDate(dateVal, fiscal_year_starts_from, fiscal_year_back);
|
|
43
|
-
console.log("test", dateVal, fiscal_year_starts_from, this.forecastValue, fiscal_year);
|
|
44
|
-
this.dateObj.date = moment(new Date(fiscal_year, 0, 1)).format("YYYY");
|
|
45
|
-
this.updateLockedDate();
|
|
46
|
-
}
|
|
47
|
-
updateLockedDate() {
|
|
48
|
-
for (let forecastTag of this.forecastTags) {
|
|
49
|
-
forecastTag.disable = false;
|
|
50
|
-
this.lockedDate.forEach(timestamp => {
|
|
51
|
-
const locked = moment.unix(timestamp);
|
|
52
|
-
if (locked.month() - 1 === forecastTag.value && +locked.year() + 1 === +this.dateObj.date) {
|
|
53
|
-
forecastTag.disable = true;
|
|
54
|
-
}
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
initName() {
|
|
59
|
-
if (!this.name) {
|
|
60
|
-
this.name = "Forecast";
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
getFiscalMonthFromDate(dateObj, fiscal_year_starts_from) {
|
|
64
|
-
let all_months = [];
|
|
65
|
-
for (let i = fiscal_year_starts_from; i < 13; i++) {
|
|
66
|
-
all_months.push(i);
|
|
67
|
-
}
|
|
68
|
-
for (let i = 1; i < fiscal_year_starts_from; i++) {
|
|
69
|
-
all_months.push(i);
|
|
70
|
-
}
|
|
71
|
-
return all_months.indexOf(dateObj.getMonth() + 1) + 1;
|
|
72
|
-
}
|
|
73
|
-
getFiscalYearFromDate(dateObj, fiscal_year_starts_from, fiscal_year_back) {
|
|
74
|
-
let fiscal_year = dateObj.getFullYear();
|
|
75
|
-
if (!fiscal_year_back) {
|
|
76
|
-
if (dateObj.getMonth() + 1 >= fiscal_year_starts_from && fiscal_year_starts_from !== 1) {
|
|
77
|
-
fiscal_year += 1;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
else {
|
|
81
|
-
if (dateObj.getMonth() + 1 < fiscal_year_starts_from && fiscal_year_starts_from !== 1) {
|
|
82
|
-
fiscal_year -= 1;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
return fiscal_year;
|
|
86
|
-
}
|
|
87
|
-
getForecastLabelFromValue(value, fiscal_year_starts_from, fiscal_year_back) {
|
|
88
|
-
let label = "";
|
|
89
|
-
if (value) {
|
|
90
|
-
let dateObj = new Date(value * 1000);
|
|
91
|
-
let fiscal_month = this.getFiscalMonthFromDate(dateObj, fiscal_year_starts_from);
|
|
92
|
-
let fiscal_year = this.getFiscalYearFromDate(dateObj, fiscal_year_starts_from, fiscal_year_back);
|
|
93
|
-
label = (fiscal_month - 1) + "+" + (13 - fiscal_month) + " (" + fiscal_year + ")";
|
|
94
|
-
}
|
|
95
|
-
return label;
|
|
96
|
-
}
|
|
97
|
-
changeTagInputHandler(event) {
|
|
98
|
-
this.chosenTagHandler();
|
|
99
|
-
}
|
|
100
|
-
changeYearInputHandler(event) {
|
|
101
|
-
this.updateLockedDate();
|
|
102
|
-
this.chosenTagHandler();
|
|
103
|
-
}
|
|
104
|
-
chosenTagHandler() {
|
|
105
|
-
let month = this.forecastValue;
|
|
106
|
-
let year = Number.parseInt(this.dateObj.date);
|
|
107
|
-
let timeStampVal = 0;
|
|
108
|
-
let label = "";
|
|
109
|
-
if (!Number.isNaN(month) && !Number.isNaN(year)) {
|
|
110
|
-
let date = new Date(year, month, 1, 12, 0, 0, 0);
|
|
111
|
-
let fiscal_year_starts_from = this.fiscalYearStartsFrom || 1;
|
|
112
|
-
let fiscal_year_back = this.fiscalYearBack || false;
|
|
113
|
-
if (fiscal_year_starts_from !== 1) {
|
|
114
|
-
if (!fiscal_year_back)
|
|
115
|
-
date.setMonth(date.getMonth() - 13 + fiscal_year_starts_from);
|
|
116
|
-
else
|
|
117
|
-
date.setMonth(date.getMonth() - 1 + fiscal_year_starts_from);
|
|
118
|
-
}
|
|
119
|
-
timeStampVal = date.getTime() / 1000;
|
|
120
|
-
label = this.getForecastLabelFromValue(timeStampVal, fiscal_year_starts_from, fiscal_year_back);
|
|
121
|
-
}
|
|
122
|
-
const resultTag = {
|
|
123
|
-
"name": this.name,
|
|
124
|
-
"value": timeStampVal,
|
|
125
|
-
"label": label,
|
|
126
|
-
"locked": !this.dateFilter(timeStampVal)
|
|
127
|
-
};
|
|
128
|
-
this.dateChange.emit(resultTag);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
ForecastTagComponent.decorators = [
|
|
132
|
-
{ type: Component, args: [{
|
|
133
|
-
template: "<div>\
|
|
134
|
-
selector: "forecast-tag"
|
|
135
|
-
},] }
|
|
136
|
-
];
|
|
137
|
-
ForecastTagComponent.ctorParameters = () => [];
|
|
138
|
-
ForecastTagComponent.propDecorators = {
|
|
139
|
-
fiscalYearStartsFrom: [{ type: Input }],
|
|
140
|
-
fiscalYearBack: [{ type: Input }],
|
|
141
|
-
lockedDate: [{ type: Input }]
|
|
142
|
-
};
|
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forecast-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/forecast-tag/forecast-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input} from \"@angular/core\";\r\nimport {Moment} from \"moment\";\r\nimport {IDateTag} from \"../../models/serverTags\";\r\nimport {AnyTagComponent} from \"../date-tag.component\";\r\nimport {MatSelectChange} from \"@angular/material/select\";\r\nimport {MatButtonToggleChange} from \"@angular/material/button-toggle\";\r\n// @ts-ignore\r\nconst moment = require(\"moment\");\r\n\r\n@Component({\r\n    templateUrl: \"forecast-tag.component.html\",\r\n    selector: \"forecast-tag\",\r\n})\r\n\r\nexport class ForecastTagComponent extends AnyTagComponent {\r\n  @Input() fiscalYearStartsFrom?: number;\r\n  @Input() fiscalYearBack?: boolean;\r\n  @Input() lockedDate: any[] = [];\r\n  forecastValue: number | undefined = undefined;\r\n\r\n  forecastTags: any[] = [\r\n    {\"value\": 0, \"label\": \"0+12\"},\r\n    {\"value\": 1, \"label\": \"1+11\"},\r\n    {\"value\": 2, \"label\": \"2+10\"},\r\n    {\"value\": 3, \"label\": \"3+9\"},\r\n    {\"value\": 4, \"label\": \"4+8\"},\r\n    {\"value\": 5, \"label\": \"5+7\"},\r\n    {\"value\": 6, \"label\": \"6+6\"},\r\n    {\"value\": 7, \"label\": \"7+5\"},\r\n    {\"value\": 8, \"label\": \"8+4\"},\r\n    {\"value\": 9, \"label\": \"9+3\"},\r\n    {\"value\": 10, \"label\": \"10+2\"},\r\n    {\"value\": 11, \"label\": \"11+1\"}\r\n  ];\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  initDate() {\r\n    let dateVal = new Date();\r\n    if (this.defaultValue) {\r\n      dateVal = new Date(this.defaultValue * 1000);\r\n    }\r\n    let fiscal_year_starts_from = this.fiscalYearStartsFrom || 1;\r\n    let fiscal_year_back = this.fiscalYearBack || false;\r\n    this.forecastValue = this.getFiscalMonthFromDate(dateVal, fiscal_year_starts_from) - 1;\r\n    let fiscal_year = this.getFiscalYearFromDate(dateVal, fiscal_year_starts_from, fiscal_year_back);\r\n\r\n    console.log(\"test\", dateVal, fiscal_year_starts_from, this.forecastValue, fiscal_year);\r\n\r\n    this.dateObj.date = moment(new Date(fiscal_year, 0, 1)).format(\"YYYY\");\r\n\r\n    this.updateLockedDate();\r\n  }\r\n\r\n  updateLockedDate() {\r\n    for (let forecastTag of this.forecastTags) {\r\n      forecastTag.disable = false;\r\n\r\n      this.lockedDate.forEach(timestamp => {\r\n        const locked = moment.unix(timestamp);\r\n\r\n        if (locked.month() - 1 === forecastTag.value && +locked.year() + 1 === +this.dateObj.date) {\r\n          forecastTag.disable = true;\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  initName() {\r\n    if (!this.name) {\r\n      this.name = \"Forecast\";\r\n    }\r\n  }\r\n\r\n  getFiscalMonthFromDate(dateObj, fiscal_year_starts_from) {\r\n    let all_months = [];\r\n\r\n    for (let i = fiscal_year_starts_from; i < 13; i++) {\r\n      all_months.push(i);\r\n    }\r\n\r\n    for (let i = 1; i < fiscal_year_starts_from; i++) {\r\n      all_months.push(i);\r\n    }\r\n\r\n    return all_months.indexOf(dateObj.getMonth() + 1) + 1;\r\n  }\r\n\r\n  getFiscalYearFromDate(dateObj, fiscal_year_starts_from, fiscal_year_back) {\r\n    let fiscal_year = dateObj.getFullYear();\r\n\r\n    if (!fiscal_year_back) {\r\n      if (dateObj.getMonth() + 1 >= fiscal_year_starts_from && fiscal_year_starts_from !== 1) {\r\n        fiscal_year += 1;\r\n      }\r\n    } else {\r\n      if (dateObj.getMonth() + 1 < fiscal_year_starts_from && fiscal_year_starts_from !== 1) {\r\n        fiscal_year -= 1;\r\n      }\r\n    }\r\n\r\n    return fiscal_year;\r\n  }\r\n\r\n  getForecastLabelFromValue(value, fiscal_year_starts_from, fiscal_year_back) {\r\n    let label = \"\";\r\n    if (value) {\r\n      let dateObj = new Date(value * 1000);\r\n\r\n      let fiscal_month = this.getFiscalMonthFromDate(dateObj, fiscal_year_starts_from);\r\n      let fiscal_year = this.getFiscalYearFromDate(dateObj, fiscal_year_starts_from, fiscal_year_back);\r\n\r\n      label = (fiscal_month - 1) + \"+\" + (13 - fiscal_month) + \" (\" + fiscal_year + \")\";\r\n    }\r\n    return label;\r\n  }\r\n\r\n  changeTagInputHandler(event: MatSelectChange | MatButtonToggleChange) {\r\n    this.chosenTagHandler();\r\n  }\r\n\r\n  changeYearInputHandler(event: Event) {\r\n    this.updateLockedDate();\r\n    this.chosenTagHandler();\r\n  }\r\n\r\n  chosenTagHandler() {\r\n    let month = this.forecastValue;\r\n    let year = Number.parseInt(this.dateObj.date);\r\n\r\n    let timeStampVal = 0;\r\n    let label = \"\";\r\n\r\n    if (!Number.isNaN(month) && !Number.isNaN(year)) {\r\n\r\n\r\n      let date = new Date(year, month, 1, 12, 0, 0, 0);\r\n      let fiscal_year_starts_from = this.fiscalYearStartsFrom || 1;\r\n      let fiscal_year_back = this.fiscalYearBack || false;\r\n      if (fiscal_year_starts_from !== 1) {\r\n        if (!fiscal_year_back)\r\n          date.setMonth(date.getMonth() - 13 + fiscal_year_starts_from);\r\n        else\r\n          date.setMonth(date.getMonth() - 1 + fiscal_year_starts_from);\r\n      }\r\n\r\n      timeStampVal = date.getTime() / 1000;\r\n      label = this.getForecastLabelFromValue(timeStampVal, fiscal_year_starts_from, fiscal_year_back);\r\n    }\r\n\r\n    const resultTag: IDateTag = {\r\n          \"name\": this.name,\r\n          \"value\": timeStampVal,\r\n          \"label\": label,\r\n          \"locked\": !this.dateFilter(timeStampVal)\r\n      };\r\n\r\n    this.dateChange.emit(resultTag);\r\n  }\r\n\r\n  dateFilter = (date) => {\r\n    const forecastDate = moment.unix(date);\r\n    let status = true;\r\n\r\n    this.lockedDate.forEach(timestamp => {\r\n      const locked = moment.unix(timestamp);\r\n\r\n      return status = !(locked.month() === forecastDate.month() && locked.year() === forecastDate.year());\r\n    });\r\n\r\n    return status;\r\n  }\r\n}\r\n"]}
|
|
1
|
+
import { Component, Input } from "@angular/core";
|
|
2
|
+
import { AnyTagComponent } from "../date-tag.component";
|
|
3
|
+
// @ts-ignore
|
|
4
|
+
const moment = require("moment");
|
|
5
|
+
export class ForecastTagComponent extends AnyTagComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
super();
|
|
8
|
+
this.lockedDate = [];
|
|
9
|
+
this.forecastValue = undefined;
|
|
10
|
+
this.forecastTags = [
|
|
11
|
+
{ "value": 0, "label": "0+12" },
|
|
12
|
+
{ "value": 1, "label": "1+11" },
|
|
13
|
+
{ "value": 2, "label": "2+10" },
|
|
14
|
+
{ "value": 3, "label": "3+9" },
|
|
15
|
+
{ "value": 4, "label": "4+8" },
|
|
16
|
+
{ "value": 5, "label": "5+7" },
|
|
17
|
+
{ "value": 6, "label": "6+6" },
|
|
18
|
+
{ "value": 7, "label": "7+5" },
|
|
19
|
+
{ "value": 8, "label": "8+4" },
|
|
20
|
+
{ "value": 9, "label": "9+3" },
|
|
21
|
+
{ "value": 10, "label": "10+2" },
|
|
22
|
+
{ "value": 11, "label": "11+1" }
|
|
23
|
+
];
|
|
24
|
+
this.dateFilter = (date) => {
|
|
25
|
+
const forecastDate = moment.unix(date);
|
|
26
|
+
let status = true;
|
|
27
|
+
this.lockedDate.forEach(timestamp => {
|
|
28
|
+
const locked = moment.unix(timestamp);
|
|
29
|
+
return status = !(locked.month() === forecastDate.month() && locked.year() === forecastDate.year());
|
|
30
|
+
});
|
|
31
|
+
return status;
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
initDate() {
|
|
35
|
+
let dateVal = new Date();
|
|
36
|
+
if (this.defaultValue) {
|
|
37
|
+
dateVal = new Date(this.defaultValue * 1000);
|
|
38
|
+
}
|
|
39
|
+
let fiscal_year_starts_from = this.fiscalYearStartsFrom || 1;
|
|
40
|
+
let fiscal_year_back = this.fiscalYearBack || false;
|
|
41
|
+
this.forecastValue = this.getFiscalMonthFromDate(dateVal, fiscal_year_starts_from) - 1;
|
|
42
|
+
let fiscal_year = this.getFiscalYearFromDate(dateVal, fiscal_year_starts_from, fiscal_year_back);
|
|
43
|
+
console.log("test", dateVal, fiscal_year_starts_from, this.forecastValue, fiscal_year);
|
|
44
|
+
this.dateObj.date = moment(new Date(fiscal_year, 0, 1)).format("YYYY");
|
|
45
|
+
this.updateLockedDate();
|
|
46
|
+
}
|
|
47
|
+
updateLockedDate() {
|
|
48
|
+
for (let forecastTag of this.forecastTags) {
|
|
49
|
+
forecastTag.disable = false;
|
|
50
|
+
this.lockedDate.forEach(timestamp => {
|
|
51
|
+
const locked = moment.unix(timestamp);
|
|
52
|
+
if (locked.month() - 1 === forecastTag.value && +locked.year() + 1 === +this.dateObj.date) {
|
|
53
|
+
forecastTag.disable = true;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
initName() {
|
|
59
|
+
if (!this.name) {
|
|
60
|
+
this.name = "Forecast";
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
getFiscalMonthFromDate(dateObj, fiscal_year_starts_from) {
|
|
64
|
+
let all_months = [];
|
|
65
|
+
for (let i = fiscal_year_starts_from; i < 13; i++) {
|
|
66
|
+
all_months.push(i);
|
|
67
|
+
}
|
|
68
|
+
for (let i = 1; i < fiscal_year_starts_from; i++) {
|
|
69
|
+
all_months.push(i);
|
|
70
|
+
}
|
|
71
|
+
return all_months.indexOf(dateObj.getMonth() + 1) + 1;
|
|
72
|
+
}
|
|
73
|
+
getFiscalYearFromDate(dateObj, fiscal_year_starts_from, fiscal_year_back) {
|
|
74
|
+
let fiscal_year = dateObj.getFullYear();
|
|
75
|
+
if (!fiscal_year_back) {
|
|
76
|
+
if (dateObj.getMonth() + 1 >= fiscal_year_starts_from && fiscal_year_starts_from !== 1) {
|
|
77
|
+
fiscal_year += 1;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
if (dateObj.getMonth() + 1 < fiscal_year_starts_from && fiscal_year_starts_from !== 1) {
|
|
82
|
+
fiscal_year -= 1;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return fiscal_year;
|
|
86
|
+
}
|
|
87
|
+
getForecastLabelFromValue(value, fiscal_year_starts_from, fiscal_year_back) {
|
|
88
|
+
let label = "";
|
|
89
|
+
if (value) {
|
|
90
|
+
let dateObj = new Date(value * 1000);
|
|
91
|
+
let fiscal_month = this.getFiscalMonthFromDate(dateObj, fiscal_year_starts_from);
|
|
92
|
+
let fiscal_year = this.getFiscalYearFromDate(dateObj, fiscal_year_starts_from, fiscal_year_back);
|
|
93
|
+
label = (fiscal_month - 1) + "+" + (13 - fiscal_month) + " (" + fiscal_year + ")";
|
|
94
|
+
}
|
|
95
|
+
return label;
|
|
96
|
+
}
|
|
97
|
+
changeTagInputHandler(event) {
|
|
98
|
+
this.chosenTagHandler();
|
|
99
|
+
}
|
|
100
|
+
changeYearInputHandler(event) {
|
|
101
|
+
this.updateLockedDate();
|
|
102
|
+
this.chosenTagHandler();
|
|
103
|
+
}
|
|
104
|
+
chosenTagHandler() {
|
|
105
|
+
let month = this.forecastValue;
|
|
106
|
+
let year = Number.parseInt(this.dateObj.date);
|
|
107
|
+
let timeStampVal = 0;
|
|
108
|
+
let label = "";
|
|
109
|
+
if (!Number.isNaN(month) && !Number.isNaN(year)) {
|
|
110
|
+
let date = new Date(year, month, 1, 12, 0, 0, 0);
|
|
111
|
+
let fiscal_year_starts_from = this.fiscalYearStartsFrom || 1;
|
|
112
|
+
let fiscal_year_back = this.fiscalYearBack || false;
|
|
113
|
+
if (fiscal_year_starts_from !== 1) {
|
|
114
|
+
if (!fiscal_year_back)
|
|
115
|
+
date.setMonth(date.getMonth() - 13 + fiscal_year_starts_from);
|
|
116
|
+
else
|
|
117
|
+
date.setMonth(date.getMonth() - 1 + fiscal_year_starts_from);
|
|
118
|
+
}
|
|
119
|
+
timeStampVal = date.getTime() / 1000;
|
|
120
|
+
label = this.getForecastLabelFromValue(timeStampVal, fiscal_year_starts_from, fiscal_year_back);
|
|
121
|
+
}
|
|
122
|
+
const resultTag = {
|
|
123
|
+
"name": this.name,
|
|
124
|
+
"value": timeStampVal,
|
|
125
|
+
"label": label,
|
|
126
|
+
"locked": !this.dateFilter(timeStampVal)
|
|
127
|
+
};
|
|
128
|
+
this.dateChange.emit(resultTag);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
ForecastTagComponent.decorators = [
|
|
132
|
+
{ type: Component, args: [{
|
|
133
|
+
template: "<div>\n <mat-form-field style=\"margin-right: 3px; margin-bottom:3px\">\n <mat-select placeholder=\"{{name}}\" (selectionChange)=\"changeTagInputHandler($event)\" [(value)]=\"forecastValue\">\n <mat-option *ngFor=\"let forecastTag of forecastTags\" [value]=\"forecastTag.value\" [disabled]=\"forecastTag.disable\">{{forecastTag.label}}</mat-option>\n </mat-select>\n </mat-form-field>\n <mat-form-field class=\"date-select-box\">\n <input matInput placeholder=\"Year\" type=\"number\" name=\"Year\"\n (change)=\"changeYearInputHandler($event)\"\n [(ngModel)]=\"dateObj.date\">\n </mat-form-field>\n</div>\n",
|
|
134
|
+
selector: "forecast-tag"
|
|
135
|
+
},] }
|
|
136
|
+
];
|
|
137
|
+
ForecastTagComponent.ctorParameters = () => [];
|
|
138
|
+
ForecastTagComponent.propDecorators = {
|
|
139
|
+
fiscalYearStartsFrom: [{ type: Input }],
|
|
140
|
+
fiscalYearBack: [{ type: Input }],
|
|
141
|
+
lockedDate: [{ type: Input }]
|
|
142
|
+
};
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forecast-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/forecast-tag/forecast-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input} from \"@angular/core\";\nimport {Moment} from \"moment\";\nimport {IDateTag} from \"../../models/serverTags\";\nimport {AnyTagComponent} from \"../date-tag.component\";\nimport {MatSelectChange} from \"@angular/material/select\";\nimport {MatButtonToggleChange} from \"@angular/material/button-toggle\";\n// @ts-ignore\nconst moment = require(\"moment\");\n\n@Component({\n    templateUrl: \"forecast-tag.component.html\",\n    selector: \"forecast-tag\",\n})\n\nexport class ForecastTagComponent extends AnyTagComponent {\n  @Input() fiscalYearStartsFrom?: number;\n  @Input() fiscalYearBack?: boolean;\n  @Input() lockedDate: any[] = [];\n  forecastValue: number | undefined = undefined;\n\n  forecastTags: any[] = [\n    {\"value\": 0, \"label\": \"0+12\"},\n    {\"value\": 1, \"label\": \"1+11\"},\n    {\"value\": 2, \"label\": \"2+10\"},\n    {\"value\": 3, \"label\": \"3+9\"},\n    {\"value\": 4, \"label\": \"4+8\"},\n    {\"value\": 5, \"label\": \"5+7\"},\n    {\"value\": 6, \"label\": \"6+6\"},\n    {\"value\": 7, \"label\": \"7+5\"},\n    {\"value\": 8, \"label\": \"8+4\"},\n    {\"value\": 9, \"label\": \"9+3\"},\n    {\"value\": 10, \"label\": \"10+2\"},\n    {\"value\": 11, \"label\": \"11+1\"}\n  ];\n\n  constructor() {\n    super();\n  }\n\n  initDate() {\n    let dateVal = new Date();\n    if (this.defaultValue) {\n      dateVal = new Date(this.defaultValue * 1000);\n    }\n    let fiscal_year_starts_from = this.fiscalYearStartsFrom || 1;\n    let fiscal_year_back = this.fiscalYearBack || false;\n    this.forecastValue = this.getFiscalMonthFromDate(dateVal, fiscal_year_starts_from) - 1;\n    let fiscal_year = this.getFiscalYearFromDate(dateVal, fiscal_year_starts_from, fiscal_year_back);\n\n    console.log(\"test\", dateVal, fiscal_year_starts_from, this.forecastValue, fiscal_year);\n\n    this.dateObj.date = moment(new Date(fiscal_year, 0, 1)).format(\"YYYY\");\n\n    this.updateLockedDate();\n  }\n\n  updateLockedDate() {\n    for (let forecastTag of this.forecastTags) {\n      forecastTag.disable = false;\n\n      this.lockedDate.forEach(timestamp => {\n        const locked = moment.unix(timestamp);\n\n        if (locked.month() - 1 === forecastTag.value && +locked.year() + 1 === +this.dateObj.date) {\n          forecastTag.disable = true;\n        }\n      });\n    }\n  }\n\n  initName() {\n    if (!this.name) {\n      this.name = \"Forecast\";\n    }\n  }\n\n  getFiscalMonthFromDate(dateObj, fiscal_year_starts_from) {\n    let all_months = [];\n\n    for (let i = fiscal_year_starts_from; i < 13; i++) {\n      all_months.push(i);\n    }\n\n    for (let i = 1; i < fiscal_year_starts_from; i++) {\n      all_months.push(i);\n    }\n\n    return all_months.indexOf(dateObj.getMonth() + 1) + 1;\n  }\n\n  getFiscalYearFromDate(dateObj, fiscal_year_starts_from, fiscal_year_back) {\n    let fiscal_year = dateObj.getFullYear();\n\n    if (!fiscal_year_back) {\n      if (dateObj.getMonth() + 1 >= fiscal_year_starts_from && fiscal_year_starts_from !== 1) {\n        fiscal_year += 1;\n      }\n    } else {\n      if (dateObj.getMonth() + 1 < fiscal_year_starts_from && fiscal_year_starts_from !== 1) {\n        fiscal_year -= 1;\n      }\n    }\n\n    return fiscal_year;\n  }\n\n  getForecastLabelFromValue(value, fiscal_year_starts_from, fiscal_year_back) {\n    let label = \"\";\n    if (value) {\n      let dateObj = new Date(value * 1000);\n\n      let fiscal_month = this.getFiscalMonthFromDate(dateObj, fiscal_year_starts_from);\n      let fiscal_year = this.getFiscalYearFromDate(dateObj, fiscal_year_starts_from, fiscal_year_back);\n\n      label = (fiscal_month - 1) + \"+\" + (13 - fiscal_month) + \" (\" + fiscal_year + \")\";\n    }\n    return label;\n  }\n\n  changeTagInputHandler(event: MatSelectChange | MatButtonToggleChange) {\n    this.chosenTagHandler();\n  }\n\n  changeYearInputHandler(event: Event) {\n    this.updateLockedDate();\n    this.chosenTagHandler();\n  }\n\n  chosenTagHandler() {\n    let month = this.forecastValue;\n    let year = Number.parseInt(this.dateObj.date);\n\n    let timeStampVal = 0;\n    let label = \"\";\n\n    if (!Number.isNaN(month) && !Number.isNaN(year)) {\n\n\n      let date = new Date(year, month, 1, 12, 0, 0, 0);\n      let fiscal_year_starts_from = this.fiscalYearStartsFrom || 1;\n      let fiscal_year_back = this.fiscalYearBack || false;\n      if (fiscal_year_starts_from !== 1) {\n        if (!fiscal_year_back)\n          date.setMonth(date.getMonth() - 13 + fiscal_year_starts_from);\n        else\n          date.setMonth(date.getMonth() - 1 + fiscal_year_starts_from);\n      }\n\n      timeStampVal = date.getTime() / 1000;\n      label = this.getForecastLabelFromValue(timeStampVal, fiscal_year_starts_from, fiscal_year_back);\n    }\n\n    const resultTag: IDateTag = {\n          \"name\": this.name,\n          \"value\": timeStampVal,\n          \"label\": label,\n          \"locked\": !this.dateFilter(timeStampVal)\n      };\n\n    this.dateChange.emit(resultTag);\n  }\n\n  dateFilter = (date) => {\n    const forecastDate = moment.unix(date);\n    let status = true;\n\n    this.lockedDate.forEach(timestamp => {\n      const locked = moment.unix(timestamp);\n\n      return status = !(locked.month() === forecastDate.month() && locked.year() === forecastDate.year());\n    });\n\n    return status;\n  }\n}\n"]}
|
|
@@ -1,87 +1,87 @@
|
|
|
1
|
-
import { Component, Input } from "@angular/core";
|
|
2
|
-
import { AnyTagComponent } from "../date-tag.component";
|
|
3
|
-
import { FormControl } from "@angular/forms";
|
|
4
|
-
import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from "@angular/material/core";
|
|
5
|
-
import { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from "@angular/material-moment-adapter";
|
|
6
|
-
// @ts-ignore
|
|
7
|
-
const moment = require("moment");
|
|
8
|
-
const MONTH_FORMATS = {
|
|
9
|
-
parse: {
|
|
10
|
-
dateInput: "DD-MM-YYYY",
|
|
11
|
-
},
|
|
12
|
-
display: {
|
|
13
|
-
dateInput: "MMMM YYYY",
|
|
14
|
-
monthYearLabel: "MMMM YYYY",
|
|
15
|
-
dateA11yLabel: "LL",
|
|
16
|
-
monthYearA11yLabel: "MMMM YYYY"
|
|
17
|
-
},
|
|
18
|
-
};
|
|
19
|
-
const ɵ0 = MONTH_FORMATS;
|
|
20
|
-
export class MonthTagComponent extends AnyTagComponent {
|
|
21
|
-
constructor() {
|
|
22
|
-
super();
|
|
23
|
-
this.lockedDate = [];
|
|
24
|
-
this.date = new FormControl(moment());
|
|
25
|
-
this.dateFilter = (date) => {
|
|
26
|
-
const calendarDate = moment(date);
|
|
27
|
-
let status = true;
|
|
28
|
-
this.lockedDate.forEach(timestamp => {
|
|
29
|
-
const lockDate = moment.unix(timestamp);
|
|
30
|
-
return status = !(lockDate.year() === calendarDate.year() && lockDate.month() === calendarDate.month());
|
|
31
|
-
});
|
|
32
|
-
return status;
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
initDate() {
|
|
36
|
-
if (this.defaultValue) {
|
|
37
|
-
this.dateObj.date = moment(this.defaultValue * 1000).utc().format("YYYY-MM");
|
|
38
|
-
this.date = new FormControl(moment(this.defaultValue * 1000));
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
this.dateObj.date = moment(new Date()).format("YYYY-MM");
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
initName() {
|
|
45
|
-
if (!this.name) {
|
|
46
|
-
this.name = "Month and Year";
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
chosenTagHandler(value) {
|
|
50
|
-
const resultDate = moment.utc(value);
|
|
51
|
-
resultDate.hour(12);
|
|
52
|
-
const resultTag = {
|
|
53
|
-
name: this.name,
|
|
54
|
-
value: parseInt(resultDate.format("X"), 10),
|
|
55
|
-
label: resultDate.format("MMMM YYYY"),
|
|
56
|
-
locked: !this.dateFilter(value)
|
|
57
|
-
};
|
|
58
|
-
console.log(resultTag, value);
|
|
59
|
-
this.dateChange.emit(resultTag);
|
|
60
|
-
}
|
|
61
|
-
chosenMonthHandler(normalizedMonth, datepicker) {
|
|
62
|
-
this.date.setValue(normalizedMonth);
|
|
63
|
-
this.dateObj.date = this.date.value;
|
|
64
|
-
this.chosenTagHandler(this.date.value);
|
|
65
|
-
datepicker.close();
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
MonthTagComponent.decorators = [
|
|
69
|
-
{ type: Component, args: [{
|
|
70
|
-
template: "<div>\
|
|
71
|
-
selector: "month-tag",
|
|
72
|
-
providers: [
|
|
73
|
-
{
|
|
74
|
-
provide: DateAdapter,
|
|
75
|
-
useClass: MomentDateAdapter,
|
|
76
|
-
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
77
|
-
},
|
|
78
|
-
{ provide: MAT_DATE_FORMATS, useValue: ɵ0 },
|
|
79
|
-
]
|
|
80
|
-
},] }
|
|
81
|
-
];
|
|
82
|
-
MonthTagComponent.ctorParameters = () => [];
|
|
83
|
-
MonthTagComponent.propDecorators = {
|
|
84
|
-
lockedDate: [{ type: Input }]
|
|
85
|
-
};
|
|
86
|
-
export { ɵ0 };
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Component, Input } from "@angular/core";
|
|
2
|
+
import { AnyTagComponent } from "../date-tag.component";
|
|
3
|
+
import { FormControl } from "@angular/forms";
|
|
4
|
+
import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from "@angular/material/core";
|
|
5
|
+
import { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from "@angular/material-moment-adapter";
|
|
6
|
+
// @ts-ignore
|
|
7
|
+
const moment = require("moment");
|
|
8
|
+
const MONTH_FORMATS = {
|
|
9
|
+
parse: {
|
|
10
|
+
dateInput: "DD-MM-YYYY",
|
|
11
|
+
},
|
|
12
|
+
display: {
|
|
13
|
+
dateInput: "MMMM YYYY",
|
|
14
|
+
monthYearLabel: "MMMM YYYY",
|
|
15
|
+
dateA11yLabel: "LL",
|
|
16
|
+
monthYearA11yLabel: "MMMM YYYY"
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
const ɵ0 = MONTH_FORMATS;
|
|
20
|
+
export class MonthTagComponent extends AnyTagComponent {
|
|
21
|
+
constructor() {
|
|
22
|
+
super();
|
|
23
|
+
this.lockedDate = [];
|
|
24
|
+
this.date = new FormControl(moment());
|
|
25
|
+
this.dateFilter = (date) => {
|
|
26
|
+
const calendarDate = moment(date);
|
|
27
|
+
let status = true;
|
|
28
|
+
this.lockedDate.forEach(timestamp => {
|
|
29
|
+
const lockDate = moment.unix(timestamp);
|
|
30
|
+
return status = !(lockDate.year() === calendarDate.year() && lockDate.month() === calendarDate.month());
|
|
31
|
+
});
|
|
32
|
+
return status;
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
initDate() {
|
|
36
|
+
if (this.defaultValue) {
|
|
37
|
+
this.dateObj.date = moment(this.defaultValue * 1000).utc().format("YYYY-MM");
|
|
38
|
+
this.date = new FormControl(moment(this.defaultValue * 1000));
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
this.dateObj.date = moment(new Date()).format("YYYY-MM");
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
initName() {
|
|
45
|
+
if (!this.name) {
|
|
46
|
+
this.name = "Month and Year";
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
chosenTagHandler(value) {
|
|
50
|
+
const resultDate = moment.utc(value);
|
|
51
|
+
resultDate.hour(12);
|
|
52
|
+
const resultTag = {
|
|
53
|
+
name: this.name,
|
|
54
|
+
value: parseInt(resultDate.format("X"), 10),
|
|
55
|
+
label: resultDate.format("MMMM YYYY"),
|
|
56
|
+
locked: !this.dateFilter(value)
|
|
57
|
+
};
|
|
58
|
+
console.log(resultTag, value);
|
|
59
|
+
this.dateChange.emit(resultTag);
|
|
60
|
+
}
|
|
61
|
+
chosenMonthHandler(normalizedMonth, datepicker) {
|
|
62
|
+
this.date.setValue(normalizedMonth);
|
|
63
|
+
this.dateObj.date = this.date.value;
|
|
64
|
+
this.chosenTagHandler(this.date.value);
|
|
65
|
+
datepicker.close();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
MonthTagComponent.decorators = [
|
|
69
|
+
{ type: Component, args: [{
|
|
70
|
+
template: "<div>\n <mat-form-field class=\"date-select-box\">\n <input\n matInput\n placeholder=\"{{name}}\"\n name=\"Month\"\n [formControl]=\"date\"\n [matDatepickerFilter]=\"dateFilter\"\n [matDatepicker]=\"datepicker\">\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\n <mat-datepicker\n #datepicker\n startView=\"year\"\n (monthSelected)=\"chosenMonthHandler($event, datepicker)\"\n ></mat-datepicker>\n </mat-form-field>\n</div>\n",
|
|
71
|
+
selector: "month-tag",
|
|
72
|
+
providers: [
|
|
73
|
+
{
|
|
74
|
+
provide: DateAdapter,
|
|
75
|
+
useClass: MomentDateAdapter,
|
|
76
|
+
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
77
|
+
},
|
|
78
|
+
{ provide: MAT_DATE_FORMATS, useValue: ɵ0 },
|
|
79
|
+
]
|
|
80
|
+
},] }
|
|
81
|
+
];
|
|
82
|
+
MonthTagComponent.ctorParameters = () => [];
|
|
83
|
+
MonthTagComponent.propDecorators = {
|
|
84
|
+
lockedDate: [{ type: Input }]
|
|
85
|
+
};
|
|
86
|
+
export { ɵ0 };
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9udGgtdGFnLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RhdGUtdGFncy9tb250aC10YWcvbW9udGgtdGFnLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLFNBQVMsRUFBZ0IsS0FBSyxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUdoRyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFFdEQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBQyxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDdEYsT0FBTyxFQUFDLCtCQUErQixFQUFFLGlCQUFpQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDcEcsYUFBYTtBQUNiLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUVqQyxNQUFNLGFBQWEsR0FBRztJQUNwQixLQUFLLEVBQUU7UUFDTCxTQUFTLEVBQUUsWUFBWTtLQUN4QjtJQUNELE9BQU8sRUFBRTtRQUNQLFNBQVMsRUFBRSxXQUFXO1FBQ3RCLGNBQWMsRUFBRSxXQUFXO1FBQzNCLGFBQWEsRUFBRSxJQUFJO1FBQ25CLGtCQUFrQixFQUFFLFdBQVc7S0FDaEM7Q0FDRixDQUFDO1dBVzBDLGFBQWE7QUFJekQsTUFBTSxPQUFPLGlCQUFrQixTQUFRLGVBQWU7SUFLbEQ7UUFDSSxLQUFLLEVBQUUsQ0FBQztRQUxILGVBQVUsR0FBVSxFQUFFLENBQUM7UUFFaEMsU0FBSSxHQUFHLElBQUksV0FBVyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7UUEyQ2pDLGVBQVUsR0FBRyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ3BCLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FB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b3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0fSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHtNb21lbnR9IGZyb20gXCJtb21lbnRcIjtcbmltcG9ydCB7SURhdGVUYWd9IGZyb20gXCIuLi8uLi9tb2RlbHMvc2VydmVyVGFnc1wiO1xuaW1wb3J0IHtBbnlUYWdDb21wb25lbnR9IGZyb20gXCIuLi9kYXRlLXRhZy5jb21wb25lbnRcIjtcbmltcG9ydCB7TWF0RGF0ZXBpY2tlcn0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXJcIjtcbmltcG9ydCB7Rm9ybUNvbnRyb2x9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuaW1wb3J0IHtEYXRlQWRhcHRlciwgTUFUX0RBVEVfRk9STUFUUywgTUFUX0RBVEVfTE9DQUxFfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZVwiO1xuaW1wb3J0IHtNQVRfTU9NRU5UX0RBVEVfQURBUFRFUl9PUFRJT05TLCBNb21lbnREYXRlQWRhcHRlcn0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsLW1vbWVudC1hZGFwdGVyXCI7XG4vLyBAdHMtaWdub3JlXG5jb25zdCBtb21lbnQgPSByZXF1aXJlKFwibW9tZW50XCIpO1xuXG5jb25zdCBNT05USF9GT1JNQVRTID0ge1xuICBwYXJzZToge1xuICAgIGRhdGVJbnB1dDogXCJERC1NTS1ZWVlZXCIsXG4gIH0sXG4gIGRpc3BsYXk6IHtcbiAgICBkYXRlSW5wdXQ6IFwiTU1NTSBZWVlZXCIsXG4gICAgbW9udGhZZWFyTGFiZWw6IFwiTU1NTSBZWVlZXCIsXG4gICAgZGF0ZUExMXlMYWJlbDogXCJMTFwiLFxuICAgIG1vbnRoWWVhckExMXlMYWJlbDogXCJNTU1NIFlZWVlcIlxuICB9LFxufTtcblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6IFwibW9udGgtdGFnLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc2VsZWN0b3I6IFwibW9udGgtdGFnXCIsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICB7XG4gICAgICAgIHByb3ZpZGU6IERhdGVBZGFwdGVyLFxuICAgICAgICB1c2VDbGFzczogTW9tZW50RGF0ZUFkYXB0ZXIsXG4gICAgICAgIGRlcHM6IFtNQVRfREFURV9MT0NBTEUsIE1BVF9NT01FTlRfREFURV9BREFQVEVSX09QVElPTlNdLFxuICAgICAgfSxcbiAgICAgIHtwcm92aWRlOiBNQVRfREFURV9GT1JNQVRTLCB1c2VWYWx1ZTogTU9OVEhfRk9STUFUU30sXG4gICAgXSxcbn0pXG5cbmV4cG9ydCBjbGFzcyBNb250aFRhZ0NvbXBvbmVudCBleHRlbmRzIEFueVRhZ0NvbXBvbmVudCB7XG4gICAgQElucHV0KCkgbG9ja2VkRGF0ZTogYW55W10gPSBbXTtcblxuICAgIGRhdGUgPSBuZXcgRm9ybUNvbnRyb2wobW9tZW50KCkpO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgaW5pdERhdGUoKSB7XG4gICAgICBpZiAodGhpcy5kZWZhdWx0VmFsdWUpIHtcbiAgICAgICAgdGhpcy5kYXRlT2JqLmRhdGUgPSBtb21lbnQodGhpcy5kZWZhdWx0VmFsdWUgKiAxMDAwKS51dGMoKS5mb3JtYXQoXCJZWVlZLU1NXCIpO1xuICAgICAgICB0aGlzLmRhdGUgPSBuZXcgRm9ybUNvbnRyb2wobW9tZW50KHRoaXMuZGVmYXVsdFZhbHVlICogMTAwMCkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5kYXRlT2JqLmRhdGUgPSBtb21lbnQobmV3IERhdGUoKSkuZm9ybWF0KFwiWVlZWS1NTVwiKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpbml0TmFtZSgpIHtcbiAgICAgIGlmICghdGhpcy5uYW1lKSB7XG4gICAgICAgIHRoaXMubmFtZSA9IFwiTW9udGggYW5kIFllYXJcIjtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjaG9zZW5UYWdIYW5kbGVyKHZhbHVlKSB7XG4gICAgICAgIGNvbnN0IHJlc3VsdERhdGU6IE1vbWVudCA9IG1vbWVudC51dGModmFsdWUpO1xuICAgICAgICByZXN1bHREYXRlLmhvdXIoMTIpO1xuICAgICAgICBjb25zdCByZXN1bHRUYWc6IElEYXRlVGFnID0ge1xuICAgICAgICAgICAgbmFtZTogdGhpcy5uYW1lLFxuICAgICAgICAgICAgdmFsdWU6IHBhcnNlSW50KHJlc3VsdERhdGUuZm9ybWF0KFwiWFwiKSwgMTApLFxuICAgICAgICAgICAgbGFiZWw6IHJlc3VsdERhdGUuZm9ybWF0KFwiTU1NTSBZWVlZXCIpLFxuICAgICAgICAgICAgbG9ja2VkOiAhdGhpcy5kYXRlRmlsdGVyKHZhbHVlKVxuICAgICAgICB9O1xuICAgICAgICBjb25zb2xlLmxvZyhyZXN1bHRUYWcsIHZhbHVlKTtcbiAgICAgICAgdGhpcy5kYXRlQ2hhbmdlLmVtaXQocmVzdWx0VGFnKTtcbiAgICB9XG5cbiAgICBjaG9zZW5Nb250aEhhbmRsZXIobm9ybWFsaXplZE1vbnRoOiBNb21lbnQsIGRhdGVwaWNrZXI6IE1hdERhdGVwaWNrZXI8TW9tZW50Pikge1xuICAgICAgICB0aGlzLmRhdGUuc2V0VmFsdWUobm9ybWFsaXplZE1vbnRoKTtcbiAgICAgICAgdGhpcy5kYXRlT2JqLmRhdGUgPSB0aGlzLmRhdGUudmFsdWU7XG5cbiAgICAgICAgdGhpcy5jaG9zZW5UYWdIYW5kbGVyKHRoaXMuZGF0ZS52YWx1ZSk7XG5cbiAgICAgICAgZGF0ZXBpY2tlci5jbG9zZSgpO1xuICAgIH1cblxuICAgIGRhdGVGaWx0ZXIgPSAoZGF0ZSkgPT4ge1xuICAgICAgY29uc3QgY2FsZW5kYXJEYXRlID0gbW9tZW50KGRhdGUpO1xuICAgICAgbGV0IHN0YXR1cyA9IHRydWU7XG5cbiAgICAgIHRoaXMubG9ja2VkRGF0ZS5mb3JFYWNoKHRpbWVzdGFtcCA9PiB7XG4gICAgICAgIGNvbnN0IGxvY2tEYXRlID0gbW9tZW50LnVuaXgodGltZXN0YW1wKTtcblxuICAgICAgICByZXR1cm4gc3RhdHVzID0gIShsb2NrRGF0ZS55ZWFyKCkgPT09IGNhbGVuZGFyRGF0ZS55ZWFyKCkgJiYgbG9ja0RhdGUubW9udGgoKSA9PT0gY2FsZW5kYXJEYXRlLm1vbnRoKCkpO1xuICAgICAgfSk7XG5cbiAgICAgIHJldHVybiBzdGF0dXM7XG4gICAgfVxufVxuIl19
|