diff --git a/site/assets/scss/_component-examples.scss b/site/assets/scss/_component-examples.scss index e1b4f8fc2a..b8f68aae44 100644 --- a/site/assets/scss/_component-examples.scss +++ b/site/assets/scss/_component-examples.scss @@ -510,13 +510,13 @@ // scss-docs-start icon-home .icon-home::before { display: inline-block; - width: 2rem; - height: 2rem; + width: 3rem; + height: 3rem; vertical-align: bottom; content: ""; - background-color: var(--bs-color-content-default); + background-color: currentcolor; background-size: contain; - mask-image: url("data:image/svg+xml,"); + mask-image: escape-svg(url("data:image/svg+xml,")); } // scss-docs-end icon-home diff --git a/site/content/docs/0.3/components/buttons.md b/site/content/docs/0.3/components/buttons.md index 1f42e116a5..b7590eb984 100644 --- a/site/content/docs/0.3/components/buttons.md +++ b/site/content/docs/0.3/components/buttons.md @@ -82,6 +82,12 @@ OUDS Web offers a few variations to use on [colored backgrounds]({{< docsref "/u ## With icon +{{< callout info >}} +The recommended way of using an icon in a button is through an [SVG sprite file]({{< docsref "/extend/icons/#svg-sprite" >}}). You need to fill it using `currentColor` to respect the button color scheme (can be set directly inside the SVG sprite). + +When icons are purely decorative, they should be hidden from assistive technologies using `aria-hidden="true"`, as we've done in our text and icon examples. For icon only, we chose to keep the icon hidden from assistive technologies and add a visually hidden label. See [icons accessibility]({{< docsref "/extend/icons/#icons-accessibility" >}}) for more info. +{{< /callout >}} + ### Text and icon The recommended way of using an icon in a button is an embedded SVG. You need to fill it using `currentColor` to respect button color scheme (which can be done inside the SVG sprite file). diff --git a/site/content/docs/0.3/components/links.md b/site/content/docs/0.3/components/links.md index 170056210e..1883b8b25e 100644 --- a/site/content/docs/0.3/components/links.md +++ b/site/content/docs/0.3/components/links.md @@ -60,18 +60,16 @@ Add `.link-chevron` to enhance your link with a chevron on the right side. Use t ## Icon link -The `.icon-link` class modifies the default link styles to enhance their appearance and quickly align any pairing of icon and text. Alignment is set via inline flexbox styling and a default `gap` value. We style the underline with a custom offset and color. Icons are automatically sized to `1em` to best match their associated text's `font-size`. - {{< callout info >}} -Inside links, you should use Solaris icons, either in an SVG sprite (`` element in an SVG file), which is the recommended method, or in an icon font. You can generate both with [Solaris Icons Finder](https://oran.ge/icons). - -We strongly advise against using an `` or other techniques, especially because the icon will not benefit from dynamic color changes across states (hover, focus, active) and the color mode system will not work. +The recommended way of using an icon in a link is through an [SVG sprite file]({{< docsref "/extend/icons/#svg-sprite" >}}). You need to fill it using `currentColor` to respect the link color scheme (can be set directly inside the SVG sprite). {{< /callout >}} +The `.icon-link` class modifies the default link styles to enhance their appearance and quickly align any pairing of icon and text. Alignment is set via inline flexbox styling and a default `gap` value. We style the underline with a custom offset and color. Icons are automatically sized to `1em` to best match their associated text's `font-size`. + If really needed, you can use a font icon associated to the `.icon` class to set correct parameters for the `font-size` and `line-height`. {{< callout >}} -When icons are purely decorative, they should be hidden from assistive technologies using `aria-hidden="true"`, as we've done in our examples. For icons that convey meaning, provide an appropriate text alternative by adding `role="img"` and an appropriate `aria-label="..."` to the SVGs, or a `.visually-hidden` text for a font icon. +When icons are purely decorative, they should be hidden from assistive technologies using `aria-hidden="true"`, as we've done in our links examples. See [icons accessibility]({{< docsref "/extend/icons/#icons-accessibility" >}}) for more info. {{< /callout >}} Take a regular `` element, add `.icon-link`, and insert an icon on the left of your link text. The icon is automatically sized, placed, and colored. diff --git a/site/content/docs/0.3/content/typography.md b/site/content/docs/0.3/content/typography.md index 688486e586..d7744e8524 100644 --- a/site/content/docs/0.3/content/typography.md +++ b/site/content/docs/0.3/content/typography.md @@ -76,7 +76,7 @@ All HTML headings, `

` through `

`, are available. Each class sets `font-s

h6. OUDS Web heading

{{< /example >}} -You can easily add an icon with your font reference using [our icon helper]({{< docsref "/helpers/icon" >}}). +You can easily add an icon with your font reference using [our icon size utilities]({{< docsref "/extend/icons#icons-size" >}}). @@ -182,7 +182,7 @@ Body medium is set by default on `:root` children but we don't set the `max-widt -You can easily add an icon with your font reference using [our icon helper]({{< docsref "/helpers/icon" >}}). +You can easily add an icon with your font reference using [our icon size utilities]({{< docsref "/extend/icons#icons-size" >}}). ### Lead diff --git a/site/content/docs/0.3/examples/grid-system/index.html b/site/content/docs/0.3/examples/grid-system/index.html index 7d684530ec..28dc29a8a1 100644 --- a/site/content/docs/0.3/examples/grid-system/index.html +++ b/site/content/docs/0.3/examples/grid-system/index.html @@ -7,16 +7,6 @@ - "/examples/grid-system" - "/docs/examples/grid-system" --- - - - - - - - - - -

OUDS Web grid system example

diff --git a/site/content/docs/0.3/extend/icons.md b/site/content/docs/0.3/extend/icons.md index 1d41af622f..ae81007bf4 100644 --- a/site/content/docs/0.3/extend/icons.md +++ b/site/content/docs/0.3/extend/icons.md @@ -1,11 +1,745 @@ --- layout: docs title: Icons -description: Guidance and suggestions for using icons library with OUDS Web. +description: Guidance and suggestions for using Solaris icons library with OUDS Web. group: extend aliases: - "/docs/extend/icons/" toc: true --- -{{< callout-soon "page" >}} +{{< callout info >}} +You can find here the [Iconography design guidelines](https://unified-design-system.orange.com/472794e18/p/275963-iconography). +{{< /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 mask image SVGs), the `fill="currentColor"` attribute is required on the `` or `` 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. For CSS mask image SVGs, the `background-color: currentColor` CSS property should be set. + +### 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](https://unified-design-system.orange.com/472794e18/p/217ac6-colour/t/9b95834c2e). + +{{< 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 depends 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 designed to be used upon ``, `` 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%)

+
+
+
+ +```html + + + + + + + +``` + +### 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 >}} + +### `` 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](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/discussions) 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](https://a11y-guidelines.orange.com/en/articles/accessible-svg/). +{{< /callout >}} + +#### Decorative icons +Purely **decorative icons** (like repeating information of an adjacent text) must be hidden to assistive technologies: +- for `` or `` tags, use the attribute `aria-hidden="true"` +- for ``, use an empty `alt` attribute +- CSS background images are intended to be decorative + +#### Informative/meaningful icons + +If the icon is **meaningful** with no visible adjacent text, e.g. indication in a table or only content of a button, you have to provide an appropriate alternative text with 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. You can also use an `aria-label` on the containing interactive element to provide an accessible name. For external images within the `` tag, you can also fill the `alt` attribute directly. + +Remember that you cannot use external images inside interactive elements because the color won't change with the element's status (hover, active, focus...), see [SVG external image]({{< docsref "extend/icons#svg-external-image" >}}). + + +{{< example class="mt-0 bd-btn-example">}} + + + + +
+ Favorite +
+{{< /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 mask image SVG]({{< docsref "extend/icons#css-mask-image-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 `` elements, and then insert an icon through a `` 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 `` 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 SVG through an `` tag 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 mask image SVG + +CSS mask image 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 should use the `mask-image` property instead of `background-image` to benefit from the coloring and theming system, by setting `background-color` property to `currentColor`. 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 ``, the icon will fill the available space. Mask images can also be styled through CSS properties like `width` or `height`. 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" >}} diff --git a/site/content/docs/0.3/helpers/icon-link.md b/site/content/docs/0.3/helpers/icon-link.md deleted file mode 100644 index 358f8f4df8..0000000000 --- a/site/content/docs/0.3/helpers/icon-link.md +++ /dev/null @@ -1,11 +0,0 @@ ---- -layout: docs -title: Icon link -description: Quickly create stylized hyperlinks with icons. -group: helpers -aliases: - - "/docs/helpers/icon-link/" -toc: true ---- - -{{< callout-soon "helper" >}} diff --git a/site/content/docs/0.3/helpers/icon.md b/site/content/docs/0.3/helpers/icon.md deleted file mode 100644 index 635bba734f..0000000000 --- a/site/content/docs/0.3/helpers/icon.md +++ /dev/null @@ -1,490 +0,0 @@ ---- -layout: docs -title: Icon -description: Quickly see the right icon sizes with a specific typography reference. -group: helpers -aliases: - - "/docs/helpers/icon/" -toc: true ---- - -## Approach - -The icon classes are done to be used upon ``, `` or even icon font wherever the icon is. Please make sure to either the rules described in this page or follow the design. - -Every icon 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` (32px) | -| `.bl-md-icon` | `1.5rem` (24px) | `1.5rem` (24px) | `2.5rem` (28px) | -| `.bl-sm-icon` | `1.25rem` (20px) | `1.25rem` (20px) | `2rem` (24px) | -| `.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` (32px) | -| `.bl-md-icon` | `1.5rem` (24px) | `1.5rem` (24px) | `2.5rem` (28px) | -| `.bl-sm-icon` | `1.25rem` (20px) | `1.25rem` (20px) | `2rem` (24px) | -| `.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. - -
- 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%)

-
-
-
- -```html - - - - - - - -``` - -## 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 >}} - -## `` 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 due to our CSS. If you are experimenting any trouble, feel free to search or fill in a new [Github discussion](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/discussions) or contact [our team]({{< docsref "/about/team" >}}). - -{{< example >}} -
- -

H1 with large icon

-
-
- -

H1 with large icon

-
-{{< /example >}} - -## CSS - -### Variables - -{{< scss-docs name="root-size-scaled-var-ouds" file="scss/_root.scss" >}} - -### Sass tokens - -#### Raw tokens - -Dimension raw tokens as Sass variables. **Not to be used as-is**. - -{{< scss-docs name="ouds-raw-dimension" file="scss/tokens/_raw.scss" >}} - -#### Semantic tokens - -Size semantic tokens are defined as Sass variables. - -{{< scss-docs name="ouds-semantic-size" file="scss/tokens/_semantic.scss" >}} diff --git a/site/content/docs/0.3/utilities/colors.md b/site/content/docs/0.3/utilities/colors.md index ea32fd1d14..643bb22fc2 100644 --- a/site/content/docs/0.3/utilities/colors.md +++ b/site/content/docs/0.3/utilities/colors.md @@ -97,33 +97,7 @@ In the following table we assume that the context is switching between light and ### On icons -The following color utilities are meant to be used only with icons and not with text. - -{{< example >}} - - - - -{{< /example >}} - -Here are [the normal contexts of use of these text color utilities](https://unified-design-system.orange.com/472794e18/p/217ac6-colour/t/9b95834c2e). - -{{< bs-table >}} -| Color utility | Context of use | -| --- | --- | -| `.text-status-info` | Use to communicate a feedback. It's more important than a neutral color. | -| `.text-status-positive` | Use to communicate a positive action, a confirmation or a positive feedback. | -| `.text-status-warning` | Use to display an information that requires more attention, or an action from the user. | -| `.text-status-negative` | Use to communicate something negative. It can be a destructive action, an error state, or a negative feedback. | -{{< /bs-table >}} +See [icons documentation]({{< docsref "/extend/icons/#icons-color" >}}) to learn how to use color utilities on icons. diff --git a/site/content/docs/0.3/utilities/text.md b/site/content/docs/0.3/utilities/text.md index a9ff5aa546..959db0cd60 100644 --- a/site/content/docs/0.3/utilities/text.md +++ b/site/content/docs/0.3/utilities/text.md @@ -143,7 +143,7 @@ These classes change the `font-size` but also the `line-height`, the `letter-spa Customize your available `font-size`s by modifying the `$ouds-font-sizes` Sass map. -You can easily add an icon with your font reference using [our icon helper]({{< docsref "/helpers/icon" >}}). +You can easily add an icon with your font reference using [our icon size utilities]({{< docsref "/extend/icons#icons-size" >}}). {{< bootstrap-compatibility >}} diff --git a/site/data/sidebar.yml b/site/data/sidebar.yml index b0757e62ba..1451669d77 100644 --- a/site/data/sidebar.yml +++ b/site/data/sidebar.yml @@ -172,7 +172,6 @@ - title: Colored links - title: Focus ring draft: true - - title: Icon - title: Position - title: Ratio - title: Stacks @@ -212,7 +211,6 @@ pages: - title: Approach - title: Icons - draft: true - title: About icon: globe2 diff --git a/site/static/docs/0.3/assets/img/heart-recommend.svg b/site/static/docs/0.3/assets/img/heart-recommend.svg new file mode 100644 index 0000000000..8806bde573 --- /dev/null +++ b/site/static/docs/0.3/assets/img/heart-recommend.svg @@ -0,0 +1,3 @@ + + + diff --git a/site/static/docs/0.3/assets/img/ouds-web-sprite.svg b/site/static/docs/0.3/assets/img/ouds-web-sprite.svg index 9a47e5f235..9cb4aa492d 100644 --- a/site/static/docs/0.3/assets/img/ouds-web-sprite.svg +++ b/site/static/docs/0.3/assets/img/ouds-web-sprite.svg @@ -1,29 +1,35 @@ - + - + - + - + - + - - + + - - + + - - + + - - + + + + + + + +