race-signal

Race a promise against an AbortSignal
About
Pass a promise and an abort signal and await the result.
Example - Basic usage
import { raceSignal } from 'race-signal'
const controller = new AbortController()
const promise = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('a value')
}, 1000)
})
setTimeout(() => {
controller.abort()
}, 500)
const resolve = await raceSignal(promise, controller.signal)
Example - Overriding errors
By default the thrown error is the .reason property of the signal but it's
possible to override this behaviour with the translateError option:
import { raceSignal } from 'race-signal'
const controller = new AbortController()
const promise = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('a value')
}, 1000)
})
setTimeout(() => {
controller.abort()
}, 500)
const resolve = await raceSignal(promise, controller.signal, {
translateError: (signal) => {
return new Error('Oh no!')
}
})
Install
$ npm i race-signal
Browser <script> tag
Loading this module through a script tag will make its exports available as RaceSignal in the global namespace.
<script src="https://unpkg.com/race-signal/dist/index.min.js"></script>
API Docs
License
Licensed under either of
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.