Skip to content

xterm.js addon for ensuring webfonts load

Notifications You must be signed in to change notification settings

LiveConfig/xterm-webfont

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

About

xterm-webfont is an xterm.js addon for ensuring that webfonts load correctly before attempting to draw characters in an xterm instance. It is only necessary when using xterm 3.0 and above. Prior to 3.0, xterm drew characters directly to the DOM. Now that xterm draws characters to a canvas element, you cannot rely on the browser to eventually load and redraw needed webfonts. xterm-webfont will attempt to delay opening the xterm instance until both the normal and bold variants of the selected font family become available. It does so using the FontFaceObserver library.

The current (2.1.x) version of xterm-webfont is a fork of the original xterm-webfont module by Vincent Woo and only adjusted for compatibility with xterm.js 5.0 and later. For xterm.js 4.x use xterm-webfont 2.0.0.

Usage

xterm-webfont is a CommonJS module available on NPM or Yarn. Install it and import (or require) it like so:

npm install @liveconfig/xterm-webfont
import { Terminal } from 'xterm'
import * as XtermWebfont from '@liveconfig/xterm-webfont'
// alternatively, var WebfontLoader = require('xterm-webfont')
const term = new Terminal({ fontFamily: 'Roboto Mono' })
term.loadAddon(new XtermWebfont())

Then, where you would normally initialize xterm like so:

term.open(myElement)

do

term.loadWebfontAndOpen(myElement)

Details

The default timeout of 3 seconds from FontFaceObserver is used. If the font fails to load both variants within that time, the Courier font is used instead.

loadWebfontAndOpen returns a promise that resolves when the terminal opens. The resolution value of this promise is the instance of the terminal.

About

xterm.js addon for ensuring webfonts load

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%