index.vue 46 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649
  1. <template>
  2. <view>
  3. <zj-page-layout
  4. :hasFooter="false"
  5. :isScroll="true"
  6. :isLoading="isLoading"
  7. :refresherTriggered="refresherTriggered"
  8. @refresherrefresh="refresherrefresh"
  9. >
  10. <!-- <view style="color: #fff; background: red; height: 50px" @click="quzhifu">支付测试</view> -->
  11. <Loading v-if="isError || !isLogin" :type="3" :loadStatus="2" :showText="'加载失败,请下拉重新加载'" />
  12. <view class="all-container" v-else>
  13. <view class="noticebar-container" v-if="noticeContent">
  14. <u-notice-bar :text="noticeContent"></u-notice-bar>
  15. </view>
  16. <!-- 去除商城和服务业务 -->
  17. <!-- <view class="swiper-container" v-if="bannerList.length > 0">
  18. <u-swiper
  19. :list="bannerList"
  20. keyName="imgSrc"
  21. autoplay
  22. circular
  23. indicator
  24. indicatorMode="line"
  25. height="175"
  26. @click="clickBanner"
  27. ></u-swiper>
  28. </view>
  29. <view class="noticebar-container" v-if="noticeContent">
  30. <u-notice-bar :text="noticeContent"></u-notice-bar>
  31. </view>
  32. <block v-if="categoryList.length > 0">
  33. <view
  34. class="service-container card"
  35. v-for="(item, index) in categoryList.filter(o => o.sub.length > 0)"
  36. :key="index"
  37. >
  38. <view class="home-title">
  39. <view class="left">{{ item.name }}</view>
  40. <view class="right" @tap="toClassifyList(item.categoryId)">
  41. <text class="text">查看更多</text>
  42. <text class="iconfont icon-jinru"></text>
  43. </view>
  44. </view>
  45. <view class="list">
  46. <view
  47. class="item"
  48. v-for="(it, idx) in item.sub.slice(0, 4)"
  49. :key="idx"
  50. @tap="toGoodsList(item.categoryId, it.categoryId, it.name)"
  51. >
  52. <image :src="it.imgUrl" mode="aspectFill"></image>
  53. <text>{{ it.name }}</text>
  54. </view>
  55. </view>
  56. </view>
  57. </block> -->
  58. <!-- 自助服务 -->
  59. <!-- <view class="service-container card">
  60. <view class="home-title">
  61. <view class="left">自助服务</view>
  62. <view class="right" @tap="toWorkorder">
  63. <text class="text">我的服务单</text>
  64. <text class="iconfont icon-jinru"></text>
  65. </view>
  66. </view>
  67. <view class="list">
  68. <view class="item" v-for="(item, index) in serviceList" :key="index" @tap="toPage(item.url)">
  69. <image :src="item.icon" mode="aspectFill" v-if="item.icon"></image>
  70. <image
  71. :src="require(`@/static/images/home/service-icon${item.code}.png`)"
  72. mode="aspectFill"
  73. v-else-if="item.code"
  74. ></image>
  75. <text>{{ item.title }}</text>
  76. </view>
  77. <view class="item" v-if="userInfo.isShowLease" @tap="toPage('/packageHome/pages/service/tenancy')">
  78. <image :src="require(`@/static/images/home/service-icon5.png`)" mode="aspectFill"></image>
  79. <text>设备租赁</text>
  80. </view>
  81. </view>
  82. </view> -->
  83. <!-- 扫码活动 -->
  84. <view class="swiper2-container" v-if="codeActivityList.length > 0">
  85. <u-swiper
  86. :list="codeActivityList"
  87. keyName="banner"
  88. autoplay
  89. circular
  90. indicator
  91. indicatorMode="line"
  92. height="100"
  93. @click="toCodeActivityList"
  94. ></u-swiper>
  95. </view>
  96. <!-- 增值服务 -->
  97. <!-- <view class="other-container card" v-if="userInfo.moduleYb">
  98. <view class="home-title">
  99. <view class="left">增值服务</view>
  100. </view>
  101. <view class="list">
  102. <view
  103. class="item"
  104. v-for="(item, index) in addvalueList.filter(o => !o.root || (o.root && o.root.includes(userInfo.type)))"
  105. :key="index"
  106. @tap="item.fn ? toFn(item.fn) : toPage(item.url)"
  107. >
  108. <image :src="require(`@/static/images/home/other-icon${item.code}.png`)" mode=""></image>
  109. <text>{{ item.title }}</text>
  110. </view>
  111. </view>
  112. </view> -->
  113. <!-- 工程维保服务 -->
  114. <!-- <view
  115. class="other-container card"
  116. v-if="(isWorkerUser || isShowMaintenance) && userInfo.moduleWb && userInfo.mobile"
  117. >
  118. <view class="home-title">
  119. <view class="left">工程维保服务</view>
  120. </view>
  121. <view class="list">
  122. <view
  123. class="item"
  124. v-for="(item, index) in maintenanceList"
  125. :key="index"
  126. @tap="item.fn ? toFn(item.fn) : toPage(item.url)"
  127. >
  128. <image :src="require(`@/static/images/home/other-icon${item.code}.png`)" mode=""></image>
  129. <text>{{ item.title }}</text>
  130. </view>
  131. </view>
  132. </view> -->
  133. <!-- 二手商城 -->
  134. <!-- <view class="other-container card" v-if="(isServiceUser || isWorkerUser) && userInfo.moduleEs">
  135. <view class="home-title">
  136. <view class="left">二手商城</view>
  137. </view>
  138. <view class="list">
  139. <view
  140. class="item"
  141. v-for="(item, index) in recycleList.filter(
  142. o => !o.root || (o.root == 1 && userInfo.isEs) || (o.root == 2 && !userInfo.isEs)
  143. )"
  144. :key="index"
  145. @tap="item.fn ? toFn(item.fn) : toPage(item.url)"
  146. >
  147. <image :src="require(`@/static/images/home/other-icon${item.code}.png`)" mode=""></image>
  148. <text>{{ item.title }}</text>
  149. </view>
  150. </view>
  151. </view> -->
  152. <!-- 分享收益 -->
  153. <!-- <view class="share-container card" v-if="isServiceUser || isWorkerUser">
  154. <view class="home-title">
  155. <view class="left">分享收益</view>
  156. <view class="right" @tap="toPage(`/packageMine/pages/order/list?tab=`)">
  157. <text class="text">我的订单</text>
  158. <text class="iconfont icon-jinru"></text>
  159. </view>
  160. </view>
  161. <view class="list">
  162. <view class="item" @tap="toMall()">
  163. <image src="@/static/images/home/share-icon1.png"></image>
  164. <view class="text">分销商城</view>
  165. </view>
  166. <view class="item" @tap="toActivityList(5)">
  167. <image src="@/static/images/home/share-icon2.png"></image>
  168. <view class="text">活动专区</view>
  169. </view>
  170. </view>
  171. </view> -->
  172. <!-- 工单管理 -->
  173. <view class="order-container card">
  174. <view class="home-title">
  175. <view class="left">工单管理</view>
  176. </view>
  177. <view class="list">
  178. <view
  179. class="item"
  180. style="position: relative"
  181. v-for="(item, index) in orderList"
  182. :key="index"
  183. @tap="toPageaa(item.url, item.tab)"
  184. >
  185. <image :src="require(`@/static/images/home/order-icon${item.code}.png`)" mode=""></image>
  186. <text>{{ item.title }}</text>
  187. <text
  188. v-if="statusCount[['djd', 'fwz', '', 'ycd'][index]]"
  189. style="position: absolute; top: -10rpx; right: -10rpx"
  190. >{{ statusCount[['djd', 'fwz', '', 'ycd'][index]] }}</text
  191. >
  192. </view>
  193. </view>
  194. </view>
  195. <!-- 其他 -->
  196. <view class="other-container card">
  197. <view class="home-title">
  198. <view class="left">辅材</view>
  199. <view class="right" @tap="toPage(`/packageMaterial/pages/index?type=M`)">
  200. <text class="text">查看详细</text>
  201. <text class="iconfont icon-jinru"></text>
  202. </view>
  203. </view>
  204. <view class="list">
  205. <view
  206. class="item"
  207. style="position: relative"
  208. v-for="(item, index) in otherList"
  209. :key="index"
  210. @tap="toPage(item.url)"
  211. >
  212. <image :src="require(`@/static/images/home/other-icon${item.code}.png`)" mode=""></image>
  213. <text>{{ item.title }}</text>
  214. <text v-if="index == 1 && fucaidzf" style="position: absolute; top: 0rpx; right: 8rpx">{{
  215. fucaidzf
  216. }}</text>
  217. </view>
  218. </view>
  219. </view>
  220. <view class="other-container card">
  221. <view class="home-title">
  222. <view class="left">配件</view>
  223. <view class="right" @tap="toPage(`/packageMaterial/pages/index?type=P`)">
  224. <text class="text">查看详细</text>
  225. <text class="iconfont icon-jinru"></text>
  226. </view>
  227. </view>
  228. <view class="list">
  229. <view
  230. class="item"
  231. style="position: relative"
  232. v-for="(item, index) in otherList2"
  233. :key="index"
  234. @tap="toPage(item.url)"
  235. >
  236. <image :src="require(`@/static/images/home/other-icon${item.code}.png`)" mode=""></image>
  237. <text>{{ item.title }}</text>
  238. <text v-if="index == 1 && peijiandzf" style="position: absolute; top: 0rpx; right: 8rpx">{{
  239. peijiandzf
  240. }}</text>
  241. </view>
  242. </view>
  243. </view>
  244. <!-- 联系我们 -->
  245. <view class="contact-container card">
  246. <view class="home-title">
  247. <view class="left">联系我们</view>
  248. </view>
  249. <view class="list">
  250. <!-- <button open-type="contact" class="item bb">
  251. <image src="@/static/images/home/home-icon1.png"></image>
  252. <view class="title">在线客服</view>
  253. <text class="iconfont icon-jinru"></text>
  254. </button> -->
  255. <view class="item" :class="isShowContact1 ? '' : 'bb'" @tap="isShowContact1 = !isShowContact1">
  256. <image src="@/static/images/home/home-icon2.png"></image>
  257. <view class="title">服务网点</view>
  258. <text class="iconfont icon-jinru"></text>
  259. </view>
  260. <view class="wrap1" v-if="isShowContact1">
  261. <view class="it" v-for="(item, index) in websitList" :key="index">
  262. <view class="top">
  263. <view class="left">{{ item.name }} {{ item.websitPhone || '' }}</view>
  264. <view class="right" @tap="$callPhone(item.websitPhone)" v-if="item.websitPhone"
  265. ><text class="iconfont icon-call"></text
  266. ></view>
  267. </view>
  268. <view class="address">{{ item.address }}</view>
  269. </view>
  270. </view>
  271. <!-- <view class="item" @tap="isShowContact2 = !isShowContact2">
  272. <image src="@/static/images/home/home-icon3.png"></image>
  273. <view class="title">投诉热线</view>
  274. <text class="iconfont icon-jinru"></text>
  275. </view>
  276. <view class="wrap2" v-if="isShowContact2">
  277. <view class="left">投诉电话:{{ userInfo.companyWechatMobile || '暂无' }}</view>
  278. <view class="right" @tap="$callPhone(userInfo.companyWechatMobile)" v-if="userInfo.companyWechatMobile"
  279. ><text class="iconfont icon-call"></text
  280. ></view>
  281. </view> -->
  282. </view>
  283. </view>
  284. </view>
  285. </zj-page-layout>
  286. <!-- <view class="dialog-container" v-if="couponDialogImgUrl && isShowCouponDialog">
  287. <uni-transition ref="dialog" mode-class="zoom-in" :duration="500" :show="couponDialogImgUrl && isShowCouponDialog">
  288. <image class="image" :src="couponDialogImgUrl" mode="widthFix" @tap="handleCoupon()"></image>
  289. </uni-transition>
  290. <uni-transition ref="dialogBtn" mode-class="fade" :duration="500" :show="couponDialogImgUrl && isShowCouponDialog">
  291. <text class="iconfont icon-close2" @tap="closeDialog()"></text>
  292. </uni-transition>
  293. </view> -->
  294. <view class="top-tooltip" v-if="isShowTopTooltip">
  295. <view class="content">
  296. <view class="left">
  297. <view>点击<text class="iconfont icon-gengduo"></text>添加到我的小程序</view>
  298. <view>微信下拉使用更方便哟!</view>
  299. </view>
  300. <text class="iconfont icon-close2 close" @tap="isShowTopTooltip = false"></text>
  301. </view>
  302. <view class="arrow"></view>
  303. </view>
  304. <view class="bottom-tooltip" v-if="isShowBottomTooltip">
  305. <view class="left">
  306. <text class="iconfont icon-close2 close" @tap="isShowBottomTooltip = false"></text>
  307. <view class="text">关注公众号及时获取服务进度</view>
  308. </view>
  309. <view class="btn" @tap="toWxLink()">前往关注</view>
  310. </view>
  311. <!-- 保险过期提示弹窗 -->
  312. <insuranceDialog ref="insuranceDialog" :data="baoxiandangqianxianxitishi"> </insuranceDialog>
  313. </view>
  314. </template>
  315. <script>
  316. import { getNoticeNum, getOrderNum, selectionChange, mini_env } from '@/common/utils/util.js'
  317. import insuranceDialog from '@/components/insuranceDialog'
  318. export default {
  319. components: {
  320. insuranceDialog
  321. },
  322. data() {
  323. return {
  324. isLoading: true,
  325. refresherTriggered: false, // 下拉刷新状态
  326. userInfo: {},
  327. configInfo: {},
  328. scene: {
  329. // 页面参数(扫码进入小程序时产生)
  330. type: '',
  331. goodsId: '',
  332. orderId: '',
  333. serviceId: '',
  334. couponId: ''
  335. },
  336. isCouponDialog: false, // 是否显示过期优惠券弹窗
  337. isReceiveDialog: false,
  338. isSmsReceive: false,
  339. isShowTopTooltip: false,
  340. isShowBottomTooltip: false,
  341. noticeContent: '', // 公告内容
  342. categoryList: [],
  343. serviceList: [],
  344. baseServiceList: [
  345. // 自助服务列表
  346. { code: 3, title: '收费标准', url: `/packageHome/pages/service/chargeStandard` },
  347. { code: 4, title: '故障自查', url: `/packageHome/pages/service/troubleshoot` }
  348. ],
  349. addvalueList: [
  350. // 增值服务列表
  351. { code: 1, title: '延保服务', fn: 'toServiceIndex' },
  352. { code: 2, title: '我的延保', url: `/packageHome/pages/addvalue/orderList` },
  353. { code: 3, title: '服务记录', fn: `toServiceRecods` },
  354. { code: 3, title: '延保查询', url: `/packageHome/pages/addvalue/check`, root: ['WORKER'] }
  355. ],
  356. maintenanceList: [
  357. // 工程维保服务列表
  358. { code: 1, title: '创建维保单', fn: `toMaintenanceCreate` },
  359. { code: 2, title: '维保单记录', fn: `toMaintenanceRecods` },
  360. { code: 3, title: '费用申请单', url: `/packageHome/pages/maintenance/applyList` }
  361. ],
  362. recycleList: [
  363. { code: 1, title: '二手商城', url: `/packageHome/pages/recycle/index`, root: 0 },
  364. { code: 2, title: '已发布的', url: `/packageHome/pages/recycle/issue/list`, root: 1 },
  365. { code: 3, title: '我买到的', url: `/packageHome/pages/recycle/order/list`, root: 2 }
  366. ],
  367. orderList: [
  368. // 工单管理列表
  369. { code: 1, title: '待接单', url: `/packageWorkorder/pages/orderList?tab=DJD`, tab: 'DJD' },
  370. { code: 2, title: '服务中', url: `/packageWorkorder/pages/orderList?tab=FWZ`, tab: 'FWZ' },
  371. { code: 3, title: '已完成', url: `/packageWorkorder/pages/orderList?tab=YWG`, tab: 'YWG' },
  372. { code: 4, title: '异常单', url: `/packageWorkorder/pages/orderList?tab=YCD`, tab: 'YCD' }
  373. ],
  374. otherList: [
  375. // 其他列表
  376. { code: 1, title: '辅材管理', url: `/packageMaterial/pages/stock/index` },
  377. { code: 2, title: '辅材收款', url: `/packageMaterial/pages/sale/orderList?type=M&tabCurrent=1` }
  378. // { code: 2, title: '辅材收款', url: `/packageMaterial/pages/sale/index?type=M` }
  379. ],
  380. otherList2: [
  381. // 其他列表
  382. { code: 1, title: '配件管理', url: `/packageAttachment/pages/fittingsManagement/index` },
  383. { code: 2, title: '配件收款', url: `/packageMaterial/pages/newSale/orderList?type=P&tabCurrent=1` }
  384. // { code: 2, title: '配件收款', url: `/packageMaterial/pages/newSale/index?type=P` }
  385. ],
  386. bannerList: [], // 轮播图列表
  387. couponList: [], // 可领取优惠券列表
  388. codeActivityList: [],
  389. couponDialogImgUrl: '',
  390. isShowCouponDialog: true,
  391. isError: false,
  392. websitList: [],
  393. isShowContact1: false,
  394. isShowContact2: false,
  395. isShowMaintenance: false,
  396. baoxiandangqianxianxitishi: [],
  397. statusCount: {},
  398. peijiandzf: 0,
  399. fucaidzf: 0
  400. }
  401. },
  402. computed: {
  403. isLogin() {
  404. return this.$store.state.user.token ? true : false
  405. },
  406. isServiceUser() {
  407. // 是否业务员
  408. return this.userInfo && this.userInfo.type === 'SERVICE'
  409. },
  410. isWorkerUser() {
  411. // 是否师傅
  412. return this.userInfo && this.userInfo.type === 'WORKER'
  413. }
  414. },
  415. async onShow() {
  416. selectionChange()
  417. try {
  418. await this.$onLaunched
  419. this.configInfo = await this.$getConfigInfo()
  420. await this.getBannerList()
  421. this.getNoticebar()
  422. if (this.isLogin) {
  423. try {
  424. this.userInfo = await this.$getUserInfo()
  425. if (!this.userInfo.isGZSign && !this.userInfo.isFSSign) {
  426. // this.isShowMaintenance = await this.checkMaintenance()
  427. this.getCategoryList()
  428. this.getServiceList()
  429. this.getCouponList()
  430. this.getWebsitList()
  431. this.getCodeActivityList()
  432. getNoticeNum()
  433. getOrderNum()
  434. } else {
  435. if (this.userInfo.isGZSign) {
  436. if (
  437. (
  438. await this.$api.post('/worker/check/manual/sign/confirm', {
  439. type: 'gz'
  440. })
  441. )?.data
  442. ) {
  443. uni.showModal({
  444. title: '温馨提示',
  445. content: '您未签署确认书!',
  446. cancelText: '取消',
  447. confirmText: '去签署',
  448. success: res => {
  449. if (res.confirm) {
  450. this.navToPage('/pages/repairConfirmation?type=gz')
  451. }
  452. }
  453. })
  454. } else {
  455. uni.showModal({
  456. title: '温馨提示',
  457. content: '签署确认书正在审核!',
  458. cancelText: '取消',
  459. confirmText: '知道了',
  460. success: res => {}
  461. })
  462. }
  463. } else if (this.userInfo.isFSSign) {
  464. if (
  465. (
  466. await this.$api.post('/worker/check/manual/sign/confirm', {
  467. type: 'fs'
  468. })
  469. )?.data
  470. ) {
  471. uni.showModal({
  472. title: '温馨提示',
  473. content: '您未签署确认书!',
  474. cancelText: '取消',
  475. confirmText: '去签署',
  476. success: res => {
  477. if (res.confirm) {
  478. this.navToPage('/pages/repairConfirmation?type=fs')
  479. }
  480. }
  481. })
  482. } else {
  483. uni.showModal({
  484. title: '温馨提示',
  485. content: '签署确认书正在审核!',
  486. cancelText: '取消',
  487. confirmText: '知道了',
  488. success: res => {}
  489. })
  490. }
  491. }
  492. }
  493. } catch (error) {}
  494. }
  495. this.$nextTick(() => {
  496. this.isError = false
  497. this.isLoading = false
  498. this.refresherTriggered = false
  499. })
  500. } catch {
  501. this.isError = true
  502. this.isLoading = false
  503. }
  504. },
  505. async onLoad({
  506. scene, // 扫码进入的参数
  507. goodsId, // 商品id
  508. serviceId, // 业务员id
  509. smsServiceId, // 短信业务员id
  510. otherType, // 类型:groupbuyList=团购活动,activityList=专区活动,orderList=订单列表,workOrderList=工单列表,couponList=优惠券列表,workOrderDetail
  511. activityType, // 专区活动类型
  512. appOrderId, // 师傅端app订单id(下单支付)
  513. orderId, // 订单id(进入订单详情)
  514. workOrderId, // 工单id(进入工单详情)
  515. workOrderTypeId,
  516. workOrderType,
  517. workOrderImgUrl,
  518. mpOpenId,
  519. type,
  520. objId,
  521. isYB,
  522. isWB,
  523. sharerOpenId
  524. }) {
  525. await this.$onLaunched
  526. setTimeout(() => {
  527. this.isShowTopTooltip = false
  528. this.isShowBottomTooltip = false
  529. }, 10000)
  530. if (this.isLogin) {
  531. this.checkCoupon()
  532. }
  533. // if (mpOpenId) {
  534. // uni.login({
  535. // provider: 'weixin',
  536. // success: loginRes => {
  537. // this.$api.post('/user/auth', {
  538. // code: loginRes.code,
  539. // mpOpenId: mpOpenId
  540. // })
  541. // }
  542. // })
  543. // }
  544. if (sharerOpenId) {
  545. this.$api
  546. .post('/user/bind', {
  547. serviceOpenId: sharerOpenId,
  548. userId: this.$store.state.user.userId
  549. })
  550. .then(res => {
  551. console.log('绑定成功:' + res.message)
  552. })
  553. }
  554. try {
  555. this.userInfo = await this.$getUserInfo()
  556. if (!this.userInfo.isGZSign && !this.userInfo.isFSSign) {
  557. // 点击短信链接进入小程序
  558. if (smsServiceId) {
  559. this.bindUser(smsServiceId)
  560. if (this.userInfo.type !== 'SERVICE') {
  561. this.isSmsReceive = true
  562. this.isReceiveDialog = true
  563. }
  564. }
  565. // 从链接进入小程序
  566. if (serviceId) {
  567. this.bindUser(serviceId)
  568. }
  569. if (goodsId) {
  570. setTimeout(() => {
  571. this.toGoodsDetail(goodsId)
  572. }, 1000)
  573. }
  574. if (isYB) {
  575. setTimeout(() => {
  576. this.toServiceIndex()
  577. }, 1000)
  578. }
  579. // if (isWB) {
  580. // setTimeout(() => {
  581. // this.toMaintenanceCreate()
  582. // }, 1000)
  583. // }
  584. if (otherType) {
  585. // 团购列表
  586. if (otherType === 'groupbuyList') {
  587. this.navToPage('/packageMine/pages/groupbuy/list')
  588. }
  589. // 活动专区列表
  590. if (otherType === 'activityList') {
  591. this.navToPage('/packageGoods/pages/activity?type=' + activityType)
  592. }
  593. // 订单列表
  594. if (otherType === 'orderList') {
  595. this.navToPage('/packageMine/pages/order/list')
  596. }
  597. // 工单列表
  598. if (otherType === 'workOrderList') {
  599. this.navToPage('/packageMine/pages/workOrder/list')
  600. }
  601. // 优惠券列表
  602. if (otherType === 'couponList') {
  603. this.navToPage('/packageMine/pages/coupon/list')
  604. }
  605. }
  606. if (orderId) {
  607. this.navToPage(`/packageMine/pages/order/detail?orderId=${orderId}`)
  608. } else if (workOrderId && workOrderTypeId && workOrderType) {
  609. workOrderType = workOrderType.replace(/\\\\/g, '\\')
  610. this.navToPage(
  611. `/packageMine/pages/workOrder/detail?id=${workOrderTypeId}&type=${workOrderType}&orderNo=${workOrderId}`
  612. )
  613. } else if (workOrderId) {
  614. this.navToPage(`/packageMine/pages/workOrder/list`)
  615. } else if (workOrderImgUrl) {
  616. this.navToPage(`/packageMine/pages/workOrder/receipt?imgurl=${workOrderImgUrl}`)
  617. }
  618. // 扫码进入小程序
  619. if (scene) {
  620. console.log(scene)
  621. // 拿scene的id去获取
  622. this.$api
  623. .get('/common/scene', {
  624. scene: scene
  625. })
  626. .then(res => {
  627. let newScene = res.data.split('&')
  628. this.scene.type = newScene[0]
  629. this.scene.serviceId = newScene[2] || ''
  630. // 如果是商品
  631. if (newScene[0] == 'goods') {
  632. this.scene.goodsId = newScene[1]
  633. this.toGoodsDetail(this.scene.goodsId)
  634. }
  635. // 如果是优惠券
  636. else if (newScene[0] == 'coupon') {
  637. this.scene.couponId = newScene[1]
  638. this.isReceiveDialog = true
  639. // this.receiveCoupon(this.scene.couponId);
  640. }
  641. // 如果是团购分享码
  642. else if (newScene[0] == 'promotion_group') {
  643. this.navToPage('/packageMine/pages/groupbuy/list')
  644. }
  645. // 如果是活动专区分享码
  646. else if (newScene[0] == 'HDZQ') {
  647. this.navToPage('/packageGoods/pages/activity?type=' + newScene[1])
  648. }
  649. // 如果是工程维保
  650. else if (newScene[0] == 'ENGIN_PROJECT_REPAIR') {
  651. this.$navToPage({
  652. url: `/packageHome/pages/maintenance/create?projectId=${newScene[1]}`
  653. })
  654. }
  655. console.log(this.scene)
  656. if (this.scene.serviceId) {
  657. this.bindUser(this.scene.serviceId)
  658. }
  659. })
  660. }
  661. this.$api.post('/worker/remind').then(res => {
  662. this.baoxiandangqianxianxitishi = res.data
  663. })
  664. this.$api.post('/pg/order/base/status/count', {}).then(res => {
  665. this.statusCount = res.data
  666. })
  667. this.$api
  668. .post('/pay/orderCount', {
  669. goodsType: 'P'
  670. })
  671. .then(res => {
  672. this.peijiandzf = res.data.dzf
  673. console.log(res.data)
  674. })
  675. this.$api
  676. .post('/pay/orderCount', {
  677. goodsType: 'M'
  678. })
  679. .then(res => {
  680. this.fucaidzf = res.data.dzf
  681. console.log(res.data)
  682. })
  683. }
  684. } catch (error) {}
  685. },
  686. methods: {
  687. quqianming(err) {},
  688. // 测试支付
  689. quzhifu() {
  690. mini_env(bool => {
  691. this.$api
  692. .post('/order/buytest', {
  693. orderId: Date.now(),
  694. amount: 0.01
  695. })
  696. .then(res => {
  697. // 小程序环境
  698. if (bool) {
  699. uniWebview.navigateTo({
  700. url: `/pages/pay/pay?${Object.entries({
  701. ...res.data,
  702. payPackage: res.data.payPackage.split('=')[0] || '',
  703. payPackageVal: res.data.payPackage.split('=')[1] || ''
  704. })
  705. .map(item => item.join('='))
  706. .join('&')}`
  707. })
  708. }
  709. })
  710. })
  711. },
  712. // 获取公告栏
  713. getNoticebar() {
  714. this.$api.get('/shpping/cart/notice').then(res => {
  715. this.noticeContent = res.data
  716. })
  717. },
  718. // 触发下拉刷新
  719. async refresherrefresh(e) {
  720. this.refresherTriggered = true
  721. this.configInfo = await this.$getConfigInfo()
  722. await this.getBannerList()
  723. try {
  724. if (this.isLogin) {
  725. this.userInfo = await this.$getUserInfo()
  726. if (!this.userInfo.isGZSign && !this.userInfo.isFSSign) {
  727. this.getCategoryList()
  728. this.getServiceList()
  729. this.getCouponList()
  730. this.getWebsitList()
  731. this.getCodeActivityList()
  732. }
  733. } else {
  734. // await this.wxLogin()
  735. this.userInfo = await this.$getUserInfo()
  736. if (!this.userInfo.isGZSign && !this.userInfo.isFSSign) {
  737. this.getCategoryList()
  738. this.getServiceList()
  739. this.getCouponList()
  740. this.getWebsitList()
  741. this.getCodeActivityList()
  742. }
  743. }
  744. } catch (error) {}
  745. this.$nextTick(() => {
  746. this.$isResolve()
  747. this.isError = false
  748. this.refresherTriggered = false
  749. })
  750. },
  751. async wxLogin() {
  752. return new Promise((resolve, reject) => {
  753. uni.login({
  754. provider: 'weixin',
  755. success: loginRes => {
  756. this.$api
  757. .post('/user/auth', {
  758. code: loginRes.code
  759. })
  760. .then(async res => {
  761. this.$store.commit('user/set_token', res.data.token)
  762. this.$store.commit('user/set_openId', res.data.openId)
  763. this.$store.commit('user/set_name', res.data.nickName)
  764. this.$store.commit('user/set_avatar', res.data.avatar)
  765. this.$store.commit('user/set_userId', res.data.userId)
  766. if (res.data.mobile) {
  767. this.$store.commit('user/set_mobile', res.data.mobile)
  768. }
  769. if (!res.data.avatar || !res.data.nickName) {
  770. await this.saveUserInfo(res.data)
  771. }
  772. resolve(1)
  773. })
  774. .catch(() => {
  775. this.refresherTriggered = false
  776. reject(0)
  777. })
  778. }
  779. })
  780. })
  781. },
  782. // 保存用户信息
  783. async saveUserInfo(userInfo) {
  784. let randomNum = new Date().getTime().toString().substr(-6)
  785. let configInfo = await this.$getConfigInfo()
  786. return new Promise((resolve, reject) => {
  787. this.$api
  788. .post('/user/userinfo/save', {
  789. userId: userInfo.userId,
  790. avatarUrl: configInfo.minLogo3,
  791. nickName: `微信用户_${randomNum}`
  792. })
  793. .then(res => {
  794. resolve(res.data)
  795. })
  796. })
  797. },
  798. getCategoryList() {
  799. this.$api
  800. .get('/goods/category/list/all', {
  801. isServiceShow: true
  802. })
  803. .then(res => {
  804. this.categoryList = res.data
  805. })
  806. },
  807. getServiceList() {
  808. this.$api.post('/pg/order/base/type/list').then(res => {
  809. let list = res.data.map(item => {
  810. return {
  811. title: item.orderSmallTypeText,
  812. icon: item.imgUrl,
  813. url: `/packageWorkorder/pages/create/index?typeId=${item.id}&typeName=${item.orderSmallTypeText}`
  814. }
  815. })
  816. this.serviceList = [...list, ...this.baseServiceList]
  817. })
  818. },
  819. getWebsitList() {
  820. this.$api
  821. .get('/user/apply/websit', {
  822. // isAll: false,
  823. examineStatus: 'OK'
  824. })
  825. .then(res => {
  826. this.websitList = res.data || []
  827. })
  828. },
  829. toPage(url) {
  830. if (!url) return this.$toast('敬请期待~')
  831. this.navToPage(url)
  832. },
  833. toPageaa(url, tab) {
  834. if (!url) return this.$toast('敬请期待~')
  835. this.navToPage(url)
  836. this.$nextTick(() => {
  837. this.crossPage.$emit('refreshWorkorderList', { tab: tab })
  838. })
  839. },
  840. toFn(fn) {
  841. if (!fn) return this.$toast('敬请期待~')
  842. this[fn]()
  843. },
  844. toServiceIndex() {
  845. if (this.isWorkerUser) {
  846. this.navToPage(`/packageHome/pages/addvalue/serviceBuy`)
  847. } else {
  848. this.navToPage(`/packageHome/pages/addvalue/explainList`)
  849. }
  850. },
  851. toServiceRecods() {
  852. if (this.isWorkerUser) {
  853. this.navToPage(`/packageWorkorder/pages/orderList?isYb=true`)
  854. } else {
  855. this.navToPage(`/packageWorkorder/pages/userWorkorderList`)
  856. }
  857. },
  858. async checkMaintenance() {
  859. const hasApply = await this.$api
  860. .post('/engin/material/list/page', {
  861. pageNum: 1,
  862. pageSize: -1,
  863. examineStatus: ''
  864. })
  865. .then(res => {
  866. return res.data.records && res.data.records.length > 0
  867. })
  868. const hasOrder = await this.$api
  869. .post('/pg/order/base/list', {
  870. pageNum: 1,
  871. pageSize: -1,
  872. isWb: true
  873. })
  874. .then(res => {
  875. return res.data.records && res.data.records.length > 0
  876. })
  877. return hasApply || hasOrder
  878. },
  879. toMaintenanceCreate() {
  880. if ((this.isWorkerUser || this.isShowMaintenance) && this.userInfo.mobile) {
  881. this.navToPage(`/packageHome/pages/maintenance/create`)
  882. } else {
  883. this.$tips('您暂无维保工程')
  884. }
  885. },
  886. toMaintenanceRecods() {
  887. if (this.isWorkerUser) {
  888. this.navToPage(`/packageWorkorder/pages/orderList?isWb=true`)
  889. } else {
  890. this.navToPage(`/packageWorkorder/pages/userWorkorderList?isWb=1`)
  891. }
  892. },
  893. toMall() {
  894. this.$navToPage(
  895. {
  896. url: '/pages/goods/index'
  897. },
  898. 'switchTab'
  899. )
  900. },
  901. // 获取轮播图列表
  902. async getBannerList() {
  903. return new Promise((resolve, reject) => {
  904. this.$api
  905. .get('/common/list/page', {
  906. pageNum: 1,
  907. pageSize: 10,
  908. state: true,
  909. port: 'SHOP'
  910. })
  911. .then(res => {
  912. this.bannerList = res.data.records
  913. resolve(1)
  914. })
  915. .catch(res => {
  916. reject(0)
  917. })
  918. })
  919. },
  920. // 点击轮播图
  921. clickBanner(index) {
  922. let item = this.bannerList[index]
  923. if (item.type == 3) {
  924. this.toActivityList(item.goodsId)
  925. } else {
  926. this.toGoodsDetail(item.goodsId)
  927. }
  928. },
  929. // 获取扫码活动列表
  930. async getCodeActivityList() {
  931. return new Promise((resolve, reject) => {
  932. this.$api
  933. .post('/promotion/questionnaire/list', {
  934. state: 1
  935. })
  936. .then(res => {
  937. this.codeActivityList = res.data
  938. resolve(1)
  939. })
  940. .catch(res => {
  941. reject(0)
  942. })
  943. })
  944. },
  945. // 获取可领优惠券列表
  946. getCouponList() {
  947. this.$api
  948. .get('/coupon/list/all', {
  949. userId: this.$store.state.user.userId
  950. })
  951. .then(res => {
  952. this.couponList = res.data.filter(item => {
  953. return item.obtainType === 1
  954. })
  955. if (this.couponList && this.couponList.length > 0) {
  956. this.couponDialogImgUrl = this.couponList[0].imgSrc
  957. }
  958. })
  959. },
  960. // 关闭弹窗
  961. closeDialog() {
  962. this.$refs.dialog.step(
  963. {
  964. scale: 0
  965. },
  966. {
  967. duration: 400
  968. }
  969. )
  970. this.$refs.dialog.run(() => {
  971. this.isShowCouponDialog = false
  972. })
  973. this.$refs.dialogBtn.step(
  974. {
  975. scale: 0
  976. },
  977. {
  978. duration: 400
  979. }
  980. )
  981. this.$refs.dialogBtn.run(() => {
  982. this.isShowCouponDialog = false
  983. })
  984. },
  985. // 领取优惠券
  986. handleCoupon() {
  987. let ids = this.couponList.map(item => {
  988. return item.couponId
  989. })
  990. this.$api
  991. .post('/coupon/obtain', {
  992. userId: this.$store.state.user.userId,
  993. couponIds: ids.join(',')
  994. })
  995. .then(res => {
  996. this.closeDialog()
  997. setTimeout(() => {
  998. this.$tips('优惠券领取成功,请及时使用!')
  999. }, 500)
  1000. })
  1001. },
  1002. // 进入商品详情
  1003. toGoodsDetail(id) {
  1004. if (!id) {
  1005. return false
  1006. }
  1007. this.$navToPage({
  1008. url: '/packageGoods/pages/detail?id=' + id
  1009. })
  1010. },
  1011. // 进入活动列表
  1012. toActivityList(type) {
  1013. this.$navToPage({
  1014. url: '/packageGoods/pages/activity?type=' + type
  1015. })
  1016. },
  1017. // 进入扫码活动列表
  1018. toCodeActivityList() {
  1019. this.$navToPage({
  1020. url: '/packageHome/pages/codeActivity/activityList'
  1021. })
  1022. },
  1023. // 绑定用户关系
  1024. bindUser(serviceId) {
  1025. this.$api
  1026. .post('/user/bind', {
  1027. serviceId: serviceId,
  1028. userId: this.$store.state.user.userId
  1029. })
  1030. .then(res => {
  1031. console.log('绑定成功:' + res.message)
  1032. })
  1033. },
  1034. // 去分类列表
  1035. toClassifyList(categoryId) {
  1036. this.navToPage(`/packageGoods/pages/classify?categoryId=${categoryId}`)
  1037. },
  1038. // 点击二级分类
  1039. toGoodsList(pid, cid, cname) {
  1040. this.$navToPage({
  1041. url: `/packageGoods/pages/list?pid=${pid}&cid=${cid}&cname=${cname}`
  1042. })
  1043. },
  1044. // 进入商品详情
  1045. toGoodsDetail(id) {
  1046. if (!id) {
  1047. return false
  1048. }
  1049. this.$navToPage({
  1050. url: '/packageGoods/pages/detail?id=' + id
  1051. })
  1052. },
  1053. // 检查是否有优惠券过期
  1054. checkCoupon() {
  1055. this.$api.get('/coupon/timeout').then(res => {
  1056. if (res.data) {
  1057. this.isCouponDialog = true
  1058. }
  1059. })
  1060. },
  1061. // 进入我的优惠券
  1062. toMyCoupon() {
  1063. this.isCouponDialog = false
  1064. this.navToPage('/packageMine/pages/coupon/list')
  1065. },
  1066. // 领取优惠券
  1067. receiveCoupon(id) {
  1068. if (!this.isLogin) {
  1069. return this.navToPage('/pages/login/indexs')
  1070. }
  1071. if (this.isSmsReceive) {
  1072. this.$api
  1073. .get('/coupon/obtain')
  1074. .then(res => {
  1075. this.isReceiveDialog = false
  1076. this.$modal({
  1077. content: '领取成功',
  1078. confirmText: '去看看'
  1079. })
  1080. .then(() => {
  1081. this.toMyCoupon()
  1082. })
  1083. .catch(() => {})
  1084. })
  1085. .catch(res => {
  1086. this.isReceiveDialog = false
  1087. this.$tips(`领取失败:${res.message}`)
  1088. })
  1089. } else {
  1090. this.$api
  1091. .get('/coupon/transfer/coupon2', {
  1092. userCouponId: this.scene.couponId,
  1093. shareUserId: this.scene.serviceId
  1094. })
  1095. .then(res => {
  1096. this.isReceiveDialog = false
  1097. this.$modal({
  1098. content: '领取成功',
  1099. confirmText: '去看看'
  1100. })
  1101. .then(() => {
  1102. this.toMyCoupon()
  1103. })
  1104. .catch(() => {})
  1105. })
  1106. .catch(res => {
  1107. this.isReceiveDialog = false
  1108. this.$tips(`领取失败:${res.message}`)
  1109. })
  1110. }
  1111. },
  1112. // 跳转微信公众号链接
  1113. toWxLink() {
  1114. let link = this.configInfo.pubOfficeAddr
  1115. if (!link) return false
  1116. this.navToPage('/pages/index/webview?link=' + link)
  1117. },
  1118. navToPage(url) {
  1119. this.$navToPage({
  1120. url
  1121. })
  1122. },
  1123. toWorkorder() {
  1124. this.$navToPage({
  1125. url: `/packageWorkorder/pages/userWorkorderList`
  1126. })
  1127. }
  1128. }
  1129. }
  1130. </script>
  1131. <style lang="scss" scoped>
  1132. .all-container {
  1133. box-sizing: border-box;
  1134. padding: 1rpx 20rpx 20rpx;
  1135. }
  1136. .top-tooltip {
  1137. width: 390rpx;
  1138. transform-origin: center bottom;
  1139. z-index: 1025;
  1140. position: fixed;
  1141. top: 20rpx;
  1142. right: 20rpx;
  1143. background: rgba(0, 0, 0, 0.8);
  1144. min-width: 150px;
  1145. border-radius: 8rpx;
  1146. padding: 15rpx 20rpx;
  1147. color: #ffffff;
  1148. text-align: justify;
  1149. box-shadow: 0 4rpx 24rpx 0 rgba(0, 0, 0, 0.1);
  1150. word-break: break-all;
  1151. box-sizing: border-box;
  1152. .content {
  1153. display: flex;
  1154. align-items: center;
  1155. justify-content: space-between;
  1156. .left {
  1157. view {
  1158. color: #ffffff;
  1159. font-size: 24rpx;
  1160. display: flex;
  1161. align-items: center;
  1162. &:last-child {
  1163. margin-top: 8rpx;
  1164. }
  1165. }
  1166. .iconfont {
  1167. color: #ffffff;
  1168. font-size: 36rpx;
  1169. margin: 0 4rpx;
  1170. }
  1171. }
  1172. .close {
  1173. flex-shrink: 0;
  1174. font-size: 34rpx;
  1175. color: #ffffff;
  1176. margin-left: 20rpx;
  1177. }
  1178. }
  1179. .arrow {
  1180. top: -6px;
  1181. right: 110rpx;
  1182. margin-right: 3px;
  1183. border-top-width: 0;
  1184. border-bottom-color: #ebeef5;
  1185. border-width: 6px;
  1186. filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.03));
  1187. position: absolute;
  1188. display: block;
  1189. width: 0;
  1190. height: 0;
  1191. border-color: transparent;
  1192. border-style: solid;
  1193. &::after {
  1194. position: absolute;
  1195. display: block;
  1196. width: 0;
  1197. height: 0;
  1198. border-color: transparent;
  1199. border-style: solid;
  1200. top: -12px;
  1201. margin-left: -6px;
  1202. border-top-width: 0;
  1203. border-bottom-color: rgba(0, 0, 0, 0.8);
  1204. content: ' ';
  1205. border-width: 6px;
  1206. }
  1207. }
  1208. }
  1209. .bottom-tooltip {
  1210. z-index: 1025;
  1211. position: fixed;
  1212. bottom: 20rpx;
  1213. left: 20rpx;
  1214. width: 710rpx;
  1215. background: rgba(0, 0, 0, 0.8);
  1216. border-radius: 8rpx;
  1217. display: flex;
  1218. align-items: center;
  1219. justify-content: space-between;
  1220. height: 72rpx;
  1221. padding: 0 20rpx 0 30rpx;
  1222. box-sizing: border-box;
  1223. .left {
  1224. display: flex;
  1225. align-items: center;
  1226. .close {
  1227. font-size: 34rpx;
  1228. color: #ffffff;
  1229. }
  1230. .text {
  1231. font-size: 24rpx;
  1232. color: #ffffff;
  1233. margin-left: 16rpx;
  1234. }
  1235. }
  1236. .btn {
  1237. font-size: 24rpx;
  1238. color: #ffffff;
  1239. background: #ff3f42;
  1240. padding: 0 16rpx;
  1241. height: 48rpx;
  1242. line-height: 48rpx;
  1243. border-radius: 48rpx;
  1244. }
  1245. }
  1246. .home-title {
  1247. display: flex;
  1248. align-items: center;
  1249. justify-content: space-between;
  1250. .left {
  1251. font-size: 34rpx;
  1252. color: $main-font;
  1253. font-weight: bold;
  1254. }
  1255. .right {
  1256. display: flex;
  1257. align-items: center;
  1258. .text {
  1259. color: $sec-font;
  1260. font-size: 28rpx;
  1261. }
  1262. .iconfont {
  1263. font-size: 24rpx;
  1264. color: $sec-font;
  1265. margin-left: 8rpx;
  1266. }
  1267. }
  1268. }
  1269. .home-container {
  1270. background: #f5f5f5;
  1271. }
  1272. .all-container {
  1273. padding: 1rpx 20rpx 20rpx;
  1274. }
  1275. .card {
  1276. @include zj-card;
  1277. padding: 30rpx;
  1278. margin-top: 20rpx;
  1279. background: linear-gradient(180deg, #f3f9fe 0%, #ffffff 100%);
  1280. }
  1281. .swiper-container {
  1282. @include zj-card;
  1283. margin-top: 20rpx;
  1284. padding: 0 20rpx;
  1285. ::v-deep .u-swiper {
  1286. height: 350rpx !important;
  1287. .u-swiper__wrapper {
  1288. height: 350rpx !important;
  1289. }
  1290. .u-swiper__wrapper__item__wrapper__image {
  1291. height: 350rpx !important;
  1292. }
  1293. }
  1294. }
  1295. .swiper2-container {
  1296. @include zj-card;
  1297. position: relative;
  1298. margin-top: 20rpx;
  1299. ::v-deep .u-swiper {
  1300. height: 188rpx !important;
  1301. .u-swiper__wrapper {
  1302. height: 188rpx !important;
  1303. }
  1304. .u-swiper__wrapper__item__wrapper__image {
  1305. height: 188rpx !important;
  1306. }
  1307. }
  1308. }
  1309. .noticebar-container {
  1310. margin-top: 30rpx;
  1311. }
  1312. .service-container {
  1313. padding: 0;
  1314. .home-title {
  1315. padding: 30rpx 30rpx 0;
  1316. }
  1317. .list {
  1318. display: flex;
  1319. margin-top: 40rpx;
  1320. flex-wrap: wrap;
  1321. padding-bottom: 30rpx;
  1322. .item {
  1323. width: 25%;
  1324. display: flex;
  1325. flex-direction: column;
  1326. align-items: center;
  1327. box-sizing: border-box;
  1328. margin-bottom: 20rpx;
  1329. &:nth-child(5),
  1330. &:nth-child(6),
  1331. &:nth-child(7),
  1332. &:nth-child(8) {
  1333. margin-bottom: 0;
  1334. }
  1335. image {
  1336. width: 76rpx;
  1337. height: 76rpx;
  1338. }
  1339. text {
  1340. font-size: 26rpx;
  1341. font-weight: 500;
  1342. margin-top: 16rpx;
  1343. }
  1344. }
  1345. }
  1346. }
  1347. .share-container {
  1348. .list {
  1349. display: flex;
  1350. margin-top: 40rpx;
  1351. .item {
  1352. flex: 1;
  1353. padding: 20rpx;
  1354. border-radius: 12rpx;
  1355. display: flex;
  1356. align-items: center;
  1357. image {
  1358. flex-shrink: 0;
  1359. width: 88rpx;
  1360. height: 88rpx;
  1361. }
  1362. .text {
  1363. margin-left: 20rpx;
  1364. font-size: 32rpx;
  1365. }
  1366. &:first-child {
  1367. margin-right: 30rpx;
  1368. background: #e8f5fe;
  1369. .text {
  1370. color: #6ca2f8;
  1371. }
  1372. }
  1373. &:last-child {
  1374. background: #fff9f4;
  1375. .text {
  1376. color: #d87e3b;
  1377. }
  1378. }
  1379. }
  1380. }
  1381. }
  1382. .order-container {
  1383. .list {
  1384. display: flex;
  1385. justify-content: space-between;
  1386. margin-top: 40rpx;
  1387. .item {
  1388. display: flex;
  1389. flex-direction: column;
  1390. align-items: center;
  1391. box-sizing: border-box;
  1392. padding: 0 10rpx;
  1393. image {
  1394. width: 76rpx;
  1395. height: 76rpx;
  1396. }
  1397. text {
  1398. font-size: 26rpx;
  1399. font-weight: 500;
  1400. margin-top: 16rpx;
  1401. }
  1402. }
  1403. }
  1404. }
  1405. .other-container {
  1406. padding: 30rpx 0;
  1407. .home-title {
  1408. padding: 0 30rpx;
  1409. }
  1410. .list {
  1411. display: flex;
  1412. margin-top: 40rpx;
  1413. .item {
  1414. width: 25%;
  1415. display: flex;
  1416. flex-direction: column;
  1417. align-items: center;
  1418. box-sizing: border-box;
  1419. padding: 0 10rpx;
  1420. image {
  1421. width: 76rpx;
  1422. height: 76rpx;
  1423. }
  1424. text {
  1425. font-size: 26rpx;
  1426. font-weight: 500;
  1427. margin-top: 16rpx;
  1428. }
  1429. }
  1430. }
  1431. }
  1432. .contact-container {
  1433. .list {
  1434. margin-top: 20rpx;
  1435. .item {
  1436. display: flex;
  1437. align-items: center;
  1438. height: 100rpx;
  1439. background: none;
  1440. padding: 0;
  1441. &::after {
  1442. border: none;
  1443. }
  1444. image {
  1445. width: 44rpx;
  1446. height: 44rpx;
  1447. margin-right: 20rpx;
  1448. }
  1449. .title {
  1450. flex: 1;
  1451. font-size: 30rpx;
  1452. font-weight: 500;
  1453. text-align: left;
  1454. line-height: 1;
  1455. }
  1456. .iconfont {
  1457. font-size: 26rpx;
  1458. color: $sec-font;
  1459. }
  1460. }
  1461. .wrap1 {
  1462. // border-bottom: 1px solid #eaeaea;
  1463. padding-bottom: 20rpx;
  1464. padding-left: 60rpx;
  1465. .it {
  1466. padding: 20rpx 0;
  1467. border-bottom: 1px solid #f5f5f5;
  1468. &:last-child {
  1469. border-bottom: none;
  1470. }
  1471. .top {
  1472. display: flex;
  1473. align-items: center;
  1474. justify-content: space-between;
  1475. .left {
  1476. font-size: 28rpx;
  1477. }
  1478. .right {
  1479. .iconfont {
  1480. font-size: 36rpx;
  1481. color: $theme-color;
  1482. }
  1483. }
  1484. }
  1485. .address {
  1486. margin-top: 12rpx;
  1487. font-size: 28rpx;
  1488. color: $sec-font;
  1489. }
  1490. }
  1491. }
  1492. .wrap2 {
  1493. display: flex;
  1494. align-items: center;
  1495. justify-content: space-between;
  1496. padding-left: 60rpx;
  1497. .left {
  1498. font-size: 28rpx;
  1499. }
  1500. .right {
  1501. .iconfont {
  1502. font-size: 36rpx;
  1503. color: $theme-color;
  1504. }
  1505. }
  1506. }
  1507. }
  1508. }
  1509. .dialog-container {
  1510. position: fixed;
  1511. z-index: 1000000;
  1512. top: 0;
  1513. left: 0;
  1514. width: 100%;
  1515. height: 100vh;
  1516. display: flex;
  1517. align-items: center;
  1518. justify-content: center;
  1519. flex-direction: column;
  1520. background: rgba($color: #000000, $alpha: 0.6);
  1521. .image {
  1522. width: 600rpx;
  1523. display: block;
  1524. border-radius: 20rpx;
  1525. margin-top: 40rpx;
  1526. }
  1527. .iconfont {
  1528. font-size: 68rpx;
  1529. color: #ffffff;
  1530. margin-top: 40rpx;
  1531. }
  1532. }
  1533. </style>
  1534. <style>
  1535. ::-webkit-scrollbar {
  1536. display: none;
  1537. width: 0 !important;
  1538. height: 0 !important;
  1539. -webkit-appearance: none;
  1540. background: transparent;
  1541. color: transparent;
  1542. }
  1543. </style>