Elm-port of the Material Design Lite CSS/JS library
Find a file
2016-03-28 21:25:11 +02:00
examples Implemented Waterfall headermode. Fixes #21. 2016-03-28 21:25:11 +02:00
src Implemented Waterfall headermode. Fixes #21. 2016-03-28 21:25:11 +02:00
.gitignore Removed remnants of native implementation. 2016-03-15 17:35:34 +01:00
elm-package.json Version bump 2016-03-16 08:19:55 +01:00
Makefile Makefile 2016-03-15 17:57:39 +01:00
page.html Implemented Waterfall headermode. Fixes #21. 2016-03-28 21:25:11 +02:00
README.md Updated README 2016-03-16 06:28:36 +01:00

Material Design Components in Elm

Port of Google's Material Design Lite CSS/JS implementation of the Material Design Specification.

Live demo here.

MDL is implemented primarily through CSS, with a little bit of Javascript adding and removing CSS classes in response to DOM events. This port re-implements the CSS parts in Elm, but relies on the CSS of MDL verbatim.

CAUTION! This is an early and incomplete prototype. Use at your own risk.

Get Started

Build the demo:

> elm-make examples/Demo.elm

This will construct a file index.html; open that in your browser.

The library has a tiny native component (for measuring geometry of rendered elements, a necessity for re-implementing MDL ripple-animations), and so cannot be in the elm-package library. If you wish to use the library, I know no better way than to copy Material.elm and Material/* to your own project.

Embedding in your own HTML.

Initial page load of the demo will produce a flicker, which can only be avoided if you set up the MDL css to load before elm does. Use the file page.html as a template. To build the demo in this mode, comment out line 154 in examples/Demo.elm and build the demo like this:

> elm-make examples/Demo.elm --output elm.js

This will produce a file elm.js. Open the file page.html in your browser; this file will set up MDL css and load elm.js.

Contribute

Please do! The easiest place to start is to add more CSS-only components. These require no porting of Javascript, just putting together css-classes as instructed by the MDL Component Documentation. Take a look at

Progress bars are pure CSS, and spinners seem to use Javascript only to insert auxiliary DOM-nodes on initialisation.

The remaining components, use Javascript in various ways. Toggles seem to use Javascript exclusively to insert ripple-animations and might be easy to implement using the Ripple.elm component:

The rest I haven't looked at; they may or may not be straightforward to port to Elm.