@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,168 +1,168 @@
1
- <script lang="ts">
2
- import Button from '../../controls/button/Button.svelte';
3
- import TextField from '../../controls/textfield/TextField.svelte';
4
- import { dataOp } from '../../utils/engine/utils.js';
5
- import Popper from '../../ui/popper/Popper.svelte';
6
- import MenuList from '../../ui/menuList/MenuList.svelte';
7
- import MenuListItem from '../../ui/menuList/MenuListItem.svelte';
8
- import type { FinderProps } from './types.js';
9
- import { widthPreset, type ExpandProps } from '../../types/index.js';
10
- import { onEvent } from '../../utils/uses/event.js';
11
-
12
- let {
13
- class: className = '',
14
- styleRoot = '',
15
- classRoot = '',
16
- style = '',
17
- element,
18
- data = [],
19
- defaultField = '*',
20
- showSortMenu = false,
21
- mode = 'partial',
22
- filteredData = $bindable(filit()),
23
- sizeRoot = widthPreset.auto,
24
- width = 'full',
25
- tall = 'default',
26
- ...restProps
27
- }: ExpandProps<FinderProps> = $props();
28
-
29
- let searchString: string | undefined = $state(undefined);
30
- let container: HTMLDivElement;
31
-
32
- /* export var filteredData = $derived(
33
- !searchString ? data : doFind(data, searchString, defaultField)
34
- ); */
35
-
36
- function filit() {
37
- let red = $derived(!searchString ? data : doFind(data, searchString, defaultField));
38
- return red;
39
- }
40
-
41
- function doFind<T = Record<string, any>>(list: T[], kw: string, field: string) {
42
- let results: any[];
43
- // if kw empty
44
- if (!kw) {
45
- results = data;
46
- } else {
47
- let kwEx = kw.replace('*', '.*.');
48
- results =
49
- mode === 'exact'
50
- ? dataOp.filterList(list, kwEx, field)
51
- : dataOp.searchList(list, kwEx, field); // filterList(list, kw, field);
52
- }
53
- return results;
54
- }
55
-
56
- let popperOpen: boolean;
57
-
58
- let dataKeys = $derived(
59
- Object.keys(data[0] || {})
60
- .filter((r) => ['string', 'number'].includes(typeof data?.[0]?.[r]))
61
- .sort((a: string, b: string) => {
62
- return a > b ? 1 : a < b ? -1 : 0;
63
- })
64
- );
65
- </script>
66
-
67
- <div
68
- class="finder-container {classRoot}"
69
- data-width={sizeRoot}
70
- bind:this={container}
71
- use:onEvent={{
72
- event: 'on:click:away',
73
- action: () => {
74
- popperOpen = false;
75
- }
76
- }}
77
- style={styleRoot}
78
- >
79
- <div style:flex="1">
80
- <TextField
81
- bind:value={searchString}
82
- bind:element
83
- placeholder="find by {defaultField} {mode}"
84
- type="search"
85
- inputType="search"
86
- {width}
87
- class={className}
88
- {...restProps}
89
- />
90
- </div>
91
- {#if showSortMenu}
92
- <Button
93
- onclick={(event) => {
94
- event.preventDefault();
95
- popperOpen = !popperOpen;
96
- }}
97
- variant="naked"
98
- width="tiny"
99
- icon={{ icon: `chevron-${popperOpen ? 'up' : 'down'}`, iconSize: 'tiny' }}
100
- />
101
- {/if}
102
- </div>
103
- {#if popperOpen}
104
- <Popper code="ui" parentNode={container} position="BC" stickToHookWidth={true}>
105
- <MenuList style="max-height:350px;overflow:auto;width:100%;" density="default">
106
- <MenuListItem
107
- divider={true}
108
- text="strict"
109
- onclick={() => {
110
- if (mode === 'exact') {
111
- mode = 'partial';
112
- } else {
113
- mode = 'exact';
114
- }
115
- }}
116
- >
117
- {#snippet menuItemLast()}
118
- <div class="pad-r-1">
119
- <input type="checkbox" checked={mode === 'exact'} style="display:block;margin:0" />
120
- </div>
121
- {/snippet}
122
- strict
123
- </MenuListItem>
124
- <MenuListItem
125
- text="strict"
126
- onclick={() => {
127
- defaultField = '*';
128
- }}
129
- >{#snippet menuItemLast()}
130
- <div class="pad-r-1">
131
- {#if defaultField === '*'}
132
- <input
133
- type="checkbox"
134
- checked={defaultField === '*'}
135
- style="display:block;margin:0"
136
- />
137
- {/if}
138
- </div>
139
- {/snippet}
140
- {'* All fields'}
141
- </MenuListItem>
142
- {#each dataKeys as kk}
143
- <MenuListItem
144
- text="strict"
145
- onclick={() => {
146
- defaultField = kk;
147
- }}
148
- >{#snippet menuItemLast()}
149
- <div class="pad-r-1">
150
- {#if defaultField === kk}
151
- <input
152
- type="checkbox"
153
- checked={defaultField === kk}
154
- style="display:block;margin:0"
155
- />
156
- {/if}
157
- </div>
158
- {/snippet}
159
- {kk}
160
- </MenuListItem>
161
- {/each}
162
- </MenuList>
163
- </Popper>
164
- {/if}
165
-
1
+ <script lang="ts">
2
+ import Button from '../../controls/button/Button.svelte';
3
+ import TextField from '../../controls/textfield/TextField.svelte';
4
+ import { dataOp } from '../../utils/engine/utils.js';
5
+ import Popper from '../../ui/popper/Popper.svelte';
6
+ import MenuList from '../../ui/menuList/MenuList.svelte';
7
+ import MenuListItem from '../../ui/menuList/MenuListItem.svelte';
8
+ import type { FinderProps } from './types.js';
9
+ import { widthPreset, type ExpandProps } from '../../types/index.js';
10
+ import { onEvent } from '../../utils/uses/event.js';
11
+
12
+ let {
13
+ class: className = '',
14
+ styleRoot = '',
15
+ classRoot = '',
16
+ style = '',
17
+ element,
18
+ data = [],
19
+ defaultField = '*',
20
+ showSortMenu = false,
21
+ mode = 'partial',
22
+ filteredData = $bindable(filit()),
23
+ sizeRoot = widthPreset.auto,
24
+ width = 'full',
25
+ tall = 'default',
26
+ ...restProps
27
+ }: ExpandProps<FinderProps> = $props();
28
+
29
+ let searchString: string | undefined = $state(undefined);
30
+ let container: HTMLDivElement;
31
+
32
+ /* export var filteredData = $derived(
33
+ !searchString ? data : doFind(data, searchString, defaultField)
34
+ ); */
35
+
36
+ function filit() {
37
+ let red = $derived(!searchString ? data : doFind(data, searchString, defaultField));
38
+ return red;
39
+ }
40
+
41
+ function doFind<T = Record<string, any>>(list: T[], kw: string, field: string) {
42
+ let results: any[];
43
+ // if kw empty
44
+ if (!kw) {
45
+ results = data;
46
+ } else {
47
+ let kwEx = kw.replace('*', '.*.');
48
+ results =
49
+ mode === 'exact'
50
+ ? dataOp.filterList(list, kwEx, field)
51
+ : dataOp.searchList(list, kwEx, field); // filterList(list, kw, field);
52
+ }
53
+ return results;
54
+ }
55
+
56
+ let popperOpen: boolean;
57
+
58
+ let dataKeys = $derived(
59
+ Object.keys(data[0] || {})
60
+ .filter((r) => ['string', 'number'].includes(typeof data?.[0]?.[r]))
61
+ .sort((a: string, b: string) => {
62
+ return a > b ? 1 : a < b ? -1 : 0;
63
+ })
64
+ );
65
+ </script>
66
+
67
+ <div
68
+ class="finder-container {classRoot}"
69
+ data-width={sizeRoot}
70
+ bind:this={container}
71
+ use:onEvent={{
72
+ event: 'on:click:away',
73
+ action: () => {
74
+ popperOpen = false;
75
+ }
76
+ }}
77
+ style={styleRoot}
78
+ >
79
+ <div style:flex="1">
80
+ <TextField
81
+ bind:value={searchString}
82
+ bind:element
83
+ placeholder="find by {defaultField} {mode}"
84
+ type="search"
85
+ inputType="search"
86
+ {width}
87
+ class={className}
88
+ {...restProps}
89
+ />
90
+ </div>
91
+ {#if showSortMenu}
92
+ <Button
93
+ onclick={(event) => {
94
+ event.preventDefault();
95
+ popperOpen = !popperOpen;
96
+ }}
97
+ variant="naked"
98
+ width="tiny"
99
+ icon={{ icon: `chevron-${popperOpen ? 'up' : 'down'}`, iconSize: 'tiny' }}
100
+ />
101
+ {/if}
102
+ </div>
103
+ {#if popperOpen}
104
+ <Popper code="ui" parentNode={container} position="BC" stickToHookWidth={true}>
105
+ <MenuList style="max-height:350px;overflow:auto;width:100%;" density="default">
106
+ <MenuListItem
107
+ divider={true}
108
+ text="strict"
109
+ onclick={() => {
110
+ if (mode === 'exact') {
111
+ mode = 'partial';
112
+ } else {
113
+ mode = 'exact';
114
+ }
115
+ }}
116
+ >
117
+ {#snippet menuItemLast()}
118
+ <div class="pad-r-1">
119
+ <input type="checkbox" checked={mode === 'exact'} style="display:block;margin:0" />
120
+ </div>
121
+ {/snippet}
122
+ strict
123
+ </MenuListItem>
124
+ <MenuListItem
125
+ text="strict"
126
+ onclick={() => {
127
+ defaultField = '*';
128
+ }}
129
+ >{#snippet menuItemLast()}
130
+ <div class="pad-r-1">
131
+ {#if defaultField === '*'}
132
+ <input
133
+ type="checkbox"
134
+ checked={defaultField === '*'}
135
+ style="display:block;margin:0"
136
+ />
137
+ {/if}
138
+ </div>
139
+ {/snippet}
140
+ {'* All fields'}
141
+ </MenuListItem>
142
+ {#each dataKeys as kk}
143
+ <MenuListItem
144
+ text="strict"
145
+ onclick={() => {
146
+ defaultField = kk;
147
+ }}
148
+ >{#snippet menuItemLast()}
149
+ <div class="pad-r-1">
150
+ {#if defaultField === kk}
151
+ <input
152
+ type="checkbox"
153
+ checked={defaultField === kk}
154
+ style="display:block;margin:0"
155
+ />
156
+ {/if}
157
+ </div>
158
+ {/snippet}
159
+ {kk}
160
+ </MenuListItem>
161
+ {/each}
162
+ </MenuList>
163
+ </Popper>
164
+ {/if}
165
+
166
166
  <style>:root {
167
167
  --finder-gap: var(--sld-gap-tiny);
168
168
  }
@@ -236,4 +236,4 @@
236
236
  }
237
237
  .finder-container[tall=default], .finder-container.tall-default {
238
238
  min-height: var(--sld-tall-default) !important;
239
- }</style>
239
+ }</style>
@@ -1,14 +1,14 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --finder-gap: var(--sld-gap-tiny);
5
- }
6
-
7
- .finder {
8
- &-container {
9
- display: inline-flex;
10
- gap: var(--finder-gap);
11
- @include slotui-mixins.ui-width-presets;
12
- @include slotui-mixins.ui-tall-presets;
13
- }
14
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --finder-gap: var(--sld-gap-tiny);
5
+ }
6
+
7
+ .finder {
8
+ &-container {
9
+ display: inline-flex;
10
+ gap: var(--finder-gap);
11
+ @include slotui-mixins.ui-width-presets;
12
+ @include slotui-mixins.ui-tall-presets;
13
+ }
14
+ }
@@ -1,36 +1,36 @@
1
- <script lang="ts">
2
- import Grouper from './Grouper.svelte';
3
-
4
- import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
5
- import Demoer from '../../base/demoer/Demoer.svelte';
6
- import DemoPage from '../../base/demoer/DemoPage.svelte';
7
- /* demo */
8
-
9
- import { parameters, componentArgs } from './types.js';
10
-
11
- let code = `<Grouper
12
- bind:groupedData
13
- bind:activeGroupField
14
- {data}
15
- />`;
16
-
17
- let groupedData: any;
18
- let activeGroupField: any;
19
- </script>
20
-
21
- <ComponentDemo component="Grouper">
22
- <div class="flex-v gap-large">
23
- <DemoPage {code} component="Popper">
24
- <Demoer {componentArgs} {parameters}>
25
- {#snippet children({ activeParams })}
26
- <div class="flex-h flex-align-middle gap-tiny">
27
- <Grouper bind:groupedData bind:activeGroupField {...activeParams} />
28
- {activeGroupField}
29
- </div>
30
- {JSON.stringify(groupedData)}
31
- {JSON.stringify(activeGroupField)}
32
- {/snippet}
33
- </Demoer>
34
- </DemoPage>
35
- </div>
36
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import Grouper from './Grouper.svelte';
3
+
4
+ import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
5
+ import Demoer from '../../base/demoer/Demoer.svelte';
6
+ import DemoPage from '../../base/demoer/DemoPage.svelte';
7
+ /* demo */
8
+
9
+ import { parameters, componentArgs } from './types.js';
10
+
11
+ let code = `<Grouper
12
+ bind:groupedData
13
+ bind:activeGroupField
14
+ {data}
15
+ />`;
16
+
17
+ let groupedData: any;
18
+ let activeGroupField: any;
19
+ </script>
20
+
21
+ <ComponentDemo component="Grouper">
22
+ <div class="flex-v gap-large">
23
+ <DemoPage {code} component="Popper">
24
+ <Demoer {componentArgs} {parameters}>
25
+ {#snippet children({ activeParams })}
26
+ <div class="flex-h flex-align-middle gap-tiny">
27
+ <Grouper bind:groupedData bind:activeGroupField {...activeParams} />
28
+ {activeGroupField}
29
+ </div>
30
+ {JSON.stringify(groupedData)}
31
+ {JSON.stringify(activeGroupField)}
32
+ {/snippet}
33
+ </Demoer>
34
+ </DemoPage>
35
+ </div>
36
+ </ComponentDemo>
@@ -1,85 +1,85 @@
1
- <script lang="ts" generics="T extends object">
2
- import Button from '../../controls/button/Button.svelte';
3
- import ButtonMenu from '../../controls/button/ButtonMenu.svelte';
4
- import type { Data, ExpandProps } from '../../types/index.js';
5
- import { dataOp } from '@medyll/idae-engine';
6
-
7
- import type { GrouperProps } from './types.js';
8
- import Looper from '../../utils/looper/Looper.svelte';
9
- import type { MenuListItemProps } from '../../ui/menuList/types.js';
10
-
11
- let {
12
- class: className = '',
13
- element,
14
- elementButton,
15
- style = '',
16
- groupBy,
17
- grouperMode = 'menu',
18
- groupListItems,
19
- data,
20
- buttonProps,
21
- groupByField,
22
- groupByTitleField,
23
- groupByOrder = 'asc',
24
- showUnGrouped = false,
25
- ungroupedTitle = 'ungrouped',
26
- activeGroupField = $bindable(),
27
- groupedData = $bindable(),
28
- children,
29
- ...rest
30
- }: ExpandProps<GrouperProps<T>> = $props();
31
-
32
- let groupedFieldList = $derived(dataOp.getDataKeys(data ?? []) ?? []);
33
-
34
- let menuProps = $derived.by(() => {
35
- let menuListItems = groupedFieldList.map((dtaK: any) => {
36
- return { text: dtaK, data: dtaK } as MenuListItemProps;
37
- });
38
-
39
- menuListItems.push({ text: 'un-group', icon: 'cancel', data: [] });
40
- return {
41
- menuListItems,
42
- onclick: (field: any) => {
43
- //if (field) {
44
- activeGroupField = field;
45
- groupedData = dataOp.groupBy<T>({
46
- dataList: data ?? [],
47
- groupBy: field ?? 'undefined'
48
- });
49
- //}
50
- }
51
- };
52
- });
53
-
54
- function buttonSelect(field: any) {
55
- if (field) {
56
- activeGroupField = field;
57
- groupedData = dataOp.groupBy<T>({
58
- dataList: data ?? [],
59
- groupBy: field ?? 'undefined'
60
- });
61
- }
62
- }
63
- </script>
64
-
65
- <div bind:this={element} class="grouper {className}" {style} {...rest}>
66
- {#if grouperMode === 'menu'}
67
- <ButtonMenu bind:element={elementButton} {...buttonProps} {menuProps}>
68
- {activeGroupField ?? 'group by'}
69
- </ButtonMenu>
70
- {/if}
71
- {#if grouperMode === 'button'}
72
- <Looper style="display:flex;gap:0.2rem;" class="flex-h" data={groupedFieldList}>
73
- {#snippet children({ item })}
74
- <Button
75
- onclick={() => {
76
- buttonSelect(item);
77
- }}
78
- {...buttonProps}
79
- title={item}
80
- width="mini">{item}</Button
81
- >
82
- {/snippet}
83
- </Looper>
84
- {/if}
85
- </div>
1
+ <script lang="ts" generics="T extends object">
2
+ import Button from '../../controls/button/Button.svelte';
3
+ import ButtonMenu from '../../controls/button/ButtonMenu.svelte';
4
+ import type { Data, ExpandProps } from '../../types/index.js';
5
+ import { dataOp } from '@medyll/idae-engine';
6
+
7
+ import type { GrouperProps } from './types.js';
8
+ import Looper from '../../utils/looper/Looper.svelte';
9
+ import type { MenuListItemProps } from '../../ui/menuList/types.js';
10
+
11
+ let {
12
+ class: className = '',
13
+ element,
14
+ elementButton,
15
+ style = '',
16
+ groupBy,
17
+ grouperMode = 'menu',
18
+ groupListItems,
19
+ data,
20
+ buttonProps,
21
+ groupByField,
22
+ groupByTitleField,
23
+ groupByOrder = 'asc',
24
+ showUnGrouped = false,
25
+ ungroupedTitle = 'ungrouped',
26
+ activeGroupField = $bindable(),
27
+ groupedData = $bindable(),
28
+ children,
29
+ ...rest
30
+ }: ExpandProps<GrouperProps<T>> = $props();
31
+
32
+ let groupedFieldList = $derived(dataOp.getDataKeys(data ?? []) ?? []);
33
+
34
+ let menuProps = $derived.by(() => {
35
+ let menuListItems = groupedFieldList.map((dtaK: any) => {
36
+ return { text: dtaK, data: dtaK } as MenuListItemProps;
37
+ });
38
+
39
+ menuListItems.push({ text: 'un-group', icon: 'cancel', data: [] });
40
+ return {
41
+ menuListItems,
42
+ onclick: (field: any) => {
43
+ //if (field) {
44
+ activeGroupField = field;
45
+ groupedData = dataOp.groupBy<T>({
46
+ dataList: data ?? [],
47
+ groupBy: field ?? 'undefined'
48
+ });
49
+ //}
50
+ }
51
+ };
52
+ });
53
+
54
+ function buttonSelect(field: any) {
55
+ if (field) {
56
+ activeGroupField = field;
57
+ groupedData = dataOp.groupBy<T>({
58
+ dataList: data ?? [],
59
+ groupBy: field ?? 'undefined'
60
+ });
61
+ }
62
+ }
63
+ </script>
64
+
65
+ <div bind:this={element} class="grouper {className}" {style} {...rest}>
66
+ {#if grouperMode === 'menu'}
67
+ <ButtonMenu bind:element={elementButton} {...buttonProps} {menuProps}>
68
+ {activeGroupField ?? 'group by'}
69
+ </ButtonMenu>
70
+ {/if}
71
+ {#if grouperMode === 'button'}
72
+ <Looper style="display:flex;gap:0.2rem;" class="flex-h" data={groupedFieldList}>
73
+ {#snippet children({ item })}
74
+ <Button
75
+ onclick={() => {
76
+ buttonSelect(item);
77
+ }}
78
+ {...buttonProps}
79
+ title={item}
80
+ width="mini">{item}</Button
81
+ >
82
+ {/snippet}
83
+ </Looper>
84
+ {/if}
85
+ </div>