Socket
Socket
Sign inDemoInstall

atom-ide-base

Package Overview
Dependencies
20
Maintainers
1
Versions
38
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.10.0 to 1.11.0

commons-ui/MarkdownRenderer.d.ts

2

commons-ui/float-pane/FloatPane.js

@@ -225,2 +225,2 @@ "use strict";

exports.PinnedDatatip = PinnedDatatip;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FloatPane.js","sourceRoot":"","sources":["../../src-commons-ui/float-pane/FloatPane.jsx"],"names":[],"mappings":"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","sourcesContent":["import type { Datatip, PinnedDatatipPosition } from \"./types\"\n\ntype Position = {\n  x: number,\n  y: number,\n}\n\nimport * as React from \"react\"\nimport ReactDOM from \"react-dom\"\nimport { Observable } from \"rxjs\"\nimport invariant from \"assert\"\nimport classnames from \"classnames\"\nimport Disposable from \"atom\"\n\nimport { ContentView, DATATIP_ACTIONS } from \"./ContentView\"\nimport isScrollable from \"./isScrollable\"\n\nconst LINE_END_MARGIN = 20\n\nlet _mouseMove$\nfunction documentMouseMove$(): Observable<MouseEvent> {\n  if (_mouseMove$ == null) {\n    _mouseMove$ = Observable.fromEvent(document, \"mousemove\")\n  }\n  return _mouseMove$\n}\n\nlet _mouseUp$\nfunction documentMouseUp$(): Observable<MouseEvent> {\n  if (_mouseUp$ == null) {\n    _mouseUp$ = Observable.fromEvent(document, \"mouseup\")\n  }\n  return _mouseUp$\n}\n\nexport type PinnedDatatipParams = {\n  onDispose: (pinnedDatatip: PinnedDatatip) => void,\n  hideDataTips: () => void,\n  // Defaults to 'end-of-line'.\n  position?: PinnedDatatipPosition,\n  // Defaults to true.\n  showRangeHighlight?: boolean,\n}\n\nexport class PinnedDatatip {\n  _boundDispose: Function\n  _boundHandleMouseDown: Function\n  _boundHandleMouseEnter: Function\n  _boundHandleMouseLeave: Function\n  _boundHandleCapturedClick: Function\n  _mouseUpTimeout: ?TimeoutID\n  _hostElement: HTMLElement\n  _marker: ?atom$Marker\n  _rangeDecoration: ?atom$Decoration\n  _mouseSubscription: ?rxjs$ISubscription\n  _subscriptions: Disposable\n  _datatip: Datatip\n  _editor: TextEditor\n  _hostElement: HTMLElement\n  _boundDispose: Function\n  _dragOrigin: ?Position\n  _isDragging: boolean\n  _offset: Position\n  _isHovering: boolean\n  _checkedScrollable: boolean\n  _isScrollable: boolean\n  _hideDataTips: () => void\n  _position: PinnedDatatipPosition\n  _showRangeHighlight: boolean\n\n  constructor(datatip: Datatip, editor: TextEditor, params: PinnedDatatipParams) {\n    this._subscriptions = new Disposable()\n    this._subscriptions.add(new Disposable(() => params.onDispose(this)))\n    this._datatip = datatip\n    this._editor = editor\n    this._marker = null\n    this._rangeDecoration = null\n    this._hostElement = document.createElement(\"div\")\n    this._hostElement.className = \"datatip-element\"\n    this._boundDispose = this.dispose.bind(this)\n    this._boundHandleMouseDown = this.handleMouseDown.bind(this)\n    this._boundHandleMouseEnter = this.handleMouseEnter.bind(this)\n    this._boundHandleMouseLeave = this.handleMouseLeave.bind(this)\n    this._boundHandleCapturedClick = this.handleCapturedClick.bind(this)\n    this._checkedScrollable = false\n    this._isScrollable = false\n\n    this._subscriptions.add(\n      Observable.fromEvent(this._hostElement, \"wheel\").subscribe((e) => {\n        if (!this._checkedScrollable) {\n          this._isScrollable = isScrollable(this._hostElement, e)\n          this._checkedScrollable = true\n        }\n        if (this._isScrollable) {\n          e.stopPropagation()\n        }\n      })\n    )\n    this._hostElement.addEventListener(\"mouseenter\", this._boundHandleMouseEnter)\n    this._hostElement.addEventListener(\"mouseleave\", this._boundHandleMouseLeave)\n    this._subscriptions.add(\n      new Disposable(() => {\n        this._hostElement.removeEventListener(\"mouseenter\", this._boundHandleMouseEnter)\n        this._hostElement.removeEventListener(\"mouseleave\", this._boundHandleMouseLeave)\n      })\n    )\n    this._mouseUpTimeout = null\n    this._offset = { x: 0, y: 0 }\n    this._isDragging = false\n    this._dragOrigin = null\n    this._isHovering = false\n    this._hideDataTips = params.hideDataTips\n    this._position = params.position == null ? \"end-of-line\" : params.position\n    this._showRangeHighlight = params.showRangeHighlight == null ? true : params.showRangeHighlight\n    this.render()\n  }\n\n  handleMouseEnter(event: MouseEvent): void {\n    this._isHovering = true\n    this._hideDataTips()\n  }\n\n  handleMouseLeave(event: MouseEvent): void {\n    this._isHovering = false\n  }\n\n  isHovering(): boolean {\n    return this._isHovering\n  }\n\n  handleGlobalMouseMove(event: Event): void {\n    const evt: MouseEvent = (event: any)\n    const { _dragOrigin } = this\n    invariant(_dragOrigin)\n    this._isDragging = true\n    this._offset = {\n      x: evt.clientX - _dragOrigin.x,\n      y: evt.clientY - _dragOrigin.y,\n    }\n    this.render()\n  }\n\n  handleGlobalMouseUp(): void {\n    // If the datatip was moved, push the effects of mouseUp to the next tick,\n    // in order to allow cancellation of captured events (e.g. clicks on child components).\n    this._mouseUpTimeout = setTimeout(() => {\n      this._isDragging = false\n      this._dragOrigin = null\n      this._mouseUpTimeout = null\n      this._ensureMouseSubscriptionDisposed()\n      this.render()\n    }, 0)\n  }\n\n  _ensureMouseSubscriptionDisposed(): void {\n    if (this._mouseSubscription != null) {\n      this._mouseSubscription.unsubscribe()\n      this._mouseSubscription = null\n    }\n  }\n\n  handleMouseDown(event: Event): void {\n    const evt: MouseEvent = (event: any)\n    this._dragOrigin = {\n      x: evt.clientX - this._offset.x,\n      y: evt.clientY - this._offset.y,\n    }\n    this._ensureMouseSubscriptionDisposed()\n    this._mouseSubscription = documentMouseMove$()\n      .takeUntil(documentMouseUp$())\n      .subscribe(\n        (e: MouseEvent) => {\n          this.handleGlobalMouseMove(e)\n        },\n        (error: any) => {},\n        () => {\n          this.handleGlobalMouseUp()\n        }\n      )\n  }\n\n  handleCapturedClick(event: SyntheticEvent<>): void {\n    if (this._isDragging) {\n      event.stopPropagation()\n    } else {\n      // Have to re-check scrolling because the datatip size may have changed.\n      this._checkedScrollable = false\n    }\n  }\n\n  // Update the position of the pinned datatip.\n  _updateHostElementPosition(): void {\n    const { _editor, _datatip, _hostElement, _offset, _position } = this\n    const { range } = _datatip\n    _hostElement.style.display = \"block\"\n    switch (_position) {\n      case \"end-of-line\":\n        const charWidth = _editor.getDefaultCharWidth()\n        const lineLength = _editor.getBuffer().getLines()[range.start.row].length\n        _hostElement.style.top = -_editor.getLineHeightInPixels() + _offset.y + \"px\"\n        _hostElement.style.left = (lineLength - range.end.column) * charWidth + LINE_END_MARGIN + _offset.x + \"px\"\n        break\n      case \"above-range\":\n        _hostElement.style.bottom = _editor.getLineHeightInPixels() + _hostElement.clientHeight - _offset.y + \"px\"\n        _hostElement.style.left = _offset.x + \"px\"\n        break\n      default:\n        ;(_position: empty)\n        throw new Error(`Unexpected PinnedDatatip position: ${this._position}`)\n    }\n  }\n\n  async render(): Promise<void> {\n    const { _editor, _datatip, _hostElement, _isDragging, _isHovering } = this\n\n    let rangeClassname = \"datatip-highlight-region\"\n    if (_isHovering) {\n      rangeClassname += \" datatip-highlight-region-active\"\n    }\n\n    if (this._marker == null) {\n      const marker: atom$Marker = _editor.markBufferRange(_datatip.range, {\n        invalidate: \"never\",\n      })\n      this._marker = marker\n      _editor.decorateMarker(marker, {\n        type: \"overlay\",\n        position: \"head\",\n        class: \"datatip-pinned-overlay\",\n        item: this._hostElement,\n        // above-range datatips currently assume that the overlay is below.\n        avoidOverflow: this._position !== \"above-range\",\n      })\n      if (this._showRangeHighlight) {\n        this._rangeDecoration = _editor.decorateMarker(marker, {\n          type: \"highlight\",\n          class: rangeClassname,\n        })\n      }\n      await _editor.getElement().getNextUpdatePromise()\n      // Guard against disposals during the await.\n      if (marker.isDestroyed() || _editor.isDestroyed()) {\n        return\n      }\n    } else if (this._rangeDecoration != null) {\n      this._rangeDecoration.setProperties({\n        type: \"highlight\",\n        class: rangeClassname,\n      })\n    }\n\n    ReactDOM.render(\n      <ContentView\n        action={DATATIP_ACTIONS.CLOSE}\n        actionTitle=\"Close this datatip\"\n        className={classnames(_isDragging ? \"datatip-dragging\" : \"\", \"datatip-pinned\")}\n        datatip={_datatip}\n        onActionClick={this._boundDispose}\n        onMouseDown={this._boundHandleMouseDown}\n        onClickCapture={this._boundHandleCapturedClick}\n      />,\n      _hostElement\n    )\n    this._updateHostElementPosition()\n  }\n\n  dispose(): void {\n    if (this._mouseUpTimeout != null) {\n      clearTimeout(this._mouseUpTimeout)\n    }\n    if (this._marker != null) {\n      this._marker.destroy()\n    }\n    if (this._mouseSubscription != null) {\n      this._mouseSubscription.unsubscribe()\n    }\n    ReactDOM.unmountComponentAtNode(this._hostElement)\n    this._hostElement.remove()\n    this._subscriptions.dispose()\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FloatPane.js","sourceRoot":"","sources":["../../src-commons-ui/float-pane/FloatPane.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Datatip, PinnedDatatipPosition } from \"./types\"\r\n\r\ntype Position = {\r\n  x: number,\r\n  y: number,\r\n}\r\n\r\nimport * as React from \"react\"\r\nimport ReactDOM from \"react-dom\"\r\nimport { Observable } from \"rxjs\"\r\nimport invariant from \"assert\"\r\nimport classnames from \"classnames\"\r\nimport Disposable from \"atom\"\r\n\r\nimport { ContentView, DATATIP_ACTIONS } from \"./ContentView\"\r\nimport isScrollable from \"./isScrollable\"\r\n\r\nconst LINE_END_MARGIN = 20\r\n\r\nlet _mouseMove$\r\nfunction documentMouseMove$(): Observable<MouseEvent> {\r\n  if (_mouseMove$ == null) {\r\n    _mouseMove$ = Observable.fromEvent(document, \"mousemove\")\r\n  }\r\n  return _mouseMove$\r\n}\r\n\r\nlet _mouseUp$\r\nfunction documentMouseUp$(): Observable<MouseEvent> {\r\n  if (_mouseUp$ == null) {\r\n    _mouseUp$ = Observable.fromEvent(document, \"mouseup\")\r\n  }\r\n  return _mouseUp$\r\n}\r\n\r\nexport type PinnedDatatipParams = {\r\n  onDispose: (pinnedDatatip: PinnedDatatip) => void,\r\n  hideDataTips: () => void,\r\n  // Defaults to 'end-of-line'.\r\n  position?: PinnedDatatipPosition,\r\n  // Defaults to true.\r\n  showRangeHighlight?: boolean,\r\n}\r\n\r\nexport class PinnedDatatip {\r\n  _boundDispose: Function\r\n  _boundHandleMouseDown: Function\r\n  _boundHandleMouseEnter: Function\r\n  _boundHandleMouseLeave: Function\r\n  _boundHandleCapturedClick: Function\r\n  _mouseUpTimeout: ?TimeoutID\r\n  _hostElement: HTMLElement\r\n  _marker: ?atom$Marker\r\n  _rangeDecoration: ?atom$Decoration\r\n  _mouseSubscription: ?rxjs$ISubscription\r\n  _subscriptions: Disposable\r\n  _datatip: Datatip\r\n  _editor: TextEditor\r\n  _hostElement: HTMLElement\r\n  _boundDispose: Function\r\n  _dragOrigin: ?Position\r\n  _isDragging: boolean\r\n  _offset: Position\r\n  _isHovering: boolean\r\n  _checkedScrollable: boolean\r\n  _isScrollable: boolean\r\n  _hideDataTips: () => void\r\n  _position: PinnedDatatipPosition\r\n  _showRangeHighlight: boolean\r\n\r\n  constructor(datatip: Datatip, editor: TextEditor, params: PinnedDatatipParams) {\r\n    this._subscriptions = new Disposable()\r\n    this._subscriptions.add(new Disposable(() => params.onDispose(this)))\r\n    this._datatip = datatip\r\n    this._editor = editor\r\n    this._marker = null\r\n    this._rangeDecoration = null\r\n    this._hostElement = document.createElement(\"div\")\r\n    this._hostElement.className = \"datatip-element\"\r\n    this._boundDispose = this.dispose.bind(this)\r\n    this._boundHandleMouseDown = this.handleMouseDown.bind(this)\r\n    this._boundHandleMouseEnter = this.handleMouseEnter.bind(this)\r\n    this._boundHandleMouseLeave = this.handleMouseLeave.bind(this)\r\n    this._boundHandleCapturedClick = this.handleCapturedClick.bind(this)\r\n    this._checkedScrollable = false\r\n    this._isScrollable = false\r\n\r\n    this._subscriptions.add(\r\n      Observable.fromEvent(this._hostElement, \"wheel\").subscribe((e) => {\r\n        if (!this._checkedScrollable) {\r\n          this._isScrollable = isScrollable(this._hostElement, e)\r\n          this._checkedScrollable = true\r\n        }\r\n        if (this._isScrollable) {\r\n          e.stopPropagation()\r\n        }\r\n      })\r\n    )\r\n    this._hostElement.addEventListener(\"mouseenter\", this._boundHandleMouseEnter)\r\n    this._hostElement.addEventListener(\"mouseleave\", this._boundHandleMouseLeave)\r\n    this._subscriptions.add(\r\n      new Disposable(() => {\r\n        this._hostElement.removeEventListener(\"mouseenter\", this._boundHandleMouseEnter)\r\n        this._hostElement.removeEventListener(\"mouseleave\", this._boundHandleMouseLeave)\r\n      })\r\n    )\r\n    this._mouseUpTimeout = null\r\n    this._offset = { x: 0, y: 0 }\r\n    this._isDragging = false\r\n    this._dragOrigin = null\r\n    this._isHovering = false\r\n    this._hideDataTips = params.hideDataTips\r\n    this._position = params.position == null ? \"end-of-line\" : params.position\r\n    this._showRangeHighlight = params.showRangeHighlight == null ? true : params.showRangeHighlight\r\n    this.render()\r\n  }\r\n\r\n  handleMouseEnter(event: MouseEvent): void {\r\n    this._isHovering = true\r\n    this._hideDataTips()\r\n  }\r\n\r\n  handleMouseLeave(event: MouseEvent): void {\r\n    this._isHovering = false\r\n  }\r\n\r\n  isHovering(): boolean {\r\n    return this._isHovering\r\n  }\r\n\r\n  handleGlobalMouseMove(event: Event): void {\r\n    const evt: MouseEvent = (event: any)\r\n    const { _dragOrigin } = this\r\n    invariant(_dragOrigin)\r\n    this._isDragging = true\r\n    this._offset = {\r\n      x: evt.clientX - _dragOrigin.x,\r\n      y: evt.clientY - _dragOrigin.y,\r\n    }\r\n    this.render()\r\n  }\r\n\r\n  handleGlobalMouseUp(): void {\r\n    // If the datatip was moved, push the effects of mouseUp to the next tick,\r\n    // in order to allow cancellation of captured events (e.g. clicks on child components).\r\n    this._mouseUpTimeout = setTimeout(() => {\r\n      this._isDragging = false\r\n      this._dragOrigin = null\r\n      this._mouseUpTimeout = null\r\n      this._ensureMouseSubscriptionDisposed()\r\n      this.render()\r\n    }, 0)\r\n  }\r\n\r\n  _ensureMouseSubscriptionDisposed(): void {\r\n    if (this._mouseSubscription != null) {\r\n      this._mouseSubscription.unsubscribe()\r\n      this._mouseSubscription = null\r\n    }\r\n  }\r\n\r\n  handleMouseDown(event: Event): void {\r\n    const evt: MouseEvent = (event: any)\r\n    this._dragOrigin = {\r\n      x: evt.clientX - this._offset.x,\r\n      y: evt.clientY - this._offset.y,\r\n    }\r\n    this._ensureMouseSubscriptionDisposed()\r\n    this._mouseSubscription = documentMouseMove$()\r\n      .takeUntil(documentMouseUp$())\r\n      .subscribe(\r\n        (e: MouseEvent) => {\r\n          this.handleGlobalMouseMove(e)\r\n        },\r\n        (error: any) => {},\r\n        () => {\r\n          this.handleGlobalMouseUp()\r\n        }\r\n      )\r\n  }\r\n\r\n  handleCapturedClick(event: SyntheticEvent<>): void {\r\n    if (this._isDragging) {\r\n      event.stopPropagation()\r\n    } else {\r\n      // Have to re-check scrolling because the datatip size may have changed.\r\n      this._checkedScrollable = false\r\n    }\r\n  }\r\n\r\n  // Update the position of the pinned datatip.\r\n  _updateHostElementPosition(): void {\r\n    const { _editor, _datatip, _hostElement, _offset, _position } = this\r\n    const { range } = _datatip\r\n    _hostElement.style.display = \"block\"\r\n    switch (_position) {\r\n      case \"end-of-line\":\r\n        const charWidth = _editor.getDefaultCharWidth()\r\n        const lineLength = _editor.getBuffer().getLines()[range.start.row].length\r\n        _hostElement.style.top = -_editor.getLineHeightInPixels() + _offset.y + \"px\"\r\n        _hostElement.style.left = (lineLength - range.end.column) * charWidth + LINE_END_MARGIN + _offset.x + \"px\"\r\n        break\r\n      case \"above-range\":\r\n        _hostElement.style.bottom = _editor.getLineHeightInPixels() + _hostElement.clientHeight - _offset.y + \"px\"\r\n        _hostElement.style.left = _offset.x + \"px\"\r\n        break\r\n      default:\r\n        ;(_position: empty)\r\n        throw new Error(`Unexpected PinnedDatatip position: ${this._position}`)\r\n    }\r\n  }\r\n\r\n  async render(): Promise<void> {\r\n    const { _editor, _datatip, _hostElement, _isDragging, _isHovering } = this\r\n\r\n    let rangeClassname = \"datatip-highlight-region\"\r\n    if (_isHovering) {\r\n      rangeClassname += \" datatip-highlight-region-active\"\r\n    }\r\n\r\n    if (this._marker == null) {\r\n      const marker: atom$Marker = _editor.markBufferRange(_datatip.range, {\r\n        invalidate: \"never\",\r\n      })\r\n      this._marker = marker\r\n      _editor.decorateMarker(marker, {\r\n        type: \"overlay\",\r\n        position: \"head\",\r\n        class: \"datatip-pinned-overlay\",\r\n        item: this._hostElement,\r\n        // above-range datatips currently assume that the overlay is below.\r\n        avoidOverflow: this._position !== \"above-range\",\r\n      })\r\n      if (this._showRangeHighlight) {\r\n        this._rangeDecoration = _editor.decorateMarker(marker, {\r\n          type: \"highlight\",\r\n          class: rangeClassname,\r\n        })\r\n      }\r\n      await _editor.getElement().getNextUpdatePromise()\r\n      // Guard against disposals during the await.\r\n      if (marker.isDestroyed() || _editor.isDestroyed()) {\r\n        return\r\n      }\r\n    } else if (this._rangeDecoration != null) {\r\n      this._rangeDecoration.setProperties({\r\n        type: \"highlight\",\r\n        class: rangeClassname,\r\n      })\r\n    }\r\n\r\n    ReactDOM.render(\r\n      <ContentView\r\n        action={DATATIP_ACTIONS.CLOSE}\r\n        actionTitle=\"Close this datatip\"\r\n        className={classnames(_isDragging ? \"datatip-dragging\" : \"\", \"datatip-pinned\")}\r\n        datatip={_datatip}\r\n        onActionClick={this._boundDispose}\r\n        onMouseDown={this._boundHandleMouseDown}\r\n        onClickCapture={this._boundHandleCapturedClick}\r\n      />,\r\n      _hostElement\r\n    )\r\n    this._updateHostElementPosition()\r\n  }\r\n\r\n  dispose(): void {\r\n    if (this._mouseUpTimeout != null) {\r\n      clearTimeout(this._mouseUpTimeout)\r\n    }\r\n    if (this._marker != null) {\r\n      this._marker.destroy()\r\n    }\r\n    if (this._mouseSubscription != null) {\r\n      this._mouseSubscription.unsubscribe()\r\n    }\r\n    ReactDOM.unmountComponentAtNode(this._hostElement)\r\n    this._hostElement.remove()\r\n    this._subscriptions.dispose()\r\n  }\r\n}\r\n"]}

@@ -0,13 +1,15 @@

import * as React from "react";
import { MarkdownService } from "../../types-packages/main";
export declare class HTMLView {
rootElement: HTMLElement;
constructor({ html, containerClassName, contentClassName, }: {
html: string;
containerClassName: string;
contentClassName: string;
});
destroy(): void;
get element(): HTMLElement;
onMouseWheel(evt: WheelEvent): void;
interface Props {
html: string;
containerClassName: string;
contentClassName: string;
}
export declare function getDocumentationHtml(markdownTexts: Array<String>, grammarName: string, renderer: MarkdownService): Promise<string | null>;
interface State {
}
export declare class HTMLView extends React.Component<Props, State> {
render(): JSX.Element;
onMouseWheel(evt: React.WheelEvent): void;
}
export declare function getDocumentationHtml(markdownTexts: Array<String>, grammarName: string, renderer?: MarkdownService): Promise<string | null>;
export {};
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {

@@ -7,22 +26,12 @@ return (mod && mod.__esModule) ? mod : { "default": mod };

exports.getDocumentationHtml = exports.HTMLView = void 0;
const React = __importStar(require("react"));
const dompurify_1 = __importDefault(require("dompurify"));
class HTMLView {
constructor({ html, containerClassName, contentClassName, }) {
this.rootElement = document.createElement("div");
this.rootElement.className = containerClassName;
this.rootElement.addEventListener("wheel", this.onMouseWheel, {
passive: true,
});
if (html) {
const innerHTML = dompurify_1.default.sanitize(html);
this.rootElement.innerHTML = `
<div className='${contentClassName}'>${innerHTML}</div>`;
}
const MarkdownRenderer_1 = require("../MarkdownRenderer");
class HTMLView extends React.Component {
render() {
return (React.createElement("div", { className: this.props.containerClassName, onWheel: (e) => this.onMouseWheel(e) },
React.createElement("div", { className: this.props.contentClassName, dangerouslySetInnerHTML: {
__html: dompurify_1.default.sanitize(this.props.html),
} })));
}
destroy() {
this.rootElement.removeEventListener("wheel", this.onMouseWheel);
}
get element() {
return this.rootElement;
}
onMouseWheel(evt) {

@@ -36,3 +45,9 @@ evt.stopPropagation();

const markdownText = markdownTexts.join("\r\n");
return renderer.render(markdownText, grammarName);
if (renderer) {
return renderer.render(markdownText, grammarName);
}
else {
const render = await MarkdownRenderer_1.getMarkdownRenderer();
return render(markdownText, grammarName);
}
}

@@ -42,2 +57,2 @@ return null;

exports.getDocumentationHtml = getDocumentationHtml;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSFRNTFZpZXcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMtY29tbW9ucy11aS9mbG9hdC1wYW5lL0hUTUxWaWV3LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUdBLDBEQUFpQztBQU1qQyxNQUFhLFFBQVE7SUFPbkIsWUFBWSxFQUNWLElBQUksRUFDSixrQkFBa0IsRUFDbEIsZ0JBQWdCLEdBS2pCO1FBQ0MsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQ2hELElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxHQUFHLGtCQUFrQixDQUFBO1FBQy9DLElBQUksQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDNUQsT0FBTyxFQUFFLElBQUk7U0FDZCxDQUFDLENBQUE7UUFDRixJQUFJLElBQUksRUFBRTtZQUNSLE1BQU0sU0FBUyxHQUFHLG1CQUFTLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFBO1lBQzFDLElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxHQUFHOzBCQUNULGdCQUFnQixLQUFLLFNBQVMsUUFBUSxDQUFBO1NBQzNEO0lBQ0gsQ0FBQztJQUtELE9BQU87UUFDTCxJQUFJLENBQUMsV0FBVyxDQUFDLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUE7SUFDbEUsQ0FBQztJQU1ELElBQUksT0FBTztRQUNULE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQTtJQUN6QixDQUFDO0lBTUQsWUFBWSxDQUFDLEdBQWU7UUFDMUIsR0FBRyxDQUFDLGVBQWUsRUFBRSxDQUFBO0lBQ3ZCLENBQUM7Q0FDRjtBQWxERCw0QkFrREM7QUFTTSxLQUFLLFVBQVUsb0JBQW9CLENBQ3hDLGFBQTRCLEVBQzVCLFdBQW1CLEVBQ25CLFFBQXlCO0lBRXpCLElBQUksYUFBYSxLQUFLLFNBQVMsSUFBSSxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtRQUMzRCxNQUFNLFlBQVksR0FBRyxhQUFhLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFBO1FBQy9DLE9BQU8sUUFBUSxDQUFDLE1BQU0sQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDLENBQUE7S0FDbEQ7SUFDRCxPQUFPLElBQUksQ0FBQTtBQUNiLENBQUM7QUFWRCxvREFVQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBhIHJlZmVyZW5jZSB0byB0aGUgRE9NcHVyaWZ5IGZ1bmN0aW9uIHRvIG1ha2Ugc2FmZSBIVE1MIHN0cmluZ3NcclxuICovXHJcbmltcG9ydCBET01QdXJpZnkgZnJvbSBcImRvbXB1cmlmeVwiXHJcbmltcG9ydCB7IE1hcmtkb3duU2VydmljZSB9IGZyb20gXCIuLi8uLi90eXBlcy1wYWNrYWdlcy9tYWluXCJcclxuXHJcbi8qKlxyXG4gKiBhbiBldGNoIGNvbXBvbmVudCB0aGF0IGNhbiBob3N0IGFscmVhZHkgcHJlcGFyZWQgSFRNTCB0ZXh0XHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgSFRNTFZpZXcge1xyXG4gIHJvb3RFbGVtZW50OiBIVE1MRWxlbWVudFxyXG5cclxuICAvKipcclxuICAgKiBjcmVhdGVzIHRoZSBIVE1MIHZpZXcgY29tcG9uZW50IGFuZCBoYW5kcyBvdmVyIHRoZSBIVE1MIHRvIGVtYmVkZFxyXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBodG1sIHRoZSBIVE1MIHN0cmluZyB0byBlbWJlZGQgaW50byB0aGUgSFRNTCB2aWV3IGNvbXBvbmVudFxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKHtcclxuICAgIGh0bWwsXHJcbiAgICBjb250YWluZXJDbGFzc05hbWUsXHJcbiAgICBjb250ZW50Q2xhc3NOYW1lLFxyXG4gIH06IHtcclxuICAgIGh0bWw6IHN0cmluZ1xyXG4gICAgY29udGFpbmVyQ2xhc3NOYW1lOiBzdHJpbmdcclxuICAgIGNvbnRlbnRDbGFzc05hbWU6IHN0cmluZ1xyXG4gIH0pIHtcclxuICAgIHRoaXMucm9vdEVsZW1lbnQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiZGl2XCIpXHJcbiAgICB0aGlzLnJvb3RFbGVtZW50LmNsYXNzTmFtZSA9IGNvbnRhaW5lckNsYXNzTmFtZVxyXG4gICAgdGhpcy5yb290RWxlbWVudC5hZGRFdmVudExpc3RlbmVyKFwid2hlZWxcIiwgdGhpcy5vbk1vdXNlV2hlZWwsIHtcclxuICAgICAgcGFzc2l2ZTogdHJ1ZSxcclxuICAgIH0pXHJcbiAgICBpZiAoaHRtbCkge1xyXG4gICAgICBjb25zdCBpbm5lckhUTUwgPSBET01QdXJpZnkuc2FuaXRpemUoaHRtbClcclxuICAgICAgdGhpcy5yb290RWxlbWVudC5pbm5lckhUTUwgPSBgXHJcbiAgICAgICAgPGRpdiBjbGFzc05hbWU9JyR7Y29udGVudENsYXNzTmFtZX0nPiR7aW5uZXJIVE1MfTwvZGl2PmBcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIGNsZWFudXAgdGhlIEhUTUwgdmlldyBjb21wb25lbnRcclxuICAgKi9cclxuICBkZXN0cm95KCkge1xyXG4gICAgdGhpcy5yb290RWxlbWVudC5yZW1vdmVFdmVudExpc3RlbmVyKFwid2hlZWxcIiwgdGhpcy5vbk1vdXNlV2hlZWwpXHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiByZXR1cm5zIHRoZSByb290IGVsZW1lbnQgb2YgdGhlIEhUTUwgdmlldyBjb21wb25lbnRcclxuICAgKiBAcmV0dXJuIHtIVE1MRWxlbWVudH0gdGhlIHJvb3QgZWxlbWVudCB3cmFwcGluZyB0aGUgSFRNTCBjb250ZW50XHJcbiAgICovXHJcbiAgZ2V0IGVsZW1lbnQoKTogSFRNTEVsZW1lbnQge1xyXG4gICAgcmV0dXJuIHRoaXMucm9vdEVsZW1lbnRcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIGhhbmRsZXMgdGhlIG1vdXNlIHdoZWVsIGV2ZW50IHRvIGVuYWJsZSBzY3JvbGxpbmcgb3ZlciBsb25nIHRleHRcclxuICAgKiBAcGFyYW0gIHtXaGVlbEV2ZW50fSBldnQgdGhlIG1vdXNlIHdoZWVsIGV2ZW50IGJlaW5nIHRyaWdnZXJlZFxyXG4gICAqL1xyXG4gIG9uTW91c2VXaGVlbChldnQ6IFdoZWVsRXZlbnQpIHtcclxuICAgIGV2dC5zdG9wUHJvcGFnYXRpb24oKVxyXG4gIH1cclxufVxyXG5cclxuLyoqXHJcbiAqIGNvbnZlcnQgdGhlIG1hcmtkb3duIGRvY3VtZW50YXRpb24gdG8gSFRNTFxyXG4gKiBAcGFyYW0gbWFya2Rvd25UZXh0cyB0aGUgZG9jdW1lbnRhdGlvbiB0ZXh0IGluIG1hcmtkb3duIGZvcm1hdCB0byBiZSBjb252ZXJ0ZWRcclxuICogQHBhcmFtIGdyYW1tYXJOYW1lICB0aGUgZGVmYXVsdCBncmFtbWFyIHVzZWQgZm9yIGVtYmVkZGVkIGNvZGUgc2FtcGxlc1xyXG4gKiBAcGFyYW0gcmVuZGVyZXIgbWFya2Rvd24gc2VydmljZSB0byBiZSB1c2VkIGZvciByZW5kZXJpbmdcclxuICogQHJldHVybiBhIHByb21pc2Ugb2JqZWN0IHRvIHRyYWNrIHRoZSBhc3luY2hyb25vdXMgb3BlcmF0aW9uXHJcbiAqL1xyXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0RG9jdW1lbnRhdGlvbkh0bWwoXHJcbiAgbWFya2Rvd25UZXh0czogQXJyYXk8U3RyaW5nPixcclxuICBncmFtbWFyTmFtZTogc3RyaW5nLFxyXG4gIHJlbmRlcmVyOiBNYXJrZG93blNlcnZpY2VcclxuKTogUHJvbWlzZTxzdHJpbmcgfCBudWxsPiB7XHJcbiAgaWYgKG1hcmtkb3duVGV4dHMgIT09IHVuZGVmaW5lZCAmJiBtYXJrZG93blRleHRzLmxlbmd0aCA+IDApIHtcclxuICAgIGNvbnN0IG1hcmtkb3duVGV4dCA9IG1hcmtkb3duVGV4dHMuam9pbihcIlxcclxcblwiKVxyXG4gICAgcmV0dXJuIHJlbmRlcmVyLnJlbmRlcihtYXJrZG93blRleHQsIGdyYW1tYXJOYW1lKVxyXG4gIH1cclxuICByZXR1cm4gbnVsbFxyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSFRNTFZpZXcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMtY29tbW9ucy11aS9mbG9hdC1wYW5lL0hUTUxWaWV3LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsNkNBQThCO0FBQzlCLDBEQUFpQztBQUVqQywwREFBeUQ7QUFhekQsTUFBYSxRQUFTLFNBQVEsS0FBSyxDQUFDLFNBQXVCO0lBQ3pELE1BQU07UUFDSixPQUFPLENBQ0wsNkJBQUssU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQztZQUNqRiw2QkFDRSxTQUFTLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsRUFDdEMsdUJBQXVCLEVBQUU7b0JBQ3ZCLE1BQU0sRUFBRSxtQkFBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQztpQkFDNUMsR0FDRCxDQUNFLENBQ1AsQ0FBQTtJQUNILENBQUM7SUFNRCxZQUFZLENBQUMsR0FBcUI7UUFDaEMsR0FBRyxDQUFDLGVBQWUsRUFBRSxDQUFBO0lBQ3ZCLENBQUM7Q0FDRjtBQXJCRCw0QkFxQkM7QUFTTSxLQUFLLFVBQVUsb0JBQW9CLENBQ3hDLGFBQTRCLEVBQzVCLFdBQW1CLEVBQ25CLFFBQTBCO0lBRTFCLElBQUksYUFBYSxLQUFLLFNBQVMsSUFBSSxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtRQUMzRCxNQUFNLFlBQVksR0FBRyxhQUFhLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFBO1FBQy9DLElBQUksUUFBUSxFQUFFO1lBQ1osT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUMsQ0FBQTtTQUNsRDthQUFNO1lBRUwsTUFBTSxNQUFNLEdBQUcsTUFBTSxzQ0FBbUIsRUFBRSxDQUFBO1lBQzFDLE9BQU8sTUFBTSxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUMsQ0FBQTtTQUN6QztLQUNGO0lBQ0QsT0FBTyxJQUFJLENBQUE7QUFDYixDQUFDO0FBaEJELG9EQWdCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gXCJyZWFjdFwiXHJcbmltcG9ydCBET01QdXJpZnkgZnJvbSBcImRvbXB1cmlmeVwiXHJcbmltcG9ydCB7IE1hcmtkb3duU2VydmljZSB9IGZyb20gXCIuLi8uLi90eXBlcy1wYWNrYWdlcy9tYWluXCJcclxuaW1wb3J0IHsgZ2V0TWFya2Rvd25SZW5kZXJlciB9IGZyb20gXCIuLi9NYXJrZG93blJlbmRlcmVyXCJcclxuXHJcbmludGVyZmFjZSBQcm9wcyB7XHJcbiAgaHRtbDogc3RyaW5nXHJcbiAgY29udGFpbmVyQ2xhc3NOYW1lOiBzdHJpbmdcclxuICBjb250ZW50Q2xhc3NOYW1lOiBzdHJpbmdcclxufVxyXG5cclxuaW50ZXJmYWNlIFN0YXRlIHt9XHJcblxyXG4vKipcclxuICogQSByZWFjdCBjb21wb25lbnQgdGhhdCBjYW4gaG9zdCBhbHJlYWR5IHByZXBhcmVkIEhUTUwgdGV4dCAoZW1iZWRzIEhUTUwpXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgSFRNTFZpZXcgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQ8UHJvcHMsIFN0YXRlPiB7XHJcbiAgcmVuZGVyKCkge1xyXG4gICAgcmV0dXJuIChcclxuICAgICAgPGRpdiBjbGFzc05hbWU9e3RoaXMucHJvcHMuY29udGFpbmVyQ2xhc3NOYW1lfSBvbldoZWVsPXsoZSkgPT4gdGhpcy5vbk1vdXNlV2hlZWwoZSl9PlxyXG4gICAgICAgIDxkaXZcclxuICAgICAgICAgIGNsYXNzTmFtZT17dGhpcy5wcm9wcy5jb250ZW50Q2xhc3NOYW1lfVxyXG4gICAgICAgICAgZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUw9e3tcclxuICAgICAgICAgICAgX19odG1sOiBET01QdXJpZnkuc2FuaXRpemUodGhpcy5wcm9wcy5odG1sKSxcclxuICAgICAgICAgIH19XHJcbiAgICAgICAgLz5cclxuICAgICAgPC9kaXY+XHJcbiAgICApXHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBoYW5kbGVzIHRoZSBtb3VzZSB3aGVlbCBldmVudCB0byBlbmFibGUgc2Nyb2xsaW5nIG92ZXIgbG9uZyB0ZXh0XHJcbiAgICogQHBhcmFtIGV2dCB0aGUgbW91c2Ugd2hlZWwgZXZlbnQgYmVpbmcgdHJpZ2dlcmVkXHJcbiAgICovXHJcbiAgb25Nb3VzZVdoZWVsKGV2dDogUmVhY3QuV2hlZWxFdmVudCkge1xyXG4gICAgZXZ0LnN0b3BQcm9wYWdhdGlvbigpXHJcbiAgfVxyXG59XHJcblxyXG4vKipcclxuICogY29udmVydCB0aGUgbWFya2Rvd24gZG9jdW1lbnRhdGlvbiB0byBIVE1MXHJcbiAqIEBwYXJhbSBtYXJrZG93blRleHRzIHRoZSBkb2N1bWVudGF0aW9uIHRleHQgaW4gbWFya2Rvd24gZm9ybWF0IHRvIGJlIGNvbnZlcnRlZFxyXG4gKiBAcGFyYW0gZ3JhbW1hck5hbWUgIHRoZSBkZWZhdWx0IGdyYW1tYXIgdXNlZCBmb3IgZW1iZWRkZWQgY29kZSBzYW1wbGVzXHJcbiAqIEBwYXJhbSByZW5kZXJlciBtYXJrZG93biBzZXJ2aWNlIHRvIGJlIHVzZWQgZm9yIHJlbmRlcmluZ1xyXG4gKiBAcmV0dXJuIGEgcHJvbWlzZSBvYmplY3QgdG8gdHJhY2sgdGhlIGFzeW5jaHJvbm91cyBvcGVyYXRpb25cclxuICovXHJcbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZXREb2N1bWVudGF0aW9uSHRtbChcclxuICBtYXJrZG93blRleHRzOiBBcnJheTxTdHJpbmc+LFxyXG4gIGdyYW1tYXJOYW1lOiBzdHJpbmcsXHJcbiAgcmVuZGVyZXI/OiBNYXJrZG93blNlcnZpY2VcclxuKTogUHJvbWlzZTxzdHJpbmcgfCBudWxsPiB7XHJcbiAgaWYgKG1hcmtkb3duVGV4dHMgIT09IHVuZGVmaW5lZCAmJiBtYXJrZG93blRleHRzLmxlbmd0aCA+IDApIHtcclxuICAgIGNvbnN0IG1hcmtkb3duVGV4dCA9IG1hcmtkb3duVGV4dHMuam9pbihcIlxcclxcblwiKVxyXG4gICAgaWYgKHJlbmRlcmVyKSB7XHJcbiAgICAgIHJldHVybiByZW5kZXJlci5yZW5kZXIobWFya2Rvd25UZXh0LCBncmFtbWFyTmFtZSlcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIC8vIFVzZSBidWlsdC1pbiBtYXJrZG93biByZW5kZXJlciB3aGVuIHRoZSBtYXJrZG93biBzZXJ2aWNlIGlzIG5vdCBhdmFpbGFibGVcclxuICAgICAgY29uc3QgcmVuZGVyID0gYXdhaXQgZ2V0TWFya2Rvd25SZW5kZXJlcigpXHJcbiAgICAgIHJldHVybiByZW5kZXIobWFya2Rvd25UZXh0LCBncmFtbWFyTmFtZSlcclxuICAgIH1cclxuICB9XHJcbiAgcmV0dXJuIG51bGxcclxufVxyXG4iXX0=

@@ -1,15 +0,12 @@

import type { ReactElement } from "react";
export declare class ReactView {
rootElement: HTMLElement;
children?: ReactElement;
childrenStatic?: string;
import * as React from "react";
interface Props {
component: () => React.ReactElement;
containerClassName: string;
contentClassName: string;
constructor({ component, containerClassName, contentClassName, }: {
component: () => ReactElement;
containerClassName: string;
contentClassName: string;
});
render(): HTMLElement;
get element(): HTMLElement;
}
interface State {
}
export declare class ReactView extends React.Component<Props, State> {
render(): JSX.Element;
}
export {};
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ReactView = void 0;
const server_1 = require("react-dom/server");
const dompurify_1 = __importDefault(require("dompurify"));
class ReactView {
constructor({ component, containerClassName, contentClassName, }) {
this.containerClassName = containerClassName;
this.contentClassName = contentClassName;
if (component) {
this.children = component();
}
this.render();
}
const React = __importStar(require("react"));
class ReactView extends React.Component {
render() {
this.rootElement = document.createElement("span");
this.rootElement.classList.add(this.containerClassName);
if (this.children) {
this.childrenStatic = dompurify_1.default.sanitize(server_1.renderToStaticMarkup(this.children));
this.rootElement.innerHTML = `
<div className="${this.contentClassName}">${this.childrenStatic}</div>
`;
let children = null;
if (this.props.component) {
children = React.createElement("div", { className: this.props.contentClassName }, this.props.component());
}
return this.rootElement;
return React.createElement("div", { className: this.props.containerClassName }, children);
}
get element() {
return this.rootElement;
}
}
exports.ReactView = ReactView;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVhY3RWaWV3LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjLWNvbW1vbnMtdWkvZmxvYXQtcGFuZS9SZWFjdFZpZXcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsNkNBQXVEO0FBTXZELDBEQUFpQztBQUtqQyxNQUFhLFNBQVM7SUFXcEIsWUFBWSxFQUNWLFNBQVMsRUFDVCxrQkFBa0IsRUFDbEIsZ0JBQWdCLEdBS2pCO1FBQ0MsSUFBSSxDQUFDLGtCQUFrQixHQUFHLGtCQUFrQixDQUFBO1FBQzVDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxnQkFBZ0IsQ0FBQTtRQUN4QyxJQUFJLFNBQVMsRUFBRTtZQUNiLElBQUksQ0FBQyxRQUFRLEdBQUcsU0FBUyxFQUFFLENBQUE7U0FDNUI7UUFDRCxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUE7SUFFZixDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQTtRQUNqRCxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUE7UUFDdkQsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxjQUFjLEdBQUcsbUJBQVMsQ0FBQyxRQUFRLENBQUMsNkJBQW9CLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUE7WUFDN0UsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLEdBQUc7NEJBQ1AsSUFBSSxDQUFDLGdCQUFnQixLQUFLLElBQUksQ0FBQyxjQUFjO09BQ2xFLENBQUE7U0FDRjtRQUNELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQTtJQUN6QixDQUFDO0lBTUQsSUFBSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFBO0lBQ3pCLENBQUM7Q0FDRjtBQWhERCw4QkFnREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyByZW5kZXJUb1N0YXRpY01hcmt1cCB9IGZyb20gXCJyZWFjdC1kb20vc2VydmVyXCJcclxuaW1wb3J0IHR5cGUgeyBSZWFjdEVsZW1lbnQgfSBmcm9tIFwicmVhY3RcIlxyXG5cclxuLyoqXHJcbiAqIGEgcmVmZXJlbmNlIHRvIHRoZSBET01wdXJpZnkgZnVuY3Rpb24gdG8gbWFrZSBzYWZlIEhUTUwgc3RyaW5nc1xyXG4gKi9cclxuaW1wb3J0IERPTVB1cmlmeSBmcm9tIFwiZG9tcHVyaWZ5XCJcclxuXHJcbi8qKlxyXG4gKiBhbiBldGNoIGNvbXBvbmVudCB0aGF0IGNhbiBob3N0IGFuIGV4dGVybmFsbHkgZ2l2ZW4gUmVhY3QgY29tcG9uZW50XHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgUmVhY3RWaWV3IHtcclxuICByb290RWxlbWVudDogSFRNTEVsZW1lbnRcclxuICBjaGlsZHJlbj86IFJlYWN0RWxlbWVudFxyXG4gIGNoaWxkcmVuU3RhdGljPzogc3RyaW5nXHJcbiAgY29udGFpbmVyQ2xhc3NOYW1lOiBzdHJpbmdcclxuICBjb250ZW50Q2xhc3NOYW1lOiBzdHJpbmdcclxuXHJcbiAgLyoqXHJcbiAgICogY3JlYXRlcyBhIFJlYWN0IHZpZXcgY29tcG9uZW50IGhhbmRpbmcgb3ZlciB0aGUgUmVhY3QgY29kZSB0byBiZSByZW5kZXJlZFxyXG4gICAqIEBwYXJhbSBjb21wb25lbnQgdGhlIFJlYWN0IGNvbXBvbmVudCB0byBiZSByZW5kZXJlZFxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKHtcclxuICAgIGNvbXBvbmVudCxcclxuICAgIGNvbnRhaW5lckNsYXNzTmFtZSxcclxuICAgIGNvbnRlbnRDbGFzc05hbWUsXHJcbiAgfToge1xyXG4gICAgY29tcG9uZW50OiAoKSA9PiBSZWFjdEVsZW1lbnRcclxuICAgIGNvbnRhaW5lckNsYXNzTmFtZTogc3RyaW5nXHJcbiAgICBjb250ZW50Q2xhc3NOYW1lOiBzdHJpbmdcclxuICB9KSB7XHJcbiAgICB0aGlzLmNvbnRhaW5lckNsYXNzTmFtZSA9IGNvbnRhaW5lckNsYXNzTmFtZVxyXG4gICAgdGhpcy5jb250ZW50Q2xhc3NOYW1lID0gY29udGVudENsYXNzTmFtZVxyXG4gICAgaWYgKGNvbXBvbmVudCkge1xyXG4gICAgICB0aGlzLmNoaWxkcmVuID0gY29tcG9uZW50KClcclxuICAgIH1cclxuICAgIHRoaXMucmVuZGVyKClcclxuICAgIC8vIGV0Y2guaW5pdGlhbGl6ZSh0aGlzKTtcclxuICB9XHJcblxyXG4gIHJlbmRlcigpIHtcclxuICAgIHRoaXMucm9vdEVsZW1lbnQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwic3BhblwiKVxyXG4gICAgdGhpcy5yb290RWxlbWVudC5jbGFzc0xpc3QuYWRkKHRoaXMuY29udGFpbmVyQ2xhc3NOYW1lKVxyXG4gICAgaWYgKHRoaXMuY2hpbGRyZW4pIHtcclxuICAgICAgdGhpcy5jaGlsZHJlblN0YXRpYyA9IERPTVB1cmlmeS5zYW5pdGl6ZShyZW5kZXJUb1N0YXRpY01hcmt1cCh0aGlzLmNoaWxkcmVuKSlcclxuICAgICAgdGhpcy5yb290RWxlbWVudC5pbm5lckhUTUwgPSBgXHJcbiAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cIiR7dGhpcy5jb250ZW50Q2xhc3NOYW1lfVwiPiR7dGhpcy5jaGlsZHJlblN0YXRpY308L2Rpdj5cclxuICAgICAgYFxyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRoaXMucm9vdEVsZW1lbnRcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIHJldHVybnMgdGhlIHJvb3QgZWxlbWVudCBvZiB0aGUgUmVhY3QgdmlldyBjb21wb25lbnRcclxuICAgKiBAcmV0dXJuIHtIVE1MRWxlbWVudH0gdGhlIHJvb3QgZWxlbWVudCB3cmFwcGluZyB0aGUgSFRNTCBjb250ZW50XHJcbiAgICovXHJcbiAgZ2V0IGVsZW1lbnQoKTogSFRNTEVsZW1lbnQge1xyXG4gICAgcmV0dXJuIHRoaXMucm9vdEVsZW1lbnRcclxuICB9XHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVhY3RWaWV3LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjLWNvbW1vbnMtdWkvZmxvYXQtcGFuZS9SZWFjdFZpZXcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw2Q0FBOEI7QUFhOUIsTUFBYSxTQUFVLFNBQVEsS0FBSyxDQUFDLFNBQXVCO0lBQzFELE1BQU07UUFDSixJQUFJLFFBQVEsR0FBRyxJQUFJLENBQUE7UUFDbkIsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsRUFBRTtZQUN4QixRQUFRLEdBQUcsNkJBQUssU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLElBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQUUsQ0FBTyxDQUFBO1NBQ3ZGO1FBRUQsT0FBTyw2QkFBSyxTQUFTLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsSUFBRyxRQUFRLENBQU8sQ0FBQTtJQUN4RSxDQUFDO0NBQ0Y7QUFURCw4QkFTQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gXCJyZWFjdFwiXHJcblxyXG5pbnRlcmZhY2UgUHJvcHMge1xyXG4gIGNvbXBvbmVudDogKCkgPT4gUmVhY3QuUmVhY3RFbGVtZW50XHJcbiAgY29udGFpbmVyQ2xhc3NOYW1lOiBzdHJpbmdcclxuICBjb250ZW50Q2xhc3NOYW1lOiBzdHJpbmdcclxufVxyXG5cclxuaW50ZXJmYWNlIFN0YXRlIHt9XHJcblxyXG4vKipcclxuICogQSByZWFjdCBjb21wb25lbnQgdGhhdCBjYW4gaG9zdCBhbiBleHRlcm5hbGx5IGdpdmVuIFJlYWN0IGNvbXBvbmVudFxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIFJlYWN0VmlldyBleHRlbmRzIFJlYWN0LkNvbXBvbmVudDxQcm9wcywgU3RhdGU+IHtcclxuICByZW5kZXIoKSB7XHJcbiAgICBsZXQgY2hpbGRyZW4gPSBudWxsXHJcbiAgICBpZiAodGhpcy5wcm9wcy5jb21wb25lbnQpIHtcclxuICAgICAgY2hpbGRyZW4gPSA8ZGl2IGNsYXNzTmFtZT17dGhpcy5wcm9wcy5jb250ZW50Q2xhc3NOYW1lfT57dGhpcy5wcm9wcy5jb21wb25lbnQoKX08L2Rpdj5cclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gPGRpdiBjbGFzc05hbWU9e3RoaXMucHJvcHMuY29udGFpbmVyQ2xhc3NOYW1lfT57Y2hpbGRyZW59PC9kaXY+XHJcbiAgfVxyXG59XHJcbiJdfQ==

@@ -0,11 +1,14 @@

import * as React from "react";
import { MarkdownService } from "../../types-packages/main";
export declare class SnippetView {
rootElement: HTMLElement;
constructor({ snippet, containerClassName, contentClassName, }: {
snippet: string;
containerClassName: string;
contentClassName: string;
});
get element(): HTMLElement;
interface Props {
snippet: string;
containerClassName: string;
contentClassName: string;
}
export declare function getSnippetHtml(snippets: Array<String>, grammarName: string, renderer: MarkdownService): Promise<string | null>;
interface State {
}
export declare class SnippetView extends React.Component<Props, State> {
render(): JSX.Element;
}
export declare function getSnippetHtml(snippets: Array<String>, grammarName: string, renderer?: MarkdownService): Promise<string | null>;
export {};
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {

@@ -7,16 +26,12 @@ return (mod && mod.__esModule) ? mod : { "default": mod };

exports.getSnippetHtml = exports.SnippetView = void 0;
const React = __importStar(require("react"));
const dompurify_1 = __importDefault(require("dompurify"));
class SnippetView {
constructor({ snippet, containerClassName, contentClassName, }) {
this.rootElement = document.createElement("div");
this.rootElement.classList.add(containerClassName);
if (snippet) {
const innerHTML = dompurify_1.default.sanitize(snippet);
this.rootElement.innerHTML = `
<div className='${contentClassName}'>${innerHTML}</div>`;
}
const MarkdownRenderer_1 = require("../MarkdownRenderer");
class SnippetView extends React.Component {
render() {
return (React.createElement("div", { className: this.props.containerClassName },
React.createElement("div", { className: this.props.contentClassName, dangerouslySetInnerHTML: {
__html: dompurify_1.default.sanitize(this.props.snippet),
} })));
}
get element() {
return this.rootElement;
}
}

@@ -36,3 +51,9 @@ exports.SnippetView = SnippetView;

});
return renderer.render(divElem.outerHTML, grammarName);
if (renderer) {
return renderer.render(divElem.outerHTML, grammarName);
}
else {
const render = await MarkdownRenderer_1.getMarkdownRenderer();
return render(divElem.outerHTML, grammarName);
}
}

@@ -42,2 +63,2 @@ return null;

exports.getSnippetHtml = getSnippetHtml;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU25pcHBldFZpZXcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMtY29tbW9ucy11aS9mbG9hdC1wYW5lL1NuaXBwZXRWaWV3LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUdBLDBEQUFpQztBQU1qQyxNQUFhLFdBQVc7SUFPdEIsWUFBWSxFQUNWLE9BQU8sRUFDUCxrQkFBa0IsRUFDbEIsZ0JBQWdCLEdBS2pCO1FBQ0MsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQ2hELElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFBO1FBQ2xELElBQUksT0FBTyxFQUFFO1lBQ1gsTUFBTSxTQUFTLEdBQUcsbUJBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUE7WUFDN0MsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLEdBQUc7MEJBQ1QsZ0JBQWdCLEtBQUssU0FBUyxRQUFRLENBQUE7U0FDM0Q7SUFDSCxDQUFDO0lBTUQsSUFBSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFBO0lBQ3pCLENBQUM7Q0FDRjtBQWhDRCxrQ0FnQ0M7QUFTTSxLQUFLLFVBQVUsY0FBYyxDQUNsQyxRQUF1QixFQUN2QixXQUFtQixFQUNuQixRQUF5QjtJQUV6QixJQUFJLFFBQVEsS0FBSyxTQUFTLElBQUksUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDakQsTUFBTSxlQUFlLEdBQUcsMENBQTBDLENBQUE7UUFDbEUsTUFBTSxPQUFPLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUM3QyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDM0IsTUFBTSxPQUFPLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUM3QyxNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFBO1lBQy9DLE9BQU8sR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLDZCQUE2QixFQUFFLEVBQUUsQ0FBQyxDQUFBO1lBQzVELFFBQVEsQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUE7WUFDekQsT0FBTyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQTtZQUM3QixPQUFPLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQzlCLENBQUMsQ0FBQyxDQUFBO1FBQ0YsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUUsV0FBVyxDQUFDLENBQUE7S0FDdkQ7SUFDRCxPQUFPLElBQUksQ0FBQTtBQUNiLENBQUM7QUFuQkQsd0NBbUJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIGEgcmVmZXJlbmNlIHRvIHRoZSBET01wdXJpZnkgZnVuY3Rpb24gdG8gbWFrZSBzYWZlIEhUTUwgc3RyaW5nc1xyXG4gKi9cclxuaW1wb3J0IERPTVB1cmlmeSBmcm9tIFwiZG9tcHVyaWZ5XCJcclxuaW1wb3J0IHsgTWFya2Rvd25TZXJ2aWNlIH0gZnJvbSBcIi4uLy4uL3R5cGVzLXBhY2thZ2VzL21haW5cIlxyXG5cclxuLyoqXHJcbiAqIGFuIGV0Y2ggY29tcG9uZW50IHRoYXQgaG9zdHMgYSBjb2RlIHNuaXBwZXQgaW5jbC4gc3ludGF4IGhpZ2hsaWdodGluZ1xyXG4gKi9cclxuZXhwb3J0IGNsYXNzIFNuaXBwZXRWaWV3IHtcclxuICByb290RWxlbWVudDogSFRNTEVsZW1lbnRcclxuXHJcbiAgLyoqXHJcbiAgICogY3JlYXRlcyBhIHNuaXBwZXQgdmlldyBjb21wb25lbnQgaGFuZGluZyBpbiB0aGUgc25pcHBldFxyXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBzbmlwcGV0IHRoZSBjb2RlIHNuaXBwZXQgdG8gYmUgZW1iZWRkZWRcclxuICAgKi9cclxuICBjb25zdHJ1Y3Rvcih7XHJcbiAgICBzbmlwcGV0LFxyXG4gICAgY29udGFpbmVyQ2xhc3NOYW1lLFxyXG4gICAgY29udGVudENsYXNzTmFtZSxcclxuICB9OiB7XHJcbiAgICBzbmlwcGV0OiBzdHJpbmdcclxuICAgIGNvbnRhaW5lckNsYXNzTmFtZTogc3RyaW5nXHJcbiAgICBjb250ZW50Q2xhc3NOYW1lOiBzdHJpbmdcclxuICB9KSB7XHJcbiAgICB0aGlzLnJvb3RFbGVtZW50ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcImRpdlwiKVxyXG4gICAgdGhpcy5yb290RWxlbWVudC5jbGFzc0xpc3QuYWRkKGNvbnRhaW5lckNsYXNzTmFtZSlcclxuICAgIGlmIChzbmlwcGV0KSB7XHJcbiAgICAgIGNvbnN0IGlubmVySFRNTCA9IERPTVB1cmlmeS5zYW5pdGl6ZShzbmlwcGV0KVxyXG4gICAgICB0aGlzLnJvb3RFbGVtZW50LmlubmVySFRNTCA9IGBcclxuICAgICAgICA8ZGl2IGNsYXNzTmFtZT0nJHtjb250ZW50Q2xhc3NOYW1lfSc+JHtpbm5lckhUTUx9PC9kaXY+YFxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogcmV0dXJucyB0aGUgcm9vdCBlbGVtZW50IG9mIHRoZSBzbmlwcGV0IHZpZXcgY29tcG9uZW50XHJcbiAgICogQHJldHVybiB7SFRNTEVsZW1lbnR9IHRoZSByb290IGVsZW1lbnQgd3JhcHBpbmcgdGhlIEhUTUwgY29udGVudFxyXG4gICAqL1xyXG4gIGdldCBlbGVtZW50KCk6IEhUTUxFbGVtZW50IHtcclxuICAgIHJldHVybiB0aGlzLnJvb3RFbGVtZW50XHJcbiAgfVxyXG59XHJcblxyXG4vKipcclxuICogY29udmVydHMgYSBnaXZlbiBjb2RlIHNuaXBwZXQgaW50byBzeW50YXggZm9ybWF0dGVkIEhUTUxcclxuICogQHBhcmFtIHNuaXBwZXRzIHRoZSBjb2RlIHNuaXBwZXQgdG8gYmUgY29udmVydGVkXHJcbiAqIEBwYXJhbSBncmFtbWFyTmFtZSB0aGUgbmFtZSBvZiB0aGUgZ3JhbW1hciB0byBiZSB1c2VkIGZvciBzeW50YXggaGlnaGxpZ2h0aW5nXHJcbiAqIEBwYXJhbSByZW5kZXJlciBtYXJrZG93biBzZXJ2aWNlIHRvIGJlIHVzZWQgZm9yIHJlbmRlcmluZ1xyXG4gKiBAcmV0dXJuIGEgcHJvbWlzZSBvYmplY3QgdG8gdHJhY2sgdGhlIGFzeW5jaHJvbm91cyBvcGVyYXRpb25cclxuICovXHJcbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZXRTbmlwcGV0SHRtbChcclxuICBzbmlwcGV0czogQXJyYXk8U3RyaW5nPixcclxuICBncmFtbWFyTmFtZTogc3RyaW5nLFxyXG4gIHJlbmRlcmVyOiBNYXJrZG93blNlcnZpY2VcclxuKTogUHJvbWlzZTxzdHJpbmcgfCBudWxsPiB7XHJcbiAgaWYgKHNuaXBwZXRzICE9PSB1bmRlZmluZWQgJiYgc25pcHBldHMubGVuZ3RoID4gMCkge1xyXG4gICAgY29uc3QgcmVnRXhwTFNQUHJlZml4ID0gL15cXCgobWV0aG9kfHByb3BlcnR5fHBhcmFtZXRlcnxhbGlhcylcXClcXFcvXHJcbiAgICBjb25zdCBkaXZFbGVtID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcImRpdlwiKVxyXG4gICAgc25pcHBldHMuZm9yRWFjaCgoc25pcHBldCkgPT4ge1xyXG4gICAgICBjb25zdCBwcmVFbGVtID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcInByZVwiKVxyXG4gICAgICBjb25zdCBjb2RlRWxlbSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoXCJjb2RlXCIpXHJcbiAgICAgIHNuaXBwZXQgPSBzbmlwcGV0LnJlcGxhY2UoL15cXHMqPChcXD98ISkoW2EtekEtWl0rKT9cXHMqL2ksIFwiXCIpIC8vIHJlbW92ZSBhbnkgcHJlYW1ibGUgZnJvbSB0aGUgbGluZVxyXG4gICAgICBjb2RlRWxlbS5pbm5lclRleHQgPSBzbmlwcGV0LnJlcGxhY2UocmVnRXhwTFNQUHJlZml4LCBcIlwiKVxyXG4gICAgICBwcmVFbGVtLmFwcGVuZENoaWxkKGNvZGVFbGVtKVxyXG4gICAgICBkaXZFbGVtLmFwcGVuZENoaWxkKHByZUVsZW0pXHJcbiAgICB9KVxyXG4gICAgcmV0dXJuIHJlbmRlcmVyLnJlbmRlcihkaXZFbGVtLm91dGVySFRNTCwgZ3JhbW1hck5hbWUpXHJcbiAgfVxyXG4gIHJldHVybiBudWxsXHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU25pcHBldFZpZXcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMtY29tbW9ucy11aS9mbG9hdC1wYW5lL1NuaXBwZXRWaWV3LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsNkNBQThCO0FBQzlCLDBEQUFpQztBQUVqQywwREFBeUQ7QUFhekQsTUFBYSxXQUFZLFNBQVEsS0FBSyxDQUFDLFNBQXVCO0lBQzVELE1BQU07UUFDSixPQUFPLENBQ0wsNkJBQUssU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCO1lBQzNDLDZCQUNFLFNBQVMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUN0Qyx1QkFBdUIsRUFBRTtvQkFDdkIsTUFBTSxFQUFFLG1CQUFTLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDO2lCQUMvQyxHQUNELENBQ0UsQ0FDUCxDQUFBO0lBQ0gsQ0FBQztDQUNGO0FBYkQsa0NBYUM7QUFTTSxLQUFLLFVBQVUsY0FBYyxDQUNsQyxRQUF1QixFQUN2QixXQUFtQixFQUNuQixRQUEwQjtJQUUxQixJQUFJLFFBQVEsS0FBSyxTQUFTLElBQUksUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDakQsTUFBTSxlQUFlLEdBQUcsMENBQTBDLENBQUE7UUFDbEUsTUFBTSxPQUFPLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUM3QyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDM0IsTUFBTSxPQUFPLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUM3QyxNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFBO1lBQy9DLE9BQU8sR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLDZCQUE2QixFQUFFLEVBQUUsQ0FBQyxDQUFBO1lBQzVELFFBQVEsQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUE7WUFDekQsT0FBTyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQTtZQUM3QixPQUFPLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQzlCLENBQUMsQ0FBQyxDQUFBO1FBQ0YsSUFBSSxRQUFRLEVBQUU7WUFDWixPQUFPLFFBQVEsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxXQUFXLENBQUMsQ0FBQTtTQUN2RDthQUFNO1lBRUwsTUFBTSxNQUFNLEdBQUcsTUFBTSxzQ0FBbUIsRUFBRSxDQUFBO1lBQzFDLE9BQU8sTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUUsV0FBVyxDQUFDLENBQUE7U0FDOUM7S0FDRjtJQUNELE9BQU8sSUFBSSxDQUFBO0FBQ2IsQ0FBQztBQXpCRCx3Q0F5QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tIFwicmVhY3RcIlxyXG5pbXBvcnQgRE9NUHVyaWZ5IGZyb20gXCJkb21wdXJpZnlcIlxyXG5pbXBvcnQgeyBNYXJrZG93blNlcnZpY2UgfSBmcm9tIFwiLi4vLi4vdHlwZXMtcGFja2FnZXMvbWFpblwiXHJcbmltcG9ydCB7IGdldE1hcmtkb3duUmVuZGVyZXIgfSBmcm9tIFwiLi4vTWFya2Rvd25SZW5kZXJlclwiXHJcblxyXG5pbnRlcmZhY2UgUHJvcHMge1xyXG4gIHNuaXBwZXQ6IHN0cmluZ1xyXG4gIGNvbnRhaW5lckNsYXNzTmFtZTogc3RyaW5nXHJcbiAgY29udGVudENsYXNzTmFtZTogc3RyaW5nXHJcbn1cclxuXHJcbmludGVyZmFjZSBTdGF0ZSB7fVxyXG5cclxuLyoqXHJcbiAqIEEgUmVhY3QgY29tcG9uZW50IHRoYXQgaG9zdHMgYSBjb2RlIHNuaXBwZXQgd2l0aCBzeW50YXggaGlnaGxpZ2h0aW5nXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgU25pcHBldFZpZXcgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQ8UHJvcHMsIFN0YXRlPiB7XHJcbiAgcmVuZGVyKCkge1xyXG4gICAgcmV0dXJuIChcclxuICAgICAgPGRpdiBjbGFzc05hbWU9e3RoaXMucHJvcHMuY29udGFpbmVyQ2xhc3NOYW1lfT5cclxuICAgICAgICA8ZGl2XHJcbiAgICAgICAgICBjbGFzc05hbWU9e3RoaXMucHJvcHMuY29udGVudENsYXNzTmFtZX1cclxuICAgICAgICAgIGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7XHJcbiAgICAgICAgICAgIF9faHRtbDogRE9NUHVyaWZ5LnNhbml0aXplKHRoaXMucHJvcHMuc25pcHBldCksXHJcbiAgICAgICAgICB9fVxyXG4gICAgICAgIC8+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgKVxyXG4gIH1cclxufVxyXG5cclxuLyoqXHJcbiAqIGNvbnZlcnRzIGEgZ2l2ZW4gY29kZSBzbmlwcGV0IGludG8gc3ludGF4IGZvcm1hdHRlZCBIVE1MXHJcbiAqIEBwYXJhbSBzbmlwcGV0cyB0aGUgY29kZSBzbmlwcGV0IHRvIGJlIGNvbnZlcnRlZFxyXG4gKiBAcGFyYW0gZ3JhbW1hck5hbWUgdGhlIG5hbWUgb2YgdGhlIGdyYW1tYXIgdG8gYmUgdXNlZCBmb3Igc3ludGF4IGhpZ2hsaWdodGluZ1xyXG4gKiBAcGFyYW0gcmVuZGVyZXIgbWFya2Rvd24gc2VydmljZSB0byBiZSB1c2VkIGZvciByZW5kZXJpbmdcclxuICogQHJldHVybiBhIHByb21pc2Ugb2JqZWN0IHRvIHRyYWNrIHRoZSBhc3luY2hyb25vdXMgb3BlcmF0aW9uXHJcbiAqL1xyXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0U25pcHBldEh0bWwoXHJcbiAgc25pcHBldHM6IEFycmF5PFN0cmluZz4sXHJcbiAgZ3JhbW1hck5hbWU6IHN0cmluZyxcclxuICByZW5kZXJlcj86IE1hcmtkb3duU2VydmljZVxyXG4pOiBQcm9taXNlPHN0cmluZyB8IG51bGw+IHtcclxuICBpZiAoc25pcHBldHMgIT09IHVuZGVmaW5lZCAmJiBzbmlwcGV0cy5sZW5ndGggPiAwKSB7XHJcbiAgICBjb25zdCByZWdFeHBMU1BQcmVmaXggPSAvXlxcKChtZXRob2R8cHJvcGVydHl8cGFyYW1ldGVyfGFsaWFzKVxcKVxcVy9cclxuICAgIGNvbnN0IGRpdkVsZW0gPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiZGl2XCIpXHJcbiAgICBzbmlwcGV0cy5mb3JFYWNoKChzbmlwcGV0KSA9PiB7XHJcbiAgICAgIGNvbnN0IHByZUVsZW0gPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwicHJlXCIpXHJcbiAgICAgIGNvbnN0IGNvZGVFbGVtID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcImNvZGVcIilcclxuICAgICAgc25pcHBldCA9IHNuaXBwZXQucmVwbGFjZSgvXlxccyo8KFxcP3whKShbYS16QS1aXSspP1xccyovaSwgXCJcIikgLy8gcmVtb3ZlIGFueSBwcmVhbWJsZSBmcm9tIHRoZSBsaW5lXHJcbiAgICAgIGNvZGVFbGVtLmlubmVyVGV4dCA9IHNuaXBwZXQucmVwbGFjZShyZWdFeHBMU1BQcmVmaXgsIFwiXCIpXHJcbiAgICAgIHByZUVsZW0uYXBwZW5kQ2hpbGQoY29kZUVsZW0pXHJcbiAgICAgIGRpdkVsZW0uYXBwZW5kQ2hpbGQocHJlRWxlbSlcclxuICAgIH0pXHJcbiAgICBpZiAocmVuZGVyZXIpIHtcclxuICAgICAgcmV0dXJuIHJlbmRlcmVyLnJlbmRlcihkaXZFbGVtLm91dGVySFRNTCwgZ3JhbW1hck5hbWUpXHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICAvLyBVc2UgYnVpbHQtaW4gbWFya2Rvd24gcmVuZGVyZXIgd2hlbiB0aGUgbWFya2Rvd24gc2VydmljZSBpcyBub3QgYXZhaWxhYmxlXHJcbiAgICAgIGNvbnN0IHJlbmRlciA9IGF3YWl0IGdldE1hcmtkb3duUmVuZGVyZXIoKVxyXG4gICAgICByZXR1cm4gcmVuZGVyKGRpdkVsZW0ub3V0ZXJIVE1MLCBncmFtbWFyTmFtZSlcclxuICAgIH1cclxuICB9XHJcbiAgcmV0dXJuIG51bGxcclxufVxyXG4iXX0=
import type { ReactElement } from "react";
export declare class ViewContainer {
props: {
component?: {
element: () => ReactElement;
containerClassName: string;
contentClassName: string;
};
html?: {
element: string;
containerClassName: string;
contentClassName: string;
};
snippet?: {
element: string;
containerClassName: string;
contentClassName: string;
};
import * as React from "react";
import type { Datatip } from "../../types-packages/main.d";
export declare const DATATIP_ACTIONS: Readonly<{
PIN: string;
CLOSE: string;
}>;
interface Props {
component?: {
element: () => ReactElement;
containerClassName: string;
contentClassName: string;
};
html?: {
element: string;
containerClassName: string;
contentClassName: string;
};
snippet?: {
element: string;
containerClassName: string;
contentClassName: string;
};
action: string;
actionTitle: string;
className?: string;
datatip: Datatip;
onActionClick: Function;
onMouseDown: Function;
onClickCapture: Function;
}
interface State {
}
export declare class ViewContainer extends React.Component<Props, State> {
actionButton?: JSX.Element;
classNames: string;
children: Array<JSX.Element>;
constructor(props: any, children?: Array<JSX.Element>);
rootElement: HTMLElement;
constructor(props: Props);
render(): JSX.Element;
update(props: any, children?: Array<JSX.Element>): any;
get element(): void;
updateChildren(): void;
ActionClick(action: string, actionTitle: string): JSX.Element | undefined;
destroy(): Promise<void>;
updateChildren(): void;
}
export {};
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {

@@ -6,44 +25,63 @@ return (mod && mod.__esModule) ? mod : { "default": mod };

Object.defineProperty(exports, "__esModule", { value: true });
exports.ViewContainer = void 0;
const etch_1 = __importDefault(require("etch"));
exports.ViewContainer = exports.DATATIP_ACTIONS = void 0;
const HTMLView_1 = require("./HTMLView");
const SnippetView_1 = require("./SnippetView");
const ReactView_1 = require("./ReactView");
class ViewContainer {
constructor(props, children) {
this.props = props;
this.children = children || [];
const React = __importStar(require("react"));
const react_dom_1 = __importDefault(require("react-dom"));
exports.DATATIP_ACTIONS = Object.freeze({
PIN: "PIN",
CLOSE: "CLOSE",
});
const IconsForAction = {
[exports.DATATIP_ACTIONS.PIN]: "pin",
[exports.DATATIP_ACTIONS.CLOSE]: "x",
};
class ViewContainer extends React.Component {
constructor(props) {
super(props);
this.children = [];
this.updateChildren();
etch_1.default.initialize(this);
this.rootElement = document.createElement("div");
const glowClass = atom.config.get("atom-ide-datatip.glowOnHover") ? "datatip-glow" : "";
this.classNames = `${String(props.className)} datatip-element ${glowClass}`;
}
render() {
const glowClass = atom.config.get("atom-ide-datatip.glowOnHover") ? "datatip-glow" : "";
const classes = `datatip-element ${glowClass}`;
return etch_1.default.dom("div", { className: classes }, this.children);
this.actionButton = this.ActionClick(this.props.action, this.props.actionTitle);
return (React.createElement("div", Object.assign({ className: this.classNames }, this.props.onMouseDown, this.props.onClickCapture),
this.children,
this.actionButton));
}
update(props, children) {
this.props = props;
this.children = children || [];
this.updateChildren();
return etch_1.default.update(this);
get element() {
return react_dom_1.default.render(this.render(), this.rootElement);
}
async destroy() {
await etch_1.default.destroy(this);
}
updateChildren() {
if (this.props.component) {
const { element, containerClassName, contentClassName } = this.props.component;
this.children.push(etch_1.default.dom(ReactView_1.ReactView, { component: element, containerClassName: containerClassName, contentClassName: contentClassName }));
this.children.push(React.createElement(ReactView_1.ReactView, { component: element, containerClassName: containerClassName, contentClassName: contentClassName }));
}
if (this.props.snippet) {
const { element, containerClassName, contentClassName } = this.props.snippet;
this.children.push(etch_1.default.dom(SnippetView_1.SnippetView, { snippet: element, containerClassName: containerClassName, contentClassName: contentClassName }));
this.children.push(React.createElement(SnippetView_1.SnippetView, { snippet: element, containerClassName: containerClassName, contentClassName: contentClassName }));
}
if (this.props.html) {
const { element, containerClassName, contentClassName } = this.props.html;
this.children.push(etch_1.default.dom(HTMLView_1.HTMLView, { html: element, containerClassName: containerClassName, contentClassName: contentClassName }));
this.children.push(React.createElement(HTMLView_1.HTMLView, { html: element, containerClassName: containerClassName, contentClassName: contentClassName }));
}
}
ActionClick(action, actionTitle) {
let actionButton = undefined;
if (action != null && IconsForAction[action] != null) {
const actionIcon = IconsForAction[action];
actionButton = (React.createElement("div", { className: `datatip-pin-button icon-${actionIcon}`, onClick: (event) => {
this.props.onActionClick();
}, title: actionTitle }));
}
return actionButton;
}
async destroy() {
return;
}
}
exports.ViewContainer = ViewContainer;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVmlld0NvbnRhaW5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy1jb21tb25zLXVpL2Zsb2F0LXBhbmUvVmlld0NvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBRUEsZ0RBQXVCO0FBQ3ZCLHlDQUFxQztBQUNyQywrQ0FBMkM7QUFDM0MsMkNBQXVDO0FBTXZDLE1BQWEsYUFBYTtJQWF4QixZQUFZLEtBQVUsRUFBRSxRQUE2QjtRQUNuRCxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQTtRQUNsQixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsSUFBSSxFQUFFLENBQUE7UUFDOUIsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFBO1FBQ3JCLGNBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDdkIsQ0FBQztJQU1ELE1BQU07UUFDSixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyw4QkFBOEIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQTtRQUN2RixNQUFNLE9BQU8sR0FBRyxtQkFBbUIsU0FBUyxFQUFFLENBQUE7UUFDOUMsT0FBTyw0QkFBSyxTQUFTLEVBQUUsT0FBTyxJQUFHLElBQUksQ0FBQyxRQUFRLENBQU8sQ0FBQTtJQUN2RCxDQUFDO0lBS0QsTUFBTSxDQUFDLEtBQVUsRUFBRSxRQUE2QjtRQUc5QyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQTtRQUNsQixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsSUFBSSxFQUFFLENBQUE7UUFDOUIsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFBO1FBQ3JCLE9BQU8sY0FBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUMxQixDQUFDO0lBTUQsS0FBSyxDQUFDLE9BQU87UUFDWCxNQUFNLGNBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDMUIsQ0FBQztJQU1ELGNBQWM7UUFDWixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFO1lBQ3hCLE1BQU0sRUFBRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsZ0JBQWdCLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQTtZQUM5RSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FDaEIsbUJBQUMscUJBQVMsSUFBQyxTQUFTLEVBQUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixHQUFJLENBQzlHLENBQUE7U0FDRjtRQUNELElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUU7WUFDdEIsTUFBTSxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxnQkFBZ0IsRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFBO1lBQzVFLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUNoQixtQkFBQyx5QkFBVyxJQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEdBQUksQ0FDOUcsQ0FBQTtTQUNGO1FBQ0QsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRTtZQUNuQixNQUFNLEVBQUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUE7WUFDekUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQ2hCLG1CQUFDLG1CQUFRLElBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsR0FBSSxDQUN4RyxDQUFBO1NBQ0Y7SUFDSCxDQUFDO0NBQ0Y7QUExRUQsc0NBMEVDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBqc3ggZXRjaC5kb20gKi9cclxuXHJcbmltcG9ydCBldGNoIGZyb20gXCJldGNoXCJcclxuaW1wb3J0IHsgSFRNTFZpZXcgfSBmcm9tIFwiLi9IVE1MVmlld1wiXHJcbmltcG9ydCB7IFNuaXBwZXRWaWV3IH0gZnJvbSBcIi4vU25pcHBldFZpZXdcIlxyXG5pbXBvcnQgeyBSZWFjdFZpZXcgfSBmcm9tIFwiLi9SZWFjdFZpZXdcIlxyXG5pbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiXHJcblxyXG4vKipcclxuICogYW4gZXRjaCBjb21wb25lbnQgZm9yIGEgZGVjb3JhdGlvbiBwYW5lXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgVmlld0NvbnRhaW5lciB7XHJcbiAgcHJvcHM6IHtcclxuICAgIGNvbXBvbmVudD86IHsgZWxlbWVudDogKCkgPT4gUmVhY3RFbGVtZW50OyBjb250YWluZXJDbGFzc05hbWU6IHN0cmluZzsgY29udGVudENsYXNzTmFtZTogc3RyaW5nIH1cclxuICAgIGh0bWw/OiB7IGVsZW1lbnQ6IHN0cmluZzsgY29udGFpbmVyQ2xhc3NOYW1lOiBzdHJpbmc7IGNvbnRlbnRDbGFzc05hbWU6IHN0cmluZyB9XHJcbiAgICBzbmlwcGV0PzogeyBlbGVtZW50OiBzdHJpbmc7IGNvbnRhaW5lckNsYXNzTmFtZTogc3RyaW5nOyBjb250ZW50Q2xhc3NOYW1lOiBzdHJpbmcgfVxyXG4gIH1cclxuICBjaGlsZHJlbjogQXJyYXk8SlNYLkVsZW1lbnQ+XHJcblxyXG4gIC8qKlxyXG4gICAqIGNyZWF0ZXMgYSBkYXRhIHRpcCB2aWV3IGNvbXBvbmVudFxyXG4gICAqIEBwYXJhbSBwcm9wcyAgdGhlIHByb3BzIG9mIHRoaXMgZGF0YSB0aXAgdmlld1xyXG4gICAqIEBwYXJhbSBjaGlsZHJlbiBwb3RlbnRpYWwgY2hpbGQgbm9kZXMgb2YgdGhpcyBkYXRhIHRpcCB2aWV3XHJcbiAgICovXHJcbiAgY29uc3RydWN0b3IocHJvcHM6IGFueSwgY2hpbGRyZW4/OiBBcnJheTxKU1guRWxlbWVudD4pIHtcclxuICAgIHRoaXMucHJvcHMgPSBwcm9wc1xyXG4gICAgdGhpcy5jaGlsZHJlbiA9IGNoaWxkcmVuIHx8IFtdXHJcbiAgICB0aGlzLnVwZGF0ZUNoaWxkcmVuKClcclxuICAgIGV0Y2guaW5pdGlhbGl6ZSh0aGlzKVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogcmVuZGVycyB0aGUgZGF0YSB0aXAgdmlldyBjb21wb25lbnRcclxuICAgKiBAcmV0dXJuIHRoZSBkYXRhIHRpcCB2aWV3IGVsZW1lbnRcclxuICAgKi9cclxuICByZW5kZXIoKTogSlNYLkVsZW1lbnQge1xyXG4gICAgY29uc3QgZ2xvd0NsYXNzID0gYXRvbS5jb25maWcuZ2V0KFwiYXRvbS1pZGUtZGF0YXRpcC5nbG93T25Ib3ZlclwiKSA/IFwiZGF0YXRpcC1nbG93XCIgOiBcIlwiXHJcbiAgICBjb25zdCBjbGFzc2VzID0gYGRhdGF0aXAtZWxlbWVudCAke2dsb3dDbGFzc31gXHJcbiAgICByZXR1cm4gPGRpdiBjbGFzc05hbWU9e2NsYXNzZXN9Pnt0aGlzLmNoaWxkcmVufTwvZGl2PlxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogdXBkYXRlcyB0aGUgaW50ZXJuYWwgc3RhdGUgb2YgdGhlIGRhdGEgdGlwIHZpZXdcclxuICAgKi9cclxuICB1cGRhdGUocHJvcHM6IGFueSwgY2hpbGRyZW4/OiBBcnJheTxKU1guRWxlbWVudD4pIHtcclxuICAgIC8vIHBlcmZvcm0gY3VzdG9tIHVwZGF0ZSBsb2dpYyBoZXJlLi4uXHJcbiAgICAvLyB0aGVuIGNhbGwgYGV0Y2gudXBkYXRlYCwgd2hpY2ggaXMgYXN5bmMgYW5kIHJldHVybnMgYSBwcm9taXNlXHJcbiAgICB0aGlzLnByb3BzID0gcHJvcHNcclxuICAgIHRoaXMuY2hpbGRyZW4gPSBjaGlsZHJlbiB8fCBbXVxyXG4gICAgdGhpcy51cGRhdGVDaGlsZHJlbigpXHJcbiAgICByZXR1cm4gZXRjaC51cGRhdGUodGhpcylcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIGNsZWFuIHVwIHRoZSBkYXRhIHRpcCB2aWV3XHJcbiAgICogQHJldHVybiBhIHByb21pc2Ugb2JqZWN0IHRvIGtlZXAgdHJhY2sgb2YgdGhlIGFzeW5jaHJvbm91cyBvcGVyYXRpb25cclxuICAgKi9cclxuICBhc3luYyBkZXN0cm95KCk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgYXdhaXQgZXRjaC5kZXN0cm95KHRoaXMpXHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBpbnRlcm5hbCBoZWxwZXIgZnVuY3Rpb24gdG8gZmlndXJlIG91dCB0aGUgc3RydWN0dXJlIG9mIHRoZSBkYXRhIHRpcCB2aWV3XHJcbiAgICogdG8gYmUgcmVuZGVyZWRcclxuICAgKi9cclxuICB1cGRhdGVDaGlsZHJlbigpIHtcclxuICAgIGlmICh0aGlzLnByb3BzLmNvbXBvbmVudCkge1xyXG4gICAgICBjb25zdCB7IGVsZW1lbnQsIGNvbnRhaW5lckNsYXNzTmFtZSwgY29udGVudENsYXNzTmFtZSB9ID0gdGhpcy5wcm9wcy5jb21wb25lbnRcclxuICAgICAgdGhpcy5jaGlsZHJlbi5wdXNoKFxyXG4gICAgICAgIDxSZWFjdFZpZXcgY29tcG9uZW50PXtlbGVtZW50fSBjb250YWluZXJDbGFzc05hbWU9e2NvbnRhaW5lckNsYXNzTmFtZX0gY29udGVudENsYXNzTmFtZT17Y29udGVudENsYXNzTmFtZX0gLz5cclxuICAgICAgKVxyXG4gICAgfVxyXG4gICAgaWYgKHRoaXMucHJvcHMuc25pcHBldCkge1xyXG4gICAgICBjb25zdCB7IGVsZW1lbnQsIGNvbnRhaW5lckNsYXNzTmFtZSwgY29udGVudENsYXNzTmFtZSB9ID0gdGhpcy5wcm9wcy5zbmlwcGV0XHJcbiAgICAgIHRoaXMuY2hpbGRyZW4ucHVzaChcclxuICAgICAgICA8U25pcHBldFZpZXcgc25pcHBldD17ZWxlbWVudH0gY29udGFpbmVyQ2xhc3NOYW1lPXtjb250YWluZXJDbGFzc05hbWV9IGNvbnRlbnRDbGFzc05hbWU9e2NvbnRlbnRDbGFzc05hbWV9IC8+XHJcbiAgICAgIClcclxuICAgIH1cclxuICAgIGlmICh0aGlzLnByb3BzLmh0bWwpIHtcclxuICAgICAgY29uc3QgeyBlbGVtZW50LCBjb250YWluZXJDbGFzc05hbWUsIGNvbnRlbnRDbGFzc05hbWUgfSA9IHRoaXMucHJvcHMuaHRtbFxyXG4gICAgICB0aGlzLmNoaWxkcmVuLnB1c2goXHJcbiAgICAgICAgPEhUTUxWaWV3IGh0bWw9e2VsZW1lbnR9IGNvbnRhaW5lckNsYXNzTmFtZT17Y29udGFpbmVyQ2xhc3NOYW1lfSBjb250ZW50Q2xhc3NOYW1lPXtjb250ZW50Q2xhc3NOYW1lfSAvPlxyXG4gICAgICApXHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ViewContainer.js","sourceRoot":"","sources":["../../src-commons-ui/float-pane/ViewContainer.tsx"],"names":[],"mappings":"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","sourcesContent":["import { HTMLView } from \"./HTMLView\"\r\nimport { SnippetView } from \"./SnippetView\"\r\nimport { ReactView } from \"./ReactView\"\r\nimport type { ReactElement } from \"react\"\r\nimport * as React from \"react\"\r\nimport ReactDOM from \"react-dom\"\r\nimport type { Datatip } from \"../../types-packages/main.d\"\r\n\r\nexport const DATATIP_ACTIONS = Object.freeze({\r\n  PIN: \"PIN\",\r\n  CLOSE: \"CLOSE\",\r\n})\r\n\r\nconst IconsForAction = {\r\n  [DATATIP_ACTIONS.PIN]: \"pin\",\r\n  [DATATIP_ACTIONS.CLOSE]: \"x\",\r\n}\r\n\r\ninterface Props {\r\n  component?: { element: () => ReactElement; containerClassName: string; contentClassName: string }\r\n  html?: { element: string; containerClassName: string; contentClassName: string }\r\n  snippet?: { element: string; containerClassName: string; contentClassName: string }\r\n  action: string\r\n  actionTitle: string\r\n  className?: string\r\n  datatip: Datatip\r\n  onActionClick: Function\r\n  onMouseDown: Function\r\n  onClickCapture: Function\r\n}\r\n\r\ninterface State {}\r\n\r\n/**\r\n * an etch component for a decoration pane\r\n */\r\nexport class ViewContainer extends React.Component<Props, State> {\r\n  actionButton?: JSX.Element\r\n  classNames: string\r\n  children: Array<JSX.Element>\r\n\r\n  rootElement: HTMLElement\r\n\r\n  constructor(props: Props) {\r\n    super(props)\r\n    this.children = []\r\n    this.updateChildren()\r\n    this.rootElement = document.createElement(\"div\")\r\n    const glowClass = atom.config.get(\"atom-ide-datatip.glowOnHover\") ? \"datatip-glow\" : \"\"\r\n    this.classNames = `${String(props.className)} datatip-element ${glowClass}`\r\n  }\r\n\r\n  /**\r\n   * renders the data tip view component\r\n   * @return the data tip view element\r\n   */\r\n  render() {\r\n    this.actionButton = this.ActionClick(this.props.action, this.props.actionTitle)\r\n    return (\r\n      <div className={this.classNames} {...this.props.onMouseDown} {...this.props.onClickCapture}>\r\n        {this.children}\r\n        {this.actionButton}\r\n      </div>\r\n    )\r\n  }\r\n\r\n  get element() {\r\n    return ReactDOM.render(this.render(), this.rootElement)\r\n  }\r\n\r\n  /**\r\n   * internal helper function to figure out the structure of the data tip view\r\n   * to be rendered\r\n   */\r\n  updateChildren() {\r\n    if (this.props.component) {\r\n      const { element, containerClassName, contentClassName } = this.props.component\r\n      this.children.push(\r\n        <ReactView component={element} containerClassName={containerClassName} contentClassName={contentClassName} />\r\n      )\r\n    }\r\n    if (this.props.snippet) {\r\n      const { element, containerClassName, contentClassName } = this.props.snippet\r\n      this.children.push(\r\n        <SnippetView snippet={element} containerClassName={containerClassName} contentClassName={contentClassName} />\r\n      )\r\n    }\r\n    if (this.props.html) {\r\n      const { element, containerClassName, contentClassName } = this.props.html\r\n      this.children.push(\r\n        <HTMLView html={element} containerClassName={containerClassName} contentClassName={contentClassName} />\r\n      )\r\n    }\r\n  }\r\n\r\n  ActionClick(action: string, actionTitle: string) {\r\n    let actionButton = undefined\r\n    if (action != null && IconsForAction[action] != null) {\r\n      const actionIcon = IconsForAction[action]\r\n      actionButton = (\r\n        <div\r\n          className={`datatip-pin-button icon-${actionIcon}`}\r\n          onClick={(event) => {\r\n            this.props.onActionClick()\r\n          }}\r\n          title={actionTitle}\r\n        />\r\n      )\r\n    }\r\n    return actionButton\r\n  }\r\n\r\n  async destroy() {\r\n    return // this.componentWillUnmount()\r\n  }\r\n}\r\n"]}
{
"name": "atom-ide-base",
"version": "1.10.0",
"version": "1.11.0",
"main": "package/main.js",

@@ -53,2 +53,3 @@ "types": "./types-packages/main.d.ts",

"dependencies": {
"atom-ide-markdown-service": "^1.3.4",
"atom-package-deps": "^6.0.0",

@@ -58,10 +59,14 @@ "dompurify": "^2.1.1",

"react": "^16.13.1",
"react-dom": "^16.13.1"
"react-dom": "^16.13.1",
"classnames": "^2.2.6",
"rxjs": "^6.6.3"
},
"devDependencies": {
"@types/atom": "1.40.4",
"@types/classnames": "^2.2.10",
"@types/dompurify": "^2.0.4",
"@types/node": "^14.11.2",
"@types/dompurify": "^2.0.4",
"@types/react": "^16.9.51",
"@types/react-dom": "^16.9.8",
"csstype": "^3.0.3",
"typescript": "^4.0.3",

@@ -68,0 +73,0 @@ "tslib": "^2.0.1",

{
"extends": "../tsconfig.json",
"compilerOptions": {
"jsxFactory": "React.createElement",
"outDir": "../commons-ui"
}
}

@@ -0,0 +0,0 @@ {

@@ -0,0 +0,0 @@ import * as Atom from "atom"

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc