| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  | <template> | 
					
						
							| 
									
										
										
										
											2024-11-01 10:37:08 +08:00
										 |  |  |  |   <div class="app-container" style="padding: 10px"> | 
					
						
							| 
									
										
										
										
											2024-10-29 16:27:05 +08:00
										 |  |  |  |     <div class="card-change" style="min-height: 80vh;"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |       <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" label-width="68px"> | 
					
						
							|  |  |  |  |         <el-form-item label="" prop="notificationName"> | 
					
						
							|  |  |  |  |           <el-input | 
					
						
							|  |  |  |  |             v-model="queryParams.notificationName" | 
					
						
							|  |  |  |  |             placeholder="请输入通知名称" | 
					
						
							|  |  |  |  |             clearable | 
					
						
							|  |  |  |  |             style="width: 240px;" | 
					
						
							|  |  |  |  |             @keyup.enter.native="handleQuery" | 
					
						
							|  |  |  |  |           /> | 
					
						
							|  |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  |         <el-form-item label="" prop="notificationType"> | 
					
						
							|  |  |  |  |           <el-select v-model="queryParams.notificationType" placeholder="请选择通知类型" clearable style="width: 240px;"> | 
					
						
							|  |  |  |  |             <el-option label="到期提醒" value="到期提醒"></el-option> | 
					
						
							| 
									
										
										
										
											2024-09-15 23:51:27 +08:00
										 |  |  |  |             <el-option label="系统升级" value="系统升级"></el-option> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |             <!-- 添加其他选项 --> | 
					
						
							|  |  |  |  |           </el-select> | 
					
						
							|  |  |  |  |         </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-11-11 11:27:25 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |         <el-form-item label="" prop="templateStatus"> | 
					
						
							|  |  |  |  |           <el-select v-model="queryParams.templateStatus" placeholder="请选择通知状态" clearable style="width: 240px;"> | 
					
						
							|  |  |  |  |             <el-option label="启用" value="1"></el-option> | 
					
						
							|  |  |  |  |             <el-option label="禁用" value="0"></el-option> | 
					
						
							|  |  |  |  |             <!-- 添加其他选项 --> | 
					
						
							|  |  |  |  |           </el-select> | 
					
						
							|  |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         <el-form-item style="float: right"> | 
					
						
							|  |  |  |  |           <el-button type="primary" icon="el-icon-search"  @click="handleQuery">搜索</el-button> | 
					
						
							|  |  |  |  |                     <el-button icon="el-icon-refresh"  @click="resetQuery">重置</el-button> | 
					
						
							|  |  |  |  |           <el-button | 
					
						
							|  |  |  |  |             type="primary" | 
					
						
							|  |  |  |  |             @click="handleAdd" | 
					
						
							|  |  |  |  |             v-hasPermi="['system:notify:addTemplate']" | 
					
						
							|  |  |  |  |           >新增通知模板</el-button> | 
					
						
							|  |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  |       </el-form> | 
					
						
							| 
									
										
										
										
											2024-11-11 11:27:25 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       <div class="table_box"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       <el-table :data="tableData" style="width: 100%" border> | 
					
						
							|  |  |  |  |         <el-table-column align="center" type="index" label="序号"></el-table-column> | 
					
						
							|  |  |  |  |         <el-table-column align="center" prop="notificationName" label="通知名称"></el-table-column> | 
					
						
							|  |  |  |  |         <el-table-column align="center" prop="notificationType" label="通知类型"></el-table-column> | 
					
						
							|  |  |  |  |         <el-table-column align="center" prop="templateContent" label="模板内容"></el-table-column> | 
					
						
							|  |  |  |  |         <el-table-column align="center" prop="recipientRolesName" label="接收角色"> | 
					
						
							|  |  |  |  |         </el-table-column> | 
					
						
							|  |  |  |  |         <el-table-column align="center" prop="templateStatus" label="模板状态"> | 
					
						
							|  |  |  |  |           <template slot-scope="scope"> | 
					
						
							|  |  |  |  |             <el-switch v-model="scope.row.templateStatus" @change="clickSwitch(scope.row)" active-color="#13ce66" inactive-color="#ff4949"> | 
					
						
							|  |  |  |  |             </el-switch> | 
					
						
							|  |  |  |  |           </template> | 
					
						
							|  |  |  |  |         </el-table-column> | 
					
						
							|  |  |  |  |         <el-table-column align="center" prop="createName" label="创建人"></el-table-column> | 
					
						
							|  |  |  |  |         <el-table-column align="center" prop="createTime" label="创建时间"></el-table-column> | 
					
						
							|  |  |  |  |         <el-table-column align="center" label="操作"  width="200" class-name="small-padding fixed-width"> | 
					
						
							|  |  |  |  |           <template slot-scope="scope"> | 
					
						
							|  |  |  |  |             <el-button | 
					
						
							|  |  |  |  |               size="mini" | 
					
						
							|  |  |  |  |               type="text" | 
					
						
							|  |  |  |  |               icon="el-icon-view" | 
					
						
							|  |  |  |  |               @click="edit(scope.row)" | 
					
						
							|  |  |  |  |               v-hasPermi="['system:notify:editTemplate']" | 
					
						
							|  |  |  |  |             >编辑</el-button> | 
					
						
							|  |  |  |  |             <el-button | 
					
						
							|  |  |  |  |               size="mini" | 
					
						
							|  |  |  |  |               type="text" | 
					
						
							|  |  |  |  |               icon="el-icon-edit" | 
					
						
							|  |  |  |  |               @click="del(scope.row)" | 
					
						
							|  |  |  |  |               v-hasPermi="['system:notify:deleteTemplate']" | 
					
						
							|  |  |  |  |             >删除</el-button> | 
					
						
							|  |  |  |  |           </template> | 
					
						
							|  |  |  |  |         </el-table-column> | 
					
						
							|  |  |  |  |       </el-table> | 
					
						
							|  |  |  |  |       </div> | 
					
						
							|  |  |  |  |       <pagination | 
					
						
							|  |  |  |  |         v-show="total>0" | 
					
						
							|  |  |  |  |         :total="total" | 
					
						
							|  |  |  |  |         :page.sync="queryParams.page" | 
					
						
							|  |  |  |  |         :limit.sync="queryParams.pageSize" | 
					
						
							|  |  |  |  |         @pagination="getList" | 
					
						
							|  |  |  |  |       /> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     </div> | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-17 17:59:26 +08:00
										 |  |  |  |     <el-dialog :title="title" :close-on-click-modal="false" :visible.sync="open" width="32%" append-to-body> | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |       <el-form :model="form" ref="form" :rules="rules" label-width="120px"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |         <!-- 通知名称 --> | 
					
						
							| 
									
										
										
										
											2024-10-30 14:42:40 +08:00
										 |  |  |  |         <el-form-item label="通知名称" prop="notificationName" style="margin-left: -30px;"> | 
					
						
							| 
									
										
										
										
											2024-10-29 16:27:05 +08:00
										 |  |  |  |           <el-input v-model="form.notificationName" placeholder="请输入通知名称" style="width: 100%" ></el-input> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         <!-- 通知类型 --> | 
					
						
							| 
									
										
										
										
											2024-10-30 14:42:40 +08:00
										 |  |  |  |         <el-form-item label="通知类型" prop="notificationType" style="margin-left: -30px;"> | 
					
						
							| 
									
										
										
										
											2024-10-29 16:27:05 +08:00
										 |  |  |  |           <el-select v-model="form.notificationType" placeholder="请选择通知类型" style="width: 100%"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |             <el-option label="到期提醒" value="到期提醒"></el-option> | 
					
						
							| 
									
										
										
										
											2024-09-15 23:51:27 +08:00
										 |  |  |  |             <el-option label="系统升级" value="系统升级"></el-option> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |             <!-- 添加其他选项 --> | 
					
						
							|  |  |  |  |           </el-select> | 
					
						
							|  |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         <!-- 通知模板 --> | 
					
						
							| 
									
										
										
										
											2024-10-30 14:42:40 +08:00
										 |  |  |  |         <el-form-item label="通知模板" prop="templateContent" style="margin-left: -30px;"> | 
					
						
							| 
									
										
										
										
											2024-11-01 10:37:08 +08:00
										 |  |  |  |           <el-input type="textarea" v-model="form.templateContent"  :rows="3" placeholder="请输入通知内容" :maxlength="200" show-word-limit | 
					
						
							| 
									
										
										
										
											2024-10-29 16:27:05 +08:00
										 |  |  |  |                           style="width: 100%"></el-input> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |           <div> | 
					
						
							|  |  |  |  |             <span @click = "insertText('{系统到期日期}')">{系统到期日期}</span> | 
					
						
							|  |  |  |  |             <span @click = "insertText('{剩余交易流量}')">{剩余交易流量}</span> | 
					
						
							|  |  |  |  |             <span @click = "insertText('{系统服务费统计}')">{系统服务费统计}</span> | 
					
						
							|  |  |  |  |           </div> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         <!-- 接收角色 --> | 
					
						
							| 
									
										
										
										
											2024-10-30 14:42:40 +08:00
										 |  |  |  |         <el-form-item label="接收角色" prop="recipientRoles" style="margin-left: -30px;"> | 
					
						
							| 
									
										
										
										
											2024-11-01 08:26:04 +08:00
										 |  |  |  |           <el-select v-model="form.recipientRoles" multiple placeholder="请选择角色(可多选)" style="width: 100%"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |             <el-option v-for="item in dutyList1" :label="item.dutyName" :value="item.dutyId" ></el-option> | 
					
						
							|  |  |  |  |           </el-select> | 
					
						
							|  |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         <!-- 模板状态 --> | 
					
						
							| 
									
										
										
										
											2024-10-30 14:42:40 +08:00
										 |  |  |  |         <el-form-item label="模板状态" prop="templateStatus" style="margin-left: -30px;"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |           <el-switch v-model="form.templateStatus" active-color="#13ce66" inactive-color="#ff4949"></el-switch> | 
					
						
							|  |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         <!-- 发送条件 --> | 
					
						
							| 
									
										
										
										
											2024-10-30 14:42:40 +08:00
										 |  |  |  |         <el-form-item label="发送条件" style="margin-bottom: 10px; margin-left: -30px;"  prop="conditions"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |           <div v-for="(condition, index) in form.conditions" :key="index" class="condition-group" style="margin-bottom: 10px"> | 
					
						
							| 
									
										
										
										
											2024-10-29 16:27:05 +08:00
										 |  |  |  |             <el-select v-model="condition.field" placeholder="请选择条件" style="width: 45%;margin-right: 10px" @change="changeField(index)"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |               <el-option label="系统到期日期" value="系统到期日期"></el-option> | 
					
						
							|  |  |  |  |               <el-option label="剩余交易量" value="剩余交易量"></el-option> | 
					
						
							|  |  |  |  |               <el-option label="系统服务费统计" value="系统服务费统计"></el-option> | 
					
						
							|  |  |  |  |               <!-- 添加其他选项 --> | 
					
						
							|  |  |  |  |             </el-select> | 
					
						
							|  |  |  |  | <!--            <el-select v-if="condition.field == '系统到期日期'" v-model="condition.operator" placeholder="请选择" style="width: 100px;margin-right: 10px">--> | 
					
						
							|  |  |  |  | <!--              <el-option label="当日日期" value="当日日期"></el-option>--> | 
					
						
							|  |  |  |  | <!--              <el-option label="大于" value="大于"></el-option>--> | 
					
						
							|  |  |  |  | <!--              <el-option label="小于" value="小于"></el-option>--> | 
					
						
							|  |  |  |  | <!--              <!– 添加其他选项 –>--> | 
					
						
							|  |  |  |  | <!--            </el-select>--> | 
					
						
							| 
									
										
										
										
											2024-10-29 16:27:05 +08:00
										 |  |  |  |             <el-input v-model="condition.value" placeholder="请输入数值" style="width: 45%;margin-right: 10px"> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |               <template slot="append">{{ condition.field === '剩余交易量' || condition.field === '系统服务费统计' ? '万元' : '天' }}</template> | 
					
						
							|  |  |  |  |             </el-input> | 
					
						
							| 
									
										
										
										
											2024-10-29 16:27:05 +08:00
										 |  |  |  |             <!-- <el-button @click="removeCondition(index)" type="danger" icon="el-icon-delete" circle></el-button> --> | 
					
						
							|  |  |  |  |             <i @click="removeCondition(index)"  class="el-icon-delete" circle></i> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |           <el-button @click="addCondition" type="primary" icon="el-icon-plus">添加条件</el-button> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |         </el-form-item> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         <!-- 操作按钮 --> | 
					
						
							|  |  |  |  | <!--        <el-form-item>--> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <!--        </el-form-item>--> | 
					
						
							|  |  |  |  |       </el-form> | 
					
						
							|  |  |  |  |       <div style="display: flex; justify-content: center; align-items: center;margin-top: 30px"> | 
					
						
							| 
									
										
										
										
											2024-10-30 14:42:40 +08:00
										 |  |  |  |         <el-button @click="handleReset">取 消</el-button> | 
					
						
							|  |  |  |  |         <el-button style="margin-left: 30px;" type="primary" @click="handleSubmit('form')">保 存</el-button> | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |       </div> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     </el-dialog> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   </div> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <script> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | import {deleteAppApi, getAppListApi, saveAppApi, updateAppApi} from "@/api/sys/app"; | 
					
						
							|  |  |  |  | import {dutyList, selectyDutyIdsApi} from "@/api/duty/duty"; | 
					
						
							|  |  |  |  | import {getSysNotifyList, saveSysNotifyApi, updateSysNotifyApi} from "@/api/sys/sysNotify"; | 
					
						
							| 
									
										
										
										
											2024-08-27 10:18:27 +08:00
										 |  |  |  | import {deleteSysNotifyApi} from "../../../../api/sys/sysNotify"; | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | export default { | 
					
						
							|  |  |  |  |   name: "notify-mode", | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   data() { | 
					
						
							|  |  |  |  |     return { | 
					
						
							|  |  |  |  |       tableData: [], | 
					
						
							|  |  |  |  |       dutyList1: [], | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       form: { | 
					
						
							|  |  |  |  |         id: null, | 
					
						
							|  |  |  |  |         notificationName: '', | 
					
						
							|  |  |  |  |         notificationType: '', | 
					
						
							|  |  |  |  |         templateContent: '', | 
					
						
							|  |  |  |  |         recipientRoles: [], | 
					
						
							|  |  |  |  |         dutyList: [], | 
					
						
							|  |  |  |  |         templateStatus: true, | 
					
						
							|  |  |  |  |         type: 0, | 
					
						
							|  |  |  |  |         conditions: [ | 
					
						
							|  |  |  |  |         ] | 
					
						
							|  |  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |         // { field: '', operator: '', value: '' }
 | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     deviceInfo: { | 
					
						
							|  |  |  |  |         id: null,            // 自增id
 | 
					
						
							|  |  |  |  |         notificationName: '',//通知名称,字符长度最多100,不能为空
 | 
					
						
							|  |  |  |  |         notificationType: '',//通知类型
 | 
					
						
							|  |  |  |  |         templateContent: '',//模板内容
 | 
					
						
							|  |  |  |  |         recipientRoles: '', // 接收角色,字符长度最多255,不能为空
 | 
					
						
							|  |  |  |  |         templateStatus: true //模板状态
 | 
					
						
							|  |  |  |  |       }, | 
					
						
							|  |  |  |  |       dutyNames: {}, // 用于存储每行的 dutyNames
 | 
					
						
							|  |  |  |  |       // 是否显示弹出层
 | 
					
						
							|  |  |  |  |       open: false, | 
					
						
							|  |  |  |  |       title:"", | 
					
						
							|  |  |  |  |       total:0, | 
					
						
							|  |  |  |  |       // 查询参数
 | 
					
						
							|  |  |  |  |       queryParams: { | 
					
						
							|  |  |  |  |         page: 1, | 
					
						
							|  |  |  |  |         pageSize: 10, | 
					
						
							|  |  |  |  |         orgName:'', | 
					
						
							|  |  |  |  |         legalRepresentativeContact:'', | 
					
						
							|  |  |  |  |         appStatus:'', | 
					
						
							|  |  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |       rules: { | 
					
						
							|  |  |  |  |         notificationName: [ | 
					
						
							|  |  |  |  |           {required: true, message: '请输入通知名称', trigger: 'blur'}, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         notificationType: [ | 
					
						
							|  |  |  |  |           {required: true, message: '请选择通知类型', trigger: 'change'}, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         templateContent: [ | 
					
						
							|  |  |  |  |           {required: true, message: '请输入通知模版', trigger: 'blur'}, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         recipientRoles: [ | 
					
						
							|  |  |  |  |           {required: true, message: '请选择接收角色', trigger: 'change'}, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         templateStatus: [ | 
					
						
							|  |  |  |  |           {required: true, message: '请选择模版状态', trigger: 'change'}, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         conditions: [ | 
					
						
							|  |  |  |  |           {required: true, message: '请添加发送条件', trigger: 'change'}, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |     }; | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   created() { | 
					
						
							|  |  |  |  |     this.getList() | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   methods: { | 
					
						
							|  |  |  |  |     getList(){ | 
					
						
							|  |  |  |  |       getSysNotifyList(this.queryParams).then(res=>{ | 
					
						
							|  |  |  |  |         this.tableData = res.data.records; | 
					
						
							|  |  |  |  |         this.total = res.data.total | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     changeField(index){ | 
					
						
							|  |  |  |  |       console.log("123",this.form.conditions) | 
					
						
							|  |  |  |  |       console.log("123",index) | 
					
						
							|  |  |  |  |       let field = this.form.conditions[index].field | 
					
						
							|  |  |  |  |       let sum = 0 | 
					
						
							|  |  |  |  |       this.form.conditions.forEach(res=>{ | 
					
						
							|  |  |  |  |         if (res.field === field) { | 
					
						
							|  |  |  |  |           sum++ | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |       if (sum > 1) { | 
					
						
							|  |  |  |  |         this.form.conditions.splice(index, 1) | 
					
						
							|  |  |  |  |         this.$message({ | 
					
						
							|  |  |  |  |           type: 'info', | 
					
						
							|  |  |  |  |           message: '条件不允许重复!' | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     // submitForm(formName) {
 | 
					
						
							|  |  |  |  |     //   this.$refs[formName].validate(valid => {
 | 
					
						
							|  |  |  |  |     //     if (valid) {
 | 
					
						
							|  |  |  |  |     //       // 表单验证通过,可以提交数据
 | 
					
						
							|  |  |  |  |     //       // 示例:调用 API 提交数据
 | 
					
						
							|  |  |  |  |     //       this.submitDeviceInfo();
 | 
					
						
							|  |  |  |  |     //     } else {
 | 
					
						
							|  |  |  |  |     //       // 表单验证失败,不执行任何操作
 | 
					
						
							|  |  |  |  |     //       return false;
 | 
					
						
							|  |  |  |  |     //     }
 | 
					
						
							|  |  |  |  |     //   });
 | 
					
						
							|  |  |  |  |     // },
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |     handleSubmit(form) { | 
					
						
							|  |  |  |  |       this.$refs[form].validate(valid =>{ | 
					
						
							|  |  |  |  |         if (valid) { | 
					
						
							|  |  |  |  |           // 表单验证通过,可以提交数据
 | 
					
						
							|  |  |  |  |           if ( this.form.conditions.length === 0 || this.form.conditions[0].field == '') { | 
					
						
							|  |  |  |  |             this.form.conditions = '' | 
					
						
							|  |  |  |  |             this.$message({ | 
					
						
							|  |  |  |  |               type: 'error', | 
					
						
							|  |  |  |  |               message: '请选择发送条件!' | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             return | 
					
						
							|  |  |  |  |           } else { | 
					
						
							|  |  |  |  |             this.form.conditions = JSON.stringify(this.form.conditions) | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |           this.form.recipientRoles = JSON.stringify(this.form.recipientRoles) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           if (this.form.id) { | 
					
						
							|  |  |  |  |             updateSysNotifyApi(this.form).then(res=>{ | 
					
						
							|  |  |  |  |               if(res.code === 200) { | 
					
						
							|  |  |  |  |                 this.form.conditions = [] | 
					
						
							|  |  |  |  |                 this.getList() | 
					
						
							|  |  |  |  |                 this.open = false | 
					
						
							|  |  |  |  |               } | 
					
						
							|  |  |  |  |             }) | 
					
						
							|  |  |  |  |           }else { | 
					
						
							|  |  |  |  |             saveSysNotifyApi(this.form).then(res=>{ | 
					
						
							|  |  |  |  |               if(res.code === 200) { | 
					
						
							|  |  |  |  |                 this.form.conditions = [] | 
					
						
							|  |  |  |  |                 this.getList() | 
					
						
							|  |  |  |  |                 this.open = false | 
					
						
							|  |  |  |  |               } | 
					
						
							|  |  |  |  |             }) | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |         } else { | 
					
						
							|  |  |  |  |           // 表单验证失败,不执行任何操作
 | 
					
						
							|  |  |  |  |           return false | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |         // 在这里调用接口提交设备信息数据
 | 
					
						
							|  |  |  |  |       console.log('提交设备信息数据:', this.form); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |     handleReset() { | 
					
						
							|  |  |  |  |       this.open = false | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     handleQuery(){ | 
					
						
							|  |  |  |  |       this.getList() | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     resetQuery(){ | 
					
						
							|  |  |  |  |       this.queryParams = { | 
					
						
							|  |  |  |  |         page: 1, | 
					
						
							|  |  |  |  |         pageSize: 10, | 
					
						
							|  |  |  |  |         deviceName:'', | 
					
						
							|  |  |  |  |       }, | 
					
						
							|  |  |  |  |       this.getList() | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     handleAdd(e) { | 
					
						
							|  |  |  |  |       this.clean() | 
					
						
							|  |  |  |  |       this.open = true; | 
					
						
							|  |  |  |  |       this.getDutyList() | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-01 08:26:04 +08:00
										 |  |  |  |       this.title = "新增通知模板" | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |     edit(e) { | 
					
						
							|  |  |  |  |       this.clean() | 
					
						
							|  |  |  |  |       this.open = true; | 
					
						
							| 
									
										
										
										
											2024-11-01 08:26:04 +08:00
										 |  |  |  |       this.title = "修改通知模板" | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |       this.getDutyList() | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       this.form = e | 
					
						
							|  |  |  |  |       this.form.conditions = JSON.parse(this.form.conditions) | 
					
						
							|  |  |  |  |       if (!this.form.conditions) { | 
					
						
							|  |  |  |  |         this.form.conditions = [] | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |       this.form.recipientRoles = JSON.parse(this.form.recipientRoles) | 
					
						
							|  |  |  |  |       console.log('提交设备信息数据:', this.deviceInfo); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     del(e) { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       this.$confirm('此操作将永久删除该设备, 是否继续?', '提示', { | 
					
						
							|  |  |  |  |         confirmButtonText: '确定', | 
					
						
							|  |  |  |  |         cancelButtonText: '取消', | 
					
						
							|  |  |  |  |         type: 'warning' | 
					
						
							|  |  |  |  |       }).then(() => { | 
					
						
							| 
									
										
										
										
											2024-08-27 10:18:27 +08:00
										 |  |  |  |         deleteSysNotifyApi(e.id).then(res=>{ | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |           if (res.code == 200) { | 
					
						
							|  |  |  |  |             this.$message({ | 
					
						
							|  |  |  |  |               type: 'success', | 
					
						
							|  |  |  |  |               message: '删除成功!' | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             this.getList() | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       }).catch(() => { | 
					
						
							|  |  |  |  |         this.$message({ | 
					
						
							|  |  |  |  |           type: 'info', | 
					
						
							|  |  |  |  |           message: '已取消删除' | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     insertText(data) { | 
					
						
							|  |  |  |  |       this.form.templateContent = this.form.templateContent+data | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |       console.log("Test",this.form.templateContent+data) | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |     addCondition() { | 
					
						
							|  |  |  |  |       if (this.form.conditions.length > 2) { | 
					
						
							|  |  |  |  |         this.$message({ | 
					
						
							|  |  |  |  |           type: 'info', | 
					
						
							|  |  |  |  |           message: '最多添加3个条件!' | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         return | 
					
						
							|  |  |  |  |       }else { | 
					
						
							|  |  |  |  |         if (!this.form.conditions) { | 
					
						
							|  |  |  |  |           this.form.conditions = [] | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         this.form.conditions.push({ field: '', operator: '', value: '' }); | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     removeCondition(index) { | 
					
						
							|  |  |  |  |       this.form.conditions.splice(index, 1); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     getDutyList(){ | 
					
						
							|  |  |  |  |       // this.loading = true;
 | 
					
						
							|  |  |  |  |       let queryParams1={ | 
					
						
							|  |  |  |  |         page: 1, | 
					
						
							|  |  |  |  |         pageSize: 10000 | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |       dutyList(queryParams1).then(res => { | 
					
						
							|  |  |  |  |         this.dutyList1 = res.data.records; | 
					
						
							|  |  |  |  |         // this.total1 = res.data.total;
 | 
					
						
							|  |  |  |  |         // this.loading = false;
 | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     xunhuanbanduan() { | 
					
						
							|  |  |  |  |       this.dutyList.forEach(item => { | 
					
						
							|  |  |  |  |         this.form.recipientRoles.forEach(res=>{ | 
					
						
							|  |  |  |  |           if(item.id === this.form.dutyId) { | 
					
						
							|  |  |  |  |             this.form.dutyName = item.dutyName | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     clickSwitch(data){ | 
					
						
							|  |  |  |  |       updateSysNotifyApi(data).then(res=>{ | 
					
						
							|  |  |  |  |         if(res.code === 200) { | 
					
						
							|  |  |  |  |           this.$message({ | 
					
						
							|  |  |  |  |             type: 'info', | 
					
						
							|  |  |  |  |             message: '修改成功' | 
					
						
							|  |  |  |  |           }); | 
					
						
							|  |  |  |  |           this.getList() | 
					
						
							|  |  |  |  |           this.open = false | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     clean() { | 
					
						
							|  |  |  |  |       this.deviceInfo= { | 
					
						
							|  |  |  |  |         id: null,            // 自增id
 | 
					
						
							|  |  |  |  |         notificationName: '', | 
					
						
							|  |  |  |  |         notificationType: '', | 
					
						
							|  |  |  |  |         templateContent: '', | 
					
						
							|  |  |  |  |         recipientRoles: [], | 
					
						
							|  |  |  |  |         dutyList1: [], | 
					
						
							|  |  |  |  |         templateStatus: true, | 
					
						
							|  |  |  |  |         conditions: [ | 
					
						
							|  |  |  |  |           { field: '', operator: '', value: '' } | 
					
						
							|  |  |  |  |         ] | 
					
						
							|  |  |  |  |       }, | 
					
						
							|  |  |  |  |         this.form= { | 
					
						
							|  |  |  |  |         id: null, | 
					
						
							|  |  |  |  |           notificationName: '', | 
					
						
							|  |  |  |  |           notificationType: '', | 
					
						
							|  |  |  |  |           templateContent: '', | 
					
						
							|  |  |  |  |           recipientRoles: [], | 
					
						
							|  |  |  |  |           dutyList: [], | 
					
						
							|  |  |  |  |           templateStatus: true, | 
					
						
							|  |  |  |  |           type: 0, | 
					
						
							|  |  |  |  |           conditions: [ | 
					
						
							|  |  |  |  |           { field: '', operator: '', value: '' } | 
					
						
							|  |  |  |  |         ] | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-17 17:53:02 +08:00
										 |  |  |  |         if (this.$refs.form) { | 
					
						
							|  |  |  |  |           this.$refs.form.resetFields(); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | </script> | 
					
						
							|  |  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  |  | .common-dialog >>> .el-upload--picture-card { | 
					
						
							|  |  |  |  |   width: 60px; | 
					
						
							|  |  |  |  |   height: 50px; | 
					
						
							|  |  |  |  |   line-height: 60px; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-11 11:27:25 +08:00
										 |  |  |  | .table_box{ | 
					
						
							|  |  |  |  |   width: 100%; | 
					
						
							| 
									
										
										
										
											2024-11-12 08:54:54 +08:00
										 |  |  |  |   height: 70vh; | 
					
						
							| 
									
										
										
										
											2024-11-11 11:27:25 +08:00
										 |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-08-16 18:26:19 +08:00
										 |  |  |  | </style> | 
					
						
							|  |  |  |  | 
 |