@angular/material 7.0.4 → 7.2.1

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 (488) hide show
  1. package/LICENSE +1 -1
  2. package/_theming.scss +61 -44
  3. package/autocomplete/typings/index.d.ts +1 -1
  4. package/autocomplete/typings/index.metadata.json +1 -1
  5. package/badge/typings/index.metadata.json +1 -1
  6. package/bottom-sheet/typings/bottom-sheet-config.d.ts +5 -0
  7. package/bottom-sheet/typings/bottom-sheet-container.d.ts +1 -1
  8. package/bottom-sheet/typings/index.metadata.json +1 -1
  9. package/bundles/material-autocomplete.umd.js +126 -32
  10. package/bundles/material-autocomplete.umd.js.map +1 -1
  11. package/bundles/material-autocomplete.umd.min.js +1 -1
  12. package/bundles/material-autocomplete.umd.min.js.map +1 -1
  13. package/bundles/material-badge.umd.js +38 -5
  14. package/bundles/material-badge.umd.js.map +1 -1
  15. package/bundles/material-badge.umd.min.js +1 -1
  16. package/bundles/material-badge.umd.min.js.map +1 -1
  17. package/bundles/material-bottom-sheet.umd.js +68 -21
  18. package/bundles/material-bottom-sheet.umd.js.map +1 -1
  19. package/bundles/material-bottom-sheet.umd.min.js +1 -1
  20. package/bundles/material-bottom-sheet.umd.min.js.map +1 -1
  21. package/bundles/material-button-toggle.umd.js +36 -13
  22. package/bundles/material-button-toggle.umd.js.map +1 -1
  23. package/bundles/material-button-toggle.umd.min.js +1 -1
  24. package/bundles/material-button-toggle.umd.min.js.map +1 -1
  25. package/bundles/material-button.umd.js +21 -14
  26. package/bundles/material-button.umd.js.map +1 -1
  27. package/bundles/material-button.umd.min.js +1 -1
  28. package/bundles/material-button.umd.min.js.map +1 -1
  29. package/bundles/material-card.umd.js +3 -3
  30. package/bundles/material-card.umd.js.map +1 -1
  31. package/bundles/material-card.umd.min.js +1 -1
  32. package/bundles/material-card.umd.min.js.map +1 -1
  33. package/bundles/material-checkbox.umd.js +56 -15
  34. package/bundles/material-checkbox.umd.js.map +1 -1
  35. package/bundles/material-checkbox.umd.min.js +1 -1
  36. package/bundles/material-checkbox.umd.min.js.map +1 -1
  37. package/bundles/material-chips.umd.js +124 -34
  38. package/bundles/material-chips.umd.js.map +1 -1
  39. package/bundles/material-chips.umd.min.js +1 -1
  40. package/bundles/material-chips.umd.min.js.map +1 -1
  41. package/bundles/material-core.umd.js +189 -126
  42. package/bundles/material-core.umd.js.map +1 -1
  43. package/bundles/material-core.umd.min.js +1 -1
  44. package/bundles/material-core.umd.min.js.map +1 -1
  45. package/bundles/material-datepicker.umd.js +231 -53
  46. package/bundles/material-datepicker.umd.js.map +1 -1
  47. package/bundles/material-datepicker.umd.min.js +2 -2
  48. package/bundles/material-datepicker.umd.min.js.map +1 -1
  49. package/bundles/material-dialog.umd.js +138 -40
  50. package/bundles/material-dialog.umd.js.map +1 -1
  51. package/bundles/material-dialog.umd.min.js +1 -1
  52. package/bundles/material-dialog.umd.min.js.map +1 -1
  53. package/bundles/material-divider.umd.js +2 -2
  54. package/bundles/material-divider.umd.js.map +1 -1
  55. package/bundles/material-divider.umd.min.js.map +1 -1
  56. package/bundles/material-expansion.umd.js +53 -27
  57. package/bundles/material-expansion.umd.js.map +1 -1
  58. package/bundles/material-expansion.umd.min.js +1 -1
  59. package/bundles/material-expansion.umd.min.js.map +1 -1
  60. package/bundles/material-form-field.umd.js +121 -32
  61. package/bundles/material-form-field.umd.js.map +1 -1
  62. package/bundles/material-form-field.umd.min.js +1 -1
  63. package/bundles/material-form-field.umd.min.js.map +1 -1
  64. package/bundles/material-grid-list.umd.js +66 -15
  65. package/bundles/material-grid-list.umd.js.map +1 -1
  66. package/bundles/material-grid-list.umd.min.js +1 -1
  67. package/bundles/material-grid-list.umd.min.js.map +1 -1
  68. package/bundles/material-icon.umd.js +277 -78
  69. package/bundles/material-icon.umd.js.map +1 -1
  70. package/bundles/material-icon.umd.min.js +1 -1
  71. package/bundles/material-icon.umd.min.js.map +1 -1
  72. package/bundles/material-input.umd.js +50 -22
  73. package/bundles/material-input.umd.js.map +1 -1
  74. package/bundles/material-input.umd.min.js +1 -1
  75. package/bundles/material-input.umd.min.js.map +1 -1
  76. package/bundles/material-list.umd.js +69 -21
  77. package/bundles/material-list.umd.js.map +1 -1
  78. package/bundles/material-list.umd.min.js +2 -6
  79. package/bundles/material-list.umd.min.js.map +1 -1
  80. package/bundles/material-menu.umd.js +171 -66
  81. package/bundles/material-menu.umd.js.map +1 -1
  82. package/bundles/material-menu.umd.min.js +1 -1
  83. package/bundles/material-menu.umd.min.js.map +1 -1
  84. package/bundles/material-paginator.umd.js +52 -10
  85. package/bundles/material-paginator.umd.js.map +1 -1
  86. package/bundles/material-paginator.umd.min.js +1 -1
  87. package/bundles/material-paginator.umd.min.js.map +1 -1
  88. package/bundles/material-progress-bar.umd.js +31 -12
  89. package/bundles/material-progress-bar.umd.js.map +1 -1
  90. package/bundles/material-progress-bar.umd.min.js +1 -1
  91. package/bundles/material-progress-bar.umd.min.js.map +1 -1
  92. package/bundles/material-progress-spinner.umd.js +29 -13
  93. package/bundles/material-progress-spinner.umd.js.map +1 -1
  94. package/bundles/material-progress-spinner.umd.min.js.map +1 -1
  95. package/bundles/material-radio.umd.js +38 -40
  96. package/bundles/material-radio.umd.js.map +1 -1
  97. package/bundles/material-radio.umd.min.js +1 -1
  98. package/bundles/material-radio.umd.min.js.map +1 -1
  99. package/bundles/material-select.umd.js +189 -51
  100. package/bundles/material-select.umd.js.map +1 -1
  101. package/bundles/material-select.umd.min.js +1 -1
  102. package/bundles/material-select.umd.min.js.map +1 -1
  103. package/bundles/material-sidenav.umd.js +104 -25
  104. package/bundles/material-sidenav.umd.js.map +1 -1
  105. package/bundles/material-sidenav.umd.min.js +1 -1
  106. package/bundles/material-sidenav.umd.min.js.map +1 -1
  107. package/bundles/material-slide-toggle.umd.js +30 -14
  108. package/bundles/material-slide-toggle.umd.js.map +1 -1
  109. package/bundles/material-slide-toggle.umd.min.js +1 -1
  110. package/bundles/material-slide-toggle.umd.min.js.map +1 -1
  111. package/bundles/material-slider.umd.js +91 -21
  112. package/bundles/material-slider.umd.js.map +1 -1
  113. package/bundles/material-slider.umd.min.js +1 -1
  114. package/bundles/material-slider.umd.min.js.map +1 -1
  115. package/bundles/material-snack-bar.umd.js +71 -19
  116. package/bundles/material-snack-bar.umd.js.map +1 -1
  117. package/bundles/material-snack-bar.umd.min.js +1 -1
  118. package/bundles/material-snack-bar.umd.min.js.map +1 -1
  119. package/bundles/material-sort.umd.js +46 -24
  120. package/bundles/material-sort.umd.js.map +1 -1
  121. package/bundles/material-sort.umd.min.js +1 -1
  122. package/bundles/material-sort.umd.min.js.map +1 -1
  123. package/bundles/material-stepper.umd.js +37 -35
  124. package/bundles/material-stepper.umd.js.map +1 -1
  125. package/bundles/material-stepper.umd.min.js +1 -1
  126. package/bundles/material-stepper.umd.min.js.map +1 -1
  127. package/bundles/material-table.umd.js +29 -9
  128. package/bundles/material-table.umd.js.map +1 -1
  129. package/bundles/material-table.umd.min.js.map +1 -1
  130. package/bundles/material-tabs.umd.js +170 -68
  131. package/bundles/material-tabs.umd.js.map +1 -1
  132. package/bundles/material-tabs.umd.min.js +2 -2
  133. package/bundles/material-tabs.umd.min.js.map +1 -1
  134. package/bundles/material-toolbar.umd.js +14 -4
  135. package/bundles/material-toolbar.umd.js.map +1 -1
  136. package/bundles/material-toolbar.umd.min.js +1 -1
  137. package/bundles/material-toolbar.umd.min.js.map +1 -1
  138. package/bundles/material-tooltip.umd.js +53 -26
  139. package/bundles/material-tooltip.umd.js.map +1 -1
  140. package/bundles/material-tooltip.umd.min.js +1 -1
  141. package/bundles/material-tooltip.umd.min.js.map +1 -1
  142. package/bundles/material-tree.umd.js +25 -16
  143. package/bundles/material-tree.umd.js.map +1 -1
  144. package/bundles/material-tree.umd.min.js +1 -1
  145. package/bundles/material-tree.umd.min.js.map +1 -1
  146. package/bundles/material.umd.js +2853 -1010
  147. package/bundles/material.umd.js.map +1 -1
  148. package/bundles/material.umd.min.js +19 -21
  149. package/bundles/material.umd.min.js.map +1 -1
  150. package/button/typings/button.d.ts +0 -5
  151. package/button/typings/index.metadata.json +1 -1
  152. package/button-toggle/typings/index.metadata.json +1 -1
  153. package/card/typings/index.metadata.json +1 -1
  154. package/checkbox/typings/index.metadata.json +1 -1
  155. package/chips/typings/chip-list.d.ts +1 -1
  156. package/chips/typings/chip.d.ts +2 -2
  157. package/chips/typings/index.metadata.json +1 -1
  158. package/core/typings/index.metadata.json +1 -1
  159. package/core/typings/{testing/month-constants.d.ts → month-constants.d.ts} +2 -0
  160. package/core/typings/public-api.d.ts +1 -1
  161. package/datepicker/typings/calendar-body.d.ts +21 -5
  162. package/datepicker/typings/calendar.d.ts +4 -1
  163. package/datepicker/typings/datepicker.d.ts +3 -0
  164. package/datepicker/typings/index.metadata.json +1 -1
  165. package/datepicker/typings/month-view.d.ts +4 -2
  166. package/dialog/typings/index.metadata.json +1 -1
  167. package/esm2015/autocomplete.js +60 -29
  168. package/esm2015/autocomplete.js.map +1 -1
  169. package/esm2015/badge.js +29 -6
  170. package/esm2015/badge.js.map +1 -1
  171. package/esm2015/bottom-sheet.js +45 -22
  172. package/esm2015/bottom-sheet.js.map +1 -1
  173. package/esm2015/button-toggle.js +20 -11
  174. package/esm2015/button-toggle.js.map +1 -1
  175. package/esm2015/button.js +20 -15
  176. package/esm2015/button.js.map +1 -1
  177. package/esm2015/card.js +5 -5
  178. package/esm2015/card.js.map +1 -1
  179. package/esm2015/checkbox.js +30 -12
  180. package/esm2015/checkbox.js.map +1 -1
  181. package/esm2015/chips.js +64 -28
  182. package/esm2015/chips.js.map +1 -1
  183. package/esm2015/core.js +148 -129
  184. package/esm2015/core.js.map +1 -1
  185. package/esm2015/datepicker.js +124 -41
  186. package/esm2015/datepicker.js.map +1 -1
  187. package/esm2015/dialog.js +77 -40
  188. package/esm2015/dialog.js.map +1 -1
  189. package/esm2015/divider.js +4 -4
  190. package/esm2015/divider.js.map +1 -1
  191. package/esm2015/expansion.js +58 -31
  192. package/esm2015/expansion.js.map +1 -1
  193. package/esm2015/form-field.js +94 -34
  194. package/esm2015/form-field.js.map +1 -1
  195. package/esm2015/grid-list.js +45 -17
  196. package/esm2015/grid-list.js.map +1 -1
  197. package/esm2015/icon.js +136 -67
  198. package/esm2015/icon.js.map +1 -1
  199. package/esm2015/input.js +44 -23
  200. package/esm2015/input.js.map +1 -1
  201. package/esm2015/list.js +47 -22
  202. package/esm2015/list.js.map +1 -1
  203. package/esm2015/material.js +13 -12
  204. package/esm2015/material.js.map +1 -1
  205. package/esm2015/menu.js +109 -63
  206. package/esm2015/menu.js.map +1 -1
  207. package/esm2015/paginator.js +35 -12
  208. package/esm2015/paginator.js.map +1 -1
  209. package/esm2015/progress-bar.js +26 -13
  210. package/esm2015/progress-bar.js.map +1 -1
  211. package/esm2015/progress-spinner.js +24 -14
  212. package/esm2015/progress-spinner.js.map +1 -1
  213. package/esm2015/radio.js +22 -21
  214. package/esm2015/radio.js.map +1 -1
  215. package/esm2015/select.js +116 -53
  216. package/esm2015/select.js.map +1 -1
  217. package/esm2015/sidenav.js +75 -28
  218. package/esm2015/sidenav.js.map +1 -1
  219. package/esm2015/slide-toggle.js +23 -15
  220. package/esm2015/slide-toggle.js.map +1 -1
  221. package/esm2015/slider.js +54 -24
  222. package/esm2015/slider.js.map +1 -1
  223. package/esm2015/snack-bar.js +41 -21
  224. package/esm2015/snack-bar.js.map +1 -1
  225. package/esm2015/sort.js +47 -24
  226. package/esm2015/sort.js.map +1 -1
  227. package/esm2015/stepper.js +35 -32
  228. package/esm2015/stepper.js.map +1 -1
  229. package/esm2015/table.js +31 -11
  230. package/esm2015/table.js.map +1 -1
  231. package/esm2015/tabs.js +113 -53
  232. package/esm2015/tabs.js.map +1 -1
  233. package/esm2015/toolbar.js +9 -5
  234. package/esm2015/toolbar.js.map +1 -1
  235. package/esm2015/tooltip.js +43 -28
  236. package/esm2015/tooltip.js.map +1 -1
  237. package/esm2015/tree.js +22 -17
  238. package/esm2015/tree.js.map +1 -1
  239. package/esm5/autocomplete.es5.js +128 -34
  240. package/esm5/autocomplete.es5.js.map +1 -1
  241. package/esm5/badge.es5.js +40 -7
  242. package/esm5/badge.es5.js.map +1 -1
  243. package/esm5/bottom-sheet.es5.js +70 -23
  244. package/esm5/bottom-sheet.es5.js.map +1 -1
  245. package/esm5/button-toggle.es5.js +38 -15
  246. package/esm5/button-toggle.es5.js.map +1 -1
  247. package/esm5/button.es5.js +23 -16
  248. package/esm5/button.es5.js.map +1 -1
  249. package/esm5/card.es5.js +5 -5
  250. package/esm5/card.es5.js.map +1 -1
  251. package/esm5/checkbox.es5.js +58 -17
  252. package/esm5/checkbox.es5.js.map +1 -1
  253. package/esm5/chips.es5.js +127 -37
  254. package/esm5/chips.es5.js.map +1 -1
  255. package/esm5/core.es5.js +192 -129
  256. package/esm5/core.es5.js.map +1 -1
  257. package/esm5/datepicker.es5.js +233 -55
  258. package/esm5/datepicker.es5.js.map +1 -1
  259. package/esm5/dialog.es5.js +140 -42
  260. package/esm5/dialog.es5.js.map +1 -1
  261. package/esm5/divider.es5.js +4 -4
  262. package/esm5/divider.es5.js.map +1 -1
  263. package/esm5/expansion.es5.js +56 -31
  264. package/esm5/expansion.es5.js.map +1 -1
  265. package/esm5/form-field.es5.js +125 -36
  266. package/esm5/form-field.es5.js.map +1 -1
  267. package/esm5/grid-list.es5.js +68 -17
  268. package/esm5/grid-list.es5.js.map +1 -1
  269. package/esm5/icon.es5.js +279 -80
  270. package/esm5/icon.es5.js.map +1 -1
  271. package/esm5/input.es5.js +52 -24
  272. package/esm5/input.es5.js.map +1 -1
  273. package/esm5/list.es5.js +72 -24
  274. package/esm5/list.es5.js.map +1 -1
  275. package/esm5/material.es5.js +13 -12
  276. package/esm5/material.es5.js.map +1 -1
  277. package/esm5/menu.es5.js +170 -65
  278. package/esm5/menu.es5.js.map +1 -1
  279. package/esm5/paginator.es5.js +55 -13
  280. package/esm5/paginator.es5.js.map +1 -1
  281. package/esm5/progress-bar.es5.js +33 -14
  282. package/esm5/progress-bar.es5.js.map +1 -1
  283. package/esm5/progress-spinner.es5.js +31 -15
  284. package/esm5/progress-spinner.es5.js.map +1 -1
  285. package/esm5/radio.es5.js +42 -42
  286. package/esm5/radio.es5.js.map +1 -1
  287. package/esm5/select.es5.js +193 -55
  288. package/esm5/select.es5.js.map +1 -1
  289. package/esm5/sidenav.es5.js +107 -28
  290. package/esm5/sidenav.es5.js.map +1 -1
  291. package/esm5/slide-toggle.es5.js +32 -16
  292. package/esm5/slide-toggle.es5.js.map +1 -1
  293. package/esm5/slider.es5.js +94 -24
  294. package/esm5/slider.es5.js.map +1 -1
  295. package/esm5/snack-bar.es5.js +73 -21
  296. package/esm5/snack-bar.es5.js.map +1 -1
  297. package/esm5/sort.es5.js +53 -26
  298. package/esm5/sort.es5.js.map +1 -1
  299. package/esm5/stepper.es5.js +40 -38
  300. package/esm5/stepper.es5.js.map +1 -1
  301. package/esm5/table.es5.js +31 -11
  302. package/esm5/table.es5.js.map +1 -1
  303. package/esm5/tabs.es5.js +162 -61
  304. package/esm5/tabs.es5.js.map +1 -1
  305. package/esm5/toolbar.es5.js +16 -6
  306. package/esm5/toolbar.es5.js.map +1 -1
  307. package/esm5/tooltip.es5.js +55 -28
  308. package/esm5/tooltip.es5.js.map +1 -1
  309. package/esm5/tree.es5.js +27 -18
  310. package/esm5/tree.es5.js.map +1 -1
  311. package/expansion/typings/expansion-panel-header.d.ts +2 -2
  312. package/expansion/typings/expansion-panel.d.ts +19 -2
  313. package/expansion/typings/index.metadata.json +1 -1
  314. package/form-field/typings/form-field.d.ts +15 -4
  315. package/form-field/typings/index.metadata.json +1 -1
  316. package/grid-list/typings/index.d.ts +1 -1
  317. package/grid-list/typings/index.metadata.json +1 -1
  318. package/icon/typings/index.metadata.json +1 -1
  319. package/list/typings/index.metadata.json +1 -1
  320. package/material.d.ts +1 -1
  321. package/material.metadata.json +3 -3
  322. package/menu/typings/index.d.ts +4 -4
  323. package/menu/typings/index.metadata.json +1 -1
  324. package/menu/typings/menu-directive.d.ts +1 -0
  325. package/menu/typings/menu-item.d.ts +2 -0
  326. package/package.json +5 -5
  327. package/paginator/typings/index.metadata.json +1 -1
  328. package/paginator/typings/paginator.d.ts +7 -3
  329. package/prebuilt-themes/deeppurple-amber.css +1 -1
  330. package/prebuilt-themes/indigo-pink.css +1 -1
  331. package/prebuilt-themes/pink-bluegrey.css +1 -1
  332. package/prebuilt-themes/purple-green.css +1 -1
  333. package/progress-bar/typings/index.metadata.json +1 -1
  334. package/radio/typings/index.metadata.json +1 -1
  335. package/radio/typings/radio.d.ts +2 -6
  336. package/schematics/ng-add/theming/{custom-theme.d.ts → create-custom-theme.d.ts} +0 -0
  337. package/schematics/ng-add/theming/{custom-theme.js → create-custom-theme.js} +1 -1
  338. package/schematics/ng-add/theming/create-custom-theme.js.map +1 -0
  339. package/schematics/ng-add/theming/theming.js +35 -19
  340. package/schematics/ng-add/theming/theming.js.map +1 -1
  341. package/schematics/ng-generate/address-form/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts +2 -2
  342. package/schematics/ng-generate/dashboard/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts +2 -2
  343. package/schematics/ng-generate/nav/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts +2 -2
  344. package/schematics/ng-generate/table/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts +2 -2
  345. package/schematics/ng-generate/tree/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts +2 -2
  346. package/select/typings/index.metadata.json +1 -1
  347. package/select/typings/select.d.ts +12 -2
  348. package/sidenav/typings/drawer.d.ts +9 -2
  349. package/sidenav/typings/index.metadata.json +1 -1
  350. package/slide-toggle/typings/index.metadata.json +1 -1
  351. package/slider/typings/index.metadata.json +1 -1
  352. package/snack-bar/typings/index.metadata.json +1 -1
  353. package/sort/typings/index.metadata.json +1 -1
  354. package/stepper/typings/index.metadata.json +1 -1
  355. package/stepper/typings/step-header.d.ts +3 -5
  356. package/tabs/typings/index.d.ts +5 -5
  357. package/tabs/typings/index.metadata.json +1 -1
  358. package/tabs/typings/tab-body.d.ts +2 -0
  359. package/tabs/typings/tab-group.d.ts +11 -2
  360. package/tabs/typings/tab-header.d.ts +9 -3
  361. package/toolbar/typings/index.metadata.json +1 -1
  362. package/tooltip/typings/index.metadata.json +1 -1
  363. package/tree/typings/data-source/flat-data-source.d.ts +2 -2
  364. package/tree/typings/index.metadata.json +1 -1
  365. package/typings/autocomplete/index.d.ts +1 -1
  366. package/typings/autocomplete/index.metadata.json +1 -1
  367. package/typings/badge/index.metadata.json +1 -1
  368. package/typings/bottom-sheet/bottom-sheet-config.d.ts +5 -0
  369. package/typings/bottom-sheet/bottom-sheet-container.d.ts +1 -1
  370. package/typings/bottom-sheet/index.metadata.json +1 -1
  371. package/typings/button/button.d.ts +0 -5
  372. package/typings/button/index.metadata.json +1 -1
  373. package/typings/button-toggle/index.metadata.json +1 -1
  374. package/typings/card/index.metadata.json +1 -1
  375. package/typings/checkbox/index.metadata.json +1 -1
  376. package/typings/chips/chip-list.d.ts +1 -1
  377. package/typings/chips/chip.d.ts +2 -2
  378. package/typings/chips/index.metadata.json +1 -1
  379. package/typings/core/index.metadata.json +1 -1
  380. package/typings/core/{testing/month-constants.d.ts → month-constants.d.ts} +2 -0
  381. package/typings/core/public-api.d.ts +1 -1
  382. package/typings/datepicker/calendar-body.d.ts +21 -5
  383. package/typings/datepicker/calendar.d.ts +4 -1
  384. package/typings/datepicker/datepicker.d.ts +3 -0
  385. package/typings/datepicker/index.metadata.json +1 -1
  386. package/typings/datepicker/month-view.d.ts +4 -2
  387. package/typings/dialog/index.metadata.json +1 -1
  388. package/typings/esm5/autocomplete/index.d.ts +1 -1
  389. package/typings/esm5/autocomplete/index.metadata.json +1 -1
  390. package/typings/esm5/badge/index.metadata.json +1 -1
  391. package/typings/esm5/bottom-sheet/bottom-sheet-config.d.ts +5 -0
  392. package/typings/esm5/bottom-sheet/bottom-sheet-container.d.ts +1 -1
  393. package/typings/esm5/bottom-sheet/index.metadata.json +1 -1
  394. package/typings/esm5/button/button.d.ts +0 -5
  395. package/typings/esm5/button/index.metadata.json +1 -1
  396. package/typings/esm5/button-toggle/index.metadata.json +1 -1
  397. package/typings/esm5/card/index.metadata.json +1 -1
  398. package/typings/esm5/checkbox/index.metadata.json +1 -1
  399. package/typings/esm5/chips/chip-list.d.ts +1 -1
  400. package/typings/esm5/chips/chip.d.ts +2 -2
  401. package/typings/esm5/chips/index.metadata.json +1 -1
  402. package/typings/esm5/core/index.metadata.json +1 -1
  403. package/typings/esm5/core/{testing/month-constants.d.ts → month-constants.d.ts} +2 -0
  404. package/typings/esm5/core/public-api.d.ts +1 -1
  405. package/typings/esm5/datepicker/calendar-body.d.ts +21 -5
  406. package/typings/esm5/datepicker/calendar.d.ts +4 -1
  407. package/typings/esm5/datepicker/datepicker.d.ts +3 -0
  408. package/typings/esm5/datepicker/index.metadata.json +1 -1
  409. package/typings/esm5/datepicker/month-view.d.ts +4 -2
  410. package/typings/esm5/dialog/index.metadata.json +1 -1
  411. package/typings/esm5/expansion/expansion-panel-header.d.ts +2 -2
  412. package/typings/esm5/expansion/expansion-panel.d.ts +19 -2
  413. package/typings/esm5/expansion/index.metadata.json +1 -1
  414. package/typings/esm5/form-field/form-field.d.ts +15 -4
  415. package/typings/esm5/form-field/index.metadata.json +1 -1
  416. package/typings/esm5/grid-list/index.d.ts +1 -1
  417. package/typings/esm5/grid-list/index.metadata.json +1 -1
  418. package/typings/esm5/icon/index.metadata.json +1 -1
  419. package/typings/esm5/index.metadata.json +1 -1
  420. package/typings/esm5/list/index.metadata.json +1 -1
  421. package/typings/esm5/menu/index.d.ts +4 -4
  422. package/typings/esm5/menu/index.metadata.json +1 -1
  423. package/typings/esm5/menu/menu-directive.d.ts +1 -0
  424. package/typings/esm5/menu/menu-item.d.ts +2 -0
  425. package/typings/esm5/paginator/index.metadata.json +1 -1
  426. package/typings/esm5/paginator/paginator.d.ts +7 -3
  427. package/typings/esm5/progress-bar/index.metadata.json +1 -1
  428. package/typings/esm5/radio/index.metadata.json +1 -1
  429. package/typings/esm5/radio/radio.d.ts +2 -6
  430. package/typings/esm5/select/index.metadata.json +1 -1
  431. package/typings/esm5/select/select.d.ts +12 -2
  432. package/typings/esm5/sidenav/drawer.d.ts +9 -2
  433. package/typings/esm5/sidenav/index.metadata.json +1 -1
  434. package/typings/esm5/slide-toggle/index.metadata.json +1 -1
  435. package/typings/esm5/slider/index.metadata.json +1 -1
  436. package/typings/esm5/snack-bar/index.metadata.json +1 -1
  437. package/typings/esm5/sort/index.metadata.json +1 -1
  438. package/typings/esm5/stepper/index.metadata.json +1 -1
  439. package/typings/esm5/stepper/step-header.d.ts +3 -5
  440. package/typings/esm5/tabs/index.d.ts +5 -5
  441. package/typings/esm5/tabs/index.metadata.json +1 -1
  442. package/typings/esm5/tabs/tab-body.d.ts +2 -0
  443. package/typings/esm5/tabs/tab-group.d.ts +11 -2
  444. package/typings/esm5/tabs/tab-header.d.ts +9 -3
  445. package/typings/esm5/toolbar/index.metadata.json +1 -1
  446. package/typings/esm5/tooltip/index.metadata.json +1 -1
  447. package/typings/esm5/tree/data-source/flat-data-source.d.ts +2 -2
  448. package/typings/esm5/tree/index.metadata.json +1 -1
  449. package/typings/expansion/expansion-panel-header.d.ts +2 -2
  450. package/typings/expansion/expansion-panel.d.ts +19 -2
  451. package/typings/expansion/index.metadata.json +1 -1
  452. package/typings/form-field/form-field.d.ts +15 -4
  453. package/typings/form-field/index.metadata.json +1 -1
  454. package/typings/grid-list/index.d.ts +1 -1
  455. package/typings/grid-list/index.metadata.json +1 -1
  456. package/typings/icon/index.metadata.json +1 -1
  457. package/typings/index.metadata.json +1 -1
  458. package/typings/list/index.metadata.json +1 -1
  459. package/typings/menu/index.d.ts +4 -4
  460. package/typings/menu/index.metadata.json +1 -1
  461. package/typings/menu/menu-directive.d.ts +1 -0
  462. package/typings/menu/menu-item.d.ts +2 -0
  463. package/typings/paginator/index.metadata.json +1 -1
  464. package/typings/paginator/paginator.d.ts +7 -3
  465. package/typings/progress-bar/index.metadata.json +1 -1
  466. package/typings/radio/index.metadata.json +1 -1
  467. package/typings/radio/radio.d.ts +2 -6
  468. package/typings/schematics/ng-add/theming/{custom-theme.d.ts → create-custom-theme.d.ts} +0 -0
  469. package/typings/select/index.metadata.json +1 -1
  470. package/typings/select/select.d.ts +12 -2
  471. package/typings/sidenav/drawer.d.ts +9 -2
  472. package/typings/sidenav/index.metadata.json +1 -1
  473. package/typings/slide-toggle/index.metadata.json +1 -1
  474. package/typings/slider/index.metadata.json +1 -1
  475. package/typings/snack-bar/index.metadata.json +1 -1
  476. package/typings/sort/index.metadata.json +1 -1
  477. package/typings/stepper/index.metadata.json +1 -1
  478. package/typings/stepper/step-header.d.ts +3 -5
  479. package/typings/tabs/index.d.ts +5 -5
  480. package/typings/tabs/index.metadata.json +1 -1
  481. package/typings/tabs/tab-body.d.ts +2 -0
  482. package/typings/tabs/tab-group.d.ts +11 -2
  483. package/typings/tabs/tab-header.d.ts +9 -3
  484. package/typings/toolbar/index.metadata.json +1 -1
  485. package/typings/tooltip/index.metadata.json +1 -1
  486. package/typings/tree/data-source/flat-data-source.d.ts +2 -2
  487. package/typings/tree/index.metadata.json +1 -1
  488. package/schematics/ng-add/theming/custom-theme.js.map +0 -1
package/esm2015/menu.js CHANGED
@@ -5,7 +5,7 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
- import { Directive, TemplateRef, ComponentFactoryResolver, ApplicationRef, Injector, ViewContainerRef, Inject, InjectionToken, ChangeDetectionStrategy, Component, ElementRef, ViewEncapsulation, Optional, ContentChild, ContentChildren, EventEmitter, Input, NgZone, Output, ViewChild, Self, NgModule } from '@angular/core';
8
+ import { Directive, TemplateRef, ComponentFactoryResolver, ApplicationRef, Injector, ViewContainerRef, Inject, InjectionToken, ChangeDetectionStrategy, Component, ElementRef, ViewEncapsulation, Optional, Input, ContentChild, ContentChildren, EventEmitter, NgZone, Output, ViewChild, Self, NgModule } from '@angular/core';
9
9
  import { TemplatePortal, DomPortalOutlet } from '@angular/cdk/portal';
10
10
  import { DOCUMENT, CommonModule } from '@angular/common';
11
11
  import { Subject, merge, Subscription, asapScheduler, of } from 'rxjs';
@@ -21,7 +21,7 @@ import { normalizePassiveListenerOptions } from '@angular/cdk/platform';
21
21
 
22
22
  /**
23
23
  * @fileoverview added by tsickle
24
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
24
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
25
25
  */
26
26
  /**
27
27
  * Menu content that will be rendered lazily once the menu is opened.
@@ -62,12 +62,11 @@ class MatMenuContent {
62
62
  this._outlet = new DomPortalOutlet(this._document.createElement('div'), this._componentFactoryResolver, this._appRef, this._injector);
63
63
  }
64
64
  /** @type {?} */
65
- const element = this._template.elementRef.nativeElement; /** @type {?} */
66
- ((
65
+ const element = this._template.elementRef.nativeElement;
67
66
  // Because we support opening the same menu from different triggers (which in turn have their
68
67
  // own `OverlayRef` panel), we have to re-insert the host element every time, otherwise we
69
68
  // risk it staying attached to a pane that's no longer in the DOM.
70
- element.parentNode)).insertBefore(this._outlet.outletElement, element);
69
+ (/** @type {?} */ (element.parentNode)).insertBefore(this._outlet.outletElement, element);
71
70
  this._portal.attach(this._outlet, context);
72
71
  this._attached.next();
73
72
  }
@@ -107,23 +106,24 @@ MatMenuContent.ctorParameters = () => [
107
106
 
108
107
  /**
109
108
  * @fileoverview added by tsickle
110
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
109
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
111
110
  */
112
- /** *
111
+ /**
113
112
  * Animations used by the mat-menu component.
114
113
  * Animation duration and timing values are based on:
115
114
  * https://material.io/guidelines/components/menus.html#menus-usage
116
115
  * \@docs-private
117
- @type {?} */
116
+ * @type {?}
117
+ */
118
118
  const matMenuAnimations = {
119
119
  /**
120
- * This animation controls the menu panel's entry and exit from the page.
121
- *
122
- * When the menu panel is added to the DOM, it scales in and fades in its border.
123
- *
124
- * When the menu panel is removed from the DOM, it simply fades out after a brief
125
- * delay to display the ripple.
126
- */
120
+ * This animation controls the menu panel's entry and exit from the page.
121
+ *
122
+ * When the menu panel is added to the DOM, it scales in and fades in its border.
123
+ *
124
+ * When the menu panel is removed from the DOM, it simply fades out after a brief
125
+ * delay to display the ripple.
126
+ */
127
127
  transformMenu: trigger('transformMenu', [
128
128
  state('void', style({
129
129
  opacity: 0,
@@ -136,9 +136,9 @@ const matMenuAnimations = {
136
136
  transition('* => void', animate('100ms 25ms linear', style({ opacity: 0 })))
137
137
  ]),
138
138
  /**
139
- * This animation fades in the background color and content of the menu panel
140
- * after its containing element is scaled in.
141
- */
139
+ * This animation fades in the background color and content of the menu panel
140
+ * after its containing element is scaled in.
141
+ */
142
142
  fadeInItems: trigger('fadeInItems', [
143
143
  // TODO(crisbeto): this is inside the `transformMenu`
144
144
  // now. Remove next time we do breaking changes.
@@ -149,22 +149,24 @@ const matMenuAnimations = {
149
149
  ])
150
150
  ])
151
151
  };
152
- /** *
152
+ /**
153
153
  * @deprecated
154
154
  * \@breaking-change 8.0.0
155
155
  * \@docs-private
156
- @type {?} */
156
+ * @type {?}
157
+ */
157
158
  const fadeInItems = matMenuAnimations.fadeInItems;
158
- /** *
159
+ /**
159
160
  * @deprecated
160
161
  * \@breaking-change 8.0.0
161
162
  * \@docs-private
162
- @type {?} */
163
+ * @type {?}
164
+ */
163
165
  const transformMenu = matMenuAnimations.transformMenu;
164
166
 
165
167
  /**
166
168
  * @fileoverview added by tsickle
167
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
169
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
168
170
  */
169
171
 
170
172
  /**
@@ -202,18 +204,20 @@ function throwMatMenuInvalidPositionY() {
202
204
 
203
205
  /**
204
206
  * @fileoverview added by tsickle
205
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
207
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
206
208
  */
207
- /** *
209
+ /**
208
210
  * Injection token used to provide the parent menu to menu-specific components.
209
211
  * \@docs-private
210
- @type {?} */
212
+ * @type {?}
213
+ */
211
214
  const MAT_MENU_PANEL = new InjectionToken('MAT_MENU_PANEL');
212
215
 
213
216
  /**
214
217
  * @fileoverview added by tsickle
215
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
218
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
216
219
  */
220
+ // Boilerplate for applying mixins to MatMenuItem.
217
221
  /**
218
222
  * \@docs-private
219
223
  */
@@ -238,6 +242,10 @@ class MatMenuItem extends _MatMenuItemMixinBase {
238
242
  this._elementRef = _elementRef;
239
243
  this._focusMonitor = _focusMonitor;
240
244
  this._parentMenu = _parentMenu;
245
+ /**
246
+ * ARIA role for the menu item.
247
+ */
248
+ this.role = 'menuitem';
241
249
  /**
242
250
  * Stream that emits when the menu item is hovered.
243
251
  */
@@ -349,7 +357,7 @@ MatMenuItem.decorators = [
349
357
  exportAs: 'matMenuItem',
350
358
  inputs: ['disabled', 'disableRipple'],
351
359
  host: {
352
- 'role': 'menuitem',
360
+ '[attr.role]': 'role',
353
361
  'class': 'mat-menu-item',
354
362
  '[class.mat-menu-item-highlighted]': '_highlighted',
355
363
  '[class.mat-menu-item-submenu-trigger]': '_triggersSubmenu',
@@ -371,14 +379,18 @@ MatMenuItem.ctorParameters = () => [
371
379
  { type: FocusMonitor },
372
380
  { type: undefined, decorators: [{ type: Inject, args: [MAT_MENU_PANEL,] }, { type: Optional }] }
373
381
  ];
382
+ MatMenuItem.propDecorators = {
383
+ role: [{ type: Input }]
384
+ };
374
385
 
375
386
  /**
376
387
  * @fileoverview added by tsickle
377
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
388
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
378
389
  */
379
- /** *
390
+ /**
380
391
  * Injection token to be used to override the default options for `mat-menu`.
381
- @type {?} */
392
+ * @type {?}
393
+ */
382
394
  const MAT_MENU_DEFAULT_OPTIONS = new InjectionToken('mat-menu-default-options', {
383
395
  providedIn: 'root',
384
396
  factory: MAT_MENU_DEFAULT_OPTIONS_FACTORY
@@ -395,10 +407,11 @@ function MAT_MENU_DEFAULT_OPTIONS_FACTORY() {
395
407
  backdropClass: 'cdk-overlay-transparent-backdrop',
396
408
  };
397
409
  }
398
- /** *
410
+ /**
399
411
  * Start elevation for the menu panel.
400
412
  * \@docs-private
401
- @type {?} */
413
+ * @type {?}
414
+ */
402
415
  const MAT_MENU_BASE_ELEVATION = 4;
403
416
  class MatMenu {
404
417
  /**
@@ -625,6 +638,7 @@ class MatMenu {
625
638
  * @return {?}
626
639
  */
627
640
  setElevation(depth) {
641
+ // The elevation starts at the base and increases by one for each level.
628
642
  /** @type {?} */
629
643
  const newElevation = `mat-elevation-z${MAT_MENU_BASE_ELEVATION + depth}`;
630
644
  /** @type {?} */
@@ -708,12 +722,19 @@ class MatMenu {
708
722
  _onAnimationDone(event) {
709
723
  this._animationDone.next(event);
710
724
  this._isAnimating = false;
711
- // Scroll the content element to the top once the animation is done. This is necessary, because
712
- // we move focus to the first item while it's still being animated, which can throw the browser
713
- // off when it determines the scroll position. Alternatively we can move focus when the
714
- // animation is done, however moving focus asynchronously will interrupt screen readers
715
- // which are in the process of reading out the menu already. We take the `element` from
716
- // the `event` since we can't use a `ViewChild` to access the pane.
725
+ }
726
+ /**
727
+ * @param {?} event
728
+ * @return {?}
729
+ */
730
+ _onAnimationStart(event) {
731
+ this._isAnimating = true;
732
+ // Scroll the content element to the top as soon as the animation starts. This is necessary,
733
+ // because we move focus to the first item while it's still being animated, which can throw
734
+ // the browser off when it determines the scroll position. Alternatively we can move focus
735
+ // when the animation is done, however moving focus asynchronously will interrupt screen
736
+ // readers which are in the process of reading out the menu already. We take the `element`
737
+ // from the `event` since we can't use a `ViewChild` to access the pane.
717
738
  if (event.toState === 'enter' && this._keyManager.activeItemIndex === 0) {
718
739
  event.element.scrollTop = 0;
719
740
  }
@@ -721,8 +742,8 @@ class MatMenu {
721
742
  }
722
743
  MatMenu.decorators = [
723
744
  { type: Component, args: [{selector: 'mat-menu',
724
- template: "<ng-template><div class=\"mat-menu-panel\" [ngClass]=\"_classList\" (keydown)=\"_handleKeydown($event)\" (click)=\"closed.emit('click')\" [@transformMenu]=\"_panelAnimationState\" (@transformMenu.start)=\"_isAnimating = true\" (@transformMenu.done)=\"_onAnimationDone($event)\" tabindex=\"-1\" role=\"menu\"><div class=\"mat-menu-content\"><ng-content></ng-content></div></div></ng-template>",
725
- styles: [".mat-menu-panel{min-width:112px;max-width:280px;overflow:auto;-webkit-overflow-scrolling:touch;max-height:calc(100vh - 48px);border-radius:4px;outline:0}@media screen and (-ms-high-contrast:active){.mat-menu-panel{outline:solid 1px}}.mat-menu-content:not(:empty){padding-top:8px;padding-bottom:8px}.mat-menu-item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;outline:0;border:none;-webkit-tap-highlight-color:transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;line-height:48px;height:48px;padding:0 16px;text-align:left;text-decoration:none;max-width:100%;position:relative}.mat-menu-item::-moz-focus-inner{border:0}.mat-menu-item[disabled]{cursor:default}[dir=rtl] .mat-menu-item{text-align:right}.mat-menu-item .mat-icon{margin-right:16px;vertical-align:middle}.mat-menu-item .mat-icon svg{vertical-align:top}[dir=rtl] .mat-menu-item .mat-icon{margin-left:16px;margin-right:0}@media screen and (-ms-high-contrast:active){.mat-menu-item-highlighted,.mat-menu-item.cdk-keyboard-focused,.mat-menu-item.cdk-program-focused{outline:dotted 1px}}.mat-menu-item-submenu-trigger{padding-right:32px}.mat-menu-item-submenu-trigger::after{width:0;height:0;border-style:solid;border-width:5px 0 5px 5px;border-color:transparent transparent transparent currentColor;content:'';display:inline-block;position:absolute;top:50%;right:16px;transform:translateY(-50%)}[dir=rtl] .mat-menu-item-submenu-trigger{padding-right:16px;padding-left:32px}[dir=rtl] .mat-menu-item-submenu-trigger::after{right:auto;left:16px;transform:rotateY(180deg) translateY(-50%)}.mat-menu-panel.ng-animating .mat-menu-item-submenu-trigger{pointer-events:none}button.mat-menu-item{width:100%}.mat-menu-item .mat-menu-ripple{top:0;left:0;right:0;bottom:0;position:absolute;pointer-events:none}"],
745
+ template: "<ng-template><div class=\"mat-menu-panel\" [ngClass]=\"_classList\" (keydown)=\"_handleKeydown($event)\" (click)=\"closed.emit('click')\" [@transformMenu]=\"_panelAnimationState\" (@transformMenu.start)=\"_onAnimationStart($event)\" (@transformMenu.done)=\"_onAnimationDone($event)\" tabindex=\"-1\" role=\"menu\"><div class=\"mat-menu-content\"><ng-content></ng-content></div></div></ng-template>",
746
+ styles: [".mat-menu-panel{min-width:112px;max-width:280px;overflow:auto;-webkit-overflow-scrolling:touch;max-height:calc(100vh - 48px);border-radius:4px;outline:0}.mat-menu-panel.ng-animating{pointer-events:none}@media (-ms-high-contrast:active){.mat-menu-panel{outline:solid 1px}}.mat-menu-content:not(:empty){padding-top:8px;padding-bottom:8px}.mat-menu-item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;outline:0;border:none;-webkit-tap-highlight-color:transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;line-height:48px;height:48px;padding:0 16px;text-align:left;text-decoration:none;max-width:100%;position:relative}.mat-menu-item::-moz-focus-inner{border:0}.mat-menu-item[disabled]{cursor:default}[dir=rtl] .mat-menu-item{text-align:right}.mat-menu-item .mat-icon{margin-right:16px;vertical-align:middle}.mat-menu-item .mat-icon svg{vertical-align:top}[dir=rtl] .mat-menu-item .mat-icon{margin-left:16px;margin-right:0}@media (-ms-high-contrast:active){.mat-menu-item-highlighted,.mat-menu-item.cdk-keyboard-focused,.mat-menu-item.cdk-program-focused{outline:dotted 1px}}.mat-menu-item-submenu-trigger{padding-right:32px}.mat-menu-item-submenu-trigger::after{width:0;height:0;border-style:solid;border-width:5px 0 5px 5px;border-color:transparent transparent transparent currentColor;content:'';display:inline-block;position:absolute;top:50%;right:16px;transform:translateY(-50%)}[dir=rtl] .mat-menu-item-submenu-trigger{padding-right:16px;padding-left:32px}[dir=rtl] .mat-menu-item-submenu-trigger::after{right:auto;left:16px;transform:rotateY(180deg) translateY(-50%)}button.mat-menu-item{width:100%}.mat-menu-item .mat-menu-ripple{top:0;left:0;right:0;bottom:0;position:absolute;pointer-events:none}"],
726
747
  changeDetection: ChangeDetectionStrategy.OnPush,
727
748
  encapsulation: ViewEncapsulation.None,
728
749
  exportAs: 'matMenu',
@@ -758,11 +779,12 @@ MatMenu.propDecorators = {
758
779
 
759
780
  /**
760
781
  * @fileoverview added by tsickle
761
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
782
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
762
783
  */
763
- /** *
784
+ /**
764
785
  * Injection token that determines the scroll handling while the menu is open.
765
- @type {?} */
786
+ * @type {?}
787
+ */
766
788
  const MAT_MENU_SCROLL_STRATEGY = new InjectionToken('mat-menu-scroll-strategy');
767
789
  /**
768
790
  * \@docs-private
@@ -772,22 +794,26 @@ const MAT_MENU_SCROLL_STRATEGY = new InjectionToken('mat-menu-scroll-strategy');
772
794
  function MAT_MENU_SCROLL_STRATEGY_FACTORY(overlay) {
773
795
  return () => overlay.scrollStrategies.reposition();
774
796
  }
775
- /** *
797
+ /**
776
798
  * \@docs-private
777
- @type {?} */
799
+ * @type {?}
800
+ */
778
801
  const MAT_MENU_SCROLL_STRATEGY_FACTORY_PROVIDER = {
779
802
  provide: MAT_MENU_SCROLL_STRATEGY,
780
803
  deps: [Overlay],
781
804
  useFactory: MAT_MENU_SCROLL_STRATEGY_FACTORY,
782
805
  };
783
- /** *
806
+ /**
784
807
  * Default top padding of the menu panel.
785
- @type {?} */
808
+ * @type {?}
809
+ */
786
810
  const MENU_PANEL_TOP_PADDING = 8;
787
- /** *
811
+ /**
788
812
  * Options for binding a passive event listener.
789
- @type {?} */
813
+ * @type {?}
814
+ */
790
815
  const passiveEventListenerOptions = normalizePassiveListenerOptions({ passive: true });
816
+ // TODO(andrewseguin): Remove the kebab versions in favor of camelCased attribute selectors
791
817
  /**
792
818
  * This directive is intended to be used in conjunction with an mat-menu tag. It is
793
819
  * responsible for toggling the display of the provided menu instance.
@@ -833,6 +859,7 @@ class MatMenuTrigger {
833
859
  * @deprecated Switch to `menuOpened` instead
834
860
  * \@breaking-change 8.0.0
835
861
  */
862
+ // tslint:disable-next-line:no-output-on-prefix
836
863
  this.onMenuOpen = this.menuOpened;
837
864
  /**
838
865
  * Event emitted when the associated menu is closed.
@@ -843,6 +870,7 @@ class MatMenuTrigger {
843
870
  * @deprecated Switch to `menuClosed` instead
844
871
  * \@breaking-change 8.0.0
845
872
  */
873
+ // tslint:disable-next-line:no-output-on-prefix
846
874
  this.onMenuClose = this.menuClosed;
847
875
  _element.nativeElement.addEventListener('touchstart', this._handleTouchStart, passiveEventListenerOptions);
848
876
  if (_menuItemInstance) {
@@ -945,7 +973,11 @@ class MatMenuTrigger {
945
973
  this._checkMenu();
946
974
  /** @type {?} */
947
975
  const overlayRef = this._createOverlay();
948
- this._setPosition(/** @type {?} */ (overlayRef.getConfig().positionStrategy));
976
+ /** @type {?} */
977
+ const overlayConfig = overlayRef.getConfig();
978
+ this._setPosition((/** @type {?} */ (overlayConfig.positionStrategy)));
979
+ overlayConfig.hasBackdrop = this.menu.hasBackdrop == null ? !this.triggersSubmenu() :
980
+ this.menu.hasBackdrop;
949
981
  overlayRef.attach(this._getPortal());
950
982
  if (this.menu.lazyContent) {
951
983
  this.menu.lazyContent.attach(this.menuData);
@@ -978,6 +1010,7 @@ class MatMenuTrigger {
978
1010
  }
979
1011
  /**
980
1012
  * Closes the menu and does the necessary cleanup.
1013
+ * @private
981
1014
  * @return {?}
982
1015
  */
983
1016
  _destroyMenu() {
@@ -996,7 +1029,7 @@ class MatMenuTrigger {
996
1029
  .pipe(filter(event => event.toState === 'void'), take(1),
997
1030
  // Interrupt if the content got re-attached.
998
1031
  takeUntil(menu.lazyContent._attached))
999
- .subscribe(() => /** @type {?} */ ((menu.lazyContent)).detach(), undefined, () => {
1032
+ .subscribe(() => (/** @type {?} */ (menu.lazyContent)).detach(), undefined, () => {
1000
1033
  // No matter whether the content got re-attached, reset the menu.
1001
1034
  this._resetMenu();
1002
1035
  });
@@ -1015,6 +1048,7 @@ class MatMenuTrigger {
1015
1048
  /**
1016
1049
  * This method sets the menu state to open and focuses the first item if
1017
1050
  * the menu was opened via the keyboard.
1051
+ * @private
1018
1052
  * @return {?}
1019
1053
  */
1020
1054
  _initMenu() {
@@ -1026,6 +1060,7 @@ class MatMenuTrigger {
1026
1060
  }
1027
1061
  /**
1028
1062
  * Updates the menu elevation based on the amount of parent menus that it has.
1063
+ * @private
1029
1064
  * @return {?}
1030
1065
  */
1031
1066
  _setMenuElevation() {
@@ -1044,6 +1079,7 @@ class MatMenuTrigger {
1044
1079
  /**
1045
1080
  * This method resets the menu when it's closed, most importantly restoring
1046
1081
  * focus to the menu trigger if the menu was opened via the keyboard.
1082
+ * @private
1047
1083
  * @return {?}
1048
1084
  */
1049
1085
  _resetMenu() {
@@ -1061,7 +1097,9 @@ class MatMenuTrigger {
1061
1097
  }
1062
1098
  this._openedBy = null;
1063
1099
  }
1100
+ // set state rather than toggle to support triggers sharing a menu
1064
1101
  /**
1102
+ * @private
1065
1103
  * @param {?} isOpen
1066
1104
  * @return {?}
1067
1105
  */
@@ -1075,6 +1113,7 @@ class MatMenuTrigger {
1075
1113
  /**
1076
1114
  * This method checks that a valid instance of MatMenu has been passed into
1077
1115
  * matMenuTriggerFor. If not, an exception is thrown.
1116
+ * @private
1078
1117
  * @return {?}
1079
1118
  */
1080
1119
  _checkMenu() {
@@ -1085,13 +1124,14 @@ class MatMenuTrigger {
1085
1124
  /**
1086
1125
  * This method creates the overlay from the provided menu's template and saves its
1087
1126
  * OverlayRef so that it can be attached to the DOM when openMenu is called.
1127
+ * @private
1088
1128
  * @return {?}
1089
1129
  */
1090
1130
  _createOverlay() {
1091
1131
  if (!this._overlayRef) {
1092
1132
  /** @type {?} */
1093
1133
  const config = this._getOverlayConfig();
1094
- this._subscribeToPositions(/** @type {?} */ (config.positionStrategy));
1134
+ this._subscribeToPositions((/** @type {?} */ (config.positionStrategy)));
1095
1135
  this._overlayRef = this._overlay.create(config);
1096
1136
  // Consume the `keydownEvents` in order to prevent them from going to another overlay.
1097
1137
  // Ideally we'd also have our keyboard event logic in here, however doing so will
@@ -1102,6 +1142,7 @@ class MatMenuTrigger {
1102
1142
  }
1103
1143
  /**
1104
1144
  * This method builds the configuration object needed to create the overlay, the OverlayState.
1145
+ * @private
1105
1146
  * @return {?} OverlayConfig
1106
1147
  */
1107
1148
  _getOverlayConfig() {
@@ -1110,7 +1151,6 @@ class MatMenuTrigger {
1110
1151
  .flexibleConnectedTo(this._element)
1111
1152
  .withLockedPosition()
1112
1153
  .withTransformOriginOn('.mat-menu-panel'),
1113
- hasBackdrop: this.menu.hasBackdrop == null ? !this.triggersSubmenu() : this.menu.hasBackdrop,
1114
1154
  backdropClass: this.menu.backdropClass || 'cdk-overlay-transparent-backdrop',
1115
1155
  scrollStrategy: this._scrollStrategy(),
1116
1156
  direction: this._dir
@@ -1120,6 +1160,7 @@ class MatMenuTrigger {
1120
1160
  * Listens to changes in the position of the overlay and sets the correct classes
1121
1161
  * on the menu based on the new position. This ensures the animation origin is always
1122
1162
  * correct, even if a fallback position is used for the overlay.
1163
+ * @private
1123
1164
  * @param {?} position
1124
1165
  * @return {?}
1125
1166
  */
@@ -1129,14 +1170,15 @@ class MatMenuTrigger {
1129
1170
  /** @type {?} */
1130
1171
  const posX = change.connectionPair.overlayX === 'start' ? 'after' : 'before';
1131
1172
  /** @type {?} */
1132
- const posY = change.connectionPair.overlayY === 'top' ? 'below' : 'above'; /** @type {?} */
1133
- ((this.menu.setPositionClasses))(posX, posY);
1173
+ const posY = change.connectionPair.overlayY === 'top' ? 'below' : 'above';
1174
+ (/** @type {?} */ (this.menu.setPositionClasses))(posX, posY);
1134
1175
  });
1135
1176
  }
1136
1177
  }
1137
1178
  /**
1138
1179
  * Sets the appropriate positions on a position strategy
1139
1180
  * so the overlay connects with the trigger correctly.
1181
+ * @private
1140
1182
  * @param {?} positionStrategy Strategy whose position to update.
1141
1183
  * @return {?}
1142
1184
  */
@@ -1179,6 +1221,7 @@ class MatMenuTrigger {
1179
1221
  }
1180
1222
  /**
1181
1223
  * Cleans up the active subscriptions.
1224
+ * @private
1182
1225
  * @return {?}
1183
1226
  */
1184
1227
  _cleanUpSubscriptions() {
@@ -1187,13 +1230,14 @@ class MatMenuTrigger {
1187
1230
  }
1188
1231
  /**
1189
1232
  * Returns a stream that emits whenever an action that should close the menu occurs.
1233
+ * @private
1190
1234
  * @return {?}
1191
1235
  */
1192
1236
  _menuClosingActions() {
1193
1237
  /** @type {?} */
1194
- const backdrop = /** @type {?} */ ((this._overlayRef)).backdropClick();
1238
+ const backdrop = (/** @type {?} */ (this._overlayRef)).backdropClick();
1195
1239
  /** @type {?} */
1196
- const detachments = /** @type {?} */ ((this._overlayRef)).detachments();
1240
+ const detachments = (/** @type {?} */ (this._overlayRef)).detachments();
1197
1241
  /** @type {?} */
1198
1242
  const parentClose = this._parentMenu ? this._parentMenu.closed : of();
1199
1243
  /** @type {?} */
@@ -1248,6 +1292,7 @@ class MatMenuTrigger {
1248
1292
  }
1249
1293
  /**
1250
1294
  * Handles the cases where the user hovers over the trigger.
1295
+ * @private
1251
1296
  * @return {?}
1252
1297
  */
1253
1298
  _handleHover() {
@@ -1279,6 +1324,7 @@ class MatMenuTrigger {
1279
1324
  }
1280
1325
  /**
1281
1326
  * Gets the portal that should be attached to the overlay.
1327
+ * @private
1282
1328
  * @return {?}
1283
1329
  */
1284
1330
  _getPortal() {
@@ -1327,7 +1373,7 @@ MatMenuTrigger.propDecorators = {
1327
1373
 
1328
1374
  /**
1329
1375
  * @fileoverview added by tsickle
1330
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1376
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
1331
1377
  */
1332
1378
  class MatMenuModule {
1333
1379
  }
@@ -1347,18 +1393,18 @@ MatMenuModule.decorators = [
1347
1393
 
1348
1394
  /**
1349
1395
  * @fileoverview added by tsickle
1350
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1396
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
1351
1397
  */
1352
1398
 
1353
1399
  /**
1354
1400
  * @fileoverview added by tsickle
1355
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1401
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
1356
1402
  */
1357
1403
 
1358
1404
  /**
1359
1405
  * @fileoverview added by tsickle
1360
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1406
+ * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
1361
1407
  */
1362
1408
 
1363
- export { MAT_MENU_SCROLL_STRATEGY, MatMenuModule, MatMenu, MAT_MENU_DEFAULT_OPTIONS, MatMenuItem, MatMenuTrigger, matMenuAnimations, fadeInItems, transformMenu, MatMenuContent, MAT_MENU_DEFAULT_OPTIONS_FACTORY as ɵa24, MatMenuItemBase as ɵb24, _MatMenuItemMixinBase as ɵc24, MAT_MENU_PANEL as ɵf24, MAT_MENU_SCROLL_STRATEGY_FACTORY as ɵd24, MAT_MENU_SCROLL_STRATEGY_FACTORY_PROVIDER as ɵe24 };
1409
+ export { MAT_MENU_SCROLL_STRATEGY, MatMenuModule, MatMenu, MAT_MENU_DEFAULT_OPTIONS, MatMenuItem, MatMenuTrigger, matMenuAnimations, fadeInItems, transformMenu, MatMenuContent, MAT_MENU_DEFAULT_OPTIONS_FACTORY as ɵa23, MatMenuItemBase as ɵb23, _MatMenuItemMixinBase as ɵc23, MAT_MENU_PANEL as ɵf23, MAT_MENU_SCROLL_STRATEGY_FACTORY as ɵd23, MAT_MENU_SCROLL_STRATEGY_FACTORY_PROVIDER as ɵe23 };
1364
1410
  //# sourceMappingURL=menu.js.map