Add window pinning

This commit is contained in:
2025-05-12 19:59:40 +08:00
parent 0710f0c9b0
commit e0b9a376cb
11 changed files with 1183 additions and 138 deletions

View File

@@ -3,9 +3,9 @@ import {useEditorStore} from '@/stores/editorStore';
import {useConfigStore} from '@/stores/configStore';
import {useLogStore} from '@/stores/logStore';
import { useI18n } from 'vue-i18n';
import { ref } from 'vue';
import { ref, onMounted, watch } from 'vue';
import {SUPPORTED_LOCALES, setLocale, SupportedLocaleType} from '@/i18n';
import * as wails from '@wailsio/runtime';
const editorStore = useEditorStore();
const configStore = useConfigStore();
const logStore = useLogStore();
@@ -25,8 +25,39 @@ const toggleLanguageMenu = () => {
showLanguageMenu.value = !showLanguageMenu.value;
};
// 窗口置顶控制
const toggleAlwaysOnTop = () => {
configStore.toggleAlwaysOnTop();
// 使用Window.SetAlwaysOnTop方法设置窗口置顶状态
try {
wails.Window.SetAlwaysOnTop(configStore.config.alwaysOnTop);
} catch (error) {
console.error('Failed to set window always on top:', error);
logStore.error(t('config.alwaysOnTopFailed'));
}
};
// 在组件挂载时根据配置设置窗口置顶状态
onMounted(() => {
if (configStore.configLoaded && configStore.config.alwaysOnTop) {
try {
wails.Window.SetAlwaysOnTop(true);
} catch (error) {
console.error('Failed to set window always on top:', error);
}
}
});
// 监听配置加载完成,加载后检查并设置窗口置顶状态
watch(() => configStore.configLoaded, (isLoaded) => {
if (isLoaded && configStore.config.alwaysOnTop) {
try {
wails.Window.SetAlwaysOnTop(true);
} catch (error) {
console.error('Failed to set window always on top:', error);
}
}
});
</script>
<template>
@@ -64,6 +95,12 @@ const toggleLanguageMenu = () => {
<button class="tab-btn" @click="configStore.increaseTabSize" :disabled="configStore.config.tabSize >= configStore.MAX_TAB_SIZE">+</button>
</span>
</span>
<!-- 窗口置顶选择框 -->
<label class="always-on-top-toggle" :title="t('toolbar.alwaysOnTop')">
<input type="checkbox" :checked="configStore.config.alwaysOnTop" @change="toggleAlwaysOnTop" />
<span>{{ t('toolbar.alwaysOnTop') }}</span>
</label>
<!-- 语言切换按钮 -->
<div class="selector-dropdown">
@@ -203,6 +240,24 @@ const toggleLanguageMenu = () => {
}
}
/* 窗口置顶选择框样式 */
.always-on-top-toggle {
display: flex;
align-items: center;
gap: 3px;
cursor: pointer;
color: var(--text-muted);
font-size: 11px;
input {
cursor: pointer;
}
&:hover {
color: var(--text-primary);
}
}
/* 通用下拉选择器样式 */
.selector-dropdown {
position: relative;

View File

@@ -13,7 +13,8 @@ export default {
tab: 'Tab'
},
encoding: 'UTF-8',
settings: 'Settings'
settings: 'Settings',
alwaysOnTop: 'Always on Top'
},
config: {
loadSuccess: 'Configuration loaded successfully',
@@ -24,7 +25,8 @@ export default {
resetFailed: 'Failed to reset configuration',
fontSizeFixed: 'Font size ({value}) has been corrected to {fixed}',
tabSizeFixed: 'Tab size ({value}) has been corrected to {fixed}',
tabTypeFixed: 'Tab type ({value}) is invalid, corrected to spaces'
tabTypeFixed: 'Tab type ({value}) is invalid, corrected to spaces',
alwaysOnTopFailed: 'Failed to set window always on top'
},
languages: {
'zh-CN': '简体中文',

View File

@@ -13,7 +13,8 @@ export default {
tab: '制表符'
},
encoding: 'UTF-8',
settings: '设置'
settings: '设置',
alwaysOnTop: '窗口置顶'
},
config: {
loadSuccess: '配置加载成功',
@@ -24,7 +25,8 @@ export default {
resetFailed: '重置配置失败',
fontSizeFixed: '字体大小值({value})已被修正为{fixed}',
tabSizeFixed: 'Tab大小值({value})已被修正为{fixed}',
tabTypeFixed: 'Tab类型({value})不合法,已修正为空格'
tabTypeFixed: 'Tab类型({value})不合法,已修正为空格',
alwaysOnTopFailed: '无法设置窗口置顶状态'
},
languages: {
'zh-CN': '简体中文',

View File

@@ -158,6 +158,11 @@ export const useConfigStore = defineStore('config', () => {
: TabType.TabTypeSpaces;
}
// 切换窗口置顶状态
function toggleAlwaysOnTop() {
updateConfig('alwaysOnTop', val => !val);
}
// 重置为默认配置
async function resetToDefaults() {
try {
@@ -197,6 +202,9 @@ export const useConfigStore = defineStore('config', () => {
toggleTabIndent: () => updateConfig('enableTabIndent', val => !val),
increaseTabSize: () => adjustTabSize(1),
decreaseTabSize: () => adjustTabSize(-1),
toggleTabType
toggleTabType,
// 窗口置顶操作
toggleAlwaysOnTop
};
});