flowbite-svelte 1.9.0 → 1.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/accordion/Accordion.svelte +8 -9
- package/dist/accordion/Accordion.svelte.d.ts +1 -1
- package/dist/accordion/AccordionItem.svelte +10 -11
- package/dist/accordion/AccordionItem.svelte.d.ts +1 -1
- package/dist/accordion/index.d.ts +1 -1
- package/dist/accordion/index.js +1 -1
- package/dist/accordion/theme.d.ts +18 -3
- package/dist/accordion/theme.js +6 -2
- package/dist/alert/Alert.svelte +8 -8
- package/dist/alert/Alert.svelte.d.ts +1 -1
- package/dist/alert/index.d.ts +1 -1
- package/dist/alert/theme.d.ts +1 -0
- package/dist/avatar/Avatar.svelte +8 -9
- package/dist/avatar/Avatar.svelte.d.ts +1 -1
- package/dist/avatar/index.d.ts +1 -1
- package/dist/avatar/theme.d.ts +1 -0
- package/dist/badge/Badge.svelte +9 -11
- package/dist/badge/Badge.svelte.d.ts +1 -1
- package/dist/badge/index.d.ts +1 -1
- package/dist/badge/theme.d.ts +5 -3
- package/dist/badge/theme.js +1 -1
- package/dist/banner/Banner.svelte +9 -5
- package/dist/banner/Banner.svelte.d.ts +1 -1
- package/dist/banner/index.d.ts +1 -1
- package/dist/banner/theme.d.ts +2 -0
- package/dist/bottom-navigation/BottomNav.svelte +8 -4
- package/dist/bottom-navigation/BottomNav.svelte.d.ts +1 -1
- package/dist/bottom-navigation/BottomNavHeader.svelte +11 -6
- package/dist/bottom-navigation/BottomNavHeader.svelte.d.ts +1 -1
- package/dist/bottom-navigation/BottomNavHeaderItem.svelte +9 -4
- package/dist/bottom-navigation/BottomNavHeaderItem.svelte.d.ts +1 -1
- package/dist/bottom-navigation/BottomNavItem.svelte +8 -4
- package/dist/bottom-navigation/BottomNavItem.svelte.d.ts +1 -1
- package/dist/bottom-navigation/index.d.ts +1 -1
- package/dist/bottom-navigation/index.js +1 -1
- package/dist/bottom-navigation/theme.d.ts +10 -2
- package/dist/bottom-navigation/theme.js +2 -2
- package/dist/breadcrumb/Breadcrumb.svelte +7 -10
- package/dist/breadcrumb/Breadcrumb.svelte.d.ts +1 -1
- package/dist/breadcrumb/BreadcrumbItem.svelte +13 -10
- package/dist/breadcrumb/BreadcrumbItem.svelte.d.ts +1 -1
- package/dist/breadcrumb/index.d.ts +1 -1
- package/dist/breadcrumb/index.js +1 -1
- package/dist/breadcrumb/theme.d.ts +33 -22
- package/dist/breadcrumb/theme.js +18 -12
- package/dist/button-group/ButtonGroup.svelte +5 -2
- package/dist/button-group/ButtonGroup.svelte.d.ts +1 -1
- package/dist/button-group/index.d.ts +1 -1
- package/dist/button-group/theme.d.ts +1 -0
- package/dist/buttons/Button.svelte +7 -3
- package/dist/buttons/Button.svelte.d.ts +1 -1
- package/dist/buttons/GradientButton.svelte +8 -5
- package/dist/buttons/GradientButton.svelte.d.ts +1 -1
- package/dist/buttons/index.d.ts +1 -1
- package/dist/buttons/theme.d.ts +4 -0
- package/dist/card/Card.svelte +9 -6
- package/dist/card/Card.svelte.d.ts +2 -2
- package/dist/card/index.d.ts +1 -1
- package/dist/card/theme.d.ts +2 -0
- package/dist/carousel/Carousel.svelte +5 -2
- package/dist/carousel/Carousel.svelte.d.ts +1 -1
- package/dist/carousel/{Indicators.svelte → CarouselIndicators.svelte} +8 -5
- package/dist/carousel/{Indicators.svelte.d.ts → CarouselIndicators.svelte.d.ts} +4 -4
- package/dist/carousel/ControlButton.svelte +5 -2
- package/dist/carousel/ControlButton.svelte.d.ts +1 -1
- package/dist/carousel/Controls.svelte +6 -3
- package/dist/carousel/Controls.svelte.d.ts +1 -1
- package/dist/carousel/Slide.svelte +5 -2
- package/dist/carousel/Slide.svelte.d.ts +1 -1
- package/dist/carousel/Thumbnail.svelte +5 -2
- package/dist/carousel/Thumbnail.svelte.d.ts +1 -1
- package/dist/carousel/Thumbnails.svelte +5 -2
- package/dist/carousel/Thumbnails.svelte.d.ts +1 -1
- package/dist/carousel/index.d.ts +2 -2
- package/dist/carousel/index.js +2 -2
- package/dist/carousel/theme.d.ts +8 -1
- package/dist/carousel/theme.js +1 -2
- package/dist/clipboard/Clipboard.svelte +6 -3
- package/dist/clipboard/Clipboard.svelte.d.ts +2 -2
- package/dist/clipboard/index.d.ts +1 -1
- package/dist/clipboard/theme.d.ts +1 -0
- package/dist/darkmode/DarkMode.svelte +5 -2
- package/dist/darkmode/DarkMode.svelte.d.ts +1 -1
- package/dist/darkmode/index.d.ts +1 -1
- package/dist/darkmode/theme.d.ts +1 -0
- package/dist/datepicker/Datepicker.svelte +25 -20
- package/dist/datepicker/Datepicker.svelte.d.ts +2 -2
- package/dist/datepicker/index.d.ts +1 -1
- package/dist/datepicker/theme.d.ts +2 -0
- package/dist/device-mockups/Android.svelte +1 -1
- package/dist/device-mockups/Android.svelte.d.ts +1 -1
- package/dist/device-mockups/DefaultMockup.svelte +1 -1
- package/dist/device-mockups/DefaultMockup.svelte.d.ts +1 -1
- package/dist/device-mockups/Desktop.svelte +1 -1
- package/dist/device-mockups/Desktop.svelte.d.ts +1 -1
- package/dist/device-mockups/DeviceMockup.svelte +1 -1
- package/dist/device-mockups/DeviceMockup.svelte.d.ts +1 -1
- package/dist/device-mockups/Ios.svelte +1 -1
- package/dist/device-mockups/Ios.svelte.d.ts +1 -1
- package/dist/device-mockups/Laptop.svelte +1 -1
- package/dist/device-mockups/Laptop.svelte.d.ts +1 -1
- package/dist/device-mockups/Smartwatch.svelte +1 -1
- package/dist/device-mockups/Smartwatch.svelte.d.ts +1 -1
- package/dist/device-mockups/Tablet.svelte +1 -1
- package/dist/device-mockups/Tablet.svelte.d.ts +1 -1
- package/dist/device-mockups/theme.d.ts +21 -21
- package/dist/drawer/Drawer.svelte +8 -5
- package/dist/drawer/Drawer.svelte.d.ts +1 -1
- package/dist/drawer/Drawerhead.svelte +8 -5
- package/dist/drawer/Drawerhead.svelte.d.ts +1 -1
- package/dist/drawer/index.d.ts +1 -1
- package/dist/drawer/theme.d.ts +16 -12
- package/dist/drawer/theme.js +4 -4
- package/dist/dropdown/Dropdown.svelte +5 -2
- package/dist/dropdown/Dropdown.svelte.d.ts +1 -1
- package/dist/dropdown/DropdownDivider.svelte +5 -2
- package/dist/dropdown/DropdownDivider.svelte.d.ts +1 -1
- package/dist/dropdown/DropdownGroup.svelte +5 -2
- package/dist/dropdown/DropdownGroup.svelte.d.ts +1 -1
- package/dist/dropdown/DropdownHeader.svelte +5 -2
- package/dist/dropdown/DropdownHeader.svelte.d.ts +1 -1
- package/dist/dropdown/DropdownItem.svelte +6 -3
- package/dist/dropdown/DropdownItem.svelte.d.ts +1 -1
- package/dist/dropdown/index.d.ts +1 -1
- package/dist/dropdown/theme.d.ts +7 -0
- package/dist/footer/Footer.svelte +5 -2
- package/dist/footer/Footer.svelte.d.ts +1 -1
- package/dist/footer/FooterBrand.svelte +8 -5
- package/dist/footer/FooterBrand.svelte.d.ts +1 -1
- package/dist/footer/FooterCopyright.svelte +8 -5
- package/dist/footer/FooterCopyright.svelte.d.ts +1 -1
- package/dist/footer/FooterIcon.svelte +5 -2
- package/dist/footer/FooterIcon.svelte.d.ts +1 -1
- package/dist/footer/FooterLink.svelte +8 -4
- package/dist/footer/FooterLink.svelte.d.ts +1 -1
- package/dist/footer/FooterLinkGroup.svelte +5 -2
- package/dist/footer/FooterLinkGroup.svelte.d.ts +1 -1
- package/dist/footer/index.d.ts +1 -1
- package/dist/footer/theme.d.ts +18 -10
- package/dist/footer/theme.js +6 -7
- package/dist/forms/button-toggle/ButtonToggle.svelte +8 -5
- package/dist/forms/button-toggle/ButtonToggle.svelte.d.ts +1 -1
- package/dist/forms/button-toggle/ButtonToggleGroup.svelte +4 -1
- package/dist/forms/button-toggle/CheckIcon.svelte +1 -1
- package/dist/forms/button-toggle/CheckIcon.svelte.d.ts +1 -1
- package/dist/forms/button-toggle/index.d.ts +1 -1
- package/dist/forms/button-toggle/theme.d.ts +152 -144
- package/dist/forms/button-toggle/theme.js +65 -63
- package/dist/forms/checkbox/Checkbox.svelte +8 -5
- package/dist/forms/checkbox/CheckboxButton.svelte +5 -2
- package/dist/forms/checkbox/CheckboxButton.svelte.d.ts +1 -1
- package/dist/forms/checkbox/index.d.ts +1 -1
- package/dist/forms/checkbox/theme.d.ts +3 -0
- package/dist/forms/dropzone/Dropzone.svelte +5 -2
- package/dist/forms/dropzone/Dropzone.svelte.d.ts +1 -1
- package/dist/forms/dropzone/index.d.ts +1 -1
- package/dist/forms/dropzone/theme.d.ts +1 -0
- package/dist/forms/fileupload/Fileupload.svelte +8 -5
- package/dist/forms/fileupload/Fileupload.svelte.d.ts +1 -1
- package/dist/forms/fileupload/index.d.ts +1 -1
- package/dist/forms/fileupload/theme.d.ts +2 -0
- package/dist/forms/floating-label/FloatingLabelInput.svelte +11 -8
- package/dist/forms/floating-label/FloatingLabelInput.svelte.d.ts +1 -1
- package/dist/forms/floating-label/index.d.ts +1 -1
- package/dist/forms/floating-label/theme.d.ts +5 -3
- package/dist/forms/floating-label/theme.js +1 -1
- package/dist/forms/helper/Helper.svelte +5 -2
- package/dist/forms/helper/Helper.svelte.d.ts +1 -1
- package/dist/forms/helper/index.d.ts +1 -1
- package/dist/forms/helper/theme.d.ts +1 -0
- package/dist/forms/input-addon/InputAddon.svelte +6 -2
- package/dist/forms/input-addon/InputAddon.svelte.d.ts +1 -1
- package/dist/forms/input-field/Input.svelte +13 -10
- package/dist/forms/input-field/index.d.ts +1 -1
- package/dist/forms/input-field/theme.d.ts +5 -3
- package/dist/forms/input-field/theme.js +1 -1
- package/dist/forms/label/Label.svelte +5 -2
- package/dist/forms/label/Label.svelte.d.ts +1 -1
- package/dist/forms/label/index.d.ts +1 -1
- package/dist/forms/label/theme.d.ts +1 -0
- package/dist/forms/phoneinput/PhoneInput.svelte +11 -8
- package/dist/forms/phoneinput/PhoneInput.svelte.d.ts +1 -1
- package/dist/forms/phoneinput/index.d.ts +1 -1
- package/dist/forms/phoneinput/theme.d.ts +2 -0
- package/dist/forms/radio/Radio.svelte +6 -3
- package/dist/forms/radio/RadioButton.svelte +4 -1
- package/dist/forms/radio/index.d.ts +1 -1
- package/dist/forms/radio/theme.d.ts +3 -0
- package/dist/forms/range/Range.svelte +5 -2
- package/dist/forms/range/Range.svelte.d.ts +1 -1
- package/dist/forms/range/theme.d.ts +1 -0
- package/dist/forms/search/Search.svelte +12 -9
- package/dist/forms/search/Search.svelte.d.ts +1 -1
- package/dist/forms/search/index.d.ts +1 -1
- package/dist/forms/search/theme.d.ts +5 -3
- package/dist/forms/search/theme.js +1 -1
- package/dist/forms/select/MultiSelect.svelte +7 -4
- package/dist/forms/select/Select.svelte +8 -5
- package/dist/forms/select/index.d.ts +1 -1
- package/dist/forms/select/index.js +1 -1
- package/dist/forms/select/theme.d.ts +7 -3
- package/dist/forms/select/theme.js +1 -1
- package/dist/forms/tags/Tags.svelte +10 -7
- package/dist/forms/tags/Tags.svelte.d.ts +1 -1
- package/dist/forms/tags/index.d.ts +1 -1
- package/dist/forms/tags/theme.d.ts +11 -9
- package/dist/forms/tags/theme.js +1 -1
- package/dist/forms/textarea/Textarea.svelte +14 -11
- package/dist/forms/textarea/Textarea.svelte.d.ts +1 -1
- package/dist/forms/textarea/index.d.ts +1 -1
- package/dist/forms/textarea/theme.d.ts +5 -3
- package/dist/forms/textarea/theme.js +1 -1
- package/dist/forms/timepicker/Timepicker.svelte +107 -64
- package/dist/forms/timepicker/Timepicker.svelte.d.ts +1 -1
- package/dist/forms/timepicker/index.d.ts +1 -0
- package/dist/forms/timepicker/index.js +1 -0
- package/dist/forms/timepicker/theme.d.ts +191 -0
- package/dist/forms/timepicker/theme.js +72 -0
- package/dist/forms/toggle/Toggle.svelte +8 -5
- package/dist/forms/toggle/Toggle.svelte.d.ts +1 -1
- package/dist/forms/toggle/index.d.ts +1 -1
- package/dist/forms/toggle/theme.d.ts +2 -0
- package/dist/gallery/Gallery.svelte +7 -4
- package/dist/gallery/Gallery.svelte.d.ts +1 -1
- package/dist/gallery/index.d.ts +1 -1
- package/dist/gallery/theme.d.ts +5 -3
- package/dist/index.d.ts +2 -2
- package/dist/index.js +5 -2
- package/dist/indicator/Indicator.svelte +6 -3
- package/dist/indicator/Indicator.svelte.d.ts +1 -1
- package/dist/indicator/index.d.ts +1 -1
- package/dist/indicator/theme.d.ts +121 -360
- package/dist/indicator/theme.js +48 -56
- package/dist/kbd/Kbd.svelte +6 -2
- package/dist/kbd/Kbd.svelte.d.ts +1 -1
- package/dist/kbd/index.d.ts +1 -1
- package/dist/kbd/theme.d.ts +1 -0
- package/dist/list-group/Listgroup.svelte +5 -2
- package/dist/list-group/Listgroup.svelte.d.ts +1 -1
- package/dist/list-group/ListgroupItem.svelte +7 -4
- package/dist/list-group/ListgroupItem.svelte.d.ts +1 -1
- package/dist/list-group/index.d.ts +1 -1
- package/dist/list-group/theme.d.ts +2 -0
- package/dist/mega-menu/MegaMenu.svelte +9 -6
- package/dist/mega-menu/MegaMenu.svelte.d.ts +1 -1
- package/dist/mega-menu/index.d.ts +1 -1
- package/dist/mega-menu/theme.d.ts +2 -0
- package/dist/modal/Modal.svelte +13 -10
- package/dist/modal/Modal.svelte.d.ts +1 -1
- package/dist/modal/index.d.ts +2 -3
- package/dist/modal/index.js +2 -3
- package/dist/modal/theme.d.ts +5 -3
- package/dist/modal/theme.js +1 -1
- package/dist/navbar/Menu.svelte +6 -2
- package/dist/navbar/Menu.svelte.d.ts +1 -1
- package/dist/navbar/NavBrand.svelte +7 -4
- package/dist/navbar/NavBrand.svelte.d.ts +1 -1
- package/dist/navbar/NavContainer.svelte +7 -4
- package/dist/navbar/NavContainer.svelte.d.ts +1 -1
- package/dist/navbar/NavHamburger.svelte +9 -6
- package/dist/navbar/NavHamburger.svelte.d.ts +1 -1
- package/dist/navbar/NavLi.svelte +7 -4
- package/dist/navbar/NavLi.svelte.d.ts +1 -1
- package/dist/navbar/NavUl.svelte +11 -8
- package/dist/navbar/NavUl.svelte.d.ts +1 -1
- package/dist/navbar/Navbar.svelte +6 -4
- package/dist/navbar/Navbar.svelte.d.ts +1 -1
- package/dist/navbar/index.d.ts +7 -7
- package/dist/navbar/index.js +7 -7
- package/dist/navbar/theme.d.ts +12 -5
- package/dist/navbar/theme.js +5 -5
- package/dist/pagination/Pagination.svelte +7 -3
- package/dist/pagination/Pagination.svelte.d.ts +1 -1
- package/dist/pagination/PaginationButton.svelte +18 -12
- package/dist/pagination/PaginationButton.svelte.d.ts +1 -1
- package/dist/pagination/PaginationItem.svelte +7 -4
- package/dist/pagination/PaginationItem.svelte.d.ts +1 -1
- package/dist/pagination/PaginationNav.svelte +13 -11
- package/dist/pagination/PaginationNav.svelte.d.ts +1 -1
- package/dist/pagination/index.d.ts +1 -1
- package/dist/pagination/index.js +1 -1
- package/dist/pagination/theme.d.ts +7 -2
- package/dist/pagination/theme.js +2 -2
- package/dist/popover/Popover.svelte +10 -7
- package/dist/popover/Popover.svelte.d.ts +1 -1
- package/dist/popover/index.d.ts +2 -3
- package/dist/popover/index.js +2 -3
- package/dist/popover/theme.d.ts +2 -3
- package/dist/popover/theme.js +1 -2
- package/dist/progress/Progressbar.svelte +12 -8
- package/dist/progress/Progressbar.svelte.d.ts +1 -1
- package/dist/progress/Progressradial.svelte +13 -9
- package/dist/progress/Progressradial.svelte.d.ts +1 -1
- package/dist/progress/index.d.ts +1 -1
- package/dist/progress/index.js +1 -1
- package/dist/progress/theme.d.ts +4 -0
- package/dist/rating/AdvancedRating.svelte +12 -9
- package/dist/rating/AdvancedRating.svelte.d.ts +1 -1
- package/dist/rating/CustomIcon.svelte +1 -1
- package/dist/rating/CustomIcon.svelte.d.ts +1 -1
- package/dist/rating/Heart.svelte +1 -1
- package/dist/rating/Heart.svelte.d.ts +1 -1
- package/dist/rating/Rating.svelte +8 -4
- package/dist/rating/Rating.svelte.d.ts +1 -1
- package/dist/rating/RatingComment.svelte +1 -1
- package/dist/rating/RatingComment.svelte.d.ts +1 -1
- package/dist/rating/Review.svelte +14 -11
- package/dist/rating/Review.svelte.d.ts +1 -1
- package/dist/rating/ScoreRating.svelte +14 -10
- package/dist/rating/ScoreRating.svelte.d.ts +1 -1
- package/dist/rating/Star.svelte +1 -1
- package/dist/rating/Star.svelte.d.ts +1 -1
- package/dist/rating/Thumbup.svelte +1 -1
- package/dist/rating/Thumbup.svelte.d.ts +1 -1
- package/dist/rating/index.d.ts +10 -11
- package/dist/rating/index.js +10 -11
- package/dist/rating/theme.d.ts +16 -14
- package/dist/rating/theme.js +2 -3
- package/dist/sidebar/Sidebar.svelte +12 -9
- package/dist/sidebar/Sidebar.svelte.d.ts +1 -1
- package/dist/sidebar/SidebarBrand.svelte +10 -7
- package/dist/sidebar/SidebarBrand.svelte.d.ts +1 -1
- package/dist/sidebar/SidebarButton.svelte +8 -4
- package/dist/sidebar/SidebarButton.svelte.d.ts +1 -1
- package/dist/sidebar/SidebarCta.svelte +11 -7
- package/dist/sidebar/SidebarCta.svelte.d.ts +1 -1
- package/dist/sidebar/SidebarDropdownWrapper.svelte +13 -10
- package/dist/sidebar/SidebarDropdownWrapper.svelte.d.ts +1 -1
- package/dist/sidebar/SidebarGroup.svelte +1 -1
- package/dist/sidebar/SidebarGroup.svelte.d.ts +1 -1
- package/dist/sidebar/SidebarItem.svelte +1 -1
- package/dist/sidebar/SidebarItem.svelte.d.ts +1 -1
- package/dist/sidebar/index.d.ts +10 -11
- package/dist/sidebar/index.js +10 -11
- package/dist/sidebar/theme.d.ts +22 -13
- package/dist/sidebar/theme.js +4 -4
- package/dist/skeleton/CardPlaceholder.svelte +17 -14
- package/dist/skeleton/CardPlaceholder.svelte.d.ts +1 -1
- package/dist/skeleton/ImagePlaceholder.svelte +17 -14
- package/dist/skeleton/ImagePlaceholder.svelte.d.ts +1 -1
- package/dist/skeleton/ListPlaceholder.svelte +12 -9
- package/dist/skeleton/ListPlaceholder.svelte.d.ts +1 -1
- package/dist/skeleton/Skeleton.svelte +15 -11
- package/dist/skeleton/Skeleton.svelte.d.ts +1 -1
- package/dist/skeleton/TestimonialPlaceholder.svelte +14 -10
- package/dist/skeleton/TestimonialPlaceholder.svelte.d.ts +1 -1
- package/dist/skeleton/TextPlaceholder.svelte +32 -28
- package/dist/skeleton/TextPlaceholder.svelte.d.ts +1 -1
- package/dist/skeleton/VideoPlaceholder.svelte +7 -3
- package/dist/skeleton/VideoPlaceholder.svelte.d.ts +1 -1
- package/dist/skeleton/WidgetPlaceholder.svelte +8 -4
- package/dist/skeleton/WidgetPlaceholder.svelte.d.ts +1 -1
- package/dist/skeleton/index.d.ts +9 -10
- package/dist/skeleton/index.js +9 -10
- package/dist/skeleton/theme.d.ts +29 -15
- package/dist/skeleton/theme.js +8 -9
- package/dist/speed-dial/SpeedDial.svelte +9 -9
- package/dist/speed-dial/SpeedDial.svelte.d.ts +1 -1
- package/dist/speed-dial/SpeedDialButton.svelte +9 -8
- package/dist/speed-dial/SpeedDialButton.svelte.d.ts +1 -1
- package/dist/speed-dial/SpeedDialTrigger.svelte +1 -1
- package/dist/speed-dial/SpeedDialTrigger.svelte.d.ts +1 -1
- package/dist/speed-dial/index.d.ts +4 -5
- package/dist/speed-dial/index.js +4 -5
- package/dist/speed-dial/theme.d.ts +8 -4
- package/dist/speed-dial/theme.js +2 -2
- package/dist/spinner/Spinner.svelte +6 -3
- package/dist/spinner/Spinner.svelte.d.ts +1 -1
- package/dist/spinner/index.d.ts +2 -3
- package/dist/spinner/index.js +2 -3
- package/dist/spinner/theme.d.ts +1 -0
- package/dist/stepindicator/StepIndicator.svelte +28 -49
- package/dist/stepindicator/StepIndicator.svelte.d.ts +3 -3
- package/dist/stepindicator/index.d.ts +1 -0
- package/dist/stepindicator/index.js +1 -0
- package/dist/stepindicator/theme.d.ts +246 -0
- package/dist/stepindicator/theme.js +103 -0
- package/dist/stepper/BreadcrumbStepper.svelte +15 -11
- package/dist/stepper/BreadcrumbStepper.svelte.d.ts +1 -1
- package/dist/stepper/DetailedStepper.svelte +9 -9
- package/dist/stepper/DetailedStepper.svelte.d.ts +1 -1
- package/dist/stepper/ProgressStepper.svelte +13 -11
- package/dist/stepper/ProgressStepper.svelte.d.ts +1 -1
- package/dist/stepper/Stepper.svelte +15 -13
- package/dist/stepper/Stepper.svelte.d.ts +1 -1
- package/dist/stepper/TimelineStepper.svelte +9 -9
- package/dist/stepper/TimelineStepper.svelte.d.ts +1 -1
- package/dist/stepper/VerticalStepper.svelte +9 -10
- package/dist/stepper/VerticalStepper.svelte.d.ts +1 -1
- package/dist/stepper/index.d.ts +1 -1
- package/dist/stepper/index.js +1 -1
- package/dist/stepper/theme.d.ts +303 -261
- package/dist/stepper/theme.js +198 -186
- package/dist/table/Table.svelte +8 -6
- package/dist/table/Table.svelte.d.ts +2 -2
- package/dist/table/TableBody.svelte +6 -2
- package/dist/table/TableBody.svelte.d.ts +1 -1
- package/dist/table/TableBodyCell.svelte +7 -4
- package/dist/table/TableBodyCell.svelte.d.ts +1 -1
- package/dist/table/TableBodyRow.svelte +8 -5
- package/dist/table/TableBodyRow.svelte.d.ts +1 -1
- package/dist/table/TableHead.svelte +8 -5
- package/dist/table/TableHead.svelte.d.ts +1 -1
- package/dist/table/TableHeadCell.svelte +7 -4
- package/dist/table/TableHeadCell.svelte.d.ts +1 -1
- package/dist/table/TableSearch.svelte +35 -30
- package/dist/table/TableSearch.svelte.d.ts +8 -8
- package/dist/table/index.d.ts +8 -9
- package/dist/table/index.js +8 -9
- package/dist/table/theme.d.ts +192 -4
- package/dist/table/theme.js +68 -4
- package/dist/tabs/TabItem.svelte +8 -5
- package/dist/tabs/TabItem.svelte.d.ts +1 -1
- package/dist/tabs/Tabs.svelte +9 -6
- package/dist/tabs/Tabs.svelte.d.ts +1 -1
- package/dist/tabs/index.d.ts +3 -4
- package/dist/tabs/index.js +3 -4
- package/dist/tabs/theme.d.ts +4 -0
- package/dist/theme/ThemeProvider.svelte +30 -0
- package/dist/theme/ThemeProvider.svelte.d.ts +17 -0
- package/dist/theme/index.d.ts +0 -10296
- package/dist/theme/index.js +2 -119
- package/dist/theme/themeUtils.d.ts +2 -0
- package/dist/theme/themeUtils.js +6 -0
- package/dist/timeline/Activity.svelte +6 -3
- package/dist/timeline/Activity.svelte.d.ts +1 -1
- package/dist/timeline/ActivityItem.svelte +15 -11
- package/dist/timeline/ActivityItem.svelte.d.ts +1 -1
- package/dist/timeline/Group.svelte +11 -5
- package/dist/timeline/Group.svelte.d.ts +1 -1
- package/dist/timeline/GroupItem.svelte +13 -8
- package/dist/timeline/GroupItem.svelte.d.ts +1 -1
- package/dist/timeline/Timeline.svelte +6 -2
- package/dist/timeline/Timeline.svelte.d.ts +1 -1
- package/dist/timeline/TimelineItem.svelte +13 -9
- package/dist/timeline/TimelineItem.svelte.d.ts +1 -1
- package/dist/timeline/index.d.ts +7 -8
- package/dist/timeline/index.js +7 -8
- package/dist/timeline/theme.d.ts +25 -15
- package/dist/timeline/theme.js +3 -3
- package/dist/toast/Toast.svelte +10 -6
- package/dist/toast/Toast.svelte.d.ts +1 -1
- package/dist/toast/index.d.ts +2 -3
- package/dist/toast/index.js +2 -3
- package/dist/toast/theme.d.ts +2 -0
- package/dist/toolbar/Toolbar.svelte +8 -4
- package/dist/toolbar/Toolbar.svelte.d.ts +1 -1
- package/dist/toolbar/ToolbarButton.svelte +6 -2
- package/dist/toolbar/ToolbarButton.svelte.d.ts +1 -1
- package/dist/toolbar/ToolbarGroup.svelte +6 -2
- package/dist/toolbar/ToolbarGroup.svelte.d.ts +1 -1
- package/dist/toolbar/index.d.ts +4 -5
- package/dist/toolbar/index.js +4 -5
- package/dist/toolbar/theme.d.ts +4 -0
- package/dist/tooltip/Tooltip.svelte +7 -3
- package/dist/tooltip/Tooltip.svelte.d.ts +1 -1
- package/dist/tooltip/index.d.ts +2 -3
- package/dist/tooltip/index.js +2 -3
- package/dist/tooltip/theme.d.ts +2 -0
- package/dist/types.d.ts +25 -25
- package/dist/types.js +1 -1
- package/dist/typography/anchor/A.svelte +7 -3
- package/dist/typography/anchor/A.svelte.d.ts +1 -1
- package/dist/typography/anchor/index.d.ts +2 -3
- package/dist/typography/anchor/index.js +2 -3
- package/dist/typography/anchor/theme.d.ts +1 -0
- package/dist/typography/blockquote/Blockquote.svelte +6 -2
- package/dist/typography/blockquote/Blockquote.svelte.d.ts +1 -1
- package/dist/typography/blockquote/theme.d.ts +1 -0
- package/dist/typography/descriptionlist/DescriptionList.svelte +7 -3
- package/dist/typography/descriptionlist/DescriptionList.svelte.d.ts +1 -1
- package/dist/typography/descriptionlist/index.d.ts +2 -3
- package/dist/typography/descriptionlist/index.js +2 -3
- package/dist/typography/descriptionlist/theme.d.ts +1 -0
- package/dist/typography/heading/Heading.svelte +7 -3
- package/dist/typography/heading/Heading.svelte.d.ts +1 -1
- package/dist/typography/heading/index.d.ts +2 -3
- package/dist/typography/heading/index.js +2 -3
- package/dist/typography/heading/theme.d.ts +1 -0
- package/dist/typography/hr/Hr.svelte +10 -6
- package/dist/typography/hr/Hr.svelte.d.ts +1 -1
- package/dist/typography/hr/index.d.ts +2 -3
- package/dist/typography/hr/index.js +2 -3
- package/dist/typography/hr/theme.d.ts +2 -0
- package/dist/typography/img/EnhancedImg.svelte +10 -6
- package/dist/typography/img/EnhancedImg.svelte.d.ts +1 -1
- package/dist/typography/img/Img.svelte +10 -6
- package/dist/typography/img/Img.svelte.d.ts +1 -1
- package/dist/typography/img/index.d.ts +3 -4
- package/dist/typography/img/index.js +3 -4
- package/dist/typography/img/theme.d.ts +2 -0
- package/dist/typography/layout/Layout.svelte +6 -2
- package/dist/typography/layout/Layout.svelte.d.ts +1 -1
- package/dist/typography/layout/index.d.ts +2 -3
- package/dist/typography/layout/index.js +2 -3
- package/dist/typography/layout/theme.d.ts +1 -0
- package/dist/typography/list/Li.svelte +6 -3
- package/dist/typography/list/Li.svelte.d.ts +1 -1
- package/dist/typography/list/List.svelte +6 -2
- package/dist/typography/list/List.svelte.d.ts +1 -1
- package/dist/typography/list/index.d.ts +3 -4
- package/dist/typography/list/index.js +3 -4
- package/dist/typography/list/theme.d.ts +1 -0
- package/dist/typography/mark/Mark.svelte +6 -2
- package/dist/typography/mark/Mark.svelte.d.ts +1 -1
- package/dist/typography/mark/index.d.ts +2 -3
- package/dist/typography/mark/index.js +2 -3
- package/dist/typography/mark/theme.d.ts +1 -0
- package/dist/typography/paragraph/P.svelte +6 -2
- package/dist/typography/paragraph/P.svelte.d.ts +1 -1
- package/dist/typography/paragraph/index.d.ts +2 -3
- package/dist/typography/paragraph/index.js +2 -3
- package/dist/typography/paragraph/theme.d.ts +1 -0
- package/dist/typography/secondary/Secondary.svelte +6 -2
- package/dist/typography/secondary/Secondary.svelte.d.ts +1 -1
- package/dist/typography/secondary/index.d.ts +2 -3
- package/dist/typography/secondary/index.js +2 -3
- package/dist/typography/secondary/theme.d.ts +1 -0
- package/dist/typography/span/Span.svelte +6 -2
- package/dist/typography/span/Span.svelte.d.ts +1 -1
- package/dist/typography/span/index.d.ts +2 -3
- package/dist/typography/span/index.js +2 -3
- package/dist/typography/span/theme.d.ts +1 -0
- package/dist/utils/Arrow.svelte +1 -1
- package/dist/utils/Arrow.svelte.d.ts +1 -1
- package/dist/utils/CloseButton.svelte +1 -1
- package/dist/utils/CloseButton.svelte.d.ts +1 -1
- package/dist/utils/Popper.svelte +1 -1
- package/dist/utils/Popper.svelte.d.ts +1 -1
- package/dist/video/Video.svelte +6 -2
- package/dist/video/Video.svelte.d.ts +1 -1
- package/dist/video/index.d.ts +1 -2
- package/dist/video/index.js +1 -2
- package/package.json +9 -12
- package/dist/chart/Chart.svelte +0 -45
- package/dist/chart/Chart.svelte.d.ts +0 -13
- package/dist/chart/chart.css +0 -166
- package/dist/chart/index.d.ts +0 -1
- package/dist/chart/index.js +0 -1
- package/dist/forms/button-toggle/button-toggle.txt +0 -25
- package/dist/theme/Theme.svelte +0 -60
- package/dist/theme/Theme.svelte.d.ts +0 -12
|
@@ -1,67 +1,94 @@
|
|
|
1
1
|
<script lang="ts">
|
|
2
2
|
import { Dropdown, DropdownItem, Button, Input, ButtonGroup, Select, Label, Toggle, type TimepickerProps, type TimePickerOption, cn } from "../..";
|
|
3
|
-
import {
|
|
3
|
+
import { timepicker, type TimepickerTheme } from ".";
|
|
4
|
+
import { parse, isValid, isBefore, isAfter } from "date-fns";
|
|
5
|
+
import { getTheme } from "../../theme/themeUtils";
|
|
4
6
|
|
|
5
|
-
// Props
|
|
6
7
|
let { id = "time", endId = "end-time", value = $bindable("00:00"), endValue = $bindable("00:00"), min = "", max = "", required = true, disabled = false, inputColor, buttonColor = "primary", Icon, iconClass = "h-5 w-5 text-gray-500 dark:text-gray-400", type = "default", optionLabel = "Options", options = [], size = "md", divClass, inputClass, selectClass, timerangeLabel = "Choose time range", timerangeButtonLabel = "Save time", timeIntervals = [], columns = 2, onselect }: TimepickerProps = $props();
|
|
7
8
|
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
const
|
|
12
|
-
const defaultSelectClass = "text-gray-900 disabled:text-gray-400 bg-gray-50 border border-gray-300 rounded-r-lg rounded-l-none focus:ring-0 focus:outline-none block w-full border-l-1 focus:ring-primary-500 focus:border-primary-500 dark:bg-gray-700 dark:border-gray-600 dark:placeholder-gray-400 dark:text-white dark:disabled:text-gray-500 dark:focus:ring-primary-500 dark:focus:border-primary-500";
|
|
13
|
-
const selectCls = cn(defaultSelectClass, selectClass);
|
|
9
|
+
const theme = getTheme("timepicker");
|
|
10
|
+
|
|
11
|
+
// Generate theme classes
|
|
12
|
+
const styles = timepicker({ type, columns, disabled });
|
|
14
13
|
|
|
15
14
|
// State
|
|
16
|
-
// let value = $state("00:00");
|
|
17
|
-
// let endValue = $state("00:00");
|
|
18
15
|
let selectedOption = $state("");
|
|
19
16
|
let dropdownOpen = $state(false);
|
|
20
17
|
let showTimerange = $state(false);
|
|
21
18
|
|
|
19
|
+
// Helper functions using date-fns
|
|
20
|
+
function parseTime(time: string): Date | null {
|
|
21
|
+
if (!time) return null;
|
|
22
|
+
const parsed = parse(time, "HH:mm", new Date());
|
|
23
|
+
return isValid(parsed) ? parsed : null;
|
|
24
|
+
}
|
|
25
|
+
|
|
22
26
|
function timeToMinutes(time: string): number {
|
|
23
|
-
const
|
|
24
|
-
return
|
|
27
|
+
const date = parseTime(time);
|
|
28
|
+
return date ? date.getHours() * 60 + date.getMinutes() : 0;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function isValidTimeFormat(time: string): boolean {
|
|
32
|
+
return parseTime(time) !== null;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
function isTimeInRange(time: string, minTime: string, maxTime: string): boolean {
|
|
36
|
+
const timeDate = parseTime(time);
|
|
37
|
+
if (!timeDate) return false;
|
|
38
|
+
|
|
39
|
+
if (minTime) {
|
|
40
|
+
const minDate = parseTime(minTime);
|
|
41
|
+
if (minDate && isBefore(timeDate, minDate)) return false;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
if (maxTime) {
|
|
45
|
+
const maxDate = parseTime(maxTime);
|
|
46
|
+
if (maxDate && isAfter(timeDate, maxDate)) return false;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return true;
|
|
25
50
|
}
|
|
26
51
|
|
|
27
52
|
function handleTimeChange(event: Event, isEndTime: boolean = false): void {
|
|
28
53
|
const target = event.target as HTMLInputElement;
|
|
29
54
|
const newValue = target.value;
|
|
30
55
|
|
|
31
|
-
// Validate
|
|
32
|
-
if (
|
|
33
|
-
target.value = isEndTime ? endValue : value;
|
|
56
|
+
// Validate time format
|
|
57
|
+
if (!isValidTimeFormat(newValue)) {
|
|
58
|
+
target.value = isEndTime ? endValue : value;
|
|
34
59
|
return;
|
|
35
60
|
}
|
|
36
61
|
|
|
37
|
-
|
|
38
|
-
|
|
62
|
+
// Validate against min/max constraints
|
|
63
|
+
if (!isTimeInRange(newValue, min, max)) {
|
|
64
|
+
target.value = isEndTime ? endValue : value;
|
|
39
65
|
return;
|
|
40
66
|
}
|
|
41
67
|
|
|
42
|
-
|
|
68
|
+
// Use date-fns for reliable time comparison
|
|
69
|
+
const newValueMinutes = timeToMinutes(newValue);
|
|
43
70
|
const valueMinutes = timeToMinutes(value);
|
|
44
71
|
const endValueMinutes = timeToMinutes(endValue);
|
|
45
72
|
|
|
46
73
|
if (isEndTime) {
|
|
47
|
-
if (
|
|
74
|
+
if (newValueMinutes < valueMinutes) {
|
|
48
75
|
// Only update start time if it respects min/max constraints
|
|
49
|
-
if ((
|
|
76
|
+
if (isTimeInRange(newValue, min, max)) {
|
|
50
77
|
value = newValue;
|
|
51
78
|
} else {
|
|
52
|
-
target.value = endValue;
|
|
79
|
+
target.value = endValue;
|
|
53
80
|
return;
|
|
54
81
|
}
|
|
55
82
|
} else {
|
|
56
83
|
endValue = newValue;
|
|
57
84
|
}
|
|
58
85
|
} else {
|
|
59
|
-
if (
|
|
86
|
+
if (newValueMinutes > endValueMinutes) {
|
|
60
87
|
// Only update end time if it respects min/max constraints
|
|
61
|
-
if ((
|
|
88
|
+
if (isTimeInRange(newValue, min, max)) {
|
|
62
89
|
endValue = newValue;
|
|
63
90
|
} else {
|
|
64
|
-
target.value = value;
|
|
91
|
+
target.value = value;
|
|
65
92
|
return;
|
|
66
93
|
}
|
|
67
94
|
} else {
|
|
@@ -109,32 +136,46 @@
|
|
|
109
136
|
}
|
|
110
137
|
|
|
111
138
|
function handleInlineButtonSelect(time: string): void {
|
|
112
|
-
|
|
113
|
-
|
|
139
|
+
if (isValidTimeFormat(time) && isTimeInRange(time, min, max)) {
|
|
140
|
+
value = time;
|
|
141
|
+
notifyChange();
|
|
142
|
+
}
|
|
114
143
|
}
|
|
144
|
+
|
|
145
|
+
// Ensure initial values are valid
|
|
146
|
+
$effect(() => {
|
|
147
|
+
if (!isValidTimeFormat(value)) {
|
|
148
|
+
value = "00:00";
|
|
149
|
+
}
|
|
150
|
+
if (!isValidTimeFormat(endValue)) {
|
|
151
|
+
endValue = "00:00";
|
|
152
|
+
}
|
|
153
|
+
});
|
|
115
154
|
</script>
|
|
116
155
|
|
|
117
156
|
{#if type !== "inline-buttons"}
|
|
118
|
-
<ButtonGroup {size} class={
|
|
157
|
+
<ButtonGroup {size} class={cn(styles.buttonGroup(), divClass, (theme as TimepickerTheme)?.buttonGroup)}>
|
|
119
158
|
{#if type === "default"}
|
|
120
|
-
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(
|
|
121
|
-
<div class=
|
|
159
|
+
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.input(), styles.inputWithIcon(), inputClass, (theme as TimepickerTheme)?.input)} bind:value oninput={(e) => handleTimeChange(e)} onchange={(e) => handleTimeChange(e)} />
|
|
160
|
+
<div class={cn(styles.iconWrapper(), (theme as TimepickerTheme)?.iconWrapper)}>
|
|
122
161
|
{#if Icon}
|
|
123
162
|
<Icon class={iconClass} />
|
|
124
163
|
{:else}
|
|
125
|
-
<svg class=
|
|
164
|
+
<svg class={styles.icon()} aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 20 20">
|
|
126
165
|
<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 6v4l3.276 3.276M19 10a9 9 0 1 1-18 0 9 9 0 0 1 18 0Z" />
|
|
127
166
|
</svg>
|
|
128
167
|
{/if}
|
|
129
168
|
</div>
|
|
130
169
|
{:else if type === "select"}
|
|
131
|
-
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={
|
|
132
|
-
<Select selectClass={
|
|
170
|
+
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.input(), inputClass, (theme as TimepickerTheme)?.input)} bind:value oninput={(e) => handleTimeChange(e)} onchange={(e) => handleTimeChange(e)} />
|
|
171
|
+
<Select selectClass={cn(styles.select(), selectClass, (theme as TimepickerTheme)?.select)} onchange={handleOptionSelect} items={options} value={selectedOption} />
|
|
133
172
|
{:else if type === "dropdown"}
|
|
134
|
-
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={
|
|
135
|
-
<Button color={buttonColor} class=
|
|
173
|
+
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.input(), inputClass, (theme as TimepickerTheme)?.input)} bind:value oninput={(e) => handleTimeChange(e)} onchange={(e) => handleTimeChange(e)} />
|
|
174
|
+
<Button color={buttonColor} class={cn(styles.button(), (theme as TimepickerTheme)?.button)}>
|
|
136
175
|
{optionLabel}
|
|
137
|
-
<svg class=
|
|
176
|
+
<svg class={cn(styles.buttonIcon(), (theme as TimepickerTheme)?.buttonIcon)} aria-hidden="true" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
|
177
|
+
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 9l-7 7-7-7"></path>
|
|
178
|
+
</svg>
|
|
138
179
|
</Button>
|
|
139
180
|
<Dropdown simple>
|
|
140
181
|
{#each options as option}
|
|
@@ -144,67 +185,69 @@
|
|
|
144
185
|
{/each}
|
|
145
186
|
</Dropdown>
|
|
146
187
|
{:else if type === "range"}
|
|
147
|
-
<div class=
|
|
148
|
-
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={
|
|
149
|
-
<button type="button" class=
|
|
188
|
+
<div class={cn(styles.rangeInputWrapper(), (theme as TimepickerTheme)?.rangeInputWrapper)}>
|
|
189
|
+
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.input(), styles.rangeInput(), inputClass, (theme as TimepickerTheme)?.rangeInput)} bind:value oninput={(e) => handleTimeChange(e)} onchange={(e) => handleTimeChange(e)} />
|
|
190
|
+
<button type="button" class={cn(styles.rangeButton(), (theme as TimepickerTheme)?.rangeButton)} onclick={() => document.getElementById(id)?.click()} aria-label="Open time picker">
|
|
150
191
|
{#if Icon}
|
|
151
192
|
<Icon class={iconClass} />
|
|
152
193
|
{:else}
|
|
153
|
-
<svg class=
|
|
194
|
+
<svg class={cn(styles.icon(), (theme as TimepickerTheme)?.icon)} aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 20 20">
|
|
154
195
|
<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 6v4l3.276 3.276M19 10a9 9 0 1 1-18 0 9 9 0 0 1 18 0Z" />
|
|
155
196
|
</svg>
|
|
156
197
|
{/if}
|
|
157
198
|
</button>
|
|
158
199
|
</div>
|
|
159
|
-
<span class=
|
|
160
|
-
<div class=
|
|
161
|
-
<Input id={endId} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(
|
|
162
|
-
<button type="button" class=
|
|
200
|
+
<span class={cn(styles.rangeSeparator(), (theme as TimepickerTheme)?.rangeSeparator)}>-</span>
|
|
201
|
+
<div class={cn(styles.rangeInputWrapper(), (theme as TimepickerTheme)?.rangeInputWrapper)}>
|
|
202
|
+
<Input id={endId} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.input(), styles.rangeInput(), inputClass, (theme as TimepickerTheme)?.rangeInput)} bind:value={endValue} oninput={(e) => handleTimeChange(e, true)} onchange={(e) => handleTimeChange(e, true)} />
|
|
203
|
+
<button type="button" class={cn(styles.rangeButton(), (theme as TimepickerTheme)?.rangeButton)} onclick={() => document.getElementById(endId)?.click()} aria-label="Open end time picker">
|
|
163
204
|
{#if Icon}
|
|
164
205
|
<Icon class={iconClass} />
|
|
165
206
|
{:else}
|
|
166
|
-
<svg class=
|
|
207
|
+
<svg class={cn(styles.icon(), (theme as TimepickerTheme)?.icon)} aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 20 20">
|
|
167
208
|
<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 6v4l3.276 3.276M19 10a9 9 0 1 1-18 0 9 9 0 0 1 18 0Z" />
|
|
168
209
|
</svg>
|
|
169
210
|
{/if}
|
|
170
211
|
</button>
|
|
171
212
|
</div>
|
|
172
213
|
{:else if type === "timerange-dropdown"}
|
|
173
|
-
<Button color={buttonColor} {size} class=
|
|
214
|
+
<Button color={buttonColor} {size} class={cn(styles.button(), (theme as TimepickerTheme)?.button)}>
|
|
174
215
|
{timerangeLabel}
|
|
175
|
-
<svg class=
|
|
216
|
+
<svg class={cn(styles.buttonIcon(), (theme as TimepickerTheme)?.buttonIcon)} aria-hidden="true" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
|
217
|
+
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 9l-7 7-7-7"></path>
|
|
218
|
+
</svg>
|
|
176
219
|
</Button>
|
|
177
|
-
<Dropdown simple class=
|
|
178
|
-
<div class=
|
|
179
|
-
<div class=
|
|
180
|
-
<div class=
|
|
220
|
+
<Dropdown simple class={cn(styles.dropdownContent(), (theme as TimepickerTheme)?.dropdownContent)}>
|
|
221
|
+
<div class={cn(styles.dropdownInner(), (theme as TimepickerTheme)?.dropdownInner)}>
|
|
222
|
+
<div class={cn(styles.dropdownTimeRow(), (theme as TimepickerTheme)?.dropdownTimeRow)}>
|
|
223
|
+
<div class={cn(styles.dropdownTimeCol(), (theme as TimepickerTheme)?.dropdownTimeCol)}>
|
|
181
224
|
<Label for={id}>Start time:</Label>
|
|
182
|
-
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(
|
|
225
|
+
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.dropdownTimeInput(), inputClass, (theme as TimepickerTheme)?.dropdownTimeInput)} bind:value oninput={(e) => handleTimeChange(e)} onchange={(e) => handleTimeChange(e)} />
|
|
183
226
|
</div>
|
|
184
|
-
<div class=
|
|
227
|
+
<div class={cn(styles.dropdownTimeCol(), (theme as TimepickerTheme)?.dropdownTimeCol)}>
|
|
185
228
|
<Label for={endId}>End time:</Label>
|
|
186
|
-
<Input id={endId} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(
|
|
229
|
+
<Input id={endId} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.dropdownTimeInput(), inputClass, (theme as TimepickerTheme)?.dropdownTimeInput)} bind:value={endValue} oninput={(e) => handleTimeChange(e, true)} onchange={(e) => handleTimeChange(e, true)} />
|
|
187
230
|
</div>
|
|
188
231
|
</div>
|
|
189
|
-
<Button color={buttonColor} class=
|
|
232
|
+
<Button color={buttonColor} class={cn(styles.dropdownButton(), (theme as TimepickerTheme)?.dropdownButton)} onclick={applyTimerange}>
|
|
190
233
|
{timerangeButtonLabel}
|
|
191
234
|
</Button>
|
|
192
235
|
</div>
|
|
193
236
|
</Dropdown>
|
|
194
237
|
{:else if type === "timerange-toggle"}
|
|
195
|
-
<div class=
|
|
196
|
-
<div class=
|
|
238
|
+
<div class={cn(styles.toggleWrapper(), (theme as TimepickerTheme)?.toggleWrapper)}>
|
|
239
|
+
<div class={cn(styles.toggleRow(), (theme as TimepickerTheme)?.toggleRow)}>
|
|
197
240
|
<Toggle id={`${id}-timerange-toggle`} checked={showTimerange} onchange={toggleTimerange} spanClass="me-0 rounded-lg" />
|
|
198
241
|
</div>
|
|
199
242
|
{#if showTimerange}
|
|
200
|
-
<div class=
|
|
201
|
-
<div class=
|
|
243
|
+
<div class={cn(styles.toggleTimeRow(), (theme as TimepickerTheme)?.toggleTimeRow)}>
|
|
244
|
+
<div class={cn(styles.toggleTimeCol(), (theme as TimepickerTheme)?.toggleTimeCol)}>
|
|
202
245
|
<Label for={id}>Start time:</Label>
|
|
203
|
-
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(
|
|
246
|
+
<Input {id} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.toggleTimeInput(), inputClass, (theme as TimepickerTheme)?.toggleTimeInput)} bind:value oninput={(e) => handleTimeChange(e)} onchange={(e) => handleTimeChange(e)} />
|
|
204
247
|
</div>
|
|
205
|
-
<div class=
|
|
248
|
+
<div class={cn(styles.toggleTimeCol(), (theme as TimepickerTheme)?.toggleTimeCol)}>
|
|
206
249
|
<Label for={endId}>End time:</Label>
|
|
207
|
-
<Input id={endId} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(
|
|
250
|
+
<Input id={endId} color={inputColor} type="time" {min} {max} {required} {disabled} class={cn(styles.toggleTimeInput(), inputClass, (theme as TimepickerTheme)?.toggleTimeInput)} bind:value={endValue} oninput={(e) => handleTimeChange(e, true)} onchange={(e) => handleTimeChange(e, true)} />
|
|
208
251
|
</div>
|
|
209
252
|
</div>
|
|
210
253
|
{/if}
|
|
@@ -212,9 +255,9 @@
|
|
|
212
255
|
{/if}
|
|
213
256
|
</ButtonGroup>
|
|
214
257
|
{:else}
|
|
215
|
-
<div class=
|
|
258
|
+
<div class={cn(styles.inlineGrid(), (theme as TimepickerTheme)?.inlineGrid)}>
|
|
216
259
|
{#each timeIntervals as time}
|
|
217
|
-
<Button {size} color={value === time ? buttonColor : "light"} class=
|
|
260
|
+
<Button {size} color={value === time ? buttonColor : "light"} class={cn(styles.inlineButton(), (theme as TimepickerTheme)?.inlineButton)} onclick={() => handleInlineButtonSelect(time)}>
|
|
218
261
|
{time}
|
|
219
262
|
</Button>
|
|
220
263
|
{/each}
|
|
@@ -225,7 +268,7 @@
|
|
|
225
268
|
@component
|
|
226
269
|
[Go to docs](https://flowbite-svelte.com/)
|
|
227
270
|
## Type
|
|
228
|
-
[TimepickerProps](https://github.com/themesberg/flowbite-svelte/blob/main/src/lib/types.ts#
|
|
271
|
+
[TimepickerProps](https://github.com/themesberg/flowbite-svelte/blob/main/src/lib/types.ts#L917)
|
|
229
272
|
## Props
|
|
230
273
|
@prop id = "time"
|
|
231
274
|
@prop endId = "end-time"
|
|
@@ -2,7 +2,7 @@ import { type TimepickerProps } from "../..";
|
|
|
2
2
|
/**
|
|
3
3
|
* [Go to docs](https://flowbite-svelte.com/)
|
|
4
4
|
* ## Type
|
|
5
|
-
* [TimepickerProps](https://github.com/themesberg/flowbite-svelte/blob/main/src/lib/types.ts#
|
|
5
|
+
* [TimepickerProps](https://github.com/themesberg/flowbite-svelte/blob/main/src/lib/types.ts#L917)
|
|
6
6
|
* ## Props
|
|
7
7
|
* @prop id = "time"
|
|
8
8
|
* @prop endId = "end-time"
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { type VariantProps } from "tailwind-variants";
|
|
2
|
+
export type TimepickerVariants = VariantProps<typeof timepicker>;
|
|
3
|
+
export declare const timepicker: import("tailwind-variants").TVReturnType<{
|
|
4
|
+
type: {
|
|
5
|
+
default: {
|
|
6
|
+
input: string;
|
|
7
|
+
};
|
|
8
|
+
select: {
|
|
9
|
+
input: string;
|
|
10
|
+
select: string;
|
|
11
|
+
};
|
|
12
|
+
dropdown: {
|
|
13
|
+
input: string;
|
|
14
|
+
};
|
|
15
|
+
range: {};
|
|
16
|
+
"timerange-dropdown": {};
|
|
17
|
+
"timerange-toggle": {};
|
|
18
|
+
"inline-buttons": {};
|
|
19
|
+
};
|
|
20
|
+
columns: {
|
|
21
|
+
1: {
|
|
22
|
+
inlineGrid: string;
|
|
23
|
+
};
|
|
24
|
+
2: {
|
|
25
|
+
inlineGrid: string;
|
|
26
|
+
};
|
|
27
|
+
3: {
|
|
28
|
+
inlineGrid: string;
|
|
29
|
+
};
|
|
30
|
+
4: {
|
|
31
|
+
inlineGrid: string;
|
|
32
|
+
};
|
|
33
|
+
};
|
|
34
|
+
disabled: {
|
|
35
|
+
true: {
|
|
36
|
+
input: string;
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
}, {
|
|
40
|
+
buttonGroup: string;
|
|
41
|
+
input: string;
|
|
42
|
+
inputWithIcon: string;
|
|
43
|
+
iconWrapper: string;
|
|
44
|
+
icon: string;
|
|
45
|
+
select: string;
|
|
46
|
+
button: string;
|
|
47
|
+
buttonIcon: string;
|
|
48
|
+
rangeSeparator: string;
|
|
49
|
+
rangeInputWrapper: string;
|
|
50
|
+
rangeInput: string;
|
|
51
|
+
rangeButton: string;
|
|
52
|
+
dropdownContent: string;
|
|
53
|
+
dropdownInner: string;
|
|
54
|
+
dropdownTimeRow: string;
|
|
55
|
+
dropdownTimeCol: string;
|
|
56
|
+
dropdownTimeInput: string;
|
|
57
|
+
dropdownButton: string;
|
|
58
|
+
toggleWrapper: string;
|
|
59
|
+
toggleRow: string;
|
|
60
|
+
toggleTimeRow: string;
|
|
61
|
+
toggleTimeCol: string;
|
|
62
|
+
toggleTimeInput: string;
|
|
63
|
+
inlineGrid: string;
|
|
64
|
+
inlineButton: string;
|
|
65
|
+
}, undefined, {
|
|
66
|
+
type: {
|
|
67
|
+
default: {
|
|
68
|
+
input: string;
|
|
69
|
+
};
|
|
70
|
+
select: {
|
|
71
|
+
input: string;
|
|
72
|
+
select: string;
|
|
73
|
+
};
|
|
74
|
+
dropdown: {
|
|
75
|
+
input: string;
|
|
76
|
+
};
|
|
77
|
+
range: {};
|
|
78
|
+
"timerange-dropdown": {};
|
|
79
|
+
"timerange-toggle": {};
|
|
80
|
+
"inline-buttons": {};
|
|
81
|
+
};
|
|
82
|
+
columns: {
|
|
83
|
+
1: {
|
|
84
|
+
inlineGrid: string;
|
|
85
|
+
};
|
|
86
|
+
2: {
|
|
87
|
+
inlineGrid: string;
|
|
88
|
+
};
|
|
89
|
+
3: {
|
|
90
|
+
inlineGrid: string;
|
|
91
|
+
};
|
|
92
|
+
4: {
|
|
93
|
+
inlineGrid: string;
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
disabled: {
|
|
97
|
+
true: {
|
|
98
|
+
input: string;
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
}, {
|
|
102
|
+
buttonGroup: string;
|
|
103
|
+
input: string;
|
|
104
|
+
inputWithIcon: string;
|
|
105
|
+
iconWrapper: string;
|
|
106
|
+
icon: string;
|
|
107
|
+
select: string;
|
|
108
|
+
button: string;
|
|
109
|
+
buttonIcon: string;
|
|
110
|
+
rangeSeparator: string;
|
|
111
|
+
rangeInputWrapper: string;
|
|
112
|
+
rangeInput: string;
|
|
113
|
+
rangeButton: string;
|
|
114
|
+
dropdownContent: string;
|
|
115
|
+
dropdownInner: string;
|
|
116
|
+
dropdownTimeRow: string;
|
|
117
|
+
dropdownTimeCol: string;
|
|
118
|
+
dropdownTimeInput: string;
|
|
119
|
+
dropdownButton: string;
|
|
120
|
+
toggleWrapper: string;
|
|
121
|
+
toggleRow: string;
|
|
122
|
+
toggleTimeRow: string;
|
|
123
|
+
toggleTimeCol: string;
|
|
124
|
+
toggleTimeInput: string;
|
|
125
|
+
inlineGrid: string;
|
|
126
|
+
inlineButton: string;
|
|
127
|
+
}, import("tailwind-variants").TVReturnType<{
|
|
128
|
+
type: {
|
|
129
|
+
default: {
|
|
130
|
+
input: string;
|
|
131
|
+
};
|
|
132
|
+
select: {
|
|
133
|
+
input: string;
|
|
134
|
+
select: string;
|
|
135
|
+
};
|
|
136
|
+
dropdown: {
|
|
137
|
+
input: string;
|
|
138
|
+
};
|
|
139
|
+
range: {};
|
|
140
|
+
"timerange-dropdown": {};
|
|
141
|
+
"timerange-toggle": {};
|
|
142
|
+
"inline-buttons": {};
|
|
143
|
+
};
|
|
144
|
+
columns: {
|
|
145
|
+
1: {
|
|
146
|
+
inlineGrid: string;
|
|
147
|
+
};
|
|
148
|
+
2: {
|
|
149
|
+
inlineGrid: string;
|
|
150
|
+
};
|
|
151
|
+
3: {
|
|
152
|
+
inlineGrid: string;
|
|
153
|
+
};
|
|
154
|
+
4: {
|
|
155
|
+
inlineGrid: string;
|
|
156
|
+
};
|
|
157
|
+
};
|
|
158
|
+
disabled: {
|
|
159
|
+
true: {
|
|
160
|
+
input: string;
|
|
161
|
+
};
|
|
162
|
+
};
|
|
163
|
+
}, {
|
|
164
|
+
buttonGroup: string;
|
|
165
|
+
input: string;
|
|
166
|
+
inputWithIcon: string;
|
|
167
|
+
iconWrapper: string;
|
|
168
|
+
icon: string;
|
|
169
|
+
select: string;
|
|
170
|
+
button: string;
|
|
171
|
+
buttonIcon: string;
|
|
172
|
+
rangeSeparator: string;
|
|
173
|
+
rangeInputWrapper: string;
|
|
174
|
+
rangeInput: string;
|
|
175
|
+
rangeButton: string;
|
|
176
|
+
dropdownContent: string;
|
|
177
|
+
dropdownInner: string;
|
|
178
|
+
dropdownTimeRow: string;
|
|
179
|
+
dropdownTimeCol: string;
|
|
180
|
+
dropdownTimeInput: string;
|
|
181
|
+
dropdownButton: string;
|
|
182
|
+
toggleWrapper: string;
|
|
183
|
+
toggleRow: string;
|
|
184
|
+
toggleTimeRow: string;
|
|
185
|
+
toggleTimeCol: string;
|
|
186
|
+
toggleTimeInput: string;
|
|
187
|
+
inlineGrid: string;
|
|
188
|
+
inlineButton: string;
|
|
189
|
+
}, undefined, unknown, unknown, undefined>>;
|
|
190
|
+
export type TimepickerSlots = keyof typeof timepicker.slots;
|
|
191
|
+
export type TimepickerTheme = Partial<Record<TimepickerSlots, string>>;
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { tv } from "tailwind-variants";
|
|
2
|
+
export const timepicker = tv({
|
|
3
|
+
slots: {
|
|
4
|
+
buttonGroup: "inline-flex rounded-lg shadow-sm",
|
|
5
|
+
input: "block disabled:cursor-not-allowed disabled:opacity-50 rtl:text-right focus:ring-0 focus:outline-none",
|
|
6
|
+
inputWithIcon: "relative px-2 pr-8",
|
|
7
|
+
iconWrapper: "pointer-events-none absolute inset-y-0 end-0 top-0 flex items-center pe-3.5",
|
|
8
|
+
icon: "h-4 w-4 text-gray-500 dark:text-gray-400",
|
|
9
|
+
select: "text-gray-900 disabled:text-gray-400 bg-gray-50 border border-gray-300 focus:ring-0 focus:outline-none block w-full border-l-1 focus:ring-primary-500 focus:border-primary-500 dark:bg-gray-700 dark:border-gray-600 dark:placeholder-gray-400 dark:text-white dark:disabled:text-gray-500 dark:focus:ring-primary-500 dark:focus:border-primary-500",
|
|
10
|
+
button: "!rounded-r-lg",
|
|
11
|
+
buttonIcon: "ml-2 h-4 w-4",
|
|
12
|
+
rangeSeparator: "flex items-center justify-center px-2 text-gray-500 dark:text-gray-400",
|
|
13
|
+
rangeInputWrapper: "relative",
|
|
14
|
+
rangeInput: "relative pr-8",
|
|
15
|
+
rangeButton: "pointer-events-none absolute inset-y-0 top-0 right-0 flex items-center border-0 bg-transparent pe-3.5",
|
|
16
|
+
dropdownContent: "p-4 last:rounded-r-lg",
|
|
17
|
+
dropdownInner: "flex flex-col space-y-4",
|
|
18
|
+
dropdownTimeRow: "flex space-x-4",
|
|
19
|
+
dropdownTimeCol: "flex flex-col",
|
|
20
|
+
dropdownTimeInput: "w-24 rounded-l-lg !border-r px-2",
|
|
21
|
+
dropdownButton: "w-full !rounded-l-lg",
|
|
22
|
+
toggleWrapper: "flex w-full flex-col space-y-2",
|
|
23
|
+
toggleRow: "flex items-center justify-between",
|
|
24
|
+
toggleTimeRow: "flex space-x-4 p-2.5",
|
|
25
|
+
toggleTimeCol: "flex flex-col",
|
|
26
|
+
toggleTimeInput: "w-24 rounded-lg !border-r px-2",
|
|
27
|
+
inlineGrid: "grid w-full gap-2",
|
|
28
|
+
inlineButton: "rounded-lg"
|
|
29
|
+
},
|
|
30
|
+
variants: {
|
|
31
|
+
type: {
|
|
32
|
+
default: {
|
|
33
|
+
input: "rounded-e-lg"
|
|
34
|
+
},
|
|
35
|
+
select: {
|
|
36
|
+
input: "w-1/3 rounded-l-lg rounded-e-none",
|
|
37
|
+
select: "rounded-r-lg rounded-l-none"
|
|
38
|
+
},
|
|
39
|
+
dropdown: {
|
|
40
|
+
input: "rounded-l-lg rounded-e-none"
|
|
41
|
+
},
|
|
42
|
+
range: {},
|
|
43
|
+
"timerange-dropdown": {},
|
|
44
|
+
"timerange-toggle": {},
|
|
45
|
+
"inline-buttons": {}
|
|
46
|
+
},
|
|
47
|
+
columns: {
|
|
48
|
+
1: {
|
|
49
|
+
inlineGrid: "grid-cols-1"
|
|
50
|
+
},
|
|
51
|
+
2: {
|
|
52
|
+
inlineGrid: "grid-cols-2"
|
|
53
|
+
},
|
|
54
|
+
3: {
|
|
55
|
+
inlineGrid: "grid-cols-3"
|
|
56
|
+
},
|
|
57
|
+
4: {
|
|
58
|
+
inlineGrid: "grid-cols-4"
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
disabled: {
|
|
62
|
+
true: {
|
|
63
|
+
input: "disabled:cursor-not-allowed disabled:opacity-50"
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
defaultVariants: {
|
|
68
|
+
type: "default",
|
|
69
|
+
columns: 2,
|
|
70
|
+
disabled: false
|
|
71
|
+
}
|
|
72
|
+
});
|
|
@@ -1,18 +1,21 @@
|
|
|
1
1
|
<script lang="ts">
|
|
2
|
-
import { toggle } from "./index";
|
|
2
|
+
import { toggle, type ToggleTheme } from "./index";
|
|
3
3
|
import { type ToggleProps, Label, cn } from "../..";
|
|
4
|
+
import { getTheme } from "../../theme/themeUtils";
|
|
4
5
|
|
|
5
6
|
let { children, size = "default", value, checked = $bindable(), disabled, color = "primary", class: className, inputClass, spanClass, offLabel, ...restProps }: ToggleProps = $props();
|
|
6
7
|
|
|
8
|
+
const theme = getTheme("toggle");
|
|
9
|
+
|
|
7
10
|
const { input, label, span } = $derived(toggle({ color, checked, size, disabled, off_state_label: !!offLabel }));
|
|
8
11
|
</script>
|
|
9
12
|
|
|
10
|
-
<Label class={cn(label(), className)}>
|
|
13
|
+
<Label class={cn(label(), className, (theme as ToggleTheme)?.label)}>
|
|
11
14
|
{#if offLabel}
|
|
12
15
|
{@render offLabel()}
|
|
13
16
|
{/if}
|
|
14
|
-
<input type="checkbox" bind:checked {value} {...restProps} {disabled} class={cn(input(), inputClass)} />
|
|
15
|
-
<span class={cn(span(), spanClass)}></span>
|
|
17
|
+
<input type="checkbox" bind:checked {value} {...restProps} {disabled} class={cn(input(), inputClass, (theme as ToggleTheme)?.input)} />
|
|
18
|
+
<span class={cn(span(), spanClass, (theme as ToggleTheme)?.span)}></span>
|
|
16
19
|
{#if children}
|
|
17
20
|
{@render children()}
|
|
18
21
|
{/if}
|
|
@@ -22,7 +25,7 @@
|
|
|
22
25
|
@component
|
|
23
26
|
[Go to docs](https://flowbite-svelte.com/)
|
|
24
27
|
## Type
|
|
25
|
-
[ToggleProps](https://github.com/themesberg/flowbite-svelte/blob/main/src/lib/types.ts#
|
|
28
|
+
[ToggleProps](https://github.com/themesberg/flowbite-svelte/blob/main/src/lib/types.ts#L968)
|
|
26
29
|
## Props
|
|
27
30
|
@prop children
|
|
28
31
|
@prop size = "default"
|
|
@@ -2,7 +2,7 @@ import { type ToggleProps } from "../..";
|
|
|
2
2
|
/**
|
|
3
3
|
* [Go to docs](https://flowbite-svelte.com/)
|
|
4
4
|
* ## Type
|
|
5
|
-
* [ToggleProps](https://github.com/themesberg/flowbite-svelte/blob/main/src/lib/types.ts#
|
|
5
|
+
* [ToggleProps](https://github.com/themesberg/flowbite-svelte/blob/main/src/lib/types.ts#L968)
|
|
6
6
|
* ## Props
|
|
7
7
|
* @prop children
|
|
8
8
|
* @prop size = "default"
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export { default as Toggle } from "./Toggle.svelte";
|
|
2
|
-
export { toggle } from "./theme";
|
|
2
|
+
export { toggle, type ToggleTheme } from "./theme";
|
|
@@ -277,3 +277,5 @@ export declare const toggle: import("tailwind-variants").TVReturnType<{
|
|
|
277
277
|
label: string;
|
|
278
278
|
input: string;
|
|
279
279
|
}, undefined, unknown, unknown, undefined>>;
|
|
280
|
+
export type ToggleSlots = keyof typeof toggle.slots;
|
|
281
|
+
export type ToggleTheme = Partial<Record<ToggleSlots, string>>;
|