// @flow import * as React from 'react'; import {View} from 'react-native'; import {withTheme} from 'react-native-paper'; import {Agenda} from 'react-native-calendars'; import type {CustomThemeType} from '../../managers/ThemeManager'; type PropsType = { theme: CustomThemeType, onRef: (ref: Agenda) => void, }; /** * Abstraction layer for Agenda component, using custom configuration */ class CustomAgenda extends React.Component { getAgenda(): React.Node { const {props} = this; return ( ); } render(): React.Node { const {props} = this; // Completely recreate the component on theme change to force theme reload if (props.theme.dark) return {this.getAgenda()}; return this.getAgenda(); } } export default withTheme(CustomAgenda);