# This code was forked from the LiveJournal project owned and operated # by Live Journal, Inc. The code has been modified and expanded by # Dreamwidth Studios, LLC. These files were originally licensed under # the terms of the license supplied by Live Journal, Inc, which can # currently be found at: # # http://code.livejournal.org/trac/livejournal/browser/trunk/LICENSE-LiveJournal.txt # # In accordance with the original license, this code and all its # modifications are provided under the GNU General Public License. # A copy of that license can be found in the LICENSE file included as # part of this distribution. package LJ::Widget::ExamplePostWidget; use strict; use base qw(LJ::Widget); use Carp qw(croak); #sub need_res { qw( stc/widgets/examplepostwidget.css ) } sub render_body { my $class = shift; my %opts = @_; my $ret; $ret .= "This widget does a normal POST.
"; $ret .= "Render it with: LJ::Widget::ExamplePostWidget->render;
"; $ret .= 'Put this at the part of the page where you want the POST to be handled: LJ::Widget->handle_post(\%POST, qw( ExamplePostWidget ));
'; $ret .= $class->start_form; $ret .= "

Type in a word: " . $class->html_text( name => "text", size => 10 ) . " "; $ret .= $class->html_submit( button => "Click me!" ) . "

"; $ret .= $class->end_form; return $ret; } sub handle_post { my $class = shift; my $post = shift; my %opts = @_; if ( $post->{text} ) { warn "You entered: $post->{text}\n"; } return; } 1;