|
@@ -3,91 +3,105 @@
|
|
|
<!-- 搜索 -->
|
|
|
<el-form inline label-width="100px" size="mini">
|
|
|
<el-form-item label="消息类型:">
|
|
|
- <el-select placeholder="请选择消息类型">
|
|
|
- <el-option />
|
|
|
+ <el-select v-model="form.messageType" placeholder="请选择消息类型" clearable>
|
|
|
+ <el-option v-for="item in typeOptions" :key="item.value" :label="item.label" :value="item.value" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="推送状态:">
|
|
|
- <el-select placeholder="请选择推送状态">
|
|
|
- <el-option />
|
|
|
+ <el-select v-model="form.status" placeholder="请选择推送状态" clearable>
|
|
|
+ <el-option v-for="item in statusOptions" :key="item.value" :label="item.label"
|
|
|
+ :value="item.value" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="推送平台:">
|
|
|
- <el-select placeholder="请选择推送平台">
|
|
|
- <el-option />
|
|
|
+ <el-select v-model="form.systemType" placeholder="请选择推送平台" clearable>
|
|
|
+ <el-option v-for="item in systemOptions" :key="item.value" :label="item.label"
|
|
|
+ :value="item.value" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="推送内容:">
|
|
|
- <el-input placeholder="请输入推送内容" />
|
|
|
+ <el-input v-model="form.content" placeholder="请输入推送内容" clearable />
|
|
|
</el-form-item>
|
|
|
<el-form-item>
|
|
|
- <el-button type="primary" icon="el-icon-search">搜索</el-button>
|
|
|
- <el-button icon="el-icon-refresh">重置</el-button>
|
|
|
- <el-button type="primary" icon="el-icon-plus" @click="dialogVisible = true">新增</el-button>
|
|
|
+ <el-button type="primary" icon="el-icon-search" @click="getSearch">搜索</el-button>
|
|
|
+ <el-button icon="el-icon-refresh" @click="getRefresh">重置</el-button>
|
|
|
+ <el-button type="primary" icon="el-icon-plus" @click="getDialog()">新增</el-button>
|
|
|
</el-form-item>
|
|
|
</el-form>
|
|
|
<!-- 列表 -->
|
|
|
<el-table :data="tableData">
|
|
|
- <el-table-column label="消息类型" align="center" />
|
|
|
- <el-table-column label="推送标题" align="center" />
|
|
|
- <el-table-column label="推送内容" align="center" />
|
|
|
- <el-table-column label="推送日期" align="center" />
|
|
|
- <el-table-column label="推送状态" align="center" />
|
|
|
- <el-table-column label="推送平台" align="center" />
|
|
|
+ <el-table-column label="消息类型" prop="messageType" align="center" :formatter="typeFormatter" />
|
|
|
+ <el-table-column label="推送标题" prop="title" align="center" />
|
|
|
+ <el-table-column label="推送内容" prop="content" align="center" />
|
|
|
+ <el-table-column label="推送日期" prop="pushTime" align="center" />
|
|
|
+ <el-table-column label="推送状态" prop="status" align="center" :formatter="statusFormatter" />
|
|
|
+ <el-table-column label="推送平台" prop="systemType" align="center" :formatter="systemFormatter" />
|
|
|
<el-table-column label="操作" align="center">
|
|
|
- <template>
|
|
|
- <el-button type="text">推送</el-button>
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <el-button type="text" @click="getDialog(scope.row.id)">详情</el-button>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
</el-table>
|
|
|
+ <pagination v-show="total>0" :total="total" :page.sync="form.pageNum" :limit.sync="form.pageSize"
|
|
|
+ @pagination="getList" />
|
|
|
<!-- 弹窗 -->
|
|
|
- <el-dialog :visible.sync="dialogVisible" title="推送" width="500px">
|
|
|
+ <el-dialog :visible.sync="dialogVisible" title="新增推送" width="500px">
|
|
|
<el-form label-width="100px">
|
|
|
<el-form-item label="推送类型:">
|
|
|
- <el-select v-model="dialogForm.type" placeholder="请选择推送类型">
|
|
|
+ <el-select v-model="dialogForm.messageType" placeholder="请选择推送类型">
|
|
|
<el-option v-for="item in typeOptions" :key="item.value" :label="item.label"
|
|
|
:value="item.value" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="推送标题:">
|
|
|
- <el-input placeholder="请输入推送标题" />
|
|
|
+ <el-input v-model="dialogForm.title" placeholder="请输入推送标题" />
|
|
|
</el-form-item>
|
|
|
<el-form-item label="推送内容:">
|
|
|
- <el-input type="textarea" rows="4" placeholder="请输入推送内容" />
|
|
|
+ <el-input v-model="dialogForm.content" type="textarea" rows="4" placeholder="请输入推送内容" />
|
|
|
</el-form-item>
|
|
|
- <el-form-item v-if="dialogForm.type === 4" label="打开方式:">
|
|
|
- <el-select placeholder="请选择打开方式">
|
|
|
- <el-option />
|
|
|
+ <el-form-item v-if="dialogForm.id" label="打开方式:">
|
|
|
+ <el-select v-model="dialogForm.jumpType" placeholder="请选择打开方式">
|
|
|
+ <el-option v-for="item in jumpOptions" :key="item.value" :label="item.label"
|
|
|
+ :value="item.value" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
- <el-form-item v-if="dialogForm.type === 4" label="参数:">
|
|
|
- <el-input placeholder="请输入URL或App参数" />
|
|
|
+ <el-form-item v-if="dialogForm.id" label="参数:">
|
|
|
+ <el-input v-model="dialogForm.jumpContent" placeholder="请输入URL或App参数" />
|
|
|
</el-form-item>
|
|
|
<el-form-item label="推送日期:">
|
|
|
- <el-date-picker type="datetimerange" start-placeholder="开始时间" end-placeholder="结束时间" />
|
|
|
+ <el-date-picker v-model="dialogForm.pushTime" type="datetime" placeholder="选择推送日期"
|
|
|
+ value-format="yyyy-MM-dd HH:mm:ss" />
|
|
|
</el-form-item>
|
|
|
<el-form-item label="推送平台:">
|
|
|
- <el-select placeholder="请选择推送平台">
|
|
|
- <el-option />
|
|
|
+ <el-select v-model="dialogForm.systemType" placeholder="请选择推送平台">
|
|
|
+ <el-option v-for="item in systemOptions" :key="item.value" :label="item.label"
|
|
|
+ :value="item.value" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
+ <el-form-item v-if="dialogForm.id">
|
|
|
+ <el-button type="danger" @click="dialogForm.status = 4, getSubmit()">强制过期</el-button>
|
|
|
+ </el-form-item>
|
|
|
</el-form>
|
|
|
<div slot="footer">
|
|
|
<el-button>取消</el-button>
|
|
|
- <el-button type="primary">确定</el-button>
|
|
|
+ <el-button type="primary" @click="getSubmit">确定</el-button>
|
|
|
</div>
|
|
|
</el-dialog>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
+import { list, create, detail, edit } from '@/api/push/message'
|
|
|
export default {
|
|
|
data() {
|
|
|
return {
|
|
|
+ form: {
|
|
|
+ pageNum: 1,
|
|
|
+ pageSize: 10
|
|
|
+ },
|
|
|
// 列表
|
|
|
- tableData: [{
|
|
|
- id: 1,
|
|
|
- }],
|
|
|
+ tableData: [],
|
|
|
+ total: 0,
|
|
|
// 弹窗
|
|
|
dialogVisible: false,
|
|
|
// 推送类型
|
|
@@ -104,9 +118,116 @@ export default {
|
|
|
value: 4,
|
|
|
label: 'push'
|
|
|
}],
|
|
|
+ // 推送平台
|
|
|
+ systemOptions: [{
|
|
|
+ value: 1,
|
|
|
+ label: '全部'
|
|
|
+ }, {
|
|
|
+ value: 2,
|
|
|
+ label: 'Android'
|
|
|
+ }, {
|
|
|
+ value: 3,
|
|
|
+ label: 'iOS'
|
|
|
+ }],
|
|
|
+ // 打开方式
|
|
|
+ jumpOptions: [{
|
|
|
+ value: 1,
|
|
|
+ label: '指定页面'
|
|
|
+ }, {
|
|
|
+ value: 2,
|
|
|
+ label: 'URL'
|
|
|
+ }],
|
|
|
+ // 推送状态
|
|
|
+ statusOptions: [{
|
|
|
+ value: 1,
|
|
|
+ label: '未开始'
|
|
|
+ }, {
|
|
|
+ value: 2,
|
|
|
+ label: '已推送'
|
|
|
+ }, {
|
|
|
+ value: 4,
|
|
|
+ label: '已过期'
|
|
|
+ }],
|
|
|
// 表单
|
|
|
+ title: '',
|
|
|
dialogForm: {}
|
|
|
}
|
|
|
+ },
|
|
|
+ mounted() {
|
|
|
+ this.getList()
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ // 列表
|
|
|
+ getList() {
|
|
|
+ list(this.form).then(res => {
|
|
|
+ if (res.code === 0) {
|
|
|
+ this.tableData = res.data.records
|
|
|
+ this.total = res.data.total
|
|
|
+ }
|
|
|
+ })
|
|
|
+ },
|
|
|
+
|
|
|
+ // 搜索
|
|
|
+ getSearch() {
|
|
|
+ this.form.pageNum = 1
|
|
|
+ this.getList()
|
|
|
+ },
|
|
|
+
|
|
|
+ // 重置
|
|
|
+ getRefresh() {
|
|
|
+ this.form = {
|
|
|
+ pageNum: 1,
|
|
|
+ pageSize: 10
|
|
|
+ }
|
|
|
+ this.getList()
|
|
|
+ },
|
|
|
+
|
|
|
+ // 详情
|
|
|
+ getDialog(id) {
|
|
|
+ this.dialogVisible = true
|
|
|
+ this.dialogForm = {}
|
|
|
+ if (id) {
|
|
|
+ detail(id).then(res => {
|
|
|
+ if (res.code === 0) {
|
|
|
+ this.dialogForm = res.data
|
|
|
+ }
|
|
|
+ })
|
|
|
+ }
|
|
|
+ },
|
|
|
+
|
|
|
+ // 推送
|
|
|
+ getSubmit() {
|
|
|
+ if (this.dialogForm.id) {
|
|
|
+ edit(this.dialogForm).then(res => {
|
|
|
+ if (res.code === 0) {
|
|
|
+ this.$message.success('新增成功!')
|
|
|
+ this.dialogVisible = false
|
|
|
+ this.getList()
|
|
|
+ }
|
|
|
+ })
|
|
|
+ } else {
|
|
|
+ create(this.dialogForm).then(res => {
|
|
|
+ if (res.code === 0) {
|
|
|
+ this.$message.success('新增成功!')
|
|
|
+ this.dialogVisible = false
|
|
|
+ this.getList()
|
|
|
+ }
|
|
|
+ })
|
|
|
+ } wo
|
|
|
+ },
|
|
|
+
|
|
|
+ // 字典翻译
|
|
|
+ statusFormatter(row) {
|
|
|
+ return this.selectDictLabel(this.statusOptions, row.status)
|
|
|
+ },
|
|
|
+
|
|
|
+ systemFormatter(row) {
|
|
|
+ return this.selectDictLabel(this.systemOptions, row.systemType)
|
|
|
+ },
|
|
|
+
|
|
|
+ typeFormatter(row) {
|
|
|
+ return this.selectDictLabel(this.typeOptions, row.messageType)
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
</script>
|