egirlskey/packages/frontend/src/components/MkUserSetupDialog.Privacy.vue

64 lines
2.1 KiB
Vue
Raw Normal View History

<!--
SPDX-FileCopyrightText: syuilo and other misskey contributors
SPDX-License-Identifier: AGPL-3.0-only
-->
<template>
<div class="_gaps">
<MkInfo>{{ i18n.ts._initialAccountSetting.theseSettingsCanEditLater }}</MkInfo>
2023-05-11 23:20:36 +00:00
<MkFolder>
<template #label>{{ i18n.ts.makeFollowManuallyApprove }}</template>
2023-09-30 19:53:52 +00:00
<template #icon><i class="ph-lock ph-bold ph-lg"></i></template>
2023-05-11 23:20:36 +00:00
<template #suffix>{{ isLocked ? i18n.ts.on : i18n.ts.off }}</template>
2023-05-11 23:20:36 +00:00
<MkSwitch v-model="isLocked">{{ i18n.ts.makeFollowManuallyApprove }}<template #caption>{{ i18n.ts.lockedAccountInfo }}</template></MkSwitch>
</MkFolder>
2023-05-11 23:20:36 +00:00
<MkFolder>
<template #label>{{ i18n.ts.hideOnlineStatus }}</template>
2023-09-30 19:53:52 +00:00
<template #icon><i class="ph-eye-slash ph-bold ph-lg"></i></template>
2023-05-11 23:20:36 +00:00
<template #suffix>{{ hideOnlineStatus ? i18n.ts.on : i18n.ts.off }}</template>
2023-05-11 23:20:36 +00:00
<MkSwitch v-model="hideOnlineStatus">{{ i18n.ts.hideOnlineStatus }}<template #caption>{{ i18n.ts.hideOnlineStatusDescription }}</template></MkSwitch>
</MkFolder>
<MkFolder>
<template #label>{{ i18n.ts.noCrawle }}</template>
2023-09-30 19:53:52 +00:00
<template #icon><i class="ph-planet ph-bold ph-lg"></i></template>
2023-05-11 23:20:36 +00:00
<template #suffix>{{ noCrawle ? i18n.ts.on : i18n.ts.off }}</template>
<MkSwitch v-model="noCrawle">{{ i18n.ts.noCrawle }}<template #caption>{{ i18n.ts.noCrawleDescription }}</template></MkSwitch>
</MkFolder>
<MkInfo>{{ i18n.ts._initialAccountSetting.youCanEditMoreSettingsInSettingsPageLater }}</MkInfo>
</div>
</template>
<script lang="ts" setup>
import { computed, ref, watch } from 'vue';
2023-09-19 07:37:43 +00:00
import { instance } from '@/instance.js';
import { i18n } from '@/i18n.js';
import MkSwitch from '@/components/MkSwitch.vue';
import MkInfo from '@/components/MkInfo.vue';
2023-05-11 23:20:36 +00:00
import MkFolder from '@/components/MkFolder.vue';
2023-09-19 07:37:43 +00:00
import * as os from '@/os.js';
import { $i } from '@/account.js';
let isLocked = ref(false);
let hideOnlineStatus = ref(false);
let noCrawle = ref(false);
2023-11-07 18:23:58 +00:00
watch([isLocked, hideOnlineStatus, noCrawle], () => {
2023-05-11 12:24:27 +00:00
os.api('i/update', {
isLocked: !!isLocked.value,
hideOnlineStatus: !!hideOnlineStatus.value,
noCrawle: !!noCrawle.value,
});
});
</script>
<style lang="scss" module>
</style>