o-icons
Helper Sass for the fticons image set.
Complete list of available icons
Though you can use these icons at any size, they render best at 40px.
Usage
Markup
<link rel="stylesheet" href="//origami-build.ft.com/v2/bundles/css?modules=o-icons@^5.0.0" />
<span class="o-icons-icon o-icons-icon--arrow-down"></span>
Sass
There are a few ways to use o-icons to get fticons:
- Using the CSS helper classes
- Using the Sass mixins with your own CSS
You can also request the icon directly from the Image Service (without using o-icons at all). See the fticons for how to do this.
Using the CSS helper classes
$o-icons-is-silent: false;
@import "o-icons/main";
<span class="o-icons-icon o-icons-icon--plus"></span>
When using CSS classes, it isn't possible to set a colour for the icon or to specify a size for the PNG fallback. The defaults are 'black' for the icon colour and '128px' for the width and height.
Using the Sass mixins with your own CSS
This option has the added flexibility of supporting coloured icons and PNG fallbacks of any size.
@import "o-icons/main";
@import "o-colors/main";
.icon-plus {
@include oIconsGetIcon('plus', oColorsGetPaletteColor('cold-1'), 32);
}
<span class="icon-plus"></span>
The Responsive Image Service helps serving resolution-independent SVG icons.
The 'base' of the service url can be set with the $o-icons-service-base-url
variable. e.g. setting
$o-icons-service-base-url: "https://my.image.service/foo";
will output an image service url in the format https://my.image.service/foo/v2/images/raw/...
.
The 'version' of the service url can be set with the $o-icons-service-version
variable. e.g. setting
$o-icons-service-version: "v1";
will output an image service url in the format https://my.image.service/foo/v1/images/raw/...
.
There's also a separate mixin to output just the base styles for an icon:
.icon {
@include oIconsBaseStyles;
}
Which outputs:
.icon {
display: inline-block;
width: 128px;
height: 128px;
background-repeat: no-repeat;
background-size: contain;
background-position: 50%;
background-color: transparent;
vertical-align: middle;
}
Contributing
o-icons
is some Sass mixins and helpers for using the fticons image set. To add a new icon you need to add it to the fticons set. There are instructions in the fticons README.
Migration guide
How to upgrade from v4.x.x to v5.x.x?
The jump from 4 to 5 introduces an entirely new set of icons. Using these icons should be a lot easier as they have a uniform amount of white-space around them, so you don't need to individually size icons to work in your application harmoniously.
That said, because the icons have all changed, you will need to adjust the sizing and alignment of them in your application as things that aligned before may be out of whack now.
Deprecated icons
The new icon set has deprecated some icons, added some, and renamed some others. For a full list of these icons please see the fticon README.
Logos and Mastheads
The logos and masthead that were deprecated in version 4 have now moved completely. Please use the Logo Images set via the image service for these.
How to upgrade from v3.x.x to v4.x.x?
Important changes
o-ft-icons
has been renamed to o-icons
- Icon font has been removed, now it's SVGs all the way. This changes the behaviour for silent mode turned off users which includes Build Service users
- Some icons have been removed, and as mentioned above, others have been deprecated. The list of deleted icons is:
- brand-always-learning
- brand-fast-ft
- brand-fast
- brand-myft
- brand-pearson
- eye
- font-size
- gift
- section-columnists
- section-house-and-home
- section-leader-and-letters
- section-lex
- section-markets-data
- section-money
- section-uk
Markup changes
CSS now doesn't add any pseudoclasses, so all the styling is applied directly on the element
CSS Changes
-
Class prefixes need to be renamed from o-ft-icons
to o-icons
e.g.
o-ft-icons-icon
to o-icons-icon
o-ft-icons-icon--arrow-down
to o-icons-icon--arrow-down
-
As it's an SVG instead of a font, size is now set using the CSS properties width
and height
Sass Changes
- All icon font related mixins have been removed
oFtIconsBaseIconStyles
has been renamed to oIconsBaseStyles
oFtIconsGetSvg
has been renamed to oIconsGetIcon
Silent mode off Changes
When using the Build Service, you're using this module with silent mode turned off. Due to the removal of the icon font, there are a couple things to keep in mind in the new implementation:
- There is a PNG fallback, and when using the default CSS classes, the size of the image served is 128px so it can be resized down, but not up
- The colour of the icon served is black. This cannot be changed. If you need a custom colour (or even a custom size), option 3 of the suggested ways of using this module is the way to go
Contact
If you have any questions or comments about this component, or need help using it, please either raise an issue, visit #ft-origami or email Origami Support.
Licence
This software is published by the Financial Times under the MIT licence.