better-share-button
v0.1.0
Published
fast, beautiful, and painless social shares (a fork of the original share-button)
Downloads
5
Readme
Simple, light, flexible, and good-looking share button. See it in action!
This is a fork of the original Carrot share-button. Because, after a year of being unmaintained, it still looks freaking awesome.
An Introduction
Why Should You Use This?
All major social networks have their own share widgets you can put on your page, but this isn't ideal for a variety of reasons:
- They tend to be slow-loading.
- They inject extra javascript and DOM elements into your page making it slower.
- They generally aren't customizable enough to fit the design of your site.
- Managing each provider's code snippets etc is repetitive and needless. Additionally, they can make your front-end code quite messy.
- The buttons themselves take up a lot of space (especially the Facebook share button).
Let's take a quick look at the alternative, using this little plugin:
- It doesn't load any iframes or extra javascript making the overall load time much faster.
- It looks simple and clean by default, and can be customized in any and every way.
- All you have to do to use it is include the script and call
new ShareButton
on ashare-button
element. That's two lines of code total, the script link and the share call. - It's tiny and compact, expanding only when the user actually wants to share something.
Getting Started
- Run
bower install better-share-button#master
. There has not been a release ofbetter-share-button
since its original forking fromshare-button
, so you need to use the master branch. - Make a
share-button
element on your page. - In your javascript, call
new ShareButton
. - Pass options to the share call if you want (details below).
- Profit!
<share-button></share-button>
new ShareButton({
// Optional options:
networks: {
facebook: {
appId: "abc123"
}
}
});
NPM installation
TODO
Customization
Configuration Options
The share button is extremely flexible. As such, we provide the ability to pass a wide array of options for additional configuration. All configuration options are available here.
Styles
Additionally, you're able to customize the look and feel of the button and animations though CSS. All CSS styles and how to modify them are available here.
Hooks
You are able to set before
and after
hooks when a user clicks a network.
This allows you to dynamically change attributes for that button. For more
information, see
here
Public API
The share button also returns a simple API that can be used to control it should you need to. For instance:
var share = new ShareButton(); // Grabs all share-button elements on page
share.toggle(); // toggles the share button popup
share.open(); // open the share button popup
share.close(); // closes the share button popup
share.config; // exposes the configurations listed above
Inspiration
The original share-button
project was inspired by
this dribbble shot and
this cssdeck experiment -
huge props to these two guys for some incredible ideas and work.
This new one was inspired by the original, because it's a fork, and it's kinda hard not to be inspired by the original when you fork!!
Contributing and License
- Contributing Guidelines can be found here
- Licensed under the MIT Expat license