提交代码

dev_xds
姜玉琦 2023-08-19 17:53:03 +08:00
parent 5210d86ae1
commit c601c709e6
12 changed files with 464 additions and 186 deletions

View File

@ -0,0 +1,34 @@
package com.ruoyi.common.enums;
/**
*
* @author ruoyi
*/
public enum WorkJournalismEnum {
DFB("1", "待发布"),
YFB("2", "已发布"),
YCH("3", "已撤回"),
YZD("1", "已置顶"),
BZD("0", "不置顶");
private final String code;
private final String info;
WorkJournalismEnum(String code, String info)
{
this.code = code;
this.info = info;
}
public String getCode()
{
return code;
}
public String getInfo()
{
return info;
}
}

View File

@ -9,6 +9,15 @@ export function listWorkJournalism(query) {
}) })
} }
// 查询集团新闻统计
export function findWorkJournalismGroupStatus(query) {
return request({
url: '/work/workJournalism/findWorkJournalismGroupStatus',
method: 'get',
params: query
})
}
// 查询集团新闻详细 // 查询集团新闻详细
export function getWorkJournalism(id) { export function getWorkJournalism(id) {
return request({ return request({

View File

@ -111,7 +111,6 @@ export default {
}, },
}, },
created() { created() {
debugger;
this.getCode(); this.getCode();
this.getCookie(); this.getCookie();
location.hash = "#/login?redirect=%2Findex"; location.hash = "#/login?redirect=%2Findex";

View File

@ -525,19 +525,23 @@ export default {
findGroupCount(this.queryParams).then((response) => { findGroupCount(this.queryParams).then((response) => {
if (response && response.data) { if (response && response.data) {
let sum = 0; let sum = 0;
this.tabs.dzg = "待整改0";
if (response.data.check0) { if (response.data.check0) {
sum += response.data.check0; sum += response.data.check0;
this.tabs.dzg = "待整改(" + response.data.check0 + ""; this.tabs.dzg = "待整改(" + response.data.check0 + "";
} }
this.tabs.dqr = "待复检0";
if (response.data.check1) { if (response.data.check1) {
sum += response.data.check1; sum += response.data.check1;
this.tabs.dqr = "待复检(" + response.data.check1 + ""; this.tabs.dqr = "待复检(" + response.data.check1 + "";
} }
this.tabs.ycl = "整改完成0";
if (response.data.check4) { if (response.data.check4) {
sum += response.data.check4; sum += response.data.check4;
this.tabs.ycl = "整改完成(" + response.data.check4 + ""; this.tabs.ycl = "整改完成(" + response.data.check4 + "";
} }
this.tabs.all = "全部数据(" + sum + ""; this.tabs.all = "全部数据(" + sum + "";
this.tabs.zgcs = "整改超时0";
if (response.data.check99) { if (response.data.check99) {
this.tabs.zgcs = "整改超时(" + response.data.check99 + ""; this.tabs.zgcs = "整改超时(" + response.data.check99 + "";
} }

View File

@ -519,19 +519,23 @@ export default {
findGroupCount(this.queryParams).then((response) => { findGroupCount(this.queryParams).then((response) => {
if (response && response.data) { if (response && response.data) {
let sum = 0; let sum = 0;
this.tabs.dzg = "待整改0";
if (response.data.check0) { if (response.data.check0) {
sum += response.data.check0; sum += response.data.check0;
this.tabs.dzg = "待整改(" + response.data.check0 + ""; this.tabs.dzg = "待整改(" + response.data.check0 + "";
} }
this.tabs.dqr = "待复检0";
if (response.data.check1) { if (response.data.check1) {
sum += response.data.check1; sum += response.data.check1;
this.tabs.dqr = "待复检(" + response.data.check1 + ""; this.tabs.dqr = "待复检(" + response.data.check1 + "";
} }
this.tabs.ycl = "整改完成0";
if (response.data.check4) { if (response.data.check4) {
sum += response.data.check4; sum += response.data.check4;
this.tabs.ycl = "整改完成(" + response.data.check4 + ""; this.tabs.ycl = "整改完成(" + response.data.check4 + "";
} }
this.tabs.all = "全部数据(" + sum + ""; this.tabs.all = "全部数据(" + sum + "";
this.tabs.zgcs = "整改超时0";
if (response.data.check99) { if (response.data.check99) {
this.tabs.zgcs = "整改超时(" + response.data.check99 + ""; this.tabs.zgcs = "整改超时(" + response.data.check99 + "";
} }

View File

@ -1,51 +1,22 @@
<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
<el-form-item label="标题" prop="title"> :model="queryParams"
ref="queryForm"
size="small"
:inline="true"
v-show="showSearch"
label-width="68px"
>
<el-form-item label="新闻标题" prop="title">
<el-input <el-input
v-model="queryParams.title" v-model="queryParams.title"
placeholder="请输入标题" placeholder="请输入新闻标题"
clearable clearable
@keyup.enter.native="handleQuery" @keyup.enter.native="handleQuery"
/> />
</el-form-item> </el-form-item>
<el-form-item label="状态标识" prop="statusFlag"> <el-form-item label="发布时间">
<el-select v-model="queryParams.statusFlag" placeholder="请选择状态标识" clearable>
<el-option
v-for="dict in dict.type.work_journalism_status"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="置顶标识" prop="topFlag">
<el-select v-model="queryParams.topFlag" placeholder="请选择置顶标识" clearable>
<el-option
v-for="dict in dict.type.work_journalism_top"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="排序" prop="sortNum">
<el-input
v-model="queryParams.sortNum"
placeholder="请输入排序"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="数据状态" prop="isDel">
<el-input
v-model="queryParams.isDel"
placeholder="请输入数据状态"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="创建时间">
<el-date-picker <el-date-picker
v-model="daterangeCreateTime" v-model="daterangeCreateTime"
style="width: 240px" style="width: 240px"
@ -57,7 +28,9 @@
></el-date-picker> ></el-date-picker>
</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
>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"></el-button> <el-button icon="el-icon-refresh" size="mini" @click="resetQuery"></el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -71,7 +44,8 @@
size="mini" size="mini"
@click="handleAdd" @click="handleAdd"
v-hasPermi="['work:workJournalism:add']" v-hasPermi="['work:workJournalism:add']"
>新增</el-button> >新增</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
@ -82,7 +56,8 @@
:disabled="single" :disabled="single"
@click="handleUpdate" @click="handleUpdate"
v-hasPermi="['work:workJournalism:edit']" v-hasPermi="['work:workJournalism:edit']"
>修改</el-button> >修改</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
@ -93,7 +68,8 @@
:disabled="multiple" :disabled="multiple"
@click="handleDelete" @click="handleDelete"
v-hasPermi="['work:workJournalism:remove']" v-hasPermi="['work:workJournalism:remove']"
>删除</el-button> >删除</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
@ -103,131 +79,169 @@
size="mini" size="mini"
@click="handleExport" @click="handleExport"
v-hasPermi="['work:workJournalism:export']" v-hasPermi="['work:workJournalism:export']"
>导出</el-button> >导出</el-button
>
</el-col> </el-col>
<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="workJournalismList" @selection-change="handleSelectionChange"> <el-tabs v-model="activeName" @tab-click="handleClick">
<el-table-column type="selection" width="55" align="center" /> <el-tab-pane :label="tabs.all" name="all"></el-tab-pane>
<el-table-column label="主键" align="center" prop="id" /> <el-tab-pane :label="tabs.yfb" name="yfb"></el-tab-pane>
<el-table-column label="标题" align="center" prop="title" /> <el-tab-pane :label="tabs.dfb" name="dfb"></el-tab-pane>
<el-table-column label="主图" align="center" prop="mainImage" width="100"> <el-table
<template slot-scope="scope"> v-loading="loading"
<image-preview :src="scope.row.mainImage" :width="50" :height="50"/> :data="workJournalismList"
</template> @selection-change="handleSelectionChange"
</el-table-column> >
<el-table-column label="简介" align="center" prop="intro" /> <el-table-column type="selection" width="55" align="center" />
<el-table-column label="内容" align="center" prop="content" /> <el-table-column
<el-table-column label="类型" align="center" prop="type" /> label="新闻标题"
<el-table-column label="来源" align="center" prop="source" /> align="center"
<el-table-column label="外部地址" align="center" prop="openUrl" /> prop="title"
<el-table-column label="阅读次数" align="center" prop="readNum" /> width="150"
<el-table-column label="状态标识" align="center" prop="statusFlag"> show-overflow-tooltip
<template slot-scope="scope"> />
<dict-tag :options="dict.type.work_journalism_status" :value="scope.row.statusFlag"/> <el-table-column label="新闻主图" align="center" prop="mainImage" width="200">
</template> <template slot-scope="scope">
</el-table-column> <el-image
<el-table-column label="置顶标识" align="center" prop="topFlag"> ref="preview"
<template slot-scope="scope"> style="width: 200px; height: 100px"
<dict-tag :options="dict.type.work_journalism_top" :value="scope.row.topFlag"/> :src="getImageUrl(scope.row.mainImage)"
</template> @click="onPreview(scope.row.mainImage)"
</el-table-column> >
<el-table-column label="相关附件" align="center" prop="files" /> </el-image>
<el-table-column label="排序" align="center" prop="sortNum" /> </template>
<el-table-column label="数据状态" align="center" prop="isDel"> </el-table-column>
<template slot-scope="scope"> <el-table-column label="简介" align="center" prop="intro" />
<dict-tag :options="dict.type.sys_common_isdel" :value="scope.row.isDel"/> <el-table-column label="新闻状态" align="center" prop="statusFlag">
</template> <template slot-scope="scope">
</el-table-column> <dict-tag
<el-table-column label="创建用户" align="center" prop="createUser" /> :options="dict.type.work_journalism_status"
<el-table-column label="备注" align="center" prop="remark" /> :value="scope.row.statusFlag"
<el-table-column label="操作" align="center" class-name="small-padding fixed-width"> />
<template slot-scope="scope"> </template>
<el-button </el-table-column>
<el-table-column label="置顶状态" align="center" prop="topFlag">
<template slot-scope="scope">
<dict-tag
:options="dict.type.work_journalism_top"
:value="scope.row.topFlag"
/>
</template>
</el-table-column>
<el-table-column
label="显示排序"
align="center"
prop="sortNum"
v-if="checkPermi(['work:workJournalism:edit'])"
>
<el-input-number
size="mini" size="mini"
type="text" v-model="scope.row.sortNum"
icon="el-icon-edit" :min="1"
@click="handleUpdate(scope.row)" :max="999"
v-hasPermi="['work:workJournalism:edit']" @change="setSort(scope.row, $event)"
>修改</el-button> ></el-input-number>
<el-button </el-table-column>
size="mini" <el-table-column label="数据状态" align="center" prop="isDel">
type="text" <template slot-scope="scope">
icon="el-icon-delete" <dict-tag :options="dict.type.sys_common_isdel" :value="scope.row.isDel" />
@click="handleDelete(scope.row)" </template>
v-hasPermi="['work:workJournalism:remove']" </el-table-column>
>删除</el-button> <el-table-column label="发布用户" align="center" prop="createUser" />
</template> <el-table-column label="发布时间" align="center" prop="updateTime" width="120">
</el-table-column> <template slot-scope="scope">
</el-table> <span>{{ parseTime(scope.row.updateTime, "{y}-{m}-{d} {h}:{i}") }}</span>
</template>
<pagination </el-table-column>
v-show="total>0" <el-table-column
:total="total" label="操作"
:page.sync="queryParams.pageNum" align="center"
:limit.sync="queryParams.pageSize" class-name="small-padding fixed-width"
@pagination="getList" >
/> <template slot-scope="scope">
<el-button
v-if="scope.row.statusFlag == '1' || scope.row.statusFlag == '3'"
size="mini"
type="text"
icon="el-icon-position"
@click="handleUpdateStatus(scope.row, 2)"
v-hasPermi="['work:workJournalism:edit']"
>发布</el-button
>
<el-button
v-if="scope.row.statusFlag == '2'"
size="mini"
type="text"
icon="el-icon-refresh-left"
@click="handleUpdateStatus(scope.row, 3)"
v-hasPermi="['work:workJournalism:edit']"
>撤回</el-button
>
<el-button
v-if="scope.row.topFlag == '0'"
size="mini"
type="text"
icon="el-icon-sort"
@click="handleUpdateTop(scope.row, 1)"
v-hasPermi="['work:workJournalism:edit']"
>置顶</el-button
>
<el-button
v-if="scope.row.topFlag == '1'"
size="mini"
type="text"
icon="el-icon-sort"
@click="handleUpdateTop(scope.row, 0)"
v-hasPermi="['work:workJournalism:edit']"
>取消置顶</el-button
>
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['work:workJournalism:edit']"
>修改</el-button
>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['work:workJournalism:remove']"
>删除</el-button
>
</template>
</el-table-column>
</el-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
</el-tabs>
<!-- 添加或修改集团新闻对话框 --> <!-- 添加或修改集团新闻对话框 -->
<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="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="mainImage"> <el-form-item label="新闻主图" prop="mainImage">
<image-upload v-model="form.mainImage"/> <image-upload v-model="form.mainImage" />
</el-form-item> </el-form-item>
<el-form-item label="简介" prop="intro"> <el-form-item label="简介" prop="intro">
<el-input v-model="form.intro" placeholder="请输入简介" /> <el-input v-model="form.intro" placeholder="请输入简介" />
</el-form-item> </el-form-item>
<el-form-item label="内容"> <el-form-item label="新闻内容">
<editor v-model="form.content" :min-height="192"/> <editor v-model="form.content" :min-height="192" />
</el-form-item> </el-form-item>
<el-form-item label="来源" prop="source"> <el-form-item label="相关文件" prop="files">
<el-input v-model="form.source" placeholder="请输入来源" /> <FileUpload @input="fileInput" :limit="9" v-model="files" />
</el-form-item>
<el-form-item label="外部地址" prop="openUrl">
<el-input v-model="form.openUrl" placeholder="请输入外部地址" />
</el-form-item>
<el-form-item label="阅读次数" prop="readNum">
<el-input v-model="form.readNum" placeholder="请输入阅读次数" />
</el-form-item>
<el-form-item label="状态标识" prop="statusFlag">
<el-select v-model="form.statusFlag" placeholder="请选择状态标识">
<el-option
v-for="dict in dict.type.work_journalism_status"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select>
</el-form-item>
<el-form-item label="置顶标识" prop="topFlag">
<el-select v-model="form.topFlag" placeholder="请选择置顶标识">
<el-option
v-for="dict in dict.type.work_journalism_top"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select>
</el-form-item>
<el-form-item label="相关附件" prop="files">
<el-input v-model="form.files" type="textarea" placeholder="请输入内容" />
</el-form-item>
<el-form-item label="排序" prop="sortNum">
<el-input v-model="form.sortNum" placeholder="请输入排序" />
</el-form-item>
<el-form-item label="数据状态" prop="isDel">
<el-input v-model="form.isDel" placeholder="请输入数据状态" />
</el-form-item>
<el-form-item label="创建用户" prop="createUser">
<el-input v-model="form.createUser" placeholder="请输入创建用户" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" placeholder="请输入备注" />
</el-form-item> </el-form-item>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
@ -235,17 +249,31 @@
<el-button @click="cancel"> </el-button> <el-button @click="cancel"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
<el-image-viewer v-if="showViewer" :on-close="closeViewer" :url-list="previewList" />
</div> </div>
</template> </template>
<script> <script>
import { listWorkJournalism, getWorkJournalism, delWorkJournalism, addWorkJournalism, updateWorkJournalism } from "@/api/work/workJournalism"; import {
listWorkJournalism,
getWorkJournalism,
delWorkJournalism,
addWorkJournalism,
updateWorkJournalism,
findWorkJournalismGroupStatus,
} from "@/api/work/workJournalism";
import ElImageViewer from "element-ui/packages/image/src/image-viewer";
import { checkPermi, checkRole } from "@/utils/permission"; //
export default { export default {
name: "WorkJournalism", name: "WorkJournalism",
dicts: ['work_journalism_status', 'work_journalism_top'], components: {
ElImageViewer,
},
dicts: ["work_journalism_status", "work_journalism_top", "sys_common_isdel"],
data() { data() {
return { return {
showViewer: false,
// //
loading: true, loading: true,
// //
@ -276,15 +304,40 @@ export default {
sortNum: null, sortNum: null,
isDel: null, isDel: null,
createTime: null, createTime: null,
activeName: null,
}, },
// //
form: {}, form: {},
// //
rules: { rules: {
} title: [
{ required: true, message: "请输入新闻标题", trigger: "blur" },
{ max: 20, message: "新闻标题最多30个字符", trigger: "blur" },
],
mainImage: [{ required: true, message: "请上传新闻主图", trigger: "blur" }],
intro: [
{ required: false, message: "请输入新闻简介", trigger: "blur" },
{ max: 200, message: "新闻简介最多200个字符", trigger: "blur" },
],
trainTitle: [
{ required: true, message: "请输入培训标题", trigger: "blur" },
{ max: 20, message: "培训标题最多20个字符", trigger: "blur" },
],
content: [{ required: true, message: "请输入新闻内容", trigger: "blur" }],
files: [{ required: false, message: "请上传相关附件", trigger: "blur" }],
},
tabs: {
all: "全部数据0",
yfb: "已发布0",
dfb: "待发布0",
},
previewList: [],
files: [],
activeName: "yfb",
}; };
}, },
created() { created() {
this.queryParams.activeName = this.activeName;
this.getList(); this.getList();
}, },
methods: { methods: {
@ -292,16 +345,53 @@ export default {
getList() { getList() {
this.loading = true; this.loading = true;
this.queryParams.params = {}; this.queryParams.params = {};
if (null != this.daterangeCreateTime && '' != this.daterangeCreateTime) { if (null != this.daterangeCreateTime && "" != this.daterangeCreateTime) {
this.queryParams.params["beginCreateTime"] = this.daterangeCreateTime[0]; this.queryParams.params["beginCreateTime"] = this.daterangeCreateTime[0];
this.queryParams.params["endCreateTime"] = this.daterangeCreateTime[1]; this.queryParams.params["endCreateTime"] = this.daterangeCreateTime[1];
} }
listWorkJournalism(this.queryParams).then(response => { this.queryCount();
listWorkJournalism(this.queryParams).then((response) => {
this.workJournalismList = response.rows; this.workJournalismList = response.rows;
this.total = response.total; this.total = response.total;
this.loading = false; this.loading = false;
}); });
}, },
queryCount() {
findWorkJournalismGroupStatus(this.queryParams).then((response) => {
if (response && response.data) {
let sum = 0;
if (response.data.status1) {
sum += response.data.status1;
}
if (response.data.status3) {
sum += response.data.status3;
}
this.tabs.dfb = "待发布(" + sum + "";
this.tabs.yfb = "已发布0";
if (response.data.status2) {
sum += response.data.status2;
this.tabs.yfb = "已发布(" + response.data.status2 + "";
}
this.tabs.all = "全部数据(" + sum + "";
}
});
},
getImageUrl(url) {
return process.env.VUE_APP_BASE_API + url + ".min.jpg";
},
onPreview(url) {
this.previewList = [];
this.previewList.push(process.env.VUE_APP_BASE_API + url);
this.showViewer = true;
},
closeViewer() {
this.showViewer = false;
},
//
handleClick() {
this.queryParams.activeName = this.activeName;
this.getList();
},
// //
cancel() { cancel() {
this.open = false; this.open = false;
@ -329,7 +419,7 @@ export default {
createTime: null, createTime: null,
updateBy: null, updateBy: null,
updateTime: null, updateTime: null,
remark: null remark: null,
}; };
this.resetForm("form"); this.resetForm("form");
}, },
@ -346,9 +436,9 @@ export default {
}, },
// //
handleSelectionChange(selection) { handleSelectionChange(selection) {
this.ids = selection.map(item => item.id) this.ids = selection.map((item) => item.id);
this.single = selection.length!==1 this.single = selection.length !== 1;
this.multiple = !selection.length this.multiple = !selection.length;
}, },
/** 新增按钮操作 */ /** 新增按钮操作 */
handleAdd() { handleAdd() {
@ -359,25 +449,58 @@ export default {
/** 修改按钮操作 */ /** 修改按钮操作 */
handleUpdate(row) { handleUpdate(row) {
this.reset(); this.reset();
const id = row.id || this.ids const id = row.id || this.ids;
getWorkJournalism(id).then(response => { getWorkJournalism(id).then((response) => {
this.form = response.data; this.form = response.data;
this.open = true; this.open = true;
this.title = "修改集团新闻"; this.title = "修改集团新闻";
}); });
}, },
//
handleUpdateStatus(row, status) {
const id = row.id || this.ids;
this.form.id = id;
this.form.statusFlag = status;
updateWorkJournalism(this.form).then((response) => {
this.$modal.msgSuccess("修改成功");
this.getList();
});
},
//
handleUpdateTop(row, top) {
const id = row.id || this.ids;
this.form.id = id;
this.form.topFlag = top;
updateWorkJournalism(this.form).then((response) => {
this.$modal.msgSuccess("修改成功");
this.getList();
});
},
//
setProjectSort(row, val) {
let param = {
id: row.id,
sortNum: val,
};
updateWorkJournalism(param).then((response) => {
this.$modal.msgSuccess("修改成功");
this.getList();
});
},
/** 提交按钮 */ /** 提交按钮 */
submitForm() { submitForm() {
this.$refs["form"].validate(valid => { this.$refs["form"].validate((valid) => {
if (valid) { if (valid) {
if (this.form.id != null) { if (this.form.id != null) {
updateWorkJournalism(this.form).then(response => { updateWorkJournalism(this.form).then((response) => {
this.$modal.msgSuccess("修改成功"); this.$modal.msgSuccess("修改成功");
this.open = false; this.open = false;
this.getList(); this.getList();
}); });
} else { } else {
addWorkJournalism(this.form).then(response => { this.form.type = 1;
this.form.source = 1;
addWorkJournalism(this.form).then((response) => {
this.$modal.msgSuccess("新增成功"); this.$modal.msgSuccess("新增成功");
this.open = false; this.open = false;
this.getList(); this.getList();
@ -389,19 +512,37 @@ export default {
/** 删除按钮操作 */ /** 删除按钮操作 */
handleDelete(row) { handleDelete(row) {
const ids = row.id || this.ids; const ids = row.id || this.ids;
this.$modal.confirm('是否确认删除集团新闻编号为"' + ids + '"的数据项?').then(function() { this.$modal
return delWorkJournalism(ids); .confirm('是否确认删除集团新闻编号为"' + ids + '"的数据项?')
}).then(() => { .then(function () {
this.getList(); return delWorkJournalism(ids);
this.$modal.msgSuccess("删除成功"); })
}).catch(() => {}); .then(() => {
this.getList();
this.$modal.msgSuccess("删除成功");
})
.catch(() => {});
},
//
fileInput(files) {
let file = "";
if (files.length > 0) {
files.forEach((item) => {
file += "," + item.url;
});
this.form.files = file.substring(1);
}
}, },
/** 导出按钮操作 */ /** 导出按钮操作 */
handleExport() { handleExport() {
this.download('work/workJournalism/export', { this.download(
...this.queryParams "work/workJournalism/export",
}, `workJournalism_${new Date().getTime()}.xlsx`) {
} ...this.queryParams,
} },
`workJournalism_${new Date().getTime()}.xlsx`
);
},
},
}; };
</script> </script>

View File

@ -46,6 +46,16 @@ public class WorkJournalismController extends BaseController
return getDataTable(list); return getDataTable(list);
} }
/**
*
*/
@PreAuthorize("@ss.hasPermi('work:workJournalism:list')")
@GetMapping("/findWorkJournalismGroupStatus")
public AjaxResult findWorkJournalismGroupStatus(WorkJournalism workJournalism)
{
return success(workJournalismService.findWorkJournalismGroupStatus(workJournalism));
}
/** /**
* *
*/ */

View File

@ -5,6 +5,8 @@ import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.annotation.Excel; import com.ruoyi.common.annotation.Excel;
import com.ruoyi.common.core.domain.BaseEntity; import com.ruoyi.common.core.domain.BaseEntity;
import java.util.Date;
/** /**
* work_journalism * work_journalism
* *
@ -74,6 +76,8 @@ public class WorkJournalism extends BaseEntity
@Excel(name = "创建用户") @Excel(name = "创建用户")
private String createUser; private String createUser;
private Date createDate;
public void setId(Long id) public void setId(Long id)
{ {
this.id = id; this.id = id;
@ -210,6 +214,14 @@ public class WorkJournalism extends BaseEntity
return createUser; return createUser;
} }
public Date getCreateDate() {
return createDate;
}
public void setCreateDate(Date createDate) {
this.createDate = createDate;
}
@Override @Override
public String toString() { public String toString() {
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)

View File

@ -1,6 +1,8 @@
package com.yanzhu.jh.work.mapper; package com.yanzhu.jh.work.mapper;
import java.util.List; import java.util.List;
import java.util.Map;
import com.yanzhu.jh.work.domain.WorkJournalism; import com.yanzhu.jh.work.domain.WorkJournalism;
/** /**
@ -27,6 +29,14 @@ public interface WorkJournalismMapper
*/ */
public List<WorkJournalism> selectWorkJournalismList(WorkJournalism workJournalism); public List<WorkJournalism> selectWorkJournalismList(WorkJournalism workJournalism);
/**
*
*
* @param workJournalism
* @return
*/
public List<Map<String,Object>> findWorkJournalismGroupStatus(WorkJournalism workJournalism);
/** /**
* *
* *

View File

@ -1,6 +1,8 @@
package com.yanzhu.jh.work.service; package com.yanzhu.jh.work.service;
import java.util.List; import java.util.List;
import java.util.Map;
import com.yanzhu.jh.work.domain.WorkJournalism; import com.yanzhu.jh.work.domain.WorkJournalism;
/** /**
@ -27,6 +29,14 @@ public interface IWorkJournalismService
*/ */
public List<WorkJournalism> selectWorkJournalismList(WorkJournalism workJournalism); public List<WorkJournalism> selectWorkJournalismList(WorkJournalism workJournalism);
/**
*
*
* @param workJournalism
* @return
*/
public Map<String,Object> findWorkJournalismGroupStatus(WorkJournalism workJournalism);
/** /**
* *
* *

View File

@ -1,6 +1,11 @@
package com.yanzhu.jh.work.service.impl; package com.yanzhu.jh.work.service.impl;
import java.util.Date;
import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map;
import com.ruoyi.common.enums.WorkJournalismEnum;
import com.ruoyi.common.utils.DateUtils; import com.ruoyi.common.utils.DateUtils;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@ -44,6 +49,22 @@ public class WorkJournalismServiceImpl implements IWorkJournalismService
return workJournalismMapper.selectWorkJournalismList(workJournalism); return workJournalismMapper.selectWorkJournalismList(workJournalism);
} }
/**
*
*
* @param workJournalism
* @return
*/
public Map<String,Object> findWorkJournalismGroupStatus(WorkJournalism workJournalism){
List<Map<String, Object>> dataList = workJournalismMapper.findWorkJournalismGroupStatus(workJournalism);
Map<String, Object> dataMap = new HashMap<>();
if(dataList!=null && dataList.size()>0){
for(Map<String, Object> map:dataList){
dataMap.put("status"+map.get("statusFlag"),map.get("total"));
}
}
return dataMap;
}
/** /**
* *
* *
@ -53,6 +74,8 @@ public class WorkJournalismServiceImpl implements IWorkJournalismService
@Override @Override
public int insertWorkJournalism(WorkJournalism workJournalism) public int insertWorkJournalism(WorkJournalism workJournalism)
{ {
workJournalism.setStatusFlag(WorkJournalismEnum.DFB.getCode());
workJournalism.setTopFlag(WorkJournalismEnum.BZD.getCode());
workJournalism.setCreateBy(SecurityUtils.getUsername()); workJournalism.setCreateBy(SecurityUtils.getUsername());
workJournalism.setCreateTime(DateUtils.getNowDate()); workJournalism.setCreateTime(DateUtils.getNowDate());
return workJournalismMapper.insertWorkJournalism(workJournalism); return workJournalismMapper.insertWorkJournalism(workJournalism);
@ -67,6 +90,10 @@ public class WorkJournalismServiceImpl implements IWorkJournalismService
@Override @Override
public int updateWorkJournalism(WorkJournalism workJournalism) public int updateWorkJournalism(WorkJournalism workJournalism)
{ {
if(WorkJournalismEnum.YFB.getCode().equals(workJournalism.getStatusFlag())){
workJournalism.setCreateUser(SecurityUtils.getLoginUser().getUser().getNickName());
workJournalism.setCreateDate(new Date());
}
workJournalism.setUpdateBy(SecurityUtils.getUsername()); workJournalism.setUpdateBy(SecurityUtils.getUsername());
workJournalism.setUpdateTime(DateUtils.getNowDate()); workJournalism.setUpdateTime(DateUtils.getNowDate());
return workJournalismMapper.updateWorkJournalism(workJournalism); return workJournalismMapper.updateWorkJournalism(workJournalism);

View File

@ -20,6 +20,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<result property="sortNum" column="sort_num" /> <result property="sortNum" column="sort_num" />
<result property="isDel" column="is_del" /> <result property="isDel" column="is_del" />
<result property="createUser" column="create_user" /> <result property="createUser" column="create_user" />
<result property="createDate" column="create_date" />
<result property="createBy" column="create_by" /> <result property="createBy" column="create_by" />
<result property="createTime" column="create_time" /> <result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" /> <result property="updateBy" column="update_by" />
@ -28,19 +29,33 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</resultMap> </resultMap>
<sql id="selectWorkJournalismVo"> <sql id="selectWorkJournalismVo">
select id, title, main_image, intro, content, type, source, open_url, read_num, status_flag, top_flag, files, sort_num, is_del, create_user, create_by, create_time, update_by, update_time, remark from work_journalism select id, title, main_image, intro, content, type, source, open_url, read_num, status_flag, top_flag, files, sort_num, is_del, create_user, create_date, create_by, create_time, update_by, update_time, remark from work_journalism
</sql> </sql>
<select id="selectWorkJournalismList" parameterType="WorkJournalism" resultMap="WorkJournalismResult"> <select id="selectWorkJournalismList" parameterType="WorkJournalism" resultMap="WorkJournalismResult">
<include refid="selectWorkJournalismVo"/> select id, title, main_image, intro, type, source, open_url, read_num, status_flag, top_flag, files, sort_num, is_del, create_user, create_date, create_by, create_time, update_by, update_time, remark from work_journalism
<where> <where>
and is_del=0
<if test="title != null and title != ''"> and title like concat('%', #{title}, '%')</if> <if test="title != null and title != ''"> and title like concat('%', #{title}, '%')</if>
<if test="statusFlag != null and statusFlag != ''"> and status_flag = #{statusFlag}</if> <if test="statusFlag != null and statusFlag != ''"> and status_flag = #{statusFlag}</if>
<if test="topFlag != null and topFlag != ''"> and top_flag = #{topFlag}</if> <if test="topFlag != null and topFlag != ''"> and top_flag = #{topFlag}</if>
<if test="sortNum != null "> and sort_num = #{sortNum}</if> <if test="sortNum != null "> and sort_num = #{sortNum}</if>
<if test="isDel != null "> and is_del = #{isDel}</if> <if test="isDel != null "> and is_del = #{isDel}</if>
<if test="params.beginCreateTime != null and params.beginCreateTime != '' and params.endCreateTime != null and params.endCreateTime != ''"> and create_time between #{params.beginCreateTime} and #{params.endCreateTime}</if> <if test="params.beginCreateTime != null and params.beginCreateTime != '' and params.endCreateTime != null and params.endCreateTime != ''"> and create_date between #{params.beginCreateTime} and #{params.endCreateTime}</if>
<if test='activeName == "dfb"'> and status_flag in (1,3)</if>
<if test='activeName == "yfb"'> and status_flag=2</if>
</where> </where>
order by top_flag desc, sort_num asc, create_date desc
</select>
<select id="findWorkJournalismGroupStatus" parameterType="WorkJournalism" resultType="map">
select status_flag as statusFlag, count(id) as total from work_journalism
<where>
and is_del=0
<if test="title != null and title != ''"> and title like concat('%', #{title}, '%')</if>
<if test="params.beginCreateTime != null and params.beginCreateTime != '' and params.endCreateTime != null and params.endCreateTime != ''"> and create_date between #{params.beginCreateTime} and #{params.endCreateTime}</if>
</where>
group by status_flag
</select> </select>
<select id="selectWorkJournalismById" parameterType="Long" resultMap="WorkJournalismResult"> <select id="selectWorkJournalismById" parameterType="Long" resultMap="WorkJournalismResult">
@ -65,6 +80,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="sortNum != null">sort_num,</if> <if test="sortNum != null">sort_num,</if>
<if test="isDel != null">is_del,</if> <if test="isDel != null">is_del,</if>
<if test="createUser != null">create_user,</if> <if test="createUser != null">create_user,</if>
<if test="createDate != null">create_date,</if>
<if test="createBy != null">create_by,</if> <if test="createBy != null">create_by,</if>
<if test="createTime != null">create_time,</if> <if test="createTime != null">create_time,</if>
<if test="updateBy != null">update_by,</if> <if test="updateBy != null">update_by,</if>
@ -86,6 +102,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="sortNum != null">#{sortNum},</if> <if test="sortNum != null">#{sortNum},</if>
<if test="isDel != null">#{isDel},</if> <if test="isDel != null">#{isDel},</if>
<if test="createUser != null">#{createUser},</if> <if test="createUser != null">#{createUser},</if>
<if test="createDate != null">#{createDate},</if>
<if test="createBy != null">#{createBy},</if> <if test="createBy != null">#{createBy},</if>
<if test="createTime != null">#{createTime},</if> <if test="createTime != null">#{createTime},</if>
<if test="updateBy != null">#{updateBy},</if> <if test="updateBy != null">#{updateBy},</if>
@ -111,6 +128,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="sortNum != null">sort_num = #{sortNum},</if> <if test="sortNum != null">sort_num = #{sortNum},</if>
<if test="isDel != null">is_del = #{isDel},</if> <if test="isDel != null">is_del = #{isDel},</if>
<if test="createUser != null">create_user = #{createUser},</if> <if test="createUser != null">create_user = #{createUser},</if>
<if test="createDate != null">create_date = #{createDate},</if>
<if test="createBy != null">create_by = #{createBy},</if> <if test="createBy != null">create_by = #{createBy},</if>
<if test="createTime != null">create_time = #{createTime},</if> <if test="createTime != null">create_time = #{createTime},</if>
<if test="updateBy != null">update_by = #{updateBy},</if> <if test="updateBy != null">update_by = #{updateBy},</if>