@shortfuse/materialdesignweb 0.4.0 → 0.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (452) hide show
  1. package/README.md +155 -79
  2. package/bin/generate-css.js +12 -0
  3. package/components/Badge.css +30 -0
  4. package/components/Badge.js +15 -0
  5. package/components/Body.css +14 -0
  6. package/components/Body.js +7 -0
  7. package/components/BottomAppBar.css +23 -0
  8. package/components/BottomAppBar.js +25 -0
  9. package/components/Box.css +31 -0
  10. package/components/Box.js +24 -0
  11. package/components/Button.css +146 -0
  12. package/components/Button.js +95 -0
  13. package/components/Button.md +61 -0
  14. package/components/Card.css +109 -0
  15. package/components/Card.js +82 -0
  16. package/components/Checkbox.css +77 -0
  17. package/components/Checkbox.js +59 -0
  18. package/components/CheckboxIcon.css +89 -0
  19. package/components/CheckboxIcon.js +41 -0
  20. package/components/Chip.css +35 -0
  21. package/components/Chip.js +22 -0
  22. package/components/Dialog.css +235 -0
  23. package/components/Dialog.js +327 -0
  24. package/components/DialogActions.js +13 -0
  25. package/components/Divider.css +41 -0
  26. package/components/Divider.js +13 -0
  27. package/components/ExtendedFab.css +24 -0
  28. package/components/ExtendedFab.js +11 -0
  29. package/components/Fab.css +23 -0
  30. package/components/Fab.js +26 -0
  31. package/components/FilterChip.css +80 -0
  32. package/components/FilterChip.js +51 -0
  33. package/components/Headline.css +14 -0
  34. package/components/Headline.js +33 -0
  35. package/components/Icon.css +76 -0
  36. package/components/Icon.js +174 -0
  37. package/components/IconButton.css +151 -0
  38. package/components/IconButton.js +65 -0
  39. package/components/Input.js +16 -0
  40. package/components/Label.css +14 -0
  41. package/components/Label.js +7 -0
  42. package/components/Layout.css +19 -0
  43. package/components/Layout.js +12 -0
  44. package/components/List.css +12 -0
  45. package/components/List.js +17 -0
  46. package/components/ListItem.css +224 -0
  47. package/components/ListItem.js +112 -0
  48. package/components/ListOption.css +34 -0
  49. package/components/ListOption.js +122 -0
  50. package/components/ListSelect.css +9 -0
  51. package/components/ListSelect.js +206 -0
  52. package/components/Menu.css +171 -0
  53. package/components/Menu.js +470 -0
  54. package/components/MenuItem.css +53 -0
  55. package/components/MenuItem.js +215 -0
  56. package/components/Nav.css +17 -0
  57. package/components/Nav.js +23 -0
  58. package/components/NavBar.css +34 -0
  59. package/components/NavBar.js +88 -0
  60. package/components/NavBarItem.css +41 -0
  61. package/components/NavBarItem.js +7 -0
  62. package/components/NavDrawer.css +31 -0
  63. package/components/NavDrawer.js +13 -0
  64. package/components/NavDrawerItem.css +42 -0
  65. package/components/NavDrawerItem.js +12 -0
  66. package/components/NavItem.css +181 -0
  67. package/components/NavItem.js +83 -0
  68. package/components/NavRail.css +47 -0
  69. package/components/NavRail.js +17 -0
  70. package/components/NavRailItem.css +25 -0
  71. package/components/NavRailItem.js +7 -0
  72. package/components/Option.js +91 -0
  73. package/components/Outline.css +138 -0
  74. package/components/Pane.css +261 -0
  75. package/components/Pane.js +21 -0
  76. package/components/Progress.css +74 -0
  77. package/components/Progress.js +67 -0
  78. package/components/ProgressCircle.css +226 -0
  79. package/components/ProgressLine.css +155 -0
  80. package/components/Radio.css +83 -0
  81. package/components/Radio.js +42 -0
  82. package/components/RadioIcon.css +73 -0
  83. package/components/RadioIcon.js +37 -0
  84. package/components/Ripple.css +74 -0
  85. package/components/Ripple.js +114 -0
  86. package/components/SegmentedButton.css +94 -0
  87. package/components/SegmentedButton.js +49 -0
  88. package/components/SegmentedButtonGroup.css +12 -0
  89. package/components/SegmentedButtonGroup.js +44 -0
  90. package/components/Select.css +52 -0
  91. package/components/Select.js +71 -0
  92. package/components/Shape.css +132 -0
  93. package/components/Shape.js +25 -0
  94. package/components/Slider.css +306 -0
  95. package/components/Slider.js +206 -0
  96. package/components/Snackbar.css +80 -0
  97. package/components/Snackbar.js +75 -0
  98. package/components/Surface.css +10 -0
  99. package/components/Surface.js +23 -0
  100. package/components/Switch.css +63 -0
  101. package/components/Switch.js +127 -0
  102. package/components/SwitchIcon.css +177 -0
  103. package/components/SwitchIcon.js +89 -0
  104. package/components/SwitchIconAnimations.css +89 -0
  105. package/components/Tab.css +85 -0
  106. package/components/Tab.js +103 -0
  107. package/components/TabContent.js +151 -0
  108. package/components/TabList.css +129 -0
  109. package/components/TabList.js +309 -0
  110. package/components/TabPanel.js +37 -0
  111. package/components/TextArea.css +93 -0
  112. package/components/TextArea.js +229 -0
  113. package/components/Title.css +14 -0
  114. package/components/Title.js +15 -0
  115. package/components/Tooltip.css +40 -0
  116. package/components/Tooltip.js +22 -0
  117. package/components/TopAppBar.css +209 -0
  118. package/components/TopAppBar.js +201 -0
  119. package/core/Composition.js +988 -0
  120. package/core/CustomElement.js +844 -0
  121. package/core/ICustomElement.d.ts +288 -0
  122. package/core/ICustomElement.js +1 -0
  123. package/core/css.js +51 -0
  124. package/core/customTypes.js +125 -0
  125. package/core/dom.js +56 -245
  126. package/core/identify.js +40 -0
  127. package/core/observe.js +410 -0
  128. package/core/template.js +121 -0
  129. package/core/typings.d.ts +135 -0
  130. package/core/typings.js +1 -0
  131. package/mixins/AriaReflectorMixin.js +42 -0
  132. package/mixins/AriaToolbarMixin.js +13 -0
  133. package/mixins/ControlMixin.css +57 -0
  134. package/mixins/ControlMixin.js +212 -0
  135. package/mixins/DensityMixin.css +40 -0
  136. package/mixins/DensityMixin.js +11 -0
  137. package/mixins/FlexableMixin.css +79 -0
  138. package/mixins/FlexableMixin.js +32 -0
  139. package/mixins/FormAssociatedMixin.js +170 -0
  140. package/mixins/InputMixin.js +335 -0
  141. package/mixins/KeyboardNavMixin.js +244 -0
  142. package/mixins/RTLObserverMixin.js +35 -0
  143. package/mixins/ResizeObserverMixin.js +38 -0
  144. package/mixins/RippleMixin.css +12 -0
  145. package/mixins/RippleMixin.js +115 -0
  146. package/mixins/ScrollListenerMixin.js +100 -0
  147. package/mixins/ShapeMixin.css +135 -0
  148. package/mixins/ShapeMixin.js +31 -0
  149. package/mixins/StateMixin.css +82 -0
  150. package/mixins/StateMixin.js +114 -0
  151. package/mixins/SurfaceMixin.css +150 -0
  152. package/mixins/SurfaceMixin.js +32 -0
  153. package/mixins/TextFieldMixin.css +657 -0
  154. package/mixins/TextFieldMixin.js +121 -0
  155. package/mixins/ThemableMixin.css +204 -0
  156. package/mixins/ThemableMixin.js +16 -0
  157. package/mixins/TooltipTriggerMixin.css +27 -0
  158. package/mixins/TooltipTriggerMixin.js +366 -0
  159. package/mixins/TouchTargetMixin.css +26 -0
  160. package/mixins/TouchTargetMixin.js +9 -0
  161. package/package.json +57 -41
  162. package/theming/index.js +594 -0
  163. package/theming/loader.js +24 -0
  164. package/utils/cli.js +11 -0
  165. package/utils/color_keywords.js +151 -0
  166. package/utils/hct/Cam16.js +298 -0
  167. package/utils/hct/CorePalette.js +84 -0
  168. package/utils/hct/Hct.js +172 -0
  169. package/utils/hct/Scheme.js +587 -0
  170. package/utils/hct/TonalPalette.js +68 -0
  171. package/utils/hct/ViewingConditions.js +136 -0
  172. package/utils/hct/blend.js +93 -0
  173. package/utils/hct/colorUtils.js +302 -0
  174. package/utils/hct/hctSolver.js +559 -0
  175. package/utils/hct/helper.js +182 -0
  176. package/utils/hct/mathUtils.js +153 -0
  177. package/utils/jsonMergePatch.js +100 -0
  178. package/utils/jsx-runtime.js +101 -0
  179. package/utils/popup.js +117 -0
  180. package/utils/svg.js +129 -0
  181. package/.browserslistrc +0 -3
  182. package/.eslintrc.json +0 -153
  183. package/.stylelintrc.json +0 -600
  184. package/.vscode/launch.json +0 -31
  185. package/.vscode/settings.json +0 -3
  186. package/.vscode/tasks.json +0 -32
  187. package/CHANGELOG.md +0 -24
  188. package/CODE_OF_CONDUCT.md +0 -46
  189. package/adapters/datatable/column.js +0 -203
  190. package/adapters/datatable/index.js +0 -972
  191. package/adapters/dom/index.js +0 -601
  192. package/adapters/list/index.js +0 -69
  193. package/adapters/search/index.js +0 -521
  194. package/components/appbar/_spec.scss +0 -225
  195. package/components/appbar/_theme.scss +0 -0
  196. package/components/appbar/index.scss +0 -2
  197. package/components/banner/_spec.scss +0 -118
  198. package/components/banner/_theme.scss +0 -0
  199. package/components/banner/index.scss +0 -2
  200. package/components/bottomnav/README.md +0 -85
  201. package/components/bottomnav/_spec.scss +0 -157
  202. package/components/bottomnav/_theme.scss +0 -0
  203. package/components/bottomnav/index.js +0 -122
  204. package/components/bottomnav/index.scss +0 -2
  205. package/components/bottomnav/item.js +0 -89
  206. package/components/button/README.md +0 -61
  207. package/components/button/_spec.scss +0 -161
  208. package/components/button/_theme.scss +0 -65
  209. package/components/button/index.eta +0 -32
  210. package/components/button/index.js +0 -43
  211. package/components/button/index.pug +0 -18
  212. package/components/button/index.scss +0 -2
  213. package/components/card/_spec.scss +0 -249
  214. package/components/card/_theme.scss +0 -0
  215. package/components/card/index.scss +0 -2
  216. package/components/chip/_spec.scss +0 -134
  217. package/components/chip/_theme.scss +0 -177
  218. package/components/chip/index.js +0 -21
  219. package/components/chip/index.scss +0 -2
  220. package/components/chip/item.js +0 -20
  221. package/components/datatable/_spec.scss +0 -288
  222. package/components/datatable/_theme.scss +0 -154
  223. package/components/datatable/cell.js +0 -45
  224. package/components/datatable/columnheader.js +0 -47
  225. package/components/datatable/index.js +0 -388
  226. package/components/datatable/index.scss +0 -2
  227. package/components/datatable/row.js +0 -49
  228. package/components/datatable/rowheader.js +0 -18
  229. package/components/dialog/_spec.scss +0 -213
  230. package/components/dialog/_theme.scss +0 -0
  231. package/components/dialog/index.js +0 -627
  232. package/components/dialog/index.scss +0 -2
  233. package/components/divider/_spec.scss +0 -13
  234. package/components/divider/_theme.scss +0 -0
  235. package/components/divider/index.scss +0 -2
  236. package/components/elevation/_spec.scss +0 -9
  237. package/components/elevation/_theme.scss +0 -0
  238. package/components/elevation/index.scss +0 -2
  239. package/components/fab/_spec.scss +0 -222
  240. package/components/fab/_theme.scss +0 -0
  241. package/components/fab/index.js +0 -103
  242. package/components/fab/index.scss +0 -2
  243. package/components/grid/_spec.scss +0 -312
  244. package/components/grid/_theme.scss +0 -0
  245. package/components/grid/index.scss +0 -2
  246. package/components/layout/_mixins.scss +0 -33
  247. package/components/layout/_spec.scss +0 -1012
  248. package/components/layout/_theme.scss +0 -44
  249. package/components/layout/index.js +0 -464
  250. package/components/layout/index.scss +0 -2
  251. package/components/list/_spec.scss +0 -397
  252. package/components/list/_theme.scss +0 -111
  253. package/components/list/content.js +0 -110
  254. package/components/list/index.js +0 -260
  255. package/components/list/index.scss +0 -2
  256. package/components/list/item.js +0 -170
  257. package/components/list/secondary.js +0 -46
  258. package/components/menu/_spec.scss +0 -362
  259. package/components/menu/_theme.scss +0 -0
  260. package/components/menu/index.js +0 -721
  261. package/components/menu/index.scss +0 -2
  262. package/components/menu/item.js +0 -239
  263. package/components/progress/_spec.scss +0 -147
  264. package/components/progress/_theme.scss +0 -0
  265. package/components/progress/index.js +0 -36
  266. package/components/progress/index.scss +0 -2
  267. package/components/selection/_spec.scss +0 -386
  268. package/components/selection/_theme.scss +0 -166
  269. package/components/selection/index.eta +0 -60
  270. package/components/selection/index.js +0 -76
  271. package/components/selection/index.pug +0 -30
  272. package/components/selection/index.scss +0 -2
  273. package/components/selection/input.js +0 -56
  274. package/components/selection/radiogroup.js +0 -47
  275. package/components/slider/_spec.scss +0 -64
  276. package/components/slider/_theme.scss +0 -0
  277. package/components/slider/index.scss +0 -2
  278. package/components/snackbar/_spec.scss +0 -195
  279. package/components/snackbar/_theme.scss +0 -0
  280. package/components/snackbar/index.js +0 -344
  281. package/components/snackbar/index.scss +0 -2
  282. package/components/tab/_spec.scss +0 -235
  283. package/components/tab/_theme.scss +0 -0
  284. package/components/tab/content.js +0 -205
  285. package/components/tab/index.js +0 -260
  286. package/components/tab/index.scss +0 -2
  287. package/components/tab/item.js +0 -89
  288. package/components/tab/list.js +0 -210
  289. package/components/tab/panel.js +0 -54
  290. package/components/template/_theme.scss +0 -27
  291. package/components/textfield/README.md +0 -179
  292. package/components/textfield/_mixins.scss +0 -52
  293. package/components/textfield/_spec.scss +0 -809
  294. package/components/textfield/_theme.scss +0 -299
  295. package/components/textfield/index.eta +0 -74
  296. package/components/textfield/index.js +0 -168
  297. package/components/textfield/index.pug +0 -30
  298. package/components/textfield/index.scss +0 -2
  299. package/components/tooltip/_spec.scss +0 -188
  300. package/components/tooltip/_theme.scss +0 -0
  301. package/components/tooltip/index.scss +0 -2
  302. package/components/type/_spec.scss +0 -224
  303. package/components/type/_theme.scss +0 -0
  304. package/components/type/index.scss +0 -2
  305. package/core/_breakpoint.scss +0 -189
  306. package/core/_elevation.scss +0 -38
  307. package/core/_length.scss +0 -9
  308. package/core/_motion.scss +0 -31
  309. package/core/_platform.scss +0 -34
  310. package/core/_type.scss +0 -127
  311. package/core/aria/attributes.js +0 -141
  312. package/core/aria/button.js +0 -50
  313. package/core/aria/keyboard.js +0 -93
  314. package/core/aria/rovingtabindex.js +0 -178
  315. package/core/aria/tab.js +0 -60
  316. package/core/color/_spec.scss +0 -0
  317. package/core/color/_theme.scss +0 -390
  318. package/core/color/index.scss +0 -2
  319. package/core/document/index.js +0 -39
  320. package/core/overlay/_spec.scss +0 -31
  321. package/core/overlay/_theme.scss +0 -171
  322. package/core/overlay/index.js +0 -108
  323. package/core/overlay/index.scss +0 -2
  324. package/core/ripple/_spec.scss +0 -197
  325. package/core/ripple/_theme.scss +0 -40
  326. package/core/ripple/index.js +0 -294
  327. package/core/ripple/index.scss +0 -2
  328. package/core/theme/_config.scss +0 -2
  329. package/core/theme/_mixins.scss +0 -172
  330. package/core/theme/_palettes.scss +0 -406
  331. package/core/theme/_variables.scss +0 -24
  332. package/core/theme/index.js +0 -50
  333. package/core/throttler.js +0 -42
  334. package/core/transition/index.js +0 -468
  335. package/docs/_flex.scss +0 -22
  336. package/docs/_menuoptions.js +0 -183
  337. package/docs/_mixins.pug +0 -155
  338. package/docs/_partials/_androidnavbar.eta +0 -5
  339. package/docs/_partials/_androidstatusbar.eta +0 -13
  340. package/docs/_partials/_appbar.eta +0 -29
  341. package/docs/_partials/_buttontest.eta +0 -31
  342. package/docs/_partials/_header.eta +0 -149
  343. package/docs/_partials/_navlistitem.eta +0 -16
  344. package/docs/_partials/_target.eta +0 -1
  345. package/docs/_sample-utils.js +0 -93
  346. package/docs/_storage.js +0 -33
  347. package/docs/docs.scss +0 -295
  348. package/docs/index.eta +0 -16
  349. package/docs/index.js +0 -0
  350. package/docs/pages/appbar.eta +0 -114
  351. package/docs/pages/appbar.js +0 -0
  352. package/docs/pages/appbar.pug +0 -78
  353. package/docs/pages/bottomnav.eta +0 -188
  354. package/docs/pages/bottomnav.js +0 -115
  355. package/docs/pages/bottomnav.pug +0 -137
  356. package/docs/pages/button.eta +0 -124
  357. package/docs/pages/button.js +0 -224
  358. package/docs/pages/button.pug +0 -121
  359. package/docs/pages/card.eta +0 -90
  360. package/docs/pages/card.js +0 -177
  361. package/docs/pages/card.pug +0 -74
  362. package/docs/pages/chip.eta +0 -122
  363. package/docs/pages/chip.js +0 -82
  364. package/docs/pages/chip.pug +0 -91
  365. package/docs/pages/color.eta +0 -143
  366. package/docs/pages/color.js +0 -262
  367. package/docs/pages/color.pug +0 -121
  368. package/docs/pages/datatable.eta +0 -323
  369. package/docs/pages/datatable.js +0 -164
  370. package/docs/pages/datatable.pug +0 -283
  371. package/docs/pages/dialog.eta +0 -186
  372. package/docs/pages/dialog.js +0 -177
  373. package/docs/pages/dialog.pug +0 -132
  374. package/docs/pages/dom.eta +0 -26
  375. package/docs/pages/dom.js +0 -143
  376. package/docs/pages/dom.pug +0 -22
  377. package/docs/pages/elevation.eta +0 -35
  378. package/docs/pages/elevation.js +0 -0
  379. package/docs/pages/elevation.pug +0 -25
  380. package/docs/pages/fab.eta +0 -99
  381. package/docs/pages/fab.js +0 -44
  382. package/docs/pages/fab.pug +0 -66
  383. package/docs/pages/grid.eta +0 -135
  384. package/docs/pages/grid.js +0 -128
  385. package/docs/pages/grid.pug +0 -95
  386. package/docs/pages/layout.eta +0 -8
  387. package/docs/pages/layout.js +0 -0
  388. package/docs/pages/layout.pug +0 -7
  389. package/docs/pages/list.eta +0 -465
  390. package/docs/pages/list.js +0 -9
  391. package/docs/pages/list.pug +0 -326
  392. package/docs/pages/menu.eta +0 -276
  393. package/docs/pages/menu.js +0 -217
  394. package/docs/pages/menu.pug +0 -205
  395. package/docs/pages/overlay.eta +0 -69
  396. package/docs/pages/overlay.js +0 -4
  397. package/docs/pages/overlay.pug +0 -55
  398. package/docs/pages/progress.eta +0 -23
  399. package/docs/pages/progress.js +0 -12
  400. package/docs/pages/progress.pug +0 -16
  401. package/docs/pages/ripple.eta +0 -27
  402. package/docs/pages/ripple.js +0 -4
  403. package/docs/pages/ripple.pug +0 -21
  404. package/docs/pages/search.eta +0 -246
  405. package/docs/pages/search.js +0 -243
  406. package/docs/pages/search.pug +0 -165
  407. package/docs/pages/selection.eta +0 -111
  408. package/docs/pages/selection.js +0 -13
  409. package/docs/pages/selection.pug +0 -74
  410. package/docs/pages/slider.eta +0 -23
  411. package/docs/pages/slider.js +0 -0
  412. package/docs/pages/slider.pug +0 -17
  413. package/docs/pages/snackbar.eta +0 -83
  414. package/docs/pages/snackbar.js +0 -158
  415. package/docs/pages/snackbar.pug +0 -60
  416. package/docs/pages/tab.eta +0 -421
  417. package/docs/pages/tab.js +0 -151
  418. package/docs/pages/tab.pug +0 -304
  419. package/docs/pages/textfield.eta +0 -486
  420. package/docs/pages/textfield.js +0 -254
  421. package/docs/pages/textfield.pug +0 -360
  422. package/docs/pages/tooltip.eta +0 -94
  423. package/docs/pages/tooltip.js +0 -0
  424. package/docs/pages/tooltip.pug +0 -78
  425. package/docs/pages/transition.eta +0 -117
  426. package/docs/pages/transition.js +0 -54
  427. package/docs/pages/transition.pug +0 -76
  428. package/docs/pages/type.eta +0 -31
  429. package/docs/pages/type.js +0 -0
  430. package/docs/pages/type.pug +0 -29
  431. package/docs/postrender.js +0 -39
  432. package/docs/prerender.js +0 -16
  433. package/docs/pwa/_dialogs.eta +0 -143
  434. package/docs/pwa/_dialogs.pug +0 -96
  435. package/docs/pwa/_menus.eta +0 -16
  436. package/docs/pwa/_menus.pug +0 -11
  437. package/docs/pwa/pwa-prerender.js +0 -3
  438. package/docs/pwa/pwa.eta +0 -480
  439. package/docs/pwa/pwa.js +0 -306
  440. package/docs/pwa/pwa.pug +0 -325
  441. package/docs/pwa/pwa.scss +0 -26
  442. package/docs/spec.scss +0 -26
  443. package/docs/themes/_component-themes.scss +0 -26
  444. package/docs/themes/theme-colored-fallbacks.scss +0 -17
  445. package/docs/themes/theme-colored.scss +0 -17
  446. package/docs/themes/theme-default-fallbacks.scss +0 -17
  447. package/docs/themes/theme-default.scss +0 -17
  448. package/jsconfig.json +0 -12
  449. package/scripts/deploy-docs.sh +0 -9
  450. package/templates/index.eta +0 -2
  451. package/templates/index.pug +0 -3
  452. package/webpack.config.cjs +0 -257
@@ -0,0 +1,366 @@
1
+ import Tooltip from '../components/Tooltip.js';
2
+ import { canAnchorPopup } from '../utils/popup.js';
3
+
4
+ import styles from './TooltipTriggerMixin.css' assert { type: 'css' };
5
+
6
+ /**
7
+ * @param {ReturnType<import('./StateMixin.js').default>} Base
8
+ */
9
+ export default function TooltipTriggerMixin(Base) {
10
+ class TooltipTrigger extends Base {
11
+ static {
12
+ this.css(styles);
13
+
14
+ this.on({
15
+ composed({ template, html }) {
16
+ template.append(html`
17
+ <${Tooltip.elementName} role=tooltip id=tooltip
18
+ ><slot id=tooltip-slot
19
+ on-slotchange={onTooltipTriggerSlotChange} name=tooltip
20
+ >{tooltip}</slot></${Tooltip.elementName}>
21
+ `);
22
+ },
23
+ });
24
+ }
25
+
26
+ static TOOLTIP_MOUSE_IDLE_MS = 500;
27
+
28
+ static TOOLTIP_TOUCH_IDLE_MS = 1500;
29
+
30
+ /** @type {InstanceType<Tooltip>} */
31
+ #tooltip;
32
+
33
+ /** @type {any} */
34
+ #idleDebounce;
35
+
36
+ #pendingHide = false;
37
+
38
+ /** @type {HTMLElement[]} */
39
+ #watchedParents = [];
40
+
41
+ #resizeObserver;
42
+
43
+ #intersectObserver;
44
+
45
+ onParentScroll = (event) => {
46
+ this.updateTooltipPosition();
47
+ };
48
+
49
+ /** @param {any[]} args */
50
+ constructor(...args) {
51
+ super(...args);
52
+ this.#tooltip = /** @type {InstanceType<Tooltip>} */ (this.refs.tooltip.cloneNode(true));
53
+ this.#tooltip.removeAttribute('id');
54
+ this.#tooltip.style.setProperty('position', 'fixed');
55
+ this.#tooltip.setAttribute('aria-hidden', 'true');
56
+ this.#resizeObserver = new ResizeObserver((entries) => {
57
+ // console.log('RO', entries);
58
+ if (!this.#tooltip.open) return;
59
+ this.updateTooltipPosition();
60
+ });
61
+ const threshold = [0, 0.49, 0.5, 0.51, 1];
62
+ this.#intersectObserver = new IntersectionObserver((entries) => {
63
+ // console.log('IO', entries);
64
+ if (!this.#tooltip.open) return;
65
+ for (const entry of entries) {
66
+ if (entry.intersectionRatio <= 0) {
67
+ console.debug('Hide tooltip due to tooltip occlusion');
68
+ this.hideTooltip();
69
+ return;
70
+ }
71
+ if (entry.target === this.#tooltip) {
72
+ console.debug('Reposition tooltip due to possible tooltip occlusion');
73
+ this.updateTooltipPosition();
74
+ return;
75
+ }
76
+ if (entry.target === this) {
77
+ if (entry.intersectionRatio <= 0.5) {
78
+ console.debug('Hiding tooltip because target is occluded');
79
+ this.hideTooltip();
80
+ } else {
81
+ console.debug('Using InsectionObserver rect to update tooltip');
82
+ this.updateTooltipPosition(entry.boundingClientRect);
83
+ }
84
+ return;
85
+ }
86
+ }
87
+ console.debug('Updating tooltip position because offsetParent change.');
88
+ this.updateTooltipPosition();
89
+ }, { threshold });
90
+ // this.#tooltip.remove();
91
+ }
92
+
93
+ /**
94
+ * @param {Event & {currentTarget: HTMLSlotElement}} event
95
+ * @return {void}
96
+ */
97
+ onTooltipTriggerSlotChange(event) {
98
+ const tooltip = this.tooltipClone;
99
+ tooltip.replaceChildren(
100
+ ...event.currentTarget.assignedNodes()
101
+ .map((child) => child.cloneNode(true)),
102
+ );
103
+ }
104
+
105
+ /**
106
+ * @this {TooltipTrigger} this
107
+ * @param {FocusEvent} event
108
+ * @return {void}
109
+ */
110
+ onTooltipTriggerFocus(event) {
111
+ // console.log('getting focus', event);
112
+ if (this.disabledState) return;
113
+ if (this.matches(':active')) {
114
+ // console.log('abort from active');
115
+ return;
116
+ }
117
+ this.showTooltip();
118
+ }
119
+
120
+ /**
121
+ * @this {TooltipTrigger} this
122
+ * @param {KeyboardEvent} event
123
+ * @return {void}
124
+ */
125
+ onTooltipTriggerKeydown(event) {
126
+ if (event.ctrlKey) this.hideTooltip();
127
+ }
128
+
129
+ /**
130
+ * @this {TooltipTrigger} this
131
+ * @return {void}
132
+ */
133
+ onTooltipTriggerBlur() {
134
+ this.hideTooltip();
135
+ }
136
+
137
+ /**
138
+ * @param {MouseEvent|TouchEvent} event
139
+ * @this {TooltipTrigger} this
140
+ * @return {void}
141
+ */
142
+ onTooltipTriggerPointer(event) {
143
+ if (this.disabledState) return;
144
+ // console.log('tooltip event', event.type);
145
+ switch (event.type) {
146
+ case 'touchstart':
147
+ this.scheduleShowTooltip('touch');
148
+ break;
149
+ case 'touchend':
150
+ case 'touchcancel':
151
+ this.scheduleHideTooltip('touch');
152
+ break;
153
+ case 'click':
154
+ case 'mouseout':
155
+ this.cancelShowTooltip();
156
+ this.hideTooltip();
157
+ break;
158
+ case 'mousemove':
159
+ case 'mouseover':
160
+ this.scheduleShowTooltip('mouse');
161
+ break;
162
+ default:
163
+ }
164
+ }
165
+
166
+ get tooltipClone() {
167
+ return this.#tooltip;
168
+ }
169
+
170
+ get clonedTooltip() {
171
+ return this.#tooltip;
172
+ }
173
+
174
+ cancelShowTooltip() {
175
+ // console.log('cancel tooltiptimer');
176
+ clearTimeout(this.#idleDebounce);
177
+ }
178
+
179
+ /** @param {'mouse'|'touch'|'keyboard'} type */
180
+ scheduleHideTooltip(type) {
181
+ clearTimeout(this.#idleDebounce);
182
+ if (!this.#tooltip.open) {
183
+ // console.log('abort schedule (shown)');
184
+ return;
185
+ }
186
+ let timeout = 0;
187
+ switch (type) {
188
+ case 'mouse':
189
+ timeout = 0;
190
+ break;
191
+ case 'touch':
192
+ timeout = 1500;
193
+ break;
194
+ default:
195
+ }
196
+ // console.log('schedule tooltiptimer');
197
+ this.#idleDebounce = setTimeout(() => {
198
+ // console.log('hide timeout');
199
+ this.hideTooltip();
200
+ }, timeout);
201
+ }
202
+
203
+ /** @param {'mouse'|'touch'|'keyboard'} type */
204
+ scheduleShowTooltip(type) {
205
+ if (this.#tooltip.open) {
206
+ // console.log('abort schedule (shown)');
207
+ return;
208
+ }
209
+ let timeout = 0;
210
+ switch (type) {
211
+ case 'mouse':
212
+ timeout = this.constructor.TOOLTIP_MOUSE_IDLE_MS;
213
+ break;
214
+ case 'touch':
215
+ timeout = this.constructor.TOOLTIP_TOUCH_IDLE_MS;
216
+ break;
217
+ default:
218
+ }
219
+ // console.log('schedule tooltiptimer');
220
+ clearTimeout(this.#idleDebounce);
221
+ this.#idleDebounce = setTimeout(() => {
222
+ // console.log('idle');
223
+ this.showTooltip(type === 'touch');
224
+ }, timeout);
225
+ }
226
+
227
+ showTooltip(touch = false) {
228
+ if (this.#tooltip.open) return;
229
+ this.refs.tooltip.open = true;
230
+ this.refs.tooltip.touch = touch;
231
+ this.#tooltip.touch = touch;
232
+ document.body.append(this.#tooltip);
233
+ this.updateTooltipPosition();
234
+ this.#resizeObserver.observe(this, { box: 'border-box' });
235
+ this.#intersectObserver.observe(this);
236
+ this.#intersectObserver.observe(this.#tooltip);
237
+ /** @type {HTMLElement} */
238
+ let offsetParent = this;
239
+ while ((offsetParent = offsetParent.offsetParent)) {
240
+ this.#resizeObserver.observe(offsetParent, { box: 'border-box' });
241
+ // console.log('observing', offsetParent);
242
+ this.#watchedParents.push(offsetParent);
243
+ this.#intersectObserver.observe(offsetParent);
244
+ offsetParent.addEventListener('scroll', this.onParentScroll);
245
+ }
246
+ window.addEventListener('scroll', this.onParentScroll);
247
+
248
+ // console.log('offsetparent', this.offsetParent);
249
+
250
+ this.#tooltip.open = true;
251
+ }
252
+
253
+ hideTooltip() {
254
+ this.#resizeObserver.disconnect();
255
+ this.#intersectObserver.disconnect();
256
+ let parent;
257
+ while ((parent = this.#watchedParents.pop())) {
258
+ parent.removeEventListener('scroll', this.onParentScroll);
259
+ }
260
+ window.removeEventListener('scroll', this.onParentScroll);
261
+ this.#tooltip.open = false;
262
+ this.#tooltip.remove();
263
+ this.refs.tooltip.open = false;
264
+ const hoverStyle = this.refs.tooltip.style;
265
+ hoverStyle.removeProperty('width');
266
+ hoverStyle.removeProperty('height');
267
+ }
268
+
269
+ /**
270
+ * @param {DOMRect} [domRect]
271
+ * @return {void}
272
+ */
273
+ updateTooltipPosition(domRect) {
274
+ const offset = 8;
275
+ // const margin = 8;
276
+ /** @type {import('../utils/popup.js').CanAnchorPopUpOptions} */
277
+ const anchorOptions = {
278
+ anchor: domRect ?? this.getBoundingClientRect(),
279
+ width: this.#tooltip.clientWidth,
280
+ height: this.#tooltip.clientHeight,
281
+ // margin,
282
+ };
283
+
284
+ const isPageRTL = (getComputedStyle(this).direction === 'rtl');
285
+ const xStart = isPageRTL ? 'right' : 'left';
286
+ const xEnd = isPageRTL ? 'left' : 'right';
287
+ /** @type {import('../utils/popup.js').CanAnchorPopUpOptions[]} */
288
+ const preferences = [
289
+ { clientY: 'bottom', clientX: 'center', offsetY: offset },
290
+ { clientY: 'bottom', clientX: xStart, offsetY: offset },
291
+ { clientY: 'bottom', clientX: xEnd, offsetY: offset },
292
+ { clientY: 'top', clientX: 'center', offsetY: -offset },
293
+ { clientY: 'top', clientX: xStart, offsetY: -offset },
294
+ { clientY: 'top', clientX: xEnd, offsetY: -offset },
295
+ ];
296
+
297
+ let anchorResult;
298
+ for (const preference of preferences) {
299
+ anchorResult = canAnchorPopup({
300
+ ...anchorOptions,
301
+ ...preference,
302
+ });
303
+ if (anchorResult) break;
304
+ }
305
+
306
+ // console.log({ anchorResult });
307
+ if (!anchorResult) {
308
+ anchorResult = canAnchorPopup({
309
+ ...anchorOptions,
310
+ ...preferences[0],
311
+ force: true,
312
+ });
313
+ }
314
+
315
+ this.#tooltip.style.setProperty('top', `${anchorResult.pageY}px`);
316
+ this.#tooltip.style.setProperty('left', `${anchorResult.pageX}px`);
317
+ this.#tooltip.style.setProperty('margin', '0');
318
+ this.#tooltip.style.setProperty('transform-origin', `${anchorResult.transformOriginY} ${anchorResult.transformOriginX}`);
319
+
320
+ const hoverStyle = this.refs.tooltip.style;
321
+ hoverStyle.setProperty('width', `${anchorResult.width + (anchorResult.offsetX * 2)}px`);
322
+ hoverStyle.setProperty('height', `${anchorResult.height + (anchorResult.offsetY)}px`);
323
+ if (anchorResult.clientY === 'bottom') {
324
+ hoverStyle.setProperty('top', '100%');
325
+ hoverStyle.removeProperty('bottom');
326
+ } else {
327
+ hoverStyle.removeProperty('top');
328
+ hoverStyle.setProperty('height', `${anchorResult.height + (anchorResult.offsetY)}px`);
329
+ hoverStyle.setProperty('bottom', '100%');
330
+ }
331
+ switch (anchorResult.clientX) {
332
+ case 'left':
333
+ hoverStyle.setProperty('left', '0');
334
+ hoverStyle.removeProperty('right');
335
+ break;
336
+ default:
337
+ case 'center':
338
+ hoverStyle.removeProperty('left');
339
+ hoverStyle.removeProperty('right');
340
+ break;
341
+ case 'right':
342
+ hoverStyle.removeProperty('left');
343
+ hoverStyle.setProperty('right', '0');
344
+ }
345
+ }
346
+
347
+ connectedCallback() {
348
+ super.connectedCallback();
349
+ for (const type of ['click', 'mousedown', 'mousemove', 'mouseout',
350
+ 'touchmove', 'touchstart', 'touchend', 'touchleave', 'touchcancel']) {
351
+ this.addEventListener(type, this.onTooltipTriggerPointer, { passive: true });
352
+ }
353
+ this.addEventListener('focus', this.onTooltipTriggerFocus);
354
+ this.addEventListener('blur', this.onTooltipTriggerBlur);
355
+ this.addEventListener('keydown', this.onTooltipTriggerKeydown, { passive: true });
356
+ }
357
+
358
+ disconnectedCallback() {
359
+ // console.log('disconnected');
360
+ this.hideTooltip();
361
+ super.disconnectedCallback();
362
+ }
363
+ }
364
+ TooltipTrigger.prototype.tooltip = TooltipTrigger.prop('tooltip');
365
+ return TooltipTrigger;
366
+ }
@@ -0,0 +1,26 @@
1
+ .touch-target {
2
+ position: absolute;
3
+ inset: 50%;
4
+ /* --mdw-device-pixel-ratio: 1; */
5
+
6
+ block-size: 100%;
7
+ min-block-size: 48px;
8
+ /* min-block-size: 10mm; */
9
+ /* min-block-size: calc(0.393701in / var(--mdw-device-pixel-ratio, 1)); */
10
+ inline-size:100%;
11
+ min-inline-size: 48px;
12
+ /* min-inline-size: 10mm; */
13
+ /* min-inline-size: calc(0.393701in / var(--mdw-device-pixel-ratio, 1)); */
14
+
15
+ cursor: inherit;
16
+
17
+ /* box-sizing: border-box; */
18
+ /* border: solid 1px magenta; */
19
+ pointer-events: auto;
20
+
21
+ transform: translateX(-50%) translateY(-50%);
22
+ visibility: visible;
23
+ z-index: 1;
24
+
25
+ border-radius: inherit;
26
+ }
@@ -0,0 +1,9 @@
1
+ import styles from './TouchTargetMixin.css' assert { type: 'css' };
2
+
3
+ /** @param {typeof import('../core/CustomElement.js').default} Base */
4
+ export default function TouchTargetMixin(Base) {
5
+ return Base
6
+ .extend()
7
+ .css(styles)
8
+ .html/* html */`<div id=touch-target class=touch-target></div>`;
9
+ }
package/package.json CHANGED
@@ -1,18 +1,16 @@
1
1
  {
2
2
  "name": "@shortfuse/materialdesignweb",
3
- "version": "0.4.0",
3
+ "version": "0.7.0",
4
4
  "description": "Material Design for Web",
5
- "main": "index.js",
6
5
  "type": "module",
7
6
  "scripts": {
8
- "analyze:docs": "webpack-bundle-analyzer stats.json",
9
- "build:docs": "webpack --config webpack.config.cjs --env target=docs",
10
- "deploy:docs": "scripts/deploy-docs.sh",
11
- "dist": "webpack",
12
- "pretest": "eslint --ignore-path .gitignore .",
13
- "start:docs": "webpack serve --config webpack.config.cjs --env target=docs --host 0.0.0.0",
14
- "stats:docs": "webpack --config webpack.config.cjs --env target=docs --profile --json > stats.json",
15
- "test": "echo \"Error: no test specified\" && exit 1"
7
+ "prebuild": "node bin/generate-css.js --custom=yellow,orange:orange,green:0f0,alias:aqua | npx esbuild --minify --loader=css > docs/theme.css",
8
+ "prebuild-alt": "node bin/generate-css.js --color=a46750 --custom=yellow,orange:orange,green:0f0,alias:aqua | npx esbuild --minify --loader=css > docs/alt-theme.css",
9
+ "build": "node build/esbuild.js --minify --metafile",
10
+ "watch": "node build/esbuild.js --watch --metafile",
11
+ "serve": "node build/esbuild.js --watch --metafile --serve --live",
12
+ "pretest": "eslint --ignore-path .gitignore",
13
+ "test": "c8 tap --no-coverage"
16
14
  },
17
15
  "repository": {
18
16
  "type": "git",
@@ -21,46 +19,64 @@
21
19
  "keywords": [
22
20
  "material",
23
21
  "design",
24
- "web"
22
+ "web",
23
+ "materialyou",
24
+ "md3",
25
+ "web-components"
26
+ ],
27
+ "files": [
28
+ "/bin",
29
+ "/components",
30
+ "/core",
31
+ "/theming",
32
+ "/mixins",
33
+ "/utils"
25
34
  ],
26
35
  "exports": {
27
- "./": "./"
36
+ "/components": "./components",
37
+ "/core": "./core",
38
+ "/theming": "./theming",
39
+ "/mixins": "./mixins",
40
+ "/utils": "./utils"
28
41
  },
29
42
  "author": "Carlos Lopez Jr. <clshortfuse@gmail.com> (https://shortfuse.org/)",
30
43
  "license": "ISC",
31
- "sideEffects": false,
44
+ "sideEffects": [
45
+ "./polyfills.js",
46
+ "./components/*.js",
47
+ "./utils/metadata.js",
48
+ "./theming/loader.js",
49
+ "./docs/demo/*.js"
50
+ ],
32
51
  "bugs": {
33
52
  "url": "https://github.com/clshortfuse/materialdesignweb/issues"
34
53
  },
35
54
  "homepage": "https://github.com/clshortfuse/materialdesignweb#readme",
36
55
  "devDependencies": {
37
- "@babel/preset-env": "^7.12.1",
38
- "@typescript-eslint/eslint-plugin": "5.7.0",
39
- "@typescript-eslint/parser": "5.7.0",
40
- "babel-loader": "^8.2.3",
41
- "clean-css": "^5.2.2",
42
- "css-loader": "^6.5.1",
43
- "cssnano": "^5.0.14",
44
- "eslint-config-airbnb-base": "^14.2.0",
45
- "eslint-plugin-eta": "github:clshortfuse/eslint-plugin-eta",
46
- "eslint-plugin-import": "^2.22.1",
47
- "eslint-plugin-jsdoc": "^37.2.0",
48
- "eta": "^1.12.0",
49
- "extract-loader": "^5.1.0",
50
- "fibers": "^5.0.0",
51
- "file-loader": "^6.2.0",
52
- "html-loader": "^1.3.2",
53
- "postcss-loader": "^6.2.1",
54
- "sass": "^1.27.0",
55
- "sass-loader": "^12.4.0",
56
- "stylelint": "^13.7.2",
57
- "stylelint-config-recommended-scss": "^4.2.0",
58
- "stylelint-config-sass-guidelines": "^7.1.0",
59
- "stylelint-scss": "^3.18.0",
60
- "typescript": "^4.5.4",
61
- "webpack": "^5.4.0",
62
- "webpack-bundle-analyzer": "^4.1.0",
63
- "webpack-cli": "^4.2.0",
64
- "webpack-dev-server": "^4.7.0"
56
+ "@types/tap": "^15.0.7",
57
+ "@typescript-eslint/eslint-plugin": "^5.30.7",
58
+ "@typescript-eslint/parser": "^5.30.7",
59
+ "browserslist-to-esbuild": "^1.1.1",
60
+ "c8": "^7.12.0",
61
+ "element-internals-polyfill": "^1.1.11",
62
+ "esbuild": "^0.17.12",
63
+ "eslint": "^8.24.0",
64
+ "eslint-config-airbnb-base": "^15.0.0",
65
+ "eslint-plugin-compat": "^4.0.2",
66
+ "eslint-plugin-github": "^4.3.5",
67
+ "eslint-plugin-import": "^2.27.5",
68
+ "eslint-plugin-jsdoc": "^40.0.3",
69
+ "eslint-plugin-sort-class-members": "^1.15.2",
70
+ "eslint-plugin-unicorn": "^46.0.0",
71
+ "http-server": "^14.1.1",
72
+ "postcss-styled": "^0.34.0",
73
+ "postcss-styled-syntax": "^0.4.0",
74
+ "stylelint": "^15.2.0",
75
+ "stylelint-no-unsupported-browser-features": "github:clshortfuse/stylelint-no-unsupported-browser-features#0a51157",
76
+ "stylelint-order": "^6.0.2",
77
+ "stylelint-use-logical-spec": "^5.0.0",
78
+ "tap": "^16.3.0",
79
+ "typescript": "^5.0.2",
80
+ "webdriverio": "^7.23.0"
65
81
  }
66
82
  }