@optimizely/ocp-local-env 1.0.0-beta.4
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/README.md +165 -0
- package/dist/package.json +104 -0
- package/dist/public/bundle.da978bb5437cd82e6d37.js +3 -0
- package/dist/public/bundle.da978bb5437cd82e6d37.js.LICENSE.txt +49 -0
- package/dist/public/bundle.da978bb5437cd82e6d37.js.map +1 -0
- package/dist/public/index.html +1 -0
- package/dist/src/cli.d.ts +2 -0
- package/dist/src/cli.js +88 -0
- package/dist/src/cli.js.map +1 -0
- package/dist/src/executor/FunctionExecutor.d.ts +56 -0
- package/dist/src/executor/FunctionExecutor.js +175 -0
- package/dist/src/executor/FunctionExecutor.js.map +1 -0
- package/dist/src/executor/JobExecutor.d.ts +60 -0
- package/dist/src/executor/JobExecutor.js +203 -0
- package/dist/src/executor/JobExecutor.js.map +1 -0
- package/dist/src/executor/LifecycleExecutor.d.ts +45 -0
- package/dist/src/executor/LifecycleExecutor.js +153 -0
- package/dist/src/executor/LifecycleExecutor.js.map +1 -0
- package/dist/src/executor/watcher.d.ts +63 -0
- package/dist/src/executor/watcher.js +213 -0
- package/dist/src/executor/watcher.js.map +1 -0
- package/dist/src/functions/hello.d.ts +4 -0
- package/dist/src/functions/hello.js +8 -0
- package/dist/src/functions/hello.js.map +1 -0
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.js +9 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/jobs/dailyJob.d.ts +4 -0
- package/dist/src/jobs/dailyJob.js +8 -0
- package/dist/src/jobs/dailyJob.js.map +1 -0
- package/dist/src/local_engine/LocalNotifier.d.ts +10 -0
- package/dist/src/local_engine/LocalNotifier.js +26 -0
- package/dist/src/local_engine/LocalNotifier.js.map +1 -0
- package/dist/src/local_engine/local-engine-child-base.d.ts +79 -0
- package/dist/src/local_engine/local-engine-child-base.js +304 -0
- package/dist/src/local_engine/local-engine-child-base.js.map +1 -0
- package/dist/src/local_engine/local-engine-client.d.ts +80 -0
- package/dist/src/local_engine/local-engine-client.js +333 -0
- package/dist/src/local_engine/local-engine-client.js.map +1 -0
- package/dist/src/local_engine/local-engine-types.d.ts +132 -0
- package/dist/src/local_engine/local-engine-types.js +6 -0
- package/dist/src/local_engine/local-engine-types.js.map +1 -0
- package/dist/src/local_engine/local-engine-unified.d.ts +40 -0
- package/dist/src/local_engine/local-engine-unified.js +406 -0
- package/dist/src/local_engine/local-engine-unified.js.map +1 -0
- package/dist/src/local_engine/local-engine-utils.d.ts +70 -0
- package/dist/src/local_engine/local-engine-utils.js +192 -0
- package/dist/src/local_engine/local-engine-utils.js.map +1 -0
- package/dist/src/local_engine/localSDKConfig.d.ts +30 -0
- package/dist/src/local_engine/localSDKConfig.js +392 -0
- package/dist/src/local_engine/localSDKConfig.js.map +1 -0
- package/dist/src/local_engine/storage/LocalConfigStore.d.ts +56 -0
- package/dist/src/local_engine/storage/LocalConfigStore.js +129 -0
- package/dist/src/local_engine/storage/LocalConfigStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalJobStore.d.ts +110 -0
- package/dist/src/local_engine/storage/LocalJobStore.js +239 -0
- package/dist/src/local_engine/storage/LocalJobStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalKVStore.d.ts +105 -0
- package/dist/src/local_engine/storage/LocalKVStore.js +1002 -0
- package/dist/src/local_engine/storage/LocalKVStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalNotificationStore.d.ts +27 -0
- package/dist/src/local_engine/storage/LocalNotificationStore.js +125 -0
- package/dist/src/local_engine/storage/LocalNotificationStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalSecretsStore.d.ts +114 -0
- package/dist/src/local_engine/storage/LocalSecretsStore.js +319 -0
- package/dist/src/local_engine/storage/LocalSecretsStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalSettingsStore.d.ts +161 -0
- package/dist/src/local_engine/storage/LocalSettingsStore.js +417 -0
- package/dist/src/local_engine/storage/LocalSettingsStore.js.map +1 -0
- package/dist/src/local_engine/storage/NumberSet.d.ts +21 -0
- package/dist/src/local_engine/storage/NumberSet.js +32 -0
- package/dist/src/local_engine/storage/NumberSet.js.map +1 -0
- package/dist/src/local_engine/storage/StringSet.d.ts +21 -0
- package/dist/src/local_engine/storage/StringSet.js +32 -0
- package/dist/src/local_engine/storage/StringSet.js.map +1 -0
- package/dist/src/local_engine/types.d.ts +52 -0
- package/dist/src/local_engine/types.js +6 -0
- package/dist/src/local_engine/types.js.map +1 -0
- package/dist/src/local_engine/utils.d.ts +31 -0
- package/dist/src/local_engine/utils.js +126 -0
- package/dist/src/local_engine/utils.js.map +1 -0
- package/dist/src/logging/LogManager.d.ts +89 -0
- package/dist/src/logging/LogManager.js +237 -0
- package/dist/src/logging/LogManager.js.map +1 -0
- package/dist/src/server/api/functions.d.ts +7 -0
- package/dist/src/server/api/functions.js +80 -0
- package/dist/src/server/api/functions.js.map +1 -0
- package/dist/src/server/api/jobs.d.ts +8 -0
- package/dist/src/server/api/jobs.js +242 -0
- package/dist/src/server/api/jobs.js.map +1 -0
- package/dist/src/server/api/lifecycle.d.ts +6 -0
- package/dist/src/server/api/lifecycle.js +73 -0
- package/dist/src/server/api/lifecycle.js.map +1 -0
- package/dist/src/server/api/settings.d.ts +6 -0
- package/dist/src/server/api/settings.js +117 -0
- package/dist/src/server/api/settings.js.map +1 -0
- package/dist/src/server/api/stores.d.ts +2 -0
- package/dist/src/server/api/stores.js +341 -0
- package/dist/src/server/api/stores.js.map +1 -0
- package/dist/src/server/api/v1.d.ts +10 -0
- package/dist/src/server/api/v1.js +711 -0
- package/dist/src/server/api/v1.js.map +1 -0
- package/dist/src/server/api.d.ts +8 -0
- package/dist/src/server/api.js +154 -0
- package/dist/src/server/api.js.map +1 -0
- package/dist/src/server/app-discovery.d.ts +5 -0
- package/dist/src/server/app-discovery.js +81 -0
- package/dist/src/server/app-discovery.js.map +1 -0
- package/dist/src/server/config.d.ts +21 -0
- package/dist/src/server/config.js +100 -0
- package/dist/src/server/config.js.map +1 -0
- package/dist/src/server/websocket.d.ts +0 -0
- package/dist/src/server/websocket.js +2 -0
- package/dist/src/server/websocket.js.map +1 -0
- package/dist/src/server.d.ts +2 -0
- package/dist/src/server.js +546 -0
- package/dist/src/server.js.map +1 -0
- package/dist/src/types/app.d.ts +155 -0
- package/dist/src/types/app.js +24 -0
- package/dist/src/types/app.js.map +1 -0
- package/dist/src/types/kvstore.d.ts +320 -0
- package/dist/src/types/kvstore.js +5 -0
- package/dist/src/types/kvstore.js.map +1 -0
- package/dist/src/ui/components/App.d.ts +6 -0
- package/dist/src/ui/components/App.js +255 -0
- package/dist/src/ui/components/App.js.map +1 -0
- package/dist/src/ui/components/FunctionsView.d.ts +6 -0
- package/dist/src/ui/components/FunctionsView.js +217 -0
- package/dist/src/ui/components/FunctionsView.js.map +1 -0
- package/dist/src/ui/components/JobsView.d.ts +6 -0
- package/dist/src/ui/components/JobsView.js +257 -0
- package/dist/src/ui/components/JobsView.js.map +1 -0
- package/dist/src/ui/components/KVStoreViewer.d.ts +11 -0
- package/dist/src/ui/components/KVStoreViewer.js +168 -0
- package/dist/src/ui/components/KVStoreViewer.js.map +1 -0
- package/dist/src/ui/components/NotificationViewer.d.ts +16 -0
- package/dist/src/ui/components/NotificationViewer.js +69 -0
- package/dist/src/ui/components/NotificationViewer.js.map +1 -0
- package/dist/src/ui/components/SecretsStoreViewer.d.ts +11 -0
- package/dist/src/ui/components/SecretsStoreViewer.js +179 -0
- package/dist/src/ui/components/SecretsStoreViewer.js.map +1 -0
- package/dist/src/ui/components/SettingsStoreViewer.d.ts +24 -0
- package/dist/src/ui/components/SettingsStoreViewer.js +132 -0
- package/dist/src/ui/components/SettingsStoreViewer.js.map +1 -0
- package/dist/src/ui/components/StoreViewer.d.ts +16 -0
- package/dist/src/ui/components/StoreViewer.js +86 -0
- package/dist/src/ui/components/StoreViewer.js.map +1 -0
- package/dist/src/ui/components/TabbedConsole.d.ts +15 -0
- package/dist/src/ui/components/TabbedConsole.js +93 -0
- package/dist/src/ui/components/TabbedConsole.js.map +1 -0
- package/dist/src/ui/components/common/DataTree.d.ts +15 -0
- package/dist/src/ui/components/common/DataTree.js +95 -0
- package/dist/src/ui/components/common/DataTree.js.map +1 -0
- package/dist/src/ui/components/common/EyeIcon.d.ts +11 -0
- package/dist/src/ui/components/common/EyeIcon.js +11 -0
- package/dist/src/ui/components/common/EyeIcon.js.map +1 -0
- package/dist/src/ui/index.d.ts +1 -0
- package/dist/src/ui/index.js +20 -0
- package/dist/src/ui/index.js.map +1 -0
- package/package.json +104 -0
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
7
|
+
const react_1 = require("react");
|
|
8
|
+
const EyeIcon_1 = __importDefault(require("./common/EyeIcon"));
|
|
9
|
+
const SecretsStoreViewer = ({ secrets, onUpdate }) => {
|
|
10
|
+
const [expandedSections, setExpandedSections] = (0, react_1.useState)(new Set());
|
|
11
|
+
const [visibleSecrets, setVisibleSecrets] = (0, react_1.useState)(new Set());
|
|
12
|
+
const [editingSecret, setEditingSecret] = (0, react_1.useState)(null);
|
|
13
|
+
const [editValue, setEditValue] = (0, react_1.useState)('');
|
|
14
|
+
const toggleSection = (sectionName) => {
|
|
15
|
+
const newExpanded = new Set(expandedSections);
|
|
16
|
+
if (newExpanded.has(sectionName)) {
|
|
17
|
+
newExpanded.delete(sectionName);
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
newExpanded.add(sectionName);
|
|
21
|
+
}
|
|
22
|
+
setExpandedSections(newExpanded);
|
|
23
|
+
};
|
|
24
|
+
const toggleSecretVisibility = (secretId) => {
|
|
25
|
+
const newVisible = new Set(visibleSecrets);
|
|
26
|
+
if (newVisible.has(secretId)) {
|
|
27
|
+
newVisible.delete(secretId);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
newVisible.add(secretId);
|
|
31
|
+
}
|
|
32
|
+
setVisibleSecrets(newVisible);
|
|
33
|
+
};
|
|
34
|
+
const startEditing = (sectionName, fieldName, currentValue) => {
|
|
35
|
+
const secretId = `${sectionName}.${fieldName}`;
|
|
36
|
+
setEditingSecret(secretId);
|
|
37
|
+
setEditValue(typeof currentValue === 'string' ? currentValue : JSON.stringify(currentValue));
|
|
38
|
+
};
|
|
39
|
+
const saveEdit = async (sectionName, fieldName) => {
|
|
40
|
+
try {
|
|
41
|
+
// Try to parse as JSON first, fallback to string
|
|
42
|
+
let newValue;
|
|
43
|
+
try {
|
|
44
|
+
newValue = JSON.parse(editValue);
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
newValue = editValue;
|
|
48
|
+
}
|
|
49
|
+
// Update via API
|
|
50
|
+
const response = await fetch(`/devserver/api/stores/secrets/${sectionName}`, {
|
|
51
|
+
method: 'PUT',
|
|
52
|
+
headers: {
|
|
53
|
+
'Content-Type': 'application/json',
|
|
54
|
+
},
|
|
55
|
+
body: JSON.stringify({ [fieldName]: newValue }),
|
|
56
|
+
});
|
|
57
|
+
if (!response.ok) {
|
|
58
|
+
throw new Error(`Failed to update secret: ${response.statusText}`);
|
|
59
|
+
}
|
|
60
|
+
const result = await response.json();
|
|
61
|
+
// Update local state
|
|
62
|
+
const updatedSecrets = { ...secrets };
|
|
63
|
+
if (!updatedSecrets[sectionName]) {
|
|
64
|
+
updatedSecrets[sectionName] = {};
|
|
65
|
+
}
|
|
66
|
+
updatedSecrets[sectionName] = result.secrets;
|
|
67
|
+
onUpdate(updatedSecrets);
|
|
68
|
+
setEditingSecret(null);
|
|
69
|
+
setEditValue('');
|
|
70
|
+
}
|
|
71
|
+
catch (error) {
|
|
72
|
+
console.error('Error updating secret:', error);
|
|
73
|
+
alert(`Failed to update secret: ${error instanceof Error ? error.message : String(error)}`);
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
const deleteSecret = async (sectionName, fieldName) => {
|
|
77
|
+
if (!confirm(`Are you sure you want to delete the secret "${fieldName}" from section "${sectionName}"?`)) {
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
try {
|
|
81
|
+
// Create updated section without the field
|
|
82
|
+
const updatedSection = { ...secrets[sectionName] };
|
|
83
|
+
delete updatedSection[fieldName];
|
|
84
|
+
// Update via API
|
|
85
|
+
const response = await fetch(`/devserver/api/stores/secrets/${sectionName}`, {
|
|
86
|
+
method: 'PUT',
|
|
87
|
+
headers: {
|
|
88
|
+
'Content-Type': 'application/json',
|
|
89
|
+
},
|
|
90
|
+
body: JSON.stringify(updatedSection),
|
|
91
|
+
});
|
|
92
|
+
if (!response.ok) {
|
|
93
|
+
throw new Error(`Failed to delete secret: ${response.statusText}`);
|
|
94
|
+
}
|
|
95
|
+
const result = await response.json();
|
|
96
|
+
// Update local state
|
|
97
|
+
const updatedSecrets = { ...secrets };
|
|
98
|
+
updatedSecrets[sectionName] = result.secrets;
|
|
99
|
+
onUpdate(updatedSecrets);
|
|
100
|
+
}
|
|
101
|
+
catch (error) {
|
|
102
|
+
console.error('Error deleting secret:', error);
|
|
103
|
+
alert(`Failed to delete secret: ${error instanceof Error ? error.message : String(error)}`);
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
const addNewSecret = async (sectionName) => {
|
|
107
|
+
const fieldName = prompt('Enter secret name:');
|
|
108
|
+
if (!fieldName)
|
|
109
|
+
return;
|
|
110
|
+
const value = prompt('Enter secret value:');
|
|
111
|
+
if (value === null)
|
|
112
|
+
return; // User cancelled
|
|
113
|
+
try {
|
|
114
|
+
// Update via API
|
|
115
|
+
const response = await fetch(`/devserver/api/stores/secrets/${sectionName}`, {
|
|
116
|
+
method: 'PUT',
|
|
117
|
+
headers: {
|
|
118
|
+
'Content-Type': 'application/json',
|
|
119
|
+
},
|
|
120
|
+
body: JSON.stringify({ [fieldName]: value }),
|
|
121
|
+
});
|
|
122
|
+
if (!response.ok) {
|
|
123
|
+
throw new Error(`Failed to add secret: ${response.statusText}`);
|
|
124
|
+
}
|
|
125
|
+
const result = await response.json();
|
|
126
|
+
// Update local state
|
|
127
|
+
const updatedSecrets = { ...secrets };
|
|
128
|
+
if (!updatedSecrets[sectionName]) {
|
|
129
|
+
updatedSecrets[sectionName] = {};
|
|
130
|
+
}
|
|
131
|
+
updatedSecrets[sectionName] = result.secrets;
|
|
132
|
+
onUpdate(updatedSecrets);
|
|
133
|
+
}
|
|
134
|
+
catch (error) {
|
|
135
|
+
console.error('Error adding secret:', error);
|
|
136
|
+
alert(`Failed to add secret: ${error instanceof Error ? error.message : String(error)}`);
|
|
137
|
+
}
|
|
138
|
+
};
|
|
139
|
+
const cancelEdit = () => {
|
|
140
|
+
setEditingSecret(null);
|
|
141
|
+
setEditValue('');
|
|
142
|
+
};
|
|
143
|
+
const renderSecretValue = (value, secretId) => {
|
|
144
|
+
const isVisible = visibleSecrets.has(secretId);
|
|
145
|
+
const isEditing = editingSecret === secretId;
|
|
146
|
+
if (isEditing) {
|
|
147
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "secret-edit-mode", children: [(0, jsx_runtime_1.jsx)("textarea", { className: "secret-edit-input", value: editValue, onChange: (e) => setEditValue(e.target.value), rows: 2, placeholder: "Enter secret value..." }), (0, jsx_runtime_1.jsxs)("div", { className: "secret-edit-controls", children: [(0, jsx_runtime_1.jsx)("button", { className: "save-btn", onClick: () => {
|
|
148
|
+
const [sectionName, fieldName] = secretId.split('.');
|
|
149
|
+
saveEdit(sectionName, fieldName);
|
|
150
|
+
}, children: "Save" }), (0, jsx_runtime_1.jsx)("button", { className: "cancel-btn", onClick: cancelEdit, children: "Cancel" })] })] }));
|
|
151
|
+
}
|
|
152
|
+
if (!isVisible) {
|
|
153
|
+
return (0, jsx_runtime_1.jsx)("span", { className: "hidden-secret-value", children: '•'.repeat(12) });
|
|
154
|
+
}
|
|
155
|
+
if (value === null || value === undefined) {
|
|
156
|
+
return (0, jsx_runtime_1.jsx)("span", { className: "empty-secret-value", children: "(empty)" });
|
|
157
|
+
}
|
|
158
|
+
if (typeof value === 'string') {
|
|
159
|
+
return (0, jsx_runtime_1.jsxs)("span", { className: "string-secret-value", children: ["\"", value, "\""] });
|
|
160
|
+
}
|
|
161
|
+
return (0, jsx_runtime_1.jsx)("span", { className: "complex-secret-value", children: JSON.stringify(value) });
|
|
162
|
+
};
|
|
163
|
+
const sectionNames = Object.keys(secrets).sort();
|
|
164
|
+
if (sectionNames.length === 0) {
|
|
165
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "secrets-store-viewer empty", children: (0, jsx_runtime_1.jsxs)("div", { className: "empty-message", children: [(0, jsx_runtime_1.jsx)("span", { className: "empty-icon", children: "\uD83D\uDD10" }), (0, jsx_runtime_1.jsx)("p", { children: "No secrets stored" }), (0, jsx_runtime_1.jsx)("button", { className: "add-section-btn", onClick: () => addNewSecret('default'), children: "Add First Secret" })] }) }));
|
|
166
|
+
}
|
|
167
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "secrets-store-viewer compact-store", children: (0, jsx_runtime_1.jsxs)("div", { className: "store-sections", children: [sectionNames.map((sectionName) => {
|
|
168
|
+
const section = secrets[sectionName];
|
|
169
|
+
const fieldNames = Object.keys(section).sort();
|
|
170
|
+
const isExpanded = expandedSections.has(sectionName);
|
|
171
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "store-section", children: [(0, jsx_runtime_1.jsxs)("div", { className: "section-header", onClick: () => toggleSection(sectionName), children: [(0, jsx_runtime_1.jsx)("span", { className: "expand-icon", children: isExpanded ? '▼' : '▶' }), (0, jsx_runtime_1.jsx)("span", { className: "section-name", children: sectionName }), (0, jsx_runtime_1.jsxs)("span", { className: "field-count", children: ["(", fieldNames.length, ")"] })] }), isExpanded && ((0, jsx_runtime_1.jsx)("div", { className: "section-fields", children: fieldNames.map((fieldName) => {
|
|
172
|
+
const value = section[fieldName];
|
|
173
|
+
const secretId = `${sectionName}.${fieldName}`;
|
|
174
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "field-row", children: [(0, jsx_runtime_1.jsx)("div", { className: "field-key", children: fieldName }), (0, jsx_runtime_1.jsx)("div", { className: "field-value", children: renderSecretValue(value, secretId) }), (0, jsx_runtime_1.jsxs)("div", { className: "field-metadata", children: [(0, jsx_runtime_1.jsx)(EyeIcon_1.default, { isVisible: visibleSecrets.has(secretId), onClick: () => toggleSecretVisibility(secretId), className: "metadata-icon" }), (0, jsx_runtime_1.jsx)("button", { className: "edit-icon", onClick: () => startEditing(sectionName, fieldName, value), title: "Edit", children: "\u270F\uFE0F" }), (0, jsx_runtime_1.jsx)("button", { className: "delete-icon", onClick: () => deleteSecret(sectionName, fieldName), title: "Delete", children: "\uD83D\uDDD1\uFE0F" })] })] }, fieldName));
|
|
175
|
+
}) }))] }, sectionName));
|
|
176
|
+
}), sectionNames.length === 0 && ((0, jsx_runtime_1.jsx)("div", { className: "empty-store", children: "No secrets configured" }))] }) }));
|
|
177
|
+
};
|
|
178
|
+
exports.default = SecretsStoreViewer;
|
|
179
|
+
//# sourceMappingURL=SecretsStoreViewer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SecretsStoreViewer.js","sourceRoot":"","sources":["../../../../src/ui/components/SecretsStoreViewer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface SettingsField {
|
|
3
|
+
value: any;
|
|
4
|
+
isSecret: boolean;
|
|
5
|
+
isFromYml: boolean;
|
|
6
|
+
hasLocalValue: boolean;
|
|
7
|
+
fieldSchema?: {
|
|
8
|
+
type?: string;
|
|
9
|
+
secret?: boolean;
|
|
10
|
+
required?: boolean;
|
|
11
|
+
description?: string;
|
|
12
|
+
default?: any;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
interface SettingsStoreViewerProps {
|
|
16
|
+
settings: {
|
|
17
|
+
[sectionName: string]: {
|
|
18
|
+
[fieldName: string]: SettingsField;
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
onUpdate: (updatedSettings: any) => void;
|
|
22
|
+
}
|
|
23
|
+
declare const SettingsStoreViewer: React.FC<SettingsStoreViewerProps>;
|
|
24
|
+
export default SettingsStoreViewer;
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
7
|
+
const react_1 = require("react");
|
|
8
|
+
const EyeIcon_1 = __importDefault(require("./common/EyeIcon"));
|
|
9
|
+
const SettingsStoreViewer = ({ settings, onUpdate }) => {
|
|
10
|
+
const [expandedSections, setExpandedSections] = (0, react_1.useState)(new Set());
|
|
11
|
+
const [hiddenFields, setHiddenFields] = (0, react_1.useState)(new Set());
|
|
12
|
+
const [editingField, setEditingField] = (0, react_1.useState)(null);
|
|
13
|
+
const [editValue, setEditValue] = (0, react_1.useState)('');
|
|
14
|
+
const toggleSection = (sectionName) => {
|
|
15
|
+
const newExpanded = new Set(expandedSections);
|
|
16
|
+
if (newExpanded.has(sectionName)) {
|
|
17
|
+
newExpanded.delete(sectionName);
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
newExpanded.add(sectionName);
|
|
21
|
+
}
|
|
22
|
+
setExpandedSections(newExpanded);
|
|
23
|
+
};
|
|
24
|
+
const toggleFieldVisibility = (fieldId) => {
|
|
25
|
+
const newHidden = new Set(hiddenFields);
|
|
26
|
+
if (newHidden.has(fieldId)) {
|
|
27
|
+
newHidden.delete(fieldId);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
newHidden.add(fieldId);
|
|
31
|
+
}
|
|
32
|
+
setHiddenFields(newHidden);
|
|
33
|
+
};
|
|
34
|
+
const startEditing = (sectionName, fieldName, currentValue) => {
|
|
35
|
+
const fieldId = `${sectionName}.${fieldName}`;
|
|
36
|
+
setEditingField(fieldId);
|
|
37
|
+
setEditValue(typeof currentValue === 'string' ? currentValue : JSON.stringify(currentValue));
|
|
38
|
+
};
|
|
39
|
+
const saveEdit = async (sectionName, fieldName) => {
|
|
40
|
+
try {
|
|
41
|
+
// Try to parse as JSON first, fallback to string
|
|
42
|
+
let newValue;
|
|
43
|
+
try {
|
|
44
|
+
newValue = JSON.parse(editValue);
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
newValue = editValue;
|
|
48
|
+
}
|
|
49
|
+
// Update via API
|
|
50
|
+
const response = await fetch(`/devserver/api/stores/settings/${sectionName}`, {
|
|
51
|
+
method: 'PUT',
|
|
52
|
+
headers: {
|
|
53
|
+
'Content-Type': 'application/json',
|
|
54
|
+
},
|
|
55
|
+
body: JSON.stringify({ [fieldName]: newValue }),
|
|
56
|
+
});
|
|
57
|
+
if (!response.ok) {
|
|
58
|
+
throw new Error(`Failed to update setting: ${response.statusText}`);
|
|
59
|
+
}
|
|
60
|
+
const result = await response.json();
|
|
61
|
+
// Update local state
|
|
62
|
+
const updatedSettings = { ...settings };
|
|
63
|
+
if (!updatedSettings[sectionName]) {
|
|
64
|
+
updatedSettings[sectionName] = {};
|
|
65
|
+
}
|
|
66
|
+
updatedSettings[sectionName] = result.fields;
|
|
67
|
+
onUpdate(updatedSettings);
|
|
68
|
+
setEditingField(null);
|
|
69
|
+
setEditValue('');
|
|
70
|
+
}
|
|
71
|
+
catch (error) {
|
|
72
|
+
console.error('Error updating setting:', error);
|
|
73
|
+
alert(`Failed to update setting: ${error instanceof Error ? error.message : String(error)}`);
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
const cancelEdit = () => {
|
|
77
|
+
setEditingField(null);
|
|
78
|
+
setEditValue('');
|
|
79
|
+
};
|
|
80
|
+
const renderFieldValue = (field, fieldId) => {
|
|
81
|
+
const isHidden = field.isSecret && !hiddenFields.has(fieldId);
|
|
82
|
+
const isEditing = editingField === fieldId;
|
|
83
|
+
if (isEditing) {
|
|
84
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "field-edit-mode", children: [(0, jsx_runtime_1.jsx)("textarea", { className: "field-edit-input", value: editValue, onChange: (e) => setEditValue(e.target.value), rows: 2 }), (0, jsx_runtime_1.jsxs)("div", { className: "field-edit-controls", children: [(0, jsx_runtime_1.jsx)("button", { className: "save-btn", onClick: () => {
|
|
85
|
+
const [sectionName, fieldName] = fieldId.split('.');
|
|
86
|
+
saveEdit(sectionName, fieldName);
|
|
87
|
+
}, children: "Save" }), (0, jsx_runtime_1.jsx)("button", { className: "cancel-btn", onClick: cancelEdit, children: "Cancel" })] })] }));
|
|
88
|
+
}
|
|
89
|
+
if (isHidden) {
|
|
90
|
+
return (0, jsx_runtime_1.jsx)("span", { className: "hidden-field-value", children: '•'.repeat(8) });
|
|
91
|
+
}
|
|
92
|
+
if (field.value === null || field.value === undefined) {
|
|
93
|
+
return (0, jsx_runtime_1.jsx)("span", { className: "empty-field-value", children: "(empty)" });
|
|
94
|
+
}
|
|
95
|
+
if (typeof field.value === 'string') {
|
|
96
|
+
return (0, jsx_runtime_1.jsxs)("span", { className: "string-field-value", children: ["\"", field.value, "\""] });
|
|
97
|
+
}
|
|
98
|
+
return (0, jsx_runtime_1.jsx)("span", { className: "complex-field-value", children: JSON.stringify(field.value) });
|
|
99
|
+
};
|
|
100
|
+
const getFieldTypeInfo = (field) => {
|
|
101
|
+
const info = [];
|
|
102
|
+
if (field.fieldSchema?.type) {
|
|
103
|
+
info.push(field.fieldSchema.type);
|
|
104
|
+
}
|
|
105
|
+
if (field.fieldSchema?.required) {
|
|
106
|
+
info.push('required');
|
|
107
|
+
}
|
|
108
|
+
if (field.isSecret) {
|
|
109
|
+
info.push('secret');
|
|
110
|
+
}
|
|
111
|
+
if (!field.isFromYml) {
|
|
112
|
+
info.push('local only');
|
|
113
|
+
}
|
|
114
|
+
return info.join(', ');
|
|
115
|
+
};
|
|
116
|
+
const sectionNames = Object.keys(settings).sort();
|
|
117
|
+
if (sectionNames.length === 0) {
|
|
118
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "settings-store-viewer empty", children: (0, jsx_runtime_1.jsxs)("div", { className: "empty-message", children: [(0, jsx_runtime_1.jsx)("span", { className: "empty-icon", children: "\u2699\uFE0F" }), (0, jsx_runtime_1.jsx)("p", { children: "No settings configured" })] }) }));
|
|
119
|
+
}
|
|
120
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "settings-store-viewer compact-store", children: (0, jsx_runtime_1.jsx)("div", { className: "store-sections", children: sectionNames.map((sectionName) => {
|
|
121
|
+
const section = settings[sectionName];
|
|
122
|
+
const fieldNames = Object.keys(section).sort();
|
|
123
|
+
const isExpanded = expandedSections.has(sectionName);
|
|
124
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "store-section", children: [(0, jsx_runtime_1.jsxs)("div", { className: "section-header", onClick: () => toggleSection(sectionName), children: [(0, jsx_runtime_1.jsx)("span", { className: "expand-icon", children: isExpanded ? '▼' : '▶' }), (0, jsx_runtime_1.jsx)("span", { className: "section-name", children: sectionName }), (0, jsx_runtime_1.jsxs)("span", { className: "field-count", children: ["(", fieldNames.length, ")"] })] }), isExpanded && ((0, jsx_runtime_1.jsx)("div", { className: "section-fields", children: fieldNames.map((fieldName) => {
|
|
125
|
+
const field = section[fieldName];
|
|
126
|
+
const fieldId = `${sectionName}.${fieldName}`;
|
|
127
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "field-row", children: [(0, jsx_runtime_1.jsx)("div", { className: "field-key", children: fieldName }), (0, jsx_runtime_1.jsx)("div", { className: "field-value", children: renderFieldValue(field, fieldId) }), (0, jsx_runtime_1.jsxs)("div", { className: "field-metadata", children: [field.isSecret && ((0, jsx_runtime_1.jsx)(EyeIcon_1.default, { isVisible: hiddenFields.has(fieldId), onClick: () => toggleFieldVisibility(fieldId), className: "metadata-icon" })), (0, jsx_runtime_1.jsx)("button", { className: "edit-icon", onClick: () => startEditing(sectionName, fieldName, field.value), title: "Edit", children: "\u270F\uFE0F" }), field.hasLocalValue && ((0, jsx_runtime_1.jsx)("span", { className: "metadata-badge local", title: "Has local value", children: "local" })), !field.isFromYml && ((0, jsx_runtime_1.jsx)("span", { className: "metadata-badge local-only", title: "Local only", children: "local only" }))] })] }, fieldName));
|
|
128
|
+
}) }))] }, sectionName));
|
|
129
|
+
}) }) }));
|
|
130
|
+
};
|
|
131
|
+
exports.default = SettingsStoreViewer;
|
|
132
|
+
//# sourceMappingURL=SettingsStoreViewer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SettingsStoreViewer.js","sourceRoot":"","sources":["../../../../src/ui/components/SettingsStoreViewer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
type StoreTab = 'settings' | 'secrets' | 'kv' | 'sharedKv' | 'notifications';
|
|
3
|
+
interface StoreViewerProps {
|
|
4
|
+
initialTab?: StoreTab;
|
|
5
|
+
hideTabs?: boolean;
|
|
6
|
+
storeTimestamps?: {
|
|
7
|
+
settings?: string | null;
|
|
8
|
+
secrets?: string | null;
|
|
9
|
+
kv?: string | null;
|
|
10
|
+
sharedKv?: string | null;
|
|
11
|
+
notifications?: string | null;
|
|
12
|
+
} | null;
|
|
13
|
+
onRefreshStores?: () => void;
|
|
14
|
+
}
|
|
15
|
+
declare const StoreViewer: React.FC<StoreViewerProps>;
|
|
16
|
+
export default StoreViewer;
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
7
|
+
const react_1 = require("react");
|
|
8
|
+
const SettingsStoreViewer_1 = __importDefault(require("./SettingsStoreViewer"));
|
|
9
|
+
const SecretsStoreViewer_1 = __importDefault(require("./SecretsStoreViewer"));
|
|
10
|
+
const KVStoreViewer_1 = __importDefault(require("./KVStoreViewer"));
|
|
11
|
+
const NotificationViewer_1 = __importDefault(require("./NotificationViewer"));
|
|
12
|
+
const StoreViewer = ({ initialTab = "settings", hideTabs = false, storeTimestamps, onRefreshStores, }) => {
|
|
13
|
+
const [activeTab, setActiveTab] = (0, react_1.useState)(initialTab);
|
|
14
|
+
const [storeData, setStoreData] = (0, react_1.useState)(null);
|
|
15
|
+
const [loading, setLoading] = (0, react_1.useState)(true);
|
|
16
|
+
const [error, setError] = (0, react_1.useState)(null);
|
|
17
|
+
const [lastKnownTimestamps, setLastKnownTimestamps] = (0, react_1.useState)(null);
|
|
18
|
+
// Fetch store data from the API
|
|
19
|
+
const fetchStoreData = async () => {
|
|
20
|
+
try {
|
|
21
|
+
setLoading(true);
|
|
22
|
+
setError(null);
|
|
23
|
+
const response = await fetch("/devserver/api/stores");
|
|
24
|
+
if (!response.ok) {
|
|
25
|
+
throw new Error(`HTTP ${response.status}: ${response.statusText}`);
|
|
26
|
+
}
|
|
27
|
+
const data = await response.json();
|
|
28
|
+
setStoreData(data);
|
|
29
|
+
}
|
|
30
|
+
catch (error) {
|
|
31
|
+
console.error("Error fetching store data:", error);
|
|
32
|
+
setError(error instanceof Error ? error.message : String(error));
|
|
33
|
+
}
|
|
34
|
+
finally {
|
|
35
|
+
setLoading(false);
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
// Fetch data on component mount
|
|
39
|
+
(0, react_1.useEffect)(() => {
|
|
40
|
+
fetchStoreData();
|
|
41
|
+
}, []);
|
|
42
|
+
// Update active tab when initialTab changes
|
|
43
|
+
(0, react_1.useEffect)(() => {
|
|
44
|
+
setActiveTab(initialTab);
|
|
45
|
+
}, [initialTab]);
|
|
46
|
+
// Watch for timestamp changes and refresh store data
|
|
47
|
+
(0, react_1.useEffect)(() => {
|
|
48
|
+
if (!storeTimestamps || !lastKnownTimestamps) {
|
|
49
|
+
// First load or no previous timestamps
|
|
50
|
+
if (storeTimestamps) {
|
|
51
|
+
fetchStoreData();
|
|
52
|
+
setLastKnownTimestamps(storeTimestamps);
|
|
53
|
+
}
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
// Check if any timestamps changed
|
|
57
|
+
const timestampsChanged = storeTimestamps.settings !== lastKnownTimestamps.settings ||
|
|
58
|
+
storeTimestamps.secrets !== lastKnownTimestamps.secrets ||
|
|
59
|
+
storeTimestamps.kv !== lastKnownTimestamps.kv ||
|
|
60
|
+
storeTimestamps.sharedKv !== lastKnownTimestamps.sharedKv ||
|
|
61
|
+
storeTimestamps.notifications !== lastKnownTimestamps.notifications;
|
|
62
|
+
if (timestampsChanged) {
|
|
63
|
+
console.log("Store files changed, refreshing data...");
|
|
64
|
+
fetchStoreData();
|
|
65
|
+
setLastKnownTimestamps(storeTimestamps);
|
|
66
|
+
}
|
|
67
|
+
}, [storeTimestamps]);
|
|
68
|
+
// Handle store data updates (when child components modify data)
|
|
69
|
+
const handleStoreUpdate = (updatedData) => {
|
|
70
|
+
if (storeData) {
|
|
71
|
+
setStoreData({ ...storeData, ...updatedData });
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
if (loading) {
|
|
75
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "store-viewer loading", children: (0, jsx_runtime_1.jsx)("div", { className: "loading-message", children: "Loading store data..." }) }));
|
|
76
|
+
}
|
|
77
|
+
if (error) {
|
|
78
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "store-viewer error", children: (0, jsx_runtime_1.jsxs)("div", { className: "error-message", children: [(0, jsx_runtime_1.jsx)("span", { className: "error-icon", children: "\u26A0\uFE0F" }), (0, jsx_runtime_1.jsxs)("span", { children: ["Failed to load store data: ", error] }), (0, jsx_runtime_1.jsx)("button", { className: "retry-btn", onClick: fetchStoreData, children: "Retry" })] }) }));
|
|
79
|
+
}
|
|
80
|
+
if (!storeData) {
|
|
81
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "store-viewer no-data", children: (0, jsx_runtime_1.jsx)("div", { className: "no-data-message", children: "No store data available" }) }));
|
|
82
|
+
}
|
|
83
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "store-viewer", children: [!hideTabs && ((0, jsx_runtime_1.jsxs)("div", { className: "store-tabs", children: [(0, jsx_runtime_1.jsxs)("div", { className: "store-tabs-container", children: [(0, jsx_runtime_1.jsxs)("button", { className: `store-tab ${activeTab === "settings" ? "active" : ""}`, onClick: () => setActiveTab("settings"), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\u2699\uFE0F" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Settings" }), (0, jsx_runtime_1.jsxs)("span", { className: "tab-count", children: ["(", Object.keys(storeData.settings).length, ")"] })] }), (0, jsx_runtime_1.jsxs)("button", { className: `store-tab ${activeTab === "secrets" ? "active" : ""}`, onClick: () => setActiveTab("secrets"), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDD10" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Secrets" }), (0, jsx_runtime_1.jsxs)("span", { className: "tab-count", children: ["(", Object.keys(storeData.secrets).length, ")"] })] }), (0, jsx_runtime_1.jsxs)("button", { className: `store-tab ${activeTab === "kv" ? "active" : ""}`, onClick: () => setActiveTab("kv"), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDDC3\uFE0F" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "KV Store" }), (0, jsx_runtime_1.jsxs)("span", { className: "tab-count", children: ["(", Object.keys(storeData.kv).length, ")"] })] }), (0, jsx_runtime_1.jsxs)("button", { className: `store-tab ${activeTab === "sharedKv" ? "active" : ""}`, onClick: () => setActiveTab("sharedKv"), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDD17" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Shared KV" }), (0, jsx_runtime_1.jsxs)("span", { className: "tab-count", children: ["(", Object.keys(storeData.sharedKv).length, ")"] })] }), (0, jsx_runtime_1.jsxs)("button", { className: `store-tab ${activeTab === "notifications" ? "active" : ""}`, onClick: () => setActiveTab("notifications"), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDD14" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Notifications" }), (0, jsx_runtime_1.jsxs)("span", { className: "tab-count", children: ["(", storeData.notifications.length, ")"] })] })] }), onRefreshStores && ((0, jsx_runtime_1.jsx)("button", { className: "refresh-btn", onClick: onRefreshStores, title: "Refresh store data", children: "\uD83D\uDD04" }))] })), (0, jsx_runtime_1.jsxs)("div", { className: "store-content", children: [hideTabs && onRefreshStores && activeTab !== "notifications" && ((0, jsx_runtime_1.jsx)("div", { className: "store-header", children: (0, jsx_runtime_1.jsx)("button", { className: "refresh-btn", onClick: onRefreshStores, title: "Refresh store data", children: "\uD83D\uDD04" }) })), activeTab === "settings" && ((0, jsx_runtime_1.jsx)(SettingsStoreViewer_1.default, { settings: storeData.settings, onUpdate: (updatedSettings) => handleStoreUpdate({ settings: updatedSettings }) })), activeTab === "secrets" && ((0, jsx_runtime_1.jsx)(SecretsStoreViewer_1.default, { secrets: storeData.secrets, onUpdate: (updatedSecrets) => handleStoreUpdate({ secrets: updatedSecrets }) })), activeTab === "kv" && ((0, jsx_runtime_1.jsx)(KVStoreViewer_1.default, { data: storeData.kv, title: "KV Store", apiEndpoint: "/devserver/api/stores/kv", onUpdate: (updatedKv) => handleStoreUpdate({ kv: updatedKv }) })), activeTab === "sharedKv" && ((0, jsx_runtime_1.jsx)(KVStoreViewer_1.default, { data: storeData.sharedKv, title: "Shared KV Store", apiEndpoint: "/devserver/api/stores/shared-kv", onUpdate: (updatedSharedKv) => handleStoreUpdate({ sharedKv: updatedSharedKv }) })), activeTab === "notifications" && ((0, jsx_runtime_1.jsx)(NotificationViewer_1.default, { notifications: storeData.notifications, onRefresh: onRefreshStores }))] })] }));
|
|
84
|
+
};
|
|
85
|
+
exports.default = StoreViewer;
|
|
86
|
+
//# sourceMappingURL=StoreViewer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StoreViewer.js","sourceRoot":"","sources":["../../../../src/ui/components/StoreViewer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface TabbedConsoleProps {
|
|
3
|
+
logs: string[];
|
|
4
|
+
onClearLogs: () => void;
|
|
5
|
+
storeTimestamps?: {
|
|
6
|
+
settings?: string | null;
|
|
7
|
+
secrets?: string | null;
|
|
8
|
+
kv?: string | null;
|
|
9
|
+
sharedKv?: string | null;
|
|
10
|
+
notifications?: string | null;
|
|
11
|
+
} | null;
|
|
12
|
+
onRefreshStores?: () => void;
|
|
13
|
+
}
|
|
14
|
+
declare const TabbedConsole: React.FC<TabbedConsoleProps>;
|
|
15
|
+
export default TabbedConsole;
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
7
|
+
const react_1 = require("react");
|
|
8
|
+
const StoreViewer_1 = __importDefault(require("./StoreViewer"));
|
|
9
|
+
const TabbedConsole = ({ logs, onClearLogs, storeTimestamps, onRefreshStores }) => {
|
|
10
|
+
const [activeTab, setActiveTab] = (0, react_1.useState)('console');
|
|
11
|
+
const [expanded, setExpanded] = (0, react_1.useState)(false);
|
|
12
|
+
const [height, setHeight] = (0, react_1.useState)(200);
|
|
13
|
+
const dragStateRef = (0, react_1.useRef)({
|
|
14
|
+
isMouseDown: false,
|
|
15
|
+
isDragging: false,
|
|
16
|
+
startY: 0,
|
|
17
|
+
startHeight: 200
|
|
18
|
+
});
|
|
19
|
+
const renderTabContent = () => {
|
|
20
|
+
switch (activeTab) {
|
|
21
|
+
case 'console':
|
|
22
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "console-tab-content", children: [(0, jsx_runtime_1.jsx)("div", { className: "console-controls", children: (0, jsx_runtime_1.jsx)("button", { className: "clear-logs-btn", onClick: onClearLogs, children: "Clear Logs" }) }), (0, jsx_runtime_1.jsx)("div", { className: "log-container", children: logs.length > 0 ? (logs.map((log, index) => {
|
|
23
|
+
// Determine log level for styling
|
|
24
|
+
const logLevel = log.includes(' ERROR:') ? 'error' :
|
|
25
|
+
log.includes(' WARN:') ? 'warn' :
|
|
26
|
+
log.includes(' DEBUG:') ? 'debug' : 'info';
|
|
27
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: `log-line log-${logLevel}`, children: log }, index));
|
|
28
|
+
})) : ((0, jsx_runtime_1.jsx)("div", { className: "no-logs", children: "No console output yet" })) })] }));
|
|
29
|
+
case 'settings':
|
|
30
|
+
case 'secrets':
|
|
31
|
+
case 'kv':
|
|
32
|
+
case 'sharedKv':
|
|
33
|
+
case 'notifications':
|
|
34
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "store-tab-content", children: (0, jsx_runtime_1.jsx)(StoreViewer_1.default, { initialTab: activeTab, hideTabs: true, storeTimestamps: storeTimestamps, onRefreshStores: onRefreshStores }) }));
|
|
35
|
+
default:
|
|
36
|
+
return null;
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
// Handle mouse resize events - ONLY for resize handle
|
|
40
|
+
const handleResizeMouseDown = (e) => {
|
|
41
|
+
e.preventDefault();
|
|
42
|
+
e.stopPropagation();
|
|
43
|
+
dragStateRef.current = {
|
|
44
|
+
isMouseDown: true,
|
|
45
|
+
isDragging: false,
|
|
46
|
+
startY: e.clientY,
|
|
47
|
+
startHeight: height
|
|
48
|
+
};
|
|
49
|
+
const handleMouseMove = (e) => {
|
|
50
|
+
const current = dragStateRef.current;
|
|
51
|
+
if (!current.isMouseDown)
|
|
52
|
+
return;
|
|
53
|
+
// Only start dragging if the mouse has moved enough
|
|
54
|
+
if (!current.isDragging) {
|
|
55
|
+
const deltaY = Math.abs(current.startY - e.clientY);
|
|
56
|
+
// Only start dragging if mouse moved at least 5px
|
|
57
|
+
if (deltaY < 5)
|
|
58
|
+
return;
|
|
59
|
+
current.isDragging = true;
|
|
60
|
+
document.body.style.cursor = 'ns-resize';
|
|
61
|
+
document.body.style.userSelect = 'none';
|
|
62
|
+
}
|
|
63
|
+
// Only resize if we're actually dragging
|
|
64
|
+
if (current.isDragging) {
|
|
65
|
+
const deltaY = current.startY - e.clientY; // Inverted: moving up increases height
|
|
66
|
+
const newHeight = current.startHeight + deltaY;
|
|
67
|
+
const minHeight = 100;
|
|
68
|
+
const maxHeight = window.innerHeight * 0.8;
|
|
69
|
+
const clampedHeight = Math.max(minHeight, Math.min(maxHeight, newHeight));
|
|
70
|
+
setHeight(clampedHeight);
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
const handleMouseUp = () => {
|
|
74
|
+
dragStateRef.current = {
|
|
75
|
+
isMouseDown: false,
|
|
76
|
+
isDragging: false,
|
|
77
|
+
startY: 0,
|
|
78
|
+
startHeight: height // Keep current height instead of resetting to 200
|
|
79
|
+
};
|
|
80
|
+
document.body.style.cursor = '';
|
|
81
|
+
document.body.style.userSelect = '';
|
|
82
|
+
// Remove event listeners
|
|
83
|
+
document.removeEventListener('mousemove', handleMouseMove);
|
|
84
|
+
document.removeEventListener('mouseup', handleMouseUp);
|
|
85
|
+
};
|
|
86
|
+
// Add event listeners
|
|
87
|
+
document.addEventListener('mousemove', handleMouseMove);
|
|
88
|
+
document.addEventListener('mouseup', handleMouseUp);
|
|
89
|
+
};
|
|
90
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: `console-panel ${expanded ? 'expanded' : 'collapsed'}`, style: { height: expanded ? `${height}px` : '32px' }, children: [expanded && ((0, jsx_runtime_1.jsx)("div", { className: "console-resize-handle", onMouseDown: handleResizeMouseDown })), (0, jsx_runtime_1.jsxs)("div", { className: "console-tab-headers", children: [(0, jsx_runtime_1.jsxs)("button", { className: `console-tab ${activeTab === 'console' ? 'active' : ''}`, onClick: () => setActiveTab('console'), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDCCB" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Console" }), (0, jsx_runtime_1.jsxs)("span", { className: "tab-count", children: ["(", logs.length, ")"] })] }), (0, jsx_runtime_1.jsxs)("button", { className: `console-tab ${activeTab === 'settings' ? 'active' : ''}`, onClick: () => setActiveTab('settings'), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\u2699\uFE0F" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Settings" })] }), (0, jsx_runtime_1.jsxs)("button", { className: `console-tab ${activeTab === 'secrets' ? 'active' : ''}`, onClick: () => setActiveTab('secrets'), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDD10" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Secrets" })] }), (0, jsx_runtime_1.jsxs)("button", { className: `console-tab ${activeTab === 'kv' ? 'active' : ''}`, onClick: () => setActiveTab('kv'), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDDC3\uFE0F" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "KV Store" })] }), (0, jsx_runtime_1.jsxs)("button", { className: `console-tab ${activeTab === 'sharedKv' ? 'active' : ''}`, onClick: () => setActiveTab('sharedKv'), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDD17" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Shared KV" })] }), (0, jsx_runtime_1.jsxs)("button", { className: `console-tab ${activeTab === 'notifications' ? 'active' : ''}`, onClick: () => setActiveTab('notifications'), children: [(0, jsx_runtime_1.jsx)("span", { className: "tab-icon", children: "\uD83D\uDD14" }), (0, jsx_runtime_1.jsx)("span", { className: "tab-label", children: "Notifications" })] }), (0, jsx_runtime_1.jsx)("button", { className: "console-toggle", onClick: () => setExpanded(!expanded), children: expanded ? '▼' : '▲' })] }), expanded && ((0, jsx_runtime_1.jsx)("div", { className: "console-content", children: (0, jsx_runtime_1.jsx)("div", { className: "console-tab-body", children: renderTabContent() }) }))] }));
|
|
91
|
+
};
|
|
92
|
+
exports.default = TabbedConsole;
|
|
93
|
+
//# sourceMappingURL=TabbedConsole.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TabbedConsole.js","sourceRoot":"","sources":["../../../../src/ui/components/TabbedConsole.tsx"],"names":[],"mappings":";;;;;;AAAA,iCAA2D;AAC3D,gEAAwC;AAkBxC,MAAM,aAAa,GAAiC,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,eAAe,EAAE,eAAe,EAAE,EAAE,EAAE;IAC9G,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,IAAA,gBAAQ,EAAa,SAAS,CAAC,CAAC;IAClE,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAC;IAChD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,IAAA,gBAAQ,EAAC,GAAG,CAAC,CAAC;IAC1C,MAAM,YAAY,GAAG,IAAA,cAAM,EAAC;QAC1B,WAAW,EAAE,KAAK;QAClB,UAAU,EAAE,KAAK;QACjB,MAAM,EAAE,CAAC;QACT,WAAW,EAAE,GAAG;KACjB,CAAC,CAAC;IAEH,MAAM,gBAAgB,GAAG,GAAG,EAAE;QAC5B,QAAQ,SAAS,EAAE;YACjB,KAAK,SAAS;gBACZ,OAAO,CACL,iCAAK,SAAS,EAAC,qBAAqB,aAClC,gCAAK,SAAS,EAAC,kBAAkB,YAC/B,mCAAQ,SAAS,EAAC,gBAAgB,EAAC,OAAO,EAAE,WAAW,2BAE9C,GACL,EACN,gCAAK,SAAS,EAAC,eAAe,YAC3B,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CACjB,IAAI,CAAC,GAAG,CAAC,CAAC,GAAW,EAAE,KAAa,EAAE,EAAE;gCACtC,kCAAkC;gCAClC,MAAM,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;oCACpC,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;wCACjC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;gCAE3D,OAAO,CACL,gCAAiB,SAAS,EAAE,gBAAgB,QAAQ,EAAE,YACnD,GAAG,IADI,KAAK,CAET,CACP,CAAC;4BACJ,CAAC,CAAC,CACH,CAAC,CAAC,CAAC,CACF,gCAAK,SAAS,EAAC,SAAS,sCAA4B,CACrD,GACG,IACF,CACP,CAAC;YAEJ,KAAK,UAAU,CAAC;YAChB,KAAK,SAAS,CAAC;YACf,KAAK,IAAI,CAAC;YACV,KAAK,UAAU,CAAC;YAChB,KAAK,eAAe;gBAClB,OAAO,CACL,gCAAK,SAAS,EAAC,mBAAmB,YAChC,uBAAC,qBAAW,IACV,UAAU,EAAE,SAAS,EACrB,QAAQ,EAAE,IAAI,EACd,eAAe,EAAE,eAAe,EAChC,eAAe,EAAE,eAAe,GAChC,GACE,CACP,CAAC;YAEJ;gBACE,OAAO,IAAI,CAAC;SACf;IACH,CAAC,CAAC;IAEF,sDAAsD;IACtD,MAAM,qBAAqB,GAAG,CAAC,CAAmB,EAAE,EAAE;QACpD,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;QAEpB,YAAY,CAAC,OAAO,GAAG;YACrB,WAAW,EAAE,IAAI;YACjB,UAAU,EAAE,KAAK;YACjB,MAAM,EAAE,CAAC,CAAC,OAAO;YACjB,WAAW,EAAE,MAAM;SACpB,CAAC;QAEF,MAAM,eAAe,GAAG,CAAC,CAAa,EAAE,EAAE;YACxC,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,CAAC;YACrC,IAAI,CAAC,OAAO,CAAC,WAAW;gBAAE,OAAO;YAEjC,oDAAoD;YACpD,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE;gBACvB,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;gBACpD,kDAAkD;gBAClD,IAAI,MAAM,GAAG,CAAC;oBAAE,OAAO;gBAEvB,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;gBAC1B,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,WAAW,CAAC;gBACzC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,MAAM,CAAC;aACzC;YAED,yCAAyC;YACzC,IAAI,OAAO,CAAC,UAAU,EAAE;gBACtB,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,uCAAuC;gBAClF,MAAM,SAAS,GAAG,OAAO,CAAC,WAAW,GAAG,MAAM,CAAC;gBAC/C,MAAM,SAAS,GAAG,GAAG,CAAC;gBACtB,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,GAAG,GAAG,CAAC;gBAE3C,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC;gBAC1E,SAAS,CAAC,aAAa,CAAC,CAAC;aAC1B;QACH,CAAC,CAAC;QAEF,MAAM,aAAa,GAAG,GAAG,EAAE;YACzB,YAAY,CAAC,OAAO,GAAG;gBACrB,WAAW,EAAE,KAAK;gBAClB,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,CAAC;gBACT,WAAW,EAAE,MAAM,CAAE,kDAAkD;aACxE,CAAC;YACF,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC;YAChC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,EAAE,CAAC;YAEpC,yBAAyB;YACzB,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;YAC3D,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;QACzD,CAAC,CAAC;QAEF,sBAAsB;QACtB,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;QACxD,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;IACtD,CAAC,CAAC;IAEF,OAAO,CACL,iCACE,SAAS,EAAE,iBAAiB,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW,EAAE,EACjE,KAAK,EAAE,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE,aAGnD,QAAQ,IAAI,CACX,gCACE,SAAS,EAAC,uBAAuB,EACjC,WAAW,EAAE,qBAAqB,GAClC,CACH,EAGD,iCAAK,SAAS,EAAC,qBAAqB,aAClC,oCACE,SAAS,EAAE,eAAe,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACnE,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,SAAS,CAAC,aAEtC,iCAAM,SAAS,EAAC,UAAU,6BAAU,EACpC,iCAAM,SAAS,EAAC,WAAW,wBAAe,EAC1C,kCAAM,SAAS,EAAC,WAAW,kBAAG,IAAI,CAAC,MAAM,SAAS,IAC3C,EAET,oCACE,SAAS,EAAE,eAAe,SAAS,KAAK,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACpE,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,aAEvC,iCAAM,SAAS,EAAC,UAAU,6BAAU,EACpC,iCAAM,SAAS,EAAC,WAAW,yBAAgB,IACpC,EAET,oCACE,SAAS,EAAE,eAAe,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACnE,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,SAAS,CAAC,aAEtC,iCAAM,SAAS,EAAC,UAAU,6BAAU,EACpC,iCAAM,SAAS,EAAC,WAAW,wBAAe,IACnC,EAET,oCACE,SAAS,EAAE,eAAe,SAAS,KAAK,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EAC9D,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,aAEjC,iCAAM,SAAS,EAAC,UAAU,mCAAW,EACrC,iCAAM,SAAS,EAAC,WAAW,yBAAgB,IACpC,EAET,oCACE,SAAS,EAAE,eAAe,SAAS,KAAK,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACpE,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,aAEvC,iCAAM,SAAS,EAAC,UAAU,6BAAU,EACpC,iCAAM,SAAS,EAAC,WAAW,0BAAiB,IACrC,EAET,oCACE,SAAS,EAAE,eAAe,SAAS,KAAK,eAAe,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACzE,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,eAAe,CAAC,aAE5C,iCAAM,SAAS,EAAC,UAAU,6BAAU,EACpC,iCAAM,SAAS,EAAC,WAAW,8BAAqB,IACzC,EAET,mCAAQ,SAAS,EAAC,gBAAgB,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,YACrE,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GACd,IACL,EAEL,QAAQ,IAAI,CACX,gCAAK,SAAS,EAAC,iBAAiB,YAE9B,gCAAK,SAAS,EAAC,kBAAkB,YAC9B,gBAAgB,EAAE,GACf,GACF,CACP,IACG,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,aAAa,CAAC"}
|