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

75 lines
1.5 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() {
const node = this.createRoot('button');
node.className = 'htk-date-chooser input';
node.addEventListener('click', this._onClick.bind(this));
this.label = this.createElement('span');
node.appendChild(this.label);
const dropDown = new Htk.Icon({
name: 'expand_more'
});
node.appendChild(dropDown.node);
this.setEditable(this._editable);
}
,putValue: 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) {
if (this.calendar) {
this.calendar.disconnectByInstance(this);
this.calendar = null;
}
if (editable) {
this.calendar = new Calendar();
this.calendar.on('changed', this._onCalendarChange.bind(this));
this.popup = new Htk.Popup();
this.popup.child = this.calendar;
}
}
,_onCalendarChange: function(calendar) {
if (this.ignoreCalendarChange)
return;
this.popup.hide();
var newDate = calendar.value;
this.putValue(newDate);
this.valueChanged(newDate);
}
,_onClick: function() {
this.ignoreCalendarChange = true;
this.calendar.value = this._value;
this.calendar.goToSelectedMonth();
this.ignoreCalendarChange = false;
this.popup.show(this.node);
}
});