Oryx: Icon system
Edit on GitHubIcons provide clear visual cues, enhance user interactions, and save screen space. Oryx offers a sophisticated icon system that ensures a consistent design across all components of an application.
Icon component
Icons are rendered using IconComponent
, a design system component designed for this purpose. To display an icon, use the type
attribute to specify the icon’s name:
<oryx-icon type="rocket"></oryx-icon>
IconComponent
can render icons using either an icon font or SVG. When rendered as SVG, icons are displayed in a 24x24 pixels viewport.
Icon sizes
The icon system is standardized around the 24x24 pixels format. Icons can be scaled to fit alternative sizes with three pre-defined sizes available:
SIZE NAME | PIXELS |
---|---|
xs : extra small |
16x16 |
md : medium |
20x20 |
lg : large |
24x24 |
To maintain consistency, IconComponent
provides the --oryx-icon-size
CSS variable, which applies to both font-based and SVG-based icons. This feature enables you to control icon sizes throughout UI effortlessly, ensuring icons remain clear and sharp across different contexts and devices.
You can control the icon size through the size
attribute or by providing the CSS variable. If both the size attribute and the CSS variable are used, the CSS variable takes precedence.
<oryx-icon type="rocket" size="md"></oryx-icon>
<div style="--oryx-icon-size:40px">
<oryx-icon type="rocket"></oryx-icon>
</div>
Font-based icons versus SVG icons
Oryx supports both font-based icons and SVG icons, letting you choose the most suitable approach for each icon in your application.
Font-based icons
Font-based icons are a popular choice due to their ease of use and the availability of a wide range of icons. They offer great quality and scalability, staying sharp at various sizes. Additionally, font-based icons can be easily colored using CSS, seamlessly integrating with UI themes.
Oryx leverages Material symbols and Font Awesome icons. However, you can also add other icon fonts. Material Symbols are built with Variable fonts, enabling developers to edit font characteristics like line weight and fill through CSS.
When using font-based icons, make sure to consider the potential impact on performance. Since all icons in the font are loaded at once, it may affect the initial page loading time. Proper optimization strategies are essential to mitigate this issue.
SVG icons
SVG icons offer several advantages, including the ability to load icons individually or in sprite sheets, which optimizes HTTP requests and improves performance. Server-side rendering of SVG icons results in optimal output for performance, leading to faster loading times. Being vector-based, SVG icons maintain their quality and sharpness at various sizes, making them ideal for responsive designs. Like font-based icons, SVG icons can also be colored using CSS, enabling seamless integration with UI themes.
Compared to font-based icons, creating and maintaining SVG icons requires more intricate design work. Developers need to find balance between icon complexity and performance to ensure a smooth user experience.
Image icons
Oryx does not provide support for using images as icons. Images lack scalability and often become pixelated or blurry when resized, making them unsuitable for responsive design and different screen sizes. Moreover, images are fixed in size, limiting their versatility and adaptability to various UI elements. In contrast, the font-based and SVG icon techniques provide better performance and customization options, making them the preferred choice for icons.
Icon colors
In Oryx, icons are seamlessly integrated into the main Document Object Model (DOM), which means they can inherit colors from ancestor HTML elements. To customize an icon’s color, you can use standard CSS or leverage the color system. If no explicit color is provided, the icon inherits its color from the parent element.
Here’s an example of how to apply colors using standard CSS or the --oryx-icon-color
variable:
<oryx-icon type="rocket" style="color: red"></oryx-icon>
<div style="color: blue">
<oryx-icon type="rocket"></oryx-icon>
<div style="--oryx-icon-color: yellow">
<oryx-icon type="cart"></oryx-icon>
</div>
</div>
Variable font styles
When using Material Symbols, you can configure the adjustable variable font styles of the icons:
- fill
- weight
- grade
- optical size
Additionally, you can configure whether an icon contains a direction (see the section on directionality below).
Global configuration
You can provide the variable font styles globally using design tokens:
import { appBuilder } from "@spryker-oryx/application";
export const app = appBuilder().withTheme({
designTokens: [
{
icon: {
weight: "100",
fill: "1",
grade: "0",
optical: "48",
},
},
],
});
CSS properties
Alternatively, you can configure the variable font styles for parts of the DOM by creating CSS properties in the stylesheet. Custom CSS properties are inherited by all descendants, making it easy to configure variable fonts for a DOM tree with a single style rule:
<div style="--oryx-icon-fill: 1">
<oryx-icon type="rocket"></oryx-icon>
<div>
<oryx-icon type="search"></oryx-icon>
</div>
</div>
Individual icon styling
You can also style the variable font for an individual icon by specifying style rules for a single icon type:
import { appBuilder } from "@spryker-oryx/application";
import { materialDesignIcons } from "@spryker-oryx/resources";
export const app = appBuilder().withTheme({
icons: {
resource: materialDesignIcons,
resources: [
{
resource: {
id: materialDesignIcons.id,
styles: { fill: 1 },
},
types: ["person"],
},
],
},
});
Configure icons for right-to-left
Icon libraries are typically created for left-to-right (LTR), but when they’re used in right-to-left (RTL) some icons much flip to reflect the layout. This is affecting only icons that express a direction, such as arrow icons.
Oryx supports directionality and to ensure that some icons will flip accordingly, the icon style must be set with the direction: true
config. The following example shows how the forward icon is configured to flip in RTL mode.
export const materialDesignIcons: IconMapper = {
id: "material-icons",
mapping: {
[IconTypes.Forward]: {
text: "chevron_right",
styles: { direction: true },
},
},
};
Icon configuration
You can configure one or multiple icon resources per theme. An icon resource can contain a reference to a font or provide SVG-based icons.
Here’s an example of configuring a theme that uses materialDesignIcons
for all icons, except for the cart icon, which is configured with a specific mapping:
export const customTheme: Theme = {
icons: {
resource: materialDesignIcons,
resources: [
{
svg: true,
mapping: {
[IconTypes.Cart]: () => import("./icons/cart").then((s) => s.default),
},
},
],
},
};
You can use the theme in the appBuilder
configuration, on top of an existing theme, or as the main theme:
import { appBuilder } from "@spryker-oryx/application";
import { materialDesignIcons, storefrontIcons } from "@spryker-oryx/resources";
export const app = appBuilder().withTheme(customTheme).create();
Thank you!
For submitting the form