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

reversible-key-map

v1.0.2

Published

A double reversible key map using classic JS Map

Downloads

6

Readme

ReversibleKeyMap

A Map extended call with support of two keys instead of one, the support of O(1) access to data linked to one of the two keys, with a non-relevant key order.

One ReversibleKeyMap object takes two keys in argument when setting a value. Keys are reversible: Order of the two keys is not relevant. You can also access data stored under one key (in the form of a map storing a key => value data) in a constant time.

This documentation will use TypeScript typing. Remove any type to restore "pure" JavaScript.

Getting started

// With a standard Map
const classic_map = new Map<string, string>();
classic_map.set('classic', 'map');

// <type_key1, type_key2, type_value>
const reversible_map = new ReversibleKeyMap<string, number, string[]>();
reversible_map.set('one', 2, ['value', 'other']);

// Key order is not important
reversible_map.set(3, 'four', ['my_values', 'in_this_array']);

reversible_map.get(3, 'four'); // => ['my_values', 'in_this_array']
reversible_map.get('four', 3); // => ['my_values', 'in_this_array']
reversible_map.get(2, 'one'); // => ['value', 'other']

Keys can be of any type (like in the Map object).

const other_map = new ReversibleKeyMap<HTMLElement, HTMLElement, Function>();
other_map.set(document.getElementById('hello'), document.getElementById('other-click'), myEventListener);

The number of keys allowed is unlimited and their order is not relevant.

To install the package, use:

$ npm install reversible-key-map

Usage

Main method are get, set, getAllFrom, has and hasCouple.

Instanciation

import ReversibleKeyMap from 'reversible-key-map';

const map = new ReversibleKeyMap<string, string, number>();
// You can instanciate with an entries array
const from_it = new ReversibleKeyMap([ [['Hello', 'world'], 3], [['Second', 'value'], 5] ]);

Set values

map.set("one", "two", 3);
map.set("four", "one", 5);
map.set("six", "seven", 8);
// Setters are chainable
map.set("nine", "ten", 11).set("twelve", "thirteen", 14);

Get values

map.get("two", "one"); // => 3
map.get("four", "one"); // => 5
map.get("six", "one"); // => undefined
// You can all values linked to one key
map.getAllFrom("one"); // => Map(2) {"two" => 3, "four" => 5}

Iteration

Iteration through .entries(), Symbol.iterator, .values(), .keysCouple() ensure that getting a value with those methods will not give you duplicates.

With .keys(), a call to .getAllFrom(key) within the loop will give you the same value twice.

/// Iterate through the map
const entries = Array.from(map.entries() /* map.entries() is a generator */);
// Using Symbol.iterator | .entries()
for (const [keys, value] of map) {
    // ["one", "two"], 3
    // ["one", "four"], 5
    // ["six", "seven"], 8
    // ["nine", "ten"], 11
    // ["twelve", "thirteen"], 14
}

// Iterate through values only
for (const value of map.values()) {
    // 3
    // 5
    // 8
    // 11
    // 14
}

// Iterate through keys couples only
for (const keys of map.keysCouples()) {
    // ["one", "two"]
    // ["one", "four"]
    // ["six", "seven"]
    // ["nine", "ten"]
    // ["twelve", "thirteen"]
    const value = map.get(...keys);
    // use value or keys...
}

// Iterate through keys
for (const key of map.keys()) {
    // one
    // two
    // four
    // six
    // seven
    // nine
    // ten
    // twelve
    // thirteen
    const linked_maps = map.getAllFrom(key);
}

Appartenance

map.hasCouple("one", "two"); // => true
map.hasCouple("six", "one"); // => false
// Test if one key exists
map.has("one"); // => true
map.has("hello"); // => false

Delete values

/// Delete values
map.delete("one", "two"); // Deletions are also chainable.
// Delete all values linked to one key
map.deleteAllFrom("one");

console.log(...map); // [["six", "seven"], 8]  [["nine", "ten"], 11]  [["twelve", "thirteen"], 14]

Full reference: ReversibleKeyMap

Map using a couple of keys to reference a value. You can get a map of values using ONE key, and a value using TWO keys.

Key order is not important.

Index

Constructors

Properties

Accessors

Methods


Constructors

constructor

new ReversibleKeyMap(it?: Iterable<[[K1, K2], T]>): ReversibleKeyMap

new ReversibleKeyMap(it?: Iterable<[[K2, K1], T]>): ReversibleKeyMap

Creates an instance of ReversibleKeyMap. You can give an iterable providing a tuple containaing a tuple of two keys and one value to initialize the instance.

Parameters:

| Name | Type | | ------ | ------ | | Optional it | Iterable<[[K1, K2], T]> |

Returns: ReversibleKeyMap


Properties

<Protected> map

● map: Map<K1 | K2, Map<K1 | K2, T>> = new Map


Accessors

__@toStringTag

get __@toStringTag(): string

Returns: string


count

get count(): number

Get map size using the VALUES. Warning, it have O(n) complexity.

readonly:

Returns: number


size

get size(): number

Get map size using the KEYS. Warning, it count EVERY key. It means that one set("a", "b", val) will produce a result of 2. 0(1) complexity.

readonly:

Returns: number


Methods

__@iterator

__@iterator(): IterableIterator<[[K1 | K2, K1 | K2], T]>

Returns: IterableIterator<[[K1 | K2, K1 | K2], T]>


clear

clear(): void

Delete all existing values in current instance.

Returns: void


delete

delete(k1: K1, k2: K2): this

delete(k1: K2, k2: K1): this

Delete a double key pair.

Parameters:

| Name | Type | Description | | ------ | ------ | ------ | | k1 | K1 | - | | k2 | K2 | - |

Returns: this


deleteAllFrom

deleteAllFrom(k1: K1 | K2): this

Delete everythinh linked to key k1.

Parameters:

| Name | Type | Description | | ------ | ------ | ------ | | k1 | K1 | K2 | - |

Returns: this


entries

entries(): IterableIterator<[[K1 | K2, K1 | K2], T]>

Returns: IterableIterator<[[K1 | K2, K1 | K2], T]>


forEach

forEach<This>(callback: function, thisArg?: This): void

Apply function callback for each [key1, key2] => value pair in ReversibleKeyMap object. Insertion order / key order is not guaranteed. If thisArg is provided, it will be used as this value for each callback call.

template: This

Type parameters:

This

Parameters:

| Name | Type | Description | | ------ | ------ | ------ | | callback | function | - | | Optional thisArg | This |

Returns: void


get

get(k1: K1, k2: K2): T

get(k1: K2, k2: K1): T

Get one value according to a couple of keys. Order of keys does NOT have any influence.

Parameters:

| Name | Type | Description | | ------ | ------ | ------ | | k1 | K1 | - | | k2 | K2 |

Returns: T


getAllFrom

getAllFrom(k1: K1): Map<K2, T>

getAllFrom(k1: K2): Map<K1, T>

Give all keys and values mapped to k1. Results are returned wrapped into a Map object.

Parameters:

| Name | Type | Description | | ------ | ------ | ------ | | k1 | K1 | - |

Returns: Map<K2, T>


has

has(k1: K1 | K2): boolean

Return true if key k1 is present.

Parameters:

| Name | Type | Description | | ------ | ------ | ------ | | k1 | K1 | K2 | - |

Returns: boolean


hasCouple

hasCouple(k1: K1, k2: K2): boolean

hasCouple(k1: K2, k2: K1): boolean

Return true if couple [k1, k2] is present.

Parameters:

| Name | Type | Description | | ------ | ------ | ------ | | k1 | K1 | - | | k2 | K2 | - |

Returns: boolean


keys

keys(): IterableIterator<K1 | K2>

Get all keys existing in double key map. Do NOT return key couples, see keysCouples method.

Returns: IterableIterator<K1 | K2>


keysCouples

keysCouples(): IterableIterator<[K1 | K2, K1 | K2]>

Get existing key couples in double key maps.

Returns: IterableIterator<[K1 | K2, K1 | K2]>


set

set(k1: K1, k2: K2, value: T): this

set(k1: K2, k2: K1, value: T): this

Set one value according to two keys.

Parameters:

| Name | Type | Description | | ------ | ------ | ------ | | k1 | K1 | - | | k2 | K2 | - | | value | T | - |

Returns: this Current instance.


values

values(): IterableIterator<T>

Get each value inside map.

Returns: IterableIterator<T>