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

54 lines
2.2 KiB
JavaScript
Raw Normal View History

2015-05-05 03:10:25 +02:00
'use strict';
(function (angular) {
var deviseModal = angular.module('DeviseModal', [
'Devise',
'ui.bootstrap'
]);
deviseModal.run([
2016-03-23 18:39:41 +01:00
'$uibModal',
2015-05-05 03:10:25 +02:00
'$http',
'Auth',
'$rootScope',
2016-03-23 18:39:41 +01:00
function ($uibModal, $http, Auth, $rootScope) {
2015-05-05 03:10:25 +02:00
var promise = null;
function reset() {
promise = null;
}
function partial(fn, arg) {
return function () {
return fn.call(this, arg);
};
}
$rootScope.$on('devise:unauthorized', function (event, response, deferred) {
function retryRequestAfterLogin() {
return promise.then(function () {
return $http(response.config);
}).then(deferred.resolve, partial(deferred.reject, response));
}
if (!promise) {
2016-03-23 18:39:41 +01:00
promise = $uibModal.open({
2015-05-05 03:10:25 +02:00
templateUrl: 'deviseModal.html',
2016-03-23 18:39:41 +01:00
controller: function ($scope, $uibModalInstance) {
2015-05-05 03:10:25 +02:00
var user = $scope.user = {};
$scope.login = function () {
2016-03-23 18:39:41 +01:00
$uibModalInstance.close(user);
2015-05-05 03:10:25 +02:00
};
$scope.dismiss = function () {
2016-03-23 18:39:41 +01:00
$uibModalInstance.dismiss('cancel');
2015-05-05 03:10:25 +02:00
};
}
}).result['finally'](reset).then(Auth.login);
}
retryRequestAfterLogin();
});
}
]);
deviseModal.run([
'$templateCache',
function ($templateCache) {
'use strict';
$templateCache.put('deviseModal.html', '<div id=loginModal><div class=modal-header><button type=button class=close ng-click=dismiss()>x</button><h3>Have an Account?</h3></div><div class=modal-body><div class=well><form name=loginForm><div class=form-group ng-class="{\'has-error\': emailError}"><label class=control-label>Email</label><input type=email name=email class=form-control ng-model=user.email required=required ng-blur="emailError = !!loginForm.email.$error.email" ng-focus="emailError = false"></div><div class=form-group><label class=control-label for=password>Password</label><input type=password name=password class=form-control ng-model=user.password required=required></div><button class="btn btn-primary" ng-click=login()>Login</button></form></div></div></div>');
}
]);
}(angular));