phrazzld

typescript-excellence

2
1
# Install this skill:
npx skills add phrazzld/claude-config --skill "typescript-excellence"

Install specific skill from multi-skill repository

# Description

|

# SKILL.md


name: typescript-excellence
description: |
TypeScript best practices, type safety, and toolchain standards. Use when:
- Writing or reviewing TypeScript code
- Setting up TypeScript projects or tsconfig
- Choosing state management patterns
- Configuring build tools (tsup, Vitest)
- Avoiding type gymnastics or any-abuse
Keywords: TypeScript, tsconfig, strict mode, no-any, pnpm, Vitest, tsup,
TanStack Query, discriminated unions, type safety, ESLint


TypeScript Excellence

Type-safe, maintainable TypeScript with modern toolchain.

Type Safety

Never use any. Alternatives:

// Unknown for external data
function parse(input: unknown): User { ... }

// Union for specific options
type Status = 'loading' | 'success' | 'error';

// Generics for reusable code
function first<T>(arr: T[]): T | undefined { ... }

// Type assertion as last resort (with runtime check)
if (isUser(data)) { return data as User; }

tsconfig.json essentials:

{
  "compilerOptions": {
    "strict": true,
    "noImplicitAny": true,
    "noUncheckedIndexedAccess": true,
    "exactOptionalPropertyTypes": true
  }
}

Module Organization

Feature-based, not layer-based:

src/
  features/
    auth/
      components/
      hooks/
      api.ts
      types.ts
      index.ts  # Barrel: controlled exports
    orders/
      ...
  shared/
    ui/
    utils/

Use path aliases: @features/*, @shared/* (avoid ../../../../).

State Management

Server state: TanStack Query exclusively.

const { data, isLoading, error } = useQuery({
  queryKey: ['user', userId],
  queryFn: () => fetchUser(userId),
});

Client state: Discriminated unions.

type AuthState =
  | { status: 'idle' }
  | { status: 'loading' }
  | { status: 'authenticated'; user: User }
  | { status: 'error'; error: AppError };

Async Patterns

Always wrap, always context:

async function fetchUser(id: string): Promise<User> {
  try {
    const res = await fetch(`/api/users/${id}`);
    if (!res.ok) throw new ApiError(res.status, await res.text());
    return res.json();
  } catch (error) {
    throw new AppError('Failed to fetch user', { cause: error });
  }
}

Cancellation: Use AbortController for long operations.

Toolchain

Tool Purpose
pnpm Package manager (declare in packageManager field)
Vitest Testing (unit/integration/e2e)
tsup Builds (ESM + CJS + .d.ts)
ESLint Linting (@typescript-eslint/no-explicit-any: error)
Prettier Formatting

Anti-Patterns

  • Type gymnastics (conditional types, template literals without justification)
  • useState + useEffect for server data (use TanStack Query)
  • Technical-layer folders (/controllers, /services, /models)
  • eslint-disable without documented justification
  • Mocking internal components (mock boundaries only)
  • Mixed package managers or test frameworks

References

# Supported AI Coding Agents

This skill is compatible with the SKILL.md standard and works with all major AI coding agents:

Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.