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

predicate-hof

v2.0.1

Published

TypeScript higher-order-functions to combine or negate predicates without evaluating them.

Downloads

298

Readme

Predicate HOF (High-Order-Functions)

A collections of higher-order-functions to combine and negate predicates, without evaluating said predicates.

Fully written in TypeScript, and no dependencies.

Currently, the functions available are:

  • not,           negates the predicate.
  • all,           true only if ALL the predicates returns true.
  • any,           true if ANY the predicate returns true.
  • none,            true only if NONE of the predicates return true.
  • onlyOne,     true if ONLY ONE of the predicates return true.

They all work with predicates taking in any number of arguments, as long as all the predicates take in the same (or subtype/supertype) parameters for example:

interface Parent {
    x: number
}
interface Child extends Parent {
    y: string
}

const parentPredicate = (x: Parent) => true
const childPredicate = (x: Child) => true

// Both works:
all(parentPredicate, childPredicate)
all(childPredicate, parentPredicate)

If you're getting type errors, check the "Fixing type errors" section below

Install

npm i predicate-hof

Examples

I didn't define the predicates below for simplicity-sake, so you can just use your imagination on how they work :)

import { all } from 'predicate-hof'

const canBuyAGun = all(isAbove18, hasNoCriminalRecord, hasMoney)
canBuyAGun(bob) // true,  bob is cool
canBuyAGun(brokeAssTimmy) // false, go get a job Timmy
import { any } from 'predicate-hof'

const toCallCops = any(hasDoneSmthBad, hasStolenMyPurse, isBlack)
toCallCops(bob) // false, bob is still cool
toCallCops(obama) // true,  he didn't do anything wrong but...
import { not } from 'predicate-hof'

isAlive(bob) // true, always alive in my heart
not(isAlive)(johnFKennedy) // true

wasAssassinated(johnFKennedy) // true, rip Mr President :(
not(wasAssassinated)(epstein) // :^)

Here's examples for binary-predicates

import { any } from 'predicate-hof'

isLessThan(1, 3) // true, 1 < 3
isEqual(1, 1) // true, 1 === 1

const isLessThanOrEqual = biAny(isLessThan, isEqual)
isLessThanOrEqual(1, 5) // true, 1 <= 5
isLessThanOrEqual(1, 1) // true, 1 <= 1

Fixing type errors

If the predicate parameters don't match exactly, TypeScript might complain:

const numOnly = (n: number) => true
const numAndStr = (n: number, str: string) => true

all(numOnly, numAndStr) // numAndStr gives type error

A fix would be to ensure the predicate that accepts the most parameters is the first to be passed:

// 'numAndStr' takes more parameters,
// so it should be at the front.
all(numAndStr, numOnly)

If that doesn't work, or is not possible to do, you can specify the generic type (which is an array of the parameter type(s)):

// number is 1st argument
// string is 2nd argument
all<[number, string]>(numOnly, numAndStr)