@ptsecurity/mosaic 17.3.0 → 17.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 (156) hide show
  1. package/autocomplete/autocomplete-trigger.directive.d.ts +1 -0
  2. package/button/button.scss +14 -4
  3. package/checkbox/checkbox.d.ts +6 -6
  4. package/core/animation/animation.d.ts +2 -1
  5. package/core/common-behaviors/checkbox.d.ts +1 -0
  6. package/core/common-behaviors/index.d.ts +1 -0
  7. package/core/forms/index.d.ts +1 -0
  8. package/core/forms/validators.d.ts +22 -0
  9. package/core/locales/en-US.d.ts +17 -0
  10. package/core/locales/es-LA.d.ts +17 -0
  11. package/core/locales/fa-IR.d.ts +17 -0
  12. package/core/locales/index.d.ts +7 -0
  13. package/core/locales/locale-service.d.ts +175 -0
  14. package/core/locales/pt-BR.d.ts +17 -0
  15. package/core/locales/ru-RU.d.ts +17 -0
  16. package/core/locales/tk-TM.d.ts +64 -0
  17. package/core/locales/zh-CN.d.ts +17 -0
  18. package/core/pop-up/constants.d.ts +9 -0
  19. package/core/pop-up/pop-up-trigger.d.ts +25 -9
  20. package/core/pop-up/pop-up.d.ts +3 -3
  21. package/core/styles/theming/_theming.scss +1 -0
  22. package/datepicker/calendar-header.component.d.ts +11 -5
  23. package/datepicker/datepicker-input.directive.d.ts +10 -0
  24. package/dropdown/dropdown-trigger.directive.d.ts +1 -1
  25. package/ellipsis-center/ellipsis-center.directive.d.ts +3 -7
  26. package/esm2022/autocomplete/autocomplete-trigger.directive.mjs +13 -5
  27. package/esm2022/button/button.component.mjs +2 -2
  28. package/esm2022/checkbox/checkbox.mjs +5 -5
  29. package/esm2022/code-block/actionbar.component.mjs +1 -1
  30. package/esm2022/core/animation/animation.mjs +2 -1
  31. package/esm2022/core/common-behaviors/checkbox.mjs +2 -0
  32. package/esm2022/core/common-behaviors/index.mjs +2 -1
  33. package/esm2022/core/forms/index.mjs +2 -1
  34. package/esm2022/core/forms/validators.mjs +33 -0
  35. package/esm2022/core/locales/en-US.mjs +19 -2
  36. package/esm2022/core/locales/es-LA.mjs +19 -2
  37. package/esm2022/core/locales/fa-IR.mjs +19 -2
  38. package/esm2022/core/locales/index.mjs +8 -1
  39. package/esm2022/core/locales/locale-service.mjs +39 -3
  40. package/esm2022/core/locales/pt-BR.mjs +19 -2
  41. package/esm2022/core/locales/ru-RU.mjs +19 -2
  42. package/esm2022/core/locales/tk-TM.mjs +63 -0
  43. package/esm2022/core/locales/zh-CN.mjs +19 -2
  44. package/esm2022/core/pop-up/constants.mjs +6 -1
  45. package/esm2022/core/pop-up/pop-up-trigger.mjs +68 -21
  46. package/esm2022/core/pop-up/pop-up.mjs +7 -6
  47. package/esm2022/core/version.mjs +2 -2
  48. package/esm2022/datepicker/calendar-header.component.mjs +40 -10
  49. package/esm2022/datepicker/datepicker-input.directive.mjs +103 -23
  50. package/esm2022/dropdown/dropdown-trigger.directive.mjs +2 -2
  51. package/esm2022/ellipsis-center/ellipsis-center.directive.mjs +12 -23
  52. package/esm2022/file-upload/file-upload.mjs +39 -2
  53. package/esm2022/file-upload/file-upload.module.mjs +8 -1
  54. package/esm2022/file-upload/multiple-file-upload.component.mjs +157 -42
  55. package/esm2022/file-upload/single-file-upload.component.mjs +140 -38
  56. package/esm2022/form-field/form-field.mjs +6 -6
  57. package/esm2022/form-field/validate.directive.mjs +5 -2
  58. package/esm2022/input/input-number.mjs +31 -59
  59. package/esm2022/input/input-password.mjs +15 -26
  60. package/esm2022/input/input.mjs +3 -3
  61. package/esm2022/loader-overlay/loader-overlay.component.mjs +10 -8
  62. package/esm2022/modal/modal.component.mjs +3 -3
  63. package/esm2022/modal/modal.directive.mjs +38 -7
  64. package/esm2022/navbar/navbar-item.component.mjs +16 -30
  65. package/esm2022/popover/popover-confirm.component.mjs +11 -20
  66. package/esm2022/popover/popover.component.mjs +27 -29
  67. package/esm2022/progress-spinner/progress-spinner.component.mjs +2 -2
  68. package/esm2022/select/select-option.directive.mjs +7 -18
  69. package/esm2022/select/select.component.mjs +9 -6
  70. package/esm2022/sidebar/sidebar.component.mjs +10 -6
  71. package/esm2022/tabs/tab-group.component.mjs +1 -1
  72. package/esm2022/tabs/tab-header.component.mjs +2 -2
  73. package/esm2022/timezone/timezone-option.directive.mjs +7 -18
  74. package/esm2022/title/title.directive.mjs +7 -18
  75. package/esm2022/toggle/toggle.component.mjs +103 -18
  76. package/esm2022/tooltip/tooltip.component.mjs +72 -45
  77. package/esm2022/tree-select/tree-select.component.mjs +8 -6
  78. package/fesm2022/ptsecurity-mosaic-autocomplete.mjs +12 -4
  79. package/fesm2022/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
  80. package/fesm2022/ptsecurity-mosaic-button.mjs +2 -2
  81. package/fesm2022/ptsecurity-mosaic-button.mjs.map +1 -1
  82. package/fesm2022/ptsecurity-mosaic-checkbox.mjs +4 -4
  83. package/fesm2022/ptsecurity-mosaic-checkbox.mjs.map +1 -1
  84. package/fesm2022/ptsecurity-mosaic-code-block.mjs +1 -1
  85. package/fesm2022/ptsecurity-mosaic-code-block.mjs.map +1 -1
  86. package/fesm2022/ptsecurity-mosaic-core.mjs +322 -36
  87. package/fesm2022/ptsecurity-mosaic-core.mjs.map +1 -1
  88. package/fesm2022/ptsecurity-mosaic-datepicker.mjs +141 -31
  89. package/fesm2022/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  90. package/fesm2022/ptsecurity-mosaic-dropdown.mjs +1 -1
  91. package/fesm2022/ptsecurity-mosaic-dropdown.mjs.map +1 -1
  92. package/fesm2022/ptsecurity-mosaic-ellipsis-center.mjs +11 -19
  93. package/fesm2022/ptsecurity-mosaic-ellipsis-center.mjs.map +1 -1
  94. package/fesm2022/ptsecurity-mosaic-file-upload.mjs +327 -73
  95. package/fesm2022/ptsecurity-mosaic-file-upload.mjs.map +1 -1
  96. package/fesm2022/ptsecurity-mosaic-form-field.mjs +9 -6
  97. package/fesm2022/ptsecurity-mosaic-form-field.mjs.map +1 -1
  98. package/fesm2022/ptsecurity-mosaic-input.mjs +39 -75
  99. package/fesm2022/ptsecurity-mosaic-input.mjs.map +1 -1
  100. package/fesm2022/ptsecurity-mosaic-loader-overlay.mjs +10 -8
  101. package/fesm2022/ptsecurity-mosaic-loader-overlay.mjs.map +1 -1
  102. package/fesm2022/ptsecurity-mosaic-modal.mjs +32 -7
  103. package/fesm2022/ptsecurity-mosaic-modal.mjs.map +1 -1
  104. package/fesm2022/ptsecurity-mosaic-navbar.mjs +14 -26
  105. package/fesm2022/ptsecurity-mosaic-navbar.mjs.map +1 -1
  106. package/fesm2022/ptsecurity-mosaic-popover.mjs +33 -39
  107. package/fesm2022/ptsecurity-mosaic-popover.mjs.map +1 -1
  108. package/fesm2022/ptsecurity-mosaic-progress-spinner.mjs +2 -2
  109. package/fesm2022/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  110. package/fesm2022/ptsecurity-mosaic-select.mjs +25 -28
  111. package/fesm2022/ptsecurity-mosaic-select.mjs.map +1 -1
  112. package/fesm2022/ptsecurity-mosaic-sidebar.mjs +8 -4
  113. package/fesm2022/ptsecurity-mosaic-sidebar.mjs.map +1 -1
  114. package/fesm2022/ptsecurity-mosaic-tabs.mjs +3 -3
  115. package/fesm2022/ptsecurity-mosaic-tabs.mjs.map +1 -1
  116. package/fesm2022/ptsecurity-mosaic-timezone.mjs +10 -17
  117. package/fesm2022/ptsecurity-mosaic-timezone.mjs.map +1 -1
  118. package/fesm2022/ptsecurity-mosaic-title.mjs +6 -14
  119. package/fesm2022/ptsecurity-mosaic-title.mjs.map +1 -1
  120. package/fesm2022/ptsecurity-mosaic-toggle.mjs +102 -17
  121. package/fesm2022/ptsecurity-mosaic-toggle.mjs.map +1 -1
  122. package/fesm2022/ptsecurity-mosaic-tooltip.mjs +71 -42
  123. package/fesm2022/ptsecurity-mosaic-tooltip.mjs.map +1 -1
  124. package/fesm2022/ptsecurity-mosaic-tree-select.mjs +7 -5
  125. package/fesm2022/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  126. package/file-upload/_file-upload-theme.scss +23 -13
  127. package/file-upload/file-upload.d.ts +31 -3
  128. package/file-upload/file-upload.module.d.ts +11 -10
  129. package/file-upload/file-upload.scss +8 -1
  130. package/file-upload/multiple-file-upload.component.d.ts +62 -10
  131. package/file-upload/multiple-file-upload.component.scss +0 -8
  132. package/file-upload/single-file-upload.component.d.ts +55 -11
  133. package/file-upload/single-file-upload.component.scss +0 -8
  134. package/form-field/form-field.d.ts +1 -1
  135. package/form-field/validate.directive.d.ts +5 -2
  136. package/input/input-number.d.ts +10 -11
  137. package/input/input-password.d.ts +3 -6
  138. package/input/input.d.ts +1 -1
  139. package/loader-overlay/loader-overlay.component.d.ts +4 -3
  140. package/modal/modal.directive.d.ts +4 -1
  141. package/navbar/navbar-item.component.d.ts +5 -7
  142. package/package.json +8 -8
  143. package/popover/popover-confirm.component.d.ts +3 -6
  144. package/popover/popover.component.d.ts +9 -6
  145. package/prebuilt-themes/dark-theme.css +1 -1
  146. package/prebuilt-themes/default-theme.css +1 -1
  147. package/progress-spinner/progress-spinner.scss +1 -0
  148. package/select/select-option.directive.d.ts +3 -6
  149. package/sidebar/sidebar.component.d.ts +3 -2
  150. package/tabs/tab-header.scss +2 -2
  151. package/timezone/timezone-option.directive.d.ts +3 -6
  152. package/title/title.directive.d.ts +3 -6
  153. package/toggle/_toggle-theme.scss +7 -1
  154. package/toggle/toggle.component.d.ts +23 -6
  155. package/toggle/toggle.scss +23 -0
  156. package/tooltip/tooltip.component.d.ts +25 -13
@@ -119,6 +119,7 @@ class McCalendarHeader {
119
119
  set activeDate(value) {
120
120
  this._activeDate = value;
121
121
  this.updateSelectedValues();
122
+ this.updateSelectionOptions();
122
123
  }
123
124
  get maxDate() {
124
125
  return this._maxDate;
@@ -128,7 +129,7 @@ class McCalendarHeader {
128
129
  return;
129
130
  }
130
131
  this._maxDate = value;
131
- this.updateYearsArray();
132
+ this.updateYearsOptions();
132
133
  }
133
134
  get minDate() {
134
135
  return this._minDate;
@@ -138,10 +139,14 @@ class McCalendarHeader {
138
139
  return;
139
140
  }
140
141
  this._minDate = value;
141
- this.updateYearsArray();
142
+ this.updateYearsOptions();
142
143
  }
143
144
  get previousDisabled() {
144
- return this.compareDate(this.activeDate, this.minDate) < 0;
145
+ return this.compareDate(this.activeDate, this.minDate) <= 0;
146
+ }
147
+ get currentDisabled() {
148
+ const today = this.adapter.today();
149
+ return this.compareDate(today, this.minDate) < 0 || this.compareDate(today, this.maxDate) > 0;
145
150
  }
146
151
  get nextDisabled() {
147
152
  return this.compareDate(this.activeDate, this.maxDate) >= 0;
@@ -156,11 +161,12 @@ class McCalendarHeader {
156
161
  this.activeDateChange = new EventEmitter();
157
162
  this.monthSelected = new EventEmitter();
158
163
  this.yearSelected = new EventEmitter();
159
- this.monthNames = this.adapter.getMonthNames('long')
160
- .map((name, i) => ({ name, value: i }));
164
+ this.monthNames = this.adapter.getMonthNames('long').map((name, i) => {
165
+ return { name, nameShort: this.adapter.getMonthNames('short')[i], value: i, disabled: false };
166
+ });
161
167
  }
162
168
  ngAfterContentInit() {
163
- this.updateYearsArray();
169
+ this.updateSelectionOptions();
164
170
  this.updateSelectedValues();
165
171
  }
166
172
  /** Handles when a new month is selected. */
@@ -179,6 +185,7 @@ class McCalendarHeader {
179
185
  this.activeDate = this.adapter.createDate(year, month, Math.min(this.adapter.getDate(this.activeDate), daysInMonth));
180
186
  this.yearSelected.emit(this.activeDate);
181
187
  this.activeDateChange.emit(this.activeDate);
188
+ this.updateMonthOptions();
182
189
  }
183
190
  selectCurrentDate() {
184
191
  this.activeDate = this.adapter.today();
@@ -205,7 +212,11 @@ class McCalendarHeader {
205
212
  this.selectedYear = this.years.find(({ name }) => name === year)
206
213
  || { name: year, value: this.adapter.getYearName(this.activeDate) };
207
214
  }
208
- updateYearsArray() {
215
+ updateSelectionOptions() {
216
+ this.updateYearsOptions();
217
+ this.updateMonthOptions();
218
+ }
219
+ updateYearsOptions() {
209
220
  const minYear = this.adapter.getYear(this.minDate);
210
221
  const maxYear = this.adapter.getYear(this.maxDate);
211
222
  this.years = [];
@@ -213,14 +224,33 @@ class McCalendarHeader {
213
224
  this.years.push({ name: key, value: this.adapter.getYearName(this.adapter.createDate(key)) });
214
225
  }
215
226
  }
227
+ updateMonthOptions() {
228
+ if (!this._activeDate) {
229
+ return;
230
+ }
231
+ const minYear = this.adapter.getYear(this.minDate);
232
+ const minMonth = this.adapter.getMonth(this.minDate);
233
+ const maxYear = this.adapter.getYear(this.maxDate);
234
+ const maxMonth = this.adapter.getMonth(this.maxDate);
235
+ const currentYear = this.adapter.getYear(this._activeDate);
236
+ if (currentYear === minYear && currentYear === maxYear) {
237
+ this.monthNames.forEach((month) => (month.disabled = month.value < minMonth || month.value > maxMonth));
238
+ }
239
+ else if (currentYear === minYear) {
240
+ this.monthNames.forEach((month) => (month.disabled = month.value < minMonth));
241
+ }
242
+ else if (currentYear === maxYear) {
243
+ this.monthNames.forEach((month) => (month.disabled = month.value > maxMonth));
244
+ }
245
+ }
216
246
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McCalendarHeader, deps: [{ token: i1$1.DateAdapter }], target: i0.ɵɵFactoryTarget.Component }); }
217
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.0", type: McCalendarHeader, selector: "mc-calendar-header", inputs: { activeDate: "activeDate", maxDate: "maxDate", minDate: "minDate" }, outputs: { activeDateChange: "activeDateChange", monthSelected: "monthSelected", yearSelected: "yearSelected" }, host: { classAttribute: "mc-calendar-header" }, exportAs: ["mcCalendarHeader"], ngImport: i0, template: "<div class=\"mc-calendar-header__select-group\">\n <mc-select\n class=\"mc-calendar-header__select\"\n #monthSelect=\"mcSelect\"\n [value]=\"selectedMonth\"\n [panelClass]=\"'mc-calendar-select-panel'\"\n (selectionChange)=\"onMonthSelected($event.value)\">\n\n <button class=\"mc-button_transparent layout-padding-right-xs\"\n mc-button\n mc-select-matcher\n [class.mc-active]=\"monthSelect.panelOpen\"\n [tabindex]=\"-1\">\n {{ monthSelect.triggerValue }}\n\n <i class=\"layout-padding-left-3xs\" mc-icon=\"mc-angle-down-S_16\"></i>\n </button>\n\n <mc-option *ngFor=\"let month of monthNames\"\n [mcTooltipDisabled]=\"true\"\n [value]=\"month.value\">\n {{ month.name }}\n </mc-option>\n </mc-select>\n\n <mc-select\n #yearSelect=\"mcSelect\"\n [value]=\"selectedYear\"\n [panelClass]=\"'mc-calendar-select-panel'\"\n (selectionChange)=\"onYearSelected($event.value.name)\">\n <button class=\"mc-button_transparent layout-padding-right-xs\"\n mc-button\n mc-select-matcher\n [class.mc-active]=\"yearSelect.panelOpen\"\n [tabindex]=\"-1\">\n {{ this.selectedYear.value }}\n\n <i class=\"layout-padding-left-3xs\" mc-icon=\"mc-angle-down-S_16\"></i>\n </button>\n\n <mc-option *ngFor=\"let year of years\"\n [mcTooltipDisabled]=\"true\"\n [value]=\"year\">\n {{ year.value }}\n </mc-option>\n </mc-select>\n</div>\n\n<div class=\"mc-calendar-header__button-group\">\n <button mc-button\n class=\"mc-button_transparent mc-calendar-header__previous-button\"\n [tabindex]=\"-1\"\n [disabled]=\"previousDisabled\"\n (click)=\"selectPreviousMonth()\">\n\n <i mc-icon=\"mc-angle-left-L_16\"></i>\n </button>\n\n <button mc-button\n class=\"mc-button_transparent\"\n [tabindex]=\"-1\"\n (click)=\"selectCurrentDate()\">\n\n <i mc-icon=\"mc-circle-8_16\"></i>\n </button>\n\n <button mc-button\n class=\"mc-button_transparent mc-calendar-header__next-button\"\n [tabindex]=\"-1\"\n [disabled]=\"nextDisabled\"\n (click)=\"selectNextMonth()\">\n\n <i mc-icon=\"mc-angle-right-L_16\"></i>\n </button>\n</div>\n", styles: [".mc-calendar-header{display:flex;flex-direction:row;justify-content:space-between;padding:var(--mc-datepicker-calendar-size-padding-top, 16px) var(--mc-datepicker-calendar-size-padding-horizontal, 8px) var(--mc-datepicker-calendar-size-padding-blocks, 12px) var(--mc-datepicker-calendar-size-padding-horizontal, 8px)}.mc-calendar-header__previous-button:after{border-left-width:var(--mc-datepicker-calendar-size-icon-border-width, 2px);transform:var(--mc-datepicker-calendar-size-icon-prev-icon-transform, translateX(2px) rotate(-45deg))}.mc-calendar-header__next-button:after{border-right-width:var(--mc-datepicker-calendar-size-icon-border-width, 2px);transform:var(--mc-datepicker-calendar-size-icon-nex-icon-transform, translateX(-2px) rotate(45deg))}.mc-calendar-header__select{width:auto!important}.mc-calendar-header__button-group,.mc-calendar-header__select-group{display:flex;flex-direction:row}.mc-calendar-select-panel{margin-top:2px;min-width:98%!important}.mc-calendar-select-panel .mc-select__content{max-height:384px;overflow-x:hidden;scrollbar-gutter:stable}.mc-calendar-select-panel .mc-select__content .mc-option{min-width:65px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.McButton, selector: "[mc-button]", inputs: ["color", "tabIndex", "disabled"] }, { kind: "directive", type: i3.McButtonCssStyler, selector: "[mc-button]" }, { kind: "directive", type: i4.McValidateDirective, selector: " input[mcInput], input[mcInputPassword], input[mcTimepicker], input[mcDatepicker], textarea[mcTextarea], mc-select, mc-tree-select, mc-tag-list ", exportAs: ["McValidate"] }, { kind: "component", type: i5.McSelect, selector: "mc-select", inputs: ["disabled", "tabIndex", "hiddenItemsText", "panelClass", "backdropClass", "errorStateMatcher", "sortComparator", "hasBackdrop", "placeholder", "required", "multiple", "compareWith", "value", "id", "hiddenItemsTextFormatter"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["mcSelect"] }, { kind: "directive", type: i1$1.McSelectMatcher, selector: "mc-select-matcher, [mc-select-matcher]" }, { kind: "directive", type: i5.McOptionTooltip, selector: "mc-option" }, { kind: "component", type: i1$1.McOption, selector: "mc-option", inputs: ["value", "showCheckbox", "disabled"], outputs: ["onSelectionChange"], exportAs: ["mcOption"] }, { kind: "component", type: i6.McIcon, selector: "[mc-icon]", inputs: ["color"] }, { kind: "directive", type: i6.McIconCSSStyler, selector: "[mc-icon]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
247
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.0", type: McCalendarHeader, selector: "mc-calendar-header", inputs: { activeDate: "activeDate", maxDate: "maxDate", minDate: "minDate" }, outputs: { activeDateChange: "activeDateChange", monthSelected: "monthSelected", yearSelected: "yearSelected" }, host: { classAttribute: "mc-calendar-header" }, exportAs: ["mcCalendarHeader"], ngImport: i0, template: "<div class=\"mc-calendar-header__select-group\">\n <mc-select\n class=\"mc-calendar-header__select\"\n #monthSelect=\"mcSelect\"\n [value]=\"selectedMonth\"\n [panelClass]=\"'mc-calendar-select-panel'\"\n (selectionChange)=\"onMonthSelected($event.value)\">\n\n <button class=\"mc-button_transparent layout-padding-right-xxs layout-padding-left-s\"\n mc-button\n mc-select-matcher\n [class.mc-active]=\"monthSelect.panelOpen\"\n [tabindex]=\"-1\">\n {{ monthSelect.triggerValue }}\n\n <i mc-icon=\"mc-angle-down-S_16\"></i>\n </button>\n\n <mc-option *ngFor=\"let month of monthNames\"\n [mcTooltipDisabled]=\"true\"\n [disabled]=\"month.disabled\"\n [value]=\"month.value\">\n {{ month.name }}\n </mc-option>\n </mc-select>\n\n <mc-select\n #yearSelect=\"mcSelect\"\n [value]=\"selectedYear\"\n [panelClass]=\"'mc-calendar-select-panel'\"\n (selectionChange)=\"onYearSelected($event.value.name)\">\n <button class=\"mc-button_transparent layout-padding-right-xxs layout-padding-left-s\"\n mc-button\n mc-select-matcher\n [class.mc-active]=\"yearSelect.panelOpen\"\n [tabindex]=\"-1\">\n {{ this.selectedYear.value }}\n\n <i mc-icon=\"mc-angle-down-S_16\"></i>\n </button>\n\n <mc-option *ngFor=\"let year of years\"\n [mcTooltipDisabled]=\"true\"\n [value]=\"year\">\n {{ year.value }}\n </mc-option>\n </mc-select>\n</div>\n\n<div class=\"mc-calendar-header__button-group\">\n <button mc-button\n class=\"mc-button_transparent mc-calendar-header__previous-button\"\n [tabindex]=\"-1\"\n [disabled]=\"previousDisabled\"\n (click)=\"selectPreviousMonth()\">\n\n <i mc-icon=\"mc-angle-left-L_16\"></i>\n </button>\n\n <button mc-button\n class=\"mc-button_transparent\"\n [disabled]=\"currentDisabled\"\n [tabindex]=\"-1\"\n (click)=\"selectCurrentDate()\">\n\n <i mc-icon=\"mc-circle-8_16\"></i>\n </button>\n\n <button mc-button\n class=\"mc-button_transparent mc-calendar-header__next-button\"\n [tabindex]=\"-1\"\n [disabled]=\"nextDisabled\"\n (click)=\"selectNextMonth()\">\n\n <i mc-icon=\"mc-angle-right-L_16\"></i>\n </button>\n</div>\n", styles: [".mc-calendar-header{display:flex;flex-direction:row;justify-content:space-between;padding:var(--mc-datepicker-calendar-size-padding-top, 16px) var(--mc-datepicker-calendar-size-padding-horizontal, 8px) var(--mc-datepicker-calendar-size-padding-blocks, 12px) var(--mc-datepicker-calendar-size-padding-horizontal, 8px)}.mc-calendar-header__previous-button:after{border-left-width:var(--mc-datepicker-calendar-size-icon-border-width, 2px);transform:var(--mc-datepicker-calendar-size-icon-prev-icon-transform, translateX(2px) rotate(-45deg))}.mc-calendar-header__next-button:after{border-right-width:var(--mc-datepicker-calendar-size-icon-border-width, 2px);transform:var(--mc-datepicker-calendar-size-icon-nex-icon-transform, translateX(-2px) rotate(45deg))}.mc-calendar-header__select{width:auto!important}.mc-calendar-header__button-group,.mc-calendar-header__select-group{display:flex;flex-direction:row}.mc-calendar-select-panel{margin-top:2px;min-width:98%!important}.mc-calendar-select-panel .mc-select__content{max-height:384px;overflow-x:hidden;scrollbar-gutter:stable}.mc-calendar-select-panel .mc-select__content .mc-option{min-width:65px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.McButton, selector: "[mc-button]", inputs: ["color", "tabIndex", "disabled"] }, { kind: "directive", type: i3.McButtonCssStyler, selector: "[mc-button]" }, { kind: "directive", type: i4.McValidateDirective, selector: " input[mcInput], input[mcInputPassword], input[mcTimepicker], input[mcDatepicker], textarea[mcTextarea], mc-select, mc-tree-select, mc-tag-list ", exportAs: ["McValidate"] }, { kind: "component", type: i5.McSelect, selector: "mc-select", inputs: ["disabled", "tabIndex", "hiddenItemsText", "panelClass", "backdropClass", "errorStateMatcher", "sortComparator", "hasBackdrop", "placeholder", "required", "multiple", "compareWith", "value", "id", "hiddenItemsTextFormatter"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["mcSelect"] }, { kind: "directive", type: i1$1.McSelectMatcher, selector: "mc-select-matcher, [mc-select-matcher]" }, { kind: "directive", type: i5.McOptionTooltip, selector: "mc-option" }, { kind: "component", type: i1$1.McOption, selector: "mc-option", inputs: ["value", "showCheckbox", "disabled"], outputs: ["onSelectionChange"], exportAs: ["mcOption"] }, { kind: "component", type: i6.McIcon, selector: "[mc-icon]", inputs: ["color"] }, { kind: "directive", type: i6.McIconCSSStyler, selector: "[mc-icon]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
218
248
  }
219
249
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McCalendarHeader, decorators: [{
220
250
  type: Component,
221
251
  args: [{ selector: 'mc-calendar-header', exportAs: 'mcCalendarHeader', host: {
222
252
  class: 'mc-calendar-header'
223
- }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mc-calendar-header__select-group\">\n <mc-select\n class=\"mc-calendar-header__select\"\n #monthSelect=\"mcSelect\"\n [value]=\"selectedMonth\"\n [panelClass]=\"'mc-calendar-select-panel'\"\n (selectionChange)=\"onMonthSelected($event.value)\">\n\n <button class=\"mc-button_transparent layout-padding-right-xs\"\n mc-button\n mc-select-matcher\n [class.mc-active]=\"monthSelect.panelOpen\"\n [tabindex]=\"-1\">\n {{ monthSelect.triggerValue }}\n\n <i class=\"layout-padding-left-3xs\" mc-icon=\"mc-angle-down-S_16\"></i>\n </button>\n\n <mc-option *ngFor=\"let month of monthNames\"\n [mcTooltipDisabled]=\"true\"\n [value]=\"month.value\">\n {{ month.name }}\n </mc-option>\n </mc-select>\n\n <mc-select\n #yearSelect=\"mcSelect\"\n [value]=\"selectedYear\"\n [panelClass]=\"'mc-calendar-select-panel'\"\n (selectionChange)=\"onYearSelected($event.value.name)\">\n <button class=\"mc-button_transparent layout-padding-right-xs\"\n mc-button\n mc-select-matcher\n [class.mc-active]=\"yearSelect.panelOpen\"\n [tabindex]=\"-1\">\n {{ this.selectedYear.value }}\n\n <i class=\"layout-padding-left-3xs\" mc-icon=\"mc-angle-down-S_16\"></i>\n </button>\n\n <mc-option *ngFor=\"let year of years\"\n [mcTooltipDisabled]=\"true\"\n [value]=\"year\">\n {{ year.value }}\n </mc-option>\n </mc-select>\n</div>\n\n<div class=\"mc-calendar-header__button-group\">\n <button mc-button\n class=\"mc-button_transparent mc-calendar-header__previous-button\"\n [tabindex]=\"-1\"\n [disabled]=\"previousDisabled\"\n (click)=\"selectPreviousMonth()\">\n\n <i mc-icon=\"mc-angle-left-L_16\"></i>\n </button>\n\n <button mc-button\n class=\"mc-button_transparent\"\n [tabindex]=\"-1\"\n (click)=\"selectCurrentDate()\">\n\n <i mc-icon=\"mc-circle-8_16\"></i>\n </button>\n\n <button mc-button\n class=\"mc-button_transparent mc-calendar-header__next-button\"\n [tabindex]=\"-1\"\n [disabled]=\"nextDisabled\"\n (click)=\"selectNextMonth()\">\n\n <i mc-icon=\"mc-angle-right-L_16\"></i>\n </button>\n</div>\n", styles: [".mc-calendar-header{display:flex;flex-direction:row;justify-content:space-between;padding:var(--mc-datepicker-calendar-size-padding-top, 16px) var(--mc-datepicker-calendar-size-padding-horizontal, 8px) var(--mc-datepicker-calendar-size-padding-blocks, 12px) var(--mc-datepicker-calendar-size-padding-horizontal, 8px)}.mc-calendar-header__previous-button:after{border-left-width:var(--mc-datepicker-calendar-size-icon-border-width, 2px);transform:var(--mc-datepicker-calendar-size-icon-prev-icon-transform, translateX(2px) rotate(-45deg))}.mc-calendar-header__next-button:after{border-right-width:var(--mc-datepicker-calendar-size-icon-border-width, 2px);transform:var(--mc-datepicker-calendar-size-icon-nex-icon-transform, translateX(-2px) rotate(45deg))}.mc-calendar-header__select{width:auto!important}.mc-calendar-header__button-group,.mc-calendar-header__select-group{display:flex;flex-direction:row}.mc-calendar-select-panel{margin-top:2px;min-width:98%!important}.mc-calendar-select-panel .mc-select__content{max-height:384px;overflow-x:hidden;scrollbar-gutter:stable}.mc-calendar-select-panel .mc-select__content .mc-option{min-width:65px}\n"] }]
253
+ }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mc-calendar-header__select-group\">\n <mc-select\n class=\"mc-calendar-header__select\"\n #monthSelect=\"mcSelect\"\n [value]=\"selectedMonth\"\n [panelClass]=\"'mc-calendar-select-panel'\"\n (selectionChange)=\"onMonthSelected($event.value)\">\n\n <button class=\"mc-button_transparent layout-padding-right-xxs layout-padding-left-s\"\n mc-button\n mc-select-matcher\n [class.mc-active]=\"monthSelect.panelOpen\"\n [tabindex]=\"-1\">\n {{ monthSelect.triggerValue }}\n\n <i mc-icon=\"mc-angle-down-S_16\"></i>\n </button>\n\n <mc-option *ngFor=\"let month of monthNames\"\n [mcTooltipDisabled]=\"true\"\n [disabled]=\"month.disabled\"\n [value]=\"month.value\">\n {{ month.name }}\n </mc-option>\n </mc-select>\n\n <mc-select\n #yearSelect=\"mcSelect\"\n [value]=\"selectedYear\"\n [panelClass]=\"'mc-calendar-select-panel'\"\n (selectionChange)=\"onYearSelected($event.value.name)\">\n <button class=\"mc-button_transparent layout-padding-right-xxs layout-padding-left-s\"\n mc-button\n mc-select-matcher\n [class.mc-active]=\"yearSelect.panelOpen\"\n [tabindex]=\"-1\">\n {{ this.selectedYear.value }}\n\n <i mc-icon=\"mc-angle-down-S_16\"></i>\n </button>\n\n <mc-option *ngFor=\"let year of years\"\n [mcTooltipDisabled]=\"true\"\n [value]=\"year\">\n {{ year.value }}\n </mc-option>\n </mc-select>\n</div>\n\n<div class=\"mc-calendar-header__button-group\">\n <button mc-button\n class=\"mc-button_transparent mc-calendar-header__previous-button\"\n [tabindex]=\"-1\"\n [disabled]=\"previousDisabled\"\n (click)=\"selectPreviousMonth()\">\n\n <i mc-icon=\"mc-angle-left-L_16\"></i>\n </button>\n\n <button mc-button\n class=\"mc-button_transparent\"\n [disabled]=\"currentDisabled\"\n [tabindex]=\"-1\"\n (click)=\"selectCurrentDate()\">\n\n <i mc-icon=\"mc-circle-8_16\"></i>\n </button>\n\n <button mc-button\n class=\"mc-button_transparent mc-calendar-header__next-button\"\n [tabindex]=\"-1\"\n [disabled]=\"nextDisabled\"\n (click)=\"selectNextMonth()\">\n\n <i mc-icon=\"mc-angle-right-L_16\"></i>\n </button>\n</div>\n", styles: [".mc-calendar-header{display:flex;flex-direction:row;justify-content:space-between;padding:var(--mc-datepicker-calendar-size-padding-top, 16px) var(--mc-datepicker-calendar-size-padding-horizontal, 8px) var(--mc-datepicker-calendar-size-padding-blocks, 12px) var(--mc-datepicker-calendar-size-padding-horizontal, 8px)}.mc-calendar-header__previous-button:after{border-left-width:var(--mc-datepicker-calendar-size-icon-border-width, 2px);transform:var(--mc-datepicker-calendar-size-icon-prev-icon-transform, translateX(2px) rotate(-45deg))}.mc-calendar-header__next-button:after{border-right-width:var(--mc-datepicker-calendar-size-icon-border-width, 2px);transform:var(--mc-datepicker-calendar-size-icon-nex-icon-transform, translateX(-2px) rotate(45deg))}.mc-calendar-header__select{width:auto!important}.mc-calendar-header__button-group,.mc-calendar-header__select-group{display:flex;flex-direction:row}.mc-calendar-select-panel{margin-top:2px;min-width:98%!important}.mc-calendar-select-panel .mc-select__content{max-height:384px;overflow-x:hidden;scrollbar-gutter:stable}.mc-calendar-select-panel .mc-select__content .mc-option{min-width:65px}\n"] }]
224
254
  }], ctorParameters: () => [{ type: i1$1.DateAdapter }], propDecorators: { activeDate: [{
225
255
  type: Input
226
256
  }], maxDate: [{
@@ -1659,22 +1689,86 @@ class McDatepickerInput {
1659
1689
  }
1660
1690
  return [this.thirdDigit.value, this.thirdDigit.start, this.thirdDigit.end];
1661
1691
  }
1662
- incrementDate(dateVal, whatToIncrement) {
1663
- let year = this.adapter.getYear(dateVal);
1664
- let month = this.adapter.getMonth(dateVal);
1665
- let day = this.adapter.getDate(dateVal);
1692
+ isMaxMonth(date) {
1693
+ return this.adapter.getMonth(date) === this.getMaxMonth(date);
1694
+ }
1695
+ isMinMonth(date) {
1696
+ return this.adapter.getMonth(date) === this.getMinMonth(date);
1697
+ }
1698
+ isMaxYear(date) {
1699
+ return this.adapter.getYear(date) === this.getMaxYear();
1700
+ }
1701
+ isMinYear(date) {
1702
+ return this.adapter.getYear(date) === this.getMinYear();
1703
+ }
1704
+ getMaxDate(date) {
1705
+ if (this.datepicker.maxDate && this.isMaxYear(date) && this.isMaxMonth(date)) {
1706
+ return this.adapter.getDate(this.datepicker.maxDate);
1707
+ }
1708
+ return this.adapter.getNumDaysInMonth(date);
1709
+ }
1710
+ getMinDate(date) {
1711
+ if (this.datepicker.minDate && this.isMinYear(date) && this.isMinMonth(date)) {
1712
+ return this.adapter.getDate(this.datepicker.minDate);
1713
+ }
1714
+ return 1;
1715
+ }
1716
+ getMaxMonth(date) {
1717
+ if (this.datepicker.maxDate && this.isMaxYear(date)) {
1718
+ return this.adapter.getMonth(this.datepicker.maxDate);
1719
+ }
1720
+ // tslint:disable-next-line:no-magic-numbers
1721
+ return 11;
1722
+ }
1723
+ getMinMonth(date) {
1724
+ if (this.datepicker.minDate && this.isMinYear(date)) {
1725
+ return this.adapter.getMonth(this.datepicker.minDate);
1726
+ }
1727
+ return 0;
1728
+ }
1729
+ getMaxYear() {
1730
+ if (this.datepicker.maxDate) {
1731
+ return this.adapter.getYear(this.datepicker.maxDate);
1732
+ }
1733
+ return MAX_YEAR;
1734
+ }
1735
+ getMinYear() {
1736
+ if (this.datepicker.minDate) {
1737
+ return this.adapter.getYear(this.datepicker.minDate);
1738
+ }
1739
+ return 1;
1740
+ }
1741
+ incrementDate(date, whatToIncrement) {
1742
+ let year = this.adapter.getYear(date);
1743
+ let month = this.adapter.getMonth(date);
1744
+ let day = this.adapter.getDate(date);
1666
1745
  switch (whatToIncrement) {
1667
1746
  case DateParts.day:
1668
1747
  day++;
1669
- if (day > this.adapter.getNumDaysInMonth(dateVal)) {
1670
- day = 1;
1748
+ if (day > this.getMaxDate(date)) {
1749
+ if (this.isMaxYear(date) && this.isMaxMonth(date)) {
1750
+ day = this.getMaxDate(date);
1751
+ }
1752
+ else if (this.isMinYear(date) && this.isMinMonth(date)) {
1753
+ day = this.getMinDate(date);
1754
+ }
1755
+ else {
1756
+ day = 1;
1757
+ }
1671
1758
  }
1672
1759
  break;
1673
1760
  case DateParts.month:
1674
1761
  month++;
1675
- // tslint:disable-next-line:no-magic-numbers
1676
- if (month > 11) {
1677
- month = 0;
1762
+ if (month > this.getMaxMonth(date)) {
1763
+ if (this.isMaxYear(date)) {
1764
+ month = this.getMaxMonth(date);
1765
+ }
1766
+ else if (this.isMinYear(date)) {
1767
+ month = this.getMinMonth(date);
1768
+ }
1769
+ else {
1770
+ month = 0;
1771
+ }
1678
1772
  }
1679
1773
  const lastDay = this.getLastDayFor(year, month);
1680
1774
  if (day > lastDay) {
@@ -1683,8 +1777,8 @@ class McDatepickerInput {
1683
1777
  break;
1684
1778
  case DateParts.year:
1685
1779
  year++;
1686
- if (year > MAX_YEAR) {
1687
- year = 1;
1780
+ if (year > this.getMaxYear()) {
1781
+ year = this.getMaxYear();
1688
1782
  }
1689
1783
  break;
1690
1784
  default:
@@ -1694,22 +1788,38 @@ class McDatepickerInput {
1694
1788
  getLastDayFor(year, month) {
1695
1789
  return this.adapter.getNumDaysInMonth(this.createDate(year, month, 1));
1696
1790
  }
1697
- decrementDate(dateVal, whatToDecrement) {
1698
- let year = this.adapter.getYear(dateVal);
1699
- let month = this.adapter.getMonth(dateVal);
1700
- let day = this.adapter.getDate(dateVal);
1791
+ decrementDate(date, whatToDecrement) {
1792
+ let year = this.adapter.getYear(date);
1793
+ let month = this.adapter.getMonth(date);
1794
+ let day = this.adapter.getDate(date);
1701
1795
  switch (whatToDecrement) {
1702
1796
  case DateParts.day:
1703
1797
  day--;
1704
- if (day < 1) {
1705
- day = this.adapter.getNumDaysInMonth(dateVal);
1798
+ if (day < this.getMinDate(date)) {
1799
+ if (this.isMinYear(date) && this.isMinMonth(date)) {
1800
+ day = this.getMinDate(date);
1801
+ }
1802
+ else if (this.isMaxYear(date) && this.isMaxMonth(date)) {
1803
+ day = this.getMaxDate(date);
1804
+ }
1805
+ else {
1806
+ day = this.adapter.getNumDaysInMonth(date);
1807
+ }
1706
1808
  }
1707
1809
  break;
1708
1810
  case DateParts.month:
1709
1811
  month--;
1710
- if (month < 0) {
1711
- // tslint:disable-next-line:no-magic-numbers
1712
- month = 11;
1812
+ if (month < this.getMinMonth(date)) {
1813
+ if (year === this.getMinYear()) {
1814
+ month = this.getMinMonth(date);
1815
+ }
1816
+ else if (this.isMaxYear(date)) {
1817
+ month = this.getMaxMonth(date);
1818
+ }
1819
+ else {
1820
+ // tslint:disable-next-line:no-magic-numbers
1821
+ month = 11;
1822
+ }
1713
1823
  }
1714
1824
  const lastDay = this.getLastDayFor(year, month);
1715
1825
  if (day > lastDay) {
@@ -1718,8 +1828,8 @@ class McDatepickerInput {
1718
1828
  break;
1719
1829
  case DateParts.year:
1720
1830
  year--;
1721
- if (year < 1) {
1722
- year = MAX_YEAR;
1831
+ if (year < this.getMinYear()) {
1832
+ year = this.getMinYear();
1723
1833
  }
1724
1834
  break;
1725
1835
  default: