Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents

Overview

Why we are doing this???

Sales Order Allocations

...

Table of Contents

Overview

AdMagic receives orders from various channels, such as EDI and Shopify Store integration. All these orders are brought in by automatic routines. Once the order is in the Goldfinch system, users will need to manually allocate and create shipments for those orders. However, due to the volume of orders, manual allocation and creating warehouse shipments is not feasible for AdMagic. Therefore, an automatic/scheduled process need to be implemented.

Process

  • Step 1: the system will automatically allocate inventory to orders whose Document Status = ‘Open’ and Allocation Status != ‘Full’

    • Classes Reference: GF_SalesOrderAllocationBatch

  • Step 2: The system will automatically create warehouse shipments for orders with Document Status = ‘Open’ and Allocation Status = ‘Full’

    • Classes Reference: GF_CreateWhseShipmentBatch

  • The above processes are scheduled to run hourly and are controlled by the scheduler class GF_SOAllocationAndWhseShiptCreationSched

    • Schedule the routine to run hourly, run this:

      Code Block
      String cron = '0 0 0/1 1/1 * ? *'; //hourly 
      GF_SOAllocationAndWhseShiptCreationSched sched = new_GF_SOAllocationAndWhseShiptCreationSched(); 
      String jobId = System.schedule('Sales Order Allocation and Whse. Shipt. Creation Job', cron, sched); 
      

Sales Order Allocations Challenge

Issue:

AdMaigc claims that they will have more than 50,000 order lines with the same item in the same warehouse open at any given time, especially for those Kickstarter items. This will cause the out-of-box GF allocation routine to fail because the routine calculates the item quantity available by taking the item Quantity on Hand minus the quantity allocated, system doing it by looping through all allocation lines, which will cause too many query rows error, rules imposed by Salesforce governor limit, you can only query upto 50000 rows per transaction.

Solution:

  • A new object "GF Item Allocation Summary" is created to store summarized item allocation by warehouse, by item, and by unit of measure.

  • Trigger "GF_ItemAllocationTrigger" is added to detect Insert, Update, and Delete operations against the GFERP's Item Allocation object. The system will increase or decrease the quantity count in the summarized table based on the operation type/or the quantity change detected by the trigger.

  • A nightly job routine is scheduled to recalculate the allocated quantity in the summarized table. The night job will run the batches in the following order:

  1. Empty the summarized table - GF_DeleteSummarizedItemAllocationBatch

  2. Prepare the item allocation table - GF_UpdateItemAllocationBatch

  3. Generate summarized item allocation records - GF_SummarizeItemAllocationBatch

This is the schedulable class:

GF_SOAllocationAndWhseShiptCreationSched

How to Schedule to Routine

To schedule the routine, run this:

Code Block
String cron = '0 0 0/1 1/1 * ? *'; //hourly 
GF_SOAllocationAndWhseShiptCreationSched sched = new_GF_SOAllocationAndWhseShiptCreationSched(); 
String jobId = System.schedule('Sales Order Allocation and Whse. Shipt. Creation Job', cron, sched); 

It calls GF_salesOrderAllocationBatch with Batch Size = 1?

To look at all sales orders with Document Status = Open, sort by Order Date.

...

Info

Two fields were created to record errors. (The system will write the error msg to all records if one record fails in the batch) 

  • Allocation_Processing_Error__c 

  • Whse_Shipt_Processing_Error__c