Skip to content
This repository has been archived by the owner on Sep 5, 2024. It is now read-only.

Commit

Permalink
feat(tabs): adds support for md-center-tabs
Browse files Browse the repository at this point in the history
Closes #1992
  • Loading branch information
Robert Messerle committed Apr 1, 2015
1 parent 7b78071 commit 2de0cf2
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 1 deletion.
9 changes: 8 additions & 1 deletion src/components/tabs/js/tabsController.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
ctrl.attachRipple = attachRipple;
ctrl.shouldStretchTabs = shouldStretchTabs;
ctrl.shouldPaginate = shouldPaginate;
ctrl.shouldCenterTabs = shouldCenterTabs;
ctrl.insertTab = insertTab;
ctrl.removeTab = removeTab;
ctrl.select = select;
Expand Down Expand Up @@ -97,7 +98,8 @@
}

function handleOffsetChange (left) {
angular.element(elements.paging).css('left', '-' + left + 'px');
var newValue = shouldCenterTabs() ? '' : '-' + left + 'px';
angular.element(elements.paging).css('left', newValue);
$scope.$broadcast('$mdTabsPaginationChanged');
}

Expand All @@ -113,6 +115,7 @@
}

function adjustOffset () {
if (shouldCenterTabs()) return;
var tab = elements.tabs[ctrl.focusIndex],
left = tab.offsetLeft,
right = tab.offsetWidth + left;
Expand Down Expand Up @@ -249,6 +252,10 @@
}
}

function shouldCenterTabs () {
return $scope.centerTabs && !shouldPaginate();
}

function shouldPaginate () {
var canvasWidth = $element.prop('clientWidth');
angular.forEach(elements.tabs, function (tab) { canvasWidth -= tab.offsetWidth; });
Expand Down
3 changes: 3 additions & 0 deletions src/components/tabs/js/tabsDirective.js
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@
* @param {string=} md-align-tabs Attribute to indicate position of tab buttons: `bottom` or `top`; default is `top`
* @param {string=} md-stretch-tabs Attribute to indicate whether or not to stretch tabs: `auto`, `always`, or `never`; default is `auto`
* @param {boolean=} md-dynamic-height When enabled, the tab wrapper will resize based on the contents of the selected tab
* @param {boolean=} md-center-tabs When enabled, tabs will be centered provided there is no need for pagination
*
* @usage
* <hljs lang="html">
Expand Down Expand Up @@ -91,6 +92,7 @@
return {
scope: {
dynamicHeight: '=?mdDynamicHeight',
centerTabs: '=?mdCenterTabs',
selectedIndex: '=?mdSelected',
stretchTabs: '@?mdStretchTabs'
},
Expand Down Expand Up @@ -126,6 +128,7 @@
ng-keydown="$mdTabsCtrl.keydown($event)"\
role="tablist">\
<md-pagination-wrapper\
ng-class="{ \'md-center-tabs\': $mdTabsCtrl.shouldCenterTabs() }"\
md-tab-scroll="$mdTabsCtrl.scroll($event)">\
<md-tab-item\
tabindex="-1"\
Expand Down
8 changes: 8 additions & 0 deletions src/components/tabs/tabs.scss
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,14 @@ md-tabs {
transition: left $swift-ease-in-out-duration $swift-ease-in-out-timing-function;
position: relative;
width: 999999px;
left: 0;
transform: translate3d(0, 0, 0);
&.md-center-tabs {
width: initial;
float: left;
left: 50%;
transform: translate3d(-50%, 0, 0);
}
}
&.md-stretch-tabs {
md-pagination-wrapper {
Expand Down

0 comments on commit 2de0cf2

Please sign in to comment.