e1f9ab77f8
* enhance(frontend): サーバールールのデザイン調整 * enhance(frontend): i18n * enhance(frontend): 利用規約URLの設定を「モデレーション」ページへ移動 * enhance(frontend): サーバールールのデザイン調整 * Update CHANGELOG.md * 不要な差分を削除 * fix(frontend): lint * ui tweak * test: add stories * tweak * test: bind args * test: add interaction tests * fix bug * Update packages/frontend/src/pages/admin/server-rules.vue Co-authored-by: Ebise Lutica <7106976+EbiseLutica@users.noreply.github.com> * Update misskey-js.api.md * chore: windowを明示 * 🎨 * refactor * 🎨 * 🎨 * fix e2e test * 🎨 * 🎨 * fix icon * fix e2e --------- Co-authored-by: Ebise Lutica <7106976+EbiseLutica@users.noreply.github.com> Co-authored-by: Acid Chicken (硫酸鶏) <root@acid-chicken.com>
78 lines
1.8 KiB
Vue
78 lines
1.8 KiB
Vue
<template>
|
|
<MkModalWindow
|
|
ref="dialog"
|
|
:width="500"
|
|
:height="600"
|
|
@close="dialog.close()"
|
|
@closed="$emit('closed')"
|
|
>
|
|
<template #header>{{ i18n.ts.signup }}</template>
|
|
|
|
<div style="overflow-x: clip;">
|
|
<Transition
|
|
mode="out-in"
|
|
:enter-active-class="$style.transition_x_enterActive"
|
|
:leave-active-class="$style.transition_x_leaveActive"
|
|
:enter-from-class="$style.transition_x_enterFrom"
|
|
:leave-to-class="$style.transition_x_leaveTo"
|
|
>
|
|
<template v-if="!isAcceptedServerRule">
|
|
<XServerRules @accept="isAcceptedServerRule = true"/>
|
|
</template>
|
|
<template v-else>
|
|
<XSignup :auto-set="autoSet" @signup="onSignup" @signup-email-pending="onSignupEmailPending"/>
|
|
</template>
|
|
</Transition>
|
|
</div>
|
|
</MkModalWindow>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { } from 'vue';
|
|
import { $ref } from 'vue/macros';
|
|
import XSignup from '@/components/MkSignupDialog.form.vue';
|
|
import XServerRules from '@/components/MkSignupDialog.rules.vue';
|
|
import MkModalWindow from '@/components/MkModalWindow.vue';
|
|
import { i18n } from '@/i18n';
|
|
import { instance } from '@/instance';
|
|
|
|
const props = withDefaults(defineProps<{
|
|
autoSet?: boolean;
|
|
}>(), {
|
|
autoSet: false,
|
|
});
|
|
|
|
const emit = defineEmits<{
|
|
(ev: 'done'): void;
|
|
(ev: 'closed'): void;
|
|
}>();
|
|
|
|
const dialog = $shallowRef<InstanceType<typeof MkModalWindow>>();
|
|
|
|
const isAcceptedServerRule = $ref(false);
|
|
|
|
function onSignup(res) {
|
|
emit('done', res);
|
|
dialog.close();
|
|
}
|
|
|
|
function onSignupEmailPending() {
|
|
dialog.close();
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" module>
|
|
.transition_x_enterActive,
|
|
.transition_x_leaveActive {
|
|
transition: opacity 0.3s cubic-bezier(0,0,.35,1), transform 0.3s cubic-bezier(0,0,.35,1);
|
|
}
|
|
.transition_x_enterFrom {
|
|
opacity: 0;
|
|
transform: translateX(50px);
|
|
}
|
|
.transition_x_leaveTo {
|
|
opacity: 0;
|
|
transform: translateX(-50px);
|
|
}
|
|
</style>
|