Skip to content

Dev utils

Prod:

Attention!

This package is still in design phase. But you can use it during the development.

The @zurich/dev-utils NPM package is a package wit JavaScript (TypesCript) and SCSS code that can help to improve the whole DX (Development Experience) and QA (Quality Assurance) processes when su are using the Zurich Design System.

Install

The are two ways of installing the package:

Via CDN

Simply import the script in the <head> of your HTML:

html
<!DOCTYPE html>
<html lang="en">
  <head>
    <script type="module" src="https://zds.zurich.com/0.6.0/@zurich/dev-utils/web-cli.js"></script>
  </head>
</html>

The available files are:

Local installation

You can also install it locally and get access to the SCSS and all the tools provided. We need to install the package:

bash
npm i -D @zurich/dev-utils

And then import the functionality in the context where is going to be used.

ts
import { isBoolean } from '@zurich/dev-utils/helpers'

Check each section to know about the imports.

Helpers

We offer a big collection of useful functions that can help developers. We do not recommend to use it via CDN because of performance issues, since you will be importing all the helpers.

You can import them from @zurich/dev-utils/helpers:

ts
import { isBoolean } from '@zurich/dev-utils/helpers'

DRY (Don't Repeat Yourself)

We provide some very useful functions with strong typing that might be really useful to complement the development process when you are using the Zurich Design System. We recommend to have a look to the available ones and get familiar with them, since they can save hours of development and they are already unit tested and documented from our side.

Check all the available helpers in here.

Type helpers

There's also a collection of type helpers that can be imported from @zurich/dev-utils/helpers:

ts
import type { Enumerate, KeysExcluding } from '@zurich/dev-utils/helpers'


type Result_1 = Enumerate<5>;    // type Result_1 = 0 | 1 | 2 | 3 | 4

type Example = {
  a: string;
  b: number;
  c: boolean;
};

type Result_2 = KeysExcluding<Example, string>;    // type Result_2 = 'b' | 'c'

Web CLI

Attention!

Do not use the Web CLI in production. This is only a tool for development and QA.

In order to use the Web CLI, we need to import it in the use context.

scss
@import '@zurich/dev-utils/web-cli';

It can be import via CDN too:

html
<!DOCTYPE html>
<html lang="en">
  <head>
    <script type="module" src="https://zds.zurich.com/0.6.0/@zurich/dev-utils/web-cli.js"></script>
  </head>
</html>

Once the import is done, you would be able to access the Web CLI just by opening the dev tools of the browser and opening the console. Then just type ZDS. and the list of available commands will appear:

Docs image
Docs image

INFO

The Web CLI is included in every page of this documentation, so you can play with it.

Functions

This is the list of available function:

  • help: prints the help text.

  • Printers:

    • print: prints a content with the given styles.
    • printImage: prints in the console the image provided via param.
    • printCodeBlock: prints a code block in the console.
  • Inventory:

    • listCSSComponents: returns a list with the ZDS' CSS components in the document.
    • listWebComponents: returns a list with the ZDS' Web components in the document.
    • listAngularComponents: returns a list with the ZDS' Angular components in the document.
  • Report:

    • reportCSSComponents: elaborates a table of CSS components and helpers and their attributes.
    • reportWebComponents: elaborates a table of Web components and their attributes.

SCSS

In order to use the SCSS functionality, we recommend to import the index.scss using @use:

scss
@use "@zurich/dev-utils/src/SCSS/index.scss" as *;

SCSS component vars

You can access the components' tokens aliases via the components.scss file:

scss
@use "@zurich/dev-utils/src/components.scss" as comp;

$my-var: comp.$button--bg;

These SCSS variables point to the primitive and semantic CSS tokens used in @zurich/design-tokens.

SCSS Functions

We offer functions to ease the development.

This is the list of available functions:

  • Operators:
    • @function if($condition, $if-value, $else-value): a regular tertiary operator.

SCSS Mixins

We offer mixins to ease the development based on our foundations.

This is the list of available mixins:

  • Breakpoints:
    • desktop: a media query to use CSS only in desktop size.
    • landscape: a media query to use CSS only in landscape size.
    • landscapeOrSmaller: a media query to use CSS only in landscape or smaller sizes.
    • landscapeOrBigger: a media query to use CSS only in landscape or bigger sizes.
    • portrait: a media query to use CSS only in portrait size.
    • portraitOrSmaller: a media query to use CSS only in portrait or smaller sizes.
    • portraitOrBigger: a media query to use CSS only in portrait or bigger sizes.
    • mobile: a media query to use CSS only in mobile size.
    • portraitAndLandscape: a media query to use CSS only between portraitand landscape sizes.

Data

We expose some of the data about the ZDS that might be useful for creating integrations with platforms or specific tooling. This includes things like the metadata of the available icons, pictograms, or the BlueRoom images and their corresponding types (literals).

It can be imported from @zurich/dev-utils/data:

ts
import { ICONS, PICTOGRAMS } from '@zurich/dev-utils/data';

Locales

The available locales can be imported from @zurich/dev-utils/locales or individually:

ts
import { en, es } from '@zurich/dev-utils/locales';
import { LOCALES as de } from '@zurich/dev-utils/locales/de';

They are also available to be imported via CDN collectively or individually:

html
<!DOCTYPE html>
<html lang="en">
  <head>
    <script type="module">
      import("https://zds.zurich.com/0.6.0/@zurich/dev-utils/locales.js")
        .then(({ en, es }) => {
          console.log(en, es); // Locales for English and Spanish
        });

      import("https://zds.zurich.com/0.6.0/@zurich/dev-utils/locales/de.js")
        .then(({ LOCALES: de }) => {
          console.log(de); // Locales for German
        });
    </script>
  </head>
</html>

ZDS and i18n (Internationalization)

ZDS has integrated localization systems. Learn more about the localization mechanisms in here.