| 1 | PSOHLSNC ;BIR/RTR - Send CHCS message to CPRS ;07/03/02 | 
|---|
| 2 | ;;7.0;OUTPATIENT PHARMACY;**111,157,143**;DEC 1997 | 
|---|
| 3 | ;External reference to ^PS(50.7 supported by DBIA 2223 | 
|---|
| 4 | ;External reference to ^PS(51.2 supported by DBIA 2226 | 
|---|
| 5 | ;External reference to ^PSDRUG( supported by DBIA 221 | 
|---|
| 6 | ;External reference to ^PS(50.607 supported by DBIA 2221 | 
|---|
| 7 | ;External reference to ^PS(50.606 supported by DBIA 2174 | 
|---|
| 8 | ;External reference to EN^PSSUTIL1 supported by DBIA 3179 | 
|---|
| 9 | ; | 
|---|
| 10 | ;PSOPND=Internal number from 52.41 | 
|---|
| 11 | ;PSOPNDST=Order Control Code Status | 
|---|
| 12 | ;PSOPNDPT=Pharmacy Status | 
|---|
| 13 | ; | 
|---|
| 14 | EN(PSOPND,PSOPNDST,PSOPNDPT) ; | 
|---|
| 15 | N MSG,PSOHLIP,PSOHLIPX,PSOHLIPC,PSOHLTTL,PSOHUTL,PSOHND,PSOHNDD,PSOHNDU,PSONFLD,PSOXFLD,PSOLIMIT,PSONJJ,PSOHJJ,PSOHCT,PSOSEGMT,PSOHENT,PSOHPRO,PSOHIM,PSOHPC,PSOHPCTX,PSOHRT,PSOHRTE,PSOHRTEN,PSOHRTX,Y,DA,DIQ,DR | 
|---|
| 16 | I $G(PSOPND)=""!($G(PSOPNDST)="") Q | 
|---|
| 17 | I '$D(^PS(52.41,+$G(PSOPND),0)) Q | 
|---|
| 18 | S PSONFLD="F PSONJJ=0:1:PSOLIMIT S PSOXFLD(PSONJJ)=""""" | 
|---|
| 19 | S PSOHCT=1 | 
|---|
| 20 | D INIT^PSOHLSN | 
|---|
| 21 | D PID,PV1,ORC,RXO,RXE,RXR,ZRX,DG1,ZCL | 
|---|
| 22 | D MSG^XQOR("PS EVSEND OR",.MSG) | 
|---|
| 23 | Q | 
|---|
| 24 | PID ;Build PID segment | 
|---|
| 25 | S PSOLIMIT=5 X PSONFLD | 
|---|
| 26 | ;What about this ICN number? | 
|---|
| 27 | S PSOXFLD(0)="PID" | 
|---|
| 28 | S PSOXFLD(3)=$P($G(^PS(52.41,PSOPND,0)),"^",2) | 
|---|
| 29 | D SEG | 
|---|
| 30 | Q | 
|---|
| 31 | PV1 ;Build PV1 segment | 
|---|
| 32 | S PSOLIMIT=19 X PSONFLD | 
|---|
| 33 | S PSOXFLD(0)="PV1" | 
|---|
| 34 | S PSOXFLD(2)="O" | 
|---|
| 35 | I $P($G(^PS(52.41,PSOPND,0)),"^",13) S PSOXFLD(3)=$P(^(0),"^",13) | 
|---|
| 36 | D SEG | 
|---|
| 37 | Q | 
|---|
| 38 | DG1 ;Build DG1 segment | 
|---|
| 39 | ;future use; chcs does not send ICD-9 codes. | 
|---|
| 40 | Q:'$D(^PS(52.41,PSOPND,"ICD")) | 
|---|
| 41 | S PSOLIMIT=4 X PSONFLD | 
|---|
| 42 | S PSOXFLD(0)="DG1" | 
|---|
| 43 | N LP,VDG,FLAG,DXDESC,DG | 
|---|
| 44 | S FLAG="",PSOXFLD(4)="",PSOXFLD(2)="" | 
|---|
| 45 | F LP=1:1:8 Q:'$D(^PS(52.41,PSOPND,"ICD",LP,0))  D | 
|---|
| 46 | . S VDG="",VDG=^PS(52.41,PSOPND,"ICD",LP,0) Q:$P(VDG,U,1)="" | 
|---|
| 47 | . S (DG,DXDESC)="" | 
|---|
| 48 | . S DXDESC=$$GET1^DIQ(80,$P(VDG,U,1)_",",10),PSOXFLD(1)=LP | 
|---|
| 49 | . S PSOXFLD(3)=$P(VDG,U,1)_U_DXDESC_U_"80"_U_$$GET1^DIQ(80,$P(VDG,U,1)_",",.01)_U_DXDESC_U_"ICD9" | 
|---|
| 50 | . D SEG | 
|---|
| 51 | Q | 
|---|
| 52 | ORC ;Build ORC segment | 
|---|
| 53 | S PSOLIMIT=15 X PSONFLD | 
|---|
| 54 | S PSOXFLD(0)="ORC" | 
|---|
| 55 | S PSOXFLD(1)=$G(PSOPNDST) | 
|---|
| 56 | S PSOXFLD(3)=PSOPND_"S^PS" | 
|---|
| 57 | S PSOXFLD(5)=$G(PSOPNDPT) | 
|---|
| 58 | S X=$P($G(^PS(52.41,PSOPND,0)),"^",6) I X S PSOXFLD(9)=$$FMTHL7^XLFDT(X) | 
|---|
| 59 | S PSOHENT=$P($G(^PS(52.41,PSOPND,0)),"^",4) I PSOHENT K ^UTILITY("DIQ1",$J) S DIC=200,DR=.01,DA=PSOHENT,DIQ(0)="E" D EN^DIQ1 S PSOXFLD(10)=PSOHENT_"^"_$P($G(^UTILITY("DIQ1",$J,200,PSOHENT,.01,"E")),"^") | 
|---|
| 60 | S PSOHPRO=$P($G(^PS(52.41,PSOPND,0)),"^",5) I PSOHPRO K ^UTILITY("DIQ1",$J) S DIC=200,DR=.01,DA=PSOHPRO,DIQ(0)="E" D EN^DIQ1 S PSOXFLD(12)=PSOHPRO_"^"_$P($G(^UTILITY("DIQ1",$J,200,PSOHPRO,.01,"E")),"^") | 
|---|
| 61 | K ^UTILITY("DIQ1",$J) | 
|---|
| 62 | S X=$P($G(^PS(52.41,PSOPND,0)),"^",12) I X S PSOXFLD(15)=$$FMTHL7^XLFDT(X) | 
|---|
| 63 | D SEG | 
|---|
| 64 | Q | 
|---|
| 65 | RXO ;Build RXO segment | 
|---|
| 66 | S PSOLIMIT=1 X PSONFLD | 
|---|
| 67 | S PSOXFLD(0)="RXO" | 
|---|
| 68 | S PSOHITM=$P($G(^PS(52.41,PSOPND,0)),"^",8) | 
|---|
| 69 | S PSOXFLD(1)=$S($G(PSOHITM):"^^^"_PSOHITM_"^"_$P($G(^PS(50.7,+$G(PSOHITM),0)),"^")_" "_$P($G(^PS(50.606,+$P($G(^(0)),"^",2),0)),"^")_"^99PSP",1:"^^^^^") | 
|---|
| 70 | D SEG | 
|---|
| 71 | Q | 
|---|
| 72 | RXE ;Build RXE segment | 
|---|
| 73 | K PSOXFLD S PSOLIMIT=26 X PSONFLD | 
|---|
| 74 | S PSOXFLD(0)="RXE" | 
|---|
| 75 | ;No Quantity Timing, since the Sig is entered as free text | 
|---|
| 76 | S PSOHNDD=$P($G(^PS(52.41,PSOPND,0)),"^",9) | 
|---|
| 77 | S PSOHND="" I PSOHNDD S PSOHND=$G(^PSDRUG(PSOHNDD,"ND")) | 
|---|
| 78 | S PSOXFLD(2)=$S($P(PSOHND,"^")&($P(PSOHND,"^",3)):$P(PSOHND,"^")_"."_$P(PSOHND,"^",3)_"^"_$P(PSOHND,"^",2)_"^"_"99NDF",1:"^^")_"^"_$G(PSOHNDD)_"^"_$S($G(PSOHNDD):$P($G(^PSDRUG(PSOHNDD,0)),"^"),1:"")_"^"_"99PSD" | 
|---|
| 79 | I $P(PSOHND,"^"),$P(PSOHND,"^",3) D | 
|---|
| 80 | .I $T(^PSNAPIS)]"" S PSOHNDU=$$DFSU^PSNAPIS($P(PSOHND,"^"),$P(PSOHND,"^",3)) S PSOXFLD(5)="^^^"_$P($G(PSOHNDU),"^",5)_"^"_$P($G(PSOHNDU),"^",6)_"^"_"99PSU" | 
|---|
| 81 | I $G(PSOHITM) S PSOXFLD(6)="^^^"_$P($G(^PS(50.7,$G(PSOHITM),0)),"^",2)_"^"_$P($G(^PS(50.606,+$P($G(^PS(50.7,$G(PSOHITM),0)),"^",2),0)),"^")_"^"_"99PSF" | 
|---|
| 82 | S PSOXFLD(10)=$P(^PS(52.41,PSOPND,0),"^",10) | 
|---|
| 83 | S PSOXFLD(12)=$P(^PS(52.41,PSOPND,0),"^",11) | 
|---|
| 84 | S PSOXFLD(22)=$P(^PS(52.41,PSOPND,0),"^",22) | 
|---|
| 85 | I $G(PSOHNDD) S PSOHUTL=$$EN^PSSUTIL1(PSOHNDD) S PSOXFLD(25)=$S($E($P(PSOHUTL,"|"),1)=".":"0",1:"")_$P(PSOHUTL,"|"),PSOXFLD(26)=$P(PSOHUTL,"|",2) | 
|---|
| 86 | ;Create RXE segment, can possibly go over 245 in length | 
|---|
| 87 | S PSOHCT=PSOHCT+1 | 
|---|
| 88 | S (PSOHLIPX,PSOHLIPC,PSOHLTTL)=0,PSOHLIP="" F  S PSOHLIP=$O(PSOXFLD(PSOHLIP)) Q:PSOHLIP=""  D | 
|---|
| 89 | .I PSOHLIP S PSOXFLD(PSOHLIP)="|"_PSOXFLD(PSOHLIP) | 
|---|
| 90 | .I PSOHLTTL+$L(PSOXFLD(PSOHLIP))<246 D  S PSOHLTTL=PSOHLTTL+$L(PSOXFLD(PSOHLIP)) Q | 
|---|
| 91 | ..I 'PSOHLIPX S MSG(PSOHCT)=$G(MSG(PSOHCT))_PSOXFLD(PSOHLIP) Q | 
|---|
| 92 | ..S MSG(PSOHCT,PSOHLIPX)=$G(MSG(PSOHCT,PSOHLIPX))_PSOXFLD(PSOHLIP) | 
|---|
| 93 | .S PSOHLICP=245-PSOHLTTL | 
|---|
| 94 | .I 'PSOHLIPX D  S PSOHLTTL=$L(MSG(PSOHCT,PSOHLIPX)) Q | 
|---|
| 95 | ..S MSG(PSOHCT)=$G(MSG(PSOHCT))_$E(PSOXFLD(PSOHLIP),1,PSOHLICP) | 
|---|
| 96 | ..S PSOHLIPX=1,MSG(PSOHCT,PSOHLIPX)=$E(PSOXFLD(PSOHLIP),(PSOHLICP+1),999) | 
|---|
| 97 | .S MSG(PSOHCT,PSOHLIPX)=$G(MSG(PSOHCT,PSOHLIPX))_$E(PSOXFLD(PSOHLIP),1,PSOHLICP) | 
|---|
| 98 | .S PSOHLIPX=PSOHLIPX+1,MSG(PSOHCT,PSOHLIPX)=$E(PSOXFLD(PSOHLIP),(PSOHLICP+1),999) | 
|---|
| 99 | .S PSOHLTTL=$L(MSG(PSOHCT,PSOHLIPX)) | 
|---|
| 100 | ;Set NTE segments | 
|---|
| 101 | S PSOHPCT=0,PSOHCT=PSOHCT+1 I $O(^PS(52.41,PSOPND,3,0)) F PSOHPC=0:0 S PSOHPC=$O(^PS(52.41,PSOPND,3,PSOHPC)) Q:'PSOHPC  D | 
|---|
| 102 | .I $G(^PS(52.41,PSOPND,3,PSOHPC,0))="" Q | 
|---|
| 103 | .I 'PSOHPCT S MSG(PSOHCT)="NTE|6||"_$G(^PS(52.41,PSOPND,3,PSOHPC,0)) S PSOHPCT=1 Q | 
|---|
| 104 | .S MSG(PSOHCT,PSOHPCT)=$G(^PS(52.41,PSOPND,3,PSOHPC,0)),PSOHPCT=PSOHPCT+1 | 
|---|
| 105 | I 'PSOHPCT S PSOHCT=PSOHCT-1 | 
|---|
| 106 | S PSOHCT=PSOHCT+1,PSOHPCT=0 I $O(^PS(52.41,PSOPND,"SIG",0)) F PSOHPC=0:0 S PSOHPC=$O(^PS(52.41,PSOPND,"SIG",PSOHPC)) Q:'PSOHPC  D | 
|---|
| 107 | .I $G(^PS(52.41,PSOPND,"SIG",PSOHPC,0))="" Q | 
|---|
| 108 | .I 'PSOHPCT S MSG(PSOHCT)="NTE|21||"_$G(^PS(52.41,PSOPND,"SIG",PSOHPC,0)) S PSOHPCT=1 Q | 
|---|
| 109 | .S MSG(PSOHCT,PSOHPCT)=$G(^PS(52.41,PSOPND,"SIG",PSOHPC,0)),PSOHPCT=PSOHPCT+1 | 
|---|
| 110 | I 'PSOHPCT S MSG(PSOHCT)="NTE|21||"_"No SIG available" | 
|---|
| 111 | Q | 
|---|
| 112 | RXR ;Build RXR segment | 
|---|
| 113 | S PSOHRTX="" F PSOHRT=0:0 S PSOHRT=$O(^PS(52.41,PSOPND,1,PSOHRT)) Q:'PSOHRT  D | 
|---|
| 114 | .S PSOHRTX=1 | 
|---|
| 115 | .S PSOLIMIT=1 X PSONFLD | 
|---|
| 116 | .S PSOXFLD(0)="RXR" | 
|---|
| 117 | .S PSOHRTEN="" | 
|---|
| 118 | .S PSOHRTE=$P($G(^PS(52.41,PSOPND,1,PSOHRT,1)),"^",8) I PSOHRTE,$D(^PS(51.2,PSOHRTE,0)) S PSOHRTEN=$P($G(^(0)),"^") | 
|---|
| 119 | .S PSOXFLD(1)="^^^"_$G(PSOHRTE)_"^"_$G(PSOHRTEN)_"^"_"99PSR" | 
|---|
| 120 | .D SEG | 
|---|
| 121 | I '$G(PSOHRTX) S PSOLIMIT=1 X PSONFLD S PSOXFLD(0)="RXR",PSOXFLD(1)="^^^^^99PSR" D SEG | 
|---|
| 122 | Q | 
|---|
| 123 | ZRX ;Build ZRX segment | 
|---|
| 124 | S PSOLIMIT=6 X PSONFLD | 
|---|
| 125 | S PSOXFLD(0)="ZRX" | 
|---|
| 126 | S PSOXFLD(3)="N" | 
|---|
| 127 | S PSOXFLD(4)=$P($G(^PS(52.41,PSOPND,0)),"^",17) | 
|---|
| 128 | D SEG | 
|---|
| 129 | Q | 
|---|
| 130 | ZCL ;Build ZCL segment | 
|---|
| 131 | N I,JJJ,INODE,EI | 
|---|
| 132 | S PSOXFLD(0)="ZCL",PSOLIMIT=3 X PSONFLD | 
|---|
| 133 | I $D(^PS(52.41,PSOPND,"ICD")) D | 
|---|
| 134 | .F I=1:1:8 D | 
|---|
| 135 | ..Q:'$D(^PS(52.41,PSOPND,"ICD",I,0)) | 
|---|
| 136 | ..S INODE="",INODE=^PS(52.41,PSOPND,"ICD",I,0) | 
|---|
| 137 | ..F JJJ=2:1:8 S EI=$P(INODE,U,JJJ) D | 
|---|
| 138 | ...S PSOXFLD(1)=I,PSOXFLD(2)=JJJ-1,PSOXFLD(3)=EI | 
|---|
| 139 | ...;I JJJ=4 S EI=$S(EI=1:"SC",EI=0:"NSC",1:"") S PSOXFLD(3)=EI | 
|---|
| 140 | ...D SEG | 
|---|
| 141 | E  D  ;if no ICD node, send one ZCL segment | 
|---|
| 142 | .S PSOXFLD(0)="ZCL",PSOXFLD(1)=1,PSOXFLD(2)=3 | 
|---|
| 143 | .S PSOXFLD(3)=$S($P(^PS(52.41,PSOPND,0),"^",16)="SC":1,$P(^(0),"^",16)="NSC":0,1:"") | 
|---|
| 144 | .D SEG | 
|---|
| 145 | .Q:'$D(^PS(52.41,PSOPND,"IBQ")) | 
|---|
| 146 | .S EI=^PS(52.41,PSOPND,"IBQ") | 
|---|
| 147 | .F I=2,3,4,1,5,6 S PSOXFLD(3)=$P(EI,U,I) D | 
|---|
| 148 | .. S PSOXFLD(2)=$S(I=2:1,I=3:2,I=4:4,I=1:5,I=5:6,I=6:7,1:"") D SEG | 
|---|
| 149 | Q | 
|---|
| 150 | ZSC ;Build ZSC segment | 
|---|
| 151 | S PSOLIMIT=6 X PSONFLD | 
|---|
| 152 | S PSOXFLD(0)="ZSC" | 
|---|
| 153 | S PSOXFLD(1)=$S($P(^PS(52.41,PSOPND,0),"^",16)="SC":1,$P(^(0),"^",16)="NSC":0,1:"") | 
|---|
| 154 | S PSOXFLD(2)=$P($G(^PS(52.41,PSOPND,"IBQ")),"^"),PSOXFLD(3)=$P($G(^("IBQ")),"^",2),PSOXFLD(4)=$P($G(^("IBQ")),"^",3),PSOXFLD(5)=$P($G(^("IBQ")),"^",4),PSOXFLD(6)=$P($G(^("IBQ")),"^",5),PSOXFLD(7)=$P($G(^("IBQ")),"^",6) | 
|---|
| 155 | D SEG | 
|---|
| 156 | Q | 
|---|
| 157 | SEG ; | 
|---|
| 158 | S PSOSEGMT="" F PSOHJJ=0:1:PSOLIMIT S PSOSEGMT=$S(PSOSEGMT="":PSOXFLD(PSOHJJ),1:PSOSEGMT_"|"_PSOXFLD(PSOHJJ)) | 
|---|
| 159 | S PSOHCT=PSOHCT+1,MSG(PSOHCT)=PSOSEGMT | 
|---|
| 160 | Q | 
|---|