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

Unified Diff: chrome_linux64/resources/inspector/NetworkPanel.js

Issue 23466010: Roll reference builds to r221697. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/deps/reference_builds/
Patch Set: Created 7 years, 3 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
Index: chrome_linux64/resources/inspector/NetworkPanel.js
===================================================================
--- chrome_linux64/resources/inspector/NetworkPanel.js (revision 221742)
+++ chrome_linux64/resources/inspector/NetworkPanel.js (working copy)
@@ -1,3498 +1,565 @@
-
-
-
-
-
-
-WebInspector.RequestView = function(request)
-{
-WebInspector.View.call(this);
-this.registerRequiredCSS("resourceView.css");
-
-this.element.addStyleClass("resource-view");
-this.request = request;
-}
-
-WebInspector.RequestView.prototype = {
-hasContent: function()
-{
-return false;
-},
-
-__proto__: WebInspector.View.prototype
-}
-
-
-WebInspector.RequestView.hasTextContent = function(request)
-{
-if (request.type.isTextType())
-return true;
-if (request.type === WebInspector.resourceTypes.Other || request.hasErrorStatusCode())
-return request.content && !request.contentEncoded;
-return false;
-}
-
-
-WebInspector.RequestView.nonSourceViewForRequest = function(request)
-{
-switch (request.type) {
-case WebInspector.resourceTypes.Image:
-return new WebInspector.ImageView(request);
-case WebInspector.resourceTypes.Font:
-return new WebInspector.FontView(request);
-default:
-return new WebInspector.RequestView(request);
-}
-}
-;
-
-
-
-WebInspector.NetworkItemView = function(request)
-{
-WebInspector.TabbedPane.call(this);
-this.element.addStyleClass("network-item-view");
-
-var headersView = new WebInspector.RequestHeadersView(request);
-this.appendTab("headers", WebInspector.UIString("Headers"), headersView);
-
-this.addEventListener(WebInspector.TabbedPane.EventTypes.TabSelected, this._tabSelected, this);
-
-if (request.type === WebInspector.resourceTypes.WebSocket) {
-var frameView = new WebInspector.ResourceWebSocketFrameView(request);
-this.appendTab("webSocketFrames", WebInspector.UIString("Frames"), frameView);
-} else {
-var responseView = new WebInspector.RequestResponseView(request);
-var previewView = new WebInspector.RequestPreviewView(request, responseView);
-this.appendTab("preview", WebInspector.UIString("Preview"), previewView);
-this.appendTab("response", WebInspector.UIString("Response"), responseView);
-}
-
-if (request.requestCookies || request.responseCookies) {
-this._cookiesView = new WebInspector.RequestCookiesView(request);
-this.appendTab("cookies", WebInspector.UIString("Cookies"), this._cookiesView);
-}
-
-if (request.timing) {
-var timingView = new WebInspector.RequestTimingView(request);
-this.appendTab("timing", WebInspector.UIString("Timing"), timingView);
-}
-this._request = request;
-}
-
-WebInspector.NetworkItemView.prototype = {
-wasShown: function()
-{
-WebInspector.TabbedPane.prototype.wasShown.call(this);
-this._selectTab();
-},
-
-
-_selectTab: function(tabId)
-{
-if (!tabId)
-tabId = WebInspector.settings.resourceViewTab.get();
-
-if (!this.selectTab(tabId)) {
-this._isInFallbackSelection = true;
-this.selectTab("headers");
-delete this._isInFallbackSelection;
-}
-},
-
-_tabSelected: function(event)
-{
-if (!event.data.isUserGesture)
-return;
-
-WebInspector.settings.resourceViewTab.set(event.data.tabId);
-
-WebInspector.notifications.dispatchEventToListeners(WebInspector.UserMetrics.UserAction, {
-action: WebInspector.UserMetrics.UserActionNames.NetworkRequestTabSelected,
-tab: event.data.tabId,
-url: this._request.url
-});
-},
-
-
-request: function()
-{
-return this._request;
-},
-
-__proto__: WebInspector.TabbedPane.prototype
-}
-
-
-WebInspector.RequestContentView = function(request)
-{
-WebInspector.RequestView.call(this, request);
-}
-
-WebInspector.RequestContentView.prototype = {
-hasContent: function()
-{
-return true;
-},
-
-get innerView()
-{
-return this._innerView;
-},
-
-set innerView(innerView)
-{
-this._innerView = innerView;
-},
-
-wasShown: function()
-{
-this._ensureInnerViewShown();
-},
-
-_ensureInnerViewShown: function()
-{
-if (this._innerViewShowRequested)
-return;
-this._innerViewShowRequested = true;
-
-
-function callback(content, contentEncoded, mimeType)
-{
-this._innerViewShowRequested = false;
-this.contentLoaded();
-}
-
-this.request.requestContent(callback.bind(this));
-},
-
-contentLoaded: function()
-{
-
-},
-
-canHighlightLine: function()
-{
-return this._innerView && this._innerView.canHighlightLine();
-},
-
-highlightLine: function(line)
-{
-if (this.canHighlightLine())
-this._innerView.highlightLine(line);
-},
-
-__proto__: WebInspector.RequestView.prototype
-}
-;
-
-
-
-WebInspector.RequestCookiesView = function(request)
-{
-WebInspector.View.call(this);
-this.element.addStyleClass("resource-cookies-view");
-
-this._request = request;
-}
-
-WebInspector.RequestCookiesView.prototype = {
-wasShown: function()
-{
-this._request.addEventListener(WebInspector.NetworkRequest.Events.RequestHeadersChanged, this._refreshCookies, this);
-this._request.addEventListener(WebInspector.NetworkRequest.Events.ResponseHeadersChanged, this._refreshCookies, this);
-
-if (!this._gotCookies) {
-if (!this._emptyView) {
-this._emptyView = new WebInspector.EmptyView(WebInspector.UIString("This request has no cookies."));
-this._emptyView.show(this.element);
-}
-return;
-}
-
-if (!this._cookiesTable)
-this._buildCookiesTable();
-},
-
-willHide: function()
-{
-this._request.removeEventListener(WebInspector.NetworkRequest.Events.RequestHeadersChanged, this._refreshCookies, this);
-this._request.removeEventListener(WebInspector.NetworkRequest.Events.ResponseHeadersChanged, this._refreshCookies, this);
-},
-
-get _gotCookies()
-{
-return (this._request.requestCookies && this._request.requestCookies.length) || (this._request.responseCookies && this._request.responseCookies.length);
-},
-
-_buildCookiesTable: function()
-{
-this.detachChildViews();
-
-this._cookiesTable = new WebInspector.CookiesTable(true);
-this._cookiesTable.setCookieFolders([
-{folderName: WebInspector.UIString("Request Cookies"), cookies: this._request.requestCookies},
-{folderName: WebInspector.UIString("Response Cookies"), cookies: this._request.responseCookies}
-]);
-this._cookiesTable.show(this.element);
-},
-
-_refreshCookies: function()
-{
-delete this._cookiesTable;
-if (!this._gotCookies || !this.isShowing())
-return;
-this._buildCookiesTable();
-},
-
-__proto__: WebInspector.View.prototype
-}
-;
-
-
-
-WebInspector.RequestHeadersView = function(request)
-{
-WebInspector.View.call(this);
-this.registerRequiredCSS("resourceView.css");
-this.element.addStyleClass("resource-headers-view");
-
-this._request = request;
-
-this._headersListElement = document.createElement("ol");
-this._headersListElement.className = "outline-disclosure";
-this.element.appendChild(this._headersListElement);
-
-this._headersTreeOutline = new TreeOutline(this._headersListElement);
-this._headersTreeOutline.expandTreeElementsWhenArrowing = true;
-
-this._urlTreeElement = new TreeElement("", null, false);
-this._urlTreeElement.selectable = false;
-this._headersTreeOutline.appendChild(this._urlTreeElement);
-
-this._requestMethodTreeElement = new TreeElement("", null, false);
-this._requestMethodTreeElement.selectable = false;
-this._headersTreeOutline.appendChild(this._requestMethodTreeElement);
-
-this._statusCodeTreeElement = new TreeElement("", null, false);
-this._statusCodeTreeElement.selectable = false;
-this._headersTreeOutline.appendChild(this._statusCodeTreeElement);
-
-this._requestHeadersTreeElement = new TreeElement("", null, true);
-this._requestHeadersTreeElement.expanded = true;
-this._requestHeadersTreeElement.selectable = false;
-this._headersTreeOutline.appendChild(this._requestHeadersTreeElement);
-
-this._decodeRequestParameters = true;
-
-this._showRequestHeadersText = false;
-this._showResponseHeadersText = false;
-
-this._queryStringTreeElement = new TreeElement("", null, true);
-this._queryStringTreeElement.expanded = true;
-this._queryStringTreeElement.selectable = false;
-this._queryStringTreeElement.hidden = true;
-this._headersTreeOutline.appendChild(this._queryStringTreeElement);
-
-this._urlFragmentTreeElement = new TreeElement("", null, true);
-this._urlFragmentTreeElement.expanded = true;
-this._urlFragmentTreeElement.selectable = false;
-this._urlFragmentTreeElement.hidden = true;
-this._headersTreeOutline.appendChild(this._urlFragmentTreeElement);
-
-this._formDataTreeElement = new TreeElement("", null, true);
-this._formDataTreeElement.expanded = true;
-this._formDataTreeElement.selectable = false;
-this._formDataTreeElement.hidden = true;
-this._headersTreeOutline.appendChild(this._formDataTreeElement);
-
-this._requestPayloadTreeElement = new TreeElement(WebInspector.UIString("Request Payload"), null, true);
-this._requestPayloadTreeElement.expanded = true;
-this._requestPayloadTreeElement.selectable = false;
-this._requestPayloadTreeElement.hidden = true;
-this._headersTreeOutline.appendChild(this._requestPayloadTreeElement);
-
-this._responseHeadersTreeElement = new TreeElement("", null, true);
-this._responseHeadersTreeElement.expanded = true;
-this._responseHeadersTreeElement.selectable = false;
-this._headersTreeOutline.appendChild(this._responseHeadersTreeElement);
-}
-
-WebInspector.RequestHeadersView.prototype = {
-
-wasShown: function()
-{
-this._request.addEventListener(WebInspector.NetworkRequest.Events.RequestHeadersChanged, this._refreshRequestHeaders, this);
-this._request.addEventListener(WebInspector.NetworkRequest.Events.ResponseHeadersChanged, this._refreshResponseHeaders, this);
-this._request.addEventListener(WebInspector.NetworkRequest.Events.FinishedLoading, this._refreshHTTPInformation, this);
-
-this._refreshURL();
-this._refreshQueryString();
-this._refreshUrlFragment();
-this._refreshRequestHeaders();
-this._refreshResponseHeaders();
-this._refreshHTTPInformation();
-},
-
-willHide: function()
-{
-this._request.removeEventListener(WebInspector.NetworkRequest.Events.RequestHeadersChanged, this._refreshRequestHeaders, this);
-this._request.removeEventListener(WebInspector.NetworkRequest.Events.ResponseHeadersChanged, this._refreshResponseHeaders, this);
-this._request.removeEventListener(WebInspector.NetworkRequest.Events.FinishedLoading, this._refreshHTTPInformation, this);
-},
-
-
-_formatHeader: function(name, value)
-{
-var fragment = document.createDocumentFragment();
-fragment.createChild("div", "header-name").textContent = name + ":";
-fragment.createChild("div", "header-value source-code").textContent = value;
-
-return fragment;
-},
-
-
-_formatParameter: function(value, className, decodeParameters)
-{
-var errorDecoding = false;
-
-if (decodeParameters) {
-value = value.replace(/\+/g, " ");
-if (value.indexOf("%") >= 0) {
-try {
-value = decodeURIComponent(value);
-} catch (e) {
-errorDecoding = true;
-}
-}
-}
-var div = document.createElement("div");
-div.className = className;
-if (errorDecoding)
-div.createChild("span", "error-message").textContent = WebInspector.UIString("(unable to decode value)");
-else
-div.textContent = value;
-return div;
-},
-
-_refreshURL: function()
-{
-this._urlTreeElement.title = this._formatHeader(WebInspector.UIString("Request URL"), this._request.url);
-},
-
-_refreshQueryString: function()
-{
-var queryString = this._request.queryString();
-var queryParameters = this._request.queryParameters;
-this._queryStringTreeElement.hidden = !queryParameters;
-if (queryParameters)
-this._refreshParams(WebInspector.UIString("Query String Parameters"), queryParameters, queryString, this._queryStringTreeElement);
-},
-
-_refreshUrlFragment: function()
-{
-var urlFragment = this._request.parsedURL.fragment;
-this._urlFragmentTreeElement.hidden = !urlFragment;
-
-if (!urlFragment)
-return;
-
-var sectionTitle = WebInspector.UIString("URL fragment");
-
-this._urlFragmentTreeElement.removeChildren();
-this._urlFragmentTreeElement.listItemElement.removeChildren();
-this._urlFragmentTreeElement.listItemElement.appendChild(document.createTextNode(sectionTitle));
-
-var fragmentTreeElement = new TreeElement(null, null, false);
-fragmentTreeElement.title = this._formatHeader("#", urlFragment);
-fragmentTreeElement.selectable = false;
-this._urlFragmentTreeElement.appendChild(fragmentTreeElement);
-},
-
-_refreshFormData: function()
-{
-this._formDataTreeElement.hidden = true;
-this._requestPayloadTreeElement.hidden = true;
-
-var formData = this._request.requestFormData;
-if (!formData)
-return;
-
-var formParameters = this._request.formParameters;
-if (formParameters) {
-this._formDataTreeElement.hidden = false;
-this._refreshParams(WebInspector.UIString("Form Data"), formParameters, formData, this._formDataTreeElement);
-} else {
-this._requestPayloadTreeElement.hidden = false;
-try {
-var json = JSON.parse(formData);
-this._refreshRequestJSONPayload(json, formData, false);
-} catch (e) {
-this._populateTreeElementWithSourceText(this._requestPayloadTreeElement, formData);
-}
-}
-},
-
-_populateTreeElementWithSourceText: function(treeElement, sourceText)
-{
-treeElement.removeChildren();
-
-var sourceTreeElement = new TreeElement(null, null, false);
-sourceTreeElement.selectable = false;
-treeElement.appendChild(sourceTreeElement);
-
-var sourceTextElement = document.createElement("span");
-sourceTextElement.addStyleClass("header-value");
-sourceTextElement.addStyleClass("source-code");
-sourceTextElement.textContent = String(sourceText).trim();
-sourceTreeElement.listItemElement.appendChild(sourceTextElement);
-},
-
-_refreshParams: function(title, params, sourceText, paramsTreeElement)
-{
-paramsTreeElement.removeChildren();
-
-paramsTreeElement.listItemElement.removeChildren();
-paramsTreeElement.listItemElement.appendChild(document.createTextNode(title));
-
-var headerCount = document.createElement("span");
-headerCount.addStyleClass("header-count");
-headerCount.textContent = WebInspector.UIString(" (%d)", params.length);
-paramsTreeElement.listItemElement.appendChild(headerCount);
-
-function toggleViewSource()
-{
-paramsTreeElement._viewSource = !paramsTreeElement._viewSource;
-this._refreshParams(title, params, sourceText, paramsTreeElement);
-}
-
-paramsTreeElement.listItemElement.appendChild(this._createViewSourceToggle(paramsTreeElement._viewSource, toggleViewSource.bind(this)));
-
-if (paramsTreeElement._viewSource) {
-this._populateTreeElementWithSourceText(paramsTreeElement, sourceText);
-return;
-}
-
-var toggleTitle = this._decodeRequestParameters ? WebInspector.UIString("view URL encoded") : WebInspector.UIString("view decoded");
-var toggleButton = this._createToggleButton(toggleTitle);
-toggleButton.addEventListener("click", this._toggleURLDecoding.bind(this));
-paramsTreeElement.listItemElement.appendChild(toggleButton);
-
-for (var i = 0; i < params.length; ++i) {
-var paramNameValue = document.createDocumentFragment();
-var name = this._formatParameter(params[i].name + ":", "header-name", this._decodeRequestParameters);
-var value = this._formatParameter(params[i].value, "header-value source-code", this._decodeRequestParameters);
-paramNameValue.appendChild(name);
-paramNameValue.appendChild(value);
-
-var parmTreeElement = new TreeElement(paramNameValue, null, false);
-parmTreeElement.selectable = false;
-paramsTreeElement.appendChild(parmTreeElement);
-}
-},
-
-
-_refreshRequestJSONPayload: function(parsedObject, sourceText, viewSource)
-{
-this._requestPayloadTreeElement.removeChildren();
-
-var listItem = this._requestPayloadTreeElement.listItemElement;
-listItem.removeChildren();
-listItem.appendChild(document.createTextNode(this._requestPayloadTreeElement.title));
-
-var setViewSource = this._refreshRequestJSONPayload.bind(this, parsedObject, sourceText);
-
-if (viewSource) {
-listItem.appendChild(this._createViewSourceToggle(true, setViewSource.bind(this, false)));
-this._populateTreeElementWithSourceText(this._requestPayloadTreeElement, sourceText);
-} else {
-listItem.appendChild(this._createViewSourceToggle(false, setViewSource.bind(this, true)));
-var object = WebInspector.RemoteObject.fromLocalObject(parsedObject);
-var section = new WebInspector.ObjectPropertiesSection(object, object.description);
-section.expand();
-section.editable = false;
-listItem.appendChild(section.element);
-}
-},
-
-
-_createViewSourceToggle: function(viewSource, handler)
-{
-var viewSourceToggleTitle = viewSource ? WebInspector.UIString("view parsed") : WebInspector.UIString("view source");
-var viewSourceToggleButton = this._createToggleButton(viewSourceToggleTitle);
-viewSourceToggleButton.addEventListener("click", handler);
-return viewSourceToggleButton;
-},
-
-_toggleURLDecoding: function(event)
-{
-this._decodeRequestParameters = !this._decodeRequestParameters;
-this._refreshQueryString();
-this._refreshFormData();
-},
-
-_getHeaderValue: function(headers, key)
-{
-var lowerKey = key.toLowerCase();
-for (var testKey in headers) {
-if (testKey.toLowerCase() === lowerKey)
-return headers[testKey];
-}
-},
-
-_refreshRequestHeaders: function()
-{
-if (this._showRequestHeadersText)
-this._refreshHeadersText(WebInspector.UIString("Request Headers"), this._request.sortedRequestHeaders, this._request.requestHeadersText, this._requestHeadersTreeElement);
-else
-this._refreshHeaders(WebInspector.UIString("Request Headers"), this._request.sortedRequestHeaders, this._requestHeadersTreeElement);
-
-if (this._request.requestHeadersText) {
-var toggleButton = this._createHeadersToggleButton(this._showRequestHeadersText);
-toggleButton.addEventListener("click", this._toggleRequestHeadersText.bind(this));
-this._requestHeadersTreeElement.listItemElement.appendChild(toggleButton);
-}
-
-this._refreshFormData();
-},
-
-_refreshResponseHeaders: function()
-{
-if (this._showResponseHeadersText)
-this._refreshHeadersText(WebInspector.UIString("Response Headers"), this._request.sortedResponseHeaders, this._request.responseHeadersText, this._responseHeadersTreeElement);
-else
-this._refreshHeaders(WebInspector.UIString("Response Headers"), this._request.sortedResponseHeaders, this._responseHeadersTreeElement);
-
-if (this._request.responseHeadersText) {
-var toggleButton = this._createHeadersToggleButton(this._showResponseHeadersText);
-toggleButton.addEventListener("click", this._toggleResponseHeadersText.bind(this));
-this._responseHeadersTreeElement.listItemElement.appendChild(toggleButton);
-}
-},
-
-_refreshHTTPInformation: function()
-{
-var requestMethodElement = this._requestMethodTreeElement;
-requestMethodElement.hidden = !this._request.statusCode;
-var statusCodeElement = this._statusCodeTreeElement;
-statusCodeElement.hidden = !this._request.statusCode;
-
-if (this._request.statusCode) {
-var statusCodeFragment = document.createDocumentFragment();
-statusCodeFragment.createChild("div", "header-name").textContent = WebInspector.UIString("Status Code") + ":";
-
-var statusCodeImage = statusCodeFragment.createChild("div", "resource-status-image");
-statusCodeImage.title = this._request.statusCode + " " + this._request.statusText;
-
-if (this._request.statusCode < 300 || this._request.statusCode === 304)
-statusCodeImage.addStyleClass("green-ball");
-else if (this._request.statusCode < 400)
-statusCodeImage.addStyleClass("orange-ball");
-else
-statusCodeImage.addStyleClass("red-ball");
-
-requestMethodElement.title = this._formatHeader(WebInspector.UIString("Request Method"), this._request.requestMethod);
-
-var value = statusCodeFragment.createChild("div", "header-value source-code");
-value.textContent = this._request.statusCode + " " + this._request.statusText;
-if (this._request.cached)
-value.createChild("span", "status-from-cache").textContent = " " + WebInspector.UIString("(from cache)");
-
-statusCodeElement.title = statusCodeFragment;
-}
-},
-
-_refreshHeadersTitle: function(title, headersTreeElement, headersLength)
-{
-headersTreeElement.listItemElement.removeChildren();
-headersTreeElement.listItemElement.appendChild(document.createTextNode(title));
-
-var headerCount = document.createElement("span");
-headerCount.addStyleClass("header-count");
-headerCount.textContent = WebInspector.UIString(" (%d)", headersLength);
-headersTreeElement.listItemElement.appendChild(headerCount);
-},
-
-_refreshHeaders: function(title, headers, headersTreeElement)
-{
-headersTreeElement.removeChildren();
-
-var length = headers.length;
-this._refreshHeadersTitle(title, headersTreeElement, length);
-headersTreeElement.hidden = !length;
-for (var i = 0; i < length; ++i) {
-var headerTreeElement = new TreeElement(null, null, false);
-headerTreeElement.title = this._formatHeader(headers[i].name, headers[i].value);
-headerTreeElement.selectable = false;
-headersTreeElement.appendChild(headerTreeElement);
-}
-},
-
-_refreshHeadersText: function(title, headers, headersText, headersTreeElement)
-{
-this._populateTreeElementWithSourceText(headersTreeElement, headersText);
-this._refreshHeadersTitle(title, headersTreeElement, headers.length);
-},
-
-_toggleRequestHeadersText: function(event)
-{
-this._showRequestHeadersText = !this._showRequestHeadersText;
-this._refreshRequestHeaders();
-},
-
-_toggleResponseHeadersText: function(event)
-{
-this._showResponseHeadersText = !this._showResponseHeadersText;
-this._refreshResponseHeaders();
-},
-
-_createToggleButton: function(title)
-{
-var button = document.createElement("span");
-button.addStyleClass("header-toggle");
-button.textContent = title;
-return button;
-},
-
-_createHeadersToggleButton: function(isHeadersTextShown)
-{
-var toggleTitle = isHeadersTextShown ? WebInspector.UIString("view parsed") : WebInspector.UIString("view source");
-return this._createToggleButton(toggleTitle);
-},
-
-__proto__: WebInspector.View.prototype
-}
-;
-
-
-
-WebInspector.RequestHTMLView = function(request, dataURL)
-{
-WebInspector.RequestView.call(this, request);
-this._dataURL = dataURL;
-this.element.addStyleClass("html");
-}
-
-WebInspector.RequestHTMLView.prototype = {
-hasContent: function()
-{
-return true;
-},
-
-wasShown: function()
-{
-this._createIFrame();
-},
-
-willHide: function(parentElement)
-{
-this.element.removeChildren();
-},
-
-_createIFrame: function()
-{
-
-
-this.element.removeChildren();
-var iframe = document.createElement("iframe");
-iframe.setAttribute("sandbox", "");
-iframe.setAttribute("src", this._dataURL);
-this.element.appendChild(iframe);
-},
-
-__proto__: WebInspector.RequestView.prototype
-}
-;
-
-
-
-WebInspector.RequestJSONView = function(request, parsedJSON)
-{
-WebInspector.RequestView.call(this, request);
-this._parsedJSON = parsedJSON;
-this.element.addStyleClass("json");
-}
-
-WebInspector.RequestJSONView.parseJSON = function(text)
-{
-var prefix = "";
-
-
-var start = /[{[]/.exec(text);
-if (start && start.index) {
-prefix = text.substring(0, start.index);
-text = text.substring(start.index);
-}
-
-try {
-return new WebInspector.ParsedJSON(JSON.parse(text), prefix, "");
-} catch (e) {
-return;
-}
-}
-
-WebInspector.RequestJSONView.parseJSONP = function(text)
-{
-
-var start = text.indexOf("(");
-var end = text.lastIndexOf(")");
-if (start == -1 || end == -1 || end < start)
-return;
-
-var prefix = text.substring(0, start + 1);
-var suffix = text.substring(end);
-text = text.substring(start + 1, end);
-
-try {
-return new WebInspector.ParsedJSON(JSON.parse(text), prefix, suffix);
-} catch (e) {
-return;
-}
-}
-
-WebInspector.RequestJSONView.prototype = {
-hasContent: function()
-{
-return true;
-},
-
-wasShown: function()
-{
-this._initialize();
-},
-
-_initialize: function()
-{
-if (this._initialized)
-return;
-this._initialized = true;
-
-var obj = WebInspector.RemoteObject.fromLocalObject(this._parsedJSON.data);
-var title = this._parsedJSON.prefix + obj.description + this._parsedJSON.suffix;
-var section = new WebInspector.ObjectPropertiesSection(obj, title);
-section.expand();
-section.editable = false;
-this.element.appendChild(section.element);
-},
-
-__proto__: WebInspector.RequestView.prototype
-}
-
-
-WebInspector.ParsedJSON = function(data, prefix, suffix)
-{
-this.data = data;
-this.prefix = prefix;
-this.suffix = suffix;
-}
-;
-
-
-
-WebInspector.RequestPreviewView = function(request, responseView)
-{
-WebInspector.RequestContentView.call(this, request);
-this._responseView = responseView;
-}
-
-WebInspector.RequestPreviewView.prototype = {
-contentLoaded: function()
-{
-if (!this.request.content) {
-if (!this._emptyView) {
-this._emptyView = this._createEmptyView();
-this._emptyView.show(this.element);
-this.innerView = this._emptyView;
-}
-} else {
-if (this._emptyView) {
-this._emptyView.detach();
-delete this._emptyView;
-}
-
-if (!this._previewView)
-this._previewView = this._createPreviewView();
-this._previewView.show(this.element);
-this.innerView = this._previewView;
-}
-},
-
-_createEmptyView: function()
-{
-return new WebInspector.EmptyView(WebInspector.UIString("This request has no preview available."));
-},
-
-_jsonView: function()
-{
-var parsedJSON = WebInspector.RequestJSONView.parseJSON(this.request.content);
-if (parsedJSON)
-return new WebInspector.RequestJSONView(this.request, parsedJSON);
-},
-
-_htmlView: function()
-{
-var dataURL = this.request.asDataURL();
-if (dataURL !== null)
-return new WebInspector.RequestHTMLView(this.request, dataURL);
-},
-
-_createPreviewView: function()
-{
-if (this.request.content) {
-if (this.request.hasErrorStatusCode()) {
-var htmlView = this._htmlView();
-if (htmlView)
-return htmlView;
-}
-
-if (this.request.type === WebInspector.resourceTypes.XHR) {
-var jsonView = this._jsonView();
-if (jsonView)
-return jsonView;
-}
-
-if (this.request.type === WebInspector.resourceTypes.XHR && this.request.mimeType === "text/html") {
-var htmlView = this._htmlView();
-if (htmlView)
-return htmlView;
-}
-
-if (this.request.type === WebInspector.resourceTypes.Script && this.request.mimeType === "application/json") {
-var jsonView = this._jsonView();
-if (jsonView)
-return jsonView;
-}
-}
-
-if (this._responseView.sourceView)
-return this._responseView.sourceView;
-
-if (this.request.type === WebInspector.resourceTypes.Other)
-return this._createEmptyView();
-
-return WebInspector.RequestView.nonSourceViewForRequest(this.request);
-},
-
-__proto__: WebInspector.RequestContentView.prototype
-}
-;
-
-
-
-WebInspector.RequestResponseView = function(request)
-{
-WebInspector.RequestContentView.call(this, request);
-}
-
-WebInspector.RequestResponseView._maxFormattedResourceSize = 100000;
-
-WebInspector.RequestResponseView.prototype = {
-get sourceView()
-{
-if (!this._sourceView && WebInspector.RequestView.hasTextContent(this.request))
-this._sourceView = this.request.resourceSize < WebInspector.RequestResponseView._maxFormattedResourceSize ? new WebInspector.ResourceSourceFrame(this.request) : new WebInspector.ResourceSourceFrameFallback(this.request);
-return this._sourceView;
-},
-
-contentLoaded: function()
-{
-if (!this.request.content || !this.sourceView) {
-if (!this._emptyView) {
-this._emptyView = new WebInspector.EmptyView(WebInspector.UIString("This request has no response data available."));
-this._emptyView.show(this.element);
-this.innerView = this._emptyView;
-}
-} else {
-if (this._emptyView) {
-this._emptyView.detach();
-delete this._emptyView;
-}
-
-this.sourceView.show(this.element);
-this.innerView = this.sourceView;
-}
-},
-
-__proto__: WebInspector.RequestContentView.prototype
-}
-;
-
-
-
-WebInspector.RequestTimingView = function(request)
-{
-WebInspector.View.call(this);
-this.element.addStyleClass("resource-timing-view");
-
-this._request = request;
-}
-
-WebInspector.RequestTimingView.prototype = {
-wasShown: function()
-{
-this._request.addEventListener(WebInspector.NetworkRequest.Events.TimingChanged, this._refresh, this);
-
-if (!this._request.timing) {
-if (!this._emptyView) {
-this._emptyView = new WebInspector.EmptyView(WebInspector.UIString("This request has no detailed timing info."));
-this._emptyView.show(this.element);
-this.innerView = this._emptyView;
-}
-return;
-}
-
-if (this._emptyView) {
-this._emptyView.detach();
-delete this._emptyView;
-}
-
-this._refresh();
-},
-
-willHide: function()
-{
-this._request.removeEventListener(WebInspector.NetworkRequest.Events.TimingChanged, this._refresh, this);
-},
-
-_refresh: function()
-{
-if (this._tableElement)
-this._tableElement.parentElement.removeChild(this._tableElement);
-
-this._tableElement = WebInspector.RequestTimingView.createTimingTable(this._request);
-this.element.appendChild(this._tableElement);
-},
-
-__proto__: WebInspector.View.prototype
-}
-
-
-WebInspector.RequestTimingView.createTimingTable = function(request)
-{
-var tableElement = document.createElement("table");
-var rows = [];
-
-function addRow(title, className, start, end)
-{
-var row = {};
-row.title = title;
-row.className = className;
-row.start = start;
-row.end = end;
-rows.push(row);
-}
-
-if (request.timing.proxyStart !== -1)
-addRow(WebInspector.UIString("Proxy"), "proxy", request.timing.proxyStart, request.timing.proxyEnd);
-
-if (request.timing.dnsStart !== -1)
-addRow(WebInspector.UIString("DNS Lookup"), "dns", request.timing.dnsStart, request.timing.dnsEnd);
-
-if (request.timing.connectStart !== -1) {
-if (request.connectionReused)
-addRow(WebInspector.UIString("Blocking"), "connecting", request.timing.connectStart, request.timing.connectEnd);
-else {
-var connectStart = request.timing.connectStart;
-
-if (request.timing.dnsStart !== -1)
-connectStart += request.timing.dnsEnd - request.timing.dnsStart;
-addRow(WebInspector.UIString("Connecting"), "connecting", connectStart, request.timing.connectEnd);
-}
-}
-
-if (request.timing.sslStart !== -1)
-addRow(WebInspector.UIString("SSL"), "ssl", request.timing.sslStart, request.timing.sslEnd);
-
-var sendStart = request.timing.sendStart;
-if (request.timing.sslStart !== -1)
-sendStart += request.timing.sslEnd - request.timing.sslStart;
-
-addRow(WebInspector.UIString("Sending"), "sending", request.timing.sendStart, request.timing.sendEnd);
-addRow(WebInspector.UIString("Waiting"), "waiting", request.timing.sendEnd, request.timing.receiveHeadersEnd);
-addRow(WebInspector.UIString("Receiving"), "receiving", (request.responseReceivedTime - request.timing.requestTime) * 1000, (request.endTime - request.timing.requestTime) * 1000);
-
-const chartWidth = 200;
-var total = (request.endTime - request.timing.requestTime) * 1000;
-var scale = chartWidth / total;
-
-for (var i = 0; i < rows.length; ++i) {
-var tr = document.createElement("tr");
-tableElement.appendChild(tr);
-
-var td = document.createElement("td");
-td.textContent = rows[i].title;
-tr.appendChild(td);
-
-td = document.createElement("td");
-td.width = chartWidth + "px";
-
-var row = document.createElement("div");
-row.className = "network-timing-row";
-td.appendChild(row);
-
-var bar = document.createElement("span");
-bar.className = "network-timing-bar " + rows[i].className;
-bar.style.left = scale * rows[i].start + "px";
-bar.style.right = scale * (total - rows[i].end) + "px";
-bar.style.backgroundColor = rows[i].color;
-bar.textContent = "\u200B";
-row.appendChild(bar);
-
-var title = document.createElement("span");
-title.className = "network-timing-bar-title";
-if (total - rows[i].end < rows[i].start)
-title.style.right = (scale * (total - rows[i].end) + 3) + "px";
-else
-title.style.left = (scale * rows[i].start + 3) + "px";
-title.textContent = Number.secondsToString((rows[i].end - rows[i].start) / 1000);
-row.appendChild(title);
-
-tr.appendChild(td);
-}
-return tableElement;
-}
-;
-
-
-
-WebInspector.ResourceWebSocketFrameView = function(resource)
-{
-WebInspector.View.call(this);
-this.element.addStyleClass("resource-websocket");
-this.resource = resource;
-this.element.removeChildren();
-
-var dataGrid = new WebInspector.DataGrid([
-{id: "data", title: WebInspector.UIString("Data"), sortable: false},
-{id: "length", title: WebInspector.UIString("Length"), sortable: false, alig: WebInspector.DataGrid.Align.Right, width: "50px"},
-{id: "time", title: WebInspector.UIString("Time"), width: "70px"}
-]);
-
-var frames = this.resource.frames();
-for (var i = 0; i < frames.length; i++) {
-var payload = frames[i];
-
-var date = new Date(payload.time * 1000);
-var row = {
-data: "",
-length: typeof payload.payloadData === "undefined" ? payload.errorMessage.length.toString() : payload.payloadData.length.toString(),
-time: date.toLocaleTimeString()
-};
-
-var rowClass = "";
-if (payload.errorMessage) {
-rowClass = "error";
-row.data = payload.errorMessage;
-} else if (payload.opcode == WebInspector.ResourceWebSocketFrameView.OpCodes.TextFrame) {
-if (payload.sent)
-rowClass = "outcoming";
-
-row.data = payload.payloadData;
-} else {
-rowClass = "opcode";
-var opcodeMeaning = "";
-switch (payload.opcode) {
-case WebInspector.ResourceWebSocketFrameView.OpCodes.ContinuationFrame:
-opcodeMeaning = WebInspector.UIString("Continuation Frame");
-break;
-case WebInspector.ResourceWebSocketFrameView.OpCodes.BinaryFrame:
-opcodeMeaning = WebInspector.UIString("Binary Frame");
-break;
-case WebInspector.ResourceWebSocketFrameView.OpCodes.ConnectionCloseFrame:
-opcodeMeaning = WebInspector.UIString("Connection Close Frame");
-break;
-case WebInspector.ResourceWebSocketFrameView.OpCodes.PingFrame:
-opcodeMeaning = WebInspector.UIString("Ping Frame");
-break;
-case WebInspector.ResourceWebSocketFrameView.OpCodes.PongFrame:
-opcodeMeaning = WebInspector.UIString("Pong Frame");
-break;
-}
-row.data = WebInspector.UIString("%s (Opcode %d%s)", opcodeMeaning, payload.opcode, (payload.mask ? ", mask" : ""));
-}
-
-var node = new WebInspector.DataGridNode(row, false);
-dataGrid.rootNode().appendChild(node);
-
-if (rowClass)
-node.element.classList.add("resource-websocket-row-" + rowClass);
-
-}
-dataGrid.show(this.element);
-}
-
-WebInspector.ResourceWebSocketFrameView.OpCodes = {
-ContinuationFrame: 0,
-TextFrame: 1,
-BinaryFrame: 2,
-ConnectionCloseFrame: 8,
-PingFrame: 9,
-PongFrame: 10
-};
-
-WebInspector.ResourceWebSocketFrameView.prototype = {
-__proto__: WebInspector.View.prototype
-}
-;
-
-
-WebInspector.NetworkLogView = function(coulmnsVisibilitySetting)
-{
-WebInspector.View.call(this);
-this.registerRequiredCSS("networkLogView.css");
-
-this._coulmnsVisibilitySetting = coulmnsVisibilitySetting;
-this._allowRequestSelection = false;
-this._requests = [];
-this._requestsById = {};
-this._requestsByURL = {};
-this._staleRequests = {};
-this._requestGridNodes = {};
-this._lastRequestGridNodeId = 0;
-this._mainRequestLoadTime = -1;
-this._mainRequestDOMContentTime = -1;
-this._typeFilterElements = {};
-this._typeFilter = WebInspector.NetworkLogView._trivialTypeFilter;
-this._matchedRequests = [];
-this._highlightedSubstringChanges = [];
-this._filteredOutRequests = new Map();
-
-this._matchedRequestsMap = {};
-this._currentMatchedRequestIndex = -1;
-
-this._createStatusbarButtons();
-this._createStatusBarItems();
-this._linkifier = new WebInspector.Linkifier();
-
-WebInspector.networkManager.addEventListener(WebInspector.NetworkManager.EventTypes.RequestStarted, this._onRequestStarted, this);
-WebInspector.networkManager.addEventListener(WebInspector.NetworkManager.EventTypes.RequestUpdated, this._onRequestUpdated, this);
-WebInspector.networkManager.addEventListener(WebInspector.NetworkManager.EventTypes.RequestFinished, this._onRequestUpdated, this);
-
-WebInspector.resourceTreeModel.addEventListener(WebInspector.ResourceTreeModel.EventTypes.MainFrameNavigated, this._mainFrameNavigated, this);
-WebInspector.resourceTreeModel.addEventListener(WebInspector.ResourceTreeModel.EventTypes.OnLoad, this._onLoadEventFired, this);
-WebInspector.resourceTreeModel.addEventListener(WebInspector.ResourceTreeModel.EventTypes.DOMContentLoaded, this._domContentLoadedEventFired, this);
-
-this._initializeView();
-
-WebInspector.networkLog.requests.forEach(this._appendRequest.bind(this));
-}
-
-WebInspector.NetworkLogView.HTTPSchemas = {"http": true, "https": true, "ws": true, "wss": true};
-WebInspector.NetworkLogView._defaultColumnsVisivility = {method: true, status: true, domain: false, type: true, initiator: true, cookies: false, setCookies: false, size: true, time: true};
-WebInspector.NetworkLogView._defaultRefreshDelay = 500;
-WebInspector.NetworkLogView.ALL_TYPES = "all";
-
-WebInspector.NetworkLogView.prototype = {
-_initializeView: function()
-{
-this.element.id = "network-container";
-
-this._createSortingFunctions();
-this._createTable();
-this._createTimelineGrid();
-this._createSummaryBar();
-
-if (!this.useLargeRows)
-this._setLargerRequests(this.useLargeRows);
-
-this._allowPopover = true;
-this._popoverHelper = new WebInspector.PopoverHelper(this.element, this._getPopoverAnchor.bind(this), this._showPopover.bind(this), this._onHidePopover.bind(this));
-
-this._popoverHelper.setTimeout(100);
-
-this.calculator = new WebInspector.NetworkTransferTimeCalculator();
-this._toggleTypeFilter(WebInspector.NetworkLogView.ALL_TYPES, false);
-
-this.switchToDetailedView();
-},
-
-get statusBarItems()
-{
-return [this._largerRequestsButton.element, this._preserveLogToggle.element, this._clearButton.element, this._filterBarElement, this._progressBarContainer];
-},
-
-get useLargeRows()
-{
-return WebInspector.settings.resourcesLargeRows.get();
-},
-
-set allowPopover(flag)
-{
-this._allowPopover = flag;
-},
-
-elementsToRestoreScrollPositionsFor: function()
-{
-if (!this._dataGrid)
-return [];
-return [this._dataGrid.scrollContainer];
-},
-
-onResize: function()
-{
-this._updateOffscreenRows();
-},
-
-_createTimelineGrid: function()
-{
-this._timelineGrid = new WebInspector.TimelineGrid();
-this._timelineGrid.element.addStyleClass("network-timeline-grid");
-this._dataGrid.element.appendChild(this._timelineGrid.element);
-},
-
-_createTable: function()
-{
-var columns = [];
-columns.push({
-id: "name",
-titleDOMFragment: this._makeHeaderFragment(WebInspector.UIString("Name"), WebInspector.UIString("Path")),
-title: WebInspector.UIString("Name"),
-sortable: true,
-weight: 20,
-disclosure: true
-});
-
-columns.push({
-id: "method",
-title: WebInspector.UIString("Method"),
-sortable: true,
-weight: 6
-});
-
-columns.push({
-id: "status",
-titleDOMFragment: this._makeHeaderFragment(WebInspector.UIString("Status"), WebInspector.UIString("Text")),
-title: WebInspector.UIString("Status"),
-sortable: true,
-weight: 6
-});
-
-columns.push({
-id: "domain",
-title: WebInspector.UIString("Domain"),
-sortable: true,
-weight: 6
-});
-
-columns.push({
-id: "type",
-title: WebInspector.UIString("Type"),
-sortable: true,
-weight: 6
-});
-
-columns.push({
-id: "initiator",
-title: WebInspector.UIString("Initiator"),
-sortable: true,
-weight: 10
-});
-
-columns.push({
-id: "cookies",
-title: WebInspector.UIString("Cookies"),
-sortable: true,
-weight: 6,
-align: WebInspector.DataGrid.Align.Right
-});
-
-columns.push({
-id: "setCookies",
-title: WebInspector.UIString("Set-Cookies"),
-sortable: true,
-weight: 6,
-align: WebInspector.DataGrid.Align.Right
-});
-
-columns.push({
-id: "size",
-titleDOMFragment: this._makeHeaderFragment(WebInspector.UIString("Size"), WebInspector.UIString("Content")),
-title: WebInspector.UIString("Size"),
-sortable: true,
-weight: 6,
-align: WebInspector.DataGrid.Align.Right
-});
-
-columns.push({
-id: "time",
-titleDOMFragment: this._makeHeaderFragment(WebInspector.UIString("Time"), WebInspector.UIString("Latency")),
-title: WebInspector.UIString("Time"),
-sortable: true,
-weight: 6,
-align: WebInspector.DataGrid.Align.Right
-});
-
-columns.push({
-id: "timeline",
-titleDOMFragment: document.createDocumentFragment(),
-title: WebInspector.UIString("Timeline"),
-sortable: false,
-weight: 40,
-sort: WebInspector.DataGrid.Order.Ascending
-});
-
-this._dataGrid = new WebInspector.DataGrid(columns);
-this._dataGrid.setName("networkLog");
-this._dataGrid.resizeMethod = WebInspector.DataGrid.ResizeMethod.Last;
-this._dataGrid.element.addStyleClass("network-log-grid");
-this._dataGrid.element.addEventListener("contextmenu", this._contextMenu.bind(this), true);
-this._dataGrid.show(this.element);
-
-
-this._dataGrid.addEventListener(WebInspector.DataGrid.Events.SortingChanged, this._sortItems, this);
-this._dataGrid.addEventListener(WebInspector.DataGrid.Events.ColumnsResized, this._updateDividersIfNeeded, this);
-this._dataGrid.scrollContainer.addEventListener("scroll", this._updateOffscreenRows.bind(this));
-
-this._patchTimelineHeader();
-},
-
-_makeHeaderFragment: function(title, subtitle)
-{
-var fragment = document.createDocumentFragment();
-fragment.createTextChild(title);
-var subtitleDiv = fragment.createChild("div", "network-header-subtitle");
-subtitleDiv.createTextChild(subtitle);
-return fragment;
-},
-
-_patchTimelineHeader: function()
-{
-var timelineSorting = document.createElement("select");
-
-var option = document.createElement("option");
-option.value = "startTime";
-option.label = WebInspector.UIString("Timeline");
-timelineSorting.appendChild(option);
-
-option = document.createElement("option");
-option.value = "startTime";
-option.label = WebInspector.UIString("Start Time");
-timelineSorting.appendChild(option);
-
-option = document.createElement("option");
-option.value = "responseTime";
-option.label = WebInspector.UIString("Response Time");
-timelineSorting.appendChild(option);
-
-option = document.createElement("option");
-option.value = "endTime";
-option.label = WebInspector.UIString("End Time");
-timelineSorting.appendChild(option);
-
-option = document.createElement("option");
-option.value = "duration";
-option.label = WebInspector.UIString("Duration");
-timelineSorting.appendChild(option);
-
-option = document.createElement("option");
-option.value = "latency";
-option.label = WebInspector.UIString("Latency");
-timelineSorting.appendChild(option);
-
-var header = this._dataGrid.headerTableHeader("timeline");
-header.replaceChild(timelineSorting, header.firstChild);
-
-timelineSorting.addEventListener("click", function(event) { event.consume() }, false);
-timelineSorting.addEventListener("change", this._sortByTimeline.bind(this), false);
-this._timelineSortSelector = timelineSorting;
-},
-
-_createSortingFunctions: function()
-{
-this._sortingFunctions = {};
-this._sortingFunctions.name = WebInspector.NetworkDataGridNode.NameComparator;
-this._sortingFunctions.method = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "method", false);
-this._sortingFunctions.status = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "statusCode", false);
-this._sortingFunctions.domain = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "domain", false);
-this._sortingFunctions.type = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "mimeType", false);
-this._sortingFunctions.initiator = WebInspector.NetworkDataGridNode.InitiatorComparator;
-this._sortingFunctions.cookies = WebInspector.NetworkDataGridNode.RequestCookiesCountComparator;
-this._sortingFunctions.setCookies = WebInspector.NetworkDataGridNode.ResponseCookiesCountComparator;
-this._sortingFunctions.size = WebInspector.NetworkDataGridNode.SizeComparator;
-this._sortingFunctions.time = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "duration", false);
-this._sortingFunctions.timeline = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "startTime", false);
-this._sortingFunctions.startTime = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "startTime", false);
-this._sortingFunctions.endTime = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "endTime", false);
-this._sortingFunctions.responseTime = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "responseReceivedTime", false);
-this._sortingFunctions.duration = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "duration", true);
-this._sortingFunctions.latency = WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null, "latency", true);
-
-var timeCalculator = new WebInspector.NetworkTransferTimeCalculator();
-var durationCalculator = new WebInspector.NetworkTransferDurationCalculator();
-
-this._calculators = {};
-this._calculators.timeline = timeCalculator;
-this._calculators.startTime = timeCalculator;
-this._calculators.endTime = timeCalculator;
-this._calculators.responseTime = timeCalculator;
-this._calculators.duration = durationCalculator;
-this._calculators.latency = durationCalculator;
-},
-
-_sortItems: function()
-{
-this._removeAllNodeHighlights();
-var columnIdentifier = this._dataGrid.sortColumnIdentifier();
-if (columnIdentifier === "timeline") {
-this._sortByTimeline();
-return;
-}
-var sortingFunction = this._sortingFunctions[columnIdentifier];
-if (!sortingFunction)
-return;
-
-this._dataGrid.sortNodes(sortingFunction, !this._dataGrid.isSortOrderAscending());
-this._timelineSortSelector.selectedIndex = 0;
-this._updateOffscreenRows();
-
-this.searchCanceled();
-
-WebInspector.notifications.dispatchEventToListeners(WebInspector.UserMetrics.UserAction, {
-action: WebInspector.UserMetrics.UserActionNames.NetworkSort,
-column: columnIdentifier,
-sortOrder: this._dataGrid.sortOrder()
-});
-},
-
-_sortByTimeline: function()
-{
-this._removeAllNodeHighlights();
-var selectedIndex = this._timelineSortSelector.selectedIndex;
-if (!selectedIndex)
-selectedIndex = 1;
-var selectedOption = this._timelineSortSelector[selectedIndex];
-var value = selectedOption.value;
-
-var sortingFunction = this._sortingFunctions[value];
-this._dataGrid.sortNodes(sortingFunction);
-this.calculator = this._calculators[value];
-if (this.calculator.startAtZero)
-this._timelineGrid.hideEventDividers();
-else
-this._timelineGrid.showEventDividers();
-this._dataGrid.markColumnAsSortedBy("timeline", WebInspector.DataGrid.Order.Ascending);
-this._updateOffscreenRows();
-},
-
-
-_addTypeFilter: function(typeName, label)
-{
-var typeFilterElement = this._filterBarElement.createChild("li", typeName);
-typeFilterElement.typeName = typeName;
-typeFilterElement.createTextChild(label);
-typeFilterElement.addEventListener("click", this._onTypeFilterClicked.bind(this), false);
-this._typeFilterElements[typeName] = typeFilterElement;
-},
-
-_createStatusBarItems: function()
-{
-var filterBarElement = document.createElement("div");
-filterBarElement.className = "scope-bar status-bar-item";
-filterBarElement.title = WebInspector.UIString("Use %s Click to select multiple types.", WebInspector.KeyboardShortcut.shortcutToString("", WebInspector.KeyboardShortcut.Modifiers.CtrlOrMeta));
-this._filterBarElement = filterBarElement;
-
-this._addTypeFilter(WebInspector.NetworkLogView.ALL_TYPES, WebInspector.UIString("All"));
-filterBarElement.createChild("div", "scope-bar-divider");
-
-for (var typeId in WebInspector.resourceTypes) {
-var type = WebInspector.resourceTypes[typeId];
-this._addTypeFilter(type.name(), type.categoryTitle());
-}
-
-this._progressBarContainer = document.createElement("div");
-this._progressBarContainer.className = "status-bar-item";
-},
-
-_createSummaryBar: function()
-{
-var tbody = this._dataGrid.dataTableBody;
-var tfoot = document.createElement("tfoot");
-var tr = tfoot.createChild("tr", "revealed network-summary-bar");
-var td = tr.createChild("td");
-td.setAttribute("colspan", 7);
-tbody.parentNode.insertBefore(tfoot, tbody);
-this._summaryBarElement = td;
-},
-
-_updateSummaryBar: function()
-{
-var requestsNumber = this._requests.length;
-
-if (!requestsNumber) {
-if (this._summaryBarElement._isDisplayingWarning)
-return;
-this._summaryBarElement._isDisplayingWarning = true;
-
-this._summaryBarElement.createChild("div", "warning-icon-small");
-this._summaryBarElement.appendChild(document.createTextNode(
-WebInspector.UIString("No requests captured. Reload the page to see detailed information on the network activity.")));
-return;
-}
-delete this._summaryBarElement._isDisplayingWarning;
-
-var transferSize = 0;
-var selectedRequestsNumber = 0;
-var selectedTransferSize = 0;
-var baseTime = -1;
-var maxTime = -1;
-for (var i = 0; i < this._requests.length; ++i) {
-var request = this._requests[i];
-var requestTransferSize = (request.cached || !request.transferSize) ? 0 : request.transferSize;
-transferSize += requestTransferSize;
-if (!this._filteredOutRequests.get(request)) {
-selectedRequestsNumber++;
-selectedTransferSize += requestTransferSize;
-}
-if (request.url === WebInspector.inspectedPageURL)
-baseTime = request.startTime;
-if (request.endTime > maxTime)
-maxTime = request.endTime;
-}
-var text = "";
-if (selectedRequestsNumber !== requestsNumber) {
-text += String.sprintf(WebInspector.UIString("%d / %d requests"), selectedRequestsNumber, requestsNumber);
-text += " \u2758 " + String.sprintf(WebInspector.UIString("%s / %s transferred"), Number.bytesToString(selectedTransferSize), Number.bytesToString(transferSize));
-} else {
-text += String.sprintf(WebInspector.UIString("%d requests"), requestsNumber);
-text += " \u2758 " + String.sprintf(WebInspector.UIString("%s transferred"), Number.bytesToString(transferSize));
-}
-if (baseTime !== -1 && this._mainRequestLoadTime !== -1 && this._mainRequestDOMContentTime !== -1 && this._mainRequestDOMContentTime > baseTime) {
-text += " \u2758 " + String.sprintf(WebInspector.UIString("%s (onload: %s, DOMContentLoaded: %s)"),
-Number.secondsToString(maxTime - baseTime),
-Number.secondsToString(this._mainRequestLoadTime - baseTime),
-Number.secondsToString(this._mainRequestDOMContentTime - baseTime));
-}
-this._summaryBarElement.textContent = text;
-},
-
-
-_onTypeFilterClicked: function(e)
-{
-var toggle;
-if (WebInspector.isMac())
-toggle = e.metaKey && !e.ctrlKey && !e.altKey && !e.shiftKey;
-else
-toggle = e.ctrlKey && !e.metaKey && !e.altKey && !e.shiftKey;
-
-this._toggleTypeFilter(e.target.typeName, toggle);
-
-this._removeAllNodeHighlights();
-this.searchCanceled();
-this._filterRequests();
-},
-
-
-_toggleTypeFilter: function(typeName, allowMultiSelect)
-{
-if (allowMultiSelect && typeName !== WebInspector.NetworkLogView.ALL_TYPES)
-this._typeFilterElements[WebInspector.NetworkLogView.ALL_TYPES].removeStyleClass("selected");
-else {
-for (var key in this._typeFilterElements)
-this._typeFilterElements[key].removeStyleClass("selected");
-}
-
-var filterElement = this._typeFilterElements[typeName];
-filterElement.enableStyleClass("selected", !filterElement.hasStyleClass("selected"));
-
-var allowedTypes = {};
-for (var key in this._typeFilterElements) {
-if (this._typeFilterElements[key].hasStyleClass("selected"))
-allowedTypes[key] = true;
-}
-
-if (typeName === WebInspector.NetworkLogView.ALL_TYPES)
-this._typeFilter = WebInspector.NetworkLogView._trivialTypeFilter;
-else
-this._typeFilter = WebInspector.NetworkLogView._typeFilter.bind(null, allowedTypes);
-},
-
-_scheduleRefresh: function()
-{
-if (this._needsRefresh)
-return;
-
-this._needsRefresh = true;
-
-if (this.isShowing() && !this._refreshTimeout)
-this._refreshTimeout = setTimeout(this.refresh.bind(this), WebInspector.NetworkLogView._defaultRefreshDelay);
-},
-
-_updateDividersIfNeeded: function()
-{
-if (!this._dataGrid)
-return;
-var timelineColumn = this._dataGrid.columns.timeline;
-for (var i = 0; i < this._dataGrid.resizers.length; ++i) {
-if (timelineColumn.ordinal === this._dataGrid.resizers[i].rightNeighboringColumnIndex) {
-
-this._timelineGrid.element.style.left = this._dataGrid.resizers[i].style.left;
-}
-}
-
-var proceed = true;
-if (!this.isShowing()) {
-this._scheduleRefresh();
-proceed = false;
-} else {
-this.calculator.setDisplayWindow(this._timelineGrid.dividersElement.clientWidth);
-proceed = this._timelineGrid.updateDividers(this.calculator);
-}
-if (!proceed)
-return;
-
-if (this.calculator.startAtZero || !this.calculator.computePercentageFromEventTime) {
-
-
-
-
-
-
-return;
-}
-
-this._timelineGrid.removeEventDividers();
-if (this._mainRequestLoadTime !== -1) {
-var percent = this.calculator.computePercentageFromEventTime(this._mainRequestLoadTime);
-
-var loadDivider = document.createElement("div");
-loadDivider.className = "network-event-divider network-red-divider";
-
-var loadDividerPadding = document.createElement("div");
-loadDividerPadding.className = "network-event-divider-padding";
-loadDividerPadding.title = WebInspector.UIString("Load event fired");
-loadDividerPadding.appendChild(loadDivider);
-loadDividerPadding.style.left = percent + "%";
-this._timelineGrid.addEventDivider(loadDividerPadding);
-}
-
-if (this._mainRequestDOMContentTime !== -1) {
-var percent = this.calculator.computePercentageFromEventTime(this._mainRequestDOMContentTime);
-
-var domContentDivider = document.createElement("div");
-domContentDivider.className = "network-event-divider network-blue-divider";
-
-var domContentDividerPadding = document.createElement("div");
-domContentDividerPadding.className = "network-event-divider-padding";
-domContentDividerPadding.title = WebInspector.UIString("DOMContent event fired");
-domContentDividerPadding.appendChild(domContentDivider);
-domContentDividerPadding.style.left = percent + "%";
-this._timelineGrid.addEventDivider(domContentDividerPadding);
-}
-},
-
-_refreshIfNeeded: function()
-{
-if (this._needsRefresh)
-this.refresh();
-},
-
-_invalidateAllItems: function()
-{
-for (var i = 0; i < this._requests.length; ++i) {
-var request = this._requests[i];
-this._staleRequests[request.requestId] = request;
-}
-},
-
-get calculator()
-{
-return this._calculator;
-},
-
-set calculator(x)
-{
-if (!x || this._calculator === x)
-return;
-
-this._calculator = x;
-this._calculator.reset();
-
-this._invalidateAllItems();
-this.refresh();
-},
-
-_requestGridNode: function(request)
-{
-return this._requestGridNodes[request.__gridNodeId];
-},
-
-_createRequestGridNode: function(request)
-{
-var node = new WebInspector.NetworkDataGridNode(this, request);
-request.__gridNodeId = this._lastRequestGridNodeId++;
-this._requestGridNodes[request.__gridNodeId] = node;
-return node;
-},
-
-_createStatusbarButtons: function()
-{
-this._preserveLogToggle = new WebInspector.StatusBarButton(WebInspector.UIString("Preserve Log upon Navigation"), "record-profile-status-bar-item");
-this._preserveLogToggle.addEventListener("click", this._onPreserveLogClicked, this);
-
-this._clearButton = new WebInspector.StatusBarButton(WebInspector.UIString("Clear"), "clear-status-bar-item");
-this._clearButton.addEventListener("click", this._reset, this);
-
-this._largerRequestsButton = new WebInspector.StatusBarButton(WebInspector.UIString("Use small resource rows."), "network-larger-resources-status-bar-item");
-this._largerRequestsButton.toggled = WebInspector.settings.resourcesLargeRows.get();
-this._largerRequestsButton.addEventListener("click", this._toggleLargerRequests, this);
-},
-
-_onLoadEventFired: function(event)
-{
-this._mainRequestLoadTime = event.data || -1;
-
-this._scheduleRefresh();
-},
-
-_domContentLoadedEventFired: function(event)
-{
-this._mainRequestDOMContentTime = event.data || -1;
-
-this._scheduleRefresh();
-},
-
-wasShown: function()
-{
-this._refreshIfNeeded();
-},
-
-willHide: function()
-{
-this._popoverHelper.hidePopover();
-},
-
-refresh: function()
-{
-this._needsRefresh = false;
-if (this._refreshTimeout) {
-clearTimeout(this._refreshTimeout);
-delete this._refreshTimeout;
-}
-
-this._removeAllNodeHighlights();
-var wasScrolledToLastRow = this._dataGrid.isScrolledToLastRow();
-var boundariesChanged = false;
-if (this.calculator.updateBoundariesForEventTime) {
-boundariesChanged = this.calculator.updateBoundariesForEventTime(this._mainRequestLoadTime) || boundariesChanged;
-boundariesChanged = this.calculator.updateBoundariesForEventTime(this._mainRequestDOMContentTime) || boundariesChanged;
-}
-
-for (var requestId in this._staleRequests) {
-var request = this._staleRequests[requestId];
-var node = this._requestGridNode(request);
-if (node)
-node.refreshRequest();
-else {
-
-node = this._createRequestGridNode(request);
-this._dataGrid.rootNode().appendChild(node);
-node.refreshRequest();
-this._applyFilter(node);
-}
-
-if (this.calculator.updateBoundaries(request))
-boundariesChanged = true;
-
-if (!node.isFilteredOut())
-this._updateHighlightIfMatched(request);
-}
-
-if (boundariesChanged) {
-
-this._invalidateAllItems();
-}
-
-for (var requestId in this._staleRequests)
-this._requestGridNode(this._staleRequests[requestId]).refreshGraph(this.calculator);
-
-this._staleRequests = {};
-this._sortItems();
-this._updateSummaryBar();
-this._dataGrid.updateWidths();
-
-if (wasScrolledToLastRow)
-this._dataGrid.scrollToLastRow();
-},
-
-_onPreserveLogClicked: function(e)
-{
-this._preserveLogToggle.toggled = !this._preserveLogToggle.toggled;
-},
-
-_reset: function()
-{
-this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.ViewCleared);
-
-this._clearSearchMatchedList();
-if (this._popoverHelper)
-this._popoverHelper.hidePopover();
-
-if (this._calculator)
-this._calculator.reset();
-
-this._requests = [];
-this._requestsById = {};
-this._requestsByURL = {};
-this._staleRequests = {};
-this._requestGridNodes = {};
-
-if (this._dataGrid) {
-this._dataGrid.rootNode().removeChildren();
-this._updateDividersIfNeeded();
-this._updateSummaryBar();
-}
-
-this._mainRequestLoadTime = -1;
-this._mainRequestDOMContentTime = -1;
-},
-
-get requests()
-{
-return this._requests;
-},
-
-requestById: function(id)
-{
-return this._requestsById[id];
-},
-
-_onRequestStarted: function(event)
-{
-this._appendRequest(event.data);
-},
-
-_appendRequest: function(request)
-{
-this._requests.push(request);
-
-
-
-if (this._requestsById[request.requestId]) {
-var oldRequest = request.redirects[request.redirects.length - 1];
-this._requestsById[oldRequest.requestId] = oldRequest;
-
-this._updateSearchMatchedListAfterRequestIdChanged(request.requestId, oldRequest.requestId);
-}
-this._requestsById[request.requestId] = request;
-
-this._requestsByURL[request.url] = request;
-
-
-if (request.redirects) {
-for (var i = 0; i < request.redirects.length; ++i)
-this._refreshRequest(request.redirects[i]);
-}
-
-this._refreshRequest(request);
-},
-
-
-_onRequestUpdated: function(event)
-{
-var request = (event.data);
-this._refreshRequest(request);
-},
-
-
-_refreshRequest: function(request)
-{
-this._staleRequests[request.requestId] = request;
-this._scheduleRefresh();
-},
-
-clear: function()
-{
-if (this._preserveLogToggle.toggled)
-return;
-this._reset();
-},
-
-_mainFrameNavigated: function(event)
-{
-if (this._preserveLogToggle.toggled)
-return;
-
-var frame = (event.data);
-var loaderId = frame.loaderId;
-
-
-var requestsToPreserve = [];
-for (var i = 0; i < this._requests.length; ++i) {
-var request = this._requests[i];
-if (request.loaderId === loaderId)
-requestsToPreserve.push(request);
-}
-
-this._reset();
-
-
-for (var i = 0; i < requestsToPreserve.length; ++i)
-this._appendRequest(requestsToPreserve[i]);
-},
-
-switchToDetailedView: function()
-{
-if (!this._dataGrid)
-return;
-if (this._dataGrid.selectedNode)
-this._dataGrid.selectedNode.selected = false;
-
-this.element.removeStyleClass("brief-mode");
-this._detailedMode = true;
-this._updateColumns();
-},
-
-switchToBriefView: function()
-{
-this.element.addStyleClass("brief-mode");
-this._removeAllNodeHighlights();
-this._detailedMode = false;
-this._updateColumns();
-this._popoverHelper.hidePopover();
-},
-
-_toggleLargerRequests: function()
-{
-WebInspector.settings.resourcesLargeRows.set(!WebInspector.settings.resourcesLargeRows.get());
-this._setLargerRequests(WebInspector.settings.resourcesLargeRows.get());
-},
-
-_setLargerRequests: function(enabled)
-{
-this._largerRequestsButton.toggled = enabled;
-if (!enabled) {
-this._largerRequestsButton.title = WebInspector.UIString("Use large resource rows.");
-this._dataGrid.element.addStyleClass("small");
-this._timelineGrid.element.addStyleClass("small");
-} else {
-this._largerRequestsButton.title = WebInspector.UIString("Use small resource rows.");
-this._dataGrid.element.removeStyleClass("small");
-this._timelineGrid.element.removeStyleClass("small");
-}
-this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.RowSizeChanged, { largeRows: enabled });
-this._updateOffscreenRows();
-},
-
-_getPopoverAnchor: function(element)
-{
-if (!this._allowPopover)
-return;
-var anchor = element.enclosingNodeOrSelfWithClass("network-graph-bar") || element.enclosingNodeOrSelfWithClass("network-graph-label");
-if (anchor && anchor.parentElement.request && anchor.parentElement.request.timing)
-return anchor;
-anchor = element.enclosingNodeOrSelfWithClass("network-script-initiated");
-if (anchor && anchor.request && anchor.request.initiator)
-return anchor;
-
-return null;
-},
-
-
-_showPopover: function(anchor, popover)
-{
-var content;
-if (anchor.hasStyleClass("network-script-initiated"))
-content = this._generateScriptInitiatedPopoverContent(anchor.request);
-else
-content = WebInspector.RequestTimingView.createTimingTable(anchor.parentElement.request);
-popover.show(content, anchor);
-},
-
-_onHidePopover: function()
-{
-this._linkifier.reset();
-},
-
-
-_generateScriptInitiatedPopoverContent: function(request)
-{
-var stackTrace = request.initiator.stackTrace;
-var framesTable = document.createElement("table");
-for (var i = 0; i < stackTrace.length; ++i) {
-var stackFrame = stackTrace[i];
-var row = document.createElement("tr");
-row.createChild("td").textContent = stackFrame.functionName ? stackFrame.functionName : WebInspector.UIString("(anonymous function)");
-row.createChild("td").textContent = " @ ";
-row.createChild("td").appendChild(this._linkifier.linkifyLocation(stackFrame.url, stackFrame.lineNumber - 1, stackFrame.columnNumber - 1));
-framesTable.appendChild(row);
-}
-return framesTable;
-},
-
-_updateColumns: function()
-{
-var columnsVisibility = this._coulmnsVisibilitySetting.get();
-var detailedMode = !!this._detailedMode;
-for (var columnIdentifier in columnsVisibility) {
-var visible = detailedMode && columnsVisibility[columnIdentifier];
-this._dataGrid.setColumnVisible(columnIdentifier, visible);
-}
-this._dataGrid.setColumnVisible("timeline", detailedMode);
-this._dataGrid.applyColumnWeights();
-},
-
-
-_toggleColumnVisibility: function(columnIdentifier)
-{
-var columnsVisibility = this._coulmnsVisibilitySetting.get();
-columnsVisibility[columnIdentifier] = !columnsVisibility[columnIdentifier];
-this._coulmnsVisibilitySetting.set(columnsVisibility);
-
-this._updateColumns();
-},
-
-
-_getConfigurableColumnIDs: function()
-{
-if (this._configurableColumnIDs)
-return this._configurableColumnIDs;
-
-var columns = this._dataGrid.columns;
-function compare(id1, id2)
-{
-return columns[id1].title.compareTo(columns[id2].title);
-}
-
-var columnIDs = Object.keys(this._coulmnsVisibilitySetting.get());
-this._configurableColumnIDs = columnIDs.sort(compare);
-return this._configurableColumnIDs;
-},
-
-_contextMenu: function(event)
-{
-var contextMenu = new WebInspector.ContextMenu(event);
-
-if (this._detailedMode && event.target.isSelfOrDescendant(this._dataGrid.headerTableBody)) {
-var columnsVisibility = this._coulmnsVisibilitySetting.get();
-var columnIDs = this._getConfigurableColumnIDs();
-for (var i = 0; i < columnIDs.length; ++i) {
-var columnIdentifier = columnIDs[i];
-var column = this._dataGrid.columns[columnIdentifier];
-contextMenu.appendCheckboxItem(column.title, this._toggleColumnVisibility.bind(this, columnIdentifier), !!columnsVisibility[columnIdentifier]);
-}
-contextMenu.show();
-return;
-}
-
-var gridNode = this._dataGrid.dataGridNodeFromNode(event.target);
-var request = gridNode && gridNode._request;
-
-if (request) {
-contextMenu.appendItem(WebInspector.openLinkExternallyLabel(), WebInspector.openResource.bind(WebInspector, request.url, false));
-contextMenu.appendSeparator();
-contextMenu.appendItem(WebInspector.copyLinkAddressLabel(), this._copyLocation.bind(this, request));
-if (request.requestHeadersText)
-contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles() ? "Copy request headers" : "Copy Request Headers"), this._copyRequestHeaders.bind(this, request));
-if (request.responseHeadersText)
-contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles() ? "Copy response headers" : "Copy Response Headers"), this._copyResponseHeaders.bind(this, request));
-contextMenu.appendItem(WebInspector.UIString("Copy as cURL"), this._copyCurlCommand.bind(this, request));
-}
-contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles() ? "Copy all as HAR" : "Copy All as HAR"), this._copyAll.bind(this));
-
-contextMenu.appendSeparator();
-contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles() ? "Save as HAR with content" : "Save as HAR with Content"), this._exportAll.bind(this));
-
-contextMenu.appendSeparator();
-contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles() ? "Clear browser cache" : "Clear Browser Cache"), this._clearBrowserCache.bind(this));
-contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles() ? "Clear browser cookies" : "Clear Browser Cookies"), this._clearBrowserCookies.bind(this));
-
-if (request && request.type === WebInspector.resourceTypes.XHR) {
-contextMenu.appendSeparator();
-contextMenu.appendItem(WebInspector.UIString("Replay XHR"), this._replayXHR.bind(this, request.requestId));
-contextMenu.appendSeparator();
-}
-
-contextMenu.show();
-},
-
-_replayXHR: function(requestId)
-{
-NetworkAgent.replayXHR(requestId);
-},
-
-_copyAll: function()
-{
-var harArchive = {
-log: (new WebInspector.HARLog(this._requests.filter(WebInspector.NetworkLogView.HTTPRequestsFilter))).build()
-};
-InspectorFrontendHost.copyText(JSON.stringify(harArchive, null, 2));
-},
-
-_copyLocation: function(request)
-{
-InspectorFrontendHost.copyText(request.url);
-},
-
-_copyRequestHeaders: function(request)
-{
-InspectorFrontendHost.copyText(request.requestHeadersText);
-},
-
-_copyResponseHeaders: function(request)
-{
-InspectorFrontendHost.copyText(request.responseHeadersText);
-},
-
-
-_copyCurlCommand: function(request)
-{
-InspectorFrontendHost.copyText(this._generateCurlCommand(request));
-},
-
-_exportAll: function()
-{
-var filename = WebInspector.inspectedPageDomain + ".har";
-var stream = new WebInspector.FileOutputStream();
-stream.open(filename, openCallback.bind(this));
-function openCallback()
-{
-var progressIndicator = new WebInspector.ProgressIndicator();
-this._progressBarContainer.appendChild(progressIndicator.element);
-var harWriter = new WebInspector.HARWriter();
-harWriter.write(stream, this._requests.filter(WebInspector.NetworkLogView.HTTPRequestsFilter), progressIndicator);
-}
-},
-
-_clearBrowserCache: function()
-{
-if (confirm(WebInspector.UIString("Are you sure you want to clear browser cache?")))
-NetworkAgent.clearBrowserCache();
-},
-
-_clearBrowserCookies: function()
-{
-if (confirm(WebInspector.UIString("Are you sure you want to clear browser cookies?")))
-NetworkAgent.clearBrowserCookies();
-},
-
-_updateOffscreenRows: function()
-{
-var dataTableBody = this._dataGrid.dataTableBody;
-var rows = dataTableBody.children;
-var recordsCount = rows.length;
-if (recordsCount < 2)
-return;
-
-var visibleTop = this._dataGrid.scrollContainer.scrollTop;
-var visibleBottom = visibleTop + this._dataGrid.scrollContainer.offsetHeight;
-
-var rowHeight = 0;
-
-
-var unfilteredRowIndex = 0;
-for (var i = 0; i < recordsCount - 1; ++i) {
-var row = rows[i];
-
-var dataGridNode = this._dataGrid.dataGridNodeFromNode(row);
-if (dataGridNode.isFilteredOut()) {
-row.removeStyleClass("offscreen");
-continue;
-}
-
-if (!rowHeight)
-rowHeight = row.offsetHeight;
-
-var rowIsVisible = unfilteredRowIndex * rowHeight < visibleBottom && (unfilteredRowIndex + 1) * rowHeight > visibleTop;
-if (rowIsVisible !== row.rowIsVisible) {
-row.enableStyleClass("offscreen", !rowIsVisible);
-row.rowIsVisible = rowIsVisible;
-}
-unfilteredRowIndex++;
-}
-},
-
-_matchRequest: function(request)
-{
-if (!this._searchRegExp)
-return -1;
-
-if (!request.name().match(this._searchRegExp) && !request.path().match(this._searchRegExp))
-return -1;
-
-if (request.requestId in this._matchedRequestsMap)
-return this._matchedRequestsMap[request.requestId];
-
-var matchedRequestIndex = this._matchedRequests.length;
-this._matchedRequestsMap[request.requestId] = matchedRequestIndex;
-this._matchedRequests.push(request.requestId);
-
-return matchedRequestIndex;
-},
-
-_clearSearchMatchedList: function()
-{
-delete this._searchRegExp;
-this._matchedRequests = [];
-this._matchedRequestsMap = {};
-this._removeAllHighlights();
-},
-
-_updateSearchMatchedListAfterRequestIdChanged: function(oldRequestId, newRequestId)
-{
-var requestIndex = this._matchedRequestsMap[oldRequestId];
-if (requestIndex) {
-delete this._matchedRequestsMap[oldRequestId];
-this._matchedRequestsMap[newRequestId] = requestIndex;
-this._matchedRequests[requestIndex] = newRequestId;
-}
-},
-
-_updateHighlightIfMatched: function(request)
-{
-var matchedRequestIndex = this._matchRequest(request);
-if (matchedRequestIndex === -1)
-return;
-
-this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.SearchCountUpdated, this._matchedRequests.length);
-
-if (this._currentMatchedRequestIndex !== -1 && this._currentMatchedRequestIndex !== matchedRequestIndex)
-return;
-
-this._highlightNthMatchedRequestForSearch(matchedRequestIndex, false);
-},
-
-_removeAllHighlights: function()
-{
-for (var i = 0; i < this._highlightedSubstringChanges.length; ++i)
-WebInspector.revertDomChanges(this._highlightedSubstringChanges[i]);
-this._highlightedSubstringChanges = [];
-},
-
-
-_highlightMatchedRequest: function(request, reveal, regExp)
-{
-var node = this._requestGridNode(request);
-if (!node)
-return;
-
-var nameMatched = request.name().match(regExp);
-var pathMatched = request.path().match(regExp);
-if (!nameMatched && pathMatched && !this._largerRequestsButton.toggled)
-this._toggleLargerRequests();
-var highlightedSubstringChanges = node._highlightMatchedSubstring(regExp);
-this._highlightedSubstringChanges.push(highlightedSubstringChanges);
-if (reveal)
-node.reveal();
-},
-
-
-_highlightNthMatchedRequestForSearch: function(matchedRequestIndex, reveal)
-{
-var request = this.requestById(this._matchedRequests[matchedRequestIndex]);
-if (!request)
-return;
-this._removeAllHighlights();
-this._highlightMatchedRequest(request, reveal, this._searchRegExp);
-var node = this._requestGridNode(request);
-if (node)
-this._currentMatchedRequestIndex = matchedRequestIndex;
-
-this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.SearchIndexUpdated, this._currentMatchedRequestIndex);
-},
-
-performSearch: function(searchQuery)
-{
-var newMatchedRequestIndex = 0;
-var currentMatchedRequestId;
-if (this._currentMatchedRequestIndex !== -1)
-currentMatchedRequestId = this._matchedRequests[this._currentMatchedRequestIndex];
-
-this._clearSearchMatchedList();
-this._searchRegExp = createPlainTextSearchRegex(searchQuery, "i");
-
-var childNodes = this._dataGrid.dataTableBody.childNodes;
-var requestNodes = Array.prototype.slice.call(childNodes, 0, childNodes.length - 1);
-
-for (var i = 0; i < requestNodes.length; ++i) {
-var dataGridNode = this._dataGrid.dataGridNodeFromNode(requestNodes[i]);
-if (dataGridNode.isFilteredOut())
-continue;
-if (this._matchRequest(dataGridNode._request) !== -1 && dataGridNode._request.requestId === currentMatchedRequestId)
-newMatchedRequestIndex = this._matchedRequests.length - 1;
-}
-
-this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.SearchCountUpdated, this._matchedRequests.length);
-this._highlightNthMatchedRequestForSearch(newMatchedRequestIndex, false);
-},
-
-
-_applyFilter: function(node)
-{
-var filter = this._filterRegExp;
-var request = node._request;
-var matches = false;
-if (this._typeFilter(request)) {
-matches = !filter || filter.test(request.name()) || filter.test(request.path());
-if (filter && matches)
-this._highlightMatchedRequest(request, false, filter);
-}
-node.element.enableStyleClass("filtered-out", !matches);
-if (!matches)
-this._filteredOutRequests.put(request, true);
-},
-
-
-performFilter: function(query)
-{
-delete this._filterRegExp;
-if (query)
-this._filterRegExp = createPlainTextSearchRegex(query, "i");
-this._filterRequests();
-},
-
-_filterRequests: function()
-{
-this._removeAllHighlights();
-this._filteredOutRequests.clear();
-
-var nodes = this._dataGrid.rootNode().children;
-for (var i = 0; i < nodes.length; ++i)
-this._applyFilter(nodes[i]);
-this._updateSummaryBar();
-this._updateOffscreenRows();
-},
-
-jumpToPreviousSearchResult: function()
-{
-if (!this._matchedRequests.length)
-return;
-this._highlightNthMatchedRequestForSearch((this._currentMatchedRequestIndex + this._matchedRequests.length - 1) % this._matchedRequests.length, true);
-},
-
-jumpToNextSearchResult: function()
-{
-if (!this._matchedRequests.length)
-return;
-this._highlightNthMatchedRequestForSearch((this._currentMatchedRequestIndex + 1) % this._matchedRequests.length, true);
-},
-
-searchCanceled: function()
-{
-this._clearSearchMatchedList();
-this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.SearchCountUpdated, 0);
-},
-
-revealAndHighlightRequest: function(request)
-{
-this._removeAllNodeHighlights();
-
-var node = this._requestGridNode(request);
-if (node) {
-this._dataGrid.element.focus();
-node.reveal();
-this._highlightNode(node);
-}
-},
-
-_removeAllNodeHighlights: function()
-{
-if (this._highlightedNode) {
-this._highlightedNode.element.removeStyleClass("highlighted-row");
-delete this._highlightedNode;
-}
-},
-
-_highlightNode: function(node)
-{
-node.element.addStyleClass("highlighted-row");
-this._highlightedNode = node;
-},
-
-
-_generateCurlCommand: function(request)
-{
-var command = ["curl"];
-var ignoredHeaders = {};
-
-function escapeCharacter(x)
-{
-var code = x.charCodeAt(0);
-if (code < 256) {
-
-return code < 16 ? "\\x0" + code.toString(16) : "\\x" + code.toString(16);
-}
-code = code.toString(16);
-return "\\u" + ("0000" + code).substr(code.length, 4);
-}
-
+WebInspector.RequestView=function(request)
+{WebInspector.View.call(this);this.registerRequiredCSS("resourceView.css");this.element.addStyleClass("resource-view");this.request=request;}
+WebInspector.RequestView.prototype={hasContent:function()
+{return false;},__proto__:WebInspector.View.prototype}
+WebInspector.RequestView.hasTextContent=function(request)
+{if(request.type.isTextType())
+return true;if(request.type===WebInspector.resourceTypes.Other||request.hasErrorStatusCode())
+return request.content&&!request.contentEncoded;return false;}
+WebInspector.RequestView.nonSourceViewForRequest=function(request)
+{switch(request.type){case WebInspector.resourceTypes.Image:return new WebInspector.ImageView(request);case WebInspector.resourceTypes.Font:return new WebInspector.FontView(request);default:return new WebInspector.RequestView(request);}};WebInspector.NetworkItemView=function(request)
+{WebInspector.TabbedPane.call(this);this.element.addStyleClass("network-item-view");var headersView=new WebInspector.RequestHeadersView(request);this.appendTab("headers",WebInspector.UIString("Headers"),headersView);this.addEventListener(WebInspector.TabbedPane.EventTypes.TabSelected,this._tabSelected,this);if(request.type===WebInspector.resourceTypes.WebSocket){var frameView=new WebInspector.ResourceWebSocketFrameView(request);this.appendTab("webSocketFrames",WebInspector.UIString("Frames"),frameView);}else{var responseView=new WebInspector.RequestResponseView(request);var previewView=new WebInspector.RequestPreviewView(request,responseView);this.appendTab("preview",WebInspector.UIString("Preview"),previewView);this.appendTab("response",WebInspector.UIString("Response"),responseView);}
+if(request.requestCookies||request.responseCookies){this._cookiesView=new WebInspector.RequestCookiesView(request);this.appendTab("cookies",WebInspector.UIString("Cookies"),this._cookiesView);}
+if(request.timing){var timingView=new WebInspector.RequestTimingView(request);this.appendTab("timing",WebInspector.UIString("Timing"),timingView);}
+this._request=request;}
+WebInspector.NetworkItemView.prototype={wasShown:function()
+{WebInspector.TabbedPane.prototype.wasShown.call(this);this._selectTab();},_selectTab:function(tabId)
+{if(!tabId)
+tabId=WebInspector.settings.resourceViewTab.get();if(!this.selectTab(tabId)){this._isInFallbackSelection=true;this.selectTab("headers");delete this._isInFallbackSelection;}},_tabSelected:function(event)
+{if(!event.data.isUserGesture)
+return;WebInspector.settings.resourceViewTab.set(event.data.tabId);WebInspector.notifications.dispatchEventToListeners(WebInspector.UserMetrics.UserAction,{action:WebInspector.UserMetrics.UserActionNames.NetworkRequestTabSelected,tab:event.data.tabId,url:this._request.url});},request:function()
+{return this._request;},__proto__:WebInspector.TabbedPane.prototype}
+WebInspector.RequestContentView=function(request)
+{WebInspector.RequestView.call(this,request);}
+WebInspector.RequestContentView.prototype={hasContent:function()
+{return true;},get innerView()
+{return this._innerView;},set innerView(innerView)
+{this._innerView=innerView;},wasShown:function()
+{this._ensureInnerViewShown();},_ensureInnerViewShown:function()
+{if(this._innerViewShowRequested)
+return;this._innerViewShowRequested=true;function callback(content,contentEncoded,mimeType)
+{this._innerViewShowRequested=false;this.contentLoaded();}
+this.request.requestContent(callback.bind(this));},contentLoaded:function()
+{},canHighlightPosition:function()
+{return this._innerView&&this._innerView.canHighlightPosition();},highlightPosition:function(line,column)
+{if(this.canHighlightPosition())
+this._innerView.highlightPosition(line,column);},__proto__:WebInspector.RequestView.prototype};WebInspector.RequestCookiesView=function(request)
+{WebInspector.View.call(this);this.element.addStyleClass("resource-cookies-view");this._request=request;}
+WebInspector.RequestCookiesView.prototype={wasShown:function()
+{this._request.addEventListener(WebInspector.NetworkRequest.Events.RequestHeadersChanged,this._refreshCookies,this);this._request.addEventListener(WebInspector.NetworkRequest.Events.ResponseHeadersChanged,this._refreshCookies,this);if(!this._gotCookies){if(!this._emptyView){this._emptyView=new WebInspector.EmptyView(WebInspector.UIString("This request has no cookies."));this._emptyView.show(this.element);}
+return;}
+if(!this._cookiesTable)
+this._buildCookiesTable();},willHide:function()
+{this._request.removeEventListener(WebInspector.NetworkRequest.Events.RequestHeadersChanged,this._refreshCookies,this);this._request.removeEventListener(WebInspector.NetworkRequest.Events.ResponseHeadersChanged,this._refreshCookies,this);},get _gotCookies()
+{return(this._request.requestCookies&&this._request.requestCookies.length)||(this._request.responseCookies&&this._request.responseCookies.length);},_buildCookiesTable:function()
+{this.detachChildViews();this._cookiesTable=new WebInspector.CookiesTable(true);this._cookiesTable.setCookieFolders([{folderName:WebInspector.UIString("Request Cookies"),cookies:this._request.requestCookies},{folderName:WebInspector.UIString("Response Cookies"),cookies:this._request.responseCookies}]);this._cookiesTable.show(this.element);},_refreshCookies:function()
+{delete this._cookiesTable;if(!this._gotCookies||!this.isShowing())
+return;this._buildCookiesTable();},__proto__:WebInspector.View.prototype};WebInspector.RequestHeadersView=function(request)
+{WebInspector.View.call(this);this.registerRequiredCSS("resourceView.css");this.element.addStyleClass("resource-headers-view");this._request=request;this._headersListElement=document.createElement("ol");this._headersListElement.className="outline-disclosure";this.element.appendChild(this._headersListElement);this._headersTreeOutline=new TreeOutline(this._headersListElement);this._headersTreeOutline.expandTreeElementsWhenArrowing=true;this._urlTreeElement=new TreeElement("",null,false);this._urlTreeElement.selectable=false;this._headersTreeOutline.appendChild(this._urlTreeElement);this._requestMethodTreeElement=new TreeElement("",null,false);this._requestMethodTreeElement.selectable=false;this._headersTreeOutline.appendChild(this._requestMethodTreeElement);this._statusCodeTreeElement=new TreeElement("",null,false);this._statusCodeTreeElement.selectable=false;this._headersTreeOutline.appendChild(this._statusCodeTreeElement);this._requestHeadersTreeElement=new TreeElement("",null,true);this._requestHeadersTreeElement.expanded=true;this._requestHeadersTreeElement.selectable=false;this._headersTreeOutline.appendChild(this._requestHeadersTreeElement);this._decodeRequestParameters=true;this._showRequestHeadersText=false;this._showResponseHeadersText=false;this._queryStringTreeElement=new TreeElement("",null,true);this._queryStringTreeElement.expanded=true;this._queryStringTreeElement.selectable=false;this._queryStringTreeElement.hidden=true;this._headersTreeOutline.appendChild(this._queryStringTreeElement);this._urlFragmentTreeElement=new TreeElement("",null,true);this._urlFragmentTreeElement.expanded=true;this._urlFragmentTreeElement.selectable=false;this._urlFragmentTreeElement.hidden=true;this._headersTreeOutline.appendChild(this._urlFragmentTreeElement);this._formDataTreeElement=new TreeElement("",null,true);this._formDataTreeElement.expanded=true;this._formDataTreeElement.selectable=false;this._formDataTreeElement.hidden=true;this._headersTreeOutline.appendChild(this._formDataTreeElement);this._requestPayloadTreeElement=new TreeElement(WebInspector.UIString("Request Payload"),null,true);this._requestPayloadTreeElement.expanded=true;this._requestPayloadTreeElement.selectable=false;this._requestPayloadTreeElement.hidden=true;this._headersTreeOutline.appendChild(this._requestPayloadTreeElement);this._responseHeadersTreeElement=new TreeElement("",null,true);this._responseHeadersTreeElement.expanded=true;this._responseHeadersTreeElement.selectable=false;this._headersTreeOutline.appendChild(this._responseHeadersTreeElement);}
+WebInspector.RequestHeadersView.prototype={wasShown:function()
+{this._request.addEventListener(WebInspector.NetworkRequest.Events.RequestHeadersChanged,this._refreshRequestHeaders,this);this._request.addEventListener(WebInspector.NetworkRequest.Events.ResponseHeadersChanged,this._refreshResponseHeaders,this);this._request.addEventListener(WebInspector.NetworkRequest.Events.FinishedLoading,this._refreshHTTPInformation,this);this._refreshURL();this._refreshQueryString();this._refreshUrlFragment();this._refreshRequestHeaders();this._refreshResponseHeaders();this._refreshHTTPInformation();},willHide:function()
+{this._request.removeEventListener(WebInspector.NetworkRequest.Events.RequestHeadersChanged,this._refreshRequestHeaders,this);this._request.removeEventListener(WebInspector.NetworkRequest.Events.ResponseHeadersChanged,this._refreshResponseHeaders,this);this._request.removeEventListener(WebInspector.NetworkRequest.Events.FinishedLoading,this._refreshHTTPInformation,this);},_formatHeader:function(name,value)
+{var fragment=document.createDocumentFragment();fragment.createChild("div","header-name").textContent=name+":";fragment.createChild("div","header-value source-code").textContent=value;return fragment;},_formatParameter:function(value,className,decodeParameters)
+{var errorDecoding=false;if(decodeParameters){value=value.replace(/\+/g," ");if(value.indexOf("%")>=0){try{value=decodeURIComponent(value);}catch(e){errorDecoding=true;}}}
+var div=document.createElement("div");div.className=className;if(errorDecoding)
+div.createChild("span","error-message").textContent=WebInspector.UIString("(unable to decode value)");else
+div.textContent=value;return div;},_refreshURL:function()
+{this._urlTreeElement.title=this._formatHeader(WebInspector.UIString("Request URL"),this._request.url);},_refreshQueryString:function()
+{var queryString=this._request.queryString();var queryParameters=this._request.queryParameters;this._queryStringTreeElement.hidden=!queryParameters;if(queryParameters)
+this._refreshParams(WebInspector.UIString("Query String Parameters"),queryParameters,queryString,this._queryStringTreeElement);},_refreshUrlFragment:function()
+{var urlFragment=this._request.parsedURL.fragment;this._urlFragmentTreeElement.hidden=!urlFragment;if(!urlFragment)
+return;var sectionTitle=WebInspector.UIString("URL fragment");this._urlFragmentTreeElement.removeChildren();this._urlFragmentTreeElement.listItemElement.removeChildren();this._urlFragmentTreeElement.listItemElement.appendChild(document.createTextNode(sectionTitle));var fragmentTreeElement=new TreeElement(null,null,false);fragmentTreeElement.title=this._formatHeader("#",urlFragment);fragmentTreeElement.selectable=false;this._urlFragmentTreeElement.appendChild(fragmentTreeElement);},_refreshFormData:function()
+{this._formDataTreeElement.hidden=true;this._requestPayloadTreeElement.hidden=true;var formData=this._request.requestFormData;if(!formData)
+return;var formParameters=this._request.formParameters;if(formParameters){this._formDataTreeElement.hidden=false;this._refreshParams(WebInspector.UIString("Form Data"),formParameters,formData,this._formDataTreeElement);}else{this._requestPayloadTreeElement.hidden=false;try{var json=JSON.parse(formData);this._refreshRequestJSONPayload(json,formData,false);}catch(e){this._populateTreeElementWithSourceText(this._requestPayloadTreeElement,formData);}}},_populateTreeElementWithSourceText:function(treeElement,sourceText)
+{treeElement.removeChildren();var sourceTreeElement=new TreeElement(null,null,false);sourceTreeElement.selectable=false;treeElement.appendChild(sourceTreeElement);var sourceTextElement=document.createElement("span");sourceTextElement.addStyleClass("header-value");sourceTextElement.addStyleClass("source-code");sourceTextElement.textContent=String(sourceText).trim();sourceTreeElement.listItemElement.appendChild(sourceTextElement);},_refreshParams:function(title,params,sourceText,paramsTreeElement)
+{paramsTreeElement.removeChildren();paramsTreeElement.listItemElement.removeChildren();paramsTreeElement.listItemElement.appendChild(document.createTextNode(title));var headerCount=document.createElement("span");headerCount.addStyleClass("header-count");headerCount.textContent=WebInspector.UIString(" (%d)",params.length);paramsTreeElement.listItemElement.appendChild(headerCount);function toggleViewSource()
+{paramsTreeElement._viewSource=!paramsTreeElement._viewSource;this._refreshParams(title,params,sourceText,paramsTreeElement);}
+paramsTreeElement.listItemElement.appendChild(this._createViewSourceToggle(paramsTreeElement._viewSource,toggleViewSource.bind(this)));if(paramsTreeElement._viewSource){this._populateTreeElementWithSourceText(paramsTreeElement,sourceText);return;}
+var toggleTitle=this._decodeRequestParameters?WebInspector.UIString("view URL encoded"):WebInspector.UIString("view decoded");var toggleButton=this._createToggleButton(toggleTitle);toggleButton.addEventListener("click",this._toggleURLDecoding.bind(this));paramsTreeElement.listItemElement.appendChild(toggleButton);for(var i=0;i<params.length;++i){var paramNameValue=document.createDocumentFragment();var name=this._formatParameter(params[i].name+":","header-name",this._decodeRequestParameters);var value=this._formatParameter(params[i].value,"header-value source-code",this._decodeRequestParameters);paramNameValue.appendChild(name);paramNameValue.appendChild(value);var parmTreeElement=new TreeElement(paramNameValue,null,false);parmTreeElement.selectable=false;paramsTreeElement.appendChild(parmTreeElement);}},_refreshRequestJSONPayload:function(parsedObject,sourceText,viewSource)
+{this._requestPayloadTreeElement.removeChildren();var listItem=this._requestPayloadTreeElement.listItemElement;listItem.removeChildren();listItem.appendChild(document.createTextNode(this._requestPayloadTreeElement.title));var setViewSource=this._refreshRequestJSONPayload.bind(this,parsedObject,sourceText);if(viewSource){listItem.appendChild(this._createViewSourceToggle(true,setViewSource.bind(this,false)));this._populateTreeElementWithSourceText(this._requestPayloadTreeElement,sourceText);}else{listItem.appendChild(this._createViewSourceToggle(false,setViewSource.bind(this,true)));var object=WebInspector.RemoteObject.fromLocalObject(parsedObject);var section=new WebInspector.ObjectPropertiesSection(object,object.description);section.expand();section.editable=false;listItem.appendChild(section.element);}},_createViewSourceToggle:function(viewSource,handler)
+{var viewSourceToggleTitle=viewSource?WebInspector.UIString("view parsed"):WebInspector.UIString("view source");var viewSourceToggleButton=this._createToggleButton(viewSourceToggleTitle);viewSourceToggleButton.addEventListener("click",handler);return viewSourceToggleButton;},_toggleURLDecoding:function(event)
+{this._decodeRequestParameters=!this._decodeRequestParameters;this._refreshQueryString();this._refreshFormData();},_getHeaderValue:function(headers,key)
+{var lowerKey=key.toLowerCase();for(var testKey in headers){if(testKey.toLowerCase()===lowerKey)
+return headers[testKey];}},_refreshRequestHeaders:function()
+{if(this._showRequestHeadersText)
+this._refreshHeadersText(WebInspector.UIString("Request Headers"),this._request.sortedRequestHeaders,this._request.requestHeadersText,this._requestHeadersTreeElement);else
+this._refreshHeaders(WebInspector.UIString("Request Headers"),this._request.sortedRequestHeaders,this._requestHeadersTreeElement);if(this._request.requestHeadersText){var toggleButton=this._createHeadersToggleButton(this._showRequestHeadersText);toggleButton.addEventListener("click",this._toggleRequestHeadersText.bind(this));this._requestHeadersTreeElement.listItemElement.appendChild(toggleButton);}
+this._refreshFormData();},_refreshResponseHeaders:function()
+{if(this._showResponseHeadersText)
+this._refreshHeadersText(WebInspector.UIString("Response Headers"),this._request.sortedResponseHeaders,this._request.responseHeadersText,this._responseHeadersTreeElement);else
+this._refreshHeaders(WebInspector.UIString("Response Headers"),this._request.sortedResponseHeaders,this._responseHeadersTreeElement);if(this._request.responseHeadersText){var toggleButton=this._createHeadersToggleButton(this._showResponseHeadersText);toggleButton.addEventListener("click",this._toggleResponseHeadersText.bind(this));this._responseHeadersTreeElement.listItemElement.appendChild(toggleButton);}},_refreshHTTPInformation:function()
+{var requestMethodElement=this._requestMethodTreeElement;requestMethodElement.hidden=!this._request.statusCode;var statusCodeElement=this._statusCodeTreeElement;statusCodeElement.hidden=!this._request.statusCode;if(this._request.statusCode){var statusCodeFragment=document.createDocumentFragment();statusCodeFragment.createChild("div","header-name").textContent=WebInspector.UIString("Status Code")+":";var statusCodeImage=statusCodeFragment.createChild("div","resource-status-image");statusCodeImage.title=this._request.statusCode+" "+this._request.statusText;if(this._request.statusCode<300||this._request.statusCode===304)
+statusCodeImage.addStyleClass("green-ball");else if(this._request.statusCode<400)
+statusCodeImage.addStyleClass("orange-ball");else
+statusCodeImage.addStyleClass("red-ball");requestMethodElement.title=this._formatHeader(WebInspector.UIString("Request Method"),this._request.requestMethod);var value=statusCodeFragment.createChild("div","header-value source-code");value.textContent=this._request.statusCode+" "+this._request.statusText;if(this._request.cached)
+value.createChild("span","status-from-cache").textContent=" "+WebInspector.UIString("(from cache)");statusCodeElement.title=statusCodeFragment;}},_refreshHeadersTitle:function(title,headersTreeElement,headersLength)
+{headersTreeElement.listItemElement.removeChildren();headersTreeElement.listItemElement.appendChild(document.createTextNode(title));var headerCount=document.createElement("span");headerCount.addStyleClass("header-count");headerCount.textContent=WebInspector.UIString(" (%d)",headersLength);headersTreeElement.listItemElement.appendChild(headerCount);},_refreshHeaders:function(title,headers,headersTreeElement)
+{headersTreeElement.removeChildren();var length=headers.length;this._refreshHeadersTitle(title,headersTreeElement,length);headersTreeElement.hidden=!length;for(var i=0;i<length;++i){var headerTreeElement=new TreeElement(null,null,false);headerTreeElement.title=this._formatHeader(headers[i].name,headers[i].value);headerTreeElement.selectable=false;headersTreeElement.appendChild(headerTreeElement);}},_refreshHeadersText:function(title,headers,headersText,headersTreeElement)
+{this._populateTreeElementWithSourceText(headersTreeElement,headersText);this._refreshHeadersTitle(title,headersTreeElement,headers.length);},_toggleRequestHeadersText:function(event)
+{this._showRequestHeadersText=!this._showRequestHeadersText;this._refreshRequestHeaders();},_toggleResponseHeadersText:function(event)
+{this._showResponseHeadersText=!this._showResponseHeadersText;this._refreshResponseHeaders();},_createToggleButton:function(title)
+{var button=document.createElement("span");button.addStyleClass("header-toggle");button.textContent=title;return button;},_createHeadersToggleButton:function(isHeadersTextShown)
+{var toggleTitle=isHeadersTextShown?WebInspector.UIString("view parsed"):WebInspector.UIString("view source");return this._createToggleButton(toggleTitle);},__proto__:WebInspector.View.prototype};WebInspector.RequestHTMLView=function(request,dataURL)
+{WebInspector.RequestView.call(this,request);this._dataURL=dataURL;this.element.addStyleClass("html");}
+WebInspector.RequestHTMLView.prototype={hasContent:function()
+{return true;},wasShown:function()
+{this._createIFrame();},willHide:function(parentElement)
+{this.element.removeChildren();},_createIFrame:function()
+{this.element.removeChildren();var iframe=document.createElement("iframe");iframe.setAttribute("sandbox","");iframe.setAttribute("src",this._dataURL);this.element.appendChild(iframe);},__proto__:WebInspector.RequestView.prototype};WebInspector.RequestJSONView=function(request,parsedJSON)
+{WebInspector.RequestView.call(this,request);this._parsedJSON=parsedJSON;this.element.addStyleClass("json");}
+WebInspector.RequestJSONView.parseJSON=function(text)
+{var prefix="";var start=/[{[]/.exec(text);if(start&&start.index){prefix=text.substring(0,start.index);text=text.substring(start.index);}
+try{return new WebInspector.ParsedJSON(JSON.parse(text),prefix,"");}catch(e){return;}}
+WebInspector.RequestJSONView.parseJSONP=function(text)
+{var start=text.indexOf("(");var end=text.lastIndexOf(")");if(start==-1||end==-1||end<start)
+return;var prefix=text.substring(0,start+1);var suffix=text.substring(end);text=text.substring(start+1,end);try{return new WebInspector.ParsedJSON(JSON.parse(text),prefix,suffix);}catch(e){return;}}
+WebInspector.RequestJSONView.prototype={hasContent:function()
+{return true;},wasShown:function()
+{this._initialize();},_initialize:function()
+{if(this._initialized)
+return;this._initialized=true;var obj=WebInspector.RemoteObject.fromLocalObject(this._parsedJSON.data);var title=this._parsedJSON.prefix+obj.description+this._parsedJSON.suffix;var section=new WebInspector.ObjectPropertiesSection(obj,title);section.expand();section.editable=false;this.element.appendChild(section.element);},__proto__:WebInspector.RequestView.prototype}
+WebInspector.ParsedJSON=function(data,prefix,suffix)
+{this.data=data;this.prefix=prefix;this.suffix=suffix;};WebInspector.RequestPreviewView=function(request,responseView)
+{WebInspector.RequestContentView.call(this,request);this._responseView=responseView;}
+WebInspector.RequestPreviewView.prototype={contentLoaded:function()
+{if(!this.request.content){if(!this._emptyView){this._emptyView=this._createEmptyView();this._emptyView.show(this.element);this.innerView=this._emptyView;}}else{if(this._emptyView){this._emptyView.detach();delete this._emptyView;}
+if(!this._previewView)
+this._previewView=this._createPreviewView();this._previewView.show(this.element);this.innerView=this._previewView;}},_createEmptyView:function()
+{return new WebInspector.EmptyView(WebInspector.UIString("This request has no preview available."));},_jsonView:function()
+{var parsedJSON=WebInspector.RequestJSONView.parseJSON(this.request.content);if(parsedJSON)
+return new WebInspector.RequestJSONView(this.request,parsedJSON);},_htmlView:function()
+{var dataURL=this.request.asDataURL();if(dataURL!==null)
+return new WebInspector.RequestHTMLView(this.request,dataURL);},_createPreviewView:function()
+{if(this.request.content){if(this.request.hasErrorStatusCode()){var htmlView=this._htmlView();if(htmlView)
+return htmlView;}
+if(this.request.type===WebInspector.resourceTypes.XHR){var jsonView=this._jsonView();if(jsonView)
+return jsonView;}
+if(this.request.type===WebInspector.resourceTypes.XHR&&this.request.mimeType==="text/html"){var htmlView=this._htmlView();if(htmlView)
+return htmlView;}
+if(this.request.type===WebInspector.resourceTypes.Script&&this.request.mimeType==="application/json"){var jsonView=this._jsonView();if(jsonView)
+return jsonView;}}
+if(this._responseView.sourceView)
+return this._responseView.sourceView;if(this.request.type===WebInspector.resourceTypes.Other)
+return this._createEmptyView();return WebInspector.RequestView.nonSourceViewForRequest(this.request);},__proto__:WebInspector.RequestContentView.prototype};WebInspector.RequestResponseView=function(request)
+{WebInspector.RequestContentView.call(this,request);}
+WebInspector.RequestResponseView._maxFormattedResourceSize=100000;WebInspector.RequestResponseView.prototype={get sourceView()
+{if(!this._sourceView&&WebInspector.RequestView.hasTextContent(this.request))
+this._sourceView=this.request.resourceSize<WebInspector.RequestResponseView._maxFormattedResourceSize?new WebInspector.ResourceSourceFrame(this.request):new WebInspector.ResourceSourceFrameFallback(this.request);return this._sourceView;},contentLoaded:function()
+{if(!this.request.content||!this.sourceView){if(!this._emptyView){this._emptyView=new WebInspector.EmptyView(WebInspector.UIString("This request has no response data available."));this._emptyView.show(this.element);this.innerView=this._emptyView;}}else{if(this._emptyView){this._emptyView.detach();delete this._emptyView;}
+this.sourceView.show(this.element);this.innerView=this.sourceView;}},__proto__:WebInspector.RequestContentView.prototype};WebInspector.RequestTimingView=function(request)
+{WebInspector.View.call(this);this.element.addStyleClass("resource-timing-view");this._request=request;}
+WebInspector.RequestTimingView.prototype={wasShown:function()
+{this._request.addEventListener(WebInspector.NetworkRequest.Events.TimingChanged,this._refresh,this);if(!this._request.timing){if(!this._emptyView){this._emptyView=new WebInspector.EmptyView(WebInspector.UIString("This request has no detailed timing info."));this._emptyView.show(this.element);this.innerView=this._emptyView;}
+return;}
+if(this._emptyView){this._emptyView.detach();delete this._emptyView;}
+this._refresh();},willHide:function()
+{this._request.removeEventListener(WebInspector.NetworkRequest.Events.TimingChanged,this._refresh,this);},_refresh:function()
+{if(this._tableElement)
+this._tableElement.remove();this._tableElement=WebInspector.RequestTimingView.createTimingTable(this._request);this.element.appendChild(this._tableElement);},__proto__:WebInspector.View.prototype}
+WebInspector.RequestTimingView.createTimingTable=function(request)
+{var tableElement=document.createElement("table");var rows=[];function addRow(title,className,start,end)
+{var row={};row.title=title;row.className=className;row.start=start;row.end=end;rows.push(row);}
+if(request.timing.proxyStart!==-1)
+addRow(WebInspector.UIString("Proxy"),"proxy",request.timing.proxyStart,request.timing.proxyEnd);if(request.timing.dnsStart!==-1)
+addRow(WebInspector.UIString("DNS Lookup"),"dns",request.timing.dnsStart,request.timing.dnsEnd);if(request.timing.connectStart!==-1){var label=request.connectionReused?WebInspector.UIString("Blocking"):WebInspector.UIString("Connecting");addRow(label,"connecting",request.timing.connectStart,request.timing.connectEnd);}
+if(request.timing.sslStart!==-1)
+addRow(WebInspector.UIString("SSL"),"ssl",request.timing.sslStart,request.timing.sslEnd);addRow(WebInspector.UIString("Sending"),"sending",request.timing.sendStart,request.timing.sendEnd);addRow(WebInspector.UIString("Waiting"),"waiting",request.timing.sendEnd,request.timing.receiveHeadersEnd);addRow(WebInspector.UIString("Receiving"),"receiving",(request.responseReceivedTime-request.timing.requestTime)*1000,(request.endTime-request.timing.requestTime)*1000);const chartWidth=200;var total=(request.endTime-request.timing.requestTime)*1000;var scale=chartWidth/total;for(var i=0;i<rows.length;++i){var tr=document.createElement("tr");tableElement.appendChild(tr);var td=document.createElement("td");td.textContent=rows[i].title;tr.appendChild(td);td=document.createElement("td");td.width=chartWidth+"px";var row=document.createElement("div");row.className="network-timing-row";td.appendChild(row);var bar=document.createElement("span");bar.className="network-timing-bar "+rows[i].className;bar.style.left=scale*rows[i].start+"px";bar.style.right=scale*(total-rows[i].end)+"px";bar.style.backgroundColor=rows[i].color;bar.textContent="\u200B";row.appendChild(bar);var title=document.createElement("span");title.className="network-timing-bar-title";if(total-rows[i].end<rows[i].start)
+title.style.right=(scale*(total-rows[i].end)+3)+"px";else
+title.style.left=(scale*rows[i].start+3)+"px";title.textContent=Number.secondsToString((rows[i].end-rows[i].start)/1000);row.appendChild(title);tr.appendChild(td);}
+return tableElement;};WebInspector.ResourceWebSocketFrameView=function(resource)
+{WebInspector.View.call(this);this.element.addStyleClass("resource-websocket");this.resource=resource;this.element.removeChildren();this._dataGrid=new WebInspector.DataGrid([{id:"data",title:WebInspector.UIString("Data"),sortable:false,weight:88},{id:"length",title:WebInspector.UIString("Length"),sortable:false,alig:WebInspector.DataGrid.Align.Right,weight:5},{id:"time",title:WebInspector.UIString("Time"),weight:7}]);this.refresh();this._dataGrid.setName("ResourceWebSocketFrameView");this._dataGrid.show(this.element);}
+WebInspector.ResourceWebSocketFrameView.OpCodes={ContinuationFrame:0,TextFrame:1,BinaryFrame:2,ConnectionCloseFrame:8,PingFrame:9,PongFrame:10};WebInspector.ResourceWebSocketFrameView.prototype={appendFrame:function(frame)
+{var payload=frame;var date=new Date(payload.time*1000);var row={data:"",length:typeof payload.payloadData==="undefined"?payload.errorMessage.length.toString():payload.payloadData.length.toString(),time:date.toLocaleTimeString()};var rowClass="";if(payload.errorMessage){rowClass="error";row.data=payload.errorMessage;}else if(payload.opcode==WebInspector.ResourceWebSocketFrameView.OpCodes.TextFrame){if(payload.sent)
+rowClass="outcoming";row.data=payload.payloadData;}else{rowClass="opcode";var opcodeMeaning="";switch(payload.opcode){case WebInspector.ResourceWebSocketFrameView.OpCodes.ContinuationFrame:opcodeMeaning=WebInspector.UIString("Continuation Frame");break;case WebInspector.ResourceWebSocketFrameView.OpCodes.BinaryFrame:opcodeMeaning=WebInspector.UIString("Binary Frame");break;case WebInspector.ResourceWebSocketFrameView.OpCodes.ConnectionCloseFrame:opcodeMeaning=WebInspector.UIString("Connection Close Frame");break;case WebInspector.ResourceWebSocketFrameView.OpCodes.PingFrame:opcodeMeaning=WebInspector.UIString("Ping Frame");break;case WebInspector.ResourceWebSocketFrameView.OpCodes.PongFrame:opcodeMeaning=WebInspector.UIString("Pong Frame");break;}
+row.data=WebInspector.UIString("%s (Opcode %d%s)",opcodeMeaning,payload.opcode,(payload.mask?", mask":""));}
+var node=new WebInspector.DataGridNode(row,false);this._dataGrid.rootNode().appendChild(node);if(rowClass)
+node.element.classList.add("resource-websocket-row-"+rowClass);},refresh:function()
+{this._dataGrid.rootNode().removeChildren();var frames=this.resource.frames();for(var i=frames.length-1;i>=0;i--){this.appendFrame(frames[i]);}},show:function(parentElement,insertBefore)
+{this.refresh();WebInspector.View.prototype.show.call(this,parentElement,insertBefore);},__proto__:WebInspector.View.prototype};WebInspector.NetworkLogView=function(coulmnsVisibilitySetting)
+{WebInspector.View.call(this);this.registerRequiredCSS("networkLogView.css");this._coulmnsVisibilitySetting=coulmnsVisibilitySetting;this._allowRequestSelection=false;this._requests=[];this._requestsById={};this._requestsByURL={};this._staleRequests={};this._requestGridNodes={};this._lastRequestGridNodeId=0;this._mainRequestLoadTime=-1;this._mainRequestDOMContentLoadedTime=-1;this._typeFilterElements={};this._typeFilter=WebInspector.NetworkLogView._trivialTypeFilter;this._matchedRequests=[];this._highlightedSubstringChanges=[];this._filteredOutRequests=new Map();this._matchedRequestsMap={};this._currentMatchedRequestIndex=-1;this._createStatusbarButtons();this._createStatusBarItems();this._linkifier=new WebInspector.Linkifier();WebInspector.networkManager.addEventListener(WebInspector.NetworkManager.EventTypes.RequestStarted,this._onRequestStarted,this);WebInspector.networkManager.addEventListener(WebInspector.NetworkManager.EventTypes.RequestUpdated,this._onRequestUpdated,this);WebInspector.networkManager.addEventListener(WebInspector.NetworkManager.EventTypes.RequestFinished,this._onRequestUpdated,this);WebInspector.resourceTreeModel.addEventListener(WebInspector.ResourceTreeModel.EventTypes.MainFrameNavigated,this._mainFrameNavigated,this);WebInspector.resourceTreeModel.addEventListener(WebInspector.ResourceTreeModel.EventTypes.Load,this._loadEventFired,this);WebInspector.resourceTreeModel.addEventListener(WebInspector.ResourceTreeModel.EventTypes.DOMContentLoaded,this._domContentLoadedEventFired,this);this._initializeView();WebInspector.networkLog.requests.forEach(this._appendRequest.bind(this));}
+WebInspector.NetworkLogView.HTTPSchemas={"http":true,"https":true,"ws":true,"wss":true};WebInspector.NetworkLogView._responseHeaderColumns=["Cache-Control","Connection","Content-Encoding","Content-Length","ETag","Keep-Alive","Last-Modified","Server","Vary"];WebInspector.NetworkLogView._defaultColumnsVisibility={method:true,status:true,scheme:false,domain:false,type:true,initiator:true,cookies:false,setCookies:false,size:true,time:true,"Cache-Control":false,"Connection":false,"Content-Encoding":false,"Content-Length":false,"ETag":false,"Keep-Alive":false,"Last-Modified":false,"Server":false,"Vary":false};WebInspector.NetworkLogView._defaultRefreshDelay=500;WebInspector.NetworkLogView.ALL_TYPES="all";WebInspector.NetworkLogView.prototype={_initializeView:function()
+{this.element.id="network-container";this._createSortingFunctions();this._createTable();this._createTimelineGrid();this._createSummaryBar();if(!this.useLargeRows)
+this._setLargerRequests(this.useLargeRows);this._allowPopover=true;this._popoverHelper=new WebInspector.PopoverHelper(this.element,this._getPopoverAnchor.bind(this),this._showPopover.bind(this),this._onHidePopover.bind(this));this._popoverHelper.setTimeout(100);this.calculator=new WebInspector.NetworkTransferTimeCalculator();this._toggleTypeFilter(WebInspector.NetworkLogView.ALL_TYPES,false);this.switchToDetailedView();},get statusBarItems()
+{return[this._largerRequestsButton.element,this._preserveLogToggle.element,this._clearButton.element,this._filterBarElement,this._progressBarContainer];},get useLargeRows()
+{return WebInspector.settings.resourcesLargeRows.get();},set allowPopover(flag)
+{this._allowPopover=flag;},elementsToRestoreScrollPositionsFor:function()
+{if(!this._dataGrid)
+return[];return[this._dataGrid.scrollContainer];},onResize:function()
+{this._updateOffscreenRows();},_createTimelineGrid:function()
+{this._timelineGrid=new WebInspector.TimelineGrid();this._timelineGrid.element.addStyleClass("network-timeline-grid");this._dataGrid.element.appendChild(this._timelineGrid.element);},_createTable:function()
+{var columns=[];columns.push({id:"name",titleDOMFragment:this._makeHeaderFragment(WebInspector.UIString("Name"),WebInspector.UIString("Path")),title:WebInspector.UIString("Name"),sortable:true,weight:20,disclosure:true});columns.push({id:"method",title:WebInspector.UIString("Method"),sortable:true,weight:6});columns.push({id:"status",titleDOMFragment:this._makeHeaderFragment(WebInspector.UIString("Status"),WebInspector.UIString("Text")),title:WebInspector.UIString("Status"),sortable:true,weight:6});columns.push({id:"scheme",title:WebInspector.UIString("Scheme"),sortable:true,weight:6});columns.push({id:"domain",title:WebInspector.UIString("Domain"),sortable:true,weight:6});columns.push({id:"type",title:WebInspector.UIString("Type"),sortable:true,weight:6});columns.push({id:"initiator",title:WebInspector.UIString("Initiator"),sortable:true,weight:10});columns.push({id:"cookies",title:WebInspector.UIString("Cookies"),sortable:true,weight:6,align:WebInspector.DataGrid.Align.Right});columns.push({id:"setCookies",title:WebInspector.UIString("Set-Cookies"),sortable:true,weight:6,align:WebInspector.DataGrid.Align.Right});columns.push({id:"size",titleDOMFragment:this._makeHeaderFragment(WebInspector.UIString("Size"),WebInspector.UIString("Content")),title:WebInspector.UIString("Size"),sortable:true,weight:6,align:WebInspector.DataGrid.Align.Right});columns.push({id:"time",titleDOMFragment:this._makeHeaderFragment(WebInspector.UIString("Time"),WebInspector.UIString("Latency")),title:WebInspector.UIString("Time"),sortable:true,weight:6,align:WebInspector.DataGrid.Align.Right});var responseHeaderColumns=WebInspector.NetworkLogView._responseHeaderColumns;for(var i=0;i<responseHeaderColumns.length;++i){var headerName=responseHeaderColumns[i];var descriptor={id:headerName,title:WebInspector.UIString(headerName),weight:6}
+if(headerName==="Content-Length")
+descriptor.align=WebInspector.DataGrid.Align.Right;columns.push(descriptor);}
+columns.push({id:"timeline",titleDOMFragment:document.createDocumentFragment(),title:WebInspector.UIString("Timeline"),sortable:false,weight:40,sort:WebInspector.DataGrid.Order.Ascending});this._dataGrid=new WebInspector.DataGrid(columns);this._dataGrid.setName("networkLog");this._dataGrid.resizeMethod=WebInspector.DataGrid.ResizeMethod.Last;this._dataGrid.element.addStyleClass("network-log-grid");this._dataGrid.element.addEventListener("contextmenu",this._contextMenu.bind(this),true);this._dataGrid.show(this.element);this._dataGrid.addEventListener(WebInspector.DataGrid.Events.SortingChanged,this._sortItems,this);this._dataGrid.addEventListener(WebInspector.DataGrid.Events.ColumnsResized,this._updateDividersIfNeeded,this);this._dataGrid.scrollContainer.addEventListener("scroll",this._updateOffscreenRows.bind(this));this._patchTimelineHeader();},_makeHeaderFragment:function(title,subtitle)
+{var fragment=document.createDocumentFragment();fragment.createTextChild(title);var subtitleDiv=fragment.createChild("div","network-header-subtitle");subtitleDiv.createTextChild(subtitle);return fragment;},_patchTimelineHeader:function()
+{var timelineSorting=document.createElement("select");var option=document.createElement("option");option.value="startTime";option.label=WebInspector.UIString("Timeline");timelineSorting.appendChild(option);option=document.createElement("option");option.value="startTime";option.label=WebInspector.UIString("Start Time");timelineSorting.appendChild(option);option=document.createElement("option");option.value="responseTime";option.label=WebInspector.UIString("Response Time");timelineSorting.appendChild(option);option=document.createElement("option");option.value="endTime";option.label=WebInspector.UIString("End Time");timelineSorting.appendChild(option);option=document.createElement("option");option.value="duration";option.label=WebInspector.UIString("Duration");timelineSorting.appendChild(option);option=document.createElement("option");option.value="latency";option.label=WebInspector.UIString("Latency");timelineSorting.appendChild(option);var header=this._dataGrid.headerTableHeader("timeline");header.replaceChild(timelineSorting,header.firstChild);timelineSorting.addEventListener("click",function(event){event.consume()},false);timelineSorting.addEventListener("change",this._sortByTimeline.bind(this),false);this._timelineSortSelector=timelineSorting;},_createSortingFunctions:function()
+{this._sortingFunctions={};this._sortingFunctions.name=WebInspector.NetworkDataGridNode.NameComparator;this._sortingFunctions.method=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"method",false);this._sortingFunctions.status=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"statusCode",false);this._sortingFunctions.scheme=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"scheme",false);this._sortingFunctions.domain=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"domain",false);this._sortingFunctions.type=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"mimeType",false);this._sortingFunctions.initiator=WebInspector.NetworkDataGridNode.InitiatorComparator;this._sortingFunctions.cookies=WebInspector.NetworkDataGridNode.RequestCookiesCountComparator;this._sortingFunctions.setCookies=WebInspector.NetworkDataGridNode.ResponseCookiesCountComparator;this._sortingFunctions.size=WebInspector.NetworkDataGridNode.SizeComparator;this._sortingFunctions.time=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"duration",false);this._sortingFunctions.timeline=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"startTime",false);this._sortingFunctions.startTime=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"startTime",false);this._sortingFunctions.endTime=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"endTime",false);this._sortingFunctions.responseTime=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"responseReceivedTime",false);this._sortingFunctions.duration=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"duration",true);this._sortingFunctions.latency=WebInspector.NetworkDataGridNode.RequestPropertyComparator.bind(null,"latency",true);var timeCalculator=new WebInspector.NetworkTransferTimeCalculator();var durationCalculator=new WebInspector.NetworkTransferDurationCalculator();this._calculators={};this._calculators.timeline=timeCalculator;this._calculators.startTime=timeCalculator;this._calculators.endTime=timeCalculator;this._calculators.responseTime=timeCalculator;this._calculators.duration=durationCalculator;this._calculators.latency=durationCalculator;},_sortItems:function()
+{this._removeAllNodeHighlights();var columnIdentifier=this._dataGrid.sortColumnIdentifier();if(columnIdentifier==="timeline"){this._sortByTimeline();return;}
+var sortingFunction=this._sortingFunctions[columnIdentifier];if(!sortingFunction)
+return;this._dataGrid.sortNodes(sortingFunction,!this._dataGrid.isSortOrderAscending());this._timelineSortSelector.selectedIndex=0;this._updateOffscreenRows();this.searchCanceled();WebInspector.notifications.dispatchEventToListeners(WebInspector.UserMetrics.UserAction,{action:WebInspector.UserMetrics.UserActionNames.NetworkSort,column:columnIdentifier,sortOrder:this._dataGrid.sortOrder()});},_sortByTimeline:function()
+{this._removeAllNodeHighlights();var selectedIndex=this._timelineSortSelector.selectedIndex;if(!selectedIndex)
+selectedIndex=1;var selectedOption=this._timelineSortSelector[selectedIndex];var value=selectedOption.value;var sortingFunction=this._sortingFunctions[value];this._dataGrid.sortNodes(sortingFunction);this.calculator=this._calculators[value];if(this.calculator.startAtZero)
+this._timelineGrid.hideEventDividers();else
+this._timelineGrid.showEventDividers();this._dataGrid.markColumnAsSortedBy("timeline",WebInspector.DataGrid.Order.Ascending);this._updateOffscreenRows();},_addTypeFilter:function(typeName,label)
+{var typeFilterElement=this._filterBarElement.createChild("li",typeName);typeFilterElement.typeName=typeName;typeFilterElement.createTextChild(label);typeFilterElement.addEventListener("click",this._onTypeFilterClicked.bind(this),false);this._typeFilterElements[typeName]=typeFilterElement;},_createStatusBarItems:function()
+{var filterBarElement=document.createElement("div");filterBarElement.className="scope-bar status-bar-item";filterBarElement.title=WebInspector.UIString("Use %s Click to select multiple types.",WebInspector.KeyboardShortcut.shortcutToString("",WebInspector.KeyboardShortcut.Modifiers.CtrlOrMeta));this._filterBarElement=filterBarElement;this._addTypeFilter(WebInspector.NetworkLogView.ALL_TYPES,WebInspector.UIString("All"));filterBarElement.createChild("div","scope-bar-divider");for(var typeId in WebInspector.resourceTypes){var type=WebInspector.resourceTypes[typeId];this._addTypeFilter(type.name(),type.categoryTitle());}
+this._progressBarContainer=document.createElement("div");this._progressBarContainer.className="status-bar-item";},_createSummaryBar:function()
+{var tbody=this._dataGrid.dataTableBody;var tfoot=document.createElement("tfoot");var tr=tfoot.createChild("tr","revealed network-summary-bar");var td=tr.createChild("td");td.setAttribute("colspan",7);tbody.parentNode.insertBefore(tfoot,tbody);this._summaryBarElement=td;},_updateSummaryBar:function()
+{var requestsNumber=this._requests.length;if(!requestsNumber){if(this._summaryBarElement._isDisplayingWarning)
+return;this._summaryBarElement._isDisplayingWarning=true;this._summaryBarElement.removeChildren();this._summaryBarElement.createChild("div","warning-icon-small");this._summaryBarElement.appendChild(document.createTextNode(WebInspector.UIString("No requests captured. Reload the page to see detailed information on the network activity.")));return;}
+delete this._summaryBarElement._isDisplayingWarning;var transferSize=0;var selectedRequestsNumber=0;var selectedTransferSize=0;var baseTime=-1;var maxTime=-1;for(var i=0;i<this._requests.length;++i){var request=this._requests[i];var requestTransferSize=request.transferSize;transferSize+=requestTransferSize;if(!this._filteredOutRequests.get(request)){selectedRequestsNumber++;selectedTransferSize+=requestTransferSize;}
+if(request.url===WebInspector.inspectedPageURL)
+baseTime=request.startTime;if(request.endTime>maxTime)
+maxTime=request.endTime;}
+var text="";if(selectedRequestsNumber!==requestsNumber){text+=String.sprintf(WebInspector.UIString("%d / %d requests"),selectedRequestsNumber,requestsNumber);text+=" \u2758 "+String.sprintf(WebInspector.UIString("%s / %s transferred"),Number.bytesToString(selectedTransferSize),Number.bytesToString(transferSize));}else{text+=String.sprintf(WebInspector.UIString("%d requests"),requestsNumber);text+=" \u2758 "+String.sprintf(WebInspector.UIString("%s transferred"),Number.bytesToString(transferSize));}
+if(baseTime!==-1&&this._mainRequestLoadTime!==-1&&this._mainRequestDOMContentLoadedTime!==-1&&this._mainRequestDOMContentLoadedTime>baseTime){text+=" \u2758 "+String.sprintf(WebInspector.UIString("%s (load: %s, DOMContentLoaded: %s)"),Number.secondsToString(maxTime-baseTime),Number.secondsToString(this._mainRequestLoadTime-baseTime),Number.secondsToString(this._mainRequestDOMContentLoadedTime-baseTime));}
+this._summaryBarElement.textContent=text;},_onTypeFilterClicked:function(e)
+{var toggle;if(WebInspector.isMac())
+toggle=e.metaKey&&!e.ctrlKey&&!e.altKey&&!e.shiftKey;else
+toggle=e.ctrlKey&&!e.metaKey&&!e.altKey&&!e.shiftKey;this._toggleTypeFilter(e.target.typeName,toggle);this._removeAllNodeHighlights();this.searchCanceled();this._filterRequests();},_toggleTypeFilter:function(typeName,allowMultiSelect)
+{if(allowMultiSelect&&typeName!==WebInspector.NetworkLogView.ALL_TYPES)
+this._typeFilterElements[WebInspector.NetworkLogView.ALL_TYPES].removeStyleClass("selected");else{for(var key in this._typeFilterElements)
+this._typeFilterElements[key].removeStyleClass("selected");}
+var filterElement=this._typeFilterElements[typeName];filterElement.enableStyleClass("selected",!filterElement.hasStyleClass("selected"));var allowedTypes={};for(var key in this._typeFilterElements){if(this._typeFilterElements[key].hasStyleClass("selected"))
+allowedTypes[key]=true;}
+if(typeName===WebInspector.NetworkLogView.ALL_TYPES)
+this._typeFilter=WebInspector.NetworkLogView._trivialTypeFilter;else
+this._typeFilter=WebInspector.NetworkLogView._typeFilter.bind(null,allowedTypes);},_scheduleRefresh:function()
+{if(this._needsRefresh)
+return;this._needsRefresh=true;if(this.isShowing()&&!this._refreshTimeout)
+this._refreshTimeout=setTimeout(this.refresh.bind(this),WebInspector.NetworkLogView._defaultRefreshDelay);},_updateDividersIfNeeded:function()
+{if(!this._dataGrid)
+return;var timelineColumn=this._dataGrid.columns.timeline;for(var i=0;i<this._dataGrid.resizers.length;++i){if(timelineColumn.ordinal===this._dataGrid.resizers[i].rightNeighboringColumnIndex){this._timelineGrid.element.style.left=this._dataGrid.resizers[i].style.left;}}
+var proceed=true;if(!this.isShowing()){this._scheduleRefresh();proceed=false;}else{this.calculator.setDisplayWindow(this._timelineGrid.dividersElement.clientWidth);proceed=this._timelineGrid.updateDividers(this.calculator);}
+if(!proceed)
+return;if(this.calculator.startAtZero||!this.calculator.computePercentageFromEventTime){return;}
+this._timelineGrid.removeEventDividers();if(this._mainRequestLoadTime!==-1){var percent=this.calculator.computePercentageFromEventTime(this._mainRequestLoadTime);var loadDivider=document.createElement("div");loadDivider.className="network-event-divider network-red-divider";var loadDividerPadding=document.createElement("div");loadDividerPadding.className="network-event-divider-padding";loadDividerPadding.title=WebInspector.UIString("Load event fired");loadDividerPadding.appendChild(loadDivider);loadDividerPadding.style.left=percent+"%";this._timelineGrid.addEventDivider(loadDividerPadding);}
+if(this._mainRequestDOMContentLoadedTime!==-1){var percent=this.calculator.computePercentageFromEventTime(this._mainRequestDOMContentLoadedTime);var domContentLoadedDivider=document.createElement("div");domContentLoadedDivider.className="network-event-divider network-blue-divider";var domContentLoadedDividerPadding=document.createElement("div");domContentLoadedDividerPadding.className="network-event-divider-padding";domContentLoadedDividerPadding.title=WebInspector.UIString("DOMContentLoaded event fired");domContentLoadedDividerPadding.appendChild(domContentLoadedDivider);domContentLoadedDividerPadding.style.left=percent+"%";this._timelineGrid.addEventDivider(domContentLoadedDividerPadding);}},_refreshIfNeeded:function()
+{if(this._needsRefresh)
+this.refresh();},_invalidateAllItems:function()
+{for(var i=0;i<this._requests.length;++i){var request=this._requests[i];this._staleRequests[request.requestId]=request;}},get calculator()
+{return this._calculator;},set calculator(x)
+{if(!x||this._calculator===x)
+return;this._calculator=x;this._calculator.reset();this._invalidateAllItems();this.refresh();},_requestGridNode:function(request)
+{return this._requestGridNodes[request.__gridNodeId];},_createRequestGridNode:function(request)
+{var node=new WebInspector.NetworkDataGridNode(this,request);request.__gridNodeId=this._lastRequestGridNodeId++;this._requestGridNodes[request.__gridNodeId]=node;return node;},_createStatusbarButtons:function()
+{this._preserveLogToggle=new WebInspector.StatusBarButton(WebInspector.UIString("Preserve Log upon Navigation"),"record-profile-status-bar-item");this._preserveLogToggle.addEventListener("click",this._onPreserveLogClicked,this);this._clearButton=new WebInspector.StatusBarButton(WebInspector.UIString("Clear"),"clear-status-bar-item");this._clearButton.addEventListener("click",this._reset,this);this._largerRequestsButton=new WebInspector.StatusBarButton(WebInspector.UIString("Use small resource rows."),"network-larger-resources-status-bar-item");this._largerRequestsButton.toggled=WebInspector.settings.resourcesLargeRows.get();this._largerRequestsButton.addEventListener("click",this._toggleLargerRequests,this);},_loadEventFired:function(event)
+{this._mainRequestLoadTime=event.data||-1;this._scheduleRefresh();},_domContentLoadedEventFired:function(event)
+{this._mainRequestDOMContentLoadedTime=event.data||-1;this._scheduleRefresh();},wasShown:function()
+{this._refreshIfNeeded();},willHide:function()
+{this._popoverHelper.hidePopover();},refresh:function()
+{this._needsRefresh=false;if(this._refreshTimeout){clearTimeout(this._refreshTimeout);delete this._refreshTimeout;}
+this._removeAllNodeHighlights();var wasScrolledToLastRow=this._dataGrid.isScrolledToLastRow();var boundariesChanged=false;if(this.calculator.updateBoundariesForEventTime){boundariesChanged=this.calculator.updateBoundariesForEventTime(this._mainRequestLoadTime)||boundariesChanged;boundariesChanged=this.calculator.updateBoundariesForEventTime(this._mainRequestDOMContentLoadedTime)||boundariesChanged;}
+for(var requestId in this._staleRequests){var request=this._staleRequests[requestId];var node=this._requestGridNode(request);if(!node){node=this._createRequestGridNode(request);this._dataGrid.rootNode().appendChild(node);}
+node.refreshRequest();this._applyFilter(node);if(this.calculator.updateBoundaries(request))
+boundariesChanged=true;if(!node.isFilteredOut())
+this._updateHighlightIfMatched(request);}
+if(boundariesChanged){this._invalidateAllItems();}
+for(var requestId in this._staleRequests)
+this._requestGridNode(this._staleRequests[requestId]).refreshGraph(this.calculator);this._staleRequests={};this._sortItems();this._updateSummaryBar();this._dataGrid.updateWidths();if(wasScrolledToLastRow)
+this._dataGrid.scrollToLastRow();},_onPreserveLogClicked:function(e)
+{this._preserveLogToggle.toggled=!this._preserveLogToggle.toggled;},_reset:function()
+{this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.ViewCleared);this._clearSearchMatchedList();if(this._popoverHelper)
+this._popoverHelper.hidePopover();if(this._calculator)
+this._calculator.reset();this._requests=[];this._requestsById={};this._requestsByURL={};this._staleRequests={};this._requestGridNodes={};if(this._dataGrid){this._dataGrid.rootNode().removeChildren();this._updateDividersIfNeeded();this._updateSummaryBar();}
+this._mainRequestLoadTime=-1;this._mainRequestDOMContentLoadedTime=-1;},get requests()
+{return this._requests;},requestById:function(id)
+{return this._requestsById[id];},_onRequestStarted:function(event)
+{this._appendRequest(event.data);},_appendRequest:function(request)
+{this._requests.push(request);if(this._requestsById[request.requestId]){var oldRequest=request.redirects[request.redirects.length-1];this._requestsById[oldRequest.requestId]=oldRequest;this._updateSearchMatchedListAfterRequestIdChanged(request.requestId,oldRequest.requestId);}
+this._requestsById[request.requestId]=request;this._requestsByURL[request.url]=request;if(request.redirects){for(var i=0;i<request.redirects.length;++i)
+this._refreshRequest(request.redirects[i]);}
+this._refreshRequest(request);},_onRequestUpdated:function(event)
+{var request=(event.data);this._refreshRequest(request);},_refreshRequest:function(request)
+{this._staleRequests[request.requestId]=request;this._scheduleRefresh();},clear:function()
+{if(this._preserveLogToggle.toggled)
+return;this._reset();},_mainFrameNavigated:function(event)
+{if(this._preserveLogToggle.toggled)
+return;var frame=(event.data);var loaderId=frame.loaderId;var requestsToPreserve=[];for(var i=0;i<this._requests.length;++i){var request=this._requests[i];if(request.loaderId===loaderId)
+requestsToPreserve.push(request);}
+this._reset();for(var i=0;i<requestsToPreserve.length;++i)
+this._appendRequest(requestsToPreserve[i]);},switchToDetailedView:function()
+{if(!this._dataGrid)
+return;if(this._dataGrid.selectedNode)
+this._dataGrid.selectedNode.selected=false;this.element.removeStyleClass("brief-mode");this._detailedMode=true;this._updateColumns();},switchToBriefView:function()
+{this.element.addStyleClass("brief-mode");this._removeAllNodeHighlights();this._detailedMode=false;this._updateColumns();this._popoverHelper.hidePopover();},_toggleLargerRequests:function()
+{WebInspector.settings.resourcesLargeRows.set(!WebInspector.settings.resourcesLargeRows.get());this._setLargerRequests(WebInspector.settings.resourcesLargeRows.get());},_setLargerRequests:function(enabled)
+{this._largerRequestsButton.toggled=enabled;if(!enabled){this._largerRequestsButton.title=WebInspector.UIString("Use large resource rows.");this._dataGrid.element.addStyleClass("small");this._timelineGrid.element.addStyleClass("small");}else{this._largerRequestsButton.title=WebInspector.UIString("Use small resource rows.");this._dataGrid.element.removeStyleClass("small");this._timelineGrid.element.removeStyleClass("small");}
+this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.RowSizeChanged,{largeRows:enabled});this._updateOffscreenRows();},_getPopoverAnchor:function(element)
+{if(!this._allowPopover)
+return;var anchor=element.enclosingNodeOrSelfWithClass("network-graph-bar")||element.enclosingNodeOrSelfWithClass("network-graph-label");if(anchor&&anchor.parentElement.request&&anchor.parentElement.request.timing)
+return anchor;anchor=element.enclosingNodeOrSelfWithClass("network-script-initiated");if(anchor&&anchor.request&&anchor.request.initiator)
+return anchor;return null;},_showPopover:function(anchor,popover)
+{var content;if(anchor.hasStyleClass("network-script-initiated"))
+content=this._generateScriptInitiatedPopoverContent(anchor.request);else
+content=WebInspector.RequestTimingView.createTimingTable(anchor.parentElement.request);popover.show(content,anchor);},_onHidePopover:function()
+{this._linkifier.reset();},_generateScriptInitiatedPopoverContent:function(request)
+{var stackTrace=request.initiator.stackTrace;var framesTable=document.createElement("table");for(var i=0;i<stackTrace.length;++i){var stackFrame=stackTrace[i];var row=document.createElement("tr");row.createChild("td").textContent=stackFrame.functionName?stackFrame.functionName:WebInspector.UIString("(anonymous function)");row.createChild("td").textContent=" @ ";row.createChild("td").appendChild(this._linkifier.linkifyLocation(stackFrame.url,stackFrame.lineNumber-1,stackFrame.columnNumber-1));framesTable.appendChild(row);}
+return framesTable;},_updateColumns:function()
+{var columnsVisibility=this._coulmnsVisibilitySetting.get();var detailedMode=!!this._detailedMode;for(var columnIdentifier in columnsVisibility){var visible=detailedMode&&columnsVisibility[columnIdentifier];this._dataGrid.setColumnVisible(columnIdentifier,visible);}
+this._dataGrid.setColumnVisible("timeline",detailedMode);this._dataGrid.applyColumnWeights();},_toggleColumnVisibility:function(columnIdentifier)
+{var columnsVisibility=this._coulmnsVisibilitySetting.get();columnsVisibility[columnIdentifier]=!columnsVisibility[columnIdentifier];this._coulmnsVisibilitySetting.set(columnsVisibility);this._updateColumns();},_getConfigurableColumnIDs:function()
+{if(this._configurableColumnIDs)
+return this._configurableColumnIDs;var columns=this._dataGrid.columns;function compare(id1,id2)
+{return columns[id1].title.compareTo(columns[id2].title);}
+var columnIDs=Object.keys(this._coulmnsVisibilitySetting.get());this._configurableColumnIDs=columnIDs.sort(compare);return this._configurableColumnIDs;},_contextMenu:function(event)
+{var contextMenu=new WebInspector.ContextMenu(event);if(this._detailedMode&&event.target.isSelfOrDescendant(this._dataGrid.headerTableBody)){var columnsVisibility=this._coulmnsVisibilitySetting.get();var columnIDs=this._getConfigurableColumnIDs();for(var i=0;i<columnIDs.length;++i){var columnIdentifier=columnIDs[i];var column=this._dataGrid.columns[columnIdentifier];contextMenu.appendCheckboxItem(column.title,this._toggleColumnVisibility.bind(this,columnIdentifier),!!columnsVisibility[columnIdentifier]);}
+contextMenu.show();return;}
+var gridNode=this._dataGrid.dataGridNodeFromNode(event.target);var request=gridNode&&gridNode._request;if(request){contextMenu.appendItem(WebInspector.openLinkExternallyLabel(),WebInspector.openResource.bind(WebInspector,request.url,false));contextMenu.appendSeparator();contextMenu.appendItem(WebInspector.copyLinkAddressLabel(),this._copyLocation.bind(this,request));if(request.requestHeadersText)
+contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles()?"Copy request headers":"Copy Request Headers"),this._copyRequestHeaders.bind(this,request));if(request.responseHeadersText)
+contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles()?"Copy response headers":"Copy Response Headers"),this._copyResponseHeaders.bind(this,request));contextMenu.appendItem(WebInspector.UIString("Copy as cURL"),this._copyCurlCommand.bind(this,request));}
+contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles()?"Copy all as HAR":"Copy All as HAR"),this._copyAll.bind(this));contextMenu.appendSeparator();contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles()?"Save as HAR with content":"Save as HAR with Content"),this._exportAll.bind(this));contextMenu.appendSeparator();contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles()?"Clear browser cache":"Clear Browser Cache"),this._clearBrowserCache.bind(this));contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles()?"Clear browser cookies":"Clear Browser Cookies"),this._clearBrowserCookies.bind(this));if(request&&request.type===WebInspector.resourceTypes.XHR){contextMenu.appendSeparator();contextMenu.appendItem(WebInspector.UIString("Replay XHR"),this._replayXHR.bind(this,request.requestId));contextMenu.appendSeparator();}
+contextMenu.show();},_replayXHR:function(requestId)
+{NetworkAgent.replayXHR(requestId);},_copyAll:function()
+{var harArchive={log:(new WebInspector.HARLog(this._requests.filter(WebInspector.NetworkLogView.HTTPRequestsFilter))).build()};InspectorFrontendHost.copyText(JSON.stringify(harArchive,null,2));},_copyLocation:function(request)
+{InspectorFrontendHost.copyText(request.url);},_copyRequestHeaders:function(request)
+{InspectorFrontendHost.copyText(request.requestHeadersText);},_copyResponseHeaders:function(request)
+{InspectorFrontendHost.copyText(request.responseHeadersText);},_copyCurlCommand:function(request)
+{InspectorFrontendHost.copyText(this._generateCurlCommand(request));},_exportAll:function()
+{var filename=WebInspector.inspectedPageDomain+".har";var stream=new WebInspector.FileOutputStream();stream.open(filename,openCallback.bind(this));function openCallback()
+{var progressIndicator=new WebInspector.ProgressIndicator();this._progressBarContainer.appendChild(progressIndicator.element);var harWriter=new WebInspector.HARWriter();harWriter.write(stream,this._requests.filter(WebInspector.NetworkLogView.HTTPRequestsFilter),progressIndicator);}},_clearBrowserCache:function()
+{if(confirm(WebInspector.UIString("Are you sure you want to clear browser cache?")))
+NetworkAgent.clearBrowserCache();},_clearBrowserCookies:function()
+{if(confirm(WebInspector.UIString("Are you sure you want to clear browser cookies?")))
+NetworkAgent.clearBrowserCookies();},_updateOffscreenRows:function()
+{var dataTableBody=this._dataGrid.dataTableBody;var rows=dataTableBody.children;var recordsCount=rows.length;if(recordsCount<2)
+return;var visibleTop=this._dataGrid.scrollContainer.scrollTop;var visibleBottom=visibleTop+this._dataGrid.scrollContainer.offsetHeight;var rowHeight=0;var unfilteredRowIndex=0;for(var i=0;i<recordsCount-1;++i){var row=rows[i];var dataGridNode=this._dataGrid.dataGridNodeFromNode(row);if(dataGridNode.isFilteredOut()){row.removeStyleClass("offscreen");continue;}
+if(!rowHeight)
+rowHeight=row.offsetHeight;var rowIsVisible=unfilteredRowIndex*rowHeight<visibleBottom&&(unfilteredRowIndex+1)*rowHeight>visibleTop;if(rowIsVisible!==row.rowIsVisible){row.enableStyleClass("offscreen",!rowIsVisible);row.rowIsVisible=rowIsVisible;}
+unfilteredRowIndex++;}},_matchRequest:function(request)
+{if(!this._searchRegExp)
+return-1;if(!request.name().match(this._searchRegExp)&&!request.path().match(this._searchRegExp))
+return-1;if(request.requestId in this._matchedRequestsMap)
+return this._matchedRequestsMap[request.requestId];var matchedRequestIndex=this._matchedRequests.length;this._matchedRequestsMap[request.requestId]=matchedRequestIndex;this._matchedRequests.push(request.requestId);return matchedRequestIndex;},_clearSearchMatchedList:function()
+{delete this._searchRegExp;this._matchedRequests=[];this._matchedRequestsMap={};this._removeAllHighlights();},_updateSearchMatchedListAfterRequestIdChanged:function(oldRequestId,newRequestId)
+{var requestIndex=this._matchedRequestsMap[oldRequestId];if(requestIndex){delete this._matchedRequestsMap[oldRequestId];this._matchedRequestsMap[newRequestId]=requestIndex;this._matchedRequests[requestIndex]=newRequestId;}},_updateHighlightIfMatched:function(request)
+{var matchedRequestIndex=this._matchRequest(request);if(matchedRequestIndex===-1)
+return;this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.SearchCountUpdated,this._matchedRequests.length);if(this._currentMatchedRequestIndex!==-1&&this._currentMatchedRequestIndex!==matchedRequestIndex)
+return;this._highlightNthMatchedRequestForSearch(matchedRequestIndex,false);},_removeAllHighlights:function()
+{this._removeAllNodeHighlights();for(var i=0;i<this._highlightedSubstringChanges.length;++i)
+WebInspector.revertDomChanges(this._highlightedSubstringChanges[i]);this._highlightedSubstringChanges=[];},_highlightMatchedRequest:function(request,reveal,regExp)
+{var node=this._requestGridNode(request);if(!node)
+return;var nameMatched=request.name().match(regExp);var pathMatched=request.path().match(regExp);if(!nameMatched&&pathMatched&&!this._largerRequestsButton.toggled)
+this._toggleLargerRequests();var highlightedSubstringChanges=node._highlightMatchedSubstring(regExp);this._highlightedSubstringChanges.push(highlightedSubstringChanges);if(reveal){node.reveal();this._highlightNode(node);}},_highlightNthMatchedRequestForSearch:function(matchedRequestIndex,reveal)
+{var request=this.requestById(this._matchedRequests[matchedRequestIndex]);if(!request)
+return;this._removeAllHighlights();this._highlightMatchedRequest(request,reveal,this._searchRegExp);var node=this._requestGridNode(request);if(node)
+this._currentMatchedRequestIndex=matchedRequestIndex;this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.SearchIndexUpdated,this._currentMatchedRequestIndex);},performSearch:function(query,shouldJump)
+{var newMatchedRequestIndex=0;var currentMatchedRequestId;if(this._currentMatchedRequestIndex!==-1)
+currentMatchedRequestId=this._matchedRequests[this._currentMatchedRequestIndex];this._clearSearchMatchedList();this._searchRegExp=createPlainTextSearchRegex(query,"i");var childNodes=this._dataGrid.dataTableBody.childNodes;var requestNodes=Array.prototype.slice.call(childNodes,0,childNodes.length-1);for(var i=0;i<requestNodes.length;++i){var dataGridNode=this._dataGrid.dataGridNodeFromNode(requestNodes[i]);if(dataGridNode.isFilteredOut())
+continue;if(this._matchRequest(dataGridNode._request)!==-1&&dataGridNode._request.requestId===currentMatchedRequestId)
+newMatchedRequestIndex=this._matchedRequests.length-1;}
+this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.SearchCountUpdated,this._matchedRequests.length);if(shouldJump)
+this._highlightNthMatchedRequestForSearch(newMatchedRequestIndex,true);},_applyFilter:function(node)
+{var filter=this._filterRegExp;var request=node._request;var matches=false;if(this._typeFilter(request)){matches=!filter||filter.test(request.name())||filter.test(request.path());if(filter&&matches)
+this._highlightMatchedRequest(request,false,filter);}
+node.element.enableStyleClass("filtered-out",!matches);if(matches)
+this._filteredOutRequests.remove(request);else
+this._filteredOutRequests.put(request,true);},performFilter:function(query)
+{delete this._filterRegExp;if(query)
+this._filterRegExp=createPlainTextSearchRegex(query,"i");this._filterRequests();},_filterRequests:function()
+{this._removeAllHighlights();this._filteredOutRequests.clear();var nodes=this._dataGrid.rootNode().children;for(var i=0;i<nodes.length;++i)
+this._applyFilter(nodes[i]);this._updateSummaryBar();this._updateOffscreenRows();},jumpToPreviousSearchResult:function()
+{if(!this._matchedRequests.length)
+return;this._highlightNthMatchedRequestForSearch((this._currentMatchedRequestIndex+this._matchedRequests.length-1)%this._matchedRequests.length,true);},jumpToNextSearchResult:function()
+{if(!this._matchedRequests.length)
+return;this._highlightNthMatchedRequestForSearch((this._currentMatchedRequestIndex+1)%this._matchedRequests.length,true);},searchCanceled:function()
+{this._clearSearchMatchedList();this.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.SearchCountUpdated,0);},revealAndHighlightRequest:function(request)
+{this._removeAllNodeHighlights();var node=this._requestGridNode(request);if(node){this._dataGrid.element.focus();node.reveal();this._highlightNode(node);}},_removeAllNodeHighlights:function()
+{if(this._highlightedNode){this._highlightedNode.element.removeStyleClass("highlighted-row");delete this._highlightedNode;}},_highlightNode:function(node)
+{node.element.addStyleClass("highlighted-row");this._highlightedNode=node;},_generateCurlCommand:function(request)
+{var command=["curl"];var ignoredHeaders={};function escapeCharacter(x)
+{var code=x.charCodeAt(0);if(code<256){return code<16?"\\x0"+code.toString(16):"\\x"+code.toString(16);}
+code=code.toString(16);return"\\u"+("0000"+code).substr(code.length,4);}
function escape(str)
-{
-if (/[^\x20-\x7E]|\'/.test(str)) {
-
-return "$\'" + str.replace(/\\/g, "\\\\")
-.replace(/\'/g, "\\\'")
-.replace(/\n/g, "\\n")
-.replace(/\r/g, "\\r")
-.replace(/[^\x20-\x7E]/g, escapeCharacter) + "'";
-} else {
-
-return "'" + str + "'";
-}
-}
-command.push(escape(request.url));
-
-var inferredMethod = "GET";
-var data = [];
-var requestContentType = request.requestContentType();
-if (requestContentType && requestContentType.startsWith("application/x-www-form-urlencoded") && request.requestFormData) {
-data.push("--data");
-data.push(escape(request.requestFormData));
-ignoredHeaders["Content-Length"] = true;
-inferredMethod = "POST";
-} else if (request.requestFormData) {
-data.push("--data-binary");
-data.push(escape(request.requestFormData));
-ignoredHeaders["Content-Length"] = true;
-inferredMethod = "POST";
-}
-
-if (request.requestMethod !== inferredMethod) {
-command.push("-X");
-command.push(request.requestMethod);
-}
-
-for (var i = 0; i < request.requestHeaders.length; i++) {
-var header = request.requestHeaders[i];
-if (header.name in ignoredHeaders)
-continue;
-command.push("-H");
-command.push(escape(header.name + ": " + header.value));
-}
-command = command.concat(data);
-command.push("--compressed");
-return command.join(" ");
-},
-
-__proto__: WebInspector.View.prototype
-}
-
-
-WebInspector.NetworkLogView.HTTPRequestsFilter = function(request)
-{
-return request.parsedURL.isValid && (request.parsedURL.scheme in WebInspector.NetworkLogView.HTTPSchemas);
-}
-
-
-WebInspector.NetworkLogView.EventTypes = {
-ViewCleared: "ViewCleared",
-RowSizeChanged: "RowSizeChanged",
-RequestSelected: "RequestSelected",
-SearchCountUpdated: "SearchCountUpdated",
-SearchIndexUpdated: "SearchIndexUpdated"
-};
-
-
-WebInspector.NetworkPanel = function()
-{
-WebInspector.Panel.call(this, "network");
-this.registerRequiredCSS("networkPanel.css");
-this._injectStyles();
-
-this.createSidebarView();
-this.splitView.hideMainElement();
-
-var defaultColumnsVisibility = WebInspector.NetworkLogView._defaultColumnsVisivility;
-var networkLogColumnsVisibilitySetting = WebInspector.settings.createSetting("networkLogColumnsVisibility", defaultColumnsVisibility);
-var savedColumnsVisibility = networkLogColumnsVisibilitySetting.get();
-var columnsVisibility = {};
-for (var columnId in defaultColumnsVisibility)
-columnsVisibility[columnId] = savedColumnsVisibility.hasOwnProperty(columnId) ? savedColumnsVisibility[columnId] : defaultColumnsVisibility[columnId];
-networkLogColumnsVisibilitySetting.set(columnsVisibility);
-
-this._networkLogView = new WebInspector.NetworkLogView(networkLogColumnsVisibilitySetting);
-this._networkLogView.show(this.sidebarElement);
-
-this._viewsContainerElement = this.splitView.mainElement;
-this._viewsContainerElement.id = "network-views";
-this._viewsContainerElement.addStyleClass("hidden");
-if (!this._networkLogView.useLargeRows)
-this._viewsContainerElement.addStyleClass("small");
-
-this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.ViewCleared, this._onViewCleared, this);
-this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.RowSizeChanged, this._onRowSizeChanged, this);
-this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.RequestSelected, this._onRequestSelected, this);
-this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.SearchCountUpdated, this._onSearchCountUpdated, this);
-this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.SearchIndexUpdated, this._onSearchIndexUpdated, this);
-
-this._closeButtonElement = this._viewsContainerElement.createChild("div", "close-button");
-this._closeButtonElement.id = "network-close-button";
-this._closeButtonElement.addEventListener("click", this._toggleGridMode.bind(this), false);
-this._viewsContainerElement.appendChild(this._closeButtonElement);
-
-function viewGetter()
-{
-return this.visibleView;
-}
-WebInspector.GoToLineDialog.install(this, viewGetter.bind(this));
-}
-
-WebInspector.NetworkPanel.prototype = {
-get statusBarItems()
-{
-return this._networkLogView.statusBarItems;
-},
-
-elementsToRestoreScrollPositionsFor: function()
-{
-return this._networkLogView.elementsToRestoreScrollPositionsFor();
-},
-
-
-_reset: function()
-{
-this._networkLogView._reset();
-},
-
-handleShortcut: function(event)
-{
-if (this._viewingRequestMode && event.keyCode === WebInspector.KeyboardShortcut.Keys.Esc.code) {
-this._toggleGridMode();
-event.handled = true;
-return;
-}
-
-WebInspector.Panel.prototype.handleShortcut.call(this, event);
-},
-
-wasShown: function()
-{
-WebInspector.Panel.prototype.wasShown.call(this);
-},
-
-get requests()
-{
-return this._networkLogView.requests;
-},
-
-requestById: function(id)
-{
-return this._networkLogView.requestById(id);
-},
-
-_requestByAnchor: function(anchor)
-{
-return anchor.requestId ? this.requestById(anchor.requestId) : this._networkLogView._requestsByURL[anchor.href];
-},
-
-canShowAnchorLocation: function(anchor)
-{
-return !!this._requestByAnchor(anchor);
-},
-
-showAnchorLocation: function(anchor)
-{
-var request = this._requestByAnchor(anchor);
-this.revealAndHighlightRequest(request)
-},
-
-revealAndHighlightRequest: function(request)
-{
-this._toggleGridMode();
-if (request)
-this._networkLogView.revealAndHighlightRequest(request);
-},
-
-_onViewCleared: function(event)
-{
-this._closeVisibleRequest();
-this._toggleGridMode();
-this._viewsContainerElement.removeChildren();
-this._viewsContainerElement.appendChild(this._closeButtonElement);
-},
-
-_onRowSizeChanged: function(event)
-{
-this._viewsContainerElement.enableStyleClass("small", !event.data.largeRows);
-},
-
-_onSearchCountUpdated: function(event)
-{
-WebInspector.searchController.updateSearchMatchesCount(event.data, this);
-},
-
-_onSearchIndexUpdated: function(event)
-{
-WebInspector.searchController.updateCurrentMatchIndex(event.data, this);
-},
-
-_onRequestSelected: function(event)
-{
-this._showRequest(event.data);
-},
-
-_showRequest: function(request)
-{
-if (!request)
-return;
-
-this._toggleViewingRequestMode();
-
-if (this.visibleView) {
-this.visibleView.detach();
-delete this.visibleView;
-}
-
-var view = new WebInspector.NetworkItemView(request);
-view.show(this._viewsContainerElement);
-this.visibleView = view;
-},
-
-_closeVisibleRequest: function()
-{
-this.element.removeStyleClass("viewing-resource");
-
-if (this.visibleView) {
-this.visibleView.detach();
-delete this.visibleView;
-}
-},
-
-_toggleGridMode: function()
-{
-if (this._viewingRequestMode) {
-this._viewingRequestMode = false;
-this.element.removeStyleClass("viewing-resource");
-this.splitView.hideMainElement();
-}
-
-this._networkLogView.switchToDetailedView();
-this._networkLogView.allowPopover = true;
-this._networkLogView._allowRequestSelection = false;
-},
-
-_toggleViewingRequestMode: function()
-{
-if (this._viewingRequestMode)
-return;
-this._viewingRequestMode = true;
-
-this.element.addStyleClass("viewing-resource");
-this.splitView.showMainElement();
-this._networkLogView.allowPopover = false;
-this._networkLogView._allowRequestSelection = true;
-this._networkLogView.switchToBriefView();
-},
-
-
-performSearch: function(searchQuery)
-{
-this._networkLogView.performSearch(searchQuery);
-},
-
-
-canFilter: function()
-{
-return true;
-},
-
-
-performFilter: function(query)
-{
-this._networkLogView.performFilter(query);
-},
-
-jumpToPreviousSearchResult: function()
-{
-this._networkLogView.jumpToPreviousSearchResult();
-},
-
-jumpToNextSearchResult: function()
-{
-this._networkLogView.jumpToNextSearchResult();
-},
-
-searchCanceled: function()
-{
-this._networkLogView.searchCanceled();
-},
-
-
-appendApplicableItems: function(event, contextMenu, target)
-{
-if (!(target instanceof WebInspector.NetworkRequest))
-return;
-if (this.visibleView && this.visibleView.isShowing() && this.visibleView.request() === target)
-return;
-
-function reveal()
-{
-WebInspector.inspectorView.setCurrentPanel(this);
-this.revealAndHighlightRequest( (target));
-}
-contextMenu.appendItem(WebInspector.UIString(WebInspector.useLowerCaseMenuTitles() ? "Reveal in Network panel" : "Reveal in Network Panel"), reveal.bind(this));
-},
-
-_injectStyles: function()
-{
-var style = document.createElement("style");
-var rules = [];
-
-var columns = WebInspector.NetworkLogView._defaultColumnsVisivility;
-
-var hideSelectors = [];
-var bgSelectors = [];
-for (var columnId in columns) {
-hideSelectors.push("#network-container .hide-" + columnId + "-column ." + columnId + "-column");
-bgSelectors.push(".network-log-grid.data-grid td." + columnId + "-column");
-}
-rules.push(hideSelectors.join(", ") + "{border-right: 0 none transparent;}");
-rules.push(bgSelectors.join(", ") + "{background-color: rgba(0, 0, 0, 0.07);}");
-
-style.textContent = rules.join("\n");
-document.head.appendChild(style);
-},
-
-__proto__: WebInspector.Panel.prototype
-}
-
-
-WebInspector.NetworkBaseCalculator = function()
-{
-}
-
-WebInspector.NetworkBaseCalculator.prototype = {
-computePosition: function(time)
-{
-return (time - this._minimumBoundary) / this.boundarySpan() * this._workingArea;
-},
-
-computeBarGraphPercentages: function(item)
-{
-return {start: 0, middle: 0, end: (this._value(item) / this.boundarySpan()) * 100};
-},
-
-computeBarGraphLabels: function(item)
-{
-const label = this.formatTime(this._value(item));
-return {left: label, right: label, tooltip: label};
-},
-
-boundarySpan: function()
-{
-return this._maximumBoundary - this._minimumBoundary;
-},
-
-updateBoundaries: function(item)
-{
-this._minimumBoundary = 0;
-
-var value = this._value(item);
-if (typeof this._maximumBoundary === "undefined" || value > this._maximumBoundary) {
-this._maximumBoundary = value;
-return true;
-}
-return false;
-},
-
-reset: function()
-{
-delete this._minimumBoundary;
-delete this._maximumBoundary;
-},
-
-maximumBoundary: function()
-{
-return this._maximumBoundary;
-},
-
-minimumBoundary: function()
-{
-return this._minimumBoundary;
-},
-
-zeroTime: function()
-{
-return this._minimumBoundary;
-},
-
-_value: function(item)
-{
-return 0;
-},
-
-formatTime: function(value)
-{
-return value.toString();
-},
-
-setDisplayWindow: function(clientWidth)
-{
-this._workingArea = clientWidth;
-this.paddingLeft = 0;
-}
-}
-
-
-WebInspector.NetworkTimeCalculator = function(startAtZero)
-{
-WebInspector.NetworkBaseCalculator.call(this);
-this.startAtZero = startAtZero;
-}
-
-WebInspector.NetworkTimeCalculator.prototype = {
-computeBarGraphPercentages: function(request)
-{
-if (request.startTime !== -1)
-var start = ((request.startTime - this._minimumBoundary) / this.boundarySpan()) * 100;
-else
-var start = 0;
-
-if (request.responseReceivedTime !== -1)
-var middle = ((request.responseReceivedTime - this._minimumBoundary) / this.boundarySpan()) * 100;
-else
-var middle = (this.startAtZero ? start : 100);
-
-if (request.endTime !== -1)
-var end = ((request.endTime - this._minimumBoundary) / this.boundarySpan()) * 100;
-else
-var end = (this.startAtZero ? middle : 100);
-
-if (this.startAtZero) {
-end -= start;
-middle -= start;
-start = 0;
-}
-
-return {start: start, middle: middle, end: end};
-},
-
-computePercentageFromEventTime: function(eventTime)
-{
-
-
-
-if (eventTime !== -1 && !this.startAtZero)
-return ((eventTime - this._minimumBoundary) / this.boundarySpan()) * 100;
-
-return 0;
-},
-
-updateBoundariesForEventTime: function(eventTime)
-{
-if (eventTime === -1 || this.startAtZero)
-return false;
-
-if (typeof this._maximumBoundary === "undefined" || eventTime > this._maximumBoundary) {
-this._maximumBoundary = eventTime;
-return true;
-}
-return false;
-},
-
-computeBarGraphLabels: function(request)
-{
-var rightLabel = "";
-if (request.responseReceivedTime !== -1 && request.endTime !== -1)
-rightLabel = this.formatTime(request.endTime - request.responseReceivedTime);
-
-var hasLatency = request.latency > 0;
-if (hasLatency)
-var leftLabel = this.formatTime(request.latency);
-else
-var leftLabel = rightLabel;
-
-if (request.timing)
-return {left: leftLabel, right: rightLabel};
-
-if (hasLatency && rightLabel) {
-var total = this.formatTime(request.duration);
-var tooltip = WebInspector.UIString("%s latency, %s download (%s total)", leftLabel, rightLabel, total);
-} else if (hasLatency)
-var tooltip = WebInspector.UIString("%s latency", leftLabel);
-else if (rightLabel)
-var tooltip = WebInspector.UIString("%s download", rightLabel);
-
-if (request.cached)
-tooltip = WebInspector.UIString("%s (from cache)", tooltip);
-return {left: leftLabel, right: rightLabel, tooltip: tooltip};
-},
-
-updateBoundaries: function(request)
-{
-var didChange = false;
-
-var lowerBound;
-if (this.startAtZero)
-lowerBound = 0;
-else
-lowerBound = this._lowerBound(request);
-
-if (lowerBound !== -1 && (typeof this._minimumBoundary === "undefined" || lowerBound < this._minimumBoundary)) {
-this._minimumBoundary = lowerBound;
-didChange = true;
-}
-
-var upperBound = this._upperBound(request);
-if (upperBound !== -1 && (typeof this._maximumBoundary === "undefined" || upperBound > this._maximumBoundary)) {
-this._maximumBoundary = upperBound;
-didChange = true;
-}
-
-return didChange;
-},
-
-formatTime: function(value)
-{
-return Number.secondsToString(value);
-},
-
-_lowerBound: function(request)
-{
-return 0;
-},
-
-_upperBound: function(request)
-{
-return 0;
-},
-
-__proto__: WebInspector.NetworkBaseCalculator.prototype
-}
-
-
-WebInspector.NetworkTransferTimeCalculator = function()
-{
-WebInspector.NetworkTimeCalculator.call(this, false);
-}
-
-WebInspector.NetworkTransferTimeCalculator.prototype = {
-formatTime: function(value)
-{
-return Number.secondsToString(value);
-},
-
-_lowerBound: function(request)
-{
-return request.startTime;
-},
-
-_upperBound: function(request)
-{
-return request.endTime;
-},
-
-__proto__: WebInspector.NetworkTimeCalculator.prototype
-}
-
-
-WebInspector.NetworkTransferDurationCalculator = function()
-{
-WebInspector.NetworkTimeCalculator.call(this, true);
-}
-
-WebInspector.NetworkTransferDurationCalculator.prototype = {
-formatTime: function(value)
-{
-return Number.secondsToString(value);
-},
-
-_upperBound: function(request)
-{
-return request.duration;
-},
-
-__proto__: WebInspector.NetworkTimeCalculator.prototype
-}
-
-
-WebInspector.NetworkDataGridNode = function(parentView, request)
-{
-WebInspector.DataGridNode.call(this, {});
-this._parentView = parentView;
-this._request = request;
-this._linkifier = new WebInspector.Linkifier();
-}
-
-WebInspector.NetworkDataGridNode.prototype = {
-
-createCells: function()
-{
-
-this._element.addStyleClass("offscreen");
-this._nameCell = this._createDivInTD("name");
-this._methodCell = this._createDivInTD("method");
-this._statusCell = this._createDivInTD("status");
-this._domainCell = this._createDivInTD("domain");
-this._typeCell = this._createDivInTD("type");
-this._initiatorCell = this._createDivInTD("initiator");
-this._cookiesCell = this._createDivInTD("cookies");
-this._setCookiesCell = this._createDivInTD("setCookies");
-this._sizeCell = this._createDivInTD("size");
-this._timeCell = this._createDivInTD("time");
-this._timelineCell = this._createDivInTD("timeline");
-this._createTimelineBar(this._timelineCell);
-this._nameCell.addEventListener("click", this._onClick.bind(this), false);
-this._nameCell.addEventListener("dblclick", this._openInNewTab.bind(this), false);
-},
-
-wasDetached: function()
-{
-this._linkifier.reset();
-},
-
-isFilteredOut: function()
-{
-if (this._parentView._filteredOutRequests.get(this._request))
-return true;
-return !this._parentView._typeFilter(this._request);
-},
-
-_onClick: function()
-{
-if (!this._parentView._allowRequestSelection)
-this.select();
-},
-
-select: function()
-{
-this._parentView.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.RequestSelected, this._request);
-WebInspector.DataGridNode.prototype.select.apply(this, arguments);
-
-WebInspector.notifications.dispatchEventToListeners(WebInspector.UserMetrics.UserAction, {
-action: WebInspector.UserMetrics.UserActionNames.NetworkRequestSelected,
-url: this._request.url
-});
-},
-
-_highlightMatchedSubstring: function(regexp)
-{
-var domChanges = [];
-var matchInfo = this._element.textContent.match(regexp);
-if (matchInfo)
-WebInspector.highlightSearchResult(this._nameCell, matchInfo.index, matchInfo[0].length, domChanges);
-return domChanges;
-},
-
-_openInNewTab: function()
-{
-InspectorFrontendHost.openInNewTab(this._request.url);
-},
-
-get selectable()
-{
-return this._parentView._allowRequestSelection && !this.isFilteredOut();
-},
-
-_createDivInTD: function(columnIdentifier)
-{
-var td = this.createTD(columnIdentifier);
-var div = td.createChild("div");
-this._element.appendChild(td);
-return div;
-},
-
-
-_createTimelineBar: function(cell)
-{
-cell.className = "network-graph-side";
-
-this._barAreaElement = document.createElement("div");
-
-this._barAreaElement.className = "network-graph-bar-area";
-this._barAreaElement.request = this._request;
-cell.appendChild(this._barAreaElement);
-
-this._barLeftElement = document.createElement("div");
-this._barLeftElement.className = "network-graph-bar waiting";
-this._barAreaElement.appendChild(this._barLeftElement);
-
-this._barRightElement = document.createElement("div");
-this._barRightElement.className = "network-graph-bar";
-this._barAreaElement.appendChild(this._barRightElement);
-
-
-this._labelLeftElement = document.createElement("div");
-this._labelLeftElement.className = "network-graph-label waiting";
-this._barAreaElement.appendChild(this._labelLeftElement);
-
-this._labelRightElement = document.createElement("div");
-this._labelRightElement.className = "network-graph-label";
-this._barAreaElement.appendChild(this._labelRightElement);
-
-cell.addEventListener("mouseover", this._refreshLabelPositions.bind(this), false);
-},
-
-refreshRequest: function()
-{
-this._refreshNameCell();
-this._refreshMethodCell();
-this._refreshStatusCell();
-this._refreshDomainCell();
-this._refreshTypeCell();
-this._refreshInitiatorCell();
-this._refreshCookiesCell();
-this._refreshSetCookiesCell();
-this._refreshSizeCell();
-this._refreshTimeCell();
-
-if (this._request.cached)
-this._timelineCell.addStyleClass("resource-cached");
-
-this._element.addStyleClass("network-item");
-this._element.enableStyleClass("network-error-row", this._request.failed || (this._request.statusCode >= 400));
-this._updateElementStyleClasses(this._element);
-},
-
-
-_updateElementStyleClasses: function(element)
-{
-var typeClassName = "network-type-" + this._request.type.name();
-if (!element.hasStyleClass(typeClassName)) {
-element.removeMatchingStyleClasses("network-type-\\w+");
-element.addStyleClass(typeClassName);
-}
-},
-
-_refreshNameCell: function()
-{
-this._nameCell.removeChildren();
-
-if (this._request.type === WebInspector.resourceTypes.Image) {
-var previewImage = document.createElement("img");
-previewImage.className = "image-network-icon-preview";
-this._request.populateImageSource(previewImage);
-
-var iconElement = document.createElement("div");
-iconElement.className = "icon";
-iconElement.appendChild(previewImage);
-} else {
-var iconElement = document.createElement("img");
-iconElement.className = "icon";
-}
-this._nameCell.appendChild(iconElement);
-this._nameCell.appendChild(document.createTextNode(this._request.name()));
-this._appendSubtitle(this._nameCell, this._request.path());
-this._nameCell.title = this._request.url;
-},
-
-_refreshMethodCell: function()
-{
-this._methodCell.setTextAndTitle(this._request.requestMethod);
-},
-
-_refreshStatusCell: function()
-{
-this._statusCell.removeChildren();
-
-if (this._request.failed) {
-var failText = this._request.canceled ? WebInspector.UIString("(canceled)") : WebInspector.UIString("(failed)");
-if (this._request.localizedFailDescription) {
-this._statusCell.appendChild(document.createTextNode(failText));
-this._appendSubtitle(this._statusCell, this._request.localizedFailDescription);
-this._statusCell.title = failText + " " + this._request.localizedFailDescription;
-} else
-this._statusCell.setTextAndTitle(failText);
-this._statusCell.addStyleClass("network-dim-cell");
-return;
-}
-
-this._statusCell.removeStyleClass("network-dim-cell");
-
-if (this._request.statusCode) {
-this._statusCell.appendChild(document.createTextNode("" + this._request.statusCode));
-this._appendSubtitle(this._statusCell, this._request.statusText);
-this._statusCell.title = this._request.statusCode + " " + this._request.statusText;
-if (this._request.cached)
-this._statusCell.addStyleClass("network-dim-cell");
-} else {
-if (!this._request.isHttpFamily() && this._request.finished)
-this._statusCell.setTextAndTitle(WebInspector.UIString("Success"));
-else if (this._request.isPingRequest())
-this._statusCell.setTextAndTitle(WebInspector.UIString("(ping)"));
-else
-this._statusCell.setTextAndTitle(WebInspector.UIString("(pending)"));
-this._statusCell.addStyleClass("network-dim-cell");
-}
-},
-
-_refreshDomainCell: function()
-{
-this._domainCell.removeChildren();
-this._domainCell.appendChild(document.createTextNode(this._request.domain));
-this._domainCell.title = this._request.parsedURL.host;
-},
-
-_refreshTypeCell: function()
-{
-if (this._request.mimeType) {
-this._typeCell.removeStyleClass("network-dim-cell");
-this._typeCell.setTextAndTitle(this._request.mimeType);
-} else if (this._request.isPingRequest()) {
-this._typeCell.removeStyleClass("network-dim-cell");
-this._typeCell.setTextAndTitle(this._request.requestContentType() || "");
-} else {
-this._typeCell.addStyleClass("network-dim-cell");
-this._typeCell.setTextAndTitle(WebInspector.UIString("Pending"));
-}
-},
-
-_refreshInitiatorCell: function()
-{
-this._initiatorCell.removeChildren();
-this._initiatorCell.removeStyleClass("network-dim-cell");
-this._initiatorCell.removeStyleClass("network-script-initiated");
-delete this._initiatorCell.request;
-
-var request = this._request;
-var initiator = request.initiatorInfo();
-
-switch (initiator.type) {
-case WebInspector.NetworkRequest.InitiatorType.Parser:
-this._initiatorCell.title = initiator.url + ":" + initiator.lineNumber;
-this._initiatorCell.appendChild(WebInspector.linkifyResourceAsNode(initiator.url, initiator.lineNumber - 1));
-this._appendSubtitle(this._initiatorCell, WebInspector.UIString("Parser"));
-break;
-
-case WebInspector.NetworkRequest.InitiatorType.Redirect:
-this._initiatorCell.title = initiator.url;
-this._initiatorCell.appendChild(WebInspector.linkifyRequestAsNode(request.redirectSource));
-this._appendSubtitle(this._initiatorCell, WebInspector.UIString("Redirect"));
-break;
-
-case WebInspector.NetworkRequest.InitiatorType.Script:
-var urlElement = this._linkifier.linkifyLocation(initiator.url, initiator.lineNumber - 1, initiator.columnNumber - 1);
-urlElement.title = "";
-this._initiatorCell.appendChild(urlElement);
-this._appendSubtitle(this._initiatorCell, WebInspector.UIString("Script"));
-this._initiatorCell.addStyleClass("network-script-initiated");
-this._initiatorCell.request = request;
-break;
-
-default:
-this._initiatorCell.title = "";
-this._initiatorCell.addStyleClass("network-dim-cell");
-this._initiatorCell.setTextAndTitle(WebInspector.UIString("Other"));
-}
-},
-
-_refreshCookiesCell: function()
-{
-var requestCookies = this._request.requestCookies;
-this._cookiesCell.setTextAndTitle(requestCookies ? "" + requestCookies.length : "");
-},
-
-_refreshSetCookiesCell: function()
-{
-var responseCookies = this._request.responseCookies;
-this._setCookiesCell.setTextAndTitle(responseCookies ? "" + responseCookies.length : "");
-},
-
-_refreshSizeCell: function()
-{
-if (this._request.cached) {
-this._sizeCell.setTextAndTitle(WebInspector.UIString("(from cache)"));
-this._sizeCell.addStyleClass("network-dim-cell");
-} else {
-var resourceSize = typeof this._request.resourceSize === "number" ? Number.bytesToString(this._request.resourceSize) : "?";
-var transferSize = typeof this._request.transferSize === "number" ? Number.bytesToString(this._request.transferSize) : "?";
-this._sizeCell.setTextAndTitle(transferSize);
-this._sizeCell.removeStyleClass("network-dim-cell");
-this._appendSubtitle(this._sizeCell, resourceSize);
-}
-},
-
-_refreshTimeCell: function()
-{
-if (this._request.duration > 0) {
-this._timeCell.removeStyleClass("network-dim-cell");
-this._timeCell.setTextAndTitle(Number.secondsToString(this._request.duration));
-this._appendSubtitle(this._timeCell, Number.secondsToString(this._request.latency));
-} else {
-this._timeCell.addStyleClass("network-dim-cell");
-this._timeCell.setTextAndTitle(WebInspector.UIString("Pending"));
-}
-},
-
-_appendSubtitle: function(cellElement, subtitleText)
-{
-var subtitleElement = document.createElement("div");
-subtitleElement.className = "network-cell-subtitle";
-subtitleElement.textContent = subtitleText;
-cellElement.appendChild(subtitleElement);
-},
-
-refreshGraph: function(calculator)
-{
-var percentages = calculator.computeBarGraphPercentages(this._request);
-this._percentages = percentages;
-
-this._barAreaElement.removeStyleClass("hidden");
-this._updateElementStyleClasses(this._timelineCell);
-
-this._barLeftElement.style.setProperty("left", percentages.start + "%");
-this._barRightElement.style.setProperty("right", (100 - percentages.end) + "%");
-
-this._barLeftElement.style.setProperty("right", (100 - percentages.end) + "%");
-this._barRightElement.style.setProperty("left", percentages.middle + "%");
-
-var labels = calculator.computeBarGraphLabels(this._request);
-this._labelLeftElement.textContent = labels.left;
-this._labelRightElement.textContent = labels.right;
-
-var tooltip = (labels.tooltip || "");
-this._barLeftElement.title = tooltip;
-this._labelLeftElement.title = tooltip;
-this._labelRightElement.title = tooltip;
-this._barRightElement.title = tooltip;
-},
-
-_refreshLabelPositions: function()
-{
-if (!this._percentages)
-return;
-this._labelLeftElement.style.removeProperty("left");
-this._labelLeftElement.style.removeProperty("right");
-this._labelLeftElement.removeStyleClass("before");
-this._labelLeftElement.removeStyleClass("hidden");
-
-this._labelRightElement.style.removeProperty("left");
-this._labelRightElement.style.removeProperty("right");
-this._labelRightElement.removeStyleClass("after");
-this._labelRightElement.removeStyleClass("hidden");
-
-const labelPadding = 10;
-const barRightElementOffsetWidth = this._barRightElement.offsetWidth;
-const barLeftElementOffsetWidth = this._barLeftElement.offsetWidth;
-
-if (this._barLeftElement) {
-var leftBarWidth = barLeftElementOffsetWidth - labelPadding;
-var rightBarWidth = (barRightElementOffsetWidth - barLeftElementOffsetWidth) - labelPadding;
-} else {
-var leftBarWidth = (barLeftElementOffsetWidth - barRightElementOffsetWidth) - labelPadding;
-var rightBarWidth = barRightElementOffsetWidth - labelPadding;
-}
-
-const labelLeftElementOffsetWidth = this._labelLeftElement.offsetWidth;
-const labelRightElementOffsetWidth = this._labelRightElement.offsetWidth;
-
-const labelBefore = (labelLeftElementOffsetWidth > leftBarWidth);
-const labelAfter = (labelRightElementOffsetWidth > rightBarWidth);
-const graphElementOffsetWidth = this._timelineCell.offsetWidth;
-
-if (labelBefore && (graphElementOffsetWidth * (this._percentages.start / 100)) < (labelLeftElementOffsetWidth + 10))
-var leftHidden = true;
-
-if (labelAfter && (graphElementOffsetWidth * ((100 - this._percentages.end) / 100)) < (labelRightElementOffsetWidth + 10))
-var rightHidden = true;
-
-if (barLeftElementOffsetWidth == barRightElementOffsetWidth) {
-
-if (labelBefore && !labelAfter)
-leftHidden = true;
-else if (labelAfter && !labelBefore)
-rightHidden = true;
-}
-
-if (labelBefore) {
-if (leftHidden)
-this._labelLeftElement.addStyleClass("hidden");
-this._labelLeftElement.style.setProperty("right", (100 - this._percentages.start) + "%");
-this._labelLeftElement.addStyleClass("before");
-} else {
-this._labelLeftElement.style.setProperty("left", this._percentages.start + "%");
-this._labelLeftElement.style.setProperty("right", (100 - this._percentages.middle) + "%");
-}
-
-if (labelAfter) {
-if (rightHidden)
-this._labelRightElement.addStyleClass("hidden");
-this._labelRightElement.style.setProperty("left", this._percentages.end + "%");
-this._labelRightElement.addStyleClass("after");
-} else {
-this._labelRightElement.style.setProperty("left", this._percentages.middle + "%");
-this._labelRightElement.style.setProperty("right", (100 - this._percentages.end) + "%");
-}
-},
-
-__proto__: WebInspector.DataGridNode.prototype
-}
-
-
-WebInspector.NetworkLogView._trivialTypeFilter = function(request)
-{
-return true;
-}
-
-
-WebInspector.NetworkLogView._typeFilter = function(allowedTypes, request)
-{
-return request.type.name() in allowedTypes;
-}
-
-
-WebInspector.NetworkDataGridNode.NameComparator = function(a, b)
-{
-var aFileName = a._request.name();
-var bFileName = b._request.name();
-if (aFileName > bFileName)
-return 1;
-if (bFileName > aFileName)
-return -1;
-return 0;
-}
-
-WebInspector.NetworkDataGridNode.SizeComparator = function(a, b)
-{
-if (b._request.cached && !a._request.cached)
-return 1;
-if (a._request.cached && !b._request.cached)
-return -1;
-
-if (a._request.transferSize === b._request.transferSize)
-return 0;
-
-return a._request.transferSize - b._request.transferSize;
-}
-
-WebInspector.NetworkDataGridNode.InitiatorComparator = function(a, b)
-{
-var aInitiator = a._request.initiatorInfo();
-var bInitiator = b._request.initiatorInfo();
-
-if (aInitiator.type < bInitiator.type)
-return -1;
-if (aInitiator.type > bInitiator.type)
-return 1;
-
-if (aInitiator.source < bInitiator.source)
-return -1;
-if (aInitiator.source > bInitiator.source)
-return 1;
-
-if (aInitiator.lineNumber < bInitiator.lineNumber)
-return -1;
-if (aInitiator.lineNumber > bInitiator.lineNumber)
-return 1;
-
-if (aInitiator.columnNumber < bInitiator.columnNumber)
-return -1;
-if (aInitiator.columnNumber > bInitiator.columnNumber)
-return 1;
-
-return 0;
-}
-
-WebInspector.NetworkDataGridNode.RequestCookiesCountComparator = function(a, b)
-{
-var aScore = a._request.requestCookies ? a._request.requestCookies.length : 0;
-var bScore = b._request.requestCookies ? b._request.requestCookies.length : 0;
-return aScore - bScore;
-}
-
-WebInspector.NetworkDataGridNode.ResponseCookiesCountComparator = function(a, b)
-{
-var aScore = a._request.responseCookies ? a._request.responseCookies.length : 0;
-var bScore = b._request.responseCookies ? b._request.responseCookies.length : 0;
-return aScore - bScore;
-}
-
-WebInspector.NetworkDataGridNode.RequestPropertyComparator = function(propertyName, revert, a, b)
-{
-var aValue = a._request[propertyName];
-var bValue = b._request[propertyName];
-if (aValue > bValue)
-return revert ? -1 : 1;
-if (bValue > aValue)
-return revert ? 1 : -1;
-return 0;
-}
+{if(/[^\x20-\x7E]|\'/.test(str)){return"$\'"+str.replace(/\\/g,"\\\\").replace(/\'/g,"\\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/[^\x20-\x7E]/g,escapeCharacter)+"'";}else{return"'"+str+"'";}}
+command.push(escape(request.url).replace(/[[{}\]]/g,"\\$&"));var inferredMethod="GET";var data=[];var requestContentType=request.requestContentType();if(requestContentType&&requestContentType.startsWith("application/x-www-form-urlencoded")&&request.requestFormData){data.push("--data");data.push(escape(request.requestFormData));ignoredHeaders["Content-Length"]=true;inferredMethod="POST";}else if(request.requestFormData){data.push("--data-binary");data.push(escape(request.requestFormData));ignoredHeaders["Content-Length"]=true;inferredMethod="POST";}
+if(request.requestMethod!==inferredMethod){command.push("-X");command.push(request.requestMethod);}
+for(var i=0;i<request.requestHeaders.length;i++){var header=request.requestHeaders[i];if(header.name in ignoredHeaders)
+continue;command.push("-H");command.push(escape(header.name+": "+header.value));}
+command=command.concat(data);command.push("--compressed");return command.join(" ");},__proto__:WebInspector.View.prototype}
+WebInspector.NetworkLogView.HTTPRequestsFilter=function(request)
+{return request.parsedURL.isValid&&(request.scheme in WebInspector.NetworkLogView.HTTPSchemas);}
+WebInspector.NetworkLogView.EventTypes={ViewCleared:"ViewCleared",RowSizeChanged:"RowSizeChanged",RequestSelected:"RequestSelected",SearchCountUpdated:"SearchCountUpdated",SearchIndexUpdated:"SearchIndexUpdated"};WebInspector.NetworkPanel=function()
+{WebInspector.Panel.call(this,"network");this.registerRequiredCSS("networkPanel.css");this._injectStyles();this.createSidebarView();this.splitView.hideMainElement();var defaultColumnsVisibility=WebInspector.NetworkLogView._defaultColumnsVisibility;var networkLogColumnsVisibilitySetting=WebInspector.settings.createSetting("networkLogColumnsVisibility",defaultColumnsVisibility);var savedColumnsVisibility=networkLogColumnsVisibilitySetting.get();var columnsVisibility={};for(var columnId in defaultColumnsVisibility)
+columnsVisibility[columnId]=savedColumnsVisibility.hasOwnProperty(columnId)?savedColumnsVisibility[columnId]:defaultColumnsVisibility[columnId];networkLogColumnsVisibilitySetting.set(columnsVisibility);this._networkLogView=new WebInspector.NetworkLogView(networkLogColumnsVisibilitySetting);this._networkLogView.show(this.sidebarElement);this._viewsContainerElement=this.splitView.mainElement;this._viewsContainerElement.id="network-views";this._viewsContainerElement.addStyleClass("hidden");if(!this._networkLogView.useLargeRows)
+this._viewsContainerElement.addStyleClass("small");this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.ViewCleared,this._onViewCleared,this);this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.RowSizeChanged,this._onRowSizeChanged,this);this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.RequestSelected,this._onRequestSelected,this);this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.SearchCountUpdated,this._onSearchCountUpdated,this);this._networkLogView.addEventListener(WebInspector.NetworkLogView.EventTypes.SearchIndexUpdated,this._onSearchIndexUpdated,this);this._closeButtonElement=this._viewsContainerElement.createChild("div","close-button");this._closeButtonElement.id="network-close-button";this._closeButtonElement.addEventListener("click",this._toggleGridMode.bind(this),false);this._viewsContainerElement.appendChild(this._closeButtonElement);function viewGetter()
+{return this.visibleView;}
+WebInspector.GoToLineDialog.install(this,viewGetter.bind(this));}
+WebInspector.NetworkPanel.prototype={get statusBarItems()
+{return this._networkLogView.statusBarItems;},elementsToRestoreScrollPositionsFor:function()
+{return this._networkLogView.elementsToRestoreScrollPositionsFor();},_reset:function()
+{this._networkLogView._reset();},handleShortcut:function(event)
+{if(this._viewingRequestMode&&event.keyCode===WebInspector.KeyboardShortcut.Keys.Esc.code){this._toggleGridMode();event.handled=true;return;}
+WebInspector.Panel.prototype.handleShortcut.call(this,event);},wasShown:function()
+{WebInspector.Panel.prototype.wasShown.call(this);},get requests()
+{return this._networkLogView.requests;},requestById:function(id)
+{return this._networkLogView.requestById(id);},_requestByAnchor:function(anchor)
+{return anchor.requestId?this.requestById(anchor.requestId):this._networkLogView._requestsByURL[anchor.href];},canShowAnchorLocation:function(anchor)
+{return!!this._requestByAnchor(anchor);},showAnchorLocation:function(anchor)
+{var request=this._requestByAnchor(anchor);this.revealAndHighlightRequest(request)},revealAndHighlightRequest:function(request)
+{this._toggleGridMode();if(request)
+this._networkLogView.revealAndHighlightRequest(request);},_onViewCleared:function(event)
+{this._closeVisibleRequest();this._toggleGridMode();this._viewsContainerElement.removeChildren();this._viewsContainerElement.appendChild(this._closeButtonElement);},_onRowSizeChanged:function(event)
+{this._viewsContainerElement.enableStyleClass("small",!event.data.largeRows);},_onSearchCountUpdated:function(event)
+{WebInspector.searchController.updateSearchMatchesCount(event.data,this);},_onSearchIndexUpdated:function(event)
+{WebInspector.searchController.updateCurrentMatchIndex(event.data,this);},_onRequestSelected:function(event)
+{this._showRequest(event.data);},_showRequest:function(request)
+{if(!request)
+return;this._toggleViewingRequestMode();if(this.visibleView){this.visibleView.detach();delete this.visibleView;}
+var view=new WebInspector.NetworkItemView(request);view.show(this._viewsContainerElement);this.visibleView=view;},_closeVisibleRequest:function()
+{this.element.removeStyleClass("viewing-resource");if(this.visibleView){this.visibleView.detach();delete this.visibleView;}},_toggleGridMode:function()
+{if(this._viewingRequestMode){this._viewingRequestMode=false;this.element.removeStyleClass("viewing-resource");this.splitView.hideMainElement();}
+this._networkLogView.switchToDetailedView();this._networkLogView.allowPopover=true;this._networkLogView._allowRequestSelection=false;},_toggleViewingRequestMode:function()
+{if(this._viewingRequestMode)
+return;this._viewingRequestMode=true;this.element.addStyleClass("viewing-resource");this.splitView.showMainElement();this._networkLogView.allowPopover=false;this._networkLogView._allowRequestSelection=true;this._networkLogView.switchToBriefView();},performSearch:function(query,shouldJump)
+{this._networkLogView.performSearch(query,shouldJump);},canFilter:function()
+{return true;},performFilter:function(query)
+{this._networkLogView.performFilter(query);},jumpToPreviousSearchResult:function()
+{this._networkLogView.jumpToPreviousSearchResult();},jumpToNextSearchResult:function()
+{this._networkLogView.jumpToNextSearchResult();},searchCanceled:function()
+{this._networkLogView.searchCanceled();},appendApplicableItems:function(event,contextMenu,target)
+{function reveal(request)
+{WebInspector.inspectorView.setCurrentPanel(this);this.revealAndHighlightRequest(request);}
+function appendRevealItem(request)
+{var revealText=WebInspector.UIString(WebInspector.useLowerCaseMenuTitles()?"Reveal in Network panel":"Reveal in Network Panel");contextMenu.appendItem(revealText,reveal.bind(this,request));}
+if(target instanceof WebInspector.Resource){var resource=(target);if(resource.request)
+appendRevealItem.call(this,resource.request);return;}
+if(target instanceof WebInspector.UISourceCode){var uiSourceCode=(target);var resource=WebInspector.resourceForURL(uiSourceCode.url);if(resource&&resource.request)
+appendRevealItem.call(this,resource.request);return;}
+if(!(target instanceof WebInspector.NetworkRequest))
+return;var request=(target);if(this.visibleView&&this.visibleView.isShowing()&&this.visibleView.request()===request)
+return;appendRevealItem.call(this,request);},_injectStyles:function()
+{var style=document.createElement("style");var rules=[];var columns=WebInspector.NetworkLogView._defaultColumnsVisibility;var hideSelectors=[];var bgSelectors=[];for(var columnId in columns){hideSelectors.push("#network-container .hide-"+columnId+"-column ."+columnId+"-column");bgSelectors.push(".network-log-grid.data-grid td."+columnId+"-column");}
+rules.push(hideSelectors.join(", ")+"{border-left: 0 none transparent;}");rules.push(bgSelectors.join(", ")+"{background-color: rgba(0, 0, 0, 0.07);}");style.textContent=rules.join("\n");document.head.appendChild(style);},__proto__:WebInspector.Panel.prototype}
+WebInspector.NetworkBaseCalculator=function()
+{}
+WebInspector.NetworkBaseCalculator.prototype={computePosition:function(time)
+{return(time-this._minimumBoundary)/this.boundarySpan()*this._workingArea;},computeBarGraphPercentages:function(item)
+{return{start:0,middle:0,end:(this._value(item)/this.boundarySpan())*100};},computeBarGraphLabels:function(item)
+{const label=this.formatTime(this._value(item));return{left:label,right:label,tooltip:label};},boundarySpan:function()
+{return this._maximumBoundary-this._minimumBoundary;},updateBoundaries:function(item)
+{this._minimumBoundary=0;var value=this._value(item);if(typeof this._maximumBoundary==="undefined"||value>this._maximumBoundary){this._maximumBoundary=value;return true;}
+return false;},reset:function()
+{delete this._minimumBoundary;delete this._maximumBoundary;},maximumBoundary:function()
+{return this._maximumBoundary;},minimumBoundary:function()
+{return this._minimumBoundary;},zeroTime:function()
+{return this._minimumBoundary;},_value:function(item)
+{return 0;},formatTime:function(value)
+{return value.toString();},setDisplayWindow:function(clientWidth)
+{this._workingArea=clientWidth;this.paddingLeft=0;}}
+WebInspector.NetworkTimeCalculator=function(startAtZero)
+{WebInspector.NetworkBaseCalculator.call(this);this.startAtZero=startAtZero;}
+WebInspector.NetworkTimeCalculator.prototype={computeBarGraphPercentages:function(request)
+{if(request.startTime!==-1)
+var start=((request.startTime-this._minimumBoundary)/this.boundarySpan())*100;else
+var start=0;if(request.responseReceivedTime!==-1)
+var middle=((request.responseReceivedTime-this._minimumBoundary)/this.boundarySpan())*100;else
+var middle=(this.startAtZero?start:100);if(request.endTime!==-1)
+var end=((request.endTime-this._minimumBoundary)/this.boundarySpan())*100;else
+var end=(this.startAtZero?middle:100);if(this.startAtZero){end-=start;middle-=start;start=0;}
+return{start:start,middle:middle,end:end};},computePercentageFromEventTime:function(eventTime)
+{if(eventTime!==-1&&!this.startAtZero)
+return((eventTime-this._minimumBoundary)/this.boundarySpan())*100;return 0;},updateBoundariesForEventTime:function(eventTime)
+{if(eventTime===-1||this.startAtZero)
+return false;if(typeof this._maximumBoundary==="undefined"||eventTime>this._maximumBoundary){this._maximumBoundary=eventTime;return true;}
+return false;},computeBarGraphLabels:function(request)
+{var rightLabel="";if(request.responseReceivedTime!==-1&&request.endTime!==-1)
+rightLabel=this.formatTime(request.endTime-request.responseReceivedTime);var hasLatency=request.latency>0;if(hasLatency)
+var leftLabel=this.formatTime(request.latency);else
+var leftLabel=rightLabel;if(request.timing)
+return{left:leftLabel,right:rightLabel};if(hasLatency&&rightLabel){var total=this.formatTime(request.duration);var tooltip=WebInspector.UIString("%s latency, %s download (%s total)",leftLabel,rightLabel,total);}else if(hasLatency)
+var tooltip=WebInspector.UIString("%s latency",leftLabel);else if(rightLabel)
+var tooltip=WebInspector.UIString("%s download",rightLabel);if(request.cached)
+tooltip=WebInspector.UIString("%s (from cache)",tooltip);return{left:leftLabel,right:rightLabel,tooltip:tooltip};},updateBoundaries:function(request)
+{var didChange=false;var lowerBound;if(this.startAtZero)
+lowerBound=0;else
+lowerBound=this._lowerBound(request);if(lowerBound!==-1&&(typeof this._minimumBoundary==="undefined"||lowerBound<this._minimumBoundary)){this._minimumBoundary=lowerBound;didChange=true;}
+var upperBound=this._upperBound(request);if(upperBound!==-1&&(typeof this._maximumBoundary==="undefined"||upperBound>this._maximumBoundary)){this._maximumBoundary=upperBound;didChange=true;}
+return didChange;},formatTime:function(value)
+{return Number.secondsToString(value);},_lowerBound:function(request)
+{return 0;},_upperBound:function(request)
+{return 0;},__proto__:WebInspector.NetworkBaseCalculator.prototype}
+WebInspector.NetworkTransferTimeCalculator=function()
+{WebInspector.NetworkTimeCalculator.call(this,false);}
+WebInspector.NetworkTransferTimeCalculator.prototype={formatTime:function(value)
+{return Number.secondsToString(value);},_lowerBound:function(request)
+{return request.startTime;},_upperBound:function(request)
+{return request.endTime;},__proto__:WebInspector.NetworkTimeCalculator.prototype}
+WebInspector.NetworkTransferDurationCalculator=function()
+{WebInspector.NetworkTimeCalculator.call(this,true);}
+WebInspector.NetworkTransferDurationCalculator.prototype={formatTime:function(value)
+{return Number.secondsToString(value);},_upperBound:function(request)
+{return request.duration;},__proto__:WebInspector.NetworkTimeCalculator.prototype}
+WebInspector.NetworkDataGridNode=function(parentView,request)
+{WebInspector.DataGridNode.call(this,{});this._parentView=parentView;this._request=request;this._linkifier=new WebInspector.Linkifier();}
+WebInspector.NetworkDataGridNode.prototype={createCells:function()
+{this._element.addStyleClass("offscreen");this._nameCell=this._createDivInTD("name");this._methodCell=this._createDivInTD("method");this._statusCell=this._createDivInTD("status");this._schemeCell=this._createDivInTD("scheme");this._domainCell=this._createDivInTD("domain");this._typeCell=this._createDivInTD("type");this._initiatorCell=this._createDivInTD("initiator");this._cookiesCell=this._createDivInTD("cookies");this._setCookiesCell=this._createDivInTD("setCookies");this._sizeCell=this._createDivInTD("size");this._timeCell=this._createDivInTD("time");this._responseHeaderCells={};var responseHeaderColumns=WebInspector.NetworkLogView._responseHeaderColumns;for(var i=0;i<responseHeaderColumns.length;++i)
+this._responseHeaderCells[responseHeaderColumns[i]]=this._createDivInTD(responseHeaderColumns[i]);this._timelineCell=this._createDivInTD("timeline");this._createTimelineBar(this._timelineCell);this._nameCell.addEventListener("click",this._onClick.bind(this),false);this._nameCell.addEventListener("dblclick",this._openInNewTab.bind(this),false);},wasDetached:function()
+{this._linkifier.reset();},isFilteredOut:function()
+{if(this._parentView._filteredOutRequests.get(this._request))
+return true;return!this._parentView._typeFilter(this._request);},_onClick:function()
+{if(!this._parentView._allowRequestSelection)
+this.select();},select:function()
+{this._parentView.dispatchEventToListeners(WebInspector.NetworkLogView.EventTypes.RequestSelected,this._request);WebInspector.DataGridNode.prototype.select.apply(this,arguments);WebInspector.notifications.dispatchEventToListeners(WebInspector.UserMetrics.UserAction,{action:WebInspector.UserMetrics.UserActionNames.NetworkRequestSelected,url:this._request.url});},_highlightMatchedSubstring:function(regexp)
+{var domChanges=[];var matchInfo=this._element.textContent.match(regexp);if(matchInfo)
+WebInspector.highlightSearchResult(this._nameCell,matchInfo.index,matchInfo[0].length,domChanges);return domChanges;},_openInNewTab:function()
+{InspectorFrontendHost.openInNewTab(this._request.url);},get selectable()
+{return this._parentView._allowRequestSelection&&!this.isFilteredOut();},_createDivInTD:function(columnIdentifier)
+{var td=this.createTD(columnIdentifier);var div=td.createChild("div");this._element.appendChild(td);return div;},_createTimelineBar:function(cell)
+{cell.className="network-graph-side";this._barAreaElement=document.createElement("div");this._barAreaElement.className="network-graph-bar-area";this._barAreaElement.request=this._request;cell.appendChild(this._barAreaElement);this._barLeftElement=document.createElement("div");this._barLeftElement.className="network-graph-bar waiting";this._barAreaElement.appendChild(this._barLeftElement);this._barRightElement=document.createElement("div");this._barRightElement.className="network-graph-bar";this._barAreaElement.appendChild(this._barRightElement);this._labelLeftElement=document.createElement("div");this._labelLeftElement.className="network-graph-label waiting";this._barAreaElement.appendChild(this._labelLeftElement);this._labelRightElement=document.createElement("div");this._labelRightElement.className="network-graph-label";this._barAreaElement.appendChild(this._labelRightElement);cell.addEventListener("mouseover",this._refreshLabelPositions.bind(this),false);},refreshRequest:function()
+{this._refreshNameCell();this._refreshMethodCell();this._refreshStatusCell();this._refreshSchemeCell();this._refreshDomainCell();this._refreshTypeCell();this._refreshInitiatorCell();this._refreshCookiesCell();this._refreshSetCookiesCell();this._refreshSizeCell();this._refreshTimeCell();var responseHeaderColumns=WebInspector.NetworkLogView._responseHeaderColumns;for(var i=0;i<responseHeaderColumns.length;++i)
+this._refreshResponseHeaderCell(responseHeaderColumns[i]);if(this._request.cached)
+this._timelineCell.addStyleClass("resource-cached");this._element.addStyleClass("network-item");this._element.enableStyleClass("network-error-row",this._request.failed||(this._request.statusCode>=400));this._updateElementStyleClasses(this._element);},_updateElementStyleClasses:function(element)
+{var typeClassName="network-type-"+this._request.type.name();if(!element.hasStyleClass(typeClassName)){element.removeMatchingStyleClasses("network-type-\\w+");element.addStyleClass(typeClassName);}},_refreshResponseHeaderCell:function(headerName)
+{var cell=this._responseHeaderCells[headerName];var value=this._request.responseHeaderValue(headerName);cell.setTextAndTitle(value?value:"");},_refreshNameCell:function()
+{this._nameCell.removeChildren();if(this._request.type===WebInspector.resourceTypes.Image){var previewImage=document.createElement("img");previewImage.className="image-network-icon-preview";this._request.populateImageSource(previewImage);var iconElement=document.createElement("div");iconElement.className="icon";iconElement.appendChild(previewImage);}else{var iconElement=document.createElement("img");iconElement.className="icon";}
+this._nameCell.appendChild(iconElement);this._nameCell.appendChild(document.createTextNode(this._request.name()));this._appendSubtitle(this._nameCell,this._request.path());this._nameCell.title=this._request.url;},_refreshMethodCell:function()
+{this._methodCell.setTextAndTitle(this._request.requestMethod);},_refreshStatusCell:function()
+{this._statusCell.removeChildren();if(this._request.failed){var failText=this._request.canceled?WebInspector.UIString("(canceled)"):WebInspector.UIString("(failed)");if(this._request.localizedFailDescription){this._statusCell.appendChild(document.createTextNode(failText));this._appendSubtitle(this._statusCell,this._request.localizedFailDescription);this._statusCell.title=failText+" "+this._request.localizedFailDescription;}else
+this._statusCell.setTextAndTitle(failText);this._statusCell.addStyleClass("network-dim-cell");return;}
+this._statusCell.removeStyleClass("network-dim-cell");if(this._request.statusCode){this._statusCell.appendChild(document.createTextNode(""+this._request.statusCode));this._appendSubtitle(this._statusCell,this._request.statusText);this._statusCell.title=this._request.statusCode+" "+this._request.statusText;if(this._request.cached)
+this._statusCell.addStyleClass("network-dim-cell");}else{if(!this._request.isHttpFamily()&&this._request.finished)
+this._statusCell.setTextAndTitle(WebInspector.UIString("Success"));else if(this._request.isPingRequest())
+this._statusCell.setTextAndTitle(WebInspector.UIString("(ping)"));else
+this._statusCell.setTextAndTitle(WebInspector.UIString("(pending)"));this._statusCell.addStyleClass("network-dim-cell");}},_refreshSchemeCell:function()
+{this._schemeCell.setTextAndTitle(this._request.scheme);},_refreshDomainCell:function()
+{this._typeCell.setTextAndTitle(this._request.domain);},_refreshTypeCell:function()
+{if(this._request.mimeType){this._typeCell.removeStyleClass("network-dim-cell");this._typeCell.setTextAndTitle(this._request.mimeType);}else if(this._request.isPingRequest()){this._typeCell.removeStyleClass("network-dim-cell");this._typeCell.setTextAndTitle(this._request.requestContentType()||"");}else{this._typeCell.addStyleClass("network-dim-cell");this._typeCell.setTextAndTitle(WebInspector.UIString("Pending"));}},_refreshInitiatorCell:function()
+{this._initiatorCell.removeChildren();this._initiatorCell.removeStyleClass("network-dim-cell");this._initiatorCell.removeStyleClass("network-script-initiated");delete this._initiatorCell.request;var request=this._request;var initiator=request.initiatorInfo();switch(initiator.type){case WebInspector.NetworkRequest.InitiatorType.Parser:this._initiatorCell.title=initiator.url+":"+initiator.lineNumber;this._initiatorCell.appendChild(WebInspector.linkifyResourceAsNode(initiator.url,initiator.lineNumber-1));this._appendSubtitle(this._initiatorCell,WebInspector.UIString("Parser"));break;case WebInspector.NetworkRequest.InitiatorType.Redirect:this._initiatorCell.title=initiator.url;this._initiatorCell.appendChild(WebInspector.linkifyRequestAsNode(request.redirectSource));this._appendSubtitle(this._initiatorCell,WebInspector.UIString("Redirect"));break;case WebInspector.NetworkRequest.InitiatorType.Script:var urlElement=this._linkifier.linkifyLocation(initiator.url,initiator.lineNumber-1,initiator.columnNumber-1);urlElement.title="";this._initiatorCell.appendChild(urlElement);this._appendSubtitle(this._initiatorCell,WebInspector.UIString("Script"));this._initiatorCell.addStyleClass("network-script-initiated");this._initiatorCell.request=request;break;default:this._initiatorCell.title="";this._initiatorCell.addStyleClass("network-dim-cell");this._initiatorCell.setTextAndTitle(WebInspector.UIString("Other"));}},_refreshCookiesCell:function()
+{var requestCookies=this._request.requestCookies;this._cookiesCell.setTextAndTitle(requestCookies?""+requestCookies.length:"");},_refreshSetCookiesCell:function()
+{var responseCookies=this._request.responseCookies;this._setCookiesCell.setTextAndTitle(responseCookies?""+responseCookies.length:"");},_refreshSizeCell:function()
+{if(this._request.cached){this._sizeCell.setTextAndTitle(WebInspector.UIString("(from cache)"));this._sizeCell.addStyleClass("network-dim-cell");}else{var resourceSize=Number.bytesToString(this._request.resourceSize);var transferSize=Number.bytesToString(this._request.transferSize);this._sizeCell.setTextAndTitle(transferSize);this._sizeCell.removeStyleClass("network-dim-cell");this._appendSubtitle(this._sizeCell,resourceSize);}},_refreshTimeCell:function()
+{if(this._request.duration>0){this._timeCell.removeStyleClass("network-dim-cell");this._timeCell.setTextAndTitle(Number.secondsToString(this._request.duration));this._appendSubtitle(this._timeCell,Number.secondsToString(this._request.latency));}else{this._timeCell.addStyleClass("network-dim-cell");this._timeCell.setTextAndTitle(WebInspector.UIString("Pending"));}},_appendSubtitle:function(cellElement,subtitleText)
+{var subtitleElement=document.createElement("div");subtitleElement.className="network-cell-subtitle";subtitleElement.textContent=subtitleText;cellElement.appendChild(subtitleElement);},refreshGraph:function(calculator)
+{var percentages=calculator.computeBarGraphPercentages(this._request);this._percentages=percentages;this._barAreaElement.removeStyleClass("hidden");this._updateElementStyleClasses(this._timelineCell);this._barLeftElement.style.setProperty("left",percentages.start+"%");this._barRightElement.style.setProperty("right",(100-percentages.end)+"%");this._barLeftElement.style.setProperty("right",(100-percentages.end)+"%");this._barRightElement.style.setProperty("left",percentages.middle+"%");var labels=calculator.computeBarGraphLabels(this._request);this._labelLeftElement.textContent=labels.left;this._labelRightElement.textContent=labels.right;var tooltip=(labels.tooltip||"");this._barLeftElement.title=tooltip;this._labelLeftElement.title=tooltip;this._labelRightElement.title=tooltip;this._barRightElement.title=tooltip;},_refreshLabelPositions:function()
+{if(!this._percentages)
+return;this._labelLeftElement.style.removeProperty("left");this._labelLeftElement.style.removeProperty("right");this._labelLeftElement.removeStyleClass("before");this._labelLeftElement.removeStyleClass("hidden");this._labelRightElement.style.removeProperty("left");this._labelRightElement.style.removeProperty("right");this._labelRightElement.removeStyleClass("after");this._labelRightElement.removeStyleClass("hidden");const labelPadding=10;const barRightElementOffsetWidth=this._barRightElement.offsetWidth;const barLeftElementOffsetWidth=this._barLeftElement.offsetWidth;if(this._barLeftElement){var leftBarWidth=barLeftElementOffsetWidth-labelPadding;var rightBarWidth=(barRightElementOffsetWidth-barLeftElementOffsetWidth)-labelPadding;}else{var leftBarWidth=(barLeftElementOffsetWidth-barRightElementOffsetWidth)-labelPadding;var rightBarWidth=barRightElementOffsetWidth-labelPadding;}
+const labelLeftElementOffsetWidth=this._labelLeftElement.offsetWidth;const labelRightElementOffsetWidth=this._labelRightElement.offsetWidth;const labelBefore=(labelLeftElementOffsetWidth>leftBarWidth);const labelAfter=(labelRightElementOffsetWidth>rightBarWidth);const graphElementOffsetWidth=this._timelineCell.offsetWidth;if(labelBefore&&(graphElementOffsetWidth*(this._percentages.start/100))<(labelLeftElementOffsetWidth+10))
+var leftHidden=true;if(labelAfter&&(graphElementOffsetWidth*((100-this._percentages.end)/100))<(labelRightElementOffsetWidth+10))
+var rightHidden=true;if(barLeftElementOffsetWidth==barRightElementOffsetWidth){if(labelBefore&&!labelAfter)
+leftHidden=true;else if(labelAfter&&!labelBefore)
+rightHidden=true;}
+if(labelBefore){if(leftHidden)
+this._labelLeftElement.addStyleClass("hidden");this._labelLeftElement.style.setProperty("right",(100-this._percentages.start)+"%");this._labelLeftElement.addStyleClass("before");}else{this._labelLeftElement.style.setProperty("left",this._percentages.start+"%");this._labelLeftElement.style.setProperty("right",(100-this._percentages.middle)+"%");}
+if(labelAfter){if(rightHidden)
+this._labelRightElement.addStyleClass("hidden");this._labelRightElement.style.setProperty("left",this._percentages.end+"%");this._labelRightElement.addStyleClass("after");}else{this._labelRightElement.style.setProperty("left",this._percentages.middle+"%");this._labelRightElement.style.setProperty("right",(100-this._percentages.end)+"%");}},__proto__:WebInspector.DataGridNode.prototype}
+WebInspector.NetworkLogView._trivialTypeFilter=function(request)
+{return true;}
+WebInspector.NetworkLogView._typeFilter=function(allowedTypes,request)
+{return request.type.name()in allowedTypes;}
+WebInspector.NetworkDataGridNode.NameComparator=function(a,b)
+{var aFileName=a._request.name();var bFileName=b._request.name();if(aFileName>bFileName)
+return 1;if(bFileName>aFileName)
+return-1;return 0;}
+WebInspector.NetworkDataGridNode.SizeComparator=function(a,b)
+{if(b._request.cached&&!a._request.cached)
+return 1;if(a._request.cached&&!b._request.cached)
+return-1;return a._request.transferSize-b._request.transferSize;}
+WebInspector.NetworkDataGridNode.InitiatorComparator=function(a,b)
+{var aInitiator=a._request.initiatorInfo();var bInitiator=b._request.initiatorInfo();if(aInitiator.type<bInitiator.type)
+return-1;if(aInitiator.type>bInitiator.type)
+return 1;if(aInitiator.source<bInitiator.source)
+return-1;if(aInitiator.source>bInitiator.source)
+return 1;if(aInitiator.lineNumber<bInitiator.lineNumber)
+return-1;if(aInitiator.lineNumber>bInitiator.lineNumber)
+return 1;if(aInitiator.columnNumber<bInitiator.columnNumber)
+return-1;if(aInitiator.columnNumber>bInitiator.columnNumber)
+return 1;return 0;}
+WebInspector.NetworkDataGridNode.RequestCookiesCountComparator=function(a,b)
+{var aScore=a._request.requestCookies?a._request.requestCookies.length:0;var bScore=b._request.requestCookies?b._request.requestCookies.length:0;return aScore-bScore;}
+WebInspector.NetworkDataGridNode.ResponseCookiesCountComparator=function(a,b)
+{var aScore=a._request.responseCookies?a._request.responseCookies.length:0;var bScore=b._request.responseCookies?b._request.responseCookies.length:0;return aScore-bScore;}
+WebInspector.NetworkDataGridNode.RequestPropertyComparator=function(propertyName,revert,a,b)
+{var aValue=a._request[propertyName];var bValue=b._request[propertyName];if(aValue>bValue)
+return revert?-1:1;if(bValue>aValue)
+return revert?1:-1;return 0;}
« no previous file with comments | « chrome_linux64/resources/inspector/LayersPanel.js ('k') | chrome_linux64/resources/inspector/ProfilesPanel.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698