@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,41 +1,41 @@
1
- <script lang="ts">
2
- import ComponentDemo from '../demoer/DemoerComponent.svelte';
3
- import Demoer from '../demoer/Demoer.svelte';
4
- import DemoPage from '../demoer/DemoPage.svelte';
5
- import Icon from '../icon/Icon.svelte';
6
- import Avatar from './Avatar.svelte';
7
-
8
- import { parameters, componentArgs } from './types.js';
9
-
10
- let code1 = `
11
- <Avatar>
12
- <Icon icon={activeParams?.icon} />
13
- </Avatar>`;
14
-
15
- let code2 = `
16
- <Avatar icon={icon} />`;
17
- </script>
18
-
19
- <ComponentDemo
20
- component="Avatar"
21
- cite="If it's not you, then it's the other you, <br /> Emma Avatar you, 1652"
22
- >
23
- <div class="flex-v gap-large">
24
- <DemoPage component="Rating" code={code1}>
25
- <Demoer {parameters} {componentArgs}>
26
- {#snippet children({ activeParams })}
27
- <Avatar {...activeParams}>
28
- <Icon icon={activeParams?.icon} />
29
- </Avatar>
30
- {/snippet}
31
- </Demoer>
32
- </DemoPage>
33
- <DemoPage title="Without slots" code={code2} component="Rating">
34
- <Demoer {parameters} {componentArgs}>
35
- {#snippet children({ activeParams })}
36
- <Avatar {...activeParams} icon={activeParams?.icon} />
37
- {/snippet}
38
- </Demoer>
39
- </DemoPage>
40
- </div>
41
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import ComponentDemo from '../demoer/DemoerComponent.svelte';
3
+ import Demoer from '../demoer/Demoer.svelte';
4
+ import DemoPage from '../demoer/DemoPage.svelte';
5
+ import Icon from '../icon/Icon.svelte';
6
+ import Avatar from './Avatar.svelte';
7
+
8
+ import { parameters, componentArgs } from './types.js';
9
+
10
+ let code1 = `
11
+ <Avatar>
12
+ <Icon icon={activeParams?.icon} />
13
+ </Avatar>`;
14
+
15
+ let code2 = `
16
+ <Avatar icon={icon} />`;
17
+ </script>
18
+
19
+ <ComponentDemo
20
+ component="Avatar"
21
+ cite="If it's not you, then it's the other you, <br /> Emma Avatar you, 1652"
22
+ >
23
+ <div class="flex-v gap-large">
24
+ <DemoPage component="Rating" code={code1}>
25
+ <Demoer {parameters} {componentArgs}>
26
+ {#snippet children({ activeParams })}
27
+ <Avatar {...activeParams}>
28
+ <Icon icon={activeParams?.icon} />
29
+ </Avatar>
30
+ {/snippet}
31
+ </Demoer>
32
+ </DemoPage>
33
+ <DemoPage title="Without slots" code={code2} component="Rating">
34
+ <Demoer {parameters} {componentArgs}>
35
+ {#snippet children({ activeParams })}
36
+ <Avatar {...activeParams} icon={activeParams?.icon} />
37
+ {/snippet}
38
+ </Demoer>
39
+ </DemoPage>
40
+ </div>
41
+ </ComponentDemo>
@@ -1,6 +1,6 @@
1
- <script lang="ts">
2
- import Icon from '../icon/Icon.svelte';
3
- import Avatar from './Avatar.svelte';
4
- </script>
5
-
6
- <Avatar size="tiny" class="marg-4"><Icon icon="user" /></Avatar>
1
+ <script lang="ts">
2
+ import Icon from '../icon/Icon.svelte';
3
+ import Avatar from './Avatar.svelte';
4
+ </script>
5
+
6
+ <Avatar size="tiny" class="marg-4"><Icon icon="user" /></Avatar>
@@ -1,67 +1,67 @@
1
- <script module lang="ts" >
2
- import type { Snippet } from "svelte";
3
- import type { CommonProps,ElementProps } from '../../types/index.js';
4
-
5
- export interface AvatarProps {
6
- /** icon name */
7
- icon?: string;
8
- /**
9
- * size of the avatar
10
- */
11
- size?: ElementProps["width"];
12
- /**
13
- * size of the icon
14
- */
15
- iconSize?: ElementProps["iconSize"];
16
- element?: HTMLElement;
17
- class?: string;
18
- children?: Snippet;
19
- avatarBadge?: Snippet;
20
- };
21
-
22
- </script>
23
-
24
- <script lang="ts">
25
- import Icon from '../icon/Icon.svelte';
26
- import type { ExpandProps } from '../../types/index.js';
27
- import Content from '../../utils/content/Content.svelte';
28
-
29
- let {
30
- icon = 'icon-park-outline:avatar',
31
- size,
32
- iconSize,
33
- class: className = '',
34
- element = $bindable(),
35
- children,
36
- avatarBadge,
37
- ...rest
38
- }: AvatarProps = $props();
39
-
40
- const sizes = {
41
- tiny: '2rem',
42
- small: '4rem',
43
- medium: '8rem',
44
- large: '12rem',
45
- full: '100%'
46
- };
47
- </script>
48
-
49
- <Content
50
- bind:element
51
- tag="figure"
52
- class="avatar {className}"
53
- style="width:{sizes[size]};height:{sizes[size]}"
54
- {...rest}
55
- >
56
- {@render avatarBadge?.()}
57
-
58
- {#if children}
59
- {@render children()}
60
- {:else}
61
- <Icon {icon} {iconSize} />
62
- {/if}
63
- </Content>
64
-
1
+ <script module lang="ts" >
2
+ import type { Snippet } from "svelte";
3
+ import type { CommonProps,ElementProps } from '../../types/index.js';
4
+
5
+ export interface AvatarProps {
6
+ /** icon name */
7
+ icon?: string;
8
+ /**
9
+ * size of the avatar
10
+ */
11
+ size?: ElementProps["width"];
12
+ /**
13
+ * size of the icon
14
+ */
15
+ iconSize?: ElementProps["iconSize"];
16
+ element?: HTMLElement;
17
+ class?: string;
18
+ children?: Snippet;
19
+ avatarBadge?: Snippet;
20
+ };
21
+
22
+ </script>
23
+
24
+ <script lang="ts">
25
+ import Icon from '../icon/Icon.svelte';
26
+ import type { ExpandProps } from '../../types/index.js';
27
+ import Content from '../../utils/content/Content.svelte';
28
+
29
+ let {
30
+ icon = 'icon-park-outline:avatar',
31
+ size,
32
+ iconSize,
33
+ class: className = '',
34
+ element = $bindable(),
35
+ children,
36
+ avatarBadge,
37
+ ...rest
38
+ }: AvatarProps = $props();
39
+
40
+ const sizes = {
41
+ tiny: '2rem',
42
+ small: '4rem',
43
+ medium: '8rem',
44
+ large: '12rem',
45
+ full: '100%'
46
+ };
47
+ </script>
48
+
49
+ <Content
50
+ bind:element
51
+ tag="figure"
52
+ class="avatar {className}"
53
+ style="width:{sizes[size]};height:{sizes[size]}"
54
+ {...rest}
55
+ >
56
+ {@render avatarBadge?.()}
57
+
58
+ {#if children}
59
+ {@render children()}
60
+ {:else}
61
+ <Icon {icon} {iconSize} />
62
+ {/if}
63
+ </Content>
64
+
65
65
  <style>:root {
66
66
  --avatar-radius: var(--css-radius-small);
67
67
  --avatar-border-color: var(--sld-color-border);
@@ -74,4 +74,4 @@ export interface AvatarProps {
74
74
  display: grid;
75
75
  place-items: center;
76
76
  overflow: hidden;
77
- }</style>
77
+ }</style>
@@ -1,17 +1,17 @@
1
- // @import "../../styles/slotui-presets.scss";
2
-
3
- @use "../../styles/slotui-mixins.scss";
4
-
5
- :root {
6
- --avatar-radius: var(--css-radius-small);
7
- --avatar-border-color: var(--sld-color-border);
8
- }
9
-
10
- .avatar {
11
- position: relative;
12
- border-radius: var(--avatar-radius);
13
- border: 1px solid var(--avatar-border-color);
14
- display: grid;
15
- place-items: center;
16
- overflow: hidden;
17
- }
1
+ // @import "../../styles/slotui-presets.scss";
2
+
3
+ @use "../../styles/slotui-mixins.scss";
4
+
5
+ :root {
6
+ --avatar-radius: var(--css-radius-small);
7
+ --avatar-border-color: var(--sld-color-border);
8
+ }
9
+
10
+ .avatar {
11
+ position: relative;
12
+ border-radius: var(--avatar-radius);
13
+ border: 1px solid var(--avatar-border-color);
14
+ display: grid;
15
+ place-items: center;
16
+ overflow: hidden;
17
+ }
@@ -1,49 +1,49 @@
1
- <script lang="ts">
2
- import ComponentDemo from '../demoer/DemoerComponent.svelte';
3
- import Demoer from '../demoer/Demoer.svelte';
4
- import DemoPage from '../demoer/DemoPage.svelte';
5
- import { defaultsArgs } from '../demoer/demoer.utils.js';
6
- import Backdrop from './Backdrop.svelte';
7
- import { BackdropDemoValues } from './types.js';
8
-
9
- import { parameters, componentArgs } from './types.js';
10
-
11
- let codeSlot = `
12
- <Backdrop
13
- flow="relative"
14
- onclick={()=>{}}>
15
- <div class="flex-h flex-align-middle-center h-full">
16
- <div class="pad-4 border radius-small theme-bg">
17
- some content
18
- </div>
19
- </div>
20
- </Backdrop>`;
21
-
22
- let BackdropRef: Backdrop;
23
- </script>
24
-
25
- <ComponentDemo component="Backdrop">
26
- <div class="flex-v gap-medium">
27
- <DemoPage code={codeSlot} component="Backdrop">
28
- <Demoer {parameters} {componentArgs}>
29
- {#snippet children({ activeParams })}
30
- <div style="width:350px;height:350px;position:realive;">
31
- <Backdrop
32
- bind:this={BackdropRef}
33
- onclick={() => {
34
- componentArgs.flow = 'relative';
35
- BackdropRef.flow = 'relative';
36
- }}
37
- {...componentArgs}
38
- {...activeParams}
39
- >
40
- <div class="flex-h flex-align-middle-center h-full">
41
- <div class="pad-4 border radius-small theme-bg">some content</div>
42
- </div>
43
- </Backdrop>
44
- </div>
45
- {/snippet}
46
- </Demoer>
47
- </DemoPage>
48
- </div>
49
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import ComponentDemo from '../demoer/DemoerComponent.svelte';
3
+ import Demoer from '../demoer/Demoer.svelte';
4
+ import DemoPage from '../demoer/DemoPage.svelte';
5
+ import { defaultsArgs } from '../demoer/demoer.utils.js';
6
+ import Backdrop from './Backdrop.svelte';
7
+ import { BackdropDemoValues } from './types.js';
8
+
9
+ import { parameters, componentArgs } from './types.js';
10
+
11
+ let codeSlot = `
12
+ <Backdrop
13
+ flow="relative"
14
+ onclick={()=>{}}>
15
+ <div class="flex-h flex-align-middle-center h-full">
16
+ <div class="pad-4 border radius-small theme-bg">
17
+ some content
18
+ </div>
19
+ </div>
20
+ </Backdrop>`;
21
+
22
+ let BackdropRef: Backdrop;
23
+ </script>
24
+
25
+ <ComponentDemo component="Backdrop">
26
+ <div class="flex-v gap-medium">
27
+ <DemoPage code={codeSlot} component="Backdrop">
28
+ <Demoer {parameters} {componentArgs}>
29
+ {#snippet children({ activeParams })}
30
+ <div style="width:350px;height:350px;position:realive;">
31
+ <Backdrop
32
+ bind:this={BackdropRef}
33
+ onclick={() => {
34
+ componentArgs.flow = 'relative';
35
+ BackdropRef.flow = 'relative';
36
+ }}
37
+ {...componentArgs}
38
+ {...activeParams}
39
+ >
40
+ <div class="flex-h flex-align-middle-center h-full">
41
+ <div class="pad-4 border radius-small theme-bg">some content</div>
42
+ </div>
43
+ </Backdrop>
44
+ </div>
45
+ {/snippet}
46
+ </Demoer>
47
+ </DemoPage>
48
+ </div>
49
+ </ComponentDemo>
@@ -1,80 +1,80 @@
1
- <script lang="ts">
2
- import { fade } from 'svelte/transition';
3
- import Icon from '../icon/Icon.svelte';
4
- import type { CommonProps, ExpandProps } from '../../types/index.js';
5
- import type { BackdropProps } from './types.js';
6
- import Slotted from '../../utils/slotted/Slotted.svelte';
7
-
8
- /** Backdrop controller */
9
- export const actions = {
10
- close: () => {
11
- isOpen = false;
12
- },
13
- open: () => {
14
- isOpen = true;
15
- }
16
- };
17
-
18
- let {
19
- class: className,
20
- style,
21
- flow = 'fixed',
22
- autoClose = false,
23
- isOpen = $bindable(),
24
- onclick,
25
- isLoading = false,
26
- element,
27
- elementContent,
28
- elementContentInner,
29
- component,
30
- componentProps,
31
- classes = {},
32
- children,
33
- backdropLoading
34
- }: BackdropProps = $props();
35
-
36
- $effect(() => {
37
- element?.addEventListener('click', testAutoClose);
38
- elementContentInner?.addEventListener('click', (event) => {
39
- event.stopPropagation();
40
- });
41
- });
42
-
43
- function testAutoClose() {
44
- if (autoClose) isOpen = false;
45
- }
46
- </script>
47
-
48
- {#if isOpen}
49
- <div
50
- in:fade|global
51
- out:fade|global
52
- bind:this={element}
53
- class="backdrop {className}"
54
- style="position:{flow};{style}"
55
- role="dialog"
56
- tabindex="-1"
57
- >
58
- <div bind:this={elementContent} class="backdrop-content">
59
- {#if isLoading}
60
- <div class="backdrop-content-loader">
61
- <Slotted child={backdropLoading}>
62
- <Icon icon="mdi:loading" iconSize="large" rotate />
63
- </Slotted>
64
- </div>
65
- {:else}
66
- <div class="backdrop-content-inner" bind:this={elementContentInner}>
67
- {#if children}
68
- {@render children?.()}
69
- {:else if component}
70
- <svelte:component this={component} {...componentProps} />
71
- {/if}
72
- </div>
73
- {/if}
74
- </div>
75
- </div>
76
- {/if}
77
-
1
+ <script lang="ts">
2
+ import { fade } from 'svelte/transition';
3
+ import Icon from '../icon/Icon.svelte';
4
+ import type { CommonProps, ExpandProps } from '../../types/index.js';
5
+ import type { BackdropProps } from './types.js';
6
+ import Slotted from '../../utils/slotted/Slotted.svelte';
7
+
8
+ /** Backdrop controller */
9
+ export const actions = {
10
+ close: () => {
11
+ isOpen = false;
12
+ },
13
+ open: () => {
14
+ isOpen = true;
15
+ }
16
+ };
17
+
18
+ let {
19
+ class: className,
20
+ style,
21
+ flow = 'fixed',
22
+ autoClose = false,
23
+ isOpen = $bindable(),
24
+ onclick,
25
+ isLoading = false,
26
+ element,
27
+ elementContent,
28
+ elementContentInner,
29
+ component,
30
+ componentProps,
31
+ classes = {},
32
+ children,
33
+ backdropLoading
34
+ }: BackdropProps = $props();
35
+
36
+ $effect(() => {
37
+ element?.addEventListener('click', testAutoClose);
38
+ elementContentInner?.addEventListener('click', (event) => {
39
+ event.stopPropagation();
40
+ });
41
+ });
42
+
43
+ function testAutoClose() {
44
+ if (autoClose) isOpen = false;
45
+ }
46
+ </script>
47
+
48
+ {#if isOpen}
49
+ <div
50
+ in:fade|global
51
+ out:fade|global
52
+ bind:this={element}
53
+ class="backdrop {className}"
54
+ style="position:{flow};{style}"
55
+ role="dialog"
56
+ tabindex="-1"
57
+ >
58
+ <div bind:this={elementContent} class="backdrop-content">
59
+ {#if isLoading}
60
+ <div class="backdrop-content-loader">
61
+ <Slotted child={backdropLoading}>
62
+ <Icon icon="mdi:loading" iconSize="large" rotate />
63
+ </Slotted>
64
+ </div>
65
+ {:else}
66
+ <div class="backdrop-content-inner" bind:this={elementContentInner}>
67
+ {#if children}
68
+ {@render children?.()}
69
+ {:else if component}
70
+ <svelte:component this={component} {...componentProps} />
71
+ {/if}
72
+ </div>
73
+ {/if}
74
+ </div>
75
+ </div>
76
+ {/if}
77
+
78
78
  <style>:root {
79
79
  --backdrop-background-color: var(--sld-color-foreground-alpha-high);
80
80
  }
@@ -106,4 +106,4 @@
106
106
  }
107
107
  .backdrop-content-inner {
108
108
  display: inherit;
109
- }</style>
109
+ }</style>
@@ -1,34 +1,34 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --backdrop-background-color: var(--sld-color-foreground-alpha-high);
5
- }
6
-
7
- .backdrop {
8
- z-index: 10000;
9
- height: 100%;
10
- width: 100%;
11
- top: 0;
12
- left: 0;
13
- &-content {
14
- z-index: 10001;
15
- position: absolute;
16
- height: 100%;
17
- width: 100%;
18
- background-color: var(--backdrop-background-color);
19
- backdrop-filter: blur(5px);
20
- --moz-backdrop-filter: blur(5px);
21
- display: flex;
22
- align-items: center;
23
- justify-content: center;
24
- &-loader {
25
- display: flex;
26
- justify-content: center;
27
- align-content: center;
28
- align-items: center;
29
- }
30
- &-inner {
31
- display: inherit;
32
- }
33
- }
34
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --backdrop-background-color: var(--sld-color-foreground-alpha-high);
5
+ }
6
+
7
+ .backdrop {
8
+ z-index: 10000;
9
+ height: 100%;
10
+ width: 100%;
11
+ top: 0;
12
+ left: 0;
13
+ &-content {
14
+ z-index: 10001;
15
+ position: absolute;
16
+ height: 100%;
17
+ width: 100%;
18
+ background-color: var(--backdrop-background-color);
19
+ backdrop-filter: blur(5px);
20
+ --moz-backdrop-filter: blur(5px);
21
+ display: flex;
22
+ align-items: center;
23
+ justify-content: center;
24
+ &-loader {
25
+ display: flex;
26
+ justify-content: center;
27
+ align-content: center;
28
+ align-items: center;
29
+ }
30
+ &-inner {
31
+ display: inherit;
32
+ }
33
+ }
34
+ }
@@ -1,33 +1,33 @@
1
- <script lang="ts">
2
- import Slotted from '../../utils/slotted/Slotted.svelte';
3
- import type { BadgeProps } from './types.js';
4
-
5
- let {
6
- value,
7
- ceiling,
8
- element,
9
- position = { x: 'right', y: 'top' },
10
- children
11
- }: BadgeProps = $props();
12
-
13
- const xM = {
14
- left: 'left:0',
15
- right: 'right:0',
16
- center: 'left:50%;transformation:translate(-50%,0)'
17
- };
18
- const yM = {
19
- top: 'top:0',
20
- bottom: 'bottom:0',
21
- center: 'top:50%;transformation:translate(0,-50%)'
22
- };
23
- </script>
24
-
25
- {#if value > ceiling}
26
- <div bind:this={element} class="badge" style="{xM[position.x]};{yM[position.y]}">
27
- <Slotted child={children}>{value}</Slotted>
28
- </div>
29
- {/if}
30
-
1
+ <script lang="ts">
2
+ import Slotted from '../../utils/slotted/Slotted.svelte';
3
+ import type { BadgeProps } from './types.js';
4
+
5
+ let {
6
+ value,
7
+ ceiling,
8
+ element,
9
+ position = { x: 'right', y: 'top' },
10
+ children
11
+ }: BadgeProps = $props();
12
+
13
+ const xM = {
14
+ left: 'left:0',
15
+ right: 'right:0',
16
+ center: 'left:50%;transformation:translate(-50%,0)'
17
+ };
18
+ const yM = {
19
+ top: 'top:0',
20
+ bottom: 'bottom:0',
21
+ center: 'top:50%;transformation:translate(0,-50%)'
22
+ };
23
+ </script>
24
+
25
+ {#if value > ceiling}
26
+ <div bind:this={element} class="badge" style="{xM[position.x]};{yM[position.y]}">
27
+ <Slotted child={children}>{value}</Slotted>
28
+ </div>
29
+ {/if}
30
+
31
31
  <style>:root {
32
32
  --badge-color-border: var(--sld-color-border);
33
33
  }
@@ -43,4 +43,4 @@
43
43
  }
44
44
  .badge .hidden {
45
45
  transform: scale(0, 0);
46
- }</style>
46
+ }</style>