repos / starfx

a micro-mvc framework for react apps
git clone https://github.com/neurosnap/starfx.git

commit
0ba8393
parent
4d4f2d8
author
Eric Bower
date
2023-09-16 22:44:36 -0400 EDT
refactor(redux): use signal for middleware
2 files changed,  +24, -22
M redux/fx.ts
+2, -4
 1@@ -1,5 +1,5 @@
 2-import { Action, Operation, Signal } from "../deps.ts";
 3-import { createContext, createSignal, each, spawn } from "../deps.ts";
 4+import type { Action, Operation, Signal } from "../deps.ts";
 5+import { createContext, each, spawn } from "../deps.ts";
 6 import { call } from "../fx/mod.ts";
 7 import { ActionPattern, matcher } from "../matcher.ts";
 8 import type { ActionWPayload, AnyAction } from "../types.ts";
 9@@ -8,9 +8,7 @@ import type { StoreLike } from "./types.ts";
10 
11 export const ActionContext = createContext<Signal<Action, void>>(
12   "redux:action",
13-  createSignal<Action, void>(),
14 );
15-
16 export const StoreContext = createContext<StoreLike>("redux:store");
17 
18 export function emit({
M redux/middleware.ts
+22, -18
 1@@ -1,24 +1,28 @@
 2-import { BATCH, BatchAction, ReducersMapObject, Scope } from "../deps.ts";
 3-import { combineReducers, createScope, enableBatching } from "../deps.ts";
 4+import {
 5+  BATCH,
 6+  BatchAction,
 7+  combineReducers,
 8+  createScope,
 9+  createSignal,
10+  enableBatching,
11+  ReducersMapObject,
12+  Scope,
13+  Signal,
14+} from "../deps.ts";
15 import type { AnyAction } from "../types.ts";
16 import { ActionContext, emit, StoreContext } from "./fx.ts";
17 import { reducers as queryReducers } from "./query.ts";
18 import type { StoreLike } from "./types.ts";
19 
20-export function* send(action: AnyAction) {
21-  const signal = yield* ActionContext;
22-  if (action.type === BATCH) {
23-    const actions = action.payload as BatchAction[];
24-    emit({
25-      signal,
26-      action: actions,
27-    });
28-  } else {
29-    emit({
30-      signal,
31-      action,
32-    });
33+export function send(signal: Signal<AnyAction, void>, act: AnyAction) {
34+  let action: AnyAction | AnyAction[] = act;
35+  if (act.type === BATCH) {
36+    action = act.payload as BatchAction[];
37   }
38+  emit({
39+    signal,
40+    action,
41+  });
42 }
43 
44 export function createFxMiddleware(initScope?: Scope) {
45@@ -29,15 +33,15 @@ export function createFxMiddleware(initScope?: Scope) {
46     const tuple = createScope();
47     scope = tuple[0];
48   }
49+  const signal = createSignal<AnyAction, void>();
50 
51   function middleware<S = unknown>(store: StoreLike<S>) {
52     scope.set(StoreContext, store);
53+    scope.set(ActionContext, signal);
54 
55     return (next: (a: unknown) => unknown) => (action: unknown) => {
56       const result = next(action); // hit reducers
57-      scope.run(function* () {
58-        yield* send(action as AnyAction);
59-      });
60+      send(signal, action as AnyAction);
61       return result;
62     };
63   }