placer-toolkit 0.5.1
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/LICENSE.md +9 -0
- package/README.md +66 -0
- package/dist/animations/attention_seekers/bounce.d.ts +16 -0
- package/dist/animations/attention_seekers/bounce.js +45 -0
- package/dist/animations/attention_seekers/flash.d.ts +4 -0
- package/dist/animations/attention_seekers/flash.js +9 -0
- package/dist/animations/attention_seekers/headShake.d.ts +4 -0
- package/dist/animations/attention_seekers/headShake.js +10 -0
- package/dist/animations/attention_seekers/heartBeat.d.ts +4 -0
- package/dist/animations/attention_seekers/heartBeat.js +9 -0
- package/dist/animations/attention_seekers/jello.d.ts +4 -0
- package/dist/animations/attention_seekers/jello.js +17 -0
- package/dist/animations/attention_seekers/pulse.d.ts +4 -0
- package/dist/animations/attention_seekers/pulse.js +7 -0
- package/dist/animations/attention_seekers/rubberBand.d.ts +4 -0
- package/dist/animations/attention_seekers/rubberBand.js +11 -0
- package/dist/animations/attention_seekers/shake.d.ts +4 -0
- package/dist/animations/attention_seekers/shake.js +15 -0
- package/dist/animations/attention_seekers/shakeX.d.ts +4 -0
- package/dist/animations/attention_seekers/shakeX.js +15 -0
- package/dist/animations/attention_seekers/shakeY.d.ts +4 -0
- package/dist/animations/attention_seekers/shakeY.js +15 -0
- package/dist/animations/attention_seekers/swing.d.ts +4 -0
- package/dist/animations/attention_seekers/swing.js +9 -0
- package/dist/animations/attention_seekers/tada.d.ts +4 -0
- package/dist/animations/attention_seekers/tada.js +42 -0
- package/dist/animations/attention_seekers/wobble.d.ts +4 -0
- package/dist/animations/attention_seekers/wobble.js +26 -0
- package/dist/animations/back_entrances/backInDown.d.ts +5 -0
- package/dist/animations/back_entrances/backInDown.js +7 -0
- package/dist/animations/back_entrances/backInLeft.d.ts +5 -0
- package/dist/animations/back_entrances/backInLeft.js +7 -0
- package/dist/animations/back_entrances/backInRight.d.ts +5 -0
- package/dist/animations/back_entrances/backInRight.js +7 -0
- package/dist/animations/back_entrances/backInUp.d.ts +5 -0
- package/dist/animations/back_entrances/backInUp.js +7 -0
- package/dist/animations/back_exits/backOutDown.d.ts +5 -0
- package/dist/animations/back_exits/backOutDown.js +7 -0
- package/dist/animations/back_exits/backOutLeft.d.ts +5 -0
- package/dist/animations/back_exits/backOutLeft.js +7 -0
- package/dist/animations/back_exits/backOutRight.d.ts +5 -0
- package/dist/animations/back_exits/backOutRight.js +7 -0
- package/dist/animations/back_exits/backOutUp.d.ts +5 -0
- package/dist/animations/back_exits/backOutUp.js +7 -0
- package/dist/animations/bouncing_entrances/bounceIn.d.ts +16 -0
- package/dist/animations/bouncing_entrances/bounceIn.js +16 -0
- package/dist/animations/bouncing_entrances/bounceInDown.d.ts +16 -0
- package/dist/animations/bouncing_entrances/bounceInDown.js +22 -0
- package/dist/animations/bouncing_entrances/bounceInLeft.d.ts +16 -0
- package/dist/animations/bouncing_entrances/bounceInLeft.js +22 -0
- package/dist/animations/bouncing_entrances/bounceInRight.d.ts +16 -0
- package/dist/animations/bouncing_entrances/bounceInRight.js +22 -0
- package/dist/animations/bouncing_entrances/bounceInUp.d.ts +16 -0
- package/dist/animations/bouncing_entrances/bounceInUp.js +22 -0
- package/dist/animations/bouncing_exits/bounceOut.d.ts +9 -0
- package/dist/animations/bouncing_exits/bounceOut.js +8 -0
- package/dist/animations/bouncing_exits/bounceOutDown.d.ts +9 -0
- package/dist/animations/bouncing_exits/bounceOutDown.js +20 -0
- package/dist/animations/bouncing_exits/bounceOutLeft.d.ts +5 -0
- package/dist/animations/bouncing_exits/bounceOutLeft.js +14 -0
- package/dist/animations/bouncing_exits/bounceOutRight.d.ts +5 -0
- package/dist/animations/bouncing_exits/bounceOutRight.js +14 -0
- package/dist/animations/bouncing_exits/bounceOutUp.d.ts +9 -0
- package/dist/animations/bouncing_exits/bounceOutUp.js +20 -0
- package/dist/animations/easings/easings.d.ts +31 -0
- package/dist/animations/easings/easings.js +33 -0
- package/dist/animations/fading_entrances/fadeIn.d.ts +4 -0
- package/dist/animations/fading_entrances/fadeIn.js +6 -0
- package/dist/animations/fading_entrances/fadeInBottomLeft.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInBottomLeft.js +6 -0
- package/dist/animations/fading_entrances/fadeInBottomRight.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInBottomRight.js +6 -0
- package/dist/animations/fading_entrances/fadeInDown.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInDown.js +6 -0
- package/dist/animations/fading_entrances/fadeInDownBig.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInDownBig.js +6 -0
- package/dist/animations/fading_entrances/fadeInLeft.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInLeft.js +6 -0
- package/dist/animations/fading_entrances/fadeInLeftBig.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInLeftBig.js +6 -0
- package/dist/animations/fading_entrances/fadeInRight.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInRight.js +6 -0
- package/dist/animations/fading_entrances/fadeInRightBig.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInRightBig.js +6 -0
- package/dist/animations/fading_entrances/fadeInTopLeft.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInTopLeft.js +6 -0
- package/dist/animations/fading_entrances/fadeInTopRight.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInTopRight.js +6 -0
- package/dist/animations/fading_entrances/fadeInUp.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInUp.js +6 -0
- package/dist/animations/fading_entrances/fadeInUpBig.d.ts +5 -0
- package/dist/animations/fading_entrances/fadeInUpBig.js +6 -0
- package/dist/animations/fading_exits/fadeOut.d.ts +4 -0
- package/dist/animations/fading_exits/fadeOut.js +6 -0
- package/dist/animations/fading_exits/fadeOutBottomLeft.d.ts +5 -0
- package/dist/animations/fading_exits/fadeOutBottomLeft.js +6 -0
- package/dist/animations/fading_exits/fadeOutBottomRight.d.ts +5 -0
- package/dist/animations/fading_exits/fadeOutBottomRight.js +6 -0
- package/dist/animations/fading_exits/fadeOutDown.d.ts +9 -0
- package/dist/animations/fading_exits/fadeOutDown.js +6 -0
- package/dist/animations/fading_exits/fadeOutDownBig.d.ts +9 -0
- package/dist/animations/fading_exits/fadeOutDownBig.js +6 -0
- package/dist/animations/fading_exits/fadeOutLeft.d.ts +9 -0
- package/dist/animations/fading_exits/fadeOutLeft.js +6 -0
- package/dist/animations/fading_exits/fadeOutLeftBig.d.ts +9 -0
- package/dist/animations/fading_exits/fadeOutLeftBig.js +6 -0
- package/dist/animations/fading_exits/fadeOutRight.d.ts +9 -0
- package/dist/animations/fading_exits/fadeOutRight.js +6 -0
- package/dist/animations/fading_exits/fadeOutRightBig.d.ts +9 -0
- package/dist/animations/fading_exits/fadeOutRightBig.js +6 -0
- package/dist/animations/fading_exits/fadeOutTopLeft.d.ts +5 -0
- package/dist/animations/fading_exits/fadeOutTopLeft.js +6 -0
- package/dist/animations/fading_exits/fadeOutTopRight.d.ts +5 -0
- package/dist/animations/fading_exits/fadeOutTopRight.js +6 -0
- package/dist/animations/fading_exits/fadeOutUp.d.ts +9 -0
- package/dist/animations/fading_exits/fadeOutUp.js +6 -0
- package/dist/animations/fading_exits/fadeOutUpBig.d.ts +9 -0
- package/dist/animations/fading_exits/fadeOutUpBig.js +6 -0
- package/dist/animations/flippers/flip.d.ts +5 -0
- package/dist/animations/flippers/flip.js +29 -0
- package/dist/animations/flippers/flipInX.d.ts +21 -0
- package/dist/animations/flippers/flipInX.js +22 -0
- package/dist/animations/flippers/flipInY.d.ts +21 -0
- package/dist/animations/flippers/flipInY.js +22 -0
- package/dist/animations/flippers/flipOutX.d.ts +9 -0
- package/dist/animations/flippers/flipOutX.js +15 -0
- package/dist/animations/flippers/flipOutY.d.ts +9 -0
- package/dist/animations/flippers/flipOutY.js +15 -0
- package/dist/animations/index.d.ts +99 -0
- package/dist/animations/index.js +101 -0
- package/dist/animations/lightspeed/lightSpeedInLeft.d.ts +9 -0
- package/dist/animations/lightspeed/lightSpeedInLeft.js +12 -0
- package/dist/animations/lightspeed/lightSpeedInRight.d.ts +9 -0
- package/dist/animations/lightspeed/lightSpeedInRight.js +12 -0
- package/dist/animations/lightspeed/lightSpeedOutLeft.d.ts +9 -0
- package/dist/animations/lightspeed/lightSpeedOutLeft.js +10 -0
- package/dist/animations/lightspeed/lightSpeedOutRight.d.ts +9 -0
- package/dist/animations/lightspeed/lightSpeedOutRight.js +10 -0
- package/dist/animations/rotating_entrances/rotateIn.d.ts +5 -0
- package/dist/animations/rotating_entrances/rotateIn.js +6 -0
- package/dist/animations/rotating_entrances/rotateInDownLeft.d.ts +5 -0
- package/dist/animations/rotating_entrances/rotateInDownLeft.js +6 -0
- package/dist/animations/rotating_entrances/rotateInDownRight.d.ts +5 -0
- package/dist/animations/rotating_entrances/rotateInDownRight.js +6 -0
- package/dist/animations/rotating_entrances/rotateInUpLeft.d.ts +5 -0
- package/dist/animations/rotating_entrances/rotateInUpLeft.js +6 -0
- package/dist/animations/rotating_entrances/rotateInUpRight.d.ts +5 -0
- package/dist/animations/rotating_entrances/rotateInUpRight.js +6 -0
- package/dist/animations/rotating_exits/rotateOut.d.ts +9 -0
- package/dist/animations/rotating_exits/rotateOut.js +6 -0
- package/dist/animations/rotating_exits/rotateOutDownLeft.d.ts +9 -0
- package/dist/animations/rotating_exits/rotateOutDownLeft.js +6 -0
- package/dist/animations/rotating_exits/rotateOutDownRight.d.ts +9 -0
- package/dist/animations/rotating_exits/rotateOutDownRight.js +6 -0
- package/dist/animations/rotating_exits/rotateOutUpLeft.d.ts +9 -0
- package/dist/animations/rotating_exits/rotateOutUpLeft.js +6 -0
- package/dist/animations/rotating_exits/rotateOutUpRight.d.ts +9 -0
- package/dist/animations/rotating_exits/rotateOutUpRight.js +6 -0
- package/dist/animations/sliding_entrances/slideInDown.d.ts +9 -0
- package/dist/animations/sliding_entrances/slideInDown.js +6 -0
- package/dist/animations/sliding_entrances/slideInLeft.d.ts +9 -0
- package/dist/animations/sliding_entrances/slideInLeft.js +6 -0
- package/dist/animations/sliding_entrances/slideInRight.d.ts +9 -0
- package/dist/animations/sliding_entrances/slideInRight.js +6 -0
- package/dist/animations/sliding_entrances/slideInUp.d.ts +9 -0
- package/dist/animations/sliding_entrances/slideInUp.js +6 -0
- package/dist/animations/sliding_exits/slideOutDown.d.ts +9 -0
- package/dist/animations/sliding_exits/slideOutDown.js +6 -0
- package/dist/animations/sliding_exits/slideOutLeft.d.ts +9 -0
- package/dist/animations/sliding_exits/slideOutLeft.js +6 -0
- package/dist/animations/sliding_exits/slideOutRight.d.ts +9 -0
- package/dist/animations/sliding_exits/slideOutRight.js +6 -0
- package/dist/animations/sliding_exits/slideOutUp.d.ts +9 -0
- package/dist/animations/sliding_exits/slideOutUp.js +6 -0
- package/dist/animations/specials/hinge.d.ts +21 -0
- package/dist/animations/specials/hinge.js +28 -0
- package/dist/animations/specials/jackInTheBox.d.ts +16 -0
- package/dist/animations/specials/jackInTheBox.js +13 -0
- package/dist/animations/specials/rollIn.d.ts +5 -0
- package/dist/animations/specials/rollIn.js +10 -0
- package/dist/animations/specials/rollOut.d.ts +9 -0
- package/dist/animations/specials/rollOut.js +10 -0
- package/dist/animations/zooming_entrances/zoomIn.d.ts +9 -0
- package/dist/animations/zooming_entrances/zoomIn.js +6 -0
- package/dist/animations/zooming_entrances/zoomInDown.d.ts +6 -0
- package/dist/animations/zooming_entrances/zoomInDown.js +16 -0
- package/dist/animations/zooming_entrances/zoomInLeft.d.ts +6 -0
- package/dist/animations/zooming_entrances/zoomInLeft.js +16 -0
- package/dist/animations/zooming_entrances/zoomInRight.d.ts +6 -0
- package/dist/animations/zooming_entrances/zoomInRight.js +16 -0
- package/dist/animations/zooming_entrances/zoomInUp.d.ts +6 -0
- package/dist/animations/zooming_entrances/zoomInUp.js +16 -0
- package/dist/animations/zooming_exits/zoomOut.d.ts +9 -0
- package/dist/animations/zooming_exits/zoomOut.js +7 -0
- package/dist/animations/zooming_exits/zoomOutDown.d.ts +6 -0
- package/dist/animations/zooming_exits/zoomOutDown.js +16 -0
- package/dist/animations/zooming_exits/zoomOutLeft.d.ts +5 -0
- package/dist/animations/zooming_exits/zoomOutLeft.js +14 -0
- package/dist/animations/zooming_exits/zoomOutRight.d.ts +5 -0
- package/dist/animations/zooming_exits/zoomOutRight.js +14 -0
- package/dist/animations/zooming_exits/zoomOutUp.d.ts +6 -0
- package/dist/animations/zooming_exits/zoomOutUp.js +16 -0
- package/dist/components/animation/animation.component.d.ts +65 -0
- package/dist/components/animation/animation.component.js +247 -0
- package/dist/components/animation/animation.d.ts +8 -0
- package/dist/components/animation/animation.js +5 -0
- package/dist/components/animation/animation.styles.d.ts +1 -0
- package/dist/components/animation/animation.styles.js +9 -0
- package/dist/components/animation/animations.d.ts +4 -0
- package/dist/components/animation/animations.js +13 -0
- package/dist/components/avatar/avatar.component.d.ts +43 -0
- package/dist/components/avatar/avatar.component.js +137 -0
- package/dist/components/avatar/avatar.d.ts +8 -0
- package/dist/components/avatar/avatar.js +5 -0
- package/dist/components/avatar/avatar.styles.d.ts +1 -0
- package/dist/components/avatar/avatar.styles.js +68 -0
- package/dist/components/badge/badge.component.d.ts +21 -0
- package/dist/components/badge/badge.component.js +64 -0
- package/dist/components/badge/badge.d.ts +8 -0
- package/dist/components/badge/badge.js +5 -0
- package/dist/components/badge/badge.styles.d.ts +1 -0
- package/dist/components/badge/badge.styles.js +76 -0
- package/dist/components/button/button.component.d.ts +104 -0
- package/dist/components/button/button.component.js +346 -0
- package/dist/components/button/button.d.ts +8 -0
- package/dist/components/button/button.js +5 -0
- package/dist/components/button/button.styles.d.ts +1 -0
- package/dist/components/button/button.styles.js +322 -0
- package/dist/components/button-group/button-group.component.d.ts +26 -0
- package/dist/components/button-group/button-group.component.js +93 -0
- package/dist/components/button-group/button-group.d.ts +8 -0
- package/dist/components/button-group/button-group.js +5 -0
- package/dist/components/button-group/button-group.styles.d.ts +1 -0
- package/dist/components/button-group/button-group.styles.js +14 -0
- package/dist/components/callout/callout.component.d.ts +22 -0
- package/dist/components/callout/callout.component.js +63 -0
- package/dist/components/callout/callout.d.ts +8 -0
- package/dist/components/callout/callout.js +5 -0
- package/dist/components/callout/callout.styles.d.ts +1 -0
- package/dist/components/callout/callout.styles.js +68 -0
- package/dist/components/card/card.component.d.ts +29 -0
- package/dist/components/card/card.component.js +59 -0
- package/dist/components/card/card.d.ts +8 -0
- package/dist/components/card/card.js +5 -0
- package/dist/components/card/card.styles.d.ts +1 -0
- package/dist/components/card/card.styles.js +65 -0
- package/dist/components/checkbox/checkbox.component.d.ts +44 -0
- package/dist/components/checkbox/checkbox.component.js +287 -0
- package/dist/components/checkbox/checkbox.d.ts +8 -0
- package/dist/components/checkbox/checkbox.js +5 -0
- package/dist/components/checkbox/checkbox.styles.d.ts +1 -0
- package/dist/components/checkbox/checkbox.styles.js +166 -0
- package/dist/components/comparer/comparer.component.d.ts +43 -0
- package/dist/components/comparer/comparer.component.js +181 -0
- package/dist/components/comparer/comparer.d.ts +8 -0
- package/dist/components/comparer/comparer.js +5 -0
- package/dist/components/comparer/comparer.styles.d.ts +1 -0
- package/dist/components/comparer/comparer.styles.js +75 -0
- package/dist/components/copy-button/copy-button.component.d.ts +75 -0
- package/dist/components/copy-button/copy-button.component.js +289 -0
- package/dist/components/copy-button/copy-button.d.ts +8 -0
- package/dist/components/copy-button/copy-button.js +5 -0
- package/dist/components/copy-button/copy-button.styles.d.ts +1 -0
- package/dist/components/copy-button/copy-button.styles.js +61 -0
- package/dist/components/details/details.component.d.ts +25 -0
- package/dist/components/details/details.component.js +243 -0
- package/dist/components/details/details.d.ts +8 -0
- package/dist/components/details/details.js +5 -0
- package/dist/components/details/details.styles.d.ts +1 -0
- package/dist/components/details/details.styles.js +86 -0
- package/dist/components/dialog/dialog.component.d.ts +84 -0
- package/dist/components/dialog/dialog.component.js +362 -0
- package/dist/components/dialog/dialog.d.ts +8 -0
- package/dist/components/dialog/dialog.js +5 -0
- package/dist/components/dialog/dialog.styles.d.ts +1 -0
- package/dist/components/dialog/dialog.styles.js +123 -0
- package/dist/components/divider/divider.component.d.ts +20 -0
- package/dist/components/divider/divider.component.js +51 -0
- package/dist/components/divider/divider.d.ts +8 -0
- package/dist/components/divider/divider.js +5 -0
- package/dist/components/divider/divider.styles.d.ts +1 -0
- package/dist/components/divider/divider.styles.js +29 -0
- package/dist/components/drawer/drawer.component.d.ts +95 -0
- package/dist/components/drawer/drawer.component.js +509 -0
- package/dist/components/drawer/drawer.d.ts +8 -0
- package/dist/components/drawer/drawer.js +5 -0
- package/dist/components/drawer/drawer.styles.d.ts +1 -0
- package/dist/components/drawer/drawer.styles.js +157 -0
- package/dist/components/dropdown/dropdown.component.d.ts +44 -0
- package/dist/components/dropdown/dropdown.component.js +385 -0
- package/dist/components/dropdown/dropdown.d.ts +8 -0
- package/dist/components/dropdown/dropdown.js +5 -0
- package/dist/components/dropdown/dropdown.styles.d.ts +1 -0
- package/dist/components/dropdown/dropdown.styles.js +52 -0
- package/dist/components/icon/icon.component.d.ts +47 -0
- package/dist/components/icon/icon.component.js +225 -0
- package/dist/components/icon/icon.d.ts +8 -0
- package/dist/components/icon/icon.js +5 -0
- package/dist/components/icon/icon.styles.d.ts +1 -0
- package/dist/components/icon/icon.styles.js +49 -0
- package/dist/components/icon/library.d.ts +14 -0
- package/dist/components/icon/library.default.d.ts +3 -0
- package/dist/components/icon/library.default.js +8 -0
- package/dist/components/icon/library.js +34 -0
- package/dist/components/icon/library.system.d.ts +3 -0
- package/dist/components/icon/library.system.js +130 -0
- package/dist/components/icon-button/icon-button.component.d.ts +27 -0
- package/dist/components/icon-button/icon-button.component.js +151 -0
- package/dist/components/icon-button/icon-button.d.ts +8 -0
- package/dist/components/icon-button/icon-button.js +5 -0
- package/dist/components/icon-button/icon-button.styles.d.ts +1 -0
- package/dist/components/icon-button/icon-button.styles.js +53 -0
- package/dist/components/input/input.component.d.ts +78 -0
- package/dist/components/input/input.component.js +513 -0
- package/dist/components/input/input.d.ts +8 -0
- package/dist/components/input/input.js +5 -0
- package/dist/components/input/input.styles.d.ts +1 -0
- package/dist/components/input/input.styles.js +308 -0
- package/dist/components/menu/menu.component.d.ts +20 -0
- package/dist/components/menu/menu.component.js +123 -0
- package/dist/components/menu/menu.d.ts +8 -0
- package/dist/components/menu/menu.js +5 -0
- package/dist/components/menu/menu.styles.d.ts +1 -0
- package/dist/components/menu/menu.styles.js +20 -0
- package/dist/components/menu-item/menu-item.component.d.ts +34 -0
- package/dist/components/menu-item/menu-item.component.js +211 -0
- package/dist/components/menu-item/menu-item.d.ts +8 -0
- package/dist/components/menu-item/menu-item.js +5 -0
- package/dist/components/menu-item/menu-item.styles.d.ts +1 -0
- package/dist/components/menu-item/menu-item.styles.js +157 -0
- package/dist/components/menu-item/submenu-controller.d.ts +34 -0
- package/dist/components/menu-item/submenu-controller.js +246 -0
- package/dist/components/menu-label/menu-label.component.d.ts +15 -0
- package/dist/components/menu-label/menu-label.component.js +25 -0
- package/dist/components/menu-label/menu-label.d.ts +8 -0
- package/dist/components/menu-label/menu-label.js +5 -0
- package/dist/components/menu-label/menu-label.styles.d.ts +1 -0
- package/dist/components/menu-label/menu-label.styles.js +22 -0
- package/dist/components/option/option.component.d.ts +42 -0
- package/dist/components/option/option.component.js +161 -0
- package/dist/components/option/option.d.ts +8 -0
- package/dist/components/option/option.js +5 -0
- package/dist/components/option/option.styles.d.ts +1 -0
- package/dist/components/option/option.styles.js +108 -0
- package/dist/components/popup/popup.component.d.ts +44 -0
- package/dist/components/popup/popup.component.js +483 -0
- package/dist/components/popup/popup.d.ts +8 -0
- package/dist/components/popup/popup.js +6 -0
- package/dist/components/popup/popup.styles.d.ts +1 -0
- package/dist/components/popup/popup.styles.js +64 -0
- package/dist/components/qr-code/qr-code.component.d.ts +16 -0
- package/dist/components/qr-code/qr-code.component.js +94 -0
- package/dist/components/qr-code/qr-code.d.ts +8 -0
- package/dist/components/qr-code/qr-code.js +5 -0
- package/dist/components/qr-code/qr-code.styles.d.ts +1 -0
- package/dist/components/qr-code/qr-code.styles.js +9 -0
- package/dist/components/radio/radio.component.d.ts +19 -0
- package/dist/components/radio/radio.component.js +120 -0
- package/dist/components/radio/radio.d.ts +8 -0
- package/dist/components/radio/radio.js +5 -0
- package/dist/components/radio/radio.styles.d.ts +1 -0
- package/dist/components/radio/radio.styles.js +132 -0
- package/dist/components/radio-button/radio-button.component.d.ts +22 -0
- package/dist/components/radio-button/radio-button.component.js +131 -0
- package/dist/components/radio-button/radio-button.d.ts +8 -0
- package/dist/components/radio-button/radio-button.js +5 -0
- package/dist/components/radio-button/radio-button.styles.d.ts +1 -0
- package/dist/components/radio-button/radio-button.styles.js +25 -0
- package/dist/components/radio-group/radio-group.component.d.ts +46 -0
- package/dist/components/radio-group/radio-group.component.js +379 -0
- package/dist/components/radio-group/radio-group.d.ts +8 -0
- package/dist/components/radio-group/radio-group.js +5 -0
- package/dist/components/radio-group/radio-group.styles.d.ts +1 -0
- package/dist/components/radio-group/radio-group.styles.js +42 -0
- package/dist/components/rating/rating.component.d.ts +37 -0
- package/dist/components/rating/rating.component.js +308 -0
- package/dist/components/rating/rating.d.ts +8 -0
- package/dist/components/rating/rating.js +5 -0
- package/dist/components/rating/rating.styles.d.ts +1 -0
- package/dist/components/rating/rating.styles.js +94 -0
- package/dist/components/resize-observer/resize-observer.component.d.ts +26 -0
- package/dist/components/resize-observer/resize-observer.component.js +89 -0
- package/dist/components/resize-observer/resize-observer.d.ts +8 -0
- package/dist/components/resize-observer/resize-observer.js +5 -0
- package/dist/components/resize-observer/resize-observer.styles.d.ts +1 -0
- package/dist/components/resize-observer/resize-observer.styles.js +9 -0
- package/dist/components/select/select.component.d.ts +174 -0
- package/dist/components/select/select.component.js +960 -0
- package/dist/components/select/select.d.ts +8 -0
- package/dist/components/select/select.js +5 -0
- package/dist/components/select/select.styles.d.ts +1 -0
- package/dist/components/select/select.styles.js +363 -0
- package/dist/components/spinner/spinner.component.d.ts +20 -0
- package/dist/components/spinner/spinner.component.js +47 -0
- package/dist/components/spinner/spinner.d.ts +8 -0
- package/dist/components/spinner/spinner.js +5 -0
- package/dist/components/spinner/spinner.styles.d.ts +1 -0
- package/dist/components/spinner/spinner.styles.js +61 -0
- package/dist/components/switch/switch.component.d.ts +84 -0
- package/dist/components/switch/switch.component.js +281 -0
- package/dist/components/switch/switch.d.ts +8 -0
- package/dist/components/switch/switch.js +5 -0
- package/dist/components/switch/switch.styles.d.ts +1 -0
- package/dist/components/switch/switch.styles.js +178 -0
- package/dist/components/tab/tab.component.d.ts +22 -0
- package/dist/components/tab/tab.component.js +112 -0
- package/dist/components/tab/tab.d.ts +8 -0
- package/dist/components/tab/tab.js +5 -0
- package/dist/components/tab/tab.styles.d.ts +1 -0
- package/dist/components/tab/tab.styles.js +85 -0
- package/dist/components/tab-group/tab-group.component.d.ts +51 -0
- package/dist/components/tab-group/tab-group.component.js +513 -0
- package/dist/components/tab-group/tab-group.d.ts +8 -0
- package/dist/components/tab-group/tab-group.js +5 -0
- package/dist/components/tab-group/tab-group.styles.d.ts +1 -0
- package/dist/components/tab-group/tab-group.styles.js +219 -0
- package/dist/components/tab-panel/tab-panel.component.d.ts +12 -0
- package/dist/components/tab-panel/tab-panel.component.js +56 -0
- package/dist/components/tab-panel/tab-panel.d.ts +8 -0
- package/dist/components/tab-panel/tab-panel.js +5 -0
- package/dist/components/tab-panel/tab-panel.styles.d.ts +1 -0
- package/dist/components/tab-panel/tab-panel.styles.js +18 -0
- package/dist/components/tag/tag.component.d.ts +38 -0
- package/dist/components/tag/tag.component.js +109 -0
- package/dist/components/tag/tag.d.ts +8 -0
- package/dist/components/tag/tag.js +5 -0
- package/dist/components/tag/tag.styles.d.ts +1 -0
- package/dist/components/tag/tag.styles.js +155 -0
- package/dist/components/tooltip/tooltip.component.d.ts +38 -0
- package/dist/components/tooltip/tooltip.component.js +267 -0
- package/dist/components/tooltip/tooltip.d.ts +8 -0
- package/dist/components/tooltip/tooltip.js +5 -0
- package/dist/components/tooltip/tooltip.styles.d.ts +1 -0
- package/dist/components/tooltip/tooltip.styles.js +59 -0
- package/dist/default.css +1005 -0
- package/dist/events/events.d.ts +33 -0
- package/dist/events/events.js +1 -0
- package/dist/events/pc-after-collapse.d.ts +6 -0
- package/dist/events/pc-after-collapse.js +1 -0
- package/dist/events/pc-after-expand.d.ts +6 -0
- package/dist/events/pc-after-expand.js +1 -0
- package/dist/events/pc-after-hide.d.ts +6 -0
- package/dist/events/pc-after-hide.js +1 -0
- package/dist/events/pc-after-show.d.ts +6 -0
- package/dist/events/pc-after-show.js +1 -0
- package/dist/events/pc-blur.d.ts +6 -0
- package/dist/events/pc-blur.js +1 -0
- package/dist/events/pc-cancel.d.ts +6 -0
- package/dist/events/pc-cancel.js +1 -0
- package/dist/events/pc-change.d.ts +6 -0
- package/dist/events/pc-change.js +1 -0
- package/dist/events/pc-clear.d.ts +6 -0
- package/dist/events/pc-clear.js +1 -0
- package/dist/events/pc-close.d.ts +6 -0
- package/dist/events/pc-close.js +1 -0
- package/dist/events/pc-collapse.d.ts +6 -0
- package/dist/events/pc-collapse.js +1 -0
- package/dist/events/pc-copy.d.ts +8 -0
- package/dist/events/pc-copy.js +1 -0
- package/dist/events/pc-error.d.ts +8 -0
- package/dist/events/pc-error.js +1 -0
- package/dist/events/pc-expand.d.ts +6 -0
- package/dist/events/pc-expand.js +1 -0
- package/dist/events/pc-finish.d.ts +6 -0
- package/dist/events/pc-finish.js +1 -0
- package/dist/events/pc-focus.d.ts +6 -0
- package/dist/events/pc-focus.js +1 -0
- package/dist/events/pc-hide.d.ts +6 -0
- package/dist/events/pc-hide.js +1 -0
- package/dist/events/pc-hover.d.ts +9 -0
- package/dist/events/pc-hover.js +1 -0
- package/dist/events/pc-initial-focus.d.ts +6 -0
- package/dist/events/pc-initial-focus.js +1 -0
- package/dist/events/pc-input.d.ts +6 -0
- package/dist/events/pc-input.js +1 -0
- package/dist/events/pc-invalid.d.ts +6 -0
- package/dist/events/pc-invalid.js +1 -0
- package/dist/events/pc-lazy-change.d.ts +6 -0
- package/dist/events/pc-lazy-change.js +1 -0
- package/dist/events/pc-lazy-load.d.ts +6 -0
- package/dist/events/pc-lazy-load.js +1 -0
- package/dist/events/pc-load.d.ts +6 -0
- package/dist/events/pc-load.js +1 -0
- package/dist/events/pc-mutation.d.ts +8 -0
- package/dist/events/pc-mutation.js +1 -0
- package/dist/events/pc-remove.d.ts +6 -0
- package/dist/events/pc-remove.js +1 -0
- package/dist/events/pc-reposition.d.ts +6 -0
- package/dist/events/pc-reposition.js +1 -0
- package/dist/events/pc-request-close.d.ts +8 -0
- package/dist/events/pc-request-close.js +1 -0
- package/dist/events/pc-resize.d.ts +8 -0
- package/dist/events/pc-resize.js +1 -0
- package/dist/events/pc-select.d.ts +9 -0
- package/dist/events/pc-select.js +1 -0
- package/dist/events/pc-selection-change.js +1 -0
- package/dist/events/pc-show.d.ts +6 -0
- package/dist/events/pc-show.js +1 -0
- package/dist/events/pc-slide-change.js +1 -0
- package/dist/events/pc-start.d.ts +6 -0
- package/dist/events/pc-start.js +1 -0
- package/dist/events/pc-tab-hide.d.ts +8 -0
- package/dist/events/pc-tab-hide.js +1 -0
- package/dist/events/pc-tab-show.d.ts +8 -0
- package/dist/events/pc-tab-show.js +1 -0
- package/dist/global-shims.d.ts +18 -0
- package/dist/global-shims.js +96 -0
- package/dist/internal/active-elements.d.ts +2 -0
- package/dist/internal/active-elements.js +16 -0
- package/dist/internal/animate.d.ts +10 -0
- package/dist/internal/animate.js +45 -0
- package/dist/internal/close-active-element.d.ts +1 -0
- package/dist/internal/close-active-element.js +8 -0
- package/dist/internal/debounce.d.ts +1 -0
- package/dist/internal/debounce.js +14 -0
- package/dist/internal/default-value.d.ts +2 -0
- package/dist/internal/default-value.js +26 -0
- package/dist/internal/drag.d.ts +7 -0
- package/dist/internal/drag.js +27 -0
- package/dist/internal/emit.d.ts +1 -0
- package/dist/internal/emit.js +14 -0
- package/dist/internal/event.d.ts +1 -0
- package/dist/internal/event.js +13 -0
- package/dist/internal/form.d.ts +41 -0
- package/dist/internal/form.js +282 -0
- package/dist/internal/math.d.ts +1 -0
- package/dist/internal/math.js +12 -0
- package/dist/internal/modal.d.ts +19 -0
- package/dist/internal/modal.js +116 -0
- package/dist/internal/offset.d.ts +4 -0
- package/dist/internal/offset.js +10 -0
- package/dist/internal/scroll.d.ts +3 -0
- package/dist/internal/scroll.js +70 -0
- package/dist/internal/scrollend-polyfill.d.ts +1 -0
- package/dist/internal/scrollend-polyfill.js +65 -0
- package/dist/internal/slot.d.ts +14 -0
- package/dist/internal/slot.js +75 -0
- package/dist/internal/string.d.ts +1 -0
- package/dist/internal/string.js +5 -0
- package/dist/internal/tabbable.d.ts +5 -0
- package/dist/internal/tabbable.js +145 -0
- package/dist/internal/watch.d.ts +11 -0
- package/dist/internal/watch.js +32 -0
- package/dist/native-styles.css +261 -0
- package/dist/placer-autoloader.d.ts +1 -0
- package/dist/placer-autoloader.js +41 -0
- package/dist/placer.d.ts +44 -0
- package/dist/placer.js +43 -0
- package/dist/style-utilities/fouce.css +13 -0
- package/dist/style-utilities/style-utilities.css +2 -0
- package/dist/style-utilities/visually-hidden.css +12 -0
- package/dist/utilities/animation-registry.d.ts +14 -0
- package/dist/utilities/animation-registry.js +39 -0
- package/dist/utilities/animation.d.ts +1 -0
- package/dist/utilities/animation.js +1 -0
- package/dist/utilities/base-path.d.ts +2 -0
- package/dist/utilities/base-path.js +8 -0
- package/dist/utilities/form.d.ts +2 -0
- package/dist/utilities/form.js +39 -0
- package/dist/utilities/icon-library.d.ts +1 -0
- package/dist/utilities/icon-library.js +1 -0
- package/dist/utility.css +41 -0
- package/package.json +82 -0
- package/src/animations/attention_seekers/bounce.ts +43 -0
- package/src/animations/attention_seekers/flash.ts +7 -0
- package/src/animations/attention_seekers/headShake.ts +8 -0
- package/src/animations/attention_seekers/heartBeat.ts +7 -0
- package/src/animations/attention_seekers/jello.ts +15 -0
- package/src/animations/attention_seekers/pulse.ts +5 -0
- package/src/animations/attention_seekers/rubberBand.ts +9 -0
- package/src/animations/attention_seekers/shake.ts +13 -0
- package/src/animations/attention_seekers/shakeX.ts +13 -0
- package/src/animations/attention_seekers/shakeY.ts +13 -0
- package/src/animations/attention_seekers/swing.ts +7 -0
- package/src/animations/attention_seekers/tada.ts +40 -0
- package/src/animations/attention_seekers/wobble.ts +24 -0
- package/src/animations/back_entrances/backInDown.ts +5 -0
- package/src/animations/back_entrances/backInLeft.ts +5 -0
- package/src/animations/back_entrances/backInRight.ts +5 -0
- package/src/animations/back_entrances/backInUp.ts +5 -0
- package/src/animations/back_exits/backOutDown.ts +5 -0
- package/src/animations/back_exits/backOutLeft.ts +5 -0
- package/src/animations/back_exits/backOutRight.ts +5 -0
- package/src/animations/back_exits/backOutUp.ts +5 -0
- package/src/animations/bouncing_entrances/bounceIn.ts +14 -0
- package/src/animations/bouncing_entrances/bounceInDown.ts +20 -0
- package/src/animations/bouncing_entrances/bounceInLeft.ts +20 -0
- package/src/animations/bouncing_entrances/bounceInRight.ts +20 -0
- package/src/animations/bouncing_entrances/bounceInUp.ts +20 -0
- package/src/animations/bouncing_exits/bounceOut.ts +6 -0
- package/src/animations/bouncing_exits/bounceOutDown.ts +18 -0
- package/src/animations/bouncing_exits/bounceOutLeft.ts +12 -0
- package/src/animations/bouncing_exits/bounceOutRight.ts +12 -0
- package/src/animations/bouncing_exits/bounceOutUp.ts +18 -0
- package/src/animations/easings/easings.ts +31 -0
- package/src/animations/fading_entrances/fadeIn.ts +4 -0
- package/src/animations/fading_entrances/fadeInBottomLeft.ts +4 -0
- package/src/animations/fading_entrances/fadeInBottomRight.ts +4 -0
- package/src/animations/fading_entrances/fadeInDown.ts +4 -0
- package/src/animations/fading_entrances/fadeInDownBig.ts +4 -0
- package/src/animations/fading_entrances/fadeInLeft.ts +4 -0
- package/src/animations/fading_entrances/fadeInLeftBig.ts +4 -0
- package/src/animations/fading_entrances/fadeInRight.ts +4 -0
- package/src/animations/fading_entrances/fadeInRightBig.ts +4 -0
- package/src/animations/fading_entrances/fadeInTopLeft.ts +4 -0
- package/src/animations/fading_entrances/fadeInTopRight.ts +4 -0
- package/src/animations/fading_entrances/fadeInUp.ts +4 -0
- package/src/animations/fading_entrances/fadeInUpBig.ts +4 -0
- package/src/animations/fading_exits/fadeOut.ts +4 -0
- package/src/animations/fading_exits/fadeOutBottomLeft.ts +4 -0
- package/src/animations/fading_exits/fadeOutBottomRight.ts +4 -0
- package/src/animations/fading_exits/fadeOutDown.ts +4 -0
- package/src/animations/fading_exits/fadeOutDownBig.ts +4 -0
- package/src/animations/fading_exits/fadeOutLeft.ts +4 -0
- package/src/animations/fading_exits/fadeOutLeftBig.ts +4 -0
- package/src/animations/fading_exits/fadeOutRight.ts +4 -0
- package/src/animations/fading_exits/fadeOutRightBig.ts +4 -0
- package/src/animations/fading_exits/fadeOutTopLeft.ts +4 -0
- package/src/animations/fading_exits/fadeOutTopRight.ts +4 -0
- package/src/animations/fading_exits/fadeOutUp.ts +4 -0
- package/src/animations/fading_exits/fadeOutUpBig.ts +4 -0
- package/src/animations/flippers/flip.ts +32 -0
- package/src/animations/flippers/flipInX.ts +20 -0
- package/src/animations/flippers/flipInY.ts +20 -0
- package/src/animations/flippers/flipOutX.ts +13 -0
- package/src/animations/flippers/flipOutY.ts +13 -0
- package/src/animations/index.ts +101 -0
- package/src/animations/lightspeed/lightSpeedInLeft.ts +10 -0
- package/src/animations/lightspeed/lightSpeedInRight.ts +10 -0
- package/src/animations/lightspeed/lightSpeedOutLeft.ts +8 -0
- package/src/animations/lightspeed/lightSpeedOutRight.ts +8 -0
- package/src/animations/rotating_entrances/rotateIn.ts +4 -0
- package/src/animations/rotating_entrances/rotateInDownLeft.ts +4 -0
- package/src/animations/rotating_entrances/rotateInDownRight.ts +4 -0
- package/src/animations/rotating_entrances/rotateInUpLeft.ts +4 -0
- package/src/animations/rotating_entrances/rotateInUpRight.ts +4 -0
- package/src/animations/rotating_exits/rotateOut.ts +4 -0
- package/src/animations/rotating_exits/rotateOutDownLeft.ts +4 -0
- package/src/animations/rotating_exits/rotateOutDownRight.ts +4 -0
- package/src/animations/rotating_exits/rotateOutUpLeft.ts +4 -0
- package/src/animations/rotating_exits/rotateOutUpRight.ts +4 -0
- package/src/animations/sliding_entrances/slideInDown.ts +4 -0
- package/src/animations/sliding_entrances/slideInLeft.ts +4 -0
- package/src/animations/sliding_entrances/slideInRight.ts +4 -0
- package/src/animations/sliding_entrances/slideInUp.ts +4 -0
- package/src/animations/sliding_exits/slideOutDown.ts +4 -0
- package/src/animations/sliding_exits/slideOutLeft.ts +4 -0
- package/src/animations/sliding_exits/slideOutRight.ts +4 -0
- package/src/animations/sliding_exits/slideOutUp.ts +4 -0
- package/src/animations/specials/hinge.ts +26 -0
- package/src/animations/specials/jackInTheBox.ts +11 -0
- package/src/animations/specials/rollIn.ts +8 -0
- package/src/animations/specials/rollOut.ts +8 -0
- package/src/animations/zooming_entrances/zoomIn.ts +4 -0
- package/src/animations/zooming_entrances/zoomInDown.ts +14 -0
- package/src/animations/zooming_entrances/zoomInLeft.ts +14 -0
- package/src/animations/zooming_entrances/zoomInRight.ts +14 -0
- package/src/animations/zooming_entrances/zoomInUp.ts +14 -0
- package/src/animations/zooming_exits/zoomOut.ts +5 -0
- package/src/animations/zooming_exits/zoomOutDown.ts +14 -0
- package/src/animations/zooming_exits/zoomOutLeft.ts +12 -0
- package/src/animations/zooming_exits/zoomOutRight.ts +12 -0
- package/src/animations/zooming_exits/zoomOutUp.ts +14 -0
- package/src/components/animation/animation.component.ts +224 -0
- package/src/components/animation/animation.styles.ts +7 -0
- package/src/components/animation/animation.ts +10 -0
- package/src/components/animation/animations.ts +13 -0
- package/src/components/avatar/avatar.component.ts +113 -0
- package/src/components/avatar/avatar.styles.ts +66 -0
- package/src/components/avatar/avatar.ts +10 -0
- package/src/components/badge/badge.component.ts +54 -0
- package/src/components/badge/badge.styles.ts +74 -0
- package/src/components/badge/badge.ts +10 -0
- package/src/components/button/button.component.ts +335 -0
- package/src/components/button/button.styles.ts +320 -0
- package/src/components/button/button.ts +10 -0
- package/src/components/button-group/button-group.component.ts +101 -0
- package/src/components/button-group/button-group.styles.ts +12 -0
- package/src/components/button-group/button-group.ts +10 -0
- package/src/components/callout/callout.component.ts +60 -0
- package/src/components/callout/callout.styles.ts +66 -0
- package/src/components/callout/callout.ts +10 -0
- package/src/components/card/card.component.ts +59 -0
- package/src/components/card/card.styles.ts +63 -0
- package/src/components/card/card.ts +10 -0
- package/src/components/checkbox/checkbox.component.ts +244 -0
- package/src/components/checkbox/checkbox.styles.ts +164 -0
- package/src/components/checkbox/checkbox.ts +10 -0
- package/src/components/comparer/comparer.component.ts +188 -0
- package/src/components/comparer/comparer.styles.ts +73 -0
- package/src/components/comparer/comparer.ts +10 -0
- package/src/components/copy-button/copy-button.component.ts +272 -0
- package/src/components/copy-button/copy-button.styles.ts +59 -0
- package/src/components/copy-button/copy-button.ts +10 -0
- package/src/components/details/details.component.ts +259 -0
- package/src/components/details/details.styles.ts +84 -0
- package/src/components/details/details.ts +10 -0
- package/src/components/dialog/dialog.component.ts +403 -0
- package/src/components/dialog/dialog.styles.ts +121 -0
- package/src/components/dialog/dialog.ts +10 -0
- package/src/components/divider/divider.component.ts +42 -0
- package/src/components/divider/divider.styles.ts +27 -0
- package/src/components/divider/divider.ts +10 -0
- package/src/components/drawer/drawer.component.ts +565 -0
- package/src/components/drawer/drawer.styles.ts +155 -0
- package/src/components/drawer/drawer.ts +10 -0
- package/src/components/dropdown/dropdown.component.ts +430 -0
- package/src/components/dropdown/dropdown.styles.ts +50 -0
- package/src/components/dropdown/dropdown.ts +10 -0
- package/src/components/icon/icon.component.ts +239 -0
- package/src/components/icon/icon.styles.ts +47 -0
- package/src/components/icon/icon.ts +10 -0
- package/src/components/icon/library.default.ts +10 -0
- package/src/components/icon/library.system.ts +136 -0
- package/src/components/icon/library.ts +54 -0
- package/src/components/icon-button/icon-button.component.ts +129 -0
- package/src/components/icon-button/icon-button.styles.ts +51 -0
- package/src/components/icon-button/icon-button.ts +10 -0
- package/src/components/input/input.component.ts +496 -0
- package/src/components/input/input.styles.ts +306 -0
- package/src/components/input/input.ts +10 -0
- package/src/components/menu/menu.component.ts +161 -0
- package/src/components/menu/menu.styles.ts +18 -0
- package/src/components/menu/menu.ts +10 -0
- package/src/components/menu-item/menu-item.component.ts +190 -0
- package/src/components/menu-item/menu-item.styles.ts +155 -0
- package/src/components/menu-item/menu-item.ts +10 -0
- package/src/components/menu-item/submenu-controller.ts +337 -0
- package/src/components/menu-label/menu-label.component.ts +22 -0
- package/src/components/menu-label/menu-label.styles.ts +20 -0
- package/src/components/menu-label/menu-label.ts +10 -0
- package/src/components/option/option.component.ts +141 -0
- package/src/components/option/option.styles.ts +106 -0
- package/src/components/option/option.ts +10 -0
- package/src/components/popup/popup.component.ts +540 -0
- package/src/components/popup/popup.styles.ts +63 -0
- package/src/components/popup/popup.ts +12 -0
- package/src/components/qr-code/qr-code.component.ts +70 -0
- package/src/components/qr-code/qr-code.styles.ts +7 -0
- package/src/components/qr-code/qr-code.ts +10 -0
- package/src/components/radio/radio.component.ts +100 -0
- package/src/components/radio/radio.styles.ts +130 -0
- package/src/components/radio/radio.ts +10 -0
- package/src/components/radio-button/radio-button.component.ts +116 -0
- package/src/components/radio-button/radio-button.styles.ts +23 -0
- package/src/components/radio-button/radio-button.ts +10 -0
- package/src/components/radio-group/radio-group.component.ts +404 -0
- package/src/components/radio-group/radio-group.styles.ts +40 -0
- package/src/components/radio-group/radio-group.ts +10 -0
- package/src/components/rating/rating.component.ts +319 -0
- package/src/components/rating/rating.styles.ts +92 -0
- package/src/components/rating/rating.ts +10 -0
- package/src/components/resize-observer/resize-observer.component.ts +91 -0
- package/src/components/resize-observer/resize-observer.styles.ts +7 -0
- package/src/components/resize-observer/resize-observer.ts +10 -0
- package/src/components/select/select.component.ts +1013 -0
- package/src/components/select/select.styles.ts +361 -0
- package/src/components/select/select.ts +10 -0
- package/src/components/spinner/spinner.component.ts +38 -0
- package/src/components/spinner/spinner.styles.ts +59 -0
- package/src/components/spinner/spinner.ts +10 -0
- package/src/components/switch/switch.component.ts +253 -0
- package/src/components/switch/switch.styles.ts +176 -0
- package/src/components/switch/switch.ts +10 -0
- package/src/components/tab/tab.component.ts +87 -0
- package/src/components/tab/tab.styles.ts +83 -0
- package/src/components/tab/tab.ts +10 -0
- package/src/components/tab-group/tab-group.component.ts +607 -0
- package/src/components/tab-group/tab-group.styles.ts +217 -0
- package/src/components/tab-group/tab-group.ts +10 -0
- package/src/components/tab-panel/tab-panel.component.ts +43 -0
- package/src/components/tab-panel/tab-panel.styles.ts +16 -0
- package/src/components/tab-panel/tab-panel.ts +10 -0
- package/src/components/tag/tag.component.ts +94 -0
- package/src/components/tag/tag.styles.ts +153 -0
- package/src/components/tag/tag.ts +10 -0
- package/src/components/tooltip/tooltip.component.ts +276 -0
- package/src/components/tooltip/tooltip.styles.ts +57 -0
- package/src/components/tooltip/tooltip.ts +10 -0
- package/src/default.css +1005 -0
- package/src/events/events.ts +35 -0
- package/src/events/pc-after-collapse.ts +7 -0
- package/src/events/pc-after-expand.ts +7 -0
- package/src/events/pc-after-hide.ts +7 -0
- package/src/events/pc-after-show.ts +7 -0
- package/src/events/pc-blur.ts +7 -0
- package/src/events/pc-cancel.ts +7 -0
- package/src/events/pc-change.ts +7 -0
- package/src/events/pc-clear.ts +7 -0
- package/src/events/pc-close.ts +7 -0
- package/src/events/pc-collapse.ts +7 -0
- package/src/events/pc-copy.ts +7 -0
- package/src/events/pc-error.ts +7 -0
- package/src/events/pc-expand.ts +7 -0
- package/src/events/pc-finish.ts +7 -0
- package/src/events/pc-focus.ts +7 -0
- package/src/events/pc-hide.ts +7 -0
- package/src/events/pc-hover.ts +10 -0
- package/src/events/pc-initial-focus.ts +7 -0
- package/src/events/pc-input.ts +7 -0
- package/src/events/pc-invalid.ts +7 -0
- package/src/events/pc-lazy-change.ts +7 -0
- package/src/events/pc-lazy-load.ts +7 -0
- package/src/events/pc-load.ts +7 -0
- package/src/events/pc-mutation.ts +7 -0
- package/src/events/pc-remove.ts +7 -0
- package/src/events/pc-reposition.ts +7 -0
- package/src/events/pc-request-close.ts +9 -0
- package/src/events/pc-resize.ts +7 -0
- package/src/events/pc-select.ts +9 -0
- package/src/events/pc-selection-change.ts +10 -0
- package/src/events/pc-show.ts +7 -0
- package/src/events/pc-slide-change.ts +13 -0
- package/src/events/pc-start.ts +7 -0
- package/src/events/pc-tab-hide.ts +7 -0
- package/src/events/pc-tab-show.ts +7 -0
- package/src/global-shims.ts +126 -0
- package/src/global.d.ts +31 -0
- package/src/internal/active-elements.ts +21 -0
- package/src/internal/animate.ts +62 -0
- package/src/internal/close-active-element.ts +7 -0
- package/src/internal/debounce.ts +25 -0
- package/src/internal/default-value.ts +40 -0
- package/src/internal/drag.ts +36 -0
- package/src/internal/emit.ts +19 -0
- package/src/internal/event.ts +12 -0
- package/src/internal/form.ts +389 -0
- package/src/internal/math.ts +14 -0
- package/src/internal/modal.ts +157 -0
- package/src/internal/offset.ts +12 -0
- package/src/internal/scroll.ts +95 -0
- package/src/internal/scrollend-polyfill.ts +99 -0
- package/src/internal/slot.ts +110 -0
- package/src/internal/string.ts +3 -0
- package/src/internal/tabbable.ts +207 -0
- package/src/internal/watch.ts +58 -0
- package/src/native-styles.css +261 -0
- package/src/placer-autoloader.ts +53 -0
- package/src/placer.ts +53 -0
- package/src/style-utilities/fouce.css +13 -0
- package/src/style-utilities/style-utilities.css +2 -0
- package/src/style-utilities/visually-hidden.css +12 -0
- package/src/utilities/animation-registry.ts +72 -0
- package/src/utilities/animation.ts +4 -0
- package/src/utilities/base-path.ts +39 -0
- package/src/utilities/form.ts +41 -0
- package/src/utilities/icon-library.ts +4 -0
- package/src/utility.css +41 -0
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { defaultConverter } from "lit";
|
|
2
|
+
import type { ReactiveElement } from "lit";
|
|
3
|
+
|
|
4
|
+
export const defaultValue =
|
|
5
|
+
(propertyName = "value") =>
|
|
6
|
+
(proto: ReactiveElement, key: string) => {
|
|
7
|
+
const ctor = proto.constructor as typeof ReactiveElement;
|
|
8
|
+
|
|
9
|
+
const attributeChangedCallback =
|
|
10
|
+
ctor.prototype.attributeChangedCallback;
|
|
11
|
+
ctor.prototype.attributeChangedCallback = function (
|
|
12
|
+
this: ReactiveElement & { [name: string]: unknown },
|
|
13
|
+
name,
|
|
14
|
+
old,
|
|
15
|
+
value,
|
|
16
|
+
) {
|
|
17
|
+
const options = ctor.getPropertyOptions(propertyName);
|
|
18
|
+
const attributeName =
|
|
19
|
+
typeof options.attribute === "string"
|
|
20
|
+
? options.attribute
|
|
21
|
+
: propertyName;
|
|
22
|
+
|
|
23
|
+
if (name === attributeName) {
|
|
24
|
+
const converter = options.converter || defaultConverter;
|
|
25
|
+
const fromAttribute =
|
|
26
|
+
typeof converter === "function"
|
|
27
|
+
? converter
|
|
28
|
+
: (converter?.fromAttribute ??
|
|
29
|
+
defaultConverter.fromAttribute);
|
|
30
|
+
|
|
31
|
+
const newValue: unknown = fromAttribute!(value, options.type);
|
|
32
|
+
|
|
33
|
+
if (this[propertyName] !== newValue) {
|
|
34
|
+
this[key] = newValue;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
attributeChangedCallback.call(this, name, old, value);
|
|
39
|
+
};
|
|
40
|
+
};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
interface DragOptions {
|
|
2
|
+
onMove: (x: number, y: number) => void;
|
|
3
|
+
onStop: () => void;
|
|
4
|
+
initialEvent: PointerEvent;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export function drag(container: HTMLElement, options?: Partial<DragOptions>) {
|
|
8
|
+
function move(pointerEvent: PointerEvent) {
|
|
9
|
+
const dims = container.getBoundingClientRect();
|
|
10
|
+
const defaultView = container.ownerDocument.defaultView!;
|
|
11
|
+
const offsetX = dims.left + defaultView.scrollX;
|
|
12
|
+
const offsetY = dims.top + defaultView.scrollY;
|
|
13
|
+
const x = pointerEvent.pageX - offsetX;
|
|
14
|
+
const y = pointerEvent.pageY - offsetY;
|
|
15
|
+
|
|
16
|
+
if (options?.onMove) {
|
|
17
|
+
options.onMove(x, y);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function stop() {
|
|
22
|
+
document.removeEventListener("pointermove", move);
|
|
23
|
+
document.removeEventListener("pointerup", stop);
|
|
24
|
+
|
|
25
|
+
if (options?.onStop) {
|
|
26
|
+
options.onStop();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
document.addEventListener("pointermove", move, { passive: true });
|
|
31
|
+
document.addEventListener("pointerup", stop);
|
|
32
|
+
|
|
33
|
+
if (options?.initialEvent instanceof PointerEvent) {
|
|
34
|
+
move(options.initialEvent);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export function emit(
|
|
2
|
+
target: EventTarget,
|
|
3
|
+
eventName: string,
|
|
4
|
+
eventDetail?: CustomEventInit,
|
|
5
|
+
): CustomEvent {
|
|
6
|
+
const { detail, cancelable, ...rest } = eventDetail || {};
|
|
7
|
+
|
|
8
|
+
const event = new CustomEvent(eventName, {
|
|
9
|
+
bubbles: true,
|
|
10
|
+
cancelable: cancelable !== undefined ? cancelable : false,
|
|
11
|
+
composed: true,
|
|
12
|
+
detail: detail,
|
|
13
|
+
...rest,
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
target.dispatchEvent(event);
|
|
17
|
+
|
|
18
|
+
return event;
|
|
19
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export function waitForEvent(element: HTMLElement, eventName: string) {
|
|
2
|
+
return new Promise<void>((resolve) => {
|
|
3
|
+
function done(event: Event) {
|
|
4
|
+
if (event.target === element) {
|
|
5
|
+
element.removeEventListener(eventName, done);
|
|
6
|
+
resolve();
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
element.addEventListener(eventName, done);
|
|
11
|
+
});
|
|
12
|
+
}
|
|
@@ -0,0 +1,389 @@
|
|
|
1
|
+
import type { ReactiveController, ReactiveControllerHost } from "lit";
|
|
2
|
+
|
|
3
|
+
export const formCollections: WeakMap<
|
|
4
|
+
HTMLFormElement,
|
|
5
|
+
Set<HTMLInputElement>
|
|
6
|
+
> = new WeakMap();
|
|
7
|
+
|
|
8
|
+
const reportValidityOverloads: WeakMap<HTMLFormElement, () => boolean> =
|
|
9
|
+
new WeakMap();
|
|
10
|
+
const checkValidityOverloads: WeakMap<HTMLFormElement, () => boolean> =
|
|
11
|
+
new WeakMap();
|
|
12
|
+
|
|
13
|
+
const userInteractedControls: WeakSet<HTMLInputElement> = new WeakSet();
|
|
14
|
+
const interactions = new WeakMap<HTMLInputElement, string[]>();
|
|
15
|
+
|
|
16
|
+
export interface FormControlControllerOptions {
|
|
17
|
+
form: (input: HTMLInputElement) => HTMLFormElement | null;
|
|
18
|
+
name: (input: HTMLInputElement) => string;
|
|
19
|
+
value: (input: HTMLInputElement) => unknown | unknown[];
|
|
20
|
+
defaultValue: (input: HTMLInputElement) => unknown | unknown[];
|
|
21
|
+
disabled: (input: HTMLInputElement) => boolean;
|
|
22
|
+
reportValidity: (input: HTMLInputElement) => boolean;
|
|
23
|
+
checkValidity: (input: HTMLInputElement) => boolean;
|
|
24
|
+
setValue: (input: HTMLInputElement, value: unknown) => void;
|
|
25
|
+
assumeInteractionOn: string[];
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export class FormControlController implements ReactiveController {
|
|
29
|
+
host: HTMLInputElement & ReactiveControllerHost;
|
|
30
|
+
form?: HTMLFormElement | null;
|
|
31
|
+
options: FormControlControllerOptions;
|
|
32
|
+
|
|
33
|
+
constructor(
|
|
34
|
+
host: ReactiveControllerHost & HTMLInputElement,
|
|
35
|
+
options?: Partial<FormControlControllerOptions>,
|
|
36
|
+
) {
|
|
37
|
+
(this.host = host).addController(this);
|
|
38
|
+
this.options = {
|
|
39
|
+
form: (input) => input.closest("form"),
|
|
40
|
+
name: (input) => input.name,
|
|
41
|
+
value: (input) => input.value,
|
|
42
|
+
defaultValue: (input) => input.defaultValue,
|
|
43
|
+
disabled: (input) => input.disabled,
|
|
44
|
+
reportValidity: (input) =>
|
|
45
|
+
typeof input.reportValidity === "function"
|
|
46
|
+
? input.reportValidity()
|
|
47
|
+
: true,
|
|
48
|
+
checkValidity: (input) =>
|
|
49
|
+
typeof input.checkValidity === "function"
|
|
50
|
+
? input.checkValidity()
|
|
51
|
+
: true,
|
|
52
|
+
setValue: (input, value: unknown) =>
|
|
53
|
+
(input.value = value as string),
|
|
54
|
+
assumeInteractionOn: ["input"],
|
|
55
|
+
...options,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
hostConnected() {
|
|
60
|
+
const form = this.options.form(this.host);
|
|
61
|
+
|
|
62
|
+
if (form) {
|
|
63
|
+
this.attachForm(form);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
interactions.set(this.host, []);
|
|
67
|
+
this.options.assumeInteractionOn.forEach((event) => {
|
|
68
|
+
this.host.addEventListener(event, this.handleInteraction);
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
hostDisconnected() {
|
|
73
|
+
this.detachForm();
|
|
74
|
+
|
|
75
|
+
interactions.delete(this.host);
|
|
76
|
+
this.options.assumeInteractionOn.forEach((event) => {
|
|
77
|
+
this.host.removeEventListener(event, this.handleInteraction);
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
hostUpdated() {
|
|
82
|
+
const form = this.options.form(this.host);
|
|
83
|
+
|
|
84
|
+
if (!form) {
|
|
85
|
+
this.detachForm();
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
if (form && this.form !== form) {
|
|
89
|
+
this.detachForm();
|
|
90
|
+
this.attachForm(form);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
if ("hasUpdated" in this.host && this.host.hasUpdated) {
|
|
94
|
+
this.setValidity(this.host.validity.valid);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
private attachForm(form?: HTMLFormElement) {
|
|
99
|
+
if (form) {
|
|
100
|
+
this.form = form;
|
|
101
|
+
|
|
102
|
+
if (formCollections.has(this.form)) {
|
|
103
|
+
formCollections.get(this.form)!.add(this.host);
|
|
104
|
+
} else {
|
|
105
|
+
formCollections.set(
|
|
106
|
+
this.form,
|
|
107
|
+
new Set<HTMLInputElement>([this.host]),
|
|
108
|
+
);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
this.form.addEventListener("formdata", this.handleFormData);
|
|
112
|
+
this.form.addEventListener("submit", this.handleFormSubmit);
|
|
113
|
+
this.form.addEventListener("reset", this.handleFormReset);
|
|
114
|
+
|
|
115
|
+
if (!reportValidityOverloads.has(this.form)) {
|
|
116
|
+
reportValidityOverloads.set(
|
|
117
|
+
this.form,
|
|
118
|
+
this.form.reportValidity,
|
|
119
|
+
);
|
|
120
|
+
this.form.reportValidity = () => this.reportFormValidity();
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
if (!checkValidityOverloads.has(this.form)) {
|
|
124
|
+
checkValidityOverloads.set(this.form, this.form.checkValidity);
|
|
125
|
+
this.form.checkValidity = () => this.checkFormValidity();
|
|
126
|
+
}
|
|
127
|
+
} else {
|
|
128
|
+
this.form = undefined;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
private detachForm() {
|
|
133
|
+
if (!this.form) {
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
const formCollection = formCollections.get(this.form);
|
|
138
|
+
|
|
139
|
+
if (!formCollection) {
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
formCollection.delete(this.host);
|
|
144
|
+
|
|
145
|
+
if (formCollection.size <= 0) {
|
|
146
|
+
this.form.removeEventListener("formdata", this.handleFormData);
|
|
147
|
+
this.form.removeEventListener("submit", this.handleFormSubmit);
|
|
148
|
+
this.form.removeEventListener("reset", this.handleFormReset);
|
|
149
|
+
|
|
150
|
+
if (reportValidityOverloads.has(this.form)) {
|
|
151
|
+
this.form.reportValidity = reportValidityOverloads.get(
|
|
152
|
+
this.form,
|
|
153
|
+
)!;
|
|
154
|
+
reportValidityOverloads.delete(this.form);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
if (checkValidityOverloads.has(this.form)) {
|
|
158
|
+
this.form.checkValidity = checkValidityOverloads.get(
|
|
159
|
+
this.form,
|
|
160
|
+
)!;
|
|
161
|
+
checkValidityOverloads.delete(this.form);
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
this.form = undefined;
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
private handleFormData = (event: FormDataEvent) => {
|
|
169
|
+
const disabled = this.options.disabled(this.host);
|
|
170
|
+
const name = this.options.name(this.host);
|
|
171
|
+
const value = this.options.value(this.host);
|
|
172
|
+
|
|
173
|
+
if (
|
|
174
|
+
this.host.isConnected &&
|
|
175
|
+
!disabled &&
|
|
176
|
+
typeof name === "string" &&
|
|
177
|
+
name.length > 0 &&
|
|
178
|
+
typeof value !== "undefined"
|
|
179
|
+
) {
|
|
180
|
+
if (Array.isArray(value)) {
|
|
181
|
+
(value as unknown[]).forEach((val) => {
|
|
182
|
+
event.formData.append(
|
|
183
|
+
name,
|
|
184
|
+
(val as string | number | boolean).toString(),
|
|
185
|
+
);
|
|
186
|
+
});
|
|
187
|
+
} else {
|
|
188
|
+
event.formData.append(
|
|
189
|
+
name,
|
|
190
|
+
(value as string | number | boolean).toString(),
|
|
191
|
+
);
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
|
|
196
|
+
private handleFormSubmit = (event: Event) => {
|
|
197
|
+
const disabled = this.options.disabled(this.host);
|
|
198
|
+
const reportValidity = this.options.reportValidity;
|
|
199
|
+
|
|
200
|
+
if (this.form && !this.form.noValidate) {
|
|
201
|
+
formCollections.get(this.form)?.forEach((control) => {
|
|
202
|
+
this.setUserInteracted(control, true);
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
if (
|
|
207
|
+
this.form &&
|
|
208
|
+
!this.form.noValidate &&
|
|
209
|
+
!disabled &&
|
|
210
|
+
!reportValidity(this.host)
|
|
211
|
+
) {
|
|
212
|
+
event.preventDefault();
|
|
213
|
+
event.stopImmediatePropagation();
|
|
214
|
+
}
|
|
215
|
+
};
|
|
216
|
+
|
|
217
|
+
private handleFormReset = () => {
|
|
218
|
+
this.options.setValue(this.host, this.options.defaultValue(this.host));
|
|
219
|
+
this.setUserInteracted(this.host, false);
|
|
220
|
+
interactions.set(this.host, []);
|
|
221
|
+
};
|
|
222
|
+
|
|
223
|
+
private handleInteraction = (event: Event) => {
|
|
224
|
+
const emittedEvents = interactions.get(this.host)!;
|
|
225
|
+
|
|
226
|
+
if (!emittedEvents.includes(event.type)) {
|
|
227
|
+
emittedEvents.push(event.type);
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
if (emittedEvents.length === this.options.assumeInteractionOn.length) {
|
|
231
|
+
this.setUserInteracted(this.host, true);
|
|
232
|
+
}
|
|
233
|
+
};
|
|
234
|
+
|
|
235
|
+
private checkFormValidity = () => {
|
|
236
|
+
if (this.form && !this.form.noValidate) {
|
|
237
|
+
const elements = this.form.querySelectorAll<HTMLInputElement>("*");
|
|
238
|
+
|
|
239
|
+
for (const element of Array.from(elements)) {
|
|
240
|
+
if (typeof element.checkValidity === "function") {
|
|
241
|
+
if (!element.checkValidity()) {
|
|
242
|
+
return false;
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
return true;
|
|
249
|
+
};
|
|
250
|
+
|
|
251
|
+
private reportFormValidity = () => {
|
|
252
|
+
if (this.form && !this.form.noValidate) {
|
|
253
|
+
const elements = this.form.querySelectorAll<HTMLInputElement>("*");
|
|
254
|
+
|
|
255
|
+
for (const element of Array.from(elements)) {
|
|
256
|
+
if (typeof element.reportValidity === "function") {
|
|
257
|
+
if (!element.reportValidity()) {
|
|
258
|
+
return false;
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
return true;
|
|
265
|
+
};
|
|
266
|
+
|
|
267
|
+
private setUserInteracted(el: HTMLInputElement, hasInteracted: boolean) {
|
|
268
|
+
if (hasInteracted) {
|
|
269
|
+
userInteractedControls.add(el);
|
|
270
|
+
} else {
|
|
271
|
+
userInteractedControls.delete(el);
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
el.dispatchEvent(new Event("update"));
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
private doAction(type: "submit" | "reset", submitter?: HTMLInputElement) {
|
|
278
|
+
if (this.form) {
|
|
279
|
+
const button = document.createElement("button");
|
|
280
|
+
button.type = type;
|
|
281
|
+
button.style.position = "absolute";
|
|
282
|
+
button.style.width = "0";
|
|
283
|
+
button.style.height = "0";
|
|
284
|
+
button.style.clipPath = "inset(50%)";
|
|
285
|
+
button.style.overflow = "hidden";
|
|
286
|
+
button.style.whiteSpace = "nowrap";
|
|
287
|
+
|
|
288
|
+
if (submitter) {
|
|
289
|
+
button.name = submitter.name;
|
|
290
|
+
button.value = submitter.value;
|
|
291
|
+
|
|
292
|
+
[
|
|
293
|
+
"formaction",
|
|
294
|
+
"formenctype",
|
|
295
|
+
"formmethod",
|
|
296
|
+
"formnovalidate",
|
|
297
|
+
"formtarget",
|
|
298
|
+
].forEach((attr) => {
|
|
299
|
+
if (submitter.hasAttribute(attr)) {
|
|
300
|
+
button.setAttribute(
|
|
301
|
+
attr,
|
|
302
|
+
submitter.getAttribute(attr)!,
|
|
303
|
+
);
|
|
304
|
+
}
|
|
305
|
+
});
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
this.form.append(button);
|
|
309
|
+
button.click();
|
|
310
|
+
button.remove();
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
|
|
314
|
+
getForm() {
|
|
315
|
+
return this.form ?? null;
|
|
316
|
+
}
|
|
317
|
+
|
|
318
|
+
reset(submitter?: HTMLInputElement) {
|
|
319
|
+
this.doAction("reset", submitter);
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
submit(submitter?: HTMLInputElement) {
|
|
323
|
+
this.doAction("submit", submitter);
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
setValidity(isValid: boolean) {
|
|
327
|
+
const host = this.host;
|
|
328
|
+
const hasInteracted = Boolean(userInteractedControls.has(host));
|
|
329
|
+
const required = Boolean(host.required);
|
|
330
|
+
|
|
331
|
+
host.toggleAttribute("data-required", required);
|
|
332
|
+
host.toggleAttribute("data-optional", !required);
|
|
333
|
+
host.toggleAttribute("data-invalid", !isValid);
|
|
334
|
+
host.toggleAttribute("data-valid", isValid);
|
|
335
|
+
host.toggleAttribute("data-user-invalid", !isValid && hasInteracted);
|
|
336
|
+
host.toggleAttribute("data-user-valid", isValid && hasInteracted);
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
updateValidity() {
|
|
340
|
+
const host = this.host;
|
|
341
|
+
this.setValidity(host.validity.valid);
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
emitInvalidEvent(originalInvalidEvent?: Event) {
|
|
345
|
+
const pcInvalidEvent = new CustomEvent<Record<PropertyKey, never>>(
|
|
346
|
+
"pc-invalid",
|
|
347
|
+
{
|
|
348
|
+
bubbles: false,
|
|
349
|
+
composed: false,
|
|
350
|
+
cancelable: true,
|
|
351
|
+
detail: {},
|
|
352
|
+
},
|
|
353
|
+
);
|
|
354
|
+
|
|
355
|
+
if (!originalInvalidEvent) {
|
|
356
|
+
pcInvalidEvent.preventDefault();
|
|
357
|
+
}
|
|
358
|
+
|
|
359
|
+
if (!this.host.dispatchEvent(pcInvalidEvent)) {
|
|
360
|
+
originalInvalidEvent?.preventDefault();
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
export const validValidityState: ValidityState = Object.freeze({
|
|
366
|
+
badInput: false,
|
|
367
|
+
customError: false,
|
|
368
|
+
patternMismatch: false,
|
|
369
|
+
rangeOverflow: false,
|
|
370
|
+
rangeUnderflow: false,
|
|
371
|
+
stepMismatch: false,
|
|
372
|
+
tooLong: false,
|
|
373
|
+
tooShort: false,
|
|
374
|
+
typeMismatch: false,
|
|
375
|
+
valid: true,
|
|
376
|
+
valueMissing: false,
|
|
377
|
+
});
|
|
378
|
+
|
|
379
|
+
export const valueMissingValidityState: ValidityState = Object.freeze({
|
|
380
|
+
...validValidityState,
|
|
381
|
+
valid: false,
|
|
382
|
+
valueMissing: true,
|
|
383
|
+
});
|
|
384
|
+
|
|
385
|
+
export const customErrorValidityState: ValidityState = Object.freeze({
|
|
386
|
+
...validValidityState,
|
|
387
|
+
valid: false,
|
|
388
|
+
customError: true,
|
|
389
|
+
});
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export function clamp(value: number, min: number, max: number) {
|
|
2
|
+
const noNegativeZero = (number: number) =>
|
|
3
|
+
Object.is(number, -0) ? 0 : number;
|
|
4
|
+
|
|
5
|
+
if (value < min) {
|
|
6
|
+
return noNegativeZero(min);
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
if (value > max) {
|
|
10
|
+
return noNegativeZero(max);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
return noNegativeZero(value);
|
|
14
|
+
}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import { activeElements, getDeepestActiveElement } from "./active-elements.js";
|
|
2
|
+
import { getTabbableElements } from "./tabbable.js";
|
|
3
|
+
|
|
4
|
+
let activeModals: HTMLElement[] = [];
|
|
5
|
+
|
|
6
|
+
export class Modal {
|
|
7
|
+
element: HTMLElement;
|
|
8
|
+
isExternalActivated?: boolean;
|
|
9
|
+
tabDirection: "forward" | "backward" = "forward";
|
|
10
|
+
currentFocus?: HTMLElement | null;
|
|
11
|
+
previousFocus?: HTMLElement | null;
|
|
12
|
+
elementsWithTabbableControls: string[];
|
|
13
|
+
|
|
14
|
+
constructor(element: HTMLElement) {
|
|
15
|
+
this.element = element;
|
|
16
|
+
|
|
17
|
+
this.elementsWithTabbableControls = ["iframe"];
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
activate() {
|
|
21
|
+
activeModals.push(this.element);
|
|
22
|
+
document.addEventListener("focusin", this.handleFocusIn);
|
|
23
|
+
document.addEventListener("keydown", this.handleKeyDown);
|
|
24
|
+
document.addEventListener("keyup", this.handleKeyUp);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
deactivate() {
|
|
28
|
+
activeModals = activeModals.filter((modal) => modal !== this.element);
|
|
29
|
+
this.currentFocus = null;
|
|
30
|
+
document.removeEventListener("focusin", this.handleFocusIn);
|
|
31
|
+
document.removeEventListener("keydown", this.handleKeyDown);
|
|
32
|
+
document.removeEventListener("keyup", this.handleKeyUp);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
isActive() {
|
|
36
|
+
return activeModals[activeModals.length - 1] === this.element;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
activateExternal() {
|
|
40
|
+
this.isExternalActivated = true;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
deactivateExternal() {
|
|
44
|
+
this.isExternalActivated = false;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
private checkFocus() {
|
|
48
|
+
if (this.isActive() && !this.isExternalActivated) {
|
|
49
|
+
const tabbableElements = getTabbableElements(this.element);
|
|
50
|
+
if (!this.element.matches(":focus-within")) {
|
|
51
|
+
const start = tabbableElements[0];
|
|
52
|
+
const end = tabbableElements[tabbableElements.length - 1];
|
|
53
|
+
const target = this.tabDirection === "forward" ? start : end;
|
|
54
|
+
|
|
55
|
+
if (typeof target?.focus === "function") {
|
|
56
|
+
this.currentFocus = target;
|
|
57
|
+
target.focus({ preventScroll: false });
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
private handleFocusIn = () => {
|
|
64
|
+
if (!this.isActive()) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
this.checkFocus();
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
private possiblyHasTabbableChildren(element: HTMLElement) {
|
|
71
|
+
return (
|
|
72
|
+
this.elementsWithTabbableControls.includes(
|
|
73
|
+
element.tagName.toLowerCase(),
|
|
74
|
+
) || element.hasAttribute("controls")
|
|
75
|
+
);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
private handleKeyDown = (event: KeyboardEvent) => {
|
|
79
|
+
if (event.key !== "Tab" || this.isExternalActivated) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
if (!this.isActive()) {
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
const currentActiveElement = getDeepestActiveElement();
|
|
88
|
+
this.previousFocus = currentActiveElement as HTMLElement | null;
|
|
89
|
+
|
|
90
|
+
if (
|
|
91
|
+
this.previousFocus &&
|
|
92
|
+
this.possiblyHasTabbableChildren(this.previousFocus)
|
|
93
|
+
) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
if (event.shiftKey) {
|
|
98
|
+
this.tabDirection = "backward";
|
|
99
|
+
} else {
|
|
100
|
+
this.tabDirection = "forward";
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
const tabbableElements = getTabbableElements(this.element);
|
|
104
|
+
|
|
105
|
+
let currentFocusIndex = tabbableElements.findIndex(
|
|
106
|
+
(element) => element === currentActiveElement,
|
|
107
|
+
);
|
|
108
|
+
|
|
109
|
+
this.previousFocus = this.currentFocus;
|
|
110
|
+
|
|
111
|
+
const addition = this.tabDirection === "forward" ? 1 : -1;
|
|
112
|
+
|
|
113
|
+
while (true) {
|
|
114
|
+
if (currentFocusIndex + addition >= tabbableElements.length) {
|
|
115
|
+
currentFocusIndex = 0;
|
|
116
|
+
} else if (currentFocusIndex + addition < 0) {
|
|
117
|
+
currentFocusIndex = tabbableElements.length - 1;
|
|
118
|
+
} else {
|
|
119
|
+
currentFocusIndex += addition;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
this.previousFocus = this.currentFocus;
|
|
123
|
+
const nextFocus = tabbableElements[currentFocusIndex];
|
|
124
|
+
|
|
125
|
+
if (this.tabDirection === "backward") {
|
|
126
|
+
if (
|
|
127
|
+
this.previousFocus &&
|
|
128
|
+
this.possiblyHasTabbableChildren(this.previousFocus)
|
|
129
|
+
) {
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
if (nextFocus && this.possiblyHasTabbableChildren(nextFocus)) {
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
event.preventDefault();
|
|
139
|
+
this.currentFocus = nextFocus;
|
|
140
|
+
this.currentFocus?.focus({ preventScroll: false });
|
|
141
|
+
|
|
142
|
+
const allActiveElements = [...activeElements()];
|
|
143
|
+
if (
|
|
144
|
+
allActiveElements.includes(this.currentFocus) ||
|
|
145
|
+
!allActiveElements.includes(this.previousFocus!)
|
|
146
|
+
) {
|
|
147
|
+
break;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
setTimeout(() => this.checkFocus());
|
|
152
|
+
};
|
|
153
|
+
|
|
154
|
+
private handleKeyUp = () => {
|
|
155
|
+
this.tabDirection = "forward";
|
|
156
|
+
};
|
|
157
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export function getOffset(element: HTMLElement, parent: HTMLElement) {
|
|
2
|
+
return {
|
|
3
|
+
top: Math.round(
|
|
4
|
+
element.getBoundingClientRect().top -
|
|
5
|
+
parent.getBoundingClientRect().top,
|
|
6
|
+
),
|
|
7
|
+
left: Math.round(
|
|
8
|
+
element.getBoundingClientRect().left -
|
|
9
|
+
parent.getBoundingClientRect().left,
|
|
10
|
+
),
|
|
11
|
+
};
|
|
12
|
+
}
|