const React = require('react'); const { View, Text, Button, FlatList } = require('react-native'); const Setting = require('@joplin/lib/models/Setting').default; const { connect } = require('react-redux'); const { ScreenHeader } = require('../ScreenHeader'); const ReportService = require('@joplin/lib/services/ReportService').default; const { _ } = require('@joplin/lib/locale'); const { BaseScreenComponent } = require('../base-screen.js'); const { themeStyle } = require('../global-style.js'); class StatusScreenComponent extends BaseScreenComponent { static navigationOptions() { return { header: null }; } constructor() { super(); this.state = { report: [], }; } UNSAFE_componentWillMount() { this.resfreshScreen(); } async resfreshScreen() { const service = new ReportService(); const report = await service.status(Setting.value('sync.target')); this.setState({ report: report }); } styles() { const theme = themeStyle(this.props.themeId); return { body: { flex: 1, margin: theme.margin, }, }; } render() { const theme = themeStyle(this.props.themeId); const renderBody = report => { const baseStyle = { paddingLeft: 6, paddingRight: 6, paddingTop: 2, paddingBottom: 2, flex: 0, color: theme.color, fontSize: theme.fontSize, }; const lines = []; for (let i = 0; i < report.length; i++) { const section = report[i]; let style = Object.assign({}, baseStyle); style.fontWeight = 'bold'; if (i > 0) style.paddingTop = 20; lines.push({ key: `section_${i}`, isSection: true, text: section.title }); if (section.canRetryAll) { lines.push({ key: `retry_all_${i}`, text: '', retryAllHandler: section.retryAllHandler }); } for (const n in section.body) { if (!section.body.hasOwnProperty(n)) continue; style = Object.assign({}, baseStyle); const item = section.body[n]; let text = ''; let retryHandler = null; if (typeof item === 'object') { if (item.canRetry) { retryHandler = async () => { await item.retryHandler(); this.resfreshScreen(); }; } text = item.text; } else { text = item; } lines.push({ key: `item_${i}_${n}`, text: text, retryHandler: retryHandler }); } lines.push({ key: `divider2_${i}`, isDivider: true }); } return ( { const style = Object.assign({}, baseStyle); if (item.isSection === true) { style.fontWeight = 'bold'; style.marginBottom = 5; } style.flex = 1; const retryAllButton = item.retryAllHandler ? (