@getmicdrop/svelte-components 2.8.1 → 3.1.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/components/AboutShow/AboutShow.svelte +22 -123
- package/dist/components/AboutShow/AboutShow.svelte.d.ts.map +1 -1
- package/dist/components/Accordion/Accordion.svelte +16 -9
- package/dist/components/Accordion/Accordion.svelte.d.ts +2 -0
- package/dist/components/Accordion/Accordion.svelte.d.ts.map +1 -1
- package/dist/components/Accordion/AccordionItem.svelte +40 -103
- package/dist/components/Accordion/AccordionItem.svelte.d.ts.map +1 -1
- package/dist/components/Alert/Alert.svelte +38 -37
- package/dist/components/Alert/Alert.svelte.d.ts +4 -5
- package/dist/components/Alert/Alert.svelte.d.ts.map +1 -1
- package/dist/components/Avatar/Avatar.svelte +56 -0
- package/dist/components/Avatar/Avatar.svelte.d.ts +37 -0
- package/dist/components/Avatar/Avatar.svelte.d.ts.map +1 -0
- package/dist/components/Badges/Badge.stories.svelte +6 -7
- package/dist/components/Badges/Badge.stories.svelte.d.ts +0 -20
- package/dist/components/Badges/Badge.stories.svelte.d.ts.map +1 -1
- package/dist/components/Badges/Badge.svelte +91 -356
- package/dist/components/Badges/Badge.svelte.d.ts +8 -8
- package/dist/components/Badges/Badge.svelte.d.ts.map +1 -1
- package/dist/components/BottomSheet/BottomSheet.stories.svelte +7 -14
- package/dist/components/BottomSheet/BottomSheet.stories.svelte.d.ts +0 -18
- package/dist/components/BottomSheet/BottomSheet.stories.svelte.d.ts.map +1 -1
- package/dist/components/BottomSheet/BottomSheet.svelte +14 -100
- package/dist/components/Breadcrumb/Breadcrumb.spec.js +1 -1
- package/dist/components/Breadcrumb/Breadcrumb.stories.svelte +7 -8
- package/dist/components/Breadcrumb/Breadcrumb.stories.svelte.d.ts +0 -9
- package/dist/components/Breadcrumb/Breadcrumb.stories.svelte.d.ts.map +1 -1
- package/dist/components/Breadcrumb/Breadcrumb.svelte +31 -37
- package/dist/components/Breadcrumb/Breadcrumb.svelte.d.ts +2 -2
- package/dist/components/Breadcrumb/Breadcrumb.svelte.d.ts.map +1 -1
- package/dist/components/Button/Button.stories.svelte +5 -7
- package/dist/components/Button/Button.stories.svelte.d.ts +0 -32
- package/dist/components/Button/Button.stories.svelte.d.ts.map +1 -1
- package/dist/components/Button/Button.svelte +110 -729
- package/dist/components/Button/Button.svelte.d.ts +4 -22
- package/dist/components/Button/Button.svelte.d.ts.map +1 -1
- package/dist/components/Button/ButtonSaveDemo.svelte +1 -1
- package/dist/components/Calendar/MiniMonthCalendar.svelte +56 -654
- package/dist/components/Calendar/MiniMonthCalendar.svelte.d.ts.map +1 -1
- package/dist/components/Card.spec.js +28 -26
- package/dist/components/Card.stories.svelte +7 -11
- package/dist/components/Card.stories.svelte.d.ts +0 -9
- package/dist/components/Card.stories.svelte.d.ts.map +1 -1
- package/dist/components/Card.svelte +12 -4
- package/dist/components/Card.svelte.d.ts +8 -2
- package/dist/components/Card.svelte.d.ts.map +1 -1
- package/dist/components/Checkbox/Checkbox.svelte +14 -35
- package/dist/components/Checkbox/Checkbox.svelte.d.ts +4 -4
- package/dist/components/Checkbox/Checkbox.svelte.d.ts.map +1 -1
- package/dist/components/CropImage/CropImage.stories.svelte +7 -29
- package/dist/components/CropImage/CropImage.stories.svelte.d.ts +0 -13
- package/dist/components/CropImage/CropImage.stories.svelte.d.ts.map +1 -1
- package/dist/components/CropImage/CropImage.svelte +101 -172
- package/dist/components/CropImage/CropImage.svelte.d.ts.map +1 -1
- package/dist/components/DarkModeToggle.stories.svelte +15 -13
- package/dist/components/DarkModeToggle.stories.svelte.d.ts +0 -5
- package/dist/components/DarkModeToggle.stories.svelte.d.ts.map +1 -1
- package/dist/components/DarkModeToggle.svelte +30 -136
- package/dist/components/DarkModeToggle.svelte.d.ts.map +1 -1
- package/dist/components/DesignSystemAudit.stories.svelte +428 -0
- package/dist/components/{CardAudit.stories.svelte.d.ts → DesignSystemAudit.stories.svelte.d.ts} +4 -9
- package/dist/components/DesignSystemAudit.stories.svelte.d.ts.map +1 -0
- package/dist/components/Drawer/Drawer.svelte +81 -136
- package/dist/components/Drawer/Drawer.svelte.d.ts +8 -10
- package/dist/components/Drawer/Drawer.svelte.d.ts.map +1 -1
- package/dist/components/Dropdown/Dropdown.svelte +56 -85
- package/dist/components/Dropdown/Dropdown.svelte.d.ts +6 -2
- package/dist/components/Dropdown/Dropdown.svelte.d.ts.map +1 -1
- package/dist/components/Dropdown/DropdownItem.svelte +31 -73
- package/dist/components/Dropdown/DropdownItem.svelte.d.ts.map +1 -1
- package/dist/components/Dropdown/SelectDropdown.svelte +36 -162
- package/dist/components/Dropdown/SelectDropdown.svelte.d.ts.map +1 -1
- package/dist/components/EmptyState/EmptyState.svelte +6 -47
- package/dist/components/EmptyState/EmptyState.svelte.d.ts.map +1 -1
- package/dist/components/ErrorDisplay.spec.js +3 -3
- package/dist/components/ErrorDisplay.stories.svelte +8 -9
- package/dist/components/ErrorDisplay.stories.svelte.d.ts +0 -35
- package/dist/components/ErrorDisplay.stories.svelte.d.ts.map +1 -1
- package/dist/components/ErrorDisplay.svelte +1 -29
- package/dist/components/ErrorDisplay.svelte.d.ts.map +1 -1
- package/dist/components/FAQs/FAQs.svelte +62 -32
- package/dist/components/FAQs/FAQs.svelte.d.ts +10 -2
- package/dist/components/FAQs/FAQs.svelte.d.ts.map +1 -1
- package/dist/components/FormActions.stories.svelte +8 -9
- package/dist/components/FormActions.stories.svelte.d.ts +0 -30
- package/dist/components/FormActions.stories.svelte.d.ts.map +1 -1
- package/dist/components/FormActions.svelte +3 -3
- package/dist/components/FormValidationSummary.stories.svelte +8 -6
- package/dist/components/FormValidationSummary.stories.svelte.d.ts +0 -5
- package/dist/components/FormValidationSummary.stories.svelte.d.ts.map +1 -1
- package/dist/components/FormValidationSummary.svelte +4 -4
- package/dist/components/Icons/ArrowLeft.svelte.d.ts +2 -2
- package/dist/components/Icons/ArrowRight.svelte.d.ts +2 -2
- package/dist/components/Icons/Availability.svelte.d.ts +2 -2
- package/dist/components/Icons/Back.svelte.d.ts +2 -2
- package/dist/components/Icons/CheckCircle.svelte.d.ts +2 -2
- package/dist/components/Icons/CheckCircleOutline.svelte.d.ts +2 -2
- package/dist/components/Icons/CheckCircleSolid.svelte +15 -0
- package/dist/components/{Badges/BadgeAudit.stories.svelte.d.ts → Icons/CheckCircleSolid.svelte.d.ts} +7 -12
- package/dist/components/Icons/CheckCircleSolid.svelte.d.ts.map +1 -0
- package/dist/components/Icons/CheckOutline.svelte +17 -0
- package/dist/components/{Alert/AlertAudit.stories.svelte.d.ts → Icons/CheckOutline.svelte.d.ts} +7 -12
- package/dist/components/Icons/CheckOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/ChevronDownOutline.svelte +17 -0
- package/dist/components/{Input/InputAudit.stories.svelte.d.ts → Icons/ChevronDownOutline.svelte.d.ts} +7 -12
- package/dist/components/Icons/ChevronDownOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/ChevronLeft.svelte.d.ts +2 -2
- package/dist/components/Icons/ChevronLeftOutline.svelte +17 -0
- package/dist/components/Icons/ChevronLeftOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/ChevronLeftOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/ChevronRight.svelte.d.ts +2 -2
- package/dist/components/Icons/ChevronRightOutline.svelte +17 -0
- package/dist/components/Icons/ChevronRightOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/ChevronRightOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/ChevronUpOutline.svelte +17 -0
- package/dist/components/Icons/ChevronUpOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/ChevronUpOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/CloseCircleOutline.svelte +17 -0
- package/dist/components/Icons/CloseCircleOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/CloseCircleOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/CloseOutline.svelte +17 -0
- package/dist/components/Icons/CloseOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/CloseOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/Copy.svelte.d.ts +2 -2
- package/dist/components/Icons/Cross.svelte.d.ts +2 -2
- package/dist/components/Icons/DotsHorizontalOutline.svelte +15 -0
- package/dist/components/Icons/DotsHorizontalOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/DotsHorizontalOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/DownArrow.svelte.d.ts +2 -2
- package/dist/components/Icons/ErrorCircle.svelte.d.ts +2 -2
- package/dist/components/Icons/ExclamationCircleOutline.svelte +17 -0
- package/dist/components/Icons/ExclamationCircleOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/ExclamationCircleOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/ExclamationTriangleOutline.svelte +17 -0
- package/dist/components/Icons/ExclamationTriangleOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/ExclamationTriangleOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/EyeOutline.svelte +18 -0
- package/dist/components/Icons/EyeOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/EyeOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/EyeSlashOutline.svelte +17 -0
- package/dist/components/Icons/EyeSlashOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/EyeSlashOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/FacebookIcon.svelte.d.ts +2 -2
- package/dist/components/Icons/FileCopyOutline.svelte +17 -0
- package/dist/components/Icons/FileCopyOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/FileCopyOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/Home.svelte.d.ts +2 -2
- package/dist/components/Icons/HomeSolid.svelte +16 -0
- package/dist/components/Icons/HomeSolid.svelte.d.ts +27 -0
- package/dist/components/Icons/HomeSolid.svelte.d.ts.map +1 -0
- package/dist/components/Icons/Icon.stories.svelte +18 -19
- package/dist/components/Icons/Icon.stories.svelte.d.ts +0 -17
- package/dist/components/Icons/Icon.stories.svelte.d.ts.map +1 -1
- package/dist/components/Icons/Icon.svelte.d.ts +2 -2
- package/dist/components/Icons/IconGallery.stories.svelte +29 -27
- package/dist/components/Icons/IconGallery.stories.svelte.d.ts +0 -4
- package/dist/components/Icons/IconGallery.stories.svelte.d.ts.map +1 -1
- package/dist/components/Icons/Info.svelte.d.ts +2 -2
- package/dist/components/Icons/InfoCircleOutline.svelte +17 -0
- package/dist/components/Icons/InfoCircleOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/InfoCircleOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/InstagramIcon.svelte.d.ts +2 -2
- package/dist/components/Icons/LogoInstagram.svelte +18 -0
- package/dist/components/Icons/LogoInstagram.svelte.d.ts +29 -0
- package/dist/components/Icons/LogoInstagram.svelte.d.ts.map +1 -0
- package/dist/components/Icons/Message.svelte.d.ts +2 -2
- package/dist/components/Icons/MinusOutline.svelte +17 -0
- package/dist/components/Icons/MinusOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/MinusOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/MoonIcon.svelte.d.ts +2 -2
- package/dist/components/Icons/More.svelte.d.ts +2 -2
- package/dist/components/Icons/MoreHori.svelte.d.ts +2 -2
- package/dist/components/Icons/Notification.svelte.d.ts +2 -2
- package/dist/components/Icons/Payment.svelte.d.ts +2 -2
- package/dist/components/Icons/PlusOutline.svelte +17 -0
- package/dist/components/Icons/PlusOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/PlusOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/Profile.svelte.d.ts +2 -2
- package/dist/components/Icons/Reload.svelte.d.ts +2 -2
- package/dist/components/Icons/SearchOutline.svelte +17 -0
- package/dist/components/Icons/SearchOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/SearchOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/ShareOutline.svelte +17 -0
- package/dist/components/Icons/ShareOutline.svelte.d.ts +27 -0
- package/dist/components/Icons/ShareOutline.svelte.d.ts.map +1 -0
- package/dist/components/Icons/Shows.svelte.d.ts +2 -2
- package/dist/components/Icons/Signout.svelte.d.ts +2 -2
- package/dist/components/Icons/SunIcon.svelte.d.ts +2 -2
- package/dist/components/Icons/TiktokIcon.svelte.d.ts +2 -2
- package/dist/components/Icons/TwitterIcon.svelte.d.ts +2 -2
- package/dist/components/Icons/index.d.ts +53 -0
- package/dist/components/Icons/index.d.ts.map +1 -0
- package/dist/components/Icons/index.js +59 -0
- package/dist/components/Input/Input.stories.svelte +7 -8
- package/dist/components/Input/Input.stories.svelte.d.ts +0 -53
- package/dist/components/Input/Input.stories.svelte.d.ts.map +1 -1
- package/dist/components/Input/Input.svelte +62 -467
- package/dist/components/Input/Input.svelte.d.ts +8 -8
- package/dist/components/Input/Input.svelte.d.ts.map +1 -1
- package/dist/components/Input/MultiSelect.stories.svelte +9 -12
- package/dist/components/Input/MultiSelect.stories.svelte.d.ts +0 -5
- package/dist/components/Input/MultiSelect.stories.svelte.d.ts.map +1 -1
- package/dist/components/Input/MultiSelect.svelte +43 -362
- package/dist/components/Input/MultiSelect.svelte.d.ts +6 -6
- package/dist/components/Input/MultiSelect.svelte.d.ts.map +1 -1
- package/dist/components/Input/OTPInput.stories.svelte +17 -20
- package/dist/components/Input/OTPInput.stories.svelte.d.ts +0 -21
- package/dist/components/Input/OTPInput.stories.svelte.d.ts.map +1 -1
- package/dist/components/Input/OTPInput.svelte +1 -20
- package/dist/components/Input/OTPInput.svelte.d.ts.map +1 -1
- package/dist/components/Input/Search.svelte +6 -101
- package/dist/components/Input/Search.svelte.d.ts +2 -2
- package/dist/components/Input/Search.svelte.d.ts.map +1 -1
- package/dist/components/Input/Select.svelte +28 -258
- package/dist/components/Input/Select.svelte.d.ts +6 -6
- package/dist/components/Input/Select.svelte.d.ts.map +1 -1
- package/dist/components/Input/Textarea.svelte +5 -90
- package/dist/components/Input/Textarea.svelte.d.ts +2 -2
- package/dist/components/Input/Textarea.svelte.d.ts.map +1 -1
- package/dist/components/Label/Label.svelte +8 -39
- package/dist/components/Label/Label.svelte.d.ts.map +1 -1
- package/dist/components/Layout/BottomNav.stories.svelte +27 -25
- package/dist/components/Layout/BottomNav.stories.svelte.d.ts +0 -5
- package/dist/components/Layout/BottomNav.stories.svelte.d.ts.map +1 -1
- package/dist/components/Layout/BottomNav.svelte +9 -72
- package/dist/components/Layout/BottomNav.svelte.d.ts.map +1 -1
- package/dist/components/Layout/Header.stories.svelte +7 -8
- package/dist/components/Layout/Header.stories.svelte.d.ts +0 -20
- package/dist/components/Layout/Header.stories.svelte.d.ts.map +1 -1
- package/dist/components/Layout/Header.svelte +59 -353
- package/dist/components/Layout/PageLayout.svelte +2 -2
- package/dist/components/Layout/PageLayout.svelte.d.ts +2 -2
- package/dist/components/Modal/ConfirmationModal.spec.js +3 -3
- package/dist/components/Modal/ConfirmationModal.stories.svelte +7 -12
- package/dist/components/Modal/ConfirmationModal.stories.svelte.d.ts +0 -19
- package/dist/components/Modal/ConfirmationModal.stories.svelte.d.ts.map +1 -1
- package/dist/components/Modal/ConfirmationModal.svelte +6 -6
- package/dist/components/Modal/ConfirmationModal.svelte.d.ts +4 -4
- package/dist/components/Modal/InputModal.svelte +3 -4
- package/dist/components/Modal/InputModal.svelte.d.ts +2 -2
- package/dist/components/Modal/Modal.stories.svelte +13 -11
- package/dist/components/Modal/Modal.stories.svelte.d.ts +0 -5
- package/dist/components/Modal/Modal.stories.svelte.d.ts.map +1 -1
- package/dist/components/Modal/Modal.svelte +22 -167
- package/dist/components/Modal/Modal.svelte.d.ts +2 -2
- package/dist/components/Modal/Modal.svelte.d.ts.map +1 -1
- package/dist/components/Modal/ModalStateManager.svelte +5 -5
- package/dist/components/Modal/StatusModal.svelte +11 -18
- package/dist/components/Modal/StatusModal.svelte.d.ts +2 -2
- package/dist/components/Modal/StatusModal.svelte.d.ts.map +1 -1
- package/dist/components/MonthSwitcher/MonthSwitcher.svelte +21 -99
- package/dist/components/MonthSwitcher/MonthSwitcher.svelte.d.ts.map +1 -1
- package/dist/components/OrderSummary/OrderSummary.svelte +45 -246
- package/dist/components/OrderSummary/OrderSummary.svelte.d.ts.map +1 -1
- package/dist/components/PageLoader.stories.svelte +7 -13
- package/dist/components/PageLoader.stories.svelte.d.ts +0 -26
- package/dist/components/PageLoader.stories.svelte.d.ts.map +1 -1
- package/dist/components/PageLoader.svelte +2 -2
- package/dist/components/Pagination/Pagination.svelte +167 -103
- package/dist/components/Pagination/Pagination.svelte.d.ts +8 -0
- package/dist/components/Pagination/Pagination.svelte.d.ts.map +1 -1
- package/dist/components/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +8 -8
- package/dist/components/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +3 -3
- package/dist/components/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +14 -17
- package/dist/components/PlaceAutocomplete/PlaceAutocomplete.stories.svelte.d.ts +0 -33
- package/dist/components/PlaceAutocomplete/PlaceAutocomplete.stories.svelte.d.ts.map +1 -1
- package/dist/components/PlaceAutocomplete/PlaceAutocomplete.svelte +31 -198
- package/dist/components/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
- package/dist/components/PublicCard/PublicCard.svelte +20 -128
- package/dist/components/PublicCard/PublicCard.svelte.d.ts.map +1 -1
- package/dist/components/Radio/Radio.svelte +21 -80
- package/dist/components/Radio/Radio.svelte.d.ts +4 -2
- package/dist/components/Radio/Radio.svelte.d.ts.map +1 -1
- package/dist/components/ShowCard/ShowCard.svelte +17 -91
- package/dist/components/ShowCard/ShowCard.svelte.d.ts.map +1 -1
- package/dist/components/ShowTimeCard/ShowTimeCard.svelte +6 -37
- package/dist/components/Skeleton/CardPlaceholder.svelte +98 -0
- package/dist/components/Skeleton/CardPlaceholder.svelte.d.ts +35 -0
- package/dist/components/Skeleton/CardPlaceholder.svelte.d.ts.map +1 -0
- package/dist/components/Skeleton/ImagePlaceholder.svelte +65 -0
- package/dist/components/{Button/ButtonAudit.stories.svelte.d.ts → Skeleton/ImagePlaceholder.svelte.d.ts} +13 -14
- package/dist/components/Skeleton/ImagePlaceholder.svelte.d.ts.map +1 -0
- package/dist/components/Skeleton/ListPlaceholder.svelte +86 -0
- package/dist/components/Skeleton/ListPlaceholder.svelte.d.ts +37 -0
- package/dist/components/Skeleton/ListPlaceholder.svelte.d.ts.map +1 -0
- package/dist/components/Skeleton/Skeleton.svelte +49 -60
- package/dist/components/Skeleton/Skeleton.svelte.d.ts +6 -10
- package/dist/components/Skeleton/Skeleton.svelte.d.ts.map +1 -1
- package/dist/components/Skeleton/index.d.ts +5 -0
- package/dist/components/Skeleton/index.d.ts.map +1 -0
- package/dist/components/Skeleton/index.js +10 -0
- package/dist/components/Spinner/Spinner.stories.svelte +9 -10
- package/dist/components/Spinner/Spinner.stories.svelte.d.ts +0 -4
- package/dist/components/Spinner/Spinner.stories.svelte.d.ts.map +1 -1
- package/dist/components/Spinner/Spinner.svelte +41 -64
- package/dist/components/Spinner/Spinner.svelte.d.ts +6 -4
- package/dist/components/Spinner/Spinner.svelte.d.ts.map +1 -1
- package/dist/components/StatusIndicator/StatusIndicator.svelte +13 -47
- package/dist/components/StatusIndicator/StatusIndicator.svelte.d.ts.map +1 -1
- package/dist/components/Tabs/TabItem.svelte +3 -9
- package/dist/components/Tabs/TabItem.svelte.d.ts.map +1 -1
- package/dist/components/Tabs/Tabs.svelte +49 -126
- package/dist/components/Tabs/Tabs.svelte.d.ts +2 -2
- package/dist/components/Tabs/Tabs.svelte.d.ts.map +1 -1
- package/dist/components/Toaster/Toaster.stories.svelte +15 -13
- package/dist/components/Toaster/Toaster.stories.svelte.d.ts +0 -3
- package/dist/components/Toaster/Toaster.stories.svelte.d.ts.map +1 -1
- package/dist/components/Toggle.spec.js +21 -52
- package/dist/components/Toggle.stories.svelte +14 -15
- package/dist/components/Toggle.stories.svelte.d.ts +0 -14
- package/dist/components/Toggle.stories.svelte.d.ts.map +1 -1
- package/dist/components/Toggle.svelte +47 -67
- package/dist/components/Toggle.svelte.d.ts +21 -4
- package/dist/components/Toggle.svelte.d.ts.map +1 -1
- package/dist/components/Typography/Typography.svelte.d.ts +4 -4
- package/dist/components/ValidationError.stories.svelte +8 -9
- package/dist/components/ValidationError.stories.svelte.d.ts +0 -14
- package/dist/components/ValidationError.stories.svelte.d.ts.map +1 -1
- package/dist/components/ValidationError.svelte +1 -1
- package/dist/components/pages/performers/ModalShowInfo.svelte +7 -61
- package/dist/components/pages/performers/ModalShowInfo.svelte.d.ts.map +1 -1
- package/dist/components/pages/performers/PageBackButton.spec.js +1 -1
- package/dist/components/pages/performers/PageBackButton.stories.svelte +7 -8
- package/dist/components/pages/performers/PageBackButton.stories.svelte.d.ts +0 -9
- package/dist/components/pages/performers/PageBackButton.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/performers/PageBackButton.svelte +1 -1
- package/dist/components/pages/performers/SectionHeader.spec.js +2 -2
- package/dist/components/pages/performers/SectionHeader.stories.svelte +13 -14
- package/dist/components/pages/performers/SectionHeader.stories.svelte.d.ts +0 -14
- package/dist/components/pages/performers/SectionHeader.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/performers/SectionHeader.svelte +2 -2
- package/dist/components/pages/performers/ShowDetails.spec.js +2 -2
- package/dist/components/pages/performers/ShowDetails.stories.svelte +9 -12
- package/dist/components/pages/performers/ShowDetails.stories.svelte.d.ts +0 -10
- package/dist/components/pages/performers/ShowDetails.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/performers/ShowDetails.svelte +11 -11
- package/dist/components/pages/performers/ShowDetails.svelte.d.ts +2 -2
- package/dist/components/pages/performers/ShowItemCard.spec.js +1 -1
- package/dist/components/pages/performers/ShowItemCard.stories.svelte +7 -5
- package/dist/components/pages/performers/ShowItemCard.stories.svelte.d.ts +0 -16
- package/dist/components/pages/performers/ShowItemCard.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/performers/ShowItemCard.svelte +52 -61
- package/dist/components/pages/performers/ShowItemCard.svelte.d.ts +4 -4
- package/dist/components/pages/performers/SwitchOption.stories.svelte +7 -10
- package/dist/components/pages/performers/SwitchOption.stories.svelte.d.ts +0 -13
- package/dist/components/pages/performers/SwitchOption.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/performers/SwitchOption.svelte +3 -3
- package/dist/components/pages/performers/VenueInfo.svelte +6 -60
- package/dist/components/pages/performers/VenueInfo.svelte.d.ts.map +1 -1
- package/dist/components/pages/performers/VenueItemCard.stories.svelte +10 -8
- package/dist/components/pages/performers/VenueItemCard.stories.svelte.d.ts +0 -10
- package/dist/components/pages/performers/VenueItemCard.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/performers/VenueItemCard.svelte +16 -15
- package/dist/components/pages/performers/VenueItemCard.svelte.d.ts +2 -2
- package/dist/components/pages/performers/VenueItemCard.svelte.d.ts.map +1 -1
- package/dist/components/pages/profile/profile-form.stories.svelte +7 -10
- package/dist/components/pages/profile/profile-form.stories.svelte.d.ts +0 -21
- package/dist/components/pages/profile/profile-form.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/profile/profile-form.svelte +21 -74
- package/dist/components/pages/profile/profile-form.svelte.d.ts.map +1 -1
- package/dist/components/pages/profile/profile-photos.stories.svelte +7 -14
- package/dist/components/pages/profile/profile-photos.stories.svelte.d.ts +0 -4
- package/dist/components/pages/profile/profile-photos.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/profile/profile-photos.svelte +1 -1
- package/dist/components/pages/settings/tabs/CustomImageDropzone.stories.svelte +11 -12
- package/dist/components/pages/settings/tabs/CustomImageDropzone.stories.svelte.d.ts +0 -22
- package/dist/components/pages/settings/tabs/CustomImageDropzone.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/settings/tabs/CustomImageDropzone.svelte +12 -12
- package/dist/components/pages/shows/ShowList.stories.svelte +7 -10
- package/dist/components/pages/shows/ShowList.stories.svelte.d.ts +0 -14
- package/dist/components/pages/shows/ShowList.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/shows/TabContent.stories.svelte +7 -10
- package/dist/components/pages/shows/TabContent.stories.svelte.d.ts +0 -18
- package/dist/components/pages/shows/TabContent.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/shows/TabContent.svelte +4 -13
- package/dist/components/pages/shows/TabContent.svelte.d.ts.map +1 -1
- package/dist/components/pages/shows/TabNavigation.stories.svelte +19 -22
- package/dist/components/pages/shows/TabNavigation.stories.svelte.d.ts +0 -14
- package/dist/components/pages/shows/TabNavigation.stories.svelte.d.ts.map +1 -1
- package/dist/components/pages/shows/TabNavigation.svelte +1 -34
- package/dist/components/pages/shows/TabNavigation.svelte.d.ts.map +1 -1
- package/dist/index.d.ts +3 -0
- package/dist/index.js +3 -0
- package/package.json +2 -5
- package/dist/components/Alert/AlertAudit.stories.svelte +0 -241
- package/dist/components/Alert/AlertAudit.stories.svelte.d.ts.map +0 -1
- package/dist/components/Badges/BadgeAudit.stories.svelte +0 -238
- package/dist/components/Badges/BadgeAudit.stories.svelte.d.ts.map +0 -1
- package/dist/components/Button/ButtonAudit.stories.svelte +0 -333
- package/dist/components/Button/ButtonAudit.stories.svelte.d.ts.map +0 -1
- package/dist/components/CardAudit.stories.svelte +0 -175
- package/dist/components/CardAudit.stories.svelte.d.ts.map +0 -1
- package/dist/components/Input/InputAudit.stories.svelte +0 -483
- package/dist/components/Input/InputAudit.stories.svelte.d.ts.map +0 -1
- package/dist/components/Input/SelectAudit.stories.svelte +0 -364
- package/dist/components/Input/SelectAudit.stories.svelte.d.ts +0 -32
- package/dist/components/Input/SelectAudit.stories.svelte.d.ts.map +0 -1
- package/dist/components/Modal/ModalAudit.stories.svelte +0 -329
- package/dist/components/Modal/ModalAudit.stories.svelte.d.ts +0 -32
- package/dist/components/Modal/ModalAudit.stories.svelte.d.ts.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DropdownItem.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/components/Dropdown/DropdownItem.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"DropdownItem.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/components/Dropdown/DropdownItem.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;AA+EA;;;WAjBW,MAAM,GAAC,SAAS;;;;;;;;;eAiBgI;sCATrH,KAAK,EAAE,KAAK;;;;;6CALL,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,OAAO,OAAO,QAAQ;IAC3L,cAAc,OAAO,QAAQ,EAAE,2BAA2B,CAAC,KAAK,CAAC,GAAG,OAAO,QAAQ,EAAE,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,GAAG;QAAE,UAAU,CAAC,EAAE,QAAQ,CAAA;KAAE,GAAG,OAAO,CAAC;IACjK,WAAW,OAAO,SAAS,KAAK,GAAG;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,KAAK,CAAA;KAAC,GAAG,OAAO,GAAG;QAAE,IAAI,CAAC,EAAE,GAAG,CAAC;QAAC,GAAG,CAAC,EAAE,GAAG,CAAA;KAAE,CAAC;IAC9G,eAAe,QAAQ,CAAC"}
|
|
@@ -12,6 +12,7 @@
|
|
|
12
12
|
* />
|
|
13
13
|
*/
|
|
14
14
|
import { createEventDispatcher, onMount, onDestroy, tick } from "svelte";
|
|
15
|
+
import { ChevronDownOutline } from "../Icons";
|
|
15
16
|
|
|
16
17
|
/** @type {Array<{label: string, value: string}>} Options to display */
|
|
17
18
|
export let options = [];
|
|
@@ -30,6 +31,7 @@
|
|
|
30
31
|
let isOpen = false;
|
|
31
32
|
let triggerRef;
|
|
32
33
|
let menuRef;
|
|
34
|
+
let containerRef;
|
|
33
35
|
let focusedIndex = -1;
|
|
34
36
|
let optionElements = [];
|
|
35
37
|
|
|
@@ -64,15 +66,17 @@
|
|
|
64
66
|
triggerRef?.focus();
|
|
65
67
|
}
|
|
66
68
|
|
|
69
|
+
// CRITICAL FIX: Click-outside detection using mousedown for reliable detection
|
|
67
70
|
function handleClickOutside(event) {
|
|
68
|
-
if (
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
) {
|
|
74
|
-
isOpen = false;
|
|
71
|
+
if (!isOpen) return;
|
|
72
|
+
|
|
73
|
+
// Check if click is inside the container (trigger or menu)
|
|
74
|
+
if (containerRef && containerRef.contains(event.target)) {
|
|
75
|
+
return;
|
|
75
76
|
}
|
|
77
|
+
|
|
78
|
+
// Click was outside - close the dropdown
|
|
79
|
+
isOpen = false;
|
|
76
80
|
}
|
|
77
81
|
|
|
78
82
|
function handleKeyDown(event) {
|
|
@@ -113,189 +117,59 @@
|
|
|
113
117
|
|
|
114
118
|
onMount(() => {
|
|
115
119
|
if (typeof window !== "undefined") {
|
|
116
|
-
|
|
117
|
-
|
|
120
|
+
// Use mousedown for click-outside to capture before click completes
|
|
121
|
+
document.addEventListener("mousedown", handleClickOutside, true);
|
|
122
|
+
document.addEventListener("keydown", handleKeyDown);
|
|
118
123
|
}
|
|
119
124
|
});
|
|
120
125
|
|
|
121
126
|
onDestroy(() => {
|
|
122
127
|
if (typeof window !== "undefined") {
|
|
123
|
-
|
|
124
|
-
|
|
128
|
+
document.removeEventListener("mousedown", handleClickOutside, true);
|
|
129
|
+
document.removeEventListener("keydown", handleKeyDown);
|
|
125
130
|
}
|
|
126
131
|
});
|
|
127
132
|
</script>
|
|
128
133
|
|
|
129
|
-
<div class="
|
|
134
|
+
<div bind:this={containerRef} class="relative inline-block text-left {className}">
|
|
130
135
|
<button
|
|
131
136
|
bind:this={triggerRef}
|
|
132
137
|
type="button"
|
|
133
|
-
class="
|
|
134
|
-
class:select-dropdown__trigger--disabled={disabled}
|
|
138
|
+
class="inline-flex items-center justify-between w-full px-4 py-2.5 text-sm font-medium text-gray-900 bg-white border border-gray-300 rounded-lg hover:bg-gray-100 focus:ring-4 focus:outline-none focus:ring-blue-300 dark:bg-gray-700 dark:text-white dark:border-gray-600 dark:hover:bg-gray-600 dark:focus:ring-blue-800 {disabled ? 'opacity-50 cursor-not-allowed' : ''}"
|
|
135
139
|
on:click|preventDefault={toggleDropdown}
|
|
136
140
|
aria-haspopup="listbox"
|
|
137
141
|
aria-expanded={isOpen}
|
|
138
142
|
aria-label={placeholder}
|
|
139
143
|
{disabled}
|
|
140
144
|
>
|
|
141
|
-
<span class="
|
|
145
|
+
<span class="truncate">
|
|
142
146
|
{selected?.label || placeholder}
|
|
143
147
|
</span>
|
|
144
|
-
<
|
|
145
|
-
class="select-dropdown__icon"
|
|
146
|
-
class:select-dropdown__icon--open={isOpen}
|
|
147
|
-
fill="none"
|
|
148
|
-
stroke="currentColor"
|
|
149
|
-
viewBox="0 0 24 24"
|
|
150
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
151
|
-
>
|
|
152
|
-
<path
|
|
153
|
-
stroke-linecap="round"
|
|
154
|
-
stroke-linejoin="round"
|
|
155
|
-
stroke-width="2"
|
|
156
|
-
d="M19 9l-7 7-7-7"
|
|
157
|
-
/>
|
|
158
|
-
</svg>
|
|
148
|
+
<ChevronDownOutline class="w-4 h-4 ml-2 transition-transform duration-200 {isOpen ? 'rotate-180' : ''}" />
|
|
159
149
|
</button>
|
|
160
150
|
|
|
161
151
|
{#if isOpen}
|
|
162
152
|
<div
|
|
163
153
|
bind:this={menuRef}
|
|
164
|
-
class="
|
|
154
|
+
class="absolute z-10 mt-1 w-full bg-white divide-y divide-gray-100 rounded-lg shadow-lg dark:bg-gray-700 dark:divide-gray-600 max-h-60 overflow-y-auto"
|
|
165
155
|
role="listbox"
|
|
166
156
|
aria-label={placeholder}
|
|
167
157
|
>
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
158
|
+
<ul class="py-2 text-sm text-gray-700 dark:text-gray-200">
|
|
159
|
+
{#each options as option}
|
|
160
|
+
<li>
|
|
161
|
+
<button
|
|
162
|
+
type="button"
|
|
163
|
+
class="block w-full text-left px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white {selected?.value === option.value ? 'bg-blue-50 text-blue-700 dark:bg-gray-600 dark:text-white' : ''}"
|
|
164
|
+
on:click|preventDefault={() => selectOption(option)}
|
|
165
|
+
role="option"
|
|
166
|
+
aria-selected={selected?.value === option.value}
|
|
167
|
+
>
|
|
168
|
+
{option.label}
|
|
169
|
+
</button>
|
|
170
|
+
</li>
|
|
171
|
+
{/each}
|
|
172
|
+
</ul>
|
|
180
173
|
</div>
|
|
181
174
|
{/if}
|
|
182
175
|
</div>
|
|
183
|
-
|
|
184
|
-
<style>
|
|
185
|
-
.select-dropdown {
|
|
186
|
-
position: relative;
|
|
187
|
-
display: inline-block;
|
|
188
|
-
font-size: 0.75rem;
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
.select-dropdown__trigger {
|
|
192
|
-
display: flex;
|
|
193
|
-
align-items: center;
|
|
194
|
-
padding: 0.5rem 1rem;
|
|
195
|
-
text-align: left;
|
|
196
|
-
background-color: hsl(var(--BG-Primary, 0 0% 100%));
|
|
197
|
-
color: hsl(var(--Text-Primary, 220 13% 13%));
|
|
198
|
-
border: 1px solid hsl(var(--Stroke-Primary, 220 13% 85%));
|
|
199
|
-
border-radius: 0.375rem;
|
|
200
|
-
box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
|
|
201
|
-
cursor: pointer;
|
|
202
|
-
transition: border-color 0.15s ease, box-shadow 0.15s ease;
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
.select-dropdown__trigger:hover:not(:disabled) {
|
|
206
|
-
border-color: hsl(var(--Stroke-Secondary, 220 13% 75%));
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
.select-dropdown__trigger:focus {
|
|
210
|
-
outline: none;
|
|
211
|
-
border-color: hsl(var(--Brand-Primary, 221 83% 53%));
|
|
212
|
-
box-shadow: 0 0 0 2px hsl(var(--Brand-Primary, 221 83% 53%) / 0.2);
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
.select-dropdown__trigger--disabled {
|
|
216
|
-
opacity: 0.5;
|
|
217
|
-
cursor: not-allowed;
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
.select-dropdown__value {
|
|
221
|
-
flex: 1;
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
.select-dropdown__icon {
|
|
225
|
-
width: 1rem;
|
|
226
|
-
height: 1rem;
|
|
227
|
-
margin-left: 0.5rem;
|
|
228
|
-
transition: transform 0.15s ease;
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
.select-dropdown__icon--open {
|
|
232
|
-
transform: rotate(180deg);
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
.select-dropdown__menu {
|
|
236
|
-
position: absolute;
|
|
237
|
-
top: 100%;
|
|
238
|
-
left: 0;
|
|
239
|
-
z-index: 50;
|
|
240
|
-
display: flex;
|
|
241
|
-
flex-direction: column;
|
|
242
|
-
min-width: 100%;
|
|
243
|
-
margin-top: 0.25rem;
|
|
244
|
-
background-color: hsl(var(--BG-Primary, 0 0% 100%));
|
|
245
|
-
border: 1px solid hsl(var(--Stroke-Primary, 220 13% 85%));
|
|
246
|
-
border-radius: 0.375rem;
|
|
247
|
-
box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
|
|
248
|
-
max-height: 200px;
|
|
249
|
-
overflow-y: auto;
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
.select-dropdown__menu::-webkit-scrollbar {
|
|
253
|
-
display: none;
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
.select-dropdown__option {
|
|
257
|
-
width: 100%;
|
|
258
|
-
padding: 0.5rem 1rem;
|
|
259
|
-
text-align: left;
|
|
260
|
-
background: transparent;
|
|
261
|
-
border: none;
|
|
262
|
-
color: hsl(var(--Text-Primary, 220 13% 13%));
|
|
263
|
-
cursor: pointer;
|
|
264
|
-
transition: background-color 0.15s ease;
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
.select-dropdown__option:hover {
|
|
268
|
-
background-color: hsl(var(--BG-Secondary, 220 14% 96%));
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
.select-dropdown__option:focus {
|
|
272
|
-
outline: none;
|
|
273
|
-
background-color: hsl(var(--BG-Secondary, 220 14% 96%));
|
|
274
|
-
}
|
|
275
|
-
|
|
276
|
-
.select-dropdown__option--selected {
|
|
277
|
-
background-color: hsl(var(--Brand-Primary, 221 83% 53%) / 0.1);
|
|
278
|
-
color: hsl(var(--Brand-Primary, 221 83% 53%));
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
/* Dark mode */
|
|
282
|
-
:global(.dark) .select-dropdown__trigger {
|
|
283
|
-
background-color: hsl(var(--BG-Primary, 220 13% 15%));
|
|
284
|
-
color: hsl(var(--Text-Primary, 0 0% 95%));
|
|
285
|
-
border-color: hsl(var(--Stroke-Primary, 220 13% 30%));
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
:global(.dark) .select-dropdown__menu {
|
|
289
|
-
background-color: hsl(var(--BG-Primary, 220 13% 15%));
|
|
290
|
-
border-color: hsl(var(--Stroke-Primary, 220 13% 30%));
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
:global(.dark) .select-dropdown__option {
|
|
294
|
-
color: hsl(var(--Text-Primary, 0 0% 95%));
|
|
295
|
-
}
|
|
296
|
-
|
|
297
|
-
:global(.dark) .select-dropdown__option:hover,
|
|
298
|
-
:global(.dark) .select-dropdown__option:focus {
|
|
299
|
-
background-color: hsl(var(--BG-Secondary, 220 13% 20%));
|
|
300
|
-
}
|
|
301
|
-
</style>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectDropdown.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/components/Dropdown/SelectDropdown.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"SelectDropdown.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/components/Dropdown/SelectDropdown.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;AAmLA;;;;eAdyB,MAAM;eAAS,MAAM;;;eAC3B,MAAM;eAAS,MAAM;;;;;;;mBAa2I;6CATtI,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,OAAO,OAAO,QAAQ;IAC3L,cAAc,OAAO,QAAQ,EAAE,2BAA2B,CAAC,KAAK,CAAC,GAAG,OAAO,QAAQ,EAAE,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,GAAG;QAAE,UAAU,CAAC,EAAE,QAAQ,CAAA;KAAE,GAAG,OAAO,CAAC;IACjK,WAAW,OAAO,SAAS,KAAK,GAAG;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,KAAK,CAAA;KAAC,GAAG,OAAO,GAAG;QAAE,IAAI,CAAC,EAAE,GAAG,CAAC;QAAC,GAAG,CAAC,EAAE,GAAG,CAAA;KAAE,CAAC;IAC9G,eAAe,QAAQ,CAAC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
<script>
|
|
2
2
|
/**
|
|
3
3
|
* EmptyState - Display an empty state message with optional icon
|
|
4
|
+
* Follows Flowbite card/alert pattern for empty states
|
|
4
5
|
*
|
|
5
6
|
* @example
|
|
6
7
|
* <EmptyState message="No results found" />
|
|
@@ -22,59 +23,17 @@
|
|
|
22
23
|
export { className as class };
|
|
23
24
|
</script>
|
|
24
25
|
|
|
25
|
-
<div class="
|
|
26
|
+
<div class="flex flex-col items-center justify-center px-6 py-10 text-center {className}">
|
|
26
27
|
{#if icon}
|
|
27
28
|
{#if iconType === 'component'}
|
|
28
|
-
<svelte:component this={icon} class="
|
|
29
|
+
<svelte:component this={icon} class="mb-3 text-gray-400 dark:text-gray-500 {iconSize}" />
|
|
29
30
|
{:else if iconType === 'image'}
|
|
30
|
-
<img src={icon} alt="" class="
|
|
31
|
+
<img src={icon} alt="" class="mb-3 {iconSize}" />
|
|
31
32
|
{/if}
|
|
32
33
|
{/if}
|
|
33
34
|
|
|
34
|
-
<h3 class="
|
|
35
|
+
<h3 class="text-lg font-semibold text-gray-900 dark:text-white">{message}</h3>
|
|
35
36
|
{#if subtext}
|
|
36
|
-
<p class="
|
|
37
|
+
<p class="mt-1 text-sm text-gray-500 dark:text-gray-400">{subtext}</p>
|
|
37
38
|
{/if}
|
|
38
39
|
</div>
|
|
39
|
-
|
|
40
|
-
<style>
|
|
41
|
-
.empty-state {
|
|
42
|
-
display: flex;
|
|
43
|
-
flex-direction: column;
|
|
44
|
-
align-items: center;
|
|
45
|
-
justify-content: center;
|
|
46
|
-
padding: 2.5rem 1.5rem;
|
|
47
|
-
text-align: center;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
.empty-state__icon {
|
|
51
|
-
margin-bottom: 0.75rem;
|
|
52
|
-
color: hsl(var(--Text-Tertiary, 220 9% 46%));
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
.empty-state__message {
|
|
56
|
-
font-size: 1.125rem;
|
|
57
|
-
font-weight: 600;
|
|
58
|
-
color: hsl(var(--Text-Primary, 220 13% 18%));
|
|
59
|
-
margin: 0;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
.empty-state__subtext {
|
|
63
|
-
font-size: 0.875rem;
|
|
64
|
-
color: hsl(var(--Text-Secondary, 220 9% 46%));
|
|
65
|
-
margin: 0.25rem 0 0;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/* Dark mode */
|
|
69
|
-
:global(.dark) .empty-state__icon {
|
|
70
|
-
color: hsl(var(--Text-Tertiary, 220 9% 60%));
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
:global(.dark) .empty-state__message {
|
|
74
|
-
color: hsl(var(--Text-Primary, 0 0% 95%));
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
:global(.dark) .empty-state__subtext {
|
|
78
|
-
color: hsl(var(--Text-Secondary, 220 9% 70%));
|
|
79
|
-
}
|
|
80
|
-
</style>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EmptyState.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/components/EmptyState/EmptyState.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"EmptyState.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/components/EmptyState/EmptyState.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;AA4DA;;;WAbW,GAAG;;;;;;mBAaoK;6CATrI,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,OAAO,OAAO,QAAQ;IAC3L,cAAc,OAAO,QAAQ,EAAE,2BAA2B,CAAC,KAAK,CAAC,GAAG,OAAO,QAAQ,EAAE,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,GAAG;QAAE,UAAU,CAAC,EAAE,QAAQ,CAAA;KAAE,GAAG,OAAO,CAAC;IACjK,WAAW,OAAO,SAAS,KAAK,GAAG;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,KAAK,CAAA;KAAC,GAAG,OAAO,GAAG;QAAE,IAAI,CAAC,EAAE,GAAG,CAAC;QAAC,GAAG,CAAC,EAAE,GAAG,CAAA;KAAE,CAAC;IAC9G,eAAe,QAAQ,CAAC"}
|
|
@@ -23,7 +23,7 @@ describe("ErrorDisplay Component Tests", () => {
|
|
|
23
23
|
props: { error: "Error", show: true },
|
|
24
24
|
});
|
|
25
25
|
const wrapper = container.firstChild;
|
|
26
|
-
expect(wrapper).toHaveClass("text-
|
|
26
|
+
expect(wrapper).toHaveClass("text-red-600");
|
|
27
27
|
});
|
|
28
28
|
|
|
29
29
|
test("Has shake class when shake is true", () => {
|
|
@@ -31,7 +31,7 @@ describe("ErrorDisplay Component Tests", () => {
|
|
|
31
31
|
props: { error: "Error", show: true, shake: true },
|
|
32
32
|
});
|
|
33
33
|
const wrapper = container.firstChild;
|
|
34
|
-
expect(wrapper).toHaveClass("
|
|
34
|
+
expect(wrapper).toHaveClass("animate-shake");
|
|
35
35
|
});
|
|
36
36
|
|
|
37
37
|
test("Does not have shake class when shake is false", () => {
|
|
@@ -39,7 +39,7 @@ describe("ErrorDisplay Component Tests", () => {
|
|
|
39
39
|
props: { error: "Error", show: true, shake: false },
|
|
40
40
|
});
|
|
41
41
|
const wrapper = container.firstChild;
|
|
42
|
-
expect(wrapper).not.toHaveClass("
|
|
42
|
+
expect(wrapper).not.toHaveClass("animate-shake");
|
|
43
43
|
});
|
|
44
44
|
|
|
45
45
|
test("Contains icon element", () => {
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
<script
|
|
1
|
+
<script module>
|
|
2
|
+
import { defineMeta } from "@storybook/addon-svelte-csf";
|
|
3
|
+
|
|
2
4
|
import ErrorDisplay from './ErrorDisplay.svelte';
|
|
3
5
|
|
|
4
|
-
|
|
6
|
+
const { Story } = defineMeta({
|
|
5
7
|
title: 'Components/ErrorDisplay',
|
|
6
8
|
component: ErrorDisplay,
|
|
7
9
|
tags: ['autodocs'],
|
|
@@ -27,12 +29,12 @@
|
|
|
27
29
|
description: 'Size of the icon',
|
|
28
30
|
},
|
|
29
31
|
},
|
|
30
|
-
};
|
|
32
|
+
});
|
|
33
|
+
|
|
31
34
|
</script>
|
|
32
35
|
|
|
33
36
|
<script>
|
|
34
|
-
|
|
35
|
-
|
|
37
|
+
|
|
36
38
|
let showShakeDemo = false;
|
|
37
39
|
function triggerShake() {
|
|
38
40
|
showShakeDemo = false;
|
|
@@ -42,9 +44,6 @@
|
|
|
42
44
|
}
|
|
43
45
|
</script>
|
|
44
46
|
|
|
45
|
-
<Template let:args>
|
|
46
|
-
<ErrorDisplay {...args} />
|
|
47
|
-
</Template>
|
|
48
47
|
|
|
49
48
|
<Story
|
|
50
49
|
name="Default"
|
|
@@ -67,7 +66,7 @@
|
|
|
67
66
|
<Story name="Interactive Shake">
|
|
68
67
|
<div class="space-y-4">
|
|
69
68
|
<button
|
|
70
|
-
class="px-4 py-2 bg-blue-500 text-white rounded hover:bg-
|
|
69
|
+
class="px-4 py-2 bg-blue-500 text-white rounded hover:bg-primary"
|
|
71
70
|
on:click={triggerShake}
|
|
72
71
|
>
|
|
73
72
|
Trigger Error Shake
|
|
@@ -1,38 +1,3 @@
|
|
|
1
|
-
export namespace meta {
|
|
2
|
-
export let title: string;
|
|
3
|
-
export { ErrorDisplay as component };
|
|
4
|
-
export let tags: string[];
|
|
5
|
-
export namespace argTypes {
|
|
6
|
-
namespace error {
|
|
7
|
-
let control: string;
|
|
8
|
-
let description: string;
|
|
9
|
-
}
|
|
10
|
-
namespace show {
|
|
11
|
-
let control_1: string;
|
|
12
|
-
export { control_1 as control };
|
|
13
|
-
let description_1: string;
|
|
14
|
-
export { description_1 as description };
|
|
15
|
-
}
|
|
16
|
-
namespace shake {
|
|
17
|
-
let control_2: string;
|
|
18
|
-
export { control_2 as control };
|
|
19
|
-
let description_2: string;
|
|
20
|
-
export { description_2 as description };
|
|
21
|
-
}
|
|
22
|
-
namespace icon {
|
|
23
|
-
let control_3: string;
|
|
24
|
-
export { control_3 as control };
|
|
25
|
-
let description_3: string;
|
|
26
|
-
export { description_3 as description };
|
|
27
|
-
}
|
|
28
|
-
namespace iconSize {
|
|
29
|
-
let control_4: string;
|
|
30
|
-
export { control_4 as control };
|
|
31
|
-
let description_4: string;
|
|
32
|
-
export { description_4 as description };
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
1
|
export default ErrorDisplay;
|
|
37
2
|
type ErrorDisplay = SvelteComponent<{
|
|
38
3
|
[x: string]: never;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ErrorDisplay.stories.svelte.d.ts","sourceRoot":"","sources":["../../src/lib/components/ErrorDisplay.stories.svelte.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ErrorDisplay.stories.svelte.d.ts","sourceRoot":"","sources":["../../src/lib/components/ErrorDisplay.stories.svelte.js"],"names":[],"mappings":";;;;;;;;AAyGA;;;;mBAAwH;yBApG7F,uBAAuB;6CA2FL,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,OAAO,OAAO,QAAQ;IAC3L,cAAc,OAAO,QAAQ,EAAE,2BAA2B,CAAC,KAAK,CAAC,GAAG,OAAO,QAAQ,EAAE,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,GAAG;QAAE,UAAU,CAAC,EAAE,QAAQ,CAAA;KAAE,GAAG,OAAO,CAAC;IACjK,WAAW,OAAO,SAAS;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,KAAK,CAAA;KAAC,GAAG,OAAO,GAAG;QAAE,IAAI,CAAC,EAAE,GAAG,CAAC;QAAC,GAAG,CAAC,EAAE,GAAG,CAAA;KAAE,CAAC;IACtG,eAAe,QAAQ,CAAC"}
|
|
@@ -22,37 +22,9 @@
|
|
|
22
22
|
|
|
23
23
|
{#if error && show}
|
|
24
24
|
<div
|
|
25
|
-
class="flex items-center gap-1.5 text-
|
|
26
|
-
? 'error-shake'
|
|
27
|
-
: ''} {className}"
|
|
25
|
+
class="flex items-center gap-1.5 text-red-600 dark:text-red-500 {shake ? 'animate-shake' : ''} {className}"
|
|
28
26
|
>
|
|
29
27
|
<Icon name={icon} size={iconSize} />
|
|
30
28
|
<p class="text-sm font-medium">{error}</p>
|
|
31
29
|
</div>
|
|
32
30
|
{/if}
|
|
33
|
-
|
|
34
|
-
<style>
|
|
35
|
-
@keyframes shake {
|
|
36
|
-
0%,
|
|
37
|
-
100% {
|
|
38
|
-
transform: translateX(0);
|
|
39
|
-
}
|
|
40
|
-
10%,
|
|
41
|
-
30%,
|
|
42
|
-
50%,
|
|
43
|
-
70%,
|
|
44
|
-
90% {
|
|
45
|
-
transform: translateX(-4px);
|
|
46
|
-
}
|
|
47
|
-
20%,
|
|
48
|
-
40%,
|
|
49
|
-
60%,
|
|
50
|
-
80% {
|
|
51
|
-
transform: translateX(4px);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
.error-shake {
|
|
56
|
-
animation: shake 0.625s ease-in-out;
|
|
57
|
-
}
|
|
58
|
-
</style>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ErrorDisplay.svelte.d.ts","sourceRoot":"","sources":["../../src/lib/components/ErrorDisplay.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"ErrorDisplay.svelte.d.ts","sourceRoot":"","sources":["../../src/lib/components/ErrorDisplay.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;AAmDA;;;;;;;;;mBAAgL;6CATnI,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,OAAO,OAAO,QAAQ;IAC3L,cAAc,OAAO,QAAQ,EAAE,2BAA2B,CAAC,KAAK,CAAC,GAAG,OAAO,QAAQ,EAAE,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,GAAG;QAAE,UAAU,CAAC,EAAE,QAAQ,CAAA;KAAE,GAAG,OAAO,CAAC;IACjK,WAAW,OAAO,SAAS,KAAK,GAAG;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,KAAK,CAAA;KAAC,GAAG,OAAO,GAAG;QAAE,IAAI,CAAC,EAAE,GAAG,CAAC;QAAC,GAAG,CAAC,EAAE,GAAG,CAAA;KAAE,CAAC;IAC9G,eAAe,QAAQ,CAAC"}
|
|
@@ -1,49 +1,79 @@
|
|
|
1
1
|
<script>
|
|
2
|
+
import { ChevronUpOutline } from "../Icons";
|
|
3
|
+
|
|
4
|
+
/** @type {Array<{question: string, answer: string} | string>} */
|
|
2
5
|
export let faqs = [];
|
|
6
|
+
/** @type {string} */
|
|
3
7
|
export let title = "FAQs";
|
|
8
|
+
/** @type {boolean} */
|
|
4
9
|
export let showTitle = true;
|
|
10
|
+
/** @type {boolean} - Whether to use accordion style (collapsible) or simple list */
|
|
11
|
+
export let accordion = false;
|
|
12
|
+
|
|
13
|
+
/** @type {number | null} - Currently open accordion item index */
|
|
14
|
+
let openIndex = null;
|
|
5
15
|
|
|
6
|
-
$: items = faqs.map(f =>
|
|
16
|
+
$: items = faqs.map((f) =>
|
|
7
17
|
typeof f === 'string' ? { question: '', answer: f } : f
|
|
8
18
|
);
|
|
19
|
+
|
|
20
|
+
function toggleAccordion(index) {
|
|
21
|
+
openIndex = openIndex === index ? null : index;
|
|
22
|
+
}
|
|
9
23
|
</script>
|
|
10
24
|
|
|
11
25
|
<div class="flex flex-col gap-3">
|
|
12
26
|
{#if showTitle}
|
|
13
|
-
<h2 class="
|
|
27
|
+
<h2 class="text-xl font-medium text-gray-900 dark:text-white">{title}</h2>
|
|
14
28
|
{/if}
|
|
15
29
|
|
|
16
30
|
{#if items.length}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
31
|
+
{#if accordion}
|
|
32
|
+
<!-- Flowbite Accordion Pattern -->
|
|
33
|
+
<div class="border border-gray-200 rounded-lg dark:border-gray-700">
|
|
34
|
+
{#each items as { question, answer }, index}
|
|
35
|
+
<div>
|
|
36
|
+
<h3>
|
|
37
|
+
<button
|
|
38
|
+
type="button"
|
|
39
|
+
class="flex items-center justify-between w-full p-5 font-medium text-left text-gray-500 border-b border-gray-200 hover:bg-gray-100 focus:ring-4 focus:ring-gray-200 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-800 dark:focus:ring-gray-800 gap-3
|
|
40
|
+
{index === 0 ? 'rounded-t-lg' : ''}
|
|
41
|
+
{index === items.length - 1 && openIndex !== index ? 'border-b-0 rounded-b-lg' : ''}
|
|
42
|
+
{openIndex === index ? 'text-gray-900 bg-gray-100 dark:bg-gray-800 dark:text-white' : ''}"
|
|
43
|
+
on:click={() => toggleAccordion(index)}
|
|
44
|
+
aria-expanded={openIndex === index}
|
|
45
|
+
aria-controls="accordion-body-{index}"
|
|
46
|
+
>
|
|
47
|
+
<span>{question || `Item ${index + 1}`}</span>
|
|
48
|
+
<ChevronUpOutline class="w-3 h-3 shrink-0 transition-transform duration-200 {openIndex === index ? 'rotate-180' : ''}" aria-hidden="true" />
|
|
49
|
+
</button>
|
|
50
|
+
</h3>
|
|
51
|
+
<div
|
|
52
|
+
id="accordion-body-{index}"
|
|
53
|
+
class="{openIndex === index ? '' : 'hidden'}"
|
|
54
|
+
aria-labelledby="accordion-heading-{index}"
|
|
55
|
+
>
|
|
56
|
+
<div class="p-5 border-b border-gray-200 dark:border-gray-700 {index === items.length - 1 ? 'border-b-0 rounded-b-lg' : ''}">
|
|
57
|
+
<p class="text-sm text-gray-500 dark:text-gray-400 leading-relaxed">{answer}</p>
|
|
58
|
+
</div>
|
|
59
|
+
</div>
|
|
60
|
+
</div>
|
|
61
|
+
{/each}
|
|
62
|
+
</div>
|
|
63
|
+
{:else}
|
|
64
|
+
<!-- Simple List Pattern (Flowbite Typography) -->
|
|
65
|
+
<div class="space-y-4">
|
|
66
|
+
{#each items as { question, answer }}
|
|
67
|
+
<div>
|
|
68
|
+
{#if question}
|
|
69
|
+
<p class="text-sm font-medium text-gray-900 dark:text-white mb-1">{question}</p>
|
|
70
|
+
{/if}
|
|
71
|
+
<p class="text-sm text-gray-600 dark:text-gray-400 leading-relaxed">{answer}</p>
|
|
72
|
+
</div>
|
|
73
|
+
{/each}
|
|
74
|
+
</div>
|
|
75
|
+
{/if}
|
|
27
76
|
{:else}
|
|
28
|
-
<p class="
|
|
77
|
+
<p class="text-sm text-gray-500 dark:text-gray-400">No FAQs available.</p>
|
|
29
78
|
{/if}
|
|
30
79
|
</div>
|
|
31
|
-
|
|
32
|
-
<style>
|
|
33
|
-
/* Theme-responsive colors using CSS variables */
|
|
34
|
-
.section-title {
|
|
35
|
-
color: hsl(var(--Text-Primary));
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
.question-text {
|
|
39
|
-
color: hsl(var(--Text-Primary));
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
.answer-text {
|
|
43
|
-
color: hsl(var(--Text-Secondary));
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
.empty-text {
|
|
47
|
-
color: hsl(var(--Text-Tartiary));
|
|
48
|
-
}
|
|
49
|
-
</style>
|
|
@@ -1,17 +1,25 @@
|
|
|
1
1
|
export default FAQs;
|
|
2
2
|
type FAQs = SvelteComponent<{
|
|
3
|
+
accordion?: boolean | undefined;
|
|
3
4
|
title?: string | undefined;
|
|
4
5
|
showTitle?: boolean | undefined;
|
|
5
|
-
faqs?:
|
|
6
|
+
faqs?: (string | {
|
|
7
|
+
question: string;
|
|
8
|
+
answer: string;
|
|
9
|
+
})[] | undefined;
|
|
6
10
|
}, {
|
|
7
11
|
[evt: string]: CustomEvent<any>;
|
|
8
12
|
}, {}> & {
|
|
9
13
|
$$bindings?: string | undefined;
|
|
10
14
|
};
|
|
11
15
|
declare const FAQs: $$__sveltets_2_IsomorphicComponent<{
|
|
16
|
+
accordion?: boolean | undefined;
|
|
12
17
|
title?: string | undefined;
|
|
13
18
|
showTitle?: boolean | undefined;
|
|
14
|
-
faqs?:
|
|
19
|
+
faqs?: (string | {
|
|
20
|
+
question: string;
|
|
21
|
+
answer: string;
|
|
22
|
+
})[] | undefined;
|
|
15
23
|
}, {
|
|
16
24
|
[evt: string]: CustomEvent<any>;
|
|
17
25
|
}, {}, {}, string>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FAQs.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/components/FAQs/FAQs.svelte.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"FAQs.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/components/FAQs/FAQs.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;;AA0FA;;;;;kBAb4B,MAAM;gBAAU,MAAM;;;;mBAawG;6CAT7G,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,OAAO,OAAO,QAAQ;IAC3L,cAAc,OAAO,QAAQ,EAAE,2BAA2B,CAAC,KAAK,CAAC,GAAG,OAAO,QAAQ,EAAE,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,GAAG;QAAE,UAAU,CAAC,EAAE,QAAQ,CAAA;KAAE,GAAG,OAAO,CAAC;IACjK,WAAW,OAAO,SAAS,KAAK,GAAG;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,KAAK,CAAA;KAAC,GAAG,OAAO,GAAG;QAAE,IAAI,CAAC,EAAE,GAAG,CAAC;QAAC,GAAG,CAAC,EAAE,GAAG,CAAA;KAAE,CAAC;IAC9G,eAAe,QAAQ,CAAC"}
|