Skip to content

Latest commit

 

History

History
301 lines (204 loc) · 6.34 KB

README.md

File metadata and controls

301 lines (204 loc) · 6.34 KB

specter-js

Javascript implementation of clojure's specter library

Operations

  • select
  • selectOne
  • transform
  • setval

Navigators

ALL

The ALL navigator navigates to every element in an array or key/value pair in an object. ALL can transform to NONE to remove elements.

s.select(s.ALL, [1, 2, 3]);
// [1, 2, 3]

s.select([s.ALL, s.ALL], [[1], [2], [3]]);
// [1, 2, 3]

s.select(s.ALL, { a: 1, b: 2 });
// [["a", 1], ["b", 2]]

s.transform(s.ALL, increment, [1, 2, 3]);
// [2, 3, 4]

s.setval(s.ALL, s.NONE, [1, 2, 3]);
// []

s.setval(s.ALL, s.NONE, { a: 1 });
// {}

s.setval(s.ALL, ["b", 2], { a: 1 });
// { b: 2 }

MAP_VALS

The MAP_VALS navigator navigates to every value in an object. MAP_VALS can transform to NONE to remove entries.

s.select(s.MAP_VALS, { a: 1, b: 2 });
// [1, 2]

s.transform(s.MAP_VALS, increment, { a: 1, b: 2 });
// { a: 2, b: 3 }

s.setval(s.MAP_VALS, s.NONE, { a: 1, b: 2 });
// {}

MAP_KEYS

The MAP_KEYS navigator navigates to every key in an object. MAP_KEYS can transform to NONE to remove entries.

s.select(s.MAP_KEYS, { a: 1, b: 2 });
// ["a", "b"]

s.transform(s.MAP_KEYS, v => v + "x", { a: 1, b: 2 });
// { ax: 1, bx: 2 }

s.setval(s.MAP_KEYS, s.NONE, { a: 1, b: 2 });
// {}

FIRST

The FIRST navigator navigates to the first element in an array. Stops navigation if the array is empty. FIRST can transform to NONE to remove the first element.

s.select(s.FIRST, [1, 2, 3]);
// [1]

s.transform(s.FIRST, increment, [1, 2, 3]);
// [2, 2, 3]

s.setval(s.FIRST, s.NONE, [1, 2, 3]);
// [2, 3]

LAST

The LAST navigator navigates to the last element in an array. Stops navigation if the array is empty. LAST can transform to NONE to remove the last element.

s.select(s.LAST, [1, 2, 3]);
// [3]

s.transform(s.LAST, increment, [1, 2, 3]);
// [1, 2, 4]

s.setval(s.LAST, s.NONE, [1, 2, 3]);
// [1, 2]

BEGINNING

The BEGINNING navigator navigates to the empty array before the beginning of an array. BEGINNING can be used to add elements to the front of an array.

s.select(s.BEGINNING, [1, 2]);
// []

s.setval(s.BEGINNING, ["a", "b"], [1, 2]);
// ["a", "b", 1, 2]

END

The END navigator navigates to the empty array after the end of an array. END can be used to add elements to the back of an array.

s.select(s.END, [1, 2]);
// []

s.setval(s.END, ["a", "b"], [1, 2]);
// [1, 2, "a", "b"]

BEFORE_ELEM

The BEFORE_ELEM navigator navigates to the void element before the beginning of an array. BEFORE_ELEM can be used to add an element to the front of an array.

s.select(s.BEFORE_ELEM, [1, 2]);
// [s.NONE]

s.setval(s.BEFORE_ELEM, "a", [1, 2]);
// ["a", 1, 2]

s.setval(s.BEFORE_ELEM, s.NONE, [1, 2]);
// [1, 2]

AFTER_ELEM

The AFTER_ELEM navigator navigates to the void element after the end of an array. AFTER_ELEM can be used to add an element to the back of an array.

s.select(s.AFTER_ELEM, [1, 2]);
// [s.NONE]

s.setval(s.AFTER_ELEM, "a", [1, 2]);
// [1, 2, "a"]

s.setval(s.AFTER_ELEM, s.NONE, [1, 2]);
// [1, 2]

key

The key navigator navigates to the value of a specific key in an object. key can transform to NONE to remove the entry.

Strings are interpreted as key navigators.

s.select(s.key("a"), { a: 1 });
// [1]

s.select("a", { a: 1 });
// [1]

s.select(["a", "b"], { a: { b: 2 } });
// [2]

s.setval("a", s.NONE, { a: 1, b: 2 });
// { b: 2 }

s.setval(["a", "b"], 5, { a: { b: 2 } });
// { a: { b: 5 } }

nth

The nth navigator navigates to the value of a specific index in an array. nth can transform to NONE to remove the element.

Numbers are interpreted as nth navigators.

s.select(s.nth(1), [0, 2, 4]);
// [2];

s.select(1, [0, 2, 4]);
// [2];

s.select([1, 0], [[1, 2], [3, 4]]);
// [3];

s.setval(1, s.NONE, [1, 2, 3]);
// [1, 3]

s.transform(1, increment, [1, 2, 3]);
// [1, 3, 3]

pred

The pred navigator evaluates a predicate function with the current navigation. Navigation stops when the predicate returns false.

Functions are interpreted as pred navigators.

s.select(s.pred(isEven), 2);
// [2]

s.select(isEven, 2);
// [2]

s.select(isEven, 1);
// []

s.select([s.ALL, isEven], [1, 2, 3, 4]);
// [2, 4]

s.setval([s.ALL, isEven], s.NONE, [1, 2, 3, 4]);
// [1, 3]

s.transform([s.ALL, isEven], increment, [1, 2, 3, 4]);
// [1, 3, 3, 5]

beforeIndex

The beforeIndex navigator navigates to the void element before a specified index in an array. beforeIndex can be used to insert elements in an array at arbitrary positions.

s.select(s.beforeIndex(1), [1, 2, 3]);
// [s.NONE]

s.setval(s.beforeIndex(1), "a", [1, 2, 3]);
// [1, "a", 2, 3]

s.setval(s.beforeIndex(1), s.NONE, [1, 2, 3]);
// [1, 2, 3]

s.setval(s.beforeIndex(5), "a", [1, 2, 3]);
// [1, 2, 3, "a"]

Examples

Increment all values in object of objects:

const data = { a: { aa: 1 }, b: { ba: 1, bb: 2 } };
s.transform([s.MAP_VALS, s.MAP_VALS], v => v + 1, data);
// { a: { aa: 2 }, b: { ba: 2, bb: 3 } };

Increment all even values for "a" keys in a array of objects:

const data = [{ a: 1 }, { a: 2 }, { a: 4 }, { a: 3 }];
s.transform([s.ALL, "a", v => v % 2 === 0], v => v + 1, data);
// [{ a: 1 }, { a: 3 }, { a: 5 }, { a: 3 }];

Select all numbers divisible by 3 from a array of arrays:

const data = [[1, 2, 3, 4], [], [5, 3, 2, 18], [2, 4, 6], [12]];
s.select([s.ALL, s.ALL, v => v % 3 === 0]);
// [3, 3, 18, 6, 12]

Increment the last odd number in a array:

const data = [2, 1, 3, 6, 9, 4, 8];
s.transform([s.filterer(v => v % 2 !== 0), s.LAST], v => v + 1, data);
// [2, 1, 3, 6, 10, 4, 8]

Remove undefined from a nested array:

const data = { a: [1, undefined, 2], b: [undefined, 1] };
s.setval([s.MAP_VALS, s.ALL, v => v === undefined], s.NONE, data);
// { a: [1, 2], b: [1] }

Remove key value pair from a nested object:

const data = { a: { b: { c: 1 } } };
s.setval(["a", "b", "c"], s.NONE, data);
// {a: {b: {}}}

Concatenate array to every nested array of arrays:

const data = [[1], [1, 2], ["c"]];
s.setval([s.ALL, s.END], ["a", "b"], data);
// [[1, "a", "b"], [1, 2, "a", "b"], ["c", "a", "b"]];