import { Document, Element } from "../../core/deno-dom.ts";
import { kPageWidth } from "../../config/constants.ts";
import { Format, FormatPandoc } from "../../config/types.ts";
import { Metadata } from "../../config/types.ts";
import { HtmlPostProcessResult } from "./types.ts";
import {
hasAdaptiveTheme,
hasTextHighlighting,
} from "../../quarto-core/text-highlighting.ts";
import { kHtmlEmptyPostProcessResult } from "./constants.ts";
const kAdaptiveTextHighlighting = "adaptive-text-highlighting";
const kTextHighlighting = "text-highlighting";
export function layoutFilterParams(
format: Format,
defaults: FormatPandoc | undefined,
) {
const params: Metadata = {};
const pageWidth = format.render[kPageWidth];
if (pageWidth) {
params[kPageWidth] = pageWidth;
}
if (defaults) {
if (hasAdaptiveTheme(defaults)) {
params[kAdaptiveTextHighlighting] = true;
}
if (hasTextHighlighting(defaults)) {
params[kTextHighlighting] = true;
}
}
return params;
}
export function overflowXPostprocessor(
doc: Document,
): Promise<HtmlPostProcessResult> {
const outputs = doc.querySelectorAll(".cell-output-display");
for (let i = 0; i < outputs.length; i++) {
const output = outputs[i] as Element;
const noOverflowX =
!!output.querySelector("select") ||
!!output.querySelector(".shiny-html-output") ||
!!output.querySelector(".rglWebGL");
if (noOverflowX) {
output.classList.add("no-overflow-x");
}
}
return Promise.resolve(kHtmlEmptyPostProcessResult);
}