2015-05-28 17:27:25 -07:00
|
|
|
/**
|
|
|
|
* @provides javelin-behavior-recurring-edit
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
JX.behavior('recurring-edit', function(config) {
|
|
|
|
var checkbox = JX.$(config.isRecurring);
|
2015-06-07 15:57:19 -07:00
|
|
|
var frequency = JX.$(config.frequency);
|
|
|
|
var end_date = JX.$(config.recurrenceEndDate);
|
2015-06-01 18:56:11 -07:00
|
|
|
|
2015-06-07 15:57:19 -07:00
|
|
|
var end_date_checkbox = JX.DOM.find(end_date, 'input', 'calendar-enable');
|
2015-05-28 17:27:25 -07:00
|
|
|
|
2015-06-07 15:57:19 -07:00
|
|
|
JX.DOM.listen(checkbox, 'change', null, function() {
|
|
|
|
if (checkbox.checked) {
|
|
|
|
enableRecurring();
|
|
|
|
} else {
|
|
|
|
disableRecurring();
|
|
|
|
}
|
|
|
|
});
|
2015-06-01 18:56:11 -07:00
|
|
|
|
2015-06-07 15:57:19 -07:00
|
|
|
JX.DOM.listen(end_date, 'change', null, function() {
|
|
|
|
if (end_date_checkbox.checked) {
|
|
|
|
enableRecurring();
|
2015-06-01 18:56:11 -07:00
|
|
|
}
|
2015-05-28 17:27:25 -07:00
|
|
|
});
|
|
|
|
|
2015-06-07 15:57:19 -07:00
|
|
|
function enableRecurring() {
|
|
|
|
checkbox.checked = true;
|
|
|
|
frequency.disabled = false;
|
|
|
|
end_date.disabled = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function disableRecurring() {
|
|
|
|
checkbox.checked = false;
|
|
|
|
frequency.disabled = true;
|
|
|
|
end_date.disabled = true;
|
|
|
|
end_date_checkbox.checked = false;
|
|
|
|
|
|
|
|
JX.DOM.alterClass(end_date, 'datepicker-disabled', true);
|
|
|
|
}
|
2015-05-28 17:27:25 -07:00
|
|
|
});
|