mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-04-04 00:49:48 +01:00
* P1 bug fix for private preview * Add updated snapshot files * Fix failing unit test * Fix unit tests and update snapshot
119 lines
4.2 KiB
TypeScript
119 lines
4.2 KiB
TypeScript
import {
|
|
Checkbox,
|
|
ChoiceGroup,
|
|
DefaultButton,
|
|
IconButton,
|
|
Link,
|
|
Modal,
|
|
PrimaryButton,
|
|
Stack,
|
|
Text,
|
|
TextField,
|
|
} from "@fluentui/react";
|
|
import Explorer from "Explorer/Explorer";
|
|
import { SubmitFeedback } from "Explorer/QueryCopilot/Shared/QueryCopilotClient";
|
|
import { useQueryCopilot } from "hooks/useQueryCopilot";
|
|
import React from "react";
|
|
import { getUserEmail } from "../../../Utils/UserUtils";
|
|
|
|
export const QueryCopilotFeedbackModal = ({ explorer }: { explorer: Explorer }): JSX.Element => {
|
|
const {
|
|
generatedQuery,
|
|
userPrompt,
|
|
likeQuery,
|
|
showFeedbackModal,
|
|
closeFeedbackModal,
|
|
setHideFeedbackModalForLikedQueries,
|
|
} = useQueryCopilot();
|
|
const [isContactAllowed, setIsContactAllowed] = React.useState<boolean>(false);
|
|
const [description, setDescription] = React.useState<string>("");
|
|
const [doNotShowAgainChecked, setDoNotShowAgainChecked] = React.useState<boolean>(false);
|
|
const [contact, setContact] = React.useState<string>(getUserEmail());
|
|
|
|
const handleSubmit = () => {
|
|
closeFeedbackModal();
|
|
setHideFeedbackModalForLikedQueries(doNotShowAgainChecked);
|
|
SubmitFeedback({
|
|
params: { generatedQuery, likeQuery, description, userPrompt, contact },
|
|
explorer: explorer,
|
|
});
|
|
};
|
|
|
|
return (
|
|
<Modal isOpen={showFeedbackModal}>
|
|
<form onSubmit={handleSubmit}>
|
|
<Stack style={{ padding: 24 }}>
|
|
<Stack horizontal horizontalAlign="space-between">
|
|
<Text style={{ fontSize: 20, fontWeight: 600, marginBottom: 20 }}>Send feedback to Microsoft</Text>
|
|
<IconButton iconProps={{ iconName: "Cancel" }} onClick={() => closeFeedbackModal()} />
|
|
</Stack>
|
|
<Text style={{ fontSize: 14, marginBottom: 14 }}>Your feedback will help improve the experience.</Text>
|
|
<TextField
|
|
styles={{ root: { marginBottom: 14 } }}
|
|
label="Description"
|
|
required
|
|
placeholder="Provide more details"
|
|
value={description}
|
|
onChange={(_, newValue) => setDescription(newValue)}
|
|
multiline
|
|
rows={3}
|
|
/>
|
|
<TextField
|
|
styles={{ root: { marginBottom: 14 } }}
|
|
label="Query generated"
|
|
defaultValue={generatedQuery}
|
|
readOnly
|
|
/>
|
|
<ChoiceGroup
|
|
styles={{
|
|
root: {
|
|
marginBottom: 14,
|
|
},
|
|
flexContainer: {
|
|
selectors: {
|
|
".ms-ChoiceField-field::before": { marginTop: 4 },
|
|
".ms-ChoiceField-field::after": { marginTop: 4 },
|
|
".ms-ChoiceFieldLabel": { paddingLeft: 6 },
|
|
},
|
|
},
|
|
}}
|
|
label="May we contact you about your feedback?"
|
|
options={[
|
|
{ key: "yes", text: "Yes, you may contact me." },
|
|
{ key: "no", text: "No, do not contact me." },
|
|
]}
|
|
selectedKey={isContactAllowed ? "yes" : "no"}
|
|
onChange={(_, option) => {
|
|
setIsContactAllowed(option.key === "yes");
|
|
setContact(option.key === "yes" ? getUserEmail() : "");
|
|
}}
|
|
></ChoiceGroup>
|
|
<Text style={{ fontSize: 12, marginBottom: 14 }}>
|
|
By pressing submit, your feedback will be used to improve Microsoft products and services. Please see the{" "}
|
|
{
|
|
<Link href="https://privacy.microsoft.com/privacystatement" target="_blank">
|
|
Privacy statement
|
|
</Link>
|
|
}{" "}
|
|
for more information.
|
|
</Text>
|
|
{likeQuery && (
|
|
<Checkbox
|
|
styles={{ label: { paddingLeft: 0 }, root: { marginBottom: 14 } }}
|
|
label="Don't show me this next time"
|
|
checked={doNotShowAgainChecked}
|
|
onChange={(_, checked) => setDoNotShowAgainChecked(checked)}
|
|
/>
|
|
)}
|
|
<Stack horizontal horizontalAlign="end">
|
|
<PrimaryButton styles={{ root: { marginRight: 8 } }} type="submit">
|
|
Submit
|
|
</PrimaryButton>
|
|
<DefaultButton onClick={() => closeFeedbackModal()}>Cancel</DefaultButton>
|
|
</Stack>
|
|
</Stack>
|
|
</form>
|
|
</Modal>
|
|
);
|
|
};
|