Bpistle/src/components/FavoriteRelaysSetting/provider.tsx
2025-04-05 15:31:34 +08:00

40 lines
1.2 KiB
TypeScript

import { createContext, useContext, useState } from 'react'
type TRelaySetsSettingComponentContext = {
renamingRelaySetId: string | null
setRenamingRelaySetId: React.Dispatch<React.SetStateAction<string | null>>
expandedRelaySetId: string | null
setExpandedRelaySetId: React.Dispatch<React.SetStateAction<string | null>>
}
export const RelaySetsSettingComponentContext = createContext<
TRelaySetsSettingComponentContext | undefined
>(undefined)
export const useRelaySetsSettingComponent = () => {
const context = useContext(RelaySetsSettingComponentContext)
if (!context) {
throw new Error(
'useRelaySetsSettingComponent must be used within a RelaySetsSettingComponentProvider'
)
}
return context
}
export function RelaySetsSettingComponentProvider({ children }: { children: React.ReactNode }) {
const [renamingRelaySetId, setRenamingRelaySetId] = useState<string | null>(null)
const [expandedRelaySetId, setExpandedRelaySetId] = useState<string | null>(null)
return (
<RelaySetsSettingComponentContext.Provider
value={{
renamingRelaySetId,
setRenamingRelaySetId,
expandedRelaySetId,
setExpandedRelaySetId
}}
>
{children}
</RelaySetsSettingComponentContext.Provider>
)
}