worker-automate-hub 0.5.21__tar.gz → 0.5.23__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (80) hide show
  1. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/PKG-INFO +1 -1
  2. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/pyproject.toml +1 -1
  3. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/rpa_fila_service.py +0 -1
  4. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dao/rpa_fila.py +5 -2
  5. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dao/rpa_processo.py +7 -3
  6. worker_automate_hub-0.5.23/worker_automate_hub/models/dao/rpa_robo.py +29 -0
  7. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_15.py +34 -35
  8. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_16.py +12 -4
  9. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/utils/utils_nfe_entrada.py +32 -3
  10. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/README.md +0 -0
  11. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/__init__.py +0 -0
  12. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/__init__.py +0 -0
  13. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/ahead_service.py +0 -0
  14. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/client.py +0 -0
  15. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/helpers/__init__.py +0 -0
  16. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/helpers/api_helpers.py +0 -0
  17. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/rdp_service.py +0 -0
  18. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/rpa_historico_service.py +0 -0
  19. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/api/webhook_service.py +0 -0
  20. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/cli.py +0 -0
  21. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/config/__init__.py +0 -0
  22. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/config/settings.py +0 -0
  23. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/config.py +0 -0
  24. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/core/so_manipulation.py +0 -0
  25. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/decorators/__init__.py +0 -0
  26. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/decorators/deprecation.py +0 -0
  27. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/decorators/rate_limit.py +0 -0
  28. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/decorators/repeat.py +0 -0
  29. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/decorators/retry.py +0 -0
  30. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/decorators/singleton.py +0 -0
  31. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/decorators/timeit.py +0 -0
  32. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/__init__.py +0 -0
  33. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dao/__init__.py +0 -0
  34. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dao/rpa_configuracao.py +0 -0
  35. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dao/rpa_historico.py +0 -0
  36. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dto/__init__.py +0 -0
  37. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dto/rpa_historico_request_dto.py +0 -0
  38. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dto/rpa_processo_entrada_dto.py +0 -0
  39. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dto/rpa_processo_rdp_dto.py +0 -0
  40. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/models/dto/rpa_sistema_dto.py +0 -0
  41. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/__init__.py +0 -0
  42. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/__init__.py +0 -0
  43. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/coleta_dje_process.py +0 -0
  44. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/conexao_rdp.py +0 -0
  45. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/descartes.py +0 -0
  46. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/ecac_estadual_go.py +0 -0
  47. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/ecac_estadual_main.py +0 -0
  48. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/ecac_estadual_mt.py +0 -0
  49. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/ecac_estadual_sc.py +0 -0
  50. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/ecac_estadual_sp.py +0 -0
  51. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/ecac_federal.py +0 -0
  52. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_207.py +0 -0
  53. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_32.py +0 -0
  54. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_33.py +0 -0
  55. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_34.py +0 -0
  56. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_36.py +0 -0
  57. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_39.py +0 -0
  58. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_500.py +0 -0
  59. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_505.py +0 -0
  60. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_7139.py +0 -0
  61. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/entrada_de_notas_9.py +0 -0
  62. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/exemplo_processo.py +0 -0
  63. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/fechar_conexao_rdp.py +0 -0
  64. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/fidc_gerar_nosso_numero.py +0 -0
  65. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/fidc_remessa_cobranca_cnab240.py +0 -0
  66. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/login_emsys.py +0 -0
  67. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/login_emsys_versao_especifica.py +0 -0
  68. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/playground.py +0 -0
  69. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/sped_fiscal.py +0 -0
  70. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/jobs/transferencias.py +0 -0
  71. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/task_definitions.py +0 -0
  72. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/tasks/task_executor.py +0 -0
  73. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/utils/__init__.py +0 -0
  74. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/utils/env.py +0 -0
  75. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/utils/get_creds_gworkspace.py +0 -0
  76. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/utils/logger.py +0 -0
  77. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/utils/toast.py +0 -0
  78. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/utils/updater.py +0 -0
  79. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/utils/util.py +0 -0
  80. {worker_automate_hub-0.5.21 → worker_automate_hub-0.5.23}/worker_automate_hub/worker.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: worker-automate-hub
3
- Version: 0.5.21
3
+ Version: 0.5.23
4
4
  Summary: Worker Automate HUB é uma aplicação para automatizar rotinas de RPA nos ambientes Argenta.
5
5
  Author: Joel Paim
6
6
  Requires-Python: >=3.12,<4.0
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "worker-automate-hub"
3
- version = "0.5.21"
3
+ version = "0.5.23"
4
4
  description = "Worker Automate HUB é uma aplicação para automatizar rotinas de RPA nos ambientes Argenta."
5
5
  authors = ["Joel Paim"]
6
6
  readme = "README.md"
@@ -2,7 +2,6 @@ import aiohttp
2
2
  from rich.console import Console
3
3
 
4
4
  from worker_automate_hub.config.settings import load_env_config
5
- from worker_automate_hub.models.dao.rpa_fila import RpaFila
6
5
  from worker_automate_hub.utils.logger import logger
7
6
 
8
7
  console = Console()
@@ -1,12 +1,15 @@
1
1
  from datetime import datetime
2
- from typing import Optional
2
+ from typing import List, Optional
3
3
 
4
4
  from pydantic import BaseModel, Field
5
5
 
6
+ from worker_automate_hub.models.dao.rpa_robo import RpaRobo
7
+
6
8
 
7
9
  class RpaFila(BaseModel):
8
10
  uuidFila: Optional[str] = Field(None, alias="uuidFila")
9
- uuidRobo: Optional[str] = Field(None, alias="uuidRobo")
11
+ robos: Optional[List[RpaRobo]] = Field(None, alias="robos")
12
+ fkRobos: Optional[str] = Field(None, alias="fkRobos")
10
13
  uuidProcesso: str = Field(..., alias="uuidProcesso")
11
14
  prioridade: int = Field(..., alias="prioridade")
12
15
  configEntrada: Optional[dict] = Field(None, alias="configEntrada")
@@ -1,7 +1,9 @@
1
- from typing import Optional
1
+ from typing import List, Optional
2
2
 
3
3
  from pydantic import BaseModel, Field
4
4
 
5
+ from worker_automate_hub.models.dao.rpa_robo import RpaRobo
6
+
5
7
 
6
8
  class RpaProcesso(BaseModel):
7
9
  uuidProcesso: str = Field(..., alias="uuidProcesso")
@@ -11,8 +13,10 @@ class RpaProcesso(BaseModel):
11
13
  prioridade: Optional[int] = Field(None, alias="prioridade")
12
14
  tempoMedio: Optional[int] = Field(None, alias="tempoMedio")
13
15
  ativo: bool = Field(..., alias="ativo")
14
- uuidRoboPreferencia: Optional[str] = Field(None, alias="uuidRoboPreferencia")
15
- uuidRoboPosFalha: Optional[str] = Field(None, alias="uuidRoboPosFalha")
16
+ robos: Optional[List[RpaRobo]] = Field(None, alias="robos")
17
+ fkRobos: Optional[str] = Field(None, alias="fkRobos")
18
+ robosPosFalha: Optional[List[RpaRobo]] = Field(None, alias="robosPosFalha")
19
+ fkRobosPosFalha: Optional[str] = Field(None, alias="fkRobosPosFalha")
16
20
  notificarFalha: bool = Field(..., alias="notificarFalha")
17
21
  gerarTarefaPosFalha: bool = Field(..., alias="gerarTarefaPosFalha")
18
22
  reenfileirarPosFalha: bool = Field(..., alias="reenfileirarPosFalha")
@@ -0,0 +1,29 @@
1
+ from datetime import datetime
2
+ from typing import Optional
3
+
4
+ from pydantic import BaseModel, Field
5
+
6
+
7
+ class RpaRobo(BaseModel):
8
+ uuidRobo: Optional[str] = Field(None, alias="uuidRobo")
9
+ nomRobo: str = Field(..., alias="nomRobo")
10
+ desRobo: str = Field(..., alias="desRobo")
11
+ vmRobo: Optional[str] = Field(None, alias="vmRobo")
12
+ ativo: bool = Field(..., alias="ativo")
13
+ ipVm: Optional[str] = Field(None, alias="ipVm")
14
+ userVm: Optional[str] = Field(None, alias="userVm")
15
+ passwordVm: Optional[str] = Field(None, alias="passwordVm")
16
+ versao: Optional[str] = Field(None, alias="versao")
17
+ tipoRobo: str = Field(..., alias="tipoRobo")
18
+ disponibilidade: Optional[str] = Field(None, alias="disponibilidade")
19
+ provisionar: Optional[str] = Field(None, alias="provisionar")
20
+ gitAppName: Optional[str] = Field(None, alias="gitAppName")
21
+ controllerRobo: Optional[str] = Field(None, alias="controllerRobo")
22
+ cloudStatus: Optional[str] = Field(None, alias="cloudStatus")
23
+ lastAlive: Optional[str] = Field(None, alias="lastAlive")
24
+ observacao: Optional[str] = Field(None, alias="observacao")
25
+ createdAt: Optional[datetime] = Field(None, alias="createdAt")
26
+ updatedAt: Optional[datetime] = Field(None, alias="updatedAt")
27
+
28
+ class Config:
29
+ populate_by_name = True
@@ -329,47 +329,46 @@ async def entrada_de_notas_15(task: RpaProcessoEntradaDTO) -> RpaRetornoProcesso
329
329
  except:
330
330
  console.print("Erros não foram encontrados após incluir o registro")
331
331
 
332
- # Verifica se a info 'Nota fiscal incluida' está na tela
333
- await worker_sleep(6)
334
- try:
335
- app = Application().connect(class_name="TFrmNotaFiscalEntrada")
336
- main_window = app["Information"]
337
-
338
- main_window.set_focus()
339
-
340
- console.print(f"Tentando clicar no Botão OK...\n")
341
- btn_ok = main_window.child_window(class_name="TButton")
342
-
343
- if btn_ok.exists():
344
- btn_ok.click()
345
- else:
346
- console.print(f" botão OK Não enontrado")
347
- except Exception as e:
348
- try:
349
- await worker_sleep(5)
350
- await emsys.verify_warning_and_error("Aviso", "OK")
351
- alterar_nop = await emsys.alterar_nop(nota["cfop"])
352
-
353
- if alterar_nop:
354
- return alterar_nop
355
- except Exception as error:
356
- observacao = f"Erro Processo Entrada de Notas: {str(error)}"
357
- logger.error(observacao)
358
- console.print(observacao, style="bold red")
359
- return RpaRetornoProcessoDTO(
360
- sucesso=False,
361
- retorno=observacao,
362
- status=RpaHistoricoStatusEnum.Falha,
363
- tags=[RpaTagDTO(descricao=RpaTagEnum.Tecnico)]
364
- )
365
-
366
332
  max_attempts = 60
367
333
  i = 0
368
334
 
369
335
  while i < max_attempts:
370
336
  information_pop_up = await is_window_open("Information")
371
337
  if information_pop_up["IsOpened"] == True:
372
- break
338
+ # Verifica se a info 'Nota fiscal incluida' está na tela
339
+ try:
340
+ app = Application().connect(class_name="TFrmNotaFiscalEntrada")
341
+ main_window = app["Information"]
342
+
343
+ main_window.set_focus()
344
+
345
+ console.print(f"Tentando clicar no Botão OK...\n")
346
+ btn_ok = main_window.child_window(class_name="TButton")
347
+
348
+ if btn_ok.exists():
349
+ btn_ok.click()
350
+ break
351
+ else:
352
+ console.print(f" botão OK Não enontrado")
353
+ except Exception as e:
354
+ try:
355
+ await worker_sleep(5)
356
+ await emsys.verify_warning_and_error("Warning", "OK")
357
+ await emsys.verify_warning_and_error("Aviso", "OK")
358
+ alterar_nop = await emsys.alterar_nop(nota["cfop"], nota["nfe"])
359
+
360
+ if alterar_nop:
361
+ return alterar_nop
362
+ except Exception as error:
363
+ observacao = f"Erro Processo Entrada de Notas: {str(error)}"
364
+ logger.error(observacao)
365
+ console.print(observacao, style="bold red")
366
+ return RpaRetornoProcessoDTO(
367
+ sucesso=False,
368
+ retorno=observacao,
369
+ status=RpaHistoricoStatusEnum.Falha,
370
+ tags=[RpaTagDTO(descricao=RpaTagEnum.Tecnico)]
371
+ )
373
372
  else:
374
373
  console.print(f"Aguardando confirmação de nota incluida...\n")
375
374
  await worker_sleep(5)
@@ -391,14 +391,21 @@ async def entrada_de_notas_16(task: RpaProcessoEntradaDTO) -> RpaRetornoProcesso
391
391
 
392
392
  except Exception as e:
393
393
  try:
394
- await worker_sleep(5)
395
- await emsys.verify_warning_and_error("Aviso", "OK")
396
- alterar_nop_result = await emsys.alterar_nop(nota.get("cfop"))
397
-
394
+ alterar_nop_result = await emsys.alterar_nop(nota.get("cfop"), nota.get("nfe"))
398
395
  if alterar_nop_result:
399
396
  await worker_sleep(5)
400
397
  resultado = await emsys.verify_max_variation()
401
398
  return alterar_nop_result
399
+ except ValueError as ve:
400
+ observacao = f"Erro Processo Entrada de Notas: {str(ve)}"
401
+ logger.error(observacao)
402
+ console.print(observacao, style="bold red")
403
+ return RpaRetornoProcessoDTO(
404
+ sucesso=False,
405
+ retorno=observacao,
406
+ status=RpaHistoricoStatusEnum.Falha,
407
+ tags=[RpaTagDTO(descricao=RpaTagEnum.Negocio)]
408
+ )
402
409
  except Exception as error:
403
410
  observacao = f"Erro Processo Entrada de Notas: {str(error)}"
404
411
  logger.error(observacao)
@@ -409,6 +416,7 @@ async def entrada_de_notas_16(task: RpaProcessoEntradaDTO) -> RpaRetornoProcesso
409
416
  status=RpaHistoricoStatusEnum.Falha,
410
417
  tags=[RpaTagDTO(descricao=RpaTagEnum.Tecnico)]
411
418
  )
419
+
412
420
  try:
413
421
 
414
422
  await emsys.verify_warning_and_error("Warning", "OK")
@@ -14,6 +14,7 @@ from pywinauto_recorder.player import set_combobox
14
14
  from rich.console import Console
15
15
  from datetime import datetime, timedelta
16
16
 
17
+ from worker_automate_hub.api.client import get_status_nf_emsys
17
18
  from worker_automate_hub.models.dao.rpa_configuracao import RpaConfiguracao
18
19
  from worker_automate_hub.models.dto.rpa_historico_request_dto import (
19
20
  RpaHistoricoStatusEnum,
@@ -28,6 +29,8 @@ from worker_automate_hub.utils.util import worker_sleep, is_window_open_by_class
28
29
  pyautogui.PAUSE = 0.5
29
30
  import pyperclip
30
31
 
32
+ ASSETS_PATH = "assets"
33
+
31
34
  console = Console()
32
35
 
33
36
 
@@ -674,7 +677,7 @@ class EMSys:
674
677
  f"Erro ao deletar o arquivo {xml_filename}: {str(e)}"
675
678
  ) from e
676
679
 
677
- async def alterar_nop(self, cfop: str) -> RpaRetornoProcessoDTO | None:
680
+ async def alterar_nop(self, cfop: str, chave_acesso=None) -> RpaRetornoProcessoDTO | None:
678
681
  await self.click_principal()
679
682
  console.print("Alterando a NOP...\n")
680
683
  pyautogui.click(945, 543)
@@ -700,6 +703,15 @@ class EMSys:
700
703
  pyautogui.hotkey("enter")
701
704
  await worker_sleep(6)
702
705
  await self.incluir_registro()
706
+ await worker_sleep(15)
707
+
708
+ if chave_acesso is not None:
709
+ console.print("\nVerifica se a nota ja foi lançada...")
710
+ nf_chave_acesso = int(chave_acesso)
711
+ status_nf_emsys = await get_status_nf_emsys(nf_chave_acesso)
712
+ if status_nf_emsys.get("status") != "Lançada":
713
+ raise ValueError("A nota não possui itens com o mesmo CFOP de capa. Necessário que ao menos um item possua este CFOP")
714
+
703
715
  else:
704
716
  pyautogui.hotkey("esc")
705
717
  observacao = f"Nota bonificada do tipo ({cfop}), está retornando diferença de itens sem o mesmo CFOP de capa. Por favor verifique a nota."
@@ -709,11 +721,28 @@ class EMSys:
709
721
  status=RpaHistoricoStatusEnum.Falha,
710
722
  tags=[RpaTagDTO(descricao=RpaTagEnum.Negocio)]
711
723
  )
712
- except:
713
- console.print("Falha ao alterar o NOP")
724
+ except ValueError as e:
725
+ console.print(f"Erro de validação ao alterar o NOP: {e}", style="bold red")
726
+ raise
727
+ except Exception as e:
728
+ console.print(f"Erro inesperado ao alterar o NOP: {e}", style="bold red")
729
+ raise
714
730
 
715
731
  return RpaRetornoProcessoDTO(
716
732
  sucesso=True,
717
733
  retorno="Nota lançada com sucesso!",
718
734
  status=RpaHistoricoStatusEnum.Sucesso,
719
735
  )
736
+
737
+ async def verify_nf_incuded(self) -> bool:
738
+ try:
739
+ nota_incluida = pyautogui.locateOnScreen(
740
+ ASSETS_PATH + "\\entrada_notas\\nota_fiscal_incluida.png", confidence=0.7
741
+ )
742
+ if nota_incluida:
743
+ return True
744
+ else:
745
+ return False
746
+ except Exception as e:
747
+ console.print(f"Error: {e}")
748
+ return False