Files @ c3487917ceba
Branch filter:

Location: rattail-project/rattail/docs/narr/receiving/overview.rst

c3487917ceba 2.9 KiB text/prs.fallenstein.rst Show Annotation Show as Raw Download as Raw
lance
Only show POD image if so configured; use "image not found" fallback

also update a random docstring

Receiving Overview
==================

Here we offer a general overview of the "product receiving" features provided
by Rattail.


Rationale
---------

The details of the receiving process can vary quite a bit for each
organization, but some patterns emerge and Rattail tries to offer tools around
these patterns.

Regardless of where your true authority lives for purchase data, Rattail should
be able to e.g. read PO data from it, and (ideally) write PO data to it as
well. (The latter especially can depend on a lot of factors of course.)

So, even if you don't use Rattail to track your purchase history "proper" the
goal for Rattail is still to provide useful workflow tools.  Of course, if you
have no other system for POs then Rattail can provide a basic home for that.

Why would you even bother with this? Especially if the system where PO data
lives already has a receiving workflow/UI, that's a good question. Short answer
is, you may not want to.  But then again it is possible that Rattail can be
leveraged to obtain a more efficient and/or flexible workflow. This can
sometimes make a big difference on labor costs as well as morale.

Objectives
----------

Short version:

#. inventory
#. credits
#. costing

The #1 objective for the receiving process - at least from Rattail's
perspective - is to accurately adjust inventory levels.  Typically this means
*incrementing* inventory for all product being received, although of course
that can vary.  But the key here is accuracy; the Rattail workflows are meant
to help avoid e.g. blindly "receiving" all product from a PO, regardless of
whether or not it was in fact physically received.

Depending on the nature of your business, sometimes product may arrive damaged,
or expired, etc.  Sometimes it doesn't arrive at all even though you were
invoiced for it, or you received the wrong product instead.  So the #2
objective, is to provide a way to deal with these exceptions, since presumably
the inventory levels should *not* be adjusted for them, but you may still want
to track them as "credits" with the vendor.

That sort of leads into #3 objective, which is named "costing" but is perhaps
aka. "accounting" - this is simply the recording of true unit costs etc.  for
each product being received, for sake of history (reporting) and/or to drive
further business logic.  For instance the receiving cost might be compared to
"expected" cost (per product master) and action taken if it's higher.  But
again the point here is accuracy; cost history is great but only if "true".


Strategy
--------

The general feature is meant to allow a user to "receive" product into a unique
batch.  Population of the batch data can happen over time, e.g. by scanning in
product.  When the batch is "complete" then it is "executed" - at which point
the inventory and/or cost data it contains is "committed" to some DB(s).

That is a simplification of the process; see :doc:`workflows` for more info.