Skip to content

Commit

Permalink
[Feature][Web] Add tag right-click function (#3903)
Browse files Browse the repository at this point in the history
Signed-off-by: Zzm0809 <[email protected]>
Co-authored-by: Zzm0809 <[email protected]>
Co-authored-by: ZackYoung <[email protected]>
Co-authored-by: zackyoungh <[email protected]>
  • Loading branch information
4 people authored Nov 12, 2024
1 parent c8c087d commit 233cb2a
Show file tree
Hide file tree
Showing 13 changed files with 1,125 additions and 50 deletions.
33 changes: 13 additions & 20 deletions dinky-web/src/pages/DataStudioNew/CenterTabContent/SqlTask.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,6 @@ export const SqlTask = memo((props: FlinkSqlProps & any) => {
updateCenterTab({ ...props.tabData, params: newParams });

setOriginStatementValue(statement);

if (params?.statement && params?.statement !== taskDetail.statement) {
setDiff([{ key: 'statement', server: taskDetail.statement, cache: params.statement }]);
setOpenDiffModal(true);
Expand Down Expand Up @@ -198,13 +197,7 @@ export const SqlTask = memo((props: FlinkSqlProps & any) => {
editorInstance.current = editor;
// @ts-ignore
editor['id'] = currentState.taskId;
editor.onDidChangeCursorPosition((e) => {
// props.footContainerCacher.cache.codePosition = [e.position.lineNumber, e.position.column];
// dispatch({
// type: STUDIO_MODEL.saveFooterValue,
// payload: { ...props.footContainerCacher.cache }
// });
});
editor.onDidChangeCursorPosition((e) => {});
registerEditorKeyBindingAndAction(editor);
};

Expand Down Expand Up @@ -422,28 +415,28 @@ export const SqlTask = memo((props: FlinkSqlProps & any) => {
updateAction({
actionType: DataStudioActionType.TASK_RUN_DEBUG,
params: {
taskId: params.taskId,
columns: res.data?.result?.columns ?? [],
rowData: res.data?.result?.rowData ?? [],
taskId: params.taskId
}
});
setCurrentState((prevState) => {
return {
...prevState,
status: res.data.status === 'SUCCESS' ? (res.data.pipeline?'RUNNING':'SUCCESS') : res.data.status
status: res.data.status === 'SUCCESS' ? 'RUNNING' : res.data.status
};
});
}
}, [currentState, updateAction]);

const handleStop = useCallback(async () => {
const result = await cancelTask('', currentState.taskId, false);
setCurrentState((prevState) => {
return {
...prevState,
status: 'CANCEL'
};
});
if (result.success) {
setCurrentState((prevState) => {
return {
...prevState,
status: 'CANCEL'
};
});
}
}, [currentState.taskId]);

const handleGotoDevOps = useCallback(async () => {
Expand Down Expand Up @@ -753,10 +746,10 @@ export const SqlTask = memo((props: FlinkSqlProps & any) => {
<Panel>
<CodeEdit
monacoRef={editorInstance}
code={currentState.statement}
code={originStatementValue}
language={matchLanguage(currentState.dialect)}
editorDidMount={editorDidMount}
onChange={debounce(onEditorChange, 500)}
onChange={debounce(onEditorChange, 50)}
enableSuggestions={true}
options={{
readOnlyMessage: {
Expand Down
37 changes: 37 additions & 0 deletions dinky-web/src/pages/DataStudioNew/ContextMenuSpace.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
/*
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/

import { Space } from 'antd';
import React from 'react';

interface ContextMenuSpaceProps {
onContextMenu: (e: React.MouseEvent<HTMLElement>) => void;
children: React.ReactNode | JSX.Element | string;
}

export const ContextMenuSpace = (props: ContextMenuSpaceProps) => {
const { onContextMenu, children } = props;
return (
<>
<Space onContextMenu={onContextMenu} size={0}>
{children}
</Space>
</>
);
};
2 changes: 1 addition & 1 deletion dinky-web/src/pages/DataStudioNew/DockLayoutFunction.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ export const createNewPanel = (
{
id: route.key,
content: <></>,
title: route.title,
title: route.title(),
group: route.position
}
]
Expand Down
Loading

0 comments on commit 233cb2a

Please sign in to comment.