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.
Files changed (193) hide show
  1. package/.vscodeignore +45 -0
  2. package/README.md +24 -85
  3. package/dist/package.json +115 -0
  4. package/dist/pnpm-lock.yaml +7447 -0
  5. package/dist/public/explorer.css +244 -111
  6. package/dist/public/explorer.js +523 -278
  7. package/dist/scripts/preinstall.js +112 -0
  8. package/dist/server/index.d.ts.map +1 -1
  9. package/dist/server/index.js +4 -9
  10. package/dist/server/index.js.map +1 -1
  11. package/dist/server/index.ts +5 -10
  12. package/dist/server/service/connection.service.d.ts.map +1 -1
  13. package/dist/server/service/connection.service.js +1 -0
  14. package/dist/server/service/connection.service.js.map +1 -1
  15. package/dist/server/service/connection.service.ts +1 -0
  16. package/dist/server/service/database/base.service.d.ts +4 -0
  17. package/dist/server/service/database/base.service.d.ts.map +1 -1
  18. package/dist/server/service/database/base.service.js +3 -3
  19. package/dist/server/service/database/base.service.js.map +1 -1
  20. package/dist/server/service/database/base.service.ts +8 -3
  21. package/dist/server/service/database/cockroachdb.service.d.ts +5 -0
  22. package/dist/server/service/database/cockroachdb.service.d.ts.map +1 -1
  23. package/dist/server/service/database/cockroachdb.service.js +112 -0
  24. package/dist/server/service/database/cockroachdb.service.js.map +1 -1
  25. package/dist/server/service/database/cockroachdb.service.ts +123 -0
  26. package/dist/server/service/database/database.service.d.ts +4 -0
  27. package/dist/server/service/database/database.service.d.ts.map +1 -1
  28. package/dist/server/service/database/database.service.js +8 -0
  29. package/dist/server/service/database/database.service.js.map +1 -1
  30. package/dist/server/service/database/database.service.ts +9 -0
  31. package/dist/server/service/database/mongodb.service.d.ts +6 -0
  32. package/dist/server/service/database/mongodb.service.d.ts.map +1 -1
  33. package/dist/server/service/database/mongodb.service.js +8 -0
  34. package/dist/server/service/database/mongodb.service.js.map +1 -1
  35. package/dist/server/service/database/mongodb.service.ts +9 -0
  36. package/dist/server/service/database/mssql.service.d.ts +4 -0
  37. package/dist/server/service/database/mssql.service.d.ts.map +1 -1
  38. package/dist/server/service/database/mssql.service.js +105 -0
  39. package/dist/server/service/database/mssql.service.js.map +1 -1
  40. package/dist/server/service/database/mssql.service.ts +118 -0
  41. package/dist/server/service/database/mysql.service.d.ts +4 -0
  42. package/dist/server/service/database/mysql.service.d.ts.map +1 -1
  43. package/dist/server/service/database/mysql.service.js +116 -0
  44. package/dist/server/service/database/mysql.service.js.map +1 -1
  45. package/dist/server/service/database/mysql.service.ts +130 -0
  46. package/dist/server/service/database/oracle.service.d.ts +4 -0
  47. package/dist/server/service/database/oracle.service.d.ts.map +1 -1
  48. package/dist/server/service/database/oracle.service.js +114 -0
  49. package/dist/server/service/database/oracle.service.js.map +1 -1
  50. package/dist/server/service/database/oracle.service.ts +128 -0
  51. package/dist/server/service/database/postgres.service.d.ts +4 -0
  52. package/dist/server/service/database/postgres.service.d.ts.map +1 -1
  53. package/dist/server/service/database/postgres.service.js +120 -0
  54. package/dist/server/service/database/postgres.service.js.map +1 -1
  55. package/dist/server/service/database/postgres.service.ts +131 -0
  56. package/dist/server/service/database/sap.service.d.ts +4 -0
  57. package/dist/server/service/database/sap.service.d.ts.map +1 -1
  58. package/dist/server/service/database/sap.service.js +107 -0
  59. package/dist/server/service/database/sap.service.js.map +1 -1
  60. package/dist/server/service/database/sap.service.ts +120 -0
  61. package/dist/server/service/database/sqlite.service.d.ts +5 -0
  62. package/dist/server/service/database/sqlite.service.d.ts.map +1 -1
  63. package/dist/server/service/database/sqlite.service.js +133 -0
  64. package/dist/server/service/database/sqlite.service.js.map +1 -1
  65. package/dist/server/service/database/sqlite.service.ts +150 -0
  66. package/fdb2.server.pid +1 -0
  67. package/package.json +18 -9
  68. package/packages/vscode/.vscodeignore +44 -0
  69. package/packages/vscode/README.md +62 -0
  70. package/packages/vscode/out/database-services/base.service.js +236 -0
  71. package/packages/vscode/out/database-services/base.service.js.map +1 -0
  72. package/packages/vscode/out/database-services/cockroachdb.service.js +634 -0
  73. package/packages/vscode/out/database-services/cockroachdb.service.js.map +1 -0
  74. package/packages/vscode/out/database-services/connection.service.js +346 -0
  75. package/packages/vscode/out/database-services/connection.service.js.map +1 -0
  76. package/packages/vscode/out/database-services/database.service.js +571 -0
  77. package/packages/vscode/out/database-services/database.service.js.map +1 -0
  78. package/packages/vscode/out/database-services/index.js +18 -0
  79. package/packages/vscode/out/database-services/index.js.map +1 -0
  80. package/packages/vscode/out/database-services/model/connection.entity.js +11 -0
  81. package/packages/vscode/out/database-services/model/connection.entity.js.map +1 -0
  82. package/packages/vscode/out/database-services/model/database.entity.js +35 -0
  83. package/packages/vscode/out/database-services/model/database.entity.js.map +1 -0
  84. package/packages/vscode/out/database-services/mongodb.service.js +458 -0
  85. package/packages/vscode/out/database-services/mongodb.service.js.map +1 -0
  86. package/packages/vscode/out/database-services/mssql.service.js +694 -0
  87. package/packages/vscode/out/database-services/mssql.service.js.map +1 -0
  88. package/packages/vscode/out/database-services/mysql.service.js +735 -0
  89. package/packages/vscode/out/database-services/mysql.service.js.map +1 -0
  90. package/packages/vscode/out/database-services/oracle.service.js +787 -0
  91. package/packages/vscode/out/database-services/oracle.service.js.map +1 -0
  92. package/packages/vscode/out/database-services/postgres.service.js +696 -0
  93. package/packages/vscode/out/database-services/postgres.service.js.map +1 -0
  94. package/packages/vscode/out/database-services/sap.service.js +695 -0
  95. package/packages/vscode/out/database-services/sap.service.js.map +1 -0
  96. package/packages/vscode/out/database-services/sqlite.service.js +532 -0
  97. package/packages/vscode/out/database-services/sqlite.service.js.map +1 -0
  98. package/packages/vscode/out/extension.js +93 -0
  99. package/packages/vscode/out/extension.js.map +1 -0
  100. package/packages/vscode/out/provider/DatabaseTreeProvider.js +159 -0
  101. package/packages/vscode/out/provider/DatabaseTreeProvider.js.map +1 -0
  102. package/packages/vscode/out/provider/WebViewProvider.js +259 -0
  103. package/packages/vscode/out/provider/WebViewProvider.js.map +1 -0
  104. package/packages/vscode/out/service/ConnectionManager.js +105 -0
  105. package/packages/vscode/out/service/ConnectionManager.js.map +1 -0
  106. package/packages/vscode/out/service/DatabaseServiceBridge.js +395 -0
  107. package/packages/vscode/out/service/DatabaseServiceBridge.js.map +1 -0
  108. package/packages/vscode/out/typings/connection.js +3 -0
  109. package/packages/vscode/out/typings/connection.js.map +1 -0
  110. package/packages/vscode/package.json +142 -0
  111. package/packages/vscode/resources/icon.svg +5 -0
  112. package/packages/vscode/resources/webview/_plugin-vue_export-helper.js +6529 -0
  113. package/packages/vscode/resources/webview/_plugin-vue_export-helper.js.map +1 -0
  114. package/packages/vscode/resources/webview/connection.css +69 -0
  115. package/packages/vscode/resources/webview/connection.js +228 -0
  116. package/packages/vscode/resources/webview/connection.js.map +1 -0
  117. package/packages/vscode/resources/webview/database.css +259 -0
  118. package/packages/vscode/resources/webview/database.js +275 -0
  119. package/packages/vscode/resources/webview/database.js.map +1 -0
  120. package/packages/vscode/resources/webview/favicon.ico +0 -0
  121. package/packages/vscode/resources/webview/index.html +9 -0
  122. package/packages/vscode/resources/webview/modules/header.tpl +14 -0
  123. package/packages/vscode/resources/webview/modules/initial_state.tpl +55 -0
  124. package/packages/vscode/resources/webview/query.css +162 -0
  125. package/packages/vscode/resources/webview/query.js +198 -0
  126. package/packages/vscode/resources/webview/query.js.map +1 -0
  127. package/packages/vscode/src/database-services/base.service.js.map +1 -0
  128. package/packages/vscode/src/database-services/base.service.ts +363 -0
  129. package/packages/vscode/src/database-services/cockroachdb.service.js.map +1 -0
  130. package/packages/vscode/src/database-services/cockroachdb.service.ts +659 -0
  131. package/packages/vscode/src/database-services/connection.service.ts +341 -0
  132. package/packages/vscode/src/database-services/database.service.ts +630 -0
  133. package/packages/vscode/src/database-services/index.ts +7 -0
  134. package/packages/vscode/src/database-services/model/connection.entity.js +11 -0
  135. package/packages/vscode/src/database-services/model/connection.entity.js.map +1 -0
  136. package/packages/vscode/src/database-services/model/connection.entity.ts +66 -0
  137. package/packages/vscode/src/database-services/model/database.entity.js +35 -0
  138. package/packages/vscode/src/database-services/model/database.entity.js.map +1 -0
  139. package/packages/vscode/src/database-services/model/database.entity.ts +246 -0
  140. package/packages/vscode/src/database-services/mongodb.service.js.map +1 -0
  141. package/packages/vscode/src/database-services/mongodb.service.ts +454 -0
  142. package/packages/vscode/src/database-services/mssql.service.js.map +1 -0
  143. package/packages/vscode/src/database-services/mssql.service.ts +723 -0
  144. package/packages/vscode/src/database-services/mysql.service.js.map +1 -0
  145. package/packages/vscode/src/database-services/mysql.service.ts +761 -0
  146. package/packages/vscode/src/database-services/oracle.service.js.map +1 -0
  147. package/packages/vscode/src/database-services/oracle.service.ts +832 -0
  148. package/packages/vscode/src/database-services/postgres.service.js.map +1 -0
  149. package/packages/vscode/src/database-services/postgres.service.ts +741 -0
  150. package/packages/vscode/src/database-services/sap.service.js.map +1 -0
  151. package/packages/vscode/src/database-services/sap.service.ts +713 -0
  152. package/packages/vscode/src/database-services/sqlite.service.js.map +1 -0
  153. package/packages/vscode/src/database-services/sqlite.service.ts +559 -0
  154. package/packages/vscode/src/extension.ts +76 -0
  155. package/packages/vscode/src/provider/DatabaseTreeProvider.ts +167 -0
  156. package/packages/vscode/src/provider/WebViewProvider.ts +277 -0
  157. package/packages/vscode/src/service/DatabaseServiceBridge.ts +414 -0
  158. package/packages/vscode/src/typings/connection.ts +90 -0
  159. package/packages/vscode/tsconfig.json +21 -0
  160. package/public/fdb2.png +0 -0
  161. package/server/backups/db_ai_breakout_2026-03-11T08-38-48-677Z.sql +0 -0
  162. package/server/index.ts +5 -10
  163. package/server/model/connection.entity.js +11 -0
  164. package/server/model/connection.entity.js.map +1 -0
  165. package/server/model/database.entity.js +35 -0
  166. package/server/model/database.entity.js.map +1 -0
  167. package/server/service/connection.service.ts +1 -0
  168. package/server/service/database/base.service.ts +8 -3
  169. package/server/service/database/cockroachdb.service.ts +123 -0
  170. package/server/service/database/database.service.ts +9 -0
  171. package/server/service/database/mongodb.service.ts +9 -0
  172. package/server/service/database/mssql.service.ts +118 -0
  173. package/server/service/database/mysql.service.ts +130 -0
  174. package/server/service/database/oracle.service.ts +128 -0
  175. package/server/service/database/postgres.service.ts +131 -0
  176. package/server/service/database/sap.service.ts +120 -0
  177. package/server/service/database/sqlite.service.ts +150 -0
  178. package/server/tsconfig.json +20 -0
  179. package/src/components/connection-editor/index.vue +0 -1
  180. package/src/platform/database/components/db-tools.vue +414 -174
  181. package/src/platform/database/components/table-detail.vue +3 -2
  182. package/src/platform/database/components/table-editor.vue +245 -18
  183. package/src/platform/vscode/bridge.ts +121 -0
  184. package/src/platform/vscode/components/ConnectionPanel.vue +272 -0
  185. package/src/platform/vscode/components/DatabasePanel.vue +532 -0
  186. package/src/platform/vscode/components/QueryPanel.vue +371 -0
  187. package/src/platform/vscode/entry/connection.ts +13 -0
  188. package/src/platform/vscode/entry/database.ts +13 -0
  189. package/src/platform/vscode/entry/query.ts +13 -0
  190. package/src/platform/vscode/index.ts +5 -0
  191. package/src/service/database.ts +2 -6
  192. package/vite.config.ts +46 -6
  193. 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
+ }