From 33db278166d88f52722420d890d1e56789d47858 Mon Sep 17 00:00:00 2001 From: peoray Date: Sat, 14 Oct 2023 13:51:44 +0100 Subject: [PATCH 1/2] Remove checkboxes from tags multi-select filters (members page) --- .../filters/components/filterTypes/MultiSelectAsyncFilter.vue | 1 + 1 file changed, 1 insertion(+) diff --git a/frontend/src/shared/modules/filters/components/filterTypes/MultiSelectAsyncFilter.vue b/frontend/src/shared/modules/filters/components/filterTypes/MultiSelectAsyncFilter.vue index d8fe876c65..4395fa0bb0 100644 --- a/frontend/src/shared/modules/filters/components/filterTypes/MultiSelectAsyncFilter.vue +++ b/frontend/src/shared/modules/filters/components/filterTypes/MultiSelectAsyncFilter.vue @@ -26,6 +26,7 @@ :value="option" >
From 0e64a06f2735c65187f711d07f5c91cf12647357 Mon Sep 17 00:00:00 2001 From: peoray Date: Thu, 19 Oct 2023 21:03:36 +0100 Subject: [PATCH 2/2] Implement removal and re-addition of tags filter on members page --- .../filterTypes/MultiSelectAsyncFilter.vue | 29 +++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) diff --git a/frontend/src/shared/modules/filters/components/filterTypes/MultiSelectAsyncFilter.vue b/frontend/src/shared/modules/filters/components/filterTypes/MultiSelectAsyncFilter.vue index 4395fa0bb0..a2d6331a8a 100644 --- a/frontend/src/shared/modules/filters/components/filterTypes/MultiSelectAsyncFilter.vue +++ b/frontend/src/shared/modules/filters/components/filterTypes/MultiSelectAsyncFilter.vue @@ -114,7 +114,24 @@ watch(() => props.modelValue.value, (value?: string[]) => { } }, { immediate: true }); -watch(() => data.value.selected, (value) => { +watch(() => data.value.selected, (value, oldValue) => { + if (props.config.id === 'tags') { + filteredOptions.value = filteredOptions.value.filter((option) => !value.map((v: any) => v.value).includes(option.value)); + + const removedOption: any = oldValue?.find((option: any) => !value.includes(option)); + + if (removedOption && !filteredOptions.value.some((option) => option.value === removedOption.value)) { + const position = oldValue.findIndex((option: any) => option.value === removedOption.value); + + if (position >= 0) { + filteredOptions.value.splice(position, 0, { + label: removedOption.label, + value: removedOption.value, + }); + } + } + } + emit('update:modelValue', { ...props.modelValue, value: value.map((v) => v.value), @@ -128,7 +145,15 @@ const searchOptions = (query: string) => { loading.value = true; props.remoteMethod(query) .then((options) => { - filteredOptions.value = options; + if (props.config.id === 'tags') { + const mappedOptions = options.map((option) => ({ + label: option.label, + value: option.value, + })); + filteredOptions.value = mappedOptions; + } else { + filteredOptions.value = options; + } }) .finally(() => { loading.value = false;