mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-09 19:48:45 +01:00
102 lines
3.7 KiB
TypeScript
102 lines
3.7 KiB
TypeScript
|
/**
|
||
|
* Copyright (c) 2017 The xterm.js authors. All rights reserved.
|
||
|
* @license MIT
|
||
|
*/
|
||
|
|
||
|
// This file is a copy of the original xterm.js file, with the following changes:
|
||
|
// - removed the allowance for the scrollbar
|
||
|
|
||
|
import type { FitAddon as IFitApi } from "@xterm/addon-fit";
|
||
|
import type { ITerminalAddon, Terminal } from "@xterm/xterm";
|
||
|
import { IRenderDimensions } from "@xterm/xterm/src/browser/renderer/shared/Types";
|
||
|
|
||
|
interface ITerminalDimensions {
|
||
|
/**
|
||
|
* The number of rows in the terminal.
|
||
|
*/
|
||
|
rows: number;
|
||
|
|
||
|
/**
|
||
|
* The number of columns in the terminal.
|
||
|
*/
|
||
|
cols: number;
|
||
|
}
|
||
|
|
||
|
const MINIMUM_COLS = 2;
|
||
|
const MINIMUM_ROWS = 1;
|
||
|
|
||
|
export class FitAddon implements ITerminalAddon, IFitApi {
|
||
|
private _terminal: Terminal | undefined;
|
||
|
public noScrollbar: boolean = false;
|
||
|
|
||
|
public activate(terminal: Terminal): void {
|
||
|
this._terminal = terminal;
|
||
|
}
|
||
|
|
||
|
public dispose(): void {}
|
||
|
|
||
|
public fit(): void {
|
||
|
const dims = this.proposeDimensions();
|
||
|
if (!dims || !this._terminal || isNaN(dims.cols) || isNaN(dims.rows)) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// TODO: Remove reliance on private API
|
||
|
const core = (this._terminal as any)._core;
|
||
|
|
||
|
// Force a full render
|
||
|
if (this._terminal.rows !== dims.rows || this._terminal.cols !== dims.cols) {
|
||
|
core._renderService.clear();
|
||
|
this._terminal.resize(dims.cols, dims.rows);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public proposeDimensions(): ITerminalDimensions | undefined {
|
||
|
if (!this._terminal) {
|
||
|
return undefined;
|
||
|
}
|
||
|
|
||
|
if (!this._terminal.element || !this._terminal.element.parentElement) {
|
||
|
return undefined;
|
||
|
}
|
||
|
|
||
|
// TODO: Remove reliance on private API
|
||
|
const core = (this._terminal as any)._core;
|
||
|
const dims: IRenderDimensions = core._renderService.dimensions;
|
||
|
|
||
|
if (dims.css.cell.width === 0 || dims.css.cell.height === 0) {
|
||
|
return undefined;
|
||
|
}
|
||
|
|
||
|
// UPDATED CODE (removed reliance on FALLBACK_SCROLL_BAR_WIDTH in viewport)
|
||
|
const measuredScrollBarWidth =
|
||
|
core.viewport._viewportElement.offsetWidth - core.viewport._scrollArea.offsetWidth;
|
||
|
let scrollbarWidth = this._terminal.options.scrollback === 0 ? 0 : measuredScrollBarWidth;
|
||
|
if (this.noScrollbar) {
|
||
|
scrollbarWidth = 0;
|
||
|
}
|
||
|
// END UPDATED CODE
|
||
|
|
||
|
const parentElementStyle = window.getComputedStyle(this._terminal.element.parentElement);
|
||
|
const parentElementHeight = parseInt(parentElementStyle.getPropertyValue("height"));
|
||
|
const parentElementWidth = Math.max(0, parseInt(parentElementStyle.getPropertyValue("width")));
|
||
|
const elementStyle = window.getComputedStyle(this._terminal.element);
|
||
|
const elementPadding = {
|
||
|
top: parseInt(elementStyle.getPropertyValue("padding-top")),
|
||
|
bottom: parseInt(elementStyle.getPropertyValue("padding-bottom")),
|
||
|
right: parseInt(elementStyle.getPropertyValue("padding-right")),
|
||
|
left: parseInt(elementStyle.getPropertyValue("padding-left")),
|
||
|
};
|
||
|
const elementPaddingVer = elementPadding.top + elementPadding.bottom;
|
||
|
const elementPaddingHor = elementPadding.right + elementPadding.left;
|
||
|
const availableHeight = parentElementHeight - elementPaddingVer;
|
||
|
// UPDATED added 6 here (adjustment in xterm.css, right: -6px for scrollbar)
|
||
|
const availableWidth = parentElementWidth - elementPaddingHor - scrollbarWidth - 6;
|
||
|
const geometry = {
|
||
|
cols: Math.max(MINIMUM_COLS, Math.floor(availableWidth / dims.css.cell.width)),
|
||
|
rows: Math.max(MINIMUM_ROWS, Math.floor(availableHeight / dims.css.cell.height)),
|
||
|
};
|
||
|
return geometry;
|
||
|
}
|
||
|
}
|