yunshangxie/pages/index/my_card.vue

566 lines
14 KiB
Vue
Raw Normal View History

2024-04-20 14:58:10 +08:00
<template>
2024-05-08 18:14:41 +08:00
<view class="page-c">
2024-05-31 18:06:24 +08:00
<tn-nav-bar :isBack="false" backTitle="" :alpha="true" :bottomShadow="false">
2024-05-08 18:14:41 +08:00
<view class="custom-nav tn-flex tn-flex-col-center tn-flex-row-left">
<view style="padding-left: 15rpx;" @click="goBack()">
2024-05-31 18:06:24 +08:00
<text class="tn-icon-left" style="font-size: 40rpx;color: #ffffff"></text>
2024-05-08 18:14:41 +08:00
</view>
2024-06-03 18:19:31 +08:00
<view class="tn-margin-top" @click="goBack()">
2024-05-31 18:06:24 +08:00
<tn-tabs :list="[{name:'会员名片'}]" :current="topCurrent" activeColor="#ffffff" :bold="false"
:fontSize="24"></tn-tabs>
2024-05-08 18:14:41 +08:00
</view>
</view>
</tn-nav-bar>
2024-05-31 18:06:24 +08:00
<view style="height: 550rpx;">
<view style="width: 100%;height: 450rpx;position: absolute;top: 0;">
<image v-if="userThisInfo.background_image==''" src="/static/my.png"
style="width: 100%;height: 450rpx;opacity: 0.8;">
</image>
<image v-if="userThisInfo.background_image!=''" :src="apiImgUrl+userThisInfo.background_image"
style="width: 100%;height: 450rpx;opacity: 0.8;"></image>
<view style="bottom:-105rpx;position: absolute;left: 28rpx;">
<view class="tn-flex tn-flex-center tn-flex-col-center">
<view style="width: 170rpx;height: 170rpx;position: relative;">
<image :src="apiImgUrl+userThisInfo.photo_image" mode="aspectFill"
style="width: 170rpx;height: 170rpx;border-radius: 50%;"></image>
2024-05-08 18:14:41 +08:00
</view>
2024-05-31 18:06:24 +08:00
<view style="margin-left: 10rpx">
<view style="font-size: 35rpx;color: #ffffff;font-weight: 600">{{userThisInfo.nikename}}
</view>
<view style="font-size: 28rpx;margin-top: 10rpx;">
<text>协会职务{{userThisInfo.position_name}}</text>
2024-06-03 18:19:31 +08:00
<text style="margin-left: 40rpx">性别{{userThisInfo.gender==0?'女':'男'}}</text>
2024-05-31 18:06:24 +08:00
</view>
<view style="margin-top: 10rpx" v-if="userThisInfo.if_tongyi==0">
联系方式{{userThisInfo.phone}}</view>
<view style="margin-top: 10rpx" v-if="userThisInfo.if_tongyi!=0">联系方式***********</view>
2024-05-08 18:14:41 +08:00
</view>
2024-05-31 18:06:24 +08:00
</view>
2024-05-08 18:14:41 +08:00
</view>
</view>
2024-05-31 18:06:24 +08:00
</view>
2024-05-08 18:14:41 +08:00
2024-06-03 18:19:31 +08:00
<view style="padding: 30rpx 30rpx 240rpx 30rpx;">
2024-05-31 18:06:24 +08:00
<view style="font-size: 30rpx;font-weight: 600;margin-bottom: 20rpx">个人经历</view>
<view style="background-color: #ffffff;border-radius: 15rpx;width: 100%;margin: 0 auto;">
2024-06-03 18:19:31 +08:00
<view style="padding: 20rpx;line-height: 50rpx;">
<view class="tn-text-ellipsis-5" @click="editInfo=true;editType=1">
{{userThisInfo.introduction==''||userThisInfo.introduction==null?'无':userThisInfo.introduction}}
</view>
2024-05-08 18:14:41 +08:00
</view>
2024-05-31 18:06:24 +08:00
</view>
<view style="font-size: 30rpx;font-weight: 600;margin-bottom: 20rpx;margin-top: 30rpx">企业介绍</view>
<view style="background-color: #ffffff;border-radius: 15rpx;width: 100%;margin: 0 auto;">
<view class="tn-flex tn-flex-center tn-flex-col-center" style="padding: 20rpx;">
<view style="padding-left: 20rpx">
<image v-if="userThisInfo.company_image!=''" :src="apiImgUrl+userThisInfo.company_image"
mode="aspectFill" style="width: 160rpx;height: 160rpx;"></image>
<view v-if="userThisInfo.company_image==''"
style="width: 160rpx;height: 160rpx;background: #d9d9d9;"></view>
2024-05-08 18:14:41 +08:00
</view>
2024-05-31 18:06:24 +08:00
<view style="font-size: 24rpx;color: #666666;margin-left: 30rpx;">
<view style="font-size: 36rpx;font-weight: 600;color: #000000">{{userThisInfo.enterprise_name}}
2024-05-08 18:14:41 +08:00
</view>
2024-06-04 18:04:09 +08:00
<view style="margin: 15rpx 0rpx">
所属行业{{userThisInfo.industry_id==-1?'其他行业':userThisInfo.industry_name}}</view>
2024-05-31 18:06:24 +08:00
<view>企业地址{{userThisInfo.enterprise_location}}</view>
2024-05-08 18:14:41 +08:00
</view>
</view>
2024-05-31 18:06:24 +08:00
</view>
2024-06-03 18:19:31 +08:00
<view style="background-color: #ffffff;border-radius: 15rpx;width: 100%;margin: 0 auto;margin-top: 30rpx;">
<view style="padding: 20rpx;line-height: 50rpx;" @click="editInfo=true;editType=2">
<view class="tn-text-ellipsis-10">{{userThisInfo.enterprise_Introduction}}</view>
2024-05-31 18:06:24 +08:00
</view>
2024-05-08 18:14:41 +08:00
</view>
</view>
2024-06-03 18:19:31 +08:00
<view class="tn-flex" style="width: 100%;position: fixed;bottom: 0;">
2024-05-31 18:06:24 +08:00
<view style="background: #418ef2;height: 100rpx;text-align: center;line-height: 100rpx;color: #ffffff;"
class="tn-flex-8" @click="addModeShow">
{{userThisInfo.if_tongyi!=0?'申请查看联系方式':'立刻联系'}}
</view>
<view style="background: #ffffff;height: 100rpx;text-align: center;line-height: 100rpx;" class="tn-flex-4">
<tn-button openType="share" backgroundColor="#ffffff">
<text class="tn-icon-send-fill" style="color: #418ef2;font-size: 40rpx;"></text>
</tn-button>
2024-05-08 18:14:41 +08:00
</view>
</view>
<view class="bg-tabbar-shadow"></view>
2024-05-14 10:20:09 +08:00
<tn-modal v-model="addMod" :custom="true">
<view class="custom-modal-content">
<view style="text-align: center;font-size: 34rpx;">申请查看</view>
<view class="text">
<tn-form ref="form" :labelWidth="180">
<tn-form-item label="自我介绍" prop="content">
<tn-input type="text" placeholder="填写自我介绍" v-model="addData.content" />
</tn-form-item>
</tn-form>
<view style="text-align: center;margin-top: 30rpx;">
<tn-button backgroundColor="#E6E6E6" fontColor="#ffffff" @click="addMod = false">取消</tn-button>
<tn-button backgroundColor="tn-bg-blue" fontColor="tn-color-white" style="margin-left: 30rpx"
@click="add_log">确定
</tn-button>
</view>
</view>
</view>
</tn-modal>
2024-06-03 18:19:31 +08:00
<tn-popup v-model="editInfo" mode="right" width="100%">
<tn-nav-bar :isBack="false" backTitle="" :alpha="true" :bottomShadow="false">
<view class="custom-nav tn-flex tn-flex-col-center tn-flex-row-left">
<view style="padding-left: 15rpx;" @click="editInfo = false">
<text class="tn-icon-left" style="font-size: 40rpx;"></text>
</view>
<view class="tn-margin-top"
style=";text-shadow: 1rpx 0 0 #FFF, 0 1rpx 0 #FFF, -1rpx 0 0 #FFF , 0 -1rpx 0 #FFF;">
<tn-tabs :list="[{name:editType==1?'个人经历':'公司介绍'}]" :current="topCurrent" activeColor="#000"
:bold="false" :fontSize="24"></tn-tabs>
</view>
</view>
</tn-nav-bar>
<view style="background: rgba(242, 241, 246, 1);height: 100%;">
<view :style="{paddingTop: vuex_custom_bar_height +'px'}"></view>
<view style="margin:30rpx;background-color: #ffffff;border-radius: 40rpx;">
<scroll-view scroll-y="true" style="height: 600rpx;padding: 30rpx;">
<view style="line-height: 45rpx;">
<view v-if="editType==1">
{{userThisInfo.introduction==''||userThisInfo.introduction==null?'无':userThisInfo.introduction}}
</view>
<view v-if="editType==2">
{{userThisInfo.enterprise_Introduction}}
</view>
</view>
</scroll-view>
</view>
<view class="tn-flex tn-flex-center tn-flex-row-center" style="color: #ffffff;">
<view @click="editInfo = false"
style="width: 300rpx;height: 80rpx;background: #d9d9d9;text-align: center;line-height: 80rpx;">
关闭</view>
</view>
</view>
</tn-popup>
2024-05-08 18:14:41 +08:00
</view>
2024-04-20 14:58:10 +08:00
</template>
<script>
2024-05-08 18:14:41 +08:00
import {
2024-05-14 10:20:09 +08:00
getUserIndex,
setMaillogAdd
2024-05-08 18:14:41 +08:00
} from "@/util/api";
import store from "@/store";
export default {
data() {
return {
2024-05-14 10:20:09 +08:00
addMod: false,
2024-05-08 18:14:41 +08:00
topCurrent: 0,
uid: 0,
this_uid: 0,
userInfo: {},
userThisInfo: {},
apiImgUrl: this.$store.state.imgUrl,
2024-05-14 10:20:09 +08:00
is: false,
2024-06-03 18:19:31 +08:00
editInfo: false,
editType: 1,
2024-05-14 10:20:09 +08:00
addData: {
content: '',
association_id: store.state.Gid,
member_q_id: 0,
member_b_id: 0,
type: 1
}
2024-05-08 18:14:41 +08:00
}
},
onLoad(d) {
this.this_uid = d.id;
2024-05-14 10:20:09 +08:00
var uid = uni.getStorageSync('uid');
console.log(uid);
if (!uid) {
getApp().getUserLogin((r) => {
console.log('---Login---', r);
this.uid = r.id;
})
} else {
this.uid = uid;
}
2024-05-08 18:14:41 +08:00
this.getUserInfo();
},
onShareAppMessage(res) {
var info = this.info;
console.log(info);
return {
title: this.userThisInfo.nikename,
path: '/pages/index/my_card?id=' + this.userThisInfo.member_id,
imageUrl: this.apiImgUrl + this.userThisInfo.photo_image
}
},
methods: {
2024-05-27 17:40:54 +08:00
addModeShow() {
var uid = uni.getStorageSync('uid');
if (!uid) {
uni.showToast({
title: '请登录!',
icon: 'none',
duration: 2000
});
return;
}
2024-05-31 18:06:24 +08:00
if (this.userThisInfo.if_tongyi == 0) {
this.callPhone();
return;
}
2024-05-27 17:40:54 +08:00
this.addMod = true;
},
2024-05-14 10:20:09 +08:00
add_log() {
2024-05-27 17:40:54 +08:00
var uid = uni.getStorageSync('uid');
if (!uid) {
uni.showToast({
title: '请登录!',
icon: 'none',
duration: 2000
});
return;
}
2024-05-14 10:20:09 +08:00
this.addData.member_q_id = this.uid;
this.addData.member_b_id = this.this_uid;
setMaillogAdd(this.addData)
.then(res => {
console.log(res);
if (res.code == 1) {
uni.showToast({
title: '申请成功!',
icon: 'none',
duration: 2000
});
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
this.addMod = false;
})
.catch(error => {
uni.showToast({
title: error,
icon: 'none',
duration: 2000
});
})
},
2024-05-08 18:14:41 +08:00
callPhone() {
// 电话号码为示例,请替换为实际需要拨打的号码
const phoneNumber = this.userThisInfo.phone;
uni.makePhoneCall({
phoneNumber: phoneNumber, // 电话号码
success: function() {
console.log('拨打电话成功');
},
fail: function() {
console.log('拨打电话失败');
}
});
},
getUserInfo() {
getUserIndex({
2024-05-14 10:20:09 +08:00
member_b_id: this.this_uid,
2024-05-27 17:40:54 +08:00
member_id: this.uid ? this.uid : 0,
2024-05-08 18:14:41 +08:00
})
.then(res => {
console.log(res)
if (res.code == 1) {
2024-05-14 10:20:09 +08:00
this.userThisInfo = res.data;
// if (this.this_uid != this.uid) {
// this.getThisUserInfo();
// } else {
// this.is = true;
// this.userThisInfo = res.data;
// }
2024-05-08 18:14:41 +08:00
}
})
.catch(error => {
uni.showToast({
title: error,
icon: 'none',
duration: 2000
});
})
},
openUrl(url) {
uni.navigateTo({
url: url
})
},
goBack() {
if (getCurrentPages().length > 1) {
uni.navigateBack()
} else {
uni.redirectTo({
url: '/pages/index/index'
})
}
}
}
}
2024-04-20 14:58:10 +08:00
</script>
<style lang="scss" scoped>
2024-05-08 18:14:41 +08:00
.page-c {
background-color: #EBF4F7;
min-height: 100vh;
}
/* 底部安全边距 start*/
.tn-tabbar-height {
min-height: 120rpx;
height: calc(140rpx + env(safe-area-inset-bottom) / 2);
height: calc(140rpx + constant(safe-area-inset-bottom));
}
.tn-footerfixed {
position: fixed;
width: 100%;
bottom: calc(180rpx + env(safe-area-inset-bottom));
z-index: 1024;
box-shadow: 0 1rpx 6rpx rgba(0, 0, 0, 0);
}
/* 按钮 */
.button-1 {
background-color: rgba(0, 0, 0, 0.15);
position: fixed;
/* bottom:200rpx;
2024-04-24 17:34:38 +08:00
right: 20rpx; */
2024-05-08 18:14:41 +08:00
bottom: 27%;
right: 30rpx;
z-index: 1001;
border-radius: 100px;
}
.button-2 {
background-color: rgba(0, 0, 0, 0.15);
position: fixed;
/* bottom:200rpx;
2024-04-24 17:34:38 +08:00
right: 20rpx; */
2024-05-08 18:14:41 +08:00
bottom: 18%;
right: 30rpx;
z-index: 1001;
border-radius: 100px;
}
/* 图标容器15 start */
.icon15 {
&__item {
width: 30%;
border-radius: 10rpx;
padding: 30rpx;
margin: 20rpx 10rpx;
transform: scale(1);
transition: transform 0.3s linear;
transform-origin: center center;
&--icon {
width: 100rpx;
height: 100rpx;
font-size: 50rpx;
border-radius: 50%;
margin-bottom: 18rpx;
z-index: 1;
&::after {
content: " ";
position: absolute;
z-index: -1;
width: 100%;
height: 100%;
left: 0;
bottom: 0;
border-radius: inherit;
opacity: 1;
transform: scale(1, 1);
background-size: 100% 100%;
}
}
}
}
/* 相册 */
.slideshow {
overflow: hidden;
text-align: center;
}
/* 简历内容 */
.king-list {
display: block;
// background-color: #ffffff;
}
.king-list .king-icon {
width: 100%;
text-align: left;
padding: 20rpx 0 20rpx 37rpx;
font-size: 26rpx;
color: #888;
display: block;
}
.king-list>.king-item {
padding: 30rpx 30rpx 30rpx 120rpx;
position: relative;
display: block;
z-index: 0;
}
.king-list>.king-item::after {
content: "";
display: block;
position: absolute;
width: 1rpx;
background-color: #E6E6E6;
left: 60rpx;
height: 100%;
top: 0;
z-index: 8;
}
.king-list>.king-item::before {
display: block;
position: absolute;
top: 36rpx;
z-index: 9;
background-color: #ffffff;
width: 50rpx;
height: 50rpx;
text-align: center;
border: none;
line-height: 50rpx;
left: 36rpx;
}
/* 名片微调 */
.img-solid {
border: 1rpx solid #eee;
}
.share-img {
position: fixed;
/* padding: 10rpx; */
width: 100rpx;
height: 100rpx;
/* top: 680rpx; */
bottom: 200rpx;
right: 20rpx;
z-index: 1024;
opacity: 0.8;
box-shadow: 0rpx 8rpx 30rpx 0rpx rgba(0, 0, 0, 0.3);
border: none;
border: 6rpx solid rgba(255, 255, 255, 0);
}
.resume {
display: flex;
justify-content: space-between;
padding-top: 10rpx;
border-radius: 6rpx;
color: #666;
line-height: 1.6;
}
.resume+.resume {
margin-top: 20rpx;
}
.resume2 {
padding-top: 10rpx;
border-radius: 6rpx;
display: block;
color: #666;
line-height: 1.6;
text-align: justify;
}
/* 间隔线 start*/
.tn-strip-bottom {
width: 100%;
border-bottom: 5rpx solid #ffffff;
}
/* 间隔线 end*/
.bg-img-cont {
background-size: cover;
background-position: center;
background-repeat: no-repeat;
height: 350rpx;
margin: 20rpx 0;
border-radius: 8rpx;
}
// .button-no {
// border: none;
// width: 100%;
// height: 100%;
// background-color: rgba(0, 0, 0, 0);
// }
/* 标签内容 start*/
.tn-tag-content {
&__item {
display: inline-block;
line-height: 45rpx;
padding: 10rpx 30rpx;
margin: 0rpx 20rpx 25rpx 0rpx;
&--prefix {
padding-right: 10rpx;
}
}
}
/* 标签内容 end*/
.see {
display: flex;
justify-content: space-between;
padding-top: 10rpx;
border-radius: 6rpx;
color: #666;
line-height: 1.6;
}
2024-05-31 18:06:24 +08:00
/* 显示5行 */
.tn-text-ellipsis-5 {
display: -webkit-box;
overflow: hidden;
white-space: normal !important;
text-overflow: ellipsis;
word-wrap: break-word;
-webkit-line-clamp: 5;
-webkit-box-orient: vertical;
}
/* 显示5行 */
.tn-text-ellipsis-10 {
display: -webkit-box;
overflow: hidden;
white-space: normal !important;
text-overflow: ellipsis;
word-wrap: break-word;
-webkit-line-clamp: 10;
-webkit-box-orient: vertical;
}
2024-06-03 18:19:31 +08:00
</style>