feat: manually mirror opencoze's code from bytedance

Change-Id: I09a73aadda978ad9511264a756b2ce51f5761adf
This commit is contained in:
fanlv
2025-07-20 17:36:12 +08:00
commit 890153324f
14811 changed files with 1923430 additions and 0 deletions

View File

@@ -0,0 +1,108 @@
/*
* Copyright 2025 coze-dev Authors
*
* Licensed 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 React, { useState, useEffect, useMemo } from 'react';
import { I18n } from '@coze-arch/i18n';
import { IconCozExpand, IconCozMinimize } from '@coze-arch/coze-design/icons';
import { IconButton, Tooltip } from '@coze-arch/coze-design';
import {
type TabBarToolbar,
useCurrentWidget,
useProjectIDEServices,
useSplitScreenArea,
Command,
useShortcuts,
} from '@coze-project-ide/framework';
import s from './styles.module.less';
export const FullScreenButton = () => {
const projectIDEServices = useProjectIDEServices();
const currentWidget = useCurrentWidget<TabBarToolbar>();
const { keybinding } = useShortcuts(Command.Default.VIEW_FULL_SCREEN);
const direction = useSplitScreenArea(
currentWidget.currentURI,
currentWidget.tabBar,
);
const [tooltipVisible, setTooltipVisible] = useState(false);
const [fullScreen, setFullScreen] = useState(
projectIDEServices.view.isFullScreenMode,
);
useEffect(() => {
const disposable = projectIDEServices.view.onFullScreenModeChange(
isFullScreen => {
setFullScreen(isFullScreen);
},
);
return () => {
disposable.dispose();
};
}, []);
const icon = useMemo(() => {
if (fullScreen) {
return <IconCozMinimize />;
} else {
return <IconCozExpand />;
}
}, [fullScreen]);
const content = useMemo(
() => (
<div className={s.shortcut}>
<div className={s.label}>
{fullScreen
? I18n.t('project_ide_restore')
: I18n.t('project_ide_maximize')}
</div>
<div className={s.keybinding}>{keybinding}</div>
</div>
),
[fullScreen, keybinding],
);
// 左边分屏不展示全屏按钮
if (direction === 'left') {
return null;
}
const handleSwitchFullScreen = () => {
projectIDEServices.view.switchFullScreenMode();
setTooltipVisible(false);
};
return (
<Tooltip
content={content}
position="bottom"
// 点击后布局变化tooltip 需要手动控制消失
trigger="custom"
visible={tooltipVisible}
>
<IconButton
className={s['icon-button']}
icon={icon}
color="secondary"
onClick={handleSwitchFullScreen}
onMouseOver={() => setTooltipVisible(true)}
onMouseOut={() => setTooltipVisible(false)}
/>
</Tooltip>
);
};

View File

@@ -0,0 +1,22 @@
.full-screen-button {
display: flex;
align-items: center;
justify-content: center;
border: 1px solid var(--coz-stroke-primary);
}
.shortcut {
display: flex;
align-items: center;
justify-content: space-between;
.label {
font-size: 14px;
line-height: 20px;
}
.keybinding {
font-weight: 700;
color: var(--coz-fg-dim);
}
}

View File

@@ -0,0 +1,29 @@
/*
* Copyright 2025 coze-dev Authors
*
* Licensed 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 React from 'react';
import { type ProjectIDEWidget } from '@coze-project-ide/framework';
import { ReloadButton } from './reload-button';
import { FullScreenButton } from './full-screen-button';
export const ToolBar = ({ widget }: { widget: ProjectIDEWidget }) => (
<div style={{ display: 'flex' }}>
<ReloadButton widget={widget} />
<FullScreenButton />
</div>
);

View File

@@ -0,0 +1,68 @@
/*
* Copyright 2025 coze-dev Authors
*
* Licensed 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 React, { useState, useMemo } from 'react';
import { I18n } from '@coze-arch/i18n';
import { IconCozRefresh } from '@coze-arch/coze-design/icons';
import { IconButton, Tooltip } from '@coze-arch/coze-design';
import {
CustomCommand,
useShortcuts,
type ProjectIDEWidget,
} from '@coze-project-ide/framework';
import s from '../full-screen-button/styles.module.less';
export const ReloadButton = ({ widget }: { widget: ProjectIDEWidget }) => {
const { keybinding } = useShortcuts(CustomCommand.RELOAD);
const [tooltipVisible, setTooltipVisible] = useState(false);
const content = useMemo(
() => (
<div className={s.shortcut}>
<div className={s.label}>{I18n.t('refresh_project_tags')}</div>
<div className={s.keybinding}>{keybinding}</div>
</div>
),
[keybinding],
);
const handleReload = () => {
widget.refresh();
widget.context.widget.setUIState('loading');
};
return (
<Tooltip
content={content}
position="bottom"
// 点击后布局变化tooltip 需要手动控制消失
trigger="custom"
visible={tooltipVisible}
>
<IconButton
className={s['icon-button']}
icon={<IconCozRefresh />}
color="secondary"
onClick={handleReload}
onMouseOver={() => setTooltipVisible(true)}
onMouseOut={() => setTooltipVisible(false)}
/>
</Tooltip>
);
};