62 lines
1.4 KiB
Vue
62 lines
1.4 KiB
Vue
<template>
|
|
<div class="window-buttons-web" @click="handleClick" :title="fullscreen.windowFullscreen ? 'Exit Fullscreen (F11)' : 'Enter Fullscreen (F11)'">
|
|
<TextLabel v-if="requestFullscreenHotkeys" :italic="true">Go fullscreen to access all hotkeys</TextLabel>
|
|
<IconLabel :icon="fullscreen.windowFullscreen ? 'FullscreenExit' : 'FullscreenEnter'" />
|
|
</div>
|
|
</template>
|
|
|
|
<style lang="scss">
|
|
.window-buttons-web {
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0 8px;
|
|
|
|
svg {
|
|
fill: var(--color-e-nearwhite);
|
|
}
|
|
|
|
.text-label {
|
|
margin-right: 8px;
|
|
}
|
|
|
|
&:hover {
|
|
background: var(--color-6-lowergray);
|
|
color: var(--color-f-white);
|
|
|
|
svg {
|
|
fill: var(--color-f-white);
|
|
}
|
|
}
|
|
}
|
|
</style>
|
|
|
|
<script lang="ts">
|
|
import { defineComponent } from "vue";
|
|
|
|
import fullscreen, { keyboardLockApiSupported, enterFullscreen, exitFullscreen } from "@/utilities/fullscreen";
|
|
|
|
import IconLabel from "@/components/widgets/labels/IconLabel.vue";
|
|
import TextLabel from "@/components/widgets/labels/TextLabel.vue";
|
|
|
|
const canUseKeyboardLock = keyboardLockApiSupported();
|
|
|
|
export default defineComponent({
|
|
inject: ["fullscreen"],
|
|
methods: {
|
|
async handleClick() {
|
|
if (fullscreen.windowFullscreen) exitFullscreen();
|
|
else enterFullscreen();
|
|
},
|
|
},
|
|
computed: {
|
|
requestFullscreenHotkeys() {
|
|
return canUseKeyboardLock && !fullscreen.keyboardLocked;
|
|
},
|
|
},
|
|
components: {
|
|
IconLabel,
|
|
TextLabel,
|
|
},
|
|
});
|
|
</script>
|