@jx3box/jx3box-common-ui 7.7.6 → 7.7.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/header/langSwitch.vue +15 -4
- package/src/header/manage.vue +17 -44
package/package.json
CHANGED
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
v-for="item in langs"
|
|
9
9
|
:key="item.key"
|
|
10
10
|
@click="onLangChange(item.key)"
|
|
11
|
-
:class="{ 'is-active': item.key === currentLang }"
|
|
11
|
+
:class="{ 'is-active': item.key === currentLang, 'is-disabled': item.disabled }"
|
|
12
12
|
>
|
|
13
13
|
<a>{{ item.name }}</a>
|
|
14
14
|
</li>
|
|
@@ -30,17 +30,17 @@ export default {
|
|
|
30
30
|
{
|
|
31
31
|
name: "繁体中文",
|
|
32
32
|
key: "zh-tw",
|
|
33
|
-
disabled:
|
|
33
|
+
disabled: true,
|
|
34
34
|
},
|
|
35
35
|
{
|
|
36
36
|
name: "Tiếng Việt",
|
|
37
37
|
key: "vi",
|
|
38
|
-
disabled:
|
|
38
|
+
disabled: true,
|
|
39
39
|
},
|
|
40
40
|
{
|
|
41
41
|
name: "English",
|
|
42
42
|
key: "en-us",
|
|
43
|
-
disabled:
|
|
43
|
+
disabled: true,
|
|
44
44
|
},
|
|
45
45
|
], // 语言列表 简体中文、繁体中文、英文、越南语
|
|
46
46
|
currentLang: "zh-cn", // 当前语言
|
|
@@ -82,6 +82,17 @@ export default {
|
|
|
82
82
|
font-weight: 600;
|
|
83
83
|
}
|
|
84
84
|
}
|
|
85
|
+
&.is-disabled {
|
|
86
|
+
a {
|
|
87
|
+
color: #999;
|
|
88
|
+
cursor: not-allowed;
|
|
89
|
+
}
|
|
90
|
+
&:hover a {
|
|
91
|
+
// .tm(0);
|
|
92
|
+
background-color: #fff;
|
|
93
|
+
color: #999;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
85
96
|
}
|
|
86
97
|
}
|
|
87
98
|
@media screen and (max-width: @phone) {
|
package/src/header/manage.vue
CHANGED
|
@@ -4,21 +4,19 @@
|
|
|
4
4
|
<img class="u-add" svg-inline src="../../assets/img/header/manage.svg" />
|
|
5
5
|
</span>
|
|
6
6
|
<ul class="u-menu u-pop-content">
|
|
7
|
-
<li v-for="item in
|
|
7
|
+
<li v-for="item in userPanel" :key="item.label">
|
|
8
8
|
<a :href="item.link" :target="item.target || '_self'"
|
|
9
9
|
><i :class="item.icon || 'el-icon-present'"></i> {{ item.label }}</a
|
|
10
10
|
>
|
|
11
11
|
</li>
|
|
12
|
-
<hr v-if="
|
|
13
|
-
<
|
|
14
|
-
<
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
<a href="/dashboard/feedback?tab=pending"><i class="el-icon-message"></i> 反馈处理</a>
|
|
21
|
-
</li>
|
|
12
|
+
<hr v-if="userPanel.length" />
|
|
13
|
+
<template v-if="isEditor">
|
|
14
|
+
<li v-for="item in adminPanel" :key="item.label">
|
|
15
|
+
<a :href="item.link" :target="item.target || '_self'"
|
|
16
|
+
><i :class="item.icon || 'el-icon-present'"></i> {{ item.label }}</a
|
|
17
|
+
>
|
|
18
|
+
</li>
|
|
19
|
+
</template>
|
|
22
20
|
</ul>
|
|
23
21
|
</div>
|
|
24
22
|
</template>
|
|
@@ -27,31 +25,23 @@
|
|
|
27
25
|
import User from "@jx3box/jx3box-common/js/user";
|
|
28
26
|
import panel from "../../assets/data/panel.json";
|
|
29
27
|
import { getMenu } from "../../service/header";
|
|
30
|
-
import { checkTeamMember } from "../../service/cms";
|
|
31
28
|
export default {
|
|
32
29
|
name: "Manage",
|
|
33
30
|
data() {
|
|
34
31
|
return {
|
|
35
32
|
panel,
|
|
36
|
-
|
|
37
|
-
isTeamMember: false,
|
|
38
33
|
};
|
|
39
34
|
},
|
|
40
35
|
computed: {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
// 只返回有权限的
|
|
46
|
-
if (item.onlyAdmin) {
|
|
47
|
-
return this.isAdmin;
|
|
48
|
-
}
|
|
49
|
-
return true;
|
|
50
|
-
})
|
|
51
|
-
.slice(0, 2);
|
|
36
|
+
userPanel: function () {
|
|
37
|
+
return this.panel.filter((item) => {
|
|
38
|
+
return !item.onlyAdmin;
|
|
39
|
+
});
|
|
52
40
|
},
|
|
53
|
-
|
|
54
|
-
return
|
|
41
|
+
adminPanel: function () {
|
|
42
|
+
return this.panel.filter((item) => {
|
|
43
|
+
return item.onlyAdmin;
|
|
44
|
+
});
|
|
55
45
|
},
|
|
56
46
|
isEditor() {
|
|
57
47
|
return User.isEditor();
|
|
@@ -59,7 +49,6 @@ export default {
|
|
|
59
49
|
},
|
|
60
50
|
mounted() {
|
|
61
51
|
this.loadPanel();
|
|
62
|
-
this.check();
|
|
63
52
|
},
|
|
64
53
|
methods: {
|
|
65
54
|
loadPanel: function () {
|
|
@@ -78,22 +67,6 @@ export default {
|
|
|
78
67
|
console.log("loadPanel error", e);
|
|
79
68
|
}
|
|
80
69
|
},
|
|
81
|
-
check: function () {
|
|
82
|
-
try {
|
|
83
|
-
const isTeamMember = JSON.parse(localStorage.getItem("BoxTeam3"));
|
|
84
|
-
|
|
85
|
-
if (isTeamMember) {
|
|
86
|
-
this.isTeamMember = isTeamMember === "true" || isTeamMember;
|
|
87
|
-
} else {
|
|
88
|
-
checkTeamMember().then((res) => {
|
|
89
|
-
this.isTeamMember = res.data.data;
|
|
90
|
-
localStorage.setItem("BoxTeam3", this.isTeamMember);
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
} catch (e) {
|
|
94
|
-
console.log("check error", e);
|
|
95
|
-
}
|
|
96
|
-
},
|
|
97
70
|
},
|
|
98
71
|
};
|
|
99
72
|
</script>
|