diff --git a/CHANGELOG.md b/CHANGELOG.md
index bbd5323..aa2efd0 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -4,9 +4,19 @@ All notable changes to this project will be documented in this file. Dates are d
Generated by [`auto-changelog`](https://github.com/CookPete/auto-changelog).
+#### [v0.3.4](https://github.com/valtiojs/valtio-history/compare/v0.3.3...v0.3.4)
+
+- fix: declare explicit return type for getNode [`#16`](https://github.com/valtiojs/valtio-history/pull/16)
+- ci: upgrade action versions [`79b1db9`](https://github.com/valtiojs/valtio-history/commit/79b1db99436fc3a0ef5deb1690d5bf7947d72d2c)
+- build: upgrade nx to latest [`db78d8e`](https://github.com/valtiojs/valtio-history/commit/db78d8ecbf179796d3cb03a950ce76b652d5e9df)
+- chore: remove migrations.json [`b8250b3`](https://github.com/valtiojs/valtio-history/commit/b8250b32f1255269e99bb40d01e3be0057601c61)
+
#### [v0.3.3](https://github.com/valtiojs/valtio-history/compare/v0.3.2...v0.3.3)
+> 29 April 2024
+
- fix: update history when a state property is set to undefined [`#14`](https://github.com/valtiojs/valtio-history/pull/14)
+- chore: release v0.3.3 [`21daf8f`](https://github.com/valtiojs/valtio-history/commit/21daf8f903599b765589e616b777278da3db2e01)
#### [v0.3.2](https://github.com/valtiojs/valtio-history/compare/v0.3.1...v0.3.2)
diff --git a/package.json b/package.json
index 2563503..57c206e 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "valtio-history",
- "version": "0.3.3",
+ "version": "0.3.4",
"license": "MIT",
"author": "Daishi Kato",
"repository": {
diff --git a/packages/history-utility/docs/modules.md b/packages/history-utility/docs/modules.md
index 8be5eb7..53c54f6 100644
--- a/packages/history-utility/docs/modules.md
+++ b/packages/history-utility/docs/modules.md
@@ -23,22 +23,22 @@
#### Type parameters
| Name |
-| :--- |
-| `T` |
+| :------ |
+| `T` |
#### Type declaration
-| Name | Type | Description |
-| :------ | :----------------------------------------------- | :-------------------------------------------------------------- |
-| `index` | `number` | the history index of the current snapshot |
-| `nodes` | [`HistoryNode`](modules.md#historynode)\<`T`\>[] | the nodes of the history for each change |
-| `wip` | `Snapshot`\<`T`\> \| typeof `EMPTY_WIP` | field for holding sandbox changes; used to avoid infinite loops |
+| Name | Type | Description |
+| :------ | :------ | :------ |
+| `index` | `number` | the history index of the current snapshot |
+| `nodes` | [`HistoryNode`](modules.md#historynode)\<`T`\>[] | the nodes of the history for each change |
+| `wip` | `Snapshot`\<`T`\> \| typeof `EMPTY_WIP` | field for holding sandbox changes; used to avoid infinite loops |
#### Defined in
-[packages/history-utility/src/index.ts:28](https://github.com/valtiojs/valtio-history/blob/ec38985/packages/history-utility/src/index.ts#L28)
+[packages/history-utility/src/index.ts:28](https://github.com/valtiojs/valtio-history/blob/44dcf22/packages/history-utility/src/index.ts#L28)
----
+___
### HistoryNode
@@ -47,22 +47,22 @@
#### Type parameters
| Name |
-| :--- |
-| `T` |
+| :------ |
+| `T` |
#### Type declaration
-| Name | Type | Description |
-| :----------- | :---------------- | :----------------------------------------------------------------------------------- |
-| `createdAt` | `Date` | The date when the node was created |
-| `snapshot` | `Snapshot`\<`T`\> | The snapshot being tracked |
-| `updatedAt?` | `Date` | The date when the node was updated. Will be undefined if the node was never updated. |
+| Name | Type | Description |
+| :------ | :------ | :------ |
+| `createdAt` | `Date` | The date when the node was created |
+| `snapshot` | `Snapshot`\<`T`\> | The snapshot being tracked |
+| `updatedAt?` | `Date` | The date when the node was updated. Will be undefined if the node was never updated. |
#### Defined in
-[packages/history-utility/src/index.ts:10](https://github.com/valtiojs/valtio-history/blob/ec38985/packages/history-utility/src/index.ts#L10)
+[packages/history-utility/src/index.ts:10](https://github.com/valtiojs/valtio-history/blob/44dcf22/packages/history-utility/src/index.ts#L10)
----
+___
### HistoryOptions
@@ -70,13 +70,13 @@
#### Type declaration
-| Name | Type | Description |
-| :--------------- | :-------- | :---------------------------------------------------------------- |
+| Name | Type | Description |
+| :------ | :------ | :------ |
| `skipSubscribe?` | `boolean` | determines if the internal subscribe behaviour should be skipped. |
#### Defined in
-[packages/history-utility/src/index.ts:45](https://github.com/valtiojs/valtio-history/blob/ec38985/packages/history-utility/src/index.ts#L45)
+[packages/history-utility/src/index.ts:45](https://github.com/valtiojs/valtio-history/blob/44dcf22/packages/history-utility/src/index.ts#L45)
## Functions
@@ -86,7 +86,6 @@
This creates a new proxy with history support (ProxyHistoryObject).
It includes following main properties:
-
- value: any value (does not have to be an object)
- history: an object holding the history of snapshots and other metadata
- history.index: the history index of the current snapshot
@@ -100,15 +99,15 @@ Notes:
#### Type parameters
| Name |
-| :--- |
-| `V` |
+| :------ |
+| `V` |
#### Parameters
-| Name | Type | Description |
-| :------------- | :--------------------------------------------------------- | :--------------------------------------------- |
-| `initialValue` | `V` | any value to be tracked |
-| `options?` | `boolean` \| [`HistoryOptions`](modules.md#historyoptions) | use to configure the proxyWithHistory utility. |
+| Name | Type | Description |
+| :------ | :------ | :------ |
+| `initialValue` | `V` | any value to be tracked |
+| `options?` | `boolean` \| [`HistoryOptions`](modules.md#historyoptions) | use to configure the proxyWithHistory utility. |
#### Returns
@@ -116,38 +115,38 @@ Notes:
proxyObject
-| Name | Type | Description |
-| :------------------------ | :-------------------------------------------------------------------------------------------------------------------- | :----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
-| `canRedo` | () => `boolean` | a function to return true if redo is available **`Deprecated`** **`See`** [https://github.com/valtiojs/valtio-history/issues/10](https://github.com/valtiojs/valtio-history/issues/10) |
-| `canUndo` | () => `boolean` | a function to return true if undo is available **`Deprecated`** **`See`** [https://github.com/valtiojs/valtio-history/issues/10](https://github.com/valtiojs/valtio-history/issues/10) |
-| `clone` | \(`value`: `T`) => `T` | utility to clone a snapshot |
-| `getCurrentChangeDate` | () => `undefined` \| `Date` | get the date when a node was entered into history. **`Deprecated`** **`See`** [https://github.com/valtiojs/valtio-history/issues/10](https://github.com/valtiojs/valtio-history/issues/10) |
-| `getNode` | (`index`: `number`) => `undefined` \| \{ `createdAt`: `Date` ; `snapshot`: `Snapshot`\<`V`\> ; `updatedAt?`: `Date` } | utility method to get a history node. The snapshot within this node is already cloned and will not affect the original value if updated. |
-| `goTo` | (`index`: `number`) => `void` | a function to go to a specific index in history |
-| `history` | [`History`](modules.md#history)\<`V`\> & `AsRef` | an object holding the history of snapshots and other metadata
- history.index: the history index to the current snapshot
- history.nodes: the nodes of the history for each change
- history.wip: field for holding sandbox changes; used to avoid infinite loops
|
-| `redo` | () => `void` | a function to go forward in history |
-| `remove` | (`index`: `number`) => `undefined` \| [`HistoryNode`](modules.md#historynode)\<`V`\> | The remove method is only invoked when there are more than one nodes and when a valid index is provided. If the current index is removed, An index greater than the current index will be preferred as the next value. |
-| `replace` | (`index`: `number`, `value`: `INTERNAL_Snapshot`\<`V`\>) => `void` | utility to replace a value in history. The history changes will not be affected, only the value to be replaced. If a base value is needed to operate on, the `getNode` utility can be used to retrieve a cloned historyNode.
Notes:
- No operations are done on the value provided to this utility.
- This is an advanced method, please ensure the value provided is a snapshot of the same type of the value being tracked.
|
-| `saveHistory` | () => `void` | a function to execute saving history when changes are made to `value` |
-| `shouldSaveHistory` | (`ops`: `Op`[]) => `boolean` | a function that returns true when the history should be updated |
-| `subscribe` | () => () => `void` | a function to subscribe to changes made to `value` |
-| `undo` | () => `void` | a function to go back in history |
-| `value` | `V` | any value to be tracked (does not have to be an object) |
-| `get currentChangeDate()` | `undefined` \| `Date` | - |
-| `get currentIndex()` | `number` | - |
-| `get historyNodeCount()` | `number` | - |
-| `get isRedoEnabled()` | `boolean` | - |
-| `get isUndoEnabled()` | `boolean` | - |
+| Name | Type | Description |
+| :------ | :------ | :------ |
+| `canRedo` | () => `boolean` | a function to return true if redo is available **`Deprecated`** **`See`** [https://github.com/valtiojs/valtio-history/issues/10](https://github.com/valtiojs/valtio-history/issues/10) |
+| `canUndo` | () => `boolean` | a function to return true if undo is available **`Deprecated`** **`See`** [https://github.com/valtiojs/valtio-history/issues/10](https://github.com/valtiojs/valtio-history/issues/10) |
+| `clone` | \(`value`: `T`) => `T` | utility to clone a snapshot |
+| `getCurrentChangeDate` | () => `undefined` \| `Date` | get the date when a node was entered into history. **`Deprecated`** **`See`** [https://github.com/valtiojs/valtio-history/issues/10](https://github.com/valtiojs/valtio-history/issues/10) |
+| `getNode` | (`index`: `number`) => `undefined` \| [`HistoryNode`](modules.md#historynode)\<`V`\> | utility method to get a history node. The snapshot within this node is already cloned and will not affect the original value if updated. |
+| `goTo` | (`index`: `number`) => `void` | a function to go to a specific index in history |
+| `history` | [`History`](modules.md#history)\<`V`\> & `AsRef` | an object holding the history of snapshots and other metadata
- history.index: the history index to the current snapshot
- history.nodes: the nodes of the history for each change
- history.wip: field for holding sandbox changes; used to avoid infinite loops
|
+| `redo` | () => `void` | a function to go forward in history |
+| `remove` | (`index`: `number`) => `undefined` \| [`HistoryNode`](modules.md#historynode)\<`V`\> | The remove method is only invoked when there are more than one nodes and when a valid index is provided. If the current index is removed, An index greater than the current index will be preferred as the next value. |
+| `replace` | (`index`: `number`, `value`: `INTERNAL_Snapshot`\<`V`\>) => `void` | utility to replace a value in history. The history changes will not be affected, only the value to be replaced. If a base value is needed to operate on, the `getNode` utility can be used to retrieve a cloned historyNode.
Notes:
- No operations are done on the value provided to this utility.
- This is an advanced method, please ensure the value provided is a snapshot of the same type of the value being tracked.
|
+| `saveHistory` | () => `void` | a function to execute saving history when changes are made to `value` |
+| `shouldSaveHistory` | (`ops`: `Op`[]) => `boolean` | a function that returns true when the history should be updated |
+| `subscribe` | () => () => `void` | a function to subscribe to changes made to `value` |
+| `undo` | () => `void` | a function to go back in history |
+| `value` | `V` | any value to be tracked (does not have to be an object) |
+| `get currentChangeDate()` | `undefined` \| `Date` | - |
+| `get currentIndex()` | `number` | - |
+| `get historyNodeCount()` | `number` | - |
+| `get isRedoEnabled()` | `boolean` | - |
+| `get isUndoEnabled()` | `boolean` | - |
**`Example`**
```ts
-import { proxyWithHistory } from 'valtio-history';
+import { proxyWithHistory } from 'valtio-history'
const state = proxyWithHistory({
count: 1,
-});
+})
```
#### Defined in
-[packages/history-utility/src/index.ts:122](https://github.com/valtiojs/valtio-history/blob/ec38985/packages/history-utility/src/index.ts#L122)
+[packages/history-utility/src/index.ts:122](https://github.com/valtiojs/valtio-history/blob/44dcf22/packages/history-utility/src/index.ts#L122)
diff --git a/packages/history-utility/package.json b/packages/history-utility/package.json
index 055451d..8c2a177 100644
--- a/packages/history-utility/package.json
+++ b/packages/history-utility/package.json
@@ -1,6 +1,6 @@
{
"name": "valtio-history",
- "version": "0.3.3",
+ "version": "0.3.4",
"author": "Daishi Kato",
"repository": {
"type": "git",