Add top option for highlighting filters.
This commit is contained in:
parent
f02688bd0a
commit
ddee297a36
@ -141,7 +141,7 @@
|
|||||||
subject: ['# Filter Generals on /v/:', '#/general/i;boards:v;op:only'].join('\n'),
|
subject: ['# Filter Generals on /v/:', '#/general/i;boards:v;op:only'].join('\n'),
|
||||||
comment: ['# Filter Stallman copypasta on /g/:', '#/what you\'re refer+ing to as linux/i;boards:g'].join('\n'),
|
comment: ['# Filter Stallman copypasta on /g/:', '#/what you\'re refer+ing to as linux/i;boards:g'].join('\n'),
|
||||||
filename: [''].join('\n'),
|
filename: [''].join('\n'),
|
||||||
dimensions: ['# Highlight potential wallpapers:', '#/1920x1080/;op:yes;highlight;boards:w,wg'].join('\n'),
|
dimensions: ['# Highlight potential wallpapers:', '#/1920x1080/;op:yes;highlight;top:no;boards:w,wg'].join('\n'),
|
||||||
filesize: [''].join('\n'),
|
filesize: [''].join('\n'),
|
||||||
md5: [''].join('\n')
|
md5: [''].join('\n')
|
||||||
},
|
},
|
||||||
@ -534,7 +534,7 @@
|
|||||||
filter = {
|
filter = {
|
||||||
filters: {},
|
filters: {},
|
||||||
init: function() {
|
init: function() {
|
||||||
var boards, filter, hl, key, op, regexp, _i, _len, _ref, _ref2, _ref3, _ref4;
|
var boards, filter, hl, key, op, regexp, top, _i, _len, _ref, _ref2, _ref3, _ref4, _ref5;
|
||||||
for (key in config.filter) {
|
for (key in config.filter) {
|
||||||
this.filters[key] = [];
|
this.filters[key] = [];
|
||||||
_ref = conf[key].split('\n');
|
_ref = conf[key].split('\n');
|
||||||
@ -553,31 +553,34 @@
|
|||||||
alert(e.message);
|
alert(e.message);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
op = ((_ref3 = filter.match(/op:(yes|no|only)/)) != null ? _ref3[1].toLowerCase() : void 0) || 'no';
|
op = ((_ref3 = filter.match(/[^t]op:(yes|no|only)/)) != null ? _ref3[1].toLowerCase() : void 0) || 'no';
|
||||||
if (hl = /highlight/.test(filter)) {
|
if (hl = /highlight/.test(filter)) {
|
||||||
hl = ((_ref4 = filter.match(/highlight:(\w+)/)) != null ? _ref4[1].toLowerCase() : void 0) || 'filter_highlight';
|
hl = ((_ref4 = filter.match(/highlight:(\w+)/)) != null ? _ref4[1].toLowerCase() : void 0) || 'filter_highlight';
|
||||||
|
top = ((_ref5 = filter.match(/top:(yes|no)/)) != null ? _ref5[1].toLowerCase() : void 0) || 'yes';
|
||||||
|
top = top === 'yes';
|
||||||
}
|
}
|
||||||
this.filters[key].push(this.createFilter(regexp, op, hl));
|
this.filters[key].push(this.createFilter(regexp, op, hl, top));
|
||||||
}
|
}
|
||||||
if (!this.filters[key].length) delete this.filters[key];
|
if (!this.filters[key].length) delete this.filters[key];
|
||||||
}
|
}
|
||||||
if (Object.keys(this.filters).length) return g.callbacks.push(this.node);
|
if (Object.keys(this.filters).length) return g.callbacks.push(this.node);
|
||||||
},
|
},
|
||||||
createFilter: function(regexp, op, hl) {
|
createFilter: function(regexp, op, hl, top) {
|
||||||
return function(root, value, isOP) {
|
return function(root, value, isOP) {
|
||||||
var firstThread, thisThread;
|
var firstThread, thisThread;
|
||||||
if (isOP && op === 'no' || !isOP && op === 'only') return false;
|
if (isOP && op === 'no' || !isOP && op === 'only') return false;
|
||||||
if (!regexp.test(value)) return false;
|
if (!regexp.test(value)) return false;
|
||||||
if (hl) {
|
if (hl) {
|
||||||
$.addClass(root, hl);
|
$.addClass(root, hl);
|
||||||
if (isOP && !g.REPLY) {
|
if (isOP && top && !g.REPLY) {
|
||||||
thisThread = root.parentNode;
|
thisThread = root.parentNode;
|
||||||
if (firstThread = $('div[class=op]')) {
|
if (firstThread = $('div[class=op]')) {
|
||||||
$.before(firstThread.parentNode, [thisThread, thisThread.nextElementSibling]);
|
$.before(firstThread.parentNode, [thisThread, thisThread.nextElementSibling]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
} else if (isOP) {
|
}
|
||||||
|
if (isOP) {
|
||||||
if (!g.REPLY) threadHiding.hideHide(root.parentNode);
|
if (!g.REPLY) threadHiding.hideHide(root.parentNode);
|
||||||
} else {
|
} else {
|
||||||
replyHiding.hideHide(root.previousSibling);
|
replyHiding.hideHide(root.previousSibling);
|
||||||
@ -2125,7 +2128,8 @@
|
|||||||
<ul>You can use these settings with each regular expression, separate them with semicolons:\
|
<ul>You can use these settings with each regular expression, separate them with semicolons:\
|
||||||
<li>Per boards, separate them with commas. It is global if not specified.<br>For example: <code>boards:a,jp;</code>.</li>\
|
<li>Per boards, separate them with commas. It is global if not specified.<br>For example: <code>boards:a,jp;</code>.</li>\
|
||||||
<li>Filter OPs only along with their threads (`only`), replies only (`no`, this is default), or both (`yes`).<br>For example: <code>op:only;</code>, <code>op:no;</code> or <code>op:yes;</code>.</li>\
|
<li>Filter OPs only along with their threads (`only`), replies only (`no`, this is default), or both (`yes`).<br>For example: <code>op:only;</code>, <code>op:no;</code> or <code>op:yes;</code>.</li>\
|
||||||
<li>Highlight instead of hiding. Highlighted OPs will have their threads put on top of board pages. You can specify a class name to use with a userstyle.<br>For example: <code>highlight;</code> or <code>hightlight:wallpaper;</code>.</li>\
|
<li>Highlight instead of hiding. You can specify a class name to use with a userstyle.<br>For example: <code>highlight;</code> or <code>hightlight:wallpaper;</code>.</li>\
|
||||||
|
<li>Highlighted OPs will have their threads put on top of board pages by default.<br>For example: <code>top:yes</code> or <code>top:no</code>.</li>\
|
||||||
</ul>\
|
</ul>\
|
||||||
<p>Name:<br><textarea name=name></textarea></p>\
|
<p>Name:<br><textarea name=name></textarea></p>\
|
||||||
<p>Tripcode:<br><textarea name=tripcode></textarea></p>\
|
<p>Tripcode:<br><textarea name=tripcode></textarea></p>\
|
||||||
|
|||||||
@ -75,7 +75,7 @@ config =
|
|||||||
].join '\n'
|
].join '\n'
|
||||||
dimensions: [
|
dimensions: [
|
||||||
'# Highlight potential wallpapers:'
|
'# Highlight potential wallpapers:'
|
||||||
'#/1920x1080/;op:yes;highlight;boards:w,wg'
|
'#/1920x1080/;op:yes;highlight;top:no;boards:w,wg'
|
||||||
].join '\n'
|
].join '\n'
|
||||||
filesize: [
|
filesize: [
|
||||||
''
|
''
|
||||||
@ -460,15 +460,19 @@ filter =
|
|||||||
|
|
||||||
# Filter OPs along with their threads, replies only, or both.
|
# Filter OPs along with their threads, replies only, or both.
|
||||||
# Defaults to replies only.
|
# Defaults to replies only.
|
||||||
op = filter.match(/op:(yes|no|only)/)?[1].toLowerCase() or 'no'
|
op = filter.match(/[^t]op:(yes|no|only)/)?[1].toLowerCase() or 'no'
|
||||||
|
|
||||||
# Highlight the post, or hide it.
|
# Highlight the post, or hide it.
|
||||||
# If not specified, the highlight class will be filter_highlight.
|
# If not specified, the highlight class will be filter_highlight.
|
||||||
# Defaults to post hiding.
|
# Defaults to post hiding.
|
||||||
if hl = /highlight/.test filter
|
if hl = /highlight/.test filter
|
||||||
hl = filter.match(/highlight:(\w+)/)?[1].toLowerCase() or 'filter_highlight'
|
hl = filter.match(/highlight:(\w+)/)?[1].toLowerCase() or 'filter_highlight'
|
||||||
|
# Put highlighted OP's thread on top of the board page or not.
|
||||||
|
# Defaults to on top.
|
||||||
|
top = filter.match(/top:(yes|no)/)?[1].toLowerCase() or 'yes'
|
||||||
|
top = top is 'yes' # Turn it into a boolean
|
||||||
|
|
||||||
@filters[key].push @createFilter regexp, op, hl
|
@filters[key].push @createFilter regexp, op, hl, top
|
||||||
|
|
||||||
# Only execute filter types that contain valid filters.
|
# Only execute filter types that contain valid filters.
|
||||||
unless @filters[key].length
|
unless @filters[key].length
|
||||||
@ -477,7 +481,7 @@ filter =
|
|||||||
if Object.keys(@filters).length
|
if Object.keys(@filters).length
|
||||||
g.callbacks.push @node
|
g.callbacks.push @node
|
||||||
|
|
||||||
createFilter: (regexp, op, hl) ->
|
createFilter: (regexp, op, hl, top) ->
|
||||||
(root, value, isOP) ->
|
(root, value, isOP) ->
|
||||||
if isOP and op is 'no' or !isOP and op is 'only'
|
if isOP and op is 'no' or !isOP and op is 'only'
|
||||||
return false
|
return false
|
||||||
@ -485,7 +489,7 @@ filter =
|
|||||||
return false
|
return false
|
||||||
if hl
|
if hl
|
||||||
$.addClass root, hl
|
$.addClass root, hl
|
||||||
if isOP and not g.REPLY
|
if isOP and top and not g.REPLY
|
||||||
# Put the highlighted OPs' threads on top of the board pages...
|
# Put the highlighted OPs' threads on top of the board pages...
|
||||||
thisThread = root.parentNode
|
thisThread = root.parentNode
|
||||||
# ...before the first non highlighted thread.
|
# ...before the first non highlighted thread.
|
||||||
@ -493,7 +497,7 @@ filter =
|
|||||||
$.before firstThread.parentNode, [thisThread, thisThread.nextElementSibling]
|
$.before firstThread.parentNode, [thisThread, thisThread.nextElementSibling]
|
||||||
# Continue the filter lookup to add more classes or hide it.
|
# Continue the filter lookup to add more classes or hide it.
|
||||||
return false
|
return false
|
||||||
else if isOP
|
if isOP
|
||||||
unless g.REPLY
|
unless g.REPLY
|
||||||
threadHiding.hideHide root.parentNode
|
threadHiding.hideHide root.parentNode
|
||||||
else
|
else
|
||||||
@ -1719,7 +1723,8 @@ options =
|
|||||||
<ul>You can use these settings with each regular expression, separate them with semicolons:
|
<ul>You can use these settings with each regular expression, separate them with semicolons:
|
||||||
<li>Per boards, separate them with commas. It is global if not specified.<br>For example: <code>boards:a,jp;</code>.</li>
|
<li>Per boards, separate them with commas. It is global if not specified.<br>For example: <code>boards:a,jp;</code>.</li>
|
||||||
<li>Filter OPs only along with their threads (`only`), replies only (`no`, this is default), or both (`yes`).<br>For example: <code>op:only;</code>, <code>op:no;</code> or <code>op:yes;</code>.</li>
|
<li>Filter OPs only along with their threads (`only`), replies only (`no`, this is default), or both (`yes`).<br>For example: <code>op:only;</code>, <code>op:no;</code> or <code>op:yes;</code>.</li>
|
||||||
<li>Highlight instead of hiding. Highlighted OPs will have their threads put on top of board pages. You can specify a class name to use with a userstyle.<br>For example: <code>highlight;</code> or <code>hightlight:wallpaper;</code>.</li>
|
<li>Highlight instead of hiding. You can specify a class name to use with a userstyle.<br>For example: <code>highlight;</code> or <code>hightlight:wallpaper;</code>.</li>
|
||||||
|
<li>Highlighted OPs will have their threads put on top of board pages by default.<br>For example: <code>top:yes</code> or <code>top:no</code>.</li>
|
||||||
</ul>
|
</ul>
|
||||||
<p>Name:<br><textarea name=name></textarea></p>
|
<p>Name:<br><textarea name=name></textarea></p>
|
||||||
<p>Tripcode:<br><textarea name=tripcode></textarea></p>
|
<p>Tripcode:<br><textarea name=tripcode></textarea></p>
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user