=== Font Awesome === Contributors: fontawesome, mlwilkerson, robmadole, frrrances, deathnfudge Stable tag: 4.5.0 Tags: font, awesome, fontawesome, font-awesome, icon, svg, webfont Requires at least: 4.7 Tested up to: 6.6 Requires PHP: 5.6 License: GPLv2 or later License URI: https://www.gnu.org/licenses/gpl-2.0.html The official way to use Font Awesome Free or Pro icons on your site, brought to you by the Font Awesome team. == Description == The official way to use Font Awesome Free or Pro icons on your site, brought to you by the Font Awesome team. = Features = Our official plugin lets you use Font Awesome the way you want: * Use Pro or Free icons. * Leverage the latest release or a specific version of our icons. * Choose the tech, either SVG or Web Font. * Take your pick of loading your icons from our classic Font Awesome CDN, or use Font Awesome Kits - the easiest and most efficient way to use Font Awesome icons on the web. * Turn on automatic compatibility for Font Awesome Version 4 if you - or your plugins - are still using Version 4 syntax. * Troubleshoot and resolve issues when multiple versions of Font Awesome are loading on your site from other plugins/themes, which can cause unexpected icon display or technical issues. * Make things even awesomer using icons from Font Awesome Version 6. * Use your uploaded icons from your Pro Kits. == How to Use == **Install and enable the plugin** (See the Installation tab for details) **Add icons to your pages and posts** Adding icons works in both the block editor and the classic editor. Once you’ve set up your plugin, you can search and add icons to your pages and posts by choosing the Font Awesome option in the format bar from any text block to open the Icon Chooser. (If you want to search and add Pro icons in the Icon Chooser, you'll need to use a Pro Kit.) Or you can [use the icon names in shortcodes or HTML](https://fontawesome.com/icons?d=gallery). When you use shortcodes, you add the name of the icon and a prefix, where [the prefix is the style of icon](https://fontawesome.com/how-to-use/on-the-web/referencing-icons/basic-use) you want to use. Note that you don’t need to include the `fa-` part of the name. And if you don’t include any prefix, the icon will default to the Solid style. The shortcode for an icon looks like this: `[icon name="stroopwafel"]` `[icon name="stroopwafel" prefix="fal"]` Get the details on all the shortcode options in the [Font Awesome WordPress docs](https://fontawesome.com/how-to-use/on-the-web/using-with/wordpress#add-icons). You can also use basic HTML with [standard Font Awesome syntax](https://fontawesome.com/how-to-use/on-the-web/referencing-icons/basic-use), like this: `` **Using Pro Icons and Features** To use a Kit, create a [Kit on FontAwesome.com](https://fontawesome.com/kits) and select "Pro icons" in the settings. Then grab your [API Token from your Font Awesome account page](https://fontawesome.com/account#api-tokens) to add into the WordPress Kit settings. To add Pro icons with the CDN, you'll need to add your domain to the list allowed domains on your [Font Awesome account CDN Settings page](https://fontawesome.com/account/cdn) and use shortcodes or HTML to add the icons into your content. If you're using the Icon Chooser, you'll need to use a Pro Kit. (The CDN can only search and add Free icons - use shortcodes or HTML to add Pro icons when using the CDN). **Troubleshooting with the Plugin** Font Awesome icons are popular, so lots of themes and plugins also load Font Awesome, and sometimes their version can conflict with yours. So we created a way to help you find and prevent those conflicting versions from affecting your icons: **The Conflict Detection Scanner**. If the plugin seems to be set up correctly and your icons still aren’t loading and you're not sure why, head over to the Troubleshoot tab, which has two parts: * _Detect Conflicts with Other Versions of Font Awesome_ - which lets you start the conflict detection scanner to find versions of Font Awesome loading on your site. * _Versions of Font Awesome Active on Your Site_ - which shows the results of the scanner and lets you prevent any conflicting versions from loading other versions of Font Awesome on your site. Get more information about using the scanner for troubleshooting on the [Font Awesome WordPress docs](https://fontawesome.com/how-to-use/on-the-web/using-with/wordpress#troubleshooting). = Configuring = The plugin is set to serve Font Awesome Free icons as a Web Font via the Font Awesome CDN by default. You can change the CDN settings right in the plugin. If you want just the basic Free icons, you probably don't need to make any changes to the default configuration. You can get more information about all the available settings and troubleshooting on the [Font Awesome WordPress docs](https://fontawesome.com/how-to-use/on-the-web/using-with/wordpress). = Upgrading from the Old Versions = If you used the old plugin or are still using Version 3 of Font Awesome, we've tried to smooth the upgrade path for you by keeping `[icon]` shortcode compatibility for Font Awesome 3 names used with the old plugin. But we plan to remove version 3 naming support from this plugin soon so don't wait too long to update your code! == Screenshots == 1. Add icons in any text block from the editing bar 2. Search and add icons from Font Awesome Free or Pro (with subscription) 3. View the icons in Preview mode or in published pages and posts 4. Use a Font Awesome Kit to power your site's icons 5. Or use the Font Awesome CDN 6. Detect and fix issues with conflicting versions of Font Awesome running on your site 7. Add icons in Classic Editor as well == See Also == The [README](https://github.com/FortAwesome/wordpress-fontawesome/blob/master/README.md) on GitHub has details for WordPress site owners and developers. And there are [API docs](https://fortawesome.github.io/wordpress-fontawesome/) for developers. == Frequently Asked Questions == You can get more information about using the plugin, details for available settings, and answers to frequently asked questions on the [WordPress docs on Font Awesome](https://fontawesome.com/how-to-use/on-the-web/using-with/wordpress). == Upgrade Notice == = 4.3.0 = Introduces support for multisite. On multisite configurations, previous installations of this plugin must be cleaned up before attempting to upgrade to this version. See Changelog for details. = 4.0.1 = Fixes bugs in the editor integration with the new Icon Chooser, introduced in 4.0.0. Temporarily disables Icon Chooser integration from Classic Editor in WordPress 4. See Changelog. = 4.0 = The 4.0 official release from the Font Awesome team is a major upgrade from the previous 3.x plugin. Only one breaking change from previous release candidate: plugin no longer adds a filter to process shortcodes in widget text. Adds an Icon Chooser feature. See Changelog for details. = 4.0.0-rc22 = This update changes how plugin configuration and metadata are stored in the WordPress database. Automatically updates database entries upon first use. See Changelog. = 4.0.0-rc17 = Security update. All users of 4.0.0-rc15 or 4.0.0-rc16 should update immediately. See Changelog. = 4.0.0-rc15 = MAJOR UPDATE, some breaking changes for developers. Improves conflict detection, adds support for Kits and internationalization. See Changelog for important details. = 4.0.0-rc1 = New plugin, replacing the old one. Font Awesome 3 icon names are being phased out, with a gradual upgrade path. == Installation == = From the Plugins Directory in WordPress Admin = From the "Add Plugins" page in WordPress admin: 1. Search the plugins directory by `author: fontawesome` 2. Click "Install" on the Font Awesome plugin in the search results 3. Click "Activate" = Installing a Zip Archive = 1. Click Download on this plugin's directory entry to get the `.zip` file 2. On the "Add Plugins" page in WordPress admin, click "Upload Plugin" and choose that `.zip` file = Access Font Awesome Plugin Settings = Once you activate the Font Awesome plugin, you will see Font Awesome in the Settings menu in your WordPress admin area, or you can click "Settings" on the plugin listing on the Plugins page. The plugin is set to serve Font Awesome Free icons as a Web Font via the Font Awesome CDN by default. You can change the CDN settings right in the plugin. If you want just the basic Free icons, you probably don't need to make any changes to the default configuration. **Using Pro Icons and Features** To enable Pro icons with the CDN, you will need to add your domain to the list allowed domains on your [Font Awesome CDN Settings page](https://fontawesome.com/account/cdn). To configure a Kit, get your [API Token from your Font Awesome account page](https://fontawesome.com/account#api-tokens). You can get more information about all the available settings and troubleshooting on the [Font Awesome WordPress docs](https://fontawesome.com/how-to-use/on-the-web/using-with/wordpress). == Changelog == = 4.5.0 = * Update the Icon Chooser to support all available family styles for the active version of Font Awesome. The available family styles are dynamically loaded so that when new family styles are introduced in new versions of Font Awesome, they will be immediately available in the Icon Chooser. * Make the Icon Chooser available in the Full Site Editor. * Change the format of some network requests in order to accommodate common Web Application Firewall settings. This resolves a common cause of error messages, such as: "Something has gone horribly wrong" in the Icon Chooser, or "Couldn't save those changes" on the plugin's settings page. = 4.4.0 = * Update the Icon Chooser to fix the use of Sharp Solid in more recent versions of Font Awesome, and include Sharp Regular and Sharp Light. * Add the "defer" attribute to script tags when in "Use a Kit" mode. This was already the behavior under "Use CDN" mode. * Fix some deprecation notices for php 8.2. = 4.3.2 = * Security Fix: escape shortcode attribute values. = 4.3.1 = * Increase network request timeout to accommodate some slow-running Icon Chooser searches. We've recently added some new functionality to the Font Awesome API server. We're in the process of optimizing it for performance. In the meantime, some icon searches that return lots of search results are running slowly. Increasing the timeout allows those searches to run longer before considering it an error. = 4.3.0 = * Introduce support for Sharp Solid. The Icon Chooser now includes Sharp Solid among the available styles when using a Font Awesome Pro Kit. * Introduce support for WordPress multisite. Allows installing the plugin network-wide and configuring each site separately. Previous versions of this plugin were not compatible with multisite, though it was possible to install and get partial functionality on multisite. However, this could also result in a confusing database state. If you're running multisite, it's important that any installation of a previous plugin version is totally cleaned up before trying to install this version. Upgrading on multisite without cleaning up first will probably result in an error. A previous installation can usually be cleaned up by deactivating and uninstalling it. Uninstall must be done by clicking "Delete" on the deactivated plugin's entry in the plugin list in the admin dashboard. It may also work to install the previous 4.2.0 version and then uninstall it, just to get its cleanup code to run. This has no impact on sites that are not running in multisite mode. If you're not running multisite, upgrading to this version should be smooth and problem-free. = 4.2.0 = * Make Font Awesome 6 the default version on new activations. * On the version selection dropdown, distinguish between the latest 5.x and the latest 6.x. * Maintenance updates to JavaScript dependencies. * Developers: the latest_version() method has been deprecated and replaced by two alternatives: latest_version_5() and latest_version_6(). = 4.1.1 = * Simplified upgrade logic: makes the upgrade process on the first page load after upgrade quicker and smoother. = 4.1.0 = * Added support for using Font Awesome Version 6 Free with CDN. In order to use Version 6 Pro with this plugin, it's still necessary to use a Kit, since Version 6 Pro is not available on the classic CDN. * Renamed the "Version 4 Compatibility" option as "Older Version Compatibility", since compatibility features may now involve both Version 4 and Version 5. * Updated version of the conflict detection script used when configured for CDN. * FIX: in some cases, when running the conflict detector on the back end, there was an error about an undefined variable called $should_enable_icon_chooser. Fixed. * FIX: in some cases, when running php 8.0 or higher, there was an error related to calling method_exists(). Fixed. * **Developers:** The v4_compatibility() method has been deprecated and will be removed in a future release. It's now just compatibility(). * **Developers:** The preference named "v4Compat" in the array argument to the register() method has been deprecated and renamed "compat". Any uses of "v4Compat" are automatically translated to "compat". * **Developers:** There are no breaking changes. Any code that uses the above deprecated features will continue to work the same without modification in this release. = 4.0.4 = * FIX: add hash values to JavaScript chunk file names to resolve the problem where sometimes an old cached version of a JavaScript file would load in the browser instead of the intended updated one. This caused some users to see a blank settings page after upgrading from a previous version of the plugin. = 4.0.3 = * FIX: When in the Classic Editor in WordPress 5, do not load block editor script dependencies that assign to the global wp.editor object. This prevents problems with other plugins on the page that may depend on that global. * FIX: When in the Classic Editor where multiple editor instances are present, ensure that the Add Font Awesome media button on each is wired up to load the Icon Chooser on click, not just those buttons that were on the page at the time this plugin's initialization code is run. = 4.0.2 = * FIX: re-enable the Icon Chooser in the Classic Editor on WordPress 4. * FIX: in some cases where the path to the plugin was a non-standard location--such as when installed via composer--the admin settings page and Icon Chooser would not load correctly. Fixed. * FIX: the global version of the lodash JavaScript library was again being overwritten by the version used by this plugin. Fixed. * The Icon Chooser's integration with the Block Editor (Gutenberg) has been disabled for Wordpress 5.0, 5.1, 5.2, and 5.3, due to incomptabile JavaScript libraries. All other features of the plugin work normally on those versions, including Icon Chooser integration with the Classic Editor. = 4.0.1 = * FIX: In scenarios where both Gutenberg (Block) and TinyMCE (Classic) editors were being loaded onto the same page, the Gutenberg editor was not displaying properly. Now, in that multi-editor situation, the Icon Chooser integration is only enabled for the block editor. In those cases, you can still use icon shortcodes or HTML in the TinyMCE editor boxes; those editors just won't have the "Add Font Awesome" media button for opening the Icon Chooser. The Icon Chooser is still available from the Classic Editor when the block editor is not present on the page. * FIX: In scenarios where there are multiple TinyMCE editor instances on the same page, such as WooCommerce product editing pages, only the "Add Font Awesome" media button on the first of those editors was working correctly. Now all of them work correctly. * FIX: In the Classic Editor, when other themes or plugins added media buttons after the "Add Font Awesome" button, those buttons were showing up as combined together and not working properly. Now they're separated and working great. * The Icon Chooser integration for the Classic Editor in WordPress 4 has been temporarily disabled. Everything else works as before in WP4, just not the new Icon Chooser. = 4.0.0 = * OFFICIAL 4.0.0 STABLE RELEASE * FEATURES: Includes all the features from the early 4.0.0 release candidates (details below) * FEATURE: Visual icon chooser lets you search and easily insert the correct shortcode. * Fixed regression on overriding global lodash version. * Added PHP API method to get current Kit token. * Removed the filter to process all shortcodes in widget text. This seems to have been an overly eager approach on our part. If you want shortcodes to be processed in widget text - all shortcodes, not just this plugin's icon shortcode - you can add a line like this to your theme's functions.php file: ``` add_filter( 'widget_text', 'do_shortcode' ); ``` = 4.0.0-rc23 = * FIX: plugin now handles Kits with version "5.x" or "6.x" * FEATURE: shortcode supports attributes: style, role, title, aria-hidden, aria-label, aria-labelledby = 4.0.0-rc22 = * Metadata about available Font Awesome releases is now stored as a normal option in the WordPress database, instead of as a transient. Thus, it does not expire and does not disappear if the transient cache is purged. This is in part to avoid the scenario where a request to the Font Awesome API server may be required to refresh metadata in response to a front end page load when that transient expires. Some site owners had occassionally experienced problems where a sudden burst of requests to the API server from many WordPress sites caused this plugin to fail when making a request with an error like 'An unexpected response was received from the Font Awesome API server.' This change means that it is significantly less likely that such a scenario will occur. (Additionally, changes have been made on the API server, also making it significantly less likely that this over-load failure will occur again.) * Developers: the refresh_releases() API method has been deprecated to discourage unnecessary blocking network requests to the API server. = 4.0.0-rc21 = * optimize normal page loads by loading much less metadata from the database (GitHub #96) * move the Font Awesome settings link from the main admin nav menu back down under Settings, where it used to be * update the version of the conflict detection script to one that also detects conflicting Kits * minor maintenance changes to keep JavaScript dependencies up to date * fix a bug involving the pseudo-elements setting when moving back and forth between using a Kit and using CDN (GitHub #82) = 4.0.0-rc20 = * developer-oriented update to support building themes that use this code as a composer package = 4.0.0-rc19 = * another minor update with additional error logging = 4.0.0-rc18 = * minor update with additional error logging = 4.0.0-rc17 = **SECURITY:** fixes a vulnerability in how API tokens were being stored, when configured to use a Kit. All users of 4.0.0-rc15 or 4.0.0-rc16 should update immediately. Find more details and instructions for updating your API Token on the [Font Awesome blog](https://blog.fontawesome.com/font-awesome-wordpress-plugin-api-token-vulnerability-fixed). * a minor bug in how network errors are handled = 4.0.0-rc16 = * Fixes to the upgrade process = 4.0.0-rc15 = **MAJOR UPDATE**, some breaking changes for developers. Improves conflict detection, adds support for Kits and internationalization. * Includes auto-upgrade logic so that most users can upgrade with no impact, except those that have "registered client" themes or plugins. Users who had previously enabled the "remove unregistered clients" option should verify that the auto-upgrade worked successfully - check that your icons are appearing correctly. If not, run the Conflict Scanner from the Troubleshoot tab. * New conflict detection and resolution: The new conflict detection scanner can be enabled to more precisely discover conflicting versions of Font Awesome and provides more granular conflict resolution. * Expanded error handling with detailed reports in the web console for more advanced diagnostics. * Adds support for Kits. * Adds comprehensive internationalization in both PHP and JavaScript. * New design of the admin UI. * **Developers:** Significant changes to the way the settings are handled internally: Font Awesome will always load in the way the WordPress admin chooses. Registered themes or plugins may register preferences (which are displayed to the admin), but the site admin will determine the configuration. * **Developers:** Registered client plugins and themes need to be updated before they will work as expected. * **Developers:** The PHP API contains significant changes. See the GitHub [README](https://github.com/FortAwesome/wordpress-fontawesome/blob/master/README.md) for an overview and the [PHP API docs](https://fortawesome.github.io/wordpress-fontawesome/) for details. _This release is intended as a final API-changing release before stabilizing the API at 4.0.0. Once 4.0.0 is released, it will follow semantic versioning best practices._ = 4.0.0-rc13 = * Improve diagnostic output for unhandled errors. = 4.0.0-rc12 = * Bug fix: Fix loading of admin page assets when removal of unregistered clients is enabled. This bug has been hiding under a rock for a while. rc11 turned over the rock, and this bug scurried out. = 4.0.0-rc11 = * Bug fix: enqueue Font Awesome assets in admin and login areas, not just in the front end = 4.0.0-rc10 = * Attempt to fix a problem where the admin settings is sometimes being confused by unexpected output from the WordPress server. This condition has been reported when certain other plugins are active, and (possibly) when PHP output buffering works differently than this plugin expects. = 4.0.0-rc9 = * Enhance Font Awesome version 4 compatibility: add shimming of the version 4 font-family to enable version 4 icons defined as pseudo-elements to be rendered via the version of Font Awesome 5 loaded by this plugin. * Add warnings to the admin UI to indicate that using svg and pseudo-elements may result in slow performance, and that svg with pseudo-elements and version 4 compatibility is not supported at all. = 4.0.0-rc8 = * Remove dependence on third party libraries, eliminating a class of potential conflicts with other plugins. * Breaking changes to the API used by theme and plugin developers (no breaking changes for WordPress site owners). See [commit log](https://github.com/FortAwesome/wordpress-fontawesome/commit/80f973b4a0f6ac09cbb4dc3ecc1ae2964ef01d32) = 4.0.0-rc7 = * Fix detection and removal of unregistered clients by changing the internal resource name this plugin uses to enqueue its resource. Change it to something unlikely to be used by other themes or plugins. = 4.0.0-rc6 = * Fix error when updating options on admin page: handle null releaseProviderStatus in cases where the release provider does not have to make a network request to update release metadata. = 4.0.0-rc5 = * Remove tilde character from JavaScript filenames to avoid violating some URL security rules = 4.0.0-rc4 = * Cache releases data in the WordPress database to reduce the number of server-side network requests. * Ensure that releases data are always loaded fresh from fontawesome.com when loading the admin settings page so site owners can see when new versions are available. * Add more specific error message on admin dashboard in the event that the WordPress server is not able to reach fontawesome.com in order to get an initial set of available releases data. = 4.0.0-rc3 = * Add missing v3 shim file = 4.0.0-rc2 = * Fix handling of v3 deprecation warnings in admin settings page = 4.0.0-rc1 = * Add admin settings page * Lots of back end code changes to support theme and plugin developers * Package plugin as a composer dependency * API Changes * Comprehensive API documentation for developers * Cache load specification unless client requirements change * Handle changing configurations as new plugins or themes are activated, de-activated or updated * Lock working load specifications and only rebuild when new requirements are conflict-free * Load Font Awesome release version metadata from the fontawesome.com releases API = 3.2.1 = * Last stable version of the old plugin