Source code
Revision control
Copy as Markdown
Other Tools
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
/* Checks to see if the root element is available and
* if the element is visible. We check the width of the element
* because it is more reliable than either checking a focus state or
* the visibleState or hidden property.
*/
export function isVisible() {
const el = document.querySelector("#mount");
return !!(el && el.getBoundingClientRect().width > 0);
}
/* Gets the line numbers width in the code editor
*/
export function getLineNumberWidth(editor) {
const { gutters } = editor.display;
const lineNumbers = gutters.querySelector(".CodeMirror-linenumbers");
return lineNumbers?.clientWidth;
}
/**
* Forces the breakpoint gutter to be the same size as the line
* numbers gutter. Editor CSS will absolutely position the gutter
* beneath the line numbers. This makes it easy to be flexible with
* how we overlay breakpoints.
*/
export function resizeBreakpointGutter(editor) {
const { gutters } = editor.display;
const breakpoints = gutters.querySelector(".breakpoints");
if (breakpoints) {
breakpoints.style.width = `${getLineNumberWidth(editor)}px`;
}
}
/**
* Updates CSS variables to reflect the current dimensions of the editor
* and its gutter.
* This is used to force the left toggle button in source header to be the same size
* as the line numbers gutter, and to properly position the conditional panel.
*/
export function updateEditorSizeCssVariables(cmEditorEl) {
document.documentElement.style.setProperty(
"--cm-gutter-width",
`${cmEditorEl.querySelector(".cm-gutters").clientWidth}px`
);
document.documentElement.style.setProperty(
"--cm-editor-scroller-width",
// We want the scroller width *without* a possible vertical scrollbar
`${cmEditorEl.querySelector(".cm-scroller").clientWidth}px`
);
}