* 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
112 lines
2.5 KiB
TypeScript
112 lines
2.5 KiB
TypeScript
"use client"
|
|
|
|
import React, { createContext, useContext, useEffect, useState } from "react"
|
|
import { Analytics, AnalyticsBrowser } from "@segment/analytics-next"
|
|
import { Area } from "@/types/openapi"
|
|
|
|
export type ExtraData = {
|
|
area: Area
|
|
section?: string
|
|
}
|
|
|
|
type AnalyticsContextType = {
|
|
loaded: boolean
|
|
analytics: Analytics | null
|
|
track: (
|
|
event: string,
|
|
options?: Record<string, any>,
|
|
callback?: () => void
|
|
) => void
|
|
}
|
|
|
|
const AnalyticsContext = createContext<AnalyticsContextType | null>(null)
|
|
|
|
type AnalyticsProviderProps = {
|
|
children?: React.ReactNode
|
|
}
|
|
|
|
const LOCAL_STORAGE_KEY = "ajs_anonymous_id"
|
|
|
|
const AnalyticsProvider: React.FC<AnalyticsProviderProps> = ({ children }) => {
|
|
// loaded is used to ensure that a connection has been made to segment
|
|
// even if it failed. This is to ensure that the connection isn't
|
|
// continuously retried
|
|
const [loaded, setLoaded] = useState<boolean>(false)
|
|
const [analytics, setAnalytics] = useState<Analytics | null>(null)
|
|
const analyticsBrowser = new AnalyticsBrowser()
|
|
|
|
const init = () => {
|
|
if (!loaded) {
|
|
analyticsBrowser
|
|
.load(
|
|
{ writeKey: process.env.NEXT_PUBLIC_SEGMENT_API_KEY || "temp" },
|
|
{
|
|
initialPageview: true,
|
|
user: {
|
|
localStorage: {
|
|
key: LOCAL_STORAGE_KEY,
|
|
},
|
|
},
|
|
}
|
|
)
|
|
.then((instance) => {
|
|
setAnalytics(instance[0])
|
|
})
|
|
.catch((e) =>
|
|
console.error(`Could not connect to Segment. Error: ${e}`)
|
|
)
|
|
.finally(() => setLoaded(true))
|
|
}
|
|
}
|
|
|
|
const track = async (
|
|
event: string,
|
|
options?: Record<string, any>,
|
|
callback?: () => void
|
|
) => {
|
|
if (analytics) {
|
|
void analytics.track(
|
|
event,
|
|
{
|
|
...options,
|
|
uuid: analytics.user().anonymousId(),
|
|
},
|
|
callback
|
|
)
|
|
} else if (callback) {
|
|
console.warn(
|
|
"Segment is either not installed or not configured. Simulating success..."
|
|
)
|
|
callback()
|
|
}
|
|
}
|
|
|
|
useEffect(() => {
|
|
init()
|
|
}, [])
|
|
|
|
return (
|
|
<AnalyticsContext.Provider
|
|
value={{
|
|
analytics,
|
|
track,
|
|
loaded,
|
|
}}
|
|
>
|
|
{children}
|
|
</AnalyticsContext.Provider>
|
|
)
|
|
}
|
|
|
|
export default AnalyticsProvider
|
|
|
|
export const useAnalytics = () => {
|
|
const context = useContext(AnalyticsContext)
|
|
|
|
if (!context) {
|
|
throw new Error("useAnalytics must be used within a AnalyticsProvider")
|
|
}
|
|
|
|
return context
|
|
}
|