mirror of
https://github.com/lrsjng/h5ai.git
synced 2025-05-24 03:57:08 -04:00
Begin to move all src javascript to es6. Add search/filter ignore case option.
This commit is contained in:
parent
f37e8e7b89
commit
7ec2bdf16a
58 changed files with 3546 additions and 3420 deletions
|
@ -1,84 +1,95 @@
|
|||
modulejs.define('ext/search', ['_', '$', 'core/event', 'core/location', 'core/resource', 'core/server', 'core/settings', 'core/util', 'model/item', 'view/view'], function (_, $, event, location, resource, server, allsettings, util, Item, view) {
|
||||
var settings = _.extend({
|
||||
enabled: false,
|
||||
advanced: false,
|
||||
debounceTime: 300
|
||||
}, allsettings.search);
|
||||
var template =
|
||||
'<div id="search" class="tool">' +
|
||||
'<img src="' + resource.image('search') + '" alt="search"/>' +
|
||||
'<input class="l10n_ph-search" type="text" value=""/>' +
|
||||
'</div>';
|
||||
var inputIsVisible = false;
|
||||
var prevPattern = '';
|
||||
var $search;
|
||||
var $input;
|
||||
const {jQuery: jq, _: lo} = require('../win');
|
||||
const event = require('../core/event');
|
||||
const location = require('../core/location');
|
||||
const resource = require('../core/resource');
|
||||
const server = require('../core/server');
|
||||
const allsettings = require('../core/settings');
|
||||
const util = require('../core/util');
|
||||
const Item = require('../model/item');
|
||||
const view = require('../view/view');
|
||||
|
||||
|
||||
function search(pattern) {
|
||||
pattern = pattern || '';
|
||||
if (pattern === prevPattern) {
|
||||
return;
|
||||
const settings = lo.extend({
|
||||
enabled: false,
|
||||
advanced: false,
|
||||
debounceTime: 300,
|
||||
ignorecase: true
|
||||
}, allsettings.search);
|
||||
const template =
|
||||
`<div id="search" class="tool">
|
||||
<img src="${resource.image('search')}" alt="search"/>
|
||||
<input class="l10n_ph-search" type="text" value=""/>
|
||||
</div>`;
|
||||
let inputIsVisible = false;
|
||||
let prevPattern = '';
|
||||
let $search;
|
||||
let $input;
|
||||
|
||||
|
||||
function search(pattern) {
|
||||
pattern = pattern || '';
|
||||
if (pattern === prevPattern) {
|
||||
return;
|
||||
}
|
||||
prevPattern = pattern;
|
||||
|
||||
if (!pattern) {
|
||||
view.setLocation();
|
||||
return;
|
||||
}
|
||||
|
||||
$search.addClass('pending');
|
||||
|
||||
server.request({
|
||||
action: 'get',
|
||||
search: {
|
||||
href: location.getAbsHref(),
|
||||
pattern,
|
||||
ignorecase: settings.ignorecase
|
||||
}
|
||||
prevPattern = pattern;
|
||||
}).then(response => {
|
||||
$search.removeClass('pending');
|
||||
view.setHint('noMatch');
|
||||
view.setItems(lo.map(response.search, item => {
|
||||
return Item.get(item);
|
||||
}));
|
||||
});
|
||||
}
|
||||
|
||||
if (!pattern) {
|
||||
view.setLocation();
|
||||
return;
|
||||
}
|
||||
function update() {
|
||||
if (inputIsVisible) {
|
||||
$search.addClass('active');
|
||||
$input.focus();
|
||||
search(util.parsePattern($input.val(), settings.advanced));
|
||||
} else {
|
||||
search();
|
||||
$search.removeClass('active');
|
||||
}
|
||||
}
|
||||
|
||||
$search.addClass('pending');
|
||||
function toggle() {
|
||||
inputIsVisible = !inputIsVisible;
|
||||
update();
|
||||
}
|
||||
|
||||
server.request({
|
||||
action: 'get',
|
||||
search: {
|
||||
href: location.getAbsHref(),
|
||||
pattern: pattern
|
||||
}
|
||||
}, function (response) {
|
||||
$search.removeClass('pending');
|
||||
view.setHint('noMatch');
|
||||
view.setItems(_.map(response.search, function (item) {
|
||||
return Item.get(item);
|
||||
}));
|
||||
});
|
||||
function reset() {
|
||||
inputIsVisible = false;
|
||||
$input.val('');
|
||||
update();
|
||||
}
|
||||
|
||||
function init() {
|
||||
if (!settings.enabled) {
|
||||
return;
|
||||
}
|
||||
|
||||
function update() {
|
||||
if (inputIsVisible) {
|
||||
$search.addClass('active');
|
||||
$input.focus();
|
||||
search(util.parsePattern($input.val(), settings.advanced));
|
||||
} else {
|
||||
search();
|
||||
$search.removeClass('active');
|
||||
}
|
||||
}
|
||||
$search = jq(template).appendTo('#toolbar');
|
||||
$input = $search.find('input');
|
||||
|
||||
function toggle() {
|
||||
inputIsVisible = !inputIsVisible;
|
||||
update();
|
||||
}
|
||||
|
||||
function reset() {
|
||||
inputIsVisible = false;
|
||||
$input.val('');
|
||||
update();
|
||||
}
|
||||
|
||||
function init() {
|
||||
if (!settings.enabled) {
|
||||
return;
|
||||
}
|
||||
|
||||
$search = $(template).appendTo('#toolbar');
|
||||
$input = $search.find('input');
|
||||
|
||||
$search.on('click', 'img', toggle);
|
||||
$input.on('keyup', _.debounce(update, settings.debounceTime, {trailing: true}));
|
||||
event.sub('location.changed', reset);
|
||||
}
|
||||
$search.on('click', 'img', toggle);
|
||||
$input.on('keyup', lo.debounce(update, settings.debounceTime, {trailing: true}));
|
||||
event.sub('location.changed', reset);
|
||||
}
|
||||
|
||||
|
||||
init();
|
||||
});
|
||||
init();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue