From 8de3ea16a6c79020bc5442e1c054db6a3cb90c46 Mon Sep 17 00:00:00 2001 From: jorgep Date: Mon, 8 Apr 2024 15:15:18 +0200 Subject: [PATCH 1/4] fix: refs #6992 add queryParams --- CHANGELOG.md | 4 ++++ src/composables/useArrayData.js | 16 ++++++++++------ test/cypress/integration/vnSearchBar.spec.js | 2 +- 3 files changed, 15 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 555b4f0ba..9f493764a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,6 +9,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added +### Fixed + +- (General) => Se vuelven a mostrar los parĂ¡metros en la url al aplicar un filtro + ## [2414.01] - 2024-04-04 ### Added diff --git a/src/composables/useArrayData.js b/src/composables/useArrayData.js index b6b81f2d5..403683415 100644 --- a/src/composables/useArrayData.js +++ b/src/composables/useArrayData.js @@ -105,7 +105,7 @@ export function useArrayData(key, userOptions) { for (const row of response.data) store.data.push(row); } else { store.data = response.data; - if (!document.querySelectorAll('[role="dialog"]')) + if (!document.querySelectorAll('[role="dialog"]').length) updateRouter && updateStateParams(); } @@ -188,11 +188,15 @@ export function useArrayData(key, userOptions) { if (store.userParams && Object.keys(store.userParams).length !== 0) query.params = JSON.stringify(store.userParams); - if (router) - router.replace({ - path: route.path, - query: query, - }); + const url = new URL(window.location.href); + const { hash: currentHash } = url; + const [currentRoute] = currentHash.split('?'); + + const params = new URLSearchParams(); + for (const param in query) params.append(param, query[param]); + + url.hash = currentRoute + '?' + params.toString(); + window.history.pushState({}, '', url); } const totalRows = computed(() => (store.data && store.data.length) || 0); diff --git a/test/cypress/integration/vnSearchBar.spec.js b/test/cypress/integration/vnSearchBar.spec.js index 3db789773..f1f3a9e82 100644 --- a/test/cypress/integration/vnSearchBar.spec.js +++ b/test/cypress/integration/vnSearchBar.spec.js @@ -36,7 +36,7 @@ describe('VnSearchBar', () => { const checkCardListAndUrl = (expectedLength) => { cy.get(cardList).then(($cardList) => { expect($cardList.find('.q-card').length).to.equal(expectedLength); - cy.url().then((currentUrl) => expect(currentUrl).to.equal(url)); + cy.url().then((currentUrl) => expect(currentUrl).to.contain(url)); }); }; }); From 16548dadefd7638bd8fa20efbd0292eaf3ce0fd0 Mon Sep 17 00:00:00 2001 From: jorgep Date: Mon, 8 Apr 2024 16:38:36 +0200 Subject: [PATCH 2/4] feat: refs #6992 add test --- src/composables/useArrayData.js | 2 +- .../composables/useArrayData.spec.js | 27 +++++++++++++++++++ 2 files changed, 28 insertions(+), 1 deletion(-) create mode 100644 test/vitest/__tests__/composables/useArrayData.spec.js diff --git a/src/composables/useArrayData.js b/src/composables/useArrayData.js index 403683415..a212cb744 100644 --- a/src/composables/useArrayData.js +++ b/src/composables/useArrayData.js @@ -196,7 +196,7 @@ export function useArrayData(key, userOptions) { for (const param in query) params.append(param, query[param]); url.hash = currentRoute + '?' + params.toString(); - window.history.pushState({}, '', url); + window.history.pushState({}, '', url.hash); } const totalRows = computed(() => (store.data && store.data.length) || 0); diff --git a/test/vitest/__tests__/composables/useArrayData.spec.js b/test/vitest/__tests__/composables/useArrayData.spec.js new file mode 100644 index 000000000..09bfc256f --- /dev/null +++ b/test/vitest/__tests__/composables/useArrayData.spec.js @@ -0,0 +1,27 @@ +import { describe, expect, it, beforeAll } from 'vitest'; +import { axios } from 'app/test/vitest/helper'; +import { useArrayData } from 'composables/useArrayData'; + +describe('useArrayData', () => { + let arrayData; + beforeAll(() => { + axios.get.mockResolvedValue({ data: [] }); + arrayData = useArrayData('InvoiceIn', { url: 'invoice-in/list' }); + Object.defineProperty(window.location, 'href', { + writable: true, + value: 'localhost:9000/invoice-in/list', + }); + window.history.pushState = (data, title, url) => (window.location.href = url); + global.URL = class URL { + constructor(url) { + this.hash = url.split('localhost:9000/')[1]; + } + }; + }); + + it('should add the params to the url', async () => { + arrayData.store.userParams = { supplierFk: 2 }; + arrayData.updateStateParams(); + expect(window.location.href).contain('params=%7B%22supplierFk%22%3A2%7D'); + }); +}); From 6349a3e790db734d0d0f0208b71dc065cbab0a49 Mon Sep 17 00:00:00 2001 From: jorgep Date: Tue, 9 Apr 2024 15:08:54 +0200 Subject: [PATCH 3/4] feat: refs #6992 comments --- src/composables/useArrayData.js | 3 +-- test/vitest/__tests__/composables/useArrayData.spec.js | 4 ++++ 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/src/composables/useArrayData.js b/src/composables/useArrayData.js index a212cb744..2c5a579c8 100644 --- a/src/composables/useArrayData.js +++ b/src/composables/useArrayData.js @@ -1,5 +1,5 @@ import { onMounted, ref, computed } from 'vue'; -import { useRouter, useRoute } from 'vue-router'; +import { useRoute } from 'vue-router'; import axios from 'axios'; import { useArrayDataStore } from 'stores/useArrayDataStore'; import { buildFilter } from 'filters/filterPanel'; @@ -15,7 +15,6 @@ export function useArrayData(key, userOptions) { const store = arrayDataStore.get(key); const hasMoreData = ref(false); - const router = useRouter(); const route = useRoute(); let canceller = null; diff --git a/test/vitest/__tests__/composables/useArrayData.spec.js b/test/vitest/__tests__/composables/useArrayData.spec.js index 09bfc256f..ae0ca7368 100644 --- a/test/vitest/__tests__/composables/useArrayData.spec.js +++ b/test/vitest/__tests__/composables/useArrayData.spec.js @@ -11,7 +11,11 @@ describe('useArrayData', () => { writable: true, value: 'localhost:9000/invoice-in/list', }); + + // Mock the window.history.pushState method within useArrayData window.history.pushState = (data, title, url) => (window.location.href = url); + + // Mock the URL constructor within useArrayData global.URL = class URL { constructor(url) { this.hash = url.split('localhost:9000/')[1]; From 83bf8183f0c0dd1ab6a3dc48d97b43ddce04dec1 Mon Sep 17 00:00:00 2001 From: jorgep Date: Tue, 9 Apr 2024 15:12:54 +0200 Subject: [PATCH 4/4] fix: refs #6992 warning console & formModel hook --- src/components/FormModel.vue | 20 ++++++++++---------- src/components/common/VnCurrency.vue | 2 +- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/components/FormModel.vue b/src/components/FormModel.vue index 8787371bc..a7af0044b 100644 --- a/src/components/FormModel.vue +++ b/src/components/FormModel.vue @@ -101,16 +101,16 @@ onMounted(async () => { }); onBeforeRouteLeave((to, from, next) => { - if (!hasChanges.value) next(); - - quasar.dialog({ - component: VnConfirm, - componentProps: { - title: t('Unsaved changes will be lost'), - message: t('Are you sure exit without saving?'), - promise: () => next(), - }, - }); + if (hasChanges.value) + quasar.dialog({ + component: VnConfirm, + componentProps: { + title: t('Unsaved changes will be lost'), + message: t('Are you sure exit without saving?'), + promise: () => next(), + }, + }); + else next(); }); onUnmounted(() => { diff --git a/src/components/common/VnCurrency.vue b/src/components/common/VnCurrency.vue index 660c4e979..b892e5012 100644 --- a/src/components/common/VnCurrency.vue +++ b/src/components/common/VnCurrency.vue @@ -5,7 +5,7 @@ import { useCapitalize } from 'src/composables/useCapitalize'; import VnInput from 'src/components/common/VnInput.vue'; const props = defineProps({ - modelValue: { type: String, default: '' }, + modelValue: { type: [String, Number], default: '' }, }); const { t } = useI18n();