源文件

This commit is contained in:
gyq
2024-04-24 09:52:04 +08:00
commit 127202beac
386 changed files with 102573 additions and 0 deletions

View File

@@ -0,0 +1,163 @@
<template>
<el-dialog title="添加支付方式" :visible.sync="dialogVisible" :show-close="false" @close="reset">
<el-form ref="form" :model="form" :rules="rules" label-width="120px" label-position="left">
<el-form-item label="支付类型" prop="payType">
<el-select v-model="form.payType" placeholder="请选择支付类型" @change="typeChange">
<el-option :label="item.lable" :value="item.key" v-for="item in payTypes"
:key="item.key"></el-option>
</el-select>
</el-form-item>
<el-form-item label="支付方式" prop="payName" v-if="form.payType == 'virtual'">
<el-input v-model="form.payName" placeholder="请输入自定义支付方式"></el-input>
</el-form-item>
<!-- <el-form-item label="图标" prop="icon">
<uploadImg ref="uploadImg" :limit="9" @success="e => form.icon = e[0]" />
</el-form-item> -->
<el-form-item label="是否虚拟">
<el-radio-group v-model="form.isIdeal">
<el-radio :label="1">虚拟</el-radio>
<el-radio :label="0">非虚拟</el-radio>
</el-radio-group>
<div class="tips">虚拟微信支付宝支付等 非虚拟现金</div>
</el-form-item>
<el-form-item label="开钱箱权限">
<el-switch v-model="form.isOpenCashDrawer" :active-value="1" :inactive-value="0"></el-switch>
</el-form-item>
<el-form-item label="是否生效">
<el-switch v-model="form.isDisplay" :active-value="1" :inactive-value="0"></el-switch>
</el-form-item>
<el-form-item label="排序">
<el-input-number v-model="form.sorts" controls-position="right" :min="0"></el-input-number>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button @click="close">取消</el-button>
<el-button type="primary" @click="submitHandle" :loading="formLoading">
<span v-if="!formLoading">保存</span>
<span v-else>保存中...</span>
</el-button>
</div>
</el-dialog>
</template>
<script>
import uploadImg from '@/components/uploadImg'
import { tbShopPayType } from '@/api/setting'
import payTypes from '../payTypes'
export default ({
components: { uploadImg },
data() {
const validateIcon = (rule, value, callback) => {
if (!this.form.icon) {
callback(new Error('请上传图标'))
} else {
callback()
}
}
return {
payTypes,
dialogVisible: false,
formLoading: false,
resetForm: '',
form: {
id: '',
icon: '',
shopId: localStorage.getItem('shopId'),
payType: '',
payName: '',
isIdeal: 1,
isOpenCashDrawer: 1,
isDisplay: 1,
sorts: 0
},
rules: {
payType: [
{
required: true,
message: ' ',
triiger: 'blur'
}
],
payName: [
{
required: true,
message: ' ',
triiger: 'blur'
}
],
icon: [
{
required: true,
validator: validateIcon,
triiger: 'change'
}
]
}
}
},
mounted() {
this.resetForm = { ...this.form }
},
methods: {
typeChange(e) {
this.form.icon = payTypes.find(item => item.key == e).icon
if (e == 'virtual') {
this.form.payName = ''
} else {
this.form.payName = payTypes.find(item => item.key == e).lable
}
},
// 保存
submitHandle() {
this.$refs.form.validate(async valid => {
if (valid) {
try {
this.formLoading = true
await tbShopPayType(this.form, this.form.id ? 'put' : 'post')
this.$emit('success')
this.formLoading = false
this.$notify({
title: '成功',
message: `${this.form.pid ? '编辑' : '添加'}成功`,
type: 'success'
});
this.close()
} catch (error) {
this.formLoading = false
console.log(error)
}
}
})
},
close() {
this.dialogVisible = false
},
reset() {
this.form = { ...this.resetForm }
// this.$refs.uploadImg.fileList = []
},
show(obj) {
this.dialogVisible = true
if (obj && obj.id) {
this.form.id = obj.id
this.form.icon = obj.icon
this.form.payType = obj.payType
this.form.payName = obj.payName
this.form.isIdeal = obj.isIdeal
this.form.isOpenCashDrawer = obj.isOpenCashDrawer
this.form.isDisplay = obj.isDisplay
this.form.sorts = obj.sorts
// if (obj.icon) {
// setTimeout(() => {
// this.$refs.uploadImg.fileList = [{
// url: obj.icon
// }]
// }, 100);
// }
}
}
}
})
</script>

View File

@@ -0,0 +1,130 @@
<template>
<div class="app-container">
<div class="head-container">
<el-button type="primary" icon="el-icon-plus" @click="$refs.addPayType.show()">添加支付方式</el-button>
</div>
<div class="head-container">
<el-table :data="tableData.list" v-loading="tableData.loading"><el-table-column prop="icon" label="图标">
<template v-slot="scope">
<el-image :src="scope.row.icon" style="width: 40px;height: 40px;"></el-image>
</template>
</el-table-column>
<el-table-column prop="payName" label="支付方式"></el-table-column>
<el-table-column prop="payType" label="类型"></el-table-column>
<el-table-column prop="isOpenCashDrawer" label="开钱箱权限">
<template v-slot="scope">
<el-switch v-model="scope.row.isOpenCashDrawer" :active-value="1" :inactive-value="0" disabled></el-switch>
</template>
</el-table-column>
<el-table-column prop="isDisplay" label="是否生效">
<template v-slot="scope">
<el-switch v-model="scope.row.isDisplay" :active-value="1" :inactive-value="0" disabled></el-switch>
</template>
</el-table-column>
<el-table-column prop="sorts" label="条件排序"></el-table-column>
<el-table-column label="操作" width="150">
<template v-slot="scope">
<el-button type="text" icon="el-icon-edit" @click="$refs.addPayType.show(scope.row)">编辑</el-button>
</template>
</el-table-column>
</el-table>
</div>
<div class="head-container">
<el-pagination :total="tableData.total" :current-page="tableData.page + 1" :page-size="tableData.size"
@current-change="paginationChange" layout="total, sizes, prev, pager, next, jumper"></el-pagination>
</div>
<addPayType ref="addPayType" @success="getTableData" />
</div>
</template>
<script>
import dayjs from 'dayjs'
import { tbShopPayTypeGet } from '@/api/setting.js'
import addPayType from './components/addPayType'
export default {
components: { addPayType },
data() {
return {
dayjs,
query: {
name: '',
account: '',
status: ''
},
status: [
{
type: 1,
label: '开启'
},
{
type: 0,
label: '关闭'
}
],
tableData: {
list: [],
page: 0,
size: 10,
loading: false,
total: 0
}
}
},
mounted() {
this.getTableData()
},
methods: {
dropdownClick(e) {
switch (e.command) {
case 1:
this.$refs.detailModal.show(e.row)
break;
default:
break;
}
},
// 重置查询
resetHandle() {
this.query.name = ''
this.query.account = ''
this.query.status = ''
this.getTableData()
},
// 分页回调
paginationChange(e) {
this.tableData.page = e - 1
this.getTableData()
},
// 获取商家列表
async getTableData() {
this.tableData.loading = true
try {
const res = await tbShopPayTypeGet({
page: this.tableData.page,
size: this.tableData.size,
shopId: localStorage.getItem('shopId')
})
this.tableData.loading = false
this.tableData.list = res.content
this.tableData.total = res.totalElements
} catch (error) {
console.log(error)
}
}
}
}
</script>
<style scoped lang="scss">
.shop_info {
display: flex;
.info {
flex: 1;
padding-left: 4px;
}
}
</style>

View File

@@ -0,0 +1,32 @@
export default [
{
lable: '现金',
key: 'cash',
icon: 'https://cashier-oss.oss-cn-beijing.aliyuncs.com/upload/20240302/2dab947729d640fba7709b7c0b42bfef.png'
},
{
lable: '银行卡',
key: 'bank',
icon: 'https://cashier-oss.oss-cn-beijing.aliyuncs.com/upload/20240302/14b20cf721304b7fa2f01e6e75fab403.png'
},
{
lable: '扫码支付',
key: 'scanCode',
icon: 'https://cashier-oss.oss-cn-beijing.aliyuncs.com/upload/20240302/9ff08224680446c8b3978844da99bbaa.png'
},
{
lable: '储值卡',
key: 'deposit',
icon: 'https://cashier-oss.oss-cn-beijing.aliyuncs.com/upload/20240302/18d40f471a924d55b4eb13e5f553734d.png'
},
// {
// lable: '挂单',
// key: 'arrears',
// icon: 'https://cashier-oss.oss-cn-beijing.aliyuncs.com/upload/20240304/fcf337b999f14a12ad75f76e74fcb344.png'
// },
{
lable: '自定义',
key: 'virtual',
icon: 'https://cashier-oss.oss-cn-beijing.aliyuncs.com/upload/20240304/6702fbf953504f89aa6a3db1f33d49b6.png'
}
]