hedera-web/js/htk/field/calendar.js

280 lines
5.5 KiB
JavaScript
Raw Normal View History

2016-09-26 09:28:47 +00:00
2017-10-25 07:47:32 +00:00
var slide = require ('vn/transitions').slide;
2016-09-26 09:28:47 +00:00
module.exports = new Class
({
Extends: Htk.Field
,Tag: 'htk-calendar'
2015-07-15 13:39:07 +00:00
,Properties:
{
restrictFunc:
{
type: Function
,set: function (x)
{
this._restrictFunc = x;
}
2017-10-18 16:01:21 +00:00
,get: function ()
2015-07-15 13:39:07 +00:00
{
return this._restrictFunc;
}
}
}
2015-07-15 13:39:07 +00:00
,cells: []
,selectedCell: -1
,year: null
,month: null
2016-10-16 14:16:08 +00:00
,render: function ()
{
var len = Vn.Date.WDays.length;
2016-10-16 14:16:08 +00:00
var node = this.createRoot ('div');
node.className = 'htk-calendar';
2017-10-25 07:47:32 +00:00
var div = this.createElement ('div');
div.className = 'month';
node.appendChild (div);
2017-10-25 07:47:32 +00:00
var button = this.createElement ('div');
button.appendChild (this.createTextNode ('<'));
button.className = 'button previous';
button.addEventListener ('click', this.prevMonthClicked.bind (this));
div.appendChild (button);
2015-07-15 13:39:07 +00:00
2016-10-16 14:16:08 +00:00
var monthNode = this.createElement ('span');
2017-10-25 07:47:32 +00:00
div.appendChild (monthNode);
2015-07-15 13:39:07 +00:00
2016-10-16 14:16:08 +00:00
var space = this.createTextNode (' ');
2017-10-25 07:47:32 +00:00
div.appendChild (space);
2015-07-15 13:39:07 +00:00
2016-10-16 14:16:08 +00:00
var yearNode = this.createElement ('span');
2017-10-25 07:47:32 +00:00
div.appendChild (yearNode);
var button = this.createElement ('div');
button.appendChild (this.createTextNode ('>'));
button.className = 'button next';
button.addEventListener ('click', this.nextMonthClicked.bind (this));
div.appendChild (button);
var wrapper = this.createElement ('div');
wrapper.className = 'wrapper';
node.appendChild (wrapper);
var table = this.createElement ('table');
wrapper.appendChild (table);
this.table = table;
2017-10-25 07:47:32 +00:00
var thead = this.createElement ('thead');
table.appendChild (thead);
2016-10-16 14:16:08 +00:00
var tr = this.createElement ('tr');
2017-10-25 07:47:32 +00:00
tr.className = 'wdays';
thead.appendChild (tr);
2015-07-17 14:34:42 +00:00
for (var i = 1; i <= len; i++)
{
2016-10-16 14:16:08 +00:00
var th = this.createElement ('th');
tr.appendChild (th);
var weekday = _(Vn.Date.AbrWDays [i%len]);
2016-10-16 14:16:08 +00:00
th.appendChild (this.createTextNode (weekday));
}
2016-10-16 14:16:08 +00:00
var tbody = this.createElement ('tbody');
table.appendChild (tbody);
2015-07-17 14:34:42 +00:00
for (var i = 0; i < 6; i++)
{
2016-10-16 14:16:08 +00:00
var tr = this.createElement ('tr');
tbody.appendChild (tr);
2015-07-17 14:34:42 +00:00
for (var j = 0; j < len; j++)
{
2016-10-16 14:16:08 +00:00
var td = this.createElement ('td');
2017-10-18 16:01:21 +00:00
td.addEventListener ('click',
this.dayClicked.bind (this, td, i * len + j));
tr.appendChild (td);
2015-07-15 13:39:07 +00:00
2016-10-16 14:16:08 +00:00
var div = this.createElement ('div');
2015-07-15 13:39:07 +00:00
td.appendChild (div);
this.cells.push ({
node: div,
enabled: false,
day: -1
});
}
}
this.monthNode = monthNode;
this.yearNode = yearNode;
this.goToCurrentMonth ();
}
,getMonthDays: function ()
{
if (this.month > 6)
return (this.month % 2 != 0) ? 31 : 30;
else if (this.month != 1)
return (this.month % 2 != 1) ? 31 : 30;
else
return (this.year % 4 != 0) ? 28 : 29;
}
,goToMonth: function (year, month)
{
if (year)
this.year = year;
2015-01-31 01:05:12 +00:00
if (!isNaN (month))
this.month = month;
this.refresh ();
}
,goToSelectedMonth: function ()
{
var date = this._value;
if (date instanceof Date)
this.goToMonth (date.getFullYear (), date.getMonth ());
else
this.goToCurrentMonth ();
}
,goToCurrentMonth: function ()
{
var date = new Date ();
this.goToMonth (date.getFullYear (), date.getMonth ());
}
,refresh: function ()
{
Vn.Node.setText (this.yearNode, this.year);
Vn.Node.setText (this.monthNode, _(Vn.Date.Months[this.month]));
var day = 1;
2015-07-15 13:39:07 +00:00
var cellDate = new Date (this.year, this.month, 1);
var weekDay = cellDate.getDay ();
var firstWeekDay = (weekDay != 0) ? weekDay - 1 : 6;
var monthDays = this.getMonthDays ();
2015-07-17 14:34:42 +00:00
for (var i = 0; i < this.cells.length; i++)
{
2015-07-15 13:39:07 +00:00
var cell = this.cells[i];
if (firstWeekDay <= i && day <= monthDays)
2015-07-15 13:39:07 +00:00
{
Vn.Node.setText (cell.node, day);
cell.enabled = true;
cell.day = day++;
if (this._restrictFunc)
{
cell.enabled = this._restrictFunc (cellDate);
cellDate.setDate (cellDate.getDate () + 1);
2015-07-15 13:39:07 +00:00
}
}
else
2015-07-15 13:39:07 +00:00
{
Vn.Node.removeChilds (cell.node);
cell.enabled = false;
cell.day = -1;
}
cell.node.className = cell.enabled ? 'enabled' : 'disabled';
}
2015-07-15 13:39:07 +00:00
// Marks the current day
2015-07-15 13:39:07 +00:00
var today = new Date ();
if (this.year == today.getFullYear ()
&& this.month == today.getMonth ())
{
2015-07-15 13:39:07 +00:00
var cellIndex = (firstWeekDay + today.getDate ()) - 1;
Vn.Node.addClass (this.cells[cellIndex].node, 'today');
}
// Marks the selected day
var date = this._value;
if (date instanceof Date
&& this.year == date.getFullYear ()
&& this.month == date.getMonth ())
2015-07-15 13:39:07 +00:00
this.selectCell ((firstWeekDay + date.getDate ()) - 1);
else
2015-07-15 13:39:07 +00:00
this.selectCell (-1);
}
2015-07-15 13:39:07 +00:00
,selectCell: function (cellIndex)
{
2015-07-15 13:39:07 +00:00
if (this.selectedCell != -1)
{
var node = this.cells[this.selectedCell].node;
Vn.Node.removeClass (node, 'selected');
}
if (cellIndex != -1)
{
var node = this.cells[cellIndex].node;
Vn.Node.addClass (node, 'selected');
}
2015-07-15 13:39:07 +00:00
this.selectedCell = cellIndex;
}
2017-10-18 16:01:21 +00:00
,putValue: function ()
{
this.goToSelectedMonth ();
}
2015-07-15 13:39:07 +00:00
,dayClicked: function (td, cellIndex)
{
2015-07-15 13:39:07 +00:00
var cell = this.cells[cellIndex];
if (cell.enabled)
{
2015-07-15 13:39:07 +00:00
this.selectCell (cellIndex);
2015-07-15 13:39:07 +00:00
var newDate = new Date (this.year, this.month, cell.day);
2017-10-18 16:01:21 +00:00
this.emit ('pick', newDate);
this.valueChanged (newDate);
}
}
,prevMonthClicked: function ()
{
if (this.month > 0)
this.month--;
else
{
this.month = 11;
this.year--;
}
2017-10-25 07:47:32 +00:00
this.refreshSlide ('right');
}
,nextMonthClicked: function ()
{
if (this.month < 11)
this.month++;
else
{
this.month = 0;
this.year++;
}
2017-10-25 07:47:32 +00:00
this.refreshSlide ('left');
}
,refreshSlide: function (way)
{
var cb = this.refresh.bind (this);
slide (this.table, way, cb);
}
});