Code Monkey home page Code Monkey logo

stylelint-media-use-custom-media's Introduction

Media Use Custom Media stylelint

NPM Version Build Status Support Chat

Media Use Custom Media is a stylelint rule to enforce usage of custom media queries in CSS.

Usage

Add stylelint and Media Use Custom Media to your project.

npm install stylelint stylelint-media-use-custom-media --save-dev

Add Media Use Custom Media to your stylelint configuration.

{
  "plugins": [
    "stylelint-media-use-custom-media"
  ],
  "rules": {
    "csstools/media-use-custom-media": "always" || "always-known" || "known" || "never" || "ignore"
  }
}

Options

always

If the first option is "always" or true, then Media Use Custom Media requires all @media queries to use Custom Media, and the following patterns are not considered violations:

@media (--sm) {}

@media (--sm), (--md) {}

@media screen and (--sm) {}

While the following patterns are considered violations:

@media (max-width: 40rem) {}

@media (max-width: 40rem), (--md) {}

never

If the first option is "never" or false, then Media Use Custom Media requires all @media queries to not use Custom Media, and the following patterns are not considered violations:

@media (max-width: 40rem) {}

@media screen and (max-width: 40rem) {}

While the following patterns are considered violations:

@media (--md) {}

@media screen and (--md) {}

@media (--md), (max-width: 40rem) {}

known

If the first option is "known", then Media Use Custom Media requires all @media queries referencing Custom Media to be known from either @custom-media declarations in the file or imported using the second option. Then the following patterns are not considered violations:

@custom-media --sm (min-width: 40rem);

@media (--sm) {}

@media (--sm), (min-width: 40rem) {}

While the following patterns are considered violations:

@media (--md) {}

@media (--md), (min-width: 40rem) {}

always-known

If the first option is "known", then Media Use Custom Media requires all @media queries to use known Custom Media from either @custom-media declarations in the file or imported using the second option. Then the following patterns are not considered violations:

@custom-media --sm (min-width: 40rem);

@media (--sm) {}

While the following patterns are considered violations:

@custom-media --sm (min-width: 40rem);

@media (--sm), (min-width: 40rem) {}

@media (--md) {}

ignore

If the first option is "ignore" or null, then Media Use Custom Media does nothing.


importFrom

When the first option is "always-known" or "known", then the second option can specify sources where Custom Properties should be imported from by using an importFrom key. These imports might be CSS, JS, and JSON files, functions, and directly passed objects.

// .stylelintrc
{
  "plugins": [
    "stylelint-media-use-custom-media"
  ],
  "rules": {
    "csstools/media-use-custom-media": ["known", {
      "importFrom": [
        "path/to/file.css", // => @custom-media --sm (min-width: 40rem);
        "path/to/file.json" // => { "custom-media": { "--sm": "(min-width: 40rem)" } }
      ]
    }
  }
}

stylelint-media-use-custom-media's People

Contributors

jonathantneal avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.