aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorkaotisk <kaotisk@arching-kaos.org>2024-12-28 07:38:52 +0200
committerkaotisk <kaotisk@arching-kaos.org>2024-12-28 07:38:52 +0200
commit5308987b82fd183d657885a014a9d82ff16299fb (patch)
tree9673a8c2c0b1ec64047b4f150ae40f436ec7ee74 /src
parentd3781c705dcc491a0568b71d24efdce67dc5f0a5 (diff)
downloadarching-kaos-web-ui-5308987b82fd183d657885a014a9d82ff16299fb.tar.gz
arching-kaos-web-ui-5308987b82fd183d657885a014a9d82ff16299fb.tar.bz2
arching-kaos-web-ui-5308987b82fd183d657885a014a9d82ff16299fb.zip
Visual feedback for download
Diffstat (limited to 'src')
-rw-r--r--src/js/arching-kaos-file-system.js48
-rw-r--r--src/js/arching-kaos-generator.js19
2 files changed, 65 insertions, 2 deletions
diff --git a/src/js/arching-kaos-file-system.js b/src/js/arching-kaos-file-system.js
index 39ef5ed..77189e9 100644
--- a/src/js/arching-kaos-file-system.js
+++ b/src/js/arching-kaos-file-system.js
@@ -8,6 +8,8 @@
import { akfsGetChunkURL, akfsGetLeafURL, akfsGetMapURL } from "./url-generators.js";
import { archingKaosFetchBlob } from "./arching-kaos-fetch.js";
import { offerDownloadableData } from "./utils.js";
+import {archingKaosLog} from "./arching-kaos-log.js";
+import { makeElement } from "./arching-kaos-generator.js";
var thingy = {};
var leafs_counter = 0;
@@ -16,8 +18,26 @@ var first_chunk_spotted = 0;
var first_chunk_size = 0;
var final_array_seq = [];
var status = [];
+var workspace = [];
var output = "";
+function drawWorkSpace()
+{
+ var ele = {
+ element:"svg",
+ className: "akfsmap",
+ viewBox: "0 0 700 50",
+ version: "1.1",
+ width: 700,
+ height:50,
+ style:"background-color:#333;width: 100%;height:100%;",
+ xmlns: "http://www.w3.org/2000/svg",
+ innerHTML:[
+ ]
+ };
+ if ( document.querySelector('svg') === null ) makeElement(ele, document.querySelector('.results-area'));
+}
+
function akfsReset()
{
thingy = null;
@@ -31,11 +51,13 @@ function akfsReset()
status = [];
workspace = [];
output = "";
+ if ( document.querySelector('svg') !== null ) document.querySelector('svg').remove();
}
export function akfsGetMap(hash)
{
akfsReset();
+ drawWorkSpace();
archingKaosFetchBlob(akfsGetMapURL(hash), akfsFromMapGetLevelOneMapHash, [hash])
return hash;
}
@@ -159,6 +181,14 @@ function akfsChunkOrLeaf(reply, params)
else if ( hash === thingy.root_hash )
{
console.log("Current is a root_hash");
+ makeElement({
+ element:"circle",
+ id:`c-${hash}`,
+ fill:"red",
+ cx:1+(workspace[wsn].length+1)*3,
+ cy:2+((wsn-1)*3),
+ r:"1"
+ }, document.querySelector('svg'));
}
// if ( thingy[hash] !== undefined )
// {
@@ -172,17 +202,34 @@ function akfsChunkOrLeaf(reply, params)
tail: reply.split('\n')[1]
};
thingy.leafs[leaf.hash] = leaf;
+ document.querySelector(`#c-${leaf.hash}`).setAttribute("fill", "lightgreen");
status[leaf.hash] = 'ready';
status[leaf.head] = 'working';
archingKaosFetchBlob(akfsGetLeafURL(leaf.head), akfsChunkOrLeaf, [leaf.head, hash, wsn]);
archingKaosFetchBlob(akfsGetChunkURL(leaf.head), akfsChunkOrLeaf, [leaf.head, hash, wsn]);
workspace[wsn].push(leaf.head);
+ makeElement({
+ element:"circle",
+ id:`c-${leaf.head}`,
+ fill:"red",
+ cx:1+(workspace[wsn].length*3),
+ cy:2+((wsn)*3),
+ r:"1"
+ }, document.querySelector('svg'));
if ( leaf.head !== leaf.tail )
{
status[leaf.tail] = 'working';
archingKaosFetchBlob(akfsGetLeafURL(leaf.tail), akfsChunkOrLeaf, [leaf.tail, hash, wsn]);
archingKaosFetchBlob(akfsGetChunkURL(leaf.tail), akfsChunkOrLeaf, [leaf.tail, hash, wsn]);
workspace[wsn].push(leaf.tail);
+ makeElement({
+ element:"circle",
+ id:`c-${leaf.tail}`,
+ fill:"red",
+ cx:1+(workspace[wsn].length*3),
+ cy:2+((wsn)*3),
+ r:"1"
+ }, document.querySelector('svg'));
}
}
else if ( base64regexp.test(reply.replaceAll('\n', '')) && ( thingy.chunks[hash] === undefined ) )
@@ -197,6 +244,7 @@ function akfsChunkOrLeaf(reply, params)
hash: hash,
data: reply
};
+ document.querySelector(`#c-${chunk.hash}`).setAttribute("fill", "lightgreen");
archingKaosLog(`${hash} is a chunk`);
status[chunk.hash] = 'ready';
thingy.chunks[chunk.hash] = chunk;
diff --git a/src/js/arching-kaos-generator.js b/src/js/arching-kaos-generator.js
index d8f2f2b..a39a77b 100644
--- a/src/js/arching-kaos-generator.js
+++ b/src/js/arching-kaos-generator.js
@@ -7,10 +7,14 @@
export function makeElement(obj, attachTo)
{
- if (obj.element !== 'head' && obj.element !== 'body' )
+ if (obj.element !== 'head' && obj.element !== 'body' && obj.element !== 'svg' && obj.element !== 'circle')
{
var temp = document.createElement(obj.element);
}
+ else if ( obj.element === 'svg' || obj.element === 'circle' )
+ {
+ var temp = document.createElementNS("http://www.w3.org/2000/svg", obj.element);
+ }
else if ( obj.id !== null && document.querySelector('#'+obj.id) )
{
var temp = document.querySelector('#'+obj.id);
@@ -24,7 +28,7 @@ export function makeElement(obj, attachTo)
if ( obj.type !== undefined ) temp.type = obj.type;
if ( obj.content !== undefined ) temp.content = obj.content;
if ( obj.property !== undefined ) temp.property = obj.property;
- if ( obj.className !== undefined ) temp.className = obj.className;
+ if ( obj.className !== undefined && obj.element !== 'svg') temp.className = obj.className;
if ( obj.rel !== undefined ) temp.rel = obj.rel;
if ( obj.href !== undefined ) temp.href = obj.href;
if ( obj.style !== undefined ) temp.style = obj.style;
@@ -40,6 +44,17 @@ export function makeElement(obj, attachTo)
if ( obj.placeholder !== undefined ) temp.placeholder = obj.placeholder;
if ( obj.classes !== undefined ) temp.classList = obj.classes;
if ( obj.innerText !== undefined ) temp.innerText = obj.innerText;
+ if ( obj.viewBox !== undefined ) temp.setAttribute("viewBox", obj.viewBox);
+ if ( obj.cx !== undefined ) temp.setAttribute("cx", obj.cx);
+ if ( obj.cy !== undefined ) temp.setAttribute("cy", obj.cy);
+ if ( obj.r !== undefined ) temp.setAttribute("r", obj.r);
+ if ( obj.xmlns !== undefined ) temp.setAttribute("xmlns", obj.xmlns);
+ if ( obj.fill !== undefined ) temp.setAttribute("fill", obj.fill);
+ if ( obj.stroke !== undefined ) temp.setAttribute("stroke", obj.stroke);
+ if ( obj.strokeWidth !== undefined ) temp.setAttribute("stroke-width", obj.strokeWidth);
+ if ( obj.version !== undefined ) temp.setAttribute("version", obj.version);
+ if ( obj.width !== undefined ) temp.setAttribute("width", obj.width);
+ if ( obj.height !== undefined ) temp.setAttribute("height", obj.height);
if ( obj.innerHTML !== undefined && Array.isArray(obj.innerHTML) )
{
obj.innerHTML.forEach((value)=>{makeElement(value, temp)});