1
0
forked from bot/app

插件商店及资源商店新增搜索功能

This commit is contained in:
2024-07-14 13:38:25 +08:00
parent 605dd035d4
commit c36a925bb5
5 changed files with 88 additions and 18 deletions

View File

@ -1,14 +1,25 @@
<script setup lang="ts">
import {ref} from 'vue'
import {computed, ref} from 'vue'
import ItemCard from './ResItemCard.vue'
// 从public/assets/resources.json加载插件
let filteredItems = computed(() => {
if (!search.value) {
return items.value
}
return items.value.filter(item =>
item.name.toLowerCase().includes(search.value.toLowerCase()) ||
item.description.toLowerCase().includes(search.value.toLowerCase()) ||
item.author.toLowerCase().includes(search.value.toLowerCase())
)
})
// 插件商店Nonebot
let items = ref([])
let search = ref('')
fetch('/assets/resources.json')
.then(response => response.json())
.then(data => {
items.value = data
})
.catch(error => console.error(error))
@ -17,9 +28,14 @@ fetch('/assets/resources.json')
<template>
<div>
<h1>主题/资源商店</h1>
<!-- <div class="market">-->
<!--&lt;!&ndash; 布局商品&ndash;&gt;-->
<!-- <ItemCard v-for="item in [...items].reverse()" :key="item.id" :item="item" />-->
<!-- </div>-->
<input class="item-search-box" type="text" placeholder="搜索资源" v-model="search" />
<div class="market">
<!-- 布局商品-->
<ItemCard v-for="item in [...items].reverse()" :key="item.id" :item="item" />
<!-- 使用filteredItems来布局商品 -->
<ItemCard v-for="item in filteredItems" :key="item.id" :item="item"/>
</div>
</div>
</template>