From 084e3ce6efc49c2d43ce9b44d96e430f8057848e Mon Sep 17 00:00:00 2001 From: kaotisk Date: Fri, 29 Nov 2024 16:18:35 +0200 Subject: Visual improvements --- src/js/ui/sections/aboutSection.js | 29 ++++++ src/js/ui/sections/akNodeInfoSection.js | 12 +++ src/js/ui/sections/chatSection.js | 23 +++++ src/js/ui/sections/commentsSection.js | 12 +++ src/js/ui/sections/filesSection.js | 18 ++++ src/js/ui/sections/mixtapesSection.js | 18 ++++ src/js/ui/sections/myPageSection.js | 24 +++++ src/js/ui/sections/newsSection.js | 18 ++++ src/js/ui/sections/notFoundSection.js | 23 +++++ src/js/ui/sections/radioSection.js | 23 +++++ src/js/ui/sections/settingsSection.js | 44 +++++++++ src/js/ui/sections/statsSection.js | 29 ++++++ src/js/ui/sections/stellarBalancesSection.js | 19 ++++ src/js/ui/sections/stellarDataConfigSection.js | 18 ++++ src/js/ui/sections/stellarSection.js | 20 +++++ src/js/ui/sections/welcomeSection.js | 120 +++++++++++++++++++++++++ src/js/ui/sections/zchainDataSection.js | 18 ++++ 17 files changed, 468 insertions(+) create mode 100644 src/js/ui/sections/aboutSection.js create mode 100644 src/js/ui/sections/akNodeInfoSection.js create mode 100644 src/js/ui/sections/chatSection.js create mode 100644 src/js/ui/sections/commentsSection.js create mode 100644 src/js/ui/sections/filesSection.js create mode 100644 src/js/ui/sections/mixtapesSection.js create mode 100644 src/js/ui/sections/myPageSection.js create mode 100644 src/js/ui/sections/newsSection.js create mode 100644 src/js/ui/sections/notFoundSection.js create mode 100644 src/js/ui/sections/radioSection.js create mode 100644 src/js/ui/sections/settingsSection.js create mode 100644 src/js/ui/sections/statsSection.js create mode 100644 src/js/ui/sections/stellarBalancesSection.js create mode 100644 src/js/ui/sections/stellarDataConfigSection.js create mode 100644 src/js/ui/sections/stellarSection.js create mode 100644 src/js/ui/sections/welcomeSection.js create mode 100644 src/js/ui/sections/zchainDataSection.js (limited to 'src/js/ui/sections') diff --git a/src/js/ui/sections/aboutSection.js b/src/js/ui/sections/aboutSection.js new file mode 100644 index 0000000..933b6aa --- /dev/null +++ b/src/js/ui/sections/aboutSection.js @@ -0,0 +1,29 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var aboutSection = { + element: "div", + hidden: true, + id:"about-section", + innerHTML: ` +
+ + > +

About

+
+

Arching Kaos is a project about radio, music, communications and decentralization.

+

On site, you can listen to the latest mixes of music (menu entry "Mixtapes"), read latest news ("News") of the network and chat (you guessed it, "Chat" menu entry).

+

You can see the zchains appearing in "zchain" and logs of the process on "Logs"

+

Note that to participate you will need to set up your Arching Kaos set, which is not so convinient yet but possible.

+

Furthermore, if you are using Freighter extension you can additionally see:

+
    +
  1. Your balances on your wallet
  2. +
  3. Your configuration IPNS address (if any)
  4. +
  5. Your Arching Kaos configuration (if any)
  6. +
  7. Your zchain (...)
  8. +
  9. Your posted newsfeed (...)
  10. +
+

Finally, on the stats page you can find people that are participating over the Stellar Network, using the ARCHINGKAOS token/asset/coin.

+ ` +}; + +makeElement(aboutSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/akNodeInfoSection.js b/src/js/ui/sections/akNodeInfoSection.js new file mode 100644 index 0000000..42223bd --- /dev/null +++ b/src/js/ui/sections/akNodeInfoSection.js @@ -0,0 +1,12 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var akNodeInfoSection = { + element: "div", + id: "arching-kaos-node-info", + innerHTML: ` +

Node Info

+ No data found (yet?)! + ` +}; + +makeElement(akNodeInfoSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/chatSection.js b/src/js/ui/sections/chatSection.js new file mode 100644 index 0000000..e9edd29 --- /dev/null +++ b/src/js/ui/sections/chatSection.js @@ -0,0 +1,23 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var chatSection = { + element: 'div', + id:"chat-section", + style:"height: 100%;", + innerHTML: [ + { + element: 'button', + style:"position: fixed;", + onclick:"refreshChat()", + innerText:"Refresh" + }, + { + element: 'iframe', + id: "chat-iframe", + src: "https://irc.arching-kaos.net", + style: "width: 100%; height: 100%;" + } + ] +}; + +makeElement(chatSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/commentsSection.js b/src/js/ui/sections/commentsSection.js new file mode 100644 index 0000000..7209079 --- /dev/null +++ b/src/js/ui/sections/commentsSection.js @@ -0,0 +1,12 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var commentsSection = { + element: 'div', + id: 'comments-section', + innerHTML: [ + { element: "h2", innerText: "Comments" }, + { element: "em", id:"comments-sec-not-found", innerText: "No data found (yet?)!"} + ] +}; + +makeElement(commentsSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/filesSection.js b/src/js/ui/sections/filesSection.js new file mode 100644 index 0000000..726fa5a --- /dev/null +++ b/src/js/ui/sections/filesSection.js @@ -0,0 +1,18 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var filesSection = { + element: 'div', + id: "files-section", + innerHTML: ` +
+ + > +

Modules

+ > +

Files

+
+ No data found (yet?)! + ` +}; + +makeElement(filesSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/mixtapesSection.js b/src/js/ui/sections/mixtapesSection.js new file mode 100644 index 0000000..64280e4 --- /dev/null +++ b/src/js/ui/sections/mixtapesSection.js @@ -0,0 +1,18 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var mixtapesSection = { + element: "div", + id: "mixtapes-section", + innerHTML: ` +
+ + > +

Modules

+ > +

Mixtapes

+
+ No data found (yet?)! + ` +}; + +makeElement(mixtapesSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/myPageSection.js b/src/js/ui/sections/myPageSection.js new file mode 100644 index 0000000..0c79f06 --- /dev/null +++ b/src/js/ui/sections/myPageSection.js @@ -0,0 +1,24 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var myPageSection = { + element: "div", + id: "mypage-section", + innerHTML: ` +

My page

+ +
+

My news

+ No data found (yet?)! +
+
+

My mixtapes

+ No data found (yet?)! +
+
+

My zchain

+ No data found (yet?)! +
+ ` +}; + +makeElement(myPageSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/newsSection.js b/src/js/ui/sections/newsSection.js new file mode 100644 index 0000000..3b89cef --- /dev/null +++ b/src/js/ui/sections/newsSection.js @@ -0,0 +1,18 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var newsSection = { + element: 'div', + id: 'news-section', + innerHTML: [ + { element: "div", className: "where-am-i", innerHTML: ` + + > +

Modules

+ > +

News

+ ` }, + { element: "em", id:"news-sec-not-found", innerText: "No data found (yet?)!"} + ] +}; + +makeElement(newsSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/notFoundSection.js b/src/js/ui/sections/notFoundSection.js new file mode 100644 index 0000000..0731101 --- /dev/null +++ b/src/js/ui/sections/notFoundSection.js @@ -0,0 +1,23 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var notFoundSection = { + element: 'div', + id: 'not-found-section', + hidden: true, + innerHTML: [ + { + element: 'h2', + innerText: 'Not found' + }, + { + element: 'p', + innerText: 'Soft 404' + }, + { + element: 'p', + innerText: 'Please select an entry from the menu' + } + ] +}; + +makeElement(notFoundSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/radioSection.js b/src/js/ui/sections/radioSection.js new file mode 100644 index 0000000..5aaacc3 --- /dev/null +++ b/src/js/ui/sections/radioSection.js @@ -0,0 +1,23 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var radioSection = { + element: 'radio-section', + hidden: true, + style: 'height: 100%;', + innerHTML: [ + { + element: 'button', + style:"position: fixed;", + onclick:"refreshRadio()", + innerText:'Refresh' + }, + { + element: 'iframe', + id:"radio-iframe", + src:"https://radio.arching-kaos.com", + style:"width: 100%; height: 100%;" + } + ] +}; + +makeElement(radioSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/settingsSection.js b/src/js/ui/sections/settingsSection.js new file mode 100644 index 0000000..febd094 --- /dev/null +++ b/src/js/ui/sections/settingsSection.js @@ -0,0 +1,44 @@ +import { makeElement } from "../../arching-kaos-generator.js"; +import { settings } from "../../arching-kaos-web-ui-settings.js"; + +var settingsSection = { + element: 'div', + id: "settings-section", + innerHTML: ` +
+ + > +

🔧 Settings

+
+ ` +} + +makeElement(settingsSection, document.querySelector('.main')); + +var settingsPage = document.querySelector('#settings-section'); + +// var scripts = [ +// { +// element:"script", +// type: "module", +// src:"./js/arching-kaos-web-ui-settings.js" +// } +// ]; +// +// for ( var i = 0; i < scripts.length; i++ ) +// { +// makeElement(scripts[i], document.querySelector('body')); +// } + +var server = new StellarSdk.Server(settings.stellar.horizon.list[settings.stellar.horizon.active], {allowHttp:true}); + +if ( settings.stellar.scan ) +{ + scanStellarNetworkForPeers(); +} + +if ( settings.ak.scan ) +{ + ringlocalbell(); + setInterval(ringlocalbell, 10*60*1000); +} diff --git a/src/js/ui/sections/statsSection.js b/src/js/ui/sections/statsSection.js new file mode 100644 index 0000000..1f2ede2 --- /dev/null +++ b/src/js/ui/sections/statsSection.js @@ -0,0 +1,29 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var statsSection = { + element: 'div', + id: "stats-section", + innerHTML: [ + { element: "div", className: "where-am-i", innerHTML: ` + + > +

Explore

+ > +

Stats

+ `}, + { element: "div", className: "available-networks", innerHTML: ` +

Networks

+
+ Stellar +
+
+ Arching Kaos Experimental Instance +
+
+ Arching Kaos SBlocks +
+ `} + ] +}; + +makeElement(statsSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/stellarBalancesSection.js b/src/js/ui/sections/stellarBalancesSection.js new file mode 100644 index 0000000..906a064 --- /dev/null +++ b/src/js/ui/sections/stellarBalancesSection.js @@ -0,0 +1,19 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var stellarBalancesSection = { + element: "div", + id: "stellar-balances", + innerHTML: ` +
+ + > +

Stellar

+ > +

Balances

+
+ No data found (yet?)! +
+ ` +}; + +makeElement(stellarBalancesSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/stellarDataConfigSection.js b/src/js/ui/sections/stellarDataConfigSection.js new file mode 100644 index 0000000..f0690b3 --- /dev/null +++ b/src/js/ui/sections/stellarDataConfigSection.js @@ -0,0 +1,18 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var stellarDataConfigSection = { + element: "div", + id: "stellar-data-config", + innerHTML: ` +
+ + > +

Stellar

+ > +

Data

+
+ No data found (yet?)! + ` +}; + +makeElement(stellarDataConfigSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/stellarSection.js b/src/js/ui/sections/stellarSection.js new file mode 100644 index 0000000..0a5341d --- /dev/null +++ b/src/js/ui/sections/stellarSection.js @@ -0,0 +1,20 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var stellarSection = { + id: "stellar-section", + innerHTML: [ + { + element: "h2", + innerText: "Stellar dashboard" + }, + { + element: "button", + className: "sub-input", + id:"stellar-freigher-connect-address-button", + onclick:"connect()", + innerText:"Connect with Stellar address" + } + ] +}; + +makeElement(stellarSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/welcomeSection.js b/src/js/ui/sections/welcomeSection.js new file mode 100644 index 0000000..7b4d6be --- /dev/null +++ b/src/js/ui/sections/welcomeSection.js @@ -0,0 +1,120 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var welcomeSection = { + element: "div", + id: "welcome-section", + innerHTML: [ + { + element : "div", + className:"where-am-i", + innerHTML: ` + + + > +

Home

+ ` + }, + { + element: "p", + innerText: "Welcome to Arching Kaos project." + }, + { + element: "div", + id: "home-grid", + innerHTML: ` + + + + + + ` + }, + { + element : "h3", + innerText: "Render explicit zblock" + }, + { + element: "div", + style:"padding: 1vh 1vw; display: flex; flex-direction: row; align-items: center; gap: 10px;", + innerHTML: ` + + + ` + }, + { + element: "div", + className: "results-area", + innerHTML: [ + { + elements: "h3", + innerText: "Results" + } + ] + }, + { + element: "h3", + innerText: "Manual scan" + }, + { + element: "div", + id: "manual-scan-section", + innerHTML: [ + { + element: "div", + className: "manual-scan", + innerHTML: [ + { element:"button", onclick:"scanStellarNetworkForPeers()", innerText:"Check Stellar Network"}, + { element:"button", onclick:"checkLocalNodeInfo()", innerText:"Check local Node"}, + { element:"button", onclick:"checkLocalPeers()", innerText:"Check local Peers"}, + { element:"button", onclick:"checkLocalSchain()", innerText:"Check Local Schain"} + ] + } + ] + }, + { + element: "div", + className: "preview" + }, + { + element: "div", + className: "dialog", + innerHTML: [ + { + element: "h3", + innerText: "Progress" + }, + { + element: "progress", + id: "total-progress", + value: 0 + }, + { + element: "progress", + id: "http-progress", + value: 0 + }, + { + element: "pre", + id: "current-log-message" + } + ] + }, + + { + element: "details", + id: "logs-area", + innerHTML: [ + { + element: "summary", + innerText: "Logs (click to expand)" + }, + { + element: "div", + id: "logs-area-element" + } + ] + } + ] +}; + +makeElement(welcomeSection, document.querySelector('.main')); diff --git a/src/js/ui/sections/zchainDataSection.js b/src/js/ui/sections/zchainDataSection.js new file mode 100644 index 0000000..ba4bfde --- /dev/null +++ b/src/js/ui/sections/zchainDataSection.js @@ -0,0 +1,18 @@ +import { makeElement } from "../../arching-kaos-generator.js"; + +var zchainDataSection = { + element: "div", + id:"zchain-data-section", + innerHTML: ` +
+ + > +

Explore

+ > +

zchains

+
+ No data found (yet?)! + ` +}; + +makeElement(zchainDataSection, document.querySelector('.main')); -- cgit v1.2.3