2021-02-04 18:13:03 +08:00
|
|
|
<template>
|
2021-02-05 01:15:37 +08:00
|
|
|
<div v-if="getUserAuthBtnList">
|
2021-02-04 18:13:03 +08:00
|
|
|
<slot />
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts">
|
|
|
|
import { computed } from "vue";
|
|
|
|
import { useStore } from "/@/store/index.ts";
|
|
|
|
export default {
|
|
|
|
nane: "authAll",
|
|
|
|
props: {
|
|
|
|
value: {
|
|
|
|
type: Array,
|
|
|
|
default: () => [],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
setup(props) {
|
|
|
|
const store = useStore();
|
2021-02-05 01:15:37 +08:00
|
|
|
// 判断两数组是否相同
|
|
|
|
const judementSameArr = (news, old) => {
|
|
|
|
let count = 0;
|
|
|
|
const leng = old.length;
|
|
|
|
for (let i in old) {
|
|
|
|
for (let j in news) {
|
|
|
|
if (old[i] === news[j]) count++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return count === leng ? true : false;
|
|
|
|
};
|
2021-02-04 18:13:03 +08:00
|
|
|
// 获取 vuex 中的用户权限
|
2021-02-05 01:15:37 +08:00
|
|
|
const getUserAuthBtnList = computed(() => {
|
|
|
|
return judementSameArr(props.value, store.state.userInfos.authBtnList);
|
2021-02-04 18:13:03 +08:00
|
|
|
});
|
|
|
|
return {
|
2021-02-05 01:15:37 +08:00
|
|
|
getUserAuthBtnList,
|
2021-02-04 18:13:03 +08:00
|
|
|
};
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|