| 1 | RORHL031 ;HOIFO/BH,SG - HL7 PHARMACY: UTILITIES ; 3/13/06 9:23am | 
|---|
| 2 | ;;1.5;CLINICAL CASE REGISTRIES;**1**;Feb 17, 2006;Build 24 | 
|---|
| 3 | ; | 
|---|
| 4 | ; This routine uses the following IAs: | 
|---|
| 5 | ; | 
|---|
| 6 | ; #1878         EN^PSOORDER | 
|---|
| 7 | ; #4533         ARWS^PSS50 (supported) | 
|---|
| 8 | ; #4545         DATA^PSN50P68 (supported) | 
|---|
| 9 | ; #4820         RX^PSO52API (supported) | 
|---|
| 10 | ; | 
|---|
| 11 | Q | 
|---|
| 12 | ; | 
|---|
| 13 | ;***** OUTPATIENT PHARMACY RXE SEGMENT BUILDER | 
|---|
| 14 | ; | 
|---|
| 15 | ; RORIEN        IEN in the PRESCRIPTION file (#52) | 
|---|
| 16 | ; | 
|---|
| 17 | ; .RORRXE       Array with info (from OEL^PSOORRL) | 
|---|
| 18 | ; | 
|---|
| 19 | ; PTIEN         Patient IEN (DFN) | 
|---|
| 20 | ; | 
|---|
| 21 | ; The ^TMP("PSOR",$J) global node is used by this function. | 
|---|
| 22 | ; | 
|---|
| 23 | ; Return Values: | 
|---|
| 24 | ;       <0  Error Code | 
|---|
| 25 | ;        0  Ok | 
|---|
| 26 | ;       >0  Non-fatal error(s) | 
|---|
| 27 | ; | 
|---|
| 28 | RXE(RORIEN,RORRXE,PTIEN) ; | 
|---|
| 29 | N BUF,CS,ERRCNT,IDGN,II,INDF,J,L,RC,RORCLIN,RORCMOP,RORISIG,RORLST,RORMREF,RORMSG,RORPRICE,RORSEG,RORSTAT,RORSTOP,RORTEST,RORTMP,RORTS,TMP | 
|---|
| 30 | S (ERRCNT,RC)=0 | 
|---|
| 31 | D ECH^RORHL7(.CS) | 
|---|
| 32 | ; | 
|---|
| 33 | Q:$P($G(RORRXE(0)),U)="" 0 | 
|---|
| 34 | ; | 
|---|
| 35 | K ^TMP("PSOR",$J) | 
|---|
| 36 | D EN^PSOORDER(,RORIEN) | 
|---|
| 37 | ; | 
|---|
| 38 | S BUF=$G(^TMP("PSOR",$J,RORIEN,0)) | 
|---|
| 39 | S RORMREF=$P(BUF,U,8)            ; # of refills | 
|---|
| 40 | S RORPRICE=$P(BUF,U,10)          ; unit price of drugs | 
|---|
| 41 | ; | 
|---|
| 42 | S BUF=$G(^TMP("PSOR",$J,RORIEN,1)) | 
|---|
| 43 | S RORSTAT=$P($P(BUF,U,5),";",1)  ; patient status (internal) | 
|---|
| 44 | S RORSTDE=$P($P(BUF,U,5),";",2)  ; patient status | 
|---|
| 45 | S RORCLIN=+$P(BUF,U,4)           ; clinic | 
|---|
| 46 | ; | 
|---|
| 47 | S (J,RORISIG)="",L=245 | 
|---|
| 48 | F  S J=$O(^TMP("PSOR",$J,RORIEN,"SIG1",J))  Q:J=""  D  Q:L'>0 | 
|---|
| 49 | . S BUF=$G(^TMP("PSOR",$J,RORIEN,"SIG1",J,0)) | 
|---|
| 50 | . S RORISIG=RORISIG_" "_$E(BUF,1,L) | 
|---|
| 51 | . S L=L-$L(BUF)-1  S:L<-1 RORISIG=RORISIG_"..." | 
|---|
| 52 | S RORISIG=$$TRIM^XLFSTR(RORISIG) | 
|---|
| 53 | ; | 
|---|
| 54 | ;--- Get Stop Code | 
|---|
| 55 | S RORSTOP=$$STOPCODE^RORUTL18(+RORCLIN) | 
|---|
| 56 | S:RORSTOP'>0 RORSTOP="" | 
|---|
| 57 | ; | 
|---|
| 58 | S RORTMP=$$ALLOC^RORTMP(.RORTS) | 
|---|
| 59 | D RX^PSO52API(PTIEN,RORTS,RORIEN,,"C,R") | 
|---|
| 60 | ;--- Get last dispensed dates | 
|---|
| 61 | S II=0  K RORLST | 
|---|
| 62 | F  S II=$O(@RORTMP@(PTIEN,RORIEN,"RF",II))  Q:II'>0  D | 
|---|
| 63 | . S RORLST(II,10.1)=+$G(@RORTMP@(PTIEN,RORIEN,"RF",II,10.1)) | 
|---|
| 64 | ;--- Load the CMOP list | 
|---|
| 65 | S II=0  K RORCMOP | 
|---|
| 66 | F  S II=$O(@RORTMP@(PTIEN,RORIEN,"C",II))  Q:II'>0  D | 
|---|
| 67 | . Q:+$G(@RORTMP@(PTIEN,RORIEN,"C",II,3))=3 | 
|---|
| 68 | . S TMP=$G(@RORTMP@(PTIEN,RORIEN,"C",II,2)) | 
|---|
| 69 | . S:TMP'="" RORCMOP("A2",TMP,II)="" | 
|---|
| 70 | ;--- Free the buffer | 
|---|
| 71 | D FREE^RORTMP(RORTMP) | 
|---|
| 72 | ; | 
|---|
| 73 | F RORINDEX="REF","PAR" D | 
|---|
| 74 | . S II="" | 
|---|
| 75 | . F  S II=$O(RORRXE(RORINDEX,II))  Q:II=""  D  Q:RC<0 | 
|---|
| 76 | . . S RORTEST=$G(RORRXE(RORINDEX,II,0))  Q:RORTEST="" | 
|---|
| 77 | . . ; | 
|---|
| 78 | . . ;--- Initialize the segment | 
|---|
| 79 | . . K RORSEG  S RORSEG(0)="RXE" | 
|---|
| 80 | . . ; | 
|---|
| 81 | . . ;--- RXE-1 - Quantity/Timing | 
|---|
| 82 | . . S RORSEG(1)="""""" | 
|---|
| 83 | . . ; | 
|---|
| 84 | . . ;--- RXE-2 - Give Code | 
|---|
| 85 | . . S IDGN=+$P($G(RORRXE("DD",1,0)),U,3)  ; File #50 IEN | 
|---|
| 86 | . . I IDGN'>0  S IDGN=+$P($G(RORRXE("DD",1,0)),U)  Q:IDGN'>0 | 
|---|
| 87 | . . S TMP=$$RXE2(IDGN,CS,.BUF,.INDF) | 
|---|
| 88 | . . I TMP  S ERRCNT=ERRCNT+1  Q:TMP<0 | 
|---|
| 89 | . . Q:BUF="" | 
|---|
| 90 | . . S RORSEG(2)=BUF | 
|---|
| 91 | . . ; | 
|---|
| 92 | . . ;--- RXE-3 - Give Amount (Min) | 
|---|
| 93 | . . S RORSEG(3)="""""" | 
|---|
| 94 | . . ; | 
|---|
| 95 | . . ;--- RXE-4 - Max # of re-fills | 
|---|
| 96 | . . S RORSEG(4)=RORMREF | 
|---|
| 97 | . . ; | 
|---|
| 98 | . . ;--- RXE-5 - Give Units | 
|---|
| 99 | . . S TMP=$$RXE5(+$G(INDF),CS,.BUF) | 
|---|
| 100 | . . S:TMP ERRCNT=ERRCNT+1 | 
|---|
| 101 | . . S:BUF'="" RORSEG(5)=BUF | 
|---|
| 102 | . . ; | 
|---|
| 103 | . . ;--- RXE-6 - Release Date/Time | 
|---|
| 104 | . . S TMP=$P($G(RORRXE(RORINDEX,II,0)),U,4) | 
|---|
| 105 | . . S RORSEG(6)=$$FM2HL^RORHL7(TMP) | 
|---|
| 106 | . . ; | 
|---|
| 107 | . . ;--- RXE-7 - SIG1 | 
|---|
| 108 | . . S RORSEG(7)=CS_$$ESCAPE^RORHL7(RORISIG) | 
|---|
| 109 | . . ; | 
|---|
| 110 | . . ;--- RXE-10 - Dispense amount | 
|---|
| 111 | . . S RORSEG(10)=$P($G(RORRXE(RORINDEX,II,0)),U,3) | 
|---|
| 112 | . . ; | 
|---|
| 113 | . . ;--- RXE-15 - Refill Indicator | 
|---|
| 114 | . . S RORSEG(15)=$S(RORINDEX="REF":1,RORINDEX="PAR":2) | 
|---|
| 115 | . . ; | 
|---|
| 116 | . . ;--- RXE-17 - Refill # | 
|---|
| 117 | . . S RORSEG(17)=II | 
|---|
| 118 | . . ; | 
|---|
| 119 | . . ;--- RXE-18 - Fill Date/Time | 
|---|
| 120 | . . S TMP=$P($G(RORRXE(RORINDEX,II,0)),U) | 
|---|
| 121 | . . S RORSEG(18)=$$FM2HL^RORHL7(TMP) | 
|---|
| 122 | . . ; | 
|---|
| 123 | . . ;--- RXE-19 - Total Daily Dose | 
|---|
| 124 | . . S RORSEG(19)=$P($G(RORRXE(RORINDEX,II,0)),U,2) | 
|---|
| 125 | . . ; | 
|---|
| 126 | . . ;--- RXE-20 - CMOP | 
|---|
| 127 | . . S RORSEG(20)=$S($D(RORCMOP("A2",II)):"Y",1:"N") | 
|---|
| 128 | . . ; | 
|---|
| 129 | . . ;--- RXE-21 - Clinic Stop | 
|---|
| 130 | . . S RORSEG(21)=RORSTOP | 
|---|
| 131 | . . ; | 
|---|
| 132 | . . ;--- RXE-22 - Dispense Date | 
|---|
| 133 | . . I 'II  D | 
|---|
| 134 | . . . S TMP=$P($G(RORRXE(0)),U,5) | 
|---|
| 135 | . . . S RORSEG(22)=$$FM2HL^RORHL7(TMP) | 
|---|
| 136 | . . E  D:$D(RORLST(II)) | 
|---|
| 137 | . . . S TMP=+$G(RORLST(II,10.1)) | 
|---|
| 138 | . . . S RORSEG(22)=$$FM2HL^RORHL7(TMP) | 
|---|
| 139 | . . ; | 
|---|
| 140 | . . ;--- RXE-23 - Unit Cost | 
|---|
| 141 | . . S RORSEG(23)=RORPRICE | 
|---|
| 142 | . . ; | 
|---|
| 143 | . . ;--- RXE-27 - Patient Status | 
|---|
| 144 | . . S RORSEG(27)=RORSTAT_CS_RORSTDE | 
|---|
| 145 | . . ; | 
|---|
| 146 | . . ;--- RXE-30 Mail/Window | 
|---|
| 147 | . . S TMP=$P($G(RORRXE(RORINDEX,II,0)),U,5) | 
|---|
| 148 | . . S RORSEG(30)=$S(TMP="M":"AD",TMP="W":"TR",1:"") | 
|---|
| 149 | . . ; | 
|---|
| 150 | . . ;--- Store the segment | 
|---|
| 151 | . . D ADDSEG^RORHL7(.RORSEG) | 
|---|
| 152 | ; | 
|---|
| 153 | K ^TMP("PSOR",$J) | 
|---|
| 154 | Q ERRCNT | 
|---|
| 155 | ; | 
|---|
| 156 | ;***** CONSTRUCTS THE RXE-2 FIELD (GIVE CODE) | 
|---|
| 157 | ; | 
|---|
| 158 | ; IEN50         IEN in the DRUG file (#50) | 
|---|
| 159 | ; | 
|---|
| 160 | ; [CS]          Component Separator (defaults to "^") | 
|---|
| 161 | ; | 
|---|
| 162 | ; .RXE2         Reference to a local variable where the value | 
|---|
| 163 | ;               of the  RXE-2 field is returned | 
|---|
| 164 | ; | 
|---|
| 165 | ; [.PSNDF]      VA PRODUCT | 
|---|
| 166 | ;                 ^01: IEN | 
|---|
| 167 | ;                 ^02: NAME (.01) | 
|---|
| 168 | ; | 
|---|
| 169 | ; Return Values: | 
|---|
| 170 | ;       <0  Error Code | 
|---|
| 171 | ;        0  Ok | 
|---|
| 172 | ;       >0  Non-fatal error(s) | 
|---|
| 173 | ; | 
|---|
| 174 | RXE2(IEN50,CS,RXE2,PSNDF) ; | 
|---|
| 175 | N ERRCNT,IDGN,NODE,RC,RORMSG,TMP,TMP1 | 
|---|
| 176 | S (ERRCNT,RC)=0,RXE2="" | 
|---|
| 177 | ; | 
|---|
| 178 | S:$G(CS)="" CS="^" | 
|---|
| 179 | S IDGN=+$G(IEN50) | 
|---|
| 180 | ; | 
|---|
| 181 | S NODE=$$ALLOC^RORTMP(.TMP) | 
|---|
| 182 | D ARWS^PSS50(IDGN,,TMP) | 
|---|
| 183 | ; | 
|---|
| 184 | S $P(RXE2,CS,1)=$G(@NODE@(IDGN,31))        ; NDC | 
|---|
| 185 | ;--- VA Product Name | 
|---|
| 186 | S PSNDF=$G(@NODE@(IDGN,22)),TMP1=$P(PSNDF,U,2) | 
|---|
| 187 | S $P(RXE2,CS,2)=$$ESCAPE^RORHL7($E(TMP1,1,64)) | 
|---|
| 188 | S $P(RXE2,CS,3)="PSNDF" | 
|---|
| 189 | ; | 
|---|
| 190 | S TMP="" | 
|---|
| 191 | S $P(TMP,"-",1)=$P($G(@NODE@(IDGN,20)),U)  ; VA Drug Code | 
|---|
| 192 | S $P(TMP,"-",2)=$G(@NODE@(IDGN,2))         ; VA Drug Class | 
|---|
| 193 | S:TMP'="-" $P(RXE2,CS,4)=TMP | 
|---|
| 194 | ;--- Drug Name | 
|---|
| 195 | S $P(RXE2,CS,5)=$$ESCAPE^RORHL7($G(@NODE@(IDGN,.01))) | 
|---|
| 196 | S $P(RXE2,CS,6)="99PSD" | 
|---|
| 197 | ; | 
|---|
| 198 | D FREE^RORTMP(NODE) | 
|---|
| 199 | S:($P(RXE2,CS,1,2)="^")&($P(RXE2,CS,4,5)="^") RXE2="" | 
|---|
| 200 | Q ERRCNT | 
|---|
| 201 | ; | 
|---|
| 202 | ;***** CONSTRUCTS THE RXE-5 FIELD (GIVE UNITS) | 
|---|
| 203 | ; | 
|---|
| 204 | ; IEN50P68      IEN in the VA PRODUCT file (#50.68) | 
|---|
| 205 | ; | 
|---|
| 206 | ; [CS]          Component Separator (defaults to "^") | 
|---|
| 207 | ; | 
|---|
| 208 | ; .RXE5         Reference to a local variable where the value | 
|---|
| 209 | ;               of the  RXE-5 field is returned | 
|---|
| 210 | ; | 
|---|
| 211 | ; Return Values: | 
|---|
| 212 | ;       <0  Error Code | 
|---|
| 213 | ;        0  Ok | 
|---|
| 214 | ; | 
|---|
| 215 | RXE5(IEN50P68,CS,RXE5) ; | 
|---|
| 216 | N INDF,NODE,TMP | 
|---|
| 217 | S:$G(CS)="" CS="^" | 
|---|
| 218 | S RXE5="",INDF=+$G(IEN50P68) | 
|---|
| 219 | Q:INDF'>0 0 | 
|---|
| 220 | ;--- Get the units | 
|---|
| 221 | S NODE=$$ALLOC^RORTMP(.TMP) | 
|---|
| 222 | D DATA^PSN50P68(INDF,,TMP) | 
|---|
| 223 | S TMP=$G(@NODE@(INDF,3)) | 
|---|
| 224 | D FREE^RORTMP(NODE) | 
|---|
| 225 | Q:TMP'>0 0 | 
|---|
| 226 | ;--- Format the field | 
|---|
| 227 | S $P(RXE5,CS,4)=$P(TMP,U) | 
|---|
| 228 | S $P(RXE5,CS,5)=$$ESCAPE^RORHL7($P(TMP,U,2)) | 
|---|
| 229 | S $P(RXE5,CS,6)="99PSU" | 
|---|
| 230 | ;--- Success | 
|---|
| 231 | Q 0 | 
|---|