diff --git a/bcs-ui/frontend/src/components/metric.vue b/bcs-ui/frontend/src/components/metric.vue index 8f35c913fb..ea07bc958f 100644 --- a/bcs-ui/frontend/src/components/metric.vue +++ b/bcs-ui/frontend/src/components/metric.vue @@ -164,7 +164,7 @@ export default defineComponent({ const series: any[] = []; data.forEach((item, index) => { const suffix = metricSuffix.value[index]; - const list = item?.result.map((result) => { + const list = item?.result?.map((result) => { // series 配置 const name = result.metric?.[metricNameProp.value] || metricMap[metrics[index]]; const defaultSeries = props.series[index] || {}; diff --git a/bcs-ui/frontend/src/composables/use-page.ts b/bcs-ui/frontend/src/composables/use-page.ts index 3904ba6983..6537b8aaf8 100644 --- a/bcs-ui/frontend/src/composables/use-page.ts +++ b/bcs-ui/frontend/src/composables/use-page.ts @@ -1,5 +1,7 @@ import { computed, ComputedRef, reactive, Ref } from 'vue'; +import $store from '@/store'; + export interface IPageConf { current: number; limit: number; @@ -31,7 +33,7 @@ export interface IPageConfResult { */ export default function usePageConf(data: Ref, options: IOptions = { current: 1, - limit: 10, + limit: $store.state.globalPageSize || 10, }): IPageConfResult { const pageConf = reactive({ current: options.current, @@ -51,6 +53,7 @@ export default function usePageConf(data: Ref, options: IOptions = { const pageSizeChange = (pageSize = 10) => { pageConf.limit = pageSize; + $store.commit('updatePageSize', pageSize); pageConf.current = 1; const { onPageSizeChange = null } = options; onPageSizeChange && typeof onPageSizeChange === 'function' && onPageSizeChange(pageSize); diff --git a/bcs-ui/frontend/src/store/index.ts b/bcs-ui/frontend/src/store/index.ts index f855593f46..9d4ff65cb8 100644 --- a/bcs-ui/frontend/src/store/index.ts +++ b/bcs-ui/frontend/src/store/index.ts @@ -77,6 +77,7 @@ const store = new Vuex.Store<{ isEn: boolean crdInstanceList: any[] cluster: typeof cluster.state + globalPageSize: number }>({ // todo 废弃模块 modules: { @@ -103,7 +104,7 @@ const store = new Vuex.Store<{ plugins: [ VuexStorage({ key: '__bcs_vuex_stroage__', - paths: ['curProject.projectID', 'curProject.projectCode', 'curProject.businessID', 'curCluster.clusterID', 'openSideMenu', 'curNamespace', 'clusterViewType'], + paths: ['curProject.projectID', 'curProject.projectCode', 'curProject.businessID', 'curCluster.clusterID', 'openSideMenu', 'curNamespace', 'clusterViewType', 'globalPageSize'], mutationEffect: [ { type: 'cluster/forceUpdateClusterList', @@ -129,6 +130,7 @@ const store = new Vuex.Store<{ clusterViewType: 'card', // 集群展示模式 card 或者 list isEn: lang === 'en-US', // todo 废弃 crdInstanceList: [], // todo 放入对应的module中 + globalPageSize: 10, } as any, // 公共 getters getters: { @@ -204,6 +206,9 @@ const store = new Vuex.Store<{ updateFeatureFlags(state, data) { state.featureFlags = data; }, + updatePageSize(state, size = 10) { + state.globalPageSize = size; + }, }, actions: { /** diff --git a/bcs-ui/frontend/src/views/cluster-manage/node-list/node-overview.vue b/bcs-ui/frontend/src/views/cluster-manage/node-list/node-overview.vue index 3aaa15992c..e5d733f81e 100644 --- a/bcs-ui/frontend/src/views/cluster-manage/node-list/node-overview.vue +++ b/bcs-ui/frontend/src/views/cluster-manage/node-list/node-overview.vue @@ -377,6 +377,7 @@ export default defineComponent({ params: { namespace, name, + clusterId: clusterId.value, }, query: { type: 'workloads', @@ -390,6 +391,7 @@ export default defineComponent({ params: { namespace, name, + clusterId: clusterId.value, }, query: { type: 'workloads', @@ -415,6 +417,7 @@ export default defineComponent({ $type: 'workloads', $category: 'pods', $name: name, + $clusterId: clusterId.value, }); result && $bkMessage({ theme: 'success', diff --git a/bcs-ui/frontend/src/views/resource-view/sidebar.vue b/bcs-ui/frontend/src/views/resource-view/sidebar.vue index 5420efa23a..f0cc4c1edb 100644 --- a/bcs-ui/frontend/src/views/resource-view/sidebar.vue +++ b/bcs-ui/frontend/src/views/resource-view/sidebar.vue @@ -20,7 +20,7 @@