@depup/angular__material 21.2.2-depup.19

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 (578) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +31 -0
  3. package/_index.scss +145 -0
  4. package/autocomplete/_autocomplete-theme.scss +76 -0
  5. package/autocomplete/_m2-autocomplete.scss +19 -0
  6. package/autocomplete/_m3-autocomplete.scss +26 -0
  7. package/badge/_badge-theme.scss +106 -0
  8. package/badge/_m2-badge.scss +73 -0
  9. package/badge/_m3-badge.scss +52 -0
  10. package/bottom-sheet/_bottom-sheet-theme.scss +76 -0
  11. package/bottom-sheet/_m2-bottom-sheet.scss +24 -0
  12. package/bottom-sheet/_m3-bottom-sheet.scss +25 -0
  13. package/button/_button-theme.scss +113 -0
  14. package/button/_fab-theme.scss +111 -0
  15. package/button/_icon-button-theme.scss +136 -0
  16. package/button/_m2-button.scss +194 -0
  17. package/button/_m2-fab.scss +101 -0
  18. package/button/_m2-icon-button.scss +59 -0
  19. package/button/_m3-button.scss +170 -0
  20. package/button/_m3-fab.scss +92 -0
  21. package/button/_m3-icon-button.scss +54 -0
  22. package/button-toggle/_button-toggle-theme.scss +93 -0
  23. package/button-toggle/_m2-button-toggle.scss +68 -0
  24. package/button-toggle/_m3-button-toggle.scss +72 -0
  25. package/card/_card-theme.scss +76 -0
  26. package/card/_m2-card.scss +39 -0
  27. package/card/_m3-card.scss +44 -0
  28. package/changes.json +10 -0
  29. package/checkbox/_checkbox-theme.scss +105 -0
  30. package/checkbox/_m2-checkbox.scss +78 -0
  31. package/checkbox/_m3-checkbox.scss +68 -0
  32. package/chips/_chips-theme.scss +115 -0
  33. package/chips/_m2-chip.scss +85 -0
  34. package/chips/_m3-chip.scss +81 -0
  35. package/core/_core-theme.scss +125 -0
  36. package/core/_core.scss +50 -0
  37. package/core/_m2-app.scss +24 -0
  38. package/core/_m3-app.scss +44 -0
  39. package/core/color/_all-color.scss +17 -0
  40. package/core/density/private/_all-density.scss +78 -0
  41. package/core/focus-indicators/_private.scss +126 -0
  42. package/core/m2/_index.scss +52 -0
  43. package/core/m2/_palette.scss +748 -0
  44. package/core/m2/_theming.scss +340 -0
  45. package/core/m2/_typography-utils.scss +81 -0
  46. package/core/m2/_typography.scss +388 -0
  47. package/core/option/_m2-optgroup.scss +21 -0
  48. package/core/option/_m2-option.scss +38 -0
  49. package/core/option/_m3-optgroup.scss +25 -0
  50. package/core/option/_m3-option.scss +37 -0
  51. package/core/option/_optgroup-theme.scss +76 -0
  52. package/core/option/_option-theme.scss +103 -0
  53. package/core/ripple/_m2-ripple.scss +17 -0
  54. package/core/ripple/_m3-ripple.scss +17 -0
  55. package/core/ripple/_ripple-theme.scss +75 -0
  56. package/core/ripple/_ripple.scss +56 -0
  57. package/core/selection/pseudo-checkbox/_m2-pseudo-checkbox.scss +32 -0
  58. package/core/selection/pseudo-checkbox/_m3-pseudo-checkbox.scss +34 -0
  59. package/core/selection/pseudo-checkbox/_pseudo-checkbox-common.scss +86 -0
  60. package/core/selection/pseudo-checkbox/_pseudo-checkbox-theme.scss +110 -0
  61. package/core/style/_checkbox-common.scss +11 -0
  62. package/core/style/_elevation.scss +208 -0
  63. package/core/style/_layout-common.scss +8 -0
  64. package/core/style/_private.scss +27 -0
  65. package/core/style/_sass-utils.scss +57 -0
  66. package/core/style/_validation.scss +52 -0
  67. package/core/style/_variables.scss +44 -0
  68. package/core/style/_vendor-prefixes.scss +56 -0
  69. package/core/theming/_all-theme.scss +168 -0
  70. package/core/theming/_color-api-backwards-compatibility.scss +159 -0
  71. package/core/theming/_config-validation.scss +174 -0
  72. package/core/theming/_definition.scss +141 -0
  73. package/core/theming/_inspection.scss +289 -0
  74. package/core/theming/_m2-inspection.scss +243 -0
  75. package/core/theming/_palettes.scss +1036 -0
  76. package/core/theming/_theming.scss +193 -0
  77. package/core/theming/_validation.scss +5 -0
  78. package/core/tokens/_classes.scss +398 -0
  79. package/core/tokens/_m2-utils.scss +25 -0
  80. package/core/tokens/_m3-tokens.scss +126 -0
  81. package/core/tokens/_m3-utils.scss +36 -0
  82. package/core/tokens/_system.scss +398 -0
  83. package/core/tokens/_token-utils.scss +119 -0
  84. package/core/tokens/m2/_index.scss +6 -0
  85. package/core/tokens/m2/_md-sys-color-internal.scss +11 -0
  86. package/core/tokens/m2/_md-sys-color.scss +123 -0
  87. package/core/tokens/m2/_md-sys-elevation.scss +10 -0
  88. package/core/tokens/m2/_md-sys-motion.scss +30 -0
  89. package/core/tokens/m2/_md-sys-shape.scss +16 -0
  90. package/core/tokens/m2/_md-sys-state.scss +8 -0
  91. package/core/tokens/m2/_md-sys-typescale.scss +68 -0
  92. package/core/tokens/m3/_index.scss +7 -0
  93. package/core/tokens/m3/_md-sys-color-internal.scss +11 -0
  94. package/core/tokens/m3/_md-sys-color.scss +118 -0
  95. package/core/tokens/m3/_md-sys-elevation.scss +15 -0
  96. package/core/tokens/m3/_md-sys-motion.scss +35 -0
  97. package/core/tokens/m3/_md-sys-shape.scss +21 -0
  98. package/core/tokens/m3/_md-sys-state.scss +13 -0
  99. package/core/tokens/m3/_md-sys-typescale-internal.scss +5 -0
  100. package/core/tokens/m3/_md-sys-typescale.scss +114 -0
  101. package/core/tokens/m3/_theme.scss +35 -0
  102. package/core/typography/_all-typography.scss +104 -0
  103. package/core/typography/_typography-utils.scss +31 -0
  104. package/core/typography/_typography.scss +269 -0
  105. package/core/typography/_versioning.scss +90 -0
  106. package/datepicker/_datepicker-theme.scss +132 -0
  107. package/datepicker/_m2-datepicker.scss +81 -0
  108. package/datepicker/_m3-datepicker.scss +74 -0
  109. package/dialog/_dialog-legacy-padding.scss +31 -0
  110. package/dialog/_dialog-theme.scss +76 -0
  111. package/dialog/_m2-dialog.scss +43 -0
  112. package/dialog/_m3-dialog.scss +47 -0
  113. package/divider/_divider-theme.scss +75 -0
  114. package/divider/_m2-divider.scss +17 -0
  115. package/divider/_m3-divider.scss +19 -0
  116. package/expansion/_expansion-theme.scss +76 -0
  117. package/expansion/_m2-expansion.scss +64 -0
  118. package/expansion/_m3-expansion.scss +61 -0
  119. package/fesm2022/_animation-chunk.mjs +22 -0
  120. package/fesm2022/_animation-chunk.mjs.map +1 -0
  121. package/fesm2022/_date-formats-chunk.mjs +86 -0
  122. package/fesm2022/_date-formats-chunk.mjs.map +1 -0
  123. package/fesm2022/_date-range-input-harness-chunk.mjs +322 -0
  124. package/fesm2022/_date-range-input-harness-chunk.mjs.map +1 -0
  125. package/fesm2022/_error-options-chunk.mjs +66 -0
  126. package/fesm2022/_error-options-chunk.mjs.map +1 -0
  127. package/fesm2022/_error-state-chunk.mjs +30 -0
  128. package/fesm2022/_error-state-chunk.mjs.map +1 -0
  129. package/fesm2022/_form-field-chunk.mjs +1351 -0
  130. package/fesm2022/_form-field-chunk.mjs.map +1 -0
  131. package/fesm2022/_icon-button-chunk.mjs +268 -0
  132. package/fesm2022/_icon-button-chunk.mjs.map +1 -0
  133. package/fesm2022/_icon-registry-chunk.mjs +368 -0
  134. package/fesm2022/_icon-registry-chunk.mjs.map +1 -0
  135. package/fesm2022/_input-harness-chunk.mjs +67 -0
  136. package/fesm2022/_input-harness-chunk.mjs.map +1 -0
  137. package/fesm2022/_input-value-accessor-chunk.mjs +6 -0
  138. package/fesm2022/_input-value-accessor-chunk.mjs.map +1 -0
  139. package/fesm2022/_internal-form-field-chunk.mjs +67 -0
  140. package/fesm2022/_internal-form-field-chunk.mjs.map +1 -0
  141. package/fesm2022/_line-chunk.mjs +99 -0
  142. package/fesm2022/_line-chunk.mjs.map +1 -0
  143. package/fesm2022/_option-chunk.mjs +385 -0
  144. package/fesm2022/_option-chunk.mjs.map +1 -0
  145. package/fesm2022/_option-harness-chunk.mjs +30 -0
  146. package/fesm2022/_option-harness-chunk.mjs.map +1 -0
  147. package/fesm2022/_option-module-chunk.mjs +48 -0
  148. package/fesm2022/_option-module-chunk.mjs.map +1 -0
  149. package/fesm2022/_pseudo-checkbox-chunk.mjs +88 -0
  150. package/fesm2022/_pseudo-checkbox-chunk.mjs.map +1 -0
  151. package/fesm2022/_pseudo-checkbox-module-chunk.mjs +46 -0
  152. package/fesm2022/_pseudo-checkbox-module-chunk.mjs.map +1 -0
  153. package/fesm2022/_public-api-chunk.mjs +84 -0
  154. package/fesm2022/_public-api-chunk.mjs.map +1 -0
  155. package/fesm2022/_ripple-chunk.mjs +544 -0
  156. package/fesm2022/_ripple-chunk.mjs.map +1 -0
  157. package/fesm2022/_ripple-loader-chunk.mjs +144 -0
  158. package/fesm2022/_ripple-loader-chunk.mjs.map +1 -0
  159. package/fesm2022/_ripple-module-chunk.mjs +46 -0
  160. package/fesm2022/_ripple-module-chunk.mjs.map +1 -0
  161. package/fesm2022/_structural-styles-chunk.mjs +45 -0
  162. package/fesm2022/_structural-styles-chunk.mjs.map +1 -0
  163. package/fesm2022/_tooltip-chunk.mjs +848 -0
  164. package/fesm2022/_tooltip-chunk.mjs.map +1 -0
  165. package/fesm2022/autocomplete-testing.mjs +75 -0
  166. package/fesm2022/autocomplete-testing.mjs.map +1 -0
  167. package/fesm2022/autocomplete.mjs +1068 -0
  168. package/fesm2022/autocomplete.mjs.map +1 -0
  169. package/fesm2022/badge-testing.mjs +48 -0
  170. package/fesm2022/badge-testing.mjs.map +1 -0
  171. package/fesm2022/badge.mjs +357 -0
  172. package/fesm2022/badge.mjs.map +1 -0
  173. package/fesm2022/bottom-sheet-testing.mjs +17 -0
  174. package/fesm2022/bottom-sheet-testing.mjs.map +1 -0
  175. package/fesm2022/bottom-sheet.mjs +390 -0
  176. package/fesm2022/bottom-sheet.mjs.map +1 -0
  177. package/fesm2022/button-testing.mjs +81 -0
  178. package/fesm2022/button-testing.mjs.map +1 -0
  179. package/fesm2022/button-toggle-testing.mjs +87 -0
  180. package/fesm2022/button-toggle-testing.mjs.map +1 -0
  181. package/fesm2022/button-toggle.mjs +789 -0
  182. package/fesm2022/button-toggle.mjs.map +1 -0
  183. package/fesm2022/button.mjs +308 -0
  184. package/fesm2022/button.mjs.map +1 -0
  185. package/fesm2022/card-testing.mjs +29 -0
  186. package/fesm2022/card-testing.mjs.map +1 -0
  187. package/fesm2022/card.mjs +615 -0
  188. package/fesm2022/card.mjs.map +1 -0
  189. package/fesm2022/checkbox-testing.mjs +79 -0
  190. package/fesm2022/checkbox-testing.mjs.map +1 -0
  191. package/fesm2022/checkbox.mjs +551 -0
  192. package/fesm2022/checkbox.mjs.map +1 -0
  193. package/fesm2022/chips-testing.mjs +239 -0
  194. package/fesm2022/chips-testing.mjs.map +1 -0
  195. package/fesm2022/chips.mjs +2663 -0
  196. package/fesm2022/chips.mjs.map +1 -0
  197. package/fesm2022/core-testing.mjs +22 -0
  198. package/fesm2022/core-testing.mjs.map +1 -0
  199. package/fesm2022/core.mjs +408 -0
  200. package/fesm2022/core.mjs.map +1 -0
  201. package/fesm2022/datepicker-testing.mjs +26 -0
  202. package/fesm2022/datepicker-testing.mjs.map +1 -0
  203. package/fesm2022/datepicker.mjs +5015 -0
  204. package/fesm2022/datepicker.mjs.map +1 -0
  205. package/fesm2022/dialog-testing.mjs +123 -0
  206. package/fesm2022/dialog-testing.mjs.map +1 -0
  207. package/fesm2022/dialog.mjs +873 -0
  208. package/fesm2022/dialog.mjs.map +1 -0
  209. package/fesm2022/divider-testing.mjs +17 -0
  210. package/fesm2022/divider-testing.mjs.map +1 -0
  211. package/fesm2022/divider.mjs +132 -0
  212. package/fesm2022/divider.mjs.map +1 -0
  213. package/fesm2022/expansion-testing.mjs +87 -0
  214. package/fesm2022/expansion-testing.mjs.map +1 -0
  215. package/fesm2022/expansion.mjs +749 -0
  216. package/fesm2022/expansion.mjs.map +1 -0
  217. package/fesm2022/form-field-testing-control.mjs +24 -0
  218. package/fesm2022/form-field-testing-control.mjs.map +1 -0
  219. package/fesm2022/form-field-testing.mjs +135 -0
  220. package/fesm2022/form-field-testing.mjs.map +1 -0
  221. package/fesm2022/form-field.mjs +57 -0
  222. package/fesm2022/form-field.mjs.map +1 -0
  223. package/fesm2022/grid-list-testing.mjs +80 -0
  224. package/fesm2022/grid-list-testing.mjs.map +1 -0
  225. package/fesm2022/grid-list.mjs +604 -0
  226. package/fesm2022/grid-list.mjs.map +1 -0
  227. package/fesm2022/icon-testing.mjs +172 -0
  228. package/fesm2022/icon-testing.mjs.map +1 -0
  229. package/fesm2022/icon.mjs +366 -0
  230. package/fesm2022/icon.mjs.map +1 -0
  231. package/fesm2022/input-testing.mjs +73 -0
  232. package/fesm2022/input-testing.mjs.map +1 -0
  233. package/fesm2022/input.mjs +495 -0
  234. package/fesm2022/input.mjs.map +1 -0
  235. package/fesm2022/list-testing.mjs +295 -0
  236. package/fesm2022/list-testing.mjs.map +1 -0
  237. package/fesm2022/list.mjs +1604 -0
  238. package/fesm2022/list.mjs.map +1 -0
  239. package/fesm2022/material.mjs +4 -0
  240. package/fesm2022/material.mjs.map +1 -0
  241. package/fesm2022/menu-testing.mjs +174 -0
  242. package/fesm2022/menu-testing.mjs.map +1 -0
  243. package/fesm2022/menu.mjs +1421 -0
  244. package/fesm2022/menu.mjs.map +1 -0
  245. package/fesm2022/paginator-testing.mjs +69 -0
  246. package/fesm2022/paginator-testing.mjs.map +1 -0
  247. package/fesm2022/paginator.mjs +445 -0
  248. package/fesm2022/paginator.mjs.map +1 -0
  249. package/fesm2022/progress-bar-testing.mjs +20 -0
  250. package/fesm2022/progress-bar-testing.mjs.map +1 -0
  251. package/fesm2022/progress-bar.mjs +247 -0
  252. package/fesm2022/progress-bar.mjs.map +1 -0
  253. package/fesm2022/progress-spinner-testing.mjs +21 -0
  254. package/fesm2022/progress-spinner-testing.mjs.map +1 -0
  255. package/fesm2022/progress-spinner.mjs +258 -0
  256. package/fesm2022/progress-spinner.mjs.map +1 -0
  257. package/fesm2022/radio-testing.mjs +143 -0
  258. package/fesm2022/radio-testing.mjs.map +1 -0
  259. package/fesm2022/radio.mjs +751 -0
  260. package/fesm2022/radio.mjs.map +1 -0
  261. package/fesm2022/select-testing.mjs +92 -0
  262. package/fesm2022/select-testing.mjs.map +1 -0
  263. package/fesm2022/select.mjs +1181 -0
  264. package/fesm2022/select.mjs.map +1 -0
  265. package/fesm2022/sidenav-testing.mjs +80 -0
  266. package/fesm2022/sidenav-testing.mjs.map +1 -0
  267. package/fesm2022/sidenav.mjs +1151 -0
  268. package/fesm2022/sidenav.mjs.map +1 -0
  269. package/fesm2022/slide-toggle-testing.mjs +68 -0
  270. package/fesm2022/slide-toggle-testing.mjs.map +1 -0
  271. package/fesm2022/slide-toggle.mjs +403 -0
  272. package/fesm2022/slide-toggle.mjs.map +1 -0
  273. package/fesm2022/slider-testing.mjs +105 -0
  274. package/fesm2022/slider-testing.mjs.map +1 -0
  275. package/fesm2022/slider.mjs +1720 -0
  276. package/fesm2022/slider.mjs.map +1 -0
  277. package/fesm2022/snack-bar-testing.mjs +47 -0
  278. package/fesm2022/snack-bar-testing.mjs.map +1 -0
  279. package/fesm2022/snack-bar.mjs +820 -0
  280. package/fesm2022/snack-bar.mjs.map +1 -0
  281. package/fesm2022/sort-testing.mjs +55 -0
  282. package/fesm2022/sort-testing.mjs.map +1 -0
  283. package/fesm2022/sort.mjs +470 -0
  284. package/fesm2022/sort.mjs.map +1 -0
  285. package/fesm2022/stepper-testing.mjs +99 -0
  286. package/fesm2022/stepper-testing.mjs.map +1 -0
  287. package/fesm2022/stepper.mjs +900 -0
  288. package/fesm2022/stepper.mjs.map +1 -0
  289. package/fesm2022/table-testing.mjs +152 -0
  290. package/fesm2022/table-testing.mjs.map +1 -0
  291. package/fesm2022/table.mjs +1151 -0
  292. package/fesm2022/table.mjs.map +1 -0
  293. package/fesm2022/tabs-testing.mjs +144 -0
  294. package/fesm2022/tabs-testing.mjs.map +1 -0
  295. package/fesm2022/tabs.mjs +2435 -0
  296. package/fesm2022/tabs.mjs.map +1 -0
  297. package/fesm2022/timepicker-testing.mjs +128 -0
  298. package/fesm2022/timepicker-testing.mjs.map +1 -0
  299. package/fesm2022/timepicker.mjs +1284 -0
  300. package/fesm2022/timepicker.mjs.map +1 -0
  301. package/fesm2022/toolbar-testing.mjs +26 -0
  302. package/fesm2022/toolbar-testing.mjs.map +1 -0
  303. package/fesm2022/toolbar.mjs +182 -0
  304. package/fesm2022/toolbar.mjs.map +1 -0
  305. package/fesm2022/tooltip-testing.mjs +48 -0
  306. package/fesm2022/tooltip-testing.mjs.map +1 -0
  307. package/fesm2022/tooltip.mjs +58 -0
  308. package/fesm2022/tooltip.mjs.map +1 -0
  309. package/fesm2022/tree-testing.mjs +104 -0
  310. package/fesm2022/tree-testing.mjs.map +1 -0
  311. package/fesm2022/tree.mjs +681 -0
  312. package/fesm2022/tree.mjs.map +1 -0
  313. package/form-field/_form-field-theme.scss +96 -0
  314. package/form-field/_m2-form-field.scss +226 -0
  315. package/form-field/_m3-form-field.scss +137 -0
  316. package/grid-list/_grid-list-theme.scss +76 -0
  317. package/grid-list/_m2-grid-list.scss +21 -0
  318. package/grid-list/_m3-grid-list.scss +20 -0
  319. package/icon/_icon-theme.scss +109 -0
  320. package/icon/_m2-icon.scss +15 -0
  321. package/icon/_m3-icon.scss +21 -0
  322. package/input/_input-theme.scss +36 -0
  323. package/list/_list-theme.scss +201 -0
  324. package/list/_m2-list.scss +92 -0
  325. package/list/_m3-list.scss +93 -0
  326. package/menu/_m2-menu.scss +44 -0
  327. package/menu/_m3-menu.scss +42 -0
  328. package/menu/_menu-theme.scss +76 -0
  329. package/package.json +404 -0
  330. package/paginator/_m2-paginator.scss +69 -0
  331. package/paginator/_m3-paginator.scss +46 -0
  332. package/paginator/_paginator-theme.scss +76 -0
  333. package/prebuilt-themes/azure-blue.css +1 -0
  334. package/prebuilt-themes/cyan-orange.css +1 -0
  335. package/prebuilt-themes/deeppurple-amber.css +1 -0
  336. package/prebuilt-themes/indigo-pink.css +1 -0
  337. package/prebuilt-themes/magenta-violet.css +1 -0
  338. package/prebuilt-themes/pink-bluegrey.css +1 -0
  339. package/prebuilt-themes/purple-green.css +1 -0
  340. package/prebuilt-themes/rose-red.css +1 -0
  341. package/progress-bar/_m2-progress-bar.scss +36 -0
  342. package/progress-bar/_m3-progress-bar.scss +29 -0
  343. package/progress-bar/_progress-bar-theme.scss +93 -0
  344. package/progress-spinner/_m2-progress-spinner.scss +25 -0
  345. package/progress-spinner/_m3-progress-spinner.scss +27 -0
  346. package/progress-spinner/_progress-spinner-theme.scss +95 -0
  347. package/radio/_m2-radio.scss +67 -0
  348. package/radio/_m3-radio.scss +65 -0
  349. package/radio/_radio-theme.scss +102 -0
  350. package/schematics/collection.json +55 -0
  351. package/schematics/migration.json +15 -0
  352. package/schematics/ng-add/fonts/material-fonts.d.ts +11 -0
  353. package/schematics/ng-add/fonts/material-fonts.js +41 -0
  354. package/schematics/ng-add/fonts/material-fonts.js.map +1 -0
  355. package/schematics/ng-add/index.d.ts +17 -0
  356. package/schematics/ng-add/index.js +54 -0
  357. package/schematics/ng-add/index.js.map +1 -0
  358. package/schematics/ng-add/package-config.d.ts +12 -0
  359. package/schematics/ng-add/package-config.js +51 -0
  360. package/schematics/ng-add/package-config.js.map +1 -0
  361. package/schematics/ng-add/schema.d.ts +15 -0
  362. package/schematics/ng-add/schema.js +10 -0
  363. package/schematics/ng-add/schema.js.map +1 -0
  364. package/schematics/ng-add/schema.json +43 -0
  365. package/schematics/ng-add/setup-project.d.ts +15 -0
  366. package/schematics/ng-add/setup-project.js +36 -0
  367. package/schematics/ng-add/setup-project.js.map +1 -0
  368. package/schematics/ng-add/theming/create-theme.d.ts +9 -0
  369. package/schematics/ng-add/theming/create-theme.js +58 -0
  370. package/schematics/ng-add/theming/create-theme.js.map +1 -0
  371. package/schematics/ng-add/theming/theming.d.ts +11 -0
  372. package/schematics/ng-add/theming/theming.js +133 -0
  373. package/schematics/ng-add/theming/theming.js.map +1 -0
  374. package/schematics/ng-generate/address-form/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.__style__.template +27 -0
  375. package/schematics/ng-generate/address-form/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.html.template +99 -0
  376. package/schematics/ng-generate/address-form/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.spec.ts.template +38 -0
  377. package/schematics/ng-generate/address-form/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts.template +118 -0
  378. package/schematics/ng-generate/address-form/index.d.ts +14 -0
  379. package/schematics/ng-generate/address-form/index.js +43 -0
  380. package/schematics/ng-generate/address-form/index.js.map +1 -0
  381. package/schematics/ng-generate/address-form/schema.d.ts +10 -0
  382. package/schematics/ng-generate/address-form/schema.js +10 -0
  383. package/schematics/ng-generate/address-form/schema.js.map +1 -0
  384. package/schematics/ng-generate/address-form/schema.json +100 -0
  385. package/schematics/ng-generate/dashboard/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.__style__.template +21 -0
  386. package/schematics/ng-generate/dashboard/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.html.template +26 -0
  387. package/schematics/ng-generate/dashboard/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.spec.ts.template +36 -0
  388. package/schematics/ng-generate/dashboard/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts.template +56 -0
  389. package/schematics/ng-generate/dashboard/index.d.ts +14 -0
  390. package/schematics/ng-generate/dashboard/index.js +42 -0
  391. package/schematics/ng-generate/dashboard/index.js.map +1 -0
  392. package/schematics/ng-generate/dashboard/schema.d.ts +10 -0
  393. package/schematics/ng-generate/dashboard/schema.js +10 -0
  394. package/schematics/ng-generate/dashboard/schema.js.map +1 -0
  395. package/schematics/ng-generate/dashboard/schema.json +100 -0
  396. package/schematics/ng-generate/navigation/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.__style__.template +17 -0
  397. package/schematics/ng-generate/navigation/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.html.template +28 -0
  398. package/schematics/ng-generate/navigation/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.spec.ts.template +36 -0
  399. package/schematics/ng-generate/navigation/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts.template +42 -0
  400. package/schematics/ng-generate/navigation/index.d.ts +14 -0
  401. package/schematics/ng-generate/navigation/index.js +42 -0
  402. package/schematics/ng-generate/navigation/index.js.map +1 -0
  403. package/schematics/ng-generate/navigation/schema.d.ts +10 -0
  404. package/schematics/ng-generate/navigation/schema.js +10 -0
  405. package/schematics/ng-generate/navigation/schema.js.map +1 -0
  406. package/schematics/ng-generate/navigation/schema.json +105 -0
  407. package/schematics/ng-generate/table/files/__path__/__name@dasherize@if-flat__/__name@dasherize__-datasource.ts.template +111 -0
  408. package/schematics/ng-generate/table/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.__style__.template +3 -0
  409. package/schematics/ng-generate/table/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.html.template +26 -0
  410. package/schematics/ng-generate/table/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.spec.ts.template +32 -0
  411. package/schematics/ng-generate/table/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts.template +36 -0
  412. package/schematics/ng-generate/table/index.d.ts +14 -0
  413. package/schematics/ng-generate/table/index.js +40 -0
  414. package/schematics/ng-generate/table/index.js.map +1 -0
  415. package/schematics/ng-generate/table/schema.d.ts +10 -0
  416. package/schematics/ng-generate/table/schema.js +10 -0
  417. package/schematics/ng-generate/table/schema.js.map +1 -0
  418. package/schematics/ng-generate/table/schema.json +100 -0
  419. package/schematics/ng-generate/theme-color/index_bundled.js +6561 -0
  420. package/schematics/ng-generate/theme-color/index_bundled.js.map +6 -0
  421. package/schematics/ng-generate/theme-color/schema.json +55 -0
  422. package/schematics/ng-generate/tree/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.__style__.template +4 -0
  423. package/schematics/ng-generate/tree/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.html.template +22 -0
  424. package/schematics/ng-generate/tree/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.spec.ts.template +32 -0
  425. package/schematics/ng-generate/tree/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts.template +93 -0
  426. package/schematics/ng-generate/tree/files/__path__/__name@dasherize@if-flat__/example-data.ts.template +47 -0
  427. package/schematics/ng-generate/tree/index.d.ts +14 -0
  428. package/schematics/ng-generate/tree/index.js +40 -0
  429. package/schematics/ng-generate/tree/index.js.map +1 -0
  430. package/schematics/ng-generate/tree/schema.d.ts +10 -0
  431. package/schematics/ng-generate/tree/schema.js +10 -0
  432. package/schematics/ng-generate/tree/schema.js.map +1 -0
  433. package/schematics/ng-generate/tree/schema.json +100 -0
  434. package/schematics/ng-update/index_bundled.js +204 -0
  435. package/schematics/ng-update/index_bundled.js.map +6 -0
  436. package/schematics/package.json +3 -0
  437. package/select/_m2-select.scss +49 -0
  438. package/select/_m3-select.scss +54 -0
  439. package/select/_select-theme.scss +99 -0
  440. package/sidenav/_m2-sidenav.scss +48 -0
  441. package/sidenav/_m3-sidenav.scss +26 -0
  442. package/sidenav/_sidenav-theme.scss +75 -0
  443. package/slide-toggle/_m2-slide-toggle.scss +134 -0
  444. package/slide-toggle/_m3-slide-toggle.scss +133 -0
  445. package/slide-toggle/_slide-toggle-theme.scss +119 -0
  446. package/slider/_m2-slider.scss +73 -0
  447. package/slider/_m3-slider.scss +69 -0
  448. package/slider/_slider-theme.scss +103 -0
  449. package/snack-bar/_m2-snack-bar.scss +24 -0
  450. package/snack-bar/_m3-snack-bar.scss +26 -0
  451. package/snack-bar/_snack-bar-theme.scss +77 -0
  452. package/sort/_m2-sort.scss +16 -0
  453. package/sort/_m3-sort.scss +20 -0
  454. package/sort/_sort-theme.scss +76 -0
  455. package/stepper/_m2-stepper.scss +65 -0
  456. package/stepper/_m3-stepper.scss +66 -0
  457. package/stepper/_stepper-theme.scss +102 -0
  458. package/table/_m2-table.scss +63 -0
  459. package/table/_m3-table.scss +52 -0
  460. package/table/_table-theme.scss +76 -0
  461. package/tabs/_m2-tabs.scss +68 -0
  462. package/tabs/_m3-tabs.scss +58 -0
  463. package/tabs/_tabs-theme.scss +131 -0
  464. package/timepicker/_m2-timepicker.scss +19 -0
  465. package/timepicker/_m3-timepicker.scss +21 -0
  466. package/timepicker/_timepicker-theme.scss +81 -0
  467. package/toolbar/_m2-toolbar.scss +43 -0
  468. package/toolbar/_m3-toolbar.scss +41 -0
  469. package/toolbar/_toolbar-theme.scss +114 -0
  470. package/tooltip/_m2-tooltip.scss +24 -0
  471. package/tooltip/_m3-tooltip.scss +25 -0
  472. package/tooltip/_tooltip-theme.scss +76 -0
  473. package/tree/_m2-tree.scss +30 -0
  474. package/tree/_m3-tree.scss +37 -0
  475. package/tree/_tree-theme.scss +76 -0
  476. package/types/_badge-chunk.d.ts +100 -0
  477. package/types/_button-toggle-chunk.d.ts +252 -0
  478. package/types/_date-adapter-chunk.d.ts +261 -0
  479. package/types/_date-range-input-harness-chunk.d.ts +284 -0
  480. package/types/_dialog-chunk.d.ts +336 -0
  481. package/types/_error-options-chunk.d.ts +17 -0
  482. package/types/_form-field-chunk.d.ts +375 -0
  483. package/types/_form-field-control-chunk.d.ts +64 -0
  484. package/types/_form-field-control-harness-chunk.d.ts +20 -0
  485. package/types/_form-field-module-chunk.d.ts +18 -0
  486. package/types/_icon-module-chunk.d.ts +162 -0
  487. package/types/_icon-registry-chunk.d.ts +271 -0
  488. package/types/_input-harness-chunk.d.ts +61 -0
  489. package/types/_line-chunk.d.ts +25 -0
  490. package/types/_list-option-types-chunk.d.ts +15 -0
  491. package/types/_option-chunk.d.ts +146 -0
  492. package/types/_option-harness-chunk.d.ts +35 -0
  493. package/types/_option-module-chunk.d.ts +13 -0
  494. package/types/_option-parent-chunk.d.ts +20 -0
  495. package/types/_paginator-chunk.d.ts +184 -0
  496. package/types/_palette-chunk.d.ts +4 -0
  497. package/types/_progress-spinner-chunk.d.ts +91 -0
  498. package/types/_pseudo-checkbox-module-chunk.d.ts +45 -0
  499. package/types/_ripple-chunk.d.ts +256 -0
  500. package/types/_ripple-loader-chunk.d.ts +48 -0
  501. package/types/_ripple-module-chunk.d.ts +11 -0
  502. package/types/_sort-chunk.d.ts +88 -0
  503. package/types/_sort-direction-chunk.d.ts +3 -0
  504. package/types/_tooltip-chunk.d.ts +315 -0
  505. package/types/autocomplete-testing.d.ts +53 -0
  506. package/types/autocomplete.d.ts +420 -0
  507. package/types/badge-testing.d.ts +36 -0
  508. package/types/badge.d.ts +14 -0
  509. package/types/bottom-sheet-testing.d.ts +26 -0
  510. package/types/bottom-sheet.d.ts +192 -0
  511. package/types/button-testing.d.ts +70 -0
  512. package/types/button-toggle-testing.d.ts +97 -0
  513. package/types/button-toggle.d.ts +16 -0
  514. package/types/button.d.ts +210 -0
  515. package/types/card-testing.d.ts +41 -0
  516. package/types/card.d.ts +156 -0
  517. package/types/checkbox-testing.d.ts +86 -0
  518. package/types/checkbox.d.ts +216 -0
  519. package/types/chips-testing.d.ts +270 -0
  520. package/types/chips.d.ts +993 -0
  521. package/types/core-testing.d.ts +32 -0
  522. package/types/core.d.ts +185 -0
  523. package/types/datepicker-testing.d.ts +25 -0
  524. package/types/datepicker.d.ts +1746 -0
  525. package/types/dialog-testing.d.ts +83 -0
  526. package/types/dialog.d.ts +84 -0
  527. package/types/divider-testing.d.ts +15 -0
  528. package/types/divider.d.ts +24 -0
  529. package/types/expansion-testing.d.ts +101 -0
  530. package/types/expansion.d.ts +258 -0
  531. package/types/form-field-testing-control.d.ts +13 -0
  532. package/types/form-field-testing.d.ts +127 -0
  533. package/types/form-field.d.ts +19 -0
  534. package/types/grid-list-testing.d.ts +82 -0
  535. package/types/grid-list.d.ts +207 -0
  536. package/types/icon-testing.d.ts +81 -0
  537. package/types/icon.d.ts +8 -0
  538. package/types/input-testing.d.ts +73 -0
  539. package/types/input.d.ts +208 -0
  540. package/types/list-testing.d.ts +354 -0
  541. package/types/list.d.ts +516 -0
  542. package/types/material.d.ts +3 -0
  543. package/types/menu-testing.d.ts +141 -0
  544. package/types/menu.d.ts +547 -0
  545. package/types/paginator-testing.d.ts +51 -0
  546. package/types/paginator.d.ts +36 -0
  547. package/types/progress-bar-testing.d.ts +24 -0
  548. package/types/progress-bar.d.ts +106 -0
  549. package/types/progress-spinner-testing.d.ts +28 -0
  550. package/types/progress-spinner.d.ts +13 -0
  551. package/types/radio-testing.d.ts +109 -0
  552. package/types/radio.d.ts +295 -0
  553. package/types/select-testing.d.ts +63 -0
  554. package/types/select.d.ts +448 -0
  555. package/types/sidenav-testing.d.ts +122 -0
  556. package/types/sidenav.d.ts +335 -0
  557. package/types/slide-toggle-testing.d.ts +66 -0
  558. package/types/slide-toggle.d.ts +151 -0
  559. package/types/slider-testing.d.ts +90 -0
  560. package/types/slider.d.ts +662 -0
  561. package/types/snack-bar-testing.d.ts +64 -0
  562. package/types/snack-bar.d.ts +328 -0
  563. package/types/sort-testing.d.ts +48 -0
  564. package/types/sort.d.ts +126 -0
  565. package/types/stepper-testing.d.ts +136 -0
  566. package/types/stepper.d.ts +225 -0
  567. package/types/table-testing.d.ts +174 -0
  568. package/types/table.d.ts +302 -0
  569. package/types/tabs-testing.d.ts +145 -0
  570. package/types/tabs.d.ts +890 -0
  571. package/types/timepicker-testing.d.ts +108 -0
  572. package/types/timepicker.d.ts +318 -0
  573. package/types/toolbar-testing.d.ts +33 -0
  574. package/types/toolbar.d.ts +44 -0
  575. package/types/tooltip-testing.d.ts +35 -0
  576. package/types/tooltip.d.ts +17 -0
  577. package/types/tree-testing.d.ts +119 -0
  578. package/types/tree.d.ts +233 -0
@@ -0,0 +1,789 @@
1
+ import { _IdGenerator, FocusMonitor } from '@angular/cdk/a11y';
2
+ import { Directionality, BidiModule } from '@angular/cdk/bidi';
3
+ import { SelectionModel } from '@angular/cdk/collections';
4
+ import { hasModifierKey, RIGHT_ARROW, DOWN_ARROW, LEFT_ARROW, UP_ARROW, ENTER, SPACE } from '@angular/cdk/keycodes';
5
+ import { _CdkPrivateStyleLoader } from '@angular/cdk/private';
6
+ import * as i0 from '@angular/core';
7
+ import { InjectionToken, forwardRef, inject, ChangeDetectorRef, EventEmitter, booleanAttribute, Directive, ContentChildren, Input, Output, ElementRef, HostAttributeToken, signal, Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild, NgModule } from '@angular/core';
8
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
9
+ import { MatRipple } from './_ripple-chunk.mjs';
10
+ import { MatPseudoCheckbox } from './_pseudo-checkbox-chunk.mjs';
11
+ import { _animationsDisabled } from './_animation-chunk.mjs';
12
+ import { _StructuralStylesLoader } from './_structural-styles-chunk.mjs';
13
+ import { MatRippleModule } from './_ripple-module-chunk.mjs';
14
+ import '@angular/cdk/platform';
15
+ import '@angular/cdk/coercion';
16
+ import '@angular/cdk/layout';
17
+
18
+ const MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS = new InjectionToken('MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS', {
19
+ providedIn: 'root',
20
+ factory: () => ({
21
+ hideSingleSelectionIndicator: false,
22
+ hideMultipleSelectionIndicator: false,
23
+ disabledInteractive: false
24
+ })
25
+ });
26
+ const MAT_BUTTON_TOGGLE_GROUP = new InjectionToken('MatButtonToggleGroup');
27
+ const MAT_BUTTON_TOGGLE_GROUP_VALUE_ACCESSOR = {
28
+ provide: NG_VALUE_ACCESSOR,
29
+ useExisting: forwardRef(() => MatButtonToggleGroup),
30
+ multi: true
31
+ };
32
+ class MatButtonToggleChange {
33
+ source;
34
+ value;
35
+ constructor(source, value) {
36
+ this.source = source;
37
+ this.value = value;
38
+ }
39
+ }
40
+ class MatButtonToggleGroup {
41
+ _changeDetector = inject(ChangeDetectorRef);
42
+ _dir = inject(Directionality, {
43
+ optional: true
44
+ });
45
+ _multiple = false;
46
+ _disabled = false;
47
+ _disabledInteractive = false;
48
+ _selectionModel;
49
+ _rawValue;
50
+ _controlValueAccessorChangeFn = () => {};
51
+ _onTouched = () => {};
52
+ _buttonToggles;
53
+ appearance;
54
+ get name() {
55
+ return this._name;
56
+ }
57
+ set name(value) {
58
+ this._name = value;
59
+ this._markButtonsForCheck();
60
+ }
61
+ _name = inject(_IdGenerator).getId('mat-button-toggle-group-');
62
+ vertical = false;
63
+ get value() {
64
+ const selected = this._selectionModel ? this._selectionModel.selected : [];
65
+ if (this.multiple) {
66
+ return selected.map(toggle => toggle.value);
67
+ }
68
+ return selected[0] ? selected[0].value : undefined;
69
+ }
70
+ set value(newValue) {
71
+ this._setSelectionByValue(newValue);
72
+ this.valueChange.emit(this.value);
73
+ }
74
+ valueChange = new EventEmitter();
75
+ get selected() {
76
+ const selected = this._selectionModel ? this._selectionModel.selected : [];
77
+ return this.multiple ? selected : selected[0] || null;
78
+ }
79
+ get multiple() {
80
+ return this._multiple;
81
+ }
82
+ set multiple(value) {
83
+ this._multiple = value;
84
+ this._markButtonsForCheck();
85
+ }
86
+ get disabled() {
87
+ return this._disabled;
88
+ }
89
+ set disabled(value) {
90
+ this._disabled = value;
91
+ this._markButtonsForCheck();
92
+ }
93
+ get disabledInteractive() {
94
+ return this._disabledInteractive;
95
+ }
96
+ set disabledInteractive(value) {
97
+ this._disabledInteractive = value;
98
+ this._markButtonsForCheck();
99
+ }
100
+ get dir() {
101
+ return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr';
102
+ }
103
+ change = new EventEmitter();
104
+ get hideSingleSelectionIndicator() {
105
+ return this._hideSingleSelectionIndicator;
106
+ }
107
+ set hideSingleSelectionIndicator(value) {
108
+ this._hideSingleSelectionIndicator = value;
109
+ this._markButtonsForCheck();
110
+ }
111
+ _hideSingleSelectionIndicator;
112
+ get hideMultipleSelectionIndicator() {
113
+ return this._hideMultipleSelectionIndicator;
114
+ }
115
+ set hideMultipleSelectionIndicator(value) {
116
+ this._hideMultipleSelectionIndicator = value;
117
+ this._markButtonsForCheck();
118
+ }
119
+ _hideMultipleSelectionIndicator;
120
+ constructor() {
121
+ const defaultOptions = inject(MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS, {
122
+ optional: true
123
+ });
124
+ this.appearance = defaultOptions && defaultOptions.appearance ? defaultOptions.appearance : 'standard';
125
+ this._hideSingleSelectionIndicator = defaultOptions?.hideSingleSelectionIndicator ?? false;
126
+ this._hideMultipleSelectionIndicator = defaultOptions?.hideMultipleSelectionIndicator ?? false;
127
+ }
128
+ ngOnInit() {
129
+ this._selectionModel = new SelectionModel(this.multiple, undefined, false);
130
+ }
131
+ ngAfterContentInit() {
132
+ this._selectionModel.select(...this._buttonToggles.filter(toggle => toggle.checked));
133
+ if (!this.multiple) {
134
+ this._initializeTabIndex();
135
+ }
136
+ }
137
+ writeValue(value) {
138
+ this.value = value;
139
+ this._changeDetector.markForCheck();
140
+ }
141
+ registerOnChange(fn) {
142
+ this._controlValueAccessorChangeFn = fn;
143
+ }
144
+ registerOnTouched(fn) {
145
+ this._onTouched = fn;
146
+ }
147
+ setDisabledState(isDisabled) {
148
+ this.disabled = isDisabled;
149
+ }
150
+ _keydown(event) {
151
+ if (this.multiple || this.disabled || hasModifierKey(event)) {
152
+ return;
153
+ }
154
+ const target = event.target;
155
+ const buttonId = target.id;
156
+ const index = this._buttonToggles.toArray().findIndex(toggle => {
157
+ return toggle.buttonId === buttonId;
158
+ });
159
+ let nextButton = null;
160
+ switch (event.keyCode) {
161
+ case SPACE:
162
+ case ENTER:
163
+ nextButton = this._buttonToggles.get(index) || null;
164
+ break;
165
+ case UP_ARROW:
166
+ nextButton = this._getNextButton(index, -1);
167
+ break;
168
+ case LEFT_ARROW:
169
+ nextButton = this._getNextButton(index, this.dir === 'ltr' ? -1 : 1);
170
+ break;
171
+ case DOWN_ARROW:
172
+ nextButton = this._getNextButton(index, 1);
173
+ break;
174
+ case RIGHT_ARROW:
175
+ nextButton = this._getNextButton(index, this.dir === 'ltr' ? 1 : -1);
176
+ break;
177
+ default:
178
+ return;
179
+ }
180
+ if (nextButton) {
181
+ event.preventDefault();
182
+ nextButton._onButtonClick();
183
+ nextButton.focus();
184
+ }
185
+ }
186
+ _emitChangeEvent(toggle) {
187
+ const event = new MatButtonToggleChange(toggle, this.value);
188
+ this._rawValue = event.value;
189
+ this._controlValueAccessorChangeFn(event.value);
190
+ this.change.emit(event);
191
+ }
192
+ _syncButtonToggle(toggle, select, isUserInput = false, deferEvents = false) {
193
+ if (!this.multiple && this.selected && !toggle.checked) {
194
+ this.selected.checked = false;
195
+ }
196
+ if (this._selectionModel) {
197
+ if (select) {
198
+ this._selectionModel.select(toggle);
199
+ } else {
200
+ this._selectionModel.deselect(toggle);
201
+ }
202
+ } else {
203
+ deferEvents = true;
204
+ }
205
+ if (deferEvents) {
206
+ Promise.resolve().then(() => this._updateModelValue(toggle, isUserInput));
207
+ } else {
208
+ this._updateModelValue(toggle, isUserInput);
209
+ }
210
+ }
211
+ _isSelected(toggle) {
212
+ return this._selectionModel && this._selectionModel.isSelected(toggle);
213
+ }
214
+ _isPrechecked(toggle) {
215
+ if (typeof this._rawValue === 'undefined') {
216
+ return false;
217
+ }
218
+ if (this.multiple && Array.isArray(this._rawValue)) {
219
+ return this._rawValue.some(value => toggle.value != null && value === toggle.value);
220
+ }
221
+ return toggle.value === this._rawValue;
222
+ }
223
+ _initializeTabIndex() {
224
+ this._buttonToggles.forEach(toggle => {
225
+ toggle.tabIndex = -1;
226
+ });
227
+ if (this.selected) {
228
+ this.selected.tabIndex = 0;
229
+ } else {
230
+ for (let i = 0; i < this._buttonToggles.length; i++) {
231
+ const toggle = this._buttonToggles.get(i);
232
+ if (!toggle.disabled) {
233
+ toggle.tabIndex = 0;
234
+ break;
235
+ }
236
+ }
237
+ }
238
+ }
239
+ _getNextButton(startIndex, offset) {
240
+ const items = this._buttonToggles;
241
+ for (let i = 1; i <= items.length; i++) {
242
+ const index = (startIndex + offset * i + items.length) % items.length;
243
+ const item = items.get(index);
244
+ if (item && !item.disabled) {
245
+ return item;
246
+ }
247
+ }
248
+ return null;
249
+ }
250
+ _setSelectionByValue(value) {
251
+ this._rawValue = value;
252
+ if (!this._buttonToggles) {
253
+ return;
254
+ }
255
+ const toggles = this._buttonToggles.toArray();
256
+ if (this.multiple && value) {
257
+ if (!Array.isArray(value) && (typeof ngDevMode === 'undefined' || ngDevMode)) {
258
+ throw Error('Value must be an array in multiple-selection mode.');
259
+ }
260
+ this._clearSelection();
261
+ value.forEach(currentValue => this._selectValue(currentValue, toggles));
262
+ } else {
263
+ this._clearSelection();
264
+ this._selectValue(value, toggles);
265
+ }
266
+ if (!this.multiple && toggles.every(toggle => toggle.tabIndex === -1)) {
267
+ for (const toggle of toggles) {
268
+ if (!toggle.disabled) {
269
+ toggle.tabIndex = 0;
270
+ break;
271
+ }
272
+ }
273
+ }
274
+ }
275
+ _clearSelection() {
276
+ this._selectionModel.clear();
277
+ this._buttonToggles.forEach(toggle => {
278
+ toggle.checked = false;
279
+ if (!this.multiple) {
280
+ toggle.tabIndex = -1;
281
+ }
282
+ });
283
+ }
284
+ _selectValue(value, toggles) {
285
+ for (const toggle of toggles) {
286
+ if (toggle.value === value) {
287
+ toggle.checked = true;
288
+ this._selectionModel.select(toggle);
289
+ if (!this.multiple) {
290
+ toggle.tabIndex = 0;
291
+ }
292
+ break;
293
+ }
294
+ }
295
+ }
296
+ _updateModelValue(toggle, isUserInput) {
297
+ if (isUserInput) {
298
+ this._emitChangeEvent(toggle);
299
+ }
300
+ this.valueChange.emit(this.value);
301
+ }
302
+ _markButtonsForCheck() {
303
+ this._buttonToggles?.forEach(toggle => toggle._markForCheck());
304
+ }
305
+ static ɵfac = i0.ɵɵngDeclareFactory({
306
+ minVersion: "12.0.0",
307
+ version: "22.0.0-next.1",
308
+ ngImport: i0,
309
+ type: MatButtonToggleGroup,
310
+ deps: [],
311
+ target: i0.ɵɵFactoryTarget.Directive
312
+ });
313
+ static ɵdir = i0.ɵɵngDeclareDirective({
314
+ minVersion: "16.1.0",
315
+ version: "22.0.0-next.1",
316
+ type: MatButtonToggleGroup,
317
+ isStandalone: true,
318
+ selector: "mat-button-toggle-group",
319
+ inputs: {
320
+ appearance: "appearance",
321
+ name: "name",
322
+ vertical: ["vertical", "vertical", booleanAttribute],
323
+ value: "value",
324
+ multiple: ["multiple", "multiple", booleanAttribute],
325
+ disabled: ["disabled", "disabled", booleanAttribute],
326
+ disabledInteractive: ["disabledInteractive", "disabledInteractive", booleanAttribute],
327
+ hideSingleSelectionIndicator: ["hideSingleSelectionIndicator", "hideSingleSelectionIndicator", booleanAttribute],
328
+ hideMultipleSelectionIndicator: ["hideMultipleSelectionIndicator", "hideMultipleSelectionIndicator", booleanAttribute]
329
+ },
330
+ outputs: {
331
+ valueChange: "valueChange",
332
+ change: "change"
333
+ },
334
+ host: {
335
+ listeners: {
336
+ "keydown": "_keydown($event)"
337
+ },
338
+ properties: {
339
+ "attr.role": "multiple ? 'group' : 'radiogroup'",
340
+ "attr.aria-disabled": "disabled",
341
+ "class.mat-button-toggle-vertical": "vertical",
342
+ "class.mat-button-toggle-group-appearance-standard": "appearance === \"standard\""
343
+ },
344
+ classAttribute: "mat-button-toggle-group"
345
+ },
346
+ providers: [MAT_BUTTON_TOGGLE_GROUP_VALUE_ACCESSOR, {
347
+ provide: MAT_BUTTON_TOGGLE_GROUP,
348
+ useExisting: MatButtonToggleGroup
349
+ }],
350
+ queries: [{
351
+ propertyName: "_buttonToggles",
352
+ predicate: i0.forwardRef(() => MatButtonToggle),
353
+ descendants: true
354
+ }],
355
+ exportAs: ["matButtonToggleGroup"],
356
+ ngImport: i0
357
+ });
358
+ }
359
+ i0.ɵɵngDeclareClassMetadata({
360
+ minVersion: "12.0.0",
361
+ version: "22.0.0-next.1",
362
+ ngImport: i0,
363
+ type: MatButtonToggleGroup,
364
+ decorators: [{
365
+ type: Directive,
366
+ args: [{
367
+ selector: 'mat-button-toggle-group',
368
+ providers: [MAT_BUTTON_TOGGLE_GROUP_VALUE_ACCESSOR, {
369
+ provide: MAT_BUTTON_TOGGLE_GROUP,
370
+ useExisting: MatButtonToggleGroup
371
+ }],
372
+ host: {
373
+ 'class': 'mat-button-toggle-group',
374
+ '(keydown)': '_keydown($event)',
375
+ '[attr.role]': "multiple ? 'group' : 'radiogroup'",
376
+ '[attr.aria-disabled]': 'disabled',
377
+ '[class.mat-button-toggle-vertical]': 'vertical',
378
+ '[class.mat-button-toggle-group-appearance-standard]': 'appearance === "standard"'
379
+ },
380
+ exportAs: 'matButtonToggleGroup'
381
+ }]
382
+ }],
383
+ ctorParameters: () => [],
384
+ propDecorators: {
385
+ _buttonToggles: [{
386
+ type: ContentChildren,
387
+ args: [forwardRef(() => MatButtonToggle), {
388
+ descendants: true
389
+ }]
390
+ }],
391
+ appearance: [{
392
+ type: Input
393
+ }],
394
+ name: [{
395
+ type: Input
396
+ }],
397
+ vertical: [{
398
+ type: Input,
399
+ args: [{
400
+ transform: booleanAttribute
401
+ }]
402
+ }],
403
+ value: [{
404
+ type: Input
405
+ }],
406
+ valueChange: [{
407
+ type: Output
408
+ }],
409
+ multiple: [{
410
+ type: Input,
411
+ args: [{
412
+ transform: booleanAttribute
413
+ }]
414
+ }],
415
+ disabled: [{
416
+ type: Input,
417
+ args: [{
418
+ transform: booleanAttribute
419
+ }]
420
+ }],
421
+ disabledInteractive: [{
422
+ type: Input,
423
+ args: [{
424
+ transform: booleanAttribute
425
+ }]
426
+ }],
427
+ change: [{
428
+ type: Output
429
+ }],
430
+ hideSingleSelectionIndicator: [{
431
+ type: Input,
432
+ args: [{
433
+ transform: booleanAttribute
434
+ }]
435
+ }],
436
+ hideMultipleSelectionIndicator: [{
437
+ type: Input,
438
+ args: [{
439
+ transform: booleanAttribute
440
+ }]
441
+ }]
442
+ }
443
+ });
444
+ class MatButtonToggle {
445
+ _changeDetectorRef = inject(ChangeDetectorRef);
446
+ _elementRef = inject(ElementRef);
447
+ _focusMonitor = inject(FocusMonitor);
448
+ _idGenerator = inject(_IdGenerator);
449
+ _animationDisabled = _animationsDisabled();
450
+ _checked = false;
451
+ ariaLabel;
452
+ ariaLabelledby = null;
453
+ _buttonElement;
454
+ buttonToggleGroup;
455
+ get buttonId() {
456
+ return `${this.id}-button`;
457
+ }
458
+ id;
459
+ name;
460
+ value;
461
+ get tabIndex() {
462
+ return this._tabIndex();
463
+ }
464
+ set tabIndex(value) {
465
+ this._tabIndex.set(value);
466
+ }
467
+ _tabIndex;
468
+ disableRipple = false;
469
+ get appearance() {
470
+ return this.buttonToggleGroup ? this.buttonToggleGroup.appearance : this._appearance;
471
+ }
472
+ set appearance(value) {
473
+ this._appearance = value;
474
+ }
475
+ _appearance;
476
+ get checked() {
477
+ return this.buttonToggleGroup ? this.buttonToggleGroup._isSelected(this) : this._checked;
478
+ }
479
+ set checked(value) {
480
+ if (value !== this._checked) {
481
+ this._checked = value;
482
+ if (this.buttonToggleGroup) {
483
+ this.buttonToggleGroup._syncButtonToggle(this, this._checked);
484
+ }
485
+ this._changeDetectorRef.markForCheck();
486
+ }
487
+ }
488
+ get disabled() {
489
+ return this._disabled || this.buttonToggleGroup && this.buttonToggleGroup.disabled;
490
+ }
491
+ set disabled(value) {
492
+ this._disabled = value;
493
+ }
494
+ _disabled = false;
495
+ get disabledInteractive() {
496
+ return this._disabledInteractive || this.buttonToggleGroup !== null && this.buttonToggleGroup.disabledInteractive;
497
+ }
498
+ set disabledInteractive(value) {
499
+ this._disabledInteractive = value;
500
+ }
501
+ _disabledInteractive;
502
+ change = new EventEmitter();
503
+ constructor() {
504
+ inject(_CdkPrivateStyleLoader).load(_StructuralStylesLoader);
505
+ const toggleGroup = inject(MAT_BUTTON_TOGGLE_GROUP, {
506
+ optional: true
507
+ });
508
+ const defaultTabIndex = inject(new HostAttributeToken('tabindex'), {
509
+ optional: true
510
+ }) || '';
511
+ const defaultOptions = inject(MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS, {
512
+ optional: true
513
+ });
514
+ this._tabIndex = signal(parseInt(defaultTabIndex) || 0, ...(ngDevMode ? [{
515
+ debugName: "_tabIndex"
516
+ }] : []));
517
+ this.buttonToggleGroup = toggleGroup;
518
+ this._appearance = defaultOptions && defaultOptions.appearance ? defaultOptions.appearance : 'standard';
519
+ this._disabledInteractive = defaultOptions?.disabledInteractive ?? false;
520
+ }
521
+ ngOnInit() {
522
+ const group = this.buttonToggleGroup;
523
+ this.id = this.id || this._idGenerator.getId('mat-button-toggle-');
524
+ if (group) {
525
+ if (group._isPrechecked(this)) {
526
+ this.checked = true;
527
+ } else if (group._isSelected(this) !== this._checked) {
528
+ group._syncButtonToggle(this, this._checked);
529
+ }
530
+ }
531
+ }
532
+ ngAfterViewInit() {
533
+ if (!this._animationDisabled) {
534
+ this._elementRef.nativeElement.classList.add('mat-button-toggle-animations-enabled');
535
+ }
536
+ this._focusMonitor.monitor(this._elementRef, true);
537
+ }
538
+ ngOnDestroy() {
539
+ const group = this.buttonToggleGroup;
540
+ this._focusMonitor.stopMonitoring(this._elementRef);
541
+ if (group && group._isSelected(this)) {
542
+ group._syncButtonToggle(this, false, false, true);
543
+ }
544
+ }
545
+ focus(options) {
546
+ this._buttonElement.nativeElement.focus(options);
547
+ }
548
+ _onButtonClick() {
549
+ if (this.disabled) {
550
+ return;
551
+ }
552
+ const newChecked = this.isSingleSelector() ? true : !this._checked;
553
+ if (newChecked !== this._checked) {
554
+ this._checked = newChecked;
555
+ if (this.buttonToggleGroup) {
556
+ this.buttonToggleGroup._syncButtonToggle(this, this._checked, true);
557
+ this.buttonToggleGroup._onTouched();
558
+ }
559
+ }
560
+ if (this.isSingleSelector()) {
561
+ const focusable = this.buttonToggleGroup._buttonToggles.find(toggle => {
562
+ return toggle.tabIndex === 0;
563
+ });
564
+ if (focusable) {
565
+ focusable.tabIndex = -1;
566
+ }
567
+ this.tabIndex = 0;
568
+ }
569
+ this.change.emit(new MatButtonToggleChange(this, this.value));
570
+ }
571
+ _markForCheck() {
572
+ this._changeDetectorRef.markForCheck();
573
+ }
574
+ _getButtonName() {
575
+ if (this.isSingleSelector()) {
576
+ return this.buttonToggleGroup.name;
577
+ }
578
+ return this.name || null;
579
+ }
580
+ isSingleSelector() {
581
+ return this.buttonToggleGroup && !this.buttonToggleGroup.multiple;
582
+ }
583
+ static ɵfac = i0.ɵɵngDeclareFactory({
584
+ minVersion: "12.0.0",
585
+ version: "22.0.0-next.1",
586
+ ngImport: i0,
587
+ type: MatButtonToggle,
588
+ deps: [],
589
+ target: i0.ɵɵFactoryTarget.Component
590
+ });
591
+ static ɵcmp = i0.ɵɵngDeclareComponent({
592
+ minVersion: "17.0.0",
593
+ version: "22.0.0-next.1",
594
+ type: MatButtonToggle,
595
+ isStandalone: true,
596
+ selector: "mat-button-toggle",
597
+ inputs: {
598
+ ariaLabel: ["aria-label", "ariaLabel"],
599
+ ariaLabelledby: ["aria-labelledby", "ariaLabelledby"],
600
+ id: "id",
601
+ name: "name",
602
+ value: "value",
603
+ tabIndex: "tabIndex",
604
+ disableRipple: ["disableRipple", "disableRipple", booleanAttribute],
605
+ appearance: "appearance",
606
+ checked: ["checked", "checked", booleanAttribute],
607
+ disabled: ["disabled", "disabled", booleanAttribute],
608
+ disabledInteractive: ["disabledInteractive", "disabledInteractive", booleanAttribute]
609
+ },
610
+ outputs: {
611
+ change: "change"
612
+ },
613
+ host: {
614
+ attributes: {
615
+ "role": "presentation"
616
+ },
617
+ listeners: {
618
+ "focus": "focus()"
619
+ },
620
+ properties: {
621
+ "class.mat-button-toggle-standalone": "!buttonToggleGroup",
622
+ "class.mat-button-toggle-checked": "checked",
623
+ "class.mat-button-toggle-disabled": "disabled",
624
+ "class.mat-button-toggle-disabled-interactive": "disabledInteractive",
625
+ "class.mat-button-toggle-appearance-standard": "appearance === \"standard\"",
626
+ "attr.aria-label": "null",
627
+ "attr.aria-labelledby": "null",
628
+ "attr.id": "id",
629
+ "attr.name": "null"
630
+ },
631
+ classAttribute: "mat-button-toggle"
632
+ },
633
+ viewQueries: [{
634
+ propertyName: "_buttonElement",
635
+ first: true,
636
+ predicate: ["button"],
637
+ descendants: true
638
+ }],
639
+ exportAs: ["matButtonToggle"],
640
+ ngImport: i0,
641
+ template: "<button #button class=\"mat-button-toggle-button mat-focus-indicator\"\n type=\"button\"\n [id]=\"buttonId\"\n [attr.role]=\"isSingleSelector() ? 'radio' : 'button'\"\n [attr.tabindex]=\"disabled && !disabledInteractive ? -1 : tabIndex\"\n [attr.aria-pressed]=\"!isSingleSelector() ? checked : null\"\n [attr.aria-checked]=\"isSingleSelector() ? checked : null\"\n [disabled]=\"(disabled && !disabledInteractive) || null\"\n [attr.name]=\"_getButtonName()\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-disabled]=\"disabled && disabledInteractive ? 'true' : null\"\n (click)=\"_onButtonClick()\">\n @if (buttonToggleGroup && (\n !buttonToggleGroup.multiple && !buttonToggleGroup.hideSingleSelectionIndicator ||\n buttonToggleGroup.multiple && !buttonToggleGroup.hideMultipleSelectionIndicator)\n ) {\n <div class=\"mat-button-toggle-checkbox-wrapper\">\n <mat-pseudo-checkbox\n [disabled]=\"disabled\"\n state=\"checked\"\n aria-hidden=\"true\"\n appearance=\"minimal\"/>\n </div>\n }\n\n <span class=\"mat-button-toggle-label-content\">\n <ng-content></ng-content>\n </span>\n</button>\n\n<span class=\"mat-button-toggle-focus-overlay\"></span>\n<span class=\"mat-button-toggle-ripple\" matRipple\n [matRippleTrigger]=\"button\"\n [matRippleDisabled]=\"disableRipple || disabled\">\n</span>\n",
642
+ styles: [".mat-button-toggle-standalone,.mat-button-toggle-group{position:relative;display:inline-flex;flex-direction:row;white-space:nowrap;overflow:hidden;-webkit-tap-highlight-color:rgba(0,0,0,0);border-radius:var(--mat-button-toggle-legacy-shape);transform:translateZ(0)}.mat-button-toggle-standalone:not([class*=mat-elevation-z]),.mat-button-toggle-group:not([class*=mat-elevation-z]){box-shadow:0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12)}@media(forced-colors: active){.mat-button-toggle-standalone,.mat-button-toggle-group{outline:solid 1px}}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,.mat-button-toggle-group-appearance-standard{border-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border:solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline))}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard .mat-pseudo-checkbox,.mat-button-toggle-group-appearance-standard .mat-pseudo-checkbox{--mat-pseudo-checkbox-minimal-selected-checkmark-color: var(--mat-button-toggle-selected-state-text-color, var(--mat-sys-on-secondary-container))}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard:not([class*=mat-elevation-z]),.mat-button-toggle-group-appearance-standard:not([class*=mat-elevation-z]){box-shadow:none}@media(forced-colors: active){.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,.mat-button-toggle-group-appearance-standard{outline:0}}.mat-button-toggle-vertical{flex-direction:column}.mat-button-toggle-vertical .mat-button-toggle-label-content{display:block}.mat-button-toggle{white-space:nowrap;position:relative;color:var(--mat-button-toggle-legacy-text-color);font-family:var(--mat-button-toggle-legacy-label-text-font);font-size:var(--mat-button-toggle-legacy-label-text-size);line-height:var(--mat-button-toggle-legacy-label-text-line-height);font-weight:var(--mat-button-toggle-legacy-label-text-weight);letter-spacing:var(--mat-button-toggle-legacy-label-text-tracking);--mat-pseudo-checkbox-minimal-selected-checkmark-color: var(--mat-button-toggle-legacy-selected-state-text-color)}.mat-button-toggle.cdk-keyboard-focused .mat-button-toggle-focus-overlay{opacity:var(--mat-button-toggle-legacy-focus-state-layer-opacity)}.mat-button-toggle .mat-icon svg{vertical-align:top}.mat-button-toggle-checkbox-wrapper{display:inline-block;justify-content:flex-start;align-items:center;width:0;height:18px;line-height:18px;overflow:hidden;box-sizing:border-box;position:absolute;top:50%;left:16px;transform:translate3d(0, -50%, 0)}[dir=rtl] .mat-button-toggle-checkbox-wrapper{left:auto;right:16px}.mat-button-toggle-appearance-standard .mat-button-toggle-checkbox-wrapper{left:12px}[dir=rtl] .mat-button-toggle-appearance-standard .mat-button-toggle-checkbox-wrapper{left:auto;right:12px}.mat-button-toggle-checked .mat-button-toggle-checkbox-wrapper{width:18px}.mat-button-toggle-animations-enabled .mat-button-toggle-checkbox-wrapper{transition:width 150ms 45ms cubic-bezier(0.4, 0, 0.2, 1)}.mat-button-toggle-vertical .mat-button-toggle-checkbox-wrapper{transition:none}.mat-button-toggle-checked{color:var(--mat-button-toggle-legacy-selected-state-text-color);background-color:var(--mat-button-toggle-legacy-selected-state-background-color)}.mat-button-toggle-disabled{pointer-events:none;color:var(--mat-button-toggle-legacy-disabled-state-text-color);background-color:var(--mat-button-toggle-legacy-disabled-state-background-color);--mat-pseudo-checkbox-minimal-disabled-selected-checkmark-color: var(--mat-button-toggle-legacy-disabled-state-text-color)}.mat-button-toggle-disabled.mat-button-toggle-checked{background-color:var(--mat-button-toggle-legacy-disabled-selected-state-background-color)}.mat-button-toggle-disabled-interactive{pointer-events:auto}.mat-button-toggle-appearance-standard{color:var(--mat-button-toggle-text-color, var(--mat-sys-on-surface));background-color:var(--mat-button-toggle-background-color, transparent);font-family:var(--mat-button-toggle-label-text-font, var(--mat-sys-label-large-font));font-size:var(--mat-button-toggle-label-text-size, var(--mat-sys-label-large-size));line-height:var(--mat-button-toggle-label-text-line-height, var(--mat-sys-label-large-line-height));font-weight:var(--mat-button-toggle-label-text-weight, var(--mat-sys-label-large-weight));letter-spacing:var(--mat-button-toggle-label-text-tracking, var(--mat-sys-label-large-tracking))}.mat-button-toggle-group-appearance-standard .mat-button-toggle-appearance-standard+.mat-button-toggle-appearance-standard{border-left:solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline))}[dir=rtl] .mat-button-toggle-group-appearance-standard .mat-button-toggle-appearance-standard+.mat-button-toggle-appearance-standard{border-left:none;border-right:solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline))}.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle-appearance-standard+.mat-button-toggle-appearance-standard{border-left:none;border-right:none;border-top:solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline))}.mat-button-toggle-appearance-standard.mat-button-toggle-checked{color:var(--mat-button-toggle-selected-state-text-color, var(--mat-sys-on-secondary-container));background-color:var(--mat-button-toggle-selected-state-background-color, var(--mat-sys-secondary-container))}.mat-button-toggle-appearance-standard.mat-button-toggle-disabled{color:var(--mat-button-toggle-disabled-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));background-color:var(--mat-button-toggle-disabled-state-background-color, transparent)}.mat-button-toggle-appearance-standard.mat-button-toggle-disabled .mat-pseudo-checkbox{--mat-pseudo-checkbox-minimal-disabled-selected-checkmark-color: var(--mat-button-toggle-disabled-selected-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent))}.mat-button-toggle-appearance-standard.mat-button-toggle-disabled.mat-button-toggle-checked{color:var(--mat-button-toggle-disabled-selected-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));background-color:var(--mat-button-toggle-disabled-selected-state-background-color, color-mix(in srgb, var(--mat-sys-on-surface) 12%, transparent))}.mat-button-toggle-appearance-standard .mat-button-toggle-focus-overlay{background-color:var(--mat-button-toggle-state-layer-color, var(--mat-sys-on-surface))}.mat-button-toggle-appearance-standard:hover .mat-button-toggle-focus-overlay{opacity:var(--mat-button-toggle-hover-state-layer-opacity, var(--mat-sys-hover-state-layer-opacity))}.mat-button-toggle-appearance-standard.cdk-keyboard-focused .mat-button-toggle-focus-overlay{opacity:var(--mat-button-toggle-focus-state-layer-opacity, var(--mat-sys-focus-state-layer-opacity))}@media(hover: none){.mat-button-toggle-appearance-standard:hover .mat-button-toggle-focus-overlay{display:none}}.mat-button-toggle-label-content{-webkit-user-select:none;user-select:none;display:inline-block;padding:0 16px;line-height:var(--mat-button-toggle-legacy-height);position:relative}.mat-button-toggle-appearance-standard .mat-button-toggle-label-content{padding:0 12px;line-height:var(--mat-button-toggle-height, 40px)}.mat-button-toggle-label-content>*{vertical-align:middle}.mat-button-toggle-focus-overlay{top:0;left:0;right:0;bottom:0;position:absolute;border-radius:inherit;pointer-events:none;opacity:0;background-color:var(--mat-button-toggle-legacy-state-layer-color)}@media(forced-colors: active){.mat-button-toggle-checked .mat-button-toggle-focus-overlay{border-bottom:solid 500px;opacity:.5;height:0}.mat-button-toggle-checked:hover .mat-button-toggle-focus-overlay{opacity:.6}.mat-button-toggle-checked.mat-button-toggle-appearance-standard .mat-button-toggle-focus-overlay{border-bottom:solid 500px}}.mat-button-toggle .mat-button-toggle-ripple{top:0;left:0;right:0;bottom:0;position:absolute;pointer-events:none}.mat-button-toggle-button{border:0;background:none;color:inherit;padding:0;margin:0;font:inherit;outline:none;width:100%;cursor:pointer}.mat-button-toggle-animations-enabled .mat-button-toggle-button{transition:padding 150ms 45ms cubic-bezier(0.4, 0, 0.2, 1)}.mat-button-toggle-vertical .mat-button-toggle-button{transition:none}.mat-button-toggle-disabled .mat-button-toggle-button{cursor:default}.mat-button-toggle-button::-moz-focus-inner{border:0}.mat-button-toggle-checked .mat-button-toggle-button:has(.mat-button-toggle-checkbox-wrapper){padding-left:30px}[dir=rtl] .mat-button-toggle-checked .mat-button-toggle-button:has(.mat-button-toggle-checkbox-wrapper){padding-left:0;padding-right:30px}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard{--mat-focus-indicator-border-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}.mat-button-toggle-group-appearance-standard:not(.mat-button-toggle-vertical) .mat-button-toggle:last-of-type .mat-button-toggle-button::before{border-top-right-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border-bottom-right-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}.mat-button-toggle-group-appearance-standard:not(.mat-button-toggle-vertical) .mat-button-toggle:first-of-type .mat-button-toggle-button::before{border-top-left-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border-bottom-left-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle:last-of-type .mat-button-toggle-button::before{border-bottom-right-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border-bottom-left-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle:first-of-type .mat-button-toggle-button::before{border-top-right-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border-top-left-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}\n"],
643
+ dependencies: [{
644
+ kind: "directive",
645
+ type: MatRipple,
646
+ selector: "[mat-ripple], [matRipple]",
647
+ inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"],
648
+ exportAs: ["matRipple"]
649
+ }, {
650
+ kind: "component",
651
+ type: MatPseudoCheckbox,
652
+ selector: "mat-pseudo-checkbox",
653
+ inputs: ["state", "disabled", "appearance"]
654
+ }],
655
+ changeDetection: i0.ChangeDetectionStrategy.OnPush,
656
+ encapsulation: i0.ViewEncapsulation.None
657
+ });
658
+ }
659
+ i0.ɵɵngDeclareClassMetadata({
660
+ minVersion: "12.0.0",
661
+ version: "22.0.0-next.1",
662
+ ngImport: i0,
663
+ type: MatButtonToggle,
664
+ decorators: [{
665
+ type: Component,
666
+ args: [{
667
+ selector: 'mat-button-toggle',
668
+ encapsulation: ViewEncapsulation.None,
669
+ exportAs: 'matButtonToggle',
670
+ changeDetection: ChangeDetectionStrategy.OnPush,
671
+ host: {
672
+ '[class.mat-button-toggle-standalone]': '!buttonToggleGroup',
673
+ '[class.mat-button-toggle-checked]': 'checked',
674
+ '[class.mat-button-toggle-disabled]': 'disabled',
675
+ '[class.mat-button-toggle-disabled-interactive]': 'disabledInteractive',
676
+ '[class.mat-button-toggle-appearance-standard]': 'appearance === "standard"',
677
+ 'class': 'mat-button-toggle',
678
+ '[attr.aria-label]': 'null',
679
+ '[attr.aria-labelledby]': 'null',
680
+ '[attr.id]': 'id',
681
+ '[attr.name]': 'null',
682
+ '(focus)': 'focus()',
683
+ 'role': 'presentation'
684
+ },
685
+ imports: [MatRipple, MatPseudoCheckbox],
686
+ template: "<button #button class=\"mat-button-toggle-button mat-focus-indicator\"\n type=\"button\"\n [id]=\"buttonId\"\n [attr.role]=\"isSingleSelector() ? 'radio' : 'button'\"\n [attr.tabindex]=\"disabled && !disabledInteractive ? -1 : tabIndex\"\n [attr.aria-pressed]=\"!isSingleSelector() ? checked : null\"\n [attr.aria-checked]=\"isSingleSelector() ? checked : null\"\n [disabled]=\"(disabled && !disabledInteractive) || null\"\n [attr.name]=\"_getButtonName()\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-disabled]=\"disabled && disabledInteractive ? 'true' : null\"\n (click)=\"_onButtonClick()\">\n @if (buttonToggleGroup && (\n !buttonToggleGroup.multiple && !buttonToggleGroup.hideSingleSelectionIndicator ||\n buttonToggleGroup.multiple && !buttonToggleGroup.hideMultipleSelectionIndicator)\n ) {\n <div class=\"mat-button-toggle-checkbox-wrapper\">\n <mat-pseudo-checkbox\n [disabled]=\"disabled\"\n state=\"checked\"\n aria-hidden=\"true\"\n appearance=\"minimal\"/>\n </div>\n }\n\n <span class=\"mat-button-toggle-label-content\">\n <ng-content></ng-content>\n </span>\n</button>\n\n<span class=\"mat-button-toggle-focus-overlay\"></span>\n<span class=\"mat-button-toggle-ripple\" matRipple\n [matRippleTrigger]=\"button\"\n [matRippleDisabled]=\"disableRipple || disabled\">\n</span>\n",
687
+ styles: [".mat-button-toggle-standalone,.mat-button-toggle-group{position:relative;display:inline-flex;flex-direction:row;white-space:nowrap;overflow:hidden;-webkit-tap-highlight-color:rgba(0,0,0,0);border-radius:var(--mat-button-toggle-legacy-shape);transform:translateZ(0)}.mat-button-toggle-standalone:not([class*=mat-elevation-z]),.mat-button-toggle-group:not([class*=mat-elevation-z]){box-shadow:0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12)}@media(forced-colors: active){.mat-button-toggle-standalone,.mat-button-toggle-group{outline:solid 1px}}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,.mat-button-toggle-group-appearance-standard{border-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border:solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline))}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard .mat-pseudo-checkbox,.mat-button-toggle-group-appearance-standard .mat-pseudo-checkbox{--mat-pseudo-checkbox-minimal-selected-checkmark-color: var(--mat-button-toggle-selected-state-text-color, var(--mat-sys-on-secondary-container))}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard:not([class*=mat-elevation-z]),.mat-button-toggle-group-appearance-standard:not([class*=mat-elevation-z]){box-shadow:none}@media(forced-colors: active){.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,.mat-button-toggle-group-appearance-standard{outline:0}}.mat-button-toggle-vertical{flex-direction:column}.mat-button-toggle-vertical .mat-button-toggle-label-content{display:block}.mat-button-toggle{white-space:nowrap;position:relative;color:var(--mat-button-toggle-legacy-text-color);font-family:var(--mat-button-toggle-legacy-label-text-font);font-size:var(--mat-button-toggle-legacy-label-text-size);line-height:var(--mat-button-toggle-legacy-label-text-line-height);font-weight:var(--mat-button-toggle-legacy-label-text-weight);letter-spacing:var(--mat-button-toggle-legacy-label-text-tracking);--mat-pseudo-checkbox-minimal-selected-checkmark-color: var(--mat-button-toggle-legacy-selected-state-text-color)}.mat-button-toggle.cdk-keyboard-focused .mat-button-toggle-focus-overlay{opacity:var(--mat-button-toggle-legacy-focus-state-layer-opacity)}.mat-button-toggle .mat-icon svg{vertical-align:top}.mat-button-toggle-checkbox-wrapper{display:inline-block;justify-content:flex-start;align-items:center;width:0;height:18px;line-height:18px;overflow:hidden;box-sizing:border-box;position:absolute;top:50%;left:16px;transform:translate3d(0, -50%, 0)}[dir=rtl] .mat-button-toggle-checkbox-wrapper{left:auto;right:16px}.mat-button-toggle-appearance-standard .mat-button-toggle-checkbox-wrapper{left:12px}[dir=rtl] .mat-button-toggle-appearance-standard .mat-button-toggle-checkbox-wrapper{left:auto;right:12px}.mat-button-toggle-checked .mat-button-toggle-checkbox-wrapper{width:18px}.mat-button-toggle-animations-enabled .mat-button-toggle-checkbox-wrapper{transition:width 150ms 45ms cubic-bezier(0.4, 0, 0.2, 1)}.mat-button-toggle-vertical .mat-button-toggle-checkbox-wrapper{transition:none}.mat-button-toggle-checked{color:var(--mat-button-toggle-legacy-selected-state-text-color);background-color:var(--mat-button-toggle-legacy-selected-state-background-color)}.mat-button-toggle-disabled{pointer-events:none;color:var(--mat-button-toggle-legacy-disabled-state-text-color);background-color:var(--mat-button-toggle-legacy-disabled-state-background-color);--mat-pseudo-checkbox-minimal-disabled-selected-checkmark-color: var(--mat-button-toggle-legacy-disabled-state-text-color)}.mat-button-toggle-disabled.mat-button-toggle-checked{background-color:var(--mat-button-toggle-legacy-disabled-selected-state-background-color)}.mat-button-toggle-disabled-interactive{pointer-events:auto}.mat-button-toggle-appearance-standard{color:var(--mat-button-toggle-text-color, var(--mat-sys-on-surface));background-color:var(--mat-button-toggle-background-color, transparent);font-family:var(--mat-button-toggle-label-text-font, var(--mat-sys-label-large-font));font-size:var(--mat-button-toggle-label-text-size, var(--mat-sys-label-large-size));line-height:var(--mat-button-toggle-label-text-line-height, var(--mat-sys-label-large-line-height));font-weight:var(--mat-button-toggle-label-text-weight, var(--mat-sys-label-large-weight));letter-spacing:var(--mat-button-toggle-label-text-tracking, var(--mat-sys-label-large-tracking))}.mat-button-toggle-group-appearance-standard .mat-button-toggle-appearance-standard+.mat-button-toggle-appearance-standard{border-left:solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline))}[dir=rtl] .mat-button-toggle-group-appearance-standard .mat-button-toggle-appearance-standard+.mat-button-toggle-appearance-standard{border-left:none;border-right:solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline))}.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle-appearance-standard+.mat-button-toggle-appearance-standard{border-left:none;border-right:none;border-top:solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline))}.mat-button-toggle-appearance-standard.mat-button-toggle-checked{color:var(--mat-button-toggle-selected-state-text-color, var(--mat-sys-on-secondary-container));background-color:var(--mat-button-toggle-selected-state-background-color, var(--mat-sys-secondary-container))}.mat-button-toggle-appearance-standard.mat-button-toggle-disabled{color:var(--mat-button-toggle-disabled-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));background-color:var(--mat-button-toggle-disabled-state-background-color, transparent)}.mat-button-toggle-appearance-standard.mat-button-toggle-disabled .mat-pseudo-checkbox{--mat-pseudo-checkbox-minimal-disabled-selected-checkmark-color: var(--mat-button-toggle-disabled-selected-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent))}.mat-button-toggle-appearance-standard.mat-button-toggle-disabled.mat-button-toggle-checked{color:var(--mat-button-toggle-disabled-selected-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));background-color:var(--mat-button-toggle-disabled-selected-state-background-color, color-mix(in srgb, var(--mat-sys-on-surface) 12%, transparent))}.mat-button-toggle-appearance-standard .mat-button-toggle-focus-overlay{background-color:var(--mat-button-toggle-state-layer-color, var(--mat-sys-on-surface))}.mat-button-toggle-appearance-standard:hover .mat-button-toggle-focus-overlay{opacity:var(--mat-button-toggle-hover-state-layer-opacity, var(--mat-sys-hover-state-layer-opacity))}.mat-button-toggle-appearance-standard.cdk-keyboard-focused .mat-button-toggle-focus-overlay{opacity:var(--mat-button-toggle-focus-state-layer-opacity, var(--mat-sys-focus-state-layer-opacity))}@media(hover: none){.mat-button-toggle-appearance-standard:hover .mat-button-toggle-focus-overlay{display:none}}.mat-button-toggle-label-content{-webkit-user-select:none;user-select:none;display:inline-block;padding:0 16px;line-height:var(--mat-button-toggle-legacy-height);position:relative}.mat-button-toggle-appearance-standard .mat-button-toggle-label-content{padding:0 12px;line-height:var(--mat-button-toggle-height, 40px)}.mat-button-toggle-label-content>*{vertical-align:middle}.mat-button-toggle-focus-overlay{top:0;left:0;right:0;bottom:0;position:absolute;border-radius:inherit;pointer-events:none;opacity:0;background-color:var(--mat-button-toggle-legacy-state-layer-color)}@media(forced-colors: active){.mat-button-toggle-checked .mat-button-toggle-focus-overlay{border-bottom:solid 500px;opacity:.5;height:0}.mat-button-toggle-checked:hover .mat-button-toggle-focus-overlay{opacity:.6}.mat-button-toggle-checked.mat-button-toggle-appearance-standard .mat-button-toggle-focus-overlay{border-bottom:solid 500px}}.mat-button-toggle .mat-button-toggle-ripple{top:0;left:0;right:0;bottom:0;position:absolute;pointer-events:none}.mat-button-toggle-button{border:0;background:none;color:inherit;padding:0;margin:0;font:inherit;outline:none;width:100%;cursor:pointer}.mat-button-toggle-animations-enabled .mat-button-toggle-button{transition:padding 150ms 45ms cubic-bezier(0.4, 0, 0.2, 1)}.mat-button-toggle-vertical .mat-button-toggle-button{transition:none}.mat-button-toggle-disabled .mat-button-toggle-button{cursor:default}.mat-button-toggle-button::-moz-focus-inner{border:0}.mat-button-toggle-checked .mat-button-toggle-button:has(.mat-button-toggle-checkbox-wrapper){padding-left:30px}[dir=rtl] .mat-button-toggle-checked .mat-button-toggle-button:has(.mat-button-toggle-checkbox-wrapper){padding-left:0;padding-right:30px}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard{--mat-focus-indicator-border-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}.mat-button-toggle-group-appearance-standard:not(.mat-button-toggle-vertical) .mat-button-toggle:last-of-type .mat-button-toggle-button::before{border-top-right-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border-bottom-right-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}.mat-button-toggle-group-appearance-standard:not(.mat-button-toggle-vertical) .mat-button-toggle:first-of-type .mat-button-toggle-button::before{border-top-left-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border-bottom-left-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle:last-of-type .mat-button-toggle-button::before{border-bottom-right-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border-bottom-left-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle:first-of-type .mat-button-toggle-button::before{border-top-right-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));border-top-left-radius:var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large))}\n"]
688
+ }]
689
+ }],
690
+ ctorParameters: () => [],
691
+ propDecorators: {
692
+ ariaLabel: [{
693
+ type: Input,
694
+ args: ['aria-label']
695
+ }],
696
+ ariaLabelledby: [{
697
+ type: Input,
698
+ args: ['aria-labelledby']
699
+ }],
700
+ _buttonElement: [{
701
+ type: ViewChild,
702
+ args: ['button']
703
+ }],
704
+ id: [{
705
+ type: Input
706
+ }],
707
+ name: [{
708
+ type: Input
709
+ }],
710
+ value: [{
711
+ type: Input
712
+ }],
713
+ tabIndex: [{
714
+ type: Input
715
+ }],
716
+ disableRipple: [{
717
+ type: Input,
718
+ args: [{
719
+ transform: booleanAttribute
720
+ }]
721
+ }],
722
+ appearance: [{
723
+ type: Input
724
+ }],
725
+ checked: [{
726
+ type: Input,
727
+ args: [{
728
+ transform: booleanAttribute
729
+ }]
730
+ }],
731
+ disabled: [{
732
+ type: Input,
733
+ args: [{
734
+ transform: booleanAttribute
735
+ }]
736
+ }],
737
+ disabledInteractive: [{
738
+ type: Input,
739
+ args: [{
740
+ transform: booleanAttribute
741
+ }]
742
+ }],
743
+ change: [{
744
+ type: Output
745
+ }]
746
+ }
747
+ });
748
+
749
+ class MatButtonToggleModule {
750
+ static ɵfac = i0.ɵɵngDeclareFactory({
751
+ minVersion: "12.0.0",
752
+ version: "22.0.0-next.1",
753
+ ngImport: i0,
754
+ type: MatButtonToggleModule,
755
+ deps: [],
756
+ target: i0.ɵɵFactoryTarget.NgModule
757
+ });
758
+ static ɵmod = i0.ɵɵngDeclareNgModule({
759
+ minVersion: "14.0.0",
760
+ version: "22.0.0-next.1",
761
+ ngImport: i0,
762
+ type: MatButtonToggleModule,
763
+ imports: [MatRippleModule, MatButtonToggleGroup, MatButtonToggle],
764
+ exports: [BidiModule, MatButtonToggleGroup, MatButtonToggle]
765
+ });
766
+ static ɵinj = i0.ɵɵngDeclareInjector({
767
+ minVersion: "12.0.0",
768
+ version: "22.0.0-next.1",
769
+ ngImport: i0,
770
+ type: MatButtonToggleModule,
771
+ imports: [MatRippleModule, MatButtonToggle, BidiModule]
772
+ });
773
+ }
774
+ i0.ɵɵngDeclareClassMetadata({
775
+ minVersion: "12.0.0",
776
+ version: "22.0.0-next.1",
777
+ ngImport: i0,
778
+ type: MatButtonToggleModule,
779
+ decorators: [{
780
+ type: NgModule,
781
+ args: [{
782
+ imports: [MatRippleModule, MatButtonToggleGroup, MatButtonToggle],
783
+ exports: [BidiModule, MatButtonToggleGroup, MatButtonToggle]
784
+ }]
785
+ }]
786
+ });
787
+
788
+ export { MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS, MAT_BUTTON_TOGGLE_GROUP, MAT_BUTTON_TOGGLE_GROUP_VALUE_ACCESSOR, MatButtonToggle, MatButtonToggleChange, MatButtonToggleGroup, MatButtonToggleModule };
789
+ //# sourceMappingURL=button-toggle.mjs.map