Made Diane's suggest json problem fix for python 2.5/2.6 support... now using simplej...
[htsworkflow.git] / htsworkflow / frontend / inventory / views.py
index 9f9207b66739e7e2b80e366d27b0b659bb43c302..7049320c9f79b5fd7adbc0ca4d6dbe3856dc97be 100644 (file)
@@ -1,7 +1,9 @@
 from htsworkflow.frontend.inventory.models import Item, LongTermStorage
 from htsworkflow.frontend.experiments.models import FlowCell
 from htsworkflow.frontend.bcmagic.forms import BarcodeMagicForm
-from htsworkflow.util.jsonutil import encode_json
+from htsworkflow.frontend.bcprinter.util import print_zpl_socket
+from htsworkflow.frontend import settings
+#from htsworkflow.util.jsonutil import encode_json
 
 from django.core.exceptions import ObjectDoesNotExist
 from django.http import HttpResponse, HttpResponseRedirect
@@ -10,13 +12,30 @@ from django.template import RequestContext
 from django.template.loader import get_template
 from django.contrib.auth.decorators import login_required
 
-
+try:
+    import json
+except ImportError, e:
+    import simplejson as json
 
 INVENTORY_CONTEXT_DEFAULTS = {
     'app_name': 'Inventory Tracker',
     'bcmagic': BarcodeMagicForm()
 }
 
+INVENTORY_ITEM_PRINT_DEFAULTS = {
+    'default': 'inventory/default.zpl',
+    'host': settings.BCPRINTER_PRINTER1_HOST
+}
+
+def getTemplateByType(item_type):
+    """
+    returns template to use given item_type
+    """
+    if item_type in INVENTORY_ITEM_PRINT_DEFAULTS:
+        return INVENTORY_ITEM_PRINT_DEFAULTS[item_type]
+    else:
+        return INVENTORY_ITEM_PRINT_DEFAULTS['default']
+
 @login_required
 def data_items(request):
     """
@@ -55,7 +74,7 @@ def data_items(request):
     
     d['rows'] = rows
     
-    return HttpResponse(encode_json(d), content_type="application/javascript")
+    return HttpResponse(json.dumps(d), content_type="application/javascript")
 
 @login_required
 def index(request):
@@ -72,7 +91,7 @@ def index(request):
                               context_instance=RequestContext(request))
     
 @login_required
-def item_summary(request, uuid):
+def item_summary(request, uuid, msg=''):
     """
     Display a summary for an item
     """
@@ -84,7 +103,8 @@ def item_summary(request, uuid):
     context_dict = {
         'page_name': 'Item Summary',
         'item': item,
-        'uuid': uuid
+        'uuid': uuid,
+        'msg': msg
     }
     context_dict.update(INVENTORY_CONTEXT_DEFAULTS)
     
@@ -92,6 +112,46 @@ def item_summary(request, uuid):
                               context_dict,
                               context_instance=RequestContext(request))
 
+
+def _item_print(item, request):
+    """
+    Prints an item given a type of item label to print
+    """
+    #FIXME: Hard coding this for now... need to abstract later.
+    context = {'item': item}
+    
+    # Print using barcode_id
+    if not item.force_use_uuid and (item.barcode_id is None or len(item.barcode_id.strip())):
+        context['use_uuid'] = False
+        msg = 'Printing item with barcode id: %s' % (item.barcode_id)
+    # Print using uuid
+    else:
+        context['use_uuid'] = True
+        msg = 'Printing item with UUID: %s' % (item.uuid)
+    
+    c = RequestContext(request, context)
+    t = get_template(getTemplateByType(item.item_type.name))
+    print_zpl_socket(t.render(c))
+    
+    return msg
+
+@login_required
+def item_print(request, uuid):
+    """
+    Print a label for a given item
+    """
+    try:
+        item = Item.objects.get(uuid=uuid)
+    except ObjectDoesNotExist, e:
+        item = None
+        msg = "Item with UUID %s does not exist" % (uuid)
+    
+    if item is not None:
+        msg = _item_print(item, request)
+    
+    return item_summary(request, uuid, msg)
+
+
 def link_flowcell_and_device(request, flowcell, serial):
     """
     Updates database records of a flowcell being archived on a device with a particular serial #