Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/yarnaimo/lifts

⛵ LIghtweight Functional programming library for TypeScript
https://github.com/yarnaimo/lifts

functional-programming typescript

Last synced: 3 months ago
JSON representation

⛵ LIghtweight Functional programming library for TypeScript

Awesome Lists containing this project

README

        

# Lifts

**LI**ghtweight **F**unctional programming library for **T**ype**S**cript

## Install

```sh
yarn add lifts remeda
# or
npm i -S lifts remeda
```

## Usage

### Do

Shorthand for Immediately Invoked Function Expression

```ts
const date = new Date('2020-04-17')

const result: number | null = Do(() => {
// check date is valid
if (!isNaN(date)) {
return date.getDate()
} else {
return null
}
})
result // => 17

// equivalent to
const result = (() => {
if (!isNaN(date)) {
return date.getDate()
} else {
return null
}
})()
```

### Switch

Object-Style `switch`

```ts
const fn = (value: string) =>
Switch(value)(
{
a: () => 'String A',
b: () => 'String B',
},
() => null, // default value
)

fn('a') // => 'string A'
fn('b') // => 'string B'
fn('c') // => null (default value)
```

### Result

```ts
const parseDate = (dateStr: string): IResult => {
const date = new Date(dateStr)

// check date is valid
if (!isNaN(date)) {
return Result.ok(date)
} else {
return Result.err(new Error('Invalid Date'))
}
}

parseDate('2020-04-17')
// => { isOk: true, valueOrError: Date('2020-04-17') }

parseDate('foo')
// => { isOk: false, valueOrError: Error('Invalid Date') }
```

#### Result.switch

```ts
const result = parseDate('2020-04-17')

Result.switch(result)({
ok: (value: Date) => {
// called if result is Ok
return value.getDate()
},
err: (error: Error) => {
// called if result is Err
return null
},
})
// => 17
```

```ts
const result = parseDate('foo')

Result.switch(result)({
ok: (value) => {
return value.getDate()
},
err: (error) => {
return null
},
})
// => null
```

#### Result.wrap

Wraps Error with `Result.err()` if error caught, else wraps value with `Result.ok()`.

```ts
const result = Result.wrap(() => {
if (condition) {
return true
} else {
throw new Error()
}
})
```

### MapAsync

### Pipe