dwmkerr / angular-modal-service

Modal service for AngularJS - supports creating popups and modals via a service.
MIT License
626 stars 321 forks source link

Close in a single controller? #281

Open alanapplyby opened 4 years ago

alanapplyby commented 4 years ago

When the user clicks a button on my modal I want to call a function which applies some logic and then closes the modal, I want to use a single controller:

function MyController($scope, $http, $window, AlertService, vcRecaptchaService, ModalService, close) {

    $scope.agreeTerms = function() {    
        // some logic...
        close(true, 500); 
    }

    $scope.popModal = function(template, controller) {
        ModalService.showModal({
            templateUrl: template,
            controller: controller,
            preClose: (modal) => {modal.element.modal('hide');}
        }).then(function(modal) {
            modal.element.modal();
            modal.close;            
        });
    };

}

In my template:

ng-click="popModal('termsConditions', 'MyController')"

The button calls the agree terms funciton. At run time I get an error:

Unknown provider: closeProvider <- close <- MyController

I have seen other solutions and it requires using a separate modal controlleer, in my case I want to use one because the logic applied in my functon called by the button on the modal needs to be in the same scope as the original controller.

Is this possible?