2021-02-08 12:50:28 +08:00

139 lines
3.9 KiB
Vue

<template>
<div class="editor-header">
<div class="left">
<Dropdown :trigger="['click']">
<div class="menu-item"><IconEdit /> 编辑</div>
<template #overlay>
<Menu>
<MenuItem @click="undo()">撤销</MenuItem>
<MenuItem @click="redo()">重做</MenuItem>
<MenuItem @click="createSlide()">添加页面</MenuItem>
<MenuItem @click="deleteSlide()">删除页面</MenuItem>
<MenuItem @click="toggleGridLines()">{{ showGridLines ? '关闭网格线' : '打开网格线' }}</MenuItem>
<MenuItem @click="resetSlides()">重置幻灯片</MenuItem>
</Menu>
</template>
</Dropdown>
<Dropdown :trigger="['click']">
<div class="menu-item"><IconPpt /> 演示</div>
<template #overlay>
<Menu>
<MenuItem @click="enterScreeningFromStart()">从头开始</MenuItem>
<MenuItem @click="enterScreening()">从当前页开始</MenuItem>
</Menu>
</template>
</Dropdown>
<Dropdown :trigger="['click']">
<div class="menu-item"><IconHelpcenter /> 帮助</div>
<template #overlay>
<Menu>
<MenuItem @click="openDoc()">开发文档</MenuItem>
<MenuItem @click="hotkeyDrawerVisible = true">快捷键</MenuItem>
</Menu>
</template>
</Dropdown>
</div>
<div class="right">
<Tooltip :mouseLeaveDelay="0" title="幻灯片放映">
<div class="menu-item" @click="enterScreening()">
<IconPpt size="18" fill="#666" style="margin-top: 2px;" />
</div>
</Tooltip>
<Tooltip :mouseLeaveDelay="0" title="Github 仓库">
<a href="https://github.com/pipipi-pikachu/PPTist" target="_blank">
<div class="menu-item"><IconGithub size="18" fill="#666" /></div>
</a>
</Tooltip>
</div>
<Drawer
width="320"
placement="right"
:visible="hotkeyDrawerVisible"
@close="hotkeyDrawerVisible = false"
>
<HotkeyDoc />
</Drawer>
</div>
</template>
<script lang="ts">
import { computed, defineComponent, ref } from 'vue'
import { MutationTypes, useStore } from '@/store'
import { createRandomCode } from '@/utils/common'
import useScreening from '@/hooks/useScreening'
import useSlideHandler from '@/hooks/useSlideHandler'
import useHistorySnapshot from '@/hooks/useHistorySnapshot'
import HotkeyDoc from './HotkeyDoc.vue'
import { message } from 'ant-design-vue'
export default defineComponent({
name: 'editor-header',
components: {
HotkeyDoc,
},
setup() {
const store = useStore()
const { enterScreening, enterScreeningFromStart } = useScreening()
const { createSlide, deleteSlide } = useSlideHandler()
const { redo, undo } = useHistorySnapshot()
const showGridLines = computed(() => store.state.showGridLines)
const toggleGridLines = () => {
store.commit(MutationTypes.SET_GRID_LINES_STATE, !showGridLines.value)
}
const resetSlides = () => {
store.commit(MutationTypes.SET_ACTIVE_ELEMENT_ID_LIST, [])
store.commit(MutationTypes.SET_SLIDES, [{
id: createRandomCode(),
elements: [],
}])
}
const openDoc = () => {
message.warning('作者努力编写中...')
}
const hotkeyDrawerVisible = ref(false)
return {
enterScreening,
enterScreeningFromStart,
createSlide,
deleteSlide,
redo,
undo,
toggleGridLines,
showGridLines,
resetSlides,
openDoc,
hotkeyDrawerVisible,
}
},
})
</script>
<style lang="scss" scoped>
.editor-header {
background-color: #fff;
user-select: none;
border-bottom: 1px solid $borderColor;
display: flex;
justify-content: space-between;
padding: 0 10px;
}
.left, .right {
display: flex;
justify-content: center;
align-items: center;
}
.menu-item {
font-size: 13px;
margin: 0 10px;
cursor: pointer;
}
</style>