No commit activity in last 3 years
No release in over 3 years
A self-hosted copy of Analytics.js, a wrapper for web analytics services, for the Ruby on Rails 3.1+ asset pipeline.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 1.0.0
< 4.0.0, >= 3.1.0
>= 0

Runtime

< 4.0.0, >= 3.1.0
 Project Readme

Analytics.js-Rails

Build Status

This gem packages a self-hosted copy of Analytics.js, a wrapper for web analytics services, for use with the Ruby on Rails 3.1+ asset pipeline.

The unfortunate truch: Analytics Service A is good at X, bad at Y, Analytics Service B is good at Y, bad at X and Z. Or maybe Marketing likes Service A, but Engineering needs Service B. Whatever. Analytics.js offers one common interface to standardize and modularize analytics setup across services - now easily in rails.

Installation

Add this line to your application's Gemfile:

gem 'analytics-js-rails'

And then execute:

$ bundle

Or install it yourself as:

$ gem install analytics-js-rails

Usage

Render the loader partial on all pages where you want Analytics.js to load. Typically this is done in application.html.erb, immediately after the opening tag. For example:

<%= render 'analytics-js/loader', 
  user_identifier: current_user.id, 
  providers: { 
    'Google Analytics' => 'google_analytics_key',
    'KISSmetrics' => 'kissmetrics_key'
} %>

Of course, keys should probably be stored in config files, not hard coded.

Make sure that you root :to => "controller#action" in config/routes.rb.

Add to your config/environments/production.rb:

config.assets.precompile += %w( analytics.js )

You can now use Analytics.js in your app.

Version

The version of this gem reflects the Analytics.js version.

Thanks

To the folks at segment.io for all their work on Analytics.js - to a more panoptical world!

Contributing

Yes, please. Pull requests are very welcome. If it's not tested, we will not pull it.

  1. Fork it
  2. Bonus points for feature branches (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request