The
Icon Service functions as a central definition and delivery method for all sorts of icons: image icons as well as font icons.
Different kinds of icons
Image icons are those that display a small icon using an image file. Each individual icon of that kind refers to exactly one file on the disk.
Font icons are bundled into a single web font file that holds all icons available via a this specific font. Web fonts are normally used to
change typographical aspects of the web with well known fonts such as Arial, Times New Roman and the like. Each glyph in a web font represents
one character of text. Icon fonts are a specific kind of web fonts where glyphs don't represent a character but an icon.
Image icons are very colorful most of the time, whereas font icons are always monochrome. The color of an image icons cannot be changed; the
color of a font icon can be adjusted by changing their text color. Icon fonts may be manipulated in many ways, most notably they can be scaled
to any size possible without losing their rendering quality. This is the main advantage over image icons that can only be delivered in a single
scale and a predefined coloring.
The
Icon Service is able to make both kinds of icons available to the system likewise as far as possible with regards to their different nature (see above).
All icons are addressible by their unique
identifier. All icons fall into at least one
category that describe their origin and nature.
Definition image icons
Image icons are defined by being available on an "icon search path". This is a list of locations (on disk), where image files are looked up for a specific identifier.
The icon search path is
configured by the
{JQueryPlugin}{IconSearchPath}
and
defaults to
Fam Fam Fam Silk Icons,
Fam Fam Fam Silk Companion 1 Icons,
Fam Fam Fam Flag Icons,
Fam Fam Fam Mini Icons,
Fam Fam Fam Mint Icons.
The named icon will be picked found first on this path of topics where icons are attached to.
Definition of font icons
Font icons are defined by the
{JQueryPlugin}{IconFonts}
setting. This is a list of icon font definitions, i.e. how they are named, and which css file
must be loaded into a web page to make them available. The default setting is:
$Foswiki::cfg{JQueryPlugin}{IconFonts} = {
'fontawesome' => {
'prefix' => 'fa',
'definition' => '$Foswiki::cfg{PubDir}/$Foswiki::cfg{SystemWebName}/JQueryPlugin/plugins/fontawesome/fontawesome.json',
'plugin' => 'fontawesome',
},
'material' => {
'prefix' => 'ma',
'definition' => '$Foswiki::cfg{PubDir}/$Foswiki::cfg{SystemWebName}/WebFontsContrib/material-icons/material.json',
'css' => '$Foswiki::cfg{PubUrlPath}/$Foswiki::cfg{SystemWebName}/WebFontsContrib/material-icons/font-face.css',
},
};
Note that Foswiki does only ship Fontawesome icons by default. Material icons are part of the
WebFontsContrib extension that you might want to install in addition.
Its definition section in the
{JQueryPlugin}{IconFonts}
setting is ignored in case of the definition file not being present.
Each entry is of the following format:
'<fontName>' => {
'prefix' => '<string>',
'definition' => '<definitionFile>',
'plugin' => '<jQueryModule>',
'css' => '<cssUrl>'
}
-
fontName
: unique identifier
-
definitionFile
: file path to a file holding a font definition (more about it below)
-
plugin
or css
: either an icon font is loaded by means of a jquery module being loaded; this module then holds any further means to load the required assets into a web page; or the css
url that is to be added to the page.
A
definitionFile
itself defines the individual icons themselves, i.e. it mapps icon identifier to the actual glyph in the icon font. The
definitionFille
lists all identifiers that might be used in a
Var JQICON macro:
%JQICON{"<prefix>-<identifier>"}%
The
<prefix>
part specifies which of the available icon fonts the
<identifier>
relates to. For instance
fa-pagelines
load the
fontawesome
jQuery module and then generate the according markup to display the icon.
Definition file for an icon font
A
definitionFile
refered to in an
fontName
entry of the
{JQueryPlugin}{IconFonts}
setting lists all available icon identifiers. It may also list aliases and categories that icons belong to grouping them into meaningful partitions.
J Query Font Awesome comes with a certan set of categories such as:
- Accessibility Icons
- Brand Icons
- Chart Icons
- Currency Icons
- Directional Icons
- File Type Icons
- Form Control Icons
- Gender Icons
- Hand Icons
- Medical Icons
- Payment Icons
- Spinner Icons
- Text Editor Icons
- Transportation Icons
- Video Player Icons
- Web Application Icons
A definition file has got the format:
{
"icons": [
{
"id": "<string>",
"name": "<string>",
"unicode": "<codepoint>",
"categories": [
"<string>",
"<string>",
...
],
},
]
}
-
id
(mandatory) defines the icon id unique among all icons of this font
-
name
: icon name in human readable form, defaults to id
if not present
-
unicode
: codepoint as defined in the web font
-
categories
list of categories that the icon belongs to
Each icon in an icon font automatically is in the
fonticon
category as well as in the
fontName
category (e.g.
fonticon, fontawesome, Payment Icons
).
Each icon of an image icon automatically is added to the category naming the topic it is attached to, e.g.
FamFamFamSilkIcons
.