Icons font generator

Created on 29 March 2023, almost 2 years ago
Updated 25 September 2023, over 1 year ago

Problem/Motivation

We need icons font generator. Specification:

- Support font icons generator with current drush theme generator. The generator will copy all files to child theme that needs to support child theme font generation - all icons, all build files, etc. If some of the files exist on the target (SVG icons) they will not be overridden.
- Add npm command for font generation.
- Reuse/clone process for bootstrap font icon generation. Use https://github.com/twbs/fantasticon which is a fork of https://github.com/tancredi/fantasticon project.
- Each theme will get a new images/font-icons folder where it can put SVG icons for font generation.
- Add a library that loads font icons and related CSS code.

Feature request
Status

Fixed

Version

1.0

Component

BS Bootstrap

Created by

🇷🇸Serbia pivica

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

  • Issue created by @pivica
  • 🇷🇸Serbia pivica

    Here is a first patch, quite a complex thing to implement in order to ensure child themes updating workflow and respecting old child themes that will not want to switch to new icons.

    Now lets do some testing.

    @TODO - we need to write documentations for this before closing this issue!

  • Status changed to Needs review almost 2 years ago
  • 🇷🇸Serbia pivica

    Some minor refactoring.

  • 🇷🇸Serbia pivica

    I am having a trouble applying previous patch with composer because of binary icons.woff2 file which I used --binary flag. Not sure why, and no time to investigate, here is a patch without icons.woff2 - remember to generate it before committing this.

  • 🇷🇸Serbia pivica

    One problem I just figured out is that fantasticon is not centering icons vertically inside of the font, more about this in this issue . We need to take this into consideration when generating our fonts. It seems that descent option with value 55 is giving us a good result for icons from free Fontawesome 6 set. Adding this and code comments that explains this,

  • 🇷🇸Serbia pivica

    Figured out we need to add arrow-up and close icons which we use in bs_bootstrap theme.

  • 🇷🇸Serbia pivica

    Removed extra space.

  • Status changed to Needs work over 1 year ago
  • 🇸🇮Slovenia primsi

    Reviewed just a few initial files.

    1. +++ b/bs_base.drush.inc
      @@ -238,7 +238,7 @@ function drush_bs_base_bs_theme_update($target_machine_name) {
      +  drush_log("Building assets for a $theme_machine_name theme", LogLevel::INFO);
      

      Not sure if drush_log is still supported.

    2. +++ b/bs_base.drush.inc
      @@ -414,6 +463,62 @@ function _bs_base_copy_file($file, array $options) {
      +  if (!is_dir($destination)) {
      

      We could use the FileSystem helper here and below that provides tools to work with the file system. FileSystem::prepareDirectory for example checks this and creates if it doesn't exist.

    3. +++ b/bs_base.drush.inc
      @@ -414,6 +463,62 @@ function _bs_base_copy_file($file, array $options) {
      +    // Skip special files "." and ".."
      

      Do we need to skip hidden files as well? Might be good for some OS-es.

  • 🇷🇸Serbia pivica

    Updated patch against latest beta5.

  • Status changed to Needs review over 1 year ago
  • 🇷🇸Serbia pivica

    > Not sure if drush_log is still supported.

    Yep that should be fixed. I also figured that we need to fix drush_print which is also depreciated. I also did a bunch of small php code optimization that phpstorm suggested. This changes could go to different issue, but I am lazy to create a new one, let's keep it here for now.

    We also need to change drush_confirm and drush_user_abort which we use in _bs_base_theme_run_update_hooks(). But we can't do this for now, first we need to move all this code to bs_lib/src/Commands/BsLibCommands.php and then we can replace this calls with $this->io()->confirm() and UserAbortException() as shown in https://github.com/drush-ops/drush/commit/277ccb6d19ed6d85f372780cff4ea1.... We have #3107100: Move all related generator code to bs_lib from bs_base for this and it seems now it is a time to do it finally.

    > We could use the FileSystem helper here and below that provides tools to work with the file system. FileSystem::prepareDirectory for example checks this and creates if it doesn't exist.

    I am not sure are we allowed to use Drupal::service('file_system') call here because we need this code to work also without Drupal instance. Will check with @Berdir.

    > Do we need to skip hidden files as well? Might be good for some OS-es.

    No idea for now.

  • 🇷🇸Serbia pivica

    > I am not sure are we allowed to use Drupal::service('file_system') call here because we need this code to work also without Drupal instance. Will check with @Berdir.

    Checked this, I think we could use Drupal::service('file_system') however current logic is not that simple and replacing all this calls with Drupal file_system would require a bit of not that trivial work and testing then that everything works as expected. I do not have enough time to do this now, created a follow-up for this in 📌 Consider using Drupal file_system API instead of PHP file calls Active for the future when/if makes sense.

  • 🇷🇸Serbia pivica

    After a ton of testing, code checking, bug fixing... finally a new patch version with next changes:

    - Fixed problem with compiling unicode hex values with SASS.
    - Updated SVG icons for Font Awsome 6.4.2
    - Added $bs-icon-shims SASS variable for shim CSS rules generation.
    - Improved font hash busting URL generation in SASS.
    - Updated fantasticon package to 2.7.1
    - Update function will add variables/icons import to theme SASS init.
    - Generator will add variables/icons import to theme SASS init.
    - Removed automatic font icons preloading, better to leave that to child theme.
    - New fonts are disabled by default in theme settings.

    Do not forget to generate fonts/icons.woff2 when committing this.

  • 🇷🇸Serbia pivica

    I think there is no need for `fa-ext` shim, recompiled CSS.

  • 🇷🇸Serbia pivica

    @Berdir suggested to improve text in theme setting admin UI for this new option.

  • 🇷🇸Serbia pivica

    Discussed with @Berdir and he suggested that having two options (on SASS level and Drupal theme settings level) is too much and that it would be better to have only one option that we should change for projects that wants to use new icons system. We figured out next changes:

    1. We will leave $bs-icon-use SASS variable and if it is set to false then icons.css should be empty. Meaning there is no library any more, we always load this for a theme.
    It is fine then to use the same SASS variable to decide to override fa-icon() or not so we are compatible with old projects.

    2. And for the Drupal PHP part, we will remove bs_bootstrap.use_icons.
    NOTE that bs_bootstrap it self is not loading FA4 resource. If your custom themes are loading FA4 you will need to figure a way to detect if `$bs-icon-use` is set to true in SASS and then do not load old FA4 resource. In Primer we solved this by checking `theme-options.yml` for a presence of `bs-icon-use: true` string.

    Here is a new patch.

  • 🇷🇸Serbia pivica

    Minor improvement, added new helper function bs-icon-content(), using generator in client project suggest that this is a good idea.

    • pivica committed a40ffb8b on 8.x-1.x
      Issue #3351106 by pivica, Primsi: Icons font generator
      
  • Status changed to Fixed over 1 year ago
  • 🇷🇸Serbia pivica

    Committed.

  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024