Files
dify/web/app/components/workflow/header/version-history-button.tsx
yyh 88196c186e refactor(web): workflow hotkeys and history state (#35736)
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
2026-04-30 09:43:16 +00:00

71 lines
2.0 KiB
TypeScript

import type { FC } from 'react'
import { Button } from '@langgenius/dify-ui/button'
import { cn } from '@langgenius/dify-ui/cn'
import {
Tooltip,
TooltipContent,
TooltipTrigger,
} from '@langgenius/dify-ui/tooltip'
import * as React from 'react'
import { useCallback } from 'react'
import { useTranslation } from 'react-i18next'
import useTheme from '@/hooks/use-theme'
import { ShortcutKbd } from '../shortcuts/shortcut-kbd'
import { useWorkflowShortcut } from '../shortcuts/use-workflow-hotkeys'
type VersionHistoryButtonProps = {
onClick: () => Promise<unknown> | unknown
}
const PopupContent = React.memo(() => {
const { t } = useTranslation()
return (
<div className="flex items-center gap-x-1">
<div className="px-0.5 system-xs-medium text-text-secondary">
{t('common.versionHistory', { ns: 'workflow' })}
</div>
<ShortcutKbd shortcut="workflow.version-history" bgColor="gray" textColor="secondary" />
</div>
)
})
PopupContent.displayName = 'PopupContent'
const VersionHistoryButton: FC<VersionHistoryButtonProps> = ({
onClick,
}) => {
const { theme } = useTheme()
const handleViewVersionHistory = useCallback(async () => {
await onClick?.()
}, [onClick])
useWorkflowShortcut('workflow.version-history', () => {
handleViewVersionHistory()
})
return (
<Tooltip>
<TooltipTrigger
render={(
<Button
className={cn(
'rounded-lg border border-transparent p-2',
theme === 'dark' && 'border-black/5 bg-white/10 backdrop-blur-xs',
)}
onClick={handleViewVersionHistory}
>
<span className="i-ri-history-line h-4 w-4 text-components-button-secondary-text" />
</Button>
)}
/>
<TooltipContent
className="rounded-lg border-[0.5px] border-components-panel-border bg-components-tooltip-bg p-1.5 shadow-lg shadow-shadow-shadow-5 backdrop-blur-[5px]"
>
<PopupContent />
</TooltipContent>
</Tooltip>
)
}
export default VersionHistoryButton