mirror of https://github.com/akveo/blur-admin
Add authSignIn, authSignUp, page.config, authenticate route, service localStorage, page.service, adjustment auth.css, adjustment gulp inject, install lodash for bower, add module main
parent
1f81f3b1c1
commit
c21905bfc6
|
@ -54,7 +54,8 @@
|
||||||
"textAngular": "~1.4.6",
|
"textAngular": "~1.4.6",
|
||||||
"angular-xeditable": "~0.5.0",
|
"angular-xeditable": "~0.5.0",
|
||||||
"ng-js-tree": "~0.0.7",
|
"ng-js-tree": "~0.0.7",
|
||||||
"angular-ui-select": "^0.19.6"
|
"angular-ui-select": "^0.19.6",
|
||||||
|
"lodash": "^4.17.4"
|
||||||
},
|
},
|
||||||
"resolutions": {
|
"resolutions": {
|
||||||
"angular": "~1.5.9",
|
"angular": "~1.5.9",
|
||||||
|
|
|
@ -18,6 +18,7 @@ gulp.task('inject-reload', ['inject'], function () {
|
||||||
gulp.task('inject', ['scripts', 'styles', 'injectAuth', 'inject404', 'copyVendorImages'], function() {
|
gulp.task('inject', ['scripts', 'styles', 'injectAuth', 'inject404', 'copyVendorImages'], function() {
|
||||||
var injectStyles = gulp.src([
|
var injectStyles = gulp.src([
|
||||||
path.join(conf.paths.tmp, '/serve/app/main.css'),
|
path.join(conf.paths.tmp, '/serve/app/main.css'),
|
||||||
|
path.join(conf.paths.tmp, '/serve/app/auth.css'),
|
||||||
path.join('!' + conf.paths.tmp, '/serve/app/vendor.css')
|
path.join('!' + conf.paths.tmp, '/serve/app/vendor.css')
|
||||||
], { read: false });
|
], { read: false });
|
||||||
|
|
||||||
|
@ -28,7 +29,8 @@ gulp.task('inject', ['scripts', 'styles', 'injectAuth', 'inject404', 'copyVendor
|
||||||
path.join('!' + conf.paths.src, '/app/**/*.spec.js'),
|
path.join('!' + conf.paths.src, '/app/**/*.spec.js'),
|
||||||
path.join('!' + conf.paths.src, '/app/**/*.mock.js'),
|
path.join('!' + conf.paths.src, '/app/**/*.mock.js'),
|
||||||
])
|
])
|
||||||
/*.pipe($.angularFilesort())*/.on('error', conf.errorHandler('AngularFilesort'));
|
/*.pipe($.angularFilesort())*/
|
||||||
|
.on('error', conf.errorHandler('AngularFilesort'));
|
||||||
|
|
||||||
var injectOptions = {
|
var injectOptions = {
|
||||||
ignorePath: [conf.paths.src, path.join(conf.paths.tmp, '/serve')],
|
ignorePath: [conf.paths.src, path.join(conf.paths.tmp, '/serve')],
|
||||||
|
@ -45,7 +47,7 @@ gulp.task('inject', ['scripts', 'styles', 'injectAuth', 'inject404', 'copyVendor
|
||||||
gulp.task('injectAuth', ['stylesAuth'], function() {
|
gulp.task('injectAuth', ['stylesAuth'], function() {
|
||||||
return injectAlone({
|
return injectAlone({
|
||||||
css: [path.join('!' + conf.paths.tmp, '/serve/app/vendor.css'), path.join(conf.paths.tmp, '/serve/app/auth.css')],
|
css: [path.join('!' + conf.paths.tmp, '/serve/app/vendor.css'), path.join(conf.paths.tmp, '/serve/app/auth.css')],
|
||||||
paths: [path.join(conf.paths.src, '/auth.html'), path.join(conf.paths.src, '/reg.html')]
|
paths: [path.join(conf.paths.src, '/auth.html'), path.join(conf.paths.src, '/reg.html'), path.join(conf.paths.src, '/app/pages/authSigIn/authSignIn.html'), path.join(conf.paths.src, '/app/pages/authSigIn/authSignUp.html')]
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -58,8 +60,7 @@ gulp.task('inject404', ['styles404'], function () {
|
||||||
|
|
||||||
var injectAlone = function(options) {
|
var injectAlone = function(options) {
|
||||||
var injectStyles = gulp.src(
|
var injectStyles = gulp.src(
|
||||||
options.css
|
options.css, { read: false });
|
||||||
, {read: false});
|
|
||||||
|
|
||||||
var injectOptions = {
|
var injectOptions = {
|
||||||
ignorePath: [conf.paths.src, path.join(conf.paths.tmp, '/serve')],
|
ignorePath: [conf.paths.src, path.join(conf.paths.tmp, '/serve')],
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
<div class="login" ng-controller="authSignInCtrl as signInVm">
|
||||||
|
<main class="auth-main">
|
||||||
|
<div class="auth-block">
|
||||||
|
<h1>Sign in to Blur Admin</h1>
|
||||||
|
<a ui-sref="authSignUp" class="auth-link">New to Blur Admin? Sign up!</a>
|
||||||
|
|
||||||
|
<form class="form-horizontal" ng-submit="signInVm.logar()">
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="inputEmail3" class="col-sm-2 control-label">Email</label>
|
||||||
|
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<input type="email" ng-model="signInVm.user" class="form-control" id="inputEmail3" placeholder="Email">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="inputPassword3" class="col-sm-2 control-label">Password</label>
|
||||||
|
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<input type="password" ng-model="signInVm.passWord" class="form-control" id="inputPassword3" placeholder="Password">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="col-sm-offset-2 col-sm-10">
|
||||||
|
<button type="submit" class="btn btn-default btn-auth">Sign in</button>
|
||||||
|
<a href class="forgot-pass">Forgot password?</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<div class="auth-sep"><span><span>or Sign in with one click</span></span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="al-share-auth">
|
||||||
|
<ul class="al-share clearfix">
|
||||||
|
<li><i class="socicon socicon-facebook" title="Share on Facebook"></i></li>
|
||||||
|
<li><i class="socicon socicon-twitter" title="Share on Twitter"></i></li>
|
||||||
|
<li><i class="socicon socicon-google" title="Share on Google Plus"></i></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
</div>
|
|
@ -0,0 +1,22 @@
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.authSignIn', [])
|
||||||
|
.config(routeConfig);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function routeConfig($stateProvider) {
|
||||||
|
$stateProvider
|
||||||
|
.state('authSignIn', {
|
||||||
|
url: '/authSignIn',
|
||||||
|
templateUrl: 'app/pages/authSignIn/authSignIn.html',
|
||||||
|
title: 'My Page',
|
||||||
|
controller: 'authSignInCtrl',
|
||||||
|
sidebarMeta: {
|
||||||
|
order: 800,
|
||||||
|
},
|
||||||
|
authenticate: false
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -0,0 +1,31 @@
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.authSignIn')
|
||||||
|
.controller('authSignInCtrl', authSignInCtrl);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function authSignInCtrl($scope, localStorage, $state) {
|
||||||
|
var vm = this;
|
||||||
|
|
||||||
|
vm.logar = logar;
|
||||||
|
|
||||||
|
init();
|
||||||
|
|
||||||
|
function init() {
|
||||||
|
localStorage.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
function logar() {
|
||||||
|
var dadosUser = {
|
||||||
|
user: vm.user,
|
||||||
|
passWord: vm.passWord
|
||||||
|
};
|
||||||
|
localStorage.setObject('dataUser', dadosUser);
|
||||||
|
$state.go('main.dashboard');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -0,0 +1,49 @@
|
||||||
|
<div class="login">
|
||||||
|
|
||||||
|
<main class="auth-main">
|
||||||
|
<div class="auth-block">
|
||||||
|
<h1>Sign up to Blur Admin</h1>
|
||||||
|
<a ui-sref="authSignIn" class="auth-link">Already have a Blur Admin account? Sign in!</a>
|
||||||
|
|
||||||
|
<form class="form-horizontal">
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="inputName3" class="col-sm-2 control-label">Name</label>
|
||||||
|
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<input type="text" class="form-control" id="inputName3" placeholder="Full Name">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="inputEmail3" class="col-sm-2 control-label">Email</label>
|
||||||
|
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<input type="email" class="form-control" id="inputEmail3" placeholder="Email">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="inputPassword3" class="col-sm-2 control-label">Password</label>
|
||||||
|
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<input type="password" class="form-control" id="inputPassword3" placeholder="Password">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="col-sm-offset-2 col-sm-10">
|
||||||
|
<button type="submit" class="btn btn-default btn-auth">Sign up</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<div class="auth-sep"><span><span>or Sign up with one click</span></span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="al-share-auth">
|
||||||
|
<ul class="al-share clearfix">
|
||||||
|
<li><i class="socicon socicon-facebook" title="Share on Facebook"></i></li>
|
||||||
|
<li><i class="socicon socicon-twitter" title="Share on Twitter"></i></li>
|
||||||
|
<li><i class="socicon socicon-google" title="Share on Google Plus"></i></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
</div>
|
|
@ -0,0 +1,22 @@
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.authSignUp', [])
|
||||||
|
.config(routeConfig);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function routeConfig($stateProvider) {
|
||||||
|
$stateProvider
|
||||||
|
.state('authSignUp', {
|
||||||
|
url: '/authSignUp',
|
||||||
|
templateUrl: 'app/pages/authSignUp/authSignUp.html',
|
||||||
|
title: 'My Page',
|
||||||
|
controller: 'authSignUpCtrl',
|
||||||
|
sidebarMeta: {
|
||||||
|
order: 800,
|
||||||
|
},
|
||||||
|
authenticate: false
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -0,0 +1,13 @@
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.authSignUp')
|
||||||
|
.controller('authSignUpCtrl', authSignUpCtrl);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function authSignUpCtrl($scope) {
|
||||||
|
var vm = this;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('charts.amCharts', {
|
.state('main.charts.amCharts', {
|
||||||
url: '/amCharts',
|
url: '/amCharts',
|
||||||
templateUrl: 'app/pages/charts/amCharts/charts.html',
|
templateUrl: 'app/pages/charts/amCharts/charts.html',
|
||||||
title: 'amCharts',
|
title: 'amCharts',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 0,
|
order: 0,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('charts.chartJs', {
|
.state('main.charts.chartJs', {
|
||||||
url: '/chartJs',
|
url: '/chartJs',
|
||||||
templateUrl: 'app/pages/charts/chartJs/chartJs.html',
|
templateUrl: 'app/pages/charts/chartJs/chartJs.html',
|
||||||
title: 'Chart.js',
|
title: 'Chart.js',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 200
|
order: 200
|
||||||
}
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,7 +27,8 @@
|
||||||
// Configure all charts
|
// Configure all charts
|
||||||
ChartJsProvider.setOptions({
|
ChartJsProvider.setOptions({
|
||||||
chartColors: [
|
chartColors: [
|
||||||
layoutColors.primary, layoutColors.danger, layoutColors.warning, layoutColors.success, layoutColors.info, layoutColors.default, layoutColors.primaryDark, layoutColors.successDark, layoutColors.warningLight, layoutColors.successLight, layoutColors.primaryLight],
|
layoutColors.primary, layoutColors.danger, layoutColors.warning, layoutColors.success, layoutColors.info, layoutColors.default, layoutColors.primaryDark, layoutColors.successDark, layoutColors.warningLight, layoutColors.successLight, layoutColors.primaryLight
|
||||||
|
],
|
||||||
responsive: true,
|
responsive: true,
|
||||||
maintainAspectRatio: false,
|
maintainAspectRatio: false,
|
||||||
animation: {
|
animation: {
|
||||||
|
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('charts.chartist', {
|
.state('main.charts.chartist', {
|
||||||
url: '/chartist',
|
url: '/chartist',
|
||||||
templateUrl: 'app/pages/charts/chartist/chartist.html',
|
templateUrl: 'app/pages/charts/chartist/chartist.html',
|
||||||
title: 'Chartist',
|
title: 'Chartist',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 100,
|
order: 100,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('charts', {
|
.state('main.charts', {
|
||||||
url: '/charts',
|
url: '/charts',
|
||||||
abstract: true,
|
abstract: true,
|
||||||
template: '<div ui-view autoscroll="true" autoscroll-body-top></div>',
|
template: '<div ui-view autoscroll="true" autoscroll-body-top></div>',
|
||||||
|
@ -25,6 +25,7 @@
|
||||||
icon: 'ion-stats-bars',
|
icon: 'ion-stats-bars',
|
||||||
order: 150,
|
order: 150,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,13 +17,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('charts.morris', {
|
.state('main.charts.morris', {
|
||||||
url: '/morris',
|
url: '/morris',
|
||||||
templateUrl: 'app/pages/charts/morris/morris.html',
|
templateUrl: 'app/pages/charts/morris/morris.html',
|
||||||
title: 'Morris',
|
title: 'Morris',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 300,
|
order: 300,
|
||||||
}
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('components', {
|
.state('main.components', {
|
||||||
url: '/components',
|
url: '/components',
|
||||||
template: '<ui-view autoscroll="true" autoscroll-body-top></ui-view>',
|
template: '<ui-view autoscroll="true" autoscroll-body-top></ui-view>',
|
||||||
abstract: true,
|
abstract: true,
|
||||||
|
@ -24,6 +24,7 @@
|
||||||
icon: 'ion-gear-a',
|
icon: 'ion-gear-a',
|
||||||
order: 100,
|
order: 100,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider, $urlRouterProvider) {
|
function routeConfig($stateProvider, $urlRouterProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('components.mail', {
|
.state('main.components.mail', {
|
||||||
url: '/mail',
|
url: '/mail',
|
||||||
abstract: true,
|
abstract: true,
|
||||||
templateUrl: 'app/pages/components/mail/mail.html',
|
templateUrl: 'app/pages/components/mail/mail.html',
|
||||||
|
@ -21,20 +21,23 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 0,
|
order: 0,
|
||||||
},
|
},
|
||||||
}).state('components.mail.label', {
|
authenticate: true
|
||||||
|
}).state('main.components.mail.label', {
|
||||||
url: '/:label',
|
url: '/:label',
|
||||||
templateUrl: 'app/pages/components/mail/list/mailList.html',
|
templateUrl: 'app/pages/components/mail/list/mailList.html',
|
||||||
title: 'Mail',
|
title: 'Mail',
|
||||||
controller: "MailListCtrl",
|
controller: "MailListCtrl",
|
||||||
controllerAs: "listCtrl"
|
controllerAs: "listCtrl",
|
||||||
}).state('components.mail.detail', {
|
authenticate: true
|
||||||
|
}).state('main.components.mail.detail', {
|
||||||
url: '/:label/:id',
|
url: '/:label/:id',
|
||||||
templateUrl: 'app/pages/components/mail/detail/mailDetail.html',
|
templateUrl: 'app/pages/components/mail/detail/mailDetail.html',
|
||||||
title: 'Mail',
|
title: 'Mail',
|
||||||
controller: "MailDetailCtrl",
|
controller: "MailDetailCtrl",
|
||||||
controllerAs: "detailCtrl"
|
controllerAs: "detailCtrl",
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
$urlRouterProvider.when('/components/mail','/components/mail/inbox');
|
$urlRouterProvider.when('/main/components/mail', '/main/components/mail/inbox');
|
||||||
}
|
}
|
||||||
|
|
||||||
})();
|
})();
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('components.timeline', {
|
.state('main.components.timeline', {
|
||||||
url: '/timeline',
|
url: '/timeline',
|
||||||
templateUrl: 'app/pages/components/timeline/timeline.html',
|
templateUrl: 'app/pages/components/timeline/timeline.html',
|
||||||
title: 'Timeline',
|
title: 'Timeline',
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
icon: 'ion-ios-pulse',
|
icon: 'ion-ios-pulse',
|
||||||
order: 100,
|
order: 100,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
})();
|
})();
|
|
@ -15,13 +15,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('components.tree', {
|
.state('main.components.tree', {
|
||||||
url: '/tree',
|
url: '/tree',
|
||||||
templateUrl: 'app/pages/components/tree/tree.html',
|
templateUrl: 'app/pages/components/tree/tree.html',
|
||||||
title: 'Tree View',
|
title: 'Tree View',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 200,
|
order: 200,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.config', [])
|
||||||
|
.config(routeConfig);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function routeConfig() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -0,0 +1,19 @@
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.config')
|
||||||
|
.run(stateChangeStart);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function stateChangeStart($rootScope, $state, localStorage) {
|
||||||
|
$rootScope.$on("$stateChangeStart", function(event, toState, toParams, fromState, fromParams) {
|
||||||
|
var login = localStorage.getObject('dataUser');
|
||||||
|
if (toState.authenticate && _.isEmpty(login)) {
|
||||||
|
// User isn’t authenticated
|
||||||
|
$state.transitionTo("authSignIn");
|
||||||
|
event.preventDefault();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('dashboard', {
|
.state('main.dashboard', {
|
||||||
url: '/dashboard',
|
url: '/dashboard',
|
||||||
templateUrl: 'app/pages/dashboard/dashboard.html',
|
templateUrl: 'app/pages/dashboard/dashboard.html',
|
||||||
title: 'Dashboard',
|
title: 'Dashboard',
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
icon: 'ion-android-home',
|
icon: 'ion-android-home',
|
||||||
order: 0,
|
order: 0,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('form', {
|
.state('main.form', {
|
||||||
url: '/form',
|
url: '/form',
|
||||||
template: '<ui-view autoscroll="true" autoscroll-body-top></ui-view>',
|
template: '<ui-view autoscroll="true" autoscroll-body-top></ui-view>',
|
||||||
abstract: true,
|
abstract: true,
|
||||||
|
@ -20,25 +20,27 @@
|
||||||
icon: 'ion-compose',
|
icon: 'ion-compose',
|
||||||
order: 250,
|
order: 250,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
})
|
})
|
||||||
.state('form.inputs', {
|
.state('main.form.inputs', {
|
||||||
url: '/inputs',
|
url: '/inputs',
|
||||||
templateUrl: 'app/pages/form/inputs/inputs.html',
|
templateUrl: 'app/pages/form/inputs/inputs.html',
|
||||||
title: 'Form Inputs',
|
title: 'Form Inputs',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 0,
|
order: 0,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
})
|
})
|
||||||
.state('form.layouts', {
|
.state('main.form.layouts', {
|
||||||
url: '/layouts',
|
url: '/layouts',
|
||||||
templateUrl: 'app/pages/form/layouts/layouts.html',
|
templateUrl: 'app/pages/form/layouts/layouts.html',
|
||||||
title: 'Form Layouts',
|
title: 'Form Layouts',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 100,
|
order: 100,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
})
|
})
|
||||||
.state('form.wizard',
|
.state('main.form.wizard', {
|
||||||
{
|
|
||||||
url: '/wizard',
|
url: '/wizard',
|
||||||
templateUrl: 'app/pages/form/wizard/wizard.html',
|
templateUrl: 'app/pages/form/wizard/wizard.html',
|
||||||
controller: 'WizardCtrl',
|
controller: 'WizardCtrl',
|
||||||
|
@ -47,6 +49,7 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 200,
|
order: 200,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
})();
|
})();
|
|
@ -0,0 +1,31 @@
|
||||||
|
<div class="body-bg"></div>
|
||||||
|
<main ng-if="$pageFinishedLoading" ng-class="{ 'menu-collapsed': $baSidebarService.isMenuCollapsed() }">
|
||||||
|
|
||||||
|
<ba-sidebar></ba-sidebar>
|
||||||
|
<page-top></page-top>
|
||||||
|
|
||||||
|
<div class="al-main">
|
||||||
|
<div class="al-content">
|
||||||
|
<content-top></content-top>
|
||||||
|
<div ui-view autoscroll="true" autoscroll-body-top></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<footer class="al-footer clearfix">
|
||||||
|
<div class="al-footer-right">Created with <i class="ion-heart"></i></div>
|
||||||
|
<div class="al-footer-main clearfix">
|
||||||
|
<div class="al-copy">Blur Admin 2016</div>
|
||||||
|
<ul class="al-share clearfix">
|
||||||
|
<li><i class="socicon socicon-facebook"></i></li>
|
||||||
|
<li><i class="socicon socicon-twitter"></i></li>
|
||||||
|
<li><i class="socicon socicon-google"></i></li>
|
||||||
|
<li><i class="socicon socicon-github"></i></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
<back-top></back-top>
|
||||||
|
</main>
|
||||||
|
<div id="preloader" ng-show="!$pageFinishedLoading">
|
||||||
|
<div></div>
|
||||||
|
</div>
|
|
@ -0,0 +1,24 @@
|
||||||
|
/**
|
||||||
|
* @author l.azevedo
|
||||||
|
* created on 29.07.2017
|
||||||
|
*/
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.main', [])
|
||||||
|
.config(routeConfig);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function routeConfig($stateProvider) {
|
||||||
|
$stateProvider
|
||||||
|
.state('main', {
|
||||||
|
url: '/main',
|
||||||
|
templateUrl: 'app/pages/main/main.html',
|
||||||
|
redirectTo: 'main.dashboard',
|
||||||
|
authenticate: true
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('maps', {
|
.state('main.maps', {
|
||||||
url: '/maps',
|
url: '/maps',
|
||||||
templateUrl: 'app/pages/maps/maps.html',
|
templateUrl: 'app/pages/maps/maps.html',
|
||||||
abstract: true,
|
abstract: true,
|
||||||
|
@ -20,8 +20,9 @@
|
||||||
icon: 'ion-ios-location-outline',
|
icon: 'ion-ios-location-outline',
|
||||||
order: 500,
|
order: 500,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
})
|
})
|
||||||
.state('maps.gmap', {
|
.state('main.maps.gmap', {
|
||||||
url: '/gmap',
|
url: '/gmap',
|
||||||
templateUrl: 'app/pages/maps/google-maps/google-maps.html',
|
templateUrl: 'app/pages/maps/google-maps/google-maps.html',
|
||||||
controller: 'GmapPageCtrl',
|
controller: 'GmapPageCtrl',
|
||||||
|
@ -29,8 +30,9 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 0,
|
order: 0,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
})
|
})
|
||||||
.state('maps.leaflet', {
|
.state('main.maps.leaflet', {
|
||||||
url: '/leaflet',
|
url: '/leaflet',
|
||||||
templateUrl: 'app/pages/maps/leaflet/leaflet.html',
|
templateUrl: 'app/pages/maps/leaflet/leaflet.html',
|
||||||
controller: 'LeafletPageCtrl',
|
controller: 'LeafletPageCtrl',
|
||||||
|
@ -38,8 +40,9 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 100,
|
order: 100,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
})
|
})
|
||||||
.state('maps.bubble', {
|
.state('main.maps.bubble', {
|
||||||
url: '/bubble',
|
url: '/bubble',
|
||||||
templateUrl: 'app/pages/maps/map-bubbles/map-bubbles.html',
|
templateUrl: 'app/pages/maps/map-bubbles/map-bubbles.html',
|
||||||
controller: 'MapBubblePageCtrl',
|
controller: 'MapBubblePageCtrl',
|
||||||
|
@ -47,8 +50,9 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 200,
|
order: 200,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
})
|
})
|
||||||
.state('maps.line', {
|
.state('main.maps.line', {
|
||||||
url: '/line',
|
url: '/line',
|
||||||
templateUrl: 'app/pages/maps/map-lines/map-lines.html',
|
templateUrl: 'app/pages/maps/map-lines/map-lines.html',
|
||||||
controller: 'MapLinesPageCtrl',
|
controller: 'MapLinesPageCtrl',
|
||||||
|
@ -56,6 +60,7 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 300,
|
order: 300,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,9 @@
|
||||||
|
|
||||||
angular.module('BlurAdmin.pages', [
|
angular.module('BlurAdmin.pages', [
|
||||||
'ui.router',
|
'ui.router',
|
||||||
|
'BlurAdmin.pages.services',
|
||||||
|
'BlurAdmin.pages.config',
|
||||||
|
'BlurAdmin.pages.main',
|
||||||
'BlurAdmin.pages.dashboard',
|
'BlurAdmin.pages.dashboard',
|
||||||
'BlurAdmin.pages.ui',
|
'BlurAdmin.pages.ui',
|
||||||
'BlurAdmin.pages.components',
|
'BlurAdmin.pages.components',
|
||||||
|
@ -16,12 +18,14 @@
|
||||||
'BlurAdmin.pages.charts',
|
'BlurAdmin.pages.charts',
|
||||||
'BlurAdmin.pages.maps',
|
'BlurAdmin.pages.maps',
|
||||||
'BlurAdmin.pages.profile',
|
'BlurAdmin.pages.profile',
|
||||||
|
'BlurAdmin.pages.authSignIn',
|
||||||
|
'BlurAdmin.pages.authSignUp',
|
||||||
])
|
])
|
||||||
.config(routeConfig);
|
.config(routeConfig);
|
||||||
|
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($urlRouterProvider, baSidebarServiceProvider) {
|
function routeConfig($urlRouterProvider, baSidebarServiceProvider) {
|
||||||
$urlRouterProvider.otherwise('/dashboard');
|
$urlRouterProvider.otherwise('/authSignIn');
|
||||||
|
|
||||||
baSidebarServiceProvider.addStaticItem({
|
baSidebarServiceProvider.addStaticItem({
|
||||||
title: 'Pages',
|
title: 'Pages',
|
||||||
|
|
|
@ -11,11 +11,12 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('profile', {
|
.state('main.profile', {
|
||||||
url: '/profile',
|
url: '/profile',
|
||||||
title: 'Profile',
|
title: 'Profile',
|
||||||
templateUrl: 'app/pages/profile/profile.html',
|
templateUrl: 'app/pages/profile/profile.html',
|
||||||
controller: 'ProfilePageCtrl',
|
controller: 'ProfilePageCtrl',
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,56 @@
|
||||||
|
/**
|
||||||
|
* @author l.azevedo
|
||||||
|
* created on 29/06/2017
|
||||||
|
*/
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.services')
|
||||||
|
.service('localStorage', localStorage);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function localStorage($window) {
|
||||||
|
var service = {
|
||||||
|
set: set,
|
||||||
|
get: get,
|
||||||
|
setObject: setObject,
|
||||||
|
getObject: getObject,
|
||||||
|
clear: clear
|
||||||
|
}
|
||||||
|
|
||||||
|
return service;
|
||||||
|
|
||||||
|
function set(key, value) {
|
||||||
|
if ($window.fakeLocalStorage) {
|
||||||
|
$window.fakeLocalStorage[key] = value;
|
||||||
|
} else {
|
||||||
|
$window.localStorage[key] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function get(key, defaultValue) {
|
||||||
|
return !$window.fakeLocalStorage ? $window.localStorage[key] || defaultValue : $window.fakeLocalStorage[key] || defaultValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
function setObject(key, value) {
|
||||||
|
if ($window.fakeLocalStorage) {
|
||||||
|
$window.fakeLocalStorage[key] = angular.toJson(value);
|
||||||
|
} else {
|
||||||
|
$window.localStorage[key] = angular.toJson(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function getObject(key) {
|
||||||
|
return !$window.fakeLocalStorage ? angular.fromJson($window.localStorage[key] || '{}') : angular.fromJson($window.fakeLocalStorage[key] || '{}');
|
||||||
|
}
|
||||||
|
|
||||||
|
function clear() {
|
||||||
|
if ($window.fakeLocalStorage) {
|
||||||
|
$window.fakeLocalStorage = {};
|
||||||
|
} else {
|
||||||
|
$window.localStorage.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -0,0 +1,12 @@
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('BlurAdmin.pages.services', [])
|
||||||
|
.config(routeConfig);
|
||||||
|
|
||||||
|
/** @ngInject */
|
||||||
|
function routeConfig() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider, $urlRouterProvider) {
|
function routeConfig($stateProvider, $urlRouterProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('tables', {
|
.state('main.tables', {
|
||||||
url: '/tables',
|
url: '/tables',
|
||||||
template: '<ui-view autoscroll="true" autoscroll-body-top></ui-view>',
|
template: '<ui-view autoscroll="true" autoscroll-body-top></ui-view>',
|
||||||
abstract: true,
|
abstract: true,
|
||||||
|
@ -21,22 +21,25 @@
|
||||||
icon: 'ion-grid',
|
icon: 'ion-grid',
|
||||||
order: 300,
|
order: 300,
|
||||||
},
|
},
|
||||||
}).state('tables.basic', {
|
authenticate: true
|
||||||
|
}).state('main.tables.basic', {
|
||||||
url: '/basic',
|
url: '/basic',
|
||||||
templateUrl: 'app/pages/tables/basic/tables.html',
|
templateUrl: 'app/pages/tables/basic/tables.html',
|
||||||
title: 'Basic Tables',
|
title: 'Basic Tables',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 0,
|
order: 0,
|
||||||
},
|
},
|
||||||
}).state('tables.smart', {
|
authenticate: true
|
||||||
|
}).state('main.tables.smart', {
|
||||||
url: '/smart',
|
url: '/smart',
|
||||||
templateUrl: 'app/pages/tables/smart/tables.html',
|
templateUrl: 'app/pages/tables/smart/tables.html',
|
||||||
title: 'Smart Tables',
|
title: 'Smart Tables',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 100,
|
order: 100,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
$urlRouterProvider.when('/tables','/tables/basic');
|
$urlRouterProvider.when('/main/tables', '/main/tables/basic');
|
||||||
}
|
}
|
||||||
|
|
||||||
})();
|
})();
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.alerts', {
|
.state('main.ui.alerts', {
|
||||||
url: '/alerts',
|
url: '/alerts',
|
||||||
templateUrl: 'app/pages/ui/alerts/alerts.html',
|
templateUrl: 'app/pages/ui/alerts/alerts.html',
|
||||||
title: 'Alerts',
|
title: 'Alerts',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 500,
|
order: 500,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.buttons', {
|
.state('main.ui.buttons', {
|
||||||
url: '/buttons',
|
url: '/buttons',
|
||||||
templateUrl: 'app/pages/ui/buttons/buttons.html',
|
templateUrl: 'app/pages/ui/buttons/buttons.html',
|
||||||
controller: 'ButtonPageCtrl',
|
controller: 'ButtonPageCtrl',
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 100,
|
order: 100,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.grid', {
|
.state('main.ui.grid', {
|
||||||
url: '/grid',
|
url: '/grid',
|
||||||
templateUrl: 'app/pages/ui/grid/grid.html',
|
templateUrl: 'app/pages/ui/grid/grid.html',
|
||||||
title: 'Grid',
|
title: 'Grid',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 400,
|
order: 400,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.icons', {
|
.state('main.ui.icons', {
|
||||||
url: '/icons',
|
url: '/icons',
|
||||||
templateUrl: 'app/pages/ui/icons/icons.html',
|
templateUrl: 'app/pages/ui/icons/icons.html',
|
||||||
controller: 'IconsPageCtrl',
|
controller: 'IconsPageCtrl',
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 200,
|
order: 200,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.modals', {
|
.state('main.ui.modals', {
|
||||||
url: '/modals',
|
url: '/modals',
|
||||||
templateUrl: 'app/pages/ui/modals/modals.html',
|
templateUrl: 'app/pages/ui/modals/modals.html',
|
||||||
controller: 'ModalsPageCtrl',
|
controller: 'ModalsPageCtrl',
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 300,
|
order: 300,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.notifications', {
|
.state('main.ui.notifications', {
|
||||||
url: '/notifications',
|
url: '/notifications',
|
||||||
templateUrl: 'app/pages/ui/notifications/notifications.html',
|
templateUrl: 'app/pages/ui/notifications/notifications.html',
|
||||||
controller: 'NotificationsPageCtrl',
|
controller: 'NotificationsPageCtrl',
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 700,
|
order: 700,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.panels', {
|
.state('main.ui.panels', {
|
||||||
url: '/panels',
|
url: '/panels',
|
||||||
templateUrl: 'app/pages/ui/panels/panels.html',
|
templateUrl: 'app/pages/ui/panels/panels.html',
|
||||||
controller: 'NotificationsPageCtrl',
|
controller: 'NotificationsPageCtrl',
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 1100,
|
order: 1100,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.progressBars', {
|
.state('main.ui.progressBars', {
|
||||||
url: '/progressBars',
|
url: '/progressBars',
|
||||||
templateUrl: 'app/pages/ui/progressBars/progressBars.html',
|
templateUrl: 'app/pages/ui/progressBars/progressBars.html',
|
||||||
title: 'Progress Bars',
|
title: 'Progress Bars',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 600,
|
order: 600,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.slider', {
|
.state('main.ui.slider', {
|
||||||
url: '/slider',
|
url: '/slider',
|
||||||
templateUrl: 'app/pages/ui/slider/slider.html',
|
templateUrl: 'app/pages/ui/slider/slider.html',
|
||||||
title: 'Sliders',
|
title: 'Sliders',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 1000,
|
order: 1000,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.tabs', {
|
.state('main.ui.tabs', {
|
||||||
url: '/tabs',
|
url: '/tabs',
|
||||||
templateUrl: 'app/pages/ui/tabs/tabs.html',
|
templateUrl: 'app/pages/ui/tabs/tabs.html',
|
||||||
title: 'Tabs & Accordions',
|
title: 'Tabs & Accordions',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 800,
|
order: 800,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,13 +11,14 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui.typography', {
|
.state('main.ui.typography', {
|
||||||
url: '/typography',
|
url: '/typography',
|
||||||
templateUrl: 'app/pages/ui/typography/typography.html',
|
templateUrl: 'app/pages/ui/typography/typography.html',
|
||||||
title: 'Typography',
|
title: 'Typography',
|
||||||
sidebarMeta: {
|
sidebarMeta: {
|
||||||
order: 0,
|
order: 0,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
function routeConfig($stateProvider) {
|
function routeConfig($stateProvider) {
|
||||||
$stateProvider
|
$stateProvider
|
||||||
.state('ui', {
|
.state('main.ui', {
|
||||||
url: '/ui',
|
url: '/ui',
|
||||||
template: '<ui-view autoscroll="true" autoscroll-body-top></ui-view>',
|
template: '<ui-view autoscroll="true" autoscroll-body-top></ui-view>',
|
||||||
abstract: true,
|
abstract: true,
|
||||||
|
@ -32,6 +32,7 @@
|
||||||
icon: 'ion-android-laptop',
|
icon: 'ion-android-laptop',
|
||||||
order: 200,
|
order: 200,
|
||||||
},
|
},
|
||||||
|
authenticate: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -73,7 +73,7 @@
|
||||||
return {
|
return {
|
||||||
name: s.name,
|
name: s.name,
|
||||||
title: s.title,
|
title: s.title,
|
||||||
level: (s.name.match(/\./g) || []).length,
|
level: ((s.name.match(/\./g) || []).length - 1),
|
||||||
order: meta.order,
|
order: meta.order,
|
||||||
icon: meta.icon,
|
icon: meta.icon,
|
||||||
stateRef: s.name,
|
stateRef: s.name,
|
||||||
|
|
|
@ -14,9 +14,9 @@
|
||||||
</a>
|
</a>
|
||||||
<ul class="top-dropdown-menu profile-dropdown" uib-dropdown-menu>
|
<ul class="top-dropdown-menu profile-dropdown" uib-dropdown-menu>
|
||||||
<li><i class="dropdown-arr"></i></li>
|
<li><i class="dropdown-arr"></i></li>
|
||||||
<li><a href="#/profile"><i class="fa fa-user"></i>Profile</a></li>
|
<li><a href="#/main/profile"><i class="fa fa-user"></i>Profile</a></li>
|
||||||
<li><a href><i class="fa fa-cog"></i>Settings</a></li>
|
<li><a href><i class="fa fa-cog"></i>Settings</a></li>
|
||||||
<li><a href class="signout"><i class="fa fa-power-off"></i>Sign out</a></li>
|
<li><a href="#/authSignIn" class="signout"><i class="fa fa-power-off"></i>Sign out</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
<msg-center></msg-center>
|
<msg-center></msg-center>
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="en" ng-app="BlurAdmin">
|
<html lang="en" ng-app="BlurAdmin">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
|
@ -23,40 +24,16 @@
|
||||||
<!-- css files will be automatically insert here -->
|
<!-- css files will be automatically insert here -->
|
||||||
<!-- endinject -->
|
<!-- endinject -->
|
||||||
<!-- endbuild -->
|
<!-- endbuild -->
|
||||||
|
|
||||||
|
<!-- build:css({.tmp/serve,src}) styles/auth.css -->
|
||||||
|
<!-- inject:css -->
|
||||||
|
<!-- css files will be automatically insert here -->
|
||||||
|
<!-- endinject -->
|
||||||
|
<!-- endbuild -->
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<div class="body-bg"></div>
|
|
||||||
<main ng-if="$pageFinishedLoading" ng-class="{ 'menu-collapsed': $baSidebarService.isMenuCollapsed() }">
|
|
||||||
|
|
||||||
<ba-sidebar></ba-sidebar>
|
|
||||||
<page-top></page-top>
|
|
||||||
|
|
||||||
<div class="al-main">
|
|
||||||
<div class="al-content">
|
|
||||||
<content-top></content-top>
|
|
||||||
<div ui-view autoscroll="true" autoscroll-body-top></div>
|
<div ui-view autoscroll="true" autoscroll-body-top></div>
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<footer class="al-footer clearfix">
|
|
||||||
<div class="al-footer-right">Created with <i class="ion-heart"></i></div>
|
|
||||||
<div class="al-footer-main clearfix">
|
|
||||||
<div class="al-copy">Blur Admin 2016</div>
|
|
||||||
<ul class="al-share clearfix">
|
|
||||||
<li><i class="socicon socicon-facebook"></i></li>
|
|
||||||
<li><i class="socicon socicon-twitter"></i></li>
|
|
||||||
<li><i class="socicon socicon-google"></i></li>
|
|
||||||
<li><i class="socicon socicon-github"></i></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</footer>
|
|
||||||
|
|
||||||
<back-top></back-top>
|
|
||||||
</main>
|
|
||||||
|
|
||||||
<div id="preloader" ng-show="!$pageFinishedLoading">
|
|
||||||
<div></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- build:js(src) scripts/vendor.js -->
|
<!-- build:js(src) scripts/vendor.js -->
|
||||||
<!-- bower:js -->
|
<!-- bower:js -->
|
||||||
|
@ -76,4 +53,5 @@
|
||||||
<!-- endbuild -->
|
<!-- endbuild -->
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
|
@ -1,28 +1,30 @@
|
||||||
@import "common.scss";
|
@import "common.scss";
|
||||||
@import "theme/_socicon.scss";
|
// @import "theme/_socicon.scss";
|
||||||
@import "theme/_layout.scss";
|
// @import "theme/_layout.scss";
|
||||||
@import 'theme/buttons.scss';
|
// @import 'theme/buttons.scss';
|
||||||
@import 'app/form.scss';
|
// @import 'app/form.scss';
|
||||||
|
// html {
|
||||||
html {
|
// min-height: 520px;
|
||||||
|
// height: 100%;
|
||||||
|
// }
|
||||||
|
.login {
|
||||||
min-height: 520px;
|
min-height: 520px;
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
body {
|
|
||||||
@include main-background();
|
@include main-background();
|
||||||
height: 100%;
|
height: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
$text-color: #ffffff;
|
$text-color: #ffffff;
|
||||||
|
.login .form-control,
|
||||||
.form-control, .form-control:focus {
|
.login .form-control:focus {
|
||||||
@include placeholderStyle($text-color, 0.9);
|
@include placeholderStyle($text-color, 0.9);
|
||||||
background-color: rgba(0, 0, 0, .4);
|
background-color: rgba(0, 0, 0, .4);
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
color: $text-color;
|
color: $text-color;
|
||||||
}
|
}
|
||||||
.form-control[disabled], .form-control[readonly], fieldset[disabled] .form-control {
|
|
||||||
|
.login .form-control[disabled],
|
||||||
|
.login .form-control[readonly],
|
||||||
|
fieldset[disabled] .form-control {
|
||||||
@include placeholderStyle($text-color, 0.6);
|
@include placeholderStyle($text-color, 0.6);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,7 +37,7 @@ $text-color: #ffffff;
|
||||||
|
|
||||||
.auth-block {
|
.auth-block {
|
||||||
width: 540px;
|
width: 540px;
|
||||||
margin: 0 auto;
|
margin: 150px auto;
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
@include bg-translucent-dark(0.55);
|
@include bg-translucent-dark(0.55);
|
||||||
color: #fff;
|
color: #fff;
|
||||||
|
@ -57,12 +59,10 @@ $text-color: #ffffff;
|
||||||
color: $primary-dark;
|
color: $primary-dark;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.control-label {
|
.control-label {
|
||||||
padding-top: 11px;
|
padding-top: 11px;
|
||||||
color: $text-color;
|
color: $text-color;
|
||||||
}
|
}
|
||||||
|
|
||||||
.form-group {
|
.form-group {
|
||||||
margin-bottom: 12px;
|
margin-bottom: 12px;
|
||||||
}
|
}
|
||||||
|
@ -116,7 +116,8 @@ a.forgot-pass {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
&:before, &:after {
|
&:before,
|
||||||
|
&:after {
|
||||||
border-top: solid 1px $text-color;
|
border-top: solid 1px $text-color;
|
||||||
content: "";
|
content: "";
|
||||||
height: 1px;
|
height: 1px;
|
||||||
|
|
Loading…
Reference in New Issue