Files
DLE/frontend/src/components/BroadcastModal.vue

86 lines
2.9 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!--
Copyright (c) 2024-2025 Тарабанов Александр Викторович
All rights reserved.
This software is proprietary and confidential.
Unauthorized copying, modification, or distribution is prohibited.
For licensing inquiries: info@hb3-accelerator.com
Website: https://hb3-accelerator.com
GitHub: https://github.com/HB3-ACCELERATOR
-->
<template>
<el-dialog v-model="visible" title="Массовая рассылка" width="700px" @close="$emit('close')">
<div v-if="step === 1">
<div style="margin-bottom:1em;">Вы выбрали {{userIds.length}} пользователей для рассылки.</div>
<ChatInterface
v-model:newMessage="message"
:isAdmin="true"
:messages="[]"
:attachments="attachments"
@update:attachments="val => attachments = val"
@send-message="onSend"
:showSendButton="false"
/>
<el-button type="primary" :disabled="!message.trim()" @click="sendBroadcast" :loading="loading">Отправить</el-button>
<el-button @click="$emit('close')" style="margin-left:1em;">Отмена</el-button>
</div>
<div v-else-if="step === 2">
<div v-if="result.success" style="color:green;">Рассылка завершена успешно!</div>
<div v-if="result.errors && result.errors.length" style="color:red;max-height:120px;overflow:auto;">
Ошибки:
<ul>
<li v-for="err in result.errors" :key="err.userId">ID {{err.userId}}: {{err.error}}</li>
</ul>
</div>
<el-button type="primary" @click="closeAndRefresh">Закрыть</el-button>
</div>
</el-dialog>
</template>
<script setup>
import { ref } from 'vue';
import ChatInterface from './ChatInterface.vue';
import messagesService from '../services/messagesService.js';
import { ElMessage } from 'element-plus';
const props = defineProps({ userIds: { type: Array, required: true } });
const visible = ref(true);
const message = ref('');
const attachments = ref([]);
const loading = ref(false);
const step = ref(1);
const result = ref({});
async function sendBroadcast() {
loading.value = true;
const errors = [];
let successCount = 0;
for (const userId of props.userIds) {
try {
await messagesService.broadcastMessage({ userId, message: message.value });
successCount++;
} catch (e) {
errors.push({ userId, error: e?.message || 'Ошибка отправки' });
}
}
result.value = { success: errors.length === 0, errors };
step.value = 2;
loading.value = false;
}
function onSend() {
sendBroadcast();
}
function closeAndRefresh() {
visible.value = false;
setTimeout(() => {
step.value = 1;
result.value = {};
message.value = '';
attachments.value = [];
loading.value = false;
// Сообщаем родителю об успешной рассылке
emit('close');
}, 300);
}
</script>