Browse Source

1, 新增

MONSTER-ygh 10 months ago
parent
commit
3014c815f2

+ 22 - 6
src/views/tourism/financialManagement/detailsBox/productRefundManagementDetails.vue

@@ -82,11 +82,20 @@
               <span style="display: block; min-width: 250px;">{{ form.refundReason }}</span>
             </el-form-item>
             <el-form-item label="申请时间:">
-              <span style="display: block; min-width: 250px;">{{ form.auditTime }}</span>
+              <span style="display: block; min-width: 250px;">{{ form.createTime }}</span>
             </el-form-item>
             <el-form-item label="退款状态:">
               <dict-tag :options="dict.type.tourism_orderRefund_status" :value="form.status"/>
-              <span style="display: block; min-width: 250px;">{{ form.status }}</span>
+            </el-form-item>
+          </div>
+          <div style="display: flex;" v-if="form.errReason">
+            <el-form-item label="退款驳回原因:">
+              <span style="display: block; min-width: 250px;">{{ form.errReason }}</span>
+            </el-form-item>
+          </div>
+          <div style="display: flex;" v-if="form.remark">
+            <el-form-item label="退款备注:">
+              <span style="display: block; min-width: 250px;">{{ form.remark }}</span>
             </el-form-item>
           </div>
           <div>
@@ -156,7 +165,7 @@ export default {
       formStatus: null, // 0/null : 加载中 1 : 获取详情成功 2  : 获取详情失败 
       configUrl: {
         add: '', // 新增地址
-        details: '/merchant/merchantOrder/orderRefundList', // 详情地址
+        details: '/merchant/merchantOrder/orderRefundById', // 详情地址
         edit: '', // 编辑地址
         refundAudit: '/merchant/merchantOrder/refundAudit',// 审核接口
       },
@@ -252,11 +261,18 @@ export default {
         return
       } 
       this.loading = true
+      let params = {
+        refundId: this.form.id,// 退款ID-列表ID
+        status: type,
+      }
+      if(type==2) {
+        params['errReason'] = this.form.errReason
+      }else {
+        params['remark'] = this.form.errReason
+      }
       addTableApi(
         this.configUrl.refundAudit,{
-          id: this.form.id,// 退款ID-列表ID
-          auditStatus: type,
-          errReason: this.form.errReason,
+          ...params 
         }).then(response => {
           this.$modal.msgSuccess(`提交成功`);
           this.loading = false

+ 7 - 7
src/views/tourism/financialManagement/productRefundManagement.vue

@@ -100,6 +100,13 @@
               class-name="small-padding fixed-width"
             >
               <template slot-scope="scope" >
+                <el-button
+                size="mini"
+                type="text"
+                icon="el-icon-document"
+                @click="handleDetails(scope.row)"
+                v-hasPermi="configPermi.refundAudit"
+                >详情</el-button>
                 <el-button
                 size="mini"
                 type="text"
@@ -108,13 +115,6 @@
                 @click="refundAuditFun(scope.row)"
                 v-hasPermi="configPermi.refundAudit"
                 >审核</el-button>
-                <el-button
-                  size="mini"
-                  type="text"
-                  icon="el-icon-delete"
-                  @click="handleDelete(scope.row)"
-                  v-hasPermi="configPermi.delect"
-                >删除</el-button>
               </template>
             </el-table-column>
           </el-table>

+ 1 - 1
src/views/tourism/orderManagement/productOrders/detailsBox/productOrdersDetails.vue

@@ -68,7 +68,7 @@
               <el-table-column label="分类" align="center" key="classifyName" prop="classifyName" :show-overflow-tooltip="true" />
               <el-table-column label="单价(元)" align="center" key="salePrice" prop="salePrice" :show-overflow-tooltip="true" />
               <el-table-column label="数量" align="center" key="saleNum" prop="saleNum" :show-overflow-tooltip="true" />
-              <el-table-column label="实付金额(元)" align="center" key="realPrice" prop="realPrice" :show-overflow-tooltip="true" />
+              <el-table-column label="实付金额(元)" align="center" key="priceSubtotal" prop="priceSubtotal" :show-overflow-tooltip="true" />
             </el-table>
           </div>
           <div class="form-title"><span>收货信息</span></div>

+ 1 - 1
src/views/tourism/orderManagement/productOrders/productOrders.vue

@@ -103,7 +103,7 @@
 
           <el-table v-loading="loading" :data="tableList" @selection-change="handleSelectionChange">
             <el-table-column type="index" label="序号" align="center"  />
-            <el-table-column label="订单号" align="center" key="orderNum" prop="orderNum" v-if="columns[0].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="订单号" align="center" key="id" prop="id" v-if="columns[0].visible" :show-overflow-tooltip="true" />
             <el-table-column label="商品名称" align="center" key="goodsName" prop="goodsName" v-if="columns[1].visible" :show-overflow-tooltip="true" />
             <el-table-column label="下单人手机号" align="center" key="memberMobile" prop="memberMobile" v-if="columns[2].visible" :show-overflow-tooltip="true" />
             <el-table-column label="下单时间" align="center" key="createTime" prop="createTime" v-if="columns[3].visible" :show-overflow-tooltip="true" />

+ 196 - 112
src/views/tourism/scenicAreaManagement/navigationManagement/formBox/imageContainer.vue

@@ -1,128 +1,212 @@
 <template>
-    <div id="container" @mousedown="startDrag" @mousemove="doDrag" @mouseup="stopDrag">
-      <div id="preview" @wheel="wheelFun" @click="previewOnclick" :style="styleObject">
+  <div id="container-box">
+    <div>
+      <div>
+        <el-radio-group v-model="radio" @input="addEvent">
+          <el-radio :label="1">拖动</el-radio>
+          <el-radio :label="2">放大和绘点</el-radio>
+        </el-radio-group>
+      </div>
+      <!-- <div style="width: 200px;">
+        <el-slider v-model="value1" @click="inputValue" :step="0.01" :max="1"></el-slider>
+      </div> -->
+    </div>
+
+    <div id="container">
+      <div id="preview" :style="styleObject">
         <img :src="imageUrl" id="image" />
         <span :style="spanStyle"></span>
       </div>
     </div>
-  </template>
-   
-  <script>
-  export default {
-    data() {
-      return {
-        preview: null,
-        container: null,
-        image: null,
-        factor: {
-            scale: 1,
-        },
-        spanStyle: {
-          width: '10px',
-          height: '10px',
-          borderRadius: '5px',
-          background: 'red',
-          position: 'absolute',
-          left: '-10px',
-          top: '-10px',
-          transform: 'translate(-50%, -50%)'
-        },
-        imageUrl: null,
-        dragging: false,
-        offset: { x: 0, y: 0 },
-        styleObject: {
-          position: 'absolute',
-          top: '0',
-          left: '0'
-        }
-      };
+  </div>
+
+</template>
+
+<script>
+export default {
+  props: {
+    value: {
+      type: String,
+      default: ""
+    }
+  },
+  data() {
+    return {
+      preview: null,
+      container: null,
+      image: null,
+      factor: {
+        scale: 1,
+      },
+      spanStyle: {
+        width: '10px',
+        height: '10px',
+        borderRadius: '5px',
+        background: 'red',
+        position: 'absolute',
+        left: '-10px',
+        top: '-10px',
+        transform: 'translate(-50%, -50%)'
+      },
+      imageUrl: null,
+
+      offset: { x: 0, y: 0 },
+      styleObject: {
+        position: 'absolute',
+        top: '0',
+        left: '0'
+      },
+      value1: 0.9,
+
+      radio: null,
+      //  拖动事件
+      dragging: false,
+      isDragging: false,
+
+      // 滚动缩放事件
+      isZoom: false
+    };
+  },
+  mounted() {
+    this.preview = document.querySelector("#preview");
+    this.container = document.getElementById("container");
+    this.image = document.getElementById("image");
+  },
+  activated() {
+    console.log("dsffadsfasdf===")
+  },
+  methods: {
+    addEvent(type) {
+      console.log(type)
+      if (this.radio == 1) {
+        this.container.addEventListener("mousedown", this.startDrag) // 鼠标按下
+        this.container.addEventListener("mousemove", this.doDrag) // 鼠标移动
+        this.container.addEventListener("mouseup", this.stopDrag) // 鼠标松开
+        this.image.addEventListener("mouseup", this.stopDrag) // 鼠标松开
+        this.preview.addEventListener("mouseup", this.stopDrag) // 鼠标按下
+      } else {
+        this.container.removeEventListener("mousedown", this.startDrag) // 鼠标按下
+        this.container.removeEventListener("mousemove", this.doDrag) // 鼠标移动
+        this.container.removeEventListener("mouseup", this.stopDrag) // 鼠标松开
+        this.image.removeEventListener("mouseup", this.stopDrag) // 鼠标松开
+        this.preview.removeEventListener("mouseup", this.stopDrag) // 鼠标按下
+      }
+
+      if (this.radio == 2) {
+        this.preview.addEventListener("wheel", this.wheelFun) // 鼠标按下
+        this.preview.addEventListener("click", this.previewOnclick) // 鼠标移动
+      } else {
+        this.preview.removeEventListener("wheel", this.wheelFun) // 鼠标按下
+        this.preview.removeEventListener("click", this.previewOnclick) // 鼠标移动
+      }
     },
-    mounted() {
-        this.preview = document.querySelector("#preview");
-        this.container = document.getElementById("container");
-        this.image = document.getElementById("image");
+    initData(url) {
+      if(!url) return
+      this.imageUrl = url
+      let image = new Image();
+      image.src = url;
+      console.log("url====", url)
+      // 方式二、加载事件中获取
+      image.onload = () => {
+        console.log("sdfdsafds====", image.width)
+        this.image.style.width = image.width + 'px'
+        this.image.style.height = image.height + 'px'
+        this.preview.style.width = image.width + 'px'
+        this.preview.style.height = image.height + 'px'
+        this.addEvent()
+      };
     },
-    methods: {
-      initData(url){
-        this.imageUrl = url
-        let image = new Image();
-        image.src = url;
-        console.log("url====",url)
-        // 方式二、加载事件中获取
-        image.onload = () => {
-          console.log("sdfdsafds====",image.width)
-          this.image.style.width = image.width + 'px'
-          this.image.style.height = image.height + 'px'
-        };
-      },
-        previewOnclick(e) {
-            const needWidth =
-                e.offsetX / (this.container.clientWidth / this.image.naturalWidth);
-            const needHeight =
-                e.offsetY / (this.container.clientHeight / this.image.naturalHeight);
+    previewOnclick(e) {
+      const needWidth =
+        e.offsetX / (this.container.clientWidth / this.image.naturalWidth);
+      const needHeight =
+        e.offsetY / (this.container.clientHeight / this.image.naturalHeight);
 
-            const left = needWidth * (this.container.clientWidth / this.image.naturalWidth);
-            const top = needHeight * (this.container.clientHeight / this.image.naturalHeight);
-            this.spanStyle.left = left + "px"
-            this.spanStyle.top = top + "px"
-        },
-        wheelFun(event) {
-            //event.preventDefault();
+      const left = needWidth * (this.container.clientWidth / this.image.naturalWidth);
+      const top = needHeight * (this.container.clientHeight / this.image.naturalHeight);
+      this.spanStyle.left = left + "px"
+      this.spanStyle.top = top + "px"
+      this.$emit("input", left+ ',' + top);
+    },
+    wheelFun(event) {
+      event.preventDefault();
 
-            const scaleDelta = event.deltaY * -1; // 可根据实际需求调整缩放速度
-            const offsetX = event.offsetX / preview.clientWidth;
-            const offsetY = event.offsetY / preview.clientHeight;
+      const scaleDelta = event.deltaY * -1; // 可根据实际需求调整缩放速度
+      const offsetX = event.offsetX / preview.clientWidth;
+      const offsetY = event.offsetY / preview.clientHeight;
 
-            const scaleVal = scaleDelta > 0 ? 0.2 : -0.2;
-            this.factor.scale += scaleVal;
-            if (this.factor.scale < 1) {
-                this.factor = {
-                    scale: 1,
-                };
-            }
+      const scaleVal = scaleDelta > 0 ? 0.02 : -0.02;
+      this.factor.scale += scaleVal;
+      console.log("event.deltaY====", scaleDelta, this.factor.scale)
+      if (this.factor.scale > 0.5) {
+        this.factor.scale += scaleVal;
+      }
 
-            this.preview.style.transformOrigin = `${offsetX * 100}% ${offsetY * 100}%`;
-            this.preview.style.transform = `scale(${this.factor.scale})`;
-        },
-        startDrag(e) {
-          this.dragging = true;
-          this.offset.x = e.clientX - Number(this.styleObject.left.replace('px',''));
-          this.offset.y = e.clientY - Number(this.styleObject.top.replace('px',''));
-        },
-        doDrag(e) {
-          if (this.dragging) {
-            this.$set(this.styleObject,'left',e.clientX - this.offset.x + 'px')
-            this.$set(this.styleObject,'top',e.clientY - this.offset.y + 'px')
-          }
-        },
-        stopDrag() {
-          this.dragging = false;
-        }
+      this.preview.style.transformOrigin = `${offsetX * 100}% ${offsetY * 100}%`;
+      this.preview.style.transform = `scale(${this.factor.scale})`;
+    },
+    inputValue(value1) {
+      console.log("value1====", value1)
+      // this.preview.style.transform = `scale(${value1})`;
+    },
+    startDrag(e) {
+      this.dragging = true;
+      this.offset.x = e.clientX - Number(this.styleObject.left.replace('px', ''));
+      this.offset.y = e.clientY - Number(this.styleObject.top.replace('px', ''));
+    },
+    doDrag(e) {
+      if (this.dragging) {
+        this.$set(this.styleObject, 'left', e.clientX - this.offset.x + 'px')
+        this.$set(this.styleObject, 'top', e.clientY - this.offset.y + 'px')
+      }
+    },
+    stopDrag() {
+      console.log("鼠标抬起事件=====")
+      this.dragging = false;
     }
-  };
-  </script>
-   
-  <style>
-  #container {
-        width: 100%;
-        height: 500px;
-        position: relative;
-        overflow: hidden;
-        border: 1px solid #ccc;
+  },
+  watch: {
+    value() {
+      if(this.value) {
+        let list =this.value.split(',')
+        this.spanStyle.left = list[0] + "px"
+        this.spanStyle.top = list[1] + "px"
+      }else {
+        this.spanStyle.left = "-100px"
+        this.spanStyle.top = "-100px"
       }
+    }
+  }
+};
+</script>
+
+<style>
+#container-box {
+  width: 100%;
+}
 
-      #preview {
-        width: 500px;
-        height: 500px;
-        background: linear-gradient(to right, red , blue);
-        /* cursor: move;
+#container {
+  width: 100%;
+  height: 500px;
+  position: relative;
+  overflow: hidden;
+  border: 1px solid #ccc;
+  z-index: 99;
+}
+
+#preview {
+  width: 100%;
+  height: 100%;
+  /* transform: scale(var(--scale-value)); */
+  /* background: linear-gradient(to right, red , blue); */
+  /* cursor: move;
         user-select: none; */
-      }
+}
 
-      #image {
-        width: 100%;
-        height: 100%;
-        transition: transform 0.2s;
-        transform-origin: 0 0;
-      }
-  </style>
+#image {
+  width: 100%;
+  height: 100%;
+  transition: transform 0.2s;
+  transform-origin: 0 0;
+}
+</style>

+ 20 - 6
src/views/tourism/scenicAreaManagement/navigationManagement/formBox/scenicGuideForm.vue

@@ -94,9 +94,11 @@
           <qqMapBox ref="qqMapBox" @setDot="setDot" />
         </div>
         <!--  手绘图的位置  -->
-        <el-form-item label="手绘图定位:" prop="address"></el-form-item>
+        <el-form-item label="手绘图定位:" prop="margin">
+          <span>{{ form.margin ? form.margin : '' }}</span>
+        </el-form-item>
         <div style="width: 100%;height: 600px;">
-          <imageContainer ref="imageContainer"></imageContainer>
+          <imageContainer v-model="form.margin" ref="imageContainer"></imageContainer>
         </div>
       </el-form>
     </div>
@@ -156,6 +158,7 @@ export default {
         content: [{ required: true, message: "请输入开放状态", trigger: ["change","blur"] }],
         workTime: [{ required: true, message: "请输入营业时间", trigger: ["change","blur"] }],
         address: [{ required: true, message: "请输入地址", trigger: ["change","blur"] }],
+        margin: [{ required: true, message: "请选择手绘图定位", trigger: ["change","blur"] }],
       },
       pointTypeList: [],// 景点产品关联
       //  上传文件
@@ -194,6 +197,9 @@ export default {
           ...row,
           imgUrl: row.imgUrl?row.imgUrl.split(','):[]
         }
+        if(row.marginLeft) {
+          obj['margin'] = row.marginLeft + ',' + row.marginTop
+        }
         let res1 = await getTableDeatilsByIdApi(this.configUrl.imageUrl)
         if(res1.code == 200){
           this.$refs.imageContainer.initData(res1.data.imgUrl)
@@ -281,11 +287,20 @@ export default {
           this.loadingText = "提交数据中..."
           this.loading = true
           this.loadingText = "提交数据中..."
+          let params = JSON.parse(JSON.stringify(this.form))
+          if(params.imgUrl) {
+            params.imgUrl = params.imgUrl.join(',')
+          }
+          if(params.margin) {
+            let list = params.margin.split(',')
+            params['marginTop'] = list[1]
+            params['marginLeft'] = list[0]
+          }
+          delete params.margin
           if (this.model != 'ADD') {
             addTableApi(
               this.configUrl.edit,{
-                ...this.form,
-                imgUrl: this.form.imgUrl ? this.form.imgUrl.join(','):'',
+                ...params
               }).then(response => {
               this.$modal.msgSuccess("修改成功");
               this.loading = false
@@ -297,8 +312,7 @@ export default {
             })
           } else {
             addTableApi(this.configUrl.edit,{
-                ...this.form,
-                imgUrl: this.form.imgUrl ? this.form.imgUrl.join(','):'',
+                ...params
               }).then(response => {
               this.$modal.msgSuccess("新增成功");
               this.loading = false