joplin/packages/app-mobile/components/screens/log.js

136 lines
3.5 KiB
JavaScript
Raw Normal View History

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');
const { connect } = require('react-redux');
const { reg } = require('@joplin/lib/registry.js');
2020-11-05 16:58:23 +00:00
const { ScreenHeader } = require('../screen-header.js');
const time = require('@joplin/lib/time').default;
2020-11-05 16:58:23 +00:00
const { themeStyle } = require('../global-style.js');
const Logger = require('@joplin/lib/Logger').default;
2020-11-05 16:58:23 +00:00
const { BaseScreenComponent } = require('../base-screen.js');
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 {
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: [],
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_ = {};
const styles = {
2017-08-01 17:59:01 +00:00
row: {
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'"
styles.rowText.fontFamily = 'monospace';
}
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
}
UNSAFE_componentWillMount() {
2017-07-07 23:25:10 +00:00
this.resfreshLogEntries();
}
2020-02-09 14:51:12 +00:00
async resfreshLogEntries(showErrorsOnly = null) {
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
}
toggleErrorsOnly() {
2020-02-09 14:51:12 +00:00
this.resfreshLogEntries(!this.state.showErrorsOnly);
}
2017-07-07 17:19:24 +00:00
render() {
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}
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();
}}
/>
</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();
}}
/>
</View>
</View>
2017-07-07 17:19:24 +00:00
</View>
);
}
}
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 };