A Yeoman generator for a Magento 2 ready, ReactJS/Redux application
- Install yeoman
npm install -g yo
- Install magepack
npm install -g generator-magepack
- Done!
- Go to your target directory
- Run
yo magepack
- Follow the prompts
- Once yeoman has finsihed, run
npm i
Run the dev server npm run dev
.
A sample application is included as a starting point. Making use of ReactJS and Redux, the main application files can be found in view/frontend/web/js/src
.
The view/frontend/web/js/src/index.entry.js
file pulls together your application for bundling. The view/frontend/web/js/dist/
contains the final application distributable.
The structure of the generated files follows the structure of a Magento 2 JavaScript application. You can use this generator directly in app/code
, app/design
or vendor/ampersand/module
.
You will need to update the view/frontend/web/js/App.js
at the very least before being 100% Magento-ready:
define(
- ['react', 'react-dom', 'prop-types', 'redux', 'react-redux', 'redux-thunk', 'app.min'],
+ ['react', 'react-dom', 'prop-types', 'redux', 'react-redux', 'redux-thunk', 'Vendor_Module/js/dist/app.min'],
function(React, ReactDOM, PropTypes, Redux, ReactRedux, ReduxThunk, ReactApp) {
npm run dev
to start a webpack dev server on http://localhost:8080/webpack-dev-server/npm test
to run any Jest spec files inview/frontend/web/js/spec/
(this command will also run a full build)npm run lint
to run ESLint against your filesnpm run build
to run the production webpack build of your module
ESLint is used for linting. http://eslint.org/
Rules can be found under the eslintConfig
key in package.json
.
ESLint will be run automatically on every npm run build
and npm run dev
.
Prettier is an opinionated code formatter. https://prettier.io/playground/
This will be run either by your editor (requires setup) or as a precommit hook. This will re-format your files that are marked as "staged" via git add
before you commit.
Jest is used for unit testing. https://facebook.github.io/jest/
Test files should be added to: view/frontend/web/js/spec/
in the format filename.spec.js
Unit tests can be run via npm test
.
Snapshot testing is available, see documentation here: http://facebook.github.io/jest/docs/en/snapshot-testing.html#snapshot-testing-with-jest
You should commit snapshots to version control.