hedera-web/js/htk/field/date-chooser.js

90 lines
1.8 KiB
JavaScript

var Calendar = require ('./calendar');
module.exports = new Class
({
Extends: Htk.Field
,Tag: 'htk-date-chooser'
,format: _('%a, %e %b %Y')
,calendar: null
,ignoreCalendarChange: false
,render: function ()
{
var node = this.createRoot ('div');
node.className = 'htk-date-chooser';
this.label = this.createElement ('span');
this.node.appendChild (this.label);
this.setEditable (this._editable);
}
,_putFieldValue: function (value)
{
var dateString;
if (value instanceof Date)
dateString = Vn.Date.strftime (value, this.format);
else
dateString = '';
Vn.Node.setText (this.label, dateString);
}
,setEditable: function (editable)
{
Vn.Node.remove (this.label);
if (this.calendar)
{
this.node.removeChild (this.button);
this.calendar.disconnectByInstance (this);
this.calendar = null;
}
if (editable && !this.calendar)
{
this.button = this.createElement ('button');
this.button.className = 'input';
this.button.title = _('ChangeDate');
this.button.addEventListener ('click', this._onClick.bind (this));
this.button.appendChild (this.label);
this.node.appendChild (this.button);
this.calendar = new Calendar ();
this.calendar.on ('changed', this._onCalendarChange.bind (this));
this.popup = new Htk.Popup ();
this.popup.child = this.calendar;
}
else if (!editable)
this.node.appendChild (this.label);
}
,_onCalendarChange: function (calendar)
{
if (this.ignoreCalendarChange)
return;
this.popup.hide ();
var newDate = calendar.value;
this._putFieldValue (newDate);
this._notifyFieldChange (newDate);
}
,_onClick: function ()
{
this.ignoreCalendarChange = true;
this.calendar.value = this._value;
this.calendar.goToSelectedMonth ();
this.ignoreCalendarChange = false;
this.popup.show (this.button);
}
});