Skip to content

Complete solution for clicks & user focused areas on websites. It includes functionality to store & show heatmap related data.

License

Notifications You must be signed in to change notification settings

qbatch/heatmap-rails

Repository files navigation

Gem Version

Heatmap-Rails

Integrate heatmaps in your web application to see on which part the user spends most time on your web application. Where does users click on the page. Helping in gathering analytics to find out what works on the web, what attracts most of the users. View user interactions and make your application more amazing! ✨

Try the demo

Quick Demo of HeatMap Generation

Demo1

Heatmap-Rails Works Perfectly in any Screen Size.

Demo2

Installation

Add this line to your application's Gemfile:

gem 'heatmap-rails'

And then execute:

$ bundle

Or install it yourself as:

$ gem install heatmap-rails

Usage

  1. Install the gem

  2. Run the command to generate a migration to save heatmaps data:

$ rails g heatmap_rails:install
  1. Migrate:
$ rake db:migrate
  1. Include the following helper on any page where you need to generate the heatmap:
<%= save_heatmap %>
  1. Include where to show the heatmap:
<%= show_heatmap %>
  1. Before adding headmap.js in the application install jquery-rails gem and require it in application.js file
//= require jquery
  1. In respective JS file, Require HeatMap.Js to show the heatmap:
//= require heatmap.js

Viewing Heat Maps

Use the helper

<%= show_heatmap %>

The argument is the path of current page. This way the helper will only display the respective heatmap. The viewing can be done in multiple ways, for example if you want only the admin users to view heatmap, you can do something like:

<% if admin_user_signed_in? %>
    <%= show_heatmap %>
<% end %>

Another way can be using some param in the URL. For example if you want to use URL like:

www.website.com/?see_heatmap

You can use:

<% if request.query_parameters.include?("see_heatmap") %>
    <%= show_heatmap %>
<% end %>

Options

You can customize the max stack limits before the data is sent to server side via http request. We understand for different application the average user interactions time on a specific page varies. You can set these values w.r.t to your application's needs:

<%= save_heatmap({click: 3, move: 50}) %>

The default values for clicks is 3. For mouse movements tracking its 50.

<%= save_heatmap({click: 3, move: 50, html_element: 'body'}) %>

you can even restrict heatmap generation to a specific DOM element. Default value for DOM element is body element. This can be change to any .class or any '#id'.

Development

After checking out the repo, run bin/setup to install dependencies. Then, run rake spec to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Credits

heatmap-rails uses HeatMap.Js to show generated data in form of heatmaps.

Contributing 🚧

  1. Bug reports are always welcome.
  2. Pull Requests. Suggest or Update.

License

The gem is available as open source under the terms of the MIT License.