Pulled ALL skills from 15 source repositories: - anthropics/skills: 16 (docs, design, MCP, testing) - obra/superpowers: 14 (TDD, debugging, agents, planning) - coreyhaines31/marketingskills: 25 (marketing, CRO, SEO, growth) - better-auth/skills: 5 (auth patterns) - vercel-labs/agent-skills: 5 (React, design, Vercel) - antfu/skills: 16 (Vue, Vite, Vitest, pnpm, Turborepo) - Plus 13 individual skills from various repos Mosaic Stack is not limited to coding — the Orchestrator and subagents serve coding, business, design, marketing, writing, logistics, analysis, and more. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
43 lines
1.1 KiB
Markdown
43 lines
1.1 KiB
Markdown
---
|
|
category: State
|
|
related: createGlobalState
|
|
---
|
|
|
|
# createSharedComposable
|
|
|
|
Make a composable function usable with multiple Vue instances.
|
|
|
|
> [!WARNING]
|
|
> When used in a **SSR** environment, `createSharedComposable` will **automatically fallback** to a non-shared version.
|
|
> This means every call will create a fresh instance in SSR to avoid [cross-request state pollution](https://vuejs.org/guide/scaling-up/ssr.html#cross-request-state-pollution).
|
|
|
|
## Usage
|
|
|
|
```ts
|
|
import { createSharedComposable, useMouse } from '@vueuse/core'
|
|
|
|
const useSharedMouse = createSharedComposable(useMouse)
|
|
|
|
// CompA.vue
|
|
const { x, y } = useSharedMouse()
|
|
|
|
// CompB.vue - will reuse the previous state and no new event listeners will be registered
|
|
const { x, y } = useSharedMouse()
|
|
```
|
|
|
|
## Type Declarations
|
|
|
|
```ts
|
|
export type SharedComposableReturn<T extends AnyFn = AnyFn> = T
|
|
/**
|
|
* Make a composable function usable with multiple Vue instances.
|
|
*
|
|
* @see https://vueuse.org/createSharedComposable
|
|
*
|
|
* @__NO_SIDE_EFFECTS__
|
|
*/
|
|
export declare function createSharedComposable<Fn extends AnyFn>(
|
|
composable: Fn,
|
|
): SharedComposableReturn<Fn>
|
|
```
|