Skip to content

Commit a53b8f4

Browse files
committed
邮箱模块:完善 template 模版的增删改查功能
1 parent c806d03 commit a53b8f4

File tree

4 files changed

+331
-10
lines changed

4 files changed

+331
-10
lines changed

src/api/system/mail/account.js

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -42,3 +42,11 @@ export function getMailAccountPage(query) {
4242
params: query
4343
})
4444
}
45+
46+
// 获取邮箱账号的精简信息列表
47+
export function getSimpleMailAccountList() {
48+
return request({
49+
url: '/system/mail-account/list-all-simple',
50+
method: 'get',
51+
})
52+
}

src/api/system/mail/template.js

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
import request from '@/utils/request'
2+
3+
// 创建邮件模版
4+
export function createMailTemplate(data) {
5+
return request({
6+
url: '/system/mail-template/create',
7+
method: 'post',
8+
data: data
9+
})
10+
}
11+
12+
// 更新邮件模版
13+
export function updateMailTemplate(data) {
14+
return request({
15+
url: '/system/mail-template/update',
16+
method: 'put',
17+
data: data
18+
})
19+
}
20+
21+
// 删除邮件模版
22+
export function deleteMailTemplate(id) {
23+
return request({
24+
url: '/system/mail-template/delete?id=' + id,
25+
method: 'delete'
26+
})
27+
}
28+
29+
// 获得邮件模版
30+
export function getMailTemplate(id) {
31+
return request({
32+
url: '/system/mail-template/get?id=' + id,
33+
method: 'get'
34+
})
35+
}
36+
37+
// 获得邮件模版分页
38+
export function getMailTemplatePage(query) {
39+
return request({
40+
url: '/system/mail-template/page',
41+
method: 'get',
42+
params: query
43+
})
44+
}

src/views/system/mail/account/index.vue

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -29,8 +29,8 @@
2929
<el-table-column label="主键" align="center" prop="id" />
3030
<el-table-column label="邮箱" align="center" prop="mail" />
3131
<el-table-column label="用户名" align="center" prop="username" />
32-
<el-table-column label="主机" align="center" prop="host" />
33-
<el-table-column label="端口" align="center" prop="port" />
32+
<el-table-column label="SMTP 服务器域名" align="center" prop="host" />
33+
<el-table-column label="SMTP 服务器端口" align="center" prop="port" />
3434
<el-table-column label="是否开启 SSL" align="center" prop="sslEnable">
3535
<template v-slot="scope">
3636
<dict-tag :type="DICT_TYPE.INFRA_BOOLEAN_STRING" :value="scope.row.sslEnable" />
@@ -56,7 +56,7 @@
5656

5757
<!-- 对话框(添加 / 修改) -->
5858
<el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body>
59-
<el-form ref="form" :model="form" :rules="rules" label-width="120px">
59+
<el-form ref="form" :model="form" :rules="rules" label-width="140px">
6060
<el-form-item label="邮箱" prop="mail">
6161
<el-input v-model="form.mail" placeholder="请输入邮箱" />
6262
</el-form-item>
@@ -66,11 +66,11 @@
6666
<el-form-item label="密码" prop="password">
6767
<el-input v-model="form.password" placeholder="请输入密码" />
6868
</el-form-item>
69-
<el-form-item label="主机" prop="host">
70-
<el-input v-model="form.host" placeholder="请输入主机" />
69+
<el-form-item label="SMTP 服务器域名" prop="host">
70+
<el-input v-model="form.host" placeholder="请输入 SMTP 服务器域名" />
7171
</el-form-item>
72-
<el-form-item label="端口" prop="port">
73-
<el-input v-model="form.port" placeholder="请输入端口" />
72+
<el-form-item label="SMTP 服务器端口" prop="port">
73+
<el-input v-model="form.port" placeholder="请输入 SMTP 服务器端口" />
7474
</el-form-item>
7575
<el-form-item label="是否开启 SSL" prop="sslEnable">
7676
<el-radio-group v-model="form.sslEnable">
@@ -124,10 +124,10 @@ export default {
124124
mail: [{ required: true, message: "邮箱不能为空", trigger: "blur" }],
125125
username: [{ required: true, message: "用户名不能为空", trigger: "blur" }],
126126
password: [{ required: true, message: "密码不能为空", trigger: "blur" }],
127-
host: [{ required: true, message: "主机不能为空", trigger: "blur" }],
128-
port: [{ required: true, message: "端口不能为空", trigger: "blur" }],
127+
host: [{ required: true, message: "SMTP 服务器域名不能为空", trigger: "blur" }],
128+
port: [{ required: true, message: "SMTP 服务器端口不能为空", trigger: "blur" }],
129129
sslEnable: [{ required: true, message: "是否开启 SSL不能为空", trigger: "blur" }],
130-
}
130+
},
131131
};
132132
},
133133
created() {
Lines changed: 269 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,269 @@
1+
<template>
2+
<div class="app-container">
3+
4+
<!-- 搜索工作栏 -->
5+
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
6+
<el-form-item label="模板名称" prop="name">
7+
<el-input v-model="queryParams.name" placeholder="请输入模板名称" clearable @keyup.enter.native="handleQuery"/>
8+
</el-form-item>
9+
<el-form-item label="模板编码" prop="code">
10+
<el-input v-model="queryParams.code" placeholder="请输入模板编码" clearable @keyup.enter.native="handleQuery"/>
11+
</el-form-item>
12+
<el-form-item label="邮箱账号" prop="accountId">
13+
<el-select v-model="queryParams.accountId" placeholder="请输入邮箱账号" clearable>
14+
<el-option v-for="account in accountOptions" :key="account.id" :value="account.id" :label="account.mail" />
15+
</el-select>
16+
</el-form-item>
17+
<el-form-item label="开启状态" prop="status">
18+
<el-select v-model="queryParams.status" placeholder="请选择开启状态" clearable size="small">
19+
<el-option v-for="dict in this.getDictDatas(DICT_TYPE.COMMON_STATUS)"
20+
:key="dict.value" :label="dict.label" :value="dict.value"/>
21+
</el-select>
22+
</el-form-item>
23+
<el-form-item label="创建时间" prop="createTime">
24+
<el-date-picker v-model="queryParams.createTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange"
25+
range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" />
26+
</el-form-item>
27+
<el-form-item>
28+
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
29+
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
30+
</el-form-item>
31+
</el-form>
32+
33+
<!-- 操作工具栏 -->
34+
<el-row :gutter="10" class="mb8">
35+
<el-col :span="1.5">
36+
<el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
37+
v-hasPermi="['system:mail-template:create']">新增</el-button>
38+
</el-col>
39+
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
40+
</el-row>
41+
42+
<!-- 列表 -->
43+
<el-table v-loading="loading" :data="list">
44+
<el-table-column label="模板编码" align="center" prop="code" />
45+
<el-table-column label="模板名称" align="center" prop="name" />
46+
<el-table-column label="模板标题" align="center" prop="title" />
47+
<el-table-column label="邮箱账号" align="center" prop="accountId">
48+
<template v-slot="scope">
49+
{{ accountOptions.find(account => account.id === scope.row.accountId)?.mail }}
50+
</template>
51+
</el-table-column>
52+
<el-table-column label="发送人名称" align="center" prop="nickname" />
53+
<el-table-column label="开启状态" align="center" prop="status">
54+
<template v-slot="scope">
55+
<dict-tag :type="DICT_TYPE.COMMON_STATUS" :value="scope.row.status"/>
56+
</template>
57+
</el-table-column>
58+
<el-table-column label="备注" align="center" prop="remark" />
59+
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
60+
<template v-slot="scope">
61+
<span>{{ parseTime(scope.row.createTime) }}</span>
62+
</template>
63+
</el-table-column>
64+
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
65+
<template v-slot="scope">
66+
<el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
67+
v-hasPermi="['system:mail-template:update']">修改</el-button>
68+
<el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
69+
v-hasPermi="['system:mail-template:delete']">删除</el-button>
70+
</template>
71+
</el-table-column>
72+
</el-table>
73+
<!-- 分页组件 -->
74+
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize"
75+
@pagination="getList"/>
76+
77+
<!-- 对话框(添加 / 修改) -->
78+
<el-dialog :title="title" :visible.sync="open" width="600px" v-dialogDrag append-to-body>
79+
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
80+
<el-form-item label="模板名称" prop="name">
81+
<el-input v-model="form.name" placeholder="请输入模板名称" />
82+
</el-form-item>
83+
<el-form-item label="模板编码" prop="code">
84+
<el-input v-model="form.code" placeholder="请输入模板编码" />
85+
</el-form-item>
86+
<el-form-item label="邮箱账号" prop="accountId">
87+
<el-select v-model="form.accountId" placeholder="请输入邮箱账号">
88+
<el-option v-for="account in accountOptions" :key="account.id" :value="account.id" :label="account.mail" />
89+
</el-select>
90+
</el-form-item>
91+
<el-form-item label="发送人名称" prop="nickname">
92+
<el-input v-model="form.nickname" placeholder="请输入发送人名称" />
93+
</el-form-item>
94+
<el-form-item label="模板标题" prop="title">
95+
<el-input v-model="form.title" placeholder="请输入模板标题" />
96+
</el-form-item>
97+
<el-form-item label="模板内容">
98+
<editor v-model="form.content" :min-height="192"/>
99+
</el-form-item>
100+
<el-form-item label="开启状态" prop="status">
101+
<el-radio-group v-model="form.status">
102+
<el-radio v-for="dict in this.getDictDatas(DICT_TYPE.COMMON_STATUS)"
103+
:key="dict.value" :label="parseInt(dict.value)">{{dict.label}}</el-radio>
104+
</el-radio-group>
105+
</el-form-item>
106+
<el-form-item label="备注" prop="remark">
107+
<el-input v-model="form.remark" placeholder="请输入备注" />
108+
</el-form-item>
109+
</el-form>
110+
<div slot="footer" class="dialog-footer">
111+
<el-button type="primary" @click="submitForm">确 定</el-button>
112+
<el-button @click="cancel">取 消</el-button>
113+
</div>
114+
</el-dialog>
115+
</div>
116+
</template>
117+
118+
<script>
119+
import { createMailTemplate, updateMailTemplate, deleteMailTemplate, getMailTemplate, getMailTemplatePage } from "@/api/system/mail/template";
120+
import Editor from '@/components/Editor';
121+
import { CommonStatusEnum } from "@/utils/constants";
122+
import { getSimpleMailAccountList } from "@/api/system/mail/account";
123+
124+
export default {
125+
name: "MailTemplate",
126+
components: {
127+
Editor,
128+
},
129+
data() {
130+
return {
131+
// 遮罩层
132+
loading: true,
133+
// 导出遮罩层
134+
exportLoading: false,
135+
// 显示搜索条件
136+
showSearch: true,
137+
// 总条数
138+
total: 0,
139+
// 邮件模版列表
140+
list: [],
141+
// 弹出层标题
142+
title: "",
143+
// 是否显示弹出层
144+
open: false,
145+
// 查询参数
146+
queryParams: {
147+
pageNo: 1,
148+
pageSize: 10,
149+
name: null,
150+
code: null,
151+
accountId: null,
152+
status: null,
153+
createTime: [],
154+
},
155+
// 表单参数
156+
form: {},
157+
// 表单校验
158+
rules: {
159+
name: [{ required: true, message: "模板名称不能为空", trigger: "blur" }],
160+
code: [{ required: true, message: "模板编码不能为空", trigger: "blur" }],
161+
accountId: [{ required: true, message: "邮箱账号不能为空", trigger: "blur" }],
162+
title: [{ required: true, message: "模板标题不能为空", trigger: "blur" }],
163+
content: [{ required: true, message: "模板内容不能为空", trigger: "blur" }],
164+
status: [{ required: true, message: "开启状态不能为空", trigger: "blur" }],
165+
},
166+
// 邮箱账号
167+
accountOptions: []
168+
};
169+
},
170+
created() {
171+
this.getList();
172+
// 获得邮箱账号列表
173+
getSimpleMailAccountList().then(response => {
174+
this.accountOptions = response.data
175+
})
176+
},
177+
methods: {
178+
/** 查询列表 */
179+
getList() {
180+
this.loading = true;
181+
// 执行查询
182+
getMailTemplatePage(this.queryParams).then(response => {
183+
this.list = response.data.list;
184+
this.total = response.data.total;
185+
this.loading = false;
186+
});
187+
},
188+
/** 取消按钮 */
189+
cancel() {
190+
this.open = false;
191+
this.reset();
192+
},
193+
/** 表单重置 */
194+
reset() {
195+
this.form = {
196+
id: undefined,
197+
name: undefined,
198+
code: undefined,
199+
accountId: undefined,
200+
nickname: undefined,
201+
title: undefined,
202+
content: undefined,
203+
status: CommonStatusEnum.ENABLE,
204+
remark: undefined,
205+
};
206+
this.resetForm("form");
207+
},
208+
/** 搜索按钮操作 */
209+
handleQuery() {
210+
this.queryParams.pageNo = 1;
211+
this.getList();
212+
},
213+
/** 重置按钮操作 */
214+
resetQuery() {
215+
this.resetForm("queryForm");
216+
this.handleQuery();
217+
},
218+
/** 新增按钮操作 */
219+
handleAdd() {
220+
this.reset();
221+
this.open = true;
222+
this.title = "添加邮件模版";
223+
},
224+
/** 修改按钮操作 */
225+
handleUpdate(row) {
226+
this.reset();
227+
const id = row.id;
228+
getMailTemplate(id).then(response => {
229+
this.form = response.data;
230+
this.open = true;
231+
this.title = "修改邮件模版";
232+
});
233+
},
234+
/** 提交按钮 */
235+
submitForm() {
236+
this.$refs["form"].validate(valid => {
237+
if (!valid) {
238+
return;
239+
}
240+
// 修改的提交
241+
if (this.form.id != null) {
242+
updateMailTemplate(this.form).then(response => {
243+
this.$modal.msgSuccess("修改成功");
244+
this.open = false;
245+
this.getList();
246+
});
247+
return;
248+
}
249+
// 添加的提交
250+
createMailTemplate(this.form).then(response => {
251+
this.$modal.msgSuccess("新增成功");
252+
this.open = false;
253+
this.getList();
254+
});
255+
});
256+
},
257+
/** 删除按钮操作 */
258+
handleDelete(row) {
259+
const id = row.id;
260+
this.$modal.confirm('是否确认删除邮件模版编号为"' + id + '"的数据项?').then(function() {
261+
return deleteMailTemplate(id);
262+
}).then(() => {
263+
this.getList();
264+
this.$modal.msgSuccess("删除成功");
265+
}).catch(() => {});
266+
}
267+
}
268+
};
269+
</script>

0 commit comments

Comments
 (0)