fix: исправлена интеграция платежей через Telegram Stars API
- справлена обработка ответа от эндпоинта /create-invoice-link
- обавлена поддержка JSON-формата ответа с полем invoice_link
- брано промежуточное подтверждение покупки для улучшения UX
- обавлено получение информации о пользователе через /users/{user_id}
- бновлен интерфейс профиля для отображения актуальных данных после оплаты
This commit is contained in:
parent
92424f6902
commit
cde032fd57
@ -89,8 +89,13 @@ const apiService = {
|
||||
throw new Error('Failed to create invoice link');
|
||||
}
|
||||
|
||||
// Предполагаем, что бэкенд возвращает строку с URL инвойса
|
||||
return await response.text();
|
||||
// Парсим ответ как JSON и извлекаем поле invoice_link
|
||||
const data = await response.json();
|
||||
if (!data.invoice_link) {
|
||||
throw new Error('Invalid response format: missing invoice_link field');
|
||||
}
|
||||
|
||||
return data.invoice_link;
|
||||
} catch (error) {
|
||||
console.error('Error creating invoice link:', error);
|
||||
throw error;
|
||||
|
||||
@ -13,23 +13,6 @@ export const paymentService = {
|
||||
const webApp = window.Telegram.WebApp;
|
||||
const userId = getCurrentUserId();
|
||||
|
||||
// Открываем окно оплаты Telegram
|
||||
webApp.showPopup({
|
||||
title: 'Покупка токенов',
|
||||
message: `Вы собираетесь купить пакет "${pack.title}" за ${pack.price} Stars (${pack.priceRub} ₽)`,
|
||||
buttons: [
|
||||
{
|
||||
type: 'ok',
|
||||
text: 'Купить',
|
||||
id: 'buy'
|
||||
},
|
||||
{
|
||||
type: 'cancel',
|
||||
text: 'Отмена'
|
||||
}
|
||||
]
|
||||
}, async (buttonId: string) => {
|
||||
if (buttonId === 'buy') {
|
||||
try {
|
||||
// Получаем ссылку на инвойс от бэкенда
|
||||
const invoiceLink = await apiService.createInvoiceLink(
|
||||
@ -38,7 +21,7 @@ export const paymentService = {
|
||||
pack.tokens + pack.bonusTokens
|
||||
);
|
||||
|
||||
// Открываем встроенный платеж Telegram
|
||||
// Открываем встроенный платеж Telegram без предварительного подтверждения
|
||||
webApp.openInvoice(invoiceLink, async (status: 'paid' | 'cancelled' | 'failed' | 'pending') => {
|
||||
if (status === 'paid') {
|
||||
try {
|
||||
@ -63,6 +46,4 @@ export const paymentService = {
|
||||
webApp.showAlert('Произошла ошибка при создании платежа. Пожалуйста, попробуйте позже.');
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
Loading…
Reference in New Issue
Block a user