forked from verdnatura/hedera-web
140 lines
2.4 KiB
JavaScript
Executable File
140 lines
2.4 KiB
JavaScript
Executable File
|
|
Htk.Field = new Class
|
|
({
|
|
Extends: Htk.Widget
|
|
,Tag: 'htk-field'
|
|
,Child: 'param'
|
|
,Properties:
|
|
{
|
|
value:
|
|
{
|
|
type: Object
|
|
,set: function (x)
|
|
{
|
|
if (Vn.Value.compare (x, this._value))
|
|
return;
|
|
|
|
if (x instanceof Date)
|
|
x = x.clone ();
|
|
|
|
this.valueChanged (x);
|
|
this.putValue (x);
|
|
}
|
|
,get: function (x)
|
|
{
|
|
return this._value;
|
|
}
|
|
},
|
|
param:
|
|
{
|
|
type: Vn.Param
|
|
,set: function (x)
|
|
{
|
|
this.link ({_param: x}, {'changed': this.onParamChange});
|
|
this.onParamChange ();
|
|
}
|
|
,get: function ()
|
|
{
|
|
return this._param;
|
|
}
|
|
},
|
|
editable:
|
|
{
|
|
type: Boolean
|
|
,set: function (x)
|
|
{
|
|
if (x != this._editable)
|
|
{
|
|
this._editable = x;
|
|
this.setEditable (x);
|
|
}
|
|
}
|
|
,get: function ()
|
|
{
|
|
return this._editable;
|
|
}
|
|
},
|
|
form:
|
|
{
|
|
type: Db.Form
|
|
,set: function (x)
|
|
{
|
|
this._form = x;
|
|
this.bindToForm ();
|
|
}
|
|
},
|
|
column:
|
|
{
|
|
type: String
|
|
,set: function (x)
|
|
{
|
|
this._paramName = x;
|
|
this.bindToForm ();
|
|
}
|
|
},
|
|
conditionalFunc:
|
|
{
|
|
type: Function
|
|
,value: null
|
|
}
|
|
}
|
|
|
|
,_value: undefined
|
|
,_param: null
|
|
,_editable: true
|
|
,ignoreParamChange: false
|
|
|
|
,onParamChange: function ()
|
|
{
|
|
this.ignoreParamChange = true;
|
|
this.value = this._param.value;
|
|
this.ignoreParamChange = false;
|
|
}
|
|
|
|
,bindToForm: function ()
|
|
{
|
|
if (this._form && this._paramName)
|
|
this.param = this._form.getParam (this._paramName);
|
|
}
|
|
|
|
/**
|
|
* 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
|
|
**/
|
|
,setEditable: function (editable) {}
|
|
|
|
/**
|
|
* 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
|
|
**/
|
|
,putValue: function (value) {}
|
|
|
|
/**
|
|
* Protected method that should be called from class childs when the value
|
|
* on the associated entry changes.
|
|
*
|
|
* @param {Object} value The new entry value
|
|
**/
|
|
,valueChanged: function (value)
|
|
{
|
|
this._value = value;
|
|
|
|
if (this.conditionalFunc)
|
|
this.conditionalFunc (this, value);
|
|
|
|
if (this._param && !this.ignoreParamChange)
|
|
{
|
|
this._param.blockSignal ('changed', this.onParamChange, true);
|
|
this._param.value = value;
|
|
this._param.blockSignal ('changed', this.onParamChange, false);
|
|
}
|
|
|
|
this.signalEmit ('changed');
|
|
}
|
|
});
|
|
|