mtrl 0.3.7 → 0.3.9
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/dist/LICENSE +21 -0
- package/dist/README.md +324 -0
- package/dist/components/badge/api.d.ts +48 -0
- package/{src/components/badge/badge.ts → dist/components/badge/badge.d.ts} +14 -57
- package/dist/components/badge/config.d.ts +79 -0
- package/dist/components/badge/constants.d.ts +35 -0
- package/dist/components/badge/features.d.ts +36 -0
- package/dist/components/badge/index.d.ts +8 -0
- package/dist/components/badge/types.d.ts +256 -0
- package/dist/components/bottom-app-bar/bottom-app-bar.d.ts +12 -0
- package/dist/components/bottom-app-bar/config.d.ts +16 -0
- package/dist/components/bottom-app-bar/constants.d.ts +22 -0
- package/{src/components/bottom-app-bar/index.ts → dist/components/bottom-app-bar/index.d.ts} +0 -9
- package/dist/components/bottom-app-bar/types.d.ts +96 -0
- package/dist/components/button/api.d.ts +47 -0
- package/dist/components/button/button.d.ts +25 -0
- package/dist/components/button/config.d.ts +59 -0
- package/dist/components/button/constants.d.ts +43 -0
- package/dist/components/button/index.d.ts +6 -0
- package/dist/components/button/types.d.ts +265 -0
- package/dist/components/card/api.d.ts +11 -0
- package/{src/components/card/card.ts → dist/components/card/card.d.ts} +10 -58
- package/dist/components/card/config.d.ts +105 -0
- package/dist/components/card/constants.d.ts +85 -0
- package/dist/components/card/content.d.ts +92 -0
- package/dist/components/card/features.d.ts +131 -0
- package/{src/components/card/index.ts → dist/components/card/index.d.ts} +13 -74
- package/dist/components/card/types.d.ts +471 -0
- package/dist/components/carousel/api.d.ts +33 -0
- package/dist/components/carousel/carousel.d.ts +75 -0
- package/dist/components/carousel/config.d.ts +45 -0
- package/dist/components/carousel/constants.d.ts +165 -0
- package/dist/components/carousel/features/drag.d.ts +8 -0
- package/{src/components/carousel/features/index.ts → dist/components/carousel/features/index.d.ts} +1 -4
- package/dist/components/carousel/features/slides.d.ts +8 -0
- package/{src/components/carousel/index.ts → dist/components/carousel/index.d.ts} +10 -29
- package/dist/components/carousel/types.d.ts +276 -0
- package/dist/components/checkbox/api.d.ts +7 -0
- package/dist/components/checkbox/checkbox.d.ts +65 -0
- package/dist/components/checkbox/config.d.ts +44 -0
- package/dist/components/checkbox/constants.d.ts +63 -0
- package/{src/components/checkbox/index.ts → dist/components/checkbox/index.d.ts} +8 -25
- package/dist/components/checkbox/types.d.ts +242 -0
- package/dist/components/chips/api.d.ts +49 -0
- package/dist/components/chips/chip/api.d.ts +23 -0
- package/dist/components/chips/chip/chip.d.ts +8 -0
- package/dist/components/chips/chip/config.d.ts +57 -0
- package/dist/components/chips/chip/constants.d.ts +38 -0
- package/dist/components/chips/chip/index.d.ts +2 -0
- package/dist/components/chips/chip/types.d.ts +11 -0
- package/dist/components/chips/chips.d.ts +17 -0
- package/dist/components/chips/config.d.ts +67 -0
- package/dist/components/chips/constants.d.ts +46 -0
- package/dist/components/chips/features/chip-items.d.ts +8 -0
- package/dist/components/chips/features/container.d.ts +8 -0
- package/dist/components/chips/features/controller.d.ts +9 -0
- package/{src/components/chips/features/index.ts → dist/components/chips/features/index.d.ts} +1 -2
- package/dist/components/chips/features/label.d.ts +8 -0
- package/dist/components/chips/index.d.ts +4 -0
- package/dist/components/chips/schema.d.ts +34 -0
- package/dist/components/chips/types.d.ts +398 -0
- package/dist/components/datepicker/api.d.ts +9 -0
- package/dist/components/datepicker/config.d.ts +79 -0
- package/dist/components/datepicker/constants.d.ts +97 -0
- package/dist/components/datepicker/datepicker.d.ts +8 -0
- package/dist/components/datepicker/index.d.ts +3 -0
- package/dist/components/datepicker/render.d.ts +43 -0
- package/dist/components/datepicker/types.d.ts +321 -0
- package/dist/components/datepicker/utils.d.ts +84 -0
- package/dist/components/dialog/api.d.ts +59 -0
- package/dist/components/dialog/config.d.ts +91 -0
- package/dist/components/dialog/constants.d.ts +116 -0
- package/{src/components/dialog/dialog.ts → dist/components/dialog/dialog.d.ts} +16 -69
- package/dist/components/dialog/features.d.ts +37 -0
- package/dist/components/dialog/index.d.ts +14 -0
- package/dist/components/dialog/types.d.ts +483 -0
- package/dist/components/divider/config.d.ts +143 -0
- package/dist/components/divider/constants.d.ts +45 -0
- package/{src/components/divider/divider.ts → dist/components/divider/divider.d.ts} +9 -37
- package/dist/components/divider/features.d.ts +50 -0
- package/{src/components/divider/index.ts → dist/components/divider/index.d.ts} +6 -12
- package/dist/components/divider/types.d.ts +124 -0
- package/dist/components/extended-fab/api.d.ts +83 -0
- package/dist/components/extended-fab/config.d.ts +75 -0
- package/dist/components/extended-fab/constants.d.ts +82 -0
- package/dist/components/extended-fab/extended-fab.d.ts +61 -0
- package/{src/components/extended-fab/index.ts → dist/components/extended-fab/index.d.ts} +6 -15
- package/dist/components/extended-fab/types.d.ts +703 -0
- package/dist/components/fab/api.d.ts +64 -0
- package/dist/components/fab/config.d.ts +71 -0
- package/dist/components/fab/constants.d.ts +75 -0
- package/{src/components/fab/fab.ts → dist/components/fab/fab.d.ts} +10 -46
- package/{src/components/fab/index.ts → dist/components/fab/index.d.ts} +6 -15
- package/dist/components/fab/types.d.ts +577 -0
- package/dist/components/index.d.ts +76 -0
- package/dist/components/list/api.d.ts +106 -0
- package/dist/components/list/config.d.ts +61 -0
- package/dist/components/list/constants.d.ts +76 -0
- package/dist/components/list/features/index.d.ts +2 -0
- package/dist/components/list/features/listmanager.d.ts +9 -0
- package/dist/components/list/features/selection.d.ts +9 -0
- package/dist/components/list/index.d.ts +12 -0
- package/dist/components/list/list.d.ts +11 -0
- package/dist/components/list/types.d.ts +294 -0
- package/dist/components/menu/api.d.ts +58 -0
- package/dist/components/menu/config.d.ts +78 -0
- package/dist/components/menu/constants.d.ts +106 -0
- package/dist/components/menu/features/controller.d.ts +10 -0
- package/dist/components/menu/features/index.d.ts +6 -0
- package/dist/components/menu/features/keyboard.d.ts +26 -0
- package/dist/components/menu/features/opener.d.ts +10 -0
- package/dist/components/menu/features/position.d.ts +18 -0
- package/dist/components/menu/features/submenu.d.ts +10 -0
- package/{src/components/menu/index.ts → dist/components/menu/index.d.ts} +11 -27
- package/dist/components/menu/menu.d.ts +29 -0
- package/dist/components/menu/types.d.ts +338 -0
- package/dist/components/navigation/api.d.ts +8 -0
- package/dist/components/navigation/config.d.ts +34 -0
- package/dist/components/navigation/constants.d.ts +137 -0
- package/dist/components/navigation/features/controller.d.ts +30 -0
- package/dist/components/navigation/features/items.d.ts +32 -0
- package/dist/components/navigation/index.d.ts +3 -0
- package/dist/components/navigation/nav-item.d.ts +30 -0
- package/dist/components/navigation/navigation.d.ts +8 -0
- package/dist/components/navigation/system/core.d.ts +72 -0
- package/dist/components/navigation/system/events.d.ts +35 -0
- package/dist/components/navigation/system/index.d.ts +10 -0
- package/dist/components/navigation/system/mobile.d.ts +52 -0
- package/dist/components/navigation/system/state.d.ts +22 -0
- package/dist/components/navigation/system/types.d.ts +305 -0
- package/dist/components/navigation/types.d.ts +216 -0
- package/dist/components/progress/api.d.ts +46 -0
- package/dist/components/progress/config.d.ts +63 -0
- package/dist/components/progress/constants.d.ts +58 -0
- package/dist/components/progress/index.d.ts +3 -0
- package/dist/components/progress/progress.d.ts +24 -0
- package/dist/components/progress/types.d.ts +199 -0
- package/dist/components/radios/api.d.ts +37 -0
- package/dist/components/radios/config.d.ts +42 -0
- package/dist/components/radios/constants.d.ts +114 -0
- package/dist/components/radios/index.d.ts +3 -0
- package/dist/components/radios/radio.d.ts +8 -0
- package/dist/components/radios/radios.d.ts +8 -0
- package/dist/components/radios/types.d.ts +189 -0
- package/dist/components/search/api.d.ts +55 -0
- package/dist/components/search/config.d.ts +73 -0
- package/dist/components/search/constants.d.ts +128 -0
- package/{src/components/search/features/index.ts → dist/components/search/features/index.d.ts} +1 -2
- package/dist/components/search/features/search.d.ts +7 -0
- package/dist/components/search/features/states.d.ts +8 -0
- package/dist/components/search/features/structure.d.ts +7 -0
- package/dist/components/search/index.d.ts +3 -0
- package/dist/components/search/search.d.ts +8 -0
- package/dist/components/search/types.d.ts +132 -0
- package/dist/components/segmented-button/config.d.ts +65 -0
- package/dist/components/segmented-button/constants.d.ts +85 -0
- package/dist/components/segmented-button/index.d.ts +4 -0
- package/dist/components/segmented-button/segment.d.ts +15 -0
- package/dist/components/segmented-button/segmented-button.d.ts +49 -0
- package/dist/components/segmented-button/types.d.ts +257 -0
- package/dist/components/select/api.d.ts +8 -0
- package/dist/components/select/config.d.ts +18 -0
- package/dist/components/select/constants.d.ts +113 -0
- package/dist/components/select/features.d.ts +13 -0
- package/{src/components/select/index.ts → dist/components/select/index.d.ts} +7 -20
- package/dist/components/select/select.d.ts +36 -0
- package/dist/components/select/types.d.ts +302 -0
- package/dist/components/sheet/api.d.ts +37 -0
- package/dist/components/sheet/config.d.ts +42 -0
- package/dist/components/sheet/constants.d.ts +136 -0
- package/dist/components/sheet/features/content.d.ts +6 -0
- package/dist/components/sheet/features/gestures.d.ts +6 -0
- package/{src/components/sheet/features/index.ts → dist/components/sheet/features/index.d.ts} +1 -2
- package/dist/components/sheet/features/position.d.ts +7 -0
- package/dist/components/sheet/features/state.d.ts +6 -0
- package/dist/components/sheet/features/title.d.ts +6 -0
- package/dist/components/sheet/index.d.ts +3 -0
- package/dist/components/sheet/sheet.d.ts +8 -0
- package/dist/components/sheet/types.d.ts +250 -0
- package/dist/components/slider/api.d.ts +57 -0
- package/dist/components/slider/config.d.ts +75 -0
- package/dist/components/slider/constants.d.ts +138 -0
- package/dist/components/slider/features/controller.d.ts +9 -0
- package/dist/components/slider/features/handlers.d.ts +25 -0
- package/dist/components/slider/features/index.d.ts +3 -0
- package/dist/components/slider/features/range.d.ts +8 -0
- package/dist/components/slider/features/states.d.ts +9 -0
- package/dist/components/slider/index.d.ts +3 -0
- package/dist/components/slider/schema.d.ts +108 -0
- package/dist/components/slider/slider.d.ts +18 -0
- package/dist/components/slider/types.d.ts +170 -0
- package/dist/components/snackbar/api.d.ts +7 -0
- package/dist/components/snackbar/config.d.ts +55 -0
- package/dist/components/snackbar/constants.d.ts +88 -0
- package/dist/components/snackbar/features.d.ts +13 -0
- package/dist/components/snackbar/index.d.ts +3 -0
- package/dist/components/snackbar/position.d.ts +15 -0
- package/dist/components/snackbar/queue.d.ts +7 -0
- package/dist/components/snackbar/snackbar.d.ts +8 -0
- package/dist/components/snackbar/types.d.ts +172 -0
- package/dist/components/switch/api.d.ts +7 -0
- package/dist/components/switch/config.d.ts +34 -0
- package/dist/components/switch/constants.d.ts +88 -0
- package/dist/components/switch/features.d.ts +59 -0
- package/dist/components/switch/index.d.ts +4 -0
- package/dist/components/switch/switch.d.ts +8 -0
- package/dist/components/switch/types.d.ts +131 -0
- package/dist/components/tabs/api.d.ts +52 -0
- package/dist/components/tabs/config.d.ts +39 -0
- package/dist/components/tabs/constants.d.ts +142 -0
- package/dist/components/tabs/features.d.ts +133 -0
- package/dist/components/tabs/index.d.ts +11 -0
- package/dist/components/tabs/indicator.d.ts +49 -0
- package/dist/components/tabs/responsive.d.ts +38 -0
- package/dist/components/tabs/scroll-indicators.d.ts +18 -0
- package/dist/components/tabs/state.d.ts +53 -0
- package/dist/components/tabs/tab-api.d.ts +43 -0
- package/dist/components/tabs/tab.d.ts +7 -0
- package/dist/components/tabs/tabs.d.ts +27 -0
- package/dist/components/tabs/types.d.ts +390 -0
- package/dist/components/tabs/utils.d.ts +17 -0
- package/dist/components/textfield/api.d.ts +8 -0
- package/dist/components/textfield/config.d.ts +34 -0
- package/dist/components/textfield/constants.d.ts +148 -0
- package/{src/components/textfield/features/index.ts → dist/components/textfield/features/index.d.ts} +1 -6
- package/dist/components/textfield/features/leading-icon.d.ts +55 -0
- package/dist/components/textfield/features/placement.d.ts +28 -0
- package/dist/components/textfield/features/prefix-text.d.ts +54 -0
- package/dist/components/textfield/features/suffix-text.d.ts +54 -0
- package/dist/components/textfield/features/supporting-text.d.ts +59 -0
- package/dist/components/textfield/features/trailing-icon.d.ts +55 -0
- package/dist/components/textfield/index.d.ts +3 -0
- package/dist/components/textfield/textfield.d.ts +36 -0
- package/dist/components/textfield/types.d.ts +217 -0
- package/dist/components/timepicker/api.d.ts +24 -0
- package/dist/components/timepicker/clockdial.d.ts +34 -0
- package/dist/components/timepicker/config.d.ts +75 -0
- package/dist/components/timepicker/constants.d.ts +266 -0
- package/dist/components/timepicker/index.d.ts +4 -0
- package/dist/components/timepicker/render.d.ts +9 -0
- package/dist/components/timepicker/timepicker.d.ts +8 -0
- package/dist/components/timepicker/types.d.ts +284 -0
- package/dist/components/timepicker/utils.d.ts +74 -0
- package/dist/components/tooltip/api.d.ts +18 -0
- package/dist/components/tooltip/config.d.ts +38 -0
- package/dist/components/tooltip/constants.d.ts +108 -0
- package/dist/components/tooltip/index.d.ts +3 -0
- package/dist/components/tooltip/tooltip.d.ts +8 -0
- package/dist/components/tooltip/types.d.ts +188 -0
- package/dist/components/top-app-bar/config.d.ts +16 -0
- package/dist/components/top-app-bar/constants.d.ts +74 -0
- package/{src/components/top-app-bar/index.ts → dist/components/top-app-bar/index.d.ts} +2 -4
- package/dist/components/top-app-bar/top-app-bar.d.ts +68 -0
- package/dist/components/top-app-bar/types.d.ts +118 -0
- package/dist/constants.d.ts +30 -0
- package/dist/core/collection/adapters/base.d.ts +47 -0
- package/dist/core/collection/adapters/route.d.ts +149 -0
- package/dist/core/collection/collection.d.ts +131 -0
- package/dist/core/collection/index.d.ts +10 -0
- package/dist/core/collection/list-manager/config.d.ts +29 -0
- package/dist/core/collection/list-manager/dom-elements.d.ts +30 -0
- package/dist/core/collection/list-manager/index.d.ts +61 -0
- package/dist/core/collection/list-manager/item-measurement.d.ts +91 -0
- package/dist/core/collection/list-manager/renderer.d.ts +31 -0
- package/dist/core/collection/list-manager/scroll-tracker.d.ts +20 -0
- package/dist/core/collection/list-manager/state.d.ts +60 -0
- package/dist/core/collection/list-manager/types.d.ts +361 -0
- package/dist/core/collection/list-manager/utils/recycling.d.ts +34 -0
- package/dist/core/collection/list-manager/utils/visibility.d.ts +45 -0
- package/dist/core/compose/base.d.ts +31 -0
- package/dist/core/compose/component.d.ts +61 -0
- package/dist/core/compose/features/badge.d.ts +43 -0
- package/dist/core/compose/features/checkable.d.ts +59 -0
- package/dist/core/compose/features/constants.d.ts +45 -0
- package/dist/core/compose/features/debounce.d.ts +84 -0
- package/dist/core/compose/features/disabled.d.ts +47 -0
- package/dist/core/compose/features/events.d.ts +37 -0
- package/dist/core/compose/features/gestures/longpress.d.ts +85 -0
- package/dist/core/compose/features/gestures/pan.d.ts +108 -0
- package/dist/core/compose/features/gestures/pinch.d.ts +111 -0
- package/dist/core/compose/features/gestures/rotate.d.ts +111 -0
- package/dist/core/compose/features/gestures/swipe.d.ts +149 -0
- package/dist/core/compose/features/gestures/tap.d.ts +79 -0
- package/dist/core/compose/features/gestures.d.ts +86 -0
- package/dist/core/compose/features/icon.d.ts +71 -0
- package/{src/core/compose/features/index.ts → dist/core/compose/features/index.d.ts} +7 -8
- package/dist/core/compose/features/input.d.ts +71 -0
- package/dist/core/compose/features/lifecycle.d.ts +61 -0
- package/dist/core/compose/features/position.d.ts +51 -0
- package/dist/core/compose/features/ripple.d.ts +61 -0
- package/dist/core/compose/features/size.d.ts +17 -0
- package/dist/core/compose/features/style.d.ts +16 -0
- package/dist/core/compose/features/text.d.ts +63 -0
- package/dist/core/compose/features/textinput.d.ts +93 -0
- package/dist/core/compose/features/textlabel.d.ts +57 -0
- package/dist/core/compose/features/throttle.d.ts +75 -0
- package/dist/core/compose/features/track.d.ts +42 -0
- package/dist/core/compose/features/variant.d.ts +17 -0
- package/dist/core/compose/features/withEvents.d.ts +45 -0
- package/dist/core/compose/index.d.ts +17 -0
- package/{src/core/compose/pipe.ts → dist/core/compose/pipe.d.ts} +4 -20
- package/dist/core/compose/utils/type-guards.d.ts +27 -0
- package/dist/core/composition/features/dom.d.ts +19 -0
- package/dist/core/composition/features/icon.d.ts +45 -0
- package/{src/core/composition/features/index.ts → dist/core/composition/features/index.d.ts} +1 -6
- package/dist/core/composition/features/label.d.ts +49 -0
- package/{src/core/composition/features/layout.ts → dist/core/composition/features/layout.d.ts} +8 -24
- package/{src/core/composition/index.ts → dist/core/composition/index.d.ts} +4 -14
- package/{src/core/config/component-config.ts → dist/core/config/component.d.ts} +34 -82
- package/dist/core/config.d.ts +130 -0
- package/{src/core/dom/attributes.ts → dist/core/dom/attributes.d.ts} +2 -13
- package/dist/core/dom/classes.d.ts +42 -0
- package/dist/core/dom/create.d.ts +124 -0
- package/dist/core/dom/events.d.ts +69 -0
- package/{src/core/dom/index.ts → dist/core/dom/index.d.ts} +1 -5
- package/dist/core/dom/utils.d.ts +42 -0
- package/dist/core/gestures/index.d.ts +12 -0
- package/dist/core/gestures/longpress.d.ts +23 -0
- package/dist/core/gestures/manager.d.ts +14 -0
- package/dist/core/gestures/pan.d.ts +12 -0
- package/dist/core/gestures/pinch.d.ts +14 -0
- package/dist/core/gestures/rotate.d.ts +14 -0
- package/dist/core/gestures/swipe.d.ts +20 -0
- package/dist/core/gestures/tap.d.ts +12 -0
- package/dist/core/gestures/types.d.ts +320 -0
- package/dist/core/gestures/utils.d.ts +57 -0
- package/dist/core/index.d.ts +29 -0
- package/dist/core/layout/array.d.ts +15 -0
- package/dist/core/layout/config.d.ts +32 -0
- package/dist/core/layout/create.d.ts +14 -0
- package/dist/core/layout/index.d.ts +13 -0
- package/dist/core/layout/jsx.d.ts +13 -0
- package/dist/core/layout/object.d.ts +14 -0
- package/dist/core/layout/processor.d.ts +28 -0
- package/dist/core/layout/result.d.ts +12 -0
- package/dist/core/layout/template.d.ts +12 -0
- package/dist/core/layout/types.d.ts +137 -0
- package/dist/core/layout/utils.d.ts +38 -0
- package/dist/core/state/disabled.d.ts +32 -0
- package/dist/core/state/emitter.d.ts +40 -0
- package/dist/core/state/events.d.ts +36 -0
- package/{src/core/state/index.ts → dist/core/state/index.d.ts} +1 -7
- package/dist/core/state/lifecycle.d.ts +57 -0
- package/dist/core/state/store.d.ts +82 -0
- package/dist/core/utils/background.d.ts +40 -0
- package/dist/core/utils/index.d.ts +23 -0
- package/dist/core/utils/mobile.d.ts +54 -0
- package/dist/core/utils/object.d.ts +13 -0
- package/dist/core/utils/performance.d.ts +79 -0
- package/dist/core/utils/validate.d.ts +73 -0
- package/dist/index.cjs +64 -0
- package/dist/index.cjs.map +285 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.js +53 -14854
- package/dist/index.js.map +285 -0
- package/dist/package.json +39 -0
- package/dist/styles.css +7 -0
- package/package.json +24 -5
- package/.env +0 -15
- package/.typedocignore +0 -11
- package/CONTRIBUTING.md +0 -218
- package/DOCS.md +0 -153
- package/TESTING.md +0 -214
- package/git-user-stats.js +0 -545
- package/index.ts +0 -10
- package/src/components/badge/api.ts +0 -313
- package/src/components/badge/config.ts +0 -153
- package/src/components/badge/features.ts +0 -194
- package/src/components/badge/index.ts +0 -90
- package/src/components/badge/types.ts +0 -279
- package/src/components/bottom-app-bar/bottom-app-bar.ts +0 -154
- package/src/components/bottom-app-bar/config.ts +0 -29
- package/src/components/bottom-app-bar/types.ts +0 -114
- package/src/components/button/api.ts +0 -172
- package/src/components/button/button.ts +0 -112
- package/src/components/button/config.ts +0 -96
- package/src/components/button/index.ts +0 -37
- package/src/components/button/types.ts +0 -290
- package/src/components/card/api.ts +0 -222
- package/src/components/card/config.ts +0 -304
- package/src/components/card/content.ts +0 -343
- package/src/components/card/features.ts +0 -407
- package/src/components/card/types.ts +0 -497
- package/src/components/carousel/api.ts +0 -147
- package/src/components/carousel/carousel.ts +0 -242
- package/src/components/carousel/config.ts +0 -91
- package/src/components/carousel/constants.ts +0 -181
- package/src/components/carousel/features/drag.ts +0 -388
- package/src/components/carousel/features/slides.ts +0 -682
- package/src/components/carousel/types.ts +0 -327
- package/src/components/checkbox/api.ts +0 -82
- package/src/components/checkbox/checkbox.ts +0 -142
- package/src/components/checkbox/config.ts +0 -89
- package/src/components/checkbox/types.ts +0 -342
- package/src/components/chips/api.ts +0 -194
- package/src/components/chips/chip/api.ts +0 -233
- package/src/components/chips/chip/chip.ts +0 -131
- package/src/components/chips/chip/config.ts +0 -91
- package/src/components/chips/chip/index.ts +0 -3
- package/src/components/chips/chips.md +0 -481
- package/src/components/chips/chips.ts +0 -75
- package/src/components/chips/config.ts +0 -109
- package/src/components/chips/constants.ts +0 -61
- package/src/components/chips/features/chip-items.ts +0 -33
- package/src/components/chips/features/container.ts +0 -77
- package/src/components/chips/features/controller.ts +0 -448
- package/src/components/chips/features/label.ts +0 -108
- package/src/components/chips/index.ts +0 -11
- package/src/components/chips/schema.ts +0 -61
- package/src/components/chips/types.ts +0 -469
- package/src/components/datepicker/api.ts +0 -265
- package/src/components/datepicker/config.ts +0 -141
- package/src/components/datepicker/datepicker.ts +0 -341
- package/src/components/datepicker/index.ts +0 -12
- package/src/components/datepicker/render.ts +0 -450
- package/src/components/datepicker/types.ts +0 -397
- package/src/components/datepicker/utils.ts +0 -289
- package/src/components/dialog/api.ts +0 -317
- package/src/components/dialog/config.ts +0 -116
- package/src/components/dialog/features.ts +0 -907
- package/src/components/dialog/index.ts +0 -141
- package/src/components/dialog/types.ts +0 -553
- package/src/components/divider/config.ts +0 -165
- package/src/components/divider/features.ts +0 -233
- package/src/components/divider/types.ts +0 -132
- package/src/components/extended-fab/api.ts +0 -193
- package/src/components/extended-fab/config.ts +0 -140
- package/src/components/extended-fab/extended-fab.ts +0 -153
- package/src/components/extended-fab/types.ts +0 -749
- package/src/components/fab/api.ts +0 -137
- package/src/components/fab/config.ts +0 -121
- package/src/components/fab/types.ts +0 -615
- package/src/components/list/api.ts +0 -82
- package/src/components/list/config.ts +0 -63
- package/src/components/list/features.ts +0 -229
- package/src/components/list/index.ts +0 -67
- package/src/components/list/list-item.ts +0 -163
- package/src/components/list/list.ts +0 -108
- package/src/components/list/types.ts +0 -396
- package/src/components/list/utils.ts +0 -98
- package/src/components/menu/api.ts +0 -193
- package/src/components/menu/config.ts +0 -125
- package/src/components/menu/features/anchor.ts +0 -243
- package/src/components/menu/features/controller.ts +0 -1167
- package/src/components/menu/features/index.ts +0 -5
- package/src/components/menu/features/position.ts +0 -353
- package/src/components/menu/menu.ts +0 -119
- package/src/components/menu/types.ts +0 -379
- package/src/components/navigation/api.ts +0 -142
- package/src/components/navigation/config.ts +0 -73
- package/src/components/navigation/features/controller.ts +0 -273
- package/src/components/navigation/features/items.ts +0 -353
- package/src/components/navigation/index.ts +0 -11
- package/src/components/navigation/nav-item.ts +0 -196
- package/src/components/navigation/navigation.ts +0 -115
- package/src/components/navigation/system/core.ts +0 -302
- package/src/components/navigation/system/events.ts +0 -240
- package/src/components/navigation/system/index.ts +0 -184
- package/src/components/navigation/system/mobile.ts +0 -278
- package/src/components/navigation/system/state.ts +0 -77
- package/src/components/navigation/system/types.ts +0 -364
- package/src/components/navigation/types.ts +0 -292
- package/src/components/progress/api.ts +0 -178
- package/src/components/progress/config.ts +0 -122
- package/src/components/progress/index.ts +0 -4
- package/src/components/progress/progress.ts +0 -159
- package/src/components/progress/types.ts +0 -255
- package/src/components/radios/api.ts +0 -125
- package/src/components/radios/config.ts +0 -59
- package/src/components/radios/constants.ts +0 -19
- package/src/components/radios/index.ts +0 -3
- package/src/components/radios/radio.ts +0 -292
- package/src/components/radios/radios.ts +0 -43
- package/src/components/radios/types.ts +0 -219
- package/src/components/search/api.ts +0 -203
- package/src/components/search/config.ts +0 -86
- package/src/components/search/features/search.ts +0 -717
- package/src/components/search/features/states.ts +0 -169
- package/src/components/search/features/structure.ts +0 -197
- package/src/components/search/index.ts +0 -7
- package/src/components/search/search.ts +0 -52
- package/src/components/search/types.ts +0 -175
- package/src/components/segmented-button/config.ts +0 -119
- package/src/components/segmented-button/index.ts +0 -4
- package/src/components/segmented-button/segment.ts +0 -108
- package/src/components/segmented-button/segmented-button.ts +0 -361
- package/src/components/segmented-button/types.ts +0 -306
- package/src/components/select/api.ts +0 -78
- package/src/components/select/config.ts +0 -76
- package/src/components/select/features.ts +0 -317
- package/src/components/select/select.ts +0 -73
- package/src/components/select/types.ts +0 -355
- package/src/components/sheet/api.ts +0 -96
- package/src/components/sheet/config.ts +0 -65
- package/src/components/sheet/features/content.ts +0 -51
- package/src/components/sheet/features/gestures.ts +0 -177
- package/src/components/sheet/features/position.ts +0 -41
- package/src/components/sheet/features/state.ts +0 -116
- package/src/components/sheet/features/title.ts +0 -86
- package/src/components/sheet/index.ts +0 -12
- package/src/components/sheet/sheet.ts +0 -56
- package/src/components/sheet/types.ts +0 -294
- package/src/components/slider/accessibility.md +0 -59
- package/src/components/slider/api.ts +0 -192
- package/src/components/slider/config.ts +0 -118
- package/src/components/slider/features/controller.ts +0 -737
- package/src/components/slider/features/handlers.ts +0 -497
- package/src/components/slider/features/index.ts +0 -5
- package/src/components/slider/features/range.ts +0 -104
- package/src/components/slider/features/states.ts +0 -195
- package/src/components/slider/index.ts +0 -17
- package/src/components/slider/schema.ts +0 -141
- package/src/components/slider/slider.ts +0 -76
- package/src/components/slider/types.ts +0 -223
- package/src/components/snackbar/api.ts +0 -162
- package/src/components/snackbar/config.ts +0 -61
- package/src/components/snackbar/features.ts +0 -76
- package/src/components/snackbar/index.ts +0 -9
- package/src/components/snackbar/position.ts +0 -79
- package/src/components/snackbar/queue.ts +0 -76
- package/src/components/snackbar/snackbar.ts +0 -60
- package/src/components/snackbar/types.ts +0 -159
- package/src/components/switch/api.ts +0 -93
- package/src/components/switch/config.ts +0 -56
- package/src/components/switch/features.ts +0 -198
- package/src/components/switch/index.ts +0 -8
- package/src/components/switch/switch.ts +0 -52
- package/src/components/switch/types.ts +0 -168
- package/src/components/tabs/api.ts +0 -221
- package/src/components/tabs/config.ts +0 -73
- package/src/components/tabs/features.ts +0 -403
- package/src/components/tabs/index.ts +0 -46
- package/src/components/tabs/indicator.ts +0 -285
- package/src/components/tabs/responsive.ts +0 -144
- package/src/components/tabs/scroll-indicators.ts +0 -149
- package/src/components/tabs/state.ts +0 -186
- package/src/components/tabs/tab-api.ts +0 -266
- package/src/components/tabs/tab.ts +0 -267
- package/src/components/tabs/tabs.ts +0 -71
- package/src/components/tabs/types.ts +0 -461
- package/src/components/tabs/utils.ts +0 -107
- package/src/components/textfield/api.ts +0 -197
- package/src/components/textfield/config.ts +0 -52
- package/src/components/textfield/features/leading-icon.ts +0 -127
- package/src/components/textfield/features/placement.ts +0 -149
- package/src/components/textfield/features/prefix-text.ts +0 -107
- package/src/components/textfield/features/suffix-text.ts +0 -100
- package/src/components/textfield/features/supporting-text.ts +0 -113
- package/src/components/textfield/features/trailing-icon.ts +0 -108
- package/src/components/textfield/index.ts +0 -9
- package/src/components/textfield/textfield.ts +0 -92
- package/src/components/textfield/types.ts +0 -265
- package/src/components/timepicker/README.md +0 -277
- package/src/components/timepicker/api.ts +0 -632
- package/src/components/timepicker/clockdial.ts +0 -479
- package/src/components/timepicker/config.ts +0 -228
- package/src/components/timepicker/index.ts +0 -3
- package/src/components/timepicker/render.ts +0 -613
- package/src/components/timepicker/timepicker.ts +0 -117
- package/src/components/timepicker/types.ts +0 -336
- package/src/components/timepicker/utils.ts +0 -241
- package/src/components/tooltip/api.ts +0 -415
- package/src/components/tooltip/config.ts +0 -80
- package/src/components/tooltip/index.ts +0 -12
- package/src/components/tooltip/tooltip.ts +0 -60
- package/src/components/tooltip/types.ts +0 -223
- package/src/components/top-app-bar/config.ts +0 -83
- package/src/components/top-app-bar/top-app-bar.ts +0 -316
- package/src/components/top-app-bar/types.ts +0 -140
- package/src/core/build/constants.ts +0 -48
- package/src/core/build/icon.ts +0 -137
- package/src/core/build/ripple.ts +0 -193
- package/src/core/build/text.ts +0 -91
- package/src/core/collection/adapters/base.ts +0 -62
- package/src/core/collection/adapters/route.ts +0 -201
- package/src/core/collection/collection.ts +0 -300
- package/src/core/collection/index.ts +0 -57
- package/src/core/collection/list-manager.ts +0 -333
- package/src/core/compose/base.ts +0 -43
- package/src/core/compose/component.ts +0 -255
- package/src/core/compose/features/badge.ts +0 -79
- package/src/core/compose/features/checkable.ts +0 -155
- package/src/core/compose/features/disabled.ts +0 -116
- package/src/core/compose/features/events.ts +0 -65
- package/src/core/compose/features/icon.ts +0 -71
- package/src/core/compose/features/input.ts +0 -174
- package/src/core/compose/features/lifecycle.ts +0 -139
- package/src/core/compose/features/position.ts +0 -94
- package/src/core/compose/features/ripple.ts +0 -58
- package/src/core/compose/features/size.ts +0 -29
- package/src/core/compose/features/style.ts +0 -31
- package/src/core/compose/features/text.ts +0 -44
- package/src/core/compose/features/textinput.ts +0 -238
- package/src/core/compose/features/textlabel.ts +0 -113
- package/src/core/compose/features/track.ts +0 -84
- package/src/core/compose/features/variant.ts +0 -29
- package/src/core/compose/features/withEvents.ts +0 -137
- package/src/core/compose/index.ts +0 -54
- package/src/core/composition/features/dom.ts +0 -45
- package/src/core/composition/features/icon.ts +0 -131
- package/src/core/composition/features/label.ts +0 -155
- package/src/core/config.ts +0 -211
- package/src/core/dom/classes.ts +0 -132
- package/src/core/dom/create.ts +0 -273
- package/src/core/dom/events.ts +0 -209
- package/src/core/dom/utils.ts +0 -97
- package/src/core/index.ts +0 -111
- package/src/core/layout/README.md +0 -715
- package/src/core/layout/array.ts +0 -180
- package/src/core/layout/config.ts +0 -193
- package/src/core/layout/create.ts +0 -54
- package/src/core/layout/index.ts +0 -36
- package/src/core/layout/object.ts +0 -123
- package/src/core/layout/processor.ts +0 -106
- package/src/core/layout/result.ts +0 -84
- package/src/core/layout/types.ts +0 -180
- package/src/core/layout/utils.ts +0 -144
- package/src/core/state/disabled.ts +0 -81
- package/src/core/state/emitter.ts +0 -94
- package/src/core/state/events.ts +0 -88
- package/src/core/state/lifecycle.ts +0 -131
- package/src/core/state/store.ts +0 -197
- package/src/core/utils/index.ts +0 -45
- package/src/core/utils/mobile.ts +0 -98
- package/src/core/utils/object.ts +0 -41
- package/src/core/utils/validate.ts +0 -234
- package/src/index.ts +0 -134
- package/src/styles/abstract/_base.scss +0 -2
- package/src/styles/abstract/_config.scss +0 -28
- package/src/styles/abstract/_functions.scss +0 -124
- package/src/styles/abstract/_mixins.scss +0 -352
- package/src/styles/abstract/_theme.scss +0 -269
- package/src/styles/abstract/_variables.scss +0 -305
- package/src/styles/base/_reset.scss +0 -86
- package/src/styles/base/_typography.scss +0 -155
- package/src/styles/components/_badge.scss +0 -182
- package/src/styles/components/_bottom-app-bar.scss +0 -103
- package/src/styles/components/_button.scss +0 -224
- package/src/styles/components/_card.scss +0 -401
- package/src/styles/components/_carousel.scss +0 -645
- package/src/styles/components/_checkbox.scss +0 -231
- package/src/styles/components/_chips.scss +0 -638
- package/src/styles/components/_datepicker.scss +0 -358
- package/src/styles/components/_dialog.scss +0 -259
- package/src/styles/components/_divider.scss +0 -57
- package/src/styles/components/_extended-fab.scss +0 -267
- package/src/styles/components/_fab.scss +0 -225
- package/src/styles/components/_list.scss +0 -248
- package/src/styles/components/_menu.scss +0 -248
- package/src/styles/components/_navigation-mobile.scss +0 -244
- package/src/styles/components/_navigation-system.scss +0 -151
- package/src/styles/components/_navigation.scss +0 -407
- package/src/styles/components/_progress.scss +0 -151
- package/src/styles/components/_radios.scss +0 -187
- package/src/styles/components/_search.scss +0 -306
- package/src/styles/components/_segmented-button.scss +0 -227
- package/src/styles/components/_select.scss +0 -265
- package/src/styles/components/_sheet.scss +0 -236
- package/src/styles/components/_slider.scss +0 -489
- package/src/styles/components/_snackbar.scss +0 -211
- package/src/styles/components/_switch.scss +0 -298
- package/src/styles/components/_tabs.scss +0 -416
- package/src/styles/components/_textfield.scss +0 -773
- package/src/styles/components/_timepicker.scss +0 -451
- package/src/styles/components/_tooltip.scss +0 -241
- package/src/styles/components/_top-app-bar.scss +0 -225
- package/src/styles/main.scss +0 -175
- package/src/styles/themes/_autumn.scss +0 -105
- package/src/styles/themes/_base-theme.scss +0 -85
- package/src/styles/themes/_baseline.scss +0 -173
- package/src/styles/themes/_bluekhaki.scss +0 -125
- package/src/styles/themes/_brownbeige.scss +0 -125
- package/src/styles/themes/_browngreen.scss +0 -125
- package/src/styles/themes/_forest.scss +0 -77
- package/src/styles/themes/_greenbeige.scss +0 -125
- package/src/styles/themes/_index.scss +0 -6
- package/src/styles/themes/_material.scss +0 -125
- package/src/styles/themes/_ocean.scss +0 -77
- package/src/styles/themes/_sageivory.scss +0 -125
- package/src/styles/themes/_spring.scss +0 -77
- package/src/styles/themes/_summer.scss +0 -87
- package/src/styles/themes/_sunset.scss +0 -60
- package/src/styles/themes/_tealcaramel.scss +0 -125
- package/src/styles/themes/_winter.scss +0 -77
- package/src/styles/utilities/_colors.scss +0 -154
- package/src/styles/utilities/_flexbox.scss +0 -194
- package/src/styles/utilities/_layout.scss +0 -665
- package/src/styles/utilities/_ripple.scss +0 -79
- package/src/styles/utilities/_spacing.scss +0 -139
- package/src/styles/utilities/_typography.scss +0 -178
- package/src/styles/utilities/_visibility.scss +0 -142
|
@@ -0,0 +1,256 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Badge variant types - determines the badge size and appearance
|
|
3
|
+
* @category Components
|
|
4
|
+
* @remarks
|
|
5
|
+
* - small: A 6dp circular dot badge without text (for notification indicators)
|
|
6
|
+
* - large: A 16dp height badge that can contain text (for counts or short labels)
|
|
7
|
+
*/
|
|
8
|
+
export type BadgeVariant = 'small' | 'large';
|
|
9
|
+
/**
|
|
10
|
+
* Badge color types - determines the badge's background color
|
|
11
|
+
* @category Components
|
|
12
|
+
* @remarks
|
|
13
|
+
* Based on Material Design 3 color system:
|
|
14
|
+
* - error: Red color for error states (default)
|
|
15
|
+
* - primary: Primary theme color
|
|
16
|
+
* - secondary: Secondary theme color
|
|
17
|
+
* - tertiary: Tertiary theme color
|
|
18
|
+
* - success: Green color for success states
|
|
19
|
+
* - warning: Orange/yellow color for warning states
|
|
20
|
+
* - info: Blue color for information states
|
|
21
|
+
*/
|
|
22
|
+
export type BadgeColor = 'error' | 'primary' | 'secondary' | 'tertiary' | 'success' | 'warning' | 'info';
|
|
23
|
+
/**
|
|
24
|
+
* Badge position types - determines where the badge appears relative to its target
|
|
25
|
+
* @category Components
|
|
26
|
+
* @remarks
|
|
27
|
+
* - top-right: Position in the top-right corner (default)
|
|
28
|
+
* - top-left: Position in the top-left corner
|
|
29
|
+
* - bottom-right: Position in the bottom-right corner
|
|
30
|
+
* - bottom-left: Position in the bottom-left corner
|
|
31
|
+
*/
|
|
32
|
+
export type BadgePosition = 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left';
|
|
33
|
+
/**
|
|
34
|
+
* Configuration interface for the Badge component
|
|
35
|
+
* @category Components
|
|
36
|
+
* @description
|
|
37
|
+
* Defines the appearance and behavior of a badge component.
|
|
38
|
+
* All properties are optional with sensible defaults.
|
|
39
|
+
*/
|
|
40
|
+
export interface BadgeConfig {
|
|
41
|
+
/**
|
|
42
|
+
* Badge variant (small dot or large numbered)
|
|
43
|
+
* Small badge (6dp) or Large badge (16dp height)
|
|
44
|
+
* @default 'large'
|
|
45
|
+
* @example 'small' | 'large'
|
|
46
|
+
*/
|
|
47
|
+
variant?: BadgeVariant | string;
|
|
48
|
+
/**
|
|
49
|
+
* Badge color (follows Material Design 3 color system)
|
|
50
|
+
* @default 'error'
|
|
51
|
+
* @example 'error' | 'primary' | 'secondary' | 'tertiary' | 'success' | 'warning' | 'info'
|
|
52
|
+
*/
|
|
53
|
+
color?: BadgeColor | string;
|
|
54
|
+
/**
|
|
55
|
+
* Badge position relative to its container element
|
|
56
|
+
* @default 'top-right'
|
|
57
|
+
* @example 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left'
|
|
58
|
+
*/
|
|
59
|
+
position?: BadgePosition | string;
|
|
60
|
+
/**
|
|
61
|
+
* Text label inside the badge (for large badges)
|
|
62
|
+
* Up to 4 characters, numbers exceeding max will show "{max}+"
|
|
63
|
+
* @example "3" | "99+" | "New"
|
|
64
|
+
*/
|
|
65
|
+
label?: string | number;
|
|
66
|
+
/**
|
|
67
|
+
* Maximum value to display (shows "{max}+" if label exceeds max)
|
|
68
|
+
* Usually 999+ for large numbers
|
|
69
|
+
* @example 99 | 999
|
|
70
|
+
*/
|
|
71
|
+
max?: number;
|
|
72
|
+
/**
|
|
73
|
+
* Whether the badge should be initially visible
|
|
74
|
+
* @default true
|
|
75
|
+
*/
|
|
76
|
+
visible?: boolean;
|
|
77
|
+
/**
|
|
78
|
+
* Target element to which badge will be attached
|
|
79
|
+
* When provided, the badge will be positioned relative to this element
|
|
80
|
+
*/
|
|
81
|
+
target?: HTMLElement;
|
|
82
|
+
/**
|
|
83
|
+
* Additional CSS classes to apply to the badge element
|
|
84
|
+
* @example "custom-badge highlighted-badge"
|
|
85
|
+
*/
|
|
86
|
+
class?: string;
|
|
87
|
+
/**
|
|
88
|
+
* CSS class prefix for all badge classes
|
|
89
|
+
* @default "mtrl"
|
|
90
|
+
*/
|
|
91
|
+
prefix?: string;
|
|
92
|
+
/**
|
|
93
|
+
* Component name used in CSS class generation
|
|
94
|
+
* @default "badge"
|
|
95
|
+
* @internal
|
|
96
|
+
*/
|
|
97
|
+
componentName?: string;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Badge component interface
|
|
101
|
+
* Provides methods for controlling a Material Design 3 badge
|
|
102
|
+
*
|
|
103
|
+
* @category Components
|
|
104
|
+
*/
|
|
105
|
+
export interface BadgeComponent {
|
|
106
|
+
/**
|
|
107
|
+
* The badge's root DOM element
|
|
108
|
+
*/
|
|
109
|
+
element: HTMLElement;
|
|
110
|
+
/**
|
|
111
|
+
* Badge wrapper element (if badge is attached to target)
|
|
112
|
+
* This is the parent element that contains both the target and the badge
|
|
113
|
+
*/
|
|
114
|
+
wrapper?: HTMLElement;
|
|
115
|
+
/**
|
|
116
|
+
* Sets the badge's text label
|
|
117
|
+
* @param label - Text or number to display in the badge
|
|
118
|
+
* @returns Badge component for method chaining
|
|
119
|
+
* @example
|
|
120
|
+
* badge.setLabel(5); // Shows "5"
|
|
121
|
+
* badge.setLabel("New"); // Shows "New"
|
|
122
|
+
* badge.setLabel(1250); // With max=999, shows "999+"
|
|
123
|
+
*/
|
|
124
|
+
setLabel: (label: string | number) => BadgeComponent;
|
|
125
|
+
/**
|
|
126
|
+
* Gets the badge's current text label
|
|
127
|
+
* @returns Current text content of the badge
|
|
128
|
+
*/
|
|
129
|
+
getLabel: () => string;
|
|
130
|
+
/**
|
|
131
|
+
* Sets the badge's content (alias for setLabel)
|
|
132
|
+
* @param content - Text or number to display in the badge
|
|
133
|
+
* @returns Badge component for method chaining
|
|
134
|
+
*/
|
|
135
|
+
setContent: (content: string | number) => BadgeComponent;
|
|
136
|
+
/**
|
|
137
|
+
* Gets the badge's current content (alias for getLabel)
|
|
138
|
+
* @returns Current text content of the badge
|
|
139
|
+
*/
|
|
140
|
+
getContent: () => string;
|
|
141
|
+
/**
|
|
142
|
+
* Shows the badge (makes it visible)
|
|
143
|
+
* @returns Badge component for method chaining
|
|
144
|
+
*/
|
|
145
|
+
show: () => BadgeComponent;
|
|
146
|
+
/**
|
|
147
|
+
* Hides the badge (makes it invisible)
|
|
148
|
+
* @returns Badge component for method chaining
|
|
149
|
+
*/
|
|
150
|
+
hide: () => BadgeComponent;
|
|
151
|
+
/**
|
|
152
|
+
* Toggles badge visibility
|
|
153
|
+
* @param visible - Optional explicit visibility state
|
|
154
|
+
* @returns Badge component for method chaining
|
|
155
|
+
* @example
|
|
156
|
+
* badge.toggle(); // Toggles current state
|
|
157
|
+
* badge.toggle(true); // Forces visible
|
|
158
|
+
*/
|
|
159
|
+
toggle: (visible?: boolean) => BadgeComponent;
|
|
160
|
+
/**
|
|
161
|
+
* Checks if the badge is currently visible
|
|
162
|
+
* @returns True if badge is visible, false otherwise
|
|
163
|
+
*/
|
|
164
|
+
isVisible: () => boolean;
|
|
165
|
+
/**
|
|
166
|
+
* Sets maximum value (after which badge shows max+)
|
|
167
|
+
* @param max - Maximum number to display before showing "+"
|
|
168
|
+
* @returns Badge component for method chaining
|
|
169
|
+
* @example
|
|
170
|
+
* badge.setMax(99); // Shows "99+" for values > 99
|
|
171
|
+
*/
|
|
172
|
+
setMax: (max: number) => BadgeComponent;
|
|
173
|
+
/**
|
|
174
|
+
* Sets badge color
|
|
175
|
+
* @param color - Badge color from Material Design 3 palette
|
|
176
|
+
* @returns Badge component for method chaining
|
|
177
|
+
* @example
|
|
178
|
+
* badge.setColor('primary');
|
|
179
|
+
* badge.setColor(BADGE_COLORS.SUCCESS);
|
|
180
|
+
*/
|
|
181
|
+
setColor: (color: BadgeColor | string) => BadgeComponent;
|
|
182
|
+
/**
|
|
183
|
+
* Sets badge variant (size style)
|
|
184
|
+
* @param variant - Badge variant ('small' or 'large')
|
|
185
|
+
* @returns Badge component for method chaining
|
|
186
|
+
* @example
|
|
187
|
+
* badge.setVariant('small'); // Dot indicator
|
|
188
|
+
* badge.setVariant(BADGE_VARIANTS.LARGE); // Numbered indicator
|
|
189
|
+
*/
|
|
190
|
+
setVariant: (variant: BadgeVariant | string) => BadgeComponent;
|
|
191
|
+
/**
|
|
192
|
+
* Sets badge position relative to target
|
|
193
|
+
* @param position - Badge position
|
|
194
|
+
* @returns Badge component for method chaining
|
|
195
|
+
* @example
|
|
196
|
+
* badge.setPosition('bottom-left');
|
|
197
|
+
*/
|
|
198
|
+
setPosition: (position: BadgePosition | string) => BadgeComponent;
|
|
199
|
+
/**
|
|
200
|
+
* Attaches badge to a target element
|
|
201
|
+
* @param target - Element to attach badge to
|
|
202
|
+
* @returns Badge component for method chaining
|
|
203
|
+
* @example
|
|
204
|
+
* badge.attachTo(document.querySelector('#notification-bell'));
|
|
205
|
+
*/
|
|
206
|
+
attachTo: (target: HTMLElement) => BadgeComponent;
|
|
207
|
+
/**
|
|
208
|
+
* Makes badge standalone (removes from wrapper)
|
|
209
|
+
* @returns Badge component for method chaining
|
|
210
|
+
*/
|
|
211
|
+
detach: () => BadgeComponent;
|
|
212
|
+
/**
|
|
213
|
+
* Destroys the badge component and cleans up resources
|
|
214
|
+
* Removes the badge from the DOM and clears event listeners
|
|
215
|
+
*/
|
|
216
|
+
destroy: () => void;
|
|
217
|
+
/**
|
|
218
|
+
* Gets a class name with the component's prefix
|
|
219
|
+
* @param name - Base class name
|
|
220
|
+
* @returns Prefixed class name
|
|
221
|
+
* @internal
|
|
222
|
+
*/
|
|
223
|
+
getClass: (name: string) => string;
|
|
224
|
+
/**
|
|
225
|
+
* Adds CSS classes to the badge element
|
|
226
|
+
* @param classes - One or more class names to add
|
|
227
|
+
* @returns Badge component for method chaining
|
|
228
|
+
* @example
|
|
229
|
+
* badge.addClass('highlighted', 'animated');
|
|
230
|
+
*/
|
|
231
|
+
addClass: (...classes: string[]) => BadgeComponent;
|
|
232
|
+
/**
|
|
233
|
+
* Removes CSS classes from the badge element
|
|
234
|
+
* @param classes - One or more class names to remove
|
|
235
|
+
* @returns Badge component for method chaining
|
|
236
|
+
* @example
|
|
237
|
+
* badge.removeClass('highlighted', 'animated');
|
|
238
|
+
*/
|
|
239
|
+
removeClass: (...classes: string[]) => BadgeComponent;
|
|
240
|
+
/**
|
|
241
|
+
* Adds an event listener to the badge
|
|
242
|
+
* @param event - Event name ('click', 'mouseover', etc.)
|
|
243
|
+
* @param handler - Event handler function
|
|
244
|
+
* @returns Badge component for method chaining
|
|
245
|
+
* @example
|
|
246
|
+
* badge.on('click', () => console.log('Badge clicked'));
|
|
247
|
+
*/
|
|
248
|
+
on: (event: string, handler: Function) => BadgeComponent;
|
|
249
|
+
/**
|
|
250
|
+
* Removes an event listener from the badge
|
|
251
|
+
* @param event - Event name
|
|
252
|
+
* @param handler - Event handler function
|
|
253
|
+
* @returns Badge component for method chaining
|
|
254
|
+
*/
|
|
255
|
+
off: (event: string, handler: Function) => BadgeComponent;
|
|
256
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module components/bottom-app-bar
|
|
3
|
+
* @description Bottom app bar implementation
|
|
4
|
+
*/
|
|
5
|
+
import { BottomAppBar, BottomAppBarConfig } from './types';
|
|
6
|
+
/**
|
|
7
|
+
* Creates a bottom app bar component
|
|
8
|
+
*
|
|
9
|
+
* @param {BottomAppBarConfig} config - Configuration options
|
|
10
|
+
* @returns {BottomAppBar} Bottom app bar component instance
|
|
11
|
+
*/
|
|
12
|
+
export declare const createBottomAppBar: (config?: BottomAppBarConfig) => BottomAppBar;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module components/bottom-app-bar
|
|
3
|
+
* @description Configuration for bottom app bar component
|
|
4
|
+
*/
|
|
5
|
+
import { BottomAppBarConfig } from './types';
|
|
6
|
+
/**
|
|
7
|
+
* Default configuration for bottom app bar
|
|
8
|
+
*/
|
|
9
|
+
export declare const defaultConfig: Partial<BottomAppBarConfig>;
|
|
10
|
+
/**
|
|
11
|
+
* Creates the configuration for a bottom app bar component
|
|
12
|
+
*
|
|
13
|
+
* @param {BottomAppBarConfig} config - User provided configuration
|
|
14
|
+
* @returns {BottomAppBarConfig} Complete configuration with defaults applied
|
|
15
|
+
*/
|
|
16
|
+
export declare const createConfig: (config?: BottomAppBarConfig) => BottomAppBarConfig;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* FAB position constants for Bottom App Bar
|
|
3
|
+
*/
|
|
4
|
+
export declare const FAB_POSITIONS: {
|
|
5
|
+
readonly CENTER: "center";
|
|
6
|
+
readonly END: "end";
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Default transition duration for show/hide animations
|
|
10
|
+
*/
|
|
11
|
+
export declare const DEFAULT_TRANSITION_DURATION = 300;
|
|
12
|
+
/**
|
|
13
|
+
* CSS class names used in the bottom app bar component
|
|
14
|
+
*/
|
|
15
|
+
export declare const BOTTOM_APP_BAR_CLASSES: {
|
|
16
|
+
readonly ROOT: "bottom-app-bar";
|
|
17
|
+
readonly ACTIONS: "bottom-app-bar-actions";
|
|
18
|
+
readonly FAB_CONTAINER: "bottom-app-bar-fab";
|
|
19
|
+
readonly HIDDEN: "bottom-app-bar--hidden";
|
|
20
|
+
readonly FAB_CENTER: "bottom-app-bar--fab-center";
|
|
21
|
+
readonly FAB_END: "bottom-app-bar--fab-end";
|
|
22
|
+
};
|
package/{src/components/bottom-app-bar/index.ts → dist/components/bottom-app-bar/index.d.ts}
RENAMED
|
@@ -1,17 +1,8 @@
|
|
|
1
|
-
// src/components/bottom-app-bar/index.ts
|
|
2
1
|
/**
|
|
3
2
|
* @module components/bottom-app-bar
|
|
4
3
|
* @description Bottom app bar component for mobile interfaces
|
|
5
4
|
*/
|
|
6
|
-
|
|
7
5
|
import { createBottomAppBar } from './bottom-app-bar';
|
|
8
|
-
|
|
9
6
|
export default createBottomAppBar;
|
|
10
7
|
export { createBottomAppBar };
|
|
11
8
|
export type { BottomAppBarConfig, BottomAppBar } from './types';
|
|
12
|
-
|
|
13
|
-
// Export position constants for convenience and backward compatibility
|
|
14
|
-
export const FAB_POSITIONS = {
|
|
15
|
-
CENTER: 'center',
|
|
16
|
-
END: 'end'
|
|
17
|
-
} as const;
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module components/bottom-app-bar
|
|
3
|
+
* @description Type definitions for Bottom App Bar component
|
|
4
|
+
*/
|
|
5
|
+
import { ElementComponent } from '../../core/compose';
|
|
6
|
+
/**
|
|
7
|
+
* FAB position type for Bottom App Bar
|
|
8
|
+
* @category Components
|
|
9
|
+
*/
|
|
10
|
+
export type FabPosition = 'center' | 'end';
|
|
11
|
+
/**
|
|
12
|
+
* Configuration options for Bottom App Bar component
|
|
13
|
+
* @category Components
|
|
14
|
+
*/
|
|
15
|
+
export interface BottomAppBarConfig {
|
|
16
|
+
/**
|
|
17
|
+
* Element to use for the container
|
|
18
|
+
* @default 'div'
|
|
19
|
+
*/
|
|
20
|
+
tag?: string;
|
|
21
|
+
/**
|
|
22
|
+
* Whether to show FAB in the bottom bar
|
|
23
|
+
* @default false
|
|
24
|
+
*/
|
|
25
|
+
hasFab?: boolean;
|
|
26
|
+
/**
|
|
27
|
+
* FAB position in bottom bar
|
|
28
|
+
* @default 'end'
|
|
29
|
+
*/
|
|
30
|
+
fabPosition?: FabPosition;
|
|
31
|
+
/**
|
|
32
|
+
* Additional CSS classes to apply
|
|
33
|
+
*/
|
|
34
|
+
class?: string;
|
|
35
|
+
/**
|
|
36
|
+
* Whether to enable auto-hide on scroll
|
|
37
|
+
* @default false
|
|
38
|
+
*/
|
|
39
|
+
autoHide?: boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Transition duration for show/hide in ms
|
|
42
|
+
* @default 300
|
|
43
|
+
*/
|
|
44
|
+
transitionDuration?: number;
|
|
45
|
+
/**
|
|
46
|
+
* Optional callback when scrolling shows/hides the bar
|
|
47
|
+
*/
|
|
48
|
+
onVisibilityChange?: (visible: boolean) => void;
|
|
49
|
+
/**
|
|
50
|
+
* Component prefix for class names
|
|
51
|
+
* @default 'mtrl'
|
|
52
|
+
*/
|
|
53
|
+
prefix?: string;
|
|
54
|
+
/**
|
|
55
|
+
* Component name for class generation
|
|
56
|
+
*/
|
|
57
|
+
componentName?: string;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Bottom App Bar component interface
|
|
61
|
+
* @category Components
|
|
62
|
+
*/
|
|
63
|
+
export interface BottomAppBar extends ElementComponent {
|
|
64
|
+
/**
|
|
65
|
+
* Adds an action button to the bottom bar
|
|
66
|
+
* @param {HTMLElement} button - Button element to add
|
|
67
|
+
* @returns {BottomAppBar} BottomAppBar instance for chaining
|
|
68
|
+
*/
|
|
69
|
+
addAction: (button: HTMLElement) => BottomAppBar;
|
|
70
|
+
/**
|
|
71
|
+
* Adds a floating action button to the bottom bar
|
|
72
|
+
* @param {HTMLElement} fab - FAB element to add
|
|
73
|
+
* @returns {BottomAppBar} BottomAppBar instance for chaining
|
|
74
|
+
*/
|
|
75
|
+
addFab: (fab: HTMLElement) => BottomAppBar;
|
|
76
|
+
/**
|
|
77
|
+
* Shows the bottom bar
|
|
78
|
+
* @returns {BottomAppBar} BottomAppBar instance for chaining
|
|
79
|
+
*/
|
|
80
|
+
show: () => BottomAppBar;
|
|
81
|
+
/**
|
|
82
|
+
* Hides the bottom bar
|
|
83
|
+
* @returns {BottomAppBar} BottomAppBar instance for chaining
|
|
84
|
+
*/
|
|
85
|
+
hide: () => BottomAppBar;
|
|
86
|
+
/**
|
|
87
|
+
* Checks if the bottom bar is visible
|
|
88
|
+
* @returns {boolean} Whether the bottom bar is visible
|
|
89
|
+
*/
|
|
90
|
+
isVisible: () => boolean;
|
|
91
|
+
/**
|
|
92
|
+
* Get the actions container element
|
|
93
|
+
* @returns {HTMLElement} Actions container element
|
|
94
|
+
*/
|
|
95
|
+
getActionsContainer: () => HTMLElement;
|
|
96
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ButtonComponent } from './types';
|
|
2
|
+
/**
|
|
3
|
+
* API configuration options for button component
|
|
4
|
+
* @category Components
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
interface ApiOptions {
|
|
8
|
+
disabled: {
|
|
9
|
+
enable: () => void;
|
|
10
|
+
disable: () => void;
|
|
11
|
+
};
|
|
12
|
+
lifecycle: {
|
|
13
|
+
destroy: () => void;
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Component with required elements and methods for API enhancement
|
|
18
|
+
* @category Components
|
|
19
|
+
* @internal
|
|
20
|
+
*/
|
|
21
|
+
interface ComponentWithElements {
|
|
22
|
+
element: HTMLElement;
|
|
23
|
+
text: {
|
|
24
|
+
setText: (content: string) => any;
|
|
25
|
+
getText: () => string;
|
|
26
|
+
getElement: () => HTMLElement | null;
|
|
27
|
+
};
|
|
28
|
+
icon: {
|
|
29
|
+
setIcon: (html: string) => any;
|
|
30
|
+
getIcon: () => string;
|
|
31
|
+
getElement: () => HTMLElement | null;
|
|
32
|
+
};
|
|
33
|
+
getClass: (name: string) => string;
|
|
34
|
+
componentName?: string;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Enhances a button component with API methods.
|
|
38
|
+
* This follows the higher-order function pattern to add public API methods
|
|
39
|
+
* to the component, making them available to the end user.
|
|
40
|
+
*
|
|
41
|
+
* @param {ApiOptions} options - API configuration options
|
|
42
|
+
* @returns {Function} Higher-order function that adds API methods to component
|
|
43
|
+
* @category Components
|
|
44
|
+
* @internal This is an internal utility for the Button component
|
|
45
|
+
*/
|
|
46
|
+
export declare const withAPI: ({ disabled, lifecycle }: ApiOptions) => (component: ComponentWithElements) => ButtonComponent;
|
|
47
|
+
export {};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { ButtonConfig } from './types';
|
|
2
|
+
/**
|
|
3
|
+
* Creates a new Button component with the specified configuration.
|
|
4
|
+
*
|
|
5
|
+
* The Button component implements support for different variants, states, and features.
|
|
6
|
+
* It follows accessibility best practices and provides a rich API for state management.
|
|
7
|
+
*
|
|
8
|
+
* The Button component is created using a functional composition pattern,
|
|
9
|
+
* applying various features through the pipe function. This approach allows
|
|
10
|
+
* for flexible and modular component construction.
|
|
11
|
+
*
|
|
12
|
+
* @param {ButtonConfig} config - Configuration options for the button
|
|
13
|
+
* This can include text content, icon options, variant styling, disabled state,
|
|
14
|
+
* and other button properties. See {@link ButtonConfig} for available options.
|
|
15
|
+
*
|
|
16
|
+
* @returns {ButtonComponent} A fully configured button component instance with
|
|
17
|
+
* all requested features applied. The returned component has methods for
|
|
18
|
+
* manipulation, event handling, and lifecycle management.
|
|
19
|
+
*
|
|
20
|
+
* @throws {Error} Throws an error if button creation fails for any reason
|
|
21
|
+
*
|
|
22
|
+
* @category Components
|
|
23
|
+
*/
|
|
24
|
+
declare const createButton: (config?: ButtonConfig) => any;
|
|
25
|
+
export default createButton;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { ButtonConfig } from './types';
|
|
2
|
+
/**
|
|
3
|
+
* Default configuration for the Button component.
|
|
4
|
+
* These values will be used when not explicitly specified by the user.
|
|
5
|
+
*
|
|
6
|
+
* @category Components
|
|
7
|
+
*/
|
|
8
|
+
export declare const defaultConfig: ButtonConfig;
|
|
9
|
+
/**
|
|
10
|
+
* Creates the base configuration for Button component by merging user-provided
|
|
11
|
+
* config with default values.
|
|
12
|
+
*
|
|
13
|
+
* @param {ButtonConfig} config - User provided configuration
|
|
14
|
+
* @returns {ButtonConfig} Complete configuration with defaults applied
|
|
15
|
+
* @category Components
|
|
16
|
+
* @internal
|
|
17
|
+
*/
|
|
18
|
+
export declare const createBaseConfig: (config?: ButtonConfig) => ButtonConfig;
|
|
19
|
+
/**
|
|
20
|
+
* Generates element configuration for the Button component.
|
|
21
|
+
* This function creates the necessary attributes and configuration
|
|
22
|
+
* for the DOM element creation process.
|
|
23
|
+
*
|
|
24
|
+
* @param {ButtonConfig} config - Button configuration
|
|
25
|
+
* @returns {Object} Element configuration object for withElement
|
|
26
|
+
* @category Components
|
|
27
|
+
* @internal
|
|
28
|
+
*/
|
|
29
|
+
export declare const getElementConfig: (config: ButtonConfig) => {
|
|
30
|
+
tag: string;
|
|
31
|
+
componentName: string;
|
|
32
|
+
attrs: Record<string, any>;
|
|
33
|
+
className: string[];
|
|
34
|
+
rawClass: string | string[];
|
|
35
|
+
html: string;
|
|
36
|
+
text: string;
|
|
37
|
+
forwardEvents: Record<string, boolean | ((component: any, event: Event) => boolean)>;
|
|
38
|
+
interactive: boolean;
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* Creates API configuration for the Button component.
|
|
42
|
+
* This connects the core component features (like disabled state)
|
|
43
|
+
* to the public API methods exposed to users.
|
|
44
|
+
*
|
|
45
|
+
* @param {Object} comp - Component with disabled and lifecycle features
|
|
46
|
+
* @returns {Object} API configuration object
|
|
47
|
+
* @category Components
|
|
48
|
+
* @internal
|
|
49
|
+
*/
|
|
50
|
+
export declare const getApiConfig: (comp: any) => {
|
|
51
|
+
disabled: {
|
|
52
|
+
enable: () => any;
|
|
53
|
+
disable: () => any;
|
|
54
|
+
};
|
|
55
|
+
lifecycle: {
|
|
56
|
+
destroy: () => any;
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
export default defaultConfig;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Button variants
|
|
3
|
+
*/
|
|
4
|
+
export declare const BUTTON_VARIANTS: {
|
|
5
|
+
/** Primary action button with solid background (high emphasis) */
|
|
6
|
+
readonly FILLED: "filled";
|
|
7
|
+
/** Secondary action button with medium emphasis */
|
|
8
|
+
readonly TONAL: "tonal";
|
|
9
|
+
/** Button with outline border and transparent background */
|
|
10
|
+
readonly OUTLINED: "outlined";
|
|
11
|
+
/** Button with slight elevation/shadow */
|
|
12
|
+
readonly ELEVATED: "elevated";
|
|
13
|
+
/** Button that appears as text without background or border (low emphasis) */
|
|
14
|
+
readonly TEXT: "text";
|
|
15
|
+
};
|
|
16
|
+
/**
|
|
17
|
+
* Default button types
|
|
18
|
+
*/
|
|
19
|
+
export declare const BUTTON_TYPES: {
|
|
20
|
+
readonly BUTTON: "button";
|
|
21
|
+
readonly SUBMIT: "submit";
|
|
22
|
+
readonly RESET: "reset";
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* CSS classes used by the button component
|
|
26
|
+
*/
|
|
27
|
+
export declare const BUTTON_CLASSES: {
|
|
28
|
+
readonly ROOT: "button";
|
|
29
|
+
readonly ICON: "button-icon";
|
|
30
|
+
readonly TEXT: "button-text";
|
|
31
|
+
readonly CIRCULAR: "button-circular";
|
|
32
|
+
readonly ACTIVE: "button-active";
|
|
33
|
+
readonly DISABLED: "button-disabled";
|
|
34
|
+
};
|
|
35
|
+
/**
|
|
36
|
+
* Default ripple effect configuration
|
|
37
|
+
* Enhanced for better visibility
|
|
38
|
+
*/
|
|
39
|
+
export declare const DEFAULT_RIPPLE_CONFIG: {
|
|
40
|
+
readonly DURATION: 450;
|
|
41
|
+
readonly TIMING: "cubic-bezier(0.4, 0.0, 0.2, 1)";
|
|
42
|
+
readonly OPACITY: readonly ["0.7", "0"];
|
|
43
|
+
};
|