プライバシーポリシー・運営者情報のリンクを追加 (#11925)
* 運営者情報・プライバシーポリシーリンクを追加 * Update Changelog * Run api extractor * プライバシーポリシー・利用規約の同意をまとめる * Update Changelog * fix lint * fix * api extractor * improve design * nodeinfoにプライバシーポリシー・運営者情報を追加
This commit is contained in:
		| @@ -30,13 +30,15 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 				<MkSwitch :modelValue="agreeServerRules" style="margin-top: 16px;" @update:modelValue="updateAgreeServerRules">{{ i18n.ts.agree }}</MkSwitch> | ||||
| 			</MkFolder> | ||||
|  | ||||
| 			<MkFolder v-if="availableTos" :defaultOpen="true"> | ||||
| 				<template #label>{{ i18n.ts.termsOfService }}</template> | ||||
| 				<template #suffix><i v-if="agreeTos" class="ti ti-check" style="color: var(--success)"></i></template> | ||||
| 			<MkFolder v-if="availableTos || availablePrivacyPolicy" :defaultOpen="true"> | ||||
| 				<template #label>{{ tosPrivacyPolicyLabel }}</template> | ||||
| 				<template #suffix><i v-if="agreeTosAndPrivacyPolicy" class="ti ti-check" style="color: var(--success)"></i></template> | ||||
| 				<div class="_gaps_s"> | ||||
| 					<div v-if="availableTos"><a :href="instance.tosUrl" class="_link" target="_blank">{{ i18n.ts.termsOfService }} <i class="ti ti-external-link"></i></a></div> | ||||
| 					<div v-if="availablePrivacyPolicy"><a :href="instance.privacyPolicyUrl" class="_link" target="_blank">{{ i18n.ts.privacyPolicy }} <i class="ti ti-external-link"></i></a></div> | ||||
| 				</div> | ||||
|  | ||||
| 				<a :href="instance.tosUrl" class="_link" target="_blank">{{ i18n.ts.termsOfService }} <i class="ti ti-external-link"></i></a> | ||||
|  | ||||
| 				<MkSwitch :modelValue="agreeTos" style="margin-top: 16px;" @update:modelValue="updateAgreeTos">{{ i18n.ts.agree }}</MkSwitch> | ||||
| 				<MkSwitch :modelValue="agreeTosAndPrivacyPolicy" style="margin-top: 16px;" @update:modelValue="updateAgreeTosAndPrivacyPolicy">{{ i18n.ts.agree }}</MkSwitch> | ||||
| 			</MkFolder> | ||||
|  | ||||
| 			<MkFolder :defaultOpen="true"> | ||||
| @@ -70,14 +72,15 @@ import MkInfo from '@/components/MkInfo.vue'; | ||||
| import * as os from '@/os.js'; | ||||
|  | ||||
| const availableServerRules = instance.serverRules.length > 0; | ||||
| const availableTos = instance.tosUrl != null; | ||||
| const availableTos = instance.tosUrl != null && instance.tosUrl !== ''; | ||||
| const availablePrivacyPolicy = instance.privacyPolicyUrl != null && instance.privacyPolicyUrl !== ''; | ||||
|  | ||||
| const agreeServerRules = ref(false); | ||||
| const agreeTos = ref(false); | ||||
| const agreeTosAndPrivacyPolicy = ref(false); | ||||
| const agreeNote = ref(false); | ||||
|  | ||||
| const agreed = computed(() => { | ||||
| 	return (!availableServerRules || agreeServerRules.value) && (!availableTos || agreeTos.value) && agreeNote.value; | ||||
| 	return (!availableServerRules || agreeServerRules.value) && ((!availableTos && !availablePrivacyPolicy) || agreeTosAndPrivacyPolicy.value) && agreeNote.value; | ||||
| }); | ||||
|  | ||||
| const emit = defineEmits<{ | ||||
| @@ -85,6 +88,18 @@ const emit = defineEmits<{ | ||||
| 	(ev: 'done'): void; | ||||
| }>(); | ||||
|  | ||||
| const tosPrivacyPolicyLabel = computed(() => { | ||||
| 	if (availableTos && availablePrivacyPolicy) { | ||||
| 		return i18n.ts.tosAndPrivacyPolicy; | ||||
| 	} else if (availableTos) { | ||||
| 		return i18n.ts.termsOfService; | ||||
| 	} else if (availablePrivacyPolicy) { | ||||
| 		return i18n.ts.privacyPolicy; | ||||
| 	} else { | ||||
| 		return ""; | ||||
| 	} | ||||
| }); | ||||
|  | ||||
| async function updateAgreeServerRules(v: boolean) { | ||||
| 	if (v) { | ||||
| 		const confirm = await os.confirm({ | ||||
| @@ -99,17 +114,19 @@ async function updateAgreeServerRules(v: boolean) { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| async function updateAgreeTos(v: boolean) { | ||||
| async function updateAgreeTosAndPrivacyPolicy(v: boolean) { | ||||
| 	if (v) { | ||||
| 		const confirm = await os.confirm({ | ||||
| 			type: 'question', | ||||
| 			title: i18n.ts.doYouAgree, | ||||
| 			text: i18n.t('iHaveReadXCarefullyAndAgree', { x: i18n.ts.termsOfService }), | ||||
| 			text: i18n.t('iHaveReadXCarefullyAndAgree', { | ||||
| 				x: tosPrivacyPolicyLabel.value, | ||||
| 			}), | ||||
| 		}); | ||||
| 		if (confirm.canceled) return; | ||||
| 		agreeTos.value = true; | ||||
| 		agreeTosAndPrivacyPolicy.value = true; | ||||
| 	} else { | ||||
| 		agreeTos.value = false; | ||||
| 		agreeTosAndPrivacyPolicy.value = false; | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -104,7 +104,25 @@ function showMenu(ev) { | ||||
| 		action: () => { | ||||
| 			os.pageWindow('/about-misskey'); | ||||
| 		}, | ||||
| 	}, null, { | ||||
| 	}, null, (instance.impressumUrl) ? { | ||||
| 		text: i18n.ts.impressum, | ||||
| 		icon: 'ti ti-file-invoice', | ||||
| 		action: () => { | ||||
| 			window.open(instance.impressumUrl, '_blank'); | ||||
| 		}, | ||||
| 	} : undefined, (instance.tosUrl) ? { | ||||
| 		text: i18n.ts.termsOfService, | ||||
| 		icon: 'ti ti-notebook', | ||||
| 		action: () => { | ||||
| 			window.open(instance.tosUrl, '_blank'); | ||||
| 		}, | ||||
| 	} : undefined, (instance.privacyPolicyUrl) ? { | ||||
| 		text: i18n.ts.privacyPolicy, | ||||
| 		icon: 'ti ti-shield-lock', | ||||
| 		action: () => { | ||||
| 			window.open(instance.privacyPolicyUrl, '_blank'); | ||||
| 		}, | ||||
| 	} : undefined, (!instance.impressumUrl && !instance.tosUrl && !instance.privacyPolicyUrl) ? undefined : null, { | ||||
| 		text: i18n.ts.help, | ||||
| 		icon: 'ti ti-help-circle', | ||||
| 		action: () => { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 かっこかり
					かっこかり