@datarailsshared/datarailsshared 1.2.3 → 1.3.2
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/bundles/datarailsshared-datarailsshared.umd.js +1591 -0
- package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -0
- package/datarailsshared-datarailsshared-1.3.2.tgz +0 -0
- package/datarailsshared-datarailsshared.d.ts +5 -0
- package/datarailsshared-datarailsshared.metadata.json +1 -0
- package/esm2015/datarailsshared-datarailsshared.js +6 -0
- package/esm2015/lib/date-tags/date-tag.component.js +70 -0
- package/esm2015/lib/date-tags/date-tag.module.js +50 -0
- package/esm2015/lib/date-tags/day-tag/day-tag.component.js +79 -0
- package/esm2015/lib/date-tags/forecast-tag/forecast-tag.component.js +143 -0
- package/esm2015/lib/date-tags/month-tag/month-tag.component.js +86 -0
- package/esm2015/lib/date-tags/quarter-tag/quarter-tag.component.js +101 -0
- package/esm2015/lib/date-tags/week-tag/week-tag.component.js +124 -0
- package/esm2015/lib/date-tags/year-tag/year-tag.component.js +92 -0
- package/esm2015/lib/dr-inputs/checkbox/checkbox.component.js +46 -0
- package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +147 -0
- package/esm2015/lib/dr-inputs/dr-inputs.module.js +24 -0
- package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +51 -0
- package/esm2015/lib/dr-inputs/radio-button/radio-button.component.js +50 -0
- package/esm2015/lib/dr-tags/dr-tag.component.js +54 -0
- package/esm2015/lib/dr-tags/dr-tag.module.js +22 -0
- package/esm2015/lib/list-tags/list-tag.component.js +41 -0
- package/esm2015/lib/list-tags/list-tag.module.js +29 -0
- package/esm2015/lib/models/serverTags.js +2 -0
- package/esm2015/public-api.js +21 -0
- package/fesm2015/datarailsshared-datarailsshared.js +1152 -0
- package/fesm2015/datarailsshared-datarailsshared.js.map +1 -0
- package/{DateTags/dateTag.component.d.ts → lib/date-tags/date-tag.component.d.ts} +27 -27
- package/lib/date-tags/date-tag.module.d.ts +4 -0
- package/{DateTags/dayTag/dayTag.component.d.ts → lib/date-tags/day-tag/day-tag.component.d.ts} +12 -12
- package/{DateTags/forecastTag/forecastTag.component.d.ts → lib/date-tags/forecast-tag/forecast-tag.component.d.ts} +21 -21
- package/{DateTags/monthTag/monthTag.component.d.ts → lib/date-tags/month-tag/month-tag.component.d.ts} +14 -14
- package/{DateTags/quarterTag/quarterTag.component.d.ts → lib/date-tags/quarter-tag/quarter-tag.component.d.ts} +17 -17
- package/{DateTags/weekTag/weekTag.component.d.ts → lib/date-tags/week-tag/week-tag.component.d.ts} +19 -19
- package/{DateTags/yearTag/yearTag.component.d.ts → lib/date-tags/year-tag/year-tag.component.d.ts} +14 -14
- package/lib/dr-inputs/checkbox/checkbox.component.d.ts +14 -0
- package/lib/dr-inputs/dr-input/dr-input.component.d.ts +44 -0
- package/lib/dr-inputs/dr-inputs.module.d.ts +2 -0
- package/lib/dr-inputs/dr-select/dr-select.component.d.ts +27 -0
- package/lib/dr-inputs/radio-button/radio-button.component.d.ts +15 -0
- package/{DrTags/drTag.component.d.ts → lib/dr-tags/dr-tag.component.d.ts} +15 -15
- package/{DrTags/drTag.module.d.ts → lib/dr-tags/dr-tag.module.d.ts} +2 -2
- package/{ListTags/listTag.component.d.ts → lib/list-tags/list-tag.component.d.ts} +14 -14
- package/{ListTags/listTag.module.d.ts → lib/list-tags/list-tag.module.d.ts} +2 -2
- package/{models → lib/models}/serverTags.d.ts +28 -28
- package/package.json +11 -11
- package/public-api.d.ts +18 -0
- package/DateTags/dateTag.module.d.ts +0 -2
- package/bundles/ng-datarails.umd.js +0 -1206
- package/bundles/ng-datarails.umd.js.map +0 -1
- package/datarailsshared-datarailsshared-1.2.3.tgz +0 -0
- package/esm2015/DateTags/dateTag.component.js +0 -69
- package/esm2015/DateTags/dateTag.module.js +0 -54
- package/esm2015/DateTags/dayTag/dayTag.component.js +0 -79
- package/esm2015/DateTags/forecastTag/forecastTag.component.js +0 -143
- package/esm2015/DateTags/monthTag/monthTag.component.js +0 -86
- package/esm2015/DateTags/quarterTag/quarterTag.component.js +0 -101
- package/esm2015/DateTags/weekTag/weekTag.component.js +0 -124
- package/esm2015/DateTags/yearTag/yearTag.component.js +0 -92
- package/esm2015/DrTags/drTag.component.js +0 -54
- package/esm2015/DrTags/drTag.module.js +0 -26
- package/esm2015/ListTags/listTag.component.js +0 -41
- package/esm2015/ListTags/listTag.module.js +0 -33
- package/esm2015/index.js +0 -5
- package/esm2015/models/serverTags.js +0 -2
- package/esm2015/ng-datarails.js +0 -14
- package/fesm2015/ng-datarails.js +0 -854
- package/fesm2015/ng-datarails.js.map +0 -1
- package/index.d.ts +0 -4
- package/ng-datarails.d.ts +0 -13
- package/ng-datarails.metadata.json +0 -1
|
@@ -0,0 +1,86 @@
|
|
|
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(new Date(this.defaultValue * 1000)).utc().format("YYYY-MM");
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
this.dateObj.date = moment(new Date()).format("YYYY-MM");
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
initName() {
|
|
44
|
+
if (!this.name) {
|
|
45
|
+
this.name = "Month and Year";
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
chosenTagHandler(value) {
|
|
49
|
+
const resultDate = moment.utc(value);
|
|
50
|
+
resultDate.hour(12);
|
|
51
|
+
const resultTag = {
|
|
52
|
+
name: this.name,
|
|
53
|
+
value: parseInt(resultDate.format("X"), 10),
|
|
54
|
+
label: resultDate.format("MMMM YYYY"),
|
|
55
|
+
locked: !this.dateFilter(value)
|
|
56
|
+
};
|
|
57
|
+
console.log(resultTag, value);
|
|
58
|
+
this.dateChange.emit(resultTag);
|
|
59
|
+
}
|
|
60
|
+
chosenMonthHandler(normalizedMonth, datepicker) {
|
|
61
|
+
this.date.setValue(normalizedMonth);
|
|
62
|
+
this.dateObj.date = this.date.value;
|
|
63
|
+
this.chosenTagHandler(this.date.value);
|
|
64
|
+
datepicker.close();
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
MonthTagComponent.decorators = [
|
|
68
|
+
{ type: Component, args: [{
|
|
69
|
+
template: "<div>\r\n <mat-form-field class=\"date-select-box\">\r\n <input\r\n matInput\r\n placeholder=\"{{name}}\"\r\n name=\"Month\"\r\n [formControl]=\"date\"\r\n [matDatepickerFilter]=\"dateFilter\"\r\n [matDatepicker]=\"datepicker\">\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker\r\n #datepicker\r\n startView=\"year\"\r\n (monthSelected)=\"chosenMonthHandler($event, datepicker)\"\r\n ></mat-datepicker>\r\n </mat-form-field>\r\n</div>\r\n",
|
|
70
|
+
selector: "month-tag",
|
|
71
|
+
providers: [
|
|
72
|
+
{
|
|
73
|
+
provide: DateAdapter,
|
|
74
|
+
useClass: MomentDateAdapter,
|
|
75
|
+
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
76
|
+
},
|
|
77
|
+
{ provide: MAT_DATE_FORMATS, useValue: ɵ0 },
|
|
78
|
+
]
|
|
79
|
+
},] }
|
|
80
|
+
];
|
|
81
|
+
MonthTagComponent.ctorParameters = () => [];
|
|
82
|
+
MonthTagComponent.propDecorators = {
|
|
83
|
+
lockedDate: [{ type: Input }]
|
|
84
|
+
};
|
|
85
|
+
export { ɵ0 };
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9udGgtdGFnLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RhdGUtdGFncy9tb250aC10YWcvbW9udGgtdGFnLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLFNBQVMsRUFBZ0IsS0FBSyxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUdoRyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFFdEQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBQyxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDdEYsT0FBTyxFQUFDLCtCQUErQixFQUFFLGlCQUFpQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDcEcsYUFBYTtBQUNiLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUVqQyxNQUFNLGFBQWEsR0FBRztJQUNwQixLQUFLLEVBQUU7UUFDTCxTQUFTLEVBQUUsWUFBWTtLQUN4QjtJQUNELE9BQU8sRUFBRTtRQUNQLFNBQVMsRUFBRSxXQUFXO1FBQ3RCLGNBQWMsRUFBRSxXQUFXO1FBQzNCLGFBQWEsRUFBRSxJQUFJO1FBQ25CLGtCQUFrQixFQUFFLFdBQVc7S0FDaEM7Q0FDRixDQUFDO1dBVzBDLGFBQWE7QUFJekQsTUFBTSxPQUFPLGlCQUFrQixTQUFRLGVBQWU7SUFLbEQ7UUFDSSxLQUFLLEVBQUUsQ0FBQztRQUxILGVBQVUsR0FBVSxFQUFFLENBQUM7UUFFaEMsU0FBSSxHQUFHLElBQUksV0FBVyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7UUEwQ2pDLGVBQVUsR0FBRyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ3BCLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNsQyxJQUFJLE1BQU0sR0FBRyxJQUFJLENBQUM7WUFFbEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUU7Z0JBQ2xDLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7Z0JBRXhDLE9BQU8sTUFBTSxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLEtBQUssWUFBWSxDQUFDLElBQUksRUFBRSxJQUFJLFFBQVEsQ0FBQyxLQUFLLEVBQUUsS0FBSyxZQUFZLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUMxRyxDQUFDLENBQUMsQ0FBQztZQUVILE9BQU8sTUFBTSxDQUFDO1FBQ2hCLENBQUMsQ0FBQTtJQWpERCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUNyQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksR0FBRyxNQUFNLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztTQUN4RjthQUFNO1lBQ0wsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDMUQ7SUFDSCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ2QsSUFBSSxDQUFDLElBQUksR0FBRyxnQkFBZ0IsQ0FBQztTQUM5QjtJQUNILENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxLQUFLO1FBQ2xCLE1BQU0sVUFBVSxHQUFXLE1BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDN0MsVUFBVSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNwQixNQUFNLFNBQVMsR0FBYTtZQUN4QixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7WUFDZixLQUFLLEVBQUUsUUFBUSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQzNDLEtBQUssRUFBRSxVQUFVLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQztZQUNyQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQztTQUNsQyxDQUFDO1FBQ0YsT0FBTyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVELGtCQUFrQixDQUFDLGVBQXVCLEVBQUUsVUFBaUM7UUFDekUsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7UUFFcEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFdkMsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3ZCLENBQUM7OztZQXhESixTQUFTLFNBQUM7Z0JBQ1AsNm5CQUF1QztnQkFDdkMsUUFBUSxFQUFFLFdBQVc7Z0JBQ3JCLFNBQVMsRUFBRTtvQkFDVDt3QkFDRSxPQUFPLEVBQUUsV0FBVzt3QkFDcEIsUUFBUSxFQUFFLGlCQUFpQjt3QkFDM0IsSUFBSSxFQUFFLENBQUMsZUFBZSxFQUFFLCtCQUErQixDQUFDO3FCQUN6RDtvQkFDRCxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLElBQWUsRUFBQztpQkFDckQ7YUFDSjs7Ozt5QkFHSSxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtNb21lbnR9IGZyb20gXCJtb21lbnRcIjtcclxuaW1wb3J0IHtJRGF0ZVRhZ30gZnJvbSBcIi4uLy4uL21vZGVscy9zZXJ2ZXJUYWdzXCI7XHJcbmltcG9ydCB7QW55VGFnQ29tcG9uZW50fSBmcm9tIFwiLi4vZGF0ZS10YWcuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7TWF0RGF0ZXBpY2tlcn0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXJcIjtcclxuaW1wb3J0IHtGb3JtQ29udHJvbH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7RGF0ZUFkYXB0ZXIsIE1BVF9EQVRFX0ZPUk1BVFMsIE1BVF9EQVRFX0xPQ0FMRX0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2NvcmVcIjtcclxuaW1wb3J0IHtNQVRfTU9NRU5UX0RBVEVfQURBUFRFUl9PUFRJT05TLCBNb21lbnREYXRlQWRhcHRlcn0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsLW1vbWVudC1hZGFwdGVyXCI7XHJcbi8vIEB0cy1pZ25vcmVcclxuY29uc3QgbW9tZW50ID0gcmVxdWlyZShcIm1vbWVudFwiKTtcclxuXHJcbmNvbnN0IE1PTlRIX0ZPUk1BVFMgPSB7XHJcbiAgcGFyc2U6IHtcclxuICAgIGRhdGVJbnB1dDogXCJERC1NTS1ZWVlZXCIsXHJcbiAgfSxcclxuICBkaXNwbGF5OiB7XHJcbiAgICBkYXRlSW5wdXQ6IFwiTU1NTSBZWVlZXCIsXHJcbiAgICBtb250aFllYXJMYWJlbDogXCJNTU1NIFlZWVlcIixcclxuICAgIGRhdGVBMTF5TGFiZWw6IFwiTExcIixcclxuICAgIG1vbnRoWWVhckExMXlMYWJlbDogXCJNTU1NIFlZWVlcIlxyXG4gIH0sXHJcbn07XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHRlbXBsYXRlVXJsOiBcIm1vbnRoLXRhZy5jb21wb25lbnQuaHRtbFwiLFxyXG4gICAgc2VsZWN0b3I6IFwibW9udGgtdGFnXCIsXHJcbiAgICBwcm92aWRlcnM6IFtcclxuICAgICAge1xyXG4gICAgICAgIHByb3ZpZGU6IERhdGVBZGFwdGVyLFxyXG4gICAgICAgIHVzZUNsYXNzOiBNb21lbnREYXRlQWRhcHRlcixcclxuICAgICAgICBkZXBzOiBbTUFUX0RBVEVfTE9DQUxFLCBNQVRfTU9NRU5UX0RBVEVfQURBUFRFUl9PUFRJT05TXSxcclxuICAgICAgfSxcclxuICAgICAge3Byb3ZpZGU6IE1BVF9EQVRFX0ZPUk1BVFMsIHVzZVZhbHVlOiBNT05USF9GT1JNQVRTfSxcclxuICAgIF0sXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgTW9udGhUYWdDb21wb25lbnQgZXh0ZW5kcyBBbnlUYWdDb21wb25lbnQge1xyXG4gICAgQElucHV0KCkgbG9ja2VkRGF0ZTogYW55W10gPSBbXTtcclxuXHJcbiAgICBkYXRlID0gbmV3IEZvcm1Db250cm9sKG1vbWVudCgpKTtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcigpIHtcclxuICAgICAgICBzdXBlcigpO1xyXG4gICAgfVxyXG5cclxuICAgIGluaXREYXRlKCkge1xyXG4gICAgICBpZiAodGhpcy5kZWZhdWx0VmFsdWUpIHtcclxuICAgICAgICB0aGlzLmRhdGVPYmouZGF0ZSA9IG1vbWVudChuZXcgRGF0ZSh0aGlzLmRlZmF1bHRWYWx1ZSAqIDEwMDApKS51dGMoKS5mb3JtYXQoXCJZWVlZLU1NXCIpO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIHRoaXMuZGF0ZU9iai5kYXRlID0gbW9tZW50KG5ldyBEYXRlKCkpLmZvcm1hdChcIllZWVktTU1cIik7XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBpbml0TmFtZSgpIHtcclxuICAgICAgaWYgKCF0aGlzLm5hbWUpIHtcclxuICAgICAgICB0aGlzLm5hbWUgPSBcIk1vbnRoIGFuZCBZZWFyXCI7XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBjaG9zZW5UYWdIYW5kbGVyKHZhbHVlKSB7XHJcbiAgICAgICAgY29uc3QgcmVzdWx0RGF0ZTogTW9tZW50ID0gbW9tZW50LnV0Yyh2YWx1ZSk7XHJcbiAgICAgICAgcmVzdWx0RGF0ZS5ob3VyKDEyKTtcclxuICAgICAgICBjb25zdCByZXN1bHRUYWc6IElEYXRlVGFnID0ge1xyXG4gICAgICAgICAgICBuYW1lOiB0aGlzLm5hbWUsXHJcbiAgICAgICAgICAgIHZhbHVlOiBwYXJzZUludChyZXN1bHREYXRlLmZvcm1hdChcIlhcIiksIDEwKSxcclxuICAgICAgICAgICAgbGFiZWw6IHJlc3VsdERhdGUuZm9ybWF0KFwiTU1NTSBZWVlZXCIpLFxyXG4gICAgICAgICAgICBsb2NrZWQ6ICF0aGlzLmRhdGVGaWx0ZXIodmFsdWUpXHJcbiAgICAgICAgfTtcclxuICAgICAgICBjb25zb2xlLmxvZyhyZXN1bHRUYWcsIHZhbHVlKTtcclxuICAgICAgICB0aGlzLmRhdGVDaGFuZ2UuZW1pdChyZXN1bHRUYWcpO1xyXG4gICAgfVxyXG5cclxuICAgIGNob3Nlbk1vbnRoSGFuZGxlcihub3JtYWxpemVkTW9udGg6IE1vbWVudCwgZGF0ZXBpY2tlcjogTWF0RGF0ZXBpY2tlcjxNb21lbnQ+KSB7XHJcbiAgICAgICAgdGhpcy5kYXRlLnNldFZhbHVlKG5vcm1hbGl6ZWRNb250aCk7XHJcbiAgICAgICAgdGhpcy5kYXRlT2JqLmRhdGUgPSB0aGlzLmRhdGUudmFsdWU7XHJcblxyXG4gICAgICAgIHRoaXMuY2hvc2VuVGFnSGFuZGxlcih0aGlzLmRhdGUudmFsdWUpO1xyXG5cclxuICAgICAgICBkYXRlcGlja2VyLmNsb3NlKCk7XHJcbiAgICB9XHJcblxyXG4gICAgZGF0ZUZpbHRlciA9IChkYXRlKSA9PiB7XHJcbiAgICAgIGNvbnN0IGNhbGVuZGFyRGF0ZSA9IG1vbWVudChkYXRlKTtcclxuICAgICAgbGV0IHN0YXR1cyA9IHRydWU7XHJcblxyXG4gICAgICB0aGlzLmxvY2tlZERhdGUuZm9yRWFjaCh0aW1lc3RhbXAgPT4ge1xyXG4gICAgICAgIGNvbnN0IGxvY2tEYXRlID0gbW9tZW50LnVuaXgodGltZXN0YW1wKTtcclxuXHJcbiAgICAgICAgcmV0dXJuIHN0YXR1cyA9ICEobG9ja0RhdGUueWVhcigpID09PSBjYWxlbmRhckRhdGUueWVhcigpICYmIGxvY2tEYXRlLm1vbnRoKCkgPT09IGNhbGVuZGFyRGF0ZS5tb250aCgpKTtcclxuICAgICAgfSk7XHJcblxyXG4gICAgICByZXR1cm4gc3RhdHVzO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,101 @@
|
|
|
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 QuarterTagComponent extends AnyTagComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
super();
|
|
8
|
+
this.lockedDate = [];
|
|
9
|
+
this.selectedValue = 0;
|
|
10
|
+
this.quarters = [];
|
|
11
|
+
this.dateFilter = (date) => {
|
|
12
|
+
let status = true;
|
|
13
|
+
this.lockedDate.forEach(timestamp => {
|
|
14
|
+
const lockDate = moment.unix(timestamp);
|
|
15
|
+
const quarterDate = moment.unix(date.value);
|
|
16
|
+
if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {
|
|
17
|
+
date.disable = true;
|
|
18
|
+
status = false;
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
return status;
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
ngOnInit() {
|
|
25
|
+
this.initName();
|
|
26
|
+
this.quarters = this.getQuarterOptions();
|
|
27
|
+
for (const quarter of this.quarters) {
|
|
28
|
+
quarter.disable = false;
|
|
29
|
+
if (quarter.isSelected) {
|
|
30
|
+
this.selectedValue = quarter.value;
|
|
31
|
+
this.chosenTagHandler(quarter.value);
|
|
32
|
+
}
|
|
33
|
+
this.dateFilter(quarter);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
initName() {
|
|
37
|
+
if (!this.name) {
|
|
38
|
+
this.name = "Quarter";
|
|
39
|
+
}
|
|
40
|
+
}
|
|
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);
|
|
47
|
+
const resultTag = {
|
|
48
|
+
name: this.name,
|
|
49
|
+
value: parseInt(resultDate.format("X"), 10),
|
|
50
|
+
label: this.getQuarterLabel(resultDate.toString()),
|
|
51
|
+
locked: !this.dateFilter(value)
|
|
52
|
+
};
|
|
53
|
+
this.dateChange.emit(resultTag);
|
|
54
|
+
}
|
|
55
|
+
getQuarterOptions() {
|
|
56
|
+
const quartersBeforeToday = 8;
|
|
57
|
+
const quartersAfterToday = 8;
|
|
58
|
+
const dateNow = new Date();
|
|
59
|
+
const dateNowUnix = this.getUTCTimestamp(dateNow);
|
|
60
|
+
let defaultValue = dateNowUnix;
|
|
61
|
+
let tempDate = new Date();
|
|
62
|
+
if (this.defaultValue) {
|
|
63
|
+
defaultValue = this.defaultValue * 1000;
|
|
64
|
+
}
|
|
65
|
+
let afterDefault = Math.round(Math.abs(dateNowUnix - defaultValue) / 7776000000) + quartersAfterToday;
|
|
66
|
+
afterDefault = Math.min(afterDefault, 100);
|
|
67
|
+
let i, tempValue;
|
|
68
|
+
const to_return = [];
|
|
69
|
+
for (i = 0 - quartersBeforeToday; i <= afterDefault; i++) {
|
|
70
|
+
tempDate = new Date(defaultValue);
|
|
71
|
+
tempDate.setDate(15);
|
|
72
|
+
tempDate.setMonth(tempDate.getMonth() + 3 * i);
|
|
73
|
+
tempValue = this.getUTCTimestamp(tempDate);
|
|
74
|
+
to_return.push({
|
|
75
|
+
value: tempValue / 1000,
|
|
76
|
+
label: this.getQuarterLabel(tempValue),
|
|
77
|
+
isSelected: (i === 0),
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
return to_return;
|
|
81
|
+
}
|
|
82
|
+
getQuarterLabel(timeValue) {
|
|
83
|
+
const date = new Date(timeValue);
|
|
84
|
+
return "Q" + Math.floor((date.getMonth() / 3) + 1) + " " + date.getFullYear();
|
|
85
|
+
}
|
|
86
|
+
getUTCTimestamp(date) {
|
|
87
|
+
const month = Math.floor(date.getMonth() / 3) * 3;
|
|
88
|
+
return Date.UTC(date.getFullYear(), month, 1, 12, 0, 0, 0);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
QuarterTagComponent.decorators = [
|
|
92
|
+
{ type: Component, args: [{
|
|
93
|
+
template: "<div>\r\n <mat-form-field>\r\n <mat-select placeholder=\"{{name}}\" (selectionChange)=\"changeSelectHandler($event)\" [(value)]=\"selectedValue\">\r\n <mat-option *ngFor=\"let quarter of quarters\" [value]=\"quarter.value\" [disabled]=\"quarter.disable\">{{quarter.label}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n</div>\r\n",
|
|
94
|
+
selector: "quarter-tag"
|
|
95
|
+
},] }
|
|
96
|
+
];
|
|
97
|
+
QuarterTagComponent.ctorParameters = () => [];
|
|
98
|
+
QuarterTagComponent.propDecorators = {
|
|
99
|
+
lockedDate: [{ type: Input }]
|
|
100
|
+
};
|
|
101
|
+
//# 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\";\r\nimport {IDateTag} from \"../../models/serverTags\";\r\nimport {Moment} from \"moment\";\r\nimport {AnyTagComponent} from \"../date-tag.component\";\r\nimport {MatSelectChange} from \"@angular/material/select\";\r\n// @ts-ignore\r\nconst moment = require(\"moment\");\r\n\r\n@Component({\r\n    templateUrl: \"quarter-tag.component.html\",\r\n    selector: \"quarter-tag\",\r\n})\r\nexport class QuarterTagComponent extends AnyTagComponent implements OnInit {\r\n    @Input() lockedDate: any[] = [];\r\n    selectedValue = 0;\r\n    quarters: any[] = [];\r\n\r\n    constructor() {\r\n        super();\r\n    }\r\n\r\n    ngOnInit() {\r\n      this.initName();\r\n      this.quarters = this.getQuarterOptions();\r\n\r\n      for (const quarter of this.quarters) {\r\n          quarter.disable = false;\r\n\r\n          if (quarter.isSelected) {\r\n              this.selectedValue = quarter.value;\r\n              this.chosenTagHandler(quarter.value);\r\n          }\r\n\r\n          this.dateFilter(quarter);\r\n      }\r\n    }\r\n\r\n    initName() {\r\n      if (!this.name) {\r\n        this.name = \"Quarter\";\r\n      }\r\n    }\r\n\r\n    changeSelectHandler(event: MatSelectChange) {\r\n      this.chosenTagHandler(event.value);\r\n    }\r\n\r\n    chosenTagHandler(value) {\r\n        const date = new Date(value * 1000);\r\n        const resultDate: Moment = moment.utc(date);\r\n        const resultTag: IDateTag = {\r\n            name: this.name,\r\n            value: parseInt(resultDate.format(\"X\"), 10),\r\n            label: this.getQuarterLabel(resultDate.toString()),\r\n            locked: !this.dateFilter(value)\r\n        };\r\n        this.dateChange.emit(resultTag);\r\n    }\r\n\r\n    getQuarterOptions() {\r\n        const quartersBeforeToday = 8;\r\n        const quartersAfterToday = 8;\r\n        const dateNow = new Date();\r\n        const dateNowUnix = this.getUTCTimestamp(dateNow);\r\n        let defaultValue = dateNowUnix;\r\n        let tempDate =  new Date();\r\n        if (this.defaultValue) {\r\n          defaultValue = this.defaultValue * 1000;\r\n        }\r\n\r\n        let afterDefault = Math.round(Math.abs(dateNowUnix - defaultValue) / 7776000000) + quartersAfterToday;\r\n        afterDefault = Math.min(afterDefault, 100);\r\n        let i, tempValue;\r\n        const to_return: any[] = [];\r\n        for (i = 0 - quartersBeforeToday; i <= afterDefault; i++) {\r\n            tempDate = new Date(defaultValue);\r\n            tempDate.setDate(15);\r\n            tempDate.setMonth(tempDate.getMonth() + 3 * i);\r\n            tempValue = this.getUTCTimestamp(tempDate);\r\n            to_return.push({\r\n                value: tempValue / 1000,\r\n                label: this.getQuarterLabel(tempValue),\r\n                isSelected: (i === 0),\r\n            });\r\n        }\r\n        return to_return;\r\n    }\r\n\r\n    private getQuarterLabel(timeValue) {\r\n        const date = new Date(timeValue);\r\n        return \"Q\" + Math.floor((date.getMonth() / 3) + 1) + \" \" + date.getFullYear();\r\n    }\r\n\r\n    private getUTCTimestamp(date) {\r\n        const month = Math.floor(date.getMonth() / 3) * 3;\r\n        return Date.UTC(date.getFullYear(), month, 1, 12, 0, 0, 0);\r\n    }\r\n\r\n  dateFilter = (date) => {\r\n    let status = true;\r\n\r\n    this.lockedDate.forEach(timestamp => {\r\n      const lockDate = moment.unix(timestamp);\r\n      const quarterDate = moment.unix(date.value);\r\n\r\n      if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {\r\n        date.disable = true;\r\n        status = false;\r\n      }\r\n    });\r\n\r\n    return status;\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,124 @@
|
|
|
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 WEEK_FORMATS = {
|
|
9
|
+
parse: {
|
|
10
|
+
dateInput: "WW-YYYY",
|
|
11
|
+
},
|
|
12
|
+
display: {
|
|
13
|
+
dateInput: "[Week] WW, YYYY",
|
|
14
|
+
monthYearLabel: "MMMM YYYY",
|
|
15
|
+
dateA11yLabel: "LL",
|
|
16
|
+
monthYearA11yLabel: "MMMM YYYY"
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
const ɵ0 = WEEK_FORMATS;
|
|
20
|
+
export class WeekTagComponent extends AnyTagComponent {
|
|
21
|
+
constructor() {
|
|
22
|
+
super();
|
|
23
|
+
this.lockedDate = [];
|
|
24
|
+
this.date = new FormControl(moment());
|
|
25
|
+
this.selectedValue = "";
|
|
26
|
+
this.dateFilter = (date) => {
|
|
27
|
+
const calendarDate = moment(date);
|
|
28
|
+
let status = true;
|
|
29
|
+
this.lockedDate.forEach(timestamp => {
|
|
30
|
+
const lockDate = moment.unix(timestamp);
|
|
31
|
+
return status = !(lockDate.week() === calendarDate.week() && lockDate.year() === calendarDate.year());
|
|
32
|
+
});
|
|
33
|
+
return status;
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
ngOnInit() {
|
|
37
|
+
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);
|
|
53
|
+
}
|
|
54
|
+
initName() {
|
|
55
|
+
if (!this.name) {
|
|
56
|
+
this.name = "Week";
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
chosenDateHandler(normalizedDay) {
|
|
60
|
+
const date = moment(normalizedDay).unix();
|
|
61
|
+
this.chosenTagHandler(date);
|
|
62
|
+
}
|
|
63
|
+
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);
|
|
73
|
+
const resultTag = {
|
|
74
|
+
name: this.name,
|
|
75
|
+
value: parseInt(resultDate.format("X"), 10),
|
|
76
|
+
label: this.getWeekLabel(date),
|
|
77
|
+
locked: !this.dateFilter(value)
|
|
78
|
+
};
|
|
79
|
+
console.log("resultTag", resultTag);
|
|
80
|
+
this.dateChange.emit(resultTag);
|
|
81
|
+
}
|
|
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;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
WeekTagComponent.decorators = [
|
|
106
|
+
{ type: Component, args: [{
|
|
107
|
+
template: "<div>\r\n <mat-form-field class=\"date-select-box\">\r\n <input\r\n matInput\r\n placeholder=\"{{name}}\"\r\n name=\"week\"\r\n [formControl]=\"date\"\r\n [matDatepicker]=\"datepicker\"\r\n [matDatepickerFilter]=\"dateFilter\"\r\n (ngModelChange)=\"chosenDateHandler($event)\">\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker\r\n #datepicker\r\n startView=\"month\"\r\n ></mat-datepicker>\r\n </mat-form-field>\r\n</div>\r\n",
|
|
108
|
+
selector: "week-tag",
|
|
109
|
+
providers: [
|
|
110
|
+
{
|
|
111
|
+
provide: DateAdapter,
|
|
112
|
+
useClass: MomentDateAdapter,
|
|
113
|
+
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
114
|
+
},
|
|
115
|
+
{ provide: MAT_DATE_FORMATS, useValue: ɵ0 },
|
|
116
|
+
]
|
|
117
|
+
},] }
|
|
118
|
+
];
|
|
119
|
+
WeekTagComponent.ctorParameters = () => [];
|
|
120
|
+
WeekTagComponent.propDecorators = {
|
|
121
|
+
lockedDate: [{ type: Input }]
|
|
122
|
+
};
|
|
123
|
+
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\";\r\nimport {IDateTag} from \"../../models/serverTags\";\r\nimport {Moment} from \"moment\";\r\nimport {AnyTagComponent} from \"../date-tag.component\";\r\nimport {FormControl} from \"@angular/forms\";\r\nimport {DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE} from \"@angular/material/core\";\r\nimport {MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter} from \"@angular/material-moment-adapter\";\r\n// @ts-ignore\r\nconst moment = require(\"moment\");\r\n\r\nconst WEEK_FORMATS = {\r\n  parse: {\r\n    dateInput: \"WW-YYYY\",\r\n  },\r\n  display: {\r\n    dateInput: \"[Week] WW, YYYY\",\r\n    monthYearLabel: \"MMMM YYYY\",\r\n    dateA11yLabel: \"LL\",\r\n    monthYearA11yLabel: \"MMMM YYYY\"\r\n  },\r\n};\r\n\r\n@Component({\r\n    templateUrl: \"week-tag.component.html\",\r\n    selector: \"week-tag\",\r\n    providers: [\r\n      {\r\n        provide: DateAdapter,\r\n        useClass: MomentDateAdapter,\r\n        deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],\r\n      },\r\n      {provide: MAT_DATE_FORMATS, useValue: WEEK_FORMATS},\r\n    ],\r\n})\r\nexport class WeekTagComponent extends AnyTagComponent implements OnInit {\r\n    @Input() lockedDate: any[] = [];\r\n\r\n    date = new FormControl(moment());\r\n    selectedValue = \"\";\r\n\r\n    constructor() {\r\n        super();\r\n    }\r\n\r\n    ngOnInit() {\r\n      this.initName();\r\n\r\n      const now = new Date();\r\n      now.setHours(0, 0, 0, 0);\r\n\r\n      const dateUnix = this.getUTCTimestamp(this.getMonday(now));\r\n      let default_value_time = dateUnix;\r\n      const one_day_in_seconds = 86400;\r\n      if (this.defaultValue) {\r\n        default_value_time = (this.defaultValue + one_day_in_seconds) * 1000;\r\n      }\r\n\r\n      const default_date = new Date(default_value_time);\r\n      const weekNumber = this.getWeekNumberByDate(default_date);\r\n      const yearNumber = default_date.getFullYear();\r\n      const dateStr = `${yearNumber}-W${weekNumber}`;\r\n      this.dateObj.date = dateStr;\r\n      this.selectedValue = dateStr;\r\n      this.chosenTagHandler(default_date);\r\n    }\r\n\r\n    initName() {\r\n      if (!this.name) {\r\n        this.name = \"Week\";\r\n      }\r\n    }\r\n\r\n    chosenDateHandler(normalizedDay) {\r\n      const date = moment(normalizedDay).unix();\r\n      this.chosenTagHandler(date);\r\n    }\r\n\r\n    dateFilter = (date) => {\r\n      const calendarDate = moment(date);\r\n      let status = true;\r\n\r\n      this.lockedDate.forEach(timestamp => {\r\n        const lockDate = moment.unix(timestamp);\r\n\r\n        return status = !(lockDate.week() === calendarDate.week() && lockDate.year() === calendarDate.year());\r\n      });\r\n\r\n      return status;\r\n    }\r\n\r\n    chosenTagHandler(value) {\r\n        let date;\r\n        console.log(\"chosenTag\", value);\r\n        if (value > 1000000000000) {\r\n          date = new Date(value);\r\n        } else {\r\n          date = new Date(value * 1000);\r\n        }\r\n\r\n        const resultDate: Moment = moment(date);\r\n        const resultTag: IDateTag = {\r\n            name: this.name,\r\n            value: parseInt(resultDate.format(\"X\"), 10),\r\n            label: this.getWeekLabel(date),\r\n            locked: !this.dateFilter(value)\r\n        };\r\n        console.log(\"resultTag\", resultTag);\r\n        this.dateChange.emit(resultTag);\r\n      }\r\n\r\n    private getWeekLabel(date) {\r\n      return \"W\" + this.pad( moment(date).isoWeek(), 2) +\r\n        \" \" + moment(date).year();\r\n    }\r\n\r\n    private getUTCTimestamp(date) {\r\n        return Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), 12, 0, 0, 0);\r\n    }\r\n\r\n    private getMonday(date) {\r\n        const day = date.getDay() || 7;\r\n        if (day !== 1) {\r\n            date.setHours(-24 * (day - 1));\r\n        }\r\n        return date;\r\n    }\r\n\r\n    private getWeekNumberByDate(date: Date) {\r\n      return this.pad(moment(date).isoWeek(), 2);\r\n    }\r\n\r\n    private pad(n, width, z = \"0\") {\r\n      z = z || \"0\";\r\n      n = n + \"\";\r\n      return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { Component, Input } from "@angular/core";
|
|
2
|
+
import { FormControl } from "@angular/forms";
|
|
3
|
+
import { AnyTagComponent } from "../date-tag.component";
|
|
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 YEAR_FORMATS = {
|
|
9
|
+
parse: {
|
|
10
|
+
dateInput: "YYYY",
|
|
11
|
+
},
|
|
12
|
+
display: {
|
|
13
|
+
dateInput: "YYYY",
|
|
14
|
+
monthYearLabel: "MMMM YYYY",
|
|
15
|
+
dateA11yLabel: "LL",
|
|
16
|
+
monthYearA11yLabel: "MMMM YYYY"
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
const ɵ0 = YEAR_FORMATS;
|
|
20
|
+
export class YearTagComponent extends AnyTagComponent {
|
|
21
|
+
constructor() {
|
|
22
|
+
super();
|
|
23
|
+
this.lockedDate = [];
|
|
24
|
+
this.date = new FormControl(moment());
|
|
25
|
+
this.dateFilter = (date) => {
|
|
26
|
+
const calendarDateYear = moment(date).year();
|
|
27
|
+
let status = true;
|
|
28
|
+
this.lockedDate.forEach(timestamp => {
|
|
29
|
+
const lockDate = moment.unix(timestamp);
|
|
30
|
+
return status = !(lockDate.year() === calendarDateYear);
|
|
31
|
+
});
|
|
32
|
+
return status;
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
initDate() {
|
|
36
|
+
if (this.defaultValue) {
|
|
37
|
+
this.dateObj.date = moment(new Date(this.defaultValue * 1000)).utc().format("YYYY");
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
this.dateObj.date = moment(new Date()).format("YYYY");
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
initName() {
|
|
44
|
+
if (!this.name) {
|
|
45
|
+
this.name = "Year";
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
chosenTagHandler(value) {
|
|
49
|
+
const date = new Date();
|
|
50
|
+
const year = moment(value).year();
|
|
51
|
+
date.setTime(0);
|
|
52
|
+
date.setFullYear(year, 0, 1);
|
|
53
|
+
const resultDate = moment.utc(date);
|
|
54
|
+
resultDate.hour(12);
|
|
55
|
+
const resultTag = {
|
|
56
|
+
name: this.name,
|
|
57
|
+
value: parseInt(resultDate.format("X"), 10),
|
|
58
|
+
label: resultDate.format("YYYY"),
|
|
59
|
+
locked: !this.dateFilter(value)
|
|
60
|
+
};
|
|
61
|
+
console.log("resultTag", resultTag);
|
|
62
|
+
this.dateChange.emit(resultTag);
|
|
63
|
+
}
|
|
64
|
+
chosenYearHandler(normalizedYear, datepicker) {
|
|
65
|
+
const ctrlValue = this.date.value;
|
|
66
|
+
ctrlValue.year(normalizedYear.year());
|
|
67
|
+
this.date.setValue(ctrlValue);
|
|
68
|
+
this.dateObj.date = this.date.value;
|
|
69
|
+
this.chosenTagHandler(this.date.value);
|
|
70
|
+
datepicker.close();
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
YearTagComponent.decorators = [
|
|
74
|
+
{ type: Component, args: [{
|
|
75
|
+
template: "<div>\r\n <mat-form-field class=\"date-select-box\">\r\n <input\r\n matInput\r\n placeholder=\"{{name}}\"\r\n name=\"Year\"\r\n [formControl]=\"date\"\r\n [matDatepicker]=\"datepicker\"\r\n [matDatepickerFilter]=\"dateFilter\">\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker\r\n #datepicker\r\n startView=\"multi-year\"\r\n (yearSelected)=\"chosenYearHandler($event, datepicker)\"\r\n panelClass=\"date-month-picker\"\r\n ></mat-datepicker>\r\n </mat-form-field>\r\n</div>\r\n",
|
|
76
|
+
selector: "year-tag",
|
|
77
|
+
providers: [
|
|
78
|
+
{
|
|
79
|
+
provide: DateAdapter,
|
|
80
|
+
useClass: MomentDateAdapter,
|
|
81
|
+
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
82
|
+
},
|
|
83
|
+
{ provide: MAT_DATE_FORMATS, useValue: ɵ0 },
|
|
84
|
+
]
|
|
85
|
+
},] }
|
|
86
|
+
];
|
|
87
|
+
YearTagComponent.ctorParameters = () => [];
|
|
88
|
+
YearTagComponent.propDecorators = {
|
|
89
|
+
lockedDate: [{ type: Input }]
|
|
90
|
+
};
|
|
91
|
+
export { ɵ0 };
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieWVhci10YWcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZGF0ZS10YWdzL3llYXItdGFnL3llYXItdGFnLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUN2RCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFJM0MsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBQyxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDdEYsT0FBTyxFQUFDLCtCQUErQixFQUFFLGlCQUFpQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDcEcsYUFBYTtBQUNiLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUVqQyxNQUFNLFlBQVksR0FBRztJQUNuQixLQUFLLEVBQUU7UUFDTCxTQUFTLEVBQUUsTUFBTTtLQUNsQjtJQUNELE9BQU8sRUFBRTtRQUNQLFNBQVMsRUFBRSxNQUFNO1FBQ2pCLGNBQWMsRUFBRSxXQUFXO1FBQzNCLGFBQWEsRUFBRSxJQUFJO1FBQ25CLGtCQUFrQixFQUFFLFdBQVc7S0FDaEM7Q0FDRixDQUFDO1dBVzBDLFlBQVk7QUFJeEQsTUFBTSxPQUFPLGdCQUFpQixTQUFRLGVBQWU7SUFLbkQ7UUFDRSxLQUFLLEVBQUUsQ0FBQztRQUxELGVBQVUsR0FBVSxFQUFFLENBQUM7UUFFaEMsU0FBSSxHQUFHLElBQUksV0FBVyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7UUFnRGpDLGVBQVUsR0FBRyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ3BCLE1BQU0sZ0JBQWdCLEdBQUcsTUFBTSxDQUFDLElB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UyxFQUFFO29CQUNUO3dCQUNFLE9BQU8sRUFBRSxXQUFXO3dCQUNwQixRQUFRLEVBQUUsaUJBQWlCO3dCQUMzQixJQUFJLEVBQUUsQ0FBQyxlQUFlLEVBQUUsK0JBQStCLENBQUM7cUJBQ3pEO29CQUNELEVBQUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFFBQVEsSUFBYyxFQUFDO2lCQUNwRDthQUNKOzs7O3lCQUdFLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIE9uSW5pdH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtGb3JtQ29udHJvbH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7TWF0RGF0ZXBpY2tlcn0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXJcIjtcclxuaW1wb3J0IHtNb21lbnR9IGZyb20gXCJtb21lbnRcIjtcclxuaW1wb3J0IHtJRGF0ZVRhZ30gZnJvbSBcIi4uLy4uL21vZGVscy9zZXJ2ZXJUYWdzXCI7XHJcbmltcG9ydCB7QW55VGFnQ29tcG9uZW50fSBmcm9tIFwiLi4vZGF0ZS10YWcuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7RGF0ZUFkYXB0ZXIsIE1BVF9EQVRFX0ZPUk1BVFMsIE1BVF9EQVRFX0xPQ0FMRX0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2NvcmVcIjtcclxuaW1wb3J0IHtNQVRfTU9NRU5UX0RBVEVfQURBUFRFUl9PUFRJT05TLCBNb21lbnREYXRlQWRhcHRlcn0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsLW1vbWVudC1hZGFwdGVyXCI7XHJcbi8vIEB0cy1pZ25vcmVcclxuY29uc3QgbW9tZW50ID0gcmVxdWlyZShcIm1vbWVudFwiKTtcclxuXHJcbmNvbnN0IFlFQVJfRk9STUFUUyA9IHtcclxuICBwYXJzZToge1xyXG4gICAgZGF0ZUlucHV0OiBcIllZWVlcIixcclxuICB9LFxyXG4gIGRpc3BsYXk6IHtcclxuICAgIGRhdGVJbnB1dDogXCJZWVlZXCIsXHJcbiAgICBtb250aFllYXJMYWJlbDogXCJNTU1NIFlZWVlcIixcclxuICAgIGRhdGVBMTF5TGFiZWw6IFwiTExcIixcclxuICAgIG1vbnRoWWVhckExMXlMYWJlbDogXCJNTU1NIFlZWVlcIlxyXG4gIH0sXHJcbn07XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHRlbXBsYXRlVXJsOiBcInllYXItdGFnLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgICBzZWxlY3RvcjogXCJ5ZWFyLXRhZ1wiLFxyXG4gICAgcHJvdmlkZXJzOiBbXHJcbiAgICAgIHtcclxuICAgICAgICBwcm92aWRlOiBEYXRlQWRhcHRlcixcclxuICAgICAgICB1c2VDbGFzczogTW9tZW50RGF0ZUFkYXB0ZXIsXHJcbiAgICAgICAgZGVwczogW01BVF9EQVRFX0xPQ0FMRSwgTUFUX01PTUVOVF9EQVRFX0FEQVBURVJfT1BUSU9OU10sXHJcbiAgICAgIH0sXHJcbiAgICAgIHtwcm92aWRlOiBNQVRfREFURV9GT1JNQVRTLCB1c2VWYWx1ZTogWUVBUl9GT1JNQVRTfSxcclxuICAgIF0sXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgWWVhclRhZ0NvbXBvbmVudCBleHRlbmRzIEFueVRhZ0NvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgbG9ja2VkRGF0ZTogYW55W10gPSBbXTtcclxuXHJcbiAgZGF0ZSA9IG5ldyBGb3JtQ29udHJvbChtb21lbnQoKSk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgc3VwZXIoKTtcclxuICB9XHJcblxyXG4gIGluaXREYXRlKCkge1xyXG4gICAgaWYgKHRoaXMuZGVmYXVsdFZhbHVlKSB7XHJcbiAgICAgIHRoaXMuZGF0ZU9iai5kYXRlID0gbW9tZW50KG5ldyBEYXRlKHRoaXMuZGVmYXVsdFZhbHVlICogMTAwMCkpLnV0YygpLmZvcm1hdChcIllZWVlcIik7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLmRhdGVPYmouZGF0ZSA9IG1vbWVudChuZXcgRGF0ZSgpKS5mb3JtYXQoXCJZWVlZXCIpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgaW5pdE5hbWUoKSB7XHJcbiAgICBpZiAoIXRoaXMubmFtZSkge1xyXG4gICAgICB0aGlzLm5hbWUgPSBcIlllYXJcIjtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGNob3NlblRhZ0hhbmRsZXIodmFsdWUpIHtcclxuICAgICAgY29uc3QgZGF0ZSA9IG5ldyBEYXRlKCk7XHJcbiAgICAgIGNvbnN0IHllYXIgPSBtb21lbnQodmFsdWUpLnllYXIoKTtcclxuICAgICAgZGF0ZS5zZXRUaW1lKDApO1xyXG4gICAgICBkYXRlLnNldEZ1bGxZZWFyKHllYXIsIDAsIDEpO1xyXG4gICAgICBjb25zdCByZXN1bHREYXRlOiBNb21lbnQgPSBtb21lbnQudXRjKGRhdGUpO1xyXG4gICAgICByZXN1bHREYXRlLmhvdXIoMTIpO1xyXG4gICAgICBjb25zdCByZXN1bHRUYWc6IElEYXRlVGFnID0ge1xyXG4gICAgICAgICAgbmFtZTogdGhpcy5uYW1lLFxyXG4gICAgICAgICAgdmFsdWU6IHBhcnNlSW50KHJlc3VsdERhdGUuZm9ybWF0KFwiWFwiKSwgMTApLFxyXG4gICAgICAgICAgbGFiZWw6IHJlc3VsdERhdGUuZm9ybWF0KFwiWVlZWVwiKSxcclxuICAgICAgICAgIGxvY2tlZDogIXRoaXMuZGF0ZUZpbHRlcih2YWx1ZSlcclxuICAgICAgfTtcclxuICAgICAgY29uc29sZS5sb2coXCJyZXN1bHRUYWdcIiwgcmVzdWx0VGFnKTtcclxuICAgICAgdGhpcy5kYXRlQ2hhbmdlLmVtaXQocmVzdWx0VGFnKTtcclxuICB9XHJcblxyXG4gIGNob3NlblllYXJIYW5kbGVyKG5vcm1hbGl6ZWRZZWFyOiBNb21lbnQsIGRhdGVwaWNrZXI6IE1hdERhdGVwaWNrZXI8TW9tZW50Pikge1xyXG4gICAgY29uc3QgY3RybFZhbHVlID0gdGhpcy5kYXRlLnZhbHVlO1xyXG4gICAgY3RybFZhbHVlLnllYXIobm9ybWFsaXplZFllYXIueWVhcigpKTtcclxuXHJcbiAgICB0aGlzLmRhdGUuc2V0VmFsdWUoY3RybFZhbHVlKTtcclxuICAgIHRoaXMuZGF0ZU9iai5kYXRlID0gdGhpcy5kYXRlLnZhbHVlO1xyXG4gICAgdGhpcy5jaG9zZW5UYWdIYW5kbGVyKHRoaXMuZGF0ZS52YWx1ZSk7XHJcblxyXG4gICAgZGF0ZXBpY2tlci5jbG9zZSgpO1xyXG4gIH1cclxuXHJcbiAgZGF0ZUZpbHRlciA9IChkYXRlKSA9PiB7XHJcbiAgICBjb25zdCBjYWxlbmRhckRhdGVZZWFyID0gbW9tZW50KGRhdGUpLnllYXIoKTtcclxuICAgIGxldCBzdGF0dXMgPSB0cnVlO1xyXG5cclxuICAgIHRoaXMubG9ja2VkRGF0ZS5mb3JFYWNoKHRpbWVzdGFtcCA9PiB7XHJcbiAgICAgIGNvbnN0IGxvY2tEYXRlID0gbW9tZW50LnVuaXgodGltZXN0YW1wKTtcclxuXHJcbiAgICAgIHJldHVybiBzdGF0dXMgPSAhKGxvY2tEYXRlLnllYXIoKSA9PT0gY2FsZW5kYXJEYXRlWWVhcilcclxuICAgIH0pO1xyXG5cclxuICAgIHJldHVybiBzdGF0dXM7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
3
|
+
export class CheckboxComponent {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.disabled = false;
|
|
6
|
+
this.checkedChange = new EventEmitter();
|
|
7
|
+
this.onChange = () => { };
|
|
8
|
+
this.onTouched = () => { };
|
|
9
|
+
}
|
|
10
|
+
writeValue(value) {
|
|
11
|
+
this.checkedStatus = value;
|
|
12
|
+
}
|
|
13
|
+
registerOnChange(fn) {
|
|
14
|
+
this.onChange = fn;
|
|
15
|
+
}
|
|
16
|
+
registerOnTouched(fn) {
|
|
17
|
+
this.onTouched = fn;
|
|
18
|
+
}
|
|
19
|
+
setDisabledState(isDisabled) {
|
|
20
|
+
this.disabled = isDisabled;
|
|
21
|
+
}
|
|
22
|
+
setValue() {
|
|
23
|
+
this.checkedStatus = !this.checkedStatus;
|
|
24
|
+
this.onChange(this.checkedStatus);
|
|
25
|
+
this.checkedChange.emit(this.checkedStatus);
|
|
26
|
+
this.onTouched();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
CheckboxComponent.decorators = [
|
|
30
|
+
{ type: Component, args: [{
|
|
31
|
+
selector: 'dr-checkbox',
|
|
32
|
+
template: "<label>\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"checkedStatus\"\r\n [disabled]=\"disabled\"\r\n (click)=\"setValue()\">\r\n <span>\r\n <ng-content></ng-content>\r\n </span>\r\n</label>\r\n",
|
|
33
|
+
providers: [
|
|
34
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: CheckboxComponent, multi: true }
|
|
35
|
+
],
|
|
36
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
37
|
+
encapsulation: ViewEncapsulation.ShadowDom,
|
|
38
|
+
styles: ["input+span{vertical-align:middle;line-height:30px}input+span,input+span:before{box-sizing:content-box!important;-webkit-box-sizing:content-box!important;-moz-box-sizing:content-box!important}input{visibility:hidden;position:absolute}label input+span{position:relative;z-index:19;display:inline-block;margin:0 5px 0 0;line-height:17px;min-height:14px;min-width:14px}label input+span:hover{cursor:pointer}label input+span:before{content:\"\";font-size:14px;border-radius:0;display:inline-block;text-align:center;vertical-align:middle;padding:1px;min-height:12px;line-height:12px;min-width:12px;margin-right:5px;border:1.5px solid #85889C;background-color:#f4f4f4;font-weight:normal;margin-top:-1px}label input+span:before,label:hover input+span:before{background-color:#fff;border-color:#85889c;color:#579bf2;border-radius:2px}label input:checked+span:before,label:hover input:checked+span:before{content:url('data:image/svg+xml; utf8, <svg width=\"12\" height=\"10\" viewBox=\"0 0 12 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"> <path d=\"M1 5L4.5 8.5L11 1.5\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/> </svg>');background:#579BF2;border-color:#579bf2;color:#fff}label input:disabled+span:before{border-color:#bcbcbc;pointer-events:none}label input[disabled]:checked+span:before{background:#BCBCBC;border-color:#bcbcbc;pointer-events:none}label input:not([disabled])+span:hover:after{content:\"\";width:28px;height:28px;background:#F6F7F8;border-radius:50%;position:absolute;left:-6px;top:-5px;z-index:-1}\n"]
|
|
39
|
+
},] }
|
|
40
|
+
];
|
|
41
|
+
CheckboxComponent.propDecorators = {
|
|
42
|
+
checkedStatus: [{ type: Input }],
|
|
43
|
+
disabled: [{ type: Input }],
|
|
44
|
+
checkedChange: [{ type: Output }]
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItaW5wdXRzL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFDTixpQkFBaUIsRUFDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBWXpFLE1BQU0sT0FBTyxpQkFBaUI7SUFWOUI7UUFjRSxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ1Asa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRTdDLGFBQVEsR0FBNkIsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO1FBQzlDLGNBQVMsR0FBZSxHQUFHLEVBQUUsR0FBRSxDQUFDLENBQUM7SUF1Qm5DLENBQUM7SUFyQkMsVUFBVSxDQUFDLEtBQWM7UUFDdkIsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7SUFDN0IsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU87UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUNELGdCQUFnQixDQUFFLFVBQW1CO1FBQ25DLElBQUksQ0FBQyxRQUFRLEdBQUcsVUFBVSxDQUFDO0lBQzdCLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLGFBQWEsR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUM7UUFDekMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDbEMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzVDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNuQixDQUFDOzs7WUF4Q0YsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxhQUFhO2dCQUN2QixxT0FBd0M7Z0JBRXhDLFNBQVMsRUFBRTtvQkFDVCxFQUFDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxXQUFXLEVBQUUsaUJBQWlCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBQztpQkFDMUU7Z0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07Z0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxTQUFTOzthQUMzQzs7OzRCQUVFLEtBQUs7dUJBRUwsS0FBSzs0QkFFTCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBDb21wb25lbnQsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIElucHV0LFxyXG4gIE91dHB1dCxcclxuICBWaWV3RW5jYXBzdWxhdGlvblxyXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdkci1jaGVja2JveCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrYm94LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9jaGVja2JveC5jb21wb25lbnQuc2NzcyddLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge3Byb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLCB1c2VFeGlzdGluZzogQ2hlY2tib3hDb21wb25lbnQsIG11bHRpOiB0cnVlfVxyXG4gIF0sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uU2hhZG93RG9tLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hlY2tib3hDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XHJcbiAgQElucHV0KClcclxuICBjaGVja2VkU3RhdHVzOiBib29sZWFuO1xyXG4gIEBJbnB1dCgpXHJcbiAgZGlzYWJsZWQgPSBmYWxzZTtcclxuICBAT3V0cHV0KCkgY2hlY2tlZENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuXHJcbiAgb25DaGFuZ2U6ICh2YWx1ZTogYm9vbGVhbikgPT4gdm9pZCA9ICgpID0+IHt9O1xyXG4gIG9uVG91Y2hlZDogKCkgPT4gdm9pZCA9ICgpID0+IHt9O1xyXG5cclxuICB3cml0ZVZhbHVlKHZhbHVlOiBib29sZWFuKSB7XHJcbiAgICB0aGlzLmNoZWNrZWRTdGF0dXMgPSB2YWx1ZTtcclxuICB9XHJcblxyXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSkge1xyXG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xyXG4gIH1cclxuXHJcbiAgcmVnaXN0ZXJPblRvdWNoZWQoZm46IGFueSkge1xyXG4gICAgdGhpcy5vblRvdWNoZWQgPSBmbjtcclxuICB9XHJcbiAgc2V0RGlzYWJsZWRTdGF0ZT8oaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgdGhpcy5kaXNhYmxlZCA9IGlzRGlzYWJsZWQ7XHJcbiAgfVxyXG5cclxuICBzZXRWYWx1ZSgpIHtcclxuICAgIHRoaXMuY2hlY2tlZFN0YXR1cyA9ICF0aGlzLmNoZWNrZWRTdGF0dXM7XHJcbiAgICB0aGlzLm9uQ2hhbmdlKHRoaXMuY2hlY2tlZFN0YXR1cyk7XHJcbiAgICB0aGlzLmNoZWNrZWRDaGFuZ2UuZW1pdCh0aGlzLmNoZWNrZWRTdGF0dXMpO1xyXG4gICAgdGhpcy5vblRvdWNoZWQoKTtcclxuICB9XHJcbn1cclxuIl19
|