@angular/material 14.0.0-rc.0 → 14.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bottom-sheet/index.d.ts +15 -82
- package/checkbox/index.d.ts +62 -31
- package/esm2020/autocomplete/autocomplete-module.mjs +5 -5
- package/esm2020/autocomplete/autocomplete-origin.mjs +7 -7
- package/esm2020/autocomplete/autocomplete-trigger.mjs +7 -7
- 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 +23 -175
- package/esm2020/bottom-sheet/bottom-sheet-module.mjs +7 -7
- package/esm2020/bottom-sheet/bottom-sheet-ref.mjs +34 -34
- package/esm2020/bottom-sheet/bottom-sheet.mjs +30 -89
- package/esm2020/button/button-module.mjs +5 -5
- package/esm2020/button/button.mjs +7 -7
- 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 +43 -43
- package/esm2020/checkbox/checkbox-module.mjs +9 -9
- package/esm2020/checkbox/checkbox-required-validator.mjs +4 -4
- package/esm2020/checkbox/checkbox.mjs +138 -121
- 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 +5 -5
- 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 +7 -7
- package/esm2020/core/option/option.mjs +7 -7
- package/esm2020/core/ripple/index.mjs +5 -5
- package/esm2020/core/ripple/ripple.mjs +4 -4
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox-module.mjs +5 -5
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +4 -4
- package/esm2020/core/version.mjs +1 -1
- package/esm2020/datepicker/calendar-body.mjs +4 -4
- 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 +23 -8
- 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 +4 -4
- 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 +4 -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 +7 -7
- package/esm2020/menu/menu-item.mjs +4 -4
- package/esm2020/menu/menu-module.mjs +5 -5
- package/esm2020/menu/menu-trigger.mjs +7 -7
- package/esm2020/menu/menu.mjs +7 -7
- package/esm2020/paginator/paginator-intl.mjs +4 -4
- package/esm2020/paginator/paginator-module.mjs +5 -5
- package/esm2020/paginator/paginator.mjs +7 -7
- package/esm2020/progress-bar/progress-bar-module.mjs +5 -5
- package/esm2020/progress-bar/progress-bar.mjs +4 -4
- package/esm2020/progress-spinner/progress-spinner-module.mjs +5 -5
- package/esm2020/progress-spinner/progress-spinner.mjs +4 -4
- package/esm2020/radio/radio-module.mjs +5 -5
- package/esm2020/radio/radio.mjs +13 -13
- package/esm2020/select/select-module.mjs +5 -5
- package/esm2020/select/select.mjs +10 -10
- package/esm2020/sidenav/drawer.mjs +10 -10
- package/esm2020/sidenav/sidenav-module.mjs +5 -5
- package/esm2020/sidenav/sidenav.mjs +10 -10
- 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 +89 -77
- package/esm2020/slider/slider-module.mjs +5 -5
- package/esm2020/slider/slider.mjs +4 -4
- package/esm2020/snack-bar/simple-snack-bar.mjs +4 -4
- 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 +7 -7
- 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 +4 -4
- 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 +7 -7
- package/esm2020/table/cell.mjs +22 -22
- package/esm2020/table/row.mjs +22 -22
- package/esm2020/table/table-module.mjs +5 -5
- package/esm2020/table/table.mjs +7 -7
- package/esm2020/table/text-column.mjs +4 -4
- package/esm2020/tabs/ink-bar.mjs +4 -4
- package/esm2020/tabs/paginated-tab-header.mjs +27 -7
- package/esm2020/tabs/tab-body.mjs +10 -10
- package/esm2020/tabs/tab-content.mjs +4 -4
- package/esm2020/tabs/tab-group.mjs +7 -7
- package/esm2020/tabs/tab-header.mjs +7 -7
- package/esm2020/tabs/tab-label-wrapper.mjs +4 -4
- package/esm2020/tabs/tab-label.mjs +4 -4
- package/esm2020/tabs/tab-nav-bar/tab-nav-bar.mjs +16 -16
- package/esm2020/tabs/tab.mjs +4 -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 +13 -13
- package/esm2020/tree/node.mjs +10 -10
- package/esm2020/tree/outlet.mjs +4 -4
- package/esm2020/tree/padding.mjs +4 -4
- package/esm2020/tree/toggle.mjs +4 -4
- package/esm2020/tree/tree-module.mjs +5 -5
- package/esm2020/tree/tree.mjs +4 -4
- package/fesm2015/autocomplete.mjs +22 -22
- 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 +125 -343
- 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 +10 -10
- package/fesm2015/button.mjs.map +1 -1
- package/fesm2015/card.mjs +46 -46
- package/fesm2015/card.mjs.map +1 -1
- package/fesm2015/checkbox.mjs +151 -134
- package/fesm2015/checkbox.mjs.map +1 -1
- package/fesm2015/chips.mjs +22 -22
- package/fesm2015/chips.mjs.map +1 -1
- package/fesm2015/core.mjs +59 -59
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/datepicker.mjs +97 -82
- 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 +28 -28
- 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 +7 -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 +25 -25
- package/fesm2015/menu.mjs.map +1 -1
- package/fesm2015/paginator.mjs +13 -13
- package/fesm2015/paginator.mjs.map +1 -1
- package/fesm2015/progress-bar.mjs +7 -7
- package/fesm2015/progress-bar.mjs.map +1 -1
- package/fesm2015/progress-spinner.mjs +7 -7
- 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 +13 -13
- package/fesm2015/select.mjs.map +1 -1
- package/fesm2015/sidenav.mjs +22 -22
- package/fesm2015/sidenav.mjs.map +1 -1
- package/fesm2015/slide-toggle.mjs +100 -88
- package/fesm2015/slide-toggle.mjs.map +1 -1
- package/fesm2015/slider.mjs +7 -7
- package/fesm2015/slider.mjs.map +1 -1
- package/fesm2015/snack-bar.mjs +16 -16
- 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 +31 -31
- package/fesm2015/stepper.mjs.map +1 -1
- package/fesm2015/table.mjs +55 -55
- package/fesm2015/table.mjs.map +1 -1
- package/fesm2015/tabs.mjs +81 -61
- package/fesm2015/tabs.mjs.map +1 -1
- package/fesm2015/toolbar.mjs +10 -10
- package/fesm2015/toolbar.mjs.map +1 -1
- package/fesm2015/tooltip.mjs +16 -16
- package/fesm2015/tooltip.mjs.map +1 -1
- package/fesm2015/tree.mjs +25 -25
- package/fesm2015/tree.mjs.map +1 -1
- package/fesm2020/autocomplete.mjs +22 -22
- 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 +132 -342
- 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 +10 -10
- package/fesm2020/button.mjs.map +1 -1
- package/fesm2020/card.mjs +46 -46
- package/fesm2020/card.mjs.map +1 -1
- package/fesm2020/checkbox.mjs +149 -132
- package/fesm2020/checkbox.mjs.map +1 -1
- package/fesm2020/chips.mjs +22 -22
- package/fesm2020/chips.mjs.map +1 -1
- package/fesm2020/core.mjs +59 -59
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/datepicker.mjs +97 -82
- 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 +28 -28
- 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 +7 -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 +25 -25
- package/fesm2020/menu.mjs.map +1 -1
- package/fesm2020/paginator.mjs +13 -13
- package/fesm2020/paginator.mjs.map +1 -1
- package/fesm2020/progress-bar.mjs +7 -7
- package/fesm2020/progress-bar.mjs.map +1 -1
- package/fesm2020/progress-spinner.mjs +7 -7
- 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 +13 -13
- package/fesm2020/select.mjs.map +1 -1
- package/fesm2020/sidenav.mjs +22 -22
- package/fesm2020/sidenav.mjs.map +1 -1
- package/fesm2020/slide-toggle.mjs +100 -88
- package/fesm2020/slide-toggle.mjs.map +1 -1
- package/fesm2020/slider.mjs +7 -7
- package/fesm2020/slider.mjs.map +1 -1
- package/fesm2020/snack-bar.mjs +16 -16
- 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 +31 -31
- package/fesm2020/stepper.mjs.map +1 -1
- package/fesm2020/table.mjs +55 -55
- package/fesm2020/table.mjs.map +1 -1
- package/fesm2020/tabs.mjs +81 -61
- package/fesm2020/tabs.mjs.map +1 -1
- package/fesm2020/toolbar.mjs +10 -10
- package/fesm2020/toolbar.mjs.map +1 -1
- package/fesm2020/tooltip.mjs +16 -16
- package/fesm2020/tooltip.mjs.map +1 -1
- package/fesm2020/tree.mjs +25 -25
- package/fesm2020/tree.mjs.map +1 -1
- package/package.json +7 -7
- package/schematics/ng-add/index.js +2 -2
- package/schematics/ng-add/index.mjs +2 -2
- package/schematics/ng-add/setup-project.js +59 -18
- package/schematics/ng-add/setup-project.mjs +59 -18
- package/schematics/ng-generate/address-form/schema.json +3 -0
- package/schematics/ng-generate/dashboard/schema.json +3 -0
- package/schematics/ng-generate/navigation/schema.json +3 -0
- package/schematics/ng-generate/table/schema.json +3 -0
- package/schematics/ng-generate/tree/schema.json +3 -0
- package/slide-toggle/index.d.ts +45 -32
- package/tabs/index.d.ts +2 -0
|
@@ -53,29 +53,70 @@ function addAnimationsModule(options) {
|
|
|
53
53
|
return async (host, context) => {
|
|
54
54
|
const workspace = await (0, workspace_1.getWorkspace)(host);
|
|
55
55
|
const project = (0, schematics_2.getProjectFromWorkspace)(workspace, options.project);
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
if ((0, schematics_2.hasNgModuleImport)(host, appModulePath, noopAnimationsModuleName)) {
|
|
63
|
-
context.logger.error(`Could not set up "${browserAnimationsModuleName}" ` +
|
|
64
|
-
`because "${noopAnimationsModuleName}" is already imported.`);
|
|
65
|
-
context.logger.info(`Please manually set up browser animations.`);
|
|
56
|
+
try {
|
|
57
|
+
addAnimationsModuleToNonStandaloneApp(host, project, context, options);
|
|
58
|
+
}
|
|
59
|
+
catch (e) {
|
|
60
|
+
if (e instanceof schematics_1.SchematicsException && e.message.includes('Bootstrap call not found')) {
|
|
61
|
+
addAnimationsModuleToStandaloneApp(host, project, context, options);
|
|
66
62
|
}
|
|
67
63
|
else {
|
|
68
|
-
|
|
64
|
+
throw e;
|
|
69
65
|
}
|
|
70
66
|
}
|
|
71
|
-
else if (options.animations === 'disabled' &&
|
|
72
|
-
!(0, schematics_2.hasNgModuleImport)(host, appModulePath, browserAnimationsModuleName)) {
|
|
73
|
-
// Do not add the NoopAnimationsModule module if the project already explicitly uses
|
|
74
|
-
// the BrowserAnimationsModule.
|
|
75
|
-
(0, schematics_2.addModuleImportToRootModule)(host, noopAnimationsModuleName, '@angular/platform-browser/animations', project);
|
|
76
|
-
}
|
|
77
67
|
};
|
|
78
68
|
}
|
|
69
|
+
/** Adds the animations module to an app that is bootstrap using the standalone component APIs. */
|
|
70
|
+
function addAnimationsModuleToStandaloneApp(host, project, context, options) {
|
|
71
|
+
const mainFile = (0, schematics_2.getProjectMainFile)(project);
|
|
72
|
+
if (options.animations === 'enabled') {
|
|
73
|
+
// In case the project explicitly uses the NoopAnimationsModule, we should print a warning
|
|
74
|
+
// message that makes the user aware of the fact that we won't automatically set up
|
|
75
|
+
// animations. If we would add the BrowserAnimationsModule while the NoopAnimationsModule
|
|
76
|
+
// is already configured, we would cause unexpected behavior and runtime exceptions.
|
|
77
|
+
if ((0, schematics_2.importsProvidersFrom)(host, mainFile, noopAnimationsModuleName)) {
|
|
78
|
+
context.logger.error(`Could not set up "${browserAnimationsModuleName}" ` +
|
|
79
|
+
`because "${noopAnimationsModuleName}" is already imported.`);
|
|
80
|
+
context.logger.info(`Please manually set up browser animations.`);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
(0, schematics_2.addModuleImportToStandaloneBootstrap)(host, mainFile, browserAnimationsModuleName, '@angular/platform-browser/animations');
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
else if (options.animations === 'disabled' &&
|
|
87
|
+
!(0, schematics_2.importsProvidersFrom)(host, mainFile, browserAnimationsModuleName)) {
|
|
88
|
+
// Do not add the NoopAnimationsModule module if the project already explicitly uses
|
|
89
|
+
// the BrowserAnimationsModule.
|
|
90
|
+
(0, schematics_2.addModuleImportToStandaloneBootstrap)(host, mainFile, noopAnimationsModuleName, '@angular/platform-browser/animations');
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Adds the animations module to an app that is bootstrap
|
|
95
|
+
* using the non-standalone component APIs.
|
|
96
|
+
*/
|
|
97
|
+
function addAnimationsModuleToNonStandaloneApp(host, project, context, options) {
|
|
98
|
+
const appModulePath = (0, schematics_2.getAppModulePath)(host, (0, schematics_2.getProjectMainFile)(project));
|
|
99
|
+
if (options.animations === 'enabled') {
|
|
100
|
+
// In case the project explicitly uses the NoopAnimationsModule, we should print a warning
|
|
101
|
+
// message that makes the user aware of the fact that we won't automatically set up
|
|
102
|
+
// animations. If we would add the BrowserAnimationsModule while the NoopAnimationsModule
|
|
103
|
+
// is already configured, we would cause unexpected behavior and runtime exceptions.
|
|
104
|
+
if ((0, schematics_2.hasNgModuleImport)(host, appModulePath, noopAnimationsModuleName)) {
|
|
105
|
+
context.logger.error(`Could not set up "${browserAnimationsModuleName}" ` +
|
|
106
|
+
`because "${noopAnimationsModuleName}" is already imported.`);
|
|
107
|
+
context.logger.info(`Please manually set up browser animations.`);
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
(0, schematics_2.addModuleImportToRootModule)(host, browserAnimationsModuleName, '@angular/platform-browser/animations', project);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
else if (options.animations === 'disabled' &&
|
|
114
|
+
!(0, schematics_2.hasNgModuleImport)(host, appModulePath, browserAnimationsModuleName)) {
|
|
115
|
+
// Do not add the NoopAnimationsModule module if the project already explicitly uses
|
|
116
|
+
// the BrowserAnimationsModule.
|
|
117
|
+
(0, schematics_2.addModuleImportToRootModule)(host, noopAnimationsModuleName, '@angular/platform-browser/animations', project);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
79
120
|
/**
|
|
80
121
|
* Adds custom Material styles to the project style file. The custom CSS sets up the Roboto font
|
|
81
122
|
* and reset the default browser body margin.
|
|
@@ -110,4 +151,4 @@ function addMaterialAppStyles(options) {
|
|
|
110
151
|
host.commitUpdate(recorder);
|
|
111
152
|
};
|
|
112
153
|
}
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"setup-project.js","sourceRoot":"","sources":["../../../../../../../src/material/schematics/ng-add/setup-project.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 {chain, Rule, SchematicContext, Tree} from '@angular-devkit/schematics';\nimport {\n  addModuleImportToRootModule,\n  getAppModulePath,\n  getProjectFromWorkspace,\n  getProjectMainFile,\n  getProjectStyleFile,\n  hasNgModuleImport,\n} from '@angular/cdk/schematics';\nimport {getWorkspace} from '@schematics/angular/utility/workspace';\nimport {ProjectType} from '@schematics/angular/utility/workspace-models';\nimport {addFontsToIndex} from './fonts/material-fonts';\nimport {Schema} from './schema';\nimport {addThemeToAppStyles, addTypographyClass} from './theming/theming';\n\n/** Name of the Angular module that enables Angular browser animations. */\nconst browserAnimationsModuleName = 'BrowserAnimationsModule';\n\n/** Name of the module that switches Angular animations to a noop implementation. */\nconst noopAnimationsModuleName = 'NoopAnimationsModule';\n\n/**\n * Scaffolds the basics of a Angular Material application, this includes:\n *  - Add Packages to package.json\n *  - Adds pre-built themes to styles.ext\n *  - Adds Browser Animation to app.module\n */\nexport default function (options: Schema): Rule {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n    const project = getProjectFromWorkspace(workspace, options.project);\n\n    if (project.extensions.projectType === ProjectType.Application) {\n      return chain([\n        addAnimationsModule(options),\n        addThemeToAppStyles(options),\n        addFontsToIndex(options),\n        addMaterialAppStyles(options),\n        addTypographyClass(options),\n      ]);\n    }\n    context.logger.warn(\n      'Angular Material has been set up in your workspace. There is no additional setup ' +\n        'required for consuming Angular Material in your library project.\\n\\n' +\n        'If you intended to run the schematic on a different project, pass the `--project` ' +\n        'option.',\n    );\n    return;\n  };\n}\n\n/**\n * Adds an animation module to the root module of the specified project. In case the \"animations\"\n * option is set to false, we still add the `NoopAnimationsModule` because otherwise various\n * components of Angular Material will throw an exception.\n */\nfunction addAnimationsModule(options: Schema) {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n    const project = getProjectFromWorkspace(workspace, options.project);\n    const appModulePath = getAppModulePath(host, getProjectMainFile(project));\n\n    if (options.animations === 'enabled') {\n      // In case the project explicitly uses the NoopAnimationsModule, we should print a warning\n      // message that makes the user aware of the fact that we won't automatically set up\n      // animations. If we would add the BrowserAnimationsModule while the NoopAnimationsModule\n      // is already configured, we would cause unexpected behavior and runtime exceptions.\n      if (hasNgModuleImport(host, appModulePath, noopAnimationsModuleName)) {\n        context.logger.error(\n          `Could not set up \"${browserAnimationsModuleName}\" ` +\n            `because \"${noopAnimationsModuleName}\" is already imported.`,\n        );\n        context.logger.info(`Please manually set up browser animations.`);\n      } else {\n        addModuleImportToRootModule(\n          host,\n          browserAnimationsModuleName,\n          '@angular/platform-browser/animations',\n          project,\n        );\n      }\n    } else if (\n      options.animations === 'disabled' &&\n      !hasNgModuleImport(host, appModulePath, browserAnimationsModuleName)\n    ) {\n      // Do not add the NoopAnimationsModule module if the project already explicitly uses\n      // the BrowserAnimationsModule.\n      addModuleImportToRootModule(\n        host,\n        noopAnimationsModuleName,\n        '@angular/platform-browser/animations',\n        project,\n      );\n    }\n  };\n}\n\n/**\n * Adds custom Material styles to the project style file. The custom CSS sets up the Roboto font\n * and reset the default browser body margin.\n */\nfunction addMaterialAppStyles(options: Schema) {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n    const project = getProjectFromWorkspace(workspace, options.project);\n    const styleFilePath = getProjectStyleFile(project);\n    const logger = context.logger;\n\n    if (!styleFilePath) {\n      logger.error(`Could not find the default style file for this project.`);\n      logger.info(`Consider manually adding the Roboto font to your CSS.`);\n      logger.info(`More information at https://fonts.google.com/specimen/Roboto`);\n      return;\n    }\n\n    const buffer = host.read(styleFilePath);\n\n    if (!buffer) {\n      logger.error(\n        `Could not read the default style file within the project ` + `(${styleFilePath})`,\n      );\n      logger.info(`Please consider manually setting up the Roboto font.`);\n      return;\n    }\n\n    const htmlContent = buffer.toString();\n    const insertion =\n      '\\n' +\n      `html, body { height: 100%; }\\n` +\n      `body { margin: 0; font-family: Roboto, \"Helvetica Neue\", sans-serif; }\\n`;\n\n    if (htmlContent.includes(insertion)) {\n      return;\n    }\n\n    const recorder = host.beginUpdate(styleFilePath);\n\n    recorder.insertLeft(htmlContent.length, insertion);\n    host.commitUpdate(recorder);\n  };\n}\n"]}
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"setup-project.js","sourceRoot":"","sources":["../../../../../../../src/material/schematics/ng-add/setup-project.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 {chain, Rule, SchematicContext, SchematicsException, Tree} from '@angular-devkit/schematics';\nimport {\n  addModuleImportToRootModule,\n  getAppModulePath,\n  getProjectFromWorkspace,\n  getProjectMainFile,\n  getProjectStyleFile,\n  hasNgModuleImport,\n  importsProvidersFrom,\n  addModuleImportToStandaloneBootstrap,\n} from '@angular/cdk/schematics';\nimport {getWorkspace, ProjectDefinition} from '@schematics/angular/utility/workspace';\nimport {ProjectType} from '@schematics/angular/utility/workspace-models';\nimport {addFontsToIndex} from './fonts/material-fonts';\nimport {Schema} from './schema';\nimport {addThemeToAppStyles, addTypographyClass} from './theming/theming';\n\n/** Name of the Angular module that enables Angular browser animations. */\nconst browserAnimationsModuleName = 'BrowserAnimationsModule';\n\n/** Name of the module that switches Angular animations to a noop implementation. */\nconst noopAnimationsModuleName = 'NoopAnimationsModule';\n\n/**\n * Scaffolds the basics of a Angular Material application, this includes:\n *  - Add Packages to package.json\n *  - Adds pre-built themes to styles.ext\n *  - Adds Browser Animation to app.module\n */\nexport default function (options: Schema): Rule {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n    const project = getProjectFromWorkspace(workspace, options.project);\n\n    if (project.extensions.projectType === ProjectType.Application) {\n      return chain([\n        addAnimationsModule(options),\n        addThemeToAppStyles(options),\n        addFontsToIndex(options),\n        addMaterialAppStyles(options),\n        addTypographyClass(options),\n      ]);\n    }\n    context.logger.warn(\n      'Angular Material has been set up in your workspace. There is no additional setup ' +\n        'required for consuming Angular Material in your library project.\\n\\n' +\n        'If you intended to run the schematic on a different project, pass the `--project` ' +\n        'option.',\n    );\n    return;\n  };\n}\n\n/**\n * Adds an animation module to the root module of the specified project. In case the \"animations\"\n * option is set to false, we still add the `NoopAnimationsModule` because otherwise various\n * components of Angular Material will throw an exception.\n */\nfunction addAnimationsModule(options: Schema) {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n    const project = getProjectFromWorkspace(workspace, options.project);\n\n    try {\n      addAnimationsModuleToNonStandaloneApp(host, project, context, options);\n    } catch (e) {\n      if (e instanceof SchematicsException && e.message.includes('Bootstrap call not found')) {\n        addAnimationsModuleToStandaloneApp(host, project, context, options);\n      } else {\n        throw e;\n      }\n    }\n  };\n}\n\n/** Adds the animations module to an app that is bootstrap using the standalone component APIs. */\nfunction addAnimationsModuleToStandaloneApp(\n  host: Tree,\n  project: ProjectDefinition,\n  context: SchematicContext,\n  options: Schema,\n) {\n  const mainFile = getProjectMainFile(project);\n\n  if (options.animations === 'enabled') {\n    // In case the project explicitly uses the NoopAnimationsModule, we should print a warning\n    // message that makes the user aware of the fact that we won't automatically set up\n    // animations. If we would add the BrowserAnimationsModule while the NoopAnimationsModule\n    // is already configured, we would cause unexpected behavior and runtime exceptions.\n    if (importsProvidersFrom(host, mainFile, noopAnimationsModuleName)) {\n      context.logger.error(\n        `Could not set up \"${browserAnimationsModuleName}\" ` +\n          `because \"${noopAnimationsModuleName}\" is already imported.`,\n      );\n      context.logger.info(`Please manually set up browser animations.`);\n    } else {\n      addModuleImportToStandaloneBootstrap(\n        host,\n        mainFile,\n        browserAnimationsModuleName,\n        '@angular/platform-browser/animations',\n      );\n    }\n  } else if (\n    options.animations === 'disabled' &&\n    !importsProvidersFrom(host, mainFile, browserAnimationsModuleName)\n  ) {\n    // Do not add the NoopAnimationsModule module if the project already explicitly uses\n    // the BrowserAnimationsModule.\n    addModuleImportToStandaloneBootstrap(\n      host,\n      mainFile,\n      noopAnimationsModuleName,\n      '@angular/platform-browser/animations',\n    );\n  }\n}\n\n/**\n * Adds the animations module to an app that is bootstrap\n * using the non-standalone component APIs.\n */\nfunction addAnimationsModuleToNonStandaloneApp(\n  host: Tree,\n  project: ProjectDefinition,\n  context: SchematicContext,\n  options: Schema,\n) {\n  const appModulePath = getAppModulePath(host, getProjectMainFile(project));\n\n  if (options.animations === 'enabled') {\n    // In case the project explicitly uses the NoopAnimationsModule, we should print a warning\n    // message that makes the user aware of the fact that we won't automatically set up\n    // animations. If we would add the BrowserAnimationsModule while the NoopAnimationsModule\n    // is already configured, we would cause unexpected behavior and runtime exceptions.\n    if (hasNgModuleImport(host, appModulePath, noopAnimationsModuleName)) {\n      context.logger.error(\n        `Could not set up \"${browserAnimationsModuleName}\" ` +\n          `because \"${noopAnimationsModuleName}\" is already imported.`,\n      );\n      context.logger.info(`Please manually set up browser animations.`);\n    } else {\n      addModuleImportToRootModule(\n        host,\n        browserAnimationsModuleName,\n        '@angular/platform-browser/animations',\n        project,\n      );\n    }\n  } else if (\n    options.animations === 'disabled' &&\n    !hasNgModuleImport(host, appModulePath, browserAnimationsModuleName)\n  ) {\n    // Do not add the NoopAnimationsModule module if the project already explicitly uses\n    // the BrowserAnimationsModule.\n    addModuleImportToRootModule(\n      host,\n      noopAnimationsModuleName,\n      '@angular/platform-browser/animations',\n      project,\n    );\n  }\n}\n\n/**\n * Adds custom Material styles to the project style file. The custom CSS sets up the Roboto font\n * and reset the default browser body margin.\n */\nfunction addMaterialAppStyles(options: Schema) {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n    const project = getProjectFromWorkspace(workspace, options.project);\n    const styleFilePath = getProjectStyleFile(project);\n    const logger = context.logger;\n\n    if (!styleFilePath) {\n      logger.error(`Could not find the default style file for this project.`);\n      logger.info(`Consider manually adding the Roboto font to your CSS.`);\n      logger.info(`More information at https://fonts.google.com/specimen/Roboto`);\n      return;\n    }\n\n    const buffer = host.read(styleFilePath);\n\n    if (!buffer) {\n      logger.error(\n        `Could not read the default style file within the project ` + `(${styleFilePath})`,\n      );\n      logger.info(`Please consider manually setting up the Roboto font.`);\n      return;\n    }\n\n    const htmlContent = buffer.toString();\n    const insertion =\n      '\\n' +\n      `html, body { height: 100%; }\\n` +\n      `body { margin: 0; font-family: Roboto, \"Helvetica Neue\", sans-serif; }\\n`;\n\n    if (htmlContent.includes(insertion)) {\n      return;\n    }\n\n    const recorder = host.beginUpdate(styleFilePath);\n\n    recorder.insertLeft(htmlContent.length, insertion);\n    host.commitUpdate(recorder);\n  };\n}\n"]}
|
package/slide-toggle/index.d.ts
CHANGED
|
@@ -20,6 +20,7 @@ import { InjectionToken } from '@angular/core';
|
|
|
20
20
|
import { OnDestroy } from '@angular/core';
|
|
21
21
|
import { Provider } from '@angular/core';
|
|
22
22
|
import { ThemePalette } from '@angular/material/core';
|
|
23
|
+
import { Type } from '@angular/core';
|
|
23
24
|
|
|
24
25
|
declare namespace i1 {
|
|
25
26
|
export {
|
|
@@ -32,6 +33,7 @@ declare namespace i2 {
|
|
|
32
33
|
export {
|
|
33
34
|
MAT_SLIDE_TOGGLE_VALUE_ACCESSOR,
|
|
34
35
|
MatSlideToggleChange,
|
|
36
|
+
_MatSlideToggleBase,
|
|
35
37
|
MatSlideToggle
|
|
36
38
|
}
|
|
37
39
|
}
|
|
@@ -42,24 +44,45 @@ export declare const MAT_SLIDE_TOGGLE_DEFAULT_OPTIONS: InjectionToken<MatSlideTo
|
|
|
42
44
|
export declare const MAT_SLIDE_TOGGLE_REQUIRED_VALIDATOR: Provider;
|
|
43
45
|
|
|
44
46
|
/** @docs-private */
|
|
45
|
-
export declare const MAT_SLIDE_TOGGLE_VALUE_ACCESSOR:
|
|
47
|
+
export declare const MAT_SLIDE_TOGGLE_VALUE_ACCESSOR: {
|
|
48
|
+
provide: InjectionToken<readonly ControlValueAccessor[]>;
|
|
49
|
+
useExisting: Type<any>;
|
|
50
|
+
multi: boolean;
|
|
51
|
+
};
|
|
46
52
|
|
|
47
53
|
/** Represents a slidable "switch" toggle that can be moved between on and off. */
|
|
48
|
-
export declare class MatSlideToggle extends _MatSlideToggleBase
|
|
49
|
-
|
|
50
|
-
|
|
54
|
+
export declare class MatSlideToggle extends _MatSlideToggleBase<MatSlideToggleChange> {
|
|
55
|
+
/** Reference to the underlying input element. */
|
|
56
|
+
_inputElement: ElementRef<HTMLInputElement>;
|
|
57
|
+
constructor(elementRef: ElementRef, focusMonitor: FocusMonitor, changeDetectorRef: ChangeDetectorRef, tabIndex: string, defaults: MatSlideToggleDefaultOptions, animationMode?: string);
|
|
58
|
+
protected _createChangeEvent(isChecked: boolean): MatSlideToggleChange;
|
|
59
|
+
/** Method being called whenever the underlying input emits a change event. */
|
|
60
|
+
_onChangeEvent(event: Event): void;
|
|
61
|
+
/** Method being called whenever the slide-toggle has been clicked. */
|
|
62
|
+
_onInputClick(event: Event): void;
|
|
63
|
+
/** Focuses the slide-toggle. */
|
|
64
|
+
focus(options?: FocusOptions, origin?: FocusOrigin): void;
|
|
65
|
+
/** Method being called whenever the label text changes. */
|
|
66
|
+
_onLabelTextChange(): void;
|
|
67
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<MatSlideToggle, [null, null, null, { attribute: "tabindex"; }, null, { optional: true; }]>;
|
|
68
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MatSlideToggle, "mat-slide-toggle", ["matSlideToggle"], { "disabled": "disabled"; "disableRipple": "disableRipple"; "color": "color"; "tabIndex": "tabIndex"; }, {}, never, ["*"], false>;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export declare abstract class _MatSlideToggleBase<T> extends _MatSlideToggleMixinBase implements OnDestroy, AfterContentInit, ControlValueAccessor, CanDisable, CanColor, HasTabIndex, CanDisableRipple {
|
|
72
|
+
protected _focusMonitor: FocusMonitor;
|
|
73
|
+
protected _changeDetectorRef: ChangeDetectorRef;
|
|
51
74
|
defaults: MatSlideToggleDefaultOptions;
|
|
52
|
-
|
|
75
|
+
protected _onChange: (_: any) => void;
|
|
53
76
|
private _onTouched;
|
|
54
|
-
|
|
77
|
+
protected _uniqueId: string;
|
|
55
78
|
private _required;
|
|
56
79
|
private _checked;
|
|
80
|
+
protected abstract _createChangeEvent(isChecked: boolean): T;
|
|
81
|
+
abstract focus(options?: FocusOptions, origin?: FocusOrigin): void;
|
|
57
82
|
/** Whether noop animations are enabled. */
|
|
58
83
|
_noopAnimations: boolean;
|
|
59
|
-
/**
|
|
60
|
-
|
|
61
|
-
/** Reference to the thumb bar HTMLElement. */
|
|
62
|
-
_thumbBarEl: ElementRef;
|
|
84
|
+
/** Whether the slide toggle is currently focused. */
|
|
85
|
+
_focused: boolean;
|
|
63
86
|
/** Name value will be applied to the input element if present. */
|
|
64
87
|
name: string | null;
|
|
65
88
|
/** A unique id for the slide-toggle input. If none is supplied, it will be auto-generated. */
|
|
@@ -79,7 +102,7 @@ export declare class MatSlideToggle extends _MatSlideToggleBase implements OnDes
|
|
|
79
102
|
get checked(): boolean;
|
|
80
103
|
set checked(value: BooleanInput);
|
|
81
104
|
/** An event will be dispatched each time the slide-toggle changes its value. */
|
|
82
|
-
readonly change: EventEmitter<
|
|
105
|
+
readonly change: EventEmitter<T>;
|
|
83
106
|
/**
|
|
84
107
|
* An event will be dispatched each time the slide-toggle input is toggled.
|
|
85
108
|
* This event is always emitted when the user toggles the slide toggle, but this does not mean
|
|
@@ -88,15 +111,9 @@ export declare class MatSlideToggle extends _MatSlideToggleBase implements OnDes
|
|
|
88
111
|
readonly toggleChange: EventEmitter<void>;
|
|
89
112
|
/** Returns the unique id for the visual hidden input. */
|
|
90
113
|
get inputId(): string;
|
|
91
|
-
|
|
92
|
-
_inputElement: ElementRef<HTMLInputElement>;
|
|
93
|
-
constructor(elementRef: ElementRef, _focusMonitor: FocusMonitor, _changeDetectorRef: ChangeDetectorRef, tabIndex: string, defaults: MatSlideToggleDefaultOptions, animationMode?: string);
|
|
114
|
+
constructor(elementRef: ElementRef, _focusMonitor: FocusMonitor, _changeDetectorRef: ChangeDetectorRef, tabIndex: string, defaults: MatSlideToggleDefaultOptions, animationMode: string | undefined, idPrefix: string);
|
|
94
115
|
ngAfterContentInit(): void;
|
|
95
116
|
ngOnDestroy(): void;
|
|
96
|
-
/** Method being called whenever the underlying input emits a change event. */
|
|
97
|
-
_onChangeEvent(event: Event): void;
|
|
98
|
-
/** Method being called whenever the slide-toggle has been clicked. */
|
|
99
|
-
_onInputClick(event: Event): void;
|
|
100
117
|
/** Implemented as part of ControlValueAccessor. */
|
|
101
118
|
writeValue(value: any): void;
|
|
102
119
|
/** Implemented as part of ControlValueAccessor. */
|
|
@@ -105,27 +122,16 @@ export declare class MatSlideToggle extends _MatSlideToggleBase implements OnDes
|
|
|
105
122
|
registerOnTouched(fn: any): void;
|
|
106
123
|
/** Implemented as a part of ControlValueAccessor. */
|
|
107
124
|
setDisabledState(isDisabled: boolean): void;
|
|
108
|
-
/** Focuses the slide-toggle. */
|
|
109
|
-
focus(options?: FocusOptions, origin?: FocusOrigin): void;
|
|
110
125
|
/** Toggles the checked state of the slide-toggle. */
|
|
111
126
|
toggle(): void;
|
|
112
127
|
/**
|
|
113
128
|
* Emits a change event on the `change` output. Also notifies the FormControl about the change.
|
|
114
129
|
*/
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<MatSlideToggle, [null, null, null, { attribute: "tabindex"; }, null, { optional: true; }]>;
|
|
119
|
-
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, ["*"], false>;
|
|
130
|
+
protected _emitChangeEvent(): void;
|
|
131
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<_MatSlideToggleBase<any>, never>;
|
|
132
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<_MatSlideToggleBase<any>, never, never, { "name": "name"; "id": "id"; "labelPosition": "labelPosition"; "ariaLabel": "aria-label"; "ariaLabelledby": "aria-labelledby"; "ariaDescribedby": "aria-describedby"; "required": "required"; "checked": "checked"; }, { "change": "change"; "toggleChange": "toggleChange"; }, never, never, false>;
|
|
120
133
|
}
|
|
121
134
|
|
|
122
|
-
/** @docs-private */
|
|
123
|
-
declare const _MatSlideToggleBase: _Constructor<HasTabIndex> & _AbstractConstructor<HasTabIndex> & _Constructor<CanColor> & _AbstractConstructor<CanColor> & _Constructor<CanDisableRipple> & _AbstractConstructor<CanDisableRipple> & _Constructor<CanDisable> & _AbstractConstructor<CanDisable> & {
|
|
124
|
-
new (_elementRef: ElementRef): {
|
|
125
|
-
_elementRef: ElementRef;
|
|
126
|
-
};
|
|
127
|
-
};
|
|
128
|
-
|
|
129
135
|
/** Change event object emitted by a MatSlideToggle. */
|
|
130
136
|
export declare class MatSlideToggleChange {
|
|
131
137
|
/** The source MatSlideToggle of the event. */
|
|
@@ -147,6 +153,13 @@ export declare interface MatSlideToggleDefaultOptions {
|
|
|
147
153
|
color?: ThemePalette;
|
|
148
154
|
}
|
|
149
155
|
|
|
156
|
+
/** @docs-private */
|
|
157
|
+
declare const _MatSlideToggleMixinBase: _Constructor<HasTabIndex> & _AbstractConstructor<HasTabIndex> & _Constructor<CanColor> & _AbstractConstructor<CanColor> & _Constructor<CanDisableRipple> & _AbstractConstructor<CanDisableRipple> & _Constructor<CanDisable> & _AbstractConstructor<CanDisable> & {
|
|
158
|
+
new (_elementRef: ElementRef): {
|
|
159
|
+
_elementRef: ElementRef;
|
|
160
|
+
};
|
|
161
|
+
};
|
|
162
|
+
|
|
150
163
|
export declare class MatSlideToggleModule {
|
|
151
164
|
static ɵfac: i0.ɵɵFactoryDeclaration<MatSlideToggleModule, never>;
|
|
152
165
|
static ɵmod: i0.ɵɵNgModuleDeclaration<MatSlideToggleModule, [typeof i2.MatSlideToggle], [typeof _MatSlideToggleRequiredValidatorModule, typeof i3.MatRippleModule, typeof i3.MatCommonModule, typeof i4.ObserversModule], [typeof _MatSlideToggleRequiredValidatorModule, typeof i2.MatSlideToggle, typeof i3.MatCommonModule]>;
|
package/tabs/index.d.ts
CHANGED
|
@@ -259,6 +259,8 @@ declare abstract class MatPaginatedTabHeader implements AfterContentChecked, Aft
|
|
|
259
259
|
protected abstract _itemSelected(event: KeyboardEvent): void;
|
|
260
260
|
ngAfterViewInit(): void;
|
|
261
261
|
ngAfterContentInit(): void;
|
|
262
|
+
/** Sends any changes that could affect the layout of the items. */
|
|
263
|
+
private _itemsResized;
|
|
262
264
|
ngAfterContentChecked(): void;
|
|
263
265
|
ngOnDestroy(): void;
|
|
264
266
|
/** Handles keyboard events on the header. */
|