@medyll/idae-slotui-svelte 0.122.0 → 0.123.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (208) hide show
  1. package/README.md +47 -47
  2. package/dist/base/alert/Alert.demo.svelte +62 -62
  3. package/dist/base/alert/Alert.svelte +121 -121
  4. package/dist/base/alert/alert.scss +93 -93
  5. package/dist/base/avatar/Avatar.demo.svelte +41 -41
  6. package/dist/base/avatar/Avatar.preview.svelte +6 -6
  7. package/dist/base/avatar/Avatar.svelte +65 -65
  8. package/dist/base/avatar/avatar.scss +17 -17
  9. package/dist/base/backdrop/Backdrop.demo.svelte +49 -49
  10. package/dist/base/backdrop/Backdrop.svelte +78 -78
  11. package/dist/base/backdrop/backdrop.scss +34 -34
  12. package/dist/base/badge/Badge.svelte +31 -31
  13. package/dist/base/badge/badge.scss +19 -19
  14. package/dist/base/box/Box.demo.svelte +54 -54
  15. package/dist/base/box/Box.svelte +72 -72
  16. package/dist/base/box/box.scss +33 -33
  17. package/dist/base/breadCrumb/BreadCrumb.svelte +23 -23
  18. package/dist/base/breadCrumb/breadcrumb.scss +11 -11
  19. package/dist/base/cartouche/Cartouche.demo.svelte +108 -108
  20. package/dist/base/cartouche/Cartouche.svelte +114 -114
  21. package/dist/base/cartouche/cartouche.scss +114 -114
  22. package/dist/base/chipper/Chipper.demo.svelte +45 -45
  23. package/dist/base/chipper/Chipper.svelte +36 -36
  24. package/dist/base/chipper/chipper.scss +65 -65
  25. package/dist/base/columner/Column.svelte +62 -62
  26. package/dist/base/columner/Columner.demo.svelte +15 -15
  27. package/dist/base/columner/Columner.svelte +21 -21
  28. package/dist/base/contentSwitcher/ContentSwitcher.demo.svelte +45 -45
  29. package/dist/base/contentSwitcher/ContentSwitcher.svelte +63 -63
  30. package/dist/base/contentSwitcher/content-switcher.scss +22 -22
  31. package/dist/base/debug/Debug.svelte +21 -21
  32. package/dist/base/demoer/DemoPage.svelte +40 -40
  33. package/dist/base/demoer/Demoer.svelte +170 -170
  34. package/dist/base/demoer/DemoerCode.svelte +45 -45
  35. package/dist/base/demoer/DemoerComponent.svelte +50 -50
  36. package/dist/base/divider/Divider.demo.svelte +34 -34
  37. package/dist/base/divider/Divider.svelte +68 -68
  38. package/dist/base/divider/divider.scss +19 -19
  39. package/dist/base/icon/Icon.demo.svelte +24 -24
  40. package/dist/base/icon/Icon.svelte +117 -117
  41. package/dist/base/icon/Icon.svelte.d.ts +1 -1
  42. package/dist/base/icon/icon.scss +17 -17
  43. package/dist/base/paper/Paper.demo.svelte +31 -31
  44. package/dist/base/paper/Paper.svelte +20 -20
  45. package/dist/base/paper/paper.scss +15 -15
  46. package/dist/base/titleBar/TitleBar.demo.svelte +30 -30
  47. package/dist/base/titleBar/TitleBar.svelte +40 -40
  48. package/dist/base/titleBar/title-bar.scss +29 -29
  49. package/dist/controls/autocomplete/AutoComplete.demo.svelte +88 -88
  50. package/dist/controls/autocomplete/AutoComplete.svelte +152 -152
  51. package/dist/controls/autocomplete/auto-complete.scss +15 -15
  52. package/dist/controls/button/Button.demo.svelte +165 -165
  53. package/dist/controls/button/Button.svelte +95 -95
  54. package/dist/controls/button/Button.svelte.d.ts +1 -1
  55. package/dist/controls/button/ButtonAction.svelte +55 -55
  56. package/dist/controls/button/ButtonMenu.svelte +55 -55
  57. package/dist/controls/button/IconButton.svelte +45 -45
  58. package/dist/controls/button/button-action.scss +8 -8
  59. package/dist/controls/button/button-menu.scss +36 -36
  60. package/dist/controls/button/button.scss +293 -293
  61. package/dist/controls/checkbox/Checkbox.demo.svelte +29 -29
  62. package/dist/controls/checkbox/Checkbox.svelte +59 -59
  63. package/dist/controls/checkbox/checkbox.scss +115 -115
  64. package/dist/controls/confirm/Confirm.demo.svelte +60 -60
  65. package/dist/controls/confirm/Confirm.preview.svelte +14 -14
  66. package/dist/controls/confirm/Confirm.svelte +156 -156
  67. package/dist/controls/confirm/confirm.scss +12 -12
  68. package/dist/controls/inplaceedit/InPlaceEdit.demo.svelte +41 -41
  69. package/dist/controls/inplaceedit/InPlaceEdit.svelte +109 -109
  70. package/dist/controls/progress/Progress.demo.svelte +30 -30
  71. package/dist/controls/progress/Progress.svelte +26 -26
  72. package/dist/controls/progress/progress.scss +23 -23
  73. package/dist/controls/rating/Rating.demo.svelte +45 -45
  74. package/dist/controls/rating/Rating.svelte +44 -44
  75. package/dist/controls/rating/Rating.svelte.d.ts +1 -1
  76. package/dist/controls/rating/rating.scss +9 -9
  77. package/dist/controls/select/Select.demo.svelte +101 -101
  78. package/dist/controls/select/Select.svelte +125 -125
  79. package/dist/controls/select/select.scss +13 -13
  80. package/dist/controls/slider/Slider.demo.svelte +34 -34
  81. package/dist/controls/slider/Slider.svelte +153 -153
  82. package/dist/controls/slider/slider.scss +51 -51
  83. package/dist/controls/stepper/Stepper.demo.svelte +32 -32
  84. package/dist/controls/stepper/Stepper.svelte +30 -30
  85. package/dist/controls/stepper/stepper.scss +23 -23
  86. package/dist/controls/switch/Switch.demo.svelte +61 -61
  87. package/dist/controls/switch/Switch.svelte +45 -45
  88. package/dist/controls/switch/switch.scss +73 -73
  89. package/dist/controls/textfield/TextField.demo.svelte +79 -79
  90. package/dist/controls/textfield/TextField.svelte +86 -86
  91. package/dist/controls/textfield/TextField.svelte.d.ts +1 -1
  92. package/dist/controls/textfield/textfield.scss +68 -68
  93. package/dist/csss/csss.scss +10 -10
  94. package/dist/data/dataList/DataList.demo.svelte +151 -151
  95. package/dist/data/dataList/DataList.preview.svelte +23 -23
  96. package/dist/data/dataList/DataList.svelte +233 -233
  97. package/dist/data/dataList/DataListCell.svelte +212 -212
  98. package/dist/data/dataList/DataListHead.svelte +75 -75
  99. package/dist/data/dataList/DataListRow.svelte +93 -93
  100. package/dist/data/dataList/datalist.scss +157 -157
  101. package/dist/data/finder/Finder.demo.svelte +55 -55
  102. package/dist/data/finder/Finder.svelte +166 -166
  103. package/dist/data/finder/finder.scss +14 -14
  104. package/dist/data/grouper/Grouper.demo.svelte +36 -36
  105. package/dist/data/grouper/Grouper.svelte +85 -85
  106. package/dist/data/jsoner/Jsoner.svelte +40 -40
  107. package/dist/data/list/List.svelte +16 -16
  108. package/dist/data/list/ListItem.svelte +10 -10
  109. package/dist/data/list/ListTitle.svelte +8 -8
  110. package/dist/data/loader/Loader.demo.svelte +95 -95
  111. package/dist/data/loader/Loader.preview.svelte +7 -7
  112. package/dist/data/loader/Loader.svelte +99 -99
  113. package/dist/data/loader/loader.scss +50 -50
  114. package/dist/data/sorter/Sorter.demo.svelte +62 -62
  115. package/dist/data/sorter/Sorter.svelte +80 -80
  116. package/dist/data/sorter/Sorterer.svelte +27 -27
  117. package/dist/data/sorter/sorterer.scss +11 -11
  118. package/dist/index.d.ts +67 -66
  119. package/dist/index.js +67 -66
  120. package/dist/navigation/drawer/Drawer.demo.svelte +52 -52
  121. package/dist/navigation/drawer/Drawer.svelte +163 -163
  122. package/dist/navigation/drawer/drawer.scss +69 -69
  123. package/dist/navigation/tabs/Tabs.demo.svelte +83 -83
  124. package/dist/navigation/tabs/Tabs.preview.svelte +22 -22
  125. package/dist/navigation/tabs/Tabs.svelte +158 -158
  126. package/dist/navigation/tabs/tabs.scss +92 -92
  127. package/dist/slotui-css/slotui-css.css +229 -229
  128. package/dist/slotui-css/slotui-min-css.css +229 -229
  129. package/dist/styles/slotui-mixins.scss +168 -168
  130. package/dist/styles/slotui-presets.scss +56 -56
  131. package/dist/styles/slotuisheet/SlotuiSheet.svelte +36 -36
  132. package/dist/styles/slotuisheet/SlotyuiSheet.demo.svelte +28 -28
  133. package/dist/styles/slotuisheet/sheetConfig.scss +7 -7
  134. package/dist/styles/slotuisheet/slotui-sheet.scss +192 -192
  135. package/dist/styles/slotuisheet/stylesheet-container.scss +147 -147
  136. package/dist/styles/slotuisheet/stylesheet.scss +156 -156
  137. package/dist/types/slotui-ambient.d.ts +27 -27
  138. package/dist/ui/bootstrapp/BootStrApp.svelte +92 -92
  139. package/dist/ui/chromeFrame/ChromeFrame.svelte +43 -43
  140. package/dist/ui/chromeFrame/ChromeFrameButtonList.svelte +33 -33
  141. package/dist/ui/chromeFrame/ChromeFrameList.svelte +106 -106
  142. package/dist/ui/chromeFrame/chrome-frame.scss +34 -34
  143. package/dist/ui/frame/Frame.demo.svelte +48 -48
  144. package/dist/ui/frame/Frame.svelte +90 -90
  145. package/dist/ui/frame/frame.scss +46 -46
  146. package/dist/ui/login/Login.demo.svelte +62 -62
  147. package/dist/ui/login/Login.svelte +102 -102
  148. package/dist/ui/marquee/Marquee.demo.svelte +33 -33
  149. package/dist/ui/marquee/Marquee.svelte +97 -97
  150. package/dist/ui/marquee/marquee.scss +34 -34
  151. package/dist/ui/menu/Menu.svelte +9 -9
  152. package/dist/ui/menu/MenuItem.svelte +9 -9
  153. package/dist/ui/menu/MenuTitle.svelte +10 -10
  154. package/dist/ui/menu/menu.scss +61 -61
  155. package/dist/ui/menuList/MenuList.demo.svelte +73 -73
  156. package/dist/ui/menuList/MenuList.svelte +143 -143
  157. package/dist/ui/menuList/MenuListItem.svelte +134 -134
  158. package/dist/ui/menuList/MenuListTitle.svelte +10 -10
  159. package/dist/ui/menuList/menu-list.scss +120 -120
  160. package/dist/ui/panel/Panel.demo.svelte +169 -169
  161. package/dist/ui/panel/Panel.svelte +96 -96
  162. package/dist/ui/panel/PanelGrid.svelte +62 -62
  163. package/dist/ui/panel/PanelSlide.svelte +156 -156
  164. package/dist/ui/panel/Paneler.svelte +63 -63
  165. package/dist/ui/panel/panel.scss +32 -32
  166. package/dist/ui/popper/Popper.demo.svelte +92 -92
  167. package/dist/ui/popper/Popper.svelte +160 -160
  168. package/dist/ui/popper/popper.scss +108 -108
  169. package/dist/ui/preview/Preview.svelte +41 -41
  170. package/dist/ui/serviceBox/ServiceBox.svelte +24 -24
  171. package/dist/ui/startMenu/BootMenu.svelte +102 -102
  172. package/dist/ui/startMenu/boot-menu.scss +86 -86
  173. package/dist/ui/taskbar/TaskBarContent.svelte +20 -20
  174. package/dist/ui/taskbar/Taskbar.svelte +26 -26
  175. package/dist/ui/taskbar/taskbar.scss +28 -28
  176. package/dist/ui/themeswitcher/ThemeSwitcher.svelte +18 -18
  177. package/dist/ui/toast/Toast.demo.svelte +19 -19
  178. package/dist/ui/toast/Toast.svelte +60 -60
  179. package/dist/ui/toast/Toaster.svelte +18 -18
  180. package/dist/ui/toggleBar/ToggleBar.demo.svelte +114 -114
  181. package/dist/ui/toggleBar/ToggleBar.svelte +58 -58
  182. package/dist/ui/toggleBar/ToggleBar.svelte.d.ts +1 -1
  183. package/dist/ui/toggleBar/toggle-bar.scss +45 -45
  184. package/dist/ui/toolBar/ToolBar.demo.svelte +98 -98
  185. package/dist/ui/toolBar/ToolBar.svelte +30 -30
  186. package/dist/ui/toolBar/toolbar.scss +32 -32
  187. package/dist/ui/tree/Tree.demo.svelte +84 -84
  188. package/dist/ui/tree/Tree.preview.svelte +19 -19
  189. package/dist/ui/tree/Tree.svelte +182 -182
  190. package/dist/ui/tree/tree.scss +38 -38
  191. package/dist/ui/window/Window.demo.svelte +111 -111
  192. package/dist/ui/window/Window.svelte +177 -177
  193. package/dist/ui/window/window.scss +66 -66
  194. package/dist/utils/content/Content.svelte +78 -78
  195. package/dist/utils/contextRooter/ContextRooter.demo.svelte +33 -33
  196. package/dist/utils/contextRooter/ContextRooter.svelte +6 -6
  197. package/dist/utils/css/Css.demo.svelte +5 -5
  198. package/dist/utils/css/Css.svelte +64 -64
  199. package/dist/utils/effects/transitions.js +6 -6
  200. package/dist/utils/looper/Looper.demo.svelte +36 -36
  201. package/dist/utils/looper/Looper.svelte +47 -47
  202. package/dist/utils/slotted/Slotted.svelte +21 -21
  203. package/dist/utils/stylesheet/StyleSheet.demo.svelte +28 -28
  204. package/dist/utils/stylesheet/StyleSheet.svelte +30 -30
  205. package/dist/utils/stylesheet/containerConfig.scss +7 -7
  206. package/dist/utils/stylesheet/stylesheet.scss +147 -147
  207. package/dist/utils/uses/sx4u/sx4uPreprocess.js +34 -34
  208. package/package.json +4 -4
@@ -1,127 +1,127 @@
1
- <script lang="ts">
2
- import type { CommonProps, Data, ElementProps, ExpandProps } from '../../types/index.js';
3
- import TextField from '../textfield/TextField.svelte';
4
- import Icon from '../../base/icon/Icon.svelte';
5
- import Popper from '../../ui/popper/Popper.svelte';
6
- import Menu from '../../ui/menu/Menu.svelte';
7
- import MenuItem from '../../ui/menu/MenuItem.svelte';
8
- import Slotted from '../../utils/slotted/Slotted.svelte';
9
- import type { Snippet } from 'svelte';
10
-
11
- type SelectProps = CommonProps & {
12
- /** The position of the popper */
13
- position?: ElementProps['popperPosition'];
14
-
15
- /** Whether the popper should stick to the hook width */
16
- stickToHookWidth: boolean;
17
-
18
- /** Whether the popper should auto close */
19
- autoClose?: boolean;
20
-
21
- /** The value of the select */
22
- value: any;
23
-
24
- /** The name of the select */
25
- name: string;
26
-
27
- /** The style of the select */
28
- style?: string;
29
-
30
- /** The class name of the select */
31
- className: string;
32
-
33
- /** The data for the select */
34
- data: any[];
35
- disabled?: boolean;
36
- /** The options for the select */
37
- options?: {
38
- data?: Data;
39
- text: string;
40
- icon?: any;
41
- }[];
42
-
43
- /** The data field id for the select */
44
- dataFieldId: string;
45
-
46
- /** The data field name for the select */
47
- dataFieldName: string;
48
- children?: Snippet<[{ optionsData: Data }]>;
49
- };
50
-
51
- let {
52
- name,
53
- element,
54
- disabled = false,
55
- data,
56
- dataFieldId,
57
- dataFieldName,
58
- options = [],
59
- position,
60
- stickToHookWidth,
61
- autoClose = false,
62
- value = undefined,
63
- children,
64
- ...rest
65
- }: ExpandProps<SelectProps> = $props();
66
-
67
- let hiddenRef;
68
- let isVisible: boolean = false;
69
-
70
- let timerClick: any;
71
-
72
- const show = (visible: boolean) => (event) => {
73
- timerClick = setTimeout(() => {
74
- isVisible = visible;
75
- }, 250);
76
- };
77
- </script>
78
-
79
- <input {value} bind:this={hiddenRef} type="hidden" {name} />
80
- <Popper {position} {stickToHookWidth} {autoClose} flow="fixed" isOpen={isVisible}>
81
- {#snippet popperHolder()}
82
- <TextField
83
- bind:this={element}
84
- onblur={show(false)}
85
- on:focus={show(true)}
86
- on:keydown={() => {
87
- console.log('red');
88
- }}
89
- placeholder="Select"
90
- readonly
91
- value=""
92
- {style}
93
- class={className}
94
- >
95
- {#snippet inputEnd()}
96
- <Icon icon="chevron-down" />
97
- {/snippet}
98
- </TextField>
99
- {/snippet}
100
-
101
- <Menu
102
- style="width:100%;"
103
- onclick={(event) => {
104
- const args = event.detail;
105
- hiddenRef.value = args?.[dataFieldId] ?? args?.['id'] ?? args?.[dataFieldName] ?? args;
106
- element.value = args?.[dataFieldName] ?? args?.[dataFieldId] ?? args?.['id'] ?? args;
107
- }}
108
- >
109
- {#if data}
110
- {#each data as dta}
111
- <Slotted child={children} slotArgs={{ optionsData: dta }}>
112
- <MenuItem selected={value === 2} data={dta}>{dta?.[dataFieldName]}</MenuItem></Slotted
113
- >
114
- {/each}
115
- {:else if options}
116
- {#each options as option}
117
- <Slotted child={children} slotArgs={{ optionsData: options }}>
118
- <MenuItem icon={option.icon} selected={value === 2} data={option}>{option.text}</MenuItem>
119
- </Slotted>
120
- {/each}
121
- {/if}
122
- </Menu>
123
- </Popper>
124
-
1
+ <script lang="ts">
2
+ import type { CommonProps, Data, ElementProps, ExpandProps } from '../../types/index.js';
3
+ import TextField from '../textfield/TextField.svelte';
4
+ import Icon from '../../base/icon/Icon.svelte';
5
+ import Popper from '../../ui/popper/Popper.svelte';
6
+ import Menu from '../../ui/menu/Menu.svelte';
7
+ import MenuItem from '../../ui/menu/MenuItem.svelte';
8
+ import Slotted from '../../utils/slotted/Slotted.svelte';
9
+ import type { Snippet } from 'svelte';
10
+
11
+ type SelectProps = CommonProps & {
12
+ /** The position of the popper */
13
+ position?: ElementProps['popperPosition'];
14
+
15
+ /** Whether the popper should stick to the hook width */
16
+ stickToHookWidth: boolean;
17
+
18
+ /** Whether the popper should auto close */
19
+ autoClose?: boolean;
20
+
21
+ /** The value of the select */
22
+ value: any;
23
+
24
+ /** The name of the select */
25
+ name: string;
26
+
27
+ /** The style of the select */
28
+ style?: string;
29
+
30
+ /** The class name of the select */
31
+ className: string;
32
+
33
+ /** The data for the select */
34
+ data: any[];
35
+ disabled?: boolean;
36
+ /** The options for the select */
37
+ options?: {
38
+ data?: Data;
39
+ text: string;
40
+ icon?: any;
41
+ }[];
42
+
43
+ /** The data field id for the select */
44
+ dataFieldId: string;
45
+
46
+ /** The data field name for the select */
47
+ dataFieldName: string;
48
+ children?: Snippet<[{ optionsData: Data }]>;
49
+ };
50
+
51
+ let {
52
+ name,
53
+ element,
54
+ disabled = false,
55
+ data,
56
+ dataFieldId,
57
+ dataFieldName,
58
+ options = [],
59
+ position,
60
+ stickToHookWidth,
61
+ autoClose = false,
62
+ value = undefined,
63
+ children,
64
+ ...rest
65
+ }: ExpandProps<SelectProps> = $props();
66
+
67
+ let hiddenRef;
68
+ let isVisible: boolean = false;
69
+
70
+ let timerClick: any;
71
+
72
+ const show = (visible: boolean) => (event) => {
73
+ timerClick = setTimeout(() => {
74
+ isVisible = visible;
75
+ }, 250);
76
+ };
77
+ </script>
78
+
79
+ <input {value} bind:this={hiddenRef} type="hidden" {name} />
80
+ <Popper {position} {stickToHookWidth} {autoClose} flow="fixed" isOpen={isVisible}>
81
+ {#snippet popperHolder()}
82
+ <TextField
83
+ bind:this={element}
84
+ onblur={show(false)}
85
+ on:focus={show(true)}
86
+ on:keydown={() => {
87
+ console.log('red');
88
+ }}
89
+ placeholder="Select"
90
+ readonly
91
+ value=""
92
+ {style}
93
+ class={className}
94
+ >
95
+ {#snippet inputEnd()}
96
+ <Icon icon="chevron-down" />
97
+ {/snippet}
98
+ </TextField>
99
+ {/snippet}
100
+
101
+ <Menu
102
+ style="width:100%;"
103
+ onclick={(event) => {
104
+ const args = event.detail;
105
+ hiddenRef.value = args?.[dataFieldId] ?? args?.['id'] ?? args?.[dataFieldName] ?? args;
106
+ element.value = args?.[dataFieldName] ?? args?.[dataFieldId] ?? args?.['id'] ?? args;
107
+ }}
108
+ >
109
+ {#if data}
110
+ {#each data as dta}
111
+ <Slotted child={children} slotArgs={{ optionsData: dta }}>
112
+ <MenuItem selected={value === 2} data={dta}>{dta?.[dataFieldName]}</MenuItem></Slotted
113
+ >
114
+ {/each}
115
+ {:else if options}
116
+ {#each options as option}
117
+ <Slotted child={children} slotArgs={{ optionsData: options }}>
118
+ <MenuItem icon={option.icon} selected={value === 2} data={option}>{option.text}</MenuItem>
119
+ </Slotted>
120
+ {/each}
121
+ {/if}
122
+ </Menu>
123
+ </Popper>
124
+
125
125
  <style>:root {
126
126
  --select-background-color: var(--sld-color-background);
127
127
  --select-radius: var(--sld-radius-small);
@@ -132,4 +132,4 @@
132
132
  height: 160px;
133
133
  width: 160px;
134
134
  border-radius: var(--select-radius);
135
- }</style>
135
+ }</style>
@@ -1,13 +1,13 @@
1
- @use "../../styles/slotui-mixins.scss";
2
-
3
- :root {
4
- --select-background-color: var(--sld-color-background);
5
- --select-radius: var(--sld-radius-small);
6
- }
7
-
8
- .select {
9
- background-color: var(--select-background-color);
10
- height: 160px;
11
- width: 160px;
12
- border-radius: var(--select-radius);
13
- }
1
+ @use "../../styles/slotui-mixins.scss";
2
+
3
+ :root {
4
+ --select-background-color: var(--sld-color-background);
5
+ --select-radius: var(--sld-radius-small);
6
+ }
7
+
8
+ .select {
9
+ background-color: var(--select-background-color);
10
+ height: 160px;
11
+ width: 160px;
12
+ border-radius: var(--select-radius);
13
+ }
@@ -1,34 +1,34 @@
1
- <script lang="ts">
2
- import Slider from './Slider.svelte';
3
-
4
- /* demo */
5
- import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
6
- import Demoer from '../../base/demoer/Demoer.svelte';
7
- import DemoPage from '../../base/demoer/DemoPage.svelte';
8
- /* demo */
9
-
10
- import { parameters, componentArgs } from './types.js';
11
-
12
- let codeSlot = `
13
- <Slider name={'switcher'} class="w-small" >
14
- <span />
15
- </Slider>`;
16
-
17
- let isOpen = false;
18
- </script>
19
-
20
- <ComponentDemo component="Slider">
21
- <div class="flex-v gap-large">
22
- <DemoPage code={codeSlot} component="Slider">
23
- <Demoer {parameters} {...componentArgs}>
24
- {#snippet children({ activeParams })}
25
- <div class="pad-2">
26
- <Slider {...activeParams} class="flex-h flex-align-middle w-small">
27
- <span>tooltip</span>
28
- </Slider>
29
- </div>
30
- {/snippet}
31
- </Demoer>
32
- </DemoPage>
33
- </div>
34
- </ComponentDemo>
1
+ <script lang="ts">
2
+ import Slider from './Slider.svelte';
3
+
4
+ /* demo */
5
+ import ComponentDemo from '../../base/demoer/DemoerComponent.svelte';
6
+ import Demoer from '../../base/demoer/Demoer.svelte';
7
+ import DemoPage from '../../base/demoer/DemoPage.svelte';
8
+ /* demo */
9
+
10
+ import { parameters, componentArgs } from './types.js';
11
+
12
+ let codeSlot = `
13
+ <Slider name={'switcher'} class="w-small" >
14
+ <span />
15
+ </Slider>`;
16
+
17
+ let isOpen = false;
18
+ </script>
19
+
20
+ <ComponentDemo component="Slider">
21
+ <div class="flex-v gap-large">
22
+ <DemoPage code={codeSlot} component="Slider">
23
+ <Demoer {parameters} {...componentArgs}>
24
+ {#snippet children({ activeParams })}
25
+ <div class="pad-2">
26
+ <Slider {...activeParams} class="flex-h flex-align-middle w-small">
27
+ <span>tooltip</span>
28
+ </Slider>
29
+ </div>
30
+ {/snippet}
31
+ </Demoer>
32
+ </DemoPage>
33
+ </div>
34
+ </ComponentDemo>
@@ -1,155 +1,155 @@
1
- <script lang="ts">
2
- import type { ExpandProps } from '../../types/index.js';
3
- import type { SliderProps } from './types.js';
4
-
5
- let {
6
- class: className = '',
7
- style = '',
8
- dense = 'default',
9
- element,
10
- elementInput,
11
- elementRail,
12
- value = $bindable(0),
13
- min = 0,
14
- max = 100,
15
- step = 1,
16
- orientation = 'horizontal',
17
- reverse = false,
18
- disabled = false,
19
- onchange
20
- }: ExpandProps<SliderProps> = $props();
21
-
22
- let dragging = $state(false);
23
- let holding = $state(false);
24
-
25
- const steps = {
26
- increase() {
27
- value += step;
28
- if (value > max) value = max;
29
- },
30
- decrease() {
31
- value -= step;
32
- if (value < min) value = min;
33
- }
34
- };
35
-
36
- const move = {
37
- handle() {
38
- if (holding) {
39
- dragging = true;
40
- }
41
- },
42
- cancel() {
43
- holding = false;
44
- dragging = false;
45
- }
46
- };
47
-
48
- const key = {
49
- start(event: Event) {
50
- if (event.cancelable) event.preventDefault();
51
- holding = true;
52
- },
53
- mouseDown(event: MouseEvent) {
54
- if (event.cancelable) event.preventDefault();
55
- holding = true;
56
- },
57
- click(event: MouseEvent) {
58
- if (event.cancelable) event.preventDefault();
59
- getSliderVal(event);
60
- holding = false;
61
- },
62
- keyDown(event: KeyboardEvent) {
63
- const { key } = event;
64
- const up = !reverse ? steps.increase : steps.decrease;
65
- const down = !reverse ? steps.decrease : steps.increase;
66
- if (key === 'ArrowDown' || key === 'ArrowUp') event.preventDefault();
67
- if (!disabled) {
68
- if (key === 'ArrowLeft' || (key === 'ArrowDown' && !disabled)) {
69
- up();
70
- } else if (key === 'ArrowRight' || (key === 'ArrowUp' && !disabled)) {
71
- down();
72
- }
73
- }
74
- }
75
- };
76
-
77
- let percentage = $derived(getPercentage(value));
78
- $effect(() => {
79
- if (value <= min) value = min;
80
- else if (value >= max) value = max;
81
- });
82
-
83
- $effect(() => {
84
- if (dragging) {
85
- getSliderVal(event);
86
- dragging = false;
87
- }
88
- });
89
-
90
- function getPercentage(val: number) {
91
- return ((val - min) / (max - min)) * 100;
92
- }
93
-
94
- function getSliderVal(event: Event) {
95
- // @ts-ignore
96
- const { clientX, clientY } = (event.touches ? event.touches?.[0] : event) as TouchEvent;
97
- // @ts-ignore
98
- const { left, top, width, height } = elementRail?.getBoundingClientRect();
99
- const offset = orientation === 'horizontal' ? clientX - left : top + height - clientY;
100
- const size = orientation === 'horizontal' ? width : height;
101
- const newValue = min + (max - min) * (offset / size);
102
- //
103
- value = Math.round(newValue / step) * step;
104
- }
105
- </script>
106
-
107
- <svelte:window
108
- onmousemove={move.handle}
109
- onmouseup={move.cancel}
110
- ontouchmove={move.handle}
111
- ontouchend={move.cancel}
112
- ontouchcancel={move.cancel}
113
- />
114
- <!-- svelte-ignore a11y_click_events_have_key_events -->
115
- <!-- svelte-ignore a11y_no_static_element_interactions -->
116
- <!-- svelte-ignore a11y_no_noninteractive_tabindex -->
117
- <div
118
- class="slider {className} dense-{dense}"
119
- onmousedown={key.mouseDown}
120
- ontouchstart={key.start}
121
- onkeydown={key.keyDown}
122
- onclick={key.click}
123
- tabindex="0"
124
- {style}
125
- bind:this={element}
126
- >
127
- <div class="slider-gouge" bind:this={elementRail}>
128
- <div class="slider-gouge-selected" style="width:{percentage}%;"></div>
129
- </div>
130
-
131
- <div
132
- class="slider-thumb"
133
- aria-valuemin={min}
134
- aria-valuemax={max}
135
- aria-valuenow={value}
136
- role="slider"
137
- style="left: {percentage}%;transform: translateX(-50%);"
138
- ></div>
139
-
140
- <input
141
- {onchange}
142
- hidden
143
- type="range"
144
- bind:this={elementInput}
145
- {disabled}
146
- {value}
147
- {min}
148
- {max}
149
- {step}
150
- />
151
- </div>
152
-
1
+ <script lang="ts">
2
+ import type { ExpandProps } from '../../types/index.js';
3
+ import type { SliderProps } from './types.js';
4
+
5
+ let {
6
+ class: className = '',
7
+ style = '',
8
+ dense = 'default',
9
+ element,
10
+ elementInput,
11
+ elementRail,
12
+ value = $bindable(0),
13
+ min = 0,
14
+ max = 100,
15
+ step = 1,
16
+ orientation = 'horizontal',
17
+ reverse = false,
18
+ disabled = false,
19
+ onchange
20
+ }: ExpandProps<SliderProps> = $props();
21
+
22
+ let dragging = $state(false);
23
+ let holding = $state(false);
24
+
25
+ const steps = {
26
+ increase() {
27
+ value += step;
28
+ if (value > max) value = max;
29
+ },
30
+ decrease() {
31
+ value -= step;
32
+ if (value < min) value = min;
33
+ }
34
+ };
35
+
36
+ const move = {
37
+ handle() {
38
+ if (holding) {
39
+ dragging = true;
40
+ }
41
+ },
42
+ cancel() {
43
+ holding = false;
44
+ dragging = false;
45
+ }
46
+ };
47
+
48
+ const key = {
49
+ start(event: Event) {
50
+ if (event.cancelable) event.preventDefault();
51
+ holding = true;
52
+ },
53
+ mouseDown(event: MouseEvent) {
54
+ if (event.cancelable) event.preventDefault();
55
+ holding = true;
56
+ },
57
+ click(event: MouseEvent) {
58
+ if (event.cancelable) event.preventDefault();
59
+ getSliderVal(event);
60
+ holding = false;
61
+ },
62
+ keyDown(event: KeyboardEvent) {
63
+ const { key } = event;
64
+ const up = !reverse ? steps.increase : steps.decrease;
65
+ const down = !reverse ? steps.decrease : steps.increase;
66
+ if (key === 'ArrowDown' || key === 'ArrowUp') event.preventDefault();
67
+ if (!disabled) {
68
+ if (key === 'ArrowLeft' || (key === 'ArrowDown' && !disabled)) {
69
+ up();
70
+ } else if (key === 'ArrowRight' || (key === 'ArrowUp' && !disabled)) {
71
+ down();
72
+ }
73
+ }
74
+ }
75
+ };
76
+
77
+ let percentage = $derived(getPercentage(value));
78
+ $effect(() => {
79
+ if (value <= min) value = min;
80
+ else if (value >= max) value = max;
81
+ });
82
+
83
+ $effect(() => {
84
+ if (dragging) {
85
+ getSliderVal(event);
86
+ dragging = false;
87
+ }
88
+ });
89
+
90
+ function getPercentage(val: number) {
91
+ return ((val - min) / (max - min)) * 100;
92
+ }
93
+
94
+ function getSliderVal(event: Event) {
95
+ // @ts-ignore
96
+ const { clientX, clientY } = (event.touches ? event.touches?.[0] : event) as TouchEvent;
97
+ // @ts-ignore
98
+ const { left, top, width, height } = elementRail?.getBoundingClientRect();
99
+ const offset = orientation === 'horizontal' ? clientX - left : top + height - clientY;
100
+ const size = orientation === 'horizontal' ? width : height;
101
+ const newValue = min + (max - min) * (offset / size);
102
+ //
103
+ value = Math.round(newValue / step) * step;
104
+ }
105
+ </script>
106
+
107
+ <svelte:window
108
+ onmousemove={move.handle}
109
+ onmouseup={move.cancel}
110
+ ontouchmove={move.handle}
111
+ ontouchend={move.cancel}
112
+ ontouchcancel={move.cancel}
113
+ />
114
+ <!-- svelte-ignore a11y_click_events_have_key_events -->
115
+ <!-- svelte-ignore a11y_no_static_element_interactions -->
116
+ <!-- svelte-ignore a11y_no_noninteractive_tabindex -->
117
+ <div
118
+ class="slider {className} dense-{dense}"
119
+ onmousedown={key.mouseDown}
120
+ ontouchstart={key.start}
121
+ onkeydown={key.keyDown}
122
+ onclick={key.click}
123
+ tabindex="0"
124
+ {style}
125
+ bind:this={element}
126
+ >
127
+ <div class="slider-gouge" bind:this={elementRail}>
128
+ <div class="slider-gouge-selected" style="width:{percentage}%;"></div>
129
+ </div>
130
+
131
+ <div
132
+ class="slider-thumb"
133
+ aria-valuemin={min}
134
+ aria-valuemax={max}
135
+ aria-valuenow={value}
136
+ role="slider"
137
+ style="left: {percentage}%;transform: translateX(-50%);"
138
+ ></div>
139
+
140
+ <input
141
+ {onchange}
142
+ hidden
143
+ type="range"
144
+ bind:this={elementInput}
145
+ {disabled}
146
+ {value}
147
+ {min}
148
+ {max}
149
+ {step}
150
+ />
151
+ </div>
152
+
153
153
  <style>:root {
154
154
  --slider-background-color: var(--sld-color-background);
155
155
  --slider-gouge-background-color: var(--sld-color-secondary);
@@ -223,4 +223,4 @@
223
223
  .slider .slider-thumb:hover {
224
224
  box-shadow: var(--slider-thumb-hover-box-shadow);
225
225
  outline: 4px solid var(--slider-thumb-hover-outline);
226
- }</style>
226
+ }</style>