forked from verdnatura/hedera-web
124 lines
2.1 KiB
JavaScript
124 lines
2.1 KiB
JavaScript
|
|
var LotIface = require ('./lot-iface');
|
|
var ModelIface = require ('./model-iface');
|
|
|
|
module.exports = new Class
|
|
({
|
|
Implements: LotIface
|
|
,Properties:
|
|
{
|
|
/**
|
|
* The model associated to this form.
|
|
*/
|
|
model:
|
|
{
|
|
type: ModelIface
|
|
},
|
|
/**
|
|
* The row where the form positioned, has -1 if the row is unselected.
|
|
*/
|
|
row:
|
|
{
|
|
type: Number
|
|
},
|
|
/**
|
|
* The number of rows in the form.
|
|
*/
|
|
numRows:
|
|
{
|
|
type: Number
|
|
},
|
|
/**
|
|
* Checks if the form data is ready.
|
|
*/
|
|
ready:
|
|
{
|
|
type: Boolean
|
|
}
|
|
}
|
|
|
|
,refresh: function ()
|
|
{
|
|
if (this._model)
|
|
this._model.refresh ();
|
|
}
|
|
|
|
/**
|
|
* Get the index of the column from its name.
|
|
*
|
|
* @param {string} columnName The column name
|
|
* @return {integer} The column index or -1 if column not exists
|
|
*/
|
|
,getColumnIndex: function (columnName)
|
|
{
|
|
return this._model ?
|
|
this._model.getColumnIndex (columnName) : -1;
|
|
}
|
|
|
|
,insertRow: function ()
|
|
{
|
|
if (this._model)
|
|
this.row = this._model.insertRow ();
|
|
}
|
|
|
|
,performOperations: function ()
|
|
{
|
|
if (this._model)
|
|
this._model.performOperations ();
|
|
}
|
|
|
|
/**
|
|
* Removes the current row.
|
|
*/
|
|
,deleteRow: function ()
|
|
{
|
|
if (this._row >= 0)
|
|
this._model.deleteRow (this._row);
|
|
}
|
|
|
|
/**
|
|
* Gets a value from the form.
|
|
*
|
|
* @param {string} columnName The column name
|
|
* @return {Object} The value
|
|
*/
|
|
,get: function (columnName)
|
|
{
|
|
return this._model ?
|
|
this._model.get (this._row, columnName) : undefined;
|
|
}
|
|
|
|
/**
|
|
* Sets a value on the form.
|
|
*
|
|
* @param {string} columnName The column name
|
|
* @param {Object} value The new value
|
|
*/
|
|
,set: function (columnName, value)
|
|
{
|
|
this._model.set (this._row, columnName, value);
|
|
}
|
|
|
|
/**
|
|
* Gets a value from the form using the column index.
|
|
*
|
|
* @param {string} columnName The column index
|
|
* @return {Object} The value
|
|
*/
|
|
,getByIndex: function (column)
|
|
{
|
|
return this._model.getByIndex (this._row, column);
|
|
}
|
|
|
|
/**
|
|
* Sets a value on the form using the column index.
|
|
*
|
|
* @param {string} columnName The column index
|
|
* @param {Object} value The new value
|
|
*/
|
|
,setByIndex: function (column, value)
|
|
{
|
|
return this._model.setByIndex (this._row, column, value);
|
|
}
|
|
});
|