First-class JSON support with DocJSON

DocJSON is the internal format used by Document Authoring, and it’s designed for high portability and custom integrations. This document representation retains the good parts of existing formats, but it fits better with modern tooling and APIs that often exchange data in JSON. An intermediary format was important for us to maximize the versatility of the library, to integrate better with web technologies, and to provide the best possible developer experience.

DocJSON is used when loading and saving from the editor. The format is easy to understand, and it can be modified outside the editor to fit your custom workflows, including templating and document generation. If you can modify JSON on the client or server, you can generate documents that the Document Authoring library can open and export (in multiple formats).

It’s our intention to fully document the format and push document handling toward more modern alternatives, with better interoperability. You can see a simple example of the format at the end of this guide.

Working with DocJSON in the editor

Before you start, ensure you have the Document Authoring library installed and running. Check out the getting started guides for more information.

Any error handling in the examples below is left out for brevity.

Loading DocJSON

Use the DocAuthSystem.loadDocument method:

// Assuming the `docAuthSystem` instance exists.

const document = await docAuthSystem.loadDocument(
	await fetch('./document.json').then((response) => response.json()),
);

const editor = await docAuthSystem.createEditor(
	document.getElementById('editor'),
	{ document },
);

Saving DocJSON

Use the DocAuthDocument.saveDocument or DocAuthDocument.saveDocumentJSONString method:

// Assuming the `editor` instance exists.

const currentDoc = editor.currentDocument();

const docObj = await currentDoc.saveDocument();
console.log('JS object', docObj);

const docJSON = await currentDoc.saveDocumentJSONString();
console.log('JSON string', docJSON);

Example

The example below shows how simple a document can be (any formatting styles and page setup are optional and will fall back to defaults). You can see from the properties in the JSON that this is version 1 of the container format, which represents documents as a body, with sections containing elements of different types, which themselves contain inline elements. In this instance, our document is a single paragraph containing a single text run of Hello world!. Inline elements, such as text runs, are modeled as a flat sequence as opposed to being nested like HTML:

{
	"type": "https://pspdfkit.com/document-authoring/persistence/container",
	"version": 1,
	"container": {
		"document": {
			"body": {
				"sections": [
					{
						"elements": [
							{
								"type": "p",
								"elements": [
									{
										"type": "r",
										"text": "Hello world!"
									}
								]
							}
						]
					}
				]
			}
		}
	}
}

Exploring more

If you’re interested in diving deeper into the DocJSON format, reach out to us.