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 Dec 5, 2021
1 parent c05b4ea commit 2d74508
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 0 deletions.
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
15 changes: 15 additions & 0 deletions lib/Mojolicious/Renderer.pm
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,12 @@ sub render {
# Inheritance
my $content = $stash->{'mojo.content'} //= {};
local $content->{content} = $output =~ /\S/ ? $output : undef if $stash->{extends} || $stash->{layout};
if ($stash->{inline_layout}) {
@$options{qw(template inline)} = (undef, delete $stash->{inline_layout});
$options->{format} = $stash->{format} || $self->default_format;
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 Expand Up @@ -214,6 +220,15 @@ sub _next {
return join '/', 'layouts', $layout;
}

sub _render_content {
my ($self, $c, $next, $options, $output) = @_;
my $stash = $c->stash;
@$options{qw(handler template)} = ($stash->{handler}, $next);
$options->{format} = $stash->{format} || $self->default_format;
if ($self->_render_template($c, \my $tmp, $options)) { $$output = $tmp }
$stash->{'mojo.content'}->{content} //= $$output if $$output =~ /\S/;
}

sub _render_template {
my ($self, $c, $output, $options) = @_;

Expand Down
10 changes: 10 additions & 0 deletions t/mojolicious/layouted_lite_app.t
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,11 @@ 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/again' => {inline => 0};

get '/data' => {data => 0};
Expand Down Expand Up @@ -254,6 +259,11 @@ 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 '"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 2d74508

Please sign in to comment.