This repository has been archived by the owner on Jun 19, 2018. It is now read-only.
/
mwlCalendarDay.js
116 lines (97 loc) · 3.23 KB
/
mwlCalendarDay.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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
'use strict';
var angular = require('angular');
angular
.module('mwl.calendar')
.controller('MwlCalendarDayCtrl', function($scope, moment, calendarHelper, calendarEventTitle) {
var vm = this;
vm.calendarEventTitle = calendarEventTitle;
function refreshView() {
vm.dayViewSplit = vm.dayViewSplit || 30;
vm.dayViewHeight = calendarHelper.getDayViewHeight(
vm.dayViewStart,
vm.dayViewEnd,
vm.dayViewSplit
);
var view = calendarHelper.getDayView(
vm.events,
vm.viewDate,
vm.dayViewStart,
vm.dayViewEnd,
vm.dayViewSplit
);
vm.allDayEvents = view.allDayEvents;
vm.nonAllDayEvents = view.events;
vm.viewWidth = view.width + 62;
}
$scope.$on('calendar.refreshView', refreshView);
$scope.$watchGroup([
'vm.dayViewStart',
'vm.dayViewEnd',
'vm.dayViewSplit'
], refreshView);
vm.eventDragComplete = function(event, minuteChunksMoved) {
var minutesDiff = minuteChunksMoved * vm.dayViewSplit;
var newStart = moment(event.startsAt).add(minutesDiff, 'minutes');
var newEnd = moment(event.endsAt).add(minutesDiff, 'minutes');
delete event.tempStartsAt;
vm.onEventTimesChanged({
calendarEvent: event,
calendarNewEventStart: newStart.toDate(),
calendarNewEventEnd: event.endsAt ? newEnd.toDate() : null
});
};
vm.eventDragged = function(event, minuteChunksMoved) {
var minutesDiff = minuteChunksMoved * vm.dayViewSplit;
event.tempStartsAt = moment(event.startsAt).add(minutesDiff, 'minutes').toDate();
};
vm.eventResizeComplete = function(event, edge, minuteChunksMoved) {
var minutesDiff = minuteChunksMoved * vm.dayViewSplit;
var start = moment(event.startsAt);
var end = moment(event.endsAt);
if (edge === 'start') {
start.add(minutesDiff, 'minutes');
} else {
end.add(minutesDiff, 'minutes');
}
delete event.tempStartsAt;
vm.onEventTimesChanged({
calendarEvent: event,
calendarNewEventStart: start.toDate(),
calendarNewEventEnd: end.toDate()
});
};
vm.eventResized = function(event, edge, minuteChunksMoved) {
var minutesDiff = minuteChunksMoved * vm.dayViewSplit;
if (edge === 'start') {
event.tempStartsAt = moment(event.startsAt).add(minutesDiff, 'minutes').toDate();
}
};
})
.directive('mwlCalendarDay', function() {
return {
template: '<div mwl-dynamic-directive-template name="calendarDayView" overrides="vm.customTemplateUrls"></div>',
restrict: 'E',
require: '^mwlCalendar',
scope: {
events: '=',
viewDate: '=',
onEventClick: '=',
onEventTimesChanged: '=',
onTimespanClick: '=',
onDateRangeSelect: '=',
dayViewStart: '=',
dayViewEnd: '=',
dayViewSplit: '=',
dayViewEventChunkSize: '=',
onEditEventClick: '=',
onDeleteEventClick: '=',
editEventHtml: '=',
deleteEventHtml: '=',
customTemplateUrls: '=?',
cellModifier: '=',
templateScope: '='
},
controller: 'MwlCalendarDayCtrl as vm',
bindToController: true
};
});