@shortfuse/materialdesignweb 0.4.0 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +155 -79
- package/bin/generate-css.js +12 -0
- package/components/Badge.css +30 -0
- package/components/Badge.js +15 -0
- package/components/Body.css +14 -0
- package/components/Body.js +7 -0
- package/components/BottomAppBar.css +23 -0
- package/components/BottomAppBar.js +25 -0
- package/components/Box.css +31 -0
- package/components/Box.js +24 -0
- package/components/Button.css +146 -0
- package/components/Button.js +95 -0
- package/components/Button.md +61 -0
- package/components/Card.css +109 -0
- package/components/Card.js +82 -0
- package/components/Checkbox.css +77 -0
- package/components/Checkbox.js +59 -0
- package/components/CheckboxIcon.css +89 -0
- package/components/CheckboxIcon.js +41 -0
- package/components/Chip.css +35 -0
- package/components/Chip.js +22 -0
- package/components/Dialog.css +235 -0
- package/components/Dialog.js +327 -0
- package/components/DialogActions.js +13 -0
- package/components/Divider.css +41 -0
- package/components/Divider.js +13 -0
- package/components/ExtendedFab.css +24 -0
- package/components/ExtendedFab.js +11 -0
- package/components/Fab.css +23 -0
- package/components/Fab.js +26 -0
- package/components/FilterChip.css +80 -0
- package/components/FilterChip.js +51 -0
- package/components/Headline.css +14 -0
- package/components/Headline.js +33 -0
- package/components/Icon.css +76 -0
- package/components/Icon.js +174 -0
- package/components/IconButton.css +151 -0
- package/components/IconButton.js +65 -0
- package/components/Input.js +16 -0
- package/components/Label.css +14 -0
- package/components/Label.js +7 -0
- package/components/Layout.css +19 -0
- package/components/Layout.js +12 -0
- package/components/List.css +12 -0
- package/components/List.js +17 -0
- package/components/ListItem.css +224 -0
- package/components/ListItem.js +112 -0
- package/components/ListOption.css +34 -0
- package/components/ListOption.js +122 -0
- package/components/ListSelect.css +9 -0
- package/components/ListSelect.js +206 -0
- package/components/Menu.css +171 -0
- package/components/Menu.js +470 -0
- package/components/MenuItem.css +53 -0
- package/components/MenuItem.js +215 -0
- package/components/Nav.css +17 -0
- package/components/Nav.js +23 -0
- package/components/NavBar.css +34 -0
- package/components/NavBar.js +88 -0
- package/components/NavBarItem.css +41 -0
- package/components/NavBarItem.js +7 -0
- package/components/NavDrawer.css +31 -0
- package/components/NavDrawer.js +13 -0
- package/components/NavDrawerItem.css +42 -0
- package/components/NavDrawerItem.js +12 -0
- package/components/NavItem.css +181 -0
- package/components/NavItem.js +83 -0
- package/components/NavRail.css +47 -0
- package/components/NavRail.js +17 -0
- package/components/NavRailItem.css +25 -0
- package/components/NavRailItem.js +7 -0
- package/components/Option.js +91 -0
- package/components/Outline.css +138 -0
- package/components/Pane.css +261 -0
- package/components/Pane.js +21 -0
- package/components/Progress.css +74 -0
- package/components/Progress.js +67 -0
- package/components/ProgressCircle.css +226 -0
- package/components/ProgressLine.css +155 -0
- package/components/Radio.css +83 -0
- package/components/Radio.js +42 -0
- package/components/RadioIcon.css +73 -0
- package/components/RadioIcon.js +37 -0
- package/components/Ripple.css +74 -0
- package/components/Ripple.js +114 -0
- package/components/SegmentedButton.css +94 -0
- package/components/SegmentedButton.js +49 -0
- package/components/SegmentedButtonGroup.css +12 -0
- package/components/SegmentedButtonGroup.js +44 -0
- package/components/Select.css +52 -0
- package/components/Select.js +71 -0
- package/components/Shape.css +132 -0
- package/components/Shape.js +25 -0
- package/components/Slider.css +306 -0
- package/components/Slider.js +206 -0
- package/components/Snackbar.css +80 -0
- package/components/Snackbar.js +75 -0
- package/components/Surface.css +10 -0
- package/components/Surface.js +23 -0
- package/components/Switch.css +63 -0
- package/components/Switch.js +127 -0
- package/components/SwitchIcon.css +177 -0
- package/components/SwitchIcon.js +89 -0
- package/components/SwitchIconAnimations.css +89 -0
- package/components/Tab.css +85 -0
- package/components/Tab.js +103 -0
- package/components/TabContent.js +151 -0
- package/components/TabList.css +129 -0
- package/components/TabList.js +309 -0
- package/components/TabPanel.js +37 -0
- package/components/TextArea.css +93 -0
- package/components/TextArea.js +229 -0
- package/components/Title.css +14 -0
- package/components/Title.js +15 -0
- package/components/Tooltip.css +40 -0
- package/components/Tooltip.js +22 -0
- package/components/TopAppBar.css +209 -0
- package/components/TopAppBar.js +201 -0
- package/core/Composition.js +988 -0
- package/core/CustomElement.js +844 -0
- package/core/ICustomElement.d.ts +288 -0
- package/core/ICustomElement.js +1 -0
- package/core/css.js +51 -0
- package/core/customTypes.js +125 -0
- package/core/dom.js +56 -245
- package/core/identify.js +40 -0
- package/core/observe.js +410 -0
- package/core/template.js +121 -0
- package/core/typings.d.ts +135 -0
- package/core/typings.js +1 -0
- package/mixins/AriaReflectorMixin.js +42 -0
- package/mixins/AriaToolbarMixin.js +13 -0
- package/mixins/ControlMixin.css +57 -0
- package/mixins/ControlMixin.js +212 -0
- package/mixins/DensityMixin.css +40 -0
- package/mixins/DensityMixin.js +11 -0
- package/mixins/FlexableMixin.css +79 -0
- package/mixins/FlexableMixin.js +32 -0
- package/mixins/FormAssociatedMixin.js +170 -0
- package/mixins/InputMixin.js +335 -0
- package/mixins/KeyboardNavMixin.js +244 -0
- package/mixins/RTLObserverMixin.js +35 -0
- package/mixins/ResizeObserverMixin.js +38 -0
- package/mixins/RippleMixin.css +12 -0
- package/mixins/RippleMixin.js +115 -0
- package/mixins/ScrollListenerMixin.js +100 -0
- package/mixins/ShapeMixin.css +135 -0
- package/mixins/ShapeMixin.js +31 -0
- package/mixins/StateMixin.css +82 -0
- package/mixins/StateMixin.js +114 -0
- package/mixins/SurfaceMixin.css +150 -0
- package/mixins/SurfaceMixin.js +32 -0
- package/mixins/TextFieldMixin.css +657 -0
- package/mixins/TextFieldMixin.js +121 -0
- package/mixins/ThemableMixin.css +204 -0
- package/mixins/ThemableMixin.js +16 -0
- package/mixins/TooltipTriggerMixin.css +27 -0
- package/mixins/TooltipTriggerMixin.js +366 -0
- package/mixins/TouchTargetMixin.css +26 -0
- package/mixins/TouchTargetMixin.js +9 -0
- package/package.json +57 -41
- package/theming/index.js +594 -0
- package/theming/loader.js +24 -0
- package/utils/cli.js +11 -0
- package/utils/color_keywords.js +151 -0
- package/utils/hct/Cam16.js +298 -0
- package/utils/hct/CorePalette.js +84 -0
- package/utils/hct/Hct.js +172 -0
- package/utils/hct/Scheme.js +587 -0
- package/utils/hct/TonalPalette.js +68 -0
- package/utils/hct/ViewingConditions.js +136 -0
- package/utils/hct/blend.js +93 -0
- package/utils/hct/colorUtils.js +302 -0
- package/utils/hct/hctSolver.js +559 -0
- package/utils/hct/helper.js +182 -0
- package/utils/hct/mathUtils.js +153 -0
- package/utils/jsonMergePatch.js +100 -0
- package/utils/jsx-runtime.js +101 -0
- package/utils/popup.js +117 -0
- package/utils/svg.js +129 -0
- package/.browserslistrc +0 -3
- package/.eslintrc.json +0 -153
- package/.stylelintrc.json +0 -600
- package/.vscode/launch.json +0 -31
- package/.vscode/settings.json +0 -3
- package/.vscode/tasks.json +0 -32
- package/CHANGELOG.md +0 -24
- package/CODE_OF_CONDUCT.md +0 -46
- package/adapters/datatable/column.js +0 -203
- package/adapters/datatable/index.js +0 -972
- package/adapters/dom/index.js +0 -601
- package/adapters/list/index.js +0 -69
- package/adapters/search/index.js +0 -521
- package/components/appbar/_spec.scss +0 -225
- package/components/appbar/_theme.scss +0 -0
- package/components/appbar/index.scss +0 -2
- package/components/banner/_spec.scss +0 -118
- package/components/banner/_theme.scss +0 -0
- package/components/banner/index.scss +0 -2
- package/components/bottomnav/README.md +0 -85
- package/components/bottomnav/_spec.scss +0 -157
- package/components/bottomnav/_theme.scss +0 -0
- package/components/bottomnav/index.js +0 -122
- package/components/bottomnav/index.scss +0 -2
- package/components/bottomnav/item.js +0 -89
- package/components/button/README.md +0 -61
- package/components/button/_spec.scss +0 -161
- package/components/button/_theme.scss +0 -65
- package/components/button/index.eta +0 -32
- package/components/button/index.js +0 -43
- package/components/button/index.pug +0 -18
- package/components/button/index.scss +0 -2
- package/components/card/_spec.scss +0 -249
- package/components/card/_theme.scss +0 -0
- package/components/card/index.scss +0 -2
- package/components/chip/_spec.scss +0 -134
- package/components/chip/_theme.scss +0 -177
- package/components/chip/index.js +0 -21
- package/components/chip/index.scss +0 -2
- package/components/chip/item.js +0 -20
- package/components/datatable/_spec.scss +0 -288
- package/components/datatable/_theme.scss +0 -154
- package/components/datatable/cell.js +0 -45
- package/components/datatable/columnheader.js +0 -47
- package/components/datatable/index.js +0 -388
- package/components/datatable/index.scss +0 -2
- package/components/datatable/row.js +0 -49
- package/components/datatable/rowheader.js +0 -18
- package/components/dialog/_spec.scss +0 -213
- package/components/dialog/_theme.scss +0 -0
- package/components/dialog/index.js +0 -627
- package/components/dialog/index.scss +0 -2
- package/components/divider/_spec.scss +0 -13
- package/components/divider/_theme.scss +0 -0
- package/components/divider/index.scss +0 -2
- package/components/elevation/_spec.scss +0 -9
- package/components/elevation/_theme.scss +0 -0
- package/components/elevation/index.scss +0 -2
- package/components/fab/_spec.scss +0 -222
- package/components/fab/_theme.scss +0 -0
- package/components/fab/index.js +0 -103
- package/components/fab/index.scss +0 -2
- package/components/grid/_spec.scss +0 -312
- package/components/grid/_theme.scss +0 -0
- package/components/grid/index.scss +0 -2
- package/components/layout/_mixins.scss +0 -33
- package/components/layout/_spec.scss +0 -1012
- package/components/layout/_theme.scss +0 -44
- package/components/layout/index.js +0 -464
- package/components/layout/index.scss +0 -2
- package/components/list/_spec.scss +0 -397
- package/components/list/_theme.scss +0 -111
- package/components/list/content.js +0 -110
- package/components/list/index.js +0 -260
- package/components/list/index.scss +0 -2
- package/components/list/item.js +0 -170
- package/components/list/secondary.js +0 -46
- package/components/menu/_spec.scss +0 -362
- package/components/menu/_theme.scss +0 -0
- package/components/menu/index.js +0 -721
- package/components/menu/index.scss +0 -2
- package/components/menu/item.js +0 -239
- package/components/progress/_spec.scss +0 -147
- package/components/progress/_theme.scss +0 -0
- package/components/progress/index.js +0 -36
- package/components/progress/index.scss +0 -2
- package/components/selection/_spec.scss +0 -386
- package/components/selection/_theme.scss +0 -166
- package/components/selection/index.eta +0 -60
- package/components/selection/index.js +0 -76
- package/components/selection/index.pug +0 -30
- package/components/selection/index.scss +0 -2
- package/components/selection/input.js +0 -56
- package/components/selection/radiogroup.js +0 -47
- package/components/slider/_spec.scss +0 -64
- package/components/slider/_theme.scss +0 -0
- package/components/slider/index.scss +0 -2
- package/components/snackbar/_spec.scss +0 -195
- package/components/snackbar/_theme.scss +0 -0
- package/components/snackbar/index.js +0 -344
- package/components/snackbar/index.scss +0 -2
- package/components/tab/_spec.scss +0 -235
- package/components/tab/_theme.scss +0 -0
- package/components/tab/content.js +0 -205
- package/components/tab/index.js +0 -260
- package/components/tab/index.scss +0 -2
- package/components/tab/item.js +0 -89
- package/components/tab/list.js +0 -210
- package/components/tab/panel.js +0 -54
- package/components/template/_theme.scss +0 -27
- package/components/textfield/README.md +0 -179
- package/components/textfield/_mixins.scss +0 -52
- package/components/textfield/_spec.scss +0 -809
- package/components/textfield/_theme.scss +0 -299
- package/components/textfield/index.eta +0 -74
- package/components/textfield/index.js +0 -168
- package/components/textfield/index.pug +0 -30
- package/components/textfield/index.scss +0 -2
- package/components/tooltip/_spec.scss +0 -188
- package/components/tooltip/_theme.scss +0 -0
- package/components/tooltip/index.scss +0 -2
- package/components/type/_spec.scss +0 -224
- package/components/type/_theme.scss +0 -0
- package/components/type/index.scss +0 -2
- package/core/_breakpoint.scss +0 -189
- package/core/_elevation.scss +0 -38
- package/core/_length.scss +0 -9
- package/core/_motion.scss +0 -31
- package/core/_platform.scss +0 -34
- package/core/_type.scss +0 -127
- package/core/aria/attributes.js +0 -141
- package/core/aria/button.js +0 -50
- package/core/aria/keyboard.js +0 -93
- package/core/aria/rovingtabindex.js +0 -178
- package/core/aria/tab.js +0 -60
- package/core/color/_spec.scss +0 -0
- package/core/color/_theme.scss +0 -390
- package/core/color/index.scss +0 -2
- package/core/document/index.js +0 -39
- package/core/overlay/_spec.scss +0 -31
- package/core/overlay/_theme.scss +0 -171
- package/core/overlay/index.js +0 -108
- package/core/overlay/index.scss +0 -2
- package/core/ripple/_spec.scss +0 -197
- package/core/ripple/_theme.scss +0 -40
- package/core/ripple/index.js +0 -294
- package/core/ripple/index.scss +0 -2
- package/core/theme/_config.scss +0 -2
- package/core/theme/_mixins.scss +0 -172
- package/core/theme/_palettes.scss +0 -406
- package/core/theme/_variables.scss +0 -24
- package/core/theme/index.js +0 -50
- package/core/throttler.js +0 -42
- package/core/transition/index.js +0 -468
- package/docs/_flex.scss +0 -22
- package/docs/_menuoptions.js +0 -183
- package/docs/_mixins.pug +0 -155
- package/docs/_partials/_androidnavbar.eta +0 -5
- package/docs/_partials/_androidstatusbar.eta +0 -13
- package/docs/_partials/_appbar.eta +0 -29
- package/docs/_partials/_buttontest.eta +0 -31
- package/docs/_partials/_header.eta +0 -149
- package/docs/_partials/_navlistitem.eta +0 -16
- package/docs/_partials/_target.eta +0 -1
- package/docs/_sample-utils.js +0 -93
- package/docs/_storage.js +0 -33
- package/docs/docs.scss +0 -295
- package/docs/index.eta +0 -16
- package/docs/index.js +0 -0
- package/docs/pages/appbar.eta +0 -114
- package/docs/pages/appbar.js +0 -0
- package/docs/pages/appbar.pug +0 -78
- package/docs/pages/bottomnav.eta +0 -188
- package/docs/pages/bottomnav.js +0 -115
- package/docs/pages/bottomnav.pug +0 -137
- package/docs/pages/button.eta +0 -124
- package/docs/pages/button.js +0 -224
- package/docs/pages/button.pug +0 -121
- package/docs/pages/card.eta +0 -90
- package/docs/pages/card.js +0 -177
- package/docs/pages/card.pug +0 -74
- package/docs/pages/chip.eta +0 -122
- package/docs/pages/chip.js +0 -82
- package/docs/pages/chip.pug +0 -91
- package/docs/pages/color.eta +0 -143
- package/docs/pages/color.js +0 -262
- package/docs/pages/color.pug +0 -121
- package/docs/pages/datatable.eta +0 -323
- package/docs/pages/datatable.js +0 -164
- package/docs/pages/datatable.pug +0 -283
- package/docs/pages/dialog.eta +0 -186
- package/docs/pages/dialog.js +0 -177
- package/docs/pages/dialog.pug +0 -132
- package/docs/pages/dom.eta +0 -26
- package/docs/pages/dom.js +0 -143
- package/docs/pages/dom.pug +0 -22
- package/docs/pages/elevation.eta +0 -35
- package/docs/pages/elevation.js +0 -0
- package/docs/pages/elevation.pug +0 -25
- package/docs/pages/fab.eta +0 -99
- package/docs/pages/fab.js +0 -44
- package/docs/pages/fab.pug +0 -66
- package/docs/pages/grid.eta +0 -135
- package/docs/pages/grid.js +0 -128
- package/docs/pages/grid.pug +0 -95
- package/docs/pages/layout.eta +0 -8
- package/docs/pages/layout.js +0 -0
- package/docs/pages/layout.pug +0 -7
- package/docs/pages/list.eta +0 -465
- package/docs/pages/list.js +0 -9
- package/docs/pages/list.pug +0 -326
- package/docs/pages/menu.eta +0 -276
- package/docs/pages/menu.js +0 -217
- package/docs/pages/menu.pug +0 -205
- package/docs/pages/overlay.eta +0 -69
- package/docs/pages/overlay.js +0 -4
- package/docs/pages/overlay.pug +0 -55
- package/docs/pages/progress.eta +0 -23
- package/docs/pages/progress.js +0 -12
- package/docs/pages/progress.pug +0 -16
- package/docs/pages/ripple.eta +0 -27
- package/docs/pages/ripple.js +0 -4
- package/docs/pages/ripple.pug +0 -21
- package/docs/pages/search.eta +0 -246
- package/docs/pages/search.js +0 -243
- package/docs/pages/search.pug +0 -165
- package/docs/pages/selection.eta +0 -111
- package/docs/pages/selection.js +0 -13
- package/docs/pages/selection.pug +0 -74
- package/docs/pages/slider.eta +0 -23
- package/docs/pages/slider.js +0 -0
- package/docs/pages/slider.pug +0 -17
- package/docs/pages/snackbar.eta +0 -83
- package/docs/pages/snackbar.js +0 -158
- package/docs/pages/snackbar.pug +0 -60
- package/docs/pages/tab.eta +0 -421
- package/docs/pages/tab.js +0 -151
- package/docs/pages/tab.pug +0 -304
- package/docs/pages/textfield.eta +0 -486
- package/docs/pages/textfield.js +0 -254
- package/docs/pages/textfield.pug +0 -360
- package/docs/pages/tooltip.eta +0 -94
- package/docs/pages/tooltip.js +0 -0
- package/docs/pages/tooltip.pug +0 -78
- package/docs/pages/transition.eta +0 -117
- package/docs/pages/transition.js +0 -54
- package/docs/pages/transition.pug +0 -76
- package/docs/pages/type.eta +0 -31
- package/docs/pages/type.js +0 -0
- package/docs/pages/type.pug +0 -29
- package/docs/postrender.js +0 -39
- package/docs/prerender.js +0 -16
- package/docs/pwa/_dialogs.eta +0 -143
- package/docs/pwa/_dialogs.pug +0 -96
- package/docs/pwa/_menus.eta +0 -16
- package/docs/pwa/_menus.pug +0 -11
- package/docs/pwa/pwa-prerender.js +0 -3
- package/docs/pwa/pwa.eta +0 -480
- package/docs/pwa/pwa.js +0 -306
- package/docs/pwa/pwa.pug +0 -325
- package/docs/pwa/pwa.scss +0 -26
- package/docs/spec.scss +0 -26
- package/docs/themes/_component-themes.scss +0 -26
- package/docs/themes/theme-colored-fallbacks.scss +0 -17
- package/docs/themes/theme-colored.scss +0 -17
- package/docs/themes/theme-default-fallbacks.scss +0 -17
- package/docs/themes/theme-default.scss +0 -17
- package/jsconfig.json +0 -12
- package/scripts/deploy-docs.sh +0 -9
- package/templates/index.eta +0 -2
- package/templates/index.pug +0 -3
- package/webpack.config.cjs +0 -257
package/docs/pages/ripple.js
DELETED
package/docs/pages/ripple.pug
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
include ../_mixins.pug
|
|
2
|
-
|
|
3
|
-
+header("ripple")
|
|
4
|
-
.mdw-grid(mdw-margin-top mdw-margin-bottom mdw-stretch)
|
|
5
|
-
.mdw-grid__item(mdw-colspan="4")
|
|
6
|
-
.mdw-grid__content
|
|
7
|
-
h6.mdw-type Javascript
|
|
8
|
-
.display-flex.flex-column.js
|
|
9
|
-
.demo-core-item.mdw-elevation.mdw-ripple.mdw-theme(mdw-elevation="1" mdw-ink="default" mdw-surface="binary") Default Ink
|
|
10
|
-
.demo-core-item.mdw-elevation.mdw-ripple.mdw-theme(mdw-elevation="1" mdw-ink="primary" mdw-surface="binary") Primary Ink
|
|
11
|
-
.demo-core-item.mdw-elevation.mdw-ripple.mdw-theme(mdw-elevation="1" mdw-ink="secondary" mdw-surface="binary") Secondary Ink
|
|
12
|
-
.demo-core-item.mdw-elevation.mdw-ripple.mdw-theme(mdw-elevation="1" mdw-ink="warn" mdw-surface="binary") Warn Ink
|
|
13
|
-
.mdw-grid__item(mdw-colspan="4")
|
|
14
|
-
.mdw-grid__content
|
|
15
|
-
h6.mdw-type CSS Only
|
|
16
|
-
.display-flex.flex-column
|
|
17
|
-
.demo-core-item.mdw-elevation.mdw-ripple.mdw-theme(mdw-elevation="1" mdw-ink="default" mdw-surface="binary") Default Ink
|
|
18
|
-
.demo-core-item.mdw-elevation.mdw-ripple.mdw-theme(mdw-elevation="1" mdw-ink="primary" mdw-surface="binary") Primary Ink
|
|
19
|
-
.demo-core-item.mdw-elevation.mdw-ripple.mdw-theme(mdw-elevation="1" mdw-ink="secondary" mdw-surface="binary") Secondary Ink
|
|
20
|
-
.demo-core-item.mdw-elevation.mdw-ripple.mdw-theme(mdw-elevation="1" mdw-ink="warn" mdw-surface="binary") Warn Ink
|
|
21
|
-
script(src='ripple.min.js')
|
package/docs/pages/search.eta
DELETED
|
@@ -1,246 +0,0 @@
|
|
|
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>
|
package/docs/pages/search.js
DELETED
|
@@ -1,243 +0,0 @@
|
|
|
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
|
-
|
|
8
|
-
/** @typedef {{line1:string, line2:string}} CustomSearchResult */
|
|
9
|
-
|
|
10
|
-
/** @type {SearchAdapter<any>} */
|
|
11
|
-
let searchDocsSimple;
|
|
12
|
-
/** @type {SearchAdapter<any>} */
|
|
13
|
-
let searchDocsMultiline;
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* @param {string} [filter]
|
|
17
|
-
* @return {CustomSearchResult[]}
|
|
18
|
-
*/
|
|
19
|
-
function performFakeSearch(filter) {
|
|
20
|
-
const results = [];
|
|
21
|
-
// eslint-disable-next-line guard-for-in, no-restricted-syntax
|
|
22
|
-
for (const key in navigator) {
|
|
23
|
-
/** @type {keyof Navigator} */
|
|
24
|
-
const navKey = (key);
|
|
25
|
-
const value = navigator[navKey] && navigator[navKey].toString();
|
|
26
|
-
if (!filter || key.indexOf(filter) !== -1 || (value && value.indexOf(filter) !== -1)) {
|
|
27
|
-
results.push({ line1: key, line2: value });
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
return results;
|
|
31
|
-
}
|
|
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
|
-
|
|
48
|
-
/**
|
|
49
|
-
* @param {HTMLLIElement} listItemElement
|
|
50
|
-
* @param {CustomSearchResult} result
|
|
51
|
-
* @return {void}
|
|
52
|
-
*/
|
|
53
|
-
function searchResultRenderer(listItemElement, result) {
|
|
54
|
-
if (!listItemElement.children.length) {
|
|
55
|
-
const markup = `
|
|
56
|
-
<div class="mdw-list__content mdw-theme" mdw-ink="secondary" aria-selected="false">
|
|
57
|
-
<div class="mdw-list__text">
|
|
58
|
-
<div class="mdw-list__text-line"></div>
|
|
59
|
-
<div class="mdw-list__text-line"></div>
|
|
60
|
-
</div>
|
|
61
|
-
</div>`;
|
|
62
|
-
// eslint-disable-next-line no-param-reassign
|
|
63
|
-
listItemElement.innerHTML = markup;
|
|
64
|
-
ListItem.attach(listItemElement);
|
|
65
|
-
}
|
|
66
|
-
const lines = listItemElement.getElementsByClassName('mdw-list__text-line');
|
|
67
|
-
setTextNode(lines[0], result.line1);
|
|
68
|
-
setTextNode(lines[1], result.line2);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
/** @return {void} */
|
|
72
|
-
function buildCustomSearch1() {
|
|
73
|
-
const textfield = document.getElementById('search-textfield-custom1');
|
|
74
|
-
const list = document.getElementById('search-list-custom1');
|
|
75
|
-
/** @type {HTMLElement} */
|
|
76
|
-
const busyIndicator = (textfield.getElementsByClassName('custom-busy-indicator')[0]);
|
|
77
|
-
|
|
78
|
-
// For purpose of this demo results are cached.
|
|
79
|
-
// Actual filter is performed by SearchAdapter
|
|
80
|
-
|
|
81
|
-
/** @type {ListAdapter<CustomSearchResult>} */
|
|
82
|
-
const customListAdapter = new ListAdapter({
|
|
83
|
-
element: list,
|
|
84
|
-
datasource: [],
|
|
85
|
-
render: searchResultRenderer,
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
/** @type {CustomSearchResult[]} */
|
|
89
|
-
let myCachedResults = null;
|
|
90
|
-
|
|
91
|
-
/** @type {SearchAdapter<CustomSearchResult>} */
|
|
92
|
-
const searchDocsCustom = new SearchAdapter({
|
|
93
|
-
textfield,
|
|
94
|
-
list,
|
|
95
|
-
searchOnFocus: false,
|
|
96
|
-
dropdown: true,
|
|
97
|
-
textFilter: 'startsWith',
|
|
98
|
-
suggestionMethod: 'append',
|
|
99
|
-
performSearch(input, resolve) {
|
|
100
|
-
// Use precached results
|
|
101
|
-
if (myCachedResults != null) {
|
|
102
|
-
resolve(myCachedResults);
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
// Display a busy indicator
|
|
107
|
-
showElement(busyIndicator);
|
|
108
|
-
|
|
109
|
-
// Add results to a cached search adapter
|
|
110
|
-
myCachedResults = performFakeSearch();
|
|
111
|
-
|
|
112
|
-
// Let busy indicator spin to illustrate loading
|
|
113
|
-
setTimeout(() => {
|
|
114
|
-
// Send back the search results
|
|
115
|
-
resolve(myCachedResults);
|
|
116
|
-
}, 2000);
|
|
117
|
-
},
|
|
118
|
-
updateList(searchResults, resolve) {
|
|
119
|
-
// SearchAdapter signaling the UI is ready to update with search results
|
|
120
|
-
|
|
121
|
-
if (customListAdapter.datasource === searchResults) {
|
|
122
|
-
// Search results have already been mapped. Nothing to do.
|
|
123
|
-
// SearchAdapter handles item filtering.
|
|
124
|
-
resolve();
|
|
125
|
-
return;
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
// Directly assign search results as ListAdapter's data source
|
|
129
|
-
customListAdapter.datasource = searchResults;
|
|
130
|
-
|
|
131
|
-
// Remove busy indicator
|
|
132
|
-
hideElement(busyIndicator);
|
|
133
|
-
|
|
134
|
-
// Tell ListAdapter to perform a full refresh
|
|
135
|
-
customListAdapter.refresh();
|
|
136
|
-
resolve();
|
|
137
|
-
},
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
searchDocsCustom.list.addEventListener(ListContent.ACTIVATE_EVENT, (event) => {
|
|
141
|
-
/** @type {HTMLElement} */
|
|
142
|
-
const listContentElement = (event.target);
|
|
143
|
-
/** @type {HTMLLIElement} */
|
|
144
|
-
const listItemElement = (listContentElement.parentElement);
|
|
145
|
-
const selectedItem = customListAdapter.elementDataMap.get(listItemElement);
|
|
146
|
-
const text = `${selectedItem.line1}:${selectedItem.line2}`;
|
|
147
|
-
document.getElementById('search-result-custom1').textContent = text;
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
/** @return {void} */
|
|
152
|
-
function buildCustomSearch2() {
|
|
153
|
-
const textfield = document.getElementById('search-textfield-custom2');
|
|
154
|
-
const list = document.getElementById('search-list-custom2');
|
|
155
|
-
/** @type {HTMLElement} */
|
|
156
|
-
const busyIndicator = (textfield.getElementsByClassName('custom-busy-indicator')[0]);
|
|
157
|
-
/** @type {HTMLElement} */
|
|
158
|
-
const noResultsIndicator = (textfield.getElementsByClassName('custom-no-results-indicator')[0]);
|
|
159
|
-
|
|
160
|
-
/** @type {ListAdapter<CustomSearchResult>} */
|
|
161
|
-
const customListAdapter = new ListAdapter({
|
|
162
|
-
element: list,
|
|
163
|
-
datasource: [],
|
|
164
|
-
render: searchResultRenderer,
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
// For purpose of this query is "searched" every time with no cache.
|
|
168
|
-
// SearchAdapter performs no filter
|
|
169
|
-
|
|
170
|
-
/** @type {SearchAdapter<CustomSearchResult>} */
|
|
171
|
-
const searchDocsCustom = new SearchAdapter({
|
|
172
|
-
textfield,
|
|
173
|
-
list,
|
|
174
|
-
debounce: 300,
|
|
175
|
-
dropdown: true,
|
|
176
|
-
filterItems: false,
|
|
177
|
-
performSearch(searchTerm, resolve) {
|
|
178
|
-
// Clear ListAdapter
|
|
179
|
-
customListAdapter.clear();
|
|
180
|
-
|
|
181
|
-
showElement(busyIndicator);
|
|
182
|
-
hideElement(noResultsIndicator);
|
|
183
|
-
|
|
184
|
-
const myData = performFakeSearch(searchTerm);
|
|
185
|
-
setTimeout(() => {
|
|
186
|
-
// Spin for 1000ms
|
|
187
|
-
resolve(myData);
|
|
188
|
-
}, 1000);
|
|
189
|
-
},
|
|
190
|
-
updateList(items, resolve) {
|
|
191
|
-
hideElement(busyIndicator);
|
|
192
|
-
|
|
193
|
-
if (!items.length) {
|
|
194
|
-
showElement(noResultsIndicator);
|
|
195
|
-
resolve();
|
|
196
|
-
return;
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
// Assign results to ListAdapter
|
|
200
|
-
customListAdapter.datasource = items;
|
|
201
|
-
customListAdapter.refresh();
|
|
202
|
-
|
|
203
|
-
resolve();
|
|
204
|
-
},
|
|
205
|
-
});
|
|
206
|
-
searchDocsCustom.list.addEventListener(ListContent.ACTIVATE_EVENT, (event) => {
|
|
207
|
-
/** @type {HTMLElement} */
|
|
208
|
-
const listContentElement = (event.target);
|
|
209
|
-
/** @type {HTMLLIElement} */
|
|
210
|
-
const listItemElement = (listContentElement.parentElement);
|
|
211
|
-
const selectedItem = customListAdapter.elementDataMap.get(listItemElement);
|
|
212
|
-
const text = `${selectedItem.line1}:${selectedItem.line2}`;
|
|
213
|
-
document.getElementById('search-result-custom2').textContent = text;
|
|
214
|
-
});
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
/** @return {void} */
|
|
218
|
-
function setupSearches() {
|
|
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
|
-
}
|
|
232
|
-
|
|
233
|
-
buildCustomSearch1();
|
|
234
|
-
buildCustomSearch2();
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
/** @return {void} */
|
|
238
|
-
function initializeMdwComponents() {
|
|
239
|
-
iterateArrayLike(document.querySelectorAll('.js .mdw-textfield'), TextField.attach);
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
initializeMdwComponents();
|
|
243
|
-
setupSearches();
|
package/docs/pages/search.pug
DELETED
|
@@ -1,165 +0,0 @@
|
|
|
1
|
-
include ../_mixins.pug
|
|
2
|
-
|
|
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
|
|
53
|
-
.comparison.js
|
|
54
|
-
.render
|
|
55
|
-
+androidstatusbar('primary 700', 'dark')
|
|
56
|
-
.mdw-appbar.mdw-theme(mdw-surface="primary 500" mdw-dark)
|
|
57
|
-
.mdw-appbar__action
|
|
58
|
-
.mdw-appbar__start
|
|
59
|
-
+mdwButton({ icon:true }).material-icons arrow_back
|
|
60
|
-
.mdw-appbar__title(mdw-custom)
|
|
61
|
-
.mdw-textfield#search-textfield-simple.mdw-theme(mdw-solo mdw-ink="secondary")
|
|
62
|
-
input.mdw-textfield__input(placeholder="Search")
|
|
63
|
-
.mdw-appbar__end
|
|
64
|
-
+mdwButton({ icon:true }).material-icons clear
|
|
65
|
-
.content
|
|
66
|
-
ul.mdw-list#search-list-simple
|
|
67
|
-
li.mdw-list__item
|
|
68
|
-
a.mdw-list__content Attractions
|
|
69
|
-
li.mdw-list__item
|
|
70
|
-
a.mdw-list__content Dining
|
|
71
|
-
li.mdw-list__item
|
|
72
|
-
a.mdw-list__content Education
|
|
73
|
-
li.mdw-list__item
|
|
74
|
-
a.mdw-list__content Family
|
|
75
|
-
li.mdw-list__item
|
|
76
|
-
a.mdw-list__content Health
|
|
77
|
-
li.mdw-list__item
|
|
78
|
-
a.mdw-list__content Office
|
|
79
|
-
li.mdw-list__item
|
|
80
|
-
a.mdw-list__content Promotions
|
|
81
|
-
li.mdw-list__item
|
|
82
|
-
a.mdw-list__content Radio
|
|
83
|
-
li.mdw-list__item
|
|
84
|
-
a.mdw-list__content Recipes
|
|
85
|
-
li.mdw-list__item
|
|
86
|
-
a.mdw-list__content Sports
|
|
87
|
-
li.mdw-list__item
|
|
88
|
-
a.mdw-list__content Travel
|
|
89
|
-
+androidnavbar
|
|
90
|
-
|
|
91
|
-
.comparison.js
|
|
92
|
-
.render
|
|
93
|
-
+androidstatusbar('primary 700', 'dark')
|
|
94
|
-
.mdw-appbar.mdw-theme(mdw-surface="primary 500" mdw-dark)
|
|
95
|
-
.mdw-appbar__action
|
|
96
|
-
.mdw-appbar__start
|
|
97
|
-
+mdwButton({ icon:true }).material-icons arrow_back
|
|
98
|
-
.mdw-appbar__title(mdw-custom)
|
|
99
|
-
.mdw-textfield#search-textfield-multiline.mdw-theme(mdw-solo mdw-ink="secondary")
|
|
100
|
-
input.mdw-textfield__input(placeholder="Search")
|
|
101
|
-
.mdw-appbar__end
|
|
102
|
-
+mdwButton({ icon:true}).material-icons clear
|
|
103
|
-
.content
|
|
104
|
-
ul.mdw-list#search-list-multiline
|
|
105
|
-
li.mdw-list__subheader.mdw-theme(mdw-ink="medium") Today
|
|
106
|
-
li.mdw-list__item
|
|
107
|
-
.mdw-list__content.mdw-overlay.mdw-ripple
|
|
108
|
-
.mdw-list__avatar
|
|
109
|
-
i.material-icons(style="font-size:40px") 
|
|
110
|
-
.mdw-list__text
|
|
111
|
-
.mdw-list__text-line Brunch this weekend?
|
|
112
|
-
.mdw-list__text-block Ali Connors
|
|
113
|
-
span.mdw-theme(mdw-ink="medium") — I'll be in your neighborhood doing errands this weekend. Do you want to meet?
|
|
114
|
-
li.mdw-list__item
|
|
115
|
-
.mdw-list__content
|
|
116
|
-
.mdw-list__avatar
|
|
117
|
-
i.material-icons(style="font-size:40px") 
|
|
118
|
-
.mdw-list__text
|
|
119
|
-
.mdw-list__text-line Summer BBQ
|
|
120
|
-
span.mdw-theme(mdw-ink="medium") 4
|
|
121
|
-
.mdw-list__text-block to Alex, Scott, Jennifer
|
|
122
|
-
span.mdw-theme(mdw-ink="medium") — Wish I could come. but I'm out of town this weekend.
|
|
123
|
-
li.mdw-list__item
|
|
124
|
-
.mdw-list__content
|
|
125
|
-
.mdw-list__avatar
|
|
126
|
-
i.material-icons(style="font-size:40px") 
|
|
127
|
-
.mdw-list__text
|
|
128
|
-
.mdw-list__text-line Oui oui
|
|
129
|
-
.mdw-list__text-block Sandra Adams
|
|
130
|
-
span.mdw-theme(mdw-ink="medium") — Do you have Paris recommendations? Have you ever been?
|
|
131
|
-
li.mdw-list__item
|
|
132
|
-
.mdw-list__content
|
|
133
|
-
.mdw-list__avatar
|
|
134
|
-
i.material-icons(style="font-size:40px") 
|
|
135
|
-
.mdw-list__text
|
|
136
|
-
.mdw-list__text-line Birthday gift
|
|
137
|
-
.mdw-list__text-block Trevor Hansen
|
|
138
|
-
span.mdw-theme(mdw-ink="medium") — Have any ideas about what we should get Heidi for her birthday?
|
|
139
|
-
li.mdw-list__item
|
|
140
|
-
.mdw-list__content
|
|
141
|
-
.mdw-list__avatar
|
|
142
|
-
i.material-icons(style="font-size:40px") 
|
|
143
|
-
.mdw-list__text
|
|
144
|
-
.mdw-list__text-line Recipe to try
|
|
145
|
-
.mdw-list__text-block Britta Holt
|
|
146
|
-
span.mdw-theme(mdw-ink="medium") — We should eat this: Grated Squash, Corn, and tomatillo Tacos J
|
|
147
|
-
li.mdw-list__item
|
|
148
|
-
.mdw-list__content
|
|
149
|
-
.mdw-list__avatar
|
|
150
|
-
i.material-icons(style="font-size:40px") 
|
|
151
|
-
.mdw-list__text
|
|
152
|
-
.mdw-list__text-line Giants game
|
|
153
|
-
.mdw-list__text-block David Park
|
|
154
|
-
span.mdw-theme(mdw-ink="medium") — Any interest in seeing
|
|
155
|
-
li.mdw-list__item
|
|
156
|
-
.mdw-list__content
|
|
157
|
-
.mdw-list__avatar
|
|
158
|
-
i.material-icons(style="font-size:40px") 
|
|
159
|
-
.mdw-list__text
|
|
160
|
-
.mdw-list__text-line Montauk weekend
|
|
161
|
-
.mdw-list__text-block -----
|
|
162
|
-
+androidnavbar
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
script(src='search.min.js')
|