9 Replies Latest reply on Jan 27, 2011 4:03 PM by trizko

    Order Processing

    trizko

      Title

      Order Processing

      Post

      My companies order process goes like this:

      Create Quote for Customer --->

      Recieve and Confirm Purchase Order From Customer --->

      Generate Work Order for our production department --->

      Generate Invoice for Customer.

      I would like to relate all the different types of Orders("Quote", "Work Order", and "Invoice"), but still keep them all in one table("ORDERS").

      How would I have to configure my tables and table occurrences to accomplish this?

        • 1. Re: Order Processing
          philmodjunk

          One option is to just use the same record for Quote, Work Order and Invoice, changing a status field from Quote, to Work Order to Invoice as it moves through the process.

          Many businesses, however, need to be able to look back and tell what information was current when the quote was sent to the customer, when the work order was sent to production and then what details were current when the invoice was used to bill that customer.

          In those cases, you can still use the same table, but a script can use duplicate record to create a new copy of each successive record, but labeled with the appropriate status (Work Order or Invoice). This same script can also duplicate your related line items if you are careful in how you set this up.

          • 2. Re: Order Processing
            trizko

            Ok I have the duplicate script figured out(this includes duplicating the related line items). Now I am trying to find a way to relate them.

            • 3. Re: Order Processing
              philmodjunk

              You can define a related table for this with an auto-entered serial number. When you create a new Quote, a script can create a new record in this related table and enter it's serial number in a field in the quote record. When you duplicate this record to create Work Orders and invoices, this field will also be duplicated and thus all three records for the same transaction will have this common serial number from the related table.

              • 4. Re: Order Processing
                trizko

                ok so how would i configure the tables and table occurrences?

                • 5. Re: Order Processing
                  trizko

                  OOOooo I see what your saying... So this related table just has one field that is a auto enter serial, and is only used for relating the records with each other

                  • 6. Re: Order Processing
                    philmodjunk

                    You might use two fields, QuoteID and SerialNumber and use this relationship to add the serial number to your Quote record:

                    Invoices::InvoiceID = masterSerial::QuoteID  // enable "allow creation of records via this relationship for MasterSerial

                    This script then can be used to generate the serial number field:
                    If [INvoices::InvoiceStatus = "Quote"]
                       Set Field [MasterSerial::QuoteID ; Invoices::InvoiceID ]
                       Set Field [Invoices::MasterSerial ; MasterSerial::SerialNumber]
                    ENd IF

                    This can be run from an OnRecordCommit script trigger set on your Quotes layout. If the related record in MasterSerial does not exist, the record is created and the MasterSerial field in Invoices is updated to receive this new number. If the related record already exists, nothing changes.

                    • 7. Re: Order Processing
                      trizko

                      [Orders]>---[MasterSerial]

                      Ok i get that, cause there will many orders to one master serial. But what is the point of having the MasterSerial::SerialNumber Field?

                      • 8. Re: Order Processing
                        philmodjunk

                        Actually it's Orders----MasterSerial The relationship is based on the serial number in Orders which is unique with each new record. The only purpose to that relationship is to assign a unique serial number to each new quote.

                        There will be exactly one order to a given master serial number, but up to three records in the orders table, Quote, Work Order and Invoice would have that same number as they would document different stages of the same order.

                        You could define another relationship:

                        orders::MasterSerial = SameOrder::MasterSerial

                        where SameOrder is a new table occurrence of Orders. This could enable you to set up a portal that lists all the "phases" that exist for a given order, just to given one possible use for it.

                        SerialNumber is the name I gave to the serial number field that is used to generate the serial number via FileMaker's Auto-enter serial number feature. Please note that my relationship in the last post only links a Quote record to this table. The MasterSerial field in orders allows you to keep your Quote, WorkOrder and Invoice for a given order linked.

                        I've set it up this way for two reasons:

                        1. It allows you to generate a serial number "on command" that is not unique to one record in Invoices the way it would if you defined it in Invoices.
                        2. It will work faultlessly in a multi-user environment where you might have more than one user generating new Quote records (and their master serial numbers ) simultaneously--a situation where many other approaches run the risk of allow duplicate numbers to be created.

                         

                        It occurs to me that you may not always start with a quote in every case (repeat orders come to mind). You may need to modify this approach so that a WorkOrder with no master serial number can also generate this value so that its invoice record will have the same value.

                        • 9. Re: Order Processing
                          trizko

                          I swear I should be paying you for all the help you've been giving me lol. Again thanks a ton.