From acf8eb9d7af7359b689122a5fe1ef1dd5d2de80c Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期四, 25 七月 2024 13:49:21 +0800
Subject: [PATCH] 提交
---
wechat_jiaxuan/pages/calculator/index.js | 186 ++++++++++++++++++++++++---------------------
1 files changed, 99 insertions(+), 87 deletions(-)
diff --git a/wechat_jiaxuan/pages/calculator/index.js b/wechat_jiaxuan/pages/calculator/index.js
index 560f42b..e8ef0df 100644
--- a/wechat_jiaxuan/pages/calculator/index.js
+++ b/wechat_jiaxuan/pages/calculator/index.js
@@ -1,6 +1,7 @@
// pages/calculator/index.js
// import { imageUrl } from '../../utils/config'
// import { calculatorOption, calculatorSave, decodePhone, bindPhone } from '../../api/index'
+import { getBjParamConfig, saveRenovationCalculator, getDictData, getWxMiniPhone, binDingPhone } from '../../api/index'
// import Ls from '../../utils/storage'
// let ls = new Ls
Page({
@@ -9,7 +10,7 @@
* 椤甸潰鐨勫垵濮嬫暟鎹�
*/
data: {
- // background: imageUrl + 'calculator/background.jpg',
+ background: '',
userPhone: '',
type: '',
info: '',
@@ -20,7 +21,8 @@
'涓�瀹や竴鍘�', '涓ゅ涓�鍘�', '涓ゅ涓ゅ巺', '涓夊涓ゅ巺',
'鍥涘涓ゅ巺', '浜斿涓ゅ巺鍙婁互涓�'
],
- calculatorOptions: [],
+ calculatorOptions: {},
+ activeList: [],
showPopup: false,
activePicker: '',
pickerIndex: 0,
@@ -29,7 +31,14 @@
containerContentStyle: 'hidden;'
},
- // 杩斿洖涓婁竴椤�
+ onLoad: function (options) {
+ let that = this
+ this.getCalculatorOption()
+ const userInfo = wx.getStorageSync('member')
+ if (userInfo.phone) {
+ that.setData({ userPhone: userInfo.phone })
+ }
+ },
navigateBack () {
wx.navigateBack({
delta: 1,
@@ -71,87 +80,101 @@
let { activePicker, pickerIndex } = this.data
this.setData({ [activePicker]: pickerIndex, showPopup: false })
},
-
+
// 鑾峰彇鐢ㄦ埛鎵嬫満鍙�
getPhoneNumber (e) {
- // console.log(e)
- let that = this
- decodePhone({ code: e.detail.code })
- .then(res => {
- if (res.phone === undefined || res.phone.length === null || !res.phone) {
- wx.showToast({
- title: res.msg,
- icon: 'none'
- })
- } else {
- bindPhone({ phone: res.phone })
- .then(newInfo => {
- ls.set('userInfo', newInfo.member)
- that.setData({ userPhone: res.phone })
- that.submit()
- })
+ const data = { ...e.detail }
+ getWxMiniPhone({
+ encryptedData: data.encryptedData,
+ iv: data.iv,
+ sessionKey: wx.getStorageSync('sessionKey') || data.iv,
+ }).then(res => {
+ binDingPhone({
+ phone: res.data
+ }).then((res) => {
+ if(res.code == 200){
+ wx.setStorageSync('member', res.data)
+ this.submit()
}
})
+ })
},
// 绔嬪嵆璁$畻
submit () {
// console.log('绔嬪嵆璁$畻')
let { userPhone } = this.data
- ls.get('userInfo').then(res => {
- // console.log(res)
- if (userPhone) {
- let { type, info, area, money, typeArray, infoArray, calculatorOptions: options } = this.data
- let submitData = {}
- submitData.name = res.name
- submitData.phone = res.phone
-
- if (type === '') {
- wx.showToast({
- title: '璇烽�夋嫨鎴垮眿绫诲瀷',
- icon: 'none'
- })
- return false
- }
- if (info === '') {
- wx.showToast({
- title: '璇烽�夋嫨鎴峰瀷淇℃伅',
- icon: 'none'
- })
- return false
- }
- if (area === '') {
- wx.showToast({
- title: '璇疯緭鍏ユ埧灞嬮潰绉�',
- icon: 'none'
- })
- return false
- }
- if (money === '') {
- wx.showToast({
- title: '璇疯緭鍏ヨ淇绠�',
- icon: 'none'
- })
- return false
- }
-
- submitData = ['鎴垮眿绫诲瀷锛�' + typeArray[type], '鎴峰瀷淇℃伅锛�' + infoArray[info], '鎴垮眿闈㈢Н锛�' + area + '銕�', '瑁呬慨棰勭畻锛�' + money + '涓囧厓'].join('-')
- for (let i in options) {
- options[i].money = (money * options[i].rate / 100).toFixed(2)
- let childList = options[i].childList
- for(let j in childList) {
- childList[j].money = (money * childList[j].rate / 100).toFixed(2)
- }
- }
- this.setData({ calculatorOptions: options, showResultMoney: true, containerContentStyle: 'auto' })
- this.submitCalculatorResult(submitData)
+ const res = wx.getStorageSync('member')
+
+ if (userPhone) {
+ let { type, info, area, money, typeArray, infoArray, calculatorOptions } = this.data
+ let submitData = {}
+ submitData.name = res.name
+ submitData.phone = res.phone
+
+ if (type === '') {
+ wx.showToast({
+ title: '璇烽�夋嫨鎴垮眿绫诲瀷',
+ icon: 'none'
+ })
+ return false
+ }
+ if (info === '') {
+ wx.showToast({
+ title: '璇烽�夋嫨鎴峰瀷淇℃伅',
+ icon: 'none'
+ })
+ return false
+ }
+ if (area === '') {
+ wx.showToast({
+ title: '璇疯緭鍏ユ埧灞嬮潰绉�',
+ icon: 'none'
+ })
+ return false
+ }
+ if (money === '') {
+ wx.showToast({
+ title: '璇疯緭鍏ヨ淇绠�',
+ icon: 'none'
+ })
+ return false
}
- })
+
+ // submitData = ['鎴垮眿绫诲瀷锛�' + typeArray[type], '鎴峰瀷淇℃伅锛�' + infoArray[info], '鎴垮眿闈㈢Н锛�' + area + '銕�', '瑁呬慨棰勭畻锛�' + money + '涓囧厓'].join('-')
+ let activeList = type == '0' ? [...calculatorOptions.exquisiteList] : [...calculatorOptions.roughList]
+ activeList.forEach(item => {
+ item.money = (money * item.rate / 100).toFixed(1)
+ if(item.children && item.children.length > 0){
+ item.children.forEach(child => {
+ child.money = (money * child.rate / 100).toFixed(2)
+ })
+ }
+ })
+ console.log('activeList', activeList);
+ saveRenovationCalculator({
+ area,
+ budget: money,
+ houseStatus: type,
+ houseType: info
+ }).then(res => {
+ // console.log(res)
+ if (res.success) {
+ wx.showToast({
+ title: '璁$畻鎴愬姛',
+ icon: 'none'
+ })
+ } else {
+ console.log(res.msg)
+ }
+ })
+ this.setData({ activeList, showResultMoney: true, containerContentStyle: 'auto' })
+ }
},
// 鎻愪氦璁$畻缁撴灉
submitCalculatorResult (data) {
- calculatorSave({ info: data }).then(res => {
+ saveRenovationCalculator({ info: data }).then(res => {
// console.log(res)
if (res.success) {
wx.showToast({
@@ -166,27 +189,16 @@
// 鑾峰彇璁$畻鍣ㄩ厤缃�
getCalculatorOption () {
- calculatorOption().then(res => {
+ getBjParamConfig().then(res => {
this.setData({ calculatorOptions: res.data })
})
+ getDictData({
+ code: 'WEIXIN_DEFAULT_IMGS',
+ label: 'JISUAN_BG'
+ }).then(res => {
+ this.setData({ background: res.data.code })
+ })
},
-
- /**
- * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鍔犺浇
- */
- onLoad: function (options) {
- let that = this
- // this.getCalculatorOption()
- // ls.get('userInfo').then(res => {
- // if (res.phone) {
- // that.setData({ userPhone: res.phone })
- // }
- // })
- },
-
- /**
- * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鍒濇娓叉煋瀹屾垚
- */
onReady: function () {
},
--
Gitblit v1.9.3