1
Fork 0
solar-conflux/typescript/option
Matei Adriel 4ef32c05c3
typescript(option): fix: fixed declaration containnig a bunch of anys
Signed-off-by: prescientmoon <git@moonythm.dev>
2019-12-27 13:28:42 +02:00
..
.github/workflows typescript(option): ci: run tests before releasing 2019-12-25 14:46:33 +02:00
.vscode typescript(option): chore: fixed readme docs url 2019-12-19 20:58:54 +02:00
docs typescript(option): docs: fixed the fromNullable section not beeing in the table of contents 2019-12-20 15:00:54 +02:00
src typescript(option): feat: added the 'combine' helper 2019-12-26 17:05:16 +02:00
test typescript(option): feat: added the 'withDefaultLazy' helper 2019-12-26 16:16:09 +02:00
.gitignore typescript(option): chore: added lib to gitignore 2019-12-23 16:07:00 +02:00
.prettierrc typescript(option): chore: initial setup 2019-12-19 12:37:48 +02:00
LICENSE typescript(option): chore: initial setup 2019-12-19 12:37:48 +02:00
package.json typescript(option): fix: fixed declaration containnig a bunch of anys 2019-12-27 13:28:42 +02:00
pnpm-lock.yaml typescript(option): fix: fixed declaration containnig a bunch of anys 2019-12-27 13:28:42 +02:00
README.md typescript(option): build: edited the rollup config to read paths from package.json and show the filesize of the esm bundle 2019-12-26 18:13:37 +02:00
rollup.config.ts typescript(option): build: removed unused variables from rollup config 2019-12-26 18:17:29 +02:00
tsconfig.json typescript(option): build: edited the rollup config to read paths from package.json and show the filesize of the esm bundle 2019-12-26 18:13:37 +02:00

npm (scoped) npm bundle size (scoped) forthebadge

Option

Probably the most opinionated implementation of the Option type for TypeScript.

Features:

  • Lazy and async versions of helpers: One of the goals of this lib is to provide variations of helpers which are lazy (don't compute something if it's not needed) or async (make mixing Promises and Options easier). If there is any function you want one of those variations of, be sure to open an issue:)
  • Large amount of helpers (curently 30), more than f#'s and elm's core libraries combined.
  • Typesafe:
    const foo0: Option<string> = None // works
    const foo1: Option<string> = Some('foo1') // works
    const foo2: Option<string> = 'foo2' // errors out
    const foo3: Option<string> = null // errors out
    const foo4: Option<string> = Some(4) // errors out
    
  • Reference equality:
    Some(7) === Some(7) // true
    Some(7) === Some(5) // false
    Some(7) === None // false
    

Limitations

Both limitaions bellow come from the lack of nominal-typing offered by TypeScript and are inherited from the Brand type offered by the utility-types library

  • Due to the way the library works (using the Brand type from utility-types) Some(4) === 4 will return true, similarly to how 4 == "4" returns true (except in this libraries case the === operator will behave the same way).
  • The inner value of Option cannot have a __brand prop (well, tehnically it can but it would be overwritten by the Brand type from utility-types)

Installation

npm install @adrielus/option

(There is also an amd build at /dist/bundle.umd.js which uses the Option namespace)

Usage

For detailed usage read the docs

Note: The docs are still work in progress. Contributions are welcome:)

Contributing

First, clone this repo:

git clone https://github.com/Mateiadrielrafael/option
cd option

Then use pnpm to install the dependencies:

pnpm install

You can use the build command to build the package (this is dont automatically by github actions):

pnpm run build