aboutsummaryrefslogtreecommitdiff
path: root/node_modules/terminal-link/index.js
diff options
context:
space:
mode:
authorJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
committerJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
commit080c5819d87b933816d724a83f3bf4f1686770a7 (patch)
tree4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/terminal-link/index.js
parent5ac7049a9d30733165cc212dee308163c2a14644 (diff)
parentd003b82235a9329f912522a2f70aa950dfce4998 (diff)
downloadLYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz
LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/terminal-link/index.js')
-rw-r--r--node_modules/terminal-link/index.js23
1 files changed, 23 insertions, 0 deletions
diff --git a/node_modules/terminal-link/index.js b/node_modules/terminal-link/index.js
new file mode 100644
index 0000000..7bbc9cb
--- /dev/null
+++ b/node_modules/terminal-link/index.js
@@ -0,0 +1,23 @@
+'use strict';
+const ansiEscapes = require('ansi-escapes');
+const supportsHyperlinks = require('supports-hyperlinks');
+
+const terminalLink = (text, url, {target = 'stdout', ...options} = {}) => {
+ if (!supportsHyperlinks[target]) {
+ // If the fallback has been explicitly disabled, don't modify the text itself.
+ if (options.fallback === false) {
+ return text;
+ }
+
+ return typeof options.fallback === 'function' ? options.fallback(text, url) : `${text} (\u200B${url}\u200B)`;
+ }
+
+ return ansiEscapes.link(text, url);
+};
+
+module.exports = (text, url, options = {}) => terminalLink(text, url, options);
+
+module.exports.stderr = (text, url, options = {}) => terminalLink(text, url, {target: 'stderr', ...options});
+
+module.exports.isSupported = supportsHyperlinks.stdout;
+module.exports.stderr.isSupported = supportsHyperlinks.stderr;