From 55bdd6e3aefafdde2f761d09836a873c8915bd41 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jarda=20Kot=C4=9B=C5=A1ovec?= Date: Thu, 9 Jan 2025 16:03:05 +0100 Subject: [PATCH] pkp/pkp-lib#10663 Hide submissions on dashboard when loading different view/page/... --- src/components/Modal/Dialog.vue | 2 +- src/composables/useFetch.js | 11 +++++++++-- .../components/DashboardTable/DashboardTable.vue | 8 +++++++- src/pages/dashboard/dashboardPageStore.js | 2 +- 4 files changed, 18 insertions(+), 5 deletions(-) diff --git a/src/components/Modal/Dialog.vue b/src/components/Modal/Dialog.vue index ac41ef190..b04ca5729 100644 --- a/src/components/Modal/Dialog.vue +++ b/src/components/Modal/Dialog.vue @@ -66,7 +66,6 @@ class="flex items-center gap-x-4" :class="icon ? 'p-10 ps-24' : 'p-12'" > - {{ action.label }} + diff --git a/src/composables/useFetch.js b/src/composables/useFetch.js index 424840806..354d54923 100644 --- a/src/composables/useFetch.js +++ b/src/composables/useFetch.js @@ -39,6 +39,10 @@ export function getCSRFToken() { * @returns {Ref} return.isLoading - A ref object indicating whether the fetch operation is currently in progress. * @returns {Function} return.fetch - The function to call to initiate the fetch operation. This function is async and handles the actual fetching logic. * + * * The `fetch` function accepts the following optional parameter: + * @param {Object} [fetchOptions={}] - Options to customize the fetch operation. + * @param {boolean} [fetchOptions.clearData=false] - If set to `true`, processes and cleans the fetched data before storing it in `data`. Defaults to `false`. + */ export function useFetch(url, options = {}) { /** @@ -72,7 +76,7 @@ export function useFetch(url, options = {}) { const screenName = modalLevel?.value ? `modal_${modalLevel.value}` : 'base'; const progressStore = useProgressStore(); - async function _fetch() { + async function _fetch({clearData} = {clearData: false}) { if (lastRequestController) { // abort in-flight request lastRequestController.abort(); @@ -109,6 +113,9 @@ export function useFetch(url, options = {}) { } isSuccess.value = null; + if (clearData) { + data.value = null; + } try { const result = await ofetchInstance(unref(url), opts); data.value = result; @@ -144,7 +151,7 @@ export function useFetch(url, options = {}) { let fetch = _fetch; if (options.debouncedMs) { - fetch = useDebounceFn(_fetch); + fetch = useDebounceFn(_fetch, options.debouncedMs); } return { data, diff --git a/src/pages/dashboard/components/DashboardTable/DashboardTable.vue b/src/pages/dashboard/components/DashboardTable/DashboardTable.vue index 8aa8417d2..59fc684cf 100644 --- a/src/pages/dashboard/components/DashboardTable/DashboardTable.vue +++ b/src/pages/dashboard/components/DashboardTable/DashboardTable.vue @@ -20,7 +20,13 @@ {{ column.header }} - +