Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1058)

Unified Diff: Source/devtools/front_end/main/App.js

Issue 307623003: [DevTools] Apps implementation. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « Source/devtools/front_end/inspector.html ('k') | Source/devtools/front_end/main/Main.js » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Source/devtools/front_end/main/App.js
diff --git a/Source/devtools/front_end/main/App.js b/Source/devtools/front_end/main/App.js
new file mode 100644
index 0000000000000000000000000000000000000000..9a551d50411ee360909cc76b8c6d3e5a5368b244
--- /dev/null
+++ b/Source/devtools/front_end/main/App.js
@@ -0,0 +1,254 @@
+// 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.
+
+/**
+ * @constructor
+ */
+WebInspector.App = function()
+{
+};
+
+WebInspector.App.prototype = {
+ createRootView: function()
+ {
+ },
+
+ createGlobalStatusBarItems: function()
+ {
+ },
+
+ presentUI: function()
+ {
+ WebInspector.inspectorView.showInitialPanel();
+
+ WebInspector.overridesSupport.applyInitialOverrides();
+ if (WebInspector.overridesSupport.hasActiveOverrides())
+ WebInspector.inspectorView.showViewInDrawer("emulation", true);
+ },
+
+ appendInspectStatusBarItem: function()
+ {
+ if (WebInspector.inspectElementModeController)
+ WebInspector.inspectorView.appendToLeftToolbar(WebInspector.inspectElementModeController.toggleSearchButton.element);
+ },
+
+ appendSettingsStatusBarItem: function()
+ {
+ WebInspector.inspectorView.appendToRightToolbar(WebInspector.settingsController.statusBarItem);
+ }
+};
+
+/**
+ * @type {!WebInspector.App}
+ */
+WebInspector.app;
+
+
+/**
+ * @constructor
+ * @extends {WebInspector.App}
+ */
+WebInspector.SimpleApp = function()
+{
+ WebInspector.App.call(this);
+};
+
+WebInspector.SimpleApp.prototype = {
+ createGlobalStatusBarItems: function()
+ {
+ this.appendInspectStatusBarItem();
+ this.appendSettingsStatusBarItem();
+ },
+
+ createRootView: function()
+ {
+ var rootView = new WebInspector.RootView();
+ WebInspector.inspectorView.show(rootView.element);
+ rootView.attachToBody();
+ },
+
+ __proto__: WebInspector.App.prototype
+};
+
+
+/**
+ * @constructor
+ * @extends {WebInspector.App}
+ */
+WebInspector.AdvancedApp = function()
pfeldman 2014/05/28 15:12:01 These all should be different files.
+{
+ WebInspector.App.call(this);
+};
+
+WebInspector.AdvancedApp.prototype = {
+ createGlobalStatusBarItems: function()
+ {
+ this.appendInspectStatusBarItem();
+
+ if (WebInspector.experimentsSettings.responsiveDesign.isEnabled()) {
+ this._toggleResponsiveDesignButton = new WebInspector.StatusBarButton(WebInspector.UIString("Responsive design mode."), "responsive-design-status-bar-item");
+ this._toggleResponsiveDesignButton.toggled = WebInspector.overridesSupport.settings.overrideDeviceMetrics.get();
+ this._toggleResponsiveDesignButton.addEventListener("click", this._toggleResponsiveDesign, this);
+ WebInspector.inspectorView.appendToLeftToolbar(this._toggleResponsiveDesignButton.element);
+ WebInspector.overridesSupport.settings.overrideDeviceMetrics.addChangeListener(this._overrideDeviceMetricsChanged, this);
+ }
+
+ this.appendSettingsStatusBarItem();
+ WebInspector.inspectorView.appendToRightToolbar(/** @type {!Element} */ (WebInspector.dockController.element));
+ },
+
+ _toggleResponsiveDesign: function()
+ {
+ WebInspector.overridesSupport.settings.overrideDeviceMetrics.set(!this._toggleResponsiveDesignButton.toggled);
+ },
+
+ _overrideDeviceMetricsChanged: function()
+ {
+ this._toggleResponsiveDesignButton.toggled = WebInspector.overridesSupport.settings.overrideDeviceMetrics.get();
pfeldman 2014/05/28 15:12:01 I'm changing this as well...
+ },
+
+ createRootView: function()
+ {
+ var rootView = new WebInspector.RootView();
+
+ this._rootSplitView = new WebInspector.SplitView(false, true, WebInspector.dockController.canDock() ? "InspectorView.splitViewState" : "InspectorView.dummySplitViewState", 300, 300);
+ this._rootSplitView.show(rootView.element);
+
+ WebInspector.inspectorView.show(this._rootSplitView.sidebarElement());
+
+ this._inspectedPagePlaceholder = new WebInspector.InspectedPagePlaceholder();
+ this._inspectedPagePlaceholder.addEventListener(WebInspector.InspectedPagePlaceholder.Events.Update, this._onSetInspectedPageBounds, this);
+ if (WebInspector.experimentsSettings.responsiveDesign.isEnabled()) {
+ var responsiveDesignView = new WebInspector.ResponsiveDesignView(this._inspectedPagePlaceholder);
+ responsiveDesignView.show(this._rootSplitView.mainElement());
+ } else
+ this._inspectedPagePlaceholder.show(this._rootSplitView.mainElement());
+
+ WebInspector.dockController.addEventListener(WebInspector.DockController.Events.BeforeDockSideChanged, this._onBeforeDockSideChange, this);
+ WebInspector.dockController.addEventListener(WebInspector.DockController.Events.DockSideChanged, this._onDockSideChange, this);
+ WebInspector.dockController.addEventListener(WebInspector.DockController.Events.AfterDockSideChanged, this._onAfterDockSideChange, this);
+ this._onDockSideChange();
+
+ rootView.attachToBody();
+ },
+
+ _onBeforeDockSideChange: function()
+ {
+ this._changingDockSide = true;
+ },
+
+ _onDockSideChange: function()
+ {
+ var dockSide = WebInspector.dockController.dockSide();
+ if (dockSide === WebInspector.DockController.State.Undocked) {
+ this._rootSplitView.toggleResizer(this._rootSplitView.resizerElement(), false);
+ this._rootSplitView.toggleResizer(WebInspector.inspectorView.topResizerElement(), false);
+ this._rootSplitView.hideMain();
+ return;
+ }
+
+ this._rootSplitView.setVertical(dockSide === WebInspector.DockController.State.DockedToLeft || dockSide === WebInspector.DockController.State.DockedToRight);
+ this._rootSplitView.setSecondIsSidebar(dockSide === WebInspector.DockController.State.DockedToRight || dockSide === WebInspector.DockController.State.DockedToBottom);
+ this._rootSplitView.toggleResizer(this._rootSplitView.resizerElement(), true);
+ this._rootSplitView.toggleResizer(WebInspector.inspectorView.topResizerElement(), dockSide === WebInspector.DockController.State.DockedToBottom);
+ this._rootSplitView.showBoth();
+ },
+
+ _onAfterDockSideChange: function()
+ {
+ this._changingDockSide = false;
+ this._inspectedPagePlaceholder.update();
+ },
+
+ _isDocked: function()
+ {
+ return WebInspector.dockController.dockSide() !== WebInspector.DockController.State.Undocked;
+ },
+
+ /**
+ * @param {!WebInspector.Event} event
+ */
+ _onSetInspectedPageBounds: function(event)
+ {
+ if (this._changingDockSide || !this._isDocked())
+ return;
+ var bounds = /** @type {{x: number, y: number, width: number, height: number}} */ (event.data);
+ InspectorFrontendHost.setInspectedPageBounds(bounds);
+ },
+
+ __proto__: WebInspector.App.prototype
+};
+
+
+/**
+ * @constructor
+ * @extends {WebInspector.App}
+ */
+WebInspector.ScreencastApp = function()
+{
+ WebInspector.App.call(this);
+
+ this._currentScreencastState = WebInspector.settings.createSetting("currentScreencastState", "");
+ this._lastScreencastState = WebInspector.settings.createSetting("lastScreencastState", "");
+ this._toggleScreencastButton = new WebInspector.StatusBarStatesSettingButton(
+ "screencast-status-bar-item",
+ ["disabled", "left", "top"],
+ [WebInspector.UIString("Disable screencast."), WebInspector.UIString("Switch to portrait screencast."), WebInspector.UIString("Switch to landscape screencast.")],
+ this._currentScreencastState,
+ this._lastScreencastState,
+ this._onStatusBarButtonStateChanged.bind(this));
+};
+
+WebInspector.ScreencastApp.prototype = {
+ createGlobalStatusBarItems: function()
+ {
+ this.appendInspectStatusBarItem();
+ this.appendSettingsStatusBarItem();
+ WebInspector.inspectorView.appendToRightToolbar(this._toggleScreencastButton.element);
+ },
+
+ createRootView: function()
+ {
+ var rootView = new WebInspector.RootView();
+
+ this._rootSplitView = new WebInspector.SplitView(false, true, "InspectorView.screencastSplitViewState", 300, 300);
+ this._rootSplitView.show(rootView.element);
+
+ WebInspector.inspectorView.show(this._rootSplitView.sidebarElement());
+ var target = /** @type {!WebInspector.Target} */ (WebInspector.targetManager.activeTarget());
+ this._screencastView = new WebInspector.ScreencastView(target);
+ this._screencastView.show(this._rootSplitView.mainElement());
+
+ this._onStatusBarButtonStateChanged("disabled");
+ rootView.attachToBody();
+ },
+
+ presentUI: function()
+ {
+ WebInspector.App.prototype.presentUI.call(this);
+ this._screencastView.initialize();
+ this._toggleScreencastButton.toggleInitialState();
+ },
+
+ /**
+ * @param {string} state
+ */
+ _onStatusBarButtonStateChanged: function(state)
+ {
+ if (state === "disabled") {
+ this._rootSplitView.toggleResizer(this._rootSplitView.resizerElement(), false);
+ this._rootSplitView.toggleResizer(WebInspector.inspectorView.topResizerElement(), false);
+ this._rootSplitView.hideMain();
+ return;
+ }
+
+ this._rootSplitView.setVertical(state === "left");
+ this._rootSplitView.setSecondIsSidebar(true);
+ this._rootSplitView.toggleResizer(this._rootSplitView.resizerElement(), true);
+ this._rootSplitView.toggleResizer(WebInspector.inspectorView.topResizerElement(), state === "top");
+ this._rootSplitView.showBoth();
+ },
+
+ __proto__: WebInspector.App.prototype
+};
« no previous file with comments | « Source/devtools/front_end/inspector.html ('k') | Source/devtools/front_end/main/Main.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698