Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/buschtoens/ember-css-modules-active-route
`:app-root` & `:document-root` selectors to apply styles to the root element, when a route is active.
https://github.com/buschtoens/ember-css-modules-active-route
ember ember-addon ember-css-modules ember-routing emberjs
Last synced: 4 days ago
JSON representation
`:app-root` & `:document-root` selectors to apply styles to the root element, when a route is active.
- Host: GitHub
- URL: https://github.com/buschtoens/ember-css-modules-active-route
- Owner: buschtoens
- License: other
- Created: 2019-09-17T00:19:25.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-12-15T17:37:17.000Z (11 months ago)
- Last Synced: 2024-10-09T12:42:39.331Z (28 days ago)
- Topics: ember, ember-addon, ember-css-modules, ember-routing, emberjs
- Language: TypeScript
- Homepage:
- Size: 300 KB
- Stars: 10
- Watchers: 3
- Forks: 0
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# ember-css-modules-active-route
[![Build Status](https://travis-ci.org/buschtoens/ember-css-modules-active-route.svg)](https://travis-ci.org/buschtoens/ember-css-modules-active-route)
[![npm version](https://badge.fury.io/js/ember-css-modules-active-route.svg)](http://badge.fury.io/js/ember-css-modules-active-route)
[![Download Total](https://img.shields.io/npm/dt/ember-css-modules-active-route.svg)](http://badge.fury.io/js/ember-css-modules-active-route)
[![Ember Observer Score](https://emberobserver.com/badges/ember-css-modules-active-route.svg)](https://emberobserver.com/addons/ember-css-modules-active-route)
[![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg)](https://github.com/prettier/prettier)
[![dependencies](https://img.shields.io/david/buschtoens/ember-css-modules-active-route.svg)](https://david-dm.org/buschtoens/ember-css-modules-active-route)
[![devDependencies](https://img.shields.io/david/dev/buschtoens/ember-css-modules-active-route.svg)](https://david-dm.org/buschtoens/ember-css-modules-active-route)`:app-root` and `:document-root` selectors to apply styles to the root element,
when a route is active.## Installation
```
ember install ember-css-modules-active-route ember-css-modules
```This is a plugin for [`ember-css-modules`][ember-css-modules], so you need to
have it installed as well.[ember-css-modules]: https://github.com/salsify/ember-css-modules
## Usage
- **`:app-root`**: Maps to the [root element][root-element] of your application.
Usually ``.
- **`:document-root`**: Maps to the [`documentElement`][document-element] /
[`:root`][css-root], which is the `` element.[root-element]: https://guides.emberjs.com/release/configuring-ember/embedding-applications/
[document-element]: https://developer.mozilla.org/en-US/docs/Web/API/Document/documentElement
[css-root]: https://developer.mozilla.org/en-US/docs/Web/CSS/:root### Example
```ts
Router.map(function() {
this.route('foo', function() {
this.route('bar');
});
this.route('qux');
});
``````css
/* app/foo/styles.css */:app-root {
background: green;
}
``````css
/* app/foo/index/styles.css */:app-root {
background: red;
}
```When the user enters the `foo` route, the `:app-root` pseudo-selector will be
applied to the app's `rootElement` (``). The background of the page will
be `red`, as `foo.index` overrides `foo`.When the user navigates to `foo.bar`, the background will turn `green`, as the
user has left the `foo.index` route and the override no longer takes effect.When the user navigates to `qux`, the background will become transparent again,
as no route styles are active any more.### Combining Selectors
You can also combine the `:app-root` & `:document-root` selectors with other
regular selectors. For instance, instead of just using `:document-root`, which
targets the `:root` element (``), you can target child elements instead:```css
:document-root :global(.some-cookie-banner) {
display: none;
}
```In this example, `