React Material Design - React components built with sass
react-md is a set of React components and sass files for implementing Google's Material Design. The Documentation Website can be used for viewing live examples, code samples, and general prop documentation.
$ npm i -S react react-dom react-md
The application should define a primary
and secondary
color. The primary
color
should be chosen from one of the '-500'
colors and the secondary
should be one of
the 'a-'
colors.
The default color palette is defined as:
$md-primary-color: $md-indigo-500 !default;
$md-secondary-color: $md-pink-a-200 !default;
If you change these variables before the react-md-everything
mixin is included, your entire
application will be styled with your new theme.
@import '~react-md/src/scss/react-md';
$md-primary-color: $md-teal-500;
$md-secondary-color: $md-lime-a-400;
@include react-md-everything;
See the themes page on the documentation website. There is also a theme builder available to try mix and matching different colors.
Please see the list of examples for how you can get a project started off quickly with React and React MD.
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/react-md@1.2.12/dist/react-md.deep_purple-pink.min.css">
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons|Roboto:400,500,700">
</head>
<body>
<div id="app"></div>
<script src="https://unpkg.com/react/dist/react-with-addons.min.js"></script>
<script src="https://unpkg.com/react-dom/dist/react-dom.min.js"></script>
<script src="https://unpkg.com/react-md@1.2.12/dist/react-md.min.js"></script>
<script>
var MyAwesomeComponent = React.createClass({
render: function() {
return React.createElement(ReactMD.Button, { label: 'Hello, World!', flat: true });
}
});
ReactDOM.render(React.createElement(MyAwesomeComponent), document.getElementById('app'));
</script>
</body>
</html>
- Bottom sheets
- Steppers
- Eventually add Floating button transitions/morphing abilities. Ex: Speed Dial, Morph into toolbar/material/paper
Please see the documentation site README
for information about contributing using the documentation server. Otherwise, here is some information about only working
within react-md
.
Right now I am using the Ruby
version of scss_lint
to lint scss files. This means that you will need to have Ruby installed
and the sass-lint
gem.
$ gem install scss_lint
I have an issue (#274) open about switching over to the node port, but it hasn't really been worked on because I don't like the little amount of features that have been ported over so far.
Otherwise this should work on most systems with node >= 6.
mlaursen @ ~/code/react-md
$ yarn
$ cd docs
mlaursen @ ~/code/react-md/docs
$ yarn
$ cp .env.example .env
$ cd ..
mlaursen @ ~/code/react-md
$ yarn dev
This will run both the lint:styles and lint:scripts commands.
This will attempt to automatically fix any eslint
errors that can be fixed.
As stated above, this will lint all the scss files within the src/scss
directory. Unfortunately, this requires the Ruby gems
version of scss-lint
to be installed to work because the node port isn't quite there yet for me. You can either
remove this temporarily from the build process or:
$ gem install scss_lint
This will run eslint
over all the files in the src/js
folder.
This command will run the build:
This command will run test:tsc followed by jest
.
This will do a simple Typescript compliation test to make sure there aren't any syntax errors or invalid types. There should probably be a better testing system put in place.
This will just run jest
in watch mode.
This will just run jest
in the docs folder.
This will just run jest
in watch mode in the docs folder.
This will run tests for Typescript definitions, the base react-md repo, and the docs folder.
This command will just copy all the Typescript definitions into the lib
folder so that it can be used correctly
by Typescript users.
This script makes 255 different scss files to be compiled for production use. This is automatically run before build.
This will compile all the components and utilities in the src/js
using babel with the babel-preset-env
.
All the files will be output into the lib
directory.
This is the same as above, but it will be done in watch mode. This is very helpful when running the development server and want to see immediate changes.
This will start up the documentation server in development mode as well as watching for changes within the base react-md library. Please look at the Getting Started for some preliminary setup required.
This will start up the documentation server in development mode as well as watching for changes within the base react-md library. The only difference is that the docs:minimal command will be run instead of docs
This will start up the documentation server in development mode. For some more information about this command, please see the documentation server scripts.
This will start up the documentation server in development mode without rebuilding all the "databases" before startup.
This command is automatically run before build. It will basically remove all the old artifacts and compiled files followed by linting the entire project.
This command will do the full build of react-md
before a release. It runs almost all of the other scripts in a specified
order so that the es
, lib
,dist
folders are created and contain the correct files for release.
This command will create the UMD bundles for development and production use. In addition, it will create all the pre-compiled css bundles for production use.