UNPKG

chrome-devtools-frontend

Version:
93 lines (75 loc) 2.25 kB
// 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; } }