新增“知识科普”栏目功能
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