Skillshub TypeScript Tooling
Development tools, linting, and build config for TypeScript. Use when configuring ESLint, Prettier, Jest, Vitest, tsconfig, or any TS build tooling.
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/tooling" ~/.claude/skills/comeonoliver-skillshub-typescript-tooling && rm -rf "$T"
manifest:
skills/HoangNguyen0403/agent-skills-standard/tooling/SKILL.mdsource content
TypeScript Tooling
Priority: P1 (OPERATIONAL)
Essential tooling for TypeScript development and maintenance.
Implementation Guidelines
- Compiler:
for CI.tsc
/ts-node
for dev.esbuild - Lint: ESLint +
. Strict type checking.@typescript-eslint - Format: Prettier (on save + commit).
- Test: Jest/Vitest > 80% coverage.
- Build:
(libs), Vite/Webpack (apps).tsup - Check:
in CI.tsc --noEmit
Anti-Patterns
- No Disable: Avoid
.// eslint-disable - No Skip: Avoid
if possible.skipLibCheck: true - No Ignore: Use
>@ts-expect-error
.@ts-ignore
ESLint Configuration
Strict Mode Requirement
CRITICAL: Every file in the project, including tests (
.spec.ts), must adhere to strict type-checked rules. NEVER turn off @typescript-eslint/no-explicit-any or no-unsafe-* rules.
Common Linting Issues & Solutions
Request Object Typing
Problem: Using
any for Express request objects or creating duplicate inline interfaces.
Solution: Use the centralized interfaces in src/common/interfaces/request.interface.ts.
import { RequestWithUser } from 'src/common/interfaces/request.interface';
Unused Parameters
Problem: Function parameters marked as unused by linter. Solution: Prefix the parameter with an underscore (e.g.,
_data) or remove it. NEVER use eslint-disable.
Test Mock Typing
Problem: Jest mocks triggering unsafe type warnings when
expect.any() or custom mocks are used.
Solution: Cast the mock or expectation using as unknown as TargetType.
mockRepo.save.mockResolvedValue(result as unknown as User);
Configuration
// tsconfig.json { "compilerOptions": { "strict": true, "noImplicitReturns": true, "noUnusedLocals": true } }
Reference & Examples
For testing configuration and CI/CD setup: See references/REFERENCE.md.
Related Topics
best-practices | language