| 1 | RASTREQN ;HIRMFO/GJC-Status Requirement check for Radiopharms ;11/18/97  15:13 | 
|---|
| 2 | ;;5.0;Radiology/Nuclear Medicine;**40**;Mar 16, 1998 | 
|---|
| 3 | ; | 
|---|
| 4 | ; *** 'RASTREQN' is called from routine: 'RASTREQ' *** | 
|---|
| 5 | EN1(RADIO,RAJ) ; Check if all the required radiopharmaceutical data has | 
|---|
| 6 | ; been entered for this particular Examination Status. | 
|---|
| 7 | ; *=*=*= Kills 'X' if the status cannot be updated =*=*=* | 
|---|
| 8 | ; Input: 'RADIO' -> .5 node of the examination status (Radiopharms req) | 
|---|
| 9 | ;        'RAJ'   -> 0 node of the examination | 
|---|
| 10 | ; | 
|---|
| 11 | ; NOTE: RAMES1 is set in RASTREQ^RASTREQ subroutine.  Only the 'Status | 
|---|
| 12 | ; Tracking Of Exams' option displays which required fields are not | 
|---|
| 13 | ; populated for the next available Exam Status. | 
|---|
| 14 | ; | 
|---|
| 15 | ;---------------------------------------------------------------------- | 
|---|
| 16 | ; Determine if 'Radiopharmaceutical' is required | 
|---|
| 17 | ; RAPRI defined in [RA STATUS CHANGE] & [RA EXAM EDIT] | 
|---|
| 18 | ; | 
|---|
| 19 | Q:"N"[$P(RADIO,"^")  ; Rpharms & Dosages NOT Req'd (either 'no' or null) | 
|---|
| 20 | N RAPROC S RAPROC(0)=$G(^RAMIS(71,+$P(RAJ,"^",2),0)) | 
|---|
| 21 | Q:$P(RAPROC(0),"^",2)=1  ; Never ask Rpharms & Dosages | 
|---|
| 22 | ;---------------------------------------------------------------------- | 
|---|
| 23 | N RA702 S RA702=+$P(RAJ,"^",28) ; ien in NUC MED EXAM DATA (70.2) file | 
|---|
| 24 | N RA7021,RACNT,RAI,RAMES2,RAREQ,RAZ S RAI=0 W:'$D(ZTQUEUED)#2 ! | 
|---|
| 25 | I 'RA702,($P(RADIO,"^")="Y") D  Q | 
|---|
| 26 | . K X S RAZ="Radiopharmaceutical" X:$D(RAMES1) RAMES1 | 
|---|
| 27 | . Q | 
|---|
| 28 | F  S RAI=$O(^RADPTN(RA702,"NUC",RAI)) Q:RAI'>0  D | 
|---|
| 29 | . S RA7021=$G(^RADPTN(RA702,"NUC",RAI,0)),RACNT=0 | 
|---|
| 30 | . S RAMES2="W:$G(K)=$P($G(^RA(72,+$G(RANXT72),0)),U,3)&('$D(ZTQUEUED)#2) !,""Radiopharmaceutical: "",$$GET1^DIQ(50,+$P(RA7021,""^"")_"","",.01)" | 
|---|
| 31 | . I $P(RADIO,"^")="Y",($P(RA7021,"^")=""!($P(RA7021,"^",7)="")) D | 
|---|
| 32 | .. K X S RACNT=RACNT+1 X:$D(RAMES1)&(RACNT=1) RAMES2 | 
|---|
| 33 | .. I $P(RA7021,"^")="" S RAZ="Radiopharmaceutical" X:$D(RAMES1) RAMES1 | 
|---|
| 34 | .. I $P(RA7021,"^",7)="" S RAZ="Dosage" X:$D(RAMES1) RAMES1 | 
|---|
| 35 | .. Q | 
|---|
| 36 | . I $P(RADIO,"^",3)="Y",($P(RA7021,"^",4)="") D | 
|---|
| 37 | .. S RACNT=RACNT+1 X:$D(RAMES1)&(RACNT=1) RAMES2 | 
|---|
| 38 | .. S RAZ="Activity Drawn" X:$D(RAMES1) RAMES1 K X | 
|---|
| 39 | .. Q | 
|---|
| 40 | . I $P(RADIO,"^",4)="Y",($P(RA7021,"^",5)=""!($P(RA7021,"^",6)="")) D | 
|---|
| 41 | .. K X S RACNT=RACNT+1 X:$D(RAMES1)&(RACNT=1) RAMES2 | 
|---|
| 42 | .. I $P(RA7021,"^",5)="" S RAZ="Date/Time Drawn" X:$D(RAMES1) RAMES1 | 
|---|
| 43 | .. I $P(RA7021,"^",6)="" S RAZ="Person Who Measured Dose" X:$D(RAMES1) RAMES1 | 
|---|
| 44 | .. Q | 
|---|
| 45 | . I $P(RADIO,"^",5)="Y",($P(RA7021,"^",8)=""!($P(RA7021,"^",9)="")) D | 
|---|
| 46 | .. K X S RACNT=RACNT+1 X:$D(RAMES1)&(RACNT=1) RAMES2 | 
|---|
| 47 | .. I $P(RA7021,"^",8)="" S RAZ="Date/Time Dose Administered" X:$D(RAMES1) RAMES1 | 
|---|
| 48 | .. I $P(RA7021,"^",9)="" S RAZ="Person Who Administered Dose" X:$D(RAMES1) RAMES1 | 
|---|
| 49 | .. Q | 
|---|
| 50 | . I $P(RADIO,"^",7)="Y",($P(RA7021,"^",11)=""!($P(RA7021,"^",12)="")) D | 
|---|
| 51 | .. K X S RACNT=RACNT+1 X:$D(RAMES1)&(RACNT=1) RAMES2 | 
|---|
| 52 | .. I $P(RA7021,"^",11)="" S RAZ="Route Of Administration" X:$D(RAMES1) RAMES1 | 
|---|
| 53 | .. I $P(RA7021,"^",12)="" S RAZ="Site Of Administration" X:$D(RAMES1) RAMES1 | 
|---|
| 54 | .. Q | 
|---|
| 55 | . I $P(RADIO,"^",8)="Y",($P(RA7021,"^",13)="") D | 
|---|
| 56 | .. S RACNT=RACNT+1 X:$D(RAMES1)&(RACNT=1) RAMES2 | 
|---|
| 57 | .. S RAZ="Lot No." X:$D(RAMES1) RAMES1 K X | 
|---|
| 58 | .. Q | 
|---|
| 59 | . I $P(RADIO,"^",9)="Y",($P(RA7021,"^",14)=""!($P(RA7021,"^",15)="")) D | 
|---|
| 60 | .. K X S RACNT=RACNT+1 X:$D(RAMES1)&(RACNT=1) RAMES2 | 
|---|
| 61 | .. I $P(RA7021,"^",14)="" S RAZ="Volume" X:$D(RAMES1) RAMES1 | 
|---|
| 62 | .. I $P(RA7021,"^",15)="" S RAZ="Form" X:$D(RAMES1) RAMES1 | 
|---|
| 63 | .. Q | 
|---|
| 64 | . W:'$D(ZTQUEUED)#2 ! ; spacing | 
|---|
| 65 | . Q | 
|---|
| 66 | Q | 
|---|
| 67 | NORADIO(RAPRI,RANXT72) ; This function will determine if Rpharm | 
|---|
| 68 | ; fields from the 'Nuc Med Exam Data' file [ ^RADPTN( ] will be asked. | 
|---|
| 69 | ; Input : 'RANXT72' -> .6 node of the 'Next' Exam Status | 
|---|
| 70 | ;       : 'RAPRI'   -> IEN of the procedure for this exam | 
|---|
| 71 | ; Output: '1' bypass Rpharm questions, else (0) ask | 
|---|
| 72 | Q:$TR($$UP^XLFSTR(RANXT72(.6)),"^","")="" 1 ; null or '^'s | 
|---|
| 73 | ; ------------------- Variable Definitions ---------------------------- | 
|---|
| 74 | ; 'RAPROC(2)': ask Rpharm & Dosages parameter for this procedure | 
|---|
| 75 | ;---------------------------------------------------------------------- | 
|---|
| 76 | N RAPROC S RAPROC(2)=$P($G(^RAMIS(71,RAPRI,0)),"^",2) | 
|---|
| 77 | ;---------------------------------------------------------------------- | 
|---|
| 78 | ; *  following conditions apply for descendants exams & single exams  * | 
|---|
| 79 | ; *  Number 1: Suppress Rpharm = 1 even if 'Rpharms/Dose' Req'd       * | 
|---|
| 80 | ; *  Number 2: Suppress Rpharm = null or 0, 'Rpharm/Dose' not req'd   * | 
|---|
| 81 | Q:RAPROC(2)=1 1 | 
|---|
| 82 | Q:"N"[$P(RANXT72(.6),"^") 1 | 
|---|
| 83 | ;---------------------------------------------------------------------- | 
|---|
| 84 | Q 0 ; ask Rpharm & Dosage fields | 
|---|
| 85 | DISDEF(RADA) ; Display Radiopharmaceutical default data | 
|---|
| 86 | ; Input: RADA -> ien of the Nuc Med Exam Data record | 
|---|
| 87 | Q:'$O(^RADPTN(RADA,"NUC",0))  ; Radiopharms missing, no data | 
|---|
| 88 | N RADARY,RADEUC,RAFLDS,RAIENS,RAOPUT,X,Y W ! | 
|---|
| 89 | S RAIENS="" D GETS^DIQ(70.2,RADA_",","**","NE","RADARY") | 
|---|
| 90 | F  S RAIENS=$O(RADARY(70.21,RAIENS)) Q:RAIENS=""  D | 
|---|
| 91 | . Q:$P(RAIENS,",",2)=""  ; top-level of the file | 
|---|
| 92 | . S (RADEUC,RAFLDS)=0 | 
|---|
| 93 | . F  S RAFLDS=$O(RADARY(70.21,RAIENS,RAFLDS)) Q:RAFLDS'>0  D  Q:$D(DIRUT) | 
|---|
| 94 | .. I RAFLDS=.01 D | 
|---|
| 95 | ... S RADEUC=0 W !,$G(RADARY(70.21,RAIENS,RAFLDS,"E")) | 
|---|
| 96 | ... W !,$$REPEAT^XLFSTR("-",$L($G(RADARY(70.21,RAIENS,RAFLDS,"E")))),! | 
|---|
| 97 | ... Q | 
|---|
| 98 | .. E  D | 
|---|
| 99 | ... S RADEUC=RADEUC+1 | 
|---|
| 100 | ... S RAOPUT=$$TRAN(RAFLDS)_$G(RADARY(70.21,RAIENS,RAFLDS,"E"))_$S(RAFLDS=2:" mCi",RAFLDS=4:" mCi",RAFLDS=7:" mCi",1:"") | 
|---|
| 101 | ... W:RADEUC=1 $E(RAOPUT,1,38) W:RADEUC=2 ?39,$E(RAOPUT,1,39) | 
|---|
| 102 | ... Q | 
|---|
| 103 | .. W:RADEUC'=2&($O(RADARY(70.21,RAIENS,RAFLDS))="") ! | 
|---|
| 104 | .. W:RADEUC=2 ! S:RADEUC=2 RADEUC=0 | 
|---|
| 105 | .. Q | 
|---|
| 106 | . Q | 
|---|
| 107 | Q | 
|---|
| 108 | TRAN(X) ; Translate field name to a shorter length. | 
|---|
| 109 | Q:X=2 "Dose (MD Override): " Q:X=3 "Prescriber: " | 
|---|
| 110 | Q:X=4 "Activity Drawn: " Q:X=5 "Drawn: " Q:X=6 "Measured By: " | 
|---|
| 111 | Q:X=7 "Dose Adm'd: " Q:X=8 "Date Adm'd: " Q:X=9 "Adm'd By: " | 
|---|
| 112 | Q:X=10 "Witness: " Q:X=11 "Route: " Q:X=12 "Site: " | 
|---|
| 113 | Q:X=12.5 "Site Text: " Q:X=13 "Lot #: " Q:X=14 "Volume: " | 
|---|
| 114 | Q:X=15 "Form: " | 
|---|
| 115 | VALDOS(RALOW,RAHI,X,RABACKTO,RAGOTO,RALASTAG,RAWARN) ;validate drawn/dose | 
|---|
| 116 | ; Called from [RA STATUS CHANGE] and [RA EXAM EDIT] input templates. | 
|---|
| 117 | ; Validate the value for either : | 
|---|
| 118 | ;      ACTIVITY DRAWN (fld 4, DD: 70.21) | 
|---|
| 119 | ;      DOSE           (fld 7, DD: 70.21) | 
|---|
| 120 | ; If there are limits on the Dosage, validate. | 
|---|
| 121 | ; If validate fails, ask user if the invalid value is to be accepted. | 
|---|
| 122 | ;   If yes, proceed. | 
|---|
| 123 | ;   If no,  re-ask DOSE. | 
|---|
| 124 | ; Input: RAHI     = Upper limit on dosage | 
|---|
| 125 | ;        RALOW    = Lower limit on dosage | 
|---|
| 126 | ;        X        = Value user input | 
|---|
| 127 | ;        RABACKTO = Previous Line tag to loop back to if need re-ask | 
|---|
| 128 | ;        RAGOTO   = Default linetag to proceed to if within range | 
|---|
| 129 | ;        RALASTAG = Last linetag in this edit template if early out | 
|---|
| 130 | ;        RAWARN   = display/not the warning msg -- 0=no, 1=yes | 
|---|
| 131 | ; | 
|---|
| 132 | ; Output: RAY     = linetag to proceed to after exiting this check | 
|---|
| 133 | ; | 
|---|
| 134 | N RAY,RAYN S RAY="" I X']"" S RAY=RAGOTO G KVAL | 
|---|
| 135 | S:RALOW=""&(RAHI="") RAY=RAGOTO | 
|---|
| 136 | S:RALOW]""&(RAHI="")&(X'<RALOW) RAY=RAGOTO | 
|---|
| 137 | S:RALOW=""&(RAHI]"")&(X'>RAHI) RAY=RAGOTO | 
|---|
| 138 | S:RALOW]""&(RAHI]"")&(X'<RALOW)&(X'>RAHI) RAY=RAGOTO | 
|---|
| 139 | I RAY="" D | 
|---|
| 140 | . F  D  Q:RAY]"" | 
|---|
| 141 | .. I $O(^RA(79,RAMDIV,"RWARN",0)) D:RAWARN | 
|---|
| 142 | ... N I S I=0 | 
|---|
| 143 | ... F  S I=$O(^RA(79,RAMDIV,"RWARN",I)) Q:I'>0  W !,$G(^(I,0)) | 
|---|
| 144 | ... Q | 
|---|
| 145 | .. E  D:RAWARN | 
|---|
| 146 | ... W !,"This dose requires a written, dated and signed directive by" | 
|---|
| 147 | ... W !,"a physician." | 
|---|
| 148 | ... Q | 
|---|
| 149 | .. W !!?3,"Are you sure (Y/N)?: N//" R RAYN:DTIME | 
|---|
| 150 | .. I '$T!(RAYN["^") S RAY=RALASTAG Q | 
|---|
| 151 | .. S RAYN=$S(RAYN']"":"N",1:$$UP^XLFSTR($E(RAYN))) | 
|---|
| 152 | .. S RAY=$S(RAYN="N":RABACKTO,RAYN="Y":RAGOTO,1:"") | 
|---|
| 153 | .. I RAY="" W !!?3,"Enter 'Yes' if this value is acceptable, or 'No' if this field is to be",!?3,"re-edited.",$C(7) | 
|---|
| 154 | .. Q | 
|---|
| 155 | . Q | 
|---|
| 156 | KVAL K RABACKTO,RAGOTO,RALASTAG,RAWARN | 
|---|
| 157 | Q RAY | 
|---|