mirror of
https://github.com/EvolutionAPI/evolution-api.git
synced 2025-07-14 01:41:24 -06:00
fix: send buttons cloud api oficial
This commit is contained in:
parent
84451ba3e0
commit
5401ecd2c4
@ -1,6 +1,5 @@
|
||||
import { NumberBusiness } from '@api/dto/chat.dto';
|
||||
import {
|
||||
Button,
|
||||
ContactMessage,
|
||||
MediaMessage,
|
||||
Options,
|
||||
@ -13,7 +12,6 @@ import {
|
||||
SendReactionDto,
|
||||
SendTemplateDto,
|
||||
SendTextDto,
|
||||
TypeButton,
|
||||
} from '@api/dto/sendMessage.dto';
|
||||
import * as s3Service from '@api/integrations/storage/s3/libs/minio.server';
|
||||
import { ProviderFiles } from '@api/provider/sessions';
|
||||
@ -26,14 +24,12 @@ import { Chatwoot, ConfigService, Database, Openai, S3, WaBusiness } from '@conf
|
||||
import { BadRequestException, InternalServerErrorException } from '@exceptions';
|
||||
import { status } from '@utils/renderStatus';
|
||||
import axios from 'axios';
|
||||
import { proto } from 'baileys';
|
||||
import { arrayUnique, isURL } from 'class-validator';
|
||||
import EventEmitter2 from 'eventemitter2';
|
||||
import FormData from 'form-data';
|
||||
import { createReadStream } from 'fs';
|
||||
import mime from 'mime';
|
||||
import { join } from 'path';
|
||||
import { v4 } from 'uuid';
|
||||
|
||||
export class BusinessStartupService extends ChannelStartupService {
|
||||
constructor(
|
||||
@ -1112,97 +1108,42 @@ export class BusinessStartupService extends ChannelStartupService {
|
||||
return audioSent;
|
||||
}
|
||||
|
||||
private toJSONString(button: Button): string {
|
||||
const toString = (obj: any) => JSON.stringify(obj);
|
||||
|
||||
const json = {
|
||||
call: () => toString({ display_text: button.displayText, phone_number: button.phoneNumber }),
|
||||
reply: () => toString({ display_text: button.displayText, id: button.id }),
|
||||
copy: () => toString({ display_text: button.displayText, copy_code: button.copyCode }),
|
||||
url: () =>
|
||||
toString({
|
||||
display_text: button.displayText,
|
||||
url: button.url,
|
||||
merchant_url: button.url,
|
||||
}),
|
||||
};
|
||||
|
||||
return json[button.type]?.() || '';
|
||||
}
|
||||
|
||||
private readonly mapType = new Map<TypeButton, string>([
|
||||
['reply', 'quick_reply'],
|
||||
['copy', 'cta_copy'],
|
||||
['url', 'cta_url'],
|
||||
['call', 'cta_call'],
|
||||
]);
|
||||
|
||||
public async buttonMessage(data: SendButtonsDto) {
|
||||
const generate = await (async () => {
|
||||
if (data?.thumbnailUrl) {
|
||||
return await this.prepareMediaMessage({
|
||||
mediatype: 'image',
|
||||
media: data.thumbnailUrl,
|
||||
});
|
||||
}
|
||||
})();
|
||||
const embeddedMedia: any = {};
|
||||
|
||||
const buttons = data.buttons.map((value) => {
|
||||
return {
|
||||
name: this.mapType.get(value.type),
|
||||
buttonParamsJson: this.toJSONString(value),
|
||||
const btnItems = {
|
||||
text: data.buttons.map((btn) => btn.displayText),
|
||||
ids: data.buttons.map((btn) => btn.id),
|
||||
};
|
||||
});
|
||||
|
||||
const message: proto.IMessage = {
|
||||
viewOnceMessage: {
|
||||
message: {
|
||||
messageContextInfo: {
|
||||
deviceListMetadata: {},
|
||||
deviceListMetadataVersion: 2,
|
||||
},
|
||||
interactiveMessage: {
|
||||
body: {
|
||||
text: (() => {
|
||||
let t = '*' + data.title + '*';
|
||||
if (data?.description) {
|
||||
t += '\n\n';
|
||||
t += data.description;
|
||||
t += '\n';
|
||||
if (!arrayUnique(btnItems.text) || !arrayUnique(btnItems.ids)) {
|
||||
throw new BadRequestException('Button texts cannot be repeated', 'Button IDs cannot be repeated.');
|
||||
}
|
||||
return t;
|
||||
})(),
|
||||
},
|
||||
footer: {
|
||||
text: data?.footer,
|
||||
},
|
||||
header: (() => {
|
||||
if (generate?.message?.imageMessage) {
|
||||
|
||||
return await this.sendMessageWithTyping(
|
||||
data.number,
|
||||
{
|
||||
text: !embeddedMedia?.mediaKey ? data.title : undefined,
|
||||
buttons: data.buttons.map((button) => {
|
||||
return {
|
||||
hasMediaAttachment: !!generate.message.imageMessage,
|
||||
imageMessage: generate.message.imageMessage,
|
||||
type: 'reply',
|
||||
reply: {
|
||||
title: button.displayText,
|
||||
id: button.id,
|
||||
},
|
||||
};
|
||||
}
|
||||
})(),
|
||||
nativeFlowMessage: {
|
||||
buttons: buttons,
|
||||
messageParamsJson: JSON.stringify({
|
||||
from: 'api',
|
||||
templateId: v4(),
|
||||
}),
|
||||
[embeddedMedia?.mediaKey]: embeddedMedia?.message,
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
return await this.sendMessageWithTyping(data.number, message, {
|
||||
{
|
||||
delay: data?.delay,
|
||||
presence: 'composing',
|
||||
quoted: data?.quoted,
|
||||
linkPreview: data?.linkPreview,
|
||||
mentionsEveryOne: data?.mentionsEveryOne,
|
||||
mentioned: data?.mentioned,
|
||||
});
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
public async locationMessage(data: SendLocationDto) {
|
||||
|
@ -2807,8 +2807,6 @@ export class BaileysStartupService extends ChannelStartupService {
|
||||
},
|
||||
};
|
||||
|
||||
console.log(JSON.stringify(message));
|
||||
|
||||
return await this.sendMessageWithTyping(data.number, message, {
|
||||
delay: data?.delay,
|
||||
presence: 'composing',
|
||||
|
Loading…
Reference in New Issue
Block a user