Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implemented: support for print picklist in open orders (#415) #421

Merged
merged 10 commits into from
Sep 12, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions src/locales/en.json
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,7 @@
"Pick up location": "Pick up location",
"Pickers successfully replaced in the picklist with the new selections.": "Pickers successfully replaced in the picklist with the new selections.",
"pieces in stock": "pieces in stock",
"Print picklists": "Print picklists",
"Product details": "Product details",
"Product not found": "Product not found",
"Products not found": "Products not found",
Expand Down
1 change: 1 addition & 0 deletions src/locales/es.json
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@
"Pick up location": "Ubicación de recogida",
"Pickers successfully replaced in the picklist with the new selections.": "Los recolectores fueron reemplazados exitosamente en la lista de selección con las nuevas selecciones.",
"pieces in stock": "piezas en inventario",
"Print picklists": "Print picklists",
"Product details": "Detalles del producto",
"Product not found": "Producto no encontrado",
"Products not found": "Productos no encontrados",
Expand Down
1 change: 1 addition & 0 deletions src/locales/ja.json
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,7 @@
"Pick up location": "受取場所",
"Pickers successfully replaced in the picklist with the new selections.": "ピッカーは新しい選択によりピックリストで正常に置き換えられました。",
"pieces in stock": "在庫あり",
"Print picklists": "Print picklists",
"Product details": "商品詳細",
"Product not found": "商品が見つかりません",
"Products not found": "商品が見つかりません",
Expand Down
42 changes: 42 additions & 0 deletions src/services/OrderService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { translate } from '@hotwax/dxp-components';
import store from '@/store';
import { formatPhoneNumber, showToast } from '@/utils';
import logger from '@/logger';
import { cogOutline } from 'ionicons/icons';

const getOpenOrders = async (payload: any): Promise <any> => {
return api({
Expand Down Expand Up @@ -120,6 +121,37 @@ const createPicklist = async (query: any): Promise <any> => {
})
}

const printPicklist = async (picklistId: string): Promise<any> => {
try {
// Get picklist from the server
const resp: any = await api({
method: 'get',
url: 'PrintPicklist.pdf',
params: {
picklistId
},
responseType: "blob"
})

if (!resp || resp.status !== 200 || hasError(resp)) {
throw resp.data;
}

// Generate local file URL for the blob received
const pdfUrl = window.URL.createObjectURL(resp.data);
// Open the file in new tab
try {
(window as any).open(pdfUrl, "_blank").focus();
}
catch {
showToast(translate('Unable to open as browser is blocking pop-ups.', {documentName: 'picklist'}), { icon: cogOutline });
}
} catch (err) {
showToast(translate('Failed to print picklist'))
logger.error("Failed to print picklist", err)
}
}

const sendPickupScheduledNotification = async (payload: any): Promise <any> => {
return api({
url: "service/sendPickupScheduledNotification",
Expand Down Expand Up @@ -307,6 +339,14 @@ const fetchTrackingCodes = async (shipmentIds: Array<string>): Promise<any> => {
return shipmentTrackingCodes;
}

const packOrder = async (payload: any): Promise<any> => {
return api({
url: "/service/packStoreFulfillmentOrder",
method: "post",
data: payload
})
}

export const OrderService = {
fetchOrderItems,
fetchOrderPaymentPreferences,
Expand All @@ -327,5 +367,7 @@ export const OrderService = {
getShipmentItems,
getCustomerContactDetails,
getShippingPhoneNumber,
packOrder,
printPicklist,
printShippingLabelAndPackingSlip
}
34 changes: 30 additions & 4 deletions src/store/modules/order/actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@
const orderQueryPayload = prepareOrderQuery({
...payload,
shipmentMethodTypeId: !store.state.user.preference.showShippingOrders ? 'STOREPICKUP' : '',
'-shipmentStatusId': '*',
'-shipmentStatusId': '(SHIPMENT_PACKED OR SHIPMENT_SHIPPED)',
'-fulfillmentStatus': '(Cancelled OR Rejected)',
orderStatusId: 'ORDER_APPROVED',
orderTypeId: 'SALES_ORDER'
Expand Down Expand Up @@ -170,7 +170,10 @@
}, []),
placedDate: orderItem.orderDate,
shippingInstructions: orderItem.shippingInstructions,
shipGroupSeqId: orderItem.shipGroupSeqId
shipGroupSeqId: orderItem.shipGroupSeqId,
isPicked: orderItem.isPicked,
picklistId: orderItem.picklistId,
picklistBinId: orderItem.picklistBinId
}
})

Expand Down Expand Up @@ -527,7 +530,7 @@
return resp;
},

async packDeliveryItems ({ commit }, shipmentId) {

Check warning on line 533 in src/store/modules/order/actions.ts

View workflow job for this annotation

GitHub Actions / call-workflow-in-another-repo / reusable_workflow_job (18.x)

'commit' is defined but never used

Check warning on line 533 in src/store/modules/order/actions.ts

View workflow job for this annotation

GitHub Actions / call-workflow-in-another-repo / reusable_workflow_job (20.x)

'commit' is defined but never used
const params = {
shipmentId: shipmentId,
statusId: 'SHIPMENT_PACKED'
Expand All @@ -538,7 +541,7 @@
async packShipGroupItems ({ state, dispatch, commit }, payload) {
emitter.emit("presentLoader")

if (store.state.user.preference.configurePicker) {
if (store.state.user.preference.configurePicker && payload.order.isPicked !== 'Y') {
let resp;

const items = payload.order.parts[0].items;
Expand All @@ -547,6 +550,7 @@
items.map((item: any, index: number) => {
formData.append("itemStatusId_o_"+index, "PICKITEM_PENDING")
formData.append("pickerIds_o_"+index, payload.selectedPicker)
formData.append("picked_o_"+index, item.quantity)
Object.keys(item).map((property) => {
if(property !== "facilityId") formData.append(property+'_o_'+index, item[property])
})
Expand Down Expand Up @@ -589,7 +593,7 @@
const shipmentMethodTypeId = payload.part?.shipmentMethodEnum?.shipmentMethodEnumId
if (shipmentMethodTypeId !== 'STOREPICKUP') {
// TODO: find a better way to get the shipmentId
const shipmentId = resp.data._EVENT_MESSAGE_.match(/\d+/g)[0]
const shipmentId = resp.data.shipmentId ? resp.data.shipmentId : resp.data._EVENT_MESSAGE_.match(/\d+/g)[0]
await dispatch('packDeliveryItems', shipmentId).then((data) => {
if (!hasError(data) && !data.data._EVENT_MESSAGE_) {
showToast(translate("Something went wrong"))
Expand All @@ -606,7 +610,10 @@
}
}
})
} else {
dispatch("removeOpenOrder", payload)
}

// Adding readyToHandover or readyToShip because we need to show the user that the order has moved to the packed tab
if(payload.order.part.shipmentMethodEnum.shipmentMethodEnumId === 'STOREPICKUP'){
payload.order = { ...payload.order, readyToHandover: true }
Expand All @@ -628,6 +635,21 @@
return resp;
},

removeOpenOrder({ commit, state }, payload) {
const orders = JSON.parse(JSON.stringify(state.open.list));

const orderIndex = orders.findIndex((order: any) => {
return order.orderId === payload.order.orderId && order.parts.some((part: any) => {
return part.orderPartSeqId === payload.part.orderPartSeqId;
});
});

if (orderIndex > -1) {
orders.splice(orderIndex, 1);
commit(types.ORDER_OPEN_UPDATED, { orders, total: state.open.total -1 })
}
},

// TODO: handle the unfillable items count
async setUnfillableOrderOrItem ({ dispatch }, payload) {
emitter.emit("presentLoader");
Expand All @@ -643,7 +665,7 @@
}).catch(err => err);
},

async rejectOrderItems ({ commit }, order) {

Check warning on line 668 in src/store/modules/order/actions.ts

View workflow job for this annotation

GitHub Actions / call-workflow-in-another-repo / reusable_workflow_job (18.x)

'commit' is defined but never used

Check warning on line 668 in src/store/modules/order/actions.ts

View workflow job for this annotation

GitHub Actions / call-workflow-in-another-repo / reusable_workflow_job (20.x)

'commit' is defined but never used
const payload = {
'orderId': order.orderId
}
Expand Down Expand Up @@ -963,6 +985,10 @@
emitter.emit("dismissLoader");
},

updateOpenOrder ({ commit }, payload) {
commit(types.ORDER_OPEN_UPDATED, {orders: payload.orders , total: payload.total})
},

// clearning the orders state when logout, or user store is changed
clearOrders ({ commit }) {
commit(types.ORDER_OPEN_UPDATED, {orders: {} , total: 0})
Expand Down Expand Up @@ -1049,7 +1075,7 @@

const orderQueryPayload = prepareOrderQuery(params)

let resp, total, shipGroups = [];

Check warning on line 1078 in src/store/modules/order/actions.ts

View workflow job for this annotation

GitHub Actions / call-workflow-in-another-repo / reusable_workflow_job (18.x)

'total' is defined but never used

Check warning on line 1078 in src/store/modules/order/actions.ts

View workflow job for this annotation

GitHub Actions / call-workflow-in-another-repo / reusable_workflow_job (20.x)

'total' is defined but never used
const facilityTypeIds: Array<string> = [];

try {
Expand Down
3 changes: 3 additions & 0 deletions src/store/modules/user/getters.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,9 @@ const getters: GetterTree <UserState, RootState> = {
showShippingOrders (state) {
return state.preference.showShippingOrders;
},
printPicklistPref (state) {
return state.preference.printPicklistPref;
},
configurePicker (state) {
return state.preference.configurePicker;
},
Expand Down
3 changes: 2 additions & 1 deletion src/store/modules/user/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@ const userModule: Module<UserState, RootState> = {
preference: {
showShippingOrders: false,
showPackingSlip: false,
configurePicker: false
configurePicker: false,
printPicklistPref: false
},
currentEComStore: {},
partialOrderRejectionConfig: {},
Expand Down
3 changes: 2 additions & 1 deletion src/store/modules/user/mutations.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@ const mutations: MutationTree <UserState> = {
state.preference= {
showShippingOrders: false,
showPackingSlip: false,
configurePicker: false
configurePicker: false,
printPicklistPref: false
},
state.allNotificationPrefs = []
},
Expand Down
32 changes: 24 additions & 8 deletions src/utils/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,30 @@ import { DateTime } from "luxon";

// TODO Use separate files for specific utilities

const showToast = async (message: string) => {
const toast = await toastController
.create({
message,
duration: 3000,
position: 'top',
})
return toast.present();
const showToast = async (message: string, options?: any) => {
const config = {
message,
...options
} as any;

if (!options?.position) {
config.position = 'top';
}
if (options?.canDismiss) {
config.buttons = [
{
text: translate('Dismiss'),
role: 'cancel',
},
]
}
if (!options?.manualDismiss) {
config.duration = 3000;
}

const toast = await toastController.create(config)
// present toast if manual dismiss is not needed
return !options?.manualDismiss ? toast.present() : toast
}

const copyToClipboard = async (text: any, showCopiedValue = true) => {
Expand Down
3 changes: 1 addition & 2 deletions src/views/AssignPickerModal.vue
Original file line number Diff line number Diff line change
Expand Up @@ -124,8 +124,7 @@ export default defineComponent({
},
readyForPickup () {
if (this.selectedPicker) {
this.store.dispatch('order/packShipGroupItems', { order: this.order, part: this.part, facilityId: this.facilityId, selectedPicker: this.selectedPicker })
modalController.dismiss({ dismissed: true });
modalController.dismiss({ dismissed: true, selectedPicker: this.selectedPicker });
} else {
showToast(translate('Select a picker'))
}
Expand Down
7 changes: 7 additions & 0 deletions src/views/OrderDetail.vue
Original file line number Diff line number Diff line change
Expand Up @@ -336,6 +336,13 @@ export default defineComponent({
component: AssignPickerModal,
componentProps: { order, part, facilityId }
});

assignPickerModal.onDidDismiss().then(async(result: any) => {
if(result.data.dismissed) {
await this.store.dispatch('order/packShipGroupItems', { order, part, facilityId, selectedPicker: result.data.selectedPicker })
}
})

return assignPickerModal.present();
},
async editPicker(order: any) {
Expand Down
Loading
Loading