2019-07-29 13:43:53 +00:00
|
|
|
const React = require('react');
|
2019-07-29 13:58:33 +00:00
|
|
|
|
2020-02-09 14:51:12 +00:00
|
|
|
const { FlatList, View, Text, Button, StyleSheet, Platform } = require('react-native');
|
2018-03-09 20:59:12 +00:00
|
|
|
const { connect } = require('react-redux');
|
2020-11-07 15:59:37 +00:00
|
|
|
const { reg } = require('@joplin/lib/registry.js');
|
2020-11-05 16:58:23 +00:00
|
|
|
const { ScreenHeader } = require('../screen-header.js');
|
2020-11-07 15:59:37 +00:00
|
|
|
const time = require('@joplin/lib/time').default;
|
2020-11-05 16:58:23 +00:00
|
|
|
const { themeStyle } = require('../global-style.js');
|
2020-11-07 15:59:37 +00:00
|
|
|
const Logger = require('@joplin/lib/Logger').default;
|
2020-11-05 16:58:23 +00:00
|
|
|
const { BaseScreenComponent } = require('../base-screen.js');
|
2020-11-07 15:59:37 +00:00
|
|
|
const { _ } = require('@joplin/lib/locale');
|
2017-07-07 17:19:24 +00:00
|
|
|
|
2017-07-14 18:49:14 +00:00
|
|
|
class LogScreenComponent extends BaseScreenComponent {
|
2019-09-12 22:16:42 +00:00
|
|
|
static navigationOptions() {
|
2017-07-07 17:19:24 +00:00
|
|
|
return { header: null };
|
|
|
|
}
|
|
|
|
|
|
|
|
constructor() {
|
|
|
|
super();
|
2020-02-09 14:51:12 +00:00
|
|
|
|
2017-07-07 17:19:24 +00:00
|
|
|
this.state = {
|
2020-02-09 14:51:12 +00:00
|
|
|
logEntries: [],
|
2018-01-31 19:51:29 +00:00
|
|
|
showErrorsOnly: false,
|
2017-07-07 17:19:24 +00:00
|
|
|
};
|
2017-08-01 17:59:01 +00:00
|
|
|
this.styles_ = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
styles() {
|
2020-09-15 13:01:07 +00:00
|
|
|
const theme = themeStyle(this.props.themeId);
|
2017-08-01 17:59:01 +00:00
|
|
|
|
2020-09-15 13:01:07 +00:00
|
|
|
if (this.styles_[this.props.themeId]) return this.styles_[this.props.themeId];
|
2017-08-01 17:59:01 +00:00
|
|
|
this.styles_ = {};
|
|
|
|
|
2020-03-13 23:46:14 +00:00
|
|
|
const styles = {
|
2017-08-01 17:59:01 +00:00
|
|
|
row: {
|
2018-03-09 20:59:12 +00:00
|
|
|
flexDirection: 'row',
|
2017-08-01 17:59:01 +00:00
|
|
|
paddingLeft: 1,
|
|
|
|
paddingRight: 1,
|
2019-07-29 13:43:53 +00:00
|
|
|
paddingTop: 0,
|
|
|
|
paddingBottom: 0,
|
2017-08-01 17:59:01 +00:00
|
|
|
},
|
|
|
|
rowText: {
|
|
|
|
fontSize: 10,
|
2019-07-29 13:43:53 +00:00
|
|
|
color: theme.color,
|
2017-08-01 17:59:01 +00:00
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2019-07-29 13:43:53 +00:00
|
|
|
if (Platform.OS !== 'ios') {
|
|
|
|
// Crashes on iOS with error "Unrecognized font family 'monospace'"
|
2018-03-09 20:59:12 +00:00
|
|
|
styles.rowText.fontFamily = 'monospace';
|
2018-02-14 15:28:56 +00:00
|
|
|
}
|
|
|
|
|
2017-08-01 17:59:01 +00:00
|
|
|
styles.rowTextError = Object.assign({}, styles.rowText);
|
|
|
|
styles.rowTextError.color = theme.colorError;
|
|
|
|
|
2017-08-21 18:32:43 +00:00
|
|
|
styles.rowTextWarn = Object.assign({}, styles.rowText);
|
2017-08-01 17:59:01 +00:00
|
|
|
styles.rowTextWarn.color = theme.colorWarn;
|
|
|
|
|
2020-09-15 13:01:07 +00:00
|
|
|
this.styles_[this.props.themeId] = StyleSheet.create(styles);
|
|
|
|
return this.styles_[this.props.themeId];
|
2017-07-07 17:19:24 +00:00
|
|
|
}
|
|
|
|
|
2018-04-30 16:38:19 +00:00
|
|
|
UNSAFE_componentWillMount() {
|
2017-07-07 23:25:10 +00:00
|
|
|
this.resfreshLogEntries();
|
|
|
|
}
|
|
|
|
|
2020-02-09 14:51:12 +00:00
|
|
|
async resfreshLogEntries(showErrorsOnly = null) {
|
2018-01-31 19:51:29 +00:00
|
|
|
if (showErrorsOnly === null) showErrorsOnly = this.state.showErrorsOnly;
|
|
|
|
|
|
|
|
let levels = [Logger.LEVEL_DEBUG, Logger.LEVEL_INFO, Logger.LEVEL_WARN, Logger.LEVEL_ERROR];
|
2019-07-29 13:43:53 +00:00
|
|
|
if (showErrorsOnly) levels = [Logger.LEVEL_WARN, Logger.LEVEL_ERROR];
|
|
|
|
|
2020-02-09 14:51:12 +00:00
|
|
|
this.setState({
|
|
|
|
logEntries: await reg.logger().lastEntries(1000, { levels: levels }),
|
|
|
|
showErrorsOnly: showErrorsOnly,
|
|
|
|
});
|
2017-07-07 17:19:24 +00:00
|
|
|
}
|
|
|
|
|
2018-01-31 19:51:29 +00:00
|
|
|
toggleErrorsOnly() {
|
2020-02-09 14:51:12 +00:00
|
|
|
this.resfreshLogEntries(!this.state.showErrorsOnly);
|
2018-01-31 19:51:29 +00:00
|
|
|
}
|
|
|
|
|
2017-07-07 17:19:24 +00:00
|
|
|
render() {
|
2020-03-13 23:46:14 +00:00
|
|
|
const renderRow = ({ item }) => {
|
2017-08-01 17:59:01 +00:00
|
|
|
let textStyle = this.styles().rowText;
|
|
|
|
if (item.level == Logger.LEVEL_WARN) textStyle = this.styles().rowTextWarn;
|
|
|
|
if (item.level == Logger.LEVEL_ERROR) textStyle = this.styles().rowTextError;
|
2019-07-29 13:43:53 +00:00
|
|
|
|
2017-07-07 17:19:24 +00:00
|
|
|
return (
|
2017-08-01 17:59:01 +00:00
|
|
|
<View style={this.styles().row}>
|
2019-09-19 21:51:18 +00:00
|
|
|
<Text style={textStyle}>{`${time.formatMsToLocal(item.timestamp, 'MM-DDTHH:mm:ss')}: ${item.message}`}</Text>
|
2017-07-07 17:19:24 +00:00
|
|
|
</View>
|
|
|
|
);
|
2019-07-29 13:43:53 +00:00
|
|
|
};
|
2017-07-07 17:19:24 +00:00
|
|
|
|
|
|
|
// `enableEmptySections` is to fix this warning: https://github.com/FaridSafi/react-native-gifted-listview/issues/39
|
2020-02-09 14:51:12 +00:00
|
|
|
|
2017-07-07 17:19:24 +00:00
|
|
|
return (
|
2020-09-15 13:01:07 +00:00
|
|
|
<View style={this.rootStyle(this.props.themeId).root}>
|
2019-07-29 13:43:53 +00:00
|
|
|
<ScreenHeader title={_('Log')} />
|
2020-02-09 14:51:12 +00:00
|
|
|
<FlatList
|
|
|
|
data={this.state.logEntries}
|
|
|
|
renderItem={renderRow}
|
2020-05-21 08:14:33 +00:00
|
|
|
keyExtractor={item => { return `${item.id}`; }}
|
2020-02-09 14:51:12 +00:00
|
|
|
/>
|
2019-07-29 13:43:53 +00:00
|
|
|
<View style={{ flexDirection: 'row' }}>
|
|
|
|
<View style={{ flex: 1, marginRight: 5 }}>
|
|
|
|
<Button
|
|
|
|
title={_('Refresh')}
|
|
|
|
onPress={() => {
|
|
|
|
this.resfreshLogEntries();
|
|
|
|
}}
|
|
|
|
/>
|
2018-01-31 19:51:29 +00:00
|
|
|
</View>
|
2019-07-29 13:43:53 +00:00
|
|
|
<View style={{ flex: 1 }}>
|
|
|
|
<Button
|
|
|
|
title={this.state.showErrorsOnly ? _('Show all') : _('Errors only')}
|
|
|
|
onPress={() => {
|
|
|
|
this.toggleErrorsOnly();
|
|
|
|
}}
|
|
|
|
/>
|
2018-01-31 19:51:29 +00:00
|
|
|
</View>
|
|
|
|
</View>
|
2017-07-07 17:19:24 +00:00
|
|
|
</View>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-21 08:14:33 +00:00
|
|
|
const LogScreen = connect(state => {
|
2019-07-29 13:43:53 +00:00
|
|
|
return {
|
2020-09-15 13:01:07 +00:00
|
|
|
themeId: state.settings.theme,
|
2019-07-29 13:43:53 +00:00
|
|
|
};
|
|
|
|
})(LogScreenComponent);
|
2017-07-07 17:19:24 +00:00
|
|
|
|
2019-07-29 13:43:53 +00:00
|
|
|
module.exports = { LogScreen };
|