mirror of
				https://github.com/KevinMidboe/linguist.git
				synced 2025-10-29 17:50:22 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			513 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Plaintext
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			513 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Plaintext
		
	
	
		
			Executable File
		
	
	
	
	
| 
 | ||
| /**
 | ||
|  * This is a sample file for Linguist.
 | ||
|  * It's written in AdvPL, a xBase Language.
 | ||
|  *
 | ||
|  * Author: Arthur Helfstein Fragoso
 | ||
|  *
 | ||
|  * This script has the specific use of integrating between a financial institution
 | ||
|  * and other two companies in the process of creating Installment Bills for
 | ||
|  * customers.
 | ||
|  *
 | ||
|  * The functions are called from the ERP Protheus TOTVS.
 | ||
|  *
 | ||
|  **/
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| #Include "TOPCONN.ch"
 | ||
| #include "tbiconn.ch"
 | ||
| #Include "Protheus.ch"
 | ||
| #Include "rwmake.ch"
 | ||
| #Include "FileIO.ch"
 | ||
| #Include "json.ch"
 | ||
| #Include "utils.ch"
 | ||
| 
 | ||
| 
 | ||
| ////////////////////////
 | ||
| // Faturando (Reparcelando)
 | ||
| // FA280
 | ||
| // FA280_01
 | ||
| //
 | ||
| 
 | ||
| User Function FA280()
 | ||
| 
 | ||
| 	//Executado uma vez para cada parcela
 | ||
| 
 | ||
| 	If cEmpAnt == '06'
 | ||
| 
 | ||
| 		SE5->(dbSelectArea("SE5"))
 | ||
| 
 | ||
| 		cSet3Filter := "SE5->E5_FATURA == SE1->E1_NUM"
 | ||
| 
 | ||
| 		SE5->(dbSetFilter( {|| &cSet3Filter }, cSet3Filter ))
 | ||
| 		SE5->(dbGoTOP())
 | ||
| 
 | ||
| 		aOrig06Tit := {} // = Todos os Titulos que ser<65>o reparcelados
 | ||
| 		nTotal := 0
 | ||
| 
 | ||
| 		While SE5->(!EOF())
 | ||
| 			AADD(aOrig06Tit, {SE5->E5_PREFIXO, SE5->E5_NUMERO, SE5->E5_VALOR})
 | ||
| 			nTotal += SE5->E5_VALOR
 | ||
| 			SE5->(dbSkip())
 | ||
| 		End
 | ||
| 
 | ||
| 		aNovoTitulo:= {;//{"E1_FILIAL"   ,SE1ORIG->E1_FILIAL ,Nil},;
 | ||
| 		              ;//{"E1_PREFIXO"  ,SE1->E1_PREFIXO    ,Nil},;
 | ||
| 		              {"E1_NUM"      ,SE1->E1_NUM        ,Nil},;
 | ||
| 		              {"E1_TIPO"     ,SE1->E1_TIPO       ,Nil},;
 | ||
| 		              {"E1_PARCELA"  ,SE1->E1_PARCELA    ,Nil},;
 | ||
| 		              {"E1_NATUREZ"  ,SE1->E1_NATUREZ    ,Nil},;
 | ||
| 		              {"E1_CLIENTE"  ,SE1->E1_CLIENTE    ,Nil},;
 | ||
| 		              {"E1_LOJA"     ,SE1->E1_LOJA       ,Nil},;
 | ||
| 		              {"E1_NRDOC"    ,SE1->E1_NRDOC      ,Nil},;
 | ||
| 		              ;//{"E1_X_COD"    ,SE1->E1_NATUREZ    ,Nil},;
 | ||
| 		              {"E1_EMISSAO"  ,SE1->E1_EMISSAO    ,Nil},;
 | ||
| 		              {"E1_VENCTO"   ,SE1->E1_VENCTO     ,Nil},;
 | ||
| 		              {"E1_VENCREA"  ,SE1->E1_VENCREA    ,Nil},;
 | ||
| 		              ;//{"E1_VALOR"    ,SE1->E1_VALOR      ,Nil},;
 | ||
| 		              ;//{"E1_SALDO"    ,SE1->E1_SALDO      ,Nil},;
 | ||
| 		              ;//{"E1_VLCRUZ"   ,SE1->E1_VLCRUZ     ,Nil},;
 | ||
| 		              {"E1_PORTADO"  ,SE1->E1_PORTADO    ,Nil},;
 | ||
| 		              {"E1_FATURA"   ,SE1->E1_FATURA     ,Nil},;
 | ||
| 		              {"E1_X_DTPAV"  ,SE1->E1_X_DTPAV    ,Nil},;
 | ||
| 		              {"E1_X_DTSAV"  ,SE1->E1_X_DTSAV    ,Nil},;
 | ||
| 		              {"E1_X_DTTAV"  ,SE1->E1_X_DTTAV    ,Nil},;
 | ||
| 		              {"E1_X_DTSPC"  ,SE1->E1_X_DTSPC    ,Nil},;
 | ||
| 		              {"E1_X_DTPRO"  ,SE1->E1_X_DTPRO    ,Nil},;
 | ||
| 		              {"E1_NUMBCO"   ,SE1->E1_NUMBCO     ,Nil},;
 | ||
| 		              {"E1_X_DUDME"  ,SE1->E1_X_DUDME    ,Nil},;
 | ||
| 		              {"E1_X_TIPOP"  ,SE1->E1_X_TIPOP    ,Nil},;
 | ||
| 		              {"E1_X_DTCAN"  ,SE1->E1_X_DTCAN    ,Nil},;
 | ||
| 		              {"E1_X_MOTIV"  ,SE1->E1_X_MOTIV    ,Nil},;
 | ||
| 		              {"E1_X_DESPC"  ,SE1->E1_X_DESPC    ,Nil},;
 | ||
| 		              {"E1_NUMNOTA"  ,SE1->E1_NUMNOTA    ,Nil},;
 | ||
| 		              {"E1_SERIE"    ,SE1->E1_SERIE      ,Nil},;
 | ||
| 		              {"E1_X_DEPRO"  ,SE1->E1_X_DEPRO    ,Nil},;
 | ||
| 		              {"E1_X_TPPAI"  ,SE1->E1_X_TPPAI    ,Nil},;
 | ||
| 		              {"E1_X_CGC"    ,SE1->E1_X_CGC      ,Nil},;
 | ||
| 		              {"E1_XTPEMP"   ,SE1->E1_XTPEMP     ,Nil},;
 | ||
| 		              {"E1_X_CTRIM"  ,SE1->E1_X_CTRIM    ,Nil}}
 | ||
| 
 | ||
| 		StartJob("U_FA280_01",getenvserver(),.T., SE1->E1_PREFIXO ,SE1->E1_NUM, SE1->E1_TIPO, SE1->E1_VALOR, aOrig06Tit, nTotal, SE1->E1_PARCELA, aNovoTitulo)
 | ||
| 
 | ||
| 		SE5->(dbClearFilter())
 | ||
| 
 | ||
| 	EndIf
 | ||
| 
 | ||
| Return nil
 | ||
| 
 | ||
| 
 | ||
| User Function FA280_01(cE1PREFIXO, cE1NUM, cE1TIPO, nE1Valor, aOrig06Tit, nTotal, cE1PARCELA, aNovoTitulo)
 | ||
| 	Local nValPar := nil
 | ||
| 	Local aTit05 := {}
 | ||
| 
 | ||
| 	RpcSetType(3) // Nao consome licensa
 | ||
| 
 | ||
| 	//Prepare Environment Empresa "01" Filial '0102'
 | ||
| 	// Muda de empresa
 | ||
| 	While !RpcSetEnv('01', '0102',,,,GetEnvServer(),{})
 | ||
| 		Sleep(400)
 | ||
| 	End
 | ||
| 
 | ||
| 		nFileLog := u_OpenLog("\Logs\FA280_"+dToS(dDataBase)+".log")
 | ||
| 
 | ||
| 		fWrite(nFileLog,"----- FA280 -----"+CRLF)
 | ||
| 
 | ||
| 		fWrite(nFileLog,cE1NUM+CRLF)
 | ||
| 
 | ||
| 		nParcelas := round(nTotal/nE1Valor, 0)
 | ||
| 
 | ||
| 		cUltima := '0'+ chr(64+nParcelas)
 | ||
| 
 | ||
| 		fWrite(nFileLog,"valor das parcelas: "+ cvaltochar(nE1Valor) +CRLF)
 | ||
| 		fWrite(nFileLog,"parcelas: "+ cvaltochar(nParcelas) +CRLF)
 | ||
| 		fWrite(nFileLog,"parcela atual: "+ cE1PARCELA +CRLF)
 | ||
| 		fWrite(nFileLog,"ultima parcela: "+ cUltima +CRLF)
 | ||
| 
 | ||
| 		n0102total := 0
 | ||
| 		n0105total := 0
 | ||
| 
 | ||
| 		//Loop entre todos os Titulos que serão Reparcelados
 | ||
| 
 | ||
| 		For nI := 1 To len(aOrig06Tit)
 | ||
| 
 | ||
| 			fWrite(nFileLog,"E5_NUMERO: "+aOrig06Tit[nI][2] +CRLF)
 | ||
| 
 | ||
| 			cQuery := "select * from SE1010 where E1_PREFIXO = '"+ aOrig06Tit[nI][1] +"' and E1_NUM = '"+ aOrig06Tit[nI][2] +"' and  E1_TIPO = 'FAT' and D_E_L_E_T_ <> '*'"
 | ||
| 
 | ||
| 			fWrite(nFileLog,cQuery +CRLF)
 | ||
| 
 | ||
| 			If select("SE1ORIG") > 0
 | ||
| 				SE1ORIG->(DbCloseArea())
 | ||
| 			endif
 | ||
| 			TcQuery cQuery New Alias 'SE1ORIG'
 | ||
| 			dbSelectArea("SE1ORIG")
 | ||
| 			SE1ORIG->(DBGOTOP())
 | ||
| 
 | ||
| 			While SE1ORIG->(!EOF()) //Loop entre as duas filiais: 0102, 0105
 | ||
| 				fWrite(nFileLog,"SE1ORIG loop: "+SE1ORIG->E1_FILIAL +CRLF)
 | ||
| 				cFilAnt := SE1ORIG->E1_FILIAL
 | ||
| 
 | ||
| 				//Faz a baixa
 | ||
| 				if alltrim(SE1ORIG->E1_STATUS) == 'A'
 | ||
| 					fWrite(nFileLog, SE1ORIG->E1_FILIAL+" : Fazendo baixa" +CRLF)
 | ||
| 
 | ||
| 					aBaixa	:= {{"E1_FILIAL"   ,SE1ORIG->E1_FILIAL   ,Nil},;
 | ||
| 					            {"E1_PREFIXO"  ,SE1ORIG->E1_PREFIXO  ,Nil},;
 | ||
| 					            {"E1_NUM"      ,SE1ORIG->E1_NUM      ,Nil},;
 | ||
| 					            {"E1_TIPO"     ,SE1ORIG->E1_TIPO     ,Nil},;
 | ||
| 					            {"E1_PARCELA"  ,SE1ORIG->E1_PARCELA  ,Nil},;
 | ||
| 					            {"E1_DESCONT"  ,SE1ORIG->E1_DESCONT  ,Nil},;
 | ||
| 					            {"E1_JUROS"    ,SE1ORIG->E1_JUROS    ,Nil},;
 | ||
| 					            {"E1_MULTA"    ,SE1ORIG->E1_MULTA    ,Nil},;
 | ||
| 					            {"E1_VLRREAL"  ,SE1ORIG->E1_VLRREAL  ,Nil},;
 | ||
| 					            {"AUTMOTBX"    ,"FAT"                ,Nil},;
 | ||
| 					            {"AUTDTBAIXA"  ,date()               ,Nil},;
 | ||
| 					            {"AUTDTCREDITO",date()               ,Nil},;
 | ||
| 					            {"AUTHIST"     ,"Bx.Emis.Fat."+cE1NUM,Nil},;
 | ||
| 					            {"AUTVALREC"   ,SE1ORIG->E1_VALOR    ,Nil}}
 | ||
| 
 | ||
| 
 | ||
| 					lMsErroAuto:=.F. //reseta lMsErroAuto
 | ||
| 					MSExecAuto ({|x,y| FINA070(x,y)},aBaixa, 3)
 | ||
| 
 | ||
| 					If lMsErroAuto
 | ||
| 
 | ||
| 						fWrite(nFileLog,SE1ORIG->E1_FILIAL+" : Não foi efetuada a baixa do titulo : "+CRLF+ MSErroString()+ CRLF + tojson(aBaixa) + CRLF)
 | ||
| 						return
 | ||
| 					else
 | ||
| 
 | ||
| 						RECLOCK('SE5',.F.)
 | ||
| 							E5_FATURA := cE1NUM
 | ||
| 							E5_FATPREF:= cE1PREFIXO
 | ||
| 							//E5_LA = S
 | ||
| 							//E5_MOEDA = ''
 | ||
| 							//E5_TXMOEDA = 1
 | ||
| 						MSUNLOCK()
 | ||
| 						RECLOCK('SE1',.F.)
 | ||
| 							E1_FATURA := cE1NUM
 | ||
| 							E1_FATPREF:= cE1PREFIXO
 | ||
| 							E1_TIPOFAT:= cE1TIPO
 | ||
| 							E1_FLAGFAT:= 'S'
 | ||
| 							E1_DTFATUR:= dDataBase
 | ||
| 						MSUNLOCK()
 | ||
| 
 | ||
| 						fWrite(nFileLog,SE1ORIG->E1_FILIAL+" : baixa feita" +CRLF)
 | ||
| 					endif
 | ||
| 
 | ||
| 				endif
 | ||
| 
 | ||
| 				//calcula valor total de cada filial para poder calcular a Fatura
 | ||
| 
 | ||
| 				if SE1ORIG->E1_FILIAL == '0102'
 | ||
| 					n0102total += SE1ORIG->E1_VALOR
 | ||
| 				elseif SE1ORIG->E1_FILIAL == '0105'
 | ||
| 					n0105total += SE1ORIG->E1_VALOR
 | ||
| 				else
 | ||
| 					fWrite(nFileLog,"Programa nao preparado para a filial "+SE1ORIG->E1_FILIAL +CRLF)
 | ||
| 				endif
 | ||
| 
 | ||
| 				SE1ORIG->(dbskip())
 | ||
| 
 | ||
| 			End
 | ||
| 
 | ||
| 		Next nI
 | ||
| 
 | ||
| 		cFilAnt := '0102'
 | ||
| 
 | ||
| 		fWrite(nFileLog,"Total 0102: "+cvaltochar(n0102total) +CRLF)
 | ||
| 		fWrite(nFileLog,"Total 0105: "+cvaltochar(n0105total) +CRLF)
 | ||
| 
 | ||
| 		n0102val := round(nE1Valor * n0102total/nTotal, 2)
 | ||
| 		n0105val := nE1Valor - n0102val
 | ||
| 
 | ||
| 		aFili := {}
 | ||
| 
 | ||
| 		if n0102total > 0
 | ||
| 			AADD(aFili,'0102')
 | ||
| 		endif
 | ||
| 
 | ||
| 		if n0105total > 0
 | ||
| 			AADD(aFili,'0105')
 | ||
| 		endif
 | ||
| 
 | ||
| 		For nI := 1 To len(aFili)
 | ||
| 
 | ||
| 			cQuery := "select COUNT(*) as QUANT, SUM(E1_VALOR) as TOTALINC from SE1010  where E1_NUM = '"+ cE1NUM +"'  and E1_FILIAL='"+ aFili[nI] +"' and E1_PREFIXO = '"+ cE1PREFIXO +"' and D_E_L_E_T_ <> '*'"
 | ||
| 
 | ||
| 			If select("PARC") > 0
 | ||
| 				PARC->(DbCloseArea())
 | ||
| 			endif
 | ||
| 			TcQuery cQuery New Alias 'PARC'
 | ||
| 			dbSelectArea("PARC")
 | ||
| 
 | ||
| 			//verificamos se estamos na ultima parcela
 | ||
| 			if PARC->QUANT == nParcelas -1 //QUANT = quantidade de parcelas incluida
 | ||
| 				fWrite(nFileLog,"Ultima Parcela"+CRLF)
 | ||
| 				//o valor desta será o valor que resta
 | ||
| 				nValPar := SE1ORIG->E1_VALOR - PARC->TOTALINC
 | ||
| 
 | ||
| 				if aFili[nI] == '0102'
 | ||
| 					n0102val := n0102total - PARC->TOTALINC
 | ||
| 				elseif aFili[nI] == '0105'
 | ||
| 					n0105val := n0105total - PARC->TOTALINC
 | ||
| 				endif
 | ||
| 			endif
 | ||
| 
 | ||
| 		Next nI
 | ||
| 
 | ||
| 		fWrite(nFileLog,"Total 0102: "+cvaltochar(n0102total) + "  -> Parcela de: "+cvaltochar(n0102val) +CRLF)
 | ||
| 		fWrite(nFileLog,"Total 0105: "+cvaltochar(n0105total) + "  -> Parcela de: "+cvaltochar(n0105val) +CRLF)
 | ||
| 
 | ||
| 		/////////////////
 | ||
| 
 | ||
| 		For nI := 1 To len(aFili)
 | ||
| 
 | ||
| 			if aFili[nI] == '0102'
 | ||
| 				nValPar := n0102val
 | ||
| 			elseif aFili[nI] == '0105'
 | ||
| 				nValPar := n0105val
 | ||
| 			endif
 | ||
| 
 | ||
| 			aTitulo := ACLONE(aNovoTitulo)
 | ||
| 
 | ||
| 			AADD(aTitulo, {"E1_PREFIXO" ,cE1PREFIXO          ,Nil})
 | ||
| 			AADD(aTitulo, {"E1_FILIAL"  ,aFili[nI]           ,Nil})
 | ||
| 			AADD(aTitulo, {"E1_VALOR"   ,nValPar             ,Nil})
 | ||
| 			AADD(aTitulo, {"E1_SALDO"   ,nValPar             ,Nil})
 | ||
| 			AADD(aTitulo, {"E1_VLCRUZ"  ,nValPar             ,Nil})
 | ||
| 
 | ||
| 			lMsErroAuto := .F.
 | ||
| 
 | ||
| 			if aFili[nI] == '0102'
 | ||
| 
 | ||
| 				MSExecAuto({|x,y| FINA040(x,y)},aTitulo,3) //Inclusao
 | ||
| 
 | ||
| 				If lMsErroAuto
 | ||
| 					fWrite(nFileLog,"Erro " + CRLF)
 | ||
| 					fWrite(nFileLog,"Erro ao incluir titulo: "+CRLF+ MSErroString()+ CRLF + tojson(aTitulo) + CRLF)
 | ||
| 					return
 | ||
| 				else
 | ||
| 					fWrite(nFileLog,"Sucesso "+ CRLF)
 | ||
| 					fWrite(nFileLog,"Titulo incluido: "+ aFili[nI] +" : " + cValToChar(nValPar) +CRLF)
 | ||
| 				endif
 | ||
| 
 | ||
| 			elseif aFili[nI] == '0105'
 | ||
| 				fWrite(nFileLog,"Salvando titulos 05 para o final "+aFili[nI]+CRLF)
 | ||
| 				//StartJob("U_JOBF040",getenvserver(),.T., SE1ORIG->E1_FILIAL, aTitulo)
 | ||
| 				AADD(aTit05, aTitulo)
 | ||
| 				//fWrite(nFileLog,"passou pela thread "+CRLF)
 | ||
| 			else
 | ||
| 				fWrite(nFileLog,"Erro, filial nao tratada "+aFili[nI]+CRLF)
 | ||
| 			endif
 | ||
| 
 | ||
| 		Next nI
 | ||
| 
 | ||
| 
 | ||
| 	Reset Environment
 | ||
| 
 | ||
| 	While !RpcSetEnv('01', '0105',,,,GetEnvServer(),{})
 | ||
| 		Sleep(400)
 | ||
| 	End
 | ||
| 
 | ||
| 		For nI := 1 To len(aTit05)
 | ||
| 
 | ||
| 			lMsErroAuto := .F.
 | ||
| 
 | ||
| 			MSExecAuto({|x,y| FINA040(x,y)},aTit05[nI],3) //Inclusao
 | ||
| 
 | ||
| 			If lMsErroAuto
 | ||
| 				fWrite(nFileLog,"Erro " + CRLF)
 | ||
| 				fWrite(nFileLog,"Erro ao incluir titulo: "+CRLF+ MSErroString()+ CRLF + tojson(aTit05[nI]) + CRLF)
 | ||
| 				return
 | ||
| 			else
 | ||
| 				fWrite(nFileLog,"Sucesso "+ CRLF)
 | ||
| 				fWrite(nFileLog,"Titulo incluido: "+CRLF)
 | ||
| 			endif
 | ||
| 
 | ||
| 		Next nI
 | ||
| 
 | ||
| 	Reset Environment
 | ||
| 
 | ||
| 	fClose(nFileLog)
 | ||
| 
 | ||
| Return
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| ////////////////////////
 | ||
| // Cancelamento da Fatura (Cancelamento do Reparcelamento)
 | ||
| // F280PCAN
 | ||
| // JOBF280C
 | ||
| //
 | ||
| 
 | ||
| User Function F280PCAN()
 | ||
| 
 | ||
| 	/**
 | ||
| 	 * cFatCan  - numero da fatura
 | ||
| 	 * cPrefCan - prefixo
 | ||
| 	 * cTipoCan - tipo
 | ||
| 	 **/
 | ||
| 
 | ||
| 	If cEmpAnt == '06'
 | ||
| 
 | ||
| 		StartJob("U_JOBF280C",getenvserver(),.T., cPrefCan, cFatCan, cTipoCan)
 | ||
| 
 | ||
| 	EndIf
 | ||
| 
 | ||
| Return .T.
 | ||
| 
 | ||
| 
 | ||
| User Function JOBF280C(cPrefCan, cFatCan, cTipoCan)
 | ||
| 
 | ||
| 	RpcSetType(3) // Nao consome licensa
 | ||
| 
 | ||
| 	While !RpcSetEnv('01', '0102',,,,GetEnvServer(),{})
 | ||
| 		Sleep(400)
 | ||
| 	End
 | ||
| 
 | ||
| 		nFileLog := u_OpenLog("\Logs\F280PCAN_"+dToS(dDataBase)+".log")
 | ||
| 
 | ||
| 		fWrite(nFileLog,"----- F280PCAN -----"+CRLF)
 | ||
| 
 | ||
| 		fWrite(nFileLog,"E1_PREFIXO = '"+ cPrefCan +"' and E1_NUM = '"+ cFatCan +"' and  E1_TIPO = '"+ cTipoCan +"'"+CRLF)
 | ||
| 
 | ||
| 		cQuery := "select * from SE1010 where E1_PREFIXO = '"+ cPrefCan +"' and E1_NUM = '"+ cFatCan +"' and  E1_TIPO = '"+ cTipoCan +"' and D_E_L_E_T_ <> '*'"
 | ||
| 
 | ||
| 		If select("SE1ORIG") > 0
 | ||
| 			SE1ORIG->(DbCloseArea())
 | ||
| 		endif
 | ||
| 		TcQuery cQuery New Alias 'SE1ORIG'
 | ||
| 		dbSelectArea("SE1ORIG")
 | ||
| 		SE1ORIG->(DBGOTOP())
 | ||
| 
 | ||
| 		While SE1ORIG->(!EOF()) //Loop entre todas as parcelas e filiais
 | ||
| 
 | ||
| 			SE1->(dbselectarea("SE1"))
 | ||
| 			SE1->(dbSetOrder(1))
 | ||
| 
 | ||
| 
 | ||
| 			fWrite(nFileLog,"dbseek" + CRLF)
 | ||
| 			if ! SE1->(dbSeek(SE1ORIG->E1_FILIAL+ SE1ORIG->E1_PREFIXO+ SE1ORIG->E1_NUM+ SE1ORIG->E1_PARCELA+ SE1ORIG->E1_TIPO))
 | ||
| 				fWrite(nFileLog,"Erro dbseek" + CRLF)
 | ||
| 				Alert("Erro. Verificar F280PCAN() - dbseek")
 | ||
| 				fWrite(nFileLog,"Erro dbseek("+SE1ORIG->E1_FILIAL+ SE1ORIG->E1_PREFIXO+ SE1ORIG->E1_NUM+ SE1ORIG->E1_PARCELA+ SE1ORIG->E1_TIPO+")" + CRLF)
 | ||
| 				return .F.
 | ||
| 			endif
 | ||
| 
 | ||
| 			cFilAnt := SE1ORIG->E1_FILIAL
 | ||
| 
 | ||
| 			aFatura:= {{"E1_FILIAL"  ,SE1ORIG->E1_FILIAL         ,Nil},;
 | ||
| 			           {"E1_PREFIXO" ,SE1ORIG->E1_PREFIXO        ,Nil},;
 | ||
| 			           {"E1_NUM"     ,SE1ORIG->E1_NUM            ,Nil},;
 | ||
| 			           {"E1_PARCELA" ,SE1ORIG->E1_PARCELA        ,Nil},;
 | ||
| 			           {"E1_TIPO"    ,SE1ORIG->E1_TIPO           ,Nil}}
 | ||
| 
 | ||
| 			lMsErroAuto := .F.
 | ||
| 
 | ||
| 			MSExecAuto({|x,y| FINA040(x,y)},aFatura,5) //Exclus<75>o
 | ||
| 
 | ||
| 			If lMsErroAuto
 | ||
| 				fWrite(nFileLog,"Erro " + CRLF)
 | ||
| 				fWrite(nFileLog,"Erro ao remover o titulo: "+CRLF+ MSErroString()+ CRLF + tojson(aFatura) + CRLF)
 | ||
| 				Alert("Erro ao remover o titulo. Verificar F280PCAN()")
 | ||
| 				return .F.
 | ||
| 			else
 | ||
| 				fWrite(nFileLog,"Sucesso "+ CRLF)
 | ||
| 				fWrite(nFileLog,"Titulo removido" +CRLF)
 | ||
| 			endif
 | ||
| 
 | ||
| 			SE1ORIG->(dbskip())
 | ||
| 
 | ||
| 		end
 | ||
| 
 | ||
| 
 | ||
| 		/////////////////////////////////////////////
 | ||
| 		///////  Cancela as baixas
 | ||
| 		///
 | ||
| 
 | ||
| 		fWrite(nFileLog,"- cancela baixas" + CRLF)
 | ||
| 
 | ||
| 		cQuery := "select * from SE1060 where  E1_FATURA = '"+ cFatCan +"' and D_E_L_E_T_ <> '*'"
 | ||
| 
 | ||
| 		If select("SE1ORIG") > 0
 | ||
| 			SE1ORIG->(DbCloseArea())
 | ||
| 		endif
 | ||
| 		TcQuery cQuery New Alias 'SE1ORIG'
 | ||
| 		dbSelectArea("SE1ORIG")
 | ||
| 		SE1ORIG->(DBGOTOP())
 | ||
| 
 | ||
| 		aFili := {"0102", "0105"}
 | ||
| 
 | ||
| 		While SE1ORIG->(!EOF()) //Loop entre todas as parcelas e filiais
 | ||
| 
 | ||
| 			SE1->(dbselectarea("SE1"))
 | ||
| 			SE1->(dbSetOrder(1))
 | ||
| 
 | ||
| 			For nI := 1 To len(aFili)
 | ||
| 
 | ||
| 				cFilAnt := aFili[nI]
 | ||
| 
 | ||
| 				fWrite(nFileLog,"dbseek" + CRLF)
 | ||
| 				if ! SE1->(dbSeek(aFili[nI]+ SE1ORIG->E1_PREFIXO+ SE1ORIG->E1_NUM+ SE1ORIG->E1_PARCELA+ SE1ORIG->E1_TIPO))
 | ||
| 					fWrite(nFileLog,"dbseek nao encontrou titulo para filial "+aFili[nI] + CRLF)
 | ||
| 					fWrite(nFileLog,"dbseek('"+aFili[nI]+ SE1ORIG->E1_PREFIXO+ SE1ORIG->E1_NUM+ SE1ORIG->E1_PARCELA+ SE1ORIG->E1_TIPO+"')" + CRLF)
 | ||
| 					LOOP
 | ||
| 				endif
 | ||
| 
 | ||
| 				nSE5Recno := u_RetSQLOne("select R_E_C_N_O_ from SE5010 where E5_FILIAL = '"+SE1->E1_FILIAL+"' and E5_PREFIXO = '"+SE1->E1_PREFIXO+"' and E5_TIPO = '"+SE1->E1_TIPO+"' and E5_NUMERO = '"+SE1->E1_NUM+"' "+;
 | ||
| 				                         " and E5_FATURA = '"+SE1->E1_FATURA+"' and E5_FATPREF='"+SE1->E1_FATPREF+"' and D_E_L_E_T_ <> '*' ", "R_E_C_N_O_")
 | ||
| 
 | ||
| 				//Removemos os Flags de Fatura para conseguirmos cancelar a baixa pelo FINA070
 | ||
| 				RECLOCK('SE1',.F.)
 | ||
| 					E1_FATURA := ''
 | ||
| 					E1_FATPREF:= ''
 | ||
| 					E1_TIPOFAT:= ''
 | ||
| 					E1_FLAGFAT:= ''
 | ||
| 					E1_DTFATUR:= StoD('')
 | ||
| 			    MSUNLOCK()
 | ||
| 
 | ||
| 			    SE5->(DbGoTo(nSE5Recno))
 | ||
| 				RECLOCK('SE5',.F.)
 | ||
| 					E5_MOTBX  := 'NOR'
 | ||
| 					//E5_FATURA := ''
 | ||
| 					//E5_FATPREF:= ''
 | ||
| 				MSUNLOCK()
 | ||
| 
 | ||
| 				aBaixa := {{"E1_FILIAL"   ,SE1->E1_FILIAL  ,Nil},;
 | ||
| 				           {"E1_PREFIXO"  ,SE1->E1_PREFIXO ,Nil},;
 | ||
| 				           {"E1_NUM"      ,SE1->E1_NUM     ,Nil},;
 | ||
| 				           {"E1_TIPO"     ,SE1->E1_TIPO    ,Nil},;
 | ||
| 				           {"E1_PARCELA"  ,SE1->E1_PARCELA ,Nil},;
 | ||
| 				           {"E1_DESCONT"  ,SE1->E1_DESCONT ,Nil},;
 | ||
| 				           {"E1_JUROS"    ,SE1->E1_JUROS   ,Nil},;
 | ||
| 				           {"E1_MULTA"    ,SE1->E1_MULTA   ,Nil},;
 | ||
| 				           {"E1_VLRREAL"  ,SE1->E1_VLRREAL ,Nil},;
 | ||
| 				           {"AUTMOTBX"    ,"NOR"           ,Nil},;
 | ||
| 				           {"AUTDTBAIXA"  ,date()          ,Nil},;
 | ||
| 				           {"AUTDTCREDITO",date()          ,Nil},;
 | ||
| 				           {"AUTHIST"     ,""              ,Nil},;
 | ||
| 				           {"AUTVALREC"   ,SE1->E1_VALOR   ,Nil}}
 | ||
| 
 | ||
| 
 | ||
| 				lMsErroAuto:=.F. //reseta lMsErroAuto
 | ||
| 				MSExecAuto ({|x,y| FINA070(x,y)},aBaixa, 5)
 | ||
| 
 | ||
| 				If lMsErroAuto
 | ||
| 					fWrite(nFileLog,SE1->E1_FILIAL+" : Não foi efetuada o cancelamento de baixa : "+CRLF+ MSErroString()+ CRLF + tojson(aBaixa) + CRLF)
 | ||
| 					return
 | ||
| 				else
 | ||
| 					fWrite(nFileLog,SE1->E1_FILIAL+" : cancelamento de baixa feito" +CRLF)
 | ||
| 				endif
 | ||
| 
 | ||
| 			Next nI
 | ||
| 
 | ||
| 			SE1ORIG->(dbskip())
 | ||
| 		end
 | ||
| 
 | ||
| 	Reset Environment
 | ||
| 
 | ||
| Return
 |