@medyll/idae-slotui-svelte 0.122.0 → 0.123.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (208) hide show
  1. package/README.md +47 -47
  2. package/dist/base/alert/Alert.demo.svelte +62 -62
  3. package/dist/base/alert/Alert.svelte +121 -121
  4. package/dist/base/alert/alert.scss +93 -93
  5. package/dist/base/avatar/Avatar.demo.svelte +41 -41
  6. package/dist/base/avatar/Avatar.preview.svelte +6 -6
  7. package/dist/base/avatar/Avatar.svelte +65 -65
  8. package/dist/base/avatar/avatar.scss +17 -17
  9. package/dist/base/backdrop/Backdrop.demo.svelte +49 -49
  10. package/dist/base/backdrop/Backdrop.svelte +78 -78
  11. package/dist/base/backdrop/backdrop.scss +34 -34
  12. package/dist/base/badge/Badge.svelte +31 -31
  13. package/dist/base/badge/badge.scss +19 -19
  14. package/dist/base/box/Box.demo.svelte +54 -54
  15. package/dist/base/box/Box.svelte +72 -72
  16. package/dist/base/box/box.scss +33 -33
  17. package/dist/base/breadCrumb/BreadCrumb.svelte +23 -23
  18. package/dist/base/breadCrumb/breadcrumb.scss +11 -11
  19. package/dist/base/cartouche/Cartouche.demo.svelte +108 -108
  20. package/dist/base/cartouche/Cartouche.svelte +114 -114
  21. package/dist/base/cartouche/cartouche.scss +114 -114
  22. package/dist/base/chipper/Chipper.demo.svelte +45 -45
  23. package/dist/base/chipper/Chipper.svelte +36 -36
  24. package/dist/base/chipper/chipper.scss +65 -65
  25. package/dist/base/columner/Column.svelte +62 -62
  26. package/dist/base/columner/Columner.demo.svelte +15 -15
  27. package/dist/base/columner/Columner.svelte +21 -21
  28. package/dist/base/contentSwitcher/ContentSwitcher.demo.svelte +45 -45
  29. package/dist/base/contentSwitcher/ContentSwitcher.svelte +63 -63
  30. package/dist/base/contentSwitcher/content-switcher.scss +22 -22
  31. package/dist/base/debug/Debug.svelte +21 -21
  32. package/dist/base/demoer/DemoPage.svelte +40 -40
  33. package/dist/base/demoer/Demoer.svelte +170 -170
  34. package/dist/base/demoer/DemoerCode.svelte +45 -45
  35. package/dist/base/demoer/DemoerComponent.svelte +50 -50
  36. package/dist/base/divider/Divider.demo.svelte +34 -34
  37. package/dist/base/divider/Divider.svelte +68 -68
  38. package/dist/base/divider/divider.scss +19 -19
  39. package/dist/base/icon/Icon.demo.svelte +24 -24
  40. package/dist/base/icon/Icon.svelte +117 -117
  41. package/dist/base/icon/Icon.svelte.d.ts +1 -1
  42. package/dist/base/icon/icon.scss +17 -17
  43. package/dist/base/paper/Paper.demo.svelte +31 -31
  44. package/dist/base/paper/Paper.svelte +20 -20
  45. package/dist/base/paper/paper.scss +15 -15
  46. package/dist/base/titleBar/TitleBar.demo.svelte +30 -30
  47. package/dist/base/titleBar/TitleBar.svelte +40 -40
  48. package/dist/base/titleBar/title-bar.scss +29 -29
  49. package/dist/controls/autocomplete/AutoComplete.demo.svelte +88 -88
  50. package/dist/controls/autocomplete/AutoComplete.svelte +152 -152
  51. package/dist/controls/autocomplete/auto-complete.scss +15 -15
  52. package/dist/controls/button/Button.demo.svelte +165 -165
  53. package/dist/controls/button/Button.svelte +95 -95
  54. package/dist/controls/button/Button.svelte.d.ts +1 -1
  55. package/dist/controls/button/ButtonAction.svelte +55 -55
  56. package/dist/controls/button/ButtonMenu.svelte +55 -55
  57. package/dist/controls/button/IconButton.svelte +45 -45
  58. package/dist/controls/button/button-action.scss +8 -8
  59. package/dist/controls/button/button-menu.scss +36 -36
  60. package/dist/controls/button/button.scss +293 -293
  61. package/dist/controls/checkbox/Checkbox.demo.svelte +29 -29
  62. package/dist/controls/checkbox/Checkbox.svelte +59 -59
  63. package/dist/controls/checkbox/checkbox.scss +115 -115
  64. package/dist/controls/confirm/Confirm.demo.svelte +60 -60
  65. package/dist/controls/confirm/Confirm.preview.svelte +14 -14
  66. package/dist/controls/confirm/Confirm.svelte +156 -156
  67. package/dist/controls/confirm/confirm.scss +12 -12
  68. package/dist/controls/inplaceedit/InPlaceEdit.demo.svelte +41 -41
  69. package/dist/controls/inplaceedit/InPlaceEdit.svelte +109 -109
  70. package/dist/controls/progress/Progress.demo.svelte +30 -30
  71. package/dist/controls/progress/Progress.svelte +26 -26
  72. package/dist/controls/progress/progress.scss +23 -23
  73. package/dist/controls/rating/Rating.demo.svelte +45 -45
  74. package/dist/controls/rating/Rating.svelte +44 -44
  75. package/dist/controls/rating/Rating.svelte.d.ts +1 -1
  76. package/dist/controls/rating/rating.scss +9 -9
  77. package/dist/controls/select/Select.demo.svelte +101 -101
  78. package/dist/controls/select/Select.svelte +125 -125
  79. package/dist/controls/select/select.scss +13 -13
  80. package/dist/controls/slider/Slider.demo.svelte +34 -34
  81. package/dist/controls/slider/Slider.svelte +153 -153
  82. package/dist/controls/slider/slider.scss +51 -51
  83. package/dist/controls/stepper/Stepper.demo.svelte +32 -32
  84. package/dist/controls/stepper/Stepper.svelte +30 -30
  85. package/dist/controls/stepper/stepper.scss +23 -23
  86. package/dist/controls/switch/Switch.demo.svelte +61 -61
  87. package/dist/controls/switch/Switch.svelte +45 -45
  88. package/dist/controls/switch/switch.scss +73 -73
  89. package/dist/controls/textfield/TextField.demo.svelte +79 -79
  90. package/dist/controls/textfield/TextField.svelte +86 -86
  91. package/dist/controls/textfield/TextField.svelte.d.ts +1 -1
  92. package/dist/controls/textfield/textfield.scss +68 -68
  93. package/dist/csss/csss.scss +10 -10
  94. package/dist/data/dataList/DataList.demo.svelte +151 -151
  95. package/dist/data/dataList/DataList.preview.svelte +23 -23
  96. package/dist/data/dataList/DataList.svelte +233 -233
  97. package/dist/data/dataList/DataListCell.svelte +212 -212
  98. package/dist/data/dataList/DataListHead.svelte +75 -75
  99. package/dist/data/dataList/DataListRow.svelte +93 -93
  100. package/dist/data/dataList/datalist.scss +157 -157
  101. package/dist/data/finder/Finder.demo.svelte +55 -55
  102. package/dist/data/finder/Finder.svelte +166 -166
  103. package/dist/data/finder/finder.scss +14 -14
  104. package/dist/data/grouper/Grouper.demo.svelte +36 -36
  105. package/dist/data/grouper/Grouper.svelte +85 -85
  106. package/dist/data/jsoner/Jsoner.svelte +40 -40
  107. package/dist/data/list/List.svelte +16 -16
  108. package/dist/data/list/ListItem.svelte +10 -10
  109. package/dist/data/list/ListTitle.svelte +8 -8
  110. package/dist/data/loader/Loader.demo.svelte +95 -95
  111. package/dist/data/loader/Loader.preview.svelte +7 -7
  112. package/dist/data/loader/Loader.svelte +99 -99
  113. package/dist/data/loader/loader.scss +50 -50
  114. package/dist/data/sorter/Sorter.demo.svelte +62 -62
  115. package/dist/data/sorter/Sorter.svelte +80 -80
  116. package/dist/data/sorter/Sorterer.svelte +27 -27
  117. package/dist/data/sorter/sorterer.scss +11 -11
  118. package/dist/index.d.ts +67 -66
  119. package/dist/index.js +67 -66
  120. package/dist/navigation/drawer/Drawer.demo.svelte +52 -52
  121. package/dist/navigation/drawer/Drawer.svelte +163 -163
  122. package/dist/navigation/drawer/drawer.scss +69 -69
  123. package/dist/navigation/tabs/Tabs.demo.svelte +83 -83
  124. package/dist/navigation/tabs/Tabs.preview.svelte +22 -22
  125. package/dist/navigation/tabs/Tabs.svelte +158 -158
  126. package/dist/navigation/tabs/tabs.scss +92 -92
  127. package/dist/slotui-css/slotui-css.css +229 -229
  128. package/dist/slotui-css/slotui-min-css.css +229 -229
  129. package/dist/styles/slotui-mixins.scss +168 -168
  130. package/dist/styles/slotui-presets.scss +56 -56
  131. package/dist/styles/slotuisheet/SlotuiSheet.svelte +36 -36
  132. package/dist/styles/slotuisheet/SlotyuiSheet.demo.svelte +28 -28
  133. package/dist/styles/slotuisheet/sheetConfig.scss +7 -7
  134. package/dist/styles/slotuisheet/slotui-sheet.scss +192 -192
  135. package/dist/styles/slotuisheet/stylesheet-container.scss +147 -147
  136. package/dist/styles/slotuisheet/stylesheet.scss +156 -156
  137. package/dist/types/slotui-ambient.d.ts +27 -27
  138. package/dist/ui/bootstrapp/BootStrApp.svelte +92 -92
  139. package/dist/ui/chromeFrame/ChromeFrame.svelte +43 -43
  140. package/dist/ui/chromeFrame/ChromeFrameButtonList.svelte +33 -33
  141. package/dist/ui/chromeFrame/ChromeFrameList.svelte +106 -106
  142. package/dist/ui/chromeFrame/chrome-frame.scss +34 -34
  143. package/dist/ui/frame/Frame.demo.svelte +48 -48
  144. package/dist/ui/frame/Frame.svelte +90 -90
  145. package/dist/ui/frame/frame.scss +46 -46
  146. package/dist/ui/login/Login.demo.svelte +62 -62
  147. package/dist/ui/login/Login.svelte +102 -102
  148. package/dist/ui/marquee/Marquee.demo.svelte +33 -33
  149. package/dist/ui/marquee/Marquee.svelte +97 -97
  150. package/dist/ui/marquee/marquee.scss +34 -34
  151. package/dist/ui/menu/Menu.svelte +9 -9
  152. package/dist/ui/menu/MenuItem.svelte +9 -9
  153. package/dist/ui/menu/MenuTitle.svelte +10 -10
  154. package/dist/ui/menu/menu.scss +61 -61
  155. package/dist/ui/menuList/MenuList.demo.svelte +73 -73
  156. package/dist/ui/menuList/MenuList.svelte +143 -143
  157. package/dist/ui/menuList/MenuListItem.svelte +134 -134
  158. package/dist/ui/menuList/MenuListTitle.svelte +10 -10
  159. package/dist/ui/menuList/menu-list.scss +120 -120
  160. package/dist/ui/panel/Panel.demo.svelte +169 -169
  161. package/dist/ui/panel/Panel.svelte +96 -96
  162. package/dist/ui/panel/PanelGrid.svelte +62 -62
  163. package/dist/ui/panel/PanelSlide.svelte +156 -156
  164. package/dist/ui/panel/Paneler.svelte +63 -63
  165. package/dist/ui/panel/panel.scss +32 -32
  166. package/dist/ui/popper/Popper.demo.svelte +92 -92
  167. package/dist/ui/popper/Popper.svelte +160 -160
  168. package/dist/ui/popper/popper.scss +108 -108
  169. package/dist/ui/preview/Preview.svelte +41 -41
  170. package/dist/ui/serviceBox/ServiceBox.svelte +24 -24
  171. package/dist/ui/startMenu/BootMenu.svelte +102 -102
  172. package/dist/ui/startMenu/boot-menu.scss +86 -86
  173. package/dist/ui/taskbar/TaskBarContent.svelte +20 -20
  174. package/dist/ui/taskbar/Taskbar.svelte +26 -26
  175. package/dist/ui/taskbar/taskbar.scss +28 -28
  176. package/dist/ui/themeswitcher/ThemeSwitcher.svelte +18 -18
  177. package/dist/ui/toast/Toast.demo.svelte +19 -19
  178. package/dist/ui/toast/Toast.svelte +60 -60
  179. package/dist/ui/toast/Toaster.svelte +18 -18
  180. package/dist/ui/toggleBar/ToggleBar.demo.svelte +114 -114
  181. package/dist/ui/toggleBar/ToggleBar.svelte +58 -58
  182. package/dist/ui/toggleBar/ToggleBar.svelte.d.ts +1 -1
  183. package/dist/ui/toggleBar/toggle-bar.scss +45 -45
  184. package/dist/ui/toolBar/ToolBar.demo.svelte +98 -98
  185. package/dist/ui/toolBar/ToolBar.svelte +30 -30
  186. package/dist/ui/toolBar/toolbar.scss +32 -32
  187. package/dist/ui/tree/Tree.demo.svelte +84 -84
  188. package/dist/ui/tree/Tree.preview.svelte +19 -19
  189. package/dist/ui/tree/Tree.svelte +182 -182
  190. package/dist/ui/tree/tree.scss +38 -38
  191. package/dist/ui/window/Window.demo.svelte +111 -111
  192. package/dist/ui/window/Window.svelte +177 -177
  193. package/dist/ui/window/window.scss +66 -66
  194. package/dist/utils/content/Content.svelte +78 -78
  195. package/dist/utils/contextRooter/ContextRooter.demo.svelte +33 -33
  196. package/dist/utils/contextRooter/ContextRooter.svelte +6 -6
  197. package/dist/utils/css/Css.demo.svelte +5 -5
  198. package/dist/utils/css/Css.svelte +64 -64
  199. package/dist/utils/effects/transitions.js +6 -6
  200. package/dist/utils/looper/Looper.demo.svelte +36 -36
  201. package/dist/utils/looper/Looper.svelte +47 -47
  202. package/dist/utils/slotted/Slotted.svelte +21 -21
  203. package/dist/utils/stylesheet/StyleSheet.demo.svelte +28 -28
  204. package/dist/utils/stylesheet/StyleSheet.svelte +30 -30
  205. package/dist/utils/stylesheet/containerConfig.scss +7 -7
  206. package/dist/utils/stylesheet/stylesheet.scss +147 -147
  207. package/dist/utils/uses/sx4u/sx4uPreprocess.js +34 -34
  208. package/package.json +4 -4
@@ -1,40 +1,40 @@
1
- <script lang="ts">
2
- import type { JsonerProps } from './types.js';
3
-
4
- let { class: className = '', element, data = [], mode = 'array' }: JsonerProps = $props();
5
-
6
- if (Array.isArray(data)) {
7
- mode = 'array';
8
- } else if (typeof data === 'object') {
9
- mode = 'object';
10
- } else if (typeof data === 'string') {
11
- mode = 'string';
12
- } else if (typeof data === 'number') {
13
- mode = 'number';
14
- }
15
- </script>
16
-
17
- {#if data}
18
- {#if mode === 'array'}
19
- <div class="flex-h w-large flex-wrap gap-small">
20
- {#each data as kdta, index}
21
- <div class="border-l"><svelte:self data={kdta} /></div>
22
- {/each}
23
- </div>
24
- {/if}
25
-
26
- {#if mode === 'object'}
27
- <div class="flex-v gap-small">
28
- {#each Object.keys(data) as kdta}
29
- <div class="flex-h gap-small flex-align-top marg-l">
30
- <div class="w-medium pad-1 border-b">- {kdta}</div>
31
- <div style="margin-left:4rem;"><svelte:self data={data[kdta]} /></div>
32
- </div>
33
- {/each}
34
- </div>
35
- {/if}
36
-
37
- {#if ['string', 'number'].includes(mode)}
38
- <div class="pad-1">{data}</div>
39
- {/if}
40
- {/if}
1
+ <script lang="ts">
2
+ import type { JsonerProps } from './types.js';
3
+
4
+ let { class: className = '', element, data = [], mode = 'array' }: JsonerProps = $props();
5
+
6
+ if (Array.isArray(data)) {
7
+ mode = 'array';
8
+ } else if (typeof data === 'object') {
9
+ mode = 'object';
10
+ } else if (typeof data === 'string') {
11
+ mode = 'string';
12
+ } else if (typeof data === 'number') {
13
+ mode = 'number';
14
+ }
15
+ </script>
16
+
17
+ {#if data}
18
+ {#if mode === 'array'}
19
+ <div class="flex-h w-large flex-wrap gap-small">
20
+ {#each data as kdta, index}
21
+ <div class="border-l"><svelte:self data={kdta} /></div>
22
+ {/each}
23
+ </div>
24
+ {/if}
25
+
26
+ {#if mode === 'object'}
27
+ <div class="flex-v gap-small">
28
+ {#each Object.keys(data) as kdta}
29
+ <div class="flex-h gap-small flex-align-top marg-l">
30
+ <div class="w-medium pad-1 border-b">- {kdta}</div>
31
+ <div style="margin-left:4rem;"><svelte:self data={data[kdta]} /></div>
32
+ </div>
33
+ {/each}
34
+ </div>
35
+ {/if}
36
+
37
+ {#if ['string', 'number'].includes(mode)}
38
+ <div class="pad-1">{data}</div>
39
+ {/if}
40
+ {/if}
@@ -1,16 +1,16 @@
1
- <script lang="ts">
2
- import type { MenuListProps } from '../../ui/menuList/types.js';
3
- import MenuList from '../../ui/menuList/MenuList.svelte';
4
-
5
- let { element, selectedData, selectedIndex, menuListItems, data, ...rest }: MenuListProps =
6
- $props();
7
- </script>
8
-
9
- <MenuList
10
- {...rest}
11
- bind:element
12
- bind:selectedData
13
- bind:selectedIndex
14
- bind:menuListItems
15
- bind:data
16
- />
1
+ <script lang="ts">
2
+ import type { MenuListProps } from '../../ui/menuList/types.js';
3
+ import MenuList from '../../ui/menuList/MenuList.svelte';
4
+
5
+ let { element, selectedData, selectedIndex, menuListItems, data, ...rest }: MenuListProps =
6
+ $props();
7
+ </script>
8
+
9
+ <MenuList
10
+ {...rest}
11
+ bind:element
12
+ bind:selectedData
13
+ bind:selectedIndex
14
+ bind:menuListItems
15
+ bind:data
16
+ />
@@ -1,10 +1,10 @@
1
- <svelte:options />
2
-
3
- <script lang="ts">
4
- import MenuListItem from '../../ui/menuList/MenuListItem.svelte';
5
- import type { MenuListItemProps } from '../../ui/menuList/types.js';
6
-
7
- let { ...rest }: MenuListItemProps = $props();
8
- </script>
9
-
10
- <MenuListItem {...rest} />
1
+ <svelte:options />
2
+
3
+ <script lang="ts">
4
+ import MenuListItem from '../../ui/menuList/MenuListItem.svelte';
5
+ import type { MenuListItemProps } from '../../ui/menuList/types.js';
6
+
7
+ let { ...rest }: MenuListItemProps = $props();
8
+ </script>
9
+
10
+ <MenuListItem {...rest} />
@@ -1,8 +1,8 @@
1
- <script lang="ts">
2
- import MenuListTitle from '../../ui/menuList/MenuListTitle.svelte';
3
- import type { MenuListItemProps } from '../../ui/menuList/types.js';
4
-
5
- let { ...rest }: MenuListItemProps = $props();
6
- </script>
7
-
8
- <MenuListTitle {...rest} />
1
+ <script lang="ts">
2
+ import MenuListTitle from '../../ui/menuList/MenuListTitle.svelte';
3
+ import type { MenuListItemProps } from '../../ui/menuList/types.js';
4
+
5
+ let { ...rest }: MenuListItemProps = $props();
6
+ </script>
7
+
8
+ <MenuListTitle {...rest} />
@@ -1,95 +1,95 @@
1
- <script lang="ts">
2
- import Loader from './Loader.svelte';
3
-
4
- /* demo */
5
- import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
6
- import Demoer from '../../base/demoer/Demoer.svelte';
7
- import DemoPage from '../../base/demoer/DemoPage.svelte';
8
- import Icon from '../../base/icon/Icon.svelte';
9
- import type { LoaderProps } from './types.js';
10
- /* demo */
11
-
12
- import { parameters, componentArgs } from './types.js';
13
-
14
- let codeSlot = `
15
- <Loader onstatuschange={() => {}}>
16
- {#snippet loaderLoading()}
17
- <Icon color="orange" fontSize="big" icon="mdi:loading" rotate />
18
- {/snippet}
19
- {#snippet loaderError()}
20
- <Icon color="red" fontSize="big" icon="mdi:alert-circle-outline" />
21
- {/snippet}
22
- {#snippet loaderEmpty()}
23
- <Icon color="gray" fontSize="big" icon="mdi:database-search-outline" />
24
- {/snippet}
25
- {#snippet loaderSuccess()}
26
- <Icon color="green" fontSize="big" icon="clarity:success-standard-line" />
27
- {/snippet}v
28
- </Loader>`;
29
-
30
- let codeProps = `
31
- <Loader
32
- status={"loading"}
33
- messages={{
34
- loading: 'Loading dataset',
35
- error : 'An error occurred',
36
- empty : 'Empty results',
37
- success: 'Success !'
38
- }}
39
- emptyIcon="mdi:database-search-outline"
40
- errorIcon="mdi:alert-circle-outline"
41
- loadingIcon="mdi:loading"
42
- successIcon="clarity:success-standard-line" />`;
43
- </script>
44
-
45
- <ComponentDemo
46
- cite="And suddenly, in this dark cabinet, i realized that the most pleasant
47
- phase was that of waiting.<br /> D. Pentes, 824"
48
- component="Loader"
49
- >
50
- <div class="flex-v gap-large">
51
- <DemoPage code={codeSlot} component="Loading">
52
- <Demoer {componentArgs} {parameters}>
53
- {#snippet children({ activeParams })}
54
- <div class="pos-rel h-large w-large">
55
- <Loader {...activeParams} on:status:change={() => {}}>
56
- {#snippet loaderLoading()}
57
- <Icon color="orange" iconSize="big" icon="mdi:loading" rotate />
58
- {/snippet}
59
- {#snippet loaderError()}
60
- <Icon color="red" iconSize="big" icon="mdi:alert-circle-outline" />
61
- {/snippet}
62
- {#snippet loaderEmpty()}
63
- <Icon color="gray" iconSize="big" icon="mdi:database-search-outline" />
64
- {/snippet}
65
- {#snippet loaderSuccess()}
66
- <Icon color="green" iconSize="big" icon="clarity:success-standard-line" />
67
- {/snippet}v
68
- </Loader>
69
- </div>
70
- {/snippet}
71
- </Demoer>
72
- </DemoPage>
73
- <DemoPage code={codeProps} component="Loading" title="Using props">
74
- <Demoer {componentArgs} {parameters}>
75
- {#snippet children({ activeParams })}
76
- <div class="pos-rel h-large w-large">
77
- <Loader
78
- {...activeParams}
79
- emptyIcon="mdi:database-search-outline"
80
- errorIcon="mdi:alert-circle-outline"
81
- loadingIcon="mdi:loading"
82
- messages={{
83
- loading: 'Loading dataset',
84
- error: 'An error occurred',
85
- empty: 'Empty results',
86
- success: 'Success !'
87
- }}
88
- successIcon="clarity:success-standard-line"
89
- />
90
- </div>
91
- {/snippet}
92
- </Demoer>
93
- </DemoPage>
94
- </div>
95
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import Loader from './Loader.svelte';
3
+
4
+ /* demo */
5
+ import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
6
+ import Demoer from '../../base/demoer/Demoer.svelte';
7
+ import DemoPage from '../../base/demoer/DemoPage.svelte';
8
+ import Icon from '../../base/icon/Icon.svelte';
9
+ import type { LoaderProps } from './types.js';
10
+ /* demo */
11
+
12
+ import { parameters, componentArgs } from './types.js';
13
+
14
+ let codeSlot = `
15
+ <Loader onstatuschange={() => {}}>
16
+ {#snippet loaderLoading()}
17
+ <Icon color="orange" fontSize="big" icon="mdi:loading" rotate />
18
+ {/snippet}
19
+ {#snippet loaderError()}
20
+ <Icon color="red" fontSize="big" icon="mdi:alert-circle-outline" />
21
+ {/snippet}
22
+ {#snippet loaderEmpty()}
23
+ <Icon color="gray" fontSize="big" icon="mdi:database-search-outline" />
24
+ {/snippet}
25
+ {#snippet loaderSuccess()}
26
+ <Icon color="green" fontSize="big" icon="clarity:success-standard-line" />
27
+ {/snippet}v
28
+ </Loader>`;
29
+
30
+ let codeProps = `
31
+ <Loader
32
+ status={"loading"}
33
+ messages={{
34
+ loading: 'Loading dataset',
35
+ error : 'An error occurred',
36
+ empty : 'Empty results',
37
+ success: 'Success !'
38
+ }}
39
+ emptyIcon="mdi:database-search-outline"
40
+ errorIcon="mdi:alert-circle-outline"
41
+ loadingIcon="mdi:loading"
42
+ successIcon="clarity:success-standard-line" />`;
43
+ </script>
44
+
45
+ <ComponentDemo
46
+ cite="And suddenly, in this dark cabinet, i realized that the most pleasant
47
+ phase was that of waiting.<br /> D. Pentes, 824"
48
+ component="Loader"
49
+ >
50
+ <div class="flex-v gap-large">
51
+ <DemoPage code={codeSlot} component="Loading">
52
+ <Demoer {componentArgs} {parameters}>
53
+ {#snippet children({ activeParams })}
54
+ <div class="pos-rel h-large w-large">
55
+ <Loader {...activeParams} on:status:change={() => {}}>
56
+ {#snippet loaderLoading()}
57
+ <Icon color="orange" iconSize="big" icon="mdi:loading" rotate />
58
+ {/snippet}
59
+ {#snippet loaderError()}
60
+ <Icon color="red" iconSize="big" icon="mdi:alert-circle-outline" />
61
+ {/snippet}
62
+ {#snippet loaderEmpty()}
63
+ <Icon color="gray" iconSize="big" icon="mdi:database-search-outline" />
64
+ {/snippet}
65
+ {#snippet loaderSuccess()}
66
+ <Icon color="green" iconSize="big" icon="clarity:success-standard-line" />
67
+ {/snippet}v
68
+ </Loader>
69
+ </div>
70
+ {/snippet}
71
+ </Demoer>
72
+ </DemoPage>
73
+ <DemoPage code={codeProps} component="Loading" title="Using props">
74
+ <Demoer {componentArgs} {parameters}>
75
+ {#snippet children({ activeParams })}
76
+ <div class="pos-rel h-large w-large">
77
+ <Loader
78
+ {...activeParams}
79
+ emptyIcon="mdi:database-search-outline"
80
+ errorIcon="mdi:alert-circle-outline"
81
+ loadingIcon="mdi:loading"
82
+ messages={{
83
+ loading: 'Loading dataset',
84
+ error: 'An error occurred',
85
+ empty: 'Empty results',
86
+ success: 'Success !'
87
+ }}
88
+ successIcon="clarity:success-standard-line"
89
+ />
90
+ </div>
91
+ {/snippet}
92
+ </Demoer>
93
+ </DemoPage>
94
+ </div>
95
+ </ComponentDemo>
@@ -1,7 +1,7 @@
1
- <script lang="ts">
2
- import Loader from './Loader.svelte';
3
- </script>
4
-
5
- <div class="pos-rel">
6
- <Loader isLoading={true} />
7
- </div>
1
+ <script lang="ts">
2
+ import Loader from './Loader.svelte';
3
+ </script>
4
+
5
+ <div class="pos-rel">
6
+ <Loader isLoading={true} />
7
+ </div>
@@ -1,101 +1,101 @@
1
- <script lang="ts">
2
- import { fade } from 'svelte/transition';
3
- import Icon from '../../base/icon/Icon.svelte';
4
- import type { LoaderProps } from './types.js';
5
- import Slotted from '../../utils/slotted/Slotted.svelte';
6
- import type { ExpandProps } from '../../types/index.js';
7
-
8
- let {
9
- class: className = '',
10
- element = $bindable(),
11
- style = '',
12
- status,
13
- showSuccess = true,
14
- loadingIcon = 'mdi:loading',
15
- errorIcon = 'mdi:alert-circle-outline',
16
- emptyIcon = 'mdi:database-search-outline',
17
- successIcon = 'clarity:success-standard-line',
18
- isLoading = false,
19
- isError = false,
20
- isEmpty = false,
21
- message,
22
- messages = {
23
- loading: 'Loading',
24
- error: 'An error occurred',
25
- empty: 'Empty results',
26
- success: 'Success'
27
- },
28
- loaderLoading,
29
- loaderError,
30
- loaderEmpty,
31
- loaderMessage,
32
- loaderSuccess,
33
- children,
34
- ...rest
35
- }: ExpandProps<LoaderProps> = $props();
36
-
37
- const msgType = $derived(() =>
38
- isLoading ? 'loading' : isError ? 'error' : isEmpty ? 'empty' : ''
39
- );
40
-
41
- let finalMessage = $derived(() => message ?? messages?.[status] ?? messages?.[msgType]);
42
-
43
- let timer: any;
44
- $effect(() => {
45
- if (status === 'success') {
46
- if (!showSuccess) status = undefined;
47
- else {
48
- clearTimeout(timer);
49
- timer = setTimeout(() => {
50
- status = undefined;
51
- }, 1250);
52
- }
53
- } else {
54
- clearTimeout(timer);
55
- }
56
- });
57
- </script>
58
-
59
- {#key status}
60
- {#if status || isLoading || isError || isEmpty}
61
- <div bind:this={element} transition:fade|global class="loader {className}" {style} {...rest}>
62
- <div class="loader-box">
63
- {#if status === 'loading' || isLoading}
64
- <Slotted child={loaderLoading}>
65
- <Icon
66
- style="color:var(--sld-color-primary)"
67
- icon={loadingIcon}
68
- iconSize="medium"
69
- rotate
70
- />
71
- </Slotted>
72
- {/if}
73
- {#if status === 'error' || isError}
74
- <Slotted child={loaderError}>
75
- <Icon style="color:orange;" icon={errorIcon} iconSize="medium" />
76
- </Slotted>
77
- {/if}
78
- {#if showSuccess && status === 'success'}
79
- <Slotted child={loaderSuccess}>
80
- <Icon style="color:green;" icon={successIcon} iconSize="medium" />
81
- </Slotted>
82
- {/if}
83
- {#if status === 'empty' || isEmpty}
84
- <Slotted child={loaderEmpty}>
85
- <Icon icon={emptyIcon} iconSize="medium" />
86
- </Slotted>
87
- {/if}
88
-
89
- {#if Boolean(finalMessage)}
90
- <Slotted child={loaderMessage}>
91
- <div class="loader-message">{finalMessage}</div>
92
- </Slotted>
93
- {/if}
94
- </div>
95
- </div>
96
- {/if}
97
- {/key}
98
-
1
+ <script lang="ts">
2
+ import { fade } from 'svelte/transition';
3
+ import Icon from '../../base/icon/Icon.svelte';
4
+ import type { LoaderProps } from './types.js';
5
+ import Slotted from '../../utils/slotted/Slotted.svelte';
6
+ import type { ExpandProps } from '../../types/index.js';
7
+
8
+ let {
9
+ class: className = '',
10
+ element = $bindable(),
11
+ style = '',
12
+ status,
13
+ showSuccess = true,
14
+ loadingIcon = 'mdi:loading',
15
+ errorIcon = 'mdi:alert-circle-outline',
16
+ emptyIcon = 'mdi:database-search-outline',
17
+ successIcon = 'clarity:success-standard-line',
18
+ isLoading = false,
19
+ isError = false,
20
+ isEmpty = false,
21
+ message,
22
+ messages = {
23
+ loading: 'Loading',
24
+ error: 'An error occurred',
25
+ empty: 'Empty results',
26
+ success: 'Success'
27
+ },
28
+ loaderLoading,
29
+ loaderError,
30
+ loaderEmpty,
31
+ loaderMessage,
32
+ loaderSuccess,
33
+ children,
34
+ ...rest
35
+ }: ExpandProps<LoaderProps> = $props();
36
+
37
+ const msgType = $derived(() =>
38
+ isLoading ? 'loading' : isError ? 'error' : isEmpty ? 'empty' : ''
39
+ );
40
+
41
+ let finalMessage = $derived(() => message ?? messages?.[status] ?? messages?.[msgType]);
42
+
43
+ let timer: any;
44
+ $effect(() => {
45
+ if (status === 'success') {
46
+ if (!showSuccess) status = undefined;
47
+ else {
48
+ clearTimeout(timer);
49
+ timer = setTimeout(() => {
50
+ status = undefined;
51
+ }, 1250);
52
+ }
53
+ } else {
54
+ clearTimeout(timer);
55
+ }
56
+ });
57
+ </script>
58
+
59
+ {#key status}
60
+ {#if status || isLoading || isError || isEmpty}
61
+ <div bind:this={element} transition:fade|global class="loader {className}" {style} {...rest}>
62
+ <div class="loader-box">
63
+ {#if status === 'loading' || isLoading}
64
+ <Slotted child={loaderLoading}>
65
+ <Icon
66
+ style="color:var(--sld-color-primary)"
67
+ icon={loadingIcon}
68
+ iconSize="medium"
69
+ rotate
70
+ />
71
+ </Slotted>
72
+ {/if}
73
+ {#if status === 'error' || isError}
74
+ <Slotted child={loaderError}>
75
+ <Icon style="color:orange;" icon={errorIcon} iconSize="medium" />
76
+ </Slotted>
77
+ {/if}
78
+ {#if showSuccess && status === 'success'}
79
+ <Slotted child={loaderSuccess}>
80
+ <Icon style="color:green;" icon={successIcon} iconSize="medium" />
81
+ </Slotted>
82
+ {/if}
83
+ {#if status === 'empty' || isEmpty}
84
+ <Slotted child={loaderEmpty}>
85
+ <Icon icon={emptyIcon} iconSize="medium" />
86
+ </Slotted>
87
+ {/if}
88
+
89
+ {#if Boolean(finalMessage)}
90
+ <Slotted child={loaderMessage}>
91
+ <div class="loader-message">{finalMessage}</div>
92
+ </Slotted>
93
+ {/if}
94
+ </div>
95
+ </div>
96
+ {/if}
97
+ {/key}
98
+
99
99
  <style>:root {
100
100
  --loader-background-color: var(--sld-color-background-alpha-mid);
101
101
  --loader-box-shadow: var(--sld-elevation-1);
@@ -141,4 +141,4 @@
141
141
  padding: var(--loader-message-padding);
142
142
  display: inline-block;
143
143
  box-shadow: var(--loader-box-shadow);
144
- }</style>
144
+ }</style>
@@ -1,50 +1,50 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --loader-background-color: var(--sld-color-background-alpha-mid);
5
- --loader-box-shadow: var(--sld-elevation-1);
6
- --loader-radius: var(--sld-radius-tiny);
7
- --loader-border: var(--sld-color-foreground-alpha-high);
8
- --loader-message-border-radius: var(--sld-radius-small);
9
- --loader-message-border-bottom: var(--sld-color-primary);
10
- --loader-message-padding: var(--box-density-1) var(--box-density-2);
11
- }
12
-
13
- .loader {
14
- position: absolute;
15
- top: 0;
16
- background-color: var(--loader-background-color);
17
- height: 100%;
18
- min-width: 128px;
19
- max-width: 100%;
20
- display: inline-flex;
21
- flex-direction: column;
22
- align-items: center;
23
- justify-content: center;
24
- left: 50%;
25
- transform: translate(-50%, 0);
26
-
27
- .loader-box {
28
- box-shadow: var(--loader-box-shadow);
29
- border-radius: var(--loader-radius);
30
- border: 1px solid var(--loader-border);
31
- padding: 1rem 0;
32
- min-width: 128px;
33
- width: 100%;
34
- margin: 1rem;
35
- text-align: center;
36
- background-color: var(--loader-background-color);
37
- display: flex;
38
- flex-direction: column;
39
- align-items: center;
40
-
41
- .loader-message {
42
- border-radius: var(--loader-message-border-radius);
43
- border-bottom: 1px solid;
44
- border-color: var(--loader-message-border-bottom);
45
- padding: var(--loader-message-padding);
46
- display: inline-block;
47
- box-shadow: var(--loader-box-shadow);
48
- }
49
- }
50
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --loader-background-color: var(--sld-color-background-alpha-mid);
5
+ --loader-box-shadow: var(--sld-elevation-1);
6
+ --loader-radius: var(--sld-radius-tiny);
7
+ --loader-border: var(--sld-color-foreground-alpha-high);
8
+ --loader-message-border-radius: var(--sld-radius-small);
9
+ --loader-message-border-bottom: var(--sld-color-primary);
10
+ --loader-message-padding: var(--box-density-1) var(--box-density-2);
11
+ }
12
+
13
+ .loader {
14
+ position: absolute;
15
+ top: 0;
16
+ background-color: var(--loader-background-color);
17
+ height: 100%;
18
+ min-width: 128px;
19
+ max-width: 100%;
20
+ display: inline-flex;
21
+ flex-direction: column;
22
+ align-items: center;
23
+ justify-content: center;
24
+ left: 50%;
25
+ transform: translate(-50%, 0);
26
+
27
+ .loader-box {
28
+ box-shadow: var(--loader-box-shadow);
29
+ border-radius: var(--loader-radius);
30
+ border: 1px solid var(--loader-border);
31
+ padding: 1rem 0;
32
+ min-width: 128px;
33
+ width: 100%;
34
+ margin: 1rem;
35
+ text-align: center;
36
+ background-color: var(--loader-background-color);
37
+ display: flex;
38
+ flex-direction: column;
39
+ align-items: center;
40
+
41
+ .loader-message {
42
+ border-radius: var(--loader-message-border-radius);
43
+ border-bottom: 1px solid;
44
+ border-color: var(--loader-message-border-bottom);
45
+ padding: var(--loader-message-padding);
46
+ display: inline-block;
47
+ box-shadow: var(--loader-box-shadow);
48
+ }
49
+ }
50
+ }