Leverages UI Bootstrap and UI Router to give you full-strength route-driven tabs in Angular.js.
-
Install the plugin into your Angular.js project, manually or via
bower install angular-ui-router-tabs
-
Add
ui.router.tabs
as a new module dependency in your angular app. -
Define your routes in a hierarchy that makes sense for a tabbed layout, Eg:
$stateProvider.state('user', {
url: '',
controller: 'UserCtrl',
templateUrl: 'example.html'
}).state('user.settings', {
url: '/user/settings',
templateUrl: 'user/settings.html'
}).state('user.accounts', {
url: '/user/accounts',
templateUrl: 'user/accounts.html'
});
- Define your
tabData
(or similiar variable) in the root view controller of your tabs (ie.UserCtrl
in the case above) Eg:
$scope.tabData = [
{
heading: 'Settings',
route: 'user.settings'
},
{
heading: 'Accounts',
route: 'user.accounts'
}
];
NOTE: You can also specify params
and options
to pass special parameters or options for the target route to UI Router, Eg:
{
heading: 'Accounts',
route: 'user.accounts',
params: {
accountId: account.id
},
options: {}
}
- Declare the following in your the parent HTML view template
<tabs data="tabData" type="tabs" />
.
Optional attributes for the <tabs>
(which are passed on to the UI Bootstrap component) are:
type: [ 'tabs' | 'pills' ]
vertical: boolean
justified: boolean
- Define a
ui-view
placeholder for the child content panes in the same HTML view template eg.<ui-view></ui-view>
.
- You can override the default directive template by specifying
template-url="my_template.html"
on the<tabs>
element. - You can use
<tab-heading>
in a custom directive template to add any HTML into the tab title. - You can update the
tabData
variable dynamically, if you want to. - You can move the
<tabs>
tag around to wherever you want the tab listing to appear. (left-positioned is the best spot to enable responsive design.) - If you are using the
<tabs>
in your root route (ie. inindex.html
directly) you can turn off auto-selecting the default tab (since UI Router can't determine the initial state), use by settingauto-select-default-tab="false"
(true by default). If you do this though, it won't auto-navigate to the first tab route initially - to achieve this put the url of the first route in$urlRouterProvider.otherwise(...)
under theconfig
function of your app.
- Checkout git repository locally:
git clone [email protected]:rpocklin/ui-router-tabs.git
npm install
bower install
grunt serve
- View
http://localhost:9000/example/
in your browser to see the example.
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Added some feature'
) - please consider adding tests! - Push to the branch (
git push origin my-new-feature
) - Run
grunt
and ensure there are no errors. - Create a new Pull Request
- 1.3.1 Added
auto-select-default-tab
option and updated jsbeautifier. See #16. - 1.3.0 Improved state equality checking to include params and options.
- 1.2.0 Prevented reload of current state again. See #11.
- 1.1.4 Added support for
strict-di
mode. - 1.1.3 Fixed tab switching when using
ngTouch
. See #2. - 1.1.2 Added
$stateChangeSuccess
watcher to update parent tab(s) when usingui-sref
or$state.go()
. See #1. - 1.1.0 Added nested tab support (tabs within tabs)
- 1.0.0 Initial release
Released under the MIT License. See the LICENSE file for further details.