my-luntan.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644
  1. <template>
  2. <view class="my-luntan">
  3. <image :src="userinfo.forum_use.image" class="my-luntan-bg" mode="aspectFill" @click="uploadimg"></image>
  4. <!-- <u-navbar :background="{background:'rgba(0,0,0,0)'}" :isFixed="false" :border-bottom="false"></u-navbar> -->
  5. <u-navbar leftIconColor="#fff" :fixed="false" bgColor='rgba(0,0,0,0)' placeholder :safeAreaInsetTop="true"
  6. @leftClick="return1"></u-navbar>
  7. <view @click="uploadimg" class="" style="height: 88rpx;"></view>
  8. <view class="my-luntan-header">
  9. <view class="u-flex u-col-bottom u-row-between" style="position: relative;top: -24rpx;">
  10. <image :src="userinfo.userinfo.avatar" class="header-img" mode=""></image>
  11. <view class="header-right u-flex u-flex-1 u-row-right">
  12. <view class="u-flex-col u-col-center right-item">
  13. <text>{{userinfo.host_follow_count || 0}}</text>
  14. <text>{{user_id == userinfo.id ? '我的关注' : 'Ta的关注'}}</text>
  15. </view>
  16. <view class="u-flex-col u-col-center right-item">
  17. <text>{{userinfo.quilt_follow_count || 0}}</text>
  18. <text>{{user_id == userinfo.id ? '关注我的' : '关注Ta的'}}</text>
  19. </view>
  20. </view>
  21. </view>
  22. <view class="user-zhiye u-flex u-row-between">
  23. <view class="u-flex-col">
  24. <text class="text1">{{userinfo.userinfo.name || ''}}</text>
  25. <text class="text2">{{userinfo.userinfo.job || ''}}</text>
  26. </view>
  27. <text class="text3" v-if="user_id == userinfo.id" @click="touser">编辑资料</text>
  28. </view>
  29. </view>
  30. <u-gap height="20" bg-color="#F6F6F6"></u-gap>
  31. <view class="luntan-list">
  32. <view class="list-header u-flex">
  33. <text :class="{text:current == 1}" @click="changecurrent(1)">动态·{{total}}</text>
  34. <text :class="{text:current == 2}" @click="changecurrent(2)">圈子</text>
  35. </view>
  36. <view v-if="current == 1">
  37. <view v-for="(item,index) in list" :key="index" @click="toinfo(item)">
  38. <view class="luntan-item">
  39. <view class="luntan-user u-flex u-row-between">
  40. <image class="user-head" :src="userinfo.userinfo.avatar" mode=""></image>
  41. <view class="user-center u-flex-1 u-flex-col">
  42. <text>{{userinfo.userinfo.name}}</text>
  43. <text>{{userinfo.userinfo.job}}</text>
  44. </view>
  45. <view @click.stop="open(item)" v-if="user_id == userinfo.id">
  46. <u-icon name="more-dot-fill" size="18"></u-icon>
  47. </view>
  48. </view>
  49. <zhao-text :text="item.content"></zhao-text>
  50. <view v-if="item.images" class="luntan-img u-flex u-flex-wrap u-row-between">
  51. <image :src="a" v-for="(a,b) in item.images.split(',')" :key="b"
  52. @click.stop="openimg(item.images.split(','),b)" mode="aspectFill"></image>
  53. <view style="width: 210rpx;"></view>
  54. </view>
  55. <view class="item-down u-flex u-row-between">
  56. <view class="u-flex u-row-center down-item" @click.stop="dianzan(item)">
  57. <image v-if="item.is_like" src="../static/images/dianzan3.png" mode=""></image>
  58. <image v-else src="../static/images/dianzan.png" mode=""></image>
  59. <text class="text1"
  60. :style="{color:item.is_like?'#0C66C2':'#777'}">{{item.like_count}}</text>
  61. </view>
  62. <view class="u-flex u-row-center down-item">
  63. <image src="../static/images/pinglun.png" mode=""></image>
  64. <text class="text1">{{item.comment_count}}</text>
  65. </view>
  66. <view class="u-flex u-row-center down-item">
  67. <image src="../static/images/liulan.png" mode=""></image>
  68. <text class="text1">{{item.read || 0}}</text>
  69. </view>
  70. </view>
  71. </view>
  72. <u-gap height="20" bg-color="#F6F6F6"></u-gap>
  73. </view>
  74. </view>
  75. <view v-if="current == 2" style="padding: 0 32rpx;">
  76. <view class="quanzi-type u-flex">
  77. <text :class="{text:type == 1}"
  78. @click="changetype(1)">{{user_id == userinfo.id ? '我的' : 'Ta的'}}关注</text>
  79. <text :class="{text:type == 2}"
  80. @click="changetype(2)">{{user_id == userinfo.id ? '我的' : 'Ta的'}}创建</text>
  81. </view>
  82. <view v-if="type == 1">
  83. <view class="quanzi-item u-flex u-row-between" v-for="(item,index) in list1" :key="index"
  84. @click="toquanzi({id:item.group.id})">
  85. <image :src="item.group.image" class="item-img" mode="aspectFill"></image>
  86. <view class="quanzi-center u-flex-1 u-flex-col">
  87. <view class="u-flex">
  88. <text class="text1">{{item.group.title}}</text>
  89. </view>
  90. <text class="text2">{{item.article_count}}条内容|{{item.group.follow_count||0}}人关注</text>
  91. </view>
  92. <u-icon name="arrow-right" color="rgba(76, 76, 76, 0.4)"></u-icon>
  93. </view>
  94. </view>
  95. <view v-else>
  96. <view class="quanzi-item u-flex u-row-between" v-for="(item,index) in list1" :key="index"
  97. @click="toquanzi({id:item.id})">
  98. <image :src="item.image" class="item-img" mode="aspectFill"></image>
  99. <view class="quanzi-center u-flex-1 u-flex-col">
  100. <view class="u-flex">
  101. <text class="text1">{{item.title}}</text>
  102. <!-- <image class="img" v-if="user_id == userinfo.id" src="static/quanzi-edit.png" mode=""></image> -->
  103. </view>
  104. <text class="text2">{{item.article_count||0}}条内容|{{item.follow_count||0}}人关注</text>
  105. </view>
  106. <view @click.stop="del(item)" class="" v-if="user_id == userinfo.id">
  107. <u-icon name="more-dot-fill" color="rgba(76, 76, 76, 0.4)"></u-icon>
  108. </view>
  109. <u-icon v-else name="arrow-right" color="rgba(76, 76, 76, 0.4)"></u-icon>
  110. </view>
  111. </view>
  112. </view>
  113. </view>
  114. <u-popup :show="del_show" mode="bottom" :round="28" :safe-area-inset-bottom="true">
  115. <view class="del" @click="del1">删除</view>
  116. <view class="cancel" @click="close">取消</view>
  117. </u-popup>
  118. </view>
  119. </template>
  120. <script>
  121. import {
  122. articlelike,
  123. homepagearticle,
  124. followgrouplist,
  125. usergrouplist,
  126. others_homepage,
  127. del_article,
  128. del_group,
  129. edit_image
  130. } from "@/units/inquire.js"
  131. export default {
  132. data() {
  133. return {
  134. id: '',
  135. current: 1,
  136. type: 1,
  137. userinfo: {
  138. userinfo: {
  139. company_name: {}
  140. }
  141. },
  142. page: 1,
  143. list: [],
  144. total: 0,
  145. user_id: '',
  146. page1: 1,
  147. list1: [],
  148. total1: 0,
  149. isshow: false,
  150. del_show: false,
  151. del_id: '',
  152. }
  153. },
  154. onLoad(option) {
  155. this.id = option.id
  156. this.user_id = uni.getStorageSync("user_id")
  157. },
  158. onShow() {
  159. this.getuser()
  160. if (this.isshow) {
  161. this.isshow = false
  162. } else {
  163. if (this.current == 1) {
  164. this.page = 1
  165. this.list = []
  166. } else {
  167. this.page1 = 1
  168. this.list1 = []
  169. }
  170. this.getlist()
  171. }
  172. },
  173. onReachBottom() {
  174. if (this.current == 1) {
  175. if (this.total != this.list.length) {
  176. this.page++
  177. this.getlist()
  178. }
  179. } else {
  180. if (this.total1 != this.list1.length) {
  181. this.page1++
  182. this.getlist()
  183. }
  184. }
  185. },
  186. methods: {
  187. uploadimg() {
  188. console.log(111111111);
  189. console.log('kkk');
  190. uni.chooseImage({
  191. count: 1,
  192. success: (img) => {
  193. uni.showLoading({
  194. mask: true,
  195. title: "请稍后"
  196. })
  197. uni.uploadFile({
  198. url: 'https://hire.hdlkeji.com/api/common/upload',
  199. filePath: img.tempFilePaths[0],
  200. name: 'file',
  201. success: (res) => {
  202. uni.hideLoading()
  203. if (JSON.parse(res.data).code == 1) {
  204. this.userinfo.forum_use.image = JSON.parse(res.data).data
  205. .fullurl
  206. edit_image({
  207. image: this.userinfo.forum_use.image
  208. }).then(res => {
  209. this.$u.toast(res.msg)
  210. })
  211. } else {
  212. this.$u.toast(JSON.parse(res.data).msg)
  213. }
  214. },
  215. fail: (e) => {
  216. console.log(e);
  217. }
  218. })
  219. }
  220. })
  221. },
  222. close() {
  223. this.del_show = false
  224. },
  225. del(item) {
  226. this.del_show = true
  227. this.del_id = item.id
  228. },
  229. del1() {
  230. let _this = this
  231. uni.showModal({
  232. title: "确定删除吗",
  233. content: "内容删除后将无法恢复,请谨慎考虑",
  234. cancelText: '我再想想',
  235. confirmText: '确定删除',
  236. confirmColor: '#0C66C2',
  237. success: (e) => {
  238. if (e.confirm) {
  239. del_group({
  240. id: _this.del_id
  241. }).then((res) => {
  242. _this.$u.toast(res.msg)
  243. _this.del_show = false
  244. _this.del_item = {}
  245. _this.page1 = 1
  246. _this.list1 = []
  247. _this.getlist()
  248. })
  249. } else {
  250. _this.close
  251. }
  252. }
  253. })
  254. },
  255. return1() {
  256. uni.navigateBack()
  257. },
  258. toquanzi(item) {
  259. uni.navigateTo({
  260. url: "/pagesC/quanzi-info?id=" + item.id
  261. })
  262. },
  263. openimg(urls, index) {
  264. this.isshow = true
  265. this.$openimage(urls, index)
  266. },
  267. changetype(type) {
  268. this.type = type
  269. this.page1 = 1
  270. this.list1 = []
  271. this.getlist()
  272. },
  273. changecurrent(current) {
  274. this.current = current
  275. if (this.current == 1) {
  276. this.page = 1
  277. this.list = []
  278. } else {
  279. this.page1 = 1
  280. this.list1 = []
  281. }
  282. this.getlist()
  283. },
  284. dianzan(item) {
  285. uni.showLoading({
  286. mask: true,
  287. title: "请稍后"
  288. })
  289. articlelike({
  290. id: item.id
  291. }).then(res => {
  292. if (res.code == 1) {
  293. item.is_like = item.is_like ? null : {}
  294. if (item.is_like) {
  295. item.like_count++
  296. } else {
  297. item.like_count--
  298. }
  299. } else {
  300. this.$u.toast(res.msg)
  301. }
  302. })
  303. },
  304. touser() {
  305. uni.navigateTo({
  306. url: "../pagesD/personal-infor"
  307. })
  308. },
  309. getlist() {
  310. if (this.current == 1) {
  311. homepagearticle({
  312. id: this.id,
  313. page: this.page
  314. }).then(res => {
  315. this.total = res.data.total
  316. this.list = this.list.concat(res.data.data)
  317. })
  318. } else {
  319. if (this.type == 1) {
  320. followgrouplist({
  321. page: this.page1,
  322. id: this.id
  323. }).then(res => {
  324. this.total1 = res.data.total
  325. this.list1 = this.list1.concat(res.data.data)
  326. })
  327. } else {
  328. usergrouplist({
  329. page: this.page1,
  330. id: this.id
  331. }).then(res => {
  332. this.total1 = res.data.total
  333. this.list1 = this.list1.concat(res.data.data)
  334. })
  335. }
  336. }
  337. },
  338. getuser() {
  339. others_homepage({
  340. id: this.id,
  341. page: this.page,
  342. page_num: 20
  343. }).then(res => {
  344. this.userinfo = res.data
  345. })
  346. },
  347. open(item) {
  348. uni.showActionSheet({
  349. itemList: ['删除'],
  350. success: (e) => {
  351. if (e.tapIndex == 0) {
  352. del_article({
  353. id: item.id
  354. }).then(res => {
  355. this.$u.toast(res.msg)
  356. if (res.code == 1) {
  357. setTimeout(() => {
  358. this.page = 1
  359. this.list = []
  360. this.getlist()
  361. }, 800)
  362. }
  363. })
  364. }
  365. }
  366. })
  367. },
  368. toinfo(item) {
  369. uni.navigateTo({
  370. url: "/pagesC/luntan-info?id=" + item.id
  371. })
  372. },
  373. }
  374. }
  375. </script>
  376. <style lang="scss">
  377. .del {
  378. font-size: 32rpx;
  379. font-family: PingFangSC, PingFang SC;
  380. font-weight: 500;
  381. color: #333333;
  382. padding: 46rpx 0 30rpx;
  383. text-align: center;
  384. width: 100%;
  385. border-bottom: 16rpx solid #f6f6f6;
  386. }
  387. .cancel {
  388. font-size: 32rpx;
  389. font-family: PingFangSC, PingFang SC;
  390. font-weight: 400;
  391. color: #333333;
  392. text-align: center;
  393. width: 100%;
  394. padding: 40rpx 0;
  395. }
  396. .my-luntan {
  397. position: relative;
  398. .luntan-list {
  399. .quanzi-item {
  400. padding: 32rpx 0;
  401. border-bottom: 2rpx solid #F4F4F4;
  402. .item-img {
  403. width: 84rpx;
  404. height: 84rpx;
  405. border-radius: 10rpx;
  406. }
  407. .quanzi-center {
  408. margin: 0 20rpx;
  409. .text1 {
  410. font-size: 32rpx;
  411. font-family: PingFangSC-Medium, PingFang SC;
  412. font-weight: 500;
  413. color: #222222;
  414. }
  415. .img {
  416. width: 24rpx;
  417. height: 24rpx;
  418. margin-left: 12rpx;
  419. }
  420. .text2 {
  421. margin-top: 8rpx;
  422. font-size: 22rpx;
  423. font-family: PingFangSC-Regular, PingFang SC;
  424. font-weight: 400;
  425. color: #777777;
  426. }
  427. }
  428. }
  429. .quanzi-type {
  430. padding: 30rpx 0 8rpx 0;
  431. text {
  432. width: 156rpx;
  433. line-height: 64rpx;
  434. background: #F0F0F0;
  435. border-radius: 32rpx;
  436. text-align: center;
  437. margin-right: 44rpx;
  438. font-size: 28rpx;
  439. font-family: PingFangSC-Regular, PingFang SC;
  440. font-weight: 400;
  441. color: #444444;
  442. }
  443. .text {
  444. background-color: #0C66C2;
  445. color: #fff;
  446. }
  447. }
  448. .luntan-item {
  449. background: #FFFFFF;
  450. border-radius: 20rpx;
  451. padding: 0 32rpx;
  452. .item-down {
  453. height: 84rpx;
  454. .down-item {
  455. width: 214rpx;
  456. image {
  457. width: 33rpx;
  458. height: 33rpx;
  459. }
  460. .text1 {
  461. font-size: 26rpx;
  462. font-family: ArialMT;
  463. color: #777777;
  464. margin-left: 12rpx;
  465. }
  466. }
  467. }
  468. .luntan-img {
  469. margin-top: 20rpx;
  470. width: 100%;
  471. image {
  472. width: 210rpx;
  473. height: 210rpx;
  474. border-radius: 10rpx;
  475. // margin-right: 10rpx;
  476. margin-bottom: 10rpx;
  477. }
  478. }
  479. .luntan-img::after {
  480. width: 210rpx;
  481. }
  482. .luntan-user {
  483. height: 130rpx;
  484. .guanzhu-btn {
  485. width: 112rpx;
  486. line-height: 48rpx;
  487. border-radius: 24rpx;
  488. border: 1rpx solid #0C66C2;
  489. text-align: center;
  490. font-size: 26rpx;
  491. font-family: PingFangSC-Regular, PingFang SC;
  492. font-weight: 400;
  493. color: #0C66C2;
  494. }
  495. .user-center {
  496. margin: 0 16rpx;
  497. min-width: 1rpx;
  498. text:first-child {
  499. font-size: 28rpx;
  500. font-family: PingFangSC-Medium, PingFang SC;
  501. font-weight: 500;
  502. color: #222222;
  503. margin-bottom: 4rpx;
  504. }
  505. text:last-child {
  506. font-size: 20rpx;
  507. font-family: PingFangSC-Regular, PingFang SC;
  508. font-weight: 400;
  509. color: #818389;
  510. }
  511. }
  512. .user-head {
  513. width: 72rpx;
  514. height: 72rpx;
  515. border-radius: 100rpx;
  516. }
  517. }
  518. }
  519. .list-header {
  520. padding: 0 32rpx;
  521. height: 108rpx;
  522. border-bottom: 2rpx solid #F4F4F4;
  523. text {
  524. font-size: 32rpx;
  525. font-family: PingFangSC-Semibold, PingFang SC;
  526. font-weight: 600;
  527. color: #666666;
  528. margin-right: 88rpx;
  529. }
  530. .text {
  531. color: #222222;
  532. }
  533. }
  534. }
  535. .my-luntan-header {
  536. padding: 0 32rpx;
  537. width: 750rpx;
  538. height: 288rpx;
  539. background: #FFFFFF;
  540. border-radius: 32rpx 32rpx 0rpx 0rpx;
  541. // margin-top: 88rpx;
  542. box-sizing: border-box;
  543. .user-zhiye {
  544. .text3 {
  545. width: 172rpx;
  546. line-height: 56rpx;
  547. border-radius: 32rpx;
  548. border: 1rpx solid #0C66C2;
  549. text-align: center;
  550. font-size: 26rpx;
  551. font-family: PingFangSC-Regular, PingFang SC;
  552. font-weight: 400;
  553. color: #0C66C2;
  554. }
  555. .text1 {
  556. font-size: 44rpx;
  557. font-family: PingFangSC-Medium, PingFang SC;
  558. font-weight: 500;
  559. color: #222222;
  560. margin-bottom: 12rpx;
  561. }
  562. .text2 {
  563. font-size: 26rpx;
  564. font-family: PingFangSC-Regular, PingFang SC;
  565. font-weight: 400;
  566. color: #666666;
  567. }
  568. }
  569. .header-right {
  570. .right-item {
  571. margin-left: 84rpx;
  572. text:first-child {
  573. font-size: 40rpx;
  574. font-family: DINAlternate-Bold, DINAlternate;
  575. font-weight: bold;
  576. color: #333333;
  577. margin-bottom: 8rpx;
  578. }
  579. text:last-child {
  580. font-size: 24rpx;
  581. font-family: PingFangSC-Regular, PingFang SC;
  582. font-weight: 400;
  583. color: #666666;
  584. }
  585. }
  586. }
  587. .header-img {
  588. width: 136rpx;
  589. height: 136rpx;
  590. border-radius: 100%;
  591. border: 4rpx solid #FFFFFF;
  592. }
  593. }
  594. .my-luntan-bg {
  595. position: absolute;
  596. top: 0;
  597. left: 0;
  598. width: 750rpx;
  599. height: 396rpx;
  600. z-index: -1;
  601. }
  602. }
  603. </style>