@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.
Files changed (79) hide show
  1. package/_theming.scss +13 -4
  2. package/_visual.scss +8 -3
  3. package/core/formatters/date/formatter.pipe.d.ts +79 -66
  4. package/core/formatters/number/formatter.d.ts +13 -3
  5. package/datepicker/datepicker-input.directive.d.ts +1 -0
  6. package/design-tokens/legacy-2017/tokens/components/datepicker.json5 +15 -6
  7. package/design-tokens/legacy-2017/tokens/components/popup.json5 +1 -1
  8. package/design-tokens/legacy-2017/tokens.d.ts +9 -3
  9. package/design-tokens/pt-2022/tokens/components/datepicker.json5 +13 -4
  10. package/design-tokens/pt-2022/tokens/components/popup.json5 +1 -1
  11. package/design-tokens/pt-2022/tokens/components/sidepanel.json5 +1 -2
  12. package/design-tokens/pt-2022/tokens.d.ts +8 -3
  13. package/esm2020/core/formatters/date/formatter.pipe.mjs +87 -54
  14. package/esm2020/core/formatters/number/formatter.mjs +26 -10
  15. package/esm2020/core/select/constants.mjs +1 -1
  16. package/esm2020/core/version.mjs +2 -2
  17. package/esm2020/datepicker/calendar-body.component.mjs +2 -2
  18. package/esm2020/datepicker/datepicker-input.directive.mjs +9 -6
  19. package/esm2020/datepicker/datepicker.component.mjs +3 -3
  20. package/esm2020/design-tokens/legacy-2017/tokens.mjs +10 -4
  21. package/esm2020/design-tokens/pt-2022/tokens.mjs +9 -4
  22. package/esm2020/form-field/form-field.mjs +50 -9
  23. package/esm2020/form-field/form-field.module.mjs +10 -6
  24. package/esm2020/form-field/password-hint.mjs +4 -4
  25. package/esm2020/input/input.mjs +10 -21
  26. package/esm2020/progress-spinner/progress-spinner.component.mjs +2 -2
  27. package/esm2020/select/select.component.mjs +10 -2
  28. package/esm2020/sidepanel/sidepanel-container.component.mjs +3 -3
  29. package/esm2020/sidepanel/sidepanel-directives.mjs +16 -11
  30. package/esm2020/tags/tag-input.mjs +19 -7
  31. package/esm2020/toast/toast.service.mjs +5 -4
  32. package/fesm2015/ptsecurity-mosaic-core.mjs +110 -60
  33. package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
  34. package/fesm2015/ptsecurity-mosaic-datepicker.mjs +12 -9
  35. package/fesm2015/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  36. package/fesm2015/ptsecurity-mosaic-design-tokens.mjs +26 -9
  37. package/fesm2015/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
  38. package/fesm2015/ptsecurity-mosaic-form-field.mjs +62 -15
  39. package/fesm2015/ptsecurity-mosaic-form-field.mjs.map +1 -1
  40. package/fesm2015/ptsecurity-mosaic-input.mjs +10 -20
  41. package/fesm2015/ptsecurity-mosaic-input.mjs.map +1 -1
  42. package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs +2 -2
  43. package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  44. package/fesm2015/ptsecurity-mosaic-select.mjs +9 -1
  45. package/fesm2015/ptsecurity-mosaic-select.mjs.map +1 -1
  46. package/fesm2015/ptsecurity-mosaic-sidepanel.mjs +18 -13
  47. package/fesm2015/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  48. package/fesm2015/ptsecurity-mosaic-tags.mjs +19 -8
  49. package/fesm2015/ptsecurity-mosaic-tags.mjs.map +1 -1
  50. package/fesm2015/ptsecurity-mosaic-toast.mjs +4 -3
  51. package/fesm2015/ptsecurity-mosaic-toast.mjs.map +1 -1
  52. package/fesm2020/ptsecurity-mosaic-core.mjs +110 -63
  53. package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
  54. package/fesm2020/ptsecurity-mosaic-datepicker.mjs +12 -9
  55. package/fesm2020/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  56. package/fesm2020/ptsecurity-mosaic-design-tokens.mjs +26 -9
  57. package/fesm2020/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
  58. package/fesm2020/ptsecurity-mosaic-form-field.mjs +60 -17
  59. package/fesm2020/ptsecurity-mosaic-form-field.mjs.map +1 -1
  60. package/fesm2020/ptsecurity-mosaic-input.mjs +9 -20
  61. package/fesm2020/ptsecurity-mosaic-input.mjs.map +1 -1
  62. package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs +2 -2
  63. package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  64. package/fesm2020/ptsecurity-mosaic-select.mjs +9 -1
  65. package/fesm2020/ptsecurity-mosaic-select.mjs.map +1 -1
  66. package/fesm2020/ptsecurity-mosaic-sidepanel.mjs +18 -13
  67. package/fesm2020/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  68. package/fesm2020/ptsecurity-mosaic-tags.mjs +16 -5
  69. package/fesm2020/ptsecurity-mosaic-tags.mjs.map +1 -1
  70. package/fesm2020/ptsecurity-mosaic-toast.mjs +4 -3
  71. package/fesm2020/ptsecurity-mosaic-toast.mjs.map +1 -1
  72. package/form-field/form-field.d.ts +12 -2
  73. package/form-field/form-field.module.d.ts +1 -1
  74. package/input/input.d.ts +1 -2
  75. package/package.json +4 -4
  76. package/prebuilt-themes/dark-theme.css +1 -1
  77. package/prebuilt-themes/default-theme.css +1 -1
  78. package/select/select.component.d.ts +2 -0
  79. 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 "./formatter";
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
- return this.formatter.absoluteLongDate(value, currYear);
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
- return this.formatter.absoluteLongDateTime(value, options);
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
- return this.formatter.absoluteShortDate(value, currYear);
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
- return this.formatter.absoluteShortDateTime(value, options);
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
- return this.formatter.relativeLongDate(value);
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
- return this.formatter.relativeLongDateTime(value, options);
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
- return this.formatter.relativeShortDate(value);
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
- return this.formatter.relativeShortDateTime(value, options);
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
- return this.formatter.rangeLongDate(value1, value2);
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
- return this.formatter.rangeShortDate(value1, value2);
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
- return this.formatter.rangeLongDateTime(value1, value2, options);
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
- return this.formatter.rangeMiddleDateTime(value1, value2, options);
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
- return this.formatter.rangeShortDateTime(value1, value2, options);
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(_locale) {
49
- this._locale = _locale;
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._locale || DEFAULT_MC_LOCALE_ID;
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
- useGrouping: true,
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbW9zYWljL2NvcmUvc2VsZWN0L2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWtCLE9BQU8sRUFBNEIsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9DLG1EQUFtRDtBQUNuRCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxHQUFHLENBQUM7QUFFM0Msd0NBQXdDO0FBQ3hDLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLENBQUMsQ0FBQztBQUV4QyxvRkFBb0Y7QUFDcEYsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHLHNCQUFzQixHQUFHLENBQUMsQ0FBQztBQUV4RTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxDQUFDLENBQUM7QUFHL0Msa0ZBQWtGO0FBQ2xGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUNsQyxJQUFJLGNBQWMsQ0FBdUIsMkJBQTJCLENBQUMsQ0FBQztBQUUxRSxvQkFBb0I7QUFDcEIsTUFBTSxVQUFVLHFDQUFxQyxDQUFDLE9BQWdCO0lBRWxFLE9BQU8sR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxDQUFDO0FBQ3ZELENBQUM7QUFFRCxvQkFBb0I7QUFDcEIsTUFBTSxDQUFDLE1BQU0sa0NBQWtDLEdBQUc7SUFDOUMsT0FBTyxFQUFFLHlCQUF5QjtJQUNsQyxJQUFJLEVBQUUsQ0FBQyxPQUFPLENBQUM7SUFDZixVQUFVLEVBQUUscUNBQXFDO0NBQ3BELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTY3JvbGxTdHJhdGVneSwgT3ZlcmxheSwgUmVwb3NpdGlvblNjcm9sbFN0cmF0ZWd5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG4vKiogVGhlIG1heCBoZWlnaHQgb2YgdGhlIHNlbGVjdCdzIG92ZXJsYXkgcGFuZWwgKi9cbmV4cG9ydCBjb25zdCBTRUxFQ1RfUEFORUxfTUFYX0hFSUdIVCA9IDIyNDtcblxuLyoqIFRoZSBwYW5lbCdzIHBhZGRpbmcgb24gdGhlIHgtYXhpcyAqL1xuZXhwb3J0IGNvbnN0IFNFTEVDVF9QQU5FTF9QQURESU5HX1ggPSAxO1xuXG4vKiogVGhlIHBhbmVsJ3MgeCBheGlzIHBhZGRpbmcgaWYgaXQgaXMgaW5kZW50ZWQgKGUuZy4gdGhlcmUgaXMgYW4gb3B0aW9uIGdyb3VwKS4gKi9cbi8qIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTpuby1tYWdpYy1udW1iZXJzICovXG5leHBvcnQgY29uc3QgU0VMRUNUX1BBTkVMX0lOREVOVF9QQURESU5HX1ggPSBTRUxFQ1RfUEFORUxfUEFERElOR19YICogMjtcblxuLyoqXG4gKiBUaGUgc2VsZWN0IHBhbmVsIHdpbGwgb25seSBcImZpdFwiIGluc2lkZSB0aGUgdmlld3BvcnQgaWYgaXQgaXMgcG9zaXRpb25lZCBhdFxuICogdGhpcyB2YWx1ZSBvciBtb3JlIGF3YXkgZnJvbSB0aGUgdmlld3BvcnQgYm91bmRhcnkuXG4gKi9cbmV4cG9ydCBjb25zdCBTRUxFQ1RfUEFORUxfVklFV1BPUlRfUEFERElORyA9IDg7XG5cblxuLyoqIEluamVjdGlvbiB0b2tlbiB0aGF0IGRldGVybWluZXMgdGhlIHNjcm9sbCBoYW5kbGluZyB3aGlsZSBhIHNlbGVjdCBpcyBvcGVuLiAqL1xuZXhwb3J0IGNvbnN0IE1DX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1kgPVxuICAgIG5ldyBJbmplY3Rpb25Ub2tlbjwoKSA9PiBTY3JvbGxTdHJhdGVneT4oJ21jLXNlbGVjdC1zY3JvbGwtc3RyYXRlZ3knKTtcblxuLyoqIEBkb2NzLXByaXZhdGUgKi9cbmV4cG9ydCBmdW5jdGlvbiBtY1NlbGVjdFNjcm9sbFN0cmF0ZWd5UHJvdmlkZXJGYWN0b3J5KG92ZXJsYXk6IE92ZXJsYXkpOlxuICAgICgpID0+IFJlcG9zaXRpb25TY3JvbGxTdHJhdGVneSB7XG4gICAgcmV0dXJuICgpID0+IG92ZXJsYXkuc2Nyb2xsU3RyYXRlZ2llcy5yZXBvc2l0aW9uKCk7XG59XG5cbi8qKiBAZG9jcy1wcml2YXRlICovXG5leHBvcnQgY29uc3QgTUNfU0VMRUNUX1NDUk9MTF9TVFJBVEVHWV9QUk9WSURFUiA9IHtcbiAgICBwcm92aWRlOiBNQ19TRUxFQ1RfU0NST0xMX1NUUkFURUdZLFxuICAgIGRlcHM6IFtPdmVybGF5XSxcbiAgICB1c2VGYWN0b3J5OiBtY1NlbGVjdFNjcm9sbFN0cmF0ZWd5UHJvdmlkZXJGYWN0b3J5XG59O1xuIl19
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbW9zYWljL2NvcmUvc2VsZWN0L2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWtCLE9BQU8sRUFBNEIsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9DLG1EQUFtRDtBQUNuRCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxHQUFHLENBQUM7QUFFM0Msd0NBQXdDO0FBQ3hDLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLENBQUMsQ0FBQztBQUV4QyxvRkFBb0Y7QUFDcEYsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHLHNCQUFzQixHQUFHLENBQUMsQ0FBQztBQUV4RTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxDQUFDLENBQUM7QUFHL0Msa0ZBQWtGO0FBQ2xGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUNsQyxJQUFJLGNBQWMsQ0FBdUIsMkJBQTJCLENBQUMsQ0FBQztBQUUxRSxvQkFBb0I7QUFDcEIsTUFBTSxVQUFVLHFDQUFxQyxDQUFDLE9BQWdCO0lBQ2xFLE9BQU8sR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxDQUFDO0FBQ3ZELENBQUM7QUFFRCxvQkFBb0I7QUFDcEIsTUFBTSxDQUFDLE1BQU0sa0NBQWtDLEdBQUc7SUFDOUMsT0FBTyxFQUFFLHlCQUF5QjtJQUNsQyxJQUFJLEVBQUUsQ0FBQyxPQUFPLENBQUM7SUFDZixVQUFVLEVBQUUscUNBQXFDO0NBQ3BELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTY3JvbGxTdHJhdGVneSwgT3ZlcmxheSwgUmVwb3NpdGlvblNjcm9sbFN0cmF0ZWd5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG4vKiogVGhlIG1heCBoZWlnaHQgb2YgdGhlIHNlbGVjdCdzIG92ZXJsYXkgcGFuZWwgKi9cbmV4cG9ydCBjb25zdCBTRUxFQ1RfUEFORUxfTUFYX0hFSUdIVCA9IDIyNDtcblxuLyoqIFRoZSBwYW5lbCdzIHBhZGRpbmcgb24gdGhlIHgtYXhpcyAqL1xuZXhwb3J0IGNvbnN0IFNFTEVDVF9QQU5FTF9QQURESU5HX1ggPSAxO1xuXG4vKiogVGhlIHBhbmVsJ3MgeCBheGlzIHBhZGRpbmcgaWYgaXQgaXMgaW5kZW50ZWQgKGUuZy4gdGhlcmUgaXMgYW4gb3B0aW9uIGdyb3VwKS4gKi9cbi8qIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTpuby1tYWdpYy1udW1iZXJzICovXG5leHBvcnQgY29uc3QgU0VMRUNUX1BBTkVMX0lOREVOVF9QQURESU5HX1ggPSBTRUxFQ1RfUEFORUxfUEFERElOR19YICogMjtcblxuLyoqXG4gKiBUaGUgc2VsZWN0IHBhbmVsIHdpbGwgb25seSBcImZpdFwiIGluc2lkZSB0aGUgdmlld3BvcnQgaWYgaXQgaXMgcG9zaXRpb25lZCBhdFxuICogdGhpcyB2YWx1ZSBvciBtb3JlIGF3YXkgZnJvbSB0aGUgdmlld3BvcnQgYm91bmRhcnkuXG4gKi9cbmV4cG9ydCBjb25zdCBTRUxFQ1RfUEFORUxfVklFV1BPUlRfUEFERElORyA9IDg7XG5cblxuLyoqIEluamVjdGlvbiB0b2tlbiB0aGF0IGRldGVybWluZXMgdGhlIHNjcm9sbCBoYW5kbGluZyB3aGlsZSBhIHNlbGVjdCBpcyBvcGVuLiAqL1xuZXhwb3J0IGNvbnN0IE1DX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1kgPVxuICAgIG5ldyBJbmplY3Rpb25Ub2tlbjwoKSA9PiBTY3JvbGxTdHJhdGVneT4oJ21jLXNlbGVjdC1zY3JvbGwtc3RyYXRlZ3knKTtcblxuLyoqIEBkb2NzLXByaXZhdGUgKi9cbmV4cG9ydCBmdW5jdGlvbiBtY1NlbGVjdFNjcm9sbFN0cmF0ZWd5UHJvdmlkZXJGYWN0b3J5KG92ZXJsYXk6IE92ZXJsYXkpOiAoKSA9PiBSZXBvc2l0aW9uU2Nyb2xsU3RyYXRlZ3kge1xuICAgIHJldHVybiAoKSA9PiBvdmVybGF5LnNjcm9sbFN0cmF0ZWdpZXMucmVwb3NpdGlvbigpO1xufVxuXG4vKiogQGRvY3MtcHJpdmF0ZSAqL1xuZXhwb3J0IGNvbnN0IE1DX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1lfUFJPVklERVIgPSB7XG4gICAgcHJvdmlkZTogTUNfU0VMRUNUX1NDUk9MTF9TVFJBVEVHWSxcbiAgICBkZXBzOiBbT3ZlcmxheV0sXG4gICAgdXNlRmFjdG9yeTogbWNTZWxlY3RTY3JvbGxTdHJhdGVneVByb3ZpZGVyRmFjdG9yeVxufTtcbiJdfQ==
@@ -1,3 +1,3 @@
1
1
  import { Version } from '@angular/core';
2
- export const VERSION = new Version('14.3.0+sha-f3520a2');
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUd4QyxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsb0JBQW9CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZlcnNpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxNC4zLjArc2hhLWYzNTIwYTInKTtcbiJdfQ==
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: [{