@angular/material 13.1.0-rc.0 → 13.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/autocomplete/autocomplete-trigger.d.ts +2 -3
- package/autocomplete/autocomplete.d.ts +1 -3
- package/badge/badge.d.ts +2 -5
- package/button/button.d.ts +11 -8
- package/button-toggle/button-toggle.d.ts +5 -13
- package/checkbox/checkbox.d.ts +6 -11
- package/chips/chip-input.d.ts +2 -4
- package/chips/chip-list.d.ts +4 -8
- package/chips/chip.d.ts +5 -11
- package/core/focus-indicators/_focus-indicators.scss +4 -0
- package/core/option/index.d.ts +1 -1
- package/core/option/optgroup.d.ts +0 -2
- package/core/option/option.d.ts +14 -15
- package/core/selection/index.d.ts +8 -8
- package/core/selection/pseudo-checkbox/pseudo-checkbox-module.d.ts +8 -0
- package/core/theming/_palette.scss +1 -1
- package/core/theming/_theming.scss +15 -4
- package/datepicker/date-range-input.d.ts +2 -4
- package/datepicker/datepicker-base.d.ts +4 -8
- package/datepicker/datepicker-input-base.d.ts +2 -4
- package/datepicker/datepicker-toggle.d.ts +1 -2
- package/divider/divider.d.ts +2 -4
- package/esm2020/autocomplete/autocomplete-module.mjs +5 -5
- package/esm2020/autocomplete/autocomplete-origin.mjs +7 -7
- package/esm2020/autocomplete/autocomplete-trigger.mjs +20 -18
- package/esm2020/autocomplete/autocomplete.mjs +7 -7
- package/esm2020/badge/badge-module.mjs +5 -5
- package/esm2020/badge/badge.mjs +4 -4
- package/esm2020/bottom-sheet/bottom-sheet-container.mjs +4 -4
- package/esm2020/bottom-sheet/bottom-sheet-module.mjs +5 -5
- package/esm2020/bottom-sheet/bottom-sheet.mjs +4 -4
- package/esm2020/button/button-module.mjs +5 -5
- package/esm2020/button/button.mjs +35 -15
- package/esm2020/button-toggle/button-toggle-module.mjs +5 -5
- package/esm2020/button-toggle/button-toggle.mjs +7 -7
- package/esm2020/card/card-module.mjs +5 -5
- package/esm2020/card/card.mjs +44 -44
- package/esm2020/checkbox/checkbox-module.mjs +9 -9
- package/esm2020/checkbox/checkbox-required-validator.mjs +4 -4
- package/esm2020/checkbox/checkbox.mjs +4 -4
- package/esm2020/chips/chip-input.mjs +4 -4
- package/esm2020/chips/chip-list.mjs +4 -4
- package/esm2020/chips/chip.mjs +13 -13
- package/esm2020/chips/chips-module.mjs +5 -5
- package/esm2020/core/common-behaviors/common-module.mjs +7 -11
- package/esm2020/core/common-behaviors/disable-ripple.mjs +1 -1
- package/esm2020/core/common-behaviors/disabled.mjs +1 -1
- package/esm2020/core/datetime/index.mjs +9 -9
- package/esm2020/core/datetime/native-date-adapter.mjs +4 -4
- package/esm2020/core/error/error-options.mjs +7 -7
- package/esm2020/core/line/line.mjs +8 -8
- package/esm2020/core/option/index.mjs +5 -5
- package/esm2020/core/option/optgroup.mjs +14 -7
- package/esm2020/core/option/option.mjs +8 -8
- package/esm2020/core/ripple/index.mjs +5 -5
- package/esm2020/core/ripple/ripple.mjs +4 -4
- package/esm2020/core/selection/index.mjs +2 -18
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox-module.mjs +25 -0
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +4 -4
- package/esm2020/core/version.mjs +1 -1
- package/esm2020/datepicker/calendar-body.mjs +5 -5
- package/esm2020/datepicker/calendar.mjs +7 -7
- package/esm2020/datepicker/date-range-input-parts.mjs +10 -10
- package/esm2020/datepicker/date-range-input.mjs +4 -4
- package/esm2020/datepicker/date-range-picker.mjs +4 -4
- package/esm2020/datepicker/date-range-selection-strategy.mjs +4 -4
- package/esm2020/datepicker/date-selection-model.mjs +10 -10
- package/esm2020/datepicker/datepicker-actions.mjs +10 -10
- package/esm2020/datepicker/datepicker-base.mjs +7 -7
- package/esm2020/datepicker/datepicker-input-base.mjs +4 -4
- package/esm2020/datepicker/datepicker-input.mjs +4 -4
- package/esm2020/datepicker/datepicker-intl.mjs +4 -4
- package/esm2020/datepicker/datepicker-module.mjs +5 -5
- package/esm2020/datepicker/datepicker-toggle.mjs +7 -7
- package/esm2020/datepicker/datepicker.mjs +4 -4
- package/esm2020/datepicker/month-view.mjs +4 -4
- package/esm2020/datepicker/multi-year-view.mjs +4 -4
- package/esm2020/datepicker/year-view.mjs +4 -4
- package/esm2020/dialog/dialog-container.mjs +7 -7
- package/esm2020/dialog/dialog-content-directives.mjs +13 -13
- package/esm2020/dialog/dialog-module.mjs +5 -5
- package/esm2020/dialog/dialog.mjs +7 -7
- package/esm2020/divider/divider-module.mjs +5 -5
- package/esm2020/divider/divider.mjs +4 -4
- package/esm2020/expansion/accordion.mjs +4 -4
- package/esm2020/expansion/expansion-module.mjs +5 -5
- package/esm2020/expansion/expansion-panel-content.mjs +4 -4
- package/esm2020/expansion/expansion-panel-header.mjs +10 -10
- package/esm2020/expansion/expansion-panel.mjs +7 -7
- package/esm2020/form-field/error.mjs +4 -4
- package/esm2020/form-field/form-field-control.mjs +4 -4
- package/esm2020/form-field/form-field-module.mjs +5 -5
- package/esm2020/form-field/form-field.mjs +17 -13
- package/esm2020/form-field/hint.mjs +4 -4
- package/esm2020/form-field/label.mjs +4 -4
- package/esm2020/form-field/placeholder.mjs +4 -4
- package/esm2020/form-field/prefix.mjs +4 -4
- package/esm2020/form-field/suffix.mjs +4 -4
- package/esm2020/grid-list/grid-list-module.mjs +5 -5
- package/esm2020/grid-list/grid-list.mjs +4 -4
- package/esm2020/grid-list/grid-tile.mjs +16 -16
- package/esm2020/icon/icon-module.mjs +5 -5
- package/esm2020/icon/icon-registry.mjs +4 -4
- package/esm2020/icon/icon.mjs +4 -4
- package/esm2020/icon/testing/fake-icon-registry.mjs +8 -8
- package/esm2020/input/input-module.mjs +5 -5
- package/esm2020/input/input.mjs +7 -4
- package/esm2020/list/list-module.mjs +5 -5
- package/esm2020/list/list.mjs +19 -19
- package/esm2020/list/selection-list.mjs +7 -7
- package/esm2020/menu/menu-content.mjs +8 -10
- package/esm2020/menu/menu-item.mjs +7 -20
- package/esm2020/menu/menu-module.mjs +5 -5
- package/esm2020/menu/menu-trigger.mjs +9 -12
- package/esm2020/menu/menu.mjs +11 -7
- package/esm2020/paginator/paginator-intl.mjs +4 -4
- package/esm2020/paginator/paginator-module.mjs +5 -5
- package/esm2020/paginator/paginator.mjs +9 -9
- package/esm2020/progress-bar/progress-bar-module.mjs +5 -5
- package/esm2020/progress-bar/progress-bar.mjs +21 -11
- package/esm2020/progress-spinner/progress-spinner-module.mjs +5 -5
- package/esm2020/progress-spinner/progress-spinner.mjs +56 -18
- package/esm2020/radio/radio-module.mjs +5 -5
- package/esm2020/radio/radio.mjs +14 -14
- package/esm2020/select/select-module.mjs +5 -5
- package/esm2020/select/select.mjs +14 -11
- package/esm2020/sidenav/drawer.mjs +61 -15
- package/esm2020/sidenav/sidenav-module.mjs +5 -5
- package/esm2020/sidenav/sidenav.mjs +25 -14
- package/esm2020/slide-toggle/slide-toggle-module.mjs +9 -9
- package/esm2020/slide-toggle/slide-toggle-required-validator.mjs +4 -4
- package/esm2020/slide-toggle/slide-toggle.mjs +4 -4
- package/esm2020/slider/slider-module.mjs +5 -5
- package/esm2020/slider/slider.mjs +14 -6
- package/esm2020/snack-bar/simple-snack-bar.mjs +5 -5
- package/esm2020/snack-bar/snack-bar-container.mjs +4 -4
- package/esm2020/snack-bar/snack-bar-module.mjs +5 -5
- package/esm2020/snack-bar/snack-bar.mjs +28 -14
- package/esm2020/sort/sort-header-intl.mjs +4 -4
- package/esm2020/sort/sort-header.mjs +4 -4
- package/esm2020/sort/sort-module.mjs +5 -5
- package/esm2020/sort/sort.mjs +4 -4
- package/esm2020/stepper/step-content.mjs +4 -4
- package/esm2020/stepper/step-header.mjs +5 -5
- package/esm2020/stepper/step-label.mjs +4 -4
- package/esm2020/stepper/stepper-button.mjs +7 -7
- package/esm2020/stepper/stepper-icon.mjs +4 -4
- package/esm2020/stepper/stepper-intl.mjs +4 -4
- package/esm2020/stepper/stepper-module.mjs +5 -5
- package/esm2020/stepper/stepper.mjs +16 -16
- package/esm2020/table/cell.mjs +22 -22
- package/esm2020/table/row.mjs +22 -22
- package/esm2020/table/table-data-source.mjs +2 -1
- package/esm2020/table/table-module.mjs +5 -5
- package/esm2020/table/table.mjs +9 -9
- package/esm2020/table/text-column.mjs +4 -4
- package/esm2020/tabs/ink-bar.mjs +4 -4
- package/esm2020/tabs/paginated-tab-header.mjs +4 -4
- package/esm2020/tabs/tab-body.mjs +10 -10
- package/esm2020/tabs/tab-content.mjs +4 -4
- package/esm2020/tabs/tab-group.mjs +8 -8
- package/esm2020/tabs/tab-header.mjs +8 -8
- package/esm2020/tabs/tab-label-wrapper.mjs +11 -4
- package/esm2020/tabs/tab-label.mjs +4 -4
- package/esm2020/tabs/tab-nav-bar/tab-nav-bar.mjs +15 -15
- package/esm2020/tabs/tab.mjs +11 -4
- package/esm2020/tabs/tabs-module.mjs +5 -5
- package/esm2020/toolbar/toolbar-module.mjs +5 -5
- package/esm2020/toolbar/toolbar.mjs +7 -7
- package/esm2020/tooltip/tooltip-module.mjs +5 -5
- package/esm2020/tooltip/tooltip.mjs +40 -33
- package/esm2020/tree/node.mjs +10 -10
- package/esm2020/tree/outlet.mjs +4 -4
- package/esm2020/tree/padding.mjs +4 -11
- package/esm2020/tree/toggle.mjs +4 -4
- package/esm2020/tree/tree-module.mjs +5 -5
- package/esm2020/tree/tree.mjs +4 -4
- package/expansion/accordion.d.ts +1 -2
- package/expansion/expansion-panel-header.d.ts +0 -2
- package/expansion/expansion-panel.d.ts +1 -2
- package/fesm2015/autocomplete.mjs +35 -33
- package/fesm2015/autocomplete.mjs.map +1 -1
- package/fesm2015/badge.mjs +7 -7
- package/fesm2015/badge.mjs.map +1 -1
- package/fesm2015/bottom-sheet.mjs +10 -10
- package/fesm2015/bottom-sheet.mjs.map +1 -1
- package/fesm2015/button-toggle.mjs +10 -10
- package/fesm2015/button-toggle.mjs.map +1 -1
- package/fesm2015/button.mjs +37 -17
- package/fesm2015/button.mjs.map +1 -1
- package/fesm2015/card.mjs +47 -47
- package/fesm2015/card.mjs.map +1 -1
- package/fesm2015/checkbox.mjs +14 -14
- package/fesm2015/checkbox.mjs.map +1 -1
- package/fesm2015/chips.mjs +22 -22
- package/fesm2015/chips.mjs.map +1 -1
- package/fesm2015/core.mjs +79 -69
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/datepicker.mjs +83 -83
- package/fesm2015/datepicker.mjs.map +1 -1
- package/fesm2015/dialog.mjs +28 -28
- package/fesm2015/dialog.mjs.map +1 -1
- package/fesm2015/divider.mjs +7 -7
- package/fesm2015/divider.mjs.map +1 -1
- package/fesm2015/expansion.mjs +25 -25
- package/fesm2015/expansion.mjs.map +1 -1
- package/fesm2015/form-field.mjs +41 -37
- package/fesm2015/form-field.mjs.map +1 -1
- package/fesm2015/grid-list.mjs +22 -22
- package/fesm2015/grid-list.mjs.map +1 -1
- package/fesm2015/icon/testing.mjs +7 -7
- package/fesm2015/icon/testing.mjs.map +1 -1
- package/fesm2015/icon.mjs +10 -10
- package/fesm2015/icon.mjs.map +1 -1
- package/fesm2015/input.mjs +10 -7
- package/fesm2015/input.mjs.map +1 -1
- package/fesm2015/list.mjs +28 -28
- package/fesm2015/list.mjs.map +1 -1
- package/fesm2015/menu.mjs +36 -48
- package/fesm2015/menu.mjs.map +1 -1
- package/fesm2015/paginator.mjs +15 -15
- package/fesm2015/paginator.mjs.map +1 -1
- package/fesm2015/progress-bar.mjs +25 -13
- package/fesm2015/progress-bar.mjs.map +1 -1
- package/fesm2015/progress-spinner.mjs +58 -20
- package/fesm2015/progress-spinner.mjs.map +1 -1
- package/fesm2015/radio.mjs +16 -16
- package/fesm2015/radio.mjs.map +1 -1
- package/fesm2015/select.mjs +17 -14
- package/fesm2015/select.mjs.map +1 -1
- package/fesm2015/sidenav.mjs +89 -32
- package/fesm2015/sidenav.mjs.map +1 -1
- package/fesm2015/slide-toggle.mjs +14 -14
- package/fesm2015/slide-toggle.mjs.map +1 -1
- package/fesm2015/slider.mjs +17 -9
- package/fesm2015/slider.mjs.map +1 -1
- package/fesm2015/snack-bar.mjs +41 -25
- package/fesm2015/snack-bar.mjs.map +1 -1
- package/fesm2015/sort.mjs +13 -13
- package/fesm2015/sort.mjs.map +1 -1
- package/fesm2015/stepper.mjs +41 -41
- package/fesm2015/stepper.mjs.map +1 -1
- package/fesm2015/table.mjs +58 -57
- package/fesm2015/table.mjs.map +1 -1
- package/fesm2015/tabs.mjs +73 -59
- package/fesm2015/tabs.mjs.map +1 -1
- package/fesm2015/toolbar.mjs +10 -10
- package/fesm2015/toolbar.mjs.map +1 -1
- package/fesm2015/tooltip.mjs +43 -36
- package/fesm2015/tooltip.mjs.map +1 -1
- package/fesm2015/tree.mjs +25 -32
- package/fesm2015/tree.mjs.map +1 -1
- package/fesm2020/autocomplete.mjs +35 -33
- package/fesm2020/autocomplete.mjs.map +1 -1
- package/fesm2020/badge.mjs +7 -7
- package/fesm2020/badge.mjs.map +1 -1
- package/fesm2020/bottom-sheet.mjs +10 -10
- package/fesm2020/bottom-sheet.mjs.map +1 -1
- package/fesm2020/button-toggle.mjs +10 -10
- package/fesm2020/button-toggle.mjs.map +1 -1
- package/fesm2020/button.mjs +37 -17
- package/fesm2020/button.mjs.map +1 -1
- package/fesm2020/card.mjs +47 -47
- package/fesm2020/card.mjs.map +1 -1
- package/fesm2020/checkbox.mjs +14 -14
- package/fesm2020/checkbox.mjs.map +1 -1
- package/fesm2020/chips.mjs +22 -22
- package/fesm2020/chips.mjs.map +1 -1
- package/fesm2020/core.mjs +79 -69
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/datepicker.mjs +83 -83
- package/fesm2020/datepicker.mjs.map +1 -1
- package/fesm2020/dialog.mjs +28 -28
- package/fesm2020/dialog.mjs.map +1 -1
- package/fesm2020/divider.mjs +7 -7
- package/fesm2020/divider.mjs.map +1 -1
- package/fesm2020/expansion.mjs +25 -25
- package/fesm2020/expansion.mjs.map +1 -1
- package/fesm2020/form-field.mjs +41 -37
- package/fesm2020/form-field.mjs.map +1 -1
- package/fesm2020/grid-list.mjs +22 -22
- package/fesm2020/grid-list.mjs.map +1 -1
- package/fesm2020/icon/testing.mjs +7 -7
- package/fesm2020/icon/testing.mjs.map +1 -1
- package/fesm2020/icon.mjs +10 -10
- package/fesm2020/icon.mjs.map +1 -1
- package/fesm2020/input.mjs +10 -7
- package/fesm2020/input.mjs.map +1 -1
- package/fesm2020/list.mjs +28 -28
- package/fesm2020/list.mjs.map +1 -1
- package/fesm2020/menu.mjs +34 -48
- package/fesm2020/menu.mjs.map +1 -1
- package/fesm2020/paginator.mjs +15 -15
- package/fesm2020/paginator.mjs.map +1 -1
- package/fesm2020/progress-bar.mjs +23 -13
- package/fesm2020/progress-bar.mjs.map +1 -1
- package/fesm2020/progress-spinner.mjs +57 -20
- package/fesm2020/progress-spinner.mjs.map +1 -1
- package/fesm2020/radio.mjs +16 -16
- package/fesm2020/radio.mjs.map +1 -1
- package/fesm2020/select.mjs +17 -14
- package/fesm2020/select.mjs.map +1 -1
- package/fesm2020/sidenav.mjs +88 -31
- package/fesm2020/sidenav.mjs.map +1 -1
- package/fesm2020/slide-toggle.mjs +14 -14
- package/fesm2020/slide-toggle.mjs.map +1 -1
- package/fesm2020/slider.mjs +17 -9
- package/fesm2020/slider.mjs.map +1 -1
- package/fesm2020/snack-bar.mjs +39 -25
- package/fesm2020/snack-bar.mjs.map +1 -1
- package/fesm2020/sort.mjs +13 -13
- package/fesm2020/sort.mjs.map +1 -1
- package/fesm2020/stepper.mjs +41 -41
- package/fesm2020/stepper.mjs.map +1 -1
- package/fesm2020/table.mjs +58 -57
- package/fesm2020/table.mjs.map +1 -1
- package/fesm2020/tabs.mjs +73 -59
- package/fesm2020/tabs.mjs.map +1 -1
- package/fesm2020/toolbar.mjs +10 -10
- package/fesm2020/toolbar.mjs.map +1 -1
- package/fesm2020/tooltip.mjs +43 -36
- package/fesm2020/tooltip.mjs.map +1 -1
- package/fesm2020/tree.mjs +25 -32
- package/fesm2020/tree.mjs.map +1 -1
- package/form-field/form-field.d.ts +1 -2
- package/grid-list/grid-list.d.ts +1 -2
- package/grid-list/grid-tile.d.ts +2 -4
- package/icon/icon.d.ts +1 -2
- package/input/input.d.ts +10 -9
- package/list/_list-theme.scss +4 -3
- package/list/list.d.ts +1 -7
- package/list/selection-list.d.ts +6 -12
- package/menu/menu-content.d.ts +5 -1
- package/menu/menu-item.d.ts +3 -15
- package/menu/menu-trigger.d.ts +6 -2
- package/menu/menu.d.ts +2 -4
- package/package.json +3 -2
- package/paginator/paginator.d.ts +6 -12
- package/prebuilt-themes/deeppurple-amber.css +1 -1
- package/prebuilt-themes/indigo-pink.css +1 -1
- package/prebuilt-themes/pink-bluegrey.css +1 -1
- package/prebuilt-themes/purple-green.css +1 -1
- package/progress-bar/progress-bar.d.ts +14 -5
- package/progress-spinner/progress-spinner.d.ts +23 -14
- package/radio/radio.d.ts +6 -13
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-add/index.mjs +1 -1
- package/schematics/ng-update/migrations/hammer-gestures-v9/import-manager.js +1 -2
- package/schematics/ng-update/migrations/hammer-gestures-v9/import-manager.mjs +1 -2
- package/schematics/ng-update/migrations/theming-api-v12/migration.js +2 -2
- package/schematics/ng-update/migrations/theming-api-v12/migration.mjs +2 -2
- package/schematics/tsconfig.json +1 -0
- package/select/select.d.ts +4 -11
- package/sidenav/drawer.d.ts +22 -14
- package/sidenav/sidenav.d.ts +3 -6
- package/slide-toggle/slide-toggle.d.ts +3 -8
- package/slider/_slider-theme.scss +12 -10
- package/slider/slider.d.ts +8 -18
- package/snack-bar/snack-bar.d.ts +18 -10
- package/sort/sort-header.d.ts +1 -3
- package/sort/sort.d.ts +1 -3
- package/table/_table-flex-styles.scss +0 -9
- package/tabs/_tabs-common.scss +0 -1
- package/tabs/paginated-tab-header.d.ts +1 -2
- package/tabs/tab-group.d.ts +4 -9
- package/tabs/tab-header.d.ts +2 -3
- package/tabs/tab-label-wrapper.d.ts +0 -2
- package/tabs/tab-nav-bar/tab-nav-bar.d.ts +4 -9
- package/tabs/tab.d.ts +0 -2
- package/tooltip/tooltip.d.ts +7 -11
- package/tree/node.d.ts +3 -6
- package/tree/padding.d.ts +2 -1
|
@@ -256,7 +256,7 @@ function replaceRemovedVariables(content, variables) {
|
|
|
256
256
|
Object.keys(variables).forEach(variableName => {
|
|
257
257
|
// Note that the pattern uses a negative lookahead to exclude
|
|
258
258
|
// variable assignments, because they can't be migrated.
|
|
259
|
-
const regex = new RegExp(`\\$${escapeRegExp(variableName)}(?!\\s
|
|
259
|
+
const regex = new RegExp(`\\$${escapeRegExp(variableName)}(?!\\s+:|[-_a-zA-Z0-9:])`, 'g');
|
|
260
260
|
content = content.replace(regex, variables[variableName]);
|
|
261
261
|
});
|
|
262
262
|
return content;
|
|
@@ -297,4 +297,4 @@ function restoreComments(content, placeholders) {
|
|
|
297
297
|
Object.keys(placeholders).forEach(key => (content = content.replace(key, placeholders[key])));
|
|
298
298
|
return content;
|
|
299
299
|
}
|
|
300
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migration.js","sourceRoot":"","sources":["../../../../../../../../../src/material/schematics/ng-update/migrations/theming-api-v12/migration.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {\n  materialMixins,\n  materialFunctions,\n  materialVariables,\n  cdkMixins,\n  cdkVariables,\n  removedMaterialVariables,\n  unprefixedRemovedVariables,\n} from './config';\n\n/** The result of a search for imports and namespaces in a file. */\ninterface DetectImportResult {\n  imports: string[];\n  namespaces: string[];\n}\n\n/** Addition mixin and function names that can be updated when invoking migration directly. */\ninterface ExtraSymbols {\n  mixins?: Record<string, string>;\n  functions?: Record<string, string>;\n  variables?: Record<string, string>;\n}\n\n/** Possible pairs of comment characters in a Sass file. */\nconst commentPairs = new Map<string, string>([\n  ['/*', '*/'],\n  ['//', '\\n'],\n]);\n\n/** Prefix for the placeholder that will be used to escape comments. */\nconst commentPlaceholderStart = '__<<ngThemingMigrationEscapedComment';\n\n/** Suffix for the comment escape placeholder. */\nconst commentPlaceholderEnd = '>>__';\n\n/**\n * Migrates the content of a file to the new theming API. Note that this migration is using plain\n * string manipulation, rather than the AST from PostCSS and the schematics string manipulation\n * APIs, because it allows us to run it inside g3 and to avoid introducing new dependencies.\n * @param fileContent Content of the file.\n * @param oldMaterialPrefix Prefix with which the old Material imports should start.\n *   Has to end with a slash. E.g. if `@import '@angular/material/theming'` should be\n *   matched, the prefix would be `@angular/material/`.\n * @param oldCdkPrefix Prefix with which the old CDK imports should start.\n *   Has to end with a slash. E.g. if `@import '@angular/cdk/overlay'` should be\n *   matched, the prefix would be `@angular/cdk/`.\n * @param newMaterialImportPath New import to the Material theming API (e.g. `@angular/material`).\n * @param newCdkImportPath New import to the CDK Sass APIs (e.g. `@angular/cdk`).\n * @param excludedImports Pattern that can be used to exclude imports from being processed.\n */\nexport function migrateFileContent(\n  fileContent: string,\n  oldMaterialPrefix: string,\n  oldCdkPrefix: string,\n  newMaterialImportPath: string,\n  newCdkImportPath: string,\n  extraMaterialSymbols: ExtraSymbols = {},\n  excludedImports?: RegExp,\n): string {\n  let {content, placeholders} = escapeComments(fileContent);\n  const materialResults = detectImports(content, oldMaterialPrefix, excludedImports);\n  const cdkResults = detectImports(content, oldCdkPrefix, excludedImports);\n\n  // Try to migrate the symbols even if there are no imports. This is used\n  // to cover the case where the Components symbols were used transitively.\n  content = migrateCdkSymbols(content, newCdkImportPath, placeholders, cdkResults);\n  content = migrateMaterialSymbols(\n    content,\n    newMaterialImportPath,\n    materialResults,\n    placeholders,\n    extraMaterialSymbols,\n  );\n  content = replaceRemovedVariables(content, removedMaterialVariables);\n\n  // We can assume that the migration has taken care of any Components symbols that were\n  // imported transitively so we can always drop the old imports. We also assume that imports\n  // to the new entry points have been added already.\n  if (materialResults.imports.length) {\n    content = replaceRemovedVariables(content, unprefixedRemovedVariables);\n    content = removeStrings(content, materialResults.imports);\n  }\n\n  if (cdkResults.imports.length) {\n    content = removeStrings(content, cdkResults.imports);\n  }\n\n  return restoreComments(content, placeholders);\n}\n\n/**\n * Counts the number of imports with a specific prefix and extracts their namespaces.\n * @param content File content in which to look for imports.\n * @param prefix Prefix that the imports should start with.\n * @param excludedImports Pattern that can be used to exclude imports from being processed.\n */\nfunction detectImports(\n  content: string,\n  prefix: string,\n  excludedImports?: RegExp,\n): DetectImportResult {\n  if (prefix[prefix.length - 1] !== '/') {\n    // Some of the logic further down makes assumptions about the import depth.\n    throw Error(`Prefix \"${prefix}\" has to end in a slash.`);\n  }\n\n  // List of `@use` namespaces from which Angular CDK/Material APIs may be referenced.\n  // Since we know that the library doesn't have any name collisions, we can treat all of these\n  // namespaces as equivalent.\n  const namespaces: string[] = [];\n  const imports: string[] = [];\n  const pattern = new RegExp(`@(import|use) +['\"]~?${escapeRegExp(prefix)}.*['\"].*;?\\n`, 'g');\n  let match: RegExpExecArray | null = null;\n\n  while ((match = pattern.exec(content))) {\n    const [fullImport, type] = match;\n\n    if (excludedImports?.test(fullImport)) {\n      continue;\n    }\n\n    if (type === 'use') {\n      const namespace = extractNamespaceFromUseStatement(fullImport);\n\n      if (namespaces.indexOf(namespace) === -1) {\n        namespaces.push(namespace);\n      }\n    }\n\n    imports.push(fullImport);\n  }\n\n  return {imports, namespaces};\n}\n\n/** Migrates the Material symbols in a file. */\nfunction migrateMaterialSymbols(\n  content: string,\n  importPath: string,\n  detectedImports: DetectImportResult,\n  commentPlaceholders: Record<string, string>,\n  extraMaterialSymbols: ExtraSymbols = {},\n): string {\n  const initialContent = content;\n  const namespace = 'mat';\n\n  // Migrate the mixins.\n  const mixinsToUpdate = {...materialMixins, ...extraMaterialSymbols.mixins};\n  content = renameSymbols(\n    content,\n    mixinsToUpdate,\n    detectedImports.namespaces,\n    mixinKeyFormatter,\n    getMixinValueFormatter(namespace),\n  );\n\n  // Migrate the functions.\n  const functionsToUpdate = {...materialFunctions, ...extraMaterialSymbols.functions};\n  content = renameSymbols(\n    content,\n    functionsToUpdate,\n    detectedImports.namespaces,\n    functionKeyFormatter,\n    getFunctionValueFormatter(namespace),\n  );\n\n  // Migrate the variables.\n  const variablesToUpdate = {...materialVariables, ...extraMaterialSymbols.variables};\n  content = renameSymbols(\n    content,\n    variablesToUpdate,\n    detectedImports.namespaces,\n    variableKeyFormatter,\n    getVariableValueFormatter(namespace),\n  );\n\n  if (content !== initialContent) {\n    // Add an import to the new API only if any of the APIs were being used.\n    content = insertUseStatement(content, importPath, namespace, commentPlaceholders);\n  }\n\n  return content;\n}\n\n/** Migrates the CDK symbols in a file. */\nfunction migrateCdkSymbols(\n  content: string,\n  importPath: string,\n  commentPlaceholders: Record<string, string>,\n  detectedImports: DetectImportResult,\n): string {\n  const initialContent = content;\n  const namespace = 'cdk';\n\n  // Migrate the mixins.\n  content = renameSymbols(\n    content,\n    cdkMixins,\n    detectedImports.namespaces,\n    mixinKeyFormatter,\n    getMixinValueFormatter(namespace),\n  );\n\n  // Migrate the variables.\n  content = renameSymbols(\n    content,\n    cdkVariables,\n    detectedImports.namespaces,\n    variableKeyFormatter,\n    getVariableValueFormatter(namespace),\n  );\n\n  // Previously the CDK symbols were exposed through `material/theming`, but now we have a\n  // dedicated entrypoint for the CDK. Only add an import for it if any of the symbols are used.\n  if (content !== initialContent) {\n    content = insertUseStatement(content, importPath, namespace, commentPlaceholders);\n  }\n\n  return content;\n}\n\n/**\n * Renames all Sass symbols in a file based on a pre-defined mapping.\n * @param content Content of a file to be migrated.\n * @param mapping Mapping between symbol names and their replacements.\n * @param namespaces Names to iterate over and pass to getKeyPattern.\n * @param getKeyPattern Function used to turn each of the keys into a regex.\n * @param formatValue Formats the value that will replace any matches of the pattern returned by\n *  `getKeyPattern`.\n */\nfunction renameSymbols(\n  content: string,\n  mapping: Record<string, string>,\n  namespaces: string[],\n  getKeyPattern: (namespace: string | null, key: string) => RegExp,\n  formatValue: (key: string) => string,\n): string {\n  // The null at the end is so that we make one last pass to cover non-namespaced symbols.\n  [...namespaces.slice(), null].forEach(namespace => {\n    Object.keys(mapping).forEach(key => {\n      const pattern = getKeyPattern(namespace, key);\n\n      // Sanity check since non-global regexes will only replace the first match.\n      if (pattern.flags.indexOf('g') === -1) {\n        throw Error('Replacement pattern must be global.');\n      }\n\n      content = content.replace(pattern, formatValue(mapping[key]));\n    });\n  });\n\n  return content;\n}\n\n/** Inserts an `@use` statement in a string. */\nfunction insertUseStatement(\n  content: string,\n  importPath: string,\n  namespace: string,\n  commentPlaceholders: Record<string, string>,\n): string {\n  // If the content already has the `@use` import, we don't need to add anything.\n  if (new RegExp(`@use +['\"]${importPath}['\"]`, 'g').test(content)) {\n    return content;\n  }\n\n  // Sass will throw an error if an `@use` statement comes after another statement. The safest way\n  // to ensure that we conform to that requirement is by always inserting our imports at the top\n  // of the file. Detecting where the user's content starts is tricky, because there are many\n  // different kinds of syntax we'd have to account for. One approach is to find the first `@import`\n  // and insert before it, but the problem is that Sass allows `@import` to be placed anywhere.\n  let newImportIndex = 0;\n\n  // One special case is if the file starts with a license header which we want to preserve on top.\n  if (content.trim().startsWith(commentPlaceholderStart)) {\n    const commentStartIndex = content.indexOf(commentPlaceholderStart);\n    newImportIndex =\n      content.indexOf(commentPlaceholderEnd, commentStartIndex + 1) + commentPlaceholderEnd.length;\n    // If the leading comment doesn't end with a newline,\n    // we need to insert the import at the next line.\n    if (!commentPlaceholders[content.slice(commentStartIndex, newImportIndex)].endsWith('\\n')) {\n      newImportIndex = Math.max(newImportIndex, content.indexOf('\\n', newImportIndex) + 1);\n    }\n  }\n\n  return (\n    content.slice(0, newImportIndex) +\n    `@use '${importPath}' as ${namespace};\\n` +\n    content.slice(newImportIndex)\n  );\n}\n\n/** Formats a migration key as a Sass mixin invocation. */\nfunction mixinKeyFormatter(namespace: string | null, name: string): RegExp {\n  // Note that adding a `(` at the end of the pattern would be more accurate, but mixin\n  // invocations don't necessarily have to include the parentheses. We could add `[(;]`,\n  // but then we won't know which character to include in the replacement string.\n  return new RegExp(`@include +${escapeRegExp((namespace ? namespace + '.' : '') + name)}`, 'g');\n}\n\n/** Returns a function that can be used to format a Sass mixin replacement. */\nfunction getMixinValueFormatter(namespace: string): (name: string) => string {\n  // Note that adding a `(` at the end of the pattern would be more accurate,\n  // but mixin invocations don't necessarily have to include the parentheses.\n  return name => `@include ${namespace}.${name}`;\n}\n\n/** Formats a migration key as a Sass function invocation. */\nfunction functionKeyFormatter(namespace: string | null, name: string): RegExp {\n  const functionName = escapeRegExp(`${namespace ? namespace + '.' : ''}${name}(`);\n  return new RegExp(`(?<![-_a-zA-Z0-9])${functionName}`, 'g');\n}\n\n/** Returns a function that can be used to format a Sass function replacement. */\nfunction getFunctionValueFormatter(namespace: string): (name: string) => string {\n  return name => `${namespace}.${name}(`;\n}\n\n/** Formats a migration key as a Sass variable. */\nfunction variableKeyFormatter(namespace: string | null, name: string): RegExp {\n  const variableName = escapeRegExp(`${namespace ? namespace + '.' : ''}$${name}`);\n  return new RegExp(`${variableName}(?![-_a-zA-Z0-9])`, 'g');\n}\n\n/** Returns a function that can be used to format a Sass variable replacement. */\nfunction getVariableValueFormatter(namespace: string): (name: string) => string {\n  return name => `${namespace}.$${name}`;\n}\n\n/** Escapes special regex characters in a string. */\nfunction escapeRegExp(str: string): string {\n  return str.replace(/([.*+?^=!:${}()|[\\]\\/\\\\])/g, '\\\\$1');\n}\n\n/** Removes all strings from another string. */\nfunction removeStrings(content: string, toRemove: string[]): string {\n  return toRemove\n    .reduce((accumulator, current) => accumulator.replace(current, ''), content)\n    .replace(/^\\s+/, '');\n}\n\n/** Parses out the namespace from a Sass `@use` statement. */\nfunction extractNamespaceFromUseStatement(fullImport: string): string {\n  const closeQuoteIndex = Math.max(fullImport.lastIndexOf(`\"`), fullImport.lastIndexOf(`'`));\n\n  if (closeQuoteIndex > -1) {\n    const asExpression = 'as ';\n    const asIndex = fullImport.indexOf(asExpression, closeQuoteIndex);\n\n    // If we found an ` as ` expression, we consider the rest of the text as the namespace.\n    if (asIndex > -1) {\n      return fullImport\n        .slice(asIndex + asExpression.length)\n        .split(';')[0]\n        .trim();\n    }\n\n    // Otherwise the namespace is the name of the file that is being imported.\n    const lastSlashIndex = fullImport.lastIndexOf('/', closeQuoteIndex);\n\n    if (lastSlashIndex > -1) {\n      const fileName = fullImport\n        .slice(lastSlashIndex + 1, closeQuoteIndex)\n        // Sass allows for leading underscores to be omitted and it technically supports .scss.\n        .replace(/^_|(\\.import)?\\.scss$|\\.import$/g, '');\n\n      // Sass ignores `/index` and infers the namespace as the next segment in the path.\n      if (fileName === 'index') {\n        const nextSlashIndex = fullImport.lastIndexOf('/', lastSlashIndex - 1);\n\n        if (nextSlashIndex > -1) {\n          return fullImport.slice(nextSlashIndex + 1, lastSlashIndex);\n        }\n      } else {\n        return fileName;\n      }\n    }\n  }\n\n  throw Error(`Could not extract namespace from import \"${fullImport}\".`);\n}\n\n/**\n * Replaces variables that have been removed with their values.\n * @param content Content of the file to be migrated.\n * @param variables Mapping between variable names and their values.\n */\nfunction replaceRemovedVariables(content: string, variables: Record<string, string>): string {\n  Object.keys(variables).forEach(variableName => {\n    // Note that the pattern uses a negative lookahead to exclude\n    // variable assignments, because they can't be migrated.\n    const regex = new RegExp(`\\\\$${escapeRegExp(variableName)}(?!\\\\s+:|:)`, 'g');\n    content = content.replace(regex, variables[variableName]);\n  });\n\n  return content;\n}\n\n/**\n * Replaces all of the comments in a Sass file with placeholders and\n * returns the list of placeholders so they can be restored later.\n */\nfunction escapeComments(content: string): {content: string; placeholders: Record<string, string>} {\n  const placeholders: Record<string, string> = {};\n  let commentCounter = 0;\n  let [openIndex, closeIndex] = findComment(content);\n\n  while (openIndex > -1 && closeIndex > -1) {\n    const placeholder = commentPlaceholderStart + commentCounter++ + commentPlaceholderEnd;\n    placeholders[placeholder] = content.slice(openIndex, closeIndex);\n    content = content.slice(0, openIndex) + placeholder + content.slice(closeIndex);\n    [openIndex, closeIndex] = findComment(content);\n  }\n\n  return {content, placeholders};\n}\n\n/** Finds the start and end index of a comment in a file. */\nfunction findComment(content: string): [openIndex: number, closeIndex: number] {\n  // Add an extra new line at the end so that we can correctly capture single-line comments\n  // at the end of the file. It doesn't really matter that the end index will be out of bounds,\n  // because `String.prototype.slice` will clamp it to the string length.\n  content += '\\n';\n\n  for (const [open, close] of commentPairs.entries()) {\n    const openIndex = content.indexOf(open);\n\n    if (openIndex > -1) {\n      const closeIndex = content.indexOf(close, openIndex + 1);\n      return closeIndex > -1 ? [openIndex, closeIndex + close.length] : [-1, -1];\n    }\n  }\n\n  return [-1, -1];\n}\n\n/** Restores the comments that have been escaped by `escapeComments`. */\nfunction restoreComments(content: string, placeholders: Record<string, string>): string {\n  Object.keys(placeholders).forEach(key => (content = content.replace(key, placeholders[key])));\n  return content;\n}\n"]}
|
|
300
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migration.js","sourceRoot":"","sources":["../../../../../../../../../src/material/schematics/ng-update/migrations/theming-api-v12/migration.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {\n  materialMixins,\n  materialFunctions,\n  materialVariables,\n  cdkMixins,\n  cdkVariables,\n  removedMaterialVariables,\n  unprefixedRemovedVariables,\n} from './config';\n\n/** The result of a search for imports and namespaces in a file. */\ninterface DetectImportResult {\n  imports: string[];\n  namespaces: string[];\n}\n\n/** Addition mixin and function names that can be updated when invoking migration directly. */\ninterface ExtraSymbols {\n  mixins?: Record<string, string>;\n  functions?: Record<string, string>;\n  variables?: Record<string, string>;\n}\n\n/** Possible pairs of comment characters in a Sass file. */\nconst commentPairs = new Map<string, string>([\n  ['/*', '*/'],\n  ['//', '\\n'],\n]);\n\n/** Prefix for the placeholder that will be used to escape comments. */\nconst commentPlaceholderStart = '__<<ngThemingMigrationEscapedComment';\n\n/** Suffix for the comment escape placeholder. */\nconst commentPlaceholderEnd = '>>__';\n\n/**\n * Migrates the content of a file to the new theming API. Note that this migration is using plain\n * string manipulation, rather than the AST from PostCSS and the schematics string manipulation\n * APIs, because it allows us to run it inside g3 and to avoid introducing new dependencies.\n * @param fileContent Content of the file.\n * @param oldMaterialPrefix Prefix with which the old Material imports should start.\n *   Has to end with a slash. E.g. if `@import '@angular/material/theming'` should be\n *   matched, the prefix would be `@angular/material/`.\n * @param oldCdkPrefix Prefix with which the old CDK imports should start.\n *   Has to end with a slash. E.g. if `@import '@angular/cdk/overlay'` should be\n *   matched, the prefix would be `@angular/cdk/`.\n * @param newMaterialImportPath New import to the Material theming API (e.g. `@angular/material`).\n * @param newCdkImportPath New import to the CDK Sass APIs (e.g. `@angular/cdk`).\n * @param excludedImports Pattern that can be used to exclude imports from being processed.\n */\nexport function migrateFileContent(\n  fileContent: string,\n  oldMaterialPrefix: string,\n  oldCdkPrefix: string,\n  newMaterialImportPath: string,\n  newCdkImportPath: string,\n  extraMaterialSymbols: ExtraSymbols = {},\n  excludedImports?: RegExp,\n): string {\n  let {content, placeholders} = escapeComments(fileContent);\n  const materialResults = detectImports(content, oldMaterialPrefix, excludedImports);\n  const cdkResults = detectImports(content, oldCdkPrefix, excludedImports);\n\n  // Try to migrate the symbols even if there are no imports. This is used\n  // to cover the case where the Components symbols were used transitively.\n  content = migrateCdkSymbols(content, newCdkImportPath, placeholders, cdkResults);\n  content = migrateMaterialSymbols(\n    content,\n    newMaterialImportPath,\n    materialResults,\n    placeholders,\n    extraMaterialSymbols,\n  );\n  content = replaceRemovedVariables(content, removedMaterialVariables);\n\n  // We can assume that the migration has taken care of any Components symbols that were\n  // imported transitively so we can always drop the old imports. We also assume that imports\n  // to the new entry points have been added already.\n  if (materialResults.imports.length) {\n    content = replaceRemovedVariables(content, unprefixedRemovedVariables);\n    content = removeStrings(content, materialResults.imports);\n  }\n\n  if (cdkResults.imports.length) {\n    content = removeStrings(content, cdkResults.imports);\n  }\n\n  return restoreComments(content, placeholders);\n}\n\n/**\n * Counts the number of imports with a specific prefix and extracts their namespaces.\n * @param content File content in which to look for imports.\n * @param prefix Prefix that the imports should start with.\n * @param excludedImports Pattern that can be used to exclude imports from being processed.\n */\nfunction detectImports(\n  content: string,\n  prefix: string,\n  excludedImports?: RegExp,\n): DetectImportResult {\n  if (prefix[prefix.length - 1] !== '/') {\n    // Some of the logic further down makes assumptions about the import depth.\n    throw Error(`Prefix \"${prefix}\" has to end in a slash.`);\n  }\n\n  // List of `@use` namespaces from which Angular CDK/Material APIs may be referenced.\n  // Since we know that the library doesn't have any name collisions, we can treat all of these\n  // namespaces as equivalent.\n  const namespaces: string[] = [];\n  const imports: string[] = [];\n  const pattern = new RegExp(`@(import|use) +['\"]~?${escapeRegExp(prefix)}.*['\"].*;?\\n`, 'g');\n  let match: RegExpExecArray | null = null;\n\n  while ((match = pattern.exec(content))) {\n    const [fullImport, type] = match;\n\n    if (excludedImports?.test(fullImport)) {\n      continue;\n    }\n\n    if (type === 'use') {\n      const namespace = extractNamespaceFromUseStatement(fullImport);\n\n      if (namespaces.indexOf(namespace) === -1) {\n        namespaces.push(namespace);\n      }\n    }\n\n    imports.push(fullImport);\n  }\n\n  return {imports, namespaces};\n}\n\n/** Migrates the Material symbols in a file. */\nfunction migrateMaterialSymbols(\n  content: string,\n  importPath: string,\n  detectedImports: DetectImportResult,\n  commentPlaceholders: Record<string, string>,\n  extraMaterialSymbols: ExtraSymbols = {},\n): string {\n  const initialContent = content;\n  const namespace = 'mat';\n\n  // Migrate the mixins.\n  const mixinsToUpdate = {...materialMixins, ...extraMaterialSymbols.mixins};\n  content = renameSymbols(\n    content,\n    mixinsToUpdate,\n    detectedImports.namespaces,\n    mixinKeyFormatter,\n    getMixinValueFormatter(namespace),\n  );\n\n  // Migrate the functions.\n  const functionsToUpdate = {...materialFunctions, ...extraMaterialSymbols.functions};\n  content = renameSymbols(\n    content,\n    functionsToUpdate,\n    detectedImports.namespaces,\n    functionKeyFormatter,\n    getFunctionValueFormatter(namespace),\n  );\n\n  // Migrate the variables.\n  const variablesToUpdate = {...materialVariables, ...extraMaterialSymbols.variables};\n  content = renameSymbols(\n    content,\n    variablesToUpdate,\n    detectedImports.namespaces,\n    variableKeyFormatter,\n    getVariableValueFormatter(namespace),\n  );\n\n  if (content !== initialContent) {\n    // Add an import to the new API only if any of the APIs were being used.\n    content = insertUseStatement(content, importPath, namespace, commentPlaceholders);\n  }\n\n  return content;\n}\n\n/** Migrates the CDK symbols in a file. */\nfunction migrateCdkSymbols(\n  content: string,\n  importPath: string,\n  commentPlaceholders: Record<string, string>,\n  detectedImports: DetectImportResult,\n): string {\n  const initialContent = content;\n  const namespace = 'cdk';\n\n  // Migrate the mixins.\n  content = renameSymbols(\n    content,\n    cdkMixins,\n    detectedImports.namespaces,\n    mixinKeyFormatter,\n    getMixinValueFormatter(namespace),\n  );\n\n  // Migrate the variables.\n  content = renameSymbols(\n    content,\n    cdkVariables,\n    detectedImports.namespaces,\n    variableKeyFormatter,\n    getVariableValueFormatter(namespace),\n  );\n\n  // Previously the CDK symbols were exposed through `material/theming`, but now we have a\n  // dedicated entrypoint for the CDK. Only add an import for it if any of the symbols are used.\n  if (content !== initialContent) {\n    content = insertUseStatement(content, importPath, namespace, commentPlaceholders);\n  }\n\n  return content;\n}\n\n/**\n * Renames all Sass symbols in a file based on a pre-defined mapping.\n * @param content Content of a file to be migrated.\n * @param mapping Mapping between symbol names and their replacements.\n * @param namespaces Names to iterate over and pass to getKeyPattern.\n * @param getKeyPattern Function used to turn each of the keys into a regex.\n * @param formatValue Formats the value that will replace any matches of the pattern returned by\n *  `getKeyPattern`.\n */\nfunction renameSymbols(\n  content: string,\n  mapping: Record<string, string>,\n  namespaces: string[],\n  getKeyPattern: (namespace: string | null, key: string) => RegExp,\n  formatValue: (key: string) => string,\n): string {\n  // The null at the end is so that we make one last pass to cover non-namespaced symbols.\n  [...namespaces.slice(), null].forEach(namespace => {\n    Object.keys(mapping).forEach(key => {\n      const pattern = getKeyPattern(namespace, key);\n\n      // Sanity check since non-global regexes will only replace the first match.\n      if (pattern.flags.indexOf('g') === -1) {\n        throw Error('Replacement pattern must be global.');\n      }\n\n      content = content.replace(pattern, formatValue(mapping[key]));\n    });\n  });\n\n  return content;\n}\n\n/** Inserts an `@use` statement in a string. */\nfunction insertUseStatement(\n  content: string,\n  importPath: string,\n  namespace: string,\n  commentPlaceholders: Record<string, string>,\n): string {\n  // If the content already has the `@use` import, we don't need to add anything.\n  if (new RegExp(`@use +['\"]${importPath}['\"]`, 'g').test(content)) {\n    return content;\n  }\n\n  // Sass will throw an error if an `@use` statement comes after another statement. The safest way\n  // to ensure that we conform to that requirement is by always inserting our imports at the top\n  // of the file. Detecting where the user's content starts is tricky, because there are many\n  // different kinds of syntax we'd have to account for. One approach is to find the first `@import`\n  // and insert before it, but the problem is that Sass allows `@import` to be placed anywhere.\n  let newImportIndex = 0;\n\n  // One special case is if the file starts with a license header which we want to preserve on top.\n  if (content.trim().startsWith(commentPlaceholderStart)) {\n    const commentStartIndex = content.indexOf(commentPlaceholderStart);\n    newImportIndex =\n      content.indexOf(commentPlaceholderEnd, commentStartIndex + 1) + commentPlaceholderEnd.length;\n    // If the leading comment doesn't end with a newline,\n    // we need to insert the import at the next line.\n    if (!commentPlaceholders[content.slice(commentStartIndex, newImportIndex)].endsWith('\\n')) {\n      newImportIndex = Math.max(newImportIndex, content.indexOf('\\n', newImportIndex) + 1);\n    }\n  }\n\n  return (\n    content.slice(0, newImportIndex) +\n    `@use '${importPath}' as ${namespace};\\n` +\n    content.slice(newImportIndex)\n  );\n}\n\n/** Formats a migration key as a Sass mixin invocation. */\nfunction mixinKeyFormatter(namespace: string | null, name: string): RegExp {\n  // Note that adding a `(` at the end of the pattern would be more accurate, but mixin\n  // invocations don't necessarily have to include the parentheses. We could add `[(;]`,\n  // but then we won't know which character to include in the replacement string.\n  return new RegExp(`@include +${escapeRegExp((namespace ? namespace + '.' : '') + name)}`, 'g');\n}\n\n/** Returns a function that can be used to format a Sass mixin replacement. */\nfunction getMixinValueFormatter(namespace: string): (name: string) => string {\n  // Note that adding a `(` at the end of the pattern would be more accurate,\n  // but mixin invocations don't necessarily have to include the parentheses.\n  return name => `@include ${namespace}.${name}`;\n}\n\n/** Formats a migration key as a Sass function invocation. */\nfunction functionKeyFormatter(namespace: string | null, name: string): RegExp {\n  const functionName = escapeRegExp(`${namespace ? namespace + '.' : ''}${name}(`);\n  return new RegExp(`(?<![-_a-zA-Z0-9])${functionName}`, 'g');\n}\n\n/** Returns a function that can be used to format a Sass function replacement. */\nfunction getFunctionValueFormatter(namespace: string): (name: string) => string {\n  return name => `${namespace}.${name}(`;\n}\n\n/** Formats a migration key as a Sass variable. */\nfunction variableKeyFormatter(namespace: string | null, name: string): RegExp {\n  const variableName = escapeRegExp(`${namespace ? namespace + '.' : ''}$${name}`);\n  return new RegExp(`${variableName}(?![-_a-zA-Z0-9])`, 'g');\n}\n\n/** Returns a function that can be used to format a Sass variable replacement. */\nfunction getVariableValueFormatter(namespace: string): (name: string) => string {\n  return name => `${namespace}.$${name}`;\n}\n\n/** Escapes special regex characters in a string. */\nfunction escapeRegExp(str: string): string {\n  return str.replace(/([.*+?^=!:${}()|[\\]\\/\\\\])/g, '\\\\$1');\n}\n\n/** Removes all strings from another string. */\nfunction removeStrings(content: string, toRemove: string[]): string {\n  return toRemove\n    .reduce((accumulator, current) => accumulator.replace(current, ''), content)\n    .replace(/^\\s+/, '');\n}\n\n/** Parses out the namespace from a Sass `@use` statement. */\nfunction extractNamespaceFromUseStatement(fullImport: string): string {\n  const closeQuoteIndex = Math.max(fullImport.lastIndexOf(`\"`), fullImport.lastIndexOf(`'`));\n\n  if (closeQuoteIndex > -1) {\n    const asExpression = 'as ';\n    const asIndex = fullImport.indexOf(asExpression, closeQuoteIndex);\n\n    // If we found an ` as ` expression, we consider the rest of the text as the namespace.\n    if (asIndex > -1) {\n      return fullImport\n        .slice(asIndex + asExpression.length)\n        .split(';')[0]\n        .trim();\n    }\n\n    // Otherwise the namespace is the name of the file that is being imported.\n    const lastSlashIndex = fullImport.lastIndexOf('/', closeQuoteIndex);\n\n    if (lastSlashIndex > -1) {\n      const fileName = fullImport\n        .slice(lastSlashIndex + 1, closeQuoteIndex)\n        // Sass allows for leading underscores to be omitted and it technically supports .scss.\n        .replace(/^_|(\\.import)?\\.scss$|\\.import$/g, '');\n\n      // Sass ignores `/index` and infers the namespace as the next segment in the path.\n      if (fileName === 'index') {\n        const nextSlashIndex = fullImport.lastIndexOf('/', lastSlashIndex - 1);\n\n        if (nextSlashIndex > -1) {\n          return fullImport.slice(nextSlashIndex + 1, lastSlashIndex);\n        }\n      } else {\n        return fileName;\n      }\n    }\n  }\n\n  throw Error(`Could not extract namespace from import \"${fullImport}\".`);\n}\n\n/**\n * Replaces variables that have been removed with their values.\n * @param content Content of the file to be migrated.\n * @param variables Mapping between variable names and their values.\n */\nfunction replaceRemovedVariables(content: string, variables: Record<string, string>): string {\n  Object.keys(variables).forEach(variableName => {\n    // Note that the pattern uses a negative lookahead to exclude\n    // variable assignments, because they can't be migrated.\n    const regex = new RegExp(`\\\\$${escapeRegExp(variableName)}(?!\\\\s+:|[-_a-zA-Z0-9:])`, 'g');\n    content = content.replace(regex, variables[variableName]);\n  });\n\n  return content;\n}\n\n/**\n * Replaces all of the comments in a Sass file with placeholders and\n * returns the list of placeholders so they can be restored later.\n */\nfunction escapeComments(content: string): {content: string; placeholders: Record<string, string>} {\n  const placeholders: Record<string, string> = {};\n  let commentCounter = 0;\n  let [openIndex, closeIndex] = findComment(content);\n\n  while (openIndex > -1 && closeIndex > -1) {\n    const placeholder = commentPlaceholderStart + commentCounter++ + commentPlaceholderEnd;\n    placeholders[placeholder] = content.slice(openIndex, closeIndex);\n    content = content.slice(0, openIndex) + placeholder + content.slice(closeIndex);\n    [openIndex, closeIndex] = findComment(content);\n  }\n\n  return {content, placeholders};\n}\n\n/** Finds the start and end index of a comment in a file. */\nfunction findComment(content: string): [openIndex: number, closeIndex: number] {\n  // Add an extra new line at the end so that we can correctly capture single-line comments\n  // at the end of the file. It doesn't really matter that the end index will be out of bounds,\n  // because `String.prototype.slice` will clamp it to the string length.\n  content += '\\n';\n\n  for (const [open, close] of commentPairs.entries()) {\n    const openIndex = content.indexOf(open);\n\n    if (openIndex > -1) {\n      const closeIndex = content.indexOf(close, openIndex + 1);\n      return closeIndex > -1 ? [openIndex, closeIndex + close.length] : [-1, -1];\n    }\n  }\n\n  return [-1, -1];\n}\n\n/** Restores the comments that have been escaped by `escapeComments`. */\nfunction restoreComments(content: string, placeholders: Record<string, string>): string {\n  Object.keys(placeholders).forEach(key => (content = content.replace(key, placeholders[key])));\n  return content;\n}\n"]}
|
package/schematics/tsconfig.json
CHANGED
package/select/select.d.ts
CHANGED
|
@@ -179,15 +179,15 @@ export declare abstract class _MatSelectBase<C> extends _MatSelectMixinBase impl
|
|
|
179
179
|
private _placeholder;
|
|
180
180
|
/** Whether the component is required. */
|
|
181
181
|
get required(): boolean;
|
|
182
|
-
set required(value:
|
|
182
|
+
set required(value: BooleanInput);
|
|
183
183
|
private _required;
|
|
184
184
|
/** Whether the user should be allowed to select multiple options. */
|
|
185
185
|
get multiple(): boolean;
|
|
186
|
-
set multiple(value:
|
|
186
|
+
set multiple(value: BooleanInput);
|
|
187
187
|
private _multiple;
|
|
188
188
|
/** Whether to center the active option over the trigger. */
|
|
189
189
|
get disableOptionCentering(): boolean;
|
|
190
|
-
set disableOptionCentering(value:
|
|
190
|
+
set disableOptionCentering(value: BooleanInput);
|
|
191
191
|
private _disableOptionCentering;
|
|
192
192
|
/**
|
|
193
193
|
* Function to compare the option values with the selected values. The first argument
|
|
@@ -208,7 +208,7 @@ export declare abstract class _MatSelectBase<C> extends _MatSelectMixinBase impl
|
|
|
208
208
|
errorStateMatcher: ErrorStateMatcher;
|
|
209
209
|
/** Time to wait in milliseconds after the last keystroke before moving focus to an item. */
|
|
210
210
|
get typeaheadDebounceInterval(): number;
|
|
211
|
-
set typeaheadDebounceInterval(value:
|
|
211
|
+
set typeaheadDebounceInterval(value: NumberInput);
|
|
212
212
|
private _typeaheadDebounceInterval;
|
|
213
213
|
/**
|
|
214
214
|
* Function used to sort the values in a select in multiple mode.
|
|
@@ -358,13 +358,6 @@ export declare abstract class _MatSelectBase<C> extends _MatSelectMixinBase impl
|
|
|
358
358
|
* @docs-private
|
|
359
359
|
*/
|
|
360
360
|
get shouldLabelFloat(): boolean;
|
|
361
|
-
static ngAcceptInputType_required: BooleanInput;
|
|
362
|
-
static ngAcceptInputType_multiple: BooleanInput;
|
|
363
|
-
static ngAcceptInputType_disableOptionCentering: BooleanInput;
|
|
364
|
-
static ngAcceptInputType_typeaheadDebounceInterval: NumberInput;
|
|
365
|
-
static ngAcceptInputType_disabled: BooleanInput;
|
|
366
|
-
static ngAcceptInputType_disableRipple: BooleanInput;
|
|
367
|
-
static ngAcceptInputType_tabIndex: NumberInput;
|
|
368
361
|
static ɵfac: i0.ɵɵFactoryDeclaration<_MatSelectBase<any>, [null, null, null, null, null, { optional: true; }, { optional: true; }, { optional: true; }, { optional: true; }, { optional: true; self: true; }, { attribute: "tabindex"; }, null, null, { optional: true; }]>;
|
|
369
362
|
static ɵdir: i0.ɵɵDirectiveDeclaration<_MatSelectBase<any>, never, never, { "panelClass": "panelClass"; "placeholder": "placeholder"; "required": "required"; "multiple": "multiple"; "disableOptionCentering": "disableOptionCentering"; "compareWith": "compareWith"; "value": "value"; "ariaLabel": "aria-label"; "ariaLabelledby": "aria-labelledby"; "errorStateMatcher": "errorStateMatcher"; "typeaheadDebounceInterval": "typeaheadDebounceInterval"; "sortComparator": "sortComparator"; "id": "id"; }, { "openedChange": "openedChange"; "_openedStream": "opened"; "_closedStream": "closed"; "selectionChange": "selectionChange"; "valueChange": "valueChange"; }, never>;
|
|
370
363
|
}
|
package/sidenav/drawer.d.ts
CHANGED
|
@@ -11,7 +11,7 @@ import { Directionality } from '@angular/cdk/bidi';
|
|
|
11
11
|
import { BooleanInput } from '@angular/cdk/coercion';
|
|
12
12
|
import { Platform } from '@angular/cdk/platform';
|
|
13
13
|
import { CdkScrollable, ScrollDispatcher, ViewportRuler } from '@angular/cdk/scrolling';
|
|
14
|
-
import { AfterContentChecked, AfterContentInit, ChangeDetectorRef, DoCheck, ElementRef, EventEmitter, InjectionToken, NgZone, OnDestroy, QueryList } from '@angular/core';
|
|
14
|
+
import { AfterContentChecked, AfterContentInit, AfterViewInit, ChangeDetectorRef, DoCheck, ElementRef, EventEmitter, InjectionToken, NgZone, OnDestroy, QueryList } from '@angular/core';
|
|
15
15
|
import { Observable, Subject } from 'rxjs';
|
|
16
16
|
import * as i0 from "@angular/core";
|
|
17
17
|
/**
|
|
@@ -45,7 +45,7 @@ export declare class MatDrawerContent extends CdkScrollable implements AfterCont
|
|
|
45
45
|
/**
|
|
46
46
|
* This component corresponds to a drawer that can be opened on the drawer container.
|
|
47
47
|
*/
|
|
48
|
-
export declare class MatDrawer implements
|
|
48
|
+
export declare class MatDrawer implements AfterViewInit, AfterContentChecked, OnDestroy {
|
|
49
49
|
private _elementRef;
|
|
50
50
|
private _focusTrapFactory;
|
|
51
51
|
private _focusMonitor;
|
|
@@ -58,6 +58,10 @@ export declare class MatDrawer implements AfterContentInit, AfterContentChecked,
|
|
|
58
58
|
private _elementFocusedBeforeDrawerWasOpened;
|
|
59
59
|
/** Whether the drawer is initialized. Used for disabling the initial animation. */
|
|
60
60
|
private _enableAnimations;
|
|
61
|
+
/** Whether the view of the component has been attached. */
|
|
62
|
+
private _isAttached;
|
|
63
|
+
/** Anchor node used to restore the drawer to its initial position. */
|
|
64
|
+
private _anchor;
|
|
61
65
|
/** The side that the drawer is attached to. */
|
|
62
66
|
get position(): 'start' | 'end';
|
|
63
67
|
set position(value: 'start' | 'end');
|
|
@@ -68,7 +72,7 @@ export declare class MatDrawer implements AfterContentInit, AfterContentChecked,
|
|
|
68
72
|
private _mode;
|
|
69
73
|
/** Whether the drawer can be closed with the escape key or by clicking on the backdrop. */
|
|
70
74
|
get disableClose(): boolean;
|
|
71
|
-
set disableClose(value:
|
|
75
|
+
set disableClose(value: BooleanInput);
|
|
72
76
|
private _disableClose;
|
|
73
77
|
/**
|
|
74
78
|
* Whether the drawer should focus the first focusable element automatically when opened.
|
|
@@ -78,14 +82,14 @@ export declare class MatDrawer implements AfterContentInit, AfterContentChecked,
|
|
|
78
82
|
* instead.
|
|
79
83
|
*/
|
|
80
84
|
get autoFocus(): AutoFocusTarget | string | boolean;
|
|
81
|
-
set autoFocus(value: AutoFocusTarget | string |
|
|
85
|
+
set autoFocus(value: AutoFocusTarget | string | BooleanInput);
|
|
82
86
|
private _autoFocus;
|
|
83
87
|
/**
|
|
84
88
|
* Whether the drawer is opened. We overload this because we trigger an event when it
|
|
85
89
|
* starts or end.
|
|
86
90
|
*/
|
|
87
91
|
get opened(): boolean;
|
|
88
|
-
set opened(value:
|
|
92
|
+
set opened(value: BooleanInput);
|
|
89
93
|
private _opened;
|
|
90
94
|
/** How the sidenav was opened (keypress, mouse click etc.) */
|
|
91
95
|
private _openedVia;
|
|
@@ -109,6 +113,8 @@ export declare class MatDrawer implements AfterContentInit, AfterContentChecked,
|
|
|
109
113
|
private readonly _destroyed;
|
|
110
114
|
/** Event emitted when the drawer's position changes. */
|
|
111
115
|
readonly onPositionChanged: EventEmitter<void>;
|
|
116
|
+
/** Reference to the inner element that contains all the content. */
|
|
117
|
+
_content: ElementRef<HTMLElement>;
|
|
112
118
|
/**
|
|
113
119
|
* An observable that emits when the drawer mode changes. This is used by the drawer container to
|
|
114
120
|
* to know when to when the mode changes so it can adapt the margins on the content.
|
|
@@ -138,7 +144,7 @@ export declare class MatDrawer implements AfterContentInit, AfterContentChecked,
|
|
|
138
144
|
private _restoreFocus;
|
|
139
145
|
/** Whether focus is currently within the drawer. */
|
|
140
146
|
private _isFocusWithinDrawer;
|
|
141
|
-
|
|
147
|
+
ngAfterViewInit(): void;
|
|
142
148
|
ngAfterContentChecked(): void;
|
|
143
149
|
ngOnDestroy(): void;
|
|
144
150
|
/**
|
|
@@ -168,9 +174,13 @@ export declare class MatDrawer implements AfterContentInit, AfterContentChecked,
|
|
|
168
174
|
_getWidth(): number;
|
|
169
175
|
/** Updates the enabled state of the focus trap. */
|
|
170
176
|
private _updateFocusTrapState;
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
177
|
+
/**
|
|
178
|
+
* Updates the position of the drawer in the DOM. We need to move the element around ourselves
|
|
179
|
+
* when it's in the `end` position so that it comes after the content and the visual order
|
|
180
|
+
* matches the tab order. We also need to be able to move it back to `start` if the sidenav
|
|
181
|
+
* started off as `end` and was changed to `start`.
|
|
182
|
+
*/
|
|
183
|
+
private _updatePositionInParent;
|
|
174
184
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatDrawer, [null, null, null, null, null, null, { optional: true; }, { optional: true; }]>;
|
|
175
185
|
static ɵcmp: i0.ɵɵComponentDeclaration<MatDrawer, "mat-drawer", ["matDrawer"], { "position": "position"; "mode": "mode"; "disableClose": "disableClose"; "autoFocus": "autoFocus"; "opened": "opened"; }, { "openedChange": "openedChange"; "_openedStream": "opened"; "openedStart": "openedStart"; "_closedStream": "closed"; "closedStart": "closedStart"; "onPositionChanged": "positionChanged"; }, never, ["*"]>;
|
|
176
186
|
}
|
|
@@ -205,15 +215,15 @@ export declare class MatDrawerContainer implements AfterContentInit, DoCheck, On
|
|
|
205
215
|
* `MAT_DRAWER_DEFAULT_AUTOSIZE` token.
|
|
206
216
|
*/
|
|
207
217
|
get autosize(): boolean;
|
|
208
|
-
set autosize(value:
|
|
218
|
+
set autosize(value: BooleanInput);
|
|
209
219
|
private _autosize;
|
|
210
220
|
/**
|
|
211
221
|
* Whether the drawer container should have a backdrop while one of the sidenavs is open.
|
|
212
222
|
* If explicitly set to `true`, the backdrop will be enabled for drawers in the `side`
|
|
213
223
|
* mode as well.
|
|
214
224
|
*/
|
|
215
|
-
get hasBackdrop():
|
|
216
|
-
set hasBackdrop(value:
|
|
225
|
+
get hasBackdrop(): boolean;
|
|
226
|
+
set hasBackdrop(value: BooleanInput);
|
|
217
227
|
_backdropOverride: boolean | null;
|
|
218
228
|
/** Event emitted when the drawer backdrop is clicked. */
|
|
219
229
|
readonly backdropClick: EventEmitter<void>;
|
|
@@ -284,8 +294,6 @@ export declare class MatDrawerContainer implements AfterContentInit, DoCheck, On
|
|
|
284
294
|
_isShowingBackdrop(): boolean;
|
|
285
295
|
private _canHaveBackdrop;
|
|
286
296
|
private _isDrawerOpen;
|
|
287
|
-
static ngAcceptInputType_autosize: BooleanInput;
|
|
288
|
-
static ngAcceptInputType_hasBackdrop: BooleanInput;
|
|
289
297
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatDrawerContainer, [{ optional: true; }, null, null, null, null, null, { optional: true; }]>;
|
|
290
298
|
static ɵcmp: i0.ɵɵComponentDeclaration<MatDrawerContainer, "mat-drawer-container", ["matDrawerContainer"], { "autosize": "autosize"; "hasBackdrop": "hasBackdrop"; }, { "backdropClick": "backdropClick"; }, ["_content", "_allDrawers"], ["mat-drawer", "mat-drawer-content", "*"]>;
|
|
291
299
|
}
|
package/sidenav/sidenav.d.ts
CHANGED
|
@@ -18,25 +18,22 @@ export declare class MatSidenavContent extends MatDrawerContent {
|
|
|
18
18
|
export declare class MatSidenav extends MatDrawer {
|
|
19
19
|
/** Whether the sidenav is fixed in the viewport. */
|
|
20
20
|
get fixedInViewport(): boolean;
|
|
21
|
-
set fixedInViewport(value:
|
|
21
|
+
set fixedInViewport(value: BooleanInput);
|
|
22
22
|
private _fixedInViewport;
|
|
23
23
|
/**
|
|
24
24
|
* The gap between the top of the sidenav and the top of the viewport when the sidenav is in fixed
|
|
25
25
|
* mode.
|
|
26
26
|
*/
|
|
27
27
|
get fixedTopGap(): number;
|
|
28
|
-
set fixedTopGap(value:
|
|
28
|
+
set fixedTopGap(value: NumberInput);
|
|
29
29
|
private _fixedTopGap;
|
|
30
30
|
/**
|
|
31
31
|
* The gap between the bottom of the sidenav and the bottom of the viewport when the sidenav is in
|
|
32
32
|
* fixed mode.
|
|
33
33
|
*/
|
|
34
34
|
get fixedBottomGap(): number;
|
|
35
|
-
set fixedBottomGap(value:
|
|
35
|
+
set fixedBottomGap(value: NumberInput);
|
|
36
36
|
private _fixedBottomGap;
|
|
37
|
-
static ngAcceptInputType_fixedInViewport: BooleanInput;
|
|
38
|
-
static ngAcceptInputType_fixedTopGap: NumberInput;
|
|
39
|
-
static ngAcceptInputType_fixedBottomGap: NumberInput;
|
|
40
37
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatSidenav, never>;
|
|
41
38
|
static ɵcmp: i0.ɵɵComponentDeclaration<MatSidenav, "mat-sidenav", ["matSidenav"], { "fixedInViewport": "fixedInViewport"; "fixedTopGap": "fixedTopGap"; "fixedBottomGap": "fixedBottomGap"; }, {}, never, ["*"]>;
|
|
42
39
|
}
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
8
|
import { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y';
|
|
9
|
-
import { BooleanInput
|
|
9
|
+
import { BooleanInput } from '@angular/cdk/coercion';
|
|
10
10
|
import { AfterContentInit, ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy } from '@angular/core';
|
|
11
11
|
import { ControlValueAccessor } from '@angular/forms';
|
|
12
12
|
import { CanColor, CanDisable, CanDisableRipple, HasTabIndex } from '@angular/material/core';
|
|
@@ -62,10 +62,10 @@ export declare class MatSlideToggle extends _MatSlideToggleBase implements OnDes
|
|
|
62
62
|
ariaDescribedby: string;
|
|
63
63
|
/** Whether the slide-toggle is required. */
|
|
64
64
|
get required(): boolean;
|
|
65
|
-
set required(value:
|
|
65
|
+
set required(value: BooleanInput);
|
|
66
66
|
/** Whether the slide-toggle element is checked or not. */
|
|
67
67
|
get checked(): boolean;
|
|
68
|
-
set checked(value:
|
|
68
|
+
set checked(value: BooleanInput);
|
|
69
69
|
/** An event will be dispatched each time the slide-toggle changes its value. */
|
|
70
70
|
readonly change: EventEmitter<MatSlideToggleChange>;
|
|
71
71
|
/**
|
|
@@ -103,11 +103,6 @@ export declare class MatSlideToggle extends _MatSlideToggleBase implements OnDes
|
|
|
103
103
|
private _emitChangeEvent;
|
|
104
104
|
/** Method being called whenever the label text changes. */
|
|
105
105
|
_onLabelTextChange(): void;
|
|
106
|
-
static ngAcceptInputType_required: BooleanInput;
|
|
107
|
-
static ngAcceptInputType_checked: BooleanInput;
|
|
108
|
-
static ngAcceptInputType_disabled: BooleanInput;
|
|
109
|
-
static ngAcceptInputType_disableRipple: BooleanInput;
|
|
110
|
-
static ngAcceptInputType_tabIndex: NumberInput;
|
|
111
106
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatSlideToggle, [null, null, null, { attribute: "tabindex"; }, null, { optional: true; }]>;
|
|
112
107
|
static ɵcmp: i0.ɵɵComponentDeclaration<MatSlideToggle, "mat-slide-toggle", ["matSlideToggle"], { "disabled": "disabled"; "disableRipple": "disableRipple"; "color": "color"; "tabIndex": "tabIndex"; "name": "name"; "id": "id"; "labelPosition": "labelPosition"; "ariaLabel": "aria-label"; "ariaLabelledby": "aria-labelledby"; "ariaDescribedby": "aria-describedby"; "required": "required"; "checked": "checked"; }, { "change": "change"; "toggleChange": "toggleChange"; }, never, ["*"]>;
|
|
113
108
|
}
|
|
@@ -52,16 +52,18 @@
|
|
|
52
52
|
background-color: $mat-slider-off-color;
|
|
53
53
|
}
|
|
54
54
|
|
|
55
|
-
.mat-
|
|
56
|
-
|
|
57
|
-
|
|
55
|
+
.mat-slider {
|
|
56
|
+
&.mat-primary {
|
|
57
|
+
@include _inner-content-theme($primary);
|
|
58
|
+
}
|
|
58
59
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
60
|
+
&.mat-accent {
|
|
61
|
+
@include _inner-content-theme($accent);
|
|
62
|
+
}
|
|
62
63
|
|
|
63
|
-
|
|
64
|
-
|
|
64
|
+
&.mat-warn {
|
|
65
|
+
@include _inner-content-theme($warn);
|
|
66
|
+
}
|
|
65
67
|
}
|
|
66
68
|
|
|
67
69
|
.mat-slider:hover,
|
|
@@ -71,7 +73,7 @@
|
|
|
71
73
|
}
|
|
72
74
|
}
|
|
73
75
|
|
|
74
|
-
.mat-slider-disabled {
|
|
76
|
+
.mat-slider.mat-slider-disabled {
|
|
75
77
|
.mat-slider-track-background,
|
|
76
78
|
.mat-slider-track-fill,
|
|
77
79
|
.mat-slider-thumb {
|
|
@@ -85,7 +87,7 @@
|
|
|
85
87
|
}
|
|
86
88
|
}
|
|
87
89
|
|
|
88
|
-
.mat-slider-min-value {
|
|
90
|
+
.mat-slider.mat-slider-min-value {
|
|
89
91
|
.mat-slider-focus-ring {
|
|
90
92
|
$opacity: 0.12;
|
|
91
93
|
$color: theming.get-color-from-palette($foreground, base, $opacity);
|
package/slider/slider.d.ts
CHANGED
|
@@ -43,34 +43,34 @@ export declare class MatSlider extends _MatSliderBase implements ControlValueAcc
|
|
|
43
43
|
_animationMode?: string | undefined;
|
|
44
44
|
/** Whether the slider is inverted. */
|
|
45
45
|
get invert(): boolean;
|
|
46
|
-
set invert(value:
|
|
46
|
+
set invert(value: BooleanInput);
|
|
47
47
|
private _invert;
|
|
48
48
|
/** The maximum value that the slider can have. */
|
|
49
49
|
get max(): number;
|
|
50
|
-
set max(v:
|
|
50
|
+
set max(v: NumberInput);
|
|
51
51
|
private _max;
|
|
52
52
|
/** The minimum value that the slider can have. */
|
|
53
53
|
get min(): number;
|
|
54
|
-
set min(v:
|
|
54
|
+
set min(v: NumberInput);
|
|
55
55
|
private _min;
|
|
56
56
|
/** The values at which the thumb will snap. */
|
|
57
57
|
get step(): number;
|
|
58
|
-
set step(v:
|
|
58
|
+
set step(v: NumberInput);
|
|
59
59
|
private _step;
|
|
60
60
|
/** Whether or not to show the thumb label. */
|
|
61
61
|
get thumbLabel(): boolean;
|
|
62
|
-
set thumbLabel(value:
|
|
62
|
+
set thumbLabel(value: BooleanInput);
|
|
63
63
|
private _thumbLabel;
|
|
64
64
|
/**
|
|
65
65
|
* How often to show ticks. Relative to the step so that a tick always appears on a step.
|
|
66
66
|
* Ex: Tick interval of 4 with a step of 3 will draw a tick every 4 steps (every 12 values).
|
|
67
67
|
*/
|
|
68
68
|
get tickInterval(): 'auto' | number;
|
|
69
|
-
set tickInterval(value: 'auto' |
|
|
69
|
+
set tickInterval(value: 'auto' | NumberInput);
|
|
70
70
|
private _tickInterval;
|
|
71
71
|
/** Value of the slider. */
|
|
72
72
|
get value(): number;
|
|
73
|
-
set value(v:
|
|
73
|
+
set value(v: NumberInput);
|
|
74
74
|
private _value;
|
|
75
75
|
/**
|
|
76
76
|
* Function that will be used to format the value before it is displayed
|
|
@@ -82,7 +82,7 @@ export declare class MatSlider extends _MatSliderBase implements ControlValueAcc
|
|
|
82
82
|
valueText: string;
|
|
83
83
|
/** Whether the slider is vertical. */
|
|
84
84
|
get vertical(): boolean;
|
|
85
|
-
set vertical(value:
|
|
85
|
+
set vertical(value: BooleanInput);
|
|
86
86
|
private _vertical;
|
|
87
87
|
/** Event emitted when the slider value has changed. */
|
|
88
88
|
readonly change: EventEmitter<MatSliderChange>;
|
|
@@ -261,16 +261,6 @@ export declare class MatSlider extends _MatSliderBase implements ControlValueAcc
|
|
|
261
261
|
* @param isDisabled
|
|
262
262
|
*/
|
|
263
263
|
setDisabledState(isDisabled: boolean): void;
|
|
264
|
-
static ngAcceptInputType_invert: BooleanInput;
|
|
265
|
-
static ngAcceptInputType_max: NumberInput;
|
|
266
|
-
static ngAcceptInputType_min: NumberInput;
|
|
267
|
-
static ngAcceptInputType_step: NumberInput;
|
|
268
|
-
static ngAcceptInputType_thumbLabel: BooleanInput;
|
|
269
|
-
static ngAcceptInputType_tickInterval: NumberInput;
|
|
270
|
-
static ngAcceptInputType_value: NumberInput;
|
|
271
|
-
static ngAcceptInputType_vertical: BooleanInput;
|
|
272
|
-
static ngAcceptInputType_disabled: BooleanInput;
|
|
273
|
-
static ngAcceptInputType_tabIndex: NumberInput;
|
|
274
264
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatSlider, [null, null, null, { optional: true; }, { attribute: "tabindex"; }, null, null, { optional: true; }]>;
|
|
275
265
|
static ɵcmp: i0.ɵɵComponentDeclaration<MatSlider, "mat-slider", ["matSlider"], { "disabled": "disabled"; "color": "color"; "tabIndex": "tabIndex"; "invert": "invert"; "max": "max"; "min": "min"; "step": "step"; "thumbLabel": "thumbLabel"; "tickInterval": "tickInterval"; "value": "value"; "displayWith": "displayWith"; "valueText": "valueText"; "vertical": "vertical"; }, { "change": "change"; "input": "input"; "valueChange": "valueChange"; }, never, never>;
|
|
276
266
|
}
|
package/snack-bar/snack-bar.d.ts
CHANGED
|
@@ -10,19 +10,16 @@ import { BreakpointObserver } from '@angular/cdk/layout';
|
|
|
10
10
|
import { Overlay } from '@angular/cdk/overlay';
|
|
11
11
|
import { ComponentType } from '@angular/cdk/portal';
|
|
12
12
|
import { EmbeddedViewRef, InjectionToken, Injector, TemplateRef, OnDestroy, Type } from '@angular/core';
|
|
13
|
-
import { TextOnlySnackBar } from './simple-snack-bar';
|
|
13
|
+
import { TextOnlySnackBar, SimpleSnackBar } from './simple-snack-bar';
|
|
14
14
|
import { MatSnackBarConfig } from './snack-bar-config';
|
|
15
|
-
import { _SnackBarContainer } from './snack-bar-container';
|
|
15
|
+
import { MatSnackBarContainer, _SnackBarContainer } from './snack-bar-container';
|
|
16
16
|
import { MatSnackBarRef } from './snack-bar-ref';
|
|
17
17
|
import * as i0 from "@angular/core";
|
|
18
18
|
/** Injection token that can be used to specify default snack bar. */
|
|
19
19
|
export declare const MAT_SNACK_BAR_DEFAULT_OPTIONS: InjectionToken<MatSnackBarConfig<any>>;
|
|
20
20
|
/** @docs-private */
|
|
21
21
|
export declare function MAT_SNACK_BAR_DEFAULT_OPTIONS_FACTORY(): MatSnackBarConfig;
|
|
22
|
-
|
|
23
|
-
* Service to dispatch Material Design snack bar messages.
|
|
24
|
-
*/
|
|
25
|
-
export declare class MatSnackBar implements OnDestroy {
|
|
22
|
+
export declare abstract class _MatSnackBarBase implements OnDestroy {
|
|
26
23
|
private _overlay;
|
|
27
24
|
private _live;
|
|
28
25
|
private _injector;
|
|
@@ -36,15 +33,15 @@ export declare class MatSnackBar implements OnDestroy {
|
|
|
36
33
|
*/
|
|
37
34
|
private _snackBarRefAtThisLevel;
|
|
38
35
|
/** The component that should be rendered as the snack bar's simple component. */
|
|
39
|
-
protected simpleSnackBarComponent: Type<TextOnlySnackBar>;
|
|
36
|
+
protected abstract simpleSnackBarComponent: Type<TextOnlySnackBar>;
|
|
40
37
|
/** The container component that attaches the provided template or component. */
|
|
41
|
-
protected snackBarContainerComponent: Type<_SnackBarContainer>;
|
|
38
|
+
protected abstract snackBarContainerComponent: Type<_SnackBarContainer>;
|
|
42
39
|
/** The CSS class to apply for handset mode. */
|
|
43
|
-
protected handsetCssClass: string;
|
|
40
|
+
protected abstract handsetCssClass: string;
|
|
44
41
|
/** Reference to the currently opened snackbar at *any* level. */
|
|
45
42
|
get _openedSnackBarRef(): MatSnackBarRef<any> | null;
|
|
46
43
|
set _openedSnackBarRef(value: MatSnackBarRef<any> | null);
|
|
47
|
-
constructor(_overlay: Overlay, _live: LiveAnnouncer, _injector: Injector, _breakpointObserver: BreakpointObserver, _parentSnackBar:
|
|
44
|
+
constructor(_overlay: Overlay, _live: LiveAnnouncer, _injector: Injector, _breakpointObserver: BreakpointObserver, _parentSnackBar: _MatSnackBarBase, _defaultConfig: MatSnackBarConfig);
|
|
48
45
|
/**
|
|
49
46
|
* Creates and dispatches a snack bar with a custom component for the content, removing any
|
|
50
47
|
* currently opened snack bars.
|
|
@@ -94,6 +91,17 @@ export declare class MatSnackBar implements OnDestroy {
|
|
|
94
91
|
* @param snackBarRef Reference to the snack bar.
|
|
95
92
|
*/
|
|
96
93
|
private _createInjector;
|
|
94
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<_MatSnackBarBase, [null, null, null, null, { optional: true; skipSelf: true; }, null]>;
|
|
95
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<_MatSnackBarBase>;
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Service to dispatch Material Design snack bar messages.
|
|
99
|
+
*/
|
|
100
|
+
export declare class MatSnackBar extends _MatSnackBarBase {
|
|
101
|
+
protected simpleSnackBarComponent: typeof SimpleSnackBar;
|
|
102
|
+
protected snackBarContainerComponent: typeof MatSnackBarContainer;
|
|
103
|
+
protected handsetCssClass: string;
|
|
104
|
+
constructor(overlay: Overlay, live: LiveAnnouncer, injector: Injector, breakpointObserver: BreakpointObserver, parentSnackBar: MatSnackBar, defaultConfig: MatSnackBarConfig);
|
|
97
105
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatSnackBar, [null, null, null, null, { optional: true; skipSelf: true; }, null]>;
|
|
98
106
|
static ɵprov: i0.ɵɵInjectableDeclaration<MatSnackBar>;
|
|
99
107
|
}
|
package/sort/sort-header.d.ts
CHANGED
|
@@ -102,7 +102,7 @@ export declare class MatSortHeader extends _MatSortHeaderBase implements CanDisa
|
|
|
102
102
|
private _sortActionDescription;
|
|
103
103
|
/** Overrides the disable clear value of the containing MatSort for this MatSortable. */
|
|
104
104
|
get disableClear(): boolean;
|
|
105
|
-
set disableClear(v:
|
|
105
|
+
set disableClear(v: BooleanInput);
|
|
106
106
|
private _disableClear;
|
|
107
107
|
constructor(
|
|
108
108
|
/**
|
|
@@ -160,8 +160,6 @@ export declare class MatSortHeader extends _MatSortHeaderBase implements CanDisa
|
|
|
160
160
|
private _updateSortActionDescription;
|
|
161
161
|
/** Handles changes in the sorting state. */
|
|
162
162
|
private _handleStateChanges;
|
|
163
|
-
static ngAcceptInputType_disableClear: BooleanInput;
|
|
164
|
-
static ngAcceptInputType_disabled: BooleanInput;
|
|
165
163
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatSortHeader, [null, null, { optional: true; }, { optional: true; }, null, null, { optional: true; }]>;
|
|
166
164
|
static ɵcmp: i0.ɵɵComponentDeclaration<MatSortHeader, "[mat-sort-header]", ["matSortHeader"], { "disabled": "disabled"; "id": "mat-sort-header"; "arrowPosition": "arrowPosition"; "start": "start"; "sortActionDescription": "sortActionDescription"; "disableClear": "disableClear"; }, {}, never, ["*"]>;
|
|
167
165
|
}
|
package/sort/sort.d.ts
CHANGED
|
@@ -61,7 +61,7 @@ export declare class MatSort extends _MatSortBase implements CanDisable, HasInit
|
|
|
61
61
|
* May be overriden by the MatSortable's disable clear input.
|
|
62
62
|
*/
|
|
63
63
|
get disableClear(): boolean;
|
|
64
|
-
set disableClear(v:
|
|
64
|
+
set disableClear(v: BooleanInput);
|
|
65
65
|
private _disableClear;
|
|
66
66
|
/** Event emitted when the user changes either the active sort or sort direction. */
|
|
67
67
|
readonly sortChange: EventEmitter<Sort>;
|
|
@@ -83,8 +83,6 @@ export declare class MatSort extends _MatSortBase implements CanDisable, HasInit
|
|
|
83
83
|
ngOnInit(): void;
|
|
84
84
|
ngOnChanges(): void;
|
|
85
85
|
ngOnDestroy(): void;
|
|
86
|
-
static ngAcceptInputType_disableClear: BooleanInput;
|
|
87
|
-
static ngAcceptInputType_disabled: BooleanInput;
|
|
88
86
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatSort, [{ optional: true; }]>;
|
|
89
87
|
static ɵdir: i0.ɵɵDirectiveDeclaration<MatSort, "[matSort]", ["matSort"], { "disabled": "matSortDisabled"; "active": "matSortActive"; "start": "matSortStart"; "direction": "matSortDirection"; "disableClear": "matSortDisableClear"; }, { "sortChange": "matSortChange"; }, never>;
|
|
90
88
|
}
|