modal stack single option

This commit is contained in:
Artem Fitiskin 2015-05-27 00:55:07 +03:00
parent 976b83708b
commit e716b76e9a
2 changed files with 42 additions and 6 deletions

View File

@ -271,7 +271,8 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
templateUrl: templateUrl('user_modal'), templateUrl: templateUrl('user_modal'),
controller: 'UserModalController', controller: 'UserModalController',
scope: scope, scope: scope,
windowClass: 'user_modal_window mobile_modal' windowClass: 'user_modal_window mobile_modal',
backdrop: 'single'
}); });
}; };

View File

@ -787,6 +787,10 @@ angular.module('ui.bootstrap.modal', ['ui.bootstrap.transition'])
element.addClass(attrs.windowClass || ''); element.addClass(attrs.windowClass || '');
scope.size = attrs.size; scope.size = attrs.size;
$modalStack.registerObserverCallback(function(hiddenBySingle) {
scope.hiddenBySingle = hiddenBySingle || false;
});
$timeout(function () { $timeout(function () {
// trigger CSS transitions // trigger CSS transitions
scope.animate = true; scope.animate = true;
@ -835,6 +839,25 @@ angular.module('ui.bootstrap.modal', ['ui.bootstrap.transition'])
var backdropDomEl, backdropScope; var backdropDomEl, backdropScope;
var openedWindows = $$stackedMap.createNew(); var openedWindows = $$stackedMap.createNew();
var $modalStack = {}; var $modalStack = {};
var observerCallbacks = [];
function notifyObservers() {
angular.forEach(observerCallbacks, function(callback, index) {
var hasSingleParent = false,
opened = openedWindows.keys();
for (var i = 0; i < opened.length; i++) {
var item = openedWindows.get(opened[i]).value;
if (item.backdrop == 'single' && item.index > index) {
hasSingleParent = true;
break;
}
}
callback(hasSingleParent);
});
};
function backdropIndex() { function backdropIndex() {
var topBackdropIndex = -1; var topBackdropIndex = -1;
@ -854,13 +877,15 @@ angular.module('ui.bootstrap.modal', ['ui.bootstrap.transition'])
}); });
function removeModalWindow(modalInstance) { function removeModalWindow(modalInstance) {
var body = $document.find('body').eq(0); var body = $document.find('body').eq(0);
var modalWindow = openedWindows.get(modalInstance).value; var modalWindow = openedWindows.get(modalInstance).value;
//clean up the stack //clean up the stack
openedWindows.remove(modalInstance); openedWindows.remove(modalInstance);
//clean up the observer
observerCallbacks.splice(modalWindow.index, 1);
//remove window DOM element //remove window DOM element
removeAfterAnimate(modalWindow.modalDomEl, modalWindow.modalScope, 0, function() { removeAfterAnimate(modalWindow.modalDomEl, modalWindow.modalScope, 0, function() {
modalWindow.modalScope.$destroy(); modalWindow.modalScope.$destroy();
@ -879,6 +904,8 @@ angular.module('ui.bootstrap.modal', ['ui.bootstrap.transition'])
}); });
backdropDomEl = undefined; backdropDomEl = undefined;
backdropScope = undefined; backdropScope = undefined;
} else {
notifyObservers();
} }
} }
@ -928,8 +955,11 @@ angular.module('ui.bootstrap.modal', ['ui.bootstrap.transition'])
} }
}); });
$modalStack.open = function (modalInstance, modal) { $modalStack.registerObserverCallback = function(callback){
observerCallbacks.push(callback);
};
$modalStack.open = function (modalInstance, modal) {
openedWindows.add(modalInstance, { openedWindows.add(modalInstance, {
deferred: modal.deferred, deferred: modal.deferred,
modalScope: modal.scope, modalScope: modal.scope,
@ -949,19 +979,24 @@ angular.module('ui.bootstrap.modal', ['ui.bootstrap.transition'])
body.append(backdropDomEl); body.append(backdropDomEl);
} }
var angularDomEl = angular.element('<div modal-window></div>'); var angularDomEl = angular.element('<div modal-window></div>'),
index = openedWindows.length() - 1;
angularDomEl.attr({ angularDomEl.attr({
'template-url': modal.windowTemplateUrl, 'template-url': modal.windowTemplateUrl,
'window-class': modal.windowClass, 'window-class': modal.windowClass,
'size': modal.size, 'size': modal.size,
'index': openedWindows.length() - 1, 'index': index,
'animate': 'animate' 'animate': 'animate'
}).html(modal.content); }).html(modal.content);
var modalDomEl = $compile(angularDomEl)(modal.scope); var modalDomEl = $compile(angularDomEl)(modal.scope);
openedWindows.top().value.modalDomEl = modalDomEl; openedWindows.top().value.modalDomEl = modalDomEl;
openedWindows.top().value.index = index;
body.append(modalDomEl); body.append(modalDomEl);
body.addClass(OPENED_MODAL_CLASS); body.addClass(OPENED_MODAL_CLASS);
notifyObservers();
}; };
$modalStack.close = function (modalInstance, result) { $modalStack.close = function (modalInstance, result) {
@ -1222,7 +1257,7 @@ angular.module("template/modal/backdrop.html", []).run(["$templateCache", functi
angular.module("template/modal/window.html", []).run(["$templateCache", function($templateCache) { angular.module("template/modal/window.html", []).run(["$templateCache", function($templateCache) {
$templateCache.put("template/modal/window.html", $templateCache.put("template/modal/window.html",
"<div tabindex=\"-1\" role=\"dialog\" class=\"modal fade\" ng-class=\"{in: animate}\" ng-style=\"{'z-index': 1050 + index*10, display: 'block'}\" ng-click=\"close($event)\">\n" + "<div tabindex=\"-1\" role=\"dialog\" class=\"modal fade\" ng-class=\"{in: animate}\" ng-style=\"{'z-index': 1050 + index*10, display: hiddenBySingle ? 'none' : 'block'}\" ng-click=\"close($event)\">\n" +
" <div class=\"modal_close_wrap\" ng-click=\"close($event)\">\n" + " <div class=\"modal_close_wrap\" ng-click=\"close($event)\">\n" +
" <div class=\"modal_close\"></div>\n" + " <div class=\"modal_close\"></div>\n" +
" </div>\n" + " </div>\n" +