1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-26 15:52:20 +01:00

151 lines
7.1 KiB
Plaintext
Raw Normal View History

2015-05-05 03:10:25 +02:00
'use strict';
/**
* The application file bootstraps the angular app by initializing the main module and
* creating namespaces and moduled for controllers, filters, services, and directives.
*/
var Application = Application || {};
Application.Constants = angular.module('application.constants', []);
Application.Services = angular.module('application.services', []);
Application.Controllers = angular.module('application.controllers', []);
Application.Filters = angular.module('application.filters', []);
Application.Directives = angular.module('application.directives', []);
2016-06-21 13:03:54 +02:00
angular.module('application', ['ngCookies', 'ngResource', 'ngSanitize', 'ngCookies', 'ui.router', 'ui.bootstrap',
2015-05-05 03:10:25 +02:00
'ngUpload', 'duScroll', 'application.filters','application.services', 'application.directives',
2016-03-23 18:39:41 +01:00
'frapontillo.bootstrap-switch', 'application.constants', 'application.controllers', 'application.router',
'ui.select', 'ui.calendar', 'angularMoment', 'Devise', 'DeviseModal', 'angular-growl', 'xeditable',
'checklist-model', 'unsavedChanges', 'angular-loading-bar', 'ngTouch', 'angular-google-analytics',
'angularUtils.directives.dirDisqus', 'summernote', 'elasticsearch', 'angular-medium-editor', 'naif.base64',
'minicolors', 'pascalprecht.translate', 'ngFitText', 'ngAside']).
2016-03-23 18:39:41 +01:00
config(['$httpProvider', 'AuthProvider', "growlProvider", "unsavedWarningsConfigProvider", "AnalyticsProvider", "uibDatepickerPopupConfig", "$provide", "$translateProvider",
function($httpProvider, AuthProvider, growlProvider, unsavedWarningsConfigProvider, AnalyticsProvider, uibDatepickerPopupConfig, $provide, $translateProvider) {
// Google analytics
<% #if Rails.env.production? %>
2016-03-23 18:39:41 +01:00
AnalyticsProvider.setAccount(Fablab.gaId);
2015-05-05 03:10:25 +02:00
// track all routes (or not)
AnalyticsProvider.trackPages(true);
2016-03-23 18:39:41 +01:00
AnalyticsProvider.setDomainName(Fablab.defaultHost);
2015-05-05 03:10:25 +02:00
AnalyticsProvider.useAnalytics(true);
AnalyticsProvider.setPageEvent('$stateChangeSuccess');
<% #else %>
//AnalyticsProvider.setAccount('DISABLED');
<% #end %>
2015-05-05 03:10:25 +02:00
2016-03-23 18:39:41 +01:00
// Custom messages for the date-picker widget
uibDatepickerPopupConfig.closeText = Fablab.translations.app.shared.buttons.close;
uibDatepickerPopupConfig.clearText = Fablab.translations.app.shared.buttons.clear;
uibDatepickerPopupConfig.currentText = Fablab.translations.app.shared.buttons.today;
2015-05-05 03:10:25 +02:00
2016-03-23 18:39:41 +01:00
// Custom messages for angular-unsavedChanges
unsavedWarningsConfigProvider.navigateMessage = Fablab.translations.app.shared.messages.you_will_lose_any_unsaved_modification_if_you_quit_this_page;
unsavedWarningsConfigProvider.reloadMessage = Fablab.translations.app.shared.messages.you_will_lose_any_unsaved_modification_if_you_reload_this_page;
2015-05-05 03:10:25 +02:00
2016-03-23 18:39:41 +01:00
// Set how long the popup messages (growl) will remain
2015-05-05 03:10:25 +02:00
growlProvider.globalTimeToLive(5000);
2016-03-23 18:39:41 +01:00
// Configure the i18n module to load the partial translations from the given API URL
$translateProvider.useLoader('$translatePartialLoader', {
urlTemplate: '/api/translations/{lang}/{part}'
});
// Enable the cache to speed-up the loading times on already seen pages
$translateProvider.useLoaderCache(true);
// Secure i18n module against XSS attacks by escaping the output
$translateProvider.useSanitizeValueStrategy('escapeParameters');
// Enable the MessageFormat interpolation (used for pluralization)
$translateProvider.addInterpolation('$translateMessageFormatInterpolation');
// Set the langage of the instance (from ruby configuration)
$translateProvider.preferredLanguage(Fablab.locale);
}]).run(["$rootScope", "$log", "AuthService", "Auth", "amMoment", "$state", "editableOptions", 'Analytics',
function($rootScope, $log, AuthService, Auth, amMoment, $state, editableOptions, Analytics) {
2016-03-23 18:39:41 +01:00
// Angular-moment (date-time manipulations library)
amMoment.changeLocale(Fablab.moment_locale);
// Angular-xeditable (click-to-edit elements, used in admin backoffice)
2015-05-05 03:10:25 +02:00
editableOptions.theme = 'bs3';
// Alter the UI-Router's $state, registering into some information concerning the previous $state.
2016-03-23 18:39:41 +01:00
// This is used to allow the user to navigate to the previous state
2015-05-05 03:10:25 +02:00
$rootScope.$on('$stateChangeSuccess', function(event, toState, toParams, fromState, fromParams){
$state.prevState = fromState;
$state.prevParams = fromParams;
});
2016-03-23 18:39:41 +01:00
// Global config: if true, the whole 'Plans & Subscriptions' feature will be disabled in the application
$rootScope.fablabWithoutPlans = Fablab.withoutPlans;
// Global config: it true, the whole 'Spaces' features will be disabled in the application
$rootScope.fablabWithoutSpaces = Fablab.withoutSpaces;
2016-03-23 18:39:41 +01:00
// Global function to allow the user to navigate to the previous screen (ie. $state).
// If no previous $state were recorded, navigate to the home page
2015-05-05 03:10:25 +02:00
$rootScope.backPrevLocation = function(event){
event.preventDefault();
event.stopPropagation();
if($state.prevState.name == ""){
$state.prevState = "app.public.home";
}
$state.go($state.prevState, $state.prevParams);
};
2016-03-23 18:39:41 +01:00
// Configuration of the summernote editor (used in project edition)
2015-05-13 18:30:35 +02:00
$rootScope.summernoteOpts = {
2016-03-23 18:39:41 +01:00
lang: Fablab.summernote_locale,
height: 200,
2015-05-13 18:30:35 +02:00
toolbar: [
['style', ['style']],
['font', ['bold', 'italic', 'underline', 'clear']],
['color', ['color']],
['para', ['ul', 'ol', 'paragraph']],
['table', ['table']],
['insert', ['link', 'picture', 'hr']],
['view', ['fullscreen', 'codeview']],
['group', ['video']],
['help', ['help']]
],
styleTags: ['p', 'blockquote', 'pre', 'h4', 'h5', 'h6'],
maximumImageFileSize: 4096
};
2016-03-23 18:39:41 +01:00
// Prevent the usage of the application for members with incomplete profiles: they will be redirected to
// the 'profile completion' page. This is especially useful for user's accounts imported through SSO.
$rootScope.$on('$stateChangeStart', function (event, toState) {
Auth.currentUser().then(function(currentUser) {
if (currentUser.need_completion && toState.name != 'app.logged.profileCompletion') {
$state.go('app.logged.profileCompletion');
}
});
});
// This code does nothing but it is here to remember to not remove the Analytics dependency,
// see https://github.com/revolunet/angular-google-analytics#automatic-page-view-tracking
Analytics.pageView();
/**
* This helper method builds and return an array contaning every integers between
* the provided start and end.
* @param start {number}
* @param end {number}
* @return {Array} [start .. end]
*/
$rootScope.intArray = function(start, end) {
var arr = [];
for (var i = start; i < end; i++) { arr.push(i); }
return arr;
};
2016-03-23 18:39:41 +01:00
}]).constant('angularMomentConfig', {
timezone: Fablab.timezone
});
2016-07-13 10:19:43 +02:00
angular.isUndefinedOrNull = function(val) {
return angular.isUndefined(val) || val === null
};