@likable-hair/svelte 3.3.21 → 3.3.22
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/dist/components/composed/buttons/ActivableButton.svelte +6 -2
- package/dist/components/composed/buttons/ActivableButton.svelte.d.ts +36 -32
- package/dist/components/composed/common/MenuOrDrawer.svelte +21 -5
- package/dist/components/composed/common/MenuOrDrawer.svelte.d.ts +50 -36
- package/dist/components/composed/common/MenuOrDrawerOptions.svelte +29 -13
- package/dist/components/composed/common/MenuOrDrawerOptions.svelte.d.ts +34 -30
- package/dist/components/composed/common/QuickActions.svelte +52 -20
- package/dist/components/composed/common/QuickActions.svelte.d.ts +24 -20
- package/dist/components/composed/common/ToolTip.svelte +31 -22
- package/dist/components/composed/common/ToolTip.svelte.d.ts +32 -43
- package/dist/components/composed/forms/AsyncAutocomplete.svelte +44 -23
- package/dist/components/composed/forms/AsyncAutocomplete.svelte.d.ts +44 -39
- package/dist/components/composed/forms/AvatarDropdown.svelte +57 -27
- package/dist/components/composed/forms/AvatarDropdown.svelte.d.ts +45 -41
- package/dist/components/composed/forms/ConfirmOrCancelButtons.svelte +35 -17
- package/dist/components/composed/forms/ConfirmOrCancelButtons.svelte.d.ts +41 -37
- package/dist/components/composed/forms/CountriesAutocomplete.svelte +16 -7
- package/dist/components/composed/forms/CountriesAutocomplete.svelte.d.ts +31 -60
- package/dist/components/composed/forms/DatePickerTextField.svelte +166 -114
- package/dist/components/composed/forms/DatePickerTextField.svelte.d.ts +67 -63
- package/dist/components/composed/forms/Dropdown.svelte +51 -21
- package/dist/components/composed/forms/Dropdown.svelte.d.ts +48 -43
- package/dist/components/composed/forms/IconsDropdown.svelte +61 -33
- package/dist/components/composed/forms/IconsDropdown.svelte.d.ts +30 -26
- package/dist/components/composed/forms/LabelAndSelect.svelte +32 -7
- package/dist/components/composed/forms/LabelAndSelect.svelte.d.ts +35 -31
- package/dist/components/composed/forms/LabelAndTextField.svelte +30 -5
- package/dist/components/composed/forms/LabelAndTextField.svelte.d.ts +46 -42
- package/dist/components/composed/forms/ToggleList.svelte +59 -33
- package/dist/components/composed/forms/ToggleList.svelte.d.ts +21 -17
- package/dist/components/composed/forms/YearPickerTextField.svelte +114 -74
- package/dist/components/composed/forms/YearPickerTextField.svelte.d.ts +53 -49
- package/dist/components/composed/list/DynamicTable.svelte +1102 -707
- package/dist/components/composed/list/DynamicTable.svelte.d.ts +369 -365
- package/dist/components/composed/list/PaginatedTable.svelte +139 -76
- package/dist/components/composed/list/PaginatedTable.svelte.d.ts +108 -108
- package/dist/components/composed/progress/HorizontalStackedProgress.svelte +58 -30
- package/dist/components/composed/progress/HorizontalStackedProgress.svelte.d.ts +25 -21
- package/dist/components/composed/search/DynamicFilters.svelte +103 -82
- package/dist/components/composed/search/DynamicFilters.svelte.d.ts +31 -27
- package/dist/components/composed/search/FilterEditor.svelte +106 -77
- package/dist/components/composed/search/FilterEditor.svelte.d.ts +37 -33
- package/dist/components/composed/search/Filters.svelte +361 -292
- package/dist/components/composed/search/Filters.svelte.d.ts +55 -51
- package/dist/components/composed/search/GlobalSearchTextField.svelte +79 -41
- package/dist/components/composed/search/GlobalSearchTextField.svelte.d.ts +43 -39
- package/dist/components/composed/search/MobileFilterEditor.svelte +135 -93
- package/dist/components/composed/search/MobileFilterEditor.svelte.d.ts +39 -35
- package/dist/components/composed/search/SearchBar.svelte +28 -5
- package/dist/components/composed/search/SearchBar.svelte.d.ts +34 -30
- package/dist/components/composed/search/SearchResults.svelte +42 -7
- package/dist/components/composed/search/SearchResults.svelte.d.ts +40 -36
- package/dist/components/composed/shop/ProductCard.svelte +18 -4
- package/dist/components/composed/shop/ProductCard.svelte.d.ts +32 -28
- package/dist/components/composed/shop/ProductsGrid.svelte +22 -2
- package/dist/components/composed/shop/ProductsGrid.svelte.d.ts +44 -40
- package/dist/components/layouts/CollapsibleSideBarLayout.svelte +77 -38
- package/dist/components/layouts/CollapsibleSideBarLayout.svelte.d.ts +109 -69
- package/dist/components/layouts/StableDividedSideBarLayout.svelte +47 -17
- package/dist/components/layouts/StableDividedSideBarLayout.svelte.d.ts +50 -32
- package/dist/components/layouts/UnstableDividedSideBarLayout.svelte +53 -30
- package/dist/components/layouts/UnstableDividedSideBarLayout.svelte.d.ts +103 -63
- package/dist/components/simple/buttons/Button.svelte +78 -32
- package/dist/components/simple/buttons/Button.svelte.d.ts +47 -35
- package/dist/components/simple/buttons/LinkButton.svelte +54 -22
- package/dist/components/simple/buttons/LinkButton.svelte.d.ts +50 -33
- package/dist/components/simple/charts/GanymedeBarChart.svelte +172 -134
- package/dist/components/simple/charts/GanymedeBarChart.svelte.d.ts +50 -46
- package/dist/components/simple/charts/GanymedeLineChart.svelte +157 -115
- package/dist/components/simple/charts/GanymedeLineChart.svelte.d.ts +51 -47
- package/dist/components/simple/charts/GanymedePieChart.svelte +62 -39
- package/dist/components/simple/charts/GanymedePieChart.svelte.d.ts +37 -33
- package/dist/components/simple/common/Card.svelte +20 -1
- package/dist/components/simple/common/Card.svelte.d.ts +51 -38
- package/dist/components/simple/common/CollapsibleDivider.svelte +23 -11
- package/dist/components/simple/common/CollapsibleDivider.svelte.d.ts +29 -25
- package/dist/components/simple/common/Divider.svelte +8 -2
- package/dist/components/simple/common/Divider.svelte.d.ts +23 -19
- package/dist/components/simple/common/Gesture.svelte +64 -46
- package/dist/components/simple/common/Gesture.svelte.d.ts +21 -17
- package/dist/components/simple/common/InfiniteScroll.svelte +52 -29
- package/dist/components/simple/common/InfiniteScroll.svelte.d.ts +24 -20
- package/dist/components/simple/common/IntersectionObserver.svelte +45 -32
- package/dist/components/simple/common/IntersectionObserver.svelte.d.ts +34 -21
- package/dist/components/simple/common/MediaQuery.svelte +30 -21
- package/dist/components/simple/common/MediaQuery.svelte.d.ts +34 -30
- package/dist/components/simple/common/Menu.svelte +290 -201
- package/dist/components/simple/common/Menu.svelte.d.ts +51 -40
- package/dist/components/simple/common/Playground.svelte +18 -17
- package/dist/components/simple/common/Playground.svelte.d.ts +19 -15
- package/dist/components/simple/common/VerticalDraggableList.svelte +35 -16
- package/dist/components/simple/common/VerticalDraggableList.svelte.d.ts +33 -29
- package/dist/components/simple/dashboards/DashboardGridShaper.svelte +32 -26
- package/dist/components/simple/dashboards/DashboardGridShaper.svelte.d.ts +16 -12
- package/dist/components/simple/dates/Calendar.svelte +52 -28
- package/dist/components/simple/dates/Calendar.svelte.d.ts +45 -41
- package/dist/components/simple/dates/DatePicker.svelte +90 -60
- package/dist/components/simple/dates/DatePicker.svelte.d.ts +44 -40
- package/dist/components/simple/dates/MonthSelector.svelte +37 -15
- package/dist/components/simple/dates/MonthSelector.svelte.d.ts +35 -31
- package/dist/components/simple/dates/TimePicker.svelte +45 -31
- package/dist/components/simple/dates/TimePicker.svelte.d.ts +24 -20
- package/dist/components/simple/dates/TimePickerTextField.svelte +56 -35
- package/dist/components/simple/dates/TimePickerTextField.svelte.d.ts +28 -24
- package/dist/components/simple/dates/YearSelector.svelte +54 -29
- package/dist/components/simple/dates/YearSelector.svelte.d.ts +35 -31
- package/dist/components/simple/dialogs/Dialog.svelte +92 -62
- package/dist/components/simple/dialogs/Dialog.svelte.d.ts +42 -28
- package/dist/components/simple/forms/Autocomplete.svelte +201 -142
- package/dist/components/simple/forms/Autocomplete.svelte.d.ts +83 -79
- package/dist/components/simple/forms/Checkbox.svelte +40 -24
- package/dist/components/simple/forms/Checkbox.svelte.d.ts +25 -21
- package/dist/components/simple/forms/FileInput.svelte +88 -48
- package/dist/components/simple/forms/FileInput.svelte.d.ts +37 -33
- package/dist/components/simple/forms/FileInputList.svelte +52 -34
- package/dist/components/simple/forms/FileInputList.svelte.d.ts +43 -39
- package/dist/components/simple/forms/RadioButton.svelte +11 -3
- package/dist/components/simple/forms/RadioButton.svelte.d.ts +31 -27
- package/dist/components/simple/forms/Select.svelte +16 -3
- package/dist/components/simple/forms/Select.svelte.d.ts +24 -20
- package/dist/components/simple/forms/SimpleTextField.svelte +53 -6
- package/dist/components/simple/forms/SimpleTextField.svelte.d.ts +64 -60
- package/dist/components/simple/forms/Switch.svelte +30 -16
- package/dist/components/simple/forms/Switch.svelte.d.ts +25 -21
- package/dist/components/simple/forms/Textarea.svelte +27 -2
- package/dist/components/simple/forms/Textarea.svelte.d.ts +41 -37
- package/dist/components/simple/forms/Textfield.svelte +56 -18
- package/dist/components/simple/forms/Textfield.svelte.d.ts +55 -51
- package/dist/components/simple/forms/TreeEditor.svelte +141 -95
- package/dist/components/simple/forms/TreeEditor.svelte.d.ts +42 -38
- package/dist/components/simple/forms/TreeEditorItem.svelte +77 -42
- package/dist/components/simple/forms/TreeEditorItem.svelte.d.ts +54 -50
- package/dist/components/simple/forms/VerticalSwitch.svelte +11 -1
- package/dist/components/simple/forms/VerticalSwitch.svelte.d.ts +32 -28
- package/dist/components/simple/forms/VerticalTextSwitch.svelte +15 -3
- package/dist/components/simple/forms/VerticalTextSwitch.svelte.d.ts +30 -26
- package/dist/components/simple/lists/ColorInvertedSelector.svelte +53 -23
- package/dist/components/simple/lists/ColorInvertedSelector.svelte.d.ts +46 -42
- package/dist/components/simple/lists/HierarchyMenu.svelte +38 -19
- package/dist/components/simple/lists/HierarchyMenu.svelte.d.ts +34 -30
- package/dist/components/simple/lists/Paginator.svelte +50 -41
- package/dist/components/simple/lists/Paginator.svelte.d.ts +23 -19
- package/dist/components/simple/lists/SelectableMenuList.svelte +43 -15
- package/dist/components/simple/lists/SelectableMenuList.svelte.d.ts +24 -20
- package/dist/components/simple/lists/SelectableVerticalList.svelte +99 -57
- package/dist/components/simple/lists/SelectableVerticalList.svelte.d.ts +51 -47
- package/dist/components/simple/lists/SidebarMenuList.svelte +115 -70
- package/dist/components/simple/lists/SidebarMenuList.svelte.d.ts +26 -22
- package/dist/components/simple/lists/SimpleTable.svelte +264 -154
- package/dist/components/simple/lists/SimpleTable.svelte.d.ts +70 -66
- package/dist/components/simple/loaders/CircularLoader.svelte +16 -5
- package/dist/components/simple/loaders/CircularLoader.svelte.d.ts +19 -15
- package/dist/components/simple/loaders/Skeleton.svelte +3 -2
- package/dist/components/simple/loaders/Skeleton.svelte.d.ts +16 -12
- package/dist/components/simple/media/AttachmentDownloader.svelte +17 -3
- package/dist/components/simple/media/AttachmentDownloader.svelte.d.ts +32 -28
- package/dist/components/simple/media/Avatar.svelte +18 -12
- package/dist/components/simple/media/Avatar.svelte.d.ts +31 -20
- package/dist/components/simple/media/Carousel.svelte +29 -11
- package/dist/components/simple/media/Carousel.svelte.d.ts +28 -24
- package/dist/components/simple/media/DescriptiveAvatar.svelte +12 -4
- package/dist/components/simple/media/DescriptiveAvatar.svelte.d.ts +44 -28
- package/dist/components/simple/media/FlagIcon.svelte +8 -5
- package/dist/components/simple/media/FlagIcon.svelte.d.ts +19 -15
- package/dist/components/simple/media/Gallery.svelte +49 -29
- package/dist/components/simple/media/Gallery.svelte.d.ts +27 -23
- package/dist/components/simple/media/Icon.svelte +9 -4
- package/dist/components/simple/media/Icon.svelte.d.ts +24 -20
- package/dist/components/simple/media/Image.svelte +42 -20
- package/dist/components/simple/media/Image.svelte.d.ts +44 -33
- package/dist/components/simple/media/ImageGrid.svelte +37 -12
- package/dist/components/simple/media/ImageGrid.svelte.d.ts +32 -28
- package/dist/components/simple/navigation/Breadcrumb.svelte +28 -10
- package/dist/components/simple/navigation/Breadcrumb.svelte.d.ts +26 -22
- package/dist/components/simple/navigation/Chip.svelte +44 -23
- package/dist/components/simple/navigation/Chip.svelte.d.ts +42 -31
- package/dist/components/simple/navigation/Drawer.svelte +107 -65
- package/dist/components/simple/navigation/Drawer.svelte.d.ts +50 -37
- package/dist/components/simple/navigation/HeaderMenu.svelte +40 -23
- package/dist/components/simple/navigation/HeaderMenu.svelte.d.ts +39 -35
- package/dist/components/simple/navigation/Navigator.svelte +30 -8
- package/dist/components/simple/navigation/Navigator.svelte.d.ts +28 -24
- package/dist/components/simple/navigation/TabSwitcher.svelte +83 -47
- package/dist/components/simple/navigation/TabSwitcher.svelte.d.ts +38 -34
- package/dist/components/simple/notifiers/AlertBanner.svelte +43 -15
- package/dist/components/simple/notifiers/AlertBanner.svelte.d.ts +41 -37
- package/dist/components/simple/progress/ProgressBar.svelte +20 -13
- package/dist/components/simple/progress/ProgressBar.svelte.d.ts +21 -17
- package/dist/components/simple/timeline/SimpleTimeLine.svelte +19 -5
- package/dist/components/simple/timeline/SimpleTimeLine.svelte.d.ts +39 -35
- package/dist/components/simple/typography/Code.svelte +27 -12
- package/dist/components/simple/typography/Code.svelte.d.ts +28 -24
- package/dist/stores/debounce.d.ts +0 -1
- package/dist/stores/layouts/unstableSidebarOpened.d.ts +0 -1
- package/dist/stores/mediaQuery.d.ts +0 -1
- package/dist/stores/theme.d.ts +0 -1
- package/dist/utils/filters/builder.d.ts +2 -0
- package/dist/utils/filters/builder.js +20 -0
- package/dist/utils/filters/modifiers/where.d.ts +10 -3
- package/package.json +1 -1
|
@@ -1,23 +1,61 @@
|
|
|
1
|
-
<script context="module"
|
|
1
|
+
<script lang="ts" context="module">
|
|
2
|
+
export type VariantOptions = "outlined" | "boxed";
|
|
3
|
+
</script>
|
|
4
|
+
|
|
5
|
+
<script lang="ts">
|
|
6
|
+
export let label = "",
|
|
7
|
+
placeholder = "",
|
|
8
|
+
color: string | null = null,
|
|
9
|
+
value: string | number = "",
|
|
10
|
+
disabled = false,
|
|
11
|
+
variant: VariantOptions = "outlined",
|
|
12
|
+
width = "100%",
|
|
13
|
+
height = "50px",
|
|
14
|
+
maxWidth: string | undefined = undefined,
|
|
15
|
+
minWidth: string | undefined = undefined,
|
|
16
|
+
textColor = "black",
|
|
17
|
+
borderWeight = "2px",
|
|
18
|
+
borderRadius = "5px",
|
|
19
|
+
borderColor: string | null = null,
|
|
20
|
+
focusBorderColor: string | null = null,
|
|
21
|
+
focusedBoxShadow: string | undefined = undefined,
|
|
22
|
+
backgroundColor: string | null = null,
|
|
23
|
+
padding: string | undefined = undefined,
|
|
24
|
+
paddingLeft: string | undefined = undefined,
|
|
25
|
+
paddingRight: string | undefined = undefined,
|
|
26
|
+
paddingBottom: string | undefined = undefined,
|
|
27
|
+
paddingTop: string | undefined = undefined,
|
|
28
|
+
fontSize: string | undefined = undefined,
|
|
29
|
+
type: "text" | "password" | "number" = "text",
|
|
30
|
+
readonly = false,
|
|
31
|
+
inputElement: HTMLElement | undefined = undefined,
|
|
32
|
+
autocomplete = true;
|
|
33
|
+
|
|
34
|
+
import { createId } from '@paralleldrive/cuid2';
|
|
35
|
+
import { onMount } from "svelte";
|
|
36
|
+
|
|
37
|
+
let inputId: string = createId(),
|
|
38
|
+
focused = false,
|
|
39
|
+
legendWidth = 0,
|
|
40
|
+
labelElement: HTMLElement | undefined = undefined;
|
|
41
|
+
|
|
42
|
+
onMount(() => {
|
|
43
|
+
console.warn('TextField component is going to be depracated. Please use SimpleTextField instead.')
|
|
2
44
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
45
|
+
if (labelElement) {
|
|
46
|
+
legendWidth = labelElement.offsetWidth * 0.8 + 8;
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
function handleFocus(): void {
|
|
51
|
+
focused = true;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function handleBlur(): void {
|
|
55
|
+
focused = false;
|
|
11
56
|
}
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
focused = true;
|
|
15
|
-
}
|
|
16
|
-
function handleBlur() {
|
|
17
|
-
focused = false;
|
|
18
|
-
}
|
|
19
|
-
$:
|
|
20
|
-
if (labelElement) {
|
|
57
|
+
|
|
58
|
+
$: if (labelElement) {
|
|
21
59
|
legendWidth = !value && !focused ? 0 : labelElement.offsetWidth * 0.8 + 8;
|
|
22
60
|
}
|
|
23
61
|
</script>
|
|
@@ -1,54 +1,58 @@
|
|
|
1
|
-
import { SvelteComponent } from "svelte";
|
|
2
1
|
export type VariantOptions = "outlined" | "boxed";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
maxWidth?: string | undefined;
|
|
14
|
-
minWidth?: string | undefined;
|
|
15
|
-
textColor?: string | undefined;
|
|
16
|
-
borderWeight?: string | undefined;
|
|
17
|
-
borderRadius?: string | undefined;
|
|
18
|
-
borderColor?: string | null | undefined;
|
|
19
|
-
focusBorderColor?: string | null | undefined;
|
|
20
|
-
focusedBoxShadow?: string | undefined;
|
|
21
|
-
backgroundColor?: string | null | undefined;
|
|
22
|
-
padding?: string | undefined;
|
|
23
|
-
paddingLeft?: string | undefined;
|
|
24
|
-
paddingRight?: string | undefined;
|
|
25
|
-
paddingBottom?: string | undefined;
|
|
26
|
-
paddingTop?: string | undefined;
|
|
27
|
-
fontSize?: string | undefined;
|
|
28
|
-
type?: "number" | "text" | "password" | undefined;
|
|
29
|
-
readonly?: boolean | undefined;
|
|
30
|
-
inputElement?: HTMLElement | undefined;
|
|
31
|
-
autocomplete?: boolean | undefined;
|
|
2
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
3
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
4
|
+
$$bindings?: Bindings;
|
|
5
|
+
} & Exports;
|
|
6
|
+
(internal: unknown, props: Props & {
|
|
7
|
+
$$events?: Events;
|
|
8
|
+
$$slots?: Slots;
|
|
9
|
+
}): Exports & {
|
|
10
|
+
$set?: any;
|
|
11
|
+
$on?: any;
|
|
32
12
|
};
|
|
33
|
-
|
|
34
|
-
change: Event;
|
|
35
|
-
input: Event;
|
|
36
|
-
focus: FocusEvent;
|
|
37
|
-
blur: FocusEvent;
|
|
38
|
-
keydown: KeyboardEvent;
|
|
39
|
-
keypress: KeyboardEvent;
|
|
40
|
-
keyup: KeyboardEvent;
|
|
41
|
-
} & {
|
|
42
|
-
[evt: string]: CustomEvent<any>;
|
|
43
|
-
};
|
|
44
|
-
slots: {
|
|
45
|
-
'prepend-inner': {};
|
|
46
|
-
'append-inner': {};
|
|
47
|
-
};
|
|
48
|
-
};
|
|
49
|
-
export type TextfieldProps = typeof __propDef.props;
|
|
50
|
-
export type TextfieldEvents = typeof __propDef.events;
|
|
51
|
-
export type TextfieldSlots = typeof __propDef.slots;
|
|
52
|
-
export default class Textfield extends SvelteComponent<TextfieldProps, TextfieldEvents, TextfieldSlots> {
|
|
13
|
+
z_$$bindings?: Bindings;
|
|
53
14
|
}
|
|
54
|
-
|
|
15
|
+
declare const Textfield: $$__sveltets_2_IsomorphicComponent<{
|
|
16
|
+
label?: string;
|
|
17
|
+
placeholder?: string;
|
|
18
|
+
color?: string | null;
|
|
19
|
+
value?: string | number;
|
|
20
|
+
disabled?: boolean;
|
|
21
|
+
variant?: VariantOptions;
|
|
22
|
+
width?: string;
|
|
23
|
+
height?: string;
|
|
24
|
+
maxWidth?: string | undefined;
|
|
25
|
+
minWidth?: string | undefined;
|
|
26
|
+
textColor?: string;
|
|
27
|
+
borderWeight?: string;
|
|
28
|
+
borderRadius?: string;
|
|
29
|
+
borderColor?: string | null;
|
|
30
|
+
focusBorderColor?: string | null;
|
|
31
|
+
focusedBoxShadow?: string | undefined;
|
|
32
|
+
backgroundColor?: string | null;
|
|
33
|
+
padding?: string | undefined;
|
|
34
|
+
paddingLeft?: string | undefined;
|
|
35
|
+
paddingRight?: string | undefined;
|
|
36
|
+
paddingBottom?: string | undefined;
|
|
37
|
+
paddingTop?: string | undefined;
|
|
38
|
+
fontSize?: string | undefined;
|
|
39
|
+
type?: "text" | "password" | "number";
|
|
40
|
+
readonly?: boolean;
|
|
41
|
+
inputElement?: HTMLElement | undefined;
|
|
42
|
+
autocomplete?: boolean;
|
|
43
|
+
}, {
|
|
44
|
+
change: Event;
|
|
45
|
+
input: Event;
|
|
46
|
+
focus: FocusEvent;
|
|
47
|
+
blur: FocusEvent;
|
|
48
|
+
keydown: KeyboardEvent;
|
|
49
|
+
keypress: KeyboardEvent;
|
|
50
|
+
keyup: KeyboardEvent;
|
|
51
|
+
} & {
|
|
52
|
+
[evt: string]: CustomEvent<any>;
|
|
53
|
+
}, {
|
|
54
|
+
'prepend-inner': {};
|
|
55
|
+
'append-inner': {};
|
|
56
|
+
}, {}, string>;
|
|
57
|
+
type Textfield = InstanceType<typeof Textfield>;
|
|
58
|
+
export default Textfield;
|
|
@@ -1,104 +1,150 @@
|
|
|
1
|
-
<script context="module"
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
let
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
1
|
+
<script lang="ts" context="module">
|
|
2
|
+
export type Item = {
|
|
3
|
+
id: number | string,
|
|
4
|
+
title: string,
|
|
5
|
+
expanded?: boolean,
|
|
6
|
+
sortable?: Sortable
|
|
7
|
+
children?: Item[],
|
|
8
|
+
data?: any
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export type CleanItem = {
|
|
12
|
+
id: number | string,
|
|
13
|
+
title: string,
|
|
14
|
+
expanded?: boolean,
|
|
15
|
+
children?: CleanItem[],
|
|
16
|
+
data?: any
|
|
17
|
+
};
|
|
18
|
+
</script>
|
|
19
|
+
|
|
20
|
+
<script lang="ts">
|
|
21
|
+
import Sortable from 'sortablejs';
|
|
22
|
+
import { onMount, createEventDispatcher, type ComponentProps } from 'svelte';
|
|
23
|
+
import TreeEditorItem from './TreeEditorItem.svelte';
|
|
24
|
+
import { createId } from '@paralleldrive/cuid2';
|
|
25
|
+
import lodash from 'lodash';
|
|
26
|
+
|
|
27
|
+
let dispatch = createEventDispatcher<{
|
|
28
|
+
'change': {
|
|
29
|
+
items: Item[]
|
|
30
|
+
},
|
|
31
|
+
'input': {
|
|
32
|
+
item: Item,
|
|
33
|
+
items: Item[]
|
|
34
|
+
},
|
|
35
|
+
}>()
|
|
36
|
+
|
|
37
|
+
export let items: Item[] = [],
|
|
38
|
+
groupName: string = createId(),
|
|
39
|
+
cleanItems: CleanItem[] = convertItemsInClean(items),
|
|
40
|
+
collapsable: boolean = true,
|
|
41
|
+
editable: boolean = true,
|
|
42
|
+
updateItem: ComponentProps<TreeEditorItem>['updateItem'] = ({ item }) => { return item }
|
|
43
|
+
|
|
44
|
+
let itemList: HTMLElement,
|
|
45
|
+
sortable: Sortable | undefined = undefined,
|
|
46
|
+
rerender: boolean = true,
|
|
47
|
+
mounted: boolean = false
|
|
48
|
+
|
|
49
|
+
onMount(() => {
|
|
50
|
+
mounted = true
|
|
51
|
+
initSortable()
|
|
52
|
+
})
|
|
53
|
+
|
|
54
|
+
async function initSortable() {
|
|
55
|
+
if(!mounted) return
|
|
56
|
+
|
|
57
|
+
sortable = Sortable.create(itemList, {
|
|
58
|
+
handle: '.handle',
|
|
59
|
+
group: groupName,
|
|
60
|
+
animation: 150,
|
|
61
|
+
ghostClass: 'ghost-drag-element',
|
|
62
|
+
onEnd(event) {
|
|
63
|
+
sortTree()
|
|
64
|
+
}
|
|
65
|
+
})
|
|
54
66
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
orderedIds.push(id);
|
|
67
|
+
|
|
68
|
+
$: if(!!items) initSortable()
|
|
69
|
+
|
|
70
|
+
function handleEnd(event: CustomEvent<{ ev: Sortable.SortableEvent }>) {
|
|
71
|
+
sortTree()
|
|
61
72
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
let
|
|
65
|
-
let
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
+
|
|
74
|
+
async function sortTree() {
|
|
75
|
+
let clonedItems = lodash.cloneDeep(items)
|
|
76
|
+
let sortedItems = sortSubTree(clonedItems, items, sortable, 'main')
|
|
77
|
+
|
|
78
|
+
dispatch('change', {
|
|
79
|
+
items: sortedItems
|
|
80
|
+
})
|
|
81
|
+
|
|
82
|
+
items = sortedItems
|
|
83
|
+
rerender = !rerender
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
function sortSubTree(totalItems: Item[], itemsToSort: Item[], parentSortable: Sortable | undefined, parentId?: Item['id']): Item[] {
|
|
87
|
+
if(!parentSortable) throw new Error('Parent sortable could not be undefined')
|
|
88
|
+
parentSortable.save()
|
|
89
|
+
|
|
90
|
+
for(let i = 0; i < itemsToSort.length; i += 1) {
|
|
91
|
+
let itemToSort = itemsToSort[i]
|
|
92
|
+
|
|
93
|
+
if(!!itemToSort.children) {
|
|
94
|
+
itemsToSort[i].children = sortSubTree(totalItems, itemToSort.children, itemToSort.sortable, itemToSort.id)
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
let orderedIds: Item['id'][] = []
|
|
99
|
+
for(let k = 0; k < parentSortable.el.children.length; k += 1) {
|
|
100
|
+
let id = parentSortable.el.children[k].getAttribute('data-sortable-id')?.toString()
|
|
101
|
+
if(!id) throw new Error('All html element must have data-sortbale-id')
|
|
102
|
+
orderedIds.push(id)
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
let newItems: Item[] = []
|
|
106
|
+
for(let j = 0; j < orderedIds.length; j += 1) {
|
|
107
|
+
let id = orderedIds[j]
|
|
108
|
+
let itemIndex = itemsToSort.findIndex((its) => its.id.toString() == id)
|
|
109
|
+
if(itemIndex === -1) {
|
|
110
|
+
let itemToAdd = findItem(totalItems, id)
|
|
111
|
+
if(!itemToAdd) continue
|
|
112
|
+
|
|
113
|
+
newItems.push(itemToAdd)
|
|
114
|
+
} else {
|
|
115
|
+
newItems.push(itemsToSort[itemIndex])
|
|
116
|
+
}
|
|
73
117
|
}
|
|
118
|
+
|
|
119
|
+
return newItems
|
|
74
120
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
121
|
+
|
|
122
|
+
function findItem(itemsToSearch: Item[], id: Item['id']): Item | undefined {
|
|
123
|
+
for(let i = 0; i < itemsToSearch.length; i += 1) {
|
|
124
|
+
let item = itemsToSearch[i]
|
|
125
|
+
|
|
126
|
+
if(item.id == id) return item
|
|
127
|
+
|
|
128
|
+
if(!!item.children) {
|
|
129
|
+
let result = findItem(item.children, id)
|
|
130
|
+
if(!!result) return result
|
|
131
|
+
}
|
|
86
132
|
}
|
|
87
133
|
}
|
|
88
|
-
|
|
89
|
-
function convertItemsInClean(
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
cleanItems = convertItemsInClean(items)
|
|
134
|
+
|
|
135
|
+
function convertItemsInClean(items: Item[]): CleanItem[] {
|
|
136
|
+
return items.map((i) => {
|
|
137
|
+
return {
|
|
138
|
+
id: i.id,
|
|
139
|
+
title: i.title,
|
|
140
|
+
expanded: i.expanded,
|
|
141
|
+
children: !!i.children ? convertItemsInClean(i.children) : [],
|
|
142
|
+
data: i.data
|
|
143
|
+
}
|
|
144
|
+
})
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
$: cleanItems = convertItemsInClean(items)
|
|
102
148
|
</script>
|
|
103
149
|
|
|
104
150
|
{#key rerender}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { SvelteComponent } from "svelte";
|
|
2
1
|
export type Item = {
|
|
3
2
|
id: number | string;
|
|
4
3
|
title: string;
|
|
@@ -17,43 +16,48 @@ export type CleanItem = {
|
|
|
17
16
|
import Sortable from 'sortablejs';
|
|
18
17
|
import { type ComponentProps } from 'svelte';
|
|
19
18
|
import TreeEditorItem from './TreeEditorItem.svelte';
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
19
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
20
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
21
|
+
$$bindings?: Bindings;
|
|
22
|
+
} & Exports;
|
|
23
|
+
(internal: unknown, props: Props & {
|
|
24
|
+
$$events?: Events;
|
|
25
|
+
$$slots?: Slots;
|
|
26
|
+
}): Exports & {
|
|
27
|
+
$set?: any;
|
|
28
|
+
$on?: any;
|
|
28
29
|
};
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
30
|
+
z_$$bindings?: Bindings;
|
|
31
|
+
}
|
|
32
|
+
declare const TreeEditor: $$__sveltets_2_IsomorphicComponent<{
|
|
33
|
+
items?: Item[];
|
|
34
|
+
groupName?: string;
|
|
35
|
+
cleanItems?: CleanItem[];
|
|
36
|
+
collapsable?: boolean;
|
|
37
|
+
editable?: boolean;
|
|
38
|
+
updateItem?: ComponentProps<TreeEditorItem>["updateItem"];
|
|
39
|
+
}, {
|
|
40
|
+
click: CustomEvent<{
|
|
41
|
+
item: Item;
|
|
42
|
+
}>;
|
|
43
|
+
change: CustomEvent<{
|
|
44
|
+
items: Item[];
|
|
45
|
+
}>;
|
|
46
|
+
input: CustomEvent<{
|
|
47
|
+
item: Item;
|
|
48
|
+
items: Item[];
|
|
49
|
+
}>;
|
|
50
|
+
} & {
|
|
51
|
+
[evt: string]: CustomEvent<any>;
|
|
52
|
+
}, {
|
|
53
|
+
append: {
|
|
54
|
+
item: any;
|
|
55
|
+
doUpdateItem: any;
|
|
42
56
|
};
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
doUpdateItem: any;
|
|
47
|
-
};
|
|
48
|
-
title: {
|
|
49
|
-
item: any;
|
|
50
|
-
doUpdateItem: any;
|
|
51
|
-
};
|
|
57
|
+
title: {
|
|
58
|
+
item: any;
|
|
59
|
+
doUpdateItem: any;
|
|
52
60
|
};
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
export
|
|
56
|
-
export type TreeEditorSlots = typeof __propDef.slots;
|
|
57
|
-
export default class TreeEditor extends SvelteComponent<TreeEditorProps, TreeEditorEvents, TreeEditorSlots> {
|
|
58
|
-
}
|
|
59
|
-
export {};
|
|
61
|
+
}, {}, string>;
|
|
62
|
+
type TreeEditor = InstanceType<typeof TreeEditor>;
|
|
63
|
+
export default TreeEditor;
|
|
@@ -1,54 +1,89 @@
|
|
|
1
|
-
<script
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
sortable = Sortable.create(subItemList, {
|
|
18
|
-
group,
|
|
19
|
-
handle: ".handle",
|
|
20
|
-
animation: animationDuration,
|
|
21
|
-
ghostClass: "ghost-drag-element",
|
|
22
|
-
onEnd(ev) {
|
|
23
|
-
dispatch("end", { ev });
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import Sortable from 'sortablejs';
|
|
3
|
+
import { onMount, type ComponentProps } from "svelte";
|
|
4
|
+
import type TreeEditor from './TreeEditor.svelte';
|
|
5
|
+
import Icon from '../media/Icon.svelte';
|
|
6
|
+
import Button from '../buttons/Button.svelte';
|
|
7
|
+
import { slide } from 'svelte/transition';
|
|
8
|
+
import { createEventDispatcher } from 'svelte';
|
|
9
|
+
import type { Item } from './TreeEditor.svelte';
|
|
10
|
+
|
|
11
|
+
let dispatch = createEventDispatcher<{
|
|
12
|
+
'change': {
|
|
13
|
+
ev: Sortable.SortableEvent
|
|
14
|
+
},
|
|
15
|
+
'end': {
|
|
16
|
+
ev: Sortable.SortableEvent
|
|
24
17
|
},
|
|
25
|
-
|
|
26
|
-
|
|
18
|
+
'input': {
|
|
19
|
+
item: Item,
|
|
20
|
+
inputData?: any
|
|
27
21
|
},
|
|
28
|
-
|
|
22
|
+
'click': {
|
|
23
|
+
item: Item
|
|
29
24
|
}
|
|
30
|
-
})
|
|
31
|
-
|
|
32
|
-
let
|
|
33
|
-
|
|
34
|
-
|
|
25
|
+
}>()
|
|
26
|
+
|
|
27
|
+
export let title: string,
|
|
28
|
+
id: number | string,
|
|
29
|
+
subtitle: string | undefined = undefined,
|
|
30
|
+
group: string,
|
|
31
|
+
animationDuration: number = 150,
|
|
32
|
+
expanded: boolean | undefined = true,
|
|
33
|
+
subItems: Item[] = [],
|
|
34
|
+
sortable: Sortable | undefined = undefined,
|
|
35
|
+
collapsable: boolean = true,
|
|
36
|
+
editable: boolean = true,
|
|
37
|
+
data: any = undefined,
|
|
38
|
+
updateItem: ((params: { item: Item, inputData?: any }) => Item) | undefined = undefined
|
|
39
|
+
|
|
40
|
+
let subItemList: HTMLElement,
|
|
41
|
+
mounted: boolean = false
|
|
42
|
+
|
|
43
|
+
onMount(() => {
|
|
44
|
+
mounted = true
|
|
45
|
+
initSortable()
|
|
46
|
+
})
|
|
47
|
+
|
|
48
|
+
function initSortable() {
|
|
49
|
+
if(!mounted) return
|
|
50
|
+
|
|
51
|
+
sortable = Sortable.create(subItemList, {
|
|
52
|
+
group: group,
|
|
53
|
+
handle: '.handle',
|
|
54
|
+
animation: animationDuration,
|
|
55
|
+
ghostClass: 'ghost-drag-element',
|
|
56
|
+
onEnd(ev) {
|
|
57
|
+
dispatch('end', { ev })
|
|
58
|
+
},
|
|
59
|
+
onChange(ev) {
|
|
60
|
+
dispatch('change', { ev })
|
|
61
|
+
},
|
|
62
|
+
onUpdate(ev) {
|
|
63
|
+
}
|
|
64
|
+
})
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
let currentItem: Item
|
|
68
|
+
$: currentItem = {
|
|
35
69
|
id,
|
|
36
70
|
title,
|
|
37
71
|
expanded,
|
|
38
72
|
sortable,
|
|
39
73
|
children: subItems,
|
|
40
|
-
data
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
if
|
|
44
|
-
|
|
45
|
-
function doUpdateItem(item, inputData) {
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
74
|
+
data: data
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
$: if(!!subItems) initSortable()
|
|
78
|
+
|
|
79
|
+
function doUpdateItem(item: Item, inputData: any) {
|
|
80
|
+
let newItem = item
|
|
81
|
+
if(!!updateItem) {
|
|
82
|
+
newItem = updateItem({ item, inputData })
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
dispatch('input', { item: newItem })
|
|
49
86
|
}
|
|
50
|
-
dispatch("input", { item: newItem });
|
|
51
|
-
}
|
|
52
87
|
</script>
|
|
53
88
|
|
|
54
89
|
<li
|