1
0
forked from bot/app
LiteyukiBot/docs/.vuepress/components/PluginStore.vue

88 lines
2.4 KiB
Vue
Raw Normal View History

2024-04-20 04:10:20 +08:00
<script setup lang="ts">
import {computed, ref} from 'vue'
2024-06-26 13:52:04 +08:00
import ItemCard from './PluginItemCard.vue'
import ToggleSwitch from "./ToggleSwitch.vue";
2024-04-20 04:10:20 +08:00
let showLiteyukiPluginOnly = ref(false)
let filteredItems = computed(() => {
let filtered = items.value
if (search.value) {
filtered = filtered.filter(item =>
item.name.toLowerCase().includes(search.value.toLowerCase()) ||
item.desc.toLowerCase().includes(search.value.toLowerCase()) ||
item.author.toLowerCase().includes(search.value.toLowerCase()) ||
item.module_name.toLowerCase().includes(search.value.toLowerCase())
)
}
if (showLiteyukiPluginOnly.value) {
filtered = filtered.filter(item => item.is_liteyuki_plugin)
}
return filtered
})
2024-04-20 04:10:20 +08:00
// 插件商店Nonebot
let items = ref([])
let search = ref('')
// 从官方拉取
fetch("/assets/plugins.json")
.then(response => response.json())
.then(data => {
data.forEach(item => {
item.is_liteyuki_plugin = true
})
items.value = data
})
.catch(error => console.error(error))
//追加
2024-04-20 04:10:20 +08:00
fetch('https://registry.nonebot.dev/plugins.json')
.then(response => response.json())
.then(data => {
// 遍历data的每一项把is_official设为false
data.forEach(item => {
item.is_official = false
})
items.value = items.value.concat(data)
2024-04-20 04:10:20 +08:00
})
2024-04-20 04:10:20 +08:00
</script>
<template>
<div class="market">
2024-04-20 04:10:20 +08:00
<h1>插件商店</h1>
<p>内容来自轻雪商店及<a href="https://nonebot.dev/store/plugins">NoneBot插件商店</a>轻雪通过nonebot插件实现兼容NoneBot在此仅作引用具体请访问NoneBot插件商店</p>
<!-- 搜索框-->
<div class="search-box-div">
<input class="item-search-box" type="text" placeholder="搜索插件" v-model="search"/>
<ToggleSwitch v-model:modelValue="showLiteyukiPluginOnly" />仅轻雪插件
</div>
<div class="items">
<!-- 使用filteredItems来布局商品 -->
<ItemCard v-for="item in filteredItems" :key="item.id" :item="item"/>
2024-04-20 04:10:20 +08:00
</div>
</div>
</template>
<style scoped>
h1 {
color: #00a6ff;
text-align: center;
font-weight: bold;
}
.items {
2024-04-20 04:10:20 +08:00
display: grid;
grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
gap: 10px;
}
.search-box-div {
display: flex;
justify-content: center;
align-items: center;
margin-bottom: 10px;
}
.search-box-div input {
margin-right: 10px;
}
2024-04-20 04:10:20 +08:00
</style>