Title: Rails Theme
Author: paulrosen
Published: <strong>29 de noviembre de 2011</strong>
Last modified: 31 de mayo de 2013

---

Buscar plugins

Este plugin **no se ha probado con las últimas 3 versiones mayores de WordPress**.
Puede que ya no tenga soporte ni lo mantenga nadie, o puede que tenga problemas 
de compatibilidad cuando se usa con las versiones más recientes de WordPress.

![](https://s.w.org/plugins/geopattern-icon/rails-theme.svg)

# Rails Theme

 Por [paulrosen](https://profiles.wordpress.org/paulrosen/)

[Descargar](https://downloads.wordpress.org/plugin/rails-theme.zip)

 * [Detalles](https://es.wordpress.org/plugins/rails-theme/#description)
 * [Valoraciones](https://es.wordpress.org/plugins/rails-theme/#reviews)
 *  [Instalación](https://es.wordpress.org/plugins/rails-theme/#installation)
 * [Desarrollo](https://es.wordpress.org/plugins/rails-theme/#developers)

 [Soporte](https://wordpress.org/support/plugin/rails-theme/)

## Descripción

This calls back to a web service to get theme information, so that it is easy to
keep the rails and WP sides in sync.

It is designed to be used when a Rails application wishes to contain WordPress content.
This allows the WordPress pages
 to directly use the styles of the Rails application
so that it will always match, even when the Rails app changes.

It is also useful when the header of the page changes, for instance, if new menu
items can appear depending on the state of the
 application.

And finally, if you want to POST back to the Rails app (for instance, to log in),
you need the CSRF to be set in the page’s header,
 and that needs to come from the
Rails session.

NOTE: This might take some tweaking depending on the theme you are using. It successfully
works with the default 2011 theme
 and the Hybrid theme.

It requires an entry point in your Rails controller that returns three things:
 
1. a section that is put in the header to load stylesheets and javascript, 1. a 
section that is loaded at the top of the body, and 1. a section that is loaded at
the bottom of the body.

There is one main option in the plugin to tell it the base URL of the Rails app.
The rails app is expected to respond to the
 following URL:

    ```
    /wrapper
    ```

This also supplies a convenience option to add classes to the so that you can match
the body styles in your rails app.

### Troubleshooting

 1. My theme doesn’t show up at all.

Turn on WP_DEBUG in wp_config.php and see if there is an error message printed to
the page.

## Capturas

 * [[
 * This is the options page.

## Instalación

The plugin itself is easy to install.

 1. Upload this folder to the `/wp-content/plugins/` directory.
 2. Activate the plugin through the ‘Plugins’ menu in WordPress.
 3. Click ‘Settings’ in the dashboard, then ‘Rails Theme’ and enter the base URL for
    your Rails app.

There are a number of things that have to happen on the Rails side, though.

You will need something like the following in your routes.rb file:

    ```
    get "/wrapper" => "home#wrapper"
    ```

And it should return a partial with three sections. The sections should be separated
from each other with 10 tildes (that
 is: `~~~~~~~~~~`).

It is most convenient to rearrange your layout file to call those three partials.
Here is a possible layout file:

    ```
    <!DOCTYPE html>
    <html>

    <head>
        <%= render :partial => '/layouts/dependencies' %>
        <title>Site Title</title>

    </head>
    <body>

       <%= render :partial => '/layouts/header' %>
        <%= yield %>

    <%= render :partial => '/layouts/footer' %>

    </body>
    </html>
    ```

Notice that all the work is done by those three partials.

Then, the wrapper call is handled like this:

 * home_controller:
    def wrapper render :partial => «/layouts/wrapper» end
 * layouts/_wrapper.html.erb:
    «/layouts/dependencies» %> «/layouts/any_session_related_tasks%
   >
 *     ```
       <%= render :partial => "/layouts/header" %>
       ```
   
 *  «/layouts/footer» %>

You will have to be careful about the css classes you create so that they don’t 
conflict with the WP theme’s classes.
 For instance, you probably don’t want a class
named ‘content’.

You will also probably have to tweak the css in your layout some to override some
of your theme. In the case of the
 2011 theme, I had to put in the following:

    ```
    /* for wordpress */
    #body-container {
        margin: 0;
    }
    #header-container {
       display:none;
    }
    ```

The big problem with making this seamless is that WP can’t use the session data 
from the Rails app. Typically in
 my apps, this means that I don’t know how to draw
the «sign in» section because I can’t tell if the user is logged in. To get around
that, the sign in section should be drawn as if there is no one logged in, then 
an ajax call made from the Rails app to correct that. That is what should go in 
the `any_session_related_tasks` partial above: some javascript that triggers at `
onload` time that returns the sign in div.

## FAQ

  How do I get rails to ignore the WP’s PHP?

If you are using Passenger and Apache, put this in your conf file (assuming you 
want the WordPress site to be accessible
 through `/news`):

    ```
    <Directory "/path/to/rails/app/public/news">
        PassengerEnabled off
        AllowOverride all
    </Directory>
    ```

  How do I get the URL for the WP blog look like the URLs for my Rails app?

If you create a symbolic link in your public folder to the wp site, then you can
use the URL /news to get to your blog:

    ```
    cd path/to/rails/app/public
    ln -s /path/to/wordpress/installation news
    ```

## Reseñas

No hay valoraciones para este plugin.

## Colaboradores y desarrolladores

«Rails Theme» es un software de código abierto. Las siguientes personas han colaborado
con este plugin.

Colaboradores

 *   [ paulrosen ](https://profiles.wordpress.org/paulrosen/)

[Traduce «Rails Theme» a tu idioma.](https://translate.wordpress.org/projects/wp-plugins/rails-theme)

### ¿Interesado en el desarrollo?

[Revisa el código](https://plugins.trac.wordpress.org/browser/rails-theme/) , echa
un vistazo al [repositorio SVN](https://plugins.svn.wordpress.org/rails-theme/) 
o suscríbete al [registro de desarrollo](https://plugins.trac.wordpress.org/log/rails-theme/)
por [RSS](https://plugins.trac.wordpress.org/log/rails-theme/?limit=100&mode=stop_on_copy&format=rss).

## Registro de cambios

#### 1.1.1.0

 * Retry the call to rails, since the rails app or the network might be slow.

#### 1.1.0.0

 * Added the option to add classes to .

#### 1.0.3.0

 * Removing the pass through of cookies, since later versions of Rails invalidates
   the session when it sees the cookie
    coming from the wrong place.

#### 1.0.2.0

 * Using WP_Http to make the server call to work in more configurations.
 * Improved error reporting.

#### 1.0.1.0

 * Pass the page’s cookies through to the rails app.

#### 1.0

 * Initial release.

## Meta

 *  Versión **1.1.1.0**
 *  Última actualización **hace 13 años**
 *  Instalaciones activas **10+**
 *  Versión de WordPress ** 3.2 o superior **
 *  Probado hasta **3.5.2**
 *  Idioma
 * [English (US)](https://wordpress.org/plugins/rails-theme/)
 * Etiquetas:
 * [rails](https://es.wordpress.org/plugins/tags/rails/)[theme](https://es.wordpress.org/plugins/tags/theme/)
 *  [Vista avanzada](https://es.wordpress.org/plugins/rails-theme/advanced/)

## Valoraciones

Aún no se han enviado valoraciones.

[Your review](https://wordpress.org/support/plugin/rails-theme/reviews/#new-post)

[Ver todas las valoraciones](https://wordpress.org/support/plugin/rails-theme/reviews/)

## Colaboradores

 *   [ paulrosen ](https://profiles.wordpress.org/paulrosen/)

## Soporte

¿Tienes algo que decir? ¿Necesitas ayuda?

 [Ver el foro de soporte](https://wordpress.org/support/plugin/rails-theme/)

## Donar

¿Te gustaría apoyar el progreso de este plugin?

 [ Dona a este plugin ](http://www.performantsoftware.com/wordpress/plugins/rails_theme/)