UNPKG

bokehmol

Version:

Handle molecules with bokeh

50 lines 2.51 kB
import { div } from "@bokehjs/core/dom"; import { replace_placeholders } from "@bokehjs/core/util/templating"; import { isString } from "@bokehjs/core/util/types"; import { HoverTool, HoverToolView } from "@bokehjs/models/tools/inspectors/hover_tool"; import { tool_icon_hover } from "@bokehjs/styles/icons.css"; export class BaseHoverView extends HoverToolView { static __name__ = "BaseHoverView"; _render_tooltips(ds, vars) { const { tooltips, smiles_column } = this.model; const i = vars.index; let user_tooltip = tooltips; if (user_tooltip === null) { user_tooltip = ""; } if (!isString(user_tooltip)) { const template = this._template_el ?? ( // @ts-ignore this._template_el = this._create_template(user_tooltip)); // @ts-ignore user_tooltip = this._render_template(template, user_tooltip, ds, vars).outerHTML; } const mol_tooltip = "<div>@" + smiles_column + "{custom}</div>" + user_tooltip; const content = replace_placeholders({ html: mol_tooltip }, ds, i, this.model.formatters, vars); return div(content); } } export class BaseHover extends HoverTool { static __name__ = "BaseHover"; get computed_icon() { return ""; } constructor(attrs) { super(attrs); } static __module__ = "bokehmol.models.base_hover"; static { this.prototype.default_view = BaseHoverView; this.define(({ Str, Int }) => ({ smiles_column: [Str, "SMILES"], width: [Int, 160], height: [Int, 120], mols_per_row: [Int, 3], })); this.override({ tooltips: [], }); } tool_icon = tool_icon_hover; } //# sourceMappingURL=base_hover.js.map