0.0
No commit activity in last 3 years
No release in over 3 years
Minimal, flexible, unobstrusive rails 4 engine for an email subscription form. It collects name, email and locale used. Optional integration with Campaign Monitor. Ready for I18n.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies
 Project Readme

LandingPage

Rails 4 engine to add a subscription by email form to an application.

There are some other rails landing page solutions out there, so here it is a quick list of what this one offers:

  • For Rails 4.
  • An engine, so it is mountable into your own application.
  • Do not come with any CSS. You have to create it according to your custom design needs.
  • Collects optional name and mandatory email.
  • Automatically collects the locale used by the user.
  • Following subscription, customizable share buttons appear.
  • Stores data in your database.
  • Optional Campaign Monitor (createsend) integration.
  • Ready for I18n.
  • HTML5 semantic mark-up
  • Very easy to override or customize to custom needs.

Rails 3.2 version

To use this gem for rails 3.2, use versions higher than 0.1 and lower than 1.0. You can find last rails 3.2 version in rails_3.2 repository branch.

Demo

Follow this link to see how it externally works.

Installation

  • Add to your Gemfile: gem 'landing_page', '~> 1.0'
  • Run bundle install
  • Run rake landing_page:install:migrations
  • Run rake db:migrate
  • Mount the routes in config/routes.rb. For example, mount LandingPage::Engine, at: '/'.

Configuration of Campaign Monitor

You must add your Campaign Monitor API key and your list id. So, in config/application.rb you can write something like:

LandingPage.campaign_monitor_api_key = 'your_api_key'
LandingPage.campaign_monitor_list_id = 'your_list_id'

If you want to use different credentials, for example, in development environment, just use the same options but instead of config/application.rb put them in config/environments/development.rb.

Collecting the locale in Campaign Monitor

Out of the box, you will collect name and email in Campaign Monitor. If you want to also collect the locale, just create a custom field in Campaign Monitor and name it locale.

Overriding and customization

Models and controllers

Like any other rails engine, use decorators to extend models and controllers.

Views

Like any other rails engine, you can override views creating them in your application.

There are three views:

Texts

Any text displayed is ready for localization under the namespace landing_page. For example, if you want to change the Name field label, you can put in your config/locales/en.yml:

en:
  landing_page:
    label_name: Your name

You can check all available keys in config/locales/en.yml.

CSS

All HTML classes are prepended with lp-. You can check them in the view files.

An elegant way to style them if you use a CSS preprocessor (like SASS), it is just to extend your own classes. For example:

.lp-field
  @extend .field

Release Policy

landing_page follows the principles of semantic versioning.

LICENSE

Copyright 2013 Marc Busqué - marc@lamarciana.com

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.