hedera-web/js/htk/repeater.js

249 lines
4.5 KiB
JavaScript
Raw Normal View History

2016-09-26 09:28:47 +00:00
module.exports = new Class
2015-03-09 08:36:54 +00:00
({
2017-10-18 16:01:21 +00:00
Extends: Vn.Component
2015-03-09 08:36:54 +00:00
,Tag: 'htk-repeater'
2015-07-23 15:58:48 +00:00
,Child: 'model'
2015-03-09 08:36:54 +00:00
,Properties:
{
2015-11-19 13:57:23 +00:00
/**
* The source data model.
2016-12-20 09:32:17 +00:00
*/
2015-03-09 08:36:54 +00:00
model:
{
type: Db.Model
,set: function (x)
{
this.link ({_model: x},
{
'status-changed': this._onModelChange
,'row-deleted': this._onRowDelete
,'row-updated': this._onRowUpdate
,'row-inserted': this._onRowInsert
2015-03-09 08:36:54 +00:00
});
this._onModelChange ();
2015-03-09 08:36:54 +00:00
}
,get: function ()
{
this._model;
}
}
2015-11-19 13:57:23 +00:00
/**
* The identifier for internal iterator.
2016-12-20 09:32:17 +00:00
*/
2015-03-09 08:36:54 +00:00
,formId:
{
type: String
,set: function (x)
{
2015-11-09 08:14:33 +00:00
this._formId = x;
2015-03-09 08:36:54 +00:00
}
,get: function ()
{
2015-11-09 08:14:33 +00:00
this._formId;
2015-03-09 08:36:54 +00:00
}
2015-07-03 05:49:45 +00:00
}
2015-11-19 13:57:23 +00:00
/**
2017-05-22 07:08:21 +00:00
* {Function (Vn.BuilderResult, Vn.Iterator)} Function to call after
2017-04-24 07:47:56 +00:00
* every box rendering.
2016-12-20 09:32:17 +00:00
*/
2015-07-03 05:49:45 +00:00
,renderer:
{
type: Function
,set: function (x)
{
this._renderer = x;
}
,get: function ()
{
this._renderer;
}
}
2015-11-19 13:57:23 +00:00
/**
* Message that should be displayed when source model is not ready.
2016-12-20 09:32:17 +00:00
*/
2015-07-03 05:49:45 +00:00
,emptyMessage:
2015-03-15 12:44:57 +00:00
{
type: String
,value: null
2015-03-09 08:36:54 +00:00
}
}
2015-11-09 08:14:33 +00:00
,_builder: null
,_formId: 'form'
2017-10-18 16:01:21 +00:00
,_parentScope: null
2015-03-09 08:36:54 +00:00
2016-10-16 14:16:08 +00:00
,render: function ()
2015-03-09 08:36:54 +00:00
{
2016-10-16 14:16:08 +00:00
var div = this.createRoot ('div');
2016-10-16 14:16:08 +00:00
this._container = this.createElement ('div');
this._container.className = 'htk-repeater';
div.appendChild (this._container);
2015-03-09 08:36:54 +00:00
}
2017-10-18 16:01:21 +00:00
,loadXml: function (scope, node)
2015-03-09 08:36:54 +00:00
{
2017-10-18 16:01:21 +00:00
this.parent (scope, node);
2015-07-23 15:58:48 +00:00
2015-11-09 08:14:33 +00:00
var builder = this._builder = new Vn.Builder ();
2017-10-18 16:01:21 +00:00
builder.compileNode (node.firstElementChild);
2015-11-09 08:14:33 +00:00
2017-10-18 16:01:21 +00:00
this._parentScope = scope;
this._onModelChange ();
2015-03-09 08:36:54 +00:00
}
2015-03-15 12:44:57 +00:00
2015-07-10 12:30:08 +00:00
,getChild: function (index)
{
return this._container.childNodes[index];
2015-07-10 12:30:08 +00:00
}
2017-10-18 16:01:21 +00:00
,getScope: function (index)
2015-07-23 15:58:48 +00:00
{
2017-10-18 16:01:21 +00:00
return this._childsData[index].scope;
2015-07-23 15:58:48 +00:00
}
,getForm: function (index)
{
return this._childsData[index].set;
2015-07-23 15:58:48 +00:00
}
,_buildBox: function (index)
2015-03-15 12:44:57 +00:00
{
2017-05-22 07:08:21 +00:00
var set = new Vn.Iterator ({
2015-11-09 08:14:33 +00:00
model: this._model,
row: index
});
2017-10-18 16:01:21 +00:00
var extraObjects = {};
extraObjects[this._formId] = set;
var scope = this._builder.load (this.doc, null, this._parentScope, extraObjects);
scope.link ();
2015-07-23 15:58:48 +00:00
this._childsData.push ({
2017-10-18 16:01:21 +00:00
scope: scope,
set: set
2015-07-23 15:58:48 +00:00
});
2015-07-03 05:49:45 +00:00
if (this._renderer)
2017-10-18 16:01:21 +00:00
this._renderer (scope, set);
2017-10-18 16:01:21 +00:00
return scope.getMain ();
2015-03-15 12:44:57 +00:00
}
2015-03-09 08:36:54 +00:00
,_onModelChange: function ()
2015-03-09 08:36:54 +00:00
{
2015-11-09 08:14:33 +00:00
if (!this._model || !this._builder)
2015-03-09 08:36:54 +00:00
return;
this.node.removeChild (this._container);
Vn.Node.removeChilds (this._container);
this._freeChildsData ();
this._childsData = [];
2015-03-09 08:36:54 +00:00
2015-03-15 12:44:57 +00:00
switch (this._model.status)
2015-03-09 08:36:54 +00:00
{
2015-03-15 12:44:57 +00:00
case Db.Model.Status.READY:
{
for (var i = 0; i < this._model.numRows; i++)
this._container.appendChild (this._buildBox (i));
2015-03-09 08:36:54 +00:00
this._showNoRecordsFound ();
2015-03-15 12:44:57 +00:00
break;
}
case Db.Model.Status.LOADING:
2015-11-19 13:57:23 +00:00
this._showMessage (_('Loading'), null);
2015-03-15 12:44:57 +00:00
break;
case Db.Model.Status.CLEAN:
{
var emptyMessage = this.emptyMessage ?
this.emptyMessage : _('NoData');
this._showMessage (emptyMessage, 'refresh');
2015-03-15 12:44:57 +00:00
break;
}
2015-03-15 12:44:57 +00:00
case Db.Model.Status.ERROR:
2016-09-26 09:28:47 +00:00
this._showMessage (_('ErrorLoadingData'), 'error');
2015-03-15 12:44:57 +00:00
break;
2015-03-09 08:36:54 +00:00
}
2015-11-19 13:57:23 +00:00
this.node.appendChild (this._container);
2017-04-19 06:16:37 +00:00
this.emit ('change');
2015-03-09 08:36:54 +00:00
}
2017-04-21 10:53:15 +00:00
,_showNoRecordsFound: function ()
2015-03-09 08:36:54 +00:00
{
if (this._model.numRows === 0)
2016-09-26 09:28:47 +00:00
this._showMessage (_('EmptyList'), 'clean');
2015-03-15 12:44:57 +00:00
}
,_showMessage: function (message, src)
2015-03-15 12:44:57 +00:00
{
2016-10-16 14:16:08 +00:00
var div = this.createElement ('div');
2015-03-15 12:44:57 +00:00
div.className = 'message';
this._container.appendChild (div);
2015-03-15 12:44:57 +00:00
2015-11-19 13:57:23 +00:00
if (src)
{
2016-10-16 14:16:08 +00:00
var img = this.createElement ('img');
2015-11-19 13:57:23 +00:00
img.alt = '';
2016-09-26 09:28:47 +00:00
img.src = 'image/icon/light/'+ src +'.svg';
2015-11-19 13:57:23 +00:00
div.appendChild (img);
}
else
{
var spinner = new Htk.Spinner ();
spinner.start ();
2016-10-16 14:16:08 +00:00
div.appendChild (spinner.node);
2015-11-19 13:57:23 +00:00
}
2015-03-15 12:44:57 +00:00
2016-10-16 14:16:08 +00:00
div.appendChild (this.createTextNode (message));
2015-03-09 08:36:54 +00:00
}
,_onRowDelete: function (model, row)
2015-03-09 08:36:54 +00:00
{
Vn.Node.remove (this._container.childNodes[row]);
this._unrefChildData (row);
this._childsData.splice (row, 1);
for (var i = row; i < this._model.numRows; i++)
this._childsData[i].set.row = i;
this._showNoRecordsFound ();
2015-03-09 08:36:54 +00:00
}
,_onRowUpdate: function (model, row, columns)
2015-03-09 08:36:54 +00:00
{
2017-03-30 11:44:53 +00:00
this._childsData[row].set.changed ();
2015-03-09 08:36:54 +00:00
}
,_onRowInsert: function (model, row)
2015-03-09 08:36:54 +00:00
{
var box = this._buildBox (row);
this._container.appendChild (box);
2015-03-09 08:36:54 +00:00
}
,_freeChildsData: function ()
{
if (this._childsData)
for (var i = 0; i < this._childsData.length; i++)
this._unrefChildData (i);
}
,_unrefChildData: function (index)
{
var childData = this._childsData[index];
childData.set.unref ();
2017-10-18 16:01:21 +00:00
childData.scope.unref ();
}
2017-04-10 15:17:56 +00:00
,_destroy: function ()
{
this._freeChildsData ();
this.parent ();
}
2015-03-09 08:36:54 +00:00
});