1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
/*
* JaCoCo Report Viewer, a web-based coverage report viewer
* Copyright (C) 2018 Pacien TRAN-GIRARD
* Adam NAILI
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
import React, { Component } from 'react';
import { Parser } from 'xml2js';
import JSZip from 'jszip';
import { Report } from './Report.js';
import './App.css';
class App extends Component {
constructor(props) {
super(props);
this.state = {
report: null,
sourceSet: null,
hasError: false
};
}
componentDidCatch(error, info) {
this.setState({ hasError: true });
console.error(error, info);
}
_useReportFile(file) {
const fileReader = new FileReader();
fileReader.onloadend = readEvent => this._useReport(readEvent.target.result);
fileReader.readAsText(file);
}
_useReport(xmlString) {
this.setState({ hasError: false });
const xmlParser = new Parser();
xmlParser.parseString(xmlString, (_, result) => this.setState({ report: result.report }));
}
_useSourceArchive(file) {
this.setState({ hasError: false });
JSZip.loadAsync(file).then(zip => this.setState({ sourceSet: zip.files }));
}
_renderError() {
return (
<span>
Something went wrong while rendering the report.
Are the provided files valid?
</span>
);
}
_renderReport() {
return this.state.hasError ? this._renderError(): (<Report report={this.state.report} sourceSet={this.state.sourceSet} />);
}
render() {
return (
<div className="App">
<h1>JaCoCo Report Viewer</h1>
<div>
<label htmlFor="reportFile">XML report: </label>
<input id="reportFile" type="file" accept=".xml" onChange={event => this._useReportFile(event.target.files[0])} />
</div>
<div>
<label htmlFor="sourceJar">Source JAR: </label>
<input id="sourceJar" type="file" accept=".jar" onChange={event => this._useSourceArchive(event.target.files[0])} />
</div>
<hr />
{this._renderReport()}
</div>
);
}
}
export default App;
|