mirror of
https://github.com/LiteyukiStudio/LiteyukiBot.git
synced 2024-11-11 05:17:24 +08:00
104 lines
3.6 KiB
Vue
104 lines
3.6 KiB
Vue
<script setup lang="ts">
|
|
import {computed, ref} from 'vue'
|
|
import ItemCard from './ResItemCard.vue'
|
|
import ResPubWindow from "./ResPubWindow.vue";
|
|
import {getTextRef} from "./scripts/i18n";
|
|
import {RepoUrl} from "./scripts/statsApi";
|
|
|
|
// 从public/assets/resources.json加载插件
|
|
let filteredItems = computed(() => {
|
|
if (!search.value) {
|
|
return items.value.reverse()
|
|
}
|
|
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())
|
|
).reverse()
|
|
})
|
|
// 插件商店Nonebot
|
|
let items = ref([])
|
|
let search = ref('')
|
|
fetch("/resources.json")
|
|
.then(response => response.json())
|
|
.then(data => {
|
|
items.value = data
|
|
})
|
|
.catch(error => console.error(error))
|
|
// 列表倒序
|
|
|
|
const isPublishWindowOpen = ref(false)
|
|
|
|
let newRes = ref({
|
|
name: '',
|
|
desc: '',
|
|
author: '',
|
|
homepage: '',
|
|
link: '',
|
|
})
|
|
|
|
function openPublishWindow() {
|
|
isPublishWindowOpen.value = true
|
|
}
|
|
|
|
function closePublishWindow() {
|
|
isPublishWindowOpen.value = false
|
|
}
|
|
|
|
const submitForm = () => {
|
|
const title = encodeURI(`Resource: ${newRes.value.name}`)
|
|
let body = encodeURI(`---\nname: ${newRes.value.name}\ndesc: ${newRes.value.desc}\nauthor: ${newRes.value.author}\nhomepage: ${newRes.value.homepage}\nlink: ${newRes.value.link}\n---\n`)
|
|
const issueURL = `${RepoUrl}/issues/new?title=${title}&body=${body}`
|
|
window.open(issueURL, '_blank')
|
|
}
|
|
|
|
</script>
|
|
|
|
<template>
|
|
<div class="market">
|
|
<h1>{{ getTextRef('resourceStore') }}</h1>
|
|
<div class="search-box-div"><input class="item-search-box" type="text" :placeholder="getTextRef('search')" v-model="search"/></div>
|
|
<div class="store-tabs" style="display: flex">
|
|
<button class="store-button publish-button" @click="openPublishWindow">{{ getTextRef('publishRes') }}</button>
|
|
</div>
|
|
<div class="items">
|
|
<!-- 使用filteredItems来布局商品 -->
|
|
<ItemCard v-for="item in filteredItems" :key="item.id" :item="item"/>
|
|
</div>
|
|
<ResPubWindow class="pub-window" :is-visible="isPublishWindowOpen">
|
|
<h2>{{ getTextRef("publishRes") }}</h2>
|
|
<form @submit.prevent="submitForm">
|
|
<label for="name">{{ getTextRef("resName") }}</label>
|
|
<input type="text" id="name" v-model="newRes.name" :placeholder="getTextRef('resNameText')"/>
|
|
<label for="desc">{{ getTextRef("resDesc") }}</label>
|
|
<input type="text" id="desc" v-model="newRes.desc" :placeholder="getTextRef('resDescText')"/>
|
|
<label for="author">{{ getTextRef("resAuthor") }}</label>
|
|
<input type="text" id="author" v-model="newRes.author" :placeholder="getTextRef('resAuthorText')"/>
|
|
<label for="link">{{ getTextRef("resLink") }}</label>
|
|
<input type="text" id="link" v-model="newRes.link" :placeholder="getTextRef('resLinkText')"/>
|
|
<label for="homepage">{{ getTextRef("resHomepage") }}</label>
|
|
<input type="text" id="homepage" v-model="newRes.homepage" :placeholder="getTextRef('resHomepageText')"/>
|
|
<div class="pub-options" style="display: flex; justify-content: center">
|
|
<button class="pub-option close" type="button" @click="closePublishWindow">{{ getTextRef("closeButtonText") }}</button>
|
|
<button class="pub-option submit" type="submit">{{ getTextRef("submitButtonText") }}</button>
|
|
</div>
|
|
</form>
|
|
</ResPubWindow>
|
|
</div>
|
|
</template>
|
|
|
|
<style scoped>
|
|
h1 {
|
|
color: #00a6ff;
|
|
text-align: center;
|
|
font-weight: bold;
|
|
}
|
|
|
|
.items {
|
|
display: grid;
|
|
grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
|
|
gap: 10px;
|
|
}
|
|
|
|
|
|
</style> |