@likable-hair/svelte 3.3.20 → 3.3.21
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 +2 -6
- package/dist/components/composed/buttons/ActivableButton.svelte.d.ts +32 -36
- package/dist/components/composed/common/MenuOrDrawer.svelte +5 -21
- package/dist/components/composed/common/MenuOrDrawer.svelte.d.ts +36 -50
- package/dist/components/composed/common/MenuOrDrawerOptions.svelte +13 -29
- package/dist/components/composed/common/MenuOrDrawerOptions.svelte.d.ts +30 -34
- package/dist/components/composed/common/QuickActions.svelte +20 -52
- package/dist/components/composed/common/QuickActions.svelte.d.ts +20 -24
- package/dist/components/composed/common/ToolTip.svelte +22 -31
- package/dist/components/composed/common/ToolTip.svelte.d.ts +43 -32
- package/dist/components/composed/forms/AsyncAutocomplete.svelte +23 -44
- package/dist/components/composed/forms/AsyncAutocomplete.svelte.d.ts +39 -44
- package/dist/components/composed/forms/AvatarDropdown.svelte +27 -57
- package/dist/components/composed/forms/AvatarDropdown.svelte.d.ts +41 -45
- package/dist/components/composed/forms/ConfirmOrCancelButtons.svelte +17 -35
- package/dist/components/composed/forms/ConfirmOrCancelButtons.svelte.d.ts +37 -41
- package/dist/components/composed/forms/CountriesAutocomplete.svelte +7 -16
- package/dist/components/composed/forms/CountriesAutocomplete.svelte.d.ts +60 -31
- package/dist/components/composed/forms/DatePickerTextField.svelte +114 -166
- package/dist/components/composed/forms/DatePickerTextField.svelte.d.ts +63 -67
- package/dist/components/composed/forms/Dropdown.svelte +21 -51
- package/dist/components/composed/forms/Dropdown.svelte.d.ts +43 -48
- package/dist/components/composed/forms/IconsDropdown.svelte +33 -61
- package/dist/components/composed/forms/IconsDropdown.svelte.d.ts +26 -30
- package/dist/components/composed/forms/LabelAndSelect.svelte +7 -32
- package/dist/components/composed/forms/LabelAndSelect.svelte.d.ts +31 -35
- package/dist/components/composed/forms/LabelAndTextField.svelte +5 -30
- package/dist/components/composed/forms/LabelAndTextField.svelte.d.ts +42 -46
- package/dist/components/composed/forms/ToggleList.svelte +33 -59
- package/dist/components/composed/forms/ToggleList.svelte.d.ts +17 -21
- package/dist/components/composed/forms/YearPickerTextField.svelte +74 -114
- package/dist/components/composed/forms/YearPickerTextField.svelte.d.ts +49 -53
- package/dist/components/composed/list/DynamicTable.svelte +707 -1102
- package/dist/components/composed/list/DynamicTable.svelte.d.ts +365 -369
- package/dist/components/composed/list/PaginatedTable.svelte +76 -139
- package/dist/components/composed/list/PaginatedTable.svelte.d.ts +108 -108
- package/dist/components/composed/progress/HorizontalStackedProgress.svelte +30 -58
- package/dist/components/composed/progress/HorizontalStackedProgress.svelte.d.ts +21 -25
- package/dist/components/composed/search/DynamicFilters.svelte +82 -103
- package/dist/components/composed/search/DynamicFilters.svelte.d.ts +27 -31
- package/dist/components/composed/search/FilterEditor.svelte +77 -106
- package/dist/components/composed/search/FilterEditor.svelte.d.ts +33 -37
- package/dist/components/composed/search/Filters.svelte +292 -361
- package/dist/components/composed/search/Filters.svelte.d.ts +51 -55
- package/dist/components/composed/search/GlobalSearchTextField.svelte +41 -79
- package/dist/components/composed/search/GlobalSearchTextField.svelte.d.ts +39 -43
- package/dist/components/composed/search/MobileFilterEditor.svelte +93 -135
- package/dist/components/composed/search/MobileFilterEditor.svelte.d.ts +35 -39
- package/dist/components/composed/search/SearchBar.svelte +5 -28
- package/dist/components/composed/search/SearchBar.svelte.d.ts +30 -34
- package/dist/components/composed/search/SearchResults.svelte +7 -42
- package/dist/components/composed/search/SearchResults.svelte.d.ts +36 -40
- package/dist/components/composed/shop/ProductCard.svelte +4 -18
- package/dist/components/composed/shop/ProductCard.svelte.d.ts +28 -32
- package/dist/components/composed/shop/ProductsGrid.svelte +2 -22
- package/dist/components/composed/shop/ProductsGrid.svelte.d.ts +40 -44
- package/dist/components/layouts/CollapsibleSideBarLayout.svelte +38 -77
- package/dist/components/layouts/CollapsibleSideBarLayout.svelte.d.ts +69 -109
- package/dist/components/layouts/StableDividedSideBarLayout.svelte +17 -47
- package/dist/components/layouts/StableDividedSideBarLayout.svelte.d.ts +32 -50
- package/dist/components/layouts/UnstableDividedSideBarLayout.svelte +30 -53
- package/dist/components/layouts/UnstableDividedSideBarLayout.svelte.d.ts +63 -103
- package/dist/components/simple/buttons/Button.svelte +32 -78
- package/dist/components/simple/buttons/Button.svelte.d.ts +35 -47
- package/dist/components/simple/buttons/LinkButton.svelte +22 -54
- package/dist/components/simple/buttons/LinkButton.svelte.d.ts +33 -50
- package/dist/components/simple/charts/GanymedeBarChart.svelte +134 -172
- package/dist/components/simple/charts/GanymedeBarChart.svelte.d.ts +46 -50
- package/dist/components/simple/charts/GanymedeLineChart.svelte +115 -157
- package/dist/components/simple/charts/GanymedeLineChart.svelte.d.ts +47 -51
- package/dist/components/simple/charts/GanymedePieChart.svelte +39 -62
- package/dist/components/simple/charts/GanymedePieChart.svelte.d.ts +33 -37
- package/dist/components/simple/common/Card.svelte +1 -20
- package/dist/components/simple/common/Card.svelte.d.ts +38 -51
- package/dist/components/simple/common/CollapsibleDivider.svelte +11 -23
- package/dist/components/simple/common/CollapsibleDivider.svelte.d.ts +25 -29
- package/dist/components/simple/common/Divider.svelte +2 -8
- package/dist/components/simple/common/Divider.svelte.d.ts +19 -23
- package/dist/components/simple/common/Gesture.svelte +46 -64
- package/dist/components/simple/common/Gesture.svelte.d.ts +17 -21
- package/dist/components/simple/common/InfiniteScroll.svelte +29 -52
- package/dist/components/simple/common/InfiniteScroll.svelte.d.ts +20 -24
- package/dist/components/simple/common/IntersectionObserver.svelte +32 -45
- package/dist/components/simple/common/IntersectionObserver.svelte.d.ts +21 -34
- package/dist/components/simple/common/MediaQuery.svelte +21 -30
- package/dist/components/simple/common/MediaQuery.svelte.d.ts +30 -34
- package/dist/components/simple/common/Menu.svelte +201 -290
- package/dist/components/simple/common/Menu.svelte.d.ts +40 -51
- package/dist/components/simple/common/Playground.svelte +17 -18
- package/dist/components/simple/common/Playground.svelte.d.ts +15 -19
- package/dist/components/simple/common/VerticalDraggableList.svelte +16 -35
- package/dist/components/simple/common/VerticalDraggableList.svelte.d.ts +29 -33
- package/dist/components/simple/dashboards/DashboardGridShaper.svelte +26 -32
- package/dist/components/simple/dashboards/DashboardGridShaper.svelte.d.ts +12 -16
- package/dist/components/simple/dates/Calendar.svelte +28 -52
- package/dist/components/simple/dates/Calendar.svelte.d.ts +41 -45
- package/dist/components/simple/dates/DatePicker.svelte +60 -90
- package/dist/components/simple/dates/DatePicker.svelte.d.ts +40 -44
- package/dist/components/simple/dates/MonthSelector.svelte +15 -37
- package/dist/components/simple/dates/MonthSelector.svelte.d.ts +31 -35
- package/dist/components/simple/dates/TimePicker.svelte +31 -45
- package/dist/components/simple/dates/TimePicker.svelte.d.ts +20 -24
- package/dist/components/simple/dates/TimePickerTextField.svelte +35 -56
- package/dist/components/simple/dates/TimePickerTextField.svelte.d.ts +24 -28
- package/dist/components/simple/dates/YearSelector.svelte +29 -54
- package/dist/components/simple/dates/YearSelector.svelte.d.ts +31 -35
- package/dist/components/simple/dialogs/Dialog.svelte +62 -92
- package/dist/components/simple/dialogs/Dialog.svelte.d.ts +28 -42
- package/dist/components/simple/forms/Autocomplete.svelte +142 -201
- package/dist/components/simple/forms/Autocomplete.svelte.d.ts +79 -83
- package/dist/components/simple/forms/Checkbox.svelte +24 -40
- package/dist/components/simple/forms/Checkbox.svelte.d.ts +21 -25
- package/dist/components/simple/forms/FileInput.svelte +48 -88
- package/dist/components/simple/forms/FileInput.svelte.d.ts +33 -37
- package/dist/components/simple/forms/FileInputList.svelte +34 -52
- package/dist/components/simple/forms/FileInputList.svelte.d.ts +39 -43
- package/dist/components/simple/forms/RadioButton.svelte +3 -11
- package/dist/components/simple/forms/RadioButton.svelte.d.ts +27 -31
- package/dist/components/simple/forms/Select.svelte +3 -16
- package/dist/components/simple/forms/Select.svelte.d.ts +20 -24
- package/dist/components/simple/forms/SimpleTextField.svelte +6 -53
- package/dist/components/simple/forms/SimpleTextField.svelte.d.ts +60 -64
- package/dist/components/simple/forms/Switch.svelte +16 -30
- package/dist/components/simple/forms/Switch.svelte.d.ts +21 -25
- package/dist/components/simple/forms/Textarea.svelte +2 -27
- package/dist/components/simple/forms/Textarea.svelte.d.ts +37 -41
- package/dist/components/simple/forms/Textfield.svelte +18 -56
- package/dist/components/simple/forms/Textfield.svelte.d.ts +51 -55
- package/dist/components/simple/forms/TreeEditor.svelte +95 -141
- package/dist/components/simple/forms/TreeEditor.svelte.d.ts +38 -42
- package/dist/components/simple/forms/TreeEditorItem.svelte +42 -77
- package/dist/components/simple/forms/TreeEditorItem.svelte.d.ts +50 -54
- package/dist/components/simple/forms/VerticalSwitch.svelte +1 -11
- package/dist/components/simple/forms/VerticalSwitch.svelte.d.ts +28 -32
- package/dist/components/simple/forms/VerticalTextSwitch.svelte +3 -15
- package/dist/components/simple/forms/VerticalTextSwitch.svelte.d.ts +26 -30
- package/dist/components/simple/lists/ColorInvertedSelector.svelte +23 -53
- package/dist/components/simple/lists/ColorInvertedSelector.svelte.d.ts +42 -46
- package/dist/components/simple/lists/HierarchyMenu.svelte +19 -38
- package/dist/components/simple/lists/HierarchyMenu.svelte.d.ts +30 -34
- package/dist/components/simple/lists/Paginator.svelte +41 -50
- package/dist/components/simple/lists/Paginator.svelte.d.ts +19 -23
- package/dist/components/simple/lists/SelectableMenuList.svelte +15 -43
- package/dist/components/simple/lists/SelectableMenuList.svelte.d.ts +20 -24
- package/dist/components/simple/lists/SelectableVerticalList.svelte +57 -99
- package/dist/components/simple/lists/SelectableVerticalList.svelte.d.ts +47 -51
- package/dist/components/simple/lists/SidebarMenuList.svelte +70 -115
- package/dist/components/simple/lists/SidebarMenuList.svelte.d.ts +22 -26
- package/dist/components/simple/lists/SimpleTable.svelte +154 -264
- package/dist/components/simple/lists/SimpleTable.svelte.d.ts +66 -70
- package/dist/components/simple/loaders/CircularLoader.svelte +5 -16
- package/dist/components/simple/loaders/CircularLoader.svelte.d.ts +15 -19
- package/dist/components/simple/loaders/Skeleton.svelte +2 -3
- package/dist/components/simple/loaders/Skeleton.svelte.d.ts +12 -16
- package/dist/components/simple/media/AttachmentDownloader.svelte +3 -17
- package/dist/components/simple/media/AttachmentDownloader.svelte.d.ts +28 -32
- package/dist/components/simple/media/Avatar.svelte +12 -18
- package/dist/components/simple/media/Avatar.svelte.d.ts +20 -31
- package/dist/components/simple/media/Carousel.svelte +11 -29
- package/dist/components/simple/media/Carousel.svelte.d.ts +24 -28
- package/dist/components/simple/media/DescriptiveAvatar.svelte +4 -12
- package/dist/components/simple/media/DescriptiveAvatar.svelte.d.ts +28 -44
- package/dist/components/simple/media/FlagIcon.svelte +5 -8
- package/dist/components/simple/media/FlagIcon.svelte.d.ts +15 -19
- package/dist/components/simple/media/Gallery.svelte +29 -49
- package/dist/components/simple/media/Gallery.svelte.d.ts +23 -27
- package/dist/components/simple/media/Icon.svelte +4 -9
- package/dist/components/simple/media/Icon.svelte.d.ts +20 -24
- package/dist/components/simple/media/Image.svelte +20 -42
- package/dist/components/simple/media/Image.svelte.d.ts +33 -44
- package/dist/components/simple/media/ImageGrid.svelte +12 -37
- package/dist/components/simple/media/ImageGrid.svelte.d.ts +28 -32
- package/dist/components/simple/navigation/Breadcrumb.svelte +10 -28
- package/dist/components/simple/navigation/Breadcrumb.svelte.d.ts +22 -26
- package/dist/components/simple/navigation/Chip.svelte +23 -44
- package/dist/components/simple/navigation/Chip.svelte.d.ts +31 -42
- package/dist/components/simple/navigation/Drawer.svelte +65 -107
- package/dist/components/simple/navigation/Drawer.svelte.d.ts +37 -50
- package/dist/components/simple/navigation/HeaderMenu.svelte +23 -40
- package/dist/components/simple/navigation/HeaderMenu.svelte.d.ts +35 -39
- package/dist/components/simple/navigation/Navigator.svelte +8 -30
- package/dist/components/simple/navigation/Navigator.svelte.d.ts +24 -28
- package/dist/components/simple/navigation/TabSwitcher.svelte +47 -83
- package/dist/components/simple/navigation/TabSwitcher.svelte.d.ts +34 -38
- package/dist/components/simple/notifiers/AlertBanner.svelte +15 -43
- package/dist/components/simple/notifiers/AlertBanner.svelte.d.ts +37 -41
- package/dist/components/simple/progress/ProgressBar.svelte +13 -20
- package/dist/components/simple/progress/ProgressBar.svelte.d.ts +17 -21
- package/dist/components/simple/timeline/SimpleTimeLine.svelte +5 -19
- package/dist/components/simple/timeline/SimpleTimeLine.svelte.d.ts +35 -39
- package/dist/components/simple/typography/Code.svelte +12 -27
- package/dist/components/simple/typography/Code.svelte.d.ts +24 -28
- package/dist/stores/debounce.d.ts +1 -0
- package/dist/stores/layouts/unstableSidebarOpened.d.ts +1 -0
- package/dist/stores/mediaQuery.d.ts +1 -0
- package/dist/stores/theme.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { SvelteComponent } from "svelte";
|
|
1
2
|
export type ArrayElement<ArrayType extends readonly unknown[]> = ArrayType extends readonly (infer ElementType)[] ? ElementType : never;
|
|
2
3
|
export type LabelMapper = {
|
|
3
4
|
[label: string]: {
|
|
@@ -9,61 +10,56 @@ import './Filters.css';
|
|
|
9
10
|
import '../../../css/main.css';
|
|
10
11
|
import { type DateMode, type Filter, type NumberMode, type SelectMode, type StringMode } from '../../../utils/filters/filters';
|
|
11
12
|
import type { Locale } from '../../simple/dates/utils';
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
13
|
+
declare const __propDef: {
|
|
14
|
+
props: {
|
|
15
|
+
filters?: Filter[] | undefined;
|
|
16
|
+
lang?: "it" | "en" | undefined;
|
|
17
|
+
addFilterLabel?: string | undefined;
|
|
18
|
+
cancelFilterLabel?: string | undefined;
|
|
19
|
+
applyFilterLabel?: string | undefined;
|
|
20
|
+
showActiveFilters?: boolean | undefined;
|
|
21
|
+
filterTitleLabel?: string | undefined;
|
|
22
|
+
dateLocale?: Locale | undefined;
|
|
23
|
+
betweenSeparator?: string | undefined;
|
|
24
|
+
trueString?: string | undefined;
|
|
25
|
+
falseString?: string | undefined;
|
|
26
|
+
editFilterMode?: "one-edit" | "multi-edit" | undefined;
|
|
27
|
+
labelsMapper?: LabelMapper | undefined;
|
|
22
28
|
};
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
betweenSeparator?: string;
|
|
35
|
-
trueString?: string;
|
|
36
|
-
falseString?: string;
|
|
37
|
-
editFilterMode?: "one-edit" | "multi-edit";
|
|
38
|
-
labelsMapper?: LabelMapper;
|
|
39
|
-
}, {
|
|
40
|
-
click: MouseEvent;
|
|
41
|
-
keydown: KeyboardEvent;
|
|
42
|
-
addFilterClick: CustomEvent<undefined>;
|
|
43
|
-
applyFilter: CustomEvent<undefined>;
|
|
44
|
-
removeFilter: CustomEvent<{
|
|
45
|
-
filter: Filter;
|
|
46
|
-
}>;
|
|
47
|
-
removeAllFilters: CustomEvent<undefined>;
|
|
48
|
-
} & {
|
|
49
|
-
[evt: string]: CustomEvent<any>;
|
|
50
|
-
}, {
|
|
51
|
-
'custom-chip': {
|
|
52
|
-
filter: Filter;
|
|
53
|
-
};
|
|
54
|
-
append: {};
|
|
55
|
-
custom: {
|
|
56
|
-
slot: string;
|
|
57
|
-
updateFunction: (filterName: string, newValue: any, newValid: boolean) => void;
|
|
58
|
-
mAndDown: boolean;
|
|
59
|
-
filter: Filter;
|
|
29
|
+
events: {
|
|
30
|
+
click: MouseEvent;
|
|
31
|
+
keydown: KeyboardEvent;
|
|
32
|
+
addFilterClick: CustomEvent<undefined>;
|
|
33
|
+
applyFilter: CustomEvent<undefined>;
|
|
34
|
+
removeFilter: CustomEvent<{
|
|
35
|
+
filter: Filter;
|
|
36
|
+
}>;
|
|
37
|
+
removeAllFilters: CustomEvent<undefined>;
|
|
38
|
+
} & {
|
|
39
|
+
[evt: string]: CustomEvent<any>;
|
|
60
40
|
};
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
41
|
+
slots: {
|
|
42
|
+
'custom-chip': {
|
|
43
|
+
filter: Filter;
|
|
44
|
+
};
|
|
45
|
+
append: {};
|
|
46
|
+
custom: {
|
|
47
|
+
slot: string;
|
|
48
|
+
updateFunction: (filterName: string, newValue: any, newValid: boolean) => void;
|
|
49
|
+
mAndDown: boolean;
|
|
50
|
+
filter: Filter;
|
|
51
|
+
};
|
|
52
|
+
content: {
|
|
53
|
+
mAndDown: boolean;
|
|
54
|
+
updateMultiFilterValues: (filterName: string, newValue: any, newValid: boolean, mode?: NumberMode | StringMode | SelectMode | DateMode) => void;
|
|
55
|
+
handleRemoveAllFilters: (e?: MouseEvent) => void;
|
|
56
|
+
filters: Filter[];
|
|
57
|
+
};
|
|
66
58
|
};
|
|
67
|
-
}
|
|
68
|
-
type
|
|
69
|
-
export
|
|
59
|
+
};
|
|
60
|
+
export type FiltersProps = typeof __propDef.props;
|
|
61
|
+
export type FiltersEvents = typeof __propDef.events;
|
|
62
|
+
export type FiltersSlots = typeof __propDef.slots;
|
|
63
|
+
export default class Filters extends SvelteComponent<FiltersProps, FiltersEvents, FiltersSlots> {
|
|
64
|
+
}
|
|
65
|
+
export {};
|
|
@@ -1,83 +1,45 @@
|
|
|
1
|
-
<script
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
/*
|
|
18
|
-
Styles:
|
|
19
|
-
|
|
20
|
-
--global-search-text-field-ring-color
|
|
21
|
-
--global-search-text-field-hover-ring-color
|
|
22
|
-
--global-search-text-field-color
|
|
23
|
-
--global-search-text-field-width
|
|
24
|
-
--global-search-text-field-max-width
|
|
25
|
-
--global-search-text-field-height
|
|
26
|
-
--global-search-text-field-background-color
|
|
27
|
-
--global-search-text-field-padding
|
|
28
|
-
--global-search-text-field-font-size
|
|
29
|
-
*/
|
|
30
|
-
|
|
31
|
-
export let searchButtonText: string = "Search",
|
|
32
|
-
searchDialogOpened: boolean = false,
|
|
33
|
-
transitionDuration: string = ".8s",
|
|
34
|
-
searcher: (params: { searchText: string }) => Promise<Result[] | undefined> = () => Promise.resolve([])
|
|
35
|
-
|
|
36
|
-
let searchBarInput: HTMLElement,
|
|
37
|
-
searchText: string | undefined = undefined,
|
|
38
|
-
searchResults: Result[] | undefined = undefined,
|
|
39
|
-
searchLoading: boolean = false,
|
|
40
|
-
searchBarFocused: boolean = false
|
|
41
|
-
|
|
42
|
-
let dispatch = createEventDispatcher<{
|
|
43
|
-
'toggle-search-dialog': {
|
|
44
|
-
opened: boolean
|
|
45
|
-
}
|
|
46
|
-
}>()
|
|
47
|
-
|
|
48
|
-
onMount(() => {
|
|
49
|
-
let handler: CallbackFunction = (params) => {
|
|
50
|
-
if((params.meta || params.ctrl) && params.key == 'k') {
|
|
51
|
-
toggleSearchDialog()
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
Keyboarder.on(handler)
|
|
56
|
-
|
|
57
|
-
return () => {
|
|
58
|
-
Keyboarder.off(handler)
|
|
59
|
-
}
|
|
60
|
-
})
|
|
61
|
-
|
|
62
|
-
function handleKeydown(event: KeyboardEvent) {
|
|
63
|
-
if(event.key == 'ArrowDown' || event.key == 'ArrowUp') event.preventDefault()
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
function toggleSearchDialog() {
|
|
67
|
-
searchDialogOpened = !searchDialogOpened
|
|
68
|
-
if(searchDialogOpened) searchBarInput.focus()
|
|
69
|
-
dispatch('toggle-search-dialog', { opened: searchDialogOpened })
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
async function search() {
|
|
73
|
-
if(!!searchText) {
|
|
74
|
-
searchLoading = true
|
|
75
|
-
searchResults = await searcher({
|
|
76
|
-
searchText
|
|
77
|
-
})
|
|
78
|
-
searchLoading = false
|
|
79
|
-
}
|
|
1
|
+
<script>import "../../../css/main.css";
|
|
2
|
+
import "./GlobalSearchTextField.css";
|
|
3
|
+
import Dialog from "../../simple/dialogs/Dialog.svelte";
|
|
4
|
+
import { createEventDispatcher, onMount } from "svelte";
|
|
5
|
+
import SearchBar from "./SearchBar.svelte";
|
|
6
|
+
import Keyboarder, {} from "../../../utils/keyboarder";
|
|
7
|
+
import SearchResults, {} from "./SearchResults.svelte";
|
|
8
|
+
let clazz = {};
|
|
9
|
+
export { clazz as class };
|
|
10
|
+
export let searchButtonText = "Search", searchDialogOpened = false, transitionDuration = ".8s", searcher = () => Promise.resolve([]);
|
|
11
|
+
let searchBarInput, searchText = void 0, searchResults = void 0, searchLoading = false, searchBarFocused = false;
|
|
12
|
+
let dispatch = createEventDispatcher();
|
|
13
|
+
onMount(() => {
|
|
14
|
+
let handler = (params) => {
|
|
15
|
+
if ((params.meta || params.ctrl) && params.key == "k") {
|
|
16
|
+
toggleSearchDialog();
|
|
80
17
|
}
|
|
18
|
+
};
|
|
19
|
+
Keyboarder.on(handler);
|
|
20
|
+
return () => {
|
|
21
|
+
Keyboarder.off(handler);
|
|
22
|
+
};
|
|
23
|
+
});
|
|
24
|
+
function handleKeydown(event) {
|
|
25
|
+
if (event.key == "ArrowDown" || event.key == "ArrowUp")
|
|
26
|
+
event.preventDefault();
|
|
27
|
+
}
|
|
28
|
+
function toggleSearchDialog() {
|
|
29
|
+
searchDialogOpened = !searchDialogOpened;
|
|
30
|
+
if (searchDialogOpened)
|
|
31
|
+
searchBarInput.focus();
|
|
32
|
+
dispatch("toggle-search-dialog", { opened: searchDialogOpened });
|
|
33
|
+
}
|
|
34
|
+
async function search() {
|
|
35
|
+
if (!!searchText) {
|
|
36
|
+
searchLoading = true;
|
|
37
|
+
searchResults = await searcher({
|
|
38
|
+
searchText
|
|
39
|
+
});
|
|
40
|
+
searchLoading = false;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
81
43
|
</script>
|
|
82
44
|
|
|
83
45
|
<div class={clazz.container || ''}>
|
|
@@ -1,49 +1,45 @@
|
|
|
1
|
+
import { SvelteComponent } from "svelte";
|
|
1
2
|
import '../../../css/main.css';
|
|
2
3
|
import './GlobalSearchTextField.css';
|
|
3
4
|
import { type Result } from './SearchResults.svelte';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
5
|
+
declare const __propDef: {
|
|
6
|
+
props: {
|
|
7
|
+
class?: {
|
|
8
|
+
container?: string | undefined;
|
|
9
|
+
button?: string | undefined;
|
|
10
|
+
shortcut?: string | undefined;
|
|
11
|
+
} | undefined;
|
|
12
|
+
searchButtonText?: string | undefined;
|
|
13
|
+
searchDialogOpened?: boolean | undefined;
|
|
14
|
+
transitionDuration?: string | undefined;
|
|
15
|
+
searcher?: ((params: {
|
|
16
|
+
searchText: string;
|
|
17
|
+
}) => Promise<Result[] | undefined>) | undefined;
|
|
14
18
|
};
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
events: {
|
|
20
|
+
select: CustomEvent<{
|
|
21
|
+
element: import("../../simple/lists/SelectableVerticalList.svelte").Element;
|
|
22
|
+
}>;
|
|
23
|
+
'toggle-search-dialog': CustomEvent<{
|
|
24
|
+
opened: boolean;
|
|
25
|
+
}>;
|
|
26
|
+
} & {
|
|
27
|
+
[evt: string]: CustomEvent<any>;
|
|
22
28
|
};
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
}>;
|
|
33
|
-
'toggle-search-dialog': CustomEvent<{
|
|
34
|
-
opened: boolean;
|
|
35
|
-
}>;
|
|
36
|
-
} & {
|
|
37
|
-
[evt: string]: CustomEvent<any>;
|
|
38
|
-
}, {
|
|
39
|
-
'search-button': {
|
|
40
|
-
toggleSearchDialog: () => void;
|
|
29
|
+
slots: {
|
|
30
|
+
'search-button': {
|
|
31
|
+
toggleSearchDialog: () => void;
|
|
32
|
+
};
|
|
33
|
+
'search-button-icon': {};
|
|
34
|
+
'search-button-text': {};
|
|
35
|
+
'search-button-shortcut': {};
|
|
36
|
+
'search-bar': {};
|
|
37
|
+
'search-results': {};
|
|
41
38
|
};
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
export default GlobalSearchTextField;
|
|
39
|
+
};
|
|
40
|
+
export type GlobalSearchTextFieldProps = typeof __propDef.props;
|
|
41
|
+
export type GlobalSearchTextFieldEvents = typeof __propDef.events;
|
|
42
|
+
export type GlobalSearchTextFieldSlots = typeof __propDef.slots;
|
|
43
|
+
export default class GlobalSearchTextField extends SvelteComponent<GlobalSearchTextFieldProps, GlobalSearchTextFieldEvents, GlobalSearchTextFieldSlots> {
|
|
44
|
+
}
|
|
45
|
+
export {};
|
|
@@ -1,158 +1,116 @@
|
|
|
1
|
-
<script
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
labelsMapper: LabelMapper,
|
|
24
|
-
forceApplyValid: boolean = false,
|
|
25
|
-
tmpFilter: Filter | undefined = undefined
|
|
26
|
-
|
|
27
|
-
let dispatch = createEventDispatcher<{
|
|
28
|
-
'backClick': undefined,
|
|
29
|
-
'cancelClick': undefined
|
|
30
|
-
}>()
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
// function handleApplyFilterClick() {
|
|
34
|
-
// if(!!filter && !!tmpFilter) {
|
|
35
|
-
// filter = {...tmpFilter}
|
|
36
|
-
// filter.active = true
|
|
37
|
-
// dispatch('apply')
|
|
38
|
-
// }
|
|
39
|
-
// }
|
|
40
|
-
|
|
41
|
-
let step: 'advanced' | 'editor'
|
|
42
|
-
|
|
43
|
-
function initTmpFilter() {
|
|
44
|
-
tmpFilter = filter === undefined ? undefined : {...filter}
|
|
45
|
-
if(!!tmpFilter && tmpFilter.advanced) {
|
|
46
|
-
if(['string', 'number', 'date', 'select'].includes(tmpFilter.type) && Object.keys(tmpFilter).includes('mode')) {
|
|
47
|
-
//@ts-ignore
|
|
48
|
-
if((tmpFilter.mode == 'between' && tmpFilter.from !== undefined && tmpFilter.to !== undefined) || tmpFilter.value !== undefined || (tmpFilter.type == 'select' && tmpFilter.values !== undefined && tmpFilter.values.length > 0)) {
|
|
49
|
-
step = 'editor'
|
|
50
|
-
//@ts-ignore
|
|
51
|
-
advancedModeSelectedOption = tmpFilter.mode
|
|
52
|
-
} else {
|
|
53
|
-
step = 'advanced'
|
|
54
|
-
}
|
|
1
|
+
<script>import { GENERIC_MODES, SELECT_MODES, STRING_MODES } from "../../../utils/filters/filters";
|
|
2
|
+
import SimpleTextField from "../../simple/forms/SimpleTextField.svelte";
|
|
3
|
+
import DatePickerTextField from "../forms/DatePickerTextField.svelte";
|
|
4
|
+
import Button from "../../simple/buttons/Button.svelte";
|
|
5
|
+
import { createEventDispatcher } from "svelte";
|
|
6
|
+
import Validator from "../../../utils/filters/validator";
|
|
7
|
+
import SelectableVerticalList, {} from "../../simple/lists/SelectableVerticalList.svelte";
|
|
8
|
+
import Icon from "../../simple/media/Icon.svelte";
|
|
9
|
+
import { fly } from "svelte/transition";
|
|
10
|
+
import Autocomplete from "../../simple/forms/Autocomplete.svelte";
|
|
11
|
+
import Checkbox from "../../simple/forms/Checkbox.svelte";
|
|
12
|
+
import ToggleList from "../forms/ToggleList.svelte";
|
|
13
|
+
export let filter = void 0, lang = "en", backIcon = "mdi-arrow-left", betweenFromLabel = lang == "en" ? "From" : "Da", betweenToLabel = lang == "en" ? "To" : "A", labelsMapper, forceApplyValid = false, tmpFilter = void 0;
|
|
14
|
+
let dispatch = createEventDispatcher();
|
|
15
|
+
let step;
|
|
16
|
+
function initTmpFilter() {
|
|
17
|
+
tmpFilter = filter === void 0 ? void 0 : { ...filter };
|
|
18
|
+
if (!!tmpFilter && tmpFilter.advanced) {
|
|
19
|
+
if (["string", "number", "date", "select"].includes(tmpFilter.type) && Object.keys(tmpFilter).includes("mode")) {
|
|
20
|
+
if (tmpFilter.mode == "between" && tmpFilter.from !== void 0 && tmpFilter.to !== void 0 || tmpFilter.value !== void 0 || tmpFilter.type == "select" && tmpFilter.values !== void 0 && tmpFilter.values.length > 0) {
|
|
21
|
+
step = "editor";
|
|
22
|
+
advancedModeSelectedOption = tmpFilter.mode;
|
|
55
23
|
} else {
|
|
56
|
-
step =
|
|
24
|
+
step = "advanced";
|
|
57
25
|
}
|
|
58
26
|
} else {
|
|
59
|
-
step = "
|
|
27
|
+
step = "advanced";
|
|
60
28
|
}
|
|
29
|
+
} else {
|
|
30
|
+
step = "editor";
|
|
61
31
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
initTmpFilter()
|
|
32
|
+
}
|
|
33
|
+
$:
|
|
34
|
+
if (!!filter) {
|
|
35
|
+
initTmpFilter();
|
|
66
36
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
modes = GENERIC_MODES
|
|
80
|
-
} else if(tmpFilter.type == 'select') {
|
|
81
|
-
modes = SELECT_MODES
|
|
37
|
+
let advancedModeOptions, advancedModeSelectedOption;
|
|
38
|
+
$:
|
|
39
|
+
if (!!tmpFilter) {
|
|
40
|
+
let modes;
|
|
41
|
+
if (tmpFilter.type == "string") {
|
|
42
|
+
modes = STRING_MODES;
|
|
43
|
+
} else if (tmpFilter.type == "date") {
|
|
44
|
+
modes = GENERIC_MODES;
|
|
45
|
+
} else if (tmpFilter.type == "number") {
|
|
46
|
+
modes = GENERIC_MODES;
|
|
47
|
+
} else if (tmpFilter.type == "select") {
|
|
48
|
+
modes = SELECT_MODES;
|
|
82
49
|
}
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
advancedModeOptions = modes.map(mode => {
|
|
50
|
+
if (!!modes) {
|
|
51
|
+
advancedModeOptions = modes.map((mode) => {
|
|
86
52
|
return {
|
|
87
53
|
title: labelsMapper[mode].short || mode,
|
|
88
54
|
name: mode
|
|
89
|
-
}
|
|
90
|
-
})
|
|
55
|
+
};
|
|
56
|
+
});
|
|
91
57
|
}
|
|
92
|
-
|
|
93
58
|
}
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
advancedModeSelectedOption =
|
|
59
|
+
$:
|
|
60
|
+
if (!tmpFilter?.advanced) {
|
|
61
|
+
advancedModeSelectedOption = void 0;
|
|
97
62
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
step = 'editor'
|
|
113
|
-
canRenderOptions = false
|
|
114
|
-
}
|
|
63
|
+
let calendarOpened = false, calendarOpened2 = false;
|
|
64
|
+
function handleAdvancedModeSelection() {
|
|
65
|
+
if (!!advancedModeSelectedOption && !!tmpFilter) {
|
|
66
|
+
if (tmpFilter.type == "date")
|
|
67
|
+
tmpFilter.mode = advancedModeSelectedOption;
|
|
68
|
+
else if (tmpFilter.type == "string")
|
|
69
|
+
tmpFilter.mode = advancedModeSelectedOption;
|
|
70
|
+
else if (tmpFilter.type == "number")
|
|
71
|
+
tmpFilter.mode = advancedModeSelectedOption;
|
|
72
|
+
else if (tmpFilter.type == "select")
|
|
73
|
+
tmpFilter.mode = advancedModeSelectedOption;
|
|
74
|
+
step = "editor";
|
|
75
|
+
canRenderOptions = false;
|
|
115
76
|
}
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
tmpFilter.value = false
|
|
77
|
+
}
|
|
78
|
+
let canRenderOptions = true;
|
|
79
|
+
$:
|
|
80
|
+
applyFilterDisabled = !Validator.isValid(tmpFilter) && !forceApplyValid;
|
|
81
|
+
$:
|
|
82
|
+
if (!!tmpFilter && tmpFilter.type == "bool") {
|
|
83
|
+
if (tmpFilter.value === void 0) {
|
|
84
|
+
tmpFilter.value = false;
|
|
125
85
|
}
|
|
126
86
|
}
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
if(tmpFilter.values ===
|
|
130
|
-
tmpFilter.values = []
|
|
87
|
+
$:
|
|
88
|
+
if (!!tmpFilter && tmpFilter.type == "select") {
|
|
89
|
+
if (tmpFilter.values === void 0) {
|
|
90
|
+
tmpFilter.values = [];
|
|
131
91
|
}
|
|
132
92
|
}
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
93
|
+
function handleModeBackClick() {
|
|
94
|
+
dispatch("backClick");
|
|
95
|
+
}
|
|
96
|
+
function handleEditorBackCLick() {
|
|
97
|
+
if (!!tmpFilter && !tmpFilter.advanced) {
|
|
98
|
+
dispatch("backClick");
|
|
99
|
+
} else {
|
|
100
|
+
step = "advanced";
|
|
101
|
+
advancedModeSelectedOption = void 0;
|
|
102
|
+
setTimeout(() => {
|
|
103
|
+
canRenderOptions = true;
|
|
104
|
+
}, 100);
|
|
136
105
|
}
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
setTimeout(() => {
|
|
145
|
-
canRenderOptions = true
|
|
146
|
-
}, 100)
|
|
147
|
-
}
|
|
106
|
+
}
|
|
107
|
+
$:
|
|
108
|
+
if (!!tmpFilter && tmpFilter.type == "date" && tmpFilter.mode == "between") {
|
|
109
|
+
if (!tmpFilter.from)
|
|
110
|
+
tmpFilter.from = /* @__PURE__ */ new Date();
|
|
111
|
+
if (!tmpFilter.to)
|
|
112
|
+
tmpFilter.to = /* @__PURE__ */ new Date();
|
|
148
113
|
}
|
|
149
|
-
|
|
150
|
-
$: if(!!tmpFilter && tmpFilter.type == 'date' && tmpFilter.mode == 'between') {
|
|
151
|
-
if(!tmpFilter.from) tmpFilter.from = new Date()
|
|
152
|
-
if(!tmpFilter.to) tmpFilter.to = new Date()
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
|
|
156
114
|
</script>
|
|
157
115
|
|
|
158
116
|
<div class="container">
|