|
@@ -81,7 +81,38 @@
|
|
<div class="buttona" @click="save">保存</div>
|
|
<div class="buttona" @click="save">保存</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
- <div v-if="subNavCurrent == 'invite'"></div>
|
|
|
|
|
|
+ <div v-if="subNavCurrent == 'invite'">
|
|
|
|
+ <div>
|
|
|
|
+ <div style="display: flex; justify-content: space-between">
|
|
|
|
+ <div style="display: flex; align-items: center">
|
|
|
|
+ <div
|
|
|
|
+ :class="inviteidx == 0 ? 'activein' : 'myin'"
|
|
|
|
+ @click="changeinvite(0)"
|
|
|
|
+ >
|
|
|
|
+ 邀请人
|
|
|
|
+ </div>
|
|
|
|
+ <div
|
|
|
|
+ style="margin-left: 27px"
|
|
|
|
+ :class="inviteidx == 1 ? 'activein' : 'myin'"
|
|
|
|
+ @click="changeinvite(1)"
|
|
|
|
+ >
|
|
|
|
+ 我的邀请
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ <div class="myfriend">邀请好友</div>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-top: 40px">
|
|
|
|
+ <img
|
|
|
|
+ src=""
|
|
|
|
+ alt=""
|
|
|
|
+ style="width: 36px; height: 36px; border-radius: 50%"
|
|
|
|
+ />
|
|
|
|
+ <span style="margin-left: 14px" class="bei">邀请人备份</span>
|
|
|
|
+ <span style="margin-left: 40px" class="time">2023-02-12</span>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ <div></div>
|
|
|
|
+ </div>
|
|
<div v-if="subNavCurrent == 'zhang'">
|
|
<div v-if="subNavCurrent == 'zhang'">
|
|
<div style="margin-top: 35px">
|
|
<div style="margin-top: 35px">
|
|
<div style="display: flex; align-items: center">
|
|
<div style="display: flex; align-items: center">
|
|
@@ -89,7 +120,9 @@
|
|
<div style="margin-left: 22px; min-width: 95px" class="phone">
|
|
<div style="margin-left: 22px; min-width: 95px" class="phone">
|
|
178****2987
|
|
178****2987
|
|
</div>
|
|
</div>
|
|
- <div class="button" style="margin-left: 24px">更改手机号</div>
|
|
|
|
|
|
+ <div class="button" style="margin-left: 24px" @click="dialog = true">
|
|
|
|
+ 更改手机号
|
|
|
|
+ </div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div style="margin-top: 33px; display: flex; align-items: center">
|
|
<div style="margin-top: 33px; display: flex; align-items: center">
|
|
@@ -103,8 +136,81 @@
|
|
<div class="button" style="margin-left: 24px">修改密码</div>
|
|
<div class="button" style="margin-left: 24px">修改密码</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
- <div v-if="subNavCurrent == 'xiaoxi'"></div>
|
|
|
|
|
|
+ <div v-if="subNavCurrent == 'xiaoxi'">
|
|
|
|
+ <div>
|
|
|
|
+ <div>推送通知</div>
|
|
|
|
+ <div style="display: flex; margin-top: 23px">
|
|
|
|
+ <div>
|
|
|
|
+ <span class="zhi">系统通知</span>
|
|
|
|
+ <el-switch
|
|
|
|
+ v-model="is_system_notify"
|
|
|
|
+ active-color="rgba(0, 176, 176, 1)"
|
|
|
|
+ inactive-color="rgba(102, 102, 102, 0.8)"
|
|
|
|
+ ></el-switch>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-left: 30px">
|
|
|
|
+ <span class="zhi">点赞推送</span>
|
|
|
|
+ <el-switch
|
|
|
|
+ v-model="is_like_notify"
|
|
|
|
+ active-color="rgba(0, 176, 176, 1)"
|
|
|
|
+ inactive-color="rgba(102, 102, 102, 0.8)"
|
|
|
|
+ ></el-switch>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-left: 30px">
|
|
|
|
+ <span class="zhi">评论推送</span>
|
|
|
|
+ <el-switch
|
|
|
|
+ v-model="is_comment_notify"
|
|
|
|
+ active-color="rgba(0, 176, 176, 1)"
|
|
|
|
+ inactive-color="rgba(102, 102, 102, 0.8)"
|
|
|
|
+ ></el-switch>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-top: 26px">谁给我点赞</div>
|
|
|
|
+ <div style="margin-top: 24px; display: flex">
|
|
|
|
+ <div><el-radio v-model="who_can_like" label="all">任何人</el-radio></div>
|
|
|
|
+ <div>
|
|
|
|
+ <el-radio v-model="who_can_like" label="follower" style="margin-left: 90px"
|
|
|
|
+ >今我关注的</el-radio
|
|
|
|
+ >
|
|
|
|
+ </div>
|
|
|
|
+ <div>
|
|
|
|
+ <el-radio v-model="who_can_like" label="fans" style="margin-left: 90px"
|
|
|
|
+ >仅关注我的</el-radio
|
|
|
|
+ >
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-top: 30px">谁能收藏我的内容</div>
|
|
|
|
+ <div style="margin-top: 24px; display: flex">
|
|
|
|
+ <div><el-radio v-model="who_can_collect" label="all">任何人</el-radio></div>
|
|
|
|
+ <div>
|
|
|
|
+ <el-radio v-model="who_can_collect" label="follower" style="margin-left: 90px"
|
|
|
|
+ >今我关注的</el-radio
|
|
|
|
+ >
|
|
|
|
+ </div>
|
|
|
|
+ <div>
|
|
|
|
+ <el-radio v-model="who_can_collect" label="fans" style="margin-left: 90px"
|
|
|
|
+ >仅关注我的</el-radio
|
|
|
|
+ >
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-top: 30px">谁能评论回复我</div>
|
|
|
|
+ <div style="margin-top: 24px; display: flex">
|
|
|
|
+ <div><el-radio v-model="who_can_comment" label="all">任何人</el-radio></div>
|
|
|
|
+ <div>
|
|
|
|
+ <el-radio v-model="who_can_comment" label="follower" style="margin-left: 90px"
|
|
|
|
+ >今我关注的</el-radio
|
|
|
|
+ >
|
|
|
|
+ </div>
|
|
|
|
+ <div>
|
|
|
|
+ <el-radio v-model="who_can_comment" label="fans" style="margin-left: 90px"
|
|
|
|
+ >仅关注我的</el-radio
|
|
|
|
+ >
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
</div>
|
|
</div>
|
|
|
|
+ <!-- 完善信息 -->
|
|
<el-dialog
|
|
<el-dialog
|
|
v-model="dialogVisible"
|
|
v-model="dialogVisible"
|
|
width="260px"
|
|
width="260px"
|
|
@@ -131,6 +237,7 @@
|
|
<div class="btn" style="" @click="enter()">确定</div>
|
|
<div class="btn" style="" @click="enter()">确定</div>
|
|
</div>
|
|
</div>
|
|
</el-dialog>
|
|
</el-dialog>
|
|
|
|
+ <!-- 更改手机号 -->
|
|
<el-dialog
|
|
<el-dialog
|
|
title="更改手机号"
|
|
title="更改手机号"
|
|
v-model="dialog"
|
|
v-model="dialog"
|
|
@@ -141,20 +248,62 @@
|
|
<div>
|
|
<div>
|
|
<div style="margin-top: -20px">
|
|
<div style="margin-top: -20px">
|
|
<el-input
|
|
<el-input
|
|
- v-model="input"
|
|
|
|
|
|
+ v-model="mobile"
|
|
style="width: 358px; height: 46px"
|
|
style="width: 358px; height: 46px"
|
|
placeholder="请输入手机号"
|
|
placeholder="请输入手机号"
|
|
></el-input>
|
|
></el-input>
|
|
</div>
|
|
</div>
|
|
- <div style="margin-top: 20px;position: relative;">
|
|
|
|
|
|
+ <div style="margin-top: 20px; position: relative">
|
|
<el-input
|
|
<el-input
|
|
- v-model="input"
|
|
|
|
|
|
+ v-model="code"
|
|
style="width: 358px; height: 46px"
|
|
style="width: 358px; height: 46px"
|
|
placeholder="请输入验证码"
|
|
placeholder="请输入验证码"
|
|
></el-input>
|
|
></el-input>
|
|
- <div style="position: absolute;cursor: pointer; right: 30px;top: 15px;" class="code">获取验证码</div>
|
|
|
|
|
|
+ <div
|
|
|
|
+ style="position: absolute; cursor: pointer; right: 30px; top: 15px"
|
|
|
|
+ class="code"
|
|
|
|
+ >
|
|
|
|
+ 获取验证码
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ <div class="change" style="margin-top: 24px" @click="change">
|
|
|
|
+ 确定更改
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ </el-dialog>
|
|
|
|
+ <!-- 修改密码 -->
|
|
|
|
+ <el-dialog
|
|
|
|
+ title="修改密码"
|
|
|
|
+ v-model="password"
|
|
|
|
+ width="406px"
|
|
|
|
+ :before-close="handleClose"
|
|
|
|
+ style="border-radius: 8px; border: 1px solid #979797"
|
|
|
|
+ >
|
|
|
|
+ <div>
|
|
|
|
+ <div style="margin-top: -20px">
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="oldpass"
|
|
|
|
+ style="width: 358px; height: 46px"
|
|
|
|
+ placeholder="旧密码"
|
|
|
|
+ ></el-input>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-top: -20px">
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="newpass"
|
|
|
|
+ style="width: 358px; height: 46px"
|
|
|
|
+ placeholder="新密码"
|
|
|
|
+ ></el-input>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-top: -20px">
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="newpa"
|
|
|
|
+ style="width: 358px; height: 46px"
|
|
|
|
+ placeholder="确定新密码"
|
|
|
|
+ ></el-input>
|
|
|
|
+ </div>
|
|
|
|
+ <div class="change" style="margin-top: 24px" @click="passchange">
|
|
|
|
+ 确定修改
|
|
</div>
|
|
</div>
|
|
- <div class="change" style="margin-top: 24px">确定更改</div>
|
|
|
|
</div>
|
|
</div>
|
|
</el-dialog>
|
|
</el-dialog>
|
|
</template>
|
|
</template>
|
|
@@ -173,6 +322,108 @@ const introduction = User.introduction;
|
|
const backgroud_image = User.backgroud_image;
|
|
const backgroud_image = User.backgroud_image;
|
|
const avatar = User.avatar;
|
|
const avatar = User.avatar;
|
|
const column_1 = ref();
|
|
const column_1 = ref();
|
|
|
|
+const inviteidx = ref(0);
|
|
|
|
+//消息推送
|
|
|
|
+//获取配置列表
|
|
|
|
+const confi = ref([{}]);
|
|
|
|
+// "is_system_notify": 1, //系统通知: 0.关闭, 1.开启
|
|
|
|
+// "is_like_notify": 1, //点赞通知: 0.关闭, 1.开启
|
|
|
|
+// "is_comment_notify": 1, //评论通知: 0.关闭, 1.开启
|
|
|
|
+// "who_can_like": "all", //谁可以点赞: all.所有人, follower.我的关注, fans.关注我的
|
|
|
|
+// "who_can_collect": "all", //谁可以收藏: all.所有人, follower.我的关注, fans.关注我的
|
|
|
|
+// "who_can_comment": "all", //谁可以评论回复: all.所有人, follower.我的关注, fans.关注我
|
|
|
|
+const is_system_notify = ref();
|
|
|
|
+const is_like_notify = ref();
|
|
|
|
+const is_comment_notify = ref();
|
|
|
|
+const who_can_like = ref();
|
|
|
|
+const who_can_collect = ref();
|
|
|
|
+const who_can_comment = ref();
|
|
|
|
+const config = async () => {
|
|
|
|
+ try {
|
|
|
|
+ const { data } = await userApi.config({});
|
|
|
|
+ confi.value = data;
|
|
|
|
+ is_system_notify.value = data.is_system_notify;
|
|
|
|
+ is_like_notify.value = data.is_like_notify;
|
|
|
|
+ is_comment_notify.value = data.is_comment_notify;
|
|
|
|
+ who_can_like.value = data.who_can_like;
|
|
|
|
+ who_can_collect.value = data.who_can_collect;
|
|
|
|
+ who_can_comment.value = data.who_can_comment;
|
|
|
|
+ } catch (error) {}
|
|
|
|
+};
|
|
|
|
+onMounted(config);
|
|
|
|
+//设置用户配置
|
|
|
|
+const postconfig = async () => {
|
|
|
|
+ try {
|
|
|
|
+ const { data } = await userApi.postconfig({
|
|
|
|
+ is_system_notify: is_system_notify.value,
|
|
|
|
+ is_like_notify: is_like_notify.value,
|
|
|
|
+ is_comment_notify: is_comment_notify.value,
|
|
|
|
+ who_can_like: who_can_like.value,
|
|
|
|
+ who_can_collect: who_can_collect.value,
|
|
|
|
+ who_can_comment: who_can_comment.value,
|
|
|
|
+ });
|
|
|
|
+ } catch (error) {}
|
|
|
|
+};
|
|
|
|
+//邀请与推广
|
|
|
|
+const changeinvite = (index) => {
|
|
|
|
+ inviteidx.value = index;
|
|
|
|
+ if (index == 0) {
|
|
|
|
+ parent();
|
|
|
|
+ } else {
|
|
|
|
+ children();
|
|
|
|
+ }
|
|
|
|
+};
|
|
|
|
+const inviteList = ref([]);
|
|
|
|
+const children = async () => {
|
|
|
|
+ try {
|
|
|
|
+ const { data } = await userApi.children({
|
|
|
|
+ is_page: 0,
|
|
|
|
+ });
|
|
|
|
+ inviteList.value = data;
|
|
|
|
+ } catch (error) {}
|
|
|
|
+};
|
|
|
|
+const parent = async () => {
|
|
|
|
+ try {
|
|
|
|
+ const { data } = await userApi.parent({});
|
|
|
|
+ inviteList.value = data;
|
|
|
|
+ } catch (error) {}
|
|
|
|
+};
|
|
|
|
+onMounted(parent);
|
|
|
|
+//修改密码
|
|
|
|
+const oldpass = ref();
|
|
|
|
+const newpass = ref();
|
|
|
|
+const newpa = ref();
|
|
|
|
+//修改密码接口
|
|
|
|
+const passchange = async () => {
|
|
|
|
+ try {
|
|
|
|
+ const { data } = await userApi.password({
|
|
|
|
+ old_password: oldpass.value,
|
|
|
|
+ password: newpass.value,
|
|
|
|
+ password_confirmation: newpa.value,
|
|
|
|
+ });
|
|
|
|
+ ElMessage.success({
|
|
|
|
+ message: "修改成功",
|
|
|
|
+ type: "success",
|
|
|
|
+ });
|
|
|
|
+ } catch (error) {}
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+//账户安全
|
|
|
|
+//电话号
|
|
|
|
+const mobile = ref();
|
|
|
|
+const code = ref();
|
|
|
|
+const dialog = ref(false);
|
|
|
|
+//更换手机号
|
|
|
|
+const change = async () => {
|
|
|
|
+ try {
|
|
|
|
+ const { data } = await userApi.phone({
|
|
|
|
+ mobile: mobile.value,
|
|
|
|
+ code: code.value,
|
|
|
|
+ });
|
|
|
|
+ useUser();
|
|
|
|
+ dialog.value = false;
|
|
|
|
+ } catch (error) {}
|
|
|
|
+};
|
|
|
|
|
|
const enter = () => {
|
|
const enter = () => {
|
|
dialogVisible.value = false;
|
|
dialogVisible.value = false;
|
|
@@ -197,9 +448,6 @@ const save = async () => {
|
|
dialogVisible.value = false;
|
|
dialogVisible.value = false;
|
|
} catch (error) {}
|
|
} catch (error) {}
|
|
};
|
|
};
|
|
-//账号安全
|
|
|
|
-const dialog = ref(true);
|
|
|
|
-
|
|
|
|
//防抖
|
|
//防抖
|
|
const handleSwitchSubNav = debounce((type) => {
|
|
const handleSwitchSubNav = debounce((type) => {
|
|
if (subNavCurrent.value === type) return;
|
|
if (subNavCurrent.value === type) return;
|
|
@@ -209,6 +457,77 @@ const handleSwitchSubNav = debounce((type) => {
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
<style lang="scss" scoped>
|
|
@import "~/styles/variable.scss";
|
|
@import "~/styles/variable.scss";
|
|
|
|
+//消息推送
|
|
|
|
+.zhi {
|
|
|
|
+ font-family: PingFangSC, PingFang SC;
|
|
|
|
+ font-weight: 500;
|
|
|
|
+ font-size: 16px;
|
|
|
|
+ color: #333333;
|
|
|
|
+ line-height: 22px;
|
|
|
|
+ text-align: left;
|
|
|
|
+ font-style: normal;
|
|
|
|
+ margin-right: 20px;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+//邀请与推广
|
|
|
|
+.activein {
|
|
|
|
+ width: 76px;
|
|
|
|
+ height: 34px;
|
|
|
|
+ background: #00b0b0;
|
|
|
|
+ border-radius: 4px;
|
|
|
|
+ font-family: PingFangSC, PingFang SC;
|
|
|
|
+ font-weight: 500;
|
|
|
|
+ font-size: 14px;
|
|
|
|
+ color: #ffffff;
|
|
|
|
+ line-height: 34px;
|
|
|
|
+ text-align: center;
|
|
|
|
+ font-style: normal;
|
|
|
|
+ cursor: pointer;
|
|
|
|
+}
|
|
|
|
+.myin {
|
|
|
|
+ width: 76px;
|
|
|
|
+ font-family: PingFangSC, PingFang SC;
|
|
|
|
+ font-weight: 500;
|
|
|
|
+ font-size: 14px;
|
|
|
|
+ color: #555555;
|
|
|
|
+ line-height: 20px;
|
|
|
|
+ text-align: center;
|
|
|
|
+ font-style: normal;
|
|
|
|
+ cursor: pointer;
|
|
|
|
+}
|
|
|
|
+.myfriend {
|
|
|
|
+ width: 112px;
|
|
|
|
+ height: 42px;
|
|
|
|
+ background: #00b0b0;
|
|
|
|
+ border-radius: 4px;
|
|
|
|
+ font-family: PingFangSC, PingFang SC;
|
|
|
|
+ font-weight: 400;
|
|
|
|
+ font-size: 16px;
|
|
|
|
+ color: #ffffff;
|
|
|
|
+ line-height: 42px;
|
|
|
|
+ text-align: center;
|
|
|
|
+ font-style: normal;
|
|
|
|
+}
|
|
|
|
+.bei {
|
|
|
|
+ font-family: SFPro, SFPro;
|
|
|
|
+ font-weight: 500;
|
|
|
|
+ font-size: 16px;
|
|
|
|
+ color: #333333;
|
|
|
|
+ line-height: 19px;
|
|
|
|
+ letter-spacing: 1px;
|
|
|
|
+ text-align: left;
|
|
|
|
+ font-style: normal;
|
|
|
|
+}
|
|
|
|
+.time {
|
|
|
|
+ font-family: SFPro, SFPro;
|
|
|
|
+ font-weight: 400;
|
|
|
|
+ font-size: 16px;
|
|
|
|
+ color: #555555;
|
|
|
|
+ line-height: 19px;
|
|
|
|
+ letter-spacing: 1px;
|
|
|
|
+ text-align: left;
|
|
|
|
+ font-style: normal;
|
|
|
|
+}
|
|
// 账号安全
|
|
// 账号安全
|
|
.code {
|
|
.code {
|
|
font-family: PingFangSC, PingFang SC;
|
|
font-family: PingFangSC, PingFang SC;
|
|
@@ -337,7 +656,6 @@ ul {
|
|
padding: 0;
|
|
padding: 0;
|
|
margin: 0;
|
|
margin: 0;
|
|
}
|
|
}
|
|
-
|
|
|
|
.personal {
|
|
.personal {
|
|
// &-container {}
|
|
// &-container {}
|
|
&-header {
|
|
&-header {
|