Clean code.

This commit is contained in:
Lars Jung 2016-06-24 18:18:44 +02:00
parent d8d7b997b5
commit 06b4d81a61

View file

@ -14,6 +14,7 @@ const settings = Object.assign({
binaryPrefix: false, binaryPrefix: false,
hideFolders: false, hideFolders: false,
hideParentFolder: false, hideParentFolder: false,
maxIconSize: 40,
modes, modes,
setParentFolderLabels: false, setParentFolderLabels: false,
sizes sizes
@ -21,6 +22,7 @@ const settings = Object.assign({
const sortedSizes = settings.sizes.sort((a, b) => a - b); const sortedSizes = settings.sizes.sort((a, b) => a - b);
const checkedModes = intersection(settings.modes, modes); const checkedModes = intersection(settings.modes, modes);
const storekey = 'view'; const storekey = 'view';
const elKey = '_h5ai_item';
const tplView = const tplView =
`<div id="view"> `<div id="view">
<ul id="items" class="clearfix"> <ul id="items" class="clearfix">
@ -48,11 +50,9 @@ const $items = $view.find('#items');
const $hint = $view.find('#view-hint'); const $hint = $view.find('#view-hint');
function cropSize(size, min, max) { const cropSize = (size, min, max) => Math.min(max, Math.max(min, size));
return Math.min(max, Math.max(min, size));
}
function createStyles(size) { const createStyles = size => {
const dsize = cropSize(size, 20, 80); const dsize = cropSize(size, 20, 80);
const gsize = cropSize(size, 40, 160); const gsize = cropSize(size, 40, 160);
const isize = cropSize(size, 80, 1000); const isize = cropSize(size, 80, 1000);
@ -76,15 +76,15 @@ function createStyles(size) {
]; ];
return rules.join('\n'); return rules.join('\n');
} };
function addCssStyles() { const addCssStyles = () => {
const styles = map(sortedSizes, size => createStyles(size)); const styles = map(sortedSizes, size => createStyles(size));
styles.push(`#view .icon img {max-width: ${settings.maxIconSize}px; max-height: ${settings.maxIconSize}px;}`); styles.push(`#view .icon img {max-width: ${settings.maxIconSize}px; max-height: ${settings.maxIconSize}px;}`);
jq('<style/>').text(styles.join('\n')).appendTo('head'); jq('<style/>').text(styles.join('\n')).appendTo('head');
} };
function set(mode, size) { const set = (mode, size) => {
const stored = store.get(storekey); const stored = store.get(storekey);
mode = mode || stored && stored.mode; mode = mode || stored && stored.mode;
@ -110,33 +110,17 @@ function set(mode, size) {
}); });
event.pub('view.mode.changed', mode, size); event.pub('view.mode.changed', mode, size);
} };
function getModes() { const getModes = () => checkedModes;
return checkedModes; const getMode = () => store.get(storekey).mode;
} const setMode = mode => set(mode, null);
function getSizes() { const getSizes = () => sortedSizes;
return sortedSizes; const getSize = () => store.get(storekey).size;
} const setSize = size => set(null, size);
function getMode() { const createHtml = item => {
return store.get(storekey).mode;
}
function setMode(mode) {
set(mode, null);
}
function getSize() {
return store.get(storekey).size;
}
function setSize(size) {
set(null, size);
}
function createHtml(item) {
const $html = jq(tplItem); const $html = jq(tplItem);
const $a = $html.find('a'); const $a = $html.find('a');
const $iconImg = $html.find('.icon img'); const $iconImg = $html.find('.icon img');
@ -148,6 +132,8 @@ function createHtml(item) {
.addClass(item.isFolder() ? 'folder' : 'file') .addClass(item.isFolder() ? 'folder' : 'file')
.data('item', item); .data('item', item);
$html[0][elKey] = item;
location.setLink($a, item); location.setLink($a, item);
$label.text(item.label).attr('title', item.label); $label.text(item.label).attr('title', item.label);
@ -170,21 +156,22 @@ function createHtml(item) {
$iconImg.attr('src', item.icon).attr('alt', item.type); $iconImg.attr('src', item.icon).attr('alt', item.type);
item.$view = $html; item.$view = $html;
item.elView = $html[0];
return $html; return $html;
} };
function onMouseenter(ev) { const onMouseenter = ev => {
const item = jq(ev.currentTarget).closest('.item').data('item'); const item = jq(ev.currentTarget).closest('.item').data('item');
event.pub('item.mouseenter', item); event.pub('item.mouseenter', item);
} };
function onMouseleave(ev) { const onMouseleave = ev => {
const item = jq(ev.currentTarget).closest('.item').data('item'); const item = jq(ev.currentTarget).closest('.item').data('item');
event.pub('item.mouseleave', item); event.pub('item.mouseleave', item);
} };
function checkHint() { const checkHint = () => {
const hasNoItems = $items.find('.item').not('.folder-parent').length === 0; const hasNoItems = $items.find('.item').not('.folder-parent').length === 0;
if (hasNoItems) { if (hasNoItems) {
@ -192,9 +179,9 @@ function checkHint() {
} else { } else {
$hint.hide(); $hint.hide();
} }
} };
function setItems(items) { const setItems = items => {
const removed = map($items.find('.item'), el => jq(el).data('item')); const removed = map($items.find('.item'), el => jq(el).data('item'));
$items.find('.item').remove(); $items.find('.item').remove();
@ -204,9 +191,9 @@ function setItems(items) {
base.$content.scrollLeft(0).scrollTop(0); base.$content.scrollLeft(0).scrollTop(0);
checkHint(); checkHint();
event.pub('view.changed', items, removed); event.pub('view.changed', items, removed);
} };
function changeItems(add, remove) { const changeItems = (add, remove) => {
each(add, item => { each(add, item => {
createHtml(item).hide().appendTo($items).fadeIn(400); createHtml(item).hide().appendTo($items).fadeIn(400);
}); });
@ -219,14 +206,14 @@ function changeItems(add, remove) {
checkHint(); checkHint();
event.pub('view.changed', add, remove); event.pub('view.changed', add, remove);
} };
function setHint(l10nKey) { const setHint = l10nKey => {
$hint.removeClass().addClass('l10n-' + l10nKey); $hint.removeClass().addClass('l10n-' + l10nKey);
checkHint(); checkHint();
} };
function onLocationChanged(item) { const onLocationChanged = item => {
if (!item) { if (!item) {
item = location.getItem(); item = location.getItem();
} }
@ -245,9 +232,9 @@ function onLocationChanged(item) {
setHint('empty'); setHint('empty');
setItems(items); setItems(items);
} };
function onLocationRefreshed(item, added, removed) { const onLocationRefreshed = (item, added, removed) => {
const add = []; const add = [];
each(added, child => { each(added, child => {
@ -258,9 +245,9 @@ function onLocationRefreshed(item, added, removed) {
setHint('empty'); setHint('empty');
changeItems(add, removed); changeItems(add, removed);
} };
function init() { const init = () => {
addCssStyles(); addCssStyles();
set(); set();
@ -275,7 +262,7 @@ function init() {
event.sub('location.changed', onLocationChanged); event.sub('location.changed', onLocationChanged);
event.sub('location.refreshed', onLocationRefreshed); event.sub('location.refreshed', onLocationRefreshed);
} };
init(); init();