Skip to content

Alert

Alerts are used to display important messages either inline or as toast notifications.

info This is a standard alert. You can customize its content and even the icon.
html
<six-alert open>
  <six-icon slot="icon">info</six-icon>
  This is a standard alert. You can customize its content and even the icon.
</six-alert>

warning

Alerts will not be visible if the open attribute is not present.

Types

Set the type attribute to change the alert's type

infoThis is super informative
You can tell by how pretty the alert is.

check_circleYour changes have been saved
You can safely exit the app now.

infoYour settings have been updated
Settings will take affect on next login.

warning_amberYour session has ended
Please login again to continue.

error_outlineYour account has been deleted
We're very sorry to see you go!
html
<six-alert type="primary" open>
  <six-icon slot="icon">info</six-icon>
  <strong>This is super informative</strong><br>
  You can tell by how pretty the alert is.
</six-alert>

<br>

<six-alert type="success" open>
  <six-icon slot="icon">check_circle</six-icon>
  <strong>Your changes have been saved</strong><br>
  You can safely exit the app now.
</six-alert>

<br>

<six-alert type="info" open>
  <six-icon slot="icon">info</six-icon>
  <strong>Your settings have been updated</strong><br>
  Settings will take affect on next login.
</six-alert>

<br>

<six-alert type="warning" open>
  <six-icon slot="icon">warning_amber</six-icon>
  <strong>Your session has ended</strong><br>
  Please login again to continue.
</six-alert>

<br>

<six-alert type="danger" open>
  <six-icon slot="icon">error_outline</six-icon>
  <strong>Your account has been deleted</strong><br>
  We're very sorry to see you go!
</six-alert>

closable

Add the closable attribute to show a close button that will hide the alert.

info You can close this alert any time!
html
<six-alert type="primary" open closable class="alert-closable">
  <six-icon slot="icon">info</six-icon>
  You can close this alert any time!
</six-alert>

<script type="module">
  (() => {
    const alert = document.querySelector('.alert-closable');
    alert.addEventListener('six-alert-after-hide', () => {
      setTimeout(() => {
        alert.open = true;
      }, 2000);
    });
  })();
</script>

Without Icons

Icons are optional. Simply omit the icon slot if you don't want them.

Nothing fancy here, just a simple alert.
html
<six-alert type="primary" open> Nothing fancy here, just a simple alert. </six-alert>

Duration

Set the duration prop to automatically hide an alert after a period of time. This is useful for alerts that don't require acknowledgement.

Show Alertinfo This alert will automatically hide itself after three seconds, unless you interact with it.
html
<div class="alert-duration">
  <six-button type="primary">Show Alert</six-button>

  <six-alert type="primary" duration="3000" closable>
    <six-icon slot="icon">info</six-icon>
    This alert will automatically hide itself after three seconds, unless you interact with it.
  </six-alert>
</div>

<script type="module">
  (() => {
    const container = document.querySelector('.alert-duration');
    const button = container.querySelector('six-button');
    const disappearingAlert = container.querySelector('six-alert');

    button.addEventListener('click', () => disappearingAlert.show());
  })();
</script>

<style>
  .alert-duration six-alert {
    margin-top: var(--six-spacing-medium);
  }
</style>

Toast Notifications

To display an alert as a toast notification, or "toast", create the alert and call its `toast()` method. This will move the alert out of its position in the DOM and into the toast stack where it will be shown. Once dismissed, it will be removed from the DOM completely. To reuse a toast, store a reference to it and call toast() again later on.

You should always use the closable prop so users can dismiss the notification. It's also common to set a reasonable duration when the notification doesn't require acknowledgement.

PrimarySuccessInfoWarningDangerinfoThis is super informative
You can tell by how pretty the alert is.
check_circleYour changes have been saved
You can safely exit the app now.
infoYour settings have been updated
Settings will take affect on next login.
warning_amberYour session has ended
Please login again to continue.
error_outlineYour account has been deleted
We're very sorry to see you go!
html
<div class="alert-toast">
  <six-button id="primary-button" type="primary">Primary</six-button>
  <six-button id="success-button" type="success">Success</six-button>
  <six-button id="secondary-button" type="secondary">Info</six-button>
  <six-button id="warning-button" type="warning">Warning</six-button>
  <six-button id="danger-button" type="danger">Danger</six-button>

  <six-alert id="primary-alert" type="primary" duration="3000" closable>
    <six-icon slot="icon">info</six-icon>
    <strong>This is super informative</strong><br>
    You can tell by how pretty the alert is.
  </six-alert>

  <six-alert id="success-alert" type="success" duration="3000" closable>
    <six-icon slot="icon">check_circle</six-icon>
    <strong>Your changes have been saved</strong><br>
    You can safely exit the app now.
  </six-alert>

  <six-alert id="info-alert" type="info" duration="3000" closable>
    <six-icon slot="icon">info</six-icon>
    <strong>Your settings have been updated</strong><br>
    Settings will take affect on next login.
  </six-alert>

  <six-alert id="warning-alert" type="warning" duration="3000" closable>
    <six-icon slot="icon">warning_amber</six-icon>
    <strong>Your session has ended</strong><br>
    Please login again to continue.
  </six-alert>

  <six-alert id="danger-alert" type="danger" duration="3000" closable>
    <six-icon slot="icon">error_outline</six-icon>
    <strong>Your account has been deleted</strong><br>
    We're very sorry to see you go!
  </six-alert>
</div>

<script type="module">
  (() => {
    const alertToastContainer = document.querySelector('.alert-toast');

    Object.entries({
      primary: 'primary',
      success: 'success',
      info: 'secondary',
      warning: 'warning',
      danger: 'danger',
    }).map(([alertType, buttonType]) => {
      const button = alertToastContainer.querySelector(`#${buttonType}-button`);
      const alert = alertToastContainer.querySelector(`#${alertType}-alert`);

      button.addEventListener('click', () => alert.toast());
    });
  })();
</script>

Angular and Vue Utilities

The wrapper libraries for Angular and Vue offer a simpler way to create toast alerts:

  • Angular: Inject the `alertService` and utilize the `showAlert` method this.alertService.showAlert('The Alert Message');
  • Vue: Use showAlert by importing it from '@six-group/ui-library' and then invoke it showAlert('The Alert Message');

Creating Toasts Imperatively

You can also create your own utility that emits toast notifications with a function call rather than composing them in your HTML. To do this, generate the alert with JavaScript, append it to the body, and call the toast() method as shown in the example below.

Create Toast
html
<div class="alert-toast-wrapper">
  <six-button type="primary">Create Toast</six-button>
</div>

<script type="module">
  (() => {
    const alertToastImpContainer = document.querySelector('.alert-toast-wrapper');
    const toastCreatorButton = alertToastImpContainer.querySelector('six-button');
    let count = 0;

    // Always escape HTML for text arguments!
    function escapeHtml(html) {
      const div = document.createElement('div');
      div.textContent = html;
      return div.innerHTML;
    }

    // Custom function to emit toast notifications
    function notify(message, type = 'primary', icon = 'info', duration = 3000) {
      const alert = Object.assign(document.createElement('six-alert'), {
        type: type,
        closable: true,
        duration: duration,
        innerHTML: `
            <six-icon slot="icon">${icon}</six-icon>
            ${escapeHtml(message)}`,
      });

      document.body.append(alert);
      return alert.toast();
    }

    toastCreatorButton.addEventListener('click', () => {
      const possibleTypes = ['primary', 'success', 'info', 'warning', 'danger'];
      const drawnNumber = Math.round(Math.random(0, 1) * 5) + 1;
      notify(`This is custom toast #${++count}`, possibleTypes[drawnNumber]);
    });
  })();
</script>

The Toast Stack

The Toast Stack allows multiple toast notifications to be displayed in a clean, organized stack. Below is an example where 5 toast notifications are dynamically created and displayed with a short delay between each toast.

Create 5 Toasts
html
<div class="toast-stack-wrapper">
  <six-button type="primary">Create 5 Toasts</six-button>
</div>

<script type="module">
  (() => {
    const toastStackWrapper = document.querySelector('.toast-stack-wrapper');
    const createToastButton = toastStackWrapper.querySelector('six-button');

    // Always escape HTML for text arguments!
    function escapeHtml(html) {
      const div = document.createElement('div');
      div.textContent = html;
      return div.innerHTML;
    }

    // Custom function to emit toast notifications
    function createToast(message, type = 'primary', icon = 'info', duration = 4000) {
      const toast = Object.assign(document.createElement('six-alert'), {
        type: type,
        closable: true,
        duration: duration,
        innerHTML: `
    <six-icon slot="icon">${icon}</six-icon>
    ${escapeHtml(message)}`,
      });
      document.body.appendChild(toast);
      toast.toast();
    }

    createToastButton.addEventListener('click', () => {
      const toastTypes = ['primary', 'success', 'info', 'warning', 'danger'];
      let delay = 0;
      for (let i = 1; i <= 5; i++) {
        const randomType = toastTypes[Math.floor(Math.random() * toastTypes.length)];
        setTimeout(() => {
          createToast(`Toast #${i}`, randomType, 'info');
        }, delay);
        delay += 200;
      }
    });
  })();
</script>

Properties

PropertyAttributeDescriptionTypeDefault
closableclosableSet to true to make the alert closable.booleanfalse
durationdurationThe length of time, in milliseconds, the alert will show before closing itself. If the user hovers over the toast alert, the timer will pause. On leaving the element with the mouse, the timer resets.numberInfinity
openopenIndicates whether or not the alert is open. You can use this in lieu of the show/hide methods.booleanfalse
typetypeThe type of alert."danger" | "info" | "primary" | "success" | "warning"'primary'

Events

EventDescriptionType
six-alert-after-hideEmitted after the alert closes and all transitions are complete.CustomEvent<undefined>
six-alert-after-showEmitted after the alert opens and all transitions are complete.CustomEvent<undefined>
six-alert-hideEmitted when the alert closes. Calling event.preventDefault() will prevent it from being closed.CustomEvent<undefined>
six-alert-showEmitted when the alert opens. Calling event.preventDefault() will prevent it from being opened.CustomEvent<undefined>

Methods

hide() => Promise<void>

Hides the alert

Returns

Type: Promise<void>

show() => Promise<void>

Shows the alert.

Returns

Type: Promise<void>

toast(adjustPosition?: boolean) => Promise<void>

Displays the alert as a toast notification. This will move the alert out of its position in the DOM and, when dismissed, it will be removed from the DOM completely. By storing a reference to the alert, you can reuse it by calling this method again. The returned promise will resolve after the alert is hidden.

Parameters

NameTypeDescription
adjustPositionbooleanIf true, the top and right position of the toast stack is shifted according to the six-root header's height and the presence of a vertical scrollbar.

Returns

Type: Promise<void>

Slots

SlotDescription
The alert's content.
"icon"An icon to show in the alert.

Shadow Parts

PartDescription
"base"The component's base wrapper.
"close-button"The close button.
"icon"The container that wraps the alert icon.
"message"The alert message.

CSS Custom Properties

NameDescription
--box-shadowThe alert's box shadow.

Dependencies

Depends on

Graph


Copyright © 2021-present SIX-Group