From 48e8ffd7292288d070bdcc71f646f05ccba30d9d Mon Sep 17 00:00:00 2001 From: Eugene Pankov Date: Wed, 5 Jul 2017 11:26:28 +0200 Subject: [PATCH] ligatures switch (fixes #51) --- .../src/components/terminalTab.component.ts | 23 +++++++++++++++++++ terminus-terminal/src/config.ts | 1 + terminus-terminal/src/hterm.ts | 6 ----- terminus-terminal/src/hterm.userCSS.scss | 4 ---- 4 files changed, 24 insertions(+), 10 deletions(-) diff --git a/terminus-terminal/src/components/terminalTab.component.ts b/terminus-terminal/src/components/terminalTab.component.ts index f78c8e23..b8fba14c 100644 --- a/terminus-terminal/src/components/terminalTab.component.ts +++ b/terminus-terminal/src/components/terminalTab.component.ts @@ -1,3 +1,4 @@ +const dataurl = require('dataurl') import { BehaviorSubject, Subject, Subscription } from 'rxjs' import 'rxjs/add/operator/bufferTime' import { Component, NgZone, Inject, Optional, ViewChild, HostBinding, Input } from '@angular/core' @@ -261,6 +262,28 @@ export class TerminalTabComponent extends BaseTabComponent { preferenceManager.set('cursor-color', config.terminal.colorScheme.cursor) } + let css = require('../hterm.userCSS.scss') + if (!config.terminal.ligatures) { + css += ` + * { + font-feature-settings: "liga" 0; + font-variant-ligatures: none; + } + ` + } else { + css += ` + * { + font-feature-settings: "liga" 1; + font-variant-ligatures: initial; + } + ` + } + preferenceManager.set('user-css', dataurl.convert({ + data: css, + mimetype: 'text/css', + charset: 'utf8', + })) + this.hterm.setBracketedPaste(config.terminal.bracketedPaste) } diff --git a/terminus-terminal/src/config.ts b/terminus-terminal/src/config.ts index 3569c83f..914a8224 100644 --- a/terminus-terminal/src/config.ts +++ b/terminus-terminal/src/config.ts @@ -7,6 +7,7 @@ export class TerminalConfigProvider extends ConfigProvider { bell: 'off', bracketedPaste: false, background: 'theme', + ligatures: false, colorScheme: { __nonStructural: true, name: 'Material', diff --git a/terminus-terminal/src/hterm.ts b/terminus-terminal/src/hterm.ts index cbc92daf..f0e6617f 100644 --- a/terminus-terminal/src/hterm.ts +++ b/terminus-terminal/src/hterm.ts @@ -1,4 +1,3 @@ -const dataurl = require('dataurl') export const hterm = require('hterm-umdjs') hterm.hterm.defaultStorage = new hterm.lib.Storage.Memory() export const preferenceManager = new hterm.hterm.PreferenceManager('default') @@ -16,11 +15,6 @@ hterm.hterm.VT.ESC['k'] = function (parseState) { parseState.func = parseOSC } -preferenceManager.set('user-css', dataurl.convert({ - data: require('./hterm.userCSS.scss'), - mimetype: 'text/css', - charset: 'utf8', -})) preferenceManager.set('background-color', '#1D272D') preferenceManager.set('color-palette-overrides', { 0: '#1D272D', diff --git a/terminus-terminal/src/hterm.userCSS.scss b/terminus-terminal/src/hterm.userCSS.scss index 010c55f3..662fef2c 100644 --- a/terminus-terminal/src/hterm.userCSS.scss +++ b/terminus-terminal/src/hterm.userCSS.scss @@ -6,10 +6,6 @@ a:hover { text-decoration: underline; } -* { - font-feature-settings: "liga" 0; // disable ligatures (they break monospacing) -} - x-screen { transition: 0.125s ease background; }