Skillshub TypeScript Language Patterns
Modern TypeScript standards for type safety and maintainability. Use when working with types, interfaces, generics, enums, unions, or tsconfig settings.
install
source · Clone the upstream repo
git clone https://github.com/ComeOnOliver/skillshub
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ComeOnOliver/skillshub "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/HoangNguyen0403/agent-skills-standard/language" ~/.claude/skills/comeonoliver-skillshub-typescript-language-patterns && rm -rf "$T"
manifest:
skills/HoangNguyen0403/agent-skills-standard/language/SKILL.mdsource content
TypeScript Language Patterns
Priority: P0 (CRITICAL)
Implementation Guidelines
- Type Annotations: Explicit params/returns. Infer locals.
- Interfaces vs Types:
for APIs.interface
for unions.type - Strict Mode:
. Null Safety:strict: true
and?.
.?? - Enums: Literal unions or
. No runtimeas const
.enum - Generics: Reusable, type-safe code.
- Type Guards:
,typeof
, predicates.instanceof - Utility Types:
,Partial
,Pick
,Omit
.Record - Immutability:
arrays/objects. Const Assertions:readonly
,as const
.satisfies - Template Literals:
.on${Capitalize<string>} - Discriminated Unions: Literal
property.kind - Advanced: Mapped, Conditional, Indexed types.
- Access: Default
. Usepublic
/private
orprotected
.#private - Branded Types:
.string & { __brand: 'Id' }
Anti-Patterns
- No
: NEVER useany
. Useany
or specific interfaces.unknown - No
: Use signatureFunction
.() => void - No
: Runtime cost.enum - No
: Use narrowing.! - NO LINT DISABLE: PROHIBITED. Fix issues properly.
Testing
- Mocking: Use
orjest.Mocked<T>
.as unknown as T - Checklist: Check method existence, match error constants, satisfy required properties.
- References: See references/TESTING.md for common issues/solutions.
Code
// Branded Type type UserId = string & { __brand: 'Id' }; // Satisfies (Validate + Infer) const cfg = { port: 3000 } satisfies Record<string, number>; // Discriminated Union type Result<T> = { kind: 'ok'; data: T } | { kind: 'err'; error: Error };
Reference & Examples
For advanced type patterns and utility types: See references/REFERENCE.md.
Related Topics
best-practices | security | tooling