@djangocfg/ui-tools 2.1.268 → 2.1.271

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/dist/PlaygroundLayout-G325I6HM.mjs +736 -0
  2. package/dist/PlaygroundLayout-G325I6HM.mjs.map +1 -0
  3. package/dist/PlaygroundLayout-ZO2LO7M5.cjs +743 -0
  4. package/dist/PlaygroundLayout-ZO2LO7M5.cjs.map +1 -0
  5. package/dist/{PrettyCode.client-OO3KAJSM.mjs → PrettyCode.client-DW5LTG47.mjs} +5 -5
  6. package/dist/PrettyCode.client-DW5LTG47.mjs.map +1 -0
  7. package/dist/{PrettyCode.client-V2ZN5DTH.cjs → PrettyCode.client-SGDGQTYT.cjs} +5 -5
  8. package/dist/PrettyCode.client-SGDGQTYT.cjs.map +1 -0
  9. package/dist/{chunk-SZ2CZEQZ.mjs → chunk-QZ55LYK2.mjs} +141 -169
  10. package/dist/chunk-QZ55LYK2.mjs.map +1 -0
  11. package/dist/{chunk-CRHHUOVJ.cjs → chunk-WM4RT5KX.cjs} +139 -169
  12. package/dist/chunk-WM4RT5KX.cjs.map +1 -0
  13. package/dist/index.cjs +8 -8
  14. package/dist/index.mjs +5 -5
  15. package/package.json +6 -6
  16. package/src/tools/OpenapiViewer/README.md +121 -0
  17. package/src/tools/OpenapiViewer/components/PlaygroundLayout/EndpointList.tsx +228 -0
  18. package/src/tools/OpenapiViewer/components/PlaygroundLayout/RequestPanel.tsx +258 -0
  19. package/src/tools/OpenapiViewer/components/PlaygroundLayout/ResponsePanel.tsx +127 -0
  20. package/src/tools/OpenapiViewer/components/PlaygroundLayout/index.tsx +107 -0
  21. package/src/tools/OpenapiViewer/components/PlaygroundLayout/ui.tsx +137 -0
  22. package/src/tools/OpenapiViewer/components/index.ts +0 -9
  23. package/src/tools/OpenapiViewer/context/PlaygroundContext.tsx +198 -208
  24. package/src/tools/OpenapiViewer/types.ts +1 -0
  25. package/src/tools/PrettyCode/PrettyCode.client.tsx +17 -12
  26. package/dist/PlaygroundLayout-FKXSULJ3.cjs +0 -971
  27. package/dist/PlaygroundLayout-FKXSULJ3.cjs.map +0 -1
  28. package/dist/PlaygroundLayout-XMMHPZYP.mjs +0 -964
  29. package/dist/PlaygroundLayout-XMMHPZYP.mjs.map +0 -1
  30. package/dist/PrettyCode.client-OO3KAJSM.mjs.map +0 -1
  31. package/dist/PrettyCode.client-V2ZN5DTH.cjs.map +0 -1
  32. package/dist/chunk-CRHHUOVJ.cjs.map +0 -1
  33. package/dist/chunk-SZ2CZEQZ.mjs.map +0 -1
  34. package/src/tools/OpenapiViewer/components/EndpointInfo.tsx +0 -149
  35. package/src/tools/OpenapiViewer/components/EndpointsLibrary.tsx +0 -278
  36. package/src/tools/OpenapiViewer/components/PlaygroundLayout.tsx +0 -91
  37. package/src/tools/OpenapiViewer/components/PlaygroundStepper.tsx +0 -100
  38. package/src/tools/OpenapiViewer/components/RequestBuilder.tsx +0 -157
  39. package/src/tools/OpenapiViewer/components/RequestParametersForm.tsx +0 -253
  40. package/src/tools/OpenapiViewer/components/ResponseViewer.tsx +0 -173
  41. package/src/tools/OpenapiViewer/components/VersionSelector.tsx +0 -68
@@ -10,7 +10,7 @@ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
10
10
  var React2__default = /*#__PURE__*/_interopDefault(React2);
11
11
  var consola__default = /*#__PURE__*/_interopDefault(consola);
12
12
 
13
- var PrettyCodeClient = React2.lazy(() => import('./PrettyCode.client-V2ZN5DTH.cjs'));
13
+ var PrettyCodeClient = React2.lazy(() => import('./PrettyCode.client-SGDGQTYT.cjs'));
14
14
  var LoadingFallback = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(() => /* @__PURE__ */ jsxRuntime.jsx("div", { className: "relative rounded-sm border border-border overflow-hidden bg-muted dark:bg-zinc-900", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "p-4", children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center gap-2", children: [
15
15
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "animate-pulse h-4 w-4 rounded-full bg-muted-foreground/20" }),
16
16
  /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-xs text-muted-foreground", children: "Loading code..." })
@@ -84,29 +84,7 @@ var getDefaultVersion = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(() => {
84
84
  throw new Error("No API versions defined");
85
85
  }, "getDefaultVersion");
86
86
 
87
- // src/tools/OpenapiViewer/constants.ts
88
- var HTTP_METHOD_COLORS = {
89
- GET: "success",
90
- POST: "primary",
91
- PUT: "warning",
92
- DELETE: "error",
93
- PATCH: "default"
94
- };
95
- var HTTP_STATUS_COLORS = {
96
- "2": "success",
97
- "3": "default",
98
- "4": "warning",
99
- "5": "error"
100
- };
101
-
102
87
  // src/tools/OpenapiViewer/utils/formatters.ts
103
- var getMethodColor = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((method) => {
104
- return HTTP_METHOD_COLORS[method.toUpperCase()] || "default";
105
- }, "getMethodColor");
106
- var getStatusColor = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((status) => {
107
- const firstDigit = Math.floor(status / 100).toString();
108
- return HTTP_STATUS_COLORS[firstDigit] || "default";
109
- }, "getStatusColor");
110
88
  var isValidJson = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((str) => {
111
89
  if (!str || typeof str !== "string") return false;
112
90
  try {
@@ -143,15 +121,12 @@ var substituteUrlParameters = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((url, par
143
121
  return substitutedUrl;
144
122
  }, "substituteUrlParameters");
145
123
  var createInitialState = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(() => ({
146
- // Step management
147
124
  currentStep: "endpoints",
148
125
  steps: ["endpoints", "request", "response"],
149
- // Endpoint selection
150
126
  selectedEndpoint: null,
151
127
  selectedCategory: "All",
152
128
  searchTerm: "",
153
129
  selectedVersion: getDefaultVersion().id,
154
- // Request configuration
155
130
  requestUrl: "",
156
131
  requestMethod: "GET",
157
132
  requestHeaders: '{\n "Content-Type": "application/json"\n}',
@@ -159,170 +134,168 @@ var createInitialState = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(() => ({
159
134
  selectedApiKey: null,
160
135
  manualApiToken: "",
161
136
  parameters: {},
162
- // Response
163
137
  response: null,
164
138
  loading: false,
165
- // UI state
166
139
  sidebarOpen: false
167
140
  }), "createInitialState");
141
+ function reducer(state, action) {
142
+ switch (action.type) {
143
+ case "SET_STEP":
144
+ return { ...state, currentStep: action.step };
145
+ case "NEXT_STEP": {
146
+ const i = state.steps.indexOf(state.currentStep);
147
+ return i < state.steps.length - 1 ? { ...state, currentStep: state.steps[i + 1] } : state;
148
+ }
149
+ case "PREV_STEP": {
150
+ const i = state.steps.indexOf(state.currentStep);
151
+ return i > 0 ? { ...state, currentStep: state.steps[i - 1] } : state;
152
+ }
153
+ case "SELECT_ENDPOINT":
154
+ if (!action.endpoint) return { ...state, selectedEndpoint: null };
155
+ return {
156
+ ...state,
157
+ selectedEndpoint: action.endpoint,
158
+ requestMethod: action.endpoint.method,
159
+ requestUrl: action.endpoint.path,
160
+ parameters: {},
161
+ currentStep: "request"
162
+ };
163
+ case "SET_CATEGORY":
164
+ return { ...state, selectedCategory: action.category };
165
+ case "SET_SEARCH":
166
+ return { ...state, searchTerm: action.term };
167
+ case "SET_VERSION":
168
+ return { ...state, selectedVersion: action.version };
169
+ case "SET_REQUEST_URL":
170
+ return { ...state, requestUrl: action.url };
171
+ case "SET_REQUEST_METHOD":
172
+ return { ...state, requestMethod: action.method };
173
+ case "SET_REQUEST_HEADERS":
174
+ return { ...state, requestHeaders: action.headers };
175
+ case "SET_REQUEST_BODY":
176
+ return { ...state, requestBody: action.body };
177
+ case "SET_API_KEY":
178
+ return { ...state, selectedApiKey: action.apiKeyId };
179
+ case "SET_MANUAL_TOKEN":
180
+ return { ...state, manualApiToken: action.token };
181
+ case "SET_PARAMETERS":
182
+ return { ...state, parameters: action.parameters };
183
+ case "SET_RESPONSE":
184
+ return { ...state, response: action.response };
185
+ case "SET_LOADING":
186
+ return { ...state, loading: action.loading };
187
+ case "REQUEST_START":
188
+ return { ...state, loading: true, response: null };
189
+ case "REQUEST_SUCCESS":
190
+ return { ...state, loading: false, response: action.response, currentStep: "response" };
191
+ case "REQUEST_ERROR":
192
+ return { ...state, loading: false, response: action.response };
193
+ case "SET_SIDEBAR":
194
+ return { ...state, sidebarOpen: action.open };
195
+ case "SYNC_API_KEY_HEADER":
196
+ return { ...state, requestHeaders: action.headers };
197
+ case "CLEAR_API_KEY_SELECTION":
198
+ return { ...state, selectedApiKey: null };
199
+ case "SYNC_URL":
200
+ return { ...state, requestUrl: action.url };
201
+ case "RESET":
202
+ return createInitialState();
203
+ default:
204
+ return state;
205
+ }
206
+ }
207
+ chunkWGEGR3DF_cjs.__name(reducer, "reducer");
168
208
  var PlaygroundContext = React2.createContext(void 0);
169
209
  var usePlaygroundContext = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(() => {
170
210
  const context = React2.useContext(PlaygroundContext);
171
- if (!context) {
172
- throw new Error("usePlaygroundContext must be used within a PlaygroundProvider");
173
- }
211
+ if (!context) throw new Error("usePlaygroundContext must be used within a PlaygroundProvider");
174
212
  return context;
175
213
  }, "usePlaygroundContext");
176
214
  var PlaygroundProvider = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(({ children, config }) => {
177
- const [state, setState] = React2.useState(() => createInitialState());
215
+ const [state, dispatch] = React2.useReducer(reducer, void 0, createInitialState);
216
+ const abortControllerRef = React2.useRef(null);
178
217
  const apiKeys = React2__default.default.useMemo(() => [], []);
179
218
  const isLoadingApiKeys = false;
180
- const updateState = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((updates) => {
181
- setState((prev) => ({ ...prev, ...updates }));
182
- }, "updateState");
183
219
  React2.useEffect(() => {
184
220
  if (apiKeys.length > 0 && !state.selectedApiKey) {
185
- updateState({ selectedApiKey: apiKeys[0]?.id || null });
221
+ dispatch({ type: "SET_API_KEY", apiKeyId: apiKeys[0]?.id || null });
186
222
  }
187
223
  }, [apiKeys, isLoadingApiKeys, state.selectedApiKey]);
188
224
  React2.useEffect(() => {
189
225
  try {
190
- setState((prev) => {
191
- const headers = parseRequestHeaders(prev.requestHeaders);
192
- let hasChanged = false;
193
- if (prev.selectedApiKey) {
194
- const apiKey = apiKeys.find((k) => k.id === prev.selectedApiKey);
195
- if (apiKey) {
196
- if (headers["X-API-Key"] !== apiKey.id) {
197
- headers["X-API-Key"] = apiKey.id;
198
- hasChanged = true;
199
- }
200
- } else {
201
- return { ...prev, selectedApiKey: null };
202
- }
203
- } else {
204
- if (headers["X-API-Key"]) {
205
- delete headers["X-API-Key"];
206
- hasChanged = true;
207
- }
226
+ const headers = parseRequestHeaders(state.requestHeaders);
227
+ if (state.selectedApiKey) {
228
+ const apiKey = apiKeys.find((k) => k.id === state.selectedApiKey);
229
+ if (!apiKey) {
230
+ dispatch({ type: "CLEAR_API_KEY_SELECTION" });
231
+ return;
208
232
  }
209
- if (hasChanged) {
210
- const updatedHeaders = JSON.stringify(headers, null, 2);
211
- return { ...prev, requestHeaders: updatedHeaders };
233
+ if (headers["X-API-Key"] !== apiKey.id) {
234
+ headers["X-API-Key"] = apiKey.id;
235
+ dispatch({ type: "SYNC_API_KEY_HEADER", headers: JSON.stringify(headers, null, 2) });
212
236
  }
213
- return prev;
214
- });
237
+ } else if (headers["X-API-Key"]) {
238
+ delete headers["X-API-Key"];
239
+ dispatch({ type: "SYNC_API_KEY_HEADER", headers: JSON.stringify(headers, null, 2) });
240
+ }
215
241
  } catch (error) {
216
242
  consola__default.default.error("Error updating headers:", error);
217
243
  }
218
244
  }, [state.selectedApiKey, apiKeys]);
219
245
  React2.useEffect(() => {
220
- if (state.selectedEndpoint && state.parameters) {
221
- const updatedUrl = substituteUrlParameters(state.selectedEndpoint.path, state.parameters);
222
- if (updatedUrl !== state.requestUrl) {
223
- updateState({ requestUrl: updatedUrl });
224
- }
225
- }
226
- }, [state.parameters, state.selectedEndpoint, state.requestUrl]);
227
- const setCurrentStep = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((step) => {
228
- updateState({ currentStep: step });
229
- }, "setCurrentStep");
230
- const goToNextStep = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(() => {
231
- const currentIndex = state.steps.indexOf(state.currentStep);
232
- if (currentIndex < state.steps.length - 1) {
233
- updateState({ currentStep: state.steps[currentIndex + 1] });
234
- }
235
- }, "goToNextStep");
236
- const goToPreviousStep = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(() => {
237
- const currentIndex = state.steps.indexOf(state.currentStep);
238
- if (currentIndex > 0) {
239
- updateState({ currentStep: state.steps[currentIndex - 1] });
246
+ if (!state.selectedEndpoint) return;
247
+ const updated = substituteUrlParameters(state.selectedEndpoint.path, state.parameters);
248
+ if (updated !== state.requestUrl) {
249
+ dispatch({ type: "SYNC_URL", url: updated });
240
250
  }
241
- }, "goToPreviousStep");
242
- const setSelectedEndpoint = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((endpoint) => {
243
- if (endpoint) {
244
- updateState({
245
- selectedEndpoint: endpoint,
246
- requestMethod: endpoint.method,
247
- requestUrl: endpoint.path,
248
- parameters: {},
249
- // Reset parameters when endpoint changes
250
- currentStep: "request"
251
- });
252
- } else {
253
- updateState({ selectedEndpoint: endpoint });
254
- }
255
- }, "setSelectedEndpoint");
256
- const setSelectedCategory = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((category) => {
257
- updateState({ selectedCategory: category });
258
- }, "setSelectedCategory");
259
- const setSearchTerm = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((term) => {
260
- updateState({ searchTerm: term });
261
- }, "setSearchTerm");
262
- const setSelectedVersion = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((version) => {
263
- updateState({ selectedVersion: version });
264
- }, "setSelectedVersion");
265
- const setRequestUrl = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((url) => {
266
- updateState({ requestUrl: url });
267
- }, "setRequestUrl");
268
- const setRequestMethod = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((method) => {
269
- updateState({ requestMethod: method });
270
- }, "setRequestMethod");
271
- const setRequestHeaders = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((headers) => {
272
- updateState({ requestHeaders: headers });
273
- }, "setRequestHeaders");
274
- const setRequestBody = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((body) => {
275
- updateState({ requestBody: body });
276
- }, "setRequestBody");
277
- const setSelectedApiKey = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((apiKeyId) => {
278
- updateState({ selectedApiKey: apiKeyId });
279
- }, "setSelectedApiKey");
280
- const setManualApiToken = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((manualApiToken) => {
281
- updateState({ manualApiToken });
282
- }, "setManualApiToken");
283
- const setParameters = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((parameters) => {
284
- updateState({ parameters });
285
- }, "setParameters");
286
- const setResponse = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((response) => {
287
- updateState({ response });
288
- }, "setResponse");
289
- const setLoading = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((loading) => {
290
- updateState({ loading });
291
- }, "setLoading");
292
- const setSidebarOpen = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name((sidebarOpen) => {
293
- updateState({ sidebarOpen });
294
- }, "setSidebarOpen");
295
- const clearAll = React2.useCallback(() => {
296
- setState(createInitialState());
297
- }, []);
251
+ }, [state.parameters, state.selectedEndpoint]);
252
+ const setCurrentStep = React2.useCallback((step) => dispatch({ type: "SET_STEP", step }), []);
253
+ const goToNextStep = React2.useCallback(() => dispatch({ type: "NEXT_STEP" }), []);
254
+ const goToPreviousStep = React2.useCallback(() => dispatch({ type: "PREV_STEP" }), []);
255
+ const setSelectedEndpoint = React2.useCallback((endpoint) => dispatch({ type: "SELECT_ENDPOINT", endpoint }), []);
256
+ const setSelectedCategory = React2.useCallback((category) => dispatch({ type: "SET_CATEGORY", category }), []);
257
+ const setSearchTerm = React2.useCallback((term) => dispatch({ type: "SET_SEARCH", term }), []);
258
+ const setSelectedVersion = React2.useCallback((version) => dispatch({ type: "SET_VERSION", version }), []);
259
+ const setRequestUrl = React2.useCallback((url) => dispatch({ type: "SET_REQUEST_URL", url }), []);
260
+ const setRequestMethod = React2.useCallback((method) => dispatch({ type: "SET_REQUEST_METHOD", method }), []);
261
+ const setRequestHeaders = React2.useCallback((headers) => dispatch({ type: "SET_REQUEST_HEADERS", headers }), []);
262
+ const setRequestBody = React2.useCallback((body) => dispatch({ type: "SET_REQUEST_BODY", body }), []);
263
+ const setSelectedApiKey = React2.useCallback((apiKeyId) => dispatch({ type: "SET_API_KEY", apiKeyId }), []);
264
+ const setManualApiToken = React2.useCallback((token) => dispatch({ type: "SET_MANUAL_TOKEN", token }), []);
265
+ const setParameters = React2.useCallback((parameters) => dispatch({ type: "SET_PARAMETERS", parameters }), []);
266
+ const setResponse = React2.useCallback((response) => dispatch({ type: "SET_RESPONSE", response }), []);
267
+ const setLoading = React2.useCallback((loading) => dispatch({ type: "SET_LOADING", loading }), []);
268
+ const setSidebarOpen = React2.useCallback((open) => dispatch({ type: "SET_SIDEBAR", open }), []);
269
+ const clearAll = React2.useCallback(() => dispatch({ type: "RESET" }), []);
298
270
  const sendRequest = React2.useCallback(async () => {
299
271
  if (!state.requestUrl) {
300
272
  consola__default.default.error("No URL provided");
301
273
  return;
302
274
  }
303
- setLoading(true);
304
- setResponse(null);
275
+ abortControllerRef.current?.abort();
276
+ const controller = new AbortController();
277
+ abortControllerRef.current = controller;
278
+ dispatch({ type: "REQUEST_START" });
279
+ const startTime = Date.now();
305
280
  try {
306
281
  const headers = parseRequestHeaders(state.requestHeaders);
307
282
  let bearerToken = null;
308
283
  if (state.manualApiToken) {
309
284
  bearerToken = state.manualApiToken;
310
- } else {
311
- if (typeof window !== "undefined") {
312
- bearerToken = window.localStorage.getItem("auth_token");
313
- }
314
- }
315
- if (bearerToken) {
316
- headers["Authorization"] = `Bearer ${bearerToken}`;
285
+ } else if (typeof window !== "undefined") {
286
+ bearerToken = window.localStorage.getItem("auth_token");
317
287
  }
288
+ if (bearerToken) headers["Authorization"] = `Bearer ${bearerToken}`;
318
289
  const requestOptions = {
319
290
  method: state.requestMethod,
320
- headers
291
+ headers,
292
+ signal: controller.signal
321
293
  };
322
294
  if (state.requestBody && state.requestMethod !== "GET") {
323
295
  requestOptions.body = state.requestBody;
324
296
  }
325
297
  const response = await fetch(state.requestUrl, requestOptions);
298
+ const duration = Date.now() - startTime;
326
299
  const responseText = await response.text();
327
300
  let responseData;
328
301
  try {
@@ -330,39 +303,41 @@ var PlaygroundProvider = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(({ children, c
330
303
  } catch {
331
304
  responseData = responseText;
332
305
  }
333
- setResponse({
334
- status: response.status,
335
- statusText: response.statusText,
336
- headers: Object.fromEntries(response.headers.entries()),
337
- data: responseData
306
+ dispatch({
307
+ type: "REQUEST_SUCCESS",
308
+ response: {
309
+ status: response.status,
310
+ statusText: response.statusText,
311
+ headers: Object.fromEntries(response.headers.entries()),
312
+ data: responseData,
313
+ duration
314
+ }
338
315
  });
339
- consola__default.default.success(`Request successful: ${state.requestMethod} ${state.requestUrl}`);
340
- updateState({ currentStep: "response" });
316
+ consola__default.default.success(`${state.requestMethod} ${state.requestUrl} \u2192 ${response.status} (${duration}ms)`);
341
317
  } catch (error) {
318
+ if (error instanceof DOMException && error.name === "AbortError") return;
342
319
  consola__default.default.error("Request failed:", error);
343
- setResponse({
344
- error: error instanceof Error ? error.message : "Request failed"
320
+ dispatch({
321
+ type: "REQUEST_ERROR",
322
+ response: {
323
+ error: error instanceof Error ? error.message : "Request failed",
324
+ duration: Date.now() - startTime
325
+ }
345
326
  });
346
- } finally {
347
- setLoading(false);
348
327
  }
349
- }, [state, setLoading, setResponse]);
328
+ }, [state.requestUrl, state.requestHeaders, state.manualApiToken, state.requestMethod, state.requestBody]);
350
329
  const contextValue = {
351
- // State
352
330
  state,
353
331
  config,
354
332
  apiKeys,
355
333
  apiKeysLoading: isLoadingApiKeys,
356
- // Step management
357
334
  setCurrentStep,
358
335
  goToNextStep,
359
336
  goToPreviousStep,
360
- // Endpoint management
361
337
  setSelectedEndpoint,
362
338
  setSelectedCategory,
363
339
  setSearchTerm,
364
340
  setSelectedVersion,
365
- // Request management
366
341
  setRequestUrl,
367
342
  setRequestMethod,
368
343
  setRequestHeaders,
@@ -370,12 +345,9 @@ var PlaygroundProvider = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(({ children, c
370
345
  setSelectedApiKey,
371
346
  setManualApiToken,
372
347
  setParameters,
373
- // Response management
374
348
  setResponse,
375
349
  setLoading,
376
- // UI management
377
350
  setSidebarOpen,
378
- // Actions
379
351
  clearAll,
380
352
  sendRequest
381
353
  };
@@ -386,10 +358,8 @@ exports.PlaygroundProvider = PlaygroundProvider;
386
358
  exports.PrettyCode_default = PrettyCode_default;
387
359
  exports.deduplicateEndpoints = deduplicateEndpoints;
388
360
  exports.findApiKeyById = findApiKeyById;
389
- exports.getMethodColor = getMethodColor;
390
- exports.getStatusColor = getStatusColor;
391
361
  exports.isValidJson = isValidJson;
392
362
  exports.parseRequestHeaders = parseRequestHeaders;
393
363
  exports.usePlaygroundContext = usePlaygroundContext;
394
- //# sourceMappingURL=chunk-CRHHUOVJ.cjs.map
395
- //# sourceMappingURL=chunk-CRHHUOVJ.cjs.map
364
+ //# sourceMappingURL=chunk-WM4RT5KX.cjs.map
365
+ //# sourceMappingURL=chunk-WM4RT5KX.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tools/PrettyCode/index.tsx","../src/tools/OpenapiViewer/utils/apiKeyManager.ts","../src/tools/OpenapiViewer/utils/versionManager.ts","../src/tools/OpenapiViewer/utils/formatters.ts","../src/tools/OpenapiViewer/context/PlaygroundContext.tsx"],"names":["lazy","__name","jsx","jsxs","Suspense","createContext","useContext","useReducer","useRef","React","useEffect","consola","useCallback"],"mappings":"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","file":"chunk-WM4RT5KX.cjs","sourcesContent":["/**\n * PrettyCode Component - Dynamic Import Wrapper\n *\n * Lazy loads the heavy Prism library (~500KB) only when needed.\n * This significantly reduces the initial bundle size.\n */\n\n'use client';\n\nimport React, { lazy, Suspense } from 'react';\nimport type { Language } from 'prism-react-renderer';\n\n// Lazy load the client component\nconst PrettyCodeClient = lazy(() => import('./PrettyCode.client'));\n\n// Loading fallback component\nconst LoadingFallback = () => (\n <div className=\"relative rounded-sm border border-border overflow-hidden bg-muted dark:bg-zinc-900\">\n <div className=\"p-4\">\n <div className=\"flex items-center gap-2\">\n <div className=\"animate-pulse h-4 w-4 rounded-full bg-muted-foreground/20\"></div>\n <span className=\"text-xs text-muted-foreground\">Loading code...</span>\n </div>\n </div>\n </div>\n);\n\nexport interface PrettyCodeProps {\n data: string | object;\n language: Language;\n className?: string;\n mode?: 'dark' | 'light';\n inline?: boolean;\n customBg?: string;\n isCompact?: boolean;\n /** Block scroll capture until user clicks (default: true) */\n scrollIsolation?: boolean;\n}\n\nconst PrettyCode: React.FC<PrettyCodeProps> = (props) => {\n return (\n <Suspense fallback={<LoadingFallback />}>\n <PrettyCodeClient {...props} />\n </Suspense>\n );\n};\n\nexport default PrettyCode;\nexport type { Language };\n","/**\n * API Key Management Utility\n *\n * Provides centralized functions for managing API keys in headers and requests.\n * This utility can be used across different components that need to handle API keys.\n */\n\nimport type { ApiKey } from '../types';\n\nexport type { ApiKey };\n\nexport interface HeadersWithApiKey {\n [key: string]: string;\n}\n\n/**\n * Add API key to request headers\n * @param headers - Existing headers object\n * @param apiKey - API key object or string\n * @returns Headers with API key added\n */\nexport function addApiKeyToHeaders(headers: HeadersWithApiKey, apiKey: ApiKey | string | null): HeadersWithApiKey {\n if (!apiKey) {\n return headers;\n }\n\n const keyValue = typeof apiKey === 'string' ? apiKey : (apiKey.id || '');\n\n return {\n ...headers,\n 'X-API-Key': keyValue,\n };\n}\n\n/**\n * Remove API key from headers object\n * @param headers - Headers object\n * @returns Headers without API key\n */\nexport function removeApiKeyFromHeaders(headers: HeadersWithApiKey): HeadersWithApiKey {\n const { 'X-API-Key': removed, ...remainingHeaders } = headers;\n return remainingHeaders;\n}\n\n/**\n * Remove API key from headers JSON string\n * @param headersJson - JSON string of headers\n * @returns JSON string without API key\n */\nexport function removeApiKeyFromHeadersJson(headersJson: string): string {\n try {\n const headers = JSON.parse(headersJson);\n const updatedHeaders = removeApiKeyFromHeaders(headers);\n return JSON.stringify(updatedHeaders, null, 2);\n } catch (error) {\n console.error('Error parsing headers JSON:', error);\n return headersJson;\n }\n}\n\n/**\n * Update headers JSON string with API key\n * @param headersJson - JSON string of headers\n * @param apiKey - API key object or string\n * @returns Updated JSON string\n */\nexport function updateHeadersJsonWithApiKey(headersJson: string, apiKey: ApiKey | string | null): string {\n try {\n const headers = JSON.parse(headersJson);\n const updatedHeaders = addApiKeyToHeaders(headers, apiKey);\n return JSON.stringify(updatedHeaders, null, 2);\n } catch (error) {\n console.error('Error parsing headers JSON:', error);\n return headersJson;\n }\n}\n\n/**\n * Find API key by ID in a list of API keys\n * @param apiKeys - Array of API keys\n * @param keyId - ID of the API key to find\n * @returns API key object or null\n */\nexport function findApiKeyById(apiKeys: ApiKey[], keyId: string): ApiKey | null {\n return apiKeys.find((key) => key.id === keyId) || null;\n}\n\n/**\n * Validate API key format\n * @param apiKey - API key string to validate\n * @returns Whether the API key format is valid\n */\nexport function validateApiKeyFormat(apiKey: string): boolean {\n // Basic validation - adjust based on your API key format requirements\n return typeof apiKey === 'string' && apiKey.length > 0 && apiKey.trim() !== '';\n}\n\n/**\n * Create default headers with API key\n * @param apiKey - API key object or string\n * @returns Default headers with API key\n */\nexport function createDefaultHeaders(apiKey?: ApiKey | string): HeadersWithApiKey {\n const defaultHeaders: HeadersWithApiKey = {\n 'Content-Type': 'application/json',\n };\n\n if (apiKey) {\n return addApiKeyToHeaders(defaultHeaders, apiKey);\n }\n\n return defaultHeaders;\n}\n\n/**\n * Merge headers with API key\n * @param baseHeaders - Base headers object\n * @param additionalHeaders - Additional headers to merge\n * @param apiKey - API key to add\n * @returns Merged headers with API key\n */\nexport function mergeHeadersWithApiKey(baseHeaders: HeadersWithApiKey, additionalHeaders: HeadersWithApiKey, apiKey?: ApiKey | string): HeadersWithApiKey {\n const mergedHeaders = { ...baseHeaders, ...additionalHeaders };\n\n if (apiKey) {\n return addApiKeyToHeaders(mergedHeaders, apiKey);\n }\n\n return mergedHeaders;\n}\n\n/**\n * Log API key usage (for debugging/analytics)\n * @param apiKey - API key that was used\n * @param endpoint - Endpoint that was called\n * @param success - Whether the request was successful\n */\nexport function logApiKeyUsage(apiKey: ApiKey | string, endpoint: string, success: boolean): void {\n const keyValue = typeof apiKey === 'string' ? apiKey : (apiKey.id || '');\n const keyName = typeof apiKey === 'string' ? 'Unknown' : apiKey.name;\n\n console.log(`API Key Usage:`, {\n keyName,\n keyValue: keyValue.substring(0, 8) + '...',\n endpoint,\n success,\n timestamp: new Date().toISOString(),\n });\n}\n","/**\n * API Version Management Utilities\n * Handles version detection, filtering, and URL transformation\n */\n\nimport type { ApiEndpoint } from '../types';\n\nexport interface ApiVersion {\n id: string;\n name: string;\n description: string;\n isDefault: boolean;\n}\n\n// Available API versions\nexport const API_VERSIONS: ApiVersion[] = [\n {\n id: 'v1',\n name: 'v1',\n description: 'Current stable version',\n isDefault: true,\n },\n];\n\n/**\n * Detect version from endpoint path\n */\nexport const detectEndpointVersion = (path: string): string => {\n // Check for versioned paths like /api/vehicles_api/v1/...\n const versionMatch = path.match(/\\/api\\/[^/]+\\/(v\\d+)\\//);\n if (versionMatch && versionMatch[1]) {\n return versionMatch[1];\n }\n \n // If no version found, default to v1\n return 'v1';\n};\n\n/**\n * Check if endpoint belongs to specific version\n */\nexport const isEndpointInVersion = (endpoint: ApiEndpoint, version: string): boolean => {\n const endpointVersion = detectEndpointVersion(endpoint.path);\n return endpointVersion === version;\n};\n\n/**\n * Filter endpoints by version\n */\nexport const filterEndpointsByVersion = (endpoints: ApiEndpoint[], version: string): ApiEndpoint[] => {\n return endpoints.filter(endpoint => isEndpointInVersion(endpoint, version));\n};\n\n/**\n * Remove duplicate endpoints across versions\n * Keeps only the specified version, removes duplicates from other versions\n */\nexport const deduplicateEndpoints = (endpoints: ApiEndpoint[], preferredVersion: string): ApiEndpoint[] => {\n const endpointMap = new Map<string, ApiEndpoint>();\n \n // Group endpoints by normalized path (without version)\n const groupedEndpoints = new Map<string, ApiEndpoint[]>();\n \n endpoints.forEach(endpoint => {\n const normalizedPath = normalizeEndpointPath(endpoint.path);\n if (!groupedEndpoints.has(normalizedPath)) {\n groupedEndpoints.set(normalizedPath, []);\n }\n groupedEndpoints.get(normalizedPath)!.push(endpoint);\n });\n \n // For each group, pick the endpoint from preferred version\n groupedEndpoints.forEach((endpointGroup, normalizedPath) => {\n let selectedEndpoint: ApiEndpoint | null = null;\n \n // Try to find endpoint in preferred version\n const versionEndpoint = endpointGroup.find(ep => isEndpointInVersion(ep, preferredVersion));\n if (versionEndpoint) {\n selectedEndpoint = versionEndpoint;\n } else if (endpointGroup.length > 0) {\n // Fallback to first available endpoint\n selectedEndpoint = endpointGroup[0] || null;\n }\n \n if (selectedEndpoint) {\n endpointMap.set(normalizedPath, selectedEndpoint);\n }\n });\n \n return Array.from(endpointMap.values());\n};\n\n/**\n * Normalize endpoint path by removing version prefix\n * /api/vehicles_api/v1/vehicles/ -> /api/vehicles_api/vehicles/\n * /api/vehicles_api/vehicles/ -> /api/vehicles_api/vehicles/\n */\nexport const normalizeEndpointPath = (path: string): string => {\n // Remove version prefix like /v1/, /v2/, etc.\n return path.replace(/\\/v\\d+\\//, '/');\n};\n\n/**\n * Convert endpoint path to specific version\n */\nexport const convertEndpointToVersion = (endpoint: ApiEndpoint, targetVersion: string): ApiEndpoint => {\n const currentVersion = detectEndpointVersion(endpoint.path);\n \n // If already in target version, return as is\n if (currentVersion === targetVersion) {\n return endpoint;\n }\n \n let newPath = endpoint.path;\n \n // Replace version: /api/vehicles_api/v1/vehicles/ -> /api/vehicles_api/v2/vehicles/\n newPath = newPath.replace(/\\/v\\d+\\//, `/${targetVersion}/`);\n \n return {\n ...endpoint,\n path: newPath,\n };\n};\n\n/**\n * Get version info by ID\n */\nexport const getVersionById = (versionId: string): ApiVersion | undefined => {\n return API_VERSIONS.find(v => v.id === versionId);\n};\n\n/**\n * Get default version\n */\nexport const getDefaultVersion = (): ApiVersion => {\n const defaultVersion = API_VERSIONS.find(v => v.isDefault);\n if (defaultVersion) {\n return defaultVersion;\n }\n \n // Fallback to first version if no default is set\n if (API_VERSIONS.length > 0 && API_VERSIONS[0]) {\n return API_VERSIONS[0];\n }\n \n // This should never happen, but TypeScript requires it\n throw new Error('No API versions defined');\n};\n\n/**\n * Get version statistics from endpoints\n */\nexport const getVersionStats = (endpoints: ApiEndpoint[]): Record<string, number> => {\n const stats: Record<string, number> = {};\n \n API_VERSIONS.forEach(version => {\n stats[version.id] = filterEndpointsByVersion(endpoints, version.id).length;\n });\n \n return stats;\n};\n","import type { ApiKey } from '../types';\nimport { HTTP_METHOD_COLORS, HTTP_STATUS_COLORS } from '../constants';\n\nexport const getMethodColor = (\n method: string\n): 'success' | 'primary' | 'warning' | 'error' | 'default' => {\n return HTTP_METHOD_COLORS[method.toUpperCase() as keyof typeof HTTP_METHOD_COLORS] || 'default';\n};\n\nexport const getStatusColor = (\n status: number\n): 'success' | 'warning' | 'error' | 'default' => {\n const firstDigit = Math.floor(status / 100).toString();\n return HTTP_STATUS_COLORS[firstDigit as keyof typeof HTTP_STATUS_COLORS] || 'default';\n};\n\nexport const formatApiKeyDisplay = (apiKey: ApiKey): string => {\n const preview = apiKey.id.substring(0, 8);\n return `${apiKey.name} (${preview}...)`;\n};\n\nexport const isValidJson = (str: string): boolean => {\n if (!str || typeof str !== 'string') return false;\n try {\n JSON.parse(str);\n return true;\n } catch {\n return false;\n }\n};\n\nexport const formatRequestHeaders = (headers: Record<string, string>): string => {\n return JSON.stringify(headers, null, 2);\n};\n\nexport const parseRequestHeaders = (headersString: string): Record<string, string> => {\n if (!headersString || typeof headersString !== 'string') {\n return { 'Content-Type': 'application/json' };\n }\n\n try {\n const parsed = JSON.parse(headersString);\n return typeof parsed === 'object' && parsed !== null ? parsed : { 'Content-Type': 'application/json' };\n } catch {\n return { 'Content-Type': 'application/json' };\n }\n};\n\n// Substitute URL parameters like {id}, {userId}, etc.\nexport const substituteUrlParameters = (\n url: string,\n parameters: Record<string, string>\n): string => {\n let substitutedUrl = url;\n\n Object.entries(parameters).forEach(([key, value]) => {\n if (value && value.trim() !== '') {\n // Replace both {key} and %7Bkey%7D patterns (URL encoded version)\n const patterns = [\n new RegExp(`\\\\{${key}\\\\}`, 'g'),\n new RegExp(`%7B${key}%7D`, 'gi'),\n ];\n\n patterns.forEach((pattern) => {\n substitutedUrl = substitutedUrl.replace(pattern, encodeURIComponent(value));\n });\n }\n });\n\n return substitutedUrl;\n};\n","'use client';\n\nimport consola from 'consola';\nimport React, {\n createContext, ReactNode, useCallback, useContext, useEffect, useReducer, useRef\n} from 'react';\n\nimport type {\n ApiEndpoint, ApiResponse, PlaygroundConfig, PlaygroundContextType, PlaygroundState,\n PlaygroundStep\n} from '../types';\nimport { parseRequestHeaders, substituteUrlParameters } from '../utils';\nimport { getDefaultVersion } from '../utils/versionManager';\n\n// ─── Initial state ────────────────────────────────────────────────────────────\n\nconst createInitialState = (): PlaygroundState => ({\n currentStep: 'endpoints',\n steps: ['endpoints', 'request', 'response'],\n selectedEndpoint: null,\n selectedCategory: 'All',\n searchTerm: '',\n selectedVersion: getDefaultVersion().id,\n requestUrl: '',\n requestMethod: 'GET',\n requestHeaders: '{\\n \"Content-Type\": \"application/json\"\\n}',\n requestBody: '',\n selectedApiKey: null,\n manualApiToken: '',\n parameters: {},\n response: null,\n loading: false,\n sidebarOpen: false,\n});\n\n// ─── Actions ──────────────────────────────────────────────────────────────────\n\ntype Action =\n | { type: 'SET_STEP'; step: PlaygroundStep }\n | { type: 'NEXT_STEP' }\n | { type: 'PREV_STEP' }\n | { type: 'SELECT_ENDPOINT'; endpoint: ApiEndpoint | null }\n | { type: 'SET_CATEGORY'; category: string }\n | { type: 'SET_SEARCH'; term: string }\n | { type: 'SET_VERSION'; version: string }\n | { type: 'SET_REQUEST_URL'; url: string }\n | { type: 'SET_REQUEST_METHOD'; method: string }\n | { type: 'SET_REQUEST_HEADERS'; headers: string }\n | { type: 'SET_REQUEST_BODY'; body: string }\n | { type: 'SET_API_KEY'; apiKeyId: string | null }\n | { type: 'SET_MANUAL_TOKEN'; token: string }\n | { type: 'SET_PARAMETERS'; parameters: Record<string, string> }\n | { type: 'SET_RESPONSE'; response: ApiResponse | null }\n | { type: 'SET_LOADING'; loading: boolean }\n // Batched: set loading + clear response atomically (avoids two renders on send)\n | { type: 'REQUEST_START' }\n // Batched: set response + loading=false + advance step atomically (avoids three renders)\n | { type: 'REQUEST_SUCCESS'; response: ApiResponse }\n // Batched: set error response + loading=false atomically\n | { type: 'REQUEST_ERROR'; response: ApiResponse }\n | { type: 'SET_SIDEBAR'; open: boolean }\n | { type: 'SYNC_API_KEY_HEADER'; headers: string }\n | { type: 'CLEAR_API_KEY_SELECTION' }\n | { type: 'SYNC_URL'; url: string }\n | { type: 'RESET' };\n\n// ─── Reducer ──────────────────────────────────────────────────────────────────\n\nfunction reducer(state: PlaygroundState, action: Action): PlaygroundState {\n switch (action.type) {\n case 'SET_STEP':\n return { ...state, currentStep: action.step };\n\n case 'NEXT_STEP': {\n const i = state.steps.indexOf(state.currentStep);\n return i < state.steps.length - 1\n ? { ...state, currentStep: state.steps[i + 1]! }\n : state;\n }\n\n case 'PREV_STEP': {\n const i = state.steps.indexOf(state.currentStep);\n return i > 0 ? { ...state, currentStep: state.steps[i - 1]! } : state;\n }\n\n case 'SELECT_ENDPOINT':\n if (!action.endpoint) return { ...state, selectedEndpoint: null };\n return {\n ...state,\n selectedEndpoint: action.endpoint,\n requestMethod: action.endpoint.method,\n requestUrl: action.endpoint.path,\n parameters: {},\n currentStep: 'request',\n };\n\n case 'SET_CATEGORY': return { ...state, selectedCategory: action.category };\n case 'SET_SEARCH': return { ...state, searchTerm: action.term };\n case 'SET_VERSION': return { ...state, selectedVersion: action.version };\n case 'SET_REQUEST_URL': return { ...state, requestUrl: action.url };\n case 'SET_REQUEST_METHOD': return { ...state, requestMethod: action.method };\n case 'SET_REQUEST_HEADERS': return { ...state, requestHeaders: action.headers };\n case 'SET_REQUEST_BODY': return { ...state, requestBody: action.body };\n case 'SET_API_KEY': return { ...state, selectedApiKey: action.apiKeyId };\n case 'SET_MANUAL_TOKEN': return { ...state, manualApiToken: action.token };\n case 'SET_PARAMETERS': return { ...state, parameters: action.parameters };\n case 'SET_RESPONSE': return { ...state, response: action.response };\n case 'SET_LOADING': return { ...state, loading: action.loading };\n\n case 'REQUEST_START':\n return { ...state, loading: true, response: null };\n\n case 'REQUEST_SUCCESS':\n return { ...state, loading: false, response: action.response, currentStep: 'response' };\n\n case 'REQUEST_ERROR':\n return { ...state, loading: false, response: action.response };\n\n case 'SET_SIDEBAR': return { ...state, sidebarOpen: action.open };\n case 'SYNC_API_KEY_HEADER': return { ...state, requestHeaders: action.headers };\n case 'CLEAR_API_KEY_SELECTION': return { ...state, selectedApiKey: null };\n case 'SYNC_URL': return { ...state, requestUrl: action.url };\n case 'RESET': return createInitialState();\n\n default: return state;\n }\n}\n\n// ─── Context ──────────────────────────────────────────────────────────────────\n\nconst PlaygroundContext = createContext<PlaygroundContextType | undefined>(undefined);\n\nexport const usePlaygroundContext = () => {\n const context = useContext(PlaygroundContext);\n if (!context) throw new Error('usePlaygroundContext must be used within a PlaygroundProvider');\n return context;\n};\n\n// ─── Provider ─────────────────────────────────────────────────────────────────\n\ninterface PlaygroundProviderProps {\n children: ReactNode;\n config: PlaygroundConfig;\n}\n\nexport const PlaygroundProvider: React.FC<PlaygroundProviderProps> = ({ children, config }) => {\n const [state, dispatch] = useReducer(reducer, undefined, createInitialState);\n const abortControllerRef = useRef<AbortController | null>(null);\n\n const apiKeys = React.useMemo(() => [], []);\n const isLoadingApiKeys = false;\n\n // Auto-select first API key\n useEffect(() => {\n if (!isLoadingApiKeys && apiKeys.length > 0 && !state.selectedApiKey) {\n dispatch({ type: 'SET_API_KEY', apiKeyId: apiKeys[0]?.id || null });\n }\n }, [apiKeys, isLoadingApiKeys, state.selectedApiKey]);\n\n // Sync X-API-Key header when selected key changes\n useEffect(() => {\n try {\n const headers = parseRequestHeaders(state.requestHeaders);\n\n if (state.selectedApiKey) {\n const apiKey = apiKeys.find((k) => k.id === state.selectedApiKey);\n if (!apiKey) {\n dispatch({ type: 'CLEAR_API_KEY_SELECTION' });\n return;\n }\n if (headers['X-API-Key'] !== apiKey.id) {\n headers['X-API-Key'] = apiKey.id;\n dispatch({ type: 'SYNC_API_KEY_HEADER', headers: JSON.stringify(headers, null, 2) });\n }\n } else if (headers['X-API-Key']) {\n delete headers['X-API-Key'];\n dispatch({ type: 'SYNC_API_KEY_HEADER', headers: JSON.stringify(headers, null, 2) });\n }\n } catch (error) {\n consola.error('Error updating headers:', error);\n }\n }, [state.selectedApiKey, apiKeys]); // eslint-disable-line react-hooks/exhaustive-deps\n\n // Sync URL when path parameters change\n useEffect(() => {\n if (!state.selectedEndpoint) return;\n const updated = substituteUrlParameters(state.selectedEndpoint.path, state.parameters);\n if (updated !== state.requestUrl) {\n dispatch({ type: 'SYNC_URL', url: updated });\n }\n }, [state.parameters, state.selectedEndpoint]); // eslint-disable-line react-hooks/exhaustive-deps\n\n // ── Stable action dispatchers ─────────────────────────────────────────────\n\n const setCurrentStep = useCallback((step: PlaygroundStep) => dispatch({ type: 'SET_STEP', step }), []);\n const goToNextStep = useCallback(() => dispatch({ type: 'NEXT_STEP' }), []);\n const goToPreviousStep = useCallback(() => dispatch({ type: 'PREV_STEP' }), []);\n\n const setSelectedEndpoint = useCallback((endpoint: ApiEndpoint | null) =>\n dispatch({ type: 'SELECT_ENDPOINT', endpoint }), []);\n\n const setSelectedCategory = useCallback((category: string) =>\n dispatch({ type: 'SET_CATEGORY', category }), []);\n\n const setSearchTerm = useCallback((term: string) => dispatch({ type: 'SET_SEARCH', term }), []);\n const setSelectedVersion = useCallback((version: string) => dispatch({ type: 'SET_VERSION', version }), []);\n const setRequestUrl = useCallback((url: string) => dispatch({ type: 'SET_REQUEST_URL', url }), []);\n const setRequestMethod = useCallback((method: string) => dispatch({ type: 'SET_REQUEST_METHOD', method }), []);\n const setRequestHeaders = useCallback((headers: string) => dispatch({ type: 'SET_REQUEST_HEADERS', headers }), []);\n const setRequestBody = useCallback((body: string) => dispatch({ type: 'SET_REQUEST_BODY', body }), []);\n const setSelectedApiKey = useCallback((apiKeyId: string | null) => dispatch({ type: 'SET_API_KEY', apiKeyId }), []);\n const setManualApiToken = useCallback((token: string) => dispatch({ type: 'SET_MANUAL_TOKEN', token }), []);\n const setParameters = useCallback((parameters: Record<string, string>) =>\n dispatch({ type: 'SET_PARAMETERS', parameters }), []);\n const setResponse = useCallback((response: ApiResponse | null) =>\n dispatch({ type: 'SET_RESPONSE', response }), []);\n const setLoading = useCallback((loading: boolean) => dispatch({ type: 'SET_LOADING', loading }), []);\n const setSidebarOpen = useCallback((open: boolean) => dispatch({ type: 'SET_SIDEBAR', open }), []);\n const clearAll = useCallback(() => dispatch({ type: 'RESET' }), []);\n\n // ── Send request ──────────────────────────────────────────────────────────\n\n const sendRequest = useCallback(async () => {\n if (!state.requestUrl) {\n consola.error('No URL provided');\n return;\n }\n\n abortControllerRef.current?.abort();\n const controller = new AbortController();\n abortControllerRef.current = controller;\n\n // Single dispatch: loading=true + clear response\n dispatch({ type: 'REQUEST_START' });\n\n const startTime = Date.now();\n\n try {\n const headers = parseRequestHeaders(state.requestHeaders);\n\n let bearerToken: string | null = null;\n if (state.manualApiToken) {\n bearerToken = state.manualApiToken;\n } else if (typeof window !== 'undefined') {\n bearerToken = window.localStorage.getItem('auth_token');\n }\n\n if (bearerToken) headers['Authorization'] = `Bearer ${bearerToken}`;\n\n const requestOptions: RequestInit = {\n method: state.requestMethod,\n headers,\n signal: controller.signal,\n };\n\n if (state.requestBody && state.requestMethod !== 'GET') {\n requestOptions.body = state.requestBody;\n }\n\n const response = await fetch(state.requestUrl, requestOptions);\n const duration = Date.now() - startTime;\n const responseText = await response.text();\n\n let responseData: unknown;\n try { responseData = JSON.parse(responseText); }\n catch { responseData = responseText; }\n\n // Single dispatch: response + loading=false + step='response'\n dispatch({\n type: 'REQUEST_SUCCESS',\n response: {\n status: response.status,\n statusText: response.statusText,\n headers: Object.fromEntries(response.headers.entries()),\n data: responseData,\n duration,\n },\n });\n\n consola.success(`${state.requestMethod} ${state.requestUrl} → ${response.status} (${duration}ms)`);\n } catch (error) {\n if (error instanceof DOMException && error.name === 'AbortError') return;\n consola.error('Request failed:', error);\n\n // Single dispatch: error response + loading=false\n dispatch({\n type: 'REQUEST_ERROR',\n response: {\n error: error instanceof Error ? error.message : 'Request failed',\n duration: Date.now() - startTime,\n },\n });\n }\n }, [state.requestUrl, state.requestHeaders, state.manualApiToken, state.requestMethod, state.requestBody]);\n\n // ── Context value ─────────────────────────────────────────────────────────\n\n const contextValue: PlaygroundContextType = {\n state,\n config,\n apiKeys,\n apiKeysLoading: isLoadingApiKeys,\n setCurrentStep,\n goToNextStep,\n goToPreviousStep,\n setSelectedEndpoint,\n setSelectedCategory,\n setSearchTerm,\n setSelectedVersion,\n setRequestUrl,\n setRequestMethod,\n setRequestHeaders,\n setRequestBody,\n setSelectedApiKey,\n setManualApiToken,\n setParameters,\n setResponse,\n setLoading,\n setSidebarOpen,\n clearAll,\n sendRequest,\n };\n\n return <PlaygroundContext.Provider value={contextValue}>{children}</PlaygroundContext.Provider>;\n};\n"]}
package/dist/index.cjs CHANGED
@@ -6,7 +6,7 @@ require('./chunk-F2N7P5XU.cjs');
6
6
  var chunkIHAY6FO6_cjs = require('./chunk-IHAY6FO6.cjs');
7
7
  var chunk77HQWEQ6_cjs = require('./chunk-77HQWEQ6.cjs');
8
8
  var chunkF2CMIIOH_cjs = require('./chunk-F2CMIIOH.cjs');
9
- var chunkCRHHUOVJ_cjs = require('./chunk-CRHHUOVJ.cjs');
9
+ var chunkWM4RT5KX_cjs = require('./chunk-WM4RT5KX.cjs');
10
10
  var chunk33AMWFBZ_cjs = require('./chunk-33AMWFBZ.cjs');
11
11
  require('./chunk-2SMCH62O.cjs');
12
12
  var chunkL37FZYJU_cjs = require('./chunk-L37FZYJU.cjs');
@@ -372,7 +372,7 @@ var CodeBlock = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(({ code, language, isUs
372
372
  }
373
373
  ),
374
374
  /* @__PURE__ */ jsxRuntime.jsx(
375
- chunkCRHHUOVJ_cjs.PrettyCode_default,
375
+ chunkWM4RT5KX_cjs.PrettyCode_default,
376
376
  {
377
377
  data: code,
378
378
  language,
@@ -721,7 +721,7 @@ function CodeLoadingFallback() {
721
721
  }
722
722
  chunkWGEGR3DF_cjs.__name(CodeLoadingFallback, "CodeLoadingFallback");
723
723
  var LazyPrettyCode = createLazyComponent(
724
- () => import('./PrettyCode.client-V2ZN5DTH.cjs'),
724
+ () => import('./PrettyCode.client-SGDGQTYT.cjs'),
725
725
  {
726
726
  displayName: "LazyPrettyCode",
727
727
  fallback: /* @__PURE__ */ jsxRuntime.jsx(CodeLoadingFallback, {})
@@ -735,14 +735,14 @@ function OpenapiLoadingFallback() {
735
735
  }
736
736
  chunkWGEGR3DF_cjs.__name(OpenapiLoadingFallback, "OpenapiLoadingFallback");
737
737
  var LazyPlaygroundLayout = createLazyComponent(
738
- () => import('./PlaygroundLayout-FKXSULJ3.cjs').then((mod) => ({ default: mod.PlaygroundLayout })),
738
+ () => import('./PlaygroundLayout-ZO2LO7M5.cjs').then((mod) => ({ default: mod.PlaygroundLayout })),
739
739
  {
740
740
  displayName: "LazyPlaygroundLayout",
741
741
  fallback: /* @__PURE__ */ jsxRuntime.jsx(OpenapiLoadingFallback, {})
742
742
  }
743
743
  );
744
744
  var LazyOpenapiViewer = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(({ config }) => {
745
- return /* @__PURE__ */ jsxRuntime.jsx(chunkCRHHUOVJ_cjs.PlaygroundProvider, { config, children: /* @__PURE__ */ jsxRuntime.jsx(LazyPlaygroundLayout, {}) });
745
+ return /* @__PURE__ */ jsxRuntime.jsx(chunkWM4RT5KX_cjs.PlaygroundProvider, { config, children: /* @__PURE__ */ jsxRuntime.jsx(LazyPlaygroundLayout, {}) });
746
746
  }, "LazyOpenapiViewer");
747
747
  LazyOpenapiViewer.displayName = "LazyOpenapiViewer";
748
748
  var LazyJsonSchemaForm = createLazyComponent(
@@ -890,11 +890,11 @@ function LottiePlayer(props) {
890
890
  }
891
891
  chunkWGEGR3DF_cjs.__name(LottiePlayer, "LottiePlayer");
892
892
  var PlaygroundLayout = React3.lazy(
893
- () => import('./PlaygroundLayout-FKXSULJ3.cjs').then((mod) => ({ default: mod.PlaygroundLayout }))
893
+ () => import('./PlaygroundLayout-ZO2LO7M5.cjs').then((mod) => ({ default: mod.PlaygroundLayout }))
894
894
  );
895
895
  var LoadingFallback9 = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(() => /* @__PURE__ */ jsxRuntime.jsx("div", { className: "flex items-center justify-center min-h-[400px]", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "text-muted-foreground", children: "Loading API Playground..." }) }), "LoadingFallback");
896
896
  var Playground = /* @__PURE__ */ chunkWGEGR3DF_cjs.__name(({ config }) => {
897
- return /* @__PURE__ */ jsxRuntime.jsx(chunkCRHHUOVJ_cjs.PlaygroundProvider, { config, children: /* @__PURE__ */ jsxRuntime.jsx(React3.Suspense, { fallback: /* @__PURE__ */ jsxRuntime.jsx(LoadingFallback9, {}), children: /* @__PURE__ */ jsxRuntime.jsx(PlaygroundLayout, {}) }) });
897
+ return /* @__PURE__ */ jsxRuntime.jsx(chunkWM4RT5KX_cjs.PlaygroundProvider, { config, children: /* @__PURE__ */ jsxRuntime.jsx(React3.Suspense, { fallback: /* @__PURE__ */ jsxRuntime.jsx(LoadingFallback9, {}), children: /* @__PURE__ */ jsxRuntime.jsx(PlaygroundLayout, {}) }) });
898
898
  }, "Playground");
899
899
  var OpenapiViewer_default = Playground;
900
900
  var CronSchedulerClient = React3.lazy(() => import('./CronScheduler.client-A4GO6YBY.cjs'));
@@ -2151,7 +2151,7 @@ Object.defineProperty(exports, "useCronWeekDays", {
2151
2151
  });
2152
2152
  Object.defineProperty(exports, "PrettyCode", {
2153
2153
  enumerable: true,
2154
- get: function () { return chunkCRHHUOVJ_cjs.PrettyCode_default; }
2154
+ get: function () { return chunkWM4RT5KX_cjs.PrettyCode_default; }
2155
2155
  });
2156
2156
  Object.defineProperty(exports, "JsonTree", {
2157
2157
  enumerable: true,
package/dist/index.mjs CHANGED
@@ -4,8 +4,8 @@ import './chunk-JWB2EWQO.mjs';
4
4
  export { ImageViewer } from './chunk-GGKGH5PM.mjs';
5
5
  export { generateContentKey, useAudioCache, useBlobUrlCleanup, useImageCache, useMediaCacheStore, useVideoCache, useVideoPlayerSettings } from './chunk-5LBDYFWH.mjs';
6
6
  export { CronSchedulerProvider, CustomInput, DayChips, MonthDayGrid, SchedulePreview, ScheduleTypeSelector, TimeSelector, buildCron, humanizeCron, isValidCron, parseCron, useCronCustom, useCronMonthDays, useCronPreview, useCronScheduler, useCronSchedulerContext, useCronTime, useCronType, useCronWeekDays } from './chunk-PZKAH7WQ.mjs';
7
- import { PlaygroundProvider, PrettyCode_default } from './chunk-SZ2CZEQZ.mjs';
8
- export { PrettyCode_default as PrettyCode } from './chunk-SZ2CZEQZ.mjs';
7
+ import { PlaygroundProvider, PrettyCode_default } from './chunk-QZ55LYK2.mjs';
8
+ export { PrettyCode_default as PrettyCode } from './chunk-QZ55LYK2.mjs';
9
9
  export { JsonTree_default as JsonTree } from './chunk-LFWQ36LJ.mjs';
10
10
  import './chunk-SSUOENAZ.mjs';
11
11
  export { ArrayFieldItemTemplate, ArrayFieldTemplate, BaseInputTemplate, CheckboxWidget, ColorWidget, ErrorListTemplate, FieldTemplate, JsonSchemaForm, NumberWidget, ObjectFieldTemplate, SelectWidget, SliderWidget, SwitchWidget, TextWidget, getRequiredFields, hasRequiredFields, mergeDefaults, normalizeFormData, safeJsonParse, safeJsonStringify, validateRequiredFields, validateSchema } from './chunk-JUGQNNDC.mjs';
@@ -694,7 +694,7 @@ function CodeLoadingFallback() {
694
694
  }
695
695
  __name(CodeLoadingFallback, "CodeLoadingFallback");
696
696
  var LazyPrettyCode = createLazyComponent(
697
- () => import('./PrettyCode.client-OO3KAJSM.mjs'),
697
+ () => import('./PrettyCode.client-DW5LTG47.mjs'),
698
698
  {
699
699
  displayName: "LazyPrettyCode",
700
700
  fallback: /* @__PURE__ */ jsx(CodeLoadingFallback, {})
@@ -708,7 +708,7 @@ function OpenapiLoadingFallback() {
708
708
  }
709
709
  __name(OpenapiLoadingFallback, "OpenapiLoadingFallback");
710
710
  var LazyPlaygroundLayout = createLazyComponent(
711
- () => import('./PlaygroundLayout-XMMHPZYP.mjs').then((mod) => ({ default: mod.PlaygroundLayout })),
711
+ () => import('./PlaygroundLayout-G325I6HM.mjs').then((mod) => ({ default: mod.PlaygroundLayout })),
712
712
  {
713
713
  displayName: "LazyPlaygroundLayout",
714
714
  fallback: /* @__PURE__ */ jsx(OpenapiLoadingFallback, {})
@@ -863,7 +863,7 @@ function LottiePlayer(props) {
863
863
  }
864
864
  __name(LottiePlayer, "LottiePlayer");
865
865
  var PlaygroundLayout = lazy(
866
- () => import('./PlaygroundLayout-XMMHPZYP.mjs').then((mod) => ({ default: mod.PlaygroundLayout }))
866
+ () => import('./PlaygroundLayout-G325I6HM.mjs').then((mod) => ({ default: mod.PlaygroundLayout }))
867
867
  );
868
868
  var LoadingFallback9 = /* @__PURE__ */ __name(() => /* @__PURE__ */ jsx("div", { className: "flex items-center justify-center min-h-[400px]", children: /* @__PURE__ */ jsx("div", { className: "text-muted-foreground", children: "Loading API Playground..." }) }), "LoadingFallback");
869
869
  var Playground = /* @__PURE__ */ __name(({ config }) => {