Open Promise đ â Micro tool for creating Promise likes Deferred (with AbortController support).
npm install o-promiseOpen Promise đ
---------------
Micro tool for creating OpenPromise likes Deferred (with AbortController support).
``sh`
npm i --save o-promise
---
`js
import {createOpenPromise} from 'o-promise';
// 1. Tuple
const [promise, resolve, reject] = createOpenPromise
// 2. or Deferred
const {promise, resolve, reject} = createOpenPromise
// 3. With executer + return
const open = createOpenPromise(() => {
return '...';
});
open.state; // pending
open.reject('canceled'); // executer â won't be called
open.state; // rejected
// 4. With executer + promise
const open = createOpenPromise(() => {
// for example
return fetch('...');
});
// 5. With executer + resolvers + controller
const open = createOpenPromise((resolve, reject, controller) => {
// Your Logic
});
`
---
#### Dependent OpenPromise on AbortController
`js
const parentController = new AbortController();
const open = createOpenPromise
open.promise.catch(reason => {
console.info('OpenPromise canceled by parentController:', reason);
});
parentController.abort('canceled'); // âšī¸: open.controller === parentController;
`
---
#### Dependent OpenPromise on AbortSignal
`js
const parentController = new AbortController();
const open = createOpenPromise
open.promise.catch(reason => {
console.info('OpenPromise canceled by parentSignal:', reason);
});
parentController.abort('canceled'); // â ī¸: open.controller !== parentController;
`
---
#### Example: Open "fetch"
`js
import {createOpenPromise} from 'o-promise';
const openFetch = createOpenPromise((_, __, controller) => {
return fetch('...', {signal: controller.signal});
});
// Reject
openFetch.reject('canceled');
// Or AbortController#abort``
openFetch.controller.abort('canceled');
---