@getmicdrop/svelte-components 5.17.0 → 5.17.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/calendar/AboutShow/AboutShow.svelte +187 -187
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
- package/dist/calendar/FAQs/FAQs.svelte +77 -77
- package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
- package/dist/calendar/OrderSummary/OrderSummary.svelte +457 -457
- package/dist/calendar/PublicCard/PublicCard.svelte +146 -146
- package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
- package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
- package/dist/components/Heading.spec.d.ts +2 -0
- package/dist/components/Heading.spec.d.ts.map +1 -0
- package/dist/components/Heading.spec.js +89 -0
- package/dist/components/Heading.svelte +60 -60
- package/dist/components/Layout/AppShell.svelte +104 -104
- package/dist/components/Layout/ContentSection.svelte +80 -80
- package/dist/components/Layout/Grid.svelte +4 -4
- package/dist/components/Layout/Heading.svelte +81 -81
- package/dist/components/Layout/PageContainer.svelte +69 -69
- package/dist/components/Layout/Responsive.svelte +75 -75
- package/dist/components/Layout/Section.svelte +80 -80
- package/dist/components/Layout/ShowOnDesktop.svelte +37 -37
- package/dist/components/Layout/ShowOnMobile.svelte +37 -37
- package/dist/components/Layout/Sidebar.svelte +108 -108
- package/dist/components/Layout/Stack.spec.js +1 -1
- package/dist/components/Layout/Stack.svelte +6 -6
- package/dist/components/Layout/Text.svelte +87 -87
- package/dist/components/Layout/TwoColumn.svelte +108 -108
- package/dist/components/Layout/__tests__/AppShell.test.js +140 -0
- package/dist/components/Text.spec.d.ts +2 -0
- package/dist/components/Text.spec.d.ts.map +1 -0
- package/dist/components/Text.spec.js +89 -0
- package/dist/components/Text.svelte +53 -53
- package/dist/constants/validation.js +91 -91
- package/dist/constants/validation.spec.js +64 -64
- package/dist/datetime/__tests__/format.test.js +1 -1
- package/dist/datetime/__tests__/parse.test.js +1 -1
- package/dist/datetime/__tests__/timezone.test.js +1 -1
- package/dist/datetime/parse.js +1 -1
- package/dist/datetime/timezone.d.ts.map +1 -1
- package/dist/datetime/timezone.js +1 -2
- package/dist/forms/createFormStore.svelte.d.ts +1 -1
- package/dist/forms/createFormStore.svelte.d.ts.map +1 -1
- package/dist/forms/createFormStore.svelte.js +1 -0
- package/dist/forms/createFormStore.svelte.spec.d.ts +2 -0
- package/dist/forms/createFormStore.svelte.spec.d.ts.map +1 -0
- package/dist/forms/createFormStore.svelte.spec.js +388 -0
- package/dist/index.js +57 -57
- package/dist/index.spec.js +369 -369
- package/dist/patterns/chat/ChatActivityNotice.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatActivityNotice.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatActivityNotice.spec.js +59 -0
- package/dist/patterns/chat/ChatActivityNotice.svelte +41 -41
- package/dist/patterns/chat/ChatBubble.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatBubble.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatBubble.spec.js +91 -0
- package/dist/patterns/chat/ChatBubble.svelte +95 -95
- package/dist/patterns/chat/ChatContainer.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatContainer.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatContainer.spec.js +30 -0
- package/dist/patterns/chat/ChatContainer.svelte +46 -46
- package/dist/patterns/chat/ChatDateDivider.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatDateDivider.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatDateDivider.spec.js +30 -0
- package/dist/patterns/chat/ChatDateDivider.svelte +27 -27
- package/dist/patterns/chat/ChatInvitationBubble.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatInvitationBubble.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatInvitationBubble.spec.js +46 -0
- package/dist/patterns/chat/ChatInvitationBubble.svelte +37 -37
- package/dist/patterns/chat/ChatInvitationNotice.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatInvitationNotice.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatInvitationNotice.spec.js +32 -0
- package/dist/patterns/chat/ChatInvitationNotice.svelte +27 -27
- package/dist/patterns/chat/ChatMessageGroup.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatMessageGroup.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatMessageGroup.spec.js +58 -0
- package/dist/patterns/chat/ChatMessageGroup.svelte +57 -57
- package/dist/patterns/chat/ChatSlotUpdate.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatSlotUpdate.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatSlotUpdate.spec.js +65 -0
- package/dist/patterns/chat/ChatSlotUpdate.svelte +46 -46
- package/dist/patterns/chat/ChatStatusBadge.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatStatusBadge.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatStatusBadge.spec.js +79 -0
- package/dist/patterns/chat/ChatStatusBadge.svelte +91 -91
- package/dist/patterns/chat/ChatStatusTransition.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatStatusTransition.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatStatusTransition.spec.js +81 -0
- package/dist/patterns/chat/ChatStatusTransition.svelte +64 -64
- package/dist/patterns/chat/ChatTextBubble.spec.d.ts +2 -0
- package/dist/patterns/chat/ChatTextBubble.spec.d.ts.map +1 -0
- package/dist/patterns/chat/ChatTextBubble.spec.js +35 -0
- package/dist/patterns/chat/ChatTextBubble.svelte +41 -41
- package/dist/patterns/chat/index.js +22 -22
- package/dist/patterns/data/DataGrid.svelte +45 -45
- package/dist/patterns/data/DataList.svelte +24 -24
- package/dist/patterns/data/DataTable.spec.js +61 -0
- package/dist/patterns/data/DataTable.svelte +36 -36
- package/dist/patterns/forms/FormActions.spec.js +95 -95
- package/dist/patterns/forms/FormActions.stories.svelte +97 -97
- package/dist/patterns/forms/FormActions.svelte +46 -46
- package/dist/patterns/forms/FormGrid.spec.js +34 -0
- package/dist/patterns/forms/FormGrid.svelte +33 -33
- package/dist/patterns/forms/FormSection.svelte +32 -32
- package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
- package/dist/patterns/forms/FormValidationSummary.svelte +74 -74
- package/dist/patterns/index.js +21 -21
- package/dist/patterns/layout/Sidebar.spec.js +240 -1
- package/dist/patterns/layout/Sidebar.svelte +39 -39
- package/dist/patterns/layout/SidebarTestWrapper.svelte +34 -0
- package/dist/patterns/layout/SidebarTestWrapper.svelte.d.ts +23 -0
- package/dist/patterns/layout/SidebarTestWrapper.svelte.d.ts.map +1 -0
- package/dist/patterns/layout/index.js +29 -29
- package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +74 -74
- package/dist/patterns/navigation/Header.spec.js +123 -0
- package/dist/patterns/navigation/Header.stories.svelte +77 -77
- package/dist/patterns/navigation/Header.svelte +251 -251
- package/dist/patterns/page/PageHeader.svelte +18 -18
- package/dist/patterns/page/PageLayout.svelte +40 -40
- package/dist/patterns/page/PageLoader.spec.js +57 -57
- package/dist/patterns/page/PageLoader.stories.svelte +137 -137
- package/dist/patterns/page/PageLoader.svelte +24 -24
- package/dist/patterns/page/SectionHeader.svelte +29 -29
- package/dist/presets/badges.js +112 -112
- package/dist/presets/buttons.js +76 -76
- package/dist/presets/index.js +9 -9
- package/dist/primitives/Accordion/Accordion.spec.js +112 -2
- package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
- package/dist/primitives/Accordion/Accordion.svelte +42 -42
- package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
- package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte +28 -0
- package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte.d.ts +7 -0
- package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte.d.ts.map +1 -0
- package/dist/primitives/Alert/Alert.spec.js +173 -173
- package/dist/primitives/Alert/Alert.stories.svelte +88 -88
- package/dist/primitives/Alert/Alert.svelte +27 -27
- package/dist/primitives/Avatar/Avatar.spec.js +23 -0
- package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
- package/dist/primitives/Avatar/Avatar.svelte +66 -66
- package/dist/primitives/AvatarButton/AvatarButton.svelte +57 -57
- package/dist/primitives/Badges/Badge.spec.js +144 -144
- package/dist/primitives/Badges/Badge.stories.svelte +86 -86
- package/dist/primitives/Badges/Badge.svelte +99 -99
- package/dist/primitives/BottomSheet/BottomSheet.spec.js +238 -136
- package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
- package/dist/primitives/BottomSheet/BottomSheet.svelte +115 -115
- package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte +20 -0
- package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte.d.ts +10 -0
- package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte.d.ts.map +1 -0
- package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +123 -123
- package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
- package/dist/primitives/Breadcrumb/Breadcrumb.svelte +99 -99
- package/dist/primitives/Button/Button.spec.js +225 -225
- package/dist/primitives/Button/Button.stories.svelte +76 -76
- package/dist/primitives/Button/Button.svelte +278 -278
- package/dist/primitives/Button/ButtonGroup.spec.d.ts +2 -0
- package/dist/primitives/Button/ButtonGroup.spec.d.ts.map +1 -0
- package/dist/primitives/Button/ButtonGroup.spec.js +44 -0
- package/dist/primitives/Button/ButtonGroup.svelte +50 -50
- package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -146
- package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
- package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
- package/dist/primitives/Card.spec.js +49 -49
- package/dist/primitives/Card.stories.svelte +22 -22
- package/dist/primitives/Card.svelte +28 -28
- package/dist/primitives/CardAction/CardAction.svelte +68 -68
- package/dist/primitives/Checkbox/Checkbox.spec.js +32 -0
- package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
- package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
- package/dist/primitives/DarkModeToggle.spec.js +390 -390
- package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
- package/dist/primitives/DarkModeToggle.svelte +136 -136
- package/dist/primitives/Drawer/Drawer.spec.js +437 -0
- package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
- package/dist/primitives/Drawer/Drawer.svelte +224 -224
- package/dist/primitives/Drawer/DrawerTestWrapper.svelte +86 -0
- package/dist/primitives/Drawer/DrawerTestWrapper.svelte.d.ts +26 -0
- package/dist/primitives/Drawer/DrawerTestWrapper.svelte.d.ts.map +1 -0
- package/dist/primitives/Dropdown/Dropdown.spec.js +116 -0
- package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
- package/dist/primitives/Dropdown/Dropdown.svelte +170 -170
- package/dist/primitives/Dropdown/DropdownDivider.spec.d.ts +2 -0
- package/dist/primitives/Dropdown/DropdownDivider.spec.d.ts.map +1 -0
- package/dist/primitives/Dropdown/DropdownDivider.spec.js +30 -0
- package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -9
- package/dist/primitives/Dropdown/DropdownItem.spec.js +155 -1
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte +43 -0
- package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte.d.ts +17 -0
- package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte.d.ts.map +1 -0
- package/dist/primitives/Helper/Helper.spec.d.ts +2 -0
- package/dist/primitives/Helper/Helper.spec.d.ts.map +1 -0
- package/dist/primitives/Helper/Helper.spec.js +57 -0
- package/dist/primitives/Helper/Helper.svelte +33 -33
- package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
- package/dist/primitives/Icons/ArrowRight.svelte +8 -8
- package/dist/primitives/Icons/Availability.svelte +14 -14
- package/dist/primitives/Icons/Back.svelte +14 -14
- package/dist/primitives/Icons/CheckCircle.svelte +6 -6
- package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
- package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
- package/dist/primitives/Icons/ChevronRight.svelte +4 -4
- package/dist/primitives/Icons/Copy.svelte +15 -15
- package/dist/primitives/Icons/Cross.svelte +5 -5
- package/dist/primitives/Icons/DownArrow.svelte +8 -8
- package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
- package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
- package/dist/primitives/Icons/Home.svelte +15 -15
- package/dist/primitives/Icons/Icon.spec.js +169 -169
- package/dist/primitives/Icons/Icon.stories.svelte +100 -100
- package/dist/primitives/Icons/Icon.svelte +52 -52
- package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
- package/dist/primitives/Icons/Info.svelte +7 -7
- package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
- package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
- package/dist/primitives/Icons/Message.svelte +15 -15
- package/dist/primitives/Icons/MoonIcon.svelte +5 -5
- package/dist/primitives/Icons/More.svelte +21 -21
- package/dist/primitives/Icons/MoreHori.spec.js +61 -61
- package/dist/primitives/Icons/MoreHori.svelte +22 -22
- package/dist/primitives/Icons/Notification.svelte +14 -14
- package/dist/primitives/Icons/Payment.svelte +14 -14
- package/dist/primitives/Icons/Profile.svelte +21 -21
- package/dist/primitives/Icons/Reload.svelte +29 -29
- package/dist/primitives/Icons/Shows.svelte +21 -21
- package/dist/primitives/Icons/Signout.svelte +21 -21
- package/dist/primitives/Icons/SunIcon.svelte +8 -8
- package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
- package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
- package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
- package/dist/primitives/Icons/WarningIcon.svelte +5 -5
- package/dist/primitives/Input/Input.spec.js +1235 -573
- package/dist/primitives/Input/Input.stories.svelte +139 -139
- package/dist/primitives/Input/Input.svelte +423 -423
- package/dist/primitives/Input/Select.spec.js +632 -218
- package/dist/primitives/Input/Select.stories.svelte +112 -112
- package/dist/primitives/Input/Select.svelte +252 -252
- package/dist/primitives/Input/Textarea.stories.svelte +137 -137
- package/dist/primitives/Input/Textarea.svelte +105 -105
- package/dist/primitives/Label/Label.spec.js +9 -0
- package/dist/primitives/Label/Label.svelte +37 -37
- package/dist/primitives/LandingButton/LandingButton.spec.d.ts +2 -0
- package/dist/primitives/LandingButton/LandingButton.spec.d.ts.map +1 -0
- package/dist/primitives/LandingButton/LandingButton.spec.js +61 -0
- package/dist/primitives/LandingButton/LandingButton.svelte +92 -92
- package/dist/primitives/MenuItem/MenuItem.spec.d.ts +2 -0
- package/dist/primitives/MenuItem/MenuItem.spec.d.ts.map +1 -0
- package/dist/primitives/MenuItem/MenuItem.spec.js +130 -0
- package/dist/primitives/MenuItem/MenuItem.svelte +85 -85
- package/dist/primitives/Modal/Modal.spec.js +314 -99
- package/dist/primitives/Modal/Modal.stories.svelte +86 -86
- package/dist/primitives/Modal/Modal.svelte +181 -181
- package/dist/primitives/NavItem/NavItem.spec.d.ts +2 -0
- package/dist/primitives/NavItem/NavItem.spec.d.ts.map +1 -0
- package/dist/primitives/NavItem/NavItem.spec.js +97 -0
- package/dist/primitives/NavItem/NavItem.svelte +75 -75
- package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
- package/dist/primitives/Pagination/Pagination.svelte +261 -261
- package/dist/primitives/Radio/Radio.stories.svelte +80 -80
- package/dist/primitives/Radio/Radio.svelte +67 -67
- package/dist/primitives/SearchResultItem/SearchResultItem.spec.d.ts +2 -0
- package/dist/primitives/SearchResultItem/SearchResultItem.spec.d.ts.map +1 -0
- package/dist/primitives/SearchResultItem/SearchResultItem.spec.js +78 -0
- package/dist/primitives/SearchResultItem/SearchResultItem.svelte +109 -109
- package/dist/primitives/SidebarToggle/SidebarToggle.spec.d.ts +2 -0
- package/dist/primitives/SidebarToggle/SidebarToggle.spec.d.ts.map +1 -0
- package/dist/primitives/SidebarToggle/SidebarToggle.spec.js +61 -0
- package/dist/primitives/SidebarToggle/SidebarToggle.svelte +55 -55
- package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
- package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
- package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
- package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
- package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
- package/dist/primitives/Spinner/Spinner.spec.js +84 -71
- package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
- package/dist/primitives/Spinner/Spinner.svelte +20 -20
- package/dist/primitives/Tabs/TabItem.svelte +49 -49
- package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
- package/dist/primitives/Tabs/Tabs.svelte +137 -137
- package/dist/primitives/Toggle.spec.js +221 -146
- package/dist/primitives/Toggle.stories.svelte +92 -92
- package/dist/primitives/Toggle.svelte +141 -141
- package/dist/primitives/ToggleTestWrapper.svelte +30 -0
- package/dist/primitives/ToggleTestWrapper.svelte.d.ts +29 -0
- package/dist/primitives/ToggleTestWrapper.svelte.d.ts.map +1 -0
- package/dist/primitives/Tooltip/Tooltip.spec.d.ts +2 -0
- package/dist/primitives/Tooltip/Tooltip.spec.d.ts.map +1 -0
- package/dist/primitives/Tooltip/Tooltip.spec.js +126 -0
- package/dist/primitives/Tooltip/Tooltip.svelte +83 -83
- package/dist/primitives/Typography/Typography.svelte +53 -53
- package/dist/primitives/ValidationError.spec.js +103 -103
- package/dist/primitives/ValidationError.stories.svelte +69 -69
- package/dist/primitives/ValidationError.svelte +29 -29
- package/dist/primitives/index.js +113 -113
- package/dist/recipes/CropImage/CropImage.spec.js +208 -208
- package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
- package/dist/recipes/CropImage/CropImage.svelte +241 -241
- package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
- package/dist/recipes/ImageUploader/ImageUploader.svelte +992 -992
- package/dist/recipes/SuperLogin/SuperLogin.spec.js +21 -21
- package/dist/recipes/SuperLogin/SuperLogin.svelte +4 -4
- package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
- package/dist/recipes/feedback/EmptyState/EmptyState.svelte +1 -1
- package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
- package/dist/recipes/feedback/ErrorDisplay.stories.svelte +101 -101
- package/dist/recipes/feedback/ErrorDisplay.svelte +1 -1
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -133
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
- package/dist/recipes/fields/CheckboxField.svelte +85 -85
- package/dist/recipes/fields/FormField.svelte +58 -58
- package/dist/recipes/fields/RadioGroup.svelte +95 -95
- package/dist/recipes/fields/SelectField.svelte +82 -82
- package/dist/recipes/fields/TextareaField.svelte +97 -97
- package/dist/recipes/fields/ToggleField.svelte +60 -60
- package/dist/recipes/fields/index.js +7 -7
- package/dist/recipes/inputs/MultiSelect.spec.js +263 -263
- package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
- package/dist/recipes/inputs/MultiSelect.svelte +283 -283
- package/dist/recipes/inputs/OTPInput.spec.js +251 -251
- package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
- package/dist/recipes/inputs/OTPInput.svelte +117 -117
- package/dist/recipes/inputs/PasswordInput.svelte +22 -22
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +131 -131
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +19 -19
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +336 -339
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
- package/dist/recipes/inputs/Search.spec.js +66 -2
- package/dist/recipes/inputs/Search.svelte +102 -102
- package/dist/recipes/inputs/index.js +7 -7
- package/dist/recipes/modals/AlertModal.svelte +130 -130
- package/dist/recipes/modals/ConfirmationModal.spec.js +396 -206
- package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
- package/dist/recipes/modals/ConfirmationModal.svelte +162 -162
- package/dist/recipes/modals/InputModal.svelte +182 -182
- package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
- package/dist/recipes/modals/ModalStateManager.svelte +77 -77
- package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
- package/dist/recipes/modals/StatusModal.svelte +206 -206
- package/dist/services/EventService.d.ts +1 -1
- package/dist/services/EventService.d.ts.map +1 -1
- package/dist/services/EventService.js +79 -75
- package/dist/services/EventService.spec.js +217 -217
- package/dist/services/ShowService.js +144 -143
- package/dist/services/ShowService.spec.js +345 -345
- package/dist/stores/auth.svelte.spec.d.ts +2 -0
- package/dist/stores/auth.svelte.spec.d.ts.map +1 -0
- package/dist/stores/auth.svelte.spec.js +112 -0
- package/dist/stores/formDataStore.svelte.spec.d.ts +2 -0
- package/dist/stores/formDataStore.svelte.spec.d.ts.map +1 -0
- package/dist/stores/formDataStore.svelte.spec.js +150 -0
- package/dist/stores/formSave.svelte.spec.d.ts +2 -0
- package/dist/stores/formSave.svelte.spec.d.ts.map +1 -0
- package/dist/stores/formSave.svelte.spec.js +196 -0
- package/dist/stores/navigation.spec.d.ts +2 -0
- package/dist/stores/navigation.spec.d.ts.map +1 -0
- package/dist/stores/navigation.spec.js +53 -0
- package/dist/stores/toaster.js +13 -13
- package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
- package/dist/stories/ButtonAuditReview.svelte +427 -427
- package/dist/stories/PatternsGallery.stories.svelte +19 -19
- package/dist/stories/PatternsGallery.svelte +206 -206
- package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
- package/dist/stories/PrimitivesGallery.svelte +756 -756
- package/dist/stories/RecipesGallery.stories.svelte +19 -19
- package/dist/stories/RecipesGallery.svelte +454 -454
- package/dist/stories/button-audit-manifest.json +11186 -11186
- package/dist/tailwind/preset.cjs +82 -82
- package/dist/telemetry.d.ts.map +1 -1
- package/dist/telemetry.js +402 -405
- package/dist/telemetry.server.js +212 -212
- package/dist/telemetry.server.spec.js +437 -438
- package/dist/telemetry.spec.js +1168 -1169
- package/dist/tokens/tokens.css +87 -87
- package/dist/tokens/typography-base.css +163 -163
- package/dist/tokens/utilities.css +353 -353
- package/dist/utils/apiConfig.js +117 -120
- package/dist/utils/apiConfig.spec.js +219 -219
- package/dist/utils/greetings.js +187 -187
- package/dist/utils/haptic.spec.d.ts +2 -0
- package/dist/utils/haptic.spec.d.ts.map +1 -0
- package/dist/utils/haptic.spec.js +153 -0
- package/dist/utils/imageOptimizer.spec.d.ts +2 -0
- package/dist/utils/imageOptimizer.spec.d.ts.map +1 -0
- package/dist/utils/imageOptimizer.spec.js +201 -0
- package/dist/utils/imageValidation.js +121 -121
- package/dist/utils/logger.spec.d.ts +2 -0
- package/dist/utils/logger.spec.d.ts.map +1 -0
- package/dist/utils/logger.spec.js +95 -0
- package/dist/utils/transitions.js +4 -4
- package/dist/utils/utils.js +693 -693
- package/package.json +292 -294
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { render, screen } from '@testing-library/svelte';
|
|
2
2
|
import userEvent from '@testing-library/user-event';
|
|
3
|
+
import { createRawSnippet } from 'svelte';
|
|
3
4
|
import { expect, describe, test, vi, beforeEach, afterEach } from 'vitest';
|
|
4
5
|
import Dropdown from './Dropdown.svelte';
|
|
5
6
|
|
|
@@ -351,6 +352,121 @@ describe('Dropdown Context', () => {
|
|
|
351
352
|
});
|
|
352
353
|
});
|
|
353
354
|
|
|
355
|
+
describe('Dropdown Placement', () => {
|
|
356
|
+
test('renders with top placement', () => {
|
|
357
|
+
const { container } = render(Dropdown, { props: { open: true, placement: 'top' } });
|
|
358
|
+
expect(container.querySelector('[role="menu"]')).toBeInTheDocument();
|
|
359
|
+
});
|
|
360
|
+
|
|
361
|
+
test('renders with left placement', () => {
|
|
362
|
+
const { container } = render(Dropdown, { props: { open: true, placement: 'left' } });
|
|
363
|
+
expect(container.querySelector('[role="menu"]')).toBeInTheDocument();
|
|
364
|
+
});
|
|
365
|
+
|
|
366
|
+
test('renders with right placement', () => {
|
|
367
|
+
const { container } = render(Dropdown, { props: { open: true, placement: 'right' } });
|
|
368
|
+
expect(container.querySelector('[role="menu"]')).toBeInTheDocument();
|
|
369
|
+
});
|
|
370
|
+
|
|
371
|
+
test('falls back to default origin for unknown placement', () => {
|
|
372
|
+
const { container } = render(Dropdown, { props: { open: true, placement: 'invalid-placement' } });
|
|
373
|
+
expect(container.querySelector('[role="menu"]')).toBeInTheDocument();
|
|
374
|
+
});
|
|
375
|
+
});
|
|
376
|
+
|
|
377
|
+
describe('Dropdown Children Rendering', () => {
|
|
378
|
+
test('renders children snippet when provided', () => {
|
|
379
|
+
const { container } = render(Dropdown, {
|
|
380
|
+
props: {
|
|
381
|
+
open: true,
|
|
382
|
+
children: createRawSnippet(() => ({
|
|
383
|
+
render: () => `<li role="menuitem">Item 1</li>`
|
|
384
|
+
}))
|
|
385
|
+
}
|
|
386
|
+
});
|
|
387
|
+
const item = container.querySelector('[role="menuitem"]');
|
|
388
|
+
expect(item).toBeInTheDocument();
|
|
389
|
+
expect(item.textContent).toBe('Item 1');
|
|
390
|
+
});
|
|
391
|
+
|
|
392
|
+
test('renders empty list when no children provided', () => {
|
|
393
|
+
const { container } = render(Dropdown, { props: { open: true } });
|
|
394
|
+
const ul = container.querySelector('ul');
|
|
395
|
+
expect(ul).toBeInTheDocument();
|
|
396
|
+
expect(ul.children.length).toBe(0);
|
|
397
|
+
});
|
|
398
|
+
});
|
|
399
|
+
|
|
400
|
+
describe('Dropdown Trigger Element Detection', () => {
|
|
401
|
+
let cleanup;
|
|
402
|
+
|
|
403
|
+
afterEach(() => {
|
|
404
|
+
if (cleanup) {
|
|
405
|
+
cleanup();
|
|
406
|
+
}
|
|
407
|
+
});
|
|
408
|
+
|
|
409
|
+
test('clicking on trigger sibling does not close dropdown', async () => {
|
|
410
|
+
const onclose = vi.fn();
|
|
411
|
+
|
|
412
|
+
// Create a wrapper with a trigger button followed by the dropdown
|
|
413
|
+
const wrapper = document.createElement('div');
|
|
414
|
+
const triggerBtn = document.createElement('button');
|
|
415
|
+
triggerBtn.textContent = 'Toggle';
|
|
416
|
+
wrapper.appendChild(triggerBtn);
|
|
417
|
+
document.body.appendChild(wrapper);
|
|
418
|
+
|
|
419
|
+
const result = render(Dropdown, {
|
|
420
|
+
props: { open: true, onclose },
|
|
421
|
+
target: wrapper
|
|
422
|
+
});
|
|
423
|
+
cleanup = () => {
|
|
424
|
+
result.unmount();
|
|
425
|
+
document.body.removeChild(wrapper);
|
|
426
|
+
};
|
|
427
|
+
|
|
428
|
+
// Click on the trigger button (sibling before the dropdown container)
|
|
429
|
+
const clickEvent = new MouseEvent('mousedown', { bubbles: true });
|
|
430
|
+
Object.defineProperty(clickEvent, 'target', { value: triggerBtn, enumerable: true });
|
|
431
|
+
document.dispatchEvent(clickEvent);
|
|
432
|
+
|
|
433
|
+
// Should not close since click was on the trigger element
|
|
434
|
+
expect(onclose).not.toHaveBeenCalled();
|
|
435
|
+
});
|
|
436
|
+
|
|
437
|
+
test('Escape returns focus to trigger element', async () => {
|
|
438
|
+
const onclose = vi.fn();
|
|
439
|
+
|
|
440
|
+
// Create wrapper with trigger sibling before dropdown
|
|
441
|
+
const wrapper = document.createElement('div');
|
|
442
|
+
const triggerBtn = document.createElement('button');
|
|
443
|
+
triggerBtn.textContent = 'Toggle';
|
|
444
|
+
wrapper.appendChild(triggerBtn);
|
|
445
|
+
document.body.appendChild(wrapper);
|
|
446
|
+
|
|
447
|
+
const result = render(Dropdown, {
|
|
448
|
+
props: { open: true, onclose },
|
|
449
|
+
target: wrapper
|
|
450
|
+
});
|
|
451
|
+
cleanup = () => {
|
|
452
|
+
result.unmount();
|
|
453
|
+
document.body.removeChild(wrapper);
|
|
454
|
+
};
|
|
455
|
+
|
|
456
|
+
const focusSpy = vi.spyOn(triggerBtn, 'focus');
|
|
457
|
+
const ul = result.container.querySelector('ul');
|
|
458
|
+
|
|
459
|
+
// Dispatch Escape from within the dropdown
|
|
460
|
+
const event = new KeyboardEvent('keydown', { key: 'Escape', bubbles: true, cancelable: true });
|
|
461
|
+
Object.defineProperty(event, 'target', { value: ul, enumerable: true });
|
|
462
|
+
document.dispatchEvent(event);
|
|
463
|
+
|
|
464
|
+
expect(onclose).toHaveBeenCalled();
|
|
465
|
+
expect(focusSpy).toHaveBeenCalled();
|
|
466
|
+
focusSpy.mockRestore();
|
|
467
|
+
});
|
|
468
|
+
});
|
|
469
|
+
|
|
354
470
|
describe('Dropdown Lifecycle', () => {
|
|
355
471
|
test('cleans up event listeners on destroy', () => {
|
|
356
472
|
const removeEventListenerSpy = vi.spyOn(document, 'removeEventListener');
|
|
@@ -1,137 +1,137 @@
|
|
|
1
|
-
<script module>
|
|
2
|
-
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
3
|
-
import Dropdown from './Dropdown.svelte';
|
|
4
|
-
import DropdownItem from './DropdownItem.svelte';
|
|
5
|
-
import Button from '../Button/Button.svelte';
|
|
6
|
-
|
|
7
|
-
const { Story } = defineMeta({
|
|
8
|
-
title: 'Primitives/Dropdown',
|
|
9
|
-
component: Dropdown,
|
|
10
|
-
tags: ['autodocs'],
|
|
11
|
-
parameters: {
|
|
12
|
-
docs: {
|
|
13
|
-
description: {
|
|
14
|
-
component: 'Dropdown menu component for actions and navigation.',
|
|
15
|
-
},
|
|
16
|
-
},
|
|
17
|
-
},
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
let open1 = $state(false);
|
|
21
|
-
let open2 = $state(false);
|
|
22
|
-
let open3 = $state(false);
|
|
23
|
-
</script>
|
|
24
|
-
|
|
25
|
-
<Story name="Default">
|
|
26
|
-
{#snippet template()}
|
|
27
|
-
<div class="relative inline-block">
|
|
28
|
-
<Button onclick={() => open1 = !open1}>
|
|
29
|
-
Options ▼
|
|
30
|
-
</Button>
|
|
31
|
-
{#if open1}
|
|
32
|
-
<Dropdown class="absolute mt-1 z-10">
|
|
33
|
-
<DropdownItem onclick={() => { console.log('Edit'); open1 = false; }}>Edit</DropdownItem>
|
|
34
|
-
<DropdownItem onclick={() => { console.log('Duplicate'); open1 = false; }}>Duplicate</DropdownItem>
|
|
35
|
-
<DropdownItem onclick={() => { console.log('Archive'); open1 = false; }}>Archive</DropdownItem>
|
|
36
|
-
</Dropdown>
|
|
37
|
-
{/if}
|
|
38
|
-
</div>
|
|
39
|
-
{/snippet}
|
|
40
|
-
</Story>
|
|
41
|
-
|
|
42
|
-
<Story name="With Dividers">
|
|
43
|
-
{#snippet template()}
|
|
44
|
-
<div class="relative inline-block">
|
|
45
|
-
<Button onclick={() => open2 = !open2}>
|
|
46
|
-
Actions ▼
|
|
47
|
-
</Button>
|
|
48
|
-
{#if open2}
|
|
49
|
-
<Dropdown class="absolute mt-1 z-10">
|
|
50
|
-
<DropdownItem onclick={() => open2 = false}>View Details</DropdownItem>
|
|
51
|
-
<DropdownItem onclick={() => open2 = false}>Edit</DropdownItem>
|
|
52
|
-
<div class="border-t my-1"></div>
|
|
53
|
-
<DropdownItem onclick={() => open2 = false}>Share</DropdownItem>
|
|
54
|
-
<DropdownItem onclick={() => open2 = false}>Export</DropdownItem>
|
|
55
|
-
<div class="border-t my-1"></div>
|
|
56
|
-
<DropdownItem onclick={() => open2 = false} class="text-red-600">Delete</DropdownItem>
|
|
57
|
-
</Dropdown>
|
|
58
|
-
{/if}
|
|
59
|
-
</div>
|
|
60
|
-
{/snippet}
|
|
61
|
-
</Story>
|
|
62
|
-
|
|
63
|
-
<Story name="Right Aligned">
|
|
64
|
-
{#snippet template()}
|
|
65
|
-
<div class="flex justify-end">
|
|
66
|
-
<div class="relative inline-block">
|
|
67
|
-
<Button onclick={() => open3 = !open3}>
|
|
68
|
-
Menu ▼
|
|
69
|
-
</Button>
|
|
70
|
-
{#if open3}
|
|
71
|
-
<Dropdown class="absolute mt-1 right-0 z-10">
|
|
72
|
-
<DropdownItem onclick={() => open3 = false}>Profile</DropdownItem>
|
|
73
|
-
<DropdownItem onclick={() => open3 = false}>Settings</DropdownItem>
|
|
74
|
-
<DropdownItem onclick={() => open3 = false}>Help</DropdownItem>
|
|
75
|
-
<div class="border-t my-1"></div>
|
|
76
|
-
<DropdownItem onclick={() => open3 = false}>Sign Out</DropdownItem>
|
|
77
|
-
</Dropdown>
|
|
78
|
-
{/if}
|
|
79
|
-
</div>
|
|
80
|
-
</div>
|
|
81
|
-
{/snippet}
|
|
82
|
-
</Story>
|
|
83
|
-
|
|
84
|
-
<Story name="With Icons">
|
|
85
|
-
{#snippet template()}
|
|
86
|
-
<div class="relative inline-block">
|
|
87
|
-
<Button onclick={() => open1 = !open1}>
|
|
88
|
-
User Menu ▼
|
|
89
|
-
</Button>
|
|
90
|
-
{#if open1}
|
|
91
|
-
<Dropdown class="absolute mt-1 z-10 min-w-[180px]">
|
|
92
|
-
<DropdownItem onclick={() => open1 = false}>
|
|
93
|
-
<span class="mr-2">👤</span> Profile
|
|
94
|
-
</DropdownItem>
|
|
95
|
-
<DropdownItem onclick={() => open1 = false}>
|
|
96
|
-
<span class="mr-2">⚙️</span> Settings
|
|
97
|
-
</DropdownItem>
|
|
98
|
-
<DropdownItem onclick={() => open1 = false}>
|
|
99
|
-
<span class="mr-2">📊</span> Analytics
|
|
100
|
-
</DropdownItem>
|
|
101
|
-
<div class="border-t my-1"></div>
|
|
102
|
-
<DropdownItem onclick={() => open1 = false}>
|
|
103
|
-
<span class="mr-2">🚪</span> Sign Out
|
|
104
|
-
</DropdownItem>
|
|
105
|
-
</Dropdown>
|
|
106
|
-
{/if}
|
|
107
|
-
</div>
|
|
108
|
-
{/snippet}
|
|
109
|
-
</Story>
|
|
110
|
-
|
|
111
|
-
<Story name="In Card Context">
|
|
112
|
-
{#snippet template()}
|
|
113
|
-
<div class="border rounded-lg p-4 max-w-sm">
|
|
114
|
-
<div class="flex justify-between items-center mb-4">
|
|
115
|
-
<h3 class="font-medium">Card Title</h3>
|
|
116
|
-
<div class="relative">
|
|
117
|
-
<button
|
|
118
|
-
class="p-1 hover:bg-gray-100 rounded"
|
|
119
|
-
onclick={() => open1 = !open1}
|
|
120
|
-
>
|
|
121
|
-
⋮
|
|
122
|
-
</button>
|
|
123
|
-
{#if open1}
|
|
124
|
-
<Dropdown class="absolute mt-1 right-0 z-10">
|
|
125
|
-
<DropdownItem onclick={() => open1 = false}>Edit</DropdownItem>
|
|
126
|
-
<DropdownItem onclick={() => open1 = false}>Share</DropdownItem>
|
|
127
|
-
<DropdownItem onclick={() => open1 = false} class="text-red-600">Delete</DropdownItem>
|
|
128
|
-
</Dropdown>
|
|
129
|
-
{/if}
|
|
130
|
-
</div>
|
|
131
|
-
</div>
|
|
132
|
-
<p class="text-gray-600 text-sm">
|
|
133
|
-
This is a card with a dropdown menu in the header for common actions.
|
|
134
|
-
</p>
|
|
135
|
-
</div>
|
|
136
|
-
{/snippet}
|
|
137
|
-
</Story>
|
|
1
|
+
<script module>
|
|
2
|
+
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
3
|
+
import Dropdown from './Dropdown.svelte';
|
|
4
|
+
import DropdownItem from './DropdownItem.svelte';
|
|
5
|
+
import Button from '../Button/Button.svelte';
|
|
6
|
+
|
|
7
|
+
const { Story } = defineMeta({
|
|
8
|
+
title: 'Primitives/Dropdown',
|
|
9
|
+
component: Dropdown,
|
|
10
|
+
tags: ['autodocs'],
|
|
11
|
+
parameters: {
|
|
12
|
+
docs: {
|
|
13
|
+
description: {
|
|
14
|
+
component: 'Dropdown menu component for actions and navigation.',
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
let open1 = $state(false);
|
|
21
|
+
let open2 = $state(false);
|
|
22
|
+
let open3 = $state(false);
|
|
23
|
+
</script>
|
|
24
|
+
|
|
25
|
+
<Story name="Default">
|
|
26
|
+
{#snippet template()}
|
|
27
|
+
<div class="relative inline-block">
|
|
28
|
+
<Button onclick={() => open1 = !open1}>
|
|
29
|
+
Options ▼
|
|
30
|
+
</Button>
|
|
31
|
+
{#if open1}
|
|
32
|
+
<Dropdown class="absolute mt-1 z-10">
|
|
33
|
+
<DropdownItem onclick={() => { console.log('Edit'); open1 = false; }}>Edit</DropdownItem>
|
|
34
|
+
<DropdownItem onclick={() => { console.log('Duplicate'); open1 = false; }}>Duplicate</DropdownItem>
|
|
35
|
+
<DropdownItem onclick={() => { console.log('Archive'); open1 = false; }}>Archive</DropdownItem>
|
|
36
|
+
</Dropdown>
|
|
37
|
+
{/if}
|
|
38
|
+
</div>
|
|
39
|
+
{/snippet}
|
|
40
|
+
</Story>
|
|
41
|
+
|
|
42
|
+
<Story name="With Dividers">
|
|
43
|
+
{#snippet template()}
|
|
44
|
+
<div class="relative inline-block">
|
|
45
|
+
<Button onclick={() => open2 = !open2}>
|
|
46
|
+
Actions ▼
|
|
47
|
+
</Button>
|
|
48
|
+
{#if open2}
|
|
49
|
+
<Dropdown class="absolute mt-1 z-10">
|
|
50
|
+
<DropdownItem onclick={() => open2 = false}>View Details</DropdownItem>
|
|
51
|
+
<DropdownItem onclick={() => open2 = false}>Edit</DropdownItem>
|
|
52
|
+
<div class="border-t my-1"></div>
|
|
53
|
+
<DropdownItem onclick={() => open2 = false}>Share</DropdownItem>
|
|
54
|
+
<DropdownItem onclick={() => open2 = false}>Export</DropdownItem>
|
|
55
|
+
<div class="border-t my-1"></div>
|
|
56
|
+
<DropdownItem onclick={() => open2 = false} class="text-red-600">Delete</DropdownItem>
|
|
57
|
+
</Dropdown>
|
|
58
|
+
{/if}
|
|
59
|
+
</div>
|
|
60
|
+
{/snippet}
|
|
61
|
+
</Story>
|
|
62
|
+
|
|
63
|
+
<Story name="Right Aligned">
|
|
64
|
+
{#snippet template()}
|
|
65
|
+
<div class="flex justify-end">
|
|
66
|
+
<div class="relative inline-block">
|
|
67
|
+
<Button onclick={() => open3 = !open3}>
|
|
68
|
+
Menu ▼
|
|
69
|
+
</Button>
|
|
70
|
+
{#if open3}
|
|
71
|
+
<Dropdown class="absolute mt-1 right-0 z-10">
|
|
72
|
+
<DropdownItem onclick={() => open3 = false}>Profile</DropdownItem>
|
|
73
|
+
<DropdownItem onclick={() => open3 = false}>Settings</DropdownItem>
|
|
74
|
+
<DropdownItem onclick={() => open3 = false}>Help</DropdownItem>
|
|
75
|
+
<div class="border-t my-1"></div>
|
|
76
|
+
<DropdownItem onclick={() => open3 = false}>Sign Out</DropdownItem>
|
|
77
|
+
</Dropdown>
|
|
78
|
+
{/if}
|
|
79
|
+
</div>
|
|
80
|
+
</div>
|
|
81
|
+
{/snippet}
|
|
82
|
+
</Story>
|
|
83
|
+
|
|
84
|
+
<Story name="With Icons">
|
|
85
|
+
{#snippet template()}
|
|
86
|
+
<div class="relative inline-block">
|
|
87
|
+
<Button onclick={() => open1 = !open1}>
|
|
88
|
+
User Menu ▼
|
|
89
|
+
</Button>
|
|
90
|
+
{#if open1}
|
|
91
|
+
<Dropdown class="absolute mt-1 z-10 min-w-[180px]">
|
|
92
|
+
<DropdownItem onclick={() => open1 = false}>
|
|
93
|
+
<span class="mr-2">👤</span> Profile
|
|
94
|
+
</DropdownItem>
|
|
95
|
+
<DropdownItem onclick={() => open1 = false}>
|
|
96
|
+
<span class="mr-2">⚙️</span> Settings
|
|
97
|
+
</DropdownItem>
|
|
98
|
+
<DropdownItem onclick={() => open1 = false}>
|
|
99
|
+
<span class="mr-2">📊</span> Analytics
|
|
100
|
+
</DropdownItem>
|
|
101
|
+
<div class="border-t my-1"></div>
|
|
102
|
+
<DropdownItem onclick={() => open1 = false}>
|
|
103
|
+
<span class="mr-2">🚪</span> Sign Out
|
|
104
|
+
</DropdownItem>
|
|
105
|
+
</Dropdown>
|
|
106
|
+
{/if}
|
|
107
|
+
</div>
|
|
108
|
+
{/snippet}
|
|
109
|
+
</Story>
|
|
110
|
+
|
|
111
|
+
<Story name="In Card Context">
|
|
112
|
+
{#snippet template()}
|
|
113
|
+
<div class="border rounded-lg p-4 max-w-sm">
|
|
114
|
+
<div class="flex justify-between items-center mb-4">
|
|
115
|
+
<h3 class="font-medium">Card Title</h3>
|
|
116
|
+
<div class="relative">
|
|
117
|
+
<button
|
|
118
|
+
class="p-1 hover:bg-gray-100 rounded"
|
|
119
|
+
onclick={() => open1 = !open1}
|
|
120
|
+
>
|
|
121
|
+
⋮
|
|
122
|
+
</button>
|
|
123
|
+
{#if open1}
|
|
124
|
+
<Dropdown class="absolute mt-1 right-0 z-10">
|
|
125
|
+
<DropdownItem onclick={() => open1 = false}>Edit</DropdownItem>
|
|
126
|
+
<DropdownItem onclick={() => open1 = false}>Share</DropdownItem>
|
|
127
|
+
<DropdownItem onclick={() => open1 = false} class="text-red-600">Delete</DropdownItem>
|
|
128
|
+
</Dropdown>
|
|
129
|
+
{/if}
|
|
130
|
+
</div>
|
|
131
|
+
</div>
|
|
132
|
+
<p class="text-gray-600 text-sm">
|
|
133
|
+
This is a card with a dropdown menu in the header for common actions.
|
|
134
|
+
</p>
|
|
135
|
+
</div>
|
|
136
|
+
{/snippet}
|
|
137
|
+
</Story>
|