Merge pull request #5 from spiralw/patch-1

feat: separate status page into clusters
This commit is contained in:
Jake Fulmine 2022-03-11 17:46:24 +01:00 committed by GitHub
commit d18e3a79ef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -9,6 +9,7 @@
let message = "Loading..."; let message = "Loading...";
let shards = []; let shards = [];
let clusters = {};
let pingAverage = ""; let pingAverage = "";
let currentCommitMsg = ""; let currentCommitMsg = "";
@ -27,19 +28,31 @@
const get = async () => { const get = async () => {
const pkdata = await api().private.meta.get(); const pkdata = await api().private.meta.get();
shards = pkdata.shards.sort((x, y) => (x.id > y.id) ? 1 : -1); let data = pkdata.shards.sort((x, y) => (x.id > y.id) ? 1 : -1);
let pings = 0; let pings = 0;
shards = shards.map(shard => { data = data.map(shard => {
pings += shard.ping; pings += shard.ping;
shard.last_connection = new Date(Number(shard.last_connection) * 1000).toUTCString().match(/([0-9][0-9]:[0-9][0-9]:[0-9][0-9])/)?.shift() shard.last_connection = new Date(Number(shard.last_connection) * 1000).toUTCString().match(/([0-9][0-9]:[0-9][0-9]:[0-9][0-9])/)?.shift()
shard.last_heartbeat = new Date(Number(shard.last_heartbeat) * 1000).toUTCString().match(/([0-9][0-9]:[0-9][0-9]:[0-9][0-9])/)?.shift() shard.last_heartbeat = new Date(Number(shard.last_heartbeat) * 1000).toUTCString().match(/([0-9][0-9]:[0-9][0-9]:[0-9][0-9])/)?.shift()
return shard; return shard;
}); });
console.log(data[0].cluster_id);
pingAverage = Math.trunc(pings / shards.length).toString(); pingAverage = Math.trunc(pings / shards.length).toString();
currentCommitMsg = `Current Git commit: <a href="https://github.com/xSke/PluralKit/commit/${pkdata.version}">${pkdata.version.slice(0,7)}</a>`; currentCommitMsg = `Current Git commit: <a href="https://github.com/xSke/PluralKit/commit/${pkdata.version}">${pkdata.version.slice(0,7)}</a>`;
if (data[0].cluster_id === 0) {
let clusterData = {};
data.forEach(shard => {
if (clusterData[shard.cluster_id] === undefined) clusterData[shard.cluster_id] = [];
clusterData[shard.cluster_id].push(shard);
});
clusters = clusterData;
} else {
shards = data;
}
message = ""; message = "";
}; };
@ -129,6 +142,7 @@
</Card> </Card>
</Col> </Col>
</Row> </Row>
{#if shards.length > 0}
<Row> <Row>
<Col class="mx-auto" xs={12} lg={11} xl={10}> <Col class="mx-auto" xs={12} lg={11} xl={10}>
<Card class="mb-4"> <Card class="mb-4">
@ -141,4 +155,22 @@
</Card> </Card>
</Col> </Col>
</Row> </Row>
{/if}
{#each Object.keys(clusters) as key}
<Row>
<Col class="mx-auto" xs={12} lg={11} xl={10}>
<Card class="mb-4">
<CardBody>
<CardTitle style="margin-top: 8px; outline: none;">
Cluster {key}
</CardTitle>
<br>
{#each clusters[key] as shard}
<ShardItem shard={shard} bind:hover={hover} />
{/each}
</CardBody>
</Card>
</Col>
</Row>
{/each}
</Container> </Container>