0.1.0 • Published 5 years ago
bs-reselect v0.1.0
bs-reselect
Low-level bindings to reselect for BuckleScript.
bs-reselect
is intended as a direct binding to the JS API. It is purely a way to use the reselect library, and since the module comprises entirely of external declarations, there is no runtime/code size overhead from using these bindings.
Example
type item = {
name: string,
value: float,
};
type shop = {
taxPercent: float,
items: array(item),
};
type state = {shop};
let shopItemsSelector = (. state) => state.shop.items;
let taxPercentSelector = (. state) => state.shop.taxPercent;
let subtotalSelector =
Reselect.create1(shopItemsSelector, (. items) =>
Array.fold_left((acc, item) => acc +. item.value, 0.0, items)
);
let taxSelector =
Reselect.create2(
subtotalSelector, taxPercentSelector, (. subtotal, taxPercent) =>
subtotal *. (taxPercent /. 100.0)
);
type total = {total: float};
let totalSelector =
Reselect.create2(subtotalSelector, taxSelector, (. subtotal, tax) =>
{total: subtotal +. tax}
);
let exampleState = {
shop: {
taxPercent: 8.0,
items: [|{name: "apple", value: 1.20}, {name: "orange", value: 0.95}|],
},
};
Js.log(subtotalSelector(. exampleState)); // 2.15
Js.log(taxSelector(. exampleState)); // 0.172
Js.log(totalSelector(. exampleState)); // { total: 2.322 }
Installation
npm install --save bs-reselect
Then add bs-reselect
to bs-dependencies
in your bsconfig.json
:
{
...
"bs-dependencies": ["bs-reselect"]
}
Usage
See usage examples in readme.re
. The source is a single file that corresponds almost directly to the typescript bindngs.
Changes
0.1.0
- Initial release with bindings for up to 9 createSelector parameters
0.1.0
5 years ago