Browse Source

Version 0.9.1 release

main
Levi Olson 4 years ago
parent
commit
90bf79d23d
16 changed files with 309 additions and 256 deletions
  1. BIN
      BNPforChromeLogo.png
  2. BIN
      BNPforChromeScreenshot1.png
  3. BIN
      assets/large-promo-tile.png
  4. BIN
      assets/marquee-promo-tile.png
  5. +0
    -0
      assets/screenshot.png
  6. BIN
      assets/small-promo-tile.png
  7. BIN
      assets/store-icon.png
  8. +1
    -1
      unpacked/devtools.js
  9. BIN
      unpacked/icon-128x128-shadow.png
  10. BIN
      unpacked/icon-128x128.png
  11. BIN
      unpacked/icon-128x128.xcf
  12. +1
    -1
      unpacked/manifest.json
  13. +117
    -66
      unpacked/panel/assets/javascripts/app.js
  14. +155
    -177
      unpacked/panel/assets/javascripts/panel.js
  15. +2
    -2
      unpacked/panel/assets/stylesheets/panel.css
  16. +33
    -9
      unpacked/panel/panel.html

BIN
BNPforChromeLogo.png View File

Before After
Width: 440  |  Height: 280  |  Size: 5.6 KiB

BIN
BNPforChromeScreenshot1.png View File

Before After
Width: 1280  |  Height: 800  |  Size: 186 KiB

BIN
assets/large-promo-tile.png View File

Before After
Width: 920  |  Height: 680  |  Size: 409 KiB

BIN
assets/marquee-promo-tile.png View File

Before After
Width: 1400  |  Height: 560  |  Size: 400 KiB

BNPforChromeScreenshot Original.png → assets/screenshot.png View File


BIN
assets/small-promo-tile.png View File

Before After
Width: 440  |  Height: 280  |  Size: 85 KiB

BIN
assets/store-icon.png View File

Before After
Width: 128  |  Height: 128  |  Size: 11 KiB

+ 1
- 1
unpacked/devtools.js View File

@ -1,6 +1,6 @@
chrome.devtools.panels.create( chrome.devtools.panels.create(
'Better Network Panel', 'Better Network Panel',
'panel/assets/images/SAMLforChromeLogoSquare.png',
'panel/assets/images/store-icon.png',
'panel/panel.html', 'panel/panel.html',
null // no callback null // no callback
); );

BIN
unpacked/icon-128x128-shadow.png View File

Before After
Width: 128  |  Height: 128  |  Size: 24 KiB

BIN
unpacked/icon-128x128.png View File

Before After
Width: 128  |  Height: 128  |  Size: 22 KiB Width: 128  |  Height: 128  |  Size: 11 KiB

BIN
unpacked/icon-128x128.xcf View File


+ 1
- 1
unpacked/manifest.json View File

@ -1,6 +1,6 @@
{ {
"name": "Better Network Panel", "name": "Better Network Panel",
"version": "0.0.6",
"version": "0.9.1",
"minimum_chrome_version": "44.0", "minimum_chrome_version": "44.0",
"description": "Extends the Developer Tools, adding a new Network Panel in the Developer Tools window with better searching and response previews.", "description": "Extends the Developer Tools, adding a new Network Panel in the Developer Tools window with better searching and response previews.",
"devtools_page": "devtools.html", "devtools_page": "devtools.html",

+ 117
- 66
unpacked/panel/assets/javascripts/app.js View File

@ -1,77 +1,128 @@
var BNPChrome = angular.module('BNPChrome', [])
.directive('prettyPrint', function ($parse) {
return {
restrict: 'E',
replace: true,
transclude: false,
scope: { data: '=data' },
link: function (scope, element, attrs) {
let data = scope.data;
let $el = $('<div></div>');
var BNPChrome = angular
.module("BNPChrome", [])
.factory("parse", function () {
const parser = function (input, level, depthOverride) {
const depth = depthOverride || 3;
if (level > depth) return input;
if (data === true) {
data = '<i>true</i>';
} else if (data === false) {
data = '<i>false</i>';
} else if (data === undefined) {
data = '<i>undefined</i>';
} else if (data === null) {
data = '<i>null</i>';
} else if (typeof data === 'number') {
// skip (i.e. do default)
} else if (typeof data === 'string' && (data[0] === '{' || data[0] === '[')) {
$el = $('<pre></pre>');
try {
data = JSON.stringify(JSON.parse(data), null, 4);
// $el.text()
} catch (e) {
console.debug('Error parsing', data);
}
} else if (typeof data === 'string') {
// i.e. a string but not a JSON stringified string
data = $('<div>').text(data).html();
}
if (!input || typeof input === "number" || typeof input === "boolean") {
return input;
}
if (Array.isArray(input)) {
// loop and parse each node
for (var i = 0; i < input.length; i++) {
input[i] = parser(input[i], level ? level + 1 : 1, depth);
}
return input;
}
$el.html(data);
if (typeof input === "string") {
try {
input = parser(JSON.parse(input), level ? level + 1 : 1, depth);
return input;
} catch (e) {
// not a stringified node
return input;
}
} else if (typeof input === "object") {
Object.keys(input).forEach(function (item) {
input[item] = parser(input[item], level ? level + 1 : 1, depth);
return item;
});
} else {
// unless there is a datatype I'm not checking for....
// console.log('shouldnt get here')
}
element.replaceWith($el);
}
};
})
.directive('resizableColumns', function ($parse) {
return {
link: function (scope, element, attrs) {
const options = {minWidth: 5};
return input;
};
if ($(element).data('resizable-columns-sync')) {
var $target = $($(element).data('resizable-columns-sync'));
return parser;
})
.directive("prettyPrint", function (parse) {
return {
restrict: "E",
replace: true,
transclude: false,
scope: { data: "=data" },
link: function (scope, element, attrs) {
let data = scope.data;
let $el = $("<div></div>");
$(element).on('column:resize', function(event, resizable, $leftColumn, $rightColumn, widthLeft, widthRight)
{
var leftColumnIndex = resizable.$table.find('.rc-column-resizing').parent().find('td, th').index($leftColumn);
if (data === true) {
data = "<i>true</i>";
} else if (data === false) {
data = "<i>false</i>";
} else if (data === undefined) {
data = "<i>undefined</i>";
} else if (data === null) {
data = "<i>null</i>";
} else if (typeof data === "number") {
// skip (i.e. do default)
} else if (typeof data === "string" && (data[0] === "{" || data[0] === "[")) {
$el = $("<pre></pre>");
data = JSON.stringify(parse(data, 0), null, 4);
// try {
// data = JSON.stringify(JSON.parse(data), null, 4);
// // $el.text()
// } catch (e) {
// console.debug("Error parsing", data);
// }
} else if (typeof data === "string") {
// i.e. a string but not a JSON stringified string
data = $("<div>").text(data).html();
}
var $targetFirstRow = $target.find('tr:first');
$el.html(data);
$($targetFirstRow.find('td, th').get(leftColumnIndex)).css('width', widthLeft + '%');
$($targetFirstRow.find('td, th').get(leftColumnIndex + 1)).css('width', widthRight + '%');
element.replaceWith($el);
}
};
})
.directive("resizableColumns", function ($parse) {
return {
link: function (scope, element, attrs) {
const options = { minWidth: 5 };
$target.data('resizableColumns').syncHandleWidths();
$target.data('resizableColumns').saveColumnWidths();
});
}
if ($(element).data("resizable-columns-sync")) {
var $target = $($(element).data("resizable-columns-sync"));
$(element).resizableColumns(options);
}
};
})
.directive('scrollToNew', function ($parse) {
return function(scope, element, attrs) {
if (scope.showIncomingRequests && scope.$last) {
const $container = $(element).parents('.data-container').first();
const $parent = $(element).parent();
$(element).on("column:resize", function (
event,
resizable,
$leftColumn,
$rightColumn,
widthLeft,
widthRight
) {
var leftColumnIndex = resizable.$table
.find(".rc-column-resizing")
.parent()
.find("td, th")
.index($leftColumn);
$container.scrollTop($parent.height());
}
};
});
var $targetFirstRow = $target.find("tr:first");
$($targetFirstRow.find("td, th").get(leftColumnIndex)).css("width", widthLeft + "%");
$($targetFirstRow.find("td, th").get(leftColumnIndex + 1)).css("width", widthRight + "%");
$target.data("resizableColumns").syncHandleWidths();
$target.data("resizableColumns").saveColumnWidths();
});
}
$(element).resizableColumns(options);
}
};
})
.directive("scrollToNew", function ($parse) {
return function (scope, element, attrs) {
if (scope.showIncomingRequests && scope.$last) {
const $container = $(element).parents(".data-container").first();
const $parent = $(element).parent();
$container.scrollTop($parent.height());
}
};
});

+ 155
- 177
unpacked/panel/assets/javascripts/panel.js View File

@ -1,4 +1,3 @@
function Console() {} function Console() {}
Console.Type = { Console.Type = {
@ -12,7 +11,7 @@ Console.Type = {
GROUP_END: "groupEnd" GROUP_END: "groupEnd"
}; };
Console.addMessage = function(type, format, args) {
Console.addMessage = function (type, format, args) {
chrome.runtime.sendMessage({ chrome.runtime.sendMessage({
command: "sendToConsole", command: "sendToConsole",
tabId: chrome.devtools.inspectedWindow.tabId, tabId: chrome.devtools.inspectedWindow.tabId,
@ -21,7 +20,7 @@ Console.addMessage = function(type, format, args) {
}; };
// Generate Console output methods, i.e. Console.log(), Console.debug() etc. // Generate Console output methods, i.e. Console.log(), Console.debug() etc.
(function() {
(function () {
var console_types = Object.getOwnPropertyNames(Console.Type); var console_types = Object.getOwnPropertyNames(Console.Type);
for (var type = 0; type < console_types.length; ++type) { for (var type = 0; type < console_types.length; ++type) {
var method_name = Console.Type[console_types[type]]; var method_name = Console.Type[console_types[type]];
@ -29,9 +28,7 @@ Console.addMessage = function(type, format, args) {
} }
})(); })();
BNPChrome.controller('PanelController', function PanelController($scope, $http, toolbar) {
BNPChrome.controller("PanelController", function PanelController($scope, toolbar, parse) {
$scope.uniqueid = 1000000; $scope.uniqueid = 1000000;
$scope.activeId = null; $scope.activeId = null;
$scope.requests = {}; $scope.requests = {};
@ -39,10 +36,10 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
$scope.filteredRequests = []; $scope.filteredRequests = [];
$scope.showAll = true; $scope.showAll = true;
$scope.limitNetworkRequests = true; $scope.limitNetworkRequests = true;
$scope.showOriginal = true;
$scope.currentDetailTab = "tab-code";
$scope.showOriginal = false;
$scope.currentDetailTab = "tab-response";
$scope.myCodeMirror = null;
$scope.myResponseCodeMirror = null;
$scope.activeCookies = []; $scope.activeCookies = [];
$scope.activeHeaders = []; $scope.activeHeaders = [];
@ -57,22 +54,16 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
$scope.showIncomingRequests = true; $scope.showIncomingRequests = true;
$scope.init = function(type) {
$('#tabs').tabs();
$scope.init = function (type) {
$("#tabs").tabs();
$scope.initChrome(); $scope.initChrome();
this.createToolbar(); this.createToolbar();
}; };
$scope.initChrome = function() {
key('⌘+k, ctrl+l', function() {
$scope.$apply(function() {
$scope.clear();
});
});
chrome.devtools.network.onRequestFinished.addListener(function(request) {
$scope.initChrome = function () {
chrome.devtools.network.onRequestFinished.addListener(function (request) {
// do not show requests to chrome extension resources // do not show requests to chrome extension resources
if (request.request.url.startsWith("chrome-extension://")) { if (request.request.url.startsWith("chrome-extension://")) {
return; return;
@ -81,100 +72,110 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
}); });
}; };
$scope.filterRequests = function() {
// console.debug('Search Filter: ', $scope.filter, $scope.filteredRequests.length, $scope.masterRequests.length);
// console.debug("Request", $scope.masterRequests[0]);
// console.debug('Requests', $scope.requests);
$scope.filteredRequests = $scope.masterRequests.filter(function(x) {
if (!$scope.filter) return true;
if (x && JSON.stringify(x).toLowerCase().includes($scope.filter.toLowerCase())) return true;
});
}
$scope.filterRequests = function () {
const searchString = $scope.filter.toLowerCase();
if (!searchString) $scope.filteredRequests = $scope.masterRequests;
$scope.handleRequest = function(har_entry) {
const request_method = har_entry.request.method;
const request_url = har_entry.request.url;
const response_status = har_entry.response.status;
$scope.filteredRequests = $scope.masterRequests.filter(function (x) {
if (x && x.searchIndex && x.searchIndex.includes(searchString)) return true;
});
};
$scope.addRequest(har_entry, request_method, request_url, response_status, null);
$scope.handleRequest = function (har_entry) {
$scope.addRequest(har_entry, har_entry.request.method, har_entry.request.url, har_entry.response.status, null);
}; };
$scope.createToolbar = function() {
toolbar.createButton('search', 'Search Code', false, function() {
$scope.createToolbar = function () {
toolbar.createButton("search", "Search Code", false, function () {
// ga('send', 'event', 'button', 'click', 'Search Code'); // ga('send', 'event', 'button', 'click', 'Search Code');
$scope.$apply(function() {
if ($scope.myCodeMirror) {
$scope.myCodeMirror.execCommand("find");
$scope.$apply(function () {
if ($scope.myResponseCodeMirror) {
$scope.myResponseCodeMirror.execCommand("find");
} }
}); });
}); });
toolbar.createToggleButton('embed', 'JSON Parsing', false, function() {
// ga('send', 'event', 'button', 'click', 'Toggle JSON Parsing');
$scope.$apply(function() {
$scope.showOriginal = !$scope.showOriginal;
$scope.displayCode();
});
}, false);
toolbar.createButton('download3', 'Download', false, function() {
toolbar.createToggleButton(
"embed",
"JSON Parsing",
false,
function () {
// ga('send', 'event', 'button', 'click', 'Toggle JSON Parsing');
$scope.$apply(function () {
$scope.showOriginal = !$scope.showOriginal;
$scope.selectDetailTab($scope.currentDetailTab);
// $scope.displayCode();
});
},
true
);
toolbar.createButton("download3", "Download", false, function () {
// ga('send', 'event', 'button', 'click', 'Download'); // ga('send', 'event', 'button', 'click', 'Download');
$scope.$apply(function() {
var blob = new Blob([JSON.stringify($scope.requests)], {type: "application/json;charset=utf-8"});
$scope.$apply(function () {
var blob = new Blob([JSON.stringify($scope.requests)], { type: "application/json;charset=utf-8" });
saveAs(blob, "BNPChromeExport.json"); saveAs(blob, "BNPChromeExport.json");
}); });
}); });
toolbar.createButton('upload3', 'Import', true, function() {
toolbar.createButton("upload3", "Import", true, function () {
// ga('send', 'event', 'button', 'click', 'Import'); // ga('send', 'event', 'button', 'click', 'Import');
$scope.$apply(function() {
$('#ImportInput').click();
$scope.$apply(function () {
$("#ImportInput").click();
}); });
}); });
toolbar.createToggleButton('meter', 'Limit network requests to 500', false, function() {
// ga('send', 'event', 'button', 'click', 'Toggle Limit Network Request');
$scope.$apply(function() {
$scope.limitNetworkRequests = !$scope.limitNetworkRequests;
});
}, true);
toolbar.createButton('blocked', 'Clear', false, function() {
toolbar.createToggleButton(
"meter",
"Limit network requests to 500",
false,
function () {
// ga('send', 'event', 'button', 'click', 'Toggle Limit Network Request');
$scope.$apply(function () {
$scope.limitNetworkRequests = !$scope.limitNetworkRequests;
});
},
true
);
toolbar.createButton("blocked", "Clear", false, function () {
// ga('send', 'event', 'button', 'click', 'Clear'); // ga('send', 'event', 'button', 'click', 'Clear');
$scope.$apply(function() {
$scope.$apply(function () {
$scope.clear(); $scope.clear();
}); });
}); });
$('.toolbar').replaceWith(toolbar.render());
$(".toolbar").replaceWith(toolbar.render());
//clears the input value so you can reload the same file //clears the input value so you can reload the same file
document.getElementById('ImportInput').addEventListener('click', function() {this.value=null;}, false);
document.getElementById('ImportInput').addEventListener('change', readFile, false);
function readFile (evt) {
document.getElementById("ImportInput").addEventListener(
"click",
function () {
this.value = null;
},
false
);
document.getElementById("ImportInput").addEventListener("change", readFile, false);
function readFile(evt) {
const files = evt.target.files; const files = evt.target.files;
const file = files[0]; const file = files[0];
const reader = new FileReader(); const reader = new FileReader();
reader.onload = function() {
reader.onload = function () {
$scope.importFile(this.result); $scope.importFile(this.result);
}
reader.readAsText(file)
};
reader.readAsText(file);
} }
}; };
$scope.importFile = function(data) {
$scope.$apply(function() {
$scope.importFile = function (data) {
$scope.$apply(function () {
const importHar = JSON.parse(data); const importHar = JSON.parse(data);
for (i in importHar)
{
for (i in importHar) {
$scope.handleRequest(importHar[i]); $scope.handleRequest(importHar[i]);
} }
}); });
}
$scope.addRequest = function(data, request_method, request_url, response_status) {
};
$scope.$apply(function() {
$scope.addRequest = function (data, request_method, request_url, response_status) {
$scope.$apply(function () {
const requestId = $scope.uniqueid; const requestId = $scope.uniqueid;
$scope.uniqueid = $scope.uniqueid + 1; $scope.uniqueid = $scope.uniqueid + 1;
if (data.request != null) { if (data.request != null) {
data["request_data"] = $scope.createKeypairs(data.request); data["request_data"] = $scope.createKeypairs(data.request);
if (data.request.cookies != null) { if (data.request.cookies != null) {
@ -194,29 +195,41 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
data["response_cookies"] = $scope.createKeypairsDeep(data.response.cookies); data["response_cookies"] = $scope.createKeypairsDeep(data.response.cookies);
} }
if (data.response.headers != null) { if (data.response.headers != null) {
data["response_headers"] = $scope.createKeypairsDeep(data.response.headers);
data["response_headers"] = $scope.createKeypairsDeep(data.response.headers);
} }
} }
data["request_method"] = request_method; data["request_method"] = request_method;
if (request_url.includes('apexremote')) {
if (request_url.includes("apexremote")) {
try { try {
let text = (data && data.request && data.request.postData && data.request.postData.text) ? JSON.parse(data.request.postData.text) : '';
data["request_apex_type"] = (text.data && typeof text.data[1] === 'string') ? text.data[1] : JSON.stringify(text.data);
data["request_apex_method"] = text.method || '';
} catch (e) {console.debug('Error', e)}
let text =
data && data.request && data.request.postData && data.request.postData.text
? JSON.parse(data.request.postData.text)
: "";
data["request_apex_type"] =
text.data && typeof text.data[1] === "string" ? text.data[1] : JSON.stringify(text.data);
data["request_apex_method"] = text.method || "";
} catch (e) {
console.debug("Error", e);
}
} }
data["request_url"] = request_url; data["request_url"] = request_url;
data["response_status"] = response_status; data["response_status"] = response_status;
data["id"] = requestId; data["id"] = requestId;
$scope.requests[requestId] = data; // master $scope.requests[requestId] = data; // master
data.searchIndex = JSON.stringify(data).toLowerCase();
// console.debug('SearchIndex', data.searchIndex)
$scope.masterRequests.push(data); $scope.masterRequests.push(data);
$scope.filteredRequests.push(data); $scope.filteredRequests.push(data);
data.getContent(function (content, encoding) { data.getContent(function (content, encoding) {
try { try {
$scope.requests[requestId].response_data.response_body = JSON.stringify(JSON.parse(content), null, 4);
$scope.requests[requestId].response_data.response_body = JSON.stringify(
JSON.parse(content),
null,
4
);
} catch (e) {} } catch (e) {}
}); });
@ -224,20 +237,20 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
}); });
}; };
$scope.cleanRequests = function() {
$scope.cleanRequests = function () {
if ($scope.limitNetworkRequests === true) { if ($scope.limitNetworkRequests === true) {
if ($scope.masterRequests.length >= 500 ) $scope.masterRequests.shift();
if ($scope.masterRequests.length >= 500) $scope.masterRequests.shift();
const keys = Object.keys($scope.requests).reverse().slice(500); const keys = Object.keys($scope.requests).reverse().slice(500);
keys.forEach(function(key) {
keys.forEach(function (key) {
if ($scope.requests[key]) { if ($scope.requests[key]) {
delete $scope.requests[key]; delete $scope.requests[key];
} }
}); });
} }
$scope.filterRequests(); $scope.filterRequests();
}
};
$scope.clear = function() {
$scope.clear = function () {
$scope.requests = {}; $scope.requests = {};
$scope.activeId = null; $scope.activeId = null;
$scope.masterRequests = []; $scope.masterRequests = [];
@ -254,11 +267,9 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
$scope.activeCode = null; $scope.activeCode = null;
$scope.showIncomingRequests = true; $scope.showIncomingRequests = true;
document.getElementById("tab-code-codemirror").style.visibility = "hidden";
}; };
$scope.setActive = function(requestId) {
$scope.setActive = function (requestId) {
if (!$scope.requests[requestId]) { if (!$scope.requests[requestId]) {
return; return;
} }
@ -275,21 +286,21 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
$scope.activeCode = $scope.requests[requestId].response_data.response_body; $scope.activeCode = $scope.requests[requestId].response_data.response_body;
}; };
$scope.getClass = function(requestId) {
$scope.getClass = function (requestId) {
if (requestId === $scope.activeId) { if (requestId === $scope.activeId) {
return 'selected';
return "selected";
} else { } else {
return '';
return "";
} }
}; };
$scope.createKeypairs = function(data) {
$scope.createKeypairs = function (data) {
let keypairs = []; let keypairs = [];
if (!(data instanceof Object)) { if (!(data instanceof Object)) {
return keypairs; return keypairs;
} }
$.each(data, function(key, value) {
$.each(data, function (key, value) {
if (!(value instanceof Object)) { if (!(value instanceof Object)) {
keypairs.push({ keypairs.push({
name: key, name: key,
@ -301,14 +312,14 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
return keypairs; return keypairs;
}; };
$scope.createKeypairsDeep = function(data) {
$scope.createKeypairsDeep = function (data) {
let keypairs = []; let keypairs = [];
if (!(data instanceof Object)) { if (!(data instanceof Object)) {
return keypairs; return keypairs;
} }
$.each(data, function(key, value) {
$.each(data, function (key, value) {
keypairs.push({ keypairs.push({
name: value.name, name: value.name,
value: value.value value: value.value
@ -318,38 +329,56 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
return keypairs; return keypairs;
}; };
$scope.$watch('activeCode', function() {
$scope.displayCode();
$scope.$watch("activeCode", function (newVal, oldVal) {
$scope.displayCode("tab-response-codemirror", $scope.activeCode, "myResponseCodeMirror", 3);
$scope.displayCode("tab-request-codemirror", $scope.flatten($scope.activePostData), "myRequestCodeMirror", 6);
}); });
$scope.selectDetailTab = function(tabId) {
$scope.selectDetailTab = function (tabId, external) {
$scope.currentDetailTab = tabId; $scope.currentDetailTab = tabId;
if (tabId === "tab-code") {
$scope.displayCode();
if (external) {
$("#tabs a[href='#" + tabId + "']").trigger("click");
} }
}
if (tabId === "tab-response")
$scope.displayCode("tab-response-codemirror", $scope.activeCode, "myResponseCodeMirror", 3);
if (tabId === "tab-request")
$scope.displayCode(
"tab-request-codemirror",
$scope.flatten($scope.activePostData),
"myRequestCodeMirror",
6
);
};
$scope.flatten = function (input) {
if (input && typeof input === "object")
return input.map(function (x) {
var tmp = {};
tmp[x.name] = x.value;
return tmp;
});
};
$scope.displayCode = function() {
if ($scope.activeCode != null) {
document.getElementById("tab-code-codemirror").style.visibility = "visible";
$scope.displayCode = function (elementId, input, scopeVar, depth) {
if (input != null) {
document.getElementById(elementId).style.visibility = "visible";
let content = $scope.activeCode;
// if (!$scope.showOriginal) {
// content = $scope.getPretty(content);
// } else {
content = JSON.stringify($scope.parse(content), null, 4);
// }
let content;
if ($scope.showOriginal) {
content = JSON.stringify(parse(input, 0, 1), null, 4);
} else {
content = JSON.stringify(parse(input, 0, depth), null, 4);
}
if ($scope.myCodeMirror) {
$scope.myCodeMirror.getDoc().setValue(content);
if ($scope[scopeVar]) {
$scope[scopeVar].getDoc().setValue(content);
$scope.myCodeMirror.refresh();
$scope[scopeVar].refresh();
return; return;
} }
document.getElementById("tab-code-codemirror").innerHTML = "";
const myCodeMirror = CodeMirror(document.getElementById("tab-code-codemirror"), {
document.getElementById(elementId).innerHTML = "";
const codeMirror = CodeMirror(document.getElementById(elementId), {
value: content, value: content,
mode: "application/json", mode: "application/json",
theme: "neat", theme: "neat",
@ -359,75 +388,24 @@ BNPChrome.controller('PanelController', function PanelController($scope, $http,
foldGutter: true, foldGutter: true,
gutters: ["CodeMirror-linenumbers", "CodeMirror-foldgutter"] gutters: ["CodeMirror-linenumbers", "CodeMirror-foldgutter"]
}); });
myCodeMirror.setOption("extraKeys", {
"Ctrl-F": function(cm) {
cm.execCommand('findPersistent');
},
"Ctrl-G": function(cm) {
cm.execCommand('findPersistentNext');
},
"Shift-Ctrl-G": function(cm) {
cm.execCommand('findPersistentPrev');
}
});
$scope.myCodeMirror = myCodeMirror;
$scope[scopeVar] = codeMirror;
} }
}
};
$scope.getPretty = function(source) {
let code = $scope.parse(source);
$scope.getPretty = function (source) {
let code = JSON.stringify(parse(source, 0, 1), null, 4);
return code;
const options = { const options = {
source: code, source: code,
mode: "beautify", // beautify, diff, minify, parse mode: "beautify", // beautify, diff, minify, parse
lang: "auto", lang: "auto",
inchar: " ", // indent character
inchar: " " // indent character
}; };
const pd = prettydiff(options); // returns and array: [beautified, report] const pd = prettydiff(options); // returns and array: [beautified, report]
const pretty = pd[0]; const pretty = pd[0];
return pretty; return pretty;
}
$scope.parse = function(input) {
try {
// console.warn('Parse Type', typeof input);
if (typeof input === 'boolean') return input;
if (typeof input === 'number') return input;
if (!input) return input;
if (typeof input === 'string') {
// if string, try to parse
// returns the original string if this fails
input = JSON.parse(input);
// console.debug('Parse String', input);
return $scope.parse(input);
}
if (Array.isArray(input)) {
for (let i = 0; i < input.length; i++) {
// console.debug('Parse Inner Array', i, input[i]);
input[i] = $scope.parse(input[i]);
}
}
if (typeof input === 'object') {
// console.debug('Parse Object', input);
Object.entries(input).forEach(function([key, value]) {
// console.debug('Parse Inner Object', key, value);
if (key === "result")
input[key] = $scope.parse(value);
})
}
} catch (e) {
// console.info('Error parsing', e, typeof input, input)
// console.debug('Parse String Failed', input);
return input
}
// console.debug('Returning', input);
return input;
}
};
}); });

+ 2
- 2
unpacked/panel/assets/stylesheets/panel.css View File

@ -340,8 +340,8 @@ th, td {
padding: 0px; padding: 0px;
position: relative; position: relative;
} }
#tab-request,
#tab-response {
#tab-request-stats,
#tab-response-stats {
padding: 10px; padding: 10px;
} }

+ 33
- 9
unpacked/panel/panel.html View File

@ -116,13 +116,22 @@
<div class="tabbed-pane-header-contents"> <div class="tabbed-pane-header-contents">
<ul class="tabbed-pane-header-tabs"> <ul class="tabbed-pane-header-tabs">
<li class="tabbed-pane-header-tab"> <li class="tabbed-pane-header-tab">
<a href="#tab-code" class="tabbed-pane-header-tab-title" ng-click="selectDetailTab('tab-code')">Preview</a>
<a href="#tab-response" class="tabbed-pane-header-tab-title" ng-click="selectDetailTab('tab-response')">
<span ng-show="showOriginal">Raw</span>
<span ng-hide="showOriginal">Formatted</span>
Response</a>
</li> </li>
<li class="tabbed-pane-header-tab"> <li class="tabbed-pane-header-tab">
<a href="#tab-request" class="tabbed-pane-header-tab-title" ng-click="selectDetailTab('tab-request')">Request</a>
<a href="#tab-request" class="tabbed-pane-header-tab-title" ng-click="selectDetailTab('tab-request')">
<span ng-show="showOriginal">Raw</span>
<span ng-hide="showOriginal">Formatted</span>
Request</a>
</li> </li>
<li class="tabbed-pane-header-tab"> <li class="tabbed-pane-header-tab">
<a href="#tab-response" class="tabbed-pane-header-tab-title" ng-click="selectDetailTab('tab-response')">Response</a>
<a href="#tab-request-stats" class="tabbed-pane-header-tab-title" ng-click="selectDetailTab('tab-request-stats')">Request</a>
</li>
<li class="tabbed-pane-header-tab">
<a href="#tab-response-stats" class="tabbed-pane-header-tab-title" ng-click="selectDetailTab('tab-response-stats')">Response</a>
</li> </li>
</ul> </ul>
</div> </div>
@ -133,15 +142,15 @@
<div class="tabbed-pane-content data-grid data-grid-details"> <div class="tabbed-pane-content data-grid data-grid-details">
<div id="tab-request">
<table id="postData" ng-show="activePostData.length">
<div id="tab-request-stats">
<table id="postData" ng-show="activePostData.length" title="Click to open Request preview tab">
<thead> <thead>
<tr> <tr>
<th colspan="2">Request POST Data</th> <th colspan="2">Request POST Data</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
<tr ng-repeat="param in activePostData">
<tr ng-repeat="param in activePostData" ng-click="selectDetailTab('tab-request', true)">
<td class="key">{{param.name}}</td> <td class="key">{{param.name}}</td>
<td><pretty-print data="param.value"/></td> <td><pretty-print data="param.value"/></td>
</tr> </tr>
@ -191,7 +200,7 @@
</table> </table>
</div> </div>
<div id="tab-response">
<div id="tab-response-stats">
<table id="response-data" ng-show="activeResponseData.length"> <table id="response-data" ng-show="activeResponseData.length">
<thead> <thead>
<tr> <tr>
@ -235,11 +244,26 @@
</div> </div>
<div id="tab-code">
<div id="tab-code-codemirror">
<div id="tab-response">
<div id="tab-response-codemirror">
</div>
</div>
<div id="tab-request">
<div id="tab-request-codemirror">
</div> </div>
</div> </div>
<!-- <div id="tab-raw-res">
<pre ng-show="activeCode">{{getPretty(activeCode)}}</pre>
<pre ng-hide="activeCode">loading...</pre>
</div>
<div id="tab-raw-req">
<pre ng-show="(activePostData | filter:{name:'text'}).length">{{activePostData | filter: {name:'text'} | json}}</pre>
<pre ng-hide="(activePostData | filter:{name:'text'}).length">loading...</pre>
</div> -->
</div> </div>
</div> </div>
</div> </div>

Loading…
Cancel
Save