create-adaptable-composable▌
vuejs-ai/skills · updated Apr 8, 2026
Library-grade Vue composables that accept plain values, refs, or getters as inputs.
- ›Use MaybeRefOrGetter for read-only inputs (computed-friendly) and MaybeRef for writable two-way inputs; normalize with toValue() or toRef() inside reactive effects
- ›Normalize inputs using toRef() for watcher sources and toValue() for non-reactive resolution to keep behavior predictable across different input types
- ›Avoid MaybeRefOrGetter when parameters are callbacks, predicates, or comparators to preve
Create Adaptable Composable
Adaptable composables are reusable functions that can accept both reactive and non-reactive inputs. This allows developers to use the composable in a variety of contexts without worrying about the reactivity of the inputs.
Steps to design an adaptable composable in Vue.js:
- Confirm the composable's purpose and API design and expected inputs/outputs.
- Identify inputs params that should be reactive (MaybeRef / MaybeRefOrGetter).
- Use
toValue()ortoRef()to normalize inputs inside reactive effects. - Implement the core logic of the composable using Vue's reactivity APIs.
Core Type Concepts
Type Utilities
/**
* value or writable ref (value/ref/shallowRef/writable computed)
*/
export type MaybeRef<T = any> = T | Ref<T> | ShallowRef<T> | WritableComputedRef<T>;
/**
* MaybeRef<T> + ComputedRef<T> + () => T
*/
export type MaybeRefOrGetter<T = any> = MaybeRef<T> | ComputedRef<T> | (() => T);
Policy and Rules
- Read-only, computed-friendly input: use
MaybeRefOrGetter - Needs to be writable / two-way input: use
MaybeRef - Parameter might be a function value (callback/predicate/comparator): do not use
MaybeRefOrGetter, or you may accidentally invoke it as a getter. - DOM/Element targets: if you want computed/derived targets, use
MaybeRefOrGetter.
When MaybeRefOrGetter or MaybeRef is used:
- resolve reactive value using
toRef()(e.g. watcher source) - resolve non-reactive value using
toValue()
Examples
Adaptable useDocumentTitle Composable: read-only title parameter
import { watch, toRef } from 'vue'
import type { MaybeRefOrGetter } from 'vue'
export function useDocumentTitle(title: MaybeRefOrGetter<string>) {
watch(toRef(title), (t) => {
document.title = t
}, { immediate: true })
}
Adaptable useCounter Composable: two-way writable count parameter
import { watch, toRef } from 'vue'
import type { MaybeRef } from 'vue'
function useCounter(count: MaybeRef<number>) {
const countRef = toRef(count)
function add() {
countRef.value++
}
return { add }
}
Discussion
Product Hunt–style comments (not star reviews)- No comments yet — start the thread.
Ratings
4.8★★★★★59 reviews- ★★★★★Aanya Sharma· Dec 24, 2024
Keeps context tight: create-adaptable-composable is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Ava Thompson· Dec 20, 2024
I recommend create-adaptable-composable for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.
- ★★★★★Aanya Gupta· Dec 16, 2024
create-adaptable-composable fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.
- ★★★★★Ganesh Mohane· Dec 8, 2024
Useful defaults in create-adaptable-composable — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.
- ★★★★★Aarav Agarwal· Dec 4, 2024
create-adaptable-composable has been reliable in day-to-day use. Documentation quality is above average for community skills.
- ★★★★★Mia Gonzalez· Dec 4, 2024
create-adaptable-composable is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
- ★★★★★Rahul Santra· Nov 27, 2024
create-adaptable-composable has been reliable in day-to-day use. Documentation quality is above average for community skills.
- ★★★★★Aanya Kapoor· Nov 23, 2024
We added create-adaptable-composable from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.
- ★★★★★Ava White· Nov 23, 2024
Useful defaults in create-adaptable-composable — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.
- ★★★★★Sakura Smith· Nov 23, 2024
create-adaptable-composable reduced setup friction for our internal harness; good balance of opinion and flexibility.
showing 1-10 of 59