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-web-view.js
80 lines (80 loc) · 10.9 KB
/
hoogle-web-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
77
78
79
80
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.HoogleWebView = void 0;
const atom_1 = require("atom");
const etch = require("etch");
class HoogleWebView {
constructor(props = {}) {
this.props = props;
this.disposables = new atom_1.CompositeDisposable();
this.zoomFactor = 100;
this.canShowWebview = false;
this.setZoom = () => {
this.refs.webView && this.refs.webView.setZoomFactor(this.zoomFactor / 100);
};
this.didNavigate = ({ url }) => {
this.props.url = url;
};
etch.initialize(this);
this.disposables.add(atom.config.observe('ide-haskell-hoogle.webZoomFactor', (zoomFactor) => {
this.zoomFactor = zoomFactor;
etch.update(this);
}));
this.canShowWebview = atom.packages.hasActivatedInitialPackages();
if (!this.canShowWebview) {
const disp = atom.packages.onDidActivateInitialPackages(() => {
disp.dispose();
this.canShowWebview = true;
etch.update(this);
});
}
}
render() {
return (etch.dom("div", { class: "ide-haskell-hoogle" },
etch.dom("div", { class: "ide-haskell-hoogle-web-navbar btn-group" },
etch.dom("button", { class: "btn btn-default btn-back", on: {
click: () => {
this.refs.webView &&
atom.commands.dispatch(this.refs.webView, 'ide-haskell-hoogle:web-go-back');
},
} }),
etch.dom("button", { class: "btn btn-default btn-forward", on: {
click: () => {
this.refs.webView &&
atom.commands.dispatch(this.refs.webView, 'ide-haskell-hoogle:web-go-forward');
},
} })),
this.webview()));
}
async update(props) {
if (this.props.url !== props.url) {
this.props.url = props.url;
}
return etch.update(this);
}
getURI() {
var _a;
return `ide-haskell://hoogle/web/${(_a = this.props.url) !== null && _a !== void 0 ? _a : ''}`;
}
getTitle() {
return 'Hoogle web';
}
destroy() {
this.disposables.dispose();
etch.destroy(this);
}
serialize() {
return Object.assign(Object.assign({}, this.props), { deserializer: 'HoogleWebView' });
}
webview() {
if (!this.canShowWebview)
return null;
return (etch.dom("webview", { ref: "webView", class: "ide-haskell-hoogle-web native-key-bindings", src: this.props.url, tabIndex: "-1", on: {
'dom-ready': this.setZoom,
'did-navigate': this.didNavigate,
'did-navigate-in-page': this.didNavigate,
} }));
}
}
exports.HoogleWebView = HoogleWebView;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hoogle-web-view.js","sourceRoot":"","sources":["../src/hoogle-web-view.tsx"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable: jsx-no-multiline-js\nimport { CompositeDisposable } from 'atom'\nimport type { WebviewTag } from 'electron'\nimport * as etch from 'etch'\n\nexport interface IProps extends JSX.Props {\n  url?: string\n}\n\ntype ElementClass = JSX.ElementClass\n\nexport class HoogleWebView implements ElementClass {\n  private disposables = new CompositeDisposable()\n  private zoomFactor = 100\n  private refs!: {\n    webView?: WebviewTag\n  }\n  private canShowWebview = false\n  constructor(public props: IProps = {}) {\n    etch.initialize(this)\n    // Create message element\n\n    this.disposables.add(\n      atom.config.observe(\n        'ide-haskell-hoogle.webZoomFactor',\n        (zoomFactor: number) => {\n          this.zoomFactor = zoomFactor\n          // tslint:disable-next-line: no-floating-promises\n          etch.update(this)\n        },\n      ),\n    )\n    this.canShowWebview = atom.packages.hasActivatedInitialPackages()\n    if (!this.canShowWebview) {\n      const disp = atom.packages.onDidActivateInitialPackages(() => {\n        disp.dispose()\n        this.canShowWebview = true\n        // tslint:disable-next-line: no-floating-promises\n        etch.update(this)\n      })\n    }\n  }\n\n  public render() {\n    return (\n      <div class=\"ide-haskell-hoogle\">\n        <div class=\"ide-haskell-hoogle-web-navbar btn-group\">\n          <button\n            class=\"btn btn-default btn-back\"\n            on={{\n              click: () => {\n                this.refs.webView &&\n                  atom.commands.dispatch(\n                    this.refs.webView,\n                    'ide-haskell-hoogle:web-go-back',\n                  )\n              },\n            }}\n          />\n          <button\n            class=\"btn btn-default btn-forward\"\n            on={{\n              click: () => {\n                this.refs.webView &&\n                  atom.commands.dispatch(\n                    this.refs.webView,\n                    'ide-haskell-hoogle:web-go-forward',\n                  )\n              },\n            }}\n          />\n        </div>\n        {this.webview()}\n      </div>\n    )\n  }\n\n  public async update(props: IProps) {\n    if (this.props.url !== props.url) {\n      this.props.url = props.url\n      // this.refs.webView\n      // && props.url\n      // && this.refs.webView.loadURL(props.url)\n    }\n    return etch.update(this)\n  }\n\n  public getURI() {\n    return `ide-haskell://hoogle/web/${this.props.url ?? ''}`\n  }\n\n  public getTitle() {\n    return 'Hoogle web'\n  }\n\n  public destroy() {\n    this.disposables.dispose()\n    // tslint:disable-next-line:no-floating-promises\n    etch.destroy(this)\n  }\n\n  public serialize(): IProps & { deserializer: string } {\n    return {\n      ...this.props,\n      deserializer: 'HoogleWebView',\n    }\n  }\n\n  private setZoom = () => {\n    this.refs.webView && this.refs.webView.setZoomFactor(this.zoomFactor / 100)\n  }\n\n  private didNavigate = ({ url }: { url: string }) => {\n    this.props.url = url\n  }\n\n  private webview() {\n    // tslint:disable-next-line: no-null-keyword\n    if (!this.canShowWebview) return null\n    return (\n      <webview\n        ref=\"webView\"\n        class=\"ide-haskell-hoogle-web native-key-bindings\"\n        src={this.props.url}\n        tabIndex=\"-1\"\n        on={{\n          'dom-ready': this.setZoom,\n          'did-navigate': this.didNavigate,\n          'did-navigate-in-page': this.didNavigate,\n        }}\n      />\n    )\n  }\n}\n"]}