|
NAMEReaction::UI::Controller - Reaction Base Controller ClassSYNOPSISpackage MyApp::Controller::Foo; use strict; use warnings; use parent 'Reaction::UI::Controller'; use aliased 'Reaction::UI::ViewPort'; sub foo: Chained('/base') Args(0) { my ($self, $ctx) = @_; $ctx->push_viewport(ViewPort, layout => 'foo', ); } 1; DESCRIPTIONBase Reaction Controller class, subclass of Catalyst::Controller.ROLES CONSUMED
METHODSpush_viewport $vp_class, %argsCreates a new instance of the Reaction::UI::ViewPort class ($vp_class) using the rest of the arguments given (%args). Defaults of the action can be overridden by using the "ViewPort" key in the controller configuration. For example to override the default number of items in a CRUD list action:__PACKAGE__->config( action => { list => { ViewPort => { per_page => 50 } }, } ); The ViewPort is added to the Reaction::UI::Window's FocusStack in the stash, and also returned to the calling code. Related items:
TODO: explain how next_action as a scalar gets converted to the redirect arrayref thing pop_viewportpop_viewport_to $vpCall "pop_viewport" in Reaction::UI::FocusStack or "pop_viewport_to" in Reaction::UI::FocusStack on the "$c->stash->{focus_stack}".redirect_to $c, $to, $captures, $args, $attrsConstruct a URI and redirect to it.$to can be:
$captures and $args default to the current requests $captures and $args if not supplied. make_context_closureThe purpose of this method is to prevent memory leaks. It weakens the context object, often denoted $c, and passes it as the first argument to the sub{} that is passed to the make_context_closure method. In other words,make_context_closure returns sub {
$sub_you_gave_it->($weak_c,
@_)
To further expound up this useful construct consider code written before make_context_closure was created: on_apply_callback => sub { $self->after_search( $c, @_ ); } ), This could be rewritten as: on_apply_callback => $self->make_context_closure( sub { my $weak_c = shift; $self->after_search( $weak_c, @_ ); } ), Or even more succintly: on_apply_callback => $self->make_context_closure( sub { $self->after_search( @_ ); } ), AUTHORSSee Reaction::Class for authors.LICENSESee Reaction::Class for the license.
Visit the GSP FreeBSD Man Page Interface. |