1 | VEPEHL7 ;DAOU/DLF- Build HL7 message to send to off board pharmacy ;05/05/2005
|
---|
2 | ;;1.0t1;Electronic Health Record;****;MAY 2005
|
---|
3 | Q
|
---|
4 | EN(PSRXIEN,RCOUNT,RMSG) ;
|
---|
5 | N COUNT,DFN,J,LIMIT,NAME,NULLFLDS,PSDIEN,PSFLAG,PSND1,PSND2,PSND3,PRODUCT,UNIT,POIPTR,PSOHINST,PODOSE,PODOSENM,PSROUTE,RTNAME,SEGMENT,CCC,BBB,CSCOUNT,PPTR,MSG,PSOHSTRT,PSOHSTOP,PSOHISSD,PSORTLP,ZRXFLAG,RXE2FLAG,RXE2ONLY,PSODFN,EDUZ
|
---|
6 | N PSOCDDUZ,DA,FSIG,BSIG,PSHRX,PSHORX,PSNOOTX,ZPRE,PSOZSTAT,CCCX,PSOCPS
|
---|
7 | S COUNT=0,NULLFLDS="F JJ=0:1:LIMIT S FIELD(JJ)="""""
|
---|
8 | K ^UTILITY("DIQ1",$J),DIQ S DA=$P($$SITE^VASITE(),"^") I $G(DA) S DIC=4,DIQ(0)="I",DR="99" D EN^DIQ1 S PSOHINST=$G(^UTILITY("DIQ1",$J,4,DA,99,"I")) K ^UTILITY("DIQ1",$J),DA,DR,DIQ,DIC
|
---|
9 | S MSG(1)="MSH|^~\&|PHARMACY|"_$G(PSOHINST)_"|||||ORM"
|
---|
10 | S COUNT=1,(ZRXFLAG,RXE2FLAG,RXE2ONLY)=0
|
---|
11 | D PID,PV1,ORC
|
---|
12 | D RXO,RXE,RXR
|
---|
13 | NCM D SEND
|
---|
14 | K PSRXIEN Q
|
---|
15 | Q
|
---|
16 | PID S LIMIT=5 X NULLFLDS
|
---|
17 | S DFN=+$P(^PSRX(PSRXIEN,0),"^",2) D DEM^VADPT S NAME=$G(VADM(1)) K VADM
|
---|
18 | S FIELD(0)="PID"
|
---|
19 | S FIELD(3)=DFN
|
---|
20 | S FIELD(5)=NAME
|
---|
21 | D SEG Q
|
---|
22 | PV1 ;
|
---|
23 | S LIMIT=19 X NULLFLDS
|
---|
24 | S FIELD(0)="PV1"
|
---|
25 | S FIELD(2)="O"
|
---|
26 | S:$P(^PSRX(PSRXIEN,0),"^",5) FIELD(3)=$P(^(0),"^",5)
|
---|
27 | D SEG Q
|
---|
28 | ORC ;
|
---|
29 | S LIMIT=15 X NULLFLDS
|
---|
30 | S FIELD(0)="ORC"
|
---|
31 | S FIELD(1)="NW"
|
---|
32 | S FIELD(2)=$P($G(^PSRX(PSRXIEN,"OR1")),"^",2)
|
---|
33 | S:FIELD(2)'="" FIELD(2)=FIELD(2)_$S($G(PLACERXX):";"_PLACERXX,1:"")_"^OR"
|
---|
34 | S FIELD(3)=PSRXIEN_"^PS"
|
---|
35 | S FIELD(5)="CM"
|
---|
36 | S X=$P($G(^PSRX(PSRXIEN,2)),"^") I X S FIELD(9)=$$FMTHL7^XLFDT(X)
|
---|
37 | S EDUZ=$P($G(^PSRX(PSRXIEN,0)),"^",16) I EDUZ S FIELD(10)=EDUZ_"^"_$P($G(^VA(200,EDUZ,0)),"^")
|
---|
38 | S FIELD(12)=$P($G(^PSRX(PSRXIEN,0)),"^",4)_"^"_$P($G(^VA(200,+$P($G(^PSRX(PSRXIEN,0)),"^",4),0)),"^")
|
---|
39 | S PSOHISSD="",X=$P($G(^PSRX(PSRXIEN,0)),"^",13) I X S PSOHISSD=$$FMTHL7^XLFDT(X)
|
---|
40 | S FIELD(15)=$G(PSOHISSD) K X
|
---|
41 | D SEG
|
---|
42 | Q
|
---|
43 | RXO ;
|
---|
44 | S LIMIT=1 X NULLFLDS
|
---|
45 | S FIELD(0)="RXO"
|
---|
46 | S PPTR=+$P($G(^PSRX(PSRXIEN,"OR1")),"^")
|
---|
47 | S FIELD(1)=$S('PPTR:"^^^^^",1:"^^^"_PPTR_"^"_$P($G(^PS(50.7,PPTR,0)),"^")_" "_$P($G(^PS(50.606,+$P($G(^(0)),"^",2),0)),"^")_"^99PSP")
|
---|
48 | D SEG Q
|
---|
49 | ;
|
---|
50 | RXE ;
|
---|
51 | S RXE2FLAG=1
|
---|
52 | S LIMIT=26 X NULLFLDS
|
---|
53 | S FIELD(0)="RXE"
|
---|
54 | S (PSOHSTRT,PSOHSTOP)="" S X=$P($G(^PSRX(PSRXIEN,2)),"^",2) I X S PSOHSTRT=$$FMTHL7^XLFDT(X)
|
---|
55 | I '$G(DT) S DT=$$DT^XLFDT
|
---|
56 | S X=$S($P($G(^PSRX(PSRXIEN,3)),"^",5):$P($G(^(3)),"^",5),$G(STAT)="OD"!($G(STAT)="OC"):$G(DT),$P($G(^(2)),"^",6):$P($G(^(2)),"^",6),1:$G(DT)) I X S PSOHSTOP=$$FMTHL7^XLFDT(X)
|
---|
57 | K X N PSOMZT,MMZZ,MMZZT S MMZZT=1
|
---|
58 | F MMZZ=0:0 S MMZZ=$O(^PSRX(PSRXIEN,6,MMZZ)) Q:'MMZZ D:$D(^(MMZZ,0))
|
---|
59 | .S FIELD(1,MMZZT)=$S($P($G(^PSRX(PSRXIEN,6,MMZZ,0)),"^",2):$P($G(^(0)),"^")_"&"_$P($G(^PS(50.607,+$P($G(^(0)),"^",3),0)),"^")_"&"_$P($G(^PSRX(PSRXIEN,6,MMZZ,0)),"^",2)_"&"_$P($G(^(0)),"^",4),1:"")_"^"_$P($G(^(0)),"^",8)
|
---|
60 | .I $P($G(FIELD(1,MMZZT)),"^")'="" F PSOMZT=1,3 I $E($P(FIELD(1,MMZZT),"&",PSOMZT),1)="." S $P(FIELD(1,MMZZT),"&",PSOMZT)="0"_$P(FIELD(1,MMZZT),"&",PSOMZT)
|
---|
61 | .S FIELD(1,MMZZT)=$G(FIELD(1,MMZZT))_"^"_$$DUR(PSRXIEN,MMZZ)_"^^^^^"_$S($P($G(FIELD(1,MMZZT)),"^")'="":$P($G(FIELD(1,MMZZT)),"&")_$P($G(FIELD(1,MMZZT)),"&",2),1:$P($G(^PSRX(PSRXIEN,6,MMZZ,0)),"^"))
|
---|
62 | .S FIELD(1,MMZZT)=$G(FIELD(1,MMZZT))_"^"_$P($G(^PSRX(PSRXIEN,6,MMZZ,0)),"^",6)
|
---|
63 | .I $O(^PSRX(PSRXIEN,6,MMZZ)) S FIELD(1,MMZZT)=$G(FIELD(1,MMZZT))_"~"
|
---|
64 | .S MMZZT=MMZZT+1
|
---|
65 | S $P(FIELD(1,1),"^",4)=$G(PSOHSTRT),$P(FIELD(1,1),"^",5)=$G(PSOHSTOP)
|
---|
66 | S PSFLAG=0,PSDIEN=+$P(^PSRX(PSRXIEN,0),"^",6),PSND1=$P($G(^PSDRUG(PSDIEN,"ND")),"^"),PSND2=$P($G(^("ND")),"^",2),PSND3=$P($G(^("ND")),"^",3) I PSND1,PSND3 S PSFLAG=1
|
---|
67 | S FIELD(2)=$S(PSFLAG:PSND1_"."_PSND3_"^"_PSND2_"^"_"99NDF",1:"^^")_"^"_PSDIEN_"^"_$P($G(^PSDRUG(PSDIEN,0)),"^")_"^"_"99PSD"
|
---|
68 | Q:$G(RXE2ONLY)
|
---|
69 | I PSFLAG D
|
---|
70 | .I $T(^PSNAPIS)]"" S PSOXN=$$DFSU^PSNAPIS(PSND1,PSND3) S FIELD(5)="^^^"_$P($G(PSOXN),"^",5)_"^"_$P($G(PSOXN),"^",6)_"^"_"99PSU" K PSOXN Q
|
---|
71 | .S PRODUCT=$G(^PSNDF(PSND1,5,PSND3,0)) S UNIT=$P($G(^PSNDF(PSND1,2,+$P(PRODUCT,"^",2),3,+$P(PRODUCT,"^",3),4,+$P(PRODUCT,"^",4),0)),"^")
|
---|
72 | .S FIELD(5)="^^^"_UNIT_"^"_$P($G(^PS(50.607,+UNIT,0)),"^")_"^"_"99PSU"
|
---|
73 | S POIPTR=$P($G(^PSRX(PSRXIEN,"OR1")),"^") I POIPTR S PODOSE=$P($G(^PS(50.7,POIPTR,0)),"^",2),PODOSENM=$P($G(^PS(50.606,+PODOSE,0)),"^")
|
---|
74 | I POIPTR S FIELD(6)="^^^"_$G(PODOSE)_"^"_$G(PODOSENM)_"^"_"99PSF"
|
---|
75 | S FIELD(10)=$P(^PSRX(PSRXIEN,0),"^",7)
|
---|
76 | S FIELD(12)=$P(^PSRX(PSRXIEN,0),"^",9)
|
---|
77 | S FIELD(14)=$P(^PSRX(PSRXIEN,0),"^",4)
|
---|
78 | S FIELD(15)=$P(^PSRX(PSRXIEN,0),"^")
|
---|
79 | S FIELD(22)=$P(^PSRX(PSRXIEN,0),"^",8)
|
---|
80 | K MMZZ S MMZZ=$$EN^PSSUTIL1(PSDIEN) S FIELD(25)=$S($E($P(MMZZ,"|"),1)=".":"0",1:"")_$P(MMZZ,"|"),FIELD(26)=$P(MMZZ,"|",2)
|
---|
81 | N PLIM,PVAR,PVAR1,SUBCOUNT D SEGPARX^PSOHLSN
|
---|
82 | ;
|
---|
83 | I $O(^PSRX(PSRXIEN,"PRC",0)) D
|
---|
84 | .S COUNT=COUNT+1,CCC=$O(^PSRX(PSRXIEN,"PRC",0))
|
---|
85 | .S MSG(COUNT)="NTE|6||"_$G(^PSRX(PSRXIEN,"PRC",CCC,0))
|
---|
86 | .S CSCOUNT=1 F CCC=CCC:0 S CCC=$O(^PSRX(PSRXIEN,"PRC",CCC)) Q:'CCC S MSG(COUNT,CSCOUNT)=$G(^PSRX(PSRXIEN,"PRC",CCC,0)),CSCOUNT=CSCOUNT+1
|
---|
87 | I $O(^PSRX(PSRXIEN,"INS1",0)) D
|
---|
88 | .S COUNT=COUNT+1,CCC=$O(^PSRX(PSRXIEN,"INS1",0))
|
---|
89 | .S MSG(COUNT)="NTE|7|L|"_$G(^PSRX(PSRXIEN,"INS1",CCC,0))
|
---|
90 | .S CCCX=1 F CCC=CCC:0 S CCC=$O(^PSRX(PSRXIEN,"INS1",CCC,0)) Q:'CCC I $D(^(0)) S MSG(COUNT,CCCX)=$G(^(0)) S CCCX=CCCX+1
|
---|
91 | S COUNT=COUNT+1
|
---|
92 | I $P($G(^PSRX(PSRXIEN,"SIG")),"^",2) D Q
|
---|
93 | .D FSIG^PSOUTLA("R",PSRXIEN,238) S MSG(COUNT)="NTE|21||"_$S($G(FSIG(1))'="":$G(FSIG(1)),1:"No SIG available") I $O(FSIG(1)) F CCC=1:0 S CCC=$O(FSIG(CCC)) Q:'CCC S MSG(COUNT,(CCC-1))=$G(FSIG(CCC))
|
---|
94 | I '$P($G(^PSRX(PSRXIEN,"SIG")),"^",2) D Q
|
---|
95 | .D EN3^PSOUTLA1(PSRXIEN,238) S MSG(COUNT)="NTE|21||"_$S($G(BSIG(1))'="":$G(BSIG(1)),1:"No SIG available") I $O(BSIG(1)) F CCC=1:0 S CCC=$O(BSIG(CCC)) Q:'CCC S MSG(COUNT,(CCC-1))=$G(BSIG(CCC))
|
---|
96 | Q
|
---|
97 | ;
|
---|
98 | RXR ;
|
---|
99 | F PSORTLP=0:0 S PSORTLP=$O(^PSRX(PSRXIEN,6,PSORTLP)) Q:'PSORTLP D
|
---|
100 | .S LIMIT=1 X NULLFLDS
|
---|
101 | .S FIELD(0)="RXR"
|
---|
102 | .S PSROUTE=$P($G(^PSRX(PSRXIEN,6,PSORTLP,0)),"^",7) I PSROUTE,$D(^PS(51.2,PSROUTE,0)) S RTNAME=$P(^PS(51.2,PSROUTE,0),"^")
|
---|
103 | .S FIELD(1)="^^^"_$G(PSROUTE)_"^"_$G(RTNAME)_"^"_"99PSR"
|
---|
104 | .D SEG
|
---|
105 | Q
|
---|
106 | SEG S SEGMENT="" F J=0:1:LIMIT S SEGMENT=$S(SEGMENT="":FIELD(J),1:SEGMENT_"|"_FIELD(J))
|
---|
107 | S COUNT=COUNT+1,MSG(COUNT)=SEGMENT
|
---|
108 | Q
|
---|
109 | SEND S RCOUNT=COUNT
|
---|
110 | M RMSG=MSG
|
---|
111 | Q
|
---|
112 | DUR(PSODX1,PSODX2) ;
|
---|
113 | N PSODX,PSODX4,PSODX5,PSODX6,PSODX7 S PSODX=$P($G(^PSRX(PSODX1,6,PSODX2,0)),"^",5)
|
---|
114 | I 'PSODX Q PSODX
|
---|
115 | S PSODX4=$L(PSODX),PSODX5=$E(PSODX,PSODX4)
|
---|
116 | S PSODX=$S(PSODX5?1A:PSODX,1:PSODX_"D")
|
---|
117 | S PSODX6=$L(PSODX)
|
---|
118 | S PSODX7=$E(PSODX,PSODX6)_$E(PSODX,1,(PSODX6-1))
|
---|
119 | Q PSODX7
|
---|
120 |
|
---|