bansho/app/routing_view/routing_view.js
Vincent Fournier 022f2e29d7 Refactoring of single table and generic actionbar
Change-Id: I64d8851d87bac157d66d64669bcb08f3bd19ffc1
2015-07-16 15:17:52 -04:00

53 lines
1.7 KiB
JavaScript

/*global jQuery */
'use strict';
angular.module('bansho.view', ['ngRoute',
'bansho.config'
])
.value('viewsTemplate', {})
.config(['$routeProvider', function ($routeProvider) {
$routeProvider.when('/view', {
controller: 'ViewCtrl',
template: '<div ng-include="templateUrl">Loading...</div>'
})
.when('/login', {
templateUrl: 'components/authentication/authentication.html'
});
}])
.controller('ViewCtrl', ['$scope', '$rootScope', '$location', '$routeParams', '$window', '$timeout', 'viewsTemplate', 'loadConfig',
function ($scope, $rootScope, $location, $routeParams, $window, $timeout, viewsTemplate, loadConfig) {
var templateName;
if (!$rootScope.isAuthenticated) {
$location.path('/login');
return;
}
if (jQuery.isEmptyObject(viewsTemplate)) {
loadConfig();
}
if (!!$routeParams.view) {
$scope.viewName = $routeParams.view;
} else {
$scope.viewName = $routeParams.view = 'dashboardConfig';
}
templateName = viewsTemplate[$scope.viewName];
$scope.templateUrl = 'templates/' + templateName + '/' + templateName + '.html';
}])
.service('loadConfig', ['configManager', 'viewsTemplate', function (configManager, viewsTemplate) {
return function () {
var viewsConfig = configManager.readConfig();
angular.forEach(viewsConfig, function (config, view) {
viewsTemplate[view] = config.template;
});
};
}]);