16.1.0 • Published 7 days ago

dts-backoffice-util v16.1.0

Weekly downloads
113
License
-
Repository
-
Last release
7 days ago

Documentação dos Componentes e Utils

Objetivo

Biblioteca que engloba diversos componentes e serviços utilizados no desenvolvimento HTML/Angular com PO-UI.

Versões

Segue abaixo as últimas versões da Biblioteca, conforme a versão do PO-UI e Angular correspondentes.Detalhes das alterações: [VER CHANGE LOG](https://github.com/ModernizaDatasul/dts-backoffice-util/blob/master/projects/dts-backoffice-util/CHANGELOG.md).

PO-UIAngularVersão dtsBackofficeUtil
v16v1616.1.0
v15v1515.4.1
v14v1414.4.1
v6v136.0.2
v5v125.0.1
v4v114.0.1
v3v103.0.1
v2v92.8.4

Pré-Requisitos

Instalação do Pacote:

npm install dts-backoffice-util

Componentes e Serviços Disponíveis

TranslateService

Objetivo: Realizar o controle do idioma corrente, considerando o que estiver parametrizado no Cadastro de Usuários do Datasul, e caso não esteja informado, será considerado o idioma informado no Browse.

Importação:

import { TranslateService } from 'dts-backoffice-util';

Métodos:

NomeDescrição
getCurrentLanguageRetorna o idioma corrente. Será considerado no primeiro momento a chave "user.language" do localStorage. Caso ela não exista ou seja inválida, será considerado o idioma parametrizado no Browse. Além disso, o idioma deve estar disponível na lista de suportados, conforme métodos "getSuportLanguage".Parâmetros: Não há.Retorno: string
getSuportLanguageRetornar uma lista com os atuais idiomas suportados.Parâmetros: Não há.Retorno: Array(string)

dtsDateFormat

Objetivo: PIPE para formatar datas, ele foi criado pois o PIPE date do angular não consegue formatada datas inferiores a 1901.

Importação: No módulo de funcionalidade importar o módulo abaixo:

@NgModule({
    declarations: [
        ...
    ],
    imports: [
        ...,
        DtsBackofficeUtilsModule
    ],
    providers: [],
    bootstrap: [...]
})

Exemplo de uso:

<po-info p-label="Data"
    [p-value]="date | dtsDateFormat : 'dd/MM/yyyy'">
</po-info>

<po-info p-label="Data"
    [p-value]="date | dtsDateFormat : 'MM/dd/yyyy'">
</po-info>

MenuDatasulService

Objetivo: Interagir com o Menu do Datasul.

Importação:

import { MenuDatasulService } from 'dts-backoffice-util';

constructor(public menuDatasulService: MenuDatasulService) {
}

Métodos:

NomeDescrição
callProgressExecuta uma tela Progress que esteja cadastrada no menu.Importante: Este método realiza uma integração direta com o Menu do Datasul (parte HTML do Menu). Portanto, ele somente funciona quando o projeto está sendo executado por dentro do Menu do Datasul.Parâmetros:- program (object): Objeto com os seguintes atributos:prg (string): Nome do programa no menu.params (Array(object)): Array de Objetos de Parâmetros. O objeto possui dois atributos: "type" com o tipo de dado (character, integer, logical, etc...). E "value" com o conteúdo.Retorno: Não há.
openTHFExecuta uma tela construídas em THF1 que esteja cadastrada no menu.Importante: Este método realiza uma integração direta com o Menu do Datasul (parte HTML do Menu). Portanto, ele somente funciona quando o projeto está sendo executado por dentro do Menu do Datasul.Parâmetros:- externalName (string): Nome EXTERNO do Programa, cadastro de menu.- params (string): Parâmetros que serão adicionados na URL.- parent (boolean): Indica se a tela deve abrir na mesma Aba do Navegador (valor: true) ou em outra Aba do Navegador (valor: false). Obs: Quando a tela abrir na mesma Aba do Navegador, irá abrir em outra Aba do Menu do Datasul.Retorno: Não há.
openPathExecuta uma tela PO-UI que esteja cadastrada no menu.Importante: Este método realiza uma integração direta com o Menu do Datasul (parte HTML do Menu). Portanto, ele somente funciona quando o projeto está sendo executado por dentro do Menu do Datasul.Parâmetros:- programName (string): Nome INTERNO do Programa, código do programa cadastro de menu.- params (string): Parâmetros que serão adicionados na URL.- parent (boolean): Indica se a tela deve abrir na mesma Aba do Navegador (valor: true) ou em outra Aba do Navegador (valor: false). Obs: Quando a tela abrir na mesma Aba do Navegador, irá abrir em outra Aba do Menu do Datasul.Retorno: Não há.
sendNotificationApresenta uma notificação ao usuário.Importante: Este método realiza uma integração direta com o Menu do Datasul (parte HTML do Menu). Portanto, ele somente funciona quando o projeto está sendo executado por dentro do Menu do Datasul.Parâmetros:- notification (object): Objeto com os seguintes atributos:type (string): Tipo de notificação (success, warning, error).title (string): Título da Notificação.detail (string): Descrição da Notificação.Retorno: Não há.
programSecurityVerifica a Segurança do Menu, identificando se o usuário corrente possui acesso a um ou mais programas.Parâmetros:- programName (string ou Array): Nome do Programa cadastro no Menu, que se deseja consultar a segurança. Podendo ser informado uma string simples com o Nome do Programa, ou um Array de strings com a lista de Programas.Retorno: response (Observable(Array)): Array com as informações dos Programas pesquisados. O objeto contido no Array terá dois atributos:programName (string): Nome do Programa no Menu.hasAccess (boolean): Valor "TRUE" ou "FALSE", indicando se o usuário tem acesso ao programa. Obs: Se o programa não estiver cadastro no Menu, o retorno deste atributo será "FALSE".

Exemplo de uso:

// Executando uma tela Progress
program = { 
  prg: 'bas_lote_liquidac_acr',
  params: [
    { type: 'character', value: 'ABC' },
    { type: 'integer', value: '345' }
  ]
};
this.menuDatasulService.callProgress(program);

// Executando uma Tela THF1
this.menuDatasulService.openTHF('dts/mab/activities', '', true);

// Executando uma Tela PO-UI
this.menuDatasulService.openPath('html.creditCardOperator', '1509;10;1', true);

// Disparando uma Notificação
notification = { 
  type: 'success',
  title: 'Operação foi executada com Sucesso.',
  detail: 'A Operação 4343 foi executada conforme parametrizado e finalizou.'
};
this.menuDatasulService.sendNotification(notification);

// Validando a Segurança de um Programa
this.menuDatasulService
  .programSecurity('html.cashControl')
  .subscribe((response: Array<Object>) => {
    console.log('response:', response[0]);
    // Resposta: { programName: "html.cashControl", hasAccess: true }
});

// Validando a Segurança de uma Lista de Programas
let programList = [];
programList.push('pr0590');
programList.push('html.prgNoExist');
programList.push('bas_empresa');

this.menuDatasulService
  .programSecurity(programList)
  .subscribe((response: Array<Object>) => {
    console.log('response:', response);
    /* Resposta:
       [
         0: { programName: "pr0590", hasAccess: false }
         1: { programName: "html.prgNoExist", hasAccess: false }
         2: { programName: "bas_empresa", hasAccess: true }
       ] */
});

TotvsScheduleExecutionComponent

Objetivo: Componente para realização de agendamentos RPW.

Dependências: Para usar esse componente deve ser instalado no projeto o pacote rxjs-compat.

  • npm i rxjs-compat --save

Importação: No módulo da aplicação importar o módulo abaixo:

@NgModule({
    declarations: [
        ...
    ],
    imports: [
        ...,
        DtsBackofficeUtilsModule.forRoot()
    ],
    providers: [],
    bootstrap: [...]
})

Parâmetros:

NomeTipoObrigatórioDescrição
programNamestringSimCódigo de Programa cadastrado no menu, do programa que será executado no RPW.
externalNamestringSimNome completo do Programa que será executado no RPW, diretório + nome externo.Importante: Em virtude do dicionário (Foundation), este parâmetro é limitado a 24 dígitos.
programEMS5booleanNãoIndica se o programa progress é do EMS5.
programStylenumberNãoNúmero que representa o Estilo do Relatório no EMS5.
programVersionstringNãoVersão do programa progress.
parametersArraySimObjeto representando a Temp-Table que será enviada ao progress.
paramDigitDefArrayNãoDefinição da Temp-Table tt-digita. Utilizado apenas pelo EMS2. Para cada campo da tt-digita, deve ser enviado um objeto com o seguinte formato: {"chave": "string", "tipo": "string" }. Onde chave representa o nome do campo, e tipo representa o tipo de dado (exemplo: character, integer, etc...).
paramDigitDataArrayNãoDados que serão enviados e alimentados na tt-digita. Utilizado apenas pelo EMS2.
paramSelectionsArrayNãoParâmetros de Seleção. Utilizado apenas pelo EMS5.
disabledParamsbooleanNãoQuando for igual a "Sim", irá desabilitar todos os campos do Agendamento (Data Execução, Servidor, Repetir ocorrência, etc...).
loadingbooleanNãoQuando for igual a "Sim", irá apresentar a tela de "loading" no momento da criação da agenda até o retorno do serviço.
endExecutionEventEmitterNãoEvento que será disparado ao finalizar o agendamento. Ele irá enviar como parâmetro um objeto da interface IScheduleParameters, contendo os parâmetros informados pelo usuário.

Métodos:

NomeDescrição
setScheduleParametersAtualiza as informações de agendamento com base no objeto que foi enviado como parâmetro.Parâmetros:- schParam (IScheduleParameters): Objeto com as informações do agendamento (Data Execução, Servidor, Repetir ocorrência, etc...).Retorno: Não há.
getScheduleParametersRetorna um objeto da interface IScheduleParameters, contendo os atuais parâmetros informados pelo usuário na tela de agendamento.Parâmetros: Não há.Retorno:- schParam (IScheduleParameters): Objeto com as informações do agendamento (Data Execução, Servidor, Repetir ocorrência, etc...).

Exemplo de Uso:

Em conjunto com o parâmetro endExecution o método setScheduleParameters pode ser utilizado para salvar e recuperar as informações de agendamento informadas pelo usuário.

Definições no HTML:

// EXEMPLO PARA EMS5
<app-totvs-schedule-execution #schParam
  programName="rpt_grp_repres"
  externalName="rpt_grp_repres"        
  programEMS5="true"
  programStyle="40"
  programVersion="1.00.00.004"
  [parameters]="parametersRpw"
  [paramSelections]="paramSelectionsRpw"
  (endExecution)="endExecutionSchedule($event)">
</app-totvs-schedule-execution>

// EXEMPLO PARA EMS2
<app-totvs-schedule-execution #schParam
  programName="pdapi701"
  externalName="pdp/pdapi701.p"
  [parameters]="parametersRpw"
  [paramDigitDef]="paramDigitDefRpw"
  [paramDigitData]="paramDigitDataRpw"
  (endExecution)="endExecutionSchedule($event)">
</app-totvs-schedule-execution>    

Definições no JavaScript:

@ViewChild('schParam', { static: true }) schParam: TotvsScheduleExecutionComponent;

scheduleParams: IScheduleParameters;
parametersRpw = new Array<any>();
paramDigitDefRpw = new Array<any>();
paramDigitDataRpw = new Array<any>();
paramSelectionsRpw = new Array<any>();

ngOnInit(): void {
  this.loadLocalStorage();
  this.schParam.setScheduleParameters(this.scheduleParams);

  this.createParametersRpw();
}

createParametersRpw(): void {
  // Parâmetros
  this.parametersRpw = [
    { chave: 'destino', valor: 2, tipo: 'integer' },
    { chave: 'arquivo', valor: '', tipo: 'character' },
    { chave: 'usuario', valor: 'FERNANDO', tipo: 'character' },
    { chave: 'perfil', valor: 880, tipo: 'integer' }
  ];

  // Definição da tt-digita (EMS2)
  this.paramDigitDefRpw = [
    { chave: 'cod-estab', tipo: 'character' },
    { chave: 'cod-ccusto', tipo: 'integer' }
  ];

  // Dados da tt-digita (EMS2)
  this.paramDigitDataRpw = [
    { "cod-estab": '19', "cod-ccusto": 17 },
    { "cod-estab": '28', "cod-ccusto": 11 },
    { "cod-estab": '73', "cod-ccusto": 90 }
  ];

  // Seleção (Relatório Regra/Exceção do EMS5)
  this.paramSelectionsRpw = [
    { ind_dwb_set_type: "Regra", cod_dwb_set: "estab",
      cod_dwb_set_initial: "01", cod_dwb_set_final: "FF", log_dwb_rule: true },
    { ind_dwb_set_type: "Exceção", cod_dwb_set: "ccusto",
      cod_dwb_set_initial: "30", cod_dwb_set_final: "35", log_dwb_rule: false }
  ]
}

endExecutionSchedule(event): void {
  this.scheduleParams = event;
  this.saveLocalStorage();
}

private saveLocalStorage(): void {
  if (typeof (Storage) === 'undefined') { return; }
  localStorage.setItem('param-maint.schParam', JSON.stringify(this.scheduleParams));
}

private loadLocalStorage(): void {
  if (typeof (Storage) === 'undefined') { return; }
  this.scheduleParams = JSON.parse(localStorage.getItem('param-maint.schParam'));
}

Definições no Progress:

DEFINE TEMP-TABLE tt-param NO-UNDO
  FIELD destino AS INTEGER
  FIELD arquivo AS CHARACTER
  FIELD usuario AS CHARACTER
  FIELD perfil  AS INTEGER.

DEFINE TEMP-TABLE tt-digita NO-UNDO
  FIELD cod-estab  AS CHARACTER
  FIELD cod-ccusto AS INTEGER.

Interfaces:

IScheduleParameters | Nome | Tipo | Descrição | Valor - Label Valor | |-|-|-|-| | executionType | number | Tipo Execução | 1 - Executar Hoje2 - Agendar Execução | | execAppointDate | date | Data Agendada | | | execAppointHour | string | Hora Agendada | | | executionServer | string | Servidor RPW | | | repeatExecution | boolean | Repetir Ocorrência | | | repeatType | number | Tipo Repetição | 1 - Diária2 - Semanal3 - Mensal | | frequency | string | Frequência | "no" - Uma vez no dia"yes" - Várias vezes no dia | | frequencyValue | number | Quantidade da Frequência | | | frequencyType | string | Tipo Frequência | "hour" - Hora(s)"minute" - Minuto(s) | | execAppointHourInit | string | Hora Inicial Frequência | | | execAppointHourFinal | string | Hora Final Frequência | | | selectWeeklys | Array | Dia da SemanaFrequência Semanal | Sunday - DomingoMonday - SegundaTuesday - TerçaWednesday - QuartaThursday - QuintaFriday - SextaSaturday - Sábado | | dayOfMonth | number | Dia do MêsFrequência Mensal | |

TotvsScheduleExecutionService

Objetivo: Serviço que disponibiliza métodos para geração de agendamento e acompanhamento do RPW.

Métodos:

NomeDescrição
createExecutionForNowCria de forma simplificada (poucos parâmetros) um agendamento no RPW, para ser executado "agora" e sem repetição.Parâmetros:- executionParams (IExecutionParameters): Objeto com as informações necessárias para execução do agendamento (Servidor RPW, Programa a ser Executado, etc...).- loading (boolean): Quando for igual a "Sim", irá apresentar a tela de "loading" até finalizar a criação do agendamento.Retorno: Objeto com as informações do Agendamento (Data de Criação, ID interno do Agendamento (jobScheduleID), etc...).
getExecutionByJobScheduleIDRetorna os dados e status de um agendamento com base no seu código interno: JobScheduleID.Parâmetros:- jobScheduleID (string): Código interno da agenda.- loading (boolean): Quando for igual a "Sim", irá apresentar a tela de "loading" até finalizar a busca do agendamento.Retorno: response (Observable(IExecutionStatus)): Objeto com as informações do Agendamento (Data de Criação, ID interno do Agendamento (jobScheduleID), Número da Agenda (executionID) etc...).
getExecutionByExecutionIDRetorna os dados e status de um agendamento com base no número da agenda: executionID.Parâmetros:- executionID (string): Número da agenda.- loading (boolean): Quando for igual a "Sim", irá apresentar a tela de "loading" até finalizar a busca do agendamento.Retorno: response (Observable(IExecutionStatus)): Objeto com as informações do Agendamento (Data de Criação, ID interno do Agendamento (jobScheduleID), Número da Agenda (executionID) etc...).
followUpExcByJobScheduleIDUtilizado para acompanhar a execução do agendamento realizado no RPW, verificando o status da execução, até que ele seja finalizado.Parâmetros:- jobScheduleID (string): ID interno do Agendamento que se deseja acompanhar.- intervalNum (number): Tempo em milisegundos para verificação do status do agendamento. Por exemplo, se for informado 5000, será verificado o status do agendamento em 5 e 5 segundos até a execução terminar.- fncCallBack (Function): Método que será executado após a tela receber o status da execução do agendamento. Ele será executado várias vezes até a execução terminar, no intervalo de tempo determinado no parâmetro intervalNum. Este método irá receber um objeto da interface IExecutionStatus com o status da execução. O método deverá retornar um valor boolean indicando se o processo deve continuar sendo monitorado ou não. Se for retornado "false", o agendamento não será mais monitorado. Observação: Isto não afeta a execução do agendamento no RPW, ele continuará executando normalmente.- loading (boolean): Quando for igual a "Sim", irá apresentar a tela de "loading" até finalizar o acompanhamento do agendamento.Retorno: Não há.
followUpExcByExecutionIDUtilizado para acompanhar a execução do agendamento realizado no RPW, verificando o status da execução, até que ele seja finalizado.Parâmetros:- executionID (string): Número do Agendamento que se deseja acompanhar.- intervalNum (number): Tempo em milisegundos para verificação do status do agendamento. Por exemplo, se for informado 5000, será verificado o status do agendamento em 5 e 5 segundos até a execução terminar.- fncCallBack (Function): Método que será executado após a tela receber o status da execução do agendamento. Ele será executado várias vezes até a execução terminar, no intervalo de tempo determinado no parâmetro intervalNum. Este método irá receber um objeto da interface IExecutionStatus com o status da execução. O método deverá retornar um valor boolean indicando se o processo deve continuar sendo monitorado ou não. Se for retornado "false", o agendamento não será mais monitorado. Observação: Isto não afeta a execução do agendamento no RPW, ele continuará executando normalmente.- loading (boolean): Quando for igual a "Sim", irá apresentar a tela de "loading" até finalizar o acompanhamento do agendamento.Retorno: Não há.
getObjectByValue getFilteredItemsMétodos utilizados pelo componente PO-LOOKUP. Desta forma, é possível utilizar o TotvsScheduleExecutionService para disponibilizar um lookup de Servidor de Execução RPW na tela.

Exemplo de Uso:

Segue abaixo exemplos da geração de agendamento, busca e acompanhamento da execução.

Definições no HTML:

<po-lookup
  p-label="Servidor RPW"
  p-placeholder="Servidor RPW"
  [p-columns]="zoomRpwServiceColumns"
  [p-field-format]="fieldRpwServiceFormat"
  [p-filter-service]="scheduleExecution"
  p-field-label="name"
  p-field-value="code"
  [(ngModel)]="executionServer">
</po-lookup>

Definições no JavaScript:

executionServer: string;
jobScheduleID: string;
executionID: string;
execStatus: string;

zoomRpwServiceColumns: Array<PoLookupColumn> = [
  { property: 'code', label: 'Servidor', type: 'string', width: '20%' },
  { property: 'name', label: 'Descrição', type: 'string', width: '80%' }
];

private schedExecSubscription$: Subscription;

constructor(
  ...
  public scheduleExecution: TotvsScheduleExecutionService
}

fieldRpwServiceFormat(value) {
  return `${value.code} - ${value.name}`;
}

createSchedule(): void {

  // Criar um Agendamento para ser Executado "agora"
  const execParam = new ExecutionParameters();
  execParam.executionServer = executionServer;

  // Exemplo de Parâmetros para o EMS5
  execParam.programName = 'rpt_grp_repres';
  execParam.externalName = 'rpt_grp_repres';
  execParam.programEMS5 = true;
  execParam.programStyle = 40;
  execParam.programVersion = '1.00.00.004';
  execParam.businessParams = [
    { chave: 'cTipoCarga', valor: 'register', tipo: 'character' },
    { chave: 'lCargaTotal', valor: false, tipo: 'logical' },
    { chave: 'dDataCorte', valor: null, tipo: 'date' }
  ];
  // Seleção (Relatório Regra/Exceção do EMS5)
  execParam.paramSelections = [
    { ind_dwb_set_type: "Regra", cod_dwb_set: "estab",
      cod_dwb_set_initial: "01", cod_dwb_set_final: "FF", log_dwb_rule: true },
    { ind_dwb_set_type: "Exceção", cod_dwb_set: "ccusto",
      cod_dwb_set_initial: "30", cod_dwb_set_final: "35", log_dwb_rule: false }
  ];

  // Exemplo de Parâmetros para o EMS2
  execParam.programName = 'pdapi701';
  execParam.externalName = 'pdp/pdapi701.p';
  execParam.businessParams = [
    { chave: 'destino', valor: 2, tipo: 'integer' },
    { chave: 'arquivo', valor: '', tipo: 'character' },
    { chave: 'usuario', valor: 'FERNANDO', tipo: 'character' },
    { chave: 'perfil', valor: 880, tipo: 'integer' }
  ];
  // Definição da tt-digita (EMS2)
  execParam.paramDigitDef = [
    { chave: 'cod-estab', tipo: 'character' },
    { chave: 'cod-ccusto', tipo: 'integer' }
  ];
  // Dados da tt-digita (EMS2)
  execParam.paramDigitData = [
    { "cod-estab": '19', "cod-ccusto": 17 },
    { "cod-estab": '28', "cod-ccusto": 11 },
    { "cod-estab": '73', "cod-ccusto": 90 }
  ];

  this.schedExecSubscription$ = this.scheduleExecution
    .createExecutionForNow(execParam, true)
    .subscribe((response: any) => {

      // Guarda o ID do Agendamento para fazer o acompanhamento
      this.jobScheduleID = response.jobScheduleID;
    });
}

getExecution(type: string): void {

  if (type === 'jobScheduleID') {
    this.schedExecSubscription$ = this.scheduleExecution
      .getExecutionByJobScheduleID(this.jobScheduleID, true)
      .subscribe((response: IExecutionStatus) => {

        if (response) {
          // Guarda o Número do Agendamento e o Status
          this.executionID = response.executionID;
          this.execStatus = response.status;
        } else {
          this.executionID = 'Não Encontrado !';
          this.execStatus = '';
        }
      });
  }

  if (type === 'executionID') {
    this.schedExecSubscription$ = this.scheduleExecution
      .getExecutionByExecutionID(this.executionID, true)
      .subscribe((response: IExecutionStatus) => {

        if (response) {
          // Guarda o ID interno do Agendamento e o Status
          this.jobScheduleID = response.jobScheduleID;
          this.execStatus = response.status;          
        } else {
          this.jobScheduleID = 'Não Encontrado !';
          this.execStatus = '';
        }
      });
  }
}

followUp(type: string): void {

  if (type === 'jobScheduleID') {
    // Inicia o Acompanhamento
    this.scheduleExecution.followUpExcByJobScheduleID(this.jobScheduleID, 5000, this.followUpCallBack.bind(this));
  }

  if (type === 'executionID') {
    // Inicia o Acompanhamento
    this.scheduleExecution.followUpExcByExecutionID(this.executionID, 5000, this.followUpCallBack.bind(this));
  }
}

followUpCallBack(execStatus: IExecutionStatus): boolean {
  // Verifica o Status do Agendamento
  switch (execStatus.status) {
    case 'PENDING': // Ainda não iniciou

      console.log('Esta esperando para executar...');
      break;

    case 'RUNNING': // Em execução

      console.log('Esta rodando...');
      break;

    case 'SUCCESS': // Terminou OK

      console.log('Terminou OK...');
      break;

    case 'FAILURE': // Terminou com Erro

      console.log('Terminou com o erro:', execStatus.error);
      break;
  }

  return true; // Continua monitorando - retornar "false" para parar o monitoramento
}

Definições no Progress:

DEFINE TEMP-TABLE tt-param NO-UNDO
  FIELD destino AS INTEGER
  FIELD arquivo AS CHARACTER
  FIELD usuario AS CHARACTER
  FIELD perfil  AS INTEGER.

DEFINE TEMP-TABLE tt-digita NO-UNDO
  FIELD cod-estab  AS CHARACTER
  FIELD cod-ccusto AS INTEGER.

Interfaces:

IExecutionParameters | Nome | Tipo | Obrigatório | Descrição | |-|-|-|-| | executionServer | string | Sim | Código do Servidor RPW. | | programName | string | Sim | Código de Programa cadastrado no menu, do programa que será executado no RPW. | | externalName | string | Sim | Nome completo do Programa que será executado no RPW, diretório + nome externo.Importante: Em virtude do dicionário (Foundation), este parâmetro é limitado a 24 dígitos. | | programEMS5 | boolean | Não | Indica se o programa progress é do EMS5. | | programStyle | number | Não | Número que representa o Estilo do Relatório no EMS5. | | programVersion | string | Não | Versão do programa progress. | | businessParams | Array | Não | Objeto representando a Temp-Table que será enviada ao progress. | | paramDigitDef | Array | Não | Definição da Temp-Table tt-digita. Utilizado apenas pelo EMS2. Para cada campo da tt-digita, deve ser enviado um objeto com o seguinte formato: {"chave": "string", "tipo": "string" }. Onde chave representa o nome do campo, e tipo representa o tipo de dado (exemplo: character, integer, etc...). | | paramDigitData | Array | Não | Dados que serão enviados e alimentados na tt-digita. Utilizado apenas pelo EMS2. | | paramSelections | Array | Não | Parâmetros de Seleção. Utilizado apenas pelo EMS5. |

IExecutionStatus | Nome | Tipo | Descrição | |-|-|-| | jobScheduleID | string | ID Interno do Agendamento. | | executionID | string | Número da Agenda (código da execução). Pode ser utilizado para, por exemplo, apresentar ao usuário, assim ele pode realizar a consulta dos detalhes da execução através do Monitor de Pedido de Execução (programa padrão do Foundation). | | startedDate | Date | Data e hora em que o agendamento iniciou a execução no RPW. | | error | string | Quando o status for igual a 'FAILURE', esta propriedade terá a descrição do erro. | | status | string | Status da execução, podendo ser:- PENDING: O agendamento está enfileirado, aguardando o início da execução.- RUNNING: O agendamento está em execução.- SUCCESS: O agendamento terminou corretamente, sem erros.- FAILURE: O agendamento terminou com erro. A descrição do erro estará disponível na propriedade error. Observação: Caso não exista um agendamento com o ID informado, também será retornar este status de erro. |


ProfileService

Objetivo: Salvar preferências do usuário.

Importação:

import { ProfileService, IProfile } from 'dts-backoffice-util';

constructor(public preferenceService: ProfileService) {
}

Métodos:

NomeDescrição
setProfileSalva informações no profile do usuário.Parâmetros:- profile (IProfile): Objeto com as informações do usuário e as informações serem salvas.Retorno:- response (Observable(any)): Retorno do BackEnd.
getProfileAsStringRetorna os valores salvos no formato de uma string.Parâmetros:- profile (IProfile): Objeto com as informações do usuário.- showLoading (boolean): Indica se deve apresentar a tela de loading enquanto busca as informações.Retorno:- response (Observable(string)): Informações salvas.
getProfileAsJSONRetorna os valores salvos no formato de um JSON.Parâmetros:- profile (IProfile): Objeto com as informações do usuário.- showLoading (boolean): Indica se deve apresentar a tela de loading enquanto busca as informações.Retorno:- response (Observable(object)): Informações salvas.

Interfaces:

IProfile | Nome | Tipo | Obrigatório | Descrição | |-|-|-|-| | pageId | string | Sim | Um ID para identificar a Tela que está salvando os parâmetros. | | userCode | string | Sim | Código do usuário (login). | | dataCode | string | Sim | Um ID para identificar o parâmetro. |

| dataValue | string | Não | Valor a ser salvo, nos GET's é opcional. |

Exemplo de Uso:

const profile: IProfile = {
  pageId: 'about-component',
  userCode: 'super',
  dataCode: 'preference',
  dataValue: this.preference
};

this.preferenceService
  .setProfile(profile)
  .subscribe((response) => {
  this.notification.success('Preferência salva com sucesso!');
}, (error) => {
  this.notification.error('Não foi possível salvar a preferência');
});

UserLoginService

Objetivo: Retorna o login do usuário tanto no framework atual e quanto no novo framework.

Importação:

import { UserLoginService } from 'dts-backoffice-util';

constructor( public sessionService: UserLoginService) {
}

Métodos:

NomeDescrição
getUserLoginRetorna o login do usuário.Parâmetros: Não há.Retorno:- response (Observable(string))

Exemplo de Uso:

this.sessionService
  .getUserLogin()
  .subscribe((user) => {
  this.notification.success(`O usuário logado é ${user}`);
});

ReportService

Objetivo: Faz a chamada do datasul-report e realiza o download do arquivo caso seja especificado.

Importação:

import { 
  ReportService, 
  IReportServiceParams, 
  ReportFormats
} from 'dts-backoffice-util';

constructor(public reportService: ReportService) {
}

Métodos:

NomeDescrição
generateRetorna o arquivo binário gerado pelo datasul-report e faz o download do arquivo.Parâmetros:- params (IReportServiceParams): Parâmetros para execução do relatório.- showLoading (boolean): Indica se deve apresentar a tela de loading enquanto busca as informações.Retorno:- response (Observable(Blob))

Interfaces:

IReportServiceParams

NomeTipoObrigatórioDescrição
reportNamestringSimNome do arquivo .rptDesign
programNamestringSimNome do programa progress.
propertiesArraySimLista de parâmetros que serão enviados ao progress. O objeto do Array deve implementar a interface IProperty.
dialectstringSimIdioma do usuário.
downloadNamestringSimNome que será dado ao arquivo de download.
downloadbooleanSimO download deve ser efetuado
formatenumSimFormato do Arquivo (XLSX, PDF, DOCX ou HTML). Enum: ReportFormats.

IProperty

NomeTipoObrigatórioDescrição
namestringSimNome do parâmetro
valuestringSimValor do parâmetro

Enums

declare enum ReportFormats {
    XLSX = "xlsx",
    PDF = "pdf",
    DOCX = "docx",
    HTML = "html"
}

Exemplo de Uso:

const properties: Array<IProperty> = [
  { 
    name: 'custom.quick_search', 
    value: '186'
  }
];

const params: IReportServiceParams = {
  reportName: 'crm/rel_campaign_export',
  programName: '/report/crm/crm0010',
  properties,
  dialect: 'pt',
  download: true,
  downloadName: '2020-1-10_13-51-53_CRM_CAMPANHAS',
  format: ReportFormats.XLSX
};

this.reportService
  .generate(params)
  .subscribe(() => {
  this.notification.error("Arquivo baixado com sucesso!");
}, () => {
  this.notification.error("Não foi possível baixar o arquivo");
});

BreadcrumbControlService

Objetivo: Realiza a criação e controle do breadcrumb das telas.

Importação:

import { BreadcrumbControlService } from 'dts-backoffice-util';

Métodos:

NomeDescrição
newBreadcrumb"Reinicia" o breadcrumb quando necessário. Ex: Telas que possuem menu lateral, ao passar de um menu para outro, o breadcrumb deve ser reiniciado.Parâmetros: Não há.Retorno: Não há.
addBreadcrumbAdiciona um item ao breadcrumb, considerando a URL atual da tela.Parâmetros:- literal (string): Nome da tela que será apresentado no breadcrumb.- activatedRoute (ActivatedRoute): ActivedRoute da tela.Retorno: Não há.
addBreadcrumbURLAdiciona um item ao breadcrumb, informando uma URL específica.Parâmetros:- literal (string): Nome da tela que será apresentado no breadcrumb.- url (string): URL específica.Retorno: Não há.
updBreadcrumbURLAltera uma informação qualquer contida na URL do item informado.Parâmetros:- literal (string): Nome da tela que está no breadcrumb.- valueOld (string): Valor a ser substituído.- valueNew (string): Novo valor.Retorno: Não há.
delBreadcrumbExclui um item do breadcrumb.Parâmetros:- literal (string): Nome do item (nome da tela), que deve ser excluído do breadcrumb.Retorno: Não há.
getBreadcrumbRetorna o breadcrumb atual completo.Parâmetros: Não há.Retorno:- breadcrumb (PoBreadcrumb)
getCurrentRouterRetorna a URL do breadcrumb do item corrente.Parâmetros: Não há.Retorno:- url (string)
getPrevRouterRetorna a URL do breadcrumb do item anterior.Parâmetros: Não há.Retorno:- url (string)
hasPreviousRouterIndica se existe um item de breadcrumb anterior.Parâmetros: Não há.Retorno:- exist (boolean)

DateUtil

Objetivo: Manipula informações de data.

Importação:

import { DateUtil } from 'dts-backoffice-util';

Métodos:

NomeDescrição
dateToQueryParamTransforma uma data para o padrão YYYY-MM-DD.Parâmetros:- date (Date): Data.Retorno:- date (string)
queryParamToDateTransforma uma data no padrão YYYY-MM-DD para objeto Date.Parâmetros:- date (string): Data.Retorno:- date (Date)
isValidDateVerifica se a data é válida.Parâmetros:- date (Date): Data.Retorno:- valid (boolean)
ajustDateAjusta a data retornando no padrão do objeto Date.Parâmetros:- param (any): Data.Retorno:- date (date)
ajustDateToModelAjusta a data para o padrão do objeto Date. Utilizado nos construtores dos modelos.Parâmetros:- object (object): Objeto que possui atributos do tipo data.- fieldName (string): Nome do Atributo que possui a data.Retorno:- date (date)
padAdiciona zero à esquerda do número.Parâmetros:- number (number): Número.Retorno:- number (string)

FileUtil

Objetivo: Auxílio na manipulação de Arquivos.

Importação:

import { FileUtil } from 'dts-backoffice-util';

Métodos:

NomeDescrição
downloadFileRealiza o Download de um arquivo que foi enviado do backEnd.Parâmetros:- data (any): Conteúdo do Arquivo, podendo estar no formato Base64 ou Blob.- fileName (string): Nome do Arquivo, podendo ser diferente do nome original. O valor informado, será o nome que o arquivo terá, quando for realizado o download.- contentType (string): Tipo do Arquivo no formato MIME Type. Este parâmetro é opcional, mas quando não informado, deve-se garantir que a extensão do arquivo, informado no nome do arquivo, esteja correta.- base64 (boolean): Indica se o conteúdo do arquivo está no formato Base64. Se o parâmetro não for informado ou for igual a "true", será considerado como Base64. Se for informado "false", será considerado o formato Blob.Retorno: não há.
downloadDataRealiza a criação e o download de um arquivo CSV gerado a partir de um listagem de dados (criada diretamente no FrontEnd ou retornada do BackEnd). Este método pode ser utilizado para, por exemplo, exportar os dados de um Grid.Parâmetros:- data (Array): Um Array com a listagem de dados, por exemplo, uma lista de clientes.- dwldDataParam (IDownloadDataParams): Parâmetros de configuração do arquivo. Este parâmetro é opcional, caso ele não seja informado, serão assumidos valores padrões de configuração, conforme descrito na inteface IDownloadDataParams.Retorno: não há.
fileToB64Realiza a conversão de um arquivo para o formato Base64.Parâmetros:- file (File): Objeto do Tipo "File".Retorno:- content (string): Conteúdo do arquivo no formato Base64.
b64toBlobRealiza a conversão de um arquivo que está no formato Base64, para o formato Blob.Parâmetros:- b64Data (any): Conteúdo do Arquivo no formato Base64.- contentType (string): Tipo do Arquivo no formato MIME Type. Este parâmetro é opcional.Retorno:- content (Blob): Conteúdo do arquivo no formato Blob.

Exemplo de Uso:

Definições no JavaScript:

// TS da Tela

import { FileUtil } from 'dts-backoffice-util';

fileBase64: string;

downloadFile() {
  this.servCustomerSubscription$ = this.servCustomer
    .getFile('1') // Código do cliente 1
    .subscribe((response: Object) => {

      FileUtil.downloadFile(response['content'], response['filename']);
    });
}

downloadQrCode() {
  this.servCustomerSubscription$ = this.servCustomer
    .getQrCode('00020126360014BR.GOV.BCB.PIX0114+554798402310452040000530398654071500.005802BR5916Robervaldo6009Joinville62070503Novo%20QR%20pix63047EF5') // Texto Exemplo para Geração do QrCode
    .subscribe((response: Blob) => {

      FileUtil.downloadFile(response, 'qrCode.png', '', false);
  });
}

downloadList() {
  this.servCustomerSubscription$ = this.servCustomer
    .query([], [], 1, 999) // Método padrão de Query do Serviço de Cliente
    .subscribe((response: TotvsResponse<ICustomer>) => {

      const dwldDataParam = new DownloadDataParams();
      dwldDataParam.fileName = 'clientes.csv';
      dwldDataParam.columnDelimiter = ';';
      dwldDataParam.literals = this.literals;
      dwldDataParam.columnList = ['shortName', 'name', 'country', 'status', 'tax'];

      FileUtil.downloadData(response.items, dwldDataParam);
  });
}

onConfirmUpload(): void {
  // fileToSend: variável utilizada no ngModel do componente de Upload
  if (!this.fileToSend || this.fileToSend.length < 1) { return; }

  // fileBase64: variável do programa para receber o conteúdo em Base64
  FileUtil.fileToB64(this.fileToSend[0].rawFile).then(
    (data: string) => this.fileBase64 = data
  );
}

// TS do Serviço

getFile(id: string): Observable<Object> {
  const url = `/customer/${id}/file`;
  return this.http.get(url);
}

getQrCode(text: string): Observable<Blob> {
  const url = `/qrcode/download?text=${text}`;
  return this.http.get(url, { responseType: 'blob' });
}

Definições no Progress:

// Conteúdo do Método que BackEnd que retorna o Arquivo em Base64
DEFINE VARIABLE v_dir_arq AS CHARACTER NO-UNDO.
DEFINE VARIABLE v_cod_arq AS CHARACTER NO-UNDO.
DEFINE VARIABLE v_mtr_arq AS MEMPTR    NO-UNDO.
DEFINE VARIABLE v_lch_arq AS LONGCHAR  NO-UNDO.

ASSIGN v_dir_arq = "\\arpoador\Publico\"
       v_cod_arq = "layout_pagfor Sistema DDA.pdf".

COPY-LOB FROM FILE STRING(v_dir_arq + v_cod_arq) TO v_mtr_arq.
ASSIGN v_lch_arq = BASE64-ENCODE(v_mtr_arq).

oOutput = NEW JsonObject().
oOutput:ADD("filename", v_cod_arq).
oOutput:ADD("content",  v_lch_arq).

Interfaces:

IDownloadDataParams

NomeTipoObrigatórioDescrição
fileNamestringNãoNome do Arquivo. Caso não seja informado será usado o nome "data.csv".
literalsanyNãoObjeto de Literais que será utilizado para tradução do Cabeçalho e do conteúdo dos campos do tipo Lógico. Nele, deverão existir literais que sejam iguais as propriedades da listagem. Por exemplo, se for uma listagem de Clientes, que possua uma propriedade chamada shortName, deverá existir uma literal com este nome. Também, deve existir as literais "true" e "false" para tradução dos campos lógicos. Caso não seja informado, o cabeçalho será gerado com os nomes das propriedades.
columnDelimiterstringNãoCaracter utilizado para separação das colunas. Caso não seja informado, será utilizado o caracter ";".
columnListArray(string)NãoLista das colunas que devem ser exportadas para o arquivo. As colunas serão exportadas na mesma ordem informada neste parâmetro. Caso não seja informada, serão exportadas todas as colunas da listagem.
columnExcludeArray(string)NãoLista das colunas que não devem ser exportadas para o arquivo. Caso não seja informada, serão exportadas todas as colunas da listagem.

DisclaimerUtil

xxxx

FieldValidationUtil

xxxx

FilterRangeUtil

xxxx

GenericFunctionsUtils

xxxx

16.1.0

7 days ago

15.4.1

7 days ago

15.4.0

7 days ago

15.3.3

5 months ago

15.3.2

5 months ago

16.0.0

5 months ago

15.3.0

12 months ago

15.3.1

11 months ago

15.1.0

1 year ago

15.2.0

1 year ago

14.3.0

1 year ago

3.0.1

1 year ago

4.0.1

1 year ago

5.0.1

1 year ago

15.0.0

1 year ago

6.0.2

1 year ago

14.2.0

1 year ago

14.2.1

1 year ago

14.4.0

1 year ago

14.2.2

1 year ago

14.4.1

1 year ago

14.2.3

1 year ago

2.8.3

1 year ago

2.8.4

1 year ago

14.1.0

2 years ago

14.0.0

2 years ago

3.0.0

2 years ago

4.0.0

2 years ago

5.0.0

2 years ago

6.0.1

2 years ago

6.0.0

2 years ago

2.8.2

2 years ago

2.8.1

3 years ago

2.8.0

3 years ago

2.7.0

3 years ago

2.6.0

3 years ago

2.5.1

3 years ago

2.5.0

3 years ago

2.4.1

3 years ago

2.4.0

3 years ago

2.3.1

3 years ago

2.3.0

3 years ago

2.2.1

3 years ago

2.2.0

3 years ago

2.1.2

3 years ago

2.1.1

4 years ago

2.1.0

4 years ago

2.0.9

4 years ago

2.0.8

4 years ago

2.0.7

4 years ago

2.0.5

4 years ago

2.0.6

4 years ago

2.0.4

4 years ago

2.0.3

4 years ago

2.0.2

4 years ago

2.0.1

4 years ago

2.0.0

4 years ago

0.0.22

4 years ago

0.0.21

4 years ago

0.0.20

4 years ago

0.0.19

4 years ago

0.0.18

4 years ago

0.0.17

4 years ago

0.0.16

4 years ago

0.0.15

4 years ago

0.0.14

4 years ago

0.0.13

4 years ago

0.0.12

4 years ago

0.0.11

4 years ago

0.0.10

4 years ago

0.0.9

4 years ago

0.0.8

4 years ago

0.0.7

4 years ago

0.0.6

4 years ago

0.0.5

4 years ago

0.0.4

4 years ago

0.0.3

4 years ago

0.0.1

4 years ago