Skip to content
This repository has been archived by the owner on May 11, 2020. It is now read-only.
/ nebula.css Public archive

A work-in-progress CSS framework with the aim to quickly generate “building-block” classes for font sizes, colors, background colors and spacing.

License

Notifications You must be signed in to change notification settings

marcohamersma/nebula.css

Repository files navigation

Nebula CSS Framework

Greenkeeper badge npm version Build Status

pre-release

Nebula.css is a CSS toolkit based on SASS that generates utility classes for font sizes, colors, background colors and spacing, while having responsiveness in mind. By default, it also includes a reset stylesheet and a number of basic typographic styles.

Demo & Documentation | Usage | SassDoc

Where does it work well

  • Quick assembly of simple websites.
  • Your design system specifies colors, font sizes, and spacing amounts, and you want to quickly start building something.
  • You want to use consistent amounts of spacing between elements, that can change on different breakpoints.
  • You want to have a couple of predefined font sizes, that can scale on different breakpoints

What does it do

You define a base set of colors, font sizes, and spacing amounts, from which Nebula creates a set of CSS classes that you can use for building your website. You might want to increase things like font size or spacing when the viewport size allows it, so by applying one of Nebula's mixins at certain breakpoints you can scale up/down font sizes and spacing amounts for this breakpoint.

A basic Nebula installation generates classes like this:

// For every color you define in your website
.n-color-accent { color: #009CDA; }
.n-background-accent { background-color: #009CDA; }

// If you want, border classes can be generated for colors as well
.n-border-accent { border: 1px solid #009CDA; }

// You define a set of body and heading sizes
.n-type-h1, h1  { font-size: 31px; }
.n-type-normal  { font-size: 18px; }
.n-type-large   { font-size: 22px; }

// You can define a number of spacing values, it generates margin and padding classes
.n-spacing-medium  { margin: 40px 40px; }
.n-vspacing-medium { margin-top: 40px; margin-bottom: 40px; }
.n-hspacing-medium { margin-left: 40px; margin-right: 40px; }

.n-padding-medium  { padding: 40px 40px; }
.n-vpadding-medium { padding-top: 40px; padding-bottom: 40px; }
.n-hpadding-medium { padding-left: 40px; padding-right: 40px; }

Using a mixin then scales these items, for example with font-sizes:

@media screen and (min-width: $breakpoint-widescreen) {
  @include scale-type($bodyTextScale: 1.2);
}

// Outputs:
@media screen and (min-width: 1280px) {
  body { font-size: 21.6px; }
  .n-type-h1, h1 { font-size: 37.2px; }
  .n-type-normal { font-size: 21.6px; }
  .n-type-large  { font-size: 26.4px; }
}

Nebula is very modular, so you can disable certain modules if you don't want to have them in your output.

How to add Nebula to your project

Nebula.css can be used in a variety of ways:

For when you already have a Sass setup or build pipeline, and want to add Nebula to it.

For when you want to use Nebula.css and programmatically generate a stylesheet with certain properties.

You want to use Nebula.css, but don't have a Sass pipeline or other build process for your stylesheets.

A compiled version of Nebula can be found in dist/nebula.css. A minified version is also available there. You can include this into your HTML file and add your own styles in other files, make modifications, etc.

License

Licensed under the MIT License.

About

A work-in-progress CSS framework with the aim to quickly generate “building-block” classes for font sizes, colors, background colors and spacing.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published