@shortfuse/materialdesignweb 0.0.9 → 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/.browserslistrc +3 -0
- package/.eslintrc.json +146 -27
- package/.stylelintrc.json +598 -2
- package/.vscode/launch.json +20 -5
- package/.vscode/settings.json +3 -0
- package/.vscode/tasks.json +19 -10
- package/CHANGELOG.md +24 -0
- package/README.md +84 -2
- package/adapters/datatable/column.js +203 -0
- package/adapters/datatable/index.js +972 -0
- package/adapters/dom/index.js +601 -0
- package/adapters/list/index.js +69 -0
- package/adapters/search/index.js +521 -0
- package/components/appbar/_spec.scss +225 -0
- package/components/appbar/_theme.scss +0 -0
- package/components/appbar/index.scss +2 -0
- package/components/banner/_spec.scss +118 -0
- package/components/banner/_theme.scss +0 -0
- package/components/banner/index.scss +2 -0
- package/components/bottomnav/README.md +85 -0
- package/components/bottomnav/_spec.scss +157 -0
- package/components/bottomnav/_theme.scss +0 -0
- package/components/bottomnav/index.js +122 -0
- package/components/bottomnav/index.scss +2 -0
- package/components/bottomnav/item.js +89 -0
- package/components/{core/button → button}/README.md +16 -22
- package/components/button/_spec.scss +161 -0
- package/components/button/_theme.scss +65 -0
- package/components/button/index.eta +32 -0
- package/components/button/index.js +43 -0
- package/components/button/index.pug +18 -0
- package/components/button/index.scss +2 -0
- package/components/card/_spec.scss +249 -0
- package/components/card/_theme.scss +0 -0
- package/components/card/index.scss +2 -0
- package/components/chip/_spec.scss +134 -0
- package/components/chip/_theme.scss +177 -0
- package/components/chip/index.js +21 -0
- package/components/chip/index.scss +2 -0
- package/components/chip/item.js +20 -0
- package/components/datatable/_spec.scss +288 -0
- package/components/datatable/_theme.scss +154 -0
- package/components/datatable/cell.js +45 -0
- package/components/datatable/columnheader.js +47 -0
- package/components/datatable/index.js +388 -0
- package/components/datatable/index.scss +2 -0
- package/components/datatable/row.js +49 -0
- package/components/datatable/rowheader.js +18 -0
- package/components/dialog/_spec.scss +213 -0
- package/components/dialog/_theme.scss +0 -0
- package/components/dialog/index.js +627 -0
- package/components/dialog/index.scss +2 -0
- package/components/divider/_spec.scss +13 -0
- package/components/divider/_theme.scss +0 -0
- package/components/divider/index.scss +2 -0
- package/components/elevation/_spec.scss +9 -0
- package/components/elevation/_theme.scss +0 -0
- package/components/elevation/index.scss +2 -0
- package/components/fab/_spec.scss +222 -0
- package/components/fab/_theme.scss +0 -0
- package/components/fab/index.js +103 -0
- package/components/fab/index.scss +2 -0
- package/components/grid/_spec.scss +312 -0
- package/components/grid/_theme.scss +0 -0
- package/components/grid/index.scss +2 -0
- package/components/layout/_mixins.scss +33 -0
- package/components/layout/_spec.scss +1012 -0
- package/components/layout/_theme.scss +44 -0
- package/components/layout/index.js +464 -0
- package/components/layout/index.scss +2 -0
- package/components/list/_spec.scss +397 -0
- package/components/list/_theme.scss +111 -0
- package/components/list/content.js +110 -0
- package/components/list/index.js +260 -0
- package/components/list/index.scss +2 -0
- package/components/list/item.js +170 -0
- package/components/list/secondary.js +46 -0
- package/components/menu/_spec.scss +362 -0
- package/components/menu/_theme.scss +0 -0
- package/components/menu/index.js +721 -0
- package/components/menu/index.scss +2 -0
- package/components/menu/item.js +239 -0
- package/components/{core/progress/style.scss → progress/_spec.scss} +36 -25
- package/components/progress/_theme.scss +0 -0
- package/components/progress/index.js +36 -0
- package/components/progress/index.scss +2 -0
- package/components/selection/_spec.scss +386 -0
- package/components/selection/_theme.scss +166 -0
- package/components/selection/index.eta +60 -0
- package/components/selection/index.js +76 -0
- package/components/selection/index.pug +30 -0
- package/components/selection/index.scss +2 -0
- package/components/selection/input.js +56 -0
- package/components/selection/radiogroup.js +47 -0
- package/components/slider/_spec.scss +64 -0
- package/components/slider/_theme.scss +0 -0
- package/components/slider/index.scss +2 -0
- package/components/snackbar/_spec.scss +195 -0
- package/components/snackbar/_theme.scss +0 -0
- package/components/snackbar/index.js +344 -0
- package/components/snackbar/index.scss +2 -0
- package/components/tab/_spec.scss +235 -0
- package/components/tab/_theme.scss +0 -0
- package/components/tab/content.js +205 -0
- package/components/tab/index.js +260 -0
- package/components/tab/index.scss +2 -0
- package/components/tab/item.js +89 -0
- package/components/tab/list.js +210 -0
- package/components/tab/panel.js +54 -0
- package/components/template/_theme.scss +27 -0
- package/components/{core/textfield → textfield}/README.md +70 -50
- package/components/textfield/_mixins.scss +52 -0
- package/components/textfield/_spec.scss +809 -0
- package/components/textfield/_theme.scss +299 -0
- package/components/textfield/index.eta +74 -0
- package/components/textfield/index.js +168 -0
- package/components/textfield/index.pug +30 -0
- package/components/textfield/index.scss +2 -0
- package/components/tooltip/_spec.scss +188 -0
- package/components/tooltip/_theme.scss +0 -0
- package/components/tooltip/index.scss +2 -0
- package/components/type/_spec.scss +224 -0
- package/components/type/_theme.scss +0 -0
- package/components/type/index.scss +2 -0
- package/core/_breakpoint.scss +189 -0
- package/core/_elevation.scss +38 -0
- package/core/_length.scss +9 -0
- package/core/_motion.scss +31 -0
- package/core/_platform.scss +34 -0
- package/core/_type.scss +127 -0
- package/core/aria/attributes.js +141 -0
- package/core/aria/button.js +50 -0
- package/core/aria/keyboard.js +93 -0
- package/core/aria/rovingtabindex.js +178 -0
- package/core/aria/tab.js +60 -0
- package/core/color/_spec.scss +0 -0
- package/core/color/_theme.scss +390 -0
- package/core/color/index.scss +2 -0
- package/core/document/index.js +39 -0
- package/core/dom.js +271 -0
- package/core/overlay/_spec.scss +31 -0
- package/core/overlay/_theme.scss +171 -0
- package/core/overlay/index.js +108 -0
- package/core/overlay/index.scss +2 -0
- package/core/ripple/_spec.scss +197 -0
- package/core/ripple/_theme.scss +40 -0
- package/core/ripple/index.js +294 -0
- package/core/ripple/index.scss +2 -0
- package/core/theme/_config.scss +2 -0
- package/core/theme/_mixins.scss +172 -0
- package/{components/theming/palettes.scss → core/theme/_palettes.scss} +173 -150
- package/core/theme/_variables.scss +24 -0
- package/core/theme/index.js +50 -0
- package/core/throttler.js +42 -0
- package/core/transition/index.js +468 -0
- package/docs/_flex.scss +22 -0
- package/docs/_menuoptions.js +183 -0
- package/docs/_mixins.pug +155 -0
- 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/_sample-utils.js +93 -0
- package/docs/_storage.js +33 -0
- package/docs/docs.scss +295 -0
- package/docs/index.eta +16 -0
- package/docs/index.js +0 -0
- package/docs/pages/appbar.eta +114 -0
- package/docs/pages/appbar.js +0 -0
- package/docs/pages/appbar.pug +78 -0
- package/docs/pages/bottomnav.eta +188 -0
- package/docs/pages/bottomnav.js +115 -0
- package/docs/pages/bottomnav.pug +137 -0
- package/docs/pages/button.eta +124 -0
- package/docs/pages/button.js +224 -0
- package/docs/pages/button.pug +121 -0
- package/docs/pages/card.eta +90 -0
- package/docs/pages/card.js +177 -0
- package/docs/pages/card.pug +74 -0
- package/docs/pages/chip.eta +122 -0
- package/docs/pages/chip.js +82 -0
- package/docs/pages/chip.pug +91 -0
- package/docs/pages/color.eta +143 -0
- package/docs/pages/color.js +262 -0
- package/docs/pages/color.pug +121 -0
- package/docs/pages/datatable.eta +323 -0
- package/docs/pages/datatable.js +164 -0
- package/docs/pages/datatable.pug +283 -0
- package/docs/pages/dialog.eta +186 -0
- package/docs/pages/dialog.js +177 -0
- package/docs/pages/dialog.pug +132 -0
- 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/pages/elevation.js +0 -0
- package/docs/pages/elevation.pug +25 -0
- package/docs/pages/fab.eta +99 -0
- package/docs/pages/fab.js +44 -0
- package/docs/pages/fab.pug +66 -0
- package/docs/pages/grid.eta +135 -0
- package/docs/pages/grid.js +128 -0
- package/docs/pages/grid.pug +95 -0
- package/docs/pages/layout.eta +8 -0
- package/docs/pages/layout.js +0 -0
- package/docs/pages/layout.pug +7 -0
- package/docs/pages/list.eta +465 -0
- package/docs/pages/list.js +9 -0
- package/docs/pages/list.pug +326 -0
- package/docs/pages/menu.eta +276 -0
- package/docs/pages/menu.js +217 -0
- package/docs/pages/menu.pug +205 -0
- package/docs/pages/overlay.eta +69 -0
- package/docs/pages/overlay.js +4 -0
- package/docs/pages/overlay.pug +55 -0
- package/docs/pages/progress.eta +23 -0
- package/docs/pages/progress.js +12 -0
- package/docs/pages/progress.pug +16 -0
- package/docs/pages/ripple.eta +27 -0
- package/docs/pages/ripple.js +4 -0
- package/docs/pages/ripple.pug +21 -0
- package/docs/pages/search.eta +246 -0
- package/docs/pages/search.js +243 -0
- package/docs/pages/search.pug +165 -0
- 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/pages/slider.js +0 -0
- package/docs/pages/slider.pug +17 -0
- package/docs/pages/snackbar.eta +83 -0
- package/docs/pages/snackbar.js +158 -0
- package/docs/pages/snackbar.pug +60 -0
- package/docs/pages/tab.eta +421 -0
- package/docs/pages/tab.js +151 -0
- package/docs/pages/tab.pug +304 -0
- package/docs/pages/textfield.eta +486 -0
- package/docs/pages/textfield.js +254 -0
- package/docs/pages/textfield.pug +360 -0
- package/docs/pages/tooltip.eta +94 -0
- package/docs/pages/tooltip.js +0 -0
- package/docs/pages/tooltip.pug +78 -0
- package/docs/pages/transition.eta +117 -0
- package/docs/pages/transition.js +54 -0
- package/docs/pages/transition.pug +76 -0
- package/docs/pages/type.eta +31 -0
- package/docs/pages/type.js +0 -0
- package/docs/pages/type.pug +29 -0
- package/docs/postrender.js +39 -0
- package/docs/prerender.js +16 -0
- package/docs/pwa/_dialogs.eta +143 -0
- package/docs/pwa/_dialogs.pug +96 -0
- package/docs/pwa/_menus.eta +16 -0
- package/docs/pwa/_menus.pug +11 -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/pwa/pwa.pug +325 -0
- 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 +43 -28
- package/scripts/deploy-docs.sh +9 -0
- package/templates/index.eta +2 -0
- package/templates/index.pug +3 -0
- package/utils/function.js +3 -0
- package/webpack.config.cjs +257 -0
- package/components/_index.scss +0 -4
- package/components/all-components.scss +0 -14
- package/components/common/functions.scss +0 -173
- package/components/common/mixins.scss +0 -107
- package/components/common/motion.scss +0 -36
- package/components/common/ripple.scss +0 -92
- package/components/common/variables.scss +0 -48
- package/components/complex/dialog/style.scss +0 -159
- package/components/complex/dialog/theming.scss +0 -29
- package/components/complex/navdrawer/style.scss +0 -477
- package/components/complex/navdrawer/theming.scss +0 -58
- package/components/complex/search/index.js +0 -492
- package/components/core/bottomnav/README.md +0 -85
- package/components/core/bottomnav/index.js +0 -140
- package/components/core/bottomnav/style.scss +0 -173
- package/components/core/bottomnav/theming.scss +0 -42
- package/components/core/button/index.js +0 -52
- package/components/core/button/style.scss +0 -283
- package/components/core/button/theming.scss +0 -131
- package/components/core/list/index.js +0 -94
- package/components/core/list/style.scss +0 -269
- package/components/core/list/theming.scss +0 -74
- package/components/core/menu/index.js +0 -127
- package/components/core/menu/style.scss +0 -239
- package/components/core/menu/theming.scss +0 -55
- package/components/core/progress/index.js +0 -33
- package/components/core/selection/style.scss +0 -249
- package/components/core/selection/theming.scss +0 -49
- package/components/core/switch/style.scss +0 -3
- package/components/core/tab/index.js +0 -174
- package/components/core/tab/style.scss +0 -202
- package/components/core/tab/theming.scss +0 -43
- package/components/core/textfield/index.js +0 -169
- package/components/core/textfield/style.scss +0 -672
- package/components/core/textfield/theming.scss +0 -262
- package/components/core/toolbar/style.scss +0 -109
- package/components/core/toolbar/theming.scss +0 -28
- package/components/core/tooltip/style.scss +0 -127
- package/components/core/type/style.scss +0 -133
- package/components/core/type/theming.scss +0 -25
- package/components/index.js +0 -24
- package/components/template/theming.scss +0 -31
- package/components/theming/theming.scss +0 -504
- package/docs/bottomnav.html +0 -171
- package/docs/bottomnav.min.js +0 -383
- package/docs/button.html +0 -322
- package/docs/button.min.js +0 -251
- package/docs/components.min.css +0 -1
- package/docs/components.min.js +0 -83
- package/docs/dialog.html +0 -103
- package/docs/dialog.min.js +0 -160
- package/docs/docs.min.css +0 -1
- package/docs/docs.min.js +0 -83
- package/docs/index.html +0 -55
- package/docs/index.min.js +0 -83
- package/docs/list.html +0 -442
- package/docs/list.min.js +0 -312
- package/docs/menu.html +0 -185
- package/docs/menu.min.js +0 -370
- package/docs/navdrawer.html +0 -199
- package/docs/navdrawer.min.js +0 -244
- package/docs/progress.html +0 -75
- package/docs/progress.min.js +0 -162
- package/docs/search.html +0 -230
- package/docs/search.min.js +0 -1202
- package/docs/selection.html +0 -188
- package/docs/selection.min.js +0 -160
- package/docs/src/complex/dialog.js +0 -3
- package/docs/src/complex/dialog.pug +0 -44
- package/docs/src/complex/navdrawer.js +0 -82
- package/docs/src/complex/navdrawer.pug +0 -109
- package/docs/src/complex/search.js +0 -207
- package/docs/src/complex/search.pug +0 -143
- package/docs/src/components.scss +0 -1
- package/docs/src/core/bottomnav.js +0 -22
- package/docs/src/core/bottomnav.pug +0 -93
- package/docs/src/core/button.js +0 -16
- package/docs/src/core/button.pug +0 -73
- package/docs/src/core/list.js +0 -21
- package/docs/src/core/list.pug +0 -246
- package/docs/src/core/menu.js +0 -33
- package/docs/src/core/menu.pug +0 -108
- package/docs/src/core/progress.js +0 -11
- package/docs/src/core/progress.pug +0 -17
- package/docs/src/core/selection.js +0 -4
- package/docs/src/core/selection.pug +0 -92
- package/docs/src/core/tab.js +0 -21
- package/docs/src/core/tab.pug +0 -180
- package/docs/src/core/textfield.js +0 -15
- package/docs/src/core/textfield.pug +0 -274
- package/docs/src/core/toolbar.js +0 -4
- package/docs/src/core/toolbar.pug +0 -79
- package/docs/src/core/tooltip.js +0 -4
- package/docs/src/core/tooltip.pug +0 -76
- package/docs/src/core/type.js +0 -4
- package/docs/src/core/type.pug +0 -36
- package/docs/src/docs.scss +0 -200
- package/docs/src/index.pug +0 -5
- package/docs/src/mixins.pug +0 -72
- package/docs/src/targetHandler.js +0 -50
- package/docs/src/theming.ie11.scss +0 -35
- package/docs/src/theming.scss +0 -36
- package/docs/tab.html +0 -301
- package/docs/tab.min.js +0 -397
- package/docs/textfield.html +0 -476
- package/docs/textfield.min.js +0 -381
- package/docs/theming.ie11.min.css +0 -1
- package/docs/theming.ie11.min.js +0 -83
- package/docs/theming.min.css +0 -1
- package/docs/theming.min.js +0 -83
- package/docs/toolbar.html +0 -213
- package/docs/toolbar.min.js +0 -160
- package/docs/tooltip.html +0 -138
- package/docs/tooltip.min.js +0 -160
- package/docs/type.html +0 -94
- package/docs/type.min.js +0 -160
- package/webpack.config.js +0 -176
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
<% var T = '../../templates/index.eta' %>
|
|
2
|
+
<% layout('../_partials/_header.eta', {page: 'bottomnav'}) %>
|
|
3
|
+
<div class="mdw-grid" mdw-margin-top mdw-margin-bottom mdw-stretch>
|
|
4
|
+
<div class="mdw-grid__item" mdw-colspan="100%">
|
|
5
|
+
<h5 class="mdw-type" mdw-baseline-next="36">Bottom navigation bars allow movement between primary destinations in an app.</h5>
|
|
6
|
+
<p class="mdw-typeBottom">navigation bars display three to five destinations at the bottom of a screen. Each destination is represented by an icon and an optional text label. When a bottom navigation icon is tapped, the user is taken to the top-level navigation destination associated with that icon.</p>
|
|
7
|
+
</div>
|
|
8
|
+
<div class="mdw-grid__item" mdw-colspan="6">
|
|
9
|
+
<div class="mdw-grid__content component-sample">
|
|
10
|
+
<div class="render-fill">
|
|
11
|
+
<%~ includeFile('../_partials/_androidstatusbar.eta', { surface: 'background 900', dark:true }) %>
|
|
12
|
+
<%~ includeFile('../_partials/_appbar.eta', { surface: 'background 800', dark:true, body:'Bottom Navigation' }) %>
|
|
13
|
+
<div class="content"></div>
|
|
14
|
+
<nav class="mdw-bottomnav">
|
|
15
|
+
<a class="mdw-bottomnav__item mdw-theme" mdw-ink="primary" aria-selected="true">
|
|
16
|
+
<div class="mdw-bottomnav__icon">
|
|
17
|
+
<i class="material-icons">history</i>
|
|
18
|
+
</div>
|
|
19
|
+
<div class="mdw-bottomnav__label">Recents</div>
|
|
20
|
+
</a>
|
|
21
|
+
<a class="mdw-bottomnav__item mdw-theme" mdw-ink="primary" aria-selected="false">
|
|
22
|
+
<div class="mdw-bottomnav__icon">
|
|
23
|
+
<div class="mdw-bottomnav__badge mdw-theme" mdw-surface="warn 500" mdw-ink="white" mdw-badge></div>
|
|
24
|
+
<i class="material-icons">favorite</i>
|
|
25
|
+
</div>
|
|
26
|
+
<div class="mdw-bottomnav__label">Favorites</div>
|
|
27
|
+
</a>
|
|
28
|
+
<a class="mdw-bottomnav__item mdw-theme" mdw-ink="primary" aria-selected="false">
|
|
29
|
+
<div class="mdw-bottomnav__icon">
|
|
30
|
+
<div class="mdw-bottomnav__badge mdw-theme" mdw-surface="warn 500" mdw-ink="white" mdw-badge="99+"></div>
|
|
31
|
+
<i class="material-icons">near_me</i>
|
|
32
|
+
</div>
|
|
33
|
+
<div class="mdw-bottomnav__label">Nearby</div>
|
|
34
|
+
</a>
|
|
35
|
+
</nav>
|
|
36
|
+
<%~ includeFile('../_partials/_androidnavbar.eta') %>
|
|
37
|
+
</div>
|
|
38
|
+
</div>
|
|
39
|
+
</div>
|
|
40
|
+
<div class="mdw-grid__item" mdw-colspan="4">
|
|
41
|
+
<div class="mdw-type" mdw-style="subtitle">Javascript</div>
|
|
42
|
+
<div class="docs-option-list">
|
|
43
|
+
<%~ includeFile(T, { selection: { ink:'secondary', type:'radio', name:'javascript', value:'required', checked:true, text: 'Required' }}) %>
|
|
44
|
+
<%~ includeFile(T, { selection: { ink:'secondary', type:'radio', name:'javascript', value:'optional', disabled:true, text: 'Optional' }}) %>
|
|
45
|
+
<%~ includeFile(T, { selection: { ink:'secondary', type:'radio', name:'javascript', value:'none', disabled:true, text: 'None' }}) %>
|
|
46
|
+
</div>
|
|
47
|
+
<div class="mdw-type" mdw-style="subtitle">Ink</div>
|
|
48
|
+
<div class="docs-option-list">
|
|
49
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'ink', value:'default', text:'Default' }}) %>
|
|
50
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'ink', value:'primary', checked:true, text:'Primary' }}) %>
|
|
51
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'ink', value:'secondary', text:'Secondary' }}) %>
|
|
52
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'ink', value:'warn', text:'Warn' }}) %>
|
|
53
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'ink', value:'purple', text:'Purple' }}) %>
|
|
54
|
+
</div>
|
|
55
|
+
<div class="mdw-type" mdw-style="subtitle">Surface</div>
|
|
56
|
+
<div class="docs-option-list">
|
|
57
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'surface', value:'none', checked:true, text:'None' }}) %>
|
|
58
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'surface', value:'card', text:'Card' }}) %>
|
|
59
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'surface', value:'primary 500 dark', text:'Primary 500 (Dark)' }}) %>
|
|
60
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'surface', value:'secondary 100 light', text:'Secondary 100 (Light)' }}) %>
|
|
61
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'surface', value:'warn 200 light', text:'Warn 200 (Light)' }}) %>
|
|
62
|
+
<%~ includeFile(T, {selection: { ink:'secondary', type:'radio', name:'surface', value:'green 700 dark', text:'Green 700 (Dark)' }}) %>
|
|
63
|
+
</div>
|
|
64
|
+
</div>
|
|
65
|
+
<div class="mdw-grid__item" mdw-colspan="100%"></div>
|
|
66
|
+
<div class="mdw-grid__item" mdw-colspan="6">
|
|
67
|
+
<h6 class="mdw-type">HTML Code</h6>
|
|
68
|
+
<div class="mdw-card mdw-theme component-code component-html" mdw-surface="card" mdw-border-ink>
|
|
69
|
+
<%~ includeFile(T, {button: { icon: true, ink:'secondary', attributes: { 'aria-pressed': 'false', 'mdw-overlay-off':'activated' }, text: 'PUG', id: 'usePug' }}) %>
|
|
70
|
+
</div>
|
|
71
|
+
</div>
|
|
72
|
+
<div class="mdw-grid__item" mdw-colspan="4">
|
|
73
|
+
<h6 class="mdw-type">Javascript Code</h6>
|
|
74
|
+
<div class="mdw-card mdw-theme component-code component-js" mdw-surface="card" mdw-border-ink></div>
|
|
75
|
+
</div>
|
|
76
|
+
<div class="mdw-grid__item" mdw-colspan="100%">
|
|
77
|
+
<h6 class="mdw-type">Samples</h6>
|
|
78
|
+
</div>
|
|
79
|
+
<div class="mdw-grid__item display-flex" mdw-colspan="6">
|
|
80
|
+
<div class="render-fill mdw-theme" mdw-surface="white" mdw-light>
|
|
81
|
+
<%~ includeFile('../_partials/_androidstatusbar.eta') %>
|
|
82
|
+
<%~ includeFile('../_partials/_appbar.eta', { text: 'Light Theme' }) %>
|
|
83
|
+
<div class="content" style="padding: 16px 0;">
|
|
84
|
+
<ul>
|
|
85
|
+
<li>Radio buttons</li>
|
|
86
|
+
<li>Badges</li>
|
|
87
|
+
</ul>
|
|
88
|
+
</div>
|
|
89
|
+
<nav class="mdw-bottomnav mdw-theme" mdw-ink="primary medium">
|
|
90
|
+
<a class="mdw-bottomnav__item" aria-selected="true">
|
|
91
|
+
<div class="mdw-bottomnav__icon material-icons">history</div>
|
|
92
|
+
<div class="mdw-bottomnav__label">Recents</div>
|
|
93
|
+
</a>
|
|
94
|
+
<a class="mdw-bottomnav__item" aria-selected="false">
|
|
95
|
+
<div class="mdw-bottomnav__icon">
|
|
96
|
+
<div class="mdw-bottomnav__badge mdw-theme" mdw-surface="warn 500" mdw-ink="white" mdw-badge></div>
|
|
97
|
+
<div class="material-icons">favorite</div>
|
|
98
|
+
</div>
|
|
99
|
+
<div class="mdw-bottomnav__label">Favorites</div>
|
|
100
|
+
</a>
|
|
101
|
+
<a class="mdw-bottomnav__item" aria-selected="false">
|
|
102
|
+
<div class="mdw-bottomnav__icon material-icons">near_me</div>
|
|
103
|
+
<div class="mdw-bottomnav__label">Nearby</div>
|
|
104
|
+
</a>
|
|
105
|
+
</nav>
|
|
106
|
+
<%~ includeFile('../_partials/_androidnavbar.eta') %>
|
|
107
|
+
</div>
|
|
108
|
+
</div>
|
|
109
|
+
<div class="mdw-grid__item display-flex" mdw-colspan="6">
|
|
110
|
+
<div class="render-fill js mdw-theme" mdw-surface="black" mdw-dark>
|
|
111
|
+
<%~ includeFile('../_partials/_androidstatusbar.eta') %>
|
|
112
|
+
<%~ includeFile('../_partials/_appbar.eta', {text: 'Dark Theme'}) %>
|
|
113
|
+
<div class="content" style="padding: 16px 0;">
|
|
114
|
+
<ul>
|
|
115
|
+
<li>Disappearing Labels</li>
|
|
116
|
+
<li>Badges</li>
|
|
117
|
+
<li>Shifting labels</li>
|
|
118
|
+
</ul>
|
|
119
|
+
</div>
|
|
120
|
+
<nav class="mdw-bottomnav" mdw-shifting>
|
|
121
|
+
<a class="mdw-bottomnav__item">
|
|
122
|
+
<div class="mdw-bottomnav__icon material-icons">tv</div>
|
|
123
|
+
<div class="mdw-bottomnav__label">Movies</div>
|
|
124
|
+
</a>
|
|
125
|
+
<a class="mdw-bottomnav__item" aria-selected="true">
|
|
126
|
+
<div class="mdw-bottomnav__icon">
|
|
127
|
+
<div class="mdw-bottomnav__badge mdw-theme" mdw-surface="warn 500" mdw-ink="white" mdw-badge></div>
|
|
128
|
+
<div class="material-icons">music_note</div>
|
|
129
|
+
</div>
|
|
130
|
+
<div class="mdw-bottomnav__label">Music</div>
|
|
131
|
+
</a>
|
|
132
|
+
<a class="mdw-bottomnav__item" aria-selected="false">
|
|
133
|
+
<div class="mdw-bottomnav__icon">
|
|
134
|
+
<div class="mdw-bottomnav__badge mdw-theme" mdw-surface="warn 500" mdw-ink="white" mdw-badge="88"></div>
|
|
135
|
+
<div class="material-icons">book</div>
|
|
136
|
+
</div>
|
|
137
|
+
<div class="mdw-bottomnav__label">Books</div>
|
|
138
|
+
</a>
|
|
139
|
+
<a class="mdw-bottomnav__item" aria-selected="false">
|
|
140
|
+
<div class="mdw-bottomnav__icon">
|
|
141
|
+
<div class="mdw-bottomnav__badge mdw-theme" mdw-surface="warn 500" mdw-ink="white" mdw-badge="888+"></div>
|
|
142
|
+
<div class="material-icons">assignment</div>
|
|
143
|
+
</div>
|
|
144
|
+
<div class="mdw-bottomnav__label">Newsstand</div>
|
|
145
|
+
</a>
|
|
146
|
+
</nav>
|
|
147
|
+
<%~ includeFile('../_partials/_androidnavbar.eta') %>
|
|
148
|
+
</div>
|
|
149
|
+
</div>
|
|
150
|
+
<div class="mdw-grid__item display-flex" mdw-colspan="6">
|
|
151
|
+
<div class="render-fill js mdw-theme">
|
|
152
|
+
<%~ includeFile('../_partials/_androidstatusbar.eta') %>
|
|
153
|
+
<%~ includeFile('../_partials/_appbar.eta', {text: 'Tablet'}) %>
|
|
154
|
+
<div class="content" style="padding: 16px 0;">
|
|
155
|
+
<ul>
|
|
156
|
+
<li>Disappearing Labels</li>
|
|
157
|
+
<li>Badges</li>
|
|
158
|
+
</ul>
|
|
159
|
+
</div>
|
|
160
|
+
<nav class="mdw-bottomnav mdw-theme" mdw-surface="teal 700" mdw-dark mdw-shifting>
|
|
161
|
+
<a class="mdw-bottomnav__item" aria-selected="true">
|
|
162
|
+
<div class="mdw-bottomnav__icon">
|
|
163
|
+
<div class="mdw-bottomnav__badge mdw-theme" mdw-surface="warn 500" mdw-ink="white" mdw-badge="4"></div>
|
|
164
|
+
<div class="material-icons">tv</div>
|
|
165
|
+
</div>
|
|
166
|
+
<div class="mdw-bottomnav__label">Movies</div>
|
|
167
|
+
</a>
|
|
168
|
+
<a class="mdw-bottomnav__item" aria-selected="false">
|
|
169
|
+
<div class="mdw-bottomnav__icon">
|
|
170
|
+
<div class="mdw-bottomnav__badge mdw-theme" mdw-surface="warn 500" mdw-ink="white" mdw-badge></div>
|
|
171
|
+
<div class="material-icons">music_note</div>
|
|
172
|
+
</div>
|
|
173
|
+
<div class="mdw-bottomnav__label">Music</div>
|
|
174
|
+
</a>
|
|
175
|
+
<a class="mdw-bottomnav__item" aria-selected="false">
|
|
176
|
+
<div class="mdw-bottomnav__icon material-icons">book</div>
|
|
177
|
+
<div class="mdw-bottomnav__label">Books</div>
|
|
178
|
+
</a>
|
|
179
|
+
<a class="mdw-bottomnav__item" aria-selected="false">
|
|
180
|
+
<div class="mdw-bottomnav__icon material-icons">assignment</div>
|
|
181
|
+
<div class="mdw-bottomnav__label">Newsstand</div>
|
|
182
|
+
</a>
|
|
183
|
+
</nav>
|
|
184
|
+
<%~ includeFile('../_partials/_androidnavbar.eta') %>
|
|
185
|
+
</div>
|
|
186
|
+
</div>
|
|
187
|
+
</div>
|
|
188
|
+
<script src="bottomnav.min.js"></script>
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import * as BottomNav from '../../components/bottomnav/index.js';
|
|
2
|
+
import * as BottomNavItem from '../../components/bottomnav/item.js';
|
|
3
|
+
import * as Button from '../../components/button/index.js';
|
|
4
|
+
import { iterateArrayLike, setTextNode } from '../../core/dom.js';
|
|
5
|
+
import { convertElementToCode } from '../_sample-utils.js';
|
|
6
|
+
|
|
7
|
+
/** @return {void} */
|
|
8
|
+
function initializeSampleComponents() {
|
|
9
|
+
iterateArrayLike(document.querySelectorAll('.mdw-bottomnav'), BottomNav.attach);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/** @type {HTMLElement} */
|
|
13
|
+
let sampleComponent;
|
|
14
|
+
|
|
15
|
+
/** @return {void} */
|
|
16
|
+
function updateSampleCode() {
|
|
17
|
+
// Strip JS related elements and attributes
|
|
18
|
+
BottomNav.detach(sampleComponent);
|
|
19
|
+
sampleComponent.removeAttribute('role');
|
|
20
|
+
iterateArrayLike(sampleComponent.getElementsByClassName('mdw-bottomnav__item'), (item) => {
|
|
21
|
+
BottomNavItem.detach(item);
|
|
22
|
+
item.classList.remove('mdw-ripple');
|
|
23
|
+
item.classList.remove('mdw-overlay');
|
|
24
|
+
item.removeAttribute('mdw-overlay-off');
|
|
25
|
+
item.removeAttribute('role');
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
const htmlCodeElement = document.getElementsByClassName('component-html')[0];
|
|
29
|
+
setTextNode(htmlCodeElement, convertElementToCode(sampleComponent,
|
|
30
|
+
document.getElementById('usePug').getAttribute('aria-pressed') === 'true'));
|
|
31
|
+
|
|
32
|
+
// Reattach JS if requested
|
|
33
|
+
BottomNav.attach(sampleComponent);
|
|
34
|
+
|
|
35
|
+
const jsCodeElement = document.getElementsByClassName('component-js')[0];
|
|
36
|
+
jsCodeElement.textContent = 'mdw.BottomNav.attach(bottomNavElement);';
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/** @return {void} */
|
|
40
|
+
function setupPugButton() {
|
|
41
|
+
const pugButton = document.getElementById('usePug');
|
|
42
|
+
Button.attach(pugButton);
|
|
43
|
+
pugButton.addEventListener('click', () => {
|
|
44
|
+
if (pugButton.getAttribute('aria-pressed') === 'true') {
|
|
45
|
+
pugButton.setAttribute('aria-pressed', 'false');
|
|
46
|
+
} else {
|
|
47
|
+
pugButton.setAttribute('aria-pressed', 'true');
|
|
48
|
+
}
|
|
49
|
+
updateSampleCode();
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* @param {Event} event
|
|
55
|
+
* @return {void}
|
|
56
|
+
*/
|
|
57
|
+
function onOptionChange(event) {
|
|
58
|
+
/** @type {HTMLInputElement} */
|
|
59
|
+
const { name, value } = (event.target);
|
|
60
|
+
switch (name) {
|
|
61
|
+
case 'ink':
|
|
62
|
+
switch (value) {
|
|
63
|
+
case 'default':
|
|
64
|
+
iterateArrayLike(sampleComponent.getElementsByClassName('mdw-bottomnav__item'), (el) => el.removeAttribute('mdw-ink'));
|
|
65
|
+
break;
|
|
66
|
+
default:
|
|
67
|
+
iterateArrayLike(sampleComponent.getElementsByClassName('mdw-bottomnav__item'), (el) => el.setAttribute('mdw-ink', value));
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
70
|
+
break;
|
|
71
|
+
case 'surface':
|
|
72
|
+
switch (value) {
|
|
73
|
+
case 'none':
|
|
74
|
+
sampleComponent.removeAttribute('mdw-surface');
|
|
75
|
+
sampleComponent.removeAttribute('mdw-light');
|
|
76
|
+
sampleComponent.removeAttribute('mdw-dark');
|
|
77
|
+
break;
|
|
78
|
+
default:
|
|
79
|
+
sampleComponent.setAttribute('mdw-surface', value.replace(/ (light|dark)/, ''));
|
|
80
|
+
if (value.indexOf(' light') === -1) {
|
|
81
|
+
sampleComponent.removeAttribute('mdw-light');
|
|
82
|
+
} else {
|
|
83
|
+
sampleComponent.setAttribute('mdw-light', '');
|
|
84
|
+
}
|
|
85
|
+
if (value.indexOf(' dark') === -1) {
|
|
86
|
+
sampleComponent.removeAttribute('mdw-dark');
|
|
87
|
+
} else {
|
|
88
|
+
sampleComponent.setAttribute('mdw-dark', '');
|
|
89
|
+
}
|
|
90
|
+
if (value === 'none') {
|
|
91
|
+
sampleComponent.classList.remove('mdw-theme');
|
|
92
|
+
} else {
|
|
93
|
+
sampleComponent.classList.add('mdw-theme');
|
|
94
|
+
}
|
|
95
|
+
break;
|
|
96
|
+
}
|
|
97
|
+
break;
|
|
98
|
+
default:
|
|
99
|
+
}
|
|
100
|
+
updateSampleCode();
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/** @return {void} */
|
|
104
|
+
function setupComponentOptions() {
|
|
105
|
+
sampleComponent = document.querySelector('.component-sample .mdw-bottomnav');
|
|
106
|
+
BottomNav.attach(sampleComponent);
|
|
107
|
+
iterateArrayLike(document.querySelectorAll('input[name]'), (el) => {
|
|
108
|
+
el.addEventListener('change', onOptionChange);
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
initializeSampleComponents();
|
|
113
|
+
setupComponentOptions();
|
|
114
|
+
setupPugButton();
|
|
115
|
+
updateSampleCode();
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
include ../_mixins.pug
|
|
2
|
+
|
|
3
|
+
+header("bottomnav")
|
|
4
|
+
.mdw-grid(mdw-margin-top mdw-margin-bottom mdw-stretch)
|
|
5
|
+
.mdw-grid__item(mdw-colspan="100%")
|
|
6
|
+
h5.mdw-type(mdw-baseline-next="36") Bottom navigation bars allow movement between primary destinations in an app.
|
|
7
|
+
p.mdw-typeBottom navigation bars display three to five destinations at the bottom of a screen. Each destination is represented by an icon and an optional text label. When a bottom navigation icon is tapped, the user is taken to the top-level navigation destination associated with that icon.
|
|
8
|
+
.mdw-grid__item(mdw-colspan="6")
|
|
9
|
+
.mdw-grid__content.component-sample
|
|
10
|
+
.render-fill
|
|
11
|
+
+androidstatusbar('background 900', 'dark')
|
|
12
|
+
+appbar('background 800', 'dark', [], []) Bottom Navigation
|
|
13
|
+
.content
|
|
14
|
+
nav.mdw-bottomnav
|
|
15
|
+
a.mdw-bottomnav__item.mdw-theme(mdw-ink="primary" aria-selected="true")
|
|
16
|
+
.mdw-bottomnav__icon
|
|
17
|
+
i.material-icons history
|
|
18
|
+
.mdw-bottomnav__label Recents
|
|
19
|
+
a.mdw-bottomnav__item.mdw-theme(mdw-ink="primary" aria-selected="false")
|
|
20
|
+
.mdw-bottomnav__icon
|
|
21
|
+
.mdw-bottomnav__badge.mdw-theme(mdw-surface="warn 500" mdw-ink="white" mdw-badge="")
|
|
22
|
+
i.material-icons favorite
|
|
23
|
+
.mdw-bottomnav__label Favorites
|
|
24
|
+
a.mdw-bottomnav__item.mdw-theme(mdw-ink="primary" aria-selected="false")
|
|
25
|
+
.mdw-bottomnav__icon
|
|
26
|
+
.mdw-bottomnav__badge.mdw-theme(mdw-surface="warn 500" mdw-ink="white" mdw-badge="99+")
|
|
27
|
+
i.material-icons near_me
|
|
28
|
+
.mdw-bottomnav__label Nearby
|
|
29
|
+
+androidnavbar
|
|
30
|
+
.mdw-grid__item(mdw-colspan="4")
|
|
31
|
+
.mdw-type(mdw-style="subtitle") Javascript
|
|
32
|
+
.docs-option-list
|
|
33
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'javascript', value:'required', checked:true}) Required
|
|
34
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'javascript', value:'optional', disabled:true}) Optional
|
|
35
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'javascript', value:'none', disabled:true}) None
|
|
36
|
+
.mdw-type(mdw-style="subtitle") Ink
|
|
37
|
+
.docs-option-list
|
|
38
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'ink', value:'default'}) Default
|
|
39
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'ink', value:'primary', checked:true}) Primary
|
|
40
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'ink', value:'secondary'}) Secondary
|
|
41
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'ink', value:'warn'}) Warn
|
|
42
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'ink', value:'purple'}) Purple
|
|
43
|
+
.mdw-type(mdw-style="subtitle") Surface
|
|
44
|
+
.docs-option-list
|
|
45
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'surface', value:'none', checked:true}) None
|
|
46
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'surface', value:'card'}) Card
|
|
47
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'surface', value:'primary 500 dark'}) Primary 500 (Dark)
|
|
48
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'surface', value:'secondary 100 light'}) Secondary 100 (Light)
|
|
49
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'surface', value:'warn 200 light'}) Warn 200 (Light)
|
|
50
|
+
+mdwSelection({ink:'secondary', type:'radio', name:'surface', value:'green 700 dark'}) Green 700 (Dark)
|
|
51
|
+
.mdw-grid__item(mdw-colspan="100%")
|
|
52
|
+
.mdw-grid__item(mdw-colspan="6")
|
|
53
|
+
h6.mdw-type HTML Code
|
|
54
|
+
.mdw-card.mdw-theme.component-code.component-html(mdw-surface="card" mdw-border-ink)
|
|
55
|
+
+mdwButton({ icon: true, ink:'secondary' })#usePug(aria-pressed="false" mdw-overlay-off="activated") PUG
|
|
56
|
+
.mdw-grid__item(mdw-colspan="4")
|
|
57
|
+
h6.mdw-type Javascript Code
|
|
58
|
+
.mdw-card.mdw-theme.component-code.component-js(mdw-surface="card" mdw-border-ink)
|
|
59
|
+
.mdw-grid__item(mdw-colspan="100%")
|
|
60
|
+
h6.mdw-type Samples
|
|
61
|
+
.mdw-grid__item.display-flex(mdw-colspan="6")
|
|
62
|
+
.render-fill.mdw-theme(mdw-surface="white" mdw-light)
|
|
63
|
+
+androidstatusbar('')
|
|
64
|
+
+appbar('', '', [], []) Light Theme
|
|
65
|
+
.content(style="padding: 16px 0")
|
|
66
|
+
ul
|
|
67
|
+
li Radio buttons
|
|
68
|
+
li Badges
|
|
69
|
+
nav.mdw-bottomnav.mdw-theme(mdw-ink="primary medium")
|
|
70
|
+
a.mdw-bottomnav__item(aria-selected="true")
|
|
71
|
+
.mdw-bottomnav__icon.material-icons history
|
|
72
|
+
.mdw-bottomnav__label Recents
|
|
73
|
+
a.mdw-bottomnav__item(aria-selected="false")
|
|
74
|
+
.mdw-bottomnav__icon
|
|
75
|
+
.mdw-bottomnav__badge.mdw-theme(mdw-surface="warn 500" mdw-ink="white" mdw-badge="")
|
|
76
|
+
.material-icons favorite
|
|
77
|
+
.mdw-bottomnav__label Favorites
|
|
78
|
+
a.mdw-bottomnav__item(aria-selected="false")
|
|
79
|
+
.mdw-bottomnav__icon.material-icons near_me
|
|
80
|
+
.mdw-bottomnav__label Nearby
|
|
81
|
+
+androidnavbar
|
|
82
|
+
.mdw-grid__item.display-flex(mdw-colspan="6")
|
|
83
|
+
.render-fill.js.mdw-theme(mdw-surface="black" mdw-dark)
|
|
84
|
+
+androidstatusbar('')
|
|
85
|
+
+appbar('', '', [], []) Dark Theme
|
|
86
|
+
.content(style="padding: 16px 0")
|
|
87
|
+
ul
|
|
88
|
+
li Disappearing Labels
|
|
89
|
+
li Badges
|
|
90
|
+
li Shifting labels
|
|
91
|
+
nav.mdw-bottomnav(mdw-shifting)
|
|
92
|
+
a.mdw-bottomnav__item
|
|
93
|
+
.mdw-bottomnav__icon.material-icons tv
|
|
94
|
+
.mdw-bottomnav__label Movies
|
|
95
|
+
a.mdw-bottomnav__item(aria-selected="true")
|
|
96
|
+
.mdw-bottomnav__icon
|
|
97
|
+
.mdw-bottomnav__badge.mdw-theme(mdw-surface="warn 500" mdw-ink="white" mdw-badge)
|
|
98
|
+
.material-icons music_note
|
|
99
|
+
.mdw-bottomnav__label Music
|
|
100
|
+
a.mdw-bottomnav__item(aria-selected="false")
|
|
101
|
+
.mdw-bottomnav__icon
|
|
102
|
+
.mdw-bottomnav__badge.mdw-theme(mdw-surface="warn 500" mdw-ink="white" mdw-badge="88")
|
|
103
|
+
.material-icons book
|
|
104
|
+
.mdw-bottomnav__label Books
|
|
105
|
+
a.mdw-bottomnav__item(aria-selected="false")
|
|
106
|
+
.mdw-bottomnav__icon
|
|
107
|
+
.mdw-bottomnav__badge.mdw-theme(mdw-surface="warn 500" mdw-ink="white" mdw-badge="888+")
|
|
108
|
+
.material-icons assignment
|
|
109
|
+
.mdw-bottomnav__label Newsstand
|
|
110
|
+
+androidnavbar
|
|
111
|
+
.mdw-grid__item.display-flex(mdw-colspan="6")
|
|
112
|
+
.render-fill.js.mdw-theme
|
|
113
|
+
+androidstatusbar('')
|
|
114
|
+
+appbar('', '', [], []) Tablet
|
|
115
|
+
.content(style="padding: 16px 0")
|
|
116
|
+
ul
|
|
117
|
+
li Disappearing Labels
|
|
118
|
+
li Badges
|
|
119
|
+
nav.mdw-bottomnav.mdw-theme(mdw-surface="teal 700" mdw-dark mdw-shifting)
|
|
120
|
+
a.mdw-bottomnav__item(aria-selected="true")
|
|
121
|
+
.mdw-bottomnav__icon
|
|
122
|
+
.mdw-bottomnav__badge.mdw-theme(mdw-surface="warn 500" mdw-ink="white" mdw-badge="4")
|
|
123
|
+
.material-icons tv
|
|
124
|
+
.mdw-bottomnav__label Movies
|
|
125
|
+
a.mdw-bottomnav__item(aria-selected="false")
|
|
126
|
+
.mdw-bottomnav__icon
|
|
127
|
+
.mdw-bottomnav__badge.mdw-theme(mdw-surface="warn 500" mdw-ink="white" mdw-badge)
|
|
128
|
+
.material-icons music_note
|
|
129
|
+
.mdw-bottomnav__label Music
|
|
130
|
+
a.mdw-bottomnav__item(aria-selected="false")
|
|
131
|
+
.mdw-bottomnav__icon.material-icons book
|
|
132
|
+
.mdw-bottomnav__label Books
|
|
133
|
+
a.mdw-bottomnav__item(aria-selected="false")
|
|
134
|
+
.mdw-bottomnav__icon.material-icons assignment
|
|
135
|
+
.mdw-bottomnav__label Newsstand
|
|
136
|
+
+androidnavbar
|
|
137
|
+
script(src='bottomnav.min.js')
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
|
|
2
|
+
<% var T = '../../templates/index.eta' %>
|
|
3
|
+
<% layout('../_partials/_header.eta', {page: 'button'}) %>
|
|
4
|
+
<div class="mdw-grid" mdw-margin-top mdw-margin-bottom mdw-stretch>
|
|
5
|
+
<div class="mdw-grid__item" mdw-colspan="100%">
|
|
6
|
+
<div class="mdw-grid__content">
|
|
7
|
+
<h5 class="mdw-type" mdw-baseline-next="36">Buttons communicate the action that will occur when the user touches them.</h5>
|
|
8
|
+
<p class="mdw-type">Material buttons trigger an ink reaction on press. They may display text, imagery, or both.</p>
|
|
9
|
+
</div>
|
|
10
|
+
</div>
|
|
11
|
+
<div class="mdw-grid__item" mdw-colspan="6">
|
|
12
|
+
<div class="mdw-grid__content">
|
|
13
|
+
<div class="component-sample">
|
|
14
|
+
<div class="display-flex"><a class="mdw-button mdw-theme" mdw-ink="secondary">Button</a></div>
|
|
15
|
+
</div>
|
|
16
|
+
</div>
|
|
17
|
+
</div>
|
|
18
|
+
<div class="mdw-grid__item" mdw-colspan="6">
|
|
19
|
+
<div class="mdw-grid__content">
|
|
20
|
+
<div class="mdw-type" mdw-style="subtitle">Javascript</div>
|
|
21
|
+
<div class="docs-option-list">
|
|
22
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'javascript', type:'radio', value:'required', disabled:true, text: 'Required' }}) %>
|
|
23
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'javascript', type:'radio', value:'optional', checked:true, text: 'Optional' }}) %>
|
|
24
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'javascript', type:'radio', value:'none', text: 'None' }}) %>
|
|
25
|
+
</div>
|
|
26
|
+
<div class="mdw-type" mdw-style="subtitle">Overlay</div>
|
|
27
|
+
<div class="docs-option-list">
|
|
28
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'overlay-hover', checked:true, text: 'Hover' }}) %>
|
|
29
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'overlay-focus', checked:true, text: 'Focus' }}) %>
|
|
30
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'overlay-activated', checked:true, text: 'Activated' }}) %>
|
|
31
|
+
</div>
|
|
32
|
+
<div class="mdw-type" mdw-style="subtitle">Options</div>
|
|
33
|
+
<div class="docs-option-list">
|
|
34
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'icon', text: 'Icon' }}) %>
|
|
35
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'raised', text: 'Raised' }}) %>
|
|
36
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'ripple', checked:true, text: 'Ripple' }}) %>
|
|
37
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'disabled', text: 'Disabled' }}) %>
|
|
38
|
+
</div>
|
|
39
|
+
<div class="mdw-type" mdw-style="subtitle">Outline</div>
|
|
40
|
+
<div class="docs-option-list">
|
|
41
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'outline', type:'radio', value:'none', checked:true, text: 'None' }}) %>
|
|
42
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'outline', type:'radio', value:'default', text: 'Default' }}) %>
|
|
43
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'outline', type:'radio', value:'', text: 'Ink' }}) %>
|
|
44
|
+
</div>
|
|
45
|
+
<div class="mdw-type" mdw-style="subtitle">Activated Toggle</div>
|
|
46
|
+
<div class="docs-option-list">
|
|
47
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'toggle', type:'radio', value:'', checked:true, text: 'None' }}) %>
|
|
48
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'toggle', type:'radio', value:'false', text: 'Off' }}) %>
|
|
49
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'toggle', type:'radio', value:'true', text: 'On' }}) %>
|
|
50
|
+
</div>
|
|
51
|
+
<div class="mdw-type" mdw-style="subtitle">Ink</div>
|
|
52
|
+
<div class="docs-option-list">
|
|
53
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'ink', type:'radio', value:'default', text: 'Default' }}) %>
|
|
54
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'ink', type:'radio', value:'primary', text: 'Primary' }}) %>
|
|
55
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'ink', type:'radio', value:'secondary', checked:true, text: 'Secondary' }}) %>
|
|
56
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'ink', type:'radio', value:'warn contrast', text: 'Warn Contrast' }}) %>
|
|
57
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'ink', type:'radio', value:'purple', text: 'Purple' }}) %>
|
|
58
|
+
</div>
|
|
59
|
+
<div class="mdw-type" mdw-style="subtitle">Surface</div>
|
|
60
|
+
<div class="docs-option-list">
|
|
61
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'surface', type:'radio', value:'none', checked:true, text: 'Default' }}) %>
|
|
62
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'surface', type:'radio', value:'primary 500 dark', text: 'Primary (Dark)' }}) %>
|
|
63
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'surface', type:'radio', value:'secondary 100 light', text: 'Secondary (Light)' }}) %>
|
|
64
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'surface', type:'radio', value:'warn 200 light', text: 'Warn 200 (Light)' }}) %>
|
|
65
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'surface', type:'radio', value:'green 700 dark', text: 'Green 700 (Dark)' }}) %>
|
|
66
|
+
</div>
|
|
67
|
+
<div class="mdw-type" mdw-style="subtitle">HTML Element Type</div>
|
|
68
|
+
<div class="docs-option-list">
|
|
69
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'htmltype', type:'radio', value:'a', checked:true, text: 'HTMLAnchorElement' }}) %>
|
|
70
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'htmltype', type:'radio', value:'button', text: 'HTMLButtonElement' }}) %>
|
|
71
|
+
<%~ includeFile(T, { selection: {ink:'secondary', name:'htmltype', type:'radio', value:'div', text: 'HTMLDivElement' }}) %>
|
|
72
|
+
</div>
|
|
73
|
+
</div>
|
|
74
|
+
</div>
|
|
75
|
+
<div class="mdw-grid__item" mdw-colspan="100%" style="max-height:0;"></div>
|
|
76
|
+
<div class="mdw-grid__item" mdw-colspan="6">
|
|
77
|
+
<div class="mdw-grid__content">
|
|
78
|
+
<h6 class="mdw-type">HTML Code</h6>
|
|
79
|
+
<div class="mdw-card mdw-theme component-code component-html" mdw-surface="card" mdw-border-ink>
|
|
80
|
+
<%~ includeFile(T, { button: { icon:true, ink:'secondary', id:'usePug', text: 'PUG', attributes: { 'aria-pressed':"false", 'mdw-overlay-off':"activated" }}}) %>
|
|
81
|
+
</div>
|
|
82
|
+
</div>
|
|
83
|
+
</div>
|
|
84
|
+
<div class="mdw-grid__item" mdw-colspan="6">
|
|
85
|
+
<div class="mdw-grid__content">
|
|
86
|
+
<h6 class="mdw-type">Javascript Code</h6>
|
|
87
|
+
<div class="mdw-card mdw-theme component-code component-js" mdw-surface="card" mdw-border-ink></div>
|
|
88
|
+
</div>
|
|
89
|
+
</div>
|
|
90
|
+
<div class="mdw-grid__item" mdw-colspan="100%">
|
|
91
|
+
<div class="mdw-grid__content">
|
|
92
|
+
<h6 class="mdw-type">Samples</h6>
|
|
93
|
+
</div>
|
|
94
|
+
</div>
|
|
95
|
+
<div class="mdw-grid__item" mdw-colspan="6">
|
|
96
|
+
<div class="mdw-grid__content">
|
|
97
|
+
<div class="render-fill mdw-theme">
|
|
98
|
+
<%~ includeFile('../_partials/_androidstatusbar.eta') %>
|
|
99
|
+
<%~ includeFile('../_partials/_appbar.eta', {text: 'CSS Only'}) %>
|
|
100
|
+
<div class="content mdw-theme" style="padding: 16px 0;" mdw-surface="binary">
|
|
101
|
+
<div>
|
|
102
|
+
<%~ includeFile('../_partials/_buttontest.eta') %>
|
|
103
|
+
</div>
|
|
104
|
+
</div>
|
|
105
|
+
<%~ includeFile('../_partials/_androidnavbar.eta') %>
|
|
106
|
+
</div>
|
|
107
|
+
</div>
|
|
108
|
+
</div>
|
|
109
|
+
<div class="mdw-grid__item" mdw-colspan="6">
|
|
110
|
+
<div class="mdw-grid__content">
|
|
111
|
+
<div class="render-fill js mdw-theme">
|
|
112
|
+
<%~ includeFile('../_partials/_androidstatusbar.eta') %>
|
|
113
|
+
<%~ includeFile('../_partials/_appbar.eta', {text: 'Javascript'}) %>
|
|
114
|
+
<div class="content mdw-theme" style="padding: 16px 0;" mdw-surface="binary">
|
|
115
|
+
<div>
|
|
116
|
+
<%~ includeFile('../_partials/_buttontest.eta') %>
|
|
117
|
+
</div>
|
|
118
|
+
</div>
|
|
119
|
+
<%~ includeFile('../_partials/_androidnavbar.eta') %>
|
|
120
|
+
</div>
|
|
121
|
+
</div>
|
|
122
|
+
</div>
|
|
123
|
+
</div>
|
|
124
|
+
<script src="button.min.js"></script>
|