// ***************************************************************************** // Copyright (C) 2019 TypeFox and others. // // This program and the accompanying materials are made available under the // terms of the Eclipse Public License v. 2.0 which is available at // http://www.eclipse.org/legal/epl-2.0. // // This Source Code may also be made available under the following Secondary // Licenses when the conditions for such availability set forth in the Eclipse // Public License v. 2.0 are satisfied: GNU General Public License, version 2 // with the GNU Classpath Exception which is available at // https://www.gnu.org/software/classpath/license.html. // // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0 // ***************************************************************************** import * as React from '@theia/core/shared/react'; import { DisposableCollection } from '@theia/core'; import { NotificationManager, NotificationUpdateEvent } from './notifications-manager'; import { NotificationComponent } from './notification-component'; import { CorePreferences } from '@theia/core/lib/common'; import { ContextMenuRenderer } from '@theia/core/lib/browser'; export interface NotificationToastsComponentProps { readonly manager: NotificationManager; readonly corePreferences: CorePreferences; readonly contextMenuRenderer: ContextMenuRenderer; } type NotificationToastsComponentState = Pick>; export class NotificationToastsComponent extends React.Component { constructor(props: NotificationToastsComponentProps) { super(props); this.state = { toasts: [], visibilityState: 'hidden' }; } protected readonly toDisposeOnUnmount = new DisposableCollection(); override async componentDidMount(): Promise { this.toDisposeOnUnmount.push( this.props.manager.onUpdated(({ toasts, visibilityState }) => { visibilityState = this.props.corePreferences['workbench.silentNotifications'] ? 'hidden' : visibilityState; this.setState({ toasts: toasts.slice(-3), visibilityState }); }) ); } override componentWillUnmount(): void { this.toDisposeOnUnmount.dispose(); } override render(): React.ReactNode { return (
{this.state.toasts.map(notification => )}
); } }