Receiving Workflows =================== Here we describe the workflows for "receiving" product, which are supported by Rattail. At a fundamental level there are just 2 workflows: you can either receive "from scratch" (i.e. starting from nothing) or you receive "against a document" (PO, invoice, both, other). In rare cases a special workflow may be needed, which Rattail refers to as "truck dump" - if you can avoid it you should! Receive From Scratch ---------------------- Receiving "from scratch" just means you're starting from nothing, i.e. you have no invoice file to upload and the purchase order does not yet exist in the system. So you effectively create an "empty" batch and then must add items to it. This may be done via mobile or desktop interface; scanner is supported for both. Executing the batch would typically *create* the (received) purchase order in the system - Rattail or POS etc. Receive Against a Document -------------------------- Receiving "against a document" just means you actually have some sort of digital representation of the order, and so can use that as the starting point for your batch, then "update" line items. This is fundamentally different than "from scratch" which starts with an empty batch and you must *add* all line items. Not all documents types are "equal" for this purpose. Specifically, some (e.g. PO) will contain the *ordered* quantities but not the *shipped* quantities (or accurate cost info). However some (e.g. invoice file) will contain shipped quantities and hopefully, accurate cost info. Purchase Order ~~~~~~~~~~~~~~ If the purchase order (PO) already exists in the system, you can choose it after identifying the vendor. The batch is auto-populated with line items from the PO when it is created. Note that a purchase order will have *ordered* quantities but not the *shipped* quantites, or accurate cost info. Usually you need a digital invoice file to get the rest of it. Invoice File ~~~~~~~~~~~~ If the user has a digital invoice file (with supported format/parser) then they can upload that when making a new batch, and it will be auto-populated with line items from the invoice file. Note that an invoice file may have *ordered* and/or *shipped* quantities. If only one is present, usually the other can be inferred from it. Most but perhaps not all invoice files will contain accurate cost data. Sometimes the normal wholesale cost is listed in addition to the "true" cost paid for each item, etc. As much data as the invoice contains, should go into the initial batch. But it still likely can't provide *everything* and so when possible a purchase order should also be chosen for the batch. Purchase Order + Invoice File ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ This of course combines the previous two approaches. User must choose an existing PO and also upload an invoice file. On a technical level the batch is first populated from the PO line items, and then the invoice data is "overlaid" onto the batch. This will *update* line items found on the PO, but may also *create* new line items which were not on the PO. Mobile/Scanner-based Receiving ------------------------------ There is a mobile-specific app/interface for use with receiving. It assumes you have a mobile smart phone with bluetooth scanner attached in keyboard wedge mode. The user opens (or creates) the batch in the mobile app, then starts scanning physical product from the order. They continue until they've scanned everything physically present. If receiving "from scratch" then the batch can be executed when scanning is complete. If receiving "against a document" then the mobile app will indicate if any product was "missed" - i.e. what was on the document, that was not yet accounted for. Once the user has addressed any discrepancies, the batch may be executed. Paper-based Receiving --------------------- If the receiver does a paper-based check-in, then the process changes a bit on the back-end. The user would always create the receiving batch via the desktop interface. If receiving "from scratch" then user has to manually key in every line item! Prone to mistakes and labor-intensive; not advised. If receiving "against a document" then user will choose/upload the document per usual, which auto-populates the batch. But each line item will assume zero quantity received at first. So user *could* manually key in the amounts from paperwork, but the easier way is to first "auto-receive" all lines and then manually key in only the exceptions. Once the batch data is correct, including any "credits" etc. then it may be executed. "Truck Dump" Receiving ---------------------- We use the term "truck dump" to refer to a specific scenario which, with any luck, you do not have to deal with and can just skip this section... Normally you place an order with the vendor and then you receive it. For some vendors (e.g. distributors) you might place multiple orders at the same time, e.g. one per department. Much of the time even in that case when the orders arrive, they are partitioned somehow and can be received independently. But, alas, sometimes multiple orders arrive all mixed together and that is a "truck dump" in Rattail terms. It is not possible to receive them independently because of their being mixed up. Rattail tries to address this but as of writing this has not seen enough production use to be called stable. Nonetheless we'll describe it here. The basic idea is to acknowledge the facts: * we want multiple batches, i.e. one per order, but * we have a pile of product that must be processed as one batch So we just do both..by creating a "parent" truck dump batch, which will contain all the received quantities, and then also for each actual order we have a "child" truck dump batch, connected to the parent. Each child batch contains the ordered/shipped quantities. But each line item within a child batch is also connected to and "consumes" some amount of the received quantity from corresponding parent batch line item. When the dust has settled we should have a fully reconciled data set, i.e. all items from all child batches have either been accounted for or marked for credit. Due to all the complexity involved it is not possible to execute a "child" truck dump batch directly. Instead you must execute the parent batch, which will immediately execute all its child batches. .. image:: /_static/truck-dump.png On a technical level the line items between parent and child batches are linked via a "claim" which indicates how much of the parent item's received quantity has been "claimed" by a given child item. And when credits are identified, those also are "linked" between the parent and child items, although not entirely clear from this picture. .. image:: /_static/truck-dump-rows.png From Scratch (aka. "children last") ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ It's possible to start "from scratch" with truck dump receiving, but the caveat is that you *should* have documents (PO and/or invoice) which can be used to "reconcile" the truck dump batches, before it's all said and done. If you do not have documents to define the individual orders then the truck dump parent batch effectively cannot be split up, and you will just be doing "normal from scratch" receiving at that point. So in the "truck dump from scratch" workflow then, you start by creating an empty "parent" batch, then start scanning all products found. When all has been scanned, your truck dump parent batch will have no ordered quantities but should have all received quantities. Then you must add each of documents as a separate "child" batch under the parent batch. Each document should have either ordered or shipped quantities. Rattail will auto-reconcile each line item where possible, which means taking the received quantites from parent batch and "divvying" them up to the child batches. If everything reconciles cleanly then each line item of each child batch should be fully received. If there are gaps etc. then perhaps not everything was delivered and credits should be requested. Once everything is reconciled and data looks good, you must execute the parent batch, which will execute all of the child batches. Against Documents (aka. "children first") ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Since you need to have documents available in order to do truck dump receiving in the first place, it makes sense to define them up-front. In this mode then, you create a truck dump "parent" batch first, and then immediately after will create a "child" batch for each order document, under the parent batch. At this point you will scan/receive against the parent batch, which should have all line items and order/ship quantities. When finished scanning and all is reconciled, you must execute the parent batch, which will execute all of the child batches.