@shortfuse/materialdesignweb 0.3.0 → 0.4.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.
- package/.eslintrc.json +136 -30
- package/.stylelintrc.json +6 -40
- package/.vscode/launch.json +20 -5
- package/CHANGELOG.md +24 -0
- package/README.md +12 -9
- package/adapters/datatable/column.js +82 -74
- package/adapters/datatable/index.js +173 -131
- package/adapters/dom/index.js +529 -75
- package/adapters/list/index.js +25 -12
- package/adapters/search/index.js +13 -13
- package/components/appbar/_spec.scss +87 -64
- package/components/appbar/index.scss +2 -2
- package/components/banner/_spec.scss +8 -8
- package/components/banner/index.scss +2 -2
- package/components/bottomnav/_spec.scss +22 -17
- package/components/bottomnav/index.js +61 -52
- package/components/bottomnav/index.scss +2 -2
- package/components/bottomnav/item.js +44 -25
- package/components/button/README.md +14 -14
- package/components/button/_spec.scss +23 -22
- package/components/button/_theme.scss +37 -21
- package/components/button/index.eta +32 -0
- package/components/button/index.js +12 -12
- package/components/button/index.scss +2 -2
- package/components/card/_spec.scss +40 -36
- package/components/card/index.scss +2 -2
- package/components/chip/_spec.scss +7 -8
- package/components/chip/_theme.scss +31 -31
- package/components/chip/index.js +3 -2
- package/components/chip/index.scss +2 -2
- package/components/chip/item.js +1 -16
- package/components/datatable/_spec.scss +71 -85
- package/components/datatable/_theme.scss +61 -156
- package/components/datatable/cell.js +45 -0
- package/components/datatable/columnheader.js +47 -0
- package/components/datatable/index.js +279 -366
- package/components/datatable/index.scss +2 -2
- package/components/datatable/row.js +49 -0
- package/components/datatable/rowheader.js +18 -0
- package/components/dialog/_spec.scss +61 -41
- package/components/dialog/index.js +325 -297
- package/components/dialog/index.scss +2 -2
- package/components/divider/_spec.scss +8 -6
- package/components/divider/index.scss +2 -2
- package/components/elevation/_spec.scss +2 -2
- package/components/elevation/index.scss +2 -2
- package/components/fab/_spec.scss +23 -24
- package/components/fab/index.js +50 -50
- package/components/fab/index.scss +2 -2
- package/components/grid/_spec.scss +33 -31
- package/components/grid/index.scss +2 -2
- package/components/layout/_mixins.scss +5 -5
- package/components/layout/_spec.scss +206 -176
- package/components/layout/_theme.scss +14 -16
- package/components/layout/index.js +181 -153
- package/components/layout/index.scss +2 -2
- package/components/list/_spec.scss +117 -104
- package/components/list/_theme.scss +31 -34
- package/components/list/content.js +68 -52
- package/components/list/index.js +194 -61
- package/components/list/index.scss +2 -2
- package/components/list/item.js +136 -12
- package/components/list/secondary.js +46 -0
- package/components/menu/_spec.scss +32 -19
- package/components/menu/index.js +242 -229
- package/components/menu/index.scss +2 -2
- package/components/menu/item.js +95 -110
- package/components/progress/_spec.scss +35 -27
- package/components/progress/index.js +21 -0
- package/components/progress/index.scss +2 -1
- package/components/selection/_spec.scss +242 -224
- package/components/selection/_theme.scss +100 -95
- package/components/selection/index.eta +60 -0
- package/components/selection/index.js +76 -0
- package/components/selection/index.pug +15 -8
- package/components/selection/index.scss +2 -2
- package/components/selection/input.js +56 -0
- package/components/selection/radiogroup.js +47 -0
- package/components/slider/_spec.scss +10 -8
- package/components/slider/index.scss +2 -2
- package/components/snackbar/_spec.scss +22 -21
- package/components/snackbar/index.js +102 -111
- package/components/snackbar/index.scss +2 -2
- package/components/tab/_spec.scss +20 -19
- package/components/tab/content.js +41 -40
- package/components/tab/index.js +192 -99
- package/components/tab/index.scss +2 -2
- package/components/tab/item.js +38 -55
- package/components/tab/list.js +96 -72
- package/components/tab/panel.js +12 -13
- package/components/template/_theme.scss +11 -11
- package/components/textfield/_mixins.scss +52 -0
- package/components/textfield/_spec.scss +215 -266
- package/components/textfield/_theme.scss +95 -72
- package/components/textfield/index.eta +74 -0
- package/components/textfield/index.js +63 -57
- package/components/textfield/index.scss +2 -2
- package/components/tooltip/_spec.scss +27 -25
- package/components/tooltip/index.scss +2 -2
- package/components/type/_spec.scss +51 -38
- package/components/type/index.scss +2 -2
- package/core/_breakpoint.scss +75 -91
- package/core/_elevation.scss +10 -10
- package/core/_length.scss +9 -0
- package/core/_motion.scss +14 -14
- package/core/_platform.scss +9 -15
- package/core/_type.scss +33 -32
- package/core/aria/attributes.js +125 -25
- package/core/aria/button.js +23 -23
- package/core/aria/keyboard.js +93 -0
- package/core/aria/rovingtabindex.js +69 -154
- package/core/aria/tab.js +31 -28
- package/core/color/_theme.scss +240 -280
- package/core/color/index.scss +2 -2
- package/core/document/index.js +39 -0
- package/core/dom.js +12 -12
- package/core/overlay/_spec.scss +0 -3
- package/core/overlay/_theme.scss +56 -74
- package/core/overlay/index.js +49 -18
- package/core/overlay/index.scss +2 -2
- package/core/ripple/_spec.scss +22 -39
- package/core/ripple/_theme.scss +13 -13
- package/core/ripple/index.js +137 -134
- package/core/ripple/index.scss +2 -2
- package/core/theme/_config.scss +2 -0
- package/core/theme/_mixins.scss +172 -0
- package/core/theme/_palettes.scss +155 -135
- package/core/theme/_variables.scss +24 -15
- package/core/theme/index.js +50 -0
- package/core/throttler.js +1 -1
- package/core/transition/index.js +36 -20
- package/{docs-src → docs}/_flex.scss +0 -0
- package/{docs-src → docs}/_menuoptions.js +21 -34
- package/{docs-src → docs}/_mixins.pug +39 -26
- package/docs/_partials/_androidnavbar.eta +5 -0
- package/docs/_partials/_androidstatusbar.eta +13 -0
- package/docs/_partials/_appbar.eta +29 -0
- package/docs/_partials/_buttontest.eta +31 -0
- package/docs/_partials/_header.eta +149 -0
- package/docs/_partials/_navlistitem.eta +16 -0
- package/docs/_partials/_target.eta +1 -0
- package/{docs-src → docs}/_sample-utils.js +8 -6
- package/{docs-src → docs}/_storage.js +0 -0
- package/{docs-src → docs}/docs.scss +5 -2
- package/docs/index.eta +16 -0
- package/{docs-src → docs}/index.js +0 -0
- package/docs/pages/appbar.eta +114 -0
- package/{docs-src/components → docs/pages}/appbar.js +0 -0
- package/{docs-src/components → docs/pages}/appbar.pug +15 -18
- package/docs/pages/bottomnav.eta +188 -0
- package/{docs-src/components → docs/pages}/bottomnav.js +23 -24
- package/{docs-src/components → docs/pages}/bottomnav.pug +4 -4
- package/docs/pages/button.eta +124 -0
- package/{docs-src/components → docs/pages}/button.js +19 -19
- package/{docs-src/components → docs/pages}/button.pug +15 -15
- package/docs/pages/card.eta +90 -0
- package/{docs-src/components → docs/pages}/card.js +3 -3
- package/{docs-src/components → docs/pages}/card.pug +7 -7
- package/docs/pages/chip.eta +122 -0
- package/{docs-src/components → docs/pages}/chip.js +3 -6
- package/{docs-src/components → docs/pages}/chip.pug +2 -2
- package/docs/pages/color.eta +143 -0
- package/{docs-src/core → docs/pages}/color.js +95 -20
- package/docs/pages/color.pug +121 -0
- package/docs/pages/datatable.eta +323 -0
- package/{docs-src/components → docs/pages}/datatable.js +26 -13
- package/docs/pages/datatable.pug +283 -0
- package/docs/pages/dialog.eta +186 -0
- package/{docs-src/components → docs/pages}/dialog.js +26 -13
- package/{docs-src/components → docs/pages}/dialog.pug +46 -28
- package/docs/pages/dom.eta +26 -0
- package/docs/pages/dom.js +143 -0
- package/docs/pages/dom.pug +22 -0
- package/docs/pages/elevation.eta +35 -0
- package/{docs-src/components → docs/pages}/elevation.js +0 -0
- package/{docs-src/components → docs/pages}/elevation.pug +0 -0
- package/docs/pages/fab.eta +99 -0
- package/{docs-src/components → docs/pages}/fab.js +3 -3
- package/{docs-src/components → docs/pages}/fab.pug +2 -2
- package/docs/pages/grid.eta +135 -0
- package/{docs-src/components → docs/pages}/grid.js +1 -1
- package/{docs-src/components → docs/pages}/grid.pug +3 -3
- package/docs/pages/layout.eta +8 -0
- package/{docs-src/components → docs/pages}/layout.js +0 -0
- package/{docs-src/components → docs/pages}/layout.pug +0 -0
- package/docs/pages/list.eta +465 -0
- package/{docs-src/components → docs/pages}/list.js +2 -2
- package/{docs-src/components → docs/pages}/list.pug +7 -14
- package/docs/pages/menu.eta +276 -0
- package/{docs-src/components → docs/pages}/menu.js +14 -10
- package/{docs-src/components → docs/pages}/menu.pug +0 -0
- package/docs/pages/overlay.eta +69 -0
- package/docs/pages/overlay.js +4 -0
- package/{docs-src/core → docs/pages}/overlay.pug +14 -11
- package/docs/pages/progress.eta +23 -0
- package/{docs-src/components → docs/pages}/progress.js +1 -1
- package/{docs-src/components → docs/pages}/progress.pug +1 -1
- package/docs/pages/ripple.eta +27 -0
- package/docs/pages/ripple.js +4 -0
- package/{docs-src/core → docs/pages}/ripple.pug +4 -4
- package/docs/pages/search.eta +246 -0
- package/{docs-src/components → docs/pages}/search.js +59 -42
- package/{docs-src/components → docs/pages}/search.pug +50 -51
- package/docs/pages/selection.eta +111 -0
- package/docs/pages/selection.js +13 -0
- package/docs/pages/selection.pug +74 -0
- package/docs/pages/slider.eta +23 -0
- package/{docs-src/components → docs/pages}/slider.js +0 -0
- package/{docs-src/components → docs/pages}/slider.pug +0 -0
- package/docs/pages/snackbar.eta +83 -0
- package/{docs-src/components → docs/pages}/snackbar.js +3 -3
- package/{docs-src/components → docs/pages}/snackbar.pug +0 -0
- package/docs/pages/tab.eta +421 -0
- package/{docs-src/components → docs/pages}/tab.js +18 -35
- package/{docs-src/components → docs/pages}/tab.pug +4 -4
- package/docs/pages/textfield.eta +486 -0
- package/{docs-src/components → docs/pages}/textfield.js +3 -4
- package/{docs-src/components → docs/pages}/textfield.pug +87 -35
- package/docs/pages/tooltip.eta +94 -0
- package/{docs-src/components → docs/pages}/tooltip.js +0 -0
- package/{docs-src/components → docs/pages}/tooltip.pug +0 -1
- package/docs/pages/transition.eta +117 -0
- package/{docs-src/core → docs/pages}/transition.js +7 -8
- package/{docs-src/core → docs/pages}/transition.pug +0 -0
- package/docs/pages/type.eta +31 -0
- package/{docs-src/components → docs/pages}/type.js +0 -0
- package/{docs-src/components → docs/pages}/type.pug +0 -1
- package/docs/postrender.js +39 -0
- package/{docs-src → docs}/prerender.js +3 -9
- package/docs/pwa/_dialogs.eta +143 -0
- package/docs/pwa/_dialogs.pug +96 -0
- package/docs/pwa/_menus.eta +16 -0
- package/{docs-src → docs}/pwa/_menus.pug +0 -0
- package/docs/pwa/pwa-prerender.js +3 -0
- package/docs/pwa/pwa.eta +480 -0
- package/docs/pwa/pwa.js +306 -0
- package/{docs-src → docs}/pwa/pwa.pug +166 -263
- package/docs/pwa/pwa.scss +26 -0
- package/docs/spec.scss +26 -0
- package/docs/themes/_component-themes.scss +26 -0
- package/docs/themes/theme-colored-fallbacks.scss +17 -0
- package/docs/themes/theme-colored.scss +17 -0
- package/docs/themes/theme-default-fallbacks.scss +17 -0
- package/docs/themes/theme-default.scss +17 -0
- package/jsconfig.json +4 -2
- package/package.json +40 -27
- package/scripts/deploy-docs.sh +9 -0
- package/templates/index.eta +2 -0
- package/utils/function.js +3 -0
- package/webpack.config.cjs +257 -0
- package/_spec.scss +0 -27
- package/_theme.scss +0 -27
- package/components/list/expander.js +0 -142
- package/components/list/itemgroup.js +0 -22
- package/core/theme/_builder.scss +0 -116
- package/core/theme/index.scss +0 -68
- package/docs/appbar.html +0 -1
- package/docs/appbar.min.js +0 -2
- package/docs/appbar.min.js.map +0 -1
- package/docs/bottomnav.html +0 -1
- package/docs/bottomnav.min.js +0 -2
- package/docs/bottomnav.min.js.map +0 -1
- package/docs/button.html +0 -1
- package/docs/button.min.js +0 -2
- package/docs/button.min.js.map +0 -1
- package/docs/card.html +0 -1
- package/docs/card.min.js +0 -2
- package/docs/card.min.js.map +0 -1
- package/docs/chip.html +0 -1
- package/docs/chip.min.js +0 -2
- package/docs/chip.min.js.map +0 -1
- package/docs/color.html +0 -1
- package/docs/color.min.js +0 -2
- package/docs/color.min.js.map +0 -1
- package/docs/datatable.html +0 -1
- package/docs/datatable.min.js +0 -2
- package/docs/datatable.min.js.map +0 -1
- package/docs/default.common.min.js +0 -2
- package/docs/default.common.min.js.map +0 -1
- package/docs/dialog.html +0 -1
- package/docs/dialog.min.js +0 -2
- package/docs/dialog.min.js.map +0 -1
- package/docs/docs.min.css +0 -1
- package/docs/docs.min.js +0 -2
- package/docs/docs.min.js.map +0 -1
- package/docs/elevation.html +0 -1
- package/docs/elevation.min.js +0 -2
- package/docs/elevation.min.js.map +0 -1
- package/docs/fab.html +0 -1
- package/docs/fab.min.js +0 -2
- package/docs/fab.min.js.map +0 -1
- package/docs/grid.html +0 -1
- package/docs/grid.min.js +0 -2
- package/docs/grid.min.js.map +0 -1
- package/docs/index.html +0 -1
- package/docs/index.min.js +0 -2
- package/docs/index.min.js.map +0 -1
- package/docs/ink.html +0 -1
- package/docs/ink.min.js +0 -2
- package/docs/ink.min.js.map +0 -1
- package/docs/layout.html +0 -1
- package/docs/layout.min.js +0 -2
- package/docs/layout.min.js.map +0 -1
- package/docs/list.html +0 -1
- package/docs/list.min.js +0 -2
- package/docs/list.min.js.map +0 -1
- package/docs/menu.html +0 -1
- package/docs/menu.min.js +0 -2
- package/docs/menu.min.js.map +0 -1
- package/docs/overlay.html +0 -1
- package/docs/overlay.min.js +0 -2
- package/docs/overlay.min.js.map +0 -1
- package/docs/prerender.common.min.js +0 -2
- package/docs/prerender.common.min.js.map +0 -1
- package/docs/prerender.min.js +0 -2
- package/docs/prerender.min.js.map +0 -1
- package/docs/progress.html +0 -1
- package/docs/progress.min.js +0 -2
- package/docs/progress.min.js.map +0 -1
- package/docs/pwa-prerender.min.js +0 -2
- package/docs/pwa-prerender.min.js.map +0 -1
- package/docs/pwa.html +0 -11
- package/docs/pwa.min.css +0 -1
- package/docs/pwa.min.js +0 -2
- package/docs/pwa.min.js.map +0 -1
- package/docs/ripple.html +0 -1
- package/docs/ripple.min.js +0 -2
- package/docs/ripple.min.js.map +0 -1
- package/docs/search.html +0 -1
- package/docs/search.min.js +0 -2
- package/docs/search.min.js.map +0 -1
- package/docs/selection.html +0 -1
- package/docs/selection.min.js +0 -2
- package/docs/selection.min.js.map +0 -1
- package/docs/slider.html +0 -1
- package/docs/slider.min.js +0 -2
- package/docs/slider.min.js.map +0 -1
- package/docs/snackbar.html +0 -1
- package/docs/snackbar.min.js +0 -2
- package/docs/snackbar.min.js.map +0 -1
- package/docs/spec.min.css +0 -1
- package/docs/spec.min.js +0 -2
- package/docs/spec.min.js.map +0 -1
- package/docs/surface.html +0 -1
- package/docs/surface.min.js +0 -2
- package/docs/surface.min.js.map +0 -1
- package/docs/tab.html +0 -1
- package/docs/tab.min.js +0 -2
- package/docs/tab.min.js.map +0 -1
- package/docs/textfield.html +0 -2
- package/docs/textfield.min.js +0 -2
- package/docs/textfield.min.js.map +0 -1
- package/docs/theme-colored-fallbacks.min.css +0 -1
- package/docs/theme-colored-fallbacks.min.js +0 -2
- package/docs/theme-colored-fallbacks.min.js.map +0 -1
- package/docs/theme-colored.min.css +0 -1
- package/docs/theme-colored.min.js +0 -2
- package/docs/theme-colored.min.js.map +0 -1
- package/docs/theme-default-fallbacks.min.css +0 -1
- package/docs/theme-default-fallbacks.min.js +0 -2
- package/docs/theme-default-fallbacks.min.js.map +0 -1
- package/docs/theme-default.min.css +0 -1
- package/docs/theme-default.min.js +0 -2
- package/docs/theme-default.min.js.map +0 -1
- package/docs/themes-fallbacks.min.css +0 -1
- package/docs/themes-fallbacks.min.js +0 -2
- package/docs/themes-fallbacks.min.js.map +0 -1
- package/docs/themes.min.css +0 -1
- package/docs/themes.min.js +0 -2
- package/docs/themes.min.js.map +0 -1
- package/docs/tooltip.html +0 -1
- package/docs/tooltip.min.js +0 -2
- package/docs/tooltip.min.js.map +0 -1
- package/docs/transition.html +0 -1
- package/docs/transition.min.js +0 -2
- package/docs/transition.min.js.map +0 -1
- package/docs/type.html +0 -1
- package/docs/type.min.js +0 -2
- package/docs/type.min.js.map +0 -1
- package/docs-src/components/datatable.pug +0 -327
- package/docs-src/components/selection.js +0 -9
- package/docs-src/components/selection.pug +0 -77
- package/docs-src/core/color.pug +0 -201
- package/docs-src/core/overlay.js +0 -4
- package/docs-src/core/ripple.js +0 -4
- package/docs-src/index.pug +0 -9
- package/docs-src/pwa/_dialogs.pug +0 -15
- package/docs-src/pwa/pwa-prerender.js +0 -3
- package/docs-src/pwa/pwa.js +0 -182
- package/docs-src/pwa/pwa.scss +0 -25
- package/docs-src/spec.scss +0 -1
- package/docs-src/themes/theme-colored-fallbacks.scss +0 -14
- package/docs-src/themes/theme-colored.scss +0 -14
- package/docs-src/themes/theme-default-fallbacks.scss +0 -14
- package/docs-src/themes/theme-default.scss +0 -14
- package/index.js +0 -51
- package/index.scss +0 -2
- package/webpack.config.js +0 -187
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
<% var T = '../../templates/index.eta' %>
|
|
2
|
+
<% layout('../_partials/_header.eta', {page: 'search'}) %>
|
|
3
|
+
<div class="comparison js">
|
|
4
|
+
<div class="render">
|
|
5
|
+
<div class="display-flex" style="padding:8px;">
|
|
6
|
+
<div class="flex-1 display-flex" flex-column>
|
|
7
|
+
<p>Text field dropdown with:</p>
|
|
8
|
+
<ul>
|
|
9
|
+
<li>one-time search on first input</li>
|
|
10
|
+
<li>startsWith text filter</li>
|
|
11
|
+
<li>append input on selection</li>
|
|
12
|
+
</ul>
|
|
13
|
+
<div>
|
|
14
|
+
<label class="mdw-textfield mdw-theme" id="search-textfield-custom1" mdw-ink="secondary">
|
|
15
|
+
<input class="mdw-textfield__input" placeholder=" " />
|
|
16
|
+
<div class="mdw-textfield__border">
|
|
17
|
+
<div class="mdw-textfield__outline-gap">
|
|
18
|
+
<div class="mdw-textfield__label">Property</div>
|
|
19
|
+
</div>
|
|
20
|
+
</div>
|
|
21
|
+
<div class="mdw-textfield__dropdown mdw-theme" mdw-surface="card" mdw-type="list" mdw-hide>
|
|
22
|
+
<div class="custom-busy-indicator display-flex" flex-align-items="center">
|
|
23
|
+
<div class="mdw-progress-circle">
|
|
24
|
+
<svg viewBox="0 0 24 24">
|
|
25
|
+
<path d="M12 3.25A8.75 8.75 0 1 1 3.25 12"></path>
|
|
26
|
+
<path d="M12 3.25A8.75 8.75 0 1 1 3.25 12 A 8.75 8.75 0 0 1 12 3.25"></path>
|
|
27
|
+
</svg>
|
|
28
|
+
</div>
|
|
29
|
+
<div>Searching...</div>
|
|
30
|
+
</div>
|
|
31
|
+
<div class="mdw-list" id="search-list-custom1"></div>
|
|
32
|
+
</div>
|
|
33
|
+
</label>
|
|
34
|
+
</div>
|
|
35
|
+
<p>Current Selection: <span id="search-result-custom1"></span></p>
|
|
36
|
+
<p>Text field dropdown with:</p>
|
|
37
|
+
<ul>
|
|
38
|
+
<li>input-based search</li>
|
|
39
|
+
<li>300ms debounce</li>
|
|
40
|
+
<li>replace input on selection</li>
|
|
41
|
+
<li>disabled item filter</li>
|
|
42
|
+
</ul>
|
|
43
|
+
<div>
|
|
44
|
+
<label class="mdw-textfield mdw-theme" id="search-textfield-custom2" mdw-ink="primary" mdw-outlined>
|
|
45
|
+
<input class="mdw-textfield__input" placeholder=" " />
|
|
46
|
+
<div class="mdw-textfield__border">
|
|
47
|
+
<div class="mdw-textfield__outline-gap">
|
|
48
|
+
<div class="mdw-textfield__label">Property</div>
|
|
49
|
+
</div>
|
|
50
|
+
</div>
|
|
51
|
+
<div class="mdw-textfield__dropdown mdw-theme" mdw-surface="card" mdw-type="list" mdw-hide>
|
|
52
|
+
<div class="custom-busy-indicator display-flex" flex-align-items="center">
|
|
53
|
+
<div class="mdw-progress-circle">
|
|
54
|
+
<svg viewBox="0 0 24 24">
|
|
55
|
+
<path d="M12 3.25A8.75 8.75 0 1 1 3.25 12"></path>
|
|
56
|
+
<path d="M12 3.25A8.75 8.75 0 1 1 3.25 12 A 8.75 8.75 0 0 1 12 3.25"></path>
|
|
57
|
+
</svg>
|
|
58
|
+
</div>
|
|
59
|
+
<div>Searching...</div>
|
|
60
|
+
</div>
|
|
61
|
+
<div class="custom-no-results-indicator display-flex" flex-align-items="center" style="display:none">No results found</div>
|
|
62
|
+
<div class="mdw-list" id="search-list-custom2"></div>
|
|
63
|
+
</div>
|
|
64
|
+
</label>
|
|
65
|
+
</div>
|
|
66
|
+
<p>Current Selection: <span id="search-result-custom2"></span></p>
|
|
67
|
+
</div>
|
|
68
|
+
</div>
|
|
69
|
+
</div>
|
|
70
|
+
</div>
|
|
71
|
+
<div class="comparison js">
|
|
72
|
+
<div class="render">
|
|
73
|
+
<div class="androidstatusbar mdw-theme" mdw-surface="primary 700" mdw-dark>
|
|
74
|
+
<div>12:30</div>
|
|
75
|
+
<i class="material-icons" style="letter-spacing:2px;padding:0 2px;"></i>
|
|
76
|
+
</div>
|
|
77
|
+
<div class="mdw-appbar mdw-theme" mdw-surface="primary 500" mdw-dark>
|
|
78
|
+
<div class="mdw-appbar__action">
|
|
79
|
+
<div class="mdw-appbar__start">
|
|
80
|
+
<a class="mdw-button mdw-overlay mdw-ripple material-icons" mdw-icon tabindex="0">arrow_back</a>
|
|
81
|
+
</div>
|
|
82
|
+
<div class="mdw-appbar__title" mdw-custom>
|
|
83
|
+
<div class="mdw-textfield mdw-theme" id="search-textfield-simple" mdw-solo mdw-ink="secondary">
|
|
84
|
+
<input class="mdw-textfield__input" placeholder="Search" />
|
|
85
|
+
</div>
|
|
86
|
+
</div>
|
|
87
|
+
<div class="mdw-appbar__end">
|
|
88
|
+
<a class="mdw-button mdw-overlay mdw-ripple material-icons" mdw-icon tabindex="0">clear</a>
|
|
89
|
+
</div>
|
|
90
|
+
</div>
|
|
91
|
+
</div>
|
|
92
|
+
<div class="content">
|
|
93
|
+
<ul class="mdw-list" id="search-list-simple">
|
|
94
|
+
<li class="mdw-list__item">
|
|
95
|
+
<a class="mdw-list__content">Attractions</a>
|
|
96
|
+
</li>
|
|
97
|
+
<li class="mdw-list__item">
|
|
98
|
+
<a class="mdw-list__content">Dining</a>
|
|
99
|
+
</li>
|
|
100
|
+
<li class="mdw-list__item">
|
|
101
|
+
<a class="mdw-list__content">Education</a>
|
|
102
|
+
</li>
|
|
103
|
+
<li class="mdw-list__item">
|
|
104
|
+
<a class="mdw-list__content">Family</a>
|
|
105
|
+
</li>
|
|
106
|
+
<li class="mdw-list__item">
|
|
107
|
+
<a class="mdw-list__content">Health</a>
|
|
108
|
+
</li>
|
|
109
|
+
<li class="mdw-list__item">
|
|
110
|
+
<a class="mdw-list__content">Office</a>
|
|
111
|
+
</li>
|
|
112
|
+
<li class="mdw-list__item">
|
|
113
|
+
<a class="mdw-list__content">Promotions</a>
|
|
114
|
+
</li>
|
|
115
|
+
<li class="mdw-list__item">
|
|
116
|
+
<a class="mdw-list__content">Radio</a>
|
|
117
|
+
</li>
|
|
118
|
+
<li class="mdw-list__item">
|
|
119
|
+
<a class="mdw-list__content">Recipes</a>
|
|
120
|
+
</li>
|
|
121
|
+
<li class="mdw-list__item">
|
|
122
|
+
<a class="mdw-list__content">Sports</a>
|
|
123
|
+
</li>
|
|
124
|
+
<li class="mdw-list__item">
|
|
125
|
+
<a class="mdw-list__content">Travel</a>
|
|
126
|
+
</li>
|
|
127
|
+
</ul>
|
|
128
|
+
</div>
|
|
129
|
+
<div class="androidnavbar">
|
|
130
|
+
<i class="material-icons back-button"></i>
|
|
131
|
+
<i class="material-icons"></i>
|
|
132
|
+
<i class="material-icons"></i>
|
|
133
|
+
</div>
|
|
134
|
+
</div>
|
|
135
|
+
</div>
|
|
136
|
+
<div class="comparison js">
|
|
137
|
+
<div class="render">
|
|
138
|
+
<div class="androidstatusbar mdw-theme" mdw-surface="primary 700" mdw-dark>
|
|
139
|
+
<div>12:30</div>
|
|
140
|
+
<i class="material-icons" style="letter-spacing:2px;padding:0 2px;"></i>
|
|
141
|
+
</div>
|
|
142
|
+
<div class="mdw-appbar mdw-theme" mdw-surface="primary 500" mdw-dark>
|
|
143
|
+
<div class="mdw-appbar__action">
|
|
144
|
+
<div class="mdw-appbar__start">
|
|
145
|
+
<a class="mdw-button mdw-overlay mdw-ripple material-icons" mdw-icon tabindex="0">arrow_back</a>
|
|
146
|
+
</div>
|
|
147
|
+
<div class="mdw-appbar__title" mdw-custom>
|
|
148
|
+
<div class="mdw-textfield mdw-theme" id="search-textfield-multiline" mdw-solo mdw-ink="secondary">
|
|
149
|
+
<input class="mdw-textfield__input" placeholder="Search" />
|
|
150
|
+
</div>
|
|
151
|
+
</div>
|
|
152
|
+
<div class="mdw-appbar__end">
|
|
153
|
+
<a class="mdw-button mdw-overlay mdw-ripple material-icons" mdw-icon tabindex="0">clear</a>
|
|
154
|
+
</div>
|
|
155
|
+
</div>
|
|
156
|
+
</div>
|
|
157
|
+
<div class="content">
|
|
158
|
+
<ul class="mdw-list" id="search-list-multiline">
|
|
159
|
+
<li class="mdw-list__subheader mdw-theme" mdw-ink="medium">Today</li>
|
|
160
|
+
<li class="mdw-list__item">
|
|
161
|
+
<div class="mdw-list__content mdw-overlay mdw-ripple">
|
|
162
|
+
<div class="mdw-list__avatar">
|
|
163
|
+
<i class="material-icons" style="font-size:40px;"></i>
|
|
164
|
+
</div>
|
|
165
|
+
<div class="mdw-list__text">
|
|
166
|
+
<div class="mdw-list__text-line">Brunch this weekend?</div>
|
|
167
|
+
<div class="mdw-list__text-block">Ali Connors<span class="mdw-theme" mdw-ink="medium"> — I'll be in your neighborhood doing errands this weekend. Do you want to meet?</span></div>
|
|
168
|
+
</div>
|
|
169
|
+
</div>
|
|
170
|
+
</li>
|
|
171
|
+
<li class="mdw-list__item">
|
|
172
|
+
<div class="mdw-list__content">
|
|
173
|
+
<div class="mdw-list__avatar">
|
|
174
|
+
<i class="material-icons" style="font-size:40px;"></i>
|
|
175
|
+
</div>
|
|
176
|
+
<div class="mdw-list__text">
|
|
177
|
+
<div class="mdw-list__text-line">Summer BBQ<span class="mdw-theme" mdw-ink="medium"> 4</span></div>
|
|
178
|
+
<div class="mdw-list__text-block">to Alex, Scott, Jennifer<span class="mdw-theme" mdw-ink="medium"> — Wish I could come. but I'm out of town this weekend.</span></div>
|
|
179
|
+
</div>
|
|
180
|
+
</div>
|
|
181
|
+
</li>
|
|
182
|
+
<li class="mdw-list__item">
|
|
183
|
+
<div class="mdw-list__content">
|
|
184
|
+
<div class="mdw-list__avatar">
|
|
185
|
+
<i class="material-icons" style="font-size:40px;"></i>
|
|
186
|
+
</div>
|
|
187
|
+
<div class="mdw-list__text">
|
|
188
|
+
<div class="mdw-list__text-line">Oui oui</div>
|
|
189
|
+
<div class="mdw-list__text-block">Sandra Adams<span class="mdw-theme" mdw-ink="medium"> — Do you have Paris recommendations? Have you ever been?</span></div>
|
|
190
|
+
</div>
|
|
191
|
+
</div>
|
|
192
|
+
</li>
|
|
193
|
+
<li class="mdw-list__item">
|
|
194
|
+
<div class="mdw-list__content">
|
|
195
|
+
<div class="mdw-list__avatar">
|
|
196
|
+
<i class="material-icons" style="font-size:40px;"></i>
|
|
197
|
+
</div>
|
|
198
|
+
<div class="mdw-list__text">
|
|
199
|
+
<div class="mdw-list__text-line">Birthday gift</div>
|
|
200
|
+
<div class="mdw-list__text-block">Trevor Hansen<span class="mdw-theme" mdw-ink="medium"> — Have any ideas about what we should get Heidi for her birthday?</span></div>
|
|
201
|
+
</div>
|
|
202
|
+
</div>
|
|
203
|
+
</li>
|
|
204
|
+
<li class="mdw-list__item">
|
|
205
|
+
<div class="mdw-list__content">
|
|
206
|
+
<div class="mdw-list__avatar">
|
|
207
|
+
<i class="material-icons" style="font-size:40px;"></i>
|
|
208
|
+
</div>
|
|
209
|
+
<div class="mdw-list__text">
|
|
210
|
+
<div class="mdw-list__text-line">Recipe to try</div>
|
|
211
|
+
<div class="mdw-list__text-block">Britta Holt<span class="mdw-theme" mdw-ink="medium"> — We should eat this: Grated Squash, Corn, and tomatillo Tacos J</span></div>
|
|
212
|
+
</div>
|
|
213
|
+
</div>
|
|
214
|
+
</li>
|
|
215
|
+
<li class="mdw-list__item">
|
|
216
|
+
<div class="mdw-list__content">
|
|
217
|
+
<div class="mdw-list__avatar">
|
|
218
|
+
<i class="material-icons" style="font-size:40px;"></i>
|
|
219
|
+
</div>
|
|
220
|
+
<div class="mdw-list__text">
|
|
221
|
+
<div class="mdw-list__text-line">Giants game</div>
|
|
222
|
+
<div class="mdw-list__text-block">David Park<span class="mdw-theme" mdw-ink="medium"> — Any interest in seeing</span></div>
|
|
223
|
+
</div>
|
|
224
|
+
</div>
|
|
225
|
+
</li>
|
|
226
|
+
<li class="mdw-list__item">
|
|
227
|
+
<div class="mdw-list__content">
|
|
228
|
+
<div class="mdw-list__avatar">
|
|
229
|
+
<i class="material-icons" style="font-size:40px;"></i>
|
|
230
|
+
</div>
|
|
231
|
+
<div class="mdw-list__text">
|
|
232
|
+
<div class="mdw-list__text-line">Montauk weekend</div>
|
|
233
|
+
<div class="mdw-list__text-block">-----</div>
|
|
234
|
+
</div>
|
|
235
|
+
</div>
|
|
236
|
+
</li>
|
|
237
|
+
</ul>
|
|
238
|
+
</div>
|
|
239
|
+
<div class="androidnavbar">
|
|
240
|
+
<i class="material-icons back-button"></i>
|
|
241
|
+
<i class="material-icons"></i>
|
|
242
|
+
<i class="material-icons"></i>
|
|
243
|
+
</div>
|
|
244
|
+
</div>
|
|
245
|
+
</div>
|
|
246
|
+
<script src="search.min.js"></script>
|
|
@@ -1,12 +1,16 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import * as
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import {
|
|
1
|
+
import ListAdapter from '../../adapters/list/index.js';
|
|
2
|
+
import SearchAdapter from '../../adapters/search/index.js';
|
|
3
|
+
import * as ListContent from '../../components/list/content.js';
|
|
4
|
+
import * as ListItem from '../../components/list/item.js';
|
|
5
|
+
import * as TextField from '../../components/textfield/index.js';
|
|
6
|
+
import { iterateArrayLike, setTextNode } from '../../core/dom.js';
|
|
7
7
|
|
|
8
8
|
/** @typedef {{line1:string, line2:string}} CustomSearchResult */
|
|
9
9
|
|
|
10
|
+
/** @type {SearchAdapter<any>} */
|
|
11
|
+
let searchDocsSimple;
|
|
12
|
+
/** @type {SearchAdapter<any>} */
|
|
13
|
+
let searchDocsMultiline;
|
|
10
14
|
|
|
11
15
|
/**
|
|
12
16
|
* @param {string} [filter]
|
|
@@ -15,15 +19,32 @@ import { ListAdapter } from '../../index';
|
|
|
15
19
|
function performFakeSearch(filter) {
|
|
16
20
|
const results = [];
|
|
17
21
|
// eslint-disable-next-line guard-for-in, no-restricted-syntax
|
|
18
|
-
for (const key in
|
|
19
|
-
|
|
22
|
+
for (const key in navigator) {
|
|
23
|
+
/** @type {keyof Navigator} */
|
|
24
|
+
const navKey = (key);
|
|
25
|
+
const value = navigator[navKey] && navigator[navKey].toString();
|
|
20
26
|
if (!filter || key.indexOf(filter) !== -1 || (value && value.indexOf(filter) !== -1)) {
|
|
21
|
-
results.push({ line1: key, line2:
|
|
27
|
+
results.push({ line1: key, line2: value });
|
|
22
28
|
}
|
|
23
29
|
}
|
|
24
30
|
return results;
|
|
25
31
|
}
|
|
26
32
|
|
|
33
|
+
/**
|
|
34
|
+
* @param {HTMLElement} element
|
|
35
|
+
* @return {void}
|
|
36
|
+
*/
|
|
37
|
+
function hideElement(element) {
|
|
38
|
+
element.style.setProperty('display', 'none');
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* @param {HTMLElement} element
|
|
42
|
+
* @return {void}
|
|
43
|
+
*/
|
|
44
|
+
function showElement(element) {
|
|
45
|
+
element.style.setProperty('display', '');
|
|
46
|
+
}
|
|
47
|
+
|
|
27
48
|
/**
|
|
28
49
|
* @param {HTMLLIElement} listItemElement
|
|
29
50
|
* @param {CustomSearchResult} result
|
|
@@ -32,7 +53,7 @@ function performFakeSearch(filter) {
|
|
|
32
53
|
function searchResultRenderer(listItemElement, result) {
|
|
33
54
|
if (!listItemElement.children.length) {
|
|
34
55
|
const markup = `
|
|
35
|
-
<div class="mdw-list__content">
|
|
56
|
+
<div class="mdw-list__content mdw-theme" mdw-ink="secondary" aria-selected="false">
|
|
36
57
|
<div class="mdw-list__text">
|
|
37
58
|
<div class="mdw-list__text-line"></div>
|
|
38
59
|
<div class="mdw-list__text-line"></div>
|
|
@@ -58,12 +79,15 @@ function buildCustomSearch1() {
|
|
|
58
79
|
// Actual filter is performed by SearchAdapter
|
|
59
80
|
|
|
60
81
|
/** @type {ListAdapter<CustomSearchResult>} */
|
|
61
|
-
const customListAdapter = new ListAdapter(
|
|
82
|
+
const customListAdapter = new ListAdapter({
|
|
83
|
+
element: list,
|
|
84
|
+
datasource: [],
|
|
85
|
+
render: searchResultRenderer,
|
|
86
|
+
});
|
|
62
87
|
|
|
63
88
|
/** @type {CustomSearchResult[]} */
|
|
64
89
|
let myCachedResults = null;
|
|
65
90
|
|
|
66
|
-
|
|
67
91
|
/** @type {SearchAdapter<CustomSearchResult>} */
|
|
68
92
|
const searchDocsCustom = new SearchAdapter({
|
|
69
93
|
textfield,
|
|
@@ -80,7 +104,7 @@ function buildCustomSearch1() {
|
|
|
80
104
|
}
|
|
81
105
|
|
|
82
106
|
// Display a busy indicator
|
|
83
|
-
busyIndicator
|
|
107
|
+
showElement(busyIndicator);
|
|
84
108
|
|
|
85
109
|
// Add results to a cached search adapter
|
|
86
110
|
myCachedResults = performFakeSearch();
|
|
@@ -105,7 +129,7 @@ function buildCustomSearch1() {
|
|
|
105
129
|
customListAdapter.datasource = searchResults;
|
|
106
130
|
|
|
107
131
|
// Remove busy indicator
|
|
108
|
-
busyIndicator
|
|
132
|
+
hideElement(busyIndicator);
|
|
109
133
|
|
|
110
134
|
// Tell ListAdapter to perform a full refresh
|
|
111
135
|
customListAdapter.refresh();
|
|
@@ -118,28 +142,12 @@ function buildCustomSearch1() {
|
|
|
118
142
|
const listContentElement = (event.target);
|
|
119
143
|
/** @type {HTMLLIElement} */
|
|
120
144
|
const listItemElement = (listContentElement.parentElement);
|
|
121
|
-
const selectedItem = customListAdapter.
|
|
145
|
+
const selectedItem = customListAdapter.elementDataMap.get(listItemElement);
|
|
122
146
|
const text = `${selectedItem.line1}:${selectedItem.line2}`;
|
|
123
147
|
document.getElementById('search-result-custom1').textContent = text;
|
|
124
148
|
});
|
|
125
149
|
}
|
|
126
150
|
|
|
127
|
-
|
|
128
|
-
/**
|
|
129
|
-
* @param {HTMLElement} element
|
|
130
|
-
* @return {void}
|
|
131
|
-
*/
|
|
132
|
-
function hideElement(element) {
|
|
133
|
-
element.style.setProperty('display', 'none');
|
|
134
|
-
}
|
|
135
|
-
/**
|
|
136
|
-
* @param {HTMLElement} element
|
|
137
|
-
* @return {void}
|
|
138
|
-
*/
|
|
139
|
-
function showElement(element) {
|
|
140
|
-
element.style.setProperty('display', '');
|
|
141
|
-
}
|
|
142
|
-
|
|
143
151
|
/** @return {void} */
|
|
144
152
|
function buildCustomSearch2() {
|
|
145
153
|
const textfield = document.getElementById('search-textfield-custom2');
|
|
@@ -150,11 +158,16 @@ function buildCustomSearch2() {
|
|
|
150
158
|
const noResultsIndicator = (textfield.getElementsByClassName('custom-no-results-indicator')[0]);
|
|
151
159
|
|
|
152
160
|
/** @type {ListAdapter<CustomSearchResult>} */
|
|
153
|
-
const customListAdapter = new ListAdapter(
|
|
161
|
+
const customListAdapter = new ListAdapter({
|
|
162
|
+
element: list,
|
|
163
|
+
datasource: [],
|
|
164
|
+
render: searchResultRenderer,
|
|
165
|
+
});
|
|
154
166
|
|
|
155
167
|
// For purpose of this query is "searched" every time with no cache.
|
|
156
168
|
// SearchAdapter performs no filter
|
|
157
169
|
|
|
170
|
+
/** @type {SearchAdapter<CustomSearchResult>} */
|
|
158
171
|
const searchDocsCustom = new SearchAdapter({
|
|
159
172
|
textfield,
|
|
160
173
|
list,
|
|
@@ -195,7 +208,7 @@ function buildCustomSearch2() {
|
|
|
195
208
|
const listContentElement = (event.target);
|
|
196
209
|
/** @type {HTMLLIElement} */
|
|
197
210
|
const listItemElement = (listContentElement.parentElement);
|
|
198
|
-
const selectedItem = customListAdapter.
|
|
211
|
+
const selectedItem = customListAdapter.elementDataMap.get(listItemElement);
|
|
199
212
|
const text = `${selectedItem.line1}:${selectedItem.line2}`;
|
|
200
213
|
document.getElementById('search-result-custom2').textContent = text;
|
|
201
214
|
});
|
|
@@ -203,15 +216,19 @@ function buildCustomSearch2() {
|
|
|
203
216
|
|
|
204
217
|
/** @return {void} */
|
|
205
218
|
function setupSearches() {
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
219
|
+
if (!searchDocsSimple) {
|
|
220
|
+
searchDocsSimple = new SearchAdapter({
|
|
221
|
+
textfield: document.getElementById('search-textfield-simple'),
|
|
222
|
+
list: document.getElementById('search-list-simple'),
|
|
223
|
+
});
|
|
224
|
+
}
|
|
225
|
+
if (!searchDocsMultiline) {
|
|
226
|
+
searchDocsMultiline = new SearchAdapter({
|
|
227
|
+
textfield: document.getElementById('search-textfield-multiline'),
|
|
228
|
+
list: document.getElementById('search-list-multiline'),
|
|
229
|
+
suggestionMethod: 'none',
|
|
230
|
+
});
|
|
231
|
+
}
|
|
215
232
|
|
|
216
233
|
buildCustomSearch1();
|
|
217
234
|
buildCustomSearch2();
|
|
@@ -1,6 +1,55 @@
|
|
|
1
1
|
include ../_mixins.pug
|
|
2
2
|
|
|
3
3
|
+header("search")
|
|
4
|
+
.comparison.js
|
|
5
|
+
.render
|
|
6
|
+
.display-flex(style="padding:8px")
|
|
7
|
+
.flex-1.display-flex(flex-column)
|
|
8
|
+
p Text field dropdown with:
|
|
9
|
+
ul
|
|
10
|
+
li one-time search on first input
|
|
11
|
+
li startsWith text filter
|
|
12
|
+
li append input on selection
|
|
13
|
+
div
|
|
14
|
+
label.mdw-textfield#search-textfield-custom1.mdw-theme(mdw-ink="secondary")
|
|
15
|
+
input.mdw-textfield__input(placeholder=" ")
|
|
16
|
+
.mdw-textfield__border
|
|
17
|
+
.mdw-textfield__outline-gap
|
|
18
|
+
.mdw-textfield__label Property
|
|
19
|
+
.mdw-textfield__dropdown.mdw-theme(mdw-surface="card" mdw-type="list" mdw-hide)
|
|
20
|
+
.custom-busy-indicator.display-flex(flex-align-items="center")
|
|
21
|
+
.mdw-progress-circle
|
|
22
|
+
svg(viewBox="0 0 24 24")
|
|
23
|
+
path(d="M12 3.25A8.75 8.75 0 1 1 3.25 12")
|
|
24
|
+
path(d="M12 3.25A8.75 8.75 0 1 1 3.25 12 A 8.75 8.75 0 0 1 12 3.25")
|
|
25
|
+
span Searching...
|
|
26
|
+
.mdw-list#search-list-custom1
|
|
27
|
+
p Current Selection:
|
|
28
|
+
span#search-result-custom1
|
|
29
|
+
p Text field dropdown with:
|
|
30
|
+
ul
|
|
31
|
+
li input-based search
|
|
32
|
+
li 300ms debounce
|
|
33
|
+
li replace input on selection
|
|
34
|
+
li disabled item filter
|
|
35
|
+
div
|
|
36
|
+
label.mdw-textfield#search-textfield-custom2.mdw-theme(mdw-ink="primary" mdw-outlined)
|
|
37
|
+
input.mdw-textfield__input(placeholder=" ")
|
|
38
|
+
.mdw-textfield__border
|
|
39
|
+
.mdw-textfield__outline-gap
|
|
40
|
+
.mdw-textfield__label Property
|
|
41
|
+
.mdw-textfield__dropdown.mdw-theme(mdw-surface="card" mdw-type="list" mdw-hide)
|
|
42
|
+
.custom-busy-indicator.display-flex(flex-align-items="center")
|
|
43
|
+
.mdw-progress-circle
|
|
44
|
+
svg(viewBox="0 0 24 24")
|
|
45
|
+
path(d="M12 3.25A8.75 8.75 0 1 1 3.25 12")
|
|
46
|
+
path(d="M12 3.25A8.75 8.75 0 1 1 3.25 12 A 8.75 8.75 0 0 1 12 3.25")
|
|
47
|
+
span Searching...
|
|
48
|
+
.custom-no-results-indicator.display-flex(flex-align-items="center" style="display:none")
|
|
49
|
+
span No results found.
|
|
50
|
+
.mdw-list#search-list-custom2
|
|
51
|
+
p Current Selection:
|
|
52
|
+
span#search-result-custom2
|
|
4
53
|
.comparison.js
|
|
5
54
|
.render
|
|
6
55
|
+androidstatusbar('primary 700', 'dark')
|
|
@@ -38,7 +87,6 @@ include ../_mixins.pug
|
|
|
38
87
|
li.mdw-list__item
|
|
39
88
|
a.mdw-list__content Travel
|
|
40
89
|
+androidnavbar
|
|
41
|
-
+target('https://storage.googleapis.com/material-design/publish/material_v_12/assets/0B5ZSepuCX1xObnc4ZFYybVRWY2s/single-action4.png')
|
|
42
90
|
|
|
43
91
|
.comparison.js
|
|
44
92
|
.render
|
|
@@ -112,55 +160,6 @@ include ../_mixins.pug
|
|
|
112
160
|
.mdw-list__text-line Montauk weekend
|
|
113
161
|
.mdw-list__text-block -----
|
|
114
162
|
+androidnavbar
|
|
115
|
-
+target('https://storage.googleapis.com/material-design/publish/material_v_12/assets/0B5ZSepuCX1xObnc4ZFYybVRWY2s/single-action4.png')
|
|
116
163
|
|
|
117
|
-
|
|
118
|
-
.render
|
|
119
|
-
.content.display-flex(style="padding:8px")
|
|
120
|
-
.flex-1.display-flex(flex-column)
|
|
121
|
-
p Text field dropdown with:
|
|
122
|
-
ul
|
|
123
|
-
li one-time search on first input
|
|
124
|
-
li startsWith text filter
|
|
125
|
-
li append input on selection
|
|
126
|
-
div
|
|
127
|
-
label.mdw-textfield#search-textfield-custom1.mdw-theme(mdw-ink="secondary")
|
|
128
|
-
input.mdw-textfield__input(placeholder=" ")
|
|
129
|
-
.mdw-textfield__border
|
|
130
|
-
.mdw-textfield__outline-gap
|
|
131
|
-
.mdw-textfield__label Property
|
|
132
|
-
.mdw-textfield__dropdown.mdw-theme(mdw-surface="card" mdw-type="list" mdw-hide)
|
|
133
|
-
.custom-busy-indicator.display-flex(flex-align-items="center")
|
|
134
|
-
.mdw-progress-circle
|
|
135
|
-
svg(viewBox="0 0 24 24")
|
|
136
|
-
path(d="M12 3.25A8.75 8.75 0 1 1 3.25 12")
|
|
137
|
-
path(d="M12 3.25A8.75 8.75 0 1 1 3.25 12 A 8.75 8.75 0 0 1 12 3.25")
|
|
138
|
-
span Searching...
|
|
139
|
-
.mdw-list#search-list-custom1
|
|
140
|
-
p Current Selection:
|
|
141
|
-
span#search-result-custom1
|
|
142
|
-
p Text field dropdown with:
|
|
143
|
-
ul
|
|
144
|
-
li input-based search
|
|
145
|
-
li 300ms debounce
|
|
146
|
-
li replace input on selection
|
|
147
|
-
li disabled item filter
|
|
148
|
-
div
|
|
149
|
-
label.mdw-textfield#search-textfield-custom2.mdw-theme(mdw-ink="primary" mdw-outlined)
|
|
150
|
-
input.mdw-textfield__input(placeholder=" ")
|
|
151
|
-
.mdw-textfield__border
|
|
152
|
-
.mdw-textfield__outline-gap
|
|
153
|
-
.mdw-textfield__label Property
|
|
154
|
-
.mdw-textfield__dropdown.mdw-theme(mdw-surface="card" mdw-type="list" mdw-hide)
|
|
155
|
-
.custom-busy-indicator.display-flex(flex-align-items="center")
|
|
156
|
-
.mdw-progress-circle
|
|
157
|
-
svg(viewBox="0 0 24 24")
|
|
158
|
-
path(d="M12 3.25A8.75 8.75 0 1 1 3.25 12")
|
|
159
|
-
path(d="M12 3.25A8.75 8.75 0 1 1 3.25 12 A 8.75 8.75 0 0 1 12 3.25")
|
|
160
|
-
span Searching...
|
|
161
|
-
.custom-no-results-indicator.display-flex(flex-align-items="center" style="display:none")
|
|
162
|
-
span No results found.
|
|
163
|
-
.mdw-list#search-list-custom2
|
|
164
|
-
p Current Selection:
|
|
165
|
-
span#search-result-custom2
|
|
164
|
+
|
|
166
165
|
script(src='search.min.js')
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
<% var T = '../../templates/index.eta' %>
|
|
2
|
+
<% layout('../_partials/_header.eta', {page: 'selection'}) %>
|
|
3
|
+
<div class="mdw-grid" mdw-stretch>
|
|
4
|
+
<div class="mdw-grid__item" mdw-colspan="4">
|
|
5
|
+
<div class="mdw-grid__content">
|
|
6
|
+
<div class="render-fill">
|
|
7
|
+
<%~ includeFile('../_partials/_androidstatusbar.eta', { surface:'teal 700', dark:true }) %>
|
|
8
|
+
<div class="mdw-appbar mdw-theme" mdw-surface="teal 500" mdw-dark>
|
|
9
|
+
<div class="mdw-appbar__action">
|
|
10
|
+
<div class="mdw-appbar__title">Styled HTMLInputElement</div>
|
|
11
|
+
</div>
|
|
12
|
+
</div>
|
|
13
|
+
<div class="content">
|
|
14
|
+
<div class="display-flex" style="padding:16px;">
|
|
15
|
+
<%~ includeFile(T, { selection: { ink:'blue', checked:true, prefix:true, type:'switch' , text:'Switch' }}) %>
|
|
16
|
+
</div>
|
|
17
|
+
<div class="display-flex" style="padding:16px;">
|
|
18
|
+
<%~ includeFile(T, { selection: { ink:'blue', checked:true, prefix:true , text:'Prefixed' }}) %>
|
|
19
|
+
</div>
|
|
20
|
+
<div class="display-flex" style="padding:16px;">
|
|
21
|
+
<%~ includeFile(T, { selection: { ink:'teal', checked:true , text:'Suffixed' }}) %>
|
|
22
|
+
</div>
|
|
23
|
+
<div class="display-flex" style="padding:16px;">
|
|
24
|
+
<%~ includeFile(T, { selection: { ink:'teal', checked:true, disabled:true, text:'Disabled' }}) %>
|
|
25
|
+
</div>
|
|
26
|
+
<div class="display-flex" style="padding:16px;">
|
|
27
|
+
<%~ includeFile(T, { selection: { ink:'teal', type:'radio', name:'test', checked:true , text:'Option A' }}) %>
|
|
28
|
+
</div>
|
|
29
|
+
<div class="display-flex" style="padding:16px;">
|
|
30
|
+
<%~ includeFile(T, { selection: { ink:'teal', type:'radio', name:'test' , text:'Option B' }}) %>
|
|
31
|
+
</div>
|
|
32
|
+
<div class="display-flex" style="padding:16px;">
|
|
33
|
+
<%~ includeFile(T, { selection: { ink:'teal', type:'radio', name:'test', disabled:true , text:'Option C' }}) %>
|
|
34
|
+
</div>
|
|
35
|
+
</div>
|
|
36
|
+
</div>
|
|
37
|
+
</div>
|
|
38
|
+
</div>
|
|
39
|
+
<div class="mdw-grid__item" mdw-colspan="4">
|
|
40
|
+
<div class="mdw-grid__content">
|
|
41
|
+
<div class="render-fill">
|
|
42
|
+
<%~ includeFile('../_partials/_androidstatusbar.eta', { surface:'teal 700', dark:true }) %>
|
|
43
|
+
<div class="mdw-appbar mdw-theme" mdw-surface="teal 500" mdw-dark>
|
|
44
|
+
<div class="mdw-appbar__action">
|
|
45
|
+
<div class="mdw-appbar__title">aria-checked (JS)</div>
|
|
46
|
+
</div>
|
|
47
|
+
</div>
|
|
48
|
+
<div class="content">
|
|
49
|
+
<div class="mdw-list__subheader mdw-theme" id="docs-selection-subheader1" mdw-ink="medium">Switch</div>
|
|
50
|
+
<ul class="mdw-list" role="listbox" aria-labelledby="docs-selection-subheader1">
|
|
51
|
+
<li class="mdw-list__item">
|
|
52
|
+
<a class="mdw-list__content mdw-selection mdw-overlay" aria-checked="true">
|
|
53
|
+
<div class="mdw-list__text mdw-selection__label">Android Switch</div>
|
|
54
|
+
<div class="mdw-list__secondary mdw-selection__icon mdw-theme" mdw-ink="teal" mdw-switch></div>
|
|
55
|
+
</a>
|
|
56
|
+
</li>
|
|
57
|
+
<li class="mdw-list__item">
|
|
58
|
+
<a class="mdw-list__content mdw-selection mdw-overlay" aria-checked="false" aria-disabled="true">
|
|
59
|
+
<div class="mdw-list__text mdw-selection__label">Android Switch Disabled</div>
|
|
60
|
+
<div class="mdw-list__secondary mdw-selection__icon mdw-theme" mdw-ink="teal contrast" mdw-switch></div>
|
|
61
|
+
</a>
|
|
62
|
+
</li>
|
|
63
|
+
</ul>
|
|
64
|
+
<div class="mdw-list__subheader mdw-theme" mdw-ink="medium">.mdw-list[role="radiogroup"]</div>
|
|
65
|
+
<ul class="mdw-list mdw-selection__radio-group" role="radiogroup">
|
|
66
|
+
<li class="mdw-list__item">
|
|
67
|
+
<a class="mdw-list__content mdw-selection mdw-overlay" aria-checked="true">
|
|
68
|
+
<div class="mdw-list__text mdw-selection__label">
|
|
69
|
+
<div class="mdw-list__text-line">Option 1</div>
|
|
70
|
+
<div class="mdw-list__text-line mdw-theme" mdw-ink="medium">Description</div>
|
|
71
|
+
</div>
|
|
72
|
+
<div class="mdw-list__secondary mdw-selection__icon mdw-theme" mdw-ink="teal" mdw-radio></div>
|
|
73
|
+
</a>
|
|
74
|
+
</li>
|
|
75
|
+
<li class="mdw-list__item">
|
|
76
|
+
<a class="mdw-list__content mdw-selection mdw-overlay" aria-checked="false">
|
|
77
|
+
<div class="mdw-list__text mdw-selection__label">
|
|
78
|
+
<div class="mdw-list__text-line">Option 2</div>
|
|
79
|
+
<div class="mdw-list__text-line mdw-theme" mdw-ink="medium">Description</div>
|
|
80
|
+
</div>
|
|
81
|
+
<div class="mdw-list__secondary mdw-selection__icon mdw-theme" mdw-ink="blue" mdw-radio></div>
|
|
82
|
+
</a>
|
|
83
|
+
</li>
|
|
84
|
+
</ul>
|
|
85
|
+
<div class="mdw-list__subheader mdw-theme" mdw-ink="medium">Multiple check</div>
|
|
86
|
+
<ul class="mdw-list" role="listbox" aria-multiselectable="true">
|
|
87
|
+
<li class="mdw-list__item">
|
|
88
|
+
<a class="mdw-list__content mdw-selection mdw-overlay" aria-checked="true">
|
|
89
|
+
<div class="mdw-list__text mdw-selection__label">Option 1</div>
|
|
90
|
+
<div class="mdw-list__secondary mdw-selection__icon mdw-theme" mdw-ink="teal" mdw-checkbox></div>
|
|
91
|
+
</a>
|
|
92
|
+
</li>
|
|
93
|
+
<li class="mdw-list__item">
|
|
94
|
+
<a class="mdw-list__content mdw-selection mdw-overlay" aria-checked="true">
|
|
95
|
+
<div class="mdw-list__text mdw-selection__label">Option 2</div>
|
|
96
|
+
<div class="mdw-list__secondary mdw-selection__icon mdw-theme" mdw-ink="blue" mdw-checkbox></div>
|
|
97
|
+
</a>
|
|
98
|
+
</li>
|
|
99
|
+
<li class="mdw-list__item">
|
|
100
|
+
<a class="mdw-list__content mdw-selection mdw-overlay" aria-checked="false">
|
|
101
|
+
<div class="mdw-list__text mdw-selection__label">Option 3</div>
|
|
102
|
+
<div class="mdw-list__secondary mdw-selection__icon mdw-theme" mdw-ink="warn" mdw-checkbox></div>
|
|
103
|
+
</a>
|
|
104
|
+
</li>
|
|
105
|
+
</ul>
|
|
106
|
+
</div>
|
|
107
|
+
</div>
|
|
108
|
+
</div>
|
|
109
|
+
</div>
|
|
110
|
+
</div>
|
|
111
|
+
<script src="selection.min.js"></script>
|