Popups

Utility

Create floating menus and tooltips using Floating UI.

Examples

This is a tooltip.

Lorem ipsum dolor sit amet consectetur, adipisicing elit. Dicta amet nam hic aspernatur cum porro praesentium. Voluptates velit ex ad eius sit! Sit deserunt ex accusamus quod fugit enim in?

Getting Started

Floating UI is a required dependency to enable Skeleton popup features.

console
npm install @floating-ui/dom

Configure Your Project

Import Floating UI into your root layout in /src/routes/+layout.svelte.

typescript
import { computePosition, autoUpdate, flip, shift, offset, arrow } from '@floating-ui/dom';

Then import storePopup from Skeleton.

typescript
import { storePopup } from '@skeletonlabs/skeleton';

Finally, pass an object containing each of the Floating UI features to the store.

typescript
storePopup.set({ computePosition, autoUpdate, flip, shift, offset, arrow });

Create a Popup

Create a PopupSettings object that maps to Floating UI settings.

typescript
let exampleSettings: PopupSettings = {
	// Set the event as: click | hover | hover-click
	event: 'click',
	// Provide a matching 'data-popup' value.
	target: 'examplePopup'
};

Apply the use:popup action to your trigger element.

html
<button ... use:popup={exampleSettings}>Trigger</button>

Apply a data-popup attribute to your desired popup element.

html
<div ... data-popup="examplePopup">(content)</div>

Arrow

Optional

Append an .arrow class element within your popup, then apply a matching background color.

html
<div class="card variant-filled-secondary p-4" data-popup="examplePopup">
	Popup text.
	<!-- Append the arrow element -->
	<div class="arrow variant-filled-secondary" />
</div>

Placement

Reference the available placement options. This setting defaults to bottom.

typescript
let exampleSettings: PopupSettings = {
	// ...
	placement: 'bottom'
};

State Handler

You can optionally monitor the show and hide state of a popup using state.

typescript
let exampleSettings: PopupSettings = {
	// ...
	state: (e) => console.log(e)
};

Middleware

Advanced

You can modify settings for select Floating UI middleware within PopupSettings. These are passed verbatim.

typescript
let exampleSettings: PopupSettings = {
	// ...
	middleware: {
		/** https://floating-ui.com/docs/offset */
		offset: 24, // or { ... }
		/** https://floating-ui.com/docs/shift */
		shift: { ... },
		/** https://floating-ui.com/docs/flip */
		flip: { ... },
		/** https://floating-ui.com/docs/arrow */
		arrow: { ... }
	}
};

Accessibility

We recommend you favor the click event for mobile devices, as hover is not well supported.


Browser Support

Please be aware that there is a z-index bug for popups rendered over elements using backdrop-blur in some browsers. The popup will appear to be rendered behind the blurred element, even with an elevated z-index.