Skip to content

Latest commit

 

History

History
62 lines (48 loc) · 2.59 KB

README.md

File metadata and controls

62 lines (48 loc) · 2.59 KB

mui-custom-builder

Custom build delivery framework for Material-UI

Note: This README will change as the project evolves, and may lag behind sometimes. Follow my comments on callemall/material-ui/#262 for progress updates.

EDIT: heroku didn't cut it for this app as one can't really write to the filesystem in a heroku dyno (this app uses bash scripts to write to the filesystem). EC2 works well though -- spin up an EC2 instance with an attached EBS volume. In the security rule for the instance, open up port 80 (HTTP) to everyone. Run the node app on port 8080, and set up port-forwarding. Excellent guide: http://www.lauradhamilton.com/how-to-set-up-a-nodejs-web-server-on-amazon-ec2

Ownership is being transfered to @hai-cea (Call-Em-All) where the project will be further developed.

The idea is as follows: Add a form page to material-ui.com that provides the capability to produce a custom build. This form allows the developer to choose an available version of MUI and the components that are to be included in the custom build (could also choose all components). The form then sends an HTTP request to a node app running on heroku, where a custom build is performed using webpack. The build files are then available to the developer to download.

How to run this?

git clone https://github.com/shaurya947/mui-custom-builder.git
cd mui-custom-builder

npm i
node app.js

Then, the magic happens when you navigate to localhost using a query string like so:

http://localhost:3000/?v=x.x.x&components=ALL/comp1,comp2,comp3...

Examples:

http://localhost:3000/?v=0.13.4&components=AppBar,AutoComplete,RaisedButton
http://localhost:3000/?v=0.13.3&components=ALL

If everything goes smoothly, the browser should download a bundle.js file for you (which is the custom build output file). In the future, more options such as minifying and including source map are to come. Then, downloading a zip file would probably be a better idea.

Using the build in your HTML

<!DOCTYPE html>
<html>
<head>
</head>
<body>
	<div>works</div>
	<div id="sample"></div>
	<script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.23/browser.min.js"></script>
	<script src="bundle.js"></script>
	<script type="text/babel">
		var MyComp = React.createClass({
			render() {
				return (<div>
					<mui.AppBar/>
					<mui.RaisedButton label="hooray" secondary={true} />
					</div>);
			}
		});
		ReactDOM.render(<MyComp />, document.getElementById('sample'));
	</script>
	</body>
</html>