@scalar/openapi-to-markdown 0.5.1 → 0.5.3
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/CHANGELOG.md +8 -0
- package/dist/components/Schema.vue.d.ts +1 -0
- package/dist/components/Schema.vue.d.ts.map +1 -1
- package/dist/index.js +71 -47
- package/dist/index.js.map +1 -1
- package/package.json +4 -4
package/CHANGELOG.md
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema';
|
|
2
2
|
type __VLS_Props = {
|
|
3
3
|
schema: MaybeRefSchemaObject;
|
|
4
|
+
depth?: number;
|
|
4
5
|
};
|
|
5
6
|
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
6
7
|
declare const _default: typeof __VLS_export;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Schema.vue.d.ts","sourceRoot":"","sources":["../../src/components/Schema.vue"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Schema.vue.d.ts","sourceRoot":"","sources":["../../src/components/Schema.vue"],"names":[],"mappings":"AAiZA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,oDAAoD,CAAA;AAI9F,KAAK,WAAW,GAAG;IACjB,MAAM,EAAE,oBAAoB,CAAA;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,CAAC;AAmhBF,QAAA,MAAM,YAAY,kSAEhB,CAAC;wBACkB,OAAO,YAAY;AAAxC,wBAAyC"}
|
package/dist/index.js
CHANGED
|
@@ -18,32 +18,37 @@ import { resolve } from "@scalar/workspace-store/resolve";
|
|
|
18
18
|
import { json2xml } from "@scalar/helpers/file/json2xml";
|
|
19
19
|
//#region src/components/Schema.vue?vue&type=script&setup=true&lang.ts
|
|
20
20
|
var _hoisted_1$2 = { key: 0 };
|
|
21
|
-
var _hoisted_2$2 = { key:
|
|
22
|
-
var _hoisted_3$2 = { key:
|
|
23
|
-
var _hoisted_4$2 = { key:
|
|
24
|
-
var _hoisted_5$1 = { key:
|
|
25
|
-
var _hoisted_6$1 = { key:
|
|
26
|
-
var _hoisted_7$1 = { key:
|
|
21
|
+
var _hoisted_2$2 = { key: 1 };
|
|
22
|
+
var _hoisted_3$2 = { key: 0 };
|
|
23
|
+
var _hoisted_4$2 = { key: 1 };
|
|
24
|
+
var _hoisted_5$1 = { key: 2 };
|
|
25
|
+
var _hoisted_6$1 = { key: 3 };
|
|
26
|
+
var _hoisted_7$1 = { key: 4 };
|
|
27
27
|
var _hoisted_8$1 = { key: 0 };
|
|
28
|
-
var _hoisted_9$1 = { key:
|
|
29
|
-
var _hoisted_10$1 = { key:
|
|
30
|
-
var _hoisted_11$1 = { key:
|
|
31
|
-
var _hoisted_12$1 = { key:
|
|
32
|
-
var _hoisted_13$1 = { key:
|
|
33
|
-
var _hoisted_14$1 = { key:
|
|
28
|
+
var _hoisted_9$1 = { key: 0 };
|
|
29
|
+
var _hoisted_10$1 = { key: 1 };
|
|
30
|
+
var _hoisted_11$1 = { key: 2 };
|
|
31
|
+
var _hoisted_12$1 = { key: 3 };
|
|
32
|
+
var _hoisted_13$1 = { key: 1 };
|
|
33
|
+
var _hoisted_14$1 = { key: 5 };
|
|
34
34
|
var _hoisted_15 = { key: 0 };
|
|
35
|
-
var _hoisted_16 = { key:
|
|
36
|
-
var _hoisted_17 = { key:
|
|
37
|
-
var _hoisted_18 = { key:
|
|
38
|
-
var _hoisted_19 = { key:
|
|
39
|
-
var _hoisted_20 = { key:
|
|
40
|
-
var _hoisted_21 = { key:
|
|
41
|
-
var _hoisted_22 = { key:
|
|
35
|
+
var _hoisted_16 = { key: 0 };
|
|
36
|
+
var _hoisted_17 = { key: 1 };
|
|
37
|
+
var _hoisted_18 = { key: 2 };
|
|
38
|
+
var _hoisted_19 = { key: 6 };
|
|
39
|
+
var _hoisted_20 = { key: 0 };
|
|
40
|
+
var _hoisted_21 = { key: 1 };
|
|
41
|
+
var _hoisted_22 = { key: 2 };
|
|
42
|
+
var _hoisted_23 = { key: 3 };
|
|
43
|
+
var MAX_DEPTH = 10;
|
|
42
44
|
//#endregion
|
|
43
45
|
//#region src/components/Schema.vue
|
|
44
46
|
var Schema_default = /* @__PURE__ */ defineComponent({
|
|
45
47
|
__name: "Schema",
|
|
46
|
-
props: {
|
|
48
|
+
props: {
|
|
49
|
+
schema: {},
|
|
50
|
+
depth: { default: 0 }
|
|
51
|
+
},
|
|
47
52
|
setup(__props) {
|
|
48
53
|
const resolvedSchema = resolve.schema(__props.schema);
|
|
49
54
|
const resolveNestedSchema = (value) => resolve.schema(value);
|
|
@@ -113,42 +118,61 @@ var Schema_default = /* @__PURE__ */ defineComponent({
|
|
|
113
118
|
};
|
|
114
119
|
return (_ctx, _cache) => {
|
|
115
120
|
const _component_Schema = resolveComponent("Schema", true);
|
|
116
|
-
return unref(resolvedSchema) ? (openBlock(), createElementBlock("section",
|
|
117
|
-
return openBlock(), createElementBlock("section", { key: index }, [createVNode(_component_Schema, {
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
121
|
+
return __props.depth >= MAX_DEPTH ? (openBlock(), createElementBlock("section", _hoisted_1$2, [..._cache[0] || (_cache[0] = [createElementVNode("p", null, [createElementVNode("em", null, "[Circular Reference]")], -1)])])) : unref(resolvedSchema) ? (openBlock(), createElementBlock("section", _hoisted_2$2, [getSchemaArray(unref(resolvedSchema), "allOf") ? (openBlock(), createElementBlock("section", _hoisted_3$2, [_cache[1] || (_cache[1] = createElementVNode("header", null, [createElementVNode("strong", null, "All of:")], -1)), (openBlock(true), createElementBlock(Fragment, null, renderList(getSchemaArray(unref(resolvedSchema), "allOf"), (subSchema, index) => {
|
|
122
|
+
return openBlock(), createElementBlock("section", { key: index }, [createVNode(_component_Schema, {
|
|
123
|
+
schema: subSchema,
|
|
124
|
+
depth: __props.depth + 1
|
|
125
|
+
}, null, 8, ["schema", "depth"])]);
|
|
126
|
+
}), 128))])) : getSchemaArray(unref(resolvedSchema), "anyOf") ? (openBlock(), createElementBlock("section", _hoisted_4$2, [_cache[2] || (_cache[2] = createElementVNode("header", null, [createElementVNode("strong", null, "Any of:")], -1)), (openBlock(true), createElementBlock(Fragment, null, renderList(getSchemaArray(unref(resolvedSchema), "anyOf"), (subSchema, index) => {
|
|
127
|
+
return openBlock(), createElementBlock("section", { key: index }, [createVNode(_component_Schema, {
|
|
128
|
+
schema: subSchema,
|
|
129
|
+
depth: __props.depth + 1
|
|
130
|
+
}, null, 8, ["schema", "depth"])]);
|
|
131
|
+
}), 128))])) : getSchemaArray(unref(resolvedSchema), "oneOf") ? (openBlock(), createElementBlock("section", _hoisted_5$1, [_cache[3] || (_cache[3] = createElementVNode("header", null, [createElementVNode("strong", null, "One of:")], -1)), (openBlock(true), createElementBlock(Fragment, null, renderList(getSchemaArray(unref(resolvedSchema), "oneOf"), (subSchema, index) => {
|
|
132
|
+
return openBlock(), createElementBlock("section", { key: index }, [createVNode(_component_Schema, {
|
|
133
|
+
schema: subSchema,
|
|
134
|
+
depth: __props.depth + 1
|
|
135
|
+
}, null, 8, ["schema", "depth"])]);
|
|
136
|
+
}), 128))])) : getSchemaNot(unref(resolvedSchema)) ? (openBlock(), createElementBlock("section", _hoisted_6$1, [_cache[4] || (_cache[4] = createElementVNode("header", null, [createElementVNode("strong", null, "Not:")], -1)), createElementVNode("section", null, [createVNode(_component_Schema, {
|
|
137
|
+
schema: getSchemaNot(unref(resolvedSchema)),
|
|
138
|
+
depth: __props.depth + 1
|
|
139
|
+
}, null, 8, ["schema", "depth"])])])) : getSchemaType(unref(resolvedSchema)) === "object" || Object.keys(getSchemaProperties(unref(resolvedSchema))).length ? (openBlock(), createElementBlock("section", _hoisted_7$1, [createElementVNode("ul", null, [(openBlock(true), createElementBlock(Fragment, null, renderList(sortProperties(getSchemaProperties(unref(resolvedSchema)), getSchemaRequired(unref(resolvedSchema))), (propSchema, propName) => {
|
|
123
140
|
return openBlock(), createElementBlock("li", { key: propName }, [
|
|
124
|
-
createElementVNode("strong", null, [createElementVNode("code", null, toDisplayString(propName), 1), getSchemaRequired(unref(resolvedSchema)).includes(propName) ? (openBlock(), createElementBlock("span",
|
|
141
|
+
createElementVNode("strong", null, [createElementVNode("code", null, toDisplayString(propName), 1), getSchemaRequired(unref(resolvedSchema)).includes(propName) ? (openBlock(), createElementBlock("span", _hoisted_8$1, " (required) ")) : createCommentVNode("", true)]),
|
|
125
142
|
createElementVNode("p", null, [
|
|
126
143
|
createElementVNode("code", null, toDisplayString(formatSchemaType(propSchema)), 1),
|
|
127
|
-
getResolvedSchemaFormat(propSchema) ? (openBlock(), createElementBlock("span",
|
|
128
|
-
getResolvedSchemaEnum(propSchema) ? (openBlock(), createElementBlock("span",
|
|
129
|
-
getResolvedSchemaDefault(propSchema) !== void 0 ? (openBlock(), createElementBlock("span",
|
|
130
|
-
getResolvedSchemaDescription(propSchema) ? (openBlock(), createElementBlock("span",
|
|
144
|
+
getResolvedSchemaFormat(propSchema) ? (openBlock(), createElementBlock("span", _hoisted_9$1, [_cache[5] || (_cache[5] = createTextVNode(", format: ", -1)), createElementVNode("code", null, toDisplayString(getResolvedSchemaFormat(propSchema)), 1)])) : createCommentVNode("", true),
|
|
145
|
+
getResolvedSchemaEnum(propSchema) ? (openBlock(), createElementBlock("span", _hoisted_10$1, [_cache[6] || (_cache[6] = createTextVNode(", possible values: ", -1)), createElementVNode("code", null, toDisplayString(formatEnumValues(getResolvedSchemaEnum(propSchema))), 1)])) : createCommentVNode("", true),
|
|
146
|
+
getResolvedSchemaDefault(propSchema) !== void 0 ? (openBlock(), createElementBlock("span", _hoisted_11$1, [_cache[7] || (_cache[7] = createTextVNode(", default: ", -1)), createElementVNode("code", null, toDisplayString(JSON.stringify(getResolvedSchemaDefault(propSchema))), 1)])) : createCommentVNode("", true),
|
|
147
|
+
getResolvedSchemaDescription(propSchema) ? (openBlock(), createElementBlock("span", _hoisted_12$1, " — " + toDisplayString(getResolvedSchemaDescription(propSchema)), 1)) : createCommentVNode("", true)
|
|
131
148
|
]),
|
|
132
149
|
getResolvedSchemaType(propSchema) === "object" || Object.keys(getResolvedSchemaProperties(propSchema)).length ? (openBlock(), createBlock(_component_Schema, {
|
|
133
150
|
key: 0,
|
|
134
|
-
schema: propSchema
|
|
135
|
-
|
|
136
|
-
|
|
151
|
+
schema: propSchema,
|
|
152
|
+
depth: __props.depth + 1
|
|
153
|
+
}, null, 8, ["schema", "depth"])) : createCommentVNode("", true),
|
|
154
|
+
getResolvedSchemaType(propSchema) === "array" && getResolvedSchemaItems(propSchema) ? (openBlock(), createElementBlock("section", _hoisted_13$1, [_cache[8] || (_cache[8] = createElementVNode("header", null, [createElementVNode("strong", null, "Items:")], -1)), createVNode(_component_Schema, {
|
|
155
|
+
schema: getResolvedSchemaItems(propSchema),
|
|
156
|
+
depth: __props.depth + 1
|
|
157
|
+
}, null, 8, ["schema", "depth"])])) : createCommentVNode("", true)
|
|
137
158
|
]);
|
|
138
|
-
}), 128))])])) : getSchemaType(unref(resolvedSchema)) === "array" && getSchemaItems(unref(resolvedSchema)) ? (openBlock(), createElementBlock("section",
|
|
139
|
-
_cache[
|
|
140
|
-
createElementVNode("section", null, [createVNode(_component_Schema, {
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
159
|
+
}), 128))])])) : getSchemaType(unref(resolvedSchema)) === "array" && getSchemaItems(unref(resolvedSchema)) ? (openBlock(), createElementBlock("section", _hoisted_14$1, [
|
|
160
|
+
_cache[12] || (_cache[12] = createElementVNode("header", null, [createElementVNode("strong", null, "Array of:")], -1)),
|
|
161
|
+
createElementVNode("section", null, [createVNode(_component_Schema, {
|
|
162
|
+
schema: getSchemaItems(unref(resolvedSchema)),
|
|
163
|
+
depth: __props.depth + 1
|
|
164
|
+
}, null, 8, ["schema", "depth"])]),
|
|
165
|
+
getSchemaMinItems(unref(resolvedSchema)) !== void 0 || getSchemaMaxItems(unref(resolvedSchema)) !== void 0 || getSchemaUniqueItems(unref(resolvedSchema)) ? (openBlock(), createElementBlock("ul", _hoisted_15, [
|
|
166
|
+
getSchemaMinItems(unref(resolvedSchema)) !== void 0 ? (openBlock(), createElementBlock("li", _hoisted_16, [_cache[9] || (_cache[9] = createTextVNode(" Min items: ", -1)), createElementVNode("code", null, toDisplayString(getSchemaMinItems(unref(resolvedSchema))), 1)])) : createCommentVNode("", true),
|
|
167
|
+
getSchemaMaxItems(unref(resolvedSchema)) !== void 0 ? (openBlock(), createElementBlock("li", _hoisted_17, [_cache[10] || (_cache[10] = createTextVNode(" Max items: ", -1)), createElementVNode("code", null, toDisplayString(getSchemaMaxItems(unref(resolvedSchema))), 1)])) : createCommentVNode("", true),
|
|
168
|
+
getSchemaUniqueItems(unref(resolvedSchema)) ? (openBlock(), createElementBlock("li", _hoisted_18, [..._cache[11] || (_cache[11] = [createTextVNode(" Unique items: ", -1), createElementVNode("code", null, "true", -1)])])) : createCommentVNode("", true)
|
|
145
169
|
])) : createCommentVNode("", true)
|
|
146
|
-
])) : (openBlock(), createElementBlock("section",
|
|
170
|
+
])) : (openBlock(), createElementBlock("section", _hoisted_19, [createElementVNode("p", null, [
|
|
147
171
|
createElementVNode("code", null, toDisplayString(getSchemaType(unref(resolvedSchema))), 1),
|
|
148
|
-
getSchemaFormat(unref(resolvedSchema)) ? (openBlock(), createElementBlock("span",
|
|
149
|
-
getSchemaEnum(unref(resolvedSchema)) ? (openBlock(), createElementBlock("span",
|
|
150
|
-
getSchemaDefault(unref(resolvedSchema)) !== void 0 ? (openBlock(), createElementBlock("span",
|
|
151
|
-
getSchemaDescription(unref(resolvedSchema)) ? (openBlock(), createElementBlock("span",
|
|
172
|
+
getSchemaFormat(unref(resolvedSchema)) ? (openBlock(), createElementBlock("span", _hoisted_20, [_cache[13] || (_cache[13] = createTextVNode(", format: ", -1)), createElementVNode("code", null, toDisplayString(getSchemaFormat(unref(resolvedSchema))), 1)])) : createCommentVNode("", true),
|
|
173
|
+
getSchemaEnum(unref(resolvedSchema)) ? (openBlock(), createElementBlock("span", _hoisted_21, [_cache[14] || (_cache[14] = createTextVNode(", possible values: ", -1)), createElementVNode("code", null, toDisplayString(formatEnumValues(getSchemaEnum(unref(resolvedSchema)))), 1)])) : createCommentVNode("", true),
|
|
174
|
+
getSchemaDefault(unref(resolvedSchema)) !== void 0 ? (openBlock(), createElementBlock("span", _hoisted_22, [_cache[15] || (_cache[15] = createTextVNode(", default: ", -1)), createElementVNode("code", null, toDisplayString(JSON.stringify(getSchemaDefault(unref(resolvedSchema)))), 1)])) : createCommentVNode("", true),
|
|
175
|
+
getSchemaDescription(unref(resolvedSchema)) ? (openBlock(), createElementBlock("span", _hoisted_23, " — " + toDisplayString(getSchemaDescription(unref(resolvedSchema))), 1)) : createCommentVNode("", true)
|
|
152
176
|
])]))])) : createCommentVNode("", true);
|
|
153
177
|
};
|
|
154
178
|
}
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["../src/components/Schema.vue","../src/components/Schema.vue","../src/components/XmlOrJson.vue","../src/components/XmlOrJson.vue","../src/components/MarkdownReference.vue","../src/components/MarkdownReference.vue","../src/create-markdown-from-openapi.ts"],"sourcesContent":["<script setup lang=\"ts\">\nimport { resolve } from '@scalar/workspace-store/resolve'\nimport type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema'\n\nconst { schema } = defineProps<{\n schema: MaybeRefSchemaObject\n}>()\n\ntype ResolvedSchema = NonNullable<\n ReturnType<typeof resolve.schema<MaybeRefSchemaObject>>\n>\n\nconst resolvedSchema = resolve.schema(schema)\n\nconst resolveNestedSchema = (\n value: MaybeRefSchemaObject | undefined,\n): ResolvedSchema | undefined => resolve.schema(value)\n\nconst asObject = (value: unknown): Record<string, unknown> | undefined =>\n value !== null && typeof value === 'object'\n ? (value as Record<string, unknown>)\n : undefined\n\nconst getSchemaType = (\n value: ResolvedSchema | undefined,\n): string | string[] | undefined => {\n const schemaType = asObject(value)?.type\n if (typeof schemaType === 'string') {\n return schemaType\n }\n if (\n Array.isArray(schemaType) &&\n schemaType.every((entry) => typeof entry === 'string')\n ) {\n return schemaType\n }\n return undefined\n}\n\nconst getSchemaArray = (\n value: ResolvedSchema | undefined,\n key: 'allOf' | 'anyOf' | 'oneOf',\n): MaybeRefSchemaObject[] | undefined => {\n const collection = asObject(value)?.[key]\n if (!Array.isArray(collection)) {\n return undefined\n }\n return collection.filter(\n (entry): entry is MaybeRefSchemaObject =>\n entry !== null && typeof entry === 'object',\n )\n}\n\nconst getSchemaNot = (\n value: ResolvedSchema | undefined,\n): MaybeRefSchemaObject | undefined => {\n const notSchema = asObject(value)?.not\n return notSchema !== null && typeof notSchema === 'object'\n ? (notSchema as MaybeRefSchemaObject)\n : undefined\n}\n\nconst getSchemaProperties = (\n value: ResolvedSchema | undefined,\n): Record<string, MaybeRefSchemaObject> => {\n const properties = asObject(value)?.properties\n if (!properties || typeof properties !== 'object') {\n return {}\n }\n return Object.entries(properties).reduce<\n Record<string, MaybeRefSchemaObject>\n >((acc, [name, prop]) => {\n if (prop !== null && typeof prop === 'object') {\n acc[name] = prop as MaybeRefSchemaObject\n }\n return acc\n }, {})\n}\n\nconst getSchemaRequired = (value: ResolvedSchema | undefined): string[] => {\n const required = asObject(value)?.required\n if (!Array.isArray(required)) {\n return []\n }\n return required.filter((item): item is string => typeof item === 'string')\n}\n\nconst getSchemaItems = (\n value: ResolvedSchema | undefined,\n): MaybeRefSchemaObject | undefined => {\n const items = asObject(value)?.items\n return items !== null && typeof items === 'object'\n ? (items as MaybeRefSchemaObject)\n : undefined\n}\n\nconst getSchemaFormat = (\n value: ResolvedSchema | undefined,\n): string | undefined =>\n typeof asObject(value)?.format === 'string'\n ? (asObject(value)?.format as string)\n : undefined\n\nconst getSchemaEnum = (\n value: ResolvedSchema | undefined,\n): unknown[] | undefined => {\n const enumValues = asObject(value)?.enum\n return Array.isArray(enumValues) ? enumValues : undefined\n}\n\nconst getSchemaDefault = (value: ResolvedSchema | undefined): unknown =>\n asObject(value)?.default\n\nconst getSchemaDescription = (\n value: ResolvedSchema | undefined,\n): string | undefined =>\n typeof asObject(value)?.description === 'string'\n ? (asObject(value)?.description as string)\n : undefined\n\nconst getSchemaMinItems = (\n value: ResolvedSchema | undefined,\n): number | undefined =>\n typeof asObject(value)?.minItems === 'number'\n ? (asObject(value)?.minItems as number)\n : undefined\n\nconst getSchemaMaxItems = (\n value: ResolvedSchema | undefined,\n): number | undefined =>\n typeof asObject(value)?.maxItems === 'number'\n ? (asObject(value)?.maxItems as number)\n : undefined\n\nconst getSchemaUniqueItems = (\n value: ResolvedSchema | undefined,\n): boolean | undefined =>\n typeof asObject(value)?.uniqueItems === 'boolean'\n ? (asObject(value)?.uniqueItems as boolean)\n : undefined\n\nconst getResolvedSchemaType = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaType(resolveNestedSchema(value))\nconst getResolvedSchemaFormat = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaFormat(resolveNestedSchema(value))\nconst getResolvedSchemaEnum = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaEnum(resolveNestedSchema(value))\nconst getResolvedSchemaDefault = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaDefault(resolveNestedSchema(value))\nconst getResolvedSchemaDescription = (\n value: MaybeRefSchemaObject | undefined,\n) => getSchemaDescription(resolveNestedSchema(value))\nconst getResolvedSchemaProperties = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaProperties(resolveNestedSchema(value))\nconst getResolvedSchemaItems = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaItems(resolveNestedSchema(value))\n\nconst formatSchemaType = (value: MaybeRefSchemaObject | undefined): string => {\n const schemaType = getResolvedSchemaType(value)\n return Array.isArray(schemaType)\n ? schemaType.join(' | ')\n : schemaType || 'object'\n}\n\nconst formatEnumValues = (value: unknown[] | undefined): string =>\n value?.map((entry: unknown) => JSON.stringify(entry)).join(', ') || ''\n\n// Sort properties to show required fields first, then optional, then metadata\nconst sortProperties = (\n properties: Record<string, MaybeRefSchemaObject>,\n required?: string[],\n) => {\n const sorted = Object.entries(properties).sort(([a], [b]) => {\n const aRequired = required?.includes(a)\n const bRequired = required?.includes(b)\n if (aRequired && !bRequired) return -1\n if (!aRequired && bRequired) return 1\n return a.localeCompare(b)\n })\n return Object.fromEntries(sorted)\n}\n</script>\n\n<template>\n <section v-if=\"resolvedSchema\">\n <!-- Composition keywords -->\n <template v-if=\"getSchemaArray(resolvedSchema, 'allOf')\">\n <section>\n <header>\n <strong>All of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'allOf')\"\n :key=\"index\">\n <Schema :schema=\"subSchema\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaArray(resolvedSchema, 'anyOf')\">\n <section>\n <header>\n <strong>Any of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'anyOf')\"\n :key=\"index\">\n <Schema :schema=\"subSchema\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaArray(resolvedSchema, 'oneOf')\">\n <section>\n <header>\n <strong>One of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'oneOf')\"\n :key=\"index\">\n <Schema :schema=\"subSchema\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaNot(resolvedSchema)\">\n <section>\n <header>\n <strong>Not:</strong>\n </header>\n <section>\n <Schema :schema=\"getSchemaNot(resolvedSchema)!\" />\n </section>\n </section>\n </template>\n\n <!-- Object type -->\n <template\n v-else-if=\"\n getSchemaType(resolvedSchema) === 'object' ||\n Object.keys(getSchemaProperties(resolvedSchema)).length\n \">\n <section>\n <ul>\n <template\n v-for=\"(propSchema, propName) in sortProperties(\n getSchemaProperties(resolvedSchema),\n getSchemaRequired(resolvedSchema),\n )\"\n :key=\"propName\">\n <li>\n <strong>\n <code>{{ propName }}</code>\n <span\n v-if=\"getSchemaRequired(resolvedSchema).includes(propName)\">\n (required)\n </span>\n </strong>\n <p>\n <code>\n {{ formatSchemaType(propSchema) }}\n </code>\n <template v-if=\"getResolvedSchemaFormat(propSchema)\">\n <span\n >, format:\n <code>{{ getResolvedSchemaFormat(propSchema) }}</code></span\n >\n </template>\n <template v-if=\"getResolvedSchemaEnum(propSchema)\">\n <span\n >, possible values:\n <code>{{\n formatEnumValues(getResolvedSchemaEnum(propSchema))\n }}</code>\n </span>\n </template>\n <template\n v-if=\"getResolvedSchemaDefault(propSchema) !== undefined\">\n <span\n >, default:\n <code>{{\n JSON.stringify(getResolvedSchemaDefault(propSchema))\n }}</code></span\n >\n </template>\n <template v-if=\"getResolvedSchemaDescription(propSchema)\">\n <span> — {{ getResolvedSchemaDescription(propSchema) }}</span>\n </template>\n </p>\n <Schema\n v-if=\"\n getResolvedSchemaType(propSchema) === 'object' ||\n Object.keys(getResolvedSchemaProperties(propSchema)).length\n \"\n :schema=\"propSchema\" />\n <template\n v-if=\"\n getResolvedSchemaType(propSchema) === 'array' &&\n getResolvedSchemaItems(propSchema)\n \">\n <section>\n <header>\n <strong>Items:</strong>\n </header>\n <Schema :schema=\"getResolvedSchemaItems(propSchema)!\" />\n </section>\n </template>\n </li>\n </template>\n </ul>\n </section>\n </template>\n\n <!-- Array type -->\n <template\n v-else-if=\"\n getSchemaType(resolvedSchema) === 'array' &&\n getSchemaItems(resolvedSchema)\n \">\n <section>\n <header>\n <strong>Array of:</strong>\n </header>\n <section>\n <Schema :schema=\"getSchemaItems(resolvedSchema)!\" />\n </section>\n <ul\n v-if=\"\n getSchemaMinItems(resolvedSchema) !== undefined ||\n getSchemaMaxItems(resolvedSchema) !== undefined ||\n getSchemaUniqueItems(resolvedSchema)\n \">\n <li v-if=\"getSchemaMinItems(resolvedSchema) !== undefined\">\n Min items: <code>{{ getSchemaMinItems(resolvedSchema) }}</code>\n </li>\n <li v-if=\"getSchemaMaxItems(resolvedSchema) !== undefined\">\n Max items: <code>{{ getSchemaMaxItems(resolvedSchema) }}</code>\n </li>\n <li v-if=\"getSchemaUniqueItems(resolvedSchema)\">\n Unique items: <code>true</code>\n </li>\n </ul>\n </section>\n </template>\n\n <!-- Primitive types -->\n <template v-else>\n <section>\n <p>\n <code>{{ getSchemaType(resolvedSchema) }}</code>\n <template v-if=\"getSchemaFormat(resolvedSchema)\">\n <span\n >, format:\n <code>{{ getSchemaFormat(resolvedSchema) }}</code></span\n >\n </template>\n <template v-if=\"getSchemaEnum(resolvedSchema)\">\n <span\n >, possible values:\n <code>{{ formatEnumValues(getSchemaEnum(resolvedSchema)) }}</code>\n </span>\n </template>\n <template v-if=\"getSchemaDefault(resolvedSchema) !== undefined\">\n <span\n >, default:\n <code>{{\n JSON.stringify(getSchemaDefault(resolvedSchema))\n }}</code></span\n >\n </template>\n <template v-if=\"getSchemaDescription(resolvedSchema)\">\n <span> — {{ getSchemaDescription(resolvedSchema) }}</span>\n </template>\n </p>\n </section>\n </template>\n </section>\n</template>\n","<script setup lang=\"ts\">\nimport { resolve } from '@scalar/workspace-store/resolve'\nimport type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema'\n\nconst { schema } = defineProps<{\n schema: MaybeRefSchemaObject\n}>()\n\ntype ResolvedSchema = NonNullable<\n ReturnType<typeof resolve.schema<MaybeRefSchemaObject>>\n>\n\nconst resolvedSchema = resolve.schema(schema)\n\nconst resolveNestedSchema = (\n value: MaybeRefSchemaObject | undefined,\n): ResolvedSchema | undefined => resolve.schema(value)\n\nconst asObject = (value: unknown): Record<string, unknown> | undefined =>\n value !== null && typeof value === 'object'\n ? (value as Record<string, unknown>)\n : undefined\n\nconst getSchemaType = (\n value: ResolvedSchema | undefined,\n): string | string[] | undefined => {\n const schemaType = asObject(value)?.type\n if (typeof schemaType === 'string') {\n return schemaType\n }\n if (\n Array.isArray(schemaType) &&\n schemaType.every((entry) => typeof entry === 'string')\n ) {\n return schemaType\n }\n return undefined\n}\n\nconst getSchemaArray = (\n value: ResolvedSchema | undefined,\n key: 'allOf' | 'anyOf' | 'oneOf',\n): MaybeRefSchemaObject[] | undefined => {\n const collection = asObject(value)?.[key]\n if (!Array.isArray(collection)) {\n return undefined\n }\n return collection.filter(\n (entry): entry is MaybeRefSchemaObject =>\n entry !== null && typeof entry === 'object',\n )\n}\n\nconst getSchemaNot = (\n value: ResolvedSchema | undefined,\n): MaybeRefSchemaObject | undefined => {\n const notSchema = asObject(value)?.not\n return notSchema !== null && typeof notSchema === 'object'\n ? (notSchema as MaybeRefSchemaObject)\n : undefined\n}\n\nconst getSchemaProperties = (\n value: ResolvedSchema | undefined,\n): Record<string, MaybeRefSchemaObject> => {\n const properties = asObject(value)?.properties\n if (!properties || typeof properties !== 'object') {\n return {}\n }\n return Object.entries(properties).reduce<\n Record<string, MaybeRefSchemaObject>\n >((acc, [name, prop]) => {\n if (prop !== null && typeof prop === 'object') {\n acc[name] = prop as MaybeRefSchemaObject\n }\n return acc\n }, {})\n}\n\nconst getSchemaRequired = (value: ResolvedSchema | undefined): string[] => {\n const required = asObject(value)?.required\n if (!Array.isArray(required)) {\n return []\n }\n return required.filter((item): item is string => typeof item === 'string')\n}\n\nconst getSchemaItems = (\n value: ResolvedSchema | undefined,\n): MaybeRefSchemaObject | undefined => {\n const items = asObject(value)?.items\n return items !== null && typeof items === 'object'\n ? (items as MaybeRefSchemaObject)\n : undefined\n}\n\nconst getSchemaFormat = (\n value: ResolvedSchema | undefined,\n): string | undefined =>\n typeof asObject(value)?.format === 'string'\n ? (asObject(value)?.format as string)\n : undefined\n\nconst getSchemaEnum = (\n value: ResolvedSchema | undefined,\n): unknown[] | undefined => {\n const enumValues = asObject(value)?.enum\n return Array.isArray(enumValues) ? enumValues : undefined\n}\n\nconst getSchemaDefault = (value: ResolvedSchema | undefined): unknown =>\n asObject(value)?.default\n\nconst getSchemaDescription = (\n value: ResolvedSchema | undefined,\n): string | undefined =>\n typeof asObject(value)?.description === 'string'\n ? (asObject(value)?.description as string)\n : undefined\n\nconst getSchemaMinItems = (\n value: ResolvedSchema | undefined,\n): number | undefined =>\n typeof asObject(value)?.minItems === 'number'\n ? (asObject(value)?.minItems as number)\n : undefined\n\nconst getSchemaMaxItems = (\n value: ResolvedSchema | undefined,\n): number | undefined =>\n typeof asObject(value)?.maxItems === 'number'\n ? (asObject(value)?.maxItems as number)\n : undefined\n\nconst getSchemaUniqueItems = (\n value: ResolvedSchema | undefined,\n): boolean | undefined =>\n typeof asObject(value)?.uniqueItems === 'boolean'\n ? (asObject(value)?.uniqueItems as boolean)\n : undefined\n\nconst getResolvedSchemaType = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaType(resolveNestedSchema(value))\nconst getResolvedSchemaFormat = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaFormat(resolveNestedSchema(value))\nconst getResolvedSchemaEnum = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaEnum(resolveNestedSchema(value))\nconst getResolvedSchemaDefault = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaDefault(resolveNestedSchema(value))\nconst getResolvedSchemaDescription = (\n value: MaybeRefSchemaObject | undefined,\n) => getSchemaDescription(resolveNestedSchema(value))\nconst getResolvedSchemaProperties = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaProperties(resolveNestedSchema(value))\nconst getResolvedSchemaItems = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaItems(resolveNestedSchema(value))\n\nconst formatSchemaType = (value: MaybeRefSchemaObject | undefined): string => {\n const schemaType = getResolvedSchemaType(value)\n return Array.isArray(schemaType)\n ? schemaType.join(' | ')\n : schemaType || 'object'\n}\n\nconst formatEnumValues = (value: unknown[] | undefined): string =>\n value?.map((entry: unknown) => JSON.stringify(entry)).join(', ') || ''\n\n// Sort properties to show required fields first, then optional, then metadata\nconst sortProperties = (\n properties: Record<string, MaybeRefSchemaObject>,\n required?: string[],\n) => {\n const sorted = Object.entries(properties).sort(([a], [b]) => {\n const aRequired = required?.includes(a)\n const bRequired = required?.includes(b)\n if (aRequired && !bRequired) return -1\n if (!aRequired && bRequired) return 1\n return a.localeCompare(b)\n })\n return Object.fromEntries(sorted)\n}\n</script>\n\n<template>\n <section v-if=\"resolvedSchema\">\n <!-- Composition keywords -->\n <template v-if=\"getSchemaArray(resolvedSchema, 'allOf')\">\n <section>\n <header>\n <strong>All of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'allOf')\"\n :key=\"index\">\n <Schema :schema=\"subSchema\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaArray(resolvedSchema, 'anyOf')\">\n <section>\n <header>\n <strong>Any of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'anyOf')\"\n :key=\"index\">\n <Schema :schema=\"subSchema\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaArray(resolvedSchema, 'oneOf')\">\n <section>\n <header>\n <strong>One of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'oneOf')\"\n :key=\"index\">\n <Schema :schema=\"subSchema\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaNot(resolvedSchema)\">\n <section>\n <header>\n <strong>Not:</strong>\n </header>\n <section>\n <Schema :schema=\"getSchemaNot(resolvedSchema)!\" />\n </section>\n </section>\n </template>\n\n <!-- Object type -->\n <template\n v-else-if=\"\n getSchemaType(resolvedSchema) === 'object' ||\n Object.keys(getSchemaProperties(resolvedSchema)).length\n \">\n <section>\n <ul>\n <template\n v-for=\"(propSchema, propName) in sortProperties(\n getSchemaProperties(resolvedSchema),\n getSchemaRequired(resolvedSchema),\n )\"\n :key=\"propName\">\n <li>\n <strong>\n <code>{{ propName }}</code>\n <span\n v-if=\"getSchemaRequired(resolvedSchema).includes(propName)\">\n (required)\n </span>\n </strong>\n <p>\n <code>\n {{ formatSchemaType(propSchema) }}\n </code>\n <template v-if=\"getResolvedSchemaFormat(propSchema)\">\n <span\n >, format:\n <code>{{ getResolvedSchemaFormat(propSchema) }}</code></span\n >\n </template>\n <template v-if=\"getResolvedSchemaEnum(propSchema)\">\n <span\n >, possible values:\n <code>{{\n formatEnumValues(getResolvedSchemaEnum(propSchema))\n }}</code>\n </span>\n </template>\n <template\n v-if=\"getResolvedSchemaDefault(propSchema) !== undefined\">\n <span\n >, default:\n <code>{{\n JSON.stringify(getResolvedSchemaDefault(propSchema))\n }}</code></span\n >\n </template>\n <template v-if=\"getResolvedSchemaDescription(propSchema)\">\n <span> — {{ getResolvedSchemaDescription(propSchema) }}</span>\n </template>\n </p>\n <Schema\n v-if=\"\n getResolvedSchemaType(propSchema) === 'object' ||\n Object.keys(getResolvedSchemaProperties(propSchema)).length\n \"\n :schema=\"propSchema\" />\n <template\n v-if=\"\n getResolvedSchemaType(propSchema) === 'array' &&\n getResolvedSchemaItems(propSchema)\n \">\n <section>\n <header>\n <strong>Items:</strong>\n </header>\n <Schema :schema=\"getResolvedSchemaItems(propSchema)!\" />\n </section>\n </template>\n </li>\n </template>\n </ul>\n </section>\n </template>\n\n <!-- Array type -->\n <template\n v-else-if=\"\n getSchemaType(resolvedSchema) === 'array' &&\n getSchemaItems(resolvedSchema)\n \">\n <section>\n <header>\n <strong>Array of:</strong>\n </header>\n <section>\n <Schema :schema=\"getSchemaItems(resolvedSchema)!\" />\n </section>\n <ul\n v-if=\"\n getSchemaMinItems(resolvedSchema) !== undefined ||\n getSchemaMaxItems(resolvedSchema) !== undefined ||\n getSchemaUniqueItems(resolvedSchema)\n \">\n <li v-if=\"getSchemaMinItems(resolvedSchema) !== undefined\">\n Min items: <code>{{ getSchemaMinItems(resolvedSchema) }}</code>\n </li>\n <li v-if=\"getSchemaMaxItems(resolvedSchema) !== undefined\">\n Max items: <code>{{ getSchemaMaxItems(resolvedSchema) }}</code>\n </li>\n <li v-if=\"getSchemaUniqueItems(resolvedSchema)\">\n Unique items: <code>true</code>\n </li>\n </ul>\n </section>\n </template>\n\n <!-- Primitive types -->\n <template v-else>\n <section>\n <p>\n <code>{{ getSchemaType(resolvedSchema) }}</code>\n <template v-if=\"getSchemaFormat(resolvedSchema)\">\n <span\n >, format:\n <code>{{ getSchemaFormat(resolvedSchema) }}</code></span\n >\n </template>\n <template v-if=\"getSchemaEnum(resolvedSchema)\">\n <span\n >, possible values:\n <code>{{ formatEnumValues(getSchemaEnum(resolvedSchema)) }}</code>\n </span>\n </template>\n <template v-if=\"getSchemaDefault(resolvedSchema) !== undefined\">\n <span\n >, default:\n <code>{{\n JSON.stringify(getSchemaDefault(resolvedSchema))\n }}</code></span\n >\n </template>\n <template v-if=\"getSchemaDescription(resolvedSchema)\">\n <span> — {{ getSchemaDescription(resolvedSchema) }}</span>\n </template>\n </p>\n </section>\n </template>\n </section>\n</template>\n","<script setup lang=\"ts\">\nimport { json2xml } from '@scalar/helpers/file/json2xml'\nimport type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema'\n\nwithDefaults(\n defineProps<{\n xml?: boolean\n modelValue: MaybeRefSchemaObject\n }>(),\n {\n xml: false,\n },\n)\n</script>\n<template>\n <template v-if=\"xml\">\n <pre><code class=\"language-xml\">{{ json2xml(modelValue) }}</code></pre>\n </template>\n <template v-else>\n <pre><code class=\"language-json\">{{ JSON.stringify(modelValue, null, 2) }}</code></pre>\n </template>\n</template>\n","<script setup lang=\"ts\">\nimport { json2xml } from '@scalar/helpers/file/json2xml'\nimport type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema'\n\nwithDefaults(\n defineProps<{\n xml?: boolean\n modelValue: MaybeRefSchemaObject\n }>(),\n {\n xml: false,\n },\n)\n</script>\n<template>\n <template v-if=\"xml\">\n <pre><code class=\"language-xml\">{{ json2xml(modelValue) }}</code></pre>\n </template>\n <template v-else>\n <pre><code class=\"language-json\">{{ JSON.stringify(modelValue, null, 2) }}</code></pre>\n </template>\n</template>\n","<script setup lang=\"ts\">\nimport { ScalarMarkdown } from '@scalar/components'\nimport { getExampleFromSchema } from '@scalar/oas-utils/spec-getters'\nimport { getResolvedRef } from '@scalar/workspace-store/helpers/get-resolved-ref'\nimport type {\n OpenApiDocument,\n OperationObject,\n RequestBodyObject,\n ResponseObject,\n SchemaObject,\n} from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { computed } from 'vue'\n\n// import { snippetz, type HarRequest } from '@scalar/snippetz'\n\nimport Schema from './Schema.vue'\nimport XmlOrJson from './XmlOrJson.vue'\n\ntype MarkdownDocument = Partial<OpenApiDocument> &\n Pick<OpenApiDocument, 'openapi' | 'info'>\ntype SchemaView = {\n description?: string\n title?: string\n type?: string | string[]\n}\ntype RequestBodyView = {\n content?: Record<string, { schema?: unknown }>\n}\ntype ResponseView = {\n description?: string\n content?: Record<string, { schema?: unknown }>\n}\n\ntype OperationEntry = {\n path: string\n method: string\n operation: OperationObject\n requestBody: RequestBodyView | null\n responses: Array<{\n statusCode: string\n response: ResponseView\n }>\n}\n\nconst { content } = defineProps<{\n content: MarkdownDocument\n}>()\n\n// const getRequestExample = (harRequest: Partial<HarRequest>) => {\n// const snippet = snippetz().print('shell', 'curl', {\n// httpVersion: 'HTTP/1.1',\n// headers: [],\n// queryString: [],\n// cookies: [],\n// headersSize: -1,\n// bodySize: -1,\n// method: 'get',\n// ...harRequest,\n// })\n\n// return snippet\n// }\n\nconst resolveRefAs = <TResolved extends object>(\n reference: unknown,\n): TResolved | null => {\n const resolved = getResolvedRef(reference as never)\n\n return resolved && typeof resolved === 'object'\n ? (resolved as TResolved)\n : null\n}\n\nconst resolveOperation = (operation: unknown): OperationObject | null =>\n resolveRefAs<OperationObject>(operation)\n\nconst resolveSchema = (schema: unknown): SchemaObject | null =>\n resolveRefAs<SchemaObject>(schema)\n\nconst resolveRequestBody = (body: unknown): RequestBodyObject | null =>\n resolveRefAs<RequestBodyObject>(body)\n\nconst resolveResponse = (response: unknown): ResponseObject | null =>\n resolveRefAs<ResponseObject>(response)\n\nconst toRequestBodyView = (body: unknown): RequestBodyView | null =>\n resolveRequestBody(body) as unknown as RequestBodyView | null\n\nconst toResponseView = (response: unknown): ResponseView | null =>\n resolveResponse(response) as unknown as ResponseView | null\n\nconst HTTP_METHODS = new Set([\n 'get',\n 'put',\n 'post',\n 'delete',\n 'options',\n 'head',\n 'patch',\n 'trace',\n])\n\nconst operations = computed<OperationEntry[]>(() => {\n const paths = content?.paths ?? {}\n\n return Object.entries(paths).flatMap(([path, pathItem]) => {\n if (!pathItem || typeof pathItem !== 'object') {\n return []\n }\n\n return Object.entries(pathItem).flatMap(([method, operation]) => {\n if (!HTTP_METHODS.has(method)) {\n return []\n }\n\n const resolvedOperation = resolveOperation(operation)\n\n if (!resolvedOperation) {\n return []\n }\n\n const requestBody = toRequestBodyView(resolvedOperation.requestBody)\n const responses = Object.entries(\n resolvedOperation.responses ?? {},\n ).flatMap(([statusCode, response]) => {\n const resolvedResponse = toResponseView(response)\n\n if (!resolvedResponse) {\n return []\n }\n\n return [{ statusCode, response: resolvedResponse }]\n })\n\n return [\n {\n path,\n method,\n operation: resolvedOperation,\n requestBody,\n responses,\n },\n ]\n })\n })\n})\n\nconst webhooks = computed(() => {\n const webhookItems = content?.webhooks ?? {}\n\n return Object.entries(webhookItems).flatMap(([name, pathItem]) => {\n if (!pathItem || typeof pathItem !== 'object') {\n return []\n }\n\n return Object.entries(pathItem).flatMap(([method, operation]) => {\n if (!HTTP_METHODS.has(method)) {\n return []\n }\n\n const resolvedOperation = resolveOperation(operation)\n\n if (!resolvedOperation) {\n return []\n }\n\n return [{ name, method, operation: resolvedOperation }]\n })\n })\n})\n\nconst componentSchemas = computed(() => {\n const schemas = content?.components?.schemas ?? {}\n\n return Object.entries(schemas).flatMap(([name, schema]) => {\n const resolvedSchema = resolveSchema(schema)\n\n if (!resolvedSchema) {\n return []\n }\n\n return [{ name, schema: resolvedSchema }]\n })\n})\n\nconst getSchemaView = (schema: SchemaObject): SchemaView =>\n schema as unknown as SchemaView\n</script>\n\n<template>\n <section>\n <header>\n <h1>{{ content?.info?.title }}</h1>\n <ul>\n <li>\n <strong>OpenAPI Version:</strong> <code>{{\n content?.openapi\n }}</code>\n </li>\n <li>\n <strong>API Version:</strong> <code>{{\n content?.info?.version\n }}</code>\n </li>\n </ul>\n </header>\n\n <ScalarMarkdown\n :value=\"content?.info?.description\"\n v-if=\"content?.info?.description\" />\n\n <section v-if=\"content?.servers?.length\">\n <h2>Servers</h2>\n <ul>\n <template\n v-for=\"server in content.servers\"\n :key=\"server.url\">\n <li>\n <strong>URL:</strong> <code>{{ server.url }}</code>\n <ul>\n <template v-if=\"server.description\">\n <li>\n <strong>Description:</strong> {{ server.description }}\n </li>\n </template>\n <template\n v-if=\"server.variables && Object.keys(server.variables).length\">\n <li>\n <strong>Variables:</strong>\n <ul>\n <template\n v-for=\"(variable, name) in server.variables\"\n :key=\"name\">\n <li>\n <code>{{ name }}</code> (default:\n <code>{{ variable.default }}</code\n >)<template v-if=\"variable.description\"\n >: {{ variable.description }}\n </template>\n </li>\n </template>\n </ul>\n </li>\n </template>\n </ul>\n </li>\n </template>\n </ul>\n </section>\n\n <section v-if=\"operations.length\">\n <h2>Operations</h2>\n\n <template\n v-for=\"entry in operations\"\n :key=\"`${entry.method}:${entry.path}`\">\n <section>\n <header>\n <h3>\n <template v-if=\"entry.operation.summary\">\n {{ entry.operation.summary }}\n </template>\n <template v-else>\n {{ entry.method.toString().toUpperCase() }} {{ entry.path }}\n </template>\n <template v-if=\"entry.operation['x-scalar-stability']\">\n ({{ entry.operation['x-scalar-stability'] }})\n </template>\n <template v-else-if=\"entry.operation.deprecated\">\n ⚠️ Deprecated\n </template>\n </h3>\n </header>\n\n <ul>\n <li>\n <strong>Method:</strong> <code>{{\n entry.method.toString().toUpperCase()\n }}</code>\n </li>\n <li>\n <strong>Path:</strong> <code>{{ entry.path }}</code>\n </li>\n <template v-if=\"entry.operation.tags\">\n <li>\n <strong>Tags:</strong> {{\n entry.operation.tags.join(', ')\n }}\n </li>\n </template>\n <template v-if=\"entry.operation['x-scalar-stability']\">\n <li>\n <strong>Stability:</strong> {{\n entry.operation['x-scalar-stability']\n }}\n </li>\n </template>\n </ul>\n\n <ScalarMarkdown :value=\"entry.operation.description\" />\n\n <!-- TODO: We need way more context to generate proper request examples -->\n <!-- <section>\n <h4>Request Example</h4>\n <pre><code>{{ getRequestExample({\n method: method.toString(),\n url: content.servers?.[0]?.url + path,\n }) }}</code></pre>\n </section> -->\n\n <template v-if=\"entry.requestBody?.content\">\n <section>\n <h4>Request Body</h4>\n <template\n v-for=\"(bodyContent, mediaType) in entry.requestBody.content\"\n :key=\"mediaType\">\n <h5>Content-Type: {{ mediaType }}</h5>\n <template v-if=\"resolveSchema(bodyContent.schema)\">\n <Schema :schema=\"resolveSchema(bodyContent.schema)!\" />\n <p><strong>Example:</strong></p>\n <XmlOrJson\n :xml=\"mediaType?.toString().includes('xml')\"\n :model-value=\"\n getExampleFromSchema(resolveSchema(bodyContent.schema)!, {\n xml: mediaType?.toString().includes('xml'),\n })\n \" />\n </template>\n </template>\n </section>\n </template>\n\n <template v-if=\"entry.responses.length\">\n <section>\n <h4>Responses</h4>\n\n <template\n v-for=\"entryResponse in entry.responses\"\n :key=\"entryResponse.statusCode\">\n <section>\n <header>\n <h5>\n Status: {{ entryResponse.statusCode }}\n <template v-if=\"entryResponse.response.description\">\n {{ entryResponse.response.description }}\n </template>\n </h5>\n </header>\n <template v-if=\"entryResponse.response.content\">\n <template\n v-for=\"(responseContent, mediaType) in entryResponse\n .response.content\"\n :key=\"mediaType\">\n <section>\n <h6>Content-Type: {{ mediaType }}</h6>\n <template v-if=\"resolveSchema(responseContent.schema)\">\n <Schema\n :schema=\"resolveSchema(responseContent.schema)!\" />\n <p><strong>Example:</strong></p>\n <XmlOrJson\n :xml=\"mediaType?.toString().includes('xml')\"\n :model-value=\"\n getExampleFromSchema(\n resolveSchema(responseContent.schema)!,\n {\n xml: mediaType?.toString().includes('xml'),\n },\n )\n \" />\n </template>\n </section>\n </template>\n </template>\n </section>\n </template>\n </section>\n </template>\n </section>\n </template>\n </section>\n\n <section v-if=\"webhooks.length\">\n <h2>Webhooks</h2>\n\n <template\n v-for=\"webhook in webhooks\"\n :key=\"`${webhook.name}:${webhook.method}`\">\n <section>\n <header>\n <h3>\n <template v-if=\"webhook.operation.summary\">\n {{ webhook.operation.summary }}\n </template>\n <template v-else>\n {{ webhook.name }}\n </template>\n <template v-if=\"webhook.operation['x-scalar-stability']\">\n <span>({{ webhook.operation['x-scalar-stability'] }})</span>\n </template>\n <template v-else-if=\"webhook.operation.deprecated\">\n <span>⚠️ Deprecated</span>\n </template>\n </h3>\n </header>\n\n <ul>\n <li>\n <strong>Method:</strong>\n <code>{{ webhook.method.toString().toUpperCase() }}</code>\n </li>\n <li>\n <strong>Path:</strong>\n <code>/webhooks/{{ webhook.name }}</code>\n </li>\n <template v-if=\"webhook.operation.tags\">\n <li>\n <strong>Tags:</strong>\n {{ webhook.operation.tags.join(', ') }}\n </li>\n </template>\n <template v-if=\"webhook.operation.deprecated\">\n <li><strong>Deprecated</strong></li>\n </template>\n </ul>\n\n <ScalarMarkdown :value=\"webhook.operation.description\" />\n\n <!-- TODO: We need way more context to generate proper request examples -->\n <!-- <section>\n <h4>Request Example</h4>\n <pre><code>{{ getRequestExample({\n method: method.toString(),\n url: content.servers?.[0]?.url + '/webhooks/' + name,\n }) }}</code></pre>\n </section> -->\n </section>\n </template>\n </section>\n\n <section v-if=\"componentSchemas.length\">\n <h2>Schemas</h2>\n <template\n v-for=\"entry in componentSchemas\"\n :key=\"entry.name\">\n <section>\n <header>\n <h3>{{ getSchemaView(entry.schema).title ?? entry.name }}</h3>\n </header>\n <ul>\n <li>\n <strong>Type:</strong>\n <code>{{ getSchemaView(entry.schema).type }}</code>\n </li>\n </ul>\n <template v-if=\"getSchemaView(entry.schema).description\">\n <ScalarMarkdown :value=\"getSchemaView(entry.schema).description\" />\n </template>\n <Schema\n v-if=\"getSchemaView(entry.schema).type === 'object'\"\n :schema=\"entry.schema\" />\n <p><strong>Example:</strong></p>\n <template v-if=\"getSchemaView(entry.schema).type === 'object'\">\n <XmlOrJson :model-value=\"getExampleFromSchema(entry.schema)\" />\n </template>\n </section>\n </template>\n </section>\n </section>\n</template>\n","<script setup lang=\"ts\">\nimport { ScalarMarkdown } from '@scalar/components'\nimport { getExampleFromSchema } from '@scalar/oas-utils/spec-getters'\nimport { getResolvedRef } from '@scalar/workspace-store/helpers/get-resolved-ref'\nimport type {\n OpenApiDocument,\n OperationObject,\n RequestBodyObject,\n ResponseObject,\n SchemaObject,\n} from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { computed } from 'vue'\n\n// import { snippetz, type HarRequest } from '@scalar/snippetz'\n\nimport Schema from './Schema.vue'\nimport XmlOrJson from './XmlOrJson.vue'\n\ntype MarkdownDocument = Partial<OpenApiDocument> &\n Pick<OpenApiDocument, 'openapi' | 'info'>\ntype SchemaView = {\n description?: string\n title?: string\n type?: string | string[]\n}\ntype RequestBodyView = {\n content?: Record<string, { schema?: unknown }>\n}\ntype ResponseView = {\n description?: string\n content?: Record<string, { schema?: unknown }>\n}\n\ntype OperationEntry = {\n path: string\n method: string\n operation: OperationObject\n requestBody: RequestBodyView | null\n responses: Array<{\n statusCode: string\n response: ResponseView\n }>\n}\n\nconst { content } = defineProps<{\n content: MarkdownDocument\n}>()\n\n// const getRequestExample = (harRequest: Partial<HarRequest>) => {\n// const snippet = snippetz().print('shell', 'curl', {\n// httpVersion: 'HTTP/1.1',\n// headers: [],\n// queryString: [],\n// cookies: [],\n// headersSize: -1,\n// bodySize: -1,\n// method: 'get',\n// ...harRequest,\n// })\n\n// return snippet\n// }\n\nconst resolveRefAs = <TResolved extends object>(\n reference: unknown,\n): TResolved | null => {\n const resolved = getResolvedRef(reference as never)\n\n return resolved && typeof resolved === 'object'\n ? (resolved as TResolved)\n : null\n}\n\nconst resolveOperation = (operation: unknown): OperationObject | null =>\n resolveRefAs<OperationObject>(operation)\n\nconst resolveSchema = (schema: unknown): SchemaObject | null =>\n resolveRefAs<SchemaObject>(schema)\n\nconst resolveRequestBody = (body: unknown): RequestBodyObject | null =>\n resolveRefAs<RequestBodyObject>(body)\n\nconst resolveResponse = (response: unknown): ResponseObject | null =>\n resolveRefAs<ResponseObject>(response)\n\nconst toRequestBodyView = (body: unknown): RequestBodyView | null =>\n resolveRequestBody(body) as unknown as RequestBodyView | null\n\nconst toResponseView = (response: unknown): ResponseView | null =>\n resolveResponse(response) as unknown as ResponseView | null\n\nconst HTTP_METHODS = new Set([\n 'get',\n 'put',\n 'post',\n 'delete',\n 'options',\n 'head',\n 'patch',\n 'trace',\n])\n\nconst operations = computed<OperationEntry[]>(() => {\n const paths = content?.paths ?? {}\n\n return Object.entries(paths).flatMap(([path, pathItem]) => {\n if (!pathItem || typeof pathItem !== 'object') {\n return []\n }\n\n return Object.entries(pathItem).flatMap(([method, operation]) => {\n if (!HTTP_METHODS.has(method)) {\n return []\n }\n\n const resolvedOperation = resolveOperation(operation)\n\n if (!resolvedOperation) {\n return []\n }\n\n const requestBody = toRequestBodyView(resolvedOperation.requestBody)\n const responses = Object.entries(\n resolvedOperation.responses ?? {},\n ).flatMap(([statusCode, response]) => {\n const resolvedResponse = toResponseView(response)\n\n if (!resolvedResponse) {\n return []\n }\n\n return [{ statusCode, response: resolvedResponse }]\n })\n\n return [\n {\n path,\n method,\n operation: resolvedOperation,\n requestBody,\n responses,\n },\n ]\n })\n })\n})\n\nconst webhooks = computed(() => {\n const webhookItems = content?.webhooks ?? {}\n\n return Object.entries(webhookItems).flatMap(([name, pathItem]) => {\n if (!pathItem || typeof pathItem !== 'object') {\n return []\n }\n\n return Object.entries(pathItem).flatMap(([method, operation]) => {\n if (!HTTP_METHODS.has(method)) {\n return []\n }\n\n const resolvedOperation = resolveOperation(operation)\n\n if (!resolvedOperation) {\n return []\n }\n\n return [{ name, method, operation: resolvedOperation }]\n })\n })\n})\n\nconst componentSchemas = computed(() => {\n const schemas = content?.components?.schemas ?? {}\n\n return Object.entries(schemas).flatMap(([name, schema]) => {\n const resolvedSchema = resolveSchema(schema)\n\n if (!resolvedSchema) {\n return []\n }\n\n return [{ name, schema: resolvedSchema }]\n })\n})\n\nconst getSchemaView = (schema: SchemaObject): SchemaView =>\n schema as unknown as SchemaView\n</script>\n\n<template>\n <section>\n <header>\n <h1>{{ content?.info?.title }}</h1>\n <ul>\n <li>\n <strong>OpenAPI Version:</strong> <code>{{\n content?.openapi\n }}</code>\n </li>\n <li>\n <strong>API Version:</strong> <code>{{\n content?.info?.version\n }}</code>\n </li>\n </ul>\n </header>\n\n <ScalarMarkdown\n :value=\"content?.info?.description\"\n v-if=\"content?.info?.description\" />\n\n <section v-if=\"content?.servers?.length\">\n <h2>Servers</h2>\n <ul>\n <template\n v-for=\"server in content.servers\"\n :key=\"server.url\">\n <li>\n <strong>URL:</strong> <code>{{ server.url }}</code>\n <ul>\n <template v-if=\"server.description\">\n <li>\n <strong>Description:</strong> {{ server.description }}\n </li>\n </template>\n <template\n v-if=\"server.variables && Object.keys(server.variables).length\">\n <li>\n <strong>Variables:</strong>\n <ul>\n <template\n v-for=\"(variable, name) in server.variables\"\n :key=\"name\">\n <li>\n <code>{{ name }}</code> (default:\n <code>{{ variable.default }}</code\n >)<template v-if=\"variable.description\"\n >: {{ variable.description }}\n </template>\n </li>\n </template>\n </ul>\n </li>\n </template>\n </ul>\n </li>\n </template>\n </ul>\n </section>\n\n <section v-if=\"operations.length\">\n <h2>Operations</h2>\n\n <template\n v-for=\"entry in operations\"\n :key=\"`${entry.method}:${entry.path}`\">\n <section>\n <header>\n <h3>\n <template v-if=\"entry.operation.summary\">\n {{ entry.operation.summary }}\n </template>\n <template v-else>\n {{ entry.method.toString().toUpperCase() }} {{ entry.path }}\n </template>\n <template v-if=\"entry.operation['x-scalar-stability']\">\n ({{ entry.operation['x-scalar-stability'] }})\n </template>\n <template v-else-if=\"entry.operation.deprecated\">\n ⚠️ Deprecated\n </template>\n </h3>\n </header>\n\n <ul>\n <li>\n <strong>Method:</strong> <code>{{\n entry.method.toString().toUpperCase()\n }}</code>\n </li>\n <li>\n <strong>Path:</strong> <code>{{ entry.path }}</code>\n </li>\n <template v-if=\"entry.operation.tags\">\n <li>\n <strong>Tags:</strong> {{\n entry.operation.tags.join(', ')\n }}\n </li>\n </template>\n <template v-if=\"entry.operation['x-scalar-stability']\">\n <li>\n <strong>Stability:</strong> {{\n entry.operation['x-scalar-stability']\n }}\n </li>\n </template>\n </ul>\n\n <ScalarMarkdown :value=\"entry.operation.description\" />\n\n <!-- TODO: We need way more context to generate proper request examples -->\n <!-- <section>\n <h4>Request Example</h4>\n <pre><code>{{ getRequestExample({\n method: method.toString(),\n url: content.servers?.[0]?.url + path,\n }) }}</code></pre>\n </section> -->\n\n <template v-if=\"entry.requestBody?.content\">\n <section>\n <h4>Request Body</h4>\n <template\n v-for=\"(bodyContent, mediaType) in entry.requestBody.content\"\n :key=\"mediaType\">\n <h5>Content-Type: {{ mediaType }}</h5>\n <template v-if=\"resolveSchema(bodyContent.schema)\">\n <Schema :schema=\"resolveSchema(bodyContent.schema)!\" />\n <p><strong>Example:</strong></p>\n <XmlOrJson\n :xml=\"mediaType?.toString().includes('xml')\"\n :model-value=\"\n getExampleFromSchema(resolveSchema(bodyContent.schema)!, {\n xml: mediaType?.toString().includes('xml'),\n })\n \" />\n </template>\n </template>\n </section>\n </template>\n\n <template v-if=\"entry.responses.length\">\n <section>\n <h4>Responses</h4>\n\n <template\n v-for=\"entryResponse in entry.responses\"\n :key=\"entryResponse.statusCode\">\n <section>\n <header>\n <h5>\n Status: {{ entryResponse.statusCode }}\n <template v-if=\"entryResponse.response.description\">\n {{ entryResponse.response.description }}\n </template>\n </h5>\n </header>\n <template v-if=\"entryResponse.response.content\">\n <template\n v-for=\"(responseContent, mediaType) in entryResponse\n .response.content\"\n :key=\"mediaType\">\n <section>\n <h6>Content-Type: {{ mediaType }}</h6>\n <template v-if=\"resolveSchema(responseContent.schema)\">\n <Schema\n :schema=\"resolveSchema(responseContent.schema)!\" />\n <p><strong>Example:</strong></p>\n <XmlOrJson\n :xml=\"mediaType?.toString().includes('xml')\"\n :model-value=\"\n getExampleFromSchema(\n resolveSchema(responseContent.schema)!,\n {\n xml: mediaType?.toString().includes('xml'),\n },\n )\n \" />\n </template>\n </section>\n </template>\n </template>\n </section>\n </template>\n </section>\n </template>\n </section>\n </template>\n </section>\n\n <section v-if=\"webhooks.length\">\n <h2>Webhooks</h2>\n\n <template\n v-for=\"webhook in webhooks\"\n :key=\"`${webhook.name}:${webhook.method}`\">\n <section>\n <header>\n <h3>\n <template v-if=\"webhook.operation.summary\">\n {{ webhook.operation.summary }}\n </template>\n <template v-else>\n {{ webhook.name }}\n </template>\n <template v-if=\"webhook.operation['x-scalar-stability']\">\n <span>({{ webhook.operation['x-scalar-stability'] }})</span>\n </template>\n <template v-else-if=\"webhook.operation.deprecated\">\n <span>⚠️ Deprecated</span>\n </template>\n </h3>\n </header>\n\n <ul>\n <li>\n <strong>Method:</strong>\n <code>{{ webhook.method.toString().toUpperCase() }}</code>\n </li>\n <li>\n <strong>Path:</strong>\n <code>/webhooks/{{ webhook.name }}</code>\n </li>\n <template v-if=\"webhook.operation.tags\">\n <li>\n <strong>Tags:</strong>\n {{ webhook.operation.tags.join(', ') }}\n </li>\n </template>\n <template v-if=\"webhook.operation.deprecated\">\n <li><strong>Deprecated</strong></li>\n </template>\n </ul>\n\n <ScalarMarkdown :value=\"webhook.operation.description\" />\n\n <!-- TODO: We need way more context to generate proper request examples -->\n <!-- <section>\n <h4>Request Example</h4>\n <pre><code>{{ getRequestExample({\n method: method.toString(),\n url: content.servers?.[0]?.url + '/webhooks/' + name,\n }) }}</code></pre>\n </section> -->\n </section>\n </template>\n </section>\n\n <section v-if=\"componentSchemas.length\">\n <h2>Schemas</h2>\n <template\n v-for=\"entry in componentSchemas\"\n :key=\"entry.name\">\n <section>\n <header>\n <h3>{{ getSchemaView(entry.schema).title ?? entry.name }}</h3>\n </header>\n <ul>\n <li>\n <strong>Type:</strong>\n <code>{{ getSchemaView(entry.schema).type }}</code>\n </li>\n </ul>\n <template v-if=\"getSchemaView(entry.schema).description\">\n <ScalarMarkdown :value=\"getSchemaView(entry.schema).description\" />\n </template>\n <Schema\n v-if=\"getSchemaView(entry.schema).type === 'object'\"\n :schema=\"entry.schema\" />\n <p><strong>Example:</strong></p>\n <template v-if=\"getSchemaView(entry.schema).type === 'object'\">\n <XmlOrJson :model-value=\"getExampleFromSchema(entry.schema)\" />\n </template>\n </section>\n </template>\n </section>\n </section>\n</template>\n","import { isObject } from '@scalar/helpers/object/is-object'\nimport { readFiles } from '@scalar/json-magic/bundle/plugins/node'\nimport { normalize } from '@scalar/json-magic/helpers/normalize'\nimport type { OpenApiDocument, PathItemObject } from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { createWorkspaceStore } from '@scalar/workspace-store/client'\nimport { minify } from 'html-minifier-terser'\nimport rehypeParse from 'rehype-parse'\nimport rehypeRemark from 'rehype-remark'\nimport rehypeSanitize from 'rehype-sanitize'\nimport remarkGfm from 'remark-gfm'\nimport remarkStringify from 'remark-stringify'\nimport { unified } from 'unified'\nimport { createSSRApp } from 'vue'\nimport { renderToString } from 'vue/server-renderer'\n\nimport MarkdownReference from './components/MarkdownReference.vue'\n\ntype AnyDocument = OpenApiDocument | Record<string, unknown> | string\ntype HttpMethodKeys = Exclude<keyof PathItemObject, '$ref' | 'summary' | 'description' | 'servers' | 'parameters'>\nexport type HttpMethod = Extract<HttpMethodKeys, string>\nexport type OperationSelector =\n | {\n path: string\n method: HttpMethod | Uppercase<HttpMethod>\n }\n | {\n operationId: string\n }\n | {\n pointer: string\n }\nexport type OpenApiRenderOptions = {\n operation?: OperationSelector\n}\ntype WorkspaceInput =\n | {\n document: Record<string, unknown>\n }\n | {\n url: string\n }\n | {\n path: string\n }\ntype OperationMatch = {\n path: string\n method: HttpMethod\n}\n\nconst HTTP_METHODS: HttpMethod[] = ['get', 'put', 'post', 'delete', 'options', 'head', 'patch', 'trace']\nconst HTTP_METHOD_SET = new Set<string>(HTTP_METHODS)\n\nconst isHttpUrl = (value: string): boolean => {\n try {\n const url = new URL(value)\n return url.protocol === 'http:' || url.protocol === 'https:'\n } catch {\n return false\n }\n}\n\nconst toWorkspaceInput = (input: AnyDocument): WorkspaceInput => {\n if (typeof input !== 'string') {\n return { document: input as Record<string, unknown> }\n }\n\n const normalized = normalize(input)\n\n if (isObject(normalized)) {\n return { document: normalized as Record<string, unknown> }\n }\n\n if (isHttpUrl(input)) {\n return { url: input }\n }\n\n return { path: input }\n}\n\nconst normalizeHttpMethod = (method: string): HttpMethod | null => {\n const normalized = method.toLowerCase()\n\n if (HTTP_METHOD_SET.has(normalized)) {\n return normalized as HttpMethod\n }\n\n return null\n}\n\nconst normalizeJsonPointer = (pointer: string): string => {\n if (pointer.startsWith('#/')) {\n return pointer.slice(1)\n }\n\n if (pointer.startsWith('/')) {\n return pointer\n }\n\n throw new Error(`Invalid JSON pointer \"${pointer}\". JSON pointers must start with \"#/\"`)\n}\n\nconst parseJsonPointer = (pointer: string): string[] =>\n normalizeJsonPointer(pointer)\n .slice(1)\n .split('/')\n .map((segment) => segment.replaceAll('~1', '/').replaceAll('~0', '~'))\n\nconst getOperationSelectorFromPointer = (pointer: string): Extract<OperationSelector, { path: string }> => {\n const segments = parseJsonPointer(pointer)\n\n if (segments.length !== 3 || segments[0] !== 'paths') {\n throw new Error(`JSON pointer \"${pointer}\" must target an operation object under \"/paths/{path}/{method}\"`)\n }\n\n const path = segments[1]\n const method = segments[2]\n\n if (!path || !method) {\n throw new Error(`JSON pointer \"${pointer}\" must target an operation object under \"/paths/{path}/{method}\"`)\n }\n\n return {\n path,\n method: method as HttpMethod,\n }\n}\n\nconst getPathEntries = (document: OpenApiDocument): Array<[string, PathItemObject]> => {\n const paths = document.paths\n\n if (!isObject(paths)) {\n return []\n }\n\n return Object.entries(paths).flatMap(([path, pathItem]) =>\n isObject(pathItem) ? [[path, pathItem as PathItemObject]] : [],\n )\n}\n\nconst filterPathItemToSingleOperation = (pathItem: PathItemObject, selectedMethod: HttpMethod): PathItemObject =>\n Object.fromEntries(\n Object.entries(pathItem).filter(([key]) => {\n const method = normalizeHttpMethod(key)\n return !method || method === selectedMethod\n }),\n )\n\nconst findOperationByPathAndMethod = (\n document: OpenApiDocument,\n selector: Extract<OperationSelector, { path: string }>,\n): OperationMatch => {\n const method = normalizeHttpMethod(selector.method)\n\n if (!method) {\n throw new Error(`Invalid HTTP method \"${selector.method}\". Supported methods: ${HTTP_METHODS.join(', ')}`)\n }\n\n const pathEntries = getPathEntries(document)\n const pathItem = pathEntries.find(([path]) => path === selector.path)?.[1]\n\n if (!pathItem || !(method in pathItem)) {\n throw new Error(`Operation not found for path \"${selector.path}\" and method \"${method.toUpperCase()}\"`)\n }\n\n return {\n path: selector.path,\n method,\n }\n}\n\nconst findOperationsByOperationId = (document: OpenApiDocument, operationId: string): OperationMatch[] =>\n getPathEntries(document).flatMap(([path, pathItem]) =>\n Object.entries(pathItem).flatMap(([methodKey, operation]) => {\n const method = normalizeHttpMethod(methodKey)\n\n if (!method || !isObject(operation)) {\n return []\n }\n\n const candidateOperationId =\n 'operationId' in operation && typeof operation.operationId === 'string' ? operation.operationId : undefined\n\n if (candidateOperationId !== operationId) {\n return []\n }\n\n return [{ path, method }]\n }),\n )\n\nconst resolveOperationMatch = (document: OpenApiDocument, selector: OperationSelector): OperationMatch => {\n if ('pointer' in selector) {\n return findOperationByPathAndMethod(document, getOperationSelectorFromPointer(selector.pointer))\n }\n\n if ('operationId' in selector) {\n const matches = findOperationsByOperationId(document, selector.operationId)\n\n if (!matches.length) {\n throw new Error(`Operation with operationId \"${selector.operationId}\" was not found`)\n }\n\n if (matches.length > 1) {\n const uniqueCandidates = matches.map(({ path, method }) => `\"${method.toUpperCase()} ${path}\"`)\n\n throw new Error(\n `Multiple operations found for operationId \"${selector.operationId}\". Use { path, method } instead. Matches: ${uniqueCandidates.join(', ')}`,\n )\n }\n\n return matches[0] as OperationMatch\n }\n\n return findOperationByPathAndMethod(document, selector)\n}\n\nconst filterDocumentByOperation = (document: OpenApiDocument, selector: OperationSelector): OpenApiDocument => {\n const match = resolveOperationMatch(document, selector)\n const pathItem = getPathEntries(document).find(([path]) => path === match.path)?.[1]\n\n if (!pathItem) {\n throw new Error(`Operation not found for path \"${match.path}\" and method \"${match.method.toUpperCase()}\"`)\n }\n\n return {\n ...document,\n paths: {\n [match.path]: filterPathItemToSingleOperation(pathItem, match.method),\n },\n }\n}\n\nexport async function createHtmlFromOpenApi(input: AnyDocument, options?: OpenApiRenderOptions) {\n const workspaceStore = createWorkspaceStore({\n fileLoader: readFiles(),\n })\n\n const name = 'openapi-to-markdown'\n const loaded = await workspaceStore.addDocument({\n name,\n ...toWorkspaceInput(input),\n })\n\n if (!loaded) {\n throw new Error('Failed to load OpenAPI document')\n }\n\n const content = workspaceStore.workspace.documents[name]\n\n if (!content) {\n throw new Error('OpenAPI document could not be resolved')\n }\n\n const renderedContent =\n options?.operation && isObject(content)\n ? filterDocumentByOperation(content as OpenApiDocument, options.operation)\n : content\n\n // Create and configure a server-side rendered Vue app\n const app = createSSRApp(MarkdownReference, {\n content: renderedContent,\n })\n\n // Get static HTML\n const html = await renderToString(app)\n\n // Clean the output\n return minify(html, {\n removeComments: true,\n removeEmptyElements: true,\n collapseWhitespace: true,\n continueOnParseError: true,\n noNewlinesBeforeTagClose: true,\n preserveLineBreaks: true,\n removeEmptyAttributes: true,\n decodeEntities: true,\n useShortDoctype: true,\n })\n}\n\nexport async function createMarkdownFromOpenApi(content: AnyDocument, options?: OpenApiRenderOptions) {\n return markdownFromHtml(await createHtmlFromOpenApi(content, options))\n}\n\nasync function markdownFromHtml(html: string): Promise<string> {\n const file = await unified()\n .use(rehypeParse, { fragment: true })\n .use(remarkGfm)\n .use(rehypeSanitize)\n .use(rehypeRemark)\n .use(remarkStringify, {\n bullet: '-',\n })\n .process(html)\n\n return String(file)\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../src/components/Schema.vue","../src/components/Schema.vue","../src/components/XmlOrJson.vue","../src/components/XmlOrJson.vue","../src/components/MarkdownReference.vue","../src/components/MarkdownReference.vue","../src/create-markdown-from-openapi.ts"],"sourcesContent":["<script setup lang=\"ts\">\nimport { resolve } from '@scalar/workspace-store/resolve'\nimport type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema'\n\nconst MAX_DEPTH = 10\n\nconst { schema, depth = 0 } = defineProps<{\n schema: MaybeRefSchemaObject\n depth?: number\n}>()\n\ntype ResolvedSchema = NonNullable<\n ReturnType<typeof resolve.schema<MaybeRefSchemaObject>>\n>\n\nconst resolvedSchema = resolve.schema(schema)\n\nconst resolveNestedSchema = (\n value: MaybeRefSchemaObject | undefined,\n): ResolvedSchema | undefined => resolve.schema(value)\n\nconst asObject = (value: unknown): Record<string, unknown> | undefined =>\n value !== null && typeof value === 'object'\n ? (value as Record<string, unknown>)\n : undefined\n\nconst getSchemaType = (\n value: ResolvedSchema | undefined,\n): string | string[] | undefined => {\n const schemaType = asObject(value)?.type\n if (typeof schemaType === 'string') {\n return schemaType\n }\n if (\n Array.isArray(schemaType) &&\n schemaType.every((entry) => typeof entry === 'string')\n ) {\n return schemaType\n }\n return undefined\n}\n\nconst getSchemaArray = (\n value: ResolvedSchema | undefined,\n key: 'allOf' | 'anyOf' | 'oneOf',\n): MaybeRefSchemaObject[] | undefined => {\n const collection = asObject(value)?.[key]\n if (!Array.isArray(collection)) {\n return undefined\n }\n return collection.filter(\n (entry): entry is MaybeRefSchemaObject =>\n entry !== null && typeof entry === 'object',\n )\n}\n\nconst getSchemaNot = (\n value: ResolvedSchema | undefined,\n): MaybeRefSchemaObject | undefined => {\n const notSchema = asObject(value)?.not\n return notSchema !== null && typeof notSchema === 'object'\n ? (notSchema as MaybeRefSchemaObject)\n : undefined\n}\n\nconst getSchemaProperties = (\n value: ResolvedSchema | undefined,\n): Record<string, MaybeRefSchemaObject> => {\n const properties = asObject(value)?.properties\n if (!properties || typeof properties !== 'object') {\n return {}\n }\n return Object.entries(properties).reduce<\n Record<string, MaybeRefSchemaObject>\n >((acc, [name, prop]) => {\n if (prop !== null && typeof prop === 'object') {\n acc[name] = prop as MaybeRefSchemaObject\n }\n return acc\n }, {})\n}\n\nconst getSchemaRequired = (value: ResolvedSchema | undefined): string[] => {\n const required = asObject(value)?.required\n if (!Array.isArray(required)) {\n return []\n }\n return required.filter((item): item is string => typeof item === 'string')\n}\n\nconst getSchemaItems = (\n value: ResolvedSchema | undefined,\n): MaybeRefSchemaObject | undefined => {\n const items = asObject(value)?.items\n return items !== null && typeof items === 'object'\n ? (items as MaybeRefSchemaObject)\n : undefined\n}\n\nconst getSchemaFormat = (\n value: ResolvedSchema | undefined,\n): string | undefined =>\n typeof asObject(value)?.format === 'string'\n ? (asObject(value)?.format as string)\n : undefined\n\nconst getSchemaEnum = (\n value: ResolvedSchema | undefined,\n): unknown[] | undefined => {\n const enumValues = asObject(value)?.enum\n return Array.isArray(enumValues) ? enumValues : undefined\n}\n\nconst getSchemaDefault = (value: ResolvedSchema | undefined): unknown =>\n asObject(value)?.default\n\nconst getSchemaDescription = (\n value: ResolvedSchema | undefined,\n): string | undefined =>\n typeof asObject(value)?.description === 'string'\n ? (asObject(value)?.description as string)\n : undefined\n\nconst getSchemaMinItems = (\n value: ResolvedSchema | undefined,\n): number | undefined =>\n typeof asObject(value)?.minItems === 'number'\n ? (asObject(value)?.minItems as number)\n : undefined\n\nconst getSchemaMaxItems = (\n value: ResolvedSchema | undefined,\n): number | undefined =>\n typeof asObject(value)?.maxItems === 'number'\n ? (asObject(value)?.maxItems as number)\n : undefined\n\nconst getSchemaUniqueItems = (\n value: ResolvedSchema | undefined,\n): boolean | undefined =>\n typeof asObject(value)?.uniqueItems === 'boolean'\n ? (asObject(value)?.uniqueItems as boolean)\n : undefined\n\nconst getResolvedSchemaType = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaType(resolveNestedSchema(value))\nconst getResolvedSchemaFormat = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaFormat(resolveNestedSchema(value))\nconst getResolvedSchemaEnum = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaEnum(resolveNestedSchema(value))\nconst getResolvedSchemaDefault = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaDefault(resolveNestedSchema(value))\nconst getResolvedSchemaDescription = (\n value: MaybeRefSchemaObject | undefined,\n) => getSchemaDescription(resolveNestedSchema(value))\nconst getResolvedSchemaProperties = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaProperties(resolveNestedSchema(value))\nconst getResolvedSchemaItems = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaItems(resolveNestedSchema(value))\n\nconst formatSchemaType = (value: MaybeRefSchemaObject | undefined): string => {\n const schemaType = getResolvedSchemaType(value)\n return Array.isArray(schemaType)\n ? schemaType.join(' | ')\n : schemaType || 'object'\n}\n\nconst formatEnumValues = (value: unknown[] | undefined): string =>\n value?.map((entry: unknown) => JSON.stringify(entry)).join(', ') || ''\n\n// Sort properties to show required fields first, then optional, then metadata\nconst sortProperties = (\n properties: Record<string, MaybeRefSchemaObject>,\n required?: string[],\n) => {\n const sorted = Object.entries(properties).sort(([a], [b]) => {\n const aRequired = required?.includes(a)\n const bRequired = required?.includes(b)\n if (aRequired && !bRequired) return -1\n if (!aRequired && bRequired) return 1\n return a.localeCompare(b)\n })\n return Object.fromEntries(sorted)\n}\n</script>\n\n<template>\n <section v-if=\"depth >= MAX_DEPTH\">\n <p><em>[Circular Reference]</em></p>\n </section>\n <section v-else-if=\"resolvedSchema\">\n <!-- Composition keywords -->\n <template v-if=\"getSchemaArray(resolvedSchema, 'allOf')\">\n <section>\n <header>\n <strong>All of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'allOf')\"\n :key=\"index\">\n <Schema\n :schema=\"subSchema\"\n :depth=\"depth + 1\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaArray(resolvedSchema, 'anyOf')\">\n <section>\n <header>\n <strong>Any of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'anyOf')\"\n :key=\"index\">\n <Schema\n :schema=\"subSchema\"\n :depth=\"depth + 1\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaArray(resolvedSchema, 'oneOf')\">\n <section>\n <header>\n <strong>One of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'oneOf')\"\n :key=\"index\">\n <Schema\n :schema=\"subSchema\"\n :depth=\"depth + 1\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaNot(resolvedSchema)\">\n <section>\n <header>\n <strong>Not:</strong>\n </header>\n <section>\n <Schema\n :schema=\"getSchemaNot(resolvedSchema)!\"\n :depth=\"depth + 1\" />\n </section>\n </section>\n </template>\n\n <!-- Object type -->\n <template\n v-else-if=\"\n getSchemaType(resolvedSchema) === 'object' ||\n Object.keys(getSchemaProperties(resolvedSchema)).length\n \">\n <section>\n <ul>\n <template\n v-for=\"(propSchema, propName) in sortProperties(\n getSchemaProperties(resolvedSchema),\n getSchemaRequired(resolvedSchema),\n )\"\n :key=\"propName\">\n <li>\n <strong>\n <code>{{ propName }}</code>\n <span\n v-if=\"getSchemaRequired(resolvedSchema).includes(propName)\">\n (required)\n </span>\n </strong>\n <p>\n <code>\n {{ formatSchemaType(propSchema) }}\n </code>\n <template v-if=\"getResolvedSchemaFormat(propSchema)\">\n <span\n >, format:\n <code>{{ getResolvedSchemaFormat(propSchema) }}</code></span\n >\n </template>\n <template v-if=\"getResolvedSchemaEnum(propSchema)\">\n <span\n >, possible values:\n <code>{{\n formatEnumValues(getResolvedSchemaEnum(propSchema))\n }}</code>\n </span>\n </template>\n <template\n v-if=\"getResolvedSchemaDefault(propSchema) !== undefined\">\n <span\n >, default:\n <code>{{\n JSON.stringify(getResolvedSchemaDefault(propSchema))\n }}</code></span\n >\n </template>\n <template v-if=\"getResolvedSchemaDescription(propSchema)\">\n <span> — {{ getResolvedSchemaDescription(propSchema) }}</span>\n </template>\n </p>\n <Schema\n v-if=\"\n getResolvedSchemaType(propSchema) === 'object' ||\n Object.keys(getResolvedSchemaProperties(propSchema)).length\n \"\n :schema=\"propSchema\"\n :depth=\"depth + 1\" />\n <template\n v-if=\"\n getResolvedSchemaType(propSchema) === 'array' &&\n getResolvedSchemaItems(propSchema)\n \">\n <section>\n <header>\n <strong>Items:</strong>\n </header>\n <Schema\n :schema=\"getResolvedSchemaItems(propSchema)!\"\n :depth=\"depth + 1\" />\n </section>\n </template>\n </li>\n </template>\n </ul>\n </section>\n </template>\n\n <!-- Array type -->\n <template\n v-else-if=\"\n getSchemaType(resolvedSchema) === 'array' &&\n getSchemaItems(resolvedSchema)\n \">\n <section>\n <header>\n <strong>Array of:</strong>\n </header>\n <section>\n <Schema\n :schema=\"getSchemaItems(resolvedSchema)!\"\n :depth=\"depth + 1\" />\n </section>\n <ul\n v-if=\"\n getSchemaMinItems(resolvedSchema) !== undefined ||\n getSchemaMaxItems(resolvedSchema) !== undefined ||\n getSchemaUniqueItems(resolvedSchema)\n \">\n <li v-if=\"getSchemaMinItems(resolvedSchema) !== undefined\">\n Min items: <code>{{ getSchemaMinItems(resolvedSchema) }}</code>\n </li>\n <li v-if=\"getSchemaMaxItems(resolvedSchema) !== undefined\">\n Max items: <code>{{ getSchemaMaxItems(resolvedSchema) }}</code>\n </li>\n <li v-if=\"getSchemaUniqueItems(resolvedSchema)\">\n Unique items: <code>true</code>\n </li>\n </ul>\n </section>\n </template>\n\n <!-- Primitive types -->\n <template v-else>\n <section>\n <p>\n <code>{{ getSchemaType(resolvedSchema) }}</code>\n <template v-if=\"getSchemaFormat(resolvedSchema)\">\n <span\n >, format:\n <code>{{ getSchemaFormat(resolvedSchema) }}</code></span\n >\n </template>\n <template v-if=\"getSchemaEnum(resolvedSchema)\">\n <span\n >, possible values:\n <code>{{ formatEnumValues(getSchemaEnum(resolvedSchema)) }}</code>\n </span>\n </template>\n <template v-if=\"getSchemaDefault(resolvedSchema) !== undefined\">\n <span\n >, default:\n <code>{{\n JSON.stringify(getSchemaDefault(resolvedSchema))\n }}</code></span\n >\n </template>\n <template v-if=\"getSchemaDescription(resolvedSchema)\">\n <span> — {{ getSchemaDescription(resolvedSchema) }}</span>\n </template>\n </p>\n </section>\n </template>\n </section>\n</template>\n","<script setup lang=\"ts\">\nimport { resolve } from '@scalar/workspace-store/resolve'\nimport type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema'\n\nconst MAX_DEPTH = 10\n\nconst { schema, depth = 0 } = defineProps<{\n schema: MaybeRefSchemaObject\n depth?: number\n}>()\n\ntype ResolvedSchema = NonNullable<\n ReturnType<typeof resolve.schema<MaybeRefSchemaObject>>\n>\n\nconst resolvedSchema = resolve.schema(schema)\n\nconst resolveNestedSchema = (\n value: MaybeRefSchemaObject | undefined,\n): ResolvedSchema | undefined => resolve.schema(value)\n\nconst asObject = (value: unknown): Record<string, unknown> | undefined =>\n value !== null && typeof value === 'object'\n ? (value as Record<string, unknown>)\n : undefined\n\nconst getSchemaType = (\n value: ResolvedSchema | undefined,\n): string | string[] | undefined => {\n const schemaType = asObject(value)?.type\n if (typeof schemaType === 'string') {\n return schemaType\n }\n if (\n Array.isArray(schemaType) &&\n schemaType.every((entry) => typeof entry === 'string')\n ) {\n return schemaType\n }\n return undefined\n}\n\nconst getSchemaArray = (\n value: ResolvedSchema | undefined,\n key: 'allOf' | 'anyOf' | 'oneOf',\n): MaybeRefSchemaObject[] | undefined => {\n const collection = asObject(value)?.[key]\n if (!Array.isArray(collection)) {\n return undefined\n }\n return collection.filter(\n (entry): entry is MaybeRefSchemaObject =>\n entry !== null && typeof entry === 'object',\n )\n}\n\nconst getSchemaNot = (\n value: ResolvedSchema | undefined,\n): MaybeRefSchemaObject | undefined => {\n const notSchema = asObject(value)?.not\n return notSchema !== null && typeof notSchema === 'object'\n ? (notSchema as MaybeRefSchemaObject)\n : undefined\n}\n\nconst getSchemaProperties = (\n value: ResolvedSchema | undefined,\n): Record<string, MaybeRefSchemaObject> => {\n const properties = asObject(value)?.properties\n if (!properties || typeof properties !== 'object') {\n return {}\n }\n return Object.entries(properties).reduce<\n Record<string, MaybeRefSchemaObject>\n >((acc, [name, prop]) => {\n if (prop !== null && typeof prop === 'object') {\n acc[name] = prop as MaybeRefSchemaObject\n }\n return acc\n }, {})\n}\n\nconst getSchemaRequired = (value: ResolvedSchema | undefined): string[] => {\n const required = asObject(value)?.required\n if (!Array.isArray(required)) {\n return []\n }\n return required.filter((item): item is string => typeof item === 'string')\n}\n\nconst getSchemaItems = (\n value: ResolvedSchema | undefined,\n): MaybeRefSchemaObject | undefined => {\n const items = asObject(value)?.items\n return items !== null && typeof items === 'object'\n ? (items as MaybeRefSchemaObject)\n : undefined\n}\n\nconst getSchemaFormat = (\n value: ResolvedSchema | undefined,\n): string | undefined =>\n typeof asObject(value)?.format === 'string'\n ? (asObject(value)?.format as string)\n : undefined\n\nconst getSchemaEnum = (\n value: ResolvedSchema | undefined,\n): unknown[] | undefined => {\n const enumValues = asObject(value)?.enum\n return Array.isArray(enumValues) ? enumValues : undefined\n}\n\nconst getSchemaDefault = (value: ResolvedSchema | undefined): unknown =>\n asObject(value)?.default\n\nconst getSchemaDescription = (\n value: ResolvedSchema | undefined,\n): string | undefined =>\n typeof asObject(value)?.description === 'string'\n ? (asObject(value)?.description as string)\n : undefined\n\nconst getSchemaMinItems = (\n value: ResolvedSchema | undefined,\n): number | undefined =>\n typeof asObject(value)?.minItems === 'number'\n ? (asObject(value)?.minItems as number)\n : undefined\n\nconst getSchemaMaxItems = (\n value: ResolvedSchema | undefined,\n): number | undefined =>\n typeof asObject(value)?.maxItems === 'number'\n ? (asObject(value)?.maxItems as number)\n : undefined\n\nconst getSchemaUniqueItems = (\n value: ResolvedSchema | undefined,\n): boolean | undefined =>\n typeof asObject(value)?.uniqueItems === 'boolean'\n ? (asObject(value)?.uniqueItems as boolean)\n : undefined\n\nconst getResolvedSchemaType = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaType(resolveNestedSchema(value))\nconst getResolvedSchemaFormat = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaFormat(resolveNestedSchema(value))\nconst getResolvedSchemaEnum = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaEnum(resolveNestedSchema(value))\nconst getResolvedSchemaDefault = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaDefault(resolveNestedSchema(value))\nconst getResolvedSchemaDescription = (\n value: MaybeRefSchemaObject | undefined,\n) => getSchemaDescription(resolveNestedSchema(value))\nconst getResolvedSchemaProperties = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaProperties(resolveNestedSchema(value))\nconst getResolvedSchemaItems = (value: MaybeRefSchemaObject | undefined) =>\n getSchemaItems(resolveNestedSchema(value))\n\nconst formatSchemaType = (value: MaybeRefSchemaObject | undefined): string => {\n const schemaType = getResolvedSchemaType(value)\n return Array.isArray(schemaType)\n ? schemaType.join(' | ')\n : schemaType || 'object'\n}\n\nconst formatEnumValues = (value: unknown[] | undefined): string =>\n value?.map((entry: unknown) => JSON.stringify(entry)).join(', ') || ''\n\n// Sort properties to show required fields first, then optional, then metadata\nconst sortProperties = (\n properties: Record<string, MaybeRefSchemaObject>,\n required?: string[],\n) => {\n const sorted = Object.entries(properties).sort(([a], [b]) => {\n const aRequired = required?.includes(a)\n const bRequired = required?.includes(b)\n if (aRequired && !bRequired) return -1\n if (!aRequired && bRequired) return 1\n return a.localeCompare(b)\n })\n return Object.fromEntries(sorted)\n}\n</script>\n\n<template>\n <section v-if=\"depth >= MAX_DEPTH\">\n <p><em>[Circular Reference]</em></p>\n </section>\n <section v-else-if=\"resolvedSchema\">\n <!-- Composition keywords -->\n <template v-if=\"getSchemaArray(resolvedSchema, 'allOf')\">\n <section>\n <header>\n <strong>All of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'allOf')\"\n :key=\"index\">\n <Schema\n :schema=\"subSchema\"\n :depth=\"depth + 1\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaArray(resolvedSchema, 'anyOf')\">\n <section>\n <header>\n <strong>Any of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'anyOf')\"\n :key=\"index\">\n <Schema\n :schema=\"subSchema\"\n :depth=\"depth + 1\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaArray(resolvedSchema, 'oneOf')\">\n <section>\n <header>\n <strong>One of:</strong>\n </header>\n <section\n v-for=\"(subSchema, index) in getSchemaArray(resolvedSchema, 'oneOf')\"\n :key=\"index\">\n <Schema\n :schema=\"subSchema\"\n :depth=\"depth + 1\" />\n </section>\n </section>\n </template>\n\n <template v-else-if=\"getSchemaNot(resolvedSchema)\">\n <section>\n <header>\n <strong>Not:</strong>\n </header>\n <section>\n <Schema\n :schema=\"getSchemaNot(resolvedSchema)!\"\n :depth=\"depth + 1\" />\n </section>\n </section>\n </template>\n\n <!-- Object type -->\n <template\n v-else-if=\"\n getSchemaType(resolvedSchema) === 'object' ||\n Object.keys(getSchemaProperties(resolvedSchema)).length\n \">\n <section>\n <ul>\n <template\n v-for=\"(propSchema, propName) in sortProperties(\n getSchemaProperties(resolvedSchema),\n getSchemaRequired(resolvedSchema),\n )\"\n :key=\"propName\">\n <li>\n <strong>\n <code>{{ propName }}</code>\n <span\n v-if=\"getSchemaRequired(resolvedSchema).includes(propName)\">\n (required)\n </span>\n </strong>\n <p>\n <code>\n {{ formatSchemaType(propSchema) }}\n </code>\n <template v-if=\"getResolvedSchemaFormat(propSchema)\">\n <span\n >, format:\n <code>{{ getResolvedSchemaFormat(propSchema) }}</code></span\n >\n </template>\n <template v-if=\"getResolvedSchemaEnum(propSchema)\">\n <span\n >, possible values:\n <code>{{\n formatEnumValues(getResolvedSchemaEnum(propSchema))\n }}</code>\n </span>\n </template>\n <template\n v-if=\"getResolvedSchemaDefault(propSchema) !== undefined\">\n <span\n >, default:\n <code>{{\n JSON.stringify(getResolvedSchemaDefault(propSchema))\n }}</code></span\n >\n </template>\n <template v-if=\"getResolvedSchemaDescription(propSchema)\">\n <span> — {{ getResolvedSchemaDescription(propSchema) }}</span>\n </template>\n </p>\n <Schema\n v-if=\"\n getResolvedSchemaType(propSchema) === 'object' ||\n Object.keys(getResolvedSchemaProperties(propSchema)).length\n \"\n :schema=\"propSchema\"\n :depth=\"depth + 1\" />\n <template\n v-if=\"\n getResolvedSchemaType(propSchema) === 'array' &&\n getResolvedSchemaItems(propSchema)\n \">\n <section>\n <header>\n <strong>Items:</strong>\n </header>\n <Schema\n :schema=\"getResolvedSchemaItems(propSchema)!\"\n :depth=\"depth + 1\" />\n </section>\n </template>\n </li>\n </template>\n </ul>\n </section>\n </template>\n\n <!-- Array type -->\n <template\n v-else-if=\"\n getSchemaType(resolvedSchema) === 'array' &&\n getSchemaItems(resolvedSchema)\n \">\n <section>\n <header>\n <strong>Array of:</strong>\n </header>\n <section>\n <Schema\n :schema=\"getSchemaItems(resolvedSchema)!\"\n :depth=\"depth + 1\" />\n </section>\n <ul\n v-if=\"\n getSchemaMinItems(resolvedSchema) !== undefined ||\n getSchemaMaxItems(resolvedSchema) !== undefined ||\n getSchemaUniqueItems(resolvedSchema)\n \">\n <li v-if=\"getSchemaMinItems(resolvedSchema) !== undefined\">\n Min items: <code>{{ getSchemaMinItems(resolvedSchema) }}</code>\n </li>\n <li v-if=\"getSchemaMaxItems(resolvedSchema) !== undefined\">\n Max items: <code>{{ getSchemaMaxItems(resolvedSchema) }}</code>\n </li>\n <li v-if=\"getSchemaUniqueItems(resolvedSchema)\">\n Unique items: <code>true</code>\n </li>\n </ul>\n </section>\n </template>\n\n <!-- Primitive types -->\n <template v-else>\n <section>\n <p>\n <code>{{ getSchemaType(resolvedSchema) }}</code>\n <template v-if=\"getSchemaFormat(resolvedSchema)\">\n <span\n >, format:\n <code>{{ getSchemaFormat(resolvedSchema) }}</code></span\n >\n </template>\n <template v-if=\"getSchemaEnum(resolvedSchema)\">\n <span\n >, possible values:\n <code>{{ formatEnumValues(getSchemaEnum(resolvedSchema)) }}</code>\n </span>\n </template>\n <template v-if=\"getSchemaDefault(resolvedSchema) !== undefined\">\n <span\n >, default:\n <code>{{\n JSON.stringify(getSchemaDefault(resolvedSchema))\n }}</code></span\n >\n </template>\n <template v-if=\"getSchemaDescription(resolvedSchema)\">\n <span> — {{ getSchemaDescription(resolvedSchema) }}</span>\n </template>\n </p>\n </section>\n </template>\n </section>\n</template>\n","<script setup lang=\"ts\">\nimport { json2xml } from '@scalar/helpers/file/json2xml'\nimport type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema'\n\nwithDefaults(\n defineProps<{\n xml?: boolean\n modelValue: MaybeRefSchemaObject\n }>(),\n {\n xml: false,\n },\n)\n</script>\n<template>\n <template v-if=\"xml\">\n <pre><code class=\"language-xml\">{{ json2xml(modelValue) }}</code></pre>\n </template>\n <template v-else>\n <pre><code class=\"language-json\">{{ JSON.stringify(modelValue, null, 2) }}</code></pre>\n </template>\n</template>\n","<script setup lang=\"ts\">\nimport { json2xml } from '@scalar/helpers/file/json2xml'\nimport type { MaybeRefSchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/schema'\n\nwithDefaults(\n defineProps<{\n xml?: boolean\n modelValue: MaybeRefSchemaObject\n }>(),\n {\n xml: false,\n },\n)\n</script>\n<template>\n <template v-if=\"xml\">\n <pre><code class=\"language-xml\">{{ json2xml(modelValue) }}</code></pre>\n </template>\n <template v-else>\n <pre><code class=\"language-json\">{{ JSON.stringify(modelValue, null, 2) }}</code></pre>\n </template>\n</template>\n","<script setup lang=\"ts\">\nimport { ScalarMarkdown } from '@scalar/components'\nimport { getExampleFromSchema } from '@scalar/oas-utils/spec-getters'\nimport { getResolvedRef } from '@scalar/workspace-store/helpers/get-resolved-ref'\nimport type {\n OpenApiDocument,\n OperationObject,\n RequestBodyObject,\n ResponseObject,\n SchemaObject,\n} from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { computed } from 'vue'\n\n// import { snippetz, type HarRequest } from '@scalar/snippetz'\n\nimport Schema from './Schema.vue'\nimport XmlOrJson from './XmlOrJson.vue'\n\ntype MarkdownDocument = Partial<OpenApiDocument> &\n Pick<OpenApiDocument, 'openapi' | 'info'>\ntype SchemaView = {\n description?: string\n title?: string\n type?: string | string[]\n}\ntype RequestBodyView = {\n content?: Record<string, { schema?: unknown }>\n}\ntype ResponseView = {\n description?: string\n content?: Record<string, { schema?: unknown }>\n}\n\ntype OperationEntry = {\n path: string\n method: string\n operation: OperationObject\n requestBody: RequestBodyView | null\n responses: Array<{\n statusCode: string\n response: ResponseView\n }>\n}\n\nconst { content } = defineProps<{\n content: MarkdownDocument\n}>()\n\n// const getRequestExample = (harRequest: Partial<HarRequest>) => {\n// const snippet = snippetz().print('shell', 'curl', {\n// httpVersion: 'HTTP/1.1',\n// headers: [],\n// queryString: [],\n// cookies: [],\n// headersSize: -1,\n// bodySize: -1,\n// method: 'get',\n// ...harRequest,\n// })\n\n// return snippet\n// }\n\nconst resolveRefAs = <TResolved extends object>(\n reference: unknown,\n): TResolved | null => {\n const resolved = getResolvedRef(reference as never)\n\n return resolved && typeof resolved === 'object'\n ? (resolved as TResolved)\n : null\n}\n\nconst resolveOperation = (operation: unknown): OperationObject | null =>\n resolveRefAs<OperationObject>(operation)\n\nconst resolveSchema = (schema: unknown): SchemaObject | null =>\n resolveRefAs<SchemaObject>(schema)\n\nconst resolveRequestBody = (body: unknown): RequestBodyObject | null =>\n resolveRefAs<RequestBodyObject>(body)\n\nconst resolveResponse = (response: unknown): ResponseObject | null =>\n resolveRefAs<ResponseObject>(response)\n\nconst toRequestBodyView = (body: unknown): RequestBodyView | null =>\n resolveRequestBody(body) as unknown as RequestBodyView | null\n\nconst toResponseView = (response: unknown): ResponseView | null =>\n resolveResponse(response) as unknown as ResponseView | null\n\nconst HTTP_METHODS = new Set([\n 'get',\n 'put',\n 'post',\n 'delete',\n 'options',\n 'head',\n 'patch',\n 'trace',\n])\n\nconst operations = computed<OperationEntry[]>(() => {\n const paths = content?.paths ?? {}\n\n return Object.entries(paths).flatMap(([path, pathItem]) => {\n if (!pathItem || typeof pathItem !== 'object') {\n return []\n }\n\n return Object.entries(pathItem).flatMap(([method, operation]) => {\n if (!HTTP_METHODS.has(method)) {\n return []\n }\n\n const resolvedOperation = resolveOperation(operation)\n\n if (!resolvedOperation) {\n return []\n }\n\n const requestBody = toRequestBodyView(resolvedOperation.requestBody)\n const responses = Object.entries(\n resolvedOperation.responses ?? {},\n ).flatMap(([statusCode, response]) => {\n const resolvedResponse = toResponseView(response)\n\n if (!resolvedResponse) {\n return []\n }\n\n return [{ statusCode, response: resolvedResponse }]\n })\n\n return [\n {\n path,\n method,\n operation: resolvedOperation,\n requestBody,\n responses,\n },\n ]\n })\n })\n})\n\nconst webhooks = computed(() => {\n const webhookItems = content?.webhooks ?? {}\n\n return Object.entries(webhookItems).flatMap(([name, pathItem]) => {\n if (!pathItem || typeof pathItem !== 'object') {\n return []\n }\n\n return Object.entries(pathItem).flatMap(([method, operation]) => {\n if (!HTTP_METHODS.has(method)) {\n return []\n }\n\n const resolvedOperation = resolveOperation(operation)\n\n if (!resolvedOperation) {\n return []\n }\n\n return [{ name, method, operation: resolvedOperation }]\n })\n })\n})\n\nconst componentSchemas = computed(() => {\n const schemas = content?.components?.schemas ?? {}\n\n return Object.entries(schemas).flatMap(([name, schema]) => {\n const resolvedSchema = resolveSchema(schema)\n\n if (!resolvedSchema) {\n return []\n }\n\n return [{ name, schema: resolvedSchema }]\n })\n})\n\nconst getSchemaView = (schema: SchemaObject): SchemaView =>\n schema as unknown as SchemaView\n</script>\n\n<template>\n <section>\n <header>\n <h1>{{ content?.info?.title }}</h1>\n <ul>\n <li>\n <strong>OpenAPI Version:</strong> <code>{{\n content?.openapi\n }}</code>\n </li>\n <li>\n <strong>API Version:</strong> <code>{{\n content?.info?.version\n }}</code>\n </li>\n </ul>\n </header>\n\n <ScalarMarkdown\n :value=\"content?.info?.description\"\n v-if=\"content?.info?.description\" />\n\n <section v-if=\"content?.servers?.length\">\n <h2>Servers</h2>\n <ul>\n <template\n v-for=\"server in content.servers\"\n :key=\"server.url\">\n <li>\n <strong>URL:</strong> <code>{{ server.url }}</code>\n <ul>\n <template v-if=\"server.description\">\n <li>\n <strong>Description:</strong> {{ server.description }}\n </li>\n </template>\n <template\n v-if=\"server.variables && Object.keys(server.variables).length\">\n <li>\n <strong>Variables:</strong>\n <ul>\n <template\n v-for=\"(variable, name) in server.variables\"\n :key=\"name\">\n <li>\n <code>{{ name }}</code> (default:\n <code>{{ variable.default }}</code\n >)<template v-if=\"variable.description\"\n >: {{ variable.description }}\n </template>\n </li>\n </template>\n </ul>\n </li>\n </template>\n </ul>\n </li>\n </template>\n </ul>\n </section>\n\n <section v-if=\"operations.length\">\n <h2>Operations</h2>\n\n <template\n v-for=\"entry in operations\"\n :key=\"`${entry.method}:${entry.path}`\">\n <section>\n <header>\n <h3>\n <template v-if=\"entry.operation.summary\">\n {{ entry.operation.summary }}\n </template>\n <template v-else>\n {{ entry.method.toString().toUpperCase() }} {{ entry.path }}\n </template>\n <template v-if=\"entry.operation['x-scalar-stability']\">\n ({{ entry.operation['x-scalar-stability'] }})\n </template>\n <template v-else-if=\"entry.operation.deprecated\">\n ⚠️ Deprecated\n </template>\n </h3>\n </header>\n\n <ul>\n <li>\n <strong>Method:</strong> <code>{{\n entry.method.toString().toUpperCase()\n }}</code>\n </li>\n <li>\n <strong>Path:</strong> <code>{{ entry.path }}</code>\n </li>\n <template v-if=\"entry.operation.tags\">\n <li>\n <strong>Tags:</strong> {{\n entry.operation.tags.join(', ')\n }}\n </li>\n </template>\n <template v-if=\"entry.operation['x-scalar-stability']\">\n <li>\n <strong>Stability:</strong> {{\n entry.operation['x-scalar-stability']\n }}\n </li>\n </template>\n </ul>\n\n <ScalarMarkdown :value=\"entry.operation.description\" />\n\n <!-- TODO: We need way more context to generate proper request examples -->\n <!-- <section>\n <h4>Request Example</h4>\n <pre><code>{{ getRequestExample({\n method: method.toString(),\n url: content.servers?.[0]?.url + path,\n }) }}</code></pre>\n </section> -->\n\n <template v-if=\"entry.requestBody?.content\">\n <section>\n <h4>Request Body</h4>\n <template\n v-for=\"(bodyContent, mediaType) in entry.requestBody.content\"\n :key=\"mediaType\">\n <h5>Content-Type: {{ mediaType }}</h5>\n <template v-if=\"resolveSchema(bodyContent.schema)\">\n <Schema :schema=\"resolveSchema(bodyContent.schema)!\" />\n <p><strong>Example:</strong></p>\n <XmlOrJson\n :xml=\"mediaType?.toString().includes('xml')\"\n :model-value=\"\n getExampleFromSchema(resolveSchema(bodyContent.schema)!, {\n xml: mediaType?.toString().includes('xml'),\n })\n \" />\n </template>\n </template>\n </section>\n </template>\n\n <template v-if=\"entry.responses.length\">\n <section>\n <h4>Responses</h4>\n\n <template\n v-for=\"entryResponse in entry.responses\"\n :key=\"entryResponse.statusCode\">\n <section>\n <header>\n <h5>\n Status: {{ entryResponse.statusCode }}\n <template v-if=\"entryResponse.response.description\">\n {{ entryResponse.response.description }}\n </template>\n </h5>\n </header>\n <template v-if=\"entryResponse.response.content\">\n <template\n v-for=\"(responseContent, mediaType) in entryResponse\n .response.content\"\n :key=\"mediaType\">\n <section>\n <h6>Content-Type: {{ mediaType }}</h6>\n <template v-if=\"resolveSchema(responseContent.schema)\">\n <Schema\n :schema=\"resolveSchema(responseContent.schema)!\" />\n <p><strong>Example:</strong></p>\n <XmlOrJson\n :xml=\"mediaType?.toString().includes('xml')\"\n :model-value=\"\n getExampleFromSchema(\n resolveSchema(responseContent.schema)!,\n {\n xml: mediaType?.toString().includes('xml'),\n },\n )\n \" />\n </template>\n </section>\n </template>\n </template>\n </section>\n </template>\n </section>\n </template>\n </section>\n </template>\n </section>\n\n <section v-if=\"webhooks.length\">\n <h2>Webhooks</h2>\n\n <template\n v-for=\"webhook in webhooks\"\n :key=\"`${webhook.name}:${webhook.method}`\">\n <section>\n <header>\n <h3>\n <template v-if=\"webhook.operation.summary\">\n {{ webhook.operation.summary }}\n </template>\n <template v-else>\n {{ webhook.name }}\n </template>\n <template v-if=\"webhook.operation['x-scalar-stability']\">\n <span>({{ webhook.operation['x-scalar-stability'] }})</span>\n </template>\n <template v-else-if=\"webhook.operation.deprecated\">\n <span>⚠️ Deprecated</span>\n </template>\n </h3>\n </header>\n\n <ul>\n <li>\n <strong>Method:</strong>\n <code>{{ webhook.method.toString().toUpperCase() }}</code>\n </li>\n <li>\n <strong>Path:</strong>\n <code>/webhooks/{{ webhook.name }}</code>\n </li>\n <template v-if=\"webhook.operation.tags\">\n <li>\n <strong>Tags:</strong>\n {{ webhook.operation.tags.join(', ') }}\n </li>\n </template>\n <template v-if=\"webhook.operation.deprecated\">\n <li><strong>Deprecated</strong></li>\n </template>\n </ul>\n\n <ScalarMarkdown :value=\"webhook.operation.description\" />\n\n <!-- TODO: We need way more context to generate proper request examples -->\n <!-- <section>\n <h4>Request Example</h4>\n <pre><code>{{ getRequestExample({\n method: method.toString(),\n url: content.servers?.[0]?.url + '/webhooks/' + name,\n }) }}</code></pre>\n </section> -->\n </section>\n </template>\n </section>\n\n <section v-if=\"componentSchemas.length\">\n <h2>Schemas</h2>\n <template\n v-for=\"entry in componentSchemas\"\n :key=\"entry.name\">\n <section>\n <header>\n <h3>{{ getSchemaView(entry.schema).title ?? entry.name }}</h3>\n </header>\n <ul>\n <li>\n <strong>Type:</strong>\n <code>{{ getSchemaView(entry.schema).type }}</code>\n </li>\n </ul>\n <template v-if=\"getSchemaView(entry.schema).description\">\n <ScalarMarkdown :value=\"getSchemaView(entry.schema).description\" />\n </template>\n <Schema\n v-if=\"getSchemaView(entry.schema).type === 'object'\"\n :schema=\"entry.schema\" />\n <p><strong>Example:</strong></p>\n <template v-if=\"getSchemaView(entry.schema).type === 'object'\">\n <XmlOrJson :model-value=\"getExampleFromSchema(entry.schema)\" />\n </template>\n </section>\n </template>\n </section>\n </section>\n</template>\n","<script setup lang=\"ts\">\nimport { ScalarMarkdown } from '@scalar/components'\nimport { getExampleFromSchema } from '@scalar/oas-utils/spec-getters'\nimport { getResolvedRef } from '@scalar/workspace-store/helpers/get-resolved-ref'\nimport type {\n OpenApiDocument,\n OperationObject,\n RequestBodyObject,\n ResponseObject,\n SchemaObject,\n} from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { computed } from 'vue'\n\n// import { snippetz, type HarRequest } from '@scalar/snippetz'\n\nimport Schema from './Schema.vue'\nimport XmlOrJson from './XmlOrJson.vue'\n\ntype MarkdownDocument = Partial<OpenApiDocument> &\n Pick<OpenApiDocument, 'openapi' | 'info'>\ntype SchemaView = {\n description?: string\n title?: string\n type?: string | string[]\n}\ntype RequestBodyView = {\n content?: Record<string, { schema?: unknown }>\n}\ntype ResponseView = {\n description?: string\n content?: Record<string, { schema?: unknown }>\n}\n\ntype OperationEntry = {\n path: string\n method: string\n operation: OperationObject\n requestBody: RequestBodyView | null\n responses: Array<{\n statusCode: string\n response: ResponseView\n }>\n}\n\nconst { content } = defineProps<{\n content: MarkdownDocument\n}>()\n\n// const getRequestExample = (harRequest: Partial<HarRequest>) => {\n// const snippet = snippetz().print('shell', 'curl', {\n// httpVersion: 'HTTP/1.1',\n// headers: [],\n// queryString: [],\n// cookies: [],\n// headersSize: -1,\n// bodySize: -1,\n// method: 'get',\n// ...harRequest,\n// })\n\n// return snippet\n// }\n\nconst resolveRefAs = <TResolved extends object>(\n reference: unknown,\n): TResolved | null => {\n const resolved = getResolvedRef(reference as never)\n\n return resolved && typeof resolved === 'object'\n ? (resolved as TResolved)\n : null\n}\n\nconst resolveOperation = (operation: unknown): OperationObject | null =>\n resolveRefAs<OperationObject>(operation)\n\nconst resolveSchema = (schema: unknown): SchemaObject | null =>\n resolveRefAs<SchemaObject>(schema)\n\nconst resolveRequestBody = (body: unknown): RequestBodyObject | null =>\n resolveRefAs<RequestBodyObject>(body)\n\nconst resolveResponse = (response: unknown): ResponseObject | null =>\n resolveRefAs<ResponseObject>(response)\n\nconst toRequestBodyView = (body: unknown): RequestBodyView | null =>\n resolveRequestBody(body) as unknown as RequestBodyView | null\n\nconst toResponseView = (response: unknown): ResponseView | null =>\n resolveResponse(response) as unknown as ResponseView | null\n\nconst HTTP_METHODS = new Set([\n 'get',\n 'put',\n 'post',\n 'delete',\n 'options',\n 'head',\n 'patch',\n 'trace',\n])\n\nconst operations = computed<OperationEntry[]>(() => {\n const paths = content?.paths ?? {}\n\n return Object.entries(paths).flatMap(([path, pathItem]) => {\n if (!pathItem || typeof pathItem !== 'object') {\n return []\n }\n\n return Object.entries(pathItem).flatMap(([method, operation]) => {\n if (!HTTP_METHODS.has(method)) {\n return []\n }\n\n const resolvedOperation = resolveOperation(operation)\n\n if (!resolvedOperation) {\n return []\n }\n\n const requestBody = toRequestBodyView(resolvedOperation.requestBody)\n const responses = Object.entries(\n resolvedOperation.responses ?? {},\n ).flatMap(([statusCode, response]) => {\n const resolvedResponse = toResponseView(response)\n\n if (!resolvedResponse) {\n return []\n }\n\n return [{ statusCode, response: resolvedResponse }]\n })\n\n return [\n {\n path,\n method,\n operation: resolvedOperation,\n requestBody,\n responses,\n },\n ]\n })\n })\n})\n\nconst webhooks = computed(() => {\n const webhookItems = content?.webhooks ?? {}\n\n return Object.entries(webhookItems).flatMap(([name, pathItem]) => {\n if (!pathItem || typeof pathItem !== 'object') {\n return []\n }\n\n return Object.entries(pathItem).flatMap(([method, operation]) => {\n if (!HTTP_METHODS.has(method)) {\n return []\n }\n\n const resolvedOperation = resolveOperation(operation)\n\n if (!resolvedOperation) {\n return []\n }\n\n return [{ name, method, operation: resolvedOperation }]\n })\n })\n})\n\nconst componentSchemas = computed(() => {\n const schemas = content?.components?.schemas ?? {}\n\n return Object.entries(schemas).flatMap(([name, schema]) => {\n const resolvedSchema = resolveSchema(schema)\n\n if (!resolvedSchema) {\n return []\n }\n\n return [{ name, schema: resolvedSchema }]\n })\n})\n\nconst getSchemaView = (schema: SchemaObject): SchemaView =>\n schema as unknown as SchemaView\n</script>\n\n<template>\n <section>\n <header>\n <h1>{{ content?.info?.title }}</h1>\n <ul>\n <li>\n <strong>OpenAPI Version:</strong> <code>{{\n content?.openapi\n }}</code>\n </li>\n <li>\n <strong>API Version:</strong> <code>{{\n content?.info?.version\n }}</code>\n </li>\n </ul>\n </header>\n\n <ScalarMarkdown\n :value=\"content?.info?.description\"\n v-if=\"content?.info?.description\" />\n\n <section v-if=\"content?.servers?.length\">\n <h2>Servers</h2>\n <ul>\n <template\n v-for=\"server in content.servers\"\n :key=\"server.url\">\n <li>\n <strong>URL:</strong> <code>{{ server.url }}</code>\n <ul>\n <template v-if=\"server.description\">\n <li>\n <strong>Description:</strong> {{ server.description }}\n </li>\n </template>\n <template\n v-if=\"server.variables && Object.keys(server.variables).length\">\n <li>\n <strong>Variables:</strong>\n <ul>\n <template\n v-for=\"(variable, name) in server.variables\"\n :key=\"name\">\n <li>\n <code>{{ name }}</code> (default:\n <code>{{ variable.default }}</code\n >)<template v-if=\"variable.description\"\n >: {{ variable.description }}\n </template>\n </li>\n </template>\n </ul>\n </li>\n </template>\n </ul>\n </li>\n </template>\n </ul>\n </section>\n\n <section v-if=\"operations.length\">\n <h2>Operations</h2>\n\n <template\n v-for=\"entry in operations\"\n :key=\"`${entry.method}:${entry.path}`\">\n <section>\n <header>\n <h3>\n <template v-if=\"entry.operation.summary\">\n {{ entry.operation.summary }}\n </template>\n <template v-else>\n {{ entry.method.toString().toUpperCase() }} {{ entry.path }}\n </template>\n <template v-if=\"entry.operation['x-scalar-stability']\">\n ({{ entry.operation['x-scalar-stability'] }})\n </template>\n <template v-else-if=\"entry.operation.deprecated\">\n ⚠️ Deprecated\n </template>\n </h3>\n </header>\n\n <ul>\n <li>\n <strong>Method:</strong> <code>{{\n entry.method.toString().toUpperCase()\n }}</code>\n </li>\n <li>\n <strong>Path:</strong> <code>{{ entry.path }}</code>\n </li>\n <template v-if=\"entry.operation.tags\">\n <li>\n <strong>Tags:</strong> {{\n entry.operation.tags.join(', ')\n }}\n </li>\n </template>\n <template v-if=\"entry.operation['x-scalar-stability']\">\n <li>\n <strong>Stability:</strong> {{\n entry.operation['x-scalar-stability']\n }}\n </li>\n </template>\n </ul>\n\n <ScalarMarkdown :value=\"entry.operation.description\" />\n\n <!-- TODO: We need way more context to generate proper request examples -->\n <!-- <section>\n <h4>Request Example</h4>\n <pre><code>{{ getRequestExample({\n method: method.toString(),\n url: content.servers?.[0]?.url + path,\n }) }}</code></pre>\n </section> -->\n\n <template v-if=\"entry.requestBody?.content\">\n <section>\n <h4>Request Body</h4>\n <template\n v-for=\"(bodyContent, mediaType) in entry.requestBody.content\"\n :key=\"mediaType\">\n <h5>Content-Type: {{ mediaType }}</h5>\n <template v-if=\"resolveSchema(bodyContent.schema)\">\n <Schema :schema=\"resolveSchema(bodyContent.schema)!\" />\n <p><strong>Example:</strong></p>\n <XmlOrJson\n :xml=\"mediaType?.toString().includes('xml')\"\n :model-value=\"\n getExampleFromSchema(resolveSchema(bodyContent.schema)!, {\n xml: mediaType?.toString().includes('xml'),\n })\n \" />\n </template>\n </template>\n </section>\n </template>\n\n <template v-if=\"entry.responses.length\">\n <section>\n <h4>Responses</h4>\n\n <template\n v-for=\"entryResponse in entry.responses\"\n :key=\"entryResponse.statusCode\">\n <section>\n <header>\n <h5>\n Status: {{ entryResponse.statusCode }}\n <template v-if=\"entryResponse.response.description\">\n {{ entryResponse.response.description }}\n </template>\n </h5>\n </header>\n <template v-if=\"entryResponse.response.content\">\n <template\n v-for=\"(responseContent, mediaType) in entryResponse\n .response.content\"\n :key=\"mediaType\">\n <section>\n <h6>Content-Type: {{ mediaType }}</h6>\n <template v-if=\"resolveSchema(responseContent.schema)\">\n <Schema\n :schema=\"resolveSchema(responseContent.schema)!\" />\n <p><strong>Example:</strong></p>\n <XmlOrJson\n :xml=\"mediaType?.toString().includes('xml')\"\n :model-value=\"\n getExampleFromSchema(\n resolveSchema(responseContent.schema)!,\n {\n xml: mediaType?.toString().includes('xml'),\n },\n )\n \" />\n </template>\n </section>\n </template>\n </template>\n </section>\n </template>\n </section>\n </template>\n </section>\n </template>\n </section>\n\n <section v-if=\"webhooks.length\">\n <h2>Webhooks</h2>\n\n <template\n v-for=\"webhook in webhooks\"\n :key=\"`${webhook.name}:${webhook.method}`\">\n <section>\n <header>\n <h3>\n <template v-if=\"webhook.operation.summary\">\n {{ webhook.operation.summary }}\n </template>\n <template v-else>\n {{ webhook.name }}\n </template>\n <template v-if=\"webhook.operation['x-scalar-stability']\">\n <span>({{ webhook.operation['x-scalar-stability'] }})</span>\n </template>\n <template v-else-if=\"webhook.operation.deprecated\">\n <span>⚠️ Deprecated</span>\n </template>\n </h3>\n </header>\n\n <ul>\n <li>\n <strong>Method:</strong>\n <code>{{ webhook.method.toString().toUpperCase() }}</code>\n </li>\n <li>\n <strong>Path:</strong>\n <code>/webhooks/{{ webhook.name }}</code>\n </li>\n <template v-if=\"webhook.operation.tags\">\n <li>\n <strong>Tags:</strong>\n {{ webhook.operation.tags.join(', ') }}\n </li>\n </template>\n <template v-if=\"webhook.operation.deprecated\">\n <li><strong>Deprecated</strong></li>\n </template>\n </ul>\n\n <ScalarMarkdown :value=\"webhook.operation.description\" />\n\n <!-- TODO: We need way more context to generate proper request examples -->\n <!-- <section>\n <h4>Request Example</h4>\n <pre><code>{{ getRequestExample({\n method: method.toString(),\n url: content.servers?.[0]?.url + '/webhooks/' + name,\n }) }}</code></pre>\n </section> -->\n </section>\n </template>\n </section>\n\n <section v-if=\"componentSchemas.length\">\n <h2>Schemas</h2>\n <template\n v-for=\"entry in componentSchemas\"\n :key=\"entry.name\">\n <section>\n <header>\n <h3>{{ getSchemaView(entry.schema).title ?? entry.name }}</h3>\n </header>\n <ul>\n <li>\n <strong>Type:</strong>\n <code>{{ getSchemaView(entry.schema).type }}</code>\n </li>\n </ul>\n <template v-if=\"getSchemaView(entry.schema).description\">\n <ScalarMarkdown :value=\"getSchemaView(entry.schema).description\" />\n </template>\n <Schema\n v-if=\"getSchemaView(entry.schema).type === 'object'\"\n :schema=\"entry.schema\" />\n <p><strong>Example:</strong></p>\n <template v-if=\"getSchemaView(entry.schema).type === 'object'\">\n <XmlOrJson :model-value=\"getExampleFromSchema(entry.schema)\" />\n </template>\n </section>\n </template>\n </section>\n </section>\n</template>\n","import { isObject } from '@scalar/helpers/object/is-object'\nimport { readFiles } from '@scalar/json-magic/bundle/plugins/node'\nimport { normalize } from '@scalar/json-magic/helpers/normalize'\nimport type { OpenApiDocument, PathItemObject } from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { createWorkspaceStore } from '@scalar/workspace-store/client'\nimport { minify } from 'html-minifier-terser'\nimport rehypeParse from 'rehype-parse'\nimport rehypeRemark from 'rehype-remark'\nimport rehypeSanitize from 'rehype-sanitize'\nimport remarkGfm from 'remark-gfm'\nimport remarkStringify from 'remark-stringify'\nimport { unified } from 'unified'\nimport { createSSRApp } from 'vue'\nimport { renderToString } from 'vue/server-renderer'\n\nimport MarkdownReference from './components/MarkdownReference.vue'\n\ntype AnyDocument = OpenApiDocument | Record<string, unknown> | string\ntype HttpMethodKeys = Exclude<keyof PathItemObject, '$ref' | 'summary' | 'description' | 'servers' | 'parameters'>\nexport type HttpMethod = Extract<HttpMethodKeys, string>\nexport type OperationSelector =\n | {\n path: string\n method: HttpMethod | Uppercase<HttpMethod>\n }\n | {\n operationId: string\n }\n | {\n pointer: string\n }\nexport type OpenApiRenderOptions = {\n operation?: OperationSelector\n}\ntype WorkspaceInput =\n | {\n document: Record<string, unknown>\n }\n | {\n url: string\n }\n | {\n path: string\n }\ntype OperationMatch = {\n path: string\n method: HttpMethod\n}\n\nconst HTTP_METHODS: HttpMethod[] = ['get', 'put', 'post', 'delete', 'options', 'head', 'patch', 'trace']\nconst HTTP_METHOD_SET = new Set<string>(HTTP_METHODS)\n\nconst isHttpUrl = (value: string): boolean => {\n try {\n const url = new URL(value)\n return url.protocol === 'http:' || url.protocol === 'https:'\n } catch {\n return false\n }\n}\n\nconst toWorkspaceInput = (input: AnyDocument): WorkspaceInput => {\n if (typeof input !== 'string') {\n return { document: input as Record<string, unknown> }\n }\n\n const normalized = normalize(input)\n\n if (isObject(normalized)) {\n return { document: normalized as Record<string, unknown> }\n }\n\n if (isHttpUrl(input)) {\n return { url: input }\n }\n\n return { path: input }\n}\n\nconst normalizeHttpMethod = (method: string): HttpMethod | null => {\n const normalized = method.toLowerCase()\n\n if (HTTP_METHOD_SET.has(normalized)) {\n return normalized as HttpMethod\n }\n\n return null\n}\n\nconst normalizeJsonPointer = (pointer: string): string => {\n if (pointer.startsWith('#/')) {\n return pointer.slice(1)\n }\n\n if (pointer.startsWith('/')) {\n return pointer\n }\n\n throw new Error(`Invalid JSON pointer \"${pointer}\". JSON pointers must start with \"#/\"`)\n}\n\nconst parseJsonPointer = (pointer: string): string[] =>\n normalizeJsonPointer(pointer)\n .slice(1)\n .split('/')\n .map((segment) => segment.replaceAll('~1', '/').replaceAll('~0', '~'))\n\nconst getOperationSelectorFromPointer = (pointer: string): Extract<OperationSelector, { path: string }> => {\n const segments = parseJsonPointer(pointer)\n\n if (segments.length !== 3 || segments[0] !== 'paths') {\n throw new Error(`JSON pointer \"${pointer}\" must target an operation object under \"/paths/{path}/{method}\"`)\n }\n\n const path = segments[1]\n const method = segments[2]\n\n if (!path || !method) {\n throw new Error(`JSON pointer \"${pointer}\" must target an operation object under \"/paths/{path}/{method}\"`)\n }\n\n return {\n path,\n method: method as HttpMethod,\n }\n}\n\nconst getPathEntries = (document: OpenApiDocument): Array<[string, PathItemObject]> => {\n const paths = document.paths\n\n if (!isObject(paths)) {\n return []\n }\n\n return Object.entries(paths).flatMap(([path, pathItem]) =>\n isObject(pathItem) ? [[path, pathItem as PathItemObject]] : [],\n )\n}\n\nconst filterPathItemToSingleOperation = (pathItem: PathItemObject, selectedMethod: HttpMethod): PathItemObject =>\n Object.fromEntries(\n Object.entries(pathItem).filter(([key]) => {\n const method = normalizeHttpMethod(key)\n return !method || method === selectedMethod\n }),\n )\n\nconst findOperationByPathAndMethod = (\n document: OpenApiDocument,\n selector: Extract<OperationSelector, { path: string }>,\n): OperationMatch => {\n const method = normalizeHttpMethod(selector.method)\n\n if (!method) {\n throw new Error(`Invalid HTTP method \"${selector.method}\". Supported methods: ${HTTP_METHODS.join(', ')}`)\n }\n\n const pathEntries = getPathEntries(document)\n const pathItem = pathEntries.find(([path]) => path === selector.path)?.[1]\n\n if (!pathItem || !(method in pathItem)) {\n throw new Error(`Operation not found for path \"${selector.path}\" and method \"${method.toUpperCase()}\"`)\n }\n\n return {\n path: selector.path,\n method,\n }\n}\n\nconst findOperationsByOperationId = (document: OpenApiDocument, operationId: string): OperationMatch[] =>\n getPathEntries(document).flatMap(([path, pathItem]) =>\n Object.entries(pathItem).flatMap(([methodKey, operation]) => {\n const method = normalizeHttpMethod(methodKey)\n\n if (!method || !isObject(operation)) {\n return []\n }\n\n const candidateOperationId =\n 'operationId' in operation && typeof operation.operationId === 'string' ? operation.operationId : undefined\n\n if (candidateOperationId !== operationId) {\n return []\n }\n\n return [{ path, method }]\n }),\n )\n\nconst resolveOperationMatch = (document: OpenApiDocument, selector: OperationSelector): OperationMatch => {\n if ('pointer' in selector) {\n return findOperationByPathAndMethod(document, getOperationSelectorFromPointer(selector.pointer))\n }\n\n if ('operationId' in selector) {\n const matches = findOperationsByOperationId(document, selector.operationId)\n\n if (!matches.length) {\n throw new Error(`Operation with operationId \"${selector.operationId}\" was not found`)\n }\n\n if (matches.length > 1) {\n const uniqueCandidates = matches.map(({ path, method }) => `\"${method.toUpperCase()} ${path}\"`)\n\n throw new Error(\n `Multiple operations found for operationId \"${selector.operationId}\". Use { path, method } instead. Matches: ${uniqueCandidates.join(', ')}`,\n )\n }\n\n return matches[0] as OperationMatch\n }\n\n return findOperationByPathAndMethod(document, selector)\n}\n\nconst filterDocumentByOperation = (document: OpenApiDocument, selector: OperationSelector): OpenApiDocument => {\n const match = resolveOperationMatch(document, selector)\n const pathItem = getPathEntries(document).find(([path]) => path === match.path)?.[1]\n\n if (!pathItem) {\n throw new Error(`Operation not found for path \"${match.path}\" and method \"${match.method.toUpperCase()}\"`)\n }\n\n return {\n ...document,\n paths: {\n [match.path]: filterPathItemToSingleOperation(pathItem, match.method),\n },\n }\n}\n\nexport async function createHtmlFromOpenApi(input: AnyDocument, options?: OpenApiRenderOptions) {\n const workspaceStore = createWorkspaceStore({\n fileLoader: readFiles(),\n })\n\n const name = 'openapi-to-markdown'\n const loaded = await workspaceStore.addDocument({\n name,\n ...toWorkspaceInput(input),\n })\n\n if (!loaded) {\n throw new Error('Failed to load OpenAPI document')\n }\n\n const content = workspaceStore.workspace.documents[name]\n\n if (!content) {\n throw new Error('OpenAPI document could not be resolved')\n }\n\n const renderedContent =\n options?.operation && isObject(content)\n ? filterDocumentByOperation(content as OpenApiDocument, options.operation)\n : content\n\n // Create and configure a server-side rendered Vue app\n const app = createSSRApp(MarkdownReference, {\n content: renderedContent,\n })\n\n // Get static HTML\n const html = await renderToString(app)\n\n // Clean the output\n return minify(html, {\n removeComments: true,\n removeEmptyElements: true,\n collapseWhitespace: true,\n continueOnParseError: true,\n noNewlinesBeforeTagClose: true,\n preserveLineBreaks: true,\n removeEmptyAttributes: true,\n decodeEntities: true,\n useShortDoctype: true,\n })\n}\n\nexport async function createMarkdownFromOpenApi(content: AnyDocument, options?: OpenApiRenderOptions) {\n return markdownFromHtml(await createHtmlFromOpenApi(content, options))\n}\n\nasync function markdownFromHtml(html: string): Promise<string> {\n const file = await unified()\n .use(rehypeParse, { fragment: true })\n .use(remarkGfm)\n .use(rehypeSanitize)\n .use(rehypeRemark)\n .use(remarkStringify, {\n bullet: '-',\n })\n .process(html)\n\n return String(file)\n}\n"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -16,7 +16,7 @@
|
|
|
16
16
|
"llm",
|
|
17
17
|
"swagger"
|
|
18
18
|
],
|
|
19
|
-
"version": "0.5.
|
|
19
|
+
"version": "0.5.3",
|
|
20
20
|
"engines": {
|
|
21
21
|
"node": ">=22"
|
|
22
22
|
},
|
|
@@ -53,11 +53,11 @@
|
|
|
53
53
|
"remark-stringify": "^11.0.0",
|
|
54
54
|
"unified": "^11.0.5",
|
|
55
55
|
"vue": "^3.5.30",
|
|
56
|
-
"@scalar/components": "0.21.
|
|
56
|
+
"@scalar/components": "0.21.4",
|
|
57
57
|
"@scalar/json-magic": "0.12.5",
|
|
58
|
-
"@scalar/oas-utils": "0.10.16",
|
|
59
58
|
"@scalar/helpers": "0.4.3",
|
|
60
|
-
"@scalar/
|
|
59
|
+
"@scalar/oas-utils": "0.11.1",
|
|
60
|
+
"@scalar/workspace-store": "0.45.0"
|
|
61
61
|
},
|
|
62
62
|
"devDependencies": {
|
|
63
63
|
"@hono/node-server": "^1.19.10",
|