UNPKG

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