@ptsecurity/mosaic 14.3.0 → 14.4.0
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/_theming.scss +13 -4
- package/_visual.scss +8 -3
- package/core/formatters/date/formatter.pipe.d.ts +79 -66
- package/core/formatters/number/formatter.d.ts +13 -3
- package/datepicker/datepicker-input.directive.d.ts +1 -0
- package/design-tokens/legacy-2017/tokens/components/datepicker.json5 +15 -6
- package/design-tokens/legacy-2017/tokens/components/popup.json5 +1 -1
- package/design-tokens/legacy-2017/tokens.d.ts +9 -3
- package/design-tokens/pt-2022/tokens/components/datepicker.json5 +13 -4
- package/design-tokens/pt-2022/tokens/components/popup.json5 +1 -1
- package/design-tokens/pt-2022/tokens/components/sidepanel.json5 +1 -2
- package/design-tokens/pt-2022/tokens.d.ts +8 -3
- package/esm2020/core/formatters/date/formatter.pipe.mjs +87 -54
- package/esm2020/core/formatters/number/formatter.mjs +26 -10
- package/esm2020/core/select/constants.mjs +1 -1
- package/esm2020/core/version.mjs +2 -2
- package/esm2020/datepicker/calendar-body.component.mjs +2 -2
- package/esm2020/datepicker/datepicker-input.directive.mjs +9 -6
- package/esm2020/datepicker/datepicker.component.mjs +3 -3
- package/esm2020/design-tokens/legacy-2017/tokens.mjs +10 -4
- package/esm2020/design-tokens/pt-2022/tokens.mjs +9 -4
- package/esm2020/form-field/form-field.mjs +50 -9
- package/esm2020/form-field/form-field.module.mjs +10 -6
- package/esm2020/form-field/password-hint.mjs +4 -4
- package/esm2020/input/input.mjs +10 -21
- package/esm2020/progress-spinner/progress-spinner.component.mjs +2 -2
- package/esm2020/select/select.component.mjs +10 -2
- package/esm2020/sidepanel/sidepanel-container.component.mjs +3 -3
- package/esm2020/sidepanel/sidepanel-directives.mjs +16 -11
- package/esm2020/tags/tag-input.mjs +19 -7
- package/esm2020/toast/toast.service.mjs +5 -4
- package/fesm2015/ptsecurity-mosaic-core.mjs +110 -60
- package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-datepicker.mjs +12 -9
- package/fesm2015/ptsecurity-mosaic-datepicker.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-design-tokens.mjs +26 -9
- package/fesm2015/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-form-field.mjs +62 -15
- package/fesm2015/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-input.mjs +10 -20
- package/fesm2015/ptsecurity-mosaic-input.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs +2 -2
- package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-select.mjs +9 -1
- package/fesm2015/ptsecurity-mosaic-select.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-sidepanel.mjs +18 -13
- package/fesm2015/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-tags.mjs +19 -8
- package/fesm2015/ptsecurity-mosaic-tags.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-toast.mjs +4 -3
- package/fesm2015/ptsecurity-mosaic-toast.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-core.mjs +110 -63
- package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-datepicker.mjs +12 -9
- package/fesm2020/ptsecurity-mosaic-datepicker.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-design-tokens.mjs +26 -9
- package/fesm2020/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-form-field.mjs +60 -17
- package/fesm2020/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-input.mjs +9 -20
- package/fesm2020/ptsecurity-mosaic-input.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs +2 -2
- package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-select.mjs +9 -1
- package/fesm2020/ptsecurity-mosaic-select.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-sidepanel.mjs +18 -13
- package/fesm2020/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-tags.mjs +16 -5
- package/fesm2020/ptsecurity-mosaic-tags.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-toast.mjs +4 -3
- package/fesm2020/ptsecurity-mosaic-toast.mjs.map +1 -1
- package/form-field/form-field.d.ts +12 -2
- package/form-field/form-field.module.d.ts +1 -1
- package/input/input.d.ts +1 -2
- package/package.json +4 -4
- package/prebuilt-themes/dark-theme.css +1 -1
- package/prebuilt-themes/default-theme.css +1 -1
- package/select/select.component.d.ts +2 -0
- package/tags/tag-input.d.ts +5 -2
@@ -1,187 +1,220 @@
|
|
1
1
|
import { Pipe } from '@angular/core';
|
2
|
+
import { DateAdapter } from '@ptsecurity/cdk/datetime';
|
2
3
|
import { DateFormatter } from './formatter';
|
3
4
|
import * as i0 from "@angular/core";
|
4
|
-
import * as i1 from "
|
5
|
+
import * as i1 from "@ptsecurity/cdk/datetime";
|
6
|
+
import * as i2 from "./formatter";
|
5
7
|
export class AbsoluteDateFormatterPipe {
|
6
|
-
constructor(formatter) {
|
8
|
+
constructor(adapter, formatter) {
|
9
|
+
this.adapter = adapter;
|
7
10
|
this.formatter = formatter;
|
8
11
|
}
|
9
12
|
transform(value, currYear) {
|
10
|
-
|
13
|
+
const date = this.adapter.deserialize(value);
|
14
|
+
return date ? this.formatter.absoluteLongDate(date, currYear) : '';
|
11
15
|
}
|
12
16
|
}
|
13
|
-
/** @nocollapse */ AbsoluteDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
17
|
+
/** @nocollapse */ AbsoluteDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
14
18
|
/** @nocollapse */ AbsoluteDateFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateFormatterPipe, name: "absoluteLongDate" });
|
15
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateFormatterPipe, decorators: [{
|
16
20
|
type: Pipe,
|
17
21
|
args: [{ name: 'absoluteLongDate' }]
|
18
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
22
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
19
23
|
export class AbsoluteDateTimeFormatterPipe {
|
20
|
-
constructor(formatter) {
|
24
|
+
constructor(adapter, formatter) {
|
25
|
+
this.adapter = adapter;
|
21
26
|
this.formatter = formatter;
|
22
27
|
}
|
23
28
|
transform(value, options) {
|
24
|
-
|
29
|
+
const date = this.adapter.deserialize(value);
|
30
|
+
return date ? this.formatter.absoluteLongDateTime(date, options) : '';
|
25
31
|
}
|
26
32
|
}
|
27
|
-
/** @nocollapse */ AbsoluteDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateTimeFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
33
|
+
/** @nocollapse */ AbsoluteDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateTimeFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
28
34
|
/** @nocollapse */ AbsoluteDateTimeFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateTimeFormatterPipe, name: "absoluteLongDateTime" });
|
29
35
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateTimeFormatterPipe, decorators: [{
|
30
36
|
type: Pipe,
|
31
37
|
args: [{ name: 'absoluteLongDateTime' }]
|
32
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
38
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
33
39
|
export class AbsoluteDateShortFormatterPipe {
|
34
|
-
constructor(formatter) {
|
40
|
+
constructor(adapter, formatter) {
|
41
|
+
this.adapter = adapter;
|
35
42
|
this.formatter = formatter;
|
36
43
|
}
|
37
44
|
transform(value, currYear) {
|
38
|
-
|
45
|
+
const date = this.adapter.deserialize(value);
|
46
|
+
return date ? this.formatter.absoluteShortDate(date, currYear) : '';
|
39
47
|
}
|
40
48
|
}
|
41
|
-
/** @nocollapse */ AbsoluteDateShortFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateShortFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
49
|
+
/** @nocollapse */ AbsoluteDateShortFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateShortFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
42
50
|
/** @nocollapse */ AbsoluteDateShortFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateShortFormatterPipe, name: "absoluteShortDate" });
|
43
51
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteDateShortFormatterPipe, decorators: [{
|
44
52
|
type: Pipe,
|
45
53
|
args: [{ name: 'absoluteShortDate' }]
|
46
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
54
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
47
55
|
export class AbsoluteShortDateTimeFormatterPipe {
|
48
|
-
constructor(formatter) {
|
56
|
+
constructor(adapter, formatter) {
|
57
|
+
this.adapter = adapter;
|
49
58
|
this.formatter = formatter;
|
50
59
|
}
|
51
60
|
transform(value, options) {
|
52
|
-
|
61
|
+
const date = this.adapter.deserialize(value);
|
62
|
+
return date ? this.formatter.absoluteShortDateTime(date, options) : '';
|
53
63
|
}
|
54
64
|
}
|
55
|
-
/** @nocollapse */ AbsoluteShortDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteShortDateTimeFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
65
|
+
/** @nocollapse */ AbsoluteShortDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteShortDateTimeFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
56
66
|
/** @nocollapse */ AbsoluteShortDateTimeFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteShortDateTimeFormatterPipe, name: "absoluteShortDateTime" });
|
57
67
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: AbsoluteShortDateTimeFormatterPipe, decorators: [{
|
58
68
|
type: Pipe,
|
59
69
|
args: [{ name: 'absoluteShortDateTime' }]
|
60
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
70
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
61
71
|
export class RelativeDateFormatterPipe {
|
62
|
-
constructor(formatter) {
|
72
|
+
constructor(adapter, formatter) {
|
73
|
+
this.adapter = adapter;
|
63
74
|
this.formatter = formatter;
|
64
75
|
}
|
65
76
|
transform(value) {
|
66
|
-
|
77
|
+
const date = this.adapter.deserialize(value);
|
78
|
+
return date ? this.formatter.relativeLongDate(date) : '';
|
67
79
|
}
|
68
80
|
}
|
69
|
-
/** @nocollapse */ RelativeDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeDateFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
81
|
+
/** @nocollapse */ RelativeDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeDateFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
70
82
|
/** @nocollapse */ RelativeDateFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RelativeDateFormatterPipe, name: "relativeLongDate" });
|
71
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeDateFormatterPipe, decorators: [{
|
72
84
|
type: Pipe,
|
73
85
|
args: [{ name: 'relativeLongDate' }]
|
74
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
86
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
75
87
|
export class RelativeDateTimeFormatterPipe {
|
76
|
-
constructor(formatter) {
|
88
|
+
constructor(adapter, formatter) {
|
89
|
+
this.adapter = adapter;
|
77
90
|
this.formatter = formatter;
|
78
91
|
}
|
79
92
|
transform(value, options) {
|
80
|
-
|
93
|
+
const date = this.adapter.deserialize(value);
|
94
|
+
return date ? this.formatter.relativeLongDateTime(date, options) : '';
|
81
95
|
}
|
82
96
|
}
|
83
|
-
/** @nocollapse */ RelativeDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeDateTimeFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
97
|
+
/** @nocollapse */ RelativeDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeDateTimeFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
84
98
|
/** @nocollapse */ RelativeDateTimeFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RelativeDateTimeFormatterPipe, name: "relativeLongDateTime" });
|
85
99
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeDateTimeFormatterPipe, decorators: [{
|
86
100
|
type: Pipe,
|
87
101
|
args: [{ name: 'relativeLongDateTime' }]
|
88
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
102
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
89
103
|
export class RelativeShortDateFormatterPipe {
|
90
|
-
constructor(formatter) {
|
104
|
+
constructor(adapter, formatter) {
|
105
|
+
this.adapter = adapter;
|
91
106
|
this.formatter = formatter;
|
92
107
|
}
|
93
108
|
transform(value) {
|
94
|
-
|
109
|
+
const date = this.adapter.deserialize(value);
|
110
|
+
return date ? this.formatter.relativeShortDate(date) : '';
|
95
111
|
}
|
96
112
|
}
|
97
|
-
/** @nocollapse */ RelativeShortDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeShortDateFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
113
|
+
/** @nocollapse */ RelativeShortDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeShortDateFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
98
114
|
/** @nocollapse */ RelativeShortDateFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RelativeShortDateFormatterPipe, name: "relativeShortDate" });
|
99
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeShortDateFormatterPipe, decorators: [{
|
100
116
|
type: Pipe,
|
101
117
|
args: [{ name: 'relativeShortDate' }]
|
102
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
118
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
103
119
|
export class RelativeShortDateTimeFormatterPipe {
|
104
|
-
constructor(formatter) {
|
120
|
+
constructor(adapter, formatter) {
|
121
|
+
this.adapter = adapter;
|
105
122
|
this.formatter = formatter;
|
106
123
|
}
|
107
124
|
transform(value, options) {
|
108
|
-
|
125
|
+
const date = this.adapter.deserialize(value);
|
126
|
+
return date ? this.formatter.relativeShortDateTime(date, options) : '';
|
109
127
|
}
|
110
128
|
}
|
111
|
-
/** @nocollapse */ RelativeShortDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeShortDateTimeFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
129
|
+
/** @nocollapse */ RelativeShortDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeShortDateTimeFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
112
130
|
/** @nocollapse */ RelativeShortDateTimeFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RelativeShortDateTimeFormatterPipe, name: "relativeShortDateTime" });
|
113
131
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RelativeShortDateTimeFormatterPipe, decorators: [{
|
114
132
|
type: Pipe,
|
115
133
|
args: [{ name: 'relativeShortDateTime' }]
|
116
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
134
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
117
135
|
export class RangeDateFormatterPipe {
|
118
|
-
constructor(formatter) {
|
136
|
+
constructor(adapter, formatter) {
|
137
|
+
this.adapter = adapter;
|
119
138
|
this.formatter = formatter;
|
120
139
|
}
|
121
140
|
transform([value1, value2]) {
|
122
|
-
|
141
|
+
const date1 = this.adapter.deserialize(value1);
|
142
|
+
const date2 = this.adapter.deserialize(value2);
|
143
|
+
return this.formatter.rangeLongDate(date1, date2);
|
123
144
|
}
|
124
145
|
}
|
125
|
-
/** @nocollapse */ RangeDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeDateFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
146
|
+
/** @nocollapse */ RangeDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeDateFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
126
147
|
/** @nocollapse */ RangeDateFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RangeDateFormatterPipe, name: "rangeLongDate" });
|
127
148
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeDateFormatterPipe, decorators: [{
|
128
149
|
type: Pipe,
|
129
150
|
args: [{ name: 'rangeLongDate' }]
|
130
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
151
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
131
152
|
export class RangeShortDateFormatterPipe {
|
132
|
-
constructor(formatter) {
|
153
|
+
constructor(adapter, formatter) {
|
154
|
+
this.adapter = adapter;
|
133
155
|
this.formatter = formatter;
|
134
156
|
}
|
135
157
|
transform([value1, value2]) {
|
136
|
-
|
158
|
+
const date1 = this.adapter.deserialize(value1);
|
159
|
+
const date2 = this.adapter.deserialize(value2);
|
160
|
+
return this.formatter.rangeShortDate(date1, date2);
|
137
161
|
}
|
138
162
|
}
|
139
|
-
/** @nocollapse */ RangeShortDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeShortDateFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
163
|
+
/** @nocollapse */ RangeShortDateFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeShortDateFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
140
164
|
/** @nocollapse */ RangeShortDateFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RangeShortDateFormatterPipe, name: "rangeShortDate" });
|
141
165
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeShortDateFormatterPipe, decorators: [{
|
142
166
|
type: Pipe,
|
143
167
|
args: [{ name: 'rangeShortDate' }]
|
144
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
168
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
145
169
|
export class RangeDateTimeFormatterPipe {
|
146
|
-
constructor(formatter) {
|
170
|
+
constructor(adapter, formatter) {
|
171
|
+
this.adapter = adapter;
|
147
172
|
this.formatter = formatter;
|
148
173
|
}
|
149
174
|
transform([value1, value2], options) {
|
150
|
-
|
175
|
+
const date1 = this.adapter.deserialize(value1);
|
176
|
+
const date2 = this.adapter.deserialize(value2);
|
177
|
+
return this.formatter.rangeLongDateTime(date1, date2, options);
|
151
178
|
}
|
152
179
|
}
|
153
|
-
/** @nocollapse */ RangeDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeDateTimeFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
180
|
+
/** @nocollapse */ RangeDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeDateTimeFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
154
181
|
/** @nocollapse */ RangeDateTimeFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RangeDateTimeFormatterPipe, name: "rangeLongDateTime" });
|
155
182
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeDateTimeFormatterPipe, decorators: [{
|
156
183
|
type: Pipe,
|
157
184
|
args: [{ name: 'rangeLongDateTime' }]
|
158
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
185
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
159
186
|
export class RangeMiddleDateTimeFormatterPipe {
|
160
|
-
constructor(formatter) {
|
187
|
+
constructor(adapter, formatter) {
|
188
|
+
this.adapter = adapter;
|
161
189
|
this.formatter = formatter;
|
162
190
|
}
|
163
191
|
transform([value1, value2], options) {
|
164
|
-
|
192
|
+
const date1 = this.adapter.deserialize(value1);
|
193
|
+
const date2 = this.adapter.deserialize(value2);
|
194
|
+
return this.formatter.rangeMiddleDateTime(date1, date2, options);
|
165
195
|
}
|
166
196
|
}
|
167
|
-
/** @nocollapse */ RangeMiddleDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeMiddleDateTimeFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
197
|
+
/** @nocollapse */ RangeMiddleDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeMiddleDateTimeFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
168
198
|
/** @nocollapse */ RangeMiddleDateTimeFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RangeMiddleDateTimeFormatterPipe, name: "rangeMiddleDateTime" });
|
169
199
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeMiddleDateTimeFormatterPipe, decorators: [{
|
170
200
|
type: Pipe,
|
171
201
|
args: [{ name: 'rangeMiddleDateTime' }]
|
172
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
202
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
173
203
|
export class RangeShortDateTimeFormatterPipe {
|
174
|
-
constructor(formatter) {
|
204
|
+
constructor(adapter, formatter) {
|
205
|
+
this.adapter = adapter;
|
175
206
|
this.formatter = formatter;
|
176
207
|
}
|
177
208
|
transform([value1, value2], options) {
|
178
|
-
|
209
|
+
const date1 = this.adapter.deserialize(value1);
|
210
|
+
const date2 = this.adapter.deserialize(value2);
|
211
|
+
return this.formatter.rangeShortDateTime(date1, date2, options);
|
179
212
|
}
|
180
213
|
}
|
181
|
-
/** @nocollapse */ RangeShortDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeShortDateTimeFormatterPipe, deps: [{ token: i1.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
214
|
+
/** @nocollapse */ RangeShortDateTimeFormatterPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeShortDateTimeFormatterPipe, deps: [{ token: i1.DateAdapter }, { token: i2.DateFormatter }], target: i0.ɵɵFactoryTarget.Pipe });
|
182
215
|
/** @nocollapse */ RangeShortDateTimeFormatterPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: RangeShortDateTimeFormatterPipe, name: "rangeShortDateTime" });
|
183
216
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: RangeShortDateTimeFormatterPipe, decorators: [{
|
184
217
|
type: Pipe,
|
185
218
|
args: [{ name: 'rangeShortDateTime' }]
|
186
|
-
}], ctorParameters: function () { return [{ type: i1.DateFormatter }]; } });
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formatter.pipe.js","sourceRoot":"","sources":["../../../../../../packages/mosaic/core/formatters/date/formatter.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { DateTime } from 'luxon';\n\nimport { DateFormatter, DateTimeOptions } from './formatter';\n\n\n@Pipe({ name: 'absoluteLongDate' })\nexport class AbsoluteDateFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform(value: any, currYear?: boolean): string {\n        return this.formatter.absoluteLongDate(value, currYear);\n    }\n}\n\n@Pipe({ name: 'absoluteLongDateTime' })\nexport class AbsoluteDateTimeFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform(value: any, options?: DateTimeOptions): string {\n        return this.formatter.absoluteLongDateTime(value, options);\n    }\n}\n\n@Pipe({ name: 'absoluteShortDate' })\nexport class AbsoluteDateShortFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform(value: any, currYear?: boolean): string {\n        return this.formatter.absoluteShortDate(value, currYear);\n    }\n}\n\n@Pipe({ name: 'absoluteShortDateTime' })\nexport class AbsoluteShortDateTimeFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform(value: any, options?: DateTimeOptions): string {\n        return this.formatter.absoluteShortDateTime(value, options);\n    }\n}\n\n@Pipe({ name: 'relativeLongDate' })\nexport class RelativeDateFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform(value: any): string {\n        return this.formatter.relativeLongDate(value);\n    }\n}\n\n@Pipe({ name: 'relativeLongDateTime' })\nexport class RelativeDateTimeFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform(value: any, options?: DateTimeOptions): string {\n        return this.formatter.relativeLongDateTime(value, options);\n    }\n}\n\n@Pipe({ name: 'relativeShortDate' })\nexport class RelativeShortDateFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform(value: any): string {\n        return this.formatter.relativeShortDate(value);\n    }\n}\n\n@Pipe({ name: 'relativeShortDateTime' })\nexport class RelativeShortDateTimeFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform(value: any, options?: DateTimeOptions): string {\n        return this.formatter.relativeShortDateTime(value, options);\n    }\n}\n\n@Pipe({ name: 'rangeLongDate' })\nexport class RangeDateFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform([value1, value2]: any): string {\n        return this.formatter.rangeLongDate(value1, value2);\n    }\n}\n\n@Pipe({ name: 'rangeShortDate' })\nexport class RangeShortDateFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform([value1, value2]: any): string {\n        return this.formatter.rangeShortDate(value1, value2);\n    }\n}\n\n@Pipe({ name: 'rangeLongDateTime' })\nexport class RangeDateTimeFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform([value1, value2]: any, options?: DateTimeOptions): string {\n        return this.formatter.rangeLongDateTime(value1, value2, options);\n    }\n}\n\n@Pipe({ name: 'rangeMiddleDateTime' })\nexport class RangeMiddleDateTimeFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform([value1, value2]: any, options?: DateTimeOptions): string {\n        return this.formatter.rangeMiddleDateTime(value1, value2, options);\n    }\n}\n\n@Pipe({ name: 'rangeShortDateTime' })\nexport class RangeShortDateTimeFormatterPipe implements PipeTransform {\n    constructor(private formatter: DateFormatter<DateTime>) {}\n\n    transform([value1, value2]: any, options?: DateTimeOptions): string {\n        return this.formatter.rangeShortDateTime(value1, value2, options);\n    }\n}\n"]}
|
219
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.DateFormatter }]; } });
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formatter.pipe.js","sourceRoot":"","sources":["../../../../../../packages/mosaic/core/formatters/date/formatter.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { DateAdapter } from '@ptsecurity/cdk/datetime';\n\nimport { DateFormatter, DateTimeOptions } from './formatter';\n\n\n@Pipe({ name: 'absoluteLongDate' })\nexport class AbsoluteDateFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform(value: D | string, currYear?: boolean): string {\n        const date = this.adapter.deserialize(value);\n\n        return date ? this.formatter.absoluteLongDate(date, currYear) : '';\n    }\n}\n\n@Pipe({ name: 'absoluteLongDateTime' })\nexport class AbsoluteDateTimeFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform(value: D | string, options?: DateTimeOptions): string {\n        const date = this.adapter.deserialize(value);\n\n        return date ? this.formatter.absoluteLongDateTime(date, options) : '';\n    }\n}\n\n@Pipe({ name: 'absoluteShortDate' })\nexport class AbsoluteDateShortFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform(value: D | string, currYear?: boolean): string {\n        const date = this.adapter.deserialize(value);\n\n        return date ? this.formatter.absoluteShortDate(date, currYear) : '';\n    }\n}\n\n@Pipe({ name: 'absoluteShortDateTime' })\nexport class AbsoluteShortDateTimeFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform(value: D | string, options?: DateTimeOptions): string {\n        const date = this.adapter.deserialize(value);\n\n        return date ? this.formatter.absoluteShortDateTime(date, options) : '';\n    }\n}\n\n@Pipe({ name: 'relativeLongDate' })\nexport class RelativeDateFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform(value: D | string): string {\n        const date = this.adapter.deserialize(value);\n\n        return date ? this.formatter.relativeLongDate(date) : '';\n    }\n}\n\n@Pipe({ name: 'relativeLongDateTime' })\nexport class RelativeDateTimeFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform(value: D | string, options?: DateTimeOptions): string {\n        const date = this.adapter.deserialize(value);\n\n        return date ? this.formatter.relativeLongDateTime(date, options) : '';\n    }\n}\n\n@Pipe({ name: 'relativeShortDate' })\nexport class RelativeShortDateFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform(value: D | string): string {\n        const date = this.adapter.deserialize(value);\n\n        return date ? this.formatter.relativeShortDate(date) : '';\n    }\n}\n\n@Pipe({ name: 'relativeShortDateTime' })\nexport class RelativeShortDateTimeFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform(value: D | string, options?: DateTimeOptions): string {\n        const date = this.adapter.deserialize(value);\n\n        return date ? this.formatter.relativeShortDateTime(date, options) : '';\n    }\n}\n\n@Pipe({ name: 'rangeLongDate' })\nexport class RangeDateFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform([value1, value2]: D[] | string[]): string {\n        const date1 = this.adapter.deserialize(value1);\n        const date2 = this.adapter.deserialize(value2);\n\n        return this.formatter.rangeLongDate(date1 as D, date2 as D);\n    }\n}\n\n@Pipe({ name: 'rangeShortDate' })\nexport class RangeShortDateFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform([value1, value2]: D[] | string[]): string {\n        const date1 = this.adapter.deserialize(value1);\n        const date2 = this.adapter.deserialize(value2);\n\n        return this.formatter.rangeShortDate(date1 as D, date2 as D);\n    }\n}\n\n@Pipe({ name: 'rangeLongDateTime' })\nexport class RangeDateTimeFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform([value1, value2]: D[] | string[], options?: DateTimeOptions): string {\n        const date1 = this.adapter.deserialize(value1);\n        const date2 = this.adapter.deserialize(value2);\n\n        return this.formatter.rangeLongDateTime(date1 as D, date2 as D, options);\n    }\n}\n\n@Pipe({ name: 'rangeMiddleDateTime' })\nexport class RangeMiddleDateTimeFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform([value1, value2]: D[] | string[], options?: DateTimeOptions): string {\n        const date1 = this.adapter.deserialize(value1);\n        const date2 = this.adapter.deserialize(value2);\n\n        return this.formatter.rangeMiddleDateTime(date1 as D, date2 as D, options);\n    }\n}\n\n@Pipe({ name: 'rangeShortDateTime' })\nexport class RangeShortDateTimeFormatterPipe<D> implements PipeTransform {\n    constructor(\n        private adapter: DateAdapter<D>,\n        private formatter: DateFormatter<D>\n    ) {}\n\n    transform([value1, value2]: D[] | string[], options?: DateTimeOptions): string {\n        const date1 = this.adapter.deserialize(value1);\n        const date2 = this.adapter.deserialize(value2);\n\n        return this.formatter.rangeShortDateTime(date1 as D, date2 as D, options);\n    }\n}\n"]}
|
@@ -2,6 +2,13 @@
|
|
2
2
|
import { Inject, Injectable, InjectionToken, Optional, Pipe } from '@angular/core';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
export const MC_LOCALE_ID = new InjectionToken('McLocaleId');
|
5
|
+
export const MC_NUMBER_FORMATTER_OPTIONS = new InjectionToken('McNumberFormatterOptions');
|
6
|
+
export const MC_NUMBER_FORMATTER_DEFAULT_OPTIONS = {
|
7
|
+
useGrouping: true,
|
8
|
+
minimumIntegerDigits: 1,
|
9
|
+
minimumFractionDigits: 0,
|
10
|
+
maximumFractionDigits: 3
|
11
|
+
};
|
5
12
|
export const DEFAULT_MC_LOCALE_ID = 'ru';
|
6
13
|
function isEmpty(value) {
|
7
14
|
return value == null || value === '' || value !== value;
|
@@ -15,10 +22,11 @@ function strToNumber(value) {
|
|
15
22
|
}
|
16
23
|
return value;
|
17
24
|
}
|
18
|
-
export const NUMBER_FORMAT_REGEXP = /^(\d+)?\.((\d+)(-(\d+))?)?$/;
|
25
|
+
export const NUMBER_FORMAT_REGEXP = /^(\d+)?\.((\d+)(-(\d+))?(-(true|false))?)?$/;
|
19
26
|
const minIntGroupPosition = 1;
|
20
27
|
const minFractionGroupPosition = 3;
|
21
28
|
const maxFractionGroupPosition = 5;
|
29
|
+
const useGroupingPosition = 7;
|
22
30
|
class ParsedDigitsInfo {
|
23
31
|
}
|
24
32
|
function parseDigitsInfo(digitsInfo) {
|
@@ -29,6 +37,7 @@ function parseDigitsInfo(digitsInfo) {
|
|
29
37
|
const minIntPart = parts[minIntGroupPosition];
|
30
38
|
const minFractionPart = parts[minFractionGroupPosition];
|
31
39
|
const maxFractionPart = parts[maxFractionGroupPosition];
|
40
|
+
const useGroupingPart = parts[useGroupingPosition];
|
32
41
|
const result = new ParsedDigitsInfo();
|
33
42
|
if (minIntPart != null) {
|
34
43
|
result.minimumIntegerDigits = parseInt(minIntPart);
|
@@ -42,11 +51,16 @@ function parseDigitsInfo(digitsInfo) {
|
|
42
51
|
else if (minFractionPart != null && result.minimumFractionDigits > result.maximumFractionDigits) {
|
43
52
|
result.maximumFractionDigits = result.minimumFractionDigits;
|
44
53
|
}
|
54
|
+
if (useGroupingPart != null) {
|
55
|
+
result.useGrouping = useGroupingPart === 'true';
|
56
|
+
}
|
45
57
|
return result;
|
46
58
|
}
|
47
59
|
export class McDecimalPipe {
|
48
|
-
constructor(
|
49
|
-
this.
|
60
|
+
constructor(locale, options) {
|
61
|
+
this.locale = locale;
|
62
|
+
this.options = options;
|
63
|
+
this.options = this.options || MC_NUMBER_FORMATTER_DEFAULT_OPTIONS;
|
50
64
|
}
|
51
65
|
/**
|
52
66
|
* @param value The number to be formatted.
|
@@ -66,16 +80,13 @@ export class McDecimalPipe {
|
|
66
80
|
if (isEmpty(value)) {
|
67
81
|
return null;
|
68
82
|
}
|
69
|
-
const currentLocale = locale || this.
|
83
|
+
const currentLocale = locale || this.locale || DEFAULT_MC_LOCALE_ID;
|
70
84
|
let parsedDigitsInfo;
|
71
85
|
if (digitsInfo) {
|
72
86
|
parsedDigitsInfo = parseDigitsInfo(digitsInfo);
|
73
87
|
}
|
74
88
|
const options = {
|
75
|
-
|
76
|
-
minimumIntegerDigits: 1,
|
77
|
-
minimumFractionDigits: 0,
|
78
|
-
maximumFractionDigits: 3,
|
89
|
+
...this.options,
|
79
90
|
...parsedDigitsInfo
|
80
91
|
};
|
81
92
|
try {
|
@@ -87,7 +98,7 @@ export class McDecimalPipe {
|
|
87
98
|
}
|
88
99
|
}
|
89
100
|
}
|
90
|
-
/** @nocollapse */ McDecimalPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: McDecimalPipe, deps: [{ token: MC_LOCALE_ID, optional: true }], target: i0.ɵɵFactoryTarget.Pipe });
|
101
|
+
/** @nocollapse */ McDecimalPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: McDecimalPipe, deps: [{ token: MC_LOCALE_ID, optional: true }, { token: MC_NUMBER_FORMATTER_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Pipe });
|
91
102
|
/** @nocollapse */ McDecimalPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.5", ngImport: i0, type: McDecimalPipe, name: "mcNumber" });
|
92
103
|
/** @nocollapse */ McDecimalPipe.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: McDecimalPipe, providedIn: 'root' });
|
93
104
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: McDecimalPipe, decorators: [{
|
@@ -101,5 +112,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImpor
|
|
101
112
|
}, {
|
102
113
|
type: Inject,
|
103
114
|
args: [MC_LOCALE_ID]
|
115
|
+
}] }, { type: ParsedDigitsInfo, decorators: [{
|
116
|
+
type: Optional
|
117
|
+
}, {
|
118
|
+
type: Inject,
|
119
|
+
args: [MC_NUMBER_FORMATTER_OPTIONS]
|
104
120
|
}] }]; } });
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formatter.js","sourceRoot":"","sources":["../../../../../../packages/mosaic/core/formatters/number/formatter.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable:naming-convention */\nimport { Inject, Injectable, InjectionToken, Optional, Pipe, PipeTransform } from '@angular/core';\n\n\nexport const MC_LOCALE_ID = new InjectionToken<string>('McLocaleId');\n\nexport const DEFAULT_MC_LOCALE_ID = 'ru';\n\n\nfunction isEmpty(value: any): boolean {\n    return value == null || value === '' || value !== value;\n}\n\nfunction strToNumber(value: number | string): number {\n    if (typeof value === 'string' && !isNaN(Number(value) - parseFloat(value))) {\n        return Number(value);\n    }\n\n    if (typeof value !== 'number') {\n        throw new Error(`${value} is not a number`);\n    }\n\n    return value;\n}\n\nexport const NUMBER_FORMAT_REGEXP = /^(\\d+)?\\.((\\d+)(-(\\d+))?)?$/;\n\nconst minIntGroupPosition = 1;\nconst minFractionGroupPosition = 3;\nconst maxFractionGroupPosition = 5;\n\ninterface NumberFormatOptions {\n    useGrouping: boolean;\n\n    minimumIntegerDigits: number;\n    minimumFractionDigits: number;\n    maximumFractionDigits: number;\n    minimumSignificantDigits: number;\n    maximumSignificantDigits: number;\n\n    localeMatcher?: string;\n    style?: string;\n\n    currency?: string;\n    currencyDisplay?: string;\n}\n\nclass ParsedDigitsInfo {\n    minimumIntegerDigits: number;\n    minimumFractionDigits: number;\n    maximumFractionDigits: number;\n}\n\nfunction parseDigitsInfo(digitsInfo: string): ParsedDigitsInfo {\n    const parts = digitsInfo.match(NUMBER_FORMAT_REGEXP);\n\n    if (parts === null) {\n        throw new Error(`${digitsInfo} is not a valid digit info`);\n    }\n\n    const minIntPart = parts[minIntGroupPosition];\n    const minFractionPart = parts[minFractionGroupPosition];\n    const maxFractionPart = parts[maxFractionGroupPosition];\n\n    const result = new ParsedDigitsInfo();\n\n    if (minIntPart != null) {\n        result.minimumIntegerDigits = parseInt(minIntPart);\n    }\n\n    if (minFractionPart != null) {\n        result.minimumFractionDigits = parseInt(minFractionPart);\n    }\n\n    if (maxFractionPart != null) {\n        result.maximumFractionDigits = parseInt(maxFractionPart);\n    } else if (minFractionPart != null && result.minimumFractionDigits > result.maximumFractionDigits) {\n        result.maximumFractionDigits = result.minimumFractionDigits;\n    }\n\n    return result;\n}\n\n\n@Injectable({ providedIn: 'root' })\n@Pipe({name: 'mcNumber'})\nexport class McDecimalPipe implements PipeTransform {\n    constructor(@Optional() @Inject(MC_LOCALE_ID) private _locale: string) {}\n\n    /**\n     * @param value The number to be formatted.\n     * @param digitsInfo Decimal representation options, specified by a string\n     * in the following format:<br>\n     * <code>{minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}</code>.\n     *   - `minIntegerDigits`: The minimum number of integer digits before the decimal point.\n     * Default is `1`.\n     *   - `minFractionDigits`: The minimum number of digits after the decimal point.\n     * Default is `0`.\n     *   - `maxFractionDigits`: The maximum number of digits after the decimal point.\n     * Default is `3`.\n     * @param locale A locale code for the locale format rules to use.\n     * When not supplied, uses the value of `MC_LOCALE_ID`, which is `ru` by default.\n     */\n    transform(value: any, digitsInfo?: string, locale?: string): string | null {\n        if (isEmpty(value)) { return null; }\n\n        const currentLocale = locale || this._locale || DEFAULT_MC_LOCALE_ID;\n\n        let parsedDigitsInfo;\n\n        if (digitsInfo) {\n            parsedDigitsInfo = parseDigitsInfo(digitsInfo);\n        }\n\n        const options: NumberFormatOptions = {\n            useGrouping: true,\n            minimumIntegerDigits: 1,\n            minimumFractionDigits: 0,\n            maximumFractionDigits: 3,\n            ...parsedDigitsInfo\n        };\n\n        try {\n            const num = strToNumber(value);\n\n            return Intl.NumberFormat.call(this, currentLocale, options).format(num);\n        } catch (error: any) {\n            throw Error(`InvalidPipeArgument: McDecimalPipe for pipe '${JSON.stringify(error.message)}'`);\n        }\n    }\n}\n"]}
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formatter.js","sourceRoot":"","sources":["../../../../../../packages/mosaic/core/formatters/number/formatter.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable:naming-convention */\nimport { Inject, Injectable, InjectionToken, Optional, Pipe, PipeTransform } from '@angular/core';\n\n\nexport const MC_LOCALE_ID = new InjectionToken<string>('McLocaleId');\n\nexport const MC_NUMBER_FORMATTER_OPTIONS = new InjectionToken<string>('McNumberFormatterOptions');\n\nexport const MC_NUMBER_FORMATTER_DEFAULT_OPTIONS: ParsedDigitsInfo = {\n    useGrouping: true,\n    minimumIntegerDigits: 1,\n    minimumFractionDigits: 0,\n    maximumFractionDigits: 3\n};\n\nexport const DEFAULT_MC_LOCALE_ID = 'ru';\n\n\nfunction isEmpty(value: any): boolean {\n    return value == null || value === '' || value !== value;\n}\n\nfunction strToNumber(value: number | string): number {\n    if (typeof value === 'string' && !isNaN(Number(value) - parseFloat(value))) {\n        return Number(value);\n    }\n\n    if (typeof value !== 'number') {\n        throw new Error(`${value} is not a number`);\n    }\n\n    return value;\n}\n\nexport const NUMBER_FORMAT_REGEXP = /^(\\d+)?\\.((\\d+)(-(\\d+))?(-(true|false))?)?$/;\n\nconst minIntGroupPosition = 1;\nconst minFractionGroupPosition = 3;\nconst maxFractionGroupPosition = 5;\nconst useGroupingPosition = 7;\n\ninterface NumberFormatOptions {\n    useGrouping: boolean;\n\n    minimumIntegerDigits: number;\n    minimumFractionDigits: number;\n    maximumFractionDigits: number;\n    minimumSignificantDigits: number;\n    maximumSignificantDigits: number;\n\n    localeMatcher?: string;\n    style?: string;\n\n    currency?: string;\n    currencyDisplay?: string;\n}\n\nclass ParsedDigitsInfo {\n    useGrouping: boolean;\n    minimumIntegerDigits: number;\n    minimumFractionDigits: number;\n    maximumFractionDigits: number;\n}\n\nfunction parseDigitsInfo(digitsInfo: string): ParsedDigitsInfo {\n    const parts = digitsInfo.match(NUMBER_FORMAT_REGEXP);\n\n    if (parts === null) {\n        throw new Error(`${digitsInfo} is not a valid digit info`);\n    }\n\n    const minIntPart = parts[minIntGroupPosition];\n    const minFractionPart = parts[minFractionGroupPosition];\n    const maxFractionPart = parts[maxFractionGroupPosition];\n    const useGroupingPart = parts[useGroupingPosition];\n\n    const result = new ParsedDigitsInfo();\n\n    if (minIntPart != null) {\n        result.minimumIntegerDigits = parseInt(minIntPart);\n    }\n\n    if (minFractionPart != null) {\n        result.minimumFractionDigits = parseInt(minFractionPart);\n    }\n\n    if (maxFractionPart != null) {\n        result.maximumFractionDigits = parseInt(maxFractionPart);\n    } else if (minFractionPart != null && result.minimumFractionDigits > result.maximumFractionDigits) {\n        result.maximumFractionDigits = result.minimumFractionDigits;\n    }\n\n    if (useGroupingPart != null) {\n        result.useGrouping = useGroupingPart === 'true';\n    }\n\n    return result;\n}\n\n\n@Injectable({ providedIn: 'root' })\n@Pipe({name: 'mcNumber'})\nexport class McDecimalPipe implements PipeTransform {\n    constructor(\n        @Optional() @Inject(MC_LOCALE_ID) private locale: string,\n        @Optional() @Inject(MC_NUMBER_FORMATTER_OPTIONS) private readonly options: ParsedDigitsInfo\n    ) {\n        this.options = this.options || MC_NUMBER_FORMATTER_DEFAULT_OPTIONS;\n    }\n\n    /**\n     * @param value The number to be formatted.\n     * @param digitsInfo Decimal representation options, specified by a string\n     * in the following format:<br>\n     * <code>{minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}</code>.\n     *   - `minIntegerDigits`: The minimum number of integer digits before the decimal point.\n     * Default is `1`.\n     *   - `minFractionDigits`: The minimum number of digits after the decimal point.\n     * Default is `0`.\n     *   - `maxFractionDigits`: The maximum number of digits after the decimal point.\n     * Default is `3`.\n     * @param locale A locale code for the locale format rules to use.\n     * When not supplied, uses the value of `MC_LOCALE_ID`, which is `ru` by default.\n     */\n    transform(value: any, digitsInfo?: string, locale?: string): string | null {\n        if (isEmpty(value)) { return null; }\n\n        const currentLocale = locale || this.locale || DEFAULT_MC_LOCALE_ID;\n\n        let parsedDigitsInfo;\n\n        if (digitsInfo) {\n            parsedDigitsInfo = parseDigitsInfo(digitsInfo);\n        }\n\n        const options: NumberFormatOptions = {\n            ...this.options,\n            ...parsedDigitsInfo\n        };\n\n        try {\n            const num = strToNumber(value);\n\n            return Intl.NumberFormat.call(this, currentLocale, options).format(num);\n        } catch (error: any) {\n            throw Error(`InvalidPipeArgument: McDecimalPipe for pipe '${JSON.stringify(error.message)}'`);\n        }\n    }\n}\n"]}
|
@@ -24,4 +24,4 @@ export const MC_SELECT_SCROLL_STRATEGY_PROVIDER = {
|
|
24
24
|
deps: [Overlay],
|
25
25
|
useFactory: mcSelectScrollStrategyProviderFactory
|
26
26
|
};
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbW9zYWljL2NvcmUvc2VsZWN0L2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWtCLE9BQU8sRUFBNEIsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9DLG1EQUFtRDtBQUNuRCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxHQUFHLENBQUM7QUFFM0Msd0NBQXdDO0FBQ3hDLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLENBQUMsQ0FBQztBQUV4QyxvRkFBb0Y7QUFDcEYsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHLHNCQUFzQixHQUFHLENBQUMsQ0FBQztBQUV4RTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxDQUFDLENBQUM7QUFHL0Msa0ZBQWtGO0FBQ2xGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUNsQyxJQUFJLGNBQWMsQ0FBdUIsMkJBQTJCLENBQUMsQ0FBQztBQUUxRSxvQkFBb0I7QUFDcEIsTUFBTSxVQUFVLHFDQUFxQyxDQUFDLE9BQWdCO0lBQ2xFLE9BQU8sR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxDQUFDO0FBQ3ZELENBQUM7QUFFRCxvQkFBb0I7QUFDcEIsTUFBTSxDQUFDLE1BQU0sa0NBQWtDLEdBQUc7SUFDOUMsT0FBTyxFQUFFLHlCQUF5QjtJQUNsQyxJQUFJLEVBQUUsQ0FBQyxPQUFPLENBQUM7SUFDZixVQUFVLEVBQUUscUNBQXFDO0NBQ3BELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTY3JvbGxTdHJhdGVneSwgT3ZlcmxheSwgUmVwb3NpdGlvblNjcm9sbFN0cmF0ZWd5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG4vKiogVGhlIG1heCBoZWlnaHQgb2YgdGhlIHNlbGVjdCdzIG92ZXJsYXkgcGFuZWwgKi9cbmV4cG9ydCBjb25zdCBTRUxFQ1RfUEFORUxfTUFYX0hFSUdIVCA9IDIyNDtcblxuLyoqIFRoZSBwYW5lbCdzIHBhZGRpbmcgb24gdGhlIHgtYXhpcyAqL1xuZXhwb3J0IGNvbnN0IFNFTEVDVF9QQU5FTF9QQURESU5HX1ggPSAxO1xuXG4vKiogVGhlIHBhbmVsJ3MgeCBheGlzIHBhZGRpbmcgaWYgaXQgaXMgaW5kZW50ZWQgKGUuZy4gdGhlcmUgaXMgYW4gb3B0aW9uIGdyb3VwKS4gKi9cbi8qIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTpuby1tYWdpYy1udW1iZXJzICovXG5leHBvcnQgY29uc3QgU0VMRUNUX1BBTkVMX0lOREVOVF9QQURESU5HX1ggPSBTRUxFQ1RfUEFORUxfUEFERElOR19YICogMjtcblxuLyoqXG4gKiBUaGUgc2VsZWN0IHBhbmVsIHdpbGwgb25seSBcImZpdFwiIGluc2lkZSB0aGUgdmlld3BvcnQgaWYgaXQgaXMgcG9zaXRpb25lZCBhdFxuICogdGhpcyB2YWx1ZSBvciBtb3JlIGF3YXkgZnJvbSB0aGUgdmlld3BvcnQgYm91bmRhcnkuXG4gKi9cbmV4cG9ydCBjb25zdCBTRUxFQ1RfUEFORUxfVklFV1BPUlRfUEFERElORyA9IDg7XG5cblxuLyoqIEluamVjdGlvbiB0b2tlbiB0aGF0IGRldGVybWluZXMgdGhlIHNjcm9sbCBoYW5kbGluZyB3aGlsZSBhIHNlbGVjdCBpcyBvcGVuLiAqL1xuZXhwb3J0IGNvbnN0IE1DX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1kgPVxuICAgIG5ldyBJbmplY3Rpb25Ub2tlbjwoKSA9PiBTY3JvbGxTdHJhdGVneT4oJ21jLXNlbGVjdC1zY3JvbGwtc3RyYXRlZ3knKTtcblxuLyoqIEBkb2NzLXByaXZhdGUgKi9cbmV4cG9ydCBmdW5jdGlvbiBtY1NlbGVjdFNjcm9sbFN0cmF0ZWd5UHJvdmlkZXJGYWN0b3J5KG92ZXJsYXk6IE92ZXJsYXkpOiAoKSA9PiBSZXBvc2l0aW9uU2Nyb2xsU3RyYXRlZ3kge1xuICAgIHJldHVybiAoKSA9PiBvdmVybGF5LnNjcm9sbFN0cmF0ZWdpZXMucmVwb3NpdGlvbigpO1xufVxuXG4vKiogQGRvY3MtcHJpdmF0ZSAqL1xuZXhwb3J0IGNvbnN0IE1DX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1lfUFJPVklERVIgPSB7XG4gICAgcHJvdmlkZTogTUNfU0VMRUNUX1NDUk9MTF9TVFJBVEVHWSxcbiAgICBkZXBzOiBbT3ZlcmxheV0sXG4gICAgdXNlRmFjdG9yeTogbWNTZWxlY3RTY3JvbGxTdHJhdGVneVByb3ZpZGVyRmFjdG9yeVxufTtcbiJdfQ==
|
package/esm2020/core/version.mjs
CHANGED
@@ -1,3 +1,3 @@
|
|
1
1
|
import { Version } from '@angular/core';
|
2
|
-
export const VERSION = new Version('14.
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
2
|
+
export const VERSION = new Version('14.2.6+sha-9dfb9002');
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUd4QyxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMscUJBQXFCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZlcnNpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxNC4yLjYrc2hhLTlkZmI5MDAyJyk7XG4iXX0=
|
@@ -76,14 +76,14 @@ export class McCalendarBody {
|
|
76
76
|
}
|
77
77
|
}
|
78
78
|
/** @nocollapse */ McCalendarBody.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: McCalendarBody, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
79
|
-
/** @nocollapse */ McCalendarBody.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.5", type: McCalendarBody, selector: "[mc-calendar-body]", inputs: { label: "label", rows: "rows", todayValue: "todayValue", selectedValue: "selectedValue", labelMinRequiredCells: "labelMinRequiredCells", numCols: "numCols", activeCell: "activeCell", cellAspectRatio: "cellAspectRatio" }, outputs: { selectedValueChange: "selectedValueChange" }, host: { attributes: { "role": "grid", "aria-readonly": "true" }, classAttribute: "mc-calendar__body" }, exportAs: ["mcCalendarBody"], usesOnChanges: true, ngImport: i0, template: "<!--\n If there's not enough space in the first row, create a separate label row. We mark this row as\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n<tr *ngIf=\"firstRowOffset < labelMinRequiredCells\">\n <td class=\"mc-calendar__body-label\" [attr.colspan]=\"numCols\">\n {{ label }}\n </td>\n</tr>\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n<tr *ngFor=\"let row of rows; let rowIndex = index\">\n <!--\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n The aspect ratio of the table cells is maintained by setting the top and bottom padding as a\n percentage of the width (a variant of the trick described here:\n https://www.w3schools.com/howto/howto_css_aspect_ratio.asp).\n -->\n <td *ngIf=\"rowIndex === 0 && firstRowOffset\"\n class=\"mc-calendar__body-label\"\n [attr.colspan]=\"firstRowOffset\">\n {{ firstRowOffset >= labelMinRequiredCells ? label : '' }}\n </td>\n <td *ngFor=\"let item of row; let colIndex = index\"\n class=\"mc-calendar__body-cell\"\n [ngClass]=\"item.cssClasses!\"\n [tabindex]=\"isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n [class.mc-calendar__body_disabled]=\"!item.enabled\"\n [class.mc-calendar__body_active]=\"isActiveCell(rowIndex, colIndex)\"\n (click)=\"cellClicked(item)\"\n [style.width]=\"cellWidth\"\n [style.paddingTop]=\"cellPadding\"\n [style.paddingBottom]=\"cellPadding\">\n <div class=\"mc-calendar__body-cell-content\"\n [class.mc-selected]=\"selectedValue === item.value\"\n [class.mc-calendar__body-today]=\"todayValue === item.value\">\n {{ item.displayValue }}\n </div>\n </td>\n</tr>\n", styles: [".mc-calendar__body{min-width:224px;min-width:calc(7 * var(--mc-datepicker-body-size-cell-min-size, 32px))}.mc-calendar__body-label{text-align:left;padding:8px 28px 12px 12px;padding:var(--mc-datepicker-body-size-label-paddings, 8px 28px 12px 12px)}.mc-calendar__body-cell{position:relative;height:0;line-height:0;text-align:center;outline:none;cursor:pointer}.mc-calendar__body_disabled{cursor:default}.mc-calendar__body-cell-content{position:absolute;top:5%;top:var(--mc-datepicker-body-size-cell-margin, 5%);left:5%;left:var(--mc-datepicker-body-size-cell-margin, 5%);padding:8px;padding:var(--mc-datepicker-body-size-cell-padding, 8px);display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;line-height:1;border-width:1px;border-width:var(--mc-datepicker-body-size-cell-border-width, 1px);border-style:solid}.cdk-high-contrast-active .mc-calendar__body-cell-content{border:none}.cdk-high-contrast-active :host .mc-calendar__body-cell-content{border:none}mc-month-view .mc-calendar__body-cell-content{justify-content:flex-end}mc-multi-year-view .mc-calendar__body-cell-content,mc-year-view .mc-calendar__body-cell-content{justify-content:center}.cdk-high-contrast-active .mc-datepicker__popup:not(:empty),.cdk-high-contrast-active .mc-selected{outline:solid 1px}.cdk-high-contrast-active .mc-calendar__body-today{outline:dotted 1px}.cdk-high-contrast-active :host .mc-datepicker__popup:not(:empty),.cdk-high-contrast-active :host .mc-selected{outline:solid 1px}.cdk-high-contrast-active :host .mc-calendar__body-today{outline:dotted 1px}[dir=rtl] .mc-calendar__body-label{text-align:right}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
79
|
+
/** @nocollapse */ McCalendarBody.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.5", type: McCalendarBody, selector: "[mc-calendar-body]", inputs: { label: "label", rows: "rows", todayValue: "todayValue", selectedValue: "selectedValue", labelMinRequiredCells: "labelMinRequiredCells", numCols: "numCols", activeCell: "activeCell", cellAspectRatio: "cellAspectRatio" }, outputs: { selectedValueChange: "selectedValueChange" }, host: { attributes: { "role": "grid", "aria-readonly": "true" }, classAttribute: "mc-calendar__body" }, exportAs: ["mcCalendarBody"], usesOnChanges: true, ngImport: i0, template: "<!--\n If there's not enough space in the first row, create a separate label row. We mark this row as\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n<tr *ngIf=\"firstRowOffset < labelMinRequiredCells\">\n <td class=\"mc-calendar__body-label\" [attr.colspan]=\"numCols\">\n {{ label }}\n </td>\n</tr>\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n<tr *ngFor=\"let row of rows; let rowIndex = index\">\n <!--\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n The aspect ratio of the table cells is maintained by setting the top and bottom padding as a\n percentage of the width (a variant of the trick described here:\n https://www.w3schools.com/howto/howto_css_aspect_ratio.asp).\n -->\n <td *ngIf=\"rowIndex === 0 && firstRowOffset\"\n class=\"mc-calendar__body-label\"\n [attr.colspan]=\"firstRowOffset\">\n {{ firstRowOffset >= labelMinRequiredCells ? label : '' }}\n </td>\n <td *ngFor=\"let item of row; let colIndex = index\"\n class=\"mc-calendar__body-cell\"\n [ngClass]=\"item.cssClasses!\"\n [tabindex]=\"isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n [class.mc-calendar__body_disabled]=\"!item.enabled\"\n [class.mc-calendar__body_active]=\"isActiveCell(rowIndex, colIndex)\"\n (click)=\"cellClicked(item)\"\n [style.width]=\"cellWidth\"\n [style.paddingTop]=\"cellPadding\"\n [style.paddingBottom]=\"cellPadding\">\n <div class=\"mc-calendar__body-cell-content\"\n [class.mc-selected]=\"selectedValue === item.value\"\n [class.mc-calendar__body-today]=\"todayValue === item.value\">\n {{ item.displayValue }}\n </div>\n </td>\n</tr>\n", styles: [".mc-calendar__body{min-width:224px;min-width:calc(7 * var(--mc-datepicker-body-size-cell-min-size, 32px))}.mc-calendar__body-label{text-align:left;padding:8px 28px 12px 12px;padding:var(--mc-datepicker-body-size-label-paddings, 8px 28px 12px 12px)}.mc-calendar__body-cell{position:relative;height:0;line-height:0;text-align:center;outline:none;cursor:pointer}.mc-calendar__body_disabled{cursor:default}.mc-calendar__body-cell-content{position:absolute;top:5%;top:var(--mc-datepicker-body-size-cell-margin, 5%);left:5%;left:var(--mc-datepicker-body-size-cell-margin, 5%);padding:8px;padding:var(--mc-datepicker-body-size-cell-padding, 8px);display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;line-height:1;border-width:1px;border-width:var(--mc-datepicker-body-size-cell-border-width, 1px);border-radius:0;border-radius:var(--mc-datepicker-body-size-cell-border-radius, 0);border-style:solid}.cdk-high-contrast-active .mc-calendar__body-cell-content{border:none}.cdk-high-contrast-active :host .mc-calendar__body-cell-content{border:none}mc-month-view .mc-calendar__body-cell-content{justify-content:flex-end}mc-multi-year-view .mc-calendar__body-cell-content,mc-year-view .mc-calendar__body-cell-content{justify-content:center}.cdk-high-contrast-active .mc-datepicker__popup:not(:empty),.cdk-high-contrast-active .mc-selected{outline:solid 1px}.cdk-high-contrast-active .mc-calendar__body-today{outline:dotted 1px}.cdk-high-contrast-active :host .mc-datepicker__popup:not(:empty),.cdk-high-contrast-active :host .mc-selected{outline:solid 1px}.cdk-high-contrast-active :host .mc-calendar__body-today{outline:dotted 1px}[dir=rtl] .mc-calendar__body-label{text-align:right}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
80
80
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: McCalendarBody, decorators: [{
|
81
81
|
type: Component,
|
82
82
|
args: [{ selector: '[mc-calendar-body]', exportAs: 'mcCalendarBody', host: {
|
83
83
|
class: 'mc-calendar__body',
|
84
84
|
role: 'grid',
|
85
85
|
'aria-readonly': 'true'
|
86
|
-
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--\n If there's not enough space in the first row, create a separate label row. We mark this row as\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n<tr *ngIf=\"firstRowOffset < labelMinRequiredCells\">\n <td class=\"mc-calendar__body-label\" [attr.colspan]=\"numCols\">\n {{ label }}\n </td>\n</tr>\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n<tr *ngFor=\"let row of rows; let rowIndex = index\">\n <!--\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n The aspect ratio of the table cells is maintained by setting the top and bottom padding as a\n percentage of the width (a variant of the trick described here:\n https://www.w3schools.com/howto/howto_css_aspect_ratio.asp).\n -->\n <td *ngIf=\"rowIndex === 0 && firstRowOffset\"\n class=\"mc-calendar__body-label\"\n [attr.colspan]=\"firstRowOffset\">\n {{ firstRowOffset >= labelMinRequiredCells ? label : '' }}\n </td>\n <td *ngFor=\"let item of row; let colIndex = index\"\n class=\"mc-calendar__body-cell\"\n [ngClass]=\"item.cssClasses!\"\n [tabindex]=\"isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n [class.mc-calendar__body_disabled]=\"!item.enabled\"\n [class.mc-calendar__body_active]=\"isActiveCell(rowIndex, colIndex)\"\n (click)=\"cellClicked(item)\"\n [style.width]=\"cellWidth\"\n [style.paddingTop]=\"cellPadding\"\n [style.paddingBottom]=\"cellPadding\">\n <div class=\"mc-calendar__body-cell-content\"\n [class.mc-selected]=\"selectedValue === item.value\"\n [class.mc-calendar__body-today]=\"todayValue === item.value\">\n {{ item.displayValue }}\n </div>\n </td>\n</tr>\n", styles: [".mc-calendar__body{min-width:224px;min-width:calc(7 * var(--mc-datepicker-body-size-cell-min-size, 32px))}.mc-calendar__body-label{text-align:left;padding:8px 28px 12px 12px;padding:var(--mc-datepicker-body-size-label-paddings, 8px 28px 12px 12px)}.mc-calendar__body-cell{position:relative;height:0;line-height:0;text-align:center;outline:none;cursor:pointer}.mc-calendar__body_disabled{cursor:default}.mc-calendar__body-cell-content{position:absolute;top:5%;top:var(--mc-datepicker-body-size-cell-margin, 5%);left:5%;left:var(--mc-datepicker-body-size-cell-margin, 5%);padding:8px;padding:var(--mc-datepicker-body-size-cell-padding, 8px);display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;line-height:1;border-width:1px;border-width:var(--mc-datepicker-body-size-cell-border-width, 1px);border-style:solid}.cdk-high-contrast-active .mc-calendar__body-cell-content{border:none}.cdk-high-contrast-active :host .mc-calendar__body-cell-content{border:none}mc-month-view .mc-calendar__body-cell-content{justify-content:flex-end}mc-multi-year-view .mc-calendar__body-cell-content,mc-year-view .mc-calendar__body-cell-content{justify-content:center}.cdk-high-contrast-active .mc-datepicker__popup:not(:empty),.cdk-high-contrast-active .mc-selected{outline:solid 1px}.cdk-high-contrast-active .mc-calendar__body-today{outline:dotted 1px}.cdk-high-contrast-active :host .mc-datepicker__popup:not(:empty),.cdk-high-contrast-active :host .mc-selected{outline:solid 1px}.cdk-high-contrast-active :host .mc-calendar__body-today{outline:dotted 1px}[dir=rtl] .mc-calendar__body-label{text-align:right}\n"] }]
|
86
|
+
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--\n If there's not enough space in the first row, create a separate label row. We mark this row as\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n<tr *ngIf=\"firstRowOffset < labelMinRequiredCells\">\n <td class=\"mc-calendar__body-label\" [attr.colspan]=\"numCols\">\n {{ label }}\n </td>\n</tr>\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n<tr *ngFor=\"let row of rows; let rowIndex = index\">\n <!--\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n The aspect ratio of the table cells is maintained by setting the top and bottom padding as a\n percentage of the width (a variant of the trick described here:\n https://www.w3schools.com/howto/howto_css_aspect_ratio.asp).\n -->\n <td *ngIf=\"rowIndex === 0 && firstRowOffset\"\n class=\"mc-calendar__body-label\"\n [attr.colspan]=\"firstRowOffset\">\n {{ firstRowOffset >= labelMinRequiredCells ? label : '' }}\n </td>\n <td *ngFor=\"let item of row; let colIndex = index\"\n class=\"mc-calendar__body-cell\"\n [ngClass]=\"item.cssClasses!\"\n [tabindex]=\"isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n [class.mc-calendar__body_disabled]=\"!item.enabled\"\n [class.mc-calendar__body_active]=\"isActiveCell(rowIndex, colIndex)\"\n (click)=\"cellClicked(item)\"\n [style.width]=\"cellWidth\"\n [style.paddingTop]=\"cellPadding\"\n [style.paddingBottom]=\"cellPadding\">\n <div class=\"mc-calendar__body-cell-content\"\n [class.mc-selected]=\"selectedValue === item.value\"\n [class.mc-calendar__body-today]=\"todayValue === item.value\">\n {{ item.displayValue }}\n </div>\n </td>\n</tr>\n", styles: [".mc-calendar__body{min-width:224px;min-width:calc(7 * var(--mc-datepicker-body-size-cell-min-size, 32px))}.mc-calendar__body-label{text-align:left;padding:8px 28px 12px 12px;padding:var(--mc-datepicker-body-size-label-paddings, 8px 28px 12px 12px)}.mc-calendar__body-cell{position:relative;height:0;line-height:0;text-align:center;outline:none;cursor:pointer}.mc-calendar__body_disabled{cursor:default}.mc-calendar__body-cell-content{position:absolute;top:5%;top:var(--mc-datepicker-body-size-cell-margin, 5%);left:5%;left:var(--mc-datepicker-body-size-cell-margin, 5%);padding:8px;padding:var(--mc-datepicker-body-size-cell-padding, 8px);display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;line-height:1;border-width:1px;border-width:var(--mc-datepicker-body-size-cell-border-width, 1px);border-radius:0;border-radius:var(--mc-datepicker-body-size-cell-border-radius, 0);border-style:solid}.cdk-high-contrast-active .mc-calendar__body-cell-content{border:none}.cdk-high-contrast-active :host .mc-calendar__body-cell-content{border:none}mc-month-view .mc-calendar__body-cell-content{justify-content:flex-end}mc-multi-year-view .mc-calendar__body-cell-content,mc-year-view .mc-calendar__body-cell-content{justify-content:center}.cdk-high-contrast-active .mc-datepicker__popup:not(:empty),.cdk-high-contrast-active .mc-selected{outline:solid 1px}.cdk-high-contrast-active .mc-calendar__body-today{outline:dotted 1px}.cdk-high-contrast-active :host .mc-datepicker__popup:not(:empty),.cdk-high-contrast-active :host .mc-selected{outline:solid 1px}.cdk-high-contrast-active :host .mc-calendar__body-today{outline:dotted 1px}[dir=rtl] .mc-calendar__body-label{text-align:right}\n"] }]
|
87
87
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }]; }, propDecorators: { label: [{
|
88
88
|
type: Input
|
89
89
|
}], rows: [{
|