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
|
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at <http://mozilla.org/MPL/2.0/>. */
import { connect } from "../../utils/connect";
import { Component } from "react";
import PropTypes from "prop-types";
import { getSelectedSource, getSelectedBreakableLines } from "../../selectors";
import { fromEditorLine } from "../../utils/editor";
import { isWasm } from "../../utils/wasm";
class EmptyLines extends Component {
static get propTypes() {
return {
breakableLines: PropTypes.object.isRequired,
editor: PropTypes.object.isRequired,
selectedSource: PropTypes.object.isRequired,
};
}
componentDidMount() {
this.disableEmptyLines();
}
componentDidUpdate() {
this.disableEmptyLines();
}
componentWillUnmount() {
const { editor } = this.props;
editor.codeMirror.operation(() => {
editor.codeMirror.eachLine(lineHandle => {
editor.codeMirror.removeLineClass(lineHandle, "wrap", "empty-line");
});
});
}
shouldComponentUpdate(nextProps) {
const { breakableLines, selectedSource } = this.props;
return (
// Breakable lines are something that evolves over time,
// but we either have them loaded or not. So only compare the size
// as sometimes we always get a blank new empty Set instance.
breakableLines.size != nextProps.breakableLines.size ||
selectedSource.id != nextProps.selectedSource.id
);
}
disableEmptyLines() {
const { breakableLines, selectedSource, editor } = this.props;
const { codeMirror } = editor;
const isSourceWasm = isWasm(selectedSource.id);
codeMirror.operation(() => {
const lineCount = codeMirror.lineCount();
for (let i = 0; i < lineCount; i++) {
const line = fromEditorLine(selectedSource.id, i, isSourceWasm);
if (breakableLines.has(line)) {
codeMirror.removeLineClass(i, "wrap", "empty-line");
} else {
codeMirror.addLineClass(i, "wrap", "empty-line");
}
}
});
}
render() {
return null;
}
}
const mapStateToProps = state => {
const selectedSource = getSelectedSource(state);
if (!selectedSource) {
throw new Error("no selectedSource");
}
const breakableLines = getSelectedBreakableLines(state);
return {
selectedSource,
breakableLines,
};
};
export default connect(mapStateToProps)(EmptyLines);
|