-
-
Notifications
You must be signed in to change notification settings - Fork 3.2k
/
index.tsx
87 lines (69 loc) · 1.99 KB
/
index.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
// Copyright (c) Jupyter Development Team.
// Distributed under the terms of the Modified BSD License.
import { IRenderMime } from '@jupyterlab/rendermime-interfaces';
import { printSymbol, printd } from '@jupyterlab/apputils';
import { Widget } from '@phosphor/widgets';
import * as React from 'react';
import * as ReactDOM from 'react-dom';
import { Component } from './component';
import '../style/index.css';
/**
* The CSS class to add to the JSON Widget.
*/
const CSS_CLASS = 'jp-RenderedJSON';
/**
* The MIME type for JSON.
*/
export const MIME_TYPE = 'application/json';
/**
* A renderer for JSON data.
*/
export class RenderedJSON extends Widget implements IRenderMime.IRenderer {
/**
* Create a new widget for rendering JSON.
*/
constructor(options: IRenderMime.IRendererOptions) {
super();
this.addClass(CSS_CLASS);
this._mimeType = options.mimeType;
}
[printSymbol] = printd;
/**
* Render JSON into this widget's node.
*/
renderModel(model: IRenderMime.IMimeModel): Promise<void> {
const data = model.data[this._mimeType] as any;
const metadata = (model.metadata[this._mimeType] as any) || {};
const props = { data, metadata, theme: 'cm-s-jupyter' };
return new Promise<void>((resolve, reject) => {
const component = <Component {...props} />;
ReactDOM.render(component, this.node, () => {
resolve();
});
});
}
private _mimeType: string;
}
/**
* A mime renderer factory for JSON data.
*/
export const rendererFactory: IRenderMime.IRendererFactory = {
safe: true,
mimeTypes: [MIME_TYPE],
createRenderer: options => new RenderedJSON(options)
};
const extensions: IRenderMime.IExtension | IRenderMime.IExtension[] = [
{
id: '@jupyterlab/json-extension:factory',
rendererFactory,
rank: 0,
dataType: 'json',
documentWidgetFactoryOptions: {
name: 'JSON',
primaryFileType: 'json',
fileTypes: ['json', 'notebook'],
defaultFor: ['json']
}
}
];
export default extensions;