Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: ECXPAI

ECXPAI.m

Go to the documentation of this file.
  1. ECXPAI ;ALB/JAP,BIR/DMA,PTD-PAI Extract from File 45.9 ; 10/30/96 14:25
  1. ;;3.0;DSS EXTRACTS;**8,20,24,33**;Dec 22, 1997
  1. BEG ;entry point from option
  1. D SETUP I ECFILE="" Q
  1. D ^ECXTRAC,^ECXKILL
  1. Q
  1. ;
  1. START ; start package specific extract
  1. N OK
  1. S QFLG=0
  1. S ECED=ECED+.3,ECD=ECSD1
  1. F S ECD=$O(^DG(45.9,"AA",ECD)),ECF=0 Q:'ECD Q:ECD>ECED Q:QFLG F S ECF=$O(^DG(45.9,"AA",ECD,ECF)) Q:'ECF I $D(^DG(45.9,ECF,0)) S EC=^(0),ECXDFN=+EC,ECTD=$P(EC,U,7) D Q:QFLG
  1. .K ECXPAT S OK=$$PAT^ECXUTL3(ECXDFN,$P(ECD,"."),"1;",.ECXPAT)
  1. .Q:'OK
  1. .S X=$$INP^ECXUTL2(ECXDFN,$P(ECD,"."))
  1. .S ECXA=$P(X,U),ECXDOM=$P(X,U,10),ECXPNM=ECXPAT("NAME")
  1. .S ECXSSN=ECXPAT("SSN"),ECXMPI=ECXPAT("MPI"),ECXRACE=ECXPAT("RACE")
  1. .S ECXDSSD="",ECDA=0
  1. .F S ECDA=+$O(^DGPM("APCA",ECXDFN,ECDA)),ECTD1=ECTD-.0001 Q:'ECDA I $D(^DGPM(ECDA,0)) F S ECTD1=+$O(^DGPM("APCA",ECXDFN,ECDA,ECTD1)) Q:'ECTD1 Q:ECTD1>(ECTD+.3) D Q:QFLG
  1. ..S EC1=0 F S EC1=+$O(^DGPM("APCA",ECXDFN,ECDA,ECTD1,EC1)) Q:'EC1 I $D(^DGPM(EC1,0)),$P(^(0),U,2)'=3 S ECADM=$P(^DGPM(ECDA,0),U) D Q:QFLG
  1. ...D FILE
  1. Q
  1. ;
  1. FILE ;file record
  1. ;^dfn^ssn^name^i/o (ECXA)^day^admission date^admission time^
  1. ;admission/transfer date^admission/transfer time^race
  1. ;node1
  1. ;mpi^dss dept^dom^extended out patient
  1. N DA,DIK
  1. S EC7=$O(^ECX(ECFILE,999999999),-1)
  1. S ECODEZ="" I EC7>0 S ECODEZ=^ECX(ECFILE,EC7,0)
  1. S ECODE=U_U_ECXDFN_U_ECXSSN_U_ECXPNM_U_3_U
  1. S ECODE=ECODE_$$ECXDATE^ECXUTL(ECD,ECXYM)_U
  1. S ECODE=ECODE_$$ECXDATE^ECXUTL(ECADM,ECXYM)_U
  1. S ECODE=ECODE_$$ECXTIME^ECXUTL(ECADM)_U_$$ECXDATE^ECXUTL(ECTD1,ECXYM)_U
  1. S ECODE=ECODE_$$ECXTIME^ECXUTL(ECTD1)_U_ECXRACE_U
  1. S ECODE1=ECXMPI_U_ECXDSSD_U_ECXDOM_U_$G(ECXEOP)
  1. Q:$P(ECODE,U,4,14)=$P(ECODEZ,U,4,14)
  1. I $P(ECODE,U,3,7)=$P(ECODEZ,U,5,9),$P(ECODE,U,10)=$P(ECODEZ,U,12),$P(ECODE,U,8,9)'=$P(ECODEZ,10,11) D Q
  1. .S $P(^ECX(ECFILE,EC7,0),U,10,11)=$P(ECODE,U,8,9)
  1. S EC7=EC7+1
  1. S ^ECX(ECFILE,EC7,0)=EC7_U_EC23_ECODE,^ECX(ECFILE,EC7,1)=ECODE1,ECRN=ECRN+1
  1. S DA=EC7,DIK="^ECX("_ECFILE_"," D IX1^DIK K DIK,DA
  1. I $D(ZTQUEUED),$$S^%ZTLOAD S QFLG=1
  1. Q
  1. ;
  1. SETUP ;Set required input for ECXTRAC
  1. S ECHEAD="PAS"
  1. D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER)
  1. Q
  1. ;
  1. QUE ; entry point for the background requeuing handled by ECXTAUTO
  1. D SETUP,QUE^ECXTAUTO,^ECXKILL Q