Lumo
⚠️ Starting from Vaadin 20, this project has migrated tovaadin-web-components
monorepository.This repository is used for Vaadin 14 LTS and Vaadin 19.
Lumo –
✨ enchantment (Finnish) and🔆 light (Esperanto)
Lumo is a design system foundation for modern, beautiful and accessible web applications.
Lumo contains foundational styles – typography, colors, visual style, sizing & spacing and icons – that components and applications can use to achieve a consistent visual design.
The implementation of Lumo is based on CSS custom properties, and Polymer style modules. Note, that you don’t need to use Polymer to build your application in order to use Lumo.
Documentation
For documentation and instructions how to get started, use the “Documentation” link in the latest release notes.
Part of the Vaadin platform
Lumo is maintained as a part of the Vaadin platform.
Vaadin components is a collection of web components that use the Lumo design language as their default theme. The Vaadin app starters are also based on Lumo.
Big Thanks
Cross-browser Testing Platform and Open Source <3 Provided by Sauce Labs.
Contributing
Reporting issues and feature request is a great way to help! If you have questions, join the Vaadin components chat – we’re happy to answer Lumo related questions there.
Running demos and tests in a browser
-
Fork the
vaadin-lumo-styles
repository and clone it locally. -
When in the
vaadin-lumo-styles
directory, runnpm install
and thenbower install
to install dependencies. -
Run
npm start
, browser will automatically open the component API documentation. -
You can also open demo/documentation by adding demo to the URL, for example:
Adding or updating icons
-
Open
icons/Lumo Icons.sketch
using Sketch -
Follow the instructions in the Sketch document
-
Run
npm install
to install dependencies -
Run
gulp icons
to generate new versions oficonset.html
andfont-icons.html
Following the coding style
We are using ESLint for linting JavaScript code. You can check if your code is following our standards by running gulp lint
, which will automatically lint all .js
files as well as JavaScript snippets inside .html
files. CSS inside .html
files is also linted at the same time.
Creating a pull request
- Make sure your code is compliant with our code linters:
gulp lint
- Submit a pull request with detailed title and description
- Wait for response from one of Vaadin components team members
Updating the version number
Use npm version <new version>
to update the version number in package.json
and in other relevant places such as version.html
, when preparing to release a new version.
License
Apache License 2.0