publish.vue 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894
  1. <template>
  2. <view class="publish">
  3. <statusBar :item="navBarData"></statusBar>
  4. <view class="" style="background-color: #ffffff;">
  5. <view class="pubTitle">
  6. <input class="title" style="" placeholder="活动标题" v-model="activitytitle" />
  7. </view>
  8. <view class="pubMid">
  9. <view class="mid">
  10. <view class="txt">
  11. <textarea class="txtClass" value="" placeholder="请输入内容" v-model="activityintro" />
  12. </view>
  13. <view class="pic" @click="uploadPic">
  14. <view class="picCont">
  15. <image :src="pic" mode="aspectFill"></image>
  16. <view
  17. style="font-size: 24rpx;line-height: 40rpx;font-weight: 400;color: rgba(0, 0, 0, 0.6);">
  18. 添加图片
  19. </view>
  20. <view
  21. style="font-size: 20rpx;line-height: 36rpx;font-weight: 400;color: rgba(0, 0, 0, 0.4);">
  22. (0/1)
  23. </view>
  24. </view>
  25. <view class="pic_show" v-if="imageValue!==''">
  26. <image :src="imageValue" mode="aspectFill"></image>
  27. </view>
  28. </view>
  29. </view>
  30. </view>
  31. <view class="userOptionsBox">
  32. <view class="optionsItemBox">
  33. <picker mode="selector" :range="classifyList" :value="index" @change="handelclassify">
  34. <view class="optionItem">
  35. <view class="option_left">
  36. <text class="option_text">
  37. 活动分类
  38. </text>
  39. </view>
  40. <view class="option_right">
  41. <view class="input_details">
  42. <view class="details">
  43. <view class="uni-input text">
  44. {{classifyList[index]==null?'请选择':classifyList[index]}}
  45. </view>
  46. </view>
  47. <view class="arrow">
  48. <image
  49. src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png"
  50. mode="aspectFill"></image>
  51. </view>
  52. </view>
  53. </view>
  54. </view>
  55. </picker>
  56. </view>
  57. </view>
  58. <view class="userOptionsBox">
  59. <view class="optionsItemBox">
  60. <view class="optionItem">
  61. <view class="option_left">
  62. <text class="option_text">
  63. 招募人数
  64. </text>
  65. </view>
  66. <view class="option_right">
  67. <view class="input_details">
  68. <view class="details">
  69. <input type="text" class="title text" placeholder="请输入人数"
  70. placeholder-style="color: rgb(153, 153, 153);" maxlength="2"
  71. v-model="recruitment" />
  72. </view>
  73. <view class="arrow">
  74. <image
  75. src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png"
  76. mode="aspectFill"></image>
  77. </view>
  78. </view>
  79. </view>
  80. </view>
  81. </view>
  82. </view>
  83. <view class="userOptionsBox">
  84. <view class="optionsItemBox">
  85. <picker mode="selector" :range="activityformList" @change="handelActivityform">
  86. <view class="optionItem">
  87. <view class="option_left">
  88. <text class="option_text">
  89. 活动形式
  90. </text>
  91. </view>
  92. <view class="option_right">
  93. <view class="input_details">
  94. <view class="details">
  95. <view class="uni-input text">{{activityform}}</view>
  96. </view>
  97. <view class="arrow">
  98. <image
  99. src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png"
  100. mode="aspectFill"></image>
  101. </view>
  102. </view>
  103. </view>
  104. </view>
  105. </picker>
  106. </view>
  107. </view>
  108. <view class="userOptionsBox">
  109. <view class="optionsItemBox">
  110. <picker mode="selector" :range="addressList" @change="handeladdress">
  111. <view class="optionItem">
  112. <view class="option_left">
  113. <text class="option_text">
  114. 活动地址
  115. </text>
  116. </view>
  117. <view class="option_right">
  118. <view class="input_details">
  119. <view class="details">
  120. <view class="uni-input text">{{address}}</view>
  121. </view>
  122. <view class="arrow">
  123. <image
  124. src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png"
  125. mode="aspectFill"></image>
  126. </view>
  127. </view>
  128. </view>
  129. </view>
  130. </picker>
  131. </view>
  132. </view>
  133. <view class="userOptionsBox">
  134. <view class="optionsItemBox">
  135. <!-- <picker mode="date" :value="activityDate" :start="startDate" :end="endDate"
  136. @change="activityDateChange">
  137. <view class="optionItem">
  138. <view class="option_left">
  139. <text class="option_text">
  140. 活动时间
  141. </text>
  142. </view>
  143. <view class="option_right">
  144. <view class="input_details">
  145. <view class="details">
  146. <view class="uni-input text">{{ activityDate }}</view>
  147. </view>
  148. <view class="arrow">
  149. <image src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png" mode="aspectFill"></image>
  150. </view>
  151. </view>
  152. </view>
  153. </view>
  154. </picker> -->
  155. <view class="optionItem" @click="show = true">
  156. <view class="option_left">
  157. <text class="option_text">
  158. 活动时间
  159. </text>
  160. </view>
  161. <view class="option_right">
  162. <view class="input_details">
  163. <view class="details">
  164. <!-- <view class="uni-input text">{{ activityDate }}</view> -->
  165. <u-calendar :show="show" :mode="mode" @confirm="confirm" :closeOnClickOverlay="true"
  166. @close="show=false"></u-calendar>
  167. <view class="text">
  168. {{ activityDate }}
  169. </view>
  170. </view>
  171. <view class="arrow">
  172. <image
  173. src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png"
  174. mode="aspectFill"></image>
  175. </view>
  176. </view>
  177. </view>
  178. </view>
  179. </view>
  180. </view>
  181. <view class="userOptionsBox">
  182. <view class="optionsItemBox">
  183. <view class="optionItem">
  184. <view class="option_left">
  185. <text class="option_text">
  186. 活动费用(元)
  187. </text>
  188. </view>
  189. <view class="option_right">
  190. <view class="input_details">
  191. <view class="details">
  192. <!-- <view class="uni-input text">{{funds}}</view> -->
  193. <input type="text" class="title text" placeholder="请输入费用"
  194. placeholder-style="color: rgb(153, 153, 153);" maxlength="4" v-model="funds" />
  195. </view>
  196. <view class="arrow">
  197. <image
  198. src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png"
  199. mode="aspectFill"></image>
  200. </view>
  201. </view>
  202. </view>
  203. </view>
  204. </view>
  205. </view>
  206. <view class="userOptionsBox">
  207. <view class="optionsItemBox">
  208. <picker mode="date" :value="deadlineDate" :start="startDate" :end="endDate"
  209. @change="deadlineDateChange">
  210. <view class="optionItem">
  211. <view class="option_left">
  212. <text class="option_text">
  213. 报名截止
  214. </text>
  215. </view>
  216. <view class="option_right">
  217. <view class="input_details">
  218. <view class="details">
  219. <view class="uni-input text">{{ deadlineDate }}</view>
  220. </view>
  221. <view class="arrow">
  222. <image
  223. src="https://teacherapi.cocorobo.cn/teaching-file/static//mine/arrow-right.png"
  224. mode="aspectFill"></image>
  225. </view>
  226. </view>
  227. </view>
  228. </view>
  229. </picker>
  230. </view>
  231. </view>
  232. </view>
  233. <view class="" style="height: 10vh;width: 750rpx;position: relative;">
  234. <view class="publish_now">
  235. <button class="btn" @click="submitForm">{{ isedit?'立即修改':'立即上传' }}</button>
  236. </view>
  237. </view>
  238. <!-- 弹窗 -->
  239. <view>
  240. <view class="mask" v-show="showPopup" @click="closePopup"></view>
  241. <view class="popup-container" v-show="showPopup">
  242. <view class="popup">
  243. <view class="header">
  244. <text>确认{{ isedit?'修改':'上传' }}</text>
  245. </view>
  246. <view class="footer">
  247. <view class="cancel-btn" @click="closePopup">取消</view>
  248. <view class="confirm-btn" v-if="isedit" @click="editPublish">确认</view>
  249. <view class="confirm-btn" v-else @click="conf">确认</view>
  250. </view>
  251. </view>
  252. </view>
  253. </view>
  254. <view>
  255. <view class="mask" v-show="showPopupConfirm" @click="closePopup"></view>
  256. <view class="popup-container" style="height: 175px;" v-show="showPopupConfirm">
  257. <view class="popup">
  258. <view class="header" style="margin-top: 15px;">
  259. <image src="https://teacherapi.cocorobo.cn/teaching-file/static//gou1.png" mode="aspectFill">
  260. </image>
  261. <text style="margin-bottom: 24px;">{{ isedit?'修改':'上传' }}成功</text>
  262. </view>
  263. </view>
  264. </view>
  265. </view>
  266. </view>
  267. </template>
  268. <script>
  269. export default {
  270. data() {
  271. const currentDate = this.getDate({
  272. format: true
  273. })
  274. return {
  275. navBarData: {
  276. title: '发布', //导航栏标题
  277. btn: 1 //是否显示返回按钮 0不显示 1 显示
  278. },
  279. //时间选择器
  280. show: false,
  281. mode: 'range',
  282. //控制弹窗
  283. showPopup: false,
  284. // 成功弹窗
  285. showPopupConfirm: false,
  286. isFirstShow: true,
  287. //按钮文本
  288. // btntext: '立即发布',
  289. // 弹窗文本
  290. // poptext: '发布',
  291. //acId
  292. acId: '',
  293. // 上传标题
  294. activitytitle: '',
  295. // 上传内容
  296. activityintro: '',
  297. // 上传图片
  298. imageValue: '',
  299. // index判断选择分类 0 直播活动 1 常规教研活动 2 专题教研活动 3 推荐课程 ,对应上面
  300. index: null,
  301. // 人数
  302. recruitment: '',
  303. // 活动费用
  304. funds: '',
  305. // 活动地址选项
  306. addressList: ['深圳××学院', '××××××××', '××××××', '××××××', '××××××'],
  307. // 分类选项
  308. classifyList: ['直播活动', '活动推荐', '精选活动', '教研室活动'],
  309. // classifyList: ['直播活动', '常规教研活动', '专题教研活动'],
  310. // 活动形式选项
  311. activityformList: ['户外活动', '室内活动', '社会活动'],
  312. // 默认图片
  313. pic: 'https://teacherapi.cocorobo.cn/teaching-file/static//publish/photo.png',
  314. // 默认分类
  315. classify: '请选择',
  316. // 默认活动形式
  317. activityform: '请选择',
  318. // 默认活动地址
  319. address: '请选择',
  320. // activityDate: currentDate,
  321. // 活动时间默认显示
  322. activityDate: '请选择',
  323. // 报名截止默认显示
  324. deadlineDate: '请选择',
  325. // activeList: [],
  326. formData: {},
  327. // 上传和修改共用一个页面,为true修改 为false上传
  328. isedit: false
  329. };
  330. },
  331. computed: {
  332. startDate() {
  333. return this.getDate('start');
  334. },
  335. endDate() {
  336. return this.getDate('end');
  337. }
  338. },
  339. methods: {
  340. confirm(e) {
  341. // console.log(e);
  342. // console.log(e[0], e[e.length - 1]);
  343. this.activityDate = e[0] + '~' + e[e.length - 1]
  344. this.show = false
  345. },
  346. // 上传按钮进行判断必填
  347. submitForm() {
  348. if (!this.activitytitle || this.activitytitle == null) return uni.showToast({title: '请填写标题',icon: 'none'})
  349. if (!this.activityintro || this.activityintro == null) return uni.showToast({title: '请填写内容',icon: 'none'})
  350. if (!this.imageValue || this.imageValue == null) return uni.showToast({title: '请添加图片',icon: 'none'})
  351. if (!this.index && this.index == null) return uni.showToast({title: '请选择分类',icon: 'none'})
  352. this.showPopup = true; //显示弹窗
  353. },
  354. closePopup() {
  355. // 取消操作
  356. this.showPopup = false;
  357. this.showPopupConfirm = false;
  358. },
  359. // 上传活动
  360. conf() {
  361. this.formData = {
  362. // id: this.$store.state.user.openid,
  363. id:this.$store.state.user.openid,
  364. activitytitle: this.activitytitle,
  365. activityintro: this.activityintro,
  366. img: this.imageValue,
  367. recruitment: this.recruitment,
  368. activityform: this.activityform=='请选择'?'-':this.activityform,
  369. address: this.address=='请选择'?'-':this.address,
  370. classify: this.index,
  371. activityDate: this.activityDate=='请选择'?'-':this.activityDate,
  372. deadlineDate: this.deadlineDate=='请选择'?'-':this.deadlineDate,
  373. funds: this.funds
  374. };
  375. this.showPopup = false;
  376. this.showPopupConfirm = true
  377. this.$request('/insertActive', 'POST', this.formData).then(res => {
  378. // console.log(res.data);
  379. // if (res.code == 200) {
  380. setTimeout(() => {
  381. uni.switchTab({
  382. url: '/pages/activityPage/activityPage'
  383. })
  384. this.isedit=true
  385. uni.removeStorageSync('formData');
  386. }, 2000)
  387. // }
  388. })
  389. },
  390. // 修改上传
  391. editPublish() {
  392. let data={
  393. id: this.acId,
  394. tit: this.activitytitle,
  395. intro: this.activityintro,
  396. img: this.imageValue,
  397. per: this.recruitment,
  398. activityform: this.activityform,
  399. address: this.address,
  400. ty: this.index,
  401. activityDate: this.activityDate,
  402. deadlineDate: this.deadlineDate,
  403. funds: this.funds
  404. }
  405. this.showPopupConfirm = true
  406. // return console.log(data);
  407. this.$request('/updateMyPublish', 'POST', data).then(res => {
  408. // console.log(res);
  409. setTimeout(() => {
  410. uni.navigateBack();
  411. }, 1000)
  412. })
  413. },
  414. // 选择分类
  415. handelclassify(e) {
  416. this.index = e.detail.value
  417. },
  418. //选择活动形式
  419. handelActivityform(e) {
  420. this.activityform = this.activityformList[e.detail.value]
  421. },
  422. // 选择活动地址
  423. handeladdress(e) {
  424. this.address = this.addressList[e.detail.value]
  425. },
  426. // activityDateChange: function(e) {
  427. // this.activityDate = e.detail.value
  428. // },
  429. deadlineDateChange: function(e) {
  430. this.deadlineDate = e.detail.value
  431. },
  432. getDate(type) {
  433. const date = new Date();
  434. let year = date.getFullYear();
  435. let month = date.getMonth() + 1;
  436. let day = date.getDate();
  437. if (type === 'start') {
  438. year = year - 60;
  439. } else if (type === 'end') {
  440. year = year + 2;
  441. }
  442. month = month > 9 ? month : '0' + month;
  443. day = day > 9 ? day : '0' + day;
  444. return `${year}-${month}-${day}`;
  445. },
  446. // 上传图片
  447. uploadPic() {
  448. uni.chooseImage({
  449. count: 1, // 图片数量
  450. sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
  451. sourceType: ['album', 'camera'], //从相册选择或者拍照
  452. success: (res) => {
  453. const tempFilePaths = res.tempFilePaths[0];
  454. // console.log(this);
  455. let that = this
  456. const uploadTask = uni.uploadFile({
  457. url: 'http://139.159.246.165:7006/img', // post请求地址
  458. filePath: tempFilePaths,
  459. name: 'file', // 待确认
  460. header: {
  461. // 不要写这个不然报错
  462. // 'Content-Type': 'multipart/form-data',
  463. },
  464. success: function(res) {
  465. that.imageValue = res.data
  466. },
  467. fail: function(uploadFileFail) {
  468. console.log('Error:', uploadFileFail.data);
  469. },
  470. complete: () => {
  471. // 接口调用结束的回调函数(调用成功、失败都会执行)
  472. // console.log('Complete:');
  473. }
  474. });
  475. }
  476. });
  477. },
  478. },
  479. onLoad(e) {
  480. console.log('获取参数', e);
  481. if (e.acId) {
  482. let data = {
  483. oid: this.$store.state.user.openid,
  484. aid: e.acId
  485. }
  486. this.$request('/selectAmendAct', 'POST', data).then(res => {
  487. // console.log(res[0][0]);
  488. let item = res[0][0]
  489. this.acId = item.acId
  490. this.activitytitle = item.acName
  491. this.activityintro = item.brief
  492. this.imageValue = item.pic
  493. this.index = item.type
  494. this.recruitment = item.pers
  495. this.activityform = item.acshape
  496. this.address = item.address
  497. this.funds = item.cost
  498. this.activityDate = item.begin_at
  499. this.deadlineDate = item.endTime
  500. })
  501. this.isedit = true
  502. }
  503. // console.log(uni.getStorageSync('formData'));
  504. // 获取缓存里面的数据
  505. let setAll=uni.getStorageSync('formData')
  506. if(setAll){
  507. this.activitytitle = setAll.activitytitle
  508. this.activityintro = setAll.activityintro
  509. this.imageValue = setAll.imageValue
  510. this.index = setAll.classify
  511. this.recruitment = setAll.recruitment
  512. this.activityform = setAll.activityform
  513. this.address = setAll.address
  514. this.funds = setAll.funds
  515. this.activityDate = setAll.activityDate
  516. this.deadlineDate = setAll.deadlineDate
  517. }
  518. },
  519. beforeDestroy() {
  520. // 在组件销毁之前保存表单数据到 Vuex 中
  521. let data = {
  522. activitytitle: this.activitytitle,
  523. activityintro: this.activityintro,
  524. imageValue: this.imageValue,
  525. classify: this.index,
  526. recruitment: this.recruitment,
  527. activityform: this.activityform,
  528. address: this.address,
  529. funds: this.funds,
  530. activityDate: this.activityDate,
  531. deadlineDate: this.deadlineDate
  532. }
  533. if (!this.isedit) {
  534. uni.setStorageSync('formData', data)
  535. }
  536. },
  537. }
  538. </script>
  539. <style lang="scss" scoped>
  540. .publish {
  541. .liu {
  542. //留白
  543. width: 750rpx;
  544. height: 68rpx;
  545. position: absolute;
  546. bottom: 0;
  547. background-color: #ffffff;
  548. }
  549. .pubTitle {
  550. width: 750rpx;
  551. height: 96rpx;
  552. padding: 24rpx 30rpx 0 30rpx;
  553. .title {
  554. font-size: 32rpx;
  555. line-height: 48rpx;
  556. font-weight: 500;
  557. }
  558. }
  559. .pubMid {
  560. width: 750rpx;
  561. // height: 504rpx;
  562. padding: 24rpx 30rpx 0 30rpx;
  563. // background-color: #8BBEFF;
  564. .mid {
  565. width: 690rpx;
  566. height: 440rpx;
  567. // background-color: #f2f2f2;
  568. .txt {
  569. width: 690rpx;
  570. height: 192rpx;
  571. .txtClass {
  572. width: 100%;
  573. height: 100%;
  574. font-size: 28rpx;
  575. font-weight: 400;
  576. line-height: 48rpx;
  577. }
  578. }
  579. .pic {
  580. width: 224rpx;
  581. height: 224rpx;
  582. background-color: rgba(242, 242, 242, 1);
  583. display: flex;
  584. position: relative;
  585. justify-content: center;
  586. align-items: center;
  587. .pic_show {
  588. position: absolute;
  589. top: 0;
  590. left: 0;
  591. width: 100%;
  592. height: 100%;
  593. z-index: 10;
  594. background-color: #8BBEFF;
  595. image {
  596. width: 100%;
  597. height: 100%;
  598. }
  599. }
  600. .picCont {
  601. display: flex;
  602. flex-direction: column;
  603. justify-content: center;
  604. align-items: center;
  605. image {
  606. width: 56rpx;
  607. height: 66rpx;
  608. }
  609. }
  610. }
  611. }
  612. }
  613. // background-color: #fff;
  614. height: 100vh;
  615. .textCont {
  616. padding: 16px;
  617. }
  618. .addPhoto {
  619. background-color: #f2f2f2;
  620. width: 224rpx;
  621. height: 224rpx;
  622. display: flex;
  623. color: #616161;
  624. flex-direction: column;
  625. align-items: center;
  626. justify-content: center;
  627. margin-left: 30rpx;
  628. image {
  629. width: 50px;
  630. height: 50px;
  631. // margin-left: 48px;
  632. }
  633. .photo {
  634. color: #000000A3;
  635. // padding-left: 44px;
  636. // font-size: 14px;
  637. }
  638. .num {
  639. color: #919191;
  640. // padding-left: 56px;
  641. // font-size: 14px;
  642. }
  643. }
  644. .userOptionsBox {
  645. width: 750rpx;
  646. height: 96rpx;
  647. display: flex;
  648. justify-content: center;
  649. align-items: center;
  650. .optionsItemBox {
  651. width: 690rpx;
  652. .optionItem {
  653. display: flex;
  654. justify-content: space-between;
  655. align-items: center;
  656. .option_left {
  657. display: flex;
  658. align-items: center;
  659. font-size: 28rpx;
  660. line-height: 48rpx;
  661. font-weight: 400;
  662. }
  663. .option_right {
  664. height: 40rpx;
  665. .input_details {
  666. display: flex;
  667. align-items: center;
  668. .details {
  669. display: flex;
  670. flex-direction: row;
  671. color: rgb(153, 153, 153);
  672. .text {
  673. font-size: 28rpx;
  674. color: rgb(153, 153, 153);
  675. }
  676. input {
  677. text-align: right;
  678. }
  679. }
  680. .arrow {
  681. display: flex;
  682. image {
  683. width: 32rpx;
  684. height: 32rpx;
  685. }
  686. }
  687. }
  688. }
  689. }
  690. }
  691. }
  692. .publish_now {
  693. position: absolute;
  694. // bottom: 100rpx;
  695. display: flex;
  696. width: 750rpx;
  697. justify-content: center;
  698. padding-bottom: 50rpx;
  699. .btn {
  700. width: 432rpx;
  701. height: 88rpx;
  702. line-height: 88rpx;
  703. // background-color: #8BBEFF;
  704. background: rgba(0, 86, 168, 1);
  705. color: #fff;
  706. display: flex;
  707. flex-direction: column;
  708. align-items: center;
  709. margin-top: 20px;
  710. }
  711. }
  712. .mask {
  713. position: fixed;
  714. top: 0;
  715. left: 0;
  716. width: 100%;
  717. height: 100%;
  718. background-color: rgba(0, 0, 0, 0.3);
  719. z-index: 999;
  720. overflow: hidden;
  721. // display: none;
  722. }
  723. .popup-container {
  724. position: fixed;
  725. top: 50%;
  726. left: 50%;
  727. transform: translate(-50%, -50%);
  728. width: 520rpx;
  729. height: 260rpx;
  730. z-index: 1000;
  731. // display: none;
  732. .popup {
  733. width: 100%;
  734. height: 100%;
  735. display: flex;
  736. flex-direction: column;
  737. background-color: #fff;
  738. border-radius: 16rpx;
  739. overflow: hidden;
  740. .header {
  741. flex: 1;
  742. display: flex;
  743. justify-content: center;
  744. align-items: center;
  745. flex-direction: column;
  746. margin-top: 24px;
  747. font-size: 34rpx;
  748. font-weight: 600;
  749. image {
  750. width: 150rpx;
  751. height: 150rpx;
  752. margin-top: 15px;
  753. margin-bottom: 15px;
  754. }
  755. }
  756. .footer {
  757. width: 100%;
  758. display: flex;
  759. overflow: hidden;
  760. .cancel-btn {
  761. width: 50%;
  762. height: 100rpx;
  763. background-color: #F7F7F7;
  764. color: #000;
  765. font-size: 34rpx;
  766. text-align: center;
  767. border-bottom-left-radius: 16rpx;
  768. line-height: 50px;
  769. }
  770. .confirm-btn {
  771. width: 50%;
  772. height: 100rpx;
  773. background-color: #0081FE;
  774. color: #fff;
  775. font-size: 34rpx;
  776. text-align: center;
  777. line-height: 50px;
  778. }
  779. // .confirm-btn_2 {
  780. // width: 518rpx;
  781. // height: 100rpx;
  782. // background-color: #F7F7F7;
  783. // color: #000;
  784. // font-size: 34rpx;
  785. // text-align: center;
  786. // border-radius: 0;
  787. // border-bottom-left-radius: 16rpx;
  788. // border-bottom-right-radius: 16rpx;
  789. // line-height: 50px;
  790. // }
  791. }
  792. }
  793. }
  794. }
  795. </style>