Browse Source

1.0.1 update

main
Levi Olson 1 year ago
parent
commit
1818b17165
5 changed files with 122 additions and 131 deletions
  1. +9
    -0
      unpacked/jsconfig.json
  2. +1
    -1
      unpacked/manifest.json
  3. +1
    -1
      unpacked/panel/assets/javascripts/app.js
  4. +103
    -121
      unpacked/panel/assets/javascripts/panel.js
  5. +8
    -8
      unpacked/panel/panel.html

+ 9
- 0
unpacked/jsconfig.json View File

@ -0,0 +1,9 @@
{
"compilerOptions": {
"module": "commonjs",
"target": "es6"
},
"exclude": [
"node_modules"
]
}

+ 1
- 1
unpacked/manifest.json View File

@ -1,6 +1,6 @@
{ {
"name": "Better Network Panel", "name": "Better Network Panel",
"version": "1.0.1",
"version": "1.0.2",
"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",

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

@ -118,7 +118,7 @@ var BNPChrome = angular
}) })
.directive("scrollToNew", function ($parse) { .directive("scrollToNew", function ($parse) {
return function (scope, element, attrs) { return function (scope, element, attrs) {
if (scope.showIncomingRequests && scope.$last) {
if (scope.scrollToNew && scope.$last) {
const $container = $(element).parents(".data-container").first(); const $container = $(element).parents(".data-container").first();
const $parent = $(element).parent(); const $parent = $(element).parent();

+ 103
- 121
unpacked/panel/assets/javascripts/panel.js View File

@ -1,40 +1,13 @@
function Console() {}
Console.Type = {
LOG: "log",
DEBUG: "debug",
INFO: "info",
WARN: "warn",
ERROR: "error",
GROUP: "group",
GROUP_COLLAPSED: "groupCollapsed",
GROUP_END: "groupEnd"
};
Console.addMessage = function (type, format, args) {
chrome.runtime.sendMessage({
command: "sendToConsole",
tabId: chrome.devtools.inspectedWindow.tabId,
args: escape(JSON.stringify(Array.prototype.slice.call(arguments, 0)))
});
};
// Generate Console output methods, i.e. Console.log(), Console.debug() etc.
(function () {
var console_types = Object.getOwnPropertyNames(Console.Type);
for (var type = 0; type < console_types.length; ++type) {
var method_name = Console.Type[console_types[type]];
Console[method_name] = Console.addMessage.bind(Console, method_name);
}
})();
BNPChrome.controller("PanelController", function PanelController($scope, toolbar, parse, $timeout) { BNPChrome.controller("PanelController", function PanelController($scope, toolbar, parse, $timeout) {
const LOCALSTORAGE = window.localStorage;
const MAXBODYSIZE = 20000;
const HOST = "https://leviolson.com" // "http://localhost:3000"
const LOCAL_STORAGE = window.localStorage;
const MAX_BODY_SIZE = 20000;
const HOST = "https://leviolson.com"; // "http://localhost:3000"
const CHANGELOG = { const CHANGELOG = {
"What's New": { "What's New": {
"v1.0.2:": {
"Added Settings": HOST + "/posts/bnp-changelog#added-settings"
},
"v1.0.1:": { "v1.0.1:": {
"Panel Settings": HOST + "/posts/bnp-changelog#panel-settings", "Panel Settings": HOST + "/posts/bnp-changelog#panel-settings",
"Bugs": "squashed" "Bugs": "squashed"
@ -46,12 +19,27 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
"Download JSON": HOST + "/posts/bnp-changelog#download-json" "Download JSON": HOST + "/posts/bnp-changelog#download-json"
} }
} }
}
};
const STORAGE_MAP = {
'autoJSONParseDepthRes': 3,
'autoJSONParseDepthReq': 6,
'clearOnRefresh': false,
'scrollToNew': true,
'andfilter': false,
'searchTerms': [],
'oldSearchTerms': [],
};
$scope.autoJSONParseDepthRes = STORAGE_MAP.autoJSONParseDepthRes;
$scope.autoJSONParseDepthReq = STORAGE_MAP.autoJSONParseDepthReq;
$scope.clearOnRefresh = STORAGE_MAP.clearOnRefresh;
$scope.scrollToNew = STORAGE_MAP.scrollToNew;
$scope.andFilter = STORAGE_MAP.andfilter;
$scope.searchTerms = STORAGE_MAP.searchTerms;
$scope.oldSearchTerms = STORAGE_MAP.oldSearchTerms;
$scope.search = ""; $scope.search = "";
$scope.searchTerms = [];
$scope.oldSearchTerms = [];
$scope.andFilter = true;
$scope.uniqueId = 100000; $scope.uniqueId = 100000;
$scope.activeId = null; $scope.activeId = null;
$scope.requests = {}; $scope.requests = {};
@ -61,9 +49,6 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
$scope.limitNetworkRequests = false; $scope.limitNetworkRequests = false;
$scope.showOriginal = false; $scope.showOriginal = false;
$scope.currentDetailTab = "tab-response"; $scope.currentDetailTab = "tab-response";
$scope.showIncomingRequests = true;
$scope.autoJSONParseDepthRes = 3;
$scope.autoJSONParseDepthReq = 6;
$scope.filter = ""; $scope.filter = "";
$scope.editor = null; $scope.editor = null;
@ -76,67 +61,64 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
$scope.activeResponseHeaders = []; $scope.activeResponseHeaders = [];
$scope.activeCode = null; $scope.activeCode = null;
$scope.init = function (type) {
$scope.init = function () {
$("#tabs").tabs(); $("#tabs").tabs();
$scope.initChrome();
_initChrome();
$scope.createToolbar();
_createToolbar();
const options = { const options = {
mode: 'view',
modes: ['code', 'view'],
mode: 'preview',
modes: ['code', 'view', 'preview'],
onEditable: function (node) { onEditable: function (node) {
if (!node.path) {
// In modes code and text, node is empty: no path, field, or value
// returning false makes the text area read-only
return false;
}
return true
if (!node.path) {
// In modes code and text, node is empty: no path, field, or value
// returning false makes the text area read-only
return false;
}
return true;
} }
}
const response = document.getElementById('response-jsoneditor')
const request = document.getElementById('request-jsoneditor')
$scope.responseJsonEditor = new JSONEditor(response, options)
$scope.requestJsonEditor = new JSONEditor(request, options)
};
const response = document.getElementById('response-jsoneditor');
const request = document.getElementById('request-jsoneditor');
$scope.responseJsonEditor = new JSONEditor(response, options);
$scope.requestJsonEditor = new JSONEditor(request, options);
$timeout(() => { $timeout(() => {
$scope.responseJsonEditor.set(CHANGELOG); $scope.responseJsonEditor.set(CHANGELOG);
$scope.responseJsonEditor.expandAll(); $scope.responseJsonEditor.expandAll();
})
});
}; };
$scope.initChrome = function () {
try {
let oldSearchTerms = JSON.parse(LOCALSTORAGE.getItem('bnp-oldsearchterms'));
$scope.oldSearchTerms = oldSearchTerms || [];
} catch (e) {
$scope.oldSearchTerms = [];
}
try {
let searchTerms = JSON.parse(LOCALSTORAGE.getItem('bnp-searchterms'));
$scope.searchTerms = searchTerms || [];
} catch (e) {
$scope.searchTerms = [];
}
try {
let andFilter = JSON.parse(LOCALSTORAGE.getItem('bnp-andfilter'));
$scope.andFilter = andFilter || false;
} catch (e) {
$scope.andFilter = false;
}
try {
let scrollToNew = JSON.parse(LOCALSTORAGE.getItem('bnp-scrollToNew'));
$scope.showIncomingRequests = !!scrollToNew;
} catch (e) {
$scope.showIncomingRequests = true;
const _initChrome = function () {
for (const property in STORAGE_MAP) {
try {
let item = LOCAL_STORAGE.getItem(`bnp-${property}`);
if (item) {
let retrieved = JSON.parse(item);
switch (typeof STORAGE_MAP[property]) {
case 'boolean':
$scope[property] = retrieved;
break;
default:
$scope[property] = retrieved || STORAGE_MAP[property];
break;
}
} else {
$scope[property] = STORAGE_MAP[property];
}
} catch (e) {
$scope[property] = STORAGE_MAP[property];
}
$scope.$watch(property, function(n, o) {
if (n !== o) {
_setLocalStorage();
}
});
console.debug(`Retrieving ${property}`, $scope[property]);
} }
console.debug('Retrieving Settings from Local Storage');
chrome.devtools.network.onRequestFinished.addListener(function (request) { 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://")) {
@ -147,6 +129,10 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
chrome.devtools.network.onNavigated.addListener(function (event) { chrome.devtools.network.onNavigated.addListener(function (event) {
// display a line break in the network logs to show page reloaded // display a line break in the network logs to show page reloaded
if ($scope.clearOnRefresh) {
$scope.clear();
return;
}
$scope.masterRequests.push({ $scope.masterRequests.push({
id: $scope.uniqueId, id: $scope.uniqueId,
separator: true, separator: true,
@ -157,7 +143,7 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
}); });
}; };
$scope.filterRequests = function () {
const _filterRequests = function () {
if (!$scope.searchTerms || $scope.searchTerms.length === 0) { if (!$scope.searchTerms || $scope.searchTerms.length === 0) {
$scope.filteredRequests = $scope.masterRequests; $scope.filteredRequests = $scope.masterRequests;
return; return;
@ -204,7 +190,7 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
$scope.toggleSearchType = function() { $scope.toggleSearchType = function() {
$scope.andFilter = !$scope.andFilter; $scope.andFilter = !$scope.andFilter;
_setLocalStorage(); _setLocalStorage();
$scope.filterRequests();
_filterRequests();
}; };
$scope.customSearch = function() { $scope.customSearch = function() {
@ -212,30 +198,29 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
$scope.searchTerms.push($scope.search); $scope.searchTerms.push($scope.search);
$scope.search = ""; $scope.search = "";
_setLocalStorage(); _setLocalStorage();
$scope.filterRequests()
_filterRequests();
} }
}; };
_setLocalStorage = function() {
const _setLocalStorage = function() {
// do some sort of comparison to searchTerms and oldSearchTerms to make sure there is only one. // do some sort of comparison to searchTerms and oldSearchTerms to make sure there is only one.
// although, now that I think about it... this comparison shouldn't be necessary... /shrug // although, now that I think about it... this comparison shouldn't be necessary... /shrug
LOCALSTORAGE.setItem('bnp-scrollToNew', JSON.stringify($scope.showIncomingRequests));
LOCALSTORAGE.setItem('bnp-andfilter', JSON.stringify($scope.andFilter));
LOCALSTORAGE.setItem('bnp-searchterms', JSON.stringify($scope.searchTerms));
LOCALSTORAGE.setItem('bnp-oldsearchterms', JSON.stringify($scope.oldSearchTerms));
console.debug('Saving', $scope.showIncomingRequests, $scope.andFilter, $scope.searchTerms, $scope.oldSearchTerms);
}
for (const property in STORAGE_MAP) {
LOCAL_STORAGE.setItem(`bnp-${property}`, JSON.stringify($scope[property]));
console.debug(`Saving ${property}`, $scope[property]);
}
};
$scope.addSearchTerm = function(index) { $scope.addSearchTerm = function(index) {
$scope.searchTerms.push($scope.oldSearchTerms.splice(index, 1)[0]); $scope.searchTerms.push($scope.oldSearchTerms.splice(index, 1)[0]);
_setLocalStorage(); _setLocalStorage();
$scope.filterRequests();
_filterRequests();
}; };
$scope.removeSearchTerm = function(index) { $scope.removeSearchTerm = function(index) {
$scope.oldSearchTerms.push($scope.searchTerms.splice(index, 1)[0]); $scope.oldSearchTerms.push($scope.searchTerms.splice(index, 1)[0]);
_setLocalStorage(); _setLocalStorage();
$scope.filterRequests();
_filterRequests();
}; };
$scope.deleteSearchTerm = function(index) { $scope.deleteSearchTerm = function(index) {
@ -247,7 +232,7 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
$scope.addRequest(har_entry, har_entry.request.method, har_entry.request.url, har_entry.response.status, null); $scope.addRequest(har_entry, har_entry.request.method, har_entry.request.url, har_entry.response.status, null);
}; };
$scope.createToolbar = function () {
const _createToolbar = function () {
toolbar.createToggleButton( toolbar.createToggleButton(
"embed", "embed",
"Toggle JSON Parsing (See Panel Settings)", "Toggle JSON Parsing (See Panel Settings)",
@ -266,17 +251,18 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
// ga('send', 'event', 'button', 'click', 'Download'); // ga('send', 'event', 'button', 'click', 'Download');
$scope.$apply(function () { $scope.$apply(function () {
const panel = $scope.currentDetailTab; const panel = $scope.currentDetailTab;
let blob;
if (panel === "tab-response") { if (panel === "tab-response") {
var blob = new Blob([JSON.parse(JSON.stringify($scope.activeCode, null, 4))], { type: "application/json;charset=utf-8" });
blob = new Blob([JSON.parse(JSON.stringify($scope.activeCode, null, 4))], { type: "application/json;charset=utf-8" });
saveAs(blob, "export_response.json"); saveAs(blob, "export_response.json");
} else { } else {
try { try {
var blob = new Blob([JSON.stringify($scope.activePostData)], { type: "application/json;charset=utf-8" });
blob = new Blob([JSON.stringify($scope.activePostData)], { type: "application/json;charset=utf-8" });
saveAs(blob, "export_request.json"); saveAs(blob, "export_request.json");
} catch (e) { } catch (e) {
console.log(e)
console.log(e);
} }
} }
}); });
}); });
@ -293,7 +279,7 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
$scope.addRequest = function (data, request_method, request_url, response_status) { $scope.addRequest = function (data, request_method, request_url, response_status) {
$scope.$apply(function () { $scope.$apply(function () {
const requestId = data.id || $scope.uniqueId; const requestId = data.id || $scope.uniqueId;
$scope.uniqueId++
$scope.uniqueId++;
if (data.request != null) { if (data.request != null) {
data["request_data"] = $scope.createKeypairs(data.request); data["request_data"] = $scope.createKeypairs(data.request);
@ -331,7 +317,7 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
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;
let ctObj = data.response_headers.find(x => x.name == "Content-Type")
let ctObj = data.response_headers.find(x => x.name == "Content-Type");
data.content_type = ctObj && ctObj.value || null; data.content_type = ctObj && ctObj.value || null;
$scope.requests[requestId] = data; // master $scope.requests[requestId] = data; // master
@ -356,7 +342,7 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
} }
}); });
} }
$scope.filterRequests();
_filterRequests();
}; };
$scope.clear = function () { $scope.clear = function () {
@ -394,7 +380,7 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
}; };
$scope.getClass = function (requestId, separator) { $scope.getClass = function (requestId, separator) {
if (separator) return "separator"
if (separator) return "separator";
if (requestId === $scope.activeId) { if (requestId === $scope.activeId) {
return "selected"; return "selected";
} else { } else {
@ -403,8 +389,8 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
}; };
$scope.titleIfSeparator = function(separator) { $scope.titleIfSeparator = function(separator) {
if (separator) if (separator)
return "Page reloaded here"
return ""
return "Page reloaded here";
return "";
}; };
$scope.createKeypairs = function (data) { $scope.createKeypairs = function (data) {
@ -444,17 +430,13 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
$scope.$watch("activeCode", function (newVal, oldVal) { $scope.$watch("activeCode", function (newVal, oldVal) {
if (newVal === null) { if (newVal === null) {
$scope.responseJsonEditor.set(null)
$scope.requestJsonEditor.set(null)
$scope.responseJsonEditor.set(null);
$scope.requestJsonEditor.set(null);
} }
$scope.displayCode("responseJsonEditor", $scope.activeCode, $scope.autoJSONParseDepthRes); $scope.displayCode("responseJsonEditor", $scope.activeCode, $scope.autoJSONParseDepthRes);
$scope.displayCode("requestJsonEditor", $scope.activePostData, $scope.autoJSONParseDepthReq); $scope.displayCode("requestJsonEditor", $scope.activePostData, $scope.autoJSONParseDepthReq);
}); });
$scope.$watch('showIncomingRequests', function(newVal, oldVal) {
_setLocalStorage();
})
$scope.selectDetailTab = function (tabId, external) { $scope.selectDetailTab = function (tabId, external) {
$scope.currentDetailTab = tabId; $scope.currentDetailTab = tabId;
if (external) { if (external) {
@ -484,7 +466,7 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
} else { } else {
// Something else // Something else
try { try {
let json = JSON.parse(input)
let json = JSON.parse(input);
$scope[elementId].setMode("view"); $scope[elementId].setMode("view");
$scope[elementId].set(content); $scope[elementId].set(content);
} catch (e) { } catch (e) {
@ -492,16 +474,16 @@ BNPChrome.controller("PanelController", function PanelController($scope, toolbar
$scope[elementId].set(content); $scope[elementId].set(content);
} }
} }
let bodySize;
if (elementId === "responseJsonEditor") { if (elementId === "responseJsonEditor") {
var bodySize = $scope.activeResponseData.find(x => x.name === "bodySize");
if (bodySize && bodySize.value < MAXBODYSIZE) { // an arbitrary number that I picked so there is HUGE lag
bodySize = $scope.activeResponseData.find(x => x.name === "bodySize");
if (bodySize && bodySize.value < MAX_BODY_SIZE) { // an arbitrary number that I picked so there is HUGE lag
if ($scope[elementId].getMode() === 'tree' || $scope[elementId].getMode() === 'view') if ($scope[elementId].getMode() === 'tree' || $scope[elementId].getMode() === 'view')
$scope[elementId].expandAll(); $scope[elementId].expandAll();
} }
} else if (elementId === "requestJsonEditor") { } else if (elementId === "requestJsonEditor") {
var bodySize = $scope.activeRequest.find(x => x.name === "bodySize");
if (bodySize && bodySize.value < MAXBODYSIZE) {
bodySize = $scope.activeRequest.find(x => x.name === "bodySize");
if (bodySize && bodySize.value < MAX_BODY_SIZE) {
if ($scope[elementId].getMode() === 'tree' || $scope[elementId].getMode() === 'view') if ($scope[elementId].getMode() === 'tree' || $scope[elementId].getMode() === 'view')
$scope[elementId].expandAll(); $scope[elementId].expandAll();
} }

+ 8
- 8
unpacked/panel/panel.html View File

@ -21,7 +21,7 @@
<script src="vendor/assets/javascripts/FileSaver.min.js"></script> <script src="vendor/assets/javascripts/FileSaver.min.js"></script>
</head> </head>
<body ng-controller='PanelController' ng-init="init('chrome-extension')" ng-cloak>
<body ng-controller='PanelController' ng-init="init()" ng-cloak>
<section class="wrapper"> <section class="wrapper">
<section class="request"> <section class="request">
@ -269,21 +269,21 @@
<h3>Settings</h3> <h3>Settings</h3>
<div class="form-group"> <div class="form-group">
<label for="scroll-to-new">Auto Scroll Network Log</label> <label for="scroll-to-new">Auto Scroll Network Log</label>
<input type="checkbox" name="scroll-to-new" id="scroll-to-new" ng-model="showIncomingRequests">
<input type="checkbox" name="scroll-to-new" id="scroll-to-new" ng-model="scrollToNew">
</div> </div>
<h3>Coming Soon</h3>
<div class="form-group" title="Not implemented yet">
<div class="form-group">
<label for="clear-on-refresh">Clear Network Log on Page Refresh</label> <label for="clear-on-refresh">Clear Network Log on Page Refresh</label>
<input disabled="disabled" type="checkbox" name="clear-on-refresh" id="clear-on-refresh" ng-model="clearOnRefresh">
<input type="checkbox" name="clear-on-refresh" id="clear-on-refresh" ng-model="clearOnRefresh">
</div> </div>
<div class="form-group" title="Not implemented yet">
<div class="form-group">
<label for="auto-json-parse-depth-response">Auto JSON Parse Depth (Response)</label> <label for="auto-json-parse-depth-response">Auto JSON Parse Depth (Response)</label>
<input disabled="disabled" type="number" name="auto-json-parse-depth-response" id="auto-json-parse-depth-response" ng-model="autoJSONParseDepthRes">
<input type="number" name="auto-json-parse-depth-response" id="auto-json-parse-depth-response" ng-model="autoJSONParseDepthRes">
</div> </div>
<div class="form-group" title="Not implemented yet"> <div class="form-group" title="Not implemented yet">
<label for="auto-json-parse-depth-request">Auto JSON Parse Depth (Request)</label> <label for="auto-json-parse-depth-request">Auto JSON Parse Depth (Request)</label>
<input disabled="disabled" type="number" name="auto-json-parse-depth-request" id="auto-json-parse-depth-request" ng-model="autoJSONParseDepthReq">
<input type="number" name="auto-json-parse-depth-request" id="auto-json-parse-depth-request" ng-model="autoJSONParseDepthReq">
</div> </div>
<h3>More Coming Soon...</h3>
</div> </div>

Loading…
Cancel
Save