aboutsummaryrefslogtreecommitdiffstats
path: root/packages/website/ts/redux/analyticsMiddleware.ts
diff options
context:
space:
mode:
authorLeonid Logvinov <logvinov.leon@gmail.com>2018-07-16 20:38:51 +0800
committerLeonid Logvinov <logvinov.leon@gmail.com>2018-07-16 20:38:51 +0800
commitf9bcf936edbb74acce145af94d23b4945e699f63 (patch)
treefaeacf408e908159f923bae70a4d67e947aba458 /packages/website/ts/redux/analyticsMiddleware.ts
parent658214a2e24d3f50aacbc078317358d510e9c351 (diff)
parentacff177c547dee049b97e4b051fe22e1efaf992c (diff)
downloaddexon-sol-tools-f9bcf936edbb74acce145af94d23b4945e699f63.tar
dexon-sol-tools-f9bcf936edbb74acce145af94d23b4945e699f63.tar.gz
dexon-sol-tools-f9bcf936edbb74acce145af94d23b4945e699f63.tar.bz2
dexon-sol-tools-f9bcf936edbb74acce145af94d23b4945e699f63.tar.lz
dexon-sol-tools-f9bcf936edbb74acce145af94d23b4945e699f63.tar.xz
dexon-sol-tools-f9bcf936edbb74acce145af94d23b4945e699f63.tar.zst
dexon-sol-tools-f9bcf936edbb74acce145af94d23b4945e699f63.zip
Merge branch 'feature/order-watcher-v2' into feature/order-watcher-erc721-tests
Diffstat (limited to 'packages/website/ts/redux/analyticsMiddleware.ts')
-rw-r--r--packages/website/ts/redux/analyticsMiddleware.ts36
1 files changed, 36 insertions, 0 deletions
diff --git a/packages/website/ts/redux/analyticsMiddleware.ts b/packages/website/ts/redux/analyticsMiddleware.ts
new file mode 100644
index 000000000..51d39a5d7
--- /dev/null
+++ b/packages/website/ts/redux/analyticsMiddleware.ts
@@ -0,0 +1,36 @@
+import { Middleware } from 'redux';
+import { State } from 'ts/redux/reducer';
+import { ActionTypes } from 'ts/types';
+import { analytics } from 'ts/utils/analytics';
+
+export const analyticsMiddleware: Middleware = store => next => action => {
+ const nextAction = next(action);
+ const nextState = (store.getState() as any) as State;
+ switch (action.type) {
+ case ActionTypes.UpdateInjectedProviderName:
+ analytics.addEventProperties({
+ injectedProviderName: nextState.injectedProviderName,
+ });
+ break;
+ case ActionTypes.UpdateNetworkId:
+ analytics.addEventProperties({
+ networkId: nextState.networkId,
+ });
+ break;
+ case ActionTypes.UpdateUserAddress:
+ analytics.addUserProperties({
+ ethAddress: nextState.userAddress,
+ });
+ break;
+ case ActionTypes.UpdateUserEtherBalance:
+ if (nextState.userEtherBalanceInWei) {
+ analytics.addUserProperties({
+ ethBalance: nextState.userEtherBalanceInWei.toString(),
+ });
+ }
+ break;
+ default:
+ break;
+ }
+ return nextAction;
+};