flowbite-svelte 0.47.1 → 0.47.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/dist/accordion/Accordion.svelte +6 -2
  2. package/dist/accordion/Accordion.svelte.d.ts +2 -0
  3. package/dist/banner/Banner.svelte +6 -2
  4. package/dist/banner/Banner.svelte.d.ts +6 -1
  5. package/dist/bottom-navigation/BottomNav.svelte +9 -3
  6. package/dist/bottom-navigation/BottomNav.svelte.d.ts +6 -0
  7. package/dist/bottom-navigation/BottomNavHeader.svelte +6 -2
  8. package/dist/bottom-navigation/BottomNavHeader.svelte.d.ts +4 -0
  9. package/dist/breadcrumb/Breadcrumb.svelte +3 -1
  10. package/dist/breadcrumb/Breadcrumb.svelte.d.ts +2 -0
  11. package/dist/breadcrumb/BreadcrumbItem.svelte +9 -3
  12. package/dist/breadcrumb/BreadcrumbItem.svelte.d.ts +6 -0
  13. package/dist/buttons/Button.svelte +4 -0
  14. package/dist/buttons/Button.svelte.d.ts +2 -2
  15. package/dist/carousel/Carousel.svelte.d.ts +2 -1
  16. package/dist/carousel/Slide.svelte.d.ts +2 -1
  17. package/dist/carousel/Thumbnails.svelte +0 -1
  18. package/dist/datepicker/Datepicker.svelte +11 -7
  19. package/dist/device-mockups/Android.svelte +18 -6
  20. package/dist/device-mockups/Android.svelte.d.ts +12 -0
  21. package/dist/device-mockups/DefaultMockup.svelte +15 -5
  22. package/dist/device-mockups/DefaultMockup.svelte.d.ts +10 -0
  23. package/dist/device-mockups/Desktop.svelte +9 -3
  24. package/dist/device-mockups/Desktop.svelte.d.ts +6 -0
  25. package/dist/device-mockups/Ios.svelte +15 -5
  26. package/dist/device-mockups/Ios.svelte.d.ts +10 -0
  27. package/dist/device-mockups/Laptop.svelte +9 -3
  28. package/dist/device-mockups/Laptop.svelte.d.ts +6 -0
  29. package/dist/device-mockups/Smartwatch.svelte +15 -5
  30. package/dist/device-mockups/Smartwatch.svelte.d.ts +10 -0
  31. package/dist/device-mockups/Tablet.svelte +15 -5
  32. package/dist/device-mockups/Tablet.svelte.d.ts +10 -0
  33. package/dist/footer/FooterBrand.svelte +9 -3
  34. package/dist/footer/FooterBrand.svelte.d.ts +6 -0
  35. package/dist/footer/FooterCopyright.svelte +6 -2
  36. package/dist/footer/FooterCopyright.svelte.d.ts +5 -1
  37. package/dist/footer/FooterLink.svelte +6 -2
  38. package/dist/footer/FooterLink.svelte.d.ts +4 -0
  39. package/dist/forms/CheckboxButton.svelte.d.ts +2 -2
  40. package/dist/forms/Fileupload.svelte +34 -3
  41. package/dist/forms/Fileupload.svelte.d.ts +6 -0
  42. package/dist/forms/FloatingLabelInput.svelte +9 -3
  43. package/dist/forms/FloatingLabelInput.svelte.d.ts +7 -1
  44. package/dist/forms/Input.svelte +7 -3
  45. package/dist/forms/Input.svelte.d.ts +4 -0
  46. package/dist/forms/Label.svelte +0 -1
  47. package/dist/forms/MultiSelect.svelte +0 -2
  48. package/dist/forms/NumberInput.svelte.d.ts +2 -0
  49. package/dist/forms/Radio.svelte +1 -1
  50. package/dist/forms/RadioButton.svelte +1 -1
  51. package/dist/forms/Search.svelte.d.ts +2 -0
  52. package/dist/forms/Textarea.svelte.d.ts +1 -1
  53. package/dist/forms/Toggle.svelte +8 -2
  54. package/dist/forms/Toggle.svelte.d.ts +4 -0
  55. package/dist/mega-menu/MegaMenu.svelte +1 -1
  56. package/dist/navbar/NavHamburger.svelte +3 -1
  57. package/dist/navbar/NavHamburger.svelte.d.ts +2 -0
  58. package/dist/navbar/NavUl.svelte +3 -5
  59. package/dist/navbar/NavUl.svelte.d.ts +1 -0
  60. package/dist/navbar/Navbar.svelte +3 -1
  61. package/dist/navbar/Navbar.svelte.d.ts +1 -0
  62. package/dist/pagination/PaginationItem.svelte +0 -1
  63. package/dist/progress/Progressbar.svelte +3 -1
  64. package/dist/progress/Progressbar.svelte.d.ts +2 -0
  65. package/dist/rating/AdvancedRating.svelte +15 -5
  66. package/dist/rating/AdvancedRating.svelte.d.ts +17 -8
  67. package/dist/rating/Review.svelte +17 -7
  68. package/dist/rating/Review.svelte.d.ts +10 -0
  69. package/dist/sidebar/SidebarDropdownWrapper.svelte +1 -1
  70. package/dist/sidebar/SidebarDropdownWrapper.svelte.d.ts +2 -0
  71. package/dist/speed-dial/SpeedDial.svelte.d.ts +2 -2
  72. package/dist/speed-dial/SpeedDialButton.svelte.d.ts +2 -2
  73. package/dist/steps/StepIndicator.svelte +11 -9
  74. package/dist/steps/StepIndicator.svelte.d.ts +14 -14
  75. package/dist/table/Table.svelte +6 -2
  76. package/dist/table/Table.svelte.d.ts +4 -0
  77. package/dist/table/TableSearch.svelte +6 -2
  78. package/dist/table/TableSearch.svelte.d.ts +4 -0
  79. package/dist/timeline/ActivityItem.svelte +24 -8
  80. package/dist/timeline/ActivityItem.svelte.d.ts +16 -0
  81. package/dist/timeline/Group.svelte +9 -3
  82. package/dist/timeline/Group.svelte.d.ts +6 -0
  83. package/dist/timeline/GroupItem.svelte +15 -5
  84. package/dist/timeline/GroupItem.svelte.d.ts +10 -0
  85. package/dist/timeline/TimelineItem.svelte +12 -4
  86. package/dist/timeline/TimelineItem.svelte.d.ts +8 -0
  87. package/dist/types.d.ts +2 -0
  88. package/dist/typography/Hr.svelte +9 -3
  89. package/dist/typography/Hr.svelte.d.ts +6 -0
  90. package/dist/utils/backdrop.js +1 -10
  91. package/package.json +14 -14
@@ -9,10 +9,12 @@ export let flush = false;
9
9
  export let activeClass = "bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-800";
10
10
  export let inactiveClass = "text-gray-500 dark:text-gray-400 hover:bg-gray-100 hover:dark:bg-gray-800";
11
11
  export let defaultClass = "text-gray-500 dark:text-gray-400";
12
+ export let classActive = "";
13
+ export let classInactive = "";
12
14
  const ctx = {
13
15
  flush,
14
- activeClass: twMerge(activeClass, $$props.classActive),
15
- inactiveClass: twMerge(inactiveClass, $$props.classInactive),
16
+ activeClass: twMerge(activeClass, classActive),
17
+ inactiveClass: twMerge(inactiveClass, classInactive),
16
18
  selected: multiple ? void 0 : writable()
17
19
  };
18
20
  setContext("ctx", ctx);
@@ -33,4 +35,6 @@ $: frameClass = twMerge(defaultClass, $$props.class);
33
35
  @prop export let activeClass: $$Props['activeClass'] = 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-800';
34
36
  @prop export let inactiveClass: $$Props['inactiveClass'] = 'text-gray-500 dark:text-gray-400 hover:bg-gray-100 hover:dark:bg-gray-800';
35
37
  @prop export let defaultClass: $$Props['defaultClass'] = 'text-gray-500 dark:text-gray-400';
38
+ @prop export let classActive: $$Props['classActive'] = '';
39
+ @prop export let classInactive: $$Props['classInactive'] = '';
36
40
  -->
@@ -50,6 +50,8 @@ export type AccordionSlots = typeof __propDef.slots;
50
50
  * @prop export let activeClass: $$Props['activeClass'] = 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-800';
51
51
  * @prop export let inactiveClass: $$Props['inactiveClass'] = 'text-gray-500 dark:text-gray-400 hover:bg-gray-100 hover:dark:bg-gray-800';
52
52
  * @prop export let defaultClass: $$Props['defaultClass'] = 'text-gray-500 dark:text-gray-400';
53
+ * @prop export let classActive: $$Props['classActive'] = '';
54
+ * @prop export let classInactive: $$Props['classInactive'] = '';
53
55
  */
54
56
  export default class Accordion extends SvelteComponentTyped<AccordionProps, AccordionEvents, AccordionSlots> {
55
57
  }
@@ -9,6 +9,8 @@ export let innerClass = "flex";
9
9
  export let bannerStatus = true;
10
10
  export let transition = fade;
11
11
  export let params = {};
12
+ export let classDiv = "";
13
+ export let classInner = "";
12
14
  const divClasses = {
13
15
  default: "top-0 start-0 w-full border-b border-gray-200 bg-gray-50",
14
16
  bottom: "bottom-0 start-0 w-full border-t border-gray-200 bg-gray-50",
@@ -23,8 +25,8 @@ const insideDivClasses = {
23
25
  signup: "items-center flex-shrink-0 w-full mx-auto sm:w-auto",
24
26
  info: "items-center flex-shrink-0"
25
27
  };
26
- $: divClass = twMerge(position, divClass, divClasses[bannerType], $$props.classDiv);
27
- $: div2Class = twMerge(innerClass, insideDivClasses[bannerType], $$props.classInner);
28
+ $: divClass = twMerge(position, divClass, divClasses[bannerType], classDiv);
29
+ $: div2Class = twMerge(innerClass, insideDivClasses[bannerType], classInner);
28
30
  function close(e) {
29
31
  e.preventDefault();
30
32
  bannerStatus = false;
@@ -58,4 +60,6 @@ function close(e) {
58
60
  @prop export let bannerStatus: $$Props['bannerStatus'] = true;
59
61
  @prop export let transition: NonNullable<$$Props['transition']> = fade;
60
62
  @prop export let params: $$Props['params'] = {};
63
+ @prop export let classDiv: $$Props['classDiv'] = '';
64
+ @prop export let classInner: $$Props['classInner'] = '';
61
65
  -->
@@ -1,6 +1,7 @@
1
1
  import { SvelteComponentTyped } from "svelte";
2
2
  import type { HTMLAttributes } from 'svelte/elements';
3
3
  import { type TransitionConfig } from 'svelte/transition';
4
+ import type { ParamsType } from '../types';
4
5
  declare const __propDef: {
5
6
  props: HTMLAttributes<HTMLDivElement> & {
6
7
  position?: "static" | "fixed" | "absolute" | "relative" | "sticky";
@@ -9,8 +10,10 @@ declare const __propDef: {
9
10
  divClass?: string;
10
11
  innerClass?: string;
11
12
  bannerStatus?: boolean;
12
- transition?: (node: HTMLElement, params: any) => TransitionConfig;
13
+ transition?: (node: HTMLElement, params: ParamsType) => TransitionConfig;
13
14
  params?: object;
15
+ classDiv?: string;
16
+ classInner?: string;
14
17
  };
15
18
  events: {
16
19
  click: MouseEvent;
@@ -43,6 +46,8 @@ export type BannerSlots = typeof __propDef.slots;
43
46
  * @prop export let bannerStatus: $$Props['bannerStatus'] = true;
44
47
  * @prop export let transition: NonNullable<$$Props['transition']> = fade;
45
48
  * @prop export let params: $$Props['params'] = {};
49
+ * @prop export let classDiv: $$Props['classDiv'] = '';
50
+ * @prop export let classInner: $$Props['classInner'] = '';
46
51
  */
47
52
  export default class Banner extends SvelteComponentTyped<BannerProps, BannerEvents, BannerSlots> {
48
53
  }
@@ -9,9 +9,12 @@ export let navType = "default";
9
9
  export let outerClass = "w-full z-50 border-gray-200 dark:bg-gray-700 dark:border-gray-600";
10
10
  export let innerClass = "grid h-full max-w-lg mx-auto";
11
11
  export let activeClass = "text-primary-700 dark:text-primary-700 hover:text-primary-900 dark:hover:text-primary-900";
12
+ export let classActive = "";
13
+ export let classOuter = "";
14
+ export let classInner = "";
12
15
  let activeCls = "";
13
16
  const activeUrlStore = writable("");
14
- activeCls = twMerge(activeClass, $$props.classActive);
17
+ activeCls = twMerge(activeClass, classActive);
15
18
  setContext("navType", navType);
16
19
  setContext("bottomNavType", { activeClass: activeCls });
17
20
  $: {
@@ -38,8 +41,8 @@ const innerDivClasses = {
38
41
  meeting: "flex items-center justify-center mx-auto",
39
42
  video: "flex items-center w-full"
40
43
  };
41
- $: outerCls = twMerge(position, outerClass, outerDivClasses[navType], $$props.classOuter);
42
- $: innerCls = twMerge(innerClass, innerDivClasses[navType], $$props.classInner);
44
+ $: outerCls = twMerge(position, outerClass, outerDivClasses[navType], classOuter);
45
+ $: innerCls = twMerge(innerClass, innerDivClasses[navType], classInner);
43
46
  </script>
44
47
 
45
48
  <div {...$$restProps} class={outerCls}>
@@ -59,4 +62,7 @@ $: innerCls = twMerge(innerClass, innerDivClasses[navType], $$props.classInner);
59
62
  @prop export let outerClass: $$Props['outerClass'] = 'w-full z-50 border-gray-200 dark:bg-gray-700 dark:border-gray-600';
60
63
  @prop export let innerClass: $$Props['innerClass'] = 'grid h-full max-w-lg mx-auto';
61
64
  @prop export let activeClass: $$Props['activeClass'] = 'text-primary-700 dark:text-primary-700 hover:text-primary-900 dark:hover:text-primary-900';
65
+ @prop export let classActive: $$Props['classActive'] = '';
66
+ @prop export let classOuter: $$Props['classOuter'] = '';
67
+ @prop export let classInner: $$Props['classInner'] = '';
62
68
  -->
@@ -13,6 +13,9 @@ declare const __propDef: {
13
13
  outerClass?: string;
14
14
  innerClass?: string;
15
15
  activeClass?: string;
16
+ classActive?: string;
17
+ classOuter?: string;
18
+ classInner?: string;
16
19
  };
17
20
  events: {
18
21
  [evt: string]: CustomEvent<any>;
@@ -34,6 +37,9 @@ export type BottomNavSlots = typeof __propDef.slots;
34
37
  * @prop export let outerClass: $$Props['outerClass'] = 'w-full z-50 border-gray-200 dark:bg-gray-700 dark:border-gray-600';
35
38
  * @prop export let innerClass: $$Props['innerClass'] = 'grid h-full max-w-lg mx-auto';
36
39
  * @prop export let activeClass: $$Props['activeClass'] = 'text-primary-700 dark:text-primary-700 hover:text-primary-900 dark:hover:text-primary-900';
40
+ * @prop export let classActive: $$Props['classActive'] = '';
41
+ * @prop export let classOuter: $$Props['classOuter'] = '';
42
+ * @prop export let classInner: $$Props['classInner'] = '';
37
43
  */
38
44
  export default class BottomNav extends SvelteComponentTyped<BottomNavProps, BottomNavEvents, BottomNavSlots> {
39
45
  }
@@ -1,10 +1,12 @@
1
1
  <script>import { twMerge } from "tailwind-merge";
2
2
  export let outerClass = "w-full";
3
3
  export let innerClass = "grid max-w-xs grid-cols-3 gap-1 p-1 mx-auto my-2 bg-gray-100 rounded-lg dark:bg-gray-600";
4
+ export let classOuter = "";
5
+ export let classInner = "";
4
6
  </script>
5
7
 
6
- <div {...$$restProps} class={twMerge(outerClass, $$props.classOuter)} >
7
- <div class={twMerge(innerClass, $$props.classInner)} role="group">
8
+ <div {...$$restProps} class={twMerge(outerClass, classOuter)} >
9
+ <div class={twMerge(innerClass, classInner)} role="group">
8
10
  <slot />
9
11
  </div>
10
12
  </div>
@@ -15,4 +17,6 @@ export let innerClass = "grid max-w-xs grid-cols-3 gap-1 p-1 mx-auto my-2 bg-gra
15
17
  ## Props
16
18
  @prop export let outerClass: $$Props['outerClass'] = 'w-full';
17
19
  @prop export let innerClass: $$Props['innerClass'] = 'grid max-w-xs grid-cols-3 gap-1 p-1 mx-auto my-2 bg-gray-100 rounded-lg dark:bg-gray-600';
20
+ @prop export let classOuter: $$Props['classOuter'] = '';
21
+ @prop export let classInner: $$Props['classInner'] = '';
18
22
  -->
@@ -4,6 +4,8 @@ declare const __propDef: {
4
4
  props: HTMLAttributes<HTMLDivElement> & {
5
5
  outerClass?: string;
6
6
  innerClass?: string;
7
+ classOuter?: string;
8
+ classInner?: string;
7
9
  };
8
10
  events: {
9
11
  [evt: string]: CustomEvent<any>;
@@ -20,6 +22,8 @@ export type BottomNavHeaderSlots = typeof __propDef.slots;
20
22
  * ## Props
21
23
  * @prop export let outerClass: $$Props['outerClass'] = 'w-full';
22
24
  * @prop export let innerClass: $$Props['innerClass'] = 'grid max-w-xs grid-cols-3 gap-1 p-1 mx-auto my-2 bg-gray-100 rounded-lg dark:bg-gray-600';
25
+ * @prop export let classOuter: $$Props['classOuter'] = '';
26
+ * @prop export let classInner: $$Props['classInner'] = '';
23
27
  */
24
28
  export default class BottomNavHeader extends SvelteComponentTyped<BottomNavHeaderProps, BottomNavHeaderEvents, BottomNavHeaderSlots> {
25
29
  }
@@ -4,11 +4,12 @@ export let navClass = "flex";
4
4
  export let solidClass = "flex px-5 py-3 text-gray-700 border border-gray-200 rounded-lg bg-gray-50 dark:bg-gray-800 dark:border-gray-700";
5
5
  export let olClass = "inline-flex items-center space-x-1 rtl:space-x-reverse md:space-x-3 rtl:space-x-reverse";
6
6
  export let ariaLabel = "Breadcrumb";
7
+ export let classOl = "";
7
8
  let classNav = solid ? solidClass : navClass;
8
9
  </script>
9
10
 
10
11
  <nav aria-label={ariaLabel} {...$$restProps} class={twMerge(classNav, $$props.class)}>
11
- <ol class={twMerge(olClass, $$props.classOl)}>
12
+ <ol class={twMerge(olClass, classOl)}>
12
13
  <slot />
13
14
  </ol>
14
15
  </nav>
@@ -22,4 +23,5 @@ let classNav = solid ? solidClass : navClass;
22
23
  @prop export let solidClass: NonNullable<$$Props['solidClass']> = 'flex px-5 py-3 text-gray-700 border border-gray-200 rounded-lg bg-gray-50 dark:bg-gray-800 dark:border-gray-700';
23
24
  @prop export let olClass: $$Props['olClass'] = 'inline-flex items-center space-x-1 rtl:space-x-reverse md:space-x-3 rtl:space-x-reverse';
24
25
  @prop export let ariaLabel: $$Props['ariaLabel'] = 'Breadcrumb';
26
+ @prop export let classOl: $$Props['classOl'] = '';
25
27
  -->
@@ -7,6 +7,7 @@ declare const __propDef: {
7
7
  solidClass?: string;
8
8
  olClass?: string;
9
9
  ariaLabel?: string;
10
+ classOl?: string;
10
11
  };
11
12
  events: {
12
13
  [evt: string]: CustomEvent<any>;
@@ -26,6 +27,7 @@ export type BreadcrumbSlots = typeof __propDef.slots;
26
27
  * @prop export let solidClass: NonNullable<$$Props['solidClass']> = 'flex px-5 py-3 text-gray-700 border border-gray-200 rounded-lg bg-gray-50 dark:bg-gray-800 dark:border-gray-700';
27
28
  * @prop export let olClass: $$Props['olClass'] = 'inline-flex items-center space-x-1 rtl:space-x-reverse md:space-x-3 rtl:space-x-reverse';
28
29
  * @prop export let ariaLabel: $$Props['ariaLabel'] = 'Breadcrumb';
30
+ * @prop export let classOl: $$Props['classOl'] = '';
29
31
  */
30
32
  export default class Breadcrumb extends SvelteComponentTyped<BreadcrumbProps, BreadcrumbEvents, BreadcrumbSlots> {
31
33
  }
@@ -4,11 +4,14 @@ export let href = void 0;
4
4
  export let linkClass = "ms-1 text-sm font-medium text-gray-700 hover:text-gray-900 md:ms-2 dark:text-gray-400 dark:hover:text-white";
5
5
  export let spanClass = "ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400";
6
6
  export let homeClass = "inline-flex items-center text-sm font-medium text-gray-700 hover:text-gray-900 dark:text-gray-400 dark:hover:text-white";
7
+ export let classHome = "";
8
+ export let classLink = "";
9
+ export let classSpan = "";
7
10
  </script>
8
11
 
9
12
  <li {...$$restProps} class={twMerge('inline-flex items-center', $$props.class)}>
10
13
  {#if home}
11
- <a class={twMerge(homeClass, $$props.classHome)} {href}>
14
+ <a class={twMerge(homeClass, classHome)} {href}>
12
15
  {#if $$slots.icon}
13
16
  <slot name="icon" />
14
17
  {:else}
@@ -27,11 +30,11 @@ export let homeClass = "inline-flex items-center text-sm font-medium text-gray-7
27
30
  </svg>
28
31
  {/if}
29
32
  {#if href}
30
- <a class={twMerge(linkClass, $$props.classLink)} {href}>
33
+ <a class={twMerge(linkClass, classLink)} {href}>
31
34
  <slot />
32
35
  </a>
33
36
  {:else}
34
- <span class={twMerge(spanClass, $$props.classSpan)}>
37
+ <span class={twMerge(spanClass, classSpan)}>
35
38
  <slot />
36
39
  </span>
37
40
  {/if}
@@ -47,4 +50,7 @@ export let homeClass = "inline-flex items-center text-sm font-medium text-gray-7
47
50
  @prop export let linkClass: $$Props['linkClass'] = 'ms-1 text-sm font-medium text-gray-700 hover:text-gray-900 md:ms-2 dark:text-gray-400 dark:hover:text-white';
48
51
  @prop export let spanClass: $$Props['spanClass'] = 'ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400';
49
52
  @prop export let homeClass: $$Props['homeClass'] = 'inline-flex items-center text-sm font-medium text-gray-700 hover:text-gray-900 dark:text-gray-400 dark:hover:text-white';
53
+ @prop export let classHome: $$Props['classHome'] = '';
54
+ @prop export let classLink: $$Props['classLink'] = '';
55
+ @prop export let classSpan: $$Props['classSpan'] = '';
50
56
  -->
@@ -7,6 +7,9 @@ declare const __propDef: {
7
7
  linkClass?: string;
8
8
  spanClass?: string;
9
9
  homeClass?: string;
10
+ classHome?: string;
11
+ classLink?: string;
12
+ classSpan?: string;
10
13
  };
11
14
  events: {
12
15
  [evt: string]: CustomEvent<any>;
@@ -27,6 +30,9 @@ export type BreadcrumbItemSlots = typeof __propDef.slots;
27
30
  * @prop export let linkClass: $$Props['linkClass'] = 'ms-1 text-sm font-medium text-gray-700 hover:text-gray-900 md:ms-2 dark:text-gray-400 dark:hover:text-white';
28
31
  * @prop export let spanClass: $$Props['spanClass'] = 'ms-1 text-sm font-medium text-gray-500 md:ms-2 dark:text-gray-400';
29
32
  * @prop export let homeClass: $$Props['homeClass'] = 'inline-flex items-center text-sm font-medium text-gray-700 hover:text-gray-900 dark:text-gray-400 dark:hover:text-white';
33
+ * @prop export let classHome: $$Props['classHome'] = '';
34
+ * @prop export let classLink: $$Props['classLink'] = '';
35
+ * @prop export let classSpan: $$Props['classSpan'] = '';
30
36
  */
31
37
  export default class BreadcrumbItem extends SvelteComponentTyped<BreadcrumbItemProps, BreadcrumbItemEvents, BreadcrumbItemSlots> {
32
38
  }
@@ -107,6 +107,10 @@ $: buttonClass = twMerge(
107
107
  <a {href} {...$$restProps} class={buttonClass} role="button" on:click on:change on:keydown on:keyup on:touchstart|passive on:touchend on:touchcancel on:mouseenter on:mouseleave>
108
108
  <slot />
109
109
  </a>
110
+ {:else if tag === 'label'}
111
+ <label {...$$restProps} class={buttonClass}>
112
+ <slot />
113
+ </label>
110
114
  {:else if tag === 'button' }
111
115
  <button {type} {...$$restProps} {disabled} class={buttonClass} on:click on:change on:keydown on:keyup on:touchstart|passive on:touchend on:touchcancel on:mouseenter on:mouseleave>
112
116
  <slot />
@@ -7,7 +7,7 @@ declare const __propDef: {
7
7
  size?: "xs" | "sm" | "md" | "lg" | "xl";
8
8
  color?: "red" | "yellow" | "green" | "purple" | "blue" | "light" | "dark" | "primary" | "none" | "alternative";
9
9
  shadow?: boolean;
10
- tag?: "a" | "button";
10
+ tag?: "a" | "button" | "label";
11
11
  checked?: boolean;
12
12
  } & Omit<HTMLAnchorAttributes, "type"> & {
13
13
  href?: string | undefined;
@@ -17,7 +17,7 @@ declare const __propDef: {
17
17
  size?: "xs" | "sm" | "md" | "lg" | "xl";
18
18
  color?: "red" | "yellow" | "green" | "purple" | "blue" | "light" | "dark" | "primary" | "none" | "alternative";
19
19
  shadow?: boolean;
20
- tag?: "a" | "button";
20
+ tag?: "a" | "button" | "label";
21
21
  checked?: boolean;
22
22
  } & HTMLButtonAttributes & {
23
23
  disabled?: HTMLButtonAttributes["disabled"];
@@ -11,13 +11,14 @@ import type { TransitionConfig } from 'svelte/transition';
11
11
  import Controls from './Controls.svelte';
12
12
  import Indicators from './Indicators.svelte';
13
13
  import Slide from './Slide.svelte';
14
+ import type { ParamsType } from '../types';
14
15
  declare const __propDef: {
15
16
  props: {
16
17
  [x: string]: any;
17
18
  images: HTMLImgAttributes[];
18
19
  index?: number | undefined;
19
20
  slideDuration?: number | undefined;
20
- transition?: (((node: HTMLElement, params: any) => TransitionConfig) | null) | undefined;
21
+ transition?: (((node: HTMLElement, params: ParamsType) => TransitionConfig) | null) | undefined;
21
22
  duration?: number | undefined;
22
23
  ariaLabel?: string | undefined;
23
24
  disableSwipe?: boolean | undefined;
@@ -1,11 +1,12 @@
1
1
  import { SvelteComponentTyped } from "svelte";
2
2
  import type { HTMLImgAttributes } from 'svelte/elements';
3
3
  import { type TransitionConfig } from 'svelte/transition';
4
+ import type { ParamsType } from '../types';
4
5
  declare const __propDef: {
5
6
  props: {
6
7
  [x: string]: any;
7
8
  image: HTMLImgAttributes;
8
- transition?: (((node: HTMLElement, params: any) => TransitionConfig) | null) | undefined;
9
+ transition?: (((node: HTMLElement, params: ParamsType) => TransitionConfig) | null) | undefined;
9
10
  };
10
11
  events: {
11
12
  [evt: string]: CustomEvent<any>;
@@ -23,7 +23,6 @@ $: index = (index + images.length) % images.length;
23
23
  <div class={twMerge('flex flex-row justify-center bg-gray-100 w-full', $$props.class)}>
24
24
  {#each images as image, idx}
25
25
  {@const selected = index === idx}
26
- <!-- svelte-ignore a11y-click-events-have-key-events -->
27
26
  <button on:click={() => btnClick(idx)} aria-label={ariaLabel}>
28
27
  <slot {Thumbnail} {image} {selected} {imgClass}>
29
28
  <Thumbnail {...image} {selected} class={imgClass} />
@@ -21,8 +21,8 @@ export let title = "";
21
21
  const dispatch = createEventDispatcher();
22
22
  let isOpen = inline;
23
23
  let inputElement;
24
+ let datepickerContainerElement;
24
25
  let currentMonth = value || defaultDate || /* @__PURE__ */ new Date();
25
- currentMonth.setDate(1);
26
26
  let focusedDate = null;
27
27
  let calendarRef;
28
28
  $: daysInMonth = getDaysInMonth(currentMonth);
@@ -129,7 +129,7 @@ function handleInputChange() {
129
129
  }
130
130
  }
131
131
  function handleClickOutside(event) {
132
- if (isOpen && !inputElement.contains(event.target)) {
132
+ if (isOpen && datepickerContainerElement && !datepickerContainerElement.contains(event.target)) {
133
133
  isOpen = false;
134
134
  }
135
135
  }
@@ -137,12 +137,16 @@ function formatDate(date) {
137
137
  if (!date) return "";
138
138
  return date.toLocaleDateString(locale, dateFormat);
139
139
  }
140
- function isSelected(day) {
140
+ function isSameDate(date1, date2) {
141
+ if (!date1 || !date2) return false;
142
+ return date1.toDateString() === date2.toDateString();
143
+ }
144
+ $: isSelected = (day) => {
141
145
  if (range) {
142
- return !!(rangeFrom && day.toDateString() === rangeFrom.toDateString()) || !!(rangeTo && day.toDateString() === rangeTo.toDateString());
146
+ return isSameDate(day, rangeFrom) || isSameDate(day, rangeTo);
143
147
  }
144
- return !!(value && day.toDateString() === value.toDateString());
145
- }
148
+ return isSameDate(day, value);
149
+ };
146
150
  function isInRange(day) {
147
151
  if (!range || !rangeFrom || !rangeTo) return false;
148
152
  return day > rangeFrom && day < rangeTo;
@@ -209,7 +213,7 @@ function handleApply() {
209
213
  }
210
214
  </script>
211
215
 
212
- <div class="relative {inline ? 'inline-block' : ''}">
216
+ <div bind:this={datepickerContainerElement} class="relative {inline ? 'inline-block' : ''}">
213
217
  {#if !inline}
214
218
  <div class="relative">
215
219
  <input bind:this={inputElement} type="text" class="w-full px-4 py-2 text-sm border rounded-md focus:outline-none dark:bg-gray-700 dark:text-white dark:border-gray-600 {getFocusRingClass(color)} {inputClass}" {placeholder} value={range ? `${formatDate(rangeFrom)} - ${formatDate(rangeTo)}` : formatDate(value)} on:focus={() => (isOpen = true)} on:input={handleInputChange} on:keydown={handleInputKeydown} {disabled} {required} aria-haspopup="dialog" />
@@ -6,15 +6,21 @@ export let leftTop = "h-[32px] w-[3px] bg-gray-800 absolute -left-[17px] top-[72
6
6
  export let leftMid = "h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[124px] rounded-l-lg";
7
7
  export let leftBot = "h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[178px] rounded-l-lg";
8
8
  export let right = "h-[64px] w-[3px] bg-gray-800 absolute -right-[17px] top-[142px] rounded-r-lg";
9
+ export let classTop = "";
10
+ export let classLeftTop = "";
11
+ export let classLeftMid = "";
12
+ export let classLeftBot = "";
13
+ export let classRight = "";
14
+ export let classSlot = "";
9
15
  </script>
10
16
 
11
17
  <div class={twMerge(div, $$props.class)}>
12
- <div class={twMerge(top, $$props.classTop)}></div>
13
- <div class={twMerge(leftTop, $$props.classLeftTop)}></div>
14
- <div class={twMerge(leftMid, $$props.classLeftMid)}></div>
15
- <div class={twMerge(leftBot, $$props.classLeftBot)}></div>
16
- <div class={twMerge(right, $$props.classRight)}></div>
17
- <div class={twMerge(slot, $$props.classSlot)}>
18
+ <div class={twMerge(top, classTop)}></div>
19
+ <div class={twMerge(leftTop, classLeftTop)}></div>
20
+ <div class={twMerge(leftMid, classLeftMid)}></div>
21
+ <div class={twMerge(leftBot, classLeftBot)}></div>
22
+ <div class={twMerge(right, classRight)}></div>
23
+ <div class={twMerge(slot, classSlot)}>
18
24
  <slot></slot>
19
25
  </div>
20
26
  </div>
@@ -30,4 +36,10 @@ export let right = "h-[64px] w-[3px] bg-gray-800 absolute -right-[17px] top-[142
30
36
  @prop export let leftMid: $$Props['leftMid'] = 'h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[124px] rounded-l-lg';
31
37
  @prop export let leftBot: $$Props['leftBot'] = 'h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[178px] rounded-l-lg';
32
38
  @prop export let right: $$Props['right'] = 'h-[64px] w-[3px] bg-gray-800 absolute -right-[17px] top-[142px] rounded-r-lg';
39
+ @prop export let classTop: $$Props['classTop'] = '';
40
+ @prop export let classLeftTop: $$Props['classLeftTop'] = '';
41
+ @prop export let classLeftMid: $$Props['classLeftMid'] = '';
42
+ @prop export let classLeftBot: $$Props['classLeftBot'] = '';
43
+ @prop export let classRight: $$Props['classRight'] = '';
44
+ @prop export let classSlot: $$Props['classSlot'] = '';
33
45
  -->
@@ -8,6 +8,12 @@ declare const __propDef: {
8
8
  leftMid?: string;
9
9
  leftBot?: string;
10
10
  right?: string;
11
+ classTop?: string;
12
+ classLeftTop?: string;
13
+ classLeftMid?: string;
14
+ classLeftBot?: string;
15
+ classRight?: string;
16
+ classSlot?: string;
11
17
  };
12
18
  events: {
13
19
  [evt: string]: CustomEvent<any>;
@@ -29,6 +35,12 @@ export type AndroidSlots = typeof __propDef.slots;
29
35
  * @prop export let leftMid: $$Props['leftMid'] = 'h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[124px] rounded-l-lg';
30
36
  * @prop export let leftBot: $$Props['leftBot'] = 'h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[178px] rounded-l-lg';
31
37
  * @prop export let right: $$Props['right'] = 'h-[64px] w-[3px] bg-gray-800 absolute -right-[17px] top-[142px] rounded-r-lg';
38
+ * @prop export let classTop: $$Props['classTop'] = '';
39
+ * @prop export let classLeftTop: $$Props['classLeftTop'] = '';
40
+ * @prop export let classLeftMid: $$Props['classLeftMid'] = '';
41
+ * @prop export let classLeftBot: $$Props['classLeftBot'] = '';
42
+ * @prop export let classRight: $$Props['classRight'] = '';
43
+ * @prop export let classSlot: $$Props['classSlot'] = '';
32
44
  */
33
45
  export default class Android extends SvelteComponentTyped<AndroidProps, AndroidEvents, AndroidSlots> {
34
46
  }
@@ -5,14 +5,19 @@ export let top = "h-[32px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -left-[
5
5
  export let leftTop = "h-[46px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -left-[17px] top-[124px] rounded-l-lg";
6
6
  export let leftBot = "h-[46px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -left-[17px] top-[178px] rounded-l-lg";
7
7
  export let right = "h-[64px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -right-[17px] top-[142px] rounded-r-lg";
8
+ export let classTop = "";
9
+ export let classLeftTop = "";
10
+ export let classLeftBot = "";
11
+ export let classRight = "";
12
+ export let classSlot = "";
8
13
  </script>
9
14
 
10
15
  <div class={twMerge(div, $$props.class)}>
11
- <div class={twMerge(top, $$props.classTop)}></div>
12
- <div class={twMerge(leftTop, $$props.classLeftTop)}></div>
13
- <div class={twMerge(leftBot, $$props.classLeftBot)}></div>
14
- <div class={twMerge(right, $$props.classRight)}></div>
15
- <div class={twMerge(slot, $$props.classSlot)}>
16
+ <div class={twMerge(top, classTop)}></div>
17
+ <div class={twMerge(leftTop, classLeftTop)}></div>
18
+ <div class={twMerge(leftBot, classLeftBot)}></div>
19
+ <div class={twMerge(right, classRight)}></div>
20
+ <div class={twMerge(slot, classSlot)}>
16
21
  <slot></slot>
17
22
  </div>
18
23
  </div>
@@ -27,4 +32,9 @@ export let right = "h-[64px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -righ
27
32
  @prop export let leftTop: $$Props['leftTop'] = 'h-[46px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -left-[17px] top-[124px] rounded-l-lg';
28
33
  @prop export let leftBot: $$Props['leftBot'] = 'h-[46px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -left-[17px] top-[178px] rounded-l-lg';
29
34
  @prop export let right: $$Props['right'] = 'h-[64px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -right-[17px] top-[142px] rounded-r-lg';
35
+ @prop export let classTop: $$Props['classTop'] = '';
36
+ @prop export let classLeftTop: $$Props['classLeftTop'] = '';
37
+ @prop export let classLeftBot: $$Props['classLeftBot'] = '';
38
+ @prop export let classRight: $$Props['classRight'] = '';
39
+ @prop export let classSlot: $$Props['classSlot'] = '';
30
40
  -->
@@ -7,6 +7,11 @@ declare const __propDef: {
7
7
  leftTop?: string;
8
8
  leftBot?: string;
9
9
  right?: string;
10
+ classTop?: string;
11
+ classLeftTop?: string;
12
+ classLeftBot?: string;
13
+ classRight?: string;
14
+ classSlot?: string;
10
15
  };
11
16
  events: {
12
17
  [evt: string]: CustomEvent<any>;
@@ -27,6 +32,11 @@ export type DefaultMockupSlots = typeof __propDef.slots;
27
32
  * @prop export let leftTop: $$Props['leftTop'] = 'h-[46px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -left-[17px] top-[124px] rounded-l-lg';
28
33
  * @prop export let leftBot: $$Props['leftBot'] = 'h-[46px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -left-[17px] top-[178px] rounded-l-lg';
29
34
  * @prop export let right: $$Props['right'] = 'h-[64px] w-[3px] bg-gray-800 dark:bg-gray-800 absolute -right-[17px] top-[142px] rounded-r-lg';
35
+ * @prop export let classTop: $$Props['classTop'] = '';
36
+ * @prop export let classLeftTop: $$Props['classLeftTop'] = '';
37
+ * @prop export let classLeftBot: $$Props['classLeftBot'] = '';
38
+ * @prop export let classRight: $$Props['classRight'] = '';
39
+ * @prop export let classSlot: $$Props['classSlot'] = '';
30
40
  */
31
41
  export default class DefaultMockup extends SvelteComponentTyped<DefaultMockupProps, DefaultMockupEvents, DefaultMockupSlots> {
32
42
  }
@@ -3,15 +3,18 @@ export let inner = "rounded-xl overflow-hidden h-[140px] md:h-[262px]";
3
3
  export let bot = "relative mx-auto bg-gray-900 dark:bg-gray-700 rounded-b-xl h-[24px] max-w-[301px] md:h-[42px] md:max-w-[512px]";
4
4
  export let botUnder = "relative mx-auto bg-gray-800 rounded-b-xl h-[55px] max-w-[83px] md:h-[95px] md:max-w-[142px]";
5
5
  export let div = "relative mx-auto border-gray-800 dark:border-gray-800 bg-gray-800 border-[16px] rounded-t-xl h-[172px] max-w-[301px] md:h-[294px] md:max-w-[512px]";
6
+ export let classInner = "";
7
+ export let classBot = "";
8
+ export let classBotUnder = "";
6
9
  </script>
7
10
 
8
11
  <div class={twMerge(div, $$props.class)}>
9
- <div class={twMerge(inner, $$props.classInner)}>
12
+ <div class={twMerge(inner, classInner)}>
10
13
  <slot></slot>
11
14
  </div>
12
15
  </div>
13
- <div class={twMerge(bot, $$props.classBot)}></div>
14
- <div class={twMerge(botUnder, $$props.classBotUnder)}></div>
16
+ <div class={twMerge(bot, classBot)}></div>
17
+ <div class={twMerge(botUnder, classBotUnder)}></div>
15
18
 
16
19
  <!--
17
20
  @component
@@ -21,4 +24,7 @@ export let div = "relative mx-auto border-gray-800 dark:border-gray-800 bg-gray-
21
24
  @prop export let bot: $$Props['bot'] = 'relative mx-auto bg-gray-900 dark:bg-gray-700 rounded-b-xl h-[24px] max-w-[301px] md:h-[42px] md:max-w-[512px]';
22
25
  @prop export let botUnder: $$Props['botUnder'] = 'relative mx-auto bg-gray-800 rounded-b-xl h-[55px] max-w-[83px] md:h-[95px] md:max-w-[142px]';
23
26
  @prop export let div: $$Props['div'] = 'relative mx-auto border-gray-800 dark:border-gray-800 bg-gray-800 border-[16px] rounded-t-xl h-[172px] max-w-[301px] md:h-[294px] md:max-w-[512px]';
27
+ @prop export let classInner: $$Props['classInner'] = '';
28
+ @prop export let classBot: $$Props['classBot'] = '';
29
+ @prop export let classBotUnder: $$Props['classBotUnder'] = '';
24
30
  -->
@@ -5,6 +5,9 @@ declare const __propDef: {
5
5
  bot?: string;
6
6
  botUnder?: string;
7
7
  div?: string;
8
+ classInner?: string;
9
+ classBot?: string;
10
+ classBotUnder?: string;
8
11
  };
9
12
  events: {
10
13
  [evt: string]: CustomEvent<any>;
@@ -23,6 +26,9 @@ export type DesktopSlots = typeof __propDef.slots;
23
26
  * @prop export let bot: $$Props['bot'] = 'relative mx-auto bg-gray-900 dark:bg-gray-700 rounded-b-xl h-[24px] max-w-[301px] md:h-[42px] md:max-w-[512px]';
24
27
  * @prop export let botUnder: $$Props['botUnder'] = 'relative mx-auto bg-gray-800 rounded-b-xl h-[55px] max-w-[83px] md:h-[95px] md:max-w-[142px]';
25
28
  * @prop export let div: $$Props['div'] = 'relative mx-auto border-gray-800 dark:border-gray-800 bg-gray-800 border-[16px] rounded-t-xl h-[172px] max-w-[301px] md:h-[294px] md:max-w-[512px]';
29
+ * @prop export let classInner: $$Props['classInner'] = '';
30
+ * @prop export let classBot: $$Props['classBot'] = '';
31
+ * @prop export let classBotUnder: $$Props['classBotUnder'] = '';
26
32
  */
27
33
  export default class Desktop extends SvelteComponentTyped<DesktopProps, DesktopEvents, DesktopSlots> {
28
34
  }
@@ -5,14 +5,19 @@ export let top = "w-[148px] h-[18px] bg-gray-800 top-0 rounded-b-[1rem] left-1/2
5
5
  export let leftTop = "h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[124px] rounded-l-lg";
6
6
  export let leftBot = "h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[178px] rounded-l-lg";
7
7
  export let right = "h-[64px] w-[3px] bg-gray-800 absolute -right-[17px] top-[142px] rounded-r-lg";
8
+ export let classTop = "";
9
+ export let classLeftTop = "";
10
+ export let classLeftBot = "";
11
+ export let classRight = "";
12
+ export let classSlot = "";
8
13
  </script>
9
14
 
10
15
  <div class={twMerge(div, $$props.class)}>
11
- <div class={twMerge(top, $$props.classTop)}></div>
12
- <div class={twMerge(leftTop, $$props.classLeftTop)}></div>
13
- <div class={twMerge(leftBot, $$props.classLeftBot)}></div>
14
- <div class={twMerge(right, $$props.classRight)}></div>
15
- <div class={twMerge(slot, $$props.classSlot)}>
16
+ <div class={twMerge(top, classTop)}></div>
17
+ <div class={twMerge(leftTop, classLeftTop)}></div>
18
+ <div class={twMerge(leftBot, classLeftBot)}></div>
19
+ <div class={twMerge(right, classRight)}></div>
20
+ <div class={twMerge(slot, classSlot)}>
16
21
  <slot></slot>
17
22
  </div>
18
23
  </div>
@@ -27,4 +32,9 @@ export let right = "h-[64px] w-[3px] bg-gray-800 absolute -right-[17px] top-[142
27
32
  @prop export let leftTop: $$Props['leftTop'] = 'h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[124px] rounded-l-lg';
28
33
  @prop export let leftBot: $$Props['leftBot'] = 'h-[46px] w-[3px] bg-gray-800 absolute -left-[17px] top-[178px] rounded-l-lg';
29
34
  @prop export let right: $$Props['right'] = 'h-[64px] w-[3px] bg-gray-800 absolute -right-[17px] top-[142px] rounded-r-lg';
35
+ @prop export let classTop: $$Props['classTop'] = '';
36
+ @prop export let classLeftTop: $$Props['classLeftTop'] = '';
37
+ @prop export let classLeftBot: $$Props['classLeftBot'] = '';
38
+ @prop export let classRight: $$Props['classRight'] = '';
39
+ @prop export let classSlot: $$Props['classSlot'] = '';
30
40
  -->