Simple, flexible and beautiful modal dialogs in AngularJS.
- If you use bower or npm, just
bower/npm install v-modal
. If not, download files from the github repo - Reference
v-modal.css
andv-modal.js
in your index.html file - Reference the module in your app:
angular.module('myApp', [ 'vModal' ])
app.js
angular.module('myApp', ['vModal'])
.factory('myModal', function (vModal) {
return vModal({
controller: 'MyModalController',
controllerAs: 'myModalCtrl',
templateUrl: 'my-modal.html'
});
})
.controller('MyModalController', function (myModal) {
this.close = myModal.deactivate;
})
.controller('AppController', function (myModal) {
this.show = myModal.activate;
});
index.html
<div ng-app="myApp" ng-controller="AppController as appCtrl">
<button ng-click="appCtrl.show()">Show</button>
</div>
my-modal.html
<v-modal class="vModal--default" onclose="myModalCtrl.close()">
<v-dialog heading="My modal" small middle>
<v-close label="Close"></v-close>
<h1>My modal</h1>
<button ng-click="myModalCtrl.close()">OK</button>
</v-dialog>
</v-modal>
small
medium
large
fit
<v-dialog large></v-dialog>
center
(default)middle
<v-dialog middle></v-dialog>
By default, vModal manages keyboard focus and adds some common ARIA attributes to improve accessibility of your dialogs.
vModal
service is based angular-modal by Brian Ford.