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/etf-spots/linKen-add-or-undata.vue | 328 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 328 insertions(+), 0 deletions(-)
diff --git a/src/views/modules/etf-spots/linKen-add-or-undata.vue b/src/views/modules/etf-spots/linKen-add-or-undata.vue
new file mode 100644
index 0000000..d715131
--- /dev/null
+++ b/src/views/modules/etf-spots/linKen-add-or-undata.vue
@@ -0,0 +1,328 @@
+<template>
+ <el-dialog
+ :title="row ? '修改行情时间段设置' : '新增行情时间段设置'"
+ :close-on-click-modal="false"
+ :visible.sync="visible"
+ append-to-body
+ @close="handClose"
+ >
+ <el-form
+ :model="dataForm"
+ :rules="dataRule"
+ ref="dataForm"
+ @keyup.enter.native="dataFormSubmit()"
+ label-width="120px"
+ >
+ <el-form-item label="开始时间" prop="openTimeTs">
+ <el-date-picker
+ v-model="dataForm.openTimeTs"
+ type="datetime"
+ value-format="yyyy-MM-dd HH:mm:ss"
+ placeholder="选择日期时间"
+ >
+ </el-date-picker>
+ </el-form-item>
+ <el-form-item label="结束时间" prop="closeTimeTs">
+ <el-date-picker
+ v-model="dataForm.closeTimeTs"
+ type="datetime"
+ value-format="yyyy-MM-dd HH:mm:ss"
+ placeholder="选择日期时间"
+ >
+ </el-date-picker>
+ </el-form-item>
+ <el-form-item label="交易对" prop="symbol">
+ <el-select
+ v-model="options.symbol"
+ placeholder="请选择"
+ @change="changeVal()"
+ >
+ <el-option
+ v-for="item in options"
+ :key="item.symbol"
+ :label="item.name"
+ :value="item.symbol"
+ >
+ </el-option>
+ </el-select>
+ </el-form-item>
+ <el-form-item label="成交量" prop="turnover">
+ <el-input v-model="dataForm.turnover" placeholder="成交量"></el-input>
+ </el-form-item>
+ <el-form-item label="当前价格" prop="close" v-if="row">
+ <el-input
+ disabled
+ v-model="dataForm.close"
+ placeholder="当前价格"
+ ></el-input> </el-form-item>
+ <el-form-item label="最高价格" prop="high">
+ <el-input
+ v-model="dataForm.high"
+ placeholder="最高价格"
+ ></el-input> </el-form-item
+ ><el-form-item label="最低价格" prop="low">
+ <el-input v-model="dataForm.low" placeholder="最低价格"></el-input>
+ </el-form-item>
+ </el-form>
+ <span slot="footer" class="dialog-footer">
+ <el-button @click="visible = false">取消</el-button>
+ <el-button type="primary" @click="dataFormSubmit()">确定</el-button>
+ </span>
+ </el-dialog>
+</template>
+
+<script>
+import { treeDataTranslate } from "@/utils";
+import { Debounce } from "@/utils/debounce";
+import { encrypt } from "@/utils/crypto";
+export default {
+ data() {
+ return {
+ visible: false,
+ menuList: [],
+ menuListTreeProps: {
+ label: "name",
+ children: "children",
+ },
+ row: "", //forex->外汇,commodities->大宗商品,指数/ETF->indices, A-stocks->A股, HK-stocks->港股.US-stocks->美股,cryptos->虚拟货币
+ options: [
+ {
+ value: "forex",
+ label: "外汇",
+ },
+ {
+ value: "commodities",
+ label: "大宗商品",
+ },
+ {
+ value: "indices",
+ label: "指数/ETF",
+ },
+ {
+ value: "A-stocks",
+ label: "A股",
+ },
+ {
+ value: "HK-stocks",
+ label: "港股",
+ },
+ {
+ value: "US-stocks",
+ label: "美股",
+ },
+ {
+ value: "cryptos",
+ label: "虚拟货币",
+ },
+ ],
+ langug: [], // 语言
+ dataForm: {
+ closeTimeTs: "",
+ openTimeTs: "",
+ high: "",
+ low: "",
+ turnover: "",
+ uuid: "",
+ },
+
+ dataRule: {
+ sorted: [{ required: true, message: "排序不能为空", trigger: "blur" }],
+ decimals: [
+ { required: true, message: "精度不能为空", trigger: "blur" },
+ ],
+ maxmumOrder: [
+ { required: true, message: "最大下单量不能为空", trigger: "blur" },
+ ],
+ maxmumPrice: [
+ { required: true, message: "最高买单价不能为空", trigger: "blur" },
+ ],
+ minimumOrder: [
+ { required: true, message: "最小下单量不能为空", trigger: "blur" },
+ ],
+ minimumPrice: [
+ { required: true, message: "最低卖单价不能为空", trigger: "blur" },
+ ],
+ high: [
+ { required: true, message: "最高价格不能为空", trigger: "blur" },
+ ],
+ low: [{ required: true, message: "最低价格不能为空", trigger: "blur" }],
+ pipsAmount: [
+ { required: true, message: "最小挂单金额不能为空", trigger: "blur" },
+ ],
+ quoteCurrency: [
+ { required: true, message: "结算币种不能为空", trigger: "blur" },
+ ],
+ unitFee: [
+ { required: true, message: "手续费不能为空", trigger: "blur" },
+ ],
+ openTimeTs: [
+ { required: true, message: "开始时间不能为空", trigger: "blur" },
+ ],
+ closeTimeTs: [
+ { required: true, message: "结束时间不能为空", trigger: "blur" },
+ ],
+ turnover: [
+ { required: true, message: "成交量不能为空", trigger: "blur" },
+ ],
+ // sorted: [{ required: true, message: "排序不能为空", trigger: "blur" }],
+ },
+ tempKey: -666666, // 临时key, 用于解决tree半选中状态项不能传给后台接口问题. # 待优化
+ };
+ },
+ methods: {
+ init(arr, row) {
+ this.options = arr;
+ this.row = {...row} || "";
+ console.log(row)
+ if (row) {
+ this.options.symbol = row.symbol;
+ this.dataForm = row
+ console.log(row.openTimeTs)
+ if (typeof row.openTimeTs !== 'number') {
+ this.dataForm.openTimeTs =row.openTimeTs
+ this.dataForm.closeTimeTs = row.closeTimeTs
+ }else{
+ this.dataForm.openTimeTs = this.formatTimestamp(row.openTimeTs)
+ this.dataForm.closeTimeTs = this.formatTimestamp(row.closeTimeTs)
+ }
+ } else {
+ this.options.symbol = this.options[0].symbol;
+ // this.langug.value = this.langug[0].value;
+ }
+ this.visible = true;
+ },
+ // Open(call) {
+ // this.$prompt("登录人资金密码", "提示", {
+ // confirmButtonText: "确定",
+ // cancelButtonText: "取消",
+ // })
+ // .then(({ value }) => {
+ // this.dataForm.loginSafeword = value;
+ // if (call) {
+ // call();
+ // }
+ // })
+ // .catch(() => {
+ // this.$message({
+ // type: "info",
+ // message: "取消输入",
+ // });
+ // });
+ // },
+ changeVal(val) {
+ this.$forceUpdate();
+ },
+ formatTimestamp(timestamp) {
+ const date = new Date(timestamp)
+ const year = date.getFullYear();
+ const month = String(date.getMonth() + 1).padStart(2, '0');
+ const day = String(date.getDate()).padStart(2, '0');
+ const hours = String(date.getHours()).padStart(2, '0');
+ const minutes = String(date.getMinutes()).padStart(2, '0');
+ const seconds = String(date.getSeconds()).padStart(2, '0');
+ const milliseconds = String(date.getMilliseconds()).padStart(3, '0');
+
+ const formattedDate = `${year}-${month}-${day} ${hours}:${minutes}:${seconds} ${milliseconds}`;
+ return formattedDate;
+},
+ handClose() {
+ this.$data.dataForm = JSON.parse(
+ JSON.stringify(this.$options.data().dataForm)
+ );
+ this.$nextTick(() => {
+ this.$refs["dataForm"].clearValidate(); // 清除表单验证
+ });
+ this.langug.value = "";
+ this.options.value = "";
+ },
+ // 表单提交
+ dataFormSubmit: Debounce(function () {
+ let a = new Date(this.dataForm.openTimeTs);
+ let b = new Date(this.dataForm.closeTimeTs);
+ let aa = a.getTime();
+ let bb = b.getTime();
+ if (this.row) {
+ this.$refs["dataForm"].validate((valid) => {
+ if (valid) {
+ this.$http({
+ // 修改
+ url: this.$http.adornUrl(`/klineStageConfig/add`),
+ method: "post",
+ data: this.$http.adornData({
+ closeTimeTs: bb,
+ openTimeTs: aa,
+ symbol: this.options.symbol,
+ high: this.dataForm.high,
+ low: this.dataForm.low,
+ turnover: this.dataForm.turnover,
+ uuid:this.dataForm.uuid,
+ }),
+ }).then(({ data }) => {
+ if (data.code == 0) {
+ this.$message({
+ message: "操作成功",
+ type: "success",
+ duration: 1500,
+ onClose: () => {
+ this.visible = false;
+ this.$emit("refreshDataList");
+ },
+ });
+ } else {
+ this.$message({
+ message: data.msg,
+ type: "error",
+ duration: 1500,
+ onClose: () => {
+ this.visible = false;
+ },
+ });
+ }
+ });
+ }
+ });
+ } else {
+ this.$refs["dataForm"].validate((valid) => {
+ if (valid) {
+ this.$http({
+ // 新增
+ url: this.$http.adornUrl(`/klineStageConfig/add`),
+ method: "post",
+ data: this.$http.adornData({
+ closeTimeTs: bb,
+ openTimeTs: aa,
+ symbol: this.options.symbol,
+ name:this.options.symbol,
+ high: this.dataForm.high,
+ low: this.dataForm.low,
+ turnover: this.dataForm.turnover,
+ }),
+ }).then(({ data }) => {
+ if (data.code == 0) {
+ this.$message({
+ message: "操作成功",
+ type: "success",
+ duration: 1500,
+ onClose: () => {
+ this.visible = false;
+ this.$emit("refreshDataList");
+ },
+ });
+ } else {
+ this.$message({
+ message: data.msg,
+ type: "error",
+ duration: 1500,
+ onClose: () => {
+ this.visible = false;
+ },
+ });
+ }
+ });
+ }
+ });
+ }
+ }),
+ },
+};
+</script>
--
Gitblit v1.9.3