aboutsummaryrefslogtreecommitdiff
path: root/src/js/arching-kaos-fetch.js
blob: 6cf1b769c4ba0221d56259ad38f8768c0217573f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
// Arching Kaos Fetch
//
// Kaotisk Hund - 2024
//
// @license magnet:?xt=urn:btih:0b31508aeb0634b347b8270c7bee4d411b5d4109&dn=agpl-3.0.txt AGPL v3.0
//

import { archingKaosLog } from "./arching-kaos-log.js";
import { httpProgressPlaceholder, progressPlaceholder } from "./app.js";
import { debugLog } from "./utils.js";

export function archingKaosFetchJSON( url, callback, params ){
    const request = new XMLHttpRequest();
    request.addEventListener("load", ()=>{
        var json = JSON.parse(request.response);
        if(request.status !== 404){
            callback(json, params);
        } else {
            archingKaosLog(`ERROR ${request.status} while loading ${url}`);
        }
    });
    request.addEventListener("error", ()=>{
        debugLog("An error occured.");
    });
    request.addEventListener("progress", (event)=>{
        if (event.lengthComputable && progressPlaceholder()){
            httpProgressPlaceholder().value = (event.loaded / event.total) * 100;
        } else {
            httpProgressPlaceholder().value = 0;
            debugLog("Supposingly zeroed progressPlaceholder");
        }
    });
    request.addEventListener("abort", ()=>{
        debugLog("Request aborted.");
    });
    request.open("GET", url);
    request.send();

}

export async function archingKaosFetchText( url, callback, params ){
    const request = new XMLHttpRequest();
    request.addEventListener("load", ()=>{
        var text = request.response;
        if(request.status !== 404){
            callback(text, params);
        } else {
            archingKaosLog(`ERROR ${request.status} while loading ${url}`);
        }
    });
    request.addEventListener("error", ()=>{
        debugLog("An error occured.");
    });
    request.addEventListener("progress", (event)=>{
        if (event.lengthComputable && progressPlaceholder()){
            httpProgressPlaceholder().value = (event.loaded / event.total) * 100;
        } else {
            httpProgressPlaceholder.value = 0;
            debugLog("Supposingly zeroed progressPlaceholder");
        }
    });
    request.addEventListener("abort", ()=>{
        debugLog("Request aborted.");
    });
    request.open("GET", url);
    request.send();
}

export function archingKaosFetchBlob( url, callback, params ){
    const request = new XMLHttpRequest();
    request.addEventListener("load", ()=>{
        var blob = request.response;
        if(request.status !== 404){
            callback(blob, params);
        } else {
            archingKaosLog(`ERROR ${request.status} while loading ${url}`);
        }
    });
    request.addEventListener("error", ()=>{
        debugLog("An error occured.");
    });
    request.addEventListener("progress", (event)=>{
        if (event.lengthComputable && progressPlaceholder()){
            httpProgressPlaceholder().value = (event.loaded / event.total) * 100;
        } else {
            httpProgressPlaceholder.value = 0;
            debugLog("Supposingly zeroed progressPlaceholder");
        }
    });
    request.addEventListener("abort", ()=>{
        debugLog("Request aborted.");
    });
    request.open("GET", url);
    request.send();
}
// @license-end