* initialized next.js project * finished markdown sections * added operation schema component * change page metadata * eslint fixes * fixes related to deployment * added response schema * resolve max stack issue * support for different property types * added support for property types * added loading for components * added more loading * type fixes * added oneOf type * removed console * fix replace with push * refactored everything * use static content for description * fixes and improvements * added code examples section * fix path name * optimizations * fixed tag navigation * add support for admin and store references * general enhancements * optimizations and fixes * fixes and enhancements * added search bar * loading enhancements * added loading * added code blocks * added margin top * add empty response text * fixed oneOf parameters * added path and query parameters * general fixes * added base path env variable * small fix for arrays * enhancements * design enhancements * general enhancements * fix isRequired * added enum values * enhancements * general fixes * general fixes * changed oas generation script * additions to the introduction section * added copy button for code + other enhancements * fix response code block * fix metadata * formatted store introduction * move sidebar logic to Tags component * added test env variables * fix code block bug * added loading animation * added expand param + loading * enhance operation loading * made responsive + improvements * added loading provider * fixed loading * adjustments for small devices * added sidebar label for endpoints * added feedback component * fixed analytics * general fixes * listen to scroll for other headings * added sample env file * update api ref files + support new fields * fix for external docs link * added new sections * fix last item in sidebar not showing * move docs content to www/docs * change redirect url * revert change * resolve build errors * configure rewrites * changed to environment variable url * revert changing environment variable name * add environment variable for API path * fix links * fix tailwind settings * remove vercel file * reconfigured api route * move api page under api * fix page metadata * fix external link in navigation bar * update api spec * updated api specs * fixed google lint error * add max-height on request samples * add padding before loading * fix for one of name * fix undefined types * general fixes * remove response schema example * redesigned navigation bar * redesigned sidebar * fixed up paddings * added feedback component + report issue * fixed up typography, padding, and general styling * redesigned code blocks * optimization * added error timeout * fixes * added indexing with algolia + fixes * fix errors with algolia script * redesign operation sections * fix heading scroll * design fixes * fix padding * fix padding + scroll issues * fix scroll issues * improve scroll performance * fixes for safari * optimization and fixes * fixes to docs + details animation * padding fixes for code block * added tab animation * fixed incorrect link * added selection styling * fix lint errors * redesigned details component * added detailed feedback form * api reference fixes * fix tabs * upgrade + fixes * updated documentation links * optimizations to sidebar items * fix spacing in sidebar item * optimizations and fixes * fix endpoint path styling * remove margin * final fixes * change margin on small devices * generated OAS * fixes for mobile * added feedback modal * optimize dark mode button * fixed color mode useeffect * minimize dom size * use new style system * radius and spacing design system * design fixes * fix eslint errors * added meta files * change cron schedule * fix docusaurus configurations * added operating system to feedback data * change content directory name * fixes to contribution guidelines * revert renaming content * added api-reference to documentation workflow * fixes for search * added dark mode + fixes * oas fixes * handle bugs * added code examples for clients * changed tooltip text * change authentication to card * change page title based on selected section * redesigned mobile navbar * fix icon colors * fix key colors * fix medusa-js installation command * change external regex in algolia * change changeset * fix padding on mobile * fix hydration error * update depedencies
208 lines
6.2 KiB
TypeScript
208 lines
6.2 KiB
TypeScript
"use client"
|
|
|
|
import React, { useRef, useState } from "react"
|
|
import { CSSTransition, SwitchTransition } from "react-transition-group"
|
|
import Solutions from "./Solutions/index"
|
|
import Button from "../Button"
|
|
import { ExtraData, useAnalytics } from "@/providers/analytics"
|
|
import { usePathname } from "next/navigation"
|
|
import Link from "next/link"
|
|
import { useArea } from "../../providers/area"
|
|
import clsx from "clsx"
|
|
import TextArea from "../TextArea"
|
|
import Label from "../Label"
|
|
|
|
type FeedbackProps = {
|
|
event: string
|
|
question?: string
|
|
positiveBtn?: string
|
|
negativeBtn?: string
|
|
positiveQuestion?: string
|
|
negativeQuestion?: string
|
|
submitBtn?: string
|
|
submitMessage?: string
|
|
showPossibleSolutions?: boolean
|
|
className?: string
|
|
extraData?: ExtraData
|
|
sectionTitle?: string
|
|
vertical?: boolean
|
|
} & React.HTMLAttributes<HTMLDivElement>
|
|
|
|
const Feedback: React.FC<FeedbackProps> = ({
|
|
event,
|
|
question = "Was this section helpful?",
|
|
positiveBtn = "Yes",
|
|
negativeBtn = "No",
|
|
positiveQuestion = "What was most helpful?",
|
|
negativeQuestion = "What can we improve?",
|
|
submitBtn = "Submit",
|
|
submitMessage = "Thank you for helping improve our documentation!",
|
|
showPossibleSolutions = true,
|
|
className = "",
|
|
extraData = {},
|
|
sectionTitle = "",
|
|
vertical = false,
|
|
}) => {
|
|
const [showForm, setShowForm] = useState(false)
|
|
const [submittedFeedback, setSubmittedFeedback] = useState(false)
|
|
const [loading, setLoading] = useState(false)
|
|
const inlineFeedbackRef = useRef<HTMLDivElement>(null)
|
|
const inlineQuestionRef = useRef<HTMLDivElement>(null)
|
|
const inlineMessageRef = useRef<HTMLDivElement>(null)
|
|
const [positiveFeedback, setPositiveFeedback] = useState(false)
|
|
const [message, setMessage] = useState("")
|
|
const nodeRef: React.RefObject<HTMLDivElement> = submittedFeedback
|
|
? inlineMessageRef
|
|
: showForm
|
|
? inlineQuestionRef
|
|
: inlineFeedbackRef
|
|
|
|
const pathname = usePathname()
|
|
const { loaded, track } = useAnalytics()
|
|
const { area } = useArea()
|
|
|
|
function handleFeedback(e: React.MouseEvent<HTMLButtonElement, MouseEvent>) {
|
|
if (!loaded) {
|
|
return
|
|
}
|
|
const feedback = (e.target as Element).classList.contains("positive")
|
|
setPositiveFeedback(feedback)
|
|
setShowForm(true)
|
|
submitFeedback(e, feedback)
|
|
}
|
|
|
|
function submitFeedback(
|
|
e: React.MouseEvent<HTMLButtonElement, MouseEvent>,
|
|
feedback = false
|
|
) {
|
|
if (showForm) {
|
|
setLoading(true)
|
|
}
|
|
track(
|
|
event,
|
|
{
|
|
url: pathname,
|
|
label: document.title,
|
|
feedback:
|
|
(feedback !== null && feedback) ||
|
|
(feedback === null && positiveFeedback)
|
|
? "yes"
|
|
: "no",
|
|
message: message?.length ? message : null,
|
|
os: window.navigator.userAgent,
|
|
...extraData,
|
|
},
|
|
function () {
|
|
if (showForm) {
|
|
setLoading(false)
|
|
resetForm()
|
|
}
|
|
}
|
|
)
|
|
}
|
|
|
|
function resetForm() {
|
|
setShowForm(false)
|
|
setSubmittedFeedback(true)
|
|
}
|
|
|
|
return (
|
|
<div className={clsx("mt-3", className)}>
|
|
<SwitchTransition mode="out-in">
|
|
<CSSTransition
|
|
key={
|
|
showForm
|
|
? "show_form"
|
|
: !submittedFeedback
|
|
? "feedback"
|
|
: "submitted_feedback"
|
|
}
|
|
nodeRef={nodeRef}
|
|
timeout={300}
|
|
addEndListener={(done) => {
|
|
nodeRef.current?.addEventListener("transitionend", done, false)
|
|
}}
|
|
classNames={{
|
|
enter: "animate-fadeIn animate-fill-forwards animate-fast",
|
|
exit: "animate-fadeOut animate-fill-forwards animate-fast",
|
|
}}
|
|
>
|
|
<>
|
|
{!showForm && !submittedFeedback && (
|
|
<div
|
|
className={clsx(
|
|
"flex",
|
|
!vertical && "flex-row items-center",
|
|
vertical && "flex-col justify-center gap-1"
|
|
)}
|
|
ref={inlineFeedbackRef}
|
|
>
|
|
<Label className="mr-1.5">{question}</Label>
|
|
<div className={clsx("flex flex-row items-center gap-0.5")}>
|
|
<Button
|
|
onClick={handleFeedback}
|
|
className="positive w-fit"
|
|
variant="secondary"
|
|
>
|
|
{positiveBtn}
|
|
</Button>
|
|
<Button
|
|
onClick={handleFeedback}
|
|
className="w-fit"
|
|
variant="secondary"
|
|
>
|
|
{negativeBtn}
|
|
</Button>
|
|
<Link
|
|
href={`https://github.com/medusajs/medusa/issues/new?assignees=&labels=type%3A+docs&template=docs.yml&title=API%20Ref%28${area}%29%3A%20Issue%20in%20${encodeURI(
|
|
sectionTitle
|
|
)}`}
|
|
className="btn-secondary"
|
|
>
|
|
Report Issue
|
|
</Link>
|
|
</div>
|
|
</div>
|
|
)}
|
|
{showForm && !submittedFeedback && (
|
|
<div className="flex flex-col gap-1" ref={inlineQuestionRef}>
|
|
<Label>
|
|
{positiveFeedback ? positiveQuestion : negativeQuestion}
|
|
</Label>
|
|
<TextArea
|
|
rows={4}
|
|
value={message}
|
|
onChange={(e) => setMessage(e.target.value)}
|
|
/>
|
|
<Button
|
|
onClick={submitFeedback}
|
|
disabled={loading}
|
|
className="w-fit"
|
|
variant="secondary"
|
|
>
|
|
{submitBtn}
|
|
</Button>
|
|
</div>
|
|
)}
|
|
{submittedFeedback && (
|
|
<div>
|
|
<div
|
|
className="text-compact-large-plus flex flex-col"
|
|
ref={inlineMessageRef}
|
|
>
|
|
<span>{submitMessage}</span>
|
|
{showPossibleSolutions && (
|
|
<Solutions message={message} feedback={positiveFeedback} />
|
|
)}
|
|
</div>
|
|
</div>
|
|
)}
|
|
</>
|
|
</CSSTransition>
|
|
</SwitchTransition>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default Feedback
|