mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-19 21:11:32 +01:00
4be8a1e37e
move codeedit to directory. new useLongClick hook. show quick navigation for directoryview on longclick of folder icon. lots more generic stuff for header new fitaddon for xtermjs more fixes for xtermjs scrollbars
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;
|
|
}
|
|
}
|