diff options
author | Sebastian Reichel <sre@ring0.de> | 2015-09-15 00:42:50 +0200 |
---|---|---|
committer | Sebastian Reichel <sre@ring0.de> | 2015-09-15 00:42:50 +0200 |
commit | 025fcee561ef9e94580ddf6652bfd1437c3f2524 (patch) | |
tree | 53c762edff27872ef13558c19c09d1cf9989fd17 /src/web/web.vala | |
parent | 1ea4fdf8072d6be99a13cc796c9775c05f8c9498 (diff) | |
download | serial-barcode-scanner-025fcee561ef9e94580ddf6652bfd1437c3f2524.tar.bz2 |
web: new product list sorted by best before date
Diffstat (limited to 'src/web/web.vala')
-rw-r--r-- | src/web/web.vala | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/src/web/web.vala b/src/web/web.vala index 698e2c3..2f3d5b4 100644 --- a/src/web/web.vala +++ b/src/web/web.vala @@ -512,6 +512,39 @@ public class WebServer { } } + void handler_product_bestbefore(Soup.Server server, Soup.Message msg, string path, GLib.HashTable? query, Soup.ClientContext client) { + try { + var l = new WebSession(server, msg, path, query, client); + var t = new WebTemplate("products/bestbefore.html", l); + t.replace("TITLE", "KtT Shop System: Best Before List"); + t.menu_set_active("products"); + + string table = ""; + foreach(var e in db.bestbeforelist()) { + string bbd; + if(e.best_before_date > 0) + bbd = (new DateTime.from_unix_local(e.best_before_date)).format("%Y-%m-%d"); + else + bbd = ""; + + table += @"<tr><td><a href=\"/products/$(e.ean)\">$(e.ean)</a></td><td><a href=\"/products/$(e.ean)\">$(e.name)</a></td><td>$(e.amount)</td><td>$(bbd)</td></tr>"; + } + + t.replace("DATA", table); + + msg.set_response("text/html", Soup.MemoryUse.COPY, t.data); + } catch(TemplateError e) { + stderr.printf(e.message+"\n"); + handler_404(server, msg, path, query, client); + } catch(DatabaseError e) { + stderr.printf(e.message+"\n"); + handler_400(server, msg, path, query, client); + } catch(IOError e) { + stderr.printf(e.message+"\n"); + handler_400(server, msg, path, query, client); + } + } + void handler_product_togglestate(Soup.Server server, Soup.Message msg, string path, GLib.HashTable? query, Soup.ClientContext client, uint64 id) { try { var l = new WebSession(server, msg, path, query, client); @@ -578,7 +611,7 @@ public class WebServer { /* restocks */ string restocks = ""; - foreach(var e in db.get_restocks(id)) { + foreach(var e in db.get_restocks(id, false)) { var time = new DateTime.from_unix_local(e.timestamp); var supplier = db.get_supplier(e.supplier).name; if(supplier == "Unknown") @@ -1286,6 +1319,7 @@ public class WebServer { /* products */ srv.add_handler("/products", handler_products); srv.add_handler("/products/new", handler_products_new); + srv.add_handler("/products/bestbefore", handler_product_bestbefore); srv.add_handler("/aliases", handler_alias_list); srv.add_handler("/aliases/new", handler_alias_new); |