Files
Automaaval/dist/zacatraz/_internal/panel/models/layout.ts
T
2026-03-14 21:48:05 +00:00

210 lines
6.0 KiB
TypeScript

import {div, px} from "@bokehjs/core/dom"
import {isArray} from "@bokehjs/core/util/types"
import {unreachable} from "@bokehjs/core/util/assert"
import {WidgetView} from "@bokehjs/models/widgets/widget"
import type {Markup} from "@bokehjs/models/widgets/markup"
import {LayoutDOM, LayoutDOMView} from "@bokehjs/models/layouts/layout_dom"
import type {UIElement} from "@bokehjs/models/ui/ui_element"
import type * as p from "@bokehjs/core/properties"
export class PanelMarkupView extends WidgetView {
declare model: Markup
container: HTMLDivElement
protected _initialized_stylesheets: Map<string, boolean>
override connect_signals(): void {
super.connect_signals()
const {width, height, min_height, max_height, margin, sizing_mode} = this.model.properties
this.on_change([width, height, min_height, max_height, margin, sizing_mode], () => {
set_size(this.el, this.model)
set_size(this.container, this.model, false)
})
}
override async lazy_initialize() {
await super.lazy_initialize()
if (this.provider.status == "not_started" || this.provider.status == "loading") {
this.provider.ready.connect(() => {
if (this.contains_tex_string(this.model.text)) {
this.render()
}
})
}
}
watch_stylesheets(): void {
this._initialized_stylesheets = new Map()
for (const stylesheet of this._applied_stylesheets) {
// @ts-expect-error: 'el' is protected
const style_el = stylesheet.el
if (style_el instanceof HTMLLinkElement) {
this._initialized_stylesheets.set(style_el.href, false)
style_el.addEventListener("load", () => {
this._initialized_stylesheets.set(style_el.href, true)
if ([...this._initialized_stylesheets.values()].every((v) => v)) {
this.style_redraw()
}
})
}
}
if (this._initialized_stylesheets.size == 0) {
this.style_redraw()
}
}
style_redraw(): void {}
has_math_disabled(): boolean {
return this.model.disable_math || !this.contains_tex_string(this.model.text)
}
override render(): void {
super.render()
set_size(this.el, this.model)
this.container = div()
set_size(this.container, this.model, false)
this.shadow_el.appendChild(this.container)
if (this.provider.status == "failed" || this.provider.status == "loaded") {
this._has_finished = true
}
}
}
export function set_size(el: HTMLElement, model: HTMLBox, adjust_margin: boolean = true): void {
let width_policy = model.width != null ? "fixed" : "fit"
let height_policy = model.height != null ? "fixed" : "fit"
const {sizing_mode, margin} = model
if (sizing_mode != null) {
if (sizing_mode == "fixed") {
width_policy = height_policy = "fixed"
} else if (sizing_mode == "stretch_both") {
width_policy = height_policy = "max"
} else if (sizing_mode == "stretch_width") {
width_policy = "max"
} else if (sizing_mode == "stretch_height") {
height_policy = "max"
} else {
switch (sizing_mode) {
case "scale_width": {
width_policy = "max"
height_policy = "min"
break
}
case "scale_height": {
width_policy = "min"
height_policy = "max"
break
}
case "scale_both": {
width_policy = "max"
height_policy = "max"
break
}
default: {
unreachable()
}
}
}
}
let wm: number, hm: number
if (!adjust_margin) {
hm = wm = 0
} else if (isArray(margin)) {
if (margin.length === 4) {
hm = margin[0] + margin[2]
wm = margin[1] + margin[3]
} else {
hm = margin[0]*2
wm = margin[1]*2
}
} else if (margin == null) {
hm = wm = 0
} else {
wm = hm = margin*2
}
if (width_policy == "fixed" && model.width != null) {
el.style.width = px(model.width)
} else if (width_policy == "max") {
el.style.width = wm != 0 ? `calc(100% - ${px(wm)})` : "100%"
}
if (model.min_width != null) {
el.style.minWidth = px(model.min_width)
}
if (model.max_width != null) {
el.style.maxWidth = px(model.max_width)
}
if (height_policy == "fixed" && model.height != null) {
el.style.height = px(model.height)
} else if (height_policy == "max") {
el.style.height = hm != 0 ? `calc(100% - ${px(hm)})` : "100%"
}
if (model.min_height != null) {
el.style.minHeight = px(model.min_height)
}
if (model.max_height != null) {
el.style.maxHeight = px(model.max_height)
}
}
export abstract class HTMLBoxView extends LayoutDOMView {
declare model: HTMLBox
protected _initialized_stylesheets: Map<string, boolean>
override connect_signals(): void {
super.connect_signals()
const {width, height, min_height, max_height, margin, sizing_mode} = this.model.properties
this.on_change([width, height, min_height, max_height, margin, sizing_mode], () => {
set_size(this.el, this.model)
})
}
override render(): void {
super.render()
set_size(this.el, this.model)
}
watch_stylesheets(): void {
this._initialized_stylesheets = new Map()
for (const stylesheet of this._applied_stylesheets) {
// @ts-expect-error: 'el' is protected
const style_el = stylesheet.el
if (style_el instanceof HTMLLinkElement) {
this._initialized_stylesheets.set(style_el.href, false)
style_el.addEventListener("load", () => {
this._initialized_stylesheets.set(style_el.href, true)
if ([...this._initialized_stylesheets.values()].every((v) => v)) {
this.style_redraw()
}
})
}
}
}
style_redraw(): void {}
get child_models(): UIElement[] {
return []
}
}
export namespace HTMLBox {
export type Attrs = p.AttrsOf<Props>
export type Props = LayoutDOM.Props
}
export interface HTMLBox extends HTMLBox.Attrs {}
export abstract class HTMLBox extends LayoutDOM {
declare properties: HTMLBox.Props
constructor(attrs?: Partial<HTMLBox.Attrs>) {
super(attrs)
}
}