添加快捷键提示

This commit is contained in:
pipipi-pikachu 2021-01-31 17:17:32 +08:00
parent 55a5c5fa16
commit 797cf96349
2 changed files with 117 additions and 4 deletions

View File

@ -35,6 +35,7 @@ import {
Dropdown, Dropdown,
Menu, Menu,
Checkbox, Checkbox,
Drawer,
} from 'ant-design-vue' } from 'ant-design-vue'
const app = createApp(App) const app = createApp(App)
@ -60,6 +61,7 @@ app.component('Dropdown', Dropdown)
app.component('Menu', Menu) app.component('Menu', Menu)
app.component('MenuItem', Menu.Item) app.component('MenuItem', Menu.Item)
app.component('Checkbox', Checkbox) app.component('Checkbox', Checkbox)
app.component('Drawer', Drawer)
app.directive('contextmenu', Contextmenu) app.directive('contextmenu', Contextmenu)
app.directive('click-outside', ClickOutside) app.directive('click-outside', ClickOutside)

View File

@ -27,9 +27,8 @@
<div class="menu-item"><IconHelpcenter /> 帮助</div> <div class="menu-item"><IconHelpcenter /> 帮助</div>
<template #overlay> <template #overlay>
<Menu> <Menu>
<MenuItem>开发文档</MenuItem> <MenuItem @click="openDoc()">开发文档</MenuItem>
<MenuItem>常见使用问题</MenuItem> <MenuItem @click="hotkeyDrawerVisible = true">快捷键</MenuItem>
<MenuItem>快捷键</MenuItem>
</Menu> </Menu>
</template> </template>
</Dropdown> </Dropdown>
@ -45,17 +44,97 @@
<div class="menu-item"><IconGithub size="18" fill="#666" /></div> <div class="menu-item"><IconGithub size="18" fill="#666" /></div>
</Tooltip> </Tooltip>
</div> </div>
<Drawer
width="300"
placement="right"
:visible="hotkeyDrawerVisible"
@close="hotkeyDrawerVisible = false"
>
<div class="hotkeys">
<template v-for="item in hotkeys" :key="item.type">
<div class="title">{{item.type}}</div>
<div class="hotkey-item" v-for="hotkey in item.children" :key="hotkey.label">
<div class="label">{{hotkey.label}}</div>
<div class="value">{{hotkey.value}}</div>
</div>
</template>
</div>
</Drawer>
</div> </div>
</template> </template>
<script lang="ts"> <script lang="ts">
import { computed, defineComponent } from 'vue' import { computed, defineComponent, ref } from 'vue'
import { MutationTypes, useStore } from '@/store' import { MutationTypes, useStore } from '@/store'
import { createRandomCode } from '@/utils/common' import { createRandomCode } from '@/utils/common'
import useScreening from '@/hooks/useScreening' import useScreening from '@/hooks/useScreening'
import useSlideHandler from '@/hooks/useSlideHandler' import useSlideHandler from '@/hooks/useSlideHandler'
import useHistorySnapshot from '@/hooks/useHistorySnapshot' import useHistorySnapshot from '@/hooks/useHistorySnapshot'
import { message } from 'ant-design-vue'
const hotkeys = [
{
type: '通用',
children: [
{ label: '剪切', value: 'Ctrl + X' },
{ label: '复制', value: 'Ctrl + C' },
{ label: '粘贴', value: 'Ctrl + V' },
{ label: '快速复制粘贴', value: 'Ctrl + D' },
{ label: '全选', value: 'Ctrl + A' },
{ label: '撤销', value: 'Ctrl + Z' },
{ label: '恢复', value: 'Ctrl + Y' },
{ label: '删除', value: 'Delete' },
],
},
{
type: '选中元素操作',
children: [
{ label: '移动', value: '↑ / ← / ↓ / →' },
{ label: '锁定', value: 'Ctrl + L' },
{ label: '组合', value: 'Ctrl + G' },
{ label: '取消组合', value: 'Ctrl + Shift + G' },
],
},
{
type: '幻灯片编辑',
children: [
{ label: '新建幻灯片', value: 'Enter' },
{ label: '缩放画布', value: 'Ctrl + 鼠标滚动' },
{ label: '放大画布', value: 'Ctrl + =' },
{ label: '缩小画布', value: 'Ctrl + -' },
{ label: '缩放画布到合适大小', value: 'Ctrl + 0' },
{ label: '编辑上一页', value: '↑ / ←' },
{ label: '编辑下一页', value: '↓ / →' },
],
},
{
type: '表格编辑',
children: [
{ label: '聚焦到下一个单元格', value: 'Tab' },
],
},
{
type: '文本编辑',
children: [
{ label: '加粗', value: 'Ctrl + B' },
{ label: '斜体', value: 'Ctrl + I' },
{ label: '下划线', value: 'Ctrl + U' },
{ label: '删除线', value: 'Ctrl + D' },
],
},
{
type: '幻灯片放映',
children: [
{ label: '开始放映幻灯片', value: 'Ctrl + F' },
{ label: '切换上一页', value: '↑ / ←' },
{ label: '切换下一页', value: '↓ / →' },
{ label: '退出放映', value: 'ESC' },
],
},
]
export default defineComponent({ export default defineComponent({
name: 'editor-header', name: 'editor-header',
setup() { setup() {
@ -77,6 +156,12 @@ export default defineComponent({
}]) }])
} }
const openDoc = () => {
message.warning('作者努力编写中...')
}
const hotkeyDrawerVisible = ref(false)
return { return {
enterScreening, enterScreening,
enterScreeningFromStart, enterScreeningFromStart,
@ -87,6 +172,9 @@ export default defineComponent({
toggleGridLines, toggleGridLines,
showGridLines, showGridLines,
resetSlides, resetSlides,
openDoc,
hotkeyDrawerVisible,
hotkeys,
} }
}, },
}) })
@ -111,4 +199,27 @@ export default defineComponent({
margin: 0 10px; margin: 0 10px;
cursor: pointer; cursor: pointer;
} }
.hotkeys {
height: 100%;
overflow: auto;
font-size: 12px;
}
.title {
font-size: 14px;
font-weight: 700;
border-bottom: 1px solid #e5e5e5;
padding: 15px 0 5px 0;
}
.hotkey-item {
border-bottom: 1px solid #e5e5e5;
padding: 15px 0 5px 0;
display: flex;
align-items: center;
}
.label {
width: 150px;
@include ellipsis();
}
</style> </style>