@angular/material 13.1.0-rc.0 → 13.1.3

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