ngx-tethys 14.2.13 → 14.2.14
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/CHANGELOG.md +16 -0
- package/date-picker/styles/calendar.scss +0 -7
- package/date-picker/styles/month-panel.scss +10 -0
- package/date-picker/styles/week-picker.scss +29 -8
- package/date-picker/styles/year-panel.scss +17 -0
- package/esm2020/color-picker/parts/inputs/inputs.component.mjs +1 -1
- package/esm2020/date-picker/base-picker.component.mjs +2 -2
- package/esm2020/date-picker/lib/date/date-table.component.mjs +4 -4
- package/esm2020/date-picker/lib/popups/inner-popup.component.mjs +1 -1
- package/esm2020/date-picker/lib/year/year-table.component.mjs +3 -2
- package/esm2020/date-picker/picker.component.mjs +1 -1
- package/esm2020/input/input-search.component.mjs +1 -1
- package/esm2020/input/input.component.mjs +1 -1
- package/esm2020/input/input.directive.mjs +3 -3
- package/esm2020/input-number/input-number.component.mjs +1 -1
- package/esm2020/select/select.component.mjs +1 -1
- package/esm2020/time-picker/time-picker.component.mjs +1 -1
- package/esm2020/upload/file-drop.directive.mjs +8 -9
- package/esm2020/version.mjs +2 -2
- package/fesm2015/ngx-tethys-color-picker.mjs +1 -1
- package/fesm2015/ngx-tethys-color-picker.mjs.map +1 -1
- package/fesm2015/ngx-tethys-date-picker.mjs +8 -7
- package/fesm2015/ngx-tethys-date-picker.mjs.map +1 -1
- package/fesm2015/ngx-tethys-input-number.mjs +1 -1
- package/fesm2015/ngx-tethys-input-number.mjs.map +1 -1
- package/fesm2015/ngx-tethys-input.mjs +4 -4
- package/fesm2015/ngx-tethys-input.mjs.map +1 -1
- package/fesm2015/ngx-tethys-select.mjs +1 -1
- package/fesm2015/ngx-tethys-select.mjs.map +1 -1
- package/fesm2015/ngx-tethys-time-picker.mjs +1 -1
- package/fesm2015/ngx-tethys-time-picker.mjs.map +1 -1
- package/fesm2015/ngx-tethys-upload.mjs +6 -7
- package/fesm2015/ngx-tethys-upload.mjs.map +1 -1
- package/fesm2015/ngx-tethys.mjs +1 -1
- package/fesm2015/ngx-tethys.mjs.map +1 -1
- package/fesm2020/ngx-tethys-color-picker.mjs +1 -1
- package/fesm2020/ngx-tethys-color-picker.mjs.map +1 -1
- package/fesm2020/ngx-tethys-date-picker.mjs +8 -7
- package/fesm2020/ngx-tethys-date-picker.mjs.map +1 -1
- package/fesm2020/ngx-tethys-input-number.mjs +1 -1
- package/fesm2020/ngx-tethys-input-number.mjs.map +1 -1
- package/fesm2020/ngx-tethys-input.mjs +4 -4
- package/fesm2020/ngx-tethys-input.mjs.map +1 -1
- package/fesm2020/ngx-tethys-select.mjs +1 -1
- package/fesm2020/ngx-tethys-select.mjs.map +1 -1
- package/fesm2020/ngx-tethys-time-picker.mjs +1 -1
- package/fesm2020/ngx-tethys-time-picker.mjs.map +1 -1
- package/fesm2020/ngx-tethys-upload.mjs +6 -7
- package/fesm2020/ngx-tethys-upload.mjs.map +1 -1
- package/fesm2020/ngx-tethys.mjs +1 -1
- package/fesm2020/ngx-tethys.mjs.map +1 -1
- package/input/input.directive.d.ts +1 -1
- package/package.json +1 -1
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
- package/shared/option/styles/option.mixin.scss +4 -0
- package/upload/file-drop.directive.d.ts +3 -3
- package/watermark/examples/basic/basic.component.scss +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,22 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
## [14.2.14](https://github.com/atinc/ngx-tethys/compare/14.2.13...14.2.14) (2023-01-20)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
* **DatePicker:** update year、week range style #INFR-6159 ([#2488](https://github.com/atinc/ngx-tethys/issues/2488)) ([e7d7845](https://github.com/atinc/ngx-tethys/commit/e7d7845c9131400d55bd8da9100c4fa34e8e6b6d)), closes [#INFR-6159](https://github.com/atinc/ngx-tethys/issues/INFR-6159)
|
|
11
|
+
* **tree-select:** fix prefix icon color of multiple option list of tree-select(#INFR-6234) ([#2495](https://github.com/atinc/ngx-tethys/issues/2495)) ([82ca864](https://github.com/atinc/ngx-tethys/commit/82ca86402263d90c832c9ecd5b8a28e7962bd0e9)), closes [#INFR-6234](https://github.com/atinc/ngx-tethys/issues/INFR-6234)
|
|
12
|
+
* **Upload:** fix NG0203 error for inject() #INFR-6222 ([d89aff9](https://github.com/atinc/ngx-tethys/commit/d89aff9c8f7cc43e38b51d819449fa6285457074)), closes [#INFR-6222](https://github.com/atinc/ngx-tethys/issues/INFR-6222)
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
### Features
|
|
16
|
+
|
|
17
|
+
* **input:** add textarea[thyInput] selector to ThyInputDirective ([e0c593d](https://github.com/atinc/ngx-tethys/commit/e0c593d9c319c5f955ed33853f334534cc6b20f0))
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
5
21
|
## [14.2.13](https://github.com/atinc/ngx-tethys/compare/14.2.12...14.2.13) (2023-01-16)
|
|
6
22
|
|
|
7
23
|
|
|
@@ -72,12 +72,6 @@
|
|
|
72
72
|
}
|
|
73
73
|
}
|
|
74
74
|
|
|
75
|
-
&-week-number-header {
|
|
76
|
-
.#{style.$calendar-prefix-cls}-column-header-inner {
|
|
77
|
-
display: none;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
|
|
81
75
|
&-cell {
|
|
82
76
|
height: 30px;
|
|
83
77
|
padding: 1px 0;
|
|
@@ -96,7 +90,6 @@
|
|
|
96
90
|
border: style.$border-width-base style.$border-style-base transparent;
|
|
97
91
|
border-radius: variables.$border-radius-lg;
|
|
98
92
|
transition: background 0.3s ease;
|
|
99
|
-
|
|
100
93
|
&-panel {
|
|
101
94
|
position: relative;
|
|
102
95
|
outline: none;
|
|
@@ -8,6 +8,16 @@
|
|
|
8
8
|
table-layout: fixed;
|
|
9
9
|
border-collapse: separate;
|
|
10
10
|
.#{style.$calendar-prefix-cls}-in-range-cell {
|
|
11
|
+
&:first-child {
|
|
12
|
+
&::before {
|
|
13
|
+
left: 14px;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
&:last-child {
|
|
17
|
+
&::before {
|
|
18
|
+
right: 14px;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
11
21
|
&::before {
|
|
12
22
|
height: 30px;
|
|
13
23
|
top: 11px;
|
|
@@ -5,20 +5,41 @@
|
|
|
5
5
|
&-cell {
|
|
6
6
|
opacity: 0.5;
|
|
7
7
|
}
|
|
8
|
-
.#{style.$calendar-prefix-cls}-
|
|
8
|
+
.#{style.$calendar-prefix-cls}-tbody tr {
|
|
9
9
|
cursor: pointer;
|
|
10
10
|
transition: all 0.3s;
|
|
11
|
+
position: sticky;
|
|
12
|
+
&::after {
|
|
13
|
+
content: '';
|
|
14
|
+
position: absolute;
|
|
15
|
+
left: 29.25px;
|
|
16
|
+
right: 0;
|
|
17
|
+
top: 3px;
|
|
18
|
+
border-radius: variables.$border-radius-lg;
|
|
19
|
+
height: 24px;
|
|
20
|
+
z-index: -1;
|
|
21
|
+
opacity: 0;
|
|
22
|
+
}
|
|
11
23
|
&:hover {
|
|
12
|
-
|
|
24
|
+
&::after {
|
|
25
|
+
background: variables.$gray-100;
|
|
26
|
+
opacity: 1;
|
|
27
|
+
}
|
|
13
28
|
}
|
|
14
29
|
&.#{style.$calendar-prefix-cls}-active-week {
|
|
15
|
-
|
|
16
|
-
|
|
30
|
+
.#{style.$calendar-prefix-cls}-date {
|
|
31
|
+
color: variables.$white;
|
|
32
|
+
}
|
|
33
|
+
&::after {
|
|
34
|
+
background: variables.$primary;
|
|
35
|
+
opacity: 1;
|
|
36
|
+
}
|
|
17
37
|
}
|
|
18
|
-
|
|
19
|
-
.#{style.$calendar-prefix-cls}-
|
|
20
|
-
|
|
21
|
-
|
|
38
|
+
|
|
39
|
+
.#{style.$calendar-prefix-cls}-date {
|
|
40
|
+
&:hover {
|
|
41
|
+
background: none;
|
|
42
|
+
}
|
|
22
43
|
}
|
|
23
44
|
}
|
|
24
45
|
}
|
|
@@ -42,6 +42,23 @@
|
|
|
42
42
|
height: 100%;
|
|
43
43
|
table-layout: fixed;
|
|
44
44
|
border-collapse: separate;
|
|
45
|
+
tr {
|
|
46
|
+
.#{style.$calendar-prefix-cls}-in-range-cell {
|
|
47
|
+
&:first-child {
|
|
48
|
+
&::before {
|
|
49
|
+
left: 14px;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
&:last-child {
|
|
53
|
+
&::before {
|
|
54
|
+
right: 14px;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
&::before {
|
|
58
|
+
top: 14px;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
45
62
|
}
|
|
46
63
|
|
|
47
64
|
.#{style.$calendar-prefix-cls}-year-panel-cell {
|
|
@@ -35,7 +35,7 @@ export class ThyColorInputsComponent {
|
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
37
|
ThyColorInputsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyColorInputsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
38
|
-
ThyColorInputsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyColorInputsComponent, selector: "thy-color-inputs", inputs: { color: "color" }, outputs: { colorChange: "colorChange" }, host: { properties: { "class.thy-color-inputs": "this.className" } }, ngImport: i0, template: "<div class=\"hex-column\">\n <input\n #elRef\n thySize=\"xs\"\n class=\"px-0 text-center\"\n thyInput\n [(ngModel)]=\"color.displayValue\"\n (blur)=\"onInputChange($event, 'hex')\"\n (thyEnter)=\"onInputChange($event, 'hex')\"\n />\n <span>HEX</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.red\"\n (thyBlur)=\"onInputChange($event, 'R')\"\n (thyEnter)=\"onInputChange($event, 'R')\"\n ></thy-input-number>\n <span>R</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.green\"\n (thyBlur)=\"onInputChange($event, 'G')\"\n (thyEnter)=\"onInputChange($event, 'G')\"\n ></thy-input-number>\n <span>G</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.blue\"\n (thyBlur)=\"onInputChange($event, 'B')\"\n (thyEnter)=\"onInputChange($event, 'B')\"\n ></thy-input-number>\n <span>B</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n [thyMin]=\"0\"\n [thyMax]=\"100\"\n thySize=\"xs\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"alpha\"\n (thyBlur)=\"onInputChange($event, 'A')\"\n (thyEnter)=\"onInputChange($event, 'A')\"\n ></thy-input-number>\n <span>A</span>\n</div>\n", dependencies: [{ kind: "directive", type: i1.ThyInputDirective, selector: "input[thyInput], select[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ThyInputNumberComponent, selector: "thy-input-number", inputs: ["thyAutoFocus", "thyPlaceholder", "thyDisabled", "thyMax", "thyMin", "thyStep", "thySize", "thyPrecision", "thySuffix"], outputs: ["thyBlur", "thyFocus"] }, { kind: "directive", type: i4.ThyEnterDirective, selector: "[thyEnter]", outputs: ["thyEnter"] }] });
|
|
38
|
+
ThyColorInputsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyColorInputsComponent, selector: "thy-color-inputs", inputs: { color: "color" }, outputs: { colorChange: "colorChange" }, host: { properties: { "class.thy-color-inputs": "this.className" } }, ngImport: i0, template: "<div class=\"hex-column\">\n <input\n #elRef\n thySize=\"xs\"\n class=\"px-0 text-center\"\n thyInput\n [(ngModel)]=\"color.displayValue\"\n (blur)=\"onInputChange($event, 'hex')\"\n (thyEnter)=\"onInputChange($event, 'hex')\"\n />\n <span>HEX</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.red\"\n (thyBlur)=\"onInputChange($event, 'R')\"\n (thyEnter)=\"onInputChange($event, 'R')\"\n ></thy-input-number>\n <span>R</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.green\"\n (thyBlur)=\"onInputChange($event, 'G')\"\n (thyEnter)=\"onInputChange($event, 'G')\"\n ></thy-input-number>\n <span>G</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.blue\"\n (thyBlur)=\"onInputChange($event, 'B')\"\n (thyEnter)=\"onInputChange($event, 'B')\"\n ></thy-input-number>\n <span>B</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n [thyMin]=\"0\"\n [thyMax]=\"100\"\n thySize=\"xs\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"alpha\"\n (thyBlur)=\"onInputChange($event, 'A')\"\n (thyEnter)=\"onInputChange($event, 'A')\"\n ></thy-input-number>\n <span>A</span>\n</div>\n", dependencies: [{ kind: "directive", type: i1.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ThyInputNumberComponent, selector: "thy-input-number", inputs: ["thyAutoFocus", "thyPlaceholder", "thyDisabled", "thyMax", "thyMin", "thyStep", "thySize", "thyPrecision", "thySuffix"], outputs: ["thyBlur", "thyFocus"] }, { kind: "directive", type: i4.ThyEnterDirective, selector: "[thyEnter]", outputs: ["thyEnter"] }] });
|
|
39
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyColorInputsComponent, decorators: [{
|
|
40
40
|
type: Component,
|
|
41
41
|
args: [{ selector: 'thy-color-inputs', template: "<div class=\"hex-column\">\n <input\n #elRef\n thySize=\"xs\"\n class=\"px-0 text-center\"\n thyInput\n [(ngModel)]=\"color.displayValue\"\n (blur)=\"onInputChange($event, 'hex')\"\n (thyEnter)=\"onInputChange($event, 'hex')\"\n />\n <span>HEX</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.red\"\n (thyBlur)=\"onInputChange($event, 'R')\"\n (thyEnter)=\"onInputChange($event, 'R')\"\n ></thy-input-number>\n <span>R</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.green\"\n (thyBlur)=\"onInputChange($event, 'G')\"\n (thyEnter)=\"onInputChange($event, 'G')\"\n ></thy-input-number>\n <span>G</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.blue\"\n (thyBlur)=\"onInputChange($event, 'B')\"\n (thyEnter)=\"onInputChange($event, 'B')\"\n ></thy-input-number>\n <span>B</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n [thyMin]=\"0\"\n [thyMax]=\"100\"\n thySize=\"xs\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"alpha\"\n (thyBlur)=\"onInputChange($event, 'A')\"\n (thyEnter)=\"onInputChange($event, 'A')\"\n ></thy-input-number>\n <span>A</span>\n</div>\n" }]
|
|
@@ -44,7 +44,7 @@ export class BasePickerComponent extends AbstractPickerComponent {
|
|
|
44
44
|
const inputFormats = {
|
|
45
45
|
year: 'yyyy',
|
|
46
46
|
month: 'yyyy-MM',
|
|
47
|
-
week: 'yyyy-ww',
|
|
47
|
+
week: 'yyyy-ww周',
|
|
48
48
|
date: this.thyShowTime ? 'yyyy-MM-dd HH:mm' : 'yyyy-MM-dd'
|
|
49
49
|
};
|
|
50
50
|
this.thyFormat = this.flexible ? inputFormats['date'] : inputFormats[this.thyMode];
|
|
@@ -112,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
112
112
|
}], thyOnOk: [{
|
|
113
113
|
type: Output
|
|
114
114
|
}] } });
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-picker.component.js","sourceRoot":"","sources":["../../../../src/date-picker/base-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ThyPlacement } from 'ngx-tethys/core';\nimport { coerceBooleanProperty, FunctionProp, TinyDate } from 'ngx-tethys/util';\n\nimport { ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, TemplateRef } from '@angular/core';\n\nimport { AbstractPickerComponent } from './abstract-picker.component';\nimport { CompatibleDate, ThyPanelMode } from './standard-types';\nimport { CompatibleValue, RangeAdvancedValue } from './inner-types';\n\n@Component({\n    template: ``\n})\nexport class BasePickerComponent extends AbstractPickerComponent implements OnInit, OnChanges {\n    showWeek = false;\n\n    panelMode: ThyPanelMode | ThyPanelMode[];\n\n    @Input() thyDateRender: FunctionProp<TemplateRef<Date> | string>;\n\n    @Output() readonly thyOnPanelChange = new EventEmitter<ThyPanelMode | ThyPanelMode[]>();\n    @Output() readonly thyOnCalendarChange = new EventEmitter<Date[]>();\n\n    private _showTime: object | boolean;\n    @Input() get thyShowTime(): object | boolean {\n        return this._showTime;\n    }\n    set thyShowTime(value: object | boolean) {\n        this._showTime = typeof value === 'object' ? value : coerceBooleanProperty(value);\n    }\n\n    @Input() thyMustShowTime = false;\n\n    @Input() thyPlacement: ThyPlacement = 'bottomLeft';\n\n    @Output() readonly thyOnOk = new EventEmitter<CompatibleDate | null>();\n\n    constructor(cdr: ChangeDetectorRef) {\n        super(cdr);\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.setDefaultTimePickerState();\n    }\n\n    onValueChange(value: CompatibleValue | RangeAdvancedValue): void {\n        this.restoreTimePickerState(value as CompatibleValue);\n        super.onValueChange(value);\n        if (!this.flexible) {\n            this.closeOverlay();\n        }\n    }\n\n    // Displays the time directly when the time must be displayed by default\n    setDefaultTimePickerState() {\n        this.thyMode = this.thyMode || 'date';\n        this.withTime = this.thyMustShowTime;\n        if (this.isRange) {\n            this.panelMode = this.flexible ? ['date', 'date'] : [this.thyMode, this.thyMode];\n        } else {\n            this.panelMode = this.thyMode;\n        }\n        this.showWeek = this.thyMode === 'week';\n        if (!this.thyFormat) {\n            const inputFormats: { [key in ThyPanelMode]?: string } = {\n                year: 'yyyy',\n                month: 'yyyy-MM',\n                week: 'yyyy-ww周',\n                date: this.thyShowTime ? 'yyyy-MM-dd HH:mm' : 'yyyy-MM-dd'\n            };\n            this.thyFormat = this.flexible ? inputFormats['date'] : inputFormats[this.thyMode];\n        }\n    }\n\n    // Restore after clearing time to select whether the original picker time is displayed or not\n    restoreTimePickerState(value: CompatibleValue | null) {\n        if (!value) {\n            this.withTime = this.thyMustShowTime || this.originWithTime;\n        }\n    }\n\n    // Emit thyOnCalendarChange when select date by thy-range-picker\n    onCalendarChange(value: TinyDate[]): void {\n        if (this.isRange) {\n            const rangeValue = value.map(x => x.nativeDate);\n            this.thyOnCalendarChange.emit(rangeValue);\n        }\n    }\n\n    onShowTimePickerChange(show: boolean): void {\n        this.withTime = show;\n    }\n\n    onResultOk(): void {\n        if (this.isRange) {\n            const value = this.thyValue as TinyDate[];\n            if (value.length) {\n                this.thyOnOk.emit([value[0].nativeDate, value[1].nativeDate]);\n            } else {\n                this.thyOnOk.emit([]);\n            }\n        } else {\n            if (this.thyValue) {\n                this.thyOnOk.emit((this.thyValue as TinyDate).nativeDate);\n            } else {\n                this.thyOnOk.emit(null);\n            }\n        }\n        this.closeOverlay();\n    }\n\n    onOpenChange(open: boolean): void {\n        this.thyOpenChange.emit(open);\n    }\n}\n"]}
|
|
@@ -92,7 +92,7 @@ export class DateTableComponent extends CalendarTable {
|
|
|
92
92
|
return dateRows;
|
|
93
93
|
}
|
|
94
94
|
addCellProperty(cell, date) {
|
|
95
|
-
if (this.selectedValue?.length > 0
|
|
95
|
+
if (this.selectedValue?.length > 0) {
|
|
96
96
|
const [startSelected, endSelected] = this.selectedValue;
|
|
97
97
|
if (startSelected?.isSameDay(date)) {
|
|
98
98
|
cell.isSelected = true;
|
|
@@ -128,11 +128,11 @@ export class DateTableComponent extends CalendarTable {
|
|
|
128
128
|
}
|
|
129
129
|
}
|
|
130
130
|
DateTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: DateTableComponent, deps: [{ token: i1.DateHelperService }], target: i0.ɵɵFactoryTarget.Component });
|
|
131
|
-
DateTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: DateTableComponent, selector: "date-table", outputs: { dayHover: "dayHover" }, exportAs: ["dateTable"], usesInheritance: true, ngImport: i0, template: "<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n <thead>\n <tr role=\"row\">\n <th *ngIf=\"showWeek\" role=\"columnheader\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n <span class=\"{{ prefixCls }}-column-header-inner\"
|
|
131
|
+
DateTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: DateTableComponent, selector: "date-table", outputs: { dayHover: "dayHover" }, exportAs: ["dateTable"], usesInheritance: true, ngImport: i0, template: "<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n <thead>\n <tr role=\"row\">\n <th *ngIf=\"showWeek\" role=\"columnheader\" title=\"\u5468\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n <span class=\"{{ prefixCls }}-column-header-inner\">\u5468</span>\n </th>\n <th *ngFor=\"let cell of headRow\" role=\"columnheader\" title=\"{{ cell.title }}\" class=\"{{ prefixCls }}-column-header\">\n <span *ngIf=\"prefixCls === 'thy-calendar'\" class=\"{{ prefixCls }}-column-header-inner\">{{ cell.content }}</span>\n <span *ngIf=\"prefixCls === 'thy-calendar-full'\" class=\"{{ prefixCls }}-column-header-inner\">\u5468{{ cell.content }}</span>\n </th>\n </tr>\n </thead>\n <tbody class=\"{{ prefixCls }}-tbody\">\n <tr *ngFor=\"let row of bodyRows; trackBy: trackByBodyRow\" [ngClass]=\"row.classMap\" role=\"row\">\n <td *ngIf=\"row.weekNum\" role=\"gridcell\" class=\"{{ prefixCls }}-week-number-cell\">\n {{ row.weekNum }}\n </td>\n <td\n *ngFor=\"let cell of row.dateCells; trackBy: trackByBodyColumn\"\n role=\"gridcell\"\n [ngClass]=\"cell.classMap\"\n (click)=\"cell.isDisabled ? null : cell.onClick()\"\n date-table-cell\n [prefixCls]=\"prefixCls\"\n [cell]=\"cell\"\n ></td>\n </tr>\n </tbody>\n</table>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.DateTableCellComponent, selector: "[date-table-cell]", inputs: ["prefixCls", "cell"], exportAs: ["dateTableCell"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
132
132
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: DateTableComponent, decorators: [{
|
|
133
133
|
type: Component,
|
|
134
|
-
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'date-table', exportAs: 'dateTable', template: "<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n <thead>\n <tr role=\"row\">\n <th *ngIf=\"showWeek\" role=\"columnheader\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n <span class=\"{{ prefixCls }}-column-header-inner\"
|
|
134
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'date-table', exportAs: 'dateTable', template: "<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n <thead>\n <tr role=\"row\">\n <th *ngIf=\"showWeek\" role=\"columnheader\" title=\"\u5468\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n <span class=\"{{ prefixCls }}-column-header-inner\">\u5468</span>\n </th>\n <th *ngFor=\"let cell of headRow\" role=\"columnheader\" title=\"{{ cell.title }}\" class=\"{{ prefixCls }}-column-header\">\n <span *ngIf=\"prefixCls === 'thy-calendar'\" class=\"{{ prefixCls }}-column-header-inner\">{{ cell.content }}</span>\n <span *ngIf=\"prefixCls === 'thy-calendar-full'\" class=\"{{ prefixCls }}-column-header-inner\">\u5468{{ cell.content }}</span>\n </th>\n </tr>\n </thead>\n <tbody class=\"{{ prefixCls }}-tbody\">\n <tr *ngFor=\"let row of bodyRows; trackBy: trackByBodyRow\" [ngClass]=\"row.classMap\" role=\"row\">\n <td *ngIf=\"row.weekNum\" role=\"gridcell\" class=\"{{ prefixCls }}-week-number-cell\">\n {{ row.weekNum }}\n </td>\n <td\n *ngFor=\"let cell of row.dateCells; trackBy: trackByBodyColumn\"\n role=\"gridcell\"\n [ngClass]=\"cell.classMap\"\n (click)=\"cell.isDisabled ? null : cell.onClick()\"\n date-table-cell\n [prefixCls]=\"prefixCls\"\n [cell]=\"cell\"\n ></td>\n </tr>\n </tbody>\n</table>\n" }]
|
|
135
135
|
}], ctorParameters: function () { return [{ type: i1.DateHelperService }]; }, propDecorators: { dayHover: [{
|
|
136
136
|
type: Output
|
|
137
137
|
}] } });
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-table.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/date/date-table.component.ts","../../../../../../src/date-picker/lib/date/date-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FunctionProp, TinyDate, valueFunctionProp } from 'ngx-tethys/util';\n\nimport { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output } from '@angular/core';\n\nimport { DateHelperService } from '../../date-helper.service';\nimport { DateCell, DateBodyRow } from './types';\nimport { CalendarTable } from '../calendar/calendar-table.component';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'date-table',\n    exportAs: 'dateTable',\n    templateUrl: 'date-table.component.html'\n})\nexport class DateTableComponent extends CalendarTable implements OnChanges {\n    @Output() readonly dayHover = new EventEmitter<TinyDate>(); // Emitted when hover on a day by mouse enter\n\n    constructor(private dateHelper: DateHelperService) {\n        super();\n    }\n\n    private chooseDate(value: TinyDate): void {\n        // Only change date not change time\n        const newValue = this.activeDate\n            .setYear(value.getYear())\n            .setMonth(value.getMonth())\n            .setDate(value.getDate());\n        this.valueChange.emit(newValue);\n    }\n\n    makeHeadRow(): DateCell[] {\n        const weekDays: DateCell[] = [];\n        const start = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n        for (let colIndex = 0; colIndex < this.MAX_COL; colIndex++) {\n            const day = start.addDays(colIndex);\n            weekDays[colIndex] = {\n                title: this.dateHelper.format(day.nativeDate, this.dateHelper.relyOnDatePipe ? 'E' : 'ddd'),\n                content: this.dateHelper.format(day.nativeDate, this.getVeryShortWeekFormat()),\n                isSelected: false,\n                isDisabled: false,\n                onClick(): void {},\n                onMouseEnter(): void {}\n            };\n        }\n        return weekDays;\n    }\n\n    private getVeryShortWeekFormat(): string {\n        if (this.dateHelper.relyOnDatePipe) {\n            return 'EEEEE'; // eg. 二\n        }\n        return 'dd';\n    }\n\n    makeBodyRows(): DateBodyRow[] {\n        const dateRows: DateBodyRow[] = [];\n        const firstDayOfMonth = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n\n        for (let week = 0; week < this.MAX_ROW; week++) {\n            const weekStart = firstDayOfMonth.addDays(week * 7);\n            const row: DateBodyRow = {\n                isActive: false,\n                isCurrent: false,\n                dateCells: [],\n                year: weekStart.getYear()\n            };\n\n            for (let day = 0; day < 7; day++) {\n                const date = weekStart.addDays(day);\n                const dateFormat = this.dateHelper.relyOnDatePipe ? 'longDate' : 'YYYY-MM-DD';\n                const title = this.dateHelper.format(date.nativeDate, dateFormat);\n                const label = this.dateHelper.format(date.nativeDate, this.dateHelper.relyOnDatePipe ? 'dd' : 'DD');\n\n                const cell: DateCell = {\n                    value: date.nativeDate,\n                    label: label,\n                    isSelected: false,\n                    isDisabled: false,\n                    isToday: false,\n                    title: title,\n                    dateCellRender: valueFunctionProp(this.cellRender, date),\n                    content: `${date.getDate()}`,\n                    onClick: () => this.chooseDate(date),\n                    onMouseEnter: () => this.dayHover.emit(date)\n                };\n                this.addCellProperty(cell, date);\n\n                if (this.showWeek && !row.weekNum) {\n                    row.weekNum = this.dateHelper.getISOWeek(date.nativeDate);\n                }\n\n                if (date.isToday()) {\n                    cell.isToday = true;\n                    row.isCurrent = true;\n                }\n                if (date.isSameDay(this.value)) {\n                    row.isActive = date.isSameDay(this.value);\n                }\n                row.dateCells.push(cell);\n            }\n\n            row.classMap = {\n                [`${this.prefixCls}-current-week`]: row.isCurrent,\n                [`${this.prefixCls}-active-week`]: row.isActive\n            };\n\n            dateRows.push(row);\n        }\n\n        return dateRows;\n    }\n\n    addCellProperty(cell: DateCell, date: TinyDate): void {\n        if (this.selectedValue?.length > 0 && !this.showWeek) {\n            const [startSelected, endSelected] = this.selectedValue;\n            if (startSelected?.isSameDay(date)) {\n                cell.isSelected = true;\n            }\n            if (endSelected?.isSameDay(date)) {\n                cell.isSelected = true;\n            }\n            cell.isStartSingle = startSelected && !endSelected;\n            cell.isEndSingle = !startSelected && !!endSelected;\n            cell.isInRange = startSelected?.isBeforeDay(date) && date.isBeforeDay(endSelected);\n        } else {\n            cell.isSelected = date.isSameDay(this.value);\n        }\n        cell.isLastMonthCell = date.isBeforeMonth(this.activeDate);\n        cell.isNextMonthCell = date.isAfterMonth(this.activeDate);\n        cell.isToday = date.isToday();\n        cell.isDisabled = !!this.disabledDate?.(date.nativeDate);\n        cell.classMap = this.getClassMap(cell);\n    }\n\n    getClassMap(cell: DateCell): { [key: string]: boolean } {\n        return {\n            [`${this.prefixCls}-cell`]: true,\n            [`${this.prefixCls}-today`]: cell.isToday,\n            [`${this.prefixCls}-last-month-cell`]: cell.isLastMonthCell,\n            [`${this.prefixCls}-next-month-btn-day`]: cell.isNextMonthCell,\n            [`${this.prefixCls}-selected-day`]: cell.isSelected,\n            [`${this.prefixCls}-disabled-cell`]: cell.isDisabled,\n            [`${this.prefixCls}-selected-start-date`]: !!cell.isSelectedStartDate,\n            [`${this.prefixCls}-selected-end-date`]: !!cell.isSelectedEndDate,\n            [`${this.prefixCls}-in-range-cell`]: !!cell.isInRange\n        };\n    }\n}\n","<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n  <thead>\n    <tr role=\"row\">\n      <th *ngIf=\"showWeek\" role=\"columnheader\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n        <span class=\"{{ prefixCls }}-column-header-inner\">x</span>\n      </th>\n      <th *ngFor=\"let cell of headRow\" role=\"columnheader\" title=\"{{ cell.title }}\" class=\"{{ prefixCls }}-column-header\">\n        <span *ngIf=\"prefixCls === 'thy-calendar'\" class=\"{{ prefixCls }}-column-header-inner\">{{ cell.content }}</span>\n        <span *ngIf=\"prefixCls === 'thy-calendar-full'\" class=\"{{ prefixCls }}-column-header-inner\">周{{ cell.content }}</span>\n      </th>\n    </tr>\n  </thead>\n  <tbody class=\"{{ prefixCls }}-tbody\">\n    <tr *ngFor=\"let row of bodyRows; trackBy: trackByBodyRow\" [ngClass]=\"row.classMap\" role=\"row\">\n      <td *ngIf=\"row.weekNum\" role=\"gridcell\" class=\"{{ prefixCls }}-week-number-cell\">\n        {{ row.weekNum }}\n      </td>\n      <td\n        *ngFor=\"let cell of row.dateCells; trackBy: trackByBodyColumn\"\n        role=\"gridcell\"\n        [ngClass]=\"cell.classMap\"\n        (click)=\"cell.isDisabled ? null : cell.onClick()\"\n        date-table-cell\n        [prefixCls]=\"prefixCls\"\n        [cell]=\"cell\"\n      ></td>\n    </tr>\n  </tbody>\n</table>\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-table.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/date/date-table.component.ts","../../../../../../src/date-picker/lib/date/date-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FunctionProp, TinyDate, valueFunctionProp } from 'ngx-tethys/util';\n\nimport { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output } from '@angular/core';\n\nimport { DateHelperService } from '../../date-helper.service';\nimport { DateCell, DateBodyRow } from './types';\nimport { CalendarTable } from '../calendar/calendar-table.component';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'date-table',\n    exportAs: 'dateTable',\n    templateUrl: 'date-table.component.html'\n})\nexport class DateTableComponent extends CalendarTable implements OnChanges {\n    @Output() readonly dayHover = new EventEmitter<TinyDate>(); // Emitted when hover on a day by mouse enter\n\n    constructor(private dateHelper: DateHelperService) {\n        super();\n    }\n\n    private chooseDate(value: TinyDate): void {\n        // Only change date not change time\n        const newValue = this.activeDate\n            .setYear(value.getYear())\n            .setMonth(value.getMonth())\n            .setDate(value.getDate());\n        this.valueChange.emit(newValue);\n    }\n\n    makeHeadRow(): DateCell[] {\n        const weekDays: DateCell[] = [];\n        const start = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n        for (let colIndex = 0; colIndex < this.MAX_COL; colIndex++) {\n            const day = start.addDays(colIndex);\n            weekDays[colIndex] = {\n                title: this.dateHelper.format(day.nativeDate, this.dateHelper.relyOnDatePipe ? 'E' : 'ddd'),\n                content: this.dateHelper.format(day.nativeDate, this.getVeryShortWeekFormat()),\n                isSelected: false,\n                isDisabled: false,\n                onClick(): void {},\n                onMouseEnter(): void {}\n            };\n        }\n        return weekDays;\n    }\n\n    private getVeryShortWeekFormat(): string {\n        if (this.dateHelper.relyOnDatePipe) {\n            return 'EEEEE'; // eg. 二\n        }\n        return 'dd';\n    }\n\n    makeBodyRows(): DateBodyRow[] {\n        const dateRows: DateBodyRow[] = [];\n        const firstDayOfMonth = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n\n        for (let week = 0; week < this.MAX_ROW; week++) {\n            const weekStart = firstDayOfMonth.addDays(week * 7);\n            const row: DateBodyRow = {\n                isActive: false,\n                isCurrent: false,\n                dateCells: [],\n                year: weekStart.getYear()\n            };\n\n            for (let day = 0; day < 7; day++) {\n                const date = weekStart.addDays(day);\n                const dateFormat = this.dateHelper.relyOnDatePipe ? 'longDate' : 'YYYY-MM-DD';\n                const title = this.dateHelper.format(date.nativeDate, dateFormat);\n                const label = this.dateHelper.format(date.nativeDate, this.dateHelper.relyOnDatePipe ? 'dd' : 'DD');\n\n                const cell: DateCell = {\n                    value: date.nativeDate,\n                    label: label,\n                    isSelected: false,\n                    isDisabled: false,\n                    isToday: false,\n                    title: title,\n                    dateCellRender: valueFunctionProp(this.cellRender, date),\n                    content: `${date.getDate()}`,\n                    onClick: () => this.chooseDate(date),\n                    onMouseEnter: () => this.dayHover.emit(date)\n                };\n                this.addCellProperty(cell, date);\n\n                if (this.showWeek && !row.weekNum) {\n                    row.weekNum = this.dateHelper.getISOWeek(date.nativeDate);\n                }\n\n                if (date.isToday()) {\n                    cell.isToday = true;\n                    row.isCurrent = true;\n                }\n                if (date.isSameDay(this.value)) {\n                    row.isActive = date.isSameDay(this.value);\n                }\n                row.dateCells.push(cell);\n            }\n\n            row.classMap = {\n                [`${this.prefixCls}-current-week`]: row.isCurrent,\n                [`${this.prefixCls}-active-week`]: row.isActive\n            };\n\n            dateRows.push(row);\n        }\n\n        return dateRows;\n    }\n\n    addCellProperty(cell: DateCell, date: TinyDate): void {\n        if (this.selectedValue?.length > 0) {\n            const [startSelected, endSelected] = this.selectedValue;\n            if (startSelected?.isSameDay(date)) {\n                cell.isSelected = true;\n            }\n            if (endSelected?.isSameDay(date)) {\n                cell.isSelected = true;\n            }\n            cell.isStartSingle = startSelected && !endSelected;\n            cell.isEndSingle = !startSelected && !!endSelected;\n            cell.isInRange = startSelected?.isBeforeDay(date) && date.isBeforeDay(endSelected);\n        } else {\n            cell.isSelected = date.isSameDay(this.value);\n        }\n        cell.isLastMonthCell = date.isBeforeMonth(this.activeDate);\n        cell.isNextMonthCell = date.isAfterMonth(this.activeDate);\n        cell.isToday = date.isToday();\n        cell.isDisabled = !!this.disabledDate?.(date.nativeDate);\n        cell.classMap = this.getClassMap(cell);\n    }\n\n    getClassMap(cell: DateCell): { [key: string]: boolean } {\n        return {\n            [`${this.prefixCls}-cell`]: true,\n            [`${this.prefixCls}-today`]: cell.isToday,\n            [`${this.prefixCls}-last-month-cell`]: cell.isLastMonthCell,\n            [`${this.prefixCls}-next-month-btn-day`]: cell.isNextMonthCell,\n            [`${this.prefixCls}-selected-day`]: cell.isSelected,\n            [`${this.prefixCls}-disabled-cell`]: cell.isDisabled,\n            [`${this.prefixCls}-selected-start-date`]: !!cell.isSelectedStartDate,\n            [`${this.prefixCls}-selected-end-date`]: !!cell.isSelectedEndDate,\n            [`${this.prefixCls}-in-range-cell`]: !!cell.isInRange\n        };\n    }\n}\n","<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n  <thead>\n    <tr role=\"row\">\n      <th *ngIf=\"showWeek\" role=\"columnheader\" title=\"周\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n        <span class=\"{{ prefixCls }}-column-header-inner\">周</span>\n      </th>\n      <th *ngFor=\"let cell of headRow\" role=\"columnheader\" title=\"{{ cell.title }}\" class=\"{{ prefixCls }}-column-header\">\n        <span *ngIf=\"prefixCls === 'thy-calendar'\" class=\"{{ prefixCls }}-column-header-inner\">{{ cell.content }}</span>\n        <span *ngIf=\"prefixCls === 'thy-calendar-full'\" class=\"{{ prefixCls }}-column-header-inner\">周{{ cell.content }}</span>\n      </th>\n    </tr>\n  </thead>\n  <tbody class=\"{{ prefixCls }}-tbody\">\n    <tr *ngFor=\"let row of bodyRows; trackBy: trackByBodyRow\" [ngClass]=\"row.classMap\" role=\"row\">\n      <td *ngIf=\"row.weekNum\" role=\"gridcell\" class=\"{{ prefixCls }}-week-number-cell\">\n        {{ row.weekNum }}\n      </td>\n      <td\n        *ngFor=\"let cell of row.dateCells; trackBy: trackByBodyColumn\"\n        role=\"gridcell\"\n        [ngClass]=\"cell.classMap\"\n        (click)=\"cell.isDisabled ? null : cell.onClick()\"\n        date-table-cell\n        [prefixCls]=\"prefixCls\"\n        [cell]=\"cell\"\n      ></td>\n    </tr>\n  </tbody>\n</table>\n"]}
|
|
@@ -117,7 +117,7 @@ export class InnerPopupComponent {
|
|
|
117
117
|
}
|
|
118
118
|
}
|
|
119
119
|
InnerPopupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: InnerPopupComponent, deps: [{ token: i1.DateHelperService }], target: i0.ɵɵFactoryTarget.Component });
|
|
120
|
-
InnerPopupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: InnerPopupComponent, selector: "inner-popup", inputs: { showWeek: "showWeek", isRange: "isRange", activeDate: "activeDate", rangeActiveDate: "rangeActiveDate", enablePrev: "enablePrev", enableNext: "enableNext", disabledDate: "disabledDate", dateRender: "dateRender", selectedValue: "selectedValue", hoverValue: "hoverValue", panelMode: "panelMode", showDateRangeInput: "showDateRangeInput", partType: "partType", endPanelMode: "endPanelMode", value: "value" }, outputs: { panelModeChange: "panelModeChange", headerChange: "headerChange", selectDate: "selectDate", dayHover: "dayHover" }, host: { properties: { "class.thy-calendar-picker-inner-popup": "this.className", "class.thy-calendar-picker-inner-popup-with-range-input": "this._showDateRangeInput" } }, exportAs: ["innerPopup"], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"showDateRangeInput\">\n <div class=\"{{ prefixCls }}-picker-inner-popup-range-input\">\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[0])\" placeholder=\"\u5F00\u59CB\u65E5\u671F\" />\n <span class=\"split\"></span>\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[1])\" placeholder=\"\u7ED3\u675F\u65E5\u671F\" />\n </div>\n</ng-container>\n<ng-container [ngSwitch]=\"panelMode\">\n <ng-container *ngSwitchCase=\"'decade'\">\n <div class=\"{{ prefixCls }}-decade\">\n <decade-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'decade')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'decade')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></decade-header>\n <div class=\"{{ prefixCls }}-body\">\n <decade-table [value]=\"value\" [activeDate]=\"activeDate\" (valueChange)=\"onChooseDecade($event)\"></decade-table>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"{{ prefixCls }}-year\">\n <year-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'year')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'year')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></year-header>\n <div class=\"{{ prefixCls }}-body\">\n <year-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseYear($event)\"\n [selectedValue]=\"selectedValue\"\n ></year-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"{{ prefixCls }}-month\">\n <month-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'month')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'month')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></month-header>\n <div class=\"{{ prefixCls }}-body\">\n <month-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseMonth($event)\"\n [selectedValue]=\"selectedValue\"\n ></month-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <date-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'date')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'date')\"\n [showPreBtn]=\"enablePrevNext('prev', 'date')\"\n [showNextBtn]=\"enablePrevNext('next', 'date')\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></date-header>\n <div class=\"{{ prefixCls }}-body\">\n <date-table\n [showWeek]=\"showWeek\"\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n (valueChange)=\"onSelectDate($event)\"\n showWeekNumber=\"false\"\n [disabledDate]=\"disabledDate\"\n [cellRender]=\"dateRender\"\n [selectedValue]=\"selectedValue\"\n [hoverValue]=\"hoverValue\"\n (dayHover)=\"dayHover.emit($event)\"\n ></date-table>\n </div>\n </ng-container>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i3.ThyInputDirective, selector: "input[thyInput], select[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }, { kind: "component", type: i4.DateTableComponent, selector: "date-table", outputs: ["dayHover"], exportAs: ["dateTable"] }, { kind: "component", type: i5.DateHeaderComponent, selector: "date-header" }, { kind: "component", type: i6.YearTableComponent, selector: "year-table", outputs: ["decadePanelShow"] }, { kind: "component", type: i7.YearHeaderComponent, selector: "year-header" }, { kind: "component", type: i8.MonthTableComponent, selector: "month-table", exportAs: ["monthTable"] }, { kind: "component", type: i9.MonthHeaderComponent, selector: "month-header" }, { kind: "component", type: i10.DecadeHeaderComponent, selector: "decade-header" }, { kind: "component", type: i11.DecadeTableComponent, selector: "decade-table", exportAs: ["decadeTable"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
120
|
+
InnerPopupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: InnerPopupComponent, selector: "inner-popup", inputs: { showWeek: "showWeek", isRange: "isRange", activeDate: "activeDate", rangeActiveDate: "rangeActiveDate", enablePrev: "enablePrev", enableNext: "enableNext", disabledDate: "disabledDate", dateRender: "dateRender", selectedValue: "selectedValue", hoverValue: "hoverValue", panelMode: "panelMode", showDateRangeInput: "showDateRangeInput", partType: "partType", endPanelMode: "endPanelMode", value: "value" }, outputs: { panelModeChange: "panelModeChange", headerChange: "headerChange", selectDate: "selectDate", dayHover: "dayHover" }, host: { properties: { "class.thy-calendar-picker-inner-popup": "this.className", "class.thy-calendar-picker-inner-popup-with-range-input": "this._showDateRangeInput" } }, exportAs: ["innerPopup"], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"showDateRangeInput\">\n <div class=\"{{ prefixCls }}-picker-inner-popup-range-input\">\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[0])\" placeholder=\"\u5F00\u59CB\u65E5\u671F\" />\n <span class=\"split\"></span>\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[1])\" placeholder=\"\u7ED3\u675F\u65E5\u671F\" />\n </div>\n</ng-container>\n<ng-container [ngSwitch]=\"panelMode\">\n <ng-container *ngSwitchCase=\"'decade'\">\n <div class=\"{{ prefixCls }}-decade\">\n <decade-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'decade')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'decade')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></decade-header>\n <div class=\"{{ prefixCls }}-body\">\n <decade-table [value]=\"value\" [activeDate]=\"activeDate\" (valueChange)=\"onChooseDecade($event)\"></decade-table>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"{{ prefixCls }}-year\">\n <year-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'year')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'year')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></year-header>\n <div class=\"{{ prefixCls }}-body\">\n <year-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseYear($event)\"\n [selectedValue]=\"selectedValue\"\n ></year-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"{{ prefixCls }}-month\">\n <month-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'month')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'month')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></month-header>\n <div class=\"{{ prefixCls }}-body\">\n <month-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseMonth($event)\"\n [selectedValue]=\"selectedValue\"\n ></month-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <date-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'date')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'date')\"\n [showPreBtn]=\"enablePrevNext('prev', 'date')\"\n [showNextBtn]=\"enablePrevNext('next', 'date')\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></date-header>\n <div class=\"{{ prefixCls }}-body\">\n <date-table\n [showWeek]=\"showWeek\"\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n (valueChange)=\"onSelectDate($event)\"\n showWeekNumber=\"false\"\n [disabledDate]=\"disabledDate\"\n [cellRender]=\"dateRender\"\n [selectedValue]=\"selectedValue\"\n [hoverValue]=\"hoverValue\"\n (dayHover)=\"dayHover.emit($event)\"\n ></date-table>\n </div>\n </ng-container>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i3.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }, { kind: "component", type: i4.DateTableComponent, selector: "date-table", outputs: ["dayHover"], exportAs: ["dateTable"] }, { kind: "component", type: i5.DateHeaderComponent, selector: "date-header" }, { kind: "component", type: i6.YearTableComponent, selector: "year-table", outputs: ["decadePanelShow"] }, { kind: "component", type: i7.YearHeaderComponent, selector: "year-header" }, { kind: "component", type: i8.MonthTableComponent, selector: "month-table", exportAs: ["monthTable"] }, { kind: "component", type: i9.MonthHeaderComponent, selector: "month-header" }, { kind: "component", type: i10.DecadeHeaderComponent, selector: "decade-header" }, { kind: "component", type: i11.DecadeTableComponent, selector: "decade-table", exportAs: ["decadeTable"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
121
121
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: InnerPopupComponent, decorators: [{
|
|
122
122
|
type: Component,
|
|
123
123
|
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'inner-popup', exportAs: 'innerPopup', template: "<ng-container *ngIf=\"showDateRangeInput\">\n <div class=\"{{ prefixCls }}-picker-inner-popup-range-input\">\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[0])\" placeholder=\"\u5F00\u59CB\u65E5\u671F\" />\n <span class=\"split\"></span>\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[1])\" placeholder=\"\u7ED3\u675F\u65E5\u671F\" />\n </div>\n</ng-container>\n<ng-container [ngSwitch]=\"panelMode\">\n <ng-container *ngSwitchCase=\"'decade'\">\n <div class=\"{{ prefixCls }}-decade\">\n <decade-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'decade')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'decade')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></decade-header>\n <div class=\"{{ prefixCls }}-body\">\n <decade-table [value]=\"value\" [activeDate]=\"activeDate\" (valueChange)=\"onChooseDecade($event)\"></decade-table>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"{{ prefixCls }}-year\">\n <year-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'year')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'year')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></year-header>\n <div class=\"{{ prefixCls }}-body\">\n <year-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseYear($event)\"\n [selectedValue]=\"selectedValue\"\n ></year-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"{{ prefixCls }}-month\">\n <month-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'month')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'month')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></month-header>\n <div class=\"{{ prefixCls }}-body\">\n <month-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseMonth($event)\"\n [selectedValue]=\"selectedValue\"\n ></month-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <date-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'date')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'date')\"\n [showPreBtn]=\"enablePrevNext('prev', 'date')\"\n [showNextBtn]=\"enablePrevNext('next', 'date')\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></date-header>\n <div class=\"{{ prefixCls }}-body\">\n <date-table\n [showWeek]=\"showWeek\"\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n (valueChange)=\"onSelectDate($event)\"\n showWeekNumber=\"false\"\n [disabledDate]=\"disabledDate\"\n [cellRender]=\"dateRender\"\n [selectedValue]=\"selectedValue\"\n [hoverValue]=\"hoverValue\"\n (dayHover)=\"dayHover.emit($event)\"\n ></date-table>\n </div>\n </ng-container>\n</ng-container>\n" }]
|
|
@@ -81,7 +81,8 @@ export class YearTableComponent extends CalendarTable {
|
|
|
81
81
|
[`${this.prefixCls}-year-panel-cell`]: true,
|
|
82
82
|
[`${this.prefixCls}-year-panel-selected-cell`]: cell.isSelected,
|
|
83
83
|
[`${this.prefixCls}-year-panel-cell-disabled`]: cell.isDisabled,
|
|
84
|
-
[`${this.prefixCls}-year-panel-cell-in-view`]: cell.isSameDecade
|
|
84
|
+
[`${this.prefixCls}-year-panel-cell-in-view`]: cell.isSameDecade,
|
|
85
|
+
[`${this.prefixCls}-in-range-cell`]: !!cell.isInRange
|
|
85
86
|
};
|
|
86
87
|
}
|
|
87
88
|
}
|
|
@@ -93,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
93
94
|
}], ctorParameters: function () { return []; }, propDecorators: { decadePanelShow: [{
|
|
94
95
|
type: Output
|
|
95
96
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"year-table.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/year/year-table.component.ts","../../../../../../src/date-picker/lib/year/year-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, OnChanges, Output } from '@angular/core';\nimport { TinyDate } from 'ngx-tethys/util';\nimport { CalendarTable } from '../calendar/calendar-table.component';\nimport { DateCell, DateBodyRow, YearCell } from '../date/types';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'year-table',\n    templateUrl: 'year-table.component.html'\n})\nexport class YearTableComponent extends CalendarTable implements OnChanges {\n    MAX_ROW = 4;\n\n    MAX_COL = 3;\n\n    @Output() readonly decadePanelShow = new EventEmitter<void>();\n\n    constructor() {\n        super();\n    }\n    private chooseYear(year: number): void {\n        this.value = this.activeDate.setYear(year);\n        this.valueChange.emit(this.value);\n        this.render();\n    }\n\n    makeHeadRow(): DateCell[] {\n        return [];\n    }\n\n    makeBodyRows(): DateBodyRow[] {\n        const years: DateBodyRow[] = [];\n        const currentYear = this.activeDate && this.activeDate.getYear();\n        const startYear = parseInt(`${currentYear / 10}`, 10) * 10;\n        const endYear = startYear + 9;\n        const previousYear = startYear - 1;\n        let yearValue = 0;\n        for (let rowIndex = 0; rowIndex < this.MAX_ROW; rowIndex++) {\n            const row: DateBodyRow = {\n                dateCells: [],\n                trackByIndex: rowIndex\n            };\n            for (let colIndex = 0; colIndex < this.MAX_COL; colIndex++) {\n                const yearNum = previousYear + yearValue;\n                const year = this.activeDate.setYear(yearNum);\n                const content = String(yearNum);\n                const isDisabled = this.disabledDate ? this.disabledDate(year.nativeDate) : false;\n\n                const cell: YearCell = {\n                    trackByIndex: colIndex,\n                    isDisabled,\n                    content,\n                    value: year.nativeDate,\n                    title: content,\n                    isSelected: yearNum === (this.value && this.value.getYear()),\n                    isSameDecade: yearNum >= startYear && yearNum <= endYear,\n                    classMap: {},\n                    onClick: () => this.chooseYear(cell.value?.getFullYear()),\n                    onMouseEnter: () => {}\n                };\n                this.addCellProperty(cell, year);\n                row.dateCells.push(cell);\n                yearValue++;\n            }\n            years.push(row);\n        }\n        return years;\n    }\n\n    private addCellProperty(cell: DateCell, year: TinyDate): void {\n        if (this.selectedValue?.length > 0) {\n            const [startSelected, endSelected] = this.selectedValue;\n            if (startSelected?.isSameYear(year)) {\n                cell.isSelected = true;\n            }\n\n            if (endSelected?.isSameYear(year)) {\n                cell.isSelected = true;\n            }\n\n            cell.isStartSingle = startSelected && !endSelected;\n            cell.isEndSingle = !startSelected && !!endSelected;\n            cell.isInRange = startSelected?.isBeforeYear(year) && year?.isBeforeYear(endSelected);\n        } else if (year.isSameYear(this.value)) {\n            cell.isSelected = true;\n        }\n        cell.classMap = this.getClassMap(cell);\n    }\n\n    yearCellClick(event: Event, yearCell: DateCell) {\n        event.stopPropagation();\n        return yearCell.isDisabled ? null : yearCell.onClick();\n    }\n\n    getClassMap(cell: YearCell): { [key: string]: boolean } {\n        return {\n            [`${this.prefixCls}-year-panel-cell`]: true,\n            [`${this.prefixCls}-year-panel-selected-cell`]: cell.isSelected,\n            [`${this.prefixCls}-year-panel-cell-disabled`]: cell.isDisabled,\n            [`${this.prefixCls}-year-panel-cell-in-view`]: cell.isSameDecade\n        };\n    }\n}\n","<table class=\"{{ prefixCls }}-year-panel-table\" cellSpacing=\"0\" role=\"grid\">\n  <tbody class=\"{{ prefixCls }}-year-panel-tbody\">\n    <tr *ngFor=\"let row of bodyRows; trackBy: trackByBodyRow\" role=\"row\">\n      <td\n        *ngFor=\"let yearCell of row.dateCells; trackBy: trackByBodyColumn\"\n        role=\"gridcell\"\n        title=\"{{ yearCell.title }}\"\n        (click)=\"yearCellClick($event, yearCell)\"\n        [ngClass]=\"yearCell.classMap\"\n      >\n        <a class=\"{{ prefixCls }}-year-panel-year\">{{ yearCell.content }}</a>\n      </td>\n    </tr>\n  </tbody>\n</table>\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"year-table.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/year/year-table.component.ts","../../../../../../src/date-picker/lib/year/year-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, OnChanges, Output } from '@angular/core';\nimport { TinyDate } from 'ngx-tethys/util';\nimport { CalendarTable } from '../calendar/calendar-table.component';\nimport { DateCell, DateBodyRow, YearCell } from '../date/types';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'year-table',\n    templateUrl: 'year-table.component.html'\n})\nexport class YearTableComponent extends CalendarTable implements OnChanges {\n    MAX_ROW = 4;\n\n    MAX_COL = 3;\n\n    @Output() readonly decadePanelShow = new EventEmitter<void>();\n\n    constructor() {\n        super();\n    }\n    private chooseYear(year: number): void {\n        this.value = this.activeDate.setYear(year);\n        this.valueChange.emit(this.value);\n        this.render();\n    }\n\n    makeHeadRow(): DateCell[] {\n        return [];\n    }\n\n    makeBodyRows(): DateBodyRow[] {\n        const years: DateBodyRow[] = [];\n        const currentYear = this.activeDate && this.activeDate.getYear();\n        const startYear = parseInt(`${currentYear / 10}`, 10) * 10;\n        const endYear = startYear + 9;\n        const previousYear = startYear - 1;\n        let yearValue = 0;\n        for (let rowIndex = 0; rowIndex < this.MAX_ROW; rowIndex++) {\n            const row: DateBodyRow = {\n                dateCells: [],\n                trackByIndex: rowIndex\n            };\n            for (let colIndex = 0; colIndex < this.MAX_COL; colIndex++) {\n                const yearNum = previousYear + yearValue;\n                const year = this.activeDate.setYear(yearNum);\n                const content = String(yearNum);\n                const isDisabled = this.disabledDate ? this.disabledDate(year.nativeDate) : false;\n\n                const cell: YearCell = {\n                    trackByIndex: colIndex,\n                    isDisabled,\n                    content,\n                    value: year.nativeDate,\n                    title: content,\n                    isSelected: yearNum === (this.value && this.value.getYear()),\n                    isSameDecade: yearNum >= startYear && yearNum <= endYear,\n                    classMap: {},\n                    onClick: () => this.chooseYear(cell.value?.getFullYear()),\n                    onMouseEnter: () => {}\n                };\n                this.addCellProperty(cell, year);\n                row.dateCells.push(cell);\n                yearValue++;\n            }\n            years.push(row);\n        }\n        return years;\n    }\n\n    private addCellProperty(cell: DateCell, year: TinyDate): void {\n        if (this.selectedValue?.length > 0) {\n            const [startSelected, endSelected] = this.selectedValue;\n            if (startSelected?.isSameYear(year)) {\n                cell.isSelected = true;\n            }\n\n            if (endSelected?.isSameYear(year)) {\n                cell.isSelected = true;\n            }\n\n            cell.isStartSingle = startSelected && !endSelected;\n            cell.isEndSingle = !startSelected && !!endSelected;\n            cell.isInRange = startSelected?.isBeforeYear(year) && year?.isBeforeYear(endSelected);\n        } else if (year.isSameYear(this.value)) {\n            cell.isSelected = true;\n        }\n        cell.classMap = this.getClassMap(cell);\n    }\n\n    yearCellClick(event: Event, yearCell: DateCell) {\n        event.stopPropagation();\n        return yearCell.isDisabled ? null : yearCell.onClick();\n    }\n\n    getClassMap(cell: YearCell): { [key: string]: boolean } {\n        return {\n            [`${this.prefixCls}-year-panel-cell`]: true,\n            [`${this.prefixCls}-year-panel-selected-cell`]: cell.isSelected,\n            [`${this.prefixCls}-year-panel-cell-disabled`]: cell.isDisabled,\n            [`${this.prefixCls}-year-panel-cell-in-view`]: cell.isSameDecade,\n            [`${this.prefixCls}-in-range-cell`]: !!cell.isInRange\n        };\n    }\n}\n","<table class=\"{{ prefixCls }}-year-panel-table\" cellSpacing=\"0\" role=\"grid\">\n  <tbody class=\"{{ prefixCls }}-year-panel-tbody\">\n    <tr *ngFor=\"let row of bodyRows; trackBy: trackByBodyRow\" role=\"row\">\n      <td\n        *ngFor=\"let yearCell of row.dateCells; trackBy: trackByBodyColumn\"\n        role=\"gridcell\"\n        title=\"{{ yearCell.title }}\"\n        (click)=\"yearCellClick($event, yearCell)\"\n        [ngClass]=\"yearCell.classMap\"\n      >\n        <a class=\"{{ prefixCls }}-year-panel-year\">{{ yearCell.content }}</a>\n      </td>\n    </tr>\n  </tbody>\n</table>\n"]}
|
|
@@ -123,7 +123,7 @@ export class ThyPickerComponent {
|
|
|
123
123
|
}
|
|
124
124
|
}
|
|
125
125
|
ThyPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyPickerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DateHelperService }], target: i0.ɵɵFactoryTarget.Component });
|
|
126
|
-
ThyPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyPickerComponent, selector: "thy-picker", inputs: { isRange: "isRange", open: "open", disabled: "disabled", placeholder: "placeholder", readonly: "readonly", allowClear: "allowClear", autoFocus: "autoFocus", className: "className", format: "format", size: "size", value: "value", suffixIcon: "suffixIcon", placement: "placement", flexible: "flexible", flexibleDateGranularity: "flexibleDateGranularity" }, outputs: { valueChange: "valueChange", openChange: "openChange" }, viewQueries: [{ propertyName: "origin", first: true, predicate: ["origin"], descendants: true, static: true }, { propertyName: "cdkConnectedOverlay", first: true, predicate: CdkConnectedOverlay, descendants: true, static: true }, { propertyName: "pickerInput", first: true, predicate: ["pickerInput"], descendants: true, static: true }], exportAs: ["thyPicker"], ngImport: i0, template: "<span\n cdkOverlayOrigin\n #origin=\"cdkOverlayOrigin\"\n class=\"{{ prefixCls }}-picker {{ size ? prefixCls + '-picker-' + size : '' }} {{ className }}\"\n (click)=\"onClickInputBox()\"\n>\n <ng-container>\n <input\n #pickerInput\n thyInput\n class=\"form-control-{{ size }} form-control {{ prefixCls }}-picker-input\"\n [thySize]=\"size\"\n [class.thy-input-disabled]=\"disabled\"\n [class.thy-input-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n readonly\n value=\"{{ getReadableValue() }}\"\n placeholder=\"{{ getPlaceholder() }}\"\n />\n <ng-container *ngTemplateOutlet=\"tplRightRest\"></ng-container>\n </ng-container>\n</span>\n\n<!-- Right operator icons -->\n<ng-template #tplRightRest>\n <span class=\"{{ prefixCls }}-picker-clear\">\n <thy-icon\n thyIconName=\"close-circle-bold-fill\"\n *ngIf=\"!disabled && !isEmptyValue(value) && allowClear && !readonly\"\n (click)=\"onClickClear($event)\"\n ngClass=\"remove-link remove-link-{{ size }}\"\n ></thy-icon>\n </span>\n <span class=\"{{ prefixCls }}-picker-icon\">\n <thy-icon [thyIconName]=\"suffixIcon\" ngClass=\"remove-link-{{ size }}\"></thy-icon>\n </span>\n</ng-template>\n\n<!-- Overlay -->\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"realOpenState\"\n [cdkConnectedOverlayHasBackdrop]=\"!isOpenHandledByUser()\"\n [cdkConnectedOverlayPositions]=\"overlayPositions\"\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n (positionChange)=\"onPositionChange($event)\"\n (backdropClick)=\"onClickBackdrop()\"\n (detach)=\"onOverlayDetach()\"\n>\n <div style=\"position: relative;\">\n <!-- Compatible for overlay that not support offset dynamically and immediately -->\n <ng-content></ng-content>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i3.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
126
|
+
ThyPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyPickerComponent, selector: "thy-picker", inputs: { isRange: "isRange", open: "open", disabled: "disabled", placeholder: "placeholder", readonly: "readonly", allowClear: "allowClear", autoFocus: "autoFocus", className: "className", format: "format", size: "size", value: "value", suffixIcon: "suffixIcon", placement: "placement", flexible: "flexible", flexibleDateGranularity: "flexibleDateGranularity" }, outputs: { valueChange: "valueChange", openChange: "openChange" }, viewQueries: [{ propertyName: "origin", first: true, predicate: ["origin"], descendants: true, static: true }, { propertyName: "cdkConnectedOverlay", first: true, predicate: CdkConnectedOverlay, descendants: true, static: true }, { propertyName: "pickerInput", first: true, predicate: ["pickerInput"], descendants: true, static: true }], exportAs: ["thyPicker"], ngImport: i0, template: "<span\n cdkOverlayOrigin\n #origin=\"cdkOverlayOrigin\"\n class=\"{{ prefixCls }}-picker {{ size ? prefixCls + '-picker-' + size : '' }} {{ className }}\"\n (click)=\"onClickInputBox()\"\n>\n <ng-container>\n <input\n #pickerInput\n thyInput\n class=\"form-control-{{ size }} form-control {{ prefixCls }}-picker-input\"\n [thySize]=\"size\"\n [class.thy-input-disabled]=\"disabled\"\n [class.thy-input-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n readonly\n value=\"{{ getReadableValue() }}\"\n placeholder=\"{{ getPlaceholder() }}\"\n />\n <ng-container *ngTemplateOutlet=\"tplRightRest\"></ng-container>\n </ng-container>\n</span>\n\n<!-- Right operator icons -->\n<ng-template #tplRightRest>\n <span class=\"{{ prefixCls }}-picker-clear\">\n <thy-icon\n thyIconName=\"close-circle-bold-fill\"\n *ngIf=\"!disabled && !isEmptyValue(value) && allowClear && !readonly\"\n (click)=\"onClickClear($event)\"\n ngClass=\"remove-link remove-link-{{ size }}\"\n ></thy-icon>\n </span>\n <span class=\"{{ prefixCls }}-picker-icon\">\n <thy-icon [thyIconName]=\"suffixIcon\" ngClass=\"remove-link-{{ size }}\"></thy-icon>\n </span>\n</ng-template>\n\n<!-- Overlay -->\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"realOpenState\"\n [cdkConnectedOverlayHasBackdrop]=\"!isOpenHandledByUser()\"\n [cdkConnectedOverlayPositions]=\"overlayPositions\"\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n (positionChange)=\"onPositionChange($event)\"\n (backdropClick)=\"onClickBackdrop()\"\n (detach)=\"onOverlayDetach()\"\n>\n <div style=\"position: relative;\">\n <!-- Compatible for overlay that not support offset dynamically and immediately -->\n <ng-content></ng-content>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i3.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
127
127
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyPickerComponent, decorators: [{
|
|
128
128
|
type: Component,
|
|
129
129
|
args: [{ selector: 'thy-picker', exportAs: 'thyPicker', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span\n cdkOverlayOrigin\n #origin=\"cdkOverlayOrigin\"\n class=\"{{ prefixCls }}-picker {{ size ? prefixCls + '-picker-' + size : '' }} {{ className }}\"\n (click)=\"onClickInputBox()\"\n>\n <ng-container>\n <input\n #pickerInput\n thyInput\n class=\"form-control-{{ size }} form-control {{ prefixCls }}-picker-input\"\n [thySize]=\"size\"\n [class.thy-input-disabled]=\"disabled\"\n [class.thy-input-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n readonly\n value=\"{{ getReadableValue() }}\"\n placeholder=\"{{ getPlaceholder() }}\"\n />\n <ng-container *ngTemplateOutlet=\"tplRightRest\"></ng-container>\n </ng-container>\n</span>\n\n<!-- Right operator icons -->\n<ng-template #tplRightRest>\n <span class=\"{{ prefixCls }}-picker-clear\">\n <thy-icon\n thyIconName=\"close-circle-bold-fill\"\n *ngIf=\"!disabled && !isEmptyValue(value) && allowClear && !readonly\"\n (click)=\"onClickClear($event)\"\n ngClass=\"remove-link remove-link-{{ size }}\"\n ></thy-icon>\n </span>\n <span class=\"{{ prefixCls }}-picker-icon\">\n <thy-icon [thyIconName]=\"suffixIcon\" ngClass=\"remove-link-{{ size }}\"></thy-icon>\n </span>\n</ng-template>\n\n<!-- Overlay -->\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"realOpenState\"\n [cdkConnectedOverlayHasBackdrop]=\"!isOpenHandledByUser()\"\n [cdkConnectedOverlayPositions]=\"overlayPositions\"\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n (positionChange)=\"onPositionChange($event)\"\n (backdropClick)=\"onClickBackdrop()\"\n (detach)=\"onOverlayDetach()\"\n>\n <div style=\"position: relative;\">\n <!-- Compatible for overlay that not support offset dynamically and immediately -->\n <ng-content></ng-content>\n </div>\n</ng-template>\n" }]
|
|
@@ -105,7 +105,7 @@ export class ThyInputSearchComponent extends _MixinBase {
|
|
|
105
105
|
}
|
|
106
106
|
}
|
|
107
107
|
ThyInputSearchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyInputSearchComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
108
|
-
ThyInputSearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputSearchComponent, selector: "thy-input-search", inputs: { name: "name", placeholder: "placeholder", thyTheme: "thyTheme", thySearchFocus: "thySearchFocus", thyIconPosition: "thyIconPosition", thySize: "thySize" }, outputs: { clear: "clear", thyClear: "thyClear" }, host: { properties: { "class.thy-input-search-ellipse": "thyTheme === \"ellipse\"", "class.thy-input-search-transparent": "thyTheme === \"transparent\"", "class.form-control-active": "focused" }, classAttribute: "thy-input form-control thy-input-search" }, providers: [CUSTOM_INPUT_SEARCH_CONTROL_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0, template: "<thy-icon class=\"input-prepend\" *ngIf=\"iconPosition === 'before'\" thyIconName=\"search\"></thy-icon>\n<input\n class=\"input-search-control\"\n thyInput\n [name]=\"name\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [thyAutofocus]=\"autoFocus\"\n [(ngModel)]=\"searchText\"\n (ngModelChange)=\"searchModelChange()\"\n (focus)=\"focused = true\"\n (blur)=\"focused = false && onTouchedCallback()\"\n [thySize]=\"thySize\"\n/>\n<ng-container *ngIf=\"iconPosition === 'after'\">\n <div class=\"input-append input-append-divider\">\n <a class=\"close\" *ngIf=\"searchText; else onlyIcon\" href=\"javascript:;\" (click)=\"clearSearchText($event)\">\n <thy-icon thyIconName=\"close\"></thy-icon>\n </a>\n <ng-template #onlyIcon>\n <thy-icon class=\"text-placeholder\" thyIconName=\"search\"></thy-icon>\n </ng-template>\n </div>\n</ng-container>\n\n<a *ngIf=\"searchText && iconPosition === 'before'\" class=\"close input-append\" href=\"javascript:;\" (click)=\"clearSearchText($event)\">\n <thy-icon thyIconName=\"close\"></thy-icon>\n</a>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
108
|
+
ThyInputSearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputSearchComponent, selector: "thy-input-search", inputs: { name: "name", placeholder: "placeholder", thyTheme: "thyTheme", thySearchFocus: "thySearchFocus", thyIconPosition: "thyIconPosition", thySize: "thySize" }, outputs: { clear: "clear", thyClear: "thyClear" }, host: { properties: { "class.thy-input-search-ellipse": "thyTheme === \"ellipse\"", "class.thy-input-search-transparent": "thyTheme === \"transparent\"", "class.form-control-active": "focused" }, classAttribute: "thy-input form-control thy-input-search" }, providers: [CUSTOM_INPUT_SEARCH_CONTROL_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0, template: "<thy-icon class=\"input-prepend\" *ngIf=\"iconPosition === 'before'\" thyIconName=\"search\"></thy-icon>\n<input\n class=\"input-search-control\"\n thyInput\n [name]=\"name\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [thyAutofocus]=\"autoFocus\"\n [(ngModel)]=\"searchText\"\n (ngModelChange)=\"searchModelChange()\"\n (focus)=\"focused = true\"\n (blur)=\"focused = false && onTouchedCallback()\"\n [thySize]=\"thySize\"\n/>\n<ng-container *ngIf=\"iconPosition === 'after'\">\n <div class=\"input-append input-append-divider\">\n <a class=\"close\" *ngIf=\"searchText; else onlyIcon\" href=\"javascript:;\" (click)=\"clearSearchText($event)\">\n <thy-icon thyIconName=\"close\"></thy-icon>\n </a>\n <ng-template #onlyIcon>\n <thy-icon class=\"text-placeholder\" thyIconName=\"search\"></thy-icon>\n </ng-template>\n </div>\n</ng-container>\n\n<a *ngIf=\"searchText && iconPosition === 'before'\" class=\"close input-append\" href=\"javascript:;\" (click)=\"clearSearchText($event)\">\n <thy-icon thyIconName=\"close\"></thy-icon>\n</a>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
109
109
|
__decorate([
|
|
110
110
|
InputBoolean(),
|
|
111
111
|
__metadata("design:type", Boolean),
|
|
@@ -102,7 +102,7 @@ export class ThyInputComponent {
|
|
|
102
102
|
}
|
|
103
103
|
}
|
|
104
104
|
ThyInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyInputComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
105
|
-
ThyInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputComponent, selector: "thy-input", inputs: { placeholder: "placeholder", thySize: "thySize", thyAutofocus: "thyAutofocus", thyType: "thyType", type: "type", thyLabelText: "thyLabelText", readonly: "readonly", thyAutocomplete: "thyAutocomplete" }, outputs: { focus: "focus", blur: "blur" }, host: { properties: { "class.form-control-active": "focused", "class.disabled": "disabled" }, classAttribute: "thy-input form-control" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], queries: [{ propertyName: "appendTemplate", first: true, predicate: ["append"], descendants: true }, { propertyName: "prependTemplate", first: true, predicate: ["prepend"], descendants: true }], viewQueries: [{ propertyName: "eyeTemplate", first: true, predicate: ["eye"], descendants: true, static: true }], ngImport: i0, template: "<div #prepend class=\"input-prepend\" *ngIf=\"prependTemplate\">\n <ng-template *ngTemplateOutlet=\"prependTemplate\"></ng-template>\n</div>\n<input\n #input\n thyInput\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutofocus\"\n [type]=\"type\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [thyAutocomplete]=\"autocomplete\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onModelChange()\"\n (focus)=\"onInputFocus($event)\"\n (blur)=\"onInputBlur($event)\"\n [readonly]=\"readonly\"\n/>\n<span class=\"input-label input-label-{{ thySize }}\" [class.active]=\"showLabel\">{{ thyLabelText }}</span>\n<div #append class=\"input-append\" *ngIf=\"appendTemplate\">\n <ng-template *ngTemplateOutlet=\"appendTemplate\"></ng-template>\n</div>\n\n<ng-template #eye>\n <a href=\"javascript:;\" class=\"link-secondary input-password-icon\" (click)=\"togglePasswordType()\">\n <thy-icon *ngIf=\"isPassword(type)\" thyIconName=\"eye\"></thy-icon>\n <thy-icon *ngIf=\"!isPassword(type)\" thyIconName=\"eye-invisible\"></thy-icon>\n </a>\n</ng-template>\n", dependencies: [{ 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: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
105
|
+
ThyInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputComponent, selector: "thy-input", inputs: { placeholder: "placeholder", thySize: "thySize", thyAutofocus: "thyAutofocus", thyType: "thyType", type: "type", thyLabelText: "thyLabelText", readonly: "readonly", thyAutocomplete: "thyAutocomplete" }, outputs: { focus: "focus", blur: "blur" }, host: { properties: { "class.form-control-active": "focused", "class.disabled": "disabled" }, classAttribute: "thy-input form-control" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], queries: [{ propertyName: "appendTemplate", first: true, predicate: ["append"], descendants: true }, { propertyName: "prependTemplate", first: true, predicate: ["prepend"], descendants: true }], viewQueries: [{ propertyName: "eyeTemplate", first: true, predicate: ["eye"], descendants: true, static: true }], ngImport: i0, template: "<div #prepend class=\"input-prepend\" *ngIf=\"prependTemplate\">\n <ng-template *ngTemplateOutlet=\"prependTemplate\"></ng-template>\n</div>\n<input\n #input\n thyInput\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutofocus\"\n [type]=\"type\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [thyAutocomplete]=\"autocomplete\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onModelChange()\"\n (focus)=\"onInputFocus($event)\"\n (blur)=\"onInputBlur($event)\"\n [readonly]=\"readonly\"\n/>\n<span class=\"input-label input-label-{{ thySize }}\" [class.active]=\"showLabel\">{{ thyLabelText }}</span>\n<div #append class=\"input-append\" *ngIf=\"appendTemplate\">\n <ng-template *ngTemplateOutlet=\"appendTemplate\"></ng-template>\n</div>\n\n<ng-template #eye>\n <a href=\"javascript:;\" class=\"link-secondary input-password-icon\" (click)=\"togglePasswordType()\">\n <thy-icon *ngIf=\"isPassword(type)\" thyIconName=\"eye\"></thy-icon>\n <thy-icon *ngIf=\"!isPassword(type)\" thyIconName=\"eye-invisible\"></thy-icon>\n </a>\n</ng-template>\n", dependencies: [{ 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: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
106
106
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyInputComponent, decorators: [{
|
|
107
107
|
type: Component,
|
|
108
108
|
args: [{ selector: 'thy-input', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], encapsulation: ViewEncapsulation.None, host: {
|