login_Wechat.vue 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959
  1. <template>
  2. <view class="login_Wechat">
  3. <statusBar :item='navBarData'></statusBar>
  4. <view class="block">
  5. <button class="avatar-wrapper" open-type="chooseAvatar" @chooseavatar="onChooseAvatar">
  6. <image class="avatar" :src="avatarUrl"></image>
  7. </button>
  8. </view>
  9. <!-- <view class="inp">
  10. <view class="nc">昵称:</view>
  11. <input type="nickname" class="weui-input" :value="nickname" @blur="inpvalue" placeholder="请输入昵称" />
  12. </view> -->
  13. <view class="mid">
  14. <!-- <radio value="r1" @click="radioCheck" size="10" :checked="isOK" /> -->
  15. <view class="" style="position: relative;padding-left:30rpx;">
  16. 我已阅读并同意<text>《教育小程序服务条款》</text>和 <text>《 隐私协议》</text>新用户自动注册
  17. <view class="quan" @click="isDui">
  18. <image v-if="isShow" class="dui"
  19. src="https://teacherapi.cocorobo.cn/teaching-file/static//yym/dui.png" mode="aspectFill">
  20. </image>
  21. </view>
  22. </view>
  23. </view>
  24. <button class="btn" @click="gotoIndex">一键登录</button>
  25. <!-- <view class="footer" @click="goto">
  26. <text>手机号登录/账号密码登录</text>
  27. </view> -->
  28. <view class="popupBlock" v-if="popupShow">
  29. <view class="shade" v-if="allShow" @click="hiddenShade">
  30. </view>
  31. <view class="pop">
  32. <view class="poptit">
  33. 完善信息
  34. </view>
  35. <view class="infoTxt">
  36. <view class="txtcell">
  37. <view class="">
  38. <text class="celTit">学号/工号</text>
  39. </view>
  40. <input @blur="judgeNum" type="number" class="inpSty" maxlength="11" placeholder="输入后自动获取信息"
  41. placeholder-style="font-size: 28rpx; color: rgb(153, 153, 153);" v-model="judgeNumber" />
  42. </view>
  43. <view class="txtcell">
  44. <view class="">
  45. <text class="dian">*</text><text class="celTit">姓名</text>
  46. </view>
  47. <input type="text" class="inpSty" maxlength="10" placeholder="请输入真实姓名"
  48. placeholder-style="font-size: 28rpx; color: rgb(153, 153, 153);"
  49. v-model="userData.username" />
  50. </view>
  51. <view class="txtcell">
  52. <view class="">
  53. <text class="dian">*</text><text class="celTit">联系方式</text>
  54. </view>
  55. <input @blur="handleInput" type="number" class="inpSty" maxlength="11" placeholder="请输入联系方式"
  56. placeholder-style="font-size: 28rpx; color: rgb(153, 153, 153);" v-model="userData.tel" />
  57. </view>
  58. <view class="txtcell">
  59. <view class="" style="width: 100rpx;">
  60. <text class="dian">*</text><text class="celTit">学校</text>
  61. </view>
  62. <view class="pickerBlock" @click="show">
  63. <view class="" style="position: relative;">
  64. <view class="">
  65. {{ !stuName?'请选择学校':stuName }}
  66. </view>
  67. <view class="stuListSty" v-if="isshow">
  68. <view class="Usearch">
  69. <u-search placeholder="搜索学校" :showAction="false" shape="square"
  70. v-model="searchStudent"></u-search>
  71. <view class="UsearchBtn" @click.stop="typeIn(0)">
  72. 手动录入
  73. </view>
  74. </view>
  75. <scroll-view scroll-y="true" show-scrollbar="true" class="list">
  76. <view id="demo1" class="listcon" @click.stop="addStu" :data-item="i"
  77. v-for="(i,index) in colleges" :key="i">{{i.name}}</view>
  78. </scroll-view>
  79. </view>
  80. </view>
  81. <uni-icons type="right" class="icooo" size="20" color='rgba(0, 0, 0, 0.4)'></uni-icons>
  82. </view>
  83. </view>
  84. <view class="txtcell">
  85. <view class="" style="width: 100rpx;">
  86. <text class="celTit">专业</text>
  87. </view>
  88. <view class="pickerBlock" @click="majorshow">
  89. <view class="" style="position: relative;">
  90. <view class="">
  91. {{ !majorName?'请选择专业':majorName }}
  92. </view>
  93. <view class="stuListSty" v-if="jorshow">
  94. <view class="Usearch">
  95. <u-search placeholder="搜索专业" :showAction="false" shape="square"
  96. v-model="searchMajor"></u-search>
  97. <view class="UsearchBtn" @click.stop="typeIn(1)">
  98. 手动录入
  99. </view>
  100. </view>
  101. <scroll-view scroll-y="true" show-scrollbar="true" class="list">
  102. <view class="listcon" v-if="!majorList.length">
  103. 此学校暂时没有专业分类哦
  104. </view>
  105. <view id="demo1" class="listcon" @click.stop="addmajor" :data-jor="i"
  106. v-for="(i,index) in majorList" :key="index">{{i.name}}</view>
  107. </scroll-view>
  108. </view>
  109. </view>
  110. <uni-icons type="right" class="icooo" size="20" color='rgba(0, 0, 0, 0.4)'></uni-icons>
  111. </view>
  112. </view>
  113. <view class="txtcell">
  114. <view class="">
  115. <text class="celTit">职称</text><text
  116. style="color: rgba(0, 0, 0, 0.26);padding-left: 10rpx;">(选填)</text>
  117. </view>
  118. <view class="pickerBlock">
  119. <picker mode="selector" @change="rankChange" :range="rankList">
  120. <view class="uni-input">{{!userData.rankl?'请选择':userData.rankl}}</view>
  121. </picker>
  122. <uni-icons type="right" class="icooo" size="20" color='rgba(0, 0, 0, 0.4)'></uni-icons>
  123. </view>
  124. </view>
  125. </view>
  126. <!-- <view :class="btnColor" @click="register">
  127. 完善信息并登录
  128. </view> -->
  129. <view class="logbtn2" @click="register">
  130. 完善信息并登录
  131. </view>
  132. <view class="logbri">
  133. 完善个人信息后即可加入“丽湖国际双创虚拟教研室”会员,免费获取海量精品资源~
  134. </view>
  135. </view>
  136. </view>
  137. <u-popup :show="popupshow" mode="center" round="10" :closeable='true' @close="popupclose">
  138. <view style="width: 600rpx;box-sizing: border-box;padding: 40px 20rpx; padding-bottom: 30px;">
  139. <view class="" style="display: flex;align-items: center;">
  140. <!-- <text>{{ typyInall?'专业':'学校' }} :</text> -->
  141. <u--input :placeholder="typyInall?'请输入专业':'请输入学校'" border="surround" v-model="typyInCon"></u--input>
  142. </view>
  143. <view style="display: flex;width: 100%;justify-content: space-around;margin-top: 20rpx;">
  144. <view class="typyInbtn" @click="popupclose">
  145. 取消
  146. </view>
  147. <view class="typyInbtn" @click="popupaffirm">
  148. 确定
  149. </view>
  150. </view>
  151. </view>
  152. </u-popup>
  153. </view>
  154. </template>
  155. <script>
  156. export default {
  157. data() {
  158. return {
  159. // 遮罩框
  160. allShow: false,
  161. isLogin: false,
  162. searchStudent: '', //学校搜索栏
  163. searchMajor: '', //专业搜索栏
  164. logbtn: 'logbtn',
  165. logbtn2: 'logbtn2',
  166. avatarUrl: '',
  167. nickname: '',
  168. // 学校
  169. isshow: false,
  170. stuName: '', //学校名称
  171. colleges: [], //学校列表
  172. // inpTxt: '', //学校id
  173. // scharray: ['深圳城市××大学', '深圳××大学', '深圳××大学', '深圳××大学'],
  174. // 专业
  175. jorshow: false,
  176. majorList: [],
  177. majorName: '',
  178. // majorInpTxt: '', //专业id
  179. // speList: ['互联网', '网络通信', '航空', '汽修', '珠宝', '文秘', '设计'],
  180. // 职称
  181. rankList: ['教授', '副教授', '讲师', '助教', '其他'],
  182. // 默认头像的
  183. isShow: false,
  184. // 完善信息弹窗的
  185. popupShow: false,
  186. navBarData: {
  187. title: '登录',
  188. btn: 1 //判断是否显示返回按钮
  189. },
  190. btnCol: [],
  191. // 这两个因为要监视,所以不能放对象里面
  192. inpTxt: '', //学校id
  193. majorInpTxt: '', //专业id
  194. // 手动录入弹窗
  195. popupshow: false,
  196. typyInCon: '',
  197. typyInall: 0,
  198. // 第一次登录
  199. // name2:'', //被监视name
  200. // 学号工号
  201. judgeNumber: '',
  202. userData: {
  203. openid: '',
  204. username: '',
  205. avatar: '',
  206. tel: '',
  207. inpTxt: '', //学校id
  208. majorInpTxt: '', //专业id
  209. rankl: '', //职称
  210. schName: '', //学校名字
  211. jorName: '' //专业名字
  212. }
  213. };
  214. },
  215. watch: {
  216. // judgeNumber:{
  217. // handler(val){
  218. // }
  219. // },
  220. searchMajor: {
  221. handler(val) {
  222. // 模糊搜索专业
  223. let data = {
  224. mid: this.inpTxt,
  225. txt: val
  226. }
  227. this.$request('/selectLikeMajors', "get", data).then(res => {
  228. console.log('模糊搜索专业', res);
  229. this.majorList = res[0]
  230. })
  231. // this.selectMajor(val)
  232. }
  233. },
  234. searchStudent: {
  235. handler(val) {
  236. this.$request('/selectLikeColleges', "get", {
  237. txt: val
  238. }).then(res => {
  239. console.log(res);
  240. this.colleges = res[0]
  241. })
  242. // this.selectMajor(val)
  243. }
  244. },
  245. inpTxt: {
  246. handler(val) {
  247. console.log('val', val);
  248. this.selectMajor(val)
  249. }
  250. }
  251. },
  252. methods: {
  253. popupclose() {
  254. this.popupshow = false
  255. this.typyInCon = ''
  256. this.searchStudent = ''
  257. },
  258. popupaffirm() {
  259. if (!this.typyInall) {
  260. if (!this.typyInCon) return uni.showToast({
  261. title:'请输入学校',
  262. icon:'none',
  263. })
  264. this.stuName = this.typyInCon
  265. this.searchStudent = ''
  266. this.inpTxt = ''
  267. this.majorInpTxt = ''
  268. this.searchMajor = ''
  269. this.majorName = ''
  270. this.popupshow = false
  271. // 赋值完清空
  272. this.typyInCon = ''
  273. } else {
  274. if (!this.typyInCon) return uni.showToast({
  275. title:'请输入专业',
  276. icon:'none',
  277. })
  278. this.majorName = this.typyInCon
  279. this.majorInpTxt = ''
  280. this.searchMajor = ''
  281. this.popupshow = false
  282. // 赋值完清空
  283. this.typyInCon = ''
  284. }
  285. },
  286. typeIn(e) {
  287. this.hiddenShade()
  288. this.typyInall = e
  289. this.popupshow = true
  290. },
  291. // 遮罩层
  292. hiddenShade() {
  293. this.isshow = false
  294. this.jorshow = false
  295. this.allShow = false
  296. },
  297. // typeInSch(){
  298. // if(!this.searchStudent) return
  299. // this.stuName = this.searchStudent
  300. // this.searchStudent=''
  301. // this.inpTxt=''
  302. // this.majorInpTxt=''
  303. // this.searchMajor=''
  304. // this.majorName=''
  305. // this.hiddenShade()
  306. // },
  307. // typeInMajor(){
  308. // if(!this.searchMajor) return
  309. // this.majorName = this.searchMajor
  310. // this.majorInpTxt=''
  311. // this.searchMajor=''
  312. // this.hiddenShade()
  313. // },
  314. // 学校list显示与隐藏
  315. show() {
  316. this.isshow = true
  317. // this.jorshow = false
  318. this.allShow = true
  319. },
  320. // 选择学校
  321. addStu(e) {
  322. // 选择学校时,将专业的数据清除,让其重新选择
  323. this.majorInpTxt = ''
  324. this.majorName = ''
  325. this.majorList = []
  326. // 为学校选项赋值
  327. let data = e.currentTarget.dataset.item
  328. this.inpTxt = data.id
  329. this.stuName = data.name
  330. // 学校list隐藏/显示
  331. this.isshow = false
  332. // 遮罩层隐藏
  333. this.allShow = false
  334. },
  335. // 专业list显示与隐藏
  336. majorshow() {
  337. // 学校未选择则提示
  338. if (!this.stuName) {
  339. uni.showToast({
  340. title: '请先选择学校',
  341. icon: 'none',
  342. duration: 1000
  343. });
  344. return
  345. }
  346. // 遮罩层显示
  347. this.allShow = true
  348. this.jorshow = true
  349. },
  350. // 选择专业
  351. addmajor(e) {
  352. let data = e.currentTarget.dataset.jor
  353. // console.log('选择专业', e);
  354. this.majorInpTxt = data.id
  355. this.majorName = data.name
  356. // console.log('选择专业', this.majorInpTxt);
  357. this.jorshow = false
  358. this.allShow = false
  359. },
  360. // 根据选择的学校来进行显示专业
  361. selectMajor(e) {
  362. console.log('根据选择的学校来进行显示专业', e);
  363. let data = {
  364. mid: e
  365. }
  366. this.$request('/selectMajors', "get", data).then(res => {
  367. console.log('显示专业列表', res);
  368. // if (res[0].length === 0) {
  369. // this.majorList[0] = {
  370. // name: '此学校没有专业分类哦'
  371. // }
  372. // } else {
  373. this.majorList = res[0]
  374. // }
  375. // this.majorList = res[0]
  376. })
  377. },
  378. // 判断手机号
  379. handleInput(e) {
  380. // console.log(e.target);
  381. const {
  382. value
  383. } = e.target
  384. // console.log(value);
  385. const newValue = value.replace(/\s*/g, '') // 只允许输入数字
  386. console.log(newValue);
  387. // if (newValue.length <= 11) {
  388. this.userData.tel = newValue
  389. // }
  390. // console.log(this.userData.tel);
  391. },
  392. // 失去焦点查询学号工号
  393. judgeNum() {
  394. if(!this.judgeNumber) return
  395. let opid = uni.getStorageSync('oId')
  396. let data = {
  397. txt: this.judgeNumber
  398. }
  399. this.$request('/selectStudentNumber', "Get", data).then(res => {
  400. console.log('失去焦点查询学号工号', res);
  401. if (res[0].length) {
  402. let aaa = res[0][0]
  403. if (aaa.cid !== null) {
  404. console.log('aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa');
  405. this.inpTxt = aaa.cid
  406. }
  407. if (aaa.sid !== null) {
  408. this.majorInpTxt = aaa.sid
  409. }
  410. if (aaa.department === '') {
  411. this.stuName = ''
  412. } else {
  413. this.stuName = aaa.department
  414. }
  415. if (aaa.class_name === '') {
  416. this.majorName = ''
  417. } else {
  418. this.majorName = aaa.class_name
  419. }
  420. this.userData.username = aaa.name
  421. } else {
  422. uni.showToast({
  423. title: '学号/工号暂无查询结果',
  424. icon: 'none',
  425. duration: 1000
  426. })
  427. }
  428. })
  429. },
  430. // 选择用户名称
  431. inpvalue(e) {
  432. this.nickname = e.detail.value
  433. },
  434. rankChange(e) {
  435. // console.log('picker发送选择改变,携带值为', e.detail)
  436. this.userData.rankl = this.rankList[e.detail.value]
  437. },
  438. // 上传图片
  439. onChooseAvatar(e) {
  440. // 获取上传的图片
  441. const {
  442. avatarUrl
  443. } = e.detail
  444. let that = this
  445. const uploadTask = uni.uploadFile({
  446. url: 'http://139.159.246.165:7006/img', // post请求地址
  447. // url: 'https://cxcy.ssti.net.cn/api/UploadFirmFile', // post请求地址
  448. // filePath: tempFilePaths,
  449. filePath: avatarUrl,
  450. name: 'file', // 待确认
  451. header: {
  452. // 不要写这个不然报错
  453. // 'Content-Type': 'multipart/form-data',
  454. },
  455. success: function(res) {
  456. console.log('上传图片', res);
  457. that.avatarUrl = res.data
  458. },
  459. fail: function(uploadFileFail) {
  460. console.log('Error:', uploadFileFail.data);
  461. },
  462. complete: () => {
  463. // 接口调用结束的回调函数(调用成功、失败都会执行)
  464. // console.log('Complete:');
  465. }
  466. });
  467. // this.avatarUrl = avatarUrl
  468. },
  469. // 登录
  470. gotoIndex() {
  471. if (this.avatarUrl ==
  472. 'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0'
  473. ) {
  474. uni.showToast({
  475. title: '请选择头像',
  476. icon: 'error',
  477. duration: 1000
  478. });
  479. return
  480. }
  481. if (!this.isShow) return uni.showToast({
  482. title: '请勾选条约',
  483. icon: 'error',
  484. duration: 1000
  485. });
  486. let oId = uni.getStorageSync('oId')
  487. // 判断是否登录过
  488. if (this.isLogin) {
  489. // console.log('已注册过直接登录', res[0][0]);
  490. // 修改昵称头像
  491. this.$request('/updateUser', "POST", {
  492. openid: oId,
  493. Nme: this.nickname,
  494. avatar: this.avatarUrl
  495. }).then(res => {
  496. // console.log('updateUser', res);
  497. this.$request('/selectUser', 'POST', {
  498. oId: oId,
  499. }).then(res => {
  500. console.log('已注册过直接登录', res[0]);
  501. this.$store.dispatch('asyncUpdateUser', res[0][0])
  502. uni.switchTab({
  503. url: '/pages/index/index'
  504. })
  505. })
  506. })
  507. } else {
  508. console.log('还未注册过,开始注册');
  509. this.userData.openid = oId
  510. this.userData.username = this.nickname
  511. this.userData.avatar = this.avatarUrl
  512. return this.popupShow = true
  513. }
  514. },
  515. register() {
  516. // username: '',
  517. // tel: '',
  518. // sch: '请选择',
  519. // spe: '请选择',
  520. if (!this.userData.username) return uni.showToast({
  521. title: '请输入姓名',
  522. icon: 'none'
  523. });
  524. if (!this.userData.tel) return uni.showToast({
  525. title: '请输入联系方式',
  526. icon: 'none'
  527. });
  528. if (!this.stuName) return uni.showToast({
  529. title: '请选择学校',
  530. icon: 'none'
  531. });
  532. // if (this.majorInpTxt == '') return uni.showToast({
  533. // title: '请选择专业',
  534. // icon: 'none'
  535. // });
  536. if (this.userData.tel.length != 11) return uni.showToast({
  537. title: '号码不足11位,请检查',
  538. icon: 'none'
  539. });
  540. this.userData.inpTxt = this.inpTxt
  541. this.userData.majorInpTxt = this.majorInpTxt
  542. this.userData.schName = this.stuName
  543. this.userData.jorName = this.majorName
  544. // return console.log(this.userData);
  545. let oId = uni.getStorageSync('oId')
  546. this.$request('/login', 'POST', this.userData).then(res => {
  547. console.log('注册成功', res);
  548. // 添加消息页面系统通知提示已加入会员
  549. this.addMessage()
  550. this.$request('/selectUser', 'POST', {
  551. oId: oId,
  552. }).then(res => {
  553. this.$store.dispatch('asyncUpdateUser', res[0][0])
  554. uni.switchTab({
  555. url: '/pages/index/index'
  556. })
  557. })
  558. })
  559. },
  560. // 添加消息页面系统通知提示加入会员
  561. addMessage() {
  562. let opid = uni.getStorageSync('oId')
  563. let data = {
  564. oid: opid,
  565. acid: '',
  566. type: 1,
  567. }
  568. this.$request('/insertMessage', "POST", data).then(res => {
  569. console.log(res);
  570. })
  571. },
  572. // 跳转其他登录方式
  573. goto() {
  574. uni.navigateTo({
  575. url: "/pages/login_two/login_two"
  576. })
  577. },
  578. // 勾选取消条约
  579. isDui() {
  580. this.isShow = !this.isShow
  581. },
  582. getdata() {
  583. this.$request('/selectUserInfo', "POST", {
  584. openid: uni.getStorageSync('oId')
  585. }).then(res => {
  586. console.log('获取渲染数据', res[0][0]);
  587. let data = res[0][0]
  588. console.log(data);
  589. if (!data) {
  590. return
  591. } else {
  592. this.isLogin = true
  593. this.avatarUrl = data.avatar
  594. this.nickname = data.username
  595. }
  596. })
  597. // 获取学院
  598. this.$request('/selectColleges', "get", {}).then(res => {
  599. console.log(res);
  600. this.colleges = res[0]
  601. })
  602. }
  603. },
  604. onLoad() {
  605. this.avatarUrl =
  606. 'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0';
  607. this.getdata()
  608. }
  609. }
  610. </script>
  611. <style lang="scss" scoped>
  612. .login_Wechat {
  613. width: 750rpx;
  614. height: 100vh;
  615. background-color: #ffffff;
  616. }
  617. ::v-deep .u-safe-bottom{
  618. display: none;
  619. }
  620. .typyInbtn {
  621. box-sizing: border-box;
  622. padding: 10rpx 60rpx;
  623. border-radius: 10rpx;
  624. color: #fff;
  625. background-color: #0081FE;
  626. }
  627. .typyInbtn2 {
  628. box-sizing: border-box;
  629. padding: 10rpx 20rpx;
  630. border-radius: 10rpx;
  631. display: flex;
  632. justify-content: center;
  633. align-items: center;
  634. background-color: #0081FE;
  635. color: #E7E7E7;
  636. margin-right: 20px;
  637. }
  638. .shade {
  639. position: absolute;
  640. top: 0;
  641. left: 0;
  642. width: 100%;
  643. height: 100%;
  644. // background-color: #0056a8;
  645. z-index: 12;
  646. }
  647. .uni-input {
  648. text-align: right;
  649. }
  650. .stuListSty {
  651. position: absolute;
  652. top: calc(100% + 15rpx);
  653. right: -20rpx;
  654. display: flex;
  655. flex-direction: column;
  656. justify-content: center;
  657. z-index: 12;
  658. background-color: #fff;
  659. border-radius: 20rpx;
  660. box-shadow: 0 0 20rpx 0 #ccc;
  661. padding: 30rpx;
  662. padding-top: 10rpx;
  663. .Usearch {
  664. margin: 20rpx 0;
  665. // background-color: #0056a8;
  666. width: 100%;
  667. display: flex;
  668. align-items: center;
  669. justify-content: flex-start;
  670. .UsearchBtn {
  671. width: 130rpx;
  672. flex-shrink: 0;
  673. display: flex;
  674. justify-content: center;
  675. align-items: center;
  676. // background-color: #0056a8;
  677. // color: #fff;
  678. }
  679. }
  680. }
  681. .list {
  682. position: relative;
  683. // top: calc(100% + 15rpx);
  684. // right: -20rpx;
  685. width: 550rpx;
  686. height: 600rpx;
  687. display: flex;
  688. flex-direction: column;
  689. background-color: #fff;
  690. // padding: 10rpx 15rpx;
  691. border-radius: 20rpx;
  692. // box-shadow: 0 0 20rpx 0 #ccc;
  693. z-index: 11;
  694. .listcon {
  695. width: 100%;
  696. padding: 20rpx 0;
  697. font-size: 28rpx;
  698. border-bottom: 1rpx #e7e7e7 solid;
  699. }
  700. }
  701. .dian {
  702. color: rgba(245, 69, 69, 1);
  703. }
  704. .celTit {
  705. color: rgba(0, 0, 0, 0.8);
  706. }
  707. .icooo {
  708. transform: translate(0, 5rpx);
  709. }
  710. .block {
  711. width: 750rpx;
  712. height: 30vh;
  713. display: flex;
  714. justify-content: center;
  715. align-items: center;
  716. }
  717. .footer {
  718. display: flex;
  719. justify-content: center;
  720. font-size: 28rpx;
  721. margin: auto;
  722. color: #666666;
  723. }
  724. .avatar-wrapper {
  725. width: 200rpx;
  726. height: 200rpx;
  727. padding: 0;
  728. image {
  729. width: 200rpx;
  730. height: 200rpx;
  731. }
  732. }
  733. .inp {
  734. display: flex;
  735. align-items: center;
  736. padding: 0rpx 50rpx;
  737. .nc {
  738. // width: 150rpx;
  739. text-align: left;
  740. }
  741. .weui-input {}
  742. }
  743. .mid {
  744. display: flex;
  745. justify-content: flex-start;
  746. width: 750rpx;
  747. padding: 0rpx 50rpx;
  748. font-size: 13px;
  749. margin-top: 80rpx;
  750. .quan {
  751. position: absolute;
  752. flex-shrink: 0;
  753. top: 0;
  754. left: -10rpx;
  755. width: 32rpx;
  756. height: 32rpx;
  757. border-radius: 50%;
  758. margin-top: 5rpx;
  759. margin-right: 10rpx;
  760. border: 1px #bdbdbd solid;
  761. display: flex;
  762. justify-content: center;
  763. align-items: center;
  764. .dui {
  765. width: 32rpx;
  766. height: 32rpx;
  767. }
  768. }
  769. text {
  770. color: #4a97f2;
  771. }
  772. }
  773. .btn {
  774. background-color: #0056a8;
  775. color: #ffffff;
  776. border-radius: 30px;
  777. margin: 30rpx 55rpx;
  778. // padding: 10rpx 0;
  779. display: flex;
  780. align-items: center;
  781. justify-content: center;
  782. margin-top: 30rpx;
  783. // padding: 0rpx 10rpx;
  784. font-size: 16px;
  785. }
  786. .popupBlock {
  787. position: absolute;
  788. left: 0;
  789. top: 0;
  790. width: 750rpx;
  791. height: 100vh;
  792. background-color: rgba(0, 0, 0, 0.6);
  793. display: flex;
  794. justify-content: center;
  795. align-items: center;
  796. z-index: 10;
  797. .pop {
  798. width: 690rpx;
  799. height: 936rpx;
  800. background-color: #ffffff;
  801. border-radius: 30rpx;
  802. padding: 30rpx;
  803. .poptit {
  804. text-align: center;
  805. height: 48rpx;
  806. line-height: 48rpx;
  807. color: rgba(0, 0, 0, 0.88);
  808. }
  809. .infoTxt {
  810. width: 100%;
  811. height: 448rpx;
  812. margin-top: 40rpx;
  813. margin-bottom: 40rpx;
  814. display: flex;
  815. flex-direction: column;
  816. justify-content: space-between;
  817. .txtcell {
  818. display: flex;
  819. justify-content: space-between;
  820. align-items: center;
  821. border-bottom: 1rpx rgba(231, 231, 231, 1) solid;
  822. padding-bottom: 10rpx;
  823. margin-bottom: 20px;
  824. .inpSty {
  825. right: 0;
  826. bottom: 0;
  827. text-align: right;
  828. }
  829. .pickerBlock {
  830. flex: 1;
  831. display: flex;
  832. justify-content: flex-end;
  833. color: rgba(0, 0, 0, 0.4);
  834. // .uni-input {
  835. // width: 100%;
  836. // height: 100%;
  837. // }
  838. }
  839. }
  840. }
  841. .logbtn2 {
  842. background-color: rgba(0, 86, 168, 1);
  843. width: 580rpx;
  844. height: 88rpx;
  845. border-radius: 60rpx;
  846. display: flex;
  847. justify-content: center;
  848. align-items: center;
  849. color: #fff;
  850. font-size: 36rpx;
  851. margin: 150rpx auto;
  852. margin-bottom: 30rpx;
  853. }
  854. .logbtn {
  855. width: 580rpx;
  856. height: 88rpx;
  857. border-radius: 60rpx;
  858. display: flex;
  859. justify-content: center;
  860. align-items: center;
  861. color: #fff;
  862. font-size: 36rpx;
  863. background-color: rgba(139, 190, 255, 1);
  864. margin: 150rpx auto;
  865. margin-bottom: 30rpx;
  866. }
  867. .logbri {
  868. width: 580rpx;
  869. margin: auto;
  870. text-align: center;
  871. font-size: 24rpx;
  872. color: rgba(48, 129, 232, 1);
  873. }
  874. }
  875. }
  876. </style>