npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

call-to-promise

v2.0.5

Published

Promiser is simple callback wrapper library. It generate, store and create a promise for any callback and pass arguments as expected.

Downloads

36

Readme

GitHub version Coverage Status JavaScript Style Guide: Good Parts dependency status contributions welcome

What is it?

Library offers to create callback functions and connect it by unique id descriptor with the promise object.

How to use it?

There are couple options how to get it into your project.

  1. You using npm/yarn and you want to install it with it, so do npm i call-to-promise and then import it import c2p from "call-to-promise";,
  2. you typing vanilla js and you want to import it, <import src="https://raw.githubusercontent.com/domino2/call-to-promise/master/dist/umd.min.js" /> what will store the call-to-promise into window.c2p,
  3. you using umd modules in the browser, import * as c2p from "https://raw.githubusercontent.com/domino2/call-to-promise/master/dist/module.min.mjs";
  4. or you doing Deno application, import * as c2p from "https://raw.githubusercontent.com/domino2/call-to-promise/master/dist/module.min.mjs"; ,
  5. node.js application c2p = require('call-to-promise')

The github raw files cannot be used as I did above to import the library. For more details read this. In case you work in browser, store the dist file locally or on the server.

After that, just call successfn function to get success callback. failfn return fail callback.

c2p = require('call-to-promise')
function countIn(a, b, resultback) {
    resultback(a+b);
}

countIn(3, 4, c2p.successfn('id'))
c2p.when('id').then(console.log) // -> 7

Multiple arguments

When success or fail callback is called with object, simple value or array, those are available as usual in the promise function. Multiple arguments are wrapped into object, because resolve and reject functions pass only one argument.

c2p = require('call-to-promise')
function countIn(a, b, resultback) {
    resultback(a+b, a*b, a-b);
}

countIn(3, 4, c2p.successfn('id'))
c2p.when('id').then(console.log) // -> { '0': { '0': 7, '1': 12, '2': -1 }}

Real Life example - reading files

c2p = require('call-to-promise')
fs = require('fs')

// callback approach - probably better :-) because of passing multiple arguments
//fs.readFile('/etc/hosts', 'utf8', function (err,data) {
//    if (err) throw(err)
//    else console.log(data)
//})

// call-to-promise approach

fs.readFile('/etc/hosts', 'utf8', c2p.successfn('p-id-1'))

c2p.id('p-id-1').promise.then(function(args){

    let err = args[0]
    let data = args[1]

    if (err) throw(err)
    else console.log(data)
})

Nuance 1

c2p = require('call-to-promise') returning global object which could be used from any place and work with same promise as has been used on other place of project according to ID.

c3p = require('call-to-promise').build() on other side creating local object and cannot share promise with other parts of your project.

c2p.when('id').then(console.log)
c3p.when('id').then(console.log)

c2p.id('id').resolve(1)
// c2p.id('id').resolve(3) // -> it will throw an exception
c3p.id('id').resolve(2)
// c3p.id('id').resolve(4) // -> it will throw an exception

// output -> 1 and 2

Nuance 2 - multi-when

It is possible to wait for resolve of multiple promises.

function sum(a, b, cb) { cbk(a+b) }

c2p.when(['ab.2','ab.1','another']).then((a) => expect(a).to.eql([8,5,'test']))

sum(1, 4, c2p.successfn('ab.1'))
c2p.id('another').resolve('test')
sum(3, 5, c2p.successfn('ab.2'))

API

c2b: promiser object

  • function id(string): deferred object
  • function successfn(string): solve callback - pointing to resolve fn from deferred
  • function failfn(string): reject callback - pointing to reject fn from deferred
  • function when(string|string[]): thenable object
  • function build(): new promiser object

deferred object

  • funciton isPending(): true|false
  • function isSucceed(): true|false
  • function isFailed(): true|false
  • function isSameObjectAs(): true|false - test if two pointer referencing same object
  • function resolve(): void - it can pass multiple arguments, see note above
  • function reject(): void - it can pass multiple arguments, see note above