forked from vergnet/application-amicale
		
	Moved about screen in sidemenu, fixed warnings
This commit is contained in:
		
							parent
							
								
									d654a5d7a8
								
							
						
					
					
						commit
						e72196812e
					
				
					 6 changed files with 155 additions and 115 deletions
				
			
		|  | @ -65,15 +65,15 @@ export default class SideBar extends React.Component<Props, State> { | ||||||
|                 route: "TutorInsaScreen", |                 route: "TutorInsaScreen", | ||||||
|                 icon: "school", |                 icon: "school", | ||||||
|             }, |             }, | ||||||
|             { |  | ||||||
|                 name: "Mails BlueMind", |  | ||||||
|                 route: "BlueMindScreen", |  | ||||||
|                 icon: "email", |  | ||||||
|             }, |  | ||||||
|             { |             { | ||||||
|                 name: i18n.t('sidenav.divider2'), |                 name: i18n.t('sidenav.divider2'), | ||||||
|                 route: "Divider2" |                 route: "Divider2" | ||||||
|             }, |             }, | ||||||
|  |             { | ||||||
|  |                 name: i18n.t('screens.bluemind'), | ||||||
|  |                 route: "BlueMindScreen", | ||||||
|  |                 icon: "email", | ||||||
|  |             }, | ||||||
|             { |             { | ||||||
|                 name: i18n.t('screens.availableRooms'), |                 name: i18n.t('screens.availableRooms'), | ||||||
|                 route: "AvailableRoomScreen", |                 route: "AvailableRoomScreen", | ||||||
|  | @ -93,6 +93,11 @@ export default class SideBar extends React.Component<Props, State> { | ||||||
|                 route: "SettingsScreen", |                 route: "SettingsScreen", | ||||||
|                 icon: "settings", |                 icon: "settings", | ||||||
|             }, |             }, | ||||||
|  |             { | ||||||
|  |                 name: i18n.t('screens.about'), | ||||||
|  |                 route: "AboutScreen", | ||||||
|  |                 icon: "information", | ||||||
|  |             }, | ||||||
|         ]; |         ]; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -31,7 +31,6 @@ export default class AboutDependenciesScreen extends React.Component<Props> { | ||||||
|         return ( |         return ( | ||||||
|             <Container> |             <Container> | ||||||
|                 <CustomHeader hasBackButton={true} navigation={nav} title={i18n.t('aboutScreen.libs')}/> |                 <CustomHeader hasBackButton={true} navigation={nav} title={i18n.t('aboutScreen.libs')}/> | ||||||
|                 <Content> |  | ||||||
|                 <FlatList |                 <FlatList | ||||||
|                     data={data} |                     data={data} | ||||||
|                     keyExtractor={(item) => item.name} |                     keyExtractor={(item) => item.name} | ||||||
|  | @ -48,7 +47,6 @@ export default class AboutDependenciesScreen extends React.Component<Props> { | ||||||
|                             </Body> |                             </Body> | ||||||
|                         </ListItem>} |                         </ListItem>} | ||||||
|                 /> |                 /> | ||||||
|                 </Content> |  | ||||||
|             </Container> |             </Container> | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -185,6 +185,107 @@ export default class AboutScreen extends React.Component<Props, State> { | ||||||
|         }, |         }, | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|  |     dataOrder: Array<Object> = [ | ||||||
|  |         { | ||||||
|  |             id: 'app', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             id: 'team', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             id: 'techno', | ||||||
|  |         }, | ||||||
|  |     ]; | ||||||
|  | 
 | ||||||
|  |     getAppCard() { | ||||||
|  |         return ( | ||||||
|  |             <Card> | ||||||
|  |                 <CardItem> | ||||||
|  |                     <Left> | ||||||
|  |                         <Thumbnail square source={require('../../assets/icon.png')}/> | ||||||
|  |                         <Body> | ||||||
|  |                             <H1>{appJson.expo.name}</H1> | ||||||
|  |                             <Text note> | ||||||
|  |                                 v.{appJson.expo.version} | ||||||
|  |                             </Text> | ||||||
|  |                         </Body> | ||||||
|  |                     </Left> | ||||||
|  |                 </CardItem> | ||||||
|  |                 <FlatList | ||||||
|  |                     data={this.appData} | ||||||
|  |                     extraData={this.state} | ||||||
|  |                     keyExtractor={(item) => item.icon} | ||||||
|  |                     listKey={(item) => "app"} | ||||||
|  |                     renderItem={({item}) => | ||||||
|  |                         this.getCardItem(item.onPressCallback, item.icon, item.text, item.showChevron, item.showOnlyDebug) | ||||||
|  |                     } | ||||||
|  |                 /> | ||||||
|  |             </Card> | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     getTeamCard() { | ||||||
|  |         return ( | ||||||
|  |             <Card> | ||||||
|  |                 <CardItem> | ||||||
|  |                     <Left> | ||||||
|  |                         <CustomMaterialIcon | ||||||
|  |                             icon={'account-multiple'} | ||||||
|  |                             fontSize={40} | ||||||
|  |                             width={40} | ||||||
|  |                             color={ThemeManager.getCurrentThemeVariables().brandPrimary}/> | ||||||
|  |                         <Body> | ||||||
|  |                             <H1>{i18n.t('aboutScreen.team')}</H1> | ||||||
|  |                         </Body> | ||||||
|  |                     </Left> | ||||||
|  |                 </CardItem> | ||||||
|  |                 <CardItem header> | ||||||
|  |                     <Text>{i18n.t('aboutScreen.author')}</Text> | ||||||
|  |                 </CardItem> | ||||||
|  |                 <FlatList | ||||||
|  |                     data={this.authorData} | ||||||
|  |                     extraData={this.state} | ||||||
|  |                     keyExtractor={(item) => item.icon} | ||||||
|  |                     listKey={(item) => "team1"} | ||||||
|  |                     renderItem={({item}) => | ||||||
|  |                         this.getCardItem(item.onPressCallback, item.icon, item.text, item.showChevron, item.showOnlyDebug) | ||||||
|  |                     } | ||||||
|  |                 /> | ||||||
|  |                 <CardItem header> | ||||||
|  |                     <Text>{i18n.t('aboutScreen.additionalDev')}</Text> | ||||||
|  |                 </CardItem> | ||||||
|  |                 <FlatList | ||||||
|  |                     data={this.additionalDevData} | ||||||
|  |                     extraData={this.state} | ||||||
|  |                     keyExtractor={(item) => item.icon} | ||||||
|  |                     listKey={(item) => "team2"} | ||||||
|  |                     renderItem={({item}) => | ||||||
|  |                         this.getCardItem(item.onPressCallback, item.icon, item.text, item.showChevron, item.showOnlyDebug) | ||||||
|  |                     } | ||||||
|  |                 /> | ||||||
|  |             </Card> | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     getTechnoCard() { | ||||||
|  |         return ( | ||||||
|  |             <Card> | ||||||
|  |                 <CardItem header> | ||||||
|  |                     <Text>{i18n.t('aboutScreen.technologies')}</Text> | ||||||
|  |                 </CardItem> | ||||||
|  |                 <FlatList | ||||||
|  |                     data={this.technoData} | ||||||
|  |                     extraData={this.state} | ||||||
|  |                     keyExtractor={(item) => item.icon} | ||||||
|  |                     listKey={(item) => "techno"} | ||||||
|  |                     renderItem={({item}) => | ||||||
|  |                         this.getCardItem(item.onPressCallback, item.icon, item.text, item.showChevron, item.showOnlyDebug) | ||||||
|  |                     } | ||||||
|  |                 /> | ||||||
|  |             </Card> | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * Get a clickable card item to be rendered inside a card. |      * Get a clickable card item to be rendered inside a card. | ||||||
|      * |      * | ||||||
|  | @ -284,86 +385,33 @@ export default class AboutScreen extends React.Component<Props, State> { | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     getMainCard(item: Object) { | ||||||
|  |         switch (item.id) { | ||||||
|  |             case 'app': | ||||||
|  |                 return this.getAppCard(); | ||||||
|  |             case 'team': | ||||||
|  |                 return this.getTeamCard(); | ||||||
|  |             case 'techno': | ||||||
|  |                 return this.getTechnoCard(); | ||||||
|  |         } | ||||||
|  |         return <View/>; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     render() { |     render() { | ||||||
|         const nav = this.props.navigation; |         const nav = this.props.navigation; | ||||||
|         return ( |         return ( | ||||||
|             <Container> |             <Container> | ||||||
|                 {this.getBugReportModal()} |                 {this.getBugReportModal()} | ||||||
|                 <CustomHeader navigation={nav} title={i18n.t('screens.about')} hasBackButton={true}/> |                 <CustomHeader navigation={nav} title={i18n.t('screens.about')} hasBackButton={true}/> | ||||||
|                 <Content padder> |  | ||||||
|                     <Card> |  | ||||||
|                         <CardItem> |  | ||||||
|                             <Left> |  | ||||||
|                                 <Thumbnail square source={require('../../assets/icon.png')}/> |  | ||||||
|                                 <Body> |  | ||||||
|                                     <H1>{appJson.expo.name}</H1> |  | ||||||
|                                     <Text note> |  | ||||||
|                                         v.{appJson.expo.version} |  | ||||||
|                                     </Text> |  | ||||||
|                                 </Body> |  | ||||||
|                             </Left> |  | ||||||
|                         </CardItem> |  | ||||||
|                 <FlatList |                 <FlatList | ||||||
|                             data={this.appData} |                     style={{padding: 5}} | ||||||
|  |                     data={this.dataOrder} | ||||||
|                     extraData={this.state} |                     extraData={this.state} | ||||||
|                             keyExtractor={(item) => item.icon} |                     keyExtractor={(item) => item.id} | ||||||
|                     renderItem={({item}) => |                     renderItem={({item}) => | ||||||
|                                 this.getCardItem(item.onPressCallback, item.icon, item.text, item.showChevron, item.showOnlyDebug) |                         this.getMainCard(item) | ||||||
|                     } |                     } | ||||||
|                 /> |                 /> | ||||||
|                     </Card> |  | ||||||
| 
 |  | ||||||
|                     <Card> |  | ||||||
|                         <CardItem> |  | ||||||
|                             <Left> |  | ||||||
|                                 <CustomMaterialIcon |  | ||||||
|                                     icon={'account-multiple'} |  | ||||||
|                                     fontSize={40} |  | ||||||
|                                     width={40} |  | ||||||
|                                     color={ThemeManager.getCurrentThemeVariables().brandPrimary}/> |  | ||||||
|                                 <Body> |  | ||||||
|                                     <H1>{i18n.t('aboutScreen.team')}</H1> |  | ||||||
|                                 </Body> |  | ||||||
|                             </Left> |  | ||||||
|                         </CardItem> |  | ||||||
|                         <CardItem header> |  | ||||||
|                             <Text>{i18n.t('aboutScreen.author')}</Text> |  | ||||||
|                         </CardItem> |  | ||||||
|                         <FlatList |  | ||||||
|                             data={this.authorData} |  | ||||||
|                             extraData={this.state} |  | ||||||
|                             keyExtractor={(item) => item.icon} |  | ||||||
|                             renderItem={({item}) => |  | ||||||
|                                 this.getCardItem(item.onPressCallback, item.icon, item.text, item.showChevron, item.showOnlyDebug) |  | ||||||
|                             } |  | ||||||
|                         /> |  | ||||||
|                         <CardItem header> |  | ||||||
|                             <Text>{i18n.t('aboutScreen.additionalDev')}</Text> |  | ||||||
|                         </CardItem> |  | ||||||
|                         <FlatList |  | ||||||
|                             data={this.additionalDevData} |  | ||||||
|                             extraData={this.state} |  | ||||||
|                             keyExtractor={(item) => item.icon} |  | ||||||
|                             renderItem={({item}) => |  | ||||||
|                                 this.getCardItem(item.onPressCallback, item.icon, item.text, item.showChevron, item.showOnlyDebug) |  | ||||||
|                             } |  | ||||||
|                         /> |  | ||||||
|                     </Card> |  | ||||||
| 
 |  | ||||||
|                     <Card> |  | ||||||
|                         <CardItem header> |  | ||||||
|                             <Text>{i18n.t('aboutScreen.technologies')}</Text> |  | ||||||
|                         </CardItem> |  | ||||||
|                         <FlatList |  | ||||||
|                             data={this.technoData} |  | ||||||
|                             extraData={this.state} |  | ||||||
|                             keyExtractor={(item) => item.icon} |  | ||||||
|                             renderItem={({item}) => |  | ||||||
|                                 this.getCardItem(item.onPressCallback, item.icon, item.text, item.showChevron, item.showOnlyDebug) |  | ||||||
|                             } |  | ||||||
|                         /> |  | ||||||
|                     </Card> |  | ||||||
|                 </Content> |  | ||||||
|             </Container> |             </Container> | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -212,24 +212,11 @@ export default class SettingsScreen extends React.Component<Props, State> { | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     getRightButton() { |  | ||||||
|         return ( |  | ||||||
|             <Touchable |  | ||||||
|                 style={{padding: 6}} |  | ||||||
|                 onPress={() => this.props.navigation.navigate('AboutScreen')}> |  | ||||||
|                 <CustomMaterialIcon |  | ||||||
|                     color={Platform.OS === 'ios' ? ThemeManager.getCurrentThemeVariables().brandPrimary : "#fff"} |  | ||||||
|                     icon="information"/> |  | ||||||
|             </Touchable> |  | ||||||
|         ); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     render() { |     render() { | ||||||
|         const nav = this.props.navigation; |         const nav = this.props.navigation; | ||||||
|         return ( |         return ( | ||||||
|             <Container> |             <Container> | ||||||
|                 <CustomHeader navigation={nav} title={i18n.t('screens.settings')} hasBackButton={true} |                 <CustomHeader navigation={nav} title={i18n.t('screens.settings')} hasBackButton={true}/> | ||||||
|                               rightButton={this.getRightButton()}/> |  | ||||||
|                 <Content padder> |                 <Content padder> | ||||||
|                     <Card> |                     <Card> | ||||||
|                         <CardItem header> |                         <CardItem header> | ||||||
|  |  | ||||||
|  | @ -7,12 +7,13 @@ | ||||||
|     "menuSelf": "RU Menu", |     "menuSelf": "RU Menu", | ||||||
|     "settings": "Settings", |     "settings": "Settings", | ||||||
|     "availableRooms": "Available rooms", |     "availableRooms": "Available rooms", | ||||||
|  |     "bluemind": "INSA Mails", | ||||||
|     "about": "About", |     "about": "About", | ||||||
|     "debug": "Debug" |     "debug": "Debug" | ||||||
|   }, |   }, | ||||||
|   "sidenav": { |   "sidenav": { | ||||||
|     "divider1": "Nice websites", |     "divider1": "Useful websites", | ||||||
|     "divider2": "Useful services", |     "divider2": "Services", | ||||||
|     "divider3": "Personalisation" |     "divider3": "Personalisation" | ||||||
|   }, |   }, | ||||||
|   "intro": { |   "intro": { | ||||||
|  |  | ||||||
|  | @ -7,12 +7,13 @@ | ||||||
|     "menuSelf": "Menu du RU", |     "menuSelf": "Menu du RU", | ||||||
|     "settings": "Paramètres", |     "settings": "Paramètres", | ||||||
|     "availableRooms": "Salles dispo", |     "availableRooms": "Salles dispo", | ||||||
|  |     "bluemind": "Mails INSA", | ||||||
|     "about": "À Propos", |     "about": "À Propos", | ||||||
|     "debug": "Debug" |     "debug": "Debug" | ||||||
|   }, |   }, | ||||||
|   "sidenav": { |   "sidenav": { | ||||||
|     "divider1": "Sites bien", |     "divider1": "Sites utiles", | ||||||
|     "divider2": "Services utiles", |     "divider2": "Services", | ||||||
|     "divider3": "Personnalisation" |     "divider3": "Personnalisation" | ||||||
|   }, |   }, | ||||||
|   "intro": { |   "intro": { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue