fdb2 1.0.6 → 1.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.vscodeignore +45 -0
- package/README.md +24 -85
- package/dist/package.json +115 -0
- package/dist/pnpm-lock.yaml +7447 -0
- package/dist/public/explorer.css +244 -111
- package/dist/public/explorer.js +523 -278
- package/dist/scripts/preinstall.js +112 -0
- package/dist/server/index.d.ts.map +1 -1
- package/dist/server/index.js +4 -9
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.ts +5 -10
- package/dist/server/service/connection.service.d.ts.map +1 -1
- package/dist/server/service/connection.service.js +1 -0
- package/dist/server/service/connection.service.js.map +1 -1
- package/dist/server/service/connection.service.ts +1 -0
- package/dist/server/service/database/base.service.d.ts +4 -0
- package/dist/server/service/database/base.service.d.ts.map +1 -1
- package/dist/server/service/database/base.service.js +3 -3
- package/dist/server/service/database/base.service.js.map +1 -1
- package/dist/server/service/database/base.service.ts +8 -3
- package/dist/server/service/database/cockroachdb.service.d.ts +5 -0
- package/dist/server/service/database/cockroachdb.service.d.ts.map +1 -1
- package/dist/server/service/database/cockroachdb.service.js +112 -0
- package/dist/server/service/database/cockroachdb.service.js.map +1 -1
- package/dist/server/service/database/cockroachdb.service.ts +123 -0
- package/dist/server/service/database/database.service.d.ts +4 -0
- package/dist/server/service/database/database.service.d.ts.map +1 -1
- package/dist/server/service/database/database.service.js +8 -0
- package/dist/server/service/database/database.service.js.map +1 -1
- package/dist/server/service/database/database.service.ts +9 -0
- package/dist/server/service/database/mongodb.service.d.ts +6 -0
- package/dist/server/service/database/mongodb.service.d.ts.map +1 -1
- package/dist/server/service/database/mongodb.service.js +8 -0
- package/dist/server/service/database/mongodb.service.js.map +1 -1
- package/dist/server/service/database/mongodb.service.ts +9 -0
- package/dist/server/service/database/mssql.service.d.ts +4 -0
- package/dist/server/service/database/mssql.service.d.ts.map +1 -1
- package/dist/server/service/database/mssql.service.js +105 -0
- package/dist/server/service/database/mssql.service.js.map +1 -1
- package/dist/server/service/database/mssql.service.ts +118 -0
- package/dist/server/service/database/mysql.service.d.ts +4 -0
- package/dist/server/service/database/mysql.service.d.ts.map +1 -1
- package/dist/server/service/database/mysql.service.js +116 -0
- package/dist/server/service/database/mysql.service.js.map +1 -1
- package/dist/server/service/database/mysql.service.ts +130 -0
- package/dist/server/service/database/oracle.service.d.ts +4 -0
- package/dist/server/service/database/oracle.service.d.ts.map +1 -1
- package/dist/server/service/database/oracle.service.js +114 -0
- package/dist/server/service/database/oracle.service.js.map +1 -1
- package/dist/server/service/database/oracle.service.ts +128 -0
- package/dist/server/service/database/postgres.service.d.ts +4 -0
- package/dist/server/service/database/postgres.service.d.ts.map +1 -1
- package/dist/server/service/database/postgres.service.js +120 -0
- package/dist/server/service/database/postgres.service.js.map +1 -1
- package/dist/server/service/database/postgres.service.ts +131 -0
- package/dist/server/service/database/sap.service.d.ts +4 -0
- package/dist/server/service/database/sap.service.d.ts.map +1 -1
- package/dist/server/service/database/sap.service.js +107 -0
- package/dist/server/service/database/sap.service.js.map +1 -1
- package/dist/server/service/database/sap.service.ts +120 -0
- package/dist/server/service/database/sqlite.service.d.ts +5 -0
- package/dist/server/service/database/sqlite.service.d.ts.map +1 -1
- package/dist/server/service/database/sqlite.service.js +133 -0
- package/dist/server/service/database/sqlite.service.js.map +1 -1
- package/dist/server/service/database/sqlite.service.ts +150 -0
- package/fdb2.server.pid +1 -0
- package/package.json +18 -9
- package/packages/vscode/.vscodeignore +44 -0
- package/packages/vscode/README.md +62 -0
- package/packages/vscode/out/database-services/base.service.js +236 -0
- package/packages/vscode/out/database-services/base.service.js.map +1 -0
- package/packages/vscode/out/database-services/cockroachdb.service.js +634 -0
- package/packages/vscode/out/database-services/cockroachdb.service.js.map +1 -0
- package/packages/vscode/out/database-services/connection.service.js +346 -0
- package/packages/vscode/out/database-services/connection.service.js.map +1 -0
- package/packages/vscode/out/database-services/database.service.js +571 -0
- package/packages/vscode/out/database-services/database.service.js.map +1 -0
- package/packages/vscode/out/database-services/index.js +18 -0
- package/packages/vscode/out/database-services/index.js.map +1 -0
- package/packages/vscode/out/database-services/model/connection.entity.js +11 -0
- package/packages/vscode/out/database-services/model/connection.entity.js.map +1 -0
- package/packages/vscode/out/database-services/model/database.entity.js +35 -0
- package/packages/vscode/out/database-services/model/database.entity.js.map +1 -0
- package/packages/vscode/out/database-services/mongodb.service.js +458 -0
- package/packages/vscode/out/database-services/mongodb.service.js.map +1 -0
- package/packages/vscode/out/database-services/mssql.service.js +694 -0
- package/packages/vscode/out/database-services/mssql.service.js.map +1 -0
- package/packages/vscode/out/database-services/mysql.service.js +735 -0
- package/packages/vscode/out/database-services/mysql.service.js.map +1 -0
- package/packages/vscode/out/database-services/oracle.service.js +787 -0
- package/packages/vscode/out/database-services/oracle.service.js.map +1 -0
- package/packages/vscode/out/database-services/postgres.service.js +696 -0
- package/packages/vscode/out/database-services/postgres.service.js.map +1 -0
- package/packages/vscode/out/database-services/sap.service.js +695 -0
- package/packages/vscode/out/database-services/sap.service.js.map +1 -0
- package/packages/vscode/out/database-services/sqlite.service.js +532 -0
- package/packages/vscode/out/database-services/sqlite.service.js.map +1 -0
- package/packages/vscode/out/extension.js +93 -0
- package/packages/vscode/out/extension.js.map +1 -0
- package/packages/vscode/out/provider/DatabaseTreeProvider.js +159 -0
- package/packages/vscode/out/provider/DatabaseTreeProvider.js.map +1 -0
- package/packages/vscode/out/provider/WebViewProvider.js +259 -0
- package/packages/vscode/out/provider/WebViewProvider.js.map +1 -0
- package/packages/vscode/out/service/ConnectionManager.js +105 -0
- package/packages/vscode/out/service/ConnectionManager.js.map +1 -0
- package/packages/vscode/out/service/DatabaseServiceBridge.js +395 -0
- package/packages/vscode/out/service/DatabaseServiceBridge.js.map +1 -0
- package/packages/vscode/out/typings/connection.js +3 -0
- package/packages/vscode/out/typings/connection.js.map +1 -0
- package/packages/vscode/package.json +142 -0
- package/packages/vscode/resources/icon.svg +5 -0
- package/packages/vscode/resources/webview/_plugin-vue_export-helper.js +6529 -0
- package/packages/vscode/resources/webview/_plugin-vue_export-helper.js.map +1 -0
- package/packages/vscode/resources/webview/connection.css +69 -0
- package/packages/vscode/resources/webview/connection.js +228 -0
- package/packages/vscode/resources/webview/connection.js.map +1 -0
- package/packages/vscode/resources/webview/database.css +259 -0
- package/packages/vscode/resources/webview/database.js +275 -0
- package/packages/vscode/resources/webview/database.js.map +1 -0
- package/packages/vscode/resources/webview/favicon.ico +0 -0
- package/packages/vscode/resources/webview/index.html +9 -0
- package/packages/vscode/resources/webview/modules/header.tpl +14 -0
- package/packages/vscode/resources/webview/modules/initial_state.tpl +55 -0
- package/packages/vscode/resources/webview/query.css +162 -0
- package/packages/vscode/resources/webview/query.js +198 -0
- package/packages/vscode/resources/webview/query.js.map +1 -0
- package/packages/vscode/src/database-services/base.service.js.map +1 -0
- package/packages/vscode/src/database-services/base.service.ts +363 -0
- package/packages/vscode/src/database-services/cockroachdb.service.js.map +1 -0
- package/packages/vscode/src/database-services/cockroachdb.service.ts +659 -0
- package/packages/vscode/src/database-services/connection.service.ts +341 -0
- package/packages/vscode/src/database-services/database.service.ts +630 -0
- package/packages/vscode/src/database-services/index.ts +7 -0
- package/packages/vscode/src/database-services/model/connection.entity.js +11 -0
- package/packages/vscode/src/database-services/model/connection.entity.js.map +1 -0
- package/packages/vscode/src/database-services/model/connection.entity.ts +66 -0
- package/packages/vscode/src/database-services/model/database.entity.js +35 -0
- package/packages/vscode/src/database-services/model/database.entity.js.map +1 -0
- package/packages/vscode/src/database-services/model/database.entity.ts +246 -0
- package/packages/vscode/src/database-services/mongodb.service.js.map +1 -0
- package/packages/vscode/src/database-services/mongodb.service.ts +454 -0
- package/packages/vscode/src/database-services/mssql.service.js.map +1 -0
- package/packages/vscode/src/database-services/mssql.service.ts +723 -0
- package/packages/vscode/src/database-services/mysql.service.js.map +1 -0
- package/packages/vscode/src/database-services/mysql.service.ts +761 -0
- package/packages/vscode/src/database-services/oracle.service.js.map +1 -0
- package/packages/vscode/src/database-services/oracle.service.ts +832 -0
- package/packages/vscode/src/database-services/postgres.service.js.map +1 -0
- package/packages/vscode/src/database-services/postgres.service.ts +741 -0
- package/packages/vscode/src/database-services/sap.service.js.map +1 -0
- package/packages/vscode/src/database-services/sap.service.ts +713 -0
- package/packages/vscode/src/database-services/sqlite.service.js.map +1 -0
- package/packages/vscode/src/database-services/sqlite.service.ts +559 -0
- package/packages/vscode/src/extension.ts +76 -0
- package/packages/vscode/src/provider/DatabaseTreeProvider.ts +167 -0
- package/packages/vscode/src/provider/WebViewProvider.ts +277 -0
- package/packages/vscode/src/service/DatabaseServiceBridge.ts +414 -0
- package/packages/vscode/src/typings/connection.ts +90 -0
- package/packages/vscode/tsconfig.json +21 -0
- package/public/fdb2.png +0 -0
- package/server/backups/db_ai_breakout_2026-03-11T08-38-48-677Z.sql +0 -0
- package/server/index.ts +5 -10
- package/server/model/connection.entity.js +11 -0
- package/server/model/connection.entity.js.map +1 -0
- package/server/model/database.entity.js +35 -0
- package/server/model/database.entity.js.map +1 -0
- package/server/service/connection.service.ts +1 -0
- package/server/service/database/base.service.ts +8 -3
- package/server/service/database/cockroachdb.service.ts +123 -0
- package/server/service/database/database.service.ts +9 -0
- package/server/service/database/mongodb.service.ts +9 -0
- package/server/service/database/mssql.service.ts +118 -0
- package/server/service/database/mysql.service.ts +130 -0
- package/server/service/database/oracle.service.ts +128 -0
- package/server/service/database/postgres.service.ts +131 -0
- package/server/service/database/sap.service.ts +120 -0
- package/server/service/database/sqlite.service.ts +150 -0
- package/server/tsconfig.json +20 -0
- package/src/components/connection-editor/index.vue +0 -1
- package/src/platform/database/components/db-tools.vue +414 -174
- package/src/platform/database/components/table-detail.vue +3 -2
- package/src/platform/database/components/table-editor.vue +245 -18
- package/src/platform/vscode/bridge.ts +121 -0
- package/src/platform/vscode/components/ConnectionPanel.vue +272 -0
- package/src/platform/vscode/components/DatabasePanel.vue +532 -0
- package/src/platform/vscode/components/QueryPanel.vue +371 -0
- package/src/platform/vscode/entry/connection.ts +13 -0
- package/src/platform/vscode/entry/database.ts +13 -0
- package/src/platform/vscode/entry/query.ts +13 -0
- package/src/platform/vscode/index.ts +5 -0
- package/src/service/database.ts +2 -6
- package/vite.config.ts +46 -6
- package/vite.config.vscode.ts +47 -0
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
|
|
2
|
+
.connection-form[data-v-d5bbc9a6] {
|
|
3
|
+
padding: 20px;
|
|
4
|
+
max-width: 600px;
|
|
5
|
+
margin: 0 auto;
|
|
6
|
+
}
|
|
7
|
+
.panel-title[data-v-d5bbc9a6] {
|
|
8
|
+
font-size: 18px;
|
|
9
|
+
font-weight: 600;
|
|
10
|
+
margin-bottom: 24px;
|
|
11
|
+
color: var(--vscode-foreground);
|
|
12
|
+
}
|
|
13
|
+
.form-group[data-v-d5bbc9a6] {
|
|
14
|
+
margin-bottom: 20px;
|
|
15
|
+
}
|
|
16
|
+
.form-label[data-v-d5bbc9a6] {
|
|
17
|
+
display: block;
|
|
18
|
+
margin-bottom: 8px;
|
|
19
|
+
font-weight: 500;
|
|
20
|
+
color: var(--vscode-foreground);
|
|
21
|
+
}
|
|
22
|
+
.form-control[data-v-d5bbc9a6] {
|
|
23
|
+
width: 100%;
|
|
24
|
+
padding: 8px 12px;
|
|
25
|
+
border: 1px solid var(--vscode-input-border);
|
|
26
|
+
background-color: var(--vscode-input-background);
|
|
27
|
+
color: var(--vscode-input-foreground);
|
|
28
|
+
border-radius: 4px;
|
|
29
|
+
font-size: 14px;
|
|
30
|
+
}
|
|
31
|
+
.form-control[data-v-d5bbc9a6]:focus {
|
|
32
|
+
outline: none;
|
|
33
|
+
border-color: var(--vscode-focusBorder);
|
|
34
|
+
}
|
|
35
|
+
.form-row[data-v-d5bbc9a6] {
|
|
36
|
+
display: flex;
|
|
37
|
+
gap: 12px;
|
|
38
|
+
}
|
|
39
|
+
.form-col[data-v-d5bbc9a6] {
|
|
40
|
+
flex: 1;
|
|
41
|
+
}
|
|
42
|
+
.form-actions[data-v-d5bbc9a6] {
|
|
43
|
+
display: flex;
|
|
44
|
+
justify-content: flex-end;
|
|
45
|
+
gap: 12px;
|
|
46
|
+
margin-top: 24px;
|
|
47
|
+
}
|
|
48
|
+
.btn[data-v-d5bbc9a6] {
|
|
49
|
+
padding: 8px 16px;
|
|
50
|
+
border: none;
|
|
51
|
+
border-radius: 4px;
|
|
52
|
+
font-size: 14px;
|
|
53
|
+
cursor: pointer;
|
|
54
|
+
transition: background-color 0.2s;
|
|
55
|
+
}
|
|
56
|
+
.btn-primary[data-v-d5bbc9a6] {
|
|
57
|
+
background-color: var(--vscode-button-background);
|
|
58
|
+
color: var(--vscode-button-foreground);
|
|
59
|
+
}
|
|
60
|
+
.btn-primary[data-v-d5bbc9a6]:hover {
|
|
61
|
+
background-color: var(--vscode-button-hoverBackground);
|
|
62
|
+
}
|
|
63
|
+
.btn-secondary[data-v-d5bbc9a6] {
|
|
64
|
+
background-color: var(--vscode-button-secondaryBackground);
|
|
65
|
+
color: var(--vscode-button-secondaryForeground);
|
|
66
|
+
}
|
|
67
|
+
.btn-secondary[data-v-d5bbc9a6]:hover {
|
|
68
|
+
background-color: var(--vscode-button-secondaryHoverBackground);
|
|
69
|
+
}
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
import { d as defineComponent, g as getVSCodeBridge, o as onMounted, a as openBlock, c as createElementBlock, b as createBaseVNode, t as toDisplayString, w as withDirectives, v as vModelText, e as vModelSelect, F as Fragment, r as renderList, f as createCommentVNode, h as withModifiers, i as ref, j as reactive, _ as _export_sfc, k as createApp } from "./_plugin-vue_export-helper.js";
|
|
2
|
+
const _hoisted_1 = { class: "connection-form" };
|
|
3
|
+
const _hoisted_2 = { class: "panel-title" };
|
|
4
|
+
const _hoisted_3 = { class: "form-group" };
|
|
5
|
+
const _hoisted_4 = { class: "form-group" };
|
|
6
|
+
const _hoisted_5 = ["value"];
|
|
7
|
+
const _hoisted_6 = {
|
|
8
|
+
key: 0,
|
|
9
|
+
class: "form-row"
|
|
10
|
+
};
|
|
11
|
+
const _hoisted_7 = { class: "form-col form-group" };
|
|
12
|
+
const _hoisted_8 = { class: "form-col form-group" };
|
|
13
|
+
const _hoisted_9 = ["id"];
|
|
14
|
+
const _hoisted_10 = { class: "form-label" };
|
|
15
|
+
const _hoisted_11 = ["placeholder"];
|
|
16
|
+
const _hoisted_12 = {
|
|
17
|
+
key: 1,
|
|
18
|
+
class: "form-group"
|
|
19
|
+
};
|
|
20
|
+
const _hoisted_13 = { class: "form-row" };
|
|
21
|
+
const _hoisted_14 = { class: "form-col" };
|
|
22
|
+
const _hoisted_15 = { class: "form-col" };
|
|
23
|
+
const _hoisted_16 = { class: "form-actions" };
|
|
24
|
+
const _hoisted_17 = {
|
|
25
|
+
type: "submit",
|
|
26
|
+
class: "btn btn-primary"
|
|
27
|
+
};
|
|
28
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
29
|
+
__name: "ConnectionPanel",
|
|
30
|
+
setup(__props) {
|
|
31
|
+
const vscode = getVSCodeBridge();
|
|
32
|
+
const isEditMode = ref(false);
|
|
33
|
+
const editingConnection = ref(null);
|
|
34
|
+
const form = reactive({
|
|
35
|
+
name: "",
|
|
36
|
+
type: "mysql",
|
|
37
|
+
host: "localhost",
|
|
38
|
+
port: 3306,
|
|
39
|
+
database: "",
|
|
40
|
+
username: "",
|
|
41
|
+
password: ""
|
|
42
|
+
});
|
|
43
|
+
const databaseTypes = [
|
|
44
|
+
{ type: "mysql", name: "MySQL", defaultPort: 3306 },
|
|
45
|
+
{ type: "postgresql", name: "PostgreSQL", defaultPort: 5432 },
|
|
46
|
+
{ type: "sqlite", name: "SQLite", defaultPort: 0 },
|
|
47
|
+
{ type: "sqlserver", name: "SQL Server", defaultPort: 1433 },
|
|
48
|
+
{ type: "oracle", name: "Oracle", defaultPort: 1521 }
|
|
49
|
+
];
|
|
50
|
+
onMounted(() => {
|
|
51
|
+
vscode.onMessage((message) => {
|
|
52
|
+
if (message.command === "editConnection") {
|
|
53
|
+
enterEditMode(message.data);
|
|
54
|
+
} else if (message.command === "testResult") {
|
|
55
|
+
handleTestResult(message.data);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
function enterEditMode(connection) {
|
|
60
|
+
editingConnection.value = connection;
|
|
61
|
+
isEditMode.value = true;
|
|
62
|
+
Object.assign(form, {
|
|
63
|
+
name: connection.name,
|
|
64
|
+
type: connection.type,
|
|
65
|
+
host: connection.host,
|
|
66
|
+
port: connection.port,
|
|
67
|
+
database: connection.database || "",
|
|
68
|
+
username: connection.username || "",
|
|
69
|
+
password: connection.password || ""
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
function handleTypeChange() {
|
|
73
|
+
const dbType = databaseTypes.find((db) => db.type === form.type);
|
|
74
|
+
if (dbType && dbType.defaultPort > 0) {
|
|
75
|
+
form.port = dbType.defaultPort;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
function handleSubmit() {
|
|
79
|
+
const connectionData = { ...form };
|
|
80
|
+
if (isEditMode.value && editingConnection.value) {
|
|
81
|
+
connectionData.id = editingConnection.value.id;
|
|
82
|
+
vscode.postMessage({ command: "updateConnection", data: connectionData });
|
|
83
|
+
} else {
|
|
84
|
+
vscode.postMessage({ command: "addConnection", data: connectionData });
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
function handleTestConnection() {
|
|
88
|
+
vscode.postMessage({ command: "testConnection", data: { ...form } });
|
|
89
|
+
}
|
|
90
|
+
function handleTestResult(data) {
|
|
91
|
+
if (data.success) {
|
|
92
|
+
alert("连接测试成功");
|
|
93
|
+
} else {
|
|
94
|
+
alert("连接测试失败");
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
function handleCancel() {
|
|
98
|
+
vscode.postMessage({ command: "close" });
|
|
99
|
+
}
|
|
100
|
+
return (_ctx, _cache) => {
|
|
101
|
+
return openBlock(), createElementBlock("div", _hoisted_1, [
|
|
102
|
+
createBaseVNode("h1", _hoisted_2, toDisplayString(isEditMode.value ? "编辑" : "添加") + "数据库连接", 1),
|
|
103
|
+
createBaseVNode("form", {
|
|
104
|
+
onSubmit: withModifiers(handleSubmit, ["prevent"])
|
|
105
|
+
}, [
|
|
106
|
+
createBaseVNode("div", _hoisted_3, [
|
|
107
|
+
_cache[7] || (_cache[7] = createBaseVNode("label", { class: "form-label" }, "连接名称", -1)),
|
|
108
|
+
withDirectives(createBaseVNode("input", {
|
|
109
|
+
type: "text",
|
|
110
|
+
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => form.name = $event),
|
|
111
|
+
class: "form-control",
|
|
112
|
+
placeholder: "例如:生产环境 MySQL",
|
|
113
|
+
required: ""
|
|
114
|
+
}, null, 512), [
|
|
115
|
+
[vModelText, form.name]
|
|
116
|
+
])
|
|
117
|
+
]),
|
|
118
|
+
createBaseVNode("div", _hoisted_4, [
|
|
119
|
+
_cache[8] || (_cache[8] = createBaseVNode("label", { class: "form-label" }, "数据库类型", -1)),
|
|
120
|
+
withDirectives(createBaseVNode("select", {
|
|
121
|
+
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => form.type = $event),
|
|
122
|
+
class: "form-control",
|
|
123
|
+
onChange: handleTypeChange,
|
|
124
|
+
required: ""
|
|
125
|
+
}, [
|
|
126
|
+
(openBlock(), createElementBlock(Fragment, null, renderList(databaseTypes, (db) => {
|
|
127
|
+
return createBaseVNode("option", {
|
|
128
|
+
key: db.type,
|
|
129
|
+
value: db.type
|
|
130
|
+
}, toDisplayString(db.name), 9, _hoisted_5);
|
|
131
|
+
}), 64))
|
|
132
|
+
], 544), [
|
|
133
|
+
[vModelSelect, form.type]
|
|
134
|
+
])
|
|
135
|
+
]),
|
|
136
|
+
form.type !== "sqlite" ? (openBlock(), createElementBlock("div", _hoisted_6, [
|
|
137
|
+
createBaseVNode("div", _hoisted_7, [
|
|
138
|
+
_cache[9] || (_cache[9] = createBaseVNode("label", { class: "form-label" }, "主机地址", -1)),
|
|
139
|
+
withDirectives(createBaseVNode("input", {
|
|
140
|
+
type: "text",
|
|
141
|
+
"onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => form.host = $event),
|
|
142
|
+
class: "form-control",
|
|
143
|
+
placeholder: "localhost",
|
|
144
|
+
required: ""
|
|
145
|
+
}, null, 512), [
|
|
146
|
+
[vModelText, form.host]
|
|
147
|
+
])
|
|
148
|
+
]),
|
|
149
|
+
createBaseVNode("div", _hoisted_8, [
|
|
150
|
+
_cache[10] || (_cache[10] = createBaseVNode("label", { class: "form-label" }, "端口", -1)),
|
|
151
|
+
withDirectives(createBaseVNode("input", {
|
|
152
|
+
type: "number",
|
|
153
|
+
"onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => form.port = $event),
|
|
154
|
+
class: "form-control",
|
|
155
|
+
placeholder: "3306",
|
|
156
|
+
required: ""
|
|
157
|
+
}, null, 512), [
|
|
158
|
+
[
|
|
159
|
+
vModelText,
|
|
160
|
+
form.port,
|
|
161
|
+
void 0,
|
|
162
|
+
{ number: true }
|
|
163
|
+
]
|
|
164
|
+
])
|
|
165
|
+
])
|
|
166
|
+
])) : createCommentVNode("", true),
|
|
167
|
+
createBaseVNode("div", {
|
|
168
|
+
class: "form-group",
|
|
169
|
+
id: form.type === "sqlite" ? "sqlite-path" : "database-name"
|
|
170
|
+
}, [
|
|
171
|
+
createBaseVNode("label", _hoisted_10, toDisplayString(form.type === "sqlite" ? "数据库文件路径" : "数据库名称"), 1),
|
|
172
|
+
withDirectives(createBaseVNode("input", {
|
|
173
|
+
type: "text",
|
|
174
|
+
"onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => form.database = $event),
|
|
175
|
+
class: "form-control",
|
|
176
|
+
placeholder: form.type === "sqlite" ? "/path/to/database.sqlite" : "数据库名称"
|
|
177
|
+
}, null, 8, _hoisted_11), [
|
|
178
|
+
[vModelText, form.database]
|
|
179
|
+
])
|
|
180
|
+
], 8, _hoisted_9),
|
|
181
|
+
form.type !== "sqlite" ? (openBlock(), createElementBlock("div", _hoisted_12, [
|
|
182
|
+
createBaseVNode("div", _hoisted_13, [
|
|
183
|
+
createBaseVNode("div", _hoisted_14, [
|
|
184
|
+
_cache[11] || (_cache[11] = createBaseVNode("label", { class: "form-label" }, "用户名", -1)),
|
|
185
|
+
withDirectives(createBaseVNode("input", {
|
|
186
|
+
type: "text",
|
|
187
|
+
"onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => form.username = $event),
|
|
188
|
+
class: "form-control",
|
|
189
|
+
placeholder: "root"
|
|
190
|
+
}, null, 512), [
|
|
191
|
+
[vModelText, form.username]
|
|
192
|
+
])
|
|
193
|
+
]),
|
|
194
|
+
createBaseVNode("div", _hoisted_15, [
|
|
195
|
+
_cache[12] || (_cache[12] = createBaseVNode("label", { class: "form-label" }, "密码", -1)),
|
|
196
|
+
withDirectives(createBaseVNode("input", {
|
|
197
|
+
type: "password",
|
|
198
|
+
"onUpdate:modelValue": _cache[6] || (_cache[6] = ($event) => form.password = $event),
|
|
199
|
+
class: "form-control",
|
|
200
|
+
placeholder: "••••••••"
|
|
201
|
+
}, null, 512), [
|
|
202
|
+
[vModelText, form.password]
|
|
203
|
+
])
|
|
204
|
+
])
|
|
205
|
+
])
|
|
206
|
+
])) : createCommentVNode("", true),
|
|
207
|
+
createBaseVNode("div", _hoisted_16, [
|
|
208
|
+
createBaseVNode("button", {
|
|
209
|
+
type: "button",
|
|
210
|
+
onClick: handleTestConnection,
|
|
211
|
+
class: "btn btn-secondary"
|
|
212
|
+
}, " 测试连接 "),
|
|
213
|
+
createBaseVNode("button", {
|
|
214
|
+
type: "button",
|
|
215
|
+
onClick: handleCancel,
|
|
216
|
+
class: "btn btn-secondary"
|
|
217
|
+
}, " 取消 "),
|
|
218
|
+
createBaseVNode("button", _hoisted_17, toDisplayString(isEditMode.value ? "保存" : "添加"), 1)
|
|
219
|
+
])
|
|
220
|
+
], 32)
|
|
221
|
+
]);
|
|
222
|
+
};
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
const ConnectionPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-d5bbc9a6"]]);
|
|
226
|
+
const app = createApp(ConnectionPanel);
|
|
227
|
+
app.mount("#app");
|
|
228
|
+
//# sourceMappingURL=connection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection.js","sources":["../../../../src/platform/vscode/components/ConnectionPanel.vue","../../../../src/platform/vscode/entry/connection.ts"],"sourcesContent":["<template>\r\n <div class=\"connection-form\">\r\n <h1 class=\"panel-title\">{{ isEditMode ? '编辑' : '添加' }}数据库连接</h1>\r\n\r\n <form @submit.prevent=\"handleSubmit\">\r\n <div class=\"form-group\">\r\n <label class=\"form-label\">连接名称</label>\r\n <input\r\n type=\"text\"\r\n v-model=\"form.name\"\r\n class=\"form-control\"\r\n placeholder=\"例如:生产环境 MySQL\"\r\n required\r\n />\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label class=\"form-label\">数据库类型</label>\r\n <select v-model=\"form.type\" class=\"form-control\" @change=\"handleTypeChange\" required>\r\n <option v-for=\"db in databaseTypes\" :key=\"db.type\" :value=\"db.type\">\r\n {{ db.name }}\r\n </option>\r\n </select>\r\n </div>\r\n\r\n <div class=\"form-row\" v-if=\"form.type !== 'sqlite'\">\r\n <div class=\"form-col form-group\">\r\n <label class=\"form-label\">主机地址</label>\r\n <input\r\n type=\"text\"\r\n v-model=\"form.host\"\r\n class=\"form-control\"\r\n placeholder=\"localhost\"\r\n required\r\n />\r\n </div>\r\n\r\n <div class=\"form-col form-group\">\r\n <label class=\"form-label\">端口</label>\r\n <input\r\n type=\"number\"\r\n v-model.number=\"form.port\"\r\n class=\"form-control\"\r\n placeholder=\"3306\"\r\n required\r\n />\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group\" :id=\"form.type === 'sqlite' ? 'sqlite-path' : 'database-name'\">\r\n <label class=\"form-label\">\r\n {{ form.type === 'sqlite' ? '数据库文件路径' : '数据库名称' }}\r\n </label>\r\n <input\r\n type=\"text\"\r\n v-model=\"form.database\"\r\n class=\"form-control\"\r\n :placeholder=\"form.type === 'sqlite' ? '/path/to/database.sqlite' : '数据库名称'\"\r\n />\r\n </div>\r\n\r\n <div class=\"form-group\" v-if=\"form.type !== 'sqlite'\">\r\n <div class=\"form-row\">\r\n <div class=\"form-col\">\r\n <label class=\"form-label\">用户名</label>\r\n <input\r\n type=\"text\"\r\n v-model=\"form.username\"\r\n class=\"form-control\"\r\n placeholder=\"root\"\r\n />\r\n </div>\r\n\r\n <div class=\"form-col\">\r\n <label class=\"form-label\">密码</label>\r\n <input\r\n type=\"password\"\r\n v-model=\"form.password\"\r\n class=\"form-control\"\r\n placeholder=\"••••••••\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-actions\">\r\n <button type=\"button\" @click=\"handleTestConnection\" class=\"btn btn-secondary\">\r\n 测试连接\r\n </button>\r\n <button type=\"button\" @click=\"handleCancel\" class=\"btn btn-secondary\">\r\n 取消\r\n </button>\r\n <button type=\"submit\" class=\"btn btn-primary\">\r\n {{ isEditMode ? '保存' : '添加' }}\r\n </button>\r\n </div>\r\n </form>\r\n </div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { ref, reactive, onMounted } from 'vue';\r\nimport { getVSCodeBridge } from '../bridge';\r\n\r\nconst vscode = getVSCodeBridge();\r\n\r\nconst isEditMode = ref(false);\r\nconst editingConnection = ref<any>(null);\r\n\r\nconst form = reactive({\r\n name: '',\r\n type: 'mysql',\r\n host: 'localhost',\r\n port: 3306,\r\n database: '',\r\n username: '',\r\n password: ''\r\n});\r\n\r\nconst databaseTypes = [\r\n { type: 'mysql', name: 'MySQL', defaultPort: 3306 },\r\n { type: 'postgresql', name: 'PostgreSQL', defaultPort: 5432 },\r\n { type: 'sqlite', name: 'SQLite', defaultPort: 0 },\r\n { type: 'sqlserver', name: 'SQL Server', defaultPort: 1433 },\r\n { type: 'oracle', name: 'Oracle', defaultPort: 1521 }\r\n];\r\n\r\nonMounted(() => {\r\n // 监听来自扩展的消息\r\n vscode.onMessage((message: any) => {\r\n if (message.command === 'editConnection') {\r\n enterEditMode(message.data);\r\n } else if (message.command === 'testResult') {\r\n handleTestResult(message.data);\r\n }\r\n });\r\n});\r\n\r\nfunction enterEditMode(connection: any) {\r\n editingConnection.value = connection;\r\n isEditMode.value = true;\r\n\r\n Object.assign(form, {\r\n name: connection.name,\r\n type: connection.type,\r\n host: connection.host,\r\n port: connection.port,\r\n database: connection.database || '',\r\n username: connection.username || '',\r\n password: connection.password || ''\r\n });\r\n}\r\n\r\nfunction handleTypeChange() {\r\n const dbType = databaseTypes.find(db => db.type === form.type);\r\n if (dbType && dbType.defaultPort > 0) {\r\n form.port = dbType.defaultPort;\r\n }\r\n}\r\n\r\nfunction handleSubmit() {\r\n const connectionData = { ...form };\r\n\r\n if (isEditMode.value && editingConnection.value) {\r\n connectionData.id = editingConnection.value.id;\r\n vscode.postMessage({ command: 'updateConnection', data: connectionData });\r\n } else {\r\n vscode.postMessage({ command: 'addConnection', data: connectionData });\r\n }\r\n}\r\n\r\nfunction handleTestConnection() {\r\n vscode.postMessage({ command: 'testConnection', data: { ...form } });\r\n}\r\n\r\nfunction handleTestResult(data: any) {\r\n if (data.success) {\r\n alert('连接测试成功');\r\n } else {\r\n alert('连接测试失败');\r\n }\r\n}\r\n\r\nfunction handleCancel() {\r\n // 在 WebView 中无法直接关闭,通知扩展关闭\r\n vscode.postMessage({ command: 'close' });\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n.connection-form {\r\n padding: 20px;\r\n max-width: 600px;\r\n margin: 0 auto;\r\n}\r\n\r\n.panel-title {\r\n font-size: 18px;\r\n font-weight: 600;\r\n margin-bottom: 24px;\r\n color: var(--vscode-foreground);\r\n}\r\n\r\n.form-group {\r\n margin-bottom: 20px;\r\n}\r\n\r\n.form-label {\r\n display: block;\r\n margin-bottom: 8px;\r\n font-weight: 500;\r\n color: var(--vscode-foreground);\r\n}\r\n\r\n.form-control {\r\n width: 100%;\r\n padding: 8px 12px;\r\n border: 1px solid var(--vscode-input-border);\r\n background-color: var(--vscode-input-background);\r\n color: var(--vscode-input-foreground);\r\n border-radius: 4px;\r\n font-size: 14px;\r\n}\r\n\r\n.form-control:focus {\r\n outline: none;\r\n border-color: var(--vscode-focusBorder);\r\n}\r\n\r\n.form-row {\r\n display: flex;\r\n gap: 12px;\r\n}\r\n\r\n.form-col {\r\n flex: 1;\r\n}\r\n\r\n.form-actions {\r\n display: flex;\r\n justify-content: flex-end;\r\n gap: 12px;\r\n margin-top: 24px;\r\n}\r\n\r\n.btn {\r\n padding: 8px 16px;\r\n border: none;\r\n border-radius: 4px;\r\n font-size: 14px;\r\n cursor: pointer;\r\n transition: background-color 0.2s;\r\n}\r\n\r\n.btn-primary {\r\n background-color: var(--vscode-button-background);\r\n color: var(--vscode-button-foreground);\r\n}\r\n\r\n.btn-primary:hover {\r\n background-color: var(--vscode-button-hoverBackground);\r\n}\r\n\r\n.btn-secondary {\r\n background-color: var(--vscode-button-secondaryBackground);\r\n color: var(--vscode-button-secondaryForeground);\r\n}\r\n\r\n.btn-secondary:hover {\r\n background-color: var(--vscode-button-secondaryHoverBackground);\r\n}\r\n</style>\r\n","/**\r\n * VSCode WebView - Connection Entry Point\r\n * 连接管理面板入口\r\n */\r\n\r\nimport { createApp } from 'vue';\r\nimport ConnectionPanel from '../components/ConnectionPanel.vue';\r\n\r\n// 创建 Vue 应用\r\nconst app = createApp(ConnectionPanel);\r\n\r\n// 挂载\r\napp.mount('#app');\r\n"],"names":["_openBlock","_createElementBlock","_createElementVNode","_toDisplayString","_vModelText","_Fragment","_renderList","_vModelSelect"],"mappings":"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"}
|
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
|
|
2
|
+
.database-panel[data-v-974a0a17] {
|
|
3
|
+
padding: 16px;
|
|
4
|
+
height: 100vh;
|
|
5
|
+
overflow: auto;
|
|
6
|
+
}
|
|
7
|
+
.panel-header[data-v-974a0a17] {
|
|
8
|
+
display: flex;
|
|
9
|
+
justify-content: space-between;
|
|
10
|
+
align-items: center;
|
|
11
|
+
margin-bottom: 20px;
|
|
12
|
+
padding-bottom: 16px;
|
|
13
|
+
border-bottom: 1px solid var(--vscode-panel-border);
|
|
14
|
+
}
|
|
15
|
+
.panel-title[data-v-974a0a17] {
|
|
16
|
+
font-size: 18px;
|
|
17
|
+
font-weight: 600;
|
|
18
|
+
margin: 0;
|
|
19
|
+
color: var(--vscode-foreground);
|
|
20
|
+
}
|
|
21
|
+
.panel-actions[data-v-974a0a17] {
|
|
22
|
+
display: flex;
|
|
23
|
+
gap: 8px;
|
|
24
|
+
}
|
|
25
|
+
.connection-selector[data-v-974a0a17] {
|
|
26
|
+
width: 300px;
|
|
27
|
+
padding: 6px 10px;
|
|
28
|
+
border: 1px solid var(--vscode-input-border);
|
|
29
|
+
background-color: var(--vscode-input-background);
|
|
30
|
+
color: var(--vscode-input-foreground);
|
|
31
|
+
border-radius: 4px;
|
|
32
|
+
font-size: 13px;
|
|
33
|
+
}
|
|
34
|
+
.btn[data-v-974a0a17] {
|
|
35
|
+
padding: 6px 14px;
|
|
36
|
+
border: none;
|
|
37
|
+
border-radius: 4px;
|
|
38
|
+
font-size: 13px;
|
|
39
|
+
cursor: pointer;
|
|
40
|
+
transition: background-color 0.2s;
|
|
41
|
+
}
|
|
42
|
+
.btn-primary[data-v-974a0a17] {
|
|
43
|
+
background-color: var(--vscode-button-background);
|
|
44
|
+
color: var(--vscode-button-foreground);
|
|
45
|
+
}
|
|
46
|
+
.btn-primary[data-v-974a0a17]:hover {
|
|
47
|
+
background-color: var(--vscode-button-hoverBackground);
|
|
48
|
+
}
|
|
49
|
+
.btn-secondary[data-v-974a0a17] {
|
|
50
|
+
background-color: var(--vscode-button-secondaryBackground);
|
|
51
|
+
color: var(--vscode-button-secondaryForeground);
|
|
52
|
+
}
|
|
53
|
+
.btn-secondary[data-v-974a0a17]:hover {
|
|
54
|
+
background-color: var(--vscode-button-secondaryHoverBackground);
|
|
55
|
+
}
|
|
56
|
+
.database-grid[data-v-974a0a17] {
|
|
57
|
+
display: grid;
|
|
58
|
+
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
|
|
59
|
+
gap: 16px;
|
|
60
|
+
}
|
|
61
|
+
.database-card[data-v-974a0a17] {
|
|
62
|
+
padding: 16px;
|
|
63
|
+
background-color: var(--vscode-editor-background);
|
|
64
|
+
border: 1px solid var(--vscode-panel-border);
|
|
65
|
+
border-radius: 8px;
|
|
66
|
+
cursor: pointer;
|
|
67
|
+
transition: all 0.2s;
|
|
68
|
+
}
|
|
69
|
+
.database-card[data-v-974a0a17]:hover {
|
|
70
|
+
border-color: var(--vscode-focusBorder);
|
|
71
|
+
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
|
|
72
|
+
transform: translateY(-2px);
|
|
73
|
+
}
|
|
74
|
+
.database-header[data-v-974a0a17] {
|
|
75
|
+
display: flex;
|
|
76
|
+
align-items: center;
|
|
77
|
+
gap: 12px;
|
|
78
|
+
margin-bottom: 12px;
|
|
79
|
+
}
|
|
80
|
+
.database-icon[data-v-974a0a17] {
|
|
81
|
+
font-size: 28px;
|
|
82
|
+
color: var(--vscode-textLink-foreground);
|
|
83
|
+
}
|
|
84
|
+
.database-name[data-v-974a0a17] {
|
|
85
|
+
flex: 1;
|
|
86
|
+
font-size: 16px;
|
|
87
|
+
font-weight: 600;
|
|
88
|
+
color: var(--vscode-foreground);
|
|
89
|
+
}
|
|
90
|
+
.database-info[data-v-974a0a17] {
|
|
91
|
+
display: flex;
|
|
92
|
+
gap: 16px;
|
|
93
|
+
font-size: 12px;
|
|
94
|
+
color: var(--vscode-descriptionForeground);
|
|
95
|
+
}
|
|
96
|
+
.database-stat[data-v-974a0a17] {
|
|
97
|
+
display: flex;
|
|
98
|
+
align-items: center;
|
|
99
|
+
gap: 4px;
|
|
100
|
+
}
|
|
101
|
+
.section-title[data-v-974a0a17] {
|
|
102
|
+
font-size: 16px;
|
|
103
|
+
font-weight: 600;
|
|
104
|
+
margin: 24px 0 16px 0;
|
|
105
|
+
padding-bottom: 8px;
|
|
106
|
+
border-bottom: 1px solid var(--vscode-panel-border);
|
|
107
|
+
color: var(--vscode-foreground);
|
|
108
|
+
}
|
|
109
|
+
.tabs[data-v-974a0a17] {
|
|
110
|
+
display: flex;
|
|
111
|
+
gap: 4px;
|
|
112
|
+
margin-bottom: 16px;
|
|
113
|
+
border-bottom: 1px solid var(--vscode-panel-border);
|
|
114
|
+
}
|
|
115
|
+
.tab[data-v-974a0a17] {
|
|
116
|
+
padding: 8px 16px;
|
|
117
|
+
border: none;
|
|
118
|
+
background-color: transparent;
|
|
119
|
+
color: var(--vscode-foreground);
|
|
120
|
+
font-size: 13px;
|
|
121
|
+
cursor: pointer;
|
|
122
|
+
border-bottom: 2px solid transparent;
|
|
123
|
+
transition: all 0.2s;
|
|
124
|
+
}
|
|
125
|
+
.tab[data-v-974a0a17]:hover {
|
|
126
|
+
background-color: var(--vscode-list-hoverBackground);
|
|
127
|
+
}
|
|
128
|
+
.tab.active[data-v-974a0a17] {
|
|
129
|
+
border-bottom-color: var(--vscode-focusBorder);
|
|
130
|
+
color: var(--vscode-textLink-foreground);
|
|
131
|
+
}
|
|
132
|
+
.tab-content[data-v-974a0a17] {
|
|
133
|
+
display: none;
|
|
134
|
+
}
|
|
135
|
+
.tab-content.active[data-v-974a0a17] {
|
|
136
|
+
display: block;
|
|
137
|
+
}
|
|
138
|
+
.table-list[data-v-974a0a17] {
|
|
139
|
+
display: flex;
|
|
140
|
+
flex-direction: column;
|
|
141
|
+
gap: 4px;
|
|
142
|
+
}
|
|
143
|
+
.table-item[data-v-974a0a17] {
|
|
144
|
+
display: flex;
|
|
145
|
+
align-items: center;
|
|
146
|
+
gap: 12px;
|
|
147
|
+
padding: 12px;
|
|
148
|
+
border-radius: 6px;
|
|
149
|
+
cursor: pointer;
|
|
150
|
+
transition: background-color 0.2s;
|
|
151
|
+
}
|
|
152
|
+
.table-item[data-v-974a0a17]:hover {
|
|
153
|
+
background-color: var(--vscode-list-hoverBackground);
|
|
154
|
+
}
|
|
155
|
+
.table-icon[data-v-974a0a17] {
|
|
156
|
+
font-size: 20px;
|
|
157
|
+
color: var(--vscode-textLink-foreground);
|
|
158
|
+
width: 24px;
|
|
159
|
+
text-align: center;
|
|
160
|
+
}
|
|
161
|
+
.table-info[data-v-974a0a17] {
|
|
162
|
+
flex: 1;
|
|
163
|
+
}
|
|
164
|
+
.table-name[data-v-974a0a17] {
|
|
165
|
+
font-size: 14px;
|
|
166
|
+
font-weight: 500;
|
|
167
|
+
margin-bottom: 2px;
|
|
168
|
+
color: var(--vscode-foreground);
|
|
169
|
+
}
|
|
170
|
+
.table-comment[data-v-974a0a17] {
|
|
171
|
+
font-size: 12px;
|
|
172
|
+
color: var(--vscode-descriptionForeground);
|
|
173
|
+
}
|
|
174
|
+
.table-meta[data-v-974a0a17] {
|
|
175
|
+
display: flex;
|
|
176
|
+
align-items: center;
|
|
177
|
+
gap: 12px;
|
|
178
|
+
font-size: 12px;
|
|
179
|
+
color: var(--vscode-descriptionForeground);
|
|
180
|
+
margin-top: 4px;
|
|
181
|
+
}
|
|
182
|
+
.table-type[data-v-974a0a17] {
|
|
183
|
+
padding: 2px 8px;
|
|
184
|
+
border-radius: 12px;
|
|
185
|
+
background-color: var(--vscode-badge-background);
|
|
186
|
+
font-weight: 500;
|
|
187
|
+
font-size: 12px;
|
|
188
|
+
}
|
|
189
|
+
.table-type.table[data-v-974a0a17] {
|
|
190
|
+
background-color: var(--vscode-badge-background);
|
|
191
|
+
}
|
|
192
|
+
.table-type.view[data-v-974a0a17] {
|
|
193
|
+
background-color: var(--vscode-gitDecorationModifiedResourceForeground);
|
|
194
|
+
color: white;
|
|
195
|
+
}
|
|
196
|
+
.table-actions[data-v-974a0a17] {
|
|
197
|
+
display: flex;
|
|
198
|
+
gap: 8px;
|
|
199
|
+
opacity: 0;
|
|
200
|
+
transition: opacity 0.2s;
|
|
201
|
+
}
|
|
202
|
+
.table-item:hover .table-actions[data-v-974a0a17] {
|
|
203
|
+
opacity: 1;
|
|
204
|
+
}
|
|
205
|
+
.action-btn[data-v-974a0a17] {
|
|
206
|
+
padding: 4px 8px;
|
|
207
|
+
font-size: 12px;
|
|
208
|
+
background-color: var(--vscode-button-secondaryBackground);
|
|
209
|
+
color: var(--vscode-button-secondaryForeground);
|
|
210
|
+
border: none;
|
|
211
|
+
border-radius: 4px;
|
|
212
|
+
cursor: pointer;
|
|
213
|
+
}
|
|
214
|
+
.action-btn[data-v-974a0a17]:hover {
|
|
215
|
+
background-color: var(--vscode-button-secondaryHoverBackground);
|
|
216
|
+
}
|
|
217
|
+
.empty-state[data-v-974a0a17] {
|
|
218
|
+
display: flex;
|
|
219
|
+
flex-direction: column;
|
|
220
|
+
align-items: center;
|
|
221
|
+
justify-content: center;
|
|
222
|
+
padding: 80px 20px;
|
|
223
|
+
text-align: center;
|
|
224
|
+
}
|
|
225
|
+
.empty-icon[data-v-974a0a17] {
|
|
226
|
+
font-size: 64px;
|
|
227
|
+
margin-bottom: 16px;
|
|
228
|
+
opacity: 0.3;
|
|
229
|
+
}
|
|
230
|
+
.empty-title[data-v-974a0a17] {
|
|
231
|
+
font-size: 16px;
|
|
232
|
+
font-weight: 600;
|
|
233
|
+
margin-bottom: 8px;
|
|
234
|
+
color: var(--vscode-foreground);
|
|
235
|
+
}
|
|
236
|
+
.empty-text[data-v-974a0a17] {
|
|
237
|
+
font-size: 14px;
|
|
238
|
+
color: var(--vscode-descriptionForeground);
|
|
239
|
+
}
|
|
240
|
+
.loading[data-v-974a0a17] {
|
|
241
|
+
display: flex;
|
|
242
|
+
flex-direction: column;
|
|
243
|
+
align-items: center;
|
|
244
|
+
justify-content: center;
|
|
245
|
+
padding: 40px;
|
|
246
|
+
}
|
|
247
|
+
.spinner[data-v-974a0a17] {
|
|
248
|
+
width: 32px;
|
|
249
|
+
height: 32px;
|
|
250
|
+
border: 3px solid var(--vscode-progressBar-background);
|
|
251
|
+
border-top-color: var(--vscode-progressBar-foreground);
|
|
252
|
+
border-radius: 50%;
|
|
253
|
+
animation: spin-974a0a17 0.6s linear infinite;
|
|
254
|
+
}
|
|
255
|
+
@keyframes spin-974a0a17 {
|
|
256
|
+
to {
|
|
257
|
+
transform: rotate(360deg);
|
|
258
|
+
}
|
|
259
|
+
}
|