@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.
- package/README.md +47 -47
- package/dist/base/alert/Alert.demo.svelte +62 -62
- package/dist/base/alert/Alert.svelte +121 -121
- package/dist/base/alert/alert.scss +93 -93
- package/dist/base/avatar/Avatar.demo.svelte +41 -41
- package/dist/base/avatar/Avatar.preview.svelte +6 -6
- package/dist/base/avatar/Avatar.svelte +65 -65
- package/dist/base/avatar/avatar.scss +17 -17
- package/dist/base/backdrop/Backdrop.demo.svelte +49 -49
- package/dist/base/backdrop/Backdrop.svelte +78 -78
- package/dist/base/backdrop/backdrop.scss +34 -34
- package/dist/base/badge/Badge.svelte +31 -31
- package/dist/base/badge/badge.scss +19 -19
- package/dist/base/box/Box.demo.svelte +54 -54
- package/dist/base/box/Box.svelte +72 -72
- package/dist/base/box/box.scss +33 -33
- package/dist/base/breadCrumb/BreadCrumb.svelte +23 -23
- package/dist/base/breadCrumb/breadcrumb.scss +11 -11
- package/dist/base/cartouche/Cartouche.demo.svelte +108 -108
- package/dist/base/cartouche/Cartouche.svelte +114 -114
- package/dist/base/cartouche/cartouche.scss +114 -114
- package/dist/base/chipper/Chipper.demo.svelte +45 -45
- package/dist/base/chipper/Chipper.svelte +36 -36
- package/dist/base/chipper/chipper.scss +65 -65
- package/dist/base/columner/Column.svelte +62 -62
- package/dist/base/columner/Columner.demo.svelte +15 -15
- package/dist/base/columner/Columner.svelte +21 -21
- package/dist/base/contentSwitcher/ContentSwitcher.demo.svelte +45 -45
- package/dist/base/contentSwitcher/ContentSwitcher.svelte +63 -63
- package/dist/base/contentSwitcher/content-switcher.scss +22 -22
- package/dist/base/debug/Debug.svelte +21 -21
- package/dist/base/demoer/DemoPage.svelte +40 -40
- package/dist/base/demoer/Demoer.svelte +170 -170
- package/dist/base/demoer/DemoerCode.svelte +45 -45
- package/dist/base/demoer/DemoerComponent.svelte +50 -50
- package/dist/base/divider/Divider.demo.svelte +34 -34
- package/dist/base/divider/Divider.svelte +68 -68
- package/dist/base/divider/divider.scss +19 -19
- package/dist/base/icon/Icon.demo.svelte +24 -24
- package/dist/base/icon/Icon.svelte +117 -117
- package/dist/base/icon/icon.scss +17 -17
- package/dist/base/paper/Paper.demo.svelte +31 -31
- package/dist/base/paper/Paper.svelte +20 -20
- package/dist/base/paper/paper.scss +15 -15
- package/dist/base/titleBar/TitleBar.demo.svelte +30 -30
- package/dist/base/titleBar/TitleBar.svelte +40 -40
- package/dist/base/titleBar/title-bar.scss +29 -29
- package/dist/controls/autocomplete/AutoComplete.demo.svelte +88 -88
- package/dist/controls/autocomplete/AutoComplete.svelte +152 -152
- package/dist/controls/autocomplete/auto-complete.scss +15 -15
- package/dist/controls/button/Button.demo.svelte +165 -165
- package/dist/controls/button/Button.svelte +95 -95
- package/dist/controls/button/ButtonAction.svelte +55 -55
- package/dist/controls/button/ButtonMenu.svelte +55 -55
- package/dist/controls/button/IconButton.svelte +45 -45
- package/dist/controls/button/button-action.scss +8 -8
- package/dist/controls/button/button-menu.scss +36 -36
- package/dist/controls/button/button.scss +293 -293
- package/dist/controls/checkbox/Checkbox.demo.svelte +29 -29
- package/dist/controls/checkbox/Checkbox.svelte +59 -59
- package/dist/controls/checkbox/checkbox.scss +115 -115
- package/dist/controls/confirm/Confirm.demo.svelte +60 -60
- package/dist/controls/confirm/Confirm.preview.svelte +14 -14
- package/dist/controls/confirm/Confirm.svelte +156 -156
- package/dist/controls/confirm/confirm.scss +12 -12
- package/dist/controls/inplaceedit/InPlaceEdit.demo.svelte +41 -41
- package/dist/controls/inplaceedit/InPlaceEdit.svelte +109 -109
- package/dist/controls/progress/Progress.demo.svelte +30 -30
- package/dist/controls/progress/Progress.svelte +26 -26
- package/dist/controls/progress/progress.scss +23 -23
- package/dist/controls/rating/Rating.demo.svelte +45 -45
- package/dist/controls/rating/Rating.svelte +44 -44
- package/dist/controls/rating/rating.scss +9 -9
- package/dist/controls/select/Select.demo.svelte +101 -101
- package/dist/controls/select/Select.svelte +125 -125
- package/dist/controls/select/select.scss +13 -13
- package/dist/controls/slider/Slider.demo.svelte +34 -34
- package/dist/controls/slider/Slider.svelte +153 -153
- package/dist/controls/slider/slider.scss +51 -51
- package/dist/controls/stepper/Stepper.demo.svelte +32 -32
- package/dist/controls/stepper/Stepper.svelte +30 -30
- package/dist/controls/stepper/stepper.scss +23 -23
- package/dist/controls/switch/Switch.demo.svelte +61 -61
- package/dist/controls/switch/Switch.svelte +45 -45
- package/dist/controls/switch/switch.scss +73 -73
- package/dist/controls/textfield/TextField.demo.svelte +79 -79
- package/dist/controls/textfield/TextField.svelte +86 -86
- package/dist/controls/textfield/textfield.scss +68 -68
- package/dist/csss/csss.scss +10 -10
- package/dist/data/dataList/DataList.demo.svelte +151 -151
- package/dist/data/dataList/DataList.preview.svelte +23 -23
- package/dist/data/dataList/DataList.svelte +233 -233
- package/dist/data/dataList/DataListCell.svelte +212 -212
- package/dist/data/dataList/DataListHead.svelte +75 -75
- package/dist/data/dataList/DataListRow.svelte +93 -93
- package/dist/data/dataList/datalist.scss +157 -157
- package/dist/data/finder/Finder.demo.svelte +55 -55
- package/dist/data/finder/Finder.svelte +166 -166
- package/dist/data/finder/finder.scss +14 -14
- package/dist/data/grouper/Grouper.demo.svelte +36 -36
- package/dist/data/grouper/Grouper.svelte +85 -85
- package/dist/data/jsoner/Jsoner.svelte +40 -40
- package/dist/data/list/List.svelte +16 -16
- package/dist/data/list/ListItem.svelte +10 -10
- package/dist/data/list/ListTitle.svelte +8 -8
- package/dist/data/loader/Loader.demo.svelte +95 -95
- package/dist/data/loader/Loader.preview.svelte +7 -7
- package/dist/data/loader/Loader.svelte +99 -99
- package/dist/data/loader/loader.scss +50 -50
- package/dist/data/sorter/Sorter.demo.svelte +62 -62
- package/dist/data/sorter/Sorter.svelte +80 -80
- package/dist/data/sorter/Sorterer.svelte +27 -27
- package/dist/data/sorter/sorterer.scss +11 -11
- package/dist/index.d.ts +39 -38
- package/dist/index.js +39 -38
- package/dist/navigation/drawer/Drawer.demo.svelte +52 -52
- package/dist/navigation/drawer/Drawer.svelte +163 -163
- package/dist/navigation/drawer/drawer.scss +69 -69
- package/dist/navigation/tabs/Tabs.demo.svelte +83 -83
- package/dist/navigation/tabs/Tabs.preview.svelte +22 -22
- package/dist/navigation/tabs/Tabs.svelte +158 -158
- package/dist/navigation/tabs/tabs.scss +92 -92
- package/dist/slotui-css/slotui-css.css +141 -141
- package/dist/slotui-css/slotui-min-css.css +141 -141
- package/dist/styles/slotui-mixins.scss +168 -168
- package/dist/styles/slotui-presets.scss +56 -56
- package/dist/styles/slotuisheet/SlotuiSheet.svelte +36 -36
- package/dist/styles/slotuisheet/SlotyuiSheet.demo.svelte +28 -28
- package/dist/styles/slotuisheet/sheetConfig.scss +7 -7
- package/dist/styles/slotuisheet/slotui-sheet.scss +192 -192
- package/dist/styles/slotuisheet/stylesheet-container.scss +147 -147
- package/dist/styles/slotuisheet/stylesheet.scss +156 -156
- package/dist/types/slotui-ambient.d.ts +27 -27
- package/dist/ui/bootstrapp/BootStrApp.svelte +92 -92
- package/dist/ui/chromeFrame/ChromeFrame.svelte +43 -43
- package/dist/ui/chromeFrame/ChromeFrameButtonList.svelte +33 -33
- package/dist/ui/chromeFrame/ChromeFrameList.svelte +106 -106
- package/dist/ui/chromeFrame/chrome-frame.scss +34 -34
- package/dist/ui/frame/Frame.demo.svelte +48 -48
- package/dist/ui/frame/Frame.svelte +90 -90
- package/dist/ui/frame/frame.scss +46 -46
- package/dist/ui/login/Login.demo.svelte +62 -62
- package/dist/ui/login/Login.svelte +102 -102
- package/dist/ui/marquee/Marquee.demo.svelte +33 -33
- package/dist/ui/marquee/Marquee.svelte +97 -97
- package/dist/ui/marquee/marquee.scss +34 -34
- package/dist/ui/menu/Menu.svelte +9 -9
- package/dist/ui/menu/MenuItem.svelte +9 -9
- package/dist/ui/menu/MenuTitle.svelte +10 -10
- package/dist/ui/menu/menu.scss +61 -61
- package/dist/ui/menuList/MenuList.demo.svelte +73 -73
- package/dist/ui/menuList/MenuList.svelte +143 -143
- package/dist/ui/menuList/MenuListItem.svelte +134 -134
- package/dist/ui/menuList/MenuListTitle.svelte +10 -10
- package/dist/ui/menuList/menu-list.scss +120 -120
- package/dist/ui/panel/Panel.demo.svelte +169 -169
- package/dist/ui/panel/Panel.svelte +96 -96
- package/dist/ui/panel/PanelGrid.svelte +62 -62
- package/dist/ui/panel/PanelSlide.svelte +156 -156
- package/dist/ui/panel/Paneler.svelte +63 -63
- package/dist/ui/panel/panel.scss +32 -32
- package/dist/ui/popper/Popper.demo.svelte +92 -92
- package/dist/ui/popper/Popper.svelte +160 -160
- package/dist/ui/popper/popper.scss +108 -108
- package/dist/ui/preview/Preview.svelte +41 -41
- package/dist/ui/serviceBox/ServiceBox.svelte +24 -24
- package/dist/ui/startMenu/BootMenu.svelte +102 -102
- package/dist/ui/startMenu/boot-menu.scss +86 -86
- package/dist/ui/taskbar/TaskBarContent.svelte +20 -20
- package/dist/ui/taskbar/Taskbar.svelte +26 -26
- package/dist/ui/taskbar/taskbar.scss +28 -28
- package/dist/ui/themeswitcher/ThemeSwitcher.svelte +18 -18
- package/dist/ui/toast/Toast.demo.svelte +19 -19
- package/dist/ui/toast/Toast.svelte +60 -60
- package/dist/ui/toast/Toaster.svelte +18 -18
- package/dist/ui/toggleBar/ToggleBar.demo.svelte +114 -114
- package/dist/ui/toggleBar/ToggleBar.svelte +58 -58
- package/dist/ui/toggleBar/toggle-bar.scss +45 -45
- package/dist/ui/toolBar/ToolBar.demo.svelte +98 -98
- package/dist/ui/toolBar/ToolBar.svelte +30 -30
- package/dist/ui/toolBar/toolbar.scss +32 -32
- package/dist/ui/tree/Tree.demo.svelte +84 -84
- package/dist/ui/tree/Tree.preview.svelte +19 -19
- package/dist/ui/tree/Tree.svelte +182 -182
- package/dist/ui/tree/tree.scss +38 -38
- package/dist/ui/window/Window.demo.svelte +111 -111
- package/dist/ui/window/Window.svelte +177 -177
- package/dist/ui/window/window.scss +66 -66
- package/dist/utils/content/Content.svelte +78 -78
- package/dist/utils/contextRooter/ContextRooter.demo.svelte +33 -33
- package/dist/utils/contextRooter/ContextRooter.svelte +6 -6
- package/dist/utils/css/Css.demo.svelte +5 -5
- package/dist/utils/css/Css.svelte +64 -64
- package/dist/utils/effects/transitions.js +6 -6
- package/dist/utils/looper/Looper.demo.svelte +36 -36
- package/dist/utils/looper/Looper.svelte +47 -47
- package/dist/utils/slotted/Slotted.svelte +21 -21
- package/dist/utils/stylesheet/StyleSheet.demo.svelte +28 -28
- package/dist/utils/stylesheet/StyleSheet.svelte +30 -30
- package/dist/utils/stylesheet/containerConfig.scss +7 -7
- package/dist/utils/stylesheet/stylesheet.scss +147 -147
- package/dist/utils/uses/sx4u/sx4uPreprocess.js +34 -34
- package/package.json +3 -3
|
@@ -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>
|