NAME

Data::Context::BEM - A Perl implementation of BEM

VERSION

This documentation refers to Data::Context::BEM version 0.1.1

SYNOPSIS

use Data::Context::BEM;

# Brief but working code example(s) here showing the most common usage(s)
# This section will be as far as many users bother reading, so make it as
# educational and exemplary as possible.

DESCRIPTION

BEM is a framework/protocol for how to build HTML or XML pages. The specification suggests how to assemble a page using Blocks, Elements and Modifiers.

The essence of this module is to provide a perl implementation that particularly allows the easy packaging of Blocks so they can be distributed alone and used by any site using this library. The aim is also that any site using this module can overwrite any part of an external block.

Deployed Blocks

Here is what an example block (Example) might look like:

lib/MyApp/BEM/Block/Example.pm
root/block/example/block.js
root/block/example/block.css

SUBROUTINES/METHODS

get_html ( )

Get the processed HTML

get_styles ( )

Get the processed Javascript

get_scripts ( )

Get the processed CSS

block_module ($block)

Returns a module that belongs to a block (if one exists)

set_template_path ( $instance, $device_path )

For a given Data::Context::BEM::Instance sets the Template path based on the specified template_path and the blocks used.

get_template ($block)

For a given block returns the template name used to process that block.

dump (@objects)

Dumps the passed objects to the log file

class ($block)

Returns the classes for a block.

json ($block)

Returns the block JSON encoded

DIAGNOSTICS

CONFIGURATION AND ENVIRONMENT

DEPENDENCIES

INCOMPATIBILITIES

HISTORY

While this is an attempt at implementing Yandex's BEM protocol it is also influenced by work of one of the people who originally started the work at Yandex but left before it had evolved into BEM.

BUGS AND LIMITATIONS

There are no known bugs in this module.

Please report problems to Ivan Wills (ivan.wills@gmail.com).

Patches are welcome.

AUTHOR

Ivan Wills - (ivan.wills@gmail.com)

LICENSE AND COPYRIGHT

Copyright (c) 2013 Ivan Wills (14 Mullion Close, Hornsby Heights, NSW Australia 2077). All rights reserved.

This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See perlartistic. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.