mapz
TypeScript icon, indicating that this package has built-in type declarations

2.0.1 • Public • Published

mapz

Build Coverage Downloads Size

Functional map with sugar.

Contents

What is this?

This is a tiny package that, in combination with zwitch, helps with ASTs.

When should I use this?

You can use this package when you want to map one AST to another, or check an AST.

Install

This package is ESM only. In Node.js (version 14.14+, 16.0+), install with npm:

npm install mapz

In Deno with esm.sh:

import {mapz} from 'https://esm.sh/mapz@2'

In browsers with esm.sh:

<script type="module">
  import {mapz} from 'https://esm.sh/mapz@2?bundle'
</script>

Use

import {mapz} from 'mapz'

const map = mapz(fn, {key: 'children', gapless: true})

map({type: 'something', children: [1, 2, 3]}) // => ['Hi, 2', 'Hi, 3']

function fn(value) {
  return value > 1 ? 'Hi, ' + value + '.' : null
}

API

This package exports the identifier mapz. There is no default export.

mapz(fn[, options])

Functional map with sugar.

Wraps the supplied fn, which handles one value, so that it accepts multiple values, calling fn for each and returning all results.

If options is a string, it’s treated as {key: options}.

options.gapless

Whether to filter out null and undefined results (boolean, default: false).

options.key

If a key (string, optional) is given, and an object supplied to the wrapped fn, values at that object’s key field are mapped and the object, instead of the values, is given to fn as a last parameter. If a key is given and an array is passed to the wrapped fn, no value is given to fn as a last parameter.

Returns

See map(values) (Function).

map(values)

Call the bound fn for all values. If a key is bound, values can be an object. See options.key for more info.

Returns

Values returned by fn (Array<unknown>). If gapless is true, null orundefined results are not returned by map.

fn(value, parent?)

Handle one value. If key is set and an array is given, no parent is passed.

Returns

Any value (unknown).

Types

This package is fully typed with TypeScript. It exports the additional type Options.

Compatibility

This package is at least compatible with all maintained versions of Node.js. As of now, that is Node.js 14.14+ and 16.0+. It also works in Deno and modern browsers.

Related

  • zwitch — handle values based on a property

Security

This package is safe.

Contribute

Yes please! See How to Contribute to Open Source.

License

MIT © Titus Wormer

Versions

Current Tags

  • Version
    Downloads (Last 7 Days)
    • Tag
  • 2.0.1
    105
    • latest

Version History

Package Sidebar

Install

npm i mapz

Weekly Downloads

332

Version

2.0.1

License

MIT

Unpacked Size

11.8 kB

Total Files

5

Last publish

Collaborators

  • wooorm