Optional chaining implementation in TypeScript.
Uses option type
This library requires TS 2.8+ version to use conditional type
npm install optional-chainimport { optional } from "optional-chain";
type User = {
name?: {
first: string
}
}
const user: User = getUser(); // { name: null }
const optionalUser = optional(user);
optionalUser.k("name").k("first").get(); // undefined, does not throw an exception.optional-chain library exports below APIs.
optional is a fuctory function to creates a Option instance.
An instance of Option can be constructed with a value for the souce of T. Option class can hold a type of Some or None based on given source.
type User = {
name: string;
sns: SNS;
followers: User[];
};
type SNS = {
twitter?: {
username: string;
};
facebook?: {
url: string;
};
};
const user: User = {
name: "yayoc",
sns: {
twitter: {
username: "@yayoc_"
}
},
followers: []
};
const optionalUser = optional(user);
optionalUser.k("name"); // Option<string>
optionalUser.k("sns"); // Option<{twitter: { username: string }}>
optionalUser.k("sns").k("facebook"); // None
optionalUser.k("foo"); // compile errorReturns a Option<T> narrowed by specified property of Object.
Returns a Option<T> narrowed by specified index of Array. If index is not in array, this returns Option<undefined>.
optionalUser
.k("followers")
.i(0)
.k("name"); // NoneReturns a value of Option.
optionalUser.k("name").get(); // yayocA public method of Option to do pattern matching.
If target Option is Some type, this funciton returns a result of given some function. Otherwise, this function returns a result of given none function.
optionalUser
.k("sns")
.k("twitter")
.match({
some: v => v,
none: v => `there is no account: ${v}`
}); // @yayoc_A public method to return T value when the instance contains some value. Otherwise, this function will return given value.
optionalUser
.k("sns")
.k("facebook")
.k("url")
.getOrElse("https://facebook.com"); // https://facebook.com