Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/refzlund/async-builder
https://github.com/refzlund/async-builder
Last synced: 5 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/refzlund/async-builder
- Owner: Refzlund
- Created: 2022-05-15T14:00:50.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-07-06T08:30:00.000Z (over 1 year ago)
- Last Synced: 2024-11-09T15:49:10.023Z (2 months ago)
- Language: TypeScript
- Size: 9.77 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# async-builder
Chained functions. They work asynchronously, meaning, if `pizza().cheese().bake().eat()`,
`bake()` won't be run before `cheese()` has fulfilled its promise (if any). And `eat()` won't be run before `bake()` is fulfilled, etc.### Todo
- `append` documentation and type### Example
```ts
let pizza = asyncBuilder(({resolve, reject}, id: string) => {
let content = {
id,
tomato: 0,
cheese: 0,
pepperoni: 0,
pineapple: 0,
mushrooms: 0,
}
let hurry = 1
let timeItTakes = (ms) => new Promise((resolve) => setTimeout(resolve, ms * hurry))
return {
__catch(error) {
console.error(error)
},
__validator() {
console.assert(hurry < 0.3, 'Aren\'t you going a little fast there?')
},
__build(reject) {
console.log(`Pizza ${id} has been made`, content)
return content
},
hurry() {
hurry /= 1.5
},
async tomatoSauce() {
await timeItTakes(1000)
content['tomato']++
},
async cheese() {
await timeItTakes(500)
content['cheese']++
},
async pepperoni() {
await timeItTakes(700)
content['pepperoni']++
},
async pineapple() {
throw new Error("Don't.")
},
async mushrooms() {
await timeItTakes(100)
content['mushrooms']++
}
}
})async function makePizza() {
let pizza = await pizza('1').tomatoSauce().cheese().pepperoni().mushrooms().cheese()
let pizza = await pizza('2').hurry().hurry().hurry().hurry().cheese().cheese().pepperoni().cheese()
}makePizza()
```## Initial constructor
The constructor (i.e. `asyncBuilder(({resolve, reject}, ... any params) => {`), contains an object for `resolve` and `reject`.| Name | Description
| ---- | -----------
| resolve | You can prematurely resolve which returns the content of `resolve(content)`. This stops any trailing functions from being run completely.
The true intention is to resolve by returning something in `__build()`, so use this with caution.
| reject | You can at any point reject the promise.
This also stops any trailing functions from being run completely.## Declarative returned functions
For readability, try to keep them in the following order| Name | Description
| ---- | -----------
| `__init?` | The initial function to be called.
Used to initialize values that require asynchronous operatinos.
Like the other declared functions here, it will be called without chaining it.
| `__catch?` | The whole chain is inside a try-catch block.
If an error occurs, and __catch is defined, rather than throwing the error, __catch will be called.
Note: If __catch is not defined, reject(error), will be called before throwing an error.
| `__validator?` | Validator is called after every chained function.
And is therefore perhaps - good at continously doing validation and alike.
| `__build` | Is called as a last function to be called (before finally). This returns the awaited result of the builder-pattern.
| `__finally?` | No matter the given event of the chain function, finally will ALWAYS be run at the end
| `__function?` | This make the builder into a function. This is run before __init.>
The `__function` is called like, pizza(1).cheese().pepperoni().cheddar()(...args)