activityDetail.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616
  1. <template>
  2. <view class="content">
  3. <view class="top">
  4. <img :src="img" alt="" class="topimg">
  5. </view>
  6. <view class="cont">
  7. <view class="name">{{info.activityName}}</view>
  8. <view class="name2" v-if="info.startTime">{{info.startTime.slice(0,10)}}~{{info.endTime.slice(0,10)}}</view>
  9. <view class="name3">{{info.activityContent}}</view>
  10. </view>
  11. <view class="shopBox">
  12. <view class="shopBoxTop">
  13. <view class="shopMs">活动门店</view>
  14. <view class="shopTy" @click="showuse">
  15. <view class="shopTyTxt">{{shopckList.length}}家门店通用</view>
  16. <img src="../../static/img/jt2.png" alt="" class="shopjt">
  17. </view>
  18. </view>
  19. <view class="shopCont">
  20. <view class="shopContLeft">
  21. <view class="shopName">{{shopInfo.shopName}}</view>
  22. <view class="shopaddress">{{shopInfo.address}}</view>
  23. </view>
  24. <view class="shopContRight">
  25. <view class="shopContRightLine" @click="getmap">
  26. <img src="../../static/img/icon_map.png" alt="" class="shopRightIcon">
  27. <view class="shopRightTxt">地图</view>
  28. </view>
  29. <view class="shopRightSx"></view>
  30. <view class="shopContRightLine" @click="call">
  31. <img src="../../static/img/icon_phone.png" alt="" class="shopRightIcon">
  32. <view class="shopRightTxt">电话</view>
  33. </view>
  34. </view>
  35. </view>
  36. </view>
  37. <view class="detailBOx" v-if="imgListArr">
  38. <view class="detailTitle">活动详情</view>
  39. <view class="detailImgBox" v-for="(item,index) in imgListArr">
  40. <img :src="item.img" alt="" class="detailImg">
  41. </view>
  42. </view>
  43. <view style="height: 120rpx;"></view>
  44. <view class="bottom" >
  45. <view class="bottomLeft" @click="edit1" v-if="iOSInfo.indexOf('Q022')!=-1||!iOSInfo" >编辑活动内容</view>
  46. <view class="bottomRight" @click="goshare" v-if="iOSInfo.indexOf('Q022')!=-1||!iOSInfo">分享</view>
  47. <view class="bottomRight2" @click="goshare" v-else>分享</view>
  48. </view>
  49. <!-- 适用门店 -->
  50. <view class="baomingBox ckshopBox" v-if="useShopShow" @click="noShowShop2">
  51. <view class="baomingCont" @click.stop="">
  52. <view class="bmTop">
  53. <view class="bmTitle">活动门店</view>
  54. <img src="../../static/img/chahao.png" alt="" class="bmChimg" @click="noShowShop2">
  55. </view>
  56. <view style="padding: 0 24rpx; height: 65vh;overflow-y: scroll;">
  57. <view class="ckshopLine" v-for="(item,index) in shopckList" >
  58. <view class="shoplineLeft">
  59. <image :src="item.photoPath" mode="" class="shopImg" v-if="item.photoPath"></image>
  60. <image src="../../static/img/noimg.png" mode="" class="shopImg" v-else></image>
  61. </view>
  62. <view class="shopright" style="padding-left: 20rpx;">
  63. <view class="shopTop">
  64. <view class="shopName">{{item.shopName}}</view>
  65. </view>
  66. <view class="brandsBg" v-if="item.brands">
  67. <view class="brands" v-for="(v,index2) in item.brands.split(',')">{{v}}</view>
  68. </view>
  69. <view class="shopTime"><span v-if="item.startTime">{{item.startTime}}</span> - <span
  70. v-if="item.endTime">{{item.endTime}}</span> </view>
  71. <view class="shopBottomLeft">
  72. <span class="shopaddress"
  73. v-if="item.address">{{item.provinceName}}{{item.cityName}}{{item.areaName}}{{item.address}}</span>
  74. <span v-if="item.distance&&item.distance!= '0.00'">{{item.distance}}km</span>
  75. </view>
  76. </view>
  77. </view>
  78. </view>
  79. </view>
  80. </view>
  81. <!-- <audio id="video" controls autoplay="autoplay" ref="iosclick" loop="loop" >
  82. <source src="http://dmsimg.66km.com/music/sakuratears.mp3" type="audio/mpeg">
  83. </audio> -->
  84. <img src="../../static/img/mp3.png" class="mp3Img" @click="play()" v-if="!payshow&mp3Url!=''">
  85. <img src=".../../static/img/mp31.png" class="mp3Img" @click="play2()" id="bofang" v-if="payshow&mp3Url!=''">
  86. </view>
  87. </template>
  88. <script>
  89. export default {
  90. data() {
  91. return {
  92. info:'',
  93. type:'',
  94. shopNum:'',
  95. shopInfo:'',
  96. useShopShow:false,
  97. shopckList:'',
  98. ckmusic:'',
  99. bgmMusic:'',
  100. payshow:false,
  101. mp3Url:'',
  102. id:'',
  103. img:'',
  104. imgListArr:'',
  105. iOSInfo:'',
  106. }
  107. },
  108. onLoad(opt) {
  109. // if(opt.type==1){
  110. // this.type=1;
  111. // this.info = uni.getStorageSync("editdata");
  112. // this.shopNum=this.info.shopList.split(',').length
  113. // uni.setNavigationBarTitle({
  114. // title:this.info.activityName
  115. // })
  116. // }
  117. this.id=opt.id;
  118. this.getDetails()
  119. var qxnum=uni.getStorageSync("quanxian");
  120. if(qxnum==1){
  121. this.iOSInfo = JSON.parse(JSON.stringify(window.iOSInfo));
  122. }else if(qxnum==2){
  123. window.getAndroid=this.getAndroid;
  124. }
  125. /* this.shopckList= uni.getStorageSync("shopckList");
  126. this.ckmusic=uni.getStorageSync("ckmusic");
  127. if(this.ckmusic){
  128. this.mp3Url=this.ckmusic.music;
  129. this.bgmMusic = uni.createInnerAudioContext();
  130. this.bgmMusic.autoplay = true;//自动播放
  131. this.bgmMusic.loop = true;//循环播放
  132. this.bgmMusic.src = 'http://dmsimg.66km.com/music/sakuratears.mp3';//背景音乐地址
  133. this.bgmMusic.onPlay(function(){
  134. console.log('背景音乐播放中');
  135. });
  136. this.bgmMusic.onError((res) => {
  137. console.log(res.errMsg);
  138. console.log(res.errCode);
  139. });
  140. } */
  141. //console.log(this.bgmMusic)
  142. },
  143. onUnload(){
  144. this.bgmMusic.stop()
  145. },
  146. methods: {
  147. getAndroid(e){
  148. this.iOSInfo=e
  149. },
  150. goshare(){
  151. var obj={
  152. ActivityContent: this.info.activityContent,
  153. ActivityName:this.info.activityName,
  154. EndTime: this.info.endTime,
  155. ID: this.info.id,
  156. Img: this.img,
  157. StartTime: this.info.createTime,
  158. state: '',
  159. }
  160. console.log(obj)
  161. var standalone = window.navigator.standalone
  162. var userAgent = window.navigator.userAgent.toLowerCase()
  163. var safari = /safari/.test(userAgent)
  164. var ios = /iphone|ipod|ipad|mac/.test(userAgent)
  165. var android = /android/.test(userAgent)
  166. if (ios) {
  167. if ( true) {//!standalone&& !safari
  168. window.webkit.messageHandlers.goShare.postMessage(obj)
  169. }
  170. } else if (android) {
  171. window.android.share(JSON.stringify(obj))
  172. // window.android.writeoff(this.id)
  173. }
  174. },
  175. getDetails(){
  176. uni.showLoading({
  177. title: '加载中'
  178. })
  179. this.$http('openH5SetTheGuest/getActivityDetails', {
  180. id:this.id
  181. },'GET').then(res => {
  182. uni.hideLoading();
  183. this.info=res.data.data
  184. // this.activityName=jkdata.activityName;
  185. // this.activityContent=jkdata.activityContent;
  186. // this.money=jkdata.money;
  187. // this.number=jkdata.number;
  188. // this.clWhereString=jkdata.clWhere;
  189. // this.clWhereList=this.clWhereString.split(',');
  190. // this.startTime=jkdata.startTime.slice(0,10);
  191. // this.endTime=jkdata.endTime.slice(0,10);
  192. // this.payType=jkdata.payType;
  193. this.img=res.data.img.img;
  194. /* if(res.data.imgList){
  195. res.data.imgList.forEach(item=>{
  196. this.imgListArr.push(item.img)
  197. })
  198. } */
  199. this.imgListArr=res.data.imgList
  200. this.shopckList=res.data.shopList;
  201. console.log()
  202. this.getShopinfo()
  203. this.ckMusic=res.data.selectedMusic;
  204. if(this.ckMusic){
  205. this.music=this.ckMusic.id;
  206. }else{
  207. }
  208. //console.log(this.imgListArr)
  209. //this.list=res.data
  210. })
  211. },
  212. play2(){
  213. this.bgmMusic.play();
  214. this.payshow=false;
  215. },
  216. play(){
  217. this.payshow=true;
  218. this.bgmMusic.stop(()=>{
  219. console.log('背景音乐停止了');
  220. });
  221. },
  222. noShowShop2(){
  223. this.useShopShow=false;
  224. },
  225. showuse(){
  226. this.useShopShow=true;
  227. },
  228. call() {
  229. uni.makePhoneCall({
  230. phoneNumber: this.shopInfo.mobilePhone
  231. });
  232. },
  233. getmap() {
  234. console.log("打开地图");
  235. return false;
  236. var that = this;
  237. if (!that.shopInfo.lat || !that.shopInfo.lng) {
  238. uni.showToast({
  239. title: '该店铺未设置定位',
  240. icon: 'none',
  241. duration: 3000
  242. });
  243. } else {
  244. uni.openLocation({
  245. latitude: Number(that.shopInfo.lat),
  246. longitude: Number(that.shopInfo.lng),
  247. name: that.shopInfo.shopName,
  248. address: that.shopInfo.provinceName + that.shopInfo.cityName + that.shopInfo.areaName + that.shopInfo.address,
  249. success: function() {
  250. console.log('success');
  251. },
  252. fail(err) {
  253. console.log(err)
  254. }
  255. });
  256. }
  257. },
  258. edit1(){
  259. uni.navigateTo({
  260. url: 'eadit?id=' + this.id
  261. })
  262. },
  263. auditSetTheGuest(){
  264. uni.showLoading({
  265. title: '加载中'
  266. })
  267. this.$http('openH5SetTheGuest/auditSetTheGuest', this.info,'POST').then(res => {
  268. uni.hideLoading();
  269. if(res.code==0){
  270. uni.showToast({
  271. title: '活动已生成',
  272. icon:'none',
  273. duration: 2000
  274. });
  275. uni.navigateTo({
  276. url:'activity?type=2'
  277. })
  278. }
  279. //this.list=res.data
  280. })
  281. },
  282. getShopinfo(){
  283. this.$http('openH5SetTheGuest/getShopInfo',{},'GET').then(res => {
  284. //this.shopInfo=res.data;
  285. var shopinfo=res.data;
  286. this.shopckList.forEach(item=>{
  287. if(item.id==shopinfo.id){
  288. this.shopInfo=shopinfo
  289. }
  290. })
  291. if(this.shopInfo==''){
  292. this.shopInfo=this.shopckList[0]
  293. }
  294. })
  295. },
  296. generate(){
  297. var that=this;
  298. uni.showModal({
  299. title: '提示',
  300. content: '活动已生成,是否立即启用',
  301. cancelText:'暂不启用',
  302. confirmText:'立即启用',
  303. success: function(res) {
  304. if (res.confirm) {
  305. that.info.clState=2;
  306. that.auditSetTheGuest()
  307. }else{
  308. console.log("no")
  309. that.info.clState=1;
  310. that.auditSetTheGuest()
  311. }
  312. }
  313. });
  314. }
  315. }
  316. }
  317. </script>
  318. <style scoped>
  319. .mp3Img{
  320. /* transform: translate(-1584.4%, 121.5%) scale(1); */
  321. position: fixed;
  322. top: 100rpx;
  323. right: 40rpx;
  324. width: 60rpx;
  325. height: 60rpx;
  326. }
  327. .shopImg {
  328. width: 146rpx;
  329. height: 146rpx;
  330. border-radius: 6rpx;
  331. }
  332. .ckshopLine{
  333. display: flex;
  334. padding: 20rpx 0;
  335. border-bottom: 1px solid #EEEEEE;
  336. }
  337. .baomingBox{
  338. width: 750rpx;
  339. height: 100vh;
  340. background: rgba(0, 0, 0, 0.4);
  341. position: fixed;
  342. top: 0;
  343. left: 0;
  344. z-index: 11;
  345. }
  346. .bmshopjt{
  347. width: 12rpx;
  348. height: 20rpx;
  349. margin-top: 10rpx;
  350. }
  351. .bmlineInput{
  352. color: #333333;
  353. font-size: 28rpx;
  354. height: 98rpx;
  355. line-height: 98rpx;
  356. }
  357. .bmshopname{
  358. font-weight: 400;
  359. color: #999999;
  360. font-size: 28rpx;
  361. line-height: 40rpx;
  362. width: 500rpx;
  363. white-space:nowrap;
  364. overflow:hidden;
  365. text-overflow:ellipsis;
  366. }
  367. .bmshopLine{
  368. display: flex;
  369. justify-content: space-between;
  370. padding: 26rpx 0;
  371. border-bottom: 1px solid #EEEEEE;
  372. }
  373. .bmLine{
  374. border-bottom: 1px solid #EEEEEE;
  375. }
  376. .bmTop{
  377. display: flex;
  378. justify-content: space-between;
  379. padding: 40rpx 24rpx 10rpx 24rpx;
  380. }
  381. .bmTitle{
  382. font-weight: 500;
  383. color: #3C3C3C;
  384. font-size: 30rpx;
  385. line-height: 36rpx;
  386. }
  387. .bmChimg{
  388. width: 36rpx;
  389. height: 36rpx;
  390. }
  391. .baomingCont{
  392. position: absolute;
  393. width: 750rpx;
  394. /* height:850rpx; */
  395. /* padding-bottom: constant(safe-area-inset-bottom);
  396. padding-bottom: env(safe-area-inset-bottom); */
  397. padding-bottom: 10rpx;
  398. left: 0;
  399. bottom: 0;
  400. background: #ffffff;
  401. border-radius: 24rpx 24rpx 0px 0px;
  402. }
  403. .shopRightIcon{
  404. width: 44rpx;
  405. height: 44rpx;
  406. display: block;
  407. margin: 0 auto;
  408. margin-bottom: 10rpx;
  409. }
  410. .shopName{
  411. color: #3C3C3C;width: 500rpx;
  412. font-size: 28rpx;
  413. }
  414. .shopaddress{
  415. font-weight: 400;
  416. color: #999999;
  417. font-size: 24rpx;
  418. padding-top: 10rpx;
  419. width: 500rpx;
  420. }
  421. .shopRightSx{
  422. width: 2rpx;
  423. height: 69rpx;
  424. background:#EEEEEE ;
  425. margin-left: 34rpx;
  426. margin-right: 34rpx;
  427. margin-top: 14rpx;
  428. }
  429. .shopCont{
  430. display: flex;
  431. justify-content: space-between;
  432. padding-top: 25rpx;
  433. }
  434. .shopContRight{
  435. display: flex;
  436. }
  437. .shopContRightLine{
  438. text-align: center;
  439. color: #999999;
  440. font-size: 24rpx;
  441. }
  442. .content{
  443. min-height: 100vh;
  444. background:#F4F5F7;
  445. }
  446. .detailImg{
  447. width: 750rpx;
  448. display: block;
  449. }
  450. .detailBOx{
  451. background: #ffffff;
  452. margin-top: 20rpx;
  453. }
  454. .detailTitle{
  455. color: #3C3C3C;
  456. font-weight: 500;
  457. padding: 20rpx 24rpx;
  458. font-size: 30rpx;
  459. }
  460. .topimg{
  461. width: 750rpx;
  462. }
  463. .shopMs{
  464. font-weight: 500;
  465. color: #222222;
  466. line-height: 42rpx;
  467. font-size: 30rpx;
  468. }
  469. .shopBox{
  470. background: #ffffff;
  471. margin-top: 20rpx;
  472. padding: 20rpx 34rpx;
  473. }
  474. .shopBoxTop{
  475. display: flex;
  476. justify-content: space-between;
  477. }
  478. .shopTy{
  479. display: flex;
  480. }
  481. .shopTyTxt{
  482. font-weight: 400;
  483. color: #666666;
  484. font-size: 24rpx;
  485. line-height: 42rpx;
  486. }
  487. .shopjt{
  488. width: 14rpx;
  489. height: 23rpx;
  490. margin-top: 10rpx;
  491. margin-left: 10rpx;
  492. }
  493. .cont{
  494. background: #ffffff;
  495. border-radius: 24rpx 24rpx 0px 0px;
  496. margin-top: -30rpx;
  497. padding: 30rpx 24rpx;
  498. position: relative;
  499. }
  500. .name{
  501. color: #3C3C3C;
  502. line-height: 42rpx;
  503. font-weight: 500;
  504. font-size: 30rpx;
  505. }
  506. .name2{
  507. color: #3C3C3C;
  508. line-height: 36rpx;
  509. font-weight: 400;
  510. font-size: 26rpx;
  511. padding-top: 16rpx;
  512. }
  513. .name3{
  514. color: #999999;
  515. line-height: 36rpx;
  516. font-weight: 400;
  517. font-size: 26rpx;
  518. padding-top: 16rpx;
  519. }
  520. .bottom{
  521. width: 750rpx;
  522. height: 98rpx;
  523. background: #FFFFFF;
  524. position: fixed;
  525. bottom: 0;
  526. left: 0;
  527. display: flex;
  528. }
  529. .bottomLeft{
  530. width: 375rpx;
  531. line-height: 98rpx;
  532. text-align: center;
  533. color: #3C3C3C;
  534. font-size: 30rpx;
  535. }
  536. .bottomRight{
  537. width: 375rpx;
  538. height: 98rpx;
  539. background: #3F90F7;
  540. line-height: 98rpx;
  541. text-align: center;
  542. color: #FFFFFF;
  543. font-size: 30rpx;
  544. }
  545. .bottomRight2{
  546. width: 750rpx;
  547. height: 98rpx;
  548. background: #3F90F7;
  549. line-height: 98rpx;
  550. text-align: center;
  551. color: #FFFFFF;
  552. font-size: 30rpx;
  553. }
  554. .brandsBg {
  555. display: flex;
  556. height: 38rpx;
  557. flex-wrap: wrap;
  558. align-items: center;
  559. overflow: hidden;
  560. padding: 5rpx 0rpx;
  561. }
  562. .brands {
  563. border-radius: 4rpx;
  564. padding: 0 5rpx;
  565. color: #F19D01;
  566. height: 28rpx;
  567. border: 1px solid #F19D01;
  568. font-size: 20rpx;
  569. line-height: 28rpx;
  570. margin: 5rpx 10rpx 5rpx 0rpx;
  571. }
  572. .timeBg {
  573. display: flex;
  574. }
  575. .shopTime {
  576. color: #666666;
  577. font-size: 22rpx;
  578. }
  579. .addressBox {
  580. color: #666666;
  581. font-size: 22rpx;
  582. }
  583. </style>