Son CV dans un terminal web en Javascript!
https://terminal-cv.gregandev.fr
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
180 lines
4.6 KiB
180 lines
4.6 KiB
2 years ago
|
"use strict";
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
exports._setStdio = _setStdio;
|
||
|
exports.writeOut = writeOut;
|
||
|
exports.persistMessage = persistMessage;
|
||
|
exports.updateSpinner = updateSpinner;
|
||
|
exports.persistSpinner = persistSpinner;
|
||
|
exports.resetWindow = resetWindow;
|
||
|
exports.table = table;
|
||
|
exports.isTTY = void 0;
|
||
|
|
||
|
function _readline() {
|
||
|
const data = _interopRequireDefault(require("readline"));
|
||
|
|
||
|
_readline = function () {
|
||
|
return data;
|
||
|
};
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
function _ora() {
|
||
|
const data = _interopRequireDefault(require("ora"));
|
||
|
|
||
|
_ora = function () {
|
||
|
return data;
|
||
|
};
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
function _stringWidth() {
|
||
|
const data = _interopRequireDefault(require("string-width"));
|
||
|
|
||
|
_stringWidth = function () {
|
||
|
return data;
|
||
|
};
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
var _utils = require("./utils");
|
||
|
|
||
|
var emoji = _interopRequireWildcard(require("./emoji"));
|
||
|
|
||
|
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
|
||
|
|
||
|
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
||
|
|
||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
|
||
|
const isTTY = // $FlowFixMe
|
||
|
process.env.NODE_ENV !== 'test' && process.stdout.isTTY;
|
||
|
exports.isTTY = isTTY;
|
||
|
let stdout = process.stdout;
|
||
|
let stderr = process.stderr; // Some state so we clear the output properly
|
||
|
|
||
|
let lineCount = 0;
|
||
|
let errorLineCount = 0;
|
||
|
let statusPersisted = false;
|
||
|
|
||
|
function _setStdio(stdoutLike, stderrLike) {
|
||
|
stdout = stdoutLike;
|
||
|
stderr = stderrLike;
|
||
|
}
|
||
|
|
||
|
let spinner = (0, _ora().default)({
|
||
|
color: 'green',
|
||
|
stream: stdout,
|
||
|
discardStdin: false
|
||
|
});
|
||
|
let persistedMessages = [];
|
||
|
|
||
|
function writeOut(message, isError = false) {
|
||
|
let processedMessage = message + '\n';
|
||
|
let hasSpinner = spinner.isSpinning; // Stop spinner so we don't duplicate it
|
||
|
|
||
|
if (hasSpinner) {
|
||
|
spinner.stop();
|
||
|
}
|
||
|
|
||
|
let lines = (0, _utils.countLines)(message);
|
||
|
|
||
|
if (isError) {
|
||
|
stderr.write(processedMessage);
|
||
|
errorLineCount += lines;
|
||
|
} else {
|
||
|
stdout.write(processedMessage);
|
||
|
lineCount += lines;
|
||
|
} // Restart the spinner
|
||
|
|
||
|
|
||
|
if (hasSpinner) {
|
||
|
spinner.start();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function persistMessage(message) {
|
||
|
if (persistedMessages.includes(message)) return;
|
||
|
persistedMessages.push(message);
|
||
|
writeOut(message);
|
||
|
}
|
||
|
|
||
|
function updateSpinner(message) {
|
||
|
// This helps the spinner play well with the tests
|
||
|
if (!isTTY) {
|
||
|
writeOut(message);
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
spinner.text = message + '\n';
|
||
|
|
||
|
if (!spinner.isSpinning) {
|
||
|
spinner.start();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function persistSpinner(name, status, message) {
|
||
|
spinner.stopAndPersist({
|
||
|
symbol: emoji[status],
|
||
|
text: message
|
||
|
});
|
||
|
statusPersisted = true;
|
||
|
}
|
||
|
|
||
|
function clearStream(stream, lines) {
|
||
|
if (!isTTY) return;
|
||
|
|
||
|
_readline().default.moveCursor(stream, 0, -lines);
|
||
|
|
||
|
_readline().default.clearScreenDown(stream);
|
||
|
} // Reset the window's state
|
||
|
|
||
|
|
||
|
function resetWindow() {
|
||
|
if (!isTTY) return; // If status has been persisted we add a line
|
||
|
// Otherwise final states would remain in the terminal for rebuilds
|
||
|
|
||
|
if (statusPersisted) {
|
||
|
lineCount++;
|
||
|
statusPersisted = false;
|
||
|
}
|
||
|
|
||
|
clearStream(stderr, errorLineCount);
|
||
|
errorLineCount = 0;
|
||
|
clearStream(stdout, lineCount);
|
||
|
lineCount = 0;
|
||
|
|
||
|
for (let m of persistedMessages) {
|
||
|
writeOut(m);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function table(columns, table) {
|
||
|
// Measure column widths
|
||
|
let colWidths = [];
|
||
|
|
||
|
for (let row of table) {
|
||
|
let i = 0;
|
||
|
|
||
|
for (let item of row) {
|
||
|
colWidths[i] = Math.max(colWidths[i] || 0, (0, _stringWidth().default)(item));
|
||
|
i++;
|
||
|
}
|
||
|
} // Render rows
|
||
|
|
||
|
|
||
|
for (let row of table) {
|
||
|
let items = row.map((item, i) => {
|
||
|
// Add padding between columns unless the alignment is the opposite to the
|
||
|
// next column and pad to the column width.
|
||
|
let padding = !columns[i + 1] || columns[i + 1].align === columns[i].align ? 4 : 0;
|
||
|
return (0, _utils.pad)(item, colWidths[i] + padding, columns[i].align);
|
||
|
});
|
||
|
writeOut(items.join(''));
|
||
|
}
|
||
|
}
|