From af2f57059a4440c4204f15a4b9f5b81beb477546 Mon Sep 17 00:00:00 2001 From: Tom <214997474@qq.com> Date: Mon, 12 Sep 2022 09:02:36 +0800 Subject: [PATCH 1/2] chore: can't reuse reactive --- .../redox/src/core/__tests__/reducer.test.ts | 18 ++++++++++++++++++ packages/redox/src/core/model.ts | 6 +----- .../src/reactivity/__tests__/producer.test.ts | 4 ++++ 3 files changed, 23 insertions(+), 5 deletions(-) diff --git a/packages/redox/src/core/__tests__/reducer.test.ts b/packages/redox/src/core/__tests__/reducer.test.ts index 25afb2c..8d21d65 100644 --- a/packages/redox/src/core/__tests__/reducer.test.ts +++ b/packages/redox/src/core/__tests__/reducer.test.ts @@ -98,6 +98,24 @@ describe('defineModel/reducers', () => { }) describe('immer', () => { + it('should not update with do nothing', () => { + const count = defineModel({ + name: 'count', + state: { value: 0 }, + reducers: { + add(_state) {}, + }, + }) + + const store = redoxStore.getModel(count) + + const $state = store.$state + + store.add() + + expect(store.$state).toBe($state) + }) + it('should work with a basic literal', () => { const count = defineModel({ name: 'count', diff --git a/packages/redox/src/core/model.ts b/packages/redox/src/core/model.ts index 5f2d1fd..1f77256 100644 --- a/packages/redox/src/core/model.ts +++ b/packages/redox/src/core/model.ts @@ -216,11 +216,7 @@ export class ModelInternal { if (state === undefined) return reducer(state, action.payload) as IModel['state'] return produce( - isReactive(this.state) - ? this.state - : isObject(this.state) - ? reactive(this.state) - : this.state, + isObject(state) ? reactive(state) : state, (draft: any) => reducer!(draft, action.payload) as IModel['state'] ) } diff --git a/packages/redox/src/reactivity/__tests__/producer.test.ts b/packages/redox/src/reactivity/__tests__/producer.test.ts index 3f4a5a2..b1c67f9 100644 --- a/packages/redox/src/reactivity/__tests__/producer.test.ts +++ b/packages/redox/src/reactivity/__tests__/producer.test.ts @@ -1277,6 +1277,10 @@ describe(`reactivity/producer`, () => { expect(child.b).toBe(2) // changed expect(child.c).toBe(2) // added expect(child.d).toBeUndefined() // deleted + child.f = 2 + produce(reactive(child), (s) => { + console.log(s.f) + }) }) }) }) From 37e7127fa71cfa2953fb01a8932d198d8d0e4f8b Mon Sep 17 00:00:00 2001 From: Tom <214997474@qq.com> Date: Mon, 12 Sep 2022 09:07:35 +0800 Subject: [PATCH 2/2] chore: build error --- packages/redox/src/core/model.ts | 1 - packages/redox/src/reactivity/index.ts | 8 +------- 2 files changed, 1 insertion(+), 8 deletions(-) diff --git a/packages/redox/src/core/model.ts b/packages/redox/src/core/model.ts index 1f77256..6972a52 100644 --- a/packages/redox/src/core/model.ts +++ b/packages/redox/src/core/model.ts @@ -9,7 +9,6 @@ import { effectScope, EffectScope, onViewInvalidate, - isReactive, } from '../reactivity' import { AnyModel } from './defineModel' import { Views, Actions, Action, State, StateObject } from './modelOptions' diff --git a/packages/redox/src/reactivity/index.ts b/packages/redox/src/reactivity/index.ts index 0d1ebb2..5d82c96 100644 --- a/packages/redox/src/reactivity/index.ts +++ b/packages/redox/src/reactivity/index.ts @@ -1,10 +1,4 @@ -export { - toReactive, - toReadonly, - reactive, - readonly, - isReactive, -} from './reactive' +export { toReactive, toReadonly, reactive, readonly } from './reactive' export { View, view, ViewGetter, onViewInvalidate } from './view' export { ReactiveEffect } from './effect' export { EffectScope, effectScope } from './effectScope'