![require(esm) Backported to Node.js 20, Paving the Way for ESM-Only Packages](https://cdn.sanity.io/images/cgdhsj6q/production/be8ab80c8efa5907bc341c6fefe9aa20d239d890-1600x1097.png?w=400&fit=max&auto=format)
Security News
require(esm) Backported to Node.js 20, Paving the Way for ESM-Only Packages
require(esm) backported to Node.js 20, easing the transition to ESM-only packages and reducing complexity for developers as Node 18 nears end-of-life.
immutable-lens
Advanced tools
React.PureComponent
, connect()
...$ npm i -S immutable-lens
import {createLens} from 'immutable-lens'
type State = {
user: {
name: string
age: number
}
}
const lens = createLens<State>()
const userLens = lens.focusOn('user')
const nameLens = userLens.focusOn('name')
const state = {
user: {
name: 'Bob',
age: 18
}
}
const user = userLens.read(state) // {name: 'Bob', age: 18}
const name = nameLens.read(state) // 'Bob'
const state = {
user: {
name: 'Bob',
age: 18
}
}
const setNameToJohn =
// THE FOUR LINES BELOW ARE ALL EQUIVALENT
nameLens.setValue('John')
nameLens.update(currentName => 'John')
userLens.setFieldValues({name: 'John'})
userLens.updateFields({name: (currentName) => 'John'})
const updatedState = setNameToJohn(state) // {user: {name: 'John', age: 18}}
pipe()
type State = {
user: {
name: string
}
}
const state = {
user: {
name: 'Bob',
age: 18
}
}
const nameLens = createLens<State>()
.focusOn('user')
.focusOn('name')
const setNameToJohn = nameLens.setValue('John')
const uppercaseName = nameLens.update(name => name.toUpperCase())
const setNameToJOHN = pipe(
setNameToJohn,
uppercaseName
)
const updatedState = setNameToJOHN(state) // {user: {name: 'JOHN', age: 18}}
defaultTo()
to avoid undefined values when reading or updating optional typestype State = {
loggedUser?: {
name: string
age: number
}
}
const state = {
// optional loggedUser field is undefined
}
const nameLens = createLens<State>()
.focusOn('loggedUser')
.defaultTo({name: 'Guest', age: 0})
.focusOn('name')
const name = nameLens.read(state) // 'Guest'
const setNameToBob = nameLens.setValue('Bob')
const updatedState = setNameToBob(state) // {user: {name: 'Bob', age: 0}}
type Person = {
name: string
}
type State = {
friends: Person[]
}
const firstFriendLens: Lens<State, Person | undefined> = createLens<State>()
.focusOn('friends')
.focusIndex(0)
getPath()
FAQs
Type-safe Lens API for immutable updates in complex data structures
The npm package immutable-lens receives a total of 4 weekly downloads. As such, immutable-lens popularity was classified as not popular.
We found that immutable-lens demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
require(esm) backported to Node.js 20, easing the transition to ESM-only packages and reducing complexity for developers as Node 18 nears end-of-life.
Security News
PyPI now supports iOS and Android wheels, making it easier for Python developers to distribute mobile packages.
Security News
Create React App is officially deprecated due to React 19 issues and lack of maintenance—developers should switch to Vite or other modern alternatives.