SocialLinker

Build Status

SocialLinker solves two problems involving social networks (and search engines): proper meta-headers and proper share links.

SocialLinker is able to generate the most common share links for you, without depending on JavaScript. You should use generated links, instead of the share buttons provided by the platforms themselves, to protect your user's privacy, and this gem makes it easy for you to do so.

And when using Rails, SocialLinker also solves the tedious job of getting the meta tags right. Because once you've set the SocialLinker::Subject correctly, you've also got the right ingredients for the perfect meta keywords & description, open graph variables etc.

Installation

Add this line to your application's Gemfile:

gem 'social_linker'

And then execute:

$ bundle

Or install it yourself as:

$ gem install social_linker

Usage

Basics

Initialize the subject with enough material to generate links from, such as the page's url, maybe the image url (mainly for Pinterest type-shares), a description, tags etc.

For example, initialze

social_linker_subject = SocialLinker::Subject.new(media: "http://example.com/img.jpg", url: "http://example.com/", title: "Example website", description: "Example.com is the typical URL you would want to use in explanations anyway."

You'll get the e-mail share url by calling:

social_linker_subject.share_link(:mail)

Which will deliver you the following url:

mailto:emailaddress?subject=Example%20website&body=Example.com%20is%20the%20typical%20URL%20you%20would%20want%20to%20use%20in%20explanations%20anyway.%0A%0Ahttp%3A%2F%2Fexample.com%2F

Setting up the subject

The supported options are:

  • url
  • media (media url, e.g. an image (shared only for Pinterest, but also used in OpenGraph headers & Twitter Cards))
  • summary
  • description
  • title
  • tags

And of a more site-global nature:

  • twitter_username
  • facebook_app_id
  • language
  • site_title_postfix (which can be hidden by setting render_site_title_postfix to false)

I've tried to map them as good as possible to the different share tools. Sometimes by combining several values. You may also pass along link-specific parameters such as :hashtags, so you can control the 2-tag long string that is generated from the list of tags by default.

For example:

@subject = SocialLinker::Subject.new(
  title: "title",
  url: "https://murb.nl/blog",
  media: "https://murb.nl/image.jpg",
  media_dimensions: [640, 480],
  summary: "short summary",
  tags: ["key1", "key2", "key3"],
)

You can also merge details later on. Let's say you want to set the global values:

@subject = SocialLinker::Subject.new(
  site_title_postfix: ":murb:",
  twitter_username: 'murb',
  facebook_app_id: '123123123',
  tags: ['murb', 'ruby']
)

You might to set these defaults in a before action in your (Ruby on Rails-speak) ApplicationController. Later on you can merge details into this subject:

@subject.merge!({
  title: "title",
  url: "https://murb.nl/blog",
  media: "https://murb.nl/image.jpg",
  media_dimensions: [640, 480],
  summary: "short summary",
  tags: ["key1", "key2", "key3"]
})

Hint, the media_dimensions are 'compatible' with the output of the Dimensions-gem:

@subject.merge!({
  title: @article.title,
  url: article_url(@article),
  media: @article.image.url(:inline),
  media_dimensions: Dimensions.dimensions(@article.image.path(:inline)),
  summary: @article.description,
  tags: @article.tag_list.to_a
})

Currently support is available for the following ways of sharing:

:email
:facebook
:facebook_native
:twitter
:twitter_native
:pinterest
:google
:linkedin
:whatsapp

Or to save you the copy-paste:

TestMailLink

UTM Campaign parameters

By default utm campaign parameters are added when they are not present. You can turn this off by passing the option: utm_parameters: false.

Use the following to create a sharelink to Facebook

social_link_to @subject, :facebook

This results in a simple <a href> containing the share link and an svg image. This SVG image may or may not be found depending on your asset initialization, make sure that config/initializers/assets.rb contains the following line:

Rails.application.config.assets.precompile += %w( social_linker/icons.svg )

(if you don't it probably will be suggested to you by Rails)

If you want to change the content of the link, pass a block, e.g.:

social_link_to @subject, :facebook do
  "Share on Facebook!"
end

To make sure that the icons align well, make sure to include the styling, include the following line to the head of your application.ccs file:

*= require social_linker/icons

Meta-Headers

When using Ruby on Rails a few helpers have been created.

Just set the following, which should give you a reasonable default.

header_meta_tags(@subject, {
  site_title_postfix: "your sitename" # optional
})

Alternatively you can also set the site_title_post in the Subject directly, as suggested in an earlier section:

header_meta_tags(@subject)

Advanced

Reuse the SVG icons elsewhere

When integrating social icons into your site, you might also want to include login options for these social networks, or access the icons for other reasons. Below is 'standard' example code of how to access image-assets in the icon

<svg class="icon icon-facebook-official">
  <use xlink:href="<%=image_path('social_linker/icons.svg')%>#icon-facebook"></use>
</svg>

Note: If you just want the SVG icon standalone, you can also use the social_link_to_image view helper:

social_link_to_image :facebook

Included layers:

  • icon-email
  • icon-google
  • icon-sticky-note-o
  • icon-share-square-o
  • icon-search
  • icon-heart-o
  • icon-heart
  • icon-twitter
  • icon-pinterest
  • icon-facebook
  • icon-facebook-unofficial
  • icon-linkedin
  • icon-whatsapp
  • icon-tumblr

Icons have been created with the IcoMoon App and come from the Font Awesome-set (OFL licensed).

Problem solving

SVG Icons not showing up in older browsers

When using SVG and serving your pages to older browsers, make sure you use something like SVG4Everyone. Include in your gemfile:

source 'https://rails-assets.org' do
 gem 'rails-assets-svg4everybody'
end

and include the following line to the head of your application.js file:

//= require svg4everybody

TODO

  • Idea: maybe improve share helpers with javascript timeout workarounds for native alternatives (although Twitter and facebook work well)
  • More share methods (pull request welcome)

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.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/murb/social_linker. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

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