feat: 文件管理增加使用 VS Code 打开 (#5572)

pull/5581/head
BugKing 2024-06-27 10:49:47 +08:00 committed by GitHub
parent 2fafe3dcb5
commit 4482bc0b1d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 114 additions and 0 deletions

View File

@ -0,0 +1,97 @@
<template>
<div>
<el-dialog
v-model="dialogVisible"
:title="$t('app.checkTitle')"
width="30%"
:close-on-click-modal="false"
:destroy-on-close="true"
>
<el-row>
<el-col :span="22" :offset="1">
<el-alert :closable="false" :title="$t('file.vscodeHelper')" type="info"></el-alert>
<el-form
ref="vscodeConnectInfoForm"
label-position="top"
:model="addForm"
label-width="100px"
class="mt-4"
>
<el-form-item :label="$t('setting.systemIP')" prop="host">
<el-input v-model="addForm.host" />
</el-form-item>
<el-form-item :label="$t('commons.table.port')" prop="port">
<el-input v-model="addForm.port" />
</el-form-item>
<el-form-item :label="$t('commons.login.username')" prop="username">
<el-input v-model="addForm.username" />
</el-form-item>
</el-form>
</el-col>
</el-row>
<template #footer>
<span class="dialog-footer">
<el-button @click="handleClose">{{ $t('commons.button.cancel') }}</el-button>
<el-button type="primary" @click="submit(vscodeConnectInfoForm)">
{{ $t('commons.button.confirm') }}
</el-button>
</span>
</template>
</el-dialog>
</div>
</template>
<script lang="ts" setup>
import { reactive, ref } from 'vue';
import { FormInstance } from 'element-plus';
const dialogVisible = ref();
interface DialogProps {
path: string;
}
const vscodeConnectInfoForm = ref<FormInstance>();
const addForm = reactive({
host: '',
port: 22,
username: 'root',
path: '',
});
const em = defineEmits(['close']);
const handleClose = () => {
dialogVisible.value = false;
if (vscodeConnectInfoForm.value) {
vscodeConnectInfoForm.value.resetFields();
}
em('close', false);
};
const submit = async (formEl: FormInstance | undefined) => {
if (!formEl) return;
await formEl.validate((valid) => {
if (!valid) {
return;
}
localStorage.setItem('VscodeConnctInfo', JSON.stringify(addForm));
dialogVisible.value = false;
window.open(
`vscode://vscode-remote/ssh-remote+${addForm.username}@${addForm.host}${addForm.path}?windowId=_blank`,
);
});
};
const acceptParams = async (params: DialogProps): Promise<void> => {
if (localStorage.getItem('VscodeConnctInfo')) {
addForm.host = JSON.parse(localStorage.getItem('VscodeConnctInfo')).host;
addForm.port = JSON.parse(localStorage.getItem('VscodeConnctInfo')).port;
addForm.username = JSON.parse(localStorage.getItem('VscodeConnctInfo')).username;
window.open(
`vscode://vscode-remote/ssh-remote+${addForm.username}@${addForm.host}${params.path}?windowId=_blank`,
);
} else {
addForm.path = params.path;
dialogVisible.value = true;
}
};
defineExpose({ acceptParams });
</script>

View File

@ -1217,6 +1217,8 @@ const message = {
back: 'Back',
top: 'Go Back',
refresh: 'Refresh',
openWithVscode: 'Open with VS Code',
vscodeHelper: 'Please make sure that VS Code is installed locally and the SSH Remote plugin is configured',
},
ssh: {
autoStart: 'Auto Start',

View File

@ -1155,6 +1155,8 @@ const message = {
back: '退',
top: '',
refresh: '',
openWithVscode: 'VS Code ',
vscodeHelper: ' VS Code SSH Remote ',
},
ssh: {
autoStart: '',

View File

@ -1157,6 +1157,8 @@ const message = {
back: '退',
top: '',
refresh: '',
openWithVscode: 'VS Code ',
vscodeHelper: ' VS Code SSH Remote ',
},
ssh: {
autoStart: '',

View File

@ -306,6 +306,7 @@
<RecycleBin ref="recycleBinRef" @close="search" />
<Favorite ref="favoriteRef" @close="search" />
<BatchRole ref="batchRoleRef" @close="search" />
<VscodeOpenDialog ref="dialogVscodeOpenRef" />
</LayoutContent>
</div>
</template>
@ -349,6 +350,7 @@ import Detail from './detail/index.vue';
import RecycleBin from './recycle-bin/index.vue';
import Favorite from './favorite/index.vue';
import BatchRole from './batch-role/index.vue';
import VscodeOpenDialog from '@/components/vscode-open/index.vue';
const globalStore = GlobalStore();
@ -413,6 +415,7 @@ const favoriteRef = ref();
const hoveredRowIndex = ref(-1);
const favorites = ref([]);
const batchRoleRef = ref();
const dialogVscodeOpenRef = ref();
// editablePath
const { searchableStatus, searchablePath, searchableInputRef, searchableInputBlur } = useSearchable(paths);
@ -846,6 +849,10 @@ const toTerminal = () => {
router.push({ path: '/hosts/terminal', query: { path: req.path } });
};
const openWithVSCode = (row: File.File) => {
dialogVscodeOpenRef.value.acceptParams({ path: row.path + (row.isDir ? '' : ':1:1') });
};
const buttons = [
{
label: i18n.global.t('file.open'),
@ -898,6 +905,10 @@ const buttons = [
label: i18n.global.t('file.info'),
click: openDetail,
},
{
label: i18n.global.t('file.openWithVscode'),
click: openWithVSCode,
},
];
onMounted(() => {