workerEnter.vue 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599
  1. <template>
  2. <zj-page-layout :hasFooter="true">
  3. <template slot="header">
  4. <view class="mode">
  5. <view class="content">
  6. <!-- ----------------------------------------------------------------- -->
  7. <view class="mokuaikapian">
  8. <view class="mokuaineirongquyu">
  9. <h3>联系信息</h3>
  10. <view class="item flex">
  11. <view class="required">入驻网点</view>
  12. <view class="flex" style="flex: 1">
  13. <input
  14. type="text"
  15. style="pointer-events: none"
  16. readonly="readonly"
  17. :value="websitName"
  18. placeholder="请选择入驻网点"
  19. />
  20. <image src="/static/mine/workerEnter/right.png" mode="aspectFill"></image>
  21. </view>
  22. </view>
  23. <view class="item flex">
  24. <view class="required">姓名</view>
  25. <view class="flex" style="flex: 1">
  26. <input v-model="name" type="text" placeholder="请输入姓名" />
  27. </view>
  28. </view>
  29. <view class="item flex">
  30. <view class="">银行卡号</view>
  31. <view class="flex" style="flex: 1">
  32. <input v-model="bankAccount" maxlength="18" type="text" placeholder="请输入银行卡号" />
  33. </view>
  34. </view>
  35. </view>
  36. </view>
  37. <!-- ----------------------------------------------------------------- -->
  38. <view class="mokuaikapian">
  39. <view class="mokuaineirongquyu">
  40. <h3>身份证信息</h3>
  41. <view class="item">
  42. <view class="imgs" @tap="toChooseImg('idCardImg')">
  43. <image
  44. class="del"
  45. @tap.stop="idCardImg = ''"
  46. v-show="idCardImg"
  47. src="/static/mine/workerEnter/del.png"
  48. mode="aspectFill"
  49. ></image>
  50. <image
  51. id="img"
  52. v-if="idCardImg"
  53. :src="idCardImg"
  54. mode="aspectFill"
  55. @tap.stop="previewImage(idCardImg)"
  56. ></image>
  57. <view v-else class="addimg">
  58. <image src="/static/mine/workerEnter/camera.png" mode="aspectFit"></image>
  59. </view>
  60. <view class="text required">身份证正面</view>
  61. </view>
  62. </view>
  63. <view class="item flex">
  64. <view class="required">身份证号</view>
  65. <view class="flex" style="flex: 1">
  66. <input v-model="idcard" maxlength="18" type="text" placeholder="请输入身份证号" />
  67. </view>
  68. </view>
  69. </view>
  70. </view>
  71. <!-- ----------------------------------------------------------------- -->
  72. <view class="mokuaikapian">
  73. <view class="mokuaineirongquyu">
  74. <h3>高空证信息</h3>
  75. <view class="item" v-for="(item, index) in imgList" :key="index">
  76. <view class="imgs" @tap="toChooseImg1(index)">
  77. <image
  78. class="del"
  79. @tap.stop="item.imgUrl = ''"
  80. v-show="item.imgUrl"
  81. src="/static/mine/workerEnter/del.png"
  82. mode="aspectFill"
  83. ></image>
  84. <image
  85. id="img"
  86. v-if="item.imgUrl"
  87. :src="item.imgUrl"
  88. mode="aspectFill"
  89. @tap.stop="previewImage(item.imgUrl)"
  90. ></image>
  91. <view v-else class="addimg">
  92. <image src="/static/mine/workerEnter/camera.png" mode="aspectFit"></image>
  93. </view>
  94. <view class="text required">{{ item.dictValue }}</view>
  95. </view>
  96. </view>
  97. <view class="zhu">注意:支持PNG、JPG、JPEG,每张大小不可超过1M</view>
  98. </view>
  99. </view>
  100. <!-- ----------------------------------------------------------------- -->
  101. <view class="mokuaikapian">
  102. <view class="mokuaineirongquyu">
  103. <h3>意外险信息</h3>
  104. <view class="item flex">
  105. <view class="required">保险公司名称</view>
  106. <view class="flex" style="flex: 1">
  107. <input v-model="name" type="text" placeholder="请输入姓名" />
  108. </view>
  109. </view>
  110. <view class="item flex">
  111. <view class="">保单名称</view>
  112. <view class="flex" style="flex: 1">
  113. <input v-model="bankAccount" maxlength="18" type="text" placeholder="请输入银行卡号" />
  114. </view>
  115. </view>
  116. <view class="item flex">
  117. <view class="">保险单号</view>
  118. <view class="flex" style="flex: 1">
  119. <input v-model="bankAccount" maxlength="18" type="text" placeholder="请输入银行卡号" />
  120. </view>
  121. </view>
  122. <view class="mt30 image-container">
  123. <view class="common-title">上传图片(最多3张)</view>
  124. <view class="images">
  125. <block v-for="(item, index) in imageList" :key="index">
  126. <view class="img">
  127. <image :src="item.url" mode="aspectFill" @tap="prevImg(item.url)"></image>
  128. <text class="iconfont icon-guanbi1" @tap="delImage(index)"></text>
  129. </view>
  130. </block>
  131. <view class="add" @tap="addImage" v-if="imageList.length < 3">
  132. <text class="iconfont icon-xiangji"></text>
  133. <text class="text">添加图片</text>
  134. </view>
  135. </view>
  136. </view>
  137. </view>
  138. </view>
  139. <!-- ----------------------------------------------------------------- -->
  140. </view>
  141. </view>
  142. <zjDialogPicker
  143. ref="websitDialog"
  144. :isShow="isShowWebsitDialog"
  145. :multiple="false"
  146. :styleType="2"
  147. :title="'入驻网点'"
  148. :list="websitList"
  149. :keyName="'name'"
  150. @cancel="isShowWebsitDialog = false"
  151. @confirm="confirmWebsitDialog"
  152. >
  153. </zjDialogPicker>
  154. </template>
  155. <template slot="footer">
  156. <view class="flex xieyi">
  157. <image
  158. :src="isChecked ? '/static/mine/workerEnter/them_check.png' : '/static/mine/workerEnter/gray_uncheck.png'"
  159. mode=""
  160. @tap.stop="isChecked = !isChecked"
  161. ></image>
  162. <view class="">我已阅读并同意</view>
  163. <view class="notification" @tap="navToPage('/packageMine/pages/agreement?type=3')">《服务协议》</view>
  164. </view>
  165. <view class="btn" @click="submit()">提交审核</view>
  166. </template>
  167. </zj-page-layout>
  168. </template>
  169. <script>
  170. import { uploadImgFull } from '@/common/utils/util.js'
  171. import zjDialogPicker from '@/components/zj-dialog/zj-dialog-picker.vue'
  172. import verify from '@/common/utils/verify.js'
  173. export default {
  174. components: {
  175. zjDialogPicker
  176. },
  177. data() {
  178. return {
  179. isShowWebsitDialog: false,
  180. isChecked: false,
  181. websitList: [],
  182. websitName: '',
  183. websitId: '',
  184. name: '',
  185. bankAccount: '',
  186. idcard: '',
  187. idCardImg: '',
  188. imageUrl: this.$imageUrl,
  189. imgList: [],
  190. imageList: [] //上传的文件数据
  191. }
  192. },
  193. onLoad({ websitId, websitName }) {
  194. if (websitId) {
  195. this.websitId = websitId
  196. this.websitName = websitName
  197. }
  198. this.getUser()
  199. this.getImageList()
  200. },
  201. computed: {},
  202. methods: {
  203. // 添加图片
  204. async addImage() {
  205. uni.chooseImage({
  206. count: 6 - this.imageList.length,
  207. success: res => {
  208. uni.showLoading()
  209. res.tempFilePaths.forEach(async item => {
  210. let data = await uploadImgFull(item)
  211. this.imageList.push(data)
  212. })
  213. uni.hideLoading()
  214. },
  215. fail: err => {}
  216. })
  217. },
  218. // 删除图片
  219. delImage(index) {
  220. this.imageList.splice(index, 1)
  221. },
  222. //预览图片
  223. prevImg(current) {
  224. uni.previewImage({
  225. current,
  226. urls: this.imageList.map(item => {
  227. return item.url
  228. })
  229. })
  230. },
  231. getWebsit() {
  232. this.$api
  233. .get('/user/apply/websit', {
  234. pageNum: 1,
  235. pageSize: -1,
  236. status: 'ON'
  237. })
  238. .then(res => {
  239. this.websitList = res.data
  240. })
  241. },
  242. getImageList() {
  243. this.$api
  244. .post('/pay/sysDict', {
  245. dictType: 'WORKER_IMG'
  246. })
  247. .then(res => {
  248. res.data.filter(item => {
  249. return (item.imgUrl = '')
  250. })
  251. this.imgList = res.data
  252. })
  253. },
  254. getUser() {
  255. this.$api
  256. .get('/user/user/detail', {
  257. userId: this.$store.state.user.userId
  258. })
  259. .then(res => {
  260. this.idcard = res.data.idCard
  261. this.idCardImg = res.data.idCardImg
  262. // this.name = res.data.nickName
  263. })
  264. },
  265. openWebsit() {
  266. this.isShowWebsitDialog = true
  267. },
  268. confirmWebsitDialog(e) {
  269. this.websitId = this.websitList[e[0]].websitId
  270. this.websitName = this.websitList[e[0]].name
  271. this.isShowWebsitDialog = false
  272. },
  273. // 选择图片
  274. async toChooseImg(type) {
  275. uni.chooseImage({
  276. count: 1,
  277. sizeType: ['compressed'],
  278. success: res => {
  279. this.uploadImage(res.tempFilePaths[0], type)
  280. },
  281. fail: err => {
  282. console.log(err)
  283. }
  284. })
  285. },
  286. // 上传文件
  287. async uploadImage(file, type) {
  288. let data = await uploadImgFull(file)
  289. uni.hideLoading()
  290. this[type] = data.url
  291. },
  292. async toChooseImg1(index) {
  293. uni.chooseImage({
  294. count: 1,
  295. sizeType: ['compressed'],
  296. success: res => {
  297. this.uploadImage1(res.tempFilePaths[0], index)
  298. },
  299. fail: err => {
  300. console.log(err)
  301. }
  302. })
  303. },
  304. async uploadImage1(file, index) {
  305. let data = await uploadImgFull(file)
  306. uni.hideLoading()
  307. this.imgList[index].imgUrl = data.url
  308. },
  309. // 预览图片
  310. previewImage(url) {
  311. uni.previewImage({
  312. current: url,
  313. urls: [url]
  314. })
  315. },
  316. async checkForm() {
  317. if (!this.websitId) {
  318. this.$tips('请选择入驻网点!')
  319. return true
  320. }
  321. if (!this.name) {
  322. this.$tips('请输入姓名!')
  323. return true
  324. } else if (!this.idcard) {
  325. this.$tips('请输入身份证号码!')
  326. return true
  327. } else if (!verify.isIdCard(this.idcard)) {
  328. this.$tips('身份证号码格式不正确,请输入正确身份证号码!')
  329. return true
  330. } else if (!this.idCardImg) {
  331. this.$tips('请上传身份证正面照!')
  332. return true
  333. }
  334. },
  335. async submit() {
  336. const that = this
  337. let is_save = await this.checkForm()
  338. let workerImgs = []
  339. for (var i = 0; i < this.imgList.length; i++) {
  340. if (!this.imgList[i].imgUrl) {
  341. return this.$tips('请上传' + this.imgList[i].dictValue + '!')
  342. break
  343. } else {
  344. workerImgs.push({
  345. imgName: this.imgList[i].dictValue,
  346. imgUrl: this.imgList[i].imgUrl
  347. })
  348. }
  349. }
  350. if (!is_save) {
  351. if (!this.isChecked) {
  352. this.$tips('请先阅读并同意服务协议!')
  353. return false
  354. }
  355. this.$api
  356. .postJson(
  357. '/user/apply',
  358. {
  359. idCard: this.idcard,
  360. idCardImg: this.idCardImg,
  361. name: this.name,
  362. bankAccount: this.bankAccount,
  363. type: 'WORKER',
  364. websitId: this.websitId,
  365. workerImgs
  366. },
  367. true,
  368. true,
  369. true
  370. )
  371. .then(res => {
  372. if (res.code == 200) {
  373. this.$toast('提交审核成功!')
  374. setTimeout(() => {
  375. this.$navToPage(
  376. {
  377. delta: 1
  378. },
  379. 'navigateBack'
  380. )
  381. }, 1500)
  382. } else {
  383. this.$tips(res.msg)
  384. }
  385. })
  386. }
  387. },
  388. navToPage(url) {
  389. this.$navToPage({
  390. url
  391. })
  392. }
  393. }
  394. }
  395. </script>
  396. <style lang="scss" scoped>
  397. .image-container {
  398. background: #ffffff;
  399. .images {
  400. display: flex;
  401. flex-wrap: wrap;
  402. .add {
  403. display: flex;
  404. flex-direction: column;
  405. align-items: center;
  406. justify-content: center;
  407. width: 146rpx;
  408. height: 146rpx;
  409. border: 2rpx dashed #dadada;
  410. border-radius: 10rpx;
  411. margin-top: 20rpx;
  412. .iconfont {
  413. font-size: 48rpx;
  414. color: #999999;
  415. }
  416. .text {
  417. font-size: 24rpx;
  418. color: #999999;
  419. margin-top: 10rpx;
  420. }
  421. }
  422. .img {
  423. position: relative;
  424. margin-right: 40rpx;
  425. margin-top: 20rpx;
  426. &:nth-child(4n) {
  427. margin-right: 0;
  428. }
  429. image {
  430. width: 150rpx;
  431. height: 150rpx;
  432. border-radius: 10rpx;
  433. overflow: hidden;
  434. display: block;
  435. }
  436. text {
  437. position: absolute;
  438. right: -10rpx;
  439. top: -10rpx;
  440. width: 40rpx;
  441. height: 40rpx;
  442. border-radius: 50%;
  443. background: #ff3f42;
  444. font-size: 24rpx;
  445. color: #ffffff;
  446. text-align: center;
  447. line-height: 40rpx;
  448. display: block;
  449. }
  450. }
  451. }
  452. }
  453. .app-container {
  454. height: auto !important;
  455. }
  456. .mokuaikapian {
  457. width: 100%;
  458. height: auto;
  459. box-sizing: border-box;
  460. margin-bottom: 40rpx;
  461. .mokuaineirongquyu {
  462. width: 100%;
  463. height: auto;
  464. background-color: #ffffff;
  465. padding: 30rpx;
  466. box-sizing: border-box;
  467. border-radius: 20rpx;
  468. }
  469. }
  470. .flex {
  471. display: flex;
  472. align-items: center;
  473. }
  474. .flex_asb {
  475. display: flex;
  476. justify-content: space-between;
  477. align-items: center;
  478. }
  479. .mode {
  480. padding: 40rpx 30rpx;
  481. box-sizing: border-box;
  482. h3 {
  483. margin-bottom: 60rpx;
  484. }
  485. .required:before {
  486. content: '*';
  487. color: #ff0000;
  488. }
  489. .item {
  490. width: 100%;
  491. padding: 20rpx 0;
  492. box-sizing: border-box;
  493. margin-bottom: 30rpx;
  494. border-bottom: 1rpx solid #eeeeee;
  495. box-sizing: border-box;
  496. input {
  497. flex: 1;
  498. text-align: right;
  499. padding: 0 20rpx;
  500. }
  501. image {
  502. width: 32rpx;
  503. height: 32rpx;
  504. }
  505. }
  506. }
  507. .imgs {
  508. text-align: center;
  509. position: relative;
  510. #img {
  511. width: 100%;
  512. height: 320rpx;
  513. padding: 30rpx 0;
  514. }
  515. .addimg {
  516. width: 100%;
  517. height: 320rpx;
  518. border: 1rpx solid #eeeeee;
  519. border-radius: 10rpx;
  520. display: flex;
  521. justify-content: center;
  522. align-items: center;
  523. padding: 30rpx 0;
  524. image {
  525. width: 64rpx;
  526. height: 64rpx;
  527. }
  528. }
  529. .text {
  530. color: #999999;
  531. }
  532. .del {
  533. width: 38rpx !important;
  534. height: 38rpx !important;
  535. position: absolute;
  536. right: -14rpx;
  537. top: 8rpx;
  538. z-index: 9;
  539. }
  540. }
  541. .zhu {
  542. margin-top: 30rpx;
  543. color: #ffa700;
  544. }
  545. .btn {
  546. width: 690rpx;
  547. height: 80rpx;
  548. background-color: #0379ff;
  549. color: #ffffff;
  550. text-align: center;
  551. line-height: 80rpx;
  552. border-radius: 40rpx;
  553. margin: 0 auto;
  554. margin-bottom: 20rpx;
  555. }
  556. .notification {
  557. color: #0379ff;
  558. }
  559. .xieyi {
  560. padding: 30rpx;
  561. font-size: 28rpx;
  562. image {
  563. border: 2rpx #00bfff;
  564. border-radius: 50%;
  565. height: 40rpx;
  566. width: 40rpx;
  567. vertical-align: sub;
  568. margin-right: 30rpx;
  569. }
  570. }
  571. </style>