about summary refs log tree commit diff
path: root/src/components/Menu/context.tsx
blob: 1c4a873b3bd62c4966fa8cf537c71a932558df08 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import React from 'react'

import {type ContextType, type ItemContextType} from '#/components/Menu/types'

export const Context = React.createContext<ContextType | null>(null)
Context.displayName = 'MenuContext'

export const ItemContext = React.createContext<ItemContextType | null>(null)
ItemContext.displayName = 'MenuItemContext'

export function useMenuContext() {
  const context = React.useContext(Context)

  if (!context) {
    throw new Error('useMenuContext must be used within a Context.Provider')
  }

  return context
}

export function useMenuItemContext() {
  const context = React.useContext(ItemContext)

  if (!context) {
    throw new Error('useMenuItemContext must be used within a Context.Provider')
  }

  return context
}