NAME
Tags::HTML::Message::Board - Tags helper for message board.
SYNOPSIS
use Tags::HTML::Message::Board;
my $obj = Tags::HTML::Message::Board->new(%params);
$obj->cleanup;
$obj->init($message_board);
$obj->prepare;
$obj->process;
$obj->process_css;
DESCRIPTION
Tags helper to print HTML page of message board.
The page contains message and comments for message. Each message or comment contains information about author, date of creation and text. There is form for adding of comment after list of comments.
This helper is created for usage in Plack::App::Message::Board plack application which is full application for page.
METHODS
new
my $obj = Tags::HTML::Message::Board->new(%params);
Constructor.
css
CSS::Struct::Output object for process_css processing.
Default value is undef.
css_class
CSS class for message board.
Default value is 'message-board'.
lang
Language in ISO 639-3 code.
Default value is 'eng'.
tags
Tags::Output object.
Default value is undef.
text
Hash reference with keys defined language in ISO 639-2 code and value with hash reference with texts.
Required keys are 'add_comment', 'author', 'date' and 'save'.
Default value is:
{ 'eng' => { 'add_comment' => 'Add comment', 'author' => 'Author', 'date' => 'Date', 'save' => 'Save', }, }
Returns instance of object.
cleanup
$obj->cleanup;
Process cleanup after page run.
Returns undef.
init
$obj->init($message_board);
Initialize object. Variable $message_board
is reference to array with Data::Message::Board instances.
Returns undef.
prepare
$obj->prepare;
Prepare object.
Do nothing in this class.
Returns undef.
process
$obj->process;
Process Tags structure for message board.
Returns undef.
process_css
$obj->process_css;
Process CSS::Struct structure for message board.
Returns undef.
ERRORS
new():
From Class::Utils::set_params():
Unknown parameter '%s'.
From Mo::utils::Language::check_language_639_2():
Parameter 'lang' doesn't contain valid ISO 639-2 code.
Codeset: %s
Value: %s
From Tags::HTML::new():
Parameter 'css' must be a 'CSS::Struct::Output::*' class.
Parameter 'tags' must be a 'Tags::Output::*' class.
Number of texts isn't same as expected.
Parameter 'text' is required.
Parameter 'text' must be a hash with language texts.
Texts for language '%s' doesn't exist.
Text for lang '%s' and key '%s' doesn't exist.
init():
Data object must be a 'Data::Message::Board' instance.
process():
From Tags::HTML::process():
Parameter 'tags' isn't defined.
process_css():
From Tags::HTML::process_css():
Parameter 'css' isn't defined.
EXAMPLE1
use strict;
use warnings;
use CSS::Struct::Output::Indent;
use Tags::HTML::Message::Board;
use Tags::Output::Indent;
use Test::Shared::Fixture::Data::Message::Board::Example;
# Object.
my $css = CSS::Struct::Output::Indent->new;
my $tags = Tags::Output::Indent->new(
'no_simple' => ['textarea'],
'preserved' => ['style', 'textarea'],
'xml' => 1,
);
my $obj = Tags::HTML::Message::Board->new(
'css' => $css,
'tags' => $tags,
);
# Init.
my $board = Test::Shared::Fixture::Data::Message::Board::Example->new;
$obj->init($board);
# Process message board.
$obj->process_css;
$obj->process;
# Print out.
print "CSS\n";
print $css->flush."\n\n";
print "HTML\n";
print $tags->flush."\n";
# Output:
# CSS
# .message-board .main-message {
# border: 1px solid #ccc;
# padding: 20px;
# border-radius: 5px;
# background-color: #f9f9f9;
# max-width: 600px;
# margin: auto;
# }
# .message-board .comments {
# max-width: 600px;
# margin: auto;
# }
# .message-board .comment {
# border-left: 2px solid #ccc;
# padding-left: 10px;
# margin-top: 20px;
# margin-left: 10px;
# }
# .author {
# font-weight: bold;
# font-size: 1.2em;
# }
# .comment .author {
# font-size: 1em;
# }
# .date {
# color: #555;
# font-size: 0.9em;
# margin-bottom: 10px;
# }
# .comment .date {
# font-size: 0.8em;
# }
# .text {
# margin-top: 10px;
# }
# textarea {
# width: 100%;
# padding: 12px 20px;
# margin: 8px 0;
# display: inline-block;
# border: 1px solid #ccc;
# border-radius: 4px;
# box-sizing: border-box;
# }
# button {
# width: 100%;
# background-color: #4CAF50;
# color: white;
# padding: 14px 20px;
# margin: 8px 0;
# border: none;
# border-radius: 4px;
# cursor: pointer;
# }
# button:hover {
# background-color: #45a049;
# }
# .message-board .add-comment {
# max-width: 600px;
# margin: auto;
# }
# .message-board .add-comment .title {
# margin-top: 20px;
# font-weight: bold;
# font-size: 1.2em;
# }
# button {
# margin: 0;
# }
#
# HTML
# <div class="message-board">
# <div class="main-message">
# <div class="author">
# Author: John Wick
# </div>
# <div class="date">
# Date: 25.05.2024 17:53:20
# </div>
# <div class="text">
# How to install Perl?
# </div>
# </div>
# <div class="comments">
# <div class="comment">
# <div class="author">
# Author: Gregor Herrmann
# </div>
# <div class="date">
# Date: 25.05.2024 17:53:27
# </div>
# <div class="text">
# apt-get update; apt-get install perl;
# </div>
# </div>
# <div class="comment">
# <div class="author">
# Author: Emmanuel Seyman
# </div>
# <div class="date">
# Date: 25.05.2024 17:53:37
# </div>
# <div class="text">
# dnf update; dnf install perl-intepreter;
# </div>
# </div>
# </div>
# <div class="add-comment">
# <div class="title">
# Add comment
# </div>
# <form method="post">
# <textarea autofocus="autofocus" rows="6"></textarea> <button type="button">
# Save
# </button>
# </form>
# </div>
# </div>
EXAMPLE2
use strict;
use warnings;
use CSS::Struct::Output::Indent;
use Plack::App::Tags::HTML;
use Plack::Runner;
use Tags::HTML::Message::Board;
use Tags::Output::Indent;
use Test::Shared::Fixture::Data::Message::Board::Example;
my $css = CSS::Struct::Output::Indent->new;
my $tags = Tags::Output::Indent->new(
'no_simple' => ['textarea'],
'preserved' => ['style', 'textarea'],
'xml' => 1,
);
my $message_board = Tags::HTML::Message::Board->new(
'css' => $css,
'tags' => $tags,
);
my $board = Test::Shared::Fixture::Data::Message::Board::Example->new;
$message_board->process_css;
my $app = Plack::App::Tags::HTML->new(
'component' => 'Tags::HTML::Container',
'data' => [sub {
my $self = shift;
$message_board->process_css;
$message_board->init($board);
$message_board->process;
return;
}],
'css' => $css,
'tags' => $tags,
)->to_app;
Plack::Runner->new->run($app);
# Output screenshot is in images/ directory.
DEPENDENCIES
Class::Utils, Data::HTML::Element::Button, Data::HTML::Element::Textarea, Error::Pure, Mo::utils, Mo::utils::CSS, Mo::utils::Language, Readonly, Scalar::Util, Tags::HTML, Tags::HTML::Element::Button, Tags::HTML::Element::Textarea.
REPOSITORY
https://github.com/michal-josef-spacek/Tags-HTML-Message-Board
AUTHOR
Michal Josef Špaček mailto:skim@cpan.org
LICENSE AND COPYRIGHT
© 2024 Michal Josef Špaček
BSD 2-Clause License
VERSION
0.03