Skip to content

Latest commit

 

History

History
733 lines (626 loc) · 37.2 KB

File metadata and controls

733 lines (626 loc) · 37.2 KB
layout title description group aliases toc
docs
Icons
Guidance and suggestions for using Solaris icons library with OUDS Web.
extend
/docs/extend/icons/
true

{{< callout info >}} You can find here the Iconography design guidelines. {{< /callout >}}

While OUDS Web doesn't include an icon set by default, Orange does have its own comprehensive icon library called Solaris. While most icon sets include multiple file formats, we prefer SVG implementations for their improved accessibility and vector support.

[Solaris icons library]({{< param icons >}}) is a growing library of icons that are designed by OUDS design team. It features an icon search tool based on categories and keywords, and allows icons to be downloaded in various formats for use in design and development. They are not open-source though and should only be used for Orange projects. Please refer to the [icons license file]({{< param icons_license >}}) for legal information.

If you need guidance to use Solaris icons, please refer to the paragraph [use Solaris icons]({{< docsref "extend/icons#use-solaris-icons" >}}).

Icons rendering

Icons are designed within a square layout to preserve consistency. Within this square, there exists a designated safety zone to guarantee that icons can be used in various sizes and contexts while maintaining alignment as intended by the designers. The dimensions of the icons encompass this safety zone, ensuring adaptability and consistency across diverse applications.

Icons color

To color icons, you can:

  • use [color utilities classes]({{< docsref "utilities/colors#colors" >}}) like .text-brand-primary, .text-disabled or .text-status-positive that change current color value.
  • specify a color using CSS variables like --bs-color-content-brand-primary, --bs-color-content-disabled" or --bs-color-content-status-positive".

For SVGs (SVG sprites, inline SVGs or CSS background SVGs), the fill="currentColor" attribute is required on the <svg> or <symbol> tag, if you want to change the icons color on the fly: it will make the icon inherit color from itself or its parent containers. It is set on the icons downloaded from Solaris icons finder.

Functional icons

The following color utilities and CSS variables are intended for use only with functional icons, not with text, and icons should not be used on their own, but only alongside text, as functional colors do not provide sufficient contrast to ensure readability.

Here are the normal contexts of use of these functional colors.

{{< bs-table >}}

Color utility Color CSS variable Context of use
.text-status-info --bs-color-content-status-info Use to communicate a feedback. It's more important than a neutral color.
.text-status-positive --bs-color-content-status-positive Use to communicate a positive action, a confirmation or a positive feedback.
.text-status-warning --bs-color-content-status-warning Use to display an information that requires more attention, or an action from the user.
.text-status-negative --bs-color-content-status-negative Use to communicate something negative. It can be a destructive action, an error state, or a negative feedback.
{{< /bs-table >}}

{{< example >}}

Info

Success

Warning

Danger

Info

Success

Warning

Danger

{{< /example >}}

Other icons

Here are some examples of other [color utilities]({{< docsref "utilities/colors#colors" >}}) and CSS variables used with icons.

{{< example class="d-inline-flex flex-column">}}

{{< /example >}}

Icons size

Icons' size depend on where they are placed in the page content, so please make sure to either use our utilities provided in this page or follow the design. Icons size utility classes are done to be used upon <img>, <svg> or even icon font wherever the icon is.

Every icon size utility class presented in here has the common following code:

{{< scss-docs name="ouds-font-icon-common" file="scss/helpers/_icon.scss" >}}

Headings

Here are the rules to follow for headings. These icons' sizes are responsive.

See the sizes associated to classes

{{< bs-table >}}

Icon class Values from 2xs to sm Values from md to lg Values for xl and upper
.hxl-lg-icon 3.25rem (52px) 4rem (64px) 4rem (64px)
.hxl-md-icon 3rem (48px) 3.5rem (56px) 3.75rem (60px)
.hxl-sm-icon 2.75rem (44px) 3.25rem (52px) 3.5rem (56px)
.hl-lg-icon 3rem (48px) 3.25rem (52px) 3.5rem (56px)
.hl-md-icon 2.75rem (44px) 3rem (48px) 3.25rem (52px)
.hl-sm-icon 2.5rem (40px) 2.75rem (44px) 3rem (48px)
.hm-lg-icon 2.75rem (44px) 3rem (48px) 3.25rem (52px)
.hm-md-icon 2.5rem (40px) 2.75rem (44px) 3rem (48px)
.hm-sm-icon 2rem (32px) 2.5rem (40px) 2.75rem (44px)
.hs-lg-icon 2.75rem (44px) 2.75rem (44px) 3rem (48px)
.hs-md-icon 2.5rem (40px) 2.5rem (40px) 2.75rem (44px)
.hs-sm-icon 2rem (32px) 2rem (32px) 2.5rem (40px)
.bl-lg-icon 1.75rem (28px) 1.75rem (28px) 2.75rem (44px)
.bl-md-icon 1.5rem (24px) 1.5rem (24px) 2.5rem (40px)
.bl-sm-icon 1.25rem (20px) 1.25rem (20px) 2rem (32px)
.bm-lg-icon 1.5rem (24px) 1.5rem (24px) 1.75rem (28px)
.bm-md-icon 1.25rem (20px) 1.25rem (20px) 1.5rem (24px)
.bm-sm-icon 1rem (16px) 1rem (16px) 1.25rem (20px)
{{< /bs-table >}}

{{< example >}}

H1 with large icon

H1 with medium icon

H1 with small icon


H2 with large icon

H2 with medium icon

H2 with small icon


H3 with large icon

H3 with medium icon

H3 with small icon


H4 with large icon

H4 with medium icon

H4 with small icon


H5 with large icon
H5 with medium icon
H5 with small icon

H6 with lg icon
H6 with medium icon
H6 with small icon
{{< /example >}}

Display headings

You should not use any icon with our .display-* font sizes, because we prefer to keep the place for the text.

Regular texts

Here are the rules to follow for regular texts. These icons' sizes are responsive.

See the sizes associated to classes

{{< bs-table >}}

Icon class Values from 2xs to sm Values from md to lg Values for xl and upper
.bl-lg-icon 1.75rem (28px) 1.75rem (28px) 2.75rem (44px)
.bl-md-icon 1.5rem (24px) 1.5rem (24px) 2.5rem (40px)
.bl-sm-icon 1.25rem (20px) 1.25rem (20px) 2rem (32px)
.bm-lg-icon 1.5rem (24px) 1.5rem (24px) 1.75rem (28px)
.bm-md-icon 1.25rem (20px) 1.25rem (20px) 1.5rem (24px)
.bm-sm-icon 1rem (16px) 1rem (16px) 1.25rem (20px)
.bs-lg-icon 1.25rem (20px) 1.25rem (20px) 1.5rem (24px)
.bs-md-icon 1rem (16px) 1rem (16px) 1.25rem (20px)
.bs-sm-icon .75rem (12px) .75rem (12px) 1rem (16px)
{{< /bs-table >}}

{{< example >}}

Lead paragraph with large icon

Lead paragraph with medium icon

Lead paragraph with small icon


Default paragraph with large icon

Default paragraph with medium icon

Default paragraph with small icon


Small paragraph with large icon

Small paragraph with medium icon

Small paragraph with small icon

{{< /example >}}

Decorative

Here are the rules to follow for decorative icons. Be careful using these icons' sizes because they are not responsive. Check out for [more information about accessibility in our documentation]({{< docsref "/extend/icons#icons-accessibility" >}}).

See the sizes associated to classes

{{< bs-table >}}

Icon class Value
.decorative-2xs-icon 1rem (16px)
.decorative-xs-icon 1.5rem (24px)
.decorative-sm-icon 2rem (32px)
.decorative-md-icon 2.5rem (40px)
.decorative-lg-icon 3rem (48px)
.decorative-xl-icon 3.5rem (56px)
.decorative-2xl-icon 4.5rem (72px)
{{< /bs-table >}}

2x-small decorative icon

coreGlobalDimension200 (1rem or 16px at zoom 100%)

X-small decorative icon

coreGlobalDimension300 (1.5rem or 24px at zoom 100%)

Small decorative icon

coreGlobalDimension400 (2rem or 32px at zoom 100%)

Medium decorative icon

coreGlobalDimension500 (2.5rem or 40px at zoom 100%)

Large decorative icon

coreGlobalDimension600 (3rem or 48px at zoom 100%)

X-large decorative icon

coreGlobalDimension700 (3.5rem or 56px at zoom 100%)

2x-large decorative icon

coreGlobalDimension900 (4.5rem or 72px at zoom 100%)

<svg class="decorative-2xs-icon text-status-info" width="1rem" height="1rem" fill="currentColor" aria-hidden="true"></svg>
<svg class="decorative-xs-icon text-status-info" width="1rem" height="1rem" fill="currentColor" aria-hidden="true"></svg>
<svg class="decorative-sm-icon text-status-info" width="1rem" height="1rem" fill="currentColor" aria-hidden="true"></svg>
<svg class="decorative-md-icon text-status-info" width="1rem" height="1rem" fill="currentColor" aria-hidden="true"></svg>
<svg class="decorative-lg-icon text-status-info" width="1rem" height="1rem" fill="currentColor" aria-hidden="true"></svg>
<svg class="decorative-xl-icon text-status-info" width="1rem" height="1rem" fill="currentColor" aria-hidden="true"></svg>
<svg class="decorative-2xl-icon text-status-info" width="1rem" height="1rem" fill="currentColor" aria-hidden="true"></svg>

Multiple lines

Sometimes you need a different structure to handle larger titles, or paragraphs that wrap over several lines. Here are some examples to handle these use cases. We've set arbitrary spacings, but align them with your design.

Centered on text block

This is the default behavior of our DOM.

{{< example >}}

H1 with large icon and a very long title to see how it behaves while being wrapped

{{< /example >}}

{{< example >}}

Default long paragraph with large icon. It stands here in order for you to see how the icon should behave when it's placed next to a long paragraph. Whenever the paragraph stands on multiple lines please prefer using a block element and not an inline element so there will no strange behaviors.

{{< /example >}}

Above text block

You can also have the icon above the text block.

{{< example >}}

H1 with large icon and a very long title to see how it behaves while being wrapped

{{< /example >}}

{{< example >}}

Default long paragraph with large icon. It stands here in order for you to see how the icon should behave when it's placed next to a long paragraph. Whenever the paragraph stands on multiple lines please prefer using a block element and not an inline element so there will no strange behaviors.

{{< /example >}}

<img> and font icon

SVG Sprite is the preferred choice for flexibility, performance and accessibility, and this is why all our examples use this method but there are other ways to display icons. They should all behave the same thanks to our CSS. If you are experimenting any trouble, feel free to search or fill in a new Github discussion or contact [our team]({{< docsref "/about/team" >}}).

{{< example >}}

H1 with large icon

H1 with large icon

{{< /example >}}

Icons accessibility

{{< callout info >}} For more details, Orange Accessibility Guidelines provides a deep-dive article regarding SVG accessibility. {{< /callout >}}

Decorative icons

Purely decorative icons (like repeating information of an adjacent text) must be hidden to assistive technologies:

  • for <svg> or <span> tags, use the attribute aria-hidden="true"
  • for <img>, use an empty alt attribute
  • CSS background images are intended to be decorative

Informative/meaningful icons

If the icon is meaningful, e.g. only content of a button, you have to provide an appropriate alternative text: for example, the description of the icon or the description of the action triggered. The best way to do this is to keep the icon hidden to assistive technologies (see above) and add a visually hidden label (which will be perceived by assistive technologies) by using the .visually-hidden class. For external images, you can also fill the alt attribute directly.

{{< example class="mt-0" >}} Delete Open settings

Parameters Add to favorites {{< /example >}}

Use Solaris icons

There are many ways to use Solaris icons in a web page:

  • Bundled, if you have several icons in your project:
    • [SVG sprite]({{< docsref "extend/icons#svg-sprite" >}}) (preferred choice for flexibility, performance and accessibility)
    • [Web font]({{< docsref "extend/icons#web-font" >}})
  • Individually, if you have only few icons to render:
    • [Inline SVG]({{< docsref "extend/icons#inline-svg" >}})
    • [SVG external image]({{< docsref "extend/icons#svg-external-image" >}})
    • [CSS background SVG]({{< docsref "extend/icons#css-background-svg" >}})

All icons can be retrieved easily in any of these formats in the Solaris icons finder. See Solaris icons library [develop documentation]({{< param icons_develop >}}) for complete development guidelines for the different formats, and their pros and cons.

SVG sprite

This technique is the preferred choice for flexibility, performance and accessibility.

Using the [Solaris icons finder]({{< param icons >}}), you can generate an SVG sprite, a single SVG file containing all your icons in <symbol> elements, and then insert an icon through a <use> element. With SVG sprites, you can benefit of the power of currentColor for easy coloring and theming.

SVG sprite file example:

{{< example lang="svg" show_preview="false" >}} {{< /example >}}

SVG sprite usage:

{{< example >}} {{< /example >}}

To speed up loading, the SVG sprite file can be preloaded in the <head> of the page:

{{< example lang="html" show_preview="false" >}}

{{< /example >}}

Web font

Web font is not the preferred solution. However, for websites needing more than 20 icons, you may consider using a Web font instead of an SVG sprite.

Using the [Solaris icons finder]({{< param icons >}}), you can generate a Web font containing all your icons and use it like a classic font. Web font icons can be styled through CSS properties like font-size and color. please keep in mind that adding or removing icons from the font afterward can be complicated.

{{< example >}} {{< /example >}}

Inline SVG

This technique should only be used if you have few icons to render, and if they are used only once in your website.

You can embed your icons directly within the HTML of your page (as opposed to an external image file). This way to use SVGs can benefit of the power of currentColor for easy coloring and theming.

{{< example class="mt-0" >}} {{< /example >}}

SVG external image

You can use it when:

  • you only have few icons to render
  • you don't need to change the icons colors. For that reason, we do not recommend to use that technique, so it won't be documented here.

CSS background SVG

CSS background icons should be used when you can't or don't want to refer to an external image, or if you want to include the icon in a CSS ::before or ::after pseudo-element.

You can use the SVG code within your CSS (be sure to escape any characters with [our internal escape-svg() function]({{< docsref "/customize/sass" >}}#escape-svg)). When no dimensions are specified via width and height on the <svg>, the icon will fill the available space. CSS background SVGs can be styled through CSS properties like width, height or background-color. Note that the xmlns attribute is required.

{{< example class="mt-0" >}} {{< /example >}}

Using:

{{< scss-docs name="icon-home" file="site/assets/scss/_component-examples.scss" >}}