支持插件详情展示

This commit is contained in:
muwoo
2021-12-10 17:48:08 +08:00
parent 6ee0b2a795
commit 6f9830a181
4 changed files with 84 additions and 11 deletions

View File

@@ -21,4 +21,15 @@ export default {
);
return res.data;
},
async getWorkerDetail() {
const res = await axios.get(
"https://gitee.com/monkeyWang/rubick-database/raw/master/plugins/worker.json"
);
return res.data;
},
async getPluginDetail(url: string) {
const res = await axios.get(url);
return res.data;
},
};

View File

@@ -4,7 +4,7 @@
<div class="list-item">
<a-list :grid="{ gutter: 16, column: 2 }" :data-source="list">
<template #renderItem="{ item, index }">
<a-list-item @click="visible=true">
<a-list-item @click="showDetail(item)">
<template #actions>
<a-button style="color: #ff4ea4;" type="text" :loading="item.isloading">
<CloudDownloadOutlined
@@ -47,15 +47,15 @@
</div>
<div class="info">
<img
src="https://static.91jkys.com/activity/img/2adb63c2e5d54dc1b26001958fcdb044.jpg"
:src="detail.logo"
class="plugin-icon"
/>
<div class="plugin-desc">
<div class="title">
备忘快贴
{{ detail.pluginName }}
</div>
<div class="desc">
适合每个人的专业图像编辑软件
{{ detail.description }}
</div>
<a-button shape="round" type="primary">
<template #icon>
@@ -67,6 +67,7 @@
</div>
</div>
</template>
<div v-html="content" class="home-page-container"></div>
</a-drawer>
</template>
@@ -79,6 +80,8 @@ import {
import { defineProps, ref } from "vue";
import { useStore } from "vuex";
import { message } from "ant-design-vue";
import MarkdownIt from "markdown-it";
import request from "../../../assets/request/index";
const store = useStore();
@@ -101,9 +104,25 @@ const downloadPlugin = async (plugin) => {
};
const visible = ref(false);
const detail = ref({});
const markdown = new MarkdownIt();
const content = ref("");
const showDetail = async (item) => {
visible.value = true;
detail.value = item;
let mdContent = "暂无内容";
if (item.homePage) {
mdContent = await request.getPluginDetail(item.homePage);
}
content.value = markdown.render(mdContent);
};
</script>
<style lang="less">
&::-webkit-scrollbar {
width: 0;
}
.panel-item {
margin: 20px 0;
.title {
@@ -174,4 +193,9 @@ const visible = ref(false);
}
}
}
.home-page-container {
img {
width: 100%;
}
}
</style>

View File

@@ -1,13 +1,49 @@
<template>
<div class="worker">
<PluginList
v-if="system && !!system.length"
@downloadSuccess="downloadSuccess"
title="生产效率"
:list="system"
/>
</div>
</template>
<script>
export default {
name: "worker"
};
<script setup>
import { ref, computed, onBeforeMount } from "vue";
import request from "../../../assets/request/index";
import PluginList from "./plugin-list.vue";
import { useStore } from "vuex";
const store = useStore();
const totalPlugins = computed(() => store.state.totalPlugins);
const data = ref([]);
onBeforeMount(async () => {
data.value = await request.getWorkerDetail();
});
const system = computed(() => {
const defaultData = data.value || [];
if (!defaultData.length) return [];
return defaultData.map((plugin) => {
let searchInfo = null;
totalPlugins.value.forEach((t) => {
if (t.name === plugin) {
searchInfo = t;
}
});
return searchInfo;
});
});
</script>
<style scoped>
<style lang="less">
.worker {
width: 100%;
height: 100vh;
overflow-x: hidden;
box-sizing: border-box;
}
</style>

View File

@@ -68,10 +68,12 @@ import { reactive, toRefs, computed } from "vue";
import { useStore } from "vuex";
import Finder from "./components/finder.vue";
import System from "./components/system.vue";
import Worker from "./components/worker.vue";
const Components = {
finder: Finder,
system: System,
worker: Worker,
};
const state = reactive({