Ich versuche, eine Direktive zu erstellen, die eckig ui Bootstrap modal verwendet. Ich möchte diese Direktive von meinem Controller öffnen, wenn eine $ http-Anfrage gemacht wird, und sie schließen, wenn die Anfrage verrechnet wird. Ich bin neu zu kantig und ein bisschen fest. Hier ist, was ich bisher habe.
expedition.html Controller:
.controller('ExpeditionCtrl', ['$http', 'UserFactory', '$scope',
function ($http, UserFactory, $scope) {
var vm = this;
vm.totalItems;
vm.itemsPerPage = 100;
vm.currentPage = 1;
vm.pageChanged = pageChanged;
vm.content = [];
vm.loadingInstance;
vm.open;
fetchPage();
function pageChanged() {
fetchPage();
}
function fetchPage() {
$http.get('myapi?page=' + vm.currentPage + "&limit=" + vm.itemsPerPage)
.then(function(response) {
angular.extend(vm.content, response.data.content);
vm.content = response.data.content;
vm.totalItems = response.data.totalElements;
})
}
}
expedition.html:
<div class="section">
<div class="sectioncontent">
// some html
<uib-pagination total-items="vm.totalItems" ng-model="vm.currentPage" ng-change="vm.pageChanged()" items-per-page="vm.itemsPerPage"></uib-pagination>
</div>
<loading-modal loadingInstance="vm.loadingInstance" open="vm.open"></loading-modal>
</div>
</div>
loadingModal.directive.js:
.directive('loadingModal', ['$uibModal',
function($modal) {
return {
transclude: true,
restrict: 'EA',
template: '<div ng-init="open()"> Test Loading </div>',
scope: {
loadingInstance: "=",
open: "="
},
link: function(scope, element, attrs) {
scope.open = function(){
scope.loadingInstance = $modal.open({
templateUrl: 'app/templates/loadingModal.tpl.html',
controller: scope.useCtrl,
size: 'sm',
windowClass: 'app-modal-window',
backdrop: true,
});
scope.loadingInstance.result.then(function(){
scope.initialized = true;
console.log('Finished');
}, function(){
scope.initialized = true;
console.log('Modal dismissed at : ' + new Date());
});
};
}
};
}]);
loadingModal.tpl.html:
<div class="modal-body">
Loading ....
</div>
Bitte geben Sie den Inhalt der Modulvorlage in der Frage –
Sie haben in dem Sie die '$ uibModalInstance.close()' (Oder '$ uibModalInstance.dismiss()') nennen das Teil nicht enthalten, Sie müssen jedoch eine dieser Funktionen aufrufen, nachdem die Anfrage gelöst wurde. –
Richtig, ich hatte das nicht getan, da ich das Modal nicht öffnen konnte. Ich konnte den Dialog nicht öffnen. Ich habe versucht, ng-init in der Richtlinie Vorlage zu verwenden. "Vorlage: '