kopia lustrzana https://github.com/dgtlmoon/changedetection.io
Update visual text difference library, add option to ignore whitespace when viewing diff (#1137)
rodzic
df6e835035
commit
bcf7417f63
|
@ -0,0 +1,112 @@
|
||||||
|
var a = document.getElementById('a');
|
||||||
|
var b = document.getElementById('b');
|
||||||
|
var result = document.getElementById('result');
|
||||||
|
|
||||||
|
function changed() {
|
||||||
|
// https://github.com/kpdecker/jsdiff/issues/389
|
||||||
|
// I would love to use `{ignoreWhitespace: true}` here but it breaks the formatting
|
||||||
|
options = {ignoreWhitespace: document.getElementById('ignoreWhitespace').checked};
|
||||||
|
|
||||||
|
var diff = Diff[window.diffType](a.textContent, b.textContent, options);
|
||||||
|
var fragment = document.createDocumentFragment();
|
||||||
|
for (var i = 0; i < diff.length; i++) {
|
||||||
|
|
||||||
|
if (diff[i].added && diff[i + 1] && diff[i + 1].removed) {
|
||||||
|
var swap = diff[i];
|
||||||
|
diff[i] = diff[i + 1];
|
||||||
|
diff[i + 1] = swap;
|
||||||
|
}
|
||||||
|
|
||||||
|
var node;
|
||||||
|
if (diff[i].removed) {
|
||||||
|
node = document.createElement('del');
|
||||||
|
node.classList.add("change");
|
||||||
|
node.appendChild(document.createTextNode(diff[i].value));
|
||||||
|
|
||||||
|
} else if (diff[i].added) {
|
||||||
|
node = document.createElement('ins');
|
||||||
|
node.classList.add("change");
|
||||||
|
node.appendChild(document.createTextNode(diff[i].value));
|
||||||
|
} else {
|
||||||
|
node = document.createTextNode(diff[i].value);
|
||||||
|
}
|
||||||
|
fragment.appendChild(node);
|
||||||
|
}
|
||||||
|
|
||||||
|
result.textContent = '';
|
||||||
|
result.appendChild(fragment);
|
||||||
|
|
||||||
|
// Jump at start
|
||||||
|
inputs.current = 0;
|
||||||
|
next_diff();
|
||||||
|
}
|
||||||
|
|
||||||
|
window.onload = function () {
|
||||||
|
|
||||||
|
|
||||||
|
/* Convert what is options from UTC time.time() to local browser time */
|
||||||
|
var diffList = document.getElementById("diff-version");
|
||||||
|
if (typeof (diffList) != 'undefined' && diffList != null) {
|
||||||
|
for (var option of diffList.options) {
|
||||||
|
var dateObject = new Date(option.value * 1000);
|
||||||
|
option.label = dateObject.toLocaleString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set current version date as local time in the browser also */
|
||||||
|
var current_v = document.getElementById("current-v-date");
|
||||||
|
var dateObject = new Date(newest_version_timestamp*1000);
|
||||||
|
current_v.innerHTML = dateObject.toLocaleString();
|
||||||
|
onDiffTypeChange(document.querySelector('#settings [name="diff_type"]:checked'));
|
||||||
|
changed();
|
||||||
|
};
|
||||||
|
|
||||||
|
a.onpaste = a.onchange =
|
||||||
|
b.onpaste = b.onchange = changed;
|
||||||
|
|
||||||
|
if ('oninput' in a) {
|
||||||
|
a.oninput = b.oninput = changed;
|
||||||
|
} else {
|
||||||
|
a.onkeyup = b.onkeyup = changed;
|
||||||
|
}
|
||||||
|
|
||||||
|
function onDiffTypeChange(radio) {
|
||||||
|
window.diffType = radio.value;
|
||||||
|
// Not necessary
|
||||||
|
// document.title = "Diff " + radio.value.slice(4);
|
||||||
|
}
|
||||||
|
|
||||||
|
var radio = document.getElementsByName('diff_type');
|
||||||
|
for (var i = 0; i < radio.length; i++) {
|
||||||
|
radio[i].onchange = function (e) {
|
||||||
|
onDiffTypeChange(e.target);
|
||||||
|
changed();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
document.getElementById('ignoreWhitespace').onchange = function (e) {
|
||||||
|
changed();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var inputs = document.getElementsByClassName('change');
|
||||||
|
inputs.current = 0;
|
||||||
|
|
||||||
|
|
||||||
|
function next_diff() {
|
||||||
|
|
||||||
|
var element = inputs[inputs.current];
|
||||||
|
var headerOffset = 80;
|
||||||
|
var elementPosition = element.getBoundingClientRect().top;
|
||||||
|
var offsetPosition = elementPosition - headerOffset + window.scrollY;
|
||||||
|
|
||||||
|
window.scrollTo({
|
||||||
|
top: offsetPosition,
|
||||||
|
behavior: "smooth"
|
||||||
|
});
|
||||||
|
|
||||||
|
inputs.current++;
|
||||||
|
if (inputs.current >= inputs.length) {
|
||||||
|
inputs.current = 0;
|
||||||
|
}
|
||||||
|
}
|
Plik diff jest za duży
Load Diff
File diff suppressed because one or more lines are too long
|
@ -37,6 +37,11 @@
|
||||||
</form>
|
</form>
|
||||||
<del>Removed text</del>
|
<del>Removed text</del>
|
||||||
<ins>Inserted Text</ins>
|
<ins>Inserted Text</ins>
|
||||||
|
<span>
|
||||||
|
<!-- https://github.com/kpdecker/jsdiff/issues/389 ? -->
|
||||||
|
<label for="ignoreWhitespace" class="pure-checkbox" id="label-diff-ignorewhitespace">
|
||||||
|
<input type="checkbox" id="ignoreWhitespace" name="ignoreWhitespace"/> Ignore Whitespace</label>
|
||||||
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="diff-jump">
|
<div id="diff-jump">
|
||||||
|
@ -102,122 +107,12 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
<script type="text/javascript" src="{{url_for('static_content', group='js', filename='diff.js')}}"></script>
|
const newest_version_timestamp = {{newest_version_timestamp}};
|
||||||
|
|
||||||
<script defer="">
|
|
||||||
|
|
||||||
var a = document.getElementById('a');
|
|
||||||
var b = document.getElementById('b');
|
|
||||||
var result = document.getElementById('result');
|
|
||||||
|
|
||||||
function changed() {
|
|
||||||
var diff = JsDiff[window.diffType](a.textContent, b.textContent);
|
|
||||||
var fragment = document.createDocumentFragment();
|
|
||||||
for (var i=0; i < diff.length; i++) {
|
|
||||||
|
|
||||||
if (diff[i].added && diff[i + 1] && diff[i + 1].removed) {
|
|
||||||
var swap = diff[i];
|
|
||||||
diff[i] = diff[i + 1];
|
|
||||||
diff[i + 1] = swap;
|
|
||||||
}
|
|
||||||
|
|
||||||
var node;
|
|
||||||
if (diff[i].removed) {
|
|
||||||
node = document.createElement('del');
|
|
||||||
node.classList.add("change");
|
|
||||||
node.appendChild(document.createTextNode(diff[i].value));
|
|
||||||
|
|
||||||
} else if (diff[i].added) {
|
|
||||||
node = document.createElement('ins');
|
|
||||||
node.classList.add("change");
|
|
||||||
node.appendChild(document.createTextNode(diff[i].value));
|
|
||||||
} else {
|
|
||||||
node = document.createTextNode(diff[i].value);
|
|
||||||
}
|
|
||||||
fragment.appendChild(node);
|
|
||||||
}
|
|
||||||
|
|
||||||
result.textContent = '';
|
|
||||||
result.appendChild(fragment);
|
|
||||||
|
|
||||||
// Jump at start
|
|
||||||
inputs.current=0;
|
|
||||||
next_diff();
|
|
||||||
}
|
|
||||||
|
|
||||||
window.onload = function() {
|
|
||||||
|
|
||||||
|
|
||||||
/* Convert what is options from UTC time.time() to local browser time */
|
|
||||||
var diffList=document.getElementById("diff-version");
|
|
||||||
if (typeof(diffList) != 'undefined' && diffList != null) {
|
|
||||||
for (var option of diffList.options) {
|
|
||||||
var dateObject = new Date(option.value*1000);
|
|
||||||
option.label=dateObject.toLocaleString();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Set current version date as local time in the browser also */
|
|
||||||
var current_v = document.getElementById("current-v-date");
|
|
||||||
var dateObject = new Date({{ newest_version_timestamp }}*1000);
|
|
||||||
current_v.innerHTML=dateObject.toLocaleString();
|
|
||||||
|
|
||||||
|
|
||||||
onDiffTypeChange(document.querySelector('#settings [name="diff_type"]:checked'));
|
|
||||||
changed();
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
a.onpaste = a.onchange =
|
|
||||||
b.onpaste = b.onchange = changed;
|
|
||||||
|
|
||||||
if ('oninput' in a) {
|
|
||||||
a.oninput = b.oninput = changed;
|
|
||||||
} else {
|
|
||||||
a.onkeyup = b.onkeyup = changed;
|
|
||||||
}
|
|
||||||
|
|
||||||
function onDiffTypeChange(radio) {
|
|
||||||
window.diffType = radio.value;
|
|
||||||
// Not necessary
|
|
||||||
// document.title = "Diff " + radio.value.slice(4);
|
|
||||||
}
|
|
||||||
|
|
||||||
var radio = document.getElementsByName('diff_type');
|
|
||||||
for (var i = 0; i < radio.length; i++) {
|
|
||||||
radio[i].onchange = function(e) {
|
|
||||||
onDiffTypeChange(e.target);
|
|
||||||
changed();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var inputs = document.getElementsByClassName('change');
|
|
||||||
inputs.current=0;
|
|
||||||
|
|
||||||
|
|
||||||
function next_diff() {
|
|
||||||
|
|
||||||
var element = inputs[inputs.current];
|
|
||||||
var headerOffset = 80;
|
|
||||||
var elementPosition = element.getBoundingClientRect().top;
|
|
||||||
var offsetPosition = elementPosition - headerOffset + window.scrollY;
|
|
||||||
|
|
||||||
window.scrollTo({
|
|
||||||
top: offsetPosition,
|
|
||||||
behavior: "smooth"
|
|
||||||
});
|
|
||||||
|
|
||||||
inputs.current++;
|
|
||||||
if(inputs.current >= inputs.length) {
|
|
||||||
inputs.current=0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
<script type="text/javascript" src="{{url_for('static_content', group='js', filename='diff.min.js')}}"></script>
|
||||||
|
|
||||||
|
<script type="text/javascript" src="{{url_for('static_content', group='js', filename='diff-render.js')}}"></script>
|
||||||
|
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
Ładowanie…
Reference in New Issue