index.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901
  1. <template>
  2. <view class="content" @click="show_add = false">
  3. <u-navbar title=" " bgColor="#00B0B0" :autoBack="false" :placeholder="true" :fixed="true" height="44">
  4. <view class="search" slot="left">
  5. <u-search placeholder="" v-model="search" :disabled="true" :showAction="false" @click="tosearch"></u-search>
  6. </view>
  7. <view class="search-right hflex acenter" slot="right">
  8. <view class="img" @click="tomessage">
  9. <image src="@/static/images/message.png" mode="aspectFill"></image>
  10. <u-badge type="error" :offset="[0,0]" :absolute="true" :value="news_number"></u-badge>
  11. </view>
  12. <image src="@/static/images/add.png" mode="aspectFill" @click.stop="show_add = !show_add"></image>
  13. <view class="add-show" v-if="show_add">
  14. <view class="hflex acenter show-item" @click="toadd('zixun')">
  15. <image src="@/static/images/add-zixun.png" mode="aspectFill"></image>
  16. <text>发布资讯</text>
  17. </view>
  18. <view class="hflex acenter show-item" @click="toadd('wenzhang')">
  19. <image src="@/static/images/add-wenzhang.png" mode="aspectFill"></image>
  20. <text>发布文章</text>
  21. </view>
  22. <view class="hflex acenter show-item" @click="toadd('video')">
  23. <image src="@/static/images/add-shipin.png" mode="aspectFill"></image>
  24. <text>发布视频</text>
  25. </view>
  26. <view class="hflex acenter show-item" @click="toadd('luntan')">
  27. <image src="@/static/images/add-luntan.png" mode="aspectFill"></image>
  28. <text>发布论坛</text>
  29. </view>
  30. </view>
  31. </view>
  32. </u-navbar>
  33. <view class="tabs hflex acenter">
  34. <u-sticky bgColor="#fff" offset-top="88" customNavHeight="44" zIndex="99">
  35. <u-tabs :list="tabs" lineWidth="0" @click="tochangetabs" :scrollable="true" :current="current"
  36. :inactiveStyle="{color: '#666666',fontSize: '30rpx',}"
  37. :activeStyle="{color: '#00B0B0',fontWeight: 'bold',fontSize: '32rpx',}"></u-tabs>
  38. </u-sticky>
  39. </view>
  40. <swiper class="index-swiper" :circular="false" :autoplay="false" :current="current" @change="swipertotabs">
  41. <!-- 福利 -->
  42. <swiper-item>
  43. <view class="swiper-item">
  44. <view class="vip">
  45. <yxVip :user="user"></yxVip>
  46. </view>
  47. <view class="fuli" v-if="user.is_vip">
  48. <view class="title hflex acenter jbetween">
  49. <text>会员领福利</text>
  50. <view class="hflex acenter title-right">
  51. <text>全部</text>
  52. <image src="/static/images/arrow-right.png" mode="aspectFill"></image>
  53. </view>
  54. </view>
  55. <view class="fuli-box">
  56. <view class="box-title">当前等级<span style="font-size: 40rpx;color: #57C3C2;">{{user.level}}</span>级</view>
  57. <view class="box-list hflex acenter">
  58. <view class="list-item vflex acenter jcenter" v-for="(item,index) in vip_list" :key="index">
  59. <image :src="item.prize_image" mode="aspectFill"></image>
  60. <text :style="item.is_receive == 1 ? 'color: #CCCCCC;' : ''">达到{{item.days}}级</text>
  61. </view>
  62. </view>
  63. </view>
  64. </view>
  65. <view class="fuli">
  66. <view class="title hflex acenter jbetween">
  67. <text>签到领福利</text>
  68. <view class="hflex acenter title-right">
  69. <text>全部</text>
  70. <image src="/static/images/arrow-right.png" mode="aspectFill"></image>
  71. </view>
  72. </view>
  73. <view class="fuli-box">
  74. <view class="box-title">已连续签到<span style="font-size: 40rpx;color: #57C3C2;">20</span>天</view>
  75. <view class="box-list hflex acenter">
  76. <view class="list-item vflex acenter jcenter" v-for="(item,index) in qiandao_list" :key="index">
  77. <image :src="item.prize_image" mode="aspectFill"></image>
  78. <text :style="item.is_receive == 1 ? 'color: #CCCCCC;' : ''">连签{{item.days}}天</text>
  79. </view>
  80. </view>
  81. </view>
  82. </view>
  83. </view>
  84. </swiper-item>
  85. <!-- 关注 -->
  86. <swiper-item>
  87. <view class="swiper-item">
  88. <view class="list vflex acenter jcenter" v-if="list.length == 0">
  89. <view class="empty">没有任何内容</view>
  90. <view class="empty-text">需关注后才可显示内容</view>
  91. <u-button class="login-btn" @click="tologin" text="登录忆象" v-if="!login"></u-button>
  92. </view>
  93. <view class="list1" v-else>
  94. <list-info type="post" :data="item" v-for="(item,index) in list" :key="index" @toinfo="toinfo(item)"></list-info>
  95. </view>
  96. </view>
  97. </swiper-item>
  98. <!-- 最新 -->
  99. <swiper-item>
  100. <view class="swiper-item">
  101. <view class="top">
  102. <swiper-list type="index"></swiper-list>
  103. <view class="vflex" v-if="zixun_list.length>0">
  104. <view class="title">精选资讯</view>
  105. <view class="vflex">
  106. <wenzhang-info type="info" :data="item" v-for="(item,index) in zixun_list.slice(0,3)" :key="index" @toinfo="toinfo(item)"></wenzhang-info>
  107. <view class="more-btn" @click="tomore('info')">查看更多资讯</view>
  108. </view>
  109. </view>
  110. <view class="vflex" v-if="circle_list.length>0">
  111. <view class="hflex acenter jbetween">
  112. <view class="title">大家在聊</view>
  113. <view class="more-text" @click="tomore('topic')">查看更多</view>
  114. </view>
  115. <view class="vflex">
  116. <view class="circle-item hflex acenter" v-for="(item,index) in circle_list" :key="index">
  117. <!-- <image :src="item.img" mode="aspectFill" class="circle-img"></image> -->
  118. <text class="circle-text" @click="tohuati(item)">{{item.title}}</text>
  119. </view>
  120. </view>
  121. </view>
  122. <view class="vflex" v-if="wenzhang_list.length>0">
  123. <view class="hflex acenter jbetween">
  124. <view class="title">精选文章</view>
  125. <view class="more-text" @click="tomore('article')">查看更多</view>
  126. </view>
  127. <wenzhang-info type="article" :data="item" v-for="(item,index) in wenzhang_list.slice(0,3)" :key="index" @toinfo="toinfo(item)"></wenzhang-info>
  128. </view>
  129. <view class="vflex" v-if="video_list.length>0">
  130. <view class="hflex acenter jbetween">
  131. <view class="title">精选视频</view>
  132. <view class="more-text" @click="tomore('video')">查看更多</view>
  133. </view>
  134. <view class="videos hflex acenter" >
  135. <video-list :item="item" v-for="(item,index) in video_list" :key="index" @toinfo="toinfo(item)"></video-list>
  136. </view>
  137. </view>
  138. </view>
  139. <view class="list1">
  140. <list-info type="post" :data="item" v-for="(item,index) in list" :key="index" @toinfo="toinfo(item)"></list-info>
  141. </view>
  142. </view>
  143. </swiper-item>
  144. <!-- 资讯 -->
  145. <swiper-item>
  146. <view class="swiper-item">
  147. <view class="top">
  148. <swiper-list type="info"></swiper-list>
  149. </view>
  150. <view class="list" style="box-sizing: border-box;padding: 28rpx;">
  151. <view class="vflex" v-for="(item,index) in zixun_list" :key="index">
  152. <view class="title">{{item.date}}</view>
  153. <view class="vflex">
  154. <wenzhang-info type="info" :data="a" v-for="(a,b) in item.list" :key="index" @toinfo="toinfo(a)"></wenzhang-info>
  155. </view>
  156. </view>
  157. </view>
  158. </view>
  159. </swiper-item>
  160. <!-- 文章 -->
  161. <swiper-item>
  162. <view class="swiper-item">
  163. <view class="top" style="margin: 0;padding-bottom: 0;">
  164. <swiper-list type="article"></swiper-list>
  165. <view class="vflex" v-if="wenzhang_list.length>0">
  166. <view class="hflex acenter jbetween">
  167. <view class="title">精选文章</view>
  168. <view class="more-text" @click="tomore('article')">查看更多</view>
  169. </view>
  170. </view>
  171. </view>
  172. <list-info type="article" :data="item" v-for="(item,index) in wenzhang_list" :key="index" @toinfo="toinfo(item)"></list-info>
  173. <view class="vflex" v-if="list.length>0">
  174. <view class="list-title2">最新文章</view>
  175. </view>
  176. <list-info type="article" :data="item" v-for="(item,index) in list" :key="index" @toinfo="toinfo(item)"></list-info>
  177. </view>
  178. </swiper-item>
  179. <!-- 视频 -->
  180. <swiper-item>
  181. <view class="swiper-item">
  182. <view class="top">
  183. <swiper-list type="video"></swiper-list>
  184. <view class="vflex" v-if="video_list.length>0">
  185. <view class="hflex acenter jbetween">
  186. <view class="title">精选视频</view>
  187. <view class="more-text" @click="tomore('video')">查看更多</view>
  188. </view>
  189. <view class="videos hflex acenter" >
  190. <video-list :item="item" v-for="(item,index) in video_list" :key="index" @toinfo="toinfo(item)"></video-list>
  191. </view>
  192. </view>
  193. </view>
  194. <view class="list1">
  195. <view class="list-title">最新视频</view>
  196. <list-info type="video" :data="item" v-for="(item,index) in list" :key="index" @toinfo="toinfo(item)"></list-info>
  197. </view>
  198. </view>
  199. </swiper-item>
  200. </swiper>
  201. </view>
  202. </template>
  203. <script>
  204. import swiperList from '@/components/swiper-list/index.vue'
  205. import yxVip from '@/components/yx-vip/index.vue'
  206. import listInfo from '@/components/list-info/index.vue'
  207. import wenzhangInfo from '@/components/wenzhang-info/index.vue'
  208. import videoList from '@/components/video-list/index.vue'
  209. import $api from '@/static/js/api.js'
  210. export default {
  211. components: {
  212. swiperList,
  213. yxVip,
  214. listInfo,
  215. wenzhangInfo,
  216. videoList
  217. },
  218. data() {
  219. return {
  220. search: '',
  221. tabs: [
  222. {
  223. id: 0,
  224. name: '福利'
  225. },
  226. {
  227. id: 1,
  228. name: '关注',
  229. badge: {
  230. isDot: false
  231. }
  232. },
  233. {
  234. id: 2,
  235. name: '最新'
  236. },
  237. {
  238. id: 3,
  239. name: '资讯'
  240. },
  241. {
  242. id: 4,
  243. name: '文章'
  244. },
  245. {
  246. id: 5,
  247. name: '视频'
  248. },
  249. ],
  250. news_number: 1,//消息数量
  251. guanzhu_num: 1,//关注的数量
  252. current: 2,
  253. scrollable: false,
  254. list: [],
  255. login: false,
  256. show_add: false,
  257. zixun_list: [],
  258. circle_list: [],
  259. wenzhang_list: [],
  260. video_list: [],
  261. page: 1,
  262. limit: 10,
  263. last_page: 1,
  264. user: {},
  265. qiandao_list: [],
  266. vip_list: []
  267. }
  268. },
  269. onLoad() {
  270. },
  271. onShow() {
  272. this.login = uni.getStorageSync('token') ? true : false
  273. this.getuser()
  274. this.list = []
  275. this.zixun_list = []
  276. this.wenzhang_list = []
  277. this.circle_list = []
  278. this.video_list = []
  279. this.getlist()
  280. },
  281. onReachBottom() {
  282. if(this.last_page > this.page) {
  283. this.page++
  284. this.getlist()
  285. } else {
  286. uni.$u.toast('已经到底了');
  287. }
  288. },
  289. methods: {
  290. tohuati(item) {
  291. uni.navigateTo({
  292. url: '/pageA/topic-detail?id=' + item.id
  293. })
  294. },
  295. getuser() {
  296. var _this = this
  297. $api.req({
  298. url: 'user/info',
  299. methos: 'GET'
  300. }, function(res) {
  301. if(res.code == 10000) {
  302. _this.user = res.data
  303. }
  304. })
  305. },
  306. tomore(type) {
  307. if(type == 'topic') {
  308. uni.navigateTo({
  309. url: '/pageA/huati'
  310. })
  311. } else {
  312. uni.navigateTo({
  313. url: '/pageA/jingxuan-list?type=' + type
  314. })
  315. }
  316. },
  317. tomessage() {
  318. uni.navigateTo({
  319. url: '/pageA/message'
  320. })
  321. },
  322. /* 发布 */
  323. toadd(val) {
  324. if(val == 'luntan') {
  325. uni.navigateTo({
  326. url: '/pageA/add-luntan'
  327. })
  328. } else {
  329. uni.navigateTo({
  330. url: '/pageA/add-wenzhang?type=' + val
  331. })
  332. }
  333. this.show_add = false
  334. },
  335. /* 详情 */
  336. toinfo(item) {
  337. uni.navigateTo({
  338. url: '/pageA/info-detail?id=' + item.id
  339. })
  340. },
  341. /* 点击切换tabs */
  342. tochangetabs(item) {
  343. this.current = item.id
  344. },
  345. /* 滑动切换tabs */
  346. swipertotabs(e) {
  347. this.current = e.detail.current
  348. this.swipe_list = []
  349. this.getswiperlist()
  350. this.page = 1
  351. this.last_page = 1
  352. this.list = []
  353. this.zixun_list = []
  354. this.wenzhang_list = []
  355. this.circle_list = []
  356. this.video_list = []
  357. this.getlist()
  358. },
  359. /* 轮播图点击事件 */
  360. swiperclick(e) {
  361. var data = this.swiper_list[e]
  362. if(data.is_jump == 1) {
  363. if(data.jump_type == 'external') {
  364. window.location.href = data.jump_url
  365. } else {
  366. uni.navigateTo({
  367. url: data.jump_url
  368. })
  369. }
  370. }
  371. },
  372. getswiperlist() {
  373. if(this.current == 0 || this.current == 1) {
  374. return
  375. }
  376. var _this = this
  377. var type = ''
  378. if(_this.current == 2) {
  379. type = 'index'
  380. } else if(_this.current == 3) {
  381. type = 'info'
  382. }
  383. else if(_this.current == 4) {
  384. type = 'article'
  385. }
  386. else if(_this.current == 5) {
  387. type = 'video'
  388. }
  389. $api.req({
  390. url: 'banner',
  391. data: {
  392. type: type,
  393. limit: 5
  394. }
  395. }, function(res) {
  396. if(res.code == 10000) {
  397. _this.swiper_list = res.data
  398. }
  399. })
  400. },
  401. /* 获取列表 */
  402. getlist() {
  403. var _this = this
  404. if(_this.current == 0) {
  405. $api.req({
  406. url: "sign/prize",
  407. data: {
  408. page: 1,
  409. limit: 5
  410. },
  411. }, function(res) {
  412. _this.qiandao_list = res.data.list
  413. })
  414. /* $api.req({
  415. url: '',
  416. }) */
  417. }
  418. if(_this.current == 1) {
  419. $api.req({
  420. url: 'summary',
  421. method: 'GET',
  422. data: {
  423. page: _this.page,
  424. limit: _this.limit,
  425. is_page: 1,
  426. type: 'follow',
  427. order: 'published_at',
  428. order_type: 'desc'
  429. }
  430. }, function(res) {
  431. if(res.code == 10000) {
  432. _this.list = _this.list.concat(res.data.list)
  433. _this.last_page = res.data.last_page
  434. }
  435. })
  436. }
  437. if(_this.current == 2) {
  438. /* $api.req({
  439. url: 'info',
  440. method: 'GET',
  441. data: {
  442. page: 1,
  443. limit: 3,
  444. status: 'normal',
  445. is_boutique: 1
  446. }
  447. }, function(res) {
  448. if(res.code == 10000) {
  449. _this.zixun_list = res.data.list
  450. }
  451. })
  452. $api.req({
  453. url: 'article',
  454. method: 'GET',
  455. data: {
  456. page: 1,
  457. limit: 3,
  458. status: 'normal',
  459. is_boutique: 1,
  460. format_type: 'normal'
  461. }
  462. }, function(res) {
  463. if(res.code == 10000) {
  464. _this.wenzhang_list = res.data.list
  465. }
  466. })
  467. $api.req({
  468. url: 'video',
  469. method: 'GET',
  470. data: {
  471. page: 1,
  472. limit: 5,
  473. status: 'normal',
  474. is_boutique: 1
  475. }
  476. }, function(res) {
  477. if(res.code == 10000) {
  478. _this.video_list = res.data.list
  479. }
  480. })
  481. $api.req({
  482. url: 'topic',
  483. method: 'GET',
  484. data: {
  485. page: 1,
  486. limit: 3,
  487. is_recommend: 1
  488. }
  489. }, function(res) {
  490. if(res.code == 10000) {
  491. _this.circle_list = res.data.list
  492. }
  493. }) */
  494. $api.req({
  495. url: 'topic',
  496. method: 'GET',
  497. data: {
  498. page: 1,
  499. limit: 3,
  500. is_recommend: 1
  501. }
  502. }, function(res) {
  503. if(res.code == 10000) {
  504. _this.circle_list = res.data.list
  505. }
  506. })
  507. $api.req({
  508. url: 'summary',
  509. method: 'GET',
  510. data: {
  511. page: 1,
  512. limit: 3,
  513. type: 'group',
  514. is_boutique: 1
  515. }
  516. }, function(res) {
  517. if(res.code == 10000) {
  518. _this.zixun_list = res.data.info
  519. _this.wenzhang_list = res.data.article
  520. _this.video_list = res.data.video
  521. // _this.zixun_list = res.data.info
  522. }
  523. })
  524. $api.req({
  525. url: 'post',
  526. method: 'GET',
  527. data: {
  528. page: _this.page,
  529. limit: _this.limit,
  530. status: 'normal'
  531. }
  532. }, function(res) {
  533. if(res.code == 10000) {
  534. _this.list = _this.list.concat(res.data.list)
  535. _this.last_page = res.data.last_page
  536. }
  537. })
  538. }
  539. if(_this.current == 3) {
  540. $api.req({
  541. url: 'info',
  542. method: 'GET',
  543. data: {
  544. is_page: '1',
  545. page: _this.page,
  546. limit: _this.limit,
  547. status: 'normal',
  548. format_type: 'date',
  549. is_boutique: 0
  550. }
  551. }, function(res) {
  552. if(res.code == 10000) {
  553. _this.zixun_list = _this.zixun_list.concat(res.data)
  554. /* for(var i=0;i<_this.zixun_list.length;i++) {
  555. if(_this.zixun_list[i].date == _this.zixun_list[i+1].date) {
  556. for(var j=0;j<_this.zixun_list[i+1].list.length;j++) {
  557. _this.zixun_list[i].list.push(_this.zixun_list[i+1].list[j])
  558. }
  559. }
  560. } */
  561. }
  562. })
  563. }
  564. if(_this.current == 4) {
  565. $api.req({
  566. url: 'article',
  567. method: 'GET',
  568. data: {
  569. is_page: '1',
  570. page: 1,
  571. limit: 3,
  572. status: 'normal',
  573. is_boutique: 1
  574. }
  575. }, function(res) {
  576. if(res.code == 10000) {
  577. _this.wenzhang_list = _this.wenzhang_list.concat(res.data.list)
  578. }
  579. })
  580. $api.req({
  581. url: 'article',
  582. method: 'GET',
  583. data: {
  584. is_page: '1',
  585. page: _this.page,
  586. limit: _this.limit,
  587. status: 'normal'
  588. }
  589. }, function(res) {
  590. if(res.code == 10000) {
  591. _this.list = _this.list.concat(res.data.list)
  592. _this.last_page = res.data.last_page
  593. }
  594. })
  595. }
  596. if(_this.current == 5) {
  597. $api.req({
  598. url: 'video',
  599. method: 'GET',
  600. data: {
  601. page: 1,
  602. limit: 5,
  603. status: 'normal',
  604. is_boutique: 1
  605. }
  606. }, function(res) {
  607. if(res.code == 10000) {
  608. _this.video_list = _this.video_list.concat(res.data.list)
  609. }
  610. })
  611. $api.req({
  612. url: 'video',
  613. method: 'GET',
  614. data: {
  615. page: _this.page,
  616. limit: _this.limit,
  617. status: 'normal'
  618. }
  619. }, function(res) {
  620. if(res.code == 10000) {
  621. _this.list = _this.list.concat(res.data.list)
  622. _this.last_page = res.data.last_page
  623. }
  624. })
  625. }
  626. },
  627. /* 去登录 */
  628. tologin() {
  629. uni.navigateTo({
  630. url: '/pages/login/index'
  631. })
  632. },
  633. /* 点击左侧区域 */
  634. leftClick() {
  635. return
  636. },
  637. /* 首页搜索 */
  638. tosearch() {
  639. uni.navigateTo({
  640. url: '/pageA/search'
  641. })
  642. },
  643. }
  644. }
  645. </script>
  646. <style lang="scss">
  647. .content::v-deep {
  648. .list-title2 {
  649. font-size: 32rpx;
  650. font-family: PingFangSC, PingFang SC;
  651. font-weight: 500;
  652. color: #333333;
  653. padding: 28rpx;
  654. width: 100%;
  655. box-sizing: border-box;
  656. background: #FFFFFF;
  657. }
  658. .index-swiper {
  659. padding: 144rpx 0 0;
  660. min-height: calc(100vh - 88rpx);
  661. height: 1rpx;
  662. .swiper-item {
  663. height: 100%;
  664. overflow: auto;
  665. .vip {
  666. background: #FFFFFF;
  667. padding: 28rpx 24rpx 44rpx;
  668. }
  669. .fuli {
  670. padding: 24rpx 28rpx ;
  671. .fuli-box {
  672. margin: 24rpx 0 32rpx;
  673. background: #FFFFFF;
  674. border-radius: 16rpx;
  675. padding: 16rpx 28rpx;
  676. .box-list {
  677. padding: 20rpx 0 0;
  678. .list-item {
  679. margin: 0 32rpx 0 0;
  680. image {
  681. width: 100rpx;
  682. height: 100rpx;
  683. }
  684. text {
  685. padding: 22rpx 0 0;
  686. font-size: 24rpx;
  687. font-family: PingFangSC, PingFang SC;
  688. font-weight: 400;
  689. color: #444444;
  690. }
  691. }
  692. .list-item:last-child {
  693. margin: 0;
  694. }
  695. }
  696. .box-title {
  697. font-size: 28rpx;
  698. font-family: PingFangSC, PingFang SC;
  699. font-weight: 600;
  700. color: #333333;
  701. }
  702. }
  703. .title {
  704. text {
  705. font-size: 32rpx;
  706. font-family: PingFangSC, PingFang SC;
  707. font-weight: 600;
  708. color: #222222;
  709. }
  710. .title-right {
  711. text {
  712. font-size: 24rpx;
  713. font-family: PingFangSC, PingFang SC;
  714. font-weight: 400;
  715. }
  716. image {
  717. width: 28rpx;
  718. height: 28rpx;
  719. }
  720. }
  721. }
  722. }
  723. }
  724. }
  725. .top {
  726. padding: 20rpx 28rpx 24rpx;
  727. margin-bottom: 20rpx;
  728. background: #fff;
  729. .videos {
  730. width: 100%;
  731. overflow: auto;
  732. // white-space: nowrap;
  733. }
  734. .title {
  735. font-size: 32rpx;
  736. font-family: PingFangSC, PingFang SC;
  737. font-weight: 500;
  738. color: #333333;
  739. padding: 24rpx 0;
  740. }
  741. .more-btn {
  742. width: 100%;
  743. font-size: 26rpx;
  744. font-family: PingFangSC, PingFang SC;
  745. font-weight: 400;
  746. color: #666666;
  747. background: #F5F5F5;
  748. border-radius: 12rpx;
  749. padding: 22rpx 0;
  750. text-align: center;
  751. }
  752. .more-text {
  753. font-size: 24rpx;
  754. font-family: PingFangSC, PingFang SC;
  755. font-weight: 400;
  756. color: #666666;
  757. }
  758. .circle-item {
  759. // width: 100%;
  760. background: #F1F4F4;
  761. border-radius: 12rpx;
  762. padding: 26rpx 0 26rpx 36rpx;
  763. margin: 0 0 20rpx;
  764. .circle-img {
  765. width: 40rpx;
  766. height: 40rpx;
  767. }
  768. .circle-text {
  769. font-size: 28rpx;
  770. font-family: AppleColorEmoji;
  771. color: #666666;
  772. }
  773. }
  774. }
  775. .search {
  776. width: 572rpx;
  777. background: rgba(255,255,255,.3);
  778. border-radius: 32rpx;
  779. .u-search__content {
  780. background: rgba(255,255,255,.3)!important;
  781. }
  782. .u-search__content__input {
  783. background-color: unset !important;
  784. }
  785. .u-search__content__icon {
  786. background-color: unset !important;
  787. .u-icon__icon {
  788. color: #fff !important;
  789. }
  790. }
  791. input {
  792. background: rgba(255,255,255,.3)
  793. }
  794. }
  795. .search-right {
  796. // padding: 0 32rpx 0 0;
  797. .img {
  798. position: relative;
  799. }
  800. image {
  801. width: 40rpx;
  802. height: 40rpx;
  803. margin-left: 20rpx;
  804. }
  805. .add-show {
  806. position: absolute;
  807. right: 30rpx;
  808. top: 88rpx;
  809. background: #FFFFFF;
  810. box-shadow: 0rpx 4rpx 20rpx 0rpx rgba(0,0,0,0.1);
  811. padding: 42rpx 32rpx 0;
  812. .show-item {
  813. margin-bottom: 40rpx;
  814. image {
  815. width: 36rpx;
  816. height: 36rpx;
  817. margin: 0;
  818. }
  819. text {
  820. white-space: nowrap;
  821. font-size: 26rpx;
  822. font-family: PingFangSC, PingFang SC;
  823. font-weight: 400;
  824. color: #333333;
  825. padding: 0 0 0 24rpx;
  826. }
  827. }
  828. }
  829. }
  830. .tabs {
  831. position: fixed;
  832. top: 144rpx;
  833. width: 100%;
  834. padding: 28rpx;
  835. background: #fff;
  836. z-index: 9;
  837. border-bottom: 1px solid #eee;
  838. .u-tabs__wrapper__nav__item {
  839. padding: 0 66rpx 0 0 !important;
  840. }
  841. }
  842. .list {
  843. background: #fff;
  844. min-height: 90vh;
  845. .title {
  846. font-size: 32rpx;
  847. font-family: SFPro, SFPro;
  848. font-weight: 500;
  849. color: #333333;
  850. padding-bottom: 20rpx;
  851. }
  852. .empty {
  853. font-size: 40rpx;
  854. font-family: PingFangSC, PingFang SC;
  855. font-weight: 500;
  856. color: #999999;
  857. }
  858. .empty-text {
  859. font-size: 24rpx;
  860. font-family: PingFangSC, PingFang SC;
  861. font-weight: 400;
  862. color: #999999;
  863. padding: 24rpx 0 40rpx;
  864. }
  865. .login-btn {
  866. width: 198rpx;
  867. height: 76rpx;
  868. background: #00B0B0;
  869. border-radius: 38rpx;
  870. font-size: 28rpx;
  871. font-family: PingFangSC, PingFang SC;
  872. font-weight: 500;
  873. color: #FFFFFF;
  874. }
  875. }
  876. .list1 {
  877. .list-title {
  878. width: 100%;
  879. background: #fff;
  880. font-size: 32rpx;
  881. font-family: PingFangSC, PingFang SC;
  882. font-weight: 500;
  883. color: #333333;
  884. padding: 32rpx 0 20rpx 28rpx;
  885. }
  886. }
  887. }
  888. </style>