summaryrefslogtreecommitdiff
path: root/src/SMAPI.Web/wwwroot/Content/js
diff options
context:
space:
mode:
authorJesse Plamondon-Willard <github@jplamondonw.com>2018-02-24 17:54:31 -0500
committerJesse Plamondon-Willard <github@jplamondonw.com>2018-02-24 17:54:31 -0500
commit414cf5c197b5b59776d3dda914eb15710efb0868 (patch)
tree0393a95194ad78cf4440c68657b0488b7db6d68b /src/SMAPI.Web/wwwroot/Content/js
parent5da8b707385b9851ff3f6442de58519125f5c96f (diff)
parentf2e8450706d1971d774f870081deffdb0c6b92eb (diff)
downloadSMAPI-414cf5c197b5b59776d3dda914eb15710efb0868.tar.gz
SMAPI-414cf5c197b5b59776d3dda914eb15710efb0868.tar.bz2
SMAPI-414cf5c197b5b59776d3dda914eb15710efb0868.zip
Merge branch 'develop' into stable
Diffstat (limited to 'src/SMAPI.Web/wwwroot/Content/js')
-rw-r--r--src/SMAPI.Web/wwwroot/Content/js/log-parser.js321
1 files changed, 88 insertions, 233 deletions
diff --git a/src/SMAPI.Web/wwwroot/Content/js/log-parser.js b/src/SMAPI.Web/wwwroot/Content/js/log-parser.js
index 914863f6..87a70391 100644
--- a/src/SMAPI.Web/wwwroot/Content/js/log-parser.js
+++ b/src/SMAPI.Web/wwwroot/Content/js/log-parser.js
@@ -1,48 +1,98 @@
/* globals $ */
var smapi = smapi || {};
-smapi.logParser = function(sectionUrl, pasteID) {
- /*********
- ** Initialisation
- *********/
- var stage,
- flags = $("#modflags"),
- output = $("#output"),
- error = $("#error"),
- filters = 0,
- memory = "",
- versionInfo,
- modInfo,
- modMap,
- modErrors,
- logInfo,
- templateModentry = $("#template-modentry").text(),
- templateCss = $("#template-css").text(),
- templateLogentry = $("#template-logentry").text(),
- templateLognotice = $("#template-lognotice").text(),
- regexInfo = /\[[\d\:]+ INFO SMAPI] SMAPI (.*?) with Stardew Valley (.*?) on (.*?)\n/g,
- regexMods = /\[[^\]]+\] Loaded \d+ mods:(?:\n\[[^\]]+\] .+)+/g,
- regexLog = /\[([\d\:]+) (TRACE|DEBUG|INFO|WARN|ALERT|ERROR) ? ([^\]]+)\] ?((?:\n|.)*?)(?=(?:\[\d\d:|$))/g,
- regexMod = /\[(?:.*?)\] *(.*?) (\d+\.?(?:.*?))(?: by (.*?))? \|(?:.*?)$/gm,
- regexDate = /\[\d{2}:\d{2}:\d{2} TRACE SMAPI\] Log started at (.*?) UTC/g,
- regexPath = /\[\d{2}:\d{2}:\d{2} DEBUG SMAPI\] Mods go here: (.*?)(?:\n|$)/g;
+var app;
+smapi.logParser = function (data, sectionUrl) {
+ // internal filter counts
+ var stats = data.stats = {
+ modsShown: 0,
+ modsHidden: 0
+ };
+ function updateModFilters() {
+ // counts
+ stats.modsShown = 0;
+ stats.modsHidden = 0;
+ for (var key in data.showMods) {
+ if (data.showMods.hasOwnProperty(key)) {
+ if (data.showMods[key])
+ stats.modsShown++;
+ else
+ stats.modsHidden++;
+ }
+ }
+ }
- $("#filters span").on("click", function(evt) {
- var t = $(evt.currentTarget);
- t.toggleClass("active");
- output.toggleClass(t.text().toLowerCase());
+ // set local time started
+ if(data)
+ data.localTimeStarted = ("0" + data.logStarted.getHours()).slice(-2) + ":" + ("0" + data.logStarted.getMinutes()).slice(-2);
+
+ // init app
+ app = new Vue({
+ el: '#output',
+ data: data,
+ computed: {
+ anyModsHidden: function () {
+ return stats.modsHidden > 0;
+ },
+ anyModsShown: function () {
+ return stats.modsShown > 0;
+ }
+ },
+ methods: {
+ toggleLevel: function(id) {
+ this.showLevels[id] = !this.showLevels[id];
+ },
+
+ toggleMod: function (id) {
+ var curShown = this.showMods[id];
+
+ // first filter: only show this by default
+ if (stats.modsHidden === 0) {
+ this.hideAllMods();
+ this.showMods[id] = true;
+ }
+
+ // unchecked last filter: reset
+ else if (stats.modsShown === 1 && curShown)
+ this.showAllMods();
+
+ // else toggle
+ else
+ this.showMods[id] = !this.showMods[id];
+
+ updateModFilters();
+ },
+ showAllMods: function () {
+ for (var key in this.showMods) {
+ if (this.showMods.hasOwnProperty(key)) {
+ this.showMods[key] = true;
+ }
+ }
+ updateModFilters();
+ },
+ hideAllMods: function () {
+ for (var key in this.showMods) {
+ if (this.showMods.hasOwnProperty(key)) {
+ this.showMods[key] = false;
+ }
+ }
+ updateModFilters();
+ }
+ }
});
+
+ /**********
+ ** Upload form
+ *********/
+ var error = $("#error");
+
$("#upload-button").on("click", function() {
- memory = $("#input").val() || "";
$("#input").val("");
$("#popup-upload").fadeIn();
});
var closeUploadPopUp = function() {
- $("#popup-upload").fadeOut(400, function() {
- $("#input").val(memory);
- memory = "";
- });
+ $("#popup-upload").fadeOut(400);
};
$("#popup-upload").on({
@@ -77,7 +127,7 @@ smapi.logParser = function(sectionUrl, pasteID) {
$("#popup-upload").fadeOut();
var paste = $("#input").val();
if (paste) {
- memory = "";
+ //memory = "";
$("#uploader").attr("data-text", "Saving...");
$("#uploader").fadeIn();
$
@@ -105,210 +155,15 @@ smapi.logParser = function(sectionUrl, pasteID) {
});
$(document).on("keydown", function(e) {
- if (e.which == 27) {
- if ($("#popup-upload").css("display") !== "none" && $("#popup-upload").css("opacity") == 1) {
+ if (e.which === 27) {
+ if ($("#popup-upload").css("display") !== "none" && $("#popup-upload").css("opacity") === 1) {
closeUploadPopUp();
}
-
- $("#popup-raw").fadeOut(400);
}
});
$("#cancel").on("click", closeUploadPopUp);
- $("#closeraw").on("click", function() {
- $("#popup-raw").fadeOut(400);
- });
-
- $("#popup-raw").on("click", function(e) {
- if (e.target.id === "popup-raw") {
- $("#popup-raw").fadeOut(400);
- }
- });
-
- if (pasteID) {
- getData(pasteID);
- }
- else
+ if (data.showPopup)
$("#popup-upload").fadeIn();
-
- /*********
- ** Helpers
- *********/
- function modClicked(evt) {
- var id = $(evt.currentTarget).attr("id").split("-")[1],
- cls = "mod-" + id;
- if (output.hasClass(cls))
- filters--;
- else
- filters++;
- output.toggleClass(cls);
- if (filters === 0) {
- output.removeClass("modfilter");
- } else {
- output.addClass("modfilter");
- }
- }
-
- function removeFilter() {
- for (var c = 0; c < modInfo.length; c++) {
- output.removeClass("mod-" + c);
- }
- filters = 0;
- output.removeClass("modfilter");
- }
-
- function selectAll() {
- for (var c = 0; c < modInfo.length; c++) {
- output.addClass("mod-" + c);
- }
- filters = modInfo.length;
- output.addClass("modfilter");
- }
-
- function parseData() {
- stage = "parseData.pre";
- var data = $("#input").val();
- if (!data) {
- stage = "parseData.checkNullData";
- throw new Error("Field `data` is null");
-
- }
- var dataInfo = regexInfo.exec(data) || regexInfo.exec(data) || regexInfo.exec(data),
- dataMods = regexMods.exec(data) || regexMods.exec(data) || regexMods.exec(data) || [""],
- dataDate = regexDate.exec(data) || regexDate.exec(data) || regexDate.exec(data),
- dataPath = regexPath.exec(data) || regexPath.exec(data) || regexPath.exec(data),
- match;
- stage = "parseData.doNullCheck";
- if (!dataInfo)
- throw new Error("Field `dataInfo` is null");
- if (!dataMods)
- throw new Error("Field `dataMods` is null");
- if (!dataPath)
- throw new Error("Field `dataPath` is null");
- dataMods = dataMods[0];
- stage = "parseData.setupDefaults";
- modMap = {
- "SMAPI": 0
- };
- modErrors = {
- "SMAPI": 0,
- "Console.Out": 0
- };
- logInfo = [];
- modInfo = [
- ["SMAPI", dataInfo[1], "Zoryn, CLxS & Pathoschild"]
- ];
- stage = "parseData.parseInfo";
- var date = dataDate ? new Date(dataDate[1] + "Z") : null;
- versionInfo = {
- apiVersion: dataInfo[1],
- gameVersion: dataInfo[2],
- platform: dataInfo[3],
- logDate: date ? date.getFullYear() + "-" + ("0" + date.getMonth().toString()).substr(-2) + "-" + ("0" + date.getDay().toString()).substr(-2) + " at " + date.getHours() + ":" + date.getMinutes() + ":" + date.getSeconds() + " " + date.toLocaleTimeString("en-us", { timeZoneName: "short" }).split(" ")[2] : "No timestamp found",
- modsPath: dataPath[1]
- };
- stage = "parseData.parseMods";
- while ((match = regexMod.exec(dataMods))) {
- modErrors[match[1]] = 0;
- modMap[match[1]] = modInfo.length;
- modInfo.push([match[1], match[2], match[3] ? ("by " + match[3]) : "Unknown author"]);
- }
- stage = "parseData.parseLog";
- while ((match = regexLog.exec(data))) {
- if (match[2] === "ERROR")
- modErrors[match[3]]++;
- logInfo.push([match[1], match[2], match[3], match[4]]);
- }
- stage = "parseData.post";
- modMap["Console.Out"] = modInfo.length;
- modInfo.push(["Console.Out", "", ""]);
- }
-
- function renderData() {
- stage = "renderData.pre";
-
- output.find("#api-version").text(versionInfo.apiVersion);
- output.find("#game-version").text(versionInfo.gameVersion);
- output.find("#platform").text(versionInfo.platform);
- output.find("#log-started").text(versionInfo.logDate);
- output.find("#mods-path").text(versionInfo.modsPath);
-
- var modslist = $("#modslist"), log = $("#log"), modCache = [], y = 0;
- for (; y < modInfo.length; y++) {
- var errors = modErrors[modInfo[y][0]],
- err, cls = "color-red";
- if (errors === 0) {
- err = "No Errors";
- cls = "color-green";
- } else if (errors === 1)
- err = "1 Error";
- else
- err = errors + " Errors";
- modCache.push(prepare(templateModentry, [y, modInfo[y][0], modInfo[y][1], modInfo[y][2], cls, err]));
- }
- modslist.append(modCache.join(""));
- for (var z = 0; z < modInfo.length; z++)
- $("#modlink-" + z).on("click", modClicked);
- var flagCache = [];
- for (var c = 0; c < modInfo.length; c++)
- flagCache.push(prepare(templateCss, [c]));
- flags.html(flagCache.join(""));
- var logCache = [], dupeCount = 0, dupeMemory = "|||";
- for (var x = 0; x < logInfo.length; x++) {
- var dm = logInfo[x][1] + "|" + logInfo[x][2] + "|" + logInfo[x][3];
- if (dupeMemory !== dm) {
- if (dupeCount > 0)
- logCache.push(prepare(templateLognotice, [logInfo[x - 1][1].toLowerCase(), modMap[logInfo[x - 1][2]], dupeCount]));
- dupeCount = 0;
- dupeMemory = dm;
- logCache.push(prepare(templateLogentry, [logInfo[x][1].toLowerCase(), modMap[logInfo[x][2]], logInfo[x][0], logInfo[x][1], logInfo[x][2], logInfo[x][3].split(" ").join("&nbsp ").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/\n/g, "<br />")]));
- }
- else
- dupeCount++;
- }
- log.append(logCache.join(""));
- $("#modlink-r").on("click", removeFilter);
- $("#modlink-a").on("click", selectAll);
-
- $("#log-data").show();
- }
-
- function prepare(str, arr) {
- var regex = /\{(\d)\}/g,
- match;
- while ((match = regex.exec(str)))
- str = str.replace(match[0], arr[match[1]]);
- return str;
- }
- function loadData() {
- try {
- stage = "loadData.Pre";
- parseData();
- renderData();
- $("#viewraw").on("click", function() {
- $("#dataraw").val($("#input").val());
- $("#popup-raw").fadeIn();
- });
- stage = "loadData.Post";
- }
- catch (err) {
- error.html('<h1>Parsing failed!</h1>Parsing of the log failed, details follow.<br />&nbsp;<p>Stage: ' + stage + "</p>" + err + '<hr /><pre id="rawlog"></pre>');
- $("#rawlog").text($("#input").val());
- }
- }
- function getData(pasteID) {
- $("#uploader").attr("data-text", "Loading...");
- $("#uploader").fadeIn();
- $.get(sectionUrl + "/fetch/" + pasteID, function(data) {
- if (data.success) {
- $("#input").val(data.content);
- loadData();
- } else {
- error.html('<h1>Fetching the log failed!</h1><p>' + data.error + '</p><pre id="rawlog"></pre>');
- $("#rawlog").text($("#input").val());
- }
- $("#uploader").fadeOut();
- });
- }
};