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/user-relation/basics-variety-add-or-update.vue |  578 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 578 insertions(+), 0 deletions(-)

diff --git a/src/views/modules/user-relation/basics-variety-add-or-update.vue b/src/views/modules/user-relation/basics-variety-add-or-update.vue
new file mode 100644
index 0000000..cf74603
--- /dev/null
+++ b/src/views/modules/user-relation/basics-variety-add-or-update.vue
@@ -0,0 +1,578 @@
+<template>
+  <el-dialog
+    :title="''"
+    :close-on-click-modal="false"
+    :visible.sync="visible"
+    @close="handClose"
+    width="600px"
+  >
+    <el-form
+      :model="dataForm"
+      ref="dataForm"
+      :rules="dataRule"
+      @keyup.enter.native="dataFormSubmit()"
+      label-width="120px"
+      label-position="top"
+      style="width: auto"
+      size="mini"
+    >
+      <span>详细信息</span>
+      <el-divider></el-divider>
+
+      <el-form-item v-if="!dataForm.uuid" label="用户UID" prop="userCode" style="width: auto">
+        <el-input
+          v-model="dataForm.userCode"
+          placeholder="请输入用户UID"
+          style="width: 510px"
+        ></el-input>
+      </el-form-item>
+
+      <el-form-item label="实名姓名" prop="name" style="width: auto">
+        <el-input
+          v-model="dataForm.name"
+          placeholder="请输入实名姓名"
+          style="width: 510px"
+        ></el-input>
+      </el-form-item>
+
+      <!-- <el-form-item label="证件名称" prop="idName" style="width: auto">
+        <el-input
+          v-model="dataForm.idName"
+          placeholder="请输入证件名称"
+          style="width: 510px"
+        ></el-input>
+      </el-form-item> -->
+
+      <el-form-item label="证件号码" prop="idNumber" style="width: auto">
+        <el-input
+          v-model="dataForm.idNumber"
+          placeholder="请输入证件号码"
+          style="width: 510px"
+        ></el-input>
+      </el-form-item>
+
+      <el-form-item label="国籍" prop="nationality" style="width: auto">
+        <el-select
+          v-model="dataForm.nationality"
+          placeholder="请选择国籍"
+          style="width: 510px"
+          filterable
+        >
+          <el-option
+            v-for="item in countryOptions"
+            :key="item.code"
+            :label="item.name"
+            :value="item.code"
+          ></el-option>
+        </el-select>
+      </el-form-item>
+
+      <el-form-item label="认证手机号" prop="phone" style="width: auto">
+        <el-input
+          v-model="dataForm.phone"
+          placeholder="请输入认证手机号"
+          style="width: 510px"
+        ></el-input>
+      </el-form-item>
+
+      <span>证件照</span>
+      <el-divider></el-divider>
+      <el-row>
+        <el-col :span="8">
+          <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="handleAvatarSuccess0"
+              :before-upload="beforeAvatarUpload0"
+            >
+              <img v-if="idFrontImg" :src="idFrontImg" class="avatar" />
+              <i v-else class="el-icon-plus avatar-uploader-icon"></i>
+            </el-upload>
+            <el-button
+              v-if="idFrontImg"
+              type="primary"
+              @click="open(idFrontImg)"
+              plain
+              size="small"
+            >
+              查看
+            </el-button>
+          </el-form-item>
+        </el-col>
+        <el-col :span="8">
+          <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="handleAvatarSuccess1"
+              :before-upload="beforeAvatarUpload1"
+            >
+              <img v-if="idBackImg" :src="idBackImg" class="avatar" />
+              <i v-else class="el-icon-plus avatar-uploader-icon"></i>
+            </el-upload>
+            <el-button
+              v-if="idBackImg"
+              type="primary"
+              @click="open(idBackImg)"
+              plain
+              size="small"
+            >
+              查看
+            </el-button>
+          </el-form-item>
+        </el-col>
+        <!-- <el-col :span="8">
+          <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="handleAvatarSuccess2"
+              :before-upload="beforeAvatarUpload2"
+            >
+              <img v-if="handheldPhoto" :src="handheldPhoto" class="avatar" />
+              <i v-else class="el-icon-plus avatar-uploader-icon"></i>
+            </el-upload>
+            <el-button
+              v-if="handheldPhoto"
+              type="primary"
+              @click="open(handheldPhoto)"
+              plain
+              size="small"
+            >
+              查看
+            </el-button>
+          </el-form-item>
+        </el-col> -->
+      </el-row>
+      <div class="mainCant" v-if="imgViewerVisible">
+        <div>
+          <el-image-viewer
+            :on-close="closeImgViewer"
+            class="picLoad"
+            :url-list="imgList"
+          />
+        </div>
+        <el-button  @click="closeImgViewer">关闭</el-button>
+      </div>
+    </el-form>
+    <span slot="footer" class="dialog-footer">
+      <el-button  @click="visible = false">关闭</el-button>
+      <el-button type="primary" @click="dataFormSubmit()">确定</el-button>
+    </span>
+    <!-- 确认弹窗-end -->
+  </el-dialog>
+</template>
+
+<script>
+import { Debounce } from "@/utils/debounce";
+import { countries } from "@/utils/countryList";
+import { isMobile } from "@/utils/validate";
+export default {
+  data() {
+    return {
+      imgViewerVisible: false,
+      imgList: "",
+      idFrontImg1: "",
+      idBackImg1: "",
+      handheldPhoto1: "",
+      idFrontImg: "",
+      idBackImg: "",
+      // handheldPhoto: "",
+      visible: false,
+      dialogFormVisible: true,
+      formLabelWidth: "120px",
+      menuList: [],
+      menuListTreeProps: {
+        label: "name",
+        children: "children",
+      },
+      options: [],
+      row: "",
+      dataForm: {
+        id: "",
+        idCode: "",
+        projectName: "",
+        issuePrice: "",
+        currency: "usdt",
+        expectedLaunchTime: "",
+        subscriptionEndTime: "",
+        subscriptionStartTime: "",
+        publishTime: "",
+        minQuantity: "",
+        maxQuantity: "",
+        whitePagerAddress: "",
+        relatedStockName: [],
+        name: "",
+        natialName: "",
+        nationality: "",
+        phone: "",
+        userCode: "",
+      },
+      countryOptions: [],
+      fixstork: [], //返回的相关股票品种
+      stocks: [],
+      dataRule: {
+        userCode: [
+          { required: true, message: "用户UID不能为空", trigger: "blur" },
+        ],
+        name: [
+          { required: true, message: "实名姓名不能为空", trigger: "blur" },
+        ],
+        // idName: [
+        //   { required: true, message: "证件名称不能为空", trigger: "blur" },
+        // ],
+        idNumber: [
+          { required: true, message: "证件号码不能为空", trigger: "blur" },
+        ],
+        nationality: [
+          { required: true, message: "国籍不能为空", trigger: "change" },
+        ],
+        phone: [
+          { required: true, message: "认证手机号不能为空", trigger: "blur" },
+          // { validator: (rule, value, callback) => {
+          //     if (value && !isMobile(value)) {
+          //       callback(new Error("手机号格式错误"));
+          //     } else {
+          //       callback();
+          //     }
+          //   }, trigger: "blur" },
+        ],
+        relatedStockName: [
+          { required: true, message: "成分股不能为空", trigger: "blur" },
+        ],
+        projectName: [{ required: true, message: "不能为空", trigger: "blur" }],
+        turnover: [
+          { required: true, message: "成交量不能为空", trigger: "blur" },
+        ],
+        initPrice: [
+          { required: true, message: "初始化价格不能为空", trigger: "blur" },
+        ],
+        minProfitLoss: [
+          {
+            required: true,
+            message: "最小变动单位的盈亏金额不能为空",
+            trigger: "blur",
+          },
+        ],
+        minUnit: [
+          { required: true, message: "最小变动单位不能为空", trigger: "blur" },
+        ],
+        fee: [
+          { required: true, message: "每张手续费不能为空", trigger: "blur" },
+        ],
+        amount: [
+          { required: true, message: "每张金额不能为空", trigger: "blur" },
+        ],
+      },
+    };
+  },
+  mounted() {
+    this.initCountryOptions();
+  },
+  components: {
+    "el-image-viewer": () =>
+      import("element-ui/packages/image/src/image-viewer"),
+  },
+  methods: {
+    init(row) {
+      //console.log(row);
+      this.dataForm = {};
+      this.visible = true;
+      if (row && row.uuid) {
+        // 编辑模式:获取详情
+        let id = row.uuid;
+        this.getDesc(id);
+      } else {
+        // 新增模式:初始化空表单
+        this.$nextTick(() => {
+          if (this.$refs["dataForm"]) {
+            this.$refs["dataForm"].clearValidate();
+          }
+        });
+      }
+    },
+    handClose() {
+      this.$data.dataForm = JSON.parse(
+        JSON.stringify(this.$options.data().dataForm)
+      );
+      this.$nextTick(() => {
+        this.$refs["dataForm"].clearValidate(); // 清除表单验证
+      });
+    },
+    changeVal(val) {
+      this.$forceUpdate();
+    },
+    initCountryOptions() {
+      // 从国家列表中提取选项
+      const countryList = countries["zh-CN"] || countries["en"];
+      this.countryOptions = Object.keys(countryList).map((key) => ({
+        code: key,
+        name: countryList[key].name,
+      }));
+      // 按名称排序
+      this.countryOptions.sort((a, b) => a.name.localeCompare(b.name, "zh-CN"));
+    },
+    dataFormSubmit: Debounce(function () {
+      this.UpdateProjectBreed();
+    }),
+    open(img) {
+      // console.log(img)
+      // const image = new Image();
+      // image.src = img;
+      // const newWindow = window.open();
+      // newWindow.document.body.appendChild(image);
+      this.imgViewerVisible = true;
+      this.imgList = [img];
+      const m = (e) => {
+        e.preventDefault();
+      };
+      document.body.style.overflow = "hidden";
+      document.addEventListener("touchmove", m, false); // 禁止页面滑动
+    },
+    closeImgViewer() {
+      this.imgViewerVisible = false;
+      const m = (e) => {
+        e.preventDefault();
+      };
+      document.body.style.overflow = "auto";
+      document.removeEventListener("touchmove", m, true);
+    },
+    handleAvatarSuccess0(res, file) {
+      if (res.code == 0) {
+        this.dataForm.idFrontImg = URL.createObjectURL(file.raw); //显示地址
+        this.dataForm.imgUrl = res.data.path; //接口传递
+        this.idFrontImg = this.dataForm.idFrontImg;
+        this.idFrontImg1 = this.dataForm.imgUrl;
+      } else {
+        this.$message({
+          message: res.msg,
+          type: "error",
+          duration: 1500,
+          onClose: () => {},
+        });
+      }
+    },
+    beforeAvatarUpload0(file) {
+      // const isJPG = file.type === 'image/jpeg';
+      const isLt2M = file.size / 1024 / 1024 < 10;
+      if (!isLt2M) {
+        this.$message.error("上传图片大小不能超过 10MB!");
+      }
+      return isLt2M;
+    },
+    handleAvatarSuccess1(res, file) {
+      if (res.code == 0) {
+        this.dataForm.idBackImg = URL.createObjectURL(file.raw); //显示地址
+        this.dataForm.imgUrl = res.data.path; //接口传递
+        this.idBackImg = this.dataForm.idBackImg || "";
+        this.idBackImg1 = this.dataForm.imgUrl;
+      } else {
+        this.$message({
+          message: res.msg,
+          type: "error",
+          duration: 1500,
+          onClose: () => {},
+        });
+      }
+    },
+    beforeAvatarUpload1(file) {
+      // const isJPG = file.type === 'image/jpeg';
+      const isLt2M = file.size / 1024 / 1024 < 10;
+      if (!isLt2M) {
+        this.$message.error("上传图片大小不能超过 10MB!");
+      }
+      return isLt2M;
+    },
+    handleAvatarSuccess2(res, file) {
+      if (res.code == 0) {
+        this.dataForm.handheldPhoto = URL.createObjectURL(file.raw); //显示地址
+        this.dataForm.imgUrl = res.data.path; //接口传递
+        this.handheldPhoto = this.dataForm.handheldPhoto || "";
+        this.handheldPhoto1 = this.dataForm.imgUrl;
+      } else {
+        this.$message({
+          message: res.msg,
+          type: "error",
+          duration: 1500,
+          onClose: () => {},
+        });
+      }
+    },
+    beforeAvatarUpload2(file) {
+      // const isJPG = file.type === 'image/jpeg';
+      const isLt2M = file.size / 1024 / 1024 < 10;
+      if (!isLt2M) {
+        this.$message.error("上传图片大小不能超过 10MB!");
+      }
+      return isLt2M;
+    },
+    UpdateProjectBreed() {
+      //start
+      this.$refs["dataForm"].validate((valid) => {
+        if (valid) {
+          const isEdit = this.dataForm.uuid;
+          const requestData = {
+            userCode: this.dataForm.userCode,
+            name: this.dataForm.name,
+            idNumber: this.dataForm.idNumber,
+            nationality: this.dataForm.nationality,
+            phone: this.dataForm.phone,
+            idFrontImg: this.idFrontImg1,
+            idBackImg: this.idBackImg1,
+            // handheldPhoto: this.handheldPhoto1,
+          };
+          
+          // 编辑模式需要传递 uuid
+          if (isEdit) {
+            requestData.uuid = this.dataForm.uuid;
+          }
+
+          // 新增和编辑的接口是一样的, 只是编辑需要多传个uuid
+          this.$http({
+            url: this.$http.adornUrl('/edit'),
+            method: "put",
+            data: this.$http.adornData(requestData),
+          }).then(({ data }) => {
+            if (data.code == 0) {
+              this.$message({
+                message: "操作成功",
+                type: "success",
+                duration: 1500,
+                onClose: () => {
+                  this.dialogFormVisible = false;
+                  this.visible = false;
+                  this.$emit("refreshDataList");
+                },
+              });
+            } else {
+              this.$message({
+                message: data.msg,
+                type: "error",
+                duration: 1500,
+                onClose: () => {
+                  this.dialogFormVisible = false;
+                  this.visible = false;
+                },
+              });
+            }
+          });
+        }
+      });
+      //end
+    },
+    //获取详情
+    getDesc(uuid) {
+      this.$http({
+        url: this.$http.adornUrl("/getById/" + uuid),
+        method: "get",
+      }).then(({ data }) => {
+        if (data.code == 0) {
+          this.dataForm = data.data;
+          // 如果后端返回的是国家代码,直接使用;如果返回的是名称,需要找到对应的代码
+          if (this.dataForm.nationality && countries["zh-CN"] && countries["zh-CN"][this.dataForm.nationality]) {
+            this.dataForm.natialName = countries["zh-CN"][this.dataForm.nationality]["name"];
+          } else if (this.dataForm.nationality) {
+            // 如果 nationality 是代码但找不到,保持原值
+            this.dataForm.nationality = this.dataForm.nationality;
+          } else {
+            this.dataForm.nationality = "";
+          }
+          this.dataForm.phone = this.dataForm.phone || "";
+          this.dataForm.userCode = this.dataForm.userCode || "";
+          this.idFrontImg = this.dataForm.idFrontImg || "";
+          this.idBackImg = this.dataForm.idBackImg || "";
+          // this.handheldPhoto = this.dataForm.handheldPhoto || "";
+        } else {
+          this.$message({
+            message: data.msg,
+            type: "error",
+            duration: 1500,
+          });
+        }
+      });
+    },
+  },
+};
+</script>
+
+<style scoped>
+.mainCant{
+  position: fixed;
+    z-index: 9998;
+    width: 1200px;
+    top: 0;
+    left: 20%;
+    height: 100%;
+    background: rgba(10, 10, 10, 0.7);
+    /* background: red; */
+}
+.picLoad {
+  position: absolute;
+  width: 600px;
+  height: 100%;
+  left: 35%;
+  margin: 0 auto;
+  top: 100px;
+  z-index: 9999 !important;
+}
+.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;
+}
+
+.frame {
+  width: 700px;
+}
+
+.customWidth1 {
+  position: relative;
+  margin: 0 auto 50px;
+  border-radius: 2px;
+  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
+  box-sizing: border-box;
+  width: 60%;
+}
+/* 
+  ::deep .customWidth {
+     width: 45%;
+  }  */
+::v-deep .el-image-viewer__actions {
+  position: relative;
+    left: 30%;
+    z-index: 9999;
+    top: 70%;
+    font-size: 25px;
+    color: #8a9093;
+    background: rgba(10, 10, 10, 0.7);
+    width: 144px;
+    /* margin: 0; */
+    padding: 0 0 0 17px;
+    border-radius: 20px;
+}
+</style>

--
Gitblit v1.9.3