diff --git a/@kiva/kv-components/vue/KvLightbox.vue b/@kiva/kv-components/vue/KvLightbox.vue index 057d5d94..efb2815e 100644 --- a/@kiva/kv-components/vue/KvLightbox.vue +++ b/@kiva/kv-components/vue/KvLightbox.vue @@ -218,10 +218,16 @@ export default { const kvLightboxBody = ref(null); const controlsRef = ref(null); + const trapElements = computed(() => [ + kvLightbox.value, // This lightbox + '[role="alert"]', // Any open toasts/alerts on the page + ]); const { activate: activateFocusTrap, deactivate: deactivateFocusTrap, - } = useFocusTrap(kvLightbox); + } = useFocusTrap(trapElements, { + allowOutsideClick: true, // allow clicking outside the lightbox to close it + }); let makePageInertCallback = null; let onKeyUp = null; diff --git a/@kiva/kv-components/vue/stories/KvLightbox.stories.js b/@kiva/kv-components/vue/stories/KvLightbox.stories.js index 797ba9c3..e2bb60eb 100644 --- a/@kiva/kv-components/vue/stories/KvLightbox.stories.js +++ b/@kiva/kv-components/vue/stories/KvLightbox.stories.js @@ -2,6 +2,7 @@ import { mdiLightningBolt } from '@mdi/js'; import KvLightbox from '../KvLightbox.vue'; import KvMaterialIcon from '../KvMaterialIcon.vue'; import KvButton from '../KvButton.vue'; +import KvToast from '../KvToast.vue'; export default { title: 'KvLightbox', @@ -253,3 +254,51 @@ export const Informational = InformationalTemplate.bind({}); Informational.args = { title: 'Lightbox Title', }; + +const ToastInLightboxTemplate = (args, { + argTypes, +}) => ({ + props: Object.keys(argTypes), + components: { + KvToast, + KvButton, + KvLightbox, + }, + template: ` +
Click the button below to show a toast.
+ +