docs: create docs workspace (#5174)
* docs: migrate ui docs to docs universe * created yarn workspace * added eslint and tsconfig configurations * fix eslint configurations * fixed eslint configurations * shared tailwind configurations * added shared ui package * added more shared components * migrating more components * made details components shared * move InlineCode component * moved InputText * moved Loading component * Moved Modal component * moved Select components * Moved Tooltip component * moved Search components * moved ColorMode provider * Moved Notification components and providers * used icons package * use UI colors in api-reference * moved Navbar component * used Navbar and Search in UI docs * added Feedback to UI docs * general enhancements * fix color mode * added copy colors file from ui-preset * added features and enhancements to UI docs * move Sidebar component and provider * general fixes and preparations for deployment * update docusaurus version * adjusted versions * fix output directory * remove rootDirectory property * fix yarn.lock * moved code component * added vale for all docs MD and MDX * fix tests * fix vale error * fix deployment errors * change ignore commands * add output directory * fix docs test * general fixes * content fixes * fix announcement script * added changeset * fix vale checks * added nofilter option * fix vale error
This commit is contained in:
45
www/apps/api-reference/providers/loading.tsx
Normal file
45
www/apps/api-reference/providers/loading.tsx
Normal file
@@ -0,0 +1,45 @@
|
||||
import { createContext, useContext, useState } from "react"
|
||||
|
||||
type LoadingContextType = {
|
||||
loading: boolean
|
||||
removeLoading: () => void
|
||||
}
|
||||
|
||||
const LoadingContext = createContext<LoadingContextType | null>(null)
|
||||
|
||||
type LoadingProviderProps = {
|
||||
children: React.ReactNode
|
||||
initialLoading?: boolean
|
||||
}
|
||||
|
||||
const LoadingProvider = ({
|
||||
children,
|
||||
initialLoading = false,
|
||||
}: LoadingProviderProps) => {
|
||||
const [loading, setLoading] = useState<boolean>(initialLoading)
|
||||
|
||||
const removeLoading = () => setLoading(false)
|
||||
|
||||
return (
|
||||
<LoadingContext.Provider
|
||||
value={{
|
||||
loading,
|
||||
removeLoading,
|
||||
}}
|
||||
>
|
||||
{children}
|
||||
</LoadingContext.Provider>
|
||||
)
|
||||
}
|
||||
|
||||
export default LoadingProvider
|
||||
|
||||
export const useLoading = (): LoadingContextType => {
|
||||
const context = useContext(LoadingContext)
|
||||
|
||||
if (!context) {
|
||||
throw new Error("useLoading must be used inside a LoadingProvider")
|
||||
}
|
||||
|
||||
return context
|
||||
}
|
||||
Reference in New Issue
Block a user