mtrl 0.3.8 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/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 +72 -0
- package/dist/components/progress/constants.d.ts +139 -0
- package/dist/components/progress/features/canvas.d.ts +32 -0
- package/dist/components/progress/features/circular.d.ts +9 -0
- package/dist/components/progress/features/index.d.ts +8 -0
- package/dist/components/progress/features/linear.d.ts +9 -0
- package/dist/components/progress/features/resize-observer.d.ts +5 -0
- package/dist/components/progress/features/state.d.ts +38 -0
- package/dist/components/progress/features.d.ts +40 -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 +272 -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/canvas/index.d.ts +5 -0
- package/dist/core/canvas/resize.d.ts +14 -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} +35 -83
- package/dist/core/config.d.ts +130 -0
- package/dist/core/dom/attributes.d.ts +20 -0
- package/dist/core/dom/classes.d.ts +52 -0
- package/dist/core/dom/create.d.ts +154 -0
- package/dist/core/dom/events.d.ts +69 -0
- package/dist/core/dom/index.d.ts +6 -0
- 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 +18 -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/theme.d.ts +38 -0
- package/dist/core/utils/validate.d.ts +73 -0
- package/dist/index.cjs +64 -0
- package/dist/index.cjs.map +291 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.js +53 -14854
- package/dist/index.js.map +291 -0
- package/dist/package.json +39 -0
- package/dist/styles.css +7 -0
- package/package.json +23 -4
- 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 -230
- package/src/components/menu/config.ts +0 -127
- package/src/components/menu/features/anchor.ts +0 -394
- package/src/components/menu/features/controller.ts +0 -1423
- package/src/components/menu/features/index.ts +0 -13
- package/src/components/menu/features/position.ts +0 -353
- package/src/components/menu/menu.ts +0 -121
- package/src/components/menu/types.ts +0 -392
- 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 -331
- 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/attributes.ts +0 -33
- 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/index.ts +0 -10
- 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 -90
- 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 -242
- 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 -272
- 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
|
@@ -1,615 +0,0 @@
|
|
|
1
|
-
// src/components/fab/types.ts
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* FAB variants following Material Design 3 guidelines
|
|
5
|
-
*
|
|
6
|
-
* Material Design 3 offers different color variants for the FAB
|
|
7
|
-
* to match visual hierarchy and application color schemes.
|
|
8
|
-
*
|
|
9
|
-
* @category Components
|
|
10
|
-
* @remarks
|
|
11
|
-
* - primary: Uses the primary color, highest emphasis (default)
|
|
12
|
-
* - secondary: Uses the secondary color, medium emphasis
|
|
13
|
-
* - tertiary: Uses the tertiary color, lower emphasis
|
|
14
|
-
* - surface: Uses the surface color with an outline, lowest emphasis
|
|
15
|
-
*/
|
|
16
|
-
export type FabVariant = 'primary' | 'secondary' | 'tertiary' | 'surface';
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* FAB size variants
|
|
20
|
-
*
|
|
21
|
-
* Material Design 3 defines multiple size options for FABs to accommodate
|
|
22
|
-
* different use cases and screen sizes.
|
|
23
|
-
*
|
|
24
|
-
* @category Components
|
|
25
|
-
* @remarks
|
|
26
|
-
* - small: 40px diameter, for compact interfaces or secondary actions
|
|
27
|
-
* - default: 56px diameter, for standard primary actions (default)
|
|
28
|
-
* - large: 96px diameter, for emphasis or touch-focused interfaces
|
|
29
|
-
*/
|
|
30
|
-
export type FabSize = 'small' | 'default' | 'large';
|
|
31
|
-
|
|
32
|
-
/**
|
|
33
|
-
* FAB position options
|
|
34
|
-
*
|
|
35
|
-
* Predefined positions for the FAB when used as a floating element.
|
|
36
|
-
* These positions automatically apply appropriate margins and positioning.
|
|
37
|
-
*
|
|
38
|
-
* @category Components
|
|
39
|
-
* @remarks
|
|
40
|
-
* Common patterns:
|
|
41
|
-
* - bottom-right: Most common position for primary actions
|
|
42
|
-
* - bottom-left: Alternative position on left-to-right interfaces
|
|
43
|
-
* - top-right: Used for actions related to top content
|
|
44
|
-
* - top-left: Less common but available for special layouts
|
|
45
|
-
*/
|
|
46
|
-
export type FabPosition = 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left';
|
|
47
|
-
|
|
48
|
-
/**
|
|
49
|
-
* Configuration interface for the FAB component
|
|
50
|
-
*
|
|
51
|
-
* Comprehensive options for creating and customizing a Floating Action Button
|
|
52
|
-
* according to Material Design 3 guidelines.
|
|
53
|
-
*
|
|
54
|
-
* @category Components
|
|
55
|
-
* @see https://m3.material.io/components/floating-action-button/overview
|
|
56
|
-
*/
|
|
57
|
-
export interface FabConfig {
|
|
58
|
-
/**
|
|
59
|
-
* FAB variant that determines visual styling
|
|
60
|
-
*
|
|
61
|
-
* The color variant affects the FAB's background color, icon color, and elevation.
|
|
62
|
-
*
|
|
63
|
-
* @default 'primary'
|
|
64
|
-
*
|
|
65
|
-
* @example
|
|
66
|
-
* ```typescript
|
|
67
|
-
* // Create a tertiary FAB
|
|
68
|
-
* createFab({ variant: 'tertiary', icon: '<svg>...</svg>' })
|
|
69
|
-
* ```
|
|
70
|
-
*/
|
|
71
|
-
variant?: FabVariant | string;
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
* FAB size variant
|
|
75
|
-
*
|
|
76
|
-
* Controls the diameter of the FAB and the appropriate icon size.
|
|
77
|
-
*
|
|
78
|
-
* @default 'default'
|
|
79
|
-
*
|
|
80
|
-
* @example
|
|
81
|
-
* ```typescript
|
|
82
|
-
* // Create a small FAB for a secondary action
|
|
83
|
-
* createFab({ size: 'small', icon: '<svg>...</svg>' })
|
|
84
|
-
*
|
|
85
|
-
* // Create a large FAB for emphasis
|
|
86
|
-
* createFab({ size: 'large', icon: '<svg>...</svg>' })
|
|
87
|
-
* ```
|
|
88
|
-
*/
|
|
89
|
-
size?: FabSize | string;
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* Whether the FAB is initially disabled
|
|
93
|
-
*
|
|
94
|
-
* When disabled, the FAB will have a visually muted appearance
|
|
95
|
-
* and won't respond to user interactions.
|
|
96
|
-
*
|
|
97
|
-
* @default false
|
|
98
|
-
*
|
|
99
|
-
* @example
|
|
100
|
-
* ```typescript
|
|
101
|
-
* // Create a disabled FAB
|
|
102
|
-
* const fab = createFab({
|
|
103
|
-
* icon: '<svg>...</svg>',
|
|
104
|
-
* disabled: true
|
|
105
|
-
* });
|
|
106
|
-
*
|
|
107
|
-
* // Later enable it when content is ready
|
|
108
|
-
* loadContent().then(() => {
|
|
109
|
-
* fab.enable();
|
|
110
|
-
* });
|
|
111
|
-
* ```
|
|
112
|
-
*/
|
|
113
|
-
disabled?: boolean;
|
|
114
|
-
|
|
115
|
-
/**
|
|
116
|
-
* FAB icon HTML content
|
|
117
|
-
*
|
|
118
|
-
* The icon content can be any valid HTML, but typically contains an SVG icon
|
|
119
|
-
* or a Material Icons ligature. Icons should follow Material Design sizing guidelines
|
|
120
|
-
* (24x24dp for most sizes, scaled appropriately for small or large variants).
|
|
121
|
-
*
|
|
122
|
-
* @example
|
|
123
|
-
* ```typescript
|
|
124
|
-
* // Using an SVG icon
|
|
125
|
-
* createFab({
|
|
126
|
-
* icon: '<svg viewBox="0 0 24 24"><path d="M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"/></svg>'
|
|
127
|
-
* });
|
|
128
|
-
*
|
|
129
|
-
* // Using a Material Icons ligature
|
|
130
|
-
* createFab({
|
|
131
|
-
* icon: '<span class="material-icons">add</span>'
|
|
132
|
-
* });
|
|
133
|
-
* ```
|
|
134
|
-
*/
|
|
135
|
-
icon?: string;
|
|
136
|
-
|
|
137
|
-
/**
|
|
138
|
-
* Icon size in pixels or other CSS units
|
|
139
|
-
*
|
|
140
|
-
* Allows customizing the icon size beyond the default size for the selected FAB size.
|
|
141
|
-
*
|
|
142
|
-
* @example
|
|
143
|
-
* ```typescript
|
|
144
|
-
* // Create a FAB with a larger icon
|
|
145
|
-
* createFab({
|
|
146
|
-
* icon: '<svg>...</svg>',
|
|
147
|
-
* iconSize: '32px'
|
|
148
|
-
* });
|
|
149
|
-
* ```
|
|
150
|
-
*/
|
|
151
|
-
iconSize?: string;
|
|
152
|
-
|
|
153
|
-
/**
|
|
154
|
-
* Additional CSS classes to add to the FAB
|
|
155
|
-
*
|
|
156
|
-
* Custom classes for styling or identifying the FAB.
|
|
157
|
-
* These classes will be applied in addition to the component's built-in classes.
|
|
158
|
-
*
|
|
159
|
-
* @example
|
|
160
|
-
* ```typescript
|
|
161
|
-
* createFab({
|
|
162
|
-
* icon: '<svg>...</svg>',
|
|
163
|
-
* class: 'home-fab pulse-animation'
|
|
164
|
-
* });
|
|
165
|
-
* ```
|
|
166
|
-
*/
|
|
167
|
-
class?: string;
|
|
168
|
-
|
|
169
|
-
/**
|
|
170
|
-
* Button value attribute
|
|
171
|
-
*
|
|
172
|
-
* Sets the HTML value attribute of the button element, useful when using
|
|
173
|
-
* the FAB in a form context.
|
|
174
|
-
*
|
|
175
|
-
* @example
|
|
176
|
-
* ```typescript
|
|
177
|
-
* createFab({
|
|
178
|
-
* icon: '<svg>...</svg>',
|
|
179
|
-
* type: 'submit',
|
|
180
|
-
* value: 'form-submitted'
|
|
181
|
-
* });
|
|
182
|
-
* ```
|
|
183
|
-
*/
|
|
184
|
-
value?: string;
|
|
185
|
-
|
|
186
|
-
/**
|
|
187
|
-
* Position of the FAB on the screen
|
|
188
|
-
*
|
|
189
|
-
* Configures the FAB for floating positioning on the screen.
|
|
190
|
-
* Applies appropriate CSS classes to position the FAB in one of the corners.
|
|
191
|
-
*
|
|
192
|
-
* @example
|
|
193
|
-
* ```typescript
|
|
194
|
-
* // Position in the bottom-right corner (common for primary actions)
|
|
195
|
-
* createFab({
|
|
196
|
-
* icon: '<svg>...</svg>',
|
|
197
|
-
* position: 'bottom-right'
|
|
198
|
-
* });
|
|
199
|
-
*
|
|
200
|
-
* // Position in the top-left corner
|
|
201
|
-
* createFab({
|
|
202
|
-
* icon: '<svg>...</svg>',
|
|
203
|
-
* position: 'top-left'
|
|
204
|
-
* });
|
|
205
|
-
* ```
|
|
206
|
-
*/
|
|
207
|
-
position?: FabPosition | string;
|
|
208
|
-
|
|
209
|
-
/**
|
|
210
|
-
* Button type attribute
|
|
211
|
-
*
|
|
212
|
-
* Sets the HTML type attribute of the button element.
|
|
213
|
-
*
|
|
214
|
-
* @default 'button'
|
|
215
|
-
*
|
|
216
|
-
* @example
|
|
217
|
-
* ```typescript
|
|
218
|
-
* // Use as a form submit button
|
|
219
|
-
* createFab({
|
|
220
|
-
* icon: '<svg>...</svg>',
|
|
221
|
-
* type: 'submit'
|
|
222
|
-
* });
|
|
223
|
-
* ```
|
|
224
|
-
*/
|
|
225
|
-
type?: 'button' | 'submit' | 'reset';
|
|
226
|
-
|
|
227
|
-
/**
|
|
228
|
-
* Accessible label for screen readers
|
|
229
|
-
*
|
|
230
|
-
* Sets the aria-label attribute for accessibility. Required for FABs since
|
|
231
|
-
* they typically contain only an icon without visible text.
|
|
232
|
-
*
|
|
233
|
-
* @example
|
|
234
|
-
* ```typescript
|
|
235
|
-
* createFab({
|
|
236
|
-
* icon: '<svg>...</svg>',
|
|
237
|
-
* ariaLabel: 'Add new item'
|
|
238
|
-
* });
|
|
239
|
-
* ```
|
|
240
|
-
*/
|
|
241
|
-
ariaLabel?: string;
|
|
242
|
-
|
|
243
|
-
/**
|
|
244
|
-
* Whether to enable ripple effect
|
|
245
|
-
*
|
|
246
|
-
* The ripple effect provides visual feedback when the user interacts
|
|
247
|
-
* with the FAB. Follows Material Design interaction patterns.
|
|
248
|
-
*
|
|
249
|
-
* @default true
|
|
250
|
-
*
|
|
251
|
-
* @example
|
|
252
|
-
* ```typescript
|
|
253
|
-
* // Disable the ripple effect
|
|
254
|
-
* createFab({
|
|
255
|
-
* icon: '<svg>...</svg>',
|
|
256
|
-
* ripple: false
|
|
257
|
-
* });
|
|
258
|
-
* ```
|
|
259
|
-
*/
|
|
260
|
-
ripple?: boolean;
|
|
261
|
-
|
|
262
|
-
/**
|
|
263
|
-
* Component prefix for class names
|
|
264
|
-
*
|
|
265
|
-
* The prefix used for BEM-style class names.
|
|
266
|
-
*
|
|
267
|
-
* @default 'mtrl'
|
|
268
|
-
*
|
|
269
|
-
* @example
|
|
270
|
-
* ```typescript
|
|
271
|
-
* // Use a custom prefix for class names
|
|
272
|
-
* createFab({
|
|
273
|
-
* icon: '<svg>...</svg>',
|
|
274
|
-
* prefix: 'app'
|
|
275
|
-
* });
|
|
276
|
-
* // Results in classes like: 'app-fab app-fab--primary'
|
|
277
|
-
* ```
|
|
278
|
-
*/
|
|
279
|
-
prefix?: string;
|
|
280
|
-
|
|
281
|
-
/**
|
|
282
|
-
* Component name used in class generation
|
|
283
|
-
*
|
|
284
|
-
* @internal
|
|
285
|
-
*/
|
|
286
|
-
componentName?: string;
|
|
287
|
-
|
|
288
|
-
/**
|
|
289
|
-
* Ripple effect configuration
|
|
290
|
-
*
|
|
291
|
-
* Fine-grained control over the ripple effect appearance and behavior.
|
|
292
|
-
*
|
|
293
|
-
* @example
|
|
294
|
-
* ```typescript
|
|
295
|
-
* // Customize ripple effect
|
|
296
|
-
* createFab({
|
|
297
|
-
* icon: '<svg>...</svg>',
|
|
298
|
-
* rippleConfig: {
|
|
299
|
-
* duration: 400,
|
|
300
|
-
* timing: 'ease-out',
|
|
301
|
-
* opacity: ['0.5', '0']
|
|
302
|
-
* }
|
|
303
|
-
* });
|
|
304
|
-
* ```
|
|
305
|
-
*/
|
|
306
|
-
rippleConfig?: {
|
|
307
|
-
/** Duration of the ripple animation in milliseconds */
|
|
308
|
-
duration?: number;
|
|
309
|
-
/** Timing function for the ripple animation */
|
|
310
|
-
timing?: string;
|
|
311
|
-
/** Opacity values for ripple start and end [start, end] */
|
|
312
|
-
opacity?: [string, string];
|
|
313
|
-
};
|
|
314
|
-
|
|
315
|
-
/**
|
|
316
|
-
* Whether to show the FAB with an entrance animation
|
|
317
|
-
*
|
|
318
|
-
* When true, the FAB will animate into view when added to the DOM.
|
|
319
|
-
*
|
|
320
|
-
* @default false
|
|
321
|
-
*
|
|
322
|
-
* @example
|
|
323
|
-
* ```typescript
|
|
324
|
-
* // Create an animated entrance FAB
|
|
325
|
-
* createFab({
|
|
326
|
-
* icon: '<svg>...</svg>',
|
|
327
|
-
* animate: true
|
|
328
|
-
* });
|
|
329
|
-
* ```
|
|
330
|
-
*/
|
|
331
|
-
animate?: boolean;
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
/**
|
|
335
|
-
* FAB component interface
|
|
336
|
-
*
|
|
337
|
-
* Provides methods for interacting with and manipulating a Floating Action Button.
|
|
338
|
-
*
|
|
339
|
-
* @category Components
|
|
340
|
-
*/
|
|
341
|
-
export interface FabComponent {
|
|
342
|
-
/**
|
|
343
|
-
* The FAB's DOM element
|
|
344
|
-
*
|
|
345
|
-
* Direct access to the underlying button element for DOM manipulation.
|
|
346
|
-
*/
|
|
347
|
-
element: HTMLButtonElement;
|
|
348
|
-
|
|
349
|
-
/**
|
|
350
|
-
* API for managing FAB icons
|
|
351
|
-
*
|
|
352
|
-
* Access to low-level icon methods and elements.
|
|
353
|
-
*/
|
|
354
|
-
icon: {
|
|
355
|
-
/** Sets the icon HTML content */
|
|
356
|
-
setIcon: (html: string) => any;
|
|
357
|
-
/** Gets the current icon HTML content */
|
|
358
|
-
getIcon: () => string;
|
|
359
|
-
/** Gets the icon DOM element */
|
|
360
|
-
getElement: () => HTMLElement | null;
|
|
361
|
-
};
|
|
362
|
-
|
|
363
|
-
/**
|
|
364
|
-
* API for managing disabled state
|
|
365
|
-
*
|
|
366
|
-
* Access to low-level disabled state methods.
|
|
367
|
-
*/
|
|
368
|
-
disabled: {
|
|
369
|
-
/** Enables the FAB */
|
|
370
|
-
enable: () => void;
|
|
371
|
-
/** Disables the FAB */
|
|
372
|
-
disable: () => void;
|
|
373
|
-
/** Checks if the FAB is disabled */
|
|
374
|
-
isDisabled: () => boolean;
|
|
375
|
-
};
|
|
376
|
-
|
|
377
|
-
/**
|
|
378
|
-
* API for managing component lifecycle
|
|
379
|
-
*
|
|
380
|
-
* Access to low-level lifecycle methods.
|
|
381
|
-
*/
|
|
382
|
-
lifecycle: {
|
|
383
|
-
/** Destroys the component and cleans up resources */
|
|
384
|
-
destroy: () => void;
|
|
385
|
-
};
|
|
386
|
-
|
|
387
|
-
/**
|
|
388
|
-
* Gets a class name with the component's prefix
|
|
389
|
-
*
|
|
390
|
-
* @param name - Base class name
|
|
391
|
-
* @returns Prefixed class name
|
|
392
|
-
*
|
|
393
|
-
* @example
|
|
394
|
-
* ```typescript
|
|
395
|
-
* const fab = createFab({ icon: '<svg>...</svg>' });
|
|
396
|
-
* const className = fab.getClass('icon'); // Returns 'mtrl-fab__icon'
|
|
397
|
-
* ```
|
|
398
|
-
*/
|
|
399
|
-
getClass: (name: string) => string;
|
|
400
|
-
|
|
401
|
-
/**
|
|
402
|
-
* Gets the FAB's value attribute
|
|
403
|
-
*
|
|
404
|
-
* @returns FAB value
|
|
405
|
-
*
|
|
406
|
-
* @example
|
|
407
|
-
* ```typescript
|
|
408
|
-
* const fab = createFab({
|
|
409
|
-
* icon: '<svg>...</svg>',
|
|
410
|
-
* value: 'action-button'
|
|
411
|
-
* });
|
|
412
|
-
* const value = fab.getValue(); // Returns 'action-button'
|
|
413
|
-
* ```
|
|
414
|
-
*/
|
|
415
|
-
getValue: () => string;
|
|
416
|
-
|
|
417
|
-
/**
|
|
418
|
-
* Sets the FAB's value attribute
|
|
419
|
-
*
|
|
420
|
-
* @param value - New value
|
|
421
|
-
* @returns The FAB component for chaining
|
|
422
|
-
*
|
|
423
|
-
* @example
|
|
424
|
-
* ```typescript
|
|
425
|
-
* const fab = createFab({ icon: '<svg>...</svg>' });
|
|
426
|
-
* fab.setValue('complete');
|
|
427
|
-
* ```
|
|
428
|
-
*/
|
|
429
|
-
setValue: (value: string) => FabComponent;
|
|
430
|
-
|
|
431
|
-
/**
|
|
432
|
-
* Enables the FAB (removes disabled attribute)
|
|
433
|
-
*
|
|
434
|
-
* Makes the FAB interactive and visually enabled.
|
|
435
|
-
*
|
|
436
|
-
* @returns The FAB component for chaining
|
|
437
|
-
*
|
|
438
|
-
* @example
|
|
439
|
-
* ```typescript
|
|
440
|
-
* // Enable a previously disabled FAB
|
|
441
|
-
* fab.enable();
|
|
442
|
-
* ```
|
|
443
|
-
*/
|
|
444
|
-
enable: () => FabComponent;
|
|
445
|
-
|
|
446
|
-
/**
|
|
447
|
-
* Disables the FAB (adds disabled attribute)
|
|
448
|
-
*
|
|
449
|
-
* Makes the FAB non-interactive and visually disabled.
|
|
450
|
-
*
|
|
451
|
-
* @returns The FAB component for chaining
|
|
452
|
-
*
|
|
453
|
-
* @example
|
|
454
|
-
* ```typescript
|
|
455
|
-
* // Disable the FAB during an async operation
|
|
456
|
-
* fab.disable();
|
|
457
|
-
* await saveData();
|
|
458
|
-
* fab.enable();
|
|
459
|
-
* ```
|
|
460
|
-
*/
|
|
461
|
-
disable: () => FabComponent;
|
|
462
|
-
|
|
463
|
-
/**
|
|
464
|
-
* Sets the FAB's icon
|
|
465
|
-
*
|
|
466
|
-
* @param icon - Icon HTML content
|
|
467
|
-
* @returns The FAB component for chaining
|
|
468
|
-
*
|
|
469
|
-
* @example
|
|
470
|
-
* ```typescript
|
|
471
|
-
* // Change the icon dynamically
|
|
472
|
-
* fab.setIcon('<svg>...</svg>');
|
|
473
|
-
*
|
|
474
|
-
* // Change to a Material Icons ligature
|
|
475
|
-
* fab.setIcon('<span class="material-icons">edit</span>');
|
|
476
|
-
* ```
|
|
477
|
-
*/
|
|
478
|
-
setIcon: (icon: string) => FabComponent;
|
|
479
|
-
|
|
480
|
-
/**
|
|
481
|
-
* Gets the FAB's icon HTML content
|
|
482
|
-
*
|
|
483
|
-
* @returns Icon HTML
|
|
484
|
-
*
|
|
485
|
-
* @example
|
|
486
|
-
* ```typescript
|
|
487
|
-
* const iconHtml = fab.getIcon();
|
|
488
|
-
* ```
|
|
489
|
-
*/
|
|
490
|
-
getIcon: () => string;
|
|
491
|
-
|
|
492
|
-
/**
|
|
493
|
-
* Sets the FAB's position
|
|
494
|
-
*
|
|
495
|
-
* Positions the FAB in one of the four corners of the viewport.
|
|
496
|
-
*
|
|
497
|
-
* @param position - Position value ('top-right', 'bottom-left', etc.)
|
|
498
|
-
* @returns The FAB component for chaining
|
|
499
|
-
*
|
|
500
|
-
* @example
|
|
501
|
-
* ```typescript
|
|
502
|
-
* // Move the FAB to the bottom-left corner
|
|
503
|
-
* fab.setPosition('bottom-left');
|
|
504
|
-
* ```
|
|
505
|
-
*/
|
|
506
|
-
setPosition: (position: string) => FabComponent;
|
|
507
|
-
|
|
508
|
-
/**
|
|
509
|
-
* Gets the current position of the FAB
|
|
510
|
-
*
|
|
511
|
-
* @returns Current position or null if not positioned
|
|
512
|
-
*
|
|
513
|
-
* @example
|
|
514
|
-
* ```typescript
|
|
515
|
-
* const position = fab.getPosition(); // Returns 'bottom-right', 'top-left', etc.
|
|
516
|
-
* ```
|
|
517
|
-
*/
|
|
518
|
-
getPosition: () => string | null;
|
|
519
|
-
|
|
520
|
-
/**
|
|
521
|
-
* Lowers the FAB (useful for pressed state)
|
|
522
|
-
*
|
|
523
|
-
* Visually lowers the FAB by reducing its elevation,
|
|
524
|
-
* typically used to indicate a pressed or active state.
|
|
525
|
-
*
|
|
526
|
-
* @returns The FAB component for chaining
|
|
527
|
-
*
|
|
528
|
-
* @example
|
|
529
|
-
* ```typescript
|
|
530
|
-
* // Visually lower the FAB when a long operation starts
|
|
531
|
-
* fab.lower();
|
|
532
|
-
* await longOperation();
|
|
533
|
-
* fab.raise();
|
|
534
|
-
* ```
|
|
535
|
-
*/
|
|
536
|
-
lower: () => FabComponent;
|
|
537
|
-
|
|
538
|
-
/**
|
|
539
|
-
* Raises the FAB back to its default elevation
|
|
540
|
-
*
|
|
541
|
-
* Restores the default elevation after it has been lowered.
|
|
542
|
-
*
|
|
543
|
-
* @returns The FAB component for chaining
|
|
544
|
-
*
|
|
545
|
-
* @example
|
|
546
|
-
* ```typescript
|
|
547
|
-
* // Restore normal elevation
|
|
548
|
-
* fab.raise();
|
|
549
|
-
* ```
|
|
550
|
-
*/
|
|
551
|
-
raise: () => FabComponent;
|
|
552
|
-
|
|
553
|
-
/**
|
|
554
|
-
* Destroys the FAB component and cleans up resources
|
|
555
|
-
*
|
|
556
|
-
* Removes event listeners and prepares the component for garbage collection.
|
|
557
|
-
* Call this method when the FAB is no longer needed.
|
|
558
|
-
*
|
|
559
|
-
* @example
|
|
560
|
-
* ```typescript
|
|
561
|
-
* // Clean up when the component is no longer needed
|
|
562
|
-
* fab.destroy();
|
|
563
|
-
* ```
|
|
564
|
-
*/
|
|
565
|
-
destroy: () => void;
|
|
566
|
-
|
|
567
|
-
/**
|
|
568
|
-
* Adds an event listener to the FAB
|
|
569
|
-
*
|
|
570
|
-
* @param event - Event name ('click', 'focus', etc.)
|
|
571
|
-
* @param handler - Event handler function
|
|
572
|
-
* @returns The FAB component for chaining
|
|
573
|
-
*
|
|
574
|
-
* @example
|
|
575
|
-
* ```typescript
|
|
576
|
-
* // Add click handler
|
|
577
|
-
* fab.on('click', () => {
|
|
578
|
-
* console.log('FAB clicked');
|
|
579
|
-
* });
|
|
580
|
-
* ```
|
|
581
|
-
*/
|
|
582
|
-
on: (event: string, handler: Function) => FabComponent;
|
|
583
|
-
|
|
584
|
-
/**
|
|
585
|
-
* Removes an event listener from the FAB
|
|
586
|
-
*
|
|
587
|
-
* @param event - Event name
|
|
588
|
-
* @param handler - Event handler function
|
|
589
|
-
* @returns The FAB component for chaining
|
|
590
|
-
*
|
|
591
|
-
* @example
|
|
592
|
-
* ```typescript
|
|
593
|
-
* // Remove a previously added event handler
|
|
594
|
-
* const handler = () => console.log('Clicked');
|
|
595
|
-
* fab.on('click', handler);
|
|
596
|
-
* // Later...
|
|
597
|
-
* fab.off('click', handler);
|
|
598
|
-
* ```
|
|
599
|
-
*/
|
|
600
|
-
off: (event: string, handler: Function) => FabComponent;
|
|
601
|
-
|
|
602
|
-
/**
|
|
603
|
-
* Adds CSS classes to the FAB element
|
|
604
|
-
*
|
|
605
|
-
* @param classes - One or more class names to add
|
|
606
|
-
* @returns The FAB component for chaining
|
|
607
|
-
*
|
|
608
|
-
* @example
|
|
609
|
-
* ```typescript
|
|
610
|
-
* // Add multiple classes
|
|
611
|
-
* fab.addClass('highlight', 'pulse-animation');
|
|
612
|
-
* ```
|
|
613
|
-
*/
|
|
614
|
-
addClass: (...classes: string[]) => FabComponent;
|
|
615
|
-
}
|
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
// src/components/list/api.ts
|
|
2
|
-
import { BaseComponent, ListComponent, ListItemConfig } from './types';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* API options interface for List component
|
|
6
|
-
*
|
|
7
|
-
* @category Components
|
|
8
|
-
* @internal
|
|
9
|
-
*/
|
|
10
|
-
interface ApiOptions {
|
|
11
|
-
disabled: {
|
|
12
|
-
enable: () => any;
|
|
13
|
-
disable: () => any;
|
|
14
|
-
};
|
|
15
|
-
lifecycle: {
|
|
16
|
-
destroy: () => void;
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* Enhances list component with public API methods
|
|
22
|
-
*
|
|
23
|
-
* Higher-order function that adds the complete public API to the List component,
|
|
24
|
-
* exposing methods for managing items, selection, events, and component state.
|
|
25
|
-
*
|
|
26
|
-
* @param {ApiOptions} options - API configuration
|
|
27
|
-
* @returns {Function} Higher-order function that adds API methods to component
|
|
28
|
-
*
|
|
29
|
-
* @category Components
|
|
30
|
-
* @internal
|
|
31
|
-
*/
|
|
32
|
-
export const withAPI = ({ disabled, lifecycle }: ApiOptions) =>
|
|
33
|
-
(component: BaseComponent): ListComponent => ({
|
|
34
|
-
...component as any,
|
|
35
|
-
element: component.element,
|
|
36
|
-
items: component.items as Map<string, any>,
|
|
37
|
-
selectedItems: component.selectedItems as Set<string>,
|
|
38
|
-
|
|
39
|
-
// Selection management
|
|
40
|
-
getSelected(): string[] {
|
|
41
|
-
return component.getSelected?.() || [];
|
|
42
|
-
},
|
|
43
|
-
|
|
44
|
-
setSelected(ids: string[]): void {
|
|
45
|
-
component.setSelected?.(ids);
|
|
46
|
-
},
|
|
47
|
-
|
|
48
|
-
// Item management
|
|
49
|
-
addItem(itemConfig: ListItemConfig): void {
|
|
50
|
-
component.addItem?.(itemConfig);
|
|
51
|
-
},
|
|
52
|
-
|
|
53
|
-
removeItem(id: string): void {
|
|
54
|
-
component.removeItem?.(id);
|
|
55
|
-
},
|
|
56
|
-
|
|
57
|
-
// Event handling
|
|
58
|
-
on(event: string, handler: Function): ListComponent {
|
|
59
|
-
component.on?.(event, handler);
|
|
60
|
-
return this;
|
|
61
|
-
},
|
|
62
|
-
|
|
63
|
-
off(event: string, handler: Function): ListComponent {
|
|
64
|
-
component.off?.(event, handler);
|
|
65
|
-
return this;
|
|
66
|
-
},
|
|
67
|
-
|
|
68
|
-
// State management
|
|
69
|
-
enable(): ListComponent {
|
|
70
|
-
disabled.enable();
|
|
71
|
-
return this;
|
|
72
|
-
},
|
|
73
|
-
|
|
74
|
-
disable(): ListComponent {
|
|
75
|
-
disabled.disable();
|
|
76
|
-
return this;
|
|
77
|
-
},
|
|
78
|
-
|
|
79
|
-
destroy(): void {
|
|
80
|
-
lifecycle.destroy();
|
|
81
|
-
}
|
|
82
|
-
});
|