API
<Modals />
Handles the rendering of your modals in the stack
Slots
backdrop
Renders when any modals are open. The slot is empty by default.
<script>
import { Modals, closeModal } from 'svelte-modals'
</script>
<Modals>
<div
slot="backdrop"
class="backdrop"
on:click={closeModal}
/>
</Modals>
<style>
.backdrop {
position: fixed;
top: 0;
bottom: 0;
right: 0;
left: 0;
background: rgba(0, 0, 0, 0.5);
}
</style>
loading
Rendered when the current modal is being lazy loaded (see Lazy Loading).
<script>
import { Modals, closeModal } from 'svelte-modals'
import Spinner from '../Spinner.svelte'
</script>
<Modals>
<div
slot="backdrop"
class="backdrop"
on:click={closeModal}
/>
<div slot="loading">
<Spinner />
</div>
</Modals>
<style>
.backdrop {
position: fixed;
top: 0;
bottom: 0;
right: 0;
left: 0;
background: rgba(0, 0, 0, 0.5);
}
</style>
default
Modals will render in the default slot. If you want to control how modals are rendered yourself, you can do so here.
<script>
import { Modals, modals } from 'svelte-modals'
$: activeModal = $modals[$modals.length-1]
</script>
<Modals>
<!--
only render the active modal, removing the need for isOpen props
(warning: modal state will be lost between transitions)
-->
{#if activeModal}
<svelte:component
this={activeModal.component}
{...activeModal.props || {}}
/>
{/if}
</Modals>
openModal
Opens a new modal
import { openModal } from 'svelte-modals'
openModal(component, props, options)
Param | Type | Required | Description |
---|---|---|---|
component | SvelteComponent |
Yes | Your Svelte modal component |
props | any |
No | Props for the modal |
options | object |
No | |
options.replace | boolean |
No | This modal will replace the last modal in the stack |
options.on | object |
No | Event handlers for events dispatched by the modal. See Communicating with your Modals |
closeModal
Closes the last modal in the stack
import { closeModal } from 'svelte-modals'
closeModal()
Param | Type | Required | Description |
---|---|---|---|
value | any |
No | If passed in, the promise returned by openModal() will resolve with this value |
closeModals
Closes the provided amount of modals
import { closeModals } from 'svelte-modals'
closeModals(2)
Param | Type | Required | Description |
---|---|---|---|
amount | number |
Yes | The number of modals to close |
value | any |
No | If passed in, the promise returned by openModal() for each closed modal will resolve with this value |
closeAllModals
Closes all modals in the stack
import { closeAllModals } from 'svelte-modals'
closeAllModals()
Param | Type | Required | Description |
---|---|---|---|
value | any |
No | If passed in, the promise returned for all openModal() s will resolve with this value |
onBeforeClose
Allows a Modal to prevent itself from being closed
<script>
import { onBeforeClose } from 'svelte-modals'
let dirty = false
onBeforeClose(() => {
if (dirty) {
alert('You have unsaved changes!')
// prevents modal from closing
return false
}
})
</script>
<FancyForm bind:dirty />
$modals
A Svelte store containing the current stack of modal components and their props
$action
A Svelte store describing how the current modal came to be active (“push” or “pop”). This can be useful for transitions if they should animate differently based on the action.