| 1 | RALWKL3 ;HISC/GJC-Workload Reports By Functional Area ;9/23/96  09:00
 | 
|---|
| 2 |  ;;5.0;Radiology/Nuclear Medicine;;Mar 16, 1998
 | 
|---|
| 3 | CHK ; Does the data meet the sort criteria?
 | 
|---|
| 4 |  S C=$P(RAP0,"^",4),C=$S(C="I":1,C="O":2,C="R":3,1:4)
 | 
|---|
| 5 |  Q:'$P(RAP0,"^",RAPCE)  S RAFLD=$S($D(@("^"_RAFILE_"+$P(RAP0,""^"",RAPCE),0)")):$P(^(0),"^"),1:"Unknown")
 | 
|---|
| 6 |  I 'RAINPUT Q:'$D(^TMP($J,"RAFLD",RAFLD))  ; not all and not a user selected entry
 | 
|---|
| 7 |  S RAFLD=$E(RAFLD,1,30)
 | 
|---|
| 8 |  I RAFILE="SC(" Q:C=1
 | 
|---|
| 9 |  I (RAFILE="DIC(42,"!(RAFILE="DIC(42.4,")!(RAFILE="DIC(49,")) Q:13'[C
 | 
|---|
| 10 |  F I=0:0 S I=$O(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"M",I)) Q:I'>0  I $D(^(I,0)) S RAQI=+$G(^(0)) D EXTRA^RAUTL12(RAQI)
 | 
|---|
| 11 |  Q:'$D(^RAMIS(71,+$P(RAP0,"^",2),0))  S RAPRI=$G(^(0)),RAPRC=$E($P(RAPRI,"^"),1,40) Q:'$D(^(2))  F I=0:0 S I=$O(^RAMIS(71,+$P(RAP0,"^",2),2,I)) Q:I'>0  I $D(^(I,0)) S RAZ=$G(^(0)),RAMJ=$S($D(^RAMIS(71.1,+RAZ,0)):^(0),1:"") D PRC^RALWKL
 | 
|---|
| 12 |  Q:'$D(RAMIS(1))
 | 
|---|
| 13 |  I J=1 S RAMIS=RAMIS(1),RAWT=RAWT(1),RAMUL=RAMUL(1),RAWT=RAWT*RAMUL,RANUM=RAMUL
 | 
|---|
| 14 |  I J>1 S RANUM=1,RAWT=0,RAMIS=RAMIS(1) F J=1:1 Q:'$D(RAMIS(J))  S I=RAWT(J),RAMUL=RAMUL(J),RAWT=RAWT+(RAMUL*I)
 | 
|---|
| 15 |  D STORE K RAMIS,RAWT,RAMUL,RAZ,RAMJ,RAMULP,RAMULPFL,RABILAT,RAOR,RAPORT
 | 
|---|
| 16 |  Q
 | 
|---|
| 17 | STORE ; Store off data into ^TMP global.
 | 
|---|
| 18 |  I $D(ZTQUEUED) D STOPCHK^RAUTL9 S:$G(ZTSTOP)=1 RAXIT=1 Q:RAXIT
 | 
|---|
| 19 |  I $D(RAOR) S A=25 D AUX^RALWKL
 | 
|---|
| 20 |  I $D(RAPORT) S A=26 D AUX^RALWKL
 | 
|---|
| 21 |  I $D(RAMULP) S A="MULP" D AUX^RALWKL
 | 
|---|
| 22 |  ;----------- Tabulation over all divisions -----------------------------
 | 
|---|
| 23 |  S X=$G(^TMP($J,"RA",RADIV))
 | 
|---|
| 24 |  S $P(X,"^",C)=$P(X,"^",C)+RANUM,$P(X,"^",5)=$P(X,"^",5)+RAWT
 | 
|---|
| 25 |  S ^TMP($J,"RA",RADIV)=X
 | 
|---|
| 26 |  ;----------- Tabulation over all divisions/imaging types ---------------
 | 
|---|
| 27 |  S X=$G(^TMP($J,"RA",RADIV,RAIMG))
 | 
|---|
| 28 |  S $P(X,"^",C)=$P(X,"^",C)+RANUM,$P(X,"^",5)=$P(X,"^",5)+RAWT
 | 
|---|
| 29 |  S ^TMP($J,"RA",RADIV,RAIMG)=X
 | 
|---|
| 30 |  ;------------Tabulation over division/i-type/option parameter ----------
 | 
|---|
| 31 |  I '$D(^TMP($J,"RA",RADIV,RAIMG,RAFLD))#2 D
 | 
|---|
| 32 |  . S ^TMP($J,"RA",RADIV,RAIMG,RAFLD)="0^0^0^0^0"
 | 
|---|
| 33 |  S X=$G(^TMP($J,"RA",RADIV,RAIMG,RAFLD))
 | 
|---|
| 34 |  S $P(X,"^",C)=$P(X,"^",C)+RANUM,$P(X,"^",5)=$P(X,"^",5)+RAWT
 | 
|---|
| 35 |  S ^TMP($J,"RA",RADIV,RAIMG,RAFLD)=X
 | 
|---|
| 36 |  ;------------Tabulation over division/option parameter ----------
 | 
|---|
| 37 |  ; ***** Note new '^TMP($J' subscript (RA1) *****
 | 
|---|
| 38 |  I '$D(^TMP($J,"RA1",RADIV,RAFLD))#2 D
 | 
|---|
| 39 |  . S ^TMP($J,"RA1",RADIV,RAFLD)="0^0^0^0^0"
 | 
|---|
| 40 |  S X=$G(^TMP($J,"RA1",RADIV,RAFLD))
 | 
|---|
| 41 |  S $P(X,"^",C)=$P(X,"^",C)+RANUM,$P(X,"^",5)=$P(X,"^",5)+RAWT
 | 
|---|
| 42 |  S ^TMP($J,"RA1",RADIV,RAFLD)=X
 | 
|---|
| 43 |  ;----------- Tabulation over division/i-types/option parameter/proc ----
 | 
|---|
| 44 |  I '$D(^TMP($J,"RA",RADIV,RAIMG,RAFLD,RAMIS,RAPRC)) D
 | 
|---|
| 45 |  . S ^TMP($J,"RA",RADIV,RAIMG,RAFLD,RAMIS,RAPRC)="0^0^0^0^0"
 | 
|---|
| 46 |  S X=$G(^TMP($J,"RA",RADIV,RAIMG,RAFLD,RAMIS,RAPRC))
 | 
|---|
| 47 |  S $P(X,"^",C)=$P(X,"^",C)+RANUM,$P(X,"^",5)=$P(X,"^",5)+RAWT
 | 
|---|
| 48 |  S ^TMP($J,"RA",RADIV,RAIMG,RAFLD,RAMIS,RAPRC)=X
 | 
|---|
| 49 |  Q
 | 
|---|
| 50 | ALLNOTH() ; Do you want access to all entries in the file or just a subset
 | 
|---|
| 51 |  ; of entries?
 | 
|---|
| 52 |  ; 'RAPRIM' will be defined if accessing this subroutine through the
 | 
|---|
| 53 |  ; Options: RA WKLRES (Resident Report) & RA WKLSTAFF (Staff Report)
 | 
|---|
| 54 |  N RAINPUT K DIR,X,Y S DIR(0)="YA",DIR("B")="Yes"
 | 
|---|
| 55 |  S DIR("A")="Do you wish to include all "_$S($G(RAPRIM)=1:"Primary ",1:"")_$G(RATITLE)_"s? "
 | 
|---|
| 56 |  I $G(RATITLE)="Interpreting Staff" S DIR("A")="Do you wish to include all"_$S($G(RAPRIM)=1:" Primary",1:"")_" Interpreting Staff? "
 | 
|---|
| 57 |  S DIR("?",1)="Enter 'Yes' to select all entries in the file."
 | 
|---|
| 58 |  S DIR("?")="Enter 'No' to select a subset of entries in the file."
 | 
|---|
| 59 |  W ! D ^DIR K DIR Q:$D(DIRUT) ""
 | 
|---|
| 60 |  S RAINPUT=+Y K DIROUT,DIRUT,DTOUT,DUOUT,X,Y
 | 
|---|
| 61 |  Q RAINPUT
 | 
|---|
| 62 | ONE(Z) ; Check if only one entry in the file.  (File specs passed in.)
 | 
|---|
| 63 |  N RAXREF,RAZERO,X,X1,Y,Y1
 | 
|---|
| 64 |  S RAXREF="^"_Z_"""B"",",RAZERO="^"_Z
 | 
|---|
| 65 |  S X=$O(@(RAXREF_""""")")) Q:X']""
 | 
|---|
| 66 |  S Y=$O(@(RAXREF_""""_X_""")")) Q:Y]""
 | 
|---|
| 67 |  S X1=+$O(@(RAXREF_""""_X_""",0)")) Q:'X1
 | 
|---|
| 68 |  S:Z="SC(" Y1=$P($G(@(RAZERO_X1_",0)")),"^")
 | 
|---|
| 69 |  S:Z'="SC(" Y1=$P($G(@(RAZERO_X1_",0)")),"^")
 | 
|---|
| 70 |  S ^TMP($J,"RAFLD",Y1,X1)="",RAINPUT=0
 | 
|---|
| 71 |  Q
 | 
|---|
| 72 | SELECT ; Select one-many-all entries from a specific file.
 | 
|---|
| 73 |  Q:$D(^TMP($J,"RAFLD"))  ; Only one entry in the file
 | 
|---|
| 74 |  N RADIC,RAUTIL S RADIC="^"_RAFILE,RADIC(0)="QEAMZ"
 | 
|---|
| 75 |  S RADIC("A")="Select "_$G(RATITLE)_": "
 | 
|---|
| 76 |  S RAUTIL="RAFLD",RAINPUT=$$ALLNOTH()
 | 
|---|
| 77 |  S:RAINPUT="" RAXIT=1 Q:RAXIT
 | 
|---|
| 78 |  D:'RAINPUT EN1^RASELCT(.RADIC,RAUTIL,"",RAINPUT)
 | 
|---|
| 79 |  S RAXIT=RAQUIT K:RAXIT RAINPUT Q:RAXIT
 | 
|---|
| 80 |  Q
 | 
|---|