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 🙏

© 2025 – Pkg Stats / Ryan Hefner

@banjoanton/utils

v1.0.0

Published

A collection of some of my most used JavaScript / TypeScript utility functions.

Downloads

172

Readme

@banjoanton/utils

A collection of some of my most used JavaScript / TypeScript utility functions.

NPM version

  • :palm_tree: - Three-shakable ESM modules.
  • :speech_balloon: - Fully typed TSDocs with examples
  • :file_folder: - Small size
  • :bookmark: - Own well-tested utilities or imported from large open source projects.

The package is designed to be used as devDependencies and bundled into your dist.

Install

# npm
npm install @banjoanton/utils -D

# yarn
yarn add @banjoanton/utils -D

# pnpm
pnpm install @banjoanton/utils -D

Import

import { isArray, fetchJson } from "@banjoanton/utils";
// or
const { isArray, fetchJson } = require("@banjoanton/utils");

Docs

Auto generated from TSDocs.

Table of Contents

Array

Utility functions for working with arrays.


toArray

Convert a single value or array of values into an array.

toArray(1); // returns [1]
toArray([1, 2, 3]); // returns [1, 2, 3]

take

Take the first n elements of an array.

take([1, 2, 3, 4, 5], 2); // returns [1, 2]
take(["a", "b", "c", "d", "e"], 3); // returns ['a', 'b', 'c']

uniq

Remove duplicate values from an array. Primites works as usual, objects are compared by value.

uniq([1, 2, 2, 3, 4, 4]); // returns [1, 2, 3, 4]
uniq(["a", "a", "b", "c"]); // returns ['a', 'b', 'c']

// objects are compared by value
const a = { name: "Alex", age: 20 };
const b = { name: "Alex", age: 15 };
const c = { name: "Bony", age: 5 };
const d = { name: "Bony", age: 5 };

uniq([a, b, c, d]); // returns [a, b, c]

uniqBy

Remove duplicate values from an array by a key. Can also take a custom function that receives the item to choose the value to compare by.

const a = { name: "Alex", age: 20 };
const b = { name: "Alex", age: 15 };

// compare by a single key
uniqBy([a, b], "name"); // returns [a]
uniqBy([a, b], "age"); // returns [a, b]

// compare by a custom function
uniqBy([a, b], item => item.name); // returns [a]
uniqBy([a, b], item => item.age); // returns [a, b]

shuffle

Shuffle the elements of an array. Creates a new array with the elements of the original array in a random order.

shuffle([1, 2, 3, 4, 5]); // returns [2, 4, 1, 5, 3]
shuffle(["a", "b", "c", "d", "e"]); // returns ['b', 'd', 'a', 'e', 'c']

chunk

Create a chunk of an array. A chunk is a new array containing a specified number of elements from the original array.

chunk([1, 2, 3, 4, 5], 2); // returns [[1, 2], [3, 4], [5]]
chunk(["a", "b", "c", "d", "e"], 3); // returns [['a', 'b', 'c'], ['d', 'e']]
chunk([1, 2, 3, 4, 5], 10); // returns [[1, 2, 3, 4, 5]]
chunk([1, 2, 3, 4, 5], 1); // returns [[1], [2], [3], [4], [5]]
chunk([1, 2, 3, 4, 5], 0); // returns []

last

Return the last element of an array.

last([1, 2, 3]); // returns 3
last(["a", "b", "c"]); // returns 'c'

first

Return the first element of an array.

first([1, 2, 3]); // returns 1
first(["a", "b", "c"]); // returns 'a'

range

Generate an array of numbers in a given range.

range(5); // returns [0, 1, 2, 3, 4]
range(2, 5); // returns [2, 3, 4]
range(2, 10, 2); // returns [2, 4, 6, 8]

move

Move an element of an array from one position to another.

move([1, 2, 3, 4], 0, 2); // returns [2, 3, 1, 4]
move(["a", "b", "c", "d"], 1, 3); // returns ['a', 'c', 'd', 'b']

sample

Return a random element from an array.

sample([1, 2, 3, 4]); // returns a random element from the array
sample(["a", "b", "c", "d"]); // returns a random element from the array

remove

Remove one or more elements from an array. Either by item or by predicate.

remove([1, 2, 3, 4], 2); // returns [1, 3, 4]
remove(["a", "b", "c", "d"], "b"); // returns ['a', 'c', 'd']

// remove by a custom function
remove([1, 2, 3], item => item === 2); // returns [1, 3]
remove(["a", "b", "c", "d"], item => item === "b"); // returns ['a', 'c', 'd']

compact

Remove falsy values (null, undefined, "", 0, false, NaN) from an array.

compact([1, 2, 3, 4, 0, null, undefined, false]); // returns [1, 2, 3, 4]

difference

Return the difference between two arrays. Objects are compared by value, meaning that two objects with the same properties will be considered equal. Can also take a custom comparator function.

// primitives are compared by value
difference([1, 2, 3, 4], [2, 4]); // returns [1, 3]
difference(["a", "b", "c", "d"], ["b", "d"]); // returns ['a', 'c']

// objects are also compared by value by default
const obj = {};
difference([obj], [obj]); // returns []
difference([{ a: 1 }], [{ a: 1 }]); // returns []
difference([{ a: 1 }], [{ a: 2 }]); // returns [{ a: 1 }, { a: 2 }]

// custom comparator
const comparator = (a: any, b: any) => a === b;
difference([1, 2, 3, 4], [2, 4], comparator); // returns [1, 3]
difference(["a", "b", "c", "d"], ["b", "d"], comparator); // returns ['a', 'c']

intersection

Return the intersection between two arrays. Objects are compared by value, meaning that two objects with the same properties will be considered equal. Can also take a custom comparator function.

// primitives are compared by value
intersection([1, 2, 3, 4], [2, 4]); // returns [2, 4]
intersection(["a", "b", "c", "d"], ["b", "d"]); // returns ['b', 'd']
intersection([1, 2, 3, 4], [2, 4, 5]); // returns [2, 4]

// objects are also compared by value by default
const obj = {};
intersection([obj], [obj]); // returns [obj]
intersection([{ a: 1 }], [{ a: 1 }]); // returns [{ a: 1 }]
intersection([{ a: 1 }], [{ a: 2 }]); // returns []

// custom comparator
const comparator = (a: any, b: any) => a === b;
intersection([1, 2, 3, 4], [2, 4], comparator); // returns [2, 4]
intersection(["a", "b", "c", "d"], ["b", "d"], comparator); // returns ['b', 'd']

union

Union multiple arrays. Objects are compared by value, meaning that two objects with the same properties will be considered equal.

union([1, 2, 3], [2, 4]); // returns [1, 2, 3, 4]
union(["a", "b", "c"], ["b", "d"]); // returns ['a', 'b', 'c', 'd']

// multiple arrays
union([1, 2, 3], [2, 4], [5, 6]); // returns [1, 2, 3, 4, 5, 6]

// objects are also compared by value by default
const point1 = { x: 1, y: 1 };
const point2 = { x: 2, y: 2 };
const point3 = { x: 3, y: 3 };
const point3ButSame = { x: 3, y: 3 };

union([point1, point2], [point2, point3], [point3ButSame]); // returns [point1, point2, point3]

sortBy

Sort an array. Can sort by a single key or multiple keys. Can also take a custom function that receives the item to choose the value to sort by.

const a = { name: "Alex", age: 20 };
const b = { name: "Alex", age: 15 };
const c = { name: "Bony", age: 5 };

// sort by a single key
sortBy([a, b, c], "name"); // returns [a, b, c]
sortBy([a, b, c], "age"); // returns [c, b, a]

// sort by multiple keys
sortBy([a, b, c], ["name", "age"]); // returns [b, a, c]

// sort by a custom function
sortBy([a, b, c], item => item.name); // returns [a, b, c]
sortBy([a, b, c], item => item.age); // returns [c, b, a]

groupBy

Group an array by a key. Can also take a custom function that receives the item to choose the value to group by.

const a = { name: "Alex", age: 20 };
const b = { name: "Alex", age: 15 };
const c = { name: "Bony", age: 5 };

groupBy([a, b, c], "name"); // returns {Alex: [a, b], Bony: [c]}
groupBy([a, b, c], "age"); // returns {5: [c], 15: [b], 20: [a]}

groupBy([a, b, c], item => item.name); // returns {Alex: [a, b], Bony: [c]}
groupBy([a, b, c], item => item.age); // returns {5: [c], 15: [b], 20: [a]}

includes

Type guard to check if a value is included in an array. Useful for filtering arrays.

const values = ["a", "b", "c"] as const;
const valueToCheck: unknown = "a";

includes(values, valueToCheck); // returns true

if (includes(values, valueToCheck)) {
    // valueToCheck is now of type "a" | "b" | "c"
}

zip

Zip multiple arrays into a single array of arrays. The first element of the result array will contain the first element of all the input arrays, the second element of the result array will contain the second element of all the input arrays, and so on.

zip([1, 2, 3], [4, 5, 6]); // returns [[1, 4], [2, 5], [3, 6]]
zip([1, 2, 3], ["a", "b", "c"]); // returns [[1, "a"], [2, "b"], [3, "c"]]

partition

Partition an array into two arrays. The first array will contain the items that pass the predicate function, the second array will contain the items that don't pass the predicate function.

const a = { name: "Alex", age: 20 };
const b = { name: "Alex", age: 15 };

partition([a, b], item => item.age > 18); // returns [[a], [b]]

const values = [1, 2, 3, 4, 5];
partition(values, item => item % 2 === 0); // returns [[2, 4], [1, 3, 5]]

sum

Return the sum of all the elements in an array.

sum([1, 2, 3, 4, 5]); // returns 15

Base

Base utilities that have no particular classification.


sleep

Sleep for a given amount of time.

await sleep(1000); // sleep for 1 second
await sleep(); // sleep for at least 0 milliseconds

Cache

Cache utility.


cache

Creates a super simple cache with expiration and support for persistance in browsers. Can be used with strings and symbols as key. Is generic and can be used with any type.

const { get, set, has, delete, clear } = cache();

set("key", "value");
get("key"); // "value"
has("key"); // true
delete("key"); // true
clear();

// can be used with generics
const cache = cache<string>();

// can be used with symbols
const cache = cache();
const key = Symbol("key");
cache.set(key, "value");

// can be be persisted in local storage
const cache = cache({ persistent: true });

// can be be persisted in local storage with a custom key
const cache = cache({ persistent: true, key: "my-cache" });

// custom expiration time in ms
const cache = cache({ ttl: 1000 });

Crypto

Utility functions for crypto.


uuid

Create a new UUID. Based on the "uncrypto" library.

uuid(); // returns a random UUID
uuid(); // returns another random UUID

isUUID

Checks if a string is a valid UUID.

isUUID("hello world"); // returns false
isUUID("9cea4ab2-beb8-4b02-ab10-48a39c6b91fa"); // returns true

encrypt

Encrypt a string with a key. Based on the "uncrypto" library. Uses AES-CBC with a random IV. Returns a string with the IV prepended. Use decrypt to decrypt the string.

await encrypt("hello world", "key"); // returns "IV:encryptedData"

decrypt

Decrypt a string with a key. Based on the "uncrypto" library. Expects a string in the format of "IV:encryptedData" in base64 format. Use encrypt to encrypt a string.

await decrypt("IV:encryptedData", "key"); // returns "hello world"

hash

Hash an object or string with SHA-256. From the ohash library.

await hash("hello world"); // returns "hashedString"
await hash({ foo: "bar" }); // returns "hashedString"
await hash({ foo: "bar" }); // returns the same "hashedString" as before

Date

Utility functions for date and time.


getCalendarMonths

Returns an array of month names. The array is zero-based, so the first month is January.

getCalendarMonths(); // returns ['January', 'February', ...]
getCalendarMonths({ month: "short" }); // returns ['Jan', 'Feb', ...]
getCalendarMonths({ month: "narrow" }); // returns ['J', 'F', ...]
getCalendarMonths({ month: "numeric" }); // returns ['1', '2', ...]

getCalendarMonths({ locales: "fr-FR" }); // returns ['janvier', 'février', ...]
getCalendarMonths({ locales: "sv-SE" }); // returns ['januari', 'februari', ...]

getCalendarDays

Returns an array of day names. The array is zero-based. The first day is Monday by default.

getCalendarDays(); // returns ['Monday', 'Tuesday', ...]
getCalendarDays({ day: "short" }); // returns ['Mon', 'Tue', ...]
getCalendarDays({ day: "narrow" }); // returns ['M', 'T', ...]
getCalendarDays({ startOnMonday: false }); // returns ['Sunday', 'Monday', ...]

getCalendarDays({ locales: "fr-FR" }); // returns ['lundi', 'mardi', ...]
getCalendarDays({ locales: "sv-SE" }); // returns ['måndag', 'tisdag', ...]
getCalendarDays({ locales: "sv-SE", startOnMonday: false }); // returns ['söndag', 'måndag', ...]

toMilliseconds

Converts a time unit to milliseconds. Combine all units to get the total time in milliseconds.

toMilliseconds({ seconds: 10 }); // returns 10000
toMilliseconds({ minutes: 10 }); // returns 600000
toMilliseconds({ hours: 10 }); // returns 36000000

toMilliseconds({ seconds: 10, minutes: 10 }); // returns 610000
toMilliseconds({ seconds: 10, minutes: 10, hours: 10 }); // returns 3610000

toSeconds

Converts a time unit to seconds. Combine all units to get the total time in seconds.

toSeconds({ seconds: 10 }); // returns 10
toSeconds({ minutes: 10 }); // returns 600
toSeconds({ hours: 10 }); // returns 36000
toSeconds({ days: 10 }); // returns 864000

toMinutes

Converts a time unit to minutes. Combine all units to get the total time in minutes.

toMinutes({ seconds: 10 }); // returns 0.16666666666666666
toMinutes({ minutes: 10 }); // returns 10
toMinutes({ hours: 10 }); // returns 600
toMinutes({ days: 10 }); // returns 14400

toHours

Converts a time unit to hours. Combine all units to get the total time in hours.

toHours({ seconds: 10 }); // returns 0.002777777777777778
toHours({ minutes: 10 }); // returns 0.16666666666666666
toHours({ hours: 10 }); // returns 10
toHours({ days: 10 }); // returns 240

toDays

Converts a time unit to days. Combine all units to get the total time in days.

toDays({ seconds: 10 }); // returns 0.00011574074074074074
toDays({ minutes: 10 }); // returns 0.006944444444444444
toDays({ hours: 10 }); // returns 0.4166666666666667
toDays({ days: 10 }); // returns 10

earliest

Returns the earliest date in an array of dates.

earliest([...dates]);

const earlyDate = new Date(2020, 0, 1);
const lateDate = new Date(2020, 0, 2);

earliest([earlyDate, lateDate]); // returns earlyDate

latest

Returns the latest date in an array of dates.

latest([...dates]);

const earlyDate = new Date(2020, 0, 1);
const lateDate = new Date(2020, 0, 2);

latest([earlyDate, lateDate]); // returns lateDate

isBetweenDates

Returns true if a date is between two other dates.

isBetweenDates([...dates]);

const earlyDate = new Date(2020, 0, 1);
const dateInBetween = new Date(2020, 0, 2);
const lateDate = new Date(2020, 0, 3);

isBetweenDates(dateInBetween, earlyDate, lateDate); // returns true

toIsoDateString

Format date to ISO 8601 format. YYYY-MM-DD.

toIsoDateString(new Date(2020, 0, 1)); // returns '2020-01-01'

getFirstDayOfWeek

Get the first day (monday) of the week. Defaults to today if nothing is passed.

getFirstDayOfWeek(); // returns previous monday
getFirstDayOfWeek(new Date("2022-02-02")); // returns previous monday from specified date

getWeekNumber

Get the week number of the specified date. Defaults to today. Wrapper around "current-week-number".

getWeekNumber(); // returns 5 (if in week 5)
getWeekNumber("2020-01-04"); // returns 1

parseDate

Parse a date string or date object to a Date object based on the provided options. If a Date object is passed, it is returned as is. If throwOnInvalid is true and the date is invalid, it throws an error. If throwOnInvalid is false and the date is invalid, it returns undefined.

parseDate("2020-01-01"); // returns Date object or throws error if invalid
parseDate("2020-01-01", { throwOnInvalid: false }); // returns Date object or undefined if invalid
parseDate(new Date("2020-01-01")); // returns Date object
parseDate(123456789, { throwOnInvalid: true }); // throws error
parseDate({}, { throwOnInvalid: false }); // returns undefined
parseDate([], { throwOnInvalid: false }); // returns undefined

Function

Utilities for working with functions.


debounce

Created a debounced version of the provided function. The function is a wrapper around the "throttle-debounce" library.

const debounced = debounce(() => console.log("hello world"), 1000);
debounced(); // logs 'hello world' after 1000ms
debounced(); // does nothing if called within 1000ms of the previous call

throttle

Created a throttled version of the provided function. The function is a wrapper around the "throttle-debounce" library.

// invokes the function not more than once per second
const throttled = throttle(() => console.log("hello world"), 1000);
element.addEventListener("mousemove", throttled);

// cancel the throttled function
throttled.cancel();

batchInvoke

Invoke all functions in an array. Will not invoke any functions that are undefined.

batchInvoke([() => console.log("hello"), () => console.log("world")]); // logs 'hello' and 'world'
batchInvoke([() => console.log("hello"), undefined, () => console.log("world")]); // logs 'hello' and 'world'

noop

A no-op function. Useful for default values.

noop(); // does nothing

const myFunction = (callback = noop) => {
    callback();
};

myFunction(); // does nothing

const func = noop;
func(); // does nothing

noopAsync

A no-op async function. Useful for default values.

noopAsync(); // does nothing

const myFunction = async (callback = noopAsync) => {
    await callback();
};

await myFunction(); // does nothing

memoize

Creates a function that memoizes the result of fn. If fn is called multiple times with the same arguments, the cached result for that set of arguments is returned.

const add = (a: number, b: number) => a + b;
const memoizedAdd = memoize(add);

memoizedAdd(1, 2); // returns 3 and caches the result
memoizedAdd(1, 2); // returns 3 from the cache
memoizedAdd(1, 2); // returns 3 from the cache

memoizedAdd(1, 3); // returns 4 and caches the result
memoizedAdd(1, 3); // returns 4 from the cache

raise

Creates a function that raises and error with the provided message. Makes it a bit easier to use in some cases.

raise("Something went wrong");

const data = somethingThatMightExist ?? raise("Data does not exist");

exhaustiveCheck

Check that a value is of type never. Useful for checking that a switch statement is exhaustive in TypeScript.

type Foo = "a" | "b";

switch (foo) {
    case "a":
        // do something
        break;
    default:
        exhaustiveCheck(foo); // raises an error
}

invariant

Check that a value is not falsy. Useful for narrowing types in TypeScript.

const person: Person | undefined = getPerson();
invariant(person, "Person does not exist"); // person is now of type Person if it exists

const person: Person | undefined = undefined;
invariant(person, "Person does not exist"); // raises an error

produce

Produce a new object from an existing object without mutating the original object. Uses structured cloning to create a deep clone of the object. Works with non-primitive types like arrays, maps, sets and objects. A simple version of immer.

// original version
const person = { name: "John", age: 30 };
const updatedPerson = produce(person, draft => {
    draft.age = 31;
});

console.log(person.age); // 30
console.log(updatedPerson.age); // 31

// curried version
const producePerson = produce((draft: Person) => {
    draft.age = 31;
});

const person = { name: "John", age: 30 };
const updatedPerson = producePerson(person);

console.log(person.age); // 30
console.log(updatedPerson.age); // 31

// curried version in React
const [person, setPerson] = useState({ name: "John", age: 30 });

setPerson(
    produce(draft => {
        draft.age = 31;
    })
);

Is

Utility functions for checking the type of a value.


isBoolean

Check if the given value is a boolean.

isBoolean(true); // true
isBoolean("hello world"); // false

isNumber

Check if the given value is a number. NaN is not considered a number. A string containing a number is not considered a number.

isNumber(1); // true
isNumber("hello world"); // false
isNumber(NaN); // false

isString

Check if the given value is a string.

isString("hello world"); // true
isString(1); // false

isSymbol

Check if the given value is a symbol.

isSymbol(Symbol("hello world")); // true
isSymbol("hello world"); // false

isFunction

Check if the given value is a function.

isFunction(() => {}); // true
isFunction("hello world"); // false
isFunction(1); // false

isObject

Check if the given value is an object.

isObject({}); // true
isObject("hello world"); // false
isObject(1); // false

isDateObject

Check if the given value is a Date object. Cannot be used to check if a value is a valid date.

isDateObject(new Date()); // true
isDateObject("hello world"); // false
isDateObject(1); // false
isDateObject(new Date("hello world")); // true

isDate

Check if the given value is a valid date. Cannot be used to check if a value is a Date object. Can pass strings, numbers, or Date objects. Notice that dates might works differently in different browsers. Passing in "1" will return true in Chrome, but false in Firefox.

isDate(new Date()); // true
isDate("hello world"); // false
isDate(1); // true or false depending on the browser
isDate(new Date("hello world")); // false
isDate("2022-12-24"); // true

isRegExp

Check if the given value is a RegExp.

isRegExp(/hello world/); // true
isRegExp("hello world"); // false
isRegExp(1); // false
isRegExp(new RegExp("hello world")); // true

isNull

Check if the given value is null.

isNull(null); // true
isNull("hello world"); // false
isNull(1); // false
isNull(undefined); // false

isUndefined

Check if the given value is undefined.

isUndefined(undefined); // true
isUndefined("hello world"); // false
isUndefined(1); // false
isUndefined(null); // false

isNil

Check if the given value is null or undefined.

isNil(null); // true
isNil(undefined); // true
isNil("hello world"); // false
isNil(1); // false

isDefined

Check if the given value exists (is not undefined). Also type guards against undefined.

isDefined(undefined); // false
isDefined(null); // true
isDefined("hello world"); // true
isDefined(1); // true
isDefined(false); // true
isDefined([]); // true

exists

Check if the given value is not null or undefined. Also type guards against null and undefined.

exists(undefined); // false
exists(null); // false
exists("hello world"); // true
exists(1); // true
exists(false); // true
exists([]); // true

isTruthy

Check if the given value is truthy. Also type guards against falsy values.

isTruthy(undefined); // false
isTruthy(null); // false
isTruthy("hello world"); // true
isTruthy(1); // true
isTruthy(false); // false
isTruthy([]); // true
isTruthy(0); // false
isTruthy(""); // false
isTruthy(NaN); // false
isTruthy({}); // true

isFalsy

Check if the given value is falsy. Also type guards against truthy values.

isFalsy(undefined); // true
isFalsy(null); // true
isFalsy("hello world"); // false
isFalsy(1); // false
isFalsy(false); // true
isFalsy([]); // false
isFalsy(0); // true
isFalsy(""); // true
isFalsy(NaN); // true
isFalsy({}); // false

isPrimitive

Check if the given value is a primitive type (string, number, boolean).

isPrimitive("hello world"); // true
isPrimitive(1); // true
isPrimitive(false); // true
isPrimitive({}); // false
isPrimitive([]); // false

isArray

Check if the given value is an array.

isArray([1, 2, 3]); // true
isArray("hello world"); // false
isArray(1); // false
isArray(new Array(1, 2, 3)); // true

isElement

Check if the value is a DOM element.

isElement(document.body); // true
isElement("hello world"); // false

isEqual

Check whether the two values are equal. Uses the fast-deep-equal package. Works with all types.

isEqual(1, 1); // true
isEqual(1, 2); // false
isEqual("hello", "hello"); // true
isEqual(null, undefined); // false
isEqual({ a: 1 }, { a: 1 }); // true
isEqual({ a: 1 }, { a: 2 }); // false
isEqual([1, 2, 3], [1, 2, 3]); // true

isEmpty

Check if the given value is empty. Works with strings, arrays, objects, and maps. Trims strings before checking.

isEmpty(""); // true
isEmpty(" "); // true
isEmpty("hello world"); // false
isEmpty(1); // false
isEmpty([]); // true
isEmpty([1, 2, 3]); // false
isEmpty({}); // true
isEmpty({ a: 1 }); // false
isEmpty(new Map()); // true
isEmpty(new Map([["a", 1]])); // false

isBrowser

Check if the code is running in a browser environment.

isBrowser(); // true
isBrowser(); // false

isNode

Check if the code is running in a Node.js environment.

isNode(); // true
isNode(); // false

Number

Utility functions for working with numbers.


random

Produces a random number between min and max (inclusive). If only one argument is provided a number between 0 and the given number is returned. If floating is true, or either min or max are floats, a floating-point number is returned instead of an integer.

random(0, 5); // 2
random(5); // 2
random(5, true); // 2.123876376
random(0, 5, true); // 2.123876376

parseNumber

Parse a string into a number. If the string is empty or cannot be parsed, undefined is returned.

parseNumber("1"); // 1
parseNumber("1.5"); // 1.5
parseNumber("1.5.5"); // undefined
parseNumber(""); // undefined

Object

Utility functions for working with objects. Both wrappers and custom functions.


getProperty

Returns the value at path of object. If the resolved value is undefined, the defaultValue is returned in its place. Undefined will be returned if the path is not found or on failure. Wrapper around the "dot-prop" library.

const obj = { a: { b: { c: "d" } } };

getProperty(obj, "a.b.c"); // => "d"
getProperty(obj, "a.b"); // => { c: "d" }

getProperty({ a: [{ b: "c" }] }, "a[0].b"); // => "c"
getProperty({ a: [{ b: "c" }] }, "a[1].b"); // => undefined

setProperty

Sets the value at path of object. If a portion of path doesn't exist, it's created. Arrays are created for missing index properties while objects are created for all other missing properties. Use deleteProperty to remove property values. Wrapper around the "dot-prop" library.

const obj = { a: { b: { c: "d" } } };

setProperty(obj, "a.b.c", "hello"); // => { a: { b: { c: "hello" } } }
setProperty(obj, "a", hello); // => { a: "hello" }
setProperty({}, "a.b", "hello"); // => { a: { b: "hello" } }

hasProperty

Checks if object has a property at path. If the resolved value is undefined, false is returned. Wrapper around the "dot-prop" library.

const obj = { a: { b: { c: "d" } } };
hasProperty(obj, "a.b.c"); // => true
hasProperty(obj, "a.b"); // => true
hasProperty(obj, "a.b.c.d"); // => false

deleteProperty

Deletes the property at path of object. Wrapper around the "dot-prop" library.

const obj = { a: { b: { c: "d" } } };

deleteProperty(obj, "a.b.c"); // => true
deleteProperty(obj, "a.b"); // => true
deleteProperty(obj, "a.b.c.d"); // => false

objectKeys

Strictly typed version of Object.keys. Returns an array of keys of the object.

const obj = { a: 1, b: 2, c: 3 };
objectKeys(obj); // => ["a", "b", "c"]
objectKeys({}); // => []

objectValues

Strictly typed version of Object.values. Returns an array of values of the object.

const obj = { a: 1, b: 2, c: 3 };
objectValues(obj); // => [1, 2, 3]
objectValues({}); // => []

objectEntries

Strictly typed version of Object.entries. Returns an array of key-value pairs of the object.

const obj = { a: 1, b: 2, c: 3 };
objectEntries(obj); // => [["a", 1], ["b", 2], ["c", 3]]
objectEntries({}); // => []

merge

Deeply merges two or more objects. The last object in the arguments list overwrites previous values. No mutation. Uses the deepmerge library.

const obj1 = { a: 1 };
const obj2 = { a: 2 };
merge(obj1, obj2); // => { a: 2 }

const obj1 = { a: { b: 1 } };
const obj2 = { a: { c: 2 } };
merge(obj1, obj2); // => { a: { b: 1, c: 2 } }

const obj1 = { a: { b: 1 } };
const obj2 = { a: { b: 2 } };
const obj3 = { a: { b: 3 } };
merge(obj1, obj2, obj3); // => { a: { b: 3 } }

clone

Deeply clones an object. No mutation.

const obj = { a: { b: 1 } };
const cloned = clone(obj);
cloned.a.b = 2;
console.log(obj.a.b); // => 1

defaults

Used for setting default values. Deeply merges two objects. No mutation. The first object is the partial one, and the second object is the default one. If a value is already set in the partial object, it will not be overwritten.

const obj1 = { a: 1 };
const obj2 = { a: 2 };
defaults(obj1, obj2); // => { a: 1 }
defaults(obj2, obj1); // => { a: 2 }

flip

Flips the keys and values of an object. If the object has duplicate values, the last key will be used.

const obj = { a: 1, b: 2, c: 3 };
flip(obj); // => { 1: "a", 2: "b", 3: "c" }

Result

A result type that can be used to return a value or an error.


Result

A simple result type that can be used to return a value or an error.

const result = Result.ok(1); // or Result.error
if (result.success) {
    console.log(result.data);
} else {
    console.log(result.message);
}

const error = Result.error("error message");
console.log(error.message);

createResult

Create a wrapper around the default Result type. Making it possible to import the Result type from your own module. Without any custom error data and types. Use createResultWithErrorData for custom error data and types.

const OwnResult = createResult();

const result = OwnResult.ok(1); // or OwnResult.error
if (result.success) {
    console.log(result.data);
} else {
    console.log(result.message);
}

createResultWithErrorData

Create a custom Result type with error data and types.

type MyErrorDataMap = {
    network: { endpoint: string; statusCode: number };
    internal: { errorId: string; details: string };
};
type DefaultError = "UnknownError";

const OwnResult = createResult<MyErrorDataMap, DefaultError>();

const error = OwnResult.error("error message", {
    type: "network",
    data: { endpoint: "http://example.com", statusCode: 404 },
});

if (error.type === "network") {
    console.log(error.data.endpoint);
}

const error = OwnResult.error("error message");
console.log(error.type); // type "UnknownError"

createTryExpressionResult

Create a custom Result type based on try expressions, with a Go-like syntax. Used to return a value or an error. Return value is a TryExpressionResult tuple with an error and a value.

const Result = createTryExpressionResult();
const getResult = () => {
    if (something()) {
        return Result.ok(1);
    } else {
        return Result.error(new Error("error"));
    }
};

const [error, value] = getResult();
if (error) {
    console.log(error.message); // Error is defined
} else {
    console.log(value); // Value is defined
}

String

Utilities for working with strings.


capitalize

Capitalizes the first letter of a given string and converts the rest of the letters to lowercase.

capitalize("hello"); // returns 'Hello'
capitalize("HELLO"); // returns 'Hello'

randomString

Generate a random string with the length provided, defaults to 16.

randomString(); // returns 'Fwf4552Dd2'
randomString(5); // return 'f5l32'

wildcardMatch

Check if a string matches a wildcard pattern. Uses the "wildcard-match" library.

wildcardMatch("/foo/bar", "/foo/*"); // returns true
wildcardMatch("/foo/bar", "/foo/bar"); // returns true
wildcardMatch("/foo/bar", "/foo/bar/*"); // returns false

ensurePrefix

Ensure a string starts with a given prefix.

ensurePrefix("hello", "foo"); // returns 'foohello'
ensurePrefix("foohello", "foo"); // returns 'foohello'
ensurePrefix("hello", "hello"); // returns 'hello'

ensureSuffix

Ensure a string ends with a given suffix.

ensureSuffix("hello", "foo"); // returns 'hellofoo'
ensureSuffix("hellofoo", "foo"); // returns 'hellofoo'
ensureSuffix("hello", "hello"); // returns 'hello'

template

Simple templating function that replaces {0}, {1} or {{key}} with the provided arguments.

template("hello {0}", "world"); // returns 'hello world'
template("hello {0} {1}", "world", "foo"); // returns 'hello world foo'
template("hello {0} {1}", "world"); // returns 'hello world {1}'

template("hello {{name}}", { name: "world" }); // returns 'hello world'
template("hello {{name}}, I am {{me}}", { name: "world", me: "Kent" }); // returns 'hello world, I am Kent'
template("hello {{name}}", { name: "world", foo: "bar" }); // returns 'hello world'
template("hello {{name}}", { foo: "bar" }); // returns 'hello {{name}}'

escapeHtml

Escape HTML special characters.

escapeHtml("<div>hello</div>"); // returns '&lt;div&gt;hello&lt;/div&gt;'

unescapeHtml

Unescape HTML special characters. Opposite of escapeHtml.

unescapeHtml("&lt;div&gt;hello&lt;/div&gt;"); // returns '<div>hello</div>'

escapeRegExp

Escape RegExp special characters.

escapeRegExp("hello world"); // returns 'hello world'
escapeRegExp("hello*world"); // returns 'hello\\*world'
escapeRegExp("hello?world"); // returns 'hello\\?world'
escapeRegExp("hello(world"); // returns 'hello\\(world'

slugify

Slugify a string. Converts a string to lowercase, removes non-word characters and replaces spaces with dashes.

slugify("hello world"); // returns 'hello-world'
slugify("hello world!"); // returns 'hello-world'
slugify(""); // returns ''
slugify("This is a long sentence that should be slugified!!"); // returns 'this-is-a-long-sentence-that-should-be-slugified'

truncate

Truncate a string to a given length. Adds an ellipsis to the end of the string if it was truncated.

truncate("hello world", 5); // returns 'hello...'
truncate("hello world", 5, "...more"); // returns 'hello...more'
truncate("hello world", 100); // returns 'hello world'
truncate("hello world", 5, ""); // returns 'hello'
truncate("hello world", 5, "..."); // returns 'hello...'

Test

Simple utility function for tests


attemptSync

Try to run a sync function, and return a fallback value if it throws an error. Defaults to undefined if nothing is provided.

attemptSync(() => 1); // 1
attemptSync(() => {
    throw new Error("test");
}); // undefined

attemptSync(
    () => {
        throw new Error("test");
    },
    { fallbackValue: 1 }
); // 1
attemptSync(
    () => {
        throw new Error("test");
    },
    { fallbackValue: 1, logError: true }
); // 1, logs error to console
attemptSync(
    () => {
        throw new Error("test");
    },
    { fallbackValue: 1, onError: e => console.error(e) }
); // 1, logs error to console

attempt

Try to run an async function, and return a fallback value if it throws an error. Defaults to undefined if nothing is provided.

await attempt(async () => 1); // 1
await attempt(async () => {
    throw new Error("test");
}); // undefined

await attempt(
    async () => {
        throw new Error("test");
    },
    { fallbackValue: 1 }
); // 1
await attempt(
    async () => {
        throw new Error("test");
    },
    { fallbackValue: 1, logError: true }
); // 1, logs error to console
await attempt(
    async () => {
        throw new Error("test");
    },
    { fallbackValue: 1, onError: e => console.error(e) }
); // 1, logs error to console

attemptAsync

Try to run an async function, and return a fallback value if it throws an error. Defaults to undefined if nothing is provided.

undefined;

to

Attempt to run an async function like in Go, returning a tuple with the error and the result.

const [error, result] = await to(async () => 1); // [null, 1]
const [error, result] = await to(async () => {
    throw new Error("test");
}); // [Error("test"), null]

toSync

Attempt to run an sync function like in Go, returning a tuple with the error and the result.

const [error, result] = toSync(() => 1); // [null, 1]
const [error, result] = toSync(() => {
    throw new Error("test");
}); // [Error("test"), null]

wrap

Attempt to run a function like in Go, returning an array with the result and the error.

undefined;

wrapAsync

Attempt to run an async function like in Go, returning an array with the result and the error.

undefined;

createMockCreator

Create a new create mock function to update the base mock with the partial mock. Will overwrite arrays instead of merging them.

const numbersMock = { a: 1, b: 2, c: 3 };
const updatedData = { a: 2 };

export const createNumbersMock = createMockCreator(numbersMock);

createNumbersMock(updatedData); // => { a: 2, b: 2, c: 3 }