@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.
Files changed (310) hide show
  1. package/bottom-sheet/index.d.ts +15 -82
  2. package/checkbox/index.d.ts +62 -31
  3. package/esm2020/autocomplete/autocomplete-module.mjs +5 -5
  4. package/esm2020/autocomplete/autocomplete-origin.mjs +7 -7
  5. package/esm2020/autocomplete/autocomplete-trigger.mjs +7 -7
  6. package/esm2020/autocomplete/autocomplete.mjs +7 -7
  7. package/esm2020/badge/badge-module.mjs +5 -5
  8. package/esm2020/badge/badge.mjs +4 -4
  9. package/esm2020/bottom-sheet/bottom-sheet-container.mjs +23 -175
  10. package/esm2020/bottom-sheet/bottom-sheet-module.mjs +7 -7
  11. package/esm2020/bottom-sheet/bottom-sheet-ref.mjs +34 -34
  12. package/esm2020/bottom-sheet/bottom-sheet.mjs +30 -89
  13. package/esm2020/button/button-module.mjs +5 -5
  14. package/esm2020/button/button.mjs +7 -7
  15. package/esm2020/button-toggle/button-toggle-module.mjs +5 -5
  16. package/esm2020/button-toggle/button-toggle.mjs +7 -7
  17. package/esm2020/card/card-module.mjs +5 -5
  18. package/esm2020/card/card.mjs +43 -43
  19. package/esm2020/checkbox/checkbox-module.mjs +9 -9
  20. package/esm2020/checkbox/checkbox-required-validator.mjs +4 -4
  21. package/esm2020/checkbox/checkbox.mjs +138 -121
  22. package/esm2020/chips/chip-input.mjs +4 -4
  23. package/esm2020/chips/chip-list.mjs +4 -4
  24. package/esm2020/chips/chip.mjs +13 -13
  25. package/esm2020/chips/chips-module.mjs +5 -5
  26. package/esm2020/core/common-behaviors/common-module.mjs +5 -5
  27. package/esm2020/core/datetime/index.mjs +9 -9
  28. package/esm2020/core/datetime/native-date-adapter.mjs +4 -4
  29. package/esm2020/core/error/error-options.mjs +7 -7
  30. package/esm2020/core/line/line.mjs +8 -8
  31. package/esm2020/core/option/index.mjs +5 -5
  32. package/esm2020/core/option/optgroup.mjs +7 -7
  33. package/esm2020/core/option/option.mjs +7 -7
  34. package/esm2020/core/ripple/index.mjs +5 -5
  35. package/esm2020/core/ripple/ripple.mjs +4 -4
  36. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox-module.mjs +5 -5
  37. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +4 -4
  38. package/esm2020/core/version.mjs +1 -1
  39. package/esm2020/datepicker/calendar-body.mjs +4 -4
  40. package/esm2020/datepicker/calendar.mjs +7 -7
  41. package/esm2020/datepicker/date-range-input-parts.mjs +10 -10
  42. package/esm2020/datepicker/date-range-input.mjs +4 -4
  43. package/esm2020/datepicker/date-range-picker.mjs +4 -4
  44. package/esm2020/datepicker/date-range-selection-strategy.mjs +4 -4
  45. package/esm2020/datepicker/date-selection-model.mjs +10 -10
  46. package/esm2020/datepicker/datepicker-actions.mjs +10 -10
  47. package/esm2020/datepicker/datepicker-base.mjs +23 -8
  48. package/esm2020/datepicker/datepicker-input-base.mjs +4 -4
  49. package/esm2020/datepicker/datepicker-input.mjs +4 -4
  50. package/esm2020/datepicker/datepicker-intl.mjs +4 -4
  51. package/esm2020/datepicker/datepicker-module.mjs +5 -5
  52. package/esm2020/datepicker/datepicker-toggle.mjs +7 -7
  53. package/esm2020/datepicker/datepicker.mjs +4 -4
  54. package/esm2020/datepicker/month-view.mjs +4 -4
  55. package/esm2020/datepicker/multi-year-view.mjs +4 -4
  56. package/esm2020/datepicker/year-view.mjs +4 -4
  57. package/esm2020/dialog/dialog-container.mjs +7 -7
  58. package/esm2020/dialog/dialog-content-directives.mjs +13 -13
  59. package/esm2020/dialog/dialog-module.mjs +5 -5
  60. package/esm2020/dialog/dialog.mjs +7 -7
  61. package/esm2020/divider/divider-module.mjs +5 -5
  62. package/esm2020/divider/divider.mjs +4 -4
  63. package/esm2020/expansion/accordion.mjs +4 -4
  64. package/esm2020/expansion/expansion-module.mjs +5 -5
  65. package/esm2020/expansion/expansion-panel-content.mjs +4 -4
  66. package/esm2020/expansion/expansion-panel-header.mjs +10 -10
  67. package/esm2020/expansion/expansion-panel.mjs +7 -7
  68. package/esm2020/form-field/error.mjs +4 -4
  69. package/esm2020/form-field/form-field-control.mjs +4 -4
  70. package/esm2020/form-field/form-field-module.mjs +5 -5
  71. package/esm2020/form-field/form-field.mjs +4 -4
  72. package/esm2020/form-field/hint.mjs +4 -4
  73. package/esm2020/form-field/label.mjs +4 -4
  74. package/esm2020/form-field/placeholder.mjs +4 -4
  75. package/esm2020/form-field/prefix.mjs +4 -4
  76. package/esm2020/form-field/suffix.mjs +4 -4
  77. package/esm2020/grid-list/grid-list-module.mjs +5 -5
  78. package/esm2020/grid-list/grid-list.mjs +4 -4
  79. package/esm2020/grid-list/grid-tile.mjs +16 -16
  80. package/esm2020/icon/icon-module.mjs +5 -5
  81. package/esm2020/icon/icon-registry.mjs +4 -4
  82. package/esm2020/icon/icon.mjs +4 -4
  83. package/esm2020/icon/testing/fake-icon-registry.mjs +8 -8
  84. package/esm2020/input/input-module.mjs +5 -5
  85. package/esm2020/input/input.mjs +4 -4
  86. package/esm2020/list/list-module.mjs +5 -5
  87. package/esm2020/list/list.mjs +19 -19
  88. package/esm2020/list/selection-list.mjs +7 -7
  89. package/esm2020/menu/menu-content.mjs +7 -7
  90. package/esm2020/menu/menu-item.mjs +4 -4
  91. package/esm2020/menu/menu-module.mjs +5 -5
  92. package/esm2020/menu/menu-trigger.mjs +7 -7
  93. package/esm2020/menu/menu.mjs +7 -7
  94. package/esm2020/paginator/paginator-intl.mjs +4 -4
  95. package/esm2020/paginator/paginator-module.mjs +5 -5
  96. package/esm2020/paginator/paginator.mjs +7 -7
  97. package/esm2020/progress-bar/progress-bar-module.mjs +5 -5
  98. package/esm2020/progress-bar/progress-bar.mjs +4 -4
  99. package/esm2020/progress-spinner/progress-spinner-module.mjs +5 -5
  100. package/esm2020/progress-spinner/progress-spinner.mjs +4 -4
  101. package/esm2020/radio/radio-module.mjs +5 -5
  102. package/esm2020/radio/radio.mjs +13 -13
  103. package/esm2020/select/select-module.mjs +5 -5
  104. package/esm2020/select/select.mjs +10 -10
  105. package/esm2020/sidenav/drawer.mjs +10 -10
  106. package/esm2020/sidenav/sidenav-module.mjs +5 -5
  107. package/esm2020/sidenav/sidenav.mjs +10 -10
  108. package/esm2020/slide-toggle/slide-toggle-module.mjs +9 -9
  109. package/esm2020/slide-toggle/slide-toggle-required-validator.mjs +4 -4
  110. package/esm2020/slide-toggle/slide-toggle.mjs +89 -77
  111. package/esm2020/slider/slider-module.mjs +5 -5
  112. package/esm2020/slider/slider.mjs +4 -4
  113. package/esm2020/snack-bar/simple-snack-bar.mjs +4 -4
  114. package/esm2020/snack-bar/snack-bar-container.mjs +4 -4
  115. package/esm2020/snack-bar/snack-bar-module.mjs +5 -5
  116. package/esm2020/snack-bar/snack-bar.mjs +7 -7
  117. package/esm2020/sort/sort-header-intl.mjs +4 -4
  118. package/esm2020/sort/sort-header.mjs +4 -4
  119. package/esm2020/sort/sort-module.mjs +5 -5
  120. package/esm2020/sort/sort.mjs +4 -4
  121. package/esm2020/stepper/step-content.mjs +4 -4
  122. package/esm2020/stepper/step-header.mjs +4 -4
  123. package/esm2020/stepper/step-label.mjs +4 -4
  124. package/esm2020/stepper/stepper-button.mjs +7 -7
  125. package/esm2020/stepper/stepper-icon.mjs +4 -4
  126. package/esm2020/stepper/stepper-intl.mjs +4 -4
  127. package/esm2020/stepper/stepper-module.mjs +5 -5
  128. package/esm2020/stepper/stepper.mjs +7 -7
  129. package/esm2020/table/cell.mjs +22 -22
  130. package/esm2020/table/row.mjs +22 -22
  131. package/esm2020/table/table-module.mjs +5 -5
  132. package/esm2020/table/table.mjs +7 -7
  133. package/esm2020/table/text-column.mjs +4 -4
  134. package/esm2020/tabs/ink-bar.mjs +4 -4
  135. package/esm2020/tabs/paginated-tab-header.mjs +27 -7
  136. package/esm2020/tabs/tab-body.mjs +10 -10
  137. package/esm2020/tabs/tab-content.mjs +4 -4
  138. package/esm2020/tabs/tab-group.mjs +7 -7
  139. package/esm2020/tabs/tab-header.mjs +7 -7
  140. package/esm2020/tabs/tab-label-wrapper.mjs +4 -4
  141. package/esm2020/tabs/tab-label.mjs +4 -4
  142. package/esm2020/tabs/tab-nav-bar/tab-nav-bar.mjs +16 -16
  143. package/esm2020/tabs/tab.mjs +4 -4
  144. package/esm2020/tabs/tabs-module.mjs +5 -5
  145. package/esm2020/toolbar/toolbar-module.mjs +5 -5
  146. package/esm2020/toolbar/toolbar.mjs +7 -7
  147. package/esm2020/tooltip/tooltip-module.mjs +5 -5
  148. package/esm2020/tooltip/tooltip.mjs +13 -13
  149. package/esm2020/tree/node.mjs +10 -10
  150. package/esm2020/tree/outlet.mjs +4 -4
  151. package/esm2020/tree/padding.mjs +4 -4
  152. package/esm2020/tree/toggle.mjs +4 -4
  153. package/esm2020/tree/tree-module.mjs +5 -5
  154. package/esm2020/tree/tree.mjs +4 -4
  155. package/fesm2015/autocomplete.mjs +22 -22
  156. package/fesm2015/autocomplete.mjs.map +1 -1
  157. package/fesm2015/badge.mjs +7 -7
  158. package/fesm2015/badge.mjs.map +1 -1
  159. package/fesm2015/bottom-sheet.mjs +125 -343
  160. package/fesm2015/bottom-sheet.mjs.map +1 -1
  161. package/fesm2015/button-toggle.mjs +10 -10
  162. package/fesm2015/button-toggle.mjs.map +1 -1
  163. package/fesm2015/button.mjs +10 -10
  164. package/fesm2015/button.mjs.map +1 -1
  165. package/fesm2015/card.mjs +46 -46
  166. package/fesm2015/card.mjs.map +1 -1
  167. package/fesm2015/checkbox.mjs +151 -134
  168. package/fesm2015/checkbox.mjs.map +1 -1
  169. package/fesm2015/chips.mjs +22 -22
  170. package/fesm2015/chips.mjs.map +1 -1
  171. package/fesm2015/core.mjs +59 -59
  172. package/fesm2015/core.mjs.map +1 -1
  173. package/fesm2015/datepicker.mjs +97 -82
  174. package/fesm2015/datepicker.mjs.map +1 -1
  175. package/fesm2015/dialog.mjs +28 -28
  176. package/fesm2015/dialog.mjs.map +1 -1
  177. package/fesm2015/divider.mjs +7 -7
  178. package/fesm2015/divider.mjs.map +1 -1
  179. package/fesm2015/expansion.mjs +25 -25
  180. package/fesm2015/expansion.mjs.map +1 -1
  181. package/fesm2015/form-field.mjs +28 -28
  182. package/fesm2015/form-field.mjs.map +1 -1
  183. package/fesm2015/grid-list.mjs +22 -22
  184. package/fesm2015/grid-list.mjs.map +1 -1
  185. package/fesm2015/icon/testing.mjs +7 -7
  186. package/fesm2015/icon/testing.mjs.map +1 -1
  187. package/fesm2015/icon.mjs +10 -10
  188. package/fesm2015/icon.mjs.map +1 -1
  189. package/fesm2015/input.mjs +7 -7
  190. package/fesm2015/input.mjs.map +1 -1
  191. package/fesm2015/list.mjs +28 -28
  192. package/fesm2015/list.mjs.map +1 -1
  193. package/fesm2015/menu.mjs +25 -25
  194. package/fesm2015/menu.mjs.map +1 -1
  195. package/fesm2015/paginator.mjs +13 -13
  196. package/fesm2015/paginator.mjs.map +1 -1
  197. package/fesm2015/progress-bar.mjs +7 -7
  198. package/fesm2015/progress-bar.mjs.map +1 -1
  199. package/fesm2015/progress-spinner.mjs +7 -7
  200. package/fesm2015/progress-spinner.mjs.map +1 -1
  201. package/fesm2015/radio.mjs +16 -16
  202. package/fesm2015/radio.mjs.map +1 -1
  203. package/fesm2015/select.mjs +13 -13
  204. package/fesm2015/select.mjs.map +1 -1
  205. package/fesm2015/sidenav.mjs +22 -22
  206. package/fesm2015/sidenav.mjs.map +1 -1
  207. package/fesm2015/slide-toggle.mjs +100 -88
  208. package/fesm2015/slide-toggle.mjs.map +1 -1
  209. package/fesm2015/slider.mjs +7 -7
  210. package/fesm2015/slider.mjs.map +1 -1
  211. package/fesm2015/snack-bar.mjs +16 -16
  212. package/fesm2015/snack-bar.mjs.map +1 -1
  213. package/fesm2015/sort.mjs +13 -13
  214. package/fesm2015/sort.mjs.map +1 -1
  215. package/fesm2015/stepper.mjs +31 -31
  216. package/fesm2015/stepper.mjs.map +1 -1
  217. package/fesm2015/table.mjs +55 -55
  218. package/fesm2015/table.mjs.map +1 -1
  219. package/fesm2015/tabs.mjs +81 -61
  220. package/fesm2015/tabs.mjs.map +1 -1
  221. package/fesm2015/toolbar.mjs +10 -10
  222. package/fesm2015/toolbar.mjs.map +1 -1
  223. package/fesm2015/tooltip.mjs +16 -16
  224. package/fesm2015/tooltip.mjs.map +1 -1
  225. package/fesm2015/tree.mjs +25 -25
  226. package/fesm2015/tree.mjs.map +1 -1
  227. package/fesm2020/autocomplete.mjs +22 -22
  228. package/fesm2020/autocomplete.mjs.map +1 -1
  229. package/fesm2020/badge.mjs +7 -7
  230. package/fesm2020/badge.mjs.map +1 -1
  231. package/fesm2020/bottom-sheet.mjs +132 -342
  232. package/fesm2020/bottom-sheet.mjs.map +1 -1
  233. package/fesm2020/button-toggle.mjs +10 -10
  234. package/fesm2020/button-toggle.mjs.map +1 -1
  235. package/fesm2020/button.mjs +10 -10
  236. package/fesm2020/button.mjs.map +1 -1
  237. package/fesm2020/card.mjs +46 -46
  238. package/fesm2020/card.mjs.map +1 -1
  239. package/fesm2020/checkbox.mjs +149 -132
  240. package/fesm2020/checkbox.mjs.map +1 -1
  241. package/fesm2020/chips.mjs +22 -22
  242. package/fesm2020/chips.mjs.map +1 -1
  243. package/fesm2020/core.mjs +59 -59
  244. package/fesm2020/core.mjs.map +1 -1
  245. package/fesm2020/datepicker.mjs +97 -82
  246. package/fesm2020/datepicker.mjs.map +1 -1
  247. package/fesm2020/dialog.mjs +28 -28
  248. package/fesm2020/dialog.mjs.map +1 -1
  249. package/fesm2020/divider.mjs +7 -7
  250. package/fesm2020/divider.mjs.map +1 -1
  251. package/fesm2020/expansion.mjs +25 -25
  252. package/fesm2020/expansion.mjs.map +1 -1
  253. package/fesm2020/form-field.mjs +28 -28
  254. package/fesm2020/form-field.mjs.map +1 -1
  255. package/fesm2020/grid-list.mjs +22 -22
  256. package/fesm2020/grid-list.mjs.map +1 -1
  257. package/fesm2020/icon/testing.mjs +7 -7
  258. package/fesm2020/icon/testing.mjs.map +1 -1
  259. package/fesm2020/icon.mjs +10 -10
  260. package/fesm2020/icon.mjs.map +1 -1
  261. package/fesm2020/input.mjs +7 -7
  262. package/fesm2020/input.mjs.map +1 -1
  263. package/fesm2020/list.mjs +28 -28
  264. package/fesm2020/list.mjs.map +1 -1
  265. package/fesm2020/menu.mjs +25 -25
  266. package/fesm2020/menu.mjs.map +1 -1
  267. package/fesm2020/paginator.mjs +13 -13
  268. package/fesm2020/paginator.mjs.map +1 -1
  269. package/fesm2020/progress-bar.mjs +7 -7
  270. package/fesm2020/progress-bar.mjs.map +1 -1
  271. package/fesm2020/progress-spinner.mjs +7 -7
  272. package/fesm2020/progress-spinner.mjs.map +1 -1
  273. package/fesm2020/radio.mjs +16 -16
  274. package/fesm2020/radio.mjs.map +1 -1
  275. package/fesm2020/select.mjs +13 -13
  276. package/fesm2020/select.mjs.map +1 -1
  277. package/fesm2020/sidenav.mjs +22 -22
  278. package/fesm2020/sidenav.mjs.map +1 -1
  279. package/fesm2020/slide-toggle.mjs +100 -88
  280. package/fesm2020/slide-toggle.mjs.map +1 -1
  281. package/fesm2020/slider.mjs +7 -7
  282. package/fesm2020/slider.mjs.map +1 -1
  283. package/fesm2020/snack-bar.mjs +16 -16
  284. package/fesm2020/snack-bar.mjs.map +1 -1
  285. package/fesm2020/sort.mjs +13 -13
  286. package/fesm2020/sort.mjs.map +1 -1
  287. package/fesm2020/stepper.mjs +31 -31
  288. package/fesm2020/stepper.mjs.map +1 -1
  289. package/fesm2020/table.mjs +55 -55
  290. package/fesm2020/table.mjs.map +1 -1
  291. package/fesm2020/tabs.mjs +81 -61
  292. package/fesm2020/tabs.mjs.map +1 -1
  293. package/fesm2020/toolbar.mjs +10 -10
  294. package/fesm2020/toolbar.mjs.map +1 -1
  295. package/fesm2020/tooltip.mjs +16 -16
  296. package/fesm2020/tooltip.mjs.map +1 -1
  297. package/fesm2020/tree.mjs +25 -25
  298. package/fesm2020/tree.mjs.map +1 -1
  299. package/package.json +7 -7
  300. package/schematics/ng-add/index.js +2 -2
  301. package/schematics/ng-add/index.mjs +2 -2
  302. package/schematics/ng-add/setup-project.js +59 -18
  303. package/schematics/ng-add/setup-project.mjs +59 -18
  304. package/schematics/ng-generate/address-form/schema.json +3 -0
  305. package/schematics/ng-generate/dashboard/schema.json +3 -0
  306. package/schematics/ng-generate/navigation/schema.json +3 -0
  307. package/schematics/ng-generate/table/schema.json +3 -0
  308. package/schematics/ng-generate/tree/schema.json +3 -0
  309. package/slide-toggle/index.d.ts +45 -32
  310. 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
- const appModulePath = (0, schematics_2.getAppModulePath)(host, (0, schematics_2.getProjectMainFile)(project));
57
- if (options.animations === 'enabled') {
58
- // In case the project explicitly uses the NoopAnimationsModule, we should print a warning
59
- // message that makes the user aware of the fact that we won't automatically set up
60
- // animations. If we would add the BrowserAnimationsModule while the NoopAnimationsModule
61
- // is already configured, we would cause unexpected behavior and runtime exceptions.
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
- (0, schematics_2.addModuleImportToRootModule)(host, browserAnimationsModuleName, '@angular/platform-browser/animations', project);
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"]}
@@ -7,6 +7,9 @@
7
7
  "path": {
8
8
  "type": "string",
9
9
  "format": "path",
10
+ "$default": {
11
+ "$source": "workingDirectory"
12
+ },
10
13
  "description": "The path to create the component.",
11
14
  "visible": false
12
15
  },
@@ -7,6 +7,9 @@
7
7
  "path": {
8
8
  "type": "string",
9
9
  "format": "path",
10
+ "$default": {
11
+ "$source": "workingDirectory"
12
+ },
10
13
  "description": "The path to create the component.",
11
14
  "visible": false
12
15
  },
@@ -7,6 +7,9 @@
7
7
  "path": {
8
8
  "type": "string",
9
9
  "format": "path",
10
+ "$default": {
11
+ "$source": "workingDirectory"
12
+ },
10
13
  "description": "The path to create the component.",
11
14
  "visible": false
12
15
  },
@@ -7,6 +7,9 @@
7
7
  "path": {
8
8
  "type": "string",
9
9
  "format": "path",
10
+ "$default": {
11
+ "$source": "workingDirectory"
12
+ },
10
13
  "description": "The path to create the component.",
11
14
  "visible": false
12
15
  },
@@ -7,6 +7,9 @@
7
7
  "path": {
8
8
  "type": "string",
9
9
  "format": "path",
10
+ "$default": {
11
+ "$source": "workingDirectory"
12
+ },
10
13
  "description": "The path to create the component.",
11
14
  "visible": false
12
15
  },
@@ -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: any;
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 implements OnDestroy, AfterContentInit, ControlValueAccessor, CanDisable, CanColor, HasTabIndex, CanDisableRipple {
49
- private _focusMonitor;
50
- private _changeDetectorRef;
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
- private _onChange;
75
+ protected _onChange: (_: any) => void;
53
76
  private _onTouched;
54
- private _uniqueId;
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
- /** Reference to the thumb HTMLElement. */
60
- _thumbEl: ElementRef;
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<MatSlideToggleChange>;
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
- /** Reference to the underlying input element. */
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
- private _emitChangeEvent;
116
- /** Method being called whenever the label text changes. */
117
- _onLabelTextChange(): void;
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. */