UNPKG

@theia/core

Version:

Theia is a cloud & desktop IDE framework implemented in TypeScript.

227 lines • 9.77 kB
"use strict"; // ***************************************************************************** // Copyright (C) 2018 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 WITH Classpath-exception-2.0 // ***************************************************************************** Object.defineProperty(exports, "__esModule", { value: true }); exports.TheiaDockPanel = exports.BOTTOM_AREA_ID = exports.MAIN_AREA_ID = exports.ACTIVE_TABBAR_CLASS = exports.MAXIMIZED_CLASS = void 0; const algorithm_1 = require("@phosphor/algorithm"); const widgets_1 = require("@phosphor/widgets"); const signaling_1 = require("@phosphor/signaling"); const disposable_1 = require("../../common/disposable"); const widgets_2 = require("../widgets"); const common_1 = require("../../common"); exports.MAXIMIZED_CLASS = 'theia-maximized'; exports.ACTIVE_TABBAR_CLASS = 'theia-tabBar-active'; const VISIBLE_MENU_MAXIMIZED_CLASS = 'theia-visible-menu-maximized'; exports.MAIN_AREA_ID = 'theia-main-content-panel'; exports.BOTTOM_AREA_ID = 'theia-bottom-content-panel'; /** * This specialization of DockPanel adds various events that are used for implementing the * side panels of the application shell. */ class TheiaDockPanel extends widgets_1.DockPanel { constructor(options, preferences) { super(options); this.preferences = preferences; /** * Emitted when a widget is added to the panel. */ this.widgetAdded = new signaling_1.Signal(this); /** * Emitted when a widget is activated by calling `activateWidget`. */ this.widgetActivated = new signaling_1.Signal(this); /** * Emitted when a widget is removed from the panel. */ this.widgetRemoved = new signaling_1.Signal(this); this.onDidToggleMaximizedEmitter = new common_1.Emitter(); this.onDidToggleMaximized = this.onDidToggleMaximizedEmitter.event; this.onDidChangeCurrentEmitter = new common_1.Emitter(); this.toDisposeOnMarkAsCurrent = new disposable_1.DisposableCollection(); this.toDisposeOnToggleMaximized = new disposable_1.DisposableCollection(); this['_onCurrentChanged'] = (sender, args) => { this.markAsCurrent(args.currentTitle || undefined); super['_onCurrentChanged'](sender, args); }; this['_onTabActivateRequested'] = (sender, args) => { this.markAsCurrent(args.title); super['_onTabActivateRequested'](sender, args); }; if (preferences) { preferences.onPreferenceChanged(preference => { if (!this.isElectron() && preference.preferenceName === 'window.menuBarVisibility' && (preference.newValue === 'visible' || preference.oldValue === 'visible')) { this.handleMenuBarVisibility(preference.newValue); } }); } } get onDidChangeCurrent() { return this.onDidChangeCurrentEmitter.event; } isElectron() { return common_1.environment.electron.is(); } handleMenuBarVisibility(newValue) { const areaContainer = this.node.parentElement; const maximizedElement = this.getMaximizedElement(); if (areaContainer === maximizedElement) { if (newValue === 'visible') { this.addClass(VISIBLE_MENU_MAXIMIZED_CLASS); } else { this.removeClass(VISIBLE_MENU_MAXIMIZED_CLASS); } } } get currentTitle() { return this._currentTitle; } get currentTabBar() { return this._currentTitle && this.findTabBar(this._currentTitle); } findTabBar(title) { return (0, algorithm_1.find)(this.tabBars(), bar => algorithm_1.ArrayExt.firstIndexOf(bar.titles, title) > -1); } markAsCurrent(title) { this.toDisposeOnMarkAsCurrent.dispose(); this._currentTitle = title; this.markActiveTabBar(title); if (title) { const resetCurrent = () => this.markAsCurrent(undefined); title.owner.disposed.connect(resetCurrent); this.toDisposeOnMarkAsCurrent.push(disposable_1.Disposable.create(() => title.owner.disposed.disconnect(resetCurrent))); } this.onDidChangeCurrentEmitter.fire(title); } markActiveTabBar(title) { const tabBars = (0, algorithm_1.toArray)(this.tabBars()); tabBars.forEach(tabBar => tabBar.removeClass(exports.ACTIVE_TABBAR_CLASS)); const activeTabBar = title && this.findTabBar(title); if (activeTabBar) { activeTabBar.addClass(exports.ACTIVE_TABBAR_CLASS); } else if (tabBars.length > 0) { // At least one tabbar needs to be active tabBars[0].addClass(exports.ACTIVE_TABBAR_CLASS); } } addWidget(widget, options) { if (this.mode === 'single-document' && widget.parent === this) { return; } super.addWidget(widget, options); this.widgetAdded.emit(widget); this.markActiveTabBar(widget.title); } activateWidget(widget) { super.activateWidget(widget); this.widgetActivated.emit(widget); this.markActiveTabBar(widget.title); } onChildRemoved(msg) { super.onChildRemoved(msg); this.widgetRemoved.emit(msg.child); } nextTabBarWidget(widget) { const current = this.findTabBar(widget.title); const next = current && this.nextTabBarInPanel(current); return next && next.currentTitle && next.currentTitle.owner || undefined; } nextTabBarInPanel(tabBar) { const tabBars = (0, algorithm_1.toArray)(this.tabBars()); const index = tabBars.indexOf(tabBar); if (index !== -1) { return tabBars[index + 1]; } return undefined; } previousTabBarWidget(widget) { const current = this.findTabBar(widget.title); const previous = current && this.previousTabBarInPanel(current); return previous && previous.currentTitle && previous.currentTitle.owner || undefined; } previousTabBarInPanel(tabBar) { const tabBars = (0, algorithm_1.toArray)(this.tabBars()); const index = tabBars.indexOf(tabBar); if (index !== -1) { return tabBars[index - 1]; } return undefined; } toggleMaximized() { var _a; const areaContainer = this.node.parentElement; if (!areaContainer) { return; } const maximizedElement = this.getMaximizedElement(); if (areaContainer === maximizedElement) { this.toDisposeOnToggleMaximized.dispose(); return; } if (this.isAttached) { widgets_2.UnsafeWidgetUtilities.detach(this); } maximizedElement.style.display = 'block'; this.addClass(exports.MAXIMIZED_CLASS); const preference = (_a = this.preferences) === null || _a === void 0 ? void 0 : _a.get('window.menuBarVisibility'); if (!this.isElectron() && preference === 'visible') { this.addClass(VISIBLE_MENU_MAXIMIZED_CLASS); } widgets_2.UnsafeWidgetUtilities.attach(this, maximizedElement); this.fit(); this.onDidToggleMaximizedEmitter.fire(this); this.toDisposeOnToggleMaximized.push(disposable_1.Disposable.create(() => { maximizedElement.style.display = 'none'; this.removeClass(exports.MAXIMIZED_CLASS); this.onDidToggleMaximizedEmitter.fire(this); if (!this.isElectron()) { this.removeClass(VISIBLE_MENU_MAXIMIZED_CLASS); } if (this.isAttached) { widgets_2.UnsafeWidgetUtilities.detach(this); } widgets_2.UnsafeWidgetUtilities.attach(this, areaContainer); this.fit(); })); const layout = this.layout; if (layout instanceof widgets_1.DockLayout) { const onResize = layout['onResize']; layout['onResize'] = () => onResize.bind(layout)(widgets_1.Widget.ResizeMessage.UnknownSize); this.toDisposeOnToggleMaximized.push(disposable_1.Disposable.create(() => layout['onResize'] = onResize)); } const removedListener = () => { if (!this.widgets().next()) { this.toDisposeOnToggleMaximized.dispose(); } }; this.widgetRemoved.connect(removedListener); this.toDisposeOnToggleMaximized.push(disposable_1.Disposable.create(() => this.widgetRemoved.disconnect(removedListener))); } getMaximizedElement() { if (!this.maximizedElement) { this.maximizedElement = document.createElement('div'); this.maximizedElement.style.display = 'none'; document.body.appendChild(this.maximizedElement); } return this.maximizedElement; } } exports.TheiaDockPanel = TheiaDockPanel; (function (TheiaDockPanel) { TheiaDockPanel.Factory = Symbol('TheiaDockPanel#Factory'); })(TheiaDockPanel = exports.TheiaDockPanel || (exports.TheiaDockPanel = {})); //# sourceMappingURL=theia-dock-panel.js.map