Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
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 systemGFERP, 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 needs to be implemented.

Process

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

    Classes

    .

    • If the allocation process fails, the system will write the error message to the Allocation Processing Error field.

    • Class Reference: GF_SalesOrderAllocationBatch

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

    Classes

    .

    • If the creation of the warehouse shipment fails, the system will save the error message to the
      Whse. Shipt. Processing Error field.

    • Class Reference: GF_CreateWhseShipmentBatch

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

    • To Schedule the routine to run hourly, run thisuse the following command:

      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

...

Allocation Challenge

Issue:

AdMaigc claims AdMagic states 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-the-box GF GFERP allocation routine to fail because the routine calculates the item quantity available by taking subtracting the quantity allocated from the item Quantity on Hand minus the quantity allocated, system doing it . The system accomplishes this by looping through all allocation lines, which will cause trigger a 'too many query rows' error, rules a limitation imposed by Salesforce governor limit, you can only query upto 50000 limits. Salesforce restricts querying up to 50,000 rows per transaction.

Solution:

...

Allocation_Processing_Error__c 

...

  • A new object "GF Item Allocation Summary(GFERP__Table02__c)" is created to store summarized item allocation by warehouse Warehouse, by item Item, and by unit Unit of measureMeasure.

  • 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(GF_SummarizeItemAllocationSched) 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

...

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

  • Custom Allocation Management class(GF_AllocationMgmt) is created to handle item allocation, utilizing the data in the new ‘Item Allocation Summary’ object.

    • This custom allocation management class is only used by 'GF_SalesOrderAllocationBatch'.
      Auto allocation when entering an order manually is still handled by the out-of-the-box GFERP allocation logic.