Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

codemirror-json-schema

Package Overview
Dependencies
Maintainers
1
Versions
34
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

codemirror-json-schema - npm Package Compare versions

Comparing version 0.5.0 to 0.5.1-canary

dist/debug.d.ts

6

CHANGELOG.md

@@ -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 @@

2

cjs/bundled.d.ts

@@ -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": {

}
}
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc