buckleshusky / fontawesomeiconpicker
Adds a Font Awesome 6.x icon picker for SilverStripe.
Installs: 9 783
Dependents: 6
Suggesters: 0
Security: 0
Stars: 7
Watchers: 2
Forks: 5
Open Issues: 7
Language:JavaScript
Type:silverstripe-vendormodule
Requires
- silverstripe/framework: ~4.3|~5.0
- silverstripe/vendor-plugin: ^1.0|^2.0
- dev-master
- 3.2.0
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.7
- 3.0.6
- 3.0.5
- 3.0.4
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 2.1.1
- 2.0.1
- 2.0.0
- 1.1.1
- 1.1.0
- 1.0.0
- dev-feature-20240814
- dev-feature-improvements
- dev-dependabot/npm_and_yarn/json5-1.0.2
- dev-dependabot/npm_and_yarn/decode-uri-component-0.2.2
- dev-dependabot/npm_and_yarn/loader-utils-and-resolve-url-loader-1.4.2
This package is auto-updated.
Last update: 2024-10-15 20:03:02 UTC
README
Adds a Font Awesome 6.x icon picker to SilverStripe 4. This uses the CDN for Fontawesome 6.2.0. This will work with Fontawesome 6.2.0 pro out-of-the-box (but you will need to have a copy of the kit).
With the Free version of Font Awesome
Starts out slim: Expands to allow you to seach for your desired icon: A list of your recently toggled icons:
With the Pro version of Font Awesome
Everything that you can do in the free version, you can do in the pro version. The pro version however comes with more options.
When enabled, Light and Duotone icon styles are unlocked:
Sharp icons, by default, are enabled when you switch to pro:
Requirements
- SilverStripe 4.x or 5.x
Installation
Installation is supported via composer only
composer require buckleshusky/fontawesomeiconpicker
- Run
dev/build?flush=all
to regenerate the manifest
Usage
Simply add the field to a DataObject or Page like you normally would. This will save the Font Awesome Icon's class info to a dbfield for use on the front end.
use BucklesHusky\FontAwesomeIconPicker\Forms\FAPickerField; use SilverStripe\ORM\DataObject; class TestDataObject extends DataObject { private static $table_name = "TestDataObject"; private static $db = [ 'FAIcon' => 'Varchar(255)', ]; public function getCMSFields() { $fields = parent::getCMSFields(); $fields->addFieldToTab( 'Root.Main', FAPickerField::create('FAIcon', 'Font Awesome Icon\'s Name') ); return $fields; } }
If needed, you can add the following to your PageController
or any page controller that extends PageController
. This can be added to the init()
method like below:
protected function init() { parent::init(); // get the requirements to render fontawesome icons $this->fontAwesome(); }
Notes
The field has not been tested for use on the frontend of a site.
Settings
Enable Font Awesome Pro
To enable Font Awesome Pro, add this to your yml file.
Replace all.min.css
and sharp-solid.min.css
with the Font Awesome Pro css name.
These files should be located in your theme's css folder.
# settings for FontawesomeIcons FontawesomeIcons: # unlocks pro mode - onkly use this if you are using Font Awesome pro unlock_pro_mode: true # the location of the icon-families.yml from fontawesome icon_yml_location: 'app/fontawesome/icon-families.yml' #the pro css for fonts pro_css: 'all.min.css' # only use one of the following to get your sharp css pro_sharp_css: 'webfonts/fontawesome/css/sharp-solid.min.css' # not needed if sharp is disabled # the folder where all the sharp-*.css are located pro_sharp_css_folder: 'webfonts/fontawesome/css/' # not needed if sharp is disabled # disable generating icons on dev build disable_generate_on_build: false # this is false by default
Options:
How to setup the PRO version of fontawesome?
- You will need to download a kit from the fontawesome site.
- Grab the css file for
all.min.css
andsharp-[x].min.css
(where x is the different variants of sharp) and place it in your theme's css folder. - Grab the
webfonts
folder and place it in your theme's folder. Examplethemes\simple
. - update your config:
FontawesomeIcons: unlock_pro_mode: true # the location of the icon-families.yml from fontawesome icon_yml_location: 'app/fontawesome/icon-families.yml' # the css of all and sharp-solid pro_css: 'webfonts/fontawesome/css/all.min.css' # not needed if sharp is disabled pro_sharp_css_folder: 'webfonts/fontawesome/css/'
- place the
icon-families.yml
yml file into your site's app folder. In this example, it would be placed inapp/fontawesome/icon-families.yml
. - do a
dev/build
, or, if you have it disabled, run the following tasksdev/tasks/generate-font-awesome
How do I use a newer version of Fontawesome?
- Get a copy of
icon-families.yml
.- You can obtain this from their github.
- for pro, you will get this file when you download pro from fontawesome
- Place this file into your site's app folder.
- Updated
icon_yml_location
to point to the yml's folder i.e.app/fontawesome/icon-families.yml
- For the FREE version you can optionally do the following:
- add the following to your yml with the desired version you would like from the CDN:
FontawesomeIcons: free_css_cdn_version: '6.3.0'
- For the PRO version:
- follow the steps above for How to setup the PRO version of fontawesome?
What's New
- switched to use FontawesomeIconsListCustom yml config to prevent duplicate icons
- clicking sharp now allows you to select type
- when you click a family, the type buttons are filtered down to only show you what's available
- added support for display logic
- added support for all sharp icons not just sharp solid
- pagination no longer remembers the page when choose a family/type
- when you expand the field, it will get the family and switch to the proper tab
- updated documentation
Future
- add back in removing icons
- removed for now to clean this up and get it released
- add documentation for adding your own icons
- dynamic generating of style types