chrome-devtools-frontend
Version:
Chrome DevTools UI
93 lines (75 loc) • 2.25 kB
text/typescript
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import {ObjectWrapper} from './Object.js';
import {reveal} from './Revealer.js';
let consoleInstance: Console|undefined;
export class Console extends ObjectWrapper<EventTypes> {
readonly #messagesInternal: Message[];
/**
* Instantiable via the instance() factory below.
*/
private constructor() {
super();
this.#messagesInternal = [];
}
static instance(opts?: {forceNew: boolean}): Console {
if (!consoleInstance || opts?.forceNew) {
consoleInstance = new Console();
}
return consoleInstance;
}
static removeInstance(): void {
consoleInstance = undefined;
}
addMessage(text: string, level: MessageLevel, show?: boolean): void {
const message = new Message(text, level || MessageLevel.Info, Date.now(), show || false);
this.#messagesInternal.push(message);
this.dispatchEventToListeners(Events.MessageAdded, message);
}
log(text: string): void {
this.addMessage(text, MessageLevel.Info);
}
warn(text: string): void {
this.addMessage(text, MessageLevel.Warning);
}
error(text: string): void {
this.addMessage(text, MessageLevel.Error, true);
}
messages(): Message[] {
return this.#messagesInternal;
}
show(): void {
void this.showPromise();
}
showPromise(): Promise<void> {
return reveal(this);
}
}
// TODO(crbug.com/1167717): Make this a const enum again
// eslint-disable-next-line rulesdir/const_enum
export enum Events {
MessageAdded = 'messageAdded',
}
export type EventTypes = {
[Events.MessageAdded]: Message,
};
// TODO(crbug.com/1167717): Make this a const enum again
// eslint-disable-next-line rulesdir/const_enum
export enum MessageLevel {
Info = 'info',
Warning = 'warning',
Error = 'error',
}
export class Message {
text: string;
level: MessageLevel;
timestamp: number;
show: boolean;
constructor(text: string, level: MessageLevel, timestamp: number, show: boolean) {
this.text = text;
this.level = level;
this.timestamp = (typeof timestamp === 'number') ? timestamp : Date.now();
this.show = show;
}
}