diff options
| author | Mistivia <i@mistivia.com> | 2025-02-08 16:43:20 +0800 |
|---|---|---|
| committer | Mistivia <i@mistivia.com> | 2025-02-08 16:45:54 +0800 |
| commit | 5db7a8c78da09e7d5f7454ba019d39be04d8795e (patch) | |
| tree | 4264c2d4a1008fc65ffb04fd93226a8b6998f698 /src/control/search.js | |
| parent | ea9350a570fcb8011bb2678ad8b60486772e411d (diff) | |
version 0.1
Diffstat (limited to 'src/control/search.js')
| -rw-r--r-- | src/control/search.js | 69 |
1 files changed, 67 insertions, 2 deletions
diff --git a/src/control/search.js b/src/control/search.js index 93a9fc9..64e97f7 100644 --- a/src/control/search.js +++ b/src/control/search.js @@ -1,7 +1,72 @@ import { writable } from 'svelte/store'; +import { cardDb } from '../data/cardDb'; -let resultCards = writable([]); +let showingCards = writable([]); +let resultCards = []; + +let curVer = 0; +let curPage = 0; + +function showCards() { + showingCards.set(resultCards.slice(curPage * 10, curPage * 10 + 10)); +} + +function changeInput(query) { + curVer += 1; + query = query.split(' '); + setTimeout(()=>{doSearch(curVer, query)}, 0); +} + +function doSearch(ver, query) { + let result = []; + for (let key in cardDb) { + if (ver !== curVer) { + return; + } + let hit = true; + for (let word of query) { + let matched = false; + for (let name of cardDb[key].names) { + if (name.toLowerCase().includes(word.toLowerCase())) { + matched = true; + break; + } + } + if (!matched) { + hit = false; + break; + } + } + if (hit) { + result.push({"id": key, "name": cardDb[key].names[0]}) + } + } + if (ver !== curVer) return; + result.sort((a, b) => { + return cardDb[a.id].cid - cardDb[b.id].cid; + }); + resultCards = result; + curPage = 0; + showCards(); +} + +function onPrevPage() { + if (curPage > 0) { + curPage -= 1; + showCards(); + } +} + +function onNextPage() { + if (curPage < Math.floor(resultCards.length / 10) - 1) { + curPage += 1; + showCards(); + } +} export { - resultCards, + changeInput, + onPrevPage, + onNextPage, + showingCards, }; |
