Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSOHLSNC

PSOHLSNC.m

Go to the documentation of this file.
  1. PSOHLSNC ;BIR/RTR - Send CHCS message to CPRS ;07/03/02
  1. ;;7.0;OUTPATIENT PHARMACY;**111,157,143,225,404,755,771**;DEC 1997;Build 8
  1. ;External reference to ^PS(50.7 supported by DBIA 2223
  1. ;External reference to ^PS(51.2 supported by DBIA 2226
  1. ;External reference to ^PSDRUG( supported by DBIA 221
  1. ;External reference to ^PS(50.607 supported by DBIA 2221
  1. ;External reference to ^PS(50.606 supported by DBIA 2174
  1. ;External reference to EN^PSSUTIL1 supported by DBIA 3179
  1. ;External reference to ^ICDCODE sup DBIA 3990
  1. ;
  1. ;PSOPND=Internal number from 52.41
  1. ;PSOPNDST=Order Control Code Status
  1. ;PSOPNDPT=Pharmacy Status
  1. ;
  1. EN(PSOPND,PSOPNDST,PSOPNDPT) ;
  1. N MSG,PSOHLIP,PSOHLIPX,PSOHLIPC,PSOHLTTL,PSOHUTL,PSOHND,PSOHNDD,PSOHNDU,PSONFLD,PSOXFLD,PSOLIMIT,PSONJJ,PSOHJJ,PSOHCT
  1. N PSOSEGMT,PSOHENT,PSOHPRO,PSOHIM,PSOHPC,PSOHPCTX,PSOHRT,PSOHRTE,PSOHRTEN,PSOHRTX,Y,DA,DIQ,DR,PSOWRDT,PSOHITM,PSOHLICP,PSOHPCT
  1. I $G(PSOPND)=""!($G(PSOPNDST)="") Q
  1. I '$D(^PS(52.41,+$G(PSOPND),0)) Q
  1. S PSONFLD="F PSONJJ=0:1:PSOLIMIT S PSOXFLD(PSONJJ)="""""
  1. S PSOHCT=1
  1. D INIT^PSOHLSN
  1. D PID,PV1,ORC,RXO,RXE,RXR,ZRX,DG1,ZCL
  1. D MSG^XQOR("PS EVSEND OR",.MSG)
  1. Q
  1. PID ;Build PID segment
  1. S PSOLIMIT=5 X PSONFLD
  1. ;What about this ICN number?
  1. S PSOXFLD(0)="PID"
  1. S PSOXFLD(3)=$P($G(^PS(52.41,PSOPND,0)),"^",2)
  1. D SEG
  1. Q
  1. PV1 ;Build PV1 segment
  1. S PSOLIMIT=19 X PSONFLD
  1. S PSOXFLD(0)="PV1"
  1. S PSOXFLD(2)="O"
  1. I $P($G(^PS(52.41,PSOPND,0)),"^",13) S PSOXFLD(3)=$P(^(0),"^",13)
  1. D SEG
  1. Q
  1. DG1 ;Build DG1 segment
  1. ;future use; chcs does not send ICD-9 codes.
  1. Q:'$D(^PS(52.41,PSOPND,"ICD"))
  1. S PSOLIMIT=4 X PSONFLD
  1. S PSOXFLD(0)="DG1"
  1. N LP,VDG,FLAG,DXDESC,DG
  1. S FLAG="",PSOXFLD(4)="",PSOXFLD(2)=""
  1. F LP=1:1:8 Q:'$D(^PS(52.41,PSOPND,"ICD",LP,0)) D
  1. . S VDG="",VDG=^PS(52.41,PSOPND,"ICD",LP,0) Q:$P(VDG,U,1)=""
  1. . S (DG,DXDESC)=""
  1. . N PSOARRY,PSOICDD,PSOICDDX ;*404
  1. . S PSOICDDX=$$ICDDX^ICDCODE($P(VDG,U,1)) ;*404
  1. . S PSOICDD=$$ICDD^ICDCODE($P(PSOICDDX,U,2),"PSOARRY"),PSOXFLD(1)=LP ;*404
  1. . S DXDESC=PSOARRY(1) ;*404
  1. . S PSOXFLD(3)=$P(VDG,U,1)_U_DXDESC_U_"80"_U_$P(PSOICDDX,U,2)_U_DXDESC_U_"ICD9" ;*404
  1. . D SEG
  1. Q
  1. ORC ;Build ORC segment
  1. N X
  1. S PSOLIMIT=15 X PSONFLD
  1. S PSOXFLD(0)="ORC"
  1. S PSOXFLD(1)=$G(PSOPNDST)
  1. S PSOXFLD(3)=PSOPND_"S^PS"
  1. S PSOXFLD(5)=$G(PSOPNDPT)
  1. S X=$P($G(^PS(52.41,PSOPND,0)),"^",6) I X S PSOXFLD(9)=$$FMTHL7^XLFDT(X)
  1. 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")),"^")
  1. 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")),"^")
  1. K ^UTILITY("DIQ1",$J),DIQ,DIC,DA,DR
  1. S X=$P($G(^PS(52.41,PSOPND,0)),"^",12) I X S PSOXFLD(15)=$$FMTHL7^XLFDT(X)
  1. D SEG
  1. Q
  1. RXO ;Build RXO segment
  1. S PSOLIMIT=1 X PSONFLD
  1. S PSOXFLD(0)="RXO"
  1. S PSOHITM=$P($G(^PS(52.41,PSOPND,0)),"^",8)
  1. 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:"^^^^^")
  1. D SEG
  1. Q
  1. RXE ;Build RXE segment
  1. K PSOXFLD S PSOLIMIT=26 X PSONFLD
  1. S PSOXFLD(0)="RXE"
  1. ;No Quantity Timing, since the Sig is entered as free text
  1. S PSOHNDD=$P($G(^PS(52.41,PSOPND,0)),"^",9)
  1. S PSOHND="" I PSOHNDD S PSOHND=$G(^PSDRUG(PSOHNDD,"ND"))
  1. 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"
  1. I $P(PSOHND,"^"),$P(PSOHND,"^",3) D
  1. .I $T(^PSNAPIS)]"" S PSOHNDU=$$DFSU^PSNAPIS($P(PSOHND,"^"),$P(PSOHND,"^",3)) S PSOXFLD(5)="^^^"_$P($G(PSOHNDU),"^",5)_"^"_$P($G(PSOHNDU),"^",6)_"^"_"99PSU"
  1. 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"
  1. S PSOXFLD(10)=$P(^PS(52.41,PSOPND,0),"^",10)
  1. S PSOXFLD(12)=$P(^PS(52.41,PSOPND,0),"^",11)
  1. I $$GET1^DIQ(52.49,PSOIEN,95.1,"I"),$$CS^PSOERXA0(PSOHNDD) D ;P755 Check if CS and send DEA# ; P771-Get DEA from File #52.48 matched to NEW DEA #'S (#53.21) field in NEW PERSON (#200)
  1. . N PSOERXPRV S PSOERXPRV=$$GET1^DIQ(52.49,PSOIEN,2.1,"I") I PSOERXPRV S PSOXFLD(13)=$$GET1^DIQ(52.48,+PSOERXPRV,1.6)
  1. S PSOXFLD(22)=$P(^PS(52.41,PSOPND,0),"^",22)
  1. 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)
  1. ;Create RXE segment, can possibly go over 245 in length
  1. S PSOHCT=PSOHCT+1
  1. S (PSOHLIPX,PSOHLIPC,PSOHLTTL)=0,PSOHLIP="" F S PSOHLIP=$O(PSOXFLD(PSOHLIP)) Q:PSOHLIP="" D
  1. .I PSOHLIP S PSOXFLD(PSOHLIP)="|"_PSOXFLD(PSOHLIP)
  1. .I PSOHLTTL+$L(PSOXFLD(PSOHLIP))<246 D S PSOHLTTL=PSOHLTTL+$L(PSOXFLD(PSOHLIP)) Q
  1. ..I 'PSOHLIPX S MSG(PSOHCT)=$G(MSG(PSOHCT))_PSOXFLD(PSOHLIP) Q
  1. ..S MSG(PSOHCT,PSOHLIPX)=$G(MSG(PSOHCT,PSOHLIPX))_PSOXFLD(PSOHLIP)
  1. .S PSOHLICP=245-PSOHLTTL
  1. .I 'PSOHLIPX D S PSOHLTTL=$L(MSG(PSOHCT,PSOHLIPX)) Q
  1. ..S MSG(PSOHCT)=$G(MSG(PSOHCT))_$E(PSOXFLD(PSOHLIP),1,PSOHLICP)
  1. ..S PSOHLIPX=1,MSG(PSOHCT,PSOHLIPX)=$E(PSOXFLD(PSOHLIP),(PSOHLICP+1),999)
  1. .S MSG(PSOHCT,PSOHLIPX)=$G(MSG(PSOHCT,PSOHLIPX))_$E(PSOXFLD(PSOHLIP),1,PSOHLICP)
  1. .S PSOHLIPX=PSOHLIPX+1,MSG(PSOHCT,PSOHLIPX)=$E(PSOXFLD(PSOHLIP),(PSOHLICP+1),999)
  1. .S PSOHLTTL=$L(MSG(PSOHCT,PSOHLIPX))
  1. ;Set NTE segments
  1. 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
  1. .I $G(^PS(52.41,PSOPND,3,PSOHPC,0))="" Q
  1. .I 'PSOHPCT S MSG(PSOHCT)="NTE|6||"_$G(^PS(52.41,PSOPND,3,PSOHPC,0)) S PSOHPCT=1 Q
  1. .S MSG(PSOHCT,PSOHPCT)=$G(^PS(52.41,PSOPND,3,PSOHPC,0)),PSOHPCT=PSOHPCT+1
  1. I 'PSOHPCT S PSOHCT=PSOHCT-1
  1. 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
  1. .I $G(^PS(52.41,PSOPND,"SIG",PSOHPC,0))="" Q
  1. .I 'PSOHPCT S MSG(PSOHCT)="NTE|21||"_$G(^PS(52.41,PSOPND,"SIG",PSOHPC,0)) S PSOHPCT=1 Q
  1. .S MSG(PSOHCT,PSOHPCT)=$G(^PS(52.41,PSOPND,"SIG",PSOHPC,0)),PSOHPCT=PSOHPCT+1
  1. I 'PSOHPCT S MSG(PSOHCT)="NTE|21||"_"No SIG available"
  1. Q
  1. RXR ;Build RXR segment
  1. S PSOHRTX="" F PSOHRT=0:0 S PSOHRT=$O(^PS(52.41,PSOPND,1,PSOHRT)) Q:'PSOHRT D
  1. .S PSOHRTX=1
  1. .S PSOLIMIT=1 X PSONFLD
  1. .S PSOXFLD(0)="RXR"
  1. .S PSOHRTEN=""
  1. .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)),"^")
  1. .S PSOXFLD(1)="^^^"_$G(PSOHRTE)_"^"_$G(PSOHRTEN)_"^"_"99PSR"
  1. .D SEG
  1. I '$G(PSOHRTX) S PSOLIMIT=1 X PSONFLD S PSOXFLD(0)="RXR",PSOXFLD(1)="^^^^^99PSR" D SEG
  1. Q
  1. ZRX ;Build ZRX segment
  1. S PSOLIMIT=6 X PSONFLD
  1. S PSOXFLD(0)="ZRX"
  1. S PSOXFLD(3)="N"
  1. S PSOXFLD(4)=$P($G(^PS(52.41,PSOPND,0)),"^",17)
  1. D SEG
  1. Q
  1. ZCL ;Build ZCL segment
  1. N I,JJJ,INODE,EI
  1. S PSOXFLD(0)="ZCL",PSOLIMIT=3 X PSONFLD
  1. I $D(^PS(52.41,PSOPND,"ICD")) D
  1. .F I=1:1:8 D
  1. ..Q:'$D(^PS(52.41,PSOPND,"ICD",I,0))
  1. ..S INODE="",INODE=^PS(52.41,PSOPND,"ICD",I,0)
  1. ..F JJJ=2:1:9 S EI=$P(INODE,U,JJJ) D
  1. ...S PSOXFLD(1)=I,PSOXFLD(2)=JJJ-1,PSOXFLD(3)=EI
  1. ...;I JJJ=4 S EI=$S(EI=1:"SC",EI=0:"NSC",1:"") S PSOXFLD(3)=EI
  1. ...D SEG
  1. E D ;if no ICD node, send one ZCL segment
  1. .S PSOXFLD(0)="ZCL",PSOXFLD(1)=1,PSOXFLD(2)=3
  1. .S PSOXFLD(3)=$S($P(^PS(52.41,PSOPND,0),"^",16)="SC":1,$P(^(0),"^",16)="NSC":0,1:"")
  1. .D SEG
  1. .Q:'$D(^PS(52.41,PSOPND,"IBQ"))
  1. .S EI=^PS(52.41,PSOPND,"IBQ")
  1. .F I=2,3,4,1,5,6,7 S PSOXFLD(3)=$P(EI,U,I) D
  1. .. S PSOXFLD(2)=$S(I=2:1,I=3:2,I=4:4,I=1:5,I=5:6,I=6:7,I=7:8,1:"") D SEG
  1. Q
  1. ZSC ;Build ZSC segment
  1. S PSOLIMIT=6 X PSONFLD
  1. S PSOXFLD(0)="ZSC"
  1. S PSOXFLD(1)=$S($P(^PS(52.41,PSOPND,0),"^",16)="SC":1,$P(^(0),"^",16)="NSC":0,1:"")
  1. 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)
  1. D SEG
  1. Q
  1. SEG ;
  1. S PSOSEGMT="" F PSOHJJ=0:1:PSOLIMIT S PSOSEGMT=$S(PSOSEGMT="":PSOXFLD(PSOHJJ),1:PSOSEGMT_"|"_PSOXFLD(PSOHJJ))
  1. S PSOHCT=PSOHCT+1,MSG(PSOHCT)=PSOSEGMT
  1. Q