Skip to content

Commit

Permalink
feat: update trigger of dropdown (doocs#349)
Browse files Browse the repository at this point in the history
  • Loading branch information
YangFong authored Aug 24, 2024
1 parent 43c63f7 commit 3ebceb8
Show file tree
Hide file tree
Showing 6 changed files with 145 additions and 48 deletions.
7 changes: 5 additions & 2 deletions src/App.vue
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,11 @@ body,
padding: 0;
}
// 抵消下拉菜单开启时带来的样式
body {
pointer-events: initial !important;
}
::-webkit-scrollbar {
width: 6px;
height: 6px;
Expand Down Expand Up @@ -78,6 +83,4 @@ body,
.el-icon.el-color-picker__icon.is-icon-arrow-down {
position: absolute;
}
</style>
19 changes: 13 additions & 6 deletions src/components/CodemirrorEditor/EditorHeader/EditDropdown.vue
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ import {
import { useStore } from '@/stores'
const props = defineProps([`isOpen`, `clickTrigger`, `openDropdown`, `updateOpen`])
const store = useStore()
const {
Expand All @@ -17,14 +19,19 @@ const {
</script>

<template>
<DropdownMenu>
<DropdownMenuTrigger class="flex items-center">
<DropdownMenu :open="props.isOpen" @update:open="props.updateOpen">
<DropdownMenuTrigger
class="flex items-center p-2 px-4 hover:bg-gray-2 dark:hover:bg-stone-9"
:class="{
'bg-gray-2': props.isOpen,
'dark:bg-stone-9': props.isOpen,
}"
@click="props.clickTrigger()"
@mouseenter="props.openDropdown()"
>
编辑
<el-icon class="ml-2">
<ElIconArrowDown />
</el-icon>
</DropdownMenuTrigger>
<DropdownMenuContent>
<DropdownMenuContent align="start">
<DropdownMenuItem @click="toggleShowUploadImgDialog()">
<el-icon class="mr-2 h-4 w-4">
<ElIconUpload />
Expand Down
19 changes: 13 additions & 6 deletions src/components/CodemirrorEditor/EditorHeader/FileDropdown.vue
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ import {
import { useStore } from '@/stores'
const props = defineProps([`isOpen`, `clickTrigger`, `openDropdown`, `updateOpen`])
const store = useStore()
const {
Expand All @@ -28,14 +30,19 @@ const {
</script>

<template>
<DropdownMenu>
<DropdownMenuTrigger class="flex items-center">
<DropdownMenu :open="props.isOpen" @update:open="props.updateOpen">
<DropdownMenuTrigger
class="flex items-center p-2 px-4 hover:bg-gray-2 dark:hover:bg-stone-9"
:class="{
'bg-gray-2': props.isOpen,
'dark:bg-stone-9': props.isOpen,
}"
@click="props.clickTrigger()"
@mouseenter="props.openDropdown()"
>
文件
<el-icon class="ml-2">
<ElIconArrowDown />
</el-icon>
</DropdownMenuTrigger>
<DropdownMenuContent>
<DropdownMenuContent align="start">
<DropdownMenuItem @click="importMarkdownContent()">
<el-icon class="mr-2 h-4 w-4">
<ElIconUpload />
Expand Down
19 changes: 13 additions & 6 deletions src/components/CodemirrorEditor/EditorHeader/HelpDropdown.vue
Original file line number Diff line number Diff line change
Expand Up @@ -10,18 +10,25 @@ import {
DropdownMenuTrigger,
} from '@/components/ui/dropdown-menu'
const props = defineProps([`isOpen`, `clickTrigger`, `openDropdown`, `updateOpen`])
const aboutDialogVisible = ref(false)
</script>

<template>
<DropdownMenu>
<DropdownMenuTrigger class="flex items-center">
<DropdownMenu :open="props.isOpen" @update:open="props.updateOpen">
<DropdownMenuTrigger
class="flex items-center p-2 px-4 hover:bg-gray-2 dark:hover:bg-stone-9"
:class="{
'bg-gray-2': props.isOpen,
'dark:bg-stone-9': props.isOpen,
}"
@click="props.clickTrigger()"
@mouseenter="props.openDropdown()"
>
帮助
<el-icon class="ml-2">
<ElIconArrowDown />
</el-icon>
</DropdownMenuTrigger>
<DropdownMenuContent>
<DropdownMenuContent align="start">
<DropdownMenuItem @click="aboutDialogVisible = true">
<el-icon class="mr-2 h-4 w-4" />
<span>关于</span>
Expand Down
19 changes: 13 additions & 6 deletions src/components/CodemirrorEditor/EditorHeader/StyleDropdown.vue
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ import {
import { codeBlockThemeOptions, colorOptions, fontFamilyOptions, fontSizeOptions, legendOptions, themeOptions } from '@/config'
import { useStore } from '@/stores'
const props = defineProps([`isOpen`, `clickTrigger`, `openDropdown`, `updateOpen`])
const store = useStore()
const {
Expand Down Expand Up @@ -67,14 +69,19 @@ function customStyle() {
</script>

<template>
<DropdownMenu>
<DropdownMenuTrigger class="flex items-center">
<DropdownMenu :open="props.isOpen" @update:open="props.updateOpen">
<DropdownMenuTrigger
class="flex items-center p-2 px-4 hover:bg-gray-2 dark:hover:bg-stone-9"
:class="{
'bg-gray-2': props.isOpen,
'dark:bg-stone-9': props.isOpen,
}"
@click="props.clickTrigger()"
@mouseenter="props.openDropdown()"
>
样式
<el-icon class="ml-2">
<ElIconArrowDown />
</el-icon>
</DropdownMenuTrigger>
<DropdownMenuContent class="w-56">
<DropdownMenuContent class="w-56" align="start">
<StyleOptionMenu title="主题" :options="themeOptions" :current="theme" :change="themeChanged" />
<DropdownMenuSeparator />
<StyleOptionMenu title="字体" :options="fontFamilyOptions" :current="fontFamily" :change="fontChanged" />
Expand Down
110 changes: 88 additions & 22 deletions src/components/CodemirrorEditor/EditorHeader/index.vue
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
<script setup>
import { nextTick } from 'vue'
import { nextTick, reactive, ref } from 'vue'
import { storeToRefs } from 'pinia'
import { ElNotification } from 'element-plus'
import CodeMirror from 'codemirror'
import { Command } from 'lucide-vue-next'
import PostInfo from './PostInfo.vue'
import FileDropdown from './FileDropdown.vue'
Expand Down Expand Up @@ -32,35 +33,38 @@ const defaultKeyMap = CodeMirror.keyMap.default
const modPrefix
= defaultKeyMap === CodeMirror.keyMap.macDefault ? `Cmd` : `Ctrl`
const kbdIcon
= defaultKeyMap === CodeMirror.keyMap.macDefault ? `` : `Ctrl`
const formatItems = [
{
label: `加粗`,
kbd: `${modPrefix} + B`,
kbd: [kbdIcon, `B`],
emitArgs: [`addFormat`, `${modPrefix}-B`],
},
{
label: `斜体`,
kbd: `${modPrefix} + I`,
kbd: [kbdIcon, `I`],
emitArgs: [`addFormat`, `${modPrefix}-I`],
},
{
label: `删除线`,
kbd: `${modPrefix} + D`,
kbd: [kbdIcon, `D`],
emitArgs: [`addFormat`, `${modPrefix}-D`],
},
{
label: `超链接`,
kbd: `${modPrefix} + K`,
kbd: [kbdIcon, `K`],
emitArgs: [`addFormat`, `${modPrefix}-K`],
},
{
label: `行内代码`,
kbd: `${modPrefix} + E`,
kbd: [kbdIcon, `E`],
emitArgs: [`addFormat`, `${modPrefix}-E`],
},
{
label: `格式化`,
kbd: `${modPrefix} + F`,
kbd: [kbdIcon, `F`],
emitArgs: [`formatContent`],
},
]
Expand Down Expand Up @@ -153,40 +157,89 @@ function copy() {
})
}, 350)
}
const isClickTrigger = ref(false)
const isOpenList = reactive(Array.from({ length: 5 }).fill(false))
function clickTrigger() {
isClickTrigger.value = !isClickTrigger.value
}
function openDropdown(index) {
return () => {
isOpenList.fill(false)
isOpenList[index] = true
}
}
function updateOpen(isOpen) {
if (!isOpen) {
isOpenList.fill(false)
isClickTrigger.value = false
}
}
</script>

<template>
<div class="header-container">
<el-space class="dropdowns flex-auto" size="large">
<FileDropdown />
<DropdownMenu>
<DropdownMenuTrigger class="flex items-center">
<div class="dropdowns flex flex-auto">
<FileDropdown
:is-open="isClickTrigger && isOpenList[0]"
:click-trigger="clickTrigger"
:open-dropdown="openDropdown(0)"
:update-open="updateOpen"
/>

<DropdownMenu :open="isClickTrigger && isOpenList[1]" @update:open="updateOpen">
<DropdownMenuTrigger
class="flex items-center p-2 px-4 hover:bg-gray-2 dark:hover:bg-stone-9"
:class="{
'bg-gray-2': isOpenList[1],
'dark:bg-stone-9': isOpenList[1],
}"
@click="clickTrigger()"
@mouseenter="openDropdown(1)()"
>
格式
<el-icon class="ml-2">
<ElIconArrowDown />
</el-icon>
</DropdownMenuTrigger>
<DropdownMenuContent class="w-60">
<DropdownMenuItem v-for="{ label, kbd, emitArgs } in formatItems" :key="kbd" @click="$emit(...emitArgs)">
<DropdownMenuContent class="w-60" align="start">
<DropdownMenuItem v-for="{ label, kbd, emitArgs } in formatItems" :key="kbd" @click="$emit(...emitArgs);">
<el-icon class="mr-2 h-4 w-4" />
{{ label }}
<DropdownMenuShortcut>
{{ kbd }}
<kbd v-for="item in kbd" :key="item" class="mx-1 bg-gray-2 dark:bg-stone-9">
{{ item }}
</kbd>
</DropdownMenuShortcut>
</DropdownMenuItem>
<DropdownMenuSeparator />
<DropdownMenuItem @click="citeStatusChanged">
<DropdownMenuItem @click="citeStatusChanged()">
<el-icon class="mr-2 h-4 w-4" :class="{ 'opacity-0': !isCiteStatus }">
<ElIconCheck />
</el-icon>
微信外链转底部引用
</DropdownMenuItem>
</DropdownMenuContent>
</DropdownMenu>
<EditDropdown />
<StyleDropdown />
<HelpDropdown />
</el-space>
<EditDropdown
:is-open="isClickTrigger && isOpenList[2]"
:click-trigger="clickTrigger"
:open-dropdown="openDropdown(2)"
:update-open="updateOpen"
/>
<StyleDropdown

:is-open="isClickTrigger && isOpenList[3]"
:click-trigger="clickTrigger"
:open-dropdown="openDropdown(3)"
:update-open="updateOpen"
/>
<HelpDropdown
:is-open="isClickTrigger && isOpenList[4]"
:click-trigger="clickTrigger"
:open-dropdown="openDropdown(4)"
:update-open="updateOpen"
/>
</div>
<el-button plain type="primary" @click="copy">
复制
</el-button>
Expand All @@ -202,4 +255,17 @@ function copy() {
height: 100%;
padding: 0 20px;
}
.dropdowns {
user-select: none;
}
kbd {
display: inline-flex;
justify-content: center;
align-items: center;
border: 1px solid #a8a8a8;
padding: 1px 4px;
border-radius: 2px;
}
</style>

0 comments on commit 3ebceb8

Please sign in to comment.