react_on_rails 12.3.0 → 12.4.0.rc.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (47) hide show
  1. checksums.yaml +4 -4
  2. data/.circleci/config.yml +12 -10
  3. data/CHANGELOG.md +21 -15
  4. data/NEWS.md +9 -3
  5. data/README.md +12 -308
  6. data/SUMMARY.md +12 -12
  7. data/docs/additional-details/generator-details.md +1 -1
  8. data/docs/additional-details/manual-installation-overview.md +2 -2
  9. data/docs/api/view-helpers-api.md +4 -4
  10. data/docs/contributor-info/linters.md +1 -1
  11. data/docs/contributor-info/pull-requests.md +1 -1
  12. data/docs/{basics → guides}/client-vs-server-rendering.md +1 -1
  13. data/docs/{basics → guides}/configuration.md +0 -0
  14. data/docs/{basics → guides}/deployment.md +1 -1
  15. data/docs/guides/getting-started.md +183 -0
  16. data/docs/{basics → guides}/hmr-and-hot-reloading-with-the-webpack-dev-server.md +0 -0
  17. data/docs/{basics → guides}/how-react-on-rails-works.md +3 -1
  18. data/docs/guides/how-to-conditionally-server-render-based-on-device-type.md +39 -0
  19. data/docs/guides/how-to-use-different-files-for-client-and-server-rendering.md +98 -0
  20. data/docs/{basics → guides}/i18n.md +0 -0
  21. data/docs/{basics → guides}/installation-into-an-existing-rails-app.md +3 -3
  22. data/docs/{basics → guides}/minitest-configuration.md +0 -0
  23. data/docs/{rails-webpacker-react-integration-options.md → guides/rails-webpacker-react-integration-options.md} +1 -1
  24. data/docs/guides/react-on-rails-overview.md +30 -0
  25. data/docs/{basics → guides}/react-server-rendering.md +2 -2
  26. data/docs/{basics → guides}/render-functions-and-railscontext.md +0 -0
  27. data/docs/{basics → guides}/rspec-configuration.md +2 -2
  28. data/docs/{basics → guides}/tutorial.md +2 -4
  29. data/docs/{basics → guides}/upgrading-react-on-rails.md +1 -1
  30. data/docs/{basics → guides}/webpack-configuration.md +1 -1
  31. data/docs/home.md +19 -378
  32. data/docs/javascript/code-splitting.md +2 -2
  33. data/docs/misc/articles.md +1 -1
  34. data/docs/misc/doctrine.md +3 -3
  35. data/docs/outdated/rails-assets-relative-paths.md +2 -2
  36. data/docs/outdated/rails-assets.md +1 -1
  37. data/docs/rails/convert-rails-5-api-only-app.md +1 -1
  38. data/docs/rails/rails-engine-integration.md +3 -12
  39. data/docs/react-on-rails-pro/react-on-rails-pro.md +43 -0
  40. data/docs/testimonials/testimonials.md +4 -4
  41. data/lib/react_on_rails/helper.rb +6 -0
  42. data/lib/react_on_rails/locales/base.rb +7 -12
  43. data/lib/react_on_rails/server_rendering_pool/ruby_embedded_java_script.rb +9 -0
  44. data/lib/react_on_rails/version.rb +1 -1
  45. data/lib/tasks/assets.rake +3 -1
  46. data/package.json +1 -1
  47. metadata +24 -19
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: bee43668fbf28e23cce1688ae60bbfd657e9b16eaecb21d274bdef8f33e0a870
4
- data.tar.gz: ad75671d6dcdadfa567abc9aa1e795415323bf57ed78ae695bac5a7035c155f9
3
+ metadata.gz: 990d342ddca60683dec307b62b5613bf43979a41d6a17f52e1346f8082cfb439
4
+ data.tar.gz: 7711987e86e65abb363f2951fc618c9cf7d656cf42f6dbc9d6a4bdeaa68e82cf
5
5
  SHA512:
6
- metadata.gz: de6e94cc63334b75ca78e0575701862fda182f9c0d1be97a92cc7bc9a3af33c3716bbbe4d893c371ece4e56893081d6cccea9712e9336a220f3cab7e7997ab10
7
- data.tar.gz: a7e27db6edaf1d9761ba80c846fd40a1e9668aba12e2a6ae1b39e64cd5719784769541d7694e348334c26c24fe102f10636ba5f25996dd5bf6a7406213e5907e
6
+ metadata.gz: a1694803ba136e798e0671d4cbaa7319be4740b2d46577e6ce7fc9232e7519f749f8afcb5b19fb1253e13a2f4b4523657ab63c241bc47ae3cce4ccf084049c82
7
+ data.tar.gz: 010a1734f18fe9cb7eceffdf0cf7b902ba3175a994c83885da5c0d2c7fd35afb9f49b0ca20355c6e722e82714afcdfe307d6a853f13f3188428e4dbf293aac2b
data/.circleci/config.yml CHANGED
@@ -69,25 +69,25 @@ aliases:
69
69
  - &restore-package-node-modules-cache
70
70
  name: Restore cached node_modules directory
71
71
  keys:
72
- - v4-package-node-modules-cache-{{ checksum "yarn.lock" }}
72
+ - v5-package-node-modules-cache-{{ checksum "yarn.lock" }}
73
73
 
74
74
  # Restore spec/dummy/node_modules dir from cache using yarn.lock checksum as a key.
75
75
  - &restore-dummy-app-node-modules-cache
76
76
  name: Restore cached spec/dummy/node_modules directory
77
77
  keys:
78
- - v4-dummy-app-node-modules-cache-{{ checksum "spec/dummy/yarn.lock" }}
78
+ - v5-dummy-app-node-modules-cache-{{ checksum "spec/dummy/yarn.lock" }}
79
79
 
80
80
  # Restore vendor/bundle dir from cache using Gemfile.lock checksum as a key.
81
81
  - &restore-dummy-app-gem-cache
82
82
  name: Restore cached Ruby Gems for dummy app
83
83
  keys:
84
- - v4-dummy-app-gem-cache-{{ checksum "spec/dummy/Gemfile.lock" }}
84
+ - v5-dummy-app-gem-cache-{{ checksum "spec/dummy/Gemfile.lock" }}
85
85
 
86
86
  # Restore vendor/bundle dir from cache using react_on_rails.gemspec checksum as a key.
87
87
  - &restore-package-gem-cache
88
88
  name: Restore cached Ruby Gems for package
89
89
  keys:
90
- - v4-package-app-gem-cache-{{ checksum "react_on_rails.gemspec" }}
90
+ - v5-package-app-gem-cache-{{ checksum "react_on_rails.gemspec" }}
91
91
 
92
92
  # NOTE: Sometimes CI generated docker images are not updated in time to keep up with the minimum required
93
93
  # by chromedriver versions of Chrome. Just bump here Chrome version if chromedriver raises errors
@@ -139,7 +139,7 @@ jobs:
139
139
  - run: *install-package-node-modules
140
140
  - save_cache:
141
141
  name: Save root node_modules to cache
142
- key: v4-package-node-modules-cache-{{ checksum "yarn.lock" }}
142
+ key: v5-package-node-modules-cache-{{ checksum "yarn.lock" }}
143
143
  paths:
144
144
  - node_modules
145
145
 
@@ -157,7 +157,7 @@ jobs:
157
157
  - run: *install-dummy-app-node-modules
158
158
  - save_cache:
159
159
  name: Save spec/dummy/node_modules to cache
160
- key: v4-dummy-app-node-modules-cache-{{ checksum "spec/dummy/yarn.lock" }}
160
+ key: v5-dummy-app-node-modules-cache-{{ checksum "spec/dummy/yarn.lock" }}
161
161
  paths:
162
162
  - spec/dummy/node_modules
163
163
  - spec/dummy/node_modules
@@ -172,7 +172,7 @@ jobs:
172
172
  - run: *install-package-ruby-gems
173
173
  - save_cache:
174
174
  name: Save dummy app ruby gems to cache
175
- key: v4-package-app-gem-cache-{{ checksum "react_on_rails.gemspec" }}
175
+ key: v5-package-app-gem-cache-{{ checksum "react_on_rails.gemspec" }}
176
176
  paths:
177
177
  - vendor/bundle
178
178
 
@@ -186,7 +186,7 @@ jobs:
186
186
  - run: *install-dummy-app-ruby-gems
187
187
  - save_cache:
188
188
  name: Save dummy app ruby gems to cache
189
- key: v4-dummy-app-gem-cache-{{ checksum "spec/dummy/Gemfile.lock" }}
189
+ key: v5-dummy-app-gem-cache-{{ checksum "spec/dummy/Gemfile.lock" }}
190
190
  paths:
191
191
  - spec/dummy/vendor/bundle
192
192
 
@@ -209,7 +209,7 @@ jobs:
209
209
  command: cd spec/dummy && yarn run build:test
210
210
  - save_cache:
211
211
  name: Save test webpack bundles to cache (for build number checksum used by rspec job)
212
- key: v4-dummy-app-webpack-bundle-{{ .Revision }}
212
+ key: v5-dummy-app-webpack-bundle-{{ .Revision }}
213
213
  paths:
214
214
  - spec/dummy/public/webpack
215
215
  # Run JS unit tests for Renderer package.
@@ -249,7 +249,7 @@ jobs:
249
249
  - restore_cache: *restore-dummy-app-gem-cache
250
250
  - restore_cache:
251
251
  name: Restore cached webpack bundles for dummy app
252
- key: v4-dummy-app-webpack-bundle-{{ .Revision }}
252
+ key: v5-dummy-app-webpack-bundle-{{ .Revision }}
253
253
  - restore_cache: *restore-dummy-app-node-modules-cache
254
254
  - restore_cache: *restore-package-node-modules-cache
255
255
  - run: *install-package-node-modules
@@ -288,6 +288,8 @@ jobs:
288
288
  path: ~/rspec
289
289
  - store_artifacts:
290
290
  path: spec/dummy/tmp/capybara
291
+ - store_artifacts:
292
+ path: spec/dummy/tmp/screenshots
291
293
  - store_artifacts:
292
294
  path: spec/dummy/log/test.log
293
295
  - store_artifacts:
data/CHANGELOG.md CHANGED
@@ -1,7 +1,7 @@
1
1
  # Change Log
2
2
  All notable changes to this project's source code will be documented in this file. Items under `Unreleased` is upcoming features that will be out in next version. NOTE: major versions of the npm module and the gem must be kept in sync.
3
3
 
4
- Migration instructions for the major updates can be found [here](docs/basics/upgrading-react-on-rails.md#upgrading-to-version-9.md). Some smaller migration information can be found here.
4
+ Migration instructions for the major updates can be found [here](https://www.shakacode.com/react-on-rails/docs/guides/upgrading-react-on-rails#upgrading-to-version-9.md). Some smaller migration information can be found here.
5
5
 
6
6
  ## Need Help Migrating?
7
7
  If you would like help in migrating between React on Rails versions or help with implementing server rendering, please contact [justin@shakacode.com](mailto:justin@shakacode.com) for information about our [React on Rails Pro Support Options](https://www.shakacode.com/react-on-rails-pro).
@@ -17,6 +17,12 @@ Changes since last non-beta release.
17
17
 
18
18
  *Please add entries here for your pull requests that are not yet released.*
19
19
 
20
+ #### Added
21
+
22
+ - Ability to stop React on Rails from modifying or creating the `assets:precompile` task. [PR 1371](https://github.com/shakacode/react_on_rails/pull/1371) by [justin808](https://github.com/justin808). Thanks to [elstgav](https://github.com/elstgav) for [the suggestion](https://github.com/shakacode/react_on_rails/issues/1368)!
23
+
24
+ - Ability to stop stubbing of setTimeout, setInterval, & clearTimeout conditional by setting `ReactOnRailsPro.config.include_execjs_polyfills = false` in the React on Rails Pro configuration file. Also, added the ability to have render functions return a promise to be awaited by React on Rails Pro Node Renderer. [PR 1380](https://github.com/shakacode/react_on_rails/pull/1380) by [judahmeek](https://github.com/judahmeek)
25
+
20
26
  ### [12.3.0] - 2021-07-26
21
27
  #### Added
22
28
 
@@ -32,7 +38,7 @@ Changes since last non-beta release.
32
38
 
33
39
  ### [12.1.0] - 2021-03-23
34
40
  #### Added
35
- - Added the ability to assign a module with a `call` method to `config.build_production_command`. See [the configuration docs](./docs/basics/configuration.md). [PR 1362: Accept custom module for config.build_production_command](https://github.com/shakacode/react_on_rails/pull/1362).
41
+ - Added the ability to assign a module with a `call` method to `config.build_production_command`. See [the configuration docs](https://www.shakacode.com/react-on-rails/docs/guides/configuration). [PR 1362: Accept custom module for config.build_production_command](https://github.com/shakacode/react_on_rails/pull/1362).
36
42
 
37
43
  #### Fixed
38
44
  - Stop setting NODE_ENV value during precompile, as it interferred with rails/webpacker's setting of NODE_ENV to production by default. Fixes [#1334](https://github.com/shakacode/react_on_rails/issues/1334). [PR 1356: Don't set NODE_ENV in assets.rake](https://github.com/shakacode/react_on_rails/pull/1356) by [alexrozanski](https://github.com/alexrozanski).
@@ -58,7 +64,7 @@ Changes since last non-beta release.
58
64
  - Changed invocation of webpacker:clean to use a very large number of versions so it does not acidentally delete the server-bundle.js. [PR 1306](https://github.com/shakacode/react_on_rails/pull/1306) by By [justin808](https://github.com/justin808).
59
65
 
60
66
  ### [12.0.0] - 2020-07-08
61
- For upgrade instructions, see [docs/basics/upgrading-react-on-rails.md](./docs/basics/upgrading-react-on-rails.md).
67
+ For upgrade instructions, see [docs/guides/upgrading-react-on-rails.md](https://www.shakacode.com/react-on-rails/docs/guides/upgrading-react-on-rails).
62
68
 
63
69
  #### Major Improvements
64
70
  1. **React Hooks Support** for top level components
@@ -74,8 +80,8 @@ set JavaScript property `renderFunction` on the function for which you want to r
74
80
  invoked to return the React component. In that case, you won't need to pass any unused params.
75
81
  [PR 1268](https://github.com/shakacode/react_on_rails/pull/1268) by [justin808](https://github.com/justin808)
76
82
 
77
- See [docs/basics/upgrading-react-on-rails](./docs/basics/upgrading-react-on-rails.md#upgrading-to-v12)
78
- for details.
83
+ See [docs/guides/upgrading-react-on-rails](https://www.shakacode.com/react-on-rails/docs/guides/upgrading-react-on-rails#upgrading-to-v12)
84
+ for details.
79
85
 
80
86
  #### Other Updates
81
87
  * `react_on_rails` fully supports `rails/webpacker`. The example test app in `spec/dummy` was recently converted over to use rails/webpacker v4+. It's a good example of how to leverage rails/webpacker's webpack configuration for server-side rendering.
@@ -343,7 +349,7 @@ Updated React on Rails to depend on [rails/webpacker](https://github.com/rails/w
343
349
 
344
350
 
345
351
  #### 9.0 from 8.x. Upgrade Instructions
346
- Moved to [our documentation](docs/basics/upgrading-react-on-rails.md#upgrading-to-version-9).
352
+ Moved to [our documentation](https://www.shakacode.com/react-on-rails/docs/guides/upgrading-react-on-rails#upgrading-to-version-9).
347
353
 
348
354
  ### [8.0.7] - 2017-08-16
349
355
  #### Fixed
@@ -693,7 +699,7 @@ Here is the addition to the generated config file:
693
699
  ## [5.2.0] - 2016-04-08
694
700
  ##### Added
695
701
  - Support for React 15.0 to react_on_rails. See [#379](https://github.com/shakacode/react_on_rails/pull/379) by [brucek](https://github.com/brucek).
696
- - Support for Node.js server side rendering. See [#380](https://github.com/shakacode/react_on_rails/pull/380) by [alleycat](https://github.com/alleycat-at-git) and [doc](https://github.com/shakacode/react_on_rails/blob/master/docs/additional-reading/node-server-rendering.md)
702
+ - Support for Node.js server side rendering. See [#380](https://github.com/shakacode/react_on_rails/pull/380) by [alleycat](https://github.com/alleycat-at-git) and [doc](https://www.shakacode.com/react-on-rails/docs/react-on-rails-pro/react-on-rails-pro#pro-integration-with-nodejs-for-server-rendering)
697
703
 
698
704
  ##### Removed
699
705
  - Generator removals to simplify installer. See [#364](https://github.com/shakacode/react_on_rails/pull/364) by [jbhatab](https://github.com/jbhatab).
@@ -826,11 +832,11 @@ All 5.1.0 changes can be found in [#362](https://github.com/shakacode/react_on_r
826
832
  <%= react_component("ReduxSharedStoreApp", props: {}, prerender: false, trace: true) %>
827
833
  ```
828
834
  You'll get a deprecation message to change this.
829
- - Renamed `ReactOnRails.configure_rspec_to_compile_assets` to `ReactOnRails::TestHelper.configure_rspec_to_compile_assets`. The code has also been optimized to check for whether or not the compiled webpack bundles are up to date or not and will not run if not necessary. If you are using non-standard directories for your generated webpack assets (`app/assets/javascripts/generated` and `app/assets/stylesheets/generated`) or have additional directories you wish the helper to check, you need to update your ReactOnRails configuration accordingly. See [documentation](https://github.com/shakacode/react_on_rails/blob/master/docs/additional-reading/rspec_configuration.md) for how to do this. [#253](https://github.com/shakacode/react_on_rails/pull/253).
835
+ - Renamed `ReactOnRails.configure_rspec_to_compile_assets` to `ReactOnRails::TestHelper.configure_rspec_to_compile_assets`. The code has also been optimized to check for whether or not the compiled webpack bundles are up to date or not and will not run if not necessary. If you are using non-standard directories for your generated webpack assets (`app/assets/javascripts/generated` and `app/assets/stylesheets/generated`) or have additional directories you wish the helper to check, you need to update your ReactOnRails configuration accordingly. See [documentation](https://www.shakacode.com/react-on-rails/docs/guides/rspec_configuration) for how to do this. [#253](https://github.com/shakacode/react_on_rails/pull/253).
830
836
  - You have to call `ReactOnRails.register` to register react components. This was deprecated in v2. [#273](https://github.com/shakacode/react_on_rails/pull/273).
831
837
 
832
838
  ##### Migration Steps v2 to v3
833
- - [spec/dummy/spec/rails_helper.rb](https://github.com/shakacode/react_on_rails/blob/master/spec%2Fdummy%2Fspec%2Frails_helper.rb#L36..38) for an example. Add this line to your `rails_helper.rb`:
839
+ - See [these changes of spec/dummy/spec/rails_helper.rb](https://github.com/shakacode/react_on_rails/blob/master/spec/dummy/spec/rails_helper.rb#L36..38) for an example. Add this line to your `rails_helper.rb`:
834
840
  ```ruby
835
841
  RSpec.configure do |config|
836
842
  # Ensure that if we are running js tests, we are using latest webpack assets
@@ -846,7 +852,7 @@ RSpec.configure do |config|
846
852
 
847
853
  ## [2.2.0] - 2016-01-29
848
854
  ##### Added
849
- - New JavaScript API for debugging TurboLinks issues. Be sure to see [turbolinks docs](docs/additional-reading/turbolinks.md). `ReactOnRails.setOptions({ traceTurbolinks: true });`. Removed the file `debug_turbolinks` added in 2.1.1. See [#243](https://github.com/shakacode/react_on_rails/pull/243).
855
+ - New JavaScript API for debugging TurboLinks issues. Be sure to see [turbolinks docs](https://www.shakacode.com/react-on-rails/docs/rails/turbolinks). `ReactOnRails.setOptions({ traceTurbolinks: true });`. Removed the file `debug_turbolinks` added in 2.1.1. See [#243](https://github.com/shakacode/react_on_rails/pull/243).
850
856
 
851
857
  ## [2.1.1] - 2016-01-28
852
858
 
@@ -855,21 +861,21 @@ RSpec.configure do |config|
855
861
 
856
862
  ##### Added
857
863
  - `ReactOnRails.render` returns a virtualDomElement Reference to your React component's backing instance. See [#234](https://github.com/shakacode/react_on_rails/pull/234).
858
- - `debug_turbolinks` helper for debugging turbolinks issues. See [turbolinks](docs/additional-reading/turbolinks.md).
864
+ - `debug_turbolinks` helper for debugging turbolinks issues. See [turbolinks](https://www.shakacode.com/react-on-rails/docs/rails/turbolinks).
859
865
  - Enhanced regression testing for non-turbolinks apps. Runs all tests for dummy app with turbolinks both disabled and enabled.
860
866
 
861
867
  ## [2.1.0] - 2016-01-26
862
868
  ##### Added
863
- - Added EnsureAssetsCompiled feature so that you do not accidentally run tests without properly compiling the JavaScript bundles. Add a line to your `rails_helper.rb` file to check that the latest Webpack bundles have been generated prior to running tests that may depend on your client-side code. See [docs](docs/additional-reading/rspec_configuration.md) for more detailed instructions. [#222](https://github.com/shakacode/react_on_rails/pull/222)
864
- - Added [migration guide](https://github.com/shakacode/react_on_rails#migrate-from-react-rails) for migrating from React-Rails. [#219](https://github.com/shakacode/react_on_rails/pull/219)
865
- - Added [React on Rails Doctrine](docs/doctrine.md) to docs. Discusses the project's motivations, conventions, and principles. [#220](https://github.com/shakacode/react_on_rails/pull/220)
869
+ - Added EnsureAssetsCompiled feature so that you do not accidentally run tests without properly compiling the JavaScript bundles. Add a line to your `rails_helper.rb` file to check that the latest Webpack bundles have been generated prior to running tests that may depend on your client-side code. See [docs](https://www.shakacode.com/react-on-rails/docs/guides/rspec_configuration) for more detailed instructions. [#222](https://github.com/shakacode/react_on_rails/pull/222)
870
+ - Added [migration guide](https://www.shakacode.com/react-on-rails/docs/additional-details/migrating-from-react-rails) for migrating from React-Rails. [#219](https://github.com/shakacode/react_on_rails/pull/219)
871
+ - Added [React on Rails Doctrine](https://www.shakacode.com/react-on-rails/docs/misc/doctrine) to docs. Discusses the project's motivations, conventions, and principles. [#220](https://github.com/shakacode/react_on_rails/pull/220)
866
872
  - Added ability to skip `display:none` style in the generated content tag for a component. Some developers may want to disable inline styles for security reasons. See generated config [initializer file](lib/generators/react_on_rails/templates/base/base/config/initializers/react_on_rails.rb#L27) for example on setting `skip_display_none`. [#218](https://github.com/shakacode/react_on_rails/pull/218)
867
873
 
868
874
  ##### Changed
869
875
  - Changed message when running the dev (a.k.a. "express" server). [#227](https://github.com/shakacode/react_on_rails/commit/543ae70254d0c7b477e2c92af86f40746e58a431)
870
876
 
871
877
  ##### Fixed
872
- - Fixed handling of Turbolinks. Code was checking that Turbolinks was installed when it was not yet because some setups load Turbolinks after the bundles. The changes to the code will check if Turbolinks is installed after the page loaded event fires. Code was also added to allow easy debugging of Turbolinks, which should be useful when v5 of Turbolinks is released shortly. Details of how to configure Turbolinks with troubleshooting were added to docs/additional-reading/turbolinks.md. [#221](https://github.com/shakacode/react_on_rails/pull/221)
878
+ - Fixed handling of Turbolinks. Code was checking that Turbolinks was installed when it was not yet because some setups load Turbolinks after the bundles. The changes to the code will check if Turbolinks is installed after the page loaded event fires. Code was also added to allow easy debugging of Turbolinks, which should be useful when v5 of Turbolinks is released shortly. Details of how to configure Turbolinks with troubleshooting were added to `docs` directory. [#221](https://github.com/shakacode/react_on_rails/pull/221)
873
879
  - Fixed issue with already initialized constant warning appearing when starting a Rails server [#226](https://github.com/shakacode/react_on_rails/pull/226)
874
880
  - Fixed to make backwards compatible with Ruby v2.0 and updated all Ruby and Node dependencies.
875
881
 
data/NEWS.md CHANGED
@@ -1,21 +1,27 @@
1
1
  # NEWS
2
2
 
3
- *We'll keep a history of the news. A few bullets at the top will also show on the [README.md](./README.md).*
3
+ *A history of the news. A few bullets at the top will also show on the [README.md](./README.md).*
4
4
 
5
+ * **October 14, 2020**: [RUBY ROGUES
6
+ RR 474: React on Rails V12 – Don’t Shave That Yak! with Justin Gordon](https://devchat.tv/ruby-rogues/rr-474-react-on-rails-v12-dont-shave-that-yak-with-justin-gordon/).
7
+
8
+ * **October 1, 2020**: See the [spec/dummy](https://github.com/shakacode/react_on_rails/tree/master/spec/dummy) example repo for a simple configuration of webpack via the rails/webpacker gem
9
+ that supports SSR.
10
+ * **August 2, 2020**: See the example repo of [React on Rails Tutorial With SSR, HMR fast refresh, and TypeScript](https://github.com/shakacode/react_on_rails_tutorial_with_ssr_and_hmr_fast_refresh) for a new way to setup the creation of your SSR bundle with `rails/webpacker`.
5
11
  * July 8, 2020: Release **v12**.
6
12
  1. **React Hooks Support** for top level components
7
13
  2. **Typescript bindings**
8
14
  3. **rails/webpacker** "just works" with React on Rails by default.
9
15
  4. i18n support for generating a JSON file rather than a JS file.
10
16
  * 2018-02-27: **Version 10.1.2** Supports the React API for ReactDOM.hydrate.
11
- * 2017-09-06: **VERSION 9.0.0 shipped!** This version depends on Webpacker directly. See [Upgrading React on Rails](./docs/basics/upgrading-react-on-rails.md) for more concise instructions on upgrading.
17
+ * 2017-09-06: **VERSION 9.0.0 shipped!** This version depends on Webpacker directly. See [Upgrading React on Rails](./docs/guides/upgrading-react-on-rails.md) for more concise instructions on upgrading.
12
18
  * Always see the [CHANGELOG.md](./CHANGELOG.md) for the latest project changes.
13
19
  * [VERSION 8.1.0](https://rubygems.org/gems/react_on_rails/) shipped with [webpacker_lite](https://github.com/shakacode/webpacker_lite) (soon [**webpacker**](https://github.com/rails/webpacker/issues/464#issuecomment-310986140) support! [react-webpack-rails-tutorial PR #395](https://github.com/shakacode/react-webpack-rails-tutorial/pull/395) shows the changes needed to migrate from the Asset Pipeline to Webpacker Lite. For more information, see my article: [Webpacker Lite: Why Fork Webpacker?](https://blog.shakacode.com/webpacker-lite-why-fork-webpacker-f0a7707fac92). Per recent discussions, we [will merge Webpacker Lite changes back into Webpacker](https://github.com/rails/webpacker/issues/464#issuecomment-310986140). There's no reason to wait for this. The upgrade will eventually be trivial.
14
20
  * 2017-04-25: 7.0.0 Shipped! Performance improvements! Please upgrade! Only "breaking" change is that you have to update both the node module and the Ruby gem.
15
21
  * 2017-04-09: 8.0.0 beta work to include webpacker_lite gem has begun. See [#786](https://github.com/shakacode/react_on_rails/issues/786).
16
22
  * 2017-04-03: 6.9.3 Released! Props rendered in JSON script tag. Page size is smaller now due to less escaping!
17
23
  * 2017-03-06: Updated to Webpack v2!
18
- * 2017-03-02: Demo of internationalization (i18n) is live at [reactrails.com](https://www.reactrails.com/). Docs [here](docs/basics/i18n.md).
24
+ * 2017-03-02: Demo of internationalization (i18n) is live at [reactrails.com](https://www.reactrails.com/). Docs [here](docs/guides/i18n.md).
19
25
  * 2017-02-28: See [discussions here on Webpacker](https://github.com/rails/webpacker/issues/139) regarding how Webpacker will allow React on Rails to avoid using the asset pipeline in the near future.
20
26
  * 2017-02-28: Upgrade to Webpack v2 or use the `--bail` option in your webpack script for test and production builds. See the discussion on [PR #730](https://github.com/shakacode/react_on_rails/pull/730).
21
27
  * 2016-11-03: Spoke at [LA Ruby: "React on Rails: Why, What, and How?"](http://www.meetup.com/laruby/events/234825187/). [Video and pictures in this article](https://blog.shakacode.com/my-react-on-rails-talk-at-the-la-ruby-rails-meetup-november-10-2016-eaaa83aff800#.ej6h4eglp).