activityDetail.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592
  1. <template>
  2. <!-- 教研室详情 -->
  3. <view class="activeDetail">
  4. <statusBar :item="navbar"></statusBar>
  5. <!-- 顶部 -->
  6. <view class="backPic">
  7. <image src="https://teacherapi.cocorobo.cn/teaching-file/static//yym/Rectangle 40.png" mode="aspectFill">
  8. </image>
  9. <view class="card">
  10. <view class="cardTop">
  11. <view class="title three-font">{{ actItemList.acName }}</view>
  12. <view class="icons">
  13. <view class="icon" @click="coll">
  14. <image :src="collArr.includes(actItemList.acId) ? pic_coll2 : pic_coll "
  15. style="width: 42rpx;height: 42rpx;" mode="aspectFill"></image>
  16. </view>
  17. <view class="icon" @click="sub">
  18. <image
  19. :src="subArr.includes(actItemList.acId) ? pic_sub2 : pic_sub "
  20. style="width: 38rpx;height: 42rpx;" mode="aspectFill"></image>
  21. </view>
  22. </view>
  23. </view>
  24. <view class="col fz-font">
  25. 活动日期:<text class="col2"> {{ actItemList.begin_at}}</text>
  26. </view>
  27. <view class="col fz-font">
  28. 招募人数:<text class="col2"> {{actItemList.bnum}}/{{ actItemList.pers}}</text>
  29. </view>
  30. <view class="col fz-font tag">
  31. <view class=" tag">活动地址:</view>
  32. <text class="col2">{{actItemList.address}}</text>
  33. </view>
  34. </view>
  35. </view>
  36. <!-- 创建者用户名 -->
  37. <view style="padding:30rpx;padding-top: 30rpx;">
  38. <view class="creator">
  39. <image
  40. :src="actItemList.avatar"
  41. mode="aspectFill"></image>
  42. <view class="creName btn-font">
  43. {{ actItemList.username }}
  44. </view>
  45. </view>
  46. </view>
  47. <!-- 教研室详情 -->
  48. <view class="" style="padding: 0 30rpx;">
  49. <!-- <detailBlock :actItemList='actItemList' :item="judge"></detailBlock> -->
  50. <view class="detailBlock">
  51. <view class="tit fwb-font">活动详情</view>
  52. <view class="cont sZw-font">
  53. 活动时间:<text>{{ actItemList.begin_at }}</text>
  54. </view>
  55. <view class="cont sZw-font">
  56. 活动形式:<text style="color: #0056a8;">{{ actItemList.acshape }}</text>
  57. </view>
  58. <view class="cont sZw-font">
  59. <!-- <view id="myElement" class="activeTit">
  60. 教研室概况:查看更多查看更多查看更多看更多查看更多查看更多查看更多查看更多查看更多查看更多查看更多看更多查看更多查看更多查看更多查看更多
  61. </view>
  62. <text class="zdwz" style="color: #0056a8;float: right;" @click="zdwz">收起</text> -->
  63. <view class="content">
  64. <view ref="p" :class="getClassNames">
  65. <text style="color: #999999;">教研室概况:</text>
  66. {{actItemList.brief}}
  67. </view>
  68. <view ref="btnnn" :class="getClassNames1" @click="qqq">
  69. <!-- {{isAll ? '收起' : '展开'}} -->
  70. </view>
  71. </view>
  72. </view>
  73. </view>
  74. </view>
  75. <!-- 当前成员 -->
  76. <!-- {{!applyUserlist.length}} -->
  77. <view style="padding: 0 30rpx;" v-if="applyUserlist.length">
  78. <view class="member">
  79. <view class="memberTop">
  80. <view class="btn-font">当前成员</view>
  81. <view class="fz-font" style="color: rgba(0, 0, 0, 0.4);display: flex;align-items: center;"
  82. @click="gotoMorePer">
  83. <text>查看更多</text>
  84. <image src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png"
  85. style="width: 32rpx;height: 32rpx;" mode="aspectFill"></image>
  86. </view>
  87. </view>
  88. <view class="pers" >
  89. <view class="per" v-for="(i,index) in applyUserlist" :key="index">
  90. <image :src="i.avatar" mode=""></image>
  91. <view class="perName fz-font">
  92. {{i.username}}
  93. </view>
  94. </view>
  95. </view>
  96. </view>
  97. </view>
  98. <!-- 申请加入 -->
  99. <view class="btnBlock">
  100. <button class="btn btn1 zw-font" v-if="actItemList.openid==oid">本人创建,暂不支持加入</button>
  101. <button class="btn zw-font" v-if="!isSign && actItemList.openid!=oid" @click="applyAdd">申请加入</button>
  102. <button class="btn btn1 zw-font" v-if="isSign && actItemList.openid!=oid">已加入</button>
  103. </view>
  104. </view>
  105. </template>
  106. <script>
  107. export default {
  108. data() {
  109. return {
  110. navbar: {
  111. title: '活动详情',
  112. btn: 1
  113. },
  114. // 是否已加入
  115. isSign:0,
  116. // 用户openid
  117. oid:'',
  118. // 活动id
  119. acId:'',
  120. // 页面数据
  121. actItemList: {},
  122. // 用户收藏列表
  123. collArr:[],
  124. // 用户订阅列表
  125. subArr:[],
  126. // 报名列表
  127. applyUserlist:[],
  128. pic_coll: 'https://teacherapi.cocorobo.cn/teaching-file/static/yym/Star 1 (Stroke).png',
  129. pic_coll2: 'https://teacherapi.cocorobo.cn/teaching-file/static//mine/Collect_yellow.png',
  130. pic_sub: 'https://teacherapi.cocorobo.cn/teaching-file/static/yym/Vector (Stroke).png',
  131. pic_sub2: '../../static/mine/dingyue_blue.png'
  132. // pic_coll:'https://teacherapi.cocorobo.cn/teaching-file/static//yym/Star 1 (Stroke) (2).png',
  133. // pic_coll2:'https://teacherapi.cocorobo.cn/teaching-file/static//mine/Collect_yellow.png',
  134. // pic_sub:'https://teacherapi.cocorobo.cn/teaching-file/static/yym/Vector (Stroke) (1).png',
  135. // pic_sub2:'https://teacherapi.cocorobo.cn/teaching-file/static/dingyue_blue.png',
  136. };
  137. },
  138. methods: {
  139. // 获取页面数据
  140. getdata(){
  141. let data = {
  142. oid:this.$store.state.user.openid,
  143. acId: this.acId,
  144. }
  145. this.$request('/selectActivityID', "POST", data).then(res => {
  146. console.log('获取页面数据',res[0][0]);
  147. this.actItemList = res[0][0]
  148. })
  149. },
  150. addview(){
  151. let data={
  152. oid:this.$store.state.user.openid,
  153. acId: this.acId,
  154. }
  155. this.$request('/updateView', "POST", data).then(res => {
  156. console.log(res[0][0]);
  157. this.actItemList = res[0][0]
  158. })
  159. },
  160. // 收藏事件
  161. coll(){
  162. //判断是否收藏
  163. let iscoll = null
  164. // 查询是否收藏过
  165. let data = {
  166. acid: this.acId,
  167. oid: this.$store.state.user.openid, //用户id
  168. ty: 0
  169. }
  170. this.$request('/selectOneOperator', 'POST', data).then(res => {
  171. // console.log('查询是否收藏过',res);
  172. res[0].length ? iscoll = true : iscoll = false;
  173. // iscoll为true表示已经收藏过,执行删除 为true则收藏
  174. if (iscoll) {
  175. console.log('执行删除');
  176. this.$request('/deleteOperator', 'POST', data).then(res => {
  177. // console.log(res);
  178. this.getColl()
  179. })
  180. } else {
  181. console.log('执行添加');
  182. this.$request('/insertOperator', 'POST', data).then(res => {
  183. // console.log(res);
  184. this.getColl()
  185. })
  186. }
  187. })
  188. },
  189. // 订阅事件
  190. sub(){
  191. //判断是否订阅
  192. let iscoll = null
  193. // 查询是否订阅过
  194. let data = {
  195. acid: this.acId,
  196. oid: this.$store.state.user.openid, //用户id
  197. ty: 1
  198. }
  199. this.$request('/selectOneOperator', 'POST', data).then(res => {
  200. // console.log('查询是否订阅过',res);
  201. res[0].length ? iscoll = true : iscoll = false;
  202. // iscoll为true表示已经订阅过,执行删除 为true则订阅
  203. if (iscoll) {
  204. console.log('执行删除');
  205. this.$request('/deleteOperator', 'POST', data).then(res => {
  206. console.log(res);
  207. this.getSub()
  208. })
  209. } else {
  210. console.log('执行添加');
  211. this.$request('/insertOperator', 'POST', data).then(res => {
  212. console.log(res);
  213. this.getSub()
  214. // 添加消息页面订阅通知提示订阅成功
  215. this.addMessage()
  216. })
  217. }
  218. })
  219. },
  220. // 添加消息页面订阅通知提示订阅成功
  221. addMessage() {
  222. let data = {
  223. oid: this.$store.state.user.openid,
  224. acid: this.acId,
  225. type: 2,
  226. con: ``
  227. }
  228. this.$request('/insertMessage', "POST", data).then(res => {
  229. console.log(res);
  230. })
  231. },
  232. // 申请加入
  233. applyAdd() {
  234. uni.navigateTo({
  235. url: `/pages/jys/jys?acId=${this.acId}&tit=${'活动报名'}`
  236. })
  237. },
  238. // 查看更多报名同学
  239. gotoMorePer() {
  240. uni.navigateTo({
  241. url: `/pages/dy/dy?acId=${this.acId}`
  242. })
  243. },
  244. // 获取是否订阅
  245. getSub(){
  246. let data = {
  247. oid: this.$store.state.user.openid, //用户id
  248. type: 1
  249. }
  250. this.$request('/selectOperator', 'POST', data).then(res => {
  251. // console.log('获取', res);
  252. // 每次调用前清零,防止push叠加错误
  253. this.subArr = []
  254. // 将acid遍历到subArrsubArr中
  255. res[0].forEach(i => {
  256. this.subArr.push(i.acId)
  257. })
  258. })
  259. },
  260. //获取是否收藏
  261. getColl() {
  262. let data = {
  263. oid: this.$store.state.user.openid, //用户id
  264. type: 0
  265. }
  266. this.$request('/selectOperator', 'POST', data).then(res => {
  267. // console.log('获取收藏', res);
  268. // 每次调用前清零,防止push叠加错误
  269. this.collArr = []
  270. // 将acid遍历到collArr中
  271. res[0].forEach(i => {
  272. this.collArr.push(i.acId)
  273. })
  274. })
  275. },
  276. //判断是否报名
  277. btnEnroll() {
  278. let data = {
  279. oid: this.$store.state.user.openid, //用户id
  280. aid:this.acId,
  281. type: 2
  282. }
  283. this.$request('/selectSignup', 'POST', data).then(res => {
  284. // console.log('获取报名', res[0][0]);
  285. this.isSign=res[0][0].num
  286. })
  287. },
  288. // 获取报名用户
  289. getUsers(){
  290. let data = {
  291. oid: this.$store.state.user.openid, //用户id
  292. aid:this.acId,
  293. type: 2,
  294. page: 1, //下拉获取更多的备用字段
  295. lim: 6 //一次获取多少数据
  296. }
  297. this.$request('/selectApplyUser', 'POST', data).then(res => {
  298. console.log('获取报名用户列表', res[0]);
  299. this.applyUserlist=res[0]
  300. })
  301. }
  302. },
  303. onLoad(e) {
  304. console.log('接收参数',e);
  305. this.acId=e.acId
  306. this.oid=this.$store.state.user.openid
  307. // this.getActivity()
  308. // 获取是否已经报名
  309. this.btnEnroll()
  310. // 获取页面数据
  311. this.getdata()
  312. // 是否收藏
  313. this.getColl()
  314. // 是否订阅
  315. this.getSub()
  316. // 获取报名人名单
  317. this.getUsers()
  318. }
  319. }
  320. </script>
  321. <style lang="scss">
  322. .activeDetail {
  323. padding-bottom: 80px;
  324. .backPic {
  325. width: 750rpx;
  326. position: relative;
  327. margin-bottom: 30rpx;
  328. image {
  329. width: 100%;
  330. display: block;
  331. }
  332. .card {
  333. position: absolute;
  334. width: 690rpx;
  335. bottom: -30rpx;
  336. left: 50%;
  337. padding: 30rpx;
  338. // background-color: rgba(0, 0, 0, 0.26);
  339. background-color: #ffffff;
  340. border-radius: 10px;
  341. transform: translate(-50%, 0);
  342. // border: 1rpx #667870 solid;
  343. color: #ffffff;
  344. // display: flex;
  345. // flex-direction: column;
  346. // justify-content: space-between;
  347. .cardTop {
  348. display: flex;
  349. justify-content: space-between;
  350. .title {
  351. margin-bottom: 20rpx;
  352. width: 80%;
  353. // height: 48rpx;
  354. color:rgba(0, 0, 0, 0.8);
  355. font-family: PingFang SC;
  356. // overflow: hidden;
  357. // text-overflow: ellipsis;
  358. // white-space: nowrap;
  359. display: -webkit-box;
  360. word-break: break-all;
  361. text-overflow: ellipsis;
  362. overflow: hidden;
  363. -webkit-box-orient: vertical;
  364. -webkit-line-clamp: 2;
  365. }
  366. .icons {
  367. flex: 1;
  368. display: flex;
  369. // align-items: center;
  370. justify-content: space-between;
  371. .icon {
  372. width: 48rpx;
  373. height: 48rpx;
  374. display: flex;
  375. align-items: center;
  376. justify-content: center;
  377. }
  378. }
  379. }
  380. .col {
  381. margin-bottom: 10rpx;
  382. // font-weight: 100;
  383. color:rgba(0, 0, 0, 0.4);
  384. }
  385. .col2 {
  386. color:rgba(0, 0, 0, 0.8);
  387. // font-weight: bold;
  388. }
  389. .tag {
  390. display: flex;
  391. align-items: center;
  392. }
  393. }
  394. // background-image: url(https://teacherapi.cocorobo.cn/teaching-file/static//resource/jqr.png);
  395. }
  396. .creator {
  397. display: flex;
  398. padding: 30rpx;
  399. background-color: #ffffff;
  400. align-items: center;
  401. // margin-top: 20rpx;
  402. border-radius: 10px;
  403. image {
  404. width: 96rpx;
  405. height: 96rpx;
  406. border-radius: 50%;
  407. margin-right: 20rpx;
  408. }
  409. .creName {
  410. font-weight: bold;
  411. }
  412. }
  413. .member {
  414. background-color: #ffffff;
  415. margin-top: 20rpx;
  416. padding: 30rpx;
  417. border-radius: 10px;
  418. margin-bottom: 30rpx;
  419. .memberTop {
  420. display: flex;
  421. justify-content: space-between;
  422. margin-bottom: 10px;
  423. }
  424. .pers {
  425. display: flex;
  426. width: 100%;
  427. // justify-content: space-between;
  428. .per {
  429. display: flex;
  430. flex-direction: column;
  431. align-items: center;
  432. width: 16%;
  433. image {
  434. width: 72rpx;
  435. height: 72rpx;
  436. border-radius: 50%;
  437. }
  438. .perName {
  439. text-align: center;
  440. display: -webkit-box;
  441. word-break: break-all;
  442. text-overflow: ellipsis;
  443. overflow: hidden;
  444. -webkit-box-orient: vertical;
  445. -webkit-line-clamp: 1;
  446. }
  447. }
  448. }
  449. }
  450. .btnBlock {
  451. position: fixed;
  452. bottom: 0;
  453. width: 750rpx;
  454. background-color: #ffffff;
  455. // padding: 20px 0;
  456. padding: 2vh 0;
  457. .btn {
  458. width: 432rpx;
  459. height: 88rpx;
  460. font-weight: 500;
  461. display: flex;
  462. justify-content: center;
  463. align-items: center;
  464. margin: auto;
  465. background-color: #0056a8;
  466. color: #ffffff;
  467. }
  468. .btn1 {
  469. background-color: rgba(139, 190, 255, 1);
  470. }
  471. }
  472. .detailBlock {
  473. background-color: #ffffff;
  474. border-radius: 10rpx;
  475. padding: 30rpx;
  476. .tit {
  477. font-weight: 600;
  478. margin-bottom: 10px;
  479. }
  480. .cont {
  481. color: #999999;
  482. margin-bottom: 10px;
  483. text {
  484. color: #666666;
  485. }
  486. .content {
  487. white-space: normal;
  488. /*隐藏溢出*/
  489. /*当文本溢出包含元素时显示省略符号来代表被修剪的文本*/
  490. /*规定段落中的文本不进行换行*/
  491. letter-spacing: 2rpx;
  492. display: -webkit-box;
  493. word-break: break-all;
  494. text-overflow: ellipsis;
  495. overflow: hidden;
  496. -webkit-box-orient: vertical;
  497. -webkit-line-clamp: 4;
  498. }
  499. .content .p {
  500. width: 90%;
  501. color: #666666;
  502. // max-width: 100%;
  503. // display:inline-block;
  504. display: block;
  505. // float: left;
  506. overflow: hidden;
  507. text-overflow: ellipsis;
  508. white-space: nowrap;
  509. // padding-right: 50rpx;
  510. /*设置文字溢出时显示省略号*/
  511. }
  512. .content .p.is-expanded {
  513. width: 100%;
  514. overflow: visible;
  515. white-space: normal;
  516. /*文字溢出时不再显示省略号*/
  517. }
  518. .btn-more {
  519. float: right;
  520. display: inline-block;
  521. // width: 60px;
  522. transform: translate(0, -100%);
  523. color: #0056a8;
  524. }
  525. .btn-more.is-zd {
  526. transform: none;
  527. // transform: translate(0,0);
  528. }
  529. }
  530. }
  531. }
  532. </style>