Various popups supported by Ionic
Created
September 16, 2015 18:07
-
-
Save davidmaogomezz/c263f6ca21bda40cba81 to your computer and use it in GitHub Desktop.
Popup: Nightly
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<html ng-app="mySuperApp"> | |
<head> | |
<meta charset="utf-8"> | |
<title> | |
Popups | |
</title> | |
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no"> | |
<link href="//code.ionicframework.com/nightly/css/ionic.css" rel="stylesheet"> | |
<script src="//code.ionicframework.com/nightly/js/ionic.bundle.js"></script> | |
</head> | |
<body class="padding" ng-controller="PopupCtrl"> | |
<button class="button button-dark" ng-click="showPopup()"> | |
show | |
</button> | |
<button class="button button-primary" ng-click="showConfirm()"> | |
Confirm | |
</button> | |
<button class="button button-positive" ng-click="showAlert()"> | |
Alert | |
</button> | |
<script id="popup-template.html" type="text/ng-template"> | |
<input ng-model="data.wifi" type="text" placeholder="Password"> | |
</script> | |
</body> | |
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
angular.module('mySuperApp', ['ionic']) | |
.controller('PopupCtrl',function($scope, $ionicPopup, $timeout) { | |
// Triggered on a button click, or some other target | |
$scope.showPopup = function() { | |
$scope.data = {} | |
// An elaborate, custom popup | |
var myPopup = $ionicPopup.show({ | |
template: '<input type="password" ng-model="data.wifi">', | |
title: 'Enter Wi-Fi Password', | |
subTitle: 'Please use normal things', | |
scope: $scope, | |
buttons: [ | |
{ text: 'Cancel' }, | |
{ | |
text: '<b>Save</b>', | |
type: 'button-positive', | |
onTap: function(e) { | |
if (!$scope.data.wifi) { | |
//don't allow the user to close unless he enters wifi password | |
e.preventDefault(); | |
} else { | |
return $scope.data.wifi; | |
} | |
} | |
}, | |
] | |
}); | |
myPopup.then(function(res) { | |
console.log('Tapped!', res); | |
}); | |
$timeout(function() { | |
myPopup.close(); //close the popup after 3 seconds for some reason | |
}, 3000); | |
}; | |
// A confirm dialog | |
$scope.showConfirm = function() { | |
var confirmPopup = $ionicPopup.confirm({ | |
title: 'Consume Ice Cream', | |
template: 'Are you sure you want to eat this ice cream?' | |
}); | |
confirmPopup.then(function(res) { | |
if(res) { | |
console.log('You are sure'); | |
} else { | |
console.log('You are not sure'); | |
} | |
}); | |
}; | |
// An alert dialog | |
$scope.showAlert = function() { | |
var alertPopup = $ionicPopup.alert({ | |
title: 'Don\'t eat that!', | |
template: 'It might taste good' | |
}); | |
alertPopup.then(function(res) { | |
console.log('Thank you for not eating my delicious ice cream cone'); | |
}); | |
}; | |
}); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment