NAME

XML::XSS::StyleAttribute - Style attribute for XML::XSS stylesheet rule

VERSION

version 0.3.0

SYNOPSIS

use XML::XSS;

my $xss = XML::XSS->new;
my $attribute = $xss->get('chapter')->pre;

$attribute->set_value( '<div class="chapter">' );

DESCRIPTION

The XML::XSS::StyleAttribute objects are the building blocks of the document transformation. They can be assigned a string, which is inserted verbatim in the rendered document

$xss->get('chapter')->set_pre( '<div class="chapter">' );

or a sub reference, which return value is inserted in the rendered document

$xss->get('clock')->set_pre( sub { return "date and time are: " .  localtime } );

Upon execution, the sub references will be passed three parameters: the invoking rule, the XML::LibXML::Node object currently rendered and the arguments ref given to render().

$xss->set( 'div' => {
    intro => sub {
        my ( $self, $node, $args ) = @_;
        my @para = $node->findnodes( '@para' );
        return "<p>node has " . @para . " para child nodes.</p>";
    }
} );

OVERLOADING

*=

Assigns the right value to the attribue.

$xss.'chapter'.'pre' *= "<div class='chapter'>";

is equivalent to

$xss->set( chapter => { pre => "<div class='chapter'>" } );

x=

Similar to '*=', but considers the right side as a template and converts it via xsst.

$xss.'chapter'.'pre' x= q{
    <div class="chapter">
        <% $r->stylesheet->stash{chapter_nbr}++ %>
};

is equivalent to

$xss->set( 'chapter' => { pre => xsst( <<'END_TEMPLATE' ) } );
    <div class="chapter">
        <% $r->stylesheet->stash{chapter_nbr}++ %>
END_TEMPLATE

ATTRIBUTES

value

The string or sub reference used by the style attribute.

# long way
$xss->get('chapter')->pre->set_value( '<div class="chapter">' );

# short way
$xss->set( chapter => { pre => '<div class="chapter">' } );

# shortest way
$xss.'chapter'.'pre' *= '<div class="chapter">';

AUTHOR

Yanick Champoux <yanick@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2010 by Yanick Champoux.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.