@getmicdrop/svelte-components 5.5.4 → 5.5.5
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.spec.d.ts +2 -0
- package/dist/calendar/AboutShow/AboutShow.spec.d.ts.map +1 -0
- package/dist/calendar/AboutShow/AboutShow.spec.js +791 -0
- package/dist/calendar/Calendar/MiniMonthCalendar.spec.d.ts +2 -0
- package/dist/calendar/Calendar/MiniMonthCalendar.spec.d.ts.map +1 -0
- package/dist/calendar/Calendar/MiniMonthCalendar.spec.js +1191 -0
- package/dist/calendar/FAQs/FAQs.spec.d.ts +2 -0
- package/dist/calendar/FAQs/FAQs.spec.d.ts.map +1 -0
- package/dist/calendar/FAQs/FAQs.spec.js +238 -0
- package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.d.ts +2 -0
- package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.d.ts.map +1 -0
- package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.js +420 -0
- package/dist/calendar/OrderSummary/OrderSummary.spec.d.ts +2 -0
- package/dist/calendar/OrderSummary/OrderSummary.spec.d.ts.map +1 -0
- package/dist/calendar/OrderSummary/OrderSummary.spec.js +808 -0
- package/dist/calendar/PublicCard/PublicCard.spec.d.ts +2 -0
- package/dist/calendar/PublicCard/PublicCard.spec.d.ts.map +1 -0
- package/dist/calendar/PublicCard/PublicCard.spec.js +301 -0
- package/dist/calendar/ShowCard/ShowCard.spec.d.ts +2 -0
- package/dist/calendar/ShowCard/ShowCard.spec.d.ts.map +1 -0
- package/dist/calendar/ShowCard/ShowCard.spec.js +714 -0
- package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.d.ts +2 -0
- package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.d.ts.map +1 -0
- package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.js +241 -0
- package/dist/components/Layout/Section.spec.d.ts +2 -0
- package/dist/components/Layout/Section.spec.d.ts.map +1 -0
- package/dist/components/Layout/Section.spec.js +149 -0
- package/dist/components/Layout/Sidebar.spec.d.ts +2 -0
- package/dist/components/Layout/Sidebar.spec.d.ts.map +1 -0
- package/dist/components/Layout/Sidebar.spec.js +186 -0
- package/dist/components/Layout/Stack.spec.js +3 -3
- package/dist/constants/formOptions.spec.js +9 -5
- 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 +124 -2
- package/dist/datetime/parse.js +1 -1
- package/dist/forms/createFieldTracker.spec.d.ts +2 -0
- package/dist/forms/createFieldTracker.spec.d.ts.map +1 -0
- package/dist/forms/createFieldTracker.spec.js +343 -0
- package/dist/forms/createFormStore.spec.d.ts +2 -0
- package/dist/forms/createFormStore.spec.d.ts.map +1 -0
- package/dist/forms/createFormStore.spec.js +689 -0
- package/dist/forms/createFormStore.svelte.js +0 -1
- package/dist/index.d.ts +4 -112
- package/dist/index.js +4 -190
- package/dist/patterns/data/DataGrid.spec.d.ts +2 -0
- package/dist/patterns/data/DataGrid.spec.d.ts.map +1 -0
- package/dist/patterns/data/DataGrid.spec.js +159 -0
- package/dist/patterns/data/DataList.spec.d.ts +2 -0
- package/dist/patterns/data/DataList.spec.d.ts.map +1 -0
- package/dist/patterns/data/DataList.spec.js +158 -0
- package/dist/patterns/data/DataTable.spec.d.ts +2 -0
- package/dist/patterns/data/DataTable.spec.d.ts.map +1 -0
- package/dist/patterns/data/DataTable.spec.js +196 -0
- package/dist/patterns/forms/FormActions.spec.js +10 -3
- package/dist/patterns/forms/FormGrid.spec.d.ts +2 -0
- package/dist/patterns/forms/FormGrid.spec.d.ts.map +1 -0
- package/dist/patterns/forms/FormGrid.spec.js +125 -0
- package/dist/patterns/forms/FormSection.spec.d.ts +2 -0
- package/dist/patterns/forms/FormSection.spec.d.ts.map +1 -0
- package/dist/patterns/forms/FormSection.spec.js +153 -0
- package/dist/patterns/layout/Sidebar.spec.d.ts +2 -0
- package/dist/patterns/layout/Sidebar.spec.d.ts.map +1 -0
- package/dist/patterns/layout/Sidebar.spec.js +159 -0
- package/dist/patterns/navigation/BottomNav.svelte +4 -4
- package/dist/patterns/navigation/Header.spec.js +33 -24
- package/dist/patterns/page/PageHeader.spec.d.ts +2 -0
- package/dist/patterns/page/PageHeader.spec.d.ts.map +1 -0
- package/dist/patterns/page/PageHeader.spec.js +167 -0
- package/dist/patterns/page/PageLayout.spec.d.ts +2 -0
- package/dist/patterns/page/PageLayout.spec.d.ts.map +1 -0
- package/dist/patterns/page/PageLayout.spec.js +145 -0
- package/dist/patterns/page/PageLoader.spec.js +5 -2
- package/dist/patterns/page/SectionHeader.spec.d.ts +2 -0
- package/dist/patterns/page/SectionHeader.spec.d.ts.map +1 -0
- package/dist/patterns/page/SectionHeader.spec.js +197 -0
- package/dist/presets/badges.spec.d.ts +2 -0
- package/dist/presets/badges.spec.d.ts.map +1 -0
- package/dist/presets/badges.spec.js +172 -0
- package/dist/presets/buttons.spec.d.ts +2 -0
- package/dist/presets/buttons.spec.d.ts.map +1 -0
- package/dist/presets/buttons.spec.js +135 -0
- package/dist/primitives/Accordion/Accordion.spec.d.ts +2 -0
- package/dist/primitives/Accordion/Accordion.spec.d.ts.map +1 -0
- package/dist/primitives/Accordion/Accordion.spec.js +83 -0
- package/dist/primitives/Accordion/AccordionItem.spec.d.ts +2 -0
- package/dist/primitives/Accordion/AccordionItem.spec.d.ts.map +1 -0
- package/dist/primitives/Accordion/AccordionItem.spec.js +661 -0
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -0
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +35 -0
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -0
- package/dist/primitives/Alert/Alert.spec.js +5 -2
- package/dist/primitives/Avatar/Avatar.spec.d.ts +2 -0
- package/dist/primitives/Avatar/Avatar.spec.d.ts.map +1 -0
- package/dist/primitives/Avatar/Avatar.spec.js +211 -0
- package/dist/primitives/Badges/Badge.spec.js +109 -68
- package/dist/primitives/BottomSheet/BottomSheet.spec.js +36 -27
- package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte +13 -0
- package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts +7 -0
- package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts.map +1 -0
- package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +15 -13
- package/dist/primitives/Breadcrumb/Breadcrumb.svelte +5 -5
- package/dist/primitives/Button/Button.spec.js +83 -71
- package/dist/primitives/Button/ButtonSaveDemo.spec.js +100 -2
- package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts +2 -0
- package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts.map +1 -0
- package/dist/primitives/Button/ButtonVariantShowcase.spec.js +202 -0
- package/dist/primitives/Card.spec.js +1 -1
- package/dist/primitives/Checkbox/Checkbox.spec.d.ts +2 -0
- package/dist/primitives/Checkbox/Checkbox.spec.d.ts.map +1 -0
- package/dist/primitives/Checkbox/Checkbox.spec.js +252 -0
- package/dist/primitives/DarkModeToggle.spec.js +84 -51
- package/dist/primitives/Drawer/Drawer.spec.d.ts +2 -0
- package/dist/primitives/Drawer/Drawer.spec.d.ts.map +1 -0
- package/dist/primitives/Drawer/Drawer.spec.js +212 -0
- package/dist/primitives/Dropdown/Dropdown.spec.d.ts +2 -0
- package/dist/primitives/Dropdown/Dropdown.spec.d.ts.map +1 -0
- package/dist/primitives/Dropdown/Dropdown.spec.js +366 -0
- package/dist/primitives/Dropdown/DropdownItem.spec.d.ts +2 -0
- package/dist/primitives/Dropdown/DropdownItem.spec.d.ts.map +1 -0
- package/dist/primitives/Dropdown/DropdownItem.spec.js +182 -0
- package/dist/primitives/Icons/iconTestUtils.spec.d.ts +2 -0
- package/dist/primitives/Icons/iconTestUtils.spec.d.ts.map +1 -0
- package/dist/primitives/Icons/iconTestUtils.spec.js +235 -0
- package/dist/primitives/Input/Input.spec.js +14 -14
- package/dist/primitives/Input/Input.svelte +1 -14
- package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
- package/dist/primitives/Input/Select.spec.js +11 -17
- package/dist/primitives/Input/Textarea.spec.d.ts +2 -0
- package/dist/primitives/Input/Textarea.spec.d.ts.map +1 -0
- package/dist/primitives/Input/Textarea.spec.js +255 -0
- package/dist/primitives/Label/Label.spec.d.ts +2 -0
- package/dist/primitives/Label/Label.spec.d.ts.map +1 -0
- package/dist/primitives/Label/Label.spec.js +157 -0
- package/dist/primitives/Modal/Modal.spec.js +29 -25
- package/dist/primitives/Modal/ModalTestWrapper.svelte +65 -0
- package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts +23 -0
- package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts.map +1 -0
- package/dist/primitives/NumberInput/NumberInput.spec.d.ts +2 -0
- package/dist/primitives/NumberInput/NumberInput.spec.d.ts.map +1 -0
- package/dist/primitives/NumberInput/NumberInput.spec.js +235 -0
- package/dist/primitives/Pagination/Pagination.spec.d.ts +2 -0
- package/dist/primitives/Pagination/Pagination.spec.d.ts.map +1 -0
- package/dist/primitives/Pagination/Pagination.spec.js +266 -0
- package/dist/primitives/Radio/Radio.spec.d.ts +2 -0
- package/dist/primitives/Radio/Radio.spec.d.ts.map +1 -0
- package/dist/primitives/Radio/Radio.spec.js +206 -0
- package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts +2 -0
- package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts.map +1 -0
- package/dist/primitives/Skeleton/CardPlaceholder.spec.js +156 -0
- package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts +2 -0
- package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts.map +1 -0
- package/dist/primitives/Skeleton/ImagePlaceholder.spec.js +120 -0
- package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts +2 -0
- package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts.map +1 -0
- package/dist/primitives/Skeleton/ListPlaceholder.spec.js +220 -0
- package/dist/primitives/Skeleton/Skeleton.spec.d.ts +2 -0
- package/dist/primitives/Skeleton/Skeleton.spec.d.ts.map +1 -0
- package/dist/primitives/Skeleton/Skeleton.spec.js +173 -0
- package/dist/primitives/Spinner/Spinner.spec.js +25 -29
- package/dist/primitives/Tabs/TabItem.spec.d.ts +2 -0
- package/dist/primitives/Tabs/TabItem.spec.d.ts.map +1 -0
- package/dist/primitives/Tabs/TabItem.spec.js +130 -0
- package/dist/primitives/Tabs/Tabs.spec.d.ts +2 -0
- package/dist/primitives/Tabs/Tabs.spec.d.ts.map +1 -0
- package/dist/primitives/Tabs/Tabs.spec.js +295 -0
- package/dist/primitives/Tabs/TabsWithItems.test.svelte +18 -0
- package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts +16 -0
- package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts.map +1 -0
- package/dist/primitives/Toggle.spec.js +93 -77
- package/dist/primitives/Typography/Typography.spec.d.ts +2 -0
- package/dist/primitives/Typography/Typography.spec.d.ts.map +1 -0
- package/dist/primitives/Typography/Typography.spec.js +183 -0
- package/dist/primitives/ValidationError.spec.js +1 -1
- package/dist/primitives/index.d.ts +1 -0
- package/dist/primitives/index.js +3 -0
- package/dist/recipes/CropImage/CropImage.spec.js +1 -9
- package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts +2 -0
- package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts.map +1 -0
- package/dist/recipes/ImageUploader/ImageUploader.spec.js +1351 -0
- package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts +2 -0
- package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts.map +1 -0
- package/dist/recipes/SuperLogin/SuperLogin.spec.js +1436 -0
- package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts +2 -0
- package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts.map +1 -0
- package/dist/recipes/feedback/EmptyState/EmptyState.spec.js +202 -0
- package/dist/recipes/feedback/ErrorDisplay.spec.js +6 -6
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +21 -17
- package/dist/recipes/fields/CheckboxField.spec.d.ts +2 -0
- package/dist/recipes/fields/CheckboxField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/CheckboxField.spec.js +135 -0
- package/dist/recipes/fields/FormField.spec.d.ts +2 -0
- package/dist/recipes/fields/FormField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/FormField.spec.js +159 -0
- package/dist/recipes/fields/RadioGroup.spec.d.ts +2 -0
- package/dist/recipes/fields/RadioGroup.spec.d.ts.map +1 -0
- package/dist/recipes/fields/RadioGroup.spec.js +199 -0
- package/dist/recipes/fields/SelectField.spec.d.ts +2 -0
- package/dist/recipes/fields/SelectField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/SelectField.spec.js +188 -0
- package/dist/recipes/fields/TextareaField.spec.d.ts +2 -0
- package/dist/recipes/fields/TextareaField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/TextareaField.spec.js +205 -0
- package/dist/recipes/fields/ToggleField.spec.d.ts +2 -0
- package/dist/recipes/fields/ToggleField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/ToggleField.spec.js +153 -0
- package/dist/recipes/inputs/MultiSelect.spec.js +4 -3
- package/dist/recipes/inputs/MultiSelect.svelte +10 -3
- package/dist/recipes/inputs/MultiSelect.svelte.d.ts +2 -0
- package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
- package/dist/recipes/inputs/OTPInput.spec.js +52 -39
- package/dist/recipes/inputs/PasswordInput.spec.d.ts +2 -0
- package/dist/recipes/inputs/PasswordInput.spec.d.ts.map +1 -0
- package/dist/recipes/inputs/PasswordInput.spec.js +410 -0
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +253 -173
- package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte +71 -0
- package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts +9 -0
- package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts.map +1 -0
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +1246 -300
- package/dist/recipes/inputs/Search.spec.d.ts +2 -0
- package/dist/recipes/inputs/Search.spec.d.ts.map +1 -0
- package/dist/recipes/inputs/Search.spec.js +177 -0
- package/dist/recipes/inputs/SelectDropdown.spec.d.ts +2 -0
- package/dist/recipes/inputs/SelectDropdown.spec.d.ts.map +1 -0
- package/dist/recipes/inputs/SelectDropdown.spec.js +512 -0
- package/dist/recipes/modals/AlertModal.spec.d.ts +2 -0
- package/dist/recipes/modals/AlertModal.spec.d.ts.map +1 -0
- package/dist/recipes/modals/AlertModal.spec.js +432 -0
- package/dist/recipes/modals/ConfirmationModal.spec.js +36 -21
- package/dist/recipes/modals/InputModal.spec.d.ts +2 -0
- package/dist/recipes/modals/InputModal.spec.d.ts.map +1 -0
- package/dist/recipes/modals/InputModal.spec.js +872 -0
- package/dist/recipes/modals/ModalTestWrapper.spec.d.ts +2 -0
- package/dist/recipes/modals/ModalTestWrapper.spec.d.ts.map +1 -0
- package/dist/recipes/modals/ModalTestWrapper.spec.js +502 -0
- package/dist/recipes/modals/StatusModal.spec.d.ts +2 -0
- package/dist/recipes/modals/StatusModal.spec.d.ts.map +1 -0
- package/dist/recipes/modals/StatusModal.spec.js +599 -0
- package/dist/services/ShowService.spec.js +18 -15
- package/dist/stories/ButtonAuditDashboard.spec.d.ts +2 -0
- package/dist/stories/ButtonAuditDashboard.spec.d.ts.map +1 -0
- package/dist/stories/ButtonAuditDashboard.spec.js +913 -0
- package/dist/stories/ButtonAuditReview.spec.d.ts +2 -0
- package/dist/stories/ButtonAuditReview.spec.d.ts.map +1 -0
- package/dist/stories/ButtonAuditReview.spec.js +422 -0
- package/dist/stories/ButtonGridView.spec.d.ts +2 -0
- package/dist/stories/ButtonGridView.spec.d.ts.map +1 -0
- package/dist/stories/ButtonGridView.spec.js +667 -0
- package/dist/stories/ButtonShowcase.spec.d.ts +2 -0
- package/dist/stories/ButtonShowcase.spec.d.ts.map +1 -0
- package/dist/stories/ButtonShowcase.spec.js +499 -0
- package/dist/stories/PatternsGallery.spec.d.ts +2 -0
- package/dist/stories/PatternsGallery.spec.d.ts.map +1 -0
- package/dist/stories/PatternsGallery.spec.js +514 -0
- package/dist/stories/PrimitivesGallery.spec.d.ts +2 -0
- package/dist/stories/PrimitivesGallery.spec.d.ts.map +1 -0
- package/dist/stories/PrimitivesGallery.spec.js +813 -0
- package/dist/stories/RecipesGallery.spec.d.ts +2 -0
- package/dist/stories/RecipesGallery.spec.d.ts.map +1 -0
- package/dist/stories/RecipesGallery.spec.js +299 -0
- package/dist/stripe/useStripeTheme.spec.d.ts +2 -0
- package/dist/stripe/useStripeTheme.spec.d.ts.map +1 -0
- package/dist/stripe/useStripeTheme.spec.js +793 -0
- package/dist/telemetry.d.ts.map +1 -1
- package/dist/telemetry.js +6 -5
- package/dist/telemetry.spec.js +495 -12
- package/dist/tokens/__tests__/colors.test.d.ts +2 -0
- package/dist/tokens/__tests__/colors.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/colors.test.js +152 -0
- package/dist/tokens/__tests__/radius.test.d.ts +2 -0
- package/dist/tokens/__tests__/radius.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/radius.test.js +118 -0
- package/dist/tokens/__tests__/shadows.test.d.ts +2 -0
- package/dist/tokens/__tests__/shadows.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/shadows.test.js +105 -0
- package/dist/tokens/__tests__/spacing.test.js +11 -8
- package/dist/tokens/__tests__/typography.test.d.ts +2 -0
- package/dist/tokens/__tests__/typography.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/typography.test.js +156 -0
- package/dist/tokens/__tests__/z-index.test.d.ts +2 -0
- package/dist/tokens/__tests__/z-index.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/z-index.test.js +121 -0
- package/dist/utils/apiConfig.spec.js +102 -1
- package/dist/utils/formatters.spec.d.ts +2 -0
- package/dist/utils/formatters.spec.d.ts.map +1 -0
- package/dist/utils/formatters.spec.js +82 -0
- package/dist/utils/transitions.spec.d.ts +2 -0
- package/dist/utils/transitions.spec.d.ts.map +1 -0
- package/dist/utils/transitions.spec.js +130 -0
- package/package.json +8 -3
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { getTimezoneDisplayName, getTimezoneOffset, getUserTimezone, getVenueTimezone, isDST, isValidTimezone, normalizeTimezone, } from '../timezone';
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { getTimezoneDisplayName, getTimezoneOffset, getUserTimezone, getVenueTimezone, isDST, isValidTimezone, normalizeTimezone, getIANATimezone, isValidIANATimezone, getAllTimezones, formatTimezoneForDisplay, getTimezoneOptions, getCommonUSTimezoneOptions, } from '../timezone';
|
|
3
3
|
import { DateTimeError, DateTimeErrorCode } from '../types';
|
|
4
4
|
describe('timezone utilities', () => {
|
|
5
5
|
describe('isValidTimezone', () => {
|
|
@@ -211,4 +211,126 @@ describe('timezone utilities', () => {
|
|
|
211
211
|
expect(() => isDST('Invalid/Zone')).toThrow(DateTimeError);
|
|
212
212
|
});
|
|
213
213
|
});
|
|
214
|
+
describe('getIANATimezone', () => {
|
|
215
|
+
it('returns default timezone for null or undefined', () => {
|
|
216
|
+
expect(getIANATimezone(null)).toBe('America/Los_Angeles');
|
|
217
|
+
expect(getIANATimezone(undefined)).toBe('America/Los_Angeles');
|
|
218
|
+
});
|
|
219
|
+
it('returns default timezone for "NaN" string', () => {
|
|
220
|
+
expect(getIANATimezone('NaN')).toBe('America/Los_Angeles');
|
|
221
|
+
});
|
|
222
|
+
it('converts legacy timezone strings', () => {
|
|
223
|
+
// Check LEGACY_TIMEZONE_MAP from constants
|
|
224
|
+
expect(getIANATimezone('California USA')).toBe('America/Los_Angeles');
|
|
225
|
+
});
|
|
226
|
+
it('returns valid IANA timezone as-is', () => {
|
|
227
|
+
expect(getIANATimezone('America/New_York')).toBe('America/New_York');
|
|
228
|
+
expect(getIANATimezone('Europe/London')).toBe('Europe/London');
|
|
229
|
+
expect(getIANATimezone('Asia/Tokyo')).toBe('Asia/Tokyo');
|
|
230
|
+
});
|
|
231
|
+
it('normalizes timezone abbreviations', () => {
|
|
232
|
+
expect(getIANATimezone('PST')).toBe('America/Los_Angeles');
|
|
233
|
+
expect(getIANATimezone('EST')).toBe('America/New_York');
|
|
234
|
+
expect(getIANATimezone('CST')).toBe('America/Chicago');
|
|
235
|
+
});
|
|
236
|
+
it('returns default timezone for invalid input', () => {
|
|
237
|
+
expect(getIANATimezone('Invalid/Zone')).toBe('America/Los_Angeles');
|
|
238
|
+
expect(getIANATimezone('UNKNOWN')).toBe('America/Los_Angeles');
|
|
239
|
+
});
|
|
240
|
+
});
|
|
241
|
+
describe('isValidIANATimezone', () => {
|
|
242
|
+
it('is an alias for isValidTimezone', () => {
|
|
243
|
+
expect(isValidIANATimezone('America/Los_Angeles')).toBe(true);
|
|
244
|
+
expect(isValidIANATimezone('Invalid/Zone')).toBe(false);
|
|
245
|
+
});
|
|
246
|
+
});
|
|
247
|
+
describe('getAllTimezones', () => {
|
|
248
|
+
it('returns an array of timezone identifiers', () => {
|
|
249
|
+
const timezones = getAllTimezones();
|
|
250
|
+
expect(Array.isArray(timezones)).toBe(true);
|
|
251
|
+
expect(timezones.length).toBeGreaterThan(0);
|
|
252
|
+
});
|
|
253
|
+
it('includes common timezones', () => {
|
|
254
|
+
const timezones = getAllTimezones();
|
|
255
|
+
expect(timezones).toContain('America/Los_Angeles');
|
|
256
|
+
expect(timezones).toContain('America/New_York');
|
|
257
|
+
expect(timezones).toContain('Europe/London');
|
|
258
|
+
});
|
|
259
|
+
});
|
|
260
|
+
describe('formatTimezoneForDisplay', () => {
|
|
261
|
+
it('formats timezone with abbreviation', () => {
|
|
262
|
+
const formatted = formatTimezoneForDisplay('America/Los_Angeles');
|
|
263
|
+
expect(formatted).toContain('America / Los Angeles');
|
|
264
|
+
expect(formatted).toMatch(/\(P[SD]T\)/);
|
|
265
|
+
});
|
|
266
|
+
it('formats timezone with underscores replaced', () => {
|
|
267
|
+
const formatted = formatTimezoneForDisplay('America/New_York');
|
|
268
|
+
expect(formatted).toContain('America / New York');
|
|
269
|
+
});
|
|
270
|
+
it('handles UTC', () => {
|
|
271
|
+
const formatted = formatTimezoneForDisplay('UTC');
|
|
272
|
+
expect(formatted).toContain('UTC');
|
|
273
|
+
});
|
|
274
|
+
it('falls back gracefully for invalid timezones', () => {
|
|
275
|
+
const formatted = formatTimezoneForDisplay('Invalid/Zone');
|
|
276
|
+
expect(typeof formatted).toBe('string');
|
|
277
|
+
expect(formatted).toContain('Invalid');
|
|
278
|
+
});
|
|
279
|
+
});
|
|
280
|
+
describe('getTimezoneOptions', () => {
|
|
281
|
+
it('returns array of timezone options', () => {
|
|
282
|
+
const options = getTimezoneOptions();
|
|
283
|
+
expect(Array.isArray(options)).toBe(true);
|
|
284
|
+
expect(options.length).toBeGreaterThan(0);
|
|
285
|
+
});
|
|
286
|
+
it('has correct structure with value and name', () => {
|
|
287
|
+
const options = getTimezoneOptions();
|
|
288
|
+
options.forEach(option => {
|
|
289
|
+
expect(option).toHaveProperty('value');
|
|
290
|
+
expect(option).toHaveProperty('name');
|
|
291
|
+
expect(typeof option.value).toBe('string');
|
|
292
|
+
expect(typeof option.name).toBe('string');
|
|
293
|
+
});
|
|
294
|
+
});
|
|
295
|
+
it('includes common timezones', () => {
|
|
296
|
+
const options = getTimezoneOptions();
|
|
297
|
+
const values = options.map(opt => opt.value);
|
|
298
|
+
expect(values).toContain('America/Los_Angeles');
|
|
299
|
+
expect(values).toContain('America/New_York');
|
|
300
|
+
});
|
|
301
|
+
});
|
|
302
|
+
describe('getCommonUSTimezoneOptions', () => {
|
|
303
|
+
it('returns array of common US timezone options', () => {
|
|
304
|
+
const options = getCommonUSTimezoneOptions();
|
|
305
|
+
expect(Array.isArray(options)).toBe(true);
|
|
306
|
+
expect(options.length).toBe(7);
|
|
307
|
+
});
|
|
308
|
+
it('has correct structure with value and name', () => {
|
|
309
|
+
const options = getCommonUSTimezoneOptions();
|
|
310
|
+
options.forEach(option => {
|
|
311
|
+
expect(option).toHaveProperty('value');
|
|
312
|
+
expect(option).toHaveProperty('name');
|
|
313
|
+
expect(typeof option.value).toBe('string');
|
|
314
|
+
expect(typeof option.name).toBe('string');
|
|
315
|
+
});
|
|
316
|
+
});
|
|
317
|
+
it('includes all major US timezones', () => {
|
|
318
|
+
const options = getCommonUSTimezoneOptions();
|
|
319
|
+
const values = options.map(opt => opt.value);
|
|
320
|
+
expect(values).toContain('America/Los_Angeles');
|
|
321
|
+
expect(values).toContain('America/Denver');
|
|
322
|
+
expect(values).toContain('America/Phoenix');
|
|
323
|
+
expect(values).toContain('America/Chicago');
|
|
324
|
+
expect(values).toContain('America/New_York');
|
|
325
|
+
expect(values).toContain('America/Anchorage');
|
|
326
|
+
expect(values).toContain('Pacific/Honolulu');
|
|
327
|
+
});
|
|
328
|
+
it('formats names correctly', () => {
|
|
329
|
+
const options = getCommonUSTimezoneOptions();
|
|
330
|
+
options.forEach(option => {
|
|
331
|
+
expect(option.name).toContain('/');
|
|
332
|
+
expect(option.name).toMatch(/\([A-Z]+\)/);
|
|
333
|
+
});
|
|
334
|
+
});
|
|
335
|
+
});
|
|
214
336
|
});
|
package/dist/datetime/parse.js
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
*
|
|
7
7
|
* @module datetime/parse
|
|
8
8
|
*/
|
|
9
|
-
import { format
|
|
9
|
+
import { format } from 'date-fns';
|
|
10
10
|
import { fromZonedTime, toZonedTime } from 'date-fns-tz';
|
|
11
11
|
import { DATE_FORMATS } from './constants';
|
|
12
12
|
import { isValidTimezone } from './timezone';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createFieldTracker.spec.d.ts","sourceRoot":"","sources":["../../src/lib/forms/createFieldTracker.spec.js"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,343 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
|
+
import { render, cleanup } from '@testing-library/svelte';
|
|
3
|
+
import { tick } from 'svelte';
|
|
4
|
+
|
|
5
|
+
// Test wrapper component to use the field tracker
|
|
6
|
+
// We need a Svelte component to test reactive behavior
|
|
7
|
+
const createTestComponent = () => {
|
|
8
|
+
const script = `
|
|
9
|
+
<script>
|
|
10
|
+
import { createFieldTracker } from './createFieldTracker.svelte.ts';
|
|
11
|
+
|
|
12
|
+
let { initialDirty = false, tracker: trackerRef = null } = $props();
|
|
13
|
+
let dirtyValue = $state(initialDirty);
|
|
14
|
+
|
|
15
|
+
const tracker = createFieldTracker(() => dirtyValue);
|
|
16
|
+
|
|
17
|
+
// Expose tracker via bindable prop
|
|
18
|
+
$effect(() => {
|
|
19
|
+
if (trackerRef) {
|
|
20
|
+
trackerRef.current = tracker;
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
export function setDirty(value) {
|
|
25
|
+
dirtyValue = value;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export function getTracker() {
|
|
29
|
+
return tracker;
|
|
30
|
+
}
|
|
31
|
+
</script>
|
|
32
|
+
<div data-testid="tracker-test"></div>
|
|
33
|
+
`;
|
|
34
|
+
|
|
35
|
+
return script;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
// Since we can't dynamically create components, we'll test the module directly
|
|
39
|
+
// The module uses Svelte runes which require proper Svelte context
|
|
40
|
+
// For this module, we'll test what we can and document limitations
|
|
41
|
+
|
|
42
|
+
describe('createFieldTracker Module', () => {
|
|
43
|
+
describe('module exports', () => {
|
|
44
|
+
it('exports createFieldTracker function', async () => {
|
|
45
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
46
|
+
expect(typeof createFieldTracker).toBe('function');
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
describe('tracker creation', () => {
|
|
51
|
+
it('creates a tracker with required properties', async () => {
|
|
52
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
53
|
+
const tracker = createFieldTracker(() => false);
|
|
54
|
+
|
|
55
|
+
expect(tracker).toHaveProperty('isLoading');
|
|
56
|
+
expect(tracker).toHaveProperty('isSaving');
|
|
57
|
+
expect(tracker).toHaveProperty('isSaved');
|
|
58
|
+
expect(tracker).toHaveProperty('isDirty');
|
|
59
|
+
expect(tracker).toHaveProperty('canSave');
|
|
60
|
+
expect(tracker).toHaveProperty('reset');
|
|
61
|
+
expect(tracker).toHaveProperty('markSaved');
|
|
62
|
+
expect(tracker).toHaveProperty('save');
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
it('has correct initial state values', async () => {
|
|
66
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
67
|
+
const tracker = createFieldTracker(() => false);
|
|
68
|
+
|
|
69
|
+
expect(tracker.isLoading).toBe(false);
|
|
70
|
+
expect(tracker.isSaving).toBe(false);
|
|
71
|
+
expect(tracker.isSaved).toBe(false);
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
describe('isLoading property', () => {
|
|
76
|
+
it('can be set to true', async () => {
|
|
77
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
78
|
+
const tracker = createFieldTracker(() => false);
|
|
79
|
+
|
|
80
|
+
tracker.isLoading = true;
|
|
81
|
+
expect(tracker.isLoading).toBe(true);
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
it('can be set back to false', async () => {
|
|
85
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
86
|
+
const tracker = createFieldTracker(() => false);
|
|
87
|
+
|
|
88
|
+
tracker.isLoading = true;
|
|
89
|
+
tracker.isLoading = false;
|
|
90
|
+
expect(tracker.isLoading).toBe(false);
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
describe('isSaving property', () => {
|
|
95
|
+
it('can be set to true', async () => {
|
|
96
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
97
|
+
const tracker = createFieldTracker(() => false);
|
|
98
|
+
|
|
99
|
+
tracker.isSaving = true;
|
|
100
|
+
expect(tracker.isSaving).toBe(true);
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
it('can be set back to false', async () => {
|
|
104
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
105
|
+
const tracker = createFieldTracker(() => false);
|
|
106
|
+
|
|
107
|
+
tracker.isSaving = true;
|
|
108
|
+
tracker.isSaving = false;
|
|
109
|
+
expect(tracker.isSaving).toBe(false);
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
describe('isSaved property', () => {
|
|
114
|
+
it('can be set to true', async () => {
|
|
115
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
116
|
+
const tracker = createFieldTracker(() => false);
|
|
117
|
+
|
|
118
|
+
tracker.isSaved = true;
|
|
119
|
+
expect(tracker.isSaved).toBe(true);
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
it('can be set back to false', async () => {
|
|
123
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
124
|
+
const tracker = createFieldTracker(() => false);
|
|
125
|
+
|
|
126
|
+
tracker.isSaved = true;
|
|
127
|
+
tracker.isSaved = false;
|
|
128
|
+
expect(tracker.isSaved).toBe(false);
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
describe('isDirty property', () => {
|
|
133
|
+
it('reflects isDirtyFn return value when false', async () => {
|
|
134
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
135
|
+
const tracker = createFieldTracker(() => false);
|
|
136
|
+
|
|
137
|
+
expect(tracker.isDirty).toBe(false);
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
it('reflects isDirtyFn return value when true', async () => {
|
|
141
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
142
|
+
const tracker = createFieldTracker(() => true);
|
|
143
|
+
|
|
144
|
+
expect(tracker.isDirty).toBe(true);
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
describe('canSave method', () => {
|
|
149
|
+
it('returns false when not dirty and valid', async () => {
|
|
150
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
151
|
+
const tracker = createFieldTracker(() => false);
|
|
152
|
+
|
|
153
|
+
expect(tracker.canSave(true)).toBe(false);
|
|
154
|
+
});
|
|
155
|
+
|
|
156
|
+
it('returns false when dirty but not valid', async () => {
|
|
157
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
158
|
+
const tracker = createFieldTracker(() => true);
|
|
159
|
+
|
|
160
|
+
expect(tracker.canSave(false)).toBe(false);
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
it('returns true when dirty and valid', async () => {
|
|
164
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
165
|
+
const tracker = createFieldTracker(() => true);
|
|
166
|
+
|
|
167
|
+
expect(tracker.canSave(true)).toBe(true);
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
it('returns false when saving', async () => {
|
|
171
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
172
|
+
const tracker = createFieldTracker(() => true);
|
|
173
|
+
|
|
174
|
+
tracker.isSaving = true;
|
|
175
|
+
expect(tracker.canSave(true)).toBe(false);
|
|
176
|
+
});
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
describe('reset method', () => {
|
|
180
|
+
it('resets isLoading to false', async () => {
|
|
181
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
182
|
+
const tracker = createFieldTracker(() => false);
|
|
183
|
+
|
|
184
|
+
tracker.isLoading = true;
|
|
185
|
+
tracker.reset();
|
|
186
|
+
expect(tracker.isLoading).toBe(false);
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
it('resets isSaving to false', async () => {
|
|
190
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
191
|
+
const tracker = createFieldTracker(() => false);
|
|
192
|
+
|
|
193
|
+
tracker.isSaving = true;
|
|
194
|
+
tracker.reset();
|
|
195
|
+
expect(tracker.isSaving).toBe(false);
|
|
196
|
+
});
|
|
197
|
+
|
|
198
|
+
it('resets isSaved to false', async () => {
|
|
199
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
200
|
+
const tracker = createFieldTracker(() => false);
|
|
201
|
+
|
|
202
|
+
tracker.isSaved = true;
|
|
203
|
+
tracker.reset();
|
|
204
|
+
expect(tracker.isSaved).toBe(false);
|
|
205
|
+
});
|
|
206
|
+
|
|
207
|
+
it('resets all states at once', async () => {
|
|
208
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
209
|
+
const tracker = createFieldTracker(() => false);
|
|
210
|
+
|
|
211
|
+
tracker.isLoading = true;
|
|
212
|
+
tracker.isSaving = true;
|
|
213
|
+
tracker.isSaved = true;
|
|
214
|
+
tracker.reset();
|
|
215
|
+
|
|
216
|
+
expect(tracker.isLoading).toBe(false);
|
|
217
|
+
expect(tracker.isSaving).toBe(false);
|
|
218
|
+
expect(tracker.isSaved).toBe(false);
|
|
219
|
+
});
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
describe('markSaved method', () => {
|
|
223
|
+
it('sets isSaved to true', async () => {
|
|
224
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
225
|
+
const tracker = createFieldTracker(() => false);
|
|
226
|
+
|
|
227
|
+
tracker.markSaved();
|
|
228
|
+
expect(tracker.isSaved).toBe(true);
|
|
229
|
+
});
|
|
230
|
+
|
|
231
|
+
it('can mark saved multiple times', async () => {
|
|
232
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
233
|
+
const tracker = createFieldTracker(() => false);
|
|
234
|
+
|
|
235
|
+
tracker.markSaved();
|
|
236
|
+
tracker.isSaved = false;
|
|
237
|
+
tracker.markSaved();
|
|
238
|
+
expect(tracker.isSaved).toBe(true);
|
|
239
|
+
});
|
|
240
|
+
});
|
|
241
|
+
|
|
242
|
+
describe('save method', () => {
|
|
243
|
+
it('sets isSaving to true during save', async () => {
|
|
244
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
245
|
+
const tracker = createFieldTracker(() => true);
|
|
246
|
+
|
|
247
|
+
let savingDuringSave = false;
|
|
248
|
+
await tracker.save(async () => {
|
|
249
|
+
savingDuringSave = tracker.isSaving;
|
|
250
|
+
return 'result';
|
|
251
|
+
});
|
|
252
|
+
|
|
253
|
+
expect(savingDuringSave).toBe(true);
|
|
254
|
+
});
|
|
255
|
+
|
|
256
|
+
it('sets isSaving to false after save completes', async () => {
|
|
257
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
258
|
+
const tracker = createFieldTracker(() => true);
|
|
259
|
+
|
|
260
|
+
await tracker.save(async () => 'result');
|
|
261
|
+
|
|
262
|
+
expect(tracker.isSaving).toBe(false);
|
|
263
|
+
});
|
|
264
|
+
|
|
265
|
+
it('sets isSaved to true after successful save', async () => {
|
|
266
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
267
|
+
const tracker = createFieldTracker(() => true);
|
|
268
|
+
|
|
269
|
+
await tracker.save(async () => 'result');
|
|
270
|
+
|
|
271
|
+
expect(tracker.isSaved).toBe(true);
|
|
272
|
+
});
|
|
273
|
+
|
|
274
|
+
it('returns the result from the save function', async () => {
|
|
275
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
276
|
+
const tracker = createFieldTracker(() => true);
|
|
277
|
+
|
|
278
|
+
const result = await tracker.save(async () => 'test result');
|
|
279
|
+
|
|
280
|
+
expect(result).toBe('test result');
|
|
281
|
+
});
|
|
282
|
+
|
|
283
|
+
it('returns typed result', async () => {
|
|
284
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
285
|
+
const tracker = createFieldTracker(() => true);
|
|
286
|
+
|
|
287
|
+
const result = await tracker.save(async () => ({ id: 1, name: 'test' }));
|
|
288
|
+
|
|
289
|
+
expect(result).toEqual({ id: 1, name: 'test' });
|
|
290
|
+
});
|
|
291
|
+
|
|
292
|
+
it('sets isSaving to false even if save throws', async () => {
|
|
293
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
294
|
+
const tracker = createFieldTracker(() => true);
|
|
295
|
+
|
|
296
|
+
try {
|
|
297
|
+
await tracker.save(async () => {
|
|
298
|
+
throw new Error('Save failed');
|
|
299
|
+
});
|
|
300
|
+
} catch {
|
|
301
|
+
// Expected
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
expect(tracker.isSaving).toBe(false);
|
|
305
|
+
});
|
|
306
|
+
|
|
307
|
+
it('propagates errors from save function', async () => {
|
|
308
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
309
|
+
const tracker = createFieldTracker(() => true);
|
|
310
|
+
|
|
311
|
+
await expect(tracker.save(async () => {
|
|
312
|
+
throw new Error('Save failed');
|
|
313
|
+
})).rejects.toThrow('Save failed');
|
|
314
|
+
});
|
|
315
|
+
|
|
316
|
+
it('does not set isSaved if save throws', async () => {
|
|
317
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
318
|
+
const tracker = createFieldTracker(() => true);
|
|
319
|
+
|
|
320
|
+
try {
|
|
321
|
+
await tracker.save(async () => {
|
|
322
|
+
throw new Error('Save failed');
|
|
323
|
+
});
|
|
324
|
+
} catch {
|
|
325
|
+
// Expected
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
expect(tracker.isSaved).toBe(false);
|
|
329
|
+
});
|
|
330
|
+
});
|
|
331
|
+
|
|
332
|
+
describe('type interface', () => {
|
|
333
|
+
it('methods are callable', async () => {
|
|
334
|
+
const { createFieldTracker } = await import('./createFieldTracker.svelte.ts');
|
|
335
|
+
const tracker = createFieldTracker(() => false);
|
|
336
|
+
|
|
337
|
+
expect(typeof tracker.canSave).toBe('function');
|
|
338
|
+
expect(typeof tracker.reset).toBe('function');
|
|
339
|
+
expect(typeof tracker.markSaved).toBe('function');
|
|
340
|
+
expect(typeof tracker.save).toBe('function');
|
|
341
|
+
});
|
|
342
|
+
});
|
|
343
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createFormStore.spec.d.ts","sourceRoot":"","sources":["../../src/lib/forms/createFormStore.spec.js"],"names":[],"mappings":""}
|