mirror of
https://iceshrimp.dev/limepotato/jormungandr-bite.git
synced 2025-01-25 14:51:31 -07:00
Improve task manager
This commit is contained in:
parent
d79e24e20a
commit
3122bab8a4
3 changed files with 90 additions and 3 deletions
69
src/client/components/taskmanager.api-window.vue
Normal file
69
src/client/components/taskmanager.api-window.vue
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
<template>
|
||||||
|
<XWindow ref="window"
|
||||||
|
:initial-width="370"
|
||||||
|
:initial-height="450"
|
||||||
|
:can-resize="true"
|
||||||
|
@close="$refs.window.close()"
|
||||||
|
@closed="$emit('closed')"
|
||||||
|
>
|
||||||
|
<template #header>Req Viewer</template>
|
||||||
|
|
||||||
|
<div class="rlkneywz">
|
||||||
|
<MkTab v-model:value="tab" :items="[{ label: 'Request', value: 'req', }, { label: 'Response', value: 'res', }]" style="border-bottom: solid 1px var(--divider);"/>
|
||||||
|
|
||||||
|
<code v-if="tab === 'req'">{{ reqStr }}</code>
|
||||||
|
<code v-if="tab === 'res'">{{ resStr }}</code>
|
||||||
|
</div>
|
||||||
|
</XWindow>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script lang="ts">
|
||||||
|
import { defineComponent } from 'vue';
|
||||||
|
import * as JSON5 from 'json5';
|
||||||
|
import XWindow from '@/components/ui/window.vue';
|
||||||
|
import MkTab from '@/components/tab.vue';
|
||||||
|
|
||||||
|
export default defineComponent({
|
||||||
|
components: {
|
||||||
|
XWindow,
|
||||||
|
MkTab,
|
||||||
|
},
|
||||||
|
|
||||||
|
props: {
|
||||||
|
req: {
|
||||||
|
required: true,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
emits: ['closed'],
|
||||||
|
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
tab: 'req',
|
||||||
|
reqStr: JSON5.stringify(this.req.req, null, '\t'),
|
||||||
|
resStr: JSON5.stringify(this.req.res, null, '\t'),
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.rlkneywz {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
height: 100%;
|
||||||
|
|
||||||
|
> code {
|
||||||
|
display: block;
|
||||||
|
flex: 1;
|
||||||
|
padding: 8px;
|
||||||
|
overflow: auto;
|
||||||
|
tab-size: 2;
|
||||||
|
white-space: pre;
|
||||||
|
font-family: Fira code, Fira Mono, Consolas, Menlo, Courier, monospace;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -54,7 +54,7 @@
|
||||||
<div>Endpoint</div>
|
<div>Endpoint</div>
|
||||||
<div>State</div>
|
<div>State</div>
|
||||||
</div>
|
</div>
|
||||||
<div v-for="req in apiRequests">
|
<div v-for="req in apiRequests" @click="showReq(req)">
|
||||||
<div>#{{ req.id }}</div>
|
<div>#{{ req.id }}</div>
|
||||||
<div>{{ req.endpoint }}</div>
|
<div>{{ req.endpoint }}</div>
|
||||||
<div class="state" :class="req.state">{{ req.state }}</div>
|
<div class="state" :class="req.state">{{ req.state }}</div>
|
||||||
|
@ -119,6 +119,13 @@ export default defineComponent({
|
||||||
os.popups.value = os.popups.value.filter(x => x !== p);
|
os.popups.value = os.popups.value.filter(x => x !== p);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const showReq = async req => {
|
||||||
|
os.popup(await import('./taskmanager.api-window.vue'), {
|
||||||
|
req: req
|
||||||
|
}, {
|
||||||
|
}, 'closed');
|
||||||
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
tab: ref('stream'),
|
tab: ref('stream'),
|
||||||
popups: os.popups,
|
popups: os.popups,
|
||||||
|
@ -126,6 +133,7 @@ export default defineComponent({
|
||||||
connections,
|
connections,
|
||||||
pools,
|
pools,
|
||||||
killPopup,
|
killPopup,
|
||||||
|
showReq,
|
||||||
faTerminal,
|
faTerminal,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
@ -152,6 +160,10 @@ export default defineComponent({
|
||||||
> div {
|
> div {
|
||||||
display: table-row;
|
display: table-row;
|
||||||
|
|
||||||
|
&:nth-child(even) {
|
||||||
|
//background: rgba(0, 0, 0, 0.1);
|
||||||
|
}
|
||||||
|
|
||||||
&.header {
|
&.header {
|
||||||
opacity: 0.7;
|
opacity: 0.7;
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,6 +13,7 @@ export const isMobile = /mobile|iphone|ipad|android/.test(ua);
|
||||||
export const stream = markRaw(new Stream());
|
export const stream = markRaw(new Stream());
|
||||||
|
|
||||||
export const pendingApiRequestsCount = ref(0);
|
export const pendingApiRequestsCount = ref(0);
|
||||||
|
let apiRequestsCount = 0; // for debug
|
||||||
export const apiRequests = ref([]); // for debug
|
export const apiRequests = ref([]); // for debug
|
||||||
|
|
||||||
export const windows = new Map();
|
export const windows = new Map();
|
||||||
|
@ -25,12 +26,15 @@ export function api(endpoint: string, data: Record<string, any> = {}, token?: st
|
||||||
};
|
};
|
||||||
|
|
||||||
const log = debug ? reactive({
|
const log = debug ? reactive({
|
||||||
id: apiRequests.value.length,
|
id: ++apiRequestsCount,
|
||||||
endpoint,
|
endpoint,
|
||||||
state: 'pending'
|
req: markRaw(data),
|
||||||
|
res: null,
|
||||||
|
state: 'pending',
|
||||||
}) : null;
|
}) : null;
|
||||||
if (debug) {
|
if (debug) {
|
||||||
apiRequests.value.push(log);
|
apiRequests.value.push(log);
|
||||||
|
if (apiRequests.value.length > 128) apiRequests.value.shift();
|
||||||
}
|
}
|
||||||
|
|
||||||
const promise = new Promise((resolve, reject) => {
|
const promise = new Promise((resolve, reject) => {
|
||||||
|
@ -50,6 +54,7 @@ export function api(endpoint: string, data: Record<string, any> = {}, token?: st
|
||||||
if (res.status === 200) {
|
if (res.status === 200) {
|
||||||
resolve(body);
|
resolve(body);
|
||||||
if (debug) {
|
if (debug) {
|
||||||
|
log.res = markRaw(body);
|
||||||
log.state = 'success';
|
log.state = 'success';
|
||||||
}
|
}
|
||||||
} else if (res.status === 204) {
|
} else if (res.status === 204) {
|
||||||
|
@ -60,6 +65,7 @@ export function api(endpoint: string, data: Record<string, any> = {}, token?: st
|
||||||
} else {
|
} else {
|
||||||
reject(body.error);
|
reject(body.error);
|
||||||
if (debug) {
|
if (debug) {
|
||||||
|
log.res = markRaw(body.error);
|
||||||
log.state = 'failed';
|
log.state = 'failed';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue