index.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408
  1. <template>
  2. <view>
  3. <view class="main_view">
  4. <image v-if="action_info.banner_img" :src="action_info.banner_img" class="banner_img"></image>
  5. <view class="active_title"> 活动内容 </view>
  6. <view class="clockin_box" v-if="active_rule?.length > 0">
  7. <view class="box_title"> 邀请好友成功注册,即可获得奖励 </view>
  8. <view class="box_time_text"> 三步奖励到账 </view>
  9. <view class="box_text">
  10. <uni-steps mode="number" deactiveColor="#1aad19" :options="[{ title: '邀请新人好友' }, { title: '好友注册成功' }, { title: '奖励到账' }]" :active="3"></uni-steps>
  11. </view>
  12. <view class="box_time_text"> 活动时间 </view>
  13. <view class="box_time"> {{ action_info.start_time }} 至 {{ action_info.end_time }} </view>
  14. <navigator url="/pages/recruitment/record" class="score_record">我的奖励记录 &gt;</navigator>
  15. <button class="clockin_rule_btn" @click="showRule">活动规则 &gt;</button>
  16. </view>
  17. <view class="clockin_box" v-else>
  18. <view class="box_title"> 暂无拉新活动 </view>
  19. </view>
  20. <uni-popup ref="clockinRule" type="center">
  21. <view class="clockin_rule_box">
  22. <view class="clockin_rule_title">
  23. <text>签到规则</text>
  24. <view class="close_btn" @click="closeRule"> X </view>
  25. </view>
  26. <scroll-view class="clockin_rule_info" scroll-y="true">
  27. <rich-text :nodes="active_rule" class="rich_text"></rich-text>
  28. </scroll-view>
  29. </view>
  30. </uni-popup>
  31. </view>
  32. </view>
  33. </template>
  34. <script>
  35. export default {
  36. data() {
  37. return {
  38. status_bar_style: {},
  39. action_info: [],
  40. isReqing: false,
  41. listKey: 0,
  42. listLength: 0,
  43. active_id: 0,
  44. active_rule: "",
  45. };
  46. },
  47. onLoad(param) {
  48. // 存储分享标识
  49. if (param.share_uid) {
  50. uni.setStorageSync("share_uid", param.share_uid);
  51. console.log("share_uid", param.share_uid);
  52. }
  53. //分享按钮
  54. uni.showShareMenu({
  55. withShareTicket: true,
  56. menus: ["shareAppMessage", "shareTimeline"],
  57. });
  58. },
  59. onShareAppMessage(obj) {
  60. //获取当前用户信息
  61. let userInfo = uni.getStorageSync("userInfo");
  62. let param = "";
  63. if (userInfo.uid) {
  64. param = "?share_uid=" + userInfo.uid;
  65. }
  66. console.log(222, param);
  67. // 返回分享信息
  68. return {
  69. title: "999智控终端平台\n药优惠 得积分 兑豪礼",
  70. path: "/pages/recruitment/index",
  71. imageUrl: "",
  72. promise: new Promise((resolve, reject) => {
  73. this.$http.request("api/share_message/get_item", { item_id: this.action_info.id, pages: "/pages/recruitment/index" }).then((callback) => {
  74. console.log(callback, "api/share_message/get_item");
  75. let obj = {
  76. title: callback.data?.title == "" ? "999智控终端平台\n药优惠 得积分 兑豪礼" : callback.data.title,
  77. path: "/pages/recruitment/index",
  78. };
  79. if (callback.data?.image_url !== "") {
  80. obj.imageUrl = callback.data.image_url;
  81. }
  82. if (param) {
  83. obj.path += param;
  84. }
  85. resolve(obj);
  86. });
  87. }),
  88. };
  89. },
  90. onShow() {
  91. // 登录提示
  92. if (!this.$checkAccess.alterLogin()) return;
  93. // 请求中,不允许刷新
  94. if (this.isReqing) return;
  95. // 设置请求中
  96. this.isReqing = true;
  97. // 请求列表
  98. this.$http.request("/api/recruitment/get_info", this.requestParam).then((re) => {
  99. // 设置非请求中
  100. this.isReqing = false;
  101. // 成功结果
  102. if (re.code == "success") {
  103. this.action_info = re.data;
  104. this.active_rule = this.action_info.active_rule;
  105. console.log(this.action_info?.length);
  106. }
  107. });
  108. },
  109. methods: {
  110. showRule() {
  111. this.$refs.clockinRule.open("center");
  112. },
  113. closeRule() {
  114. this.$refs.clockinRule.close();
  115. },
  116. },
  117. };
  118. </script>
  119. <style lang="less">
  120. page {
  121. background-color: #ffffff;
  122. }
  123. .main_view {
  124. display: block;
  125. height: 1000rpx;
  126. background: linear-gradient(to bottom, #fc335f 0%, #fb7224 50%, #ffffff 100%);
  127. .banner_img {
  128. height: 450rpx;
  129. width: 100%;
  130. }
  131. .status_bar {
  132. width: 100%;
  133. height: 64rpx;
  134. display: block;
  135. padding-top: var(--status-bar-height);
  136. }
  137. .active_title {
  138. width: 700rpx;
  139. height: 80rpx;
  140. line-height: 80rpx;
  141. text-align: center;
  142. margin: 0rpx auto;
  143. border-radius: 30rpx;
  144. background-color: #f86526;
  145. color: #f9f9f9;
  146. }
  147. .clockin_box {
  148. z-index: 9;
  149. display: block;
  150. width: 700rpx;
  151. margin: 0rpx auto;
  152. position: relative;
  153. border-radius: 40rpx;
  154. background-color: #ffffff;
  155. box-shadow: 5rpx 5rpx 2rpx 0rpx #dddddd;
  156. .box_title {
  157. padding-top: 20rpx;
  158. height: 80rpx;
  159. color: #000000;
  160. text-align: center;
  161. line-height: 80rpx;
  162. }
  163. .box_text {
  164. padding-top: 20rpx;
  165. }
  166. .box_time_text {
  167. padding-top: 40rpx;
  168. text-align: center;
  169. color: #e15c21;
  170. }
  171. .box_time {
  172. padding-top: 20rpx;
  173. text-align: center;
  174. color: #555555;
  175. font-size: 25rpx;
  176. }
  177. .clockin_list {
  178. display: block;
  179. overflow: hidden;
  180. width: 100%;
  181. padding-top: 25rpx;
  182. .clockin_item {
  183. float: left;
  184. position: relative;
  185. width: 70rpx;
  186. height: 165rpx;
  187. text-align: center;
  188. margin-left: 25rpx;
  189. border-radius: 20rpx;
  190. margin-bottom: 20rpx;
  191. background-color: #f8f8f8;
  192. .what_day {
  193. display: block;
  194. height: 40rpx;
  195. font-size: 24rpx;
  196. line-height: 60rpx;
  197. }
  198. .score_one {
  199. display: block;
  200. height: 60rpx;
  201. margin: 10rpx auto;
  202. position: relative;
  203. .score_icon {
  204. display: block;
  205. width: 60rpx;
  206. height: 60rpx;
  207. margin: 0rpx auto;
  208. }
  209. }
  210. .score_tow {
  211. display: block;
  212. height: 80rpx;
  213. margin: 10rpx auto;
  214. position: relative;
  215. .score_icon {
  216. display: block;
  217. width: 80rpx;
  218. height: 80rpx;
  219. margin: 0rpx auto;
  220. }
  221. .score_icon:nth-child(1) {
  222. top: 0rpx;
  223. left: 10rpx;
  224. width: 80rpx;
  225. height: 80rpx;
  226. position: absolute;
  227. }
  228. .score_icon:nth-child(2) {
  229. top: 0rpx;
  230. left: 55rpx;
  231. width: 80rpx;
  232. height: 80rpx;
  233. position: absolute;
  234. }
  235. }
  236. .score_the {
  237. width: 200rpx;
  238. display: block;
  239. height: 100rpx;
  240. margin: 10rpx auto;
  241. position: relative;
  242. .score_icon {
  243. display: block;
  244. width: 80rpx;
  245. height: 80rpx;
  246. margin: 0rpx auto;
  247. }
  248. .score_icon:nth-child(1) {
  249. top: 15rpx;
  250. left: 20rpx;
  251. width: 80rpx;
  252. height: 80rpx;
  253. position: absolute;
  254. }
  255. .score_icon:nth-child(2) {
  256. top: 15rpx;
  257. left: 95rpx;
  258. width: 80rpx;
  259. height: 80rpx;
  260. position: absolute;
  261. }
  262. .score_icon:nth-child(3) {
  263. top: 0rpx;
  264. left: 60rpx;
  265. width: 80rpx;
  266. height: 80rpx;
  267. position: absolute;
  268. }
  269. }
  270. .give_score {
  271. display: block;
  272. height: 30rpx;
  273. font-size: 24rpx;
  274. line-height: 40rpx;
  275. }
  276. .give_coupon {
  277. position: absolute;
  278. font-size: 20rpx;
  279. padding: 2px 5px;
  280. background-color: #f00;
  281. color: #fff;
  282. border-radius: 6px;
  283. display: inline-block;
  284. text-align: center;
  285. right: -15rpx;
  286. top: -15rpx;
  287. }
  288. }
  289. /*.clockin_item:nth-child(7){
  290. width: 315rpx;
  291. }*/
  292. .clockin_item.acitve {
  293. color: #ffffff;
  294. background-color: #e03519;
  295. }
  296. }
  297. .clockin_btn {
  298. width: 660rpx;
  299. color: #ffffff;
  300. font-size: 30rpx;
  301. margin-top: 20rpx;
  302. padding: 0rpx 0rpx;
  303. border-radius: 60rpx;
  304. background-color: #e03519;
  305. border: 0rpx solid transparent;
  306. }
  307. .clockin_btn.active {
  308. color: #ffffff;
  309. background-color: #aaaaaa;
  310. }
  311. .clockin_btn::after {
  312. border: 0rpx solid transparent;
  313. }
  314. .score_record {
  315. height: 60rpx;
  316. display: block;
  317. color: #999999;
  318. font-size: 24rpx;
  319. margin-top: 20rpx;
  320. text-align: center;
  321. line-height: 80rpx;
  322. }
  323. .clockin_rule_btn {
  324. color: #999999;
  325. overflow: hidden;
  326. font-size: 24rpx;
  327. text-align: center;
  328. line-height: 80rpx;
  329. padding: 0rpx 0rpx;
  330. background: transparent;
  331. }
  332. .clockin_rule_btn::after {
  333. border: 0rpx solid transparent;
  334. }
  335. }
  336. }
  337. .popup {
  338. overflow: hidden;
  339. }
  340. .clockin_rule_box {
  341. width: 500rpx;
  342. display: block;
  343. overflow: hidden;
  344. background: #ffffff;
  345. font-size: 26rpx;
  346. margin: 0rpx auto;
  347. line-height: 50rpx;
  348. border-radius: 10rpx;
  349. padding: 0rpx 25rpx;
  350. padding-bottom: 20rpx;
  351. background: linear-gradient(to bottom, #fc335f 0%, #fb7224 100%);
  352. .clockin_rule_title {
  353. color: #ffffff;
  354. height: 60rpx;
  355. font-size: 32rpx;
  356. line-height: 60rpx;
  357. text-align: center;
  358. margin-bottom: 10rpx;
  359. .close_btn {
  360. float: right;
  361. width: 40rpx;
  362. height: 40rpx;
  363. font-size: 24rpx;
  364. margin-top: 9rpx;
  365. line-height: 40rpx;
  366. border-radius: 50%;
  367. border: 1rpx solid #ffffff;
  368. }
  369. }
  370. .clockin_rule_info {
  371. display: block;
  372. height: 500rpx;
  373. font-size: 24rpx;
  374. line-height: 40rpx;
  375. border-radius: 10rpx;
  376. padding: 20rpx 20rpx;
  377. box-sizing: border-box;
  378. background-color: #ffffff;
  379. .rich_text {
  380. white-space: break-spaces;
  381. }
  382. }
  383. }
  384. </style>