修改管理页面
This commit is contained in:
@ -26,3 +26,21 @@ export function getNewsDetail(params) {
|
|||||||
params,
|
params,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 保存新闻
|
||||||
|
export function updateNews(data) {
|
||||||
|
return request({
|
||||||
|
url: '/news/B8fpNxunbxj37x3VRcVz',
|
||||||
|
method: 'post',
|
||||||
|
data,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取新闻列表
|
||||||
|
export function saveDetail(data) {
|
||||||
|
return request({
|
||||||
|
url: '/news/VbxWW8EdJQGyWzJyvSrN',
|
||||||
|
method: 'post',
|
||||||
|
data,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|||||||
@ -3,8 +3,9 @@ import axios from 'axios';
|
|||||||
import { ref, reactive, onMounted } from 'vue';
|
import { ref, reactive, onMounted } from 'vue';
|
||||||
import { QuillEditor } from '@vueup/vue-quill'
|
import { QuillEditor } from '@vueup/vue-quill'
|
||||||
import '@vueup/vue-quill/dist/vue-quill.snow.css'
|
import '@vueup/vue-quill/dist/vue-quill.snow.css'
|
||||||
|
import {getNews,getNewsDetail,updateNews,saveDetail} from '@/api/index'
|
||||||
|
|
||||||
const API_BASE = window.config?.baseUrl
|
const baseURL = window.config?.baseUrl
|
||||||
|
|
||||||
// 新闻列表
|
// 新闻列表
|
||||||
const newsList = ref([]);
|
const newsList = ref([]);
|
||||||
@ -127,16 +128,15 @@ function imageHandler() {
|
|||||||
// ----------------- 获取新闻 -----------------
|
// ----------------- 获取新闻 -----------------
|
||||||
const fetchNews = async () => {
|
const fetchNews = async () => {
|
||||||
try {
|
try {
|
||||||
const res = await axios.get(`${API_BASE}/news/`, {
|
let query = {
|
||||||
params: {
|
status: statusFilter.value || undefined,
|
||||||
page: page.value,
|
page: page.value,
|
||||||
page_size: pageSize.value,
|
page_size: pageSize.value,
|
||||||
status: statusFilter.value || undefined,
|
}
|
||||||
},
|
let {code, data, pagination} = await getNews(query)
|
||||||
});
|
if (code === 0) {
|
||||||
if (res.data.code === 0) {
|
newsList.value = data;
|
||||||
newsList.value = res.data.data;
|
totalPages.value = pagination.total_pages;
|
||||||
totalPages.value = res.data.pagination.total_pages;
|
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
console.error("获取新闻失败", err);
|
console.error("获取新闻失败", err);
|
||||||
@ -147,9 +147,9 @@ const fetchNews = async () => {
|
|||||||
const saveNews = async () => {
|
const saveNews = async () => {
|
||||||
try {
|
try {
|
||||||
if (isEditing.value) {
|
if (isEditing.value) {
|
||||||
await axios.post(`${API_BASE}/news/B8fpNxunbxj37x3VRcVz`, editingNews);
|
await updateNews(editingNews);
|
||||||
} else {
|
} else {
|
||||||
await axios.post(`${API_BASE}/news/VbxWW8EdJQGyWzJyvSrN`, editingNews);
|
await saveDetail(editingNews);
|
||||||
}
|
}
|
||||||
showForm.value = false;
|
showForm.value = false;
|
||||||
fetchNews();
|
fetchNews();
|
||||||
@ -161,14 +161,12 @@ const saveNews = async () => {
|
|||||||
const editNews = async (news) => {
|
const editNews = async (news) => {
|
||||||
loading.value = true;
|
loading.value = true;
|
||||||
try {
|
try {
|
||||||
const res = await axios.get(`${API_BASE}/news/details`, {
|
let query = {
|
||||||
params: { slug: news.slug }
|
slug: news.slug,
|
||||||
});
|
}
|
||||||
|
let {code, data} = await getNewsDetail(query)
|
||||||
console.log(res.data)
|
if (code === 0) {
|
||||||
if (res.data.code === 0) {
|
Object.assign(editingNews, data);
|
||||||
console.log(res.data.data)
|
|
||||||
Object.assign(editingNews, res.data.data);
|
|
||||||
isEditing.value = true;
|
isEditing.value = true;
|
||||||
showForm.value = true;
|
showForm.value = true;
|
||||||
}
|
}
|
||||||
@ -185,6 +183,7 @@ const addNews = () => {
|
|||||||
content: "",
|
content: "",
|
||||||
status: "draft",
|
status: "draft",
|
||||||
slug: "",
|
slug: "",
|
||||||
|
datetime: null,
|
||||||
});
|
});
|
||||||
isEditing.value = false;
|
isEditing.value = false;
|
||||||
showForm.value = true;
|
showForm.value = true;
|
||||||
@ -222,7 +221,7 @@ function uploadImage(file) {
|
|||||||
const formData = new FormData();
|
const formData = new FormData();
|
||||||
formData.append('file', file);
|
formData.append('file', file);
|
||||||
|
|
||||||
fetch(`${API_BASE}/update/img`, {
|
fetch(`${baseURL}update/img`, {
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
body: formData,
|
body: formData,
|
||||||
})
|
})
|
||||||
@ -230,7 +229,7 @@ function uploadImage(file) {
|
|||||||
.then((data) => {
|
.then((data) => {
|
||||||
if (data.code === 0) {
|
if (data.code === 0) {
|
||||||
console.log(data)
|
console.log(data)
|
||||||
resolve(`${API_BASE}/download/img/${data.data}`);
|
resolve(`${baseURL}download/img/${data.data}`);
|
||||||
} else {
|
} else {
|
||||||
reject(data.msg);
|
reject(data.msg);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user