@quantform/core 0.3.254 → 0.3.259
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/adapter/backtester/backtester-cursor.spec.js.map +1 -1
- package/dist/adapter/backtester/backtester-streamer.spec.js.map +1 -1
- package/dist/session/session.d.ts +6 -9
- package/dist/session/session.js +10 -24
- package/dist/session/session.js.map +1 -1
- package/dist/store/event/store-balance.event.d.ts +5 -6
- package/dist/store/event/store-balance.event.js +8 -8
- package/dist/store/event/store-balance.event.js.map +1 -1
- package/dist/store/event/store-candle.event.d.ts +2 -1
- package/dist/store/event/store-candle.event.js +25 -19
- package/dist/store/event/store-candle.event.js.map +1 -1
- package/dist/store/event/store-candle.event.spec.js +7 -8
- package/dist/store/event/store-candle.event.spec.js.map +1 -1
- package/dist/store/event/store-instrument.event.d.ts +6 -6
- package/dist/store/event/store-instrument.event.js +7 -7
- package/dist/store/event/store-instrument.event.js.map +1 -1
- package/dist/store/event/store-order.event.d.ts +9 -9
- package/dist/store/event/store-order.event.js +26 -47
- package/dist/store/event/store-order.event.js.map +1 -1
- package/dist/store/event/store-order.event.spec.js +7 -7
- package/dist/store/event/store-order.event.spec.js.map +1 -1
- package/dist/store/event/store-orderbook.event.d.ts +2 -3
- package/dist/store/event/store-orderbook.event.js +2 -2
- package/dist/store/event/store-orderbook.event.js.map +1 -1
- package/dist/store/event/store-position.event.d.ts +3 -3
- package/dist/store/event/store-position.event.js +6 -5
- package/dist/store/event/store-position.event.js.map +1 -1
- package/dist/store/event/store-trade.event.d.ts +2 -3
- package/dist/store/event/store-trade.event.js +2 -2
- package/dist/store/event/store-trade.event.js.map +1 -1
- package/dist/store/event/store-trade.event.spec.js +16 -17
- package/dist/store/event/store-trade.event.spec.js.map +1 -1
- package/dist/store/store.d.ts +23 -20
- package/dist/store/store.js +29 -28
- package/dist/store/store.js.map +1 -1
- package/dist/store/store.state.d.ts +6 -7
- package/dist/store/store.state.js +1 -6
- package/dist/store/store.state.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/adapter/backtester/backtester-cursor.spec.ts +2 -2
- package/src/adapter/backtester/backtester-streamer.spec.ts +0 -1
- package/src/session/session.ts +21 -56
- package/src/store/event/store-balance.event.ts +25 -9
- package/src/store/event/store-candle.event.spec.ts +8 -10
- package/src/store/event/store-candle.event.ts +44 -30
- package/src/store/event/store-instrument.event.ts +12 -7
- package/src/store/event/store-order.event.spec.ts +8 -8
- package/src/store/event/store-order.event.ts +56 -54
- package/src/store/event/store-orderbook.event.ts +7 -3
- package/src/store/event/store-position.event.ts +15 -7
- package/src/store/event/store-trade.event.spec.ts +18 -20
- package/src/store/event/store-trade.event.ts +7 -3
- package/src/store/store.state.ts +9 -14
- package/src/store/store.ts +33 -31
|
@@ -2,7 +2,7 @@ import { event } from '../../shared/topic';
|
|
|
2
2
|
import { timestamp } from '../../shared';
|
|
3
3
|
import { InstrumentSelector } from '../../domain/instrument';
|
|
4
4
|
import { Orderbook } from '../../domain/orderbook';
|
|
5
|
-
import { State } from '../store.state';
|
|
5
|
+
import { State, StateChangeTracker } from '../store.state';
|
|
6
6
|
import { StoreEvent } from './store.event';
|
|
7
7
|
|
|
8
8
|
@event
|
|
@@ -19,7 +19,11 @@ export class OrderbookPatchEvent implements StoreEvent {
|
|
|
19
19
|
) {}
|
|
20
20
|
}
|
|
21
21
|
|
|
22
|
-
export function OrderbookPatchEventHandler(
|
|
22
|
+
export function OrderbookPatchEventHandler(
|
|
23
|
+
event: OrderbookPatchEvent,
|
|
24
|
+
state: State,
|
|
25
|
+
changes: StateChangeTracker
|
|
26
|
+
) {
|
|
23
27
|
const instrumentKey = event.instrument.toString();
|
|
24
28
|
|
|
25
29
|
if (!(instrumentKey in state.subscription.instrument)) {
|
|
@@ -62,5 +66,5 @@ export function OrderbookPatchEventHandler(event: OrderbookPatchEvent, state: St
|
|
|
62
66
|
}
|
|
63
67
|
}
|
|
64
68
|
|
|
65
|
-
|
|
69
|
+
changes.commit(orderbook);
|
|
66
70
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { event } from '../../shared/topic';
|
|
2
2
|
import { timestamp } from '../../shared';
|
|
3
3
|
import { Position, Instrument, PositionMode } from '../../domain';
|
|
4
|
-
import { State } from '../store.state';
|
|
4
|
+
import { State, StateChangeTracker } from '../store.state';
|
|
5
5
|
import { StoreEvent } from './store.event';
|
|
6
6
|
|
|
7
7
|
@event
|
|
@@ -11,7 +11,11 @@ export class PositionLoadEvent implements StoreEvent {
|
|
|
11
11
|
constructor(readonly position: Position, readonly timestamp: timestamp) {}
|
|
12
12
|
}
|
|
13
13
|
|
|
14
|
-
export function PositionLoadEventHandler(
|
|
14
|
+
export function PositionLoadEventHandler(
|
|
15
|
+
event: PositionLoadEvent,
|
|
16
|
+
state: State,
|
|
17
|
+
changes: StateChangeTracker
|
|
18
|
+
) {
|
|
15
19
|
if (
|
|
16
20
|
event.position.instrument.toString()! in state.subscription.instrument ||
|
|
17
21
|
event.position.size == 0
|
|
@@ -50,7 +54,11 @@ export class PositionPatchEvent implements StoreEvent {
|
|
|
50
54
|
) {}
|
|
51
55
|
}
|
|
52
56
|
|
|
53
|
-
export function PositionPatchEventHandler(
|
|
57
|
+
export function PositionPatchEventHandler(
|
|
58
|
+
event: PositionPatchEvent,
|
|
59
|
+
state: State,
|
|
60
|
+
changes: StateChangeTracker
|
|
61
|
+
) {
|
|
54
62
|
if (!(event.instrument.toString() in state.subscription.instrument)) {
|
|
55
63
|
return;
|
|
56
64
|
}
|
|
@@ -74,10 +82,9 @@ export function PositionPatchEventHandler(event: PositionPatchEvent, state: Stat
|
|
|
74
82
|
position.calculatePnL(rate);
|
|
75
83
|
}
|
|
76
84
|
|
|
77
|
-
|
|
85
|
+
changes.commit(position);
|
|
86
|
+
changes.commit(balance);
|
|
78
87
|
}
|
|
79
|
-
|
|
80
|
-
return;
|
|
81
88
|
}
|
|
82
89
|
|
|
83
90
|
if (!position) {
|
|
@@ -97,5 +104,6 @@ export function PositionPatchEventHandler(event: PositionPatchEvent, state: Stat
|
|
|
97
104
|
position.calculatePnL(rate);
|
|
98
105
|
}
|
|
99
106
|
|
|
100
|
-
|
|
107
|
+
changes.commit(position);
|
|
108
|
+
changes.commit(balance);
|
|
101
109
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Asset, Instrument } from '../../domain';
|
|
2
|
-
import { TradePatchEvent
|
|
3
|
-
import { State } from '../store.state';
|
|
2
|
+
import { TradePatchEvent } from '.';
|
|
4
3
|
import { now } from '../../shared';
|
|
4
|
+
import { Store } from '..';
|
|
5
5
|
|
|
6
6
|
const instrument = new Instrument(
|
|
7
7
|
new Asset('btc', 'binance', 8),
|
|
@@ -12,49 +12,47 @@ const instrument = new Instrument(
|
|
|
12
12
|
describe('trade patch event tests', () => {
|
|
13
13
|
test('should create a new trade object and patch a store', () => {
|
|
14
14
|
const timestamp = now();
|
|
15
|
-
const
|
|
15
|
+
const store = new Store();
|
|
16
16
|
|
|
17
|
-
|
|
18
|
-
|
|
17
|
+
store.snapshot.universe.instrument[instrument.toString()] = instrument;
|
|
18
|
+
store.snapshot.subscription.instrument[instrument.toString()] = instrument;
|
|
19
19
|
|
|
20
|
-
|
|
20
|
+
store.dispatch(new TradePatchEvent(instrument, 1000, 0.1, timestamp));
|
|
21
21
|
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
const trade = state.trade[instrument.toString()];
|
|
22
|
+
const trade = store.snapshot.trade[instrument.toString()];
|
|
25
23
|
|
|
26
24
|
expect(trade.timestamp).toEqual(timestamp);
|
|
27
25
|
expect(trade.instrument.toString()).toEqual(trade.instrument.toString());
|
|
28
26
|
expect(trade.rate).toEqual(1000);
|
|
29
27
|
expect(trade.quantity).toEqual(0.1);
|
|
30
|
-
expect(
|
|
28
|
+
expect(store.snapshot.timestamp).toEqual(timestamp);
|
|
31
29
|
});
|
|
32
30
|
|
|
33
31
|
test('should use the existing instance of trade when patching a store', () => {
|
|
34
|
-
const
|
|
32
|
+
const store = new Store();
|
|
35
33
|
|
|
36
|
-
|
|
37
|
-
|
|
34
|
+
store.snapshot.universe.instrument[instrument.toString()] = instrument;
|
|
35
|
+
store.snapshot.subscription.instrument[instrument.toString()] = instrument;
|
|
38
36
|
|
|
39
|
-
|
|
37
|
+
store.dispatch(new TradePatchEvent(instrument, 1000, 0.1, now()));
|
|
40
38
|
|
|
41
39
|
const timestamp = now();
|
|
42
|
-
const trade =
|
|
40
|
+
const trade = store.snapshot.trade[instrument.toString()];
|
|
43
41
|
|
|
44
|
-
|
|
42
|
+
store.dispatch(new TradePatchEvent(instrument, 2000, 0.2, now()));
|
|
45
43
|
|
|
46
44
|
expect(trade.timestamp).toEqual(timestamp);
|
|
47
45
|
expect(trade.instrument.toString()).toEqual(instrument.toString());
|
|
48
46
|
expect(trade.rate).toEqual(2000);
|
|
49
47
|
expect(trade.quantity).toEqual(0.2);
|
|
50
|
-
expect(
|
|
48
|
+
expect(store.snapshot.timestamp).toEqual(timestamp);
|
|
51
49
|
});
|
|
52
50
|
|
|
53
51
|
test('should throw exception when patching unsubscribed instrument', () => {
|
|
54
|
-
const
|
|
55
|
-
const event = new TradePatchEvent(instrument, 1000, 0.1, now());
|
|
52
|
+
const store = new Store();
|
|
56
53
|
|
|
57
|
-
|
|
54
|
+
const fn = () => {
|
|
55
|
+
store.dispatch(new TradePatchEvent(instrument, 1000, 0.1, now()));
|
|
58
56
|
};
|
|
59
57
|
|
|
60
58
|
expect(fn).toThrow(Error);
|
|
@@ -2,7 +2,7 @@ import { event } from '../../shared/topic';
|
|
|
2
2
|
import { timestamp } from '../../shared';
|
|
3
3
|
import { Trade } from '../../domain';
|
|
4
4
|
import { InstrumentSelector } from '../../domain/instrument';
|
|
5
|
-
import { State } from '../store.state';
|
|
5
|
+
import { State, StateChangeTracker } from '../store.state';
|
|
6
6
|
import { StoreEvent } from './store.event';
|
|
7
7
|
|
|
8
8
|
/**
|
|
@@ -24,7 +24,11 @@ export class TradePatchEvent implements StoreEvent {
|
|
|
24
24
|
* Patches a store with specific event @see TradePatchEvent
|
|
25
25
|
* If there is no specific @see Trade in store, it will create a new one.
|
|
26
26
|
*/
|
|
27
|
-
export function TradePatchEventHandler(
|
|
27
|
+
export function TradePatchEventHandler(
|
|
28
|
+
event: TradePatchEvent,
|
|
29
|
+
state: State,
|
|
30
|
+
changes: StateChangeTracker
|
|
31
|
+
) {
|
|
28
32
|
const instrumentKey = event.instrument.toString();
|
|
29
33
|
|
|
30
34
|
if (!(instrumentKey in state.subscription.instrument)) {
|
|
@@ -44,5 +48,5 @@ export function TradePatchEventHandler(event: TradePatchEvent, state: State) {
|
|
|
44
48
|
trade.rate = trade.instrument.quote.fixed(event.rate);
|
|
45
49
|
trade.quantity = trade.instrument.base.fixed(event.quantity);
|
|
46
50
|
|
|
47
|
-
|
|
51
|
+
changes.commit(trade);
|
|
48
52
|
}
|
package/src/store/store.state.ts
CHANGED
|
@@ -7,13 +7,19 @@ import {
|
|
|
7
7
|
Asset,
|
|
8
8
|
Trade,
|
|
9
9
|
AssetSelector,
|
|
10
|
-
InstrumentSelector
|
|
10
|
+
InstrumentSelector,
|
|
11
|
+
Component
|
|
11
12
|
} from '../domain';
|
|
12
13
|
|
|
14
|
+
export interface StateChangeTracker {
|
|
15
|
+
commit(component: Component);
|
|
16
|
+
commitPendingChanges();
|
|
17
|
+
}
|
|
18
|
+
|
|
13
19
|
export class State {
|
|
14
20
|
timestamp: timestamp;
|
|
15
21
|
|
|
16
|
-
//
|
|
22
|
+
// available trading assets and instruments
|
|
17
23
|
universe: {
|
|
18
24
|
asset: Record<string, Asset>;
|
|
19
25
|
instrument: Record<string, Instrument>;
|
|
@@ -33,16 +39,5 @@ export class State {
|
|
|
33
39
|
trade: Record<string, Trade> = {};
|
|
34
40
|
orderbook: Record<string, Orderbook> = {};
|
|
35
41
|
balance: Record<string, Balance> = {};
|
|
36
|
-
|
|
37
|
-
order: {
|
|
38
|
-
pending: Record<string, Order>;
|
|
39
|
-
filled: Record<string, Order>;
|
|
40
|
-
canceled: Record<string, Order>;
|
|
41
|
-
rejected: Record<string, Order>;
|
|
42
|
-
} = {
|
|
43
|
-
pending: {},
|
|
44
|
-
filled: {},
|
|
45
|
-
canceled: {},
|
|
46
|
-
rejected: {}
|
|
47
|
-
};
|
|
42
|
+
order: Record<string, Order> = {};
|
|
48
43
|
}
|
package/src/store/store.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { BehaviorSubject, Observable, Subject } from 'rxjs';
|
|
2
|
-
import { State } from './store.state';
|
|
2
|
+
import { State, StateChangeTracker } from './store.state';
|
|
3
3
|
import { Component } from '../domain';
|
|
4
4
|
import { Set } from 'typescript-collections';
|
|
5
5
|
import { StoreEvent } from './event/store.event';
|
|
@@ -44,7 +44,8 @@ import {
|
|
|
44
44
|
PositionPatchEventHandler
|
|
45
45
|
} from './event';
|
|
46
46
|
|
|
47
|
-
export class Store extends Topic<StoreEvent, any> {
|
|
47
|
+
export class Store extends Topic<StoreEvent, any> implements StateChangeTracker {
|
|
48
|
+
private readonly pendingChanges = new Set<Component>();
|
|
48
49
|
private readonly changes = new Subject<Component>();
|
|
49
50
|
private readonly state = new BehaviorSubject<State>(new State());
|
|
50
51
|
|
|
@@ -61,19 +62,20 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
61
62
|
}
|
|
62
63
|
|
|
63
64
|
dispatch(...events: StoreEvent[]) {
|
|
64
|
-
const notifyComponentsChanged = new Set<Component>();
|
|
65
|
-
|
|
66
65
|
for (const event of events) {
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
if (Array.isArray(componentOrComponents)) {
|
|
70
|
-
componentOrComponents.forEach(it => notifyComponentsChanged.add(it));
|
|
71
|
-
} else {
|
|
72
|
-
notifyComponentsChanged.add(componentOrComponents);
|
|
73
|
-
}
|
|
66
|
+
super.dispatch(event, {});
|
|
74
67
|
}
|
|
75
68
|
|
|
76
|
-
|
|
69
|
+
this.commitPendingChanges();
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
commit(component: Component) {
|
|
73
|
+
this.pendingChanges.add(component);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
commitPendingChanges() {
|
|
77
|
+
this.pendingChanges.forEach(it => this.changes.next(it));
|
|
78
|
+
this.pendingChanges.clear();
|
|
77
79
|
}
|
|
78
80
|
|
|
79
81
|
dispose() {
|
|
@@ -86,7 +88,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
86
88
|
*/
|
|
87
89
|
@handler(InstrumentPatchEvent)
|
|
88
90
|
onInstrumentPatch(event: InstrumentPatchEvent) {
|
|
89
|
-
return InstrumentPatchEventHandler(event, this.snapshot);
|
|
91
|
+
return InstrumentPatchEventHandler(event, this.snapshot, this);
|
|
90
92
|
}
|
|
91
93
|
|
|
92
94
|
/**
|
|
@@ -94,7 +96,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
94
96
|
*/
|
|
95
97
|
@handler(InstrumentSubscriptionEvent)
|
|
96
98
|
onInstrumentSubscription(event: InstrumentSubscriptionEvent) {
|
|
97
|
-
return InstrumentSubscriptionEventHandler(event, this.snapshot);
|
|
99
|
+
return InstrumentSubscriptionEventHandler(event, this.snapshot, this);
|
|
98
100
|
}
|
|
99
101
|
|
|
100
102
|
/**
|
|
@@ -102,7 +104,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
102
104
|
*/
|
|
103
105
|
@handler(BalancePatchEvent)
|
|
104
106
|
onBalancePatch(event: BalancePatchEvent) {
|
|
105
|
-
return BalancePatchEventHandler(event, this.snapshot);
|
|
107
|
+
return BalancePatchEventHandler(event, this.snapshot, this);
|
|
106
108
|
}
|
|
107
109
|
|
|
108
110
|
/**
|
|
@@ -110,7 +112,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
110
112
|
*/
|
|
111
113
|
@handler(BalanceTransactEvent)
|
|
112
114
|
onBalanceTransact(event: BalanceTransactEvent) {
|
|
113
|
-
return BalanceTransactEventHandler(event, this.snapshot);
|
|
115
|
+
return BalanceTransactEventHandler(event, this.snapshot, this);
|
|
114
116
|
}
|
|
115
117
|
|
|
116
118
|
/**
|
|
@@ -118,7 +120,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
118
120
|
*/
|
|
119
121
|
@handler(BalanceFreezEvent)
|
|
120
122
|
onBalanceFreez(event: BalanceFreezEvent) {
|
|
121
|
-
return BalanceFreezEventHandler(event, this.snapshot);
|
|
123
|
+
return BalanceFreezEventHandler(event, this.snapshot, this);
|
|
122
124
|
}
|
|
123
125
|
|
|
124
126
|
/**
|
|
@@ -126,7 +128,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
126
128
|
*/
|
|
127
129
|
@handler(BalanceUnfreezEvent)
|
|
128
130
|
onBalanceUnfreez(event: BalanceUnfreezEvent) {
|
|
129
|
-
return BalanceUnfreezEventHandler(event, this.snapshot);
|
|
131
|
+
return BalanceUnfreezEventHandler(event, this.snapshot, this);
|
|
130
132
|
}
|
|
131
133
|
|
|
132
134
|
/**
|
|
@@ -134,7 +136,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
134
136
|
*/
|
|
135
137
|
@handler(OrderLoadEvent)
|
|
136
138
|
onOrderLoad(event: OrderLoadEvent) {
|
|
137
|
-
return OrderLoadEventHandler(event, this.snapshot);
|
|
139
|
+
return OrderLoadEventHandler(event, this.snapshot, this);
|
|
138
140
|
}
|
|
139
141
|
|
|
140
142
|
/**
|
|
@@ -142,7 +144,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
142
144
|
*/
|
|
143
145
|
@handler(OrderNewEvent)
|
|
144
146
|
onOrderNew(event: OrderNewEvent) {
|
|
145
|
-
return OrderNewEventHandler(event, this.snapshot);
|
|
147
|
+
return OrderNewEventHandler(event, this.snapshot, this);
|
|
146
148
|
}
|
|
147
149
|
|
|
148
150
|
/**
|
|
@@ -150,7 +152,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
150
152
|
*/
|
|
151
153
|
@handler(OrderPendingEvent)
|
|
152
154
|
onOrderPending(event: OrderPendingEvent) {
|
|
153
|
-
return OrderPendingEventHandler(event, this.snapshot);
|
|
155
|
+
return OrderPendingEventHandler(event, this.snapshot, this);
|
|
154
156
|
}
|
|
155
157
|
|
|
156
158
|
/**
|
|
@@ -158,7 +160,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
158
160
|
*/
|
|
159
161
|
@handler(OrderFilledEvent)
|
|
160
162
|
onOrderFilled(event: OrderFilledEvent) {
|
|
161
|
-
return OrderFilledEventHandler(event, this.snapshot);
|
|
163
|
+
return OrderFilledEventHandler(event, this.snapshot, this);
|
|
162
164
|
}
|
|
163
165
|
|
|
164
166
|
/**
|
|
@@ -166,7 +168,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
166
168
|
*/
|
|
167
169
|
@handler(OrderCancelingEvent)
|
|
168
170
|
onOrderCanceling(event: OrderCancelingEvent) {
|
|
169
|
-
return OrderCancelingEventHandler(event, this.snapshot);
|
|
171
|
+
return OrderCancelingEventHandler(event, this.snapshot, this);
|
|
170
172
|
}
|
|
171
173
|
|
|
172
174
|
/**
|
|
@@ -174,7 +176,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
174
176
|
*/
|
|
175
177
|
@handler(OrderCanceledEvent)
|
|
176
178
|
onOrderCanceled(event: OrderCanceledEvent) {
|
|
177
|
-
return OrderCanceledEventHandler(event, this.snapshot);
|
|
179
|
+
return OrderCanceledEventHandler(event, this.snapshot, this);
|
|
178
180
|
}
|
|
179
181
|
|
|
180
182
|
/**
|
|
@@ -182,7 +184,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
182
184
|
*/
|
|
183
185
|
@handler(OrderCancelFailedEvent)
|
|
184
186
|
onOrderCancelFailed(event: OrderCancelFailedEvent) {
|
|
185
|
-
return OrderCancelFailedEventHandler(event, this.snapshot);
|
|
187
|
+
return OrderCancelFailedEventHandler(event, this.snapshot, this);
|
|
186
188
|
}
|
|
187
189
|
|
|
188
190
|
/**
|
|
@@ -190,7 +192,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
190
192
|
*/
|
|
191
193
|
@handler(OrderRejectedEvent)
|
|
192
194
|
onOrderRejected(event: OrderRejectedEvent) {
|
|
193
|
-
return OrderRejectedEventHandler(event, this.snapshot);
|
|
195
|
+
return OrderRejectedEventHandler(event, this.snapshot, this);
|
|
194
196
|
}
|
|
195
197
|
|
|
196
198
|
/**
|
|
@@ -198,7 +200,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
198
200
|
*/
|
|
199
201
|
@handler(OrderbookPatchEvent)
|
|
200
202
|
onOrderbookPatch(event: OrderbookPatchEvent) {
|
|
201
|
-
return OrderbookPatchEventHandler(event, this.snapshot);
|
|
203
|
+
return OrderbookPatchEventHandler(event, this.snapshot, this);
|
|
202
204
|
}
|
|
203
205
|
|
|
204
206
|
/**
|
|
@@ -206,7 +208,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
206
208
|
*/
|
|
207
209
|
@handler(PositionLoadEvent)
|
|
208
210
|
onPositionLoad(event: PositionLoadEvent) {
|
|
209
|
-
return PositionLoadEventHandler(event, this.snapshot);
|
|
211
|
+
return PositionLoadEventHandler(event, this.snapshot, this);
|
|
210
212
|
}
|
|
211
213
|
|
|
212
214
|
/**
|
|
@@ -214,7 +216,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
214
216
|
*/
|
|
215
217
|
@handler(PositionPatchEvent)
|
|
216
218
|
onPositionPatch(event: PositionPatchEvent) {
|
|
217
|
-
return PositionPatchEventHandler(event, this.snapshot);
|
|
219
|
+
return PositionPatchEventHandler(event, this.snapshot, this);
|
|
218
220
|
}
|
|
219
221
|
|
|
220
222
|
/**
|
|
@@ -222,7 +224,7 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
222
224
|
*/
|
|
223
225
|
@handler(TradePatchEvent)
|
|
224
226
|
onTradePatch(event: TradePatchEvent) {
|
|
225
|
-
return TradePatchEventHandler(event, this.snapshot);
|
|
227
|
+
return TradePatchEventHandler(event, this.snapshot, this);
|
|
226
228
|
}
|
|
227
229
|
|
|
228
230
|
/**
|
|
@@ -230,6 +232,6 @@ export class Store extends Topic<StoreEvent, any> {
|
|
|
230
232
|
*/
|
|
231
233
|
@handler(CandleEvent)
|
|
232
234
|
onCandle(event: CandleEvent) {
|
|
233
|
-
return CandleEventHandler(event, this.snapshot);
|
|
235
|
+
return CandleEventHandler(event, this.snapshot, this);
|
|
234
236
|
}
|
|
235
237
|
}
|