typescript▌
prowler-cloud/prowler · updated Apr 8, 2026
Why? Single source of truth, runtime values, autocomplete, easier refactoring.
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.
Ratings
4.5★★★★★52 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