@medyll/idae-slotui-svelte 0.122.1 → 0.124.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 (203) 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.scss +17 -17
  42. package/dist/base/paper/Paper.demo.svelte +31 -31
  43. package/dist/base/paper/Paper.svelte +20 -20
  44. package/dist/base/paper/paper.scss +15 -15
  45. package/dist/base/titleBar/TitleBar.demo.svelte +30 -30
  46. package/dist/base/titleBar/TitleBar.svelte +40 -40
  47. package/dist/base/titleBar/title-bar.scss +29 -29
  48. package/dist/controls/autocomplete/AutoComplete.demo.svelte +88 -88
  49. package/dist/controls/autocomplete/AutoComplete.svelte +152 -152
  50. package/dist/controls/autocomplete/auto-complete.scss +15 -15
  51. package/dist/controls/button/Button.demo.svelte +165 -165
  52. package/dist/controls/button/Button.svelte +95 -95
  53. package/dist/controls/button/ButtonAction.svelte +55 -55
  54. package/dist/controls/button/ButtonMenu.svelte +55 -55
  55. package/dist/controls/button/IconButton.svelte +45 -45
  56. package/dist/controls/button/button-action.scss +8 -8
  57. package/dist/controls/button/button-menu.scss +36 -36
  58. package/dist/controls/button/button.scss +293 -293
  59. package/dist/controls/checkbox/Checkbox.demo.svelte +29 -29
  60. package/dist/controls/checkbox/Checkbox.svelte +59 -59
  61. package/dist/controls/checkbox/checkbox.scss +115 -115
  62. package/dist/controls/confirm/Confirm.demo.svelte +60 -60
  63. package/dist/controls/confirm/Confirm.preview.svelte +14 -14
  64. package/dist/controls/confirm/Confirm.svelte +156 -156
  65. package/dist/controls/confirm/confirm.scss +12 -12
  66. package/dist/controls/inplaceedit/InPlaceEdit.demo.svelte +41 -41
  67. package/dist/controls/inplaceedit/InPlaceEdit.svelte +109 -109
  68. package/dist/controls/progress/Progress.demo.svelte +30 -30
  69. package/dist/controls/progress/Progress.svelte +26 -26
  70. package/dist/controls/progress/progress.scss +23 -23
  71. package/dist/controls/rating/Rating.demo.svelte +45 -45
  72. package/dist/controls/rating/Rating.svelte +44 -44
  73. package/dist/controls/rating/rating.scss +9 -9
  74. package/dist/controls/select/Select.demo.svelte +101 -101
  75. package/dist/controls/select/Select.svelte +125 -125
  76. package/dist/controls/select/select.scss +13 -13
  77. package/dist/controls/slider/Slider.demo.svelte +34 -34
  78. package/dist/controls/slider/Slider.svelte +153 -153
  79. package/dist/controls/slider/slider.scss +51 -51
  80. package/dist/controls/stepper/Stepper.demo.svelte +32 -32
  81. package/dist/controls/stepper/Stepper.svelte +30 -30
  82. package/dist/controls/stepper/stepper.scss +23 -23
  83. package/dist/controls/switch/Switch.demo.svelte +61 -61
  84. package/dist/controls/switch/Switch.svelte +45 -45
  85. package/dist/controls/switch/switch.scss +73 -73
  86. package/dist/controls/textfield/TextField.demo.svelte +79 -79
  87. package/dist/controls/textfield/TextField.svelte +86 -86
  88. package/dist/controls/textfield/textfield.scss +68 -68
  89. package/dist/csss/csss.scss +10 -10
  90. package/dist/data/dataList/DataList.demo.svelte +151 -151
  91. package/dist/data/dataList/DataList.preview.svelte +23 -23
  92. package/dist/data/dataList/DataList.svelte +233 -233
  93. package/dist/data/dataList/DataListCell.svelte +212 -212
  94. package/dist/data/dataList/DataListHead.svelte +75 -75
  95. package/dist/data/dataList/DataListRow.svelte +93 -93
  96. package/dist/data/dataList/datalist.scss +157 -157
  97. package/dist/data/finder/Finder.demo.svelte +55 -55
  98. package/dist/data/finder/Finder.svelte +166 -166
  99. package/dist/data/finder/finder.scss +14 -14
  100. package/dist/data/grouper/Grouper.demo.svelte +36 -36
  101. package/dist/data/grouper/Grouper.svelte +85 -85
  102. package/dist/data/jsoner/Jsoner.svelte +40 -40
  103. package/dist/data/list/List.svelte +16 -16
  104. package/dist/data/list/ListItem.svelte +10 -10
  105. package/dist/data/list/ListTitle.svelte +8 -8
  106. package/dist/data/loader/Loader.demo.svelte +95 -95
  107. package/dist/data/loader/Loader.preview.svelte +7 -7
  108. package/dist/data/loader/Loader.svelte +99 -99
  109. package/dist/data/loader/loader.scss +50 -50
  110. package/dist/data/sorter/Sorter.demo.svelte +62 -62
  111. package/dist/data/sorter/Sorter.svelte +80 -80
  112. package/dist/data/sorter/Sorterer.svelte +27 -27
  113. package/dist/data/sorter/sorterer.scss +11 -11
  114. package/dist/index.d.ts +58 -57
  115. package/dist/index.js +58 -57
  116. package/dist/navigation/drawer/Drawer.demo.svelte +52 -52
  117. package/dist/navigation/drawer/Drawer.svelte +163 -163
  118. package/dist/navigation/drawer/drawer.scss +69 -69
  119. package/dist/navigation/tabs/Tabs.demo.svelte +83 -83
  120. package/dist/navigation/tabs/Tabs.preview.svelte +22 -22
  121. package/dist/navigation/tabs/Tabs.svelte +158 -158
  122. package/dist/navigation/tabs/tabs.scss +92 -92
  123. package/dist/slotui-css/slotui-css.css +141 -141
  124. package/dist/slotui-css/slotui-min-css.css +141 -141
  125. package/dist/styles/slotui-mixins.scss +168 -168
  126. package/dist/styles/slotui-presets.scss +56 -56
  127. package/dist/styles/slotuisheet/SlotuiSheet.svelte +36 -36
  128. package/dist/styles/slotuisheet/SlotyuiSheet.demo.svelte +28 -28
  129. package/dist/styles/slotuisheet/sheetConfig.scss +7 -7
  130. package/dist/styles/slotuisheet/slotui-sheet.scss +192 -192
  131. package/dist/styles/slotuisheet/stylesheet-container.scss +147 -147
  132. package/dist/styles/slotuisheet/stylesheet.scss +156 -156
  133. package/dist/types/slotui-ambient.d.ts +27 -27
  134. package/dist/ui/bootstrapp/BootStrApp.svelte +92 -92
  135. package/dist/ui/chromeFrame/ChromeFrame.svelte +43 -43
  136. package/dist/ui/chromeFrame/ChromeFrameButtonList.svelte +33 -33
  137. package/dist/ui/chromeFrame/ChromeFrameList.svelte +106 -106
  138. package/dist/ui/chromeFrame/chrome-frame.scss +34 -34
  139. package/dist/ui/frame/Frame.demo.svelte +48 -48
  140. package/dist/ui/frame/Frame.svelte +90 -90
  141. package/dist/ui/frame/frame.scss +46 -46
  142. package/dist/ui/login/Login.demo.svelte +62 -62
  143. package/dist/ui/login/Login.svelte +102 -102
  144. package/dist/ui/marquee/Marquee.demo.svelte +33 -33
  145. package/dist/ui/marquee/Marquee.svelte +97 -97
  146. package/dist/ui/marquee/marquee.scss +34 -34
  147. package/dist/ui/menu/Menu.svelte +9 -9
  148. package/dist/ui/menu/MenuItem.svelte +9 -9
  149. package/dist/ui/menu/MenuTitle.svelte +10 -10
  150. package/dist/ui/menu/menu.scss +61 -61
  151. package/dist/ui/menuList/MenuList.demo.svelte +73 -73
  152. package/dist/ui/menuList/MenuList.svelte +143 -143
  153. package/dist/ui/menuList/MenuListItem.svelte +134 -134
  154. package/dist/ui/menuList/MenuListTitle.svelte +10 -10
  155. package/dist/ui/menuList/menu-list.scss +120 -120
  156. package/dist/ui/panel/Panel.demo.svelte +169 -169
  157. package/dist/ui/panel/Panel.svelte +96 -96
  158. package/dist/ui/panel/PanelGrid.svelte +62 -62
  159. package/dist/ui/panel/PanelSlide.svelte +156 -156
  160. package/dist/ui/panel/Paneler.svelte +63 -63
  161. package/dist/ui/panel/panel.scss +32 -32
  162. package/dist/ui/popper/Popper.demo.svelte +92 -92
  163. package/dist/ui/popper/Popper.svelte +160 -160
  164. package/dist/ui/popper/popper.scss +108 -108
  165. package/dist/ui/preview/Preview.svelte +41 -41
  166. package/dist/ui/serviceBox/ServiceBox.svelte +24 -24
  167. package/dist/ui/startMenu/BootMenu.svelte +102 -102
  168. package/dist/ui/startMenu/boot-menu.scss +86 -86
  169. package/dist/ui/taskbar/TaskBarContent.svelte +20 -20
  170. package/dist/ui/taskbar/Taskbar.svelte +26 -26
  171. package/dist/ui/taskbar/taskbar.scss +28 -28
  172. package/dist/ui/themeswitcher/ThemeSwitcher.svelte +18 -18
  173. package/dist/ui/toast/Toast.demo.svelte +19 -19
  174. package/dist/ui/toast/Toast.svelte +60 -60
  175. package/dist/ui/toast/Toaster.svelte +18 -18
  176. package/dist/ui/toggleBar/ToggleBar.demo.svelte +114 -114
  177. package/dist/ui/toggleBar/ToggleBar.svelte +58 -58
  178. package/dist/ui/toggleBar/toggle-bar.scss +45 -45
  179. package/dist/ui/toolBar/ToolBar.demo.svelte +98 -98
  180. package/dist/ui/toolBar/ToolBar.svelte +30 -30
  181. package/dist/ui/toolBar/toolbar.scss +32 -32
  182. package/dist/ui/tree/Tree.demo.svelte +84 -84
  183. package/dist/ui/tree/Tree.preview.svelte +19 -19
  184. package/dist/ui/tree/Tree.svelte +182 -182
  185. package/dist/ui/tree/tree.scss +38 -38
  186. package/dist/ui/window/Window.demo.svelte +111 -111
  187. package/dist/ui/window/Window.svelte +177 -177
  188. package/dist/ui/window/window.scss +66 -66
  189. package/dist/utils/content/Content.svelte +78 -78
  190. package/dist/utils/contextRooter/ContextRooter.demo.svelte +33 -33
  191. package/dist/utils/contextRooter/ContextRooter.svelte +6 -6
  192. package/dist/utils/css/Css.demo.svelte +5 -5
  193. package/dist/utils/css/Css.svelte +64 -64
  194. package/dist/utils/effects/transitions.js +6 -6
  195. package/dist/utils/looper/Looper.demo.svelte +36 -36
  196. package/dist/utils/looper/Looper.svelte +47 -47
  197. package/dist/utils/slotted/Slotted.svelte +21 -21
  198. package/dist/utils/stylesheet/StyleSheet.demo.svelte +28 -28
  199. package/dist/utils/stylesheet/StyleSheet.svelte +30 -30
  200. package/dist/utils/stylesheet/containerConfig.scss +7 -7
  201. package/dist/utils/stylesheet/stylesheet.scss +147 -147
  202. package/dist/utils/uses/sx4u/sx4uPreprocess.js +34 -34
  203. package/package.json +3 -3
@@ -1,114 +1,114 @@
1
- <script lang="ts">
2
- import Button from '../../controls/button/Button.svelte';
3
- import ToggleBar from './ToggleBar.svelte';
4
-
5
- /* demo */
6
- import { defaultsArgs } from '../../base/demoer/demoer.utils.js';
7
- import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
8
- import Demoer from '../../base/demoer/Demoer.svelte';
9
- import DemoPage from '../../base/demoer/DemoPage.svelte';
10
- import Icon from '../../base/icon/Icon.svelte';
11
- import { uiPresets } from '../../utils/engine/presets.js';
12
- import Finder from '../../data/finder/Finder.svelte';
13
- /* demo */
14
-
15
- let parametersSlot: any = {
16
- open: {
17
- type: 'boolean',
18
- values: [true, false]
19
- },
20
- flow: {
21
- type: 'preset-flow',
22
- values: uiPresets.flow
23
- },
24
- showHandle: {
25
- type: 'boolean',
26
- values: [true, false]
27
- },
28
- closeOnValidate: {
29
- type: 'boolean',
30
- values: [true, false]
31
- },
32
- hideAcceptButton: {
33
- type: 'boolean',
34
- values: [false, true]
35
- },
36
- hideCloseButton: {
37
- type: 'boolean',
38
- values: [false, true]
39
- },
40
- hideCancelButton: {
41
- type: 'boolean',
42
- values: [true, false]
43
- }
44
- };
45
-
46
- let multiple = {
47
- orientation: {
48
- right: { orientation: 'right' },
49
- left: { orientation: 'left' }
50
- }
51
- };
52
-
53
- $: componentArgsSlot = {
54
- ...defaultsArgs(parametersSlot),
55
- title: 'A toggle bar',
56
- onClose: () => {
57
- componentArgsSlot.open = !componentArgsSlot.open;
58
- },
59
- data: [
60
- { id: 1, name: 'name' },
61
- { id: 2, name: 'name' },
62
- { id: 3, name: 'name' },
63
- { id: 4, name: 'name' }
64
- ]
65
- };
66
-
67
- let codeSlot = `
68
- <ToggleBar style="width:350px;" {...activeParams}>
69
- {#snippet toggleBarIcon()}
70
- <Icon icon="carbon:progress-bar" />
71
- {/snippet}
72
- {#snippet toggleBarButtons()}
73
- <div><Button>button</Button></div>
74
- <div><Button>button</Button></div>
75
- {/snippet}
76
- {#snippet contentSwitcherIcon()}
77
- <Button ratio="1/1" icon="search" />
78
- {/snippet}
79
- {#snippet contentSwitcherReveal()}
80
- <Finder styleRoot="width:100%;" size="full" showSortMenu={true} />
81
- {/snippet}
82
- </ToggleBar>
83
- `;
84
-
85
- let codeProps = ` `;
86
- </script>
87
-
88
- <ComponentDemo component="ToggleBar">
89
- <div class="flex-v gap-large">
90
- <DemoPage code={codeSlot} component="ToggleBar">
91
- <Demoer {multiple} parameters={parametersSlot} componentArgs={componentArgsSlot}
92
- >{#snippet children({ activeParams })}
93
- <div class="pad pos-rel">
94
- <ToggleBar style="width:350px;" {...activeParams}>
95
- {#snippet toggleBarIcon()}
96
- <Icon icon="carbon:progress-bar" />
97
- {/snippet}
98
- {#snippet toggleBarButtons()}
99
- <div><Button>button</Button></div>
100
- <div><Button>button</Button></div>
101
- {/snippet}
102
- {#snippet contentSwitcherIcon()}
103
- <Button ratio="1/1" icon="search" />
104
- {/snippet}
105
- {#snippet contentSwitcherReveal()}
106
- <Finder styleRoot="width:100%;" size="full" showSortMenu={true} />
107
- {/snippet}
108
- </ToggleBar>
109
- </div>
110
- {/snippet}
111
- </Demoer>
112
- </DemoPage>
113
- </div>
114
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import Button from '../../controls/button/Button.svelte';
3
+ import ToggleBar from './ToggleBar.svelte';
4
+
5
+ /* demo */
6
+ import { defaultsArgs } from '../../base/demoer/demoer.utils.js';
7
+ import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
8
+ import Demoer from '../../base/demoer/Demoer.svelte';
9
+ import DemoPage from '../../base/demoer/DemoPage.svelte';
10
+ import Icon from '../../base/icon/Icon.svelte';
11
+ import { uiPresets } from '../../utils/engine/presets.js';
12
+ import Finder from '../../data/finder/Finder.svelte';
13
+ /* demo */
14
+
15
+ let parametersSlot: any = {
16
+ open: {
17
+ type: 'boolean',
18
+ values: [true, false]
19
+ },
20
+ flow: {
21
+ type: 'preset-flow',
22
+ values: uiPresets.flow
23
+ },
24
+ showHandle: {
25
+ type: 'boolean',
26
+ values: [true, false]
27
+ },
28
+ closeOnValidate: {
29
+ type: 'boolean',
30
+ values: [true, false]
31
+ },
32
+ hideAcceptButton: {
33
+ type: 'boolean',
34
+ values: [false, true]
35
+ },
36
+ hideCloseButton: {
37
+ type: 'boolean',
38
+ values: [false, true]
39
+ },
40
+ hideCancelButton: {
41
+ type: 'boolean',
42
+ values: [true, false]
43
+ }
44
+ };
45
+
46
+ let multiple = {
47
+ orientation: {
48
+ right: { orientation: 'right' },
49
+ left: { orientation: 'left' }
50
+ }
51
+ };
52
+
53
+ $: componentArgsSlot = {
54
+ ...defaultsArgs(parametersSlot),
55
+ title: 'A toggle bar',
56
+ onClose: () => {
57
+ componentArgsSlot.open = !componentArgsSlot.open;
58
+ },
59
+ data: [
60
+ { id: 1, name: 'name' },
61
+ { id: 2, name: 'name' },
62
+ { id: 3, name: 'name' },
63
+ { id: 4, name: 'name' }
64
+ ]
65
+ };
66
+
67
+ let codeSlot = `
68
+ <ToggleBar style="width:350px;" {...activeParams}>
69
+ {#snippet toggleBarIcon()}
70
+ <Icon icon="carbon:progress-bar" />
71
+ {/snippet}
72
+ {#snippet toggleBarButtons()}
73
+ <div><Button>button</Button></div>
74
+ <div><Button>button</Button></div>
75
+ {/snippet}
76
+ {#snippet contentSwitcherIcon()}
77
+ <Button ratio="1/1" icon="search" />
78
+ {/snippet}
79
+ {#snippet contentSwitcherReveal()}
80
+ <Finder styleRoot="width:100%;" size="full" showSortMenu={true} />
81
+ {/snippet}
82
+ </ToggleBar>
83
+ `;
84
+
85
+ let codeProps = ` `;
86
+ </script>
87
+
88
+ <ComponentDemo component="ToggleBar">
89
+ <div class="flex-v gap-large">
90
+ <DemoPage code={codeSlot} component="ToggleBar">
91
+ <Demoer {multiple} parameters={parametersSlot} componentArgs={componentArgsSlot}
92
+ >{#snippet children({ activeParams })}
93
+ <div class="pad pos-rel">
94
+ <ToggleBar style="width:350px;" {...activeParams}>
95
+ {#snippet toggleBarIcon()}
96
+ <Icon icon="carbon:progress-bar" />
97
+ {/snippet}
98
+ {#snippet toggleBarButtons()}
99
+ <div><Button>button</Button></div>
100
+ <div><Button>button</Button></div>
101
+ {/snippet}
102
+ {#snippet contentSwitcherIcon()}
103
+ <Button ratio="1/1" icon="search" />
104
+ {/snippet}
105
+ {#snippet contentSwitcherReveal()}
106
+ <Finder styleRoot="width:100%;" size="full" showSortMenu={true} />
107
+ {/snippet}
108
+ </ToggleBar>
109
+ </div>
110
+ {/snippet}
111
+ </Demoer>
112
+ </DemoPage>
113
+ </div>
114
+ </ComponentDemo>
@@ -1,60 +1,60 @@
1
- <script lang="ts">
2
- import ContentSwitcher from '../../base/contentSwitcher/ContentSwitcher.svelte';
3
- import Icon from '../../base/icon/Icon.svelte';
4
- import Slotted from '../../utils/slotted/Slotted.svelte';
5
- import type { ToggleBarProps } from './types.js';
6
-
7
- let {
8
- class: className = '',
9
- style,
10
- title,
11
- icon,
12
- contentSwitcherProps = {
13
- icon: 'search'
14
- },
15
- orientation = $bindable('right'),
16
- element = $bindable(),
17
- toggleBarIcon,
18
- toggleBarTitle,
19
- toggleBarButtons,
20
- contentSwitcherReveal,
21
- contentSwitcherIcon,
22
- children,
23
- ...rest
24
- }: ToggleBarProps = $props();
25
-
26
- const posTitle = orientation === 'right' ? 1 : 3;
27
- const posCloser = orientation === 'right' ? 3 : 1;
28
- </script>
29
-
30
- <div bind:this={element} class="toggle-bar {className}" {style} {...rest}>
31
- {#if toggleBarIcon || icon}
32
- <div class="toggle-bar-icon">
33
- <Slotted child={toggleBarIcon}>
34
- <Icon {icon} />
35
- </Slotted>
36
- </div>
37
- {/if}
38
- <div class="toggle-bar-title" style="order:{posTitle};">
39
- {#if toggleBarTitle || Boolean(title)}
40
- <Slotted child={toggleBarTitle}>
41
- <div class="toggle-bar-title-content">
42
- <h5 class="text-ellipsis">{title}</h5>
43
- </div>
44
- </Slotted>
45
- {/if}
46
- </div>
47
- <div class="toggle-bar-content" style="order:2;">
48
- <Slotted child={toggleBarButtons} />
49
- </div>
50
- <div style="order:{posCloser}">
51
- <ContentSwitcher parent={element} {...contentSwitcherProps}>
52
- <Slotted child={contentSwitcherIcon} />
53
- <Slotted child={contentSwitcherReveal} />
54
- </ContentSwitcher>
55
- </div>
56
- </div>
57
-
1
+ <script lang="ts">
2
+ import ContentSwitcher from '../../base/contentSwitcher/ContentSwitcher.svelte';
3
+ import Icon from '../../base/icon/Icon.svelte';
4
+ import Slotted from '../../utils/slotted/Slotted.svelte';
5
+ import type { ToggleBarProps } from './types.js';
6
+
7
+ let {
8
+ class: className = '',
9
+ style,
10
+ title,
11
+ icon,
12
+ contentSwitcherProps = {
13
+ icon: 'search'
14
+ },
15
+ orientation = $bindable('right'),
16
+ element = $bindable(),
17
+ toggleBarIcon,
18
+ toggleBarTitle,
19
+ toggleBarButtons,
20
+ contentSwitcherReveal,
21
+ contentSwitcherIcon,
22
+ children,
23
+ ...rest
24
+ }: ToggleBarProps = $props();
25
+
26
+ const posTitle = orientation === 'right' ? 1 : 3;
27
+ const posCloser = orientation === 'right' ? 3 : 1;
28
+ </script>
29
+
30
+ <div bind:this={element} class="toggle-bar {className}" {style} {...rest}>
31
+ {#if toggleBarIcon || icon}
32
+ <div class="toggle-bar-icon">
33
+ <Slotted child={toggleBarIcon}>
34
+ <Icon {icon} />
35
+ </Slotted>
36
+ </div>
37
+ {/if}
38
+ <div class="toggle-bar-title" style="order:{posTitle};">
39
+ {#if toggleBarTitle || Boolean(title)}
40
+ <Slotted child={toggleBarTitle}>
41
+ <div class="toggle-bar-title-content">
42
+ <h5 class="text-ellipsis">{title}</h5>
43
+ </div>
44
+ </Slotted>
45
+ {/if}
46
+ </div>
47
+ <div class="toggle-bar-content" style="order:2;">
48
+ <Slotted child={toggleBarButtons} />
49
+ </div>
50
+ <div style="order:{posCloser}">
51
+ <ContentSwitcher parent={element} {...contentSwitcherProps}>
52
+ <Slotted child={contentSwitcherIcon} />
53
+ <Slotted child={contentSwitcherReveal} />
54
+ </ContentSwitcher>
55
+ </div>
56
+ </div>
57
+
58
58
  <style>:root {
59
59
  --toggle-bar-padding: var(--sld-commandbar-padding, var(--box-density-1));
60
60
  --toggle-bar-border-bottom: var(--sld-topbar-border-bottom-color, var(--sld-color-border));
@@ -95,4 +95,4 @@
95
95
  position: relative;
96
96
  min-width: auto;
97
97
  overflow: hidden;
98
- }</style>
98
+ }</style>
@@ -1,45 +1,45 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --toggle-bar-padding: var(--sld-commandbar-padding, var(--box-density-1));
5
- --toggle-bar-border-bottom: var(--sld-topbar-border-bottom-color, var(--sld-color-border));
6
- --toggle-bar-gap: var(--sld-commandbar-gap, var(--sld-pad-tiny));
7
- --toggle-bar-icon-padding: var(--sld-pad-medium);
8
- --toggle-bar-title-font-weight: 500;
9
- --toggle-bar-title-content-font-size: 18px;
10
- }
11
-
12
- .toggle-bar {
13
- padding: var(--toggle-bar-padding);
14
- display: flex;
15
- border-bottom: var(--toggle-bar-border-bottom);
16
- width: 100%;
17
- max-width: 100%;
18
- min-width: auto;
19
- position: relative;
20
- gap: var(--toggle-bar-gap);
21
-
22
- &-icon {
23
- padding: var(--toggle-bar-icon-padding);
24
- }
25
- &-title {
26
- flex: 1;
27
- font-weight: var(--toggle-bar-title-font-weight);
28
- min-width: auto;
29
- &-content {
30
- display: flex;
31
- align-items: center;
32
- overflow: hidden;
33
- text-overflow: ellipsis;
34
- font-size: var(--toggle-bar-title-content-font-size);
35
- min-width: auto;
36
- height: 100%;
37
- }
38
- }
39
-
40
- &-content {
41
- position: relative;
42
- min-width: auto;
43
- overflow: hidden;
44
- }
45
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --toggle-bar-padding: var(--sld-commandbar-padding, var(--box-density-1));
5
+ --toggle-bar-border-bottom: var(--sld-topbar-border-bottom-color, var(--sld-color-border));
6
+ --toggle-bar-gap: var(--sld-commandbar-gap, var(--sld-pad-tiny));
7
+ --toggle-bar-icon-padding: var(--sld-pad-medium);
8
+ --toggle-bar-title-font-weight: 500;
9
+ --toggle-bar-title-content-font-size: 18px;
10
+ }
11
+
12
+ .toggle-bar {
13
+ padding: var(--toggle-bar-padding);
14
+ display: flex;
15
+ border-bottom: var(--toggle-bar-border-bottom);
16
+ width: 100%;
17
+ max-width: 100%;
18
+ min-width: auto;
19
+ position: relative;
20
+ gap: var(--toggle-bar-gap);
21
+
22
+ &-icon {
23
+ padding: var(--toggle-bar-icon-padding);
24
+ }
25
+ &-title {
26
+ flex: 1;
27
+ font-weight: var(--toggle-bar-title-font-weight);
28
+ min-width: auto;
29
+ &-content {
30
+ display: flex;
31
+ align-items: center;
32
+ overflow: hidden;
33
+ text-overflow: ellipsis;
34
+ font-size: var(--toggle-bar-title-content-font-size);
35
+ min-width: auto;
36
+ height: 100%;
37
+ }
38
+ }
39
+
40
+ &-content {
41
+ position: relative;
42
+ min-width: auto;
43
+ overflow: hidden;
44
+ }
45
+ }
@@ -1,98 +1,98 @@
1
- <script lang="ts">
2
- import ToolBar from './ToolBar.svelte';
3
-
4
- /* demo */
5
- import { defaultsArgs } from '../../base/demoer/demoer.utils.js';
6
- import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
7
- import Demoer from '../../base/demoer/Demoer.svelte';
8
- import DemoPage from '../../base/demoer/DemoPage.svelte';
9
- /* demo */
10
-
11
- let parametersSlot: any = {
12
- vertical: {
13
- type: 'boolean',
14
- values: [false, true]
15
- },
16
- color: {
17
- type: 'string',
18
- values: [undefined, '#999']
19
- },
20
- closeOnValidate: {
21
- type: 'boolean',
22
- values: [true, false]
23
- }
24
- };
25
-
26
- let multiple = {
27
- vertical: {
28
- false: { vertical: false },
29
- true: { vertical: true }
30
- }
31
- };
32
-
33
- $: componentArgsSlot = {
34
- ...defaultsArgs(parametersSlot),
35
- onClose: () => {
36
- // componentArgsSlot.open = !componentArgsSlot.open;
37
- },
38
- data: [
39
- { id: 1, name: 'name' },
40
- { id: 2, name: 'name' },
41
- { id: 3, name: 'name' },
42
- { id: 4, name: 'name' }
43
- ]
44
- };
45
-
46
- let codeSlot = ` <ToolBar>
47
- <span>item 1</span>
48
- <span>item 2</span>
49
- <divider />
50
- <span>item 3</span>
51
- <span>item 4</span>
52
- </ToolBar>`;
53
-
54
- let codeProps = `
55
- <Button
56
- onclick={() => {
57
- openWindow("html", {
58
- componentProps: { some: "props", someother: "deprops" },
59
- contentHTML:
60
- '<div class="pad-4 align-center">some html content</div>',
61
- });
62
- }}>
63
- Window with html content
64
- </Button>
65
-
66
- <Button
67
- onclick={() => {
68
- openWindow("component", {
69
- component: Debug,
70
- componentProps: { some: "props", someother: "deprops" },
71
- });
72
- }}>
73
- Window with component
74
- </Button>`;
75
- </script>
76
-
77
- <ComponentDemo
78
- component="ToolBar"
79
- cite="Way more than putting tools in a bar : having them in a toolbar ! <br /> Quead Jones, 450"
80
- >
81
- <div class="flex-v gap-large">
82
- <DemoPage code={codeSlot} component="ToolBar">
83
- <Demoer {multiple} parameters={parametersSlot} componentArgs={componentArgsSlot}
84
- >{#snippet children({ activeParams })}
85
- <div class="pad-2 h-large pos-rel">
86
- <ToolBar {...activeParams}>
87
- <span>item 1</span>
88
- <span>item 2</span>
89
- <divider></divider>
90
- <span>item 3</span>
91
- <span>item 4</span>
92
- </ToolBar>
93
- </div>
94
- {/snippet}
95
- </Demoer>
96
- </DemoPage>
97
- </div>
98
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import ToolBar from './ToolBar.svelte';
3
+
4
+ /* demo */
5
+ import { defaultsArgs } from '../../base/demoer/demoer.utils.js';
6
+ import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
7
+ import Demoer from '../../base/demoer/Demoer.svelte';
8
+ import DemoPage from '../../base/demoer/DemoPage.svelte';
9
+ /* demo */
10
+
11
+ let parametersSlot: any = {
12
+ vertical: {
13
+ type: 'boolean',
14
+ values: [false, true]
15
+ },
16
+ color: {
17
+ type: 'string',
18
+ values: [undefined, '#999']
19
+ },
20
+ closeOnValidate: {
21
+ type: 'boolean',
22
+ values: [true, false]
23
+ }
24
+ };
25
+
26
+ let multiple = {
27
+ vertical: {
28
+ false: { vertical: false },
29
+ true: { vertical: true }
30
+ }
31
+ };
32
+
33
+ $: componentArgsSlot = {
34
+ ...defaultsArgs(parametersSlot),
35
+ onClose: () => {
36
+ // componentArgsSlot.open = !componentArgsSlot.open;
37
+ },
38
+ data: [
39
+ { id: 1, name: 'name' },
40
+ { id: 2, name: 'name' },
41
+ { id: 3, name: 'name' },
42
+ { id: 4, name: 'name' }
43
+ ]
44
+ };
45
+
46
+ let codeSlot = ` <ToolBar>
47
+ <span>item 1</span>
48
+ <span>item 2</span>
49
+ <divider />
50
+ <span>item 3</span>
51
+ <span>item 4</span>
52
+ </ToolBar>`;
53
+
54
+ let codeProps = `
55
+ <Button
56
+ onclick={() => {
57
+ openWindow("html", {
58
+ componentProps: { some: "props", someother: "deprops" },
59
+ contentHTML:
60
+ '<div class="pad-4 align-center">some html content</div>',
61
+ });
62
+ }}>
63
+ Window with html content
64
+ </Button>
65
+
66
+ <Button
67
+ onclick={() => {
68
+ openWindow("component", {
69
+ component: Debug,
70
+ componentProps: { some: "props", someother: "deprops" },
71
+ });
72
+ }}>
73
+ Window with component
74
+ </Button>`;
75
+ </script>
76
+
77
+ <ComponentDemo
78
+ component="ToolBar"
79
+ cite="Way more than putting tools in a bar : having them in a toolbar ! <br /> Quead Jones, 450"
80
+ >
81
+ <div class="flex-v gap-large">
82
+ <DemoPage code={codeSlot} component="ToolBar">
83
+ <Demoer {multiple} parameters={parametersSlot} componentArgs={componentArgsSlot}
84
+ >{#snippet children({ activeParams })}
85
+ <div class="pad-2 h-large pos-rel">
86
+ <ToolBar {...activeParams}>
87
+ <span>item 1</span>
88
+ <span>item 2</span>
89
+ <divider></divider>
90
+ <span>item 3</span>
91
+ <span>item 4</span>
92
+ </ToolBar>
93
+ </div>
94
+ {/snippet}
95
+ </Demoer>
96
+ </DemoPage>
97
+ </div>
98
+ </ComponentDemo>