DGPZ07P ;BAJ - HL7 Z07 CONSISTENCY CHECKER -- PRINT ROUTINE ; 06/30/06
;;5.3;Registration;**653**;Aug 13,1993;Build 2
;
; This routine prints the inconsistency report for the Z07 Consistency Check option
; This routine is copied from DGRPCP1 and modified for a single DFN
;
ST N DGSTOP,ZTSTOP,CRT,%,DGCLK1,I,J,X,Y,Z,DGCT,DGPG,DGDATA,DGDFN,DGER,DGHDR,DGINC,DGOFF,DGSSN,DGSTORE,DGZ,I1,I2,X1
S CRT=$S($E(IOST,1,2)="C-":1,1:0)
S DGDATA=^DGIN(38.5,DFN,0) I $D(^DPT(DFN,0)) D SET I $$FIRST^DGUTL G Q
S DGPG=0,DGHDR="INCONSISTENT ELEMENTS FOR "_$P(^DPT(DFN,0),"^",1)_" "_$P(^DPT(DFN,0),"^",9) D HDR
S I=0 F I1=0:0 S I=$O(^UTILITY($J,"DGINC",I)) Q:I="" F I2=0:0 S I2=$O(^UTILITY($J,"DGINC",I,I2)) Q:'I2 G:$G(DGSTOP) Q S X=^(I2) D W
D TRA
Q K %,%DT,DGVAR,DGER,DFN,DGPGM,^UTILITY($J,"DGINC")
D ENDREP^DGUTL,CLOSE^DGUTQ
Q
W W !,$P(X,"^",1),?31,$P(X,"^",2),?$S($E($P(X,"^",3))="*":43,1:45),$P(X,"^",3) I $S(CRT:$Y>20,1:$Y>45) D
. D:'CRT TRA S DGSTOP=$$SUBSEQ^DGUTL
. D HDR
Q
HDR Q:$G(DGSTOP) S DGPG=DGPG+1 W !,DGHDR
W:DGPG>1 ?73,"Page "_DGPG W !,"Patient Name",?31,"Soc Sec #",?45,"Inconsistent/Missing Data Elements"
S X1="",$P(X1,"=",80)="" W !,X1,!
Q
TRA S DGCT=0,X1="",$P(X1,"*",80)="" X "F DGZ=$Y:1:$S($D(IOSL):(IOSL-10),1:41) W !"
W !!,X1,!,"An inconsistent Data element preceded by '**' prevents a Z07"
W !,"record from being sent to the HEC.",!,X1
Q
SET S DGDFN=^DPT(DFN,0),DGSSN=$P(DGDFN,"^",9),DGSTORE=$S($P(DGDFN,"^",1)]"":$P(DGDFN,"^",1),1:"UNIDENTIFIED PATIENT #"_DFN)_" "_$E(DGSSN,8,9)_$E(DGSSN,6,7)_$E(DGSSN,4,5)_$E(DGSSN,1,3),DGINC="",DGLOOP=0
F J=0:0 S J=$O(^DGIN(38.5,DFN,"I",J)) Q:'J D
. Q:'$D(^DGIN(38.6,J))
. S DG6=$P(^DGIN(38.6,J,0),"^",6) I DG6'=1 S DG6=0
. S DGTEXT=$P(^DGIN(38.6,J,0),"^",1) I DG6 S DGTEXT="**"_DGTEXT
. ; set up variables
. S DGLOOP=DGLOOP+1
. ; print full first record, abbreviated subsequent records
. I DGLOOP=1 S ^UTILITY($J,"DGINC",DGSTORE,DGLOOP)=$S($P(DGDFN,"^",1)]"":$P(DGDFN,"^",1),1:"UNIDENTIFIED PATIENT #"_DFN)_U_$P(DGDFN,"^",9)_U_DGTEXT Q
. S ^UTILITY($J,"DGINC",DGSTORE,DGLOOP)="^^"_DGTEXT
K J,DGINC,DGSSN,DGDFN,DGLOOP,DGSTORE,DG6,DGCHK,DGTEXT
Q
;
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HDGPZ07P 2175 printed Dec 13, 2024@02:54:35 Page 2
DGPZ07P ;BAJ - HL7 Z07 CONSISTENCY CHECKER -- PRINT ROUTINE ; 06/30/06
+1 ;;5.3;Registration;**653**;Aug 13,1993;Build 2
+2 ;
+3 ; This routine prints the inconsistency report for the Z07 Consistency Check option
+4 ; This routine is copied from DGRPCP1 and modified for a single DFN
+5 ;
ST NEW DGSTOP,ZTSTOP,CRT,%,DGCLK1,I,J,X,Y,Z,DGCT,DGPG,DGDATA,DGDFN,DGER,DGHDR,DGINC,DGOFF,DGSSN,DGSTORE,DGZ,I1,I2,X1
+1 SET CRT=$SELECT($EXTRACT(IOST,1,2)="C-":1,1:0)
+2 SET DGDATA=^DGIN(38.5,DFN,0)
IF $DATA(^DPT(DFN,0))
DO SET
IF $$FIRST^DGUTL
GOTO Q
+3 SET DGPG=0
SET DGHDR="INCONSISTENT ELEMENTS FOR "_$PIECE(^DPT(DFN,0),"^",1)_" "_$PIECE(^DPT(DFN,0),"^",9)
DO HDR
+4 SET I=0
FOR I1=0:0
SET I=$ORDER(^UTILITY($JOB,"DGINC",I))
if I=""
QUIT
FOR I2=0:0
SET I2=$ORDER(^UTILITY($JOB,"DGINC",I,I2))
if 'I2
QUIT
if $GET(DGSTOP)
GOTO Q
SET X=^(I2)
DO W
+5 DO TRA
Q KILL %,%DT,DGVAR,DGER,DFN,DGPGM,^UTILITY($JOB,"DGINC")
+1 DO ENDREP^DGUTL
DO CLOSE^DGUTQ
+2 QUIT
W WRITE !,$PIECE(X,"^",1),?31,$PIECE(X,"^",2),?$SELECT($EXTRACT($PIECE(X,"^",3))="*":43,1:45),$PIECE(X,"^",3)
IF $SELECT(CRT:$Y>20,1:$Y>45)
Begin DoDot:1
+1 if 'CRT
DO TRA
SET DGSTOP=$$SUBSEQ^DGUTL
+2 DO HDR
End DoDot:1
+3 QUIT
HDR if $GET(DGSTOP)
QUIT
SET DGPG=DGPG+1
WRITE !,DGHDR
+1 if DGPG>1
WRITE ?73,"Page "_DGPG
WRITE !,"Patient Name",?31,"Soc Sec #",?45,"Inconsistent/Missing Data Elements"
+2 SET X1=""
SET $PIECE(X1,"=",80)=""
WRITE !,X1,!
+3 QUIT
TRA SET DGCT=0
SET X1=""
SET $PIECE(X1,"*",80)=""
XECUTE "F DGZ=$Y:1:$S($D(IOSL):(IOSL-10),1:41) W !"
+1 WRITE !!,X1,!,"An inconsistent Data element preceded by '**' prevents a Z07"
+2 WRITE !,"record from being sent to the HEC.",!,X1
+3 QUIT
SET SET DGDFN=^DPT(DFN,0)
SET DGSSN=$PIECE(DGDFN,"^",9)
SET DGSTORE=$SELECT($PIECE(DGDFN,"^",1)]"":$PIECE(DGDFN,"^",1),1:"UNIDENTIFIED PATIENT #"_DFN)_" "_$EXTRACT(DGSSN,8,9)_$EXTRACT(DGSSN,6,7)_$EXTRACT(DGSSN,4,5)_$EXTRACT(DGSSN,1,3)
SET DGINC=""
SET DGLOOP=0
+1 FOR J=0:0
SET J=$ORDER(^DGIN(38.5,DFN,"I",J))
if 'J
QUIT
Begin DoDot:1
+2 if '$DATA(^DGIN(38.6,J))
QUIT
+3 SET DG6=$PIECE(^DGIN(38.6,J,0),"^",6)
IF DG6'=1
SET DG6=0
+4 SET DGTEXT=$PIECE(^DGIN(38.6,J,0),"^",1)
IF DG6
SET DGTEXT="**"_DGTEXT
+5 ; set up variables
+6 SET DGLOOP=DGLOOP+1
+7 ; print full first record, abbreviated subsequent records
+8 IF DGLOOP=1
SET ^UTILITY($JOB,"DGINC",DGSTORE,DGLOOP)=$SELECT($PIECE(DGDFN,"^",1)]"":$PIECE(DGDFN,"^",1),1:"UNIDENTIFIED PATIENT #"_DFN)_U_$PIECE(DGDFN,"^",9)_U_DGTEXT
QUIT
+9 SET ^UTILITY($JOB,"DGINC",DGSTORE,DGLOOP)="^^"_DGTEXT
End DoDot:1
+10 KILL J,DGINC,DGSSN,DGDFN,DGLOOP,DGSTORE,DG6,DGCHK,DGTEXT
+11 QUIT
+12 ;