DESCRIPTION

Xass extends Rails with namespacing CSS classes in Sass.

SUPPORT

Xass version Supported Sass version
0.3.0 3.4.7
0.2.0 3.2.19

INSTALLATION

We suppose you use Rails with sass-rails.

Gemfile

gem 'xass'

USAGE

Namespacing by directory tree

// /app/assets/stylesheets/application.sass

@import ./main/**/*
// /app/assets/stylesheets/main/hoge/piyo/fuga.sass

.hogehoge
  width: 100px

This emits the following css (notice that there are three underscores before hogehoge.)

.hoge__piyo__fuga___hogehoge {
  width: 100px;
}

In view, use helpers or ns prefixed class names to apply the style.

-# /app/views/someview.html.haml

= namespace :hoge, :piyo, :fuga do
  .ns-hogehoge
  -# or %div{ class: ns(:hogehoge) }

This emits

<div class="hoge__piyo__fuga___hogehoge"></div>

As matter of course, namespace can be nested as follows.

-# /app/views/someview.html.haml

= namespace :hoge do
  = namespace :piyo do
    = namespace :fuga do
      .ns-hogehoge

If you don't want to dig namespaces, you can specify namespaces directly in ns prefixed class name.

= namespace :hoge do
  .ns-piyo--fuga--hogehoge

Special class name root

You can use root class for specify a root class name.

// /app/assets/stylesheets/main/hoge/piyo/fuga.sass

.root
  width: 10px

This emits

.hoge__piyo__fuga {
  width: 10px;
}

And,

-# /app/views/someview.html.haml

= namespace :hoge, :piyo, :fuga do
  .nsr
  -# or %div{ class: nsr }

This emits

<div class="hoge__piyo__fuga"></div>

Abbreviately, you can write this as follows.

-# /app/views/someview.html.haml

= namespace_with_root :hoge, :piyo, :fuga

Disable namespacing

You can use _ prefix to disable namespacing.

// /app/assets/stylesheets/application.sass

@import ./main/**/*
// /app/assets/stylesheets/main/hoge/piyo/fuga.sass

._current
  background-color: black

This emits the following css.

.current {
  background-color: black;
}

Reset current namespace

In partial, you may want to reset current namespace. namespace! and namespace_with_root! do this.

-# /app/views/someview.html.haml

= namespace_with_root :hoge, :piyo, :fuga do
  = render partial: 'partial'
-# /app/views/_partial.html.haml

= namespace_with_root! :foo do
  foo

This emits

<div class="hoge__piyo__fuga">
  <div class="foo">
    foo
  </div>
</div>

Abbreviations

The following aliases are available.

alias :dns :namespace
alias :dns! :namespace!
alias :dnsr :namespace_with_root
alias :dnsr! :namespace_with_root!