| 1 | PSOHLSG2 ;BIR/LC-Build HL7 Segments ;03/01/96 09:45 | 
|---|
| 2 | ;;7.0;OUTPATIENT PHARMACY;**30,139,162,172**;DEC 1997 | 
|---|
| 3 | ;External reference to DIWP supported by DBIA 10011 | 
|---|
| 4 | ;External reference to HLFNC supported by DBIA 10106 | 
|---|
| 5 | ;External reference to ^PS(51 supported by DBIA 2224 | 
|---|
| 6 | ;External reference to ^PS(55 supported by DBIA 2228 | 
|---|
| 7 | ;External reference to ^PSDRUG supported by DBIA 221 | 
|---|
| 8 | ;External reference to ^PS(54 supported by DBIA 2227 | 
|---|
| 9 | ;External reference to EN1^GMRAOR2 supported by DBIA 2422 | 
|---|
| 10 | ;External reference to ^DPT supported by DBIA 3097 | 
|---|
| 11 | ;External reference to EN1^GMRADPT supported by DBIA 10099 | 
|---|
| 12 | ;Cont'd build HL7 segments | 
|---|
| 13 | ; | 
|---|
| 14 | ZAL(PSI) ;allergy list segment | 
|---|
| 15 | Q:'$D(DFN) | 
|---|
| 16 | N ZAL,IDX,SEV,DAT,X | 
|---|
| 17 | S CNT=0,GMRA="0^0^111" D EN1^GMRADPT | 
|---|
| 18 | I $G(GMRAL)="" G ZALQT | 
|---|
| 19 | F AIEN=0:0 S AIEN=$O(GMRAL(AIEN)) Q:'AIEN  D | 
|---|
| 20 | .K ADTL D EN1^GMRAOR2(AIEN,"ADTL") S CNT=CNT+1 | 
|---|
| 21 | .S ZAL="ZAL"_FS_AIEN_FS_$P(GMRAL(AIEN),"^",2)_FS_$P($P(GMRAL(AIEN),"^",6),";") | 
|---|
| 22 | .S ZAL=ZAL_FS_$S($P(GMRAL(AIEN),"^",3)="D":"DRUG",$P(GMRAL(AIEN),"^",3)="F":"FOOD",$P(GMRAL(AIEN),"^",3)="O":"OTHER",1:"""""") | 
|---|
| 23 | .S ZAL=ZAL_FS_$S($P(GMRAL(AIEN),"^",4)=1:"VERIFIED",1:"NON-VERIFIED") | 
|---|
| 24 | .S IDX=$O(ADTL("O","")),X="" S:IDX'="" X=$G(ADTL("O",IDX)) | 
|---|
| 25 | .S DAT=$P(X,"^"),DAT=$S(DAT'="":$$HLDATE^HLFNC(DAT,"DT"),1:"") | 
|---|
| 26 | .S SEV=$P(X,"^",2) S:SEV="" SEV="""""",DAT="" | 
|---|
| 27 | .S $P(ZAL,FS,7,8)=SEV_FS_DAT,^TMP("PSO",$J,PSI)=ZAL,PSI=PSI+1 | 
|---|
| 28 | .F  S IDX=$O(ADTL("O",IDX)) Q:IDX=""  D | 
|---|
| 29 | ..S X=$G(ADTL("O",IDX)),DAT=$P(X,"^"),SEV=$P(X,"^",2) I SEV="" Q | 
|---|
| 30 | ..S DAT=$S(DAT'="":$$HLDATE^HLFNC(DAT,"DT"),1:"") | 
|---|
| 31 | ..S $P(ZAL,FS,7,8)=SEV_FS_DAT,^TMP("PSO",$J,PSI)=ZAL,PSI=PSI+1 | 
|---|
| 32 | ; | 
|---|
| 33 | ZALQT K GMRAL,ADTL,AIEN,CNT,CNT,GMRA | 
|---|
| 34 | Q | 
|---|
| 35 | ; | 
|---|
| 36 | ZML(PSI) ;multi-Rx label segment | 
|---|
| 37 | Q:'$D(DFN) | 
|---|
| 38 | N ZML S CNT1=0 | 
|---|
| 39 | I '$D(PSSPND),$P(PSOPAR,"^",18) D | 
|---|
| 40 | .F PSRX=0:0 S PSRX=$O(^PS(55,DFN,"P",PSRX)) Q:'PSRX  D | 
|---|
| 41 | ..S PSRXX=+^PS(55,DFN,"P",PSRX,0) I $D(^PSRX(PSRXX,0)) S PSRFL=$P(^(0),"^",9) D:$D(^(1))&PSRFL | 
|---|
| 42 | ...F AMC=0:0 S AMC=$O(^PSRX(PSRXX,1,AMC)) Q:'AMC  S PSRFL=PSRFL-1 | 
|---|
| 43 | ...I $G(PSRFL)>0 S X1=DT,X2=$P(^PSRX(PSRXX,0),"^",8)-10 D C^%DTC I X'<$P(^(2),"^",6) S PSRFL=0 | 
|---|
| 44 | ..I $G(PSRFL)>0,$P($G(^PSRX(PSRXX,"STA")),"^")<10,$P(^(2),"^",6)>DT S RX(PSRXX)=$P(^(2),"^",6)_"^"_PSRFL Q | 
|---|
| 45 | .S PSA=0 F J=1:1 S PSA=$O(RX(PSA)) Q:'PSA  D | 
|---|
| 46 | ..S DRG=$$ZZ^PSOSUTL(PSA),CNT1=CNT1+1 K ZDRUG | 
|---|
| 47 | ..S REFILLS=$P(RX(PSA),"^",2),EXPDATE=$P(RX(PSA),"^"),EXPDATE=$$HLDATE^HLFNC(EXPDATE,"DT") | 
|---|
| 48 | ..S RXNUM=$P(^PSRX(PSA,0),"^") | 
|---|
| 49 | ..I $G(PSOBARS),$P($G(PSOPAR),"^",19) S BARCODE=PSOINST_"-"_PSA | 
|---|
| 50 | ..S ZML="ZML"_FS_DRG_FS_REFILLS_FS_EXPDATE_FS_RXNUM_FS_$S($G(BARCODE):BARCODE,1:"""""") | 
|---|
| 51 | ..S ^TMP("PSO",$J,PSI)=ZML | 
|---|
| 52 | ..S PSI=PSI+1 | 
|---|
| 53 | K PSRX,PSRXX,PSRFL,AMC,J,X,X1,X2,RX,PSA,DRG,CNT1,REFILLS,EXPDATE,RXNUM,BARCODE | 
|---|
| 54 | Q | 
|---|
| 55 | ; | 
|---|
| 56 | ZSL(PSI) ;build Suspense Notice segment | 
|---|
| 57 | Q:'$D(DFN) | 
|---|
| 58 | N ZSL | 
|---|
| 59 | S (PSSUFLG,PSSPCNT)=0 S PSODFN=DFN,(SPPL,RXX,STA)="" | 
|---|
| 60 | I $G(PSODTCUT)']"" S X1=DT,X2=-120 D C^%DTC S PSODTCUT=X | 
|---|
| 61 | D ^PSOBUILD S (STA,RXX)="" F  S STA=$O(PSOSD(STA)) Q:STA=""  F  S RXX=$O(PSOSD(STA,RXX)) Q:RXX=""  I $P(PSOSD(STA,RXX),"^",2)=5 S SPPL=$P(PSOSD(STA,RXX),"^")_","_SPPL | 
|---|
| 62 | F XX=1:1 Q:$P(SPPL,",",XX)=""  S PSSSRX=$P(SPPL,",",XX) D | 
|---|
| 63 | .S SPNUM=$O(^PS(52.5,"B",PSSSRX,0)) I SPNUM S SPDATE=$P($G(^PS(52.5,SPNUM,0)),"^",2) S SPDATE=$$HLDATE^HLFNC(SPDATE,"DT") | 
|---|
| 64 | .S $P(PSOLGTH," ",(20-($L($P(^PSRX(PSSSRX,0),"^")))))="" | 
|---|
| 65 | .S ZSL="ZSL"_FS_$$ZZ^PSOSUTL(PSSSRX)_FS_$G(SPDATE)_FS_$P(^PSRX(PSSSRX,0),"^") | 
|---|
| 66 | .S ^TMP("PSO",$J,PSI)=ZSL | 
|---|
| 67 | .S PSI=PSI+1 | 
|---|
| 68 | K SPNUM,SPDATE,PSSUFLG,PSSPCNT,SPPL,RXX,STA,X1,X2,XX,X,PSOSD,PSSSRX,PSOLGTH,PSODTCUT | 
|---|
| 69 | Q | 
|---|
| 70 | ; | 
|---|
| 71 | NTE1(PSI) ;build NTE segment for SIG | 
|---|
| 72 | ; | 
|---|
| 73 | Q:'$D(DFN) | 
|---|
| 74 | N NTE1 | 
|---|
| 75 | S SIG=$P($G(^PSRX(IRXN,"SIG")),"^") I $P($G(^PSRX(IRXN,"SIG")),"^",2) D PSOLBL3,SIGOLD | 
|---|
| 76 | I '$P($G(^PSRX(IRXN,"SIG")),"^",2) D SIG | 
|---|
| 77 | S NTE1="NTE"_FS_1_FS_FS,FLD3="" F DR=1:1 Q:$G(SGY(DR))=""  S FLD3=FLD3_SGY(DR) | 
|---|
| 78 | S ^TMP("PSO",$J,PSI)=NTE1_FLD3 | 
|---|
| 79 | S PSI=PSI+1 | 
|---|
| 80 | K SIG,E,F,S,FLD3,X,Y,SGY,SGC,Z,DR,%,J,P | 
|---|
| 81 | Q | 
|---|
| 82 | ; | 
|---|
| 83 | SIG S SGY="" F P=1:1:$L(SIG," ") S X=$P(SIG," ",P) D:X]"" | 
|---|
| 84 | .I $D(^PS(51,"A",X)) S %=^(X),X=$P(%,"^") I $P(%,"^",2)]"" S Y=$P(SIG," ",P-1),Y=$E(Y,$L(Y)) S:Y>1 X=$P(%,"^",2) | 
|---|
| 85 | .S SGY=SGY_X_" " | 
|---|
| 86 | S X="",SGC=1 F J=1:1 S Z=$P(SGY," ",J) S:Z="" SGY(SGC)=X Q:Z=""  S:$L(X)+$L(Z)'<$S($P(PSOPAR,"^",28):46,1:34) SGY(SGC)=X,SGC=SGC+1,X="" S X=X_Z_" " | 
|---|
| 87 | SIGOLD I '$P(PSOPAR,"^",28) I $P($G(^DPT(DFN,"NHC")),"^")="Y"!($P($G(^PS(55,DFN,40)),"^")) S SGC=SGC+1,SGY(SGC)="Expiration:________ Mfg:_________" | 
|---|
| 88 | I $P(PSOPAR,"^",28) K SIG,E,F,S | 
|---|
| 89 | Q | 
|---|
| 90 | ; | 
|---|
| 91 | PSOLBL3 ;RX must be defined (Internal), Check already done for OERR SIG | 
|---|
| 92 | ;Format OERR Sig for New and Old label stock | 
|---|
| 93 | N CTCT,FFFF,LLIM,LLLL,LVAR,LVAR1,PPP,PPPP,SGCT,SIG9,ZZZZ,PSLONG,PPPP | 
|---|
| 94 | S PSLONG=$S($P(PSOPAR,"^",28):46,1:34),RX=IRXN | 
|---|
| 95 | ; NEXT LINE IF SIG IS MOVED BACK TO MULTIPLE | 
|---|
| 96 | S PPPP=1 F PPP=0:0 S PPP=$O(^PSRX(RX,"SIG1",PPP)) Q:'PPP  I $G(^PSRX(RX,"SIG1",PPP,0))'="" S SIG9(PPPP)=^(0) S PPPP=PPPP+1 | 
|---|
| 97 | ;NEXT LINE IF 1ST FRONT DOOR SIG LINE LIVES IN BACK DOOR SPOT | 
|---|
| 98 | ;S SIG9(1)=$P($G(^PSRX(RX,"SIG")),"^") S PPP=2 F PPPP=0:0 S PPPP=$O(^PSRX(RX,"SIG1",PPPP)) Q:'PPPP  I $G(^(PPPP,0))'="" S SIG9(PPP)=$G(^(0)),PPP=PPP+1 | 
|---|
| 99 | S (LVAR,LVAR1)="",LLLL=1 | 
|---|
| 100 | F FFFF=0:0 S FFFF=$O(SIG9(FFFF)) Q:'FFFF  S SGCT=0 F ZZZZ=1:1:$L(SIG9(FFFF)) I $E(SIG9(FFFF),ZZZZ)=" "!($L(SIG9(FFFF))=ZZZZ) S SGCT=SGCT+1 D  I $L(LVAR)>PSLONG S SGY(LLLL)=LLIM_" ",LLLL=LLLL+1,LVAR=LVAR1 | 
|---|
| 101 | .S LVAR1=$P(SIG9(FFFF)," ",(SGCT)) | 
|---|
| 102 | .S LLIM=LVAR | 
|---|
| 103 | .S LVAR=$S(LVAR="":LVAR1,1:LVAR_" "_LVAR1) | 
|---|
| 104 | I $G(LVAR)'="" S SGY(LLLL)=LVAR | 
|---|
| 105 | I '$P(PSOPAR,"^",28) S SGC=0 F CTCT=0:0 S CTCT=$O(SGY(CTCT)) Q:'CTCT  S SGC=SGC+1 | 
|---|
| 106 | Q | 
|---|
| 107 | NTE2(PSI) ;build NTE segment for patient narrative | 
|---|
| 108 | Q:'$D(DFN) | 
|---|
| 109 | N NTE2 | 
|---|
| 110 | K ^UTILITY($J,"W") S (DIWL,PSNACNT)=1,DIWR=45,DIWF="",(PSSIXFL,PSSEVFL)=0 F ZZ=0:0 S ZZ=$O(^PS(59,PSOSITE,6,ZZ)) Q:'ZZ  I $D(^(ZZ,0)) S X=^(0) D ^DIWP | 
|---|
| 111 | S NTE2="NTE"_FS_2_FS_FS,^TMP("PSO",$J,PSI)=NTE2 | 
|---|
| 112 | F LLL=0:0 S LLL=$O(^UTILITY($J,"W",DIWL,LLL)) Q:'LLL  S ^TMP("PSO",$J,PSI,PSNACNT)=^UTILITY($J,"W",DIWL,LLL,0) S PSNACNT=PSNACNT+1,PSSIXFL=1 | 
|---|
| 113 | I PSSIXFL S ^TMP("PSO",$J,PSI,PSNACNT)=" " S PSNACNT=PSNACNT+1 | 
|---|
| 114 | S DIWL=1,DIWR=45,DIWF="" K ^UTILITY($J,"W") F ZZ=0:0 S ZZ=$O(^PS(59,PSOSITE,7,ZZ)) Q:'ZZ  I $D(^(ZZ,0)) S X=^(0) D ^DIWP | 
|---|
| 115 | F LLL=0:0 S LLL=$O(^UTILITY($J,"W",DIWL,LLL)) Q:'LLL  S ^TMP("PSO",$J,PSI,PSNACNT)=^UTILITY($J,"W",DIWL,LLL,0) S PSNACNT=PSNACNT+1,PSSEVFL=1 | 
|---|
| 116 | I PSSEVFL S ^TMP("PSO",$J,PSI,PSNACNT)=" " S PSNACNT=PSNACNT+1 | 
|---|
| 117 | S DIWL=1,DIWR=45,DIWF="" K ^UTILITY($J,"W") F ZZ=0:0 S ZZ=$O(^PS(59,PSOSITE,4,ZZ)) Q:'ZZ  I $D(^(ZZ,0)) S X=^(0) D ^DIWP | 
|---|
| 118 | F LLL=0:0 S LLL=$O(^UTILITY($J,"W",DIWL,LLL)) Q:'LLL  S ^TMP("PSO",$J,PSI,PSNACNT)=^UTILITY($J,"W",DIWL,LLL,0) S PSNACNT=PSNACNT+1 | 
|---|
| 119 | F LLL=1:1:PSNACNT-1 I $L(^TMP("PSO",$J,PSI,LLL))=0 S ^TMP("PSO",$J,PSI,LLL)=" " | 
|---|
| 120 | S:$D(NTE2) PSI=PSI+1 | 
|---|
| 121 | K DIWF,DIWL,DIWR,LLL,PSNACNT,PSSEVFL,PSSIXFL,ZZ | 
|---|
| 122 | Q | 
|---|
| 123 | NTE3(PSI) ;build NTE segment for drug warning narrative | 
|---|
| 124 | Q:'$D(DFN) | 
|---|
| 125 | N NTE3 | 
|---|
| 126 | S WARN=$P($G(^PSDRUG(IDGN,0)),"^",8) | 
|---|
| 127 | S:$D(WARN) NTE3="NTE"_FS_3_FS_FS,^TMP("PSO",$J,PSI)=NTE3,CNT=1 | 
|---|
| 128 | F WWW=1:1 Q:$P(WARN,",",WWW,99)=""  S PSOWARN=$P(WARN,",",WWW) D:$D(^PS(54,PSOWARN,0)) | 
|---|
| 129 | . S JJJ=0 | 
|---|
| 130 | . F  S JJJ=$O(^PS(54,PSOWARN,1,JJJ)) Q:'JJJ  D | 
|---|
| 131 | . . I $D(^PS(54,PSOWARN,1,JJJ,0))  S ^TMP("PSO",$J,PSI,CNT)=^PS(54,PSOWARN,1,JJJ,0),CNT=CNT+1 | 
|---|
| 132 | . . Q | 
|---|
| 133 | . Q | 
|---|
| 134 | S:$D(NTE3) PSI=PSI+1 | 
|---|
| 135 | K WARN,CNT,WW,JJJ,PSOWARN,RX,WWW | 
|---|
| 136 | Q | 
|---|
| 137 | ; | 
|---|
| 138 | NTE4(PSI) ;build NTE segment for profile information | 
|---|
| 139 | Q:'$D(DFN)  S PSODFN=DFN | 
|---|
| 140 | N NTE4 | 
|---|
| 141 | I $P(PSOPAR,"^",8) D START^PSOHLSG3 | 
|---|
| 142 | S:$D(NTE4) PSI=PSI+1 | 
|---|
| 143 | Q | 
|---|
| 144 | NTE5(PSI) ;build NTE segment for drug interactions | 
|---|
| 145 | Q:'$D(DFN) | 
|---|
| 146 | N NTE5 | 
|---|
| 147 | D:$D(DRI) START2^PSOHLSG3 | 
|---|
| 148 | S:$D(NTE5) ^TMP("PSO",$J,PSI)=NTE5 | 
|---|
| 149 | S:'$D(NTE5) ^TMP("PSO",$J,PSI)="NTE"_FS_5_FS_FS | 
|---|
| 150 | S PSI=PSI+1 | 
|---|
| 151 | Q | 
|---|
| 152 | NTE6(PSI) ;build NTE segment for drug allergy indications | 
|---|
| 153 | Q:'$D(DFN) | 
|---|
| 154 | N NTE6 | 
|---|
| 155 | D:$D(DAW) START3^PSOHLSG3 | 
|---|
| 156 | S ^TMP("PSO",$J,PSI)=NTE6 | 
|---|
| 157 | S PSI=PSI+1 | 
|---|
| 158 | Q | 
|---|