diff --git a/CHANGELOG.md b/CHANGELOG.md
index 26df90f25..a1bfb5aaa 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,6 +1,10 @@
-## v2.8.0
-*2014-01-11*
+**seaweeedchan**:
+- Turn infinite scrolling into new index mode
+**Zixaphir**:
+- Fix an issue where changing the current archive would crash the redirect features.
+
+*2014-01-11*
**seaweedchan**:
- Various fixes and improvements for the JSONified index
diff --git a/builds/4chan-X.meta.js b/builds/4chan-X.meta.js
deleted file mode 100755
index 37469de03..000000000
--- a/builds/4chan-X.meta.js
+++ /dev/null
@@ -1,21 +0,0 @@
-// ==UserScript==
-// @name 4chan X
-// @version 1.3.0
-// @minGMVer 1.13
-// @minFFVer 26
-// @namespace 4chan-X
-// @description Cross-browser userscript for maximum lurking on 4chan.
-// @license MIT; https://github.com/seaweedchan/4chan-x/blob/master/LICENSE
-// @match *://boards.4chan.org/*
-// @match *://sys.4chan.org/*
-// @match *://a.4cdn.org/*
-// @match *://i.4cdn.org/*
-// @grant GM_getValue
-// @grant GM_setValue
-// @grant GM_deleteValue
-// @grant GM_openInTab
-// @run-at document-start
-// @updateURL https://github.com/seaweedchan/4chan-x/raw/stable/builds/4chan-X.meta.js
-// @downloadURL https://github.com/seaweedchan/4chan-x/raw/stable/builds/4chan-X.user.js
-// @icon 
-// ==/UserScript==
diff --git a/builds/appchan-x.user.js b/builds/appchan-x.user.js
index 653b70adc..0abfdff5a 100644
--- a/builds/appchan-x.user.js
+++ b/builds/appchan-x.user.js
@@ -4470,6 +4470,10 @@
el: $.el('label', {
innerHTML: ' Paged'
})
+ }, {
+ el: $.el('label', {
+ innerHTML: ' Infinite scrolling'
+ })
}, {
el: $.el('label', {
innerHTML: ' All threads'
@@ -4614,7 +4618,7 @@
},
scroll: $.debounce(100, function() {
var nodes, nodesPerPage, pageNum;
- if (Index.req || Conf['Index Mode'] !== 'paged' || (doc.scrollTop <= doc.scrollHeight - (300 + window.innerHeight)) || g.VIEW === 'thread') {
+ if (Index.req || Conf['Index Mode'] !== 'infinite' || ((d.body.scrollTop || doc.scrollTop) <= doc.scrollHeight - (300 + window.innerHeight)) || g.VIEW === 'thread') {
return;
}
pageNum = Index.getCurrentPage() + 1;
@@ -4696,7 +4700,7 @@
return +window.location.pathname.split('/')[2];
},
userPageNav: function(pageNum) {
- if (Conf['Refreshed Navigation'] && Conf['Index Mode'] === 'paged') {
+ if (Conf['Refreshed Navigation'] && Conf['Index Mode'] !== 'all pages') {
return Index.update(pageNum);
} else {
return Index.pageNav(pageNum);
@@ -4711,7 +4715,7 @@
},
pageLoad: function(pageNum) {
Index.currentPage = pageNum;
- if (Conf['Index Mode'] !== 'paged') {
+ if (Conf['Index Mode'] === 'all pages') {
return;
}
Index.buildIndex();
@@ -4729,7 +4733,7 @@
return Math.max(0, Index.getPagesNum() - 1);
},
togglePagelist: function() {
- return Index.pagelist.hidden = Conf['Index Mode'] !== 'paged';
+ return Index.pagelist.hidden = Conf['Index Mode'] === 'all pages';
},
buildPagelist: function() {
var a, i, maxPageNum, nodes, pagesRoot, _i;
@@ -5049,7 +5053,7 @@
},
buildIndex: function() {
var nodes, nodesPerPage, pageNum;
- if (Conf['Index Mode'] === 'paged') {
+ if (Conf['Index Mode'] !== 'all pages') {
pageNum = Index.getCurrentPage();
nodesPerPage = Index.threadsNumPerPage * 2;
nodes = Index.sortedNodes.slice(nodesPerPage * pageNum, nodesPerPage * (pageNum + 1));
@@ -5086,7 +5090,7 @@
Index.searchInput.removeAttribute('data-searching');
}
Index.sort();
- if (Conf['Index Mode'] === 'paged') {
+ if (Conf['Index Mode'] !== 'all pages') {
pageNum = Math.min(pageNum, Index.getMaxPageNum());
}
Index.buildPagelist();
@@ -15102,13 +15106,13 @@
$.open("/" + g.BOARD + "/");
break;
case Conf['Next page']:
- if (!(g.VIEW === 'index' && Conf['Index Mode'] === 'paged')) {
+ if (!(g.VIEW === 'index' && Conf['Index Mode'] !== 'all pages')) {
return;
}
$('.next button', Index.pagelist).click();
break;
case Conf['Previous page']:
- if (!(g.VIEW === 'index' && Conf['Index Mode'] === 'paged')) {
+ if (!(g.VIEW === 'index' && Conf['Index Mode'] !== 'all pages')) {
return;
}
$('.prev button', Index.pagelist).click();
diff --git a/builds/crx/script.js b/builds/crx/script.js
index f97317ee2..83bdf7610 100644
--- a/builds/crx/script.js
+++ b/builds/crx/script.js
@@ -4481,6 +4481,10 @@
el: $.el('label', {
innerHTML: ' Paged'
})
+ }, {
+ el: $.el('label', {
+ innerHTML: ' Infinite scrolling'
+ })
}, {
el: $.el('label', {
innerHTML: ' All threads'
@@ -4625,7 +4629,7 @@
},
scroll: $.debounce(100, function() {
var nodes, nodesPerPage, pageNum;
- if (Index.req || Conf['Index Mode'] !== 'paged' || (doc.scrollTop <= doc.scrollHeight - (300 + window.innerHeight)) || g.VIEW === 'thread') {
+ if (Index.req || Conf['Index Mode'] !== 'infinite' || ((d.body.scrollTop || doc.scrollTop) <= doc.scrollHeight - (300 + window.innerHeight)) || g.VIEW === 'thread') {
return;
}
pageNum = Index.getCurrentPage() + 1;
@@ -4707,7 +4711,7 @@
return +window.location.pathname.split('/')[2];
},
userPageNav: function(pageNum) {
- if (Conf['Refreshed Navigation'] && Conf['Index Mode'] === 'paged') {
+ if (Conf['Refreshed Navigation'] && Conf['Index Mode'] !== 'all pages') {
return Index.update(pageNum);
} else {
return Index.pageNav(pageNum);
@@ -4722,7 +4726,7 @@
},
pageLoad: function(pageNum) {
Index.currentPage = pageNum;
- if (Conf['Index Mode'] !== 'paged') {
+ if (Conf['Index Mode'] === 'all pages') {
return;
}
Index.buildIndex();
@@ -4740,7 +4744,7 @@
return Math.max(0, Index.getPagesNum() - 1);
},
togglePagelist: function() {
- return Index.pagelist.hidden = Conf['Index Mode'] !== 'paged';
+ return Index.pagelist.hidden = Conf['Index Mode'] === 'all pages';
},
buildPagelist: function() {
var a, i, maxPageNum, nodes, pagesRoot, _i;
@@ -5060,7 +5064,7 @@
},
buildIndex: function() {
var nodes, nodesPerPage, pageNum;
- if (Conf['Index Mode'] === 'paged') {
+ if (Conf['Index Mode'] !== 'all pages') {
pageNum = Index.getCurrentPage();
nodesPerPage = Index.threadsNumPerPage * 2;
nodes = Index.sortedNodes.slice(nodesPerPage * pageNum, nodesPerPage * (pageNum + 1));
@@ -5097,7 +5101,7 @@
delete Index.searchInput.dataset.searching;
}
Index.sort();
- if (Conf['Index Mode'] === 'paged') {
+ if (Conf['Index Mode'] !== 'all pages') {
pageNum = Math.min(pageNum, Index.getMaxPageNum());
}
Index.buildPagelist();
@@ -15098,13 +15102,13 @@
$.open("/" + g.BOARD + "/");
break;
case Conf['Next page']:
- if (!(g.VIEW === 'index' && Conf['Index Mode'] === 'paged')) {
+ if (!(g.VIEW === 'index' && Conf['Index Mode'] !== 'all pages')) {
return;
}
$('.next button', Index.pagelist).click();
break;
case Conf['Previous page']:
- if (!(g.VIEW === 'index' && Conf['Index Mode'] === 'paged')) {
+ if (!(g.VIEW === 'index' && Conf['Index Mode'] !== 'all pages')) {
return;
}
$('.prev button', Index.pagelist).click();
diff --git a/src/General/Index.coffee b/src/General/Index.coffee
index 137711e4e..034fe6757 100644
--- a/src/General/Index.coffee
+++ b/src/General/Index.coffee
@@ -14,6 +14,7 @@ Index =
el: $.el 'span', textContent: 'Index mode'
subEntries: [
{ el: $.el 'label', innerHTML: ' Paged' }
+ { el: $.el 'label', innerHTML: ' Infinite scrolling' }
{ el: $.el 'label', innerHTML: ' All threads' }
]
for label in modeEntry.subEntries
@@ -109,7 +110,7 @@ Index =
$.after $.id('delform'), Index.pagelist
scroll: $.debounce 100, ->
- return if Index.req or Conf['Index Mode'] isnt 'paged' or (doc.scrollTop <= doc.scrollHeight - (300 + window.innerHeight)) or g.VIEW is 'thread'
+ return if Index.req or Conf['Index Mode'] isnt 'infinite' or ((d.body.scrollTop or doc.scrollTop) <= doc.scrollHeight - (300 + window.innerHeight)) or g.VIEW is 'thread'
pageNum = Index.getCurrentPage() + 1
return Index.endNotice() if pageNum >= Index.pagesNum
nodesPerPage = Index.threadsNumPerPage * 2
@@ -163,7 +164,7 @@ Index =
getCurrentPage: ->
+window.location.pathname.split('/')[2]
userPageNav: (pageNum) ->
- if Conf['Refreshed Navigation'] and Conf['Index Mode'] is 'paged'
+ if Conf['Refreshed Navigation'] and Conf['Index Mode'] isnt 'all pages'
Index.update pageNum
else
Index.pageNav pageNum
@@ -173,7 +174,7 @@ Index =
Index.pageLoad pageNum
pageLoad: (pageNum) ->
Index.currentPage = pageNum
- return if Conf['Index Mode'] isnt 'paged'
+ return if Conf['Index Mode'] is 'all pages'
Index.buildIndex()
Index.setPage()
Index.scrollToIndex()
@@ -186,7 +187,7 @@ Index =
getMaxPageNum: ->
Math.max 0, Index.getPagesNum() - 1
togglePagelist: ->
- Index.pagelist.hidden = Conf['Index Mode'] isnt 'paged'
+ Index.pagelist.hidden = Conf['Index Mode'] is 'all pages'
buildPagelist: ->
pagesRoot = $ '.pages', Index.pagelist
maxPageNum = Index.getMaxPageNum()
@@ -406,7 +407,7 @@ Index =
return
buildIndex: ->
- if Conf['Index Mode'] is 'paged'
+ if Conf['Index Mode'] isnt 'all pages'
pageNum = Index.getCurrentPage()
nodesPerPage = Index.threadsNumPerPage * 2
nodes = Index.sortedNodes[nodesPerPage * pageNum ... nodesPerPage * (pageNum + 1)]
@@ -444,7 +445,7 @@ Index =
<% } %>
Index.sort()
# Go to the last available page if we were past the limit.
- pageNum = Math.min pageNum, Index.getMaxPageNum() if Conf['Index Mode'] is 'paged'
+ pageNum = Math.min pageNum, Index.getMaxPageNum() if Conf['Index Mode'] isnt 'all pages'
Index.buildPagelist()
if Index.currentPage is pageNum
Index.buildIndex()
diff --git a/src/General/css/burichan.css b/src/General/css/burichan.css
index 976a043bc..8f4350347 100755
--- a/src/General/css/burichan.css
+++ b/src/General/css/burichan.css
@@ -18,10 +18,10 @@
:root.burichan #header-bar a, :root.burichan #header-bar #notifications a {
color: #34345C;
}
-:root.burichan #custom-board-list .current {
+:root.burichan.fixed #custom-board-list .current {
border-bottom: 1px solid rgba(30, 30, 255, 0.2);
}
-:root.burichan #custom-board-list .current:hover {
+:root.burichan.fixed #custom-board-list .current:hover {
border-bottom-color: rgba(255,0,0,0.2);
}
diff --git a/src/General/css/futaba.css b/src/General/css/futaba.css
index b50e52f11..845d948b2 100755
--- a/src/General/css/futaba.css
+++ b/src/General/css/futaba.css
@@ -18,10 +18,10 @@
:root.futaba #header-bar a, :root.futaba #notifications a {
color: #800000;
}
-:root.futaba #custom-board-list a.current {
+:root.futaba.fixed #custom-board-list a.current {
border-bottom: 1px solid rgba(178,0,0,0.2);
}
-:root.futaba #custom-board-list .current:hover {
+:root.futaba.fixed #custom-board-list .current:hover {
border-bottom-color: rgba(255,0,0,0.2);
}
diff --git a/src/General/css/photon.css b/src/General/css/photon.css
index 709166bae..0feb8a3ec 100755
--- a/src/General/css/photon.css
+++ b/src/General/css/photon.css
@@ -18,10 +18,10 @@
:root.photon #header-bar a, :root.photon #notifications a {
color: #FF6600;
}
-:root.photon #custom-board-list a.current {
+:root.photon.fixed #custom-board-list a.current {
border-bottom: 1px solid rgba(0,74,153,0.2);
}
-:root.photon #custom-board-list .current:hover {
+:root.photon.fixed #custom-board-list .current:hover {
border-bottom-color: rgba(255,51,0,0.2);
}
diff --git a/src/General/css/style.css b/src/General/css/style.css
index 4f9708b58..0dfb44d7d 100755
--- a/src/General/css/style.css
+++ b/src/General/css/style.css
@@ -164,6 +164,8 @@ div.center:not(.ad-cnt) {
#header-bar {
border-width: 0;
transition: all .1s .05s ease-in-out;
+}
+:root.fixed #header-bar {
box-shadow: -5px 1px 10px rgba(0, 0, 0, 0.20);
}
#custom-board-list .current {
diff --git a/src/General/css/tomorrow.css b/src/General/css/tomorrow.css
index 3acd7d4ca..3485475f6 100755
--- a/src/General/css/tomorrow.css
+++ b/src/General/css/tomorrow.css
@@ -15,10 +15,10 @@
:root.tomorrow #header-bar a, :root.tomorrow #notifications a {
color: #81A2BE;
}
-:root.tomorrow #custom-board-list a.current {
+:root.tomorrow.fixed #custom-board-list a.current {
border-bottom: 1px solid rgba(83,124,160,0.4);
}
-:root.tomorrow #custom-board-list .current:hover {
+:root.tomorrow.fixed #custom-board-list .current:hover {
border-bottom-color: rgba(95,137,172,0.4);
}
diff --git a/src/General/css/yotsuba-b.css b/src/General/css/yotsuba-b.css
index 2301743ef..c3cf4c8ee 100755
--- a/src/General/css/yotsuba-b.css
+++ b/src/General/css/yotsuba-b.css
@@ -18,10 +18,10 @@
:root.yotsuba-b #board-list a, :root.yotsuba-b #shortcuts a {
color: #34345C;
}
-:root.yotsuba-b #custom-board-list .current {
+:root.yotsuba-b.fixed #custom-board-list .current {
border-bottom: 1px solid rgba(30, 30, 255, 0.2);
}
-:root.yotsuba-b #custom-board-list .current:hover {
+:root.yotsuba-b.fixed #custom-board-list .current:hover {
border-bottom-color: rgba(255,0,0,0.2);
}
diff --git a/src/General/css/yotsuba.css b/src/General/css/yotsuba.css
index cd88892e8..0fd7b1c82 100755
--- a/src/General/css/yotsuba.css
+++ b/src/General/css/yotsuba.css
@@ -18,10 +18,10 @@
:root.yotsuba #board-list a, :root.yotsuba #shortcuts a {
color: #800000;
}
-:root.yotsuba #custom-board-list a.current {
+:root.yotsuba.fixed #custom-board-list a.current {
border-bottom: 1px solid rgba(178,0,0,0.2);
}
-:root.yotsuba #custom-board-list .current:hover {
+:root.yotsuba.fixed #custom-board-list .current:hover {
border-bottom-color: rgba(255,0,0,0.2);
}
diff --git a/src/Miscellaneous/Keybinds.coffee b/src/Miscellaneous/Keybinds.coffee
index 18e59f2ed..ca385b223 100755
--- a/src/Miscellaneous/Keybinds.coffee
+++ b/src/Miscellaneous/Keybinds.coffee
@@ -97,10 +97,10 @@ Keybinds =
when Conf['Open front page']
$.open "/#{g.BOARD}/"
when Conf['Next page']
- return unless g.VIEW is 'index' and Conf['Index Mode'] is 'paged'
+ return unless g.VIEW is 'index' and Conf['Index Mode'] isnt 'all pages'
$('.next button', Index.pagelist).click()
when Conf['Previous page']
- return unless g.VIEW is 'index' and Conf['Index Mode'] is 'paged'
+ return unless g.VIEW is 'index' and Conf['Index Mode'] isnt 'all pages'
$('.prev button', Index.pagelist).click()
when Conf['Search form']
Index.searchInput.focus()