mirror of
https://github.com/QwenLM/qwen-code.git
synced 2026-01-07 17:39:17 +00:00
272 lines
8.2 KiB
TypeScript
272 lines
8.2 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2025 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import { Box, Text } from 'ink';
|
|
import { IdeIntegrationNudge } from '../IdeIntegrationNudge.js';
|
|
import { LoopDetectionConfirmation } from './LoopDetectionConfirmation.js';
|
|
import { FolderTrustDialog } from './FolderTrustDialog.js';
|
|
import { ShellConfirmationDialog } from './ShellConfirmationDialog.js';
|
|
import { ConsentPrompt } from './ConsentPrompt.js';
|
|
import { ThemeDialog } from './ThemeDialog.js';
|
|
import { SettingsDialog } from './SettingsDialog.js';
|
|
import { AuthInProgress } from '../auth/AuthInProgress.js';
|
|
import { QwenOAuthProgress } from './QwenOAuthProgress.js';
|
|
import { AuthDialog } from '../auth/AuthDialog.js';
|
|
import { EditorSettingsDialog } from './EditorSettingsDialog.js';
|
|
import { WorkspaceMigrationDialog } from './WorkspaceMigrationDialog.js';
|
|
import { ProQuotaDialog } from './ProQuotaDialog.js';
|
|
import { PermissionsModifyTrustDialog } from './PermissionsModifyTrustDialog.js';
|
|
import { ModelDialog } from './ModelDialog.js';
|
|
import { theme } from '../semantic-colors.js';
|
|
import { useUIState } from '../contexts/UIStateContext.js';
|
|
import { useUIActions } from '../contexts/UIActionsContext.js';
|
|
import { useConfig } from '../contexts/ConfigContext.js';
|
|
import { useSettings } from '../contexts/SettingsContext.js';
|
|
import process from 'node:process';
|
|
import { type UseHistoryManagerReturn } from '../hooks/useHistoryManager.js';
|
|
import { IdeTrustChangeDialog } from './IdeTrustChangeDialog.js';
|
|
import { WelcomeBackDialog } from './WelcomeBackDialog.js';
|
|
import { ModelSwitchDialog } from './ModelSwitchDialog.js';
|
|
import { AgentCreationWizard } from './subagents/create/AgentCreationWizard.js';
|
|
import { AgentsManagerDialog } from './subagents/manage/AgentsManagerDialog.js';
|
|
import {
|
|
QuitConfirmationDialog,
|
|
QuitChoice,
|
|
} from './QuitConfirmationDialog.js';
|
|
|
|
interface DialogManagerProps {
|
|
addItem: UseHistoryManagerReturn['addItem'];
|
|
terminalWidth: number;
|
|
}
|
|
|
|
// Props for DialogManager
|
|
export const DialogManager = ({
|
|
addItem,
|
|
terminalWidth,
|
|
}: DialogManagerProps) => {
|
|
const config = useConfig();
|
|
const settings = useSettings();
|
|
|
|
const uiState = useUIState();
|
|
const uiActions = useUIActions();
|
|
const { constrainHeight, terminalHeight, staticExtraHeight, mainAreaWidth } =
|
|
uiState;
|
|
|
|
if (uiState.showWelcomeBackDialog && uiState.welcomeBackInfo?.hasHistory) {
|
|
return (
|
|
<WelcomeBackDialog
|
|
welcomeBackInfo={uiState.welcomeBackInfo}
|
|
onSelect={uiActions.handleWelcomeBackSelection}
|
|
onClose={uiActions.handleWelcomeBackClose}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.showIdeRestartPrompt) {
|
|
return <IdeTrustChangeDialog reason={uiState.ideTrustRestartReason} />;
|
|
}
|
|
if (uiState.showWorkspaceMigrationDialog) {
|
|
return (
|
|
<WorkspaceMigrationDialog
|
|
workspaceExtensions={uiState.workspaceExtensions}
|
|
onOpen={uiActions.onWorkspaceMigrationDialogOpen}
|
|
onClose={uiActions.onWorkspaceMigrationDialogClose}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.proQuotaRequest) {
|
|
return (
|
|
<ProQuotaDialog
|
|
failedModel={uiState.proQuotaRequest.failedModel}
|
|
fallbackModel={uiState.proQuotaRequest.fallbackModel}
|
|
onChoice={uiActions.handleProQuotaChoice}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.shouldShowIdePrompt) {
|
|
return (
|
|
<IdeIntegrationNudge
|
|
ide={uiState.currentIDE!}
|
|
onComplete={uiActions.handleIdePromptComplete}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.isFolderTrustDialogOpen) {
|
|
return (
|
|
<FolderTrustDialog
|
|
onSelect={uiActions.handleFolderTrustSelect}
|
|
isRestarting={uiState.isRestarting}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.shellConfirmationRequest) {
|
|
return (
|
|
<ShellConfirmationDialog request={uiState.shellConfirmationRequest} />
|
|
);
|
|
}
|
|
if (uiState.loopDetectionConfirmationRequest) {
|
|
return (
|
|
<LoopDetectionConfirmation
|
|
onComplete={uiState.loopDetectionConfirmationRequest.onComplete}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.quitConfirmationRequest) {
|
|
return (
|
|
<QuitConfirmationDialog
|
|
onSelect={(choice: QuitChoice) => {
|
|
if (choice === QuitChoice.CANCEL) {
|
|
uiState.quitConfirmationRequest?.onConfirm(false, 'cancel');
|
|
} else if (choice === QuitChoice.QUIT) {
|
|
uiState.quitConfirmationRequest?.onConfirm(true, 'quit');
|
|
} else if (choice === QuitChoice.SAVE_AND_QUIT) {
|
|
uiState.quitConfirmationRequest?.onConfirm(true, 'save_and_quit');
|
|
} else if (choice === QuitChoice.SUMMARY_AND_QUIT) {
|
|
uiState.quitConfirmationRequest?.onConfirm(
|
|
true,
|
|
'summary_and_quit',
|
|
);
|
|
}
|
|
}}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.confirmationRequest) {
|
|
return (
|
|
<ConsentPrompt
|
|
prompt={uiState.confirmationRequest.prompt}
|
|
onConfirm={uiState.confirmationRequest.onConfirm}
|
|
terminalWidth={terminalWidth}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.confirmUpdateExtensionRequests.length > 0) {
|
|
const request = uiState.confirmUpdateExtensionRequests[0];
|
|
return (
|
|
<ConsentPrompt
|
|
prompt={request.prompt}
|
|
onConfirm={request.onConfirm}
|
|
terminalWidth={terminalWidth}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.isThemeDialogOpen) {
|
|
return (
|
|
<Box flexDirection="column">
|
|
{uiState.themeError && (
|
|
<Box marginBottom={1}>
|
|
<Text color={theme.status.error}>{uiState.themeError}</Text>
|
|
</Box>
|
|
)}
|
|
<ThemeDialog
|
|
onSelect={uiActions.handleThemeSelect}
|
|
onHighlight={uiActions.handleThemeHighlight}
|
|
settings={settings}
|
|
availableTerminalHeight={
|
|
constrainHeight ? terminalHeight - staticExtraHeight : undefined
|
|
}
|
|
terminalWidth={mainAreaWidth}
|
|
/>
|
|
</Box>
|
|
);
|
|
}
|
|
if (uiState.isSettingsDialogOpen) {
|
|
return (
|
|
<Box flexDirection="column">
|
|
<SettingsDialog
|
|
settings={settings}
|
|
onSelect={() => uiActions.closeSettingsDialog()}
|
|
onRestartRequest={() => process.exit(0)}
|
|
availableTerminalHeight={terminalHeight - staticExtraHeight}
|
|
/>
|
|
</Box>
|
|
);
|
|
}
|
|
if (uiState.isModelDialogOpen) {
|
|
return <ModelDialog onClose={uiActions.closeModelDialog} />;
|
|
}
|
|
if (uiState.isVisionSwitchDialogOpen) {
|
|
return <ModelSwitchDialog onSelect={uiActions.handleVisionSwitchSelect} />;
|
|
}
|
|
if (uiState.isAuthenticating) {
|
|
// Show Qwen OAuth progress if it's Qwen auth and OAuth is active
|
|
if (uiState.isQwenAuth && uiState.isQwenAuthenticating) {
|
|
return (
|
|
<QwenOAuthProgress
|
|
deviceAuth={uiState.deviceAuth || undefined}
|
|
authStatus={uiState.authStatus}
|
|
authMessage={uiState.authMessage}
|
|
onTimeout={uiActions.handleQwenAuthTimeout}
|
|
onCancel={uiActions.handleQwenAuthCancel}
|
|
/>
|
|
);
|
|
}
|
|
|
|
// Default auth progress for other auth types
|
|
return (
|
|
<AuthInProgress
|
|
onTimeout={() => {
|
|
uiActions.onAuthError('Authentication cancelled.');
|
|
}}
|
|
/>
|
|
);
|
|
}
|
|
if (uiState.isAuthDialogOpen) {
|
|
return (
|
|
<Box flexDirection="column">
|
|
<AuthDialog
|
|
onSelect={uiActions.handleAuthSelect}
|
|
settings={settings}
|
|
initialErrorMessage={uiState.authError}
|
|
/>
|
|
</Box>
|
|
);
|
|
}
|
|
if (uiState.isEditorDialogOpen) {
|
|
return (
|
|
<Box flexDirection="column">
|
|
{uiState.editorError && (
|
|
<Box marginBottom={1}>
|
|
<Text color={theme.status.error}>{uiState.editorError}</Text>
|
|
</Box>
|
|
)}
|
|
<EditorSettingsDialog
|
|
onSelect={uiActions.handleEditorSelect}
|
|
settings={settings}
|
|
onExit={uiActions.exitEditorDialog}
|
|
/>
|
|
</Box>
|
|
);
|
|
}
|
|
if (uiState.isPermissionsDialogOpen) {
|
|
return (
|
|
<PermissionsModifyTrustDialog
|
|
onExit={uiActions.closePermissionsDialog}
|
|
addItem={addItem}
|
|
/>
|
|
);
|
|
}
|
|
|
|
if (uiState.isSubagentCreateDialogOpen) {
|
|
return (
|
|
<AgentCreationWizard
|
|
onClose={uiActions.closeSubagentCreateDialog}
|
|
config={config}
|
|
/>
|
|
);
|
|
}
|
|
|
|
if (uiState.isAgentsManagerDialogOpen) {
|
|
return (
|
|
<AgentsManagerDialog
|
|
onClose={uiActions.closeAgentsManagerDialog}
|
|
config={config}
|
|
/>
|
|
);
|
|
}
|
|
|
|
return null;
|
|
};
|