Plagger::Plugin::Widget::Simple - Simple widget creation using config


Plagger documentation Contained in the Plagger distribution.

Index


Code Index:

NAME

Top

Plagger::Plugin::Widget::Simple - Simple widget creation using config

SYNOPSIS

Top

  - module: Widget::Simple
    config:
      link: http://www.example.com/
      content_dynamic: "Entry from [% entry.author %]"

DESCRIPTION

Top

Widget::Simple is a plugin that allows you to write your own widget using a simple configuration file.

CONFIG

Top

  link: http://example.com/add

URL that the widget links to. Required.

query
  query:
    version: 4
    url: $args->{entry}->url

Query parameter to append to the URL. If the value contains $, it'll be automatically eval()ed. Optional.

content
  content: <img src="http://example.com/img.gif" alt="foo" />

Content to display in a widget. HTML tags will be displayed as is and thus any HTML meta characters have to be escaped. Required, if you don't use content_dynamic.

content_dynamic
  content_dynamic: "Entry from [% entry.author | html %]"

If you want to dynamically generate the content of widget, use content_dynamic instead. Value of the content_dynamic is compiled and rendered using Template-Toolkit. Required, if you don't use content.

AUTHOR

Top

Tatsuhiko Miyagawa

SEE ALSO

Top

Plagger


Plagger documentation Contained in the Plagger distribution.

package Plagger::Plugin::Widget::Simple;
use strict;
use base qw( Plagger::Plugin );

use Encode;
use HTML::Entities;
use URI;

sub register {
    my($self, $context) = @_;
    $context->register_hook(
        $self,
        'publish.entry.fixup' => \&add,
        'plugin.init'         => \&initialize,
    );
}

sub initialize {
    my($self, $context, $args) = @_;

    if (my $name = $self->conf->{widget}) {
        my $found;
        $self->load_assets(
            "$name.yaml",
            sub {
                my $data = YAML::LoadFile(shift);
                $self->{conf} = { %{$self->{conf}}, %$data };
                $found++;
            },
        );

        unless ($found) {
            $context->log(error => "Can't find widget for $name");
        }
    }
}

sub add {
    my($self, $context, $args) = @_;

    my $widget = Plagger::Plugin::Widget::Simple::Widget->new;
    $widget->{feed}   = $args->{entry}->source || $args->{feed};
    $widget->{plugin} = $self;

    $args->{entry}->add_widget($widget);
}

package Plagger::Plugin::Widget::Simple::Widget;

sub new { bless {}, shift }

sub feed { shift->{feed} }
sub plugin { shift->{plugin} }

sub value {
    my($self, $string, $args) = @_;

    if ($string =~ /\$/) { # DWIM
        $string = eval $string;
        Plagger->context->log(error => $@) if $@;

        $string = "$string"; # stringify ::Content
        utf8::encode($string) if utf8::is_utf8($string);
    }

    $string;
}

sub html {
    my($self, $entry) = @_;
    my $uri = URI->new($self->plugin->conf->{link});

    my $args = { entry => $entry, feed => $self->{feed} };

    if (my $append = $self->plugin->conf->{append}) {
        $uri->path( $uri->path . $self->value($append, $args) );
    }

    if (my $query = $self->plugin->conf->{query}) {
        if (ref $query) {
            my @query = map {
                ($_ => $self->value($query->{$_}, $args));
            } sort keys %$query;
            $uri->query_form(@query);
        } else {
            $query = $self->value($query, $args);
            $uri->query($query);
        }
    }

    my $url = HTML::Entities::encode($uri->as_string);

    my $content;
    if (my $template = $self->plugin->conf->{content_dynamic}) {
        $content = $self->plugin->templatize(\$template, $args);
    } else {
        $content = $self->plugin->conf->{content};
    }

    return qq(<a href="$url">$content</a>);
}

1;
__END__