@medyll/idae-slotui-svelte 0.120.0 → 0.122.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 +46 -47
  119. package/dist/index.js +46 -47
  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 +288 -288
  128. package/dist/slotui-css/slotui-min-css.css +288 -288
  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,152 +1,152 @@
1
- <script lang="ts" generics="T">
2
- import type { AutoCompleteProps } from './types.js';
3
-
4
- import TextField from '../textfield/TextField.svelte';
5
- import { dataOp } from '../../utils/engine/utils.js';
6
- import Popper from '../../ui/popper/Popper.svelte';
7
- import MenuList from '../../ui/menuList/MenuList.svelte';
8
- import MenuListItem from '../../ui/menuList/MenuListItem.svelte';
9
- import Icon from '../../base/icon/Icon.svelte';
10
- import type { Data, ExpandProps } from '../../types/index.js';
11
- import Slotted from '../../utils/slotted/Slotted.svelte';
12
-
13
- let {
14
- class: className = '',
15
- element = $bindable(),
16
- data = $bindable([]),
17
- searchField = '*',
18
- dataFieldName,
19
- mode = 'partial',
20
- filteredData = $bindable<T[]>(data),
21
- selectedIndex = $bindable(-1),
22
- onchange = (args) => {},
23
- showAllOnEmpty = true,
24
- children,
25
- autoCompleteEmpty,
26
- autoCompleteNoResults,
27
- ...rest
28
- }: ExpandProps<AutoCompleteProps<T>> & Partial<Omit<HTMLInputElement, 'style'>> = $props();
29
-
30
- let searchString: string | undefined = $state(undefined);
31
- let menuHTML: HTMLElement | null = $state(null);
32
- let popperHTML: HTMLElement | undefined = $state(undefined);
33
- let popperOpen: boolean = $state(false);
34
-
35
- let menuRef: MenuList<T>;
36
-
37
- let childs = children;
38
-
39
- $effect(() => {
40
- element?.addEventListener('keypress', ((e: KeyboardEvent) => {
41
- preNavigate(e);
42
- }) as EventListener);
43
- });
44
- $effect(() => {
45
- filteredData = !searchString
46
- ? showAllOnEmpty
47
- ? data
48
- : []
49
- : doFind(data, searchString, searchField);
50
- });
51
-
52
- const doFind = <T = Record<string, any>,>(list: T[], kw: string, field: string) => {
53
- let results: any[];
54
-
55
- if (!kw) {
56
- results = data;
57
- } else {
58
- results =
59
- mode === 'exact' ? dataOp.filterList(list, kw, field) : dataOp.searchList(list, kw, field);
60
- }
61
- return results;
62
- };
63
-
64
- async function preNavigate(e: KeyboardEvent) {
65
- if (e.keyCode === 13) {
66
- e.preventDefault();
67
- onSelect(filteredData[selectedIndex], selectedIndex);
68
- return;
69
- }
70
- }
71
-
72
- function onSelect(filteredData: T, index: number) {
73
- searchString = getFieldName(filteredData, dataFieldName as keyof T) as string;
74
- if (onchange) onchange(filteredData);
75
- }
76
-
77
- function getFieldName(data: T, fieldName: keyof T | (keyof T)[]): string {
78
- let field = Array.isArray(fieldName) ? fieldName : [fieldName];
79
-
80
- return data ? field.map((field) => data[field]).join(' ') : '';
81
- }
82
- </script>
83
-
84
- {popperOpen}
85
- <Popper
86
- bind:isOpen={popperOpen}
87
- bind:element={popperHTML}
88
- position="BC"
89
- stickToHookWidth={true}
90
- autoClose
91
- class="auto-complete"
92
- >
93
- {#snippet popperHolder()}
94
- <TextField
95
- bind:value={searchString}
96
- bind:element
97
- type="search"
98
- inputType="search"
99
- class={className}
100
- onclick={() => (popperOpen = true)}
101
- onfocus={() => {
102
- setTimeout(() => (popperOpen = true), 125);
103
- }}
104
- onkeydown={(e: Event) => menuRef.actions.navigate(e, filteredData)}
105
- {...rest}
106
- aria-haspopup="menu"
107
- aria-controls="menu"
108
- tabindex="0"
109
- />
110
- {/snippet}
111
-
112
- <MenuList
113
- bind:this={menuRef}
114
- style="max-height:350px;overflow:auto;width:100%;"
115
- data={filteredData}
116
- bind:element={menuHTML}
117
- bind:selectedIndex
118
- id="menu"
119
- role="menu"
120
- tabindex="-1"
121
- aria-expanded={popperOpen}
122
- >
123
- {#snippet children(prop)}
124
- <Slotted child={childs} slotArgs={prop.item}>
125
- <MenuListItem
126
- text={getFieldName(prop.item, dataFieldName)}
127
- data={prop.item}
128
- onclick={(event) => {
129
- onSelect(event.detail ?? (event as T), prop.itemIndex);
130
- popperOpen = false;
131
- menuRef.actions.gotoIndex(prop.itemIndex);
132
- }}
133
- />
134
- </Slotted>
135
- {/snippet}
136
- </MenuList>
137
- {#if !filteredData.length && !searchString}
138
- <Slotted child={autoCompleteEmpty}>
139
- <div class="auto-complete-boot">
140
- <Icon iconSize="large" icon="fa-regular:keyboard" />
141
- perform search
142
- </div>
143
- </Slotted>
144
- {:else if !filteredData.length}
145
- <Slotted child={autoCompleteNoResults}>
146
- <div class="auto-complete-no-results">
147
- <Icon class="dsp-inline" iconSize="large" icon="material-symbols:no-sim-outline" />
148
- no results
149
- </div>
150
- </Slotted>
151
- {/if}
152
- </Popper>
1
+ <script lang="ts" generics="T">
2
+ import type { AutoCompleteProps } from './types.js';
3
+
4
+ import TextField from '../textfield/TextField.svelte';
5
+ import { dataOp } from '../../utils/engine/utils.js';
6
+ import Popper from '../../ui/popper/Popper.svelte';
7
+ import MenuList from '../../ui/menuList/MenuList.svelte';
8
+ import MenuListItem from '../../ui/menuList/MenuListItem.svelte';
9
+ import Icon from '../../base/icon/Icon.svelte';
10
+ import type { Data, ExpandProps } from '../../types/index.js';
11
+ import Slotted from '../../utils/slotted/Slotted.svelte';
12
+
13
+ let {
14
+ class: className = '',
15
+ element = $bindable(),
16
+ data = $bindable([]),
17
+ searchField = '*',
18
+ dataFieldName,
19
+ mode = 'partial',
20
+ filteredData = $bindable<T[]>(data),
21
+ selectedIndex = $bindable(-1),
22
+ onchange = (args) => {},
23
+ showAllOnEmpty = true,
24
+ children,
25
+ autoCompleteEmpty,
26
+ autoCompleteNoResults,
27
+ ...rest
28
+ }: ExpandProps<AutoCompleteProps<T>> & Partial<Omit<HTMLInputElement, 'style'>> = $props();
29
+
30
+ let searchString: string | undefined = $state(undefined);
31
+ let menuHTML: HTMLElement | null = $state(null);
32
+ let popperHTML: HTMLElement | undefined = $state(undefined);
33
+ let popperOpen: boolean = $state(false);
34
+
35
+ let menuRef: MenuList<T>;
36
+
37
+ let childs = children;
38
+
39
+ $effect(() => {
40
+ element?.addEventListener('keypress', ((e: KeyboardEvent) => {
41
+ preNavigate(e);
42
+ }) as EventListener);
43
+ });
44
+ $effect(() => {
45
+ filteredData = !searchString
46
+ ? showAllOnEmpty
47
+ ? data
48
+ : []
49
+ : doFind(data, searchString, searchField);
50
+ });
51
+
52
+ const doFind = <T = Record<string, any>,>(list: T[], kw: string, field: string) => {
53
+ let results: any[];
54
+
55
+ if (!kw) {
56
+ results = data;
57
+ } else {
58
+ results =
59
+ mode === 'exact' ? dataOp.filterList(list, kw, field) : dataOp.searchList(list, kw, field);
60
+ }
61
+ return results;
62
+ };
63
+
64
+ async function preNavigate(e: KeyboardEvent) {
65
+ if (e.keyCode === 13) {
66
+ e.preventDefault();
67
+ onSelect(filteredData[selectedIndex], selectedIndex);
68
+ return;
69
+ }
70
+ }
71
+
72
+ function onSelect(filteredData: T, index: number) {
73
+ searchString = getFieldName(filteredData, dataFieldName as keyof T) as string;
74
+ if (onchange) onchange(filteredData);
75
+ }
76
+
77
+ function getFieldName(data: T, fieldName: keyof T | (keyof T)[]): string {
78
+ let field = Array.isArray(fieldName) ? fieldName : [fieldName];
79
+
80
+ return data ? field.map((field) => data[field]).join(' ') : '';
81
+ }
82
+ </script>
83
+
84
+ {popperOpen}
85
+ <Popper
86
+ bind:isOpen={popperOpen}
87
+ bind:element={popperHTML}
88
+ position="BC"
89
+ stickToHookWidth={true}
90
+ autoClose
91
+ class="auto-complete"
92
+ >
93
+ {#snippet popperHolder()}
94
+ <TextField
95
+ bind:value={searchString}
96
+ bind:element
97
+ type="search"
98
+ inputType="search"
99
+ class={className}
100
+ onclick={() => (popperOpen = true)}
101
+ onfocus={() => {
102
+ setTimeout(() => (popperOpen = true), 125);
103
+ }}
104
+ onkeydown={(e: Event) => menuRef.actions.navigate(e, filteredData)}
105
+ {...rest}
106
+ aria-haspopup="menu"
107
+ aria-controls="menu"
108
+ tabindex="0"
109
+ />
110
+ {/snippet}
111
+
112
+ <MenuList
113
+ bind:this={menuRef}
114
+ style="max-height:350px;overflow:auto;width:100%;"
115
+ data={filteredData}
116
+ bind:element={menuHTML}
117
+ bind:selectedIndex
118
+ id="menu"
119
+ role="menu"
120
+ tabindex="-1"
121
+ aria-expanded={popperOpen}
122
+ >
123
+ {#snippet children(prop)}
124
+ <Slotted child={childs} slotArgs={prop.item}>
125
+ <MenuListItem
126
+ text={getFieldName(prop.item, dataFieldName)}
127
+ data={prop.item}
128
+ onclick={(event) => {
129
+ onSelect(event.detail ?? (event as T), prop.itemIndex);
130
+ popperOpen = false;
131
+ menuRef.actions.gotoIndex(prop.itemIndex);
132
+ }}
133
+ />
134
+ </Slotted>
135
+ {/snippet}
136
+ </MenuList>
137
+ {#if !filteredData.length && !searchString}
138
+ <Slotted child={autoCompleteEmpty}>
139
+ <div class="auto-complete-boot">
140
+ <Icon iconSize="large" icon="fa-regular:keyboard" />
141
+ perform search
142
+ </div>
143
+ </Slotted>
144
+ {:else if !filteredData.length}
145
+ <Slotted child={autoCompleteNoResults}>
146
+ <div class="auto-complete-no-results">
147
+ <Icon class="dsp-inline" iconSize="large" icon="material-symbols:no-sim-outline" />
148
+ no results
149
+ </div>
150
+ </Slotted>
151
+ {/if}
152
+ </Popper>
@@ -1,15 +1,15 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --auto-complete-pad: var(--sld-pad-medium);
5
- --auto-complete-gap: var(--sld-gap-small);
6
- }
7
-
8
- .auto-complete {
9
- &-no-results,
10
- &-boot {
11
- padding: var(--auto-complete-pad);
12
- gap: var(--auto-complete-gap);
13
- @include slotui-mixins.flex(row, center);
14
- }
15
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --auto-complete-pad: var(--sld-pad-medium);
5
+ --auto-complete-gap: var(--sld-gap-small);
6
+ }
7
+
8
+ .auto-complete {
9
+ &-no-results,
10
+ &-boot {
11
+ padding: var(--auto-complete-pad);
12
+ gap: var(--auto-complete-gap);
13
+ @include slotui-mixins.flex(row, center);
14
+ }
15
+ }
@@ -1,165 +1,165 @@
1
- <script lang="ts">
2
- import MenuList from '../../ui/menuList/MenuList.svelte';
3
- import MenuListItem from '../../ui/menuList/MenuListItem.svelte';
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
- import Icon from '../../base/icon/Icon.svelte';
8
- import Button from './Button.svelte';
9
- import { uiPresets } from '../../utils/engine/presets.js';
10
- import ButtonAction from './ButtonAction.svelte';
11
- import ButtonMenu from './ButtonMenu.svelte';
12
-
13
- import { parameters, componentArgs } from './types.js';
14
-
15
- let multiple = {
16
- bgTheme: {
17
- none: { bgTheme: undefined },
18
- primary: { bgTheme: 'primary' },
19
- secondary: { bgTheme: 'secondary' },
20
- tertiary: { bgTheme: 'tertiary' }
21
- }
22
- };
23
-
24
- let parametersMenu: any = {
25
- position: {
26
- type: 'stickyPosition',
27
- values: uiPresets.stickyPosition
28
- }
29
- };
30
- /** */
31
- let styleParameters: any = {
32
- color: {
33
- type: 'color-preset',
34
- values: [undefined, 'primary', 'secondary', 'tertiary']
35
- },
36
- contained: {
37
- type: 'boolean',
38
- values: [true, false]
39
- },
40
- bordered: {
41
- type: 'boolean',
42
- values: [true, false]
43
- },
44
- link: {
45
- type: 'boolean',
46
- values: [true, false]
47
- }
48
- };
49
-
50
- let code = `
51
- <Button onclick={()=>{}} >
52
- My button
53
- {#snippet buttonStart()}
54
- <Icon icon="user" />
55
- {/snippet}
56
- {#snippet buttonEnd()}
57
- <Icon icon="user" />
58
- {/snippet}
59
- </Button>`;
60
- </script>
61
-
62
- <Button variant="contained" value="red" icon="material-symbols-light:post-add-sharp"></Button>
63
- <ButtonAction
64
- >test et essai
65
- {#snippet popperContent()}
66
- <div class="pad-4">content</div>
67
- {/snippet}
68
- </ButtonAction>
69
- <ButtonMenu
70
- >menu
71
- {#snippet menuItem()}
72
- content
73
- {/snippet}
74
- </ButtonMenu>
75
- <ButtonMenu
76
- tall="small"
77
- width="auto"
78
- icon="material-symbols-light:post-add-sharp"
79
- value={"Some text for the menu with an icon"}
80
- popperProps={{ stickToHookWidth: true, position: 'TL', flow: 'fixed', autoClose: true }}
81
- variant="naked"
82
- menuProps={{
83
- data: [],
84
- grid: 3,
85
- onclick: (event) => {
86
- // chatParams.promptSystem = event;
87
- },
88
- }}>
89
- {#snippet menuItem({ item })}
90
- <MenuListItem data={item}>
91
- {item?.name}
92
- </MenuListItem>
93
- {/snippet}
94
- </ButtonMenu>
95
- <ComponentDemo
96
- component="Button"
97
- cite="There were a place where we used to click. You've called it a button, and we clicked yes.<br /> R. Falgt, 1354"
98
- >
99
- <div class="flex-v gap-medium">
100
- <DemoPage {code} component="Button">
101
- <Demoer {parameters} {componentArgs}>
102
- {#snippet children({ activeParams })}
103
- <Button {...activeParams}
104
- >Using snippets scscs dsvdvd
105
- <!-- {#snippet buttonStart()}
106
- <Icon icon="user" />
107
- {/snippet} -->
108
-
109
- {#snippet buttonLoadingIcon()}
110
- <Icon icon="loading" rotate />
111
- {/snippet}
112
- </Button>
113
- {/snippet}
114
- </Demoer>
115
- </DemoPage>
116
- <DemoPage title="" subTitle="Styling props" component="Button">
117
- <Demoer parameters={styleParameters} {multiple} {componentArgs}>
118
- {#snippet children({ activeParams })}
119
- <Button {...activeParams}
120
- >Using snippets
121
- {#snippet buttonStart()}
122
- <Icon icon="user" />
123
- {/snippet}
124
- {#snippet buttonLoadingIcon()}
125
- <Icon icon="loading" rotate />
126
- {/snippet}
127
- </Button>
128
- {/snippet}
129
- </Demoer>
130
- </DemoPage>
131
- <DemoPage title="" subTitle="Menu buttons" component="Button">
132
- <Demoer parameters={parametersMenu} {componentArgs}>
133
- <Button>
134
- default action
135
- {#snippet buttonPopper()}
136
- <MenuList style="max-height:350px;overflow:auto" density="default">
137
- <MenuListItem divider={true} text="strict">menu</MenuListItem>
138
- <MenuListItem data={{ some: 'data' }} text="strict">item</MenuListItem>
139
- <MenuListItem data={{ some: 'data' }} text="strict">item</MenuListItem>
140
- <MenuListItem data={{ some: 'data' }} text="strict">item</MenuListItem>
141
- </MenuList>
142
- {/snippet}
143
- </Button>
144
- </Demoer>
145
- </DemoPage>
146
- <!-- <DemoPage title="Using props" code={code2} component="Button">
147
- <Demoer parameters={parametersProps} {componentArgs}>
148
- {#snippet children({ activeParams })}
149
- <Button {...activeParams}>Using props</Button>
150
- {/snippet}
151
- </Demoer>
152
- </DemoPage> -->
153
- <!-- <DemoPage title="" subTitle="Menu buttons" code={code3} component="Button">
154
- <Demoer parameters={parametersMenu} {componentArgs}>
155
- {#snippet children({ activeParams })}
156
- <Button
157
- size="medium"
158
- usePopper={{ ...usePopper, position: activeParams?.position }}
159
- primary="Menu {activeParams?.position ?? ''}"
160
- />
161
- {/snippet}
162
- </Demoer>
163
- </DemoPage> -->
164
- </div>
165
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import MenuList from '../../ui/menuList/MenuList.svelte';
3
+ import MenuListItem from '../../ui/menuList/MenuListItem.svelte';
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
+ import Icon from '../../base/icon/Icon.svelte';
8
+ import Button from './Button.svelte';
9
+ import { uiPresets } from '../../utils/engine/presets.js';
10
+ import ButtonAction from './ButtonAction.svelte';
11
+ import ButtonMenu from './ButtonMenu.svelte';
12
+
13
+ import { parameters, componentArgs } from './types.js';
14
+
15
+ let multiple = {
16
+ bgTheme: {
17
+ none: { bgTheme: undefined },
18
+ primary: { bgTheme: 'primary' },
19
+ secondary: { bgTheme: 'secondary' },
20
+ tertiary: { bgTheme: 'tertiary' }
21
+ }
22
+ };
23
+
24
+ let parametersMenu: any = {
25
+ position: {
26
+ type: 'stickyPosition',
27
+ values: uiPresets.stickyPosition
28
+ }
29
+ };
30
+ /** */
31
+ let styleParameters: any = {
32
+ color: {
33
+ type: 'color-preset',
34
+ values: [undefined, 'primary', 'secondary', 'tertiary']
35
+ },
36
+ contained: {
37
+ type: 'boolean',
38
+ values: [true, false]
39
+ },
40
+ bordered: {
41
+ type: 'boolean',
42
+ values: [true, false]
43
+ },
44
+ link: {
45
+ type: 'boolean',
46
+ values: [true, false]
47
+ }
48
+ };
49
+
50
+ let code = `
51
+ <Button onclick={()=>{}} >
52
+ My button
53
+ {#snippet buttonStart()}
54
+ <Icon icon="user" />
55
+ {/snippet}
56
+ {#snippet buttonEnd()}
57
+ <Icon icon="user" />
58
+ {/snippet}
59
+ </Button>`;
60
+ </script>
61
+
62
+ <Button variant="contained" value="red" icon="material-symbols-light:post-add-sharp"></Button>
63
+ <ButtonAction
64
+ >test et essai
65
+ {#snippet popperContent()}
66
+ <div class="pad-4">content</div>
67
+ {/snippet}
68
+ </ButtonAction>
69
+ <ButtonMenu
70
+ >menu
71
+ {#snippet menuItem()}
72
+ content
73
+ {/snippet}
74
+ </ButtonMenu>
75
+ <ButtonMenu
76
+ tall="small"
77
+ width="auto"
78
+ icon="material-symbols-light:post-add-sharp"
79
+ value={"Some text for the menu with an icon"}
80
+ popperProps={{ stickToHookWidth: true, position: 'TL', flow: 'fixed', autoClose: true }}
81
+ variant="naked"
82
+ menuProps={{
83
+ data: [],
84
+ grid: 3,
85
+ onclick: (event) => {
86
+ // chatParams.promptSystem = event;
87
+ },
88
+ }}>
89
+ {#snippet menuItem({ item })}
90
+ <MenuListItem data={item}>
91
+ {item?.name}
92
+ </MenuListItem>
93
+ {/snippet}
94
+ </ButtonMenu>
95
+ <ComponentDemo
96
+ component="Button"
97
+ cite="There were a place where we used to click. You've called it a button, and we clicked yes.<br /> R. Falgt, 1354"
98
+ >
99
+ <div class="flex-v gap-medium">
100
+ <DemoPage {code} component="Button">
101
+ <Demoer {parameters} {componentArgs}>
102
+ {#snippet children({ activeParams })}
103
+ <Button {...activeParams}
104
+ >Using snippets scscs dsvdvd
105
+ <!-- {#snippet buttonStart()}
106
+ <Icon icon="user" />
107
+ {/snippet} -->
108
+
109
+ {#snippet buttonLoadingIcon()}
110
+ <Icon icon="loading" rotate />
111
+ {/snippet}
112
+ </Button>
113
+ {/snippet}
114
+ </Demoer>
115
+ </DemoPage>
116
+ <DemoPage title="" subTitle="Styling props" component="Button">
117
+ <Demoer parameters={styleParameters} {multiple} {componentArgs}>
118
+ {#snippet children({ activeParams })}
119
+ <Button {...activeParams}
120
+ >Using snippets
121
+ {#snippet buttonStart()}
122
+ <Icon icon="user" />
123
+ {/snippet}
124
+ {#snippet buttonLoadingIcon()}
125
+ <Icon icon="loading" rotate />
126
+ {/snippet}
127
+ </Button>
128
+ {/snippet}
129
+ </Demoer>
130
+ </DemoPage>
131
+ <DemoPage title="" subTitle="Menu buttons" component="Button">
132
+ <Demoer parameters={parametersMenu} {componentArgs}>
133
+ <Button>
134
+ default action
135
+ {#snippet buttonPopper()}
136
+ <MenuList style="max-height:350px;overflow:auto" density="default">
137
+ <MenuListItem divider={true} text="strict">menu</MenuListItem>
138
+ <MenuListItem data={{ some: 'data' }} text="strict">item</MenuListItem>
139
+ <MenuListItem data={{ some: 'data' }} text="strict">item</MenuListItem>
140
+ <MenuListItem data={{ some: 'data' }} text="strict">item</MenuListItem>
141
+ </MenuList>
142
+ {/snippet}
143
+ </Button>
144
+ </Demoer>
145
+ </DemoPage>
146
+ <!-- <DemoPage title="Using props" code={code2} component="Button">
147
+ <Demoer parameters={parametersProps} {componentArgs}>
148
+ {#snippet children({ activeParams })}
149
+ <Button {...activeParams}>Using props</Button>
150
+ {/snippet}
151
+ </Demoer>
152
+ </DemoPage> -->
153
+ <!-- <DemoPage title="" subTitle="Menu buttons" code={code3} component="Button">
154
+ <Demoer parameters={parametersMenu} {componentArgs}>
155
+ {#snippet children({ activeParams })}
156
+ <Button
157
+ size="medium"
158
+ usePopper={{ ...usePopper, position: activeParams?.position }}
159
+ primary="Menu {activeParams?.position ?? ''}"
160
+ />
161
+ {/snippet}
162
+ </Demoer>
163
+ </DemoPage> -->
164
+ </div>
165
+ </ComponentDemo>