wwf
3 天以前 a430284aa21e3ae1f0d5654e55b2ad2852519cc2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import React, { type FC, useCallback } from 'react'
import { RiHistoryLine } from '@remixicon/react'
import { useTranslation } from 'react-i18next'
import { useKeyPress } from 'ahooks'
import Button from '../../base/button'
import Tooltip from '../../base/tooltip'
import { getKeyboardKeyCodeBySystem } from '../utils'
 
type VersionHistoryButtonProps = {
  onClick: () => Promise<unknown> | unknown
}
 
const VERSION_HISTORY_SHORTCUT = ['⌘', '⇧', 'H']
 
const PopupContent = React.memo(() => {
  const { t } = useTranslation()
  return (
    <div className='flex items-center gap-x-1'>
      <div className='system-xs-medium px-0.5 text-text-secondary'>
        {t('workflow.common.versionHistory')}
      </div>
      <div className='flex items-center gap-x-0.5'>
        {VERSION_HISTORY_SHORTCUT.map(key => (
          <span
            key={key}
            className='system-kbd rounded-[4px] bg-components-kbd-bg-white px-[1px] text-text-tertiary'
          >
            {key}
          </span>
        ))}
      </div>
    </div>
  )
})
 
PopupContent.displayName = 'PopupContent'
 
const VersionHistoryButton: FC<VersionHistoryButtonProps> = ({
  onClick,
}) => {
  const handleViewVersionHistory = useCallback(async () => {
    await onClick?.()
  }, [onClick])
 
  useKeyPress(`${getKeyboardKeyCodeBySystem('ctrl')}.shift.h`, (e) => {
    e.preventDefault()
    handleViewVersionHistory()
  },
  { exactMatch: true, useCapture: true })
 
  return <Tooltip
    popupContent={<PopupContent />}
    noDecoration
    popupClassName='rounded-lg border-[0.5px] border-components-panel-border bg-components-tooltip-bg
    shadow-lg shadow-shadow-shadow-5 backdrop-blur-[5px] p-1.5'
  >
    <Button
      className={'p-2'}
      onClick={handleViewVersionHistory}
    >
      <RiHistoryLine className='h-4 w-4 text-components-button-secondary-text' />
    </Button>
  </Tooltip>
}
 
export default VersionHistoryButton