Skip to content
GitLab
Projects
Groups
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
thalia
ThaliApp
Commits
7201d033
Commit
7201d033
authored
May 11, 2017
by
Gijs Hendriksen
Browse files
First stage of wrapper styling
parent
94a9a48e
Changes
4
Hide whitespace changes
Inline
Side-by-side
app/components/Sidebar.js
View file @
7201d033
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
);
app/components/navigator.js
View file @
7201d033
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
);
app/img/huygens.jpg
0 → 100644
View file @
7201d033
304 KB
app/style.js
View file @
7201d033
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
,
},
});
...
...
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment