From 8549bd68d9a7cef104868e3e0c35734583102aac Mon Sep 17 00:00:00 2001 From: Ravi Lodhi Date: Fri, 25 Oct 2024 12:07:27 +0530 Subject: [PATCH] Improved: Fetched product identifier options dynamically (#345). --- src/components/DxpProductIdentifier.vue | 3 ++- src/index.ts | 1 + src/store/productIdentification.ts | 13 ++++++++++++- 3 files changed, 15 insertions(+), 2 deletions(-) diff --git a/src/components/DxpProductIdentifier.vue b/src/components/DxpProductIdentifier.vue index 01347d6..8619423 100644 --- a/src/components/DxpProductIdentifier.vue +++ b/src/components/DxpProductIdentifier.vue @@ -36,9 +36,10 @@ const productIdentificationStore = useProductIdentificationStore(); const appState = appContext.config.globalProperties.$store const eComStore = computed(() => appState.getters['user/getCurrentEComStore']) const productIdentificationPref = computed(() => productIdentificationStore.getProductIdentificationPref); -const productIdentificationOptions = productIdentificationStore.getProductIdentificationOptions; +const productIdentificationOptions = computed(() => productIdentificationStore.getProductIdentificationOptions); onMounted(() => { + productIdentificationStore.prepareProductIdentifierOptions(); productIdentificationStore.getIdentificationPref(eComStore.value.productStoreId); }) diff --git a/src/index.ts b/src/index.ts index dfdae45..3be6564 100644 --- a/src/index.ts +++ b/src/index.ts @@ -96,6 +96,7 @@ export let dxpComponents = { productIdentificationContext.getProductIdentificationPref = options.getProductIdentificationPref productIdentificationContext.setProductIdentificationPref = options.setProductIdentificationPref + productIdentificationContext.fetchGoodIdentificationTypes = options.fetchGoodIdentificationTypes notificationContext.addNotification = options.addNotification notificationContext.appFirebaseConfig = options.appFirebaseConfig diff --git a/src/store/productIdentification.ts b/src/store/productIdentification.ts index b6d87f4..86c18d9 100644 --- a/src/store/productIdentification.ts +++ b/src/store/productIdentification.ts @@ -8,7 +8,7 @@ export const useProductIdentificationStore = defineStore('productIdentification' primaryId: '', secondaryId: '' }, - productIdentificationOptions: ["productId", "groupId", "groupName", "internalName", "parentProductName", "primaryProductCategoryName", "sku", "title", "SHOPIFY_PROD_SKU", "upc"] + productIdentificationOptions: [] } }, getters: { @@ -44,6 +44,17 @@ export const useProductIdentificationStore = defineStore('productIdentification' } this.productIdentificationPref = await productIdentificationContext.getProductIdentificationPref(eComStoreId) + }, + async prepareProductIdentifierOptions() { + //static identifications + const productIdentificationOptions = ["productId", "groupId", "groupName", "internalName", "parentProductName", "primaryProductCategoryName", "title"]; + + //good identification types + const fetchedGoodIdentificationTypes = await productIdentificationContext.fetchGoodIdentificationTypes("HC_GOOD_ID_TYPE"); + const fetchedGoodIdentificationOptions = fetchedGoodIdentificationTypes?.map((fetchedGoodIdentificationType: any) => fetchedGoodIdentificationType.goodIdentificationTypeId) || []; + + // Merge the arrays and remove duplicates + this.productIdentificationOptions = Array.from(new Set([...productIdentificationOptions, ...fetchedGoodIdentificationOptions])).sort(); } } })