@angular/material 12.0.0-rc.2 → 12.0.2

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 (215) hide show
  1. package/_index.scss +2 -1
  2. package/_theming.scss +39 -4
  3. package/autocomplete/_autocomplete-legacy-index.scss +2 -0
  4. package/badge/_badge-legacy-index.scss +3 -0
  5. package/bottom-sheet/_bottom-sheet-legacy-index.scss +2 -0
  6. package/bottom-sheet/bottom-sheet-container.d.ts +0 -2
  7. package/bottom-sheet/index.metadata.json +1 -1
  8. package/bundles/material-bottom-sheet.umd.js +7 -15
  9. package/bundles/material-bottom-sheet.umd.js.map +1 -1
  10. package/bundles/material-checkbox.umd.js +1 -1
  11. package/bundles/material-checkbox.umd.js.map +1 -1
  12. package/bundles/material-core.umd.js +2 -2
  13. package/bundles/material-core.umd.js.map +1 -1
  14. package/bundles/material-datepicker.umd.js +33 -17
  15. package/bundles/material-datepicker.umd.js.map +1 -1
  16. package/bundles/material-dialog.umd.js +11 -19
  17. package/bundles/material-dialog.umd.js.map +1 -1
  18. package/bundles/material-input.umd.js +7 -1
  19. package/bundles/material-input.umd.js.map +1 -1
  20. package/bundles/material-slide-toggle.umd.js +4 -4
  21. package/bundles/material-slide-toggle.umd.js.map +1 -1
  22. package/bundles/material-sort.umd.js +7 -1
  23. package/bundles/material-sort.umd.js.map +1 -1
  24. package/bundles/material-stepper.umd.js +2 -2
  25. package/bundles/material-stepper.umd.js.map +1 -1
  26. package/bundles/material-table-testing.umd.js +103 -143
  27. package/bundles/material-table-testing.umd.js.map +1 -1
  28. package/bundles/material-table.umd.js.map +1 -1
  29. package/bundles/material-tabs.umd.js +4 -2
  30. package/bundles/material-tabs.umd.js.map +1 -1
  31. package/bundles/material-tooltip.umd.js +19 -15
  32. package/bundles/material-tooltip.umd.js.map +1 -1
  33. package/button/_button-legacy-index.scss +19 -0
  34. package/button-toggle/_button-toggle-legacy-index.scss +2 -0
  35. package/card/_card-legacy-index.scss +2 -0
  36. package/checkbox/_checkbox-legacy-index.scss +2 -0
  37. package/checkbox/index.metadata.json +1 -1
  38. package/chips/_chips-legacy-index.scss +6 -0
  39. package/core/_core-legacy-index.scss +17 -0
  40. package/core/color/_color-legacy-index.scss +1 -0
  41. package/core/density/private/_density-legacy-index.scss +5 -0
  42. package/core/focus-indicators/_focus-indicators-legacy-index.scss +5 -0
  43. package/core/focus-indicators/_focus-indicators.import.scss +1 -1
  44. package/core/focus-indicators/_focus-indicators.scss +4 -0
  45. package/core/index.metadata.json +1 -1
  46. package/core/option/_option-legacy-index.scss +5 -0
  47. package/core/ripple/_ripple-legacy-index.scss +3 -0
  48. package/core/ripple/ripple.d.ts +3 -3
  49. package/core/selection/pseudo-checkbox/_pseudo-checkbox-legacy-index.scss +2 -0
  50. package/core/style/_style-legacy-index.scss +24 -0
  51. package/core/theming/_theming-legacy-index.scss +22 -0
  52. package/core/typography/_typography-legacy-index.scss +18 -0
  53. package/datepicker/_datepicker-legacy-index.scss +9 -0
  54. package/datepicker/date-range-input.d.ts +2 -0
  55. package/datepicker/datepicker-base.d.ts +7 -2
  56. package/datepicker/datepicker-input.d.ts +4 -2
  57. package/datepicker/index.metadata.json +1 -1
  58. package/dialog/_dialog-legacy-index.scss +2 -0
  59. package/dialog/dialog-container.d.ts +0 -2
  60. package/dialog/index.metadata.json +1 -1
  61. package/divider/_divider-legacy-index.scss +3 -0
  62. package/esm2015/bottom-sheet/bottom-sheet-container.js +5 -12
  63. package/esm2015/checkbox/checkbox.js +2 -2
  64. package/esm2015/core/common-behaviors/common-module.js +1 -1
  65. package/esm2015/core/ripple/ripple.js +1 -1
  66. package/esm2015/core/version.js +1 -1
  67. package/esm2015/datepicker/date-range-input-parts.js +3 -2
  68. package/esm2015/datepicker/date-range-input.js +5 -1
  69. package/esm2015/datepicker/datepicker-base.js +16 -11
  70. package/esm2015/datepicker/datepicker-input.js +8 -1
  71. package/esm2015/datepicker/datepicker-intl.js +3 -3
  72. package/esm2015/dialog/dialog-container.js +5 -12
  73. package/esm2015/input/input.js +9 -3
  74. package/esm2015/slide-toggle/slide-toggle.js +5 -5
  75. package/esm2015/sort/sort-header.js +8 -2
  76. package/esm2015/stepper/step-header.js +3 -3
  77. package/esm2015/table/table-data-source.js +1 -1
  78. package/esm2015/table/testing/cell-harness.js +9 -9
  79. package/esm2015/table/testing/row-harness.js +38 -70
  80. package/esm2015/table/testing/table-harness.js +23 -15
  81. package/esm2015/tabs/tab-group.js +4 -2
  82. package/esm2015/tabs/tab.js +3 -3
  83. package/esm2015/tooltip/tooltip.js +12 -8
  84. package/expansion/_expansion-legacy-index.scss +3 -0
  85. package/fesm2015/bottom-sheet.js +4 -11
  86. package/fesm2015/bottom-sheet.js.map +1 -1
  87. package/fesm2015/checkbox.js +1 -1
  88. package/fesm2015/checkbox.js.map +1 -1
  89. package/fesm2015/core.js +2 -2
  90. package/fesm2015/core.js.map +1 -1
  91. package/fesm2015/datepicker.js +30 -13
  92. package/fesm2015/datepicker.js.map +1 -1
  93. package/fesm2015/dialog.js +4 -11
  94. package/fesm2015/dialog.js.map +1 -1
  95. package/fesm2015/input.js +8 -2
  96. package/fesm2015/input.js.map +1 -1
  97. package/fesm2015/slide-toggle.js +4 -4
  98. package/fesm2015/slide-toggle.js.map +1 -1
  99. package/fesm2015/sort.js +7 -1
  100. package/fesm2015/sort.js.map +1 -1
  101. package/fesm2015/stepper.js +2 -2
  102. package/fesm2015/stepper.js.map +1 -1
  103. package/fesm2015/table/testing.js +66 -90
  104. package/fesm2015/table/testing.js.map +1 -1
  105. package/fesm2015/table.js.map +1 -1
  106. package/fesm2015/tabs.js +4 -2
  107. package/fesm2015/tabs.js.map +1 -1
  108. package/fesm2015/tooltip.js +11 -7
  109. package/fesm2015/tooltip.js.map +1 -1
  110. package/form-field/_form-field-legacy-index.scss +24 -0
  111. package/grid-list/_grid-list-legacy-index.scss +2 -0
  112. package/icon/_icon-legacy-index.scss +2 -0
  113. package/input/_input-legacy-index.scss +2 -0
  114. package/input/index.metadata.json +1 -1
  115. package/list/_list-legacy-index.scss +2 -0
  116. package/menu/_menu-legacy-index.scss +2 -0
  117. package/package.json +6 -6
  118. package/paginator/_paginator-legacy-index.scss +2 -0
  119. package/prebuilt-themes/deeppurple-amber.css +1 -1
  120. package/prebuilt-themes/indigo-pink.css +1 -1
  121. package/prebuilt-themes/pink-bluegrey.css +1 -1
  122. package/prebuilt-themes/purple-green.css +1 -1
  123. package/progress-bar/_progress-bar-legacy-index.scss +2 -0
  124. package/progress-spinner/_progress-spinner-legacy-index.scss +2 -0
  125. package/radio/_radio-legacy-index.scss +2 -0
  126. package/schematics/collection.json +0 -6
  127. package/schematics/ng-add/fonts/material-fonts.mjs +46 -0
  128. package/schematics/ng-add/index.js +2 -2
  129. package/schematics/ng-add/index.mjs +55 -0
  130. package/schematics/ng-add/package-config.mjs +47 -0
  131. package/schematics/ng-add/schema.mjs +10 -0
  132. package/schematics/ng-add/setup-project.mjs +121 -0
  133. package/schematics/ng-add/theming/create-custom-theme.mjs +51 -0
  134. package/schematics/ng-add/theming/theming.mjs +165 -0
  135. package/schematics/ng-generate/address-form/index.mjs +49 -0
  136. package/schematics/ng-generate/address-form/schema.mjs +10 -0
  137. package/schematics/ng-generate/dashboard/index.mjs +49 -0
  138. package/schematics/ng-generate/dashboard/schema.mjs +10 -0
  139. package/schematics/ng-generate/navigation/index.mjs +49 -0
  140. package/schematics/ng-generate/navigation/schema.mjs +10 -0
  141. package/schematics/ng-generate/table/index.mjs +46 -0
  142. package/schematics/ng-generate/table/schema.mjs +10 -0
  143. package/schematics/ng-generate/tree/index.mjs +46 -0
  144. package/schematics/ng-generate/tree/schema.mjs +10 -0
  145. package/schematics/ng-update/data/attribute-selectors.mjs +12 -0
  146. package/schematics/ng-update/data/class-names.mjs +32 -0
  147. package/schematics/ng-update/data/constructor-checks.mjs +143 -0
  148. package/schematics/ng-update/data/css-selectors.mjs +46 -0
  149. package/schematics/ng-update/data/element-selectors.mjs +18 -0
  150. package/schematics/ng-update/data/index.mjs +29 -0
  151. package/schematics/ng-update/data/input-names.mjs +76 -0
  152. package/schematics/ng-update/data/method-call-checks.mjs +22 -0
  153. package/schematics/ng-update/data/output-names.mjs +101 -0
  154. package/schematics/ng-update/data/property-names.mjs +173 -0
  155. package/schematics/ng-update/index.js +3 -1
  156. package/schematics/ng-update/index.mjs +78 -0
  157. package/schematics/ng-update/migrations/hammer-gestures-v9/find-hammer-script-tags.mjs +42 -0
  158. package/schematics/ng-update/migrations/hammer-gestures-v9/find-main-module.mjs +32 -0
  159. package/schematics/ng-update/migrations/hammer-gestures-v9/hammer-gestures-migration.mjs +778 -0
  160. package/schematics/ng-update/migrations/hammer-gestures-v9/hammer-template-check.mjs +56 -0
  161. package/schematics/ng-update/migrations/hammer-gestures-v9/import-manager.mjs +370 -0
  162. package/schematics/ng-update/migrations/hammer-gestures-v9/remove-array-element.mjs +66 -0
  163. package/schematics/ng-update/migrations/hammer-gestures-v9/remove-element-from-html.mjs +28 -0
  164. package/schematics/ng-update/migrations/misc-checks/misc-class-inheritance.mjs +48 -0
  165. package/schematics/ng-update/migrations/misc-checks/misc-class-names.mjs +43 -0
  166. package/schematics/ng-update/migrations/misc-checks/misc-imports.mjs +54 -0
  167. package/schematics/ng-update/migrations/misc-checks/misc-property-names.mjs +47 -0
  168. package/schematics/ng-update/migrations/misc-checks/misc-template.mjs +60 -0
  169. package/schematics/ng-update/migrations/misc-ripples-v7/ripple-speed-factor-migration.mjs +138 -0
  170. package/schematics/ng-update/migrations/misc-ripples-v7/ripple-speed-factor.mjs +30 -0
  171. package/schematics/ng-update/migrations/package-imports-v8/secondary-entry-points-migration.mjs +169 -0
  172. package/schematics/{ng-generate/theming-api → ng-update/migrations/theming-api-v12}/config.d.ts +6 -0
  173. package/schematics/ng-update/migrations/theming-api-v12/config.js +206 -0
  174. package/schematics/ng-update/migrations/theming-api-v12/config.mjs +206 -0
  175. package/schematics/{ng-generate/theming-api → ng-update/migrations/theming-api-v12}/migration.d.ts +0 -0
  176. package/schematics/ng-update/migrations/theming-api-v12/migration.js +234 -0
  177. package/schematics/ng-update/migrations/theming-api-v12/migration.mjs +234 -0
  178. package/schematics/ng-update/migrations/theming-api-v12/theming-api-migration.d.ts +18 -0
  179. package/schematics/ng-update/migrations/theming-api-v12/theming-api-migration.js +45 -0
  180. package/schematics/ng-update/migrations/theming-api-v12/theming-api-migration.mjs +45 -0
  181. package/schematics/ng-update/typescript/module-specifiers.mjs +35 -0
  182. package/schematics/ng-update/upgrade-data.mjs +24 -0
  183. package/schematics/paths.mjs +16 -0
  184. package/schematics/schematics.externs.js +0 -0
  185. package/select/_select-legacy-index.scss +2 -0
  186. package/sidenav/_sidenav-legacy-index.scss +2 -0
  187. package/slide-toggle/_slide-toggle-legacy-index.scss +3 -0
  188. package/slide-toggle/index.metadata.json +1 -1
  189. package/slide-toggle/slide-toggle.d.ts +3 -2
  190. package/slider/_slider-legacy-index.scss +2 -0
  191. package/snack-bar/_snack-bar-legacy-index.scss +2 -0
  192. package/sort/_sort-legacy-index.scss +2 -0
  193. package/sort/sort-header.d.ts +1 -1
  194. package/stepper/_stepper-legacy-index.scss +7 -0
  195. package/stepper/index.metadata.json +1 -1
  196. package/table/_table-legacy-index.scss +3 -0
  197. package/table/index.metadata.json +1 -1
  198. package/table/table-data-source.d.ts +17 -5
  199. package/table/testing/cell-harness.d.ts +2 -1
  200. package/table/testing/row-harness.d.ts +21 -22
  201. package/table/testing/table-harness.d.ts +32 -13
  202. package/tabs/_tabs-legacy-index.scss +6 -0
  203. package/tabs/_tabs-theme.scss +5 -2
  204. package/tabs/index.metadata.json +1 -1
  205. package/toolbar/_toolbar-legacy-index.scss +4 -0
  206. package/tooltip/_tooltip-legacy-index.scss +3 -0
  207. package/tooltip/index.metadata.json +1 -1
  208. package/tree/_tree-legacy-index.scss +2 -0
  209. package/schematics/ng-generate/theming-api/config.js +0 -183
  210. package/schematics/ng-generate/theming-api/index.d.ts +0 -10
  211. package/schematics/ng-generate/theming-api/index.js +0 -26
  212. package/schematics/ng-generate/theming-api/migration.js +0 -226
  213. package/schematics/ng-generate/theming-api/schema.d.ts +0 -9
  214. package/schematics/ng-generate/theming-api/schema.js +0 -10
  215. package/schematics/ng-generate/theming-api/schema.json +0 -7
@@ -0,0 +1,169 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.SecondaryEntryPointsMigration = void 0;
11
+ const schematics_1 = require("@angular/cdk/schematics");
12
+ const ts = require("typescript");
13
+ const module_specifiers_1 = require("../../../ng-update/typescript/module-specifiers");
14
+ const ONLY_SUBPACKAGE_FAILURE_STR = `Importing from "@angular/material" is deprecated. ` +
15
+ `Instead import from the entry-point the symbol belongs to.`;
16
+ const NO_IMPORT_NAMED_SYMBOLS_FAILURE_STR = `Imports from Angular Material should import ` +
17
+ `specific symbols rather than importing the entire library.`;
18
+ /**
19
+ * Regex for testing file paths against to determine if the file is from the
20
+ * Angular Material library.
21
+ */
22
+ const ANGULAR_MATERIAL_FILEPATH_REGEX = new RegExp(`${module_specifiers_1.materialModuleSpecifier}/(.*?)/`);
23
+ /**
24
+ * Mapping of Material symbol names to their module names. Used as a fallback if
25
+ * we didn't manage to resolve the module name of a symbol using the type checker.
26
+ */
27
+ const ENTRY_POINT_MAPPINGS = require('./material-symbols.json');
28
+ /**
29
+ * Migration that updates imports which refer to the primary Angular Material
30
+ * entry-point to use the appropriate secondary entry points (e.g. @angular/material/button).
31
+ */
32
+ class SecondaryEntryPointsMigration extends schematics_1.Migration {
33
+ constructor() {
34
+ super(...arguments);
35
+ this.printer = ts.createPrinter();
36
+ // Only enable this rule if the migration targets version 8. The primary
37
+ // entry-point of Material has been marked as deprecated in version 8.
38
+ this.enabled = this.targetVersion === schematics_1.TargetVersion.V8 || this.targetVersion === schematics_1.TargetVersion.V9;
39
+ }
40
+ visitNode(declaration) {
41
+ // Only look at import declarations.
42
+ if (!ts.isImportDeclaration(declaration) ||
43
+ !ts.isStringLiteralLike(declaration.moduleSpecifier)) {
44
+ return;
45
+ }
46
+ const importLocation = declaration.moduleSpecifier.text;
47
+ // If the import module is not @angular/material, skip the check.
48
+ if (importLocation !== module_specifiers_1.materialModuleSpecifier) {
49
+ return;
50
+ }
51
+ // If no import clause is found, or nothing is named as a binding in the
52
+ // import, add failure saying to import symbols in clause.
53
+ if (!declaration.importClause || !declaration.importClause.namedBindings) {
54
+ this.createFailureAtNode(declaration, NO_IMPORT_NAMED_SYMBOLS_FAILURE_STR);
55
+ return;
56
+ }
57
+ // All named bindings in import clauses must be named symbols, otherwise add
58
+ // failure saying to import symbols in clause.
59
+ if (!ts.isNamedImports(declaration.importClause.namedBindings)) {
60
+ this.createFailureAtNode(declaration, NO_IMPORT_NAMED_SYMBOLS_FAILURE_STR);
61
+ return;
62
+ }
63
+ // If no symbols are in the named bindings then add failure saying to
64
+ // import symbols in clause.
65
+ if (!declaration.importClause.namedBindings.elements.length) {
66
+ this.createFailureAtNode(declaration, NO_IMPORT_NAMED_SYMBOLS_FAILURE_STR);
67
+ return;
68
+ }
69
+ // Whether the existing import declaration is using a single quote module specifier.
70
+ const singleQuoteImport = declaration.moduleSpecifier.getText()[0] === `'`;
71
+ // Map which consists of secondary entry-points and import specifiers which are used
72
+ // within the current import declaration.
73
+ const importMap = new Map();
74
+ // Determine the subpackage each symbol in the namedBinding comes from.
75
+ for (const element of declaration.importClause.namedBindings.elements) {
76
+ const elementName = element.propertyName ? element.propertyName : element.name;
77
+ // Try to resolve the module name via the type checker, and if it fails, fall back to
78
+ // resolving it from our list of symbol to entry point mappings. Using the type checker is
79
+ // more accurate and doesn't require us to keep a list of symbols, but it won't work if
80
+ // the symbols don't exist anymore (e.g. after we remove the top-level @angular/material).
81
+ const moduleName = resolveModuleName(elementName, this.typeChecker) ||
82
+ ENTRY_POINT_MAPPINGS[elementName.text] || null;
83
+ if (!moduleName) {
84
+ this.createFailureAtNode(element, `"${element.getText()}" was not found in the Material library.`);
85
+ return;
86
+ }
87
+ // The module name where the symbol is defined e.g. card, dialog. The
88
+ // first capture group is contains the module name.
89
+ if (importMap.has(moduleName)) {
90
+ importMap.get(moduleName).push(element);
91
+ }
92
+ else {
93
+ importMap.set(moduleName, [element]);
94
+ }
95
+ }
96
+ // Transforms the import declaration into multiple import declarations that import
97
+ // the given symbols from the individual secondary entry-points. For example:
98
+ // import {MatCardModule, MatCardTitle} from '@angular/material/card';
99
+ // import {MatRadioModule} from '@angular/material/radio';
100
+ const newImportStatements = Array.from(importMap.entries())
101
+ .sort()
102
+ .map(([name, elements]) => {
103
+ const newImport = ts.createImportDeclaration(undefined, undefined, ts.createImportClause(undefined, ts.createNamedImports(elements)), createStringLiteral(`${module_specifiers_1.materialModuleSpecifier}/${name}`, singleQuoteImport));
104
+ return this.printer.printNode(ts.EmitHint.Unspecified, newImport, declaration.getSourceFile());
105
+ })
106
+ .join('\n');
107
+ // Without any import statements that were generated, we can assume that this was an empty
108
+ // import declaration. We still want to add a failure in order to make developers aware that
109
+ // importing from "@angular/material" is deprecated.
110
+ if (!newImportStatements) {
111
+ this.createFailureAtNode(declaration.moduleSpecifier, ONLY_SUBPACKAGE_FAILURE_STR);
112
+ return;
113
+ }
114
+ const filePath = this.fileSystem.resolve(declaration.moduleSpecifier.getSourceFile().fileName);
115
+ const recorder = this.fileSystem.edit(filePath);
116
+ // Perform the replacement that switches the primary entry-point import to
117
+ // the individual secondary entry-point imports.
118
+ recorder.remove(declaration.getStart(), declaration.getWidth());
119
+ recorder.insertRight(declaration.getStart(), newImportStatements);
120
+ }
121
+ }
122
+ exports.SecondaryEntryPointsMigration = SecondaryEntryPointsMigration;
123
+ /**
124
+ * Creates a string literal from the specified text.
125
+ * @param text Text of the string literal.
126
+ * @param singleQuotes Whether single quotes should be used when printing the literal node.
127
+ */
128
+ function createStringLiteral(text, singleQuotes) {
129
+ const literal = ts.createStringLiteral(text);
130
+ // See: https://github.com/microsoft/TypeScript/blob/master/src/compiler/utilities.ts#L584-L590
131
+ literal['singleQuote'] = singleQuotes;
132
+ return literal;
133
+ }
134
+ /** Gets the symbol that contains the value declaration of the given node. */
135
+ function getDeclarationSymbolOfNode(node, checker) {
136
+ const symbol = checker.getSymbolAtLocation(node);
137
+ // Symbols can be aliases of the declaration symbol. e.g. in named import specifiers.
138
+ // We need to resolve the aliased symbol back to the declaration symbol.
139
+ // tslint:disable-next-line:no-bitwise
140
+ if (symbol && (symbol.flags & ts.SymbolFlags.Alias) !== 0) {
141
+ return checker.getAliasedSymbol(symbol);
142
+ }
143
+ return symbol;
144
+ }
145
+ /** Tries to resolve the name of the Material module that a node is imported from. */
146
+ function resolveModuleName(node, typeChecker) {
147
+ // Get the symbol for the named binding element. Note that we cannot determine the
148
+ // value declaration based on the type of the element as types are not necessarily
149
+ // specific to a given secondary entry-point (e.g. exports with the type of "string")
150
+ // would resolve to the module types provided by TypeScript itself.
151
+ const symbol = getDeclarationSymbolOfNode(node, typeChecker);
152
+ // If the symbol can't be found, or no declaration could be found within
153
+ // the symbol, add failure to report that the given symbol can't be found.
154
+ if (!symbol ||
155
+ !(symbol.valueDeclaration || (symbol.declarations && symbol.declarations.length !== 0))) {
156
+ return null;
157
+ }
158
+ // The filename for the source file of the node that contains the
159
+ // first declaration of the symbol. All symbol declarations must be
160
+ // part of a defining node, so parent can be asserted to be defined.
161
+ const resolvedNode = symbol.valueDeclaration || symbol.declarations[0];
162
+ const sourceFile = resolvedNode.getSourceFile().fileName;
163
+ // File the module the symbol belongs to from a regex match of the
164
+ // filename. This will always match since only "@angular/material"
165
+ // elements are analyzed.
166
+ const matches = sourceFile.match(ANGULAR_MATERIAL_FILEPATH_REGEX);
167
+ return matches ? matches[1] : null;
168
+ }
169
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"secondary-entry-points-migration.js","sourceRoot":"","sources":["../../../../../../../../../src/material/schematics/ng-update/migrations/package-imports-v8/secondary-entry-points-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 {Migration, TargetVersion} from '@angular/cdk/schematics';\nimport * as ts from 'typescript';\nimport {materialModuleSpecifier} from '../../../ng-update/typescript/module-specifiers';\n\nconst ONLY_SUBPACKAGE_FAILURE_STR = `Importing from \"@angular/material\" is deprecated. ` +\n    `Instead import from the entry-point the symbol belongs to.`;\n\nconst NO_IMPORT_NAMED_SYMBOLS_FAILURE_STR = `Imports from Angular Material should import ` +\n    `specific symbols rather than importing the entire library.`;\n\n/**\n * Regex for testing file paths against to determine if the file is from the\n * Angular Material library.\n */\nconst ANGULAR_MATERIAL_FILEPATH_REGEX = new RegExp(`${materialModuleSpecifier}/(.*?)/`);\n\n/**\n * Mapping of Material symbol names to their module names. Used as a fallback if\n * we didn't manage to resolve the module name of a symbol using the type checker.\n */\nconst ENTRY_POINT_MAPPINGS: {[name: string]: string} = require('./material-symbols.json');\n\n/**\n * Migration that updates imports which refer to the primary Angular Material\n * entry-point to use the appropriate secondary entry points (e.g. @angular/material/button).\n */\nexport class SecondaryEntryPointsMigration extends Migration<null> {\n  printer = ts.createPrinter();\n\n  // Only enable this rule if the migration targets version 8. The primary\n  // entry-point of Material has been marked as deprecated in version 8.\n  enabled = this.targetVersion === TargetVersion.V8 || this.targetVersion === TargetVersion.V9;\n\n  visitNode(declaration: ts.Node): void {\n    // Only look at import declarations.\n    if (!ts.isImportDeclaration(declaration) ||\n        !ts.isStringLiteralLike(declaration.moduleSpecifier)) {\n      return;\n    }\n\n    const importLocation = declaration.moduleSpecifier.text;\n    // If the import module is not @angular/material, skip the check.\n    if (importLocation !== materialModuleSpecifier) {\n      return;\n    }\n\n    // If no import clause is found, or nothing is named as a binding in the\n    // import, add failure saying to import symbols in clause.\n    if (!declaration.importClause || !declaration.importClause.namedBindings) {\n      this.createFailureAtNode(declaration, NO_IMPORT_NAMED_SYMBOLS_FAILURE_STR);\n      return;\n    }\n\n    // All named bindings in import clauses must be named symbols, otherwise add\n    // failure saying to import symbols in clause.\n    if (!ts.isNamedImports(declaration.importClause.namedBindings)) {\n      this.createFailureAtNode(declaration, NO_IMPORT_NAMED_SYMBOLS_FAILURE_STR);\n      return;\n    }\n\n    // If no symbols are in the named bindings then add failure saying to\n    // import symbols in clause.\n    if (!declaration.importClause.namedBindings.elements.length) {\n      this.createFailureAtNode(declaration, NO_IMPORT_NAMED_SYMBOLS_FAILURE_STR);\n      return;\n    }\n\n    // Whether the existing import declaration is using a single quote module specifier.\n    const singleQuoteImport = declaration.moduleSpecifier.getText()[0] === `'`;\n\n    // Map which consists of secondary entry-points and import specifiers which are used\n    // within the current import declaration.\n    const importMap = new Map<string, ts.ImportSpecifier[]>();\n\n    // Determine the subpackage each symbol in the namedBinding comes from.\n    for (const element of declaration.importClause.namedBindings.elements) {\n      const elementName = element.propertyName ? element.propertyName : element.name;\n\n      // Try to resolve the module name via the type checker, and if it fails, fall back to\n      // resolving it from our list of symbol to entry point mappings. Using the type checker is\n      // more accurate and doesn't require us to keep a list of symbols, but it won't work if\n      // the symbols don't exist anymore (e.g. after we remove the top-level @angular/material).\n      const moduleName = resolveModuleName(elementName, this.typeChecker) ||\n          ENTRY_POINT_MAPPINGS[elementName.text] || null;\n\n      if (!moduleName) {\n        this.createFailureAtNode(\n          element, `\"${element.getText()}\" was not found in the Material library.`);\n        return;\n      }\n\n        // The module name where the symbol is defined e.g. card, dialog. The\n        // first capture group is contains the module name.\n        if (importMap.has(moduleName)) {\n          importMap.get(moduleName)!.push(element);\n        } else {\n          importMap.set(moduleName, [element]);\n        }\n    }\n\n    // Transforms the import declaration into multiple import declarations that import\n    // the given symbols from the individual secondary entry-points. For example:\n    // import {MatCardModule, MatCardTitle} from '@angular/material/card';\n    // import {MatRadioModule} from '@angular/material/radio';\n    const newImportStatements =\n        Array.from(importMap.entries())\n            .sort()\n            .map(([name, elements]) => {\n              const newImport = ts.createImportDeclaration(\n                  undefined, undefined,\n                  ts.createImportClause(undefined, ts.createNamedImports(elements)),\n                  createStringLiteral(`${materialModuleSpecifier}/${name}`, singleQuoteImport));\n              return this.printer.printNode(\n                  ts.EmitHint.Unspecified, newImport, declaration.getSourceFile());\n            })\n            .join('\\n');\n\n    // Without any import statements that were generated, we can assume that this was an empty\n    // import declaration. We still want to add a failure in order to make developers aware that\n    // importing from \"@angular/material\" is deprecated.\n    if (!newImportStatements) {\n      this.createFailureAtNode(declaration.moduleSpecifier, ONLY_SUBPACKAGE_FAILURE_STR);\n      return;\n    }\n\n    const filePath = this.fileSystem.resolve(\n        declaration.moduleSpecifier.getSourceFile().fileName);\n    const recorder = this.fileSystem.edit(filePath);\n\n    // Perform the replacement that switches the primary entry-point import to\n    // the individual secondary entry-point imports.\n    recorder.remove(declaration.getStart(), declaration.getWidth());\n    recorder.insertRight(declaration.getStart(), newImportStatements);\n  }\n}\n\n/**\n * Creates a string literal from the specified text.\n * @param text Text of the string literal.\n * @param singleQuotes Whether single quotes should be used when printing the literal node.\n */\nfunction createStringLiteral(text: string, singleQuotes: boolean): ts.StringLiteral {\n  const literal = ts.createStringLiteral(text);\n  // See: https://github.com/microsoft/TypeScript/blob/master/src/compiler/utilities.ts#L584-L590\n  literal['singleQuote'] = singleQuotes;\n  return literal;\n}\n\n/** Gets the symbol that contains the value declaration of the given node. */\nfunction getDeclarationSymbolOfNode(node: ts.Node, checker: ts.TypeChecker): ts.Symbol|undefined {\n  const symbol = checker.getSymbolAtLocation(node);\n\n  // Symbols can be aliases of the declaration symbol. e.g. in named import specifiers.\n  // We need to resolve the aliased symbol back to the declaration symbol.\n  // tslint:disable-next-line:no-bitwise\n  if (symbol && (symbol.flags & ts.SymbolFlags.Alias) !== 0) {\n    return checker.getAliasedSymbol(symbol);\n  }\n  return symbol;\n}\n\n\n/** Tries to resolve the name of the Material module that a node is imported from. */\nfunction resolveModuleName(node: ts.Identifier, typeChecker: ts.TypeChecker) {\n  // Get the symbol for the named binding element. Note that we cannot determine the\n  // value declaration based on the type of the element as types are not necessarily\n  // specific to a given secondary entry-point (e.g. exports with the type of \"string\")\n  // would resolve to the module types provided by TypeScript itself.\n  const symbol = getDeclarationSymbolOfNode(node, typeChecker);\n\n  // If the symbol can't be found, or no declaration could be found within\n  // the symbol, add failure to report that the given symbol can't be found.\n  if (!symbol ||\n      !(symbol.valueDeclaration || (symbol.declarations && symbol.declarations.length !== 0))) {\n    return null;\n  }\n\n  // The filename for the source file of the node that contains the\n  // first declaration of the symbol. All symbol declarations must be\n  // part of a defining node, so parent can be asserted to be defined.\n  const resolvedNode = symbol.valueDeclaration || symbol.declarations[0];\n  const sourceFile = resolvedNode.getSourceFile().fileName;\n\n  // File the module the symbol belongs to from a regex match of the\n  // filename. This will always match since only \"@angular/material\"\n  // elements are analyzed.\n  const matches = sourceFile.match(ANGULAR_MATERIAL_FILEPATH_REGEX);\n  return matches ? matches[1] : null;\n}\n"]}
@@ -20,3 +20,9 @@ export declare const cdkMixins: Record<string, string>;
20
20
  * and which should be replaced with their values.
21
21
  */
22
22
  export declare const removedMaterialVariables: Record<string, string>;
23
+ /**
24
+ * Material variables **without a `mat-` prefix** that have been removed from the public API
25
+ * and which should be replaced with their values. These should be migrated only when there's a
26
+ * Material import, because their names could conflict with other variables in the user's app.
27
+ */
28
+ export declare const unprefixedRemovedVariables: Record<string, string>;
@@ -0,0 +1,206 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.unprefixedRemovedVariables = exports.removedMaterialVariables = exports.cdkMixins = exports.cdkVariables = exports.materialVariables = exports.materialFunctions = exports.materialMixins = void 0;
11
+ /** Mapping of Material mixins that should be renamed. */
12
+ exports.materialMixins = {
13
+ 'mat-core': 'core',
14
+ 'mat-core-color': 'core-color',
15
+ 'mat-core-theme': 'core-theme',
16
+ 'angular-material-theme': 'all-component-themes',
17
+ 'angular-material-typography': 'all-component-typographies',
18
+ 'angular-material-color': 'all-component-colors',
19
+ 'mat-base-typography': 'typography-hierarchy',
20
+ 'mat-typography-level-to-styles': 'typography-level',
21
+ 'mat-elevation': 'elevation',
22
+ 'mat-overridable-elevation': 'overridable-elevation',
23
+ 'mat-elevation-transition': 'elevation-transition',
24
+ 'mat-ripple': 'ripple',
25
+ 'mat-ripple-color': 'ripple-color',
26
+ 'mat-ripple-theme': 'ripple-theme',
27
+ 'mat-strong-focus-indicators': 'strong-focus-indicators',
28
+ 'mat-strong-focus-indicators-color': 'strong-focus-indicators-color',
29
+ 'mat-strong-focus-indicators-theme': 'strong-focus-indicators-theme',
30
+ 'mat-font-shorthand': 'font-shorthand',
31
+ // The expansion panel is a special case, because the package is called `expansion`, but the
32
+ // mixins were prefixed with `expansion-panel`. This was corrected by the Sass module migration.
33
+ 'mat-expansion-panel-theme': 'expansion-theme',
34
+ 'mat-expansion-panel-color': 'expansion-color',
35
+ 'mat-expansion-panel-typography': 'expansion-typography',
36
+ };
37
+ // The component themes all follow the same pattern so we can spare ourselves some typing.
38
+ [
39
+ 'option', 'optgroup', 'pseudo-checkbox', 'autocomplete', 'badge', 'bottom-sheet', 'button',
40
+ 'button-toggle', 'card', 'checkbox', 'chips', 'divider', 'table', 'datepicker', 'dialog',
41
+ 'grid-list', 'icon', 'input', 'list', 'menu', 'paginator', 'progress-bar', 'progress-spinner',
42
+ 'radio', 'select', 'sidenav', 'slide-toggle', 'slider', 'stepper', 'sort', 'tabs', 'toolbar',
43
+ 'tooltip', 'snack-bar', 'form-field', 'tree'
44
+ ].forEach(name => {
45
+ exports.materialMixins[`mat-${name}-theme`] = `${name}-theme`;
46
+ exports.materialMixins[`mat-${name}-color`] = `${name}-color`;
47
+ exports.materialMixins[`mat-${name}-typography`] = `${name}-typography`;
48
+ });
49
+ /** Mapping of Material functions that should be renamed. */
50
+ exports.materialFunctions = {
51
+ 'mat-color': 'get-color-from-palette',
52
+ 'mat-contrast': 'get-contrast-color-from-palette',
53
+ 'mat-palette': 'define-palette',
54
+ 'mat-dark-theme': 'define-dark-theme',
55
+ 'mat-light-theme': 'define-light-theme',
56
+ 'mat-typography-level': 'define-typography-level',
57
+ 'mat-typography-config': 'define-typography-config',
58
+ 'mat-font-size': 'font-size',
59
+ 'mat-line-height': 'line-height',
60
+ 'mat-font-weight': 'font-weight',
61
+ 'mat-letter-spacing': 'letter-spacing',
62
+ 'mat-font-family': 'font-family',
63
+ };
64
+ /** Mapping of Material variables that should be renamed. */
65
+ exports.materialVariables = {
66
+ 'mat-light-theme-background': 'light-theme-background-palette',
67
+ 'mat-dark-theme-background': 'dark-theme-background-palette',
68
+ 'mat-light-theme-foreground': 'light-theme-foreground-palette',
69
+ 'mat-dark-theme-foreground': 'dark-theme-foreground-palette',
70
+ };
71
+ // The palettes all follow the same pattern.
72
+ [
73
+ 'red', 'pink', 'indigo', 'purple', 'deep-purple', 'blue', 'light-blue', 'cyan', 'teal', 'green',
74
+ 'light-green', 'lime', 'yellow', 'amber', 'orange', 'deep-orange', 'brown', 'grey', 'gray',
75
+ 'blue-grey', 'blue-gray'
76
+ ].forEach(name => exports.materialVariables[`mat-${name}`] = `${name}-palette`);
77
+ /** Mapping of CDK variables that should be renamed. */
78
+ exports.cdkVariables = {
79
+ 'cdk-z-index-overlay-container': 'overlay-container-z-index',
80
+ 'cdk-z-index-overlay': 'overlay-z-index',
81
+ 'cdk-z-index-overlay-backdrop': 'overlay-backdrop-z-index',
82
+ 'cdk-overlay-dark-backdrop-background': 'overlay-backdrop-color',
83
+ };
84
+ /** Mapping of CDK mixins that should be renamed. */
85
+ exports.cdkMixins = {
86
+ 'cdk-overlay': 'overlay',
87
+ 'cdk-a11y': 'a11y-visually-hidden',
88
+ 'cdk-high-contrast': 'high-contrast',
89
+ 'cdk-text-field-autofill-color': 'text-field-autofill-color',
90
+ // This one was split up into two mixins which is trickier to
91
+ // migrate so for now we forward to the deprecated variant.
92
+ 'cdk-text-field': 'text-field',
93
+ };
94
+ /**
95
+ * Material variables that have been removed from the public API
96
+ * and which should be replaced with their values.
97
+ */
98
+ exports.removedMaterialVariables = {
99
+ // Note: there's also a usage of a variable called `$pi`, but the name is short enough that
100
+ // it matches things like `$mat-pink`. Don't migrate it since it's unlikely to be used.
101
+ 'mat-xsmall': 'max-width: 599px',
102
+ 'mat-small': 'max-width: 959px',
103
+ 'mat-toggle-padding': '8px',
104
+ 'mat-toggle-size': '20px',
105
+ 'mat-linear-out-slow-in-timing-function': 'cubic-bezier(0, 0, 0.2, 0.1)',
106
+ 'mat-fast-out-slow-in-timing-function': 'cubic-bezier(0.4, 0, 0.2, 1)',
107
+ 'mat-fast-out-linear-in-timing-function': 'cubic-bezier(0.4, 0, 1, 1)',
108
+ 'mat-elevation-transition-duration': '280ms',
109
+ 'mat-elevation-transition-timing-function': 'cubic-bezier(0.4, 0, 0.2, 1)',
110
+ 'mat-elevation-color': '#000',
111
+ 'mat-elevation-opacity': '1',
112
+ 'mat-elevation-prefix': `'mat-elevation-z'`,
113
+ 'mat-ripple-color-opacity': '0.1',
114
+ 'mat-badge-font-size': '12px',
115
+ 'mat-badge-font-weight': '600',
116
+ 'mat-badge-default-size': '22px',
117
+ 'mat-badge-small-size': '16px',
118
+ 'mat-badge-large-size': '28px',
119
+ 'mat-button-toggle-standard-height': '48px',
120
+ 'mat-button-toggle-standard-minimum-height': '24px',
121
+ 'mat-button-toggle-standard-maximum-height': '48px',
122
+ 'mat-chip-remove-font-size': '18px',
123
+ 'mat-datepicker-selected-today-box-shadow-width': '1px',
124
+ 'mat-datepicker-selected-fade-amount': '0.6',
125
+ 'mat-datepicker-range-fade-amount': '0.2',
126
+ 'mat-datepicker-today-fade-amount': '0.2',
127
+ 'mat-calendar-body-font-size': '13px',
128
+ 'mat-calendar-weekday-table-font-size': '11px',
129
+ 'mat-expansion-panel-header-collapsed-height': '48px',
130
+ 'mat-expansion-panel-header-collapsed-minimum-height': '36px',
131
+ 'mat-expansion-panel-header-collapsed-maximum-height': '48px',
132
+ 'mat-expansion-panel-header-expanded-height': '64px',
133
+ 'mat-expansion-panel-header-expanded-minimum-height': '48px',
134
+ 'mat-expansion-panel-header-expanded-maximum-height': '64px',
135
+ 'mat-expansion-panel-header-transition': '225ms cubic-bezier(0.4, 0, 0.2, 1)',
136
+ 'mat-paginator-height': '56px',
137
+ 'mat-paginator-minimum-height': '40px',
138
+ 'mat-paginator-maximum-height': '56px',
139
+ 'mat-stepper-header-height': '72px',
140
+ 'mat-stepper-header-minimum-height': '42px',
141
+ 'mat-stepper-header-maximum-height': '72px',
142
+ 'mat-stepper-label-header-height': '24px',
143
+ 'mat-stepper-label-position-bottom-top-gap': '16px',
144
+ 'mat-stepper-label-min-width': '50px',
145
+ 'mat-vertical-stepper-content-margin': '36px',
146
+ 'mat-stepper-side-gap': '24px',
147
+ 'mat-stepper-line-width': '1px',
148
+ 'mat-stepper-line-gap': '8px',
149
+ 'mat-step-sub-label-font-size': '12px',
150
+ 'mat-step-header-icon-size': '16px',
151
+ 'mat-toolbar-minimum-height': '44px',
152
+ 'mat-toolbar-height-desktop': '64px',
153
+ 'mat-toolbar-maximum-height-desktop': '64px',
154
+ 'mat-toolbar-minimum-height-desktop': '44px',
155
+ 'mat-toolbar-height-mobile': '56px',
156
+ 'mat-toolbar-maximum-height-mobile': '56px',
157
+ 'mat-toolbar-minimum-height-mobile': '44px',
158
+ 'mat-tooltip-target-height': '22px',
159
+ 'mat-tooltip-font-size': '10px',
160
+ 'mat-tooltip-vertical-padding': '6px',
161
+ 'mat-tooltip-handset-target-height': '30px',
162
+ 'mat-tooltip-handset-font-size': '14px',
163
+ 'mat-tooltip-handset-vertical-padding': '8px',
164
+ 'mat-tree-node-height': '48px',
165
+ 'mat-tree-node-minimum-height': '24px',
166
+ 'mat-tree-node-maximum-height': '48px',
167
+ };
168
+ /**
169
+ * Material variables **without a `mat-` prefix** that have been removed from the public API
170
+ * and which should be replaced with their values. These should be migrated only when there's a
171
+ * Material import, because their names could conflict with other variables in the user's app.
172
+ */
173
+ exports.unprefixedRemovedVariables = {
174
+ 'z-index-fab': '20',
175
+ 'z-index-drawer': '100',
176
+ 'ease-in-out-curve-function': 'cubic-bezier(0.35, 0, 0.25, 1)',
177
+ 'swift-ease-out-duration': '400ms',
178
+ 'swift-ease-out-timing-function': 'cubic-bezier(0.25, 0.8, 0.25, 1)',
179
+ 'swift-ease-out': 'all 400ms cubic-bezier(0.25, 0.8, 0.25, 1)',
180
+ 'swift-ease-in-duration': '300ms',
181
+ 'swift-ease-in-timing-function': 'cubic-bezier(0.55, 0, 0.55, 0.2)',
182
+ 'swift-ease-in': 'all 300ms cubic-bezier(0.55, 0, 0.55, 0.2)',
183
+ 'swift-ease-in-out-duration': '500ms',
184
+ 'swift-ease-in-out-timing-function': 'cubic-bezier(0.35, 0, 0.25, 1)',
185
+ 'swift-ease-in-out': 'all 500ms cubic-bezier(0.35, 0, 0.25, 1)',
186
+ 'swift-linear-duration': '80ms',
187
+ 'swift-linear-timing-function': 'linear',
188
+ 'swift-linear': 'all 80ms linear',
189
+ 'black-87-opacity': 'rgba(black, 0.87)',
190
+ 'white-87-opacity': 'rgba(white, 0.87)',
191
+ 'black-12-opacity': 'rgba(black, 0.12)',
192
+ 'white-12-opacity': 'rgba(white, 0.12)',
193
+ 'black-6-opacity': 'rgba(black, 0.06)',
194
+ 'white-6-opacity': 'rgba(white, 0.06)',
195
+ 'dark-primary-text': 'rgba(black, 0.87)',
196
+ 'dark-secondary-text': 'rgba(black, 0.54)',
197
+ 'dark-disabled-text': 'rgba(black, 0.38)',
198
+ 'dark-dividers': 'rgba(black, 0.12)',
199
+ 'dark-focused': 'rgba(black, 0.12)',
200
+ 'light-primary-text': 'white',
201
+ 'light-secondary-text': 'rgba(white, 0.7)',
202
+ 'light-disabled-text': 'rgba(white, 0.5)',
203
+ 'light-dividers': 'rgba(white, 0.12)',
204
+ 'light-focused': 'rgba(white, 0.12)',
205
+ };
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../../../../../../../src/material/schematics/ng-update/migrations/theming-api-v12/config.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\n/** Mapping of Material mixins that should be renamed. */\nexport const materialMixins: Record<string, string> = {\n  'mat-core': 'core',\n  'mat-core-color': 'core-color',\n  'mat-core-theme': 'core-theme',\n  'angular-material-theme': 'all-component-themes',\n  'angular-material-typography': 'all-component-typographies',\n  'angular-material-color': 'all-component-colors',\n  'mat-base-typography': 'typography-hierarchy',\n  'mat-typography-level-to-styles': 'typography-level',\n  'mat-elevation': 'elevation',\n  'mat-overridable-elevation': 'overridable-elevation',\n  'mat-elevation-transition': 'elevation-transition',\n  'mat-ripple': 'ripple',\n  'mat-ripple-color': 'ripple-color',\n  'mat-ripple-theme': 'ripple-theme',\n  'mat-strong-focus-indicators': 'strong-focus-indicators',\n  'mat-strong-focus-indicators-color': 'strong-focus-indicators-color',\n  'mat-strong-focus-indicators-theme': 'strong-focus-indicators-theme',\n  'mat-font-shorthand': 'font-shorthand',\n  // The expansion panel is a special case, because the package is called `expansion`, but the\n  // mixins were prefixed with `expansion-panel`. This was corrected by the Sass module migration.\n  'mat-expansion-panel-theme': 'expansion-theme',\n  'mat-expansion-panel-color': 'expansion-color',\n  'mat-expansion-panel-typography': 'expansion-typography',\n};\n\n// The component themes all follow the same pattern so we can spare ourselves some typing.\n[\n  'option', 'optgroup', 'pseudo-checkbox', 'autocomplete', 'badge', 'bottom-sheet', 'button',\n  'button-toggle', 'card', 'checkbox', 'chips', 'divider', 'table', 'datepicker', 'dialog',\n  'grid-list', 'icon', 'input', 'list', 'menu', 'paginator', 'progress-bar', 'progress-spinner',\n  'radio', 'select', 'sidenav', 'slide-toggle', 'slider', 'stepper', 'sort', 'tabs', 'toolbar',\n  'tooltip', 'snack-bar', 'form-field', 'tree'\n].forEach(name => {\n  materialMixins[`mat-${name}-theme`] = `${name}-theme`;\n  materialMixins[`mat-${name}-color`] = `${name}-color`;\n  materialMixins[`mat-${name}-typography`] = `${name}-typography`;\n});\n\n/** Mapping of Material functions that should be renamed. */\nexport const materialFunctions: Record<string, string> = {\n  'mat-color': 'get-color-from-palette',\n  'mat-contrast': 'get-contrast-color-from-palette',\n  'mat-palette': 'define-palette',\n  'mat-dark-theme': 'define-dark-theme',\n  'mat-light-theme': 'define-light-theme',\n  'mat-typography-level': 'define-typography-level',\n  'mat-typography-config': 'define-typography-config',\n  'mat-font-size': 'font-size',\n  'mat-line-height': 'line-height',\n  'mat-font-weight': 'font-weight',\n  'mat-letter-spacing': 'letter-spacing',\n  'mat-font-family': 'font-family',\n};\n\n/** Mapping of Material variables that should be renamed. */\nexport const materialVariables: Record<string, string> = {\n  'mat-light-theme-background': 'light-theme-background-palette',\n  'mat-dark-theme-background': 'dark-theme-background-palette',\n  'mat-light-theme-foreground': 'light-theme-foreground-palette',\n  'mat-dark-theme-foreground': 'dark-theme-foreground-palette',\n};\n\n// The palettes all follow the same pattern.\n[\n  'red', 'pink', 'indigo', 'purple', 'deep-purple', 'blue', 'light-blue', 'cyan', 'teal', 'green',\n  'light-green', 'lime', 'yellow', 'amber', 'orange', 'deep-orange', 'brown', 'grey', 'gray',\n  'blue-grey', 'blue-gray'\n].forEach(name => materialVariables[`mat-${name}`] = `${name}-palette`);\n\n/** Mapping of CDK variables that should be renamed. */\nexport const cdkVariables: Record<string, string> = {\n  'cdk-z-index-overlay-container': 'overlay-container-z-index',\n  'cdk-z-index-overlay': 'overlay-z-index',\n  'cdk-z-index-overlay-backdrop': 'overlay-backdrop-z-index',\n  'cdk-overlay-dark-backdrop-background': 'overlay-backdrop-color',\n};\n\n/** Mapping of CDK mixins that should be renamed. */\nexport const cdkMixins: Record<string, string> = {\n  'cdk-overlay': 'overlay',\n  'cdk-a11y': 'a11y-visually-hidden',\n  'cdk-high-contrast': 'high-contrast',\n  'cdk-text-field-autofill-color': 'text-field-autofill-color',\n  // This one was split up into two mixins which is trickier to\n  // migrate so for now we forward to the deprecated variant.\n  'cdk-text-field': 'text-field',\n};\n\n/**\n * Material variables that have been removed from the public API\n * and which should be replaced with their values.\n */\nexport const removedMaterialVariables: Record<string, string> = {\n  // Note: there's also a usage of a variable called `$pi`, but the name is short enough that\n  // it matches things like `$mat-pink`. Don't migrate it since it's unlikely to be used.\n  'mat-xsmall': 'max-width: 599px',\n  'mat-small': 'max-width: 959px',\n  'mat-toggle-padding': '8px',\n  'mat-toggle-size': '20px',\n  'mat-linear-out-slow-in-timing-function': 'cubic-bezier(0, 0, 0.2, 0.1)',\n  'mat-fast-out-slow-in-timing-function': 'cubic-bezier(0.4, 0, 0.2, 1)',\n  'mat-fast-out-linear-in-timing-function': 'cubic-bezier(0.4, 0, 1, 1)',\n  'mat-elevation-transition-duration': '280ms',\n  'mat-elevation-transition-timing-function': 'cubic-bezier(0.4, 0, 0.2, 1)',\n  'mat-elevation-color': '#000',\n  'mat-elevation-opacity': '1',\n  'mat-elevation-prefix': `'mat-elevation-z'`,\n  'mat-ripple-color-opacity': '0.1',\n  'mat-badge-font-size': '12px',\n  'mat-badge-font-weight': '600',\n  'mat-badge-default-size': '22px',\n  'mat-badge-small-size': '16px',\n  'mat-badge-large-size': '28px',\n  'mat-button-toggle-standard-height': '48px',\n  'mat-button-toggle-standard-minimum-height': '24px',\n  'mat-button-toggle-standard-maximum-height': '48px',\n  'mat-chip-remove-font-size': '18px',\n  'mat-datepicker-selected-today-box-shadow-width': '1px',\n  'mat-datepicker-selected-fade-amount': '0.6',\n  'mat-datepicker-range-fade-amount': '0.2',\n  'mat-datepicker-today-fade-amount': '0.2',\n  'mat-calendar-body-font-size': '13px',\n  'mat-calendar-weekday-table-font-size': '11px',\n  'mat-expansion-panel-header-collapsed-height': '48px',\n  'mat-expansion-panel-header-collapsed-minimum-height': '36px',\n  'mat-expansion-panel-header-collapsed-maximum-height': '48px',\n  'mat-expansion-panel-header-expanded-height': '64px',\n  'mat-expansion-panel-header-expanded-minimum-height': '48px',\n  'mat-expansion-panel-header-expanded-maximum-height': '64px',\n  'mat-expansion-panel-header-transition': '225ms cubic-bezier(0.4, 0, 0.2, 1)',\n  'mat-paginator-height': '56px',\n  'mat-paginator-minimum-height': '40px',\n  'mat-paginator-maximum-height': '56px',\n  'mat-stepper-header-height': '72px',\n  'mat-stepper-header-minimum-height': '42px',\n  'mat-stepper-header-maximum-height': '72px',\n  'mat-stepper-label-header-height': '24px',\n  'mat-stepper-label-position-bottom-top-gap': '16px',\n  'mat-stepper-label-min-width': '50px',\n  'mat-vertical-stepper-content-margin': '36px',\n  'mat-stepper-side-gap': '24px',\n  'mat-stepper-line-width': '1px',\n  'mat-stepper-line-gap': '8px',\n  'mat-step-sub-label-font-size': '12px',\n  'mat-step-header-icon-size': '16px',\n  'mat-toolbar-minimum-height': '44px',\n  'mat-toolbar-height-desktop': '64px',\n  'mat-toolbar-maximum-height-desktop': '64px',\n  'mat-toolbar-minimum-height-desktop': '44px',\n  'mat-toolbar-height-mobile': '56px',\n  'mat-toolbar-maximum-height-mobile': '56px',\n  'mat-toolbar-minimum-height-mobile': '44px',\n  'mat-tooltip-target-height': '22px',\n  'mat-tooltip-font-size': '10px',\n  'mat-tooltip-vertical-padding': '6px',\n  'mat-tooltip-handset-target-height': '30px',\n  'mat-tooltip-handset-font-size': '14px',\n  'mat-tooltip-handset-vertical-padding': '8px',\n  'mat-tree-node-height': '48px',\n  'mat-tree-node-minimum-height': '24px',\n  'mat-tree-node-maximum-height': '48px',\n};\n\n/**\n * Material variables **without a `mat-` prefix** that have been removed from the public API\n * and which should be replaced with their values. These should be migrated only when there's a\n * Material import, because their names could conflict with other variables in the user's app.\n */\nexport const unprefixedRemovedVariables: Record<string, string> = {\n  'z-index-fab': '20',\n  'z-index-drawer': '100',\n  'ease-in-out-curve-function': 'cubic-bezier(0.35, 0, 0.25, 1)',\n  'swift-ease-out-duration': '400ms',\n  'swift-ease-out-timing-function': 'cubic-bezier(0.25, 0.8, 0.25, 1)',\n  'swift-ease-out': 'all 400ms cubic-bezier(0.25, 0.8, 0.25, 1)',\n  'swift-ease-in-duration': '300ms',\n  'swift-ease-in-timing-function': 'cubic-bezier(0.55, 0, 0.55, 0.2)',\n  'swift-ease-in': 'all 300ms cubic-bezier(0.55, 0, 0.55, 0.2)',\n  'swift-ease-in-out-duration': '500ms',\n  'swift-ease-in-out-timing-function': 'cubic-bezier(0.35, 0, 0.25, 1)',\n  'swift-ease-in-out': 'all 500ms cubic-bezier(0.35, 0, 0.25, 1)',\n  'swift-linear-duration': '80ms',\n  'swift-linear-timing-function': 'linear',\n  'swift-linear': 'all 80ms linear',\n  'black-87-opacity': 'rgba(black, 0.87)',\n  'white-87-opacity': 'rgba(white, 0.87)',\n  'black-12-opacity': 'rgba(black, 0.12)',\n  'white-12-opacity': 'rgba(white, 0.12)',\n  'black-6-opacity': 'rgba(black, 0.06)',\n  'white-6-opacity': 'rgba(white, 0.06)',\n  'dark-primary-text': 'rgba(black, 0.87)',\n  'dark-secondary-text': 'rgba(black, 0.54)',\n  'dark-disabled-text': 'rgba(black, 0.38)',\n  'dark-dividers': 'rgba(black, 0.12)',\n  'dark-focused': 'rgba(black, 0.12)',\n  'light-primary-text': 'white',\n  'light-secondary-text': 'rgba(white, 0.7)',\n  'light-disabled-text': 'rgba(white, 0.5)',\n  'light-dividers': 'rgba(white, 0.12)',\n  'light-focused': 'rgba(white, 0.12)',\n};\n"]}