@material/web 1.0.0-pre.1 → 1.0.0-pre.3
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 +66 -19
- package/autocomplete/autocomplete-item.js.map +1 -1
- package/autocomplete/autocomplete-list.js.map +1 -1
- package/autocomplete/autocomplete-surface.js.map +1 -1
- package/autocomplete/filled-autocomplete.d.ts +0 -2
- package/autocomplete/filled-autocomplete.js +0 -7
- package/autocomplete/filled-autocomplete.js.map +1 -1
- package/autocomplete/lib/_filled-autocomplete.scss +23 -62
- package/autocomplete/lib/_outlined-autocomplete.scss +24 -63
- package/autocomplete/lib/_shared.scss +6 -10
- package/autocomplete/lib/autocomplete.d.ts +2 -6
- package/autocomplete/lib/autocomplete.js +9 -17
- package/autocomplete/lib/autocomplete.js.map +1 -1
- package/autocomplete/lib/autocompleteitem/autocomplete-item.d.ts +2 -2
- package/autocomplete/lib/autocompleteitem/autocomplete-item.js +2 -2
- package/autocomplete/lib/autocompleteitem/autocomplete-item.js.map +1 -1
- package/autocomplete/lib/autocompletelist/autocomplete-list-styles.scss +2 -0
- package/autocomplete/lib/autocompletelist/autocomplete-list.d.ts +1 -1
- package/autocomplete/lib/autocompletelist/autocomplete-list.js +2 -2
- package/autocomplete/lib/autocompletelist/autocomplete-list.js.map +1 -1
- package/autocomplete/lib/autocompletesurface/autocomplete-surface-styles.scss +2 -0
- package/autocomplete/lib/filled-styles.css.js +1 -1
- package/autocomplete/lib/filled-styles.css.js.map +1 -1
- package/autocomplete/lib/filled-styles.scss +2 -0
- package/autocomplete/lib/outlined-styles.css.js +1 -1
- package/autocomplete/lib/outlined-styles.css.js.map +1 -1
- package/autocomplete/lib/outlined-styles.scss +2 -0
- package/autocomplete/lib/shared-styles.scss +2 -0
- package/autocomplete/outlined-autocomplete.d.ts +0 -2
- package/autocomplete/outlined-autocomplete.js +0 -7
- package/autocomplete/outlined-autocomplete.js.map +1 -1
- package/badge/badge.js.map +1 -1
- package/badge/lib/_badge.scss +10 -13
- package/badge/lib/badge-styles.css.js +1 -1
- package/badge/lib/badge-styles.css.js.map +1 -1
- package/badge/lib/badge-styles.scss +2 -0
- package/badge/lib/badge.js.map +1 -1
- package/button/elevated-button.js.map +1 -1
- package/button/elevated-link-button.js.map +1 -1
- package/button/filled-button.js.map +1 -1
- package/button/filled-link-button.js.map +1 -1
- package/button/lib/_elevated-button.scss +10 -15
- package/button/lib/_elevation.scss +5 -2
- package/button/lib/_filled-button.scss +12 -14
- package/button/lib/_icon.scss +15 -24
- package/button/lib/_outlined-button.scss +10 -15
- package/button/lib/_shared.scss +15 -19
- package/button/lib/_text-button.scss +12 -14
- package/button/lib/_tonal-button.scss +10 -15
- package/button/lib/button.d.ts +0 -3
- package/button/lib/button.js +1 -12
- package/button/lib/button.js.map +1 -1
- package/button/lib/elevated-styles.css.js +1 -1
- package/button/lib/elevated-styles.css.js.map +1 -1
- package/button/lib/elevated-styles.scss +2 -0
- package/button/lib/filled-styles.css.js +1 -1
- package/button/lib/filled-styles.css.js.map +1 -1
- package/button/lib/filled-styles.scss +2 -0
- package/button/lib/link-button.d.ts +0 -1
- package/button/lib/link-button.js +0 -5
- package/button/lib/link-button.js.map +1 -1
- package/button/lib/outlined-styles.css.js +1 -1
- package/button/lib/outlined-styles.css.js.map +1 -1
- package/button/lib/outlined-styles.scss +2 -0
- package/button/lib/shared-elevation-styles.css.js +1 -1
- package/button/lib/shared-elevation-styles.css.js.map +1 -1
- package/button/lib/shared-elevation-styles.scss +2 -0
- package/button/lib/shared-styles.css.js +1 -1
- package/button/lib/shared-styles.css.js.map +1 -1
- package/button/lib/shared-styles.scss +2 -0
- package/button/lib/text-styles.css.js +1 -1
- package/button/lib/text-styles.css.js.map +1 -1
- package/button/lib/text-styles.scss +2 -0
- package/button/lib/tonal-styles.css.js +1 -1
- package/button/lib/tonal-styles.css.js.map +1 -1
- package/button/lib/tonal-styles.scss +2 -0
- package/button/outlined-button.js.map +1 -1
- package/button/outlined-link-button.js.map +1 -1
- package/button/text-button.js.map +1 -1
- package/button/text-link-button.js.map +1 -1
- package/button/tonal-button.js.map +1 -1
- package/button/tonal-link-button.js.map +1 -1
- package/checkbox/checkbox.d.ts +11 -2
- package/checkbox/checkbox.js +11 -2
- package/checkbox/checkbox.js.map +1 -1
- package/checkbox/lib/_checkbox.scss +26 -31
- package/checkbox/lib/checkbox-styles.css.js +1 -1
- package/checkbox/lib/checkbox-styles.css.js.map +1 -1
- package/checkbox/lib/checkbox-styles.scss +2 -0
- package/checkbox/lib/checkbox.d.ts +28 -0
- package/checkbox/lib/checkbox.js +33 -4
- package/checkbox/lib/checkbox.js.map +1 -1
- package/checkbox/lib/forced-colors-styles.scss +2 -0
- package/chips/action/delete-action.js.map +1 -1
- package/chips/action/lib/action.js +4 -4
- package/chips/action/lib/action.js.map +1 -1
- package/chips/action/lib/link-action.js +1 -1
- package/chips/action/lib/link-action.js.map +1 -1
- package/chips/action/lib/primary-action.js.map +1 -1
- package/chips/action/lib/selectable-action.js.map +1 -1
- package/chips/action/link-action.js.map +1 -1
- package/chips/action/presentational-action.js.map +1 -1
- package/chips/action/primary-action.js.map +1 -1
- package/chips/action/selectable-action.js.map +1 -1
- package/chips/chip/lib/_assist-chip-theme.scss +4 -0
- package/chips/chip/lib/_chip-theme.scss +30 -41
- package/chips/chip/lib/_chip.scss +2 -0
- package/chips/chip/lib/_filter-chip-theme.scss +4 -0
- package/chips/chip/lib/_input-chip-theme.scss +4 -0
- package/chips/chip/lib/_suggestion-chip-theme.scss +4 -0
- package/chips/chip/lib/chip.js.map +1 -1
- package/chips/chip/lib/foundation.js +4 -4
- package/chips/chip/lib/foundation.js.map +1 -1
- package/chips/chip/lib/link-chip.js.map +1 -1
- package/chips/chip/lib/selectable-chip.js.map +1 -1
- package/chips/chip/lib/types.d.ts +2 -2
- package/chips/chipset/lib/_chip-set-theme.scss +2 -0
- package/chips/chipset/lib/_chip-set.scss +2 -0
- package/chips/chipset/lib/foundation.js +3 -3
- package/chips/chipset/lib/foundation.js.map +1 -1
- package/chips/chipset/lib/types.d.ts +3 -3
- package/controller/events.js +4 -0
- package/controller/events.js.map +1 -1
- package/controller/form-controller.js.map +1 -1
- package/controller/foundation.d.ts +1 -1
- package/controller/observer.d.ts +2 -2
- package/dialog/_dialog.scss +6 -0
- package/dialog/dialog.d.ts +38 -0
- package/dialog/dialog.js +41 -0
- package/dialog/dialog.js.map +1 -0
- package/dialog/harness.d.ts +18 -0
- package/dialog/harness.js +58 -0
- package/dialog/harness.js.map +1 -0
- package/dialog/lib/_dialog.scss +382 -0
- package/dialog/lib/_tokens.scss +89 -0
- package/dialog/lib/dialog-styles.css.js +9 -0
- package/dialog/lib/dialog-styles.css.js.map +1 -0
- package/dialog/lib/dialog-styles.scss +10 -0
- package/dialog/lib/dialog.d.ts +190 -0
- package/dialog/lib/dialog.js +568 -0
- package/dialog/lib/dialog.js.map +1 -0
- package/divider/_divider.scss +6 -0
- package/divider/divider.d.ts +24 -0
- package/divider/divider.js +27 -0
- package/divider/divider.js.map +1 -0
- package/divider/lib/_divider.scss +56 -0
- package/divider/lib/divider-styles.css.js +9 -0
- package/divider/lib/divider-styles.css.js.map +1 -0
- package/divider/lib/divider-styles.scss +10 -0
- package/divider/lib/divider.d.ts +23 -0
- package/divider/lib/divider.js +41 -0
- package/divider/lib/divider.js.map +1 -0
- package/elevation/elevation.js.map +1 -1
- package/elevation/lib/_elevation.scss +5 -1
- package/elevation/lib/_md-comp-elevation.scss +5 -1
- package/elevation/lib/elevation-styles.css.js +1 -1
- package/elevation/lib/elevation-styles.css.js.map +1 -1
- package/elevation/lib/elevation-styles.scss +2 -0
- package/elevation/lib/elevation.js.map +1 -1
- package/fab/fab-extended.js.map +1 -1
- package/fab/fab.js.map +1 -1
- package/fab/lib/_fab-extended.scss +18 -11
- package/fab/lib/_fab.scss +7 -2
- package/fab/lib/_shared.scss +17 -9
- package/fab/lib/fab-extended-styles.css.js +1 -1
- package/fab/lib/fab-extended-styles.css.js.map +1 -1
- package/fab/lib/fab-extended-styles.scss +2 -0
- package/fab/lib/fab-shared-styles.css.js +1 -1
- package/fab/lib/fab-shared-styles.css.js.map +1 -1
- package/fab/lib/fab-shared-styles.scss +2 -0
- package/fab/lib/fab-shared.d.ts +9 -15
- package/fab/lib/fab-shared.js +21 -33
- package/fab/lib/fab-shared.js.map +1 -1
- package/fab/lib/fab-styles.css.js +1 -1
- package/fab/lib/fab-styles.css.js.map +1 -1
- package/fab/lib/fab-styles.scss +2 -0
- package/field/filled-field.d.ts +1 -1
- package/field/filled-field.js +1 -1
- package/field/filled-field.js.map +1 -1
- package/field/harness.js +1 -1
- package/field/harness.js.map +1 -1
- package/field/lib/_content.scss +35 -50
- package/field/lib/_filled-field.scss +60 -76
- package/field/lib/_label.scss +26 -63
- package/field/lib/_md-comp-filled-field.scss +17 -3
- package/field/lib/_md-comp-outlined-field.scss +16 -5
- package/field/lib/_outlined-field.scss +96 -110
- package/field/lib/_shared.scss +15 -35
- package/field/lib/_supporting-text.scss +25 -52
- package/field/lib/field.d.ts +14 -33
- package/field/lib/field.js +79 -101
- package/field/lib/field.js.map +1 -1
- package/field/lib/filled-field.d.ts +10 -16
- package/field/lib/filled-field.js +14 -37
- package/field/lib/filled-field.js.map +1 -1
- package/field/lib/filled-styles.css.js +1 -1
- package/field/lib/filled-styles.css.js.map +1 -1
- package/field/lib/outlined-field.d.ts +4 -10
- package/field/lib/outlined-field.js +13 -33
- package/field/lib/outlined-field.js.map +1 -1
- package/field/lib/outlined-styles.css.js +1 -1
- package/field/lib/outlined-styles.css.js.map +1 -1
- package/field/lib/shared-styles.css.js +1 -1
- package/field/lib/shared-styles.css.js.map +1 -1
- package/field/outlined-field.d.ts +1 -1
- package/field/outlined-field.js +1 -1
- package/field/outlined-field.js.map +1 -1
- package/focus/focus-ring.js.map +1 -1
- package/focus/lib/_focus-ring.scss +10 -23
- package/focus/lib/_md-comp-focus-ring.scss +4 -0
- package/focus/lib/focus-ring-styles.css.js +1 -1
- package/focus/lib/focus-ring-styles.css.js.map +1 -1
- package/focus/lib/focus-ring-styles.scss +2 -0
- package/focus/lib/focus-ring.d.ts +1 -4
- package/focus/lib/focus-ring.js +2 -11
- package/focus/lib/focus-ring.js.map +1 -1
- package/icon/icon.js.map +1 -1
- package/icon/lib/_icon.scss +2 -0
- package/icon/lib/icon-styles.scss +2 -0
- package/iconbutton/filled-icon-button-toggle.js.map +1 -1
- package/iconbutton/filled-icon-button.js.map +1 -1
- package/iconbutton/filled-link-icon-button.js.map +1 -1
- package/iconbutton/filled-tonal-icon-button-toggle.js.map +1 -1
- package/iconbutton/filled-tonal-icon-button.js.map +1 -1
- package/iconbutton/filled-tonal-link-icon-button.js.map +1 -1
- package/iconbutton/lib/_filled-icon-button.scss +20 -20
- package/iconbutton/lib/_filled-tonal-icon-button.scss +20 -20
- package/iconbutton/lib/_outlined-icon-button.scss +27 -21
- package/iconbutton/lib/_shared.scss +13 -33
- package/iconbutton/lib/_standard-icon-button.scss +25 -24
- package/iconbutton/lib/filled-styles.css.js +1 -1
- package/iconbutton/lib/filled-styles.css.js.map +1 -1
- package/iconbutton/lib/filled-styles.scss +2 -0
- package/iconbutton/lib/filled-tonal-styles.css.js +1 -1
- package/iconbutton/lib/filled-tonal-styles.css.js.map +1 -1
- package/iconbutton/lib/filled-tonal-styles.scss +2 -0
- package/iconbutton/lib/icon-button-toggle.d.ts +13 -42
- package/iconbutton/lib/icon-button-toggle.js +33 -103
- package/iconbutton/lib/icon-button-toggle.js.map +1 -1
- package/iconbutton/lib/icon-button.d.ts +2 -4
- package/iconbutton/lib/icon-button.js +3 -9
- package/iconbutton/lib/icon-button.js.map +1 -1
- package/iconbutton/lib/link-icon-button.js.map +1 -1
- package/iconbutton/lib/outlined-styles.css.js +1 -1
- package/iconbutton/lib/outlined-styles.css.js.map +1 -1
- package/iconbutton/lib/outlined-styles.scss +2 -0
- package/iconbutton/lib/shared-styles.css.js +1 -1
- package/iconbutton/lib/shared-styles.css.js.map +1 -1
- package/iconbutton/lib/shared-styles.scss +2 -0
- package/iconbutton/lib/standard-styles.css.js +1 -1
- package/iconbutton/lib/standard-styles.css.js.map +1 -1
- package/iconbutton/lib/standard-styles.scss +2 -0
- package/iconbutton/outlined-icon-button-toggle.js.map +1 -1
- package/iconbutton/outlined-icon-button.js.map +1 -1
- package/iconbutton/outlined-link-icon-button.js.map +1 -1
- package/iconbutton/standard-icon-button-toggle.js.map +1 -1
- package/iconbutton/standard-icon-button.js.map +1 -1
- package/iconbutton/standard-link-icon-button.js.map +1 -1
- package/list/lib/_list.scss +35 -39
- package/list/lib/avatar/_list-item-avatar.scss +3 -1
- package/list/lib/avatar/list-item-avatar-styles.css.js +1 -1
- package/list/lib/avatar/list-item-avatar-styles.css.js.map +1 -1
- package/list/lib/avatar/list-item-avatar-styles.scss +2 -0
- package/list/lib/avatar/list-item-avatar.d.ts +9 -4
- package/list/lib/avatar/list-item-avatar.js +24 -11
- package/list/lib/avatar/list-item-avatar.js.map +1 -1
- package/list/lib/icon/_list-item-icon.scss +7 -1
- package/list/lib/icon/list-item-icon-styles.css.js +1 -1
- package/list/lib/icon/list-item-icon-styles.css.js.map +1 -1
- package/list/lib/icon/list-item-icon-styles.scss +2 -0
- package/list/lib/icon/list-item-icon.d.ts +0 -3
- package/list/lib/icon/list-item-icon.js +1 -12
- package/list/lib/icon/list-item-icon.js.map +1 -1
- package/list/lib/image/_list-item-image.scss +6 -2
- package/list/lib/image/list-item-image-styles.css.js +1 -1
- package/list/lib/image/list-item-image-styles.css.js.map +1 -1
- package/list/lib/image/list-item-image-styles.scss +2 -0
- package/list/lib/image/list-item-image.d.ts +11 -4
- package/list/lib/image/list-item-image.js +24 -13
- package/list/lib/image/list-item-image.js.map +1 -1
- package/list/lib/list-styles.css.js +1 -1
- package/list/lib/list-styles.css.js.map +1 -1
- package/list/lib/list-styles.scss +2 -0
- package/list/lib/list.d.ts +99 -28
- package/list/lib/list.js +213 -112
- package/list/lib/list.js.map +1 -1
- package/list/lib/listitem/_list-item.scss +122 -56
- package/list/lib/listitem/harness.js +2 -1
- package/list/lib/listitem/harness.js.map +1 -1
- package/list/lib/listitem/list-item-private-styles.css.js +9 -0
- package/list/lib/listitem/list-item-private-styles.css.js.map +1 -0
- package/list/lib/listitem/list-item-private-styles.scss +10 -0
- package/list/lib/listitem/list-item-styles.css.js +1 -1
- package/list/lib/listitem/list-item-styles.css.js.map +1 -1
- package/list/lib/listitem/list-item-styles.scss +2 -0
- package/list/lib/listitem/list-item.d.ts +99 -43
- package/list/lib/listitem/list-item.js +204 -173
- package/list/lib/listitem/list-item.js.map +1 -1
- package/list/lib/listitemlink/list-item-link.d.ts +17 -0
- package/list/lib/listitemlink/list-item-link.js +42 -0
- package/list/lib/listitemlink/list-item-link.js.map +1 -0
- package/list/lib/video/_list-item-video.scss +15 -5
- package/list/lib/video/list-item-video-styles.css.js +1 -1
- package/list/lib/video/list-item-video-styles.css.js.map +1 -1
- package/list/lib/video/list-item-video-styles.scss +2 -0
- package/list/lib/video/list-item-video.d.ts +43 -4
- package/list/lib/video/list-item-video.js +90 -12
- package/list/lib/video/list-item-video.js.map +1 -1
- package/list/list-item-avatar.d.ts +2 -1
- package/list/list-item-avatar.js +2 -1
- package/list/list-item-avatar.js.map +1 -1
- package/list/list-item-icon.d.ts +2 -1
- package/list/list-item-icon.js +2 -1
- package/list/list-item-icon.js.map +1 -1
- package/list/list-item-image.d.ts +2 -1
- package/list/list-item-image.js +2 -1
- package/list/list-item-image.js.map +1 -1
- package/list/list-item-link.d.ts +35 -0
- package/list/list-item-link.js +39 -0
- package/list/list-item-link.js.map +1 -0
- package/list/list-item-video.d.ts +2 -1
- package/list/list-item-video.js +2 -1
- package/list/list-item-video.js.map +1 -1
- package/list/list-item.d.ts +18 -2
- package/list/list-item.js +20 -3
- package/list/list-item.js.map +1 -1
- package/list/list.d.ts +15 -1
- package/list/list.js +15 -1
- package/list/list.js.map +1 -1
- package/menu/_menu-item.scss +6 -0
- package/menu/_menu.scss +6 -0
- package/menu/harness.d.ts +5 -0
- package/menu/harness.js +22 -0
- package/menu/harness.js.map +1 -1
- package/menu/lib/_menu.scss +64 -62
- package/menu/lib/menu-styles.css.js +1 -1
- package/menu/lib/menu-styles.css.js.map +1 -1
- package/menu/lib/menu-styles.scss +2 -0
- package/menu/lib/menu.d.ts +177 -43
- package/menu/lib/menu.js +506 -246
- package/menu/lib/menu.js.map +1 -1
- package/menu/lib/menuitem/_menu-item.scss +123 -0
- package/menu/lib/menuitem/menu-item-private-styles.css.js +9 -0
- package/menu/lib/menuitem/menu-item-private-styles.css.js.map +1 -0
- package/menu/lib/menuitem/menu-item-private-styles.scss +10 -0
- package/menu/lib/menuitem/menu-item-styles.css.d.ts +1 -0
- package/menu/lib/menuitem/menu-item-styles.css.js +9 -0
- package/menu/lib/menuitem/menu-item-styles.css.js.map +1 -0
- package/menu/lib/menuitem/menu-item-styles.scss +10 -0
- package/menu/lib/menuitem/menu-item.d.ts +20 -3
- package/menu/lib/menuitem/menu-item.js +42 -3
- package/menu/lib/menuitem/menu-item.js.map +1 -1
- package/menu/lib/menuitemlink/menu-item-link.d.ts +25 -0
- package/menu/lib/menuitemlink/menu-item-link.js +51 -0
- package/menu/lib/menuitemlink/menu-item-link.js.map +1 -0
- package/menu/lib/shared.d.ts +134 -0
- package/menu/lib/shared.js +85 -0
- package/menu/lib/shared.js.map +1 -0
- package/menu/lib/submenuitem/harness.d.ts +11 -0
- package/menu/lib/submenuitem/harness.js +12 -0
- package/menu/lib/submenuitem/harness.js.map +1 -0
- package/menu/lib/submenuitem/sub-menu-item.d.ts +89 -0
- package/menu/lib/submenuitem/sub-menu-item.js +266 -0
- package/menu/lib/submenuitem/sub-menu-item.js.map +1 -0
- package/menu/lib/surfacePositionController.d.ts +117 -0
- package/menu/lib/surfacePositionController.js +196 -0
- package/menu/lib/surfacePositionController.js.map +1 -0
- package/menu/lib/typeaheadController.d.ts +144 -0
- package/menu/lib/typeaheadController.js +242 -0
- package/menu/lib/typeaheadController.js.map +1 -0
- package/menu/menu-item-link.d.ts +33 -0
- package/menu/menu-item-link.js +37 -0
- package/menu/menu-item-link.js.map +1 -0
- package/menu/menu-item.d.ts +19 -2
- package/menu/menu-item.js +22 -4
- package/menu/menu-item.js.map +1 -1
- package/menu/menu.d.ts +45 -0
- package/menu/menu.js +43 -0
- package/menu/menu.js.map +1 -1
- package/menu/sub-menu-item.d.ts +60 -0
- package/menu/sub-menu-item.js +64 -0
- package/menu/sub-menu-item.js.map +1 -0
- package/menusurface/lib/_md-comp-menu-surface.scss +4 -0
- package/menusurface/lib/_menu-surface.scss +5 -1
- package/menusurface/lib/foundation.js +31 -31
- package/menusurface/lib/foundation.js.map +1 -1
- package/menusurface/lib/menu-surface-styles.css.js +1 -1
- package/menusurface/lib/menu-surface-styles.css.js.map +1 -1
- package/menusurface/lib/menu-surface-styles.scss +2 -0
- package/menusurface/lib/menu-surface.d.ts +2 -2
- package/menusurface/lib/menu-surface.js.map +1 -1
- package/menusurface/menu-surface.js.map +1 -1
- package/motion/animation.d.ts +20 -3
- package/motion/animation.js +39 -4
- package/motion/animation.js.map +1 -1
- package/navigationbar/lib/_navigation-bar.scss +11 -9
- package/navigationbar/lib/constants.d.ts +1 -1
- package/navigationbar/lib/navigation-bar-styles.css.js +1 -1
- package/navigationbar/lib/navigation-bar-styles.css.js.map +1 -1
- package/navigationbar/lib/navigation-bar-styles.scss +2 -0
- package/navigationbar/lib/navigation-bar.js.map +1 -1
- package/navigationbar/navigation-bar.js.map +1 -1
- package/navigationdrawer/lib/_navigation-drawer-modal.scss +11 -2
- package/navigationdrawer/lib/_navigation-drawer.scss +11 -6
- package/navigationdrawer/lib/_shared.scss +4 -8
- package/navigationdrawer/lib/navigation-drawer-modal-styles.css.js +1 -1
- package/navigationdrawer/lib/navigation-drawer-modal-styles.css.js.map +1 -1
- package/navigationdrawer/lib/navigation-drawer-modal-styles.scss +2 -0
- package/navigationdrawer/lib/navigation-drawer-modal.js.map +1 -1
- package/navigationdrawer/lib/navigation-drawer-styles.css.js +1 -1
- package/navigationdrawer/lib/navigation-drawer-styles.css.js.map +1 -1
- package/navigationdrawer/lib/navigation-drawer-styles.scss +2 -0
- package/navigationdrawer/lib/navigation-drawer.js.map +1 -1
- package/navigationdrawer/lib/shared-styles.scss +2 -0
- package/navigationdrawer/navigation-drawer-modal.js.map +1 -1
- package/navigationdrawer/navigation-drawer.js.map +1 -1
- package/navigationtab/lib/_navigation-tab.scss +34 -41
- package/navigationtab/lib/navigation-tab-styles.css.js +1 -1
- package/navigationtab/lib/navigation-tab-styles.css.js.map +1 -1
- package/navigationtab/lib/navigation-tab-styles.scss +2 -0
- package/navigationtab/lib/navigation-tab.js +4 -4
- package/navigationtab/lib/navigation-tab.js.map +1 -1
- package/navigationtab/navigation-tab.js.map +1 -1
- package/package.json +2 -9
- package/radio/lib/_radio.scss +16 -15
- package/radio/lib/forced-colors-styles.scss +2 -0
- package/radio/lib/radio-styles.css.js +1 -1
- package/radio/lib/radio-styles.css.js.map +1 -1
- package/radio/lib/radio-styles.scss +2 -0
- package/radio/lib/radio.d.ts +10 -1
- package/radio/lib/radio.js +28 -19
- package/radio/lib/radio.js.map +1 -1
- package/radio/radio.d.ts +16 -1
- package/radio/radio.js +16 -1
- package/radio/radio.js.map +1 -1
- package/ripple/directive.d.ts +1 -33
- package/ripple/directive.js +7 -194
- package/ripple/directive.js.map +1 -1
- package/ripple/lib/_md-comp-ripple.scss +20 -19
- package/ripple/lib/_ripple.scss +24 -40
- package/ripple/lib/ripple-styles.css.js +1 -1
- package/ripple/lib/ripple-styles.css.js.map +1 -1
- package/ripple/lib/ripple-styles.scss +2 -0
- package/ripple/lib/ripple.d.ts +50 -48
- package/ripple/lib/ripple.js +215 -77
- package/ripple/lib/ripple.js.map +1 -1
- package/ripple/ripple.d.ts +9 -1
- package/ripple/ripple.js +9 -1
- package/ripple/ripple.js.map +1 -1
- package/sass/_assert.scss +2 -0
- package/sass/_color-scheme.scss +4 -0
- package/sass/_color.scss +4 -0
- package/sass/_elevation.scss +4 -0
- package/sass/_feature-flags.scss +2 -0
- package/sass/_map-ext.scss +26 -0
- package/sass/_resolvers.scss +4 -4
- package/sass/_shape.scss +75 -27
- package/sass/_string-ext.scss +67 -0
- package/sass/_theme.scss +4 -0
- package/sass/_typography.scss +18 -93
- package/sass/_var.scss +4 -0
- package/segmentedbutton/lib/_outlined-segmented-button.scss +4 -0
- package/segmentedbutton/lib/_shared.scss +18 -22
- package/segmentedbutton/lib/outlined-styles.css.js +1 -1
- package/segmentedbutton/lib/outlined-styles.css.js.map +1 -1
- package/segmentedbutton/lib/outlined-styles.scss +2 -0
- package/segmentedbutton/lib/segmented-button.js +4 -4
- package/segmentedbutton/lib/segmented-button.js.map +1 -1
- package/segmentedbutton/lib/shared-styles.css.js +1 -1
- package/segmentedbutton/lib/shared-styles.css.js.map +1 -1
- package/segmentedbutton/lib/shared-styles.scss +2 -0
- package/segmentedbutton/outlined-segmented-button.js.map +1 -1
- package/segmentedbuttonset/lib/_outlined-segmented-button-set.scss +9 -5
- package/segmentedbuttonset/lib/_shared.scss +0 -13
- package/segmentedbuttonset/lib/outlined-styles.css.js +1 -1
- package/segmentedbuttonset/lib/outlined-styles.css.js.map +1 -1
- package/segmentedbuttonset/lib/outlined-styles.scss +2 -0
- package/segmentedbuttonset/lib/segmented-button-set.d.ts +0 -2
- package/segmentedbuttonset/lib/segmented-button-set.js +0 -2
- package/segmentedbuttonset/lib/segmented-button-set.js.map +1 -1
- package/segmentedbuttonset/lib/shared-styles.scss +2 -0
- package/segmentedbuttonset/outlined-segmented-button-set.js.map +1 -1
- package/slider/_slider.scss +6 -0
- package/slider/harness.d.ts +20 -0
- package/slider/harness.js +63 -0
- package/slider/harness.js.map +1 -0
- package/slider/lib/_slider.scss +503 -0
- package/slider/lib/_tokens.scss +66 -0
- package/slider/lib/forced-colors-styles.css.d.ts +1 -0
- package/slider/lib/forced-colors-styles.css.js +9 -0
- package/slider/lib/forced-colors-styles.css.js.map +1 -0
- package/slider/lib/forced-colors-styles.scss +53 -0
- package/slider/lib/slider-styles.css.d.ts +1 -0
- package/slider/lib/slider-styles.css.js +9 -0
- package/slider/lib/slider-styles.css.js.map +1 -0
- package/slider/lib/slider-styles.scss +8 -0
- package/slider/lib/slider.d.ts +158 -0
- package/slider/lib/slider.js +575 -0
- package/slider/lib/slider.js.map +1 -0
- package/slider/slider.d.ts +28 -0
- package/slider/slider.js +32 -0
- package/slider/slider.js.map +1 -0
- package/switch/lib/README.md +55 -0
- package/switch/lib/_handle.scss +72 -26
- package/switch/lib/_icon.scss +40 -0
- package/switch/lib/_switch.scss +12 -133
- package/switch/lib/_track.scss +41 -0
- package/switch/lib/switch-styles.css.js +1 -1
- package/switch/lib/switch-styles.css.js.map +1 -1
- package/switch/lib/switch-styles.scss +2 -0
- package/switch/lib/switch.d.ts +3 -0
- package/switch/lib/switch.js +12 -9
- package/switch/lib/switch.js.map +1 -1
- package/switch/switch.js.map +1 -1
- package/textfield/filled-text-field.d.ts +1 -1
- package/textfield/filled-text-field.js +1 -2
- package/textfield/filled-text-field.js.map +1 -1
- package/textfield/harness.js +1 -1
- package/textfield/harness.js.map +1 -1
- package/textfield/lib/_filled-text-field.scss +29 -23
- package/textfield/lib/_icon.scss +41 -56
- package/textfield/lib/_input.scss +17 -36
- package/textfield/lib/_outlined-text-field.scss +29 -23
- package/textfield/lib/_shared.scss +10 -29
- package/textfield/lib/filled-forced-colors-styles.scss +2 -0
- package/textfield/lib/filled-styles.css.js +1 -1
- package/textfield/lib/filled-styles.css.js.map +1 -1
- package/textfield/lib/filled-styles.scss +2 -0
- package/textfield/lib/filled-text-field.d.ts +6 -5
- package/textfield/lib/filled-text-field.js +8 -7
- package/textfield/lib/filled-text-field.js.map +1 -1
- package/textfield/lib/outlined-forced-colors-styles.scss +2 -0
- package/textfield/lib/outlined-styles.css.js +1 -1
- package/textfield/lib/outlined-styles.css.js.map +1 -1
- package/textfield/lib/outlined-styles.scss +2 -0
- package/textfield/lib/outlined-text-field.d.ts +6 -5
- package/textfield/lib/outlined-text-field.js +8 -7
- package/textfield/lib/outlined-text-field.js.map +1 -1
- package/textfield/lib/shared-styles.css.js +1 -1
- package/textfield/lib/shared-styles.css.js.map +1 -1
- package/textfield/lib/shared-styles.scss +2 -0
- package/textfield/lib/text-field.d.ts +40 -90
- package/textfield/lib/text-field.js +194 -272
- package/textfield/lib/text-field.js.map +1 -1
- package/textfield/outlined-text-field.d.ts +1 -1
- package/textfield/outlined-text-field.js +1 -2
- package/textfield/outlined-text-field.js.map +1 -1
- package/tokens/_index.scss +1 -1
- package/tokens/{v0_150 → v0_160}/_index.scss +1 -1
- package/tokens/{v0_150 → v0_160}/_md-comp-assist-chip.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-badge.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-banner.scss +2 -43
- package/tokens/{v0_150 → v0_160}/_md-comp-bottom-app-bar.scss +3 -4
- package/tokens/{v0_150 → v0_160}/_md-comp-carousel-item.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-checkbox.scss +5 -26
- package/tokens/{v0_150 → v0_160}/_md-comp-circular-progress-indicator.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-data-table.scss +2 -6
- package/tokens/{v0_150 → v0_160}/_md-comp-date-input-modal.scss +11 -11
- package/tokens/{v0_150 → v0_160}/_md-comp-date-picker-docked.scss +24 -24
- package/tokens/{v0_150 → v0_160}/_md-comp-date-picker-modal.scss +35 -35
- package/tokens/{v0_150 → v0_160}/_md-comp-dialog.scss +2 -25
- package/tokens/{v0_150 → v0_160}/_md-comp-divider.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-elevated-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-elevated-card.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-extended-fab-branded.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-extended-fab-primary.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-extended-fab-secondary.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-extended-fab-surface.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-extended-fab-tertiary.scss +2 -4
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-branded-large.scss +2 -3
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-branded.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-primary-large.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-primary-small.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-primary.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-secondary-large.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-secondary-small.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-secondary.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-surface-large.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-surface-small.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-surface.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-tertiary-large.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-tertiary-small.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-fab-tertiary.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-autocomplete.scss +2 -3
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-button.scss +2 -8
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-card.scss +2 -4
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-icon-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-menu-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-select.scss +2 -6
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-text-field.scss +2 -3
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-tonal-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-filled-tonal-icon-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-filter-chip.scss +2 -30
- package/tokens/{v0_150 → v0_160}/_md-comp-full-screen-dialog.scss +3 -53
- package/tokens/{v0_150 → v0_160}/_md-comp-icon-button.scss +3 -3
- package/tokens/{v0_150 → v0_160}/_md-comp-input-chip.scss +2 -52
- package/tokens/{v0_150 → v0_160}/_md-comp-linear-progress-indicator.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-list.scss +3 -12
- package/tokens/{v0_150 → v0_160}/_md-comp-menu.scss +2 -4
- package/tokens/{v0_150 → v0_160}/_md-comp-navigation-bar.scss +2 -9
- package/tokens/{v0_150 → v0_160}/_md-comp-navigation-drawer.scss +2 -8
- package/tokens/{v0_150 → v0_160}/_md-comp-navigation-rail.scss +2 -39
- package/tokens/{v0_150 → v0_160}/_md-comp-outlined-autocomplete.scss +2 -3
- package/tokens/{v0_150 → v0_160}/_md-comp-outlined-button.scss +2 -6
- package/tokens/{v0_150 → v0_160}/_md-comp-outlined-card.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-outlined-icon-button.scss +2 -4
- package/tokens/{v0_150 → v0_160}/_md-comp-outlined-menu-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-outlined-segmented-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-outlined-select.scss +2 -6
- package/tokens/{v0_150 → v0_160}/_md-comp-outlined-text-field.scss +2 -3
- package/tokens/{v0_150 → v0_160}/_md-comp-plain-tooltip.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-primary-navigation-tab.scss +2 -4
- package/tokens/{v0_150 → v0_160}/_md-comp-radio-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-rich-tooltip.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-scrim.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-search-bar.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-search-view.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-secondary-navigation-tab.scss +2 -4
- package/tokens/{v0_150 → v0_160}/_md-comp-sheet-bottom.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-sheet-floating.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-sheet-side.scss +13 -11
- package/tokens/{v0_150 → v0_160}/_md-comp-slider.scss +2 -4
- package/tokens/{v0_150 → v0_160}/_md-comp-snackbar.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-standard-menu-button.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-suggestion-chip.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-switch.scss +2 -11
- package/tokens/{v0_150 → v0_160}/_md-comp-text-button.scss +2 -6
- package/tokens/{v0_150 → v0_160}/_md-comp-time-input.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-time-picker.scss +2 -5
- package/tokens/{v0_150 → v0_160}/_md-comp-top-app-bar-large.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-top-app-bar-medium.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-comp-top-app-bar-small-centered.scss +2 -3
- package/tokens/{v0_150 → v0_160}/_md-comp-top-app-bar-small.scss +2 -3
- package/tokens/{v0_150 → v0_160}/_md-ref-palette.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-ref-typeface.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-sys-color.scss +218 -20
- package/tokens/{v0_150 → v0_160}/_md-sys-elevation.scss +4 -13
- package/tokens/{v0_150 → v0_160}/_md-sys-motion.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-sys-shape.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-sys-state.scss +2 -2
- package/tokens/{v0_150 → v0_160}/_md-sys-typescale.scss +2 -3
- package/tokens/v0_160/index.test.css.d.ts +1 -0
- package/tokens/{v0_150 → v0_160}/index.test.scss +1 -1
- package/tokens/v0_160/lib.test.css.d.ts +1 -0
- package/tokens/{v0_150 → v0_160}/lib.test.scss +1 -1
- package/list/lib/_tokens.scss +0 -80
- package/list/lib/divider/_list-divider.scss +0 -46
- package/list/lib/divider/list-divider-styles.css.js +0 -9
- package/list/lib/divider/list-divider-styles.css.js.map +0 -1
- package/list/lib/divider/list-divider-styles.scss +0 -8
- package/list/lib/divider/list-divider.d.ts +0 -13
- package/list/lib/divider/list-divider.js +0 -32
- package/list/lib/divider/list-divider.js.map +0 -1
- package/list/list-divider.d.ts +0 -19
- package/list/list-divider.js +0 -22
- package/list/list-divider.js.map +0 -1
- package/menu/lib/_menu-button.scss +0 -14
- package/menu/lib/adapter.d.ts +0 -66
- package/menu/lib/adapter.js +0 -7
- package/menu/lib/adapter.js.map +0 -1
- package/menu/lib/constants.d.ts +0 -22
- package/menu/lib/constants.js +0 -23
- package/menu/lib/constants.js.map +0 -1
- package/menu/lib/foundation.d.ts +0 -49
- package/menu/lib/foundation.js +0 -123
- package/menu/lib/foundation.js.map +0 -1
- package/menu/lib/menu-button-styles.css.js +0 -9
- package/menu/lib/menu-button-styles.css.js.map +0 -1
- package/menu/lib/menu-button-styles.scss +0 -8
- package/menu/lib/menu-button.d.ts +0 -27
- package/menu/lib/menu-button.js +0 -93
- package/menu/lib/menu-button.js.map +0 -1
- package/menu/menu-button.d.ts +0 -14
- package/menu/menu-button.js +0 -17
- package/menu/menu-button.js.map +0 -1
- /package/{list/lib/divider/list-divider-styles.css.d.ts → dialog/lib/dialog-styles.css.d.ts} +0 -0
- /package/{menu/lib/menu-button-styles.css.d.ts → divider/lib/divider-styles.css.d.ts} +0 -0
- /package/{tokens/v0_150/index.test.css.d.ts → list/lib/listitem/list-item-private-styles.css.d.ts} +0 -0
- /package/{tokens/v0_150/lib.test.css.d.ts → menu/lib/menuitem/menu-item-private-styles.css.d.ts} +0 -0
- /package/tokens/{v0_150 → v0_160}/index.test.css.js +0 -0
- /package/tokens/{v0_150 → v0_160}/index.test.css.js.map +0 -0
- /package/tokens/{v0_150 → v0_160}/lib.test.css.js +0 -0
- /package/tokens/{v0_150 → v0_160}/lib.test.css.js.map +0 -0
|
@@ -1,15 +1,12 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @requirecss {textfield.lib.shared_styles}
|
|
3
|
-
*
|
|
4
2
|
* @license
|
|
5
3
|
* Copyright 2021 Google LLC
|
|
6
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
7
5
|
*/
|
|
8
6
|
import { __decorate, __metadata } from "tslib";
|
|
9
|
-
import { html, LitElement } from 'lit';
|
|
7
|
+
import { html, LitElement, nothing } from 'lit';
|
|
10
8
|
import { property, query, queryAssignedElements, state } from 'lit/decorators.js';
|
|
11
9
|
import { classMap } from 'lit/directives/class-map.js';
|
|
12
|
-
import { ifDefined } from 'lit/directives/if-defined.js';
|
|
13
10
|
import { live } from 'lit/directives/live.js';
|
|
14
11
|
import { styleMap } from 'lit/directives/style-map.js';
|
|
15
12
|
import { html as staticHtml } from 'lit/static-html.js';
|
|
@@ -17,8 +14,94 @@ import { redispatchEvent } from '../../controller/events.js';
|
|
|
17
14
|
import { FormController, getFormValue } from '../../controller/form-controller.js';
|
|
18
15
|
import { stringConverter } from '../../controller/string-converter.js';
|
|
19
16
|
import { ariaProperty } from '../../decorators/aria-property.js';
|
|
20
|
-
/**
|
|
17
|
+
/**
|
|
18
|
+
* A text field component.
|
|
19
|
+
*/
|
|
21
20
|
export class TextField extends LitElement {
|
|
21
|
+
// FormElement
|
|
22
|
+
get form() {
|
|
23
|
+
return this.closest('form');
|
|
24
|
+
}
|
|
25
|
+
[getFormValue]() {
|
|
26
|
+
return this.value;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Gets or sets the direction in which selection occurred.
|
|
30
|
+
*/
|
|
31
|
+
get selectionDirection() {
|
|
32
|
+
return this.getInput().selectionDirection;
|
|
33
|
+
}
|
|
34
|
+
set selectionDirection(value) {
|
|
35
|
+
this.getInput().selectionDirection = value;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Gets or sets the end position or offset of a text selection.
|
|
39
|
+
*/
|
|
40
|
+
get selectionEnd() {
|
|
41
|
+
return this.getInput().selectionEnd;
|
|
42
|
+
}
|
|
43
|
+
set selectionEnd(value) {
|
|
44
|
+
this.getInput().selectionEnd = value;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Gets or sets the starting position or offset of a text selection.
|
|
48
|
+
*/
|
|
49
|
+
get selectionStart() {
|
|
50
|
+
return this.getInput().selectionStart;
|
|
51
|
+
}
|
|
52
|
+
set selectionStart(value) {
|
|
53
|
+
this.getInput().selectionStart = value;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Returns the native validation error message that would be displayed upon
|
|
57
|
+
* calling `reportValidity()`.
|
|
58
|
+
*
|
|
59
|
+
* https://developer.mozilla.org/en-US/docs/Web/API/HTMLObjectElement/validationMessage
|
|
60
|
+
*/
|
|
61
|
+
get validationMessage() {
|
|
62
|
+
return this.getInput().validationMessage;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Returns a ValidityState object that represents the validity states of the
|
|
66
|
+
* text field.
|
|
67
|
+
*
|
|
68
|
+
* https://developer.mozilla.org/en-US/docs/Web/API/HTMLObjectElement/validity
|
|
69
|
+
*/
|
|
70
|
+
get validity() {
|
|
71
|
+
return this.getInput().validity;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* The text field's value as a number.
|
|
75
|
+
*/
|
|
76
|
+
get valueAsNumber() {
|
|
77
|
+
return this.getInput().valueAsNumber;
|
|
78
|
+
}
|
|
79
|
+
set valueAsNumber(value) {
|
|
80
|
+
this.getInput().valueAsNumber = value;
|
|
81
|
+
this.value = this.getInput().value;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* The text field's value as a Date.
|
|
85
|
+
*/
|
|
86
|
+
get valueAsDate() {
|
|
87
|
+
return this.getInput().valueAsDate;
|
|
88
|
+
}
|
|
89
|
+
set valueAsDate(value) {
|
|
90
|
+
this.getInput().valueAsDate = value;
|
|
91
|
+
this.value = this.getInput().value;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Returns whether an element will successfully validate based on forms
|
|
95
|
+
* validation rules and constraints.
|
|
96
|
+
*
|
|
97
|
+
* https://developer.mozilla.org/en-US/docs/Web/API/HTMLObjectElement/willValidate
|
|
98
|
+
*/
|
|
99
|
+
get willValidate() {
|
|
100
|
+
return this.getInput().willValidate;
|
|
101
|
+
}
|
|
102
|
+
get hasError() {
|
|
103
|
+
return this.error || this.nativeError;
|
|
104
|
+
}
|
|
22
105
|
constructor() {
|
|
23
106
|
super();
|
|
24
107
|
this.disabled = false;
|
|
@@ -79,13 +162,10 @@ export class TextField extends LitElement {
|
|
|
79
162
|
*/
|
|
80
163
|
this.textDirection = '';
|
|
81
164
|
// ARIA
|
|
82
|
-
// TODO(b/210730484): replace with @soyParam annotation
|
|
83
165
|
this.ariaAutoComplete = null;
|
|
84
166
|
this.ariaControls = null;
|
|
85
167
|
this.ariaActiveDescendant = null;
|
|
86
168
|
this.ariaExpanded = null;
|
|
87
|
-
// tslint:disable:decorator-placement
|
|
88
|
-
// @ts-ignore(b/264292293): Use `override` with TS 4.9+
|
|
89
169
|
this.role = null;
|
|
90
170
|
this.name = '';
|
|
91
171
|
// <input> properties
|
|
@@ -137,7 +217,6 @@ export class TextField extends LitElement {
|
|
|
137
217
|
* https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#step
|
|
138
218
|
*/
|
|
139
219
|
this.step = '';
|
|
140
|
-
// TODO(b/237284412): replace with exported types
|
|
141
220
|
this.type = 'text';
|
|
142
221
|
/**
|
|
143
222
|
* Returns true when the text field has been interacted with. Native
|
|
@@ -173,98 +252,11 @@ export class TextField extends LitElement {
|
|
|
173
252
|
* `reportValidity()`.
|
|
174
253
|
*/
|
|
175
254
|
this.nativeErrorText = '';
|
|
176
|
-
/** @soyUniqueAttribute */
|
|
177
|
-
this.counterId = 'counter';
|
|
178
|
-
/** @soyUniqueAttribute */
|
|
179
|
-
this.supportingTextId = 'support';
|
|
180
255
|
this.addController(new FormController(this));
|
|
181
|
-
|
|
182
|
-
this.addEventListener('click', this.handleClick);
|
|
256
|
+
this.addEventListener('click', this.focus);
|
|
183
257
|
this.addEventListener('focusin', this.handleFocusin);
|
|
184
258
|
this.addEventListener('focusout', this.handleFocusout);
|
|
185
259
|
}
|
|
186
|
-
// tslint:enable:decorator-placement
|
|
187
|
-
// FormElement
|
|
188
|
-
get form() {
|
|
189
|
-
return this.closest('form');
|
|
190
|
-
}
|
|
191
|
-
[getFormValue]() {
|
|
192
|
-
return this.value;
|
|
193
|
-
}
|
|
194
|
-
/**
|
|
195
|
-
* Gets or sets the direction in which selection occurred.
|
|
196
|
-
*/
|
|
197
|
-
get selectionDirection() {
|
|
198
|
-
return this.getInput().selectionDirection;
|
|
199
|
-
}
|
|
200
|
-
set selectionDirection(value) {
|
|
201
|
-
this.getInput().selectionDirection = value;
|
|
202
|
-
}
|
|
203
|
-
/**
|
|
204
|
-
* Gets or sets the end position or offset of a text selection.
|
|
205
|
-
*/
|
|
206
|
-
get selectionEnd() {
|
|
207
|
-
return this.getInput().selectionEnd;
|
|
208
|
-
}
|
|
209
|
-
set selectionEnd(value) {
|
|
210
|
-
this.getInput().selectionEnd = value;
|
|
211
|
-
}
|
|
212
|
-
/**
|
|
213
|
-
* Gets or sets the starting position or offset of a text selection.
|
|
214
|
-
*/
|
|
215
|
-
get selectionStart() {
|
|
216
|
-
return this.getInput().selectionStart;
|
|
217
|
-
}
|
|
218
|
-
set selectionStart(value) {
|
|
219
|
-
this.getInput().selectionStart = value;
|
|
220
|
-
}
|
|
221
|
-
/**
|
|
222
|
-
* Returns the native validation error message that would be displayed upon
|
|
223
|
-
* calling `reportValidity()`.
|
|
224
|
-
*
|
|
225
|
-
* https://developer.mozilla.org/en-US/docs/Web/API/HTMLObjectElement/validationMessage
|
|
226
|
-
*/
|
|
227
|
-
get validationMessage() {
|
|
228
|
-
return this.getInput().validationMessage;
|
|
229
|
-
}
|
|
230
|
-
/**
|
|
231
|
-
* Returns a ValidityState object that represents the validity states of the
|
|
232
|
-
* text field.
|
|
233
|
-
*
|
|
234
|
-
* https://developer.mozilla.org/en-US/docs/Web/API/HTMLObjectElement/validity
|
|
235
|
-
*/
|
|
236
|
-
get validity() {
|
|
237
|
-
return this.getInput().validity;
|
|
238
|
-
}
|
|
239
|
-
/**
|
|
240
|
-
* The text field's value as a number.
|
|
241
|
-
*/
|
|
242
|
-
get valueAsNumber() {
|
|
243
|
-
return this.getInput().valueAsNumber;
|
|
244
|
-
}
|
|
245
|
-
set valueAsNumber(value) {
|
|
246
|
-
this.getInput().valueAsNumber = value;
|
|
247
|
-
this.value = this.getInput().value;
|
|
248
|
-
}
|
|
249
|
-
/**
|
|
250
|
-
* The text field's value as a Date.
|
|
251
|
-
*/
|
|
252
|
-
get valueAsDate() {
|
|
253
|
-
return this.getInput().valueAsDate;
|
|
254
|
-
}
|
|
255
|
-
set valueAsDate(value) {
|
|
256
|
-
this.getInput().valueAsDate = value;
|
|
257
|
-
this.value = this.getInput().value;
|
|
258
|
-
}
|
|
259
|
-
/**
|
|
260
|
-
* Returns whether an element will successfully validate based on forms
|
|
261
|
-
* validation rules and constraints.
|
|
262
|
-
*
|
|
263
|
-
* https://developer.mozilla.org/en-US/docs/Web/API/HTMLObjectElement/willValidate
|
|
264
|
-
*/
|
|
265
|
-
get willValidate() {
|
|
266
|
-
return this.getInput().willValidate;
|
|
267
|
-
}
|
|
268
260
|
/**
|
|
269
261
|
* Checks the text field's native validation and returns whether or not the
|
|
270
262
|
* element is valid.
|
|
@@ -288,15 +280,7 @@ export class TextField extends LitElement {
|
|
|
288
280
|
// button, to the input when focus is requested.
|
|
289
281
|
return;
|
|
290
282
|
}
|
|
291
|
-
|
|
292
|
-
// delegating focus
|
|
293
|
-
this.getInput().focus();
|
|
294
|
-
}
|
|
295
|
-
/**
|
|
296
|
-
* Unfocuses the text field.
|
|
297
|
-
*/
|
|
298
|
-
blur() {
|
|
299
|
-
this.getInput().blur();
|
|
283
|
+
super.focus();
|
|
300
284
|
}
|
|
301
285
|
/**
|
|
302
286
|
* Checks the text field's native validation and returns whether or not the
|
|
@@ -406,40 +390,65 @@ export class TextField extends LitElement {
|
|
|
406
390
|
this.nativeError = false;
|
|
407
391
|
this.nativeErrorText = '';
|
|
408
392
|
}
|
|
409
|
-
|
|
393
|
+
update(changedProperties) {
|
|
394
|
+
// Consider a value change anything that is not the initial empty string
|
|
395
|
+
// value.
|
|
396
|
+
const valueHasChanged = changedProperties.has('value') &&
|
|
397
|
+
changedProperties.get('value') !== undefined;
|
|
398
|
+
if (valueHasChanged && !this.ignoreNextValueChange) {
|
|
399
|
+
this.valueHasChanged = true;
|
|
400
|
+
}
|
|
401
|
+
if (this.ignoreNextValueChange) {
|
|
402
|
+
this.ignoreNextValueChange = false;
|
|
403
|
+
}
|
|
404
|
+
super.update(changedProperties);
|
|
405
|
+
}
|
|
410
406
|
render() {
|
|
407
|
+
const classes = {
|
|
408
|
+
'disabled': this.disabled,
|
|
409
|
+
'error': !this.disabled && this.hasError,
|
|
410
|
+
};
|
|
411
411
|
return html `
|
|
412
|
-
<span class="
|
|
412
|
+
<span class="text-field ${classMap(classes)}">
|
|
413
413
|
${this.renderField()}
|
|
414
414
|
</span>
|
|
415
415
|
`;
|
|
416
416
|
}
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
417
|
+
updated(changedProperties) {
|
|
418
|
+
// Keep changedProperties arg so that subclasses may call it
|
|
419
|
+
// If a property such as `type` changes and causes the internal <input>
|
|
420
|
+
// value to change without dispatching an event, re-sync it.
|
|
421
|
+
const value = this.getInput().value;
|
|
422
|
+
if (this.value !== value) {
|
|
423
|
+
// Don't consider these updates (such as setting `defaultValue`) as
|
|
424
|
+
// the developer directly changing the `value`.
|
|
425
|
+
this.ignoreNextValueChange = true;
|
|
426
|
+
// Note this is typically inefficient in updated() since it schedules
|
|
427
|
+
// another update. However, it is needed for the <input> to fully render
|
|
428
|
+
// before checking its value.
|
|
429
|
+
this.value = value;
|
|
430
|
+
}
|
|
431
|
+
if (this.refreshErrorAlert) {
|
|
432
|
+
// The past render cycle removed the role="alert" from the error message.
|
|
433
|
+
// Re-add it after an animation frame to re-announce the error.
|
|
434
|
+
requestAnimationFrame(() => {
|
|
435
|
+
this.refreshErrorAlert = false;
|
|
436
|
+
});
|
|
437
|
+
}
|
|
427
438
|
}
|
|
428
|
-
/** @soyTemplate */
|
|
429
439
|
renderField() {
|
|
430
440
|
const prefix = this.renderPrefix();
|
|
431
441
|
const suffix = this.renderSuffix();
|
|
432
442
|
const input = this.renderInput();
|
|
433
|
-
const inputValue = this.getInputValue();
|
|
434
443
|
return staticHtml `<${this.fieldTag}
|
|
435
|
-
class="
|
|
444
|
+
class="field"
|
|
436
445
|
?disabled=${this.disabled}
|
|
437
|
-
?error=${this.
|
|
446
|
+
?error=${this.hasError}
|
|
438
447
|
?focused=${this.focused}
|
|
439
448
|
?hasEnd=${this.hasTrailingIcon}
|
|
440
449
|
?hasStart=${this.hasLeadingIcon}
|
|
441
450
|
.label=${this.label}
|
|
442
|
-
?populated=${!!
|
|
451
|
+
?populated=${!!this.getInputValue()}
|
|
443
452
|
?required=${this.required}
|
|
444
453
|
>
|
|
445
454
|
${this.renderLeadingIcon()}
|
|
@@ -449,74 +458,44 @@ export class TextField extends LitElement {
|
|
|
449
458
|
${this.renderCounter()}
|
|
450
459
|
</${this.fieldTag}>`;
|
|
451
460
|
}
|
|
452
|
-
/**
|
|
453
|
-
* @soyTemplate
|
|
454
|
-
* @slotName start
|
|
455
|
-
*/
|
|
456
461
|
renderLeadingIcon() {
|
|
457
462
|
return html `
|
|
458
|
-
<span class="
|
|
459
|
-
slot="start">
|
|
463
|
+
<span class="icon leading" slot="start">
|
|
460
464
|
<slot name="leadingicon" @slotchange=${this.handleIconChange}></slot>
|
|
461
465
|
</span>
|
|
462
466
|
`;
|
|
463
467
|
}
|
|
464
|
-
/**
|
|
465
|
-
* @soyTemplate
|
|
466
|
-
* @slotName end
|
|
467
|
-
*/
|
|
468
468
|
renderTrailingIcon() {
|
|
469
469
|
return html `
|
|
470
|
-
<span class="
|
|
471
|
-
slot="end">
|
|
470
|
+
<span class="icon trailing" slot="end">
|
|
472
471
|
<slot name="trailingicon" @slotchange=${this.handleIconChange}></slot>
|
|
473
472
|
</span>
|
|
474
473
|
`;
|
|
475
474
|
}
|
|
476
|
-
/** @soyTemplate */
|
|
477
475
|
renderInput() {
|
|
478
|
-
// TODO(b/237283903): remove when custom isTruthy directive is supported
|
|
479
|
-
const placeholderValue = this.placeholder || undefined;
|
|
480
|
-
const ariaActiveDescendantValue = this.ariaActiveDescendant || undefined;
|
|
481
|
-
const ariaAutoCompleteValue = this.ariaAutoComplete || undefined;
|
|
482
|
-
const ariaControlsValue = this.ariaControls || undefined;
|
|
483
|
-
const ariaDescribedByValue = this.getAriaDescribedBy() || undefined;
|
|
484
|
-
const ariaExpandedValue = this.ariaExpanded || undefined;
|
|
485
|
-
const ariaLabelValue = this.ariaLabel || this.label || undefined;
|
|
486
|
-
const ariaLabelledByValue = this.ariaLabelledBy || undefined;
|
|
487
|
-
const maxValue = this.max || undefined;
|
|
488
|
-
const maxLengthValue = this.maxLength > -1 ? this.maxLength : undefined;
|
|
489
|
-
const minValue = this.min || undefined;
|
|
490
|
-
const minLengthValue = this.minLength > -1 ? this.minLength : undefined;
|
|
491
|
-
const patternValue = this.pattern || undefined;
|
|
492
|
-
const roleValue = this.role || undefined;
|
|
493
|
-
const stepValue = this.step || undefined;
|
|
494
|
-
/** @styleMap */
|
|
495
476
|
const style = { direction: this.textDirection };
|
|
496
477
|
// TODO(b/243805848): remove `as unknown as number` once lit analyzer is
|
|
497
478
|
// fixed
|
|
498
479
|
return html `<input
|
|
499
|
-
class="md3-text-field__input"
|
|
500
480
|
style=${styleMap(style)}
|
|
501
|
-
aria-activedescendant=${
|
|
502
|
-
aria-autocomplete=${
|
|
503
|
-
aria-controls=${
|
|
504
|
-
aria-describedby=${
|
|
505
|
-
aria-expanded=${
|
|
506
|
-
aria-invalid=${this.
|
|
507
|
-
aria-label=${
|
|
508
|
-
aria-labelledby=${ifDefined(ariaLabelledByValue)}
|
|
481
|
+
aria-activedescendant=${this.ariaActiveDescendant || nothing}
|
|
482
|
+
aria-autocomplete=${this.ariaAutoComplete || nothing}
|
|
483
|
+
aria-controls=${this.ariaControls || nothing}
|
|
484
|
+
aria-describedby=${this.getAriaDescribedBy() || nothing}
|
|
485
|
+
aria-expanded=${this.ariaExpanded || nothing}
|
|
486
|
+
aria-invalid=${this.hasError}
|
|
487
|
+
aria-label=${this.ariaLabel || this.label || nothing}
|
|
509
488
|
?disabled=${this.disabled}
|
|
510
|
-
max=${
|
|
511
|
-
maxlength=${
|
|
512
|
-
min=${
|
|
513
|
-
minlength=${
|
|
514
|
-
pattern=${
|
|
515
|
-
placeholder=${
|
|
516
|
-
role=${
|
|
489
|
+
max=${(this.max || nothing)}
|
|
490
|
+
maxlength=${this.maxLength > -1 ? this.maxLength : nothing}
|
|
491
|
+
min=${(this.min || nothing)}
|
|
492
|
+
minlength=${this.minLength > -1 ? this.minLength : nothing}
|
|
493
|
+
pattern=${this.pattern || nothing}
|
|
494
|
+
placeholder=${this.placeholder || nothing}
|
|
495
|
+
role=${this.role || nothing}
|
|
517
496
|
?readonly=${this.readOnly}
|
|
518
497
|
?required=${this.required}
|
|
519
|
-
step=${
|
|
498
|
+
step=${(this.step || nothing)}
|
|
520
499
|
type=${this.type}
|
|
521
500
|
.value=${live(this.getInputValue())}
|
|
522
501
|
@change=${this.redispatchEvent}
|
|
@@ -524,131 +503,80 @@ export class TextField extends LitElement {
|
|
|
524
503
|
@select=${this.redispatchEvent}
|
|
525
504
|
>`;
|
|
526
505
|
}
|
|
527
|
-
/** @soyTemplate */
|
|
528
506
|
getInputValue() {
|
|
529
507
|
const alwaysShowValue = this.dirty || this.valueHasChanged;
|
|
530
|
-
|
|
508
|
+
if (alwaysShowValue) {
|
|
509
|
+
return this.value;
|
|
510
|
+
}
|
|
511
|
+
return this.defaultValue || this.value;
|
|
531
512
|
}
|
|
532
|
-
/** @soyTemplate */
|
|
533
513
|
getAriaDescribedBy() {
|
|
534
|
-
const
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
'';
|
|
514
|
+
const ids = [];
|
|
515
|
+
if (this.getSupportingText()) {
|
|
516
|
+
ids.push('support');
|
|
517
|
+
}
|
|
518
|
+
if (this.getCounterText()) {
|
|
519
|
+
ids.push('counter');
|
|
520
|
+
}
|
|
521
|
+
return ids.join(' ');
|
|
540
522
|
}
|
|
541
|
-
/** @soyTemplate */
|
|
542
523
|
renderPrefix() {
|
|
543
|
-
return this.prefixText
|
|
544
|
-
html `<span class="md3-text-field__prefix">${this.prefixText}</span>` :
|
|
545
|
-
html ``;
|
|
546
|
-
// TODO(b/217441842): Create shared function once argument bug is fixed
|
|
547
|
-
// return this.renderAffix(/* isSuffix */ false);
|
|
524
|
+
return this.renderAffix(this.prefixText, /* isSuffix */ false);
|
|
548
525
|
}
|
|
549
|
-
/** @soyTemplate */
|
|
550
526
|
renderSuffix() {
|
|
551
|
-
return this.suffixText
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
527
|
+
return this.renderAffix(this.suffixText, /* isSuffix */ true);
|
|
528
|
+
}
|
|
529
|
+
renderAffix(text, isSuffix) {
|
|
530
|
+
if (!text) {
|
|
531
|
+
return nothing;
|
|
532
|
+
}
|
|
533
|
+
const classes = {
|
|
534
|
+
'suffix': isSuffix,
|
|
535
|
+
'prefix': !isSuffix,
|
|
536
|
+
};
|
|
537
|
+
return html `<span class="${classMap(classes)}">${text}</span>`;
|
|
556
538
|
}
|
|
557
|
-
/**
|
|
558
|
-
* @soyTemplate
|
|
559
|
-
* @slotName supporting-text
|
|
560
|
-
*/
|
|
561
539
|
renderSupportingText() {
|
|
562
|
-
const shouldAlert = this.shouldErrorAnnounce();
|
|
563
540
|
const text = this.getSupportingText();
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
return
|
|
541
|
+
if (!text) {
|
|
542
|
+
return nothing;
|
|
543
|
+
}
|
|
544
|
+
return html `<span id="support"
|
|
545
|
+
slot="supporting-text"
|
|
546
|
+
role=${this.shouldErrorAnnounce() ? 'alert' : nothing}>${text}</span>`;
|
|
568
547
|
}
|
|
569
|
-
/** @soyTemplate */
|
|
570
548
|
getSupportingText() {
|
|
571
549
|
const errorText = this.getErrorText();
|
|
572
|
-
return this.
|
|
550
|
+
return this.hasError && errorText ? errorText : this.supportingText;
|
|
573
551
|
}
|
|
574
|
-
/** @soyTemplate */
|
|
575
552
|
getErrorText() {
|
|
576
553
|
return this.error ? this.errorText : this.nativeErrorText;
|
|
577
554
|
}
|
|
578
|
-
/** @soyTemplate */
|
|
579
555
|
shouldErrorAnnounce() {
|
|
580
556
|
// Announce if there is an error and error text visible.
|
|
581
557
|
// If refreshErrorAlert is true, do not announce. This will remove the
|
|
582
558
|
// role="alert" attribute. Another render cycle will happen after an
|
|
583
559
|
// animation frame to re-add the role.
|
|
584
|
-
return this.
|
|
560
|
+
return this.hasError && !!this.getErrorText() && !this.refreshErrorAlert;
|
|
585
561
|
}
|
|
586
|
-
/**
|
|
587
|
-
* @soyTemplate
|
|
588
|
-
* @slotName supporting-text-end
|
|
589
|
-
*/
|
|
590
562
|
renderCounter() {
|
|
591
|
-
const
|
|
592
|
-
|
|
593
|
-
|
|
563
|
+
const text = this.getCounterText();
|
|
564
|
+
if (!text) {
|
|
565
|
+
return nothing;
|
|
566
|
+
}
|
|
594
567
|
// TODO(b/244473435): add aria-label and announcements
|
|
595
|
-
return
|
|
568
|
+
return html `<span id="counter"
|
|
569
|
+
class="counter"
|
|
570
|
+
slot="supporting-text-end">${text}</span>`;
|
|
596
571
|
}
|
|
597
|
-
// TODO(b/244197198): replace with !!this.getCounterText()
|
|
598
|
-
/** @soyTemplate */
|
|
599
|
-
hasCounter() {
|
|
600
|
-
return this.maxLength > -1;
|
|
601
|
-
}
|
|
602
|
-
/** @soyTemplate */
|
|
603
572
|
getCounterText() {
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
return this.hasCounter() ? html `${length} / ${this.maxLength}` : html ``;
|
|
607
|
-
}
|
|
608
|
-
update(changedProperties) {
|
|
609
|
-
// Consider a value change anything that is not the initial empty string
|
|
610
|
-
// value.
|
|
611
|
-
const valueHasChanged = changedProperties.has('value') &&
|
|
612
|
-
changedProperties.get('value') !== undefined;
|
|
613
|
-
if (valueHasChanged && !this.ignoreNextValueChange) {
|
|
614
|
-
this.valueHasChanged = true;
|
|
615
|
-
}
|
|
616
|
-
if (this.ignoreNextValueChange) {
|
|
617
|
-
this.ignoreNextValueChange = false;
|
|
618
|
-
}
|
|
619
|
-
super.update(changedProperties);
|
|
620
|
-
}
|
|
621
|
-
updated(changedProperties) {
|
|
622
|
-
// If a property such as `type` changes and causes the internal <input>
|
|
623
|
-
// value to change without dispatching an event, re-sync it.
|
|
624
|
-
const value = this.getInput().value;
|
|
625
|
-
if (this.value !== value) {
|
|
626
|
-
// Don't consider these updates (such as setting `defaultValue`) as
|
|
627
|
-
// the developer directly changing the `value`.
|
|
628
|
-
this.ignoreNextValueChange = true;
|
|
629
|
-
// Note this is typically inefficient in updated() since it schedules
|
|
630
|
-
// another update. However, it is needed for the <input> to fully render
|
|
631
|
-
// before checking its value.
|
|
632
|
-
this.value = value;
|
|
633
|
-
}
|
|
634
|
-
if (this.refreshErrorAlert) {
|
|
635
|
-
// The past render cycle removed the role="alert" from the error message.
|
|
636
|
-
// Re-add it after an animation frame to re-announce the error.
|
|
637
|
-
requestAnimationFrame(() => {
|
|
638
|
-
this.refreshErrorAlert = false;
|
|
639
|
-
});
|
|
640
|
-
}
|
|
641
|
-
}
|
|
642
|
-
/** @bubbleWizEvent */
|
|
643
|
-
handleClick() {
|
|
644
|
-
this.focus();
|
|
573
|
+
return this.maxLength > -1 ? `${this.value.length} / ${this.maxLength}` :
|
|
574
|
+
'';
|
|
645
575
|
}
|
|
646
|
-
|
|
647
|
-
handleFocusin(event) {
|
|
576
|
+
handleFocusin() {
|
|
648
577
|
this.focused = true;
|
|
649
578
|
}
|
|
650
|
-
|
|
651
|
-
handleFocusout(event) {
|
|
579
|
+
handleFocusout() {
|
|
652
580
|
if (this.matches(':focus-within')) {
|
|
653
581
|
// Changing focus to another child within the text field, like a button
|
|
654
582
|
return;
|
|
@@ -694,7 +622,7 @@ export class TextField extends LitElement {
|
|
|
694
622
|
this.hasTrailingIcon = this.trailingIcons.length > 0;
|
|
695
623
|
}
|
|
696
624
|
}
|
|
697
|
-
TextField.shadowRootOptions = {
|
|
625
|
+
TextField.shadowRootOptions = { ...LitElement.shadowRootOptions, delegatesFocus: true };
|
|
698
626
|
__decorate([
|
|
699
627
|
property({ type: Boolean, reflect: true }),
|
|
700
628
|
__metadata("design:type", Object)
|
|
@@ -777,12 +705,6 @@ __decorate([
|
|
|
777
705
|
,
|
|
778
706
|
__metadata("design:type", String)
|
|
779
707
|
], TextField.prototype, "ariaLabel", void 0);
|
|
780
|
-
__decorate([
|
|
781
|
-
property({ type: String, attribute: 'data-aria-labelledby', noAccessor: true }),
|
|
782
|
-
ariaProperty // tslint:disable-line:no-new-decorators
|
|
783
|
-
,
|
|
784
|
-
__metadata("design:type", String)
|
|
785
|
-
], TextField.prototype, "ariaLabelledBy", void 0);
|
|
786
708
|
__decorate([
|
|
787
709
|
property({ type: String, attribute: 'data-role', noAccessor: true }),
|
|
788
710
|
ariaProperty // tslint:disable-line:no-new-decorators
|
|
@@ -854,7 +776,7 @@ __decorate([
|
|
|
854
776
|
__metadata("design:type", Object)
|
|
855
777
|
], TextField.prototype, "nativeErrorText", void 0);
|
|
856
778
|
__decorate([
|
|
857
|
-
query('
|
|
779
|
+
query('input'),
|
|
858
780
|
__metadata("design:type", HTMLInputElement)
|
|
859
781
|
], TextField.prototype, "input", void 0);
|
|
860
782
|
__decorate([
|