diff --git a/.babelrc b/.babelrc
index 15aa9d00e..d7d00389e 100644
--- a/.babelrc
+++ b/.babelrc
@@ -1,5 +1,6 @@
{
"presets": ["react", "es2015", "stage-0"],
+ "plugins": ["transform-decorators-legacy"],
"env": {
"development": {
"presets": ["react-hmre"]
diff --git a/package.json b/package.json
index e682cef5b..7cb40f291 100644
--- a/package.json
+++ b/package.json
@@ -26,6 +26,7 @@
"babel-core": "^6.4.5",
"babel-eslint": "^4.1.8",
"babel-loader": "^6.2.1",
+ "babel-plugin-transform-decorators-legacy": "^1.3.4",
"babel-polyfill": "^6.7.4",
"babel-preset-es2015": "^6.3.13",
"babel-preset-react": "^6.3.13",
@@ -69,6 +70,9 @@
"lodash": "^4.13.1",
"lodash.orderby": "^4.4.0",
"marked": "^0.3.5",
+ "mobx": "^2.2.2",
+ "mobx-react": "^3.3.0",
+ "mobx-react-devtools": "^4.2.0",
"moment": "^2.13.0",
"node-dev": "^3.1.0",
"node-sass": "^3.4.2",
@@ -110,10 +114,11 @@
"webpack": "^1.12.12"
},
"devDependencies": {
+ "babel-regenerator-runtime": "^6.5.0",
+ "fsevents": "^1.0.11",
"koa-webpack-dev-middleware": "^1.2.0",
"koa-webpack-hot-middleware": "^1.0.3",
"node-dev": "^3.1.0",
- "nodemon": "^1.9.1",
- "fsevents": "^1.0.11"
+ "nodemon": "^1.9.1"
}
}
diff --git a/src/index.js b/src/index.js
index 7629245f5..82da57d3d 100644
--- a/src/index.js
+++ b/src/index.js
@@ -10,6 +10,8 @@ import { persistStore, autoRehydrate } from 'redux-persist';
import thunkMiddleware from 'redux-thunk';
import createLogger from 'redux-logger';
import History from 'utils/History';
+import { useStrict } from 'mobx';
+import DevTools from 'mobx-react-devtools';
import auth from 'utils/auth';
@@ -31,6 +33,9 @@ import DocumentScene from 'scenes/DocumentScene';
import DocumentEdit from 'scenes/DocumentEdit';
import SlackAuth from 'scenes/SlackAuth';
+// MobX
+useStrict(true);
+
// Redux
let store;
const routerMiddlewareWithHistory = routerMiddleware(History);
@@ -61,16 +66,18 @@ persistStore(store, {
-
-
-
-
-
+
+
+
+
+
-
-
-
-
+
+
+
+
+ { __DEV__ ? : null }
+
), document.getElementById('root'));
});
diff --git a/webpack.config.dev.js b/webpack.config.dev.js
index 154c4d4ba..a83d608f1 100644
--- a/webpack.config.dev.js
+++ b/webpack.config.dev.js
@@ -8,6 +8,7 @@ const developmentWebpackConfig = Object.assign(commonWebpackConfig, {
cache: true,
devtool: 'eval',
entry: [
+ 'babel-regenerator-runtime',
'webpack-hot-middleware/client',
'./src/index',
],