Monday, July 2, 2012

Fishbowl Inventory Batch Print Packing Slip and Pick Report

As par of the productivity gains services that we offer recently we came across a problem where a warehouse personnel was as part of their shipping and handling routine in Fishbowl Inventory software had print 2 pieces of paper for each order (Packing List & Print Report). Each one of the reports took series of clicks and screens in order to produce final print - in total 16 clicks per order. Now count that on busy days there are about 600 orders and you get one seriously sore index finger.

So we took a deeper look at the process and came up with solution that would batch print entire order load for the day in just 5 clicks total. This report includes two individualized subreports "Packing List" and "Pick Report". There are several things that can cause pain points:

  1. make sure that you are producing and compiling report in the correct version of iReport Designer from Jasper Software. You can find correct corresponding versions to your Fishbowl Server here
  2. Make sure that your iReport Designer is installed on same server as the Fishbowl server and that it has all Fishbowl .jar files added  (by default this is installed C:\Program Files\Fishbowl\lib). For us installing iReport on separate box could not compile valid reports
  3. Master Batch reports "path" parameter should be empty "" and should be passed on to subreports as well as the "module" parameter
  4. We wanted 2 subreports for each order to be printed back to back so insert page break between two subreports
Lastly there is pretty good number of questions answered on Fishbowl forum & Fishbowl Wiki so I would start there if you have any questions first. Here is our final batch report appropriately called "Batch Pick Pack" (by the way our report has two optional parameters to constrain Order number range and may not be appropriate for your situation - they are Greater Than Order and Less Than Order).

Monday, June 4, 2012

wordpress mysqli class

So recently as it usually a client of ours come with a request for fresher looking website and blog based on wordpress. No big deal, we said we do those with our eyes closed. So after all the development has been finished and we were ready to push it to production server we hit a brick wall. Production server is running a legacy application on php 5 and mysql 4.1 with just mysqli module. So no big deal still - yum update blah blah and all set but not so fast. Server was running a legacy Fedora v1. Getting a push back from client on migration to cloud we had to improvise with mysqli and wordpress. So with two developers exploring options and playing around we finally hit the jackpot with mysqli wpdb class from wordpress's own repo at http://plugins.svn.wordpress.org/performance-testing/trunk/library/db.php and few additions (functions like db_version, tables, get_blog_prefix and class variable $ms_global_tables) to make it work with our version of wordpress (3.1+).

Keep in mind that you should place this file in wp-content folder under name db.php. If you get any errors about wpdb class cannot be re-declared than you know that original wp-includes/wp-db.php file is being loaded before your custom wp-content/db.php so you have two options:
  1. Overwrite contents of wp-includes/wp-db.php with that of wp-content/db.php
  2. Change wp-includes/load.php function require_wp_db() to load original wp-includes/wp-db.php ONLY if wp-content/db.php does not exist. End result:



Here is the final code: