@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.
- 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.svelte.d.ts +1 -1
- 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/Button.svelte.d.ts +1 -1
- 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.svelte.d.ts +1 -1
- 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.svelte.d.ts +1 -1
- 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 +46 -47
- package/dist/index.js +46 -47
- 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 +288 -288
- package/dist/slotui-css/slotui-min-css.css +288 -288
- 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/ToggleBar.svelte.d.ts +1 -1
- 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 +4 -4
|
@@ -1,104 +1,104 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import { fade, type TransitionConfig } from 'svelte/transition';
|
|
3
|
-
|
|
4
|
-
import Backdrop from '../../base/backdrop/Backdrop.svelte';
|
|
5
|
-
import Button from '../../controls/button/Button.svelte';
|
|
6
|
-
import Icon from '../../base/icon/Icon.svelte';
|
|
7
|
-
import Slotted from '../../utils/slotted/Slotted.svelte';
|
|
8
|
-
import type { LoginProps } from './types.js';
|
|
9
|
-
|
|
10
|
-
let {
|
|
11
|
-
class: className = '',
|
|
12
|
-
element = $bindable(),
|
|
13
|
-
style = '',
|
|
14
|
-
showLogin = true,
|
|
15
|
-
transition = { type: fade, args: {} },
|
|
16
|
-
fields = { email: '', password: '' },
|
|
17
|
-
loading = false,
|
|
18
|
-
submitting = false,
|
|
19
|
-
onSubmit = function (args) {
|
|
20
|
-
return new Promise((resolve, reject) => {
|
|
21
|
-
return setTimeout(() => {
|
|
22
|
-
resolve(true);
|
|
23
|
-
}, 2000);
|
|
24
|
-
});
|
|
25
|
-
},
|
|
26
|
-
children,
|
|
27
|
-
slotRetrievePassword,
|
|
28
|
-
loginAvatarRoot,
|
|
29
|
-
loginAvatar,
|
|
30
|
-
loginForm,
|
|
31
|
-
...rest
|
|
32
|
-
}: LoginProps = $props();
|
|
33
|
-
|
|
34
|
-
export const actions = {
|
|
35
|
-
toggle: (lo?: boolean) => {
|
|
36
|
-
showLogin = lo ?? !showLogin;
|
|
37
|
-
},
|
|
38
|
-
toggleLoading: (lo?: boolean) => {
|
|
39
|
-
loading = lo ?? !loading;
|
|
40
|
-
}
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
let grantedError = false;
|
|
44
|
-
|
|
45
|
-
const validData: any = {};
|
|
46
|
-
|
|
47
|
-
function validate() {
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
</script>
|
|
51
|
-
|
|
52
|
-
{#if showLogin}
|
|
53
|
-
<Backdrop isOpen={showLogin} style="height:100%;" {loading}>
|
|
54
|
-
<form
|
|
55
|
-
bind:this={element}
|
|
56
|
-
class="pos-abs top-0 h-full w-full {className}"
|
|
57
|
-
method="post"
|
|
58
|
-
on:submit|preventDefault={validate}
|
|
59
|
-
>
|
|
60
|
-
<div transition:fade|global class="pos-rel h-full w-full flex-h flex-align-middle-center">
|
|
61
|
-
<div class="form flex-v flex-align-middle-center">
|
|
62
|
-
<Slotted child={loginAvatarRoot}>
|
|
63
|
-
<div class="avatarHolder marg-b-2">
|
|
64
|
-
<div class="avatar flex-h flex-align-middle-center">
|
|
65
|
-
{#if submitting}
|
|
66
|
-
<Icon rotate iconSize="large" icon="loading" />
|
|
67
|
-
{:else}
|
|
68
|
-
<Slotted child={loginAvatar} />
|
|
69
|
-
{/if}
|
|
70
|
-
</div>
|
|
71
|
-
</div>
|
|
72
|
-
</Slotted>
|
|
73
|
-
<Slotted child={loginForm}>
|
|
74
|
-
<div class="pad-2">
|
|
75
|
-
<input class="input" name="email" type="text" />
|
|
76
|
-
</div>
|
|
77
|
-
<div class="pad-2">
|
|
78
|
-
<input name="password" type="password" />
|
|
79
|
-
</div>
|
|
80
|
-
<Button type="submit" value="login" loading={submitting}>
|
|
81
|
-
{#if submitting}<i class="fa fa-spinner fa-spin theme-text-primary-complement"
|
|
82
|
-
></i>{/if}
|
|
83
|
-
Login
|
|
84
|
-
</Button>
|
|
85
|
-
{#if grantedError}
|
|
86
|
-
<div class="pad-1 color-scheme-error">Please verify your input</div>
|
|
87
|
-
{/if}
|
|
88
|
-
</Slotted>
|
|
89
|
-
{#if slotRetrievePassword}
|
|
90
|
-
<div class="retrieve">
|
|
91
|
-
<Slotted child={slotRetrievePassword} />
|
|
92
|
-
</div>
|
|
93
|
-
{/if}
|
|
94
|
-
</div>
|
|
95
|
-
</div>
|
|
96
|
-
</form>
|
|
97
|
-
</Backdrop>
|
|
98
|
-
{:else}
|
|
99
|
-
{@render children?.()}
|
|
100
|
-
{/if}
|
|
101
|
-
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { fade, type TransitionConfig } from 'svelte/transition';
|
|
3
|
+
|
|
4
|
+
import Backdrop from '../../base/backdrop/Backdrop.svelte';
|
|
5
|
+
import Button from '../../controls/button/Button.svelte';
|
|
6
|
+
import Icon from '../../base/icon/Icon.svelte';
|
|
7
|
+
import Slotted from '../../utils/slotted/Slotted.svelte';
|
|
8
|
+
import type { LoginProps } from './types.js';
|
|
9
|
+
|
|
10
|
+
let {
|
|
11
|
+
class: className = '',
|
|
12
|
+
element = $bindable(),
|
|
13
|
+
style = '',
|
|
14
|
+
showLogin = true,
|
|
15
|
+
transition = { type: fade, args: {} },
|
|
16
|
+
fields = { email: '', password: '' },
|
|
17
|
+
loading = false,
|
|
18
|
+
submitting = false,
|
|
19
|
+
onSubmit = function (args) {
|
|
20
|
+
return new Promise((resolve, reject) => {
|
|
21
|
+
return setTimeout(() => {
|
|
22
|
+
resolve(true);
|
|
23
|
+
}, 2000);
|
|
24
|
+
});
|
|
25
|
+
},
|
|
26
|
+
children,
|
|
27
|
+
slotRetrievePassword,
|
|
28
|
+
loginAvatarRoot,
|
|
29
|
+
loginAvatar,
|
|
30
|
+
loginForm,
|
|
31
|
+
...rest
|
|
32
|
+
}: LoginProps = $props();
|
|
33
|
+
|
|
34
|
+
export const actions = {
|
|
35
|
+
toggle: (lo?: boolean) => {
|
|
36
|
+
showLogin = lo ?? !showLogin;
|
|
37
|
+
},
|
|
38
|
+
toggleLoading: (lo?: boolean) => {
|
|
39
|
+
loading = lo ?? !loading;
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
let grantedError = false;
|
|
44
|
+
|
|
45
|
+
const validData: any = {};
|
|
46
|
+
|
|
47
|
+
function validate() {
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
</script>
|
|
51
|
+
|
|
52
|
+
{#if showLogin}
|
|
53
|
+
<Backdrop isOpen={showLogin} style="height:100%;" {loading}>
|
|
54
|
+
<form
|
|
55
|
+
bind:this={element}
|
|
56
|
+
class="pos-abs top-0 h-full w-full {className}"
|
|
57
|
+
method="post"
|
|
58
|
+
on:submit|preventDefault={validate}
|
|
59
|
+
>
|
|
60
|
+
<div transition:fade|global class="pos-rel h-full w-full flex-h flex-align-middle-center">
|
|
61
|
+
<div class="form flex-v flex-align-middle-center">
|
|
62
|
+
<Slotted child={loginAvatarRoot}>
|
|
63
|
+
<div class="avatarHolder marg-b-2">
|
|
64
|
+
<div class="avatar flex-h flex-align-middle-center">
|
|
65
|
+
{#if submitting}
|
|
66
|
+
<Icon rotate iconSize="large" icon="loading" />
|
|
67
|
+
{:else}
|
|
68
|
+
<Slotted child={loginAvatar} />
|
|
69
|
+
{/if}
|
|
70
|
+
</div>
|
|
71
|
+
</div>
|
|
72
|
+
</Slotted>
|
|
73
|
+
<Slotted child={loginForm}>
|
|
74
|
+
<div class="pad-2">
|
|
75
|
+
<input class="input" name="email" type="text" />
|
|
76
|
+
</div>
|
|
77
|
+
<div class="pad-2">
|
|
78
|
+
<input name="password" type="password" />
|
|
79
|
+
</div>
|
|
80
|
+
<Button type="submit" value="login" loading={submitting}>
|
|
81
|
+
{#if submitting}<i class="fa fa-spinner fa-spin theme-text-primary-complement"
|
|
82
|
+
></i>{/if}
|
|
83
|
+
Login
|
|
84
|
+
</Button>
|
|
85
|
+
{#if grantedError}
|
|
86
|
+
<div class="pad-1 color-scheme-error">Please verify your input</div>
|
|
87
|
+
{/if}
|
|
88
|
+
</Slotted>
|
|
89
|
+
{#if slotRetrievePassword}
|
|
90
|
+
<div class="retrieve">
|
|
91
|
+
<Slotted child={slotRetrievePassword} />
|
|
92
|
+
</div>
|
|
93
|
+
{/if}
|
|
94
|
+
</div>
|
|
95
|
+
</div>
|
|
96
|
+
</form>
|
|
97
|
+
</Backdrop>
|
|
98
|
+
{:else}
|
|
99
|
+
{@render children?.()}
|
|
100
|
+
{/if}
|
|
101
|
+
|
|
102
102
|
<style>form {
|
|
103
103
|
z-index: 1000;
|
|
104
104
|
}
|
|
@@ -130,4 +130,4 @@
|
|
|
130
130
|
.form .name {
|
|
131
131
|
text-align: center;
|
|
132
132
|
margin: 0.5rem;
|
|
133
|
-
}</style>
|
|
133
|
+
}</style>
|
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
|
|
3
|
-
import Demoer from '../../base/demoer/Demoer.svelte';
|
|
4
|
-
import DemoPage from '../../base/demoer/DemoPage.svelte';
|
|
5
|
-
|
|
6
|
-
import { parameters, componentArgs } from './types.js';
|
|
7
|
-
import Marquee from './Marquee.svelte';
|
|
8
|
-
import Looper from '../../utils/looper/Looper.svelte';
|
|
9
|
-
import { dataOp } from '@medyll/idae-engine';
|
|
10
|
-
|
|
11
|
-
let code = `
|
|
12
|
-
<Marquee >
|
|
13
|
-
<div></div>
|
|
14
|
-
<div></div>
|
|
15
|
-
<div></div>
|
|
16
|
-
</Marquee>`;
|
|
17
|
-
</script>
|
|
18
|
-
|
|
19
|
-
<ComponentDemo component="Marquee">
|
|
20
|
-
<DemoPage component="Rating" {code}>
|
|
21
|
-
<Demoer {parameters} {componentArgs}>
|
|
22
|
-
{#snippet children({ activeParams })}
|
|
23
|
-
<Marquee style="width:450px;height:450px;gap!2rem;border:1px solid black;display:flex;" {...activeParams}>
|
|
24
|
-
<Looper style="display:flex;" data={[...Array(90)].map((_,idx)=>({idx}))} >
|
|
25
|
-
{#snippet children({ item ,idx})}
|
|
26
|
-
<div style="min-width:250px;height:250px;border:1px solid green;" >cell {item?.idx} </div>
|
|
27
|
-
{/snippet}
|
|
28
|
-
</Looper>
|
|
29
|
-
</Marquee>
|
|
30
|
-
{/snippet}
|
|
31
|
-
</Demoer>
|
|
32
|
-
</DemoPage>
|
|
33
|
-
</ComponentDemo>
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
|
|
3
|
+
import Demoer from '../../base/demoer/Demoer.svelte';
|
|
4
|
+
import DemoPage from '../../base/demoer/DemoPage.svelte';
|
|
5
|
+
|
|
6
|
+
import { parameters, componentArgs } from './types.js';
|
|
7
|
+
import Marquee from './Marquee.svelte';
|
|
8
|
+
import Looper from '../../utils/looper/Looper.svelte';
|
|
9
|
+
import { dataOp } from '@medyll/idae-engine';
|
|
10
|
+
|
|
11
|
+
let code = `
|
|
12
|
+
<Marquee >
|
|
13
|
+
<div></div>
|
|
14
|
+
<div></div>
|
|
15
|
+
<div></div>
|
|
16
|
+
</Marquee>`;
|
|
17
|
+
</script>
|
|
18
|
+
|
|
19
|
+
<ComponentDemo component="Marquee">
|
|
20
|
+
<DemoPage component="Rating" {code}>
|
|
21
|
+
<Demoer {parameters} {componentArgs}>
|
|
22
|
+
{#snippet children({ activeParams })}
|
|
23
|
+
<Marquee style="width:450px;height:450px;gap!2rem;border:1px solid black;display:flex;" {...activeParams}>
|
|
24
|
+
<Looper style="display:flex;" data={[...Array(90)].map((_,idx)=>({idx}))} >
|
|
25
|
+
{#snippet children({ item ,idx})}
|
|
26
|
+
<div style="min-width:250px;height:250px;border:1px solid green;" >cell {item?.idx} </div>
|
|
27
|
+
{/snippet}
|
|
28
|
+
</Looper>
|
|
29
|
+
</Marquee>
|
|
30
|
+
{/snippet}
|
|
31
|
+
</Demoer>
|
|
32
|
+
</DemoPage>
|
|
33
|
+
</ComponentDemo>
|
|
@@ -1,99 +1,99 @@
|
|
|
1
|
-
<script lang="ts" generics="T=Data">
|
|
2
|
-
import Stepper from '../../controls/stepper/Stepper.svelte';
|
|
3
|
-
import type { StepperProps } from '../../controls/stepper/types.js';
|
|
4
|
-
import type { Data, ExpandProps } from '../../types/index.js';
|
|
5
|
-
import Content from '../../utils/content/Content.svelte';
|
|
6
|
-
import Slotted from '../../utils/slotted/Slotted.svelte';
|
|
7
|
-
import type { MarqueeProps } from './types.js';
|
|
8
|
-
|
|
9
|
-
let container = $state<HTMLElement>();
|
|
10
|
-
|
|
11
|
-
let {
|
|
12
|
-
showControls = true,
|
|
13
|
-
autoStart = false,
|
|
14
|
-
pauseOnHover = false,
|
|
15
|
-
activeElement = $bindable(0),
|
|
16
|
-
activeIndex = $bindable(0),
|
|
17
|
-
showStepper = false,
|
|
18
|
-
stepperProps = {} as StepperProps,
|
|
19
|
-
gutter,
|
|
20
|
-
marqueePrev,
|
|
21
|
-
marqueeNext,
|
|
22
|
-
children,
|
|
23
|
-
...rest
|
|
24
|
-
}: ExpandProps<MarqueeProps> = $props();
|
|
25
|
-
|
|
26
|
-
/* export function pauseOnHoverFunction(
|
|
27
|
-
node: HTMLElement | null,
|
|
28
|
-
params: MarqueeProps
|
|
29
|
-
): Action<HTMLElement, MarqueeProps> | undefined {
|
|
30
|
-
if (!node) return;
|
|
31
|
-
let isHovered = false;
|
|
32
|
-
|
|
33
|
-
function handleMouseEnter() {
|
|
34
|
-
isHovered = true;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
function handleMouseLeave() {
|
|
38
|
-
isHovered = false;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
node.addEventListener('mouseenter', handleMouseEnter);
|
|
42
|
-
node.addEventListener('mouseleave', handleMouseLeave);
|
|
43
|
-
|
|
44
|
-
return {
|
|
45
|
-
update({ pauseOnHover }) {
|
|
46
|
-
if (pauseOnHover && isHovered) {
|
|
47
|
-
node.style.animationPlayState = 'paused';
|
|
48
|
-
} else {
|
|
49
|
-
node.style.animationPlayState = 'running';
|
|
50
|
-
}
|
|
51
|
-
},
|
|
52
|
-
destroy() {
|
|
53
|
-
node.removeEventListener('mouseenter', handleMouseEnter);
|
|
54
|
-
node.removeEventListener('mouseleave', handleMouseLeave);
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
} */
|
|
58
|
-
|
|
59
|
-
function scrollHorizontally(element: HTMLElement, distance: number) {
|
|
60
|
-
element.scrollBy({ left: distance, behavior: 'smooth' });
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
function scrollNext() {
|
|
64
|
-
if (container) scrollHorizontally(container, container.clientWidth);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
function scrollPrev() {
|
|
68
|
-
if (container) scrollHorizontally(container, -container.clientWidth);
|
|
69
|
-
}
|
|
70
|
-
</script>
|
|
71
|
-
|
|
72
|
-
<div class="marquee-container" {...rest}>
|
|
73
|
-
{#if showControls}
|
|
74
|
-
<div class="marquee-controls-prev">
|
|
75
|
-
<button onclick={scrollPrev}>Précédent</button>
|
|
76
|
-
</div>
|
|
77
|
-
{/if}
|
|
78
|
-
<div bind:this={container} class="marquee">
|
|
79
|
-
<Content {gutter} tag="div" class="marquee-children" style="scroll-snap-type: x mandatory;">
|
|
80
|
-
{#if children}{@render children()}{:else}
|
|
81
|
-
<div>enter content or data</div>
|
|
82
|
-
{/if}
|
|
83
|
-
</Content>
|
|
84
|
-
</div>
|
|
85
|
-
{#if showControls}
|
|
86
|
-
<div class="marquee-controls-next">
|
|
87
|
-
<Slotted child={marqueePrev}>
|
|
88
|
-
<button onclick={scrollNext}>Suivant</button>
|
|
89
|
-
</Slotted>
|
|
90
|
-
</div>
|
|
91
|
-
{/if}
|
|
92
|
-
</div>
|
|
93
|
-
{#if showStepper}
|
|
94
|
-
<Stepper {...stepperProps} steps={[{ order: 1 }, { order: 2 }]}></Stepper>
|
|
95
|
-
{/if}
|
|
96
|
-
|
|
1
|
+
<script lang="ts" generics="T=Data">
|
|
2
|
+
import Stepper from '../../controls/stepper/Stepper.svelte';
|
|
3
|
+
import type { StepperProps } from '../../controls/stepper/types.js';
|
|
4
|
+
import type { Data, ExpandProps } from '../../types/index.js';
|
|
5
|
+
import Content from '../../utils/content/Content.svelte';
|
|
6
|
+
import Slotted from '../../utils/slotted/Slotted.svelte';
|
|
7
|
+
import type { MarqueeProps } from './types.js';
|
|
8
|
+
|
|
9
|
+
let container = $state<HTMLElement>();
|
|
10
|
+
|
|
11
|
+
let {
|
|
12
|
+
showControls = true,
|
|
13
|
+
autoStart = false,
|
|
14
|
+
pauseOnHover = false,
|
|
15
|
+
activeElement = $bindable(0),
|
|
16
|
+
activeIndex = $bindable(0),
|
|
17
|
+
showStepper = false,
|
|
18
|
+
stepperProps = {} as StepperProps,
|
|
19
|
+
gutter,
|
|
20
|
+
marqueePrev,
|
|
21
|
+
marqueeNext,
|
|
22
|
+
children,
|
|
23
|
+
...rest
|
|
24
|
+
}: ExpandProps<MarqueeProps> = $props();
|
|
25
|
+
|
|
26
|
+
/* export function pauseOnHoverFunction(
|
|
27
|
+
node: HTMLElement | null,
|
|
28
|
+
params: MarqueeProps
|
|
29
|
+
): Action<HTMLElement, MarqueeProps> | undefined {
|
|
30
|
+
if (!node) return;
|
|
31
|
+
let isHovered = false;
|
|
32
|
+
|
|
33
|
+
function handleMouseEnter() {
|
|
34
|
+
isHovered = true;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
function handleMouseLeave() {
|
|
38
|
+
isHovered = false;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
node.addEventListener('mouseenter', handleMouseEnter);
|
|
42
|
+
node.addEventListener('mouseleave', handleMouseLeave);
|
|
43
|
+
|
|
44
|
+
return {
|
|
45
|
+
update({ pauseOnHover }) {
|
|
46
|
+
if (pauseOnHover && isHovered) {
|
|
47
|
+
node.style.animationPlayState = 'paused';
|
|
48
|
+
} else {
|
|
49
|
+
node.style.animationPlayState = 'running';
|
|
50
|
+
}
|
|
51
|
+
},
|
|
52
|
+
destroy() {
|
|
53
|
+
node.removeEventListener('mouseenter', handleMouseEnter);
|
|
54
|
+
node.removeEventListener('mouseleave', handleMouseLeave);
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
} */
|
|
58
|
+
|
|
59
|
+
function scrollHorizontally(element: HTMLElement, distance: number) {
|
|
60
|
+
element.scrollBy({ left: distance, behavior: 'smooth' });
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
function scrollNext() {
|
|
64
|
+
if (container) scrollHorizontally(container, container.clientWidth);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
function scrollPrev() {
|
|
68
|
+
if (container) scrollHorizontally(container, -container.clientWidth);
|
|
69
|
+
}
|
|
70
|
+
</script>
|
|
71
|
+
|
|
72
|
+
<div class="marquee-container" {...rest}>
|
|
73
|
+
{#if showControls}
|
|
74
|
+
<div class="marquee-controls-prev">
|
|
75
|
+
<button onclick={scrollPrev}>Précédent</button>
|
|
76
|
+
</div>
|
|
77
|
+
{/if}
|
|
78
|
+
<div bind:this={container} class="marquee">
|
|
79
|
+
<Content {gutter} tag="div" class="marquee-children" style="scroll-snap-type: x mandatory;">
|
|
80
|
+
{#if children}{@render children()}{:else}
|
|
81
|
+
<div>enter content or data</div>
|
|
82
|
+
{/if}
|
|
83
|
+
</Content>
|
|
84
|
+
</div>
|
|
85
|
+
{#if showControls}
|
|
86
|
+
<div class="marquee-controls-next">
|
|
87
|
+
<Slotted child={marqueePrev}>
|
|
88
|
+
<button onclick={scrollNext}>Suivant</button>
|
|
89
|
+
</Slotted>
|
|
90
|
+
</div>
|
|
91
|
+
{/if}
|
|
92
|
+
</div>
|
|
93
|
+
{#if showStepper}
|
|
94
|
+
<Stepper {...stepperProps} steps={[{ order: 1 }, { order: 2 }]}></Stepper>
|
|
95
|
+
{/if}
|
|
96
|
+
|
|
97
97
|
<style>.marquee {
|
|
98
98
|
flex: 1;
|
|
99
99
|
overflow-x: hidden;
|
|
@@ -151,4 +151,4 @@
|
|
|
151
151
|
}
|
|
152
152
|
.marquee-controls-next {
|
|
153
153
|
display: contents;
|
|
154
|
-
}</style>
|
|
154
|
+
}</style>
|
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
@use "../../styles/slotui-mixins.scss";
|
|
2
|
-
|
|
3
|
-
.marquee {
|
|
4
|
-
flex: 1;
|
|
5
|
-
overflow-x: hidden;
|
|
6
|
-
scroll-behavior: smooth;
|
|
7
|
-
scroll-snap-type: x mandatory;
|
|
8
|
-
|
|
9
|
-
width: 300px;
|
|
10
|
-
&-container {
|
|
11
|
-
display: flex;
|
|
12
|
-
align-items: center;
|
|
13
|
-
@include slotui-mixins.ui-gutter-presets;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
&-children {
|
|
17
|
-
display: flex;
|
|
18
|
-
border: 1px solid red;
|
|
19
|
-
& > * {
|
|
20
|
-
border: 1px solid red;
|
|
21
|
-
height: 300px;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
&-controls {
|
|
26
|
-
&-prev {
|
|
27
|
-
display: contents;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
&-next {
|
|
31
|
-
display: contents;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
1
|
+
@use "../../styles/slotui-mixins.scss";
|
|
2
|
+
|
|
3
|
+
.marquee {
|
|
4
|
+
flex: 1;
|
|
5
|
+
overflow-x: hidden;
|
|
6
|
+
scroll-behavior: smooth;
|
|
7
|
+
scroll-snap-type: x mandatory;
|
|
8
|
+
|
|
9
|
+
width: 300px;
|
|
10
|
+
&-container {
|
|
11
|
+
display: flex;
|
|
12
|
+
align-items: center;
|
|
13
|
+
@include slotui-mixins.ui-gutter-presets;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
&-children {
|
|
17
|
+
display: flex;
|
|
18
|
+
border: 1px solid red;
|
|
19
|
+
& > * {
|
|
20
|
+
border: 1px solid red;
|
|
21
|
+
height: 300px;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
&-controls {
|
|
26
|
+
&-prev {
|
|
27
|
+
display: contents;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
&-next {
|
|
31
|
+
display: contents;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
package/dist/ui/menu/Menu.svelte
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
<script lang="ts" generics="T= Data">
|
|
2
|
-
import type { Data } from '../../types/index.js';
|
|
3
|
-
import MenuList from '../menuList/MenuList.svelte';
|
|
4
|
-
import type { MenuListProps } from '../menuList/types.js';
|
|
5
|
-
|
|
6
|
-
let { ...rest }: MenuListProps = $props();
|
|
7
|
-
</script>
|
|
8
|
-
|
|
9
|
-
<MenuList {...rest} class="menu" />
|
|
1
|
+
<script lang="ts" generics="T= Data">
|
|
2
|
+
import type { Data } from '../../types/index.js';
|
|
3
|
+
import MenuList from '../menuList/MenuList.svelte';
|
|
4
|
+
import type { MenuListProps } from '../menuList/types.js';
|
|
5
|
+
|
|
6
|
+
let { ...rest }: MenuListProps = $props();
|
|
7
|
+
</script>
|
|
8
|
+
|
|
9
|
+
<MenuList {...rest} class="menu" />
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
<script lang="ts" generics="T= Data">
|
|
2
|
-
import type { MenuListItemProps } from '../menuList/types.js';
|
|
3
|
-
import type { Data } from '../../types/index.js';
|
|
4
|
-
import MenuListItem from '../menuList/MenuListItem.svelte';
|
|
5
|
-
|
|
6
|
-
let { ...rest }: MenuListItemProps = $props();
|
|
7
|
-
</script>
|
|
8
|
-
|
|
9
|
-
<MenuListItem {...rest} class="menuItem" />
|
|
1
|
+
<script lang="ts" generics="T= Data">
|
|
2
|
+
import type { MenuListItemProps } from '../menuList/types.js';
|
|
3
|
+
import type { Data } from '../../types/index.js';
|
|
4
|
+
import MenuListItem from '../menuList/MenuListItem.svelte';
|
|
5
|
+
|
|
6
|
+
let { ...rest }: MenuListItemProps = $props();
|
|
7
|
+
</script>
|
|
8
|
+
|
|
9
|
+
<MenuListItem {...rest} class="menuItem" />
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import MenuItem from './MenuItem.svelte';
|
|
3
|
-
import type { MenuItemProps } from './types.js';
|
|
4
|
-
|
|
5
|
-
let { ...rest }: MenuItemProps = $props();
|
|
6
|
-
</script>
|
|
7
|
-
|
|
8
|
-
<MenuItem {...rest} class="menuTitle" />
|
|
9
|
-
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import MenuItem from './MenuItem.svelte';
|
|
3
|
+
import type { MenuItemProps } from './types.js';
|
|
4
|
+
|
|
5
|
+
let { ...rest }: MenuItemProps = $props();
|
|
6
|
+
</script>
|
|
7
|
+
|
|
8
|
+
<MenuItem {...rest} class="menuTitle" />
|
|
9
|
+
|
|
10
10
|
<style>:root {
|
|
11
11
|
--menu-min-width: 150px;
|
|
12
12
|
--menu-padding: 0.25rem;
|
|
@@ -102,4 +102,4 @@ li.menuItem .menu-list-item-text {
|
|
|
102
102
|
}
|
|
103
103
|
li.menuItem .menu-list-item-action {
|
|
104
104
|
display: block;
|
|
105
|
-
}</style>
|
|
105
|
+
}</style>
|