Javascript implementation of clojure's specter library
- select
- selectOne
- transform
- setval
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 }
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 });
// {}
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 });
// {}
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]
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]
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]
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"]
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]
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]
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 } }
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]
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]
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"]
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"]];