ваше сообщение коммита
This commit is contained in:
180
frontend/src/views/settings/AiSettingsView.vue
Normal file
180
frontend/src/views/settings/AiSettingsView.vue
Normal file
@@ -0,0 +1,180 @@
|
||||
<template>
|
||||
<div class="ai-settings settings-panel">
|
||||
<h2>Настройки ИИ</h2>
|
||||
|
||||
<!-- Панель Промт -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки промптов</h3>
|
||||
<div class="setting-form">
|
||||
<p>Здесь будут настройки для конфигурации промптов</p>
|
||||
<textarea v-model="settings.prompt" placeholder="Базовый промпт для ИИ..." rows="5" class="form-control"></textarea>
|
||||
<button class="btn btn-primary" @click="saveSettings('prompt')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель RAG -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки RAG (Retrieval Augmented Generation)</h3>
|
||||
<div class="setting-form">
|
||||
<p>Конфигурация системы поиска и генерации ответов</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">
|
||||
<input type="checkbox" v-model="settings.ragEnabled">
|
||||
Включить RAG
|
||||
</label>
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('rag')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель Каналы -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки каналов для ИИ</h3>
|
||||
<div class="setting-form">
|
||||
<p>Управление каналами связи для ИИ</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">
|
||||
<input type="checkbox" v-model="settings.channels.telegram">
|
||||
Telegram
|
||||
</label>
|
||||
</div>
|
||||
<div class="form-group">
|
||||
<label class="form-label">
|
||||
<input type="checkbox" v-model="settings.channels.email">
|
||||
Email
|
||||
</label>
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('channels')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель Модели -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки моделей ИИ</h3>
|
||||
<div class="setting-form">
|
||||
<p>Выбор и конфигурация моделей ИИ</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Модель по умолчанию:</label>
|
||||
<select v-model="settings.defaultModel" class="form-control">
|
||||
<option value="claude-3-haiku">Claude 3 Haiku</option>
|
||||
<option value="claude-3-sonnet">Claude 3 Sonnet</option>
|
||||
<option value="claude-3-opus">Claude 3 Opus</option>
|
||||
<option value="gpt-4o">GPT-4o</option>
|
||||
</select>
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('models')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
// Логика из AISettings.vue
|
||||
import { reactive, onMounted } from 'vue';
|
||||
// TODO: Импортировать API для загрузки/сохранения
|
||||
|
||||
// Локальное состояние настроек
|
||||
const settings = reactive({
|
||||
prompt: '',
|
||||
ragEnabled: false,
|
||||
channels: {
|
||||
telegram: false,
|
||||
email: false
|
||||
},
|
||||
defaultModel: 'claude-3-sonnet'
|
||||
});
|
||||
|
||||
// Загрузка настроек при монтировании
|
||||
onMounted(() => {
|
||||
loadAiSettings();
|
||||
});
|
||||
|
||||
const loadAiSettings = async () => {
|
||||
console.log('[AiSettingsView] Загрузка настроек ИИ...');
|
||||
// TODO: Заменить на реальный вызов API
|
||||
// Пример:
|
||||
// try {
|
||||
// const response = await api.get('/api/settings/ai');
|
||||
// Object.assign(settings, response.data);
|
||||
// } catch (error) {
|
||||
// console.error('Ошибка загрузки настроек ИИ:', error);
|
||||
// }
|
||||
};
|
||||
|
||||
// Сохранение настроек
|
||||
const saveSettings = async (section) => {
|
||||
console.log(`[AiSettingsView] Сохранение настроек раздела: ${section}`);
|
||||
// TODO: Заменить на реальный вызов API
|
||||
// Пример:
|
||||
// try {
|
||||
// const dataToSave = { [section]: settings[section] }; // Или вся группа настроек
|
||||
// await api.post('/api/settings/ai', dataToSave);
|
||||
// // Показать сообщение об успехе
|
||||
// } catch (error) {
|
||||
// console.error('Ошибка сохранения настроек ИИ:', error);
|
||||
// // Показать сообщение об ошибке
|
||||
// }
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.settings-panel {
|
||||
padding: var(--block-padding);
|
||||
background-color: var(--color-light);
|
||||
border-radius: var(--radius-md);
|
||||
margin-top: var(--spacing-lg);
|
||||
animation: fadeIn var(--transition-normal);
|
||||
}
|
||||
|
||||
h2 {
|
||||
margin-bottom: var(--spacing-lg);
|
||||
border-bottom: 1px solid var(--color-grey-light);
|
||||
padding-bottom: var(--spacing-md);
|
||||
}
|
||||
|
||||
h3 {
|
||||
margin-bottom: var(--spacing-md);
|
||||
color: var(--color-primary);
|
||||
}
|
||||
|
||||
.sub-settings-panel {
|
||||
margin-bottom: var(--spacing-lg);
|
||||
padding-bottom: var(--spacing-lg);
|
||||
border-bottom: 1px dashed var(--color-grey-light);
|
||||
}
|
||||
|
||||
.sub-settings-panel:last-child {
|
||||
border-bottom: none;
|
||||
margin-bottom: 0;
|
||||
padding-bottom: 0;
|
||||
}
|
||||
|
||||
.setting-form {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: var(--spacing-md);
|
||||
}
|
||||
|
||||
.form-group {
|
||||
margin-bottom: 0; /* Убираем лишний отступ, т.к. есть gap */
|
||||
}
|
||||
|
||||
.form-label {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: var(--spacing-sm);
|
||||
}
|
||||
|
||||
.form-control {
|
||||
max-width: 500px; /* Ограничим ширину для select/textarea */
|
||||
}
|
||||
|
||||
.btn-primary {
|
||||
align-self: flex-start;
|
||||
}
|
||||
|
||||
@keyframes fadeIn {
|
||||
from { opacity: 0; }
|
||||
to { opacity: 1; }
|
||||
}
|
||||
</style>
|
||||
123
frontend/src/views/settings/BlockchainSettingsView.vue
Normal file
123
frontend/src/views/settings/BlockchainSettingsView.vue
Normal file
@@ -0,0 +1,123 @@
|
||||
<template>
|
||||
<div class="blockchain-settings settings-panel">
|
||||
<h2>Настройки Блокчейна</h2>
|
||||
|
||||
<!-- Панель Смарт-контракты -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки смарт-контрактов</h3>
|
||||
<div class="setting-form">
|
||||
<p>Управление смарт-контрактами</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Адрес основного контракта:</label>
|
||||
<input type="text" v-model="settings.contractAddress" class="form-control">
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('smartContract')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель Кворум -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки кворума</h3>
|
||||
<div class="setting-form">
|
||||
<p>Настройки кворума для блокчейн-операций</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Минимальный кворум (%):</label>
|
||||
<input type="number" v-model="settings.quorumPercent" min="0" max="100" class="form-control">
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('quorum')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель RWA -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки Real World Assets (RWA)</h3>
|
||||
<div class="setting-form">
|
||||
<p>Конфигурация для работы с реальными активами</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">
|
||||
<input type="checkbox" v-model="settings.rwaEnabled">
|
||||
Включить поддержку RWA
|
||||
</label>
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('rwa')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import { reactive, onMounted } from 'vue';
|
||||
// TODO: Импортировать API
|
||||
|
||||
const settings = reactive({
|
||||
contractAddress: '',
|
||||
quorumPercent: 51,
|
||||
rwaEnabled: false
|
||||
});
|
||||
|
||||
onMounted(() => {
|
||||
loadBlockchainSettings();
|
||||
});
|
||||
|
||||
const loadBlockchainSettings = async () => {
|
||||
console.log('[BlockchainSettingsView] Загрузка настроек блокчейна...');
|
||||
// TODO: API call
|
||||
};
|
||||
|
||||
const saveSettings = async (section) => {
|
||||
console.log(`[BlockchainSettingsView] Сохранение настроек раздела: ${section}`);
|
||||
// TODO: API call
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.settings-panel {
|
||||
padding: var(--block-padding);
|
||||
background-color: var(--color-light);
|
||||
border-radius: var(--radius-md);
|
||||
margin-top: var(--spacing-lg);
|
||||
animation: fadeIn var(--transition-normal);
|
||||
}
|
||||
h2 {
|
||||
margin-bottom: var(--spacing-lg);
|
||||
border-bottom: 1px solid var(--color-grey-light);
|
||||
padding-bottom: var(--spacing-md);
|
||||
}
|
||||
h3 {
|
||||
margin-bottom: var(--spacing-md);
|
||||
color: var(--color-primary);
|
||||
}
|
||||
.sub-settings-panel {
|
||||
margin-bottom: var(--spacing-lg);
|
||||
padding-bottom: var(--spacing-lg);
|
||||
border-bottom: 1px dashed var(--color-grey-light);
|
||||
}
|
||||
.sub-settings-panel:last-child {
|
||||
border-bottom: none;
|
||||
margin-bottom: 0;
|
||||
padding-bottom: 0;
|
||||
}
|
||||
.setting-form {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: var(--spacing-md);
|
||||
}
|
||||
.form-group {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
.form-label {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: var(--spacing-sm);
|
||||
}
|
||||
.form-control {
|
||||
max-width: 500px;
|
||||
}
|
||||
.btn-primary {
|
||||
align-self: flex-start;
|
||||
}
|
||||
@keyframes fadeIn {
|
||||
from { opacity: 0; }
|
||||
to { opacity: 1; }
|
||||
}
|
||||
</style>
|
||||
94
frontend/src/views/settings/InterfaceSettingsView.vue
Normal file
94
frontend/src/views/settings/InterfaceSettingsView.vue
Normal file
@@ -0,0 +1,94 @@
|
||||
<template>
|
||||
<div class="interface-settings settings-panel">
|
||||
<h2>Настройки Интерфейса</h2>
|
||||
|
||||
<!-- Панель Язык -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки языка</h3>
|
||||
<div class="setting-form">
|
||||
<p>Выбор языка интерфейса</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Язык интерфейса:</label>
|
||||
<select v-model="selectedLanguage" class="form-control">
|
||||
<option value="ru">Русский</option>
|
||||
<option value="en">English</option>
|
||||
<!-- Добавить другие языки по необходимости -->
|
||||
</select>
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveLanguageSetting">Сохранить язык</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Другие настройки интерфейса можно добавить сюда -->
|
||||
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import { ref, watch } from 'vue';
|
||||
import { getFromStorage, setToStorage } from '../../utils/storage'; // Путь к utils может отличаться
|
||||
// TODO: Импортировать API для сохранения, если нужно
|
||||
|
||||
const selectedLanguage = ref(getFromStorage('userLanguage', 'ru'));
|
||||
|
||||
// Функция сохранения
|
||||
const saveLanguageSetting = () => {
|
||||
setToStorage('userLanguage', selectedLanguage.value);
|
||||
console.log(`[InterfaceSettingsView] Язык сохранен как: ${selectedLanguage.value}`);
|
||||
// TODO: Добавить реальную смену языка (i18n)
|
||||
// TODO: Возможно, отправить на сервер, если язык влияет на бэкенд
|
||||
// alert('Язык сохранен!'); // Пример уведомления
|
||||
};
|
||||
|
||||
// Можно убрать watch, если сохранение происходит только по кнопке
|
||||
// watch(selectedLanguage, (newLang) => {
|
||||
// setToStorage('userLanguage', newLang);
|
||||
// console.log(`[InterfaceSettingsView] Язык изменен на: ${newLang}`);
|
||||
// });
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.settings-panel {
|
||||
padding: var(--block-padding);
|
||||
background-color: var(--color-light);
|
||||
border-radius: var(--radius-md);
|
||||
margin-top: var(--spacing-lg);
|
||||
animation: fadeIn var(--transition-normal);
|
||||
}
|
||||
h2 {
|
||||
margin-bottom: var(--spacing-lg);
|
||||
border-bottom: 1px solid var(--color-grey-light);
|
||||
padding-bottom: var(--spacing-md);
|
||||
}
|
||||
h3 {
|
||||
margin-bottom: var(--spacing-md);
|
||||
color: var(--color-primary);
|
||||
}
|
||||
.sub-settings-panel {
|
||||
margin-bottom: var(--spacing-lg);
|
||||
padding-bottom: var(--spacing-lg);
|
||||
/* Убираем нижнюю границу, если это последняя панель */
|
||||
}
|
||||
.setting-form {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: var(--spacing-md);
|
||||
}
|
||||
.form-group {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
.form-label {
|
||||
display: block; /* Можно оставить блочным */
|
||||
margin-bottom: var(--spacing-xs);
|
||||
}
|
||||
.form-control {
|
||||
max-width: 300px; /* Ограничим ширину select */
|
||||
}
|
||||
.btn-primary {
|
||||
align-self: flex-start;
|
||||
}
|
||||
@keyframes fadeIn {
|
||||
from { opacity: 0; }
|
||||
to { opacity: 1; }
|
||||
}
|
||||
</style>
|
||||
171
frontend/src/views/settings/SecuritySettingsView.vue
Normal file
171
frontend/src/views/settings/SecuritySettingsView.vue
Normal file
@@ -0,0 +1,171 @@
|
||||
<template>
|
||||
<div class="security-settings settings-panel">
|
||||
<h2>Настройки Безопасности</h2>
|
||||
|
||||
<!-- Панель Авторизация -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки авторизации</h3>
|
||||
<div class="setting-form">
|
||||
<p>Управление параметрами авторизации</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Метод авторизации по умолчанию:</label>
|
||||
<select v-model="settings.defaultAuthMethod" class="form-control">
|
||||
<option value="wallet">Кошелек</option>
|
||||
<option value="email">Email</option>
|
||||
<option value="telegram">Telegram</option>
|
||||
</select>
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('authorization')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель RPC -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки RPC</h3>
|
||||
<div class="setting-form">
|
||||
<p>Настройка RPC-эндпоинтов</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Ethereum RPC:</label>
|
||||
<input type="text" v-model="settings.rpcEndpoints.ethereum" class="form-control">
|
||||
</div>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Polygon RPC:</label>
|
||||
<input type="text" v-model="settings.rpcEndpoints.polygon" class="form-control">
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('rpc')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель Noda -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки Noda</h3>
|
||||
<div class="setting-form">
|
||||
<p>Конфигурация нод</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">
|
||||
<input type="checkbox" v-model="settings.useCustomNode">
|
||||
Использовать собственную ноду
|
||||
</label>
|
||||
</div>
|
||||
<div class="form-group" v-if="settings.useCustomNode">
|
||||
<label class="form-label">URL собственной ноды:</label>
|
||||
<input type="text" v-model="settings.customNodeUrl" class="form-control">
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('noda')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель Хранилище -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки хранилища</h3>
|
||||
<div class="setting-form">
|
||||
<p>Настройки для хранения данных</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Тип хранилища:</label>
|
||||
<select v-model="settings.storageType" class="form-control">
|
||||
<option value="local">Локальное</option>
|
||||
<option value="ipfs">IPFS</option>
|
||||
<option value="arweave">Arweave</option>
|
||||
</select>
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('storage')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Панель CPU -->
|
||||
<div class="sub-settings-panel">
|
||||
<h3>Настройки CPU</h3>
|
||||
<div class="setting-form">
|
||||
<p>Оптимизация использования CPU</p>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Максимальное использование CPU (%):</label>
|
||||
<input type="number" v-model="settings.maxCpuUsage" min="0" max="100" class="form-control">
|
||||
</div>
|
||||
<button class="btn btn-primary" @click="saveSettings('cpu')">Сохранить</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import { reactive, onMounted } from 'vue';
|
||||
// TODO: Импортировать API
|
||||
|
||||
const settings = reactive({
|
||||
defaultAuthMethod: 'wallet',
|
||||
rpcEndpoints: {
|
||||
ethereum: '',
|
||||
polygon: ''
|
||||
},
|
||||
useCustomNode: false,
|
||||
customNodeUrl: '',
|
||||
storageType: 'local',
|
||||
maxCpuUsage: 80
|
||||
});
|
||||
|
||||
onMounted(() => {
|
||||
loadSecuritySettings();
|
||||
});
|
||||
|
||||
const loadSecuritySettings = async () => {
|
||||
console.log('[SecuritySettingsView] Загрузка настроек безопасности...');
|
||||
// TODO: API call
|
||||
};
|
||||
|
||||
const saveSettings = async (section) => {
|
||||
console.log(`[SecuritySettingsView] Сохранение настроек раздела: ${section}`);
|
||||
// TODO: API call
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.settings-panel {
|
||||
padding: var(--block-padding);
|
||||
background-color: var(--color-light);
|
||||
border-radius: var(--radius-md);
|
||||
margin-top: var(--spacing-lg);
|
||||
animation: fadeIn var(--transition-normal);
|
||||
}
|
||||
h2 {
|
||||
margin-bottom: var(--spacing-lg);
|
||||
border-bottom: 1px solid var(--color-grey-light);
|
||||
padding-bottom: var(--spacing-md);
|
||||
}
|
||||
h3 {
|
||||
margin-bottom: var(--spacing-md);
|
||||
color: var(--color-primary);
|
||||
}
|
||||
.sub-settings-panel {
|
||||
margin-bottom: var(--spacing-lg);
|
||||
padding-bottom: var(--spacing-lg);
|
||||
border-bottom: 1px dashed var(--color-grey-light);
|
||||
}
|
||||
.sub-settings-panel:last-child {
|
||||
border-bottom: none;
|
||||
margin-bottom: 0;
|
||||
padding-bottom: 0;
|
||||
}
|
||||
.setting-form {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: var(--spacing-md);
|
||||
}
|
||||
.form-group {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
.form-label {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: var(--spacing-sm);
|
||||
}
|
||||
.form-control {
|
||||
max-width: 500px;
|
||||
}
|
||||
.btn-primary {
|
||||
align-self: flex-start;
|
||||
}
|
||||
@keyframes fadeIn {
|
||||
from { opacity: 0; }
|
||||
to { opacity: 1; }
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user