header.tsx 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. 'use client'
  2. import type { FC } from 'react'
  3. import React from 'react'
  4. import { useTranslation } from 'react-i18next'
  5. import { ClipboardDocumentIcon, HandThumbDownIcon, HandThumbUpIcon } from '@heroicons/react/24/outline'
  6. import { Feedbacktype } from '@/app/components/app/chat'
  7. import Button from '@/app/components/base/button'
  8. import Toast from '@/app/components/base/toast'
  9. import Tooltip from '@/app/components/base/tooltip'
  10. // import useCopyToClipboard from '@/hooks/use-copy-to-clipboard'
  11. import copy from 'copy-to-clipboard'
  12. type IResultHeaderProps = {
  13. result: string
  14. showFeedback: boolean
  15. feedback: Feedbacktype
  16. onFeedback: (feedback: Feedbacktype) => void
  17. }
  18. const Header: FC<IResultHeaderProps> = ({
  19. feedback,
  20. showFeedback,
  21. onFeedback,
  22. result,
  23. }) => {
  24. const { t } = useTranslation()
  25. return (
  26. <div className='flex w-full justify-between items-center '>
  27. <div className='text-gray-800 text-2xl leading-4 font-normal'>{t('share.generation.resultTitle')}</div>
  28. <div className='flex items-center space-x-2'>
  29. <Button
  30. className='flex items-center !h-7 !p-[2px] !pr-2'
  31. onClick={() => {
  32. copy(result)
  33. Toast.notify({ type: 'success', message: 'copied' })
  34. }}
  35. >
  36. <>
  37. <ClipboardDocumentIcon className='text-gray-500 w-4 h-3 mr-1' />
  38. <span className='text-gray-500 text-xs leading-3'>{t('share.generation.copy')}</span>
  39. </>
  40. </Button>
  41. {showFeedback && feedback.rating && feedback.rating === 'like' && (
  42. <Tooltip
  43. selector="undo-feedback-like"
  44. content="Undo Great Rating"
  45. >
  46. <div
  47. onClick={() => {
  48. onFeedback({
  49. rating: null
  50. })
  51. }}
  52. className='flex w-7 h-7 items-center justify-center rounded-md cursor-pointer !text-primary-600 border border-primary-200 bg-primary-100 hover:border-primary-300 hover:bg-primary-200'>
  53. <HandThumbUpIcon width={16} height={16} />
  54. </div>
  55. </Tooltip>
  56. )}
  57. {showFeedback && feedback.rating && feedback.rating === 'dislike' && (
  58. <Tooltip
  59. selector="undo-feedback-dislike"
  60. content="Undo Undesirable Response"
  61. >
  62. <div
  63. onClick={() => {
  64. onFeedback({
  65. rating: null
  66. })
  67. }}
  68. className='flex w-7 h-7 items-center justify-center rounded-md cursor-pointer !text-red-600 border border-red-200 bg-red-100 hover:border-red-300 hover:bg-red-200'>
  69. <HandThumbDownIcon width={16} height={16} />
  70. </div>
  71. </Tooltip>
  72. )}
  73. {showFeedback && !feedback.rating && (
  74. <div className='flex rounded-lg border border-gray-200 p-[1px] space-x-1'>
  75. <Tooltip
  76. selector="feedback-like"
  77. content="Great Rating"
  78. >
  79. <div
  80. onClick={() => {
  81. onFeedback({
  82. rating: 'like'
  83. })
  84. }}
  85. className='flex w-6 h-6 items-center justify-center rounded-md cursor-pointer hover:bg-gray-100'>
  86. <HandThumbUpIcon width={16} height={16} />
  87. </div>
  88. </Tooltip>
  89. <Tooltip
  90. selector="feedback-dislike"
  91. content="Undesirable Response"
  92. >
  93. <div
  94. onClick={() => {
  95. onFeedback({
  96. rating: 'dislike'
  97. })
  98. }}
  99. className='flex w-6 h-6 items-center justify-center rounded-md cursor-pointer hover:bg-gray-100'>
  100. <HandThumbDownIcon width={16} height={16} />
  101. </div>
  102. </Tooltip>
  103. </div>
  104. )}
  105. </div>
  106. </div>
  107. )
  108. }
  109. export default React.memo(Header)