/BEMNames

A utility for easily creating BEM class names in JS

Primary LanguageJavaScript

BEMNames

A utility for easily creating BEM class names in JS

Installation

npm install @takinabradley/bem-names

Usage:

Create BEM object with BEM.b as desired block name

import createBEM from "@takinabradley/bem-names"

const BEM = createBEM("your-block")
BEM.b // 'your-block'

Get BEM string from element name

BEM.e("your-elem") // 'your-block__your-elem'

Get BEM element with modifier

BEM.e("your-elem", "sharp") //'your-block__your-elem--sharp'

Get BEM block modifier

BEM.e(null, "pointy") //'your-block--pointy'
Better BEM block modifier alternative
BEM.bm("super sucky") // 'your-block--super your-block--sucky'

Better way to add modifiers to elements:

const modifierFunc = BEM.m(<block-or-elem-to-modify>)
modifierFunc('modifier1 modifier2')

Ex:

const modifyNavItem = BEM.m("block-name__nav-item")
//        OR          BEM.m(BEM.e('nav-item'))

modifyNavItem("mod1 mod2")
// 'block-name__nav-item--mod1 block-name__nav-item--mod2'

Snippets

The following are useful snippets to add to javascript.json in VSCode

{
  "import createBEM": {
    "prefix": "icb",
    "body": "import createBEM from '@takinabradley/bem-names'"
  },
  "createBEM": {
    "prefix": "bc",
    "body": "const BEM = createBEM($1)$2"
  },
  "BEM Block": {
    "prefix": "bb",
    "body": "BEM.b"
  },
  "ModifyBEMBlock": {
    "prefix": "bbm",
    "body": "BEM.bm($1)$0"
  },
  "BEM Element": {
    "prefix": "be",
    "body": "BEM.e($1)$0"
  },
  "BEM create Modifier": {
    "prefix": "bm",
    "body": "const $1 = BEM.m($2)$0"
  }
}