From 7fd9ffcc9d1a7f914d23a660d8d5df71eb30d713 Mon Sep 17 00:00:00 2001
From: lin <sbla5888@163.com>
Date: Mon, 04 Mar 2024 11:23:48 +0800
Subject: [PATCH] 消息设置

---
 src/views/message/messageSettings.vue |  322 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 322 insertions(+), 0 deletions(-)

diff --git a/src/views/message/messageSettings.vue b/src/views/message/messageSettings.vue
new file mode 100644
index 0000000..c3a8751
--- /dev/null
+++ b/src/views/message/messageSettings.vue
@@ -0,0 +1,322 @@
+<template>
+    <basic-container>
+        <avue-crud :option="option" :table-loading="loading" :data="data" :page.sync="page" :permission="permissionList"
+            :before-open="beforeOpen" v-model="form" ref="crud" @row-update="rowUpdate" @row-save="rowSave"
+            @row-del="rowDel" @search-change="searchChange" @search-reset="searchReset" @selection-change="selectionChange"
+            @current-change="currentChange" @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad">
+            <template slot="menuLeft">
+                <el-button type="danger" size="small" icon="el-icon-delete" plain v-if="permission.email_delete"
+                    @click="handleDelete">删 除
+                </el-button>
+            </template>
+
+            <template slot-scope="{row, size}" slot="status">
+                <el-tag :size="size" :type="row.statusName == '是' ? 'success' : 'info'">{{ row.statusName }}</el-tag>
+            </template>
+
+
+
+
+            <template slot-scope="{ row, size, index }" slot="menu">
+                <el-button :size="size" type="text" icon="el-icon-circle-check" v-if="permission.email_enable"
+                    @click.stop="handleEnable(row)">启用
+                </el-button>
+                <el-button :size="size" type="text" icon="el-icon-video-play" v-if="userInfo.role_name.includes('admin')"
+                    @click="handleDebug(row)">调试
+                </el-button>
+            </template>
+
+        </avue-crud>
+
+        <el-dialog title="短信发送调试" append-to-body :visible.sync="box" width="550px">
+            <avue-form ref="form" :option="debugOption" v-model="debugForm" @submit="handleSubmit" />
+        </el-dialog>
+
+    </basic-container>
+</template>
+
+<script>
+import { getList, getDetail, add, update, remove, enable, sendEmail } from "@/api/system/email"
+import { mapGetters } from "vuex"
+
+export default {
+    data () {
+        return {
+            box: false,
+            form: {},
+            query: {},
+            loading: true,
+            page: {
+                pageSize: 10,
+                currentPage: 1,
+                total: 0
+            },
+            selectionList: [],
+            option: {
+                height: 'auto',
+                calcHeight: 30,
+                tip: false,
+                searchShow: true,
+                searchMenuSpan: 6,
+                border: true,
+                index: true,
+                viewBtn: true,
+                selection: true,
+                dialogClickModal: false,
+                menuWidth: 350,
+                column: [
+                    {
+                        label: "主键",
+                        prop: "id",
+                        type: "input",
+                        addDisplay: false,
+                        editDisplay: false,
+                        viewDisplay: false,
+                        hide: true,
+                    },
+                    {
+                        label: "发送者邮箱",
+                        prop: "username",
+                        type: "input",
+                    },
+                    {
+                        label: "授权码",
+                        prop: "password",
+                        type: "input",
+                    },
+                    {
+                        label: "服务器地址",
+                        prop: "host",
+                        type: "input",
+                    },
+                    {
+                        label: "端口号",
+                        prop: "port",
+                        type: "input",
+                        value: 465
+                    },
+                    {
+                        label: "默认编码",
+                        prop: "defaultEncoding",
+                        type: "input",
+                        value: "UTF-8"
+                    },
+                    {
+                        label: "协议",
+                        prop: "protocol",
+                        type: "input",
+                        value: "smtps"
+                    },
+                    {
+                        label: "备注",
+                        prop: "remark",
+                        type: "input",
+                    },
+                    {
+                        label: "是否启用",
+                        prop: "status",
+                        type: "input",
+                        addDisplay: false,
+                        editDisplay: false,
+                        viewDisplay: false,
+                    },
+                ]
+            },
+            data: [],
+
+
+            debugForm: {},
+            debugOption: {
+                submitText: "保存",
+                column: [
+                    {
+                        label: "收件人",
+                        prop: "emails",
+                        placeholder: "多个收件人请用英文逗号进行分隔",
+                        span: 24,
+                    },
+                    {
+                        label: "主题",
+                        prop: "subject",
+                        span: 24,
+                    },
+                    {
+                        label: "内容",
+                        prop: "content",
+                        type: "textarea",
+                        minRow: 5,
+                        span: 24,
+                    },
+                ]
+            }
+
+        }
+    },
+    computed: {
+        ...mapGetters(["permission", "userInfo"]),
+        permissionList () {
+            return {
+                addBtn: this.vaildData(this.permission.email_add, false),
+                viewBtn: this.vaildData(this.permission.email_view, false),
+                delBtn: this.vaildData(this.permission.email_delete, false),
+                editBtn: this.vaildData(this.permission.email_edit, false)
+            }
+        },
+        ids () {
+            let ids = []
+            this.selectionList.forEach(ele => {
+                ids.push(ele.id)
+            })
+            return ids.join(",")
+        }
+    },
+    methods: {
+        handleSubmit (form, done) {
+            console.log(form, "+++++++++")
+
+            form.emails = form.emails.split(",")
+
+            sendEmail(form).then(res => {
+                this.$message({
+                    type: "success",
+                    message: "发送成功!"
+                })
+            })
+            done()
+        },
+        rowSave (row, done, loading) {
+            add(row).then(() => {
+                this.onLoad(this.page)
+                this.$message({
+                    type: "success",
+                    message: "操作成功!"
+                })
+                done()
+            }, error => {
+                loading()
+                window.console.log(error)
+            })
+        },
+        rowUpdate (row, index, done, loading) {
+            update(row).then(() => {
+                this.onLoad(this.page)
+                this.$message({
+                    type: "success",
+                    message: "操作成功!"
+                })
+                done()
+            }, error => {
+                loading()
+                console.log(error)
+            })
+        },
+        rowDel (row) {
+            this.$confirm("确定将选择数据删除?", {
+                confirmButtonText: "确定",
+                cancelButtonText: "取消",
+                type: "warning"
+            })
+                .then(() => {
+                    return remove(row.id)
+                })
+                .then(() => {
+                    this.onLoad(this.page)
+                    this.$message({
+                        type: "success",
+                        message: "操作成功!"
+                    })
+                })
+        },
+        handleDebug (row) {
+            console.log(row, "++++++++++")
+            this.box = true
+        },
+        handleEnable (row) {
+            this.$confirm("是否确定启用这条配置?", {
+                confirmButtonText: "确定",
+                cancelButtonText: "取消",
+                type: "warning"
+            })
+                .then(() => {
+                    return enable(row.id)
+                })
+                .then(() => {
+                    this.onLoad(this.page)
+                    this.$message({
+                        type: "success",
+                        message: "操作成功!"
+                    })
+                    this.$refs.crud.toggleSelection()
+                })
+        },
+        handleDelete () {
+            if (this.selectionList.length === 0) {
+                this.$message.warning("请选择至少一条数据")
+                return
+            }
+            this.$confirm("确定将选择数据删除?", {
+                confirmButtonText: "确定",
+                cancelButtonText: "取消",
+                type: "warning"
+            })
+                .then(() => {
+                    return remove(this.ids)
+                })
+                .then(() => {
+                    this.onLoad(this.page)
+                    this.$message({
+                        type: "success",
+                        message: "操作成功!"
+                    })
+                    this.$refs.crud.toggleSelection()
+                })
+        },
+        beforeOpen (done, type) {
+            if (["edit", "view"].includes(type)) {
+                getDetail(this.form.id).then(res => {
+                    this.form = res.data.data
+                })
+            }
+            done()
+        },
+        searchReset () {
+            this.query = {}
+            this.onLoad(this.page)
+        },
+        searchChange (params, done) {
+            this.query = params
+            this.page.currentPage = 1
+            this.onLoad(this.page, params)
+            done()
+        },
+        selectionChange (list) {
+            this.selectionList = list
+        },
+        selectionClear () {
+            this.selectionList = []
+            this.$refs.crud.toggleSelection()
+        },
+        currentChange (currentPage) {
+            this.page.currentPage = currentPage
+        },
+        sizeChange (pageSize) {
+            this.page.pageSize = pageSize
+        },
+        refreshChange () {
+            this.onLoad(this.page, this.query)
+        },
+        onLoad (page, params = {}) {
+            this.loading = true
+            getList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
+                const data = res.data.data
+                this.page.total = data.total
+                this.data = data.records
+                this.loading = false
+                this.selectionClear()
+            })
+        }
+    }
+}
+</script>
+
+<style></style>

--
Gitblit v1.9.3