Skip to content

Commit

Permalink
Add an inline_layout stash keyword, based on the mojo.js inlineLayout…
Browse files Browse the repository at this point in the history
… one.
  • Loading branch information
mkende committed Jan 31, 2022
1 parent c05b4ea commit 9578a17
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 1 deletion.
5 changes: 5 additions & 0 deletions lib/Mojolicious/Guides/Rendering.pod
Original file line number Diff line number Diff line change
Expand Up @@ -530,6 +530,11 @@ as a render argument (not a stash value).

my $html = $c->render_to_string('reminder', layout => 'mail');

For renderers that support C<inline> templates, such as C<ep>, you can also pass a layout with the C<inline_layout>
stash value.

$c->render(inline => 'World', inline_layout => 'Hello <%= content %>!');

=head2 Partial templates

You can break up bigger templates into smaller, more manageable chunks. These partial templates can also be shared with
Expand Down
8 changes: 7 additions & 1 deletion lib/Mojolicious/Renderer.pm
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,13 @@ sub render {

# Inheritance
my $content = $stash->{'mojo.content'} //= {};
local $content->{content} = $output =~ /\S/ ? $output : undef if $stash->{extends} || $stash->{layout};
local $content->{content} = $output =~ /\S/ ? $output : undef if $stash->{extends} || $stash->{layout} || $stash->{inline_layout};
if (defined $stash->{inline_layout}) {
local $options->{inline} = delete $stash->{inline_layout};
delete $stash->{layout};
if ($self->_render_template($c, \my $tmp, $options)) { $output = $tmp }
$content->{content} //= $output if $output =~ /\S/;
}
while ((my $next = _next($stash)) && !defined $inline) {
@$options{qw(handler template)} = ($stash->{handler}, $next);
$options->{format} = $stash->{format} || $self->default_format;
Expand Down
19 changes: 19 additions & 0 deletions t/mojolicious/layouted_lite_app.t
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,16 @@ get '/content_with';

get '/inline' => {inline => '<%= "inline!" %>'};

get '/inline/inline_layout' => sub {
my $c = shift;
$c->render(inline => '<%= "inline!" %>', inline_layout => 'layouted_inline <%== content %>');
};

get '/inline/template_with_inline_layout' => sub {
my $c = shift;
$c->render(template => 'variants', format => 'txt', inline_layout => 'layouted_inline <%== content %>');
};

get '/inline/again' => {inline => 0};

get '/data' => {data => 0};
Expand Down Expand Up @@ -254,6 +264,15 @@ subtest 'Inline template' => sub {
$t->get_ok('/inline')->status_is(200)->header_is(Server => 'Mojolicious (Perl)')->content_is("inline!\n");
};

subtest 'Inline with layout' => sub {
$t->get_ok('/inline/inline_layout')->status_is(200)->header_is(Server => 'Mojolicious (Perl)')
->content_is("layouted_inline inline!\n\n");
};

subtest 'Template with inline layout' => sub {
$t->get_ok('/inline/template_with_inline_layout')->status_is(200)->content_is("layouted_inline Desktop!\n");
};

subtest '"0" inline template' => sub {
$t->get_ok('/inline/again')->status_is(200)->header_is(Server => 'Mojolicious (Perl)')->content_is("0\n");
};
Expand Down

0 comments on commit 9578a17

Please sign in to comment.