typescript

prowler-cloud/prowler · updated Apr 8, 2026

$npx skills add https://github.com/prowler-cloud/prowler --skill typescript
0 commentsdiscussion
summary

Why? Single source of truth, runtime values, autocomplete, easier refactoring.

skill.md

Const Types Pattern (REQUIRED)

// ✅ ALWAYS: Create const object first, then extract type
const STATUS = {
  ACTIVE: "active",
  INACTIVE: "inactive",
  PENDING: "pending",
} as const;

type Status = (typeof STATUS)[keyof typeof STATUS];

// ❌ NEVER: Direct union types
type Status = "active" | "inactive" | "pending";

Why? Single source of truth, runtime values, autocomplete, easier refactoring.

Flat Interfaces (REQUIRED)

// ✅ ALWAYS: One level depth, nested objects → dedicated interface
interface UserAddress {
  street: string;
  city: string;
}

interface User {
  id: string;
  name: string;
  address: UserAddress;  // Reference, not inline
}

interface Admin extends User {
  permissions: string[];
}

// ❌ NEVER: Inline nested objects
interface User {
  address: { street: string; city: string };  // NO!
}

Never Use any

// ✅ Use unknown for truly unknown types
function parse(input: unknown): User {
  if (isUser(input)) return input;
  throw new Error("Invalid input");
}

// ✅ Use generics for flexible types
function first<T>(arr: T[]): T | undefined {
  return arr[0];
}

// ❌ NEVER
function parse(input: any): any { }

Utility Types

Pick<User, "id" | "name">     // Select fields
Omit<User, "id">              // Exclude fields
Partial<User>                 // All optional
Required<User>                // All required
Readonly<User>                // All readonly
Record<string, User>          // Object type
Extract<Union, "a" | "b">     // Extract from union
Exclude<Union, "a">           // Exclude from union
NonNullable<T | null>         // Remove null/undefined
ReturnType<typeof fn>         // Function return type
Parameters<typeof fn>         // Function params tuple

Type Guards

function isUser(value: unknown): value is User {
  return (
    typeof value === "object" &&
    value !== null &&
    "id" in value &&
    "name" in value
  );
}

Coupled Optional Props (REQUIRED)

Do not model semantically coupled props as independent optionals — this allows invalid half-states that compile but break at runtime. Use discriminated unions with never to make invalid combinations impossible.

// ❌ BEFORE: Independent optionals — half-states allowed
interface PaginationProps {
  onPageChange?: (page: number) => void;
  pageSize?: number;
  currentPage?: number;
}

// ✅ AFTER: Discriminated union — shape is all-or-nothing
type ControlledPagination = {
  controlled: true;
  currentPage: number;
  pageSize: number;
  onPageChange: (page: number) => void;
};

type UncontrolledPagination = {
  controlled: false;
  currentPage?: never;
  pageSize?: never;
  onPageChange?: never;
};

type PaginationProps = ControlledPagination | UncontrolledPagination;

Key rule: If two or more props are only meaningful together, they belong to the same discriminated union branch. Mixing them as independent optionals shifts correctness responsibility from the type system to runtime guards.

Import Types

import type { User } from "./types";
import { createUser, type Config } from "./utils";

Discussion

Product Hunt–style comments (not star reviews)
  • No comments yet — start the thread.
general reviews

Ratings

4.552 reviews
  • Michael Kapoor· Dec 28, 2024

    typescript reduced setup friction for our internal harness; good balance of opinion and flexibility.

  • Harper Sanchez· Dec 16, 2024

    typescript is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.

  • Ganesh Mohane· Dec 8, 2024

    typescript fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.

  • Chinedu Perez· Dec 8, 2024

    We added typescript from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.

  • Ama Jackson· Dec 8, 2024

    Useful defaults in typescript — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.

  • Rahul Santra· Nov 27, 2024

    typescript is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.

  • Isabella Malhotra· Nov 27, 2024

    Keeps context tight: typescript is the kind of skill you can hand to a new teammate without a long onboarding doc.

  • Aarav Shah· Nov 27, 2024

    typescript has been reliable in day-to-day use. Documentation quality is above average for community skills.

  • Isabella Khanna· Nov 7, 2024

    Registry listing for typescript matched our evaluation — installs cleanly and behaves as described in the markdown.

  • Michael Khanna· Nov 7, 2024

    typescript fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.

showing 1-10 of 52

1 / 6