@ng-nest/ui 15.0.15 → 15.0.17
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/checkbox/checkbox.component.d.ts +2 -0
- package/checkbox/checkbox.module.d.ts +4 -3
- package/checkbox/checkbox.property.d.ts +42 -1
- package/core/functions/date.d.ts +2 -0
- package/date-picker/date-picker-portal.component.d.ts +1 -0
- package/date-picker/date-picker.module.d.ts +18 -16
- package/date-picker/date-picker.property.d.ts +120 -1
- package/date-picker/date-quarter.pipe.d.ts +9 -0
- package/date-picker/picker-date.component.d.ts +1 -0
- package/date-picker/picker-quarter.component.d.ts +45 -0
- package/date-picker/public-api.d.ts +2 -0
- package/esm2020/checkbox/checkbox.component.mjs +21 -4
- package/esm2020/checkbox/checkbox.module.mjs +5 -4
- package/esm2020/checkbox/checkbox.property.mjs +28 -2
- package/esm2020/core/functions/date.mjs +15 -1
- package/esm2020/date-picker/date-picker-portal.component.mjs +16 -4
- package/esm2020/date-picker/date-picker.component.mjs +12 -3
- package/esm2020/date-picker/date-picker.module.mjs +18 -6
- package/esm2020/date-picker/date-picker.property.mjs +154 -1
- package/esm2020/date-picker/date-quarter.pipe.mjs +19 -0
- package/esm2020/date-picker/date-range-portal.component.mjs +7 -6
- package/esm2020/date-picker/date-range.component.mjs +28 -4
- package/esm2020/date-picker/picker-date.component.mjs +6 -3
- package/esm2020/date-picker/picker-quarter.component.mjs +237 -0
- package/esm2020/date-picker/public-api.mjs +3 -1
- package/esm2020/i18n/i18n.property.mjs +1 -1
- package/esm2020/i18n/languages/en_GB.mjs +4 -1
- package/esm2020/i18n/languages/en_US.mjs +4 -1
- package/esm2020/i18n/languages/zh_CN.mjs +4 -1
- package/esm2020/i18n/languages/zh_TW.mjs +4 -1
- package/esm2020/radio/radio.component.mjs +28 -6
- package/esm2020/radio/radio.module.mjs +5 -4
- package/esm2020/radio/radio.property.mjs +28 -3
- package/esm2020/tag/tag.component.mjs +4 -4
- package/esm2020/tag/tag.property.mjs +22 -2
- package/esm2020/tree/tree.component.mjs +47 -59
- package/fesm2015/ng-nest-ui-checkbox.mjs +51 -7
- package/fesm2015/ng-nest-ui-checkbox.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-core.mjs +15 -1
- package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-date-picker.mjs +468 -18
- package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-i18n.mjs +12 -0
- package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-radio.mjs +58 -10
- package/fesm2015/ng-nest-ui-radio.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tag.mjs +24 -4
- package/fesm2015/ng-nest-ui-tag.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tree.mjs +45 -57
- package/fesm2015/ng-nest-ui-tree.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-checkbox.mjs +51 -7
- package/fesm2020/ng-nest-ui-checkbox.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-core.mjs +15 -1
- package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-date-picker.mjs +467 -18
- package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-i18n.mjs +12 -0
- package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-radio.mjs +58 -10
- package/fesm2020/ng-nest-ui-radio.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tag.mjs +24 -4
- package/fesm2020/ng-nest-ui-tag.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tree.mjs +45 -57
- package/fesm2020/ng-nest-ui-tree.mjs.map +1 -1
- package/i18n/i18n.property.d.ts +3 -0
- package/i18n/languages/en_GB.d.ts +3 -0
- package/i18n/languages/en_US.d.ts +3 -0
- package/i18n/languages/zh_CN.d.ts +3 -0
- package/i18n/languages/zh_TW.d.ts +3 -0
- package/package.json +1 -1
- package/radio/radio.component.d.ts +2 -0
- package/radio/radio.module.d.ts +4 -3
- package/radio/radio.property.d.ts +38 -3
- package/tag/tag.property.d.ts +8 -3
- package/tree/tree.component.d.ts +1 -1
|
@@ -6,18 +6,19 @@ import { XButtonModule } from '@ng-nest/ui/button';
|
|
|
6
6
|
import { XOutletModule } from '@ng-nest/ui/outlet';
|
|
7
7
|
import { XCheckboxProperty } from './checkbox.property';
|
|
8
8
|
import { XBaseFormModule } from '@ng-nest/ui/base-form';
|
|
9
|
+
import { XTagModule } from '@ng-nest/ui/tag';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
export class XCheckboxModule {
|
|
11
12
|
}
|
|
12
13
|
/** @nocollapse */ XCheckboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: XCheckboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
-
/** @nocollapse */ XCheckboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.3", ngImport: i0, type: XCheckboxModule, declarations: [XCheckboxComponent, XCheckboxProperty], imports: [CommonModule, FormsModule, XButtonModule, XOutletModule, XBaseFormModule], exports: [XCheckboxComponent] });
|
|
14
|
-
/** @nocollapse */ XCheckboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: XCheckboxModule, imports: [CommonModule, FormsModule, XButtonModule, XOutletModule, XBaseFormModule] });
|
|
14
|
+
/** @nocollapse */ XCheckboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.3", ngImport: i0, type: XCheckboxModule, declarations: [XCheckboxComponent, XCheckboxProperty], imports: [CommonModule, FormsModule, XButtonModule, XTagModule, XOutletModule, XBaseFormModule], exports: [XCheckboxComponent] });
|
|
15
|
+
/** @nocollapse */ XCheckboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: XCheckboxModule, imports: [CommonModule, FormsModule, XButtonModule, XTagModule, XOutletModule, XBaseFormModule] });
|
|
15
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: XCheckboxModule, decorators: [{
|
|
16
17
|
type: NgModule,
|
|
17
18
|
args: [{
|
|
18
19
|
declarations: [XCheckboxComponent, XCheckboxProperty],
|
|
19
20
|
exports: [XCheckboxComponent],
|
|
20
|
-
imports: [CommonModule, FormsModule, XButtonModule, XOutletModule, XBaseFormModule]
|
|
21
|
+
imports: [CommonModule, FormsModule, XButtonModule, XTagModule, XOutletModule, XBaseFormModule]
|
|
21
22
|
}]
|
|
22
23
|
}] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvY2hlY2tib3gvY2hlY2tib3gubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzFELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBTzdDLE1BQU0sT0FBTyxlQUFlOzsrSEFBZixlQUFlO2dJQUFmLGVBQWUsaUJBSlgsa0JBQWtCLEVBQUUsaUJBQWlCLGFBRTFDLFlBQVksRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsZUFBZSxhQURwRixrQkFBa0I7Z0lBR2pCLGVBQWUsWUFGaEIsWUFBWSxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxlQUFlOzJGQUVuRixlQUFlO2tCQUwzQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGtCQUFrQixFQUFFLGlCQUFpQixDQUFDO29CQUNyRCxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztvQkFDN0IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxlQUFlLENBQUM7aUJBQ2hHIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgWENoZWNrYm94Q29tcG9uZW50IH0gZnJvbSAnLi9jaGVja2JveC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgWEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BuZy1uZXN0L3VpL2J1dHRvbic7XHJcbmltcG9ydCB7IFhPdXRsZXRNb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9vdXRsZXQnO1xyXG5pbXBvcnQgeyBYQ2hlY2tib3hQcm9wZXJ0eSB9IGZyb20gJy4vY2hlY2tib3gucHJvcGVydHknO1xyXG5pbXBvcnQgeyBYQmFzZUZvcm1Nb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9iYXNlLWZvcm0nO1xyXG5pbXBvcnQgeyBYVGFnTW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvdGFnJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbWENoZWNrYm94Q29tcG9uZW50LCBYQ2hlY2tib3hQcm9wZXJ0eV0sXHJcbiAgZXhwb3J0czogW1hDaGVja2JveENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIFhCdXR0b25Nb2R1bGUsIFhUYWdNb2R1bGUsIFhPdXRsZXRNb2R1bGUsIFhCYXNlRm9ybU1vZHVsZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIFhDaGVja2JveE1vZHVsZSB7fVxyXG4iXX0=
|
|
@@ -21,10 +21,25 @@ export class XCheckboxProperty extends XControlValueAccessor {
|
|
|
21
21
|
* @en_US Checkbox data
|
|
22
22
|
*/
|
|
23
23
|
this.data = [];
|
|
24
|
+
/**
|
|
25
|
+
* @zh_CN 按钮/图标/ tag 标签样式时生效
|
|
26
|
+
* @en_US Take effect when button style
|
|
27
|
+
*/
|
|
28
|
+
this.type = 'initial';
|
|
29
|
+
/**
|
|
30
|
+
* @zh_CN tag 标签边框
|
|
31
|
+
* @en_US Tag bordered
|
|
32
|
+
*/
|
|
33
|
+
this.tagBordered = true;
|
|
34
|
+
/**
|
|
35
|
+
* @zh_CN tag 标签深色主题
|
|
36
|
+
* @en_US Tag dark theme
|
|
37
|
+
*/
|
|
38
|
+
this.tagDark = false;
|
|
24
39
|
}
|
|
25
40
|
}
|
|
26
41
|
/** @nocollapse */ XCheckboxProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: XCheckboxProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
27
|
-
/** @nocollapse */ XCheckboxProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: XCheckboxProperty, selector: "ng-component", inputs: { data: "data", button: "button", icon: "icon", indeterminate: "indeterminate", size: "size", before: "before", after: "after" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
|
|
42
|
+
/** @nocollapse */ XCheckboxProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: XCheckboxProperty, selector: "ng-component", inputs: { data: "data", button: "button", icon: "icon", tag: "tag", indeterminate: "indeterminate", size: "size", type: "type", tagBordered: "tagBordered", tagDark: "tagDark", before: "before", after: "after" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
|
|
28
43
|
__decorate([
|
|
29
44
|
XDataConvert()
|
|
30
45
|
], XCheckboxProperty.prototype, "data", void 0);
|
|
@@ -34,6 +49,9 @@ __decorate([
|
|
|
34
49
|
__decorate([
|
|
35
50
|
XInputBoolean()
|
|
36
51
|
], XCheckboxProperty.prototype, "icon", void 0);
|
|
52
|
+
__decorate([
|
|
53
|
+
XInputBoolean()
|
|
54
|
+
], XCheckboxProperty.prototype, "tag", void 0);
|
|
37
55
|
__decorate([
|
|
38
56
|
XInputBoolean()
|
|
39
57
|
], XCheckboxProperty.prototype, "indeterminate", void 0);
|
|
@@ -49,13 +67,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImpor
|
|
|
49
67
|
type: Input
|
|
50
68
|
}], icon: [{
|
|
51
69
|
type: Input
|
|
70
|
+
}], tag: [{
|
|
71
|
+
type: Input
|
|
52
72
|
}], indeterminate: [{
|
|
53
73
|
type: Input
|
|
54
74
|
}], size: [{
|
|
55
75
|
type: Input
|
|
76
|
+
}], type: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], tagBordered: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], tagDark: [{
|
|
81
|
+
type: Input
|
|
56
82
|
}], before: [{
|
|
57
83
|
type: Input
|
|
58
84
|
}], after: [{
|
|
59
85
|
type: Input
|
|
60
86
|
}] } });
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gucHJvcGVydHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9jaGVja2JveC9jaGVja2JveC5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUF1QyxZQUFZLEVBQUUsYUFBYSxFQUFtQixXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNsSSxPQUFPLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUscUJBQXFCLEVBQWUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFFM0U7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxZQUFZLENBQUM7QUFDNUMsTUFBTSxhQUFhLEdBQUcsVUFBVSxDQUFDO0FBRWpDOztHQUVHO0FBRUgsTUFBTSxPQUFPLGlCQUFrQixTQUFRLHFCQUEyQztJQURsRjs7UUFFRTs7O1dBR0c7UUFDc0IsU0FBSSxHQUF5QixFQUFFLENBQUM7UUEwQnpEOzs7V0FHRztRQUNNLFNBQUksR0FBZ0IsU0FBUyxDQUFDO1FBQ3ZDOzs7V0FHRztRQUNNLGdCQUFXLEdBQWEsSUFBSSxDQUFDO1FBQ3RDOzs7V0FHRztRQUNNLFlBQU8sR0FBYSxLQUFLLENBQUM7S0FXcEM7O2lJQXhEWSxpQkFBaUI7cUhBQWpCLGlCQUFpQiwrUkFEUCxFQUFFO0FBTUU7SUFBZixZQUFZLEVBQUU7K0NBQWlDO0FBSy9CO0lBQWhCLGFBQWEsRUFBRTtpREFBbUI7QUFLbEI7SUFBaEIsYUFBYSxFQUFFOytDQUFpQjtBQUtoQjtJQUFoQixhQUFhLEVBQUU7OENBQWdCO0FBS2Y7SUFBaEIsYUFBYSxFQUFFO3dEQUEwQjtBQUtHO0lBQTVDLFdBQVcsQ0FBUSxhQUFhLEVBQUUsUUFBUSxDQUFDOytDQUF1QjsyRkE5QmpFLGlCQUFpQjtrQkFEN0IsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUU7OEJBTUEsSUFBSTtzQkFBNUIsS0FBSztnQkFLb0IsTUFBTTtzQkFBL0IsS0FBSztnQkFLb0IsSUFBSTtzQkFBN0IsS0FBSztnQkFLb0IsR0FBRztzQkFBNUIsS0FBSztnQkFLb0IsYUFBYTtzQkFBdEMsS0FBSztnQkFLeUQsSUFBSTtzQkFBbEUsS0FBSztnQkFLRyxJQUFJO3NCQUFaLEtBQUs7Z0JBS0csV0FBVztzQkFBbkIsS0FBSztnQkFLRyxPQUFPO3NCQUFmLEtBQUs7Z0JBS1ksTUFBTTtzQkFBdkIsS0FBSztnQkFLWSxLQUFLO3NCQUF0QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgWERhdGEsIFhUZW1wbGF0ZSwgWElkZW50aXR5UHJvcGVydHksIFhEYXRhQ29udmVydCwgWElucHV0Qm9vbGVhbiwgWFNpemUsIFhCb29sZWFuLCBYV2l0aENvbmZpZyB9IGZyb20gJ0BuZy1uZXN0L3VpL2NvcmUnO1xyXG5pbXBvcnQgeyBJbnB1dCwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFhCdXR0b25UeXBlIH0gZnJvbSAnQG5nLW5lc3QvdWkvYnV0dG9uJztcclxuaW1wb3J0IHsgWENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBYRm9ybU9wdGlvbiB9IGZyb20gJ0BuZy1uZXN0L3VpL2Jhc2UtZm9ybSc7XHJcblxyXG4vKipcclxuICogQ2hlY2tib3hcclxuICogQHNlbGVjdG9yIHgtY2hlY2tib3hcclxuICogQGRlY29yYXRvciBjb21wb25lbnRcclxuICovXHJcbmV4cG9ydCBjb25zdCBYQ2hlY2tib3hQcmVmaXggPSAneC1jaGVja2JveCc7XHJcbmNvbnN0IFhfQ09ORklHX05BTUUgPSAnY2hlY2tib3gnO1xyXG5cclxuLyoqXHJcbiAqIENoZWNrYm94IFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgdGVtcGxhdGU6ICcnIH0pXHJcbmV4cG9ydCBjbGFzcyBYQ2hlY2tib3hQcm9wZXJ0eSBleHRlbmRzIFhDb250cm9sVmFsdWVBY2Nlc3Nvcjxib29sZWFuIHwgQXJyYXk8YW55Pj4gaW1wbGVtZW50cyBYQ2hlY2tib3hPcHRpb24ge1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlpJrpgInmoYbmlbDmja5cclxuICAgKiBAZW5fVVMgQ2hlY2tib3ggZGF0YVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYRGF0YUNvbnZlcnQoKSBkYXRhOiBYRGF0YTxYQ2hlY2tib3hOb2RlPiA9IFtdO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmjInpkq7moLflvI9cclxuICAgKiBAZW5fVVMgQnV0dG9uIHN0eWxlXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhJbnB1dEJvb2xlYW4oKSBidXR0b24/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5Zu+5qCH5qC35byPXHJcbiAgICogQGVuX1VTIEljb24gc3R5bGVcclxuICAgKi9cclxuICBASW5wdXQoKSBAWElucHV0Qm9vbGVhbigpIGljb24/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04gdGFnIOagh+etvuagt+W8j1xyXG4gICAqIEBlbl9VUyBUYWcgc3R5bGVcclxuICAgKi9cclxuICBASW5wdXQoKSBAWElucHV0Qm9vbGVhbigpIHRhZz86IFhCb29sZWFuO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDkuI3noa7lrprnirbmgIHnmoTmoLflvI9cclxuICAgKiBAZW5fVVMgVW5jZXJ0YWluIHN0YXRlIHN0eWxlXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhJbnB1dEJvb2xlYW4oKSBpbmRldGVybWluYXRlPzogWEJvb2xlYW47XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWwuuWvuFxyXG4gICAqIEBlbl9VUyBTaXplXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhTaXplPihYX0NPTkZJR19OQU1FLCAnbWVkaXVtJykgb3ZlcnJpZGUgc2l6ZT86IFhTaXplO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmjInpkq4v5Zu+5qCHLyB0YWcg5qCH562+5qC35byP5pe255Sf5pWIXHJcbiAgICogQGVuX1VTIFRha2UgZWZmZWN0IHdoZW4gYnV0dG9uIHN0eWxlXHJcbiAgICovXHJcbiAgQElucHV0KCkgdHlwZTogWEJ1dHRvblR5cGUgPSAnaW5pdGlhbCc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIHRhZyDmoIfnrb7ovrnmoYZcclxuICAgKiBAZW5fVVMgVGFnIGJvcmRlcmVkXHJcbiAgICovXHJcbiAgQElucHV0KCkgdGFnQm9yZGVyZWQ6IFhCb29sZWFuID0gdHJ1ZTtcclxuICAvKipcclxuICAgKiBAemhfQ04gdGFnIOagh+etvua3seiJsuS4u+mimFxyXG4gICAqIEBlbl9VUyBUYWcgZGFyayB0aGVtZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHRhZ0Rhcms6IFhCb29sZWFuID0gZmFsc2U7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWJjee9ruagh+etvlxyXG4gICAqIEBlbl9VUyBCZWZvcmUgbGFiZWxcclxuICAgKi9cclxuICBASW5wdXQoKSBvdmVycmlkZSBiZWZvcmUhOiBYVGVtcGxhdGU7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWQjue9ruagh+etvlxyXG4gICAqIEBlbl9VUyBBZnRlciBsYWJlbFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIG92ZXJyaWRlIGFmdGVyITogWFRlbXBsYXRlO1xyXG59XHJcblxyXG4vKipcclxuICogQ2hlY2tib3ggT3B0aW9uXHJcbiAqIEB1bmRvY3VtZW50IHRydWVcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgWENoZWNrYm94T3B0aW9uIGV4dGVuZHMgWEZvcm1PcHRpb24ge1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDljZXpgInmoYbmlbDmja5cclxuICAgKiBAZW5fVVMgUmFkaW8gZGF0YVxyXG4gICAqL1xyXG4gIGRhdGE/OiBYRGF0YTxYQ2hlY2tib3hOb2RlPjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5oyJ6ZKu5qC35byPXHJcbiAgICogQGVuX1VTIEJ1dHRvbiBzdHlsZVxyXG4gICAqL1xyXG4gIGJ1dHRvbj86IFhCb29sZWFuO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77moIfmoLflvI9cclxuICAgKiBAZW5fVVMgSWNvbiBzdHlsZVxyXG4gICAqL1xyXG4gIGljb24/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04gdGFnIOagh+etvuagt+W8j1xyXG4gICAqIEBlbl9VUyBUYWcgc3R5bGVcclxuICAgKi9cclxuICB0YWc/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5LiN56Gu5a6a54q25oCB55qE5qC35byPXHJcbiAgICogQGVuX1VTIFVuY2VydGFpbiBzdGF0ZSBzdHlsZVxyXG4gICAqL1xyXG4gIGluZGV0ZXJtaW5hdGU/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5bC65a+4XHJcbiAgICogQGVuX1VTIFNpemVcclxuICAgKi9cclxuICBzaXplPzogWFNpemU7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOaMiemSri/lm77moIcvIHRhZyDmoIfnrb7moLflvI/ml7bnlJ/mlYhcclxuICAgKiBAZW5fVVMgVGFrZSBlZmZlY3Qgd2hlbiBidXR0b24gc3R5bGVcclxuICAgKi9cclxuICB0eXBlPzogWEJ1dHRvblR5cGU7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIHRhZyDmoIfnrb7ovrnmoYZcclxuICAgKiBAZW5fVVMgVGFnIGJvcmRlcmVkXHJcbiAgICovXHJcbiAgdGFnQm9yZGVyZWQ/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04gdGFnIOagh+etvua3seiJsuS4u+mimFxyXG4gICAqIEBlbl9VUyBUYWcgZGFyayB0aGVtZVxyXG4gICAqL1xyXG4gIHRhZ0Rhcms/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5YmN572u5qCH562+XHJcbiAgICogQGVuX1VTIEJlZm9yZSBsYWJlbFxyXG4gICAqL1xyXG4gIGJlZm9yZT86IFhUZW1wbGF0ZTtcclxuICAvKipcclxuICAgKiBAemhfQ04g5ZCO572u5qCH562+XHJcbiAgICogQGVuX1VTIEFmdGVyIGxhYmVsXHJcbiAgICovXHJcbiAgYWZ0ZXI/OiBYVGVtcGxhdGU7XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAemhfQ04gQ2hlY2tib3gg5pWw5o2u5a+56LGhXHJcbiAqIEBlbl9VUyBDaGVja2JveCBkYXRhIG9iamVjdFxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBYQ2hlY2tib3hOb2RlIGV4dGVuZHMgWElkZW50aXR5UHJvcGVydHkge1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDnpoHnlKhcclxuICAgKiBAZW5fVVMgRGlzYWJsZVxyXG4gICAqL1xyXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5Zu+5qCHXHJcbiAgICogQGVuX1VTIEljb25cclxuICAgKi9cclxuICBpY29uPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77moIfnmoTmj5DnpLrkv6Hmga9cclxuICAgKiBAZW5fVVMgSWNvbiBtZXNzYWdlXHJcbiAgICovXHJcbiAgdGl0bGU/OiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOagh+etvuaWh+Wtl1xyXG4gICAqIEBlbl9VUyBMYWJlbCB0ZXh0XHJcbiAgICovXHJcbiAgbGFiZWw/OiBYVGVtcGxhdGU7XHJcbn1cclxuIl19
|
|
@@ -79,6 +79,20 @@ export function XDateYearWeek(date) {
|
|
|
79
79
|
}
|
|
80
80
|
return;
|
|
81
81
|
}
|
|
82
|
+
export function XDateYearQuarter(date) {
|
|
83
|
+
let dt = XToDate(date);
|
|
84
|
+
if (!isNaN(dt.valueOf())) {
|
|
85
|
+
return `${dt.getFullYear()}-${XDateQuarter(dt)}`;
|
|
86
|
+
}
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
export function XDateQuarter(date) {
|
|
90
|
+
let dt = XToDate(date);
|
|
91
|
+
if (!isNaN(dt.valueOf())) {
|
|
92
|
+
return `Q${Math.ceil((dt.getMonth() + 1) / 3)}`;
|
|
93
|
+
}
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
82
96
|
function getISOWeek(date) {
|
|
83
97
|
const diff = startOfISOWeek(date).getTime() - startOfISOWeekYear(date).getTime();
|
|
84
98
|
return Math.round(diff / 604800000) + 1;
|
|
@@ -130,4 +144,4 @@ function getISOWeekYear(date) {
|
|
|
130
144
|
return year - 1;
|
|
131
145
|
}
|
|
132
146
|
}
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.js","sourceRoot":"","sources":["../../../../../../lib/ng-nest/ui/core/functions/date.ts"],"names":[],"mappings":"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","sourcesContent":["import { XIsDate, XIsNumber } from '../interfaces';\r\n\r\nexport type XDate = string | Date | number;\r\n\r\nexport function XToDate(date: XDate): Date {\r\n  if (XIsDate(date) || XIsNumber(date)) {\r\n    return new Date(date);\r\n  } else {\r\n    return new Date(Date.parse(date as string));\r\n  }\r\n}\r\n\r\nexport function XAddMilliseconds(date: XDate, amount: number): Date {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf()) && amount) {\r\n    return new Date(dt.getTime() + amount);\r\n  } else {\r\n    return date as Date;\r\n  }\r\n}\r\n\r\nexport function XAddSeconds(date: XDate, amount: number): Date {\r\n  return XAddMilliseconds(date, amount * 1000);\r\n}\r\n\r\nexport function XAddMinutes(date: XDate, amount: number): Date {\r\n  return XAddMilliseconds(date, amount * 60000);\r\n}\r\n\r\nexport function XAddHours(date: XDate, amount: number): Date {\r\n  return XAddMilliseconds(date, amount * 3600000);\r\n}\r\n\r\nexport function XAddDays(date: XDate, amount: number): Date {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf()) && amount) {\r\n    dt.setDate(dt.getDate() + amount);\r\n    return dt;\r\n  } else {\r\n    return date as Date;\r\n  }\r\n}\r\n\r\nexport function XAddMonths(date: XDate, amount: number): Date {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf()) && amount) {\r\n    const day = dt.getDate();\r\n    const month = dt.getMonth();\r\n    const endMonth = new Date(dt);\r\n    endMonth.setMonth(month + amount + 1, 0);\r\n    const endDay = endMonth.getDate();\r\n    if (day >= endDay) {\r\n      return endMonth;\r\n    } else {\r\n      dt.setFullYear(endMonth.getFullYear(), endMonth.getMonth(), day);\r\n    }\r\n    return dt;\r\n  } else {\r\n    return date as Date;\r\n  }\r\n}\r\n\r\nexport function XAddYears(date: XDate, amount: number): Date {\r\n  return XAddMonths(date, amount * 12);\r\n}\r\n\r\nexport function XDateWeek(date: XDate) {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf())) {\r\n    return getISOWeek(dt);\r\n  }\r\n  return;\r\n}\r\n\r\nexport function XDateWeekYear(date: XDate) {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf())) {\r\n    return getISOWeekYear(dt);\r\n  }\r\n  return;\r\n}\r\n\r\nexport function XDateYearWeek(date: XDate) {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf())) {\r\n    return `${getISOWeekYear(dt)}-${getISOWeek(dt)}`;\r\n  }\r\n  return;\r\n}\r\n\r\nfunction getISOWeek(date: Date): number {\r\n  const diff = startOfISOWeek(date).getTime() - startOfISOWeekYear(date).getTime();\r\n  return Math.round(diff / 604800000) + 1;\r\n}\r\n\r\nfunction startOfISOWeek(date: Date) {\r\n  return startOfWeek(date, { weekStartsOn: 1 });\r\n}\r\n\r\nfunction startOfWeek(date: Date, options?: { weekStartsOn: number }) {\r\n  const weekStartsOn = options?.weekStartsOn || 0;\r\n  const day = date.getDay();\r\n  const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\r\n  date.setDate(date.getDate() - diff);\r\n  date.setHours(0, 0, 0, 0);\r\n  return date;\r\n}\r\n\r\nfunction startOfISOWeekYear(date: Date) {\r\n  const year = getISOWeekYear(date);\r\n  const fourthOfJanuary = constructFrom(date, 0);\r\n  fourthOfJanuary.setFullYear(year, 0, 4);\r\n  fourthOfJanuary.setHours(0, 0, 0, 0);\r\n  const result = startOfISOWeek(fourthOfJanuary);\r\n  return result;\r\n}\r\n\r\nfunction constructFrom<DateType extends Date>(date: DateType | number, value: Date | number): DateType {\r\n  if (date instanceof Date) {\r\n    return new (date.constructor as any)(value);\r\n  } else {\r\n    return new Date(value) as DateType;\r\n  }\r\n}\r\n\r\nfunction getISOWeekYear(date: Date): number {\r\n  const year = date.getFullYear();\r\n\r\n  const fourthOfJanuaryOfNextYear = constructFrom(date, 0);\r\n  fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);\r\n  fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);\r\n  const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);\r\n\r\n  const fourthOfJanuaryOfThisYear = constructFrom(date, 0);\r\n  fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);\r\n  fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);\r\n  const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear);\r\n\r\n  if (date.getTime() >= startOfNextYear.getTime()) {\r\n    return year + 1;\r\n  } else if (date.getTime() >= startOfThisYear.getTime()) {\r\n    return year;\r\n  } else {\r\n    return year - 1;\r\n  }\r\n}\r\n"]}
|
|
147
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.js","sourceRoot":"","sources":["../../../../../../lib/ng-nest/ui/core/functions/date.ts"],"names":[],"mappings":"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","sourcesContent":["import { XIsDate, XIsNumber } from '../interfaces';\r\n\r\nexport type XDate = string | Date | number;\r\n\r\nexport function XToDate(date: XDate): Date {\r\n  if (XIsDate(date) || XIsNumber(date)) {\r\n    return new Date(date);\r\n  } else {\r\n    return new Date(Date.parse(date as string));\r\n  }\r\n}\r\n\r\nexport function XAddMilliseconds(date: XDate, amount: number): Date {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf()) && amount) {\r\n    return new Date(dt.getTime() + amount);\r\n  } else {\r\n    return date as Date;\r\n  }\r\n}\r\n\r\nexport function XAddSeconds(date: XDate, amount: number): Date {\r\n  return XAddMilliseconds(date, amount * 1000);\r\n}\r\n\r\nexport function XAddMinutes(date: XDate, amount: number): Date {\r\n  return XAddMilliseconds(date, amount * 60000);\r\n}\r\n\r\nexport function XAddHours(date: XDate, amount: number): Date {\r\n  return XAddMilliseconds(date, amount * 3600000);\r\n}\r\n\r\nexport function XAddDays(date: XDate, amount: number): Date {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf()) && amount) {\r\n    dt.setDate(dt.getDate() + amount);\r\n    return dt;\r\n  } else {\r\n    return date as Date;\r\n  }\r\n}\r\n\r\nexport function XAddMonths(date: XDate, amount: number): Date {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf()) && amount) {\r\n    const day = dt.getDate();\r\n    const month = dt.getMonth();\r\n    const endMonth = new Date(dt);\r\n    endMonth.setMonth(month + amount + 1, 0);\r\n    const endDay = endMonth.getDate();\r\n    if (day >= endDay) {\r\n      return endMonth;\r\n    } else {\r\n      dt.setFullYear(endMonth.getFullYear(), endMonth.getMonth(), day);\r\n    }\r\n    return dt;\r\n  } else {\r\n    return date as Date;\r\n  }\r\n}\r\n\r\nexport function XAddYears(date: XDate, amount: number): Date {\r\n  return XAddMonths(date, amount * 12);\r\n}\r\n\r\nexport function XDateWeek(date: XDate) {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf())) {\r\n    return getISOWeek(dt);\r\n  }\r\n  return;\r\n}\r\n\r\nexport function XDateWeekYear(date: XDate) {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf())) {\r\n    return getISOWeekYear(dt);\r\n  }\r\n  return;\r\n}\r\n\r\nexport function XDateYearWeek(date: XDate) {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf())) {\r\n    return `${getISOWeekYear(dt)}-${getISOWeek(dt)}`;\r\n  }\r\n  return;\r\n}\r\n\r\nexport function XDateYearQuarter(date: XDate) {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf())) {\r\n    return `${dt.getFullYear()}-${XDateQuarter(dt)}`;\r\n  }\r\n  return;\r\n}\r\n\r\nexport function XDateQuarter(date: XDate) {\r\n  let dt = XToDate(date);\r\n  if (!isNaN(dt.valueOf())) {\r\n    return `Q${Math.ceil((dt.getMonth() + 1) / 3)}`;\r\n  }\r\n  return;\r\n}\r\n\r\nfunction getISOWeek(date: Date): number {\r\n  const diff = startOfISOWeek(date).getTime() - startOfISOWeekYear(date).getTime();\r\n  return Math.round(diff / 604800000) + 1;\r\n}\r\n\r\nfunction startOfISOWeek(date: Date) {\r\n  return startOfWeek(date, { weekStartsOn: 1 });\r\n}\r\n\r\nfunction startOfWeek(date: Date, options?: { weekStartsOn: number }) {\r\n  const weekStartsOn = options?.weekStartsOn || 0;\r\n  const day = date.getDay();\r\n  const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\r\n  date.setDate(date.getDate() - diff);\r\n  date.setHours(0, 0, 0, 0);\r\n  return date;\r\n}\r\n\r\nfunction startOfISOWeekYear(date: Date) {\r\n  const year = getISOWeekYear(date);\r\n  const fourthOfJanuary = constructFrom(date, 0);\r\n  fourthOfJanuary.setFullYear(year, 0, 4);\r\n  fourthOfJanuary.setHours(0, 0, 0, 0);\r\n  const result = startOfISOWeek(fourthOfJanuary);\r\n  return result;\r\n}\r\n\r\nfunction constructFrom<DateType extends Date>(date: DateType | number, value: Date | number): DateType {\r\n  if (date instanceof Date) {\r\n    return new (date.constructor as any)(value);\r\n  } else {\r\n    return new Date(value) as DateType;\r\n  }\r\n}\r\n\r\nfunction getISOWeekYear(date: Date): number {\r\n  const year = date.getFullYear();\r\n\r\n  const fourthOfJanuaryOfNextYear = constructFrom(date, 0);\r\n  fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);\r\n  fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);\r\n  const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);\r\n\r\n  const fourthOfJanuaryOfThisYear = constructFrom(date, 0);\r\n  fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);\r\n  fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);\r\n  const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear);\r\n\r\n  if (date.getTime() >= startOfNextYear.getTime()) {\r\n    return year + 1;\r\n  } else if (date.getTime() >= startOfThisYear.getTime()) {\r\n    return year;\r\n  } else {\r\n    return year - 1;\r\n  }\r\n}\r\n"]}
|
|
@@ -13,7 +13,8 @@ import * as i5 from "@ng-nest/ui/button";
|
|
|
13
13
|
import * as i6 from "@ng-nest/ui/outlet";
|
|
14
14
|
import * as i7 from "./picker-date.component";
|
|
15
15
|
import * as i8 from "./picker-month.component";
|
|
16
|
-
import * as i9 from "./picker-
|
|
16
|
+
import * as i9 from "./picker-quarter.component";
|
|
17
|
+
import * as i10 from "./picker-year.component";
|
|
17
18
|
export class XDatePickerPortalComponent {
|
|
18
19
|
constructor(datePipe, lowerCasePipe, cdr, i18n) {
|
|
19
20
|
this.datePipe = datePipe;
|
|
@@ -123,6 +124,17 @@ export class XDatePickerPortalComponent {
|
|
|
123
124
|
}
|
|
124
125
|
this.cdr.detectChanges();
|
|
125
126
|
}
|
|
127
|
+
quarterChange(date) {
|
|
128
|
+
this.setDisplay(date);
|
|
129
|
+
if (this._type === 'quarter') {
|
|
130
|
+
this.model = date;
|
|
131
|
+
this.nodeEmit(date);
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
this.type = this._type;
|
|
135
|
+
}
|
|
136
|
+
this.cdr.detectChanges();
|
|
137
|
+
}
|
|
126
138
|
yearChange(date) {
|
|
127
139
|
this.setDisplay(date);
|
|
128
140
|
if (this._type === 'year') {
|
|
@@ -160,10 +172,10 @@ export class XDatePickerPortalComponent {
|
|
|
160
172
|
}
|
|
161
173
|
}
|
|
162
174
|
/** @nocollapse */ XDatePickerPortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: XDatePickerPortalComponent, deps: [{ token: i1.DatePipe }, { token: i1.LowerCasePipe }, { token: i0.ChangeDetectorRef }, { token: i2.XI18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
163
|
-
/** @nocollapse */ XDatePickerPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: XDatePickerPortalComponent, selector: "x-date-picker-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], viewQueries: [{ propertyName: "timePickerFrame", first: true, predicate: ["timePickerFrame"], descendants: true }], ngImport: i0, template: "<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'week'\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'month'\">\r\n <x-picker-month\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"monthChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-month>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'year'\">\r\n <x-picker-year\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"yearChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-year>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-time'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-hour'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-minute'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isDatePicker\">\r\n <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n <div class=\"x-date-picker-portal-content\">\r\n <div class=\"x-date-picker-portal-date\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [(type)]=\"type\"\r\n [model]=\"model\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </div>\r\n <div class=\"x-date-picker-portal-time\">\r\n <div class=\"x-date-picker-portal-time-label\">\r\n {{ time | date : timeFormat }}\r\n </div>\r\n <x-time-picker-frame\r\n #timePickerFrame\r\n [type]=\"timeType\"\r\n [value]=\"time\"\r\n (nodeEmit)=\"selectTime($event)\"\r\n [disabledTime]=\"disabledTime\"\r\n [defaultNow]=\"false\"\r\n ></x-time-picker-frame>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"!isDatePicker\">\r\n <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n </div>\r\n </ng-container>\r\n <div class=\"x-date-picker-portal-footer\">\r\n <div class=\"x-date-picker-portal-footer-left\">\r\n <ng-container *ngIf=\"!isDatePicker\">\r\n <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n </ng-container>\r\n </div>\r\n <x-button type=\"primary\" (click)=\"!sureDisabled && nodeEmit(model)\" size=\"small\" [disabled]=\"sureDisabled\">{{ locale.sure }}</x-button>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #presetTpl>\r\n <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n <ng-container *ngFor=\"let item of preset\">\r\n <x-link *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-link>\r\n <x-link *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-link>\r\n <x-link *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-link>\r\n <x-link *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-link>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-picker-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:16rem;display:flex;flex-direction:column}.x-date-picker-portal.week{width:18.125rem}.x-date-picker-portal.week .x-picker-date-body .x-picker-date-item:not(.x-date-in-range):not(.x-date-active) .x-date-text{background-color:transparent}.x-date-picker-portal.week .x-picker-date-body tbody tr:not(.x-date-week-active):hover .x-picker-date-item:not(.x-date-in-range){background-color:var(--x-background-a200);border-radius:var(--x-border-radius)}.x-date-picker-portal.date-time{width:27rem}.x-date-picker-portal.date-hour{width:19.75rem}.x-date-picker-portal.date-minute{width:23.375rem}.x-date-picker-portal-preset{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;border-top:var(--x-border-width) solid var(--x-border)}.x-date-picker-portal-preset>x-link{padding:.25rem}.x-date-picker-portal-preset>x-link:not(:first-child){margin-left:1rem}.x-date-picker-portal-body{padding:.4rem}.x-date-picker-portal-content{display:flex}.x-date-picker-portal-footer{display:flex;align-items:center;justify-content:space-between;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-footer .x-date-picker-portal-preset{border-top:none}.x-date-picker-portal-footer .x-date-picker-portal-preset>x-link{padding:0 .25rem}.x-date-picker-portal-extra-footer{display:flex;align-items:center;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-date{flex:1}.x-date-picker-portal-time{display:flex;flex-direction:column;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time-label{display:flex;align-items:center;justify-content:center;padding:0 .5rem;height:2.5rem;border-bottom:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time .x-time-picker-frame{border-width:0;box-shadow:none;margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.XTimePickerFrameComponent, selector: "x-time-picker-frame", inputs: ["type", "value", "use12Hours", "hourStep", "minuteStep", "secondStep", "defaultNow", "disabledTime", "disabledTimeParam"], outputs: ["nodeEmit"] }, { kind: "component", type: i4.XLinkComponent, selector: "x-link" }, { kind: "component", type: i5.XButtonComponent, selector: "x-button" }, { kind: "directive", type: i6.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i7.XPickerDateComponent, selector: "x-picker-date" }, { kind: "component", type: i8.XPickerMonthComponent, selector: "x-picker-month" }, { kind: "component", type: i9.XPickerYearComponent, selector: "x-picker-year" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], animations: [XConnectBaseAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
175
|
+
/** @nocollapse */ XDatePickerPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: XDatePickerPortalComponent, selector: "x-date-picker-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], viewQueries: [{ propertyName: "timePickerFrame", first: true, predicate: ["timePickerFrame"], descendants: true }], ngImport: i0, template: "<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'week'\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'month'\">\r\n <x-picker-month\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"monthChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-month>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'quarter'\">\r\n <x-picker-quarter\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"quarterChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-quarter>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'year'\">\r\n <x-picker-year\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"yearChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-year>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-time'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-hour'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-minute'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isDatePicker\">\r\n <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n <div class=\"x-date-picker-portal-content\">\r\n <div class=\"x-date-picker-portal-date\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [(type)]=\"type\"\r\n [model]=\"model\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </div>\r\n <div class=\"x-date-picker-portal-time\">\r\n <div class=\"x-date-picker-portal-time-label\">\r\n {{ time | date : timeFormat }}\r\n </div>\r\n <x-time-picker-frame\r\n #timePickerFrame\r\n [type]=\"timeType\"\r\n [value]=\"time\"\r\n (nodeEmit)=\"selectTime($event)\"\r\n [disabledTime]=\"disabledTime\"\r\n [defaultNow]=\"false\"\r\n ></x-time-picker-frame>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"!isDatePicker\">\r\n <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n </div>\r\n </ng-container>\r\n <div class=\"x-date-picker-portal-footer\">\r\n <div class=\"x-date-picker-portal-footer-left\">\r\n <ng-container *ngIf=\"!isDatePicker\">\r\n <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n </ng-container>\r\n </div>\r\n <x-button type=\"primary\" (click)=\"!sureDisabled && nodeEmit(model)\" size=\"small\" [disabled]=\"sureDisabled\">{{ locale.sure }}</x-button>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #presetTpl>\r\n <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n <ng-container *ngFor=\"let item of preset\">\r\n <x-link *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-link>\r\n <x-link *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-link>\r\n <x-link *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-link>\r\n <x-link *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-link>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-picker-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:16rem;display:flex;flex-direction:column}.x-date-picker-portal.week{width:18.125rem}.x-date-picker-portal.week .x-picker-date-body .x-picker-date-item:not(.x-date-in-range):not(.x-date-active) .x-date-text{background-color:transparent}.x-date-picker-portal.week .x-picker-date-body tbody tr:not(.x-date-week-active):hover .x-picker-date-item:not(.x-date-in-range){background-color:var(--x-background-a200);border-radius:var(--x-border-radius)}.x-date-picker-portal.date-time{width:27rem}.x-date-picker-portal.date-hour{width:19.75rem}.x-date-picker-portal.date-minute{width:23.375rem}.x-date-picker-portal-preset{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;border-top:var(--x-border-width) solid var(--x-border)}.x-date-picker-portal-preset>x-link{padding:.25rem}.x-date-picker-portal-preset>x-link:not(:first-child){margin-left:1rem}.x-date-picker-portal-body{padding:.4rem}.x-date-picker-portal-content{display:flex}.x-date-picker-portal-footer{display:flex;align-items:center;justify-content:space-between;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-footer .x-date-picker-portal-preset{border-top:none}.x-date-picker-portal-footer .x-date-picker-portal-preset>x-link{padding:0 .25rem}.x-date-picker-portal-extra-footer{display:flex;align-items:center;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-date{flex:1}.x-date-picker-portal-time{display:flex;flex-direction:column;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time-label{display:flex;align-items:center;justify-content:center;padding:0 .5rem;height:2.5rem;border-bottom:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time .x-time-picker-frame{border-width:0;box-shadow:none;margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.XTimePickerFrameComponent, selector: "x-time-picker-frame", inputs: ["type", "value", "use12Hours", "hourStep", "minuteStep", "secondStep", "defaultNow", "disabledTime", "disabledTimeParam"], outputs: ["nodeEmit"] }, { kind: "component", type: i4.XLinkComponent, selector: "x-link" }, { kind: "component", type: i5.XButtonComponent, selector: "x-button" }, { kind: "directive", type: i6.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i7.XPickerDateComponent, selector: "x-picker-date" }, { kind: "component", type: i8.XPickerMonthComponent, selector: "x-picker-month" }, { kind: "component", type: i9.XPickerQuarterComponent, selector: "x-picker-quarter" }, { kind: "component", type: i10.XPickerYearComponent, selector: "x-picker-year" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], animations: [XConnectBaseAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
164
176
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: XDatePickerPortalComponent, decorators: [{
|
|
165
177
|
type: Component,
|
|
166
|
-
args: [{ selector: `${XDatePickerPortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'week'\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'month'\">\r\n <x-picker-month\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"monthChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-month>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'year'\">\r\n <x-picker-year\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"yearChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-year>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-time'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-hour'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-minute'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isDatePicker\">\r\n <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n <div class=\"x-date-picker-portal-content\">\r\n <div class=\"x-date-picker-portal-date\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [(type)]=\"type\"\r\n [model]=\"model\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </div>\r\n <div class=\"x-date-picker-portal-time\">\r\n <div class=\"x-date-picker-portal-time-label\">\r\n {{ time | date : timeFormat }}\r\n </div>\r\n <x-time-picker-frame\r\n #timePickerFrame\r\n [type]=\"timeType\"\r\n [value]=\"time\"\r\n (nodeEmit)=\"selectTime($event)\"\r\n [disabledTime]=\"disabledTime\"\r\n [defaultNow]=\"false\"\r\n ></x-time-picker-frame>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"!isDatePicker\">\r\n <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n </div>\r\n </ng-container>\r\n <div class=\"x-date-picker-portal-footer\">\r\n <div class=\"x-date-picker-portal-footer-left\">\r\n <ng-container *ngIf=\"!isDatePicker\">\r\n <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n </ng-container>\r\n </div>\r\n <x-button type=\"primary\" (click)=\"!sureDisabled && nodeEmit(model)\" size=\"small\" [disabled]=\"sureDisabled\">{{ locale.sure }}</x-button>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #presetTpl>\r\n <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n <ng-container *ngFor=\"let item of preset\">\r\n <x-link *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-link>\r\n <x-link *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-link>\r\n <x-link *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-link>\r\n <x-link *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-link>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-picker-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:16rem;display:flex;flex-direction:column}.x-date-picker-portal.week{width:18.125rem}.x-date-picker-portal.week .x-picker-date-body .x-picker-date-item:not(.x-date-in-range):not(.x-date-active) .x-date-text{background-color:transparent}.x-date-picker-portal.week .x-picker-date-body tbody tr:not(.x-date-week-active):hover .x-picker-date-item:not(.x-date-in-range){background-color:var(--x-background-a200);border-radius:var(--x-border-radius)}.x-date-picker-portal.date-time{width:27rem}.x-date-picker-portal.date-hour{width:19.75rem}.x-date-picker-portal.date-minute{width:23.375rem}.x-date-picker-portal-preset{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;border-top:var(--x-border-width) solid var(--x-border)}.x-date-picker-portal-preset>x-link{padding:.25rem}.x-date-picker-portal-preset>x-link:not(:first-child){margin-left:1rem}.x-date-picker-portal-body{padding:.4rem}.x-date-picker-portal-content{display:flex}.x-date-picker-portal-footer{display:flex;align-items:center;justify-content:space-between;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-footer .x-date-picker-portal-preset{border-top:none}.x-date-picker-portal-footer .x-date-picker-portal-preset>x-link{padding:0 .25rem}.x-date-picker-portal-extra-footer{display:flex;align-items:center;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-date{flex:1}.x-date-picker-portal-time{display:flex;flex-direction:column;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time-label{display:flex;align-items:center;justify-content:center;padding:0 .5rem;height:2.5rem;border-bottom:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time .x-time-picker-frame{border-width:0;box-shadow:none;margin:0}\n"] }]
|
|
178
|
+
args: [{ selector: `${XDatePickerPortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'week'\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'month'\">\r\n <x-picker-month\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"monthChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-month>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'quarter'\">\r\n <x-picker-quarter\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"quarterChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-quarter>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'year'\">\r\n <x-picker-year\r\n [display]=\"display\"\r\n [model]=\"model\"\r\n [(type)]=\"type\"\r\n (modelChange)=\"yearChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-year>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-time'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-hour'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date-minute'\">\r\n <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isDatePicker\">\r\n <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n <div class=\"x-date-picker-portal-content\">\r\n <div class=\"x-date-picker-portal-date\">\r\n <x-picker-date\r\n [display]=\"display\"\r\n [(type)]=\"type\"\r\n [model]=\"model\"\r\n (modelChange)=\"dateChange($event)\"\r\n [disabledDate]=\"disabledDate\"\r\n ></x-picker-date>\r\n </div>\r\n <div class=\"x-date-picker-portal-time\">\r\n <div class=\"x-date-picker-portal-time-label\">\r\n {{ time | date : timeFormat }}\r\n </div>\r\n <x-time-picker-frame\r\n #timePickerFrame\r\n [type]=\"timeType\"\r\n [value]=\"time\"\r\n (nodeEmit)=\"selectTime($event)\"\r\n [disabledTime]=\"disabledTime\"\r\n [defaultNow]=\"false\"\r\n ></x-time-picker-frame>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"!isDatePicker\">\r\n <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n </div>\r\n </ng-container>\r\n <div class=\"x-date-picker-portal-footer\">\r\n <div class=\"x-date-picker-portal-footer-left\">\r\n <ng-container *ngIf=\"!isDatePicker\">\r\n <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n </ng-container>\r\n </div>\r\n <x-button type=\"primary\" (click)=\"!sureDisabled && nodeEmit(model)\" size=\"small\" [disabled]=\"sureDisabled\">{{ locale.sure }}</x-button>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #presetTpl>\r\n <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n <ng-container *ngFor=\"let item of preset\">\r\n <x-link *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-link>\r\n <x-link *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-link>\r\n <x-link *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-link>\r\n <x-link *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-link>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-picker-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:16rem;display:flex;flex-direction:column}.x-date-picker-portal.week{width:18.125rem}.x-date-picker-portal.week .x-picker-date-body .x-picker-date-item:not(.x-date-in-range):not(.x-date-active) .x-date-text{background-color:transparent}.x-date-picker-portal.week .x-picker-date-body tbody tr:not(.x-date-week-active):hover .x-picker-date-item:not(.x-date-in-range){background-color:var(--x-background-a200);border-radius:var(--x-border-radius)}.x-date-picker-portal.date-time{width:27rem}.x-date-picker-portal.date-hour{width:19.75rem}.x-date-picker-portal.date-minute{width:23.375rem}.x-date-picker-portal-preset{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;border-top:var(--x-border-width) solid var(--x-border)}.x-date-picker-portal-preset>x-link{padding:.25rem}.x-date-picker-portal-preset>x-link:not(:first-child){margin-left:1rem}.x-date-picker-portal-body{padding:.4rem}.x-date-picker-portal-content{display:flex}.x-date-picker-portal-footer{display:flex;align-items:center;justify-content:space-between;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-footer .x-date-picker-portal-preset{border-top:none}.x-date-picker-portal-footer .x-date-picker-portal-preset>x-link{padding:0 .25rem}.x-date-picker-portal-extra-footer{display:flex;align-items:center;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-picker-portal-date{flex:1}.x-date-picker-portal-time{display:flex;flex-direction:column;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time-label{display:flex;align-items:center;justify-content:center;padding:0 .5rem;height:2.5rem;border-bottom:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-picker-portal-time .x-time-picker-frame{border-width:0;box-shadow:none;margin:0}\n"] }]
|
|
167
179
|
}], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i1.LowerCasePipe }, { type: i0.ChangeDetectorRef }, { type: i2.XI18nService }]; }, propDecorators: { placement: [{
|
|
168
180
|
type: HostBinding,
|
|
169
181
|
args: ['@x-connect-base-animation']
|
|
@@ -177,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImpor
|
|
|
177
189
|
type: ViewChild,
|
|
178
190
|
args: ['timePickerFrame']
|
|
179
191
|
}] } });
|
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-picker-portal.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-picker-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  OnInit,\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  HostBinding,\r\n  HostListener,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {\r\n  XDatePickerDisabledDate,\r\n  XDatePickerDisabledTime,\r\n  XDatePickerPortalPrefix,\r\n  XDatePickerPreset,\r\n  XDatePickerType\r\n} from './date-picker.property';\r\nimport { XIsEmpty, XConnectBaseAnimation, XPositionTopBottom, XAddDays, XTemplate, XIsUndefined } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, map } from 'rxjs/operators';\r\nimport { DatePipe, LowerCasePipe } from '@angular/common';\r\nimport { XI18nService, XI18nDatePicker } from '@ng-nest/ui/i18n';\r\nimport { XInputComponent } from '@ng-nest/ui/input';\r\nimport { XTimePickerFrameComponent } from '@ng-nest/ui/time-picker';\r\n\r\n@Component({\r\n  selector: `${XDatePickerPortalPrefix}`,\r\n  templateUrl: './date-picker-portal.component.html',\r\n  styleUrls: ['./date-picker-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XConnectBaseAnimation],\r\n  providers: [DatePipe, LowerCasePipe]\r\n})\r\nexport class XDatePickerPortalComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  @HostBinding('@x-connect-base-animation') public placement!: XPositionTopBottom;\r\n  @HostListener('@x-connect-base-animation.done', ['$event']) done(event: { toState: any }) {\r\n    this.animating(false);\r\n    event.toState === 'void' && this.destroyPortal();\r\n  }\r\n  @HostListener('@x-connect-base-animation.start', ['$event']) start() {\r\n    this.animating(true);\r\n  }\r\n\r\n  @ViewChild('timePickerFrame') timePickerFrame?: XTimePickerFrameComponent;\r\n\r\n  type: XDatePickerType = 'date';\r\n  display = new Date();\r\n  model!: Date;\r\n  value: any;\r\n  valueChange!: Subject<any>;\r\n  positionChange!: Subject<any>;\r\n  animating!: Function;\r\n  closePortal!: Function;\r\n  destroyPortal!: Function;\r\n  nodeEmit!: (date: Date, sure?: boolean) => void;\r\n  locale: XI18nDatePicker = {};\r\n  time!: number | null;\r\n  preset: XDatePickerPreset[] = [];\r\n  extraFooter?: XTemplate;\r\n  inputCom!: XInputComponent;\r\n  disabledDate!: XDatePickerDisabledDate;\r\n  disabledTime!: XDatePickerDisabledTime;\r\n  private _type!: XDatePickerType;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  get isDatePicker() {\r\n    return ['date', 'month', 'year'].includes(this.type);\r\n  }\r\n\r\n  get sureDisabled() {\r\n    let res = XIsUndefined(this.time);\r\n    if (this.timePickerFrame && !XIsUndefined(this.time)) {\r\n      const dt = new Date(this.time!);\r\n      const hours = dt.getHours();\r\n      const minutes = dt.getMinutes();\r\n      const seconds = dt.getSeconds();\r\n      return (\r\n        this.timePickerFrame.setDisabled('hours', hours) ||\r\n        this.timePickerFrame.setDisabled('minutes', minutes) ||\r\n        this.timePickerFrame.setDisabled('seconds', seconds)\r\n      );\r\n    }\r\n    return res;\r\n  }\r\n\r\n  constructor(public datePipe: DatePipe, public lowerCasePipe: LowerCasePipe, public cdr: ChangeDetectorRef, public i18n: XI18nService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.valueChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.value = x;\r\n      this.init();\r\n    });\r\n    this.positionChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.placement = x;\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.datePicker as XI18nDatePicker),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.init();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  init() {\r\n    if (!XIsEmpty(this.value)) {\r\n      this.setDefault();\r\n    }\r\n    this._type = this.type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  stopPropagation(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  setDefault() {\r\n    const date = new Date(this.value);\r\n    this.model = date;\r\n    this.time = this.model.getTime();\r\n    this.setDisplay(this.model);\r\n  }\r\n\r\n  setDisplay(date: Date) {\r\n    this.display = new Date(date.getFullYear(), date.getMonth(), 1);\r\n  }\r\n\r\n  dateChange(date: Date) {\r\n    this.setDisplay(date);\r\n    this.model = date;\r\n    if (['date-time', 'date-hour', 'date-minute'].includes(this._type)) {\r\n      let time = new Date();\r\n      if (['date-hour', 'date-minute'].includes(this.type)) {\r\n        time.setSeconds(0);\r\n      }\r\n      if (this.type === 'date-hour') {\r\n        time.setMinutes(0);\r\n      }\r\n      if (!this.time) {\r\n        this.time = time.getTime();\r\n      }\r\n      this.setModelTime(this.model, new Date(this.time!));\r\n      this.nodeEmit(this.model, false);\r\n    } else {\r\n      this.nodeEmit(this.model);\r\n    }\r\n  }\r\n\r\n  monthChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'month') {\r\n      this.model = date;\r\n      this.nodeEmit(date);\r\n    } else {\r\n      this.type = this._type;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'year') {\r\n      this.model = date;\r\n      this.nodeEmit(date);\r\n    } else {\r\n      this.type = 'month';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onToday() {\r\n    this.dateChange(new Date());\r\n  }\r\n\r\n  onYesterday() {\r\n    this.dateChange(XAddDays(new Date(), -1));\r\n  }\r\n\r\n  onTomorrow() {\r\n    this.dateChange(XAddDays(new Date(), 1));\r\n  }\r\n\r\n  onPresetFunc(item: XDatePickerPreset) {\r\n    this.dateChange(item.func());\r\n  }\r\n\r\n  selectTime(time: Date) {\r\n    if (!this.model) {\r\n      this.model = new Date();\r\n    }\r\n    this.time = time.getTime();\r\n    this.nodeEmit(this.setModelTime(this.model, time), false);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setModelTime(date: Date, time: Date) {\r\n    this.model = new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes(), time.getSeconds());\r\n    return this.model;\r\n  }\r\n}\r\n","<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n  <ng-container *ngSwitchCase=\"'date'\">\r\n    <x-picker-date\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"dateChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-date>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'week'\">\r\n    <x-picker-date\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"dateChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-date>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'month'\">\r\n    <x-picker-month\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"monthChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-month>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'year'\">\r\n    <x-picker-year\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"yearChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-year>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'date-time'\">\r\n    <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'date-hour'\">\r\n    <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'date-minute'\">\r\n    <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n  </ng-container>\r\n  <ng-container *ngIf=\"isDatePicker\">\r\n    <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n      <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n    </div>\r\n    <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n  </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n  <div class=\"x-date-picker-portal-content\">\r\n    <div class=\"x-date-picker-portal-date\">\r\n      <x-picker-date\r\n        [display]=\"display\"\r\n        [(type)]=\"type\"\r\n        [model]=\"model\"\r\n        (modelChange)=\"dateChange($event)\"\r\n        [disabledDate]=\"disabledDate\"\r\n      ></x-picker-date>\r\n    </div>\r\n    <div class=\"x-date-picker-portal-time\">\r\n      <div class=\"x-date-picker-portal-time-label\">\r\n        {{ time | date : timeFormat }}\r\n      </div>\r\n      <x-time-picker-frame\r\n        #timePickerFrame\r\n        [type]=\"timeType\"\r\n        [value]=\"time\"\r\n        (nodeEmit)=\"selectTime($event)\"\r\n        [disabledTime]=\"disabledTime\"\r\n        [defaultNow]=\"false\"\r\n      ></x-time-picker-frame>\r\n    </div>\r\n  </div>\r\n  <ng-container *ngIf=\"!isDatePicker\">\r\n    <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n      <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n    </div>\r\n  </ng-container>\r\n  <div class=\"x-date-picker-portal-footer\">\r\n    <div class=\"x-date-picker-portal-footer-left\">\r\n      <ng-container *ngIf=\"!isDatePicker\">\r\n        <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n      </ng-container>\r\n    </div>\r\n    <x-button type=\"primary\" (click)=\"!sureDisabled && nodeEmit(model)\" size=\"small\" [disabled]=\"sureDisabled\">{{ locale.sure }}</x-button>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #presetTpl>\r\n  <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n    <ng-container *ngFor=\"let item of preset\">\r\n      <x-link *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-link>\r\n      <x-link *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-link>\r\n      <x-link *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-link>\r\n      <x-link *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-link>\r\n    </ng-container>\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-picker-portal.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-picker-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  OnInit,\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  HostBinding,\r\n  HostListener,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {\r\n  XDatePickerDisabledDate,\r\n  XDatePickerDisabledTime,\r\n  XDatePickerPortalPrefix,\r\n  XDatePickerPreset,\r\n  XDatePickerType\r\n} from './date-picker.property';\r\nimport { XIsEmpty, XConnectBaseAnimation, XPositionTopBottom, XAddDays, XTemplate, XIsUndefined } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, map } from 'rxjs/operators';\r\nimport { DatePipe, LowerCasePipe } from '@angular/common';\r\nimport { XI18nService, XI18nDatePicker } from '@ng-nest/ui/i18n';\r\nimport { XInputComponent } from '@ng-nest/ui/input';\r\nimport { XTimePickerFrameComponent } from '@ng-nest/ui/time-picker';\r\n\r\n@Component({\r\n  selector: `${XDatePickerPortalPrefix}`,\r\n  templateUrl: './date-picker-portal.component.html',\r\n  styleUrls: ['./date-picker-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XConnectBaseAnimation],\r\n  providers: [DatePipe, LowerCasePipe]\r\n})\r\nexport class XDatePickerPortalComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  @HostBinding('@x-connect-base-animation') public placement!: XPositionTopBottom;\r\n  @HostListener('@x-connect-base-animation.done', ['$event']) done(event: { toState: any }) {\r\n    this.animating(false);\r\n    event.toState === 'void' && this.destroyPortal();\r\n  }\r\n  @HostListener('@x-connect-base-animation.start', ['$event']) start() {\r\n    this.animating(true);\r\n  }\r\n\r\n  @ViewChild('timePickerFrame') timePickerFrame?: XTimePickerFrameComponent;\r\n\r\n  type: XDatePickerType = 'date';\r\n  display = new Date();\r\n  model!: Date;\r\n  value: any;\r\n  valueChange!: Subject<any>;\r\n  positionChange!: Subject<any>;\r\n  animating!: Function;\r\n  closePortal!: Function;\r\n  destroyPortal!: Function;\r\n  nodeEmit!: (date: Date, sure?: boolean) => void;\r\n  locale: XI18nDatePicker = {};\r\n  time!: number | null;\r\n  preset: XDatePickerPreset[] = [];\r\n  extraFooter?: XTemplate;\r\n  inputCom!: XInputComponent;\r\n  disabledDate!: XDatePickerDisabledDate;\r\n  disabledTime!: XDatePickerDisabledTime;\r\n  private _type!: XDatePickerType;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  get isDatePicker() {\r\n    return ['date', 'month', 'year'].includes(this.type);\r\n  }\r\n\r\n  get sureDisabled() {\r\n    let res = XIsUndefined(this.time);\r\n    if (this.timePickerFrame && !XIsUndefined(this.time)) {\r\n      const dt = new Date(this.time!);\r\n      const hours = dt.getHours();\r\n      const minutes = dt.getMinutes();\r\n      const seconds = dt.getSeconds();\r\n      return (\r\n        this.timePickerFrame.setDisabled('hours', hours) ||\r\n        this.timePickerFrame.setDisabled('minutes', minutes) ||\r\n        this.timePickerFrame.setDisabled('seconds', seconds)\r\n      );\r\n    }\r\n    return res;\r\n  }\r\n\r\n  constructor(public datePipe: DatePipe, public lowerCasePipe: LowerCasePipe, public cdr: ChangeDetectorRef, public i18n: XI18nService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.valueChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.value = x;\r\n      this.init();\r\n    });\r\n    this.positionChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.placement = x;\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.datePicker as XI18nDatePicker),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.init();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  init() {\r\n    if (!XIsEmpty(this.value)) {\r\n      this.setDefault();\r\n    }\r\n    this._type = this.type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  stopPropagation(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  setDefault() {\r\n    const date = new Date(this.value);\r\n    this.model = date;\r\n    this.time = this.model.getTime();\r\n    this.setDisplay(this.model);\r\n  }\r\n\r\n  setDisplay(date: Date) {\r\n    this.display = new Date(date.getFullYear(), date.getMonth(), 1);\r\n  }\r\n\r\n  dateChange(date: Date) {\r\n    this.setDisplay(date);\r\n    this.model = date;\r\n    if (['date-time', 'date-hour', 'date-minute'].includes(this._type)) {\r\n      let time = new Date();\r\n      if (['date-hour', 'date-minute'].includes(this.type)) {\r\n        time.setSeconds(0);\r\n      }\r\n      if (this.type === 'date-hour') {\r\n        time.setMinutes(0);\r\n      }\r\n      if (!this.time) {\r\n        this.time = time.getTime();\r\n      }\r\n      this.setModelTime(this.model, new Date(this.time!));\r\n      this.nodeEmit(this.model, false);\r\n    } else {\r\n      this.nodeEmit(this.model);\r\n    }\r\n  }\r\n\r\n  monthChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'month') {\r\n      this.model = date;\r\n      this.nodeEmit(date);\r\n    } else {\r\n      this.type = this._type;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  quarterChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'quarter') {\r\n      this.model = date;\r\n      this.nodeEmit(date);\r\n    } else {\r\n      this.type = this._type;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'year') {\r\n      this.model = date;\r\n      this.nodeEmit(date);\r\n    } else {\r\n      this.type = 'month';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onToday() {\r\n    this.dateChange(new Date());\r\n  }\r\n\r\n  onYesterday() {\r\n    this.dateChange(XAddDays(new Date(), -1));\r\n  }\r\n\r\n  onTomorrow() {\r\n    this.dateChange(XAddDays(new Date(), 1));\r\n  }\r\n\r\n  onPresetFunc(item: XDatePickerPreset) {\r\n    this.dateChange(item.func());\r\n  }\r\n\r\n  selectTime(time: Date) {\r\n    if (!this.model) {\r\n      this.model = new Date();\r\n    }\r\n    this.time = time.getTime();\r\n    this.nodeEmit(this.setModelTime(this.model, time), false);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setModelTime(date: Date, time: Date) {\r\n    this.model = new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes(), time.getSeconds());\r\n    return this.model;\r\n  }\r\n}\r\n","<div class=\"x-date-picker-portal {{ type }}\" [ngSwitch]=\"type\" (click)=\"inputCom.inputFocus()\">\r\n  <ng-container *ngSwitchCase=\"'date'\">\r\n    <x-picker-date\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"dateChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-date>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'week'\">\r\n    <x-picker-date\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"dateChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-date>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'month'\">\r\n    <x-picker-month\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"monthChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-month>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'quarter'\">\r\n    <x-picker-quarter\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"quarterChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-quarter>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'year'\">\r\n    <x-picker-year\r\n      [display]=\"display\"\r\n      [model]=\"model\"\r\n      [(type)]=\"type\"\r\n      (modelChange)=\"yearChange($event)\"\r\n      [disabledDate]=\"disabledDate\"\r\n    ></x-picker-year>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'date-time'\">\r\n    <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm:ss', timeType: 'time' }\"></ng-container>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'date-hour'\">\r\n    <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH', timeType: 'hour' }\"></ng-container>\r\n  </ng-container>\r\n  <ng-container *ngSwitchCase=\"'date-minute'\">\r\n    <ng-container *ngTemplateOutlet=\"dateTimeHourMinuteTpl; context: { timeFormat: 'HH:mm', timeType: 'minute' }\"></ng-container>\r\n  </ng-container>\r\n  <ng-container *ngIf=\"isDatePicker\">\r\n    <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n      <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n    </div>\r\n    <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n  </ng-container>\r\n</div>\r\n\r\n<ng-template #dateTimeHourMinuteTpl let-timeFormat=\"timeFormat\" let-timeType=\"timeType\">\r\n  <div class=\"x-date-picker-portal-content\">\r\n    <div class=\"x-date-picker-portal-date\">\r\n      <x-picker-date\r\n        [display]=\"display\"\r\n        [(type)]=\"type\"\r\n        [model]=\"model\"\r\n        (modelChange)=\"dateChange($event)\"\r\n        [disabledDate]=\"disabledDate\"\r\n      ></x-picker-date>\r\n    </div>\r\n    <div class=\"x-date-picker-portal-time\">\r\n      <div class=\"x-date-picker-portal-time-label\">\r\n        {{ time | date : timeFormat }}\r\n      </div>\r\n      <x-time-picker-frame\r\n        #timePickerFrame\r\n        [type]=\"timeType\"\r\n        [value]=\"time\"\r\n        (nodeEmit)=\"selectTime($event)\"\r\n        [disabledTime]=\"disabledTime\"\r\n        [defaultNow]=\"false\"\r\n      ></x-time-picker-frame>\r\n    </div>\r\n  </div>\r\n  <ng-container *ngIf=\"!isDatePicker\">\r\n    <div *ngIf=\"extraFooter\" class=\"x-date-picker-portal-extra-footer\">\r\n      <ng-container *xOutlet=\"extraFooter\">{{ extraFooter }}</ng-container>\r\n    </div>\r\n  </ng-container>\r\n  <div class=\"x-date-picker-portal-footer\">\r\n    <div class=\"x-date-picker-portal-footer-left\">\r\n      <ng-container *ngIf=\"!isDatePicker\">\r\n        <ng-container *ngTemplateOutlet=\"presetTpl\"></ng-container>\r\n      </ng-container>\r\n    </div>\r\n    <x-button type=\"primary\" (click)=\"!sureDisabled && nodeEmit(model)\" size=\"small\" [disabled]=\"sureDisabled\">{{ locale.sure }}</x-button>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #presetTpl>\r\n  <div *ngIf=\"preset\" class=\"x-date-picker-portal-preset\">\r\n    <ng-container *ngFor=\"let item of preset\">\r\n      <x-link *ngIf=\"item.id === 'yesterday'\" (click)=\"onYesterday()\">{{ locale.yesterday }}</x-link>\r\n      <x-link *ngIf=\"item.id === 'today'\" (click)=\"onToday()\">{{ locale.today }}</x-link>\r\n      <x-link *ngIf=\"item.id === 'tomorrow'\" (click)=\"onTomorrow()\">{{ locale.tomorrow }}</x-link>\r\n      <x-link *ngIf=\"item.func\" (click)=\"onPresetFunc(item)\">{{ item.label }}</x-link>\r\n    </ng-container>\r\n  </div>\r\n</ng-template>\r\n"]}
|