szurubooru/client/js/views/manual_page_view.js

122 lines
3.9 KiB
JavaScript
Raw Normal View History

2016-04-10 22:13:01 +02:00
'use strict';
const page = require('page');
2016-04-10 22:13:01 +02:00
const events = require('../events.js');
const keyboard = require('../util/keyboard.js');
2016-04-10 22:13:01 +02:00
const misc = require('../util/misc.js');
const views = require('../util/views.js');
function _formatUrl(url, page) {
return url.replace('{page}', page);
}
function _removeConsecutiveDuplicates(a) {
2016-04-10 22:13:01 +02:00
return a.filter((item, pos, ary) => {
return !pos || item != ary[pos - 1];
});
}
function _getVisiblePageNumbers(currentPage, totalPages) {
2016-04-14 20:54:00 +02:00
const threshold = 2;
let pagesVisible = [];
for (let i = 1; i <= threshold; i++) {
pagesVisible.push(i);
}
for (let i = totalPages - threshold; i <= totalPages; i++) {
pagesVisible.push(i);
}
for (let i = currentPage - threshold;
i <= currentPage + threshold;
i++) {
pagesVisible.push(i);
}
pagesVisible = pagesVisible.filter((item, pos, ary) => {
return item >= 1 && item <= totalPages;
});
pagesVisible = pagesVisible.sort((a, b) => { return a - b; });
pagesVisible = _removeConsecutiveDuplicates(pagesVisible);
2016-04-14 20:54:00 +02:00
return pagesVisible;
}
function _getPages(currentPage, pageNumbers, clientUrl) {
2016-04-14 20:54:00 +02:00
const pages = [];
let lastPage = 0;
for (let page of pageNumbers) {
if (page !== lastPage + 1) {
pages.push({ellipsis: true});
}
pages.push({
number: page,
link: _formatUrl(clientUrl, page),
2016-04-14 20:54:00 +02:00
active: currentPage === page,
});
lastPage = page;
}
return pages;
}
2016-04-10 22:13:01 +02:00
class ManualPageView {
constructor() {
this._holderTemplate = views.getTemplate('manual-pager');
this._navTemplate = views.getTemplate('manual-pager-nav');
2016-04-10 22:13:01 +02:00
}
render(ctx) {
const target = document.getElementById('content-holder');
const source = this._holderTemplate();
2016-04-10 22:13:01 +02:00
const pageContentHolder = source.querySelector('.page-content-holder');
2016-04-14 12:11:31 +02:00
const pageHeaderHolder = source.querySelector('.page-header-holder');
2016-04-10 22:13:01 +02:00
const pageNav = source.querySelector('.page-nav');
2016-04-14 12:11:31 +02:00
const currentPage = ctx.searchQuery.page;
2016-06-11 09:59:29 +02:00
ctx.headerContext.target = pageHeaderHolder;
ctx.headerRenderer.render(ctx.headerContext);
2016-04-10 22:13:01 +02:00
ctx.requestPage(currentPage).then(response => {
2016-06-11 09:59:29 +02:00
Object.assign(ctx.pageContext, response);
ctx.pageContext.target = pageContentHolder;
ctx.pageRenderer.render(ctx.pageContext);
2016-04-10 22:13:01 +02:00
const totalPages = Math.ceil(response.total / response.pageSize);
const pageNumbers = _getVisiblePageNumbers(currentPage, totalPages);
const pages = _getPages(currentPage, pageNumbers, ctx.clientUrl);
keyboard.bind(['a', 'left'], () => {
if (currentPage > 1) {
page.show(_formatUrl(ctx.clientUrl, currentPage - 1));
}
});
keyboard.bind(['d', 'right'], () => {
if (currentPage < totalPages) {
page.show(_formatUrl(ctx.clientUrl, currentPage + 1));
}
});
if (response.total) {
views.showView(pageNav, this._navTemplate({
prevLink: _formatUrl(ctx.clientUrl, currentPage - 1),
nextLink: _formatUrl(ctx.clientUrl, currentPage + 1),
prevLinkActive: currentPage > 1,
nextLinkActive: currentPage < totalPages,
pages: pages,
}));
}
views.listenToMessages(source);
2016-04-10 22:13:01 +02:00
views.showView(target, source);
2016-04-12 23:49:46 +02:00
if (response.total <= (currentPage - 1) * response.pageSize) {
events.notify(events.Info, 'No data to show');
}
2016-04-10 22:13:01 +02:00
}, response => {
views.listenToMessages(source);
2016-04-10 22:13:01 +02:00
views.showView(target, source);
events.notify(events.Error, response.description);
});
}
2016-04-12 23:49:46 +02:00
unrender() {
}
2016-04-10 22:13:01 +02:00
}
module.exports = ManualPageView;