hedera-web/forms/ecomerce/catalog/catalog.js

541 lines
9.9 KiB
JavaScript
Raw Normal View History

2017-04-19 06:16:37 +00:00
(function () {
var View = {
LIST: 0,
GRID: 1
};
2016-09-26 09:28:47 +00:00
Hedera.Catalog = new Class
({
2016-09-26 09:28:47 +00:00
Extends: Hedera.Form
2015-09-16 16:11:15 +00:00
,_menuShown: false
,open: function ()
{
2015-12-10 13:48:43 +00:00
this.close ();
this.isOpen = true;
2016-09-26 09:28:47 +00:00
if (!localStorage.getItem ('hederaGuest'))
{
2017-09-12 11:31:15 +00:00
Hedera.BasketChecker.check (this.conn, this.params,
this.onBasketCheck.bind (this));
}
else
{
var query = 'CALL basket_configure_for_guest ()';
2015-12-10 13:48:43 +00:00
this.conn.execQuery (query, this.loadUi.bind (this));
}
}
,onBasketCheck: function (isOk)
{
2015-12-10 13:48:43 +00:00
if (isOk)
this.loadUi ();
}
2015-12-10 13:48:43 +00:00
,activate: function ()
{
2017-04-21 10:53:15 +00:00
this.$('items').setInfo ('a', 'Articles', 'vn2008', ['item_id']);
2015-09-16 16:11:15 +00:00
document.body.appendChild (this.$('right-panel'));
2015-09-28 15:21:37 +00:00
2016-09-23 22:47:34 +00:00
if (localStorage.getItem ('hederaView'))
2016-09-26 09:28:47 +00:00
this.setView (parseInt (localStorage.getItem ('hederaView')));
2015-12-10 13:48:43 +00:00
else
2017-04-19 06:16:37 +00:00
this.setView (View.GRID);
2017-04-21 10:53:15 +00:00
this.onRealmChange ();
this.refreshTitle ();
2015-12-10 13:48:43 +00:00
}
2017-09-12 11:31:15 +00:00
2015-12-10 13:48:43 +00:00
,deactivate: function ()
{
2015-12-10 23:24:14 +00:00
this.hideMenu ();
2015-12-10 13:48:43 +00:00
this.gui.$('top-bar').style.backgroundColor = '';
Vn.Node.remove (this.$('right-panel'));
}
2017-09-12 11:31:15 +00:00
2015-09-22 07:20:47 +00:00
,setView: function (view)
{
2017-04-19 06:16:37 +00:00
if (view === View.GRID)
2015-09-22 07:20:47 +00:00
{
this.$('view-button').setProperties ({
2016-09-26 09:28:47 +00:00
icon: 'view-list',
tip: _('List view')
});
2017-04-19 06:16:37 +00:00
this.view = View.GRID;
var className = 'grid-view';
2015-09-22 07:20:47 +00:00
}
else
{
this.$('view-button').setProperties ({
2016-09-27 06:18:20 +00:00
icon: 'view-grid',
tip: _('Grid view')
});
2017-04-19 06:16:37 +00:00
this.view = View.LIST;
var className = 'list-view';
2015-09-22 07:20:47 +00:00
}
2016-10-16 14:16:08 +00:00
var node = this.$('grid-view').node;
node.className = className;
2016-09-23 22:47:34 +00:00
localStorage.setItem ('hederaView', this.view);
2015-12-10 13:48:43 +00:00
}
,onSwitchViewClick: function ()
{
2017-04-19 06:16:37 +00:00
this.setView (this.view === View.LIST ?
View.GRID : View.LIST);
}
2015-02-08 15:38:38 +00:00
,onBasketReady: function (form)
{
if (form.get ('method') != 'PICKUP')
Vn.Node.setText (this.$('method'), _('Agency'));
else
Vn.Node.setText (this.$('method'), _('Warehouse'));
}
,onOrderChange: function (e)
{
var value = e.target.value;
var sortField = value.substr (2);
var sortWay = value.charAt (0) === 'A' ?
Db.Model.SortWay.ASC : Db.Model.SortWay.DESC;
if (sortField)
2017-04-19 06:16:37 +00:00
this.$('items').sortByName (sortField, sortWay);
this.hideMenu ();
}
2017-04-19 06:16:37 +00:00
,shouldRefresh: function ()
{
2017-09-12 11:31:15 +00:00
var params = this.params.$;
2017-04-19 06:16:37 +00:00
if (params.search)
return true;
var refresh = params.realm && (
params.type ||
params.color ||
params.origin ||
params.category ||
params.producer
);
return refresh;
}
2017-04-21 10:53:15 +00:00
,onLotChange: function ()
2017-04-19 06:16:37 +00:00
{
2017-04-21 10:53:15 +00:00
if (this.shouldRefresh ())
{
this.$('items').refresh ();
this.hideMenu ();
this.$('order').style.display = 'block';
}
else
{
this.$('items').clean ();
this.$('order').style.display = 'none';
}
}
2015-07-23 15:58:48 +00:00
,realmRenderer: function (builder, form)
2015-02-08 15:38:38 +00:00
{
2015-07-23 15:58:48 +00:00
var link = builder.$('link');
link.href = this.hash.make ({
2017-09-12 11:31:15 +00:00
form: this.hash.$.form,
realm: form.$.id
2015-07-23 15:58:48 +00:00
});
var img = builder.$('image');
2017-09-12 11:31:15 +00:00
img.src = 'image/family/light/'+ form.$.id +'.svg';
img.title = form.$.name;
2015-07-23 15:58:48 +00:00
img.alt = img.title;
2015-02-08 15:38:38 +00:00
}
2017-04-21 10:53:15 +00:00
,onRealmChange: function ()
2015-02-08 15:38:38 +00:00
{
2017-09-12 11:31:15 +00:00
var newValue = this.params.$.realm;
2017-08-21 10:20:36 +00:00
this.$('filters').style.display = newValue ? 'block' : 'none';
this.$('realm-msg').style.display = newValue ? 'none' : 'block';
2017-04-21 10:53:15 +00:00
this.refreshTitleColor ();
2015-12-10 13:48:43 +00:00
}
2017-04-21 10:53:15 +00:00
2015-12-10 13:48:43 +00:00
,refreshTitleColor: function ()
{
2017-04-19 06:16:37 +00:00
var realms = this.$('realms');
2017-09-12 11:31:15 +00:00
var realm = this.params.$.realm;
2015-02-08 15:38:38 +00:00
var color = null;
2017-04-19 06:16:37 +00:00
2015-12-10 13:48:43 +00:00
if (realm)
2015-07-23 15:58:48 +00:00
{
2015-12-10 13:48:43 +00:00
var row = realms.search ('id', realm);
2015-07-23 15:58:48 +00:00
if (row != -1)
color = '#'+ realms.get (row, 'color');
}
2015-02-08 15:38:38 +00:00
this.gui.$('top-bar').style.backgroundColor = color;
2015-02-08 15:38:38 +00:00
}
2015-12-10 13:48:43 +00:00
,refreshTitle: function ()
2015-02-08 15:38:38 +00:00
{
2017-04-19 06:16:37 +00:00
var types = this.$('types');
2017-09-12 11:31:15 +00:00
var type = this.params.$.type;
2015-07-23 15:58:48 +00:00
var title = _('Catalog');
2017-04-19 06:16:37 +00:00
2015-12-10 13:48:43 +00:00
if (type)
2015-02-08 15:38:38 +00:00
{
2015-12-10 13:48:43 +00:00
var row = types.search ('tipo_id', type);
2015-02-08 15:38:38 +00:00
if (row != -1)
2015-12-10 13:48:43 +00:00
title = types.get (row, 'name');
2015-02-08 15:38:38 +00:00
}
2017-03-17 12:42:10 +00:00
Vn.Node.setText (this.$('title'), title);
2015-02-08 15:38:38 +00:00
}
2015-09-16 16:11:15 +00:00
,onRightPanelClick: function (event)
2015-02-08 15:38:38 +00:00
{
event.stopPropagation ();
}
,onShowMenuClick: function (event)
2015-02-08 15:38:38 +00:00
{
2015-09-16 16:11:15 +00:00
this._menuShown = true;
2015-02-08 15:38:38 +00:00
event.stopPropagation ();
this.gui.showBackground ();
2015-09-16 16:11:15 +00:00
Vn.Node.addClass (this.$('right-panel'), 'show');
2015-02-08 15:38:38 +00:00
this.hideMenuCallback = this.hideMenu.bind (this);
document.addEventListener ('click', this.hideMenuCallback);
}
,hideMenu: function ()
{
2015-09-16 16:11:15 +00:00
if (!this._menuShown)
return;
2015-02-08 15:38:38 +00:00
this.gui.hideBackground ();
2015-09-16 16:11:15 +00:00
Vn.Node.removeClass (this.$('right-panel'), 'show');
2015-02-08 15:38:38 +00:00
document.removeEventListener ('click', this.hideMenuCallback);
this.hideMenuCallback = null;
}
2016-05-04 14:36:51 +00:00
,isGuest: function ()
{
2016-09-26 09:28:47 +00:00
if (localStorage.getItem ('hederaGuest'))
2016-05-04 14:36:51 +00:00
{
Htk.Toast.showError (_('YouMustBeLoggedIn'));
2016-05-04 14:36:51 +00:00
return true;
}
return false;
}
2016-05-04 14:36:51 +00:00
,onBasketClick: function ()
{
2016-05-04 14:36:51 +00:00
if (this.isGuest ())
return;
2017-09-12 11:31:15 +00:00
this.hash.$ = {form: 'ecomerce/basket'};
}
2016-05-04 14:36:51 +00:00
,onConfigureClick: function ()
2015-11-19 13:57:23 +00:00
{
2016-05-04 14:36:51 +00:00
if (this.isGuest ())
return;
2015-11-19 13:57:23 +00:00
2017-09-12 11:31:15 +00:00
this.hash.$ = {form: 'ecomerce/checkout'};
2015-11-19 13:57:23 +00:00
}
2016-05-04 14:36:51 +00:00
,onAddItemClick: function (button, form)
{
2016-05-04 14:36:51 +00:00
if (this.isGuest ())
return;
2015-07-07 15:27:47 +00:00
this.onEraseClick ();
2016-05-04 14:36:51 +00:00
this.$('card').row = form.row;
2017-09-12 11:31:15 +00:00
this.$('card-lot').assign ({item: form.$.item_id});
2016-10-16 14:16:08 +00:00
this.$('card-popup').show (button.node);
2015-07-07 15:27:47 +00:00
}
2017-04-19 06:16:37 +00:00
,onAddLotClick: function (column, value, rowIndex)
{
2017-04-19 06:16:37 +00:00
var row = this.$('item-lots').getObject (rowIndex);
var lotAmount = this.items[row.warehouse];
2015-07-21 14:16:07 +00:00
if (lotAmount === undefined)
lotAmount = 0;
2017-04-19 06:16:37 +00:00
if (lotAmount < row.available)
2015-07-07 15:27:47 +00:00
{
2017-04-19 06:16:37 +00:00
var newAmount = lotAmount + row.grouping;
2017-04-19 06:16:37 +00:00
if (newAmount > row.available)
newAmount = row.available;
2017-04-19 06:16:37 +00:00
this.items[row.warehouse] = newAmount;
this.$('amount').value += newAmount - lotAmount;
2015-07-07 15:27:47 +00:00
}
else
2015-08-17 18:02:14 +00:00
Htk.Toast.showError (_('NoMoreAmountAvailable'));
2015-07-07 15:27:47 +00:00
}
,onConfirmClick: function ()
{
2015-07-21 14:16:07 +00:00
var sql = '';
2017-04-19 06:16:37 +00:00
var query = 'CALL basket_item_add (#warehouse, #item, #amount);';
var amountSum = 0;
2015-07-21 14:16:07 +00:00
for (var warehouse in this.items)
2015-07-07 15:27:47 +00:00
{
var amount = this.items[warehouse];
amountSum += amount;
2017-04-19 06:16:37 +00:00
var params = {
item: this.$('card-item').value,
warehouse: warehouse,
amount: amount
};
sql += this.conn.render (query, params);
2015-07-21 14:16:07 +00:00
}
2017-04-19 06:16:37 +00:00
if (amountSum > 0)
{
2015-07-07 15:27:47 +00:00
this.conn.execQuery (sql);
2017-09-12 11:31:15 +00:00
var itemName = this.$('card').$.Article;
Htk.Toast.showMessage (
sprintf (_('Added%dOf%s'), amountSum, itemName));
}
2016-05-04 14:36:51 +00:00
this.$('card-popup').hide ();
}
2015-07-21 14:16:07 +00:00
2016-05-04 14:36:51 +00:00
,onEraseClick: function ()
{
this.$('amount').value = 0;
this.items = {};
}
,onPopupClose: function ()
2015-07-21 14:16:07 +00:00
{
2016-05-04 14:36:51 +00:00
this.onEraseClick ();
this.$('card').row = -1;
this.$('card-item').value = undefined;
}
2015-11-19 13:57:23 +00:00
2017-03-22 16:57:21 +00:00
,onStatusChange: function ()
2015-11-19 13:57:23 +00:00
{
2016-05-04 14:36:51 +00:00
this.$('card-popup').reset ();
2015-07-21 14:16:07 +00:00
}
});
2015-10-14 11:51:43 +00:00
Vn.Filter = new Class
2015-09-28 09:46:24 +00:00
({
Extends: Htk.Field
2015-10-14 11:51:43 +00:00
,Tag: 'vn-filter'
2015-09-28 09:46:24 +00:00
,Properties:
{
model:
{
type: Db.Model
,set: function (x)
{
this._model = x;
2015-11-19 13:57:23 +00:00
this._select.model = x;
2017-04-21 10:53:15 +00:00
this._refreshModelLot ();
2015-09-28 09:46:24 +00:00
}
,get: function ()
{
return this._model;
}
},
2015-10-14 11:51:43 +00:00
placeholder:
2015-09-28 09:46:24 +00:00
{
type: String
,set: function (x)
{
2015-10-14 11:51:43 +00:00
this._select.placeholder = x;
this._placeholder = x;
2015-09-28 09:46:24 +00:00
}
,get: function ()
{
2015-10-14 11:51:43 +00:00
return this._placeholder;
2015-09-28 09:46:24 +00:00
}
},
filter:
{
type: Sql.Filter
,set: function (x)
{
this._filter = x;
2017-04-19 06:16:37 +00:00
this._modelLot.assign ({filter: x});
2017-04-21 10:53:15 +00:00
this._refreshModelLot ();
}
,get: function ()
{
return this._filter;
}
},
2017-04-19 06:16:37 +00:00
lot:
{
type: Vn.LotIface
,set: function (x)
{
this._modelLot.source = x;
this._setLot (x);
}
,get: function ()
{
return this._lot;
}
},
name:
{
type: String
,set: function (x)
{
this._modelLot.fields = [x];
2017-04-21 10:53:15 +00:00
this._setName (x);
2017-04-19 06:16:37 +00:00
}
,get: function ()
{
return this._name;
}
}
2015-09-28 09:46:24 +00:00
}
2015-11-19 13:57:23 +00:00
,_valueColumnIndex: 0
,_showColumnIndex: 1
2015-10-14 11:51:43 +00:00
2015-09-28 09:46:24 +00:00
,initialize: function (props)
{
2016-10-16 14:16:08 +00:00
var node = this.createRoot ('div');
node.className = 'vn-filter';
2015-09-28 09:46:24 +00:00
2017-03-22 16:57:21 +00:00
this._select = new Htk.Combo ();
this._select.on ('mousedown', this._onMouseDown, this);
this._select.on ('changed', this._onChange, this);
2015-11-19 13:57:23 +00:00
this._select.on ('ready', this._onReady, this);
2016-10-16 14:16:08 +00:00
this.node.appendChild (this._select.node);
2015-09-28 09:46:24 +00:00
2016-10-16 14:16:08 +00:00
this._ul = this.createElement ('ul');
2015-10-14 11:51:43 +00:00
this.node.appendChild (this._ul);
2017-08-21 10:20:36 +00:00
this._modelLot = new Vn.LotQuery ();
2015-11-09 08:14:33 +00:00
this.parent (props);
2015-09-28 09:46:24 +00:00
}
2017-04-19 06:16:37 +00:00
2017-04-21 10:53:15 +00:00
,_refreshModelLot: function ()
2017-04-19 06:16:37 +00:00
{
2017-04-21 10:53:15 +00:00
if (this._model && this._filter)
2017-04-19 06:16:37 +00:00
this._model.lot = this._modelLot;
}
2015-09-28 09:46:24 +00:00
2017-03-22 16:57:21 +00:00
,_onMouseDown: function ()
2015-09-28 09:46:24 +00:00
{
2015-10-14 11:51:43 +00:00
if (this._model && this._model.status === Db.Model.Status.CLEAN)
this._model.refresh ();
2015-10-14 11:51:43 +00:00
}
2017-04-21 10:53:15 +00:00
,_onUnselectClick: function ()
2015-10-14 11:51:43 +00:00
{
2015-11-19 13:57:23 +00:00
this._removeSelectionNode ();
2017-04-21 10:53:15 +00:00
this.valueChanged (undefined);
2015-10-14 11:51:43 +00:00
}
2015-11-19 13:57:23 +00:00
,_removeSelectionNode: function ()
{
if (this._lastLi)
{
Vn.Node.remove (this._lastLi);
this._lastLi = null;
this._label = null;
}
}
2015-10-14 11:51:43 +00:00
,_onChange: function ()
2015-11-19 13:57:23 +00:00
{
2015-10-14 11:51:43 +00:00
if (this._select.value === null
|| this._select.value === undefined)
2015-09-28 09:46:24 +00:00
return;
2017-04-21 10:53:15 +00:00
var value = this._select.value;
this._selectValue (value);
this.valueChanged (value);
2015-11-19 13:57:23 +00:00
}
,_onReady: function ()
{
if (this._emptyLabel)
this._refreshLabel ();
}
,_onTimeout: function ()
{
this._select.value = null;
}
,putValue: function (value)
{
2017-04-21 10:53:15 +00:00
this._selectValue (value);
2015-11-19 13:57:23 +00:00
}
2017-04-21 10:53:15 +00:00
,_selectValue: function (value)
2015-11-19 13:57:23 +00:00
{
this._removeSelectionNode ();
2015-11-19 13:57:23 +00:00
if (value === null || value === undefined)
return;
2016-10-16 14:16:08 +00:00
var li = this._lastLi = this.createElement ('li');
2015-10-14 11:51:43 +00:00
this._ul.appendChild (li);
2016-10-16 14:16:08 +00:00
var button = this.createElement ('button');
2015-10-14 11:51:43 +00:00
button.addEventListener ('click',
2017-04-21 10:53:15 +00:00
this._onUnselectClick.bind (this, li));
2015-10-14 11:51:43 +00:00
li.appendChild (button);
2016-09-26 09:28:47 +00:00
var icon = new Htk.Icon ({
icon: 'close',
alt: _('Close')
});
2016-10-04 15:27:49 +00:00
button.appendChild (icon.node);
2016-10-16 14:16:08 +00:00
var text = this._label = this.createTextNode ('');
2015-10-14 11:51:43 +00:00
li.appendChild (text);
setTimeout (this._onTimeout.bind (this));
2015-11-19 13:57:23 +00:00
this._refreshLabel ();
}
2015-11-19 13:57:23 +00:00
,_refreshLabel: function ()
{
2015-11-19 13:57:23 +00:00
if (!this._label)
return;
2015-10-14 11:51:43 +00:00
2015-11-19 13:57:23 +00:00
var row = -1;
2017-04-21 10:53:15 +00:00
if (this._model && this._model.ready)
2015-11-19 13:57:23 +00:00
row = this._model.searchByIndex (this._valueColumnIndex, this._value);
if (row != -1)
{
var label = this._model.getByIndex (row, this._showColumnIndex);
this._label.nodeValue = label;
this._emptyLabel = false;
}
else
{
this._emptyLabel = true;
this._label.nodeValue = _('Loading...');
}
2015-09-28 09:46:24 +00:00
}
2016-05-04 14:36:51 +00:00
});
2015-09-22 07:25:50 +00:00
2017-04-19 06:16:37 +00:00
})();