createTrinity
The createTrinity factory function is a type-safe utility for generating a 3-item tuple—called a trinity—which contains a context consumer, a provider, and the underlying context object.
Usage
The trinity pattern is the marrying of provide and inject with a context object. It provides a clean and type safe way to create a sharable singleton state.
import { ref } from 'vue'
import { createContext, createTrinity } from '@vuetify/v0'
import type { Ref } from 'vue'
interface User {
id: string
name: string
}
interface UserContext {
user: Ref<User>
update: (user: User) => void
}
function createUserContext() {
const [useContext, provideContext] = createContext<UserContext>('user')
const user = ref<User>({ id: '123', name: 'John Doe' })
function update(record: User) {
user.value = record
}
const context: UserContext = {
user,
update,
}
return createTrinity<UserContext>(useContext, provideContext, context)
}
export const [useUser, provideUser, context] = createUserContext()Architecture
createTrinity builds on createContext to provide a standardized 3-tuple pattern:
Examples
Toast Notification System
A toast notification system split into four files demonstrating real-world trinity usage:
| File | Role |
|---|---|
toasts.ts | Context factory — creates the trinity tuple |
ToastProvider.vue | Calls provideToasts() and renders a slot |
ToastConsumer.vue | Calls useToasts() to inject and display toasts |
toast-system.vue | Entry point — wraps Provider around Consumer |
Key patterns:
createToastContextwraps bothcreateContextandcreateTrinity— the factory builds the context object and returns the trinity in one stepprovideToasts()called with no arguments provides the default context — the trinity’s provider wrapper handles the fallback automaticallyToastConsumercallsuseToasts()to inject the context from the nearest providerThe entry point composes Provider and Consumer — the same pattern scales to any app
Quick notifications
useToasts
Consumer
provideToasts
Provider
toastsContext
Default context
Functions
createTrinity
(useContext: () => Z, provideContext: (_context?: Z, app?: App) => Z, context: Z) => ContextTrinity<Z>Creates a new trinity for a context composable and its provider.