BUDCRP6C ; IHS/CMI/LAB - UDS REPORT PROCESSOR 01 Dec 2015 3:10 PM 30 Dec 2015 7:19 PM ;
;;10.0;IHS/RPMS UNIFORM DATA SYSTEM;;FEB 04, 2016;Build 50
;
;
GETIMMS(P,BDATE,EDATE,C,BUDX) ;EP
K BUDX
NEW X,Y,I,Z,V
S X=0 F S X=$O(^AUPNVIMM("AC",P,X)) Q:X'=+X D
.Q:'$D(^AUPNVIMM(X,0)) ;happens
.S Y=$P(^AUPNVIMM(X,0),U)
.Q:'Y ;happens too
.S I=$P($G(^AUTTIMM(Y,0)),U,3) ;get HL7/CVX code
.F Z=1:1:$L(C,U) I I=$P(C,U,Z) S V=$P(^AUPNVIMM(X,0),U,3) I V S D=$P($P($G(^AUPNVSIT(V,0)),U),".") I D]"",D'>EDATE,D'<BDATE S BUDX(D)="CVX: "_I_" on "_$$DATE^BUDBUTL1(D)
.Q
Q
;
IMM ;EP - IMM
;must have DOB between in the year - 3
S BUDX3YRB=($E(BUDBD,1,3)-3)_"0101"
S BUDX3YRE=($E(BUDED,1,3)-3)_"1231"
S BUDDOB=$P(^DPT(DFN,0),U,3)
Q:BUDDOB<BUDX3YRB
Q:BUDDOB>BUDX3YRE
S BUDX3RD=$E(BUDDOB,1,3)+3_$E(BUDDOB,4,7)
S BUDX2ND=$E(BUDDOB,1,3)+2_$E(BUDDOB,4,7)
S BUDX1ST=$E(BUDDOB,1,3)+1_$E(BUDDOB,4,7)
;
Q:BUDMEDV<1 ;didn't have at least 1 medical visit
S BUDVBBD=$$VBBD^BUDCRP6D(DFN,BUDDOB,$$FMADD^XLFDT(BUDX3RD,-1)) I 'BUDVBBD Q ;no visit before 3RD bd
S BUDSECTC("PTS")=$G(BUDSECTC("PTS"))+1
S BUDX42D=$$FMADD^XLFDT(BUDDOB,42)
S BUDX180D=$$FMADD^XLFDT(BUDDOB,180)
S (BUDNDTP,BUDNIPV,BUDNMMR,BUDNHEP,BUDNHIB,BUDNVAR,BUDNPNEU)=""
;see if ever had a 999.4 before 3RD birthday
S BUDCTA=""
S X=$$CONTRA(DFN,BUDDOB,BUDX3RD)
I X]"" S BUDCTA=X
I BUDCTA]"" D Q
.S BUDSECTC("IMM")=$G(BUDSECTC("IMM"))+1 D Q
..I $G(BUDIMM1L) D
...S ^XTMP("BUDCRP6B",BUDJ,BUDH,"IMM1",$P(^DPT(DFN,0),U),BUDCOM,DFN)="CONTRA ALL: "_$P(X,U,1)_" on "_$$FMTE^XLFDT($P(X,U,2))_"|||"_BUDVBBD_U_BUDMEDVI
..Q
S BUDNDTP=$$DTAP^BUDCRP6X(DFN,BUDX42D,BUDX3RD)
S BUDNIPV=$$IPV(DFN,BUDX42D,BUDX3RD)
S BUDNMMR=$$MMR(DFN,BUDDOB,BUDX3RD)
S BUDNHEP=$$HEP^BUDCRP6Y(DFN,BUDDOB,BUDX3RD)
S BUDNHIB=$$HIB^BUDCRP6Y(DFN,BUDX42D,BUDX3RD)
S BUDNVAR=$$VAR^BUDCRP6Y(DFN,BUDX1ST,BUDX3RD)
S BUDNPNEU=$$PNEU^BUDCRP6Y(DFN,BUDDOB,BUDX3RD)
I $P(BUDNDTP,U,1)=1,$P(BUDNIPV,U,1)=1,$P(BUDNMMR,U,1)=1,$P(BUDNHEP,U,1)=1,$P(BUDNHIB,U,1)=1,$P(BUDNVAR,U,1)=1,$P(BUDNPNEU,U,1)=1 S BUDSECTC("IMM")=$G(BUDSECTC("IMM"))+1 D Q
.I $G(BUDIMM1L) D
..S X=$P(BUDNDTP,U,2)_U_$P(BUDNIPV,U,2)_U_$P(BUDNMMR,U,2)_U_$P(BUDNHEP,U,2)_U_$P(BUDNHIB,U,2)_U_$P(BUDNVAR,U,2)_U_$P(BUDNPNEU,U,2)_"|||"_BUDVBBD_U_BUDMEDVI
..S ^XTMP("BUDCRP6B",BUDJ,BUDH,"IMM1",$P(^DPT(DFN,0),U),BUDCOM,DFN)=X
..Q
I $G(BUDIMM2L) D
.S V=$S($P(BUDNDTP,U,1)=1:"",1:$P(BUDNDTP,U,2))_$S($P(BUDNIPV,U,1)=1:"",1:";"_$P(BUDNIPV,U,2))_$S($P(BUDNMMR,U,1)=1:"",1:";"_$P(BUDNMMR,U,2))_$S($P(BUDNHEP,U,1)=1:"",1:";"_$P(BUDNHEP,U,2))
.S V=V_$S($P(BUDNHIB,U,1)=1:"",1:";"_$P(BUDNHIB,U,2))_$S($P(BUDNVAR,U,1)=1:"",1:";VARI")_$S($P(BUDNPNEU,U,1)=1:"",1:";"_$P(BUDNPNEU,U,2))
.S ^XTMP("BUDCRP6B",BUDJ,BUDH,"IMM2",$P(^DPT(DFN,0),U),BUDCOM,DFN)=V
Q
;
CONTRA(P,BD,ED) ;EP
NEW D,BUDG,E,%
K BUDG S %=P_"^ALL DX;DURING "_BD_"-"_ED,E=$$START1^APCLDF(%,"BUDG(")
NEW X,Y,G,T
S T=$O(^BUDCTSSC("B","CONTRA ALL VACCINES",0))
S G=""
S X=0 F S X=$O(BUDG(X)) Q:X'=+X!(G]"") D
.S Y=+$P(BUDG(X),U,4)
.S Y=$P($G(^AUPNVPOV(Y,0)),U,1)
.I $D(^BUDCTSSC("AD",Y,T)) S G=$P(BUDG(X),U,2)_U_$P(BUDG(X),U,1)
Q G
ANAREACT(I) ;EP
NEW X,Y,R
S X=0,Y=0 F S X=$O(^GMR(120.8,I,10,X)) Q:X'=+X D
.S R=$P($G(^GMR(120.8,I,10,X,0)),U)
.Q:R=""
.S R=$P($G(^GMRD(120.83,R,0)),U)
.I R'="ANAPHYLAXIS" Q
.S Y=1
.Q
Q Y
;
ANCONT(P,C,ED) ;EP - ANALPHYLAXIS CONTRA
NEW X
S X=0,G="",Y=$O(^AUTTIMM("C",C,0)) I Y F S X=$O(^BIPC("AC",P,Y,X)) Q:X'=+X!(G) D
.S R=$P(^BIPC(X,0),U,3)
.Q:R=""
.Q:'$D(^BICONT(R,0))
.S D=$P(^BIPC(X,0),U,4)
.Q:D=""
.;Q:$P(^BIPC(X,0),U,4)<BD
.;Q:$P(^BIPC(X,0),U,4)>ED
.I $P(^BICONT(R,0),U,1)="Anaphylaxis" S G=D_U_"Anaphylaxis"
.I $P(^BICONT(R,0),U,1)="Baker's Yeast Allergy" S G=D_U_"Baker's Yeast Allergy"
.I $P(^BICONT(R,0),U,1)="Yeast Allergy" S G=D_U_"Yeast Allergy"
Q G
;
EGGCONT(P,C,ED) ;EP - EGG CONTRA
NEW X
S X=0,G="",Y=$O(^AUTTIMM("C",C,0)) I Y F S X=$O(^BIPC("AC",P,Y,X)) Q:X'=+X!(G) D
.S R=$P(^BIPC(X,0),U,3)
.Q:R=""
.Q:'$D(^BICONT(R,0))
.S D=$P(^BIPC(X,0),U,4)
.Q:D=""
.;Q:$P(^BIPC(X,0),U,4)<BD
.;Q:$P(^BIPC(X,0),U,4)>ED
.I $P(^BICONT(R,0),U,1)="Egg Allergy" S G=D_U_"Egg Allergy"
Q G
ANNECONT(P,C,ED) ;EP - ANALPHYLAXIS/NEOMYCIN CONTRA
NEW X
S X=0,G="",Y=$O(^AUTTIMM("C",C,0)) I Y F S X=$O(^BIPC("AC",P,Y,X)) Q:X'=+X!(G) D
.S R=$P(^BIPC(X,0),U,3)
.Q:R=""
.Q:'$D(^BICONT(R,0))
.S D=$P(^BIPC(X,0),U,4)
.Q:D=""
.I $P(^BICONT(R,0),U,1)="Anaphylaxis" S G=D_U_"Anaphylaxis"
.I $P(^BICONT(R,0),U,1)="Neomycin Allergy" S G=D_U_"Neomycin Allergy"
.I $P(^BICONT(R,0),U,1)="Streptomycin Allergy" S G=D_U_"Streptomycin Allergy"
.I $P(^BICONT(R,0),U,1)="Polymyxin B Allergy" S G=D_U_"Polymyxin B Allergy"
Q G
;
MMRCONT(P,C,ED) ;EP - ANALPHYLAXIS/NEOMYCIN/IMMUNE CONTRA
NEW X
S X=0,G="",Y=$O(^AUTTIMM("C",C,0)) I Y F S X=$O(^BIPC("AC",P,Y,X)) Q:X'=+X!(G) D
.S R=$P(^BIPC(X,0),U,3)
.Q:R=""
.Q:'$D(^BICONT(R,0))
.S D=$P(^BIPC(X,0),U,4)
.Q:D=""
.;Q:$P(^BIPC(X,0),U,4)<BD
.;Q:$P(^BIPC(X,0),U,4)>ED
.I $P(^BICONT(R,0),U,1)="Anaphylaxis" S G=D_U_"Anaphylaxis"
.I $P(^BICONT(R,0),U,1)="Neomycin Allergy" S G=D_U_"Neomycin Allergy"
.I $P(^BICONT(R,0),U,1)="Immune Deficiency" S G=D_U_"Immune Deficiency"
.I $P(^BICONT(R,0),U,1)["Immune Deficient" S G=D_U_"Immune Deficient"
.I $P(^BICONT(R,0),U,1)="Immune" S G=D_U_"Immune"
Q G
;
IPV(P,BDATE,EDATE) ;EP
;check for a contraindication from DOB to 2nd birthday
NEW X,G,N,BUDG,BUDX,BUDC,BUDOPV,BUDAPOV,C,BD,ED,V,Y,E
IPVCONT ;check allergy tracking
S G=""
S X=0 F S X=$O(^GMR(120.8,"B",P,X)) Q:X'=+X!(G) D
.;Q:$P($P($G(^GMR(120.8,X,0)),U,4),".")>EDATE ;entered after 2ND birthday
.S N=$P($G(^GMR(120.8,X,0)),U,2),N=$$UP^XLFSTR(N)
.I N["STREPTOMYCIN"!(N["POLYMYXIN B")!(N["NEOMYCIN") S G="1^IPV Contraindiction: "_$$DATE^BUDCUTL1($P($P($G(^GMR(120.8,X,0)),U,4),"."))_" Allergy Tracking: "_N
.Q:'$$ANAREACT(X) ;quit if anaphylactic is not a reaction/sign/symptom
I G]"" Q G
;now check immunization package
F BUDZ=2,10,89,110,120,130,132,146 S X=$$ANNECONT(P,BUDZ,EDATE) Q:X]""
I X]"" Q "1^IPV Contraindication IM package: "_$$DATE^BUDCUTL1($P(X,U))_" "_$P(X,U,2)
;now check for evidence of disease
IPVEVID ;
;V10.0 ICD10
K BUDG S %=P_"^ALL DX;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
S T=$O(^BUDCTSSC("B","EVIDENCE IPV",0))
S X=0,G="" F S X=$O(BUDG(X)) Q:X'=+X!(G]"") D
.S Y=+$P(BUDG(X),U,4)
.S Y=$P($G(^AUPNVPOV(Y,0)),U,1)
.I $D(^BUDCTSSC("AD",Y,T)) S G="1^IPV Evidence "_$P(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(X),U))
I G]"" Q G
S X=$$PLCL^BUDCDU(P,"EVIDENCE IPV") I X Q "1^IPV Evidence: "_$P(X,U,2)_" on Problem List"
K BUDC,BUDG,BUDX
K BUDOPV,BUDAPOV
IPVIMM ;get all immunizations
S C="2^10^89^110^120^130^132^146"
K BUDX D GETIMMS(P,BDATE,EDATE,C,.BUDX)
;now get cpt codes
S X=0 F S X=$O(BUDX(X)) Q:X'=+X S BUDOPV(X)=BUDX(X),BUDAPOV(X)=BUDX(X)
;now get cpts
S ED=9999999-EDATE,BD=9999999-BDATE,G=0
F S ED=$O(^AUPNVSIT("AA",P,ED)) Q:ED=""!($P(ED,".")>BD) D
.S V=0 F S V=$O(^AUPNVSIT("AA",P,ED,V)) Q:V'=+V D
..Q:'$D(^AUPNVSIT(V,0))
..S X=0 F S X=$O(^AUPNVCPT("AD",V,X)) Q:X'=+X D
...S Y=$P(^AUPNVCPT(X,0),U),Y=$P($$CPT^ICPTCOD(Y),U,2) D
....I Y=90698!(Y=90713)!(Y=90723) S BUDOPV(9999999-$P(ED,"."))="CPT: "_Y_" on "_$$DATE^BUDCUTL1((9999999-$P(ED,"."))),BUDAPOV(9999999-$P(ED,"."))="CPT: "_Y_" on "_$$DATE^BUDCUTL1((9999999-$P(ED,".")))
..S X=0 F S X=$O(^AUPNVTC("AD",V,X)) Q:X'=+X D
...S Y=$P(^AUPNVTC(X,0),U,7) Q:'Y S Y=$P($$CPT^ICPTCOD(Y),U,2) D
....I Y=90698!(Y=90713)!(Y=90723) S BUDOPV(9999999-$P(ED,"."))="CPT: "_Y_" on "_$$DATE^BUDCUTL1((9999999-$P(ED,"."))),BUDAPOV(9999999-$P(ED,"."))="CPT: "_Y_" on "_$$DATE^BUDCUTL1((9999999-$P(ED,".")))
;now check to see if they are all spaced 10 days apart, if not, kill off the odd ones
S (X,Y)="",C=0 F S X=$O(BUDOPV(X)) Q:X'=+X S C=C+1 D
.I C=1 S Y=X Q
.I $$FMDIFF^XLFDT(X,Y)<11 K BUDOPV(X) Q
.S Y=X
;now count them and see if there are 4 of them
S BUDOPV=0,X=0 F S X=$O(BUDOPV(X)) Q:X'=+X S BUDOPV=BUDOPV+1
I BUDOPV>2 S Y="1^IPV: total #: "_BUDOPV,X="" F S X=$O(BUDOPV(X)) Q:X'=+X S Y=Y_" "_BUDOPV(X)
I BUDOPV>2 Q Y
;now get povs
K BUDOPV M BUDOPV=BUDAPOV
I $D(BUDG(1)) S X=0 F S X=$O(BUDG(X)) Q:X'=+X S BUDOPV($P(BUDG(X),U))="POV: "_$P(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1)),BUDAOPV($P(BUDG(X),U))="POV: "_$P(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1))
K BUDG S %=P_"^ALL PROCEDURE 99.41;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
I $D(BUDG(1)) S X=0 F S X=$O(BUDG(X)) Q:X'=+X S BUDOPV($P(BUDG(X),U))="Procedure: "_$P(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1)),BUDAPOV($P(BUDG(X),U))="Procedure: "_$P(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1))
;now check to see if they are all spaced 10 days apart, if not, kill off the odd ones
S (X,Y)="",C=0 F S X=$O(BUDOPV(X)) Q:X'=+X S C=C+1 D
.I C=1 S Y=X Q
.I $$FMDIFF^XLFDT(X,Y)<11 K BUDOPV(X) Q
.S Y=X
;now count them and see if there are 4 of them
S BUDOPV=0,X=0 F S X=$O(BUDOPV(X)) Q:X'=+X S BUDOPV=BUDOPV+1
I BUDOPV>2 S Y="1^IPV: total #: "_BUDOPV,X="" F S X=$O(BUDOPV(X)) Q:X'=+X S Y=Y_" "_BUDOPV(X)
I BUDOPV>2 Q Y
Q "0^"_(3-BUDOPV)_" IPV"
;
MMR(P,BDATE,EDATE) ;EP
;first check for contraindications
;dx first
MMRC ;
NEW BUDG,%,X,BUDZ,BUDC,BUDX,G,N,T,Y,E
;V10.0 ICD10
K BUDG S %=P_"^ALL DX;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
S T=$O(^BUDCTSSC("B","CONTRA VARICELLA/MMR",0))
S X=0,G="" F S X=$O(BUDG(X)) Q:X'=+X!(G]"") D
.S Y=+$P(BUDG(X),U,4)
.S Y=$P($G(^AUPNVPOV(Y,0)),U,1)
.I $D(^BUDCTSSC("AD",Y,T)) S G="1^MMR CONTRA DX "_$P(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(X),U))
I G]"" Q G
S X=$$PLCL^BUDCDU(P,"CONTRA VARICELLA/MMR") I X Q "1^MMR CONTRA DX: "_$P(X,U,2)_" on Problem List"
S G=""
S X=0 F S X=$O(^GMR(120.8,"B",P,X)) Q:X'=+X!(G) D
.;Q:$P($P($G(^GMR(120.8,X,0)),U,4),".")>EDATE ;entered after 2ND birthday
.S N=$P($G(^GMR(120.8,X,0)),U,2),N=$$UP^XLFSTR(N)
.Q:'$$ANAREACT(X) ;quit if anaphylactic is not a reaction/sign/symptom
.I N["NEOMYCIN" S G="1^MMR Contraindiction: "_$$DATE^BUDCUTL1($P($P($G(^GMR(120.8,X,0)),U,4),"."))_" Allergy Tracking: "_N
I G]"" Q G
F BUDZ=3,94,5,7,6 S X=$$MMRCONT(P,BUDZ,EDATE) Q:X]""
I X]"" Q "1^MMR Contraindication: "_$P(X,U,2)_" on "_$$DATE^BUDCUTL1($P(X,U,1))_" Immunization Package"
MMREVID ;
;
MMRI ;
K BUDC,BUDG,BUDX
K ^TMP($J,"CPT")
S (BUDMMR,BUDMUMPS,BUDRUB,BUDMEAS)="" ;set to null for all
;first gather up all cpt codes that relate in any way to MMR and store in ^TMP
S ED=9999999-EDATE,BD=9999999-BDATE,G=0
F S ED=$O(^AUPNVSIT("AA",P,ED)) Q:ED=""!($P(ED,".")>BD) D
.S V=0 F S V=$O(^AUPNVSIT("AA",P,ED,V)) Q:V'=+V D
..Q:'$D(^AUPNVSIT(V,0))
..Q:'$D(^AUPNVCPT("AD",V))
..S X=0 F S X=$O(^AUPNVCPT("AD",V,X)) Q:X'=+X D
...S Y=$P(^AUPNVCPT(X,0),U),Y=$P($$CPT^ICPTCOD(Y),U,2) I Y=+Y,$T(@Y)]"" S ^TMP($J,"CPT",9999999-$P(ED,"."),Y)=""
;get all immunizations
S C="3^94"
K BUDX D GETIMMS(P,BDATE,EDATE,C,.BUDX) ;before 2nd birthday
I $D(BUDX) S D=$O(BUDX(0)) Q "1^MMR "_BUDX(D) ;HAD 1 MMR
S D=0 F S D=$O(^TMP($J,"CPT",D)) Q:D'=+D S Y="" F S Y=$O(^TMP($J,"CPT",D,Y)) Q:Y="" D
.I Y=90707!(Y=90710)!(Y=90708) S BUDMMR="CPT: "_Y_" on "_$$DATE^BUDCUTL1(D)
I BUDMMR]"" Q "1^MMR "_BUDMMR
;
;K BUDG S %=P_"^ALL PROCEDURE 99.45;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
;I $D(BUDG(1)) Q "1^MMR PROCEDURE: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U))
;now check individuals
MR ;see if one M/R, Mumps or R/M
S BUDVALUE=""
ME S C=5
K BUDX D GETIMMS(P,BDATE,EDATE,C,.BUDX)
I $D(BUDX) S BUDMEAS=1 S D=$O(BUDX(0)) S BUDVALUE=BUDVALUE_" MEASLES "_BUDX(D)
S D=0 F S D=$O(^TMP($J,"CPT",D)) Q:D'=+D S Y="" F S Y=$O(^TMP($J,"CPT",D,Y)) Q:Y="" D
.I Y=90705!(Y=90708) S BUDMEAS=1,BUDVALUE=BUDVALUE_" MEASLES CPT "_Y_" on "_$$DATE^BUDCUTL1(D)
K BUDG S %=P_"^ALL PROCEDURE 99.45;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
I $D(BUDG(1)) S BUDMEAS=1,BUDVALUE=BUDVALUE_" MEASLES PROCEDURE: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1))
I BUDMEAS="" K BUDG S %=P_"^LAST DX [BGP MEASLES EVIDENCE;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(") I $D(BUDG(1)) S BUDMEAS=1,BUDVALUE=BUDVALUE_" MEASLES EVIDENCE DX: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1))
I BUDMEAS="" S X=$$PLTAX^BUDCDU(P,"BGP MEASLES EVIDENCE") I X S BUDMEAS=1,BUDVALUE=BUDVALUE_" MEASLES EVIDENCE PROB LIST: "_$P(X,U,2)
I BUDMEAS,BUDMUMPS,BUDRUB Q "1^"_BUDVALUE
MU S C=7
D GETIMMS(P,BDATE,EDATE,C,.BUDX)
I $D(BUDX) S BUDMUMPS=1 S D=$O(BUDX(0)) S BUDVALUE=BUDVALUE_" MUMPS "_BUDX(D)
S D=0 F S D=$O(^TMP($J,"CPT",D)) Q:D'=+D S Y="" F S Y=$O(^TMP($J,"CPT",D,Y)) Q:Y="" D
.I Y=90704!(Y=90710) S BUDMUMPS=1,BUDVALUE=BUDVALUE_" MUMPS CPT "_Y_" on "_$$DATE^BUDCUTL1(D)
K BUDG S %=P_"^ALL PROCEDURE 99.46;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
I $D(BUDG(1)) S BUDMUMPS=1,BUDVALUE=BUDVALUE_" MUMPS PROCEDURE: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1))
I BUDMUMPS="" K BUDG S %=P_"^LAST DX [BGP MUMPS EVIDENCE;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(") I $D(BUDG(1)) S BUDMUMPS=1,BUDVALUE=BUDVALUE_" MUMPS EVIDENCE DX: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1))
I BUDMUMPS="" S X=$$PLTAX^BUDCDU(P,"BGP MUMPS EVIDENCE") I X S BUDMUMPS=1,BUDVALUE=BUDVALUE_" MUMPS EVIDENCE PROB LIST: "_$P(X,U,2)
I BUDMEAS,BUDMUMPS,BUDRUB Q "1^"_BUDVALUE
RUB S C=6
D GETIMMS(P,BDATE,EDATE,C,.BUDX)
I $D(BUDX) S BUDRUB=1,D=$O(BUDX(0)) S BUDVALUE=BUDVALUE_" RUBELLA "_BUDX(D)
S D=0 F S D=$O(^TMP($J,"CPT",D)) Q:D'=+D S Y="" F S Y=$O(^TMP($J,"CPT",D,Y)) Q:Y="" D
.I Y=90706!(Y=90707)!(Y=90708)!(Y=90710) S BUDRUB=1,BUDVALUE=BUDVALUE_" RUBELLA CPT "_Y_" on "_$$DATE^BUDCUTL1(D)
K BUDG S %=P_"^ALL PROCEDURE 99.47;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
I $D(BUDG(1)) S BUDRUB=1,BUDVALUE=BUDVALUE_" RUBELLA PROCEDURE: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1))
I BUDRUB="" K BUDG S %=P_"^LAST DX [BGP RUBELLA EVIDENCE;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(") I $D(BUDG(1)) S BUDRUB=1,BUDVALUE=BUDVALUE_" RUBELLA EVIDENCE DX: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U,1))
I BUDRUB="" S X=$$PLTAX^BUDCDU(P,"BGP RUBELLA EVIDENCE") I X S BUDRUB=1,BUDVALUE=BUDVALUE_" RUBELLA EVIDENCE PROB LIST: "_$P(X,U,2)
I BUDMEAS,BUDMUMPS,BUDRUB Q "1^"_BUDVALUE
I 'BUDMEAS,'BUDMUMPS,'BUDRUB Q "0^1 MEASLES MUMPS RUBBELLA"
Q "0^"_$S('BUDMEAS:" 1 MEASLES",1:"")_$S('BUDMUMPS:" 1 MUMPS",1:"")_$S('BUDRUB:" 1 RUBELLA",1:"")
;
90707 ;;
90708 ;;
90710 ;;
90705 ;;
90704 ;;
90706 ;;
BUDCRP6C ; IHS/CMI/LAB - UDS REPORT PROCESSOR 01 Dec 2015 3:10 PM 30 Dec 2015 7:19 PM ;
+1 ;;10.0;IHS/RPMS UNIFORM DATA SYSTEM;;FEB 04, 2016;Build 50
+2 ;
+3 ;
GETIMMS(P,BDATE,EDATE,C,BUDX) ;EP
+1 KILL BUDX
+2 NEW X,Y,I,Z,V
+3 SET X=0
FOR
SET X=$ORDER(^AUPNVIMM("AC",P,X))
IF X'=+X
QUIT
Begin DoDot:1
+4 ;happens
IF '$DATA(^AUPNVIMM(X,0))
QUIT
+5 SET Y=$PIECE(^AUPNVIMM(X,0),U)
+6 ;happens too
IF 'Y
QUIT
+7 ;get HL7/CVX code
SET I=$PIECE($GET(^AUTTIMM(Y,0)),U,3)
+8 FOR Z=1:1:$LENGTH(C,U)
IF I=$PIECE(C,U,Z)
SET V=$PIECE(^AUPNVIMM(X,0),U,3)
IF V
SET D=$PIECE($PIECE($GET(^AUPNVSIT(V,0)),U),".")
IF D]""
IF D'>EDATE
IF D'<BDATE
SET BUDX(D)="CVX: "_I_" on "_$$DATE^BUDBUTL1(D)
+9 QUIT
End DoDot:1
+10 QUIT
+11 ;
IMM ;EP - IMM
+1 ;must have DOB between in the year - 3
+2 SET BUDX3YRB=($EXTRACT(BUDBD,1,3)-3)_"0101"
+3 SET BUDX3YRE=($EXTRACT(BUDED,1,3)-3)_"1231"
+4 SET BUDDOB=$PIECE(^DPT(DFN,0),U,3)
+5 IF BUDDOB<BUDX3YRB
QUIT
+6 IF BUDDOB>BUDX3YRE
QUIT
+7 SET BUDX3RD=$EXTRACT(BUDDOB,1,3)+3_$EXTRACT(BUDDOB,4,7)
+8 SET BUDX2ND=$EXTRACT(BUDDOB,1,3)+2_$EXTRACT(BUDDOB,4,7)
+9 SET BUDX1ST=$EXTRACT(BUDDOB,1,3)+1_$EXTRACT(BUDDOB,4,7)
+10 ;
+11 ;didn't have at least 1 medical visit
IF BUDMEDV<1
QUIT
+12 ;no visit before 3RD bd
SET BUDVBBD=$$VBBD^BUDCRP6D(DFN,BUDDOB,$$FMADD^XLFDT(BUDX3RD,-1))
IF 'BUDVBBD
QUIT
+13 SET BUDSECTC("PTS")=$GET(BUDSECTC("PTS"))+1
+14 SET BUDX42D=$$FMADD^XLFDT(BUDDOB,42)
+15 SET BUDX180D=$$FMADD^XLFDT(BUDDOB,180)
+16 SET (BUDNDTP,BUDNIPV,BUDNMMR,BUDNHEP,BUDNHIB,BUDNVAR,BUDNPNEU)=""
+17 ;see if ever had a 999.4 before 3RD birthday
+18 SET BUDCTA=""
+19 SET X=$$CONTRA(DFN,BUDDOB,BUDX3RD)
+20 IF X]""
SET BUDCTA=X
+21 IF BUDCTA]""
Begin DoDot:1
+22 SET BUDSECTC("IMM")=$GET(BUDSECTC("IMM"))+1
Begin DoDot:2
+23 IF $GET(BUDIMM1L)
Begin DoDot:3
+24 SET ^XTMP("BUDCRP6B",BUDJ,BUDH,"IMM1",$PIECE(^DPT(DFN,0),U),BUDCOM,DFN)="CONTRA ALL: "_$PIECE(X,U,1)_" on "_$$FMTE^XLFDT($PIECE(X,U,2))_"|||"_BUDVBBD_U_BUDMEDVI
End DoDot:3
+25 QUIT
End DoDot:2
QUIT
End DoDot:1
QUIT
+26 SET BUDNDTP=$$DTAP^BUDCRP6X(DFN,BUDX42D,BUDX3RD)
+27 SET BUDNIPV=$$IPV(DFN,BUDX42D,BUDX3RD)
+28 SET BUDNMMR=$$MMR(DFN,BUDDOB,BUDX3RD)
+29 SET BUDNHEP=$$HEP^BUDCRP6Y(DFN,BUDDOB,BUDX3RD)
+30 SET BUDNHIB=$$HIB^BUDCRP6Y(DFN,BUDX42D,BUDX3RD)
+31 SET BUDNVAR=$$VAR^BUDCRP6Y(DFN,BUDX1ST,BUDX3RD)
+32 SET BUDNPNEU=$$PNEU^BUDCRP6Y(DFN,BUDDOB,BUDX3RD)
+33 IF $PIECE(BUDNDTP,U,1)=1
IF $PIECE(BUDNIPV,U,1)=1
IF $PIECE(BUDNMMR,U,1)=1
IF $PIECE(BUDNHEP,U,1)=1
IF $PIECE(BUDNHIB,U,1)=1
IF $PIECE(BUDNVAR,U,1)=1
IF $PIECE(BUDNPNEU,U,1)=1
SET BUDSECTC("IMM")=$GET(BUDSECTC("IMM"))+1
Begin DoDot:1
+34 IF $GET(BUDIMM1L)
Begin DoDot:2
+35 SET X=$PIECE(BUDNDTP,U,2)_U_$PIECE(BUDNIPV,U,2)_U_$PIECE(BUDNMMR,U,2)_U_$PIECE(BUDNHEP,U,2)_U_$PIECE(BUDNHIB,U,2)_U_$PIECE(BUDNVAR,U,2)_U_$PIECE(BUDNPNEU,U,2)_"|||"_BUDVBBD_U_BUDMEDVI
+36 SET ^XTMP("BUDCRP6B",BUDJ,BUDH,"IMM1",$PIECE(^DPT(DFN,0),U),BUDCOM,DFN)=X
+37 QUIT
End DoDot:2
End DoDot:1
QUIT
+38 IF $GET(BUDIMM2L)
Begin DoDot:1
+39 SET V=$SELECT($PIECE(BUDNDTP,U,1)=1:"",1:$PIECE(BUDNDTP,U,2))_$SELECT($PIECE(BUDNIPV,U,1)=1:"",1:";"_$PIECE(BUDNIPV,U,2))_$SELECT($PIECE(BUDNMMR,U,1)=1:"",1:";"_$PIECE(BUDNMMR,U,2))_$SELECT($PIECE(BUDNHEP,U,1)=1:"",1:";"_$PIECE(BUDNHEP,
U,2))
+40 SET V=V_$SELECT($PIECE(BUDNHIB,U,1)=1:"",1:";"_$PIECE(BUDNHIB,U,2))_$SELECT($PIECE(BUDNVAR,U,1)=1:"",1:";VARI")_$SELECT($PIECE(BUDNPNEU,U,1)=1:"",1:";"_$PIECE(BUDNPNEU,U,2))
+41 SET ^XTMP("BUDCRP6B",BUDJ,BUDH,"IMM2",$PIECE(^DPT(DFN,0),U),BUDCOM,DFN)=V
End DoDot:1
+42 QUIT
+43 ;
CONTRA(P,BD,ED) ;EP
+1 NEW D,BUDG,E,%
+2 KILL BUDG
SET %=P_"^ALL DX;DURING "_BD_"-"_ED
SET E=$$START1^APCLDF(%,"BUDG(")
+3 NEW X,Y,G,T
+4 SET T=$ORDER(^BUDCTSSC("B","CONTRA ALL VACCINES",0))
+5 SET G=""
+6 SET X=0
FOR
SET X=$ORDER(BUDG(X))
IF X'=+X!(G]"")
QUIT
Begin DoDot:1
+7 SET Y=+$PIECE(BUDG(X),U,4)
+8 SET Y=$PIECE($GET(^AUPNVPOV(Y,0)),U,1)
+9 IF $DATA(^BUDCTSSC("AD",Y,T))
SET G=$PIECE(BUDG(X),U,2)_U_$PIECE(BUDG(X),U,1)
End DoDot:1
+10 QUIT G
ANAREACT(I) ;EP
+1 NEW X,Y,R
+2 SET X=0
SET Y=0
FOR
SET X=$ORDER(^GMR(120.8,I,10,X))
IF X'=+X
QUIT
Begin DoDot:1
+3 SET R=$PIECE($GET(^GMR(120.8,I,10,X,0)),U)
+4 IF R=""
QUIT
+5 SET R=$PIECE($GET(^GMRD(120.83,R,0)),U)
+6 IF R'="ANAPHYLAXIS"
QUIT
+7 SET Y=1
+8 QUIT
End DoDot:1
+9 QUIT Y
+10 ;
ANCONT(P,C,ED) ;EP - ANALPHYLAXIS CONTRA
+1 NEW X
+2 SET X=0
SET G=""
SET Y=$ORDER(^AUTTIMM("C",C,0))
IF Y
FOR
SET X=$ORDER(^BIPC("AC",P,Y,X))
IF X'=+X!(G)
QUIT
Begin DoDot:1
+3 SET R=$PIECE(^BIPC(X,0),U,3)
+4 IF R=""
QUIT
+5 IF '$DATA(^BICONT(R,0))
QUIT
+6 SET D=$PIECE(^BIPC(X,0),U,4)
+7 IF D=""
QUIT
+8 ;Q:$P(^BIPC(X,0),U,4)<BD
+9 ;Q:$P(^BIPC(X,0),U,4)>ED
+10 IF $PIECE(^BICONT(R,0),U,1)="Anaphylaxis"
SET G=D_U_"Anaphylaxis"
+11 IF $PIECE(^BICONT(R,0),U,1)="Baker's Yeast Allergy"
SET G=D_U_"Baker's Yeast Allergy"
+12 IF $PIECE(^BICONT(R,0),U,1)="Yeast Allergy"
SET G=D_U_"Yeast Allergy"
End DoDot:1
+13 QUIT G
+14 ;
EGGCONT(P,C,ED) ;EP - EGG CONTRA
+1 NEW X
+2 SET X=0
SET G=""
SET Y=$ORDER(^AUTTIMM("C",C,0))
IF Y
FOR
SET X=$ORDER(^BIPC("AC",P,Y,X))
IF X'=+X!(G)
QUIT
Begin DoDot:1
+3 SET R=$PIECE(^BIPC(X,0),U,3)
+4 IF R=""
QUIT
+5 IF '$DATA(^BICONT(R,0))
QUIT
+6 SET D=$PIECE(^BIPC(X,0),U,4)
+7 IF D=""
QUIT
+8 ;Q:$P(^BIPC(X,0),U,4)<BD
+9 ;Q:$P(^BIPC(X,0),U,4)>ED
+10 IF $PIECE(^BICONT(R,0),U,1)="Egg Allergy"
SET G=D_U_"Egg Allergy"
End DoDot:1
+11 QUIT G
ANNECONT(P,C,ED) ;EP - ANALPHYLAXIS/NEOMYCIN CONTRA
+1 NEW X
+2 SET X=0
SET G=""
SET Y=$ORDER(^AUTTIMM("C",C,0))
IF Y
FOR
SET X=$ORDER(^BIPC("AC",P,Y,X))
IF X'=+X!(G)
QUIT
Begin DoDot:1
+3 SET R=$PIECE(^BIPC(X,0),U,3)
+4 IF R=""
QUIT
+5 IF '$DATA(^BICONT(R,0))
QUIT
+6 SET D=$PIECE(^BIPC(X,0),U,4)
+7 IF D=""
QUIT
+8 IF $PIECE(^BICONT(R,0),U,1)="Anaphylaxis"
SET G=D_U_"Anaphylaxis"
+9 IF $PIECE(^BICONT(R,0),U,1)="Neomycin Allergy"
SET G=D_U_"Neomycin Allergy"
+10 IF $PIECE(^BICONT(R,0),U,1)="Streptomycin Allergy"
SET G=D_U_"Streptomycin Allergy"
+11 IF $PIECE(^BICONT(R,0),U,1)="Polymyxin B Allergy"
SET G=D_U_"Polymyxin B Allergy"
End DoDot:1
+12 QUIT G
+13 ;
MMRCONT(P,C,ED) ;EP - ANALPHYLAXIS/NEOMYCIN/IMMUNE CONTRA
+1 NEW X
+2 SET X=0
SET G=""
SET Y=$ORDER(^AUTTIMM("C",C,0))
IF Y
FOR
SET X=$ORDER(^BIPC("AC",P,Y,X))
IF X'=+X!(G)
QUIT
Begin DoDot:1
+3 SET R=$PIECE(^BIPC(X,0),U,3)
+4 IF R=""
QUIT
+5 IF '$DATA(^BICONT(R,0))
QUIT
+6 SET D=$PIECE(^BIPC(X,0),U,4)
+7 IF D=""
QUIT
+8 ;Q:$P(^BIPC(X,0),U,4)<BD
+9 ;Q:$P(^BIPC(X,0),U,4)>ED
+10 IF $PIECE(^BICONT(R,0),U,1)="Anaphylaxis"
SET G=D_U_"Anaphylaxis"
+11 IF $PIECE(^BICONT(R,0),U,1)="Neomycin Allergy"
SET G=D_U_"Neomycin Allergy"
+12 IF $PIECE(^BICONT(R,0),U,1)="Immune Deficiency"
SET G=D_U_"Immune Deficiency"
+13 IF $PIECE(^BICONT(R,0),U,1)["Immune Deficient"
SET G=D_U_"Immune Deficient"
+14 IF $PIECE(^BICONT(R,0),U,1)="Immune"
SET G=D_U_"Immune"
End DoDot:1
+15 QUIT G
+16 ;
IPV(P,BDATE,EDATE) ;EP
+1 ;check for a contraindication from DOB to 2nd birthday
+2 NEW X,G,N,BUDG,BUDX,BUDC,BUDOPV,BUDAPOV,C,BD,ED,V,Y,E
IPVCONT ;check allergy tracking
+1 SET G=""
+2 SET X=0
FOR
SET X=$ORDER(^GMR(120.8,"B",P,X))
IF X'=+X!(G)
QUIT
Begin DoDot:1
+3 ;Q:$P($P($G(^GMR(120.8,X,0)),U,4),".")>EDATE ;entered after 2ND birthday
+4 SET N=$PIECE($GET(^GMR(120.8,X,0)),U,2)
SET N=$$UP^XLFSTR(N)
+5 IF N["STREPTOMYCIN"!(N["POLYMYXIN B")!(N["NEOMYCIN")
SET G="1^IPV Contraindiction: "_$$DATE^BUDCUTL1($PIECE($PIECE($GET(^GMR(120.8,X,0)),U,4),"."))_" Allergy Tracking: "_N
+6 ;quit if anaphylactic is not a reaction/sign/symptom
IF '$$ANAREACT(X)
QUIT
End DoDot:1
+7 IF G]""
QUIT G
+8 ;now check immunization package
+9 FOR BUDZ=2,10,89,110,120,130,132,146
SET X=$$ANNECONT(P,BUDZ,EDATE)
IF X]""
QUIT
+10 IF X]""
QUIT "1^IPV Contraindication IM package: "_$$DATE^BUDCUTL1($PIECE(X,U))_" "_$PIECE(X,U,2)
+11 ;now check for evidence of disease
IPVEVID ;
+1 ;V10.0 ICD10
+2 KILL BUDG
SET %=P_"^ALL DX;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
+3 SET T=$ORDER(^BUDCTSSC("B","EVIDENCE IPV",0))
+4 SET X=0
SET G=""
FOR
SET X=$ORDER(BUDG(X))
IF X'=+X!(G]"")
QUIT
Begin DoDot:1
+5 SET Y=+$PIECE(BUDG(X),U,4)
+6 SET Y=$PIECE($GET(^AUPNVPOV(Y,0)),U,1)
+7 IF $DATA(^BUDCTSSC("AD",Y,T))
SET G="1^IPV Evidence "_$PIECE(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(X),U))
End DoDot:1
+8 IF G]""
QUIT G
+9 SET X=$$PLCL^BUDCDU(P,"EVIDENCE IPV")
IF X
QUIT "1^IPV Evidence: "_$PIECE(X,U,2)_" on Problem List"
+10 KILL BUDC,BUDG,BUDX
+11 KILL BUDOPV,BUDAPOV
IPVIMM ;get all immunizations
+1 SET C="2^10^89^110^120^130^132^146"
+2 KILL BUDX
DO GETIMMS(P,BDATE,EDATE,C,.BUDX)
+3 ;now get cpt codes
+4 SET X=0
FOR
SET X=$ORDER(BUDX(X))
IF X'=+X
QUIT
SET BUDOPV(X)=BUDX(X)
SET BUDAPOV(X)=BUDX(X)
+5 ;now get cpts
+6 SET ED=9999999-EDATE
SET BD=9999999-BDATE
SET G=0
+7 FOR
SET ED=$ORDER(^AUPNVSIT("AA",P,ED))
IF ED=""!($PIECE(ED,".")>BD)
QUIT
Begin DoDot:1
+8 SET V=0
FOR
SET V=$ORDER(^AUPNVSIT("AA",P,ED,V))
IF V'=+V
QUIT
Begin DoDot:2
+9 IF '$DATA(^AUPNVSIT(V,0))
QUIT
+10 SET X=0
FOR
SET X=$ORDER(^AUPNVCPT("AD",V,X))
IF X'=+X
QUIT
Begin DoDot:3
+11 SET Y=$PIECE(^AUPNVCPT(X,0),U)
SET Y=$PIECE($$CPT^ICPTCOD(Y),U,2)
Begin DoDot:4
+12 IF Y=90698!(Y=90713)!(Y=90723)
SET BUDOPV(9999999-$PIECE(ED,"."))="CPT: "_Y_" on "_$$DATE^BUDCUTL1((9999999-$PIECE(ED,".")))
SET BUDAPOV(9999999-$PIECE(ED,"."))="CPT: "_Y_" on "_$$DATE^BUDCUTL1((9999999-$PIECE(ED,".")))
End DoDot:4
End DoDot:3
+13 SET X=0
FOR
SET X=$ORDER(^AUPNVTC("AD",V,X))
IF X'=+X
QUIT
Begin DoDot:3
+14 SET Y=$PIECE(^AUPNVTC(X,0),U,7)
IF 'Y
QUIT
SET Y=$PIECE($$CPT^ICPTCOD(Y),U,2)
Begin DoDot:4
+15 IF Y=90698!(Y=90713)!(Y=90723)
SET BUDOPV(9999999-$PIECE(ED,"."))="CPT: "_Y_" on "_$$DATE^BUDCUTL1((9999999-$PIECE(ED,".")))
SET BUDAPOV(9999999-$PIECE(ED,"."))="CPT: "_Y_" on "_$$DATE^BUDCUTL1((9999999-$PIECE(ED,".")))
End DoDot:4
End DoDot:3
End DoDot:2
End DoDot:1
+16 ;now check to see if they are all spaced 10 days apart, if not, kill off the odd ones
+17 SET (X,Y)=""
SET C=0
FOR
SET X=$ORDER(BUDOPV(X))
IF X'=+X
QUIT
SET C=C+1
Begin DoDot:1
+18 IF C=1
SET Y=X
QUIT
+19 IF $$FMDIFF^XLFDT(X,Y)<11
KILL BUDOPV(X)
QUIT
+20 SET Y=X
End DoDot:1
+21 ;now count them and see if there are 4 of them
+22 SET BUDOPV=0
SET X=0
FOR
SET X=$ORDER(BUDOPV(X))
IF X'=+X
QUIT
SET BUDOPV=BUDOPV+1
+23 IF BUDOPV>2
SET Y="1^IPV: total #: "_BUDOPV
SET X=""
FOR
SET X=$ORDER(BUDOPV(X))
IF X'=+X
QUIT
SET Y=Y_" "_BUDOPV(X)
+24 IF BUDOPV>2
QUIT Y
+25 ;now get povs
+26 KILL BUDOPV
MERGE BUDOPV=BUDAPOV
+27 IF $DATA(BUDG(1))
SET X=0
FOR
SET X=$ORDER(BUDG(X))
IF X'=+X
QUIT
SET BUDOPV($PIECE(BUDG(X),U))="POV: "_$PIECE(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
SET BUDAOPV($PIECE(BUDG(X),U))="POV: "_$PIECE(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
+28 KILL BUDG
SET %=P_"^ALL PROCEDURE 99.41;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
+29 IF $DATA(BUDG(1))
SET X=0
FOR
SET X=$ORDER(BUDG(X))
IF X'=+X
QUIT
SET BUDOPV($PIECE(BUDG(X),U))="Procedure: "_$PIECE(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
SET BUDAPOV($PIECE(BUDG(X),U))="Procedure: "_$PIECE(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
+30 ;now check to see if they are all spaced 10 days apart, if not, kill off the odd ones
+31 SET (X,Y)=""
SET C=0
FOR
SET X=$ORDER(BUDOPV(X))
IF X'=+X
QUIT
SET C=C+1
Begin DoDot:1
+32 IF C=1
SET Y=X
QUIT
+33 IF $$FMDIFF^XLFDT(X,Y)<11
KILL BUDOPV(X)
QUIT
+34 SET Y=X
End DoDot:1
+35 ;now count them and see if there are 4 of them
+36 SET BUDOPV=0
SET X=0
FOR
SET X=$ORDER(BUDOPV(X))
IF X'=+X
QUIT
SET BUDOPV=BUDOPV+1
+37 IF BUDOPV>2
SET Y="1^IPV: total #: "_BUDOPV
SET X=""
FOR
SET X=$ORDER(BUDOPV(X))
IF X'=+X
QUIT
SET Y=Y_" "_BUDOPV(X)
+38 IF BUDOPV>2
QUIT Y
+39 QUIT "0^"_(3-BUDOPV)_" IPV"
+40 ;
MMR(P,BDATE,EDATE) ;EP
+1 ;first check for contraindications
+2 ;dx first
MMRC ;
+1 NEW BUDG,%,X,BUDZ,BUDC,BUDX,G,N,T,Y,E
+2 ;V10.0 ICD10
+3 KILL BUDG
SET %=P_"^ALL DX;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
+4 SET T=$ORDER(^BUDCTSSC("B","CONTRA VARICELLA/MMR",0))
+5 SET X=0
SET G=""
FOR
SET X=$ORDER(BUDG(X))
IF X'=+X!(G]"")
QUIT
Begin DoDot:1
+6 SET Y=+$PIECE(BUDG(X),U,4)
+7 SET Y=$PIECE($GET(^AUPNVPOV(Y,0)),U,1)
+8 IF $DATA(^BUDCTSSC("AD",Y,T))
SET G="1^MMR CONTRA DX "_$PIECE(BUDG(X),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(X),U))
End DoDot:1
+9 IF G]""
QUIT G
+10 SET X=$$PLCL^BUDCDU(P,"CONTRA VARICELLA/MMR")
IF X
QUIT "1^MMR CONTRA DX: "_$PIECE(X,U,2)_" on Problem List"
+11 SET G=""
+12 SET X=0
FOR
SET X=$ORDER(^GMR(120.8,"B",P,X))
IF X'=+X!(G)
QUIT
Begin DoDot:1
+13 ;Q:$P($P($G(^GMR(120.8,X,0)),U,4),".")>EDATE ;entered after 2ND birthday
+14 SET N=$PIECE($GET(^GMR(120.8,X,0)),U,2)
SET N=$$UP^XLFSTR(N)
+15 ;quit if anaphylactic is not a reaction/sign/symptom
IF '$$ANAREACT(X)
QUIT
+16 IF N["NEOMYCIN"
SET G="1^MMR Contraindiction: "_$$DATE^BUDCUTL1($PIECE($PIECE($GET(^GMR(120.8,X,0)),U,4),"."))_" Allergy Tracking: "_N
End DoDot:1
+17 IF G]""
QUIT G
+18 FOR BUDZ=3,94,5,7,6
SET X=$$MMRCONT(P,BUDZ,EDATE)
IF X]""
QUIT
+19 IF X]""
QUIT "1^MMR Contraindication: "_$PIECE(X,U,2)_" on "_$$DATE^BUDCUTL1($PIECE(X,U,1))_" Immunization Package"
MMREVID ;
+1 ;
MMRI ;
+1 KILL BUDC,BUDG,BUDX
+2 KILL ^TMP($JOB,"CPT")
+3 ;set to null for all
SET (BUDMMR,BUDMUMPS,BUDRUB,BUDMEAS)=""
+4 ;first gather up all cpt codes that relate in any way to MMR and store in ^TMP
+5 SET ED=9999999-EDATE
SET BD=9999999-BDATE
SET G=0
+6 FOR
SET ED=$ORDER(^AUPNVSIT("AA",P,ED))
IF ED=""!($PIECE(ED,".")>BD)
QUIT
Begin DoDot:1
+7 SET V=0
FOR
SET V=$ORDER(^AUPNVSIT("AA",P,ED,V))
IF V'=+V
QUIT
Begin DoDot:2
+8 IF '$DATA(^AUPNVSIT(V,0))
QUIT
+9 IF '$DATA(^AUPNVCPT("AD",V))
QUIT
+10 SET X=0
FOR
SET X=$ORDER(^AUPNVCPT("AD",V,X))
IF X'=+X
QUIT
Begin DoDot:3
+11 SET Y=$PIECE(^AUPNVCPT(X,0),U)
SET Y=$PIECE($$CPT^ICPTCOD(Y),U,2)
IF Y=+Y
IF $TEXT(@Y)]""
SET ^TMP($JOB,"CPT",9999999-$PIECE(ED,"."),Y)=""
End DoDot:3
End DoDot:2
End DoDot:1
+12 ;get all immunizations
+13 SET C="3^94"
+14 ;before 2nd birthday
KILL BUDX
DO GETIMMS(P,BDATE,EDATE,C,.BUDX)
+15 ;HAD 1 MMR
IF $DATA(BUDX)
SET D=$ORDER(BUDX(0))
QUIT "1^MMR "_BUDX(D)
+16 SET D=0
FOR
SET D=$ORDER(^TMP($JOB,"CPT",D))
IF D'=+D
QUIT
SET Y=""
FOR
SET Y=$ORDER(^TMP($JOB,"CPT",D,Y))
IF Y=""
QUIT
Begin DoDot:1
+17 IF Y=90707!(Y=90710)!(Y=90708)
SET BUDMMR="CPT: "_Y_" on "_$$DATE^BUDCUTL1(D)
End DoDot:1
+18 IF BUDMMR]""
QUIT "1^MMR "_BUDMMR
+19 ;
+20 ;K BUDG S %=P_"^ALL PROCEDURE 99.45;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
+21 ;I $D(BUDG(1)) Q "1^MMR PROCEDURE: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($P(BUDG(1),U))
+22 ;now check individuals
MR ;see if one M/R, Mumps or R/M
+1 SET BUDVALUE=""
ME SET C=5
+1 KILL BUDX
DO GETIMMS(P,BDATE,EDATE,C,.BUDX)
+2 IF $DATA(BUDX)
SET BUDMEAS=1
SET D=$ORDER(BUDX(0))
SET BUDVALUE=BUDVALUE_" MEASLES "_BUDX(D)
+3 SET D=0
FOR
SET D=$ORDER(^TMP($JOB,"CPT",D))
IF D'=+D
QUIT
SET Y=""
FOR
SET Y=$ORDER(^TMP($JOB,"CPT",D,Y))
IF Y=""
QUIT
Begin DoDot:1
+4 IF Y=90705!(Y=90708)
SET BUDMEAS=1
SET BUDVALUE=BUDVALUE_" MEASLES CPT "_Y_" on "_$$DATE^BUDCUTL1(D)
End DoDot:1
+5 KILL BUDG
SET %=P_"^ALL PROCEDURE 99.45;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
+6 IF $DATA(BUDG(1))
SET BUDMEAS=1
SET BUDVALUE=BUDVALUE_" MEASLES PROCEDURE: "_$PIECE(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
+7 IF BUDMEAS=""
KILL BUDG
SET %=P_"^LAST DX [BGP MEASLES EVIDENCE;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
IF $DATA(BUDG(1))
SET BUDMEAS=1
SET BUDVALUE=BUDVALUE_" MEASLES EVIDENCE DX: "_$PIECE(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
+8 IF BUDMEAS=""
SET X=$$PLTAX^BUDCDU(P,"BGP MEASLES EVIDENCE")
IF X
SET BUDMEAS=1
SET BUDVALUE=BUDVALUE_" MEASLES EVIDENCE PROB LIST: "_$PIECE(X,U,2)
+9 IF BUDMEAS
IF BUDMUMPS
IF BUDRUB
QUIT "1^"_BUDVALUE
MU SET C=7
+1 DO GETIMMS(P,BDATE,EDATE,C,.BUDX)
+2 IF $DATA(BUDX)
SET BUDMUMPS=1
SET D=$ORDER(BUDX(0))
SET BUDVALUE=BUDVALUE_" MUMPS "_BUDX(D)
+3 SET D=0
FOR
SET D=$ORDER(^TMP($JOB,"CPT",D))
IF D'=+D
QUIT
SET Y=""
FOR
SET Y=$ORDER(^TMP($JOB,"CPT",D,Y))
IF Y=""
QUIT
Begin DoDot:1
+4 IF Y=90704!(Y=90710)
SET BUDMUMPS=1
SET BUDVALUE=BUDVALUE_" MUMPS CPT "_Y_" on "_$$DATE^BUDCUTL1(D)
End DoDot:1
+5 KILL BUDG
SET %=P_"^ALL PROCEDURE 99.46;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
+6 IF $DATA(BUDG(1))
SET BUDMUMPS=1
SET BUDVALUE=BUDVALUE_" MUMPS PROCEDURE: "_$PIECE(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
+7 IF BUDMUMPS=""
KILL BUDG
SET %=P_"^LAST DX [BGP MUMPS EVIDENCE;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
IF $DATA(BUDG(1))
SET BUDMUMPS=1
SET BUDVALUE=BUDVALUE_" MUMPS EVIDENCE DX: "_$PIECE(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
+8 IF BUDMUMPS=""
SET X=$$PLTAX^BUDCDU(P,"BGP MUMPS EVIDENCE")
IF X
SET BUDMUMPS=1
SET BUDVALUE=BUDVALUE_" MUMPS EVIDENCE PROB LIST: "_$PIECE(X,U,2)
+9 IF BUDMEAS
IF BUDMUMPS
IF BUDRUB
QUIT "1^"_BUDVALUE
RUB SET C=6
+1 DO GETIMMS(P,BDATE,EDATE,C,.BUDX)
+2 IF $DATA(BUDX)
SET BUDRUB=1
SET D=$ORDER(BUDX(0))
SET BUDVALUE=BUDVALUE_" RUBELLA "_BUDX(D)
+3 SET D=0
FOR
SET D=$ORDER(^TMP($JOB,"CPT",D))
IF D'=+D
QUIT
SET Y=""
FOR
SET Y=$ORDER(^TMP($JOB,"CPT",D,Y))
IF Y=""
QUIT
Begin DoDot:1
+4 IF Y=90706!(Y=90707)!(Y=90708)!(Y=90710)
SET BUDRUB=1
SET BUDVALUE=BUDVALUE_" RUBELLA CPT "_Y_" on "_$$DATE^BUDCUTL1(D)
End DoDot:1
+5 KILL BUDG
SET %=P_"^ALL PROCEDURE 99.47;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
+6 IF $DATA(BUDG(1))
SET BUDRUB=1
SET BUDVALUE=BUDVALUE_" RUBELLA PROCEDURE: "_$PIECE(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
+7 IF BUDRUB=""
KILL BUDG
SET %=P_"^LAST DX [BGP RUBELLA EVIDENCE;DURING "_BDATE_"-"_EDATE
SET E=$$START1^APCLDF(%,"BUDG(")
IF $DATA(BUDG(1))
SET BUDRUB=1
SET BUDVALUE=BUDVALUE_" RUBELLA EVIDENCE DX: "_$PIECE(BUDG(1),U,2)_" on "_$$DATE^BUDCUTL1($PIECE(BUDG(1),U,1))
+8 IF BUDRUB=""
SET X=$$PLTAX^BUDCDU(P,"BGP RUBELLA EVIDENCE")
IF X
SET BUDRUB=1
SET BUDVALUE=BUDVALUE_" RUBELLA EVIDENCE PROB LIST: "_$PIECE(X,U,2)
+9 IF BUDMEAS
IF BUDMUMPS
IF BUDRUB
QUIT "1^"_BUDVALUE
+10 IF 'BUDMEAS
IF 'BUDMUMPS
IF 'BUDRUB
QUIT "0^1 MEASLES MUMPS RUBBELLA"
+11 QUIT "0^"_$SELECT('BUDMEAS:" 1 MEASLES",1:"")_$SELECT('BUDMUMPS:" 1 MUMPS",1:"")_$SELECT('BUDRUB:" 1 RUBELLA",1:"")
+12 ;
90707 ;;
90708 ;;
90710 ;;
90705 ;;
90704 ;;
90706 ;;