Skip to content

Commit

Permalink
fix behavior with strict mode (#7)
Browse files Browse the repository at this point in the history
* fix behavior with strict mode

* remove unused

* only support v2

* remove unused type
  • Loading branch information
dai-shi authored Jan 11, 2024
1 parent c3128e4 commit 154f399
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 39 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
# Change Log

## [Unreleased]
### Added
- fix behavior with strict mode #7

## [0.3.0] - 2023-03-03
### Added
Expand Down
8 changes: 6 additions & 2 deletions examples/01_typescript/src/index.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,13 @@
import React from 'react';
import React, { StrictMode } from 'react';
import { createRoot } from 'react-dom/client';

import App from './App';

const ele = document.getElementById('app');
if (ele) {
createRoot(ele).render(<App />);
createRoot(ele).render(
<StrictMode>
<App />
</StrictMode>,
);
}
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,6 @@
"webpack-dev-server": "^4.11.1"
},
"peerDependencies": {
"jotai": ">=1.11.0"
"jotai": ">=2.0.0"
}
}
55 changes: 19 additions & 36 deletions src/atomWithCache.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { atom } from 'jotai/vanilla';
import type { Atom, Getter } from 'jotai/vanilla';
import type { Atom, WritableAtom } from 'jotai/vanilla';

type AnyAtomValue = unknown;
type AnyAtom = Atom<AnyAtomValue>;
Expand All @@ -24,32 +24,25 @@ export function atomWithCache<Value>(
const is = options?.areEqual || Object.is;
// this cache is common across Provider components
const cache: [CreatedAt, AnyAtomValue, Map<AnyAtom, AnyAtomValue>][] = [];
const writeGetterAtom = atom<[Getter] | null>(null);
if (process.env.NODE_ENV !== 'production') {
writeGetterAtom.debugPrivate = true;
}

const baseAtom = atom(
(get, opts) => {
const writeGetter = get(writeGetterAtom)?.[0];
if (writeGetter) {
const index = cache.findIndex((item) =>
Array.from(item[2]).every(([a, v]) => {
const vv = writeGetter(a);
if (vv instanceof Promise) {
return false;
}
return is(v, vv);
}),
);
if (index >= 0) {
const item = cache[index] as (typeof cache)[number];
if (options?.shouldRemove?.(...item)) {
cache.splice(index, 1);
} else {
item[2].forEach((_, a) => get(a)); // touch atoms
return item[1] as Value;
const baseAtom: WritableAtom<Value, [AnyAtom], AnyAtomValue> = atom(
(get, { setSelf: writeGetter, ...opts }) => {
const index = cache.findIndex((item) =>
Array.from(item[2]).every(([a, v]) => {
const vv = writeGetter(a);
if (vv instanceof Promise) {
return false;
}
return is(v, vv);
}),
);
if (index >= 0) {
const item = cache[index] as (typeof cache)[number];
if (options?.shouldRemove?.(...item)) {
cache.splice(index, 1);
} else {
item[2].forEach((_, a) => get(a)); // touch atoms
return item[1] as Value;
}
}
const map = new Map<AnyAtom, AnyAtomValue>();
Expand All @@ -64,23 +57,13 @@ export function atomWithCache<Value>(
}
return value;
},
(get, set, isInit) => {
if (isInit) {
set(writeGetterAtom, [get]);
} else {
set(writeGetterAtom, null);
}
},
(get, _set, anAtom: AnyAtom) => get(anAtom), // HACK HACK HACK
);

if (process.env.NODE_ENV !== 'production') {
baseAtom.debugPrivate = true;
}

baseAtom.onMount = (init) => {
init(true);
return () => init(false);
};
const derivedAtom = atom((get) => get(baseAtom));
return derivedAtom;
}

0 comments on commit 154f399

Please sign in to comment.