-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
101 lines (94 loc) · 3.2 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
var emitter = require('emitter');
var editable = require('editable');
module.exports = makeEditable;
function makeEditable(elements, options) {
options = options || {};
options.displayFormat = options.displayFormat || function (date) {
if (date)
return date.toDateString();
else
return '';
};
options.updateFormat = options.updateFormat || RFCDate;
options.parseDate = options.parseDate || function (dateString) {
return dateString ? new Date(dateString) : null;
};
editable.click(elements, function (element) {
if (element.getAttribute('data-in-edit-mode') == 'true') return;
element.setAttribute('data-in-edit-mode', 'true');
edit(element, options);
});
}
emitter(makeEditable);
function edit(element, options) {
var dimensions;
var oldStyle;
if (options.maintainSize === true) {
dimensions = editable.dimensions(element);
}
emit('pre-begin-edit', element);
var value = options.parseDate(element.textContent.trim());
element.innerHTML = '';
var edit = document.createElement('input');
edit.type = "date";
edit.value = RFCDate(value);
element.appendChild(edit);
if (options.maintainSize === true) {
var editDimensions = editable.transformDimensions(edit, dimensions);
edit.style.width = editDimensions.width + 'px';
edit.style.height = editDimensions.height + 'px';
oldStyle = {width: element.style.width, height: element.style.height};
element.style.width = dimensions.width + 'px';
element.style.height = dimensions.height + 'px';
}
edit.focus();
editable.blur(edit, function () {
if (element.getAttribute('data-in-edit-mode') != 'true') return;
if (!Date.parse(edit.value) && edit.value !== '') {
setTimeout(function () {
edit.focus();
}, 10);
//todo: display validation error
return;
}
element.setAttribute('data-in-edit-mode', 'false');
emit('pre-end-edit', element);
var newVal = edit.value ? new Date(edit.value) : null;
element.innerHTML = options.displayFormat(newVal);
if (options.maintainSize === true) {
element.style.width = oldStyle.width;
element.style.height = oldStyle.height;
}
if (RFCDate(value) != RFCDate(edit.value)) {
emit('update', element, options.updateFormat(newVal));
}
emit('post-end-edit', element);
});
emit('post-begin-edit', element);
}
function emit() {
module.exports.emit.apply(module.exports, arguments);
editable.emit.apply(editable, arguments);
}
function RFCDate(date) {
if (typeof date === 'string') {
date = new Date(date);
}
if (date) {
var day = date.getDate();
var month = date.getMonth() + 1;
var year = date.getFullYear();
if (day < 10) {
day = '0' + day;
}
if (month < 10) {
month = '0' + month;
}
if (year < 1000) {
throw new Error('Does\'t support dates that old');
}
return year + '-' + month + '-' + day;
} else {
return null;
}
}