Skip to content

Commit

Permalink
🐛 fix: fix compatible with subscribeWithSelector middleware (#89)
Browse files Browse the repository at this point in the history
* 🐛 fix: fix compatible with subscribe api

* ✅ test: upgrade @testing-library/jest-dom
  • Loading branch information
arvinxx committed Nov 24, 2023
1 parent 44551aa commit b11cb36
Show file tree
Hide file tree
Showing 4 changed files with 25 additions and 20 deletions.
8 changes: 6 additions & 2 deletions docs/guide/demos/Redo/store.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { proEditorMiddleware, ProEditorOptions } from '@ant-design/pro-editor';
import { create, StateCreator } from 'zustand';
import { devtools } from 'zustand/middleware';
import { devtools, subscribeWithSelector } from 'zustand/middleware';

interface Store {
tabs: string;
Expand Down Expand Up @@ -49,5 +49,9 @@ const proEditorOptions: ProEditorOptions<Store, ProEditorStore> = {
};

export const useStore = create<Store>()(
devtools(proEditorMiddleware(createStore, proEditorOptions), { name: storeName }),
devtools(proEditorMiddleware(subscribeWithSelector(createStore), proEditorOptions), {
name: storeName,
}),
);

useStore.subscribe((s) => s.data, console.log);
14 changes: 6 additions & 8 deletions docs/guide/redo-undo.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,14 +19,13 @@ order: 2
1. 外层包裹 ProEditorProvider,传入相应的 zustand store

```tsx | pure
import { ProEditorProvider, ProEditorStoreUpdater } from '@ant-design/pro-editor';
import { ProEditorProvider } from '@ant-design/pro-editor';

import { useStore } from './store';


export default () => {
return (
<ProEditorProvider store=[useStore]>
<ProEditorProvider store={[useStore]}>
<App />
</ProEditorProvider>
);
Expand Down Expand Up @@ -56,15 +55,14 @@ export const useStore = create<Store>()(
多个 Store 使用的方式:

```tsx | pure
import { ProEditorProvider, ProEditorStoreUpdater } from '@ant-design/pro-editor';
import { ProEditorProvider } from '@ant-design/pro-editor';

import { useAStore } from './storeA';
import { useBStore } from './storeB';


export default () => {
return (
<ProEditorProvider store=[useAStore,useBStore]>
<ProEditorProvider store={[useAStore, useBStore]}>
<App />
</ProEditorProvider>
);
Expand All @@ -75,11 +73,11 @@ export default () => {

```tsx | pure
<div>
<ProEditorProvider store=[cStore]>
<ProEditorProvider store={[cStore]}>
<A />
</ProEditorProvider>

<ProEditorProvider store=[dStore]>
<ProEditorProvider store={[dStore]}>
<B />
</ProEditorProvider>
</div>
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@
},
"devDependencies": {
"@emotion/jest": "^11.11.0",
"@testing-library/jest-dom": "^6.1.2",
"@testing-library/jest-dom": "^6.1.3",
"@testing-library/react": "^13.4.0",
"@testing-library/user-event": "^14.5.1",
"@types/color": "^3.0.4",
Expand Down
21 changes: 12 additions & 9 deletions src/ProEditor/middleware/pro-editor/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,17 @@ const middleware: ProEditorImpl = (storeInitializer, options) => (set, get, api)
{ trigger: 'proEditorMiddleware', ...action },
);
};

/**
* handle setState function
*/
const savedSetState = api.setState;
api.setState = (partial, replace, action) => {
savedSetState(partial, replace, action);

updateInProEditor((action as any) || {});
};

/*
* Capture the initial state so that we can initialize the pro editor store to the
* same values as the initial values of the Zustand store.
Expand All @@ -47,15 +58,7 @@ const middleware: ProEditorImpl = (storeInitializer, options) => (set, get, api)
updateInProEditor((action as any) || {});
},
get,
{
...api,
// Create a new setState function as we did with set.
setState: (partial, replace, action) => {
api.setState(partial, replace, action);

updateInProEditor((action as any) || {});
},
},
api,
);

// Return the initial state to create or the next middleware.
Expand Down

0 comments on commit b11cb36

Please sign in to comment.