新增“知识科普”栏目功能
parent
d5a2dda1b5
commit
b186df32f5
@ -0,0 +1,60 @@
|
|||||||
|
/*
|
||||||
|
* @Author: chris
|
||||||
|
* @Date: 2025-09-05 11:34:53
|
||||||
|
* @LastEditors: chris
|
||||||
|
* @LastEditTime: 2025-12-03 15:18:14
|
||||||
|
*/
|
||||||
|
import request from "@/utils/request";
|
||||||
|
|
||||||
|
// 查询科普知识列表
|
||||||
|
export function listKnowledge(query) {
|
||||||
|
return request({
|
||||||
|
url: "/business/article/list",
|
||||||
|
method: "get",
|
||||||
|
params: query,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查询科普知识详细
|
||||||
|
export function getKnowledge(id) {
|
||||||
|
return request({
|
||||||
|
url: "/business/article/" + id,
|
||||||
|
method: "get",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 新增科普知识
|
||||||
|
export function addKnowledge(data) {
|
||||||
|
return request({
|
||||||
|
url: "/business/article",
|
||||||
|
method: "post",
|
||||||
|
data,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 修改科普知识
|
||||||
|
export function updateKnowledge(data) {
|
||||||
|
return request({
|
||||||
|
url: "/business/article",
|
||||||
|
method: "put",
|
||||||
|
data,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 删除科普知识
|
||||||
|
export function delKnowledge(id) {
|
||||||
|
return request({
|
||||||
|
url: "/business/article/" + id,
|
||||||
|
method: "delete",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 导出科普知识数据
|
||||||
|
export function exportKnowledge(query) {
|
||||||
|
return request({
|
||||||
|
url: "/business/article/export",
|
||||||
|
method: "post",
|
||||||
|
params: query,
|
||||||
|
responseType: "blob",
|
||||||
|
});
|
||||||
|
}
|
||||||
Binary file not shown.
@ -0,0 +1,85 @@
|
|||||||
|
<!--
|
||||||
|
* @Author: chris
|
||||||
|
* @Date: 2025-08-08 16:17:48
|
||||||
|
* @LastEditors: chris
|
||||||
|
* @LastEditTime: 2025-12-03 14:51:46
|
||||||
|
-->
|
||||||
|
<template>
|
||||||
|
<common-action-toolbar
|
||||||
|
:buttons="buttons"
|
||||||
|
:selectedRows="props.selectedRows"
|
||||||
|
:columns="props.columns"
|
||||||
|
v-model:showSearch="showSearch"
|
||||||
|
@buttonClick="handleButtonClick"
|
||||||
|
@queryTable="handleQuery"
|
||||||
|
></common-action-toolbar>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import CommonActionToolbar from '@/components/CommonActionToolbar'
|
||||||
|
|
||||||
|
const props = defineProps({
|
||||||
|
selectedRows: { type: Array, required: true },
|
||||||
|
columns: { type: Array, required: true },
|
||||||
|
showSearch: { type: Boolean, required: true }
|
||||||
|
})
|
||||||
|
|
||||||
|
const emits = defineEmits(['add', 'update', 'delete', 'export', 'query', 'update:showSearch'])
|
||||||
|
const showSearch = computed({
|
||||||
|
get: () => props.showSearch,
|
||||||
|
set: (value) => emits('update:showSearch', value)
|
||||||
|
})
|
||||||
|
|
||||||
|
// 按钮配置
|
||||||
|
const buttons = reactive([
|
||||||
|
{
|
||||||
|
key: 'add',
|
||||||
|
text: '新增',
|
||||||
|
type: 'primary',
|
||||||
|
plain: true,
|
||||||
|
icon: 'Plus',
|
||||||
|
action: 'add'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'update',
|
||||||
|
text: '修改',
|
||||||
|
type: 'success',
|
||||||
|
plain: true,
|
||||||
|
icon: 'Edit',
|
||||||
|
action: 'update',
|
||||||
|
disabled: computed(() => props.selectedRows.length !== 1)
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'delete',
|
||||||
|
text: '删除',
|
||||||
|
type: 'danger',
|
||||||
|
plain: true,
|
||||||
|
icon: 'Delete',
|
||||||
|
action: 'delete',
|
||||||
|
disabled: computed(() => props.selectedRows.length === 0)
|
||||||
|
}
|
||||||
|
])
|
||||||
|
|
||||||
|
// 按钮点击处理
|
||||||
|
function handleButtonClick(action) {
|
||||||
|
switch (action) {
|
||||||
|
case 'add':
|
||||||
|
emits('add')
|
||||||
|
break
|
||||||
|
case 'update':
|
||||||
|
emits('update')
|
||||||
|
break
|
||||||
|
case 'delete':
|
||||||
|
emits('delete')
|
||||||
|
break
|
||||||
|
case 'export':
|
||||||
|
emits('export')
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查询处理
|
||||||
|
function handleQuery() {
|
||||||
|
emits('query')
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@ -0,0 +1,44 @@
|
|||||||
|
<!--
|
||||||
|
* @Author: chris
|
||||||
|
* @Date: 2025-08-08 16:17:37
|
||||||
|
* @LastEditors: chris
|
||||||
|
* @LastEditTime: 2025-12-03 15:30:34
|
||||||
|
-->
|
||||||
|
<template>
|
||||||
|
<el-form :model="queryParams" ref="queryRef" :inline="true" label-width="68px">
|
||||||
|
<el-form-item label="标题" prop="title">
|
||||||
|
<el-input v-model="queryParams.title" placeholder="标题" clearable style="width: 240px" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="类型" prop="type">
|
||||||
|
<el-select v-model="queryParams.type" placeholder="类型" clearable style="width: 240px">
|
||||||
|
<el-option v-for="dict in props.types" :key="dict.value" :label="dict.label" :value="dict.value" />
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
|
||||||
|
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
|
||||||
|
// 定义props
|
||||||
|
const props = defineProps({
|
||||||
|
queryParams: { type: Object, required: true },
|
||||||
|
types: { type: Array, required: true }
|
||||||
|
})
|
||||||
|
|
||||||
|
// 定义事件
|
||||||
|
const emits = defineEmits(['query', 'reset'])
|
||||||
|
|
||||||
|
// 搜索按钮操作
|
||||||
|
function handleQuery() {
|
||||||
|
emits('query')
|
||||||
|
}
|
||||||
|
|
||||||
|
// 重置按钮操作
|
||||||
|
function resetQuery() {
|
||||||
|
emits('reset')
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@ -0,0 +1,69 @@
|
|||||||
|
<!--
|
||||||
|
* @Author: chris
|
||||||
|
* @Date: 2025-08-08 16:17:54
|
||||||
|
* @LastEditors: chris
|
||||||
|
* @LastEditTime: 2025-12-08 16:37:07
|
||||||
|
-->
|
||||||
|
<template>
|
||||||
|
<el-table
|
||||||
|
v-loading="loading"
|
||||||
|
:data="list"
|
||||||
|
@selection-change="handleSelectionChange"
|
||||||
|
border
|
||||||
|
highlight-current-row
|
||||||
|
style="width: 100%"
|
||||||
|
>
|
||||||
|
<el-table-column type="selection" width="50" align="center" />
|
||||||
|
<el-table-column label="标题" align="center" prop="title" v-if="columns[0].visible" :show-overflow-tooltip="true" />
|
||||||
|
<el-table-column label="类型" align="center" prop="type" v-if="columns[1].visible">
|
||||||
|
<template #default="scope">
|
||||||
|
<span>{{ selectDictLabel(props.types, scope.row.type) }}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="内容" align="center" prop="content" :show-overflow-tooltip="true" v-if="columns[2].visible" />
|
||||||
|
<el-table-column label="创建时间" align="center" prop="createTime" v-if="columns[3].visible">
|
||||||
|
<template #default="scope">
|
||||||
|
<span>{{ parseTime(scope.row.createTime) }}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="操作" align="center" fixed="right">
|
||||||
|
<template #default="scope">
|
||||||
|
<!-- <el-tooltip content="查看" placement="top">
|
||||||
|
<el-button link type="primary" icon="Eye" @click="handleView(scope.row)" v-hasPermi="['business:orchard:query']"></el-button>
|
||||||
|
</el-tooltip> -->
|
||||||
|
<el-tooltip content="修改" placement="top">
|
||||||
|
<el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['business:orchard:edit']"></el-button>
|
||||||
|
</el-tooltip>
|
||||||
|
<el-tooltip content="删除" placement="top">
|
||||||
|
<el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['business:orchard:remove']"></el-button>
|
||||||
|
</el-tooltip>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import { parseTime, selectDictLabel } from '@/utils/ruoyi'
|
||||||
|
import { statusColorMap } from '../config'
|
||||||
|
|
||||||
|
const props = defineProps({
|
||||||
|
list: { type: Array, required: true },
|
||||||
|
loading: { type: Boolean, required: true },
|
||||||
|
columns: { type: Array, required: true },
|
||||||
|
types: { type: Array, required: true }
|
||||||
|
})
|
||||||
|
|
||||||
|
const emits = defineEmits(['selection-change', 'view', 'update', 'delete'])
|
||||||
|
|
||||||
|
function handleSelectionChange(selection) {
|
||||||
|
emits('selection-change', selection)
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleUpdate(row) {
|
||||||
|
emits('update', row)
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleDelete(row) {
|
||||||
|
emits('delete', row)
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@ -0,0 +1,25 @@
|
|||||||
|
/*
|
||||||
|
* @Author: chris
|
||||||
|
* @Date: 2025-09-05 10:12:41
|
||||||
|
* @LastEditors: chris
|
||||||
|
* @LastEditTime: 2025-12-08 14:55:43
|
||||||
|
*/
|
||||||
|
// 列配置
|
||||||
|
export const columnsConfig = [
|
||||||
|
{ key: 0, label: "标题", visible: true },
|
||||||
|
{ key: 1, label: "类型", visible: true },
|
||||||
|
{ key: 2, label: "正文", visible: true },
|
||||||
|
{ key: 3, label: "创建时间", visible: true },
|
||||||
|
];
|
||||||
|
|
||||||
|
// 状态颜色映射
|
||||||
|
export const statusColorMap = {
|
||||||
|
0: "success",
|
||||||
|
1: "danger",
|
||||||
|
};
|
||||||
|
|
||||||
|
export const defaultForm = {
|
||||||
|
title: "",
|
||||||
|
type: "", // 1: 种植技术 2:虫害知识 3:病害知识
|
||||||
|
content: "<p></p>",
|
||||||
|
};
|
||||||
Loading…
Reference in New Issue