@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,61 +1,61 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --menu-min-width: 150px;
5
- --menu-padding: 0.25rem;
6
- --menu-color: var(--sld-color-foreground);
7
- --menu-item-border-radius: var(--sld-radius-small);
8
- --menu-item-icon-width: 16px;
9
- --menu-item-text-padding-left: 0.25rem;
10
- }
11
-
12
- ul.menu {
13
- & {
14
- margin: 0;
15
- min-width: var(--menu-min-width);
16
- padding: var(--menu-padding);
17
- cursor: pointer;
18
- display: block;
19
- color: var(--menu-color);
20
- }
21
-
22
- li.menuTitle {
23
- position: sticky;
24
- margin-top: 0px !important;
25
- top: 0px;
26
- z-index: 1;
27
- }
28
- }
29
-
30
- li.menuItem {
31
- @include slotui-mixins.data-hover;
32
- @include slotui-mixins.data-selected;
33
- @include slotui-mixins.ui-tall-presets;
34
-
35
- & {
36
- border-radius: var(--menu-item-border-radius);
37
- overflow: hidden;
38
- display: flex;
39
- align-items: center;
40
- border: 1px solid transparent;
41
- }
42
-
43
- .menuListItemIcon {
44
- width: var(--menu-item-icon-width);
45
- max-width: var(--menu-item-icon-width);
46
- text-align: center;
47
- overflow: hidden;
48
- text-align: center;
49
- display: flex;
50
- justify-content: center;
51
- }
52
-
53
- .menu-list-item-text {
54
- flex: 1;
55
- padding-left: var(--menu-item-text-padding-left);
56
- }
57
-
58
- .menu-list-item-action {
59
- display: block;
60
- }
61
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --menu-min-width: 150px;
5
+ --menu-padding: 0.25rem;
6
+ --menu-color: var(--sld-color-foreground);
7
+ --menu-item-border-radius: var(--sld-radius-small);
8
+ --menu-item-icon-width: 16px;
9
+ --menu-item-text-padding-left: 0.25rem;
10
+ }
11
+
12
+ ul.menu {
13
+ & {
14
+ margin: 0;
15
+ min-width: var(--menu-min-width);
16
+ padding: var(--menu-padding);
17
+ cursor: pointer;
18
+ display: block;
19
+ color: var(--menu-color);
20
+ }
21
+
22
+ li.menuTitle {
23
+ position: sticky;
24
+ margin-top: 0px !important;
25
+ top: 0px;
26
+ z-index: 1;
27
+ }
28
+ }
29
+
30
+ li.menuItem {
31
+ @include slotui-mixins.data-hover;
32
+ @include slotui-mixins.data-selected;
33
+ @include slotui-mixins.ui-tall-presets;
34
+
35
+ & {
36
+ border-radius: var(--menu-item-border-radius);
37
+ overflow: hidden;
38
+ display: flex;
39
+ align-items: center;
40
+ border: 1px solid transparent;
41
+ }
42
+
43
+ .menuListItemIcon {
44
+ width: var(--menu-item-icon-width);
45
+ max-width: var(--menu-item-icon-width);
46
+ text-align: center;
47
+ overflow: hidden;
48
+ text-align: center;
49
+ display: flex;
50
+ justify-content: center;
51
+ }
52
+
53
+ .menu-list-item-text {
54
+ flex: 1;
55
+ padding-left: var(--menu-item-text-padding-left);
56
+ }
57
+
58
+ .menu-list-item-action {
59
+ display: block;
60
+ }
61
+ }
@@ -1,73 +1,73 @@
1
- <script lang="ts">
2
- import MenuList from './MenuList.svelte';
3
- import MenuItem from './MenuListItem.svelte';
4
- /* demo */
5
- import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
6
- import Demoer from '../../base/demoer/Demoer.svelte';
7
- import DemoPage from '../../base/demoer/DemoPage.svelte';
8
- import { uiPresets } from '../../utils/engine/presets.js';
9
- import { defaultsArgs, defaultsArgsFromProps } from '../../base/demoer/demoer.utils.js';
10
- /* demo */
11
-
12
- import { parameters, componentArgs } from './types.js';
13
-
14
- let codeSlot = `
15
- <Menu>
16
- <MenuItem divider={true}>menu item</MenuItem>
17
- <MenuItem icon="home" selected={true}>menu item</MenuItem>
18
- <MenuItem icon="close">menu item</MenuItem>
19
- <MenuItem divider={true}>menu item</MenuItem>
20
- <MenuItem>menu item</MenuItem>
21
- </Menu>`;
22
- </script>
23
-
24
- <ComponentDemo
25
- component="Menu"
26
- cite="A menu is not a list, it's just like a list but more and less"
27
- >
28
- <div class="flex-v gap-large">
29
- <DemoPage code={codeSlot} component="Popper">
30
- <Demoer {componentArgs} {parameters}>
31
- {#snippet children({ activeParams })}
32
- <div class="flex-h flex-align-bottom gap-small">
33
- <div class="pad-tiny">
34
- <MenuList {...activeParams}>
35
- <MenuItem>menu item</MenuItem>
36
- <MenuItem>menu item</MenuItem>
37
- <MenuItem>menu item</MenuItem>
38
- <MenuItem>menu item</MenuItem>
39
- <MenuItem>menu item</MenuItem>
40
- </MenuList>
41
- <h6 class="pad">A menu</h6>
42
- </div>
43
- <div class="pad">
44
- <MenuList {...activeParams}>
45
- <MenuItem>menu item</MenuItem>
46
- <MenuItem icon="home" selected={true}>menu item</MenuItem>
47
- <MenuItem icon="close">menu item</MenuItem>
48
- <MenuItem>menu item</MenuItem>
49
- <MenuItem>menu item</MenuItem>
50
- </MenuList>
51
- <h6 class="pad">A menu with icons</h6>
52
- </div>
53
- <div class="pad">
54
- <MenuList {...activeParams}>
55
- <MenuItem divider={true}>menu item</MenuItem>
56
- <MenuItem icon="home" selected={true}>menu item</MenuItem>
57
- <MenuItem icon="close">menu item</MenuItem>
58
- <MenuItem divider={true}>menu item</MenuItem>
59
- <MenuItem>menu item</MenuItem>
60
- </MenuList>
61
- <h6 class="pad">A menu with some dividers</h6>
62
- </div>
63
- </div>
64
- {/snippet}
65
- </Demoer>
66
- </DemoPage>
67
- </div></ComponentDemo
68
- >
69
- <br />
70
- <br />
71
- <br />
72
- <br />
73
- <ComponentDemo component="MenuItem" cite="A MenuItem gets one place to stay" />
1
+ <script lang="ts">
2
+ import MenuList from './MenuList.svelte';
3
+ import MenuItem from './MenuListItem.svelte';
4
+ /* demo */
5
+ import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
6
+ import Demoer from '../../base/demoer/Demoer.svelte';
7
+ import DemoPage from '../../base/demoer/DemoPage.svelte';
8
+ import { uiPresets } from '../../utils/engine/presets.js';
9
+ import { defaultsArgs, defaultsArgsFromProps } from '../../base/demoer/demoer.utils.js';
10
+ /* demo */
11
+
12
+ import { parameters, componentArgs } from './types.js';
13
+
14
+ let codeSlot = `
15
+ <Menu>
16
+ <MenuItem divider={true}>menu item</MenuItem>
17
+ <MenuItem icon="home" selected={true}>menu item</MenuItem>
18
+ <MenuItem icon="close">menu item</MenuItem>
19
+ <MenuItem divider={true}>menu item</MenuItem>
20
+ <MenuItem>menu item</MenuItem>
21
+ </Menu>`;
22
+ </script>
23
+
24
+ <ComponentDemo
25
+ component="Menu"
26
+ cite="A menu is not a list, it's just like a list but more and less"
27
+ >
28
+ <div class="flex-v gap-large">
29
+ <DemoPage code={codeSlot} component="Popper">
30
+ <Demoer {componentArgs} {parameters}>
31
+ {#snippet children({ activeParams })}
32
+ <div class="flex-h flex-align-bottom gap-small">
33
+ <div class="pad-tiny">
34
+ <MenuList {...activeParams}>
35
+ <MenuItem>menu item</MenuItem>
36
+ <MenuItem>menu item</MenuItem>
37
+ <MenuItem>menu item</MenuItem>
38
+ <MenuItem>menu item</MenuItem>
39
+ <MenuItem>menu item</MenuItem>
40
+ </MenuList>
41
+ <h6 class="pad">A menu</h6>
42
+ </div>
43
+ <div class="pad">
44
+ <MenuList {...activeParams}>
45
+ <MenuItem>menu item</MenuItem>
46
+ <MenuItem icon="home" selected={true}>menu item</MenuItem>
47
+ <MenuItem icon="close">menu item</MenuItem>
48
+ <MenuItem>menu item</MenuItem>
49
+ <MenuItem>menu item</MenuItem>
50
+ </MenuList>
51
+ <h6 class="pad">A menu with icons</h6>
52
+ </div>
53
+ <div class="pad">
54
+ <MenuList {...activeParams}>
55
+ <MenuItem divider={true}>menu item</MenuItem>
56
+ <MenuItem icon="home" selected={true}>menu item</MenuItem>
57
+ <MenuItem icon="close">menu item</MenuItem>
58
+ <MenuItem divider={true}>menu item</MenuItem>
59
+ <MenuItem>menu item</MenuItem>
60
+ </MenuList>
61
+ <h6 class="pad">A menu with some dividers</h6>
62
+ </div>
63
+ </div>
64
+ {/snippet}
65
+ </Demoer>
66
+ </DemoPage>
67
+ </div></ComponentDemo
68
+ >
69
+ <br />
70
+ <br />
71
+ <br />
72
+ <br />
73
+ <ComponentDemo component="MenuItem" cite="A MenuItem gets one place to stay" />
@@ -1,145 +1,145 @@
1
- <script lang="ts" generics="T= Data">
2
- import { navigation } from '../../utils/uses/navigation.js';
3
-
4
- import { setContext } from 'svelte';
5
- import type { MenuListProps } from './types.js';
6
- import MenuListItem from './MenuListItem.svelte';
7
- import { tallPreset, widthPreset, type Data, type ExpandProps } from '../../types/index.js';
8
- import Slotted from '../../utils/slotted/Slotted.svelte';
9
- import Looper from '../../utils/looper/Looper.svelte';
10
-
11
- export const actions = {
12
- navigate(e: KeyboardEvent) {
13
- element?.dispatchEvent(new CustomEvent('menu:navigate', { detail: e }));
14
- },
15
- gotoIndex: (idx: number) => {
16
- if (element && idx > -1) {
17
- element.dispatchEvent(new CustomEvent('menu:gotoIndex', { detail: { index: idx } }));
18
- selectedIndex = idx;
19
- if (menuStore) menuStore.selectedIndex = idx;
20
- const target = element.querySelector('[aria-selected=true]');
21
- if (target) {
22
- scrollToElement(target as HTMLElement);
23
- }
24
- }
25
- }
26
- };
27
- let {
28
- class: className = '',
29
- tall = tallPreset.small,
30
- width = widthPreset.full,
31
- style,
32
- selectorField,
33
- role = 'menu',
34
- grid,
35
- showLastOnSelected = true,
36
- presentationField,
37
- onclick,
38
- data = $bindable(),
39
- selectedData = $bindable(),
40
- selectedIndex = $bindable(),
41
- element = $bindable(),
42
- menuListItems = $bindable(),
43
- menuListItemProps = $bindable(),
44
- children,
45
- menuListItem,
46
- listItemBottom,
47
- ...rest
48
- }: MenuListProps = $props();
49
-
50
- menuListItemProps = {
51
- tall,
52
- width,
53
- selectorField,
54
- presentationField,
55
- ...menuListItemProps
56
- };
57
-
58
- let defaultStoreValues = {
59
- menuListItems,
60
- menuItemsInstances: [],
61
- tall,
62
- width,
63
- data,
64
- selectorField,
65
- selectedIndex,
66
- actions,
67
- presentationField,
68
- ...menuListItemProps
69
- };
70
-
71
- let menuStore = $state(defaultStoreValues);
72
- setContext('menuStateContext', menuStore);
73
-
74
- $effect(() => {
75
- menuStore.selectedIndex = selectedIndex;
76
- });
77
- $effect(() => {
78
- menuStore.tall = tall;
79
- });
80
- $effect(() => {
81
- if (element) {
82
- element.addEventListener<any>('menu:item:clicked', onMenuItemClick);
83
-
84
- element.addEventListener('click', () => {
85
- element?.focus();
86
- });
87
- element.addEventListener('menu:onnavigate', ((
88
- event: CustomEvent<{ selectedIndex: number }>
89
- ) => {
90
- if (event?.detail?.selectedIndex) selectedIndex = event.detail.selectedIndex;
91
- }) as EventListener);
92
- }
93
- });
94
-
95
- function onMenuItemClick(e: CustomEvent<any>) {
96
- if (onclick) onclick(e.detail, 2);
97
- }
98
-
99
- function scrollToElement(target: HTMLElement) {
100
- if (target) {
101
- const tD = target.getBoundingClientRect();
102
- const sD = element?.getBoundingClientRect();
103
- if (sD) {
104
- if (tD.top - 10 <= sD.top || tD.bottom >= sD.bottom) {
105
- target.scrollIntoView({ behavior: 'smooth', block: 'center' });
106
- }
107
- }
108
- }
109
- }
110
- </script>
111
-
112
- <!-- svelte-ignore a11y_no_noninteractive_tabindex -->
113
- <ul
114
- bind:this={element}
115
- class:showLastOnSelected
116
- class="slotui-menulist {className} {grid ? 'grid' : ''}"
117
- tabindex="0"
118
- style={`${style};var(--menulist-grid-items-count):${grid ? grid : '0'}`}
119
- {role}
120
- use:navigation={{ className: 'menulist-item', selectedIndex: -1 }}
121
- {...rest}
122
- >
123
- {#if menuListItems}
124
- {#each menuListItems ?? [] as menuItem, itemIndex}
125
- <Slotted child={children} slotArgs={{ item: menuItem, itemIndex, menuItem }}>
126
- <MenuListItem {...menuListItemProps} {...menuItem} {itemIndex} />
127
- </Slotted>
128
- {/each}
129
- {:else if data}
130
- {#each data as dta, itemIndex}
131
- <Slotted child={children} slotArgs={{ item: dta, itemIndex, menuItem: dta }}>
132
- <MenuListItem {...menuListItemProps} data={dta} {itemIndex}>
133
- {@render menuListItem?.({ item: dta, itemIndex })}
134
- </MenuListItem>
135
- </Slotted>
136
- {/each}
137
- {:else}
138
- <Slotted child={children} />
139
- {/if}
140
- {@render listItemBottom?.({ item: {}, itemIndex: -1 })}
141
- </ul>
142
-
1
+ <script lang="ts" generics="T= Data">
2
+ import { navigation } from '../../utils/uses/navigation.js';
3
+
4
+ import { setContext } from 'svelte';
5
+ import type { MenuListProps } from './types.js';
6
+ import MenuListItem from './MenuListItem.svelte';
7
+ import { tallPreset, widthPreset, type Data, type ExpandProps } from '../../types/index.js';
8
+ import Slotted from '../../utils/slotted/Slotted.svelte';
9
+ import Looper from '../../utils/looper/Looper.svelte';
10
+
11
+ export const actions = {
12
+ navigate(e: KeyboardEvent) {
13
+ element?.dispatchEvent(new CustomEvent('menu:navigate', { detail: e }));
14
+ },
15
+ gotoIndex: (idx: number) => {
16
+ if (element && idx > -1) {
17
+ element.dispatchEvent(new CustomEvent('menu:gotoIndex', { detail: { index: idx } }));
18
+ selectedIndex = idx;
19
+ if (menuStore) menuStore.selectedIndex = idx;
20
+ const target = element.querySelector('[aria-selected=true]');
21
+ if (target) {
22
+ scrollToElement(target as HTMLElement);
23
+ }
24
+ }
25
+ }
26
+ };
27
+ let {
28
+ class: className = '',
29
+ tall = tallPreset.small,
30
+ width = widthPreset.full,
31
+ style,
32
+ selectorField,
33
+ role = 'menu',
34
+ grid,
35
+ showLastOnSelected = true,
36
+ presentationField,
37
+ onclick,
38
+ data = $bindable(),
39
+ selectedData = $bindable(),
40
+ selectedIndex = $bindable(),
41
+ element = $bindable(),
42
+ menuListItems = $bindable(),
43
+ menuListItemProps = $bindable(),
44
+ children,
45
+ menuListItem,
46
+ listItemBottom,
47
+ ...rest
48
+ }: MenuListProps = $props();
49
+
50
+ menuListItemProps = {
51
+ tall,
52
+ width,
53
+ selectorField,
54
+ presentationField,
55
+ ...menuListItemProps
56
+ };
57
+
58
+ let defaultStoreValues = {
59
+ menuListItems,
60
+ menuItemsInstances: [],
61
+ tall,
62
+ width,
63
+ data,
64
+ selectorField,
65
+ selectedIndex,
66
+ actions,
67
+ presentationField,
68
+ ...menuListItemProps
69
+ };
70
+
71
+ let menuStore = $state(defaultStoreValues);
72
+ setContext('menuStateContext', menuStore);
73
+
74
+ $effect(() => {
75
+ menuStore.selectedIndex = selectedIndex;
76
+ });
77
+ $effect(() => {
78
+ menuStore.tall = tall;
79
+ });
80
+ $effect(() => {
81
+ if (element) {
82
+ element.addEventListener<any>('menu:item:clicked', onMenuItemClick);
83
+
84
+ element.addEventListener('click', () => {
85
+ element?.focus();
86
+ });
87
+ element.addEventListener('menu:onnavigate', ((
88
+ event: CustomEvent<{ selectedIndex: number }>
89
+ ) => {
90
+ if (event?.detail?.selectedIndex) selectedIndex = event.detail.selectedIndex;
91
+ }) as EventListener);
92
+ }
93
+ });
94
+
95
+ function onMenuItemClick(e: CustomEvent<any>) {
96
+ if (onclick) onclick(e.detail, 2);
97
+ }
98
+
99
+ function scrollToElement(target: HTMLElement) {
100
+ if (target) {
101
+ const tD = target.getBoundingClientRect();
102
+ const sD = element?.getBoundingClientRect();
103
+ if (sD) {
104
+ if (tD.top - 10 <= sD.top || tD.bottom >= sD.bottom) {
105
+ target.scrollIntoView({ behavior: 'smooth', block: 'center' });
106
+ }
107
+ }
108
+ }
109
+ }
110
+ </script>
111
+
112
+ <!-- svelte-ignore a11y_no_noninteractive_tabindex -->
113
+ <ul
114
+ bind:this={element}
115
+ class:showLastOnSelected
116
+ class="slotui-menulist {className} {grid ? 'grid' : ''}"
117
+ tabindex="0"
118
+ style={`${style};var(--menulist-grid-items-count):${grid ? grid : '0'}`}
119
+ {role}
120
+ use:navigation={{ className: 'menulist-item', selectedIndex: -1 }}
121
+ {...rest}
122
+ >
123
+ {#if menuListItems}
124
+ {#each menuListItems ?? [] as menuItem, itemIndex}
125
+ <Slotted child={children} slotArgs={{ item: menuItem, itemIndex, menuItem }}>
126
+ <MenuListItem {...menuListItemProps} {...menuItem} {itemIndex} />
127
+ </Slotted>
128
+ {/each}
129
+ {:else if data}
130
+ {#each data as dta, itemIndex}
131
+ <Slotted child={children} slotArgs={{ item: dta, itemIndex, menuItem: dta }}>
132
+ <MenuListItem {...menuListItemProps} data={dta} {itemIndex}>
133
+ {@render menuListItem?.({ item: dta, itemIndex })}
134
+ </MenuListItem>
135
+ </Slotted>
136
+ {/each}
137
+ {:else}
138
+ <Slotted child={children} />
139
+ {/if}
140
+ {@render listItemBottom?.({ item: {}, itemIndex: -1 })}
141
+ </ul>
142
+
143
143
  <style global>:root {
144
144
  --menulist-padding: var(--sld-pad-tiny);
145
145
  --menulist-item-padding: 0;
@@ -356,4 +356,4 @@
356
356
  }
357
357
  :global(ul.menuList.showLastOnSelected) :global(a.menulist-item .menulist-item-action) {
358
358
  visibility: hidden;
359
- }</style>
359
+ }</style>