File size: 4,043 Bytes
4304c6d
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
'use client'
import type { FC } from 'react'
import React from 'react'
import { useTranslation } from 'react-i18next'
import { ClipboardDocumentIcon, HandThumbDownIcon, HandThumbUpIcon } from '@heroicons/react/24/outline'
import copy from 'copy-to-clipboard'
import type { Feedbacktype } from '@/app/components/app/chat/type'
import Button from '@/app/components/base/button'
import Toast from '@/app/components/base/toast'
import Tooltip from '@/app/components/base/tooltip'

type IResultHeaderProps = {
  result: string
  showFeedback: boolean
  feedback: Feedbacktype
  onFeedback: (feedback: Feedbacktype) => void
}

const Header: FC<IResultHeaderProps> = ({

  feedback,

  showFeedback,

  onFeedback,

  result,

}) => {
  const { t } = useTranslation()
  return (
    <div className='flex w-full justify-between items-center '>

      <div className='text-gray-800 text-2xl leading-4 font-normal'>{t('share.generation.resultTitle')}</div>

      <div className='flex items-center space-x-2'>

        <Button

          className='flex items-center !h-7 !p-[2px] !pr-2'

          onClick={() => {

            copy(result)

            Toast.notify({ type: 'success', message: 'copied' })

          }}

        >

          <>

            <ClipboardDocumentIcon className='text-gray-500 w-4 h-3 mr-1' />

            <span className='text-gray-500 text-xs leading-3'>{t('share.generation.copy')}</span>

          </>

        </Button>



        {showFeedback && feedback.rating && feedback.rating === 'like' && (

          <Tooltip

            selector="undo-feedback-like"

            content="Undo Great Rating"

          >

            <div

              onClick={() => {

                onFeedback({

                  rating: null,

                })

              }}

              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'>

              <HandThumbUpIcon width={16} height={16} />

            </div>

          </Tooltip>

        )}



        {showFeedback && feedback.rating && feedback.rating === 'dislike' && (

          <Tooltip

            selector="undo-feedback-dislike"

            content="Undo Undesirable Response"

          >

            <div

              onClick={() => {

                onFeedback({

                  rating: null,

                })

              }}

              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'>

              <HandThumbDownIcon width={16} height={16} />

            </div>

          </Tooltip>

        )}



        {showFeedback && !feedback.rating && (

          <div className='flex rounded-lg border border-gray-200 p-[1px] space-x-1'>

            <Tooltip

              selector="feedback-like"

              content="Great Rating"

            >

              <div

                onClick={() => {

                  onFeedback({

                    rating: 'like',

                  })

                }}

                className='flex w-6 h-6 items-center justify-center rounded-md cursor-pointer hover:bg-gray-100'>

                <HandThumbUpIcon width={16} height={16} />

              </div>

            </Tooltip>

            <Tooltip

              selector="feedback-dislike"

              content="Undesirable Response"

            >

              <div

                onClick={() => {

                  onFeedback({

                    rating: 'dislike',

                  })

                }}

                className='flex w-6 h-6 items-center justify-center rounded-md cursor-pointer hover:bg-gray-100'>

                <HandThumbDownIcon width={16} height={16} />

              </div>

            </Tooltip>

          </div>

        )}

      </div>

    </div>
  )
}

export default React.memo(Header)