GitXplorerGitXplorer
c

compear

public
9 stars
0 forks
0 issues

Commits

List of commits on branch main.
Unverified
40ae7316c506cd8b50f2b3187da331280773d748

readme: Add npm version badge

ccamsteffen committed 5 months ago
Unverified
1052605ef242e60b141d6a515fad73a7544c374f

Document min/max functions throw with empty lists

ccamsteffen committed 5 months ago
Unverified
0e85315f60372855091cd0a465c22bc2606db29f

Bless Dates

ccamsteffen committed 5 months ago
Unverified
252b5d08de8346fd0dc19252332420bb38c696b4

Add check script

ccamsteffen committed 5 months ago
Unverified
f97e8510d56015c637a98bfa52ca175ed1a920de

Improve some docs for overloaded functions

ccamsteffen committed 5 months ago
Unverified
3a2bedec10ae7a3aab59da9cec3d8ae10842ef1e

Use overloads for compareBy

ccamsteffen committed 5 months ago

README

The README file for this repository.

Compear 🍐🤷🍐

Utilities for comparing and sorting with comparators in JavaScript

Documentation

NPM Version

Installation

npm install compear

What is this?

Let's look at an example. Suppose you have a list of objects...

const people = [
    { firstName: "Tina", lastName: "Ham" },
    { firstName: "Bob", lastName: "Builder" },
    { firstName: "Lewis", lastName: "Mayor" },
];

...and you want to sort the array alphabetically by the "lastName" property.

Without Compear, you can write:

const peopleSorted = people.toSorted((personA, personB) => {
    if (personA.lastName < personB.lastName) {
        return -1;
    } else if (personA.lastName > personB.lastName) {
        return 1;
    } else {
        return 0;
    }
});

With Compear, you can write:

const peopleSorted = people.toSorted(compareBy((person) => person.lastName));

Both examples use the array.toSorted(..) function that is built-in to JavaScript. The difference is in how you write the function that is passed as an argument to array.toSorted(..). This kind of function is called a comparator. Creating and using comparators is what Compear is all about.

Compear is written in TypeScript and provides strong type safety.

Notable features

naturalOrder

naturalOrder is meant to be a sensible default comparator for many cases. It works well for comparing numbers, strings, Dates, or lists of these values. For other types of values, you will probably need to create a more specific comparator.

In some of the provided functions (such as compareBy), Compear uses naturalOrder by default, but allows you to provide a different comparator if needed.

compareBy

The compareBy function can create a comparator that selects a specific property to compare, or somehow derives another value to be compared.

compareWith

compareWith chains together multiple comparators. This is useful when you want to: "sort by X, but if X is equal, then sort by Y, etc."

minWith / maxWith

These functions find the smallest or largest value from a list of values using any given comparator.

See the documentation for more.

Examples

Here are some examples of what you can do with Compear:

import { compareBy, compareByDesc, compareWith, minWith } from "compear";

const heros = [
    {
        name: "Frozone",
        age: 37,
        favoriteColor: "blue",
    },
    {
        name: "Stupendous Man",
        age: 9,
        favoriteColor: "red",
    },
    {
        name: "Iron Man",
        age: 44,
        favoriteColor: "gold",
    },
];

const youngestHero = minWith(heros, compareBy("age"))

const sortedByName = heros.sort(compareBy("name"));

const sortedByNameAndGoldFirst = heros.toSorted(
    compareWith(
        compareByDesc("favoriteColor", (color) => color === "gold"),
        compareBy("name"),
    )
);

About

Compear takes some inspiration from Kotlin's kotlin.comparisons package, but is designed for JavaScript.

Compear embraces functional programming to a certain extent. It prioritizes the treatment of comparator functions as first-class citizens especially because they are highly composable and re-usable in practical applications. On the other hand, some functions have a chosen parameter order that prioritizes readability over the possibility of currying.