sandTable.vue 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841
  1. <template>
  2. <page-meta :page-style="'padding-bottom: 0;'+'overflow:'+((showFilter||show||showPoster)?'hidden':'visible')"/>
  3. <view style="background-color: #F6F6F6;">
  4. <!-- 没有权限 -->
  5. <block v-if="noAuthor ==1 && isFinished">
  6. <view class="sandTable-noAuthor">
  7. <block v-if="!applyer.hasApply">
  8. <image :src="globalImgUrls.sandBoxNoAuthor" mode="aspectFit"></image>
  9. <text style="margin-top: 48rpx;">您暂无权限查看沙盘推演</text>
  10. <text style="margin-top: 20rpx;">若想查看可以申请开通</text>
  11. <button @click="toApply">立即申请</button>
  12. </block>
  13. <block v-else>
  14. <image class="img-wait" :src="globalImgUrls.chartWait" mode="widthFix"
  15. style="width: 186rpx;margin-top: 200rpx;width: 186rpx;margin-bottom: 50rpx;"></image>
  16. <text style="margin-bottom:15px">您已提交申请</text>
  17. <text>请等待销售人员与您联系</text>
  18. </block>
  19. </view>
  20. </block>
  21. <block v-if="noAuthor ==2 && isFinished">
  22. <view class="sandTable-noAuthor">
  23. <image :src="globalImgUrls.sandBoxNoAuthor" mode="aspectFit"></image>
  24. <text style="margin-top: 48rpx;">您暂无权限查看沙盘推演</text>
  25. <text style="margin: 20rpx 0 6rpx 0;">若想查看请联系对口销售</text>
  26. <view>
  27. <text>{{salesData.name}}:</text><text class="sales-mobile" @click="callToSales">{{salesData.phone}}</text>
  28. </view>
  29. </view>
  30. </block>
  31. <!-- 部分有权限 分享进来没有权限 -->
  32. <block v-if="noAuthor ==4 && isFinished">
  33. <!-- 显示空白 一秒钟后跳转至有权限的沙盘图-->
  34. </block>
  35. <!-- 有权限 -->
  36. <view v-show="noAuthor ==0 && isFinished" style="padding-top: 156rpx;">
  37. <view style="position: fixed;top: 0;width: 100vw;z-index: 2;">
  38. <view style="height: 2rpx;background-color: #F6F6F6;"></view>
  39. <view class="search-wrap">
  40. <van-search
  41. shape="round"
  42. placeholder="沙盘图名称搜索"
  43. clear-trigger="always"
  44. style="flex-grow: 1"
  45. :value="sandTableQuery.keyword"
  46. @change="searchValChange"
  47. @search="onSearch"
  48. @clear="onClearSearch"
  49. placeholderStyle="color: #999999;"
  50. />
  51. <view class="filtration-icon-zone" @click="showFilter=true">
  52. <image
  53. src="../static/sandTable/sandTable_filtration.png"
  54. mode="widthFix"
  55. class="menu-icon"/>
  56. <text>筛选</text>
  57. </view>
  58. </view>
  59. </view>
  60. <!-- 无数据 -->
  61. <view class="sandTable-noData" v-if="!list">
  62. <image :src="globalImgUrls.sandBoxNoAuthor" mode="aspectFit"></image>
  63. <text >暂无数据</text>
  64. </view>
  65. <view class="sandTable-list" v-else>
  66. <view class="sandTable-box" v-for="(item,index) in list" :key="item.sandbox_id">
  67. <view class="sandTable-box-top">
  68. <view class="sandTable-box-topL">
  69. <view class="sandTable-tag">
  70. {{item.chart_permission_name}}
  71. </view>
  72. <rich-text :nodes="item.name" class="sandTable-name"></rich-text>
  73. </view>
  74. <view class="sandTable-box-topR">
  75. <image src="../static/sandTable/fullScreen.png" style="margin-right: 32rpx;" @click="previewImage(index)"></image>
  76. <image src="@/static/sandTable/sandBox-share-icon.png" style="margin-right: 32rpx;" @click="generatePoster('detail',item)"></image>
  77. <button
  78. class="share-btn"
  79. open-type="share"
  80. :data-item="item">
  81. <image src="../static/sandTable/sandTable-share.png" mode="aspectFill"/>
  82. </button>
  83. </view>
  84. </view>
  85. <view class="sandTable-item" @click="previewImage(index)">
  86. <image :src="item.pic_url" mode="aspectFit"></image>
  87. <!-- <view class="sandTable-item-origin">
  88. 来源:弘则研究
  89. </view> -->
  90. </view>
  91. </view>
  92. <view v-if="list.length==total && list.length>0" class="bottom_text">已经到底了</view>
  93. </view>
  94. </view>
  95. </view>
  96. <!-- 筛选弹窗 -->
  97. <van-popup :show="showFilter" round position="bottom" @close="showFilter = false" z-index="99999" :safe-area-inset-bottom="true" >
  98. <view class="filter-container">
  99. <view class="filter-container-header">
  100. <text>全部筛选</text>
  101. <text style="color: #E3B377;" @click="showFilter=false">取消</text>
  102. </view>
  103. <view class="list-box">
  104. <van-collapse accordion @change="selectFisrtClassify" :value="selectedFirstId" :border="false">
  105. <van-collapse-item
  106. :title="item.classify_name"
  107. :name='item.id'
  108. :border="false"
  109. v-for="item in classfyList"
  110. :key="item.id"
  111. >
  112. <van-row gutter="5">
  113. <van-col
  114. :span="_item.chart_permission_name.length>7?16:8"
  115. v-for="_item in item.list"
  116. :key="_item.chart_permission_id"
  117. >
  118. <text
  119. :class="['list-item',_item.chart_permission_id==selectedSecondId&&'list-item-active']"
  120. @click="handleSelectPerItem(_item)"
  121. >{{_item.chart_permission_name}}</text>
  122. </van-col>
  123. </van-row>
  124. </van-collapse-item>
  125. </van-collapse>
  126. </view>
  127. </view>
  128. </van-popup>
  129. <!-- 分享按钮 -->
  130. <image @click="generatePoster('list')" class="share-icon" src="@/static/share-poster-icon.png" mode="aspectFill" v-if="noAuthor==0&&isFinished"/>
  131. <!-- 生成海报弹窗 -->
  132. <div class="share-poster-wrap" @touchmove.prevent>
  133. <div class="poster-mask" v-if="show||showPoster" @click="showPoster=false" @touchmove.prevent></div>
  134. <div class="loading-box" v-if="show">
  135. <img class="load-img" src="../static/loading.png"/>
  136. <div>海报生成中...</div>
  137. </div>
  138. <img v-if="showPoster" class="poster-img" mode="widthFix" :src="posterImg" show-menu-by-longpress />
  139. </div>
  140. </template>
  141. <script>
  142. import {apiSandTableList,apiSandTableDetail} from "../api/sandTable.js"
  143. import {apiReportIndexPageAuthList} from "../api/report.js"
  144. import {apiGetPoster,apiGetSceneToParams} from "../api/common.js"
  145. import {apiApplyPermission} from "../api/user.js"
  146. export default {
  147. data() {
  148. return {
  149. sandTableQuery:{
  150. page_size: 20,
  151. curr_page: 1,
  152. keyword:'' ,
  153. chart_permission_id: 0,
  154. is_high_light:false // 是否高亮
  155. },
  156. total:0,
  157. isRequseting:false,
  158. showFilter:false,
  159. list:[],
  160. classfyList:[],
  161. selectedFirstId:0,
  162. selectedSecondId:0,
  163. // 是否显示过全部加载弹窗
  164. haveShowToast:false,
  165. showPoster:false,
  166. show:false,
  167. // 是否跳转到申请结果页面
  168. haveGoToResult:false,
  169. // 是否请求完成
  170. isFinished:false,
  171. posterImg:'',
  172. // 没有权限 1:立即申请 2:联系销售
  173. noAuthor:0,
  174. // 销售信息
  175. salesData:{
  176. phone:'',
  177. name:''
  178. },
  179. // 申请权限时的用户信息
  180. applyer:{
  181. name:'',
  182. company:'',
  183. // 是否已经申请
  184. hasApply:false,
  185. // 状态
  186. status:''
  187. }
  188. }
  189. },
  190. onLoad(options) {
  191. this.init(options)
  192. },
  193. onShow() {
  194. // 预览图片结束时,会触发onShow,切回竖屏
  195. uni.setPageOrientation({orientation : "portrait"})
  196. if(this.haveGoToResult){
  197. //从申请结果页面回来
  198. this.getSandBoxList()
  199. this.haveGoToResult=false
  200. }
  201. },
  202. // 小程序自带分享
  203. onShareAppMessage({from,target}) {
  204. if(from == 'menu'){
  205. // 列表分享
  206. let {keyword,chart_permission_id,is_high_light} = this.sandTableQuery
  207. return {
  208. title:'沙盘推演',
  209. path:`/pages-sandTable/sandTable?keyword=${keyword}&chart_permission_id=${chart_permission_id}`+
  210. `&is_high_light=${is_high_light}&firstClassifyId=${this.selectedFirstId}`
  211. }
  212. }else if(from == 'button'){
  213. // 单个分享
  214. let {sandbox_id,chart_permission_id,chart_permission_name,name,pic_url} = target.dataset.item
  215. let first_permission_id = 0
  216. // 通过分享的沙盘图的二级分类Id,找到对应的一级Id
  217. U:for (let item of this.classfyList) {
  218. for (let it of item.list) {
  219. if(it.chart_permission_id == chart_permission_id){
  220. first_permission_id = item.id
  221. break U
  222. }
  223. }
  224. }
  225. return {
  226. title:`${chart_permission_name}: ${name}`,
  227. path:`/pages-sandTable/sandTable?sandbox_id=${sandbox_id}&chart_permission_id=${chart_permission_id}`+
  228. `&firstClassifyId=${first_permission_id}`,
  229. imageUrl:pic_url
  230. }
  231. }
  232. },
  233. onPullDownRefresh() {
  234. this.sandTableQuery.curr_page=1
  235. this.sandTableQuery.chart_permission_id = this.selectedSecondId = this.selectedFirstId=0
  236. this.sandTableQuery.keyword=''
  237. this.is_high_light=false
  238. this.haveShowToast=false
  239. this.getSandBoxList('stopPullDown')
  240. this.getClassifyList()
  241. },
  242. onReachBottom() {
  243. if(this.isRequseting) return
  244. if(this.list.length>=this.total && this.total!=0){
  245. // if(this.haveShowToast) return
  246. // // 只显示一次
  247. // this.haveShowToast = true
  248. // uni.showToast({
  249. // title:"没有了~",
  250. // icon:'none'
  251. // })
  252. return
  253. }
  254. this.sandTableQuery.curr_page++
  255. this.getSandBoxList()
  256. },
  257. methods: {
  258. async init(options){
  259. let obj={}
  260. if(options.scene){
  261. // 海报分享
  262. let res = await apiGetSceneToParams({scene_key:options.scene})
  263. if(res.code==200){
  264. obj=JSON.parse(res.data)
  265. }
  266. }else{
  267. obj = options
  268. }
  269. // 有sandbox_id 说明是单个分享进来的
  270. if(obj.sandbox_id){
  271. this.selectedFirstId = obj.firstClassifyId || 0
  272. this.selectedSecondId = obj.chart_permission_id || 0
  273. this.getSandBoxDetail(obj.sandbox_id)
  274. }else{
  275. this.sandTableQuery.keyword = obj.keyword || ""
  276. this.selectedFirstId = obj.firstClassifyId || 0
  277. this.sandTableQuery.chart_permission_id = this.selectedSecondId = obj.chart_permission_id || 0
  278. this.sandTableQuery.is_high_light = obj.is_high_light || false
  279. this.getSandBoxList()
  280. }
  281. this.getClassifyList()
  282. },
  283. // 获取沙盘图数据
  284. getSandBoxList(option){
  285. this.isRequseting=true
  286. apiSandTableList(this.sandTableQuery).then(({data:{list,paging,type,name,mobile,customer_info,jump},code})=>{
  287. if(option == 'stopPullDown'){
  288. uni.stopPullDownRefresh()
  289. }
  290. // 403 没有权限
  291. if(code==403){
  292. this.applyer.name = customer_info.name
  293. this.applyer.company = customer_info.company_name
  294. this.applyer.hasApply = customer_info.has_apply
  295. this.applyer.status = customer_info.status
  296. if(type == 'apply'){
  297. // 申请
  298. this.noAuthor =1
  299. }else{
  300. if(jump){
  301. this.noAuthor =4
  302. // jump 跳转,说明该用户是有部分权限,提示“暂无此权限”,跳转至有权限的分类
  303. uni.showToast({
  304. title:"暂无此权限",
  305. icon:'none'
  306. })
  307. setTimeout(()=>{
  308. uni.redirectTo({url:'/pages-sandTable/sandTable'})
  309. },1000)
  310. }else{
  311. // 联系销售
  312. this.noAuthor =2
  313. this.salesData.name=name
  314. this.salesData.phone=mobile
  315. }
  316. }
  317. return
  318. }
  319. if(this.sandTableQuery.curr_page==1){
  320. this.list = list
  321. this.total = paging.totals
  322. }else{
  323. this.list = [...this.list,...list]
  324. }
  325. this.noAuthor=0
  326. })
  327. .finally(res=>{
  328. this.isRequseting=false
  329. this.isFinished=true
  330. this.showFilter=false
  331. })
  332. },
  333. getSandBoxDetail(sandbox_id){
  334. this.isRequseting=true
  335. apiSandTableDetail({sandbox_id}).then(({data,code})=>{
  336. if(code==403){
  337. this.applyer.name = data.customer_info.name
  338. this.applyer.company = data.customer_info.company_name
  339. this.applyer.hasApply = data.customer_info.has_apply
  340. this.applyer.status = data.customer_info.status
  341. if(data.type == 'apply'){
  342. // 申请
  343. this.noAuthor =1
  344. }else{
  345. if(data.jump){
  346. // jump 跳转,说明该用户是有部分权限,提示“暂无此权限”,跳转至有权限的分类
  347. this.noAuthor =4
  348. uni.showToast({
  349. title:"暂无此权限",
  350. icon:'none'
  351. })
  352. setTimeout(()=>{
  353. uni.redirectTo({url:'/pages-sandTable/sandTable'})
  354. },1000)
  355. }else{
  356. // 联系销售
  357. this.noAuthor =2
  358. this.salesData.name=data.name
  359. this.salesData.phone=data.mobile
  360. }
  361. }
  362. return
  363. }
  364. this.list= [data]
  365. this.noAuthor=0
  366. })
  367. .finally(res=>{
  368. this.isRequseting=false
  369. this.isFinished=true
  370. this.showFilter=false
  371. })
  372. },
  373. // 获取分类数据
  374. getClassifyList(){
  375. apiReportIndexPageAuthList().then(({data:{permission_list}})=>{
  376. // 过滤掉'更多报告' 和 没有权限的分类
  377. this.classfyList = permission_list.filter(item => item.sort!=100000)
  378. this.classfyList.forEach(item=>{
  379. item.list=item.list.filter(it=>it.auth_ok)
  380. })
  381. this.classfyList=this.classfyList.filter(item=>item.list.length!=0)
  382. })
  383. },
  384. // 权限申请
  385. async toApply(type=''){
  386. await this.checkUserIsBind()
  387. if(type=='auto'){
  388. apiApplyPermission({
  389. company_name:this.applyer.company,
  390. real_name:this.applyer.name,
  391. source:7,
  392. from_page:'沙盘推演',
  393. }).then(res=>{
  394. console.log('自动申请成功');
  395. })
  396. }else{
  397. if(this.applyer.status==='流失'){
  398. apiApplyPermission({
  399. company_name:this.applyer.company,
  400. real_name:this.applyer.name,
  401. source:7,
  402. from_page:'沙盘推演',
  403. }).then(res=>{
  404. this.haveGoToResult=true
  405. uni.navigateTo({url:'/pages-applyPermission/applyResult'})
  406. })
  407. }else{
  408. uni.navigateTo({ url: '/pages-applyPermission/applyPermission?source=7&from_page=沙盘推演' })
  409. }
  410. }
  411. },
  412. // 联系销售申请权限
  413. callToSales(){
  414. if(!this.applyer.hasApply){
  415. this.toApply('auto')
  416. }
  417. uni.makePhoneCall({
  418. phoneNumber: this.salesData.phone,
  419. success: (result) => {},
  420. fail: (error) => {}
  421. })
  422. },
  423. // 搜索内容变化
  424. searchValChange(e){
  425. this.sandTableQuery.keyword=e.detail
  426. // this.sandTableQuery.is_high_light = true
  427. // this.getSandBoxList()
  428. },
  429. // 清除搜索内容
  430. onClearSearch(){
  431. this.sandTableQuery={
  432. page_size: 20,
  433. curr_page: 1,
  434. keyword:'' ,
  435. chart_permission_id: 0,
  436. is_high_light:false
  437. }
  438. this.selectedFirstId = this.selectedSecondId = 0
  439. this.haveShowToast=false
  440. this.getSandBoxList()
  441. },
  442. // 确认搜索
  443. onSearch(){
  444. this.sandTableQuery.chart_permission_id= this.selectedFirstId = this.selectedSecondId = 0
  445. this.sandTableQuery.is_high_light = true
  446. this.haveShowToast=false
  447. this.getSandBoxList()
  448. },
  449. // 选中一级分类
  450. selectFisrtClassify(e){
  451. this.selectedFirstId = e.detail
  452. },
  453. handleSelectPerItem(item){
  454. if(this.selectedSecondId==item.chart_permission_id){
  455. this.sandTableQuery.chart_permission_id=this.selectedSecondId=0
  456. }else{
  457. this.sandTableQuery.chart_permission_id=this.selectedSecondId=item.chart_permission_id
  458. }
  459. this.sandTableQuery.curr_page=1
  460. uni.pageScrollTo({
  461. scrollTop:0,
  462. duration:300
  463. })
  464. this.showFilter=false
  465. this.getSandBoxList()
  466. },
  467. // 预览图片
  468. previewImage(index){
  469. // 先切换横屏才预览图片 ,预览图片开启之后 切换不了横屏
  470. uni.setPageOrientation({orientation : "landscape"}).finally(()=>{
  471. // 在回调函数中 用setTimeout将预览图片的任务 再往后排 不然可能会切换失败
  472. setTimeout(()=>{
  473. uni.previewImage({
  474. urls:this.list.map(item=> item.pic_url),
  475. current:index,
  476. showmenu:false
  477. })
  478. },10)
  479. })
  480. },
  481. // 生成海报
  482. generatePoster(type,item=''){
  483. this.handleCreatePoster(type,item)
  484. },
  485. async handleCreatePoster(type,item){
  486. this.show=true
  487. let code_scene_json = {},source='',parsJson={},code_scene=''
  488. if(type == 'detail'){
  489. // 分享单个
  490. let {chart_permission_id} = item
  491. let first_permission_id = 0
  492. // 通过分享的沙盘图的二级分类Id,找到对应的一级Id
  493. U:for (let item of this.classfyList) {
  494. for (let it of item.list) {
  495. if(it.chart_permission_id == chart_permission_id){
  496. first_permission_id = item.id
  497. break U
  498. }
  499. }
  500. }
  501. code_scene_json={
  502. sandbox_id:item.sandbox_id,
  503. chart_permission_id,
  504. firstClassifyId:first_permission_id
  505. }
  506. code_scene=JSON.stringify(code_scene_json)
  507. source = 'sandbox_detail'
  508. parsJson = {title_1:item.name,img_1:item.pic_url}
  509. }else{
  510. // 分享列表
  511. let {keyword,chart_permission_id,is_high_light} = this.sandTableQuery
  512. let firstImageUrl,secondImageUrl;
  513. if(!this.list || !this.list[0]){
  514. // 分享的列表页一条数据也没有 使用两个默认的沙盘图地址
  515. firstImageUrl = this.globalImgUrls.sandBoxShareDefault1
  516. secondImageUrl = this.globalImgUrls.sandBoxShareDefault2
  517. }else if(!this.list[1]){
  518. // 分享的列表页只有一条数据 第二个图片使用默认的沙盘图地址
  519. firstImageUrl = this.list[0].pic_url
  520. secondImageUrl = this.globalImgUrls.sandBoxShareDefault1
  521. }else{
  522. // 列表页有数据
  523. firstImageUrl = this.list[0].pic_url
  524. secondImageUrl = this.list[1].pic_url
  525. }
  526. code_scene_json={
  527. keyword,
  528. chart_permission_id,
  529. is_high_light,
  530. firstClassifyId:this.selectedFirstId
  531. }
  532. code_scene=JSON.stringify(code_scene_json)
  533. source = 'sandbox_list'
  534. parsJson = {title_1:'沙盘推演',img_1:firstImageUrl,img_2:secondImageUrl}
  535. }
  536. const res=await apiGetPoster({
  537. code_page:'pages-sandTable/sandTable',
  538. code_scene,
  539. source,
  540. pars:JSON.stringify(parsJson),
  541. version:'7.0'
  542. })
  543. if(res.code==200){
  544. this.posterImg=res.data
  545. this.show=false
  546. this.showPoster=true
  547. }else{
  548. this.show=false
  549. }
  550. }
  551. }
  552. }
  553. </script>
  554. <style lang="scss" scoped>
  555. page{
  556. padding-bottom: 0;
  557. // 无权限
  558. .sandTable-noAuthor{
  559. display: flex;
  560. flex-direction: column;
  561. align-items: center;
  562. height: 100vh;
  563. image{
  564. margin-top: 180rpx;
  565. }
  566. text{
  567. font-family: 'PingFang SC';
  568. font-style: normal;
  569. font-weight: 400;
  570. font-size: 28rpx;
  571. color: #999999;
  572. }
  573. .sales-mobile{
  574. color: #E3B377;
  575. }
  576. button{
  577. background: #E6B77D;
  578. border-radius: 4px;
  579. width: 634rpx;
  580. height: 80rpx;
  581. margin-top: 108rpx;
  582. font-family: 'PingFang SC';
  583. font-style: normal;
  584. font-weight: 500;
  585. font-size: 32rpx;
  586. color: #FFFFFF;
  587. }
  588. }
  589. // 搜索区域
  590. .search-wrap{
  591. display: flex;
  592. background-color: white;
  593. padding: 20rpx 34rpx 20rpx 10rpx;
  594. height: 156rpx;
  595. align-items: center;
  596. .filtration-icon-zone{
  597. display: flex;
  598. align-items: center;
  599. image{
  600. width: 52rpx;
  601. height: 52rpx;
  602. }
  603. text{
  604. font-family: 'PingFang SC';
  605. font-style: normal;
  606. font-weight: 400;
  607. font-size: 32rpx;
  608. color: #E3B377;
  609. }
  610. }
  611. }
  612. // 列表区域 无数据
  613. .sandTable-noData{
  614. display: flex;
  615. flex-direction: column;
  616. align-items: center;
  617. height: calc(100vh - 158rpx);
  618. image{
  619. margin-top: 180rpx;
  620. }
  621. text{
  622. margin-top: 48rpx;
  623. font-family: 'PingFang SC';
  624. font-style: normal;
  625. font-weight: 400;
  626. font-size: 28rpx;
  627. color: #999999;
  628. }
  629. }
  630. // 列表区域
  631. .sandTable-box{
  632. padding: 24rpx 34rpx 40rpx 34rpx;
  633. background-color: white;
  634. margin-top: 10rpx;
  635. .sandTable-box-top{
  636. display: flex;
  637. justify-content: space-between;
  638. align-items: center;
  639. margin-bottom: 32rpx;
  640. .sandTable-box-topL{
  641. display: flex;
  642. align-items: center;
  643. .sandTable-tag{
  644. margin-right: 20rpx;
  645. padding: 4rpx 22rpx;
  646. background: #333333;
  647. border-radius: 8rpx 8rpx 8rpx 8rpx;
  648. font-size: 24rpx;
  649. font-family: PingFang SC-Medium, PingFang SC;
  650. font-weight: 500;
  651. color: #E4B478;
  652. display: flex;
  653. align-items: center;
  654. justify-content: center;
  655. }
  656. .sandTable-name{
  657. font-size: 32rpx;
  658. font-family: PingFang SC-Medium, PingFang SC;
  659. font-weight: 500;
  660. color: #333333;
  661. max-width: 390rpx;
  662. }
  663. }
  664. .sandTable-box-topR{
  665. display: flex;
  666. align-items: center;
  667. .share-btn{
  668. padding: 0;
  669. height: unset;
  670. line-height: unset;
  671. font-size: 0;
  672. border-radius: unset;
  673. &::after{
  674. border: none;
  675. }
  676. }
  677. image{
  678. width: 32rpx;
  679. height: 32rpx;
  680. }
  681. }
  682. }
  683. .sandTable-item{
  684. border: 2rpx solid #C4C4C4;
  685. image{
  686. width: 100%;
  687. height: 480rpx;
  688. }
  689. .sandTable-item-origin{
  690. text-align: right;
  691. padding:0 24rpx 20rpx 0 ;
  692. font-size: 20rpx;
  693. font-family: PingFang SC-Regular, PingFang SC;
  694. font-weight: 400;
  695. color: #666666;
  696. }
  697. }
  698. }
  699. .bottom_text{
  700. display: flex;
  701. justify-content: center;
  702. height: 60rpx;
  703. color: gray;
  704. font-size: 32rpx;
  705. }
  706. // 过滤弹窗
  707. .filter-container{
  708. height: 700rpx;
  709. width: 100vw;
  710. position: relative;
  711. .filter-container-header{
  712. padding: 54rpx 34rpx 20rpx 34rpx;
  713. display: flex;
  714. align-items: center;
  715. justify-content: space-between;
  716. text{
  717. font-size: 32rpx;
  718. font-family: PingFang SC-Medium, PingFang SC;
  719. font-weight: 500;
  720. color: #000000;
  721. }
  722. }
  723. .list-box{
  724. min-height: 30vh;
  725. max-height: 60vh;
  726. .list-item{
  727. display: block;
  728. margin: 10rpx;
  729. height: 76rpx;
  730. line-height: 76rpx;
  731. color: #000;
  732. background: #F6F6F6;
  733. border-radius: 4px 4px 4px 4px;
  734. text-align: center;
  735. }
  736. .list-item-active{
  737. background-color: #FAEEDE;
  738. }
  739. }
  740. button{
  741. position: absolute;
  742. bottom: 0;
  743. height: 80rpx;
  744. width: 100vw;
  745. border-radius: 0;
  746. background-color: #E6B77D;
  747. font-size: 32rpx;
  748. font-family: PingFang SC-Medium, PingFang SC;
  749. font-weight: 500;
  750. color: #FFFFFF;
  751. }
  752. }
  753. // 分享海报
  754. .share-poster-wrap{
  755. .poster-mask{
  756. position: fixed;
  757. left: 0;
  758. top: 0;
  759. right: 0;
  760. bottom: 0;
  761. background: rgba(0, 0, 0, 0.4);
  762. z-index: 998;
  763. }
  764. .loading-box{
  765. background-color: #fff;
  766. position: fixed;
  767. left: 50%;
  768. top: 50%;
  769. z-index: 999;
  770. transform: translate(-50%,-50%);
  771. width: 417rpx;
  772. height: 261rpx;
  773. text-align: center;
  774. padding-top: 80rpx;
  775. font-size: 32rpx;
  776. font-weight: bold;
  777. .load-img{
  778. width: 91rpx;
  779. height: 91rpx;
  780. animation: circle 1s linear infinite;
  781. }
  782. @keyframes circle {
  783. 0%{
  784. transform: rotateZ(0);
  785. }
  786. 100%{
  787. transform: rotateZ(360deg);
  788. }
  789. }
  790. }
  791. .poster-img{
  792. width: 90vw;
  793. display: block;
  794. position: fixed;
  795. left: 50%;
  796. top: 50%;
  797. z-index: 999;
  798. transform: translate(-50%,-50%);
  799. border-radius: 16rpx;
  800. }
  801. }
  802. // 分享图标
  803. .share-icon{
  804. position: fixed;
  805. bottom: 100rpx;
  806. right: 34rpx;
  807. z-index: 50;
  808. width: 76rpx;
  809. height: 76rpx;
  810. }
  811. }
  812. </style>
  813. <style scoped>
  814. /deep/ .van-search__content{background-color:#F6F6F6;
  815. border: 2px solid #E5E5E5;box-sizing: border-box;}
  816. </style>
  817. <style lang='scss'>
  818. .filter-container{
  819. .list-box{
  820. .van-cell__title, .van-cell__value{
  821. flex: none !important;
  822. }
  823. .van-cell:after{
  824. border: none !important;
  825. }
  826. .van-cell__title{
  827. font-size: 14px;
  828. }
  829. .van-hairline--top:after{
  830. border-top-width: 0 !important;
  831. }
  832. }
  833. }
  834. </style>