From 089bf5d2378b3c4a61d795b2a92bede2c193b771 Mon Sep 17 00:00:00 2001
From: admin <344137771@qq.com>
Date: Tue, 06 Jan 2026 11:22:58 +0800
Subject: [PATCH] 1
---
src/views/modules/order/ctc-add-or-update.vue | 439 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 439 insertions(+), 0 deletions(-)
diff --git a/src/views/modules/order/ctc-add-or-update.vue b/src/views/modules/order/ctc-add-or-update.vue
new file mode 100644
index 0000000..fbfa54f
--- /dev/null
+++ b/src/views/modules/order/ctc-add-or-update.vue
@@ -0,0 +1,439 @@
+<template>
+ <el-dialog
+ :title="!id ? '添加支付方式模板' : '修改支付方式模板'"
+ :close-on-click-modal="false"
+ :visible.sync="visible"
+ >
+ <el-form
+ :model="dataForm"
+ :rules="dataRule"
+ ref="dataForm"
+ @keyup.enter.native="dataFormSubmit()"
+ label-width="120px"
+ >
+ <el-form-item label="支付方式类型" prop="id">
+ <el-select
+ v-model="arr.id"
+ @change="changeVal(arr.id)"
+ placeholder="请选择"
+ >
+ <el-option
+ v-for="item in arr"
+ :key="item.id"
+ :label="item.name"
+ :value="item.id"
+ >
+ </el-option>
+ </el-select>
+ </el-form-item>
+ <el-form-item label="支付方式名称" prop="methodName">
+ <el-input
+ v-model="dataForm.methodName"
+ placeholder="支付方式名称"
+ ></el-input>
+ </el-form-item>
+ <el-form-item v-if="id" label="登录人资金密码" prop="loginSafeword">
+ <el-input
+ v-model="dataForm.loginSafeword"
+ type="password"
+ placeholder="登录人资金密码"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="支付方式图片" prop="methodImg">
+ <el-upload
+ class="avatar-uploader"
+ :action="$http.adornUrl('/api/uploadFile')"
+ :headers="{ Authorization: $cookie.get('Authorization') }"
+ :show-file-list="false"
+ :on-success="handleAvatarSuccess"
+ :before-upload="beforeAvatarUpload"
+ >
+ <img v-if="imageUrl" :src="imageUrl" class="avatar" />
+ <i v-else class="el-icon-plus avatar-uploader-icon"></i>
+ </el-upload>
+ </el-form-item>
+ <el-form-item label="" prop="">
+ <div style="color: green">
+ 参数名1:
+ 配关键数据,如微信账号、支付宝账号、银行卡号、虚拟货币地址等等;
+ </div>
+ </el-form-item>
+ <el-form-item label="参数名1(必填)" prop="paramName1">
+ <el-input
+ v-model="dataForm.paramName1"
+ placeholder="参数名1"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名2(选填)" prop="paramName2">
+ <el-input
+ v-model="dataForm.paramName2"
+ placeholder="参数名2"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名3(选填)" prop="paramName3">
+ <el-input
+ v-model="dataForm.paramName3"
+ placeholder="参数名3"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名4(选填)" prop="paramName4">
+ <el-input
+ v-model="dataForm.paramName4"
+ placeholder="参数名4"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名5(选填)" prop="paramName5">
+ <el-input
+ v-model="dataForm.paramName5"
+ placeholder="参数名5"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名6(选填)" prop="paramName6">
+ <el-input
+ v-model="dataForm.paramName6"
+ placeholder="参数名6"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名7(选填)" prop="paramName7">
+ <el-input
+ v-model="dataForm.paramName7"
+ placeholder="参数名7"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名8(选填)" prop="paramName8">
+ <el-input
+ v-model="dataForm.paramName8"
+ placeholder="参数名8"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名9(选填)" prop="paramName9">
+ <el-input
+ v-model="dataForm.paramName9"
+ placeholder="参数名9"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名10(选填)" prop="paramName10">
+ <el-input
+ v-model="dataForm.paramName10"
+ placeholder="参数名10"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名11(选填)" prop="paramName11">
+ <el-input
+ v-model="dataForm.paramName11"
+ placeholder="参数名11"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名12(选填)" prop="paramName12">
+ <el-input
+ v-model="dataForm.paramName12"
+ placeholder="参数名12"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名13(选填)" prop="paramName13">
+ <el-input
+ v-model="dataForm.paramName13"
+ placeholder="参数名13"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名14(选填)" prop="paramName14">
+ <el-input
+ v-model="dataForm.paramName14"
+ placeholder="参数名14"
+ ></el-input>
+ </el-form-item>
+ <el-form-item label="参数名15(选填)" prop="paramName15">
+ <el-input
+ v-model="dataForm.paramName15"
+ placeholder="参数名15"
+ ></el-input>
+ </el-form-item>
+ </el-form>
+ <span slot="footer" class="dialog-footer">
+ <el-button @click="visible = false">取消</el-button>
+ <el-button type="primary" :loading="loading" @click="dataFormSubmit()"
+ >确定</el-button
+ >
+ </span>
+ </el-dialog>
+</template>
+
+<script>
+import { isEmail, isMobile } from "@/utils/validate";
+import { Debounce } from "@/utils/debounce";
+import { encrypt } from "@/utils/crypto";
+export default {
+ data() {
+ var validatePassword = (rule, value, callback) => {
+ if (!this.dataForm.id && !/\S/.test(value)) {
+ callback(new Error("密码不能为空"));
+ } else {
+ callback();
+ }
+ };
+ var validateEmail = (rule, value, callback) => {
+ if (!isEmail(value)) {
+ callback(new Error("邮箱格式错误"));
+ } else {
+ callback();
+ }
+ };
+ var validateMobile = (rule, value, callback) => {
+ if (!isMobile(value)) {
+ callback(new Error("手机号格式错误"));
+ } else {
+ callback();
+ }
+ };
+ return {
+ visible: false,
+ roleList: {},
+ id: "",
+ loading: false,
+ imageUrl: "",
+ dataForm: {
+ methodImg: "",
+ methodName: "",
+ paramName1: "",
+ paramName2: "",
+ paramName3: "",
+ paramName4: "",
+ paramName5: "",
+ paramName6: "",
+ paramName7: "",
+ paramName8: "",
+ paramName9: "",
+ paramName10: "",
+ paramName11: "",
+ paramName12: "",
+ paramName13: "",
+ paramName14: "",
+ paramName15: "",
+ loginSafeword: "",
+ },
+ arr: [],
+ dataRule: {
+ paramName1: [
+ { required: true, message: "参数1不能为空", trigger: "blur" },
+ // { pattern: /\s\S+|S+\s|\S/, message: '请输入正确的用户名', trigger: 'blur' }
+ ],
+ password: [
+ { required: true, message: "密码不能为空", trigger: "blur" },
+ ],
+ value1: [
+ { required: true, message: "请选择支付方式", trigger: "blur" },
+ ],
+ loginSafeword: [
+ { required: true, message: "资金密码不能为空", trigger: "blur" },
+ ],
+ // mobile: [
+ // { required: true, message: '手机号不能为空', trigger: 'blur' },
+ // { validator: validateMobile, trigger: 'blur' }
+ // ]
+ },
+ };
+ },
+ created() {},
+ methods: {
+ init(row, id, arr) {
+ this.resClear();
+ this.arr = { ...arr };
+ this.id = id;
+ this.arr.id = row.methodType;
+ this.dataForm = { ...row } || {};
+ if (id == "") {
+ console.log(id);
+ this.arr.id = this.arr[0].id;
+ }
+ if (row) {
+ this.dataForm.username = row.userName;
+ this.imageUrl = row.methodImgUrl;
+ // this.options.value1 = row.loginAuthority
+ // this.optionsTwo.value2 = row.enabled
+ // this.optionsThree.value3 = row.withdrawAuthority
+ this.dataForm.remarks = row.remarks;
+ } else {
+ this.dataForm.username = "";
+ this.imageUrl = "";
+ this.dataForm.remarks = "";
+ }
+ this.visible = true;
+ this.$nextTick(() => {
+ //this.$refs.dataForm.resetFields()
+ });
+ },
+ resClear() {
+ this.dataForm = {
+ methodImg: "",
+ methodName: "",
+ paramName1: "",
+ paramName2: "",
+ paramName3: "",
+ paramName4: "",
+ paramName5: "",
+ paramName6: "",
+ paramName7: "",
+ paramName8: "",
+ paramName9: "",
+ paramName10: "",
+ paramName11: "",
+ paramName12: "",
+ paramName13: "",
+ paramName14: "",
+ paramName15: "",
+ loginSafeword: "",
+ };
+ },
+ handleAvatarSuccess(res, file) {
+ this.dataForm.methodImg = res.data.path;
+ console.log(file);
+ this.imageUrl = URL.createObjectURL(file.raw);
+ console.log(this.imageUrl);
+ },
+ beforeAvatarUpload(file) {
+ // const isJPG = file.type === 'image/jpeg';
+ const isLt2M = file.size / 1024 / 1024 < 10;
+
+ // if (!isJPG) {
+ // this.$message.error('上传头像图片只能是 JPG 格式!');
+ // }
+ if (!isLt2M) {
+ this.$message.error("上传图片大小不能超过 10MB!");
+ }
+ // return isJPG && isLt2M;
+ return isLt2M;
+ },
+ changeVal(val) {
+ this.$forceUpdate();
+ },
+ // 表单提交
+ dataFormSubmit: Debounce(function () {
+ this.loading = true;
+ this.$refs["dataForm"].validate((valid) => {
+ if (valid) {
+ if (this.id) {
+ this.$http({
+ url: this.$http.adornUrl(`/paymentMethodConfig/update`), //修改
+ method: "post",
+ data: this.$http.adornData({
+ id: this.id,
+ methodImg: this.dataForm.methodImg,
+ methodName: this.dataForm.methodName,
+ methodType: this.arr.id,
+ paramName1: this.dataForm.paramName1,
+ paramName2: this.dataForm.paramName2,
+ paramName3: this.dataForm.paramName3,
+ paramName4: this.dataForm.paramName4,
+ paramName5: this.dataForm.paramName5,
+ paramName6: this.dataForm.paramName6,
+ paramName7: this.dataForm.paramName7,
+ paramName8: this.dataForm.paramName8,
+ paramName9: this.dataForm.paramName9,
+ paramName10: this.dataForm.paramName10,
+ paramName11: this.dataForm.paramName11,
+ paramName12: this.dataForm.paramName12,
+ paramName13: this.dataForm.paramName13,
+ paramName14: this.dataForm.paramName14,
+ paramName15: this.dataForm.paramName15,
+ loginSafeword: encrypt(this.dataForm.loginSafeword),
+ }),
+ }).then(({ data }) => {
+ if (data.code == 0) {
+ this.$message({
+ message: "操作成功",
+ type: "success",
+ duration: 1500,
+ onClose: () => {
+ this.resClear();
+ this.visible = false;
+ this.$emit("refreshDataList");
+ this.loading = false;
+ },
+ });
+ } else {
+ this.$message({
+ message: data.msg,
+ type: "error",
+ });
+ this.loading = false;
+ }
+ });
+ } else {
+ console.log(this.id);
+ this.$http({
+ url: this.$http.adornUrl(`/paymentMethodConfig/add`), //新增
+ method: "post",
+ data: this.$http.adornData({
+ type: 2, // 1.银行卡 2.c2c
+ methodImg: this.dataForm.methodImg,
+ methodName: this.dataForm.methodName,
+ methodType: this.arr.id,
+ paramName1: this.dataForm.paramName1,
+ paramName2: this.dataForm.paramName2,
+ paramName3: this.dataForm.paramName3,
+ paramName4: this.dataForm.paramName4,
+ paramName5: this.dataForm.paramName5,
+ paramName6: this.dataForm.paramName6,
+ paramName7: this.dataForm.paramName7,
+ paramName8: this.dataForm.paramName8,
+ paramName9: this.dataForm.paramName9,
+ paramName10: this.dataForm.paramName10,
+ paramName11: this.dataForm.paramName11,
+ paramName12: this.dataForm.paramName12,
+ paramName13: this.dataForm.paramName13,
+ paramName14: this.dataForm.paramName14,
+ paramName15: this.dataForm.paramName15,
+ }),
+ }).then(({ data }) => {
+ if (data.code == 0) {
+ this.$message({
+ message: "操作成功",
+ type: "success",
+ duration: 1500,
+ onClose: () => {
+ this.resClear();
+ this.visible = false;
+ this.$emit("refreshDataList");
+ this.loading = false;
+ },
+ });
+ } else {
+ this.$message({
+ message: data.msg,
+ type: "error",
+ });
+ this.loading = false;
+ }
+ });
+ }
+ }
+ });
+ }),
+ },
+};
+</script>
+<style scoped>
+.avatar-uploader .el-upload {
+ border: 1px dashed #d9d9d9;
+ border-radius: 6px;
+ cursor: pointer;
+ position: relative;
+ overflow: hidden;
+}
+.avatar-uploader .el-upload:hover {
+ border-color: #409eff;
+}
+.avatar-uploader-icon {
+ font-size: 28px;
+ color: #8c939d;
+ width: 178px;
+ height: 178px;
+ line-height: 178px;
+ text-align: center;
+}
+.avatar {
+ width: 178px;
+ height: 178px;
+ display: block;
+}
+</style>
--
Gitblit v1.9.3