Friendiiverse/Source/Main.js

128 lines
3.2 KiB
JavaScript
Raw Normal View History

2023-04-19 12:18:14 +02:00
var CurrTasks = {};
2023-04-19 00:16:35 +02:00
function DoAsync(First, Then, Data) {
var Job = RndId();
CurrTasks[Job] = {
Remains: 0,
Return(Data) {
this.Remains -= 1;
this.Result = Data;
},
2023-04-19 00:16:35 +02:00
};
// Call all First functs
2023-04-19 12:18:14 +02:00
ForceList(First).forEach(function(Fun, Data){
var Task = RndId();
var Proc = [Job, Task];
CurrTasks[Job][Task] = {};
CurrTasks[Job].Remains += 1;
//Fun(Proc, Data);
Data ? Fun(Data, Proc) : Fun(Proc);
2023-04-19 12:18:14 +02:00
});
// Continuosly check when First functs completed
CurrTasks[Job].Interval = setInterval(function(Job, Then){
if (CurrTasks[Job].Remains <= 0) {
clearInterval(CurrTasks[Job].Interval);
// Call all Then functs
2023-04-19 12:18:14 +02:00
ForceList(Then).forEach(function(Fun){
Fun(CurrTasks[Job].Result);
2023-04-19 12:18:14 +02:00
});
};
}, 50, Job, Then);
return Job;
2023-04-19 12:18:14 +02:00
};
function HttpCodeGood(Code) {
var Unit = String(Code)[0];
if (['1', '2', '3'].includes(Unit)) {
return true;
} else
if (['4', '5'].includes(Unit)) {
return false;
};
};
function ApiCall(Data, Proc) {
2023-04-19 00:16:35 +02:00
// Data = {Target: "Friendica", Method: "...", Data: {}, Call: (), CallFine: (), CallFail: ()}
var Req = new XMLHttpRequest();
2023-04-19 12:18:14 +02:00
Req.Proc = Proc;
2023-04-19 00:16:35 +02:00
Req.onloadend = function(){
2023-04-19 12:18:14 +02:00
var Status = String(this.status);
if (Data.Call) {
Data.Call(this);
}
if (HttpCodeGood(this.status)) {
if (Data.CallFine) {
Data.CallFine(this);
};
LogDebug([this.status, this.responseText], 'l');
} else {
if (Data.CallFail) {
Data.CallFail(this);
2023-04-19 00:16:35 +02:00
};
2023-04-19 12:18:14 +02:00
LogDebug([this.status, this.responseText], 'e');
};
2023-04-19 00:16:35 +02:00
};
if (Data.Target == 'Mastodon') {
Req.open('GET', `${MastodonUrl}/api/v1/${Data.Method}`, true);
};
if (Data.Target == 'Friendica') {
Req.open('GET', `${FriendicaUrl}/api/${Data.Method}.json`, true);
Req.setRequestHeader('Authorization', `Basic ${btoa(FriendicaCredentials)}`);
};
Req.send();
};
function DisplayFriendicaTimeline(Timeline) {
ApiCall({Target: "Friendica", Method: Timeline, CallFine: function(Res){
DataView.innerHTML = Res.responseText;
JSON.parse(DataView.innerHTML).forEach(function(Item){
var Title = Item.friendica_title ? `<h2>${Item.friendica_title}</h2>` : '';
TimelineView.innerHTML += `<div class=PostView>
<a href="${Item.external_url}">${Item.created_at}</a>
${Item.friendica_author.url}
${Title}
${Item.friendica_html}
</div>`;
});
}});
};
2023-04-19 12:18:14 +02:00
function FetchMastodon(Proc) {
ApiCall({Target: "Mastodon", Method: "timelines/public", CallFine: function(Res){
var Notes = [ TransParsers.Mastodon.Status( JSON.parse(Res.responseText)[0] ) ];
LogDebug(Notes, 'l');
CurrTasks[Proc[0]].Return(Notes);
2023-04-19 12:18:14 +02:00
}}, Proc);
2023-04-19 00:16:35 +02:00
};
function FillTimeline(Notes) {
Notes.forEach(function(Note){
TimelineView.innerHTML += `<div class="NoteView">
2023-04-19 00:16:35 +02:00
<a href="${Note.Url}">${Note.Time}</a>
${Note.Author.Url}
2023-04-19 00:16:35 +02:00
${Note.Content}
</div>`;
});
};
PlazasView.innerHTML = `
<div>
<h3>Featured</h3>
<ul>
<li onclick="DisplayFriendicaTimeline('statuses/networkpublic_timeline');">Federation</li>
<li onclick="DisplayFriendicaTimeline('statuses/public_timeline');">${FriendicaUrl}</li>
<li onclick="DoAsync(FetchMastodon, FillTimeline);">
<img src=""/>
${MastodonUrl}
</li>
2023-04-19 00:16:35 +02:00
</ul>
</div>
<div>
<h3>Categories</h3>
<ul>
<li>Testing</li>
<li>#fediverse</li>
</ul>
</div>
`;