@medyll/idae-slotui-svelte 0.120.0 → 0.122.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 +46 -47
  119. package/dist/index.js +46 -47
  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 +288 -288
  128. package/dist/slotui-css/slotui-min-css.css +288 -288
  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,34 +1,34 @@
1
- <script lang="ts">
2
- import Divider from './Divider.svelte';
3
-
4
- /* demo */
5
- import ComponentDemo from '../demoer/DemoerComponent.svelte';
6
- import Demoer from '../demoer/Demoer.svelte';
7
- import DemoPage from '../demoer/DemoPage.svelte';
8
- /* demo */
9
-
10
- import { parameters, componentArgs } from './types.js';
11
-
12
- let codeSlot = `
13
- <Divider />`;
14
- </script>
15
-
16
- <ComponentDemo
17
- component="Divider"
18
- cite="What is separating before from after is not a time nor a place : it's only a component <br /> B. Franklin,
19
- 1854"
20
- >
21
- <div class=" flex-v gap-small">
22
- <DemoPage component="Divider" code={codeSlot}>
23
- <Demoer {parameters} {componentArgs}>
24
- {#snippet children({ activeParams })}
25
- <div class="pad">
26
- <div class="pad">What is before</div>
27
- <Divider {...activeParams} />
28
- <div class="pad">And what is after</div>
29
- </div>
30
- {/snippet}
31
- </Demoer>
32
- </DemoPage>
33
- </div>
34
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import Divider from './Divider.svelte';
3
+
4
+ /* demo */
5
+ import ComponentDemo from '../demoer/DemoerComponent.svelte';
6
+ import Demoer from '../demoer/Demoer.svelte';
7
+ import DemoPage from '../demoer/DemoPage.svelte';
8
+ /* demo */
9
+
10
+ import { parameters, componentArgs } from './types.js';
11
+
12
+ let codeSlot = `
13
+ <Divider />`;
14
+ </script>
15
+
16
+ <ComponentDemo
17
+ component="Divider"
18
+ cite="What is separating before from after is not a time nor a place : it's only a component <br /> B. Franklin,
19
+ 1854"
20
+ >
21
+ <div class=" flex-v gap-small">
22
+ <DemoPage component="Divider" code={codeSlot}>
23
+ <Demoer {parameters} {componentArgs}>
24
+ {#snippet children({ activeParams })}
25
+ <div class="pad">
26
+ <div class="pad">What is before</div>
27
+ <Divider {...activeParams} />
28
+ <div class="pad">And what is after</div>
29
+ </div>
30
+ {/snippet}
31
+ </Demoer>
32
+ </DemoPage>
33
+ </div>
34
+ </ComponentDemo>
@@ -1,70 +1,70 @@
1
- <script lang="ts">
2
- /** extends button */
3
- import type { ElementProps, ExpandProps } from '../../types/index.js';
4
- import { uiPresets } from '../../utils/engine/presets.js';
5
- import type { DividerProps } from './types.js';
6
- let {
7
- class: className = '',
8
- style,
9
- element = null,
10
- dense: density = 'default',
11
- orientation: direction = 'horizontal',
12
- expansion = 'full',
13
- shadowed: shadow = false,
14
- color
15
- }: ExpandProps<DividerProps> = $props();
16
-
17
- let extensionClass = {
18
- horizontal: {
19
- full: '',
20
- padded: 'marg-ii-12',
21
- centered: 'marg-ii-6'
22
- },
23
- vertical: {
24
- full: '',
25
- padded: 'marg-ii-12',
26
- centered: 'marg-ii-6'
27
- }
28
- };
29
- let addStyle: string = (style as unknown as string) ?? ('' as unknown as string);
30
-
31
- const shadowClass = $derived(shadow ? 'shad-3' : '');
32
-
33
- if (color) addStyle += `--sld-color-border:${color};`;
34
-
35
- // set height od divider when direction === vertical in a flex env
36
- if (
37
- direction === 'vertical' &&
38
- (element?.nextElementSibling ?? element?.previousElementSibling)
39
- ) {
40
- let maxHeight = (
41
- element?.previousElementSibling ?? element?.nextElementSibling
42
- )?.getBoundingClientRect()?.height;
43
-
44
- addStyle += `height:calc(${maxHeight}px - ${getDensity(density)});`;
45
- }
46
-
47
- function getDensity(density: ElementProps['density']) {
48
- return uiPresets.density?.[density];
49
- }
50
-
51
- switch (direction) {
52
- case 'horizontal':
53
- addStyle += `margin-top:${getDensity(density)};margin-bottom:${getDensity(density)};`;
54
- break;
55
- case 'vertical':
56
- addStyle += `margin-left:${getDensity(density)};margin-right:${getDensity(density)};`;
57
- break;
58
- }
59
- </script>
60
-
61
- <hr
62
- bind:this={element}
63
- class="{extensionClass[direction][expansion]} {className} {shadowClass}"
64
- class:vertical={direction === 'vertical'}
65
- style={addStyle}
66
- />
67
-
1
+ <script lang="ts">
2
+ /** extends button */
3
+ import type { ElementProps, ExpandProps } from '../../types/index.js';
4
+ import { uiPresets } from '../../utils/engine/presets.js';
5
+ import type { DividerProps } from './types.js';
6
+ let {
7
+ class: className = '',
8
+ style,
9
+ element = null,
10
+ dense: density = 'default',
11
+ orientation: direction = 'horizontal',
12
+ expansion = 'full',
13
+ shadowed: shadow = false,
14
+ color
15
+ }: ExpandProps<DividerProps> = $props();
16
+
17
+ let extensionClass = {
18
+ horizontal: {
19
+ full: '',
20
+ padded: 'marg-ii-12',
21
+ centered: 'marg-ii-6'
22
+ },
23
+ vertical: {
24
+ full: '',
25
+ padded: 'marg-ii-12',
26
+ centered: 'marg-ii-6'
27
+ }
28
+ };
29
+ let addStyle: string = (style as unknown as string) ?? ('' as unknown as string);
30
+
31
+ const shadowClass = $derived(shadow ? 'shad-3' : '');
32
+
33
+ if (color) addStyle += `--sld-color-border:${color};`;
34
+
35
+ // set height od divider when direction === vertical in a flex env
36
+ if (
37
+ direction === 'vertical' &&
38
+ (element?.nextElementSibling ?? element?.previousElementSibling)
39
+ ) {
40
+ let maxHeight = (
41
+ element?.previousElementSibling ?? element?.nextElementSibling
42
+ )?.getBoundingClientRect()?.height;
43
+
44
+ addStyle += `height:calc(${maxHeight}px - ${getDensity(density)});`;
45
+ }
46
+
47
+ function getDensity(density: ElementProps['density']) {
48
+ return uiPresets.density?.[density];
49
+ }
50
+
51
+ switch (direction) {
52
+ case 'horizontal':
53
+ addStyle += `margin-top:${getDensity(density)};margin-bottom:${getDensity(density)};`;
54
+ break;
55
+ case 'vertical':
56
+ addStyle += `margin-left:${getDensity(density)};margin-right:${getDensity(density)};`;
57
+ break;
58
+ }
59
+ </script>
60
+
61
+ <hr
62
+ bind:this={element}
63
+ class="{extensionClass[direction][expansion]} {className} {shadowClass}"
64
+ class:vertical={direction === 'vertical'}
65
+ style={addStyle}
66
+ />
67
+
68
68
  <style>:root {
69
69
  --divider-border-top: var(--sld-color-border, var(--sld-color-foreground-alpha-high, #333));
70
70
  --divider-background-color: var(--sld-color-border, var(--sld-color-foreground-alpha-mid, #333));
@@ -80,4 +80,4 @@ hr {
80
80
  hr.vertical {
81
81
  width: 1px;
82
82
  border-right: 1px solid var(--divider-border-right);
83
- }</style>
83
+ }</style>
@@ -1,19 +1,19 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --divider-border-top: var(--sld-color-border, var(--sld-color-foreground-alpha-high, #333));
5
- --divider-background-color: var(--sld-color-border, var(--sld-color-foreground-alpha-mid, #333));
6
- --divider-border-right: var(--sld-color-border, var(--sld-color-foreground-alpha-mid, #333));
7
- }
8
-
9
- hr {
10
- border: none;
11
- border-top: 1px solid var(--divider-border-top);
12
- background-color: var(--divider-background-color);
13
- display: block;
14
-
15
- &.vertical {
16
- width: 1px;
17
- border-right: 1px solid var(--divider-border-right);
18
- }
19
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --divider-border-top: var(--sld-color-border, var(--sld-color-foreground-alpha-high, #333));
5
+ --divider-background-color: var(--sld-color-border, var(--sld-color-foreground-alpha-mid, #333));
6
+ --divider-border-right: var(--sld-color-border, var(--sld-color-foreground-alpha-mid, #333));
7
+ }
8
+
9
+ hr {
10
+ border: none;
11
+ border-top: 1px solid var(--divider-border-top);
12
+ background-color: var(--divider-background-color);
13
+ display: block;
14
+
15
+ &.vertical {
16
+ width: 1px;
17
+ border-right: 1px solid var(--divider-border-right);
18
+ }
19
+ }
@@ -1,24 +1,24 @@
1
- <script lang="ts">
2
- import ComponentDemo from '../demoer/DemoerComponent.svelte';
3
- import { DemoPage, Demoer } from '../../index.js';
4
- import Icon from './Icon.svelte';
5
-
6
- import { parameters, componentArgs } from './types.js';
7
-
8
- let code = `
9
- <Icon>
10
- mdi:tree
11
- </Icon>`;
12
- </script>
13
-
14
- <ComponentDemo component="Icon" cite="The icon is the window to the soul of the app">
15
- <div class="flex-v gap-small">
16
- <DemoPage component="Icon" {code}>
17
- <Demoer {parameters} {componentArgs}>
18
- {#snippet children({ activeParams })}
19
- <Icon {...activeParams} />
20
- {/snippet}
21
- </Demoer>
22
- </DemoPage>
23
- </div>
24
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import ComponentDemo from '../demoer/DemoerComponent.svelte';
3
+ import { DemoPage, Demoer } from '../../index.js';
4
+ import Icon from './Icon.svelte';
5
+
6
+ import { parameters, componentArgs } from './types.js';
7
+
8
+ let code = `
9
+ <Icon>
10
+ mdi:tree
11
+ </Icon>`;
12
+ </script>
13
+
14
+ <ComponentDemo component="Icon" cite="The icon is the window to the soul of the app">
15
+ <div class="flex-v gap-small">
16
+ <DemoPage component="Icon" {code}>
17
+ <Demoer {parameters} {componentArgs}>
18
+ {#snippet children({ activeParams })}
19
+ <Icon {...activeParams} />
20
+ {/snippet}
21
+ </Demoer>
22
+ </DemoPage>
23
+ </div>
24
+ </ComponentDemo>
@@ -1,119 +1,119 @@
1
- <script module lang="ts">
2
- import type { ElementProps, IconObj } from "../../types/index.js";
3
-
4
- /**
5
- * Properties for the IconApp component.
6
- */
7
- export type IconAppProps = {
8
- /**
9
- * Icon name for Iconify.
10
- * @param icon
11
- */
12
- icon?: ElementProps["icon"];
13
-
14
- /**
15
- * Class name of the root component.
16
- * @param class
17
- */
18
- class?: string;
19
-
20
- /**
21
- * CSS style of the root component.
22
- * @param style
23
- */
24
- style?: string;
25
-
26
- /**
27
- * Root HTMLDivElement properties.
28
- * @param element
29
- */
30
- element?: HTMLDivElement | null | any;
31
-
32
- /**
33
- * Icon object for Iconify, replaces and invalidates `icon` prop.
34
- * @param ico
35
- */
36
- ico?: IconObj;
37
-
38
- /**
39
- * Icon size.
40
- * @param iconSize
41
- */
42
- iconSize?: ElementProps["iconSize"];
43
-
44
- /**
45
- * Rotate icon.
46
- * @param rotate
47
- */
48
- rotate?: boolean;
49
-
50
- /**
51
- * Icon color.
52
- * @param color
53
- */
54
- color?: string;
55
-
56
- /**
57
- * Icon rotation.
58
- * @param rotation
59
- */
60
- rotation?: number;
61
-
62
- /**
63
- * Display property for the icon.
64
- * @param display
65
- */
66
- display?: "block" | "inline-block" | "inline";
67
- };
68
- </script>
69
-
70
- <script lang="ts">
71
- import { iconFontSize, type ExpandProps } from '../../types/index.js';
72
- import Iconify from '@iconify/svelte';
73
-
74
- let {
75
- icon = $bindable('question'),
76
- class: className,
77
- style,
78
- element = $bindable<HTMLDivElement>(),
79
- iconSize = $bindable(),
80
- rotate = false,
81
- color = $bindable(),
82
- rotation = 0,
83
- ico,
84
- display = 'inline-block',
85
- ...rest
86
- }: ExpandProps<IconAppProps> = $props();
87
-
88
- iconSize = iconSize || 'small';
89
-
90
- const sizes: Record<ElementProps['iconSize'], string> = iconFontSize;
91
-
92
- let finalI = $derived(ico?.icon ?? (typeof icon === 'object' ? icon.icon : icon));
93
- let finRot = $derived(ico?.rotate ?? (typeof icon === 'object' ? icon.rotate : rotate));
94
- let finRotation = $derived(
95
- ico?.rotation ?? (typeof icon === 'object' ? icon.rotation : rotation)
96
- );
97
- let finCol = $derived(ico?.color ?? (typeof icon === 'object' ? icon.color : color));
98
- let finSize = $derived(ico?.iconSize ?? (typeof icon === 'object' ? iconSize : iconSize));
99
- let iconName = $derived(finalI.includes(':') ? finalI : `mdi:${finalI}`);
100
-
101
- let finalStyle = $derived(
102
- `display:${display};font-size:${sizes[finSize]};color:${finCol};transform: rotate(${finRotation}deg);${style};`
103
- );
104
-
105
- </script>
106
-
107
- {#key [icon, iconName, color, finalStyle]}
108
- <Iconify
109
- bind:this={element}
110
- class="icon medium {className} {finRot ? 'rotate' : ''}"
111
- style={finalStyle}
112
- icon={iconName}
113
- {...rest}
114
- />
115
- {/key}
116
-
1
+ <script module lang="ts">
2
+ import type { ElementProps, IconObj } from "../../types/index.js";
3
+
4
+ /**
5
+ * Properties for the IconApp component.
6
+ */
7
+ export type IconAppProps = {
8
+ /**
9
+ * Icon name for Iconify.
10
+ * @param icon
11
+ */
12
+ icon?: ElementProps["icon"];
13
+
14
+ /**
15
+ * Class name of the root component.
16
+ * @param class
17
+ */
18
+ class?: string;
19
+
20
+ /**
21
+ * CSS style of the root component.
22
+ * @param style
23
+ */
24
+ style?: string;
25
+
26
+ /**
27
+ * Root HTMLDivElement properties.
28
+ * @param element
29
+ */
30
+ element?: HTMLDivElement | null | any;
31
+
32
+ /**
33
+ * Icon object for Iconify, replaces and invalidates `icon` prop.
34
+ * @param ico
35
+ */
36
+ ico?: IconObj;
37
+
38
+ /**
39
+ * Icon size.
40
+ * @param iconSize
41
+ */
42
+ iconSize?: ElementProps["iconSize"];
43
+
44
+ /**
45
+ * Rotate icon.
46
+ * @param rotate
47
+ */
48
+ rotate?: boolean;
49
+
50
+ /**
51
+ * Icon color.
52
+ * @param color
53
+ */
54
+ color?: string;
55
+
56
+ /**
57
+ * Icon rotation.
58
+ * @param rotation
59
+ */
60
+ rotation?: number;
61
+
62
+ /**
63
+ * Display property for the icon.
64
+ * @param display
65
+ */
66
+ display?: "block" | "inline-block" | "inline";
67
+ };
68
+ </script>
69
+
70
+ <script lang="ts">
71
+ import { iconFontSize, type ExpandProps } from '../../types/index.js';
72
+ import Iconify from '@iconify/svelte';
73
+
74
+ let {
75
+ icon = $bindable('question'),
76
+ class: className,
77
+ style,
78
+ element = $bindable<HTMLDivElement>(),
79
+ iconSize = $bindable(),
80
+ rotate = false,
81
+ color = $bindable(),
82
+ rotation = 0,
83
+ ico,
84
+ display = 'inline-block',
85
+ ...rest
86
+ }: ExpandProps<IconAppProps> = $props();
87
+
88
+ iconSize = iconSize || 'small';
89
+
90
+ const sizes: Record<ElementProps['iconSize'], string> = iconFontSize;
91
+
92
+ let finalI = $derived(ico?.icon ?? (typeof icon === 'object' ? icon.icon : icon));
93
+ let finRot = $derived(ico?.rotate ?? (typeof icon === 'object' ? icon.rotate : rotate));
94
+ let finRotation = $derived(
95
+ ico?.rotation ?? (typeof icon === 'object' ? icon.rotation : rotation)
96
+ );
97
+ let finCol = $derived(ico?.color ?? (typeof icon === 'object' ? icon.color : color));
98
+ let finSize = $derived(ico?.iconSize ?? (typeof icon === 'object' ? iconSize : iconSize));
99
+ let iconName = $derived(finalI.includes(':') ? finalI : `mdi:${finalI}`);
100
+
101
+ let finalStyle = $derived(
102
+ `display:${display};font-size:${sizes[finSize]};color:${finCol};transform: rotate(${finRotation}deg);${style};`
103
+ );
104
+
105
+ </script>
106
+
107
+ {#key [icon, iconName, color, finalStyle]}
108
+ <Iconify
109
+ bind:this={element}
110
+ class="icon medium {className} {finRot ? 'rotate' : ''}"
111
+ style={finalStyle}
112
+ icon={iconName}
113
+ {...rest}
114
+ />
115
+ {/key}
116
+
117
117
  <style>:global(.icon) {
118
118
  transition: all 0.2;
119
119
  }
@@ -129,4 +129,4 @@ export type IconAppProps = {
129
129
  100% {
130
130
  transform: rotate(360deg);
131
131
  }
132
- }</style>
132
+ }</style>
@@ -65,6 +65,6 @@ declare const Icon: import("svelte").Component<{
65
65
  color?: string | undefined;
66
66
  rotation?: number | undefined;
67
67
  display?: "block" | "inline-block" | "inline" | undefined;
68
- }, {}, "icon" | "iconSize" | "element" | "color">;
68
+ }, {}, "element" | "icon" | "iconSize" | "color">;
69
69
  type Icon = ReturnType<typeof Icon>;
70
70
  export default Icon;
@@ -1,17 +1,17 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :global(.icon) {
4
- transition: all 0.2;
5
- }
6
-
7
- .rotate {
8
- animation: spinner-frames 3s infinite linear;
9
- }
10
- @keyframes spinner-frames {
11
- 0% {
12
- transform: rotate(0deg);
13
- }
14
- 100% {
15
- transform: rotate(360deg);
16
- }
17
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :global(.icon) {
4
+ transition: all 0.2;
5
+ }
6
+
7
+ .rotate {
8
+ animation: spinner-frames 3s infinite linear;
9
+ }
10
+ @keyframes spinner-frames {
11
+ 0% {
12
+ transform: rotate(0deg);
13
+ }
14
+ 100% {
15
+ transform: rotate(360deg);
16
+ }
17
+ }
@@ -1,31 +1,31 @@
1
- <script lang="ts">
2
- import ComponentDemo from '../demoer/DemoerComponent.svelte';
3
- import DemoPage from '../demoer/DemoPage.svelte';
4
- import Demoer from '../demoer/Demoer.svelte';
5
- import { defaultsArgs } from '../demoer/demoer.utils.js';
6
- import Paper from './Paper.svelte';
7
- import { paperDemoValues, type PaperProps } from './type.js';
8
-
9
- let parameters = paperDemoValues;
10
- let componentArgs = defaultsArgs(parameters);
11
-
12
- let code = `
13
- <Paper elevation="2" style="height:350px;width:250px" >
14
- paper content
15
- </Paper>`;
16
- </script>
17
-
18
- <ComponentDemo
19
- component="Paper"
20
- cite="What is separating before from after is not a time nor a place : it's only a component <br /> B. Franklin, 1854"
21
- >
22
- <div class=" flex-v gap-small">
23
- <DemoPage component="Paper" {code}>
24
- <Demoer {parameters} {componentArgs}>
25
- {#snippet children({ activeParams })}
26
- <Paper {...activeParams} style="height:350px;width:250px" />
27
- {/snippet}
28
- </Demoer>
29
- </DemoPage>
30
- </div>
31
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import ComponentDemo from '../demoer/DemoerComponent.svelte';
3
+ import DemoPage from '../demoer/DemoPage.svelte';
4
+ import Demoer from '../demoer/Demoer.svelte';
5
+ import { defaultsArgs } from '../demoer/demoer.utils.js';
6
+ import Paper from './Paper.svelte';
7
+ import { paperDemoValues, type PaperProps } from './type.js';
8
+
9
+ let parameters = paperDemoValues;
10
+ let componentArgs = defaultsArgs(parameters);
11
+
12
+ let code = `
13
+ <Paper elevation="2" style="height:350px;width:250px" >
14
+ paper content
15
+ </Paper>`;
16
+ </script>
17
+
18
+ <ComponentDemo
19
+ component="Paper"
20
+ cite="What is separating before from after is not a time nor a place : it's only a component <br /> B. Franklin, 1854"
21
+ >
22
+ <div class=" flex-v gap-small">
23
+ <DemoPage component="Paper" {code}>
24
+ <Demoer {parameters} {componentArgs}>
25
+ {#snippet children({ activeParams })}
26
+ <Paper {...activeParams} style="height:350px;width:250px" />
27
+ {/snippet}
28
+ </Demoer>
29
+ </DemoPage>
30
+ </div>
31
+ </ComponentDemo>