-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathCompareRevisions.js
126 lines (109 loc) · 3.23 KB
/
CompareRevisions.js
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/*** Compare Revisions ***/
// Adds a button to the diff page to compare two revisions side-by-side
// Documentation at [[en:w:User:BrandonXLF/CompareRevisions]]
// By [[en:w:User:BrandonXLF]]
$.when(mw.loader.using('oojs-ui'), $.ready).then(function() {
var cache = {};
mw.hook('wikipage.diff').add(function() {
var oldId = mw.config.get('wgDiffOldId'),
newId = mw.config.get('wgDiffNewId'),
bar = new OO.ui.ButtonSelectWidget({items: [
new OO.ui.ButtonOptionWidget({
label: 'Diff',
data: 'diff'
}),
new OO.ui.ButtonOptionWidget({
label: 'Compare',
data: 'compare'
}),
new OO.ui.ButtonOptionWidget({
label: 'Compare Wikitext',
data: 'wikitext'
})
]}),
compareArea = $('<div>').attr('id', 'comparerevisions-area');
if (!oldId || !newId) return;
function showComparison(cachePrefix, displayFunc, getFunc) {
var compareOld = $('<div>').addClass('comparerevisions-side'),
compareNew = $('<div>').addClass('comparerevisions-side');
function showRevision(revId, el) {
var cacheKey = cachePrefix + '-' + revId;
compareArea.append(
el.append(
$('<div>').css('text-align', 'center').text('Loading...')
)
);
if (cache[cacheKey]) {
displayFunc(el.empty(), cache[cacheKey], revId);
} else {
getFunc(revId).done(function(data) {
cache[cacheKey] = data;
displayFunc(el.empty(), cache[cacheKey], revId);
});
}
}
showRevision(oldId, compareOld);
showRevision(newId, compareNew);
}
$('.diff-title').after(
$('<tr>').append(
$('<td>').attr('colspan', '4').append(compareArea)
)
);
bar.$element.css({
float: 'left',
margin: $('.ve-init-mw-diffPage-diffMode').length ? '0 0 0 8px' : '8px 0'
});
if ($('.ve-init-mw-diffPage-diffMode').length) {
$('.ve-init-mw-diffPage-diffMode').append(bar.$element);
} else if ($('.mw-revslider-container').length) {
$('.mw-revslider-container').after(bar.$element);
} else {
$('#mw-content-text').prepend(bar.$element);
}
bar.on('select', function(e) {
mw.storage.set('comparerevisions-lastview', e.data);
compareArea.empty();
if (e.data == 'compare') {
showComparison(
'compare',
function(el, html, revId) {
el.html(html);
el.find('[for="toctogglecheckbox"]').attr('for', 'toctogglecheckbox-' + revId);
el.find('#toctogglecheckbox').attr('id', 'toctogglecheckbox-' + revId);
},
function(revId) {
return $.get(mw.config.get('wgScriptPath') + '/api.php', {
action: 'parse',
oldid: revId,
prop: 'text',
format: 'json'
}).then(function(res) {
return res.parse.text['*'];
});
}
);
} else if (e.data == 'wikitext') {
showComparison(
'wikitext',
function(el, text) {
el.append(
$('<pre></pre>').text(text)
);
},
function(revId) {
return $.get(mw.config.get('wgScript'), {
action: 'raw',
oldid: revId
});
}
);
}
});
bar.selectItemByData(mw.storage.get('comparerevisions-lastview') || 'diff');
});
mw.loader.addStyleTag(
'#comparerevisions-area { border-spacing: 0; }' +
'.comparerevisions-side { width: 50%; padding: 3px 10px; box-sizing: border-box; float: left; }'
);
});