Skip to content

[WordPress] A WordPress plugin that allows you to easily integrate the latest version of FontAwesome.

License

Notifications You must be signed in to change notification settings

MickeyKay/better-font-awesome

Repository files navigation

Build Status Downloads License: GPL v3

Better Font Awesome

Contributors: mcguive7, aaronbmm, mightyminnow
Tags: better, font, awesome, icon, icons, bootstrap, fontstrap, cdn, shortcode
Donate link: https://mickeykay.me
Requires at least: 3.0
Tested up to: 6.1.1
Stable tag: 2.0.4
License: GPLv2+
License URI: http://www.gnu.org/licenses/gpl-2.0.html

The Better Font Awesome plugin for WordPress. Shortcodes, HTML, TinyMCE, various Font Awesome versions, backwards compatibility, CDN speeds, and more.

Description

Build Status

Do you find this plugin helpful? Please consider leaving a 5-star review.

Better Font Awesome allows you to automatically integrate the latest available version of Font Awesome into your WordPress project, along with accompanying CSS, shortcodes, and TinyMCE icon shortcode generator.

Features

  • Always up-to-date - automatically fetches the most recent available version of Font Awesome, meaning you no longer need to manually update the version included in your theme/plugin.

  • Backwards compatible - shortcode output is automatically updated depending on which version of Font Awesome you choose, meaning that you can switch versions without having to modify your shortcodes.

  • Compatible with other plugins - designed to work with shortcodes generated with plugins like Font Awesome Icons, Font Awesome More Icons, and Font Awesome Shortcodes, so you can switch to Better Font Awesome and your existing shortcodes will still work.

  • CDN speeds - Font Awesome CSS is pulled from the super-fast and reliable jsDelivr CDN.

  • Shortcode generator - includes an easy-to-use TinyMCE dropdown shortcode generator.

Settings

All settings can be adjusted via Settings → Better Font Awesome.

Usage

Better Font Awesome can be used in 3 different ways: shortcode, HTML, and TinyMCE

1. Shortcode

[icon name="flag" class="2x spin border" unprefixed_class="my-custom-class"] Note that prefixes (fa- and icon-) are not required, but if you do include them things will still work just fine! Better Font Awesome is smart enough to know what version of Font Awesome you're using and correct of the appropriate prefix.

That means that all of the following shortcodes will work, regardless of what version of Font Awesome you choose: [icon name="flag" class="2x spin border"] [icon name="icon-flag" class="icon-2x icon-spin icon-border"] [icon name="fa-flag" class="fa-2x fa-spin fa-border"] [icon name="icon-flag" class="fa-2x spin icon-border"]

You can read more about shortcode usage on Github

2. TinyMCE

Better Font Awesome also provides you with an easy-to-use drop down menu when editing in TinyMCE's visual mode. Check out our Screenshots to see what it looks like.

3. HTML

Note that prefixes are required for HTML usage, and are version-specific. For this reason, shortcode usage is encouraged over HTML. If you do want to use HTML, however, you can read more on the Font Awesome site.

Advanced / Integration

Better Font Awesome is built around the Better Font Awesome Library. This library allows you to integrate Better Font Awesome into any custom project you want to create (perhaps a theme or plugin with a constantly up-to-date icon list), and includes all the filters you might need.

Languages / Translations

Credits

Many thanks to the following plugins and their authors:

And many thanks to the following folks who helped with testing and QA:

Installation

This section describes how to install the plugin and get it working.

  1. Upload Better Font Awesome to the /wp-content/plugins/ directory.
  2. Activate the plugin through the 'Plugins' menu in WordPress.
  3. That's it! Now you can use 3 different methods (shortcode, HTML, TinyMCE) to insert Font Awesome icons, all outlined in the Description section.

Frequently Asked Questions

How is this plugin different from other Font Awesome plugins?

This plugin is unique in that it automatically pulls in all available versions of Font Awesome, meaning you never have to wait for the plugin developer to add the latest version. Furthermore, Better Font Awesome is designed to work with a wide variety of shortcode formats used by other Font Awesome plugins - this means that you can easily switch to Better Font Awesome (if, for example, you need to include icons from the most recent version of Font Awesome, which isn't always available with other plugins), and they will still work.

Do I have to install any font files?

Nope. Better Font Awesome automatically pulls in everything you need, and it does it from the lightning-fast jsDelivr CDN.

What happens if I have another plugin/theme that uses Font Awesome?

Better Font Awesome does it's best to load after any existing Font Awesome CSS, which can minimize conflicts. If you are experiencing any unexpected behavior resulting from plugin/theme conflicts, you can try checking the box to "Remove existing Font Awesome styles" in under Settings → Better Font Awesome.

Screenshots

  1. The icon shortcode dropdown selector
  2. Better Font Awesome settings, accessed via Settings → Better Font Awesome

Changelog

2.0.4

  • Bump BFAL to properly esc attributes
  • Add unit tests

2.0.3

  • Bugfix: fix broken icon text selection
  • Improve admin settings success/error message logic

2.0.2

  • Bugfix: fix CSRF vulnerability

2.0.1

  • Bugfix: add necessary @font-face mappings to ensure site-specific CSS and pseudo-elements render correctly

2.0.0

  • Add support for Font Awesome v5
  • Integration with Font Awesome GraphQL API for all data fetching (improve performance)
  • Integrate with Font Awesome CDN for all CSS
  • Add option to include the v4 Font Awesome CSS shim to support older icons (default on for upgrades)
  • Updatee hard-coded fallback Font Awesome version
  • Modify version check frequency to a saner 24 hour interval
  • Ensure admin notices are dismissible
  • Lower data fetch timeout to mitigate performance risks
  • Remove legacy options that are no longer relevant (version select, minification opt-out)
  • Add more/better unit tests to ensure things are working as expected

1.7.6

  • Fix: revert to 1.7.4 codebase.
  • Fix: remove calls to ready() jQuery method to support latest jQuery versions.

1.7.5

(BAD BUILD)

  • Fix: remove calls to ready() jQuery method to support latest jQuery versions.
  • Fix: update fontawesome-iconpicker dependency to repair broken icon select functionality.

1.7.4

  • Fix: revert accidental bump to underlying Better Font Awesome Library dependency.

1.7.3

  • Add admin notice to invite beta testers.

1.7.2

  • Bump "tested up to" value to 5.5.

1.7.1

  • Fix functionality to hide/show admin notices.

1.7.0

  • Update fallback Font Awesome to v4.7.0.
  • Switch from using git submodules to composer dependency management for core library inclusion.

Upgrade Notice

2.0.4

  • Bump BFAL to properly esc attributes
  • Add unit tests

2.0.3

  • Bugfix: fix broken icon text selection
  • Improve admin settings success/error message logic

2.0.2

  • Bugfix: fix CSRF vulnerability

2.0.1

  • Bugfix: add necessary @font-face mappings to ensure site-specific CSS and pseudo-elements render correctly

2.0.0

  • Add support for Font Awesome v5
  • Integration with Font Awesome GraphQL API for all data fetching (improve performance)
  • Integrate with Font Awesome CDN for all CSS
  • Add option to include the v4 Font Awesome CSS shim to support older icons (default on for upgrades)
  • Updatee hard-coded fallback Font Awesome version
  • Modify version check frequency to a saner 24 hour interval
  • Ensure admin notices are dismissible
  • Lower data fetch timeout to mitigate performance risks
  • Remove legacy options that are no longer relevant (version select, minification opt-out)
  • Add more/better unit tests to ensure things are working as expected

1.7.6

  • Fix: revert to 1.7.4 codebase.
  • Fix: remove calls to ready() jQuery method to support latest jQuery versions.

1.7.5

(BAD BUILD)

  • Fix: remove calls to ready() jQuery method to support latest jQuery versions.
  • Fix: update fontawesome-iconpicker dependency to repair broken icon select functionality.

1.7.4

  • Fix: revert accidental bump to underlying Better Font Awesome Library dependency.

1.7.3

  • Add admin notice to invite beta testers.

1.7.2

  • Bump "tested up to" value to 5.5.

1.7.1

  • Fix functionality to hide/show admin notices.

1.7.0

  • Update fallback Font Awesome to v4.7.0.
  • Switch from using git submodules to composer dependency management for core library inclusion.

About

[WordPress] A WordPress plugin that allows you to easily integrate the latest version of FontAwesome.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •