getorset-anything
Version:
Gets a value from a Map/Obj or sets an initial value when not found and returns that. TypeScript supported.
90 lines (59 loc) • 2.6 kB
Markdown
# Get or Set Anything 🐊
<a href="https://www.npmjs.com/package/getorset-anything"><img src="https://img.shields.io/npm/v/getorset-anything.svg" alt="Total Downloads"></a>
<a href="https://www.npmjs.com/package/getorset-anything"><img src="https://img.shields.io/npm/dw/getorset-anything.svg" alt="Latest Stable Version"></a>
```
npm i getorset-anything
```
Get a Map/Obj value, or if it didn't exist yet set it and return that. Fully **TypeScript** supported! A simple & small integration.
## Motivation
I created this package because I always hated doing this over and over again:
```ts
const map = new Map<string, number[]>()
const id = 'abc'
let arr = map.get(id)
if (arr === undefined) {
arr = []
map.set(id, arr)
}
arr.push(100)
```
So that is exactly what `getorset-anything` does for you! 💯
`getorset-anything` has performance in mind. It won't do a `.has()` check, like other libraries do, when it found the value it will immediately return it.
## Usage
Maps
```ts
import { mapGetOrSet } from 'getorset-anything'
const map = new Map<string, number[]>()
const arr = mapGetOrSet(map, 'abc', (): number[] => [])
arr.push(100) // OK!
```
Objects
```ts
import { objGetOrSet } from 'getorset-anything'
const obj: Record<string, number[]> = {}
const arr = objGetOrSet(obj, 'abc', (): number[] => [])
arr.push(100) // OK!
```
## TypeScript Support
You don't have to do anything extra for TypeScript! It comes with awesome type support.
```ts
import { mapGetOrSet } from 'getorset-anything'
const map = new Map<string, number[]>()
const arr = mapGetOrSet(map, 'abc', () => []) // OK!
const arr2 = mapGetOrSet(map, 'abc', () => ({})) // NG! ⛔️
arr.push(100) // OK!
arr.push('100') // NG! ⛔️
```
## Meet the family (more tiny utils with TS support)
- [is-what 🙉](https://github.com/mesqueeb/is-what)
- [is-where 🙈](https://github.com/mesqueeb/is-where)
- [merge-anything 🥡](https://github.com/mesqueeb/merge-anything)
- [check-anything 👁](https://github.com/mesqueeb/check-anything)
- [remove-anything ✂️](https://github.com/mesqueeb/remove-anything)
- [getorset-anything 🐊](https://github.com/mesqueeb/getorset-anything)
- [map-anything 🗺](https://github.com/mesqueeb/map-anything)
- [filter-anything ⚔️](https://github.com/mesqueeb/filter-anything)
- [copy-anything 🎭](https://github.com/mesqueeb/copy-anything)
- [case-anything 🐫](https://github.com/mesqueeb/case-anything)
- [flatten-anything 🏏](https://github.com/mesqueeb/flatten-anything)
- [nestify-anything 🧅](https://github.com/mesqueeb/nestify-anything)