| 1 | RAPRINT1 ;HISC/FPT-Abnormal Exam Report (cont.) ;4/5/96  10:49
 | 
|---|
| 2 |  ;;5.0;Radiology/Nuclear Medicine;**34**;Mar 16, 1998
 | 
|---|
| 3 | DIV ; walk through tmp global, start with 'division'
 | 
|---|
| 4 |  Q:'$D(^TMP($J))
 | 
|---|
| 5 |  N RAFIRST,RAPRTSET,RASAME,RACURR,RAPREV,L1
 | 
|---|
| 6 |  S RADIVNME=""
 | 
|---|
| 7 |  F  S RADIVNME=$O(^TMP($J,RADIVNME)) Q:RADIVNME=""!(RAOUT)  D IT
 | 
|---|
| 8 |  Q
 | 
|---|
| 9 | IT ; imaging type
 | 
|---|
| 10 |  S RAITNAME=""
 | 
|---|
| 11 |  F  S RAITNAME=$O(^TMP($J,RADIVNME,RAITNAME)) Q:RAITNAME=""!(RAOUT)  D DXNUM
 | 
|---|
| 12 |  Q
 | 
|---|
| 13 | DXNUM ; diagnostic code number
 | 
|---|
| 14 |  S RAPREV="" ; Determine If Next Line Item is Related to Previous Line.
 | 
|---|
| 15 |  S I=0
 | 
|---|
| 16 |  F  S I=$O(^TMP($J,RADIVNME,RAITNAME,I)) Q:I'>0!(RAOUT)  D PATNAME
 | 
|---|
| 17 |  Q
 | 
|---|
| 18 | PATNAME ; patient name
 | 
|---|
| 19 |  S RAPATNME=""
 | 
|---|
| 20 |  F  S RAPATNME=$O(^TMP($J,RADIVNME,RAITNAME,I,RAPATNME)) Q:RAPATNME=""!(RAOUT)  D PATIEN
 | 
|---|
| 21 |  Q
 | 
|---|
| 22 | PATIEN ; patient internal entry number
 | 
|---|
| 23 |  S J=0
 | 
|---|
| 24 |  F  S J=$O(^TMP($J,RADIVNME,RAITNAME,I,RAPATNME,J)) Q:J'>0!(RAOUT)  D EXAMDATE
 | 
|---|
| 25 |  Q
 | 
|---|
| 26 | EXAMDATE ; exam date
 | 
|---|
| 27 |  S K=0
 | 
|---|
| 28 |  F  S K=$O(^TMP($J,RADIVNME,RAITNAME,I,RAPATNME,J,K)) Q:K'>0!(RAOUT)  D CASENUM
 | 
|---|
| 29 |  Q
 | 
|---|
| 30 | CASENUM ; case number
 | 
|---|
| 31 |  S (RAPRTSET,RAFIRST)=0 ; Group PrintSet Exams for Printing.
 | 
|---|
| 32 |  S RASAME=0 ; Group Multiple Diagnoses of Same Exam for Printing.
 | 
|---|
| 33 |  S L1=$O(^TMP($J,RADIVNME,RAITNAME,I,RAPATNME,J,K,0))
 | 
|---|
| 34 |  I L1>0,$P(^RADPT(J,"DT",K,"P",L1,0),U,25)=2 S RAFIRST=1 D
 | 
|---|
| 35 |  .I $O(^RADPT(J,"DT",K,"P",L1),-1) S RAFIRST=2 ; Not First PrintSet Exam.
 | 
|---|
| 36 |  S L=0
 | 
|---|
| 37 |  F  S L=$O(^TMP($J,RADIVNME,RAITNAME,I,RAPATNME,J,K,L)) Q:L'>0!(RAOUT)  D
 | 
|---|
| 38 |  .D DECIDE S (RAFIRST,RAPRTSET)=0
 | 
|---|
| 39 |  .S RAPREV=J_U_K_U_L ; This Represents Last Line Printed.
 | 
|---|
| 40 |  Q
 | 
|---|
| 41 | DECIDE ; decide which entries to print
 | 
|---|
| 42 |  S RAEXAM(0)=^RADPT(J,"DT",K,"P",L,0)
 | 
|---|
| 43 |  I 'RAFIRST,$P(RAEXAM(0),U,25)=2 S RAPRTSET=1 ; Determine Descendants.
 | 
|---|
| 44 |  S RACURR=J_U_K_U_L ; Save Current Line Info to be Printed.
 | 
|---|
| 45 |  S RADIAG=$P(^RA(78.3,I,0),U)
 | 
|---|
| 46 |  S RADXCODE=$S($P(RAEXAM(0),U,13)=I:"(P)",1:"(S)")
 | 
|---|
| 47 |  I RASW D PRINT Q
 | 
|---|
| 48 |  I RADXCODE="(P)",$P(RAEXAM(0),U,20) Q
 | 
|---|
| 49 |  I RADXCODE="(P)",'$P(RAEXAM(0),U,20) D PRINT Q
 | 
|---|
| 50 |  I '$D(^RADPT(J,"DT",K,"P",L,"DX")) Q
 | 
|---|
| 51 |  S RASDXIEN=$O(^RADPT(J,"DT",K,"P",L,"DX","B",I,0)) I RASDXIEN'>0 Q
 | 
|---|
| 52 |  S RASDXDTE=$P(^RADPT(J,"DT",K,"P",L,"DX",RASDXIEN,0),U,2)
 | 
|---|
| 53 |  I RASDXDTE="" D PRINT
 | 
|---|
| 54 |  Q
 | 
|---|
| 55 | PRINT ; print entries
 | 
|---|
| 56 |  I $Y+5>IOSL D HANG Q:RAOUT  D HDR Q:RAOUT
 | 
|---|
| 57 |  I I1("DIV")="" W !?22,"Division: ",RADIVNME S I1("DIV")=RADIVNME
 | 
|---|
| 58 |  I I1("IT")="" W !?18,"Imaging Type: ",RAITNAME S I1("IT")=RAITNAME
 | 
|---|
| 59 |  I I1("DIV")'=RADIVNME!(I1("IT")'=RAITNAME) D HANG Q:RAOUT  D HDR Q:RAOUT  S I1("DIV")=RADIVNME S I1("IT")=RAITNAME D
 | 
|---|
| 60 |  .W !?22,"Division: ",RADIVNME
 | 
|---|
| 61 |  .W !?18,"Imaging Type: ",RAITNAME
 | 
|---|
| 62 |  .I I1("DX")=I W !?15,"Diagnostic Code: ",RADIAG,!?15,"----------------"
 | 
|---|
| 63 |  I I1("DX")'=I W !?15,"Diagnostic Code: ",RADIAG S I1("DX")=I D
 | 
|---|
| 64 |  .I RAPREV=RACURR Q  ; Same Single Exam.
 | 
|---|
| 65 |  .W !?15,"----------------"
 | 
|---|
| 66 |  S RADFN=J,RAPAT=$S($D(^DPT(J,0)):^(0),1:""),RASSN=$$SSN^RAUTL(RADFN,1)
 | 
|---|
| 67 |  S RAPAT=$S($P(RAPAT,U)]"":$P(RAPAT,U),1:"Not Found")
 | 
|---|
| 68 |  S Y=9999999.9999-K X ^DD("DD") S RAEXDT=Y
 | 
|---|
| 69 |  S RACASE=$P(RAEXAM(0),U)
 | 
|---|
| 70 |  S RAWARD=$S($P(RAEXAM(0),U,6):$P(RAEXAM(0),U,6),1:"")
 | 
|---|
| 71 |  I RAWARD]"" S RAWARD=$S($D(^DIC(42,RAWARD,0)):$P(^(0),U),1:"")
 | 
|---|
| 72 |  I RAWARD']"" S RAWARD=$S($P(RAEXAM(0),U,8):$P(RAEXAM(0),U,8),1:"") I RAWARD]"" S RAWARD=$S($D(^SC(RAWARD,0)):$P(^(0),U),1:"Unknown")
 | 
|---|
| 73 |  S RAPROC=$P(RAEXAM(0),U,2)
 | 
|---|
| 74 |  S RAPROC=$S($D(^RAMIS(71,RAPROC,0)):$P(^(0),U),1:"Unknown")
 | 
|---|
| 75 |  S RAMD=$P(RAEXAM(0),U,14)
 | 
|---|
| 76 |  S RAMD=$S(RAMD="":"Unknown",$D(^VA(200,RAMD,0)):$P(^(0),U),1:"Unknown")
 | 
|---|
| 77 |  I RADXCODE="(S)",'$D(RASDXIEN) D SDX I '$D(RASDXDTE) K RADXCODE,RASDXDTE,RASDXIEN Q
 | 
|---|
| 78 |  I RAFIRST!'RAPRTSET D  ; Print Patient Header Once for PrintSets.
 | 
|---|
| 79 |  .I RAPREV=RACURR Q  ; Print Patient Header Once for Multiple Dx.
 | 
|---|
| 80 |  .W !!
 | 
|---|
| 81 |  .I RADXCODE="(P)" W $S($P(RAEXAM(0),U,20):"*",1:"")
 | 
|---|
| 82 |  .I RADXCODE="(S)" W $S(RASDXDTE]"":"*",1:"")
 | 
|---|
| 83 |  .W $E(RAPAT,1,30)_" -"_RASSN,?38,RADXCODE,?42,$E(RAWARD,1,15),?58,$E(RAMD,1,21)
 | 
|---|
| 84 |  ; Print Pat. Case# Once for Single Exam with Multiple Dx or
 | 
|---|
| 85 |  ; Once for PrintSets.
 | 
|---|
| 86 |  I (RAPREV'=RACURR)!RAPRTSET D
 | 
|---|
| 87 |  .W !?2 W:RAFIRST=1 "(+)" I (RAFIRST=2)!RAPRTSET W "(.)"
 | 
|---|
| 88 |  .W ?6,"Case #",RACASE,?20,$E(RAPROC,1,39),?60,RAEXDT
 | 
|---|
| 89 |  I RADXCODE="(P)",'$P(^RADPT(J,"DT",K,"P",L,0),U,20) S $P(^(0),U,20)=DT
 | 
|---|
| 90 |  I RADXCODE="(S)",'$P(^RADPT(J,"DT",K,"P",L,"DX",RASDXIEN,0),U,2) S $P(^(0),U,2)=DT
 | 
|---|
| 91 |  S ^TMP($J,"RADLY",RADIVNME,RAITNAME)=+^TMP($J,"RADLY",RADIVNME,RAITNAME)+1,CNT=CNT+1
 | 
|---|
| 92 |  K RADXCODE,RASDXDTE,RASDXIEN
 | 
|---|
| 93 |  Q
 | 
|---|
| 94 | HDR ; header
 | 
|---|
| 95 |  W:$Y>0 @IOF
 | 
|---|
| 96 |  W !?20,"<<<< ABNORMAL DIAGNOSTIC REPORT >>>>",?58,"Print Date: ",PDATE
 | 
|---|
| 97 |  W !?13,"(P=Primary Dx, S=Secondary Dx / '*' represents reprint)"
 | 
|---|
| 98 |  W !!,"Patient Name",?42,"Ward/Clinic",?58,"Requesting Physician"
 | 
|---|
| 99 |  W !?20,"Procedure",?60,"Exam Date",!,QQ
 | 
|---|
| 100 |  S I1("DIV")="",I1("IT")=""
 | 
|---|
| 101 |  I $D(ZTQUEUED) D STOPCHK^RAUTL9 S:$G(ZTSTOP)=1 RAOUT=1
 | 
|---|
| 102 |  Q
 | 
|---|
| 103 | HANG ; hold screen
 | 
|---|
| 104 |  K DIR,DIROUT,DIRUT,DTOUT,DUOUT
 | 
|---|
| 105 |  I $E(IOST,1,2)="C-" S DIR(0)="E" D ^DIR K DIR
 | 
|---|
| 106 |  S:$D(DIRUT) RAOUT=1
 | 
|---|
| 107 |  Q
 | 
|---|
| 108 | SDX ; secondary dx ien and date
 | 
|---|
| 109 |  I '$D(^RADPT(J,"DT",K,"P",L,"DX")) Q
 | 
|---|
| 110 |  S RASDXIEN=$O(^RADPT(J,"DT",K,"P",L,"DX","B",I,0))
 | 
|---|
| 111 |  Q:RASDXIEN'>0
 | 
|---|
| 112 |  S RASDXDTE=$P(^RADPT(J,"DT",K,"P",L,"DX",RASDXIEN,0),U,2)
 | 
|---|
| 113 |  Q
 | 
|---|