Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xiscodev/promise-with-state
A library to use queryable promises or make native promise A+ queryable
https://github.com/xiscodev/promise-with-state
browser javascript-library promise
Last synced: 3 months ago
JSON representation
A library to use queryable promises or make native promise A+ queryable
- Host: GitHub
- URL: https://github.com/xiscodev/promise-with-state
- Owner: xiscodev
- Created: 2021-07-22T21:15:15.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-05-13T08:56:15.000Z (9 months ago)
- Last Synced: 2024-09-15T22:41:09.049Z (4 months ago)
- Topics: browser, javascript-library, promise
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/promise-with-state
- Size: 1.03 MB
- Stars: 4
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
Promise with state
## What is this?
A library to use queryable promises or make native promise A+ queryable.
## Why?
According to [Promises/A+](https://promisesaplus.com) standard definition, a [Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) is a "thenable" object, which sets itself into 3 different states: [PENDING](#pending), [FULFILLED](#fulfilled), or [REJECTED](#rejected). However, there is no way to ask a promise which state it is only know it has fulfilled or rejected. With this library you can create queryable promise or make native promise queryable.
## A little bit about promises
Let see a typical Promise use:
```js
new Promise((resolve, reject) => {
if (condition) {
resolve(result)
} else {
reject(err)
}
})
```A promise is built to fulfill or reject whatever its executor function defines, so a promise and its executor callback can look like this:
```js
const functionExecutor = (resolve, reject) => {
if (condition) {
resolve(result)
} else {
reject(err)
}
}new Promise(functionExecutor)
```This package was made to handle both cases, when a Promise instance is handled or if an executor callback is instead
Feel free to look the source code on the [github repository](https://github.com/xiscodev/promise-with-state/) of this project
## How to use it?
First you need to install it to your project.
```bash
npm install promise-with-state
```Then import it in your project.
* *The require way*
```js
let { QueryablePromise } = require("promise-with-state");
```* *The import way*
```js
import { QueryablePromise } from "promise-with-state";
```Use it so you can instantiate [QueryablePromise](#queryablepromise) to create Promises that are queryable.
* in the case it resolves
```js
import { QueryablePromise } from "promise-with-state";const queryableWithResolution = new QueryablePromise((resolve, reject) => {
// YOUR OWN CODE AND STUFF
resolve()
})console.log(queryableWithResolution.state)
// PENDING
console.log(queryableWithResolution.isPending())
// true
console.log(queryableWithResolution.isFulfilled())
// false
console.log(queryableWithResolution.isRejected())
// falsequeryableWithResolution
.then(() => {
console.log(queryableWithResolution.state)
// FULFILLED
console.log(queryableWithResolution.isPending())
// false
console.log(queryableWithResolution.isFulfilled())
// true
})
.catch()
```* in the case it rejects
```js
import { QueryablePromise } from "promise-with-state";
const promiseExecutor = (resolve, reject) => {
// YOUR OWN CODE AND STUFF
reject()
}const queryableWithRejection = new QueryablePromise(promiseExecutor)
console.log(queryableWithRejection.state)
// PENDING
console.log(queryableWithRejection.isPending())
// true
console.log(queryableWithRejection.isFulfilled())
// false
console.log(queryableWithRejection.isRejected())
// falsequeryableWithRejection
.then() // promises always should has thenable
.catch((err) => {
console.log(queryableWithRejection.state)
// REJECTED
console.log(queryableWithRejection.isPending())
// false
console.log(queryableWithRejection.isRejected())
// true
handleError(err)
})
```The states for queryable promises are grouped in a constant called [PromiseState](#promisestate)
```js
import { PromiseState } from "promise-with-state";console.log(PromiseState)
// {
// "PENDING": "PENDING",
// "FULFILLED": "FULFILLED",
// "REJECTED": "REJECTED"
// }const queryableWithResolution = new QueryablePromise((resolve, reject) => {
// YOUR OWN CODE AND STUFF
resolve(foo)
})console.log(queryableWithResolution.state === PromiseState.PENDING)
// true
```Native thenables can be transformed into queryable promises with [makeQueryablePromise](#makequeryablepromise).
```js
import { makeQueryablePromise } from "promise-with-state";const promiseExecutor = (resolve, reject) => {
// YOUR OWN CODE AND STUFF
if (condition) {
resolve()
} else {
reject()
}
}const processTextPromise = new Promise(promiseExecutor)
const queryableTextPromise = makeQueryablePromise(processTextPromise)queryableTextPromise
// if resolves
.then(() => {
console.log(queryableTextPromise.state)
// FULFILLED
console.log(queryableTextPromise.isPending())
// false
console.log(queryableTextPromise.isFulfilled())
// true
})
// if rejects
.catch(() => {
console.log(queryableTextPromise.state)
// REJECTED
console.log(queryableTextPromise.isPending())
// false
console.log(queryableTextPromise.isRejected())
// true
})
// whatever happens here
.finally(() => {
console.log(queryableTextPromise.isPending())
// false
})
```Powered by
Additional JSDOC info
### JSDOC
##### Table of Contents
* [makeQueryablePromise](#makequeryablepromise)
* [Parameters](#parameters)
* [PromiseExecutor](#promiseexecutor)
* [PromiseState](#promisestate)
* [PENDING](#pending)
* [FULFILLED](#fulfilled)
* [REJECTED](#rejected)
* [QueryablePromise](#queryablepromise)
* [Parameters](#parameters-1)
* [then](#then)
* [Parameters](#parameters-2)
* [catch](#catch)
* [Parameters](#parameters-3)
* [finally](#finally)
* [Parameters](#parameters-4)
* [state](#state)
* [isPending](#ispending)
* [isFulfilled](#isfulfilled)
* [isRejected](#isrejected)#### makeQueryablePromise
Takes a native Promise and returns a QueryablePromise with state and query methods.
##### Parameters
* `fnExecutor` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** The native Promise or function which contains fulfill and reject callbacks
* Throws **[Error](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Error)** if the fnExecutor is invalid
Returns **[QueryablePromise](#queryablepromise)** A QueryablePromise instance with state and query methods.
#### PromiseExecutor
describes what a promise executor should look like
Type: function (fulfill: function (value: (T | PromiseLike\)): void, reject: function (reason: any): void): void
#### PromiseState
Contains queryable promise states
##### PENDING
Promise state PENDING for queryable promise
Type: [PromiseState](#promisestate)
##### FULFILLED
Promise state FULFILLED for queryable promise
Type: [PromiseState](#promisestate)
##### REJECTED
Promise state REJECTED for queryable promise
Type: [PromiseState](#promisestate)
#### QueryablePromise
##### Parameters
* `fnExecutor` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** The native Promise or function which contains fulfill and reject callbacks
##### then
then method refers to promise method.
###### Parameters
* `onFulfilled` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** callback function to run on fulfilled
* `onRejected` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** callback function to run on rejectedReturns **[QueryablePromise](#queryablepromise)** returns class instance
##### catch
catch method refers to promise method.
###### Parameters
* `onRejected` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** callback function to run on rejected
Returns **[QueryablePromise](#queryablepromise)** returns class instance
##### finally
finally method refers to promise method.
###### Parameters
* `onFinally` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** callback function that can run after fulfilled or rejected states
Returns **[QueryablePromise](#queryablepromise)** returns class instance
##### state
Getter for queryable promise state.
Type: [PromiseState](#promisestate)
Returns **[PromiseState](#promisestate)** contains current promise state
##### isPending
a function that retrieves if queried state is the actual queryable promise state.
Returns **[boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)** a boolean whether a queryable promise state is PENDING
##### isFulfilled
a function that retrieves if queried state is the actual queryable promise state.
Returns **[boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)** a boolean whether a queryable promise state is FULFILLED
##### isRejected
a function that retrieves if queried state is the actual queryable promise state.
Returns **[boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)** a boolean whether a queryable promise state is REJECTED