summaryrefslogtreecommitdiffstats
path: root/public/vendor
diff options
context:
space:
mode:
authorsilverwind <me@silverwind.io>2019-11-17 22:39:06 +0100
committerLauris BH <lauris@nix.lv>2019-11-17 22:39:06 +0100
commitf8bd90ba60b0c362d3e39ddf702cac0e0df2b0ab (patch)
treebf0d009550720440d5e7db505b5dafec1450777e /public/vendor
parent[skip ci] Updated translations via Crowdin (diff)
downloadforgejo-f8bd90ba60b0c362d3e39ddf702cac0e0df2b0ab.tar.xz
forgejo-f8bd90ba60b0c362d3e39ddf702cac0e0df2b0ab.zip
enable lazy-loading of gitgraph.js (#9036)
- moved gitgraph.js to web_src and made it importable and es6-compatible - created new webpack chunk for gitgraph - enabled CSS loader in webpack - enabled async/await syntax via regenerator-runtime - added script to ensure webpack chunks are loaded correctly - disable terser's comment extraction to prevent .LICENCE files gitgraph.js has many issues: 1. it is incompatible with ES6 because of strict-mode violations 1. it does not export anything 1. it's css has weird styles like for `body` 1. it is not available on npm I fixed points 1-3 in our version so it's now loadable in webpack. We should eventually consider alternatives.
Diffstat (limited to 'public/vendor')
-rw-r--r--public/vendor/VERSIONS3
-rw-r--r--public/vendor/librejs.html2
-rw-r--r--public/vendor/plugins/gitgraph/LICENSE24
-rw-r--r--public/vendor/plugins/gitgraph/gitgraph.css16
-rw-r--r--public/vendor/plugins/gitgraph/gitgraph.js435
5 files changed, 1 insertions, 479 deletions
diff --git a/public/vendor/VERSIONS b/public/vendor/VERSIONS
index 4643ee7b1e..0e6d2d2387 100644
--- a/public/vendor/VERSIONS
+++ b/public/vendor/VERSIONS
@@ -17,9 +17,6 @@ Version: 2.3.1
File(s): /vendor/plugins/clipboard/clipboard.min.js
Version: 1.5.9
-File(s): /vendor/plugins/gitgraph/gitgraph.js
-Version: 745f604212e2abfe2f0a59169ea530857b46625c
-
File(s): /vendor/plugins/vue/vue.min.js
Version: 2.1.10
diff --git a/public/vendor/librejs.html b/public/vendor/librejs.html
index 56c1cb287c..320dbb69a3 100644
--- a/public/vendor/librejs.html
+++ b/public/vendor/librejs.html
@@ -46,7 +46,7 @@
<td><a href="https://github.com/zenorocha/clipboard.js/archive/v1.5.9.tar.gz">clipboard-1.5.9.tar.gz</a></td>
</tr>
<tr>
- <td><a href="./plugins/gitgraph/gitgraph.js">gitgraph.js</a></td>
+ <td><a href="../js/gitgraph.js">gitgraph.js</a></td>
<td><a href="https://github.com/bluef/gitgraph.js/blob/master/LICENSE">BSD 3-Clause</a></td>
<td><a href="https://github.com/bluef/gitgraph.js">gitgraph.js-latest</a></td>
</tr>
diff --git a/public/vendor/plugins/gitgraph/LICENSE b/public/vendor/plugins/gitgraph/LICENSE
deleted file mode 100644
index 30cd6b7692..0000000000
--- a/public/vendor/plugins/gitgraph/LICENSE
+++ /dev/null
@@ -1,24 +0,0 @@
-Copyright (c) 2011, Terrence Lee <kill889@gmail.com>
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are met:
- * Redistributions of source code must retain the above copyright
- notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above copyright
- notice, this list of conditions and the following disclaimer in the
- documentation and/or other materials provided with the distribution.
- * Neither the name of the fgdev nor the
- names of its contributors may be used to endorse or promote products
- derived from this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
-ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
-WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
-DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
-DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
-(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
-LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
-ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
-SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. \ No newline at end of file
diff --git a/public/vendor/plugins/gitgraph/gitgraph.css b/public/vendor/plugins/gitgraph/gitgraph.css
deleted file mode 100644
index 3eba675177..0000000000
--- a/public/vendor/plugins/gitgraph/gitgraph.css
+++ /dev/null
@@ -1,16 +0,0 @@
-body {font:13.34px/1.4 helvetica,arial,freesans,clean,sans-serif;}
-em {font-style:normal;}
-
-#git-graph-container, #rel-container {float:left;}
-#rel-container {max-width:30%; overflow-x:auto;}
-#git-graph-container {overflow-x:auto; width:100%}
-#git-graph-container li {list-style-type:none;height:20px;line-height:20px; white-space:nowrap;}
-#git-graph-container li .node-relation {font-family:'Bitstream Vera Sans Mono', 'Courier', monospace;}
-#git-graph-container li .author {color:#666666;}
-#git-graph-container li .time {color:#999999;font-size:80%}
-#git-graph-container li a {color:#000000;}
-#git-graph-container li a:hover {text-decoration:underline;}
-#git-graph-container li a em {color:#BB0000;border-bottom:1px dotted #BBBBBB;text-decoration:none;font-style:normal;}
-#rev-container {width:100%}
-#rev-list {margin:0;padding:0 5px 0 5px;min-width:95%}
-#graph-raw-list {margin:0px;} \ No newline at end of file
diff --git a/public/vendor/plugins/gitgraph/gitgraph.js b/public/vendor/plugins/gitgraph/gitgraph.js
deleted file mode 100644
index 05ca0844d7..0000000000
--- a/public/vendor/plugins/gitgraph/gitgraph.js
+++ /dev/null
@@ -1,435 +0,0 @@
-/*
- * @license magnet:?xt=urn:btih:c80d50af7d3db9be66a4d0a86db0286e4fd33292&dn=bsd-3-clause.txt BSD 3-Clause
- * Copyright (c) 2011, Terrence Lee <kill889@gmail.com>
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * * Neither the name of the <organization> nor the
- * names of its contributors may be used to endorse or promote products
- * derived from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
- * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
- * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
- * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-var gitGraph = function (canvas, rawGraphList, config) {
- if (!canvas.getContext) {
- return;
- }
-
- if (typeof config === "undefined") {
- config = {
- unitSize: 20,
- lineWidth: 3,
- nodeRadius: 4
- };
- }
-
- var flows = [];
- var graphList = [];
-
- var ctx = canvas.getContext("2d");
-
- var devicePixelRatio = window.devicePixelRatio || 1;
- var backingStoreRatio = ctx.webkitBackingStorePixelRatio ||
- ctx.mozBackingStorePixelRatio ||
- ctx.msBackingStorePixelRatio ||
- ctx.oBackingStorePixelRatio ||
- ctx.backingStorePixelRatio || 1;
-
- var ratio = devicePixelRatio / backingStoreRatio;
-
- var init = function () {
- var maxWidth = 0;
- var i;
- var l = rawGraphList.length;
- var row;
- var midStr;
-
- for (i = 0; i < l; i++) {
- midStr = rawGraphList[i].replace(/\s+/g, " ").replace(/^\s+|\s+$/g, "");
-
- maxWidth = Math.max(midStr.replace(/(\_|\s)/g, "").length, maxWidth);
-
- row = midStr.split("");
-
- graphList.unshift(row);
- }
-
- var width = maxWidth * config.unitSize;
- var height = graphList.length * config.unitSize;
-
- canvas.width = width * ratio;
- canvas.height = height * ratio;
-
- canvas.style.width = width + 'px';
- canvas.style.height = height + 'px';
-
- ctx.lineWidth = config.lineWidth;
- ctx.lineJoin = "round";
- ctx.lineCap = "round";
-
- ctx.scale(ratio, ratio);
- };
-
- var genRandomStr = function () {
- var chars = "0123456789ABCDEF";
- var stringLength = 6;
- var randomString = '', rnum, i;
- for (i = 0; i < stringLength; i++) {
- rnum = Math.floor(Math.random() * chars.length);
- randomString += chars.substring(rnum, rnum + 1);
- }
-
- return randomString;
- };
-
- var findFlow = function (id) {
- var i = flows.length;
-
- while (i-- && flows[i].id !== id) {}
-
- return i;
- };
-
- var findColomn = function (symbol, row) {
- var i = row.length;
-
- while (i-- && row[i] !== symbol) {}
-
- return i;
- };
-
- var findBranchOut = function (row) {
- if (!row) {
- return -1
- }
-
- var i = row.length;
-
- while (i-- &&
- !(row[i - 1] && row[i] === "/" && row[i - 1] === "|") &&
- !(row[i - 2] && row[i] === "_" && row[i - 2] === "|")) {}
-
- return i;
- };
-
- var findLineBreak = function (row) {
- if (!row) {
- return -1
- }
-
- var i = row.length;
-
- while (i-- &&
- !(row[i - 1] && row[i - 2] && row[i] === " " && row[i - 1] === "|" && row[i - 2] === "_")) {}
-
- return i;
- };
-
- var genNewFlow = function () {
- var newId;
-
- do {
- newId = genRandomStr();
- } while (findFlow(newId) !== -1);
-
- return {id:newId, color:"#" + newId};
- };
-
- //Draw methods
- var drawLine = function (moveX, moveY, lineX, lineY, color) {
- ctx.strokeStyle = color;
- ctx.beginPath();
- ctx.moveTo(moveX, moveY);
- ctx.lineTo(lineX, lineY);
- ctx.stroke();
- };
-
- var drawLineRight = function (x, y, color) {
- drawLine(x, y + config.unitSize / 2, x + config.unitSize, y + config.unitSize / 2, color);
- };
-
- var drawLineUp = function (x, y, color) {
- drawLine(x, y + config.unitSize / 2, x, y - config.unitSize / 2, color);
- };
-
- var drawNode = function (x, y, color) {
- ctx.strokeStyle = color;
-
- drawLineUp(x, y, color);
-
- ctx.beginPath();
- ctx.arc(x, y, config.nodeRadius, 0, Math.PI * 2, true);
- ctx.fill();
- };
-
- var drawLineIn = function (x, y, color) {
- drawLine(x + config.unitSize, y + config.unitSize / 2, x, y - config.unitSize / 2, color);
- };
-
- var drawLineOut = function (x, y, color) {
- drawLine(x, y + config.unitSize / 2, x + config.unitSize, y - config.unitSize / 2, color);
- };
-
- var draw = function (graphList) {
- var colomn, colomnIndex, prevColomn, condenseIndex, breakIndex = -1;
- var x, y;
- var color;
- var nodePos;
- var tempFlow;
- var prevRowLength = 0;
- var flowSwapPos = -1;
- var lastLinePos;
- var i, l;
- var condenseCurrentLength, condensePrevLength = 0, condenseNextLength = 0;
-
- var inlineIntersect = false;
-
- //initiate color array for first row
- for (i = 0, l = graphList[0].length; i < l; i++) {
- if (graphList[0][i] !== "_" && graphList[0][i] !== " ") {
- flows.push(genNewFlow());
- }
- }
-
- y = (canvas.height / ratio) - config.unitSize * 0.5;
-
- //iterate
- for (i = 0, l = graphList.length; i < l; i++) {
- x = config.unitSize * 0.5;
-
- currentRow = graphList[i];
- nextRow = graphList[i + 1];
- prevRow = graphList[i - 1];
-
- flowSwapPos = -1;
-
- condenseCurrentLength = currentRow.filter(function (val) {
- return (val !== " " && val !== "_")
- }).length;
-
- if (nextRow) {
- condenseNextLength = nextRow.filter(function (val) {
- return (val !== " " && val !== "_")
- }).length;
- } else {
- condenseNextLength = 0;
- }
-
- //pre process begin
- //use last row for analysing
- if (prevRow) {
- if (!inlineIntersect) {
- //intersect might happen
- for (colomnIndex = 0; colomnIndex < prevRowLength; colomnIndex++) {
- if (prevRow[colomnIndex + 1] &&
- (prevRow[colomnIndex] === "/" && prevRow[colomnIndex + 1] === "|") ||
- ((prevRow[colomnIndex] === "_" && prevRow[colomnIndex + 1] === "|") &&
- (prevRow[colomnIndex + 2] === "/"))) {
-
- flowSwapPos = colomnIndex;
-
- //swap two flow
- tempFlow = {id:flows[flowSwapPos].id, color:flows[flowSwapPos].color};
-
- flows[flowSwapPos].id = flows[flowSwapPos + 1].id;
- flows[flowSwapPos].color = flows[flowSwapPos + 1].color;
-
- flows[flowSwapPos + 1].id = tempFlow.id;
- flows[flowSwapPos + 1].color = tempFlow.color;
- }
- }
- }
-
- if (condensePrevLength < condenseCurrentLength &&
- ((nodePos = findColomn("*", currentRow)) !== -1 &&
- (findColomn("_", currentRow) === -1))) {
-
- flows.splice(nodePos - 1, 0, genNewFlow());
- }
-
- if (prevRowLength > currentRow.length &&
- (nodePos = findColomn("*", prevRow)) !== -1) {
-
- if (findColomn("_", currentRow) === -1 &&
- findColomn("/", currentRow) === -1 &&
- findColomn("\\", currentRow) === -1) {
-
- flows.splice(nodePos + 1, 1);
- }
- }
- } //done with the previous row
-
- prevRowLength = currentRow.length; //store for next round
- colomnIndex = 0; //reset index
- condenseIndex = 0;
- condensePrevLength = 0;
- breakIndex = -1; //reset break index
- while (colomnIndex < currentRow.length) {
- colomn = currentRow[colomnIndex];
-
- if (colomn !== " " && colomn !== "_") {
- ++condensePrevLength;
- }
-
- //check and fix line break in next row
- if (colomn === "/" && currentRow[colomnIndex - 1] && currentRow[colomnIndex - 1] === "|") {
- if ((breakIndex = findLineBreak(nextRow)) !== -1) {
- nextRow.splice(breakIndex, 1);
- }
- }
- //if line break found replace all '/' with '|' after breakIndex in previous row
- if (breakIndex !== - 1 && colomn === "/" && colomnIndex > breakIndex) {
- currentRow[colomnIndex] = "|";
- colomn = "|";
- }
-
- if (colomn === " " &&
- currentRow[colomnIndex + 1] &&
- currentRow[colomnIndex + 1] === "_" &&
- currentRow[colomnIndex - 1] &&
- currentRow[colomnIndex - 1] === "|") {
-
- currentRow.splice(colomnIndex, 1);
-
- currentRow[colomnIndex] = "/";
- colomn = "/";
- }
-
- //create new flow only when no intersect happened
- if (flowSwapPos === -1 &&
- colomn === "/" &&
- currentRow[colomnIndex - 1] &&
- currentRow[colomnIndex - 1] === "|") {
-
- flows.splice(condenseIndex, 0, genNewFlow());
- }
-
- //change \ and / to | when it's in the last position of the whole row
- if (colomn === "/" || colomn === "\\") {
- if (!(colomn === "/" && findBranchOut(nextRow) === -1)) {
- if ((lastLinePos = Math.max(findColomn("|", currentRow),
- findColomn("*", currentRow))) !== -1 &&
- (lastLinePos < colomnIndex - 1)) {
-
- while (currentRow[++lastLinePos] === " ") {}
-
- if (lastLinePos === colomnIndex) {
- currentRow[colomnIndex] = "|";
- }
- }
- }
- }
-
- if (colomn === "*" &&
- prevRow &&
- prevRow[condenseIndex + 1] === "\\") {
- flows.splice(condenseIndex + 1, 1);
- }
-
- if (colomn !== " ") {
- ++condenseIndex;
- }
-
- ++colomnIndex;
- }
-
- condenseCurrentLength = currentRow.filter(function (val) {
- return (val !== " " && val !== "_")
- }).length;
-
- //do some clean up
- if (flows.length > condenseCurrentLength) {
- flows.splice(condenseCurrentLength, flows.length - condenseCurrentLength);
- }
-
- colomnIndex = 0;
-
- //a little inline analysis and draw process
- while (colomnIndex < currentRow.length) {
- colomn = currentRow[colomnIndex];
- prevColomn = currentRow[colomnIndex - 1];
-
- if (currentRow[colomnIndex] === " ") {
- currentRow.splice(colomnIndex, 1);
- x += config.unitSize;
-
- continue;
- }
-
- //inline interset
- if ((colomn === "_" || colomn === "/") &&
- currentRow[colomnIndex - 1] === "|" &&
- currentRow[colomnIndex - 2] === "_") {
-
- inlineIntersect = true;
-
- tempFlow = flows.splice(colomnIndex - 2, 1)[0];
- flows.splice(colomnIndex - 1, 0, tempFlow);
- currentRow.splice(colomnIndex - 2, 1);
-
- colomnIndex = colomnIndex - 1;
- } else {
- inlineIntersect = false;
- }
-
- color = flows[colomnIndex].color;
-
- switch (colomn) {
- case "_" :
- drawLineRight(x, y, color);
-
- x += config.unitSize;
- break;
-
- case "*" :
- drawNode(x, y, color);
- break;
-
- case "|" :
- drawLineUp(x, y, color);
- break;
-
- case "/" :
- if (prevColomn &&
- (prevColomn === "/" ||
- prevColomn === " ")) {
- x -= config.unitSize;
- }
-
- drawLineOut(x, y, color);
-
- x += config.unitSize;
- break;
-
- case "\\" :
- drawLineIn(x, y, color);
- break;
- }
-
- ++colomnIndex;
- }
-
- y -= config.unitSize;
- }
- };
-
- init();
- draw(graphList);
-};
-// @end-license \ No newline at end of file