hedera-web/js/htk/field/combo.js

352 lines
5.9 KiB
JavaScript
Raw Normal View History

2016-09-26 09:28:47 +00:00
var ColumnText = require ('../column/text');
module.exports = new Class
({
Extends: Htk.Field
2017-05-22 07:08:21 +00:00
,Implements: Vn.Iterator
,Tag: 'htk-combo'
,Properties:
{
/**
* The model associated to this form.
2016-12-20 09:32:17 +00:00
*/
model:
{
type: Db.Model
,set: function (x)
{
this.link ({_model: x}, {'status-changed-after': this._onModelChange});
2015-11-19 13:57:23 +00:00
this._onModelChange ();
}
,get: function ()
{
return this._model;
}
2015-07-03 05:49:45 +00:00
},
/**
* The row where the form positioned, has -1 if the row is unselected.
2016-12-20 09:32:17 +00:00
*/
2015-07-03 05:49:45 +00:00
row:
{
type: Number
,set: function (x)
{
if (!this._model || this._model.numRows <= x || x < -1)
x = -1;
if (x == this._row)
return;
this._row = x;
2017-05-22 07:08:21 +00:00
this.rowChanged ();
2015-07-03 05:49:45 +00:00
}
,get: function ()
{
return this._row;
}
},
/**
* The number of rows in the form.
2016-12-20 09:32:17 +00:00
*/
2015-07-03 05:49:45 +00:00
numRows:
{
type: Number
,get: function ()
{
if (this._model)
return this._model.numRows;
return 0;
}
},
/**
* Checks if the form data is ready.
2016-12-20 09:32:17 +00:00
*/
2015-07-03 05:49:45 +00:00
ready:
{
type: Boolean
,get: function ()
{
2015-11-19 13:57:23 +00:00
return this._model && this._model.ready;
2015-07-03 05:49:45 +00:00
}
2015-09-28 11:37:31 +00:00
},
/**
* Checks if the form data is ready.
2016-12-20 09:32:17 +00:00
*/
2015-09-28 11:37:31 +00:00
placeholder:
{
type: String
,set: function (x)
{
this._placeholder = x;
this._refreshShowText (x);
2015-09-28 11:37:31 +00:00
}
,get: function ()
{
return this._placeholder;
}
},
/**
* Wether to allow null values.
2016-12-20 09:32:17 +00:00
*/
notNull:
{
type: Boolean
,set: function (x)
{
this._notNull = x;
}
,get: function ()
{
return this._notNull;
2015-07-03 05:49:45 +00:00
}
2017-04-08 11:42:27 +00:00
},
2017-11-20 12:15:01 +00:00
/**
* The field to use for internal value.
*/
valueField:
{
type: String,
value: 'id'
},
/**
* The field to display.
*/
showField:
{
type: String,
value: 'name'
},
2017-04-08 11:42:27 +00:00
params:
2017-05-22 07:08:21 +00:00
{
type: Object
,set: function (x)
{
this.setAll (x);
}
,get: function ()
{
return this._params;
}
}
,$:
2017-04-08 11:42:27 +00:00
{
type: Object
,set: function (x)
{
2017-05-22 07:08:21 +00:00
this.setAll (x);
2017-04-08 11:42:27 +00:00
}
,get: function ()
{
2017-05-22 07:08:21 +00:00
return this._params;
2017-04-08 11:42:27 +00:00
}
}
}
2015-07-03 05:49:45 +00:00
,_row: -1
,_model: null
2017-11-16 14:53:20 +00:00
,_notNull: false
2017-11-20 18:01:14 +00:00
,_selected: false
2016-10-16 14:16:08 +00:00
,render: function ()
{
2017-11-16 14:53:20 +00:00
var node = this.createRoot ('div');
2017-11-22 12:25:19 +00:00
Vn.Node.addClass (node, 'input clickable');
2017-11-20 12:15:01 +00:00
node.tabIndex = 0;
node.addEventListener ('mousedown',
this._onMouseDown.bind (this));
var icons = this.createElement ('div');
icons.className = 'icons';
node.appendChild (icons);
2017-11-16 14:53:20 +00:00
var clearButton = this.createElement ('htk-icon');
2017-11-20 12:15:01 +00:00
clearButton.className = 'clear button';
2017-11-16 14:53:20 +00:00
clearButton.icon = 'close';
2017-11-20 12:15:01 +00:00
clearButton.node.title = _('Clear');
2017-11-16 14:53:20 +00:00
clearButton.on ('click', this._onClearClick, this);
2017-11-20 12:15:01 +00:00
clearButton.on ('mousedown', this._onClearMouseDown, this);
icons.appendChild (clearButton.node);
var downIcon = this.createElement ('htk-icon');
downIcon.className = 'down';
downIcon.icon = 'down';
icons.appendChild (downIcon.node);
2017-11-16 14:53:20 +00:00
2017-11-20 12:15:01 +00:00
var text = this.createElement ('div');
text.className = 'text';
node.appendChild (text);
2017-11-16 14:53:20 +00:00
2017-11-20 12:15:01 +00:00
this.text = text;
2017-11-16 14:53:20 +00:00
this.clearButton = clearButton;
this._refreshShowText ();
}
,_onClearClick: function ()
{
this.value = null;
}
2017-11-20 12:15:01 +00:00
,_onClearMouseDown: function (_, event)
{
event.preventDefault ();
}
2017-11-20 12:15:01 +00:00
,_onMouseDown: function (e)
{
2017-11-20 12:15:01 +00:00
if (e.defaultPrevented)
return;
if (this._popup)
{
this._popup.hide ();
return;
}
var model = this._model;
2017-11-20 18:01:14 +00:00
if (model.status === Db.Model.Status.CLEAN)
model.refresh ();
2016-10-16 14:16:08 +00:00
var menu = this.createElement ('div');
2017-11-16 14:53:20 +00:00
menu.className = 'htk-combo-menu';
var grid = new Htk.Grid ({showHeader: false});
2016-10-16 14:16:08 +00:00
menu.appendChild (grid.node);
2016-10-16 14:16:08 +00:00
var gridNode = grid.node;
2017-10-28 15:13:00 +00:00
gridNode.addEventListener ('click',
this._onGridClicked.bind (this, grid));
2017-11-16 14:53:20 +00:00
var column = new ColumnText ({column: this.showField});
grid.appendColumn (column);
grid.model = model;
var popup = this._popup = new Htk.Popup ({childNode: menu});
popup.on ('closed', this._onPopupClose.bind (this));
2017-03-22 16:57:21 +00:00
popup.show (this.node, true, e);
2017-04-19 06:16:37 +00:00
this.emit ('menu-show');
}
,_onGridClicked: function (grid, e)
{
2017-11-20 12:15:01 +00:00
e.stopPropagation ();
var target = e.target;
var parentNode = target.parentNode;
while (parentNode !== grid.tbody)
{
target = parentNode;
parentNode = parentNode.parentNode;
}
var value;
var row = target.rowIndex - 1;
if (row >= 0)
2017-11-16 14:53:20 +00:00
value = this._model.get (row, this.valueField);
else
value = null;
this._popup.hide ();
2017-11-20 12:15:01 +00:00
var changed = this._putValue (value);
2017-11-20 18:01:14 +00:00
this._selected = false;
this._setRow (row, true);
2017-11-20 12:15:01 +00:00
if (changed)
{
if (this.conditionalFunc)
this.conditionalFunc (this, newValue);
this._notifyChanges ();
}
}
,_onPopupClose: function ()
{
this._popup = null;
2017-04-19 06:16:37 +00:00
this.emit ('menu-hide');
}
2017-11-20 18:01:14 +00:00
,_setRow: function (row)
{
2017-11-20 18:01:14 +00:00
this._row = row;
2015-09-28 11:37:31 +00:00
2017-11-20 18:01:14 +00:00
if (!this._selected)
2017-11-16 14:53:20 +00:00
{
2017-11-20 18:01:14 +00:00
if (row != -1)
this._selected = true;
this.rowChanged ();
this._refreshShowText ();
2017-11-16 14:53:20 +00:00
}
}
2017-11-20 18:01:14 +00:00
2015-11-19 13:57:23 +00:00
,_onModelChange: function ()
{
var model = this._model;
2017-04-19 06:16:37 +00:00
this.emit ('status-changed');
2015-10-14 11:51:43 +00:00
if (this._popup)
this._popup.reset ();
2017-11-20 18:01:14 +00:00
this._selectOption ();
if (model && model.ready)
2017-04-19 06:16:37 +00:00
this.emit ('ready');
}
,_selectOption: function ()
{
2015-07-03 05:49:45 +00:00
var row;
2015-10-14 11:51:43 +00:00
if (this._model && this._model.ready)
2017-11-16 14:53:20 +00:00
row = this._model.search (this.valueField, this._value);
2015-07-03 05:49:45 +00:00
else
row = -1;
this._setRow (row);
}
2017-11-20 12:15:01 +00:00
,_putFieldValue: function ()
{
2017-11-20 18:01:14 +00:00
this._selected = false;
this._selectOption ();
}
2017-11-20 18:01:14 +00:00
,_refreshShowText: function ()
{
var model = this._model;
if (this._value != null)
var showText = this.$[this.showField];
else if (model && model.status === Db.Model.Status.LOADING)
var showText = _('Loading...');
else if (this._placeholder)
var showText = this._placeholder;
else
var showText = '';
if (this.node)
{
var display;
if (this._value && !this._notNull)
display = '';
else
display = 'none';
this.clearButton.node.style.display = display;
Vn.Node.setText (this.text, showText);
}
}
2017-11-20 12:15:01 +00:00
,setEditable: function (editable)
{
this.node.disabled = !editable;
}
});