Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 1019705
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 16, 20262026-05-16T11:03:20+00:00 2026-05-16T11:03:20+00:00

I have a Rails-based site with a basic two-column layout. On the right is

  • 0

I have a Rails-based site with a basic two-column layout. On the right is a sidebar with different (let’s just say) vertical widgets. Depending on what page you visit, the widgets can be included, excluded, and in different order. For ex:

Main Page (Application)

PAGE CONTENT…

SIDEBAR

  • Widget A
  • Widget B
  • Widget C

Page X

PAGE CONTENT…

SIDEBAR

  • Widget D
  • Widget A
  • Widget C

Page Y

PAGE CONTENT…

SIDEBAR

  • Widget E
  • Widget A
  • Widget B
  • Widget C

Right now the way that I’m displaying the page-specific widgets is not very DRY. I’m creating a layout for each page, then copying and pasting the same HTML partials and widget partials over and over. For ex:

application.html.erb

<%= render :partial => 'shared/html_header' %>

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">

    <%= render :partial => "shared/head" %>     

    <body>                        
        <div id="outer">

            <%= render :partial => 'shared/banner' %>
            <%= render :partial => 'shared/nav' %>

            <div id="main">
                <table cellpadding="0" cellspacing="0" border="0" style="width:100%;">
                  <tr style="vertical-align:top;">

                   <td style="width:759px;">
                    <%= render :partial => 'shared/content' %>
                  </td>

                        <td><%= image_tag("spacer.gif", :width => "5") %></td>

                        <td style="width:252px;">
                            <%= render :partial => 'shared/widget_a' %>
                            <%= image_tag("spacer.gif", :height => "10") %>

                            <%= render :partial => 'shared/widget_b' %>
                            <%= image_tag("spacer.gif", :height => "10") %>

                            <%= render :partial => 'shared/widget_c' %>
                            <%= image_tag("spacer.gif", :height => "10") %>

                        </td>
                    </tr>
                </table>
            </div>
            <%= render :partial => 'shared/footer' %>
        </div>
            <%= render :partial => 'shared/user_voice_widget_script' %>
            <%= render :partial => 'shared/google_analytics_script' %>
    </body> 
</html>

I basically just repeat this pattern for the other page layouts, but with the page-specific widgets. Doesn’t seem too DRY.

I’m thinking there has to be a more efficient way to do this. Any suggestions?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-16T11:03:21+00:00Added an answer on May 16, 2026 at 11:03 am

    You can use a single layout file which defines the two column structure for all your pages and then use Rail’s content_for helper to contextually populate your sidebar, depending on the page visited. Then the only page specific information is the sidebar detail, not the whole layout being repeated over and over.

    In your (single) application layout:

    <td style="width:252px;">
      <%= yield :sidebar %>
    </td>
    

    Somewhere in your pages:

    <% content_for :sidebar do %>
      <%= render :partial => 'shared/widget_a' %>
      <%= image_tag("spacer.gif", :height => "10") %>
    
      ...
    
    <% end %>
    

    If enough of the widget combinations occur frequently together you could consider putting their render directives together into partials and using those in your content_for block.

    The general technique is described here

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 499k
  • Answers 500k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer This is not pretty but it works: rm -R $(ls… May 16, 2026 at 12:45 pm
  • Editorial Team
    Editorial Team added an answer Yes. Override the base1 and base2 methods in Derived to… May 16, 2026 at 12:45 pm
  • Editorial Team
    Editorial Team added an answer No, you can't. Unfortunately, UIEvent doesn't expose any public way… May 16, 2026 at 12:45 pm

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Related Questions

Im working on a Rails based application where I have the need to allow
I have a rails site that allows authentication through OAuth (I use Restful Authentication
I am going over some basic guides in Rails, reviewing the basics and such
I want to make a community based site, which is Drupal's strength. However I
I am building a site for a magazine that includes three different sections- articles,
We have some JavaScript code that resizes <div/> elements (adjusts height/width/padding/margin etc.) based on
Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2) I have a Rails
I have a model Task which will HABTM many TaskTargets. When it comes to
I'm working on a site that's grown both in terms of user-base and functionality
So Rails time stamping is great. I'm using it to add expires headers to

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.