Incentro IC - Code Standards - Typescript
💫 Introduction
This package provides a set of shared Typescript configuration files that can be used across different projects.
- 🏠 Base -
@incentro-ic/typescript/base - 📦 App - Next.js -
@incentro-ic/typescript/app-next - 📦 Package -
@incentro-ic/typescript/package - 🌎 Package - Browser -
@incentro-ic/typescript/package-browser/ - 🟩 Package - Node -
@incentro-ic/typescript/package-node/ - ⚛️ Package - React -
@incentro-ic/typescript/package-react
💾 Installation
To install the package, use the following command:
pnpm add -D typescript @incentro-ic/typescript🪛 Usage
After installing the package you can use the provided configuration as a basis by using the extends keyword in your tsconfig.json.
Here’s an example:
{
"extends": "@incentro-ic/typescript"
}The configuration files do not include any includes, files, exclude or compilerOptions.outDir options. You will need to add these options according to your project’s requirements.
⚙️ Configs
🏠 Base
This is the base Typescript configuration that is applicable to all projects. The settings in this configuration are primarily related to the strictness of Typescript and should rarely be overridden as they do not affect the output or the compilation target.
🪛 Usage
{
"extends": "@incentro-ic/typescript"
}🔼 App - Next.js
This is the Typescript configuration for all Next.js projects. It extends the base configuration and adds settings that are related to working with React and Next.js’ Typescript plugin and type helpers.
🪛 Usage
{
"extends": "@incentro-ic/typescript/app-next"
}📦 Package
This is the base Typescript configuration for all projects that are meant to be published as a package and do not specifically target the browser or a Node.js environment. It extends the base configuration and adds settings that are related to the output of the Typescript compiler.
🪛 Usage
{
"extends": "@incentro-ic/typescript/package"
}🌎 Package - Browser
This is the Typescript configuration for all projects that are meant to be published as package targeting browser environments. It extends the package configuration and adds settings that are specific to browser environments, like enabling types for methods only available in DOM environments. It targets the latest versions of most major browsers.
This config disables file emission by the Typescript compiler as it is expected that you’ll be using a bundler to transform the source files for use in browser environments.
🪛 Usage
{
"extends": "@incentro-ic/typescript/package-browser"
}🟩 Package - Node
This is the Typescript configuration for all projects that are meant to be published as Node.js packages. It extends the package configuration and adds settings that are related to Node.js, specifically the LTS version.
🪛 Usage
{
"extends": "@incentro-ic/typescript/package-node"
}⚛️ Package - React
This is the Typescript configuration for all projects that are meant to be published as React packages. It extends the browser package configuration and adds settings that are related to interpreting JSX.
This config disables file emission by the Typescript compiler as it is expected that you’ll be using a bundler to transform the source files for use in browser environments.
🪛 Usage
{
"extends": "@incentro-ic/typescript/package-react"
}