|
1 | | -import React, {useEffect, useState} from 'react'; |
2 | | -import {Alert, Button, StyleSheet, Switch, Text, View} from 'react-native'; |
3 | | -import {FileLogger, LogLevel} from 'react-native-file-logger'; |
| 1 | +import { useEffect, useState } from "react"; |
| 2 | +import { Alert, Button, StyleSheet, Switch, Text, View } from "react-native"; |
| 3 | +import { FileLogger, LogLevel } from "react-native-file-logger"; |
4 | 4 |
|
5 | 5 | export const App = () => { |
6 | | - const [logLevel, setLogLevel] = useState(LogLevel.Debug); |
7 | | - const [enabled, setEnabled] = useState(true); |
| 6 | + const [logLevel, setLogLevel] = useState(LogLevel.Debug); |
| 7 | + const [enabled, setEnabled] = useState(true); |
8 | 8 |
|
9 | | - useEffect(() => { |
10 | | - FileLogger.configure({logLevel: LogLevel.Debug}).then(() => |
11 | | - console.log('File-logger configured'), |
12 | | - ); |
13 | | - }, []); |
| 9 | + useEffect(() => { |
| 10 | + FileLogger.configure({ logLevel: LogLevel.Debug }).then(() => console.log("File-logger configured")); |
| 11 | + }, []); |
14 | 12 |
|
15 | | - const showLogFilePaths = async () => { |
16 | | - Alert.alert('File paths', (await FileLogger.getLogFilePaths()).join('\n')); |
17 | | - }; |
| 13 | + const showLogFilePaths = async () => { |
| 14 | + Alert.alert("File paths", (await FileLogger.getLogFilePaths()).join("\n")); |
| 15 | + }; |
18 | 16 |
|
19 | | - const changeEnabled = (value: boolean) => { |
20 | | - if (value) { |
21 | | - FileLogger.enableConsoleCapture(); |
22 | | - } else { |
23 | | - FileLogger.disableConsoleCapture(); |
24 | | - } |
25 | | - setEnabled(value); |
26 | | - }; |
| 17 | + const changeEnabled = (value: boolean) => { |
| 18 | + if (value) { |
| 19 | + FileLogger.enableConsoleCapture(); |
| 20 | + } else { |
| 21 | + FileLogger.disableConsoleCapture(); |
| 22 | + } |
| 23 | + setEnabled(value); |
| 24 | + }; |
27 | 25 |
|
28 | | - const changeLogLevel = () => { |
29 | | - const nextLogLevel = (logLevel + 1) % 4; |
30 | | - FileLogger.setLogLevel(nextLogLevel); |
31 | | - setLogLevel(nextLogLevel); |
32 | | - }; |
| 26 | + const changeLogLevel = () => { |
| 27 | + const nextLogLevel = (logLevel + 1) % 4; |
| 28 | + FileLogger.setLogLevel(nextLogLevel); |
| 29 | + setLogLevel(nextLogLevel); |
| 30 | + }; |
33 | 31 |
|
34 | | - const sendLogFilesByEmail = () => { |
35 | | - FileLogger.sendLogFilesByEmail({ |
36 | | - |
37 | | - subject: 'Log files', |
38 | | - body: 'Please find attached the log files from your app', |
39 | | - }); |
40 | | - }; |
| 32 | + const sendLogFilesByEmail = () => { |
| 33 | + FileLogger.sendLogFilesByEmail({ |
| 34 | + |
| 35 | + subject: "Log files", |
| 36 | + body: "Please find attached the log files from your app", |
| 37 | + }); |
| 38 | + }; |
41 | 39 |
|
42 | | - const deleteLogFiles = async () => { |
43 | | - FileLogger.deleteLogFiles(); |
44 | | - Alert.alert('Log files deleted'); |
45 | | - }; |
| 40 | + const deleteLogFiles = async () => { |
| 41 | + FileLogger.deleteLogFiles(); |
| 42 | + Alert.alert("Log files deleted"); |
| 43 | + }; |
46 | 44 |
|
47 | | - const massiveLogging = () => { |
48 | | - const logHugeAmountOfData = () => { |
49 | | - for (let i = 0; i < 50000; i++) { |
50 | | - FileLogger.debug( |
51 | | - 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero pharetra tempor. Cras vestibulum bibendum augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum. Maecenas adipiscing ante non diam sodales hendrerit.\ |
| 45 | + const massiveLogging = () => { |
| 46 | + const logHugeAmountOfData = () => { |
| 47 | + for (let i = 0; i < 50000; i++) { |
| 48 | + FileLogger.debug( |
| 49 | + "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero pharetra tempor. Cras vestibulum bibendum augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum. Maecenas adipiscing ante non diam sodales hendrerit.\ |
52 | 50 | Ut velit mauris, egestas sed, gravida nec, ornare ut, mi. Aenean ut orci vel massa suscipit pulvinar. Nulla sollicitudin. Fusce varius, ligula non tempus aliquam, nunc turpis ullamcorper nibh, in tempus sapien eros vitae ligula. Pellentesque rhoncus nunc et augue. Integer id felis. Curabitur aliquet pellentesque diam. Integer quis metus vitae elit lobortis egestas. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Morbi vel erat non mauris convallis vehicula. Nulla et sapien. Integer tortor tellus, aliquam faucibus, convallis id, congue eu, quam. Mauris ullamcorper felis vitae erat. Proin feugiat, augue non elementum posuere, metus purus iaculis lectus, et tristique ligula justo vitae magna.\ |
53 | | - Aliquam convallis sollicitudin purus. Praesent aliquam, enim at fermentum mollis, ligula massa adipiscing nisl, ac euismod nibh nisl eu lectus. Fusce vulputate sem at sapien. Vivamus leo. Aliquam euismod libero eu enim. Nulla nec felis sed leo placerat imperdiet. Aenean suscipit nulla in justo. Suspendisse cursus rutrum augue. Nulla tincidunt tincidunt mi. Curabitur iaculis, lorem vel rhoncus faucibus, felis magna fermentum augue, et ultricies lacus lorem varius purus. Curabitur eu amet.', |
54 | | - ); |
55 | | - } |
56 | | - }; |
57 | | - Alert.alert( |
58 | | - 'Massive log', |
59 | | - 'This will log large amounts of data to test your maximum file size configuration. Your phone may freeze during the operation.', |
60 | | - [ |
61 | | - {text: 'Cancel', style: 'cancel'}, |
62 | | - {text: 'Continue', onPress: logHugeAmountOfData, style: 'destructive'}, |
63 | | - ], |
64 | | - {cancelable: true}, |
65 | | - ); |
66 | | - }; |
| 51 | + Aliquam convallis sollicitudin purus. Praesent aliquam, enim at fermentum mollis, ligula massa adipiscing nisl, ac euismod nibh nisl eu lectus. Fusce vulputate sem at sapien. Vivamus leo. Aliquam euismod libero eu enim. Nulla nec felis sed leo placerat imperdiet. Aenean suscipit nulla in justo. Suspendisse cursus rutrum augue. Nulla tincidunt tincidunt mi. Curabitur iaculis, lorem vel rhoncus faucibus, felis magna fermentum augue, et ultricies lacus lorem varius purus. Curabitur eu amet." |
| 52 | + ); |
| 53 | + } |
| 54 | + }; |
| 55 | + Alert.alert( |
| 56 | + "Massive log", |
| 57 | + "This will log large amounts of data to test your maximum file size configuration. Your phone may freeze during the operation.", |
| 58 | + [ |
| 59 | + { text: "Cancel", style: "cancel" }, |
| 60 | + { text: "Continue", onPress: logHugeAmountOfData, style: "destructive" }, |
| 61 | + ], |
| 62 | + { cancelable: true } |
| 63 | + ); |
| 64 | + }; |
67 | 65 |
|
68 | | - return ( |
69 | | - <View style={styles.container}> |
70 | | - <View style={styles.buttonContainer}> |
71 | | - <View style={styles.button}> |
72 | | - <Button |
73 | | - title="Log info" |
74 | | - onPress={() => console.log('Log info', {nested: {data: 123}})} |
75 | | - /> |
76 | | - </View> |
77 | | - <View style={styles.button}> |
78 | | - <Button |
79 | | - title="Log warning" |
80 | | - onPress={() => console.warn('Log warning', {nested: {data: 456}})} |
81 | | - /> |
82 | | - </View> |
83 | | - <View style={styles.button}> |
84 | | - <Button title="Log large data" onPress={() => massiveLogging()} /> |
85 | | - </View> |
86 | | - <View style={styles.button}> |
87 | | - <Button title="Change log level" onPress={changeLogLevel} /> |
88 | | - </View> |
89 | | - <View style={styles.button}> |
90 | | - <Button title="Show file paths" onPress={showLogFilePaths} /> |
91 | | - </View> |
92 | | - <View style={styles.button}> |
93 | | - <Button title="Send files by email" onPress={sendLogFilesByEmail} /> |
94 | | - </View> |
95 | | - <View style={styles.button}> |
96 | | - <Button title="Delete files" onPress={deleteLogFiles} /> |
97 | | - </View> |
98 | | - </View> |
99 | | - <View style={styles.settingsRow}> |
100 | | - <Text style={styles.settingsLabel}>Enabled</Text> |
101 | | - <Switch value={enabled} onValueChange={changeEnabled} /> |
102 | | - </View> |
103 | | - <View style={styles.settingsRow}> |
104 | | - <Text style={styles.settingsLabel}>Log Level</Text> |
105 | | - <Text style={styles.settingsValue}>{LogLevel[logLevel]}</Text> |
106 | | - </View> |
107 | | - </View> |
108 | | - ); |
| 66 | + return ( |
| 67 | + <View style={styles.container}> |
| 68 | + <View style={styles.buttonContainer}> |
| 69 | + <View style={styles.button}> |
| 70 | + <Button title="Log info" onPress={() => console.log("Log info", { nested: { data: 123 } })} /> |
| 71 | + </View> |
| 72 | + <View style={styles.button}> |
| 73 | + <Button title="Log warning" onPress={() => console.warn("Log warning", { nested: { data: 456 } })} /> |
| 74 | + </View> |
| 75 | + <View style={styles.button}> |
| 76 | + <Button title="Log error" onPress={() => console.error("Log error", { nested: { data: 789 } })} /> |
| 77 | + </View> |
| 78 | + <View style={styles.button}> |
| 79 | + <Button title="Log large data" onPress={() => massiveLogging()} /> |
| 80 | + </View> |
| 81 | + <View style={styles.button}> |
| 82 | + <Button title="Change log level" onPress={changeLogLevel} /> |
| 83 | + </View> |
| 84 | + <View style={styles.button}> |
| 85 | + <Button title="Show file paths" onPress={showLogFilePaths} /> |
| 86 | + </View> |
| 87 | + <View style={styles.button}> |
| 88 | + <Button title="Send files by email" onPress={sendLogFilesByEmail} /> |
| 89 | + </View> |
| 90 | + <View style={styles.button}> |
| 91 | + <Button title="Delete files" onPress={deleteLogFiles} /> |
| 92 | + </View> |
| 93 | + </View> |
| 94 | + <View style={styles.settingsRow}> |
| 95 | + <Text style={styles.settingsLabel}>Enabled</Text> |
| 96 | + <Switch value={enabled} onValueChange={changeEnabled} /> |
| 97 | + </View> |
| 98 | + <View style={styles.settingsRow}> |
| 99 | + <Text style={styles.settingsLabel}>Log Level</Text> |
| 100 | + <Text style={styles.settingsValue}>{LogLevel[logLevel]}</Text> |
| 101 | + </View> |
| 102 | + </View> |
| 103 | + ); |
109 | 104 | }; |
110 | 105 |
|
111 | 106 | const styles = StyleSheet.create({ |
112 | | - container: { |
113 | | - flex: 1, |
114 | | - padding: 25, |
115 | | - backgroundColor: '#f5fcff', |
116 | | - }, |
117 | | - buttonContainer: { |
118 | | - flex: 1, |
119 | | - justifyContent: 'center', |
120 | | - }, |
121 | | - button: { |
122 | | - marginVertical: 6, |
123 | | - }, |
124 | | - settingsRow: { |
125 | | - paddingHorizontal: 16, |
126 | | - paddingVertical: 10, |
127 | | - marginBottom: 20, |
128 | | - minHeight: 50, |
129 | | - flexDirection: 'row', |
130 | | - alignItems: 'center', |
131 | | - backgroundColor: '#dff4ff', |
132 | | - borderRadius: 6, |
133 | | - }, |
134 | | - settingsLabel: { |
135 | | - flex: 1, |
136 | | - fontWeight: '500', |
137 | | - color: 'black', |
138 | | - }, |
139 | | - settingsValue: { |
140 | | - color: 'black', |
141 | | - }, |
| 107 | + container: { |
| 108 | + flex: 1, |
| 109 | + padding: 25, |
| 110 | + backgroundColor: "#f5fcff", |
| 111 | + }, |
| 112 | + buttonContainer: { |
| 113 | + flex: 1, |
| 114 | + justifyContent: "center", |
| 115 | + }, |
| 116 | + button: { |
| 117 | + marginVertical: 6, |
| 118 | + }, |
| 119 | + settingsRow: { |
| 120 | + paddingHorizontal: 16, |
| 121 | + paddingVertical: 10, |
| 122 | + marginBottom: 20, |
| 123 | + minHeight: 50, |
| 124 | + flexDirection: "row", |
| 125 | + alignItems: "center", |
| 126 | + backgroundColor: "#dff4ff", |
| 127 | + borderRadius: 6, |
| 128 | + }, |
| 129 | + settingsLabel: { |
| 130 | + flex: 1, |
| 131 | + fontWeight: "500", |
| 132 | + color: "black", |
| 133 | + }, |
| 134 | + settingsValue: { |
| 135 | + color: "black", |
| 136 | + }, |
142 | 137 | }); |
0 commit comments