2022-11-23 04:48:01 +01:00
|
|
|
|
<script setup lang="ts">
|
2022-11-27 02:52:46 +01:00
|
|
|
|
import {
|
2022-12-09 22:18:21 +01:00
|
|
|
|
isCommandPanelOpen,
|
2022-11-27 02:52:46 +01:00
|
|
|
|
isEditHistoryDialogOpen,
|
2022-11-30 04:27:19 +01:00
|
|
|
|
isMediaPreviewOpen,
|
2022-11-27 02:52:46 +01:00
|
|
|
|
isPreviewHelpOpen,
|
|
|
|
|
isPublishDialogOpen,
|
|
|
|
|
isSigninDialogOpen,
|
|
|
|
|
} from '~/composables/dialog'
|
2022-12-09 22:18:21 +01:00
|
|
|
|
|
|
|
|
|
const isMac = useIsMac()
|
|
|
|
|
|
|
|
|
|
// TODO: temporary, await for keybind system
|
2022-12-13 19:29:42 +01:00
|
|
|
|
// open search panel
|
|
|
|
|
// listen to ctrl+k on windows/linux or cmd+k on mac
|
|
|
|
|
// open command panel
|
2022-12-09 22:18:21 +01:00
|
|
|
|
// listen to ctrl+/ on windows/linux or cmd+/ on mac
|
2022-12-13 19:29:42 +01:00
|
|
|
|
// or shift+ctrl+k on windows/linux or shift+cmd+k on mac
|
2022-12-09 22:18:21 +01:00
|
|
|
|
useEventListener('keydown', (e: KeyboardEvent) => {
|
2022-12-13 19:29:42 +01:00
|
|
|
|
if (e.key === 'k' && (isMac.value ? e.metaKey : e.ctrlKey)) {
|
|
|
|
|
e.preventDefault()
|
|
|
|
|
openCommandPanel(e.shiftKey)
|
|
|
|
|
}
|
2022-12-09 22:18:21 +01:00
|
|
|
|
if (e.key === '/' && (isMac.value ? e.metaKey : e.ctrlKey)) {
|
|
|
|
|
e.preventDefault()
|
|
|
|
|
openCommandPanel(true)
|
|
|
|
|
}
|
|
|
|
|
})
|
2022-11-23 04:48:01 +01:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<template>
|
2022-12-22 15:59:51 +01:00
|
|
|
|
<ModalDialog v-model="isPreviewHelpOpen" max-w-125>
|
|
|
|
|
<LazyHelpPreview @close="closePreviewHelp()" />
|
|
|
|
|
</ModalDialog>
|
|
|
|
|
<ClientOnly v-if="isMastoInitialised">
|
2022-12-17 17:55:29 +01:00
|
|
|
|
<ModalDialog v-model="isSigninDialogOpen" py-4 px-8 max-w-125>
|
2022-12-22 15:59:51 +01:00
|
|
|
|
<LazyUserSignIn />
|
2022-12-17 17:55:29 +01:00
|
|
|
|
</ModalDialog>
|
|
|
|
|
<ModalDialog v-model="isPublishDialogOpen" max-w-180 flex>
|
|
|
|
|
<!-- This `w-0` style is used to avoid overflow problems in flex layouts,so don't remove it unless you know what you're doing -->
|
2022-12-22 15:59:51 +01:00
|
|
|
|
<LazyPublishWidget v-if="currentUser" :draft-key="dialogDraftKey" expanded flex-1 w-0 />
|
2022-12-17 17:55:29 +01:00
|
|
|
|
</ModalDialog>
|
|
|
|
|
<ModalDialog
|
|
|
|
|
v-model="isMediaPreviewOpen"
|
|
|
|
|
w-full max-w-full h-full max-h-full
|
|
|
|
|
bg-transparent border-0 shadow-none
|
|
|
|
|
>
|
2022-12-22 15:59:51 +01:00
|
|
|
|
<LazyModalMediaPreview v-if="isMediaPreviewOpen" @close="closeMediaPreview()" />
|
2022-12-17 17:55:29 +01:00
|
|
|
|
</ModalDialog>
|
|
|
|
|
<ModalDialog v-model="isEditHistoryDialogOpen" max-w-125>
|
2022-12-22 15:59:51 +01:00
|
|
|
|
<LazyStatusEditPreview :edit="statusEdit" />
|
2022-12-17 17:55:29 +01:00
|
|
|
|
</ModalDialog>
|
|
|
|
|
<ModalDialog v-model="isCommandPanelOpen" max-w-fit flex>
|
2022-12-22 15:59:51 +01:00
|
|
|
|
<LazyCommandPanel @close="closeCommandPanel()" />
|
2022-12-17 17:55:29 +01:00
|
|
|
|
</ModalDialog>
|
2022-12-22 15:59:51 +01:00
|
|
|
|
</ClientOnly>
|
2022-11-23 04:48:01 +01:00
|
|
|
|
</template>
|