feat:Configuration、Performance、MML权限按钮添加

This commit is contained in:
zhongzm
2025-09-04 14:25:26 +08:00
parent f155a0dc8e
commit 4293c611be
7 changed files with 40 additions and 15 deletions

View File

@@ -625,6 +625,7 @@ onMounted(() => {
size="small"
@click.prevent="fnCleanFrom"
v-if="!!state.mmlSelect.param"
v-perms:has="['mmlManage:neOperate:reset']"
>
<template #icon>
<ClearOutlined />
@@ -636,6 +637,7 @@ onMounted(() => {
size="small"
:loading="state.from.sendLoading"
@click.prevent="fnSendMML"
v-perms:has="['mmlManage:neOperate:execute']"
>
<template #icon>
<SendOutlined />

View File

@@ -592,6 +592,7 @@ onMounted(() => {
size="small"
@click.prevent="fnCleanFrom"
v-if="!!state.mmlSelect.param"
v-perms:has="['mmlManage:udmOperate:reset']"
>
<template #icon>
<ClearOutlined />
@@ -603,6 +604,7 @@ onMounted(() => {
size="small"
:loading="state.from.sendLoading"
@click.prevent="fnSendMML"
v-perms:has="['mmlManage:udmOperate:execute']"
>
<template #icon>
<SendOutlined />

View File

@@ -438,7 +438,7 @@ onMounted(() => {
<PageContainer>
<template #content> </template>
<template #contentExtra>
<a-button type="primary" @click="fnBaseOpen">
<a-button type="primary" @click="fnBaseOpen" v-perms:has="['ne:neConfig:edit']">
Quickly Modify PLMN
</a-button>
</template>
@@ -640,6 +640,7 @@ onMounted(() => {
!listState.confirmLoading &&
!['read-only', 'read', 'ro'].includes(record.access)
"
v-perms:has="['ne:neConfig:edit']"
/>
</div>
</div>

View File

@@ -1,5 +1,5 @@
<script setup lang="ts">
import { reactive, onMounted, toRaw, defineAsyncComponent, ref } from 'vue';
import { reactive, onMounted, toRaw, defineAsyncComponent, ref, computed } from 'vue';
import { PageContainer } from 'antdv-pro-layout';
import { message, Modal } from 'ant-design-vue/es';
import { SizeType } from 'ant-design-vue/es/config-provider';
@@ -12,6 +12,7 @@ import { listNeInfo, delNeInfo, stateNeInfo } from '@/api/ne/neInfo';
import { NE_TYPE_LIST } from '@/constants/ne-constants';
import useDictStore from '@/store/modules/dict';
import useNeOptions from './hooks/useNeOptions';
import { hasPermissions } from '@/plugins/auth-user';
const { getDict } = useDictStore();
const { t } = useI18n();
const { fnNeStart, fnNeRestart, fnNeStop, fnNeReload, fnNeLogFile } =
@@ -28,7 +29,15 @@ const BackConfModal = defineAsyncComponent(
() => import('./components/BackConfModal.vue')
);
const backConf = ref(); // 引用句柄,取导出函数
// 计算是否至少拥有一个批量操作权限
const hasAnyBatchPermission = computed(() => {
return hasPermissions(['ne:neInfo:logs']) ||
hasPermissions(['ne:neInfo:start']) ||
hasPermissions(['ne:neInfo:stop'])||
hasPermissions(['ne:neInfo:delete'])||
hasPermissions(['ne:neInfo:export'])||
hasPermissions(['ne:neInfo:import']);
});
/**字典数据 */
let dict: {
/**网元信息状态 */
@@ -498,7 +507,7 @@ onMounted(() => {
<!-- 插槽-卡片左侧侧 -->
<template #title>
<a-space :size="8" align="center">
<a-button type="primary" @click.prevent="fnModalVisibleByEdit()">
<a-button type="primary" @click.prevent="fnModalVisibleByEdit()" v-perms:has="['ne:neInfo:add']">
<template #icon><PlusOutlined /></template>
{{ t('common.addText') }}
</a-button>
@@ -508,6 +517,7 @@ onMounted(() => {
:disabled="tableState.selectedRowKeys.length <= 0"
:loading="modalState.confirmLoading"
@click.prevent="fnRecordDelete('0')"
v-perms:has="['ne:neInfo:delete']"
>
<template #icon><DeleteOutlined /></template>
{{ t('common.deleteText') }}
@@ -588,6 +598,7 @@ onMounted(() => {
<a-button
type="link"
@click.prevent="fnModalVisibleByEdit(record)"
v-perms:has="['ne:neInfo:edit']"
>
<template #icon><FormOutlined /></template>
</a-button>
@@ -599,27 +610,28 @@ onMounted(() => {
<a-button
type="link"
@click.prevent="fnRecordMore('restart', record)"
v-perms:has="['ne:neInfo:restart']"
>
<template #icon><UndoOutlined /></template>
</a-button>
</a-tooltip>
<a-tooltip placement="left">
<template #title>{{ t('common.moreText') }}</template>
<a-dropdown placement="bottomRight" trigger="click">
<a-dropdown placement="bottomRight" trigger="click" v-if="hasAnyBatchPermission">
<a-button type="link">
<template #icon><EllipsisOutlined /> </template>
</a-button>
<template #overlay>
<a-menu @click="({ key }:any) => fnRecordMore(key, record)">
<a-menu-item key="log">
<a-menu-item key="log" v-if="hasPermissions(['ne:neInfo:logs'])">
<FileTextOutlined />
{{ t('views.ne.common.log') }}
</a-menu-item>
<a-menu-item key="start">
<a-menu-item key="start" v-if="hasPermissions(['ne:neInfo:start'])">
<ThunderboltOutlined />
{{ t('views.ne.common.start') }}
</a-menu-item>
<a-menu-item key="stop">
<a-menu-item key="stop" v-if="hasPermissions(['ne:neInfo:stop'])">
<CloseSquareOutlined />
{{ t('views.ne.common.stop') }}
</a-menu-item>
@@ -632,7 +644,7 @@ onMounted(() => {
<SyncOutlined />
{{ t('views.ne.common.reload') }}
</a-menu-item>
<a-menu-item key="delete">
<a-menu-item key="delete" v-if="hasPermissions(['ne:neInfo:delete'])">
<DeleteOutlined />
{{ t('common.deleteText') }}
</a-menu-item>
@@ -644,11 +656,11 @@ onMounted(() => {
{{ t('views.ne.common.oam') }}
</a-menu-item>
<!-- 配置备份 -->
<a-menu-item key="backConfExport">
<a-menu-item key="backConfExport" v-if="hasPermissions(['ne:neInfo:export'])">
<ExportOutlined />
{{ t('views.ne.neInfo.backConf.export') }}
</a-menu-item>
<a-menu-item key="backConfImport">
<a-menu-item key="backConfImport" v-if="hasPermissions(['ne:neInfo:import'])">
<ImportOutlined />
{{ t('views.ne.neInfo.backConf.import') }}
</a-menu-item>

View File

@@ -263,7 +263,7 @@ function fnModalOk(e: any) {
if (res.code === RESULT_CODE_SUCCESS) {
row.status = '1';
row.serialNum = res.data.sn;
row.expiryDate = res.data.expire;
row.expiryDate = res.data.expire;
row.ueNumber = res.data.ueNumber;
row.nbNumber = res.data.nbNumber;
} else {
@@ -445,6 +445,7 @@ onMounted(() => {
type="default"
:loading="modalState.confirmLoading"
@click.prevent="fnRecordStateReload()"
v-perms:has="['ne:neLicense:refresh']"
>
<template #icon><SyncOutlined /></template>
{{ t('views.ne.neLicense.reloadBatch') }}
@@ -519,7 +520,7 @@ onMounted(() => {
<a-space :size="8" align="center">
<a-tooltip placement="topRight">
<template #title>{{ t('views.ne.neLicense.reload') }}</template>
<a-button type="link" @click.prevent="fnRecordState(record)">
<a-button type="link" @click.prevent="fnRecordState(record)" v-perms:has="['ne:neLicense:refresh']">
<template #icon><SyncOutlined /> </template>
</a-button>
</a-tooltip>
@@ -528,6 +529,7 @@ onMounted(() => {
<a-button
type="link"
@click.prevent="fnModalVisibleByEdit(record.id)"
v-perms:has="['ne:neLicense:edit']"
>
<template #icon><UploadOutlined /> </template>
</a-button>

View File

@@ -520,6 +520,7 @@ onMounted(() => {
@click.prevent="
() => (modalState.openByEdit = !modalState.openByEdit)
"
v-perms:has="['ne:neVersion:upload']"
>
<template #icon><UploadOutlined /></template>
{{ t('views.ne.neSoftware.upload') }}
@@ -530,6 +531,7 @@ onMounted(() => {
@click.prevent="
() => (modalState.openByMoreFile = !modalState.openByMoreFile)
"
v-perms:has="['ne:neVersion:upload']"
>
<template #icon><UploadOutlined /></template>
<template v-if="tableState.selectedRowOne.neType">
@@ -546,6 +548,7 @@ onMounted(() => {
:disabled="tableState.selectedRowKeys.length <= 0"
:loading="modalState.confirmLoading"
@click.prevent="fnRecordUpgradeConfirm()"
v-perms:has="['ne:neVersion:upgrade']"
>
<template #icon><ThunderboltOutlined /></template>
{{ t('views.ne.neVersion.upgradeBatch') }}
@@ -659,6 +662,7 @@ onMounted(() => {
<a-button
type="link"
@click.prevent="fnRecordVersion('upgrade', record)"
v-perms:has="['ne:neVersion:upgrade']"
>
<template #icon><ThunderboltOutlined /></template>
</a-button>
@@ -670,6 +674,7 @@ onMounted(() => {
<a-button
type="link"
@click.prevent="fnRecordVersion('rollback', record)"
v-perms:has="['ne:neVersion:previous']"
>
<template #icon><RollbackOutlined /></template>
</a-button>

View File

@@ -534,7 +534,7 @@ onMounted(() => {
<a-card :bordered="false" :body-style="{ padding: '0px' }">
<!-- 插槽-卡片左侧侧 -->
<template #title>
<a-button type="primary" @click.prevent="fnModalVisibleByEdit()">
<a-button type="primary" @click.prevent="fnModalVisibleByEdit()" v-perms:has="['perfManage:customTarget:add']">
<template #icon><PlusOutlined /></template>
{{ t('common.addText') }}
</a-button>
@@ -604,13 +604,14 @@ onMounted(() => {
<a-button
type="link"
@click.prevent="fnModalVisibleByEdit(record, record.id)"
v-perms:has="['perfManage:customTarget:edit']"
>
<template #icon><FormOutlined /></template>
</a-button>
</a-tooltip>
<a-tooltip>
<template #title>{{ t('common.deleteText') }}</template>
<a-button type="link" @click.prevent="fnRecordDelete(record)">
<a-button type="link" @click.prevent="fnRecordDelete(record)" v-perms:has="['perfManage:customTarget:delete']">
<template #icon><DeleteOutlined /></template>
</a-button>
</a-tooltip>