Micro tool for creating OpenPromise likes Deferred (with AbortController support).
npm i --save o-promise
import {createOpenPromise} from 'o-promise';
// 1. Tuple
const [promise, resolve, reject] = createOpenPromise<string>();
// 2. or Deferred
const {promise, resolve, reject} = createOpenPromise<number>();
// 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
});
const parentController = new AbortController();
const open = createOpenPromise<number>(parentController); // <- AbortController
open.promise.catch(reason => {
console.info('OpenPromise canceled by parentController:', reason);
});
parentController.abort('canceled'); // βΉοΈ: open.controller === parentController;
const parentController = new AbortController();
const open = createOpenPromise<number>(parentController.signal); // <- AbortSignal
open.promise.catch(reason => {
console.info('OpenPromise canceled by parentSignal:', reason);
});
parentController.abort('canceled'); // β οΈ: open.controller !== parentController;
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');