flowbite-svelte 0.37.4 → 0.38.1

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 (159) hide show
  1. package/README.md +1 -1
  2. package/dist/accordion/Accordion.svelte +2 -2
  3. package/dist/accordion/AccordionItem.svelte +2 -2
  4. package/dist/alerts/Alert.svelte +35 -28
  5. package/dist/alerts/Alert.svelte.d.ts +3 -2
  6. package/dist/alerts/Alert.svelte.d.ts.map +1 -1
  7. package/dist/avatar/Avatar.svelte +2 -2
  8. package/dist/avatar/Avatar.svelte.d.ts.map +1 -1
  9. package/dist/badges/Badge.svelte +8 -4
  10. package/dist/badges/Badge.svelte.d.ts.map +1 -1
  11. package/dist/banner/Banner.svelte +3 -3
  12. package/dist/bottom-nav/BottomNav.svelte +3 -3
  13. package/dist/bottom-nav/BottomNavHeaderItem.svelte +2 -3
  14. package/dist/bottom-nav/BottomNavHeaderItem.svelte.d.ts.map +1 -1
  15. package/dist/bottom-nav/BottomNavItem.svelte +6 -6
  16. package/dist/breadcrumbs/Breadcrumb.svelte +3 -3
  17. package/dist/buttongroups/ButtonGroup.svelte +2 -2
  18. package/dist/buttons/Button.svelte +8 -2
  19. package/dist/buttons/Button.svelte.d.ts +6 -0
  20. package/dist/buttons/Button.svelte.d.ts.map +1 -1
  21. package/dist/buttons/GradientButton.svelte +9 -3
  22. package/dist/buttons/GradientButton.svelte.d.ts +6 -0
  23. package/dist/buttons/GradientButton.svelte.d.ts.map +1 -1
  24. package/dist/cards/Card.svelte +3 -3
  25. package/dist/darkmode/DarkMode.svelte +2 -2
  26. package/dist/drawer/Drawer.svelte +4 -4
  27. package/dist/dropdowns/Dropdown.svelte +6 -6
  28. package/dist/dropdowns/Dropdown.svelte.d.ts +2 -2
  29. package/dist/dropdowns/Dropdown.svelte.d.ts.map +1 -1
  30. package/dist/dropdowns/DropdownDivider.svelte +2 -2
  31. package/dist/dropdowns/DropdownHeader.svelte +2 -2
  32. package/dist/dropdowns/DropdownItem.svelte +2 -2
  33. package/dist/footer/Footer.svelte +19 -15
  34. package/dist/footer/Footer.svelte.d.ts +1 -2
  35. package/dist/footer/Footer.svelte.d.ts.map +1 -1
  36. package/dist/footer/FooterBrand.svelte +2 -2
  37. package/dist/footer/FooterCopyright.svelte +2 -2
  38. package/dist/footer/FooterIcon.svelte +2 -2
  39. package/dist/footer/FooterLink.svelte +2 -2
  40. package/dist/footer/FooterLinkGroup.svelte +2 -2
  41. package/dist/forms/Checkbox.svelte +6 -2
  42. package/dist/forms/Checkbox.svelte.d.ts +1 -0
  43. package/dist/forms/Checkbox.svelte.d.ts.map +1 -1
  44. package/dist/forms/Dropzone.svelte +2 -2
  45. package/dist/forms/Fileupload.svelte +2 -2
  46. package/dist/forms/FloatingLabelInput.svelte +5 -5
  47. package/dist/forms/Helper.svelte +2 -2
  48. package/dist/forms/Input.svelte +14 -3
  49. package/dist/forms/Input.svelte.d.ts.map +1 -1
  50. package/dist/forms/InputAddon.svelte +2 -2
  51. package/dist/forms/Label.svelte +2 -2
  52. package/dist/forms/MultiSelect.svelte +131 -0
  53. package/dist/forms/MultiSelect.svelte.d.ts +40 -0
  54. package/dist/forms/MultiSelect.svelte.d.ts.map +1 -0
  55. package/dist/forms/Radio.svelte +4 -3
  56. package/dist/forms/Radio.svelte.d.ts +2 -1
  57. package/dist/forms/Radio.svelte.d.ts.map +1 -1
  58. package/dist/forms/Range.svelte +2 -2
  59. package/dist/forms/Select.svelte +2 -2
  60. package/dist/forms/Textarea.svelte +5 -5
  61. package/dist/forms/Toggle.svelte +2 -2
  62. package/dist/gallery/Gallery.svelte +3 -3
  63. package/dist/gallery/Gallery.svelte.d.ts +3 -1
  64. package/dist/gallery/Gallery.svelte.d.ts.map +1 -1
  65. package/dist/index.d.ts +1 -0
  66. package/dist/index.d.ts.map +1 -1
  67. package/dist/index.js +1 -0
  68. package/dist/indicators/Indicator.svelte +3 -2
  69. package/dist/indicators/Indicator.svelte.d.ts.map +1 -1
  70. package/dist/kbd/ArrowKeyDown.svelte +2 -2
  71. package/dist/kbd/ArrowKeyLeft.svelte +2 -2
  72. package/dist/kbd/ArrowKeyRight.svelte +2 -2
  73. package/dist/kbd/ArrowKeyUp.svelte +2 -2
  74. package/dist/kbd/Kbd.svelte +2 -2
  75. package/dist/list-group/Listgroup.svelte +2 -2
  76. package/dist/list-group/ListgroupItem.svelte +2 -2
  77. package/dist/megamenu/MegaMenu.svelte +4 -4
  78. package/dist/modals/Modal.svelte +4 -4
  79. package/dist/navbar/NavBrand.svelte +2 -2
  80. package/dist/navbar/NavDropdown.svelte +1 -1
  81. package/dist/navbar/NavHamburger.svelte +2 -2
  82. package/dist/navbar/NavLi.svelte +2 -2
  83. package/dist/navbar/NavSidebarHamburger.svelte +2 -2
  84. package/dist/navbar/NavUl.svelte +7 -7
  85. package/dist/navbar/NavUl.svelte.d.ts +2 -2
  86. package/dist/navbar/Navbar.svelte +3 -3
  87. package/dist/paginations/Pagination.svelte +4 -4
  88. package/dist/paginations/PaginationItem.svelte +10 -2
  89. package/dist/popover/Popover.svelte +9 -2
  90. package/dist/progressbars/Progressbar.svelte +8 -7
  91. package/dist/progressbars/Progressbar.svelte.d.ts +1 -1
  92. package/dist/progressbars/Progressbar.svelte.d.ts.map +1 -1
  93. package/dist/ratings/AdvancedRating.svelte +4 -4
  94. package/dist/ratings/AdvancedRating.svelte.d.ts +2 -2
  95. package/dist/ratings/Rating.svelte +2 -2
  96. package/dist/ratings/RatingComment.svelte +2 -3
  97. package/dist/ratings/RatingComment.svelte.d.ts +1 -1
  98. package/dist/ratings/RatingComment.svelte.d.ts.map +1 -1
  99. package/dist/ratings/Review.svelte +11 -11
  100. package/dist/ratings/Review.svelte.d.ts +2 -2
  101. package/dist/sidebars/Sidebar.svelte +3 -3
  102. package/dist/sidebars/Sidebar.svelte.d.ts +1 -1
  103. package/dist/sidebars/SidebarBrand.svelte +2 -2
  104. package/dist/sidebars/SidebarCta.svelte +7 -7
  105. package/dist/sidebars/SidebarCta.svelte.d.ts +3 -3
  106. package/dist/sidebars/SidebarDropdownItem.svelte +2 -2
  107. package/dist/sidebars/SidebarDropdownWrapper.svelte +2 -2
  108. package/dist/sidebars/SidebarGroup.svelte +2 -2
  109. package/dist/sidebars/SidebarItem.svelte +2 -2
  110. package/dist/sidebars/SidebarWrapper.svelte +2 -2
  111. package/dist/skeleton/CardPlaceholder.svelte +3 -3
  112. package/dist/skeleton/ImagePlaceholder.svelte +2 -2
  113. package/dist/skeleton/ListPlaceholder.svelte +2 -2
  114. package/dist/skeleton/Skeleton.svelte +2 -2
  115. package/dist/skeleton/TestimonialPlaceholder.svelte +2 -2
  116. package/dist/skeleton/TextPlaceholder.svelte +3 -3
  117. package/dist/skeleton/TextPlaceholder.svelte.d.ts.map +1 -1
  118. package/dist/skeleton/VideoPlaceholder.svelte +3 -3
  119. package/dist/skeleton/VideoPlaceholder.svelte.d.ts.map +1 -1
  120. package/dist/skeleton/WidgetPlaceholder.svelte +2 -2
  121. package/dist/speed-dial/SpeedDial.svelte +3 -3
  122. package/dist/speed-dial/SpeedDialButton.svelte +2 -2
  123. package/dist/spinners/Spinner.svelte +2 -2
  124. package/dist/steps/StepIndicator.svelte +7 -7
  125. package/dist/tables/Table.svelte +3 -3
  126. package/dist/tables/TableBodyCell.svelte +2 -2
  127. package/dist/tables/TableBodyRow.svelte +8 -2
  128. package/dist/tables/TableHead.svelte +2 -2
  129. package/dist/tables/TableHeadCell.svelte +2 -2
  130. package/dist/tables/TableSearch.svelte +2 -2
  131. package/dist/tabs/TabItem.svelte +3 -3
  132. package/dist/tabs/Tabs.svelte +2 -2
  133. package/dist/timeline/TimelineItem.svelte +2 -2
  134. package/dist/toasts/Toast.svelte +3 -3
  135. package/dist/toasts/Toast.svelte.d.ts +38 -0
  136. package/dist/toasts/Toast.svelte.d.ts.map +1 -1
  137. package/dist/toolbar/Toolbar.svelte +3 -3
  138. package/dist/toolbar/ToolbarButton.svelte +2 -2
  139. package/dist/tooltips/Tooltip.svelte +2 -2
  140. package/dist/typography/A.svelte +3 -3
  141. package/dist/typography/Blockquote.svelte +2 -2
  142. package/dist/typography/DescriptionList.svelte +2 -2
  143. package/dist/typography/Heading.svelte +2 -2
  144. package/dist/typography/Hr.svelte +4 -4
  145. package/dist/typography/Img.svelte +3 -3
  146. package/dist/typography/Layout.svelte +2 -2
  147. package/dist/typography/Li.svelte +2 -2
  148. package/dist/typography/List.svelte +2 -2
  149. package/dist/typography/Mark.svelte +2 -2
  150. package/dist/typography/P.svelte +2 -2
  151. package/dist/typography/Secondary.svelte +2 -2
  152. package/dist/typography/Span.svelte +3 -3
  153. package/dist/utils/CloseButton.svelte +2 -2
  154. package/dist/utils/Frame.svelte +4 -4
  155. package/dist/utils/MenuButton.svelte +2 -2
  156. package/dist/utils/Popper.svelte +8 -7
  157. package/dist/utils/Popper.svelte.d.ts.map +1 -1
  158. package/dist/video/Video.svelte +2 -2
  159. package/package.json +27 -6
@@ -1,8 +1,8 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let divClass = 'my-1 h-px bg-gray-100 dark:bg-gray-600';
3
3
  </script>
4
4
 
5
- <div {...$$restProps} class={classNames(divClass, $$props.class)} />
5
+ <div {...$$restProps} class={twMerge(divClass, $$props.class)} />
6
6
 
7
7
  <!--
8
8
  @component
@@ -1,10 +1,10 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  import DropdownDivider from './DropdownDivider.svelte';
3
3
  export let divClass = 'py-2 px-4 text-gray-700 dark:text-white';
4
4
  export let divider = true;
5
5
  </script>
6
6
 
7
- <div {...$$restProps} class={classNames(divClass, $$props.class)}>
7
+ <div {...$$restProps} class={twMerge(divClass, $$props.class)}>
8
8
  <slot />
9
9
  </div>
10
10
  {#if divider}
@@ -1,9 +1,9 @@
1
1
  <script>import Wrapper from '../utils/Wrapper.svelte';
2
- import classNames from 'classnames';
2
+ import { twMerge } from 'tailwind-merge';
3
3
  export let defaultClass = 'font-medium py-2 px-4 text-sm hover:bg-gray-100 dark:hover:bg-gray-600';
4
4
  export let href = undefined;
5
5
  let liClass;
6
- $: liClass = classNames(defaultClass, href ? 'block' : 'w-full text-left', $$props.class);
6
+ $: liClass = twMerge(defaultClass, href ? 'block' : 'w-full text-left', $$props.class);
7
7
  let wrap = true;
8
8
  function init(node) {
9
9
  wrap = node.parentElement?.tagName === 'UL';
@@ -1,22 +1,26 @@
1
- <script>import classNames from 'classnames';
2
- export let customClass = '';
1
+ <script>import { twMerge } from 'tailwind-merge';
3
2
  export let footerType = 'default';
4
- // using classNames dynamic class names, https://github.com/JedWatson/classnames#dynamic-class-names-with-es2015
3
+ let styles = '';
4
+ switch (footerType) {
5
+ case 'sitemap':
6
+ styles = 'bg-gray-800';
7
+ break;
8
+ case 'socialmedia':
9
+ styles = 'p-4 bg-white sm:p-6 dark:bg-gray-800';
10
+ break;
11
+ case 'logo':
12
+ styles = 'p-4 bg-white rounded-lg shadow md:px-6 md:py-8 dark:bg-gray-800';
13
+ break;
14
+ case 'default':
15
+ styles = 'p-4 bg-white rounded-lg shadow md:flex md:items-center md:justify-between md:p-6 dark:bg-gray-800';
16
+ break;
17
+ }
18
+ let footerClass = twMerge([styles, $$props.class]);
19
+ console.log(footerClass);
5
20
  </script>
6
-
7
21
  <footer
8
22
  {...$$restProps}
9
- class={classNames(
10
- {
11
- 'bg-gray-800': footerType === 'sitemap',
12
- 'p-4 bg-white sm:p-6 dark:bg-gray-800': footerType === 'socialmedia',
13
- 'p-4 bg-white rounded-lg shadow md:px-6 md:py-8 dark:bg-gray-800': footerType === 'logo',
14
- 'p-4 bg-white rounded-lg shadow md:flex md:items-center md:justify-between md:p-6 dark:bg-gray-800':
15
- footerType === 'default',
16
- [`${customClass}`]: footerType === 'custom'
17
- },
18
- $$props.class
19
- )}>
23
+ class={footerClass}>
20
24
  <slot />
21
25
  </footer>
22
26
 
@@ -2,8 +2,7 @@ import { SvelteComponentTyped } from "svelte";
2
2
  declare const __propDef: {
3
3
  props: {
4
4
  [x: string]: any;
5
- customClass?: string | undefined;
6
- footerType?: "default" | "custom" | "sitemap" | "logo" | "socialmedia" | undefined;
5
+ footerType?: "default" | "sitemap" | "logo" | "socialmedia" | undefined;
7
6
  };
8
7
  events: {
9
8
  [evt: string]: CustomEvent<any>;
@@ -1 +1 @@
1
- {"version":3,"file":"Footer.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/footer/Footer.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AA4BD,QAAA,MAAM,SAAS;;;;;;;;;;;;CAA+D,CAAC;AAC/E,MAAM,MAAM,WAAW,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AACjD,MAAM,MAAM,YAAY,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AACnD,MAAM,MAAM,WAAW,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEjD;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,MAAM,CAAC,OAAO,OAAO,MAAO,SAAQ,oBAAoB,CAAC,WAAW,EAAE,YAAY,EAAE,WAAW,CAAC;CAC/F"}
1
+ {"version":3,"file":"Footer.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/footer/Footer.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AAqCD,QAAA,MAAM,SAAS;;;;;;;;;;;CAA+D,CAAC;AAC/E,MAAM,MAAM,WAAW,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AACjD,MAAM,MAAM,YAAY,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AACnD,MAAM,MAAM,WAAW,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEjD;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,MAAM,CAAC,OAAO,OAAO,MAAO,SAAQ,oBAAoB,CAAC,WAAW,EAAE,YAAY,EAAE,WAAW,CAAC;CAC/F"}
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let aClass = 'flex items-center';
3
3
  export let spanClass = 'self-center text-2xl font-semibold whitespace-nowrap dark:text-white';
4
4
  export let imgClass = 'mr-3 h-8';
@@ -10,7 +10,7 @@ export let target = undefined;
10
10
  </script>
11
11
 
12
12
  {#if href}
13
- <a {...$$restProps} {href} {target} class={classNames(aClass, $$props.class)}>
13
+ <a {...$$restProps} {href} {target} class={twMerge(aClass, $$props.class)}>
14
14
  <img {src} class={imgClass} {alt} />
15
15
  <span class={spanClass}>{name}</span>
16
16
  <slot />
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let spanClass = 'block text-sm text-gray-500 sm:text-center dark:text-gray-400';
3
3
  export let aClass = 'hover:underline';
4
4
  export let year = new Date().getFullYear();
@@ -8,7 +8,7 @@ export let target = undefined;
8
8
  export let copyrightMessage = 'All Rights Reserved.';
9
9
  </script>
10
10
 
11
- <span class={classNames(spanClass, $$props.class)}>
11
+ <span class={twMerge(spanClass, $$props.class)}>
12
12
  &copy; {year}
13
13
  {#if href}
14
14
  <a {...$$restProps} {href} {target} class={aClass}>
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let href = '';
3
3
  export let ariaLabel = '';
4
4
  export let aClass = 'text-gray-500 hover:text-gray-900 dark:hover:text-white';
@@ -6,7 +6,7 @@ export let target = undefined;
6
6
  </script>
7
7
 
8
8
  {#if href}
9
- <a {...$$restProps} {href} {target} aria-label={ariaLabel} class={classNames(aClass, $$props.class)}>
9
+ <a {...$$restProps} {href} {target} aria-label={ariaLabel} class={twMerge(aClass, $$props.class)}>
10
10
  <slot />
11
11
  </a>
12
12
  {:else}
@@ -1,11 +1,11 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let liClass = 'mr-4 last:mr-0 md:mr-6';
3
3
  export let aClass = 'hover:underline';
4
4
  export let href = '';
5
5
  export let target = undefined;
6
6
  </script>
7
7
 
8
- <li class={classNames(liClass, $$props.class)}>
8
+ <li class={twMerge(liClass, $$props.class)}>
9
9
  <a {...$$restProps} {href} class={aClass} {target}>
10
10
  <slot />
11
11
  </a>
@@ -1,8 +1,8 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let ulClass = 'text-gray-600 dark:text-gray-400';
3
3
  </script>
4
4
 
5
- <ul class={classNames(ulClass, $$props.class)}>
5
+ <ul class={twMerge(ulClass, $$props.class)}>
6
6
  <slot />
7
7
  </ul>
8
8
 
@@ -1,4 +1,5 @@
1
- <script>import { getContext } from 'svelte';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
+ import { getContext } from 'svelte';
2
3
  import { labelClass, inputClass } from './Radio.svelte';
3
4
  import Label from './Label.svelte';
4
5
  // properties forwarding
@@ -8,6 +9,7 @@ export let inline = false;
8
9
  export let group = [];
9
10
  export let value = 'on';
10
11
  export let checked = undefined;
12
+ export let spacing = 'mr-2';
11
13
  // tinted if put in component having its own background
12
14
  let background = getContext('background');
13
15
  // react on external group changes
@@ -62,7 +64,9 @@ function onChange() {
62
64
  on:change
63
65
  {value}
64
66
  {...$$restProps}
65
- class={inputClass(custom, color, true, background, $$slots.default || $$props.class)} /><slot />
67
+ class={twMerge(
68
+ spacing,
69
+ inputClass(custom, color, true, background, $$slots.default || $$props.class))} /><slot />
66
70
  </Label>
67
71
 
68
72
  <!--
@@ -9,6 +9,7 @@ declare const __propDef: {
9
9
  group?: (string | number)[] | undefined;
10
10
  value?: string | number | undefined;
11
11
  checked?: boolean | undefined;
12
+ spacing?: string | undefined;
12
13
  };
13
14
  events: {
14
15
  keyup: KeyboardEvent;
@@ -1 +1 @@
1
- {"version":3,"file":"Checkbox.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/forms/Checkbox.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AAED,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AA+D9C,QAAA,MAAM,SAAS;;;;;;;;kBADkO,OAAO,GAAG,SAAS;;;;;;;;;;;;;;;;;;;;CACtL,CAAC;AAC/E,MAAM,MAAM,aAAa,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AACnD,MAAM,MAAM,cAAc,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AACrD,MAAM,MAAM,aAAa,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6CG;AACH,MAAM,CAAC,OAAO,OAAO,QAAS,SAAQ,oBAAoB,CAAC,aAAa,EAAE,cAAc,EAAE,aAAa,CAAC;CACvG"}
1
+ {"version":3,"file":"Checkbox.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/forms/Checkbox.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AAGD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAmE9C,QAAA,MAAM,SAAS;;;;;;;;kBADqP,OAAO,GAAG,SAAS;;;;;;;;;;;;;;;;;;;;;CACzM,CAAC;AAC/E,MAAM,MAAM,aAAa,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AACnD,MAAM,MAAM,cAAc,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AACrD,MAAM,MAAM,aAAa,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6CG;AACH,MAAM,CAAC,OAAO,OAAO,QAAS,SAAQ,oBAAoB,CAAC,aAAa,EAAE,cAAc,EAAE,aAAa,CAAC;CACvG"}
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let value = '';
3
3
  export let files = undefined;
4
4
  export let defaultClass = 'flex flex-col justify-center items-center w-full h-64 bg-gray-50 rounded-lg border-2 border-gray-300 border-dashed cursor-pointer dark:hover:bg-bray-800 dark:bg-gray-700 hover:bg-gray-100 dark:border-gray-600 dark:hover:border-gray-500 dark:hover:bg-gray-600';
@@ -12,7 +12,7 @@ function keydown(ev) {
12
12
  </script>
13
13
 
14
14
  <button
15
- class={classNames(defaultClass, $$props.class)}
15
+ class={twMerge(defaultClass, $$props.class)}
16
16
  on:keydown={keydown}
17
17
  on:focus
18
18
  on:blur
@@ -1,11 +1,11 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  import Input from './Input.svelte';
3
3
  export let value = '';
4
4
  export let files = undefined;
5
5
  export let inputClass = 'border !p-0 dark:text-gray-400';
6
6
  </script>
7
7
 
8
- <Input {...$$restProps} class={classNames(inputClass, $$props.class)} let:props>
8
+ <Input {...$$restProps} class={twMerge(inputClass, $$props.class)} let:props>
9
9
  <input
10
10
  type="file"
11
11
  on:change
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  import generateId from '../utils/generateId.js';
3
3
  export let id = generateId();
4
4
  export let style = 'standard';
@@ -51,12 +51,12 @@ const labelClasses = {
51
51
  standard: 'absolute text-sm duration-300 transform -translate-y-6 scale-75 top-3 -z-10 origin-[0] peer-focus:left-0 peer-placeholder-shown:scale-100 peer-placeholder-shown:translate-y-0 peer-focus:scale-75 peer-focus:-translate-y-6'
52
52
  };
53
53
  const inputColorClasses = {
54
- base: 'border-gray-300 dark:border-gray-600 dark:focus:border-blue-500 focus:border-blue-600',
54
+ base: 'border-gray-300 dark:border-gray-600 dark:focus:border-primary-500 focus:border-primary-600',
55
55
  green: 'border-green-600 dark:border-green-500 dark:focus:border-green-500 focus:border-green-600',
56
56
  red: 'border-red-600 dark:border-red-500 dark:focus:border-red-500 focus:border-red-600'
57
57
  };
58
58
  const labelColorClasses = {
59
- base: 'text-gray-500 dark:text-gray-400 peer-focus:text-blue-600 peer-focus:dark:text-blue-500',
59
+ base: 'text-gray-500 dark:text-gray-400 peer-focus:text-primary-600 peer-focus:dark:text-primary-500',
60
60
  green: 'text-green-600 dark:text-green-500',
61
61
  red: 'text-red-600 dark:text-red-500'
62
62
  };
@@ -90,7 +90,7 @@ function setType(node, _type) {
90
90
  on:paste
91
91
  use:setType={type}
92
92
  placeholder=" "
93
- class={classNames(
93
+ class={twMerge(
94
94
  inputClasses[style],
95
95
  inputColorClasses[color],
96
96
  inputSizes[style][size],
@@ -99,7 +99,7 @@ function setType(node, _type) {
99
99
 
100
100
  <label
101
101
  for={id}
102
- class={classNames(
102
+ class={twMerge(
103
103
  labelClasses[style],
104
104
  labelColorClasses[color],
105
105
  labelSizes[style][size],
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let helperClass = 'text-xs font-normal text-gray-500 dark:text-gray-300';
3
3
  export let color = 'gray';
4
4
  const colorClasses = {
@@ -9,7 +9,7 @@ const colorClasses = {
9
9
  };
10
10
  </script>
11
11
 
12
- <p {...$$restProps} class={classNames(helperClass, colorClasses[color], $$props.class)}>
12
+ <p {...$$restProps} class={twMerge(helperClass, colorClasses[color], $$props.class)}>
13
13
  <slot />
14
14
  </p>
15
15
 
@@ -4,7 +4,7 @@
4
4
  </script>
5
5
 
6
6
  <script>import Wrapper from '../utils/Wrapper.svelte';
7
- import classNames from 'classnames';
7
+ import { twMerge } from 'tailwind-merge';
8
8
  import { getContext } from 'svelte';
9
9
  export let type = 'text';
10
10
  export let value = undefined;
@@ -18,7 +18,7 @@ const borderClasses = {
18
18
  red: 'border-red-500 dark:border-red-400'
19
19
  };
20
20
  const ringClasses = {
21
- base: 'focus:border-blue-500 focus:ring-blue-500 dark:focus:border-blue-500 dark:focus:ring-blue-500',
21
+ base: 'focus:border-primary-500 focus:ring-primary-500 dark:focus:border-primary-500 dark:focus:ring-primary-500',
22
22
  green: 'focus:ring-green-500 focus:border-green-500 dark:focus:border-green-500 dark:focus:ring-green-500',
23
23
  red: 'focus:ring-red-500 focus:border-red-500 dark:focus:ring-red-500 dark:focus:border-red-500'
24
24
  };
@@ -48,7 +48,18 @@ $: _size = size || clampSize(group?.size) || 'md';
48
48
  let inputClass;
49
49
  $: {
50
50
  const _color = color === 'base' && background ? 'tinted' : color;
51
- inputClass = classNames(defaultClass, $$slots.left && leftPadding[_size], $$slots.right && rightPadding[_size], ringClasses[color], colorClasses[_color], borderClasses[_color], inputPadding[_size], textSizes[_size], group || 'rounded-lg', group && 'first:rounded-l-lg last:rounded-r-lg', group && 'border-l-0 first:border-l last:border-r', $$props.class);
51
+ inputClass = twMerge([
52
+ defaultClass,
53
+ ($$slots.left && leftPadding[_size] || $$slots.right && rightPadding[_size]) || inputPadding[_size],
54
+ ringClasses[color],
55
+ colorClasses[_color],
56
+ borderClasses[_color],
57
+ textSizes[_size],
58
+ group || 'rounded-lg',
59
+ group && 'first:rounded-l-lg last:rounded-r-lg',
60
+ group && 'border-l-0 first:border-l last:border-r',
61
+ $$props.class
62
+ ]);
52
63
  }
53
64
  let floatClass = 'flex absolute inset-y-0 items-center text-gray-500 dark:text-gray-400';
54
65
  </script>
@@ -1 +1 @@
1
- {"version":3,"file":"Input.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/forms/Input.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AACC,OAAO,KAAK,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AACzD,wBAAgB,SAAS,CAAC,CAAC,EAAE,QAAQ,sBAEpC;AAMH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAgG1C,QAAA,MAAM,SAAS;;;;gBADoH,GAAG;eAAS,YAAY,GAAG,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACzF,CAAC;AAC/E,MAAM,MAAM,UAAU,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAChD,MAAM,MAAM,WAAW,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AAClD,MAAM,MAAM,UAAU,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEhD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwDG;AACH,MAAM,CAAC,OAAO,OAAO,KAAM,SAAQ,oBAAoB,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC;CAC3F"}
1
+ {"version":3,"file":"Input.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/forms/Input.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AACC,OAAO,KAAK,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AACzD,wBAAgB,SAAS,CAAC,CAAC,EAAE,QAAQ,sBAEpC;AAMH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AA8F1C,QAAA,MAAM,SAAS;;;;gBADoH,GAAG;eAAS,YAAY,GAAG,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACzF,CAAC;AAC/E,MAAM,MAAM,UAAU,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAChD,MAAM,MAAM,WAAW,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AAClD,MAAM,MAAM,UAAU,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEhD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwDG;AACH,MAAM,CAAC,OAAO,OAAO,KAAM,SAAQ,oBAAoB,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC;CAC3F"}
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  import { getContext } from 'svelte';
3
3
  import { clampSize } from './Input.svelte';
4
4
  export let size = undefined;
@@ -21,7 +21,7 @@ const textSizes = { sm: 'sm:text-xs', md: 'text-sm', lg: 'sm:text-base' };
21
21
  const prefixPadding = { sm: 'px-2', md: 'px-3', lg: 'px-4' };
22
22
  // size: explicit, inherited, default
23
23
  $: _size = size || clampSize(group?.size) || 'md';
24
- $: divClass = classNames(textSizes[_size], prefixPadding[_size], background ? borderClasses['tinted'] : borderClasses['base'], 'text-gray-500 bg-gray-200', background ? darkBgClasses.tinted : darkBgClasses.base, background ? divider.tinted : divider.base, 'inline-flex items-center border-t border-b first:border-l border-r', 'first:rounded-l-lg last:rounded-r-lg', $$props.class);
24
+ $: divClass = twMerge(textSizes[_size], prefixPadding[_size], background ? borderClasses['tinted'] : borderClasses['base'], 'text-gray-500 bg-gray-200', background ? darkBgClasses.tinted : darkBgClasses.base, background ? divider.tinted : divider.base, 'inline-flex items-center border-t border-b first:border-l border-r', 'first:rounded-l-lg last:rounded-r-lg', $$props.class);
25
25
  </script>
26
26
 
27
27
  <div {...$$restProps} class={divClass}>
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let color = 'gray';
3
3
  export let defaultClass = 'text-sm font-medium block';
4
4
  export let show = true;
@@ -14,7 +14,7 @@ $: {
14
14
  const control = node?.control;
15
15
  color = control?.disabled ? 'disabled' : color;
16
16
  }
17
- $: labelClass = classNames(defaultClass, colorClasses[color], $$props.class);
17
+ $: labelClass = twMerge(defaultClass, colorClasses[color], $$props.class);
18
18
  </script>
19
19
 
20
20
  {#if show}
@@ -0,0 +1,131 @@
1
+ <script>export let items = [];
2
+ export let value = [];
3
+ export let highlighted = false;
4
+ export let defaultClass = '';
5
+ let show = false;
6
+ // Container
7
+ const multiSelectClass = 'relative !min-h-[55px] p-2 text-gray-900 bg-gray-50 border border-gray-300 flex items-center rounded-lg gap-2 dark:bg-gray-700 dark:border-gray-600 dark:text-white focus:border-2 dark:focus:border-2 focus:border-primary-500 focus:ring-primary-500 dark:focus:border-primary-500 dark:focus:ring-primary-500';
8
+ // Pills Button
9
+ const multiSelectBtn = 'flex items-center gap-1 rounded-lg border overflow-hidden border-gray-300 dark:border-gray-500';
10
+ // Dropdown
11
+ const multiSelectDropdown = 'absolute h-32 border border-gray-300 dark:bg-gray-700 dark:border-gray-600 dark:text-white left-0 top-[calc(100%+1rem)] rounded-lg bg-gray-50 cursor-pointer overflow-y-scroll w-full';
12
+ // Items
13
+ const itemsClass = 'p-1 pl-2 pr-2 hover:bg-gray-100 dark:hover:bg-gray-600';
14
+ // Selected items
15
+ const itemsSelectClass = 'bg-primary-500 text-white hover:bg-primary-600';
16
+ const selectOption = (select) => {
17
+ if (value.includes(select)) {
18
+ // todo
19
+ }
20
+ else {
21
+ value.push(select);
22
+ value = value;
23
+ }
24
+ };
25
+ const clearAll = () => {
26
+ value = [];
27
+ };
28
+ const clearThisOption = (select) => {
29
+ if (value.includes(select)) {
30
+ value = value.filter((o) => o !== select);
31
+ }
32
+ };
33
+ </script>
34
+
35
+ <!-- svelte-ignore a11y-click-events-have-key-events -->
36
+ <div
37
+ on:click={() => (show = !show)}
38
+ on:blur={() => (show = !show)}
39
+ tabindex="-1"
40
+ class="{multiSelectClass} {defaultClass}">
41
+ <span class="flex gap-2 flex-wrap">
42
+ {#if value.length}
43
+ {#each value as select, index}
44
+ <button class={multiSelectBtn}>
45
+ <span class="p-[1px] ml-[1.5px]">{select.name}</span>
46
+ <svg
47
+ on:click={(e) => {
48
+ e.stopPropagation();
49
+ clearThisOption(select);
50
+ }}
51
+ class="w-4 h-full pr-[1.5px] hover:bg-primary-500"
52
+ fill="currentColor"
53
+ viewBox="0 0 20 20"
54
+ xmlns="http://www.w3.org/2000/svg"
55
+ ><path
56
+ fill-rule="evenodd"
57
+ d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z"
58
+ clip-rule="evenodd" /></svg>
59
+ </button>
60
+ {/each}
61
+ {/if}
62
+ </span>
63
+ <div class="flex ml-auto gap-2">
64
+ <button
65
+ on:click={(e) => {
66
+ e.stopPropagation();
67
+ clearAll();
68
+ }}>
69
+ <svg class="w-5 h-5" fill="currentColor" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"
70
+ ><path
71
+ fill-rule="evenodd"
72
+ d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z"
73
+ clip-rule="evenodd" /></svg>
74
+ </button>
75
+ <div class="w-[1px] bg-gray-300" />
76
+ <button>
77
+ <svg
78
+ xmlns="http://www.w3.org/2000/svg"
79
+ width="20"
80
+ height="20"
81
+ class="h-4 w-4 mb-1 mr-1 cursor-pointer"
82
+ aria-label="chevron down"
83
+ fill="none"
84
+ viewBox="0 0 20 20"
85
+ role="img"
86
+ stroke-width="2"
87
+ ><path
88
+ stroke-linecap="round"
89
+ stroke-linejoin="round"
90
+ d="M19 9l-7 7-7-7"
91
+ stroke="currentColor" /></svg>
92
+ </button>
93
+ </div>
94
+
95
+ {#if show}
96
+ <div class={multiSelectDropdown}>
97
+ {#each items as item, index}
98
+ <!-- svelte-ignore a11y-click-events-have-key-events -->
99
+ <div
100
+ on:click={(e) => {
101
+ e.stopPropagation();
102
+ selectOption(item);
103
+ }}
104
+ class="{itemsClass} {value.includes(item) && highlighted ? itemsSelectClass : ''}">
105
+ {item.name}
106
+ </div>
107
+ {/each}
108
+ </div>
109
+ {/if}
110
+ </div>
111
+
112
+ <!--
113
+ @component
114
+ ## Example
115
+ ```
116
+ <script>
117
+ import MultiSelect from '../../../lib/forms/MultiSelect.svelte';
118
+
119
+ let selected = [];
120
+ let countries = [
121
+ {value:"us", name: "United States"},
122
+ {value:"ca", name: "Canada"},
123
+ {value:"fr", name: "France"},
124
+ {value:"jp", name: "Japan"},
125
+ {value:"en", name: "England"},
126
+ ]
127
+ </script>
128
+
129
+ <MultiSelect items={countries} bind:value={selected} />
130
+ ```
131
+ -->
@@ -0,0 +1,40 @@
1
+ import { SvelteComponentTyped } from "svelte";
2
+ import type { SelectOptionType } from '../types';
3
+ declare const __propDef: {
4
+ props: {
5
+ items?: SelectOptionType[] | undefined;
6
+ value?: SelectOptionType[] | undefined;
7
+ highlighted?: boolean | undefined;
8
+ defaultClass?: string | undefined;
9
+ };
10
+ events: {
11
+ [evt: string]: CustomEvent<any>;
12
+ };
13
+ slots: {};
14
+ };
15
+ export type MultiSelectProps = typeof __propDef.props;
16
+ export type MultiSelectEvents = typeof __propDef.events;
17
+ export type MultiSelectSlots = typeof __propDef.slots;
18
+ /**
19
+ * ## Example
20
+ * ```
21
+ * <script>
22
+ * import MultiSelect from '../../../lib/forms/MultiSelect.svelte';
23
+ *
24
+ * let selected = [];
25
+ * let countries = [
26
+ * {value:"us", name: "United States"},
27
+ * {value:"ca", name: "Canada"},
28
+ * {value:"fr", name: "France"},
29
+ * {value:"jp", name: "Japan"},
30
+ * {value:"en", name: "England"},
31
+ * ]
32
+ * </script>
33
+ *
34
+ * <MultiSelect items={countries} bind:value={selected} />
35
+ * ```
36
+ */
37
+ export default class MultiSelect extends SvelteComponentTyped<MultiSelectProps, MultiSelectEvents, MultiSelectSlots> {
38
+ }
39
+ export {};
40
+ //# sourceMappingURL=MultiSelect.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MultiSelect.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/forms/MultiSelect.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AACD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AA6FjD,QAAA,MAAM,SAAS;;;;;;;;;;;CAAwC,CAAC;AACxD,MAAM,MAAM,gBAAgB,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AACtD,MAAM,MAAM,iBAAiB,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AACxD,MAAM,MAAM,gBAAgB,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEtD;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,CAAC,OAAO,OAAO,WAAY,SAAQ,oBAAoB,CAAC,gBAAgB,EAAE,iBAAiB,EAAE,gBAAgB,CAAC;CACnH"}
@@ -1,5 +1,5 @@
1
1
  <script context="module">// this part is shared between Radio and Checkbox
2
- import classNames from 'classnames';
2
+ import { twMerge } from 'tailwind-merge';
3
3
  const colorClasses = {
4
4
  primary: 'text-primary-600 focus:ring-primary-500 dark:focus:ring-primary-600',
5
5
  secondary: 'text-secondary-600 focus:ring-secondary-500 dark:focus:ring-secondary-600',
@@ -11,8 +11,9 @@ const colorClasses = {
11
11
  orange: 'text-orange-500 focus:ring-orange-500 dark:focus:ring-orange-600',
12
12
  blue: 'text-blue-600 focus:ring-blue-500 dark:focus:ring-blue-600'
13
13
  };
14
- export const labelClass = (inline, extraClass) => classNames(inline ? 'inline-flex' : 'flex', 'items-center', extraClass);
15
- export const inputClass = (custom, color, rounded, tinted, extraClass) => classNames('w-4 h-4 bg-gray-100 border-gray-300 dark:ring-offset-gray-800 focus:ring-2', extraClass === true && 'mr-2', tinted ? 'dark:bg-gray-600 dark:border-gray-500' : 'dark:bg-gray-700 dark:border-gray-600', custom && 'sr-only peer', rounded && 'rounded', colorClasses[color], extraClass);
14
+ export const labelClass = (inline, extraClass) => twMerge(inline ? 'inline-flex' : 'flex', 'items-center', extraClass);
15
+ export let spacing = 'mr-2';
16
+ export const inputClass = (custom, color, rounded, tinted, extraClass) => twMerge('w-4 h-4 bg-gray-100 border-gray-300 dark:ring-offset-gray-800 focus:ring-2', spacing, tinted ? 'dark:bg-gray-600 dark:border-gray-500' : 'dark:bg-gray-700 dark:border-gray-600', custom && 'sr-only peer', rounded && 'rounded', colorClasses[color], extraClass);
16
17
  </script>
17
18
 
18
19
  <script>import { getContext } from 'svelte';
@@ -1,6 +1,7 @@
1
1
  import { SvelteComponentTyped } from "svelte";
2
2
  export declare const labelClass: (inline: boolean, extraClass: string) => string;
3
- export declare const inputClass: (custom: boolean, color: FormColorType, rounded: boolean, tinted: boolean, extraClass: string | boolean) => string;
3
+ export declare let spacing: string;
4
+ export declare const inputClass: (custom: boolean, color: FormColorType, rounded: boolean, tinted: boolean, extraClass: string) => string;
4
5
  import type { FormColorType } from '../types';
5
6
  declare const __propDef: {
6
7
  props: {
@@ -1 +1 @@
1
- {"version":3,"file":"Radio.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/forms/Radio.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AAgBC,eAAO,MAAM,UAAU,WAAY,OAAO,cAAc,MAAM,WACW,CAAC;AAE1E,eAAO,MAAM,UAAU,WACb,OAAO,SACR,aAAa,WACX,OAAO,UACR,OAAO,cACH,MAAM,GAAG,OAAO,WAU3B,CAAC;AAIN,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AA4B9C,QAAA,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;CAA+D,CAAC;AAC/E,MAAM,MAAM,UAAU,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAChD,MAAM,MAAM,WAAW,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AAClD,MAAM,MAAM,UAAU,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEhD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,MAAM,CAAC,OAAO,OAAO,KAAM,SAAQ,oBAAoB,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC;CAC3F"}
1
+ {"version":3,"file":"Radio.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/forms/Radio.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AAgBC,eAAO,MAAM,UAAU,WAAY,OAAO,cAAc,MAAM,WACM,CAAC;AACrE,eAAO,IAAI,OAAO,EAAE,MAAe,CAAC;AAEpC,eAAO,MAAM,UAAU,WACb,OAAO,SACR,aAAa,WACX,OAAO,UACR,OAAO,cACH,MAAM,WAUjB,CAAC;AAIN,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AA4B9C,QAAA,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;CAA+D,CAAC;AAC/E,MAAM,MAAM,UAAU,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAChD,MAAM,MAAM,WAAW,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AAClD,MAAM,MAAM,UAAU,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAEhD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,MAAM,CAAC,OAAO,OAAO,KAAM,SAAQ,oBAAoB,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC;CAC3F"}
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let value;
3
3
  export let size = 'md';
4
4
  const sizes = {
@@ -7,7 +7,7 @@ const sizes = {
7
7
  lg: 'h-3 range-lg'
8
8
  };
9
9
  let inputClass;
10
- $: inputClass = classNames('w-full bg-gray-200 rounded-lg appearance-none cursor-pointer dark:bg-gray-700', sizes[size] ?? sizes.md, $$props.class);
10
+ $: inputClass = twMerge('w-full bg-gray-200 rounded-lg appearance-none cursor-pointer dark:bg-gray-700', sizes[size] ?? sizes.md, $$props.class);
11
11
  </script>
12
12
 
13
13
  <input
@@ -1,4 +1,4 @@
1
- <script>import classNames from 'classnames';
1
+ <script>import { twMerge } from 'tailwind-merge';
2
2
  export let items = [];
3
3
  export let value = undefined;
4
4
  export let placeholder = 'Choose option ...';
@@ -13,7 +13,7 @@ const sizes = {
13
13
  lg: 'text-base py-3 px-4'
14
14
  };
15
15
  let selectClass;
16
- $: selectClass = classNames(common, underline ? underlineClass : defaultClass, sizes[size], underline && '!px-0', $$restProps.class);
16
+ $: selectClass = twMerge(common, underline ? underlineClass : defaultClass, sizes[size], underline && '!px-0', $$restProps.class);
17
17
  </script>
18
18
 
19
19
  <select {...$$restProps} bind:value class={selectClass} on:change on:contextmenu on:input>