Electrode flavored react component archetype.
First, install yeoman to help quickly create an empty component:
$ npm install -g yo
Now, yo
can scaffold the project for you.
$ yo electrode-component
You should see something similar to the below session:
$ yo electrode-component
Welcome to the Electrode Component generator
Were going to set up a new Electrode Component, ready for development with
gulp, webpack, demo, electrode component archetype, live-reload
? What is your Package/GitHub project name? (e.g., 'wysiwyg-component') product-card
? What is the ClassName for your component? ProductCard
? What will be the npm package name? product-card
? What will be the GitHub organization username (e.g., 'walmartlabs')? electrodeio
? What is your name? (for copyright notice, etc.) arpan nanavati
? What is your GitHub Username? ananavati
? What is the name of the GitHub repo this will be published at? product-card
? Would you like to create a new directory for your project? Yes
create .babelrc
create .gitignore
create .npmignore
create .editorconfig
create gulpfile.js
create package.json
create README.md
create src/components/product-card.jsx
create src/styles/product-card.styl
create src/index.js
create demo/demo.jsx
create demo/demo.css
create demo/examples/product-card.example
create test/client/.eslintrc
create test/client/components/product-card.spec.jsx
Your new Electrode Component is ready!
Your component is in '/src' and your demo files are in '/demo/*'
Type 'cd product-card' then 'gulp demo' to run the development build and demo tasks.
If you prefer to create your component manually or if you have an existing component that you want to migrate to using this archetype, follow the instructions below:
$ npm install --save-dev electrode-gulp-helper electrode-archetype-react-component electrode-archetype-react-component-dev
The .babelrc
needs to extend
the archetype's babel configuration in order to apply the presents (ES2015, React) and the plugins like i18n. If your project needs additional Babel settings (like using stage 0 features) you can add them to this file. See the Babel docs for more information.
{
"extends": "./node_modules/electrode-archetype-react-component/config/babel/.babelrc"
}
The gulpfile.js
needs to extend
the archetype's gulp tasks in order to apply the shared tasks on your new/existing electrode component. Add this following lines of code to the newly created gulpfile.js
"use strict";
const exec = require("electrode-gulp-helper").exec;
const tasks = {
"demo": ["generate", "server-dev"],
"demo-iso": ["dev-iso"],
"generate": ["generate-metadata", "generate-documentation"],
"generate-documentation": () => exec(`electrode-docgen --package ./package.json --src ./src --markdown components.md`),
"generate-metadata": () => exec(`electrode-docgen --package ./package.json --src ./src --metadata components.json`),
"prepublish": ["npm:prepublish"],
"preversion": ["check-cov"]
}
require("electrode-archetype-react-component")(tasks);
The archetypes are split into two parts: <archetype>
and <archetype>-dev
. Both archetypes need to be in each component and should be included in the package.json
's devDependencies
.
This archetype assumes an architecture as follows:
demo/
demo.jsx
demo.css
src
components/
*.jsx
styles/
*.css
index.js
test
client/
spec/
components/
*.jsx?
*.jsx?
main.js
test.html
.babelrc
package.json
By default, this archetype assumes you are using CSS-Modules + CSS-Next, you need
to opt-in to stylus support by adding a *.styl
to your project's demo/demo.styl
& src/styles/*.styl
Import css files in your components and reference class names via the exported object src/components/<%= componentPath %>.js
:
import React from "react";
import styles from "../styles/<%= componentPath %>.css";
class <%= componentName %> extends React.Component {
render() {
return (
<div className={styles.someStyle}>Hello Modules!</div>
);
}
}
Add following styling to src/styles/<%= componentPath %>.css
:root {
--black: #000;
--white: #fff;
}
.baseStyle {
background-color: var(--black);
color: var(--white);
}
.someStyle {
composes: baseStyle;
font-size: 18px;
}
For the demo-iso
task to work, demo/demo.jsx
has some limitations:
demo/demo.jsx
can't usereact-router
demo/demo.jsx
can't import files that rely on webpack loaders e.g..styl
files.
This is because the server rendering uses node for both routing and import statements.
Specifically for routing, react-router
instances create a history that relies on DOM availability.
This will break server render with an error like this:
Unhandled rejection Invariant Violation: Browser history needs a DOM
If you would like to augment or override the demo server config you can add archetype-demo-server.config.js
file to the root of the project. This file will be merged with the default config and passed into the electrode-server
instance. Add any hapi plugins or settings here.
// Sample archetype-demo-server.config.js
module.exports = {
"plugins": {
"my-electrode-plugin": {}
}
};
$ gulp help
[13:02:10] Using gulpfile ~/walmart-oss/test-generator-electrode-component/product-card/gulpfile.js
[13:02:10] Starting 'help'...
Usage
gulp [TASK] [OPTIONS...]
Available tasks
archetype:check .............. tasks: ["archetype:lint","archetype:test-dev-pkg","clean-test-init"]
archetype:lint --------------- tasks: ["archetype:lint-server"]
archetype:lint-server
archetype:test-dev-pkg
babel-src-step
build ........................ tasks: ["build-lib","build-dist"]
build-dist ------------------- tasks: ["clean-dist","build-dist-min","build-dist-dev"]
build-dist-dev
build-dist-min ............... Build minified dist files for production
deps: ["~production-env"]
build-lib -------------------- deps: ["~production-env"]
build-lib:clean-tmp
build-lib:copy-flow
build-lib:flatten-l10n
check ........................ tasks: ["check-dep","lint","test-cov"]
check-ci --------------------- tasks: ["check-dep","lint","test-ci"]
check-cov .................... tasks: ["lint","test-cov"]
check-dep
check-dev -------------------- tasks: ["lint","test-dev"]
clean ........................ tasks: ["clean-lib","clean-dist"]
clean-dist
clean-lib
clean-test-init
cov-frontend
cov-frontend-50
cov-frontend-70
cov-frontend-85
cov-frontend-95
default ---------------------- Invokes 'gulp help'
demo ......................... tasks: ["generate","server-dev"]
demo-iso --------------------- tasks: ["dev-iso"]
dev .......................... Start server in development mode
tasks: ["~webpack-dev",["server-dev","server-test"]]
dev-iso ---------------------- Start ISO server in development mode
tasks: ["~webpack-dev",["iso-render-server-start","server-dev-iso"]]
generate ..................... tasks: ["generate-metadata","generate-documentation"]
generate-documentation
generate-metadata
help ------------------------- Display this help text.
hot .......................... Start server in hot/auto-watch mode
tasks: ["~webpack-dev",["server-hot","server-test"]]
iso-render-server-start ------ tasks: ["~webpack-dev","iso-render-server-start-watch"]
iso-render-server-start-watch
lint ......................... tasks: ["lint-stylus","lint-react-demo","lint-react-src","lint-react-test","lint-scripts"]
lint-react-demo
lint-react-src
lint-react-test
lint-scripts
lint-stylus
npm:prepublish --------------- tasks: ["build-lib","build-dist-dev","build-dist-min"]
prepublish ................... tasks: ["npm:prepublish"]
preversion ------------------- tasks: ["check-cov"]
server-dev
server-dev-iso
server-hot
server-test
test-ci ...................... tasks: ["test-frontend-ci"]
test-cov --------------------- tasks: ["test-frontend-cov"]
test-dev ..................... tasks: ["test-frontend-dev"]
test-frontend
test-frontend-ci
test-frontend-cov
test-frontend-dev
test-frontend-dev-watch
test-watch ------------------- tasks: ["test-frontend-dev-watch"]
If you are enhancing / refactoring this archetype and have locally checked it out,
please see CONTRIBUTING.md
for our guidelines.
The main check we provide for the archetype itself is:
$ gulp archetype:check