Bring navigation (with right, left and enter) on material entries page. Supports going to next and previous page !

Also better indentation for js files (changed editorconfig for them).

Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
Thomas Citharel 2016-11-03 10:02:16 +01:00
parent 16ef7607f4
commit 5637a26e9a
12 changed files with 162 additions and 24 deletions

View file

@ -8,3 +8,7 @@ indent_style = space
indent_size = 4 indent_size = 4
trim_trailing_whitespace = true trim_trailing_whitespace = true
insert_final_newline = true insert_final_newline = true
[*.js]
indent_style = space
indent_size = 2

View file

@ -1,3 +1,6 @@
import Mousetrap from 'mousetrap';
/** Shortcuts **/ /** Shortcuts **/
/* Go to */ /* Go to */

View file

@ -1,7 +1,6 @@
import $ from 'jquery'; import $ from 'jquery';
import Mousetrap from 'mousetrap'; import './shortcuts/main';
import './shortcuts/main.js'; import './shortcuts/entry';
import './shortcuts/entry.js';
/* Allows inline call qr-code call */ /* Allows inline call qr-code call */
import jrQrcode from 'jr-qrcode'; // eslint-disable-line import jrQrcode from 'jr-qrcode'; // eslint-disable-line

View file

@ -1,7 +1,5 @@
/* jQuery */
import $ from 'jquery'; import $ from 'jquery';
import { initFilters, initExport } from '../../_global/js/tools';
import './shortcuts/main.js';
import './shortcuts/entry.js';
/* eslint-disable no-unused-vars */ /* eslint-disable no-unused-vars */
/* jquery has default scope */ /* jquery has default scope */
@ -9,8 +7,16 @@ import cookie from 'jquery.cookie';
import ui from 'jquery-ui-browserify'; import ui from 'jquery-ui-browserify';
/* eslint-enable no-unused-vars */ /* eslint-enable no-unused-vars */
/* Annotations */
import annotator from 'annotator'; import annotator from 'annotator';
/* Shortcuts */
import './shortcuts/main';
import './shortcuts/entry';
import '../../_global/js/shortcuts/main';
import '../../_global/js/shortcuts/entry';
/* Tools */
import { savePercent, retrievePercent } from '../../_global/js/tools'; import { savePercent, retrievePercent } from '../../_global/js/tools';
import toggleSaveLinkForm from './uiTools'; import toggleSaveLinkForm from './uiTools';

View file

@ -1,3 +1,6 @@
import Mousetrap from 'mousetrap';
import $ from 'jquery';
/* Article view */ /* Article view */
Mousetrap.bind('o', () => { Mousetrap.bind('o', () => {
$('div#article_toolbar ul.links li:nth-child(2) a')[0].click(); $('div#article_toolbar ul.links li:nth-child(2) a')[0].click();

View file

@ -1,8 +1,17 @@
/* jQuery */
import $ from 'jquery'; import $ from 'jquery';
/* Annotations */
import annotator from 'annotator'; import annotator from 'annotator';
/* Tools */
import { savePercent, retrievePercent, initFilters, initExport } from '../../_global/js/tools'; import { savePercent, retrievePercent, initFilters, initExport } from '../../_global/js/tools';
import './shortcuts/main.js';
import './shortcuts/entry.js'; /* Import shortcuts */
import './shortcuts/main';
import './shortcuts/entry';
import '../../_global/js/shortcuts/main';
import '../../_global/js/shortcuts/entry';
require('materialize'); // eslint-disable-line require('materialize'); // eslint-disable-line

View file

@ -1,3 +1,6 @@
import Mousetrap from 'mousetrap';
import $ from 'jquery';
/* open original article */ /* open original article */
Mousetrap.bind('o', () => { Mousetrap.bind('o', () => {
$('ul.side-nav li:nth-child(2) a i')[0].click(); $('ul.side-nav li:nth-child(2) a i')[0].click();

View file

@ -1,13 +1,71 @@
/* Actions */ import Mousetrap from 'mousetrap';
Mousetrap.bind('g n', () => { import $ from 'jquery';
function toggleFocus(cardToToogleFocus) {
if (cardToToogleFocus) {
$(cardToToogleFocus).toggleClass('z-depth-4');
}
}
let card;
let cardIndex;
let cardNumber;
let pagination;
$(document).ready(() => {
cardIndex = 0;
cardNumber = $('#content ul.data > li').length;
card = $('#content ul.data > li')[cardIndex];
pagination = $('.pagination');
/* If we come from next page */
if (window.location.hash === '#prev') {
cardIndex = cardNumber - 1;
card = $('ul.data > li')[cardIndex];
}
/* Focus current card */
toggleFocus(card);
/* Actions */
Mousetrap.bind('g n', () => {
$('#nav-btn-add').trigger('click'); $('#nav-btn-add').trigger('click');
}); });
Mousetrap.bind('esc', () => { Mousetrap.bind('esc', () => {
$('.close').trigger('click'); $('.close').trigger('click');
}); });
// Display the first element of the current view /* Select right card. If there's a next page, go to next page */
Mousetrap.bind('right', () => { Mousetrap.bind('right', () => {
$('ul.data li:first-child span.dot-ellipsis a')[0].click(); if (cardIndex >= 0 && cardIndex < cardNumber - 1) {
toggleFocus(card);
cardIndex += 1;
card = $('ul.data > li')[cardIndex];
toggleFocus(card);
return;
}
if (pagination != null && pagination.find('li.next') && cardIndex === cardNumber - 1) {
window.location.href = window.location.origin + $(pagination).find('li.next a').attr('href');
return;
}
});
/* Select previous card. If there's a previous page, go to next page */
Mousetrap.bind('left', () => {
if (cardIndex > 0 && cardIndex < cardNumber) {
toggleFocus(card);
cardIndex -= 1;
card = $('ul.data > li')[cardIndex];
toggleFocus(card);
return;
}
if (pagination !== null && $(pagination).find('li.prev') && cardIndex === 0) {
window.location.href = `${window.location.origin + $(pagination).find('li.prev a').attr('href')}#prev`;
return;
}
});
Mousetrap.bind('enter', () => {
window.location.href = window.location.origin + $(card).find('span.card-title a').attr('href');
});
}); });

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long