Auth.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. <template><page-meta :root-font-size="fontSize+'px'"></page-meta>
  2. <member-base :show="false"><view class="div member-auth">
  3. <view class="div common-header-wrap">
  4. <view :style="'height:'+navHeight+'px'"></view>
  5. <view class="common-header-holder"></view>
  6. <view class="common-header-fixed">
  7. <title-header />
  8. <uni-nav-bar title="实名认证" class="common-header" left-icon="back" @clickLeft="goBack()">
  9. </uni-nav-bar>
  10. </view>
  11. </view>
  12. <view class="div form main-content">
  13. <view class="div form-wrapper">
  14. <flex-line v-if="user.member_auth_state!=1 && user.member_auth_state!=3" class="field-line menu-item" :show-border="true"><text class="span field-name">真实姓名:</text><view class="div field-line-right" slot="right"><input class="field-input" v-model="realname" /></view></flex-line>
  15. <flex-line v-else :show-border="true"><text class="span line-name">真实姓名:</text><text class="span" slot="right">{{realname}}</text></flex-line>
  16. <flex-line v-if="user.member_auth_state!=1 && user.member_auth_state!=3" class="field-line menu-item" :show-border="true"><text class="span field-name">身份证号:</text><view class="div field-line-right" slot="right"><input class="field-input" v-model="idcard" /></view></flex-line>
  17. <flex-line v-else :show-border="true"><text class="span line-name">身份证号:</text><text class="span" slot="right">{{idcard}}</text></flex-line>
  18. </view>
  19. <view class="div idcard-wrapper pt-10">
  20. <view class="div title">手持身份证照片</view>
  21. <view class="div idcard-item">
  22. <view class="div img">
  23. <view class="div user-avatar">
  24. <uni-file-picker
  25. class="common-avatar"
  26. v-model="imageValue['member_idcard_image1']"
  27. fileMediatype="image"
  28. mode="grid"
  29. :readonly="user.member_auth_state==1 || user.member_auth_state==3"
  30. :limit="1"
  31. :auto-upload="false"
  32. :image-styles="{
  33. width:'200px',
  34. height:'160px',
  35. }"
  36. @select="uploadInformPic('member_idcard_image1',$event)"
  37. @delete="dropImage('member_idcard_image1')"
  38. >
  39. </uni-file-picker>
  40. </view>
  41. </view>
  42. </view>
  43. <view class="div title">身份证正面照片</view>
  44. <view class="div idcard-item">
  45. <view class="div img">
  46. <view class="div user-avatar">
  47. <uni-file-picker
  48. class="common-avatar"
  49. v-model="imageValue['member_idcard_image2']"
  50. fileMediatype="image"
  51. mode="grid"
  52. :readonly="user.member_auth_state==1 || user.member_auth_state==3"
  53. :limit="1"
  54. :auto-upload="false"
  55. :image-styles="{
  56. width:'200px',
  57. height:'160px',
  58. }"
  59. @select="uploadInformPic('member_idcard_image2',$event)"
  60. @delete="dropImage('member_idcard_image2')"
  61. >
  62. </uni-file-picker>
  63. </view>
  64. </view>
  65. </view>
  66. <view class="div title">身份证反面照片</view>
  67. <view class="div idcard-item">
  68. <view class="div img">
  69. <view class="div user-avatar">
  70. <uni-file-picker
  71. class="common-avatar"
  72. v-model="imageValue['member_idcard_image3']"
  73. fileMediatype="image"
  74. mode="grid"
  75. :readonly="user.member_auth_state==1 || user.member_auth_state==3"
  76. :limit="1"
  77. :auto-upload="false"
  78. :image-styles="{
  79. width:'200px',
  80. height:'160px',
  81. }"
  82. @select="uploadInformPic('member_idcard_image3',$event)"
  83. @delete="dropImage('member_idcard_image3')"
  84. >
  85. </uni-file-picker>
  86. </view>
  87. </view>
  88. </view>
  89. </view>
  90. <view class="div pb-10 pt-10">
  91. <view class="div common-btn ds-button-large" @click="submitInformation" v-if="user.member_auth_state!=1 && user.member_auth_state!=3">保存</view>
  92. </view>
  93. </view>
  94. <uni-popup background-color="#fff" ref="isshow" class="popup" >
  95. <image mode="aspectFit" class="img" :src="showimage" :style="getBannerStyle" @click="hidePopup('isshow')">
  96. </uni-popup>
  97. <tui-picture-cropper v-if="cropperOption.imgUrl" :width="cropperOption.autoCropWidth" :height="cropperOption.autoCropHeight" :imageUrl="cropperOption.img" @ready="cropReady" @cropper="useCrop" @back="cropBack"></tui-picture-cropper>
  98. </view>
  99. <uni-popup background-color="#fff" ref="confirm" type="dialog">
  100. <uni-popup-dialog :mode="dialog.mode" :title="dialog.title" :content="dialog.content" :placeholder="dialog.content" @confirm="confirmDialog" @close="closeDialog"></uni-popup-dialog>
  101. </uni-popup>
  102. </member-base>
  103. </template>
  104. <script>
  105. import {getFontSize} from '@/util/common'
  106. import TitleHeader from '../../TitleHeader'
  107. import MemberBase from '../MemberBase'
  108. import tuiPictureCropper from "@/components/thorui/tui-picture-cropper/tui-picture-cropper"
  109. import { mapState, mapMutations } from 'vuex'
  110. import { uploadAuth, dropAuth, updateMemberAuth } from '../../../api/member'
  111. import flexLine from '../../flexLine'
  112. export default {
  113. name:'MemberProfileSet',
  114. data(){
  115. return {
  116. navHeight: 0,
  117. imageValue:{},
  118. dialog:{},
  119. screenWidth:0,
  120. screenHeight:0,
  121. cropperOption: {
  122. img: '',
  123. canMove: false,
  124. autoCrop: true,
  125. autoCropWidth: 100,
  126. autoCropHeight: 100,
  127. maxImgSize: 500,
  128. outputType: 'png'
  129. },
  130. cropType: '',
  131. if_confirm: false,
  132. showimage: '',
  133. realname: '',
  134. idcard: '',
  135. member_ww: ''
  136. }
  137. },
  138. mounted(){
  139. // #ifdef MP-WEIXIN
  140. this.navHeight = uni.getMenuButtonBoundingClientRect().height
  141. // #endif
  142. const res = uni.getSystemInfoSync()
  143. this.screenWidth = res.windowWidth
  144. this.screenHeight = res.windowHeight
  145. },
  146. components:{
  147. TitleHeader,
  148. MemberBase,
  149. flexLine,
  150. tuiPictureCropper
  151. },
  152. computed:{
  153. fontSize(){
  154. return getFontSize()
  155. },
  156. ...mapState({
  157. user: state => state.member.info
  158. }),
  159. getBannerStyle: function () {
  160. var width = this.screenWidth
  161. var height = this.screenHeight
  162. let itemWidth = width
  163. let itemHeight = height
  164. return "max-width:"+itemWidth +"px;max-height:"+itemHeight +"px"
  165. }
  166. },
  167. created: function () {
  168. if (this.user) {
  169. this.realname = this.user.member_truename
  170. this.idcard = this.user.member_idcard
  171. if(this.user.member_idcard_image1_url){
  172. this.imageValue['member_idcard_image1']=[{
  173. name:'member_idcard_image1',
  174. extname:'jpg',
  175. url:this.user.member_idcard_image1_url
  176. }]
  177. }
  178. if(this.user.member_idcard_image2_url){
  179. this.imageValue['member_idcard_image2']=[{
  180. name:'member_idcard_image2',
  181. extname:'jpg',
  182. url:this.user.member_idcard_image2_url
  183. }]
  184. }
  185. if(this.user.member_idcard_image3_url){
  186. this.imageValue['member_idcard_image3']=[{
  187. name:'member_idcard_image3',
  188. extname:'jpg',
  189. url:this.user.member_idcard_image3_url
  190. }]
  191. }
  192. }
  193. },
  194. methods:{
  195. closeDialog(){
  196. },
  197. confirmDialog(value){
  198. switch(this.dialog.condition){
  199. case 1:
  200. this.confirmSumit()
  201. break
  202. case 2:
  203. dropAuth(this.dialog.data).then(res => {
  204. this.user[this.dialog.data + '_url'] = ''
  205. var temp = {}
  206. temp[this.dialog.data + '_url'] = ''
  207. this.memberEdit(temp)
  208. }).catch(function (error) {
  209. uni.showToast({icon:'none',title: error.message})
  210. })
  211. break
  212. }
  213. },
  214. showPopup(id){
  215. this.$refs[id].open()
  216. },
  217. hidePopup(id){
  218. this.$refs[id].close()
  219. },
  220. goBack(){uni.navigateBack({delta:1})},
  221. ...mapMutations({
  222. memberEdit: 'memberEdit'
  223. }),
  224. submitInformation () {
  225. if (!this.if_confirm) {
  226. this.confirmSumit()
  227. return
  228. }
  229. this.dialog={condition:1,content:'请仔细核对信息,确认上传后除非管理员审核否则无法再次上传'}
  230. this.$refs.confirm.open()
  231. },
  232. confirmSumit () {
  233. updateMemberAuth(this.realname, this.idcard, this.if_confirm).then(res => {
  234. if (this.if_confirm) {
  235. this.memberEdit({ member_truename: this.realname, member_idcard: this.idcard, member_auth_state: 1 })
  236. uni.showToast({icon:'none',title: res.message})
  237. } else {
  238. this.if_confirm = true
  239. this.submitInformation()
  240. }
  241. }).catch(function (error) {
  242. uni.showToast({icon:'none',title: error.message})
  243. })
  244. },
  245. openImage (src) {
  246. this.showimage = src
  247. this.showPopup('isshow')
  248. },
  249. dropImage (id) {
  250. this.dialog={content:'确定要删除该图片吗?',data:id}
  251. this.$refs.confirm.open()
  252. },
  253. useCrop (res) {
  254. let index = this.cropType
  255. var formdata={
  256. filePath:res.url,
  257. name:index,
  258. id:index
  259. }
  260. uploadAuth(formdata).then(res => {
  261. this.user[index + '_url'] = res.result.file_path
  262. this.imageValue[index]=[{
  263. name:index,
  264. extname:'jpg',
  265. url:res.result.file_path
  266. }]
  267. var temp = {}
  268. temp[index + '_url'] = res.result.file_path
  269. this.memberEdit(temp)
  270. this.cropperOption.imgUrl=''
  271. this.$forceUpdate()
  272. uni.hideLoading()
  273. }).catch(function (error) {
  274. uni.showToast({icon:'none',title: error.message})
  275. uni.hideLoading()
  276. this.cropperOption.imgUrl=''
  277. this.$forceUpdate()
  278. })
  279. },
  280. cropReady(){
  281. this.cropperOption.img = this.cropperOption.imgUrl
  282. },
  283. cropBack(){
  284. this.cropperOption.imgUrl=''
  285. this.$forceUpdate()
  286. },
  287. uploadInformPic (index, event) {
  288. let that = this
  289. this.cropType = index
  290. let file = event.tempFiles[0]
  291. that.cropperOption.imgUrl = file.path
  292. that.cropperOption.autoCropWidth = uni.getSystemInfoSync().windowWidth
  293. that.cropperOption.autoCropHeight = uni.getSystemInfoSync().windowWidth
  294. that.cropperOption.maxImgSize = uni.getSystemInfoSync().windowHeight - 40
  295. that.$forceUpdate()
  296. }
  297. }
  298. }
  299. </script>
  300. <style lang="scss" scoped>
  301. .common-header{
  302. .btn{background: #000;color: #fff;box-shadow: 0px 2px 4px #d2d2d2;}
  303. }
  304. .ds-button-large{margin:0 $pageSpace}
  305. .member-auth {
  306. background: #fff;
  307. .main-content{padding: 0 $pageSpace;box-sizing: border-box;}
  308. .form{
  309. .form-wrapper{
  310. position: relative;
  311. box-shadow: 0px 4px 4px #f7f7f7;
  312. z-index: 2;
  313. }
  314. .title{
  315. font-size:$subFontSize;
  316. font-weight: 700;
  317. }
  318. }
  319. .idcard-wrapper{
  320. .idcard-item{
  321. background: #fff;
  322. padding: 1rem 0;
  323. .del-btn{
  324. position: absolute;
  325. font-size: 1.5rem;
  326. top: -.75rem;
  327. right: -.75rem;
  328. }
  329. }
  330. }
  331. }
  332. </style>
  333. <style lang="scss">
  334. .member-auth .mint-cell-title{flex:unset;width:7rem}
  335. .member-auth .mint-cell-value{flex:1}
  336. </style>