Author: cbrisson Date: Tue Jun 26 10:21:36 2018 New Revision: 1834414 URL: http://svn.apache.org/viewvc?rev=1834414&view=rev Log: [site/tools] Update VelocityLayoutServlet doc => prod
Modified: velocity/site/production/tools/devel/view-layoutservlet.html Modified: velocity/site/production/tools/devel/view-layoutservlet.html URL: http://svn.apache.org/viewvc/velocity/site/production/tools/devel/view-layoutservlet.html?rev=1834414&r1=1834413&r2=1834414&view=diff ============================================================================== --- velocity/site/production/tools/devel/view-layoutservlet.html (original) +++ velocity/site/production/tools/devel/view-layoutservlet.html Tue Jun 26 10:21:36 2018 @@ -249,13 +249,30 @@ h2:hover > .headerlink, h3:hover > .head <p>This saves you the trouble of doing the basic <html>,<head>, and <body> tags in every single screen. That's the point of layouts: to save effort and eliminate redundancy. Note that this still lets the inner screen control the title of the page. This works because the layout template is blessed by the VLS with access to the same context as the screen <em>after</em> the screen is done with it. Just do a <code>#set( $page_title = "Hello" )</code> in the screen.</p> <h2 id="alternative-layouts">Alternative Layouts<a class="headerlink" href="#alternative-layouts" title="Permanent link">¶</a></h2> -<p>VLS provides two ways to specify an alternate template for a requested page:</p> +<p>VLS provides several ways to specify an alternate template for a requested page:</p> <ol> -<li><strong>Specify the layout in the request parameters</strong></li> -</ol> -<p>Just add the query string "layout=MyOtherLayout.vm" to any request params and the VLS will find it and render your screen within that layout instead of the default layout. It don't matter how you get the layout param into the query data, only that it's there.</p> -<ol> -<li><strong>Specify the layout in the requested screen.</strong></li> +<li> +<p><strong>Specify the layout in the request attribute</strong></p> +<div class="codehilite"><pre><span class="n">request</span><span class="o">.</span><span class="na">setAttribute</span><span class="o">(</span><span class="s">"layout"</span><span class="o">,</span> <span class="s">"MyOtherLayout.vm"</span><span class="o">);</span> +</pre></div> + + +</li> +<li> +<p><strong>Specify the layout by overloading the <code>VelocityLayoutServlet.findLayout(HttpServletRequest)</code> function</strong></p> +<div class="codehilite"><pre><span class="nd">@Override</span> +<span class="kd">public</span> <span class="n">String</span> <span class="nf">findLayout</span><span class="o">(</span><span class="n">HttpServletRequest</span> <span class="n">request</span><span class="o">)</span> +<span class="o">{</span> + <span class="k">if</span> <span class="o">(</span><span class="n">request</span><span class="o">.</span><span class="na">getParameter</span><span class="o">(</span><span class="s">"change_layout"</span><span class="o">)</span> <span class="o">!=</span> <span class="kc">null</span><span class="o">)</span> <span class="k">return</span> <span class="s">"MyOtherLayout.vm"</span><span class="o">;</span> + <span class="k">else</span> <span class="k">return</span> <span class="kd">super</span><span class="o">.</span><span class="na">findLayout</span><span class="o">(</span><span class="n">request</span><span class="o">)</span> +<span class="o">}</span> +</pre></div> + + +</li> +<li> +<p><strong>Specify the layout in the requested screen.</strong></p> +</li> </ol> <p>In the requested screen, put a line like this:</p> <div class="codehilite"><pre><span class="cp">#</span><span class="nf">set</span><span class="p">(</span> <span class="p">$</span><span class="nv">layout</span> <span class="o">=</span> <span class="s2">"MyOtherLayout.vm"</span> <span class="p">)</span><span class="x"></span>