feat: Complete fleet — 94 skills across 10+ domains
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>
This commit is contained in:
87
skills/vueuse-functions/references/useAsyncQueue.md
Normal file
87
skills/vueuse-functions/references/useAsyncQueue.md
Normal file
@@ -0,0 +1,87 @@
|
||||
---
|
||||
category: Utilities
|
||||
---
|
||||
|
||||
# useAsyncQueue
|
||||
|
||||
Executes each asynchronous task sequentially and passes the current task result to the next task
|
||||
|
||||
## Usage
|
||||
|
||||
```ts
|
||||
import { useAsyncQueue } from '@vueuse/core'
|
||||
|
||||
function p1() {
|
||||
return new Promise((resolve) => {
|
||||
setTimeout(() => {
|
||||
resolve(1000)
|
||||
}, 10)
|
||||
})
|
||||
}
|
||||
|
||||
function p2(result: number) {
|
||||
return new Promise((resolve) => {
|
||||
setTimeout(() => {
|
||||
resolve(1000 + result)
|
||||
}, 20)
|
||||
})
|
||||
}
|
||||
|
||||
const { activeIndex, result } = useAsyncQueue([p1, p2])
|
||||
|
||||
console.log(activeIndex.value) // current pending task index
|
||||
|
||||
console.log(result) // the tasks result
|
||||
```
|
||||
|
||||
## Type Declarations
|
||||
|
||||
```ts
|
||||
export type UseAsyncQueueTask<T> = (...args: any[]) => T | Promise<T>
|
||||
type MapQueueTask<T extends any[]> = {
|
||||
[K in keyof T]: UseAsyncQueueTask<T[K]>
|
||||
}
|
||||
export interface UseAsyncQueueResult<T> {
|
||||
state: "aborted" | "fulfilled" | "pending" | "rejected"
|
||||
data: T | null
|
||||
}
|
||||
export interface UseAsyncQueueReturn<T> {
|
||||
activeIndex: ShallowRef<number>
|
||||
result: T
|
||||
}
|
||||
export interface UseAsyncQueueOptions {
|
||||
/**
|
||||
* Interrupt tasks when current task fails.
|
||||
*
|
||||
* @default true
|
||||
*/
|
||||
interrupt?: boolean
|
||||
/**
|
||||
* Trigger it when the tasks fails.
|
||||
*
|
||||
*/
|
||||
onError?: () => void
|
||||
/**
|
||||
* Trigger it when the tasks ends.
|
||||
*
|
||||
*/
|
||||
onFinished?: () => void
|
||||
/**
|
||||
* A AbortSignal that can be used to abort the task.
|
||||
*/
|
||||
signal?: AbortSignal
|
||||
}
|
||||
/**
|
||||
* Asynchronous queue task controller.
|
||||
*
|
||||
* @see https://vueuse.org/useAsyncQueue
|
||||
* @param tasks
|
||||
* @param options
|
||||
*/
|
||||
export declare function useAsyncQueue<T extends any[], S = MapQueueTask<T>>(
|
||||
tasks: S & Array<UseAsyncQueueTask<any>>,
|
||||
options?: UseAsyncQueueOptions,
|
||||
): UseAsyncQueueReturn<{
|
||||
[P in keyof T]: UseAsyncQueueResult<T[P]>
|
||||
}>
|
||||
```
|
||||
Reference in New Issue
Block a user