@getmicdrop/svelte-components 5.3.12 → 5.3.13
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 +172 -172
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
- package/dist/calendar/FAQs/FAQs.svelte +75 -75
- package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
- package/dist/calendar/OrderSummary/OrderSummary.svelte +367 -367
- package/dist/calendar/PublicCard/PublicCard.svelte +145 -145
- package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
- package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
- package/dist/components/Layout/Grid.svelte +109 -109
- package/dist/components/Layout/Section.svelte +80 -80
- package/dist/components/Layout/Sidebar.svelte +108 -108
- package/dist/components/Layout/Stack.svelte +90 -90
- package/dist/constants/formOptions.js +26 -26
- package/dist/constants/validation.js +91 -91
- package/dist/constants/validation.spec.js +64 -64
- package/dist/datetime/__tests__/format.test.d.ts +2 -0
- package/dist/datetime/__tests__/format.test.d.ts.map +1 -0
- package/dist/datetime/__tests__/format.test.js +268 -0
- package/dist/datetime/__tests__/integration.test.d.ts +2 -0
- package/dist/datetime/__tests__/integration.test.d.ts.map +1 -0
- package/dist/datetime/__tests__/integration.test.js +243 -0
- package/dist/datetime/__tests__/parse.test.d.ts +2 -0
- package/dist/datetime/__tests__/parse.test.d.ts.map +1 -0
- package/dist/datetime/__tests__/parse.test.js +261 -0
- package/dist/datetime/__tests__/timezone.test.d.ts +2 -0
- package/dist/datetime/__tests__/timezone.test.d.ts.map +1 -0
- package/dist/datetime/__tests__/timezone.test.js +214 -0
- package/dist/datetime/constants.d.ts +133 -0
- package/dist/datetime/constants.d.ts.map +1 -0
- package/dist/datetime/constants.js +112 -0
- package/dist/datetime/format.d.ts +158 -0
- package/dist/datetime/format.d.ts.map +1 -0
- package/dist/datetime/format.js +315 -0
- package/dist/datetime/index.d.ts +42 -0
- package/dist/datetime/index.d.ts.map +1 -0
- package/dist/datetime/index.js +44 -0
- package/dist/datetime/parse.d.ts +149 -0
- package/dist/datetime/parse.d.ts.map +1 -0
- package/dist/datetime/parse.js +276 -0
- package/dist/datetime/timezone.d.ts +95 -0
- package/dist/datetime/timezone.d.ts.map +1 -0
- package/dist/datetime/timezone.js +241 -0
- package/dist/datetime/types.d.ts +105 -0
- package/dist/datetime/types.d.ts.map +1 -0
- package/dist/datetime/types.js +31 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +232 -218
- package/dist/patterns/data/DataGrid.svelte +45 -45
- package/dist/patterns/data/DataList.svelte +24 -24
- package/dist/patterns/data/DataTable.svelte +40 -40
- package/dist/patterns/forms/FormActions.spec.js +88 -88
- package/dist/patterns/forms/FormActions.stories.svelte +97 -97
- package/dist/patterns/forms/FormActions.svelte +46 -46
- package/dist/patterns/forms/FormGrid.svelte +33 -33
- package/dist/patterns/forms/FormSection.svelte +32 -32
- package/dist/patterns/forms/FormValidationSummary.spec.js +203 -203
- package/dist/patterns/forms/FormValidationSummary.stories.svelte +97 -97
- package/dist/patterns/forms/FormValidationSummary.svelte +67 -67
- package/dist/patterns/layout/Grid.svelte +35 -35
- package/dist/patterns/layout/Sidebar.svelte +39 -39
- package/dist/patterns/layout/Stack.svelte +45 -45
- package/dist/patterns/navigation/BottomNav.spec.js +130 -130
- package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +54 -54
- package/dist/patterns/navigation/Header.spec.js +203 -203
- package/dist/patterns/navigation/Header.stories.svelte +77 -77
- package/dist/patterns/navigation/Header.svelte +240 -240
- package/dist/patterns/page/PageHeader.svelte +36 -36
- package/dist/patterns/page/PageLayout.svelte +40 -40
- package/dist/patterns/page/PageLoader.spec.js +54 -54
- package/dist/patterns/page/PageLoader.stories.svelte +137 -137
- package/dist/patterns/page/PageLoader.svelte +41 -41
- package/dist/patterns/page/SectionHeader.svelte +41 -41
- 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.stories.svelte +75 -75
- package/dist/primitives/Accordion/Accordion.svelte +61 -61
- package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
- package/dist/primitives/Alert/Alert.spec.js +170 -170
- package/dist/primitives/Alert/Alert.stories.svelte +88 -88
- package/dist/primitives/Alert/Alert.svelte +65 -65
- package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
- package/dist/primitives/Avatar/Avatar.svelte +66 -66
- package/dist/primitives/Badges/Badge.spec.js +103 -103
- package/dist/primitives/Badges/Badge.stories.svelte +86 -86
- package/dist/primitives/Badges/Badge.svelte +142 -142
- package/dist/primitives/BottomSheet/BottomSheet.spec.js +127 -127
- package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
- package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
- package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +120 -120
- package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
- package/dist/primitives/Breadcrumb/Breadcrumb.svelte +89 -89
- package/dist/primitives/Button/Button.spec.js +211 -211
- package/dist/primitives/Button/Button.stories.svelte +76 -76
- package/dist/primitives/Button/Button.svelte +301 -301
- package/dist/primitives/Button/ButtonSaveDemo.spec.js +48 -48
- 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/Checkbox/Checkbox.stories.svelte +84 -84
- package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
- package/dist/primitives/DarkModeToggle.spec.js +357 -357
- package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
- package/dist/primitives/DarkModeToggle.svelte +136 -136
- package/dist/primitives/Drawer/Drawer.stories.svelte +100 -100
- package/dist/primitives/Drawer/Drawer.svelte +214 -214
- package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
- package/dist/primitives/Dropdown/Dropdown.svelte +148 -148
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Icons/ArrowLeft.svelte +20 -20
- package/dist/primitives/Icons/ArrowRight.svelte +20 -20
- package/dist/primitives/Icons/Availability.svelte +26 -26
- package/dist/primitives/Icons/Back.svelte +26 -26
- package/dist/primitives/Icons/CheckCircle.svelte +18 -18
- package/dist/primitives/Icons/CheckCircleOutline.svelte +27 -27
- package/dist/primitives/Icons/ChevronLeft.svelte +16 -16
- package/dist/primitives/Icons/ChevronRight.svelte +16 -16
- package/dist/primitives/Icons/Copy.svelte +27 -27
- package/dist/primitives/Icons/Cross.svelte +17 -17
- package/dist/primitives/Icons/DownArrow.svelte +20 -20
- package/dist/primitives/Icons/ErrorCircle.svelte +18 -18
- package/dist/primitives/Icons/FacebookIcon.svelte +13 -13
- package/dist/primitives/Icons/Home.svelte +27 -27
- package/dist/primitives/Icons/Icon.spec.js +175 -175
- package/dist/primitives/Icons/Icon.stories.svelte +100 -100
- package/dist/primitives/Icons/Icon.svelte +63 -63
- package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
- package/dist/primitives/Icons/ImageOutline.svelte +19 -19
- package/dist/primitives/Icons/Info.svelte +19 -19
- package/dist/primitives/Icons/InstagramIcon.svelte +19 -19
- package/dist/primitives/Icons/LogoInstagram.svelte +15 -15
- package/dist/primitives/Icons/Message.svelte +27 -27
- package/dist/primitives/Icons/MoonIcon.svelte +16 -16
- package/dist/primitives/Icons/More.svelte +33 -33
- package/dist/primitives/Icons/MoreHori.spec.js +67 -67
- package/dist/primitives/Icons/MoreHori.svelte +34 -34
- package/dist/primitives/Icons/Notification.svelte +26 -26
- package/dist/primitives/Icons/Payment.svelte +26 -26
- package/dist/primitives/Icons/Profile.svelte +33 -33
- package/dist/primitives/Icons/Reload.svelte +41 -41
- package/dist/primitives/Icons/Shows.svelte +33 -33
- package/dist/primitives/Icons/Signout.svelte +33 -33
- package/dist/primitives/Icons/SunIcon.svelte +19 -19
- package/dist/primitives/Icons/TiktokIcon.svelte +13 -13
- package/dist/primitives/Icons/TrashBinOutline.svelte +19 -19
- package/dist/primitives/Icons/TwitterIcon.svelte +13 -13
- package/dist/primitives/Icons/WarningIcon.spec.js +30 -30
- package/dist/primitives/Icons/WarningIcon.svelte +24 -24
- package/dist/primitives/Input/Input.spec.js +573 -573
- package/dist/primitives/Input/Input.stories.svelte +139 -139
- package/dist/primitives/Input/Input.svelte +444 -444
- package/dist/primitives/Input/Select.spec.js +218 -218
- package/dist/primitives/Input/Select.stories.svelte +112 -112
- package/dist/primitives/Input/Select.svelte +232 -232
- package/dist/primitives/Input/Textarea.stories.svelte +137 -137
- package/dist/primitives/Input/Textarea.svelte +79 -79
- package/dist/primitives/Label/Label.svelte +37 -37
- package/dist/primitives/Modal/Modal.spec.js +95 -95
- package/dist/primitives/Modal/Modal.stories.svelte +86 -86
- package/dist/primitives/Modal/Modal.svelte +158 -158
- 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/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 +52 -52
- package/dist/primitives/Spinner/Spinner.spec.js +75 -75
- package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
- package/dist/primitives/Spinner/Spinner.svelte +57 -57
- package/dist/primitives/Tabs/TabItem.svelte +51 -51
- package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
- package/dist/primitives/Tabs/Tabs.svelte +128 -128
- package/dist/primitives/Toggle.spec.js +127 -127
- package/dist/primitives/Toggle.stories.svelte +92 -92
- package/dist/primitives/Toggle.svelte +71 -71
- package/dist/primitives/Typography/Typography.svelte +53 -53
- package/dist/primitives/ValidationError.spec.js +103 -103
- package/dist/primitives/ValidationError.stories.svelte +111 -111
- package/dist/primitives/ValidationError.svelte +29 -29
- package/dist/recipes/CropImage/CropImage.spec.js +216 -216
- package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
- package/dist/recipes/CropImage/CropImage.svelte +238 -238
- package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
- package/dist/recipes/ImageUploader/ImageUploader.svelte +980 -980
- package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
- package/dist/recipes/feedback/EmptyState/EmptyState.svelte +47 -47
- package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
- package/dist/recipes/feedback/ErrorDisplay.stories.svelte +112 -112
- package/dist/recipes/feedback/ErrorDisplay.svelte +38 -38
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +129 -129
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +167 -167
- 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 +101 -101
- package/dist/recipes/fields/ToggleField.svelte +60 -60
- package/dist/recipes/fields/index.js +7 -7
- package/dist/recipes/inputs/MultiSelect.spec.js +257 -257
- package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
- package/dist/recipes/inputs/MultiSelect.svelte +244 -244
- package/dist/recipes/inputs/OTPInput.spec.js +238 -238
- package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
- package/dist/recipes/inputs/OTPInput.svelte +102 -102
- package/dist/recipes/inputs/PasswordInput.svelte +100 -100
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +173 -173
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +108 -108
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +300 -300
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +165 -165
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +337 -337
- package/dist/recipes/inputs/Search.svelte +85 -85
- package/dist/recipes/inputs/SelectDropdown.svelte +161 -161
- package/dist/recipes/modals/AlertModal.svelte +130 -130
- package/dist/recipes/modals/ConfirmationModal.spec.js +191 -191
- package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
- package/dist/recipes/modals/ConfirmationModal.svelte +152 -152
- 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.js +75 -75
- package/dist/services/EventService.spec.js +217 -217
- package/dist/services/ShowService.spec.js +342 -342
- package/dist/stores/auth.js +93 -6
- package/dist/stores/auth.spec.js +310 -2
- 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 +388 -388
- package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
- package/dist/stories/PrimitivesGallery.svelte +752 -752
- package/dist/stories/RecipesGallery.stories.svelte +19 -19
- package/dist/stories/RecipesGallery.svelte +441 -441
- package/dist/stories/button-audit-manifest.json +11186 -11186
- package/dist/tailwind/preset.cjs +82 -82
- package/dist/telemetry.js +357 -357
- package/dist/tokens/tokens.css +87 -87
- package/dist/utils/apiConfig.js +49 -49
- package/dist/utils/utils.js +9 -1
- package/package.json +233 -191
|
@@ -1,85 +1,85 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
import { SearchOutline } from "../../primitives/Icons";
|
|
3
|
-
import { typography } from '../../tokens/typography';
|
|
4
|
-
|
|
5
|
-
// API compatible with flowbite-svelte Search
|
|
6
|
-
let {
|
|
7
|
-
value = $bindable(""),
|
|
8
|
-
placeholder = "Search",
|
|
9
|
-
size = "lg", // sm, md, lg
|
|
10
|
-
disabled = false,
|
|
11
|
-
id = "",
|
|
12
|
-
name = "",
|
|
13
|
-
class: className = "",
|
|
14
|
-
// Callbacks
|
|
15
|
-
oninput,
|
|
16
|
-
onchange,
|
|
17
|
-
onkeydown,
|
|
18
|
-
onkeyup,
|
|
19
|
-
onfocus,
|
|
20
|
-
onblur,
|
|
21
|
-
// Snippet for trailing content
|
|
22
|
-
children,
|
|
23
|
-
...restProps
|
|
24
|
-
} = $props();
|
|
25
|
-
|
|
26
|
-
const sizes = {
|
|
27
|
-
sm: { icon: "w-3.5 h-3.5", input: `h-8 ${typography.xs} pl-8`, wrapper: "h-8" },
|
|
28
|
-
md: { icon: "w-4 h-4", input: `h-10 ${typography.sm} pl-9`, wrapper: "h-10" },
|
|
29
|
-
lg: { icon: "w-5 h-5", input: `h-11 ${typography.sm} pl-10`, wrapper: "h-11" }
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
let sizeConfig = $derived(sizes[size] || sizes.lg);
|
|
33
|
-
|
|
34
|
-
function handleInput(event) {
|
|
35
|
-
value = event.target.value;
|
|
36
|
-
oninput?.(event);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
function handleChange(event) {
|
|
40
|
-
onchange?.(event);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
function handleKeydown(event) {
|
|
44
|
-
onkeydown?.(event);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
function handleKeyup(event) {
|
|
48
|
-
onkeyup?.(event);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
function handleFocus(event) {
|
|
52
|
-
onfocus?.(event);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
function handleBlur(event) {
|
|
56
|
-
onblur?.(event);
|
|
57
|
-
}
|
|
58
|
-
</script>
|
|
59
|
-
|
|
60
|
-
<div class="relative w-full {sizeConfig.wrapper} {className}">
|
|
61
|
-
<div class="absolute inset-y-0 left-0 flex items-center pl-3 pointer-events-none">
|
|
62
|
-
<SearchOutline class={`${typography.iconMuted} ${sizeConfig.icon}`} />
|
|
63
|
-
</div>
|
|
64
|
-
<input
|
|
65
|
-
type="search"
|
|
66
|
-
{id}
|
|
67
|
-
{name}
|
|
68
|
-
{placeholder}
|
|
69
|
-
{disabled}
|
|
70
|
-
class="w-full pr-3 bg-gray-50 dark:bg-gray-700 font-medium border border-gray-300 dark:border-gray-600 rounded-lg transition-colors focus:outline-none focus:ring-4 focus:ring-blue-300 dark:focus:ring-blue-800 focus:border-blue-500 hover:border-blue-500 placeholder-gray-500 dark:placeholder-gray-400 [&::-webkit-search-cancel-button]:appearance-none {sizeConfig.input} {disabled ? 'opacity-50 cursor-not-allowed' : ''}"
|
|
71
|
-
bind:value
|
|
72
|
-
oninput={handleInput}
|
|
73
|
-
onchange={handleChange}
|
|
74
|
-
onkeydown={handleKeydown}
|
|
75
|
-
onkeyup={handleKeyup}
|
|
76
|
-
onfocus={handleFocus}
|
|
77
|
-
onblur={handleBlur}
|
|
78
|
-
{...restProps}
|
|
79
|
-
/>
|
|
80
|
-
{#if children}
|
|
81
|
-
<div class={`absolute inset-y-0 right-0 flex items-center ${typography.iconMuted}`}>
|
|
82
|
-
{@render children()}
|
|
83
|
-
</div>
|
|
84
|
-
{/if}
|
|
85
|
-
</div>
|
|
1
|
+
<script>
|
|
2
|
+
import { SearchOutline } from "../../primitives/Icons";
|
|
3
|
+
import { typography } from '../../tokens/typography';
|
|
4
|
+
|
|
5
|
+
// API compatible with flowbite-svelte Search
|
|
6
|
+
let {
|
|
7
|
+
value = $bindable(""),
|
|
8
|
+
placeholder = "Search",
|
|
9
|
+
size = "lg", // sm, md, lg
|
|
10
|
+
disabled = false,
|
|
11
|
+
id = "",
|
|
12
|
+
name = "",
|
|
13
|
+
class: className = "",
|
|
14
|
+
// Callbacks
|
|
15
|
+
oninput,
|
|
16
|
+
onchange,
|
|
17
|
+
onkeydown,
|
|
18
|
+
onkeyup,
|
|
19
|
+
onfocus,
|
|
20
|
+
onblur,
|
|
21
|
+
// Snippet for trailing content
|
|
22
|
+
children,
|
|
23
|
+
...restProps
|
|
24
|
+
} = $props();
|
|
25
|
+
|
|
26
|
+
const sizes = {
|
|
27
|
+
sm: { icon: "w-3.5 h-3.5", input: `h-8 ${typography.xs} pl-8`, wrapper: "h-8" },
|
|
28
|
+
md: { icon: "w-4 h-4", input: `h-10 ${typography.sm} pl-9`, wrapper: "h-10" },
|
|
29
|
+
lg: { icon: "w-5 h-5", input: `h-11 ${typography.sm} pl-10`, wrapper: "h-11" }
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
let sizeConfig = $derived(sizes[size] || sizes.lg);
|
|
33
|
+
|
|
34
|
+
function handleInput(event) {
|
|
35
|
+
value = event.target.value;
|
|
36
|
+
oninput?.(event);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function handleChange(event) {
|
|
40
|
+
onchange?.(event);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function handleKeydown(event) {
|
|
44
|
+
onkeydown?.(event);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function handleKeyup(event) {
|
|
48
|
+
onkeyup?.(event);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function handleFocus(event) {
|
|
52
|
+
onfocus?.(event);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function handleBlur(event) {
|
|
56
|
+
onblur?.(event);
|
|
57
|
+
}
|
|
58
|
+
</script>
|
|
59
|
+
|
|
60
|
+
<div class="relative w-full {sizeConfig.wrapper} {className}">
|
|
61
|
+
<div class="absolute inset-y-0 left-0 flex items-center pl-3 pointer-events-none">
|
|
62
|
+
<SearchOutline class={`${typography.iconMuted} ${sizeConfig.icon}`} />
|
|
63
|
+
</div>
|
|
64
|
+
<input
|
|
65
|
+
type="search"
|
|
66
|
+
{id}
|
|
67
|
+
{name}
|
|
68
|
+
{placeholder}
|
|
69
|
+
{disabled}
|
|
70
|
+
class="w-full pr-3 bg-gray-50 dark:bg-gray-700 font-medium border border-gray-300 dark:border-gray-600 rounded-lg transition-colors focus:outline-none focus:ring-4 focus:ring-blue-300 dark:focus:ring-blue-800 focus:border-blue-500 hover:border-blue-500 placeholder-gray-500 dark:placeholder-gray-400 [&::-webkit-search-cancel-button]:appearance-none {sizeConfig.input} {disabled ? 'opacity-50 cursor-not-allowed' : ''}"
|
|
71
|
+
bind:value
|
|
72
|
+
oninput={handleInput}
|
|
73
|
+
onchange={handleChange}
|
|
74
|
+
onkeydown={handleKeydown}
|
|
75
|
+
onkeyup={handleKeyup}
|
|
76
|
+
onfocus={handleFocus}
|
|
77
|
+
onblur={handleBlur}
|
|
78
|
+
{...restProps}
|
|
79
|
+
/>
|
|
80
|
+
{#if children}
|
|
81
|
+
<div class={`absolute inset-y-0 right-0 flex items-center ${typography.iconMuted}`}>
|
|
82
|
+
{@render children()}
|
|
83
|
+
</div>
|
|
84
|
+
{/if}
|
|
85
|
+
</div>
|
|
@@ -1,161 +1,161 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
import { tick } from "svelte";
|
|
3
|
-
import { ChevronDownOutline } from "../../primitives/Icons";
|
|
4
|
-
|
|
5
|
-
let {
|
|
6
|
-
/** @type {Array<{label: string, value: string}>} Options to display */
|
|
7
|
-
options = [],
|
|
8
|
-
/** @type {{label: string, value: string}|null} Currently selected option */
|
|
9
|
-
selected = $bindable(null),
|
|
10
|
-
/** @type {string} Placeholder text when no option is selected */
|
|
11
|
-
placeholder = "Select",
|
|
12
|
-
/** @type {string} Additional CSS classes for the container */
|
|
13
|
-
class: className = "",
|
|
14
|
-
/** @type {boolean} Whether the dropdown is disabled */
|
|
15
|
-
disabled = false,
|
|
16
|
-
// Callbacks
|
|
17
|
-
onselect,
|
|
18
|
-
} = $props();
|
|
19
|
-
|
|
20
|
-
let isOpen = $state(false);
|
|
21
|
-
let triggerRef = $state();
|
|
22
|
-
let menuRef = $state();
|
|
23
|
-
let containerRef = $state();
|
|
24
|
-
let focusedIndex = $state(-1);
|
|
25
|
-
let optionElements = $state([]);
|
|
26
|
-
|
|
27
|
-
async function toggleDropdown() {
|
|
28
|
-
if (disabled) return;
|
|
29
|
-
isOpen = !isOpen;
|
|
30
|
-
if (isOpen) {
|
|
31
|
-
focusedIndex = -1;
|
|
32
|
-
await tick();
|
|
33
|
-
updateOptionElements();
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
function updateOptionElements() {
|
|
38
|
-
if (menuRef) {
|
|
39
|
-
optionElements = Array.from(menuRef.querySelectorAll('[role="option"]'));
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
function focusOption(index) {
|
|
44
|
-
if (optionElements.length === 0) return;
|
|
45
|
-
if (index < 0) index = optionElements.length - 1;
|
|
46
|
-
if (index >= optionElements.length) index = 0;
|
|
47
|
-
focusedIndex = index;
|
|
48
|
-
optionElements[focusedIndex]?.focus();
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
function selectOption(option) {
|
|
52
|
-
selected = option;
|
|
53
|
-
onselect?.(option);
|
|
54
|
-
isOpen = false;
|
|
55
|
-
triggerRef?.focus();
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
// CRITICAL FIX: Click-outside detection using mousedown for reliable detection
|
|
59
|
-
function handleClickOutside(event) {
|
|
60
|
-
if (!isOpen) return;
|
|
61
|
-
|
|
62
|
-
// Check if click is inside the container (trigger or menu)
|
|
63
|
-
if (containerRef && containerRef.contains(event.target)) {
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
// Click was outside - close the dropdown
|
|
68
|
-
isOpen = false;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
function handleKeyDown(event) {
|
|
72
|
-
if (!isOpen) return;
|
|
73
|
-
|
|
74
|
-
// Only handle if event originated from within this dropdown
|
|
75
|
-
if (!menuRef?.contains(event.target) && !triggerRef?.contains(event.target)) {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
switch (event.key) {
|
|
80
|
-
case "Escape":
|
|
81
|
-
isOpen = false;
|
|
82
|
-
triggerRef?.focus();
|
|
83
|
-
event.preventDefault();
|
|
84
|
-
break;
|
|
85
|
-
case "ArrowDown":
|
|
86
|
-
focusOption(focusedIndex + 1);
|
|
87
|
-
event.preventDefault();
|
|
88
|
-
break;
|
|
89
|
-
case "ArrowUp":
|
|
90
|
-
focusOption(focusedIndex - 1);
|
|
91
|
-
event.preventDefault();
|
|
92
|
-
break;
|
|
93
|
-
case "Home":
|
|
94
|
-
focusOption(0);
|
|
95
|
-
event.preventDefault();
|
|
96
|
-
break;
|
|
97
|
-
case "End":
|
|
98
|
-
focusOption(optionElements.length - 1);
|
|
99
|
-
event.preventDefault();
|
|
100
|
-
break;
|
|
101
|
-
case "Tab":
|
|
102
|
-
isOpen = false;
|
|
103
|
-
break;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
$effect(() => {
|
|
108
|
-
if (typeof window !== "undefined") {
|
|
109
|
-
// Use mousedown for click-outside to capture before click completes
|
|
110
|
-
document.addEventListener("mousedown", handleClickOutside, true);
|
|
111
|
-
document.addEventListener("keydown", handleKeyDown);
|
|
112
|
-
return () => {
|
|
113
|
-
document.removeEventListener("mousedown", handleClickOutside, true);
|
|
114
|
-
document.removeEventListener("keydown", handleKeyDown);
|
|
115
|
-
};
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
</script>
|
|
119
|
-
|
|
120
|
-
<div bind:this={containerRef} class="relative inline-block text-left {className}">
|
|
121
|
-
<button
|
|
122
|
-
bind:this={triggerRef}
|
|
123
|
-
type="button"
|
|
124
|
-
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' : ''}"
|
|
125
|
-
onclick={toggleDropdown}
|
|
126
|
-
aria-haspopup="listbox"
|
|
127
|
-
aria-expanded={isOpen}
|
|
128
|
-
aria-label={placeholder}
|
|
129
|
-
{disabled}
|
|
130
|
-
>
|
|
131
|
-
<span class="truncate">
|
|
132
|
-
{selected?.label || placeholder}
|
|
133
|
-
</span>
|
|
134
|
-
<ChevronDownOutline class="w-4 h-4 ml-2 transition-transform duration-200 {isOpen ? 'rotate-180' : ''}" />
|
|
135
|
-
</button>
|
|
136
|
-
|
|
137
|
-
{#if isOpen}
|
|
138
|
-
<div
|
|
139
|
-
bind:this={menuRef}
|
|
140
|
-
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"
|
|
141
|
-
role="listbox"
|
|
142
|
-
aria-label={placeholder}
|
|
143
|
-
>
|
|
144
|
-
<ul class="py-2 text-sm text-gray-700 dark:text-gray-200">
|
|
145
|
-
{#each options as option}
|
|
146
|
-
<li>
|
|
147
|
-
<button
|
|
148
|
-
type="button"
|
|
149
|
-
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' : ''}"
|
|
150
|
-
onclick={() => selectOption(option)}
|
|
151
|
-
role="option"
|
|
152
|
-
aria-selected={selected?.value === option.value}
|
|
153
|
-
>
|
|
154
|
-
{option.label}
|
|
155
|
-
</button>
|
|
156
|
-
</li>
|
|
157
|
-
{/each}
|
|
158
|
-
</ul>
|
|
159
|
-
</div>
|
|
160
|
-
{/if}
|
|
161
|
-
</div>
|
|
1
|
+
<script>
|
|
2
|
+
import { tick } from "svelte";
|
|
3
|
+
import { ChevronDownOutline } from "../../primitives/Icons";
|
|
4
|
+
|
|
5
|
+
let {
|
|
6
|
+
/** @type {Array<{label: string, value: string}>} Options to display */
|
|
7
|
+
options = [],
|
|
8
|
+
/** @type {{label: string, value: string}|null} Currently selected option */
|
|
9
|
+
selected = $bindable(null),
|
|
10
|
+
/** @type {string} Placeholder text when no option is selected */
|
|
11
|
+
placeholder = "Select",
|
|
12
|
+
/** @type {string} Additional CSS classes for the container */
|
|
13
|
+
class: className = "",
|
|
14
|
+
/** @type {boolean} Whether the dropdown is disabled */
|
|
15
|
+
disabled = false,
|
|
16
|
+
// Callbacks
|
|
17
|
+
onselect,
|
|
18
|
+
} = $props();
|
|
19
|
+
|
|
20
|
+
let isOpen = $state(false);
|
|
21
|
+
let triggerRef = $state();
|
|
22
|
+
let menuRef = $state();
|
|
23
|
+
let containerRef = $state();
|
|
24
|
+
let focusedIndex = $state(-1);
|
|
25
|
+
let optionElements = $state([]);
|
|
26
|
+
|
|
27
|
+
async function toggleDropdown() {
|
|
28
|
+
if (disabled) return;
|
|
29
|
+
isOpen = !isOpen;
|
|
30
|
+
if (isOpen) {
|
|
31
|
+
focusedIndex = -1;
|
|
32
|
+
await tick();
|
|
33
|
+
updateOptionElements();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
function updateOptionElements() {
|
|
38
|
+
if (menuRef) {
|
|
39
|
+
optionElements = Array.from(menuRef.querySelectorAll('[role="option"]'));
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function focusOption(index) {
|
|
44
|
+
if (optionElements.length === 0) return;
|
|
45
|
+
if (index < 0) index = optionElements.length - 1;
|
|
46
|
+
if (index >= optionElements.length) index = 0;
|
|
47
|
+
focusedIndex = index;
|
|
48
|
+
optionElements[focusedIndex]?.focus();
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function selectOption(option) {
|
|
52
|
+
selected = option;
|
|
53
|
+
onselect?.(option);
|
|
54
|
+
isOpen = false;
|
|
55
|
+
triggerRef?.focus();
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
// CRITICAL FIX: Click-outside detection using mousedown for reliable detection
|
|
59
|
+
function handleClickOutside(event) {
|
|
60
|
+
if (!isOpen) return;
|
|
61
|
+
|
|
62
|
+
// Check if click is inside the container (trigger or menu)
|
|
63
|
+
if (containerRef && containerRef.contains(event.target)) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// Click was outside - close the dropdown
|
|
68
|
+
isOpen = false;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
function handleKeyDown(event) {
|
|
72
|
+
if (!isOpen) return;
|
|
73
|
+
|
|
74
|
+
// Only handle if event originated from within this dropdown
|
|
75
|
+
if (!menuRef?.contains(event.target) && !triggerRef?.contains(event.target)) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
switch (event.key) {
|
|
80
|
+
case "Escape":
|
|
81
|
+
isOpen = false;
|
|
82
|
+
triggerRef?.focus();
|
|
83
|
+
event.preventDefault();
|
|
84
|
+
break;
|
|
85
|
+
case "ArrowDown":
|
|
86
|
+
focusOption(focusedIndex + 1);
|
|
87
|
+
event.preventDefault();
|
|
88
|
+
break;
|
|
89
|
+
case "ArrowUp":
|
|
90
|
+
focusOption(focusedIndex - 1);
|
|
91
|
+
event.preventDefault();
|
|
92
|
+
break;
|
|
93
|
+
case "Home":
|
|
94
|
+
focusOption(0);
|
|
95
|
+
event.preventDefault();
|
|
96
|
+
break;
|
|
97
|
+
case "End":
|
|
98
|
+
focusOption(optionElements.length - 1);
|
|
99
|
+
event.preventDefault();
|
|
100
|
+
break;
|
|
101
|
+
case "Tab":
|
|
102
|
+
isOpen = false;
|
|
103
|
+
break;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
$effect(() => {
|
|
108
|
+
if (typeof window !== "undefined") {
|
|
109
|
+
// Use mousedown for click-outside to capture before click completes
|
|
110
|
+
document.addEventListener("mousedown", handleClickOutside, true);
|
|
111
|
+
document.addEventListener("keydown", handleKeyDown);
|
|
112
|
+
return () => {
|
|
113
|
+
document.removeEventListener("mousedown", handleClickOutside, true);
|
|
114
|
+
document.removeEventListener("keydown", handleKeyDown);
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
</script>
|
|
119
|
+
|
|
120
|
+
<div bind:this={containerRef} class="relative inline-block text-left {className}">
|
|
121
|
+
<button
|
|
122
|
+
bind:this={triggerRef}
|
|
123
|
+
type="button"
|
|
124
|
+
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' : ''}"
|
|
125
|
+
onclick={toggleDropdown}
|
|
126
|
+
aria-haspopup="listbox"
|
|
127
|
+
aria-expanded={isOpen}
|
|
128
|
+
aria-label={placeholder}
|
|
129
|
+
{disabled}
|
|
130
|
+
>
|
|
131
|
+
<span class="truncate">
|
|
132
|
+
{selected?.label || placeholder}
|
|
133
|
+
</span>
|
|
134
|
+
<ChevronDownOutline class="w-4 h-4 ml-2 transition-transform duration-200 {isOpen ? 'rotate-180' : ''}" />
|
|
135
|
+
</button>
|
|
136
|
+
|
|
137
|
+
{#if isOpen}
|
|
138
|
+
<div
|
|
139
|
+
bind:this={menuRef}
|
|
140
|
+
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"
|
|
141
|
+
role="listbox"
|
|
142
|
+
aria-label={placeholder}
|
|
143
|
+
>
|
|
144
|
+
<ul class="py-2 text-sm text-gray-700 dark:text-gray-200">
|
|
145
|
+
{#each options as option}
|
|
146
|
+
<li>
|
|
147
|
+
<button
|
|
148
|
+
type="button"
|
|
149
|
+
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' : ''}"
|
|
150
|
+
onclick={() => selectOption(option)}
|
|
151
|
+
role="option"
|
|
152
|
+
aria-selected={selected?.value === option.value}
|
|
153
|
+
>
|
|
154
|
+
{option.label}
|
|
155
|
+
</button>
|
|
156
|
+
</li>
|
|
157
|
+
{/each}
|
|
158
|
+
</ul>
|
|
159
|
+
</div>
|
|
160
|
+
{/if}
|
|
161
|
+
</div>
|