Application Android et IOS pour l'amicale des élèves
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

BaseContainer.js 2.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. // @flow
  2. import * as React from 'react';
  3. import {Container, Right} from "native-base";
  4. import CustomHeader from "./CustomHeader";
  5. import CustomSideMenu from "./CustomSideMenu";
  6. import CustomMaterialIcon from "./CustomMaterialIcon";
  7. import {Platform, View} from "react-native";
  8. import ThemeManager from "../utils/ThemeManager";
  9. import Touchable from "react-native-platform-touchable";
  10. type Props = {
  11. navigation: Object,
  12. headerTitle: string,
  13. headerRightMenu: React.Node,
  14. children: React.Node
  15. }
  16. type State = {
  17. isOpen: boolean
  18. }
  19. export default class BaseContainer extends React.Component<Props, State> {
  20. static defaultProps = {
  21. headerRightMenu: <Right/>
  22. };
  23. state = {
  24. isOpen: false,
  25. };
  26. toggle() {
  27. console.log('coucou');
  28. this.setState({
  29. isOpen: !this.state.isOpen,
  30. });
  31. }
  32. updateMenuState(isOpen: boolean) {
  33. this.setState({isOpen});
  34. }
  35. render() {
  36. console.log(this.state.isOpen);
  37. return (
  38. <CustomSideMenu navigation={this.props.navigation} isOpen={this.state.isOpen}
  39. onChange={(isOpen) => this.updateMenuState(isOpen)}>
  40. <Container>
  41. <CustomHeader navigation={this.props.navigation} title={this.props.headerTitle}
  42. leftButton={
  43. <Touchable
  44. style={{padding: 6}}
  45. onPress={() => this.toggle()}>
  46. <CustomMaterialIcon
  47. color={Platform.OS === 'ios' ? ThemeManager.getCurrentThemeVariables().brandPrimary : "#fff"}
  48. icon="menu"/>
  49. </Touchable>
  50. }
  51. rightMenu={this.props.headerRightMenu}/>
  52. {this.props.children}
  53. </Container>
  54. </CustomSideMenu>
  55. );
  56. }
  57. }