Files
Yi.Admin/Yi.Bbs.Vue3/src/views/EditArticle.vue

392 lines
11 KiB
Vue
Raw Normal View History

2023-12-14 10:15:23 +08:00
<template>
2023-12-24 16:07:13 +08:00
<div style="width: 1300px">
2023-12-14 10:15:23 +08:00
<div class="body-div">
2023-12-24 16:07:13 +08:00
<el-form
label-width="120px"
:model="editForm"
label-position="left"
:rules="rules"
ref="ruleFormRef"
>
2023-12-14 10:15:23 +08:00
<el-form-item label="类型:">
<el-radio-group v-model="radio">
<el-radio-button label="discuss">主题</el-radio-button>
<el-radio-button label="article">文章</el-radio-button>
<el-radio-button label="plate">板块</el-radio-button>
<el-radio-button label="orther">其他</el-radio-button>
</el-radio-group>
</el-form-item>
2024-01-03 23:32:32 +08:00
<el-form-item label="权限:" v-if="radio == 'discuss'">
2023-12-14 10:15:23 +08:00
<el-radio-group v-model="perRadio">
<el-radio-button label="Public">公开</el-radio-button>
<el-radio-button label="Oneself">仅自己可见</el-radio-button>
<el-radio-button label="User">部分用户可见</el-radio-button>
</el-radio-group>
</el-form-item>
2023-12-24 16:07:13 +08:00
<el-form-item
label="可见用户:"
2024-01-03 23:32:32 +08:00
v-if="radio == 'discuss' && perRadio == 'User'"
2023-12-24 16:07:13 +08:00
>
<UserSelectInfo v-model="editForm.permissionUserIds" />
2023-12-14 10:15:23 +08:00
</el-form-item>
2023-12-24 16:07:13 +08:00
<el-form-item
2024-01-03 23:32:32 +08:00
v-if="radio == 'article'"
2023-12-24 16:07:13 +08:00
label="子文章名称:"
prop="name"
>
2023-12-14 10:15:23 +08:00
<el-input placeholder="请输入" v-model="editForm.name" />
</el-form-item>
<el-form-item v-else label="标题:" prop="title">
<el-input placeholder="请输入" v-model="editForm.title" />
</el-form-item>
<el-form-item label="描述:" prop="introduction">
<el-input placeholder="请输入" v-model="editForm.introduction" />
</el-form-item>
<el-form-item label="内容:" prop="content">
2023-12-24 16:07:13 +08:00
<MavonEdit
height="30rem"
v-model="editForm.content"
:codeStyle="codeStyle"
/>
2023-12-14 10:15:23 +08:00
</el-form-item>
2024-01-03 23:32:32 +08:00
<el-form-item label="封面:" v-if="radio == 'discuss'">
2023-12-24 16:07:13 +08:00
<!-- 主题封面选择 -->
<el-upload
class="avatar-uploader"
:action="fileUploadUrl"
:show-file-list="false"
:on-success="onSuccess"
>
<el-image
v-if="dialogImageUrl"
:src="getUrl(dialogImageUrl)"
style="width: 178px; height: 178px"
class="avatar"
/>
<el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon>
</el-upload>
2023-12-14 10:15:23 +08:00
</el-form-item>
<el-form-item label="标签:" prop="types">
<el-input placeholder="请输入" v-model="editForm.types" />
</el-form-item>
<el-form-item>
2023-12-24 16:07:13 +08:00
<el-button
@click="submit(ruleFormRef)"
class="submit-btn"
type="primary"
>提交</el-button
></el-form-item
>
2023-12-14 10:15:23 +08:00
</el-form>
2024-01-04 08:56:52 +08:00
<div class="import-content" v-show="radio == 'article'">
<div class="text">上传类型</div>
2024-01-03 23:32:32 +08:00
<el-select
v-model="currentType"
placeholder="请选择"
style="width: 120px"
>
<el-option
v-for="item in typeOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<el-button
type="primary"
:icon="Download"
:loading="importLoading"
@click="handleImport"
class="import-btn"
>导入文章</el-button
>
</div>
</div>
<!-- 文件弹框 -->
<div>
<input v-show="false" ref="fileRef" type="file" @change="getFile" />
2023-12-14 10:15:23 +08:00
</div>
</div>
</template>
<script setup>
import MavonEdit from "@/components/MavonEdit.vue";
2023-12-24 16:07:13 +08:00
import UserSelectInfo from "@/components/UserSelectInfo.vue";
2023-12-14 10:15:23 +08:00
import { ref, reactive, onMounted } from "vue";
import { useRoute, useRouter } from "vue-router";
2024-01-03 23:32:32 +08:00
import { Plus, Download } from "@element-plus/icons-vue";
2023-12-14 10:15:23 +08:00
import {
add as discussAdd,
update as discussUpdate,
get as discussGet,
} from "@/apis/discussApi.js";
import {
add as articleAdd,
update as articleUpdate,
get as articleGet,
2024-01-03 23:32:32 +08:00
importArticle,
2023-12-14 10:15:23 +08:00
} from "@/apis/articleApi.js";
//数据定义
const route = useRoute();
const router = useRouter();
2023-12-24 16:07:13 +08:00
const perRadio = ref("Public");
2023-12-14 10:15:23 +08:00
const radio = ref(route.query.artType);
const codeStyle = "atom-one-dark";
//封面完整显示的url
2023-12-24 16:07:13 +08:00
const fileUploadUrl = `${import.meta.env.VITE_APP_BASEAPI}/file`;
2023-12-14 10:15:23 +08:00
//封面的url
2023-12-24 16:07:13 +08:00
const dialogImageUrl = ref("");
2023-12-14 10:15:23 +08:00
//文件上传成功后
2023-12-24 16:07:13 +08:00
const onSuccess = (response) => {
dialogImageUrl.value = response.data[0].id;
};
2023-12-14 10:15:23 +08:00
//封面url
2023-12-24 16:07:13 +08:00
const getUrl = (str) => {
return `${import.meta.env.VITE_APP_BASEAPI}/file/${str}`;
};
2023-12-14 10:15:23 +08:00
//整个页面上的表单
const editForm = reactive({
title: "",
types: "",
introduction: "",
content: "",
name: "",
2023-12-24 16:07:13 +08:00
permissionUserIds: [],
2023-12-14 10:15:23 +08:00
});
//组装主题内容: 需要更新主题信息
2023-12-24 16:07:13 +08:00
const discuss = {};
2023-12-14 10:15:23 +08:00
//组装文章内容:需要添加的文章信息
2023-12-24 16:07:13 +08:00
const article = {};
2023-12-14 10:15:23 +08:00
//定义效验规则
const ruleFormRef = ref(null);
const rules = reactive({
title: [
{ required: true, message: "请输入标题", trigger: "blur" },
{ min: 3, max: 40, message: "长度 3 到 20", trigger: "blur" },
],
2023-12-24 16:07:13 +08:00
name: [{ required: true, message: "请输入子文章名称", trigger: "blur" }],
2023-12-14 10:15:23 +08:00
content: [
{ required: true, message: "请输入内容", trigger: "blur" },
{ min: 10, message: "长度 大于 10", trigger: "blur" },
],
});
//提交按钮,需要区分操作类型
const submit = async (formEl) => {
if (!formEl) return;
await formEl.validate(async (valid, fields) => {
if (valid) {
//dicuss主题处理
2024-01-03 23:32:32 +08:00
if (radio.value == "discuss") {
2023-12-14 10:15:23 +08:00
discuss.title = editForm.title;
discuss.types = editForm.types;
discuss.introduction = editForm.introduction;
discuss.content = editForm.content;
2023-12-24 16:07:13 +08:00
discuss.plateId = discuss.plateId ?? route.query.plateId;
discuss.cover = dialogImageUrl.value;
discuss.permissionType = perRadio.value;
2023-12-14 10:15:23 +08:00
2023-12-24 16:07:13 +08:00
discuss.permissionUserIds = editForm.permissionUserIds;
2023-12-14 10:15:23 +08:00
//主题创建
if (route.query.operType == "create") {
const response = await discussAdd(discuss);
ElMessage({
message: `[${discuss.title}]主题创建成功!`,
2023-12-24 16:07:13 +08:00
type: "success",
});
2023-12-14 10:15:23 +08:00
var routerPer = { path: `/article/${response.data.id}` };
router.push(routerPer);
}
//主题更新
else if (route.query.operType == "update") {
await discussUpdate(route.query.discussId, discuss);
ElMessage({
message: `[${discuss.title}]主题更新成功!`,
2023-12-24 16:07:13 +08:00
type: "success",
});
2023-12-14 10:15:23 +08:00
var routerPer = { path: `/article/${route.query.discussId}` };
router.push(routerPer);
}
}
//artcle文章处理
2024-01-03 23:32:32 +08:00
else if (radio.value == "article") {
2023-12-14 10:15:23 +08:00
//组装文章内容:需要添加的文章信息
article.content = editForm.content;
article.name = editForm.name;
article.discussId = route.query.discussId;
2023-12-24 16:07:13 +08:00
article.parentId = route.query.parentArticleId;
2023-12-14 10:15:23 +08:00
//文章创建
if (route.query.operType == "create") {
const response = await articleAdd(article);
ElMessage({
message: `[${article.name}]文章创建成功!`,
2023-12-24 16:07:13 +08:00
type: "success",
});
var routerPer = {
path: `/article/${route.query.discussId}/${response.data.id}`,
};
2023-12-14 10:15:23 +08:00
router.push(routerPer);
}
//文章更新
else if (route.query.operType == "update") {
await articleUpdate(route.query.articleId, article);
ElMessage({
message: `[${article.name}]文章更新成功!`,
2023-12-24 16:07:13 +08:00
type: "success",
});
var routerPer = {
path: `/article/${route.query.discussId}/${route.query.articleId}`,
};
2023-12-14 10:15:23 +08:00
router.push(routerPer);
}
}
//添加成功后跳转到该页面
// var routerPer = { path: `/discuss/${discuss.plateId}` };
// router.push(routerPer);
// ruleFormRef.value.resetFields();
// discuss.plateId = route.query.plateId;
}
});
};
onMounted(async () => {
//如果是更新操作,需要先查询
if (route.query.operType == "update") {
//更新主题
2024-01-03 23:32:32 +08:00
if (radio.value == "discuss") {
2023-12-14 10:15:23 +08:00
await loadDiscuss();
//更新文章
2024-01-03 23:32:32 +08:00
} else if (radio.value == "article") {
2023-12-14 10:15:23 +08:00
await loadArticle();
}
}
});
//加载主题
const loadDiscuss = async () => {
const response = await discussGet(route.query.discussId);
2023-12-24 16:07:13 +08:00
const res = response.data;
2023-12-14 10:15:23 +08:00
editForm.content = res.content;
editForm.title = res.title;
editForm.types = res.types;
editForm.introduction = res.introduction;
discuss.plateId = res.plateId;
2023-12-24 16:07:13 +08:00
dialogImageUrl.value = res.cover;
perRadio.value = res.permissionType;
editForm.permissionUserIds = res.permissionUserIds;
2023-12-14 10:15:23 +08:00
};
//加载文章
const loadArticle = async () => {
const response = await articleGet(route.query.articleId);
2023-12-24 16:07:13 +08:00
const res = response.data;
2023-12-14 10:15:23 +08:00
editForm.content = res.content;
editForm.name = res.name;
editForm.discussId = res.discussId;
};
2024-01-03 23:32:32 +08:00
// 导入
let importLoading = ref(false);
const fileRef = ref(null);
const handleImport = async () => {
fileRef.value.click();
};
const currentType = ref("Defalut");
const typeOptions = [
{
value: "Defalut",
label: "默认",
},
{
value: "Vuepress",
label: "Vuepress",
},
];
const getFile = async (e) => {
importLoading.value = true;
try {
let formDate = new FormData();
formDate.append("file", e.target.files[0]);
await importArticle(
{
discussId: route.query.discussId,
articleParentId: route.query.parentArticleId,
importType: currentType.value,
},
formDate
);
ElMessage({
message: `导入成功!`,
type: "success",
});
importLoading.value = false;
} catch (error) {
console.log(error, "error");
const { data } = error.response.data;
ElMessage.error(data.message);
importLoading.value = false;
}
};
2023-12-14 10:15:23 +08:00
</script>
<style scoped>
.submit-btn {
width: 40%;
}
.body-div {
2024-01-03 23:32:32 +08:00
position: relative;
2023-12-14 10:15:23 +08:00
min-height: 1000px;
background-color: #fff;
margin: 1.5rem;
padding: 1.5rem;
2024-01-03 23:32:32 +08:00
.import-content {
2024-01-04 08:56:52 +08:00
display: flex;
align-items: center;
2024-01-03 23:32:32 +08:00
position: absolute;
top: 1.5rem;
right: 1.5rem;
2024-01-04 08:56:52 +08:00
.text {
margin-right: 10px;
}
2024-01-03 23:32:32 +08:00
}
.import-btn {
margin-left: 10px;
}
2023-12-14 10:15:23 +08:00
}
2023-12-24 16:07:13 +08:00
.avatar-uploader >>> .el-upload {
2023-12-14 10:15:23 +08:00
border: 1px dashed var(--el-border-color);
border-radius: 6px;
cursor: pointer;
position: relative;
overflow: hidden;
transition: var(--el-transition-duration-fast);
}
2023-12-24 16:07:13 +08:00
.avatar-uploader >>> .el-upload:hover {
2023-12-14 10:15:23 +08:00
border-color: var(--el-color-primary);
}
.el-icon.avatar-uploader-icon {
font-size: 28px;
color: #8c939d;
width: 178px;
height: 178px;
text-align: center;
}
2023-12-24 16:07:13 +08:00
.el-upload {
2023-12-14 10:15:23 +08:00
}
2023-12-24 16:07:13 +08:00
</style>