123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- 'use strict';
- const ansiEscapes = module.exports;
- // TODO: remove this in the next major version
- module.exports.default = ansiEscapes;
-
- const ESC = '\u001B[';
- const OSC = '\u001B]';
- const BEL = '\u0007';
- const SEP = ';';
- const isTerminalApp = process.env.TERM_PROGRAM === 'Apple_Terminal';
-
- ansiEscapes.cursorTo = (x, y) => {
- if (typeof x !== 'number') {
- throw new TypeError('The `x` argument is required');
- }
-
- if (typeof y !== 'number') {
- return ESC + (x + 1) + 'G';
- }
-
- return ESC + (y + 1) + ';' + (x + 1) + 'H';
- };
-
- ansiEscapes.cursorMove = (x, y) => {
- if (typeof x !== 'number') {
- throw new TypeError('The `x` argument is required');
- }
-
- let ret = '';
-
- if (x < 0) {
- ret += ESC + (-x) + 'D';
- } else if (x > 0) {
- ret += ESC + x + 'C';
- }
-
- if (y < 0) {
- ret += ESC + (-y) + 'A';
- } else if (y > 0) {
- ret += ESC + y + 'B';
- }
-
- return ret;
- };
-
- ansiEscapes.cursorUp = (count = 1) => ESC + count + 'A';
- ansiEscapes.cursorDown = (count = 1) => ESC + count + 'B';
- ansiEscapes.cursorForward = (count = 1) => ESC + count + 'C';
- ansiEscapes.cursorBackward = (count = 1) => ESC + count + 'D';
-
- ansiEscapes.cursorLeft = ESC + 'G';
- ansiEscapes.cursorSavePosition = isTerminalApp ? '\u001B7' : ESC + 's';
- ansiEscapes.cursorRestorePosition = isTerminalApp ? '\u001B8' : ESC + 'u';
- ansiEscapes.cursorGetPosition = ESC + '6n';
- ansiEscapes.cursorNextLine = ESC + 'E';
- ansiEscapes.cursorPrevLine = ESC + 'F';
- ansiEscapes.cursorHide = ESC + '?25l';
- ansiEscapes.cursorShow = ESC + '?25h';
-
- ansiEscapes.eraseLines = count => {
- let clear = '';
-
- for (let i = 0; i < count; i++) {
- clear += ansiEscapes.eraseLine + (i < count - 1 ? ansiEscapes.cursorUp() : '');
- }
-
- if (count) {
- clear += ansiEscapes.cursorLeft;
- }
-
- return clear;
- };
-
- ansiEscapes.eraseEndLine = ESC + 'K';
- ansiEscapes.eraseStartLine = ESC + '1K';
- ansiEscapes.eraseLine = ESC + '2K';
- ansiEscapes.eraseDown = ESC + 'J';
- ansiEscapes.eraseUp = ESC + '1J';
- ansiEscapes.eraseScreen = ESC + '2J';
- ansiEscapes.scrollUp = ESC + 'S';
- ansiEscapes.scrollDown = ESC + 'T';
-
- ansiEscapes.clearScreen = '\u001Bc';
-
- ansiEscapes.clearTerminal = process.platform === 'win32' ?
- `${ansiEscapes.eraseScreen}${ESC}0f` :
- // 1. Erases the screen (Only done in case `2` is not supported)
- // 2. Erases the whole screen including scrollback buffer
- // 3. Moves cursor to the top-left position
- // More info: https://www.real-world-systems.com/docs/ANSIcode.html
- `${ansiEscapes.eraseScreen}${ESC}3J${ESC}H`;
-
- ansiEscapes.beep = BEL;
-
- ansiEscapes.link = (text, url) => {
- return [
- OSC,
- '8',
- SEP,
- SEP,
- url,
- BEL,
- text,
- OSC,
- '8',
- SEP,
- SEP,
- BEL
- ].join('');
- };
-
- ansiEscapes.image = (buffer, options = {}) => {
- let ret = `${OSC}1337;File=inline=1`;
-
- if (options.width) {
- ret += `;width=${options.width}`;
- }
-
- if (options.height) {
- ret += `;height=${options.height}`;
- }
-
- if (options.preserveAspectRatio === false) {
- ret += ';preserveAspectRatio=0';
- }
-
- return ret + ':' + buffer.toString('base64') + BEL;
- };
-
- ansiEscapes.iTerm = {
- setCwd: (cwd = process.cwd()) => `${OSC}50;CurrentDir=${cwd}${BEL}`,
-
- annotation: (message, options = {}) => {
- let ret = `${OSC}1337;`;
-
- const hasX = typeof options.x !== 'undefined';
- const hasY = typeof options.y !== 'undefined';
- if ((hasX || hasY) && !(hasX && hasY && typeof options.length !== 'undefined')) {
- throw new Error('`x`, `y` and `length` must be defined when `x` or `y` is defined');
- }
-
- message = message.replace(/\|/g, '');
-
- ret += options.isHidden ? 'AddHiddenAnnotation=' : 'AddAnnotation=';
-
- if (options.length > 0) {
- ret +=
- (hasX ?
- [message, options.length, options.x, options.y] :
- [options.length, message]).join('|');
- } else {
- ret += message;
- }
-
- return ret + BEL;
- }
- };
|