-
-
Notifications
You must be signed in to change notification settings - Fork 4.3k
/
Copy pathuseFeedbackWidget.tsx
54 lines (46 loc) · 1.24 KB
/
useFeedbackWidget.tsx
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
import type {RefObject} from 'react';
import {useEffect} from 'react';
import type {UseFeedbackOptions} from 'sentry/components/feedback/widget/useFeedback';
import {useFeedback} from 'sentry/components/feedback/widget/useFeedback';
interface Props {
buttonRef?: RefObject<HTMLButtonElement | null> | RefObject<HTMLAnchorElement | null>;
formTitle?: string;
messagePlaceholder?: string;
optionOverrides?: UseFeedbackOptions;
}
export default function useFeedbackWidget({
buttonRef,
formTitle,
messagePlaceholder,
optionOverrides,
}: Props) {
const {feedback, options: defaultOptions} = useFeedback({
formTitle,
messagePlaceholder,
});
useEffect(() => {
if (!feedback) {
return undefined;
}
const options = {
...defaultOptions,
...optionOverrides,
tags: {
...defaultOptions.tags,
...optionOverrides?.tags,
},
};
if (buttonRef) {
if (buttonRef.current) {
return feedback.attachTo(buttonRef.current, options);
}
} else {
const widget = feedback.createWidget(options);
return () => {
widget.removeFromDom();
};
}
return undefined;
}, [buttonRef, feedback, defaultOptions, optionOverrides]);
return feedback;
}