@medyll/idae-slotui-svelte 0.122.1 → 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 (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 +39 -38
  115. package/dist/index.js +39 -38
  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,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>
@@ -1,22 +1,22 @@
1
- <svelte:options />
2
-
3
- <script lang="ts">
4
- import Tabs from './Tabs.svelte';
5
- import type { TabsItemsProps } from './types.js';
6
- import Cartouche from '../../base/cartouche/Cartouche.svelte';
7
- import Divider from '../../base/divider/Divider.svelte';
8
- import Button from '../../controls/button/Button.svelte';
9
-
10
- const items: TabsItemsProps = [
11
- { label: 'Tab 1', code: 'theTitle1', withContent: 'ff', secondary: 'some' },
12
- { label: 'Tab 2', code: 'theTitle2' },
13
- {
14
- label: 'Another tab',
15
- code: 'theTitle3',
16
- withComponent: Cartouche,
17
- componentProps: { label: 'inner component' }
18
- }
19
- ];
20
- </script>
21
-
22
- <Tabs activeTabCode="theTitle3" {items}>s</Tabs>
1
+ <svelte:options />
2
+
3
+ <script lang="ts">
4
+ import Tabs from './Tabs.svelte';
5
+ import type { TabsItemsProps } from './types.js';
6
+ import Cartouche from '../../base/cartouche/Cartouche.svelte';
7
+ import Divider from '../../base/divider/Divider.svelte';
8
+ import Button from '../../controls/button/Button.svelte';
9
+
10
+ const items: TabsItemsProps = [
11
+ { label: 'Tab 1', code: 'theTitle1', withContent: 'ff', secondary: 'some' },
12
+ { label: 'Tab 2', code: 'theTitle2' },
13
+ {
14
+ label: 'Another tab',
15
+ code: 'theTitle3',
16
+ withComponent: Cartouche,
17
+ componentProps: { label: 'inner component' }
18
+ }
19
+ ];
20
+ </script>
21
+
22
+ <Tabs activeTabCode="theTitle3" {items}>s</Tabs>
@@ -1,160 +1,160 @@
1
- <svelte:options runes />
2
-
3
- <script lang="ts" generics="T=Data">
4
- import Slotted from '../../utils/slotted/Slotted.svelte';
5
-
6
- import { elem } from '../../utils/engine/elem.js';
7
- import Icon from '../../base/icon/Icon.svelte';
8
- import type { TabItem, TabsProps } from './types.js';
9
- import type { Data, ExpandProps } from '../../types/index.js';
10
- import { onEvent } from '../../utils/uses/event.js';
11
-
12
- let {
13
- class: className = '',
14
- element = $bindable(),
15
- style = '',
16
- activeTabCode = $bindable(),
17
- items = [],
18
- orientation = 'horizontal',
19
- onTabClick = (item: TabItem) => {},
20
- children,
21
- tabsTitleMain,
22
- tabsLabel,
23
- tabsTitle,
24
- tabsButtonZone,
25
- tabsInner,
26
- ...rest
27
- }: ExpandProps<TabsProps> = $props();
28
-
29
- let navElementRef: HTMLElement;
30
- let tabsElementRef: HTMLElement;
31
- let activeCellElementRef: HTMLElement;
32
- let boundingClientRect: DOMRect;
33
-
34
- const handleClick = (item: TabItem) => {
35
- onTabClick(item);
36
- const event = new CustomEvent('on:tabs:click', { detail: item, bubbles: true });
37
- element?.dispatchEvent(event);
38
- };
39
-
40
- const setChipPos = (code: any) => {
41
- if (!elem(navElementRef) || !code) return;
42
- const node = elem(navElementRef).find(`[data-code=${code}]`);
43
- if (node && activeCellElementRef?.parentElement) {
44
- boundingClientRect = node.getBoundingClientRect();
45
- if (orientation === 'vertical') {
46
- activeCellElementRef.style.left = node?.offsetLeft + 'px';
47
- activeCellElementRef.style.width = boundingClientRect.width + 'px';
48
- } else {
49
- activeCellElementRef.style.top = node?.offsetTop + 'px';
50
- activeCellElementRef.style.height = boundingClientRect.height + 'px';
51
- activeCellElementRef.style.width = '3px';
52
- }
53
- }
54
- };
55
-
56
- $effect(() => {
57
- if (activeTabCode && element && navElementRef) {
58
- setChipPos(activeTabCode);
59
- }
60
- });
61
-
62
- function toggler(node: HTMLElement) {
63
- if (element !== undefined && node !== undefined)
64
- elem(element)
65
- ?.findAll('[aria-selected]')
66
- ?.forEach((node) => {
67
- node?.removeAttribute('aria-selected');
68
- });
69
- node.setAttribute('aria-selected', 'true');
70
- if (node.dataset.code) togglerCode(node.dataset.code);
71
- }
72
-
73
- function togglerCode(code: string) {
74
- activeTabCode = code;
75
- }
76
- </script>
77
-
78
- <div bind:this={element} class="tab {className}" aria-orientation={orientation} {style}>
79
- <div
80
- use:onEvent={{ event: 'dom:close', action: () => {} }}
81
- use:onEvent={{ event: 'dom:toggle', action: () => {} }}
82
- use:onEvent={{
83
- event: 'on:tabs:click',
84
- action: () => {}
85
- }}
86
- bind:this={tabsElementRef}
87
- class="tab-nav"
88
- >
89
- <div>
90
- <Slotted child={tabsTitleMain}></Slotted>
91
- </div>
92
- <nav bind:this={navElementRef} class="tab-nav-rail">
93
- {#each items as item}
94
- <button
95
- data-code={item?.code}
96
- data-toggle={item?.code}
97
- onclick={(ji) => {
98
- if (ji.target) toggler(ji.target as HTMLElement);
99
- handleClick(item);
100
- }}
101
- class={activeTabCode === item?.code ? 'active' : ''}
102
- >
103
- <Slotted child={tabsLabel} slotArgs={{ item, activeTabCode }}>
104
- {item?.label}
105
- </Slotted>
106
- </button>
107
- {/each}
108
- </nav>
109
- <div>
110
- <Slotted child={tabsTitle}></Slotted>
111
- </div>
112
- <div>
113
- <Slotted child={tabsButtonZone}></Slotted>
114
- </div>
115
- </div>
116
- <div class="tab-floating-cell">
117
- <div bind:this={activeCellElementRef} class="tab-floating-cell-snip"></div>
118
- </div>
119
- <div class="tab-content">
120
- {#each items as item}
121
- {@const display = activeTabCode === item?.code ? 'flex' : 'none'}
122
- {#if item && activeTabCode === item?.code}
123
- <Slotted child={tabsInner} slotArgs={{ item, activeTabCode }}>
124
- <div
125
- data-code={item.code}
126
- data-toggle-on={item.code}
127
- data-activeTabCode={activeTabCode}
128
- style="display:{display};height:100%;position:relative;flex-direction:column"
129
- >
130
- {#if Boolean(item?.secondary)}
131
- <div class="tab-content-secondary">
132
- <div class="tab-content-secondary-icon">
133
- <Icon style="display:block" icon="clarity:help-info-solid" />
134
- </div>
135
- <div style="flex:1;">{@html item?.secondary}</div>
136
- </div>
137
- {/if}
138
- <Slotted child={tabsInner} slotArgs={{ item, activeTabCode }}>
139
- <div data-code={item.code} style="flex:1;overflow:hidden;position:relative;">
140
- {#if activeTabCode === item.code}
141
- {#if Boolean(item?.withComponent)}
142
- <svelte:component this={item.withComponent} {...item.componentProps ?? {}} />
143
- {:else if Boolean(item?.withContent)}
144
- {item.withContent}
145
- {:else if Boolean(item?.withUid)}
146
- {item.withUid}
147
- {/if}
148
- {/if}
149
- </div>
150
- </Slotted>
151
- </div>
152
- </Slotted>
153
- {/if}
154
- {/each}
155
- </div>
156
- </div>
157
-
1
+ <svelte:options runes />
2
+
3
+ <script lang="ts" generics="T=Data">
4
+ import Slotted from '../../utils/slotted/Slotted.svelte';
5
+
6
+ import { elem } from '../../utils/engine/elem.js';
7
+ import Icon from '../../base/icon/Icon.svelte';
8
+ import type { TabItem, TabsProps } from './types.js';
9
+ import type { Data, ExpandProps } from '../../types/index.js';
10
+ import { onEvent } from '../../utils/uses/event.js';
11
+
12
+ let {
13
+ class: className = '',
14
+ element = $bindable(),
15
+ style = '',
16
+ activeTabCode = $bindable(),
17
+ items = [],
18
+ orientation = 'horizontal',
19
+ onTabClick = (item: TabItem) => {},
20
+ children,
21
+ tabsTitleMain,
22
+ tabsLabel,
23
+ tabsTitle,
24
+ tabsButtonZone,
25
+ tabsInner,
26
+ ...rest
27
+ }: ExpandProps<TabsProps> = $props();
28
+
29
+ let navElementRef: HTMLElement;
30
+ let tabsElementRef: HTMLElement;
31
+ let activeCellElementRef: HTMLElement;
32
+ let boundingClientRect: DOMRect;
33
+
34
+ const handleClick = (item: TabItem) => {
35
+ onTabClick(item);
36
+ const event = new CustomEvent('on:tabs:click', { detail: item, bubbles: true });
37
+ element?.dispatchEvent(event);
38
+ };
39
+
40
+ const setChipPos = (code: any) => {
41
+ if (!elem(navElementRef) || !code) return;
42
+ const node = elem(navElementRef).find(`[data-code=${code}]`);
43
+ if (node && activeCellElementRef?.parentElement) {
44
+ boundingClientRect = node.getBoundingClientRect();
45
+ if (orientation === 'vertical') {
46
+ activeCellElementRef.style.left = node?.offsetLeft + 'px';
47
+ activeCellElementRef.style.width = boundingClientRect.width + 'px';
48
+ } else {
49
+ activeCellElementRef.style.top = node?.offsetTop + 'px';
50
+ activeCellElementRef.style.height = boundingClientRect.height + 'px';
51
+ activeCellElementRef.style.width = '3px';
52
+ }
53
+ }
54
+ };
55
+
56
+ $effect(() => {
57
+ if (activeTabCode && element && navElementRef) {
58
+ setChipPos(activeTabCode);
59
+ }
60
+ });
61
+
62
+ function toggler(node: HTMLElement) {
63
+ if (element !== undefined && node !== undefined)
64
+ elem(element)
65
+ ?.findAll('[aria-selected]')
66
+ ?.forEach((node) => {
67
+ node?.removeAttribute('aria-selected');
68
+ });
69
+ node.setAttribute('aria-selected', 'true');
70
+ if (node.dataset.code) togglerCode(node.dataset.code);
71
+ }
72
+
73
+ function togglerCode(code: string) {
74
+ activeTabCode = code;
75
+ }
76
+ </script>
77
+
78
+ <div bind:this={element} class="tab {className}" aria-orientation={orientation} {style}>
79
+ <div
80
+ use:onEvent={{ event: 'dom:close', action: () => {} }}
81
+ use:onEvent={{ event: 'dom:toggle', action: () => {} }}
82
+ use:onEvent={{
83
+ event: 'on:tabs:click',
84
+ action: () => {}
85
+ }}
86
+ bind:this={tabsElementRef}
87
+ class="tab-nav"
88
+ >
89
+ <div>
90
+ <Slotted child={tabsTitleMain}></Slotted>
91
+ </div>
92
+ <nav bind:this={navElementRef} class="tab-nav-rail">
93
+ {#each items as item}
94
+ <button
95
+ data-code={item?.code}
96
+ data-toggle={item?.code}
97
+ onclick={(ji) => {
98
+ if (ji.target) toggler(ji.target as HTMLElement);
99
+ handleClick(item);
100
+ }}
101
+ class={activeTabCode === item?.code ? 'active' : ''}
102
+ >
103
+ <Slotted child={tabsLabel} slotArgs={{ item, activeTabCode }}>
104
+ {item?.label}
105
+ </Slotted>
106
+ </button>
107
+ {/each}
108
+ </nav>
109
+ <div>
110
+ <Slotted child={tabsTitle}></Slotted>
111
+ </div>
112
+ <div>
113
+ <Slotted child={tabsButtonZone}></Slotted>
114
+ </div>
115
+ </div>
116
+ <div class="tab-floating-cell">
117
+ <div bind:this={activeCellElementRef} class="tab-floating-cell-snip"></div>
118
+ </div>
119
+ <div class="tab-content">
120
+ {#each items as item}
121
+ {@const display = activeTabCode === item?.code ? 'flex' : 'none'}
122
+ {#if item && activeTabCode === item?.code}
123
+ <Slotted child={tabsInner} slotArgs={{ item, activeTabCode }}>
124
+ <div
125
+ data-code={item.code}
126
+ data-toggle-on={item.code}
127
+ data-activeTabCode={activeTabCode}
128
+ style="display:{display};height:100%;position:relative;flex-direction:column"
129
+ >
130
+ {#if Boolean(item?.secondary)}
131
+ <div class="tab-content-secondary">
132
+ <div class="tab-content-secondary-icon">
133
+ <Icon style="display:block" icon="clarity:help-info-solid" />
134
+ </div>
135
+ <div style="flex:1;">{@html item?.secondary}</div>
136
+ </div>
137
+ {/if}
138
+ <Slotted child={tabsInner} slotArgs={{ item, activeTabCode }}>
139
+ <div data-code={item.code} style="flex:1;overflow:hidden;position:relative;">
140
+ {#if activeTabCode === item.code}
141
+ {#if Boolean(item?.withComponent)}
142
+ <svelte:component this={item.withComponent} {...item.componentProps ?? {}} />
143
+ {:else if Boolean(item?.withContent)}
144
+ {item.withContent}
145
+ {:else if Boolean(item?.withUid)}
146
+ {item.withUid}
147
+ {/if}
148
+ {/if}
149
+ </div>
150
+ </Slotted>
151
+ </div>
152
+ </Slotted>
153
+ {/if}
154
+ {/each}
155
+ </div>
156
+ </div>
157
+
158
158
  <style>:root {
159
159
  --tabs-nav-border-color: var(--sld-color-primary-alpha-high);
160
160
  --tabs-content-background-color: var(--sld-color-background);
@@ -239,4 +239,4 @@
239
239
  position: absolute;
240
240
  transition: all 0.25s ease-in;
241
241
  z-index: 200;
242
- }</style>
242
+ }</style>