Upstream version 9.38.198.0
[platform/framework/web/crosswalk.git] / src / third_party / WebKit / Source / devtools / front_end / main / AdvancedApp.js
index 3c74972..098d2bb 100644 (file)
@@ -9,34 +9,72 @@
 WebInspector.AdvancedApp = function()
 {
     WebInspector.App.call(this);
+    if (WebInspector.overridesSupport.responsiveDesignAvailable()) {
+        this._toggleEmulationButton = new WebInspector.StatusBarButton(WebInspector.UIString("Toggle device mode."), "emulation-status-bar-item");
+        this._toggleEmulationButton.toggled = WebInspector.overridesSupport.emulationEnabled();
+        this._toggleEmulationButton.addEventListener("click", this._toggleEmulationEnabled, this);
+        WebInspector.overridesSupport.addEventListener(WebInspector.OverridesSupport.Events.EmulationStateChanged, this._emulationEnabledChanged, this);
+        WebInspector.overridesSupport.addEventListener(WebInspector.OverridesSupport.Events.OverridesWarningUpdated, this._overridesWarningUpdated, this);
+    }
     WebInspector.dockController.addEventListener(WebInspector.DockController.Events.BeforeDockSideChanged, this._openToolboxWindow, this);
 };
 
 WebInspector.AdvancedApp.prototype = {
+    _toggleEmulationEnabled: function()
+    {
+        var enabled = !this._toggleEmulationButton.toggled;
+        if (enabled)
+            WebInspector.userMetrics.DeviceModeEnabled.record();
+        WebInspector.overridesSupport.setEmulationEnabled(enabled);
+    },
+
+    _emulationEnabledChanged: function()
+    {
+        this._toggleEmulationButton.toggled = WebInspector.overridesSupport.emulationEnabled();
+        if (!WebInspector.overridesSupport.responsiveDesignAvailable() && WebInspector.overridesSupport.emulationEnabled())
+            WebInspector.inspectorView.showViewInDrawer("emulation", true);
+    },
+
+    _overridesWarningUpdated: function()
+    {
+        if (!this._toggleEmulationButton)
+            return;
+        var message = WebInspector.overridesSupport.warningMessage();
+        this._toggleEmulationButton.title = message || WebInspector.UIString("Toggle device mode.");
+        this._toggleEmulationButton.element.classList.toggle("warning", !!message);
+    },
+
     createRootView: function()
     {
         var rootView = new WebInspector.RootView();
 
-        this._rootSplitView = new WebInspector.SplitView(false, true, WebInspector.dockController.canDock() ? "InspectorView.splitViewState" : "InspectorView.dummySplitViewState", 300, 300, true);
+        this._rootSplitView = new WebInspector.SplitView(false, true, "InspectorView.splitViewState", 300, 300, true);
         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.bind(this, false), this);
-        if (WebInspector.experimentsSettings.responsiveDesign.isEnabled()) {
-            this._responsiveDesignView = new WebInspector.ResponsiveDesignView(this._inspectedPagePlaceholder);
-            this._responsiveDesignView.show(this._rootSplitView.mainElement());
-        } else {
-            this._inspectedPagePlaceholder.show(this._rootSplitView.mainElement());
-        }
+        this._responsiveDesignView = new WebInspector.ResponsiveDesignView(this._inspectedPagePlaceholder);
+        this._responsiveDesignView.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();
 
+        console.timeStamp("AdvancedApp.attachToBody");
         rootView.attachToBody();
+        this._inspectedPagePlaceholder.update();
+    },
+
+    /**
+     * @param {!WebInspector.Target} mainTarget
+     */
+    presentUI: function(mainTarget)
+    {
+        WebInspector.App.prototype.presentUI.call(this, mainTarget);
+        this._overridesWarningUpdated();
     },
 
     /**
@@ -47,7 +85,7 @@ WebInspector.AdvancedApp.prototype = {
         if (/** @type {string} */ (event.data.to) !== WebInspector.DockController.State.Undocked)
             return;
 
-        if (this._toolboxWindow || !WebInspector.experimentsSettings.responsiveDesign.isEnabled())
+        if (this._toolboxWindow)
             return;
 
         var toolbox = (window.location.search ? "&" : "?") + "toolbox=true";
@@ -57,23 +95,22 @@ WebInspector.AdvancedApp.prototype = {
     },
 
     /**
-     * @param {!WebInspector.Toolbox} toolbox
+     * @param {!WebInspector.ResponsiveDesignView} responsiveDesignView
+     * @param {!WebInspector.InspectedPagePlaceholder} placeholder
      */
-    _toolboxLoaded: function(toolbox)
+    toolboxLoaded: function(responsiveDesignView, placeholder)
     {
-        this._toolbox = toolbox;
+        this._toolboxResponsiveDesignView = responsiveDesignView;
+        placeholder.addEventListener(WebInspector.InspectedPagePlaceholder.Events.Update, this._onSetInspectedPageBounds.bind(this, true));
         this._updatePageResizer();
     },
 
     _updatePageResizer: function()
     {
-        if (!WebInspector.experimentsSettings.responsiveDesign.isEnabled())
-            return;
-
         if (this._isDocked())
             this._responsiveDesignView.updatePageResizer();
-        else if (this._toolbox)
-            this._toolbox._responsiveDesignView.updatePageResizer();
+        else if (this._toolboxResponsiveDesignView)
+            this._toolboxResponsiveDesignView.updatePageResizer();
     },
 
     /**
@@ -81,7 +118,7 @@ WebInspector.AdvancedApp.prototype = {
      */
     _onBeforeDockSideChange: function(event)
     {
-        if (/** @type {string} */ (event.data.to) === WebInspector.DockController.State.Undocked && this._toolbox) {
+        if (/** @type {string} */ (event.data.to) === WebInspector.DockController.State.Undocked && this._toolboxResponsiveDesignView) {
             // Hide inspectorView and force layout to mimic the undocked state.
             this._rootSplitView.hideSidebar();
             this._inspectedPagePlaceholder.update();
@@ -100,7 +137,7 @@ WebInspector.AdvancedApp.prototype = {
         var toDockSide = event ? /** @type {string} */ (event.data.to) : WebInspector.dockController.dockSide();
         if (toDockSide === WebInspector.DockController.State.Undocked) {
             this._updateForUndocked();
-        } else if (this._toolbox && event && /** @type {string} */ (event.data.from) === WebInspector.DockController.State.Undocked) {
+        } else if (this._toolboxResponsiveDesignView && event && /** @type {string} */ (event.data.from) === WebInspector.DockController.State.Undocked) {
             // Don't update yet for smooth transition.
             this._rootSplitView.hideSidebar();
         } else {
@@ -159,6 +196,7 @@ WebInspector.AdvancedApp.prototype = {
         if (!window.innerWidth || !window.innerHeight)
             return;
         var bounds = /** @type {{x: number, y: number, width: number, height: number}} */ (event.data);
+        console.timeStamp("AdvancedApp.setInspectedPageBounds");
         InspectorFrontendHost.setInspectedPageBounds(bounds);
     },
 
@@ -167,32 +205,86 @@ WebInspector.AdvancedApp.prototype = {
 
 /**
  * @constructor
+ * @implements {WebInspector.StatusBarItem.Provider}
  */
-WebInspector.Toolbox = function()
+WebInspector.AdvancedApp.DeviceCounter = function()
 {
-    if (!window.opener)
+    if (!WebInspector.experimentsSettings.devicesPanel.isEnabled() || !(WebInspector.app instanceof WebInspector.AdvancedApp)) {
+        this._counter = null;
         return;
+    }
 
-    WebInspector.zoomManager = window.opener.WebInspector.zoomManager;
-    WebInspector.overridesSupport = window.opener.WebInspector.overridesSupport;
-    WebInspector.settings = window.opener.WebInspector.settings;
-    WebInspector.experimentsSettings = window.opener.WebInspector.experimentsSettings;
-    WebInspector.cssModel = window.opener.WebInspector.cssModel;
-    WebInspector.domModel = window.opener.WebInspector.domModel;
-    WebInspector.workspace = window.opener.WebInspector.workspace;
-    WebInspector.Revealer = window.opener.WebInspector.Revealer;
-    WebInspector.installPortStyles();
-
-    var advancedApp = /** @type {!WebInspector.AdvancedApp} */ (window.opener.WebInspector.app);
-    var rootView = new WebInspector.RootView();
-    this._inspectedPagePlaceholder = new WebInspector.InspectedPagePlaceholder();
-    this._inspectedPagePlaceholder.addEventListener(WebInspector.InspectedPagePlaceholder.Events.Update, advancedApp._onSetInspectedPageBounds.bind(advancedApp, true));
-    if (WebInspector.experimentsSettings.responsiveDesign.isEnabled()) {
-        this._responsiveDesignView = new WebInspector.ResponsiveDesignView(this._inspectedPagePlaceholder);
-        this._responsiveDesignView.show(rootView.element);
-    } else {
-        this._inspectedPagePlaceholder.show(rootView.element);
+    this._counter = new WebInspector.StatusBarCounter(["device-icon-small"]);
+    this._counter.addEventListener("click", showDevices);
+
+    function showDevices()
+    {
+        WebInspector.inspectorView.showViewInDrawer("devices", true);
+    }
+
+    InspectorFrontendHost.setDeviceCountUpdatesEnabled(true);
+    InspectorFrontendHost.events.addEventListener(InspectorFrontendHostAPI.Events.DeviceCountUpdated, this._onDeviceCountUpdated, this);
+}
+
+WebInspector.AdvancedApp.DeviceCounter.prototype = {
+    /**
+     * @param {!WebInspector.Event} event
+     */
+    _onDeviceCountUpdated: function(event)
+    {
+        var count = /** @type {number} */ (event.data);
+        this._counter.setCounter("device-icon-small", count, WebInspector.UIString(count > 1 ? "%d devices found" : "%d device found", count));
+        WebInspector.inspectorView.toolbarItemResized();
+    },
+
+    /**
+     * @return {?WebInspector.StatusBarItem}
+     */
+    item: function()
+    {
+        return this._counter;
+    }
+}
+
+/**
+ * @constructor
+ * @implements {WebInspector.StatusBarItem.Provider}
+ */
+WebInspector.AdvancedApp.EmulationButtonProvider = function()
+{
+}
+
+WebInspector.AdvancedApp.EmulationButtonProvider.prototype = {
+    /**
+     * @return {?WebInspector.StatusBarItem}
+     */
+    item: function()
+    {
+        if (!(WebInspector.app instanceof WebInspector.AdvancedApp))
+            return null;
+        return WebInspector.app._toggleEmulationButton || null;
+    }
+}
+
+/**
+ * @constructor
+ * @implements {WebInspector.ActionDelegate}
+ */
+WebInspector.AdvancedApp.ToggleDeviceModeActionDelegate = function()
+{
+}
+
+WebInspector.AdvancedApp.ToggleDeviceModeActionDelegate.prototype = {
+    /**
+     * @return {boolean}
+     */
+    handleAction: function()
+    {
+        if (!WebInspector.overridesSupport.responsiveDesignAvailable())
+            return false;
+        if (!(WebInspector.app instanceof WebInspector.AdvancedApp))
+            return false;
+        WebInspector.app._toggleEmulationEnabled();
+        return true;
     }
-    rootView.attachToBody();
-    advancedApp._toolboxLoaded(this);
 }