Application Android et IOS pour l'amicale des élèves https://play.google.com/store/apps/details?id=fr.amicaleinsat.application
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.

GridComponent.js 2.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /*
  2. * Copyright (c) 2019 - 2020 Arnaud Vergnet.
  3. *
  4. * This file is part of Campus INSAT.
  5. *
  6. * Campus INSAT is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 3 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * Campus INSAT is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with Campus INSAT. If not, see <https://www.gnu.org/licenses/>.
  18. */
  19. // @flow
  20. import * as React from 'react';
  21. import {View} from 'react-native';
  22. import {withTheme} from 'react-native-paper';
  23. import type {ViewStyle} from 'react-native/Libraries/StyleSheet/StyleSheet';
  24. import type {CellType} from './CellComponent';
  25. import CellComponent from './CellComponent';
  26. export type GridType = Array<Array<CellComponent>>;
  27. type PropsType = {
  28. grid: Array<Array<CellType>>,
  29. height: number,
  30. width: number,
  31. style: ViewStyle,
  32. };
  33. class GridComponent extends React.Component<PropsType> {
  34. getRow(rowNumber: number): React.Node {
  35. const {grid} = this.props;
  36. return (
  37. <View style={{flexDirection: 'row'}} key={rowNumber.toString()}>
  38. {grid[rowNumber].map(this.getCellRender)}
  39. </View>
  40. );
  41. }
  42. getCellRender = (item: CellType): React.Node => {
  43. return <CellComponent cell={item} key={item.key} />;
  44. };
  45. getGrid(): React.Node {
  46. const {height} = this.props;
  47. const rows = [];
  48. for (let i = 0; i < height; i += 1) {
  49. rows.push(this.getRow(i));
  50. }
  51. return rows;
  52. }
  53. render(): React.Node {
  54. const {style, width, height} = this.props;
  55. return (
  56. <View
  57. style={{
  58. aspectRatio: width / height,
  59. borderRadius: 4,
  60. ...style,
  61. }}>
  62. {this.getGrid()}
  63. </View>
  64. );
  65. }
  66. }
  67. export default withTheme(GridComponent);