Skip to main content
Vuetify0 is now in alpha!
Vuetify0 Logo
Theme
Mode
Palettes
Accessibility
Vuetify One
Sign in to Vuetify One

Access premium tools across the Vuetify ecosystem — Bin, Play, Studio, and more.

Not a subscriber? See what's included

createTrinity

Generates a typed [useX, provideX, defaultX] tuple for Vue’s provide/inject dependency injection pattern.

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.

ts
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:

Trinity Pattern

Use controls to zoom and pan. Click outside or press Escape to close.

Trinity Pattern

Plugin Trinity

When building a Vue plugin, use createPluginContext instead of wiring createContext + createTrinity manually. It generates the same trinity tuple from a factory function with far less boilerplate:

ts
// Manual (createTrinity) — needed for non-plugin state
export const [useUser, provideUser, userContext] = createUserContext()

// Plugin (createPluginContext) — preferred for app.use() plugins
export const [createThemeContext, createThemePlugin, useTheme] =
  createPluginContext('v0:theme', options => createTheme(options))

createTrinity is the right tool when you want a shared singleton without a Vue plugin — component-scoped contexts, library utilities, or any state that doesn’t need app.use() lifecycle hooks.

Examples

Toast Notification System

A toast notification system split into four files demonstrating real-world trinity usage:

FileRole
toasts.tsContext factory — creates the trinity tuple
ToastProvider.vueCalls provideToasts() and renders a slot
ToastConsumer.vueCalls useToasts() to inject and display toasts
toast-system.vueEntry point — wraps Provider around Consumer
Trinity Flow

Use controls to zoom and pan. Click outside or press Escape to close.

Trinity Flow

Key patterns:

  • createToastContext wraps both createContext and createTrinity — the factory builds the context object and returns the trinity in one step

  • provideToasts() called with no arguments provides the default context — the trinity’s provider wrapper handles the fallback automatically

  • ToastConsumer calls useToasts() to inject the context from the nearest provider

  • The entry point composes Provider and Consumer — the same pattern scales to any app

Quick notifications

0 active notifications
No notifications. Click a button above to fire one.

useToasts

Consumer

provideToasts

Provider

toastsContext

Default context

API Reference

The following API details are for the createTrinity composable.

Functions

createTrinity

(keyOrUseContext: string | (() => Z), provideContextOrContext: Z | ((context: Z, app?: App) => Z), maybeContext?: Z | undefined) => ContextTrinity<Z>
Was this page helpful?

© 2016-1970 Vuetify, LLC
Ctrl+/