From 841976b34353e3177c3bae6e2509bcd183d3b028 Mon Sep 17 00:00:00 2001 From: "Laurie T. Malau" Date: Wed, 11 May 2022 10:32:19 +0000 Subject: [PATCH] Feedback modal --- components/dashboard/src/Analytics.tsx | 10 +- components/dashboard/src/Menu.tsx | 21 +++- .../dashboard/src/components/PillMenuItem.tsx | 2 +- .../src/feedback-form/FeedbackComponent.tsx | 111 ++++++++++++++++++ .../src/feedback-form/FeedbackModal.tsx | 26 ++++ .../src/images/feedback/crying-emoji.svg | 10 ++ .../src/images/feedback/happy-emoji.svg | 7 ++ .../src/images/feedback/meh-emoji.svg | 6 + .../src/images/feedback/starry-emoji.svg | 6 + components/dashboard/src/index.css | 6 + 10 files changed, 198 insertions(+), 7 deletions(-) create mode 100644 components/dashboard/src/feedback-form/FeedbackComponent.tsx create mode 100644 components/dashboard/src/feedback-form/FeedbackModal.tsx create mode 100644 components/dashboard/src/images/feedback/crying-emoji.svg create mode 100644 components/dashboard/src/images/feedback/happy-emoji.svg create mode 100644 components/dashboard/src/images/feedback/meh-emoji.svg create mode 100644 components/dashboard/src/images/feedback/starry-emoji.svg diff --git a/components/dashboard/src/Analytics.tsx b/components/dashboard/src/Analytics.tsx index b6f127850942b1..4e7704f8c7f5e4 100644 --- a/components/dashboard/src/Analytics.tsx +++ b/components/dashboard/src/Analytics.tsx @@ -10,10 +10,10 @@ import Cookies from "js-cookie"; import { v4 } from "uuid"; import { Experiment } from "./experiments"; -export type Event = "invite_url_requested" | "organisation_authorised" | "dotfile_repo_changed"; +export type Event = "invite_url_requested" | "organisation_authorised" | "dotfile_repo_changed" | "feedback_submitted"; type InternalEvent = Event | "path_changed" | "dashboard_clicked"; -export type EventProperties = TrackOrgAuthorised | TrackInviteUrlRequested | TrackDotfileRepo; +export type EventProperties = TrackOrgAuthorised | TrackInviteUrlRequested | TrackDotfileRepo | TrackFeedback; type InternalEventProperties = TrackUIExperiments & (EventProperties | TrackDashboardClick | TrackPathChanged); export interface TrackOrgAuthorised { @@ -30,6 +30,12 @@ export interface TrackDotfileRepo { current: string; } +export interface TrackFeedback { + score: number; + feedback: string; + href: string; + path: string; +} interface TrackDashboardClick { dnt?: boolean; path: string; diff --git a/components/dashboard/src/Menu.tsx b/components/dashboard/src/Menu.tsx index 225c1b5f6d3414..9b5afb0bdb2a1b 100644 --- a/components/dashboard/src/Menu.tsx +++ b/components/dashboard/src/Menu.tsx @@ -26,6 +26,7 @@ import { getTeamSettingsMenu } from "./teams/TeamSettings"; import { getProjectSettingsMenu } from "./projects/ProjectSettings"; import { ProjectContext } from "./projects/project-context"; import { PaymentContext } from "./payment-context"; +import FeedbackFormModal from "./feedback-form/FeedbackModal"; interface Entry { title: string; @@ -41,6 +42,7 @@ export default function Menu() { const { showPaymentUI, setShowPaymentUI, setCurrency, setIsStudent, setIsChargebeeCustomer } = useContext(PaymentContext); const { project, setProject } = useContext(ProjectContext); + const [isFeedbackFormVisible, setFeedbackFormVisible] = useState(false); const match = useRouteMatch<{ segment1?: string; segment2?: string; segment3?: string }>( "/(t/)?:segment1/:segment2?/:segment3?", @@ -227,12 +229,15 @@ export default function Menu() { title: "Docs", link: "https://www.gitpod.io/docs/", }, - { - title: "Help", - link: "https://www.gitpod.io/support", - }, ]; + const handleFeedbackFormClick = () => { + setFeedbackFormVisible(true); + }; + + const onFeedbackFormClose = () => { + setFeedbackFormVisible(false); + }; const renderTeamMenu = () => { return (
@@ -371,6 +376,9 @@ export default function Menu() { /> ))} +
  • + +
  • + {isFeedbackFormVisible && } {!isMinimalUI && !prebuildId && (