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

APCM24E5.m

Go to the documentation of this file.
  1. APCM24E5 ;IHS/CMI/LAB - IHS MU;
  1. ;;1.0;IHS MU PERFORMANCE REPORTS;**5,6**;MAR 26, 2012;Build 65
  1. ;;;;;;Build 3
  1. PATEDUC ;EP - CALCULATE PAT ED
  1. ;for each provider or for the facility find out if this
  1. ;patient had a visit of A, O, R, S to this provider or facility
  1. ;if so, then check to see if they have PAT ED LITERATURE documented anytime before end of report period
  1. NEW APCMP
  1. S (APCMD1,APCMN1)=0
  1. I APCMRPTT=1 D Q
  1. .S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP D
  1. ..I $D(APCMOFFV(APCMP,APCMTIME)) S F=$P(^APCM24OB(APCMIC,0),U,11) D Q
  1. ...D S^APCM24E1(APCMRPT,APCMIC,"Provider is excluded from this measure as he/she did not have any office visits during the EHR Reporting Period.",APCMP,APCMRPTT,APCMTIME,F,1) Q
  1. ..Q:'$D(APCMPEVT(APCMP)) ;no visits to this provider for this patient so don't bother, the patient is not in the denominator
  1. ..;Q:'$D(APCMHVTP(APCMP))
  1. ..D PATEDUC1
  1. ..Q
  1. I APCMRPTT=2 D
  1. .S APCMP=APCMFAC
  1. .Q:'$D(APCMHVTP(APCMP))
  1. .D PATEDUC1
  1. .Q
  1. Q
  1. PATEDUC1 ;
  1. ;set denominator value into field
  1. S F=$P(^APCM24OB(APCMIC,0),U,8) ;denom field for this measure
  1. D S^APCM24E1(APCMRPT,APCMIC,1,APCMP,APCMRPTT,APCMTIME,F)
  1. ;numerator?
  1. S APCMVALU="VISIT: "_$$DATE^APCM1UTL(APCMHVTP(APCMP))
  1. ;S APCMEP=$$HASED(DFN,APCMBDAT,DT)
  1. ;S APCMEP=$$HASED(DFN,$$FMADD^XLFDT(APCMBDAT,-365),DT)
  1. ;I APCMRPTT=2 S APCMEP=$$HASEDH(DFN,APCMBDAT,APCMEDAT,APCMFAC,.APCMVSTS)
  1. NEW B
  1. I APCMRPTT=1 S B=$E(APCMBDAT,1,3)_"0101"
  1. I APCMRPTT=2 S B=$S(+$E(APCMBDAT,4,5)>9:$E(APCMBDAT,1,3)_"1001",1:$E(APCMBDAT,1,3)-1_"1001")
  1. S APCMEP=$$HASED(DFN,B,APCMEDAT)
  1. S APCMVALU=APCMVALU_"|||"_$P(APCMEP,U,2)_"|||"_$P(APCMEP,U,1)
  1. S F=$P(^APCM24OB(APCMIC,0),U,9)
  1. D S^APCM24E1(APCMRPT,APCMIC,$P(APCMEP,U,1),APCMP,APCMRPTT,APCMTIME,F)
  1. ;S APCMVALU=APCMVALU_"|||"_$P(APCMEP,U,2)_"|||"_$P(APCMEP,U,1)
  1. D SETLIST^APCM24E1
  1. Q
  1. ;
  1. HASED(P,BD,ED) ;does patient have Patient Ed -L
  1. ;
  1. NEW A,B,C,D,E,PED,Y,EDUC,X,T
  1. S C=0
  1. S PED=""
  1. S Y="EDUC("
  1. S X=P_"^ALL EDUC;DURING "_$$FMTE^XLFDT(BD)_"-"_$$FMTE^XLFDT(ED) S E=$$START1^APCLDF(X,Y)
  1. I '$D(EDUC(1)) Q ""
  1. S (X,D)=0,%="",T="" F S X=$O(EDUC(X)) Q:X'=+X!(PED]"") D
  1. .S T=$P(^AUPNVPED(+$P(EDUC(X),U,4),0),U)
  1. .Q:'T
  1. .Q:'$D(^AUTTEDT(T,0))
  1. .S T=$P(^AUTTEDT(T,0),U,2)
  1. .I $P(T,"-",2)="L" S PED=1_U_T_" on "_$$DATE^APCM1UTL($P(EDUC(X),U)) Q
  1. Q PED
  1. HASMMR(V) ;does patient have a m-mr ON this visit in v updated/reviewed
  1. ;
  1. NEW X,Y,Z
  1. S Z=""
  1. S X=0 F S X=$O(^AUPNVRUP("AD",V,X)) Q:X'=+X!(Z) D
  1. .S Y=0 F S Y=$O(^AUPNVRUP(X,26,Y)) Q:Y'=+Y!(Z) D
  1. ..I $P($G(^AUPNVRUP(X,26,Y,0)),U,1)=428191000124101 S Z=1
  1. Q Z
  1. PR ;EP - patient reminders
  1. ;if patinet seen 2 or more times in 24 months prior to bd and still alive on last day of reporting period
  1. ;exclude deceased, and inactive charts
  1. ;if so, then check to see if they have icare notice ocumented any time before end of report period
  1. NEW APCMP
  1. S (APCMD1,APCMN1)=0
  1. I APCMRPTT=1 S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP D
  1. .I $D(APCM24BR(APCMP)) S F=$P(^APCM24OB(APCMIC,0),U,11) D Q
  1. ..D S^APCM24E1(APCMRPT,APCMIC,"Provider is excluded from this measure as the EP did not have any office visits in 24 months before report period.",APCMP,APCMRPTT,APCMTIME,F,1) Q
  1. .;set denominator value into field
  1. .S G=0
  1. PR1 .;IS CHART ACTIVE OR DECEASED
  1. .S X=$$DOD^AUPNPAT(DFN)
  1. .I X,X'>APCMEDAT Q
  1. .Q:'$O(^AUPNPAT(DFN,41,0)) ;no charts
  1. .S X=$P($G(^AUPNPAT(DFN,41,DUZ(2),0)),U,3)
  1. .I X,X'>APCMEDAT Q
  1. .;2 visits w/EP in 24 months before EHR reporting period?
  1. .Q:'$$HADV(DFN,APCMP,$$FMADD^XLFDT(APCMBD,-(24*30.5)),$$FMADD^XLFDT(APCMBD,-1)) ;DIDN'T HAVE 2 VISITS
  1. .S F=$P(^APCM24OB(APCMIC,0),U,8) ;denom field for this measure
  1. .D S^APCM24E1(APCMRPT,APCMIC,1,APCMP,APCMRPTT,APCMTIME,F)
  1. .S APCMVALU=""
  1. .;numerator?
  1. .S APCMEP=$$HASRM(DFN,APCMBDAT,APCMEDAT)
  1. .S APCMVALU="|||"_"NOTIFICATION: "_$P(APCMEP,U,2)_"|||"_$P(APCMEP,U,1)
  1. .S F=$P(^APCM24OB(APCMIC,0),U,9)
  1. .D S^APCM24E1(APCMRPT,APCMIC,$P(APCMEP,U,1),APCMP,APCMRPTT,APCMTIME,F)
  1. .D SETLIST^APCM24E1
  1. Q
  1. HADV(P,R,BD,ED) ;EP - had visit of A, O, R, S with provider R in time frame BD-ED
  1. ;PATCH 1 excludes ER and case management clinics
  1. ;patch 1 provider must be primary only
  1. ; so, in summary, the patient must have at least 1 A,O,R,M, non-ER, non-case man visit
  1. ; where this provider is the primary provider
  1. I '$G(P) Q ""
  1. I '$G(R) Q ""
  1. I '$G(BD) Q ""
  1. I '$G(ED) Q ""
  1. I '$D(^AUPNPAT(P,0)) Q ""
  1. I '$D(^VA(200,R,0)) Q ""
  1. NEW V,X,Y,G,VSTS
  1. D ALLV^APCLAPIU(P,BD,ED,"VSTS")
  1. S G=0
  1. S X=0 F S X=$O(VSTS(X)) Q:X'=+X!(G>1) D
  1. .S V=$P(VSTS(X),U,5)
  1. .I '$D(^AUPNVSIT(V,0)) Q
  1. .I $P(^AUPNVSIT(V,0),U,11) Q ;deleted
  1. .I "AOSM"'[$P(^AUPNVSIT(V,0),U,7) Q ;not correct service category
  1. .S C=$$CLINIC^APCLV(V,"C")
  1. .I C=30 Q ;no ER per Carmen patch 1
  1. .I C=77 Q ;no case management clinic 77 per Chris
  1. .I C=76 Q ;no lab
  1. .I C=63 Q ;no radiology
  1. .I C=39 Q ;no pharmacy
  1. .S Y=$$PRIMPROV^APCLV(V,"I")
  1. .I 'Y Q
  1. .I Y'=R Q ;not this provider
  1. .S G=G+1
  1. I G>1 Q 1 ;2 or more?
  1. Q 0
  1. ;
  1. HASRM(P,BD,ED) ;
  1. ;
  1. NEW A,B,C,NOTIF,N
  1. S NOTIF=""
  1. S A=0 F S A=$O(^BQI(90509.4,"B",P,A)) Q:A'=+A!(NOTIF) D
  1. .S N=$G(^BQI(90509.4,A,0))
  1. .I N="" Q ;BAD XREF
  1. .S B=$P($P(N,U,4),".")
  1. .Q:B<BD ;before time period
  1. .Q:B>ED ;after time period
  1. .S C=$P(N,U,2) ;preferred method
  1. .I C="" S NOTIF=1_U_$$GET1^DIQ(90509.4,A,.09)_" "_$$FMTE^XLFDT(B) Q
  1. .I C'=$P(N,U,3) ;preferred doesn't match notificaton type so don't count it
  1. .S NOTIF=1_U_$$GET1^DIQ(90509.4,A,.09)_" "_$$FMTE^XLFDT(B)
  1. Q NOTIF
  1. SC ;EP - TRANSITION OF CARE SUMMARY
  1. ;for each provider count each Visit that HAS a v referral
  1. K ^TMP($J,"TRANS")
  1. NEW APCMLABS,MMR
  1. D TOCSUMC
  1. NEW APCMP,N,F,O,Y
  1. S (APCMD1,APCMN1)=0
  1. I APCMRPTT=1 S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP D
  1. .I $P($G(MMR(APCMP)),U,1)<100 D
  1. ..S F=$P(^APCM24OB(APCMIC,0),U,11) D S^APCM24E1(APCMRPT,APCMIC,"Provider is excluded from this measure as he/she had less than 100 referrals during the EHR reporting period.",APCMP,APCMRPTT,APCMTIME,F,1)
  1. ..;now get all related measures
  1. ..S O=0 F S O=$O(^APCM24OB(APCMIC,29,O)) Q:O'=+O S Y=$P(^APCM24OB(APCMIC,29,O,0),U,1),Y=$O(^APCM24OB("B",Y,0)) I Y D
  1. ...S F=$P(^APCM24OB(Y,0),U,11) D S^APCM24E1(APCMRPT,Y,"X",APCMP,APCMRPTT,APCMTIME,F,1)
  1. .;set value for measure 3
  1. .S Y=$O(^APCM24OB("B","S2.023.2.EP",0))
  1. .S F=$P(^APCM24OB(Y,0),U,8) D S^APCM24E1(APCMRPT,Y,APCMATTE("S2.023.EP",APCMP),APCMP,APCMRPTT,APCMTIME,F)
  1. .;set denominator value into field FOR measure 1
  1. .S F=$P(^APCM24OB(APCMIC,0),U,8) ;denom field for this measure
  1. .S N=$P($G(MMR(APCMP)),U,1) ;returns # of transS^# with mmr
  1. .D S^APCM24E1(APCMRPT,APCMIC,N,APCMP,APCMRPTT,APCMTIME,F)
  1. .;now set patient list for this provider
  1. .S P=0 F S P=$O(^TMP($J,"TRANS",APCMP,P)) Q:P'=+P D
  1. ..I $P(^TMP($J,"TRANS",APCMP,P),U,1)=$P(^TMP($J,"TRANS",APCMP,P),U,2) S APCMVALU="# referrals: "_$P(^TMP($J,"TRANS",APCMP,P),U,1)_"|||"_" # w/TOCS: "_+$P(^TMP($J,"TRANS",APCMP,P),U,2)_" "_$P(^TMP($J,"TRANS",APCMP,P),U,3)_"|||1" D Q
  1. ...S DFN=P D SETLIST^APCM24E1 Q
  1. ..S DFN=P,APCMVALU="# referrals: "_$P(^TMP($J,"TRANS",APCMP,P),U,1)_"|||"_" # w/TOCS: "_+$P(^TMP($J,"TRANS",APCMP,P),U,2)_" "_$P(^TMP($J,"TRANS",APCMP,P),U,3)_"|||0" D SETLIST^APCM24E1
  1. .;numerator?
  1. .S F=$P(^APCM24OB(APCMIC,0),U,9)
  1. .S N=$P($G(MMR(APCMP)),U,2)
  1. .D S^APCM24E1(APCMRPT,APCMIC,N,APCMP,APCMRPTT,APCMTIME,F)
  1. .;NOW SET VALUES FOR MEASURE 2
  1. .S Y=$O(^APCM24OB("B","S2.023.1.EP",0))
  1. .S F=$P(^APCM24OB(Y,0),U,8) D S^APCM24E1(APCMRPT,Y,$P($G(MMR(APCMP)),U,1),APCMP,APCMRPTT,APCMTIME,F)
  1. .S F=$P(^APCM24OB(Y,0),U,9)
  1. .S N=$P($G(MMR(APCMP)),U,5)
  1. .D S^APCM24E1(APCMRPT,APCMIC,N,APCMP,APCMRPTT,APCMTIME,F)
  1. I APCMRPTT=2 S APCMP=APCMFAC D
  1. .I '$P($G(MMR(APCMP)),U,1) D Q
  1. ..S F=$P(^APCM24OB(APCMIC,0),U,11) D S^APCM24E1(APCMRPT,APCMIC,"Facility is excluded from this measure as there were no referrals during the EHR reporting period.",APCMP,APCMRPTT,APCMTIME,F,1)
  1. ..;now get all related measures
  1. ..S O=0 F S O=$O(^APCM24OB(APCMIC,29,O)) Q:O'=+O S Y=$P(^APCM24OB(APCMIC,29,O,0),U,1),Y=$O(^APCM24OB("B",Y,0)) I Y D
  1. ...S F=$P(^APCM24OB(Y,0),U,11) D S^APCM24E1(APCMRPT,Y,"X",APCMP,APCMRPTT,APCMTIME,F,1)
  1. .;set value for measure 3
  1. .S Y=$O(^APCM24OB("B","S2.021.2.H",0))
  1. .S F=$P(^APCM24OB(Y,0),U,8) D S^APCM24E1(APCMRPT,Y,APCMATTE("S2.021.H",APCMP),APCMP,APCMRPTT,APCMTIME,F)
  1. .;set denominator value into field FOR measure 1
  1. .S F=$P(^APCM24OB(APCMIC,0),U,8) ;denom field for this measure
  1. .S N=$P($G(MMR(APCMP)),U,1) ;returns # of transS^# with mmr
  1. .D S^APCM24E1(APCMRPT,APCMIC,N,APCMP,APCMRPTT,APCMTIME,F)
  1. .;now set patient list for this provider
  1. .S P=0 F S P=$O(^TMP($J,"TRANS",APCMP,P)) Q:P'=+P D
  1. ..I $P(^TMP($J,"TRANS",APCMP,P),U,1)=$P(^TMP($J,"TRANS",APCMP,P),U,2) S APCMVALU="# referrals: "_$P(^TMP($J,"TRANS",APCMP,P),U,1)_"|||"_" # w/TOCS: "_+$P(^TMP($J,"TRANS",APCMP,P),U,2)_" "_$P(^TMP($J,"TRANS",APCMP,P),U,3)_"|||1" D Q
  1. ...S DFN=P D SETLIST^APCM24E1 Q
  1. ..S DFN=P,APCMVALU="# referrals: "_$P(^TMP($J,"TRANS",APCMP,P),U,1)_"|||"_" # w/TOCS: "_+$P(^TMP($J,"TRANS",APCMP,P),U,2)_" "_$P(^TMP($J,"TRANS",APCMP,P),U,3)_"|||0" D SETLIST^APCM24E1
  1. .;numerator?
  1. .S F=$P(^APCM24OB(APCMIC,0),U,9)
  1. .S N=$P($G(MMR(APCMP)),U,2)
  1. .D S^APCM24E1(APCMRPT,APCMIC,N,APCMP,APCMRPTT,APCMTIME,F)
  1. .;NOW SET VALUES FOR MEASURE 2
  1. .S Y=$O(^APCM24OB("B","S2.021.1.H",0))
  1. .S F=$P(^APCM24OB(Y,0),U,8) D S^APCM24E1(APCMRPT,Y,$P($G(MMR(APCMP)),U,1),APCMP,APCMRPTT,APCMTIME,F)
  1. .S F=$P(^APCM24OB(Y,0),U,9)
  1. .S N=$P($G(MMR(APCMP)),U,5)
  1. .D S^APCM24E1(APCMRPT,APCMIC,N,APCMP,APCMRPTT,APCMTIME,F)
  1. K ^TMP($J,"TRANS")
  1. Q
  1. TOCSUMC ;EP - ep toc
  1. ;SET ARRAY MMR to MMR(prov ien)=denom^numer
  1. ;DENOM=# VISITS W/REFERRAL
  1. ;NUMER=# W/TOC DOCUMENT IN 600 MULTIPLE
  1. ;IF DENOM =0 THEN PROVIDER EXCLUSION
  1. NEW T,C,PAT,N,APCMX,R,C,G,Z,S,B,E,J,K
  1. S C=0,N=0,PAT=""
  1. S T=$O(^APCMMUCN("B","INTERIM STAGE 2 2014",0))
  1. ;GO THROUGH EACH PATIENT WHO HAS VISITS
  1. S PAT=0 F S PAT=$O(^AUPNVSIT("AA",PAT)) Q:PAT'=+PAT D TOCSUMC1
  1. Q
  1. TOCSUMC1 ;
  1. NEW APCMLAB
  1. S APCMLAB="APCMLAB"
  1. D ALLV^APCLAPIU(PAT,APCMBDAT,APCMEDAT,APCMLAB) ;get all visits for this patient in time period
  1. S APCMX=0 F S APCMX=$O(APCMLAB(APCMX)) Q:APCMX'=+APCMX D
  1. .S V=$P(APCMLAB(APCMX),U,5) ;VISIT IEN
  1. .Q:'$D(^AUPNVSIT(V,0)) ;NO VISIT??
  1. .I APCMRPTT=2,APCMMETH="E" Q:'$$HOSER^APCM24E6(V,APCMFAC) S R=APCMFAC G TOCS2
  1. .I APCMRPTT=2,APCMMETH="O" Q:"OH"'[$P(^AUPNVSIT(V,0),U,7) Q:$P(^AUPNVSIT(V,0),U,6)'=APCMFAC S R=APCMFAC G TOCS2
  1. .S R=$$PRIMPROV^APCLV(V,"I") ;primary provider IEN
  1. .Q:'R
  1. .I '$D(APCMPRV(R)) Q ;not a provider of interest for this report
  1. .Q:"AOSM"'[$P(^AUPNVSIT(V,0),U,7)
  1. .S C=$$CLINIC^APCLV(V,"C")
  1. .Q:C=30
  1. .Q:C=77
  1. .Q:C=76
  1. .Q:C=63
  1. .Q:C=39
  1. TOCS2 .;IS THERE A V REFERAL THAT MEETS DENOM DEFINITION
  1. .S Z=0 F S Z=$O(^AUPNVREF("AD",V,Z)) Q:Z'=+Z D
  1. ..Q:'$D(^AUPNVREF(Z,0)) ;??
  1. ..S S=$P(^AUPNVREF(Z,0),U,6) ;REFERRAL IEN
  1. ..Q:'S ;no referral??
  1. ..Q:'$D(^BMCREF(S,0)) ;bad pointer
  1. ..Q:$P(^BMCREF(S,0),U,4)="N" ;NO INHOUSE
  1. ..Q:$P($G(^BMCREF(S,11)),U,5)="" ;MUST HAVE AN EXPECTED BEGIN DOS
  1. ..S D=$P($G(^BMCREF(S,13)),U,5) ;approval date
  1. ..Q:D="" ;NO APPROVAL DATE
  1. ..Q:D>APCMEDAT ;AFTER TP
  1. ..Q:D<APCMBDAT ;BEFORE TP
  1. SUMNUM ..;
  1. ..I '$D(MMR(R)) S MMR(R)=""
  1. ..S $P(MMR(R),U,1)=$P(MMR(R),U,1)+1 D
  1. ...S $P(^TMP($J,"TRANS",R,PAT),U,1)=$P($G(^TMP($J,"TRANS",R,PAT)),U,1)+1
  1. ...S $P(^TMP($J,"TRANS",R,PAT),U,3)=$P(^TMP($J,"TRANS",R,PAT),U,3)_" "_$$VD^APCLV(V,"S")_"-"_$P(^BMCREF(S,0),U,2)
  1. ..;now check numerator, FIELD 600
  1. ..S G=0,T=0
  1. ..;FIRST LOOK FOR A TX AND ACKNOWLEDGED IF FOUND, USE IT
  1. ..;NEXT LOOK FOR A TX, IF FOUND, USE IT
  1. ..;THEN LOOK FOR PRINTED.
  1. ..S B=0 F S B=$O(^BMCREF(S,6,B)) Q:B'=+B!(G) D
  1. ...S (A,E)=""
  1. ...I $P(^BMCREF(S,6,B,0),U,4)'="CT" Q
  1. ...S E=$P($P(^BMCREF(S,6,B,0),U,6),".")
  1. ...S M=$$CD(E,D,APCMEDAT)
  1. ...I 'M S E=$P($P(^BMCREF(S,6,B,0),U,1),".") S M=$$CD(E,D,APCMEDAT) Q:'M ;dates aren't good
  1. ...S A=$P($P(^BMCREF(S,6,B,0),U,3),".") ;tx acknowledged
  1. ...I A,A'<D,A'>APCMEDAT S G=1,T="CT"
  1. ...Q
  1. ..I G D SN Q
  1. ..;CHECK FOR TX BUT NO ACKNOWLEDGE
  1. ..S (G,A,T)=""
  1. ..S B=0 F S B=$O(^BMCREF(S,6,B)) Q:B'=+B!(G) D
  1. ...S (A,E)=""
  1. ...I $P(^BMCREF(S,6,B,0),U,4)'="CT" Q
  1. ...S E=$P($P(^BMCREF(S,6,B,0),U,6),".")
  1. ...S M=$$CD(E,D,APCMEDAT)
  1. ...I 'M S E=$P($P(^BMCREF(S,6,B,0),U,1),".") S M=$$CD(E,D,APCMEDAT) Q:'M ;dates aren't good
  1. ...;S A=$P($P(^BMCREF(S,6,B,0),U,3),".") ;tx acknowledged
  1. ...S G=1,A=0,T="CT"
  1. ...Q
  1. ..I G D SN Q
  1. ..;NOW PRINTED
  1. ..S (G,A,T)=""
  1. ..S B=0 F S B=$O(^BMCREF(S,6,B)) Q:B'=+B!(G) D
  1. ...S (A,E)=""
  1. ...I $P(^BMCREF(S,6,B,0),U,4)'="CP" Q
  1. ...S E=$P($P(^BMCREF(S,6,B,0),U,6),".")
  1. ...S M=$$CD(E,D,APCMEDAT)
  1. ...I 'M S E=$P($P(^BMCREF(S,6,B,0),U,1),".") S M=$$CD(E,D,APCMEDAT) Q:'M ;dates aren't good
  1. ...S G=1,A=0,T="CP"
  1. ...Q
  1. ..I G D SN Q
  1. ..;
  1. SUMAPCC ..;CHECK APCC DOCUMENT FILE
  1. ..S J=0 F S J=$O(^APCCDPL(V,1,J)) Q:J'=+J!(G) D
  1. ...Q:$P($G(^APCCDPL(V,1,J,0)),U,4)'=2 ;TOC ONLY
  1. ...Q:$P($P(^APCCDPL(V,1,J,0),U,1),".")'=$$VD^APCLV(V) ;DATE MUST EQUAL VISIT DATE
  1. ...S G=1
  1. ...S $P(MMR(R),U,2)=$P(MMR(R),U,2)+1 D
  1. ....S $P(^TMP($J,"TRANS",R,PAT),U,2)=$P($G(^TMP($J,"TRANS",R,PAT)),U,2)+1
  1. ....S $P(^TMP($J,"TRANS",R,PAT),U,3)=$P(^TMP($J,"TRANS",R,PAT),U,3)_";YES APCC TOCS"
  1. ..I 'G S $P(^TMP($J,"TRANS",R,PAT),U,3)=$P(^TMP($J,"TRANS",R,PAT),U,3)_";NO TOCS" Q
  1. Q
  1. SN ;
  1. S $P(MMR(R),U,2)=$P(MMR(R),U,2)+1 D Q
  1. .S $P(^TMP($J,"TRANS",R,PAT),U,2)=$P($G(^TMP($J,"TRANS",R,PAT)),U,2)+1
  1. .S $P(^TMP($J,"TRANS",R,PAT),U,3)=$P(^TMP($J,"TRANS",R,PAT),U,3)_";YES "_T I T="CT" S $P(^TMP($J,"TRANS",R,PAT),U,3)=$P(^TMP($J,"TRANS",R,PAT),U,3)_$S(A:" TX",1:"")
  1. .I T="CT" S $P(MMR(R),U,4)=$P(MMR(R),U,4)+1 I A S $P(MMR(R),U,5)=$P(MMR(R),U,5)+1
  1. Q
  1. CD(E,D,APCMEDAT) ;
  1. I E="" Q 0 ;NO DATE TRANSMITTED
  1. I E<D Q 0 ;BEFORE APPROVAL DATE
  1. I E>APCMEDAT Q 0 ;AFTER TIME PERIOD
  1. Q 1