<template> <div class="app-container"> <div class="filter-container"> <el-form ref="query" :model="installerdata" style="display: inline-block;"> <el-input v-model="installerdata.phone" placeholder="手机号" clearable style="width: 200px;" class="filter-item" @input="changeValue" /> <el-select v-model="installerdata.status" placeholder="状态" clearable class="filter-item" style="width: 130px" @change="selectOne"> <el-option v-for="item in calendarTypeOptions" :key="item" :label="item" :value="item" /> </el-select> <el-button v-waves class="filter-item" type="primary" icon="el-icon-search" @click="handleSubmit"> {{ $t('table.search') }} </el-button> </el-form> <el-button v-waves class="filter-item" type="primary" icon="el-icon-edit" @click="addinstaller">添加</el-button> <el-button v-if="total > 0 " v-waves :loading="downloadLoading" class="filter-item" type="primary" icon="el-icon-download" @click="handleDownload"> {{ $t('table.export') }} </el-button> </div> <el-table :key="tableKey" v-loading="loading" :data="instller" border fit highlight-current-rows> <el-table-column prop="username" label="用户名" width="150"> <template slot-scope="scope"> <span>{{ scope.row.username }}</span> </template> </el-table-column> <el-table-column prop="name" label="姓名" width="150"> <template slot-scope="scope"> <span>{{ scope.row.name }}</span> </template> </el-table-column> <el-table-column prop="phone" label="手机号"> <template slot-scope="scope"> <span @click="handleCopy(scope.row.phone,$event)">{{ scope.row.phone }}</span> </template> </el-table-column> <el-table-column prop="email" label="邮箱"> <template slot-scope="scope"> <span @click="handleCopy(scope.row.email,$event)">{{ scope.row.email }}</span> </template> </el-table-column> <el-table-column prop="addtime" label="创建时间" width="150"> <template slot-scope="scope"> <span>{{ scope.row.addtime | parseTime('{y}-{m}-{d} {h}:{i}') }}</span> </template> </el-table-column> <el-table-column prop="zip" label="状态" width="140"> <template slot-scope="scope"> <span :style="{color:( scope.row.status==1 ? '#67C23A' : '#909399' )}">{{ scope.row.status==1 ? '正常' : '禁用' }}</span> </template> </el-table-column> <el-table-column prop="zip" label="是否被删除" width="150"> <template slot-scope="scope"> <el-tag v-if="scope.row.delete==1" type="success" effect="dark">正常</el-tag> <el-popover v-if="scope.row.delete==2" width="160" trigger="hover" placement="top"> <p>将禁用以及删除用户人员恢复</p> <div style="text-align: right; margin: 0"> <el-button size="mini" type="text" @click="normalinstaller(scope.row.id)">恢复人员</el-button> </div> <el-button slot="reference" size="mini" type="danger">已删除</el-button> </el-popover> </template> </el-table-column> <el-table-column label="操作" width="150"> <template slot-scope="scope"> <el-popover width="160" trigger="click" placement="top"> <p>此删除,分丢弃废纸篓,和删除</p> <div style="text-align: right; margin: 0"> <el-button v-if="scope.row.delete==1" size="mini" type="text" @click="deleteInsrall(scope.row.id, 2)">丢弃废纸篓</el-button> <el-button type="text" size="mini" @click="deleteInsrall(scope.row.id, 1)">删除</el-button> </div> <el-button slot="reference" size="mini" type="danger">删除</el-button> </el-popover> <el-button slot="reference" size="mini" type="primary" @click="getUpInsrall(scope.row.id)">编辑</el-button> </template> </el-table-column> </el-table> <pagination v-show="total>0" :total="total" :page.sync="installerdata.page" :limit.sync="installerdata.limit" @pagination="installerlist" /> <el-dialog title="添加装维人员" :visible.sync="dialogFormVisible"> <el-form ref="addinstallerfrom" :model="addinstallerfrom" :rules="rules"> <el-form-item label="用户名" :label-width="formLabelWidth" prop="username"> <el-input v-model="addinstallerfrom.username" autocomplete="off"></el-input> </el-form-item> <el-form-item label="姓名" :label-width="formLabelWidth" prop="username"> <el-input v-model="addinstallerfrom.name" autocomplete="off"></el-input> </el-form-item> <el-form-item label="手机号" :label-width="formLabelWidth" prop="phone"> <el-input v-model="addinstallerfrom.phone" autocomplete="off"></el-input> </el-form-item> <el-form-item label="邮箱" :label-width="formLabelWidth" prop="email"> <el-input v-model="addinstallerfrom.email" autocomplete="off"></el-input> </el-form-item> <el-form-item label="密码" :label-width="formLabelWidth" prop="password"> <el-input v-model="addinstallerfrom.password" type="password" autocomplete="off"></el-input> </el-form-item> <el-form-item label="确认密码" :label-width="formLabelWidth" prop="ispassword"> <el-input v-model="addinstallerfrom.ispassword" type="password" autocomplete="off"></el-input> </el-form-item> </el-form> <div slot="footer" class="dialog-footer"> <el-button @click="dialogFormVisible = false">取 消</el-button> <el-button type="primary" @click="okdialogFormVisible('addinstallerfrom')">确 定</el-button> </div> </el-dialog> <!-- 编辑 --> <el-dialog title="编辑装维人员" :visible.sync="updialogFormVisible"> <el-form ref="addinstallerfrom" :model="upDatainstaller" :rules="rules"> <el-form-item label="用户名" :label-width="formLabelWidth" prop="username"> <el-input v-model="upDatainstaller.username" autocomplete="off"></el-input> </el-form-item> <el-form-item label="姓名" :label-width="formLabelWidth" prop="username"> <el-input v-model="upDatainstaller.name" autocomplete="off"></el-input> </el-form-item> <el-form-item label="手机号" :label-width="formLabelWidth" prop="phone"> <el-input v-model="upDatainstaller.phone" autocomplete="off"></el-input> </el-form-item> <el-form-item label="邮箱" :label-width="formLabelWidth" prop="email"> <el-input v-model="upDatainstaller.email" autocomplete="off"></el-input> </el-form-item> <el-form-item label="密码" :label-width="formLabelWidth" prop="password"> <el-input v-model="upDatainstaller.password" type="password" autocomplete="off"></el-input> </el-form-item> </el-form> <div slot="footer" class="dialog-footer"> <el-button @click="updialogFormVisible = false">取 消</el-button> <el-button type="primary" @click="okUpdialogFormVisible('addinstallerfrom')">确 定</el-button> </div> </el-dialog> </div> </template> <script> import { parseTime } from '@/utils'; import Pagination from '@/components/Pagination'; // 分页 import { installerlist, seekInstaller, deleteInsrall, addinstaller, updateinstaller, postupdateinstaller, normalinstaller } from '@/api/installer'; import waves from '@/directive/waves'; // 水波纹效果 import clip from '@/utils/clipboard'; export default { components: { Pagination }, directives: { waves }, data() { return { instller: [], // 列表 tableKey: 0, downloadLoading: false, dialogFormVisible: false, updialogFormVisible: false, formLabelWidth: '120px', total: 0, installerdata: { limit: 10, page: 1, phone: undefined, status: undefined, }, calendarTypeOptions: ['正常', '禁用'], addinstallerfrom: { username: undefined, name: undefined, phone: undefined, email: undefined, password: undefined, ispassword: undefined, }, upDatainstaller: [], rules: { name: [ { required: true, message: '请输入姓名', trigger: 'blur' }, { min: 2, max: 5, message: '长度在 2 到 5 个字符', trigger: 'blur' }, ], username: [ { required: true, message: '请输入用户名', trigger: 'change' }, { min: 2, max: 5, message: '长度在 2 到 5 个字符', trigger: 'blur' }, ], phone: [ { type: 'string', required: true, message: '请输入手机号', trigger: 'change' }, { min: 11, max: 11, message: '长度在11字符', trigger: 'blur' }, ], email: [ { type: 'email', required: true, message: '请输入邮箱', trigger: 'change' }, ], password: [ { type: 'string', required: true, message: '请输入密码', trigger: 'change' }, { min: 6, max: 20, message: '长度在 6 到 20 个字符', trigger: 'blur' }, ], ispassword: [ { type: 'string', required: true, message: '请输入密码', trigger: 'change' }, { min: 6, max: 20, message: '长度在 6 到 20 个字符', trigger: 'blur' }, ], }, }; }, created() { this.installerlist(); // 用户列表 }, methods: { installerlist() { this.loading = true; installerlist(this.installerdata.limit, this.installerdata.page) .then(response => { this.instller = response.data.instllerdata; this.instller.forEach((element, index) => { element['index'] = (this.installerdata.page - 1) * this.installerdata.limit + index + 1; }); this.total = response.data.count; this.loading = false; }) .catch(err => { console.log(err); }); }, handleCopy(text, event) { clip(text, event); }, selectOne(event, item) { console.log(event); if (event === '') { this.installerdata.status = undefined; } }, changeValue(event, item) { if (event === '') { this.installerdata.phone = undefined; } }, handleSubmit() { seekInstaller(this.installerdata) .then(response => { this.instller = response.data.instllerdata; this.instller.forEach((element, index) => { element['index'] = (this.installerdata.page - 1) * this.installerdata.limit + index + 1; }); this.total = response.data.count; }) .catch(err => { console.log(err); }); }, handleDownload() { this.downloadLoading = true; import('@/vendor/Export2Excel').then(excel => { const tHeader = ['id', '用户名', '姓名', '用户邮箱', '创建时间', '状态']; const filterVal = ['id', 'username', 'name', 'email', 'addtime', 'status']; const data = this.formatJson(filterVal, this.instller); excel.export_json_to_excel({ header: tHeader, data, filename: '装维人员', }); this.downloadLoading = false; }); }, formatJson(filterVal, jsonData) { return jsonData.map(v => filterVal.map(j => { if (j === 'addtime') { return parseTime(v[j]); } else if (j === 'status') { return v[j] === 1 ? '正常' : '禁用'; } else { return v[j]; } })); }, // 删除 deleteInsrall(id, type) { deleteInsrall(id, type) .then(response => { if (response.code === 105) { this.$message({ message: response.msg, type: 'warning', }); } else { this.installerlist(); } }) .catch(err => { console.log(err); }); }, addinstaller() { this.dialogFormVisible = true; }, okdialogFormVisible(formName) { this.$refs[formName].validate((valid) => { if (valid) { if (this.addinstallerfrom.password !== this.addinstallerfrom.ispassword) { this.$message.error('两次密码不一致'); } else { addinstaller(this.addinstallerfrom) .then(response => { if (response.code === 105) { this.$message({ message: response.msg, type: 'warning', }); } else if (response.code === 200) { this.installerlist(); this.dialogFormVisible = false; this.$refs[formName].resetFields(); } }) .catch(err => { console.log(err); }); } } else { console.log('error submit!!'); return false; } }); }, getUpInsrall(id) { updateinstaller(id) .then(response => { if (response.code === 105) { this.$message({ message: response.msg, type: 'warning', }); } else { this.upDatainstaller = response.data; this.updialogFormVisible = true; } }) .catch(err => { console.log(err); }); }, okUpdialogFormVisible(formName) { this.$refs[formName].validate((valid) => { if (valid) { postupdateinstaller(this.upDatainstaller) .then(response => { if (response.code === 105) { this.$message({ message: response.msg, type: 'warning', }); } else if (response.code === 200) { this.installerlist(); this.updialogFormVisible = false; } }) .catch(err => { console.log(err); }); } else { console.log('error submit!!'); return false; } }); }, normalinstaller(id) { normalinstaller(id) .then(response => { if (response.code === 105) { this.$message({ message: response.msg, type: 'warning', }); } else { this.installerlist(); } }) .catch(err => { console.log(err); }); }, }, }; </script> <style> </style>