160 lines
4.3 KiB
JavaScript
160 lines
4.3 KiB
JavaScript
|
/**
|
||
|
* Copyright (c) 2015-present, Facebook, Inc.
|
||
|
* All rights reserved.
|
||
|
*
|
||
|
* This source code is licensed under the BSD-style license found in the
|
||
|
* LICENSE file in the root directory of this source tree. An additional grant
|
||
|
* of patent rights can be found in the PATENTS file in the same directory.
|
||
|
*
|
||
|
* @providesModule NavigatorNavigationBarStyles
|
||
|
*/
|
||
|
'use strict';
|
||
|
|
||
|
var buildStyleInterpolator = require('buildStyleInterpolator');
|
||
|
var merge = require('merge');
|
||
|
|
||
|
// Android Material Design
|
||
|
var NAV_BAR_HEIGHT = 56;
|
||
|
var TITLE_LEFT = 72;
|
||
|
var BUTTON_SIZE = 24;
|
||
|
var TOUCH_TARGT_SIZE = 48;
|
||
|
var BUTTON_HORIZONTAL_MARGIN = 16;
|
||
|
|
||
|
var BUTTON_EFFECTIVE_MARGIN = BUTTON_HORIZONTAL_MARGIN - (TOUCH_TARGT_SIZE - BUTTON_SIZE) / 2;
|
||
|
var NAV_ELEMENT_HEIGHT = NAV_BAR_HEIGHT;
|
||
|
|
||
|
var BASE_STYLES = {
|
||
|
Title: {
|
||
|
position: 'absolute',
|
||
|
bottom: 0,
|
||
|
left: 0,
|
||
|
right: 0,
|
||
|
alignItems: 'flex-start',
|
||
|
height: NAV_ELEMENT_HEIGHT,
|
||
|
backgroundColor: 'transparent',
|
||
|
marginLeft: TITLE_LEFT,
|
||
|
},
|
||
|
LeftButton: {
|
||
|
position: 'absolute',
|
||
|
top: 0,
|
||
|
left: BUTTON_EFFECTIVE_MARGIN,
|
||
|
overflow: 'hidden',
|
||
|
height: NAV_ELEMENT_HEIGHT,
|
||
|
backgroundColor: 'transparent',
|
||
|
},
|
||
|
RightButton: {
|
||
|
position: 'absolute',
|
||
|
top: 0,
|
||
|
right: BUTTON_EFFECTIVE_MARGIN,
|
||
|
overflow: 'hidden',
|
||
|
alignItems: 'flex-end',
|
||
|
height: NAV_ELEMENT_HEIGHT,
|
||
|
backgroundColor: 'transparent',
|
||
|
},
|
||
|
};
|
||
|
|
||
|
// There are 3 stages: left, center, right. All previous navigation
|
||
|
// items are in the left stage. The current navigation item is in the
|
||
|
// center stage. All upcoming navigation items are in the right stage.
|
||
|
// Another way to think of the stages is in terms of transitions. When
|
||
|
// we move forward in the navigation stack, we perform a
|
||
|
// right-to-center transition on the new navigation item and a
|
||
|
// center-to-left transition on the current navigation item.
|
||
|
var Stages = {
|
||
|
Left: {
|
||
|
Title: merge(BASE_STYLES.Title, { opacity: 0 }),
|
||
|
LeftButton: merge(BASE_STYLES.LeftButton, { opacity: 0 }),
|
||
|
RightButton: merge(BASE_STYLES.RightButton, { opacity: 0 }),
|
||
|
},
|
||
|
Center: {
|
||
|
Title: merge(BASE_STYLES.Title, { opacity: 1 }),
|
||
|
LeftButton: merge(BASE_STYLES.LeftButton, { opacity: 1 }),
|
||
|
RightButton: merge(BASE_STYLES.RightButton, { opacity: 1 }),
|
||
|
},
|
||
|
Right: {
|
||
|
Title: merge(BASE_STYLES.Title, { opacity: 0 }),
|
||
|
LeftButton: merge(BASE_STYLES.LeftButton, { opacity: 0 }),
|
||
|
RightButton: merge(BASE_STYLES.RightButton, { opacity: 0 }),
|
||
|
},
|
||
|
};
|
||
|
|
||
|
|
||
|
var opacityRatio = 100;
|
||
|
|
||
|
function buildSceneInterpolators(startStyles, endStyles) {
|
||
|
return {
|
||
|
Title: buildStyleInterpolator({
|
||
|
opacity: {
|
||
|
type: 'linear',
|
||
|
from: startStyles.Title.opacity,
|
||
|
to: endStyles.Title.opacity,
|
||
|
min: 0,
|
||
|
max: 1,
|
||
|
},
|
||
|
left: {
|
||
|
type: 'linear',
|
||
|
from: startStyles.Title.left,
|
||
|
to: endStyles.Title.left,
|
||
|
min: 0,
|
||
|
max: 1,
|
||
|
extrapolate: true,
|
||
|
},
|
||
|
}),
|
||
|
LeftButton: buildStyleInterpolator({
|
||
|
opacity: {
|
||
|
type: 'linear',
|
||
|
from: startStyles.LeftButton.opacity,
|
||
|
to: endStyles.LeftButton.opacity,
|
||
|
min: 0,
|
||
|
max: 1,
|
||
|
round: opacityRatio,
|
||
|
},
|
||
|
left: {
|
||
|
type: 'linear',
|
||
|
from: startStyles.LeftButton.left,
|
||
|
to: endStyles.LeftButton.left,
|
||
|
min: 0,
|
||
|
max: 1,
|
||
|
},
|
||
|
}),
|
||
|
RightButton: buildStyleInterpolator({
|
||
|
opacity: {
|
||
|
type: 'linear',
|
||
|
from: startStyles.RightButton.opacity,
|
||
|
to: endStyles.RightButton.opacity,
|
||
|
min: 0,
|
||
|
max: 1,
|
||
|
round: opacityRatio,
|
||
|
},
|
||
|
left: {
|
||
|
type: 'linear',
|
||
|
from: startStyles.RightButton.left,
|
||
|
to: endStyles.RightButton.left,
|
||
|
min: 0,
|
||
|
max: 1,
|
||
|
extrapolate: true,
|
||
|
},
|
||
|
}),
|
||
|
};
|
||
|
}
|
||
|
|
||
|
var Interpolators = {
|
||
|
// Animating *into* the center stage from the right
|
||
|
RightToCenter: buildSceneInterpolators(Stages.Right, Stages.Center),
|
||
|
// Animating out of the center stage, to the left
|
||
|
CenterToLeft: buildSceneInterpolators(Stages.Center, Stages.Left),
|
||
|
// Both stages (animating *past* the center stage)
|
||
|
RightToLeft: buildSceneInterpolators(Stages.Right, Stages.Left),
|
||
|
};
|
||
|
|
||
|
|
||
|
module.exports = {
|
||
|
General: {
|
||
|
NavBarHeight: NAV_BAR_HEIGHT,
|
||
|
StatusBarHeight: 0,
|
||
|
TotalNavHeight: NAV_BAR_HEIGHT,
|
||
|
},
|
||
|
Interpolators,
|
||
|
Stages,
|
||
|
};
|