From 5c14b28f11b776ae3209bfef83c3700291d6a804 Mon Sep 17 00:00:00 2001 From: kalencaya <1942460489@qq.com> Date: Fri, 29 Dec 2023 21:26:26 +0800 Subject: [PATCH] [Feature][scaleph-ui-react] update flink kubernetes session cluster web (#677) * feature: add xflow event listener * feature: update flink kubernetes session cluster * feature: add tooltip for flink kubernetes * feature: add tooltip for flink kubernetes --------- Co-authored-by: wangqi --- .../src/locales/zh-CN/pages/project.ts | 18 +++-- .../flinkKubernetesSessionClusterDetail.ts | 29 +++++-- .../DI/DiJobFlow/Dag/config-graph.tsx | 32 +++++++- .../Deployment/Steps/New/ClusterStepForm.tsx | 12 ++- .../Workspace/Kubernetes/Deployment/index.tsx | 21 +---- .../Workspace/Kubernetes/Job/Detail/index.tsx | 3 +- .../Workspace/Kubernetes/Job/JobForm.tsx | 7 +- .../Workspace/Kubernetes/Job/index.tsx | 12 ++- ...linkKubernetesSessionClusterStatusYaml.tsx | 38 ++++++++++ .../FlinkKubernetesSessionClusterYaml.tsx | 38 ++++++++++ .../SessionCluster/Detail/YAML/index.tsx | 76 +++++-------------- .../SessionCluster/Detail/index.tsx | 52 ++++++++----- .../Steps/New/ClusterStepForm.tsx | 9 +++ .../Kubernetes/SessionCluster/index.tsx | 7 +- .../Workspace/Kubernetes/Template/index.tsx | 5 +- .../src/services/project/typings.d.ts | 1 + 16 files changed, 235 insertions(+), 125 deletions(-) create mode 100644 scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/SessionCluster/Detail/YAML/FlinkKubernetesSessionClusterStatusYaml.tsx create mode 100644 scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/SessionCluster/Detail/YAML/FlinkKubernetesSessionClusterYaml.tsx diff --git a/scaleph-ui-react/src/locales/zh-CN/pages/project.ts b/scaleph-ui-react/src/locales/zh-CN/pages/project.ts index 0ff809c13..acd266080 100644 --- a/scaleph-ui-react/src/locales/zh-CN/pages/project.ts +++ b/scaleph-ui-react/src/locales/zh-CN/pages/project.ts @@ -822,7 +822,7 @@ export default { 'pages.project.flink.kubernetes.template.deploymentKind': '部署模式', 'pages.project.flink.kubernetes.template.namespace': 'Namespace', 'pages.project.flink.kubernetes.template.namespace.tooltip': '填写 Kubernetes Namespace', - 'pages.project.flink.kubernetes.template.flinkVersion': 'Flink 版本', + 'pages.project.flink.kubernetes.template.flinkVersion': 'Flink', 'pages.project.flink.kubernetes.template.image': '镜像', 'pages.project.flink.kubernetes.template.update': '修改模板', 'pages.project.flink.kubernetes.template.detail': '模板详情', @@ -834,20 +834,25 @@ export default { 'pages.project.flink.kubernetes.template.step.yaml': 'YAML', 'pages.project.flink.kubernetes.session-cluster': 'SessionCluster', + 'pages.project.flink.kubernetes.session-cluster.sessionClusterId': 'ID', 'pages.project.flink.kubernetes.session-cluster.name': '名称', - 'pages.project.flink.kubernetes.session-cluster.flinkVersion': 'Flink 版本', + 'pages.project.flink.kubernetes.session-cluster.flinkVersion': 'Flink', 'pages.project.flink.kubernetes.session-cluster.image': '镜像', 'pages.project.flink.kubernetes.session-cluster.namespace': 'Namespace', 'pages.project.flink.kubernetes.session-cluster.sql-gateway': 'Sql Gateway', - 'pages.project.flink.kubernetes.session-cluster.state': 'State', - 'pages.project.flink.kubernetes.session-cluster.error': 'Error', + 'pages.project.flink.kubernetes.session-cluster.state': '状态', + 'pages.project.flink.kubernetes.session-cluster.error': '异常', 'pages.project.flink.kubernetes.session-cluster.remark': 'remark', 'pages.project.flink.kubernetes.session-cluster.steps.cluster': 'Cluster & Template', 'pages.project.flink.kubernetes.session-cluster.steps.cluster.template': 'Template', 'pages.project.flink.kubernetes.session-cluster.steps.cluster.cluster': 'Cluster', + 'pages.project.flink.kubernetes.session-cluster.steps.cluster.cluster.tooltip': '选择部署的 Kubernetes', 'pages.project.flink.kubernetes.session-cluster.steps.options': 'Options', 'pages.project.flink.kubernetes.session-cluster.steps.yaml': 'YAML', + 'pages.project.flink.kubernetes.session-cluster.steps.yaml.instance': '实例', + 'pages.project.flink.kubernetes.session-cluster.steps.yaml.status': '状态', + 'pages.project.flink.kubernetes.session-cluster.detail': 'Session集群详情', 'pages.project.flink.kubernetes.session-cluster.detail.deploy': 'Deploy', 'pages.project.flink.kubernetes.session-cluster.detail.suspend': 'Suspend', 'pages.project.flink.kubernetes.session-cluster.detail.shutdown': 'Shutdown', @@ -865,12 +870,13 @@ export default { 'pages.project.flink.kubernetes.deployment.kind': '类型', 'pages.project.flink.kubernetes.deployment.name': '名称', 'pages.project.flink.kubernetes.deployment.type': '类型', - 'pages.project.flink.kubernetes.deployment.flinkVersion': 'Flink 版本', + 'pages.project.flink.kubernetes.deployment.flinkVersion': 'Flink', 'pages.project.flink.kubernetes.deployment.image': '镜像', 'pages.project.flink.kubernetes.deployment.namespace': 'Namespace', 'pages.project.flink.kubernetes.deployment.steps.cluster': 'Cluster & Template', 'pages.project.flink.kubernetes.deployment.steps.cluster.template': 'Template', 'pages.project.flink.kubernetes.deployment.steps.cluster.cluster': 'Cluster', + 'pages.project.flink.kubernetes.deployment.steps.cluster.cluster.tooltip': '选择部署的 Kubernetes', 'pages.project.flink.kubernetes.deployment.steps.options': 'Options', 'pages.project.flink.kubernetes.deployment.steps.yaml': 'YAML', @@ -892,7 +898,7 @@ export default { 'pages.project.flink.kubernetes.job.state': 'Deploy State', 'pages.project.flink.kubernetes.job.error': 'Error', - 'pages.project.flink.kubernetes.job.detail': '详情', + 'pages.project.flink.kubernetes.job.detail': '任务详情', 'pages.project.flink.kubernetes.job.detail.deploy': 'Deploy', 'pages.project.flink.kubernetes.job.detail.deploy.resource': 'Resource', 'pages.project.flink.kubernetes.job.detail.deploy.resource.jobManagerCpu': 'JobManager CPU', diff --git a/scaleph-ui-react/src/models/project/workspace/kubernetes/sessionCluster/flinkKubernetesSessionClusterDetail.ts b/scaleph-ui-react/src/models/project/workspace/kubernetes/sessionCluster/flinkKubernetesSessionClusterDetail.ts index f484e57e1..c7eee452d 100644 --- a/scaleph-ui-react/src/models/project/workspace/kubernetes/sessionCluster/flinkKubernetesSessionClusterDetail.ts +++ b/scaleph-ui-react/src/models/project/workspace/kubernetes/sessionCluster/flinkKubernetesSessionClusterDetail.ts @@ -1,9 +1,12 @@ import {WsFlinkKubernetesSessionCluster} from "@/services/project/typings"; import {Effect, Reducer} from "umi"; import {WsFlinkKubernetesSessionClusterService} from "@/services/project/WsFlinkKubernetesSessionClusterService"; +import YAML from "yaml"; export interface StateType { sessionCluster: WsFlinkKubernetesSessionCluster, + sessionClusterYaml: string, + sessionClusterStatusYaml: string, } export interface ModelType { @@ -12,11 +15,11 @@ export interface ModelType { state: StateType; effects: { - queryTemplate: Effect; + querySessionCluster: Effect; }; reducers: { - updateTemplate: Reducer; + updateSessionCluster: Reducer; }; } @@ -25,12 +28,26 @@ const model: ModelType = { state: { sessionCluster: null, + sessionClusterYaml: null, + sessionClusterStatusYaml: null, }, effects: { - *querySessionCluster({payload}, {call, put}) { + * querySessionCluster({payload}, {call, put}) { const {data} = yield call(WsFlinkKubernetesSessionClusterService.selectOne, payload); - yield put({type: 'updateSessionCluster', payload: {sessionCluster: data}}); + const param = {...data} + param.deployed = undefined + param.state = undefined + const response = yield call(WsFlinkKubernetesSessionClusterService.asYAML, param); + const statusReponse = yield call(WsFlinkKubernetesSessionClusterService.status, param); + yield put({ + type: 'updateSessionCluster', + payload: { + sessionCluster: data, + sessionClusterYaml: YAML.stringify(response.data), + sessionClusterStatusYaml: YAML.stringify(statusReponse.data) + } + }); }, }, @@ -38,7 +55,9 @@ const model: ModelType = { updateSessionCluster(state, {payload}) { return { ...state, - sessionCluster: payload.sessionCluster + sessionCluster: payload.sessionCluster, + sessionClusterYaml: payload.sessionClusterYaml, + sessionClusterStatusYaml: payload.sessionClusterStatusYaml }; }, }, diff --git a/scaleph-ui-react/src/pages/Project/Workspace/Artifact/DI/DiJobFlow/Dag/config-graph.tsx b/scaleph-ui-react/src/pages/Project/Workspace/Artifact/DI/DiJobFlow/Dag/config-graph.tsx index c7d964c74..80a76502d 100644 --- a/scaleph-ui-react/src/pages/Project/Workspace/Artifact/DI/DiJobFlow/Dag/config-graph.tsx +++ b/scaleph-ui-react/src/pages/Project/Workspace/Artifact/DI/DiJobFlow/Dag/config-graph.tsx @@ -3,7 +3,7 @@ import type { EventArgs } from '@antv/x6/lib/graph/events'; import { createGraphConfig, createHookConfig, - DisposableCollection, + DisposableCollection, IEvent, NsGraph, NsNodeCmd, XFlowNodeCommands, @@ -206,4 +206,34 @@ export const useGraphConfig = createGraphConfig((config) => { }, }, }); + + // 配置不同组件的 node 和 edge 组件 + config.setNodeRender(DND_RENDER_ID, BaseNode) + + // 节点事件 + const edgeAdded: IEvent<'edge:added'> = { + eventName: 'edge:added', + callback: (eventArgs, command, modelService) => { + console.log('edge:added', eventArgs, e) + }, + } + const edgeRemoved: IEvent<'edge:removed'> = { + eventName: 'edge:removed', + callback: (eventArgs, command, modelService) => { + console.log('edge:removed', eventArgs, e) + }, + } + const nodeAdded: IEvent<'node:added'> = { + eventName: 'node:added', + callback: (eventArgs, command, modelService) => { + console.log('node:added', eventArgs, e) + }, + } + const nodeRemoved: IEvent<'node:removed'> = { + eventName: 'node:removed', + callback: (eventArgs, command, modelService) => { + console.log('node:removed', eventArgs, e) + }, + } + config.setEvents([edgeAdded, edgeRemoved, nodeAdded, nodeRemoved]) }); diff --git a/scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/Deployment/Steps/New/ClusterStepForm.tsx b/scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/Deployment/Steps/New/ClusterStepForm.tsx index 03ae328e0..03d8057f2 100644 --- a/scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/Deployment/Steps/New/ClusterStepForm.tsx +++ b/scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/Deployment/Steps/New/ClusterStepForm.tsx @@ -1,12 +1,12 @@ -import {useIntl} from "umi"; +import {connect, useIntl} from "umi"; import React from "react"; import {ProCard, ProFormSelect, ProFormText, ProFormTextArea} from "@ant-design/pro-components"; +import {InfoCircleOutlined} from "@ant-design/icons"; import {WsFlinkKubernetesTemplateService} from "@/services/project/WsFlinkKubernetesTemplateService"; import {WsFlinkKubernetesTemplateParam} from "@/services/project/typings"; import {ClusterCredentialService} from "@/services/resource/clusterCredential.service"; import {ClusterCredentialListParam} from "@/services/resource/typings"; import {WORKSPACE_CONF} from "@/constants/constant"; -import {connect} from "umi"; import {DeploymentKind} from "@/constants/enum"; const DeploymentClusterStepForm: React.FC = (props: any) => { @@ -23,6 +23,10 @@ const DeploymentClusterStepForm: React.FC = (props: any) => { , + }} rules={[{required: true}]} allowClear={false} request={((params, props) => { @@ -39,6 +43,10 @@ const DeploymentClusterStepForm: React.FC = (props: any) => { , + }} rules={[{required: true}]} initialValue={"default"} /> diff --git a/scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/Deployment/index.tsx b/scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/Deployment/index.tsx index db9e7c99e..c153bf18b 100644 --- a/scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/Deployment/index.tsx +++ b/scaleph-ui-react/src/pages/Project/Workspace/Kubernetes/Deployment/index.tsx @@ -1,7 +1,7 @@ import {history, useAccess, useIntl} from "umi"; import React, {useRef, useState} from "react"; import {Button, message, Modal, Space, Tag, Tooltip} from "antd"; -import {DeleteOutlined, EditOutlined, EyeOutlined} from "@ant-design/icons"; +import {DeleteOutlined, EditOutlined} from "@ant-design/icons"; import {ActionType, ProColumns, ProFormInstance, ProFormSelect, ProTable} from "@ant-design/pro-components"; import {WORKSPACE_CONF} from "@/constants/constant"; import {PRIVILEGE_CODE} from "@/constants/privilegeCode"; @@ -22,7 +22,7 @@ const FlinkKubernetesDeploymentWeb: React.FC = () => { { title: intl.formatMessage({id: 'pages.project.flink.kubernetes.deployment.name'}), dataIndex: 'name', - width: 200, + width: '10%', }, { title: intl.formatMessage({id: 'pages.project.flink.kubernetes.deployment.flinkVersion'}), @@ -58,19 +58,18 @@ const FlinkKubernetesDeploymentWeb: React.FC = () => { title: intl.formatMessage({id: 'app.common.data.remark'}), dataIndex: 'remark', hideInSearch: true, - width: 180, }, { title: intl.formatMessage({id: 'app.common.data.createTime'}), dataIndex: 'createTime', hideInSearch: true, - width: 180, + width: '8%', }, { title: intl.formatMessage({id: 'app.common.data.updateTime'}), dataIndex: 'updateTime', hideInSearch: true, - width: 180, + width: '8%', }, { title: intl.formatMessage({id: 'app.common.operate.label'}), @@ -93,18 +92,6 @@ const FlinkKubernetesDeploymentWeb: React.FC = () => { /> )} - {access.canAccess(PRIVILEGE_CODE.datadevJobEdit) && ( - -