/ods-toast

Deprecated toast custom element

Primary LanguageJavaScriptApache License 2.0Apache-2.0

ods-toast web component

The <ods-toast> component is custom functional web component for the purpose of exposing a user feedback interface.

Docs

All information regarding Project Setup, Technical Details, Tests and information regarding auro web components can be found in the doc site.

Install

Build Status See it on NPM! License

$ npm i @alaskaairux/ods-toast

Define dependency in project component

Define the component dependency within each component that is using the <ods-toast> component.

import "@alaskaairux/ods-toast";

Toaster.js

Use the bundled Toaster.js tool to display and manage toasts in a given interface. This dependency isn't built into the scope of the component in order to allow for consuming projects to bundle it with other project dependencies as needed.

Toaster.js is an optional--but highly recommended--utility class containing logic to manage toasts. If there is a compelling reason not to use Toaster.js, please submit an issue with the intent to resolve it.

Swipe.js

Swipe.js is an independent dependency that will only be loaded when the user's device is detected to support touchstart.

Toaster.css / .scss

The animation of <ods-toast> is to be installed as an external resource.

File Type Import path
toaster.css CSS @alaskaairux/ods-toast/dist/toaster.css
toaster.scss Sass @alaskaairux/ods-toast/dist/toaster.scss

Orion Icons dependency

The <ods-toast> custom element has a dependency on the Auro Icons library. Be sure to read the Icons tokens install instructions for additional styling support.

Design Token CSS Custom Property dependency

The use of any ODS Component has a dependency on the ODS Design Tokens.

CSS Custom Property fallbacks

CSS Custom Properties are not supported in older browsers. For this, fallback properties are pre-generated and included with the npm. Any update to the Orion Design Tokens will be immediately reflected with browsers that support CSS Custom Properties, legacy browsers will require updated components with pre-generated fallback properties.

Reference component in HTML

<ods-toast title="This is the title"></ods-toast>

Element ods-toast

Toast use cases

The <ods-toast> element should be used in situations where:

  • alert of successful actions is passive
  • message does not require interaction from user
  • messages, if missed by auto dismiss, is not crucial to the users interaction

Properties:

Attribute Value type Description
title string large bold-faced text at the top of the toast component
message string, null smaller text that appears below the title
clickCallback function to allow for external events to be bound within the scope of the shadow DOM

API Code Examples

Default Classic Toast

<ods-toast title="This is a title"></ods-toast>
<ods-toast title="This is a title" message="This is a message"></ods-toast>

Classic Toast with slotting

<ods-toast title="This is a title" message="This is a message">
  <ods-hyperlink class="util_paddingLeft--none" href="#">Learn more</ods-hyperlink>
</ods-toast>
Loading Dynamic Toasts

Loading a dynamic experience with <ods-toast> requires the use of Toaster.js and Swipe.js and follows a slightly different API then that of the static web component.

The following example illustrates how you could implement a use case:

import "@alaskaairux/ods-toast/dist/ods-toast";
import Swipe from "@alaskaairux/ods-toast/dist/swipe.js";
import Toaster from "@alaskaairux/ods-toast/dist/toaster";
import "@alaskaairux/ods-toast/dist/toaster.css";

window.Swipe = Swipe;
const toastDuration = 7000;
const initialToastDelay = 2000;
const toasts = new Toaster(toastDuration);
setTimeout(() => {
  toasts.add("Your status has been updated");
  toasts.add("Flight information updated", "Thank you, Your seat preference has been saved");
  toasts.add("Wahoo!", "Your preferences have been updated", "Oops? <ods-hyperlink class='util_paddingLeft--none' href='/'>UNDO</ods-hyperlink>");
}, initialToastDelay);

Each instance of toasts.add() will add the <ods-toast> custom element to the view.

ods-hyperlink example styling; requires @alaskaairux/ods-hyperlink: ^1.0.6

The classes util_paddingLeft--none and util_paddingRight--none can be placed on the ods-hyperlink element using the class attribute.

Development

In order to develop against this project, if you are not part of the core team, you will be required to fork the project prior to submitting a pull request.

Please be sure to review the contribution guidelines for this project. Please make sure to pay special attention to the conventional commits section of the document.

Start development environment

Once the project has been cloned to your local resource and you have installed all the dependencies you will need to open three different shell sessions. One is for the Gulp tasks, the second is for a series of npm tasks and the last is to run the Polymer server.

// shell terminal one
$ gulp dev

// shell terminal two
$ npm run dev

// shell terminal three
polymer serve