UNPKG

26.1 kBMarkdownView Raw
1# MobX-React Changelog
2
3### 6.1.0
4
5- Restored the classic implementation of `observer`: class based components are patched again, rather than wrapping them in `<Observer>`, see [#703](https://github.com/mobxjs/mobx-react/pull/703). Fixes:
6 - `componentDidUpdate` not being triggered after a reactive render [#692](https://github.com/mobxjs/mobx-react/issues/692)
7 - The appearance of an additional `<Observer>` component in the component tree, which complicates shallow testing [#699](https://github.com/mobxjs/mobx-react/issues/699)
8 - Some regressions in `disposeOnUnmount` [#702](https://github.com/mobxjs/mobx-react/issues/702)
9 - Note that dev tool support, and other constraints mentioned in the 6.0.0 release notes have not been restored.
10- The function `useStaticRendering(value: boolean): void` from mobx-react-lite is now exposed
11
12### 6.0.4
13
14- Fixed IE 11 compatibility which was accidentally broken. Fixes [#698](https://github.com/mobxjs/mobx-react/issues/698)
15
16### 6.0.3
17
18- `disposeOnUnmount` now supports initializing it with an array of disposers. Fixes [#637](https://github.com/mobxjs/mobx-react/pull/637) through [#641](https://github.com/mobxjs/mobx-react/pull/641) by [@Amareis](https://github.com/Amareis)
19- Fixed hoisting of statically declared members. Fixes [#678](https://github.com/mobxjs/mobx-react/issues/678) through [#682](https://github.com/mobxjs/mobx-react/pull/682) by [@meabed](https://github.com/meabed)
20
21### 6.0.2
22
23- Added missing types for `MobXProviderContext`, `useLocalStore` and `useAsObservableSource`. Fixes #679.
24
25### 6.0.0
26
27**Breaking changes**
28
29- The minimal supported version of React is 16.8.0
30- Killed the possibility to directly pass store names to `observer`. Always use `inject` instead. (This was deprecated for a long time already). `observer(["a", "b"], component)` should now be written as `inject("a", "b")(component)`.
31- `observer` components no longer automatically recover from errors (to prevent potential memory leaks). Instead, this is the responsibility of error boundaries.
32- `inject` now supports ref forwarding. As such, the `.wrappedInstance` property has been removed since refs can be used instead. (Fixes [#616](https://github.com/mobxjs/mobx-react/issues/616) (See also [#619](https://github.com/mobxjs/mobx-react/pull/619) by [42shadow42](https://github.com/42shadow42))
33- Changing the set of stores in `Provider` is no longer supported and while throw a hard error (this was a warning before), as the model of `Provider` / `inject` has always been designed to inject final values into the tree. (That is, constanted references, the injected objects themselves can be stateful without problem). If you want to dynamically swap what is provided into the tree, use `React.createContext` instead of `Provider` / `inject`. The suppressChangedStoreWarning`flag for`Provider` has been dropped.
34- The third argument of custom `storesToProps` functions passed to `inject` is no longer available.
35- `<Observer>` no longer supports the deprecated `inject` property.
36- Defining `shouldComponentUpdate` on `observer` based components is no longer supported
37- `propTypes` is no longer exposed, use `PropTypes` instead
38- `disposeOnUnmount` now only supports direct subclasses of `React.Component` and `React.PureComponent`. This prevents several unreliable edge cases that silently leaked memory before. Either only extend React.(Pure)Component when using `disposeOnUnmount`, or manually clean up stuff in `componentWillUnmount`.
39- The `onError` global error handler has been removed. Use error boundaries instead.
40- Improved dev tool names for `inject` wrapped components, see [#472](https://github.com/mobxjs/mobx-react/pull/472) by [SimeonC](https://github.com/SimeonC). Fixes [#466](https://github.com/mobxjs/mobx-react/issues/466)
41- Dropped support for a build of mobx-react that doesn't target either `react-dom` or `react-native`. mobx-react doesn't need `react-dom` to be present, but to make sure your build tools don't fail, you might want to stub `react-dom` as an empty module.
42- The `componentWillReact` has been dropped
43- The MobX-react devtools (either as package or browser plugin) are no longer supported. Instead, the following tools can be analyzed to analyze your mobx-react application:
44 - Visualizing re-rendering of components is now part of the standard React devtools
45 - The dependency tree of a compent tree can be inspected by showing the state of the `useObserver` hook in the React devtools (at the time of this release it displays as just `Object`, but the next iteration of the React devtools will support those properly)
46 - Spying on events can still be done with the [MobX-react browser plugin](https://github.com/mobxjs/mobx-devtools), through the [mobx-logger](https://github.com/winterbe/mobx-logger) package or manually by using the `spy` or `trace` utility from the mobx package.
47
48**Improvements**
49
50- Hook based components are now supported by mobx-react (in fact, the package is now implemented using hooks)
51- Using `PureComponent` is now _recommended_.
52- For `observer` based components, there will now be an additional `Observer` component in the tree.
53- Two new hooks have been exposed, in case you want to manage local state in observable: `useLocalStore` and `useAsObservableSource`.
54- `MobXProviderContext` is now exposed from the package, in case you want to consume the context used by `Provider` with a `useContext` hook.
55
56### 5.4.3
57
58- Fixed [#612](https://github.com/mobxjs/mobx-react/issues/612), `contextType` was hoisted by `inject`, which shouldn't the case.
59
60### 5.4.1 / 5.4.2
61
62- Fixed issue where `react-is` wasn't properly rolled-up into the package. Fixes [#608](https://github.com/mobxjs/mobx-react/issues/608)
63
64### 5.4.0
65
66- Added support for forward refs, fixes [#602](https://github.com/mobxjs/mobx-react/issues/602)
67
68### 5.3.6
69
70- Fixed some additional issues around life-cycle patching, take 3. See [#536](https://github.com/mobxjs/mobx-react/pull/586) by [@xaviergonz](https://github.com/xaviergonz). Fixed [#579](https://github.com/mobxjs/mobx-react/issues/579)
71
72### 5.3.5
73
74- Fixed some additional issues around life-cycle patching, see [#583](https://github.com/mobxjs/mobx-react/pull/583) by [@xaviergonz](https://github.com/xaviergonz). Fixed [#581](https://github.com/mobxjs/mobx-react/issues/581)
75
76### 5.3.4
77
78- Fixed unending recursing as a result of lifecylce patching. Fixes [#579](https://github.com/mobxjs/mobx-react/issues/579) through [#582](https://github.com/mobxjs/mobx-react/pull/582) by [@xaviergonz](https://github.com/xaviergonz)
79
80### 5.3.3
81
82- Fixed `Cannot read property 'forEach' of undefined` exception if `disposeOnUnmount` was called conditionally. [#578](https://github.com/mobxjs/mobx-react/pull/578) by [Jef Hellemans](https://github.com/JefHellemans)
83
84### 5.3.2
85
86- Fixed: "process not defined", [#574](https://github.com/mobxjs/mobx-react/pull/574/) through [#576](https://github.com/mobxjs/mobx-react/pull/576/) by [@xaviergonz](https://github.com/xaviergonz)
87
88### 5.3.0 / 5.3.1
89
90_5.3.0 was retracted as files were not generated correctly during publish_
91
92- Added `disposeOnUnmount` utility / decorator to call disposable properties (reaction, autorun, etc) automatically on `componentWillUnmount`
93- Introduced new method to patch lifecycle methods which should be more compatible with for example arrow functions.
94
95### 5.2.8
96
97- Make sure `mobx-react` doesn't require `Object.assign` polyfill
98
99### 5.2.7
100
101- Fixed issue where React 16.5 printed a warning when using `Provider`, fixes [#545](https://github.com/mobxjs/mobx-react/issues/545)
102
103### 5.2.6
104
105- Fixed bug in defining properties (although the bug had no known observable effect). Fixes [#540](https://github.com/mobxjs/mobx-react/issues/540)
106
107### 5.2.4 / 5.2.5
108
109- Improved compatibility with React-Hot-Loader, see [#522](https://github.com/mobxjs/mobx-react/pull/522) by [theKashey](https://github.com/theKashey). Fixes [#500](https://github.com/mobxjs/mobx-react/issues/500)
110
111### 5.2.3
112
113- Fixed problem with `Symbol` feature detection. By [@Strate](https://github.com/Strate) through [#501](https://github.com/mobxjs/mobx-react/pull/501). Fixes [#498](https://github.com/mobxjs/mobx-react/issues/498) and [#503](https://github.com/mobxjs/mobx-react/issues/503).
114
115### 5.2.2
116
117- Polyfill `Symbol` if it doesn't exist. By [@Strate](https://github.com/Strate) through [#499](https://github.com/mobxjs/mobx-react/pull/499).
118
119### 5.2.1
120
121- Component `props` and `state` properties are now made observable during the instance creation. This restores the behavior from before 5.1.0 where `props` and `state` could safely be observed during mount. Actually it is now possible to do similar things in constructors as well. Fixes [#478](https://github.com/mobxjs/mobx-react/issues/478). Thanks [@Strate](https://github.com/Strate) for the idea and PR! [#496](https://github.com/mobxjs/mobx-react/pull/496).
122
123### 5.2.0
124
125- Added backward compatible support for MobX 5.
126- Fixed components sometimes being displayed as `undefined` in mobx-devtools. See [#470](https://github.com/mobxjs/mobx-react/pull/470) by [@MauricioAndrades](https://github.com/MauricioAndrades)
127- Removed unnecessary warning `@observer` was used both on a sub and super class. See [#492](https://github.com/mobxjs/mobx-react/pull/476) by [@skiritsis](https://github.com/skiritsis). _N.B. putting `@observer` on a super and subclass is still not an supported pattern, use @observer on subclasses only!_
128
129### 5.1.2
130
131- Fixed regression bug in integration with devtools. Fixed through [#465](https://github.com/mobxjs/mobx-react/pull/465) by @le0nik
132
133### 5.1.0
134
135- Added support for React 16.3, including support for the `getDerivedStateFromProps` life-cycle hook. MobX will no longer use `componentWillMount` hook internally, so that it can be used in `StrictMode` react as well. Fixes [#447](https://github.com/mobx/mobx-react/447)
136- Static properties of a function component are now automatically hoisted when the component is wrapped by `observer`. Implements [#427](https://github.com/mobx/mobx-react/427)
137- Misspelled export `componentByNodeRegistery` is now properly export as `componentByNodeRegistry` as well, please update consumers, the mispelled version will be dropped in the next major. Fixes [#421](https://github.com/mobx/mobx-react/421)
138- Deprecated the support for the `inject` property on `Observer`, it is fundamentally broken and should not be used. Use `inject` on the enclosing component instead and grab the necessary stores from the closure. Fixes [#423](https://github.com/mobx/mobx-react/423)
139- Added warning about using `observer` on a React.PureComponent, this will become an exception in the next major. Fixes [#309](https://github.com/mobx/mobx-react/309)
140- Mobx-react will now print a warning when combining `observer` with a custom `shouldComponentUpdate` implementation. Fixes [#417](https://github.com/mobx/mobx-react/417)
141
142### 5.0.0
143
144- Added compatibility with MobX 4.x. This version is not compatible with older Mobx versions
145
146### 4.4.3
147
148- The exposed React Native build now uses commonjs, to prevent the need of further transpilation. Fixes [#428](https://github.com/mobxjs/mobx-react/issues/428)
149
150### 4.4.2
151
152- Fixed issue with mobx-react not compiling on react-native due to the presence of a `.babelrc` file. Fixes [#415](https://github.com/mobxjs/mobx-react/issues/415) by [Ryan Rampersad](https://github.com/ryanmr) through [#416](https://github.com/mobxjs/mobx-react/pull/416)
153
154### 4.4.1
155
156- Fixed syntax error in 4.4.0 that escaped
157
158### 4.4.0
159
160- `Observer` now supports render props, `render` and `inject`. See the updated readme. By [ZiYingMai](https://github.com/Sunshine168) through [#403](https://github.com/mobxjs/mobx-react/pull/403)
161- Fixed: `NaN` is now considered to be equal to `NaN` when doing reconciliation. Fixes [#363](https://github.com/mobxjs/mobx-react/issues/363), by [Andrew Branch](https://github.com/andrewbranch) through [#402](https://github.com/mobxjs/mobx-react/pull/402)
162- Improved typings of `Observer` component, by [Rafał Filipek](https://github.com/RafalFilipek) through [#376](https://github.com/mobxjs/mobx-react/pull/376)
163- Fixed incorrect generation of component name, by [Andy Kogut](https://github.com/andykog) through [#368](https://github.com/mobxjs/mobx-react/pull/368)
164- Lot of internal repo upgrades: Test suite is now in Jest, Prettier is used etc.
165
166### 4.3.5
167
168Fixed some issues with the typescript typings. See for example #353
169
170### 4.3.4
171
172Improved typescript typings, including support for `strict` mode in TS 2.6. Fixes
173
174### 4.3.3
175
176Added support for React 16. (No changes)
177
178### 4.3.2
179
180Killed accidentally exposed default exports.
181
182If you are still using `import mobxReact from "mobx-react"`, use `import * as mobxReact from "mobx-react"`, or better `import { whatYouNeed } from "mobx-react"` instead.
183
184### 4.3.1
185
186### 4.3.0 (unpublished)
187
188Improved module rollup setup, enabling better tree shaking. See #324 / #328
189
190### 4.2.2
191
192- Fixed check for stateless components, by @leader22, see #280
193
194### 4.2.1
195
196_Note: Due to pull / rebase issue the release commit is incorrect. This is the released [commit](https://github.com/mobxjs/mobx-react/commit/f1b3eefc5239cb451b317204fa8aad94b4dcfc2f)_
197
198- Reduced module size by 31% (switched to rollup.js). See #244 by @rossipedia
199- Skip creation of `.wrappedInstance` reference for stateless components. See #254 by @farwayer
200- Introduced global `onError` handler hook to be notified on errors thrown by `@observer` components. See #262 by @andykog
201- Improved typescript typings of the exposed `propTypes`, See #263 by @panjiesw
202
203### 4.2.0
204
205- Same as 4.2.1, but contained build issue and is unpublished
206
207### 4.1.8
208
209- Undid change introduced in 4.1.4 where the lifecycle hooks were protected, as this breaks react-hot-loader.... Fixes #231
210
211### 4.1.7
212
213- Added support for React 15.5 (no deprecation warnings) and 16.0 (no proptypes / createClass), by @andykog, see #238. Fixes #233, #237
214
215### 4.1.5
216
217- Improved typescript typings, fixes #223
218
219### 4.1.4
220
221- Made lifecycle hooks used by mobx-react read-only to make sure they are not accidentally overwritten in component instances. Fixes, #195, #202. Note that they can still be defined, just make sure to define them on the prototype (`componentWillMount() {}`) instead of the instance (`componentWillMount = () => {}`). Which is best practice anyway.
222
223### 4.1.3
224
225- Fixed `ReactDOM.findDOMNode` exception when using react-test-runner, #216
226
227### 4.1.2
228
229- Exceptions caught during render are now rethrown with proper stack, fixes #206
230
231### 4.1.1
232
233- Exposed `wrappedInstance` and `wrappedComponent` in typings
234- Fixed accidental use of `default` import from `mobx` package.
235
236### 4.1.0
237
238- Added support for MobX3. Note that using MobX3 changes the error semantics. If an `observer` component throws, it will no longer crash the app, but just log the exceptions instead.
239
240### 4.0.4
241
242- Introduced `suppressChangedStoreWarning` to optionally supresss change store warnings, by @dropfen, see #182, #183
243
244### 4.0.3
245
246- Fixed issue where userland componentWilMount was run before observer componentWillMount
247
248### 4.0.2
249
250- Fixed order of `inject` overloads, see #169
251- Fixed import of `mobx` when using Webpack without commonjs plugin, see: #168
252
253### 4.0.1
254
255- Improved typings, by @timmolendijk, fixes #164, #166
256- Fixed `inject` signature in readme, by @farwayer
257
258### 4.0.0
259
260#### `observer` now uses shallow comparision for all props _(Breaking change)_
261
262`observer` used to compare all properties shallow in the built-in _shouldComponentUpdate_, except when it received
263non-observable data structures.
264Because mobx-react cannot know whether a non observable has been deeply modified, it took no chances and just re-renders.
265
266However, the downside of this when an unchanged, non-observable object is passed in to an observer component again, it would still cause a re-render.
267Objects such as styling etc. To fix this mobx-react will now always compare all properties in a pure manner.
268In general this should cause no trouble, as typically mutable data in mobx based objects is captured in observable objects, which will still cause components to re-render if needed.
269
270If you need to pass in a deeply modified object and still want to make sure to cause a re-render, either
271
272- make sure the object / array is an observable
273- do not decorate your component with `observer`, but use `Observer` regions instead (see below)
274
275See [#160](https://github.com/mobxjs/mobx-react/issues/160) for more details.
276
277#### `inject(fn)(component)` will now track `fn` as well
278
279`inject(func)` is now reactive as well, that means that transformations in the selector function will be tracked, see [#111](https://github.com/mobxjs/mobx-react/issues/111)
280
281```javascript
282const NameDisplayer = ({ name }) => <h1>{name}</h1>
283
284const UserNameDisplayer = inject(stores => ({
285 name: stores.userStore.name
286}))(NameDisplayer)
287
288const user = mobx.observable({
289 name: "Noa"
290})
291
292const App = () => (
293 <Provider userStore={user}>
294 <UserNameDisplayer />
295 </Provider>
296)
297
298ReactDOM.render(<App />, document.body)
299```
300
301_N.B. note that in this specific case NameDisplayer doesn't have to be an `observer`, as it doesn't receive observables, but just plain data from the transformer function._
302
303#### `this.props` and `this.state` in React components are now observables as well
304
305A common cause of confusion were cases like:
306
307```javascript
308@observer class MyComponent() {
309 @computed upperCaseName() {
310 return this.props.user.name.toUpperCase()
311 }
312
313 render() {
314 return <h1>{this.upperCaseName}</h1>
315 }
316}
317```
318
319This component would re-render if `user.name` was modified, but it would still render the previous user's name if a complete new user was received!
320The reason for that is that in the above example the only observable tracked by the computed value is `user.name`, but not `this.props.user`.
321So a change to the first would be picked up, but a change in `props` itself, assigning a new user, not.
322
323Although this is technically correct, it was a source of confusion.
324For that reason `this.state` and `this.props` are now automatically converted to observables in any `observer` based react component.
325For more details, see [#136](https://github.com/mobxjs/mobx-react/pull/136) by @Strate
326
327#### Better support for Server Side Rendering
328
329Introduced `useStaticRendering(boolean)` to better support server-side rendering scenarios. See [#140](https://github.com/mobxjs/mobx-react/issues/140)
330
331#### Introduced `Observer` as alternative syntax to the `observer` decorator.
332
333_This feature is still experimental and might change in the next minor release, or be deprecated_
334
335Introduced `Observer`. Can be used as alternative to the `observer` decorator. Marks a component region as reactive.
336See the Readme / [#138](https://github.com/mobxjs/mobx-react/issues/138)
337Example:
338
339```javascript
340const UserNameDisplayer = ({ user }) => <Observer>{() => <div>{user.name}</div>}</Observer>
341```
342
343#### Using `observer` to inject stores is deprecated
344
345The fact that `observer` could inject stores as well caused quite some confusion.
346Because in some cases `observer` would return the original component (when not inject), but it would return a HoC when injecting.
347To make this more consistent, you should always use `inject` to inject stores into a component. So use:
348
349```
350@inject("store1", "store2") @observer
351class MyComponent extends React.Component {
352```
353
354or:
355
356```
357const MyComponent = inject("store1", "store2")(observer(props => rendering))
358```
359
360For more info see the related [discussion](https://github.com/mobxjs/mobx-react/commit/666577b41b7af8209839e7b243064a31c9951632#commitcomment-19773706)
361
362#### Other improvements
363
364- If `mobx` and `mobx-react` are used in combination, all reactions are run as part of React's batched updates. This minimizes the work of the reconciler, guarantees optimal rendering order of components (if the rendering was not triggered from within a React event). Tnx @gkaemmer for the suggestion.
365- It is now possible to directly define `propTypes` and `defaultProps` on components wrapped with `inject` (or `observer(["stores"])`) again, see #120, #142. Removed the warnings for this, and instead improved the docs.
366- Clean up data subscriptions if an error is thrown by an `observer` component, see [#134](https://github.com/mobxjs/mobx-react/pull/134) by @andykog
367- export `PropTypes` as well in typescript typings, fixes #153
368- Add react as a peer dependency
369- Added minified browser build: `index.min.js`, fixes #147
370- Generate better component names when using `inject`
371
372---
373
374### 3.5.9
375
376- Print warning when `inject` and `observer` are used in the wrong order, see #146, by @delaetthomas
377
378### 3.5.8
379
380- Fixed issue where `props` where not passed properly to components in very rare cases. Also fixed #115
381
382### 3.5.7
383
384- Bundles are no longer minified, fixes #127
385
386### 3.5.6
387
388- Export `propTypes` as `PropTypes`, like React (@andykog, ##117)
389
390### 3.5.5
391
392- Removed `experimental` status of `inject` / `Provider`. Official feature now.
393- Fixed hot-reloading issue, #101
394
395### 3.5.4
396
397- Introduced `wrappedInstance` by @rossipedia on `inject` decorated HOC's, see https://github.com/mobxjs/mobx-react/pull/90/
398- print warnings when assign values to `propTypes`, `defaultProps`, or `contextTypes` of a HOC. (by @jtraub, see https://github.com/mobxjs/mobx-react/pull/88/)
399- Static properties are now hoisted to HoC components when, #92
400- If `inject` is used incombination with a function, the object return from the function will now be merged into the `nextProps` instead of replacing them, #80
401- Always do propType checking untracked, partially fixes #56, #305
402
403### 3.5.3
404
405- Fixed error `Cannot read property 'renderReporter' of undefined` (#96)
406
407### 3.5.2
408
409- Added propTypes.observableArrayOf and propTypes.arrayOrObservableArrayOf (#91)
410
411### 3.5.1
412
413- Fixed regression #85, changes caused by the constructor results in inconsistent rendering (N.B.: that is un-idiomatic React usage and React will warn about this!)
414
415### 3.5.0
416
417- Introduced `inject("store1", "store2")(component)` as alternative syntax to inject stores. Should address #77, #70
418- Introduced the `wrappedComponent` property on injected higher order components, addresses #70, #72
419- Fixed #76: error when no stores are provided through context
420- Added typings for devTools related features (@benjamingr).
421- Added MobX specific propTypes (@mattruby)
422- Merged #44, fixes #73: don't re-render if component was somehow unmounted
423
424### 3.4.0
425
426- Introduced `Provider` / context support (#53 / MobX #300)
427- Fixed issues when using devtools with IE. #66 (By @pvasek)
428
429### 3.3.1
430
431- Added typescript typings form `mobx-react/native` and `mobx-react/custom`
432- Fixed #63: error when using stateless function components when using babel and typescript
433
434### 3.3.0
435
436- Upgraded to MobX 2.2.0
437
438### 3.2.0
439
440- Added support for react-native 0.25 and higher. By @danieldunderfelt.
441
442### 3.1.0
443
444- Added support for custom renderers (without DOM), use: `mobx-react/custom` as import fixes #42
445- Fixed some issues with rollup #43
446- Minor optimization
447
448### 3.0.5
449
450Introduced `componentWillReact`
451
452### 3.0.4
453
454The debug name stateless function components of babel transpiled jsx are now properly picked up if the wrapper is applied after defining the component:
455
456```javascript
457const MyComponent = () => <span>hi</span>
458
459export default observer(MyComponent)
460```
461
462### 3.0.3
463
464Removed peer dependencies, React 15 (and 0.13) are supported as well. By @bkniffler
465
466### 3.0.2
467
468Removed the warning introduced in 3.0.1. It triggered always when using shallow rendering (when using shallow rendering `componentDidMount` won't fire. See https://github.com/facebook/react/issues/4919).
469
470### 3.0.1
471
472Added warning when changing state in `getInitialState` / `constructor`.
473
474### 3.0.0
475
476Upgraded to MobX 2.0.0
477
478### 2.1.5
479
480Improved typescript typings overloads of `observer`
481
482### 2.1.4
483
484Added empty 'dependencies' section to package.json, fixes #26
485
486### 2.1.3
487
488Added support for context to stateless components. (by Kosta-Github).
489
490### 2.1.1
491
492Fixed #12: fixed React warning when a component was unmounted after scheduling a re-render but before executing it.
493
494### 2.1.0
495
496Upped dependency of mobx to 1.1.1.
497
498### 2.0.1
499
500It is now possible to define `propTypes` and `getDefaultProps` on a stateless component:
501
502```javascript
503const myComponent = props => {
504 // render
505}
506
507myComponent.propTypes = {
508 name: React.PropTypes.string
509}
510
511myComponent.defaultProps = {
512 name: "World"
513}
514
515export default observer(myComponent)
516```
517
518All credits to Jiri Spac for this contribution!
519
520### 2.0.0
521
522Use React 0.14 instead of React 0.13. For React 0.13, use version `mobx-react@1.0.2` or higher.
523
524### 1.0.2
525
526Minor fixes and improvements
527
528### 1.0.1
529
530Fixed issue with typescript typings. An example project with MobX, React, Typescript, TSX can be found here: https://github.com/mobxjs/mobx-react-typescript
531
532### 1.0.0
533
534`reactiveComponent` has been renamed to `observer`
535
536### 0.2.3
537
538Added separte import for react-native: use `var reactiveComponent = require('mobx-react/native').reactiveComponent` for native support; webpack clients will refuse to build otherwise.
539
540### 0.2.2
541
542Added react-native as dependency, so that the package works with either `react` or `react-native`.
543
544### 0.2.0
545
546Upgraded to MobX 0.7.0
547
548### 0.1.7
549
550Fixed issue where Babel generated component classes where not properly picked up.
551
552### 0.1.6
553
554`observer` now accepts a pure render function as argument, besides constructor function. For example:
555
556```javascript
557var TodoItem = observer(function TodoItem(props) {
558 var todo = props.todo
559 return <li>{todo.task}</li>
560})
561```
562
563### 0.1.5
564
565observer is now defined in terms of side effects.
566
567### 0.1.4
568
569Added support for React 0.14(RC) by dropping peer dependency