|
|
|
@ -1,6 +1,10 @@
|
|
|
|
<template>
|
|
|
|
<template>
|
|
|
|
<div class="app-container">
|
|
|
|
<div class="app-container">
|
|
|
|
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
|
|
|
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="100px">
|
|
|
|
|
|
|
|
<el-form-item label="下发对象" prop="deptId">
|
|
|
|
|
|
|
|
<treeselect v-model="queryParams.deptId" :options="deptOptions" :disable-branch-nodes="true" style="width:215px;"
|
|
|
|
|
|
|
|
placeholder="请选择下发对象"/>
|
|
|
|
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="标题" prop="title">
|
|
|
|
<el-form-item label="标题" prop="title">
|
|
|
|
<el-input
|
|
|
|
<el-input
|
|
|
|
v-model="queryParams.title"
|
|
|
|
v-model="queryParams.title"
|
|
|
|
@ -9,45 +13,20 @@
|
|
|
|
@keyup.enter.native="handleQuery"
|
|
|
|
@keyup.enter.native="handleQuery"
|
|
|
|
/>
|
|
|
|
/>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="图片" prop="picture">
|
|
|
|
<el-form-item label="级别(县/乡/村)" prop="sort">
|
|
|
|
<el-input
|
|
|
|
<el-select
|
|
|
|
v-model="queryParams.picture"
|
|
|
|
v-model="queryParams.sort"
|
|
|
|
placeholder="请输入图片"
|
|
|
|
placeholder="级别(县/乡/村)"
|
|
|
|
clearable
|
|
|
|
|
|
|
|
@keyup.enter.native="handleQuery"
|
|
|
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
<el-form-item label="级别(县/乡/村)" prop="leave">
|
|
|
|
|
|
|
|
<el-input
|
|
|
|
|
|
|
|
v-model="queryParams.leave"
|
|
|
|
|
|
|
|
placeholder="请输入级别(县/乡/村)"
|
|
|
|
|
|
|
|
clearable
|
|
|
|
|
|
|
|
@keyup.enter.native="handleQuery"
|
|
|
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
<el-form-item label="部门id" prop="deptId">
|
|
|
|
|
|
|
|
<el-input
|
|
|
|
|
|
|
|
v-model="queryParams.deptId"
|
|
|
|
|
|
|
|
placeholder="请输入部门id"
|
|
|
|
|
|
|
|
clearable
|
|
|
|
|
|
|
|
@keyup.enter.native="handleQuery"
|
|
|
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
<el-form-item label="所属网格" prop="deptName">
|
|
|
|
|
|
|
|
<el-input
|
|
|
|
|
|
|
|
v-model="queryParams.deptName"
|
|
|
|
|
|
|
|
placeholder="请输入所属网格"
|
|
|
|
|
|
|
|
clearable
|
|
|
|
clearable
|
|
|
|
@keyup.enter.native="handleQuery"
|
|
|
|
style="width:100%"
|
|
|
|
/>
|
|
|
|
>
|
|
|
|
</el-form-item>
|
|
|
|
<el-option
|
|
|
|
<el-form-item label="创建者ID" prop="userId">
|
|
|
|
v-for="dict in dict.type.szxc_leave"
|
|
|
|
<el-input
|
|
|
|
:key="dict.value"
|
|
|
|
v-model="queryParams.userId"
|
|
|
|
:label="dict.label"
|
|
|
|
placeholder="请输入创建者ID"
|
|
|
|
:value="dict.value"
|
|
|
|
clearable
|
|
|
|
|
|
|
|
@keyup.enter.native="handleQuery"
|
|
|
|
|
|
|
|
/>
|
|
|
|
/>
|
|
|
|
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item>
|
|
|
|
<el-form-item>
|
|
|
|
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
|
|
|
|
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
|
|
|
|
@ -101,17 +80,27 @@
|
|
|
|
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
|
|
|
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
|
|
|
</el-row>
|
|
|
|
</el-row>
|
|
|
|
|
|
|
|
|
|
|
|
<el-table v-loading="loading" :data="newsList" @selection-change="handleSelectionChange">
|
|
|
|
<el-table v-loading="loading" :data="newsList" @selection-change="handleSelectionChange" border>
|
|
|
|
<el-table-column type="selection" width="55" align="center" />
|
|
|
|
<el-table-column type="selection" width="55" align="center" />
|
|
|
|
<el-table-column label="id" align="center" prop="id" />
|
|
|
|
<el-table-column label="ID" align="center" prop="id" />
|
|
|
|
<el-table-column label="标题" align="center" prop="title" />
|
|
|
|
<el-table-column label="标题" align="center" prop="title" />
|
|
|
|
<el-table-column label="类型(公告/咨询)" align="center" prop="type" />
|
|
|
|
<el-table-column label="资讯类型" align="center" prop="type" >
|
|
|
|
<el-table-column label="图片" align="center" prop="picture" />
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
|
|
|
<dict-tag :options="dict.type.szxc_zx_type" :value="scope.row.type"/>
|
|
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
</el-table-column>
|
|
|
|
|
|
|
|
<el-table-column label="图片" align="center" prop="picture" >
|
|
|
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
|
|
|
<image-preview :src="scope.row.picture" :width="50" :height="50"/>
|
|
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="内容" align="center" prop="content" />
|
|
|
|
<el-table-column label="内容" align="center" prop="content" />
|
|
|
|
<el-table-column label="级别(县/乡/村)" align="center" prop="leave" />
|
|
|
|
<el-table-column label="级别(县/乡/村)" align="center" prop="sort" >
|
|
|
|
<el-table-column label="部门id" align="center" prop="deptId" />
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<el-table-column label="所属网格" align="center" prop="deptName" />
|
|
|
|
<dict-tag :options="dict.type.szxc_leave" :value="scope.row.sort"/>
|
|
|
|
<el-table-column label="创建者ID" align="center" prop="userId" />
|
|
|
|
</template>
|
|
|
|
|
|
|
|
</el-table-column>
|
|
|
|
|
|
|
|
<el-table-column label="下发对象" align="center" prop="deptName" />
|
|
|
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
|
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<el-button
|
|
|
|
<el-button
|
|
|
|
@ -141,28 +130,50 @@
|
|
|
|
/>
|
|
|
|
/>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 添加或修改公告资讯对话框 -->
|
|
|
|
<!-- 添加或修改公告资讯对话框 -->
|
|
|
|
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
|
|
|
|
<el-dialog :title="title" :visible.sync="open" width="800px" append-to-body>
|
|
|
|
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
|
|
|
|
<el-form ref="form" :model="form" :rules="rules" label-width="120px">
|
|
|
|
|
|
|
|
<el-form-item label="下发对象" prop="deptId">
|
|
|
|
|
|
|
|
<treeselect v-model="form.deptId" :options="deptOptions" :disable-branch-nodes="true"
|
|
|
|
|
|
|
|
placeholder="请选择下发对象" style="width:100%;" @select="selectedTree"/>
|
|
|
|
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="标题" prop="title">
|
|
|
|
<el-form-item label="标题" prop="title">
|
|
|
|
<el-input v-model="form.title" placeholder="请输入标题" />
|
|
|
|
<el-input v-model="form.title" placeholder="请输入标题" />
|
|
|
|
</el-form-item>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="图片" prop="picture">
|
|
|
|
<el-form-item label="级别(县/乡/村)" prop="sort">
|
|
|
|
<el-input v-model="form.picture" placeholder="请输入图片" />
|
|
|
|
<el-select
|
|
|
|
</el-form-item>
|
|
|
|
v-model="form.sort"
|
|
|
|
<el-form-item label="内容">
|
|
|
|
placeholder="级别(县/乡/村)"
|
|
|
|
<editor v-model="form.content" :min-height="192"/>
|
|
|
|
clearable
|
|
|
|
</el-form-item>
|
|
|
|
style="width:100%"
|
|
|
|
<el-form-item label="级别(县/乡/村)" prop="leave">
|
|
|
|
>
|
|
|
|
<el-input v-model="form.leave" placeholder="请输入级别(县/乡/村)" />
|
|
|
|
<el-option
|
|
|
|
|
|
|
|
v-for="dict in dict.type.szxc_leave"
|
|
|
|
|
|
|
|
:key="dict.value"
|
|
|
|
|
|
|
|
:label="dict.label"
|
|
|
|
|
|
|
|
:value="dict.value"
|
|
|
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="部门id" prop="deptId">
|
|
|
|
<el-form-item label="资讯类型" prop="type">
|
|
|
|
<el-input v-model="form.deptId" placeholder="请输入部门id" />
|
|
|
|
<el-select
|
|
|
|
|
|
|
|
v-model="form.type"
|
|
|
|
|
|
|
|
placeholder="资讯类型"
|
|
|
|
|
|
|
|
clearable
|
|
|
|
|
|
|
|
style="width:100%"
|
|
|
|
|
|
|
|
>
|
|
|
|
|
|
|
|
<el-option
|
|
|
|
|
|
|
|
v-for="dict in dict.type.szxc_zx_type"
|
|
|
|
|
|
|
|
:key="dict.value"
|
|
|
|
|
|
|
|
:label="dict.label"
|
|
|
|
|
|
|
|
:value="dict.value"
|
|
|
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="所属网格" prop="deptName">
|
|
|
|
<el-form-item label="图片" prop="picture">
|
|
|
|
<el-input v-model="form.deptName" placeholder="请输入所属网格" />
|
|
|
|
<image-upload v-model="form.picture"/>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="创建者ID" prop="userId">
|
|
|
|
<el-form-item label="内容">
|
|
|
|
<el-input v-model="form.userId" placeholder="请输入创建者ID" />
|
|
|
|
<editor v-model="form.content" :min-height="150"/>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form>
|
|
|
|
</el-form>
|
|
|
|
<div slot="footer" class="dialog-footer">
|
|
|
|
<div slot="footer" class="dialog-footer">
|
|
|
|
@ -175,9 +186,14 @@
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
<script>
|
|
|
|
import { listNews, getNews, delNews, addNews, updateNews } from "@/api/szxc/news";
|
|
|
|
import { listNews, getNews, delNews, addNews, updateNews } from "@/api/szxc/news";
|
|
|
|
|
|
|
|
import { deptTreeSelect } from "@/api/system/user";
|
|
|
|
|
|
|
|
import Treeselect from "@riophae/vue-treeselect";
|
|
|
|
|
|
|
|
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
|
|
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
export default {
|
|
|
|
name: "News",
|
|
|
|
name: "News",
|
|
|
|
|
|
|
|
components: { Treeselect },
|
|
|
|
|
|
|
|
dicts: ['szxc_leave', 'szxc_zx_type'],
|
|
|
|
data() {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
return {
|
|
|
|
// 遮罩层
|
|
|
|
// 遮罩层
|
|
|
|
@ -196,6 +212,8 @@ export default {
|
|
|
|
newsList: [],
|
|
|
|
newsList: [],
|
|
|
|
// 弹出层标题
|
|
|
|
// 弹出层标题
|
|
|
|
title: "",
|
|
|
|
title: "",
|
|
|
|
|
|
|
|
// 组织树选项
|
|
|
|
|
|
|
|
deptOptions: undefined,
|
|
|
|
// 是否显示弹出层
|
|
|
|
// 是否显示弹出层
|
|
|
|
open: false,
|
|
|
|
open: false,
|
|
|
|
// 查询参数
|
|
|
|
// 查询参数
|
|
|
|
@ -206,7 +224,7 @@ export default {
|
|
|
|
type: null,
|
|
|
|
type: null,
|
|
|
|
picture: null,
|
|
|
|
picture: null,
|
|
|
|
content: null,
|
|
|
|
content: null,
|
|
|
|
leave: null,
|
|
|
|
sort: null,
|
|
|
|
deptId: null,
|
|
|
|
deptId: null,
|
|
|
|
deptName: null,
|
|
|
|
deptName: null,
|
|
|
|
userId: null
|
|
|
|
userId: null
|
|
|
|
@ -226,8 +244,19 @@ export default {
|
|
|
|
},
|
|
|
|
},
|
|
|
|
created() {
|
|
|
|
created() {
|
|
|
|
this.getList();
|
|
|
|
this.getList();
|
|
|
|
|
|
|
|
this.getDeptTree();
|
|
|
|
},
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
methods: {
|
|
|
|
|
|
|
|
/** 查询组织下拉树结构 */
|
|
|
|
|
|
|
|
getDeptTree() {
|
|
|
|
|
|
|
|
deptTreeSelect().then(response => {
|
|
|
|
|
|
|
|
this.deptOptions = response.data;
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
selectedTree(node){
|
|
|
|
|
|
|
|
this.form.deptId = node.id;
|
|
|
|
|
|
|
|
this.form.deptName = node.label;
|
|
|
|
|
|
|
|
},
|
|
|
|
/** 查询公告资讯列表 */
|
|
|
|
/** 查询公告资讯列表 */
|
|
|
|
getList() {
|
|
|
|
getList() {
|
|
|
|
this.loading = true;
|
|
|
|
this.loading = true;
|
|
|
|
@ -250,7 +279,7 @@ export default {
|
|
|
|
type: null,
|
|
|
|
type: null,
|
|
|
|
picture: null,
|
|
|
|
picture: null,
|
|
|
|
content: null,
|
|
|
|
content: null,
|
|
|
|
leave: null,
|
|
|
|
sort: null,
|
|
|
|
createBy: null,
|
|
|
|
createBy: null,
|
|
|
|
createTime: null,
|
|
|
|
createTime: null,
|
|
|
|
updateBy: null,
|
|
|
|
updateBy: null,
|
|
|
|
|