feat: 指令菜单功能 (#1407)

* feat: 指令菜单功能

* 增加快捷指令功能

* 废弃jwt结构StandardClaims替换为RegisteredClaims #1409

* 调整快捷指令登出操作

---------

Co-authored-by: krank <emosick@qq.com>
This commit is contained in:
奇淼(piexlmax
2023-04-08 15:37:22 +08:00
committed by GitHub
parent 6ad7ccdd6e
commit 5f0402043a
10 changed files with 269 additions and 92 deletions

View File

@@ -62,6 +62,16 @@
</span>
</el-dropdown-item>
</template>
<el-dropdown-item icon="avatar">
<div class="command-box" style="display: flex" @click="handleCommand">
<div>指令菜单</div>
<div style="margin-left: 8px">
<span class="button">{{ first }}</span>
+
<span class="button">K</span>
</div>
</div>
</el-dropdown-item>
<el-dropdown-item icon="avatar" @click="toPerson">个人信息</el-dropdown-item>
<el-dropdown-item icon="reading-lamp" @click="userStore.LoginOut"> </el-dropdown-item>
</el-dropdown-menu>
@@ -96,6 +106,7 @@
</router-view>
<BottomInfo />
<setting />
<CommandMenu ref="command"/>
</el-main>
</el-container>
@@ -114,6 +125,7 @@ import HistoryComponent from '@/view/layout/aside/historyComponent/history.vue'
import Search from '@/view/layout/search/search.vue'
import BottomInfo from '@/view/layout/bottomInfo/bottomInfo.vue'
import CustomPic from '@/components/customPic/index.vue'
import CommandMenu from '@/components/commandMenu/index.vue'
import Setting from './setting/index.vue'
import { setUserAuthority } from '@/api/user'
import { emitter } from '@/utils/bus.js'
@@ -131,8 +143,26 @@ const isCollapse = ref(false)
const isSider = ref(true)
const isMobile = ref(false)
const first = ref('')
const dialogVisible = ref(false)
const initPage = () => {
const screenWidth = document.body.clientWidth
// 判断当前用户的操作系统
if(window.localStorage.getItem('osType') === 'WIN') {
first.value = 'Ctrl'
} else {
first.value = '⌘'
}
// 当用户同时按下ctrl和k键的时候
const handleKeyDown = (e) => {
if (e.ctrlKey && e.key === 'k') {
// 阻止浏览器默认事件
e.preventDefault();
handleCommand()
}
}
window.addEventListener('keydown', handleKeyDown);
const screenWidth = document.body.clientWidth
if (screenWidth < 1000) {
isMobile.value = true
isSider.value = false
@@ -150,6 +180,11 @@ const initPage = () => {
initPage()
const command = ref()
const handleCommand = () => {
command.value.open()
}
const loadingFlag = ref(false)
onMounted(() => {
// 挂载一些通用的事件
@@ -246,4 +281,20 @@ const changeShadow = () => {
<style lang="scss">
@import '@/style/mobile.scss';
.button {
font-size: 12px;
color: #666;
background: rgb(250,250,250);
width: 25px!important;
padding: 4px 8px !important;
border: 1px solid #eaeaea;
margin-right: 4px;
border-radius: 4px;
}
:deep .el-overlay {
background-color: hsla(0,0%,100%,.9) !important;
}
.command-box{
}
</style>