ts-option
Scala like Option
type for TypeScript/JavaScript.
Install
# yarn
$ yarn add ts-option
# npm
$ npm install --save ts-option
Usage
TypeScript
import {Option, option, some, none} from "ts-option";
let a: Option<number> = option(1); // Some(1)
let c: Option<number> = some(2); // Some(2)
let b: Option<number> = option(null); // None
let d: Option<number> = none; // None
JavaScript (ES Modules)
import {Option, option, some, none} from "ts-option";
let a = option(1); // Some(1)
let c = some(2); // Some(2)
let b = option(null); // None
let d = none; // None
API
option<A>(value?: A | null): Option<A>
Create an Option
instance from a value.
It returns Some<A>
when the value is not null/undefined, otherwise returns None
.
some<A>(value: A): Option<A>
Create an Some
instance from a value.
It returns Some<A>
even if the value is null or undefined.
If strict null checks are enabled in your tsconfig.json, undefined and null won't be permitted here.
none: Option<never>
The None
type singleton object.
option<A>(...).exists(p: (_: A) => boolean): boolean
Returns true if the option is non-empty and the predicate p returns true when applied to the option's value.
option<A>(...).filter(p: (_: A) => boolean): Option<A>
Returns the option if it is non-empty and applying the predicate p to the option's value returns true.
option<A>(...).filterNot(p: (_: A) => boolean): Option<A>
Returns the option if it is non-empty and applying the predicate p to the option's value returns false.
option<A>(...).flatMap<B>(f: (_: A) => Option<B>): Option<B>
Returns the result of applying f to the option's value if the option is non-empty, otherwise returns None
.
option<A>(...).fold<B>(ifEmpty: () => B)(f: (_: A) => B): B
Returns the result of applying f to the option's value if the option is non-empty, otherwise returns ifEmpty
value.
option<A>(...).forAll(p: (_: A) => boolean): boolean
Tests whether a predicate holds for all elements of the option.
option<A>(...).forComprehension(...fns: (a: any) => Option<any>): Option<any>
Performs a for-comprehension like operation using the given list of functions. For example:
const nestedOptions = some({
anOption: some({
anotherOption: some({
finalValue: true
})
})
});
const result = nestedOptions.forComprehension(
obj => obj.anOption,
anOption => anOption.anotherOption,
anotherOption => anotherOption.finalValue
);
console.log(`${result}`) // Some(true)
As with the Scala for comprehension the result of each function is flat-mapped with the next, except for the last, which is mapped.
Please note that there are currently some limitations:
- Filtering must be done manually
- There is no shared scope between functions
- The result type is always
Option<any>
option<A>(...).forEach(f: (_: A) => any): void
Apply the given procedure f to the option's value if it is non-empty, otherwise do nothing.
option<A>(...).get: A
Returns the option's value if the option is non-empty, otherwise throws an error.
option<A>(...).getOrElse(defaultValue: () => A): A
Returns the option's value if the option is non-empty, otherwise return the result of evaluating defaultValue.
option<A>(...).getOrElseValue(defaultValue: A): A
Returns the option's value if the option is non-empty, otherwise return the defaultValue.
option<A>(...).isDefined: boolean
Returns true if the option's value is non-empty, false otherwise.
option<A>(...).isEmpty: boolean
Returns true if the option is an instance of None
, false otherwise.
option<A>(...).map<B>(f: (_: A) => B): Option<B>
Builds a new option by applying a function to all elements of this option.
option<A>(...).match<B>(matcher: { some: (_: A) => B, none: () => B }): B
Scala's "Pattern Match" like signature. Returns the value that the function some
returns if the option is non-empty,
otherwise returns the value that function none
returns.
let s: Option<number> = some(9);
let n: Option<number> = none;
let a: number = s.match({
some: x => x * 9,
none: () => -1,
});
let b: number = n.match({
some: x => x * 9,
none: () => -1,
});
console.log(a); // 81
console.log(b); // -1
option<A>(...).nonEmpty: boolean
Returns true if the option is an instance of Some
, false otherwise.
option<A>(...).orElse(alternative: () => Option<A>): Option<A>
Returns the option itself if it is non-empty, otherwise return the result of evaluating alternative.
option<A>(...).orElseValue(alternative: Option<A>): Option<A>
Returns the option itself if it is non-empty, otherwise return the alternative.
option<A>(...).orNull: A | null
Returns the option's value if it is non-empty, or null if it is empty.
option<A>(...).orUndefined: A | undefined
Returns the option's value if it is non-empty, or undefined if it is empty.
option<A>(...).toArray: Array<A>
Converts the option to an array.
License
MIT