rescript-clean-deep

Remove empty or nullable values from JavaScript objects

Usage no npm install needed!

<script type="module">
  import rescriptCleanDeep from 'https://cdn.skypack.dev/rescript-clean-deep';
</script>

README

rescript-clean-deep

NPM version Build Status

ReScript bindings for clean-deep, a library for removing empty or nullable values from javascript objects.

Getting started

yarn add rescript-clean-deep

Then add rescript-clean-deep as a dependency to bsconfig.json:

"bs-dependencies": [
+  "rescript-clean-deep"
]

Example

open RescriptCleanDeep;

let jsObject = [%bs.raw {|
{
  bar: {},
  baz: null,
  biz: 'baz',
  foo: '',
  net: [],
  nit: undefined,
  qux: {
    baz: 'boz',
    txi: ''
  }
}
|}];

let cleaned = CleanDeep.cleanDeep(jsObject, ());

Js.log(cleaned);
/* => { biz: 'baz', qux: { baz: 'boz' } } */

let cleanedKeepStrings = jsObject->CleanDeep.cleanDeep(~emptyStrings=false, ());

Js.log(cleanedKeepStrings);
/* => { biz: 'baz', foo: '', qux: { baz: 'boz', txi: '' } } */

let cleanedCustomValues = jsObject->CleanDeep.cleanDeep(~cleanValues=[|"baz"|], ());

Js.log(cleanedCustomValues);
/* => { qux: { baz: 'boz' } } */

See also example-project.

Contribute

If you find bugs or there are updates in clean-deep, feel free to open an issue or PR. If you are upgrading any dependencies, please use yarn so yarn.lock is updated.