- Extract atlas/ into 15 focused modules (hook, event handler, tool policies, types, etc.) - Split auto-update-checker into checker/ and hook/ subdirectories with single-purpose files - Decompose session-recovery into separate recovery strategy files per error type - Extract todo-continuation-enforcer from monolith to directory with dedicated modules - Split background-task/tools.ts into individual tool creator files - Extract command-executor, tmux-utils into focused sub-modules - Split config/schema.ts into domain-specific schema files - Decompose cli/config-manager.ts into focused modules - Rollback skill-mcp-manager, model-availability, index.ts splits that broke tests - Fix all import path depths for moved files (../../ -> ../../../) - Add explicit type annotations to resolve TS7006 implicit any errors Typecheck: 0 errors Tests: 2359 pass, 5 fail (all pre-existing)
26 lines
798 B
TypeScript
26 lines
798 B
TypeScript
import type { PluginInput } from "@opencode-ai/plugin"
|
|
|
|
const SISYPHUS_SPINNER = ["·", "•", "●", "○", "◌", "◦", " "]
|
|
|
|
export async function showSpinnerToast(ctx: PluginInput, version: string, message: string): Promise<void> {
|
|
const totalDuration = 5000
|
|
const frameInterval = 100
|
|
const totalFrames = Math.floor(totalDuration / frameInterval)
|
|
|
|
for (let i = 0; i < totalFrames; i++) {
|
|
const spinner = SISYPHUS_SPINNER[i % SISYPHUS_SPINNER.length]
|
|
await ctx.client.tui
|
|
.showToast({
|
|
body: {
|
|
title: `${spinner} OhMyOpenCode ${version}`,
|
|
message,
|
|
variant: "info" as const,
|
|
duration: frameInterval + 50,
|
|
},
|
|
})
|
|
.catch(() => {})
|
|
|
|
await new Promise((resolve) => setTimeout(resolve, frameInterval))
|
|
}
|
|
}
|