WebInspector.ResourceView = function(resource)
{
WebInspector.View.call(this);
this.element.addStyleClass("resource-view");
this.resource = resource;
}
WebInspector.ResourceView.prototype = {
hasContent: function()
{
return false;
}
}
WebInspector.ResourceView.prototype.__proto__ = WebInspector.View.prototype;
WebInspector.ResourceView.createResourceView = function(resource)
{
switch (resource.category) {
case WebInspector.resourceCategories.documents:
case WebInspector.resourceCategories.scripts:
case WebInspector.resourceCategories.xhr:
case WebInspector.resourceCategories.stylesheets:
return new WebInspector.ResourceSourceFrame(resource);
case WebInspector.resourceCategories.images:
return new WebInspector.ImageView(resource);
case WebInspector.resourceCategories.fonts:
return new WebInspector.FontView(resource);
default:
return new WebInspector.ResourceView(resource);
}
}
WebInspector.ResourceView.resourceViewTypeMatchesResource = function(resource)
{
var resourceView = resource._resourceView;
switch (resource.category) {
case WebInspector.resourceCategories.documents:
case WebInspector.resourceCategories.scripts:
case WebInspector.resourceCategories.xhr:
case WebInspector.resourceCategories.stylesheets:
return resourceView.__proto__ === WebInspector.ResourceSourceFrame.prototype;
case WebInspector.resourceCategories.images:
return resourceView.__proto__ === WebInspector.ImageView.prototype;
case WebInspector.resourceCategories.fonts:
return resourceView.__proto__ === WebInspector.FontView.prototype;
default:
return resourceView.__proto__ === WebInspector.ResourceView.prototype;
}
}
WebInspector.ResourceView.resourceViewForResource = function(resource)
{
if (!resource)
return null;
if (!resource._resourceView)
resource._resourceView = WebInspector.ResourceView.createResourceView(resource);
return resource._resourceView;
}
WebInspector.ResourceView.recreateResourceView = function(resource)
{
var newView = WebInspector.ResourceView.createResourceView(resource);
var oldView = resource._resourceView;
var oldViewParentNode = oldView.visible ? oldView.element.parentNode : null;
var scrollTop = oldView.scrollTop;
resource._resourceView.detach();
delete resource._resourceView;
resource._resourceView = newView;
if (oldViewParentNode)
newView.show(oldViewParentNode);
if (scrollTop)
newView.scrollTop = scrollTop;
return newView;
}
WebInspector.ResourceView.existingResourceViewForResource = function(resource)
{
if (!resource)
return null;
return resource._resourceView;
}
WebInspector.ResourceSourceFrame = function(resource)
{
WebInspector.SourceFrame.call(this, new WebInspector.SourceFrameDelegate(), resource.url);
this._resource = resource;
}
WebInspector.ResourceSourceFrame.DefaultMIMETypeForResourceType = {
0: "text/html",
1: "text/css",
4: "text/javascript"
}
WebInspector.ResourceSourceFrame.prototype = {
get resource()
{
return this._resource;
},
doubleClick: function(lineNumber)
{
if (!this._resource.isEditable())
return;
if (this._commitEditingInProgress)
return;
this._textViewer.readOnly = false;
WebInspector.markBeingEdited(this._textViewer.element, true);
},
editContent: function(newText, callback)
{
this._clearIncrementalUpdateTimer();
var majorChange = true;
this._resource.setContent(newText, majorChange, callback);
},
cancelEditing: function()
{
this._clearIncrementalUpdateTimer();
const majorChange = false;
this._resource.setContent(this._viewerState.textModelContent, majorChange);
WebInspector.SourceFrame.prototype.cancelEditing.call(this);
},
afterTextChanged: function(oldRange, newRange)
{
function commitIncrementalEdit()
{
var majorChange = false;
this._resource.setContent(this._textModel.text, majorChange, function() {});
}
const updateTimeout = 200;
this._incrementalUpdateTimer = setTimeout(commitIncrementalEdit.bind(this), updateTimeout);
},
_clearIncrementalUpdateTimer: function()
{
if (this._incrementalUpdateTimer)
clearTimeout(this._incrementalUpdateTimer);
delete this._incrementalUpdateTimer;
},
requestContent: function(callback)
{
function contentLoaded(text)
{
var mimeType = WebInspector.ResourceSourceFrame.DefaultMIMETypeForResourceType[this._resource.type] || this._resource.mimeType;
callback(mimeType, text);
}
this._resource.requestContent(contentLoaded.bind(this));
},
suggestedFileName: function()
{
return this._resource.displayName;
}
}
WebInspector.ResourceSourceFrame.prototype.__proto__ = WebInspector.SourceFrame.prototype;
WebInspector.RevisionSourceFrame = function(revision)
{
WebInspector.SourceFrame.call(this, new WebInspector.SourceFrameDelegate(), revision.resource.url);
this._revision = revision;
}
WebInspector.RevisionSourceFrame.prototype = {
get resource()
{
return this._revision.resource;
},
doubleClick: function(lineNumber)
{
},
requestContent: function(callback)
{
function contentLoaded(text)
{
var mimeType = WebInspector.ResourceSourceFrame.DefaultMIMETypeForResourceType[this._revision.resource.type] || this._revision.resource.mimeType;
callback(mimeType, text);
}
this._revision.requestContent(contentLoaded.bind(this));
},
suggestedFileName: function()
{
return this._revision.resource.displayName;
}
}
WebInspector.RevisionSourceFrame.prototype.__proto__ = WebInspector.SourceFrame.prototype;