codemirror-json-schema
Advanced tools
Comparing version 0.5.0 to 0.5.1-canary
@@ -7,4 +7,6 @@ # codemirror-json-schema | ||
- [#63](https://github.com/acao/codemirror-json-schema/pull/63) [`a73c517`](https://github.com/acao/codemirror-json-schema/commit/a73c517722bbe9d37124993117c091e259eb6998) Thanks [@acao](https://github.com/acao)! - **breaking change**: only impacts those following the "custom usage" approach, it _does not_ effect users using the high level, "bundled" `jsonSchema()` or `json5Schema()` modes. | ||
- [#63](https://github.com/acao/codemirror-json-schema/pull/63) [`a73c517`](https://github.com/acao/codemirror-json-schema/commit/a73c517722bbe9d37124993117c091e259eb6998) Thanks [@acao](https://github.com/acao)! | ||
- **breaking change**: only impacts those following the "custom usage" approach, it _does not_ effect users using the high level, "bundled" `jsonSchema()` or `json5Schema()` modes. | ||
Previously, we ask you to pass schema to each of the linter, completion and hover extensions. | ||
@@ -47,2 +49,4 @@ | ||
- upgrade to use full `.js` import paths for `NodeNext` compatibility, however not all of our dependencies are compatible with this mode, thus we continue using the legacy `nodeResolution` strategy. | ||
## 0.4.5 | ||
@@ -49,0 +53,0 @@ |
@@ -6,2 +6,2 @@ import { JSONSchema7 } from "json-schema"; | ||
*/ | ||
export declare function jsonSchema(schema?: JSONSchema7): import("@codemirror/state").Extension[]; | ||
export declare function jsonSchema(schema: JSONSchema7): import("@codemirror/state").Extension[]; |
@@ -6,6 +6,5 @@ "use strict"; | ||
const view_1 = require("@codemirror/view"); | ||
const json_completion_js_1 = require("./json-completion.js"); | ||
const json_validation_js_1 = require("./json-validation.js"); | ||
const json_hover_js_1 = require("./json-hover.js"); | ||
const state_js_1 = require("./state.js"); | ||
const json_completion_1 = require("./json-completion"); | ||
const json_validation_1 = require("./json-validation"); | ||
const json_hover_1 = require("./json-hover"); | ||
const lint_1 = require("@codemirror/lint"); | ||
@@ -20,12 +19,9 @@ /** | ||
(0, lint_1.linter)((0, lang_json_1.jsonParseLinter)()), | ||
(0, lint_1.linter)((0, json_validation_js_1.jsonSchemaLinter)(), { | ||
needsRefresh: json_validation_js_1.handleRefresh, | ||
}), | ||
(0, lint_1.linter)((0, json_validation_1.jsonSchemaLinter)(schema)), | ||
lang_json_1.jsonLanguage.data.of({ | ||
autocomplete: (0, json_completion_js_1.jsonCompletion)(), | ||
autocomplete: (0, json_completion_1.jsonCompletion)(schema), | ||
}), | ||
(0, view_1.hoverTooltip)((0, json_hover_js_1.jsonSchemaHover)()), | ||
(0, state_js_1.stateExtensions)(schema), | ||
(0, view_1.hoverTooltip)((0, json_hover_1.jsonSchemaHover)(schema)), | ||
]; | ||
} | ||
exports.jsonSchema = jsonSchema; |
@@ -1,8 +0,7 @@ | ||
export { jsonCompletion } from "./json-completion.js"; | ||
export { jsonSchemaLinter, type JSONValidationOptions, } from "./json-validation.js"; | ||
export { jsonSchemaHover, type HoverOptions, type FoundCursorData, type CursorData, } from "./json-hover.js"; | ||
export { jsonSchema } from "./bundled.js"; | ||
export type { JSONPointersMap, JSONPointerData, JSONPartialPointerData, } from "./types.js"; | ||
export * from "./utils/parseJSONDocument.js"; | ||
export * from "./utils/jsonPointers.js"; | ||
export * from "./state.js"; | ||
export { jsonCompletion } from "./json-completion"; | ||
export { jsonSchemaLinter, type JSONValidationOptions, } from "./json-validation"; | ||
export { jsonSchemaHover, type HoverOptions, type FoundCursorData, type CursorData, } from "./json-hover"; | ||
export { jsonSchema } from "./bundled"; | ||
export type { JSONPointersMap, JSONPointerData, JSONPartialPointerData, } from "./types"; | ||
export * from "./utils/parseJSONDocument"; | ||
export * from "./utils/jsonPointers"; |
@@ -18,12 +18,11 @@ "use strict"; | ||
exports.jsonSchema = exports.jsonSchemaHover = exports.jsonSchemaLinter = exports.jsonCompletion = void 0; | ||
var json_completion_js_1 = require("./json-completion.js"); | ||
Object.defineProperty(exports, "jsonCompletion", { enumerable: true, get: function () { return json_completion_js_1.jsonCompletion; } }); | ||
var json_validation_js_1 = require("./json-validation.js"); | ||
Object.defineProperty(exports, "jsonSchemaLinter", { enumerable: true, get: function () { return json_validation_js_1.jsonSchemaLinter; } }); | ||
var json_hover_js_1 = require("./json-hover.js"); | ||
Object.defineProperty(exports, "jsonSchemaHover", { enumerable: true, get: function () { return json_hover_js_1.jsonSchemaHover; } }); | ||
var bundled_js_1 = require("./bundled.js"); | ||
Object.defineProperty(exports, "jsonSchema", { enumerable: true, get: function () { return bundled_js_1.jsonSchema; } }); | ||
__exportStar(require("./utils/parseJSONDocument.js"), exports); | ||
__exportStar(require("./utils/jsonPointers.js"), exports); | ||
__exportStar(require("./state.js"), exports); | ||
var json_completion_1 = require("./json-completion"); | ||
Object.defineProperty(exports, "jsonCompletion", { enumerable: true, get: function () { return json_completion_1.jsonCompletion; } }); | ||
var json_validation_1 = require("./json-validation"); | ||
Object.defineProperty(exports, "jsonSchemaLinter", { enumerable: true, get: function () { return json_validation_1.jsonSchemaLinter; } }); | ||
var json_hover_1 = require("./json-hover"); | ||
Object.defineProperty(exports, "jsonSchemaHover", { enumerable: true, get: function () { return json_hover_1.jsonSchemaHover; } }); | ||
var bundled_1 = require("./bundled"); | ||
Object.defineProperty(exports, "jsonSchema", { enumerable: true, get: function () { return bundled_1.jsonSchema; } }); | ||
__exportStar(require("./utils/parseJSONDocument"), exports); | ||
__exportStar(require("./utils/jsonPointers"), exports); |
@@ -8,6 +8,6 @@ import { CompletionContext, CompletionResult } from "@codemirror/autocomplete"; | ||
export declare class JSONCompletion { | ||
private schema; | ||
private opts; | ||
private schema; | ||
constructor(opts: JSONCompletionOptions); | ||
doComplete(ctx: CompletionContext): CompletionResult | never[]; | ||
constructor(schema: JSONSchema7, opts: JSONCompletionOptions); | ||
doComplete(ctx: CompletionContext): CompletionResult; | ||
private applySnippetCompletion; | ||
@@ -38,3 +38,3 @@ private getPropertyCompletions; | ||
*/ | ||
export declare function jsonCompletion(opts?: JSONCompletionOptions): (ctx: CompletionContext) => CompletionResult | never[]; | ||
export declare function jsonCompletion(schema: JSONSchema7, opts?: JSONCompletionOptions): (ctx: CompletionContext) => CompletionResult; | ||
/** | ||
@@ -44,3 +44,3 @@ * provides a JSON schema enabled autocomplete extension for codemirror and json5 | ||
*/ | ||
export declare function json5Completion(opts?: Omit<JSONCompletionOptions, "mode">): (ctx: CompletionContext) => CompletionResult | never[]; | ||
export declare function json5Completion(schema: JSONSchema7, opts?: Omit<JSONCompletionOptions, "mode">): (ctx: CompletionContext) => CompletionResult; | ||
export {}; |
@@ -9,9 +9,8 @@ "use strict"; | ||
const language_1 = require("@codemirror/language"); | ||
const debug_js_1 = require("./utils/debug.js"); | ||
const node_js_1 = require("./utils/node.js"); | ||
const debug_1 = require("./utils/debug"); | ||
const node_1 = require("./utils/node"); | ||
const json_schema_library_1 = require("json-schema-library"); | ||
const jsonPointers_js_1 = require("./utils/jsonPointers.js"); | ||
const constants_js_1 = require("./constants.js"); | ||
const state_js_1 = require("./state.js"); | ||
const getSchema_js_1 = __importDefault(require("./utils/schema-lib/getSchema.js")); | ||
const jsonPointers_1 = require("./utils/jsonPointers"); | ||
const constants_1 = require("./constants"); | ||
const getSchema_1 = __importDefault(require("./utils/schema-lib/getSchema")); | ||
function json5PropertyInsertSnippet(rawWord, value) { | ||
@@ -42,14 +41,8 @@ if (rawWord.startsWith('"')) { | ||
class JSONCompletion { | ||
constructor(opts) { | ||
constructor(schema, opts) { | ||
this.schema = schema; | ||
this.opts = opts; | ||
this.schema = null; | ||
} | ||
doComplete(ctx) { | ||
var _a, _b; | ||
this.schema = (0, state_js_1.getJSONSchema)(ctx.state); | ||
if (!this.schema) { | ||
// todo: should we even do anything without schema | ||
// without taking over the existing mode responsibilties? | ||
return []; | ||
} | ||
const result = { | ||
@@ -62,15 +55,15 @@ from: ctx.pos, | ||
const text = ctx.state.doc.sliceString(0); | ||
let node = (0, node_js_1.getNodeAtPosition)(ctx.state, ctx.pos); | ||
let node = (0, node_1.getNodeAtPosition)(ctx.state, ctx.pos); | ||
// position node word prefix (without quotes) for matching | ||
const prefix = ctx.state.sliceDoc(node.from, ctx.pos).replace(/^("|')/, ""); | ||
debug_js_1.debug.log("xxx", "node", node, "prefix", prefix, "ctx", ctx); | ||
debug_1.debug.log("xxx", "node", node, "prefix", prefix, "ctx", ctx); | ||
// Only show completions if we are filling out a word or right after the starting quote, or if explicitly requested | ||
if (!((0, node_js_1.isPrimitiveValueNode)(node) || (0, node_js_1.isPropertyNameNode)(node)) && | ||
if (!((0, node_1.isPrimitiveValueNode)(node) || (0, node_1.isPropertyNameNode)(node)) && | ||
!ctx.explicit) { | ||
return result; | ||
} | ||
const currentWord = (0, node_js_1.getWord)(ctx.state.doc, node); | ||
const rawWord = (0, node_js_1.getWord)(ctx.state.doc, node, false); | ||
const currentWord = (0, node_1.getWord)(ctx.state.doc, node); | ||
const rawWord = (0, node_1.getWord)(ctx.state.doc, node, false); | ||
// Calculate overwrite range | ||
if (node && ((0, node_js_1.isPrimitiveValueNode)(node) || (0, node_js_1.isPropertyNameNode)(node))) { | ||
if (node && ((0, node_1.isPrimitiveValueNode)(node) || (0, node_1.isPropertyNameNode)(node))) { | ||
result.from = node.from; | ||
@@ -82,5 +75,5 @@ result.to = node.to; | ||
const overwriteStart = ctx.pos - currentWord.length; | ||
debug_js_1.debug.log("xxx", "overwriteStart after", overwriteStart, "ctx.pos", ctx.pos, "word", word, "currentWord", currentWord, "=>", text[overwriteStart - 1], "..", text[overwriteStart], "..", text); | ||
debug_1.debug.log("xxx", "overwriteStart after", overwriteStart, "ctx.pos", ctx.pos, "word", word, "currentWord", currentWord, "=>", text[overwriteStart - 1], "..", text[overwriteStart], "..", text); | ||
result.from = | ||
node.name === constants_js_1.TOKENS.INVALID ? (_a = word === null || word === void 0 ? void 0 : word.from) !== null && _a !== void 0 ? _a : ctx.pos : overwriteStart; | ||
node.name === constants_1.TOKENS.INVALID ? (_a = word === null || word === void 0 ? void 0 : word.from) !== null && _a !== void 0 ? _a : ctx.pos : overwriteStart; | ||
result.to = ctx.pos; | ||
@@ -90,16 +83,16 @@ } | ||
let addValue = true; | ||
if ((0, node_js_1.isPropertyNameNode)(node)) { | ||
if ((0, node_1.isPropertyNameNode)(node)) { | ||
const parent = node.parent; | ||
if (parent) { | ||
// get value node from parent | ||
const valueNode = (0, node_js_1.getChildValueNode)(parent); | ||
const valueNode = (0, node_1.getChildValueNode)(parent); | ||
addValue = | ||
!valueNode || | ||
(valueNode.name === constants_js_1.TOKENS.INVALID && | ||
(valueNode.name === constants_1.TOKENS.INVALID && | ||
valueNode.from - valueNode.to === 0); | ||
debug_js_1.debug.log("xxx", "addValue", addValue, (0, node_js_1.getChildValueNode)(parent), node); | ||
debug_1.debug.log("xxx", "addValue", addValue, (0, node_1.getChildValueNode)(parent), node); | ||
// find object node | ||
node = | ||
(_b = [parent, parent.parent].find((p) => { | ||
if ((p === null || p === void 0 ? void 0 : p.name) === constants_js_1.TOKENS.OBJECT) { | ||
if ((p === null || p === void 0 ? void 0 : p.name) === constants_1.TOKENS.OBJECT) { | ||
return true; | ||
@@ -111,7 +104,7 @@ } | ||
} | ||
debug_js_1.debug.log("xxx", node, currentWord, ctx); | ||
debug_1.debug.log("xxx", node, currentWord, ctx); | ||
// proposals for properties | ||
if (node && | ||
(node.name === constants_js_1.TOKENS.OBJECT || node.name === constants_js_1.TOKENS.JSON_TEXT) && | ||
(0, node_js_1.isPropertyNameNode)((0, node_js_1.getNodeAtPosition)(ctx.state, ctx.pos))) { | ||
(node.name === constants_1.TOKENS.OBJECT || node.name === constants_1.TOKENS.JSON_TEXT) && | ||
(0, node_1.isPropertyNameNode)((0, node_1.getNodeAtPosition)(ctx.state, ctx.pos))) { | ||
// don't suggest keys when the cursor is just before the opening curly brace | ||
@@ -131,4 +124,4 @@ if (node.from === ctx.pos) { | ||
// handle filtering | ||
result.options = Array.from(collector.completions.values()).filter((v) => (0, node_js_1.stripSurroundingQuotes)(v.label).startsWith(prefix)); | ||
debug_js_1.debug.log("xxx", "result", result, "prefix", prefix, "collector.completions", collector.completions, "reservedKeys", collector.reservedKeys); | ||
result.options = Array.from(collector.completions.values()).filter((v) => (0, node_1.stripSurroundingQuotes)(v.label).startsWith(prefix)); | ||
debug_1.debug.log("xxx", "result", result, "prefix", prefix, "collector.completions", collector.completions, "reservedKeys", collector.reservedKeys); | ||
return result; | ||
@@ -143,7 +136,7 @@ } | ||
// don't suggest properties that are already present | ||
const properties = node.getChildren(constants_js_1.TOKENS.PROPERTY); | ||
debug_js_1.debug.log("xxx", "getPropertyCompletions", node, ctx, properties); | ||
const properties = node.getChildren(constants_1.TOKENS.PROPERTY); | ||
debug_1.debug.log("xxx", "getPropertyCompletions", node, ctx, properties); | ||
properties.forEach((p) => { | ||
const key = (0, node_js_1.getWord)(ctx.state.doc, p.getChild(constants_js_1.TOKENS.PROPERTY_NAME)); | ||
collector.reserve((0, node_js_1.stripSurroundingQuotes)(key)); | ||
const key = (0, node_1.getWord)(ctx.state.doc, p.getChild(constants_1.TOKENS.PROPERTY_NAME)); | ||
collector.reserve((0, node_1.stripSurroundingQuotes)(key)); | ||
}); | ||
@@ -299,3 +292,3 @@ // TODO: Handle separatorAfter | ||
if (!value || nValueProposals > 1) { | ||
debug_js_1.debug.log("xxx", "value", value, "nValueProposals", nValueProposals, propertySchema); | ||
debug_1.debug.log("xxx", "value", value, "nValueProposals", nValueProposals, propertySchema); | ||
value = "#{}"; | ||
@@ -341,4 +334,4 @@ } | ||
let parentKey = undefined; | ||
debug_js_1.debug.log("xxx", "getValueCompletions", node, ctx); | ||
if (node && (0, node_js_1.isPrimitiveValueNode)(node)) { | ||
debug_1.debug.log("xxx", "getValueCompletions", node, ctx); | ||
if (node && (0, node_1.isPrimitiveValueNode)(node)) { | ||
valueNode = node; | ||
@@ -351,11 +344,11 @@ node = node.parent; | ||
} | ||
if (node.name === constants_js_1.TOKENS.PROPERTY) { | ||
const keyNode = node.getChild(constants_js_1.TOKENS.PROPERTY_NAME); | ||
if (node.name === constants_1.TOKENS.PROPERTY) { | ||
const keyNode = node.getChild(constants_1.TOKENS.PROPERTY_NAME); | ||
if (keyNode) { | ||
parentKey = (0, node_js_1.getWord)(ctx.state.doc, keyNode); | ||
parentKey = (0, node_1.getWord)(ctx.state.doc, keyNode); | ||
node = node.parent; | ||
} | ||
} | ||
debug_js_1.debug.log("xxx", "node", node, "parentKey", parentKey); | ||
if (node && (parentKey !== undefined || node.name === constants_js_1.TOKENS.ARRAY)) { | ||
debug_1.debug.log("xxx", "node", node, "parentKey", parentKey); | ||
if (node && (parentKey !== undefined || node.name === constants_1.TOKENS.ARRAY)) { | ||
// Get matching schemas | ||
@@ -367,3 +360,3 @@ const schemas = this.getSchemas(schema, ctx); | ||
} | ||
if (node.name === constants_js_1.TOKENS.ARRAY && s.items) { | ||
if (node.name === constants_1.TOKENS.ARRAY && s.items) { | ||
let c = collector; | ||
@@ -384,3 +377,3 @@ if (s.uniqueItems) { | ||
// get index of next node in array | ||
const foundIdx = (0, node_js_1.findNodeIndexInArrayNode)(node, valueNode); | ||
const foundIdx = (0, node_1.findNodeIndexInArrayNode)(node, valueNode); | ||
if (foundIdx >= 0) { | ||
@@ -536,4 +529,4 @@ arrayIndex = foundIdx; | ||
const draft = new json_schema_library_1.Draft07(this.schema); | ||
let pointer = (0, jsonPointers_js_1.jsonPointerForPosition)(ctx.state, ctx.pos); | ||
let subSchema = (0, getSchema_js_1.default)(draft, pointer); | ||
let pointer = (0, jsonPointers_1.jsonPointerForPosition)(ctx.state, ctx.pos); | ||
let subSchema = (0, getSchema_1.default)(draft, pointer); | ||
// if we don't have a schema for the current pointer, try the parent pointer | ||
@@ -545,5 +538,5 @@ if (!subSchema || | ||
pointer = pointer.replace(/\/[^/]*$/, "/"); | ||
subSchema = (0, getSchema_js_1.default)(draft, pointer); | ||
subSchema = (0, getSchema_1.default)(draft, pointer); | ||
} | ||
debug_js_1.debug.log("xxx", "pointer..", JSON.stringify(pointer)); | ||
debug_1.debug.log("xxx", "pointer..", JSON.stringify(pointer)); | ||
// For some reason, it returns undefined schema for the root pointer | ||
@@ -554,3 +547,3 @@ if (!pointer || pointer === "/") { | ||
// const subSchema = new Draft07(this.schema).getSchema(pointer); | ||
debug_js_1.debug.log("xxx", "subSchema..", subSchema); | ||
debug_1.debug.log("xxx", "subSchema..", subSchema); | ||
if (this.isJsonError(subSchema)) { | ||
@@ -642,4 +635,4 @@ return []; | ||
*/ | ||
function jsonCompletion(opts = {}) { | ||
const completion = new JSONCompletion(opts); | ||
function jsonCompletion(schema, opts = {}) { | ||
const completion = new JSONCompletion(schema, opts); | ||
return function jsonDoCompletion(ctx) { | ||
@@ -654,4 +647,4 @@ return completion.doComplete(ctx); | ||
*/ | ||
function json5Completion(opts = {}) { | ||
const completion = new JSONCompletion(Object.assign(Object.assign({}, opts), { mode: "json5" })); | ||
function json5Completion(schema, opts = {}) { | ||
const completion = new JSONCompletion(schema, Object.assign(Object.assign({}, opts), { mode: "json5" })); | ||
return function jsonDoCompletion(ctx) { | ||
@@ -658,0 +651,0 @@ return completion.doComplete(ctx); |
import { type EditorView, Tooltip } from "@codemirror/view"; | ||
import { type Draft, JsonSchema } from "json-schema-library"; | ||
import { Side } from "./types.js"; | ||
import type { JSONSchema7 } from "json-schema"; | ||
import { Side } from "./types"; | ||
export type CursorData = { | ||
@@ -32,7 +33,7 @@ schema?: JsonSchema; | ||
*/ | ||
export declare function jsonSchemaHover(options?: HoverOptions): (view: EditorView, pos: number, side: Side) => Promise<Tooltip | null>; | ||
export declare function jsonSchemaHover(schema: JSONSchema7, options?: HoverOptions): (view: EditorView, pos: number, side: Side) => Promise<Tooltip | null>; | ||
export declare class JSONHover { | ||
private opts?; | ||
private schema; | ||
constructor(opts?: HoverOptions | undefined); | ||
constructor(schema: JSONSchema7, opts?: HoverOptions | undefined); | ||
getDataForCursor(view: EditorView, pos: number, side: Side): CursorData | null; | ||
@@ -39,0 +40,0 @@ private formatMessage; |
@@ -8,8 +8,7 @@ "use strict"; | ||
const json_schema_library_1 = require("json-schema-library"); | ||
const jsonPointers_js_1 = require("./utils/jsonPointers.js"); | ||
const formatting_js_1 = require("./utils/formatting.js"); | ||
const getSchema_js_1 = __importDefault(require("./utils/schema-lib/getSchema.js")); | ||
const debug_js_1 = require("./utils/debug.js"); | ||
const dom_js_1 = require("./utils/dom.js"); | ||
const state_js_1 = require("./state.js"); | ||
const jsonPointers_1 = require("./utils/jsonPointers"); | ||
const formatting_1 = require("./utils/formatting"); | ||
const getSchema_1 = __importDefault(require("./utils/schema-lib/getSchema")); | ||
const debug_1 = require("./utils/debug"); | ||
const dom_1 = require("./utils/dom"); | ||
/** | ||
@@ -19,4 +18,4 @@ * provides a JSON schema enabled tooltip extension for codemirror | ||
*/ | ||
function jsonSchemaHover(options) { | ||
const hover = new JSONHover(options); | ||
function jsonSchemaHover(schema, options) { | ||
const hover = new JSONHover(schema, options); | ||
return async function jsonDoHover(view, pos, side) { | ||
@@ -28,3 +27,3 @@ return hover.doHover(view, pos, side); | ||
function formatComplexType(schema, type, draft) { | ||
return `${type}: ${(0, formatting_js_1.joinWithOr)(schema[type].map((s) => { | ||
return `${type}: ${(0, formatting_1.joinWithOr)(schema[type].map((s) => { | ||
var _a; | ||
@@ -35,16 +34,9 @@ return (_a = s.type) !== null && _a !== void 0 ? _a : draft.resolveRef(s).type; | ||
class JSONHover { | ||
constructor(opts) { | ||
constructor(schema, opts) { | ||
this.opts = opts; | ||
this.schema = null; | ||
this.schema = new json_schema_library_1.Draft04(schema); | ||
this.opts = Object.assign({ parser: JSON.parse }, this.opts); | ||
} | ||
getDataForCursor(view, pos, side) { | ||
const schema = (0, state_js_1.getJSONSchema)(view.state); | ||
if (!schema) { | ||
// todo: should we even do anything without schema | ||
// without taking over the existing mode responsibilties? | ||
return null; | ||
} | ||
this.schema = new json_schema_library_1.Draft04(schema); | ||
const pointer = (0, jsonPointers_js_1.jsonPointerForPosition)(view.state, pos, side); | ||
const pointer = (0, jsonPointers_1.jsonPointerForPosition)(view.state, pos, side); | ||
let data = undefined; | ||
@@ -60,6 +52,6 @@ // TODO: use the AST tree to return the right hand, data so that we don't have to parse the doc | ||
// if the data is valid, we can infer a type for complex types | ||
let subSchema = (0, getSchema_js_1.default)(this.schema, pointer, data); | ||
let subSchema = (0, getSchema_1.default)(this.schema, pointer, data); | ||
if (subSchema.type === "error" && data !== undefined) { | ||
// if the data is invalid, we won't get the type - try again without the data | ||
subSchema = (0, getSchema_js_1.default)(this.schema, pointer, undefined); | ||
subSchema = (0, getSchema_1.default)(this.schema, pointer, undefined); | ||
if (subSchema.type === "error") { | ||
@@ -74,15 +66,15 @@ return { pointer }; | ||
if (message) { | ||
return (0, dom_js_1.el)("div", { class: "cm6-json-schema-hover" }, [ | ||
(0, dom_js_1.el)("div", { | ||
return (0, dom_1.el)("div", { class: "cm6-json-schema-hover" }, [ | ||
(0, dom_1.el)("div", { | ||
class: "cm6-json-schema-hover--description", | ||
text: message, | ||
}), | ||
(0, dom_js_1.el)("div", { class: "cm6-json-schema-hover--code-wrapper" }, [ | ||
(0, dom_js_1.el)("code", { class: "cm6-json-schema-hover--code", text: typeInfo }), | ||
(0, dom_1.el)("div", { class: "cm6-json-schema-hover--code-wrapper" }, [ | ||
(0, dom_1.el)("code", { class: "cm6-json-schema-hover--code", text: typeInfo }), | ||
]), | ||
]); | ||
} | ||
return (0, dom_js_1.el)("div", { class: "cm6-json-schema-hover" }, [ | ||
(0, dom_js_1.el)("div", { class: "cm6-json-schema-hover--code-wrapper" }, [ | ||
(0, dom_js_1.el)("code", { class: "cm6-json-schema-hover--code", text: typeInfo }), | ||
return (0, dom_1.el)("div", { class: "cm6-json-schema-hover" }, [ | ||
(0, dom_1.el)("div", { class: "cm6-json-schema-hover--code-wrapper" }, [ | ||
(0, dom_1.el)("code", { class: "cm6-json-schema-hover--code", text: typeInfo }), | ||
]), | ||
@@ -106,3 +98,3 @@ ]); | ||
typeInfo = Array.isArray(schema.type) | ||
? (0, formatting_js_1.joinWithOr)(schema.type) | ||
? (0, formatting_1.joinWithOr)(schema.type) | ||
: schema.type; | ||
@@ -144,3 +136,3 @@ } | ||
catch (err) { | ||
debug_js_1.debug.log(err); | ||
debug_1.debug.log(err); | ||
return null; | ||
@@ -147,0 +139,0 @@ } |
@@ -1,5 +0,6 @@ | ||
import type { EditorView, ViewUpdate } from "@codemirror/view"; | ||
import { type Diagnostic } from "@codemirror/lint"; | ||
import type { EditorView } from "@codemirror/view"; | ||
import type { Diagnostic } from "@codemirror/lint"; | ||
import type { JSONSchema7 } from "json-schema"; | ||
import { type JsonError } from "json-schema-library"; | ||
import { parseJSONDocumentState } from "./utils/parseJSONDocument.js"; | ||
import { parseJSONDocumentState } from "./utils/parseJSONDocument"; | ||
export type JSONValidationOptions = { | ||
@@ -9,3 +10,2 @@ formatError?: (error: JsonError) => string; | ||
}; | ||
export declare const handleRefresh: (vu: ViewUpdate) => boolean; | ||
/** | ||
@@ -15,7 +15,7 @@ * Helper for simpler class instantiaton | ||
*/ | ||
export declare function jsonSchemaLinter(options?: JSONValidationOptions): (view: EditorView) => Diagnostic[]; | ||
export declare function jsonSchemaLinter(schema: JSONSchema7, options?: JSONValidationOptions): (view: EditorView) => Diagnostic[]; | ||
export declare class JSONValidation { | ||
private schema; | ||
private options; | ||
constructor(options?: JSONValidationOptions); | ||
constructor(schema: JSONSchema7, options?: JSONValidationOptions); | ||
private get schemaTitle(); | ||
@@ -22,0 +22,0 @@ private rewriteError; |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.JSONValidation = exports.jsonSchemaLinter = exports.handleRefresh = void 0; | ||
exports.JSONValidation = exports.jsonSchemaLinter = void 0; | ||
const json_schema_library_1 = require("json-schema-library"); | ||
const formatting_js_1 = require("./utils/formatting.js"); | ||
const parseJSONDocument_js_1 = require("./utils/parseJSONDocument.js"); | ||
const state_js_1 = require("./state.js"); | ||
const formatting_1 = require("./utils/formatting"); | ||
const parseJSONDocument_1 = require("./utils/parseJSONDocument"); | ||
// return an object path that matches with the json-source-map pointer | ||
@@ -22,6 +21,2 @@ const getErrorPath = (error) => { | ||
}; | ||
const handleRefresh = (vu) => { | ||
return (vu.startState.field(state_js_1.schemaStateField) !== vu.state.field(state_js_1.schemaStateField)); | ||
}; | ||
exports.handleRefresh = handleRefresh; | ||
/** | ||
@@ -31,5 +26,5 @@ * Helper for simpler class instantiaton | ||
*/ | ||
function jsonSchemaLinter(options) { | ||
const validation = new JSONValidation(options); | ||
return (view) => { | ||
function jsonSchemaLinter(schema, options) { | ||
const validation = new JSONValidation(schema, options); | ||
return function jsonDoValidation(view) { | ||
return validation.doValidation(view); | ||
@@ -40,4 +35,3 @@ }; | ||
class JSONValidation { | ||
constructor(options) { | ||
this.schema = null; | ||
constructor(schema, options) { | ||
// rewrite the error message to be more human readable | ||
@@ -47,7 +41,7 @@ this.rewriteError = (error) => { | ||
if (error.code === "one-of-error") { | ||
return `Expected one of ${(0, formatting_js_1.joinWithOr)((_a = error === null || error === void 0 ? void 0 : error.data) === null || _a === void 0 ? void 0 : _a.errors, (data) => data.data.expected)}`; | ||
return `Expected one of ${(0, formatting_1.joinWithOr)((_a = error === null || error === void 0 ? void 0 : error.data) === null || _a === void 0 ? void 0 : _a.errors, (data) => data.data.expected)}`; | ||
} | ||
if (error.code === "type-error") { | ||
return `Expected \`${((_b = error === null || error === void 0 ? void 0 : error.data) === null || _b === void 0 ? void 0 : _b.expected) && Array.isArray((_c = error === null || error === void 0 ? void 0 : error.data) === null || _c === void 0 ? void 0 : _c.expected) | ||
? (0, formatting_js_1.joinWithOr)((_d = error === null || error === void 0 ? void 0 : error.data) === null || _d === void 0 ? void 0 : _d.expected) | ||
? (0, formatting_1.joinWithOr)((_d = error === null || error === void 0 ? void 0 : error.data) === null || _d === void 0 ? void 0 : _d.expected) | ||
: (_e = error === null || error === void 0 ? void 0 : error.data) === null || _e === void 0 ? void 0 : _e.expected}\` but received \`${(_f = error === null || error === void 0 ? void 0 : error.data) === null || _f === void 0 ? void 0 : _f.received}\``; | ||
@@ -58,3 +52,3 @@ } | ||
}; | ||
this.options = Object.assign({ jsonParser: parseJSONDocument_js_1.parseJSONDocumentState }, options); | ||
this.options = Object.assign({ jsonParser: parseJSONDocument_1.parseJSONDocumentState }, options); | ||
// TODO: support other versions of json schema. | ||
@@ -65,2 +59,3 @@ // most standard schemas are draft 4 for some reason, probably | ||
// ajv did not support draft 4, so I used json-schema-library | ||
this.schema = new json_schema_library_1.Draft04(schema); | ||
} | ||
@@ -73,7 +68,2 @@ get schemaTitle() { | ||
doValidation(view) { | ||
const schema = (0, state_js_1.getJSONSchema)(view.state); | ||
if (!schema) { | ||
return []; | ||
} | ||
this.schema = new json_schema_library_1.Draft04(schema); | ||
if (!this.schema) | ||
@@ -80,0 +70,0 @@ return []; |
@@ -6,2 +6,2 @@ import { JSONSchema7 } from "json-schema"; | ||
*/ | ||
export declare function json5Schema(schema?: JSONSchema7): import("@codemirror/state").Extension[]; | ||
export declare function json5Schema(schema: JSONSchema7): import("@codemirror/state").Extension[]; |
@@ -6,8 +6,6 @@ "use strict"; | ||
const view_1 = require("@codemirror/view"); | ||
const json_completion_js_1 = require("./json-completion.js"); | ||
const json5_validation_js_1 = require("./json5-validation.js"); | ||
const json5_hover_js_1 = require("./json5-hover.js"); | ||
const json_completion_1 = require("./json-completion"); | ||
const json5_validation_1 = require("./json5-validation"); | ||
const json5_hover_1 = require("./json5-hover"); | ||
const lint_1 = require("@codemirror/lint"); | ||
const state_js_1 = require("./state.js"); | ||
const json_validation_js_1 = require("./json-validation.js"); | ||
/** | ||
@@ -21,12 +19,9 @@ * Full featured cm6 extension for json5, including `codemirror-json5` | ||
(0, lint_1.linter)((0, codemirror_json5_1.json5ParseLinter)()), | ||
(0, lint_1.linter)((0, json5_validation_js_1.json5SchemaLinter)(), { | ||
needsRefresh: json_validation_js_1.handleRefresh, | ||
}), | ||
(0, lint_1.linter)((0, json5_validation_1.json5SchemaLinter)(schema)), | ||
codemirror_json5_1.json5Language.data.of({ | ||
autocomplete: (0, json_completion_js_1.json5Completion)(), | ||
autocomplete: (0, json_completion_1.json5Completion)(schema), | ||
}), | ||
(0, view_1.hoverTooltip)((0, json5_hover_js_1.json5SchemaHover)()), | ||
(0, state_js_1.stateExtensions)(schema), | ||
(0, view_1.hoverTooltip)((0, json5_hover_1.json5SchemaHover)(schema)), | ||
]; | ||
} | ||
exports.json5Schema = json5Schema; |
import { type EditorView } from "@codemirror/view"; | ||
import { type HoverOptions } from "./json-hover.js"; | ||
import { Side } from "./types.js"; | ||
import { type HoverOptions } from "./json-hover"; | ||
import { type JSONSchema7 } from "json-schema"; | ||
import { Side } from "./types"; | ||
export type JSON5HoverOptions = Exclude<HoverOptions, "mode">; | ||
@@ -9,2 +10,2 @@ /** | ||
*/ | ||
export declare function json5SchemaHover(options?: JSON5HoverOptions): (view: EditorView, pos: number, side: Side) => Promise<import("@codemirror/view").Tooltip | null>; | ||
export declare function json5SchemaHover(schema: JSONSchema7, options?: JSON5HoverOptions): (view: EditorView, pos: number, side: Side) => Promise<import("@codemirror/view").Tooltip | null>; |
@@ -7,3 +7,3 @@ "use strict"; | ||
exports.json5SchemaHover = void 0; | ||
const json_hover_js_1 = require("./json-hover.js"); | ||
const json_hover_1 = require("./json-hover"); | ||
const json5_1 = __importDefault(require("json5")); | ||
@@ -14,4 +14,4 @@ /** | ||
*/ | ||
function json5SchemaHover(options) { | ||
const hover = new json_hover_js_1.JSONHover(Object.assign(Object.assign({}, options), { parser: json5_1.default.parse })); | ||
function json5SchemaHover(schema, options) { | ||
const hover = new json_hover_1.JSONHover(schema, Object.assign(Object.assign({}, options), { parser: json5_1.default.parse })); | ||
return async function jsonDoHover(view, pos, side) { | ||
@@ -18,0 +18,0 @@ return hover.doHover(view, pos, side); |
import { EditorView } from "@codemirror/view"; | ||
import { type JSONValidationOptions } from "./json-validation.js"; | ||
import { type JSONValidationOptions } from "./json-validation"; | ||
import type { JSONSchema7 } from "json-schema"; | ||
/** | ||
@@ -7,2 +8,2 @@ * Instantiates a JSONValidation instance with the JSON5 mode | ||
*/ | ||
export declare function json5SchemaLinter(options?: JSONValidationOptions): (view: EditorView) => import("@codemirror/lint").Diagnostic[]; | ||
export declare function json5SchemaLinter(schema: JSONSchema7, options?: JSONValidationOptions): (view: EditorView) => import("@codemirror/lint").Diagnostic[]; |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.json5SchemaLinter = void 0; | ||
const json_validation_js_1 = require("./json-validation.js"); | ||
const parseJSON5Document_js_1 = require("./utils/parseJSON5Document.js"); | ||
const json_validation_1 = require("./json-validation"); | ||
const parseJSON5Document_1 = require("./utils/parseJSON5Document"); | ||
/** | ||
@@ -10,5 +10,5 @@ * Instantiates a JSONValidation instance with the JSON5 mode | ||
*/ | ||
function json5SchemaLinter(options) { | ||
const validation = new json_validation_js_1.JSONValidation(Object.assign({ jsonParser: parseJSON5Document_js_1.parseJSON5DocumentState }, options)); | ||
return (view) => { | ||
function json5SchemaLinter(schema, options) { | ||
const validation = new json_validation_1.JSONValidation(schema, Object.assign({ jsonParser: parseJSON5Document_1.parseJSON5DocumentState }, options)); | ||
return function json5DoLint(view) { | ||
return validation.doValidation(view); | ||
@@ -15,0 +15,0 @@ }; |
@@ -1,8 +0,8 @@ | ||
export { json5SchemaLinter } from "./json5-validation.js"; | ||
export { json5SchemaHover } from "./json5-hover.js"; | ||
export { json5Completion } from "./json-completion.js"; | ||
export { json5SchemaLinter } from "./json5-validation"; | ||
export { json5SchemaHover } from "./json5-hover"; | ||
export { json5Completion } from "./json-completion"; | ||
/** | ||
* @group Bundled Codemirror Extensions | ||
*/ | ||
export { json5Schema } from "./json5-bundled.js"; | ||
export * from "./utils/parseJSON5Document.js"; | ||
export { json5Schema } from "./json5-bundled"; | ||
export * from "./utils/parseJSON5Document"; |
@@ -19,13 +19,13 @@ "use strict"; | ||
// json5 | ||
var json5_validation_js_1 = require("./json5-validation.js"); | ||
Object.defineProperty(exports, "json5SchemaLinter", { enumerable: true, get: function () { return json5_validation_js_1.json5SchemaLinter; } }); | ||
var json5_hover_js_1 = require("./json5-hover.js"); | ||
Object.defineProperty(exports, "json5SchemaHover", { enumerable: true, get: function () { return json5_hover_js_1.json5SchemaHover; } }); | ||
var json_completion_js_1 = require("./json-completion.js"); | ||
Object.defineProperty(exports, "json5Completion", { enumerable: true, get: function () { return json_completion_js_1.json5Completion; } }); | ||
var json5_validation_1 = require("./json5-validation"); | ||
Object.defineProperty(exports, "json5SchemaLinter", { enumerable: true, get: function () { return json5_validation_1.json5SchemaLinter; } }); | ||
var json5_hover_1 = require("./json5-hover"); | ||
Object.defineProperty(exports, "json5SchemaHover", { enumerable: true, get: function () { return json5_hover_1.json5SchemaHover; } }); | ||
var json_completion_1 = require("./json-completion"); | ||
Object.defineProperty(exports, "json5Completion", { enumerable: true, get: function () { return json_completion_1.json5Completion; } }); | ||
/** | ||
* @group Bundled Codemirror Extensions | ||
*/ | ||
var json5_bundled_js_1 = require("./json5-bundled.js"); | ||
Object.defineProperty(exports, "json5Schema", { enumerable: true, get: function () { return json5_bundled_js_1.json5Schema; } }); | ||
__exportStar(require("./utils/parseJSON5Document.js"), exports); | ||
var json5_bundled_1 = require("./json5-bundled"); | ||
Object.defineProperty(exports, "json5Schema", { enumerable: true, get: function () { return json5_bundled_1.json5Schema; } }); | ||
__exportStar(require("./utils/parseJSON5Document"), exports); |
import { EditorState, Text } from "@codemirror/state"; | ||
import { SyntaxNode } from "@lezer/common"; | ||
import { JSONPointersMap, Side } from "../types.js"; | ||
import { JSONPointersMap, Side } from "../types"; | ||
export type JSONMode = "json4" | "json5"; | ||
@@ -5,0 +5,0 @@ export declare function getJsonPointerAt(docText: Text, node: SyntaxNode): string; |
@@ -5,4 +5,4 @@ "use strict"; | ||
const language_1 = require("@codemirror/language"); | ||
const constants_js_1 = require("../constants.js"); | ||
const node_js_1 = require("./node.js"); | ||
const constants_1 = require("../constants"); | ||
const node_1 = require("./node"); | ||
// adapted from https://discuss.codemirror.net/t/json-pointer-at-cursor-seeking-implementation-critique/4793/3 | ||
@@ -14,12 +14,12 @@ // this could be useful for other things later! | ||
switch (n.parent.name) { | ||
case constants_js_1.TOKENS.PROPERTY: { | ||
const name = n.parent.getChild(constants_js_1.TOKENS.PROPERTY_NAME); | ||
case constants_1.TOKENS.PROPERTY: { | ||
const name = n.parent.getChild(constants_1.TOKENS.PROPERTY_NAME); | ||
if (name) { | ||
path.unshift((0, node_js_1.getWord)(docText, name).replace(/[/~]/g, (v) => v === "~" ? "~0" : "~1")); | ||
path.unshift((0, node_1.getWord)(docText, name).replace(/[/~]/g, (v) => v === "~" ? "~0" : "~1")); | ||
} | ||
break; | ||
} | ||
case constants_js_1.TOKENS.ARRAY: { | ||
if ((0, node_js_1.isValueNode)(n)) { | ||
const index = (0, node_js_1.findNodeIndexInArrayNode)(n.parent, n); | ||
case constants_1.TOKENS.ARRAY: { | ||
if ((0, node_1.isValueNode)(n)) { | ||
const index = (0, node_1.findNodeIndexInArrayNode)(n.parent, n); | ||
path.unshift(`${index}`); | ||
@@ -26,0 +26,0 @@ } |
import { SyntaxNode } from "@lezer/common"; | ||
import { EditorState, Text } from "@codemirror/state"; | ||
import { Side } from "../types.js"; | ||
import { Side } from "../types"; | ||
export declare const getNodeAtPosition: (state: EditorState, pos: number, side?: Side) => SyntaxNode; | ||
@@ -5,0 +5,0 @@ export declare const stripSurroundingQuotes: (str: string) => string; |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.findNodeIndexInArrayNode = exports.getChildValueNode = exports.isPropertyNameNode = exports.isValueNode = exports.isPrimitiveValueNode = exports.isInvalidValueNode = exports.getWord = exports.stripSurroundingQuotes = exports.getNodeAtPosition = void 0; | ||
const constants_js_1 = require("../constants.js"); | ||
const constants_1 = require("../constants"); | ||
const language_1 = require("@codemirror/language"); | ||
@@ -21,13 +21,13 @@ const getNodeAtPosition = (state, pos, side = -1) => { | ||
var _a, _b; | ||
return (node.name === constants_js_1.TOKENS.INVALID && | ||
(((_a = node.prevSibling) === null || _a === void 0 ? void 0 : _a.name) === constants_js_1.TOKENS.PROPERTY_NAME || | ||
((_b = node.prevSibling) === null || _b === void 0 ? void 0 : _b.name) === constants_js_1.TOKENS.PROPERTY_COLON)); | ||
return (node.name === constants_1.TOKENS.INVALID && | ||
(((_a = node.prevSibling) === null || _a === void 0 ? void 0 : _a.name) === constants_1.TOKENS.PROPERTY_NAME || | ||
((_b = node.prevSibling) === null || _b === void 0 ? void 0 : _b.name) === constants_1.TOKENS.PROPERTY_COLON)); | ||
}; | ||
exports.isInvalidValueNode = isInvalidValueNode; | ||
const isPrimitiveValueNode = (node) => { | ||
return constants_js_1.PRIMITIVE_TYPES.includes(node.name) || (0, exports.isInvalidValueNode)(node); | ||
return constants_1.PRIMITIVE_TYPES.includes(node.name) || (0, exports.isInvalidValueNode)(node); | ||
}; | ||
exports.isPrimitiveValueNode = isPrimitiveValueNode; | ||
const isValueNode = (node) => { | ||
return ([...constants_js_1.PRIMITIVE_TYPES, ...constants_js_1.COMPLEX_TYPES].includes(node.name) || | ||
return ([...constants_1.PRIMITIVE_TYPES, ...constants_1.COMPLEX_TYPES].includes(node.name) || | ||
(0, exports.isInvalidValueNode)(node)); | ||
@@ -38,5 +38,5 @@ }; | ||
var _a, _b; | ||
return (node.name === constants_js_1.TOKENS.PROPERTY_NAME || | ||
(node.name === constants_js_1.TOKENS.INVALID && | ||
(((_a = node.prevSibling) === null || _a === void 0 ? void 0 : _a.name) === constants_js_1.TOKENS.PROPERTY || | ||
return (node.name === constants_1.TOKENS.PROPERTY_NAME || | ||
(node.name === constants_1.TOKENS.INVALID && | ||
(((_a = node.prevSibling) === null || _a === void 0 ? void 0 : _a.name) === constants_1.TOKENS.PROPERTY || | ||
((_b = node.prevSibling) === null || _b === void 0 ? void 0 : _b.name) === "{"))); | ||
@@ -61,3 +61,3 @@ }; | ||
const getArrayNodeChildren = (node) => { | ||
return getChildrenNodes(node).filter((n) => constants_js_1.PRIMITIVE_TYPES.includes(n.name) || constants_js_1.COMPLEX_TYPES.includes(n.name)); | ||
return getChildrenNodes(node).filter((n) => constants_1.PRIMITIVE_TYPES.includes(n.name) || constants_1.COMPLEX_TYPES.includes(n.name)); | ||
}; | ||
@@ -64,0 +64,0 @@ const findNodeIndexInArrayNode = (arrayNode, valueNode) => { |
@@ -11,3 +11,3 @@ /** | ||
data: any; | ||
pointers: import("../types.js").JSONPointersMap; | ||
pointers: import("..").JSONPointersMap; | ||
}; | ||
@@ -20,3 +20,3 @@ /** | ||
data: any; | ||
pointers: import("../types.js").JSONPointersMap; | ||
pointers: import("..").JSONPointersMap; | ||
}; |
@@ -13,3 +13,3 @@ "use strict"; | ||
const state_1 = require("@codemirror/state"); | ||
const jsonPointers_js_1 = require("./jsonPointers.js"); | ||
const jsonPointers_1 = require("./jsonPointers"); | ||
/** | ||
@@ -26,3 +26,3 @@ * Return parsed data and json5 pointers for a given codemirror EditorState | ||
catch (_a) { } | ||
const pointers = (0, jsonPointers_js_1.getJsonPointers)(state, "json5"); | ||
const pointers = (0, jsonPointers_1.getJsonPointers)(state, "json5"); | ||
return { data, pointers }; | ||
@@ -29,0 +29,0 @@ } |
@@ -8,3 +8,3 @@ import { EditorState } from "@codemirror/state"; | ||
data: any; | ||
pointers: import("../types.js").JSONPointersMap; | ||
pointers: import("..").JSONPointersMap; | ||
}; | ||
@@ -17,3 +17,3 @@ /** | ||
data: any; | ||
pointers: import("../types.js").JSONPointersMap; | ||
pointers: import("..").JSONPointersMap; | ||
}; |
@@ -6,3 +6,3 @@ "use strict"; | ||
const state_1 = require("@codemirror/state"); | ||
const jsonPointers_js_1 = require("./jsonPointers.js"); | ||
const jsonPointers_1 = require("./jsonPointers"); | ||
/** | ||
@@ -19,3 +19,3 @@ * Return parsed data and json pointers for a given codemirror EditorState | ||
catch (_a) { } | ||
const pointers = (0, jsonPointers_js_1.getJsonPointers)(state, "json4"); | ||
const pointers = (0, jsonPointers_1.getJsonPointers)(state, "json4"); | ||
return { data, pointers }; | ||
@@ -22,0 +22,0 @@ } |
@@ -8,3 +8,3 @@ "use strict"; | ||
const json_schema_library_1 = require("json-schema-library"); | ||
const step_js_1 = __importDefault(require("./step.js")); | ||
const step_1 = __importDefault(require("./step")); | ||
const emptyObject = {}; | ||
@@ -36,3 +36,3 @@ /** | ||
// @ts-expect-error | ||
schema = (0, step_js_1.default)(draft, key, schema, data, pointer); // step schema | ||
schema = (0, step_1.default)(draft, key, schema, data, pointer); // step schema | ||
if ((0, json_schema_library_1.isJsonError)(schema)) { | ||
@@ -39,0 +39,0 @@ return schema; |
@@ -8,5 +8,5 @@ "use strict"; | ||
// @ts-expect-error | ||
const errors_js_1 = __importDefault(require("json-schema-library/dist/module/lib/validation/errors.js")); | ||
const errors_1 = __importDefault(require("json-schema-library/dist/module/lib/validation/errors")); | ||
// @ts-expect-error | ||
const createSchemaOf_js_1 = __importDefault(require("json-schema-library/dist/module/lib/createSchemaOf.js")); | ||
const createSchemaOf_1 = __importDefault(require("json-schema-library/dist/module/lib/createSchemaOf")); | ||
const stepType = { | ||
@@ -24,7 +24,7 @@ array: (draft, key, schema, data, pointer) => { | ||
if (schema.items[key] === true) { | ||
return (0, createSchemaOf_js_1.default)(itemValue); | ||
return (0, createSchemaOf_1.default)(itemValue); | ||
} | ||
// @draft >= 7 bool schema, items:[true, false] | ||
if (schema.items[key] === false) { | ||
return errors_js_1.default.invalidDataError({ | ||
return errors_1.default.invalidDataError({ | ||
key, | ||
@@ -39,3 +39,3 @@ value: itemValue, | ||
if (schema.additionalItems === false) { | ||
return errors_js_1.default.additionalItemsError({ | ||
return errors_1.default.additionalItemsError({ | ||
key, | ||
@@ -48,3 +48,3 @@ value: itemValue, | ||
schema.additionalItems === undefined) { | ||
return (0, createSchemaOf_js_1.default)(itemValue); | ||
return (0, createSchemaOf_1.default)(itemValue); | ||
} | ||
@@ -59,3 +59,3 @@ if ((0, json_schema_library_1.getTypeOf)(schema.additionalItems) === "object") { | ||
// @todo support additionalItems: {schema} | ||
return (0, createSchemaOf_js_1.default)(itemValue); | ||
return (0, createSchemaOf_1.default)(itemValue); | ||
} | ||
@@ -73,3 +73,3 @@ return new Error(`Invalid array schema for ${key} at ${pointer}`); | ||
if (property === false) { | ||
return errors_js_1.default.forbiddenPropertyError({ | ||
return errors_1.default.forbiddenPropertyError({ | ||
property: key, | ||
@@ -81,3 +81,3 @@ value: data, | ||
else if (property === true) { | ||
return (0, createSchemaOf_js_1.default)(data === null || data === void 0 ? void 0 : data[key]); | ||
return (0, createSchemaOf_1.default)(data === null || data === void 0 ? void 0 : data[key]); | ||
} | ||
@@ -122,5 +122,5 @@ const targetSchema = draft.resolveRef(property); | ||
(additionalProperties === undefined || additionalProperties === true)) { | ||
return (0, createSchemaOf_js_1.default)(data[key]); | ||
return (0, createSchemaOf_1.default)(data[key]); | ||
} | ||
return errors_js_1.default.unknownPropertyError({ | ||
return errors_1.default.unknownPropertyError({ | ||
property: key, | ||
@@ -127,0 +127,0 @@ value: data, |
import { CompletionContext, CompletionResult } from "@codemirror/autocomplete"; | ||
import { JSONSchema7 } from "json-schema"; | ||
import { JsonError } from "json-schema-library"; | ||
type JSONCompletionOptions = { | ||
@@ -26,3 +24,2 @@ mode?: "json" | "json5"; | ||
private getSchemas; | ||
isJsonError(d: JSONSchema7 | JsonError): d is JsonError; | ||
private expandSchemaProperty; | ||
@@ -29,0 +26,0 @@ private getReferenceSchema; |
@@ -5,7 +5,6 @@ import { snippetCompletion, } from "@codemirror/autocomplete"; | ||
import { findNodeIndexInArrayNode, getChildValueNode, getWord, isPropertyNameNode, isPrimitiveValueNode, stripSurroundingQuotes, getNodeAtPosition, } from "./utils/node.js"; | ||
import { Draft07 } from "json-schema-library"; | ||
import { getJSONSchema } from "./state.js"; | ||
import { Draft07, isJsonError } from "json-schema-library"; | ||
import { jsonPointerForPosition } from "./utils/jsonPointers.js"; | ||
import { TOKENS } from "./constants.js"; | ||
import { getJSONSchema } from "./state.js"; | ||
import getSchema from "./utils/schema-lib/getSchema.js"; | ||
function json5PropertyInsertSnippet(rawWord, value) { | ||
@@ -517,5 +516,9 @@ if (rawWord.startsWith('"')) { | ||
getSchemas(schema, ctx) { | ||
var _a; | ||
const draft = new Draft07(this.schema); | ||
let pointer = jsonPointerForPosition(ctx.state, ctx.pos); | ||
let subSchema = getSchema(draft, pointer); | ||
let subSchema = draft.getSchema({ pointer }); | ||
if (isJsonError(subSchema)) { | ||
subSchema = (_a = subSchema.data) === null || _a === void 0 ? void 0 : _a.schema; | ||
} | ||
// if we don't have a schema for the current pointer, try the parent pointer | ||
@@ -527,3 +530,3 @@ if (!subSchema || | ||
pointer = pointer.replace(/\/[^/]*$/, "/"); | ||
subSchema = getSchema(draft, pointer); | ||
subSchema = draft.getSchema({ pointer }); | ||
} | ||
@@ -537,3 +540,3 @@ debug.log("xxx", "pointer..", JSON.stringify(pointer)); | ||
debug.log("xxx", "subSchema..", subSchema); | ||
if (this.isJsonError(subSchema)) { | ||
if (!subSchema) { | ||
return []; | ||
@@ -561,5 +564,2 @@ } | ||
} | ||
isJsonError(d) { | ||
return d.type === "error"; | ||
} | ||
expandSchemaProperty(property, schema) { | ||
@@ -566,0 +566,0 @@ if (typeof property === "object" && property.$ref) { |
@@ -1,5 +0,4 @@ | ||
import { Draft04 } from "json-schema-library"; | ||
import { Draft04, isJsonError, } from "json-schema-library"; | ||
import { jsonPointerForPosition } from "./utils/jsonPointers.js"; | ||
import { joinWithOr } from "./utils/formatting.js"; | ||
import getSchema from "./utils/schema-lib/getSchema.js"; | ||
import { debug } from "./utils/debug.js"; | ||
@@ -49,9 +48,14 @@ import { el } from "./utils/dom.js"; | ||
// if the data is valid, we can infer a type for complex types | ||
let subSchema = getSchema(this.schema, pointer, data); | ||
if (subSchema.type === "error" && data !== undefined) { | ||
// if the data is invalid, we won't get the type - try again without the data | ||
subSchema = getSchema(this.schema, pointer, undefined); | ||
if (subSchema.type === "error") { | ||
return { pointer }; | ||
let subSchema = this.schema.getSchema({ | ||
pointer, | ||
data, | ||
withSchemaWarning: true, | ||
}); | ||
if (isJsonError(subSchema)) { | ||
if (subSchema === null || subSchema === void 0 ? void 0 : subSchema.data.schema["$ref"]) { | ||
subSchema = this.schema.resolveRef(subSchema); | ||
} | ||
else { | ||
subSchema = subSchema === null || subSchema === void 0 ? void 0 : subSchema.data.schema; | ||
} | ||
} | ||
@@ -69,3 +73,11 @@ return { schema: subSchema, pointer }; | ||
el("div", { class: "cm6-json-schema-hover--code-wrapper" }, [ | ||
el("code", { class: "cm6-json-schema-hover--code", text: typeInfo }), | ||
typeInfo.includes("<code>") | ||
? el("div", { | ||
class: "cm6-json-schema-hover--code", | ||
inner: typeInfo, | ||
}) | ||
: el("code", { | ||
class: "cm6-json-schema-hover--code", | ||
text: typeInfo, | ||
}), | ||
]), | ||
@@ -98,2 +110,11 @@ ]); | ||
} | ||
if (schema.enum) { | ||
typeInfo = `<code>enum</code>: ${joinWithOr(schema.enum)}`; | ||
} | ||
if (schema.format) { | ||
typeInfo += ` <code>format</code>: ${schema.format}`; | ||
} | ||
if (schema.pattern) { | ||
typeInfo += ` <code>pattern</code>: ${schema.pattern}`; | ||
} | ||
if (schema.description) { | ||
@@ -100,0 +121,0 @@ message = schema.description; |
import { Draft04 } from "json-schema-library"; | ||
import { getJSONSchema, schemaStateField } from "./state.js"; | ||
import { joinWithOr } from "./utils/formatting.js"; | ||
import { parseJSONDocumentState } from "./utils/parseJSONDocument.js"; | ||
import { getJSONSchema, schemaStateField } from "./state.js"; | ||
import { el } from "./utils/dom.js"; | ||
// return an object path that matches with the json-source-map pointer | ||
@@ -37,12 +38,20 @@ const getErrorPath = (error) => { | ||
this.rewriteError = (error) => { | ||
var _a, _b, _c, _d, _e, _f; | ||
if (error.code === "one-of-error") { | ||
return `Expected one of ${joinWithOr((_a = error === null || error === void 0 ? void 0 : error.data) === null || _a === void 0 ? void 0 : _a.errors, (data) => data.data.expected)}`; | ||
var _a, _b, _c, _d, _e; | ||
const errorData = error === null || error === void 0 ? void 0 : error.data; | ||
const errors = errorData === null || errorData === void 0 ? void 0 : errorData.errors; | ||
if (error.code === "one-of-error" && (errors === null || errors === void 0 ? void 0 : errors.length)) { | ||
return `Expected one of ${joinWithOr(errors, (data) => data.data.expected)}`; | ||
} | ||
if (error.code === "type-error") { | ||
return `Expected \`${((_b = error === null || error === void 0 ? void 0 : error.data) === null || _b === void 0 ? void 0 : _b.expected) && Array.isArray((_c = error === null || error === void 0 ? void 0 : error.data) === null || _c === void 0 ? void 0 : _c.expected) | ||
? joinWithOr((_d = error === null || error === void 0 ? void 0 : error.data) === null || _d === void 0 ? void 0 : _d.expected) | ||
: (_e = error === null || error === void 0 ? void 0 : error.data) === null || _e === void 0 ? void 0 : _e.expected}\` but received \`${(_f = error === null || error === void 0 ? void 0 : error.data) === null || _f === void 0 ? void 0 : _f.received}\``; | ||
return `Expected <code>${((_a = error === null || error === void 0 ? void 0 : error.data) === null || _a === void 0 ? void 0 : _a.expected) && Array.isArray((_b = error === null || error === void 0 ? void 0 : error.data) === null || _b === void 0 ? void 0 : _b.expected) | ||
? joinWithOr((_c = error === null || error === void 0 ? void 0 : error.data) === null || _c === void 0 ? void 0 : _c.expected) | ||
: (_d = error === null || error === void 0 ? void 0 : error.data) === null || _d === void 0 ? void 0 : _d.expected}</code> but received <code>${(_e = error === null || error === void 0 ? void 0 : error.data) === null || _e === void 0 ? void 0 : _e.received}</code>`; | ||
} | ||
const message = error.message.replaceAll("#/", "").replaceAll("/", "."); | ||
const message = error.message | ||
// don't mention root object | ||
.replaceAll("in `#` ", "") | ||
.replaceAll("/", ".") | ||
.replaceAll("#.", "") | ||
// replace backticks with <code> tags | ||
.replaceAll(/`([^`]*)`/gm, "<code>$1</code>"); | ||
return message; | ||
@@ -58,4 +67,4 @@ }; | ||
get schemaTitle() { | ||
var _a; | ||
return (_a = this.schema.getSchema().title) !== null && _a !== void 0 ? _a : "json-schema"; | ||
var _a, _b, _c; | ||
return (_c = (_b = (_a = this.schema) === null || _a === void 0 ? void 0 : _a.getSchema()) === null || _b === void 0 ? void 0 : _b.title) !== null && _c !== void 0 ? _c : "json-schema"; | ||
} | ||
@@ -90,8 +99,12 @@ // validate using view as the linter extension signature requires | ||
const isPropertyError = error.name === "NoAdditionalPropertiesError"; | ||
const errorString = this.rewriteError(error); | ||
acc.push({ | ||
from: isPropertyError ? pointer.keyFrom : pointer.valueFrom, | ||
to: isPropertyError ? pointer.keyTo : pointer.valueTo, | ||
// TODO: create a domnode and replace `` with <code></code> | ||
// renderMessage: () => error.message, | ||
message: this.rewriteError(error), | ||
message: errorString, | ||
renderMessage: () => { | ||
const dom = el("div", {}); | ||
dom.innerHTML = errorString; | ||
return dom; | ||
}, | ||
severity: "error", | ||
@@ -98,0 +111,0 @@ source: this.schemaTitle, |
@@ -6,2 +6,2 @@ import { JSONSchema7 } from "json-schema"; | ||
*/ | ||
export declare function json5Schema(schema?: JSONSchema7): import("@codemirror/state").Extension[]; | ||
export declare function json5Schema(schema?: JSONSchema7): any[]; |
export const debug = { | ||
log: (...args) => { | ||
if ("production" !== "development") { | ||
if (process.env.NODE_ENV !== "development") { | ||
return; | ||
@@ -5,0 +5,0 @@ } |
@@ -1,3 +0,3 @@ | ||
type Attributes = "class" | "text" | "id" | "role" | "aria-label"; | ||
type Attributes = "class" | "text" | "id" | "role" | "aria-label" | "inner"; | ||
export declare function el(tagName: string, attributes: Partial<Record<Attributes, string>>, children?: HTMLElement[]): HTMLElement; | ||
export {}; |
@@ -15,2 +15,6 @@ // export function el(tagName: string, className?: string) { | ||
} | ||
if (k === "inner") { | ||
e.innerHTML = v; | ||
return; | ||
} | ||
e.setAttribute(k, v); | ||
@@ -17,0 +21,0 @@ }); |
@@ -6,3 +6,3 @@ // a little english-centric utility | ||
let data = arr.map((err, i) => { | ||
const result = `\`` + (getPath ? JSON.stringify(getPath(err)) : err) + `\``; | ||
const result = `<code>` + (getPath ? getPath(err) : err) + `</code>`; | ||
if (i === arr.length - 1) | ||
@@ -9,0 +9,0 @@ return "or " + result; |
import { SyntaxNode } from "@lezer/common"; | ||
import { EditorState, Text } from "@codemirror/state"; | ||
import { Side } from "../types.js"; | ||
export declare const getNodeAtPosition: (state: EditorState, pos: number, side?: Side) => SyntaxNode; | ||
export declare const getNodeAtPosition: (state: EditorState, pos: number, side?: Side) => any; | ||
export declare const stripSurroundingQuotes: (str: string) => string; | ||
@@ -11,3 +11,3 @@ export declare const getWord: (doc: Text, node: SyntaxNode | null, stripQuotes?: boolean) => string; | ||
export declare const isPropertyNameNode: (node: SyntaxNode) => boolean; | ||
export declare const getChildValueNode: (node: SyntaxNode) => SyntaxNode | undefined; | ||
export declare const getChildValueNode: (node: SyntaxNode) => any; | ||
export declare const findNodeIndexInArrayNode: (arrayNode: SyntaxNode, valueNode: SyntaxNode) => number; |
{ | ||
"name": "codemirror-json-schema", | ||
"license": "MIT", | ||
"version": "0.5.0", | ||
"version": "0.5.1-canary", | ||
"description": "Codemirror 6 extensions that provide full JSONSchema support for `@codemirror/lang-json` and `codemirror-json5`", | ||
@@ -59,3 +59,3 @@ "contributors": [ | ||
"json-schema": "^0.4.0", | ||
"json-schema-library": "^8.0.0" | ||
"json-schema-library": "^9.1.2" | ||
}, | ||
@@ -110,2 +110,2 @@ "optionalDependencies": { | ||
} | ||
} | ||
} |
185798
97
3795
+ Addedcommander@2.20.3(transitive)
+ Addeddiscontinuous-range@1.0.0(transitive)
+ Addedjson-schema-library@9.3.5(transitive)
+ Addedmoo@0.5.2(transitive)
+ Addednearley@2.20.1(transitive)
+ Addedrailroad-diagrams@1.0.0(transitive)
+ Addedrandexp@0.4.6(transitive)
+ Addedret@0.1.15(transitive)
+ Addedsmtp-address-parser@1.0.10(transitive)
- Removedjson-schema-library@8.0.0(transitive)
Updatedjson-schema-library@^9.1.2