mirror of
https://github.com/lrsjng/h5ai.git
synced 2025-05-27 21:44:22 -04:00
Clean code.
This commit is contained in:
parent
d8d7b997b5
commit
06b4d81a61
1 changed files with 38 additions and 51 deletions
|
@ -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();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue