Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

bem-loader

Package Overview
Dependencies
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

bem-loader

[![Build Status](https://travis-ci.org/alfa-bank-dev/bem-loader.svg?branch=master)](https://travis-ci.org/alfa-bank-dev/bem-loader)

  • 0.5.0
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

BEM loader

Build Status

The module has several purposes:

  • load CSS from bem-based project
  • provide functions to combine bemhtml templates from bem-based project

Loading CSS

It's necessary to set up plugin:

    // -----> in webpack.config.js
    var loader = require('bem-loader');
    var CollectBemAssetsPlugin = loader.CollectBemAssetsPlugin;

    module.exports = {
        // ...

        plugins: [
            new CollectBemAssetsPlugin({
                done: (data) => { loader.setStylesData(data.css); }, // load data to css-loader
                techs: ['css', 'bemhtml'], // or maybe post.css
                techExtensions: { // it is possible to define custom extensions for technology
                    bemhtml: ['bemhtml', 'bemhtml.js']
                },
                // where to search css
                levels: [
                    './bem-project/common.blocks',
                ]
            }),
        ]
    };

And use loader:


    // -----> somewhere in code
    require('bem-loader!./button.css'); // this file have to exist and should be created manually,
                                            // also a name of the file is the name of BEM-block

    // ... Webpack should handle everything else

You can also generate stubs using StubsCreatorPlugin:

    // -----> in webpack.config.js
    var loader = require('bem-loader');
    var CollectBemAssetsPlugin = loader.StubsCreatorPlugin;

    var stubsDir = './bem-stubs';
    module.exports = {
        // ...

        plugins: [
            new StubsCreatorPlugin({
                stubsDir,
                componentNames: [
                    'button',
                    'select',
                ],
                // or if you want to generate stubs for all components in some library
                // pathsToComponents: [ 'src/components' ]
            }),
        ]
    };

And somethere in your code:

    require('./bem-stubs');

Loading BEMHTML


    // -----> in webpack.config.js
    var loader = require('bem-loader');
    var CollectBemAssetsPlugin = loader.CollectBemAssetsPlugin;
    var generateBemHtml = loader.generateBemHtml;

    module.exports = {
        plugins: [
            new CollectBemAssetsPlugin({
                done: function(data) {
                    if (process.env.STANDALONE) {
                        // e.g.
                        var out = bemxjst.vidom.generate(generateBemHtml(data.bemhtml));
                        fs.writeFileSync(
                            './dist/bem-templates.js',
                            out
                        );
                    }
                },
                techs: ['bemhtml'],
                levels: [
                    './bem-project/common.blocks'),
                ]

            }),
        ],
    };

FAQs

Package last updated on 11 Apr 2016

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc