create-expo-cljs-app
Version:
Create a react native application with Expo and Shadow-CLJS!
68 lines (59 loc) • 1.82 kB
Flow
/**
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @format
* @flow
*/
/* eslint-disable no-console */
;
const chalk = require('chalk');
import type {Terminal} from 'metro-core';
const groupStack = [];
let collapsedGuardTimer;
module.exports = (terminal: Terminal, level: string, ...data: Array<mixed>) => {
const logFunction = console[level] && level !== 'trace' ? level : 'log';
const color =
level === 'error'
? chalk.inverse.red
: level === 'warn'
? chalk.inverse.yellow
: chalk.inverse.white;
if (level === 'group') {
groupStack.push(level);
} else if (level === 'groupCollapsed') {
groupStack.push(level);
clearTimeout(collapsedGuardTimer);
// Inform users that logs get swallowed if they forget to call `groupEnd`.
collapsedGuardTimer = setTimeout(() => {
if (groupStack.includes('groupCollapsed')) {
terminal.log(
chalk.inverse.yellow.bold(' WARN '),
'Expected `console.groupEnd` to be called after `console.groupCollapsed`.',
);
groupStack.length = 0;
}
}, 3000);
return;
} else if (level === 'groupEnd') {
groupStack.pop();
if (!groupStack.length) {
clearTimeout(collapsedGuardTimer);
}
return;
}
if (!groupStack.includes('groupCollapsed')) {
// Remove excess whitespace at the end of a log message, if possible.
const lastItem = data[data.length - 1];
if (typeof lastItem === 'string') {
data[data.length - 1] = lastItem.trimEnd();
}
terminal.log(
color.bold(` ${logFunction.toUpperCase()} `) +
''.padEnd(groupStack.length * 2, ' '),
...data,
);
}
};