mirror of
https://activitypub.software/TransFem-org/Sharkey
synced 2024-12-02 10:47:28 +00:00
ae5d052274
to keep things manageable i merged a lot of one off values into just a handful of common sizes, so some parts of the ui will look different than upstream even with the "Misskey" rounding mode
192 lines
6.2 KiB
Vue
192 lines
6.2 KiB
Vue
<!--
|
|
SPDX-FileCopyrightText: syuilo and other misskey contributors
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
-->
|
|
|
|
<template>
|
|
<div>
|
|
<div :class="$style.banner">
|
|
<i class="ph-check ph-bold ph-lglist"></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="ph-check ph-bold ph-lg" 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="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="ph-check ph-bold pg-lg" 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="ph-arrow-square-out ph-bold ph-lg"></i></a></div>
|
|
<div v-if="availablePrivacyPolicy"><a :href="instance.privacyPolicyUrl" class="_link" target="_blank">{{ i18n.ts.privacyPolicy }} <i class="ph-arrow-square-out ph-bold ph-lg"></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="ph-check ph-bold ph-lg" style="color: var(--success)"></i></template>
|
|
|
|
<a href="https://github.com/transfem-org/JoinSharkey/blob/main/IMPORTANT_NOTES.md" class="_link" target="_blank">{{ i18n.ts.basicNotesBeforeCreateAccount }} <i class="ph-arrow-square-out ph-bold ph-lg"></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="ph-arrow-right ph-bold pg-lg"></i></MkButton>
|
|
</div>
|
|
</div>
|
|
</MkSpacer>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { computed, onMounted, ref, watch } from 'vue';
|
|
import { instance } from '@/instance.js';
|
|
import { i18n } from '@/i18n.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.t('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.t('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.t('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>
|