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
| import React, { useEffect } from 'react'
|
| function useFeature({
| introduction,
| setIntroduction,
| moreLikeThis,
| setMoreLikeThis,
| suggestedQuestionsAfterAnswer,
| setSuggestedQuestionsAfterAnswer,
| speechToText,
| setSpeechToText,
| textToSpeech,
| setTextToSpeech,
| citation,
| setCitation,
| annotation,
| setAnnotation,
| moderation,
| setModeration,
| }: {
| introduction: string
| setIntroduction: (introduction: string) => void
| moreLikeThis: boolean
| setMoreLikeThis: (moreLikeThis: boolean) => void
| suggestedQuestionsAfterAnswer: boolean
| setSuggestedQuestionsAfterAnswer: (suggestedQuestionsAfterAnswer: boolean) => void
| speechToText: boolean
| setSpeechToText: (speechToText: boolean) => void
| textToSpeech: boolean
| setTextToSpeech: (textToSpeech: boolean) => void
| citation: boolean
| setCitation: (citation: boolean) => void
| annotation: boolean
| setAnnotation: (annotation: boolean) => void
| moderation: boolean
| setModeration: (moderation: boolean) => void
| }) {
| const [tempShowOpeningStatement, setTempShowOpeningStatement] = React.useState(!!introduction)
| useEffect(() => {
| // wait to api data back
| if (introduction)
| setTempShowOpeningStatement(true)
| }, [introduction])
|
| // const [tempMoreLikeThis, setTempMoreLikeThis] = React.useState(moreLikeThis)
| // useEffect(() => {
| // setTempMoreLikeThis(moreLikeThis)
| // }, [moreLikeThis])
|
| const featureConfig = {
| openingStatement: tempShowOpeningStatement,
| moreLikeThis,
| suggestedQuestionsAfterAnswer,
| speechToText,
| textToSpeech,
| citation,
| annotation,
| moderation,
| }
| const handleFeatureChange = (key: string, value: boolean) => {
| switch (key) {
| case 'openingStatement':
| if (!value)
| setIntroduction('')
|
| setTempShowOpeningStatement(value)
| break
| case 'moreLikeThis':
| setMoreLikeThis(value)
| break
| case 'suggestedQuestionsAfterAnswer':
| setSuggestedQuestionsAfterAnswer(value)
| break
| case 'speechToText':
| setSpeechToText(value)
| break
| case 'textToSpeech':
| setTextToSpeech(value)
| break
| case 'citation':
| setCitation(value)
| break
| case 'annotation':
| setAnnotation(value)
| break
| case 'moderation':
| setModeration(value)
| }
| }
| return {
| featureConfig,
| handleFeatureChange,
| }
| }
|
| export default useFeature
|
|