Skip to content

Instantly share code, notes, and snippets.

Created June 7, 2014 11:02

Revisions

  1. @invalid-email-address Anonymous created this gist Jun 7, 2014.
    7 changes: 7 additions & 0 deletions Ionic---Back-Button-In-Tabs.markdown
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,7 @@
    Ionic - Back Button In Tabs
    ---------------------------
    Attempting to get Tabs view to show back buttons or at least "left-buttons"

    A [Pen](http://codepen.io/calendee/pen/BKjnz) by [Justin Noel](http://codepen.io/calendee) on [CodePen](http://codepen.io/).

    [License](http://codepen.io/calendee/pen/BKjnz/license).
    127 changes: 127 additions & 0 deletions index.html
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,127 @@
    <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/0.9.26/css/ionic.min.css" rel="stylesheet">
    <script src="http://code.ionicframework.com/0.9.26/js/ionic.bundle.min.js"></script>
    </head>

    <body>

    <ion-nav-bar animation="nav-title-slide-ios7"
    type="bar-positive"
    back-button-type="button-icon"
    back-button-icon="ion-arrow-left-c"></ion-nav-bar>

    <ion-nav-view animation="slide-left-right"></ion-nav-view>


    <script id="start.html" type="text/ng-template">
    <ion-view title="'Start'">
    <ion-content has-header="true" padding="true">

    <a class="button icon icon-right ion-chevron-right" href="#/tab/home">Go To Page With Tabs</a>
    </p>
    </ion-content>
    </ion-view>
    </script>

    <script id="tabs.html" type="text/ng-template">
    <ion-tabs tabs-style="tabs-icon-top" tabs-type="tabs-positive" left-buttons="leftButtons">

    <ion-tab title="Home" icon="ion-home" href="#/tab/home" >
    <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 has-header="true" padding="true">
    <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'">
    <ion-content has-header="true" padding="true">
    <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 has-header="true" padding="true">
    <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 has-header="true" padding="true">
    <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 has-header="true" padding="true">
    <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 has-header="true" padding="true">
    <p>@IonicFramework</p>
    <p>@DriftyCo</p>
    </ion-content>
    </ion-view>
    </script>

    </body>
    </html>
    80 changes: 80 additions & 0 deletions script.js
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,80 @@
    angular.module('ionicApp', ['ionic'])

    .config(function($stateProvider, $urlRouterProvider) {

    $stateProvider
    .state('start', {
    url: "/start",
    templateUrl: "start.html"
    })
    .state('tabs', {
    url: "/tab",
    abstract: true,
    templateUrl: "tabs.html"
    })
    .state('tabs.home', {
    url: "/home",
    views: {
    'home-tab': {
    templateUrl: "home.html",
    controller: 'HomeTabCtrl'
    }
    }
    })
    .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("/start");

    })

    .controller('HomeTabCtrl', function($scope) {
    console.log('HomeTabCtrl');

    $scope.leftButtons = [{
    type: 'button-icon icon ion-navicon',
    tap: function(e) {
    console.log('Going back!');
    }
    }];

    });