fix: product tour modal bugs (#2657)

* fix: product tour

* style: product tour navigation buttons

* refactor: step logic
This commit is contained in:
Aaryan Khandelwal 2023-11-06 13:06:00 +05:30 committed by GitHub
parent 14ac885e55
commit bf48d93a25
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 34 additions and 24 deletions

View File

@ -1,16 +1,15 @@
import { useState } from "react"; import { useState } from "react";
import Image from "next/image"; import Image from "next/image";
import { observer } from "mobx-react-lite";
// hooks // mobx store
import useUser from "hooks/use-user"; import { useMobxStore } from "lib/mobx/store-provider";
// components // components
import { TourSidebar } from "components/onboarding"; import { TourSidebar } from "components/onboarding";
// ui // ui
import { Button } from "@plane/ui"; import { Button } from "@plane/ui";
// icons // icons
import { X } from "lucide-react"; import { X } from "lucide-react";
// images // assets
import PlaneWhiteLogo from "public/plane-logos/white-horizontal.svg"; import PlaneWhiteLogo from "public/plane-logos/white-horizontal.svg";
import IssuesTour from "public/onboarding/issues.webp"; import IssuesTour from "public/onboarding/issues.webp";
import CyclesTour from "public/onboarding/cycles.webp"; import CyclesTour from "public/onboarding/cycles.webp";
@ -75,10 +74,13 @@ const TOUR_STEPS: {
}, },
]; ];
export const TourRoot: React.FC<Props> = ({ onComplete }) => { export const TourRoot: React.FC<Props> = observer((props) => {
const { onComplete } = props;
// states
const [step, setStep] = useState<TTourSteps>("welcome"); const [step, setStep] = useState<TTourSteps>("welcome");
const { user } = useUser(); const { user: userStore, commandPalette: commandPaletteStore } = useMobxStore();
const user = userStore.currentUser;
const currentStepIndex = TOUR_STEPS.findIndex((tourStep) => tourStep.key === step); const currentStepIndex = TOUR_STEPS.findIndex((tourStep) => tourStep.key === step);
const currentStep = TOUR_STEPS[currentStepIndex]; const currentStep = TOUR_STEPS[currentStepIndex];
@ -91,7 +93,7 @@ export const TourRoot: React.FC<Props> = ({ onComplete }) => {
<div className="h-3/5 bg-custom-primary-100 grid place-items-center"> <div className="h-3/5 bg-custom-primary-100 grid place-items-center">
<Image src={PlaneWhiteLogo} alt="Plane White Logo" /> <Image src={PlaneWhiteLogo} alt="Plane White Logo" />
</div> </div>
<div className="h-2/5 overflow-y-auto p-6"> <div className="h-2/5 flex flex-col overflow-y-auto p-6">
<h3 className="font-semibold sm:text-xl"> <h3 className="font-semibold sm:text-xl">
Welcome to Plane, {user?.first_name} {user?.last_name} Welcome to Plane, {user?.first_name} {user?.last_name}
</h3> </h3>
@ -99,17 +101,19 @@ export const TourRoot: React.FC<Props> = ({ onComplete }) => {
We{"'"}re glad that you decided to try out Plane. You can now manage your projects with ease. Get We{"'"}re glad that you decided to try out Plane. You can now manage your projects with ease. Get
started by creating a project. started by creating a project.
</p> </p>
<div className="flex items-center gap-6 mt-8"> <div className="flex items-end h-full">
<Button variant="primary" onClick={() => setStep("issues")}> <div className="flex items-center gap-6 mt-8">
Take a Product Tour <Button variant="primary" onClick={() => setStep("issues")}>
</Button> Take a Product Tour
<button </Button>
type="button" <button
className="outline-custom-text-100 bg-transparent text-custom-primary-100 text-xs font-medium" type="button"
onClick={onComplete} className="outline-custom-text-100 bg-transparent text-custom-primary-100 text-xs font-medium"
> onClick={onComplete}
No thanks, I will explore it myself >
</button> No thanks, I will explore it myself
</button>
</div>
</div> </div>
</div> </div>
</div> </div>
@ -148,8 +152,14 @@ export const TourRoot: React.FC<Props> = ({ onComplete }) => {
</Button> </Button>
)} )}
</div> </div>
{TOUR_STEPS.findIndex((tourStep) => tourStep.key === step) === TOUR_STEPS.length - 1 && ( {currentStepIndex === TOUR_STEPS.length - 1 && (
<Button variant="primary" onClick={onComplete}> <Button
variant="primary"
onClick={() => {
onComplete();
commandPaletteStore.toggleCreateProjectModal(true);
}}
>
Create my first project Create my first project
</Button> </Button>
)} )}
@ -160,4 +170,4 @@ export const TourRoot: React.FC<Props> = ({ onComplete }) => {
)} )}
</> </>
); );
}; });

View File

@ -1 +1,2 @@
export * from "./signin"; export * from "./signin";
export * from "./workspace-dashboard";

View File

@ -3,4 +3,3 @@ export * from "./form";
export * from "./modal"; export * from "./modal";
export * from "./view-list-item"; export * from "./view-list-item";
export * from "./views-list"; export * from "./views-list";
export * from "./workspace-dashboard";

View File

@ -2,7 +2,7 @@ import { ReactElement } from "react";
// layouts // layouts
import { AppLayout } from "layouts/app-layout"; import { AppLayout } from "layouts/app-layout";
// components // components
import { WorkspaceDashboardView } from "components/views"; import { WorkspaceDashboardView } from "components/page-views";
import { WorkspaceDashboardHeader } from "components/headers/workspace-dashboard"; import { WorkspaceDashboardHeader } from "components/headers/workspace-dashboard";
// types // types
import { NextPageWithLayout } from "types/app"; import { NextPageWithLayout } from "types/app";