From 7e77074c9d9a67625c544cdbcf8f96141c662320 Mon Sep 17 00:00:00 2001 From: Yash Maheshwari Date: Mon, 20 Nov 2023 12:16:25 +0530 Subject: [PATCH] Improved: logic to update default shipping days for facility(#16) --- src/views/FacilityDetails.vue | 27 ++++++++++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/src/views/FacilityDetails.vue b/src/views/FacilityDetails.vue index d5df206f..21377cea 100644 --- a/src/views/FacilityDetails.vue +++ b/src/views/FacilityDetails.vue @@ -192,9 +192,9 @@ {{ translate("Days to ship") }} - + - + {{ translate("Update days to ship") }} @@ -466,7 +466,8 @@ export default defineComponent({ return { isTimeModalOpen: false as boolean, isLoading: true, // shows whether the facility information fetching is completed or not - segment: 'external-mappings' + segment: 'external-mappings', + defaultDaysToShip: '' // not assinging 0 by default as it will convey the user that the facility can ship same day, but actually defaultDays are not setup on the facility } }, computed: { @@ -477,6 +478,7 @@ export default defineComponent({ props: ["facilityId"], async ionViewWillEnter() { await this.store.dispatch('facility/fetchCurrentFacility', { facilityId: this.facilityId }) + this.defaultDaysToShip = this.current.defaultDaysToShip this.isLoading = false }, methods: { @@ -642,6 +644,25 @@ export default defineComponent({ logger.error('Failed to update fulfillment setting', err) } }, + async updateDefaultDaysToShip() { + try { + const payload = { + facilityId: this.current.facilityId, + defaultDaysToShip: this.defaultDaysToShip + } + + const resp = await FacilityService.updateFacility(payload) + + if(!hasError(resp)) { + showToast(translate('Updated default days to ship')) + } else { + throw resp.data + } + } catch(err) { + logger.error('Failed to update default days to ship', err) + showToast(translate('Failed to update default days to ship')) + } + } }, setup() { const store = useStore();