This package includes scripts and configuration used by React Unity.
This project is a fork of Create React App (CRA). Same options, conventions, and environment variables can be used. You can also check the documentation of CRA to get more information.
npm i @reactunity/scripts
react-unity-scripts start
- Start the dev server with Hot Module Replacement (HMR)react-unity-scripts build
- Create the production ready buildreact-unity-scripts start --test
- Start the test server (entry file will betest.ts
instead ofindex.ts
)
Environment variables of CRA can be used with React Unity. However, there are some differences:
FILENAME
- Name of the generated javascript file.index.js
by default.BUILD_PATH
- Path to the generated output. Relative to the project.../Assets/Resources/react
by default.GENERATE_SOURCEMAP
-false
by default.FAST_REFRESH
- This can be set tofalse
to disablereact-refresh
if you are having problems with hot reloadIMAGE_INLINE_SIZE_LIMIT
-0
by default. Because non-inlined images will be faster in Unity. However, if users still want to inline images, they should increase this limit.JSX_IMPORT_SOURCE
- Can be used to allow some custom JSX transformations. For example, set this variable to@emotion/react
for Emotion.ENABLE_SCOPE
- Can be used to restricts imports tosrc
folder only.
Environment variables can also be defined by having .env
, .env.local
, .env.<development|production>
in project folder.
Custom environment variables are also possible as in CRA.
.babelrc
can be used to modify some Babel options.
In addition to src/index
file, there can be other entry points. Every file under src/entry/
folder will be detected and configured as an entry point. For example, if there is a file src/entry/menu.tsx
, Webpack will detect that and create an entrypoint named menu
with output menu.js
in addition to the default entrypoint index.js
.
When dev server is started with the start
script, a web server is launched at the selected port (e.g. http://localhost:3000). This server serves the javascript and asset files that are used by ReactUnity. If you visit this link in browser, you will see a page explaining how to setup the web previewer. The previewer can be used to quickly test the React code without even launching Unity. It also reacts to the changes in code by utilizing HMR.
Note that this web inspector has very limited capabilities. Naturally, it may not work for all cases. However it is a useful tool for when starting a new ReactUnity project. As an advanced feature, you can override the web inspector by placing your custom web inspector in previewer
folder under your React project.