浏览代码

分享好友

潘超林 4 月之前
父节点
当前提交
b3d96d5da3

+ 13 - 209
TUIKit/components/TUIChat/message-list/message-elements/message-custom.vue

@@ -1,185 +1,20 @@
 <template>
   <div class="custom">
-    <!-- {{ isCustom }} -->
-    <template v-if="isCustom.businessID === 'product_message'">
+    <template v-if="isCustom.businessID === 'order'">
       <div class="evaluate">
         <div @click="product(isCustom)">
           <div class="left">
             <img
-              :src="isCustom.pic"
+              :src="isCustom.imageUrl"
               style="width: 80px; height: 80px; border-radius: 10px"
             />
             <div class="right">
               <div class="label">
-                {{ isCustom.spuName }}
+                {{ isCustom.title }}
               </div>
+              <div class="label">描述:{{ isCustom.spuDesc }}</div>
               <div style="font-weight: 400; font-size: 28rpx">
-                {{ isCustom.price.toFixed(2) }}元/{{ isCustom.unit }}
-              </div>
-            </div>
-          </div>
-        </div>
-      </div>
-    </template>
-
-    <template v-else-if="isCustom.businessID === 'modify_order_cost'">
-      <div class="evaluate">
-        <span style="font-size: 36rpx; line-height: 44rpx"
-          >老板,请及时修改订单费用!</span
-        >
-        <div @click="productOrder(isCustom)" style="margin-top: 10px">
-          <div class="left">
-            <img
-              :src="isCustom.pic"
-              style="width: 80px; height: 80px; border-radius: 10px"
-            />
-            <div class="right">
-              <div class="label">
-                {{ isCustom.spuName }}
-              </div>
-
-              <div style="font-weight: 400; font-size: 28rpx" v-if="userType == 0">
-                {{ isCustom.price.toFixed(2) }}元/{{ isCustom.unit }}
-              </div>
-              <div style="font-weight: 400; font-size: 28rpx" v-else>
-                {{
-                  isCustom.goodsAmount + isCustom.serviceFee + isCustom.freightFee
-                }}元/{{ isCustom.unit }}
-              </div>
-            </div>
-          </div>
-          <div style="line-height: 32px; margin-top: 10px">
-            <div>
-              <span class="name">姓名 :</span>
-              <span class="value">{{ isCustom.consigneeContactName }}</span>
-            </div>
-            <div>
-              <span class="name">电话 :</span>
-              <span class="value">{{ isCustom.consigneeContactMobile }}</span>
-            </div>
-            <div>
-              <span class="name">地址 :</span>
-              <span class="value">{{ isCustom.consigneeAddressDetail }}</span>
-            </div>
-          </div>
-        </div>
-      </div>
-    </template>
-
-    <template v-else-if="isCustom.businessID === 'reminder_pay'">
-      <div class="evaluate">
-        <span style="font-size: 36rpx; line-height: 44rpx">亲,请及时付款!</span>
-        <div @click="productOrder(isCustom)" style="margin-top: 10px">
-          <div class="left">
-            <img
-              :src="isCustom.pic"
-              style="width: 80px; height: 80px; border-radius: 10px"
-            />
-            <div class="right">
-              <div class="label">
-                {{ isCustom.spuName }}
-              </div>
-              <div style="font-weight: 400; font-size: 28rpx" v-if="userType == 0">
-                {{ isCustom.price.toFixed(2) }}元/{{ isCustom.unit }}
-              </div>
-              <div style="font-weight: 400; font-size: 28rpx" v-else>
-                {{
-                  (
-                    isCustom.goodsAmount +
-                    isCustom.serviceFee +
-                    isCustom.freightFee
-                  ).toFixed(2)
-                }}元/{{ isCustom.unit }}
-              </div>
-            </div>
-          </div>
-          <div style="line-height: 32px; margin-top: 10px">
-            <div>
-              <span class="name">姓名 :</span>
-              <span class="value">{{ isCustom.consigneeContactName }}</span>
-            </div>
-            <div>
-              <span class="name">电话 :</span>
-              <span class="value">{{ isCustom.consigneeContactMobile }}</span>
-            </div>
-            <div>
-              <span class="name">地址 :</span>
-              <span class="value">{{ isCustom.consigneeAddressDetail }}</span>
-            </div>
-          </div>
-        </div>
-      </div>
-    </template>
-    <template v-else-if="isCustom.businessID === 'order_deliver_goods'">
-      <div class="evaluate">
-        <span style="font-size: 36rpx; line-height: 44rpx">老板,请尽快发货!</span>
-        <div @click="productOrder(isCustom)" style="margin-top: 10px">
-          <div class="left">
-            <img
-              :src="isCustom.pic"
-              style="width: 80px; height: 80px; border-radius: 10px"
-            />
-            <div class="right">
-              <div class="label">
-                {{ isCustom.spuName }}
-              </div>
-              <div style="font-weight: 400; font-size: 28rpx" v-if="userType == 0">
-                {{ isCustom.price }}元/{{ isCustom.unit }}
-              </div>
-              <div style="font-weight: 400; font-size: 28rpx" v-else>
-                {{
-                  (
-                    isCustom.goodsAmount +
-                    isCustom.serviceFee +
-                    isCustom.freightFee
-                  ).toFixed(2)
-                }}元/{{ isCustom.unit }}
-              </div>
-            </div>
-          </div>
-          <div style="line-height: 32px; margin-top: 10px">
-            <div>
-              <span class="name">姓名 :</span>
-              <span class="value">{{ isCustom.consigneeContactName }}</span>
-            </div>
-            <div>
-              <span class="name">电话 :</span>
-              <span class="value">{{ isCustom.consigneeContactMobile }}</span>
-            </div>
-            <div>
-              <span class="name">地址 :</span>
-              <span class="value">{{ isCustom.consigneeAddressDetail }}</span>
-            </div>
-          </div>
-        </div>
-      </div>
-    </template>
-    <template v-else-if="isCustom.businessID === 'order_pay'">
-      <div class="evaluate">
-        <span style="font-size: 36rpx; line-height: 44rpx"
-          >订单价格已修改,请及时付款!</span
-        >
-        <div @click="productOrder(isCustom)" style="margin-top: 10px">
-          <div class="left">
-            <img
-              :src="isCustom.pic"
-              style="width: 80px; height: 80px; border-radius: 10px"
-            />
-            <div class="right">
-              <div class="label">
-                {{ isCustom.spuName }}
-              </div>
-              <div style="font-weight: 400; font-size: 28rpx" v-if="userType == 0">
-                {{ isCustom.price.toFixed(2) }}元/{{ isCustom.unit }}
-              </div>
-              <div style="font-weight: 400; font-size: 28rpx" v-else>
-                {{
-                  (
-                    isCustom.goodsAmount +
-                    isCustom.serviceFee +
-                    isCustom.freightFee
-                  ).toFixed(2)
-                }}元/{{ isCustom.unit }}
+                价格:{{ isCustom.price.toFixed(2) }}元/{{ isCustom.unit }}
               </div>
             </div>
           </div>
@@ -232,49 +67,18 @@ watchEffect(() => {
 const openLink = (url: any) => {
   window.open(url);
 };
-// const productOrderPay = async (record) => {
-//   let userid = uni.getStorageSync("userId");
-//   if (userid == record.shopOwnerId) {
-//     let res = await mesApi.default.orderDetail(record.orderId);
-//     if (res.code == 200) {
-//       let item = res.data;
-//       webUni.webView.navigateTo({
-//         url: `/subpages/my/product-orders/sell-order-details?id=${item.id}&item=${item.consigneeAddress.contact.contactMobile}&orderStatus=${item.orderStatus}&transportStatus=${item.transportStatus}&invoiceStatus=${item.invoiceStatus}&currentIndex=1`,
-//       });
-//     }
-//     console.log(res);
-//   } else {
-//     webUni.webView.navigateTo({
-//       url: `/subpages/my/product-orders/buy-order-details?id=` + record.orderId,
-//     });
-//   }
-// };
-const userType = ref();
-const productOrder = async (record) => {
-  let userid = uni.getStorageSync("userId");
-  if (userid == record.shopOwnerId) {
-    userType.value = 1;
-    let res = await mesApi.default.orderDetail(record.orderId);
-    if (res.code == 200) {
-      let item = res.data;
-      webUni.webView.navigateTo({
-        url: `/subpages/my/product-orders/sell-order-details?id=${item.orderId}&item=${item.consigneeAddress.contact.contactMobile}&orderStatus=${item.orderStatus}&transportStatus=${item.transportStatus}&invoiceStatus=${item.invoiceStatus}&currentIndex=1`,
-      });
-    }
-    console.log(res);
+
+const product = (record) => {
+  if (record.saleType == 2) {
+    webUni.webView.redirectTo({
+      url: `/subpages/home/carpoolGoods/product-details?id=` + record.id,
+    });
   } else {
-    userType.value = 0;
-    webUni.webView.navigateTo({
-      url: `/subpages/my/product-orders/buy-order-details?id=` + record.orderId,
+    webUni.webView.redirectTo({
+      url: `/subpages/home/supply-hall/product-details?id=` + record.id,
     });
   }
 };
-
-const product = (record) => {
-  webUni.webView.navigateTo({
-    url: `/subpages/home/carpoolGoods/product-details?id=` + record.id,
-  });
-};
 </script>
 <style lang="scss" scoped>
 @import "../../../../assets/styles/common";

+ 65 - 7
TUIKit/components/TUIConversation/index.vue

@@ -50,10 +50,11 @@
         @getPassingRef="getPassingRef"
       />
     </div>
+    <div></div>
   </div>
 </template>
 <script lang="ts" setup>
-import { TUIStore, StoreName } from "@tencentcloud/chat-uikit-engine";
+import { TUIStore, StoreName, TUIChatService } from "@tencentcloud/chat-uikit-engine";
 import { TUIGlobal } from "@tencentcloud/universal-api";
 import { ref, onMounted } from "../../adapter-vue";
 // import TUISearch from "../TUISearch/index.vue";
@@ -66,8 +67,8 @@ import { onHide, onShow, onLoad } from "@dcloudio/uni-app";
 // uniapp packaged mini-programs are integrated by default, and the default initialization entry file is imported here
 // TUIChatKit init needs to be encapsulated because uni vue2 will report an error when compiling H5 directly through conditional compilation
 import "./entry.ts";
-
 // #endif
+const centerDialogVisibl = ref(false);
 const emits = defineEmits(["handleSwitchConversation"]);
 const totalUnreadCount = ref(0);
 const headerRef = ref<typeof ConversationHeader>();
@@ -123,11 +124,68 @@ const book = () => {
   });
 };
 
-const handleSwitchConversation = (conversationID: string) => {
-  TUIGlobal?.navigateTo({
-    url: "/TUIKit/components/TUIChat/index",
-  });
-  emits("handleSwitchConversation", conversationID);
+function getQueryString(name) {
+  var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
+  var r = window.location.search.substr(1).match(reg);
+  if (r != null) {
+    return unescape(r[2]);
+  }
+  return null;
+}
+const spuInfo = ref();
+const handleSwitchConversation = async (conversationID: string) => {
+  let spuId = getQueryString("spuId");
+  let share = getQueryString("share");
+  if (spuId && share === "1") {
+    let res = await msgApi.default.getSupplyDetails({ spuId: spuId });
+    console.log(res);
+    spuInfo.value = res.data;
+    uni.showModal({
+      title: "提示",
+      content: `是否确认分享给该好友`,
+      success: function (res) {
+        if (res.confirm) {
+          console.log("用户点击确定");
+          let promise = TUIChatService.sendCustomMessage({
+            payload: {
+              data: JSON.stringify({
+                saleType: spuInfo.value.saleType,
+                id: spuInfo.value.id,
+                // 订单类消息标识字段
+                businessID: "order",
+                // 订单标题
+                title: spuInfo.value.title,
+                // 订单描述
+                description: spuInfo.value.spuDesc,
+                // 订单价格
+                price: spuInfo.value.lowestPrice,
+                // 订单 url
+                link: "https://buy.cloud.tencent.com/avc?ver=ultimate",
+                // 订单封面图
+                imageUrl: spuInfo.value.pic,
+                unit: spuInfo.value.unit,
+              }),
+              description: "",
+              extension: "",
+            },
+          });
+          console.log("promise", promise);
+
+          TUIGlobal?.navigateTo({
+            url: "/TUIKit/components/TUIChat/index",
+          });
+          emits("handleSwitchConversation", conversationID);
+        } else if (res.cancel) {
+          console.log("用户点击取消");
+        }
+      },
+    });
+  } else {
+    TUIGlobal?.navigateTo({
+      url: "/TUIKit/components/TUIChat/index",
+    });
+    emits("handleSwitchConversation", conversationID);
+  }
 };
 
 const closeChildren = () => {

+ 7 - 0
api/message/index.js

@@ -5,6 +5,13 @@ let request = Request.http;
 
 
 export default {
+    getSupplyDetails(param) {
+        return request({
+            url: '/goods/app/v1/prods/find',
+            method: 'get',
+            data: param,
+        })
+    },
     /**
   * 获取所有群组
   * @param {*} param 

+ 14 - 0
pages/views/login.vue

@@ -15,19 +15,33 @@ const inputValue = ref("");
 
 const userSigs = ref();
 onLoad((options) => {
+  let share = getQueryString("share");
+  let spuId = getQueryString("spuId");
   let personId = getQueryString("personId");
   let type = getQueryString("type");
   let openid = getQueryString("openid");
   // 获取跳转的token和userId
   let token = getQueryString("token");
   let id = getQueryString("id");
+  console.log("ssss", spuId == "undefined");
+
+  uni.setStorageSync("spuId", spuId);
   uni.setStorageSync("personId", personId);
   uni.setStorageSync("type", type);
   uni.setStorageSync("token", token);
   uni.setStorageSync("userId", id);
   uni.setStorageSync("openid", openid);
+  uni.setStorageSync("share", share);
   let userSig = getQueryString("userSig");
   uni.setStorageSync("userSig", userSig);
+
+  if (share == undefined || share == "undefined") {
+    uni.removeStorageSync("share");
+  }
+  if (spuId == undefined || spuId == "undefined") {
+    uni.removeStorageSync("spuId");
+  }
+
   userSigs.value = userSig;
   let params = {
     token: token,