fix(perf): fix remaining lazy-loading and dead toggle issues from PR review

- Gate TeamListView dialogs with showCreateDialog/launchDialogOpen
- Gate SchedulesView and ScheduleSection lazy dialogs with dialogOpen
- Fix import order in SchedulesView (import type before lazy constant)
- Add Show raw toggle button to MarkdownViewer rendered view
This commit is contained in:
Mike 2026-05-03 14:42:23 +05:00
parent 90d887fcce
commit f2231d7dad
4 changed files with 60 additions and 30 deletions

View file

@ -1169,12 +1169,36 @@ export const MarkdownViewer: React.FC<MarkdownViewerProps> = React.memo(function
<span className="text-sm font-medium" style={{ color: COLOR_TEXT_SECONDARY }}>
{label}
</span>
{copyable && (
<>
<span className="flex-1" />
<CopyButton text={content} inline />
</>
)}
<span className="flex-1" />
<button
type="button"
className="text-xs underline"
style={{ color: PROSE_LINK }}
onClick={() => setShowRaw(true)}
title="Show raw"
>
Show raw
</button>
{copyable && <CopyButton text={content} inline />}
</div>
)}
{/* Show raw toggle for no-label path */}
{!label && (
<div
className="flex items-center justify-between px-3 py-1 text-xs"
style={{ color: COLOR_TEXT_MUTED }}
>
<span />
<button
type="button"
className="underline"
style={{ color: PROSE_LINK }}
onClick={() => setShowRaw(true)}
title="Show raw"
>
Show raw
</button>
</div>
)}

View file

@ -28,12 +28,14 @@ import { ScheduleRunLogDialog } from '../team/schedule/ScheduleRunLogDialog';
import { ScheduleRunRow } from '../team/schedule/ScheduleRunRow';
import { ScheduleStatusBadge } from '../team/schedule/ScheduleStatusBadge';
const LaunchTeamDialog = lazy(() =>
import('../team/dialogs/LaunchTeamDialog').then((m) => ({ default: m.LaunchTeamDialog }))
);
import type { Schedule, ScheduleRun, ScheduleStatus } from '@shared/types';
const LaunchTeamDialog = lazy(() =>
import('@renderer/components/team/dialogs/LaunchTeamDialog').then((m) => ({
default: m.LaunchTeamDialog,
}))
);
// =============================================================================
// Constants
// =============================================================================
@ -565,15 +567,17 @@ export const SchedulesView = (): React.JSX.Element => {
</div>
{/* Create/Edit Dialog */}
<Suspense fallback={null}>
<LaunchTeamDialog
mode="schedule"
open={dialogOpen}
teamName={editingSchedule?.teamName}
schedule={editingSchedule}
onClose={handleClose}
/>
</Suspense>
{dialogOpen && (
<Suspense fallback={null}>
<LaunchTeamDialog
mode="schedule"
open={dialogOpen}
teamName={editingSchedule?.teamName}
schedule={editingSchedule}
onClose={handleClose}
/>
</Suspense>
)}
</div>
);
};

View file

@ -736,7 +736,7 @@ export const TeamListView = memo(function TeamListView(): React.JSX.Element {
);
}
const createDialogElement = (
const createDialogElement = showCreateDialog && (
<Suspense fallback={null}>
<CreateTeamDialog
open={showCreateDialog}
@ -755,7 +755,7 @@ export const TeamListView = memo(function TeamListView(): React.JSX.Element {
</Suspense>
);
const launchDialogElement = (
const launchDialogElement = launchDialogOpen && (
<Suspense fallback={null}>
<LaunchTeamDialog
mode="launch"

View file

@ -307,15 +307,17 @@ export const ScheduleSection = ({ teamName }: ScheduleSectionProps): React.JSX.E
)}
{/* Create/Edit Dialog */}
<Suspense fallback={null}>
<LaunchTeamDialog
mode="schedule"
open={dialogOpen}
teamName={teamName}
schedule={editingSchedule}
onClose={handleClose}
/>
</Suspense>
{dialogOpen && (
<Suspense fallback={null}>
<LaunchTeamDialog
mode="schedule"
open={dialogOpen}
teamName={teamName}
schedule={editingSchedule}
onClose={handleClose}
/>
</Suspense>
)}
</div>
);
};