@optimizely/ocp-local-env 1.0.0-beta.10
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 +51 -0
- package/dist/package.json +112 -0
- package/dist/public/bundle.82dc5d29fffb9f205051.js +3 -0
- package/dist/public/bundle.82dc5d29fffb9f205051.js.LICENSE.txt +92 -0
- package/dist/public/bundle.82dc5d29fffb9f205051.js.map +1 -0
- package/dist/public/index.html +1 -0
- package/dist/src/cli.d.ts +2 -0
- package/dist/src/cli.js +115 -0
- package/dist/src/cli.js.map +1 -0
- package/dist/src/executor/DestinationExecutor.d.ts +19 -0
- package/dist/src/executor/DestinationExecutor.js +72 -0
- package/dist/src/executor/DestinationExecutor.js.map +1 -0
- package/dist/src/executor/FunctionExecutor.d.ts +67 -0
- package/dist/src/executor/FunctionExecutor.js +189 -0
- package/dist/src/executor/FunctionExecutor.js.map +1 -0
- package/dist/src/executor/JobExecutor.d.ts +79 -0
- package/dist/src/executor/JobExecutor.js +215 -0
- package/dist/src/executor/JobExecutor.js.map +1 -0
- package/dist/src/executor/LifecycleExecutor.d.ts +64 -0
- package/dist/src/executor/LifecycleExecutor.js +167 -0
- package/dist/src/executor/LifecycleExecutor.js.map +1 -0
- package/dist/src/executor/SourceExecutor.d.ts +32 -0
- package/dist/src/executor/SourceExecutor.js +163 -0
- package/dist/src/executor/SourceExecutor.js.map +1 -0
- package/dist/src/executor/watcher.d.ts +62 -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/LocalFunctionApi.d.ts +17 -0
- package/dist/src/local_engine/LocalFunctionApi.js +54 -0
- package/dist/src/local_engine/LocalFunctionApi.js.map +1 -0
- package/dist/src/local_engine/LocalJobApi.d.ts +67 -0
- package/dist/src/local_engine/LocalJobApi.js +205 -0
- package/dist/src/local_engine/LocalJobApi.js.map +1 -0
- package/dist/src/local_engine/LocalNotifier.d.ts +9 -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 +110 -0
- package/dist/src/local_engine/local-engine-child-base.js +607 -0
- package/dist/src/local_engine/local-engine-child-base.js.map +1 -0
- package/dist/src/local_engine/local-engine-client.d.ts +161 -0
- package/dist/src/local_engine/local-engine-client.js +888 -0
- package/dist/src/local_engine/local-engine-client.js.map +1 -0
- package/dist/src/local_engine/local-engine-types.d.ts +245 -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 +71 -0
- package/dist/src/local_engine/local-engine-unified.js +723 -0
- package/dist/src/local_engine/local-engine-unified.js.map +1 -0
- package/dist/src/local_engine/local-engine-utils.d.ts +68 -0
- package/dist/src/local_engine/local-engine-utils.js +219 -0
- package/dist/src/local_engine/local-engine-utils.js.map +1 -0
- package/dist/src/local_engine/localSDKConfig.d.ts +40 -0
- package/dist/src/local_engine/localSDKConfig.js +247 -0
- package/dist/src/local_engine/localSDKConfig.js.map +1 -0
- package/dist/src/local_engine/storage/BaseKVStoreWrapper.d.ts +37 -0
- package/dist/src/local_engine/storage/BaseKVStoreWrapper.js +110 -0
- package/dist/src/local_engine/storage/BaseKVStoreWrapper.js.map +1 -0
- package/dist/src/local_engine/storage/LocalConfigStore.d.ts +74 -0
- package/dist/src/local_engine/storage/LocalConfigStore.js +178 -0
- package/dist/src/local_engine/storage/LocalConfigStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalJobStore.d.ts +111 -0
- package/dist/src/local_engine/storage/LocalJobStore.js +249 -0
- package/dist/src/local_engine/storage/LocalJobStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalKVStore.d.ts +106 -0
- package/dist/src/local_engine/storage/LocalKVStore.js +1061 -0
- package/dist/src/local_engine/storage/LocalKVStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalNotificationStore.d.ts +28 -0
- package/dist/src/local_engine/storage/LocalNotificationStore.js +149 -0
- package/dist/src/local_engine/storage/LocalNotificationStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalSecretsStore.d.ts +115 -0
- package/dist/src/local_engine/storage/LocalSecretsStore.js +350 -0
- package/dist/src/local_engine/storage/LocalSecretsStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalSecretsStoreWrapper.d.ts +19 -0
- package/dist/src/local_engine/storage/LocalSecretsStoreWrapper.js +52 -0
- package/dist/src/local_engine/storage/LocalSecretsStoreWrapper.js.map +1 -0
- package/dist/src/local_engine/storage/LocalSettingsStore.d.ts +168 -0
- package/dist/src/local_engine/storage/LocalSettingsStore.js +509 -0
- package/dist/src/local_engine/storage/LocalSettingsStore.js.map +1 -0
- package/dist/src/local_engine/storage/LocalSettingsStoreWrapper.d.ts +15 -0
- package/dist/src/local_engine/storage/LocalSettingsStoreWrapper.js +28 -0
- package/dist/src/local_engine/storage/LocalSettingsStoreWrapper.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/SourceDataStore.d.ts +23 -0
- package/dist/src/local_engine/storage/SourceDataStore.js +83 -0
- package/dist/src/local_engine/storage/SourceDataStore.js.map +1 -0
- package/dist/src/local_engine/storage/SourceJobExecutionStore.d.ts +25 -0
- package/dist/src/local_engine/storage/SourceJobExecutionStore.js +61 -0
- package/dist/src/local_engine/storage/SourceJobExecutionStore.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 +53 -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 +33 -0
- package/dist/src/local_engine/utils.js +143 -0
- package/dist/src/local_engine/utils.js.map +1 -0
- package/dist/src/logging/LogManager.d.ts +246 -0
- package/dist/src/logging/LogManager.js +343 -0
- package/dist/src/logging/LogManager.js.map +1 -0
- package/dist/src/server/api/destinations.d.ts +7 -0
- package/dist/src/server/api/destinations.js +170 -0
- package/dist/src/server/api/destinations.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 +10 -0
- package/dist/src/server/api/jobs.js +244 -0
- package/dist/src/server/api/jobs.js.map +1 -0
- package/dist/src/server/api/settings.d.ts +6 -0
- package/dist/src/server/api/settings.js +116 -0
- package/dist/src/server/api/settings.js.map +1 -0
- package/dist/src/server/api/sources.d.ts +7 -0
- package/dist/src/server/api/sources.js +382 -0
- package/dist/src/server/api/sources.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 +718 -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 +217 -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 +113 -0
- package/dist/src/server/app-discovery.js.map +1 -0
- package/dist/src/server/config.d.ts +26 -0
- package/dist/src/server/config.js +112 -0
- package/dist/src/server/config.js.map +1 -0
- package/dist/src/server/mockDataGenerator.d.ts +1 -0
- package/dist/src/server/mockDataGenerator.js +154 -0
- package/dist/src/server/mockDataGenerator.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 +735 -0
- package/dist/src/server.js.map +1 -0
- package/dist/src/types/app.d.ts +154 -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 +432 -0
- package/dist/src/ui/components/App.js.map +1 -0
- package/dist/src/ui/components/DestinationBatchEditor.d.ts +7 -0
- package/dist/src/ui/components/DestinationBatchEditor.js +160 -0
- package/dist/src/ui/components/DestinationBatchEditor.js.map +1 -0
- package/dist/src/ui/components/DestinationSchemaViewer.d.ts +7 -0
- package/dist/src/ui/components/DestinationSchemaViewer.js +61 -0
- package/dist/src/ui/components/DestinationSchemaViewer.js.map +1 -0
- package/dist/src/ui/components/DestinationsView.d.ts +14 -0
- package/dist/src/ui/components/DestinationsView.js +68 -0
- package/dist/src/ui/components/DestinationsView.js.map +1 -0
- package/dist/src/ui/components/FunctionsView.d.ts +13 -0
- package/dist/src/ui/components/FunctionsView.js +288 -0
- package/dist/src/ui/components/FunctionsView.js.map +1 -0
- package/dist/src/ui/components/JobsView.d.ts +13 -0
- package/dist/src/ui/components/JobsView.js +320 -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/MetadataModal.d.ts +14 -0
- package/dist/src/ui/components/MetadataModal.js +28 -0
- package/dist/src/ui/components/MetadataModal.js.map +1 -0
- package/dist/src/ui/components/MetadataModal.test.d.ts +1 -0
- package/dist/src/ui/components/MetadataModal.test.js +143 -0
- package/dist/src/ui/components/MetadataModal.test.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/SourceDataViewer.d.ts +8 -0
- package/dist/src/ui/components/SourceDataViewer.js +84 -0
- package/dist/src/ui/components/SourceDataViewer.js.map +1 -0
- package/dist/src/ui/components/SourceJobsSection.d.ts +8 -0
- package/dist/src/ui/components/SourceJobsSection.js +99 -0
- package/dist/src/ui/components/SourceJobsSection.js.map +1 -0
- package/dist/src/ui/components/SourceLifecycleSection.d.ts +7 -0
- package/dist/src/ui/components/SourceLifecycleSection.js +58 -0
- package/dist/src/ui/components/SourceLifecycleSection.js.map +1 -0
- package/dist/src/ui/components/SourceSchemaViewer.d.ts +7 -0
- package/dist/src/ui/components/SourceSchemaViewer.js +65 -0
- package/dist/src/ui/components/SourceSchemaViewer.js.map +1 -0
- package/dist/src/ui/components/SourceWebhookEditor.d.ts +8 -0
- package/dist/src/ui/components/SourceWebhookEditor.js +181 -0
- package/dist/src/ui/components/SourceWebhookEditor.js.map +1 -0
- package/dist/src/ui/components/SourcesView.d.ts +14 -0
- package/dist/src/ui/components/SourcesView.js +74 -0
- package/dist/src/ui/components/SourcesView.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 +17 -0
- package/dist/src/ui/components/TabbedConsole.js +163 -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/hooks/useEntityNavigation.d.ts +72 -0
- package/dist/src/ui/hooks/useEntityNavigation.js +150 -0
- package/dist/src/ui/hooks/useEntityNavigation.js.map +1 -0
- package/dist/src/ui/hooks/useQueryParams.d.ts +6 -0
- package/dist/src/ui/hooks/useQueryParams.js +39 -0
- package/dist/src/ui/hooks/useQueryParams.js.map +1 -0
- package/dist/src/ui/index.d.ts +1 -0
- package/dist/src/ui/index.js +23 -0
- package/dist/src/ui/index.js.map +1 -0
- package/dist/src/ui/store/formStateSlice.d.ts +54 -0
- package/dist/src/ui/store/formStateSlice.js +94 -0
- package/dist/src/ui/store/formStateSlice.js.map +1 -0
- package/dist/src/ui/store/hooks.d.ts +6 -0
- package/dist/src/ui/store/hooks.js +8 -0
- package/dist/src/ui/store/hooks.js.map +1 -0
- package/dist/src/ui/store/index.d.ts +11 -0
- package/dist/src/ui/store/index.js +107 -0
- package/dist/src/ui/store/index.js.map +1 -0
- package/dist/src/utils/functionEndpoints.d.ts +24 -0
- package/dist/src/utils/functionEndpoints.js +45 -0
- package/dist/src/utils/functionEndpoints.js.map +1 -0
- package/package.json +112 -0
|
@@ -0,0 +1,143 @@
|
|
|
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("@testing-library/react");
|
|
8
|
+
const user_event_1 = __importDefault(require("@testing-library/user-event"));
|
|
9
|
+
require("@testing-library/jest-dom");
|
|
10
|
+
const MetadataModal_1 = require("./MetadataModal");
|
|
11
|
+
describe('MetadataModal', () => {
|
|
12
|
+
const defaultProps = {
|
|
13
|
+
isOpen: true,
|
|
14
|
+
onClose: jest.fn(),
|
|
15
|
+
attempt: '1',
|
|
16
|
+
syncId: 'test-sync-id',
|
|
17
|
+
syncName: 'Test Sync',
|
|
18
|
+
onAttemptChange: jest.fn(),
|
|
19
|
+
onSyncIdChange: jest.fn(),
|
|
20
|
+
onSyncNameChange: jest.fn(),
|
|
21
|
+
};
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
jest.clearAllMocks();
|
|
24
|
+
});
|
|
25
|
+
it('should render modal when isOpen is true', () => {
|
|
26
|
+
const { getByText, getByLabelText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
27
|
+
expect(getByText('Batch Metadata')).toBeInTheDocument();
|
|
28
|
+
expect(getByLabelText('Attempt:')).toBeInTheDocument();
|
|
29
|
+
expect(getByLabelText('Sync ID:')).toBeInTheDocument();
|
|
30
|
+
expect(getByLabelText('Sync Name:')).toBeInTheDocument();
|
|
31
|
+
});
|
|
32
|
+
it('should not render modal when isOpen is false', () => {
|
|
33
|
+
const { queryByText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps, isOpen: false }));
|
|
34
|
+
expect(queryByText('Batch Metadata')).not.toBeInTheDocument();
|
|
35
|
+
});
|
|
36
|
+
it('should display correct initial values', () => {
|
|
37
|
+
const { getByLabelText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
38
|
+
const attemptInput = getByLabelText('Attempt:');
|
|
39
|
+
const syncIdInput = getByLabelText('Sync ID:');
|
|
40
|
+
const syncNameInput = getByLabelText('Sync Name:');
|
|
41
|
+
expect(attemptInput.value).toBe('1');
|
|
42
|
+
expect(syncIdInput.value).toBe('test-sync-id');
|
|
43
|
+
expect(syncNameInput.value).toBe('Test Sync');
|
|
44
|
+
});
|
|
45
|
+
it('should call onAttemptChange when attempt input changes', async () => {
|
|
46
|
+
const user = user_event_1.default.setup();
|
|
47
|
+
const { getByLabelText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
48
|
+
const attemptInput = getByLabelText('Attempt:');
|
|
49
|
+
await user.clear(attemptInput);
|
|
50
|
+
await user.type(attemptInput, '2');
|
|
51
|
+
expect(defaultProps.onAttemptChange).toHaveBeenCalled();
|
|
52
|
+
});
|
|
53
|
+
it('should call onSyncIdChange when sync ID input changes', async () => {
|
|
54
|
+
const user = user_event_1.default.setup();
|
|
55
|
+
const { getByLabelText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
56
|
+
const syncIdInput = getByLabelText('Sync ID:');
|
|
57
|
+
await user.clear(syncIdInput);
|
|
58
|
+
await user.type(syncIdInput, 'new-id');
|
|
59
|
+
expect(defaultProps.onSyncIdChange).toHaveBeenCalled();
|
|
60
|
+
});
|
|
61
|
+
it('should call onSyncNameChange when sync name input changes', async () => {
|
|
62
|
+
const user = user_event_1.default.setup();
|
|
63
|
+
const { getByLabelText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
64
|
+
const syncNameInput = getByLabelText('Sync Name:');
|
|
65
|
+
await user.clear(syncNameInput);
|
|
66
|
+
await user.type(syncNameInput, 'New Name');
|
|
67
|
+
expect(defaultProps.onSyncNameChange).toHaveBeenCalled();
|
|
68
|
+
});
|
|
69
|
+
it('should close modal when ESC key is pressed', async () => {
|
|
70
|
+
const user = user_event_1.default.setup();
|
|
71
|
+
const { container } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
72
|
+
const overlay = container.querySelector('.metadata-modal-overlay');
|
|
73
|
+
overlay.focus();
|
|
74
|
+
await user.keyboard('{Escape}');
|
|
75
|
+
expect(defaultProps.onClose).toHaveBeenCalledTimes(1);
|
|
76
|
+
});
|
|
77
|
+
it('should not close modal when other keys are pressed', async () => {
|
|
78
|
+
const user = user_event_1.default.setup();
|
|
79
|
+
const { container } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
80
|
+
const overlay = container.querySelector('.metadata-modal-overlay');
|
|
81
|
+
overlay.focus();
|
|
82
|
+
await user.keyboard('{Enter}');
|
|
83
|
+
await user.keyboard('a');
|
|
84
|
+
expect(defaultProps.onClose).not.toHaveBeenCalled();
|
|
85
|
+
});
|
|
86
|
+
it('should close modal when clicking outside (on overlay)', async () => {
|
|
87
|
+
const user = user_event_1.default.setup();
|
|
88
|
+
const { container } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
89
|
+
const overlay = container.querySelector('.metadata-modal-overlay');
|
|
90
|
+
if (overlay) {
|
|
91
|
+
await user.click(overlay);
|
|
92
|
+
expect(defaultProps.onClose).toHaveBeenCalledTimes(1);
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
it('should not close modal when clicking inside content', async () => {
|
|
96
|
+
const user = user_event_1.default.setup();
|
|
97
|
+
const { getByText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
98
|
+
const content = getByText('Batch Metadata').parentElement;
|
|
99
|
+
if (content) {
|
|
100
|
+
await user.click(content);
|
|
101
|
+
expect(defaultProps.onClose).not.toHaveBeenCalled();
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
it('should close modal when clicking the close button', async () => {
|
|
105
|
+
const user = user_event_1.default.setup();
|
|
106
|
+
const { getByText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
107
|
+
const closeButton = getByText('×');
|
|
108
|
+
await user.click(closeButton);
|
|
109
|
+
expect(defaultProps.onClose).toHaveBeenCalledTimes(1);
|
|
110
|
+
});
|
|
111
|
+
it('should show auto-save indicator', () => {
|
|
112
|
+
const { getByText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
113
|
+
expect(getByText('Changes auto-saved')).toBeInTheDocument();
|
|
114
|
+
});
|
|
115
|
+
it('should cleanup event listener when modal is closed', async () => {
|
|
116
|
+
const user = user_event_1.default.setup();
|
|
117
|
+
const { container, rerender } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
118
|
+
const overlay = container.querySelector('.metadata-modal-overlay');
|
|
119
|
+
overlay.focus();
|
|
120
|
+
await user.keyboard('{Escape}');
|
|
121
|
+
expect(defaultProps.onClose).toHaveBeenCalledTimes(1);
|
|
122
|
+
defaultProps.onClose.mockClear();
|
|
123
|
+
rerender((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps, isOpen: false }));
|
|
124
|
+
// ESC should not trigger callback anymore when modal is closed
|
|
125
|
+
await user.keyboard('{Escape}');
|
|
126
|
+
expect(defaultProps.onClose).not.toHaveBeenCalled();
|
|
127
|
+
});
|
|
128
|
+
it('should have proper input types', () => {
|
|
129
|
+
const { getByLabelText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
130
|
+
const attemptInput = getByLabelText('Attempt:');
|
|
131
|
+
const syncIdInput = getByLabelText('Sync ID:');
|
|
132
|
+
const syncNameInput = getByLabelText('Sync Name:');
|
|
133
|
+
expect(attemptInput.type).toBe('number');
|
|
134
|
+
expect(syncIdInput.type).toBe('text');
|
|
135
|
+
expect(syncNameInput.type).toBe('text');
|
|
136
|
+
});
|
|
137
|
+
it('should have min attribute on attempt input', () => {
|
|
138
|
+
const { getByLabelText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(MetadataModal_1.MetadataModal, { ...defaultProps }));
|
|
139
|
+
const attemptInput = getByLabelText('Attempt:');
|
|
140
|
+
expect(attemptInput.min).toBe('1');
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
//# sourceMappingURL=MetadataModal.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetadataModal.test.js","sourceRoot":"","sources":["../../../../src/ui/components/MetadataModal.test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface NotificationEntry {
|
|
3
|
+
id: string;
|
|
4
|
+
status: 'info' | 'success' | 'warn' | 'error';
|
|
5
|
+
activity: string;
|
|
6
|
+
title: string;
|
|
7
|
+
summary: string;
|
|
8
|
+
details?: string;
|
|
9
|
+
timestamp: string;
|
|
10
|
+
}
|
|
11
|
+
interface NotificationViewerProps {
|
|
12
|
+
notifications: NotificationEntry[];
|
|
13
|
+
onRefresh?: () => void;
|
|
14
|
+
}
|
|
15
|
+
declare const NotificationViewer: React.FC<NotificationViewerProps>;
|
|
16
|
+
export default NotificationViewer;
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
const NotificationViewer = ({ notifications, onRefresh }) => {
|
|
6
|
+
const [expandedNotifications, setExpandedNotifications] = (0, react_1.useState)(new Set());
|
|
7
|
+
const toggleNotification = (id) => {
|
|
8
|
+
const newExpanded = new Set(expandedNotifications);
|
|
9
|
+
if (newExpanded.has(id)) {
|
|
10
|
+
newExpanded.delete(id);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
newExpanded.add(id);
|
|
14
|
+
}
|
|
15
|
+
setExpandedNotifications(newExpanded);
|
|
16
|
+
};
|
|
17
|
+
const clearAllNotifications = async () => {
|
|
18
|
+
if (!confirm('Are you sure you want to clear all notifications?')) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
try {
|
|
22
|
+
const response = await fetch('/devserver/api/stores/notifications', {
|
|
23
|
+
method: 'DELETE',
|
|
24
|
+
});
|
|
25
|
+
if (response.ok && onRefresh) {
|
|
26
|
+
onRefresh();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
catch (error) {
|
|
30
|
+
console.error('Error clearing notifications:', error);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
const deleteNotification = async (id) => {
|
|
34
|
+
try {
|
|
35
|
+
const response = await fetch(`/devserver/api/stores/notifications/${id}`, {
|
|
36
|
+
method: 'DELETE',
|
|
37
|
+
});
|
|
38
|
+
if (response.ok && onRefresh) {
|
|
39
|
+
onRefresh();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
console.error('Error deleting notification:', error);
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
const formatTimestamp = (timestamp) => {
|
|
47
|
+
return new Date(timestamp).toLocaleString();
|
|
48
|
+
};
|
|
49
|
+
const getStatusIcon = (status) => {
|
|
50
|
+
switch (status) {
|
|
51
|
+
case 'info': return 'ℹ️';
|
|
52
|
+
case 'success': return '✅';
|
|
53
|
+
case 'warn': return '⚠️';
|
|
54
|
+
case 'error': return '❌';
|
|
55
|
+
default: return 'ℹ️';
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
// Sort notifications by timestamp (newest first)
|
|
59
|
+
const sortedNotifications = [...notifications].sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime());
|
|
60
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: "notification-viewer", children: [(0, jsx_runtime_1.jsxs)("div", { className: "notification-controls", children: [(0, jsx_runtime_1.jsx)("button", { className: "clear-notifications-btn", onClick: clearAllNotifications, children: "Clear All" }), onRefresh && ((0, jsx_runtime_1.jsx)("button", { className: "refresh-notifications-btn", onClick: onRefresh, children: "Refresh" }))] }), (0, jsx_runtime_1.jsx)("div", { className: "notification-list", children: sortedNotifications.length > 0 ? (sortedNotifications.map((notification) => {
|
|
61
|
+
const isExpanded = expandedNotifications.has(notification.id);
|
|
62
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: `notification-item notification-${notification.status}`, children: [(0, jsx_runtime_1.jsxs)("div", { className: "notification-header", onClick: () => toggleNotification(notification.id), children: [(0, jsx_runtime_1.jsx)("div", { className: "notification-main", children: (0, jsx_runtime_1.jsxs)("div", { className: "notification-single-line", children: [(0, jsx_runtime_1.jsx)("span", { className: "notification-icon", children: getStatusIcon(notification.status) }), (0, jsx_runtime_1.jsx)("span", { className: "notification-activity", children: notification.activity }), (0, jsx_runtime_1.jsx)("span", { className: "notification-separator", children: "\u2022" }), (0, jsx_runtime_1.jsx)("span", { className: "notification-title", children: notification.title }), (0, jsx_runtime_1.jsx)("span", { className: "notification-separator", children: "\u2022" }), (0, jsx_runtime_1.jsx)("span", { className: "notification-summary", children: notification.summary }), (0, jsx_runtime_1.jsx)("span", { className: "notification-timestamp", children: formatTimestamp(notification.timestamp) })] }) }), (0, jsx_runtime_1.jsxs)("div", { className: "notification-actions", children: [(0, jsx_runtime_1.jsx)("button", { className: "delete-notification-btn", onClick: (e) => {
|
|
63
|
+
e.stopPropagation();
|
|
64
|
+
deleteNotification(notification.id);
|
|
65
|
+
}, title: "Delete notification", children: "\uD83D\uDDD1\uFE0F" }), (0, jsx_runtime_1.jsx)("span", { className: "expand-icon", children: isExpanded ? '▼' : '▶' })] })] }), isExpanded && notification.details && ((0, jsx_runtime_1.jsx)("div", { className: "notification-details", children: (0, jsx_runtime_1.jsx)("pre", { children: notification.details }) }))] }, notification.id));
|
|
66
|
+
})) : ((0, jsx_runtime_1.jsx)("div", { className: "no-notifications", children: "No notifications yet" })) })] }));
|
|
67
|
+
};
|
|
68
|
+
exports.default = NotificationViewer;
|
|
69
|
+
//# sourceMappingURL=NotificationViewer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotificationViewer.js","sourceRoot":"","sources":["../../../../src/ui/components/NotificationViewer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface SecretsStoreViewerProps {
|
|
3
|
+
secrets: {
|
|
4
|
+
[sectionName: string]: {
|
|
5
|
+
[fieldName: string]: any;
|
|
6
|
+
};
|
|
7
|
+
};
|
|
8
|
+
onUpdate: (updatedSecrets: any) => void;
|
|
9
|
+
}
|
|
10
|
+
declare const SecretsStoreViewer: React.FC<SecretsStoreViewerProps>;
|
|
11
|
+
export default SecretsStoreViewer;
|
|
@@ -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
|