@quantform/core 0.5.13 → 0.5.23
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/dist/adapter/adapter-aggregate.d.ts +8 -5
- package/dist/adapter/adapter-aggregate.js +18 -20
- package/dist/adapter/adapter-aggregate.js.map +1 -1
- package/dist/adapter/adapter.d.ts +20 -32
- package/dist/adapter/adapter.js +8 -43
- package/dist/adapter/adapter.js.map +1 -1
- package/dist/adapter/backtester/backtester-adapter.d.ts +11 -9
- package/dist/adapter/backtester/backtester-adapter.js +17 -16
- package/dist/adapter/backtester/backtester-adapter.js.map +1 -1
- package/dist/{tests → adapter/backtester}/backtester-adapter.spec.d.ts +0 -0
- package/dist/adapter/backtester/backtester-adapter.spec.js +83 -0
- package/dist/adapter/backtester/backtester-adapter.spec.js.map +1 -0
- package/dist/adapter/backtester/backtester-cursor.d.ts +3 -4
- package/dist/adapter/backtester/backtester-cursor.js +2 -1
- package/dist/adapter/backtester/backtester-cursor.js.map +1 -1
- package/dist/adapter/backtester/backtester-cursor.spec.js +19 -18
- package/dist/adapter/backtester/backtester-cursor.spec.js.map +1 -1
- package/dist/adapter/backtester/backtester-streamer.d.ts +3 -1
- package/dist/adapter/backtester/backtester-streamer.js +25 -14
- package/dist/adapter/backtester/backtester-streamer.js.map +1 -1
- package/dist/adapter/backtester/backtester-streamer.spec.js +17 -16
- package/dist/adapter/backtester/backtester-streamer.spec.js.map +1 -1
- package/dist/adapter/error.d.ts +2 -0
- package/dist/adapter/error.js +12 -0
- package/dist/adapter/error.js.map +1 -0
- package/dist/adapter/paper/engine/paper-engine.d.ts +11 -0
- package/dist/adapter/paper/engine/paper-engine.js +104 -0
- package/dist/adapter/paper/engine/paper-engine.js.map +1 -0
- package/dist/adapter/paper/{simulator/paper-spot-simulator.spec.d.ts → engine/paper-engine.spec.d.ts} +0 -0
- package/dist/adapter/paper/engine/paper-engine.spec.js +54 -0
- package/dist/adapter/paper/engine/paper-engine.spec.js.map +1 -0
- package/dist/adapter/paper/index.d.ts +1 -2
- package/dist/adapter/paper/index.js +1 -2
- package/dist/adapter/paper/index.js.map +1 -1
- package/dist/adapter/paper/paper-adapter.d.ts +10 -9
- package/dist/adapter/paper/paper-adapter.js +26 -23
- package/dist/adapter/paper/paper-adapter.js.map +1 -1
- package/dist/adapter/paper/paper-adapter.spec.js +36 -17
- package/dist/adapter/paper/paper-adapter.spec.js.map +1 -1
- package/dist/bootstrap.js +11 -10
- package/dist/bootstrap.js.map +1 -1
- package/dist/cli/pull.js +8 -11
- package/dist/cli/pull.js.map +1 -1
- package/dist/cli/test.js +5 -1
- package/dist/cli/test.js.map +1 -1
- package/dist/domain/asset.d.ts +10 -9
- package/dist/domain/asset.js +26 -23
- package/dist/domain/asset.js.map +1 -1
- package/dist/domain/asset.spec.js +36 -36
- package/dist/domain/asset.spec.js.map +1 -1
- package/dist/domain/balance.d.ts +13 -13
- package/dist/domain/balance.js +38 -32
- package/dist/domain/balance.js.map +1 -1
- package/dist/domain/balance.operator.d.ts +6 -0
- package/dist/domain/balance.operator.js +10 -0
- package/dist/domain/balance.operator.js.map +1 -0
- package/dist/{indicator/truerange.spec.d.ts → domain/balance.operator.spec.d.ts} +0 -0
- package/dist/domain/balance.operator.spec.js +23 -0
- package/dist/domain/balance.operator.spec.js.map +1 -0
- package/dist/domain/balance.spec.js +73 -12
- package/dist/domain/balance.spec.js.map +1 -1
- package/dist/domain/candle.d.ts +8 -23
- package/dist/domain/candle.js +6 -72
- package/dist/domain/candle.js.map +1 -1
- package/dist/domain/candle.operator.d.ts +10 -0
- package/dist/domain/candle.operator.js +64 -0
- package/dist/domain/candle.operator.js.map +1 -0
- package/dist/{shared/policy.spec.d.ts → domain/candle.operator.spec.d.ts} +0 -0
- package/dist/domain/candle.operator.spec.js +112 -0
- package/dist/domain/candle.operator.spec.js.map +1 -0
- package/dist/domain/candle.spec.js +16 -58
- package/dist/domain/candle.spec.js.map +1 -1
- package/dist/domain/commission.d.ts +12 -8
- package/dist/domain/commission.js +6 -6
- package/dist/domain/commission.js.map +1 -1
- package/dist/{shared/topic.spec.d.ts → domain/commission.spec.d.ts} +0 -0
- package/dist/domain/commission.spec.js +31 -0
- package/dist/domain/commission.spec.js.map +1 -0
- package/dist/domain/component.d.ts +1 -0
- package/dist/domain/error.d.ts +6 -0
- package/dist/domain/error.js +24 -0
- package/dist/domain/error.js.map +1 -0
- package/dist/domain/index.d.ts +8 -1
- package/dist/domain/index.js +8 -1
- package/dist/domain/index.js.map +1 -1
- package/dist/domain/instrument.d.ts +3 -2
- package/dist/domain/instrument.js +17 -9
- package/dist/domain/instrument.js.map +1 -1
- package/dist/domain/instrument.operator.d.ts +6 -0
- package/dist/domain/instrument.operator.js +14 -0
- package/dist/domain/instrument.operator.js.map +1 -0
- package/dist/{store/event/store-balance.event.spec.d.ts → domain/instrument.operator.spec.d.ts} +0 -0
- package/dist/domain/instrument.operator.spec.js +24 -0
- package/dist/domain/instrument.operator.spec.js.map +1 -0
- package/dist/domain/instrument.spec.js +22 -30
- package/dist/domain/instrument.spec.js.map +1 -1
- package/dist/domain/order.d.ts +16 -18
- package/dist/domain/order.js +39 -27
- package/dist/domain/order.js.map +1 -1
- package/dist/domain/order.operator.d.ts +7 -0
- package/dist/domain/order.operator.js +14 -0
- package/dist/domain/order.operator.js.map +1 -0
- package/dist/{store/event/store-candle.event.spec.d.ts → domain/order.operator.spec.d.ts} +0 -0
- package/dist/domain/order.operator.spec.js +65 -0
- package/dist/domain/order.operator.spec.js.map +1 -0
- package/dist/{store/event/store-instrument.event.spec.d.ts → domain/order.spec.d.ts} +0 -0
- package/dist/domain/order.spec.js +34 -0
- package/dist/domain/order.spec.js.map +1 -0
- package/dist/domain/orderbook.d.ts +19 -6
- package/dist/domain/orderbook.js +6 -4
- package/dist/domain/orderbook.js.map +1 -1
- package/dist/domain/orderbook.operator.d.ts +6 -0
- package/dist/domain/orderbook.operator.js +10 -0
- package/dist/domain/orderbook.operator.js.map +1 -0
- package/dist/{store/event/store-order.event.spec.d.ts → domain/orderbook.operator.spec.d.ts} +0 -0
- package/dist/domain/orderbook.operator.spec.js +22 -0
- package/dist/domain/orderbook.operator.spec.js.map +1 -0
- package/dist/{store/event/store-trade.event.spec.d.ts → domain/orderbook.spec.d.ts} +0 -0
- package/dist/domain/orderbook.spec.js +13 -0
- package/dist/domain/orderbook.spec.js.map +1 -0
- package/dist/domain/position.d.ts +9 -14
- package/dist/domain/position.js +9 -31
- package/dist/domain/position.js.map +1 -1
- package/dist/domain/position.operator.d.ts +11 -0
- package/dist/domain/position.operator.js +38 -0
- package/dist/domain/position.operator.js.map +1 -0
- package/dist/domain/position.operator.spec.d.ts +1 -0
- package/dist/domain/position.operator.spec.js +49 -0
- package/dist/domain/position.operator.spec.js.map +1 -0
- package/dist/domain/position.spec.js +22 -17
- package/dist/domain/position.spec.js.map +1 -1
- package/dist/domain/session.d.ts +15 -18
- package/dist/domain/session.js +21 -31
- package/dist/domain/session.js.map +1 -1
- package/dist/domain/session.spec.js +2 -2
- package/dist/domain/session.spec.js.map +1 -1
- package/dist/domain/trade.d.ts +4 -3
- package/dist/domain/trade.js +1 -0
- package/dist/domain/trade.js.map +1 -1
- package/dist/domain/trade.operator.d.ts +6 -0
- package/dist/domain/trade.operator.js +10 -0
- package/dist/domain/trade.operator.js.map +1 -0
- package/dist/domain/trade.operator.spec.d.ts +1 -0
- package/dist/domain/trade.operator.spec.js +24 -0
- package/dist/domain/trade.operator.spec.js.map +1 -0
- package/dist/domain/trade.spec.d.ts +1 -0
- package/dist/domain/trade.spec.js +13 -0
- package/dist/domain/trade.spec.js.map +1 -0
- package/dist/indicator/atr.d.ts +2 -1
- package/dist/indicator/atr.js +3 -3
- package/dist/indicator/atr.js.map +1 -1
- package/dist/indicator/cross.d.ts +3 -2
- package/dist/indicator/cross.js +13 -13
- package/dist/indicator/cross.js.map +1 -1
- package/dist/indicator/cross.spec.js +23 -22
- package/dist/indicator/cross.spec.js.map +1 -1
- package/dist/indicator/donchian.d.ts +3 -2
- package/dist/indicator/donchian.js.map +1 -1
- package/dist/indicator/drawdown.d.ts +2 -1
- package/dist/indicator/drawdown.js +3 -2
- package/dist/indicator/drawdown.js.map +1 -1
- package/dist/indicator/ema.d.ts +2 -1
- package/dist/indicator/ema.js +3 -2
- package/dist/indicator/ema.js.map +1 -1
- package/dist/indicator/ema.spec.js +4 -3
- package/dist/indicator/ema.spec.js.map +1 -1
- package/dist/indicator/envelope.d.ts +4 -3
- package/dist/indicator/envelope.js +4 -4
- package/dist/indicator/envelope.js.map +1 -1
- package/dist/indicator/index.d.ts +1 -1
- package/dist/indicator/index.js +1 -1
- package/dist/indicator/index.js.map +1 -1
- package/dist/indicator/macd.d.ts +2 -1
- package/dist/indicator/macd.js +1 -1
- package/dist/indicator/macd.js.map +1 -1
- package/dist/indicator/min-max.d.ts +4 -3
- package/dist/indicator/min-max.js +5 -4
- package/dist/indicator/min-max.js.map +1 -1
- package/dist/indicator/rma.d.ts +2 -1
- package/dist/indicator/rma.js +3 -2
- package/dist/indicator/rma.js.map +1 -1
- package/dist/indicator/sma.d.ts +2 -1
- package/dist/indicator/sma.js +4 -6
- package/dist/indicator/sma.js.map +1 -1
- package/dist/indicator/sma.spec.js +4 -3
- package/dist/indicator/sma.spec.js.map +1 -1
- package/dist/indicator/swma.d.ts +2 -1
- package/dist/indicator/swma.js +5 -1
- package/dist/indicator/swma.js.map +1 -1
- package/dist/indicator/tma.d.ts +2 -1
- package/dist/indicator/tma.js.map +1 -1
- package/dist/indicator/tma.spec.js +4 -3
- package/dist/indicator/tma.spec.js.map +1 -1
- package/dist/indicator/trailing.d.ts +8 -7
- package/dist/indicator/trailing.js +12 -11
- package/dist/indicator/trailing.js.map +1 -1
- package/dist/indicator/trailing.spec.js +15 -14
- package/dist/indicator/trailing.spec.js.map +1 -1
- package/dist/indicator/true-range.d.ts +4 -0
- package/dist/indicator/true-range.js +20 -0
- package/dist/indicator/true-range.js.map +1 -0
- package/dist/indicator/true-range.spec.d.ts +1 -0
- package/dist/indicator/true-range.spec.js +28 -0
- package/dist/indicator/true-range.spec.js.map +1 -0
- package/dist/indicator/window.d.ts +1 -1
- package/dist/indicator/window.js +1 -1
- package/dist/indicator/window.js.map +1 -1
- package/dist/indicator/wma.d.ts +2 -1
- package/dist/indicator/wma.js +6 -5
- package/dist/indicator/wma.js.map +1 -1
- package/dist/indicator/wma.spec.js +4 -3
- package/dist/indicator/wma.spec.js.map +1 -1
- package/dist/shared/collections.d.ts +26 -0
- package/dist/shared/collections.js +115 -0
- package/dist/shared/collections.js.map +1 -0
- package/dist/shared/collections.spec.d.ts +1 -0
- package/dist/shared/collections.spec.js +28 -0
- package/dist/shared/collections.spec.js.map +1 -0
- package/dist/shared/datetime.d.ts +0 -1
- package/dist/shared/datetime.js +1 -12
- package/dist/shared/datetime.js.map +1 -1
- package/dist/shared/decimals.d.ts +15 -6
- package/dist/shared/decimals.js +22 -36
- package/dist/shared/decimals.js.map +1 -1
- package/dist/shared/decimals.spec.js +18 -22
- package/dist/shared/decimals.spec.js.map +1 -1
- package/dist/shared/index.d.ts +2 -1
- package/dist/shared/index.js +2 -1
- package/dist/shared/index.js.map +1 -1
- package/dist/shared/io.js.map +1 -1
- package/dist/shared/pipe.d.ts +4 -0
- package/dist/shared/pipe.js +9 -0
- package/dist/shared/pipe.js.map +1 -0
- package/dist/shared/policy.d.ts +0 -1
- package/dist/shared/policy.js +1 -11
- package/dist/shared/policy.js.map +1 -1
- package/dist/storage/cache.js +1 -1
- package/dist/storage/cache.js.map +1 -1
- package/dist/storage/cache.spec.d.ts +1 -0
- package/dist/storage/cache.spec.js +18 -0
- package/dist/storage/cache.spec.js.map +1 -0
- package/dist/storage/feed.d.ts +7 -4
- package/dist/storage/feed.js +55 -8
- package/dist/storage/feed.js.map +1 -1
- package/dist/storage/storage.d.ts +2 -7
- package/dist/storage/storage.js +6 -11
- package/dist/storage/storage.js.map +1 -1
- package/dist/store/index.d.ts +8 -2
- package/dist/store/index.js +8 -2
- package/dist/store/index.js.map +1 -1
- package/dist/store/store-balance.event.d.ts +33 -0
- package/dist/store/store-balance.event.js +90 -0
- package/dist/store/store-balance.event.js.map +1 -0
- package/dist/store/store-balance.event.spec.d.ts +1 -0
- package/dist/store/{event/store-balance.event.spec.js → store-balance.event.spec.js} +10 -10
- package/dist/store/store-balance.event.spec.js.map +1 -0
- package/dist/store/{event/store-instrument.event.d.ts → store-instrument.event.d.ts} +5 -8
- package/dist/store/store-instrument.event.js +52 -0
- package/dist/store/store-instrument.event.js.map +1 -0
- package/dist/store/store-instrument.event.spec.d.ts +1 -0
- package/dist/store/store-instrument.event.spec.js +22 -0
- package/dist/store/store-instrument.event.spec.js.map +1 -0
- package/dist/store/store-order.event.d.ts +59 -0
- package/dist/store/store-order.event.js +181 -0
- package/dist/store/store-order.event.js.map +1 -0
- package/dist/store/store-order.event.spec.d.ts +1 -0
- package/dist/store/{event/store-order.event.spec.js → store-order.event.spec.js} +8 -8
- package/dist/store/store-order.event.spec.js.map +1 -0
- package/dist/store/store-orderbook.event.d.ts +12 -0
- package/dist/store/store-orderbook.event.js +42 -0
- package/dist/store/store-orderbook.event.js.map +1 -0
- package/dist/store/store-orderbook.event.spec.d.ts +1 -0
- package/dist/store/store-orderbook.event.spec.js +28 -0
- package/dist/store/store-orderbook.event.spec.js.map +1 -0
- package/dist/store/store-position.event.d.ts +21 -0
- package/dist/store/store-position.event.js +89 -0
- package/dist/store/store-position.event.js.map +1 -0
- package/dist/store/store-state.d.ts +27 -0
- package/dist/store/store-state.js +29 -0
- package/dist/store/store-state.js.map +1 -0
- package/dist/store/store-trade.event.d.ts +12 -0
- package/dist/store/store-trade.event.js +25 -0
- package/dist/store/store-trade.event.js.map +1 -0
- package/dist/store/store-trade.event.spec.d.ts +1 -0
- package/dist/store/store-trade.event.spec.js +44 -0
- package/dist/store/store-trade.event.spec.js.map +1 -0
- package/dist/store/store.d.ts +4 -25
- package/dist/store/store.event.d.ts +6 -0
- package/dist/store/{event/store.event.js → store.event.js} +0 -0
- package/dist/store/store.event.js.map +1 -0
- package/dist/store/store.js +7 -195
- package/dist/store/store.js.map +1 -1
- package/dist/store/store.spec.d.ts +1 -0
- package/dist/store/store.spec.js +119 -0
- package/dist/store/store.spec.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/{jestconfig.unit.json → jestconfig.json} +2 -2
- package/package.json +4 -6
- package/src/adapter/adapter-aggregate.ts +39 -38
- package/src/adapter/adapter.ts +39 -71
- package/src/adapter/backtester/backtester-adapter.spec.ts +133 -0
- package/src/adapter/backtester/backtester-adapter.ts +41 -21
- package/src/adapter/backtester/backtester-cursor.spec.ts +19 -18
- package/src/adapter/backtester/backtester-cursor.ts +7 -7
- package/src/adapter/backtester/backtester-streamer.spec.ts +23 -22
- package/src/adapter/backtester/backtester-streamer.ts +28 -15
- package/src/adapter/error.ts +9 -0
- package/src/adapter/paper/engine/paper-engine.spec.ts +99 -0
- package/src/adapter/paper/engine/paper-engine.ts +142 -0
- package/src/adapter/paper/index.ts +1 -2
- package/src/adapter/paper/paper-adapter.spec.ts +65 -20
- package/src/adapter/paper/paper-adapter.ts +42 -27
- package/src/bootstrap.ts +26 -19
- package/src/cli/pull.ts +11 -6
- package/src/cli/test.ts +5 -2
- package/src/domain/asset.spec.ts +37 -33
- package/src/domain/asset.ts +33 -34
- package/src/domain/balance.operator.spec.ts +25 -0
- package/src/domain/balance.operator.ts +15 -0
- package/src/domain/balance.spec.ts +101 -12
- package/src/domain/balance.ts +57 -51
- package/src/domain/candle.operator.spec.ts +126 -0
- package/src/domain/candle.operator.ts +107 -0
- package/src/domain/candle.spec.ts +18 -73
- package/src/domain/candle.ts +9 -121
- package/src/domain/commission.spec.ts +34 -0
- package/src/domain/commission.ts +13 -11
- package/src/domain/component.ts +1 -0
- package/src/domain/error.ts +27 -0
- package/src/domain/index.ts +8 -1
- package/src/domain/instrument.operator.spec.ts +28 -0
- package/src/domain/instrument.operator.ts +25 -0
- package/src/domain/instrument.spec.ts +22 -30
- package/src/domain/instrument.ts +20 -11
- package/src/domain/order.operator.spec.ts +82 -0
- package/src/domain/order.operator.ts +23 -0
- package/src/domain/order.spec.ts +44 -0
- package/src/domain/order.ts +55 -55
- package/src/domain/orderbook.operator.spec.ts +28 -0
- package/src/domain/orderbook.operator.ts +15 -0
- package/src/domain/orderbook.spec.ts +17 -0
- package/src/domain/orderbook.ts +18 -9
- package/src/domain/position.operator.spec.ts +59 -0
- package/src/domain/position.operator.ts +64 -0
- package/src/domain/position.spec.ts +28 -23
- package/src/domain/position.ts +17 -49
- package/src/domain/session.spec.ts +4 -4
- package/src/domain/session.ts +42 -134
- package/src/domain/trade.operator.spec.ts +31 -0
- package/src/domain/trade.operator.ts +15 -0
- package/src/domain/trade.spec.ts +17 -0
- package/src/domain/trade.ts +7 -4
- package/src/indicator/atr.ts +6 -5
- package/src/indicator/cross.spec.ts +33 -48
- package/src/indicator/cross.ts +18 -10
- package/src/indicator/donchian.ts +5 -4
- package/src/indicator/drawdown.ts +7 -5
- package/src/indicator/ema.spec.ts +5 -4
- package/src/indicator/ema.ts +7 -6
- package/src/indicator/envelope.ts +11 -6
- package/src/indicator/index.ts +1 -1
- package/src/indicator/macd.ts +5 -4
- package/src/indicator/min-max.ts +10 -7
- package/src/indicator/rma.ts +7 -6
- package/src/indicator/sma.spec.ts +5 -4
- package/src/indicator/sma.ts +9 -8
- package/src/indicator/swma.ts +8 -4
- package/src/indicator/tma.spec.ts +5 -4
- package/src/indicator/tma.ts +4 -3
- package/src/indicator/trailing.spec.ts +29 -16
- package/src/indicator/trailing.ts +22 -16
- package/src/indicator/true-range.spec.ts +32 -0
- package/src/indicator/true-range.ts +32 -0
- package/src/indicator/window.ts +3 -3
- package/src/indicator/wma.spec.ts +5 -4
- package/src/indicator/wma.ts +8 -7
- package/src/shared/collections.spec.ts +30 -0
- package/src/shared/collections.ts +141 -0
- package/src/shared/datetime.ts +0 -12
- package/src/shared/decimals.spec.ts +19 -24
- package/src/shared/decimals.ts +22 -55
- package/src/shared/index.ts +2 -1
- package/src/shared/io.ts +0 -2
- package/src/shared/pipe.ts +12 -0
- package/src/shared/policy.ts +0 -13
- package/src/storage/cache.spec.ts +18 -0
- package/src/storage/cache.ts +1 -1
- package/src/storage/feed.ts +88 -23
- package/src/storage/storage.ts +9 -13
- package/src/store/index.ts +8 -2
- package/src/store/{event/store-balance.event.spec.ts → store-balance.event.spec.ts} +10 -10
- package/src/store/store-balance.event.ts +124 -0
- package/src/store/store-instrument.event.spec.ts +25 -0
- package/src/store/store-instrument.event.ts +72 -0
- package/src/store/store-order.event.spec.ts +28 -0
- package/src/store/store-order.event.ts +214 -0
- package/src/store/store-orderbook.event.spec.ts +37 -0
- package/src/store/store-orderbook.event.ts +54 -0
- package/src/store/store-position.event.ts +114 -0
- package/src/store/store-state.ts +48 -0
- package/src/store/store-trade.event.spec.ts +60 -0
- package/src/store/store-trade.event.ts +36 -0
- package/src/store/store.event.ts +8 -0
- package/src/store/store.spec.ts +180 -0
- package/src/store/store.ts +10 -208
- package/dist/adapter/paper/simulator/paper-margin-simulator.d.ts +0 -10
- package/dist/adapter/paper/simulator/paper-margin-simulator.js +0 -69
- package/dist/adapter/paper/simulator/paper-margin-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-simulator.d.ts +0 -16
- package/dist/adapter/paper/simulator/paper-simulator.js +0 -93
- package/dist/adapter/paper/simulator/paper-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-spot-simulator.d.ts +0 -13
- package/dist/adapter/paper/simulator/paper-spot-simulator.js +0 -81
- package/dist/adapter/paper/simulator/paper-spot-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-spot-simulator.spec.js +0 -49
- package/dist/adapter/paper/simulator/paper-spot-simulator.spec.js.map +0 -1
- package/dist/domain/statement.d.ts +0 -4
- package/dist/domain/statement.js +0 -87
- package/dist/domain/statement.js.map +0 -1
- package/dist/indicator/truerange.d.ts +0 -3
- package/dist/indicator/truerange.js +0 -19
- package/dist/indicator/truerange.js.map +0 -1
- package/dist/indicator/truerange.spec.js +0 -28
- package/dist/indicator/truerange.spec.js.map +0 -1
- package/dist/shared/policy.spec.js +0 -22
- package/dist/shared/policy.spec.js.map +0 -1
- package/dist/shared/topic.d.ts +0 -14
- package/dist/shared/topic.js +0 -40
- package/dist/shared/topic.js.map +0 -1
- package/dist/shared/topic.spec.js +0 -43
- package/dist/shared/topic.spec.js.map +0 -1
- package/dist/store/event/index.d.ts +0 -8
- package/dist/store/event/index.js +0 -25
- package/dist/store/event/index.js.map +0 -1
- package/dist/store/event/store-balance.event.d.ts +0 -37
- package/dist/store/event/store-balance.event.js +0 -119
- package/dist/store/event/store-balance.event.js.map +0 -1
- package/dist/store/event/store-balance.event.spec.js.map +0 -1
- package/dist/store/event/store-candle.event.d.ts +0 -18
- package/dist/store/event/store-candle.event.js +0 -63
- package/dist/store/event/store-candle.event.js.map +0 -1
- package/dist/store/event/store-candle.event.spec.js +0 -23
- package/dist/store/event/store-candle.event.spec.js.map +0 -1
- package/dist/store/event/store-instrument.event.js +0 -78
- package/dist/store/event/store-instrument.event.js.map +0 -1
- package/dist/store/event/store-instrument.event.spec.js +0 -21
- package/dist/store/event/store-instrument.event.spec.js.map +0 -1
- package/dist/store/event/store-order.event.d.ts +0 -61
- package/dist/store/event/store-order.event.js +0 -205
- package/dist/store/event/store-order.event.js.map +0 -1
- package/dist/store/event/store-order.event.spec.js.map +0 -1
- package/dist/store/event/store-orderbook.event.d.ts +0 -15
- package/dist/store/event/store-orderbook.event.js +0 -65
- package/dist/store/event/store-orderbook.event.js.map +0 -1
- package/dist/store/event/store-position.event.d.ts +0 -23
- package/dist/store/event/store-position.event.js +0 -97
- package/dist/store/event/store-position.event.js.map +0 -1
- package/dist/store/event/store-trade.event.d.ts +0 -13
- package/dist/store/event/store-trade.event.js +0 -47
- package/dist/store/event/store-trade.event.js.map +0 -1
- package/dist/store/event/store-trade.event.spec.js +0 -44
- package/dist/store/event/store-trade.event.spec.js.map +0 -1
- package/dist/store/event/store.event.d.ts +0 -5
- package/dist/store/event/store.event.js.map +0 -1
- package/dist/store/store.state.d.ts +0 -21
- package/dist/store/store.state.js +0 -21
- package/dist/store/store.state.js.map +0 -1
- package/dist/tests/backtester-adapter.spec.js +0 -61
- package/dist/tests/backtester-adapter.spec.js.map +0 -1
- package/dist/tests/session.spec.d.ts +0 -0
- package/dist/tests/session.spec.js +0 -1
- package/dist/tests/session.spec.js.map +0 -1
- package/jestconfig.integration.json +0 -12
- package/src/adapter/paper/simulator/paper-margin-simulator.ts +0 -108
- package/src/adapter/paper/simulator/paper-simulator.ts +0 -121
- package/src/adapter/paper/simulator/paper-spot-simulator.spec.ts +0 -87
- package/src/adapter/paper/simulator/paper-spot-simulator.ts +0 -134
- package/src/domain/statement.ts +0 -119
- package/src/indicator/truerange.spec.ts +0 -32
- package/src/indicator/truerange.ts +0 -31
- package/src/shared/policy.spec.ts +0 -25
- package/src/shared/topic.spec.ts +0 -34
- package/src/shared/topic.ts +0 -43
- package/src/store/event/index.ts +0 -8
- package/src/store/event/store-balance.event.ts +0 -161
- package/src/store/event/store-candle.event.spec.ts +0 -30
- package/src/store/event/store-candle.event.ts +0 -71
- package/src/store/event/store-instrument.event.spec.ts +0 -25
- package/src/store/event/store-instrument.event.ts +0 -84
- package/src/store/event/store-order.event.spec.ts +0 -28
- package/src/store/event/store-order.event.ts +0 -218
- package/src/store/event/store-orderbook.event.ts +0 -70
- package/src/store/event/store-position.event.ts +0 -109
- package/src/store/event/store-trade.event.spec.ts +0 -60
- package/src/store/event/store-trade.event.ts +0 -52
- package/src/store/event/store.event.ts +0 -6
- package/src/store/store.state.ts +0 -43
- package/src/tests/backtester-adapter.spec.ts +0 -88
- package/src/tests/session.spec.ts +0 -121
|
@@ -1,10 +1,14 @@
|
|
|
1
|
+
import { decimal } from '../shared';
|
|
1
2
|
export declare class Commission {
|
|
2
|
-
readonly makerRate:
|
|
3
|
-
readonly takerRate:
|
|
4
|
-
constructor(makerRate:
|
|
5
|
-
calculateMakerFee(value:
|
|
6
|
-
calculateTakerFee(value:
|
|
7
|
-
applyMakerFee(value:
|
|
8
|
-
applyTakerFee(value:
|
|
3
|
+
readonly makerRate: decimal;
|
|
4
|
+
readonly takerRate: decimal;
|
|
5
|
+
constructor(makerRate: decimal, takerRate: decimal);
|
|
6
|
+
calculateMakerFee(value: decimal): import("decimal.js").default;
|
|
7
|
+
calculateTakerFee(value: decimal): import("decimal.js").default;
|
|
8
|
+
applyMakerFee(value: decimal): decimal;
|
|
9
|
+
applyTakerFee(value: decimal): decimal;
|
|
9
10
|
}
|
|
10
|
-
export declare function commissionPercentOf(
|
|
11
|
+
export declare function commissionPercentOf(fees: {
|
|
12
|
+
maker: decimal;
|
|
13
|
+
taker: decimal;
|
|
14
|
+
}): Commission;
|
|
@@ -7,21 +7,21 @@ class Commission {
|
|
|
7
7
|
this.takerRate = takerRate;
|
|
8
8
|
}
|
|
9
9
|
calculateMakerFee(value) {
|
|
10
|
-
return value
|
|
10
|
+
return value.mul(this.makerRate);
|
|
11
11
|
}
|
|
12
12
|
calculateTakerFee(value) {
|
|
13
|
-
return value
|
|
13
|
+
return value.mul(this.takerRate);
|
|
14
14
|
}
|
|
15
15
|
applyMakerFee(value) {
|
|
16
|
-
return value
|
|
16
|
+
return value.minus(this.calculateMakerFee(value));
|
|
17
17
|
}
|
|
18
18
|
applyTakerFee(value) {
|
|
19
|
-
return value
|
|
19
|
+
return value.minus(this.calculateTakerFee(value));
|
|
20
20
|
}
|
|
21
21
|
}
|
|
22
22
|
exports.Commission = Commission;
|
|
23
|
-
function commissionPercentOf(
|
|
24
|
-
return new Commission(maker
|
|
23
|
+
function commissionPercentOf(fees) {
|
|
24
|
+
return new Commission(fees.maker.div(100.0), fees.taker.div(100.0));
|
|
25
25
|
}
|
|
26
26
|
exports.commissionPercentOf = commissionPercentOf;
|
|
27
27
|
//# sourceMappingURL=commission.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commission.js","sourceRoot":"","sources":["../../src/domain/commission.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"commission.js","sourceRoot":"","sources":["../../src/domain/commission.ts"],"names":[],"mappings":";;;AAEA,MAAa,UAAU;IACrB,YAAqB,SAAkB,EAAW,SAAkB;QAA/C,cAAS,GAAT,SAAS,CAAS;QAAW,cAAS,GAAT,SAAS,CAAS;IAAG,CAAC;IAExE,iBAAiB,CAAC,KAAc;QAC9B,OAAO,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAED,iBAAiB,CAAC,KAAc;QAC9B,OAAO,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAED,aAAa,CAAC,KAAc;QAC1B,OAAO,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC;IACpD,CAAC;IAED,aAAa,CAAC,KAAc;QAC1B,OAAO,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC;IACpD,CAAC;CACF;AAlBD,gCAkBC;AAED,SAAgB,mBAAmB,CAAC,IAAwC;IAC1E,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;AACtE,CAAC;AAFD,kDAEC"}
|
|
File without changes
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const shared_1 = require("../shared");
|
|
4
|
+
const commission_1 = require("./commission");
|
|
5
|
+
describe('Commission', () => {
|
|
6
|
+
test('should construct a Commission', () => {
|
|
7
|
+
const sut = (0, commission_1.commissionPercentOf)({
|
|
8
|
+
maker: (0, shared_1.d)(0.1),
|
|
9
|
+
taker: (0, shared_1.d)(0.2)
|
|
10
|
+
});
|
|
11
|
+
expect(sut.makerRate).toEqual((0, shared_1.d)(0.001));
|
|
12
|
+
expect(sut.takerRate).toEqual((0, shared_1.d)(0.002));
|
|
13
|
+
});
|
|
14
|
+
test('should calculate a maker fee', () => {
|
|
15
|
+
const sut = (0, commission_1.commissionPercentOf)({
|
|
16
|
+
maker: (0, shared_1.d)(0.1),
|
|
17
|
+
taker: (0, shared_1.d)(0.2)
|
|
18
|
+
});
|
|
19
|
+
expect(sut.calculateMakerFee((0, shared_1.d)(2000))).toEqual((0, shared_1.d)(2));
|
|
20
|
+
expect(sut.applyMakerFee((0, shared_1.d)(2000))).toEqual((0, shared_1.d)(1998));
|
|
21
|
+
});
|
|
22
|
+
test('should calculate a taker fee', () => {
|
|
23
|
+
const sut = (0, commission_1.commissionPercentOf)({
|
|
24
|
+
maker: (0, shared_1.d)(0.1),
|
|
25
|
+
taker: (0, shared_1.d)(0.2)
|
|
26
|
+
});
|
|
27
|
+
expect(sut.calculateTakerFee((0, shared_1.d)(2000))).toEqual((0, shared_1.d)(4));
|
|
28
|
+
expect(sut.applyTakerFee((0, shared_1.d)(2000))).toEqual((0, shared_1.d)(1996));
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
//# sourceMappingURL=commission.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commission.spec.js","sourceRoot":"","sources":["../../src/domain/commission.spec.ts"],"names":[],"mappings":";;AAAA,sCAA8B;AAC9B,6CAAmD;AAEnD,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,IAAI,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACzC,MAAM,GAAG,GAAG,IAAA,gCAAmB,EAAC;YAC9B,KAAK,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC;YACb,KAAK,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC;SACd,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,KAAK,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,KAAK,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACxC,MAAM,GAAG,GAAG,IAAA,gCAAmB,EAAC;YAC9B,KAAK,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC;YACb,KAAK,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC;SACd,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,CAAC,GAAG,CAAC,aAAa,CAAC,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACxC,MAAM,GAAG,GAAG,IAAA,gCAAmB,EAAC;YAC9B,KAAK,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC;YACb,KAAK,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC;SACd,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,CAAC,GAAG,CAAC,aAAa,CAAC,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { decimal } from '../shared';
|
|
2
|
+
export declare function insufficientFundsError(assetName: string, requiredAmount: decimal, availableAmount: decimal): Error;
|
|
3
|
+
export declare function invalidArgumentError(value: any): void;
|
|
4
|
+
export declare function invalidAssetSelectorError(selector: string): void;
|
|
5
|
+
export declare function invalidInstrumentSelectorError(selector: string): void;
|
|
6
|
+
export declare function adapterMismatchError(): Error;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.adapterMismatchError = exports.invalidInstrumentSelectorError = exports.invalidAssetSelectorError = exports.invalidArgumentError = exports.insufficientFundsError = void 0;
|
|
4
|
+
function insufficientFundsError(assetName, requiredAmount, availableAmount) {
|
|
5
|
+
return new Error(`insufficient funds of ${assetName} has: ${availableAmount.toString()} requires: ${requiredAmount.toString()}`);
|
|
6
|
+
}
|
|
7
|
+
exports.insufficientFundsError = insufficientFundsError;
|
|
8
|
+
function invalidArgumentError(value) {
|
|
9
|
+
throw new Error(`invalid argument: ${value}`);
|
|
10
|
+
}
|
|
11
|
+
exports.invalidArgumentError = invalidArgumentError;
|
|
12
|
+
function invalidAssetSelectorError(selector) {
|
|
13
|
+
throw new Error(`invalid asset selector: ${selector}`);
|
|
14
|
+
}
|
|
15
|
+
exports.invalidAssetSelectorError = invalidAssetSelectorError;
|
|
16
|
+
function invalidInstrumentSelectorError(selector) {
|
|
17
|
+
throw new Error(`invalid instrument selector: ${selector}`);
|
|
18
|
+
}
|
|
19
|
+
exports.invalidInstrumentSelectorError = invalidInstrumentSelectorError;
|
|
20
|
+
function adapterMismatchError() {
|
|
21
|
+
return new Error('adapters must be the same');
|
|
22
|
+
}
|
|
23
|
+
exports.adapterMismatchError = adapterMismatchError;
|
|
24
|
+
//# sourceMappingURL=error.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error.js","sourceRoot":"","sources":["../../src/domain/error.ts"],"names":[],"mappings":";;;AAEA,SAAgB,sBAAsB,CACpC,SAAiB,EACjB,cAAuB,EACvB,eAAwB;IAExB,OAAO,IAAI,KAAK,CACd,yBAAyB,SAAS,SAAS,eAAe,CAAC,QAAQ,EAAE,cAAc,cAAc,CAAC,QAAQ,EAAE,EAAE,CAC/G,CAAC;AACJ,CAAC;AARD,wDAQC;AAED,SAAgB,oBAAoB,CAAC,KAAU;IAC7C,MAAM,IAAI,KAAK,CAAC,qBAAqB,KAAK,EAAE,CAAC,CAAC;AAChD,CAAC;AAFD,oDAEC;AAED,SAAgB,yBAAyB,CAAC,QAAgB;IACxD,MAAM,IAAI,KAAK,CAAC,2BAA2B,QAAQ,EAAE,CAAC,CAAC;AACzD,CAAC;AAFD,8DAEC;AAED,SAAgB,8BAA8B,CAAC,QAAgB;IAC7D,MAAM,IAAI,KAAK,CAAC,gCAAgC,QAAQ,EAAE,CAAC,CAAC;AAC9D,CAAC;AAFD,wEAEC;AAED,SAAgB,oBAAoB;IAClC,OAAO,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;AAChD,CAAC;AAFD,oDAEC"}
|
package/dist/domain/index.d.ts
CHANGED
|
@@ -1,13 +1,20 @@
|
|
|
1
1
|
export * from './asset';
|
|
2
2
|
export * from './balance';
|
|
3
|
+
export * from './balance.operator';
|
|
4
|
+
export * from './error';
|
|
3
5
|
export * from './candle';
|
|
6
|
+
export * from './candle.operator';
|
|
4
7
|
export * from './commission';
|
|
5
8
|
export * from './component';
|
|
6
9
|
export * from './instrument';
|
|
10
|
+
export * from './instrument.operator';
|
|
7
11
|
export * from './order';
|
|
12
|
+
export * from './order.operator';
|
|
8
13
|
export * from './orderbook';
|
|
14
|
+
export * from './orderbook.operator';
|
|
9
15
|
export * from './position';
|
|
16
|
+
export * from './position.operator';
|
|
10
17
|
export * from './session';
|
|
11
|
-
export * from './statement';
|
|
12
18
|
export * from './timeframe';
|
|
13
19
|
export * from './trade';
|
|
20
|
+
export * from './trade.operator';
|
package/dist/domain/index.js
CHANGED
|
@@ -16,15 +16,22 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./asset"), exports);
|
|
18
18
|
__exportStar(require("./balance"), exports);
|
|
19
|
+
__exportStar(require("./balance.operator"), exports);
|
|
20
|
+
__exportStar(require("./error"), exports);
|
|
19
21
|
__exportStar(require("./candle"), exports);
|
|
22
|
+
__exportStar(require("./candle.operator"), exports);
|
|
20
23
|
__exportStar(require("./commission"), exports);
|
|
21
24
|
__exportStar(require("./component"), exports);
|
|
22
25
|
__exportStar(require("./instrument"), exports);
|
|
26
|
+
__exportStar(require("./instrument.operator"), exports);
|
|
23
27
|
__exportStar(require("./order"), exports);
|
|
28
|
+
__exportStar(require("./order.operator"), exports);
|
|
24
29
|
__exportStar(require("./orderbook"), exports);
|
|
30
|
+
__exportStar(require("./orderbook.operator"), exports);
|
|
25
31
|
__exportStar(require("./position"), exports);
|
|
32
|
+
__exportStar(require("./position.operator"), exports);
|
|
26
33
|
__exportStar(require("./session"), exports);
|
|
27
|
-
__exportStar(require("./statement"), exports);
|
|
28
34
|
__exportStar(require("./timeframe"), exports);
|
|
29
35
|
__exportStar(require("./trade"), exports);
|
|
36
|
+
__exportStar(require("./trade.operator"), exports);
|
|
30
37
|
//# sourceMappingURL=index.js.map
|
package/dist/domain/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/domain/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAwB;AACxB,4CAA0B;AAC1B,2CAAyB;AACzB,+CAA6B;AAC7B,8CAA4B;AAC5B,+CAA6B;AAC7B,0CAAwB;AACxB,8CAA4B;AAC5B,6CAA2B;AAC3B,4CAA0B;AAC1B,8CAA4B;AAC5B,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/domain/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAwB;AACxB,4CAA0B;AAC1B,qDAAmC;AACnC,0CAAwB;AACxB,2CAAyB;AACzB,oDAAkC;AAClC,+CAA6B;AAC7B,8CAA4B;AAC5B,+CAA6B;AAC7B,wDAAsC;AACtC,0CAAwB;AACxB,mDAAiC;AACjC,8CAA4B;AAC5B,uDAAqC;AACrC,6CAA2B;AAC3B,sDAAoC;AACpC,4CAA0B;AAC1B,8CAA4B;AAC5B,0CAAwB;AACxB,mDAAiC"}
|
|
@@ -2,8 +2,9 @@ import { timestamp } from '../shared';
|
|
|
2
2
|
import { Asset, AssetSelector } from './asset';
|
|
3
3
|
import { Commission } from './commission';
|
|
4
4
|
import { Component } from './component';
|
|
5
|
+
export declare const InstrumentSelectorSeparator = "-";
|
|
5
6
|
export declare class InstrumentSelector {
|
|
6
|
-
|
|
7
|
+
readonly id: string;
|
|
7
8
|
readonly base: AssetSelector;
|
|
8
9
|
readonly quote: AssetSelector;
|
|
9
10
|
constructor(base: string, quote: string, adapter: string);
|
|
@@ -20,4 +21,4 @@ export declare class Instrument extends InstrumentSelector implements Component
|
|
|
20
21
|
leverage?: number;
|
|
21
22
|
constructor(base: Asset, quote: Asset, raw: string);
|
|
22
23
|
}
|
|
23
|
-
export declare function instrumentOf(
|
|
24
|
+
export declare function instrumentOf(selector: string): InstrumentSelector;
|
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.instrumentOf = exports.Instrument = exports.InstrumentSelector = void 0;
|
|
3
|
+
exports.instrumentOf = exports.Instrument = exports.InstrumentSelector = exports.InstrumentSelectorSeparator = void 0;
|
|
4
4
|
const asset_1 = require("./asset");
|
|
5
|
+
const error_1 = require("./error");
|
|
6
|
+
exports.InstrumentSelectorSeparator = '-';
|
|
5
7
|
class InstrumentSelector {
|
|
6
8
|
constructor(base, quote, adapter) {
|
|
7
9
|
this.base = new asset_1.AssetSelector(base.toLowerCase(), adapter.toLowerCase());
|
|
8
10
|
this.quote = new asset_1.AssetSelector(quote.toLowerCase(), adapter.toLowerCase());
|
|
9
|
-
this.id = `${this.base.
|
|
11
|
+
this.id = `${this.base.id}${exports.InstrumentSelectorSeparator}${this.quote.name}`;
|
|
10
12
|
}
|
|
11
13
|
toString() {
|
|
12
14
|
return this.id;
|
|
@@ -15,22 +17,28 @@ class InstrumentSelector {
|
|
|
15
17
|
exports.InstrumentSelector = InstrumentSelector;
|
|
16
18
|
class Instrument extends InstrumentSelector {
|
|
17
19
|
constructor(base, quote, raw) {
|
|
18
|
-
super(base.name, quote.name, base.
|
|
20
|
+
super(base.name, quote.name, base.adapterName);
|
|
19
21
|
this.base = base;
|
|
20
22
|
this.quote = quote;
|
|
21
23
|
this.raw = raw;
|
|
22
24
|
this.kind = 'instrument';
|
|
23
25
|
this.leverage = null;
|
|
24
|
-
if (base.
|
|
25
|
-
throw
|
|
26
|
+
if (base.adapterName != quote.adapterName) {
|
|
27
|
+
throw (0, error_1.adapterMismatchError)();
|
|
26
28
|
}
|
|
27
29
|
}
|
|
28
30
|
}
|
|
29
31
|
exports.Instrument = Instrument;
|
|
30
|
-
function instrumentOf(
|
|
31
|
-
const
|
|
32
|
-
|
|
33
|
-
|
|
32
|
+
function instrumentOf(selector) {
|
|
33
|
+
const [adapterName, asset, ...rest] = selector.split(asset_1.AssetSelectorSeparator);
|
|
34
|
+
if (!adapterName || !asset || rest.length) {
|
|
35
|
+
throw (0, error_1.invalidInstrumentSelectorError)(selector);
|
|
36
|
+
}
|
|
37
|
+
const [baseAssetName, quoteAssetName] = asset.split(exports.InstrumentSelectorSeparator);
|
|
38
|
+
if (!baseAssetName || !quoteAssetName) {
|
|
39
|
+
throw (0, error_1.invalidInstrumentSelectorError)(selector);
|
|
40
|
+
}
|
|
41
|
+
return new InstrumentSelector(baseAssetName, quoteAssetName, adapterName);
|
|
34
42
|
}
|
|
35
43
|
exports.instrumentOf = instrumentOf;
|
|
36
44
|
//# sourceMappingURL=instrument.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"instrument.js","sourceRoot":"","sources":["../../src/domain/instrument.ts"],"names":[],"mappings":";;;AACA,mCAA+
|
|
1
|
+
{"version":3,"file":"instrument.js","sourceRoot":"","sources":["../../src/domain/instrument.ts"],"names":[],"mappings":";;;AACA,mCAAuE;AAGvE,mCAA+E;AAElE,QAAA,2BAA2B,GAAG,GAAG,CAAC;AAE/C,MAAa,kBAAkB;IAK7B,YAAY,IAAY,EAAE,KAAa,EAAE,OAAe;QACtD,IAAI,CAAC,IAAI,GAAG,IAAI,qBAAa,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;QACzE,IAAI,CAAC,KAAK,GAAG,IAAI,qBAAa,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;QAE3E,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,mCAA2B,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IAC9E,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;CACF;AAfD,gDAeC;AAKD,MAAa,UAAW,SAAQ,kBAAkB;IAOhD,YAAqB,IAAW,EAAW,KAAY,EAAW,GAAW;QAC3E,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAD5B,SAAI,GAAJ,IAAI,CAAO;QAAW,UAAK,GAAL,KAAK,CAAO;QAAW,QAAG,GAAH,GAAG,CAAQ;QAN7E,SAAI,GAAG,YAAY,CAAC;QAIpB,aAAQ,GAAY,IAAI,CAAC;QAKvB,IAAI,IAAI,CAAC,WAAW,IAAI,KAAK,CAAC,WAAW,EAAE;YACzC,MAAM,IAAA,4BAAoB,GAAE,CAAC;SAC9B;IACH,CAAC;CACF;AAdD,gCAcC;AAED,SAAgB,YAAY,CAAC,QAAgB;IAC3C,MAAM,CAAC,WAAW,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,8BAAsB,CAAC,CAAC;IAC7E,IAAI,CAAC,WAAW,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE;QACzC,MAAM,IAAA,sCAA8B,EAAC,QAAQ,CAAC,CAAC;KAChD;IAED,MAAM,CAAC,aAAa,EAAE,cAAc,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,mCAA2B,CAAC,CAAC;IACjF,IAAI,CAAC,aAAa,IAAI,CAAC,cAAc,EAAE;QACrC,MAAM,IAAA,sCAA8B,EAAC,QAAQ,CAAC,CAAC;KAChD;IAED,OAAO,IAAI,kBAAkB,CAAC,aAAa,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC;AAC5E,CAAC;AAZD,oCAYC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Observable } from 'rxjs';
|
|
2
|
+
import { State } from '../store';
|
|
3
|
+
import { Component } from './component';
|
|
4
|
+
import { Instrument, InstrumentSelector } from './instrument';
|
|
5
|
+
export declare function instrument(selector: InstrumentSelector, state: State): (source$: Observable<Component>) => Observable<Instrument>;
|
|
6
|
+
export declare function instruments(state: State): (source$: Observable<Component>) => Observable<readonly Instrument[]>;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.instruments = exports.instrument = void 0;
|
|
4
|
+
const rxjs_1 = require("rxjs");
|
|
5
|
+
const instrument_1 = require("./instrument");
|
|
6
|
+
function instrument(selector, state) {
|
|
7
|
+
return (source$) => source$.pipe((0, rxjs_1.startWith)(state.universe.instrument.get(selector.id)), (0, rxjs_1.filter)(it => it instanceof instrument_1.Instrument && it.id == selector.id), (0, rxjs_1.map)(it => it));
|
|
8
|
+
}
|
|
9
|
+
exports.instrument = instrument;
|
|
10
|
+
function instruments(state) {
|
|
11
|
+
return (source$) => source$.pipe((0, rxjs_1.filter)(it => it instanceof instrument_1.Instrument), (0, rxjs_1.map)(() => state.universe.instrument.asReadonlyArray()), (0, rxjs_1.startWith)(state.universe.instrument.asReadonlyArray()), (0, rxjs_1.filter)(it => it.length > 0), (0, rxjs_1.distinctUntilChanged)((lhs, rhs) => lhs.length == rhs.length));
|
|
12
|
+
}
|
|
13
|
+
exports.instruments = instruments;
|
|
14
|
+
//# sourceMappingURL=instrument.operator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instrument.operator.js","sourceRoot":"","sources":["../../src/domain/instrument.operator.ts"],"names":[],"mappings":";;;AAAA,+BAAgF;AAIhF,6CAA8D;AAE9D,SAAgB,UAAU,CAAC,QAA4B,EAAE,KAAY;IACnE,OAAO,CAAC,OAA8B,EAAE,EAAE,CACxC,OAAO,CAAC,IAAI,CACV,IAAA,gBAAS,EAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,EACrD,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,EAAE,YAAY,uBAAU,IAAI,EAAE,CAAC,EAAE,IAAI,QAAQ,CAAC,EAAE,CAAC,EAC9D,IAAA,UAAG,EAAC,EAAE,CAAC,EAAE,CAAC,EAAgB,CAAC,CAC5B,CAAC;AACN,CAAC;AAPD,gCAOC;AAED,SAAgB,WAAW,CAAC,KAAY;IACtC,OAAO,CAAC,OAA8B,EAAE,EAAE,CACxC,OAAO,CAAC,IAAI,CACV,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,EAAE,YAAY,uBAAU,CAAC,EACtC,IAAA,UAAG,EAAC,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC,EACtD,IAAA,gBAAS,EAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC,EACtD,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,EAC3B,IAAA,2BAAoB,EAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,CAC7D,CAAC;AACN,CAAC;AATD,kCASC"}
|
package/dist/{store/event/store-balance.event.spec.d.ts → domain/instrument.operator.spec.d.ts}
RENAMED
|
File without changes
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const rxjs_1 = require("rxjs");
|
|
4
|
+
const store_1 = require("../store");
|
|
5
|
+
const asset_1 = require("./asset");
|
|
6
|
+
const instrument_1 = require("./instrument");
|
|
7
|
+
const instrument_operator_1 = require("./instrument.operator");
|
|
8
|
+
describe('instrument', () => {
|
|
9
|
+
const state = new store_1.State();
|
|
10
|
+
beforeEach(() => {
|
|
11
|
+
state.universe.instrument.upsert(new instrument_1.Instrument(new asset_1.Asset('abc', 'xyz', 4), new asset_1.Asset('def', 'xyz', 4), 'abc-def'));
|
|
12
|
+
});
|
|
13
|
+
test('should pipe an instrument on subscription', done => {
|
|
14
|
+
new rxjs_1.Subject()
|
|
15
|
+
.pipe((0, instrument_operator_1.instrument)((0, instrument_1.instrumentOf)('xyz:abc-def'), state))
|
|
16
|
+
.subscribe({
|
|
17
|
+
next: it => {
|
|
18
|
+
expect(it.id).toEqual('xyz:abc-def');
|
|
19
|
+
done();
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
//# sourceMappingURL=instrument.operator.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instrument.operator.spec.js","sourceRoot":"","sources":["../../src/domain/instrument.operator.spec.ts"],"names":[],"mappings":";;AAAA,+BAA+B;AAE/B,oCAAiC;AACjC,mCAAgC;AAEhC,6CAAwD;AACxD,+DAAmD;AAEnD,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,MAAM,KAAK,GAAG,IAAI,aAAK,EAAE,CAAC;IAE1B,UAAU,CAAC,GAAG,EAAE;QACd,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,CAC9B,IAAI,uBAAU,CAAC,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,CAClF,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2CAA2C,EAAE,IAAI,CAAC,EAAE;QACvD,IAAI,cAAO,EAAa;aACrB,IAAI,CAAC,IAAA,gCAAU,EAAC,IAAA,yBAAY,EAAC,aAAa,CAAC,EAAE,KAAK,CAAC,CAAC;aACpD,SAAS,CAAC;YACT,IAAI,EAAE,EAAE,CAAC,EAAE;gBACT,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;gBACrC,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -2,56 +2,48 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const asset_1 = require("./asset");
|
|
4
4
|
const instrument_1 = require("./instrument");
|
|
5
|
-
describe('
|
|
6
|
-
test('should
|
|
5
|
+
describe('Instrument', () => {
|
|
6
|
+
test('should construct a instrument', () => {
|
|
7
7
|
const sut = new instrument_1.Instrument(new asset_1.Asset('abc', 'xyz', 4), new asset_1.Asset('def', 'xyz', 4), 'abc-def');
|
|
8
8
|
expect(sut.base.name).toEqual('abc');
|
|
9
|
-
expect(sut.base.
|
|
9
|
+
expect(sut.base.adapterName).toEqual('xyz');
|
|
10
10
|
expect(sut.quote.name).toEqual('def');
|
|
11
|
-
expect(sut.quote.
|
|
12
|
-
expect(sut.
|
|
11
|
+
expect(sut.quote.adapterName).toEqual('xyz');
|
|
12
|
+
expect(sut.id).toEqual('xyz:abc-def');
|
|
13
13
|
});
|
|
14
14
|
});
|
|
15
|
-
describe('
|
|
16
|
-
test('should
|
|
15
|
+
describe('InstrumentSelector', () => {
|
|
16
|
+
test('should construct a instrument selector', () => {
|
|
17
17
|
const sut = (0, instrument_1.instrumentOf)('xyz:abc-def');
|
|
18
18
|
expect(sut.base.name).toEqual('abc');
|
|
19
|
-
expect(sut.base.
|
|
19
|
+
expect(sut.base.adapterName).toEqual('xyz');
|
|
20
20
|
expect(sut.quote.name).toEqual('def');
|
|
21
|
-
expect(sut.quote.
|
|
22
|
-
expect(sut.
|
|
21
|
+
expect(sut.quote.adapterName).toEqual('xyz');
|
|
22
|
+
expect(sut.id).toEqual('xyz:abc-def');
|
|
23
23
|
});
|
|
24
|
-
test('should
|
|
24
|
+
test('should construct a instrument selector capital case', () => {
|
|
25
25
|
const sut = (0, instrument_1.instrumentOf)('XYZ:ABC-DEF');
|
|
26
26
|
expect(sut.base.name).toEqual('abc');
|
|
27
|
-
expect(sut.base.
|
|
27
|
+
expect(sut.base.adapterName).toEqual('xyz');
|
|
28
28
|
expect(sut.quote.name).toEqual('def');
|
|
29
|
-
expect(sut.quote.
|
|
30
|
-
expect(sut.
|
|
29
|
+
expect(sut.quote.adapterName).toEqual('xyz');
|
|
30
|
+
expect(sut.id).toEqual('xyz:abc-def');
|
|
31
31
|
});
|
|
32
32
|
test('should throw invalid format message for missing separator', () => {
|
|
33
|
-
const fn = () =>
|
|
34
|
-
|
|
35
|
-
};
|
|
36
|
-
expect(fn).toThrow(Error);
|
|
33
|
+
const fn = () => (0, instrument_1.instrumentOf)('xyzabc-def');
|
|
34
|
+
expect(fn).toThrowError();
|
|
37
35
|
});
|
|
38
36
|
test('should throw invalid format message for multiple separators', () => {
|
|
39
|
-
const fn = () =>
|
|
40
|
-
|
|
41
|
-
};
|
|
42
|
-
expect(fn).toThrow(Error);
|
|
37
|
+
const fn = () => (0, instrument_1.instrumentOf)('xyz:abc:-def');
|
|
38
|
+
expect(fn).toThrowError();
|
|
43
39
|
});
|
|
44
40
|
test('should throw invalid format message for missing pair name', () => {
|
|
45
|
-
const fn = () =>
|
|
46
|
-
|
|
47
|
-
};
|
|
48
|
-
expect(fn).toThrow(Error);
|
|
41
|
+
const fn = () => (0, instrument_1.instrumentOf)('xyz:');
|
|
42
|
+
expect(fn).toThrowError();
|
|
49
43
|
});
|
|
50
44
|
test('should throw invalid format message for missing adapter name', () => {
|
|
51
|
-
const fn = () =>
|
|
52
|
-
|
|
53
|
-
};
|
|
54
|
-
expect(fn).toThrow(Error);
|
|
45
|
+
const fn = () => (0, asset_1.assetOf)(':abc-def');
|
|
46
|
+
expect(fn).toThrowError();
|
|
55
47
|
});
|
|
56
48
|
});
|
|
57
49
|
//# sourceMappingURL=instrument.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"instrument.spec.js","sourceRoot":"","sources":["../../src/domain/instrument.spec.ts"],"names":[],"mappings":";;AAAA,mCAAyC;AACzC,6CAAwD;AAExD,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"instrument.spec.js","sourceRoot":"","sources":["../../src/domain/instrument.spec.ts"],"names":[],"mappings":";;AAAA,mCAAyC;AACzC,6CAAwD;AAExD,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,IAAI,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACzC,MAAM,GAAG,GAAG,IAAI,uBAAU,CACxB,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,SAAS,CACV,CAAC;QAEF,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7C,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,IAAI,CAAC,wCAAwC,EAAE,GAAG,EAAE;QAClD,MAAM,GAAG,GAAG,IAAA,yBAAY,EAAC,aAAa,CAAC,CAAC;QAExC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7C,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC/D,MAAM,GAAG,GAAG,IAAA,yBAAY,EAAC,aAAa,CAAC,CAAC;QAExC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7C,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACrE,MAAM,EAAE,GAAG,GAAG,EAAE,CAAC,IAAA,yBAAY,EAAC,YAAY,CAAC,CAAC;QAE5C,MAAM,CAAC,EAAE,CAAC,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACvE,MAAM,EAAE,GAAG,GAAG,EAAE,CAAC,IAAA,yBAAY,EAAC,cAAc,CAAC,CAAC;QAE9C,MAAM,CAAC,EAAE,CAAC,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACrE,MAAM,EAAE,GAAG,GAAG,EAAE,CAAC,IAAA,yBAAY,EAAC,MAAM,CAAC,CAAC;QAEtC,MAAM,CAAC,EAAE,CAAC,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8DAA8D,EAAE,GAAG,EAAE;QACxE,MAAM,EAAE,GAAG,GAAG,EAAE,CAAC,IAAA,eAAO,EAAC,UAAU,CAAC,CAAC;QAErC,MAAM,CAAC,EAAE,CAAC,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/dist/domain/order.d.ts
CHANGED
|
@@ -1,33 +1,31 @@
|
|
|
1
|
-
import { timestamp } from '../shared';
|
|
1
|
+
import { decimal, timestamp } from '../shared';
|
|
2
|
+
import { Balance } from './balance';
|
|
2
3
|
import { Component } from './component';
|
|
3
4
|
import { InstrumentSelector } from './instrument';
|
|
4
|
-
export declare type OrderSide = 'SELL' | 'BUY';
|
|
5
5
|
export declare type OrderType = 'MARKET' | 'LIMIT' | 'STOP-MARKET' | 'STOP-LIMIT';
|
|
6
6
|
export declare type OrderState = 'NEW' | 'PENDING' | 'FILLED' | 'CANCELING' | 'CANCELED' | 'REJECTED';
|
|
7
7
|
export declare class Order implements Component {
|
|
8
8
|
readonly instrument: InstrumentSelector;
|
|
9
|
-
readonly side: OrderSide;
|
|
10
9
|
readonly type: OrderType;
|
|
11
|
-
readonly quantity:
|
|
12
|
-
readonly rate
|
|
13
|
-
readonly stopRate
|
|
10
|
+
readonly quantity: decimal;
|
|
11
|
+
readonly rate?: decimal;
|
|
12
|
+
readonly stopRate?: decimal;
|
|
14
13
|
kind: string;
|
|
15
14
|
timestamp: timestamp;
|
|
16
15
|
id: string;
|
|
17
16
|
externalId: string;
|
|
18
17
|
state: OrderState;
|
|
19
|
-
quantityExecuted:
|
|
20
|
-
averageExecutionRate:
|
|
18
|
+
quantityExecuted: decimal;
|
|
19
|
+
averageExecutionRate: decimal;
|
|
21
20
|
createdAt: timestamp;
|
|
22
|
-
|
|
23
|
-
static
|
|
24
|
-
static
|
|
25
|
-
static
|
|
26
|
-
|
|
27
|
-
static sellStopMarket(instrument: InstrumentSelector, quantity: number, stopRate: number): Order;
|
|
28
|
-
static buyStopMarket(instrument: InstrumentSelector, quantity: number, stopRate: number): Order;
|
|
29
|
-
static sellStopLimit(instrument: InstrumentSelector, quantity: number, rate: number, stopRate: number): Order;
|
|
30
|
-
static buyStopLimit(instrument: InstrumentSelector, quantity: number, rate: number, stopRate: number): Order;
|
|
31
|
-
constructor(instrument: InstrumentSelector, side: OrderSide, type: OrderType, quantity: number, rate?: number, stopRate?: number);
|
|
21
|
+
static market(instrument: InstrumentSelector, quantity: decimal): Order;
|
|
22
|
+
static limit(instrument: InstrumentSelector, quantity: decimal, rate: decimal): Order;
|
|
23
|
+
static stopMarket(instrument: InstrumentSelector, quantity: decimal, stopRate: decimal): Order;
|
|
24
|
+
static stopLimit(instrument: InstrumentSelector, quantity: decimal, rate: decimal, stopRate: decimal): Order;
|
|
25
|
+
constructor(instrument: InstrumentSelector, type: OrderType, quantity: decimal, rate?: decimal, stopRate?: decimal);
|
|
32
26
|
toString(): string;
|
|
27
|
+
calculateBalanceToLock(base: Balance, quote: Balance): {
|
|
28
|
+
base: decimal;
|
|
29
|
+
quote: decimal;
|
|
30
|
+
};
|
|
33
31
|
}
|
package/dist/domain/order.js
CHANGED
|
@@ -2,10 +2,11 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Order = void 0;
|
|
4
4
|
const uuid_1 = require("uuid");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
6
|
+
const error_1 = require("./error");
|
|
5
7
|
class Order {
|
|
6
|
-
constructor(instrument,
|
|
8
|
+
constructor(instrument, type, quantity, rate, stopRate) {
|
|
7
9
|
this.instrument = instrument;
|
|
8
|
-
this.side = side;
|
|
9
10
|
this.type = type;
|
|
10
11
|
this.quantity = quantity;
|
|
11
12
|
this.rate = rate;
|
|
@@ -13,41 +14,52 @@ class Order {
|
|
|
13
14
|
this.kind = 'order';
|
|
14
15
|
this.id = (0, uuid_1.v4)();
|
|
15
16
|
this.state = 'NEW';
|
|
16
|
-
this.quantityExecuted =
|
|
17
|
-
if (quantity
|
|
18
|
-
throw
|
|
17
|
+
this.quantityExecuted = shared_1.d.Zero;
|
|
18
|
+
if (!quantity || Number.isNaN(quantity)) {
|
|
19
|
+
throw (0, error_1.invalidArgumentError)(quantity);
|
|
19
20
|
}
|
|
20
|
-
if (rate &&
|
|
21
|
-
throw
|
|
21
|
+
if (rate && rate.lessThanOrEqualTo(0)) {
|
|
22
|
+
throw (0, error_1.invalidArgumentError)(rate);
|
|
22
23
|
}
|
|
23
24
|
}
|
|
24
|
-
static
|
|
25
|
-
return new Order(instrument, '
|
|
25
|
+
static market(instrument, quantity) {
|
|
26
|
+
return new Order(instrument, 'MARKET', quantity);
|
|
26
27
|
}
|
|
27
|
-
static
|
|
28
|
-
return new Order(instrument, '
|
|
28
|
+
static limit(instrument, quantity, rate) {
|
|
29
|
+
return new Order(instrument, 'LIMIT', quantity, rate);
|
|
29
30
|
}
|
|
30
|
-
static
|
|
31
|
-
return new Order(instrument, '
|
|
31
|
+
static stopMarket(instrument, quantity, stopRate) {
|
|
32
|
+
return new Order(instrument, 'STOP-MARKET', quantity, undefined, stopRate);
|
|
32
33
|
}
|
|
33
|
-
static
|
|
34
|
-
return new Order(instrument, '
|
|
35
|
-
}
|
|
36
|
-
static sellStopMarket(instrument, quantity, stopRate) {
|
|
37
|
-
return new Order(instrument, 'SELL', 'STOP-MARKET', quantity, null, stopRate);
|
|
38
|
-
}
|
|
39
|
-
static buyStopMarket(instrument, quantity, stopRate) {
|
|
40
|
-
return new Order(instrument, 'BUY', 'STOP-MARKET', quantity, null, stopRate);
|
|
41
|
-
}
|
|
42
|
-
static sellStopLimit(instrument, quantity, rate, stopRate) {
|
|
43
|
-
return new Order(instrument, 'SELL', 'STOP-LIMIT', quantity, rate, stopRate);
|
|
44
|
-
}
|
|
45
|
-
static buyStopLimit(instrument, quantity, rate, stopRate) {
|
|
46
|
-
return new Order(instrument, 'BUY', 'STOP-LIMIT', quantity, rate, stopRate);
|
|
34
|
+
static stopLimit(instrument, quantity, rate, stopRate) {
|
|
35
|
+
return new Order(instrument, 'STOP-LIMIT', quantity, rate, stopRate);
|
|
47
36
|
}
|
|
48
37
|
toString() {
|
|
49
38
|
return this.id;
|
|
50
39
|
}
|
|
40
|
+
calculateBalanceToLock(base, quote) {
|
|
41
|
+
const qty = this.quantity.abs();
|
|
42
|
+
if (this.quantity.greaterThan(0)) {
|
|
43
|
+
switch (this.type) {
|
|
44
|
+
case 'MARKET':
|
|
45
|
+
return {
|
|
46
|
+
base: shared_1.d.Zero,
|
|
47
|
+
quote: quote.free
|
|
48
|
+
};
|
|
49
|
+
case 'LIMIT':
|
|
50
|
+
return {
|
|
51
|
+
base: shared_1.d.Zero,
|
|
52
|
+
quote: quote.asset.ceil(this.rate.mul(qty))
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
if (this.quantity.lessThan(0)) {
|
|
57
|
+
return {
|
|
58
|
+
base: qty,
|
|
59
|
+
quote: shared_1.d.Zero
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
}
|
|
51
63
|
}
|
|
52
64
|
exports.Order = Order;
|
|
53
65
|
//# sourceMappingURL=order.js.map
|
package/dist/domain/order.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"order.js","sourceRoot":"","sources":["../../src/domain/order.ts"],"names":[],"mappings":";;;AAAA,+BAA0B;
|
|
1
|
+
{"version":3,"file":"order.js","sourceRoot":"","sources":["../../src/domain/order.ts"],"names":[],"mappings":";;;AAAA,+BAA0B;AAE1B,sCAAkD;AAGlD,mCAA+C;AAY/C,MAAa,KAAK;IAoChB,YACW,UAA8B,EAC9B,IAAe,EACf,QAAiB,EACjB,IAAc,EACd,QAAkB;QAJlB,eAAU,GAAV,UAAU,CAAoB;QAC9B,SAAI,GAAJ,IAAI,CAAW;QACf,aAAQ,GAAR,QAAQ,CAAS;QACjB,SAAI,GAAJ,IAAI,CAAU;QACd,aAAQ,GAAR,QAAQ,CAAU;QAxC7B,SAAI,GAAG,OAAO,CAAC;QAEf,OAAE,GAAG,IAAA,SAAE,GAAE,CAAC;QAEV,UAAK,GAAe,KAAK,CAAC;QAE1B,qBAAgB,GAAG,UAAC,CAAC,IAAI,CAAC;QAoCxB,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE;YACvC,MAAM,IAAA,4BAAoB,EAAC,QAAQ,CAAC,CAAC;SACtC;QAED,IAAI,IAAI,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE;YACrC,MAAM,IAAA,4BAAoB,EAAC,IAAI,CAAC,CAAC;SAClC;IACH,CAAC;IAvCD,MAAM,CAAC,MAAM,CAAC,UAA8B,EAAE,QAAiB;QAC7D,OAAO,IAAI,KAAK,CAAC,UAAU,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,UAA8B,EAAE,QAAiB,EAAE,IAAa;QAC3E,OAAO,IAAI,KAAK,CAAC,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IACxD,CAAC;IAED,MAAM,CAAC,UAAU,CACf,UAA8B,EAC9B,QAAiB,EACjB,QAAiB;QAEjB,OAAO,IAAI,KAAK,CAAC,UAAU,EAAE,aAAa,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;IAC7E,CAAC;IAED,MAAM,CAAC,SAAS,CACd,UAA8B,EAC9B,QAAiB,EACjB,IAAa,EACb,QAAiB;QAEjB,OAAO,IAAI,KAAK,CAAC,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC;IACvE,CAAC;IAkBD,QAAQ;QACN,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;IAED,sBAAsB,CACpB,IAAa,EACb,KAAc;QAEd,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAEhC,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE;YAChC,QAAQ,IAAI,CAAC,IAAI,EAAE;gBACjB,KAAK,QAAQ;oBACX,OAAO;wBACL,IAAI,EAAE,UAAC,CAAC,IAAI;wBACZ,KAAK,EAAE,KAAK,CAAC,IAAI;qBAClB,CAAC;gBAEJ,KAAK,OAAO;oBACV,OAAO;wBACL,IAAI,EAAE,UAAC,CAAC,IAAI;wBACZ,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;qBAC5C,CAAC;aACL;SACF;QAED,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;YAC7B,OAAO;gBACL,IAAI,EAAE,GAAG;gBACT,KAAK,EAAE,UAAC,CAAC,IAAI;aACd,CAAC;SACH;IACH,CAAC;CACF;AArFD,sBAqFC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Observable } from 'rxjs';
|
|
2
|
+
import { State } from '../store';
|
|
3
|
+
import { Component } from './component';
|
|
4
|
+
import { InstrumentSelector } from './instrument';
|
|
5
|
+
import { Order } from './order';
|
|
6
|
+
export declare function order(selector: InstrumentSelector): (source$: Observable<Component>) => Observable<Order>;
|
|
7
|
+
export declare function orders(selector: InstrumentSelector, state: State): (source$: Observable<Component>) => Observable<readonly Order[]>;
|