elgentos / magento2-react
Module to add React to Magento 2 KO frontend
Installs: 9 628
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 14
Forks: 3
Open Issues: 0
Language:JavaScript
Type:magento2-module
Requires (Dev)
- composer/composer: *@dev
This package is auto-updated.
Last update: 2024-11-16 14:21:54 UTC
README
This module is based on https://github.com/yireo-training/Yireo_React.
Install
Execute these commands to install all required dependencies.
npm install react react-dom
npm install --save-dev @babel/core @babel/preset-env @babel/preset-react babel-loader glob path webpack webpack-cli
Put this file in your root:
// webpack.config.js const path = require('path'); const glob = require('glob'); const appRoot = path.resolve(__dirname, 'app', 'code'); const entries = {}; const appPaths = glob.sync("app/code/*/*/view/*/src/*.define.js", {}); appPaths.forEach(file => { const relativeFile = path.relative(appRoot, file); entries[path.dirname(path.dirname(relativeFile)) + '/web/js/' + path.basename(file.replace('.define.js', ''))] = "./" + file; }); const vendorPaths = glob.sync("vendor/*/*/view/*/src/*.define.js", {}); vendorPaths.forEach(file => { const relativeFile = path.relative(appRoot, file); entries[path.dirname(path.dirname(relativeFile)) + '/web/js/' + path.basename(file.replace('.define.js', ''))] = "./" + file; }); console.log(entries); if (Object.keys(entries).length === 0) { console.error('ERROR: There are no valid files to compile!'); } module.exports = (env, arg) => { return { entry: entries, externals: { react: { commonjs: 'React', amd: 'react' } }, module: { rules: [ { test: /\.js$/, exclude: /node_modules/, use: { loader: "babel-loader", options: { presets: [ '@babel/react', '@babel/preset-env' ] } } }, ] }, output: { path: appRoot, libraryTarget: "amd", filename: '[name]' + (arg.mode === 'production' ? '.min' : '') + '.js' } } };
Add these scripts to your package.json file:
{ ... "scripts": { "dev": "webpack --config vendor/elgentos/magento2-react/webpack.config.js --mode development && webpack --mode development", "watch": "webpack --config vendor/elgentos/magento2-react/webpack.config.js --mode development && webpack --watch --mode development", "build": "webpack --config vendor/elgentos/magento2-react/webpack.config.js --mode production && webpack --mode production" }, ... }