Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/typescript-cheatsheets/utilities
a list of typescript helper libraries
https://github.com/typescript-cheatsheets/utilities
Last synced: 6 days ago
JSON representation
a list of typescript helper libraries
- Host: GitHub
- URL: https://github.com/typescript-cheatsheets/utilities
- Owner: typescript-cheatsheets
- License: mit
- Created: 2019-05-02T03:55:20.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-06-26T12:23:49.000Z (7 months ago)
- Last Synced: 2025-01-08T15:21:39.629Z (6 days ago)
- Size: 71.3 KB
- Stars: 775
- Watchers: 14
- Forks: 32
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-list - utilities - cheatsheets | 383 | (Others)
- jimsghstars - typescript-cheatsheets/utilities - a list of typescript helper libraries (Others)
- stars - utilities - cheatsheets | 775 | (Others)
- stars - utilities - cheatsheets | 771 | (Others)
README
# typescript-utilities-guide
a list of typescript helper libraries. advanced guides in `typescript-cheatsheets` will assume knowledge of these and refer people here.
There is a stage in every TypeScript journey where you struggle getting the types you want and eventually find a lifesaver blogpost like [TypeScript Types You Should Know About](https://xpbytes.com/articles/types-you-should-know-about-typescript/). This cheatsheet accumulates them.
## Automated JS to TS Conversion
- [TypeStat](https://github.com/JoshuaKGoldberg/TypeStat) ([used by Codecademy](https://mobile.twitter.com/JoshuaKGoldberg/status/1159090281314160640))
- [TypeWiz](https://github.com/urish/typewiz)
- [js-to-ts-converter](https://github.com/gregjacobs/js-to-ts-converter)
- [TS-migrate](https://medium.com/airbnb-engineering/ts-migrate-a-tool-for-migrating-to-typescript-at-scale-cd23bfeb5cc) from Airbnb
- [dts-gen](https://github.com/microsoft/dts-gen) - `dts-gen` is a tool that generates TypeScript definition files (.d.ts) from any JavaScript object.JSON to TS type inference https://jvilk.com/MakeTypes/
## Utility Types
Be familiar with the [Utility Types that ship with TS](https://www.typescriptlang.org/docs/handbook/utility-types.html). On top of that, here are handy Utility Types often used by TS practitioners, with explanation on what they do and how they can help. We will assume knowledge of [mapped types and conditional types](https://mariusschulz.com/blog/series/typescript-evolution) like `Exclude` and `ReturnType` but try to build progressively upon them.
> Note: If you are new to conditional types, I highly recommend [DJSheldrick's blogpost and talk on Conditional Types in TypeScript](https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/)
Optionalize<T extends K, K>
: Remove from T the keys that are in common with K
```ts
/**
* Remove from T the keys that are in common with K
*/
type Optionalize = Omit;
```
An example usage is in our HOC section below.
Nullable<T>
orMaybe<T>
: Make a Type into a Maybe Type
```ts
/**
* Make a Type into a Maybe Type
*/
type Nullable = T | null
type Maybe = T | undefined
```Your choice of `null` or `undefined` depends on your approach toward missing values. Some folks feel strongly one way or the other.
Dictionary<T>
: Dictionary of string, value pairs
```ts
/**
* Dictionary of string, value pairs
*/
type Dictionary = { [key: string]: T }
````[key: string]` is a very handy trick in general. You can also modify dictionary fields with [Readonly](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-8.html) or make them optional or Omit them, etc.
There also exist helper type libraries:
- [utility-types](https://github.com/piotrwitek/utility-types)
- [type-zoo](https://github.com/pelotom/type-zoo)
- 🌟 [ts-toolbelt](https://github.com/pirix-gh/ts-toolbelt) ([Reddit](https://www.reddit.com/r/typescript/comments/c2nq7k/higher_type_safety_for_typescript_with_tstoolbelt/))
- [typesafe-actions](https://github.com/piotrwitek/typesafe-actions)
- [type-fest](https://github.com/sindresorhus/type-fest)
- [tsdef](https://github.com/joonhocho/tsdef)
- [rex-tils](https://github.com/Hotell/rex-tils)
- [tiny-types](https://github.com/jan-molak/tiny-types)
- [ts-essentials](https://github.com/krzkaczor/ts-essentials)seriously, check some of these out, they represent a ton of accumulated typescript experience.
## Type Testing
- https://github.com/SamVerschueren/tsd: Check TypeScript type definitions
- https://github.com/aikoven/typings-tester#readme
- https://github.com/ikatyang/dts-jest
- https://github.com/SamVerschueren/tsd
- https://github.com/azz/jest-runner-tsc
- https://github.com/dsherret/conditional-type-checks
* `IsNullable` - Checks if `T` is possibly `null` or `undefined`.
* `IsExact` - Checks if `T` exactly matches `U`.
* `Has` - Checks if `T` has `U`.
* `NotHas` - Checks if `T` does not have `U`.
* `IsAny` - Checks if `T` is the `any` type.
* `IsNever` - Checks if `T` is the `never` type.
* `IsUnknown` - Checks if `T` is the `unknown` type.
- https://github.com/microsoft/dtslint ([Intro to dtslint](https://www.youtube.com/watch?v=nygcFEwOG8w&feature=share))## TypeScript Plugins
You can write plugins to modify typescript syntax itself. this is ADVANCED and not exactly recommended but here are some examples if you need them:
- https://github.com/rimeto/ts-optchain/
## types to runtime
- https://github.com/gcanti/io-ts Runtime type system for IO decoding/encoding
- https://github.com/nokia/ts-serialize-closures
- https://github.com/YousefED/typescript-json-schema Generate json-schemas from your Typescript sources.## Misc
- [sourcegraph chrome extension](https://chrome.google.com/webstore/detail/sourcegraph/dgjhfomjieaadpoljlnidmbgkdffpack?hl=en) - hover over types in GitHub and jump to definition/references
- https://github.com/urish/typewiz Automatically discover and add missing types in your TypeScript code
- https://github.com/microsoft/rushstack/tree/master/apps/api-extractor
- You can find more [recommended TS config here](https://github.com/tsconfig/bases).
- ts-prune - Find dead code and dead types in your project https://effectivetypescript.com/2020/10/20/tsprune/
- The "Loose autocomplete" trick: https://twitter.com/mpocock1/status/1506607945445949446?s=20&t=b1oRUmqyj51vZAQH6FwTNg
- crazy TS things for science
- https://github.com/ronami/meta-typing
- https://twitter.com/buildsghost/status/1301976526603206657
- https://github.com/ronami/typelangAPI Extractor provides an integrated, professional-quality solution for all these problems. It is invoked at build time by your toolchain and leverages the TypeScript compiler engine to:
- Detect a project's exported API surface
- Capture the contracts in a concise report designed to facilitate review
- Warn about common mistakes (e.g. missing exports, inconsistent visibility, etc.)
- Generate \*.d.ts rollups with trimming according to release type
- Output API documentation in a portable format that's easy to integrate with your content pipelineexample https://github.com/framer/api-docs/tree/master/api
## documentation
- https://github.com/phryneas/remark-typescript-tools
* it transpiles TypeScript code examples to JavaScript
* it typechecks your TypeScript code examples
* it allows you to include Docblocks from your sourcecodehttps://twitter.com/phry/status/1302662810707660801?s=20
## monorepo build tooling
- https://rushstack.io/ - Specific strategy that integrates popular tools like NodeJS, TypeScript, ESLint, Prettier, Webpack, Jest for large scale monorepos from Microsoft
- https://nx.dev/react/guides/js-and-ts - Nx is a general-purpose build system and a general-purpose CLI. It works with JavaScript, TypeScript, Java, C#, Go, etc.. The core plugins Nx comes with do work best with JavaScript or TypeScript.
- https://blog.mgechev.com/2018/11/19/introduction-bazel-typescript-tutorial/ - Bazel is a powerful tool which can keep track of the dependencies between different packages and build targets. For simplicity, we can think of a build target as a build rule - for example, “build a TypeScript library”## Codegen from TypeScript
- https://github.com/yousefed/typescript-json-schema
- https://github.com/apollographql/apollo-tooling/tree/master/packages/apollo-codegen-typescript## Data Structures
https://github.com/basarat/typescript-collections