Przeglądaj źródła

添加快捷键提示

pipipi-pikachu 5 lat temu
rodzic
commit
797cf96349
2 zmienionych plików z 117 dodań i 4 usunięć
  1. 2 0
      src/main.ts
  2. 115 4
      src/views/Editor/EditorHeader/index.vue

+ 2 - 0
src/main.ts

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

+ 115 - 4
src/views/Editor/EditorHeader/index.vue

@@ -27,9 +27,8 @@
         <div class="menu-item"><IconHelpcenter /> 帮助</div>
         <template #overlay>
           <Menu>
-            <MenuItem>开发文档</MenuItem>
-            <MenuItem>常见使用问题</MenuItem>
-            <MenuItem>快捷键</MenuItem>
+            <MenuItem @click="openDoc()">开发文档</MenuItem>
+            <MenuItem @click="hotkeyDrawerVisible = true">快捷键</MenuItem>
           </Menu>
         </template>
       </Dropdown>
@@ -45,17 +44,97 @@
         <div class="menu-item"><IconGithub size="18" fill="#666" /></div>
       </Tooltip>
     </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>
 </template>
 
 <script lang="ts">
-import { computed, defineComponent } from 'vue'
+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 { 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({
   name: 'editor-header',
   setup() {
@@ -77,6 +156,12 @@ export default defineComponent({
       }])
     }
 
+    const openDoc = () => {
+      message.warning('作者努力编写中...')
+    }
+
+    const hotkeyDrawerVisible = ref(false)
+
     return {
       enterScreening,
       enterScreeningFromStart,
@@ -87,6 +172,9 @@ export default defineComponent({
       toggleGridLines,
       showGridLines,
       resetSlides,
+      openDoc,
+      hotkeyDrawerVisible,
+      hotkeys,
     }
   },
 })
@@ -111,4 +199,27 @@ export default defineComponent({
   margin: 0 10px;
   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>