@cloudparker/moldex.js 4.1.7 → 4.1.9

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 (222) hide show
  1. package/dist/actions/badge.d.ts +12 -0
  2. package/dist/actions/badge.js +22 -0
  3. package/dist/actions/index.d.ts +3 -0
  4. package/dist/actions/index.js +3 -0
  5. package/dist/actions/no-context-menu.d.ts +3 -0
  6. package/dist/actions/no-context-menu.js +11 -0
  7. package/dist/actions/ripple.css +29 -0
  8. package/dist/actions/ripple.d.ts +7 -0
  9. package/dist/actions/ripple.js +74 -0
  10. package/dist/index.d.ts +4 -0
  11. package/dist/index.js +4 -0
  12. package/dist/services/date/date-service.d.ts +52 -0
  13. package/dist/services/date/date-service.js +206 -0
  14. package/dist/services/dialog/dialog-service.d.ts +96 -0
  15. package/dist/services/dialog/dialog-service.js +350 -0
  16. package/dist/services/index.d.ts +12 -0
  17. package/dist/services/index.js +12 -0
  18. package/dist/services/navigation/navigation-service.d.ts +39 -0
  19. package/dist/services/navigation/navigation-service.js +100 -0
  20. package/dist/services/screen/screen-service.d.ts +17 -0
  21. package/dist/services/screen/screen-service.js +40 -0
  22. package/dist/services/toast/toast-service.d.ts +5 -0
  23. package/dist/services/toast/toast-service.js +26 -0
  24. package/dist/services/utils/color-service.d.ts +46 -0
  25. package/dist/services/utils/color-service.js +73 -0
  26. package/dist/services/utils/currency-service.d.ts +91 -0
  27. package/dist/services/utils/currency-service.js +140 -0
  28. package/dist/services/utils/download-service.d.ts +91 -0
  29. package/dist/services/utils/download-service.js +159 -0
  30. package/dist/services/utils/file-service.d.ts +140 -0
  31. package/dist/services/utils/file-service.js +301 -0
  32. package/dist/services/utils/http-service.d.ts +77 -0
  33. package/dist/services/utils/http-service.js +158 -0
  34. package/dist/services/utils/image-service.d.ts +107 -0
  35. package/dist/services/utils/image-service.js +260 -0
  36. package/dist/services/utils/melody-service.d.ts +5 -0
  37. package/dist/services/utils/melody-service.js +41 -0
  38. package/dist/services/utils/utils-service.d.ts +260 -0
  39. package/dist/services/utils/utils-service.js +413 -0
  40. package/dist/stores/referrer-store/referrer-store.svelte.d.ts +3 -0
  41. package/dist/stores/referrer-store/referrer-store.svelte.js +11 -0
  42. package/dist/stores/screen-size/screen-size-store.svelte.d.ts +11 -0
  43. package/dist/stores/screen-size/screen-size-store.svelte.js +33 -0
  44. package/dist/types.d.ts +14 -0
  45. package/dist/types.js +16 -0
  46. package/dist/views/core/button/components/button/button.svelte +161 -0
  47. package/dist/views/core/button/components/button/button.svelte.d.ts +4 -0
  48. package/dist/views/core/button/components/button-back/button-back.svelte +46 -0
  49. package/dist/views/core/button/components/button-back/button-back.svelte.d.ts +11 -0
  50. package/dist/views/core/button/components/button-close/button-close.svelte +8 -0
  51. package/dist/views/core/button/components/button-close/button-close.svelte.d.ts +4 -0
  52. package/dist/views/core/button/components/button-close-icon/button-close-icon.svelte +47 -0
  53. package/dist/views/core/button/components/button-close-icon/button-close-icon.svelte.d.ts +11 -0
  54. package/dist/views/core/button/components/button-dropdown/button-dropdown.svelte +149 -0
  55. package/dist/views/core/button/components/button-dropdown/button-dropdown.svelte.d.ts +24 -0
  56. package/dist/views/core/button/components/button-list-item/button-list-item.svelte +136 -0
  57. package/dist/views/core/button/components/button-list-item/button-list-item.svelte.d.ts +4 -0
  58. package/dist/views/core/button/components/button-menu/button-menu.svelte +105 -0
  59. package/dist/views/core/button/components/button-menu/button-menu.svelte.d.ts +21 -0
  60. package/dist/views/core/button/components/button-ok/button-ok.svelte +9 -0
  61. package/dist/views/core/button/components/button-ok/button-ok.svelte.d.ts +4 -0
  62. package/dist/views/core/button/components/button-search/button-search.svelte +72 -0
  63. package/dist/views/core/button/components/button-search/button-search.svelte.d.ts +21 -0
  64. package/dist/views/core/button/components/switch/switch.svelte +62 -0
  65. package/dist/views/core/button/components/switch/switch.svelte.d.ts +4 -0
  66. package/dist/views/core/button/index.d.ts +12 -0
  67. package/dist/views/core/button/index.js +12 -0
  68. package/dist/views/core/button/types.d.ts +100 -0
  69. package/dist/views/core/button/types.js +1 -0
  70. package/dist/views/core/common/components/content-area/content-area.svelte +47 -0
  71. package/dist/views/core/common/components/content-area/content-area.svelte.d.ts +12 -0
  72. package/dist/views/core/common/components/loading/loading.svelte +14 -0
  73. package/dist/views/core/common/components/loading/loading.svelte.d.ts +7 -0
  74. package/dist/views/core/common/components/virtual-scrolling/virtual-scrolling-list.svelte +60 -0
  75. package/dist/views/core/common/components/virtual-scrolling/virtual-scrolling-list.svelte.d.ts +11 -0
  76. package/dist/views/core/common/index.d.ts +4 -0
  77. package/dist/views/core/common/index.js +4 -0
  78. package/dist/views/core/dialog/components/cropper-dialog/cropper-dialog.svelte +51 -0
  79. package/dist/views/core/dialog/components/cropper-dialog/cropper-dialog.svelte.d.ts +5 -0
  80. package/dist/views/core/dialog/components/dialog/dialog.svelte +370 -0
  81. package/dist/views/core/dialog/components/dialog/dialog.svelte.d.ts +19 -0
  82. package/dist/views/core/dialog/components/loading-dialog/loading-dialog.svelte +42 -0
  83. package/dist/views/core/dialog/components/loading-dialog/loading-dialog.svelte.d.ts +12 -0
  84. package/dist/views/core/dialog/components/msg-dialog/msg-dialog.svelte +22 -0
  85. package/dist/views/core/dialog/components/msg-dialog/msg-dialog.svelte.d.ts +9 -0
  86. package/dist/views/core/dialog/components/number-field-dialog/number-field-dialog.svelte +57 -0
  87. package/dist/views/core/dialog/components/number-field-dialog/number-field-dialog.svelte.d.ts +14 -0
  88. package/dist/views/core/dialog/components/picker-dialog/picker-dialog.svelte +181 -0
  89. package/dist/views/core/dialog/components/picker-dialog/picker-dialog.svelte.d.ts +5 -0
  90. package/dist/views/core/dialog/components/text-field-dialog/text-field-dialog.svelte +56 -0
  91. package/dist/views/core/dialog/components/text-field-dialog/text-field-dialog.svelte.d.ts +15 -0
  92. package/dist/views/core/dialog/components/textarea-field-dialog/textarea-field-dialog.svelte +56 -0
  93. package/dist/views/core/dialog/components/textarea-field-dialog/textarea-field-dialog.svelte.d.ts +15 -0
  94. package/dist/views/core/dialog/index.d.ts +9 -0
  95. package/dist/views/core/dialog/index.js +9 -0
  96. package/dist/views/core/dialog/types.d.ts +105 -0
  97. package/dist/views/core/dialog/types.js +1 -0
  98. package/dist/views/core/drawer/components/drawer/drawer.svelte +110 -0
  99. package/dist/views/core/drawer/components/drawer/drawer.svelte.d.ts +19 -0
  100. package/dist/views/core/drawer/index.d.ts +2 -0
  101. package/dist/views/core/drawer/index.js +2 -0
  102. package/dist/views/core/icon/components/icon/icon.svelte +27 -0
  103. package/dist/views/core/icon/components/icon/icon.svelte.d.ts +12 -0
  104. package/dist/views/core/icon/components/icon-circle/icon-circle.svelte +17 -0
  105. package/dist/views/core/icon/components/icon-circle/icon-circle.svelte.d.ts +8 -0
  106. package/dist/views/core/icon/index.d.ts +4 -0
  107. package/dist/views/core/icon/index.js +4 -0
  108. package/dist/views/core/icon/services/icon-path-service.d.ts +23 -0
  109. package/dist/views/core/icon/services/icon-path-service.js +24 -0
  110. package/dist/views/core/index.d.ts +16 -0
  111. package/dist/views/core/index.js +16 -0
  112. package/dist/views/core/input/components/checkbox-field/checkbox-field.svelte +83 -0
  113. package/dist/views/core/input/components/checkbox-field/checkbox-field.svelte.d.ts +19 -0
  114. package/dist/views/core/input/components/color-field/color-field.svelte +135 -0
  115. package/dist/views/core/input/components/color-field/color-field.svelte.d.ts +11 -0
  116. package/dist/views/core/input/components/combobox-field/combobox-field.svelte +492 -0
  117. package/dist/views/core/input/components/combobox-field/combobox-field.svelte.d.ts +7 -0
  118. package/dist/views/core/input/components/date-field/date-field.svelte +40 -0
  119. package/dist/views/core/input/components/date-field/date-field.svelte.d.ts +11 -0
  120. package/dist/views/core/input/components/datetime-field/datetime-field.svelte +22 -0
  121. package/dist/views/core/input/components/datetime-field/datetime-field.svelte.d.ts +8 -0
  122. package/dist/views/core/input/components/email-field/email-field.svelte +27 -0
  123. package/dist/views/core/input/components/email-field/email-field.svelte.d.ts +8 -0
  124. package/dist/views/core/input/components/file-field/file-field.svelte +106 -0
  125. package/dist/views/core/input/components/file-field/file-field.svelte.d.ts +13 -0
  126. package/dist/views/core/input/components/input-field/input-field.svelte +336 -0
  127. package/dist/views/core/input/components/input-field/input-field.svelte.d.ts +9 -0
  128. package/dist/views/core/input/components/label/label.svelte +48 -0
  129. package/dist/views/core/input/components/label/label.svelte.d.ts +14 -0
  130. package/dist/views/core/input/components/number-field/number-field.svelte +22 -0
  131. package/dist/views/core/input/components/number-field/number-field.svelte.d.ts +8 -0
  132. package/dist/views/core/input/components/password-field/password-field.svelte +100 -0
  133. package/dist/views/core/input/components/password-field/password-field.svelte.d.ts +12 -0
  134. package/dist/views/core/input/components/phone-field/phone-field.svelte +187 -0
  135. package/dist/views/core/input/components/phone-field/phone-field.svelte.d.ts +12 -0
  136. package/dist/views/core/input/components/radio-field/radio-field.svelte +127 -0
  137. package/dist/views/core/input/components/radio-field/radio-field.svelte.d.ts +4 -0
  138. package/dist/views/core/input/components/range-field/range-field.svelte +120 -0
  139. package/dist/views/core/input/components/range-field/range-field.svelte.d.ts +23 -0
  140. package/dist/views/core/input/components/search-field/search-field.svelte +80 -0
  141. package/dist/views/core/input/components/search-field/search-field.svelte.d.ts +12 -0
  142. package/dist/views/core/input/components/text-field/text-field.svelte +31 -0
  143. package/dist/views/core/input/components/text-field/text-field.svelte.d.ts +11 -0
  144. package/dist/views/core/input/components/textarea-field/textarea-field.svelte +27 -0
  145. package/dist/views/core/input/components/textarea-field/textarea-field.svelte.d.ts +8 -0
  146. package/dist/views/core/input/components/time-field/time-field.svelte +21 -0
  147. package/dist/views/core/input/components/time-field/time-field.svelte.d.ts +8 -0
  148. package/dist/views/core/input/index.d.ts +20 -0
  149. package/dist/views/core/input/index.js +20 -0
  150. package/dist/views/core/input/types.d.ts +159 -0
  151. package/dist/views/core/input/types.js +1 -0
  152. package/dist/views/core/navbar/components/navbar/navbar.svelte +133 -0
  153. package/dist/views/core/navbar/components/navbar/navbar.svelte.d.ts +4 -0
  154. package/dist/views/core/navbar/index.d.ts +3 -0
  155. package/dist/views/core/navbar/index.js +3 -0
  156. package/dist/views/core/navbar/types.d.ts +35 -0
  157. package/dist/views/core/navbar/types.js +1 -0
  158. package/dist/views/core/no-data/components/no-data/no-data.svelte +47 -0
  159. package/dist/views/core/no-data/components/no-data/no-data.svelte.d.ts +13 -0
  160. package/dist/views/core/no-data/index.d.ts +2 -0
  161. package/dist/views/core/no-data/index.js +2 -0
  162. package/dist/views/core/pagination/components/pagination/pagination.svelte +151 -0
  163. package/dist/views/core/pagination/components/pagination/pagination.svelte.d.ts +16 -0
  164. package/dist/views/core/pagination/index.d.ts +2 -0
  165. package/dist/views/core/pagination/index.js +2 -0
  166. package/dist/views/core/progressbar/components/progressbar/progressbar.svelte +55 -0
  167. package/dist/views/core/progressbar/components/progressbar/progressbar.svelte.d.ts +11 -0
  168. package/dist/views/core/progressbar/index.d.ts +2 -0
  169. package/dist/views/core/progressbar/index.js +2 -0
  170. package/dist/views/core/ruler/components/vertical-ruler/verticcal-ruler.svelte +8 -0
  171. package/dist/views/core/ruler/components/vertical-ruler/verticcal-ruler.svelte.d.ts +6 -0
  172. package/dist/views/core/ruler/index.d.ts +2 -0
  173. package/dist/views/core/ruler/index.js +2 -0
  174. package/dist/views/core/screen-detector/components/screen-detector.svelte +17 -0
  175. package/dist/views/core/screen-detector/components/screen-detector.svelte.d.ts +3 -0
  176. package/dist/views/core/screen-detector/index.d.ts +2 -0
  177. package/dist/views/core/screen-detector/index.js +2 -0
  178. package/dist/views/core/sidebar/components/sidebar.svelte +49 -0
  179. package/dist/views/core/sidebar/components/sidebar.svelte.d.ts +12 -0
  180. package/dist/views/core/sidebar/index.d.ts +2 -0
  181. package/dist/views/core/sidebar/index.js +2 -0
  182. package/dist/views/core/spinner/components/spinner/spinner.svelte +21 -0
  183. package/dist/views/core/spinner/components/spinner/spinner.svelte.d.ts +6 -0
  184. package/dist/views/core/spinner/index.d.ts +2 -0
  185. package/dist/views/core/spinner/index.js +2 -0
  186. package/dist/views/core/text/components/text-await/text-await.svelte +23 -0
  187. package/dist/views/core/text/components/text-await/text-await.svelte.d.ts +10 -0
  188. package/dist/views/core/text/components/text-copy/text-copy.svelte +40 -0
  189. package/dist/views/core/text/components/text-copy/text-copy.svelte.d.ts +10 -0
  190. package/dist/views/core/text/components/text-currency/text-currency.svelte +24 -0
  191. package/dist/views/core/text/components/text-currency/text-currency.svelte.d.ts +11 -0
  192. package/dist/views/core/text/components/text-date/text-date.svelte +40 -0
  193. package/dist/views/core/text/components/text-date/text-date.svelte.d.ts +10 -0
  194. package/dist/views/core/text/components/text-email/text-email.svelte +22 -0
  195. package/dist/views/core/text/components/text-email/text-email.svelte.d.ts +9 -0
  196. package/dist/views/core/text/components/text-html/text-html.svelte +7 -0
  197. package/dist/views/core/text/components/text-html/text-html.svelte.d.ts +6 -0
  198. package/dist/views/core/text/components/text-phone/text-phone.svelte +25 -0
  199. package/dist/views/core/text/components/text-phone/text-phone.svelte.d.ts +9 -0
  200. package/dist/views/core/text/index.d.ts +8 -0
  201. package/dist/views/core/text/index.js +8 -0
  202. package/dist/views/core/toast/components/toast/toast.svelte +46 -0
  203. package/dist/views/core/toast/components/toast/toast.svelte.d.ts +7 -0
  204. package/dist/views/core/toast/index.d.ts +3 -0
  205. package/dist/views/core/toast/index.js +3 -0
  206. package/dist/views/core/toast/types.d.ts +8 -0
  207. package/dist/views/core/toast/types.js +1 -0
  208. package/dist/views/extra/fields/country-combobox-field.svelte +42 -0
  209. package/dist/views/extra/fields/country-combobox-field.svelte.d.ts +8 -0
  210. package/dist/views/extra/index.d.ts +6 -0
  211. package/dist/views/extra/index.js +6 -0
  212. package/dist/views/extra/loaders/country-loader.svelte +38 -0
  213. package/dist/views/extra/loaders/country-loader.svelte.d.ts +12 -0
  214. package/dist/views/extra/texts/text-country-state.svelte +48 -0
  215. package/dist/views/extra/texts/text-country-state.svelte.d.ts +6 -0
  216. package/dist/views/extra/texts/text-country.svelte +22 -0
  217. package/dist/views/extra/texts/text-country.svelte.d.ts +6 -0
  218. package/dist/views/extra/types.d.ts +5 -0
  219. package/dist/views/extra/types.js +1 -0
  220. package/dist/views/index.d.ts +2 -0
  221. package/dist/views/index.js +2 -0
  222. package/package.json +2 -1
@@ -0,0 +1,46 @@
1
+ <script lang="ts">
2
+ import { isSmallScreen } from '../../../../../services/index.js';
3
+ import { mdiArrowLeft } from '../../../icon/index.js';
4
+
5
+ import Button from '../button/button.svelte';
6
+
7
+ type PropsType = {
8
+ id?: string;
9
+ iconPath?: string;
10
+ iconClassName?: string;
11
+ className?: string;
12
+ onlyMobile?: boolean;
13
+ onClick?: (ev: MouseEvent) => void;
14
+ };
15
+
16
+ let {
17
+ id,
18
+ iconPath = mdiArrowLeft,
19
+ iconClassName = '',
20
+ className = '',
21
+ onlyMobile,
22
+ onClick
23
+ }: PropsType = $props();
24
+
25
+ let isMobileScreen = $derived(isSmallScreen() || false);
26
+ </script>
27
+
28
+ {#snippet button()}
29
+ <Button
30
+ {id}
31
+ appearance="none"
32
+ size="none"
33
+ {iconPath}
34
+ className="w-12 h-12 rounded-full hover:bg-neutral-50 dark:hover:bg-neutral-900 {className}"
35
+ {iconClassName}
36
+ {onClick}
37
+ />
38
+ {/snippet}
39
+
40
+ {#if onlyMobile}
41
+ {#if isMobileScreen}
42
+ {@render button()}
43
+ {/if}
44
+ {:else}
45
+ {@render button()}
46
+ {/if}
@@ -0,0 +1,11 @@
1
+ type PropsType = {
2
+ id?: string;
3
+ iconPath?: string;
4
+ iconClassName?: string;
5
+ className?: string;
6
+ onlyMobile?: boolean;
7
+ onClick?: (ev: MouseEvent) => void;
8
+ };
9
+ declare const ButtonBack: import("svelte").Component<PropsType, {}, "">;
10
+ type ButtonBack = ReturnType<typeof ButtonBack>;
11
+ export default ButtonBack;
@@ -0,0 +1,8 @@
1
+ <script lang="ts">
2
+ import type { ButtonProps } from '../../types';
3
+ import Button from '../button/button.svelte';
4
+
5
+ let { className, ...props }: ButtonProps = $props();
6
+ </script>
7
+
8
+ <Button {...props} size="none" className="bg-gray-100 focus:bg-gray-200 p-2 px-4 {className}" />
@@ -0,0 +1,4 @@
1
+ import type { ButtonProps } from '../../types';
2
+ declare const ButtonClose: import("svelte").Component<ButtonProps, {}, "">;
3
+ type ButtonClose = ReturnType<typeof ButtonClose>;
4
+ export default ButtonClose;
@@ -0,0 +1,47 @@
1
+ <script lang="ts">
2
+ import { isSmallScreen } from '../../../../../services/index.js';
3
+ import { mdiClose } from '../../../icon/index.js';
4
+
5
+
6
+ import Button from '../button/button.svelte';
7
+
8
+ type PropsType = {
9
+ id?: string;
10
+ iconPath?: string;
11
+ iconClassName?: string;
12
+ className?: string;
13
+ onlyWeb?: boolean;
14
+
15
+ onClick?: (ev: MouseEvent) => void;
16
+ };
17
+
18
+ let {
19
+ id,
20
+ iconPath = mdiClose,
21
+ iconClassName = '',
22
+ className = '',
23
+ onlyWeb,
24
+ onClick
25
+ }: PropsType = $props();
26
+
27
+ let isMobileScreen = $state(isSmallScreen() || false);
28
+
29
+ </script>
30
+
31
+ {#snippet button()}
32
+ <Button
33
+ {id}
34
+ {iconPath}
35
+ className="w-12 h-12 rounded-full text-neutral-500 hover:text-neutral-600 hover:bg-neutral-50 dark:hover:bg-neutral-900 transition-all {className}"
36
+ {iconClassName}
37
+ {onClick}
38
+ />
39
+ {/snippet}
40
+
41
+ {#if onlyWeb}
42
+ {#if !isMobileScreen}
43
+ {@render button()}
44
+ {/if}
45
+ {:else}
46
+ {@render button()}
47
+ {/if}
@@ -0,0 +1,11 @@
1
+ type PropsType = {
2
+ id?: string;
3
+ iconPath?: string;
4
+ iconClassName?: string;
5
+ className?: string;
6
+ onlyWeb?: boolean;
7
+ onClick?: (ev: MouseEvent) => void;
8
+ };
9
+ declare const ButtonCloseIcon: import("svelte").Component<PropsType, {}, "">;
10
+ type ButtonCloseIcon = ReturnType<typeof ButtonCloseIcon>;
11
+ export default ButtonCloseIcon;
@@ -0,0 +1,149 @@
1
+ <script lang="ts">
2
+ import { DropdownState } from '../../../../../types.js';
3
+ import { onMount, type Snippet } from 'svelte';
4
+ import type { ButtonAppearance, ButtonSize, ButtonType } from '../../types';
5
+ import Button from '../button/button.svelte';
6
+
7
+ export type ButtonDropdownProps = {
8
+ appearance?: ButtonAppearance;
9
+ size?: ButtonSize;
10
+ label?: string;
11
+ type?: ButtonType;
12
+ children?: Snippet;
13
+ dropdownSnippet?: Snippet;
14
+ id?: string;
15
+ backdropClassName?: string;
16
+ className?: string;
17
+ containerClassName?: string;
18
+ dropdownClassName?: string;
19
+ dropdownCloseClassName?: string;
20
+ dropdownOpenClassName?: string;
21
+ disabled?: boolean;
22
+ dropPosition?: 'top' | 'bottom' | 'middle';
23
+ };
24
+
25
+ let {
26
+ id,
27
+ appearance,
28
+ size,
29
+ label,
30
+ type,
31
+ children,
32
+ dropdownSnippet,
33
+ backdropClassName = '',
34
+ className = '',
35
+ containerClassName = '',
36
+ dropdownClassName = '',
37
+ dropdownCloseClassName = '',
38
+ dropdownOpenClassName = '',
39
+ disabled = false,
40
+ dropPosition = 'bottom',
41
+ ...others
42
+ }: ButtonDropdownProps = $props();
43
+
44
+ let placement = $state(false);
45
+ let dropdownState = $state(DropdownState.CLOSED);
46
+ let openUpward = $state(false);
47
+ let openMiddle = $state(false);
48
+ let buttonElement: HTMLDivElement;
49
+
50
+ export function toggleDropdown(ev: MouseEvent | TouchEvent) {
51
+ ev.stopPropagation();
52
+
53
+ if (placement) {
54
+ dropdownState = DropdownState.CLOSED;
55
+ setTimeout(() => (placement = false), 100);
56
+ } else {
57
+ placement = true;
58
+ setTimeout(() => (dropdownState = DropdownState.OPENED), 1);
59
+ adjustDropdownPosition();
60
+ }
61
+ }
62
+
63
+ function adjustDropdownPosition() {
64
+ if (buttonElement) {
65
+ const rect = buttonElement?.getBoundingClientRect();
66
+ const viewportHeight = window.innerHeight;
67
+ const spaceBelow = viewportHeight - rect.bottom;
68
+ const spaceAbove = rect.top;
69
+ const dropdownHeight = 200;
70
+
71
+ openUpward = false;
72
+ openMiddle = false;
73
+
74
+ switch (dropPosition) {
75
+ case 'top':
76
+ openUpward = true;
77
+ break;
78
+ case 'middle':
79
+ openMiddle = true;
80
+ break;
81
+ default:
82
+ openUpward = spaceBelow < dropdownHeight && spaceAbove > dropdownHeight;
83
+ }
84
+ }
85
+ }
86
+
87
+ onMount(() => {
88
+ window.addEventListener('resize', adjustDropdownPosition);
89
+ });
90
+ </script>
91
+
92
+ <div class="relative max-w-min {containerClassName}" bind:this={buttonElement}>
93
+ <Button
94
+ {id}
95
+ {type}
96
+ {appearance}
97
+ {size}
98
+ className="flex items-center justify-center flex-nowrap text-start {className}"
99
+ onClick={toggleDropdown}
100
+ {label}
101
+ {disabled}
102
+ {...others}
103
+ >
104
+ {#if children}
105
+ {@render children()}
106
+ {/if}
107
+ </Button>
108
+
109
+ {#if placement}
110
+ <div
111
+ aria-label="backdrop"
112
+ id="{id}-dropdown-backdrop"
113
+ class="fixed inset-0 z-10 cursor-auto {backdropClassName}"
114
+ onmousedown={(e) => {
115
+ e.stopPropagation();
116
+ e.stopImmediatePropagation();
117
+ toggleDropdown(e);
118
+ }}
119
+ ontouchstart={(e) => {
120
+ e.stopPropagation();
121
+ e.stopImmediatePropagation();
122
+ toggleDropdown(e);
123
+ }}
124
+ onclick={(e) => {
125
+ e.stopPropagation();
126
+ e.stopImmediatePropagation();
127
+ toggleDropdown(e);
128
+ }}
129
+ tabindex="-1"
130
+ role="presentation"
131
+ ></div>
132
+
133
+ <div
134
+ role="dialog"
135
+ class="absolute right-0 z-10 max-h-[50vh] min-w-40 origin-top overflow-y-auto rounded-md bg-white shadow-lg transition duration-100 ease-out dark:bg-neutral-800 dark:shadow-black {dropdownClassName} {dropdownState ===
136
+ DropdownState.OPENED
137
+ ? `scale-100 transform opacity-100 ${dropdownOpenClassName}`
138
+ : `scale-60 transform opacity-0 ${dropdownCloseClassName}`}"
139
+ style={openMiddle
140
+ ? 'top: 50%; transform: translateY(-50%);'
141
+ : openUpward
142
+ ? 'bottom: 100%; margin-bottom: 4px;'
143
+ : 'top: 100%; margin-top: 4px;'}
144
+ tabindex="-1"
145
+ >
146
+ {@render dropdownSnippet?.()}
147
+ </div>
148
+ {/if}
149
+ </div>
@@ -0,0 +1,24 @@
1
+ import { type Snippet } from 'svelte';
2
+ import type { ButtonAppearance, ButtonSize, ButtonType } from '../../types';
3
+ export type ButtonDropdownProps = {
4
+ appearance?: ButtonAppearance;
5
+ size?: ButtonSize;
6
+ label?: string;
7
+ type?: ButtonType;
8
+ children?: Snippet;
9
+ dropdownSnippet?: Snippet;
10
+ id?: string;
11
+ backdropClassName?: string;
12
+ className?: string;
13
+ containerClassName?: string;
14
+ dropdownClassName?: string;
15
+ dropdownCloseClassName?: string;
16
+ dropdownOpenClassName?: string;
17
+ disabled?: boolean;
18
+ dropPosition?: 'top' | 'bottom' | 'middle';
19
+ };
20
+ declare const ButtonDropdown: import("svelte").Component<ButtonDropdownProps, {
21
+ toggleDropdown: (ev: MouseEvent | TouchEvent) => void;
22
+ }, "">;
23
+ type ButtonDropdown = ReturnType<typeof ButtonDropdown>;
24
+ export default ButtonDropdown;
@@ -0,0 +1,136 @@
1
+
2
+ <script lang="ts">
3
+
4
+ import ButtonMenu from '../button-menu/button-menu.svelte';
5
+ import IconCircle from '../../../icon/components/icon-circle/icon-circle.svelte';
6
+ import { mdiCheckCircle, mdiCheckCircleOutline, mdiChevronRight } from '../../../icon/index.js';
7
+ import Icon from '../../../icon/components/icon/icon.svelte';
8
+ import type { ButtonListItemProps } from '../../types';
9
+ import Button from '../button/button.svelte';
10
+
11
+ let {
12
+ appearance,
13
+ size,
14
+ index,
15
+ id = '',
16
+ className,
17
+ checkboxIconPath = mdiCheckCircle,
18
+ uncheckboxIconPath = mdiCheckCircleOutline,
19
+ checkboxIconClassName = '',
20
+ uncheckboxIconClassName = '',
21
+ hasIcon = false,
22
+ iconClassName = '',
23
+ hasImg = false,
24
+ imgClassName = '',
25
+ iconPath,
26
+ isCircularIcon,
27
+ circularIconClassName = '',
28
+ imgSrc,
29
+ hasArrow = false,
30
+ arrowIconPath = mdiChevronRight,
31
+ arrowClassName = '',
32
+ title = '',
33
+ subtitle = '',
34
+ titleClassName = '',
35
+ subtitleClassName = '',
36
+ disabled = false,
37
+ hasCheckbox,
38
+ checkboxClassName = '',
39
+ isChecked = false,
40
+ hasMenu,
41
+ menus,
42
+ menuIconPath,
43
+ menuIconClassName,
44
+ menuButtonClassName,
45
+ menuButtonLabel,
46
+ hasDivider,
47
+ dividerClassName,
48
+ onMenu,
49
+ onClick = (ev: MouseEvent) => {},
50
+ children
51
+ }: ButtonListItemProps = $props();
52
+ </script>
53
+
54
+ {#snippet itemInternal()}
55
+ {#if hasIcon && iconPath}
56
+ <div class="flex-none">
57
+ {#if isCircularIcon}
58
+ <IconCircle
59
+ {iconPath}
60
+ iconClassName=" {iconClassName}"
61
+ circleClassName=" {circularIconClassName}"
62
+ />
63
+ {:else}
64
+ <Icon path={iconPath} className=" {iconClassName}" />
65
+ {/if}
66
+ </div>
67
+ {/if}
68
+
69
+ {#if hasImg && imgSrc}
70
+ <div class="flex-none">
71
+ <img src={imgSrc} class="w-6 h-6 {imgClassName} {imgClassName}" alt="item-img-{index}" />
72
+ </div>
73
+ {/if}
74
+
75
+ <div class="flex-grow min-w-0">
76
+ {#if title}
77
+ <div class="overflow-hidden whitespace-nowrap overflow-ellipsis {titleClassName}">
78
+ {title || ''}
79
+ </div>
80
+ {/if}
81
+ {#if subtitle}
82
+ <div
83
+ class="overflow-hidden whitespace-nowrap overflow-ellipsis text-neutral-400 dark:text-neutral-300 text-sm font-light {subtitleClassName}"
84
+ >
85
+ {subtitle || ''}
86
+ </div>
87
+ {/if}
88
+ </div>
89
+ {#if hasCheckbox}
90
+ <div class="flex-none">
91
+ <Icon
92
+ path={isChecked ? checkboxIconPath : uncheckboxIconPath}
93
+ className="w-5 h-5 {checkboxClassName} {isChecked
94
+ ? `text-primary ${checkboxIconClassName}`
95
+ : `text-neutral-400 ${uncheckboxIconClassName}`}"
96
+ />
97
+ </div>
98
+ {/if}
99
+
100
+ {#if hasArrow}
101
+ <div class="flex-none">
102
+ <Icon path={arrowIconPath} className="w-5 h-5 text-neutral-500 {arrowClassName} " />
103
+ </div>
104
+ {/if}
105
+ {#if hasMenu}
106
+ <div class="flex-none">
107
+ <ButtonMenu
108
+ {menus}
109
+ {onMenu}
110
+ label={menuButtonLabel}
111
+ iconPath={menuIconPath}
112
+ {menuIconClassName}
113
+ className={menuButtonClassName}
114
+ />
115
+ </div>
116
+ {/if}
117
+ {/snippet}
118
+
119
+ <Button
120
+ id="{id}-list-item-{index}"
121
+ type="button"
122
+ className="w-full !text-start !justify-start gap-4 hover:bg-neutral-50 transition rounded-none dark:hover:bg-neutral-700 h-full {className}"
123
+ {onClick}
124
+ {disabled}
125
+ {appearance}
126
+ {size}
127
+ >
128
+ {#if children}
129
+ {@render children()}
130
+ {:else}
131
+ {@render itemInternal()}
132
+ {/if}
133
+ </Button>
134
+ {#if hasDivider}
135
+ <hr class=" {dividerClassName}" />
136
+ {/if}
@@ -0,0 +1,4 @@
1
+ import type { ButtonListItemProps } from '../../types';
2
+ declare const ButtonListItem: import("svelte").Component<ButtonListItemProps, {}, "">;
3
+ type ButtonListItem = ReturnType<typeof ButtonListItem>;
4
+ export default ButtonListItem;
@@ -0,0 +1,105 @@
1
+ <script lang="ts">
2
+ import ButtonDropdown, {
3
+ type ButtonDropdownProps
4
+ } from '../button-dropdown/button-dropdown.svelte';
5
+ import Icon from '../../../icon/components/icon/icon.svelte';
6
+ import type { Snippet } from 'svelte';
7
+ import ButtonListItem from '../button-list-item/button-list-item.svelte';
8
+
9
+ import { mdiDotsHorizontal } from '../../../icon/index.js';
10
+ import type { ButtonAppearance, ButtonProps, ButtonSize, Menu } from '../../types';
11
+ type Props = {
12
+ label?: string;
13
+ className?: string;
14
+ appearance?: ButtonAppearance;
15
+ size?: ButtonSize;
16
+ children?: Snippet;
17
+ iconPath?: string;
18
+ iconClassName?: string;
19
+ menus?: string[] | Menu[];
20
+ onMenu?: (ev: MouseEvent, menu: string | Menu) => void;
21
+ dropdownClassName?: string;
22
+ menuIconClassName?: string;
23
+ disabled?: boolean;
24
+ };
25
+
26
+ let {
27
+ label,
28
+ className,
29
+ appearance,
30
+ size,
31
+ children,
32
+ iconPath = mdiDotsHorizontal,
33
+ iconClassName,
34
+ menus,
35
+ onMenu,
36
+ dropdownClassName,
37
+ menuIconClassName,
38
+ disabled,
39
+ ...others
40
+ }: ButtonDropdownProps & ButtonProps & Props = $props();
41
+
42
+ let buttonDropdownRef: ButtonDropdown;
43
+
44
+ let items: Menu[] = $derived.by(() => {
45
+ if (menus && typeof menus[0] == 'string') {
46
+ let array = (menus as string[]).map((name: string) => {
47
+ return {
48
+ _id: name,
49
+ title: name
50
+ } as Menu;
51
+ });
52
+ return array;
53
+ }
54
+ return (menus || []) as Menu[];
55
+ });
56
+
57
+ function handleItemClick(ev: MouseEvent, menuItem: Menu, index: number) {
58
+ let menu = (menus || [])[index];
59
+ if (menu) {
60
+ onMenu && onMenu(ev, menu);
61
+ buttonDropdownRef && buttonDropdownRef.toggleDropdown(ev);
62
+ }
63
+ }
64
+ </script>
65
+
66
+ {#snippet dropdownView()}
67
+ <div class="py-2">
68
+ {#each items as item, index}
69
+ {#if item.title == '-'}
70
+ <hr />
71
+ {:else}
72
+ <ButtonListItem
73
+ {...item}
74
+ className=""
75
+ iconClassName={menuIconClassName}
76
+ onClick={(ev) => handleItemClick(ev, item, index)}
77
+ />
78
+ {/if}
79
+ {/each}
80
+ </div>
81
+ {/snippet}
82
+
83
+ <ButtonDropdown
84
+ bind:this={buttonDropdownRef}
85
+ dropdownSnippet={dropdownView}
86
+ {className}
87
+ {appearance}
88
+ {size}
89
+ {dropdownClassName}
90
+ {disabled}
91
+ {...others}
92
+ >
93
+ {#if children}
94
+ {@render children()}
95
+ {:else}
96
+ {#if label}
97
+ <div>
98
+ {label || ''}
99
+ </div>
100
+ {/if}
101
+ <div>
102
+ <Icon path={iconPath} className={iconClassName} />
103
+ </div>
104
+ {/if}
105
+ </ButtonDropdown>
@@ -0,0 +1,21 @@
1
+ import { type ButtonDropdownProps } from '../button-dropdown/button-dropdown.svelte';
2
+ import type { Snippet } from 'svelte';
3
+ import type { ButtonAppearance, ButtonProps, ButtonSize, Menu } from '../../types';
4
+ type Props = {
5
+ label?: string;
6
+ className?: string;
7
+ appearance?: ButtonAppearance;
8
+ size?: ButtonSize;
9
+ children?: Snippet;
10
+ iconPath?: string;
11
+ iconClassName?: string;
12
+ menus?: string[] | Menu[];
13
+ onMenu?: (ev: MouseEvent, menu: string | Menu) => void;
14
+ dropdownClassName?: string;
15
+ menuIconClassName?: string;
16
+ disabled?: boolean;
17
+ };
18
+ type $$ComponentProps = ButtonDropdownProps & ButtonProps & Props;
19
+ declare const ButtonMenu: import("svelte").Component<$$ComponentProps, {}, "">;
20
+ type ButtonMenu = ReturnType<typeof ButtonMenu>;
21
+ export default ButtonMenu;
@@ -0,0 +1,9 @@
1
+ <script lang="ts">
2
+ import type { ButtonProps } from "../../types";
3
+ import Button from "../button/button.svelte";
4
+
5
+
6
+ let { className, ...props }: ButtonProps = $props();
7
+ </script>
8
+
9
+ <Button {...props} className="bg-indigo-600 focus:bg-indigo-700 text-white p-2 px-4 {className}" />
@@ -0,0 +1,4 @@
1
+ import type { ButtonProps } from "../../types";
2
+ declare const ButtonOk: import("svelte").Component<ButtonProps, {}, "">;
3
+ type ButtonOk = ReturnType<typeof ButtonOk>;
4
+ export default ButtonOk;
@@ -0,0 +1,72 @@
1
+ <script lang="ts">
2
+ import ButtonDropdown from '../button-dropdown/button-dropdown.svelte';
3
+ import Icon from '../../../icon/components/icon/icon.svelte';
4
+ import SearchField from '../../../input/components/search-field/search-field.svelte';
5
+ import type { Snippet } from 'svelte';
6
+
7
+ import { mdiMagnify } from '../../../icon/index.js';
8
+ import type { ButtonAppearance, ButtonProps, ButtonSize } from '../../types';
9
+ import type { InputFieldAppearance, InputFieldSize } from '../../../input/types';
10
+
11
+ type Props = {
12
+ searchAppearance?: InputFieldAppearance;
13
+ searchClassName?: string;
14
+ searchSize?: InputFieldSize;
15
+ onSearch?: (searchText: string) => void;
16
+
17
+ className?: string;
18
+ appearance?: ButtonAppearance;
19
+ size?: ButtonSize;
20
+ children?: Snippet;
21
+ iconClassName?: string;
22
+
23
+ dropdownClassName?: string;
24
+ searchText?: string;
25
+ placeholder?: string;
26
+ };
27
+
28
+ let {
29
+ searchText = $bindable(''),
30
+ searchClassName,
31
+ searchAppearance,
32
+ searchSize,
33
+ onSearch,
34
+ className,
35
+ appearance,
36
+ size,
37
+ children,
38
+ iconClassName,
39
+ dropdownClassName,
40
+ placeholder,
41
+ ...others
42
+ }: ButtonProps & Props = $props();
43
+ </script>
44
+
45
+ {#snippet dropdownSearch()}
46
+ <div class="p-4">
47
+ <SearchField
48
+ value={searchText}
49
+ {onSearch}
50
+ autofocus
51
+ className="min-w-52 {searchClassName}"
52
+ appearance={searchAppearance}
53
+ size={searchSize}
54
+ {placeholder}
55
+ />
56
+ </div>
57
+ {/snippet}
58
+
59
+ <ButtonDropdown
60
+ dropdownSnippet={dropdownSearch}
61
+ {className}
62
+ {appearance}
63
+ {size}
64
+ {dropdownClassName}
65
+ {...others}
66
+ >
67
+ {#if children}
68
+ {@render children()}
69
+ {:else}
70
+ <Icon path={mdiMagnify} className="{iconClassName} {searchText ? '!text-primary' : ''}" />
71
+ {/if}
72
+ </ButtonDropdown>
@@ -0,0 +1,21 @@
1
+ import type { Snippet } from 'svelte';
2
+ import type { ButtonAppearance, ButtonProps, ButtonSize } from '../../types';
3
+ import type { InputFieldAppearance, InputFieldSize } from '../../../input/types';
4
+ type Props = {
5
+ searchAppearance?: InputFieldAppearance;
6
+ searchClassName?: string;
7
+ searchSize?: InputFieldSize;
8
+ onSearch?: (searchText: string) => void;
9
+ className?: string;
10
+ appearance?: ButtonAppearance;
11
+ size?: ButtonSize;
12
+ children?: Snippet;
13
+ iconClassName?: string;
14
+ dropdownClassName?: string;
15
+ searchText?: string;
16
+ placeholder?: string;
17
+ };
18
+ type $$ComponentProps = ButtonProps & Props;
19
+ declare const ButtonSearch: import("svelte").Component<$$ComponentProps, {}, "searchText">;
20
+ type ButtonSearch = ReturnType<typeof ButtonSearch>;
21
+ export default ButtonSearch;