A Google Material Design Lite project built with NPM and Webpack using SASS and EcmaScript 2015/2016.
Material Design is a design language developed by Google. Expanding upon the "card" motifs that debuted in Google Now, Material Design makes more liberal use of grid-based layouts, responsive animations and transitions, padding, and depth effects such as lighting and shadows.
Material Design Lite lets you add a Material Design look and feel to your websites. It doesn’t rely on any JavaScript frameworks and aims to optimize for cross-device use, and offer an experience that is immediately accessible
A Material Design Lite project showcasing all components in MDL version 1.1.2. You can use SASS variables to modify all
aspects of MDL - a typical use case is to configure fonts and color schemes. The project has selfhosting of font Roboto,
Material Icons and Material Design Iconic Font - you don't need any external references in HTML.
A few custom components are also hosted in this project (later they should move to their own repo).
Material Design Lite is a great SASS/CSS framework, but the pre built themes was not sufficient for my use. SASS with Webpack provides control with all aspects of MDL and makes it easy to customize the design.
- NodeJS version 4.x or 5.x must be installed in advance and it is assumed that you have basic knowledge of NodeJS.
- Fork, clone or download ZIP
- CD to project root folder
- Install project dependencies:
npm install
- Start the project in development mode:
npm run dev
- Open a browser an hit:
http://localhost:8080/webpack-dev-server/
- Import the project into an IDE of your choice
- Open:
./src/stylesheets/utils/_variables.scss
- In the
/* ========== Color & Themes ========== */
section add the following code:
$color-primary: "63,63,63";
$color-primary-dark: "43,43,43";
$color-primary-contrast: "114,160,224";
$color-accent: "69,97,136";
$color-accent-contrast: "255,255,255";
- Save the modified file.
- If the Webpack Dev Server is running, you will (almost) immediately see the changes in your browser.
This project has a few custom components.
An accordion component is a collection of expandable panels associated with a common outer container. Panels consist of a header and an associated content region or panel. The primary use of an Accordion is to present multiple sections of content on a single page without scrolling, where all of the sections are peers in the application or object hierarchy. The general look is similar to a tree where each root tree node is an expandable accordion header. The user navigates and makes the contents of each panel visible (or not) by interacting with the Accordion Header.
Credits: The Accordion component is based on this CodePen
Demonstrates how you can create your own theme of MDL text fields.
Credits: The Bordered Fields Theme component is based on this CodePen
Image carousel.
The HTML <select>
element represents a control that presents a menu of options. MDL does not provide it's own
component for the <select>
element.
Credits: The Select component is based on the following sources:
- Material Design Lite selectfield component
- mdl-selectfield
- Simple Material Design Login, with select field
- Material Design <select> element, css only
This project uses the GoogleChrome dialog-polyfill
package.
You can find the usage instructions here
This project uses the lavu-details-polyfill
package.
You can find the usage instructions here.
This project is still in it's early stages.
As part of my work I review the usability of MDL as a SASS framework for both internal and public projects. In the coming months we plan to use MDL in some of our internal projects. At the same time, I plan to expand this project so that it can run as part of the actual frontend project. In this way it will be easy for web designers to make changes in design and simultaneously verify that the changes are as expected for all aspects of the design.