Get started with our application framework!
The Zywave API Toolkit is offered in a variety of ways. All components (including the bundle) are available via the npm registry; meaning you're just an npm install
or yarn add
away.
However, the most common (and recommended) way to install the toolkit is via a CDN that can resolve npm tags and versions. Zywave offers that service via the Zywave CDN.
Determine if your application requires stable third-party components
- If yes, get the most recent stable versions here:
- Booster Design System (ZUI) bundle: https://cdn.zywave.com/@zywave/zui-bundle@latest/dist/
- Booster Application Framework (ZAPI) bundle: https://cdn.zywave.com/@zywave/zywave-api-toolkit-bundle@latest/dist/
- If no, get the most recent pre-released versions here:
- Booster Design System (ZUI) bundle: https://cdn.zywave.com/@zywave/zui-bundle@next/dist/
- Booster Application Framework (ZAPI) bundle: https://cdn.zywave.com/@zywave/zywave-api-toolkit-bundle@next/dist/
Required files
There are four required files in order for the Booster Application Framework bundle to work propertly in every application:
zui-bundle.fouc.css
- required for a smooth transition while all the scripts on the page loads, especially for non-SPAszui-bundle.app.css
- required for resetting styles for all base elements in your application- zui-bundle's
bundle.js
* - required to load most ZUI components properly - zywave-api-toolkit-bundle's
bundle.js
* - required to load all ZAPI components properly
<script type="module" src="https://cdn.zywave.com/@zywave/zywave-api-toolkit-bundle@{latest|next}/dist/bundle.js"></script>
bundle.js
file is delivered as ES modules and must be loaded from other ES modules, e.g. <script type="module" src="https://cdn.zywave.com/@zywave/zui-bundle@latest/dist/bundle.js"></script>
.
** There are some exceptions to what components are part of the ZUI bundle. For example, <zui-table>
must be embedded separately. Learn more by visiting the Tables documentation.
Install via CDN (recommended)
The Zywave API toolkit offers a bundle with all of the core componentry for the Zywave API Toolkit, which includes the Zywave Shell, the API proxy, etc. This bundle is delivered as an ES module, and only works in modern browsers.
By loading the bundle via a CDN that can resolve npm tags, we can push fixes/enhancements to your application without any deployment on your end.
<!doctype html>
<html>
<head>
<title>Installing packages | Booster Development Network</title>
<!-- These two stylesheets should always be listed before all other application styles -->
<!-- Make sure `zui-bundle.fouc.css` is always listed first to counter FOUC -->
<link rel="stylesheet" href="https://cdn.zywave.com/@zywave/zui-bundle@{latest|next}/dist/css/zui-bundle.fouc.css" />
<link rel="stylesheet" href="https://cdn.zywave.com/@zywave/zui-bundle@{latest|next}/dist/css/zui-bundle.app.css" />
<!-- It is required to also load the ZUI bundle and stylesheets above, especially for Zywave Shell usage -->
<script type="module" src="https://cdn.zywave.com/@zywave/zui-bundle@{latest|next}/dist/bundle.js"></script>
<script type="module" src="https://cdn.zywave.com/@zywave/zywave-api-toolkit-bundle@{latest|next}/dist/bundle.js"></script>
</head>
<body>
<!-- your content here -->
<body>
</html>
Install via Yarn/NPM
If you want an à la carte experience, you can install individual component packages via Yarn or NPM.
The following works with no extra work:
> yarn add @zywave/zui-components-all
> yarn add @zywave/zywave-components-all
> npm install @zywave/zui-components-all
> npm install @zywave/zywave-components-all
API Proxy Element
The Zywave API Toolkit, as its name might suggest, communicates with Zywave's own APIs via client-side JavaScript. Because of distrust when it comes to client-side authentication, we offer an API Proxy element that communicates API calls through a hosted proxy application, which applies secure headers before sending the request off to the underlying APIs. This element must be the first element on the page within your <body>
and requires an api-base-url
be supplied to ensure it is pointing at the proper host.
profile-token
or bearer-token
to all Zywave API Toolkit components.
For more information on the API Proxy Element, click here.
Where do I find a list of released packages to install?
- Search for
@zywave
at npmjs.com - Check out our Booster Design System monorepo and Booster Application Framework monorepo for all available packages
@latest and @next tags
You may have noticed in that code snippets above the following:@{latest|next}
These terms correspond to npm distribution tags, where latest
is stable, production-ready code, and next
is generally unstable and not suitable to be referenced in a live environment.
Choose the right tag for your situation, and update accordingly (e.g., https://cdn.zywave.com/@zywave/zywave-api-toolkit-bundle@latest/dist/bundle.js
).
Version numbers
In addition to dist tags, you can use any valid npm version as found here.
This can be generally useful when a critical issue is encountered, or a deprecation notice goes unheeded.
A versioned URL could look something like the following:https://cdn.zywave.com/@zywave/zywave-api-toolkit-bundle@1.0.22/dist/bundle.js