36 lines
947 B
Vue
36 lines
947 B
Vue
|
|
<script setup lang="ts">
|
||
|
|
import { NSwitch, useMessage } from 'naive-ui'
|
||
|
|
import { useI18n } from 'vue-i18n'
|
||
|
|
import { useSettingsStore } from '@/stores/settings'
|
||
|
|
import SettingRow from './SettingRow.vue'
|
||
|
|
|
||
|
|
const settingsStore = useSettingsStore()
|
||
|
|
const message = useMessage()
|
||
|
|
const { t } = useI18n()
|
||
|
|
|
||
|
|
async function save(values: Record<string, any>) {
|
||
|
|
try {
|
||
|
|
await settingsStore.saveSection('privacy', values)
|
||
|
|
message.success(t('settings.saved'))
|
||
|
|
} catch (err: any) {
|
||
|
|
message.error(t('settings.saveFailed'))
|
||
|
|
}
|
||
|
|
}
|
||
|
|
</script>
|
||
|
|
|
||
|
|
<template>
|
||
|
|
<section class="settings-section">
|
||
|
|
<SettingRow :label="t('settings.privacy.redactPii')" :hint="t('settings.privacy.redactPiiHint')">
|
||
|
|
<NSwitch :value="settingsStore.privacy.redact_pii" @update:value="v => save({ redact_pii: v })" />
|
||
|
|
</SettingRow>
|
||
|
|
</section>
|
||
|
|
</template>
|
||
|
|
|
||
|
|
<style scoped lang="scss">
|
||
|
|
@use '@/styles/variables' as *;
|
||
|
|
|
||
|
|
.settings-section {
|
||
|
|
margin-top: 16px;
|
||
|
|
}
|
||
|
|
</style>
|