index.vue 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331
  1. <template>
  2. <view class="content">
  3. <view class="top" :style="{background:'#'+themeColor}">
  4. <view class="status_bar" :style="{height: iStatusBarHeight + 'px'}"></view>
  5. <view class="logoBox">
  6. <image src="../../static/img2/indexlogo.png" mode="" class="logoImg"></image>
  7. </view>
  8. </view>
  9. <view>
  10. <view class="status_bar" :style="{height: iStatusBarHeight + 'px'}"></view>
  11. <view style="height: 100rpx;"></view>
  12. </view>
  13. <view class="topCont" :style="{background:'#'+themeColor}">
  14. <view class="carBox">
  15. <view class="carLeft">
  16. <view class="carTop">
  17. <image src="../../static/timg/nocar.png" mode="" class="carLogo"></image>
  18. <view class="carInfomodel">{{carInfo.brand}}&nbsp;{{carInfo.model}}</view>
  19. <image src="../../static/img2/xia.png" mode="" class="carXia"></image>
  20. <view class="plateNumber">{{carInfo.plateNumber}}</view>
  21. <image src="../../static/img2/carBj.png" mode="" class="carBj"></image>
  22. </view>
  23. <view class="carBq">
  24. <view class="carBqLine">
  25. <image src="../../static/img2/carDui.png" mode="" class="carDui"></image>
  26. <view class="carTitle">车况报告</view>
  27. </view>
  28. <view class="carBqLine">
  29. <image src="../../static/img2/carDui.png" mode="" class="carDui"></image>
  30. <view class="carTitle">车况报告</view>
  31. </view>
  32. <view class="carBqLine">
  33. <image src="../../static/img2/carDui.png" mode="" class="carDui"></image>
  34. <view class="carTitle">车况报告</view>
  35. </view>
  36. </view>
  37. </view>
  38. <view class="carRight">
  39. <image src="../../static/img2/carLogo.png" mode="" class="carLogoBg"></image>
  40. </view>
  41. </view>
  42. </view>
  43. <view class="contBox">
  44. <!-- 中间应用模块 -->
  45. <view class="modular">
  46. <view class="modularLine">
  47. <view class="modularMk" @click="goShopList">
  48. <view class="modularLogoBox">
  49. <image src="../../static/img2/icon_1.png" mode="" class="modularLogo"></image>
  50. </view>
  51. <view class="modularTitle">做保养</view>
  52. </view>
  53. <view class="modularMk">
  54. <view class="modularLogoBox">
  55. <image src="../../static/img2/icon_1.png" mode="" class="modularLogo"></image>
  56. </view>
  57. <view class="modularTitle">做保养</view>
  58. </view>
  59. <view class="modularMk">
  60. <view class="modularLogoBox">
  61. <image src="../../static/img2/icon_1.png" mode="" class="modularLogo"></image>
  62. </view>
  63. <view class="modularTitle">做保养</view>
  64. </view>
  65. <view class="modularMk">
  66. <view class="modularLogoBox">
  67. <image src="../../static/img2/icon_1.png" mode="" class="modularLogo"></image>
  68. </view>
  69. <view class="modularTitle">做保养</view>
  70. </view>
  71. </view>
  72. <view class="modularLine" style="margin-top: 13rpx;">
  73. <view class="modularMk">
  74. <view class="modularLogoBox">
  75. <image src="../../static/img2/icon_1.png" mode="" class="modularLogo"></image>
  76. </view>
  77. <view class="modularTitle2">做保养</view>
  78. </view>
  79. <view class="modularMk">
  80. <view class="modularLogoBox">
  81. <image src="../../static/img2/icon_1.png" mode="" class="modularLogo"></image>
  82. </view>
  83. <view class="modularTitle2">做保养</view>
  84. </view>
  85. <view class="modularMk">
  86. <view class="modularLogoBox">
  87. <image src="../../static/img2/icon_1.png" mode="" class="modularLogo"></image>
  88. </view>
  89. <view class="modularTitle2">做保养</view>
  90. </view>
  91. <view class="modularMk">
  92. <view class="modularLogoBox">
  93. <image src="../../static/img2/icon_1.png" mode="" class="modularLogo"></image>
  94. </view>
  95. <view class="modularTitle2">做保养</view>
  96. </view>
  97. </view>
  98. </view>
  99. <!-- 中间应用模块 -->
  100. </view>
  101. <view style="height: 60rpx;"></view>
  102. <!-- 手机号授权 -->
  103. <view class="authorizBox" v-if="authorizShow" @click="authorizShowHide">
  104. <view class="authorizCont" @click.stop="">
  105. <view class="authorizName">{{wxOpenData.miniAppName}}</view>
  106. <view class="authorizMs">未注册的手机号登录后将自动创会员账号,如果您不同意授权获取手机号,会影响您使用我们的产品和服务。</view>
  107. <view class="sqLine">
  108. <button class="authorizContbutton" type="default" open-type="getPhoneNumber" @getphonenumber="decryptPhoneNumber">授权</button>
  109. <view class="sqRefuse" @click="authorizShowHide">拒绝</view>
  110. </view>
  111. </view>
  112. <view style="text-align: center;padding-top: 56rpx;">
  113. <image src="../../static/timg/icon_guanbi@2x.png" mode="" class="authorizCloseImg"></image>
  114. </view>
  115. </view>
  116. <view class="qrBox" v-if="qrSHow">
  117. <view class="qrimgBox">
  118. <view class="qrTitle">微信绑定
  119. <image src="../../static/timg/chahao.png" mode="" class="qrimgchahao" @click="qrclose"></image>
  120. </view>
  121. <view class="qrms">扫描/长按下方二维码进行绑定</view>
  122. <view class="qrms2">绑定后可接收微信消息通知</view>
  123. <view style="text-align: center;padding-top: 30rpx;">
  124. <image :src="qrimg" mode="" class="qrimg" :show-menu-by-longpress='true'></image>
  125. </view>
  126. <view class="qrBtn" @click="qrclose">我知道了</view>
  127. </view>
  128. </view>
  129. </view>
  130. </template>
  131. <script>
  132. export default {
  133. data() {
  134. return {
  135. shopId: '',
  136. url:'',
  137. wxOpenData:'',
  138. code:'',
  139. carInfo:'',
  140. homeCardList:'',
  141. authorizShow:false,
  142. miniAppName:'',
  143. iStatusBarHeight:'',
  144. managerInfo:'',
  145. unionId:'',
  146. ext:'',
  147. duration:500,
  148. interval:3000,
  149. InsuranceExpireDate:'',
  150. NextCareDate:'',
  151. NextAuditDate:'',
  152. themeColor:'',
  153. getwxLoing:false,
  154. shareID:'',
  155. discount:'',
  156. bizUserId:'',
  157. coCouponsMsg:'',
  158. coNoNewCustMsg:'',
  159. qrimg:'',
  160. qrSHow:false,
  161. customerInfo:'',
  162. exitNum:'',
  163. }
  164. },
  165. onLoad(opt) {
  166. this.iStatusBarHeight = uni.getSystemInfoSync().statusBarHeight;
  167. var that=this;
  168. //this.$common.getExtStoreId()
  169. var ext=this.$common.getExtStoreId();
  170. this.ext=ext
  171. console.log("ext--themeColor")
  172. console.log(ext)
  173. //console.log( String(Date.now()))
  174. this.shopId=ext.shopId;
  175. this.url=ext.url;
  176. this.unionId=ext.unionId;
  177. var shareID = opt.scene //'F16E7299-6850-4015-ABCE-A9F2794B45B5'
  178. if (shareID) {
  179. this.shareID = shareID
  180. console.log('this.shareID==='+this.shareID)
  181. //this.$store.commit('mutationsshareID', shareID)
  182. }
  183. //this.shareID='F16E7299-6850-4015-ABCE-A9F2794B45B5'
  184. //this.shareID='1BF04FAEC8844ECE9C40E880C3B13721'
  185. //this.unionId="26A1039A-DB10-4D0E-BBA2-541C06274EED";
  186. //this.ext.appId="wxffd2502e67d37908"
  187. // uni.setStorage({
  188. // key: 'extdata',
  189. // data: {
  190. // shopId:'E37BB296-5A08-4534-859D-B351BA611AF9',
  191. // },
  192. // success: function () {
  193. // that.uniLogin()
  194. // }
  195. // });
  196. //this.userInfo = uni.getStorageSync("userInfo");
  197. this.userInfo=this.$store.state.userInfo
  198. if(this.userInfo){
  199. //this.wxOpenData = uni.getStorageSync("wxOpenData");
  200. this.getCarList();
  201. this.queryHomeCardList()
  202. this.queryManagerInfo()
  203. }else{
  204. this.uniLogin()
  205. }
  206. //版本更新
  207. this.UpdateManager();
  208. },
  209. onShow() {
  210. this.userInfo=this.$store.state.userInfo;
  211. this.wxOpenData=this.$store.state.wxOpenData;
  212. var indexaddcar = uni.getStorageSync("indexaddcar");
  213. var themeColor = uni.getStorageSync("themeColor");
  214. if(themeColor){
  215. this.themeColor=themeColor
  216. }
  217. this.getwxLoing=true;
  218. this.exitNum=this.$store.state.exitNum;
  219. if(this.exitNum==1){
  220. this.carInfo=''
  221. }else{
  222. if(indexaddcar==1){
  223. uni.removeStorageSync('indexaddcar');
  224. this.getCarList();
  225. }else{
  226. this.carInfo=this.$store.state.carInfo;
  227. console.log("车辆信息")
  228. console.log(this.carInfo)
  229. if(!this.carInfo){
  230. this.getCarList();
  231. }
  232. this.jsTime()
  233. }
  234. }
  235. },
  236. onPullDownRefresh(){
  237. this.getCarList();
  238. this.queryHomeCardList()
  239. this.queryManagerInfo()
  240. setTimeout(() => {
  241. uni.stopPullDownRefresh(); // 关闭下拉刷新
  242. }, 1000);
  243. },
  244. methods: {
  245. seeQr(){
  246. // this.authorizShow = true;
  247. // return false;
  248. if (this.userInfo) {
  249. } else {
  250. this.authorizShow = true;
  251. return false;
  252. }
  253. uni.showLoading({
  254. title: '加载中'
  255. })
  256. this.$request.httpBinary('wxV2/createQrCode', {
  257. type:'bindWx',
  258. customerId:this.customerInfo.id,
  259. unionID:this.customerInfo.unionID,
  260. }, 'GET').then(res => {
  261. uni.hideLoading();
  262. this.qrimg = 'data:image/png;base64,'+uni.arrayBufferToBase64(res);
  263. this.qrSHow=true;
  264. //this.img= uni.arrayBufferToBase64(res)
  265. //console.log('list+=', this.queryShopList);
  266. })
  267. },
  268. qrclose(){
  269. this.qrSHow=false;
  270. },
  271. authorizShowHide(){
  272. this.authorizShow=false
  273. },
  274. UpdateManager(){
  275. const updateManager = uni.getUpdateManager();
  276. updateManager.onCheckForUpdate(function (res) {
  277. // 请求完新版本信息的回调
  278. console.log(res.hasUpdate);
  279. });
  280. updateManager.onUpdateReady(function (res) {
  281. uni.showModal({
  282. title: '更新提示',
  283. content: '新版本已经准备好,是否重启应用?',
  284. success(res) {
  285. if (res.confirm) {
  286. // 新的版本已经下载好,调用 applyUpdate 应用新版本并重启
  287. updateManager.applyUpdate();
  288. }
  289. }
  290. });
  291. });
  292. updateManager.onUpdateFailed(function (res) {
  293. // 新的版本下载失败
  294. uni.showToast({
  295. title: '新的版本下载失败',
  296. icon:'none',
  297. duration: 3000
  298. });
  299. });
  300. },
  301. addCar(){
  302. if(!this.userInfo){
  303. if(this.exitNum!=1){
  304. this.authorizShow=true;
  305. }else{
  306. this.$common.automaticlogin().then(val => {
  307. this.userInfo=this.$store.state.userInfo;
  308. this.wxOpenData=this.$store.state.wxOpenData;
  309. /* uni.navigateTo({
  310. url:'../user/addCar/addCar?type=1'
  311. }) */
  312. this.exitNum=''
  313. this.$store.commit('mutationsexitNum', '')
  314. this.getCarList();
  315. uni.navigateTo({
  316. url:'../user/addCar/cailist'
  317. })
  318. })
  319. }
  320. }else{
  321. uni.navigateTo({
  322. url:'../user/addCar/addCar?type=1'
  323. })
  324. }
  325. },
  326. goShopList(){
  327. uni.navigateTo({
  328. url:'shopList'
  329. })
  330. },
  331. goShop(){
  332. uni.switchTab({
  333. url:'../shop/shop'
  334. })
  335. },
  336. moreJk(){
  337. uni.switchTab({
  338. url:'../activity/activity'
  339. })
  340. },
  341. information(){
  342. console.log('车辆信息--',this.carInfo);
  343. uni.navigateTo({
  344. url:'handbook?mileage='+this.carInfo.milage+'&liyangId='+this.carInfo.nLevelID
  345. })
  346. },
  347. changeCar(){
  348. /* uni.scanCode({
  349. success: function (res) {
  350. console.log('条码类型:' + res.scanType);
  351. console.log( res);
  352. }
  353. });
  354. return false; */
  355. uni.navigateTo({
  356. url:'../user/addCar/cailist'
  357. })
  358. },
  359. goMUsers(){
  360. if(!this.userInfo){
  361. this.authorizShow=true;
  362. }else{
  363. var managerInfo={
  364. name:this.managerInfo.name,
  365. shopInfo:{
  366. shopName:this.managerInfo.shopInfo.shopName,
  367. provinceName:this.managerInfo.shopInfo.provinceName,
  368. cityName:this.managerInfo.shopInfo.cityName,
  369. areaName:this.managerInfo.shopInfo.areaName,
  370. Address:this.managerInfo.shopInfo.Address,
  371. },
  372. avatar:this.managerInfo.avatar,
  373. phone:this.managerInfo.phone,
  374. shopID:this.managerInfo.shopInfo.id
  375. }
  376. uni.navigateTo({
  377. url:'../index/personalCard?adInfo='+JSON.stringify(managerInfo)
  378. })
  379. }
  380. },
  381. goGoods(item){
  382. uni.navigateTo({
  383. url:'../shop/goodsDetail?id='+item.id
  384. })
  385. /* if(!this.userInfo){
  386. if(this.exitNum!=1){
  387. this.authorizShow=true;
  388. }else{
  389. this.$common.automaticlogin().then(val => {
  390. this.userInfo=this.$store.state.userInfo;
  391. this.wxOpenData=this.$store.state.wxOpenData;
  392. this.exitNum=''
  393. this.$store.commit('mutationsexitNum', '')
  394. uni.navigateTo({
  395. url:'../shop/goodsDetail?id='+item.id
  396. })
  397. })
  398. }
  399. }else{
  400. uni.navigateTo({
  401. url:'../shop/goodsDetail?id='+item.id
  402. })
  403. } */
  404. /* if(!this.userInfo){
  405. this.authorizShow=true;
  406. }else{
  407. uni.navigateTo({
  408. url:'../shop/goodsDetail?id='+item.id
  409. })
  410. } */
  411. },
  412. goJk(item){
  413. uni.navigateTo({
  414. url:'../activity/jkDetail?id='+item.id
  415. })
  416. /* if(!this.userInfo){
  417. this.authorizShow=true;
  418. }else{
  419. uni.navigateTo({
  420. url:'../activity/jkDetail?id='+item.id
  421. })
  422. } */
  423. /* if(!this.userInfo){
  424. if(this.exitNum!=1){
  425. this.authorizShow=true;
  426. }else{
  427. this.$common.automaticlogin().then(val => {
  428. this.userInfo=this.$store.state.userInfo;
  429. this.wxOpenData=this.$store.state.wxOpenData;
  430. this.exitNum=''
  431. this.$store.commit('mutationsexitNum', '')
  432. uni.navigateTo({
  433. url:'../activity/jkDetail?id='+item.id
  434. })
  435. })
  436. }
  437. }else{
  438. uni.navigateTo({
  439. url:'../activity/jkDetail?id='+item.id
  440. })
  441. } */
  442. },
  443. goRoter(item){
  444. /* if(!this.userInfo){
  445. if(this.exitNum!=1){
  446. this.authorizShow=true;
  447. }else{
  448. this.$common.automaticlogin().then(val => {
  449. this.userInfo=this.$store.state.userInfo;
  450. this.wxOpenData=this.$store.state.wxOpenData;
  451. this.exitNum=''
  452. this.$store.commit('mutationsexitNum', '')
  453. this.goRoter2(item)
  454. })
  455. }
  456. }else{
  457. this.goRoter2(item)
  458. } */
  459. this.$common.automaticlogin().then(val => {
  460. this.userInfo=this.$store.state.userInfo;
  461. this.wxOpenData=this.$store.state.wxOpenData;
  462. this.exitNum=''
  463. this.$store.commit('mutationsexitNum', '')
  464. this.goRoter2(item)
  465. })
  466. },
  467. goRoter2(item){
  468. console.log(item)
  469. if(!this.userInfo){
  470. //this.authorizShow=true;
  471. }else{
  472. if(item.bizType==0){
  473. if(item.name=='新车'){ //
  474. uni.navigateTo({
  475. url:'newCar'
  476. })
  477. }else if(item.name=='二手车'){
  478. uni.navigateTo({
  479. url:'usedCar'
  480. })
  481. }else if(item.name=='爱车估价'){
  482. uni.navigateTo({
  483. url:'evaluation'
  484. })
  485. }else if(item.sortId==18){ //领券中心
  486. uni.navigateTo({
  487. url:'receiveCoupon'
  488. })
  489. }else if(item.sortId==19){ //救援测试
  490. uni.navigateTo({
  491. url:'rescue'
  492. })
  493. }
  494. else{
  495. uni.showToast({
  496. title: '敬请期待',
  497. icon:'none',
  498. duration: 3000
  499. });
  500. }
  501. }else if(item.bizType==1){ //紧急救援
  502. uni.navigateTo({
  503. url:'rescue'
  504. })
  505. /* uni.showToast({
  506. title: '敬请期待',
  507. icon:'none',
  508. duration: 3000
  509. }); */
  510. }else if(item.bizType==2){ //钣金喷漆
  511. uni.navigateTo({
  512. url:'paint'
  513. })
  514. /* uni.navigateTo({
  515. url:'receiveCoupon'
  516. }) */
  517. }else if(item.bizType==3){ //保养
  518. uni.navigateTo({
  519. url:'maintain'
  520. })
  521. }else if(item.bizType==4){ //在线预约
  522. uni.navigateTo({
  523. url:'onlineBooking?naShopId='+item.naShopId
  524. })
  525. }else if(item.bizType==5){ //导航
  526. this.getShopinfo(5,item.reShopId)
  527. }else if(item.bizType==6){ //联系本店
  528. this.getShopinfo(6,item.orShopId)
  529. }else if(item.bizType==7){ //7门店列表
  530. uni.navigateTo({
  531. url:'shopList'
  532. })
  533. }else if(item.bizType==8){ //我的会员卡
  534. uni.navigateTo({
  535. url:'vipCard'
  536. })
  537. }else if(item.bizType==9){ //我的优惠券
  538. uni.navigateTo({
  539. url:'discountCard'
  540. })
  541. }else if(item.bizType==10){ //我的订单
  542. uni.navigateTo({
  543. url:'../user/myOrder/myOrder'
  544. })
  545. }else if(item.bizType==11){ //我的预约
  546. uni.navigateTo({
  547. url:'../user/myBespeak'
  548. })
  549. }else if(item.bizType==12){ //历史消费
  550. uni.navigateTo({
  551. url:'../user/historySpend'
  552. })
  553. }else if(item.bizType==12){ //历史消费
  554. uni.navigateTo({
  555. url:'../user/historySpend'
  556. })
  557. }else if(item.bizType==13){ //车检报告
  558. uni.navigateTo({
  559. url:'../user/checkReport'
  560. })
  561. }else if(item.bizType==14){ //指定商品分类
  562. uni.setStorage({
  563. key: 'shopcategoryID',
  564. data: item.bizId,
  565. success: function () {
  566. getApp().globalData.shopcategoryID=item.bizId;
  567. uni.switchTab({
  568. url:'../shop/shop?shopcategoryID='+ item.bizId
  569. })
  570. }
  571. });
  572. }else if(item.bizType==15){ //商品详情
  573. uni.navigateTo({
  574. url:'../shop/goodsDetail?id='+item.bizId
  575. })
  576. }else if(item.bizType==16){ //积分商城
  577. uni.navigateTo({
  578. url:'../integral/integral'
  579. })
  580. }else if(item.bizType==17){ //公司介绍
  581. uni.navigateTo({
  582. url:'aboutUS?unionID='+this.userInfo.unionId
  583. })
  584. }else if(item.bizType==18){ //领券中心
  585. uni.navigateTo({
  586. url:'receiveCoupon'
  587. })
  588. /* uni.navigateTo({
  589. url:'rescue'
  590. }) */
  591. }else if(item.bizType==19){
  592. //我的车库pages/user/addCar/cailist
  593. uni.navigateTo({
  594. url:'../user/addCar/cailist'
  595. })
  596. }
  597. // uni.navigateTo({
  598. // url:url
  599. // })
  600. }
  601. },
  602. decryptPhoneNumber: function(e) {
  603. console.log(e);
  604. this.code=e.detail.code
  605. this.wxPhoneLogin()
  606. this.authorizShow=false;
  607. },
  608. wxgologin(){
  609. var that=this;
  610. uni.getUserProfile({
  611. lang:'zh_CN',
  612. desc:'登录',
  613. success:(res)=>{
  614. console.log(res);
  615. that.wxdata=res;
  616. uni.setStorage({
  617. key: 'wxdata',
  618. data: res,
  619. success: function () {
  620. that.uniLogin()
  621. }
  622. });
  623. },
  624. fail:(res)=>{
  625. console.log(res)
  626. }
  627. });
  628. },
  629. uniLogin(){
  630. var that=this;
  631. uni.login({
  632. provider: 'weixin',
  633. success: function (loginRes) {
  634. console.log(loginRes);
  635. that.getWxOpenID(loginRes)
  636. }
  637. });
  638. },
  639. getWxOpenID(e){
  640. var that=this;
  641. // uni.showLoading({
  642. // title: '加载中'
  643. // })
  644. this.$http('miniApp2/sys/getWxOpenID', {
  645. code:e.code,
  646. unionId:this.unionId,
  647. shareId:this.shareID
  648. },'GET').then(res => {
  649. console.log(res.code);
  650. console.log("授权信息")
  651. console.log(res)
  652. //uni.hideLoading();
  653. if(res.code!=0){
  654. //uni.hideLoading();
  655. var msg=res.msg
  656. if(!msg){
  657. msg='授权失败'
  658. }
  659. console.log(msg);
  660. // uni.showModal({
  661. // title: '提示',
  662. // content: msg,
  663. // success: function(resTK) {
  664. // if (resTK.confirm) {
  665. // }
  666. // }
  667. // });
  668. // uni.showToast({
  669. // title:msg,
  670. // icon: 'none',
  671. // duration: 3000
  672. // });
  673. //return false
  674. }
  675. this.wxOpenData=res.data;
  676. this.themeColor=res.data.themeColor
  677. //this.themeColor='FFFFFF'
  678. this.getwxLoing=true;
  679. uni.setNavigationBarTitle({
  680. title:this.wxOpenData.miniAppName
  681. })
  682. if(this.themeColor=='6F2BE8'){
  683. var backgroundImage='/static/tabimg/index6F2BE8.png'
  684. }
  685. if(this.themeColor=='1677FF'){
  686. var backgroundImage='/static/tabimg/index1677FF.png'
  687. }
  688. if(this.themeColor=='FF4F00'){
  689. var backgroundImage='/static/tabimg/indexFF4F00.png'
  690. }
  691. if(this.themeColor=='D53533'){
  692. var backgroundImage='/static/tabimg/index1.png'
  693. }
  694. uni.setTabBarStyle({
  695. // color: '#FF0000',
  696. selectedColor: '#'+this.themeColor,
  697. })
  698. uni.setTabBarItem({
  699. index: 0,
  700. text: '首页',
  701. selectedIconPath: backgroundImage
  702. })
  703. if(res.code==0){
  704. that.queryHomeCardList()
  705. }
  706. //that.wxPhoneLogin()
  707. this.$store.commit('mutationswxOpenData', that.wxOpenData)
  708. uni.setStorage({
  709. key: 'wxOpenData',
  710. data: that.wxOpenData,
  711. success: function () {
  712. // that.uniLogin()
  713. }
  714. });
  715. uni.setStorage({
  716. key: 'themeColor',
  717. data: that.themeColor,
  718. success: function () {
  719. // that.uniLogin()
  720. console.log("themeColor=="+that.themeColor)
  721. }
  722. });
  723. if(this.wxOpenData.loginInfo){
  724. this.$store.commit('mutationsuserInfo', that.wxOpenData.loginInfo.openUser)
  725. this.userInfo=that.wxOpenData.loginInfo.openUser
  726. that.queryManagerInfo()
  727. uni.setStorage({
  728. key: 'userInfo',
  729. data: that.wxOpenData.loginInfo.openUser,
  730. success: function () {
  731. that.getCarList()
  732. }
  733. });
  734. }else{
  735. //this.authorizShow=true;
  736. }
  737. if(res.data.loginInfo.discount){
  738. that.discount=res.data.loginInfo.discount;
  739. if(that.discount==2){
  740. that.bizUserId=res.data.loginInfo.bizUserId;
  741. }
  742. if(that.shareID){
  743. that.getCouponList()
  744. }
  745. }
  746. if(res.data.loginInfo.coNoNewCustMsg){ //车主合伙人二维码提示
  747. uni.showModal({
  748. title: '提示',
  749. content:res.data.loginInfo.coNoNewCustMsg,
  750. success: function(resTKk) {
  751. }
  752. });
  753. }
  754. //console.log("优惠券")
  755. })
  756. },
  757. wxPhoneLogin(){
  758. var that=this;
  759. this.$http('miniApp2/sys/wxPhoneLogin', {
  760. appId:this.ext.appId,
  761. unionId:this.unionId,
  762. code:this.code,
  763. openId:this.wxOpenData.openid,
  764. shareId:this.shareID
  765. },'POST').then(res => {
  766. var data = res.data;
  767. if(data.loginInfo){
  768. this.userInfo=data.loginInfo.openUser;
  769. this.customerInfo=data.loginInfo.customerInfo
  770. this.$store.commit('mutationsuserInfo', this.userInfo);
  771. this.$store.commit('mutationswxOpenData', data);
  772. uni.setStorage({
  773. key: 'userInfo',
  774. data: data.loginInfo.openUser,
  775. success: function () {
  776. that.getCarList()
  777. that.queryHomeCardList()
  778. that.queryManagerInfo();
  779. if(data.loginInfo.coCouponsMsg){
  780. uni.hideLoading()
  781. that.coCouponsMsg =data.loginInfo.coCouponsMsg;
  782. that.ownerCoupon()
  783. }
  784. if(data.loginInfo.coNoNewCustMsg){
  785. //console.log(data.loginInfo.coNoNewCustMsg)
  786. uni.hideLoading()
  787. that.coNoNewCustMsg =data.loginInfo.coNoNewCustMsg;
  788. that.coNoNewCust()
  789. }
  790. if(data.loginInfo.discount){
  791. that.discount=data.loginInfo.discount;
  792. if(that.discount==2){
  793. that.bizUserId=data.loginInfo.bizUserId;
  794. }
  795. if(that.shareID&&that.discount==2){
  796. that.getCouponList()
  797. }
  798. }
  799. }
  800. });
  801. if(!this.customerInfo.wxMiniV2OpenID){
  802. this.seeQr()
  803. }
  804. }
  805. })
  806. },
  807. coNoNewCust(){
  808. console.log(111111)
  809. var that=this;
  810. uni.showModal({
  811. title: '提示',
  812. content: that.coNoNewCustMsg,
  813. success: function(resTK) {
  814. }
  815. });
  816. },
  817. ownerCoupon(){
  818. console.log(22222)
  819. var that=this;
  820. uni.showModal({
  821. title: '提示',
  822. content: that.coCouponsMsg,
  823. cancelText:'回到首页',
  824. confirmText:'查看',
  825. success: function(resTK) {
  826. if (resTK.confirm) {
  827. uni.navigateTo({
  828. url:'discountCard'
  829. })
  830. }
  831. }
  832. });
  833. },
  834. getCouponList(){
  835. if(this.discount!=2){
  836. var params={
  837. discount:this.discount
  838. }
  839. }else{
  840. var params={
  841. discount:this.discount,
  842. bizId:this.bizUserId
  843. }
  844. }
  845. var that=this;
  846. this.$http('opencoupon/getCouponList', params, 'GET').then(res => {
  847. var list = res.data;
  848. if(list.length>0){
  849. uni.showModal({
  850. title: '提示',
  851. content: '您有优惠券待领取',
  852. cancelText:'回到首页',
  853. confirmText:'查看',
  854. success: function(resTK) {
  855. if (resTK.confirm) {
  856. uni.navigateTo({
  857. url:'discountDlq?bizUserId='+that.bizUserId+'&discount='+that.discount
  858. })
  859. }
  860. }
  861. });
  862. }
  863. })
  864. },
  865. getCarList(){
  866. this.$http('opencarOwnerHome/queryCarInfoList', {
  867. },'GET').then(res => {
  868. if(res.code==401){
  869. // this.uniLogin()
  870. this.carInfo=''
  871. this.$store.commit('mutationscarInfo', '')
  872. }else{
  873. this.carInfo=res.data[0]
  874. //this.carInfo=[]
  875. this.$store.commit('mutationscarInfo', this.carInfo)
  876. /* this.carInfo.insuranceExpireDate='2022-11-11';
  877. this.carInfo.nextAuditDate='2022-08-13'; */
  878. //this.carInfo.nextCareDate='2022-08-11';
  879. //this.carInfo.nextCareMilage=11
  880. this.jsTime()
  881. }
  882. })
  883. },
  884. jsTime(){
  885. if(this.carInfo.insuranceExpireDate){
  886. if (Number(new Date().getTime()) > (Number(new Date(this.carInfo.insuranceExpireDate.replace(/-/g, '/')).getTime()) || 0)) {
  887. console.log("现在时间大于开始时间")
  888. this.InsuranceExpireDate = 0
  889. } else {
  890. this.clock()
  891. }
  892. }else{
  893. this.InsuranceExpireDate=''
  894. }
  895. if(this.carInfo.nextCareDate){
  896. if (Number(new Date().getTime()) > (Number(new Date(this.carInfo.nextCareDate.replace(/-/g, '/')).getTime()) || 0)) {
  897. this.NextCareDate = 0
  898. } else {
  899. this.clock2()
  900. }
  901. }else{
  902. this.NextCareDate = ''
  903. }
  904. if(this.carInfo.nextAuditDate){
  905. if (Number(new Date().getTime()) > (Number(new Date(this.carInfo.nextAuditDate.replace(/-/g, '/')).getTime()) || 0)) {
  906. this.NextAuditDate = 0
  907. } else {
  908. this.clock3()
  909. }
  910. }else{
  911. this.NextAuditDate=''
  912. }
  913. },
  914. clock () {
  915. let _this = this
  916. let today = new Date() // 当前时间
  917. let h = today.getHours()
  918. let m = today.getMinutes()
  919. let s = today.getSeconds()
  920. let stopTime = new Date(_this.carInfo.insuranceExpireDate.replace(/-/g, '/')) // 结束时间
  921. let stopH = stopTime.getHours()
  922. let stopM = stopTime.getMinutes()
  923. let stopS = stopTime.getSeconds()
  924. let shenyu = stopTime.getTime() - today.getTime() // 倒计时毫秒数
  925. let shengyuD = parseInt(shenyu / (60 * 60 * 24 * 1000)) // 转换为天
  926. this.InsuranceExpireDate=shengyuD+1;
  927. // setTimeout(_this.clock, 500)
  928. },
  929. clock2 () {
  930. let _this = this
  931. let today = new Date() // 当前时间
  932. let stopTime = new Date(_this.carInfo.nextCareDate.replace(/-/g, '/')) // 结束时间
  933. let stopH = stopTime.getHours()
  934. let stopM = stopTime.getMinutes()
  935. let stopS = stopTime.getSeconds()
  936. let shenyu = stopTime.getTime() - today.getTime() // 倒计时毫秒数
  937. let shengyuD = parseInt(shenyu / (60 * 60 * 24 * 1000)) // 转换为天
  938. this.NextCareDate=shengyuD+1;
  939. // setTimeout(_this.clock, 500)
  940. },
  941. clock3 () {
  942. let _this = this
  943. let today = new Date() // 当前时间
  944. let stopTime = new Date(_this.carInfo.nextAuditDate.replace(/-/g, '/')) // 结束时间
  945. let shenyu = stopTime.getTime() - today.getTime() // 倒计时毫秒数
  946. let shengyuD = parseInt(shenyu / (60 * 60 * 24 * 1000)) // 转换为天
  947. this.NextAuditDate=shengyuD+1;
  948. // setTimeout(_this.clock, 500)
  949. },
  950. queryManagerInfo(){
  951. console.log("11")
  952. this.$http('openHome/queryManagerInfo', {
  953. },'GET').then(res => {
  954. this.managerInfo=res.data
  955. })
  956. },
  957. queryHomeCardList(){
  958. //console.log(this.wxOpenData)
  959. var that=this;
  960. uni.showLoading({
  961. title: '加载中'
  962. })
  963. this.$http('openHome/queryHomeCardList', {
  964. unionId:this.unionId
  965. },'GET').then(res => {
  966. uni.hideLoading();
  967. this.homeCardList=res.data;
  968. uni.setStorage({
  969. key: 'openMCar',
  970. data: res.data.openMCar,
  971. success: function () {
  972. that.getCarList()
  973. }
  974. });
  975. })
  976. },
  977. getShopinfo(num,shopId){
  978. var that=this;
  979. uni.showLoading({
  980. title: '加载中'
  981. })
  982. if(!shopId){
  983. shopId=''
  984. }
  985. this.$http('openmy/getShopinfo', {
  986. shopId:shopId
  987. },'GET').then(res => {
  988. uni.hideLoading();
  989. var res=res.data
  990. if(num==5){
  991. uni.openLocation({
  992. latitude:Number(res.lat),
  993. longitude:Number(res.lng),
  994. name: res.shopName,
  995. address: res.address,
  996. success: function() {
  997. console.log('success');
  998. },
  999. fail(err) {
  1000. console.log(err)
  1001. }
  1002. });
  1003. }else{
  1004. uni.makePhoneCall({
  1005. phoneNumber: res.mobilePhone
  1006. });
  1007. }
  1008. })
  1009. }
  1010. },
  1011. onShareAppMessage(){
  1012. }
  1013. }
  1014. </script>
  1015. <style scoped>
  1016. .content{
  1017. background: #F4F4F4;
  1018. }
  1019. .top{
  1020. position: fixed;
  1021. left: 0;
  1022. width: 750rpx;
  1023. top: 0;
  1024. }
  1025. .logoImg{
  1026. height: 72rpx;width: 492rpx;
  1027. }
  1028. .logoBox{
  1029. padding-left: 20rpx;
  1030. padding-bottom: 20rpx;
  1031. padding-top: 8rpx;
  1032. }
  1033. .topCont{
  1034. padding: 8rpx 20rpx;
  1035. padding-bottom: 210rpx;
  1036. }
  1037. .carBox{
  1038. background: #FFFFFF;
  1039. border-radius: 17rpx;
  1040. display: flex;
  1041. justify-content: space-between;
  1042. padding-top: 20rpx;
  1043. padding-right: 24rpx;
  1044. padding-left: 30rpx;
  1045. }
  1046. .carLogoBg{
  1047. width: 123rpx;
  1048. height: 127rpx;
  1049. }
  1050. .carLogo{
  1051. width: 42rpx;height: 42rpx;border-radius: 22rpx;
  1052. }
  1053. .carInfomodel{
  1054. font-size: 30rpx;
  1055. color: #0B0B0B;
  1056. line-height: 42rpx;
  1057. font-weight: 500;
  1058. padding-left: 12rpx;
  1059. }
  1060. .carTop{
  1061. display: flex;
  1062. }
  1063. .carXia{
  1064. width: 12rpx;height: 9rpx;
  1065. margin-left: 4rpx;margin-top: 18rpx;
  1066. }
  1067. .plateNumber{
  1068. color: #0B0B0B;padding-right: 20rpx;
  1069. line-height: 42rpx;
  1070. font-size: 22rpx;padding-left: 20rpx;
  1071. }
  1072. .carBj{
  1073. width: 12rpx;height: 15rpx;margin-top: 16rpx;
  1074. }
  1075. .carBq{
  1076. display: flex;
  1077. width: 446rpx;
  1078. height: 47rpx;
  1079. background: #FBF0E4;
  1080. border-radius: 10rpx;
  1081. margin-top: 18rpx;
  1082. }
  1083. .carDui{
  1084. width: 24rpx;height: 24rpx;
  1085. }
  1086. .carBqLine{
  1087. display: flex;
  1088. padding-left: 20rpx;padding-right: 10rpx;padding-top: 10rpx;
  1089. font-size: 22rpx;
  1090. color: #A26D4F;line-height: 26rpx;
  1091. }
  1092. .carTitle{
  1093. padding-left: 6rpx;
  1094. }
  1095. .modular{
  1096. background: #FFFFFF;
  1097. border-radius: 17rpx;
  1098. padding: 34rpx 0;
  1099. }
  1100. .modularMk{
  1101. padding: 0 38rpx;text-align: center;
  1102. }
  1103. .modularLine{
  1104. display: flex;
  1105. }
  1106. .modularLogo{
  1107. width: 97rpx;height: 97rpx;
  1108. }
  1109. .modularTitle{
  1110. font-weight: 600;
  1111. font-size: 28rpx;
  1112. color: #222222;line-height: 40rpx;
  1113. }
  1114. .modularTitle2{
  1115. font-size: 28rpx;
  1116. color: #222222;line-height: 40rpx;
  1117. }
  1118. .contBox{
  1119. padding: 20rpx;
  1120. margin-top: -200rpx;
  1121. }
  1122. .authorizBox{
  1123. width: 100vw;
  1124. height: 100vh;
  1125. background: rgba(0, 0, 0, 0.5);
  1126. position: fixed;
  1127. top: 0;
  1128. left: 0;
  1129. }
  1130. .authorizCont{
  1131. margin-top: 30vh;
  1132. width: 564rpx;
  1133. height: 408rpx;
  1134. background: #FFFFFF;
  1135. border-radius: 24rpx;
  1136. margin-left: 93rpx;
  1137. position: relative;
  1138. }
  1139. .authorizCloseImg{
  1140. width: 62rpx;
  1141. height: 62rpx;
  1142. }
  1143. .sqLogoBox{
  1144. width: 180rpx;
  1145. height: 180rpx;
  1146. background: #FFFFFF;
  1147. border-radius: 90rpx;
  1148. text-align: center;
  1149. position: absolute;
  1150. top: -50rpx;
  1151. left: 192rpx;
  1152. }
  1153. .authorizName{
  1154. color: #333333;
  1155. line-height: 42rpx;
  1156. font-size: 30rpx;
  1157. text-align: center;
  1158. padding-top: 58rpx;
  1159. }
  1160. .authorizMs{
  1161. color: #999999;
  1162. line-height: 36rpx;
  1163. font-size: 26rpx;
  1164. width: 452rpx;
  1165. padding-top: 24rpx;
  1166. text-align: center;
  1167. margin-left: 56rpx;
  1168. }
  1169. .authorizContbutton{
  1170. width: 210rpx;
  1171. height: 66rpx;
  1172. background: #D53533;
  1173. border-radius: 44rpx;
  1174. line-height: 66rpx;
  1175. text-align: center;
  1176. font-size:30rpx;
  1177. color: #FFFFFF;
  1178. margin-left:40rpx;
  1179. }
  1180. .qrBox{
  1181. position: fixed;
  1182. width: 100vw;
  1183. height: 100vh;
  1184. background: rgba(0,0,0,0.5);
  1185. left: 0;
  1186. top: 0;
  1187. z-index: 11;
  1188. display: flex;
  1189. justify-content: center;
  1190. align-items: center;
  1191. flex-direction: column;
  1192. }
  1193. .qrimgBox{
  1194. width: 562rpx;
  1195. height: 704rpx;
  1196. background: #FFFFFF;
  1197. border-radius: 24rpx;
  1198. }
  1199. .qrTitle{
  1200. font-size: 30rpx;
  1201. font-family: PingFangSC-Medium, PingFang SC;
  1202. font-weight: 500;
  1203. color: #333333;
  1204. border-bottom: 1px solid #EEEEEE;
  1205. text-align: center;
  1206. line-height: 90rpx;
  1207. position: relative;
  1208. }
  1209. .qrimgchahao{
  1210. width: 38rpx;
  1211. height: 38rpx;
  1212. position: absolute;
  1213. top: 26rpx;
  1214. right: 20rpx;
  1215. }
  1216. .qrms{
  1217. font-weight: 400;
  1218. color: #999999;
  1219. line-height: 37rpx;
  1220. font-size: 26rpx;
  1221. padding-top: 23rpx;
  1222. text-align: center;
  1223. }
  1224. .qrms2{
  1225. font-weight: 400;
  1226. color: #999999;
  1227. line-height: 37rpx;
  1228. font-size: 26rpx;
  1229. text-align: center;
  1230. }
  1231. .qrimg{
  1232. width: 328rpx;
  1233. height: 328rpx;
  1234. }
  1235. .qrBtn{
  1236. width: 292rpx;
  1237. height: 64rpx;
  1238. background: #D53533;
  1239. border-radius: 32rpx;
  1240. color: #FFFFFF;
  1241. line-height: 64rpx;
  1242. text-align: center;
  1243. margin: 0 auto;
  1244. margin-top:40rpx;
  1245. }
  1246. </style>