tweak ui
This commit is contained in:
		| @@ -1,70 +1,71 @@ | ||||
| <template> | ||||
| <FormBase> | ||||
| 	<FormGroup v-if="instance"> | ||||
| 		<template #label>{{ instance.host }}</template> | ||||
| 		<FormGroup> | ||||
| 			<div class="_debobigegoItem"> | ||||
| 				<div class="_debobigegoPanel fnfelxur"> | ||||
| 					<img :src="instance.iconUrl || instance.faviconUrl" alt="" class="icon"/> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<FormKeyValueView> | ||||
| 				<template #key>Name</template> | ||||
| 				<template #value><span class="_monospace">{{ instance.name || `(${$ts.unknown})` }}</span></template> | ||||
| 			</FormKeyValueView> | ||||
| 		</FormGroup> | ||||
| <MkSpacer :content-max="600" :margin-min="16" :margin-max="32"> | ||||
| 	<div v-if="instance" class="_formRoot"> | ||||
| 		<div class="fnfelxur"> | ||||
| 			<img :src="instance.iconUrl || instance.faviconUrl" alt="" class="icon"/> | ||||
| 		</div> | ||||
| 		<MkKeyValue :copy="host" oneline style="margin: 1em 0;"> | ||||
| 			<template #key>Host</template> | ||||
| 			<template #value><span class="_monospace"><MkLink :url="`https://${host}`">{{ host }}</MkLink></span></template> | ||||
| 		</MkKeyValue> | ||||
| 		<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 			<template #key>Name</template> | ||||
| 			<template #value>{{ instance.name || `(${$ts.unknown})` }}</template> | ||||
| 		</MkKeyValue> | ||||
| 		<MkKeyValue> | ||||
| 			<template #key>{{ $ts.description }}</template> | ||||
| 			<template #value>{{ instance.description }}</template> | ||||
| 		</MkKeyValue> | ||||
| 		<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 			<template #key>{{ $ts.software }}</template> | ||||
| 			<template #value><span class="_monospace">{{ instance.softwareName || `(${$ts.unknown})` }} / {{ instance.softwareVersion || `(${$ts.unknown})` }}</span></template> | ||||
| 		</MkKeyValue> | ||||
| 		<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 			<template #key>{{ $ts.administrator }}</template> | ||||
| 			<template #value>{{ instance.maintainerName || `(${$ts.unknown})` }} ({{ instance.maintainerEmail || `(${$ts.unknown})` }})</template> | ||||
| 		</MkKeyValue> | ||||
|  | ||||
| 		<FormButton v-if="$i.isAdmin || $i.isModerator" primary @click="info">{{ $ts.settings }}</FormButton> | ||||
| 		<FormSection v-if="iAmModerator"> | ||||
| 			<template #label>Moderation</template> | ||||
| 			<FormSwitch v-model="suspended" class="_formBlock" @update:modelValue="toggleSuspend">{{ $ts.stopActivityDelivery }}</FormSwitch> | ||||
| 			<FormSwitch :model-value="isBlocked" class="switch" @update:modelValue="changeBlock">{{ $ts.blockThisInstance }}</FormSwitch> | ||||
| 		</FormSection> | ||||
|  | ||||
| 		<FormTextarea readonly :value="instance.description"> | ||||
| 			<span>{{ $ts.description }}</span> | ||||
| 		</FormTextarea> | ||||
|  | ||||
| 		<FormGroup> | ||||
| 			<FormKeyValueView> | ||||
| 				<template #key>{{ $ts.software }}</template> | ||||
| 				<template #value><span class="_monospace">{{ instance.softwareName || `(${$ts.unknown})` }}</span></template> | ||||
| 			</FormKeyValueView> | ||||
| 			<FormKeyValueView> | ||||
| 				<template #key>{{ $ts.version }}</template> | ||||
| 				<template #value><span class="_monospace">{{ instance.softwareVersion || `(${$ts.unknown})` }}</span></template> | ||||
| 			</FormKeyValueView> | ||||
| 		</FormGroup> | ||||
| 		<FormGroup> | ||||
| 			<FormKeyValueView> | ||||
| 				<template #key>{{ $ts.administrator }}</template> | ||||
| 				<template #value><span class="_monospace">{{ instance.maintainerName || `(${$ts.unknown})` }}</span></template> | ||||
| 			</FormKeyValueView> | ||||
| 			<FormKeyValueView> | ||||
| 				<template #key>{{ $ts.contact }}</template> | ||||
| 				<template #value><span class="_monospace">{{ instance.maintainerEmail || `(${$ts.unknown})` }}</span></template> | ||||
| 			</FormKeyValueView> | ||||
| 		</FormGroup> | ||||
| 		<FormGroup> | ||||
| 			<FormKeyValueView> | ||||
| 		<FormSection> | ||||
| 			<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 				<template #key>{{ $ts.registeredAt }}</template> | ||||
| 				<template #value><MkTime mode="detail" :time="instance.caughtAt"/></template> | ||||
| 			</MkKeyValue> | ||||
| 			<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 				<template #key>{{ $ts.updatedAt }}</template> | ||||
| 				<template #value><MkTime mode="detail" :time="instance.infoUpdatedAt"/></template> | ||||
| 			</MkKeyValue> | ||||
| 			<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 				<template #key>{{ $ts.latestRequestSentAt }}</template> | ||||
| 				<template #value><MkTime v-if="instance.latestRequestSentAt" :time="instance.latestRequestSentAt"/><span v-else>N/A</span></template> | ||||
| 			</FormKeyValueView> | ||||
| 			<FormKeyValueView> | ||||
| 			</MkKeyValue> | ||||
| 			<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 				<template #key>{{ $ts.latestStatus }}</template> | ||||
| 				<template #value>{{ instance.latestStatus ? instance.latestStatus : 'N/A' }}</template> | ||||
| 			</FormKeyValueView> | ||||
| 			<FormKeyValueView> | ||||
| 			</MkKeyValue> | ||||
| 			<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 				<template #key>{{ $ts.latestRequestReceivedAt }}</template> | ||||
| 				<template #value><MkTime v-if="instance.latestRequestReceivedAt" :time="instance.latestRequestReceivedAt"/><span v-else>N/A</span></template> | ||||
| 			</FormKeyValueView> | ||||
| 		</FormGroup> | ||||
| 		<FormGroup> | ||||
| 			<FormKeyValueView> | ||||
| 			</MkKeyValue> | ||||
| 		</FormSection> | ||||
| 	 | ||||
| 		<FormSection> | ||||
| 			<MkKeyValue oneline style="margin: 1em 0;"> | ||||
| 				<template #key>Open Registrations</template> | ||||
| 				<template #value>{{ instance.openRegistrations ? $ts.yes : $ts.no }}</template> | ||||
| 			</FormKeyValueView> | ||||
| 		</FormGroup> | ||||
| 		<div class="_debobigegoItem"> | ||||
| 			<div class="_debobigegoLabel">{{ $ts.statistics }}</div> | ||||
| 			<div class="_debobigegoPanel cmhjzshl"> | ||||
| 			</MkKeyValue> | ||||
| 		</FormSection> | ||||
|  | ||||
| 		<FormSection> | ||||
| 			<template #label>{{ $ts.statistics }}</template> | ||||
| 			<div class="cmhjzshl"> | ||||
| 				<div class="selects"> | ||||
| 					<MkSelect v-model="chartSrc" style="margin: 0; flex: 1;"> | ||||
| 					<MkSelect v-model="chartSrc" style="margin: 0 10px 0 0; flex: 1;"> | ||||
| 						<option value="instance-requests">{{ $ts._instanceCharts.requests }}</option> | ||||
| 						<option value="instance-users">{{ $ts._instanceCharts.users }}</option> | ||||
| 						<option value="instance-users-total">{{ $ts._instanceCharts.usersTotal }}</option> | ||||
| @@ -83,86 +84,56 @@ | ||||
| 					</MkSelect> | ||||
| 				</div> | ||||
| 				<div class="chart"> | ||||
| 					<MkChart :src="chartSrc" :span="chartSpan" :limit="90" :detailed="true"></MkChart> | ||||
| 					<MkChart :src="chartSrc" :span="chartSpan" :limit="90" :args="{ host: host }" :detailed="true"></MkChart> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 		<FormGroup> | ||||
| 			<FormKeyValueView> | ||||
| 				<template #key>{{ $ts.registeredAt }}</template> | ||||
| 				<template #value><MkTime mode="detail" :time="instance.caughtAt"/></template> | ||||
| 			</FormKeyValueView> | ||||
| 			<FormKeyValueView> | ||||
| 				<template #key>{{ $ts.updatedAt }}</template> | ||||
| 				<template #value><MkTime mode="detail" :time="instance.infoUpdatedAt"/></template> | ||||
| 			</FormKeyValueView> | ||||
| 		</FormGroup> | ||||
| 		</FormSection> | ||||
|  | ||||
| 		<FormObjectView tall :value="instance"> | ||||
| 			<span>Raw</span> | ||||
| 		</FormObjectView> | ||||
| 		<FormGroup> | ||||
|  | ||||
| 		<FormSection> | ||||
| 			<template #label>Well-known resources</template> | ||||
| 			<FormLink :to="`https://${host}/.well-known/host-meta`" external>host-meta</FormLink> | ||||
| 			<FormLink :to="`https://${host}/.well-known/host-meta.json`" external>host-meta.json</FormLink> | ||||
| 			<FormLink :to="`https://${host}/.well-known/nodeinfo`" external>nodeinfo</FormLink> | ||||
| 			<FormLink :to="`https://${host}/robots.txt`" external>robots.txt</FormLink> | ||||
| 			<FormLink :to="`https://${host}/manifest.json`" external>manifest.json</FormLink> | ||||
| 		</FormGroup> | ||||
| 		<FormSuspense v-slot="{ result: dns }" :p="dnsPromiseFactory"> | ||||
| 			<FormGroup> | ||||
| 				<template #label>DNS</template> | ||||
| 				<FormKeyValueView v-for="record in dns.a" :key="record"> | ||||
| 					<template #key>A</template> | ||||
| 					<template #value><span class="_monospace">{{ record }}</span></template> | ||||
| 				</FormKeyValueView> | ||||
| 				<FormKeyValueView v-for="record in dns.aaaa" :key="record"> | ||||
| 					<template #key>AAAA</template> | ||||
| 					<template #value><span class="_monospace">{{ record }}</span></template> | ||||
| 				</FormKeyValueView> | ||||
| 				<FormKeyValueView v-for="record in dns.cname" :key="record"> | ||||
| 					<template #key>CNAME</template> | ||||
| 					<template #value><span class="_monospace">{{ record }}</span></template> | ||||
| 				</FormKeyValueView> | ||||
| 				<FormKeyValueView v-for="record in dns.txt"> | ||||
| 					<template #key>TXT</template> | ||||
| 					<template #value><span class="_monospace">{{ record[0] }}</span></template> | ||||
| 				</FormKeyValueView> | ||||
| 			</FormGroup> | ||||
| 		</FormSuspense> | ||||
| 	</FormGroup> | ||||
| </FormBase> | ||||
| 			<FormLink :to="`https://${host}/.well-known/host-meta`" external style="margin-bottom: 8px;">host-meta</FormLink> | ||||
| 			<FormLink :to="`https://${host}/.well-known/host-meta.json`" external style="margin-bottom: 8px;">host-meta.json</FormLink> | ||||
| 			<FormLink :to="`https://${host}/.well-known/nodeinfo`" external style="margin-bottom: 8px;">nodeinfo</FormLink> | ||||
| 			<FormLink :to="`https://${host}/robots.txt`" external style="margin-bottom: 8px;">robots.txt</FormLink> | ||||
| 			<FormLink :to="`https://${host}/manifest.json`" external style="margin-bottom: 8px;">manifest.json</FormLink> | ||||
| 		</FormSection> | ||||
| 	</div> | ||||
| </MkSpacer> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import { defineAsyncComponent, defineComponent } from 'vue'; | ||||
| import MkChart from '@/components/chart.vue'; | ||||
| import FormObjectView from '@/components/debobigego/object-view.vue'; | ||||
| import FormTextarea from '@/components/debobigego/textarea.vue'; | ||||
| import FormLink from '@/components/debobigego/link.vue'; | ||||
| import FormBase from '@/components/debobigego/base.vue'; | ||||
| import FormGroup from '@/components/debobigego/group.vue'; | ||||
| import FormButton from '@/components/debobigego/button.vue'; | ||||
| import FormKeyValueView from '@/components/debobigego/key-value-view.vue'; | ||||
| import FormSuspense from '@/components/debobigego/suspense.vue'; | ||||
| import FormTextarea from '@/components/form/textarea.vue'; | ||||
| import FormLink from '@/components/form/link.vue'; | ||||
| import MkLink from '@/components/link.vue'; | ||||
| import FormSection from '@/components/form/section.vue'; | ||||
| import FormButton from '@/components/ui/button.vue'; | ||||
| import MkKeyValue from '@/components/key-value.vue'; | ||||
| import MkSelect from '@/components/form/select.vue'; | ||||
| import FormSwitch from '@/components/form/switch.vue'; | ||||
| import * as os from '@/os'; | ||||
| import number from '@/filters/number'; | ||||
| import bytes from '@/filters/bytes'; | ||||
| import * as symbols from '@/symbols'; | ||||
| import MkInstanceInfo from '@/pages/admin/instance.vue'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		FormBase, | ||||
| 		FormTextarea, | ||||
| 		FormObjectView, | ||||
| 		FormButton, | ||||
| 		FormLink, | ||||
| 		FormGroup, | ||||
| 		FormKeyValueView, | ||||
| 		FormSuspense, | ||||
| 		FormSection, | ||||
| 		FormSwitch, | ||||
| 		MkKeyValue, | ||||
| 		MkSelect, | ||||
| 		MkChart, | ||||
| 		MkLink, | ||||
| 	}, | ||||
|  | ||||
| 	props: { | ||||
| @@ -175,8 +146,9 @@ export default defineComponent({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			[symbols.PAGE_INFO]: { | ||||
| 				title: this.$ts.instanceInfo, | ||||
| 				title: this.host, | ||||
| 				icon: 'fas fa-info-circle', | ||||
| 				bg: 'var(--bg)', | ||||
| 				actions: [{ | ||||
| 					text: `https://${this.host}`, | ||||
| 					icon: 'fas fa-external-link-alt', | ||||
| @@ -186,14 +158,22 @@ export default defineComponent({ | ||||
| 				}], | ||||
| 			}, | ||||
| 			instance: null, | ||||
| 			dnsPromiseFactory: () => os.api('federation/dns', { | ||||
| 				host: this.host | ||||
| 			}), | ||||
| 			suspended: false, | ||||
| 			chartSrc: 'instance-requests', | ||||
| 			chartSpan: 'hour', | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		iAmModerator(): boolean { | ||||
| 			return this.$i && (this.$i.isAdmin || this.$i.isModerator); | ||||
| 		}, | ||||
|  | ||||
| 		isBlocked() { | ||||
| 			return this.instance && this.$instance && this.$instance.blockedHosts && this.$instance.blockedHosts.includes(this.instance.host); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.fetch(); | ||||
| 	}, | ||||
| @@ -206,24 +186,30 @@ export default defineComponent({ | ||||
| 			this.instance = await os.api('federation/show-instance', { | ||||
| 				host: this.host | ||||
| 			}); | ||||
| 			this.suspended = this.instance.isSuspended; | ||||
| 		}, | ||||
|  | ||||
| 		info() { | ||||
| 			os.popup(MkInstanceInfo, { | ||||
| 				instance: this.instance | ||||
| 			}, {}, 'closed'); | ||||
| 		} | ||||
| 		changeBlock(e) { | ||||
| 			os.api('admin/update-meta', { | ||||
| 				blockedHosts: this.isBlocked ? this.meta.blockedHosts.concat([this.instance.host]) : this.meta.blockedHosts.filter(x => x !== this.instance.host) | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		async toggleSuspend(v) { | ||||
| 			await os.api('admin/federation/update-instance', { | ||||
| 				host: this.instance.host, | ||||
| 				isSuspended: this.suspended | ||||
| 			}); | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .fnfelxur { | ||||
| 	padding: 16px; | ||||
|  | ||||
| 	> .icon { | ||||
| 		display: block; | ||||
| 		margin: auto; | ||||
| 		margin: 0; | ||||
| 		height: 64px; | ||||
| 		border-radius: 8px; | ||||
| 	} | ||||
| @@ -232,7 +218,7 @@ export default defineComponent({ | ||||
| .cmhjzshl { | ||||
| 	> .selects { | ||||
| 		display: flex; | ||||
| 		padding: 16px; | ||||
| 		margin: 0 0 16px 0; | ||||
| 	} | ||||
| } | ||||
| </style> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 syuilo
					syuilo