@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,165 +1,165 @@
1
- <script lang="ts" generics="T">
2
- import IconButton from '../../controls/button/IconButton.svelte';
3
- import Button from '../../controls/button/Button.svelte';
4
- import Icon from '../../base/icon/Icon.svelte';
5
- import type { DrawerProps } from './types.js';
6
- import Slotted from '../../utils/slotted/Slotted.svelte';
7
- import type { ExpandProps } from '../../types/index.js';
8
-
9
- /** @deprecated use actions.toggle */
10
- export const actions = {
11
- toggle: (visibleSate?: boolean) => {
12
- isOpen = visibleSate !== undefined ? visibleSate : !isOpen;
13
- }
14
- };
15
- export function toggle(visibleSate?: boolean) {
16
- isOpen = visibleSate !== undefined ? visibleSate : !isOpen;
17
- }
18
-
19
- let {
20
- class: className = '',
21
- style,
22
- primary = undefined,
23
- secondary = undefined,
24
- icon,
25
- hideCloseIcon = $bindable(false),
26
- showOpenerIcon = false,
27
- element = $bindable(),
28
- isOpen = $bindable(true),
29
- flow = $bindable('fixed'),
30
- stickTo = $bindable('left'),
31
- defaultWidth = '288px',
32
- defaultVisibleArea = '0px',
33
- defaultHeight = '288px',
34
- drawerContent,
35
- drawerIcon,
36
- drawerTitle,
37
- drawerPrimary,
38
- drawerSecondary,
39
- drawerTop,
40
- drawerFooter,
41
- children,
42
- ...rest
43
- }: ExpandProps<DrawerProps<T>> = $props();
44
-
45
- let dspStyle: string;
46
-
47
- const stickToStyle = {
48
- right: 'right:0;top:0;height:100%;height:100%;',
49
- left: 'left:0;top:0;bottom:0;height:100%;height:100%;',
50
- top: `left:0;right:0;top:0;height:${defaultHeight};`,
51
- bottom: `left:0;right:0;bottom:0;height:${defaultHeight};`
52
- };
53
-
54
- const openerIconStyle = {
55
- right: 'left:-16px;top:8px;',
56
- left: 'right:-16px;top:8px;',
57
- top: 'bottom:-16px;right:8px;',
58
- bottom: 'top:-16px;right:8px;'
59
- };
60
-
61
- let sensSuffix = '';
62
- let dimKeyVary: string;
63
- let widthStyle: string;
64
- let finalStyle: string = $state('');
65
- let sens: number = 0;
66
- $effect(() => {
67
- dimKeyVary = ['top', 'bottom'].includes(stickTo) ? 'height' : 'width';
68
- switch (stickTo) {
69
- case 'top':
70
- sensSuffix = isOpen ? 'up' : 'down';
71
- sens = isOpen ? 180 : 0;
72
- break;
73
- case 'right':
74
- sensSuffix = isOpen ? 'right' : 'left';
75
- sens = isOpen ? 180 : 0;
76
- break;
77
- case 'bottom':
78
- sensSuffix = isOpen ? 'down' : 'up';
79
- sens = isOpen ? 180 : 0;
80
- break;
81
- case 'left':
82
- sensSuffix = isOpen ? 'left' : 'right';
83
- sens = isOpen ? 180 : 0;
84
- break;
85
- }
86
- });
87
-
88
- $effect(() => {
89
- dspStyle = isOpen ? 'flex' : 'flex';
90
- widthStyle = isOpen ? defaultWidth : defaultVisibleArea;
91
- finalStyle = `display:${dspStyle};position:${flow};${stickToStyle[stickTo]};${dimKeyVary}:${widthStyle};${style};`;
92
- });
93
- </script>
94
-
95
- <div
96
- bind:this={element}
97
- class="drawer {className}"
98
- style={finalStyle}
99
- aria-expanded={isOpen}
100
- aria-orientation="vertical"
101
- {...rest}
102
- >
103
- {#if showOpenerIcon}
104
- <div class="drawer-opener" style={openerIconStyle[stickTo]}>
105
- <IconButton
106
- --sld-button-radius="50%"
107
- icon={'chevron-right'}
108
- rotation={sens}
109
- style="cursor:pointer;"
110
- onclick={() => actions.toggle()}
111
- />
112
- </div>
113
- {/if}
114
- {#if isOpen}
115
- {#if drawerTop || drawerIcon || Boolean(primary) || Boolean(icon)}
116
- <header class="drawer-header">
117
- {#if Boolean(icon) || drawerIcon}
118
- <div class="drawer-icon">
119
- <Slotted child={drawerIcon}>
120
- <Icon {icon} />
121
- </Slotted>
122
- </div>
123
- {/if}
124
- <div class="drawer-header-bar">
125
- <div class="drawer-header-bar-title">
126
- <Slotted child={drawerTitle}>
127
- <Slotted child={drawerPrimary}>
128
- {#if primary}
129
- <div style="font-size:18px;">{primary}</div>
130
- {/if}
131
- </Slotted>
132
- <Slotted child={drawerSecondary}>
133
- {#if secondary}
134
- <div>{secondary}</div>
135
- {/if}
136
- </Slotted>
137
- </Slotted>
138
- </div>
139
- <Slotted child={drawerTop}></Slotted>
140
- </div>
141
- {#if !hideCloseIcon && !showOpenerIcon}
142
- <Button
143
- onclick={() => {
144
- toggle();
145
- }}
146
- icon="window-close"
147
- variant="naked"
148
- />
149
- {/if}
150
- </header>
151
- {/if}
152
- <div class="drawer-content">
153
- <Slotted child={drawerContent}>
154
- <Slotted child={children}></Slotted>
155
- </Slotted>
156
- </div>
157
- <footer>
158
- <Slotted child={drawerFooter}></Slotted>
159
- </footer>
160
- {/if}
161
- </div>
162
-
1
+ <script lang="ts" generics="T">
2
+ import IconButton from '../../controls/button/IconButton.svelte';
3
+ import Button from '../../controls/button/Button.svelte';
4
+ import Icon from '../../base/icon/Icon.svelte';
5
+ import type { DrawerProps } from './types.js';
6
+ import Slotted from '../../utils/slotted/Slotted.svelte';
7
+ import type { ExpandProps } from '../../types/index.js';
8
+
9
+ /** @deprecated use actions.toggle */
10
+ export const actions = {
11
+ toggle: (visibleSate?: boolean) => {
12
+ isOpen = visibleSate !== undefined ? visibleSate : !isOpen;
13
+ }
14
+ };
15
+ export function toggle(visibleSate?: boolean) {
16
+ isOpen = visibleSate !== undefined ? visibleSate : !isOpen;
17
+ }
18
+
19
+ let {
20
+ class: className = '',
21
+ style,
22
+ primary = undefined,
23
+ secondary = undefined,
24
+ icon,
25
+ hideCloseIcon = $bindable(false),
26
+ showOpenerIcon = false,
27
+ element = $bindable(),
28
+ isOpen = $bindable(true),
29
+ flow = $bindable('fixed'),
30
+ stickTo = $bindable('left'),
31
+ defaultWidth = '288px',
32
+ defaultVisibleArea = '0px',
33
+ defaultHeight = '288px',
34
+ drawerContent,
35
+ drawerIcon,
36
+ drawerTitle,
37
+ drawerPrimary,
38
+ drawerSecondary,
39
+ drawerTop,
40
+ drawerFooter,
41
+ children,
42
+ ...rest
43
+ }: ExpandProps<DrawerProps<T>> = $props();
44
+
45
+ let dspStyle: string;
46
+
47
+ const stickToStyle = {
48
+ right: 'right:0;top:0;height:100%;height:100%;',
49
+ left: 'left:0;top:0;bottom:0;height:100%;height:100%;',
50
+ top: `left:0;right:0;top:0;height:${defaultHeight};`,
51
+ bottom: `left:0;right:0;bottom:0;height:${defaultHeight};`
52
+ };
53
+
54
+ const openerIconStyle = {
55
+ right: 'left:-16px;top:8px;',
56
+ left: 'right:-16px;top:8px;',
57
+ top: 'bottom:-16px;right:8px;',
58
+ bottom: 'top:-16px;right:8px;'
59
+ };
60
+
61
+ let sensSuffix = '';
62
+ let dimKeyVary: string;
63
+ let widthStyle: string;
64
+ let finalStyle: string = $state('');
65
+ let sens: number = 0;
66
+ $effect(() => {
67
+ dimKeyVary = ['top', 'bottom'].includes(stickTo) ? 'height' : 'width';
68
+ switch (stickTo) {
69
+ case 'top':
70
+ sensSuffix = isOpen ? 'up' : 'down';
71
+ sens = isOpen ? 180 : 0;
72
+ break;
73
+ case 'right':
74
+ sensSuffix = isOpen ? 'right' : 'left';
75
+ sens = isOpen ? 180 : 0;
76
+ break;
77
+ case 'bottom':
78
+ sensSuffix = isOpen ? 'down' : 'up';
79
+ sens = isOpen ? 180 : 0;
80
+ break;
81
+ case 'left':
82
+ sensSuffix = isOpen ? 'left' : 'right';
83
+ sens = isOpen ? 180 : 0;
84
+ break;
85
+ }
86
+ });
87
+
88
+ $effect(() => {
89
+ dspStyle = isOpen ? 'flex' : 'flex';
90
+ widthStyle = isOpen ? defaultWidth : defaultVisibleArea;
91
+ finalStyle = `display:${dspStyle};position:${flow};${stickToStyle[stickTo]};${dimKeyVary}:${widthStyle};${style};`;
92
+ });
93
+ </script>
94
+
95
+ <div
96
+ bind:this={element}
97
+ class="drawer {className}"
98
+ style={finalStyle}
99
+ aria-expanded={isOpen}
100
+ aria-orientation="vertical"
101
+ {...rest}
102
+ >
103
+ {#if showOpenerIcon}
104
+ <div class="drawer-opener" style={openerIconStyle[stickTo]}>
105
+ <IconButton
106
+ --sld-button-radius="50%"
107
+ icon={'chevron-right'}
108
+ rotation={sens}
109
+ style="cursor:pointer;"
110
+ onclick={() => actions.toggle()}
111
+ />
112
+ </div>
113
+ {/if}
114
+ {#if isOpen}
115
+ {#if drawerTop || drawerIcon || Boolean(primary) || Boolean(icon)}
116
+ <header class="drawer-header">
117
+ {#if Boolean(icon) || drawerIcon}
118
+ <div class="drawer-icon">
119
+ <Slotted child={drawerIcon}>
120
+ <Icon {icon} />
121
+ </Slotted>
122
+ </div>
123
+ {/if}
124
+ <div class="drawer-header-bar">
125
+ <div class="drawer-header-bar-title">
126
+ <Slotted child={drawerTitle}>
127
+ <Slotted child={drawerPrimary}>
128
+ {#if primary}
129
+ <div style="font-size:18px;">{primary}</div>
130
+ {/if}
131
+ </Slotted>
132
+ <Slotted child={drawerSecondary}>
133
+ {#if secondary}
134
+ <div>{secondary}</div>
135
+ {/if}
136
+ </Slotted>
137
+ </Slotted>
138
+ </div>
139
+ <Slotted child={drawerTop}></Slotted>
140
+ </div>
141
+ {#if !hideCloseIcon && !showOpenerIcon}
142
+ <Button
143
+ onclick={() => {
144
+ toggle();
145
+ }}
146
+ icon="window-close"
147
+ variant="naked"
148
+ />
149
+ {/if}
150
+ </header>
151
+ {/if}
152
+ <div class="drawer-content">
153
+ <Slotted child={drawerContent}>
154
+ <Slotted child={children}></Slotted>
155
+ </Slotted>
156
+ </div>
157
+ <footer>
158
+ <Slotted child={drawerFooter}></Slotted>
159
+ </footer>
160
+ {/if}
161
+ </div>
162
+
163
163
  <style global>:root {
164
164
  --drawer-color: inherit;
165
165
  --drawer-background-color: var(--sld-color-paper-alpha-low);
@@ -247,4 +247,4 @@
247
247
  position: relative;
248
248
  overflow: hidden;
249
249
  width: 100%;
250
- }</style>
250
+ }</style>
@@ -1,69 +1,69 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --drawer-color: inherit;
5
- --drawer-background-color: var(--sld-color-paper-alpha-low);
6
- --drawer-backdrop-filter: blur(0px);
7
- --drawer-box-shadow: var(--sld-elevation-3);
8
- --drawer-border-left: var(--sld-color-primary-alpha-mid);
9
- --drawer-icon-padding: 0 0.5rem;
10
- --drawer-header-min-height: 48px;
11
- --drawer-header-bar-title-font-size: large;
12
- --drawer-content-flex: 1;
13
- }
14
-
15
- .drawer {
16
- @include slotui-mixins.flex(column);
17
- & {
18
- color: var(--drawer-color);
19
- background-color: var(--drawer-background-color);
20
- --webkit-backdrop-filter: var(--drawer-backdrop-filter);
21
- backdrop-filter: var(--drawer-backdrop-filter);
22
- z-index: 3000;
23
- box-shadow: var(--drawer-box-shadow);
24
- border-left: 1px solid var(--drawer-border-left);
25
- overflow: visible;
26
- height: 100%;
27
- transition: all 0.1s;
28
- }
29
-
30
- &-icon {
31
- padding: var(--drawer-icon-padding);
32
- display: flex;
33
- align-items: center;
34
- }
35
-
36
- &-opener {
37
- position: absolute;
38
- z-index: 8600;
39
- }
40
- header,
41
- &-header {
42
- @include slotui-mixins.ui-tall-presets;
43
-
44
- & {
45
- min-height: var(--drawer-header-min-height);
46
- display: flex;
47
- width: 100%;
48
- }
49
-
50
- &-bar {
51
- flex: 1;
52
- display: flex;
53
- align-items: center;
54
-
55
- &-title {
56
- display: flex;
57
- flex-direction: column;
58
- gap: 0.25rem;
59
- font-size: var(--drawer-header-bar-title-font-size);
60
- }
61
- }
62
- }
63
- &-content {
64
- flex: var(--drawer-content-flex);
65
- position: relative;
66
- overflow: hidden;
67
- width: 100%;
68
- }
69
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --drawer-color: inherit;
5
+ --drawer-background-color: var(--sld-color-paper-alpha-low);
6
+ --drawer-backdrop-filter: blur(0px);
7
+ --drawer-box-shadow: var(--sld-elevation-3);
8
+ --drawer-border-left: var(--sld-color-primary-alpha-mid);
9
+ --drawer-icon-padding: 0 0.5rem;
10
+ --drawer-header-min-height: 48px;
11
+ --drawer-header-bar-title-font-size: large;
12
+ --drawer-content-flex: 1;
13
+ }
14
+
15
+ .drawer {
16
+ @include slotui-mixins.flex(column);
17
+ & {
18
+ color: var(--drawer-color);
19
+ background-color: var(--drawer-background-color);
20
+ --webkit-backdrop-filter: var(--drawer-backdrop-filter);
21
+ backdrop-filter: var(--drawer-backdrop-filter);
22
+ z-index: 3000;
23
+ box-shadow: var(--drawer-box-shadow);
24
+ border-left: 1px solid var(--drawer-border-left);
25
+ overflow: visible;
26
+ height: 100%;
27
+ transition: all 0.1s;
28
+ }
29
+
30
+ &-icon {
31
+ padding: var(--drawer-icon-padding);
32
+ display: flex;
33
+ align-items: center;
34
+ }
35
+
36
+ &-opener {
37
+ position: absolute;
38
+ z-index: 8600;
39
+ }
40
+ header,
41
+ &-header {
42
+ @include slotui-mixins.ui-tall-presets;
43
+
44
+ & {
45
+ min-height: var(--drawer-header-min-height);
46
+ display: flex;
47
+ width: 100%;
48
+ }
49
+
50
+ &-bar {
51
+ flex: 1;
52
+ display: flex;
53
+ align-items: center;
54
+
55
+ &-title {
56
+ display: flex;
57
+ flex-direction: column;
58
+ gap: 0.25rem;
59
+ font-size: var(--drawer-header-bar-title-font-size);
60
+ }
61
+ }
62
+ }
63
+ &-content {
64
+ flex: var(--drawer-content-flex);
65
+ position: relative;
66
+ overflow: hidden;
67
+ width: 100%;
68
+ }
69
+ }
@@ -1,83 +1,83 @@
1
- <svelte:options runes />
2
-
3
- <script lang="ts">
4
- import Tabs from './Tabs.svelte';
5
- import Cartouche from '../../base/cartouche/Cartouche.svelte';
6
- import type { TabsItemsProps } from './types.js';
7
- import Button from '../../controls/button/Button.svelte';
8
- import DemoerComponent from '../../base/demoer/DemoerComponent.svelte';
9
- import DemoPage from '../../base/demoer/DemoPage.svelte';
10
- import Demoer from '../../base/demoer/Demoer.svelte';
11
-
12
- import { parameters, componentArgs } from './types.js';
13
-
14
- const items: TabsItemsProps = [
15
- { label: 'Tab 1', code: 'tab1', withContent: 'ff' },
16
- { label: 'Tab 2', code: 'tab2' },
17
- {
18
- label: 'Another tab',
19
- code: 'tab3',
20
- withComponent: Cartouche,
21
- componentProps: { label: 'inner component' }
22
- }
23
- ];
24
-
25
- let code = `
26
- <Tabs
27
- activeTabCode="tab1"
28
- onTabClick={(e) => {
29
- }}
30
- class="h-full"
31
- style="height:100%;width:350px"
32
- {items}>
33
- {#snippet children({ activeTabCode })}
34
- {#snippet tabTitle()}
35
- Some tabs title
36
- {/snippet}
37
- {#snippet tabButtons()}
38
- <Button variant="bordered">button</Button>
39
- {/snippet}
40
- {#snippet tabsInner()}
41
- <div class="h-full">
42
- <div class="pad-4 h-full overflow-auto">
43
- <!-- selected : {activeTabCode} -->
44
- </div>
45
- </div>
46
- {/snippet}
47
- {/snippet}
48
- </Tabs>`;
49
- </script>
50
-
51
- <DemoerComponent component="Tabs">
52
- <DemoPage {code} component="Tabs">
53
- <Demoer {componentArgs} {parameters}>
54
- {#snippet children({ activeParams })}
55
- <div style="height:450px;">
56
- <Tabs
57
- {...activeParams}
58
- onTabClick={(e) => {
59
- console.log(e);
60
- componentArgs.activeTabCode = e.code;
61
- }}
62
- class="h-full"
63
- style="height:100%;width:350px"
64
- >
65
- {#snippet tabsTitle()}
66
- Some tabs title
67
- {/snippet}
68
- {#snippet tabsButtonZone()}
69
- <Button variant="bordered">button</Button>
70
- {/snippet}
71
- {#snippet tabsInner({ activeTabCode })}
72
- <div class="h-full">
73
- <div class="pad-4 h-full overflow-auto">
74
- selected : {activeTabCode}
75
- </div>
76
- </div>
77
- {/snippet}
78
- </Tabs>
79
- </div>
80
- {/snippet}
81
- </Demoer>
82
- </DemoPage>
83
- </DemoerComponent>
1
+ <svelte:options runes />
2
+
3
+ <script lang="ts">
4
+ import Tabs from './Tabs.svelte';
5
+ import Cartouche from '../../base/cartouche/Cartouche.svelte';
6
+ import type { TabsItemsProps } from './types.js';
7
+ import Button from '../../controls/button/Button.svelte';
8
+ import DemoerComponent from '../../base/demoer/DemoerComponent.svelte';
9
+ import DemoPage from '../../base/demoer/DemoPage.svelte';
10
+ import Demoer from '../../base/demoer/Demoer.svelte';
11
+
12
+ import { parameters, componentArgs } from './types.js';
13
+
14
+ const items: TabsItemsProps = [
15
+ { label: 'Tab 1', code: 'tab1', withContent: 'ff' },
16
+ { label: 'Tab 2', code: 'tab2' },
17
+ {
18
+ label: 'Another tab',
19
+ code: 'tab3',
20
+ withComponent: Cartouche,
21
+ componentProps: { label: 'inner component' }
22
+ }
23
+ ];
24
+
25
+ let code = `
26
+ <Tabs
27
+ activeTabCode="tab1"
28
+ onTabClick={(e) => {
29
+ }}
30
+ class="h-full"
31
+ style="height:100%;width:350px"
32
+ {items}>
33
+ {#snippet children({ activeTabCode })}
34
+ {#snippet tabTitle()}
35
+ Some tabs title
36
+ {/snippet}
37
+ {#snippet tabButtons()}
38
+ <Button variant="bordered">button</Button>
39
+ {/snippet}
40
+ {#snippet tabsInner()}
41
+ <div class="h-full">
42
+ <div class="pad-4 h-full overflow-auto">
43
+ <!-- selected : {activeTabCode} -->
44
+ </div>
45
+ </div>
46
+ {/snippet}
47
+ {/snippet}
48
+ </Tabs>`;
49
+ </script>
50
+
51
+ <DemoerComponent component="Tabs">
52
+ <DemoPage {code} component="Tabs">
53
+ <Demoer {componentArgs} {parameters}>
54
+ {#snippet children({ activeParams })}
55
+ <div style="height:450px;">
56
+ <Tabs
57
+ {...activeParams}
58
+ onTabClick={(e) => {
59
+ console.log(e);
60
+ componentArgs.activeTabCode = e.code;
61
+ }}
62
+ class="h-full"
63
+ style="height:100%;width:350px"
64
+ >
65
+ {#snippet tabsTitle()}
66
+ Some tabs title
67
+ {/snippet}
68
+ {#snippet tabsButtonZone()}
69
+ <Button variant="bordered">button</Button>
70
+ {/snippet}
71
+ {#snippet tabsInner({ activeTabCode })}
72
+ <div class="h-full">
73
+ <div class="pad-4 h-full overflow-auto">
74
+ selected : {activeTabCode}
75
+ </div>
76
+ </div>
77
+ {/snippet}
78
+ </Tabs>
79
+ </div>
80
+ {/snippet}
81
+ </Demoer>
82
+ </DemoPage>
83
+ </DemoerComponent>