From 9dbde75ce0fda18724f5156aaa28bb2580972f11 Mon Sep 17 00:00:00 2001 From: amansinghbais Date: Mon, 30 Dec 2024 10:55:50 +0530 Subject: [PATCH 1/8] Reverted: download count confirmation alert (#567) --- src/components/DownloadClosedCountModal.vue | 134 +++++++++----------- src/locales/en.json | 3 - 2 files changed, 60 insertions(+), 77 deletions(-) diff --git a/src/components/DownloadClosedCountModal.vue b/src/components/DownloadClosedCountModal.vue index 6adc0849..2e58c248 100644 --- a/src/components/DownloadClosedCountModal.vue +++ b/src/components/DownloadClosedCountModal.vue @@ -217,80 +217,66 @@ async function fetchProducts(productIds: any){ } async function downloadCSV() { - const alert = await alertController.create({ - header: translate("Download closed counts"), - message: translate("Are you sure you want to download the cycle counts?"), - buttons: [{ - text: translate("Cancel"), - role: 'cancel', - }, { - text: translate("Download"), - handler: async () => { - await modalController.dismiss({ dismissed: true }); - await alert.dismiss(); - emitter.emit("presentLoader", { message: "Preparing file to downlaod...", backdropDismiss: true }); - - const facilityDetails = getFacilityDetails(); - const selectedFieldMappings: any = { - countId: "inventoryCountImportId", - countName: "countImportName", - acceptedByUser: "acceptedByUserLoginId", - createdDate: "createdDate", - lastSubmittedDate: "lastSubmittedDate", - closedDate: "closedDate", - facility: "facilityId", - primaryProductId: "primaryProductId", - secondaryProductId: "secondaryProductId", - lineStatus: "statusId", - expectedQuantity: "qoh", - countedQuantity: "quantity", - variance: "varianceQuantityOnHand", - }; - - const selectedData = Object.keys(selectedFields.value).filter((field) => selectedFields.value[field]); - - const cycleCountItems = await fetchBulkCycleCountItems(); - await fetchProducts([... new Set(cycleCountItems.map((item: any) => item.productId))]); - - const downloadData = await Promise.all(cycleCountItems.map(async (item: any) => { - const facility = facilityDetails[item?.facilityId]; - const product = getProduct.value(item.productId) - - if(product.productId) { - const cycleCountDetails = selectedData.reduce((details: any, property: any) => { - if (property === 'createdDate') { - details[property] = getDateWithOrdinalSuffix(item.createdDate); - } else if (property === 'lastSubmittedDate') { - details[property] = getLastSubmittedDate(item); - } else if (property === 'closedDate') { - details[property] = getClosedDate(item); - } else if (property === 'facility') { - details[property] = facility[selectedFacilityField.value]; - } else if (property === 'primaryProductId') { - details[property] = getProductIdentificationValue(selectedPrimaryProductId.value, product); - } else if (property === 'secondaryProductId') { - details[property] = getProductIdentificationValue(selectedSecondaryProductId.value, product); - } else if (property === 'countName' && item.countImportName) { - details[property] = item.countImportName; - } else if (property === "lineStatus") { - details[property] = item.itemStatusId === 'INV_COUNT_COMPLETED' ? 'Completed' : item.itemStatusId === 'INV_COUNT_REJECTED' ? 'Rejected' : item.itemStatusId; - } else { - details[property] = item[selectedFieldMappings[property]]; - } - return details; - }, {}); - - return cycleCountDetails; - } - })); - - const fileName = `CycleCounts-${DateTime.now().toLocaleString(DateTime.DATETIME_MED_WITH_SECONDS)}.csv`; - await jsonToCsv(downloadData, { download: true, name: fileName }); - emitter.emit("dismissLoader") - } - }] - }); - return alert.present(); + await modalController.dismiss({ dismissed: true }); + emitter.emit("presentLoader", { message: "Preparing file to downlaod...", backdropDismiss: true }); + + const facilityDetails = getFacilityDetails(); + const selectedFieldMappings: any = { + countId: "inventoryCountImportId", + countName: "countImportName", + acceptedByUser: "acceptedByUserLoginId", + createdDate: "createdDate", + lastSubmittedDate: "lastSubmittedDate", + closedDate: "closedDate", + facility: "facilityId", + primaryProductId: "primaryProductId", + secondaryProductId: "secondaryProductId", + lineStatus: "statusId", + expectedQuantity: "qoh", + countedQuantity: "quantity", + variance: "varianceQuantityOnHand", + }; + + const selectedData = Object.keys(selectedFields.value).filter((field) => selectedFields.value[field]); + + const cycleCountItems = await fetchBulkCycleCountItems(); + await fetchProducts([... new Set(cycleCountItems.map((item: any) => item.productId))]); + + const downloadData = await Promise.all(cycleCountItems.map(async (item: any) => { + const facility = facilityDetails[item?.facilityId]; + const product = getProduct.value(item.productId) + + if(product.productId) { + const cycleCountDetails = selectedData.reduce((details: any, property: any) => { + if (property === 'createdDate') { + details[property] = getDateWithOrdinalSuffix(item.createdDate); + } else if (property === 'lastSubmittedDate') { + details[property] = getLastSubmittedDate(item); + } else if (property === 'closedDate') { + details[property] = getClosedDate(item); + } else if (property === 'facility') { + details[property] = facility[selectedFacilityField.value]; + } else if (property === 'primaryProductId') { + details[property] = getProductIdentificationValue(selectedPrimaryProductId.value, product); + } else if (property === 'secondaryProductId') { + details[property] = getProductIdentificationValue(selectedSecondaryProductId.value, product); + } else if (property === 'countName' && item.countImportName) { + details[property] = item.countImportName; + } else if (property === "lineStatus") { + details[property] = item.itemStatusId === 'INV_COUNT_COMPLETED' ? 'Completed' : item.itemStatusId === 'INV_COUNT_REJECTED' ? 'Rejected' : item.itemStatusId; + } else { + details[property] = item[selectedFieldMappings[property]]; + } + return details; + }, {}); + + return cycleCountDetails; + } + })); + + const fileName = `CycleCounts-${DateTime.now().toLocaleString(DateTime.DATETIME_MED_WITH_SECONDS)}.csv`; + await jsonToCsv(downloadData, { download: true, name: fileName }); + emitter.emit("dismissLoader") } diff --git a/src/locales/en.json b/src/locales/en.json index 22206690..0aabce58 100644 --- a/src/locales/en.json +++ b/src/locales/en.json @@ -19,7 +19,6 @@ "Auto assign to stores": "Auto assign to stores", "Average variance": "Average variance", "Are you sure you want to change the time zone to?": "Are you sure you want to change the time zone to {timeZoneId}?", - "Are you sure you want to download the cycle counts?": "Are you sure you want to download the cycle counts?", "Assigned": "Assigned", "Assign": "Assign", "Assign a facility to the cycle count": "Assign a facility to the cycle count", @@ -86,9 +85,7 @@ "count name": "count name", "eCom Store": "eCom Store", "due date": "due date", - "Download": "Download", "Download results": "Download results", - "Download closed counts": "Download closed counts", "Enter a SKU, or use the barcode scanner to search a product": "Enter a SKU, or use the barcode scanner to search a product", "Enter a valid cycle count name": "Enter a valid cycle count name", "Enter a valid product sku": "Enter a valid product sku", From 3fbdb39f2cdc93bb5cb7dffa44e42d9ccc3c4d4d Mon Sep 17 00:00:00 2001 From: amansinghbais Date: Mon, 30 Dec 2024 12:10:20 +0530 Subject: [PATCH 2/8] Improved: showing spinner while searching product in matchProduct modal (#563) --- src/components/MatchProductModal.vue | 13 +++++++++++-- src/locales/en.json | 2 ++ 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/src/components/MatchProductModal.vue b/src/components/MatchProductModal.vue index 779620c2..0850bfae 100644 --- a/src/components/MatchProductModal.vue +++ b/src/components/MatchProductModal.vue @@ -12,7 +12,12 @@ - diff --git a/src/views/DraftDetail.vue b/src/views/DraftDetail.vue index a7986cae..b8bb8342 100644 --- a/src/views/DraftDetail.vue +++ b/src/views/DraftDetail.vue @@ -99,7 +99,7 @@ -

{{ translate("No product found") }}

+

{{ translate("No items added to count") }}


diff --git a/src/views/PendingReview.vue b/src/views/PendingReview.vue index 44bcb78f..b9d26820 100644 --- a/src/views/PendingReview.vue +++ b/src/views/PendingReview.vue @@ -34,7 +34,7 @@ - {{ getCycleCountStats(count.inventoryCountImportId) }} + {{ getCycleCountStats(count.inventoryCountImportId, count.countTypeEnumId === "HARD_COUNT") }}

{{ translate("counted") }}

diff --git a/src/views/PendingReviewDetail.vue b/src/views/PendingReviewDetail.vue index e720dadf..0c57f666 100644 --- a/src/views/PendingReviewDetail.vue +++ b/src/views/PendingReviewDetail.vue @@ -153,7 +153,7 @@

- {{ translate("No items found") }} + {{ translate("No items added to count") }}