From a5c614b1ab9554e3b177f387c30c9b86d4d70b0e Mon Sep 17 00:00:00 2001 From: Mats Johansen Date: Fri, 6 Sep 2024 10:08:57 +0200 Subject: [PATCH] feat(date picker): add date picker component change behaviour of number input: now adding seperate dates instead of having all dates be the same in all search bars --- .../catalogue/DataTreeElement.svelte | 54 +---------- .../catalogue/DatePickerComponent.svelte | 94 +++++++++++++++++++ .../catalogue/NumberInputComponent.svelte | 63 ++----------- packages/lib/src/stores/catalogue.ts | 3 - packages/lib/src/styles/catalogue.css | 43 ++++++++- packages/lib/src/types/ast.ts | 2 +- 6 files changed, 151 insertions(+), 108 deletions(-) create mode 100644 packages/lib/src/components/catalogue/DatePickerComponent.svelte diff --git a/packages/lib/src/components/catalogue/DataTreeElement.svelte b/packages/lib/src/components/catalogue/DataTreeElement.svelte index 2babe872..85fabf08 100644 --- a/packages/lib/src/components/catalogue/DataTreeElement.svelte +++ b/packages/lib/src/components/catalogue/DataTreeElement.svelte @@ -6,10 +6,11 @@ import AutocompleteComponent from "./AutoCompleteComponent.svelte"; import SingleSelectComponent from "./SingleSelectComponent.svelte"; import { v4 as uuidv4 } from "uuid"; - import { activeNumberInputs, openTreeNodes } from "../../stores/catalogue"; + import { openTreeNodes } from "../../stores/catalogue"; import type { QueryItem } from "../../types/queryData"; import { iconStore } from "../../stores/icons"; import InfoButtonComponent from "../buttons/InfoButtonComponent.wc.svelte"; + import DatePickerComponent from "./DatePickerComponent.svelte"; export let element: Category; const subCategoryName: string | null = @@ -100,45 +101,6 @@ typeof element.fieldType === "string" && element.fieldType == "single-select")); - /** - * watches the number input store to update the number input components - */ - $: numberInput = $activeNumberInputs.find( - (item) => item.key === element.key, - ); - - /** - * adds the number input to the store if it is not already in the store - * @param store - * @returns updated store - */ - activeNumberInputs.update((store: QueryItem[]): QueryItem[] => { - if ( - "fieldType" in element && - element.fieldType === "number" && - !store.find((item) => item.key === element.key) - ) { - return [ - ...store, - { - id: uuidv4(), - key: element.key, - name: element.name, - system: "system" in element ? element.system : "", - type: "type" in element ? element.type : "", - values: [ - { - name: "0", - value: { min: 0, max: 0 }, - queryBindId: uuidv4(), - }, - ], - }, - ]; - } - return store; - }); - $: selectAllText = $iconStore.get("selectAllText"); const selectAllOptions = (): void => { @@ -219,15 +181,9 @@ {:else if "fieldType" in element && element.fieldType === "autocomplete"} {:else if "fieldType" in element && element.fieldType === "number"} - {#each numberInput.values as numberInputValues (numberInputValues.queryBindId)} - - {/each} + + {:else if "fieldType" in element && element.fieldType === "date"} + {/if} {/if} diff --git a/packages/lib/src/components/catalogue/DatePickerComponent.svelte b/packages/lib/src/components/catalogue/DatePickerComponent.svelte new file mode 100644 index 00000000..22130675 --- /dev/null +++ b/packages/lib/src/components/catalogue/DatePickerComponent.svelte @@ -0,0 +1,94 @@ + + +
+
+
+ + + +
+ +
+
diff --git a/packages/lib/src/components/catalogue/NumberInputComponent.svelte b/packages/lib/src/components/catalogue/NumberInputComponent.svelte index 2b8c5d7e..6b60e59a 100644 --- a/packages/lib/src/components/catalogue/NumberInputComponent.svelte +++ b/packages/lib/src/components/catalogue/NumberInputComponent.svelte @@ -1,19 +1,13 @@