123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420 |
- <template>
- <view class="container">
- <image-cropper :link="tempFilePath" @confirm="confirm" @cancel="cancel"></image-cropper>
- <TopBar></TopBar>
- <uni-popup ref="popup" type="bottom" :is-mask-click="false">
- <view class="popup" @touchmove.prevent>
- <view class="p-title-box flex-between">
- <view class="p-title font36 fw600">
- 上传头像
- </view>
- <image :src="`${assetsUrl}info-figure-close.png`" mode="aspectFill" class="p-close" @click="hideHeadPopup"></image>
- </view>
- <view class="p-title-tip font28 fw400">
- 上传清晰本人照片更容易交到好友哦
- </view>
- <view class="p-img-box flex-between">
- <view class="p-img">
- <image :src="`${assetsUrl}info-figure-img1.png`" mode="aspectFill" class="img"></image>
- <view class="p-text font22 fw400">
- 五官清晰
- </view>
- </view>
- <view class="p-img">
- <image :src="`${assetsUrl}info-figure-img2.png`" mode="aspectFill" class="img"></image>
- <view class="p-text font22 fw400">
- 半身照
- </view>
- </view>
- <view class="p-img">
- <image :src="`${assetsUrl}info-figure-img3.png`" mode="aspectFill" class="img"></image>
- <view class="p-text font22 fw400">
- 风景和人
- </view>
- </view>
- </view>
- <view style="height: 60rpx;">
-
- </view>
- </view>
-
- </uni-popup>
- <view class="line-bar flex-between">
- <view class="span active"></view>
- <view class="span active"></view>
- <view class="span"></view>
- <view class="span"></view>
- <view class="span"></view>
- </view>
- <view class="title font44 fw600">
- 设置你的社交形象
- </view>
- <view class="tip font28 fw400">
- 展示你的真实一面,给大家留一个好印象
- </view>
- <view class="head-info" @click="showHeadPopup">
- <view class="head-box flex-center">
- <view class="head-inner flex-center" v-if="cropFilePath===''">
- <image :src="`${assetsUrl}info-figure-add.png`" mode="aspectFill" class="add"></image>
- </view>
- <image :src="cropFilePath" mode="aspectFit" v-else></image>
- </view>
- <image :src="`${assetsUrl}info-figure-camera.png`" mode="aspectFill" class="camera"></image>
- </view>
- <view class="label-box flex-between">
- <view class="left font28 fw400">
- 昵称
- </view>
- <view class="right flex-center" @click="randNick">
- <view class="rand-btn flex-center">
- <image :src="`${assetsUrl}info-figure-tou.png`" mode="aspectFill" class="rand"></image>
- <view class="rand-text font20 fw400">
- 随机昵称
- </view>
- </view>
- </view>
- </view>
- <view class="input-box flex-between">
- <input type="text" maxlength="10" placeholder="请输入你的昵称" placeholder-style="color:#494667;font-size:28rpx;" class="input fw500 font32" v-model="nickname">
- <view class="input-num font22 fw400">
- {{nickname.length}}/10
- </view>
- </view>
- <view class="label-box flex-between">
- <view class="left font28 fw400">
- 个人简介
- </view>
- <view class="right flex-center">
- <view class="input-num font22 fw400">
- {{introduce.length}}/200
- </view>
- </view>
- </view>
-
- <view class="textarea-box flex-between">
- <textarea maxlength="200" placeholder="可以填写个人介绍、人生经历、交友期望等" placeholder-style="color:#494667;font-size:28rpx;" class="textarea fw500 font32" v-model="introduce"></textarea>
- </view>
- <view class="label-box flex-between">
- <view class="left font28 fw400">
- 邀请码<span class="font22">(可不填)</span>
- </view>
- </view>
- <view class="input-box flex-between">
- <input type="text" maxlength="6" placeholder="请输入你的邀请码" placeholder-style="color:#494667;font-size:28rpx;" class="input fw500 font32" v-model="code" >
- </view>
- <view style="height: 200rpx;"></view>
- <view class="btn font32 fw600" @click="sure">
- {{btnText}}
- </view>
- </view>
- </template>
- <script>
- import TopBar from '@/components/TopBar/TopBar.vue';
- import ImageCropper from "@/components/invinbg-image-cropper/invinbg-image-cropper.vue";
- import {getPolicy,computeSignature,getKey} from '@/util/oss.js';
- import {encode} from '@/util/base64.js'
- import {dataURLtoBlob} from '@/util/index.js'
- export default {
- components:{TopBar,ImageCropper},
- data() {
- return {
- assetsUrl:this.$util.assetsUrl,
- nickname:'',
- introduce:'',
- code:'',
- icon:'',
- btnText:'下一步',
- tempFilePath: '',
- cropFilePath: '',
-
- };
- },
- methods:{
- sure(){
- if(this.btnText==='从相册上传'){
-
- uni.chooseImage({
- count: 1, //默认9
- sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
- sourceType: ['album','camera'], //从相册选择
- success: res=>{
- this.tempFilePath = res.tempFiles[0].path;
- }
- });
- }
- else{
- if(this.icon===''){uni.showToast({title:'请上传头像',icon:'none'});return;}
- if(this.nickname===''){uni.showToast({title:'请填写昵称',icon:'none'});return;}
- if(this.introduce===''){uni.showToast({title:'请填写个人简介',icon:'none'});return;}
- uni.showLoading({mask:true});
- let user=JSON.parse(uni.getStorageSync('user'));
- user.nick=this.nickname;
- user.desc=this.introduce;
- user.shareCode=this.code;
- user.icon=this.icon;
- let saveOption={
- "completeUser": user,
- "weiXinStatusEnum": 'NoWeiXin',
- }
- uni.showLoading({
- title:'保存中',
- mask:true
- })
- this.$api.login.saveFigure(saveOption).then(res=>{
- uni.setStorageSync('regStep','SocialData');
- uni.setStorageSync('LL_Ukn',res.data.ukn);
- uni.setStorageSync('user',JSON.stringify(user));
- this.$api.login.editHead({completeUser:user,icon:this.icon}).then(res=>{
- uni.hideLoading();
- })
- uni.reLaunch({
- url:`/pages/info/datum`
- })
- }).catch(err=>{})
- }
- },
- randNick(){
- this.$api.login.randNick({}).then(res=>{
- this.nickname=res.data.nick;
- }).catch(err=>{})
- },
- confirm(e) {
- this.tempFilePath = ''
- this.cropFilePath = e.detail.tempFilePath;
- this.btnText="下一步";
- this.$refs.popup.close();
- const that=this;
- const policyText=getPolicy();
- const policy=encode(JSON.stringify(policyText));
- const key=getKey(0);
- that.$api.public.aliossToken({}).then(result=>{
- console.log(result)
- // const client=new this.$oss({
- // // yourRegion填写Bucket所在地域。以华东1(杭州)为例,Region填写为oss-cn-hangzhou。
- // region: 'oss-cn-qingdao',
- // // 从STS服务获取的临时访问密钥(AccessKey ID和AccessKey Secret)。
- // accessKeyId: result.data.accessKeyId,
- // accessKeySecret: result.data.accessKeySecret,
- // // 从STS服务获取的安全令牌(SecurityToken)。
- // stsToken: result.data.securityToken,
- // // 填写Bucket名称。
- // bucket: 'zhenyanapp-gen'
- // });
- // console.log(this.cropFilePath)
- // let path=dataURLtoBlob(this.cropFilePath);
- // console.log(path)
- // client.put('upload-file',path).then(succ=>{
- // console.log(succ);
- // }).catch(err=>{
- // console.log(err);
- // })
- let formData={
- key:key,
- policy:policy,
- OSSAccessKeyId:result.data.accessKeyId,
- signature:computeSignature(result.data.accessKeySecret,policy),
- 'x-oss-security-token':result.data.securityToken,
- success_action_status:'200'
- }
- // console.log(key)
- // this.cropFilePath=base64toFile(this.cropFilePath,key);
- // console.log(this.cropFilePath)
- uni.uploadFile({
- url: 'https://zhenyanapp-gen.oss-cn-qingdao.aliyuncs.com',
- filePath:this.cropFilePath,
- name: 'file',
- header:{
- "Content-Type": "multipart/form-data"
- },
- formData: formData,
- success: (data) => {
- if (data.statusCode === 200) {
- that.icon=`${that.$store.state.imageCdn}/${key}`;
- }
- },
- fail: err => {
- console.log(err);
- }
- })
- })
-
- },
- cancel() {
- console.log('canceled')
- },
- showHeadPopup(){
- this.btnText="从相册上传";
- this.$refs.popup.open();
- },
- hideHeadPopup(){
- this.btnText="下一步";
- this.$refs.popup.close();
- }
- }
- }
- </script>
- <style lang="scss" scoped>
- .container{
- width: 100vw;
- min-height: 100vh;
- background-color: $bgcolor1;
- .popup{
- width: 100vw;
- box-sizing: border-box;
- padding: 56rpx 60rpx;
- background-color: $bgcolor3;
- .p-title-box{
- .p-title{
- color: $fontcolor5;
- }
- .p-close{
- width: 40rpx;
- height: 40rpx;
- }
- }
- .p-title-tip{
- color: $fontcolor3;
- margin-top: 16rpx;
- }
- .p-img-box{
- margin-top: 80rpx;
- .p-img{
- .img{
- width: 200rpx;
- height: 200rpx;
- }
- .p-text{
- color: $fontcolor2;
- text-align: center;
- }
- }
- }
- }
- .line-bar{
- margin: 0 60rpx;
- margin-top:108rpx;
- .span{
- width: 120rpx;
- height: 8rpx;
- border-radius: 4rpx 0rpx 0rpx 4rpx;
- background-color: $bgcolor4;
- }
- .active{
- background-color: $primary;
- }
- }
- .title{
- color: $fontcolor5;
- padding-left: 60rpx;
- margin-top: 108rpx;
- }
- .tip{
- color: $fontcolor3;
- padding-left: 60rpx;
- margin-top: 8rpx;
- }
- .head-info{
- position: relative;
- width: 184rpx;
- height: 184rpx;
- margin: 0 auto;
- .head-box{
- width: 184rpx;
- height: 184rpx;
- border-radius: 92rpx;
- margin: 0 auto;
- margin-top: 88rpx;
- overflow: hidden;
-
- .head-inner{
- width: 184rpx;
- height: 184rpx;
- background: linear-gradient(133deg, rgba(250, 92, 116, 1), rgba(188, 85, 191, 1), rgba(138, 79, 255, 1));
- .add{
- width: 40rpx;
- height: 40rpx;
- background-color: $bgcolor1;
- border-radius: 92rpx;
- padding: 68rpx;
- }
- }
- }
- .camera{
- position: absolute;
- right: 0;
- bottom: 0;
- width: 56rpx;
- height: 56rpx;
- }
- }
- .label-box{
- margin: 0 60rpx;
- margin-top: 56rpx;
- .left{
- color: $fontcolor3;
- }
- .right{
- .rand-btn{
- border-radius: 24rpx;
- border: 1rpx solid #7D7DA4;
- width: 136rpx;
- height: 40rpx;
- .rand{
- width: 24rpx;
- height: 24rpx;
- }
- .rand-text{
- color: $fontcolor2;
- margin-left: 10rpx;
- }
- }
- }
- }
- .input-box{
-
- margin: 0rpx 60rpx;
- margin-top: 16rpx;
- background-color: $bgcolor3;
- border-radius: 16rpx;
- height: 112rpx;
- padding: 0rpx 32rpx;
- .input{
- color: $fontcolor5;
- }
-
- }
- .textarea-box{
-
- border-radius: 16rpx;
- margin: 0rpx 60rpx;
- margin-top: 16rpx;
- background-color: $bgcolor3;
- padding: 0rpx 32rpx;
- min-height: 200rpx;
- .textarea{
- color: $fontcolor5;
- height: 136rpx;
- }
- }
- .btn{
- position: fixed;
- z-index: 999;
- left: 0;
- right: 0;
- bottom: 44rpx;
- margin: auto;
- width: 630rpx;
- height: 104rpx;
- border-radius: 52rpx;
- background-color: $primary;
- color: $fontcolor5;
- text-align: center;
- line-height: 104rpx;
- }
- }
- .input-num{
- color: $fontcolor2;
- }
- </style>
|