01. DADOS GERAIS

Produto:

TOTVS Saúde Planos

Linha de Produto:

Linha Protheus 

Segmento:

Saúde

Módulo:GESTÃO DE CONTRATOS / FAMÍLIAS
Função:GERENCIADOR DE EMAIL
Issue :DSAUBE-26611


02. 
SITUAÇÃO/REQUISITO

Houve a necessidade de criar uma rotina automatizada para envio de e-mails, garantindo mais eficiência na comunicação e padronização das mensagens enviadas pelo sistema. Durante o processo, identificou-se a importância de permitir a configuração de eventos para disparo automático, assegurando que as notificações sejam enviadas de forma precisa e oportuna.

03. SOLUÇÃO

Gerenciador de E-mails

Personalização de Envio de E-mails

Introdução

O configurador de e-mails é uma ferramenta que permite configurar dados de e-mails utilizados como remetentes em diversas rotinas. Ideal para clientes que desejam personalizar e-mails.

Funcionalidades

Entre as principais funcionalidades do configurador de e-mails, destacam-se:

Layouts em HTML e CSS

Criação de layouts específicos em HTML e CSS para cada configuração.

Configuração de Remetentes

Permite configurar diferentes remetentes para rotinas diferentes ou para uma mesma rotina levando em consideração a operadora, empresa, contrato e subcontrato.

Personalização do Corpo do E-mail

Personaliza o envio de e-mails para diferentes rotinas ou para uma mesma rotina com base na operadora, empresa, contrato e subcontrato.


Tela de configuração de e-mail:

1 - Título Conf. - Título de identificação do Gerenciador de E-mail.

2 - Usu. Conta / Senha - Dados do e-mail remetente que irá enviar o E-mail.

3 - Autentica? - ComboBox que se marcado com Sim  deverá ter os dados do Passo 4 como obrigatório.

4 - Usuario Aut. / Senha Aut. - Usuário de e-mail com dados de autenticação e token de autenticação para liberar o envio de E-mail.


5 - Remetente - Remetente que será enviado o E-mail.

6 - SMTP / Porta - SMTP do E-mail que está sendo configurado como Rementente (No exemplo estamos utilizando Gmail) e a Porta que deve ser usada conforme seleção do Passo 7 (No exemplo, utilizamos a porta SSL).

7 - Utiliza TLS? / Utiliza SSL? - Uma das duas deve estar como Sim para poder fazer a conexão com o SMTP  e deverá ser configurado conforme informações do Passo 6.


8 - Assun. Email - Assunto que irá aparecer no E-mail que será enviado.

9 - Corpo E-mail - Dados do HTML e CSS para personalizar o E-mail que será enviado conforme tópico Código exemplo de HTML para geração do E-mail.

       OBS: Esta função recebe alguns ## que será substituídos por dados dinamicos que serão retornados da Função de Dados.

10 - Func. Dados - Função de dados para extrair informações da rotina para preencher o E-mail.

       OBS: A função de dados deve retornar um objeto JSON onde os atributos devem ser um sequencial de numeral conforme o exemplo no tópico Função de Dados Exemplo.

11 - Funcao Conf. - Função que chamará esse Gerenciador de E-mail (No Exemplo está sendo chamado ao Bloquear um Beneficiário).

       OBS: Esta função não pode ser do tipo static e deverá fazer a chamada da função conforme tópico Função de Configuração


Função de Dados Exemplo:

#INCLUDE "Totvs.ch"

function dados()

	Local cCompHtml   := ""
	oJErrorData         := JsonObject():New()

	cCompHtml += "<tr>"
	cCompHtml += "	<td>" + AllTrim(BA1->BA1_NOMUSR) + "</td>"
	cCompHtml += "	<td>" + DTOC(BA1->BA1_DATINC) + "</td>"
	cCompHtml += "	<td>" + DTOC(BA1->BA1_DATBLO) + "</td>"
	cCompHtml += "</tr>"


	oJErrorData["1"] := BA1->BA1_NOMUSR
	oJErrorData["2"] := BA1->(BA1_CODINT+BA1_CODEMP+BA1_MATRIC+BA1_TIPREG+BA1_DIGITO)
	oJErrorData["3"] := BA1->BA1_EMAIL
	oJErrorData["4"] := BA1->BA1_TELEFO
	oJErrorData["5"] := cCompHtml

Return oJErrorData

Código exemplo de HTML para geração do E-mail

<!DOCTYPE html>
<html lang="pt-BR">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <style>
      body {
        font-family: Arial, sans-serif;
        margin: 0;
        padding: 0;
        background-color: #f4f4f4;
      }
      .container {
        max-width: 600px;
        margin: 40px auto;
        padding: 20px;
        border-radius: 8px;
        background-color: #ffffff;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
      }
      .header,
      .footer {
        background-color: #6c9ebd;
        color: #ffffff;
        text-align: center;
        padding: 10px;
        border-radius: 8px 8px 0 0;
      }
      .footer {
        border-radius: 0 0 8px 8px;
        margin-top: 20px;
        font-size: 14px;
      }
      h2 {
        text-align: center;
        color: #333;
      }
      .info {
        padding: 10px 0;
        font-size: 16px;
        color: #555;
      }
      .info strong {
        color: #222;
      }
      table {
        width: 100%;
        border-collapse: collapse;
        margin-top: 20px;
      }
      th,
      td {
        border: 1px solid #ddd;
        padding: 12px;
        text-align: left;
      }
      th {
        background-color: #6c9ebd;
        color: #ffffff;
      }
      tr:nth-child(even) {
        background-color: #f9f9f9;
      }
      .company-name {
        font-size: 20px;
        color: #333;
        text-align: center;
        margin-bottom: 20px;
        font-weight: bold;
      }
    </style>
  </head>
  <body>
    <div class="container">
      <div class="header">
        <h2>Usuario Bloqueado</h2>
      </div>

      <p class="info">
        <strong>Prezado(a):</strong> ##1, portador da matrícula
        <strong>##2</strong>
      </p>

      <p class="info">Esperamos que esta mensagem o(a) encontre bem.</p>
      <p class="info">
        Verificamos em nosso sistema que seu plano de saúde foi bloqueado devido
        à inadimplência. Conforme a Resolução Normativa nº 593 da ANS (Agência
        Nacional de Saúde Suplementar), o contrato pode ser suspenso ou
        rescindido caso haja atraso superior a 60 dias, consecutivos ou não.
      </p>
      <p class="info">
        Para restabelecer seus serviços de assistência à saúde, é necessário
        regularizar os débitos pendentes. Caso já tenha efetuado o pagamento,
        pedimos a gentileza de desconsiderar esta mensagem.
      </p>
      <p class="info">
        Estamos à disposição para auxiliá-lo(a) no que for necessário.
      </p>

      <table>
        <thead>
          <tr>
            <th>Nome</th>
            <th>Data de Inclusão</th>
            <th>Data de Bloqueio</th>
          </tr>
        </thead>
        <tbody>
          ##5
        </tbody>
      </table>

      <div class="footer">
        <p>
          Entre em contato conosco para mais informações.<br />Email: ##3 |
          Telefone: ##4
        </p>
      </div>
    </div>
  </body>
</html>


Função de Configuração


//Código acima

// instanciando a classe Gerenciadora de E-mail
oemail := totvs.protheus.health.plan.configurator.EmailConfigurator():New()

// Chamada do método responsável por fazer todo o processamento de envio de E-mail.
// param1 = Cod. do ID do gerenciador,
// param2 = email destinatário,
// param3 = Diretório de anexos que deseja enviar no email (Pode receber um array de diretórios),
// param4 = email que você deseja enviar como cópia
ojson := oemail:SendEmailUsingConfigurator(, "[email protected]",, )//Código abaixo

Testando funcionalidade conforme HTML e dados criados:

04. DEMAIS INFORMAÇÕES

Atualização do Dicionário de Dados

inclusão de itens da tabela BZD no Arquivo SX3:

Campo

Tipo

Tamanho

Decimal

Titulo

Descrição

Relação

Usado

Obrigatório

Exibe Browser

Visual

Contexto

VLDUSR

CBox

Help

BZD_FILIALCaracter80

Filial    

Filial do Sistema
NãoNãoNão



Filial do Sistema  

BZD_IDCaracter60

ID Config.

ID Config.NextNumero("BZD", 1, "BZD_ID", .T.)SimSimNãoVisualReal

ID do configurador

BZD_TITCFGCaracter1000

Titulo Conf.  

Titulo da configuracao
SimSimSimAlterarReal

Titulo da configuracao

BZD_REMTNTCaracter2540

Remetente

Remetente
SimSimSimAlterarRealVAZIO() .OR. ValidMail(M->BZD_REMTNT)

Remetente

BZD_SMTPCaracter2540

SMTP

SMTP
SimSimSimAlterarReal

SMTP

BZD_USUARICaracter2540

Usu. Conta

Usuario
SimSimNãoAlterarRealVAZIO() .OR. ValidMail(M->BZD_USUARIO)

Usuario

BZD_SENHACaracter2540

Senha

Senha
SimSimNãoAlterarReal

Senha

BZD_PORTANúmeral60

Porta

Porta
SimSimSimAlterarReal

Porta

BZD_AUTENTCaracter10

Autentica?

Autentica?"1"SimSimNãoAlterarReal
0=Nao;1=Sim

Autentica?

BZD_USUAUTCaracter2540

Usuario Aut.

Usuario Aut.
SimNãoNãoAlterarRealVAZIO() .OR. ValidMail(M->BZD_USUAUT)

Usuario Autenticador

BZD_SENAUTCaracter2540

Senha Aut.

Senha Aut.
SimNãoNãoAlterarReal

Senha Aut.

BZD_ASSUNTCaracter2540

Assun. Email

Assun. Email
SimSimNãoAlterarReal

Assun. Email

BZD_FUNCAOCaracter200

Func. Dados

Func. Dados
SimNãoNãoAlterarReal

Func. Dados

BZD_HTMLMemo100

Corpo E-mail

Corpo E-mail
SimSimNãoAlterarReal

Corpo E-mail

BZD_USERGACaracter170

Log de Alter

Log de Alteracao
NãoNãoNãoVisualReal

Log de Alteração

BZD_USERGICaracter170

Log de Inclu

Log de Inclusao
NãoNãoNãoVisualReal


BZD_TLSCaracter10

Utiliza TLS?

Utiliza TLS?
SimSimNãoAlterarReal
0=Nao;1=Sim

Utiliza TLS?

BZD_SSLCaracter10

Utiliza SSL?

Utiliza SSL?
SimSimNãoAlterarReal
0=Nao;1=Sim

Utiliza SSL?


inclusão de itens da tabela BZD no Arquivo SX3:

Campo

Tipo

Tamanho

Decimal

Titulo

Descrição

Relação

Usado

Obrigatório

Exibe Browser

Visual

Contexto

Help

BZF_FILIALCaracter80

Filial    

Filial do Sistema
NãoNãoNão

Filial do Sistema  

BZF_IDBZDCaracter60

ID cabecalho

ID cabecalhoM->BZD_IDSimNãoNãoVisualReal

ID do cabeçalho

BZF_IDCaracter60

ID registro 

ID registro
SimNãoNãoVisualReal

ID do registro

BZF_FUNCFGCaracter300

Funcao Conf.

Funcao de Configuracao
SimNãoNãoAlterarReal

Função de Configuração

BZF_USERGICaracter170

Log de Inclu

Log de Inclusao
NãoNãoNãoVisualReal

Log de Inclusão

BZF_USERGACaracter170

Log de Alter

Log de Alteracao
NãoNãoNãoVisualReal

Log de Alteração


Inclusão no Arquivo SIX:

Índice

Ordem

Chave

Descrição

BZD1BZD_FILIAL + BZD_IDFilial + ID
BZF1BZF_FILIAL + BZF_FUNCFGFilial + funcao em execucao

Inclusões na tabela SX2 (Tabela):

TabelaBZD
ModoCompartilhado
Modo UnidadeExclusivo
Modo EmpresaExclusivo
Chave ÚnicaBZD_FILIAL + BZD_ID
Nome 

Cabecalho do Config. de email

TabelaBZF
ModoCompartilhado
Modo UnidadeExclusivo
Modo EmpresaExclusivo
Chave ÚnicaBZF_FILIAL + BZF_IDBZD + BZF_FUNCFG
Nome 

Funcoes do Config. de email

05. ASSUNTOS RELACIONADOS

        Não se aplica