mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-31 13:34:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			193 lines
		
	
	
	
		
			6.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			193 lines
		
	
	
	
		
			6.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <!--
 | |
| SPDX-FileCopyrightText: syuilo and misskey-project
 | |
| SPDX-License-Identifier: AGPL-3.0-only
 | |
| -->
 | |
| 
 | |
| <template>
 | |
| <div>
 | |
| 	<div :class="$style.banner">
 | |
| 		<i class="ti ti-checklist"></i>
 | |
| 	</div>
 | |
| 	<MkSpacer :marginMin="20" :marginMax="28">
 | |
| 		<div class="_gaps_m">
 | |
| 			<div v-if="instance.disableRegistration">
 | |
| 				<MkInfo warn>{{ i18n.ts.invitationRequiredToRegister }}</MkInfo>
 | |
| 			</div>
 | |
| 
 | |
| 			<div style="text-align: center;">
 | |
| 				<div>{{ i18n.ts.pleaseConfirmBelowBeforeSignup }}</div>
 | |
| 				<div style="font-weight: bold; margin-top: 0.5em;">{{ i18n.ts.beSureToReadThisAsItIsImportant }}</div>
 | |
| 			</div>
 | |
| 
 | |
| 			<MkFolder v-if="availableServerRules" :defaultOpen="true">
 | |
| 				<template #label>{{ i18n.ts.serverRules }}</template>
 | |
| 				<template #suffix><i v-if="agreeServerRules" class="ti ti-check" style="color: var(--success)"></i></template>
 | |
| 
 | |
| 				<ol class="_gaps_s" :class="$style.rules">
 | |
| 					<li v-for="item in instance.serverRules" :class="$style.rule"><div :class="$style.ruleText" v-html="sanitizeHtml(item)"></div></li>
 | |
| 				</ol>
 | |
| 
 | |
| 				<MkSwitch :modelValue="agreeServerRules" style="margin-top: 16px;" @update:modelValue="updateAgreeServerRules">{{ i18n.ts.agree }}</MkSwitch>
 | |
| 			</MkFolder>
 | |
| 
 | |
| 			<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 ?? undefined" class="_link" target="_blank">{{ i18n.ts.termsOfService }} <i class="ti ti-external-link"></i></a></div>
 | |
| 					<div v-if="availablePrivacyPolicy"><a :href="instance.privacyPolicyUrl ?? undefined" class="_link" target="_blank">{{ i18n.ts.privacyPolicy }} <i class="ti ti-external-link"></i></a></div>
 | |
| 				</div>
 | |
| 
 | |
| 				<MkSwitch :modelValue="agreeTosAndPrivacyPolicy" style="margin-top: 16px;" @update:modelValue="updateAgreeTosAndPrivacyPolicy">{{ i18n.ts.agree }}</MkSwitch>
 | |
| 			</MkFolder>
 | |
| 
 | |
| 			<MkFolder :defaultOpen="true">
 | |
| 				<template #label>{{ i18n.ts.basicNotesBeforeCreateAccount }}</template>
 | |
| 				<template #suffix><i v-if="agreeNote" class="ti ti-check" style="color: var(--success)"></i></template>
 | |
| 
 | |
| 				<a href="https://activitypub.software/TransFem-org/Sharkey/-/blob/stable/IMPORTANT_NOTES.md" class="_link" target="_blank">{{ i18n.ts.basicNotesBeforeCreateAccount }} <i class="ti ti-external-link"></i></a>
 | |
| 
 | |
| 				<MkSwitch :modelValue="agreeNote" style="margin-top: 16px;" data-cy-signup-rules-notes-agree @update:modelValue="updateAgreeNote">{{ i18n.ts.agree }}</MkSwitch>
 | |
| 			</MkFolder>
 | |
| 
 | |
| 			<div v-if="!agreed" style="text-align: center;">{{ i18n.ts.pleaseAgreeAllToContinue }}</div>
 | |
| 
 | |
| 			<div class="_buttonsCenter">
 | |
| 				<MkButton inline rounded @click="emit('cancel')">{{ i18n.ts.cancel }}</MkButton>
 | |
| 				<MkButton inline primary rounded gradate :disabled="!agreed" data-cy-signup-rules-continue @click="emit('done')">{{ i18n.ts.continue }} <i class="ti ti-arrow-right"></i></MkButton>
 | |
| 			</div>
 | |
| 		</div>
 | |
| 	</MkSpacer>
 | |
| </div>
 | |
| </template>
 | |
| 
 | |
| <script lang="ts" setup>
 | |
| import { computed, ref } from 'vue';
 | |
| import { instance } from '@/instance.js';
 | |
| import { i18n } from '@/i18n.js';
 | |
| import sanitizeHtml from '@/scripts/sanitize-html.js';
 | |
| import MkButton from '@/components/MkButton.vue';
 | |
| import MkFolder from '@/components/MkFolder.vue';
 | |
| import MkSwitch from '@/components/MkSwitch.vue';
 | |
| import MkInfo from '@/components/MkInfo.vue';
 | |
| import * as os from '@/os.js';
 | |
| 
 | |
| const availableServerRules = instance.serverRules.length > 0;
 | |
| const availableTos = instance.tosUrl != null && instance.tosUrl !== '';
 | |
| const availablePrivacyPolicy = instance.privacyPolicyUrl != null && instance.privacyPolicyUrl !== '';
 | |
| 
 | |
| const agreeServerRules = ref(false);
 | |
| const agreeTosAndPrivacyPolicy = ref(false);
 | |
| const agreeNote = ref(false);
 | |
| 
 | |
| const agreed = computed(() => {
 | |
| 	return (!availableServerRules || agreeServerRules.value) && ((!availableTos && !availablePrivacyPolicy) || agreeTosAndPrivacyPolicy.value) && agreeNote.value;
 | |
| });
 | |
| 
 | |
| const emit = defineEmits<{
 | |
| 	(ev: 'cancel'): void;
 | |
| 	(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({
 | |
| 			type: 'question',
 | |
| 			title: i18n.ts.doYouAgree,
 | |
| 			text: i18n.tsx.iHaveReadXCarefullyAndAgree({ x: i18n.ts.serverRules }),
 | |
| 		});
 | |
| 		if (confirm.canceled) return;
 | |
| 		agreeServerRules.value = true;
 | |
| 	} else {
 | |
| 		agreeServerRules.value = false;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| async function updateAgreeTosAndPrivacyPolicy(v: boolean) {
 | |
| 	if (v) {
 | |
| 		const confirm = await os.confirm({
 | |
| 			type: 'question',
 | |
| 			title: i18n.ts.doYouAgree,
 | |
| 			text: i18n.tsx.iHaveReadXCarefullyAndAgree({
 | |
| 				x: tosPrivacyPolicyLabel.value,
 | |
| 			}),
 | |
| 		});
 | |
| 		if (confirm.canceled) return;
 | |
| 		agreeTosAndPrivacyPolicy.value = true;
 | |
| 	} else {
 | |
| 		agreeTosAndPrivacyPolicy.value = false;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| async function updateAgreeNote(v: boolean) {
 | |
| 	if (v) {
 | |
| 		const confirm = await os.confirm({
 | |
| 			type: 'question',
 | |
| 			title: i18n.ts.doYouAgree,
 | |
| 			text: i18n.tsx.iHaveReadXCarefullyAndAgree({ x: i18n.ts.basicNotesBeforeCreateAccount }),
 | |
| 		});
 | |
| 		if (confirm.canceled) return;
 | |
| 		agreeNote.value = true;
 | |
| 	} else {
 | |
| 		agreeNote.value = false;
 | |
| 	}
 | |
| }
 | |
| </script>
 | |
| 
 | |
| <style lang="scss" module>
 | |
| .banner {
 | |
| 	padding: 16px;
 | |
| 	text-align: center;
 | |
| 	font-size: 26px;
 | |
| 	background-color: var(--accentedBg);
 | |
| 	color: var(--accent);
 | |
| }
 | |
| 
 | |
| .rules {
 | |
| 	counter-reset: item;
 | |
| 	list-style: none;
 | |
| 	padding: 0;
 | |
| 	margin: 0;
 | |
| }
 | |
| 
 | |
| .rule {
 | |
| 	display: flex;
 | |
| 	gap: 8px;
 | |
| 	word-break: break-word;
 | |
| 
 | |
| 	&::before {
 | |
| 		flex-shrink: 0;
 | |
| 		display: flex;
 | |
| 		position: sticky;
 | |
| 		top: calc(var(--stickyTop, 0px) + 8px);
 | |
| 		counter-increment: item;
 | |
| 		content: counter(item);
 | |
| 		width: 32px;
 | |
| 		height: 32px;
 | |
| 		line-height: 32px;
 | |
| 		background-color: var(--accentedBg);
 | |
| 		color: var(--accent);
 | |
| 		font-size: 13px;
 | |
| 		font-weight: bold;
 | |
| 		align-items: center;
 | |
| 		justify-content: center;
 | |
| 		border-radius: var(--radius-ellipse);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| .ruleText {
 | |
| 	padding-top: 6px;
 | |
| }
 | |
| </style>
 |