2015-01-23 13:09:30 +00:00
|
|
|
|
2019-05-27 13:38:06 +00:00
|
|
|
var Widget = require('./widget');
|
2016-09-26 09:28:47 +00:00
|
|
|
|
2019-05-27 13:38:06 +00:00
|
|
|
module.exports = new Class({
|
2016-09-26 09:28:47 +00:00
|
|
|
Extends: Widget
|
2015-01-23 13:09:30 +00:00
|
|
|
,Tag: 'htk-field'
|
|
|
|
,Child: 'param'
|
|
|
|
,Properties:
|
|
|
|
{
|
2019-05-27 13:38:06 +00:00
|
|
|
value: {
|
2015-07-03 05:49:45 +00:00
|
|
|
type: String
|
2019-05-27 13:38:06 +00:00
|
|
|
,set: function(x) {
|
|
|
|
if (Vn.Value.compare(x, this._value))
|
2015-01-23 13:09:30 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
if (x instanceof Date)
|
2019-05-27 13:38:06 +00:00
|
|
|
x = x.clone();
|
2015-01-23 13:09:30 +00:00
|
|
|
|
2019-05-27 13:38:06 +00:00
|
|
|
this.valueChanged(x);
|
|
|
|
this.putValue(x);
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
2019-05-27 13:38:06 +00:00
|
|
|
,get: function(x) {
|
2015-01-23 13:09:30 +00:00
|
|
|
return this._value;
|
|
|
|
}
|
|
|
|
},
|
2019-05-27 13:38:06 +00:00
|
|
|
param: {
|
2015-01-23 13:09:30 +00:00
|
|
|
type: Vn.Param
|
2019-05-27 13:38:06 +00:00
|
|
|
,set: function(x) {
|
|
|
|
this.link({_param: x}, {'changed': this.onParamChange});
|
|
|
|
this.onParamChange();
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
2019-05-27 13:38:06 +00:00
|
|
|
,get: function() {
|
2015-01-23 13:09:30 +00:00
|
|
|
return this._param;
|
|
|
|
}
|
|
|
|
},
|
2019-05-27 13:38:06 +00:00
|
|
|
editable: {
|
2015-01-23 13:09:30 +00:00
|
|
|
type: Boolean
|
2019-05-27 13:38:06 +00:00
|
|
|
,set: function(x) {
|
|
|
|
if (x != this._editable) {
|
2015-01-23 13:09:30 +00:00
|
|
|
this._editable = x;
|
2019-05-27 13:38:06 +00:00
|
|
|
this.setEditable(x);
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
|
|
|
}
|
2019-05-27 13:38:06 +00:00
|
|
|
,get: function() {
|
2015-01-23 13:09:30 +00:00
|
|
|
return this._editable;
|
|
|
|
}
|
|
|
|
},
|
2019-05-27 13:38:06 +00:00
|
|
|
form: {
|
2015-11-19 13:57:23 +00:00
|
|
|
type: Db.Iterator
|
2019-05-27 13:38:06 +00:00
|
|
|
,set: function(x) {
|
2015-01-23 13:09:30 +00:00
|
|
|
this._form = x;
|
2019-05-27 13:38:06 +00:00
|
|
|
this.bindToForm();
|
|
|
|
}
|
|
|
|
,get: function() {
|
|
|
|
return this._form;
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
|
|
|
},
|
2019-05-27 13:38:06 +00:00
|
|
|
column: {
|
2015-01-23 13:09:30 +00:00
|
|
|
type: String
|
2019-05-27 13:38:06 +00:00
|
|
|
,set: function(x) {
|
2015-01-23 13:09:30 +00:00
|
|
|
this._paramName = x;
|
2019-05-27 13:38:06 +00:00
|
|
|
this.bindToForm();
|
|
|
|
}
|
|
|
|
,get: function() {
|
|
|
|
return this._paramName;
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
|
|
|
},
|
2019-05-27 13:38:06 +00:00
|
|
|
conditionalFunc: {
|
2015-01-23 13:09:30 +00:00
|
|
|
type: Function
|
|
|
|
,value: null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
,_value: undefined
|
|
|
|
,_param: null
|
|
|
|
,_editable: true
|
2015-06-30 12:06:19 +00:00
|
|
|
,_blockParamChange: false
|
|
|
|
,_blockValueChange: false
|
2015-01-23 13:09:30 +00:00
|
|
|
|
2019-05-27 13:38:06 +00:00
|
|
|
,onParamChange: function() {
|
|
|
|
if (!this._blockValueChange) {
|
2015-06-30 12:06:19 +00:00
|
|
|
this._blockParamChange = true;
|
|
|
|
this.value = this._param.value;
|
|
|
|
this._blockParamChange = false;
|
|
|
|
}
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
|
|
|
|
2019-05-27 13:38:06 +00:00
|
|
|
,bindToForm: function() {
|
2015-01-23 13:09:30 +00:00
|
|
|
if (this._form && this._paramName)
|
2016-09-26 09:28:47 +00:00
|
|
|
this.param = new Db.Param
|
|
|
|
({
|
|
|
|
form: this._form
|
|
|
|
,column: this._paramName
|
|
|
|
});
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Virtual method that must be implemented by class childs to set the entry
|
|
|
|
* editable.
|
|
|
|
*
|
|
|
|
* @param {Boolean} editable Whether the user is allowed to edit the entry
|
2022-05-26 06:08:31 +00:00
|
|
|
*/
|
2019-05-27 13:38:06 +00:00
|
|
|
,setEditable: function(editable) {}
|
2015-01-23 13:09:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Virtual method that must be implemented by class childs to put the value
|
|
|
|
* on the associated entry.
|
|
|
|
*
|
|
|
|
* @param {Object} value The new value for the entry
|
2022-05-26 06:08:31 +00:00
|
|
|
*/
|
2019-05-27 13:38:06 +00:00
|
|
|
,putValue: function(value) {}
|
2015-01-23 13:09:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Protected method that should be called from class childs when the value
|
|
|
|
* on the associated entry changes.
|
|
|
|
*
|
|
|
|
* @param {Object} value The new entry value
|
2022-05-26 06:08:31 +00:00
|
|
|
*/
|
2019-05-27 13:38:06 +00:00
|
|
|
,valueChanged: function(value) {
|
2015-01-23 13:09:30 +00:00
|
|
|
this._value = value;
|
|
|
|
|
|
|
|
if (this.conditionalFunc)
|
2019-05-27 13:38:06 +00:00
|
|
|
this.conditionalFunc(this, value);
|
2015-01-23 13:09:30 +00:00
|
|
|
|
2019-05-27 13:38:06 +00:00
|
|
|
if (this._param && !this._blockParamChange) {
|
2015-06-30 12:06:19 +00:00
|
|
|
this._blockValueChange = true;
|
2015-01-23 13:09:30 +00:00
|
|
|
this._param.value = value;
|
2015-06-30 12:06:19 +00:00
|
|
|
this._blockValueChange = false;
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
|
|
|
|
2019-05-27 13:38:06 +00:00
|
|
|
this.signalEmit('changed');
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|