mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-11 09:51:40 +00:00
* feat: init * fix * fix * fix * feat * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: implement icons * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: update init command * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: dialog * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add registry:base item type * feat: rename frame to canva * fix * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fi * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add all colors * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add outfit font * fix * fix * fix * fix * fix * chore: changeset * fix * fix * fix * fix * fix * fix * fix * fix
58 lines
1.3 KiB
TypeScript
58 lines
1.3 KiB
TypeScript
"use client"
|
|
|
|
import * as React from "react"
|
|
|
|
export type LockableParam =
|
|
| "style"
|
|
| "baseColor"
|
|
| "theme"
|
|
| "iconLibrary"
|
|
| "font"
|
|
| "menuAccent"
|
|
| "menuColor"
|
|
| "radius"
|
|
|
|
type LocksContextValue = {
|
|
locks: Set<LockableParam>
|
|
isLocked: (param: LockableParam) => boolean
|
|
toggleLock: (param: LockableParam) => void
|
|
}
|
|
|
|
const LocksContext = React.createContext<LocksContextValue | null>(null)
|
|
|
|
export function LocksProvider({ children }: { children: React.ReactNode }) {
|
|
const [locks, setLocks] = React.useState<Set<LockableParam>>(new Set())
|
|
|
|
const isLocked = React.useCallback(
|
|
(param: LockableParam) => locks.has(param),
|
|
[locks]
|
|
)
|
|
|
|
const toggleLock = React.useCallback((param: LockableParam) => {
|
|
setLocks((prev) => {
|
|
const next = new Set(prev)
|
|
if (next.has(param)) {
|
|
next.delete(param)
|
|
} else {
|
|
next.add(param)
|
|
}
|
|
return next
|
|
})
|
|
}, [])
|
|
|
|
const value = React.useMemo(
|
|
() => ({ locks, isLocked, toggleLock }),
|
|
[locks, isLocked, toggleLock]
|
|
)
|
|
|
|
return <LocksContext value={value}>{children}</LocksContext>
|
|
}
|
|
|
|
export function useLocks() {
|
|
const context = React.useContext(LocksContext)
|
|
if (!context) {
|
|
throw new Error("useLocks must be used within LocksProvider")
|
|
}
|
|
return context
|
|
}
|