-
Notifications
You must be signed in to change notification settings - Fork 2
/
Scheduler.js
73 lines (59 loc) · 2.3 KB
/
Scheduler.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
define([
'jquery',
'DoughBaseComponent'
], function (
$,
DoughBaseComponent
) {
'use strict';
var SchedulerProto,
defaultConfig = {
selectors: {
scheduleButton: '[data-dough-dialog-trigger=scheduler]',
alternateTag: '[js-alternate]',
formToSubmit: '[data-dough-scheduler-form]',
scheduleTrigger: '[data-dough-scheduler-trigger]',
scheduledDate: '[data-dough-scheduler-date]',
scheduledTime: '[data-dough-scheduler-time]',
scheduledOn: '[data-dough-scheduler-on]'
}
};
function Scheduler($el, config) {
Scheduler.baseConstructor.call(this, $el, config, defaultConfig);
}
DoughBaseComponent.extend(Scheduler);
Scheduler.componentName = 'Scheduler';
SchedulerProto = Scheduler.prototype;
SchedulerProto.init = function(initialised) {
this._cacheComponentElements();
this._setupUIEvents();
this._initialisedSuccess(initialised);
};
SchedulerProto._cacheComponentElements = function() {
this.$scheduleButton = $(this.config.selectors.scheduleButton);
this.$alternateTag = $(this.config.selectors.alternateTag);
this.$formToSubmit = $(this.config.selectors.formToSubmit);
this.$scheduledDate = $(this.config.selectors.scheduledDate);
this.$scheduledTime = $(this.config.selectors.scheduledTime);
this.$scheduledOn = $(this.config.selectors.scheduledOn);
this.$scheduleTrigger = $(this.config.selectors.scheduleTrigger);
};
SchedulerProto._setupUIEvents = function() {
this.$scheduleButton.on('click', $.proxy(this._preventFormSubmission, this));
this.$scheduleTrigger.on('click', $.proxy(this._handleFormSubmit, this));
};
SchedulerProto._preventFormSubmission = function(e) {
e.preventDefault();
};
SchedulerProto._handleFormSubmit = function(e) {
this.$scheduledOn.val(this.$scheduledDate.val() + "T" + this.$scheduledTime.val());
if (this.$alternateTag.length > 1) {
this.$formToSubmit.append($("<input>").attr("type", "hidden").attr("name", this.$alternateTag.name));
}
if (this.$scheduleButton.val().length > 0) {
this.$formToSubmit.append($("<input>").attr("type", "hidden").attr("name", "state_event").val(this.$scheduleButton.val()));
}
this.$formToSubmit.submit();
};
return Scheduler;
});