Demo showing how to go back to the home view of a specific tab everytime the tab is opened
See more Ionic work on my blog blog.clearlyinnovative.com
Forked from Ionic's Pen Tabs And Navigation: 1.0.0-beta.6.
A Pen by aaron k saunders on CodePen.
<html ng-app="ionicApp"> | |
<head> | |
<meta charset="utf-8"> | |
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width"> | |
<title>Tabs Example</title> | |
<link href="http://code.ionicframework.com/1.0.0-beta.8/css/ionic.css" rel="stylesheet"> | |
<script src="http://code.ionicframework.com/1.0.0-beta.8/js/ionic.bundle.js"></script> | |
</head> | |
<body ng-controller="MainCtrl as main"> | |
<ion-nav-bar class="nav-title-slide-ios7 bar-positive"> | |
<ion-nav-back-button class="button-icon ion-arrow-left-c"> | |
</ion-nav-back-button> | |
</ion-nav-bar> | |
<ion-nav-view animation="slide-left-right"></ion-nav-view> | |
<script id="tabs.html" type="text/ng-template"> | |
<ion-tabs class="tabs-icon-top tabs-positive"> | |
<ion-tab title="Home" icon="ion-home" | |
href="#/tab/home" | |
on-select="main.onTabSelected(this)" | |
on-deselect="main.onTabDeselected(this)"> | |
<ion-nav-view name="home-tab"></ion-nav-view> | |
</ion-tab> | |
<ion-tab title="About" icon="ion-ios7-information" | |
href="#/tab/about"> | |
<ion-nav-view name="about-tab"></ion-nav-view> | |
</ion-tab> | |
<ion-tab title="Contact" icon="ion-ios7-world" | |
ui-sref="tabs.contact"> | |
<ion-nav-view name="contact-tab"></ion-nav-view> | |
</ion-tab> | |
</ion-tabs> | |
</script> | |
<script id="home.html" type="text/ng-template"> | |
<ion-view title="Home"> | |
<ion-content class="padding"> | |
<p>Example of Ionic tabs. Navigate to each tab, and | |
navigate to child views of each tab and notice how | |
each tab has its own navigation history.</p> | |
<p> | |
<a class="button icon icon-right ion-chevron-right" href="#/tab/facts">Scientific Facts</a> | |
</p> | |
</ion-content> | |
</ion-view> | |
</script> | |
<script id="facts.html" type="text/ng-template"> | |
<ion-view title="Facts" class="padding"> | |
<ion-content> | |
<p>Banging your head against a wall uses 150 calories an hour.</p> | |
<p>Dogs have four toes on their hind feet, and five on their front feet.</p> | |
<p>The ant can lift 50 times its own weight, can pull 30 times its own weight and always falls over on its right side when intoxicated.</p> | |
<p>A cockroach will live nine days without it's head, before it starves to death.</p> | |
<p>Polar bears are left handed.</p> | |
<p> | |
<a class="button icon ion-home" href="#/tab/home"> Home</a> | |
<a class="button icon icon-right ion-chevron-right" href="#/tab/facts2">More Facts</a> | |
</p> | |
</ion-content> | |
</ion-view> | |
</script> | |
<script id="facts2.html" type="text/ng-template"> | |
<ion-view title="Also Factual"> | |
<ion-content class="padding"> | |
<p>111,111,111 x 111,111,111 = 12,345,678,987,654,321</p> | |
<p>1 in every 4 Americans has appeared on T.V.</p> | |
<p>11% of the world is left-handed.</p> | |
<p>1 in 8 Americans has worked at a McDonalds restaurant.</p> | |
<p>$283,200 is the absolute highest amount of money you can win on Jeopardy.</p> | |
<p>101 Dalmatians, Peter Pan, Lady and the Tramp, and Mulan are the only Disney cartoons where both parents are present and don't die throughout the movie.</p> | |
<p> | |
<a class="button icon ion-home" href="#/tab/home"> Home</a> | |
<a class="button icon ion-chevron-left" href="#/tab/facts"> Scientific Facts</a> | |
</p> | |
</ion-content> | |
</ion-view> | |
</script> | |
<script id="about.html" type="text/ng-template"> | |
<ion-view title="About"> | |
<ion-content class="padding"> | |
<h3>Create hybrid mobile apps with the web technologies you love.</h3> | |
<p>Free and open source, Ionic offers a library of mobile-optimized HTML, CSS and JS components for building highly interactive apps.</p> | |
<p>Built with Sass and optimized for AngularJS.</p> | |
<p> | |
<a class="button icon icon-right ion-chevron-right" href="#/tab/navstack">Tabs Nav Stack</a> | |
</p> | |
</ion-content> | |
</ion-view> | |
</script> | |
<script id="nav-stack.html" type="text/ng-template"> | |
<ion-view title="Tab Nav Stack"> | |
<ion-content class="padding"> | |
<p><img src="http://ionicframework.com/img/diagrams/tabs-nav-stack.png" style="width:100%"></p> | |
</ion-content> | |
</ion-view> | |
</script> | |
<script id="contact.html" type="text/ng-template"> | |
<ion-view title="Contact"> | |
<ion-content> | |
<p>@IonicFramework</p> | |
<p>@DriftyCo</p> | |
</ion-content> | |
</ion-view> | |
</script> | |
</body> | |
</html> |
angular.module('ionicApp', ['ionic']) | |
.config(function($stateProvider, $urlRouterProvider) { | |
$stateProvider | |
.state('tabs', { | |
url: "/tab", | |
abstract: true, | |
templateUrl: "tabs.html" | |
}) | |
.state('tabs.home', { | |
url: "/home", | |
views: { | |
'home-tab': { | |
templateUrl: "home.html", | |
controller: 'HomeTabCtrl as homeCtrl' | |
} | |
} | |
}) | |
.state('tabs.facts', { | |
url: "/facts", | |
views: { | |
'home-tab': { | |
templateUrl: "facts.html" | |
} | |
} | |
}) | |
.state('tabs.facts2', { | |
url: "/facts2", | |
views: { | |
'home-tab': { | |
templateUrl: "facts2.html" | |
} | |
} | |
}) | |
.state('tabs.about', { | |
url: "/about", | |
views: { | |
'about-tab': { | |
templateUrl: "about.html" | |
} | |
} | |
}) | |
.state('tabs.navstack', { | |
url: "/navstack", | |
views: { | |
'about-tab': { | |
templateUrl: "nav-stack.html" | |
} | |
} | |
}) | |
.state('tabs.contact', { | |
url: "/contact", | |
views: { | |
'contact-tab': { | |
templateUrl: "contact.html" | |
} | |
} | |
}); | |
$urlRouterProvider.otherwise("/tab/home"); | |
}) | |
.controller('MainCtrl', ['$state', function($state) { | |
//console.log('HomeTabCtrl'); | |
this.onTabSelected = function(_scope){ | |
console.log("onTabSelected - main"); | |
// if we are selectng the home title then | |
// change the state back to the top state | |
if ( _scope.title === 'Home') { | |
setTimeout(function() { | |
$state.go('tabs.home', {}); | |
},20); | |
} | |
} | |
this.onTabDeselected = function(){ | |
console.log("onTabDeselected - main"); | |
} | |
}]) | |
.controller('HomeTabCtrl', function($scope) { | |
}); |
Demo showing how to go back to the home view of a specific tab everytime the tab is opened
See more Ionic work on my blog blog.clearlyinnovative.com
Forked from Ionic's Pen Tabs And Navigation: 1.0.0-beta.6.
A Pen by aaron k saunders on CodePen.