forked from GeekyAnts/NativeBase
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathHeader.js
More file actions
125 lines (123 loc) · 3.65 KB
/
Header.js
File metadata and controls
125 lines (123 loc) · 3.65 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
import React, { Component } from "react";
import PropTypes from "prop-types";
import { View, StatusBar, ViewPropTypes, StyleSheet } from "react-native";
import { connectStyle } from "native-base-shoutem-theme";
import mapPropsToStyleNames from "../utils/mapPropsToStyleNames";
import variable from "../theme/variables/platform";
import _ from "lodash";
class Header extends Component {
static contextTypes = {
theme: PropTypes.object
};
constructor(props) {
super(props);
this.state = {
orientation: "portrait"
};
}
layoutChange(val) {
let maxComp = Math.max(variable.deviceWidth, variable.deviceHeight);
if (val.width >= maxComp) this.setState({ orientation: "landscape" });
else {
this.setState({ orientation: "portrait" });
}
}
calculateHeight(mode, inSet) {
let inset = null;
if (inSet != undefined) {
inset = inSet;
} else {
inset = variable.Inset;
}
const InsetValues = mode === "portrait" ? inset.portrait : inset.landscape;
let oldHeight = null;
if (this.props.style.height != undefined) {
oldHeight = this.props.style.height;
} else if (this.props.style[1]) {
oldHeight = this.props.style[1].height ? this.props.style[1].height : this.props.style[0].height;
} else {
oldHeight = this.props.style[0].height;
}
let height = oldHeight + InsetValues.topInset;
return height;
}
calculatePadder(mode, inSet) {
let inset = null;
if (inSet != undefined) {
inset = inSet;
} else {
inset = variable.Inset;
}
const InsetValues = mode === "portrait" ? inset.portrait : inset.landscape;
let topPadder = null;
let style = StyleSheet.flatten(this.props.style);
if (style.padding !== undefined || style.paddingTop !== undefined) {
topPadder = (style.paddingTop ? style.paddingTop : style.padding) + InsetValues.topInset;
} else {
topPadder = InsetValues.topInset;
}
return topPadder;
}
render() {
const variables = this.context.theme
? this.context.theme["@@shoutem.theme/themeStyle"].variables
: variable;
const platformStyle = variables.platformStyle;
return (
<View onLayout={e => this.layoutChange(e.nativeEvent.layout)}>
<StatusBar
backgroundColor={
this.props.androidStatusBarColor
? this.props.androidStatusBarColor
: variables.statusBarColor
}
barStyle={
this.props.iosBarStyle
? this.props.iosBarStyle
: platformStyle === "material"
? "light-content"
: variables.iosStatusbar
}
translucent={this.props.transparent ? true : this.props.translucent}
/>
{variable.isIphoneX ? (
<View
ref={c => (this._root = c)}
{...this.props}
style={[
this.props.style,
{
height: this.calculateHeight(
this.state.orientation,
variables.Inset
),
paddingTop: this.calculatePadder(
this.state.orientation,
variables.Inset
)
}
]}
/>
) : (
<View ref={c => (this._root = c)} {...this.props} />
)}
</View>
);
}
}
Header.propTypes = {
...ViewPropTypes,
style: PropTypes.oneOfType([
PropTypes.object,
PropTypes.number,
PropTypes.array
]),
searchBar: PropTypes.bool,
rounded: PropTypes.bool
};
const StyledHeader = connectStyle(
"NativeBase.Header",
{},
mapPropsToStyleNames
)(Header);
export { StyledHeader as Header };