@solana/functional
Version:
Functional JavaScript helpers
44 lines (34 loc) • 1.89 kB
Markdown
[![npm][npm-image]][npm-url]
[![npm-downloads][npm-downloads-image]][npm-url]
<br />
[![code-style-prettier][code-style-prettier-image]][code-style-prettier-url]
[//img.shields.io/badge/code_style-prettier-ff69b4.svg?style=flat-square
[ ]: https://github.com/prettier/prettier
[ ]: https://img.shields.io/npm/dm/@solana/functional?style=flat
[ ]: https://img.shields.io/npm/v/@solana/functional?style=flat
[ ]: https://www.npmjs.com/package/@solana/functional
This package contains generalized functional helpers and functional helpers specific to Solana application components. It can be used standalone, but it is also exported as part of Kit [`@solana/kit`](https://github.com/anza-xyz/kit/tree/main/packages/kit).
A pipeline is a solution that allows you to perform successive transforms of a value using functions. This is useful when building up a transaction message.
Until the [pipeline operator](https://github.com/tc39/proposal-pipeline-operator) becomes part of JavaScript you can use this utility to create pipelines.
```ts
const add = (a, b) => a + b;
const add10 = x => add(x, 10);
const add100 = x => add(x, 100);
const sum = pipe(1, add10, add100);
sum === 111; // true
```
```ts
const transferTransactionMessage = pipe(
// The result of the first expression...
createTransactionMessage({ version: 0 }),
// ...gets passed as the sole argument to the next function in the pipeline.
tx => setTransactionMessageFeePayer(myAddress, tx),
// The return value of that function gets passed to the next...
tx => setTransactionMessageLifetimeUsingBlockhash(latestBlockhash, tx),
// ...and so on.
tx => appendTransactionMessageInstruction(getTransferSolInstruction({ source, destination, amount }), tx),
);
```
]: https: