This repository was archived by the owner on Oct 5, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathhoogle-doc-view.js
76 lines (76 loc) · 10.9 KB
/
hoogle-doc-view.js
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
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.HoogleDocView = void 0;
const atom_1 = require("atom");
const etch = require("etch");
const util_1 = require("./util");
class HoogleDocView {
constructor(props = {}) {
this.props = props;
this.disposables = new atom_1.CompositeDisposable();
this.style = {};
this.parsedDoc = '';
this.openWebDoc = () => {
this.props.symbol && util_1.openWeb(this.props.symbol, false);
};
this.updateDoc(props.symbol && props.symbol.doc);
this.disposables.add(atom.config.observe('editor.fontSize', (fontSize) => {
if (fontSize) {
this.style.fontSize = `${fontSize}px`;
}
}), atom.config.observe('editor.fontFamily', (fontFamily) => {
if (fontFamily) {
this.style.fontFamily = fontFamily;
}
}));
etch.initialize(this);
}
render() {
const hrefBtns = [];
if (this.props.symbol && this.props.symbol.href) {
hrefBtns.push(etch.dom("a", { class: "btn btn-default", on: { click: this.openWebDoc } }, "Open web documentation"), etch.dom("a", { class: "btn btn-default", href: this.props.symbol.href }, "Open web documentation in browser"));
}
return (etch.dom("div", { class: "ide-haskell-hoogle" },
etch.dom("div", { style: this.style, className: "ide-haskell-hoogle-doc-header", innerHTML: util_1.hl((this.props.symbol && this.props.symbol.signature) || '') }),
etch.dom("div", { className: "btn-group" }, hrefBtns),
etch.dom("div", { class: "ide-haskell-hoogle-output editor editor-colors native-key-bindings", style: this.style, tabIndex: "-1", innerHTML: this.parsedDoc })));
}
async update(props) {
if ((this.props.symbol && this.props.symbol.doc) !==
(props.symbol && props.symbol.doc)) {
this.updateDoc(props.symbol && props.symbol.doc);
}
this.props = props;
return etch.update(this);
}
getURI() {
return 'ide-haskell://hoogle/doc/';
}
getTitle() {
return 'Hoogle doc';
}
destroy() {
etch.destroy(this);
this.disposables.dispose();
}
serialize() {
return Object.assign(Object.assign({}, this.props), { deserializer: 'HoogleDocView' });
}
updateDoc(doc) {
if (!doc) {
this.parsedDoc = 'No documentation';
return;
}
const div = document.createElement('div');
div.innerHTML = doc;
div.querySelectorAll('pre').forEach((el) => {
el.innerHTML = util_1.hl(el.innerText);
});
div.querySelectorAll('a').forEach((el) => {
el.outerHTML = util_1.hl(el.innerText.trim());
});
this.parsedDoc = div.innerHTML;
}
}
exports.HoogleDocView = HoogleDocView;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hoogle-doc-view.js","sourceRoot":"","sources":["../src/hoogle-doc-view.tsx"],"names":[],"mappings":"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","sourcesContent":["import { CompositeDisposable } from 'atom'\nimport * as etch from 'etch'\nimport { hl, openWeb } from './util'\n\nexport interface IProps extends JSX.Props {\n  symbol?: ISymbol\n}\n\ntype ElementClass = JSX.ElementClass\n\nexport class HoogleDocView implements ElementClass {\n  public disposables = new CompositeDisposable()\n  private style: {\n    fontSize?: string\n    fontFamily?: string\n  } = {}\n  private parsedDoc: string = ''\n  constructor(public props: IProps = {}) {\n    this.updateDoc(props.symbol && props.symbol.doc)\n    this.disposables.add(\n      atom.config.observe('editor.fontSize', (fontSize: number) => {\n        if (fontSize) {\n          this.style.fontSize = `${fontSize}px`\n        }\n      }),\n      atom.config.observe('editor.fontFamily', (fontFamily: string) => {\n        if (fontFamily) {\n          this.style.fontFamily = fontFamily\n        }\n      }),\n    )\n    etch.initialize(this)\n  }\n\n  public render() {\n    const hrefBtns: JSX.Element[] = []\n    if (this.props.symbol && this.props.symbol.href) {\n      hrefBtns.push(\n        <a class=\"btn btn-default\" on={{ click: this.openWebDoc }}>\n          Open web documentation\n        </a>,\n        // tslint:disable-next-line: jsx-wrap-multiline\n        <a class=\"btn btn-default\" href={this.props.symbol.href}>\n          Open web documentation in browser\n        </a>,\n      )\n    }\n    return (\n      <div class=\"ide-haskell-hoogle\">\n        <div\n          style={this.style}\n          className=\"ide-haskell-hoogle-doc-header\"\n          innerHTML={hl(\n            (this.props.symbol && this.props.symbol.signature) || '',\n          )}\n        />\n        <div className=\"btn-group\">{hrefBtns}</div>\n        <div\n          class=\"ide-haskell-hoogle-output editor editor-colors native-key-bindings\"\n          style={this.style}\n          tabIndex=\"-1\"\n          innerHTML={this.parsedDoc}\n        />\n      </div>\n    )\n  }\n\n  public async update(props: IProps) {\n    if (\n      (this.props.symbol && this.props.symbol.doc) !==\n      (props.symbol && props.symbol.doc)\n    ) {\n      this.updateDoc(props.symbol && props.symbol.doc)\n    }\n    this.props = props\n    return etch.update(this)\n  }\n\n  public getURI() {\n    return 'ide-haskell://hoogle/doc/'\n  }\n\n  public getTitle() {\n    return 'Hoogle doc'\n  }\n\n  public destroy() {\n    // tslint:disable-next-line:no-floating-promises\n    etch.destroy(this)\n    this.disposables.dispose()\n  }\n\n  public serialize(): IProps & { deserializer: string } {\n    return {\n      ...this.props,\n      deserializer: 'HoogleDocView',\n    }\n  }\n\n  private updateDoc(doc: string | undefined) {\n    if (!doc) {\n      this.parsedDoc = 'No documentation'\n      return\n    }\n    const div = document.createElement('div')\n    div.innerHTML = doc\n    div.querySelectorAll('pre').forEach((el) => {\n      el.innerHTML = hl(el.innerText)\n    })\n    div.querySelectorAll('a').forEach((el) => {\n      el.outerHTML = hl(el.innerText.trim())\n    })\n    this.parsedDoc = div.innerHTML\n  }\n\n  private openWebDoc = () => {\n    this.props.symbol && openWeb(this.props.symbol, false)\n  }\n}\n"]}