You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					70 lines
				
				2.3 KiB
			
		
		
			
		
	
	
					70 lines
				
				2.3 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								# FP Guide
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								**date-fns** v2.x provides [functional programming](https://en.wikipedia.org/wiki/Functional_programming) (FP)
							 | 
						||
| 
								 | 
							
								friendly functions, like those in [lodash](https://github.com/lodash/lodash/wiki/FP-Guide),
							 | 
						||
| 
								 | 
							
								that support [currying](https://en.wikipedia.org/wiki/Currying).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Table of Contents
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- [Usage](#usage)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- [Using Function Composition](#using-function-composition)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Usage
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								FP functions are provided via `'date-fns/fp'` submodule.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Functions with options (`format`, `parse`, etc.) have two FP counterparts:
							 | 
						||
| 
								 | 
							
								one that has the options object as its first argument and one that hasn't.
							 | 
						||
| 
								 | 
							
								The name of the former has `WithOptions` added to the end of its name.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								In **date-fns'** FP functions, the order of arguments is reversed.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```javascript
							 | 
						||
| 
								 | 
							
								import { addYears, formatWithOptions } from 'date-fns/fp'
							 | 
						||
| 
								 | 
							
								import { eo } from 'date-fns/locale'
							 | 
						||
| 
								 | 
							
								import toUpper from 'lodash/fp/toUpper' // 'date-fns/fp' is compatible with 'lodash/fp'!
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// If FP function has not received enough arguments, it returns another function
							 | 
						||
| 
								 | 
							
								const addFiveYears = addYears(5)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// Several arguments can be curried at once
							 | 
						||
| 
								 | 
							
								const dateToString = formatWithOptions({ locale: eo }, 'd MMMM yyyy')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const dates = [
							 | 
						||
| 
								 | 
							
								  new Date(2017, 0 /* Jan */, 1),
							 | 
						||
| 
								 | 
							
								  new Date(2017, 1 /* Feb */, 11),
							 | 
						||
| 
								 | 
							
								  new Date(2017, 6 /* Jul */, 2)
							 | 
						||
| 
								 | 
							
								]
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const formattedDates = dates.map(addFiveYears).map(dateToString).map(toUpper)
							 | 
						||
| 
								 | 
							
								//=> ['1 JANUARO 2022', '11 FEBRUARO 2022', '2 JULIO 2022']
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Using Function Composition
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The main advantage of FP functions is support of functional-style
							 | 
						||
| 
								 | 
							
								[function composing](https://medium.com/making-internets/why-using-chain-is-a-mistake-9bc1f80d51ba).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								In the example above, you can compose `addFiveYears`, `dateToString` and `toUpper` into a single function:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```javascript
							 | 
						||
| 
								 | 
							
								const formattedDates = dates.map((date) => toUpper(dateToString(addFiveYears(date))))
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Or you can use `compose` function provided by [lodash](https://lodash.com) to do the same in more idiomatic way:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```javascript
							 | 
						||
| 
								 | 
							
								import compose from 'lodash/fp/compose'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const formattedDates = dates.map(compose(toUpper, dateToString, addFiveYears))
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Or if you prefer natural direction of composing (as opposed to the computationally correct order),
							 | 
						||
| 
								 | 
							
								you can use lodash' `flow` instead:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```javascript
							 | 
						||
| 
								 | 
							
								import flow from 'lodash/fp/flow'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const formattedDates = dates.map(flow(addFiveYears, dateToString, toUpper))
							 | 
						||
| 
								 | 
							
								```
							 |