@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,158 +1,158 @@
1
- <svelte:options />
2
-
3
- <script lang="ts">
4
- import { transitions } from '../../utils/effects/transitions.js';
5
- import { onMount, setContext, getContext } from 'svelte';
6
- import type { PanelContextType } from './types.js';
7
- const { slideInNoName, slideOutNoName } = transitions;
8
-
9
- import type { SvelteComponent } from 'svelte';
10
- import type { Snippet } from 'svelte';
11
- import type { CommonProps, ElementProps } from '../../types/index.js';
12
- import Slotted from '../../utils/slotted/Slotted.svelte';
13
-
14
- type PanelSlideProps = CommonProps & {
15
- /** Whether the panel is open or not */
16
- open: boolean;
17
-
18
- /** Component to be rendered in the panel */
19
- component?: SvelteComponent;
20
-
21
- /** Flow of the panel */
22
- flow?: ElementProps['flow'];
23
-
24
- /** Whether the panel is outer or not */
25
- outer?: boolean;
26
-
27
- /** Unique ID for the panel slide */
28
- panelSlideId?: string;
29
- panelSlideZoom?: import('svelte').Snippet;
30
- /** Children for the default content */
31
- children?: Snippet<[any]>;
32
- };
33
- let panelSlideRef: any;
34
- let {
35
- class: className = '',
36
- element = $bindable<HTMLInputElement>(panelSlideRef),
37
- style = '',
38
- open,
39
- component,
40
- flow = 'absolute',
41
- outer,
42
- panelSlideId = crypto.randomUUID() as string,
43
- panelSlideZoom,
44
- children,
45
- ...rest
46
- }: PanelSlideProps = $props();
47
-
48
- let transitionTo: 'prev' | 'next';
49
-
50
- export const actions = {
51
- open: () => {
52
- setVisible(true);
53
- },
54
- close: () => {
55
- setVisible(false);
56
- },
57
- toggle: () => {
58
- setVisible(!open);
59
- },
60
- hasNextPrev: (nextPrev: 'next' | 'prev') => {
61
- const registredPanelSlides = $panelerContext.panelSlides;
62
- const slidePanelsKeys = Object.keys(registredPanelSlides);
63
- const activeIdx = slidePanelsKeys.indexOf(panelSlideId);
64
- }
65
- };
66
-
67
- const panelerContext = getContext<PanelContextType>('Paneler');
68
- if (outer) setContext<string>('PanelSlide', panelSlideId);
69
-
70
- $effect(() => {
71
- if (!$panelerContext.panelSlides[panelSlideId] && outer && panelerContext) {
72
- $panelerContext.panelSlides[panelSlideId] = {};
73
- }
74
- });
75
-
76
- $effect(() => {
77
- if (panelerContext && component && outer) {
78
- $panelerContext.panelSlides[panelSlideId] = component;
79
- }
80
- });
81
-
82
- $effect(() => {
83
- panelSlideRef?.addEventListener('panel-button-clicked', (event: CustomEvent) => {
84
- toggleSlidePanels(event);
85
- });
86
- return () => {
87
- delete $panelerContext.panelSlides?.[panelSlideId];
88
- };
89
- });
90
-
91
- function setVisible(vis: boolean) {
92
- open = vis;
93
- }
94
-
95
- /** receives PanelpanelSlideId to show/hide */
96
- function toggleSlidePanels(
97
- event: CustomEvent<{ panelId: string; page: 'next' | 'prev'; data?: any }>
98
- ) {
99
- const { panelId, page, data } = event.detail;
100
- // get other context.panelSlideId
101
- const registredPanelSlides = $panelerContext.panelSlides;
102
- const slidePanelsKeys = Object.keys(registredPanelSlides);
103
- const activeIdx = slidePanelsKeys.indexOf(panelSlideId);
104
- let prevNext;
105
-
106
- if (page === 'next' && slidePanelsKeys[activeIdx + 1]) {
107
- prevNext = slidePanelsKeys[activeIdx + 1];
108
- transitionTo = 'next';
109
- }
110
- if (page === 'prev' && slidePanelsKeys[activeIdx - 1]) {
111
- prevNext = slidePanelsKeys[activeIdx - 1];
112
- transitionTo = 'prev';
113
- }
114
- // transitionTo
115
- actions.close();
116
- // new activePanelSlide
117
- // will be bound to the default child
118
- if (prevNext) {
119
- const activePanelSlideId = registredPanelSlides[prevNext].panelSlideId;
120
- $panelerContext.activePanelSlideData[activePanelSlideId] = data;
121
- registredPanelSlides[prevNext].actions.open();
122
- }
123
- }
124
- </script>
125
-
126
- {#if !outer}
127
- <svelte:self
128
- bind:this={component}
129
- outer={true}
130
- {panelSlideId}
131
- {flow}
132
- {open}
133
- {style}
134
- {children}
135
- {panelSlideZoom}
136
- />
137
- {:else if open}
138
- <div
139
- bind:this={panelSlideRef}
140
- out:slideOutNoName|global={{ duration: 125, delay: 20, direction: transitionTo }}
141
- in:slideInNoName|global={{ duration: 150, delay: 150, direction: transitionTo }}
142
- class="sidePanel {className}"
143
- style:position={flow ?? ''}
144
- {style}
145
- {...rest}
146
- >
147
- {@render children?.({ panelSlideId, data: $panelerContext.activePanelSlideData[panelSlideId] })}
148
- </div>
149
- {#if panelSlideZoom}
150
- <svelte:self class={className}>
151
- {@render panelSlideZoom?.()}
152
- </svelte:self>
153
- {/if}
154
- {/if}
155
-
1
+ <svelte:options />
2
+
3
+ <script lang="ts">
4
+ import { transitions } from '../../utils/effects/transitions.js';
5
+ import { onMount, setContext, getContext } from 'svelte';
6
+ import type { PanelContextType } from './types.js';
7
+ const { slideInNoName, slideOutNoName } = transitions;
8
+
9
+ import type { SvelteComponent } from 'svelte';
10
+ import type { Snippet } from 'svelte';
11
+ import type { CommonProps, ElementProps } from '../../types/index.js';
12
+ import Slotted from '../../utils/slotted/Slotted.svelte';
13
+
14
+ type PanelSlideProps = CommonProps & {
15
+ /** Whether the panel is open or not */
16
+ open: boolean;
17
+
18
+ /** Component to be rendered in the panel */
19
+ component?: SvelteComponent;
20
+
21
+ /** Flow of the panel */
22
+ flow?: ElementProps['flow'];
23
+
24
+ /** Whether the panel is outer or not */
25
+ outer?: boolean;
26
+
27
+ /** Unique ID for the panel slide */
28
+ panelSlideId?: string;
29
+ panelSlideZoom?: import('svelte').Snippet;
30
+ /** Children for the default content */
31
+ children?: Snippet<[any]>;
32
+ };
33
+ let panelSlideRef: any;
34
+ let {
35
+ class: className = '',
36
+ element = $bindable<HTMLInputElement>(panelSlideRef),
37
+ style = '',
38
+ open,
39
+ component,
40
+ flow = 'absolute',
41
+ outer,
42
+ panelSlideId = crypto.randomUUID() as string,
43
+ panelSlideZoom,
44
+ children,
45
+ ...rest
46
+ }: PanelSlideProps = $props();
47
+
48
+ let transitionTo: 'prev' | 'next';
49
+
50
+ export const actions = {
51
+ open: () => {
52
+ setVisible(true);
53
+ },
54
+ close: () => {
55
+ setVisible(false);
56
+ },
57
+ toggle: () => {
58
+ setVisible(!open);
59
+ },
60
+ hasNextPrev: (nextPrev: 'next' | 'prev') => {
61
+ const registredPanelSlides = $panelerContext.panelSlides;
62
+ const slidePanelsKeys = Object.keys(registredPanelSlides);
63
+ const activeIdx = slidePanelsKeys.indexOf(panelSlideId);
64
+ }
65
+ };
66
+
67
+ const panelerContext = getContext<PanelContextType>('Paneler');
68
+ if (outer) setContext<string>('PanelSlide', panelSlideId);
69
+
70
+ $effect(() => {
71
+ if (!$panelerContext.panelSlides[panelSlideId] && outer && panelerContext) {
72
+ $panelerContext.panelSlides[panelSlideId] = {};
73
+ }
74
+ });
75
+
76
+ $effect(() => {
77
+ if (panelerContext && component && outer) {
78
+ $panelerContext.panelSlides[panelSlideId] = component;
79
+ }
80
+ });
81
+
82
+ $effect(() => {
83
+ panelSlideRef?.addEventListener('panel-button-clicked', (event: CustomEvent) => {
84
+ toggleSlidePanels(event);
85
+ });
86
+ return () => {
87
+ delete $panelerContext.panelSlides?.[panelSlideId];
88
+ };
89
+ });
90
+
91
+ function setVisible(vis: boolean) {
92
+ open = vis;
93
+ }
94
+
95
+ /** receives PanelpanelSlideId to show/hide */
96
+ function toggleSlidePanels(
97
+ event: CustomEvent<{ panelId: string; page: 'next' | 'prev'; data?: any }>
98
+ ) {
99
+ const { panelId, page, data } = event.detail;
100
+ // get other context.panelSlideId
101
+ const registredPanelSlides = $panelerContext.panelSlides;
102
+ const slidePanelsKeys = Object.keys(registredPanelSlides);
103
+ const activeIdx = slidePanelsKeys.indexOf(panelSlideId);
104
+ let prevNext;
105
+
106
+ if (page === 'next' && slidePanelsKeys[activeIdx + 1]) {
107
+ prevNext = slidePanelsKeys[activeIdx + 1];
108
+ transitionTo = 'next';
109
+ }
110
+ if (page === 'prev' && slidePanelsKeys[activeIdx - 1]) {
111
+ prevNext = slidePanelsKeys[activeIdx - 1];
112
+ transitionTo = 'prev';
113
+ }
114
+ // transitionTo
115
+ actions.close();
116
+ // new activePanelSlide
117
+ // will be bound to the default child
118
+ if (prevNext) {
119
+ const activePanelSlideId = registredPanelSlides[prevNext].panelSlideId;
120
+ $panelerContext.activePanelSlideData[activePanelSlideId] = data;
121
+ registredPanelSlides[prevNext].actions.open();
122
+ }
123
+ }
124
+ </script>
125
+
126
+ {#if !outer}
127
+ <svelte:self
128
+ bind:this={component}
129
+ outer={true}
130
+ {panelSlideId}
131
+ {flow}
132
+ {open}
133
+ {style}
134
+ {children}
135
+ {panelSlideZoom}
136
+ />
137
+ {:else if open}
138
+ <div
139
+ bind:this={panelSlideRef}
140
+ out:slideOutNoName|global={{ duration: 125, delay: 20, direction: transitionTo }}
141
+ in:slideInNoName|global={{ duration: 150, delay: 150, direction: transitionTo }}
142
+ class="sidePanel {className}"
143
+ style:position={flow ?? ''}
144
+ {style}
145
+ {...rest}
146
+ >
147
+ {@render children?.({ panelSlideId, data: $panelerContext.activePanelSlideData[panelSlideId] })}
148
+ </div>
149
+ {#if panelSlideZoom}
150
+ <svelte:self class={className}>
151
+ {@render panelSlideZoom?.()}
152
+ </svelte:self>
153
+ {/if}
154
+ {/if}
155
+
156
156
  <style>:root {
157
157
  --panel-margin-bottom: 2rem;
158
158
  --panel-bar-margin-bottom: 2rem;
@@ -184,4 +184,4 @@
184
184
  bottom: 0;
185
185
  padding: 1rem 2rem;
186
186
  width: 100%;
187
- }</style>
187
+ }</style>
@@ -1,63 +1,63 @@
1
- <script lang="ts">
2
- import { fade, slide } from 'svelte/transition';
3
-
4
- import { setContext } from 'svelte';
5
- import { writable, type Writable } from 'svelte/store';
6
- import type { PanelContextType } from './types.js';
7
- import Slotted from '../../utils/slotted/Slotted.svelte';
8
- import type { CommonProps } from '../../types/index.js';
9
- import { onEvent } from '../../utils/uses/event.js';
10
-
11
- interface PanelerProps {
12
- class?: string;
13
- element?: HTMLInputElement | null;
14
- style?: string;
15
- dd?: string;
16
- children?: import('svelte').Snippet;
17
- }
18
-
19
- let {
20
- class: className = '',
21
- element = null,
22
- style = '',
23
- dd = '',
24
- children
25
- }: PanelerProps = $props();
26
-
27
- export const panelerStore: PanelContextType = writable({
28
- activePanelId: undefined,
29
- activePanelSlideData: {},
30
- panelSlides: {},
31
- panels: {}
32
- });
33
-
34
- setContext<PanelContextType>('Paneler', panelerStore);
35
-
36
- let slideLeft: any;
37
- let slideRight: any;
38
-
39
- function toggleSlidePanels(event) {
40
- console.log(event);
41
- // get children from context
42
- // alert("red");
43
- /* slideLeft.actions.toggle();
44
- slideRight.actions.toggle();
45
-
46
- panelerStore.set({
47
- ...$panelerStore,
48
- open: !$panelerStore?.open
49
- });
50
- setContext('PanelSlide', panelerStore); */
51
- }
52
- </script>
53
-
54
- <div
55
- use:onEvent={{ event: 'panel:button:clicked', action: toggleSlidePanels }}
56
- transition:fade|global={{ duration: 50 }}
57
- class={className}
58
- {style}
59
- >
60
- {@render children?.()}
61
- </div>
62
-
63
- <style></style>
1
+ <script lang="ts">
2
+ import { fade, slide } from 'svelte/transition';
3
+
4
+ import { setContext } from 'svelte';
5
+ import { writable, type Writable } from 'svelte/store';
6
+ import type { PanelContextType } from './types.js';
7
+ import Slotted from '../../utils/slotted/Slotted.svelte';
8
+ import type { CommonProps } from '../../types/index.js';
9
+ import { onEvent } from '../../utils/uses/event.js';
10
+
11
+ interface PanelerProps {
12
+ class?: string;
13
+ element?: HTMLInputElement | null;
14
+ style?: string;
15
+ dd?: string;
16
+ children?: import('svelte').Snippet;
17
+ }
18
+
19
+ let {
20
+ class: className = '',
21
+ element = null,
22
+ style = '',
23
+ dd = '',
24
+ children
25
+ }: PanelerProps = $props();
26
+
27
+ export const panelerStore: PanelContextType = writable({
28
+ activePanelId: undefined,
29
+ activePanelSlideData: {},
30
+ panelSlides: {},
31
+ panels: {}
32
+ });
33
+
34
+ setContext<PanelContextType>('Paneler', panelerStore);
35
+
36
+ let slideLeft: any;
37
+ let slideRight: any;
38
+
39
+ function toggleSlidePanels(event) {
40
+ console.log(event);
41
+ // get children from context
42
+ // alert("red");
43
+ /* slideLeft.actions.toggle();
44
+ slideRight.actions.toggle();
45
+
46
+ panelerStore.set({
47
+ ...$panelerStore,
48
+ open: !$panelerStore?.open
49
+ });
50
+ setContext('PanelSlide', panelerStore); */
51
+ }
52
+ </script>
53
+
54
+ <div
55
+ use:onEvent={{ event: 'panel:button:clicked', action: toggleSlidePanels }}
56
+ transition:fade|global={{ duration: 50 }}
57
+ class={className}
58
+ {style}
59
+ >
60
+ {@render children?.()}
61
+ </div>
62
+
63
+ <style></style>
@@ -1,32 +1,32 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --panel-margin-bottom: 2rem;
5
- --panel-bar-margin-bottom: 2rem;
6
- --panel-bar-padding-right: var(--sld-pad-tiny);
7
- --panel-bar-button-padding: 0 var(--sld-pad-tiny);
8
- --panel-bar-button-border: 1px solid rgba(255, 255, 255, 0.05);
9
- --panel-bar-button-background-color: rgba(255, 255, 255, 0.1);
10
- }
11
-
12
- .panel {
13
- position: relative;
14
- margin-bottom: var(--panel-margin-bottom);
15
-
16
- .panel-bar {
17
- margin-bottom: var(--panel-bar-margin-bottom);
18
- display: flex;
19
- min-width: auto;
20
- align-items: center;
21
- padding-right: var(--panel-bar-padding-right);
22
-
23
- button {
24
- padding: var(--panel-bar-button-padding);
25
- border: var(--panel-bar-button-border);
26
- background-color: var(--panel-bar-button-background-color);
27
- }
28
- }
29
-
30
- .panelContent {
31
- }
32
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --panel-margin-bottom: 2rem;
5
+ --panel-bar-margin-bottom: 2rem;
6
+ --panel-bar-padding-right: var(--sld-pad-tiny);
7
+ --panel-bar-button-padding: 0 var(--sld-pad-tiny);
8
+ --panel-bar-button-border: 1px solid rgba(255, 255, 255, 0.05);
9
+ --panel-bar-button-background-color: rgba(255, 255, 255, 0.1);
10
+ }
11
+
12
+ .panel {
13
+ position: relative;
14
+ margin-bottom: var(--panel-margin-bottom);
15
+
16
+ .panel-bar {
17
+ margin-bottom: var(--panel-bar-margin-bottom);
18
+ display: flex;
19
+ min-width: auto;
20
+ align-items: center;
21
+ padding-right: var(--panel-bar-padding-right);
22
+
23
+ button {
24
+ padding: var(--panel-bar-button-padding);
25
+ border: var(--panel-bar-button-border);
26
+ background-color: var(--panel-bar-button-background-color);
27
+ }
28
+ }
29
+
30
+ .panelContent {
31
+ }
32
+ }