90 lines
1.8 KiB
JavaScript
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);
|
|
}
|
|
});
|
|
|