NetworkItemView.js [plain text]
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
}