/* -*- Mode: javascript; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ (function() { 'use strict'; /** * @ngInject */ CalendarsController.$inject = ['$rootScope', '$scope', '$window', '$mdDialog', '$log', '$mdToast', 'FileUploader', 'sgFocus', 'Dialog', 'sgSettings', 'Preferences', 'Calendar', 'User', 'stateCalendars']; function CalendarsController($rootScope, $scope, $window, $mdDialog, $log, $mdToast, FileUploader, focus, Dialog, Settings, Preferences, Calendar, User, stateCalendars) { var vm = this; vm.activeUser = Settings.activeUser; vm.service = Calendar; vm.newCalendar = newCalendar; vm.addWebCalendar = addWebCalendar; vm.confirmDelete = confirmDelete; vm.editFolder = editFolder; vm.revertEditing = revertEditing; vm.renameFolder = renameFolder; vm.share = share; vm.importCalendar = importCalendar; vm.exportCalendar = exportCalendar; vm.showLinks = showLinks; vm.showProperties = showProperties; vm.subscribeToFolder = subscribeToFolder; vm.today = today; Preferences.ready().then(function() { vm.categories = _.map(Preferences.defaults.SOGoCalendarCategories, function(name) { return { id: name.asCSSIdentifier(), name: name, color: Preferences.defaults.SOGoCalendarCategoriesColors[name] }; }); }); // Dispatch the event named 'calendars:list' when a calendar is activated or deactivated or // when the color of a calendar is changed $scope.$watch( function() { return _.union( _.map(Calendar.$calendars, function(o) { return _.pick(o, ['id', 'active', 'color']); }), _.map(Calendar.$subscriptions, function(o) { return _.pick(o, ['id', 'active', 'color']); }), _.map(Calendar.$webcalendars, function(o) { return _.pick(o, ['id', 'active', 'color']); }) ); }, function(newList, oldList) { // Identify which calendar has changed var ids = _.pluck(_.filter(newList, function(o, i) { return !_.isEqual(o, oldList[i]); }), 'id'); if (ids.length > 0) { $log.debug(ids.join(', ') + ' changed'); _.each(ids, function(id) { var calendar = Calendar.$get(id); calendar.$setActivation().then(function() { $rootScope.$emit('calendars:list'); }); }); } }, true // compare for object equality ); function newCalendar(ev) { Dialog.prompt(l('New calendar'), l('Name of the Calendar')) .then(function(name) { var calendar = new Calendar( { name: name, isEditable: true, isRemote: false, owner: UserLogin } ); calendar.$id().then(function() { Calendar.$add(calendar); }); }); } function addWebCalendar() { Dialog.prompt(l('Subscribe to a web calendar...'), l('URL of the Calendar'), {inputType: 'url'}) .then(function(url) { Calendar.$addWebCalendar(url); }); } function confirmDelete(folder) { if (folder.isSubscription) { // Unsubscribe without confirmation folder.$delete() .then(function() { $rootScope.$emit('calendars:list'); }, function(data, status) { Dialog.alert(l('An error occured while deleting the calendar "%{0}".', folder.name), l(data.error)); }); } else { Dialog.confirm(l('Warning'), l('Are you sure you want to delete the calendar %{0}?', folder.name), { ok: l('Delete') }) .then(function() { folder.$delete() .then(function() { $rootScope.$emit('calendars:list'); }, function(data, status) { Dialog.alert(l('An error occured while deleting the calendar "%{0}".', folder.name), l(data.error)); }); }); } } function importCalendar($event, folder) { $mdDialog.show({ parent: angular.element(document.body), targetEvent: $event, clickOutsideToClose: true, escapeToClose: true, templateUrl: 'UIxCalendarImportDialog', controller: CalendarImportDialogController, controllerAs: '$CalendarImportDialogController', locals: { folder: folder } }); /** * @ngInject */ CalendarImportDialogController.$inject = ['scope', '$mdDialog', 'folder']; function CalendarImportDialogController(scope, $mdDialog, folder) { var vm = this; vm.uploader = new FileUploader({ url: ApplicationBaseURL + [folder.id, 'import'].join('/'), autoUpload: true, queueLimit: 1, filters: [{ name: filterByExtension, fn: filterByExtension }], onSuccessItem: function(item, response, status, headers) { var msg; $mdDialog.hide(); if (response.imported === 0) msg = l('No event was imported.'); else { msg = l('A total of %{0} events were imported in the calendar.', response.imported); $rootScope.$emit('calendars:list'); } $mdToast.show( $mdToast.simple() .content(msg) .position('top right') .hideDelay(3000)); }, onErrorItem: function(item, response, status, headers) { $mdToast.show({ template: [ '', '
', ' error_outline', ' ' + l('An error occurred while importing calendar.') + '', '
', '
' ].join(''), position: 'top right', hideDelay: 3000 }); } }); vm.close = function() { $mdDialog.hide(); }; function filterByExtension(item) { var isTextFile = item.type.indexOf('text') === 0 || /\.(ics)$/.test(item.name); if (!isTextFile) $mdToast.show({ template: [ '', '
', ' error_outline', ' ' + l('Select an iCalendar file (.ics).') + '', '
', '
' ].join(''), position: 'top right', hideDelay: 3000 }); return isTextFile; } } } function exportCalendar(calendar) { window.location.href = ApplicationBaseURL + '/' + calendar.id + '.ics' + '/export'; } function showLinks(calendar) { $mdDialog.show({ parent: angular.element(document.body), clickOutsideToClose: true, escapeToClose: true, templateUrl: calendar.id + '/links', controller: LinksDialogController, controllerAs: 'links', locals: { calendar: calendar } }); /** * @ngInject */ LinksDialogController.$inject = ['$mdDialog', 'calendar']; function LinksDialogController($mdDialog, calendar) { var vm = this; vm.calendar = calendar; vm.close = close; function close() { $mdDialog.hide(); } } } function showProperties(calendar) { var color = calendar.color; $mdDialog.show({ templateUrl: calendar.id + '/properties', controller: PropertiesDialogController, controllerAs: 'properties', clickOutsideToClose: true, escapeToClose: true, locals: { srcCalendar: calendar } }).catch(function() { // Restore original color when cancelling or closing the dialog calendar.color = color; }); /** * @ngInject */ PropertiesDialogController.$inject = ['$scope', '$mdDialog', 'srcCalendar']; function PropertiesDialogController($scope, $mdDialog, srcCalendar) { var vm = this; vm.calendar = new Calendar(srcCalendar.$omit()); vm.saveProperties = saveProperties; vm.close = close; $scope.$watch('properties.calendar.color', function() { srcCalendar.color = vm.calendar.color; }); function saveProperties() { vm.calendar.$save(); // Refresh list instance srcCalendar.init(vm.calendar.$omit()); $mdDialog.hide(); } function close() { $mdDialog.cancel(); } } } function editFolder(folder) { vm.calendarName = folder.name; vm.editMode = folder.id; focus('calendarName_' + folder.id); } function revertEditing(folder) { folder.$reset(); vm.editMode = false; } function renameFolder(folder) { folder.$rename() .then(function(data) { vm.editMode = false; }, function(data, status) { Dialog.alert(l('Warning'), data); }); } function share(calendar) { calendar.$acl.$users().then(function() { $mdDialog.show({ templateUrl: calendar.id + '/UIxAclEditor', // UI/Templates/UIxAclEditor.wox controller: 'AclController', // from the ng module SOGo.Common controllerAs: 'acl', clickOutsideToClose: true, escapeToClose: true, locals: { usersWithACL: calendar.$acl.users, User: User, folder: calendar } }); }); } // Callback of sgSubscribe directive function subscribeToFolder(calendarData) { $log.debug('subscribeToFolder ' + calendarData.owner + calendarData.name); Calendar.$subscribe(calendarData.owner, calendarData.name).then(function(data) { $mdToast.show( $mdToast.simple() .content(l('Successfully subscribed to calendar')) .position('top right') .hideDelay(3000)); }); } function today() { var fragments = $window.location.hash.split('/'), state = fragments[1], view = fragments[2], now = new Date(), path = ['#', state, view, now.getDayString()]; $window.location = path.join('/'); } } angular .module('SOGo.SchedulerUI') .controller('CalendarsController', CalendarsController); })();