enhance(frontend): tweak control panel
This commit is contained in:
parent
891bbcf475
commit
3df1bb2d71
5 changed files with 175 additions and 145 deletions
|
@ -199,11 +199,6 @@ const menuDef = computed(() => [{
|
||||||
text: i18n.ts.relays,
|
text: i18n.ts.relays,
|
||||||
to: '/admin/relays',
|
to: '/admin/relays',
|
||||||
active: currentPage.value?.route.name === 'relays',
|
active: currentPage.value?.route.name === 'relays',
|
||||||
}, {
|
|
||||||
icon: 'ti ti-ban',
|
|
||||||
text: i18n.ts.instanceBlocking,
|
|
||||||
to: '/admin/instance-block',
|
|
||||||
active: currentPage.value?.route.name === 'instance-block',
|
|
||||||
}, {
|
}, {
|
||||||
icon: 'ti ti-ghost',
|
icon: 'ti ti-ghost',
|
||||||
text: i18n.ts.proxyAccount,
|
text: i18n.ts.proxyAccount,
|
||||||
|
|
|
@ -1,84 +0,0 @@
|
||||||
<!--
|
|
||||||
SPDX-FileCopyrightText: syuilo and misskey-project
|
|
||||||
SPDX-License-Identifier: AGPL-3.0-only
|
|
||||||
-->
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<MkStickyContainer>
|
|
||||||
<template #header><XHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template>
|
|
||||||
<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32">
|
|
||||||
<FormSuspense :p="init">
|
|
||||||
<template v-if="tab === 'block'">
|
|
||||||
<MkTextarea v-model="blockedHosts">
|
|
||||||
<span>{{ i18n.ts.blockedInstances }}</span>
|
|
||||||
<template #caption>{{ i18n.ts.blockedInstancesDescription }}</template>
|
|
||||||
</MkTextarea>
|
|
||||||
</template>
|
|
||||||
<template v-else-if="tab === 'silence'">
|
|
||||||
<MkTextarea v-model="silencedHosts" class="_formBlock">
|
|
||||||
<span>{{ i18n.ts.silencedInstances }}</span>
|
|
||||||
<template #caption>{{ i18n.ts.silencedInstancesDescription }}</template>
|
|
||||||
</MkTextarea>
|
|
||||||
<MkTextarea v-model="mediaSilencedHosts" class="_formBlock">
|
|
||||||
<span>{{ i18n.ts.mediaSilencedInstances }}</span>
|
|
||||||
<template #caption>{{ i18n.ts.mediaSilencedInstancesDescription }}</template>
|
|
||||||
</MkTextarea>
|
|
||||||
</template>
|
|
||||||
<MkButton primary @click="save"><i class="ti ti-device-floppy"></i> {{ i18n.ts.save }}</MkButton>
|
|
||||||
</FormSuspense>
|
|
||||||
</MkSpacer>
|
|
||||||
</MkStickyContainer>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script lang="ts" setup>
|
|
||||||
import { ref, computed } from 'vue';
|
|
||||||
import XHeader from './_header_.vue';
|
|
||||||
import MkButton from '@/components/MkButton.vue';
|
|
||||||
import MkTextarea from '@/components/MkTextarea.vue';
|
|
||||||
import FormSuspense from '@/components/form/suspense.vue';
|
|
||||||
import * as os from '@/os.js';
|
|
||||||
import { misskeyApi } from '@/scripts/misskey-api.js';
|
|
||||||
import { fetchInstance } from '@/instance.js';
|
|
||||||
import { i18n } from '@/i18n.js';
|
|
||||||
import { definePageMetadata } from '@/scripts/page-metadata.js';
|
|
||||||
|
|
||||||
const blockedHosts = ref<string>('');
|
|
||||||
const silencedHosts = ref<string>('');
|
|
||||||
const mediaSilencedHosts = ref<string>('');
|
|
||||||
const tab = ref('block');
|
|
||||||
|
|
||||||
async function init() {
|
|
||||||
const meta = await misskeyApi('admin/meta');
|
|
||||||
blockedHosts.value = meta.blockedHosts.join('\n');
|
|
||||||
silencedHosts.value = meta.silencedHosts.join('\n');
|
|
||||||
mediaSilencedHosts.value = meta.mediaSilencedHosts.join('\n');
|
|
||||||
}
|
|
||||||
|
|
||||||
function save() {
|
|
||||||
os.apiWithDialog('admin/update-meta', {
|
|
||||||
blockedHosts: blockedHosts.value.split('\n') || [],
|
|
||||||
silencedHosts: silencedHosts.value.split('\n') || [],
|
|
||||||
mediaSilencedHosts: mediaSilencedHosts.value.split('\n') || [],
|
|
||||||
|
|
||||||
}).then(() => {
|
|
||||||
fetchInstance(true);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
const headerActions = computed(() => []);
|
|
||||||
|
|
||||||
const headerTabs = computed(() => [{
|
|
||||||
key: 'block',
|
|
||||||
title: i18n.ts.block,
|
|
||||||
icon: 'ti ti-ban',
|
|
||||||
}, {
|
|
||||||
key: 'silence',
|
|
||||||
title: i18n.ts.silence,
|
|
||||||
icon: 'ti ti-eye-off',
|
|
||||||
}]);
|
|
||||||
|
|
||||||
definePageMetadata(() => ({
|
|
||||||
title: i18n.ts.instanceBlocking,
|
|
||||||
icon: 'ti ti-ban',
|
|
||||||
}));
|
|
||||||
</script>
|
|
|
@ -10,61 +10,102 @@ SPDX-License-Identifier: AGPL-3.0-only
|
||||||
<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32">
|
<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32">
|
||||||
<FormSuspense :p="init">
|
<FormSuspense :p="init">
|
||||||
<div class="_gaps_m">
|
<div class="_gaps_m">
|
||||||
<MkSwitch v-model="enableRegistration">
|
<MkSwitch v-model="enableRegistration" @change="onChange_enableRegistration">
|
||||||
<template #label>{{ i18n.ts.enableRegistration }}</template>
|
<template #label>{{ i18n.ts.enableRegistration }}</template>
|
||||||
</MkSwitch>
|
</MkSwitch>
|
||||||
|
|
||||||
<MkSwitch v-model="emailRequiredForSignup">
|
<MkSwitch v-model="emailRequiredForSignup" @change="onChange_emailRequiredForSignup">
|
||||||
<template #label>{{ i18n.ts.emailRequiredForSignup }}</template>
|
<template #label>{{ i18n.ts.emailRequiredForSignup }}</template>
|
||||||
</MkSwitch>
|
</MkSwitch>
|
||||||
|
|
||||||
<FormLink to="/admin/server-rules">{{ i18n.ts.serverRules }}</FormLink>
|
<FormLink to="/admin/server-rules">{{ i18n.ts.serverRules }}</FormLink>
|
||||||
|
|
||||||
<MkInput v-model="tosUrl" type="url">
|
<MkFolder>
|
||||||
<template #prefix><i class="ti ti-link"></i></template>
|
<template #icon><i class="ti ti-lock-star"></i></template>
|
||||||
<template #label>{{ i18n.ts.tosUrl }}</template>
|
|
||||||
</MkInput>
|
|
||||||
|
|
||||||
<MkInput v-model="privacyPolicyUrl" type="url">
|
|
||||||
<template #prefix><i class="ti ti-link"></i></template>
|
|
||||||
<template #label>{{ i18n.ts.privacyPolicyUrl }}</template>
|
|
||||||
</MkInput>
|
|
||||||
|
|
||||||
<MkInput v-model="inquiryUrl" type="url">
|
|
||||||
<template #prefix><i class="ti ti-link"></i></template>
|
|
||||||
<template #label>{{ i18n.ts._serverSettings.inquiryUrl }}</template>
|
|
||||||
<template #caption>{{ i18n.ts._serverSettings.inquiryUrlDescription }}</template>
|
|
||||||
</MkInput>
|
|
||||||
|
|
||||||
<MkTextarea v-model="preservedUsernames">
|
|
||||||
<template #label>{{ i18n.ts.preservedUsernames }}</template>
|
<template #label>{{ i18n.ts.preservedUsernames }}</template>
|
||||||
|
|
||||||
|
<div class="_gaps">
|
||||||
|
<MkTextarea v-model="preservedUsernames">
|
||||||
<template #caption>{{ i18n.ts.preservedUsernamesDescription }}</template>
|
<template #caption>{{ i18n.ts.preservedUsernamesDescription }}</template>
|
||||||
</MkTextarea>
|
</MkTextarea>
|
||||||
|
<MkButton primary @click="save_preservedUsernames">{{ i18n.ts.save }}</MkButton>
|
||||||
|
</div>
|
||||||
|
</MkFolder>
|
||||||
|
|
||||||
<MkTextarea v-model="sensitiveWords">
|
<MkFolder>
|
||||||
|
<template #icon><i class="ti ti-message-exclamation"></i></template>
|
||||||
<template #label>{{ i18n.ts.sensitiveWords }}</template>
|
<template #label>{{ i18n.ts.sensitiveWords }}</template>
|
||||||
|
|
||||||
|
<div class="_gaps">
|
||||||
|
<MkTextarea v-model="sensitiveWords">
|
||||||
<template #caption>{{ i18n.ts.sensitiveWordsDescription }}<br>{{ i18n.ts.sensitiveWordsDescription2 }}</template>
|
<template #caption>{{ i18n.ts.sensitiveWordsDescription }}<br>{{ i18n.ts.sensitiveWordsDescription2 }}</template>
|
||||||
</MkTextarea>
|
</MkTextarea>
|
||||||
|
<MkButton primary @click="save_sensitiveWords">{{ i18n.ts.save }}</MkButton>
|
||||||
|
</div>
|
||||||
|
</MkFolder>
|
||||||
|
|
||||||
<MkTextarea v-model="prohibitedWords">
|
<MkFolder>
|
||||||
|
<template #icon><i class="ti ti-message-x"></i></template>
|
||||||
<template #label>{{ i18n.ts.prohibitedWords }}</template>
|
<template #label>{{ i18n.ts.prohibitedWords }}</template>
|
||||||
|
|
||||||
|
<div class="_gaps">
|
||||||
|
<MkTextarea v-model="prohibitedWords">
|
||||||
<template #caption>{{ i18n.ts.prohibitedWordsDescription }}<br>{{ i18n.ts.prohibitedWordsDescription2 }}</template>
|
<template #caption>{{ i18n.ts.prohibitedWordsDescription }}<br>{{ i18n.ts.prohibitedWordsDescription2 }}</template>
|
||||||
</MkTextarea>
|
</MkTextarea>
|
||||||
|
<MkButton primary @click="save_prohibitedWords">{{ i18n.ts.save }}</MkButton>
|
||||||
|
</div>
|
||||||
|
</MkFolder>
|
||||||
|
|
||||||
<MkTextarea v-model="hiddenTags">
|
<MkFolder>
|
||||||
|
<template #icon><i class="ti ti-eye-off"></i></template>
|
||||||
<template #label>{{ i18n.ts.hiddenTags }}</template>
|
<template #label>{{ i18n.ts.hiddenTags }}</template>
|
||||||
|
|
||||||
|
<div class="_gaps">
|
||||||
|
<MkTextarea v-model="hiddenTags">
|
||||||
<template #caption>{{ i18n.ts.hiddenTagsDescription }}</template>
|
<template #caption>{{ i18n.ts.hiddenTagsDescription }}</template>
|
||||||
</MkTextarea>
|
</MkTextarea>
|
||||||
|
<MkButton primary @click="save_hiddenTags">{{ i18n.ts.save }}</MkButton>
|
||||||
|
</div>
|
||||||
|
</MkFolder>
|
||||||
|
|
||||||
|
<MkFolder>
|
||||||
|
<template #icon><i class="ti ti-eye-off"></i></template>
|
||||||
|
<template #label>{{ i18n.ts.silencedInstances }}</template>
|
||||||
|
|
||||||
|
<div class="_gaps">
|
||||||
|
<MkTextarea v-model="silencedHosts">
|
||||||
|
<template #caption>{{ i18n.ts.silencedInstancesDescription }}</template>
|
||||||
|
</MkTextarea>
|
||||||
|
<MkButton primary @click="save_silencedHosts">{{ i18n.ts.save }}</MkButton>
|
||||||
|
</div>
|
||||||
|
</MkFolder>
|
||||||
|
|
||||||
|
<MkFolder>
|
||||||
|
<template #icon><i class="ti ti-eye-off"></i></template>
|
||||||
|
<template #label>{{ i18n.ts.mediaSilencedInstances }}</template>
|
||||||
|
|
||||||
|
<div class="_gaps">
|
||||||
|
<MkTextarea v-model="mediaSilencedHosts">
|
||||||
|
<template #caption>{{ i18n.ts.mediaSilencedInstancesDescription }}</template>
|
||||||
|
</MkTextarea>
|
||||||
|
<MkButton primary @click="save_mediaSilencedHosts">{{ i18n.ts.save }}</MkButton>
|
||||||
|
</div>
|
||||||
|
</MkFolder>
|
||||||
|
|
||||||
|
<MkFolder>
|
||||||
|
<template #icon><i class="ti ti-ban"></i></template>
|
||||||
|
<template #label>{{ i18n.ts.blockedInstances }}</template>
|
||||||
|
|
||||||
|
<div class="_gaps">
|
||||||
|
<MkTextarea v-model="blockedHosts">
|
||||||
|
<template #caption>{{ i18n.ts.blockedInstancesDescription }}</template>
|
||||||
|
</MkTextarea>
|
||||||
|
<MkButton primary @click="save_blockedHosts">{{ i18n.ts.save }}</MkButton>
|
||||||
|
</div>
|
||||||
|
</MkFolder>
|
||||||
</div>
|
</div>
|
||||||
</FormSuspense>
|
</FormSuspense>
|
||||||
</MkSpacer>
|
</MkSpacer>
|
||||||
<template #footer>
|
|
||||||
<div :class="$style.footer">
|
|
||||||
<MkSpacer :contentMax="700" :marginMin="16" :marginMax="16">
|
|
||||||
<MkButton primary rounded @click="save"><i class="ti ti-check"></i> {{ i18n.ts.save }}</MkButton>
|
|
||||||
</MkSpacer>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
</MkStickyContainer>
|
</MkStickyContainer>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
@ -83,6 +124,7 @@ import { i18n } from '@/i18n.js';
|
||||||
import { definePageMetadata } from '@/scripts/page-metadata.js';
|
import { definePageMetadata } from '@/scripts/page-metadata.js';
|
||||||
import MkButton from '@/components/MkButton.vue';
|
import MkButton from '@/components/MkButton.vue';
|
||||||
import FormLink from '@/components/form/link.vue';
|
import FormLink from '@/components/form/link.vue';
|
||||||
|
import MkFolder from '@/components/MkFolder.vue';
|
||||||
|
|
||||||
const enableRegistration = ref<boolean>(false);
|
const enableRegistration = ref<boolean>(false);
|
||||||
const emailRequiredForSignup = ref<boolean>(false);
|
const emailRequiredForSignup = ref<boolean>(false);
|
||||||
|
@ -90,9 +132,9 @@ const sensitiveWords = ref<string>('');
|
||||||
const prohibitedWords = ref<string>('');
|
const prohibitedWords = ref<string>('');
|
||||||
const hiddenTags = ref<string>('');
|
const hiddenTags = ref<string>('');
|
||||||
const preservedUsernames = ref<string>('');
|
const preservedUsernames = ref<string>('');
|
||||||
const tosUrl = ref<string | null>(null);
|
const blockedHosts = ref<string>('');
|
||||||
const privacyPolicyUrl = ref<string | null>(null);
|
const silencedHosts = ref<string>('');
|
||||||
const inquiryUrl = ref<string | null>(null);
|
const mediaSilencedHosts = ref<string>('');
|
||||||
|
|
||||||
async function init() {
|
async function init() {
|
||||||
const meta = await misskeyApi('admin/meta');
|
const meta = await misskeyApi('admin/meta');
|
||||||
|
@ -102,27 +144,83 @@ async function init() {
|
||||||
prohibitedWords.value = meta.prohibitedWords.join('\n');
|
prohibitedWords.value = meta.prohibitedWords.join('\n');
|
||||||
hiddenTags.value = meta.hiddenTags.join('\n');
|
hiddenTags.value = meta.hiddenTags.join('\n');
|
||||||
preservedUsernames.value = meta.preservedUsernames.join('\n');
|
preservedUsernames.value = meta.preservedUsernames.join('\n');
|
||||||
tosUrl.value = meta.tosUrl;
|
blockedHosts.value = meta.blockedHosts.join('\n');
|
||||||
privacyPolicyUrl.value = meta.privacyPolicyUrl;
|
silencedHosts.value = meta.silencedHosts.join('\n');
|
||||||
inquiryUrl.value = meta.inquiryUrl;
|
mediaSilencedHosts.value = meta.mediaSilencedHosts.join('\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
function save() {
|
function onChange_enableRegistration(value: boolean) {
|
||||||
|
os.apiWithDialog('admin/update-meta', {
|
||||||
|
disableRegistration: !value,
|
||||||
|
}).then(() => {
|
||||||
|
fetchInstance(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function onChange_emailRequiredForSignup(value: boolean) {
|
||||||
|
os.apiWithDialog('admin/update-meta', {
|
||||||
|
emailRequiredForSignup: value,
|
||||||
|
}).then(() => {
|
||||||
|
fetchInstance(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function save_preservedUsernames() {
|
||||||
os.apiWithDialog('admin/update-meta', {
|
os.apiWithDialog('admin/update-meta', {
|
||||||
disableRegistration: !enableRegistration.value,
|
|
||||||
emailRequiredForSignup: emailRequiredForSignup.value,
|
|
||||||
tosUrl: tosUrl.value,
|
|
||||||
privacyPolicyUrl: privacyPolicyUrl.value,
|
|
||||||
inquiryUrl: inquiryUrl.value,
|
|
||||||
sensitiveWords: sensitiveWords.value.split('\n'),
|
|
||||||
prohibitedWords: prohibitedWords.value.split('\n'),
|
|
||||||
hiddenTags: hiddenTags.value.split('\n'),
|
|
||||||
preservedUsernames: preservedUsernames.value.split('\n'),
|
preservedUsernames: preservedUsernames.value.split('\n'),
|
||||||
}).then(() => {
|
}).then(() => {
|
||||||
fetchInstance(true);
|
fetchInstance(true);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function save_sensitiveWords() {
|
||||||
|
os.apiWithDialog('admin/update-meta', {
|
||||||
|
sensitiveWords: sensitiveWords.value.split('\n'),
|
||||||
|
}).then(() => {
|
||||||
|
fetchInstance(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function save_prohibitedWords() {
|
||||||
|
os.apiWithDialog('admin/update-meta', {
|
||||||
|
prohibitedWords: prohibitedWords.value.split('\n'),
|
||||||
|
}).then(() => {
|
||||||
|
fetchInstance(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function save_hiddenTags() {
|
||||||
|
os.apiWithDialog('admin/update-meta', {
|
||||||
|
hiddenTags: hiddenTags.value.split('\n'),
|
||||||
|
}).then(() => {
|
||||||
|
fetchInstance(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function save_blockedHosts() {
|
||||||
|
os.apiWithDialog('admin/update-meta', {
|
||||||
|
blockedHosts: blockedHosts.value.split('\n') || [],
|
||||||
|
}).then(() => {
|
||||||
|
fetchInstance(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function save_silencedHosts() {
|
||||||
|
os.apiWithDialog('admin/update-meta', {
|
||||||
|
silencedHosts: silencedHosts.value.split('\n') || [],
|
||||||
|
}).then(() => {
|
||||||
|
fetchInstance(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function save_mediaSilencedHosts() {
|
||||||
|
os.apiWithDialog('admin/update-meta', {
|
||||||
|
mediaSilencedHosts: mediaSilencedHosts.value.split('\n') || [],
|
||||||
|
}).then(() => {
|
||||||
|
fetchInstance(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
const headerTabs = computed(() => []);
|
const headerTabs = computed(() => []);
|
||||||
|
|
||||||
definePageMetadata(() => ({
|
definePageMetadata(() => ({
|
||||||
|
|
|
@ -34,6 +34,22 @@ SPDX-License-Identifier: AGPL-3.0-only
|
||||||
</MkInput>
|
</MkInput>
|
||||||
</FormSplit>
|
</FormSplit>
|
||||||
|
|
||||||
|
<MkInput v-model="tosUrl" type="url">
|
||||||
|
<template #prefix><i class="ti ti-link"></i></template>
|
||||||
|
<template #label>{{ i18n.ts.tosUrl }}</template>
|
||||||
|
</MkInput>
|
||||||
|
|
||||||
|
<MkInput v-model="privacyPolicyUrl" type="url">
|
||||||
|
<template #prefix><i class="ti ti-link"></i></template>
|
||||||
|
<template #label>{{ i18n.ts.privacyPolicyUrl }}</template>
|
||||||
|
</MkInput>
|
||||||
|
|
||||||
|
<MkInput v-model="inquiryUrl" type="url">
|
||||||
|
<template #prefix><i class="ti ti-link"></i></template>
|
||||||
|
<template #label>{{ i18n.ts._serverSettings.inquiryUrl }}</template>
|
||||||
|
<template #caption>{{ i18n.ts._serverSettings.inquiryUrlDescription }}</template>
|
||||||
|
</MkInput>
|
||||||
|
|
||||||
<MkInput v-model="repositoryUrl" type="url">
|
<MkInput v-model="repositoryUrl" type="url">
|
||||||
<template #label>{{ i18n.ts.repositoryUrl }}</template>
|
<template #label>{{ i18n.ts.repositoryUrl }}</template>
|
||||||
<template #prefix><i class="ti ti-link"></i></template>
|
<template #prefix><i class="ti ti-link"></i></template>
|
||||||
|
@ -196,6 +212,9 @@ const shortName = ref<string | null>(null);
|
||||||
const description = ref<string | null>(null);
|
const description = ref<string | null>(null);
|
||||||
const maintainerName = ref<string | null>(null);
|
const maintainerName = ref<string | null>(null);
|
||||||
const maintainerEmail = ref<string | null>(null);
|
const maintainerEmail = ref<string | null>(null);
|
||||||
|
const tosUrl = ref<string | null>(null);
|
||||||
|
const privacyPolicyUrl = ref<string | null>(null);
|
||||||
|
const inquiryUrl = ref<string | null>(null);
|
||||||
const repositoryUrl = ref<string | null>(null);
|
const repositoryUrl = ref<string | null>(null);
|
||||||
const impressumUrl = ref<string | null>(null);
|
const impressumUrl = ref<string | null>(null);
|
||||||
const pinnedUsers = ref<string>('');
|
const pinnedUsers = ref<string>('');
|
||||||
|
@ -219,6 +238,9 @@ async function init(): Promise<void> {
|
||||||
description.value = meta.description;
|
description.value = meta.description;
|
||||||
maintainerName.value = meta.maintainerName;
|
maintainerName.value = meta.maintainerName;
|
||||||
maintainerEmail.value = meta.maintainerEmail;
|
maintainerEmail.value = meta.maintainerEmail;
|
||||||
|
tosUrl.value = meta.tosUrl;
|
||||||
|
privacyPolicyUrl.value = meta.privacyPolicyUrl;
|
||||||
|
inquiryUrl.value = meta.inquiryUrl;
|
||||||
repositoryUrl.value = meta.repositoryUrl;
|
repositoryUrl.value = meta.repositoryUrl;
|
||||||
impressumUrl.value = meta.impressumUrl;
|
impressumUrl.value = meta.impressumUrl;
|
||||||
pinnedUsers.value = meta.pinnedUsers.join('\n');
|
pinnedUsers.value = meta.pinnedUsers.join('\n');
|
||||||
|
@ -243,6 +265,9 @@ async function save() {
|
||||||
description: description.value,
|
description: description.value,
|
||||||
maintainerName: maintainerName.value,
|
maintainerName: maintainerName.value,
|
||||||
maintainerEmail: maintainerEmail.value,
|
maintainerEmail: maintainerEmail.value,
|
||||||
|
tosUrl: tosUrl.value,
|
||||||
|
privacyPolicyUrl: privacyPolicyUrl.value,
|
||||||
|
inquiryUrl: inquiryUrl.value,
|
||||||
repositoryUrl: repositoryUrl.value,
|
repositoryUrl: repositoryUrl.value,
|
||||||
impressumUrl: impressumUrl.value,
|
impressumUrl: impressumUrl.value,
|
||||||
pinnedUsers: pinnedUsers.value.split('\n'),
|
pinnedUsers: pinnedUsers.value.split('\n'),
|
||||||
|
|
|
@ -462,10 +462,6 @@ const routes: RouteDef[] = [{
|
||||||
path: '/relays',
|
path: '/relays',
|
||||||
name: 'relays',
|
name: 'relays',
|
||||||
component: page(() => import('@/pages/admin/relays.vue')),
|
component: page(() => import('@/pages/admin/relays.vue')),
|
||||||
}, {
|
|
||||||
path: '/instance-block',
|
|
||||||
name: 'instance-block',
|
|
||||||
component: page(() => import('@/pages/admin/instance-block.vue')),
|
|
||||||
}, {
|
}, {
|
||||||
path: '/proxy-account',
|
path: '/proxy-account',
|
||||||
name: 'proxy-account',
|
name: 'proxy-account',
|
||||||
|
|
Loading…
Reference in a new issue