Commit 7201d033 authored by Gijs Hendriksen's avatar Gijs Hendriksen
Browse files

First stage of wrapper styling

parent 94a9a48e
import React from 'react';
import { Text, View } from 'react-native';
import React, { Component } from 'react';
import { Text, View, Image, Dimensions } from 'react-native';
import { connect } from 'react-redux';
import styles from '../style';
import Icon from 'react-native-vector-icons/MaterialIcons';
import styles, { colors } from '../style';
import * as actions from '../actions/navigation';
import * as loginActions from '../actions/login';
const Sidebar = props =>
<View
style={styles.sidebar}
>
<Text style={styles.header}>MENU</Text>
<Text onPress={() => props.navigate('welcome')} style={styles.button} >Welcome</Text>
<Text onPress={() => props.navigate('eventList')} style={styles.button} >Calendar</Text>
</View>
;
const Sidebar = props => {
const b64Image = '';
const buttons = [
{
onPress: () => props.navigate('welcome'),
iconName: 'home',
text: 'Welkom',
style: {},
scene: 'welcome',
},
{
onPress: () => props.navigate('eventList'),
iconName: 'calendar',
text: 'Agenda',
style: {},
scene: 'eventList',
},
{
onPress: props.logout,
iconName: 'lock open',
text: 'Uitloggen',
style: {
borderTopColor: colors.lightGray,
borderTopWidth: 1,
},
scene: '',
},
];
const width = Dimensions.get('window').width * 0.8;
const height = width / 640 * 426;
return (
<View
style={styles.sidebar}
>
<Image
source={require('../img/huygens.jpg')}
style={{width: width, height: height, justifyContent: 'space-around', paddingLeft: 10}}
resizeMode='contain'
>
<Image
source={{uri: b64Image}}
style={{width: 100, height: 100, borderRadius: 50, marginBottom: 10}}
resizeMode='cover'
/>
<Text style={{color: colors.white, fontSize: 24}}>Gijs Hendriksen</Text>
</Image>
{buttons.map((object, i) => (
<Icon.Button
onPress={object.onPress}
name={object.iconName}
borderRadius={0}
backgroundColor={colors.white}
color={props.currentScene === object.scene ?
colors.magenta : colors.textColour}
size={28}
iconStyle={{
marginRight: 30,
width: 28,
textAlign: 'center',
}}
textStyle={{fontSize: 28}}
style={[{padding: 20}, object.style]}
key={i}
>
{object.text}
</Icon.Button>
))}
</View>
)
};
Sidebar.propTypes = {
currentScene: React.PropTypes.string.isRequired,
navigate: React.PropTypes.func.isRequired,
logout: React.PropTypes.func.isRequired,
};
const mapStateToProps = state => ({
currentScene: state.navigation.currentScene,
});
const mapDispatchToProps = dispatch => ({
navigate: scene => dispatch(actions.navigate(scene)),
logout: () => dispatch(loginActions.logout())
});
export default connect(() => ({}), mapDispatchToProps)(Sidebar);
export default connect(mapStateToProps, mapDispatchToProps)(Sidebar);
import React from 'react';
import { Platform, StyleSheet, Text, View, StatusBar, TouchableOpacity } from 'react-native';
import { connect } from 'react-redux';
import Drawer from 'react-native-drawer';
import Icon from 'react-native-vector-icons/FontAwesome';
import Login from './Login';
import Welcome from './Welcome';
import Sidebar from './Sidebar';
......@@ -8,16 +10,10 @@ import Event from './Event';
import Calendar from './Calendar';
import * as actions from '../actions/navigation';
import { colors } from '../style';
const mapStateToProps = state => ({
currentScene: state.navigation.currentScene,
loggedIn: state.navigation.loggedIn,
drawerOpen: state.navigation.drawerOpen,
});
const mapDispatchToProps = dispatch => ({
updateDrawer: isOpen => dispatch(actions.updateDrawer(isOpen)),
});
const STATUSBAR_HEIGHT = Platform.OS === 'ios' ? 20 : 0;
const APPBAR_HEIGHT = Platform.OS === 'ios' ? 44 : 56;
const sceneToComponent = (scene) => {
switch (scene) {
......@@ -32,22 +28,84 @@ const sceneToComponent = (scene) => {
}
};
const sceneToTitle = (scene) => {
switch (scene) {
case 'welcome':
return 'Welkom';
case 'event':
return 'Evenement';
case 'eventList':
return 'Agenda';
default:
return 'ThaliApp';
}
};
const styles = StyleSheet.create({
container: {
flex: 1,
},
statusBar: {
height: STATUSBAR_HEIGHT,
backgroundColor: colors.darkMagenta,
},
appBar: {
backgroundColor: colors.magenta,
height: APPBAR_HEIGHT,
justifyContent: 'flex-start',
alignItems: 'center',
flexWrap: 'wrap',
flexDirection: 'row',
},
title: {
color: colors.white,
fontSize: 24,
},
icon: {
paddingLeft: 20,
paddingRight: 50,
color: colors.white,
},
});
const ReduxNavigator = (props) => {
const { currentScene, loggedIn, drawerOpen, updateDrawer } = props;
if (loggedIn) {
return (<Drawer
type="displace"
content={<Sidebar />}
openDrawerOffset={0.4}
openDrawerOffset={0.2}
panOpenMask={0.2}
panCloseMask={0.2}
panThreshold={0.3}
tweenHandler={ratio => ({ main: { opacity: (2 - ratio) / 2 } })}
styles={{
mainOverlay: {
backgroundColor: colors.black,
opacity: 0,
}
}}
tweenHandler={ratio => ({ mainOverlay: { opacity: ratio * 0.75 } })}
open={drawerOpen}
onOpen={() => updateDrawer(true)}
onClose={() => updateDrawer(false)}
tapToClose
>
<View style={styles.statusBar}>
<StatusBar backgroundColor={colors.darkMagenta} barStyle='light-content' />
</View>
<View style={styles.appBar}>
<TouchableOpacity
onPress={props.isFirstScene ? () => props.updateDrawer(!props.drawerOpen) : props.back}
>
<Icon
name={props.isFirstScene ? 'bars' : 'arrow-left'}
onClick={props.back}
style={styles.icon}
size={20}
/>
</TouchableOpacity>
<Text style={styles.title}>{sceneToTitle(currentScene)}</Text>
</View>
{sceneToComponent(currentScene)}
</Drawer>);
}
......@@ -58,7 +116,21 @@ ReduxNavigator.propTypes = {
currentScene: React.PropTypes.string.isRequired,
loggedIn: React.PropTypes.bool.isRequired,
drawerOpen: React.PropTypes.bool.isRequired,
isFirstScene: React.PropTypes.bool.isRequired,
updateDrawer: React.PropTypes.func.isRequired,
back: React.PropTypes.func.isRequired,
};
const mapStateToProps = state => ({
currentScene: state.navigation.currentScene,
loggedIn: state.navigation.loggedIn,
drawerOpen: state.navigation.drawerOpen,
isFirstScene: state.navigation.previousScenes.length == 0,
});
const mapDispatchToProps = dispatch => ({
updateDrawer: isOpen => dispatch(actions.updateDrawer(isOpen)),
back: () => dispatch(actions.back()),
});
export default connect(mapStateToProps, mapDispatchToProps)(ReduxNavigator);
import { StyleSheet } from 'react-native';
const magenta = '#E62272';
const white = '#FFFFFF';
const black = '#000000';
export const colors = {
magenta: '#E62272',
darkMagenta: '#C2185B',
white: '#FFFFFF',
black: '#000000',
lightGray: '#BBBBBB',
textColour: '#313131',
};
const styles = StyleSheet.create({
sidebar: {
flex: 1,
backgroundColor: white,
},
header: {
backgroundColor: magenta,
color: white,
fontWeight: 'bold',
padding: 20,
},
button: {
backgroundColor: white,
color: black,
paddingLeft: 10,
paddingTop: 20,
paddingBottom: 20,
borderBottomWidth: 1,
backgroundColor: colors.white,
},
});
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment