ok-selector

2.0.1 • Public • Published

ok-selector

A small library for plucking values out of objects, both native and immutable.

native

Given the following state:

const state = {
  level1: {
    level2: {
      level3: {
        value: 'yes'
      }
    }
  },
  array: [
    {id: 1, value: 2},
    {id: 2, value: 4},
    {id: 3, value: 6},
    {id: 4, value: 8},
  ]
};

These tests hold true

it('should support dot.strings', () => {
  expect(read(state, 'level1.level2.level3.value')).to.equal('yes');
  expect(read(state, 'level1.level2.level3')).to.deep.equal({value: 'yes'});
  expect(read(state, 'array')).to.deep.equal([
    {id: 1, value: 2},
    {id: 2, value: 4},
    {id: 3, value: 6},
    {id: 4, value: 8},
  ]);
});
 
it('should support addressing arrays by id', () => {
  expect(read(state, 'array:3')).to.deep.equal({id: 3, value: 6});
  expect(read(state, 'array:3.value')).to.deep.equal(6);
});
 
it('should support plucking all values from an array', () => {
  expect(read(state, 'array*.value')).to.deep.equal([2, 4, 6, 8]);
});

Package Sidebar

Install

npm i ok-selector

Weekly Downloads

2

Version

2.0.1

License

BSD-2-Clause

Last publish

Collaborators

  • distributedlife