123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676 |
- <template>
- <view>
- <!-- 顶部导航栏 -->
- <view class="navbar" :style="{ paddingTop: (12 + statusBarHeight) + 'px' }">
- <view class="navbar-content">
- <view class="navbar-left" @click="goBack">
- <u-icon name="arrow-leftward" size="36" color="#333"></u-icon>
- </view>
- <view class="navbar-title">基本信息</view>
- <view class="navbar-right"></view>
- </view>
- </view>
- <!-- <nav-bar title="基本信息"></nav-bar> -->
- <view class="usermain">
- <view class="usermain-item ">
- <view class="usermain-item-title">头像</view>
- <view class="avatar-wrapper">
- <!-- #ifdef MP-WEIXIN -->
- <button open-type="chooseAvatar" class="avatar-button" @chooseavatar="onChooseAvatar">
- <image style="width: 78rpx;height: 78rpx;border-radius: 50%"
- :src="avatar?avatar:'../../static/logo.png'"></image>
- </button>
- <!-- #endif -->
- <!-- #ifndef MP-WEIXIN -->
- <view @click="uploadImg()">
- <image src="../../static/logo.png" v-if="avatar==null" mode=""
- style="width: 78rpx;height: 78rpx;border-radius: 50%;"></image>
- <image v-else :src="avatar" mode="" style="width: 78rpx;height: 78rpx;border-radius: 50%;">
- </image>
- </view>
- <!-- #endif -->
- <view class="edit-avatar-icon">
- <image src="/static/images/index/Combined-Shape.svg" style="width: 32rpx;height: 32rpx;" mode="scaleToFill"></image>
- </view>
- </view>
- </view>
- <view class="usermain-item item-padding ">
- <view class="form-label">
- <text class="required-mark">*</text>
- <text class="usermain-item-title">姓名</text>
- </view>
- <view class="cu-form-group">
- <input type="nickname" v-model="userName" placeholder="请输入用户名" />
- </view>
- </view>
- <view class="usermain-item item-padding ">
- <view class="form-label">
- <text class="required-mark">*</text>
- <view class="usermain-item-title">性别</view>
- </view>
- <view>
- <view class="cu-form-group">
- <u-radio-group v-model="sex">
- <u-radio shape="circle" :name="1">男</u-radio>
- <u-radio shape="circle" active-color="red" :name="2">女</u-radio>
- </u-radio-group>
- </view>
- </view>
- </view>
- <view class="usermain-item item-padding ">
- <view class="usermain-item-title">年龄</view>
- <view>
- <view class="cu-form-group">
- <input v-model="age" />
- </view>
- </view>
- </view>
- <view class="usermain-item item-padding contact-structure">
- <view class="usermain-item-title">联系方式</view>
- <view class="contact-wrapper">
- <text class="phone-display">{{phoneWithMask}}</text>
- <text class="modify-link" @click="modifyPhone">修改手机号</text>
- </view>
- </view>
- <!-- <view class="usermain-item item-padding">
- <view >姓名</view>
- <view class="cu-form-group">
- <input v-model="realName" placeholder="请填写您的真实姓名" />
- </view>
- </view> -->
- <view class="usermain-item item-padding ">
- <view class="usermain-item-title">微信号码</view>
- <view>
- <view class="cu-form-group">
- <input v-model="weChatNum" placeholder="请输入微信号码,方便给求职者交换微信联系" />
- </view>
- </view>
- </view>
-
- <!-- 接收简历邮箱 -->
- <view class="usermain-item item-padding">
- <view class="usermain-item-title">接收简历邮箱</view>
- <view>
- <view class="cu-form-group">
- <input v-model="email" placeholder="建议录入企业邮箱" />
- </view>
- </view>
- </view>
-
- <!-- 我的公司 -->
- <view class="usermain-item item-padding">
- <view class="usermain-item-title">我的公司</view>
- <view>
- <view class="form-input-selector" @click="selectCompany">
- <text v-if="selectedCompany">{{ selectedCompany }}</text>
- <text v-else class="placeholder">请选择公司</text>
- <u-icon name="arrow-down" color="#999" size="36"></u-icon>
- </view>
- </view>
- </view>
-
- <!-- 我的职务 -->
- <view class="usermain-item item-padding">
- <view class="usermain-item-title">我的职务</view>
- <view>
- <view class="form-input-selector" @click="selectPosition">
- <text v-if="selectedPosition">{{ selectedPosition }}</text>
- <text v-else class="placeholder">请选择职务</text>
- <u-icon name="arrow-down" color="#999" size="36"></u-icon>
- </view>
- </view>
- </view>
- </view>
- <view class="footer-btn">
- <view class="usermain-btn" @click="messagebtn()">保存</view>
- </view>
- </view>
- </template>
- <script>
- import configdata from '../../common/config.js';
- import navBar from "@/components/nav-bar/index.vue";
- export default {
- components: {
- navBar
- },
- data() {
- return {
- statusBarHeight: 0, // 状态栏高度
- phone: '',
- weChatNum:'',//微信号
- email: '',//接收简历邮箱
- selectedCompany: '深圳市汉瑞国际猎头服务有限公司', // 我的公司
- selectedPosition: '人事总监', // 我的职务
- avatar: '../../static/logo.png',
- userName: '',
- nickName: '',
- userId: '',
- realName: '',
- weChatId: "",
- password: '',
- platform: '',
- createTime: '',
- money: '',
- jiFen: '',
- status: '',
- zhiFuBao: '',
- zhiFuBaoName: '',
- sex: 1,
- age: 0
- };
- },
- computed: {
- phoneWithMask() {
- if (this.phone && this.phone.length >= 11) {
- return this.phone.substring(0, 3) + '******' + this.phone.substring(9);
- }
- return this.phone || '请设置手机号';
- }
- },
- onLoad(e) {
- // 获取状态栏高度
- let systemInfo = uni.getSystemInfoSync();
- this.statusBarHeight = systemInfo.statusBarHeight || 0;
-
- this.getUserInfo()
- // this.avatar = uni.getStorageSync('avatar')
- },
- methods: {
- // 返回上一页
- goBack() {
- uni.navigateBack();
- },
- // 修改手机号
- modifyPhone() {
- console.log('点击修改手机号,当前手机号:', this.phone);
- const url = `/pages/my/userphone?currentPhone=${this.phone}`;
- console.log('跳转路径:', url);
-
- uni.navigateTo({
- url: url,
- });
- },
- // 选择公司
- selectCompany() {
- uni.navigateTo({
- url: '/pages/my/myCompany'
- });
- },
- // 选择职务
- selectPosition() {
- // 这里可以跳转到职务选择页面或显示职务选择弹窗
- console.log('选择职务');
- },
- onChooseAvatar(e) {
- let that = this;
- let token = uni.getStorageSync('token');
- uni.uploadFile({
- url: that.config("APIHOST1") +
- '/alioss/upload', //真实的接口地址
- filePath: e.detail.avatarUrl,
- header: {
- token: token
- },
- name: 'file',
- success: uploadFileRes => {
- let url = JSON.parse(uploadFileRes.data);
- that.avatar = url.data
- uni.hideLoading();
- }
- });
- },
- goMyAddress() {
- uni.navigateTo({
- url: '../jifen/myaddress'
- });
- },
- uploadImg() {
- let token = uni.getStorageSync('token')
- if (!token) {
- this.goLoginInfo();
- return;
- }
- let that = this;
- var url = null;
- uni.showActionSheet({
- // itemList按钮的文字接受的是数组
- itemList: ["查看头像", "从相册选择图片"],
- success(e) {
- var index = e.tapIndex
- if (index === 0) {
- // 用户点击了预览当前图片
- // 可以自己实现当前头像链接的读取
- let url = that.avatar;
- let arr = []
- arr.push(url)
- uni.previewImage({
- // 预览功能图片也必须是数组的
- urls: arr
- })
- } else if (index === 1) {
- uni.chooseImage({
- count: 1, //默认9
- sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
- sourceType: ['album'], //从相册选择
- success: function(res) {
- uni.showLoading({
- title: '上传中...'
- });
- let token = uni.getStorageSync('token');
- let userId = uni.getStorageSync('userId');
- uni.uploadFile({
- url: that.config("APIHOST1") +
- '/alioss/upload', //真实的接口地址
- filePath: res.tempFilePaths[0],
- header: {
- token: token
- },
- name: 'file',
- success: uploadFileRes => {
- url = JSON.parse(uploadFileRes.data);
- that.avatar = url.data
- uni.hideLoading();
- }
- });
- }
- });
- }
- }
- })
- },
- config: function(name) {
- var info = null;
- if (name) {
- var name2 = name.split("."); //字符分割
- if (name2.length > 1) {
- info = configdata[name2[0]][name2[1]] || null;
- } else {
- info = configdata[name] || null;
- }
- if (info == null) {
- let web_config = cache.get("web_config");
- if (web_config) {
- if (name2.length > 1) {
- info = web_config[name2[0]][name2[1]] || null;
- } else {
- info = web_config[name] || null;
- }
- }
- }
- }
- return info;
- },
- getUserInfo() {
- let userId = uni.getStorageSync('userId')
- this.$Request.get("/app/user/selectUserById").then(res => {
- if (res.code == 0) {
- this.$queue.setData('avatar', res.data.avatar);
- this.$queue.setData('userId', res.data.userId);
- this.$queue.setData('userName', res.data.userName);
- this.$queue.setData('phone', res.data.phone);
- this.$queue.setData('age', res.data.age);
- this.$queue.setData('weChatNum',res.data.weChatNum)
- this.weChatNum = res.data.weChatNum
- this.sex = res.data.sex
- this.age = res.data.age
- this.phone = res.data.phone;
- this.avatar = res.data.avatar;
- this.userName = res.data.userName;
- if (this.userName == null) {
- this.userName = res.data.nickName;
- } else {
- this.userName = res.data.userName;
- }
- }
- uni.hideLoading();
- });
- },
- // 保存
- messagebtn() {
- if (!this.userName) {
- // this.$queue.showToast('用户名不能为空');
- uni.showToast({
- title: "用户名不能为空",
- icon: "none"
- })
- } else if (!this.phone) {
- // this.$queue.showToast('用户名不能为空');
- uni.showToast({
- title: "联系电话不能为空",
- icon: "none"
- })
- } else {
- let that = this
- uni.showModal({
- title: '温馨提示',
- content: '确定保存信息',
- success: e => {
- if (e.confirm) {
- that.$Request.postJson("/app/user/updateUser", {
- userName: that.userName,
- avatar: that.avatar,
- phone: that.phone,
- sex: that.sex,
- age: that.age,
- weChatNum:that.weChatNum
- }).then(res => {
- if (res.code === 0) {
- uni.showToast({
- title: '保存成功',
- icon: "none"
- })
- that.getUserInfo()
- setTimeout(function() {
- uni.navigateBack()
- }, 1000)
- } else {
- uni.showToast({
- title: res.msg,
- icon: "none"
- })
- }
- })
- }
- }
- });
- }
- }
- },
- // userphone(){
- // uni.navigateTo({
- // url:'/pages/my/userphone'
- // })
- // }
- };
- </script>
- <style lang="scss" scoped>
- page {
- /* background: #1c1b20; */
- }
- .navbar {
- position: fixed;
- top: 0;
- left: 0;
- right: 0;
- z-index: 999;
- background: #fff;
- padding: 0 0 40rpx 20rpx;
-
- .navbar-content {
- display: flex;
- align-items: center;
- justify-content: space-between;
- padding: 0 30rpx;
- height: 60rpx;
-
- .navbar-left {
- width: 60rpx;
- height: 60rpx;
- display: flex;
- align-items: center;
- justify-content: center;
- }
-
- .navbar-title {
- color: rgba(23, 23, 37, 1);
- font-family: DM Sans;
- font-size: 36rpx;
- font-weight: 700;
- line-height: 52rpx;
- letter-spacing: 0%;
- text-align: center;
- }
-
- .navbar-right {
- width: 60rpx;
- height: 60rpx;
- }
- }
- }
- button::after {
- border: none;
- background-color: none;
- }
- button {
- position: relative;
- display: block;
- margin-left: auto;
- margin-right: auto;
- padding-left: 0px;
- padding-right: 0px;
- box-sizing: border-box;
- text-decoration: none;
- line-height: 1.35;
- overflow: hidden;
- color: #666666;
- /* background-color: #fff; */
- background-color: rgba(255, 255, 255, 0) !important;
- width: 100%;
- height: 100%;
- }
- .usermain {
- background: #ffffff;
- /* color: #fff; */
- margin-top: 120rpx; /* 为固定导航栏留出空间 */
- }
- .usermain-item {
- display: flex;
- flex-direction: column;
- margin: 0 40rpx;
- padding: 20rpx 0;
- // border-bottom: 1rpx solid rgba(229, 229, 229, 0.3);
- gap: 16rpx;
- }
- .usermain-item-title {
- color: rgba(31, 44, 55, 1);
- font-family: DM Sans;
- font-size: 28rpx;
- font-weight: 500;
- line-height: 44rpx;
- text-align: left;
- }
- .usermain-item.item-padding {
- /* padding: 0; */
- }
- .cu-form-group {
- padding: 0;
- background: #ffffff;
- text-align: right;
- }
- .cu-form-group input {
- background: #ffffff;
- font-size: 28rpx;
- /* color: #fff; */
- }
- /* 姓名字段样式 - 参考basicInfo.vue */
- .usermain-item .form-label {
- color: rgba(31, 44, 55, 1);
- font-family: DM Sans;
- font-size: 32rpx;
- font-weight: 500;
- line-height: 44rpx;
- letter-spacing: 0.5%;
- text-align: left;
- display: flex;
- align-items: center;
- margin-bottom: 16rpx;
- }
- .usermain-item .required-mark {
- color: #FF3B30;
- font-size: 36rpx;
- font-weight: 600;
- margin-right: 8rpx;
- }
- .usermain-item .cu-form-group {
- background: transparent;
- text-align: left;
- padding: 0;
- }
- .usermain-item .cu-form-group input {
- width: 100%;
- height: 68rpx;
- font-size: 28rpx;
- border: 1rpx solid rgba(227, 231, 236, 1);
- border-radius: 44rpx;
- color: rgba(23, 23, 37, 1);
- padding: 0 32rpx;
- background: #ffffff;
- font-family: DM Sans;
- font-weight: 400;
- }
- .usermain-item .cu-form-group input::placeholder {
- color: rgba(155, 155, 155, 1);
- font-size: 28rpx;
- }
- /* 联系方式样式 */
- .contact-structure {
- border-bottom: none !important;
- }
- .contact-wrapper {
- display: flex;
- align-items: center;
- justify-content: space-between;
- padding: 0;
- margin-top: 8rpx;
- }
- .phone-display {
- color: rgba(23, 23, 37, 1);
- font-family: DM Sans;
- font-size: 28rpx;
- font-weight: 400;
- line-height: 40rpx;
- letter-spacing: 0.5%;
- }
- .modify-link {
- color: rgba(24, 144, 255, 1);
- font-family: DM Sans;
- font-size: 28rpx;
- font-weight: 400;
- line-height: 40rpx;
- letter-spacing: 0.5%;
- cursor: pointer;
- text-decoration: none;
- }
- .modify-link:active {
- opacity: 0.7;
- }
- /* 头像编辑图标样式 */
- .avatar-wrapper {
- position: relative;
- display: inline-block;
- }
- .edit-avatar-icon {
- position: absolute;
- bottom: 10rpx;
- right: 2rpx;
- width: 24rpx;
- height: 24rpx;
- // background: #fff;
- border-radius: 50%;
- display: flex;
- align-items: center;
- justify-content: center;
- box-shadow: 0 2rpx 8rpx rgba(0, 0, 0, 0.1);
- }
- .avatar-button {
- position: relative;
- padding: 0;
- margin: 0;
- background: transparent;
- border: none;
- }
- .footer-btn {
- margin-top: 40rpx;
- padding-bottom: 40rpx;
- }
- .footer-btn .usermain-btn {
- color: rgba(255, 255, 255, 1);
- background: rgba(1, 107, 246, 1);
- text-align: center;
- width: 90%;
- height: 80rpx;
- font-size: 32rpx;
- line-height: 80rpx;
- margin: 20rpx auto;
- border-radius: 40rpx;
- }
- /* 选择器样式 - 参考workExperience页面 */
- .form-input-selector {
- width: 100%;
- height: 68rpx;
- padding: 0 40rpx;
- border: 1px solid rgba(227, 231, 236, 1);
- border-radius: 24px;
- background: rgba(255, 255, 255, 1);
- display: flex;
- align-items: center;
- justify-content: space-between;
- cursor: pointer;
- transition: all 0.2s ease;
-
- .placeholder {
- color: #999999;
- font-family: DM Sans;
- font-size: 28rpx;
- font-weight: 400;
- line-height: 40rpx;
- }
-
- text {
- color: rgba(23, 23, 37, 1);
- font-family: DM Sans;
- font-size: 28rpx;
- font-weight: 400;
- line-height: 40rpx;
- }
- }
- .arrow-down {
- color: rgba(96, 98, 102, 1);
- font-size: 24rpx;
- font-weight: 400;
- transform: scale(1.5);
- }
- .selector-group:active {
- background: #f5f7fa !important;
- transform: scale(0.99);
- }
- </style>
|