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

BUDHRP6X.m

Go to the documentation of this file.
  1. BUDHRP6X ; IHS/CMI/LAB - measure C ; 13 Jun 2018 4:06 PM
  1. ;;13.0;IHS/RPMS UNIFORM DATA SYSTEM;;OCT 12, 2018;Build 90
  1. ;
  1. CNTDTAP ;
  1. NEW X,Y,C
  1. S (X,Y)="",C=0 F S X=$O(BUDDTAP(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDDTAP(X) Q
  1. .S Y=X
  1. ;now count
  1. S BUDDTAP=0,X=0 F S X=$O(BUDDTAP(X)) Q:X'=+X S BUDDTAP=BUDDTAP+1
  1. Q
  1. RESETD ;RESET DUPES
  1. NEW X,Y,C
  1. S (X,Y)="",C=0 F S X=$O(BUDDT(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDDT(X) Q
  1. .S Y=X
  1. S (X,Y)="",C=0 F S X=$O(BUDDIP(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDDIP(X) Q
  1. .S Y=X
  1. S (X,Y)="",C=0 F S X=$O(BUDTET(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDTET(X) Q
  1. .S Y=X
  1. S (X,Y)="",C=0 F S X=$O(BUDTD(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDTD(X) Q
  1. .S Y=X
  1. S (X,Y)="",C=0 F S X=$O(BUDPER(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDPER(X) Q
  1. .S Y=X
  1. S BUDDT=0,X=0 F S X=$O(BUDDT(X)) Q:X'=+X S BUDDT=BUDDT+1
  1. S BUDTD=0,X=0 F S X=$O(BUDTD(X)) Q:X'=+X S BUDTD=BUDTD+1
  1. S BUDDIP=0,X=0 F S X=$O(BUDDIP(X)) Q:X'=+X S BUDDIP=BUDDIP+1
  1. S BUDTET=0,X=0 F S X=$O(BUDTET(X)) Q:X'=+X S BUDTET=BUDTET+1
  1. S BUDPER=0,X=0 F S X=$O(BUDPER(X)) Q:X'=+X S BUDPER=BUDPER+1
  1. Q
  1. DTAP(P,BDATE,EDATE) ;EP
  1. NEW BUDTET,BUDVS,TIEN,TIENDT,TIENTET,TIENDIP,TIENPER,CTR,VIEN,VDATE,X,Y,BUDX,BUDDT,BUDADT,BUDDIP,BUDPER,BUDDTAP,BUDPEREV,BUDHVTD,BUDHVIP,BUDCOTET,BUDCOPER,BUDCODIP,C,BUDG,BUDA,Z,G,A
  1. ;
  1. DTAPIM ;
  1. S BUDTET=0
  1. D ALLV^APCLAPIU(P,BDATE,EDATE,"BUDVS") ;all visits in 42 days to end
  1. S TIEN=$O(^BUDHTSSC("B","T6B IMM DTAP CODES",0))
  1. S TIENDT=$O(^BUDHTSSC("B","T6B IMM DT CODES",0))
  1. S TIENTET=$O(^BUDHTSSC("B","T6B IMM TETANUS CODES",0))
  1. S TIENDIP=$O(^BUDHTSSC("B","T6B IMM DIPHTHERIA CODES",0))
  1. S TIENPER=$O(^BUDHTSSC("B","T6B IMM PERTUSSIS CODES",0))
  1. S CTR=0 F S CTR=$O(BUDVS(CTR)) Q:CTR'=+CTR D
  1. .S VIEN=$P(BUDVS(CTR),U,5)
  1. .S VDATE=$P(BUDVS(CTR),U,1)
  1. .S X=0 F S X=$O(^AUPNVIMM("AD",VIEN,X)) Q:X'=+X D
  1. ..Q:'$D(^AUPNVIMM(X,0))
  1. ..S Y=$$VALI^XBDIQ1(9000010.11,X,.01)
  1. ..S Y=+$P($G(^AUTTIMM(Y,0)),U,3)
  1. ..Q:'Y
  1. ..I $D(^BUDHTSSC(TIEN,15,"B",Y)) S BUDX(VDATE)="CVX "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC(TIENDT,15,"B",Y)) S BUDDT(VDATE)="CVX "_Y_" on "_$$DATE^BUDHUTL1(VDATE),BUDADT(VDATE)="CVX "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC(TIENTET,15,"B",Y)) S BUDTET(VDATE)="CVX "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC(TIENDIP,15,"B",Y)) S BUDDIP(VDATE)="CVX "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC(TIENPER,15,"B",Y)) S BUDPER(VDATE)="CVX "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. .;CPT
  1. .S X=0 F S X=$O(^AUPNVCPT("AD",VIEN,X)) Q:X'=+X D
  1. ..Q:'$D(^AUPNVCPT(X,0))
  1. ..S Y=$$VAL^XBDIQ1(9000010.18,X,.01)
  1. ..Q:Y=""
  1. ..I $D(^BUDHTSSC("AC",Y,TIEN)) S BUDX(VDATE)="CPT "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AC",Y,TIENDT)) S BUDDT(VDATE)="CPT "_Y_" on "_$$DATE^BUDHUTL1(VDATE),BUDADT(VDATE)="CPT "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AC",Y,TIENTET)) S BUDTET(VDATE)="CPT "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AC",Y,TIENDIP)) S BUDDIP(VDATE)="CPT "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AC",Y,TIENPER)) S BUDPER(VDATE)="CPT "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. .;V TRANS
  1. .S X=0 F S X=$O(^AUPNVTC("AD",VIEN,X)) Q:X'=+X D
  1. ..Q:'$D(^AUPNVTC(X,0))
  1. ..S Y=$$VAL^XBDIQ1(9000010.33,X,.07)
  1. ..Q:Y=""
  1. ..I $D(^BUDHTSSC("AC",Y,TIEN)) S BUDX(VDATE)="CPT/TRAN "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AC",Y,TIENDT)) S BUDDT(VDATE)="CPT/TRAN "_Y_" on "_$$DATE^BUDHUTL1(VDATE),BUDADT(VDATE)="CPT/TRAN "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AC",Y,TIENTET)) S BUDTET(VDATE)="CPT/TRAN "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AC",Y,TIENDIP)) S BUDDIP(VDATE)="CPT/TRAN "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AC",Y,TIENPER)) S BUDPER(VDATE)="CPT/TRAN "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. .;V PROC
  1. .S X=0 F S X=$O(^AUPNVPRC("AD",VIEN,X)) Q:X'=+X D
  1. ..Q:'$D(^AUPNVPRC(X,0))
  1. ..S Y=$$VALI^XBDIQ1(9000010.08,X,.01)
  1. ..I $D(^BUDHTSSC("AP",Y,TIEN)) S BUDX(VDATE)="PROC "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AP",Y,TIENDT)) S BUDDT(VDATE)="PROC "_Y_" on "_$$DATE^BUDHUTL1(VDATE),BUDADT(VDATE)="PROC "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AP",Y,TIENTET)) S BUDTET(VDATE)="PROC "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AP",Y,TIENDIP)) S BUDDIP(VDATE)="PROC "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AP",Y,TIENPER)) S BUDPER(VDATE)="PROC "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. .S X=0 F S X=$O(^AUPNVPOV("AD",VIEN,X)) Q:X'=+X D
  1. ..Q:'$D(^AUPNVPOV(X,0))
  1. ..S Y=$$VAL^XBDIQ1(9000010.07,X,1101)
  1. ..Q:Y=""
  1. ..I $D(^BUDHTSSC("AS",Y,TIEN)) S BUDX(VDATE)="SNOMED "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AS",Y,TIENDT)) S BUDDT(VDATE)="SNOMED "_Y_" on "_$$DATE^BUDHUTL1(VDATE),BUDADT(VDATE)="SNOMED "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AS",Y,TIENTET)) S BUDTET(VDATE)="SNOMED "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AS",Y,TIENDIP)) S BUDDIP(VDATE)="SNOMED "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ..I $D(^BUDHTSSC("AS",Y,TIENPER)) S BUDPER(VDATE)="SNOMED "_Y_" on "_$$DATE^BUDHUTL1(VDATE) Q
  1. ;go through and set into DTAP if 10 days apart
  1. S X=0 F S X=$O(BUDX(X)) Q:X'=+X S BUDDTAP(X)=BUDX(X)
  1. D CNTDTAP ;count to see if there are 4
  1. I BUDDTAP>3 S Y="1^DTap: total #: "_BUDDTAP,X=0 F S X=$O(BUDDTAP(X)) Q:X'=+X S Y=Y_" "_BUDDTAP(X)
  1. I BUDDTAP>3 Q Y
  1. S (BUDPEREV,BUDHVTD,BUDHVDIP,BUDCOTET,BUDCOPER,BUDCODIP)=""
  1. ;now check contra to DTap
  1. S Y=$$CONTDTAP(P,$$DOB^AUPNPAT(P),EDATE)
  1. I Y Q Y
  1. DT1 ;
  1. ;kill off any that are on the same day as the dtaps
  1. S (X,Y)="",C=0 F S X=$O(BUDDT(X)) Q:X'=+X I $D(BUDDTAP(X)) K BUDDT(X)
  1. S (X,Y)="",C=0 F S X=$O(BUDDT(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDDT(X) Q
  1. .S Y=X
  1. K BUDALL
  1. S BUDDT=0,X=0 F S X=$O(BUDDT(X)) Q:X'=+X S BUDDT=BUDDT+1,BUDALL(X)=BUDDT(X)
  1. S BUDDTAP=0,X=0 F S X=$O(BUDDTAP(X)) Q:X'=+X S BUDDTAP=BUDDTAP+1,BUDALL(X)=BUDDTAP(X)
  1. S (X,Y)="",C=0 F S X=$O(BUDALL(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDALL(X) Q
  1. .S Y=X
  1. S BUDALL=0 S X=0 F S X=$O(BUDALL(X)) Q:X'=+X S BUDALL=BUDALL+1
  1. I BUDALL>3 D Q "1^"_Y
  1. .S Y=">=1 DTap & DT/TdS",X=0 F S X=$O(BUDDTAP(X)) Q:X'=+X S Y=Y_" "_BUDDTAP(X)
  1. .S X=0 F S X=$O(BUDDT(X)) Q:X'=+X S Y=Y_" "_BUDDT(X)
  1. ;
  1. TETCVX ;
  1. S BUDTET=0
  1. ;EVIDENCE?
  1. S BUDHVTD=""
  1. K BUDG S %=P_"^LAST DX 037.;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
  1. I $D(BUDG(1)) S BUDHVTD="1^Tetanus Evidence: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDHUTL1($P(BUDG(1),U))
  1. K BUDG S %=P_"^LAST DX A35.;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
  1. I $D(BUDG(1)) S BUDHVTD="1^Tetanus Evidence: "_$P(BUDG(1),U,2)_" on "_$$DATE^BUDHUTL1($P(BUDG(1),U))
  1. I $$PLCODE^BUDHDU(P,"037.",EDATE) S BUDHVTD="1^Tetanus Evidence: 037. on Problem List"
  1. I $$PLCODE^BUDHDU(P,"A35.",EDATE) S BUDHVTD="1^Tetanus Evidence: A35. on Problem List"
  1. S X=0 F S X=$O(BUDDT(X)) Q:X'=+X S BUDTET(X)=BUDDT(X)
  1. S X=0 F S X=$O(BUDDTAP(X)) Q:X'=+X S BUDTET(X)=BUDDTAP(X)
  1. S (X,Y)="",C=0 F S X=$O(BUDTET(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDTET(X) Q
  1. .S Y=X
  1. S X=0 F S X=$O(BUDTET(X)) Q:X'=+X S BUDTET=BUDTET+1
  1. DIP ;
  1. S BUDHVDIP=""
  1. ;V10.0 ICD10
  1. K BUDG S %=P_"^ALL DX;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
  1. S T=$O(^BUDHTSSC("B","T6B IMM EVIDENCE DIPHTHERIA",0))
  1. S X=0,BUDHVDIP="" F S X=$O(BUDG(X)) Q:X'=+X!(BUDHVDIP]"") D
  1. .S Y=+$P(BUDG(X),U,4)
  1. .S Y=$P($G(^AUPNVPOV(Y,0)),U,1)
  1. .I $D(^BUDHTSSC("AD",Y,T)) S BUDHVDIP="1^Diphtheria Evidence "_$P(BUDG(X),U,2)_" on "_$$DATE^BUDHUTL1($P(BUDG(X),U))
  1. S X=$$PLCL^BUDHDU(P,"T6B IMM EVIDENCE DIPHTHERIA",EDATE,0) I X S BUDHVDIP="1^Diphtheria Evidence: "_$P(X,U,2)_" on Problem List"
  1. S X=0 F S X=$O(BUDDT(X)) Q:X'=+X S BUDDIP(X)=BUDDT(X)
  1. S X=0 F S X=$O(BUDDTAP(X)) Q:X'=+X S BUDDIP(X)=BUDDTAP(X)
  1. S (X,Y)="",C=0 F S X=$O(BUDDIP(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDDIP(X) Q
  1. .S Y=X
  1. S X=0,BUDDIP=0 F S X=$O(BUDDIP(X)) Q:X'=+X S BUDDIP=BUDDIP+1
  1. ;
  1. PER ;
  1. S BUDPEREV=""
  1. ;V10.0 ICD10
  1. K BUDG S %=P_"^ALL DX;DURING "_BDATE_"-"_EDATE,E=$$START1^APCLDF(%,"BUDG(")
  1. S T=$O(^BUDHTSSC("B","T6B IMM EVIDENCE PERTUSSIS",0))
  1. S X=0,BUDPEREV="" F S X=$O(BUDG(X)) Q:X'=+X!(BUDPEREV]"") D
  1. .S Y=+$P(BUDG(X),U,4)
  1. .S Y=$P($G(^AUPNVPOV(Y,0)),U,1)
  1. .I $D(^BUDHTSSC("AD",Y,T)) S BUDPEREV="1^Pertussis: Evidence "_$P(BUDG(X),U,2)_" on "_$$DATE^BUDHUTL1($P(BUDG(X),U))
  1. S X=$$PLCL^BUDHDU(P,"T6B IMM EVIDENCE PERTUSSIS",EDATE,0) I X S BUDPEREV="1^Pertussis: Evidence "_$P(X,U,2)_" on Problem List"
  1. S X=0 F S X=$O(BUDDTAP(X)) Q:X'=+X S BUDPER(X)=BUDDTAP(X)
  1. S (X,Y)="",C=0 F S X=$O(BUDPER(X)) Q:X'=+X S C=C+1 D
  1. .I C=1 S Y=X Q
  1. .I $$FMDIFF^XLFDT(X,Y)<11 K BUDPER(X) Q
  1. .S Y=X
  1. S X=0,BUDPER=0 F S X=$O(BUDPER(X)) Q:X'=+X S BUDPER=BUDPER+1
  1. I BUDPER<4,'BUDPEREV S BUDCOPER=$$CONTRA^BUDHRP6C(P,$$DOB^AUPNPAT(P),EDATE,$O(^BUDHTSSC("B","T6B IMM PERTUSSIS CODES",0)),"PERTUSSIS")
  1. I BUDDIP<4,'BUDHVDIP S BUDCODEP=$$CONTRA^BUDHRP6C(P,$$DOB^AUPNPAT(P),EDATE,$O(^BUDHTSSC("B","T6B IMM DIPHTHERIA CODES",0)),"DIPHTHERIA")
  1. I BUDTET<4,'BUDHVTD S BUDCOTET=$$CONTRA^BUDHRP6C(P,$$DOB^AUPNPAT(P),EDATE,$O(^BUDHTSSC("B","T6B IMM TETANUS CODES",0)),"TETANUS")
  1. CHK ;4 of each or evidence
  1. S BUDA(1)=$P(BUDHVDIP,U)_U_"DIP: Evidence"_U_$P(BUDHVDIP,U,2)
  1. S X=0,Y="" F S X=$O(BUDDIP(X)) Q:X'=+X S Y=Y_" "_BUDDIP(X)
  1. S BUDA(2)=$S(BUDDIP>3:1,1:0)_U_"DIP: total #: 4"_U_Y
  1. S BUDA(3)=$P(BUDCODIP,U)_U_"DIP: CONTRA"_U_$P(BUDCODIP,U,2)
  1. ;
  1. S BUDA(4)=$P(BUDHVTD,U)_U_"Tetanus: Evidence"_U_$P(BUDHVTD,U,2)
  1. S X=0,Y="" F S X=$O(BUDETT(X)) Q:X'=+X S Y=Y_" "_BUDTET(X)
  1. S BUDA(5)=$S(BUDTET>3:1,1:0)_U_"Tetanus: total #: 4"_U_Y
  1. S BUDA(6)=$P(BUDCOTET,U)_U_"Tetanus: CONTRA"_U_$P(BUDCOTET,U,2)
  1. ;
  1. S BUDA(7)=$P(BUDPEREV,U)_U_"Perussis: Evidence"_U_$P(BUDPEREV,U,2)
  1. S X=0,Y="" F S X=$O(BUDPER(X)) Q:X'=+X S Y=Y_" "_BUDPER(X)
  1. S BUDA(8)=$S(BUDPER>3:1,1:0)_U_"Pertussis: total #: 4"_U_Y
  1. S BUDA(9)=$P(BUDCOPER,U)_U_"Pertussis: CONTRA"_U_$P(BUDCOPER,U,2)
  1. ;
  1. S G=""
  1. F X=1,2,3 D Q:G]""
  1. .F Y=4,5,6 D Q:G]""
  1. ..F Z=7,8,9 D Q:G]""
  1. ...I $P(BUDA(X),U,1),$P(BUDA(Y),U,1),$P(BUDA(Z),U,1) D
  1. ....S G=1_U_$P(BUDA(X),U,2)_", "_$P(BUDA(Y),U,2)_", "_$P(BUDA(Z),U,2)
  1. ....S A="",A=$P(BUDA(X),U,3)_", "_$P(BUDA(Y),U,3)_", "_$P(BUDA(Z),U,3)
  1. ....S G=G_" "_A
  1. I G]"" Q G
  1. S Y="0^"
  1. I BUDDIP<4,'BUDHVDIP S Y=Y_(4-BUDDIP)_" DIP "
  1. I BUDTET<4,'BUDHVTD S Y=Y_(4-BUDTET)_" TET "
  1. I BUDPER<4,'BUDPEREV S Y=Y_(4-BUDPER)_" PER"
  1. Q Y
  1. CONTDTAP(P,BDATE,EDATE) ;
  1. NEW BUDG,X,G,Z,E,%,T,S,BUDZ
  1. ;
  1. ;CONTRA ALL VACCINES
  1. S X=$$CONTRA^BUDHRP6C(P,$$DOB^AUPNPAT(P),EDATE,$O(^BUDHTSSC("B","T6B IMM DTAP CODES",0)),"DTAP")
  1. I X Q X
  1. ;
  1. ;CONTRA IMM PKG ANAPHYLACTIC
  1. ;ANALPHYLAXIS IMM PKG
  1. S BUDZ=0,X=""
  1. S T=$O(^BUDHTSSC("B","T6B IMM DTAP CODES",0))
  1. F S BUDZ=$O(^BUDHTSSC(T,15,"B",BUDZ)) Q:BUDZ=""!(X]"") S X=$$ANALCONT^BUDHRP6C(P,BUDZ,EDATE) ;ANALPHYLAXIS
  1. I X]"" Q "1^DTAP: CONTRA IMM package: "_$$DATE^BUDHUTL1($P(X,U))_" "_$P(X,U,2)
  1. ;
  1. ;SNOMED ANALPHALACTIC V POV OR PROBLEM LIST?
  1. S T=$O(^BUDHTSSC("B","T6B IMM CONTRA DTAP",0))
  1. S (X,Y,I)=0
  1. F S X=$O(^AUPNPROB("AC",P,X)) Q:X'=+X!(I) D
  1. .Q:'$D(^AUPNPROB(X,0))
  1. .Q:$P(^AUPNPROB(X,0),U,12)="D"
  1. .I $P(^AUPNPROB(X,0),U,13),$P(^AUPNPROB(X,0),U,13)>EDATE Q ;if there is a doo and it is after report period skip
  1. .I $P(^AUPNPROB(X,0),U,13)="",$P(^AUPNPROB(X,0),U,8)>EDATE Q ;entered after report period, skip
  1. .S S=$$VAL^XBDIQ1(9000011,X,80001)
  1. .I S]"",$D(^BUDHTSSC("AS",S,T)) S I="1^DTAP: CONTRA PL "_S Q
  1. .Q
  1. I I Q I
  1. ;NOW V POV SNOMED
  1. S G="",I=""
  1. S S="" F S S=$O(^AUPNVPOV("ASNC",P,S)) Q:S=""!(G) D
  1. .S I=0
  1. .I $D(^BUDHTSSC("AS",S,T)) S I="1^DTAP: CONTRA POV "_S
  1. .Q:'I
  1. .S D=0 F S D=$O(^AUPNVPOV("ASNC",P,S,D)) Q:D=""!(G) D
  1. ..S Y=9999999-D
  1. ..Q:Y>EDATE
  1. ..S G=I_"^"_$$DATE^BUDHUTL1(Y)
  1. I G Q G
  1. N1 ;ENCEPHALOPATHY
  1. ;V POV OR PROBLEM LIST
  1. NEW X,Y,Z,G,T,S,D,BUDG,BUDZ
  1. S G=$$PLTAXND^BUDHDU(P,"BGP IPC IZ ENCEPHALOPATHY DXS",EDATE,0) I G Q "1^DTAP: CONTRA DX/SNOMED "_$P(G,U,2)_" on "_$$DATE^BUDHUTL1($P(G,U,3))
  1. S G=$$IPLSNOND^BUDHDU(P,"T6B IMM CONTRA ENCEPH",EDATE,0) I G Q "1^DTAP: CONTRA DX/SNOMED "_$P(G,U,2)_" on "_$$DATE^BUDHUTL1($P(G,U,3))
  1. S G=$$LASTDX^BUDHUTL1(P,"BGP IPC IZ ENCEPHALOPATHY DXS",$$DOB^AUPNPAT(P),EDATE) I G Q "1^DTAP: CONTRA DX/SNOMED "_$P(G,U,2)_" on "_$$DATE^BUDHUTL1($P(G,U,3))
  1. ;NOW V POV SNOMED
  1. ;NOW SNOMED USING ASNC
  1. S T=$O(^BUDHTSSC("B","T6B IMM CONTRA ENCEPH",0))
  1. S G=""
  1. S S=0 F S S=$O(^BUDHTSSC(T,13,"B",S)) Q:S=""!(G) D
  1. .Q:'$D(^AUPNVPOV("ASNC",P,S))
  1. .S D=0 F S D=$O(^AUPNVPOV("ASNC",P,S,D)) Q:D=""!(G) D
  1. ..S Y=9999999-D
  1. ..Q:Y>EDATE
  1. ..S G="1^DTAP: CONTRA DX/SNOMED "_S_" on "_$$DATE^BUDHUTL1(Y)
  1. Q G