APCM25E ; IHS/CMI/LAB - IHS MU ; 07 Oct 2015 1:21 PM
;;1.0;MU PERFORMANCE REPORTS;**7,8,9,10**;MAR 26, 2012;Build 31
;
;
W:$D(IOF) @IOF
EP D XIT
INTRO ;
S APCMRPTT=1 ;CONTROL VARIABLE FOR EP REPORT
W !!!,"*IHS Modified Stage 2 MU Performance Reports for EPS*",!
W !,"This report displays the performance measure results for Modified",!
W "Stage 2 Meaningful Use. In order to achieve Meaningful Use, an EP must",!
W "attest to meeting all 10 objectives and their associated performance measures.",!
W !,"The report can be run for 90 days, 1 year or a user defined time period.",!
S DIR(0)="Y",DIR("A")="Do you wish to continue to report",DIR("B")="YES" KILL DA D ^DIR KILL DIR
I $D(DIRUT) D XIT Q
I 'Y D XIT Q
;gather up measures for this report
W !! S X=0 F S X=$O(^APCM25OB(X)) Q:X'=+X I $P(^APCM25OB(X,0),U,2)="E" S APCMIND(X)=""
RT ;
S APCMSUM="S"
TP ;
S APCMRPTP=""
;display note
W !
MUYEAR ;
K APCMPER,APCMVDT,APCMEDUD
K DIR S DIR(0)="D^::EP"
W !,"Enter the Calendar Year for which the EP is demonstrating Meaningful"
S DIR("A")="Use. Use a 4 digit year, e.g. 2015"
S DIR("?")="Enter a valid year."
D ^DIR KILL DIR
I $D(DIRUT) G EP
I $D(DUOUT) G EP
S APCMVDT=Y
I $E(Y,4,7)'="0000" W !!,"Please enter a year only!",! G MUYEAR
I $E(Y,1,3)<315 W !!,"Year entered cannot be prior to 2015.",! G MUYEAR
S APCMPER=APCMVDT
I $E(APCMPER,1,3)>316 S APCMEDUD=$E(APCMPER,1,3)_"1231" ;IHS/CMI/LAB - PATCH 10 06/06/2017
S APCMLD=$E(APCMPER,1,3)_"0101",APCMHD=$E(APCMPER,1,3)_"1231" ;LOW AND HIGH DATES ALLOWED BELOW
;
YEAR ;
S (APCMVDT,APCMBD,APCMED)=""
S APCMQ=0
D G:APCMQ INTRO
.W !!,"Select one of the following:",!
.W !?10,"1 User Defined 90-Day Report"
.W !?10,"2 Calendar Year"
.W !?10,"3 User Defined Date Range"
.W ! S DIR(0)="N^1:3:",DIR("A")="Select Report Period" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1 Q
.S APCMRPTP=Y
.I APCMRPTP=1 D 5 Q
.I APCMRPTP=2 S APCMBD=APCMLD,APCMED=APCMHD W !!,"Date range is: ",$$FMTE^XLFDT(APCMBD)," - ",$$FMTE^XLFDT(APCMED),"." Q
.I APCMRPTP=3 D 6 Q
I APCMBD="" G TP
I APCMED="" G TP
;
PRV ;
S APCMPLTY=""
S DIR(0)="S^IP:Individual Provider;SEL:Selected Providers (User Defined);TAX:Provider Taxonomy List",DIR("A")="Enter Selection" KILL DA D ^DIR KILL DIR
I $D(DIRUT) G TP
S APCMPLTY=Y
S APCMQUIT=""
I APCMPLTY="IP" D I $G(APCMQUIT) G PRV
.K APCMPRV
.W !!,"Enter the name of the provider for whom the Meaningful Use Report will be run.",!
.S DIC="^VA(200,",DIC(0)="AEMQ",D="AK.PROVIDER",DIC("A")="Enter PROVIDER NAME: " D MIX^DIC1 K DIC,D
.I Y<0 S APCMQUIT=1 Q
.S APCMPRV(+Y)=""
I APCMPLTY="SEL" D I $G(APCMQUIT) G PRV
.K APCMPRV
.W !!,"Enter the name of the provider for whom the Meaningful Use Report will be run.",!
SEL1 .S DIC="^VA(200,",DIC(0)="AEMQ",D="AK.PROVIDER",DIC("A")="Enter PROVIDER NAME: " D MIX^DIC1 K DIC,D
.I Y<0,'$D(APCMPRV) S APCMQUIT=1 Q
.I Y<0 Q
.S APCMPRV(+Y)=""
.G SEL1
I APCMPLTY="TAX" D I $G(APCMQUIT) G PRV
.W !!,"Enter the name of the provider taxonomy"
.S DIC="^ATXAX(",DIC("S")="I $P(^(0),U,15)=200",DIC(0)="AEMQ",DIC("A")="Enter PROVIDER TAXONOMY NAME: " D ^DIC K DIC
.I Y<0 S APCMQUIT=1 Q
.S APCMPRTX=+Y
.W !,"The following providers are members of this taxonomy: "
.S X=0 F S X=$O(^ATXAX(+Y,21,"B",X)) Q:X'=+X S APCMPRV(X)="" W !?5,"- ",$P(^VA(200,X,0),U,1)
DEMO ;
D DEMOCHK^APCLUTL(.APCMDEMO)
I APCMDEMO=-1 G PRV
ASKADD ;
K APCMADDQ
S B=$O(^APCM25OB("B","S2.003.EP",0))
I '$D(APCMIND(B)) G ATTEST
W !!,"Please answer the following exclusion questions for each provider."
D EPRES ;ASK ADDITIONAL QUESTIONS FOR E-PRESCRIBING
I APCMQ G DEMO
I APCMQ G ASKADD
;D IMMREG
;I APCMQ G ASKADD
;D SPECREG
;I APCMQ G ASKADD
ATTEST ;get answers to attestation questions for each provider.
D ATTESTQ
I APCMQ G ASKADD
SUM ;display summary of this report
W:$D(IOF) @IOF
W !,$$CTR("SUMMARY OF MODIFIED STAGE 2 REPORT TO BE GENERATED")
W !!,"The date ranges for this report are:"
W !?5,"Report Period: ",?31,$$FMTE^XLFDT(APCMBD)," to ",?31,$$FMTE^XLFDT(APCMED)
I $E(APCMPER,1,3)>316 D ;IHS/CMI/LAB - PATCH 9 06/06/2017 PATCH 10 06/20/2018
.W !!,"Please note: the date range for Patient Education, Patient Electronic Access",!,"and Summary of Care (HIE) is ",$$FMTE^XLFDT(APCMBD)," to ",$$FMTE^XLFDT(APCMEDUD),".",!
W !!,"Providers: "
S X=0 F S X=$O(APCMPRV(X)) Q:X'=+X W !?5,$P(^VA(200,X,0),U,1)
D PT^APCM25SL
I APCMROT="" G DEMO
ZIS ;call to XBDBQUE
D REPORT^APCM25SL
I $G(APCMQUIT) D XIT Q
I APCMRPT="" D XIT Q
K IOP,%ZIS I APCMROT="D",APCMDELT="F" D NODEV,XIT Q
K IOP,%ZIS W !! S %ZIS=$S(APCMDELT'="S":"PQM",1:"PM") D ^%ZIS
I POP W !,"Report Aborted" S DA=APCMRPT,DIK="^APCMM25C(" D ^DIK K DIK D XIT Q
I $D(IO("Q")) G TSKMN
DRIVER ;
D PROC^APCM25E1
U IO
D ^APCM25EP
D ^%ZISC
D XIT
Q
;
NODEV ;
S XBRP="",XBRC="NODEV1^APCM25E",XBRX="XIT^APCM25E",XBNS="APCM"
D ^XBDBQUE
Q
;
NODEV1 ;
D PROC^APCM25E1
D ^APCM25EP
D ^%ZISC
D XIT
Q
TSKMN ;EP ENTRY POINT FROM TASKMAN
S ZTIO=$S($D(ION):ION,1:IO) I $D(IOST)#2,IOST]"" S ZTIO=ZTIO_";"_IOST
I $G(IO("DOC"))]"" S ZTIO=ZTIO_";"_$G(IO("DOC"))
I $D(IOM)#2,IOM S ZTIO=ZTIO_";"_IOM I $D(IOSL)#2,IOSL S ZTIO=ZTIO_";"_IOSL
K ZTSAVE S ZTSAVE("APCM*")=""
S ZTCPU=$G(IOCPU),ZTRTN="DRIVER^APCM25E",ZTDTH="",ZTDESC="MODIFIED STAGE 2 REPORT" D ^%ZTLOAD D XIT Q
Q
;
XIT ;
D ^%ZISC
D EN^XBVK("APCM")
I $D(ZTQUEUED) S ZTREQ="@"
K DIRUT,DUOUT,DIR,DOD
K DIADD,DLAYGO
D KILL^AUPNPAT
K X,X1,X2,X3,X4,X5,X6
K A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,V,W,X,Y,Z
K N,N1,N2,N3,N4,N5,N6
K BD,ED
D KILL^AUPNPAT
D ^XBFMK
Q
;
CTR(X,Y) ;EP - Center X in a field Y wide.
Q $J("",$S($D(Y):Y,1:IOM)-$L(X)\2)_X
;----------
EOP ;EP - End of page.
Q:$E(IOST)'="C"
Q:$D(ZTQUEUED)!$D(IO("S"))
NEW DIR
K DIR,DIRUT,DFOUT,DLOUT,DTOUT,DUOUT
S DIR(0)="E" D ^DIR KILL DIR
Q
;----------
USR() ;EP - Return name of current user from ^VA(200.
Q $S($G(DUZ):$S($D(^VA(200,DUZ,0)):$P(^(0),U),1:"UNKNOWN"),1:"DUZ UNDEFINED OR 0")
;----------
LOC() ;EP - Return location name from file 4 based on DUZ(2).
Q $S($G(DUZ(2)):$S($D(^DIC(4,DUZ(2),0)):$P(^(0),U),1:"UNKNOWN"),1:"DUZ(2) UNDEFINED OR 0")
;----------
6 ;EP
C ;EP
S (APCMVDT,APCMBD,APCMED)=""
K DIR W ! S DIR(0)="DO^::EXP",DIR("A")="Enter Beginning Date"
D ^DIR I $D(DIRUT) S APCMQ=1 Q
I Y<0 S APCMQ=1 Q
I Y>DT W !!,"Future dates not allowed." G C
I Y<APCMLD W !!,"The beginning date must be within calendar year entered." G C
S APCMBD=Y
K DIR S DIR(0)="DO^:DT:EXP",DIR("A")="Enter Ending Date"
D ^DIR G:Y<1 C
I Y>APCMHD W !!,"The ending date must be within calendar year entered." G C
S APCMED=Y
;
I APCMED<APCMBD D G C
. W !!,$C(7),"Sorry, Ending Date MUST not be earlier than Beginning Date."
Q
5 ;EP - TEXT
;W !!,"Enter the start date of the 90-day report period.",!
S (APCMVDT,APCMBD,APCMED)=""
W ! K DIR,X,Y
;S DIR(0)="DO^"_APCMLD_":"_$$FMADD^XLFDT(APCMHD,-89)_":EP"
S DIR(0)="D^::E"
S DIR("A")="Enter Start Date for the 90-Day Report (e.g. 01/01/2015)" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
I $D(DIRUT) S APCMQ=1 Q
I Y<APCMLD W !!,"The 90 day start and end dates must be within the calendar year entered." G 5
I $$FMADD^XLFDT(Y,89)>APCMHD W !!,"The end date would be ",$$FMTE^XLFDT($$FMADD^XLFDT(Y,89)),".",!,"The 90 day start and end dates must be within the calendar year entered." G 5
S APCMBD=Y,APCMED=$$FMADD^XLFDT(APCMBD,89)
Q
;
CXIT ;
K DIR
Q
EPRES ;EP - ask additional exclusion questions for e-prescribing
S APCMQ=0
S APCMY=$O(^APCM25OB("B","S2.003.EP",0))
Q:'$D(APCMIND(APCMY)) ;measure not being run
K APCMADDQ("ANS",APCMY)
;display exclusion text/narrative
I $O(^APCM25OB(APCMY,26,0)) D ET
I APCMPLTY="SEL"!(APCMPLTY="TAX") D G:APCMIND=1 EIND Q
.S APCMQ=0,APCMIND=0
.W !,"The e-Prescribing onsite pharmacy question below may be addressed as a group or"
.W !,"by individual provider. Do you want to answer for all selected providers as a"
.S DIR(0)="Y",DIR("A")="group Y/N",DIR("B")="YES" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1 Q
.I 'Y S APCMIND=1 Q
.W !!,"Do all selected providers included in this report have an onsite"
.S DIR(0)="Y",DIR("A")="pharmacy Y/N",DIR("B")="YES" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1 Q
.I 'Y S APCMIND=1 Q
.S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP S APCMADDQ("ANS",APCMY,24,APCMP)="Yes"
EIND ;ask individually
S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP!(APCMQ) D
.S APCMZ=0 F S APCMZ=$O(^APCM25OB(APCMY,24,APCMZ)) Q:APCMZ'=+APCMZ W !,^APCM25OB(APCMY,24,APCMZ,0)
.W ! S DIR(0)="Y",DIR("A")=$E($P(^VA(200,APCMP,0),U,1),1,25)_"'s answer",DIR("B")="YES" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1 Q
.S APCMADDQ("ANS",APCMY,24,APCMP)=$S(Y:"Yes",1:"No")
.Q:Y
.W ! S X=0 F S X=$O(^APCM25OB(APCMY,25,X)) Q:X'=+X W !,^APCM25OB(APCMY,25,X,0)
.;S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP!(APCMQ) D
.W ! S DIR(0)="Y",DIR("A")=$E($P(^VA(200,APCMP,0),U,1),1,25)_"'s answer",DIR("B")="YES" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1 Q
.S APCMADDQ("ANS",APCMY,25,APCMP)=$S(Y:"Yes",1:"No")
Q
ET ;
W ! S APCMZ=0 F S APCMZ=$O(^APCM25OB(APCMY,26,APCMZ)) Q:APCMZ'=+APCMZ W !,^APCM25OB(APCMY,26,APCMZ,0)
W !
Q
ATTESTQ ;EP
K APCMATTE
S APCMQ=0
S Z=0 F S Z=$O(^APCM25OB("ATT",Z)) Q:Z'=+Z S A=0 F S A=$O(^APCM25OB("ATT",Z,A)) Q:A'=+A I $D(APCMIND(A)),$P(^APCM25OB(A,0),U,17) S X=$P(^APCM25OB(A,0),U,1) D
.S Y=0 F S Y=$O(APCMPRV(Y)) Q:Y'=+Y S APCMATTE(X,Y)="",APCMORA(Z,X)=""
I '$D(APCMATTE) Q ;no measures with attestation being run
;W !!,"Several Stage 2 Meaningful Use Performance Measures require an attestation of "
;W !,"Yes or No for each provider for which the report is being run.",!
;S DIR(0)="Y",DIR("A")="Do you wish to continue",DIR("B")="YES" KILL DA D ^DIR KILL DIR
;I $D(DIRUT) S APCMQ=1 Q
;I 'Y S APCMQ=1 Q
S APCMQ=0
I APCMPLTY="SEL"!(APCMPLTY="TAX") D
.W !!,"Each of the questions below may be addressed as a group or individual",!,"attestation.",!
S APCMO=0 F S APCMO=$O(APCMORA(APCMO)) Q:APCMO=""!(APCMQ) S APCMX="" F S APCMX=$O(APCMORA(APCMO,APCMX)) Q:APCMX=""!(APCMQ) D
.;WRITE QUESTION 1 THEN QUESTION 2
.I APCMX="S2.024.EP" D IMMREG Q
.I APCMX="S2.025.EP" D IMMREG Q
.I APCMX="S2.030.EP" D IMMREG Q
.F APCMQU=19,31 S APCMAP=$S(APCMQU=19:1,1:2) D ASK
Q
ASK ;
D
.S APCMY=$O(^APCM25OB("B",APCMX,0))
.Q:'$O(^APCM25OB(APCMY,APCMQU,0))
.W !
.I APCMX="S2.020.EP.1" S Y=$O(^APCM25OB("B","S2.026.EP",0)) Q:$D(APCMIND(Y))
.S X=0 F S X=$O(^APCM25OB(APCMY,APCMQU,X)) Q:X'=+X W !,^APCM25OB(APCMY,APCMQU,X,0)
.I APCMPLTY="SEL"!(APCMPLTY="TAX") D G:APCMIND ATTIND Q
..S APCMIND=0
..I '$P(^APCM25OB(APCMY,0),U,13) D
...W ! S DIR(0)="Y",DIR("A")="Do all selected providers included in this report"_$$T(APCMY,APCMQU)
...S DIR("B")="YES" I $P(^APCM25OB(APCMY,0),U,1)="S2.020.EP.1" S DIR("B")="NO"
...I APCMQU=19,$P(^APCM25OB(APCMY,0),U,1)="S2.026.EP" S DIR("B")="NO"
...KILL DA D ^DIR KILL DIR
...I $D(DIRUT) S APCMQ=1 Q
...I 'Y S APCMIND=1 Q
...S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP I $P(APCMATTE(APCMX,APCMP),U,APCMAP)'="N/A" S $P(APCMATTE(APCMX,APCMP),U,APCMAP)="Yes"
..I $P(^APCM25OB(APCMY,0),U,13) D
...W ! S DIR(0)="Y",DIR("A")="Will the following response apply to all EPs included in this report",DIR("B")="YES" KILL DA D ^DIR KILL DIR
...I $D(DIRUT) S APCMQ=1 Q
...I 'Y S APCMIND=1 Q
...S DIR(0)="S^Y:YES;N:NO;X:No Registry Available",DIR("A")="All selected providers included in this report attest to (Enter Y, N or X)",DIR("B")="YES" KILL DA D ^DIR KILL DIR
...I $D(DIRUT) S APCMQ=1 Q
...S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP S $P(APCMATTE(APCMX,APCMP),U,APCMAP)=$S(Y="X":"N/A",Y="Y":"Yes",Y="N":"No",Y:"Yes",1:"No")
ATTIND .;
.S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP!(APCMQ) D
..W !
..I '$P(^APCM25OB(APCMY,0),U,13) S DIR(0)="Y",DIR("A")="Does "_$E($P(^VA(200,APCMP,0),U,1),1,25)_$$T(APCMY,APCMQU)
..S DIR("B")="YES" I $P(^APCM25OB(APCMY,0),U,1)="S2.020.EP.1" S DIR("B")="NO"
..I APCMQU=19,$P(^APCM25OB(APCMY,0),U,1)="S2.026.EP" S DIR("B")="NO"
..KILL DA D ^DIR KILL DIR
..I $P(^APCM25OB(APCMY,0),U,13) S DIR(0)="S^Y:YES;N:NO;X:No Registry Available" D
...S DIR("A")="Does "_$E($P(^VA(200,APCMP,0),U,1),1,25)_$$T(APCMY,APCMQU),DIR("B")="YES" KILL DA D ^DIR KILL DIR
..I $D(DIRUT) S APCMQ=1 Q
..S $P(APCMATTE(APCMX,APCMP),U,APCMAP)=$S(Y="X":"N/A",Y="Y":"Yes",Y="N":"No",Y:"Yes",1:"No")
Q
IMMREG ;EP - ask additional exclusion questions for IMM REG
D IMMREG^APCM25EA
Q
SPECREG ;
D SPECREG^APCM25EA
Q
SS D SS^APCM25EA
Q
T(APCMY,APCMQU) ;
I APCMQU=31 Q " attest to this"
NEW %
S %=$S($P($G(^APCM25OB(APCMY,11)),U,1)]"":$P(^APCM25OB(APCMY,11),U,1),1:" attest to this")
Q %
APCM25E ; IHS/CMI/LAB - IHS MU ; 07 Oct 2015 1:21 PM
+1 ;;1.0;MU PERFORMANCE REPORTS;**7,8,9,10**;MAR 26, 2012;Build 31
+2 ;
+3 ;
+4 IF $DATA(IOF)
WRITE @IOF
EP DO XIT
INTRO ;
+1 ;CONTROL VARIABLE FOR EP REPORT
SET APCMRPTT=1
+2 WRITE !!!,"*IHS Modified Stage 2 MU Performance Reports for EPS*",!
+3 WRITE !,"This report displays the performance measure results for Modified",!
+4 WRITE "Stage 2 Meaningful Use. In order to achieve Meaningful Use, an EP must",!
+5 WRITE "attest to meeting all 10 objectives and their associated performance measures.",!
+6 WRITE !,"The report can be run for 90 days, 1 year or a user defined time period.",!
+7 SET DIR(0)="Y"
SET DIR("A")="Do you wish to continue to report"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+8 IF $DATA(DIRUT)
DO XIT
QUIT
+9 IF 'Y
DO XIT
QUIT
+10 ;gather up measures for this report
+11 WRITE !!
SET X=0
FOR
SET X=$ORDER(^APCM25OB(X))
IF X'=+X
QUIT
IF $PIECE(^APCM25OB(X,0),U,2)="E"
SET APCMIND(X)=""
RT ;
+1 SET APCMSUM="S"
TP ;
+1 SET APCMRPTP=""
+2 ;display note
+3 WRITE !
MUYEAR ;
+1 KILL APCMPER,APCMVDT,APCMEDUD
+2 KILL DIR
SET DIR(0)="D^::EP"
+3 WRITE !,"Enter the Calendar Year for which the EP is demonstrating Meaningful"
+4 SET DIR("A")="Use. Use a 4 digit year, e.g. 2015"
+5 SET DIR("?")="Enter a valid year."
+6 DO ^DIR
KILL DIR
+7 IF $DATA(DIRUT)
GOTO EP
+8 IF $DATA(DUOUT)
GOTO EP
+9 SET APCMVDT=Y
+10 IF $EXTRACT(Y,4,7)'="0000"
WRITE !!,"Please enter a year only!",!
GOTO MUYEAR
+11 IF $EXTRACT(Y,1,3)<315
WRITE !!,"Year entered cannot be prior to 2015.",!
GOTO MUYEAR
+12 SET APCMPER=APCMVDT
+13 ;IHS/CMI/LAB - PATCH 10 06/06/2017
IF $EXTRACT(APCMPER,1,3)>316
SET APCMEDUD=$EXTRACT(APCMPER,1,3)_"1231"
+14 ;LOW AND HIGH DATES ALLOWED BELOW
SET APCMLD=$EXTRACT(APCMPER,1,3)_"0101"
SET APCMHD=$EXTRACT(APCMPER,1,3)_"1231"
+15 ;
YEAR ;
+1 SET (APCMVDT,APCMBD,APCMED)=""
+2 SET APCMQ=0
+3 Begin DoDot:1
+4 WRITE !!,"Select one of the following:",!
+5 WRITE !?10,"1 User Defined 90-Day Report"
+6 WRITE !?10,"2 Calendar Year"
+7 WRITE !?10,"3 User Defined Date Range"
+8 WRITE !
SET DIR(0)="N^1:3:"
SET DIR("A")="Select Report Period"
KILL DA
DO ^DIR
KILL DIR
+9 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+10 SET APCMRPTP=Y
+11 IF APCMRPTP=1
DO 5
QUIT
+12 IF APCMRPTP=2
SET APCMBD=APCMLD
SET APCMED=APCMHD
WRITE !!,"Date range is: ",$$FMTE^XLFDT(APCMBD)," - ",$$FMTE^XLFDT(APCMED),"."
QUIT
+13 IF APCMRPTP=3
DO 6
QUIT
End DoDot:1
IF APCMQ
GOTO INTRO
+14 IF APCMBD=""
GOTO TP
+15 IF APCMED=""
GOTO TP
+16 ;
PRV ;
+1 SET APCMPLTY=""
+2 SET DIR(0)="S^IP:Individual Provider;SEL:Selected Providers (User Defined);TAX:Provider Taxonomy List"
SET DIR("A")="Enter Selection"
KILL DA
DO ^DIR
KILL DIR
+3 IF $DATA(DIRUT)
GOTO TP
+4 SET APCMPLTY=Y
+5 SET APCMQUIT=""
+6 IF APCMPLTY="IP"
Begin DoDot:1
+7 KILL APCMPRV
+8 WRITE !!,"Enter the name of the provider for whom the Meaningful Use Report will be run.",!
+9 SET DIC="^VA(200,"
SET DIC(0)="AEMQ"
SET D="AK.PROVIDER"
SET DIC("A")="Enter PROVIDER NAME: "
DO MIX^DIC1
KILL DIC,D
+10 IF Y<0
SET APCMQUIT=1
QUIT
+11 SET APCMPRV(+Y)=""
End DoDot:1
IF $GET(APCMQUIT)
GOTO PRV
+12 IF APCMPLTY="SEL"
Begin DoDot:1
+13 KILL APCMPRV
+14 WRITE !!,"Enter the name of the provider for whom the Meaningful Use Report will be run.",!
SEL1 SET DIC="^VA(200,"
SET DIC(0)="AEMQ"
SET D="AK.PROVIDER"
SET DIC("A")="Enter PROVIDER NAME: "
DO MIX^DIC1
KILL DIC,D
+1 IF Y<0
IF '$DATA(APCMPRV)
SET APCMQUIT=1
QUIT
+2 IF Y<0
QUIT
+3 SET APCMPRV(+Y)=""
+4 GOTO SEL1
End DoDot:1
IF $GET(APCMQUIT)
GOTO PRV
+5 IF APCMPLTY="TAX"
Begin DoDot:1
+6 WRITE !!,"Enter the name of the provider taxonomy"
+7 SET DIC="^ATXAX("
SET DIC("S")="I $P(^(0),U,15)=200"
SET DIC(0)="AEMQ"
SET DIC("A")="Enter PROVIDER TAXONOMY NAME: "
DO ^DIC
KILL DIC
+8 IF Y<0
SET APCMQUIT=1
QUIT
+9 SET APCMPRTX=+Y
+10 WRITE !,"The following providers are members of this taxonomy: "
+11 SET X=0
FOR
SET X=$ORDER(^ATXAX(+Y,21,"B",X))
IF X'=+X
QUIT
SET APCMPRV(X)=""
WRITE !?5,"- ",$PIECE(^VA(200,X,0),U,1)
End DoDot:1
IF $GET(APCMQUIT)
GOTO PRV
DEMO ;
+1 DO DEMOCHK^APCLUTL(.APCMDEMO)
+2 IF APCMDEMO=-1
GOTO PRV
ASKADD ;
+1 KILL APCMADDQ
+2 SET B=$ORDER(^APCM25OB("B","S2.003.EP",0))
+3 IF '$DATA(APCMIND(B))
GOTO ATTEST
+4 WRITE !!,"Please answer the following exclusion questions for each provider."
+5 ;ASK ADDITIONAL QUESTIONS FOR E-PRESCRIBING
DO EPRES
+6 IF APCMQ
GOTO DEMO
+7 IF APCMQ
GOTO ASKADD
+8 ;D IMMREG
+9 ;I APCMQ G ASKADD
+10 ;D SPECREG
+11 ;I APCMQ G ASKADD
ATTEST ;get answers to attestation questions for each provider.
+1 DO ATTESTQ
+2 IF APCMQ
GOTO ASKADD
SUM ;display summary of this report
+1 IF $DATA(IOF)
WRITE @IOF
+2 WRITE !,$$CTR("SUMMARY OF MODIFIED STAGE 2 REPORT TO BE GENERATED")
+3 WRITE !!,"The date ranges for this report are:"
+4 WRITE !?5,"Report Period: ",?31,$$FMTE^XLFDT(APCMBD)," to ",?31,$$FMTE^XLFDT(APCMED)
+5 ;IHS/CMI/LAB - PATCH 9 06/06/2017 PATCH 10 06/20/2018
IF $EXTRACT(APCMPER,1,3)>316
Begin DoDot:1
+6 WRITE !!,"Please note: the date range for Patient Education, Patient Electronic Access",!,"and Summary of Care (HIE) is ",$$FMTE^XLFDT(APCMBD)," to ",$$FMTE^XLFDT(APCMEDUD),".",!
End DoDot:1
+7 WRITE !!,"Providers: "
+8 SET X=0
FOR
SET X=$ORDER(APCMPRV(X))
IF X'=+X
QUIT
WRITE !?5,$PIECE(^VA(200,X,0),U,1)
+9 DO PT^APCM25SL
+10 IF APCMROT=""
GOTO DEMO
ZIS ;call to XBDBQUE
+1 DO REPORT^APCM25SL
+2 IF $GET(APCMQUIT)
DO XIT
QUIT
+3 IF APCMRPT=""
DO XIT
QUIT
+4 KILL IOP,%ZIS
IF APCMROT="D"
IF APCMDELT="F"
DO NODEV
DO XIT
QUIT
+5 KILL IOP,%ZIS
WRITE !!
SET %ZIS=$SELECT(APCMDELT'="S":"PQM",1:"PM")
DO ^%ZIS
+6 IF POP
WRITE !,"Report Aborted"
SET DA=APCMRPT
SET DIK="^APCMM25C("
DO ^DIK
KILL DIK
DO XIT
QUIT
+7 IF $DATA(IO("Q"))
GOTO TSKMN
DRIVER ;
+1 DO PROC^APCM25E1
+2 USE IO
+3 DO ^APCM25EP
+4 DO ^%ZISC
+5 DO XIT
+6 QUIT
+7 ;
NODEV ;
+1 SET XBRP=""
SET XBRC="NODEV1^APCM25E"
SET XBRX="XIT^APCM25E"
SET XBNS="APCM"
+2 DO ^XBDBQUE
+3 QUIT
+4 ;
NODEV1 ;
+1 DO PROC^APCM25E1
+2 DO ^APCM25EP
+3 DO ^%ZISC
+4 DO XIT
+5 QUIT
TSKMN ;EP ENTRY POINT FROM TASKMAN
+1 SET ZTIO=$SELECT($DATA(ION):ION,1:IO)
IF $DATA(IOST)#2
IF IOST]""
SET ZTIO=ZTIO_";"_IOST
+2 IF $GET(IO("DOC"))]""
SET ZTIO=ZTIO_";"_$GET(IO("DOC"))
+3 IF $DATA(IOM)#2
IF IOM
SET ZTIO=ZTIO_";"_IOM
IF $DATA(IOSL)#2
IF IOSL
SET ZTIO=ZTIO_";"_IOSL
+4 KILL ZTSAVE
SET ZTSAVE("APCM*")=""
+5 SET ZTCPU=$GET(IOCPU)
SET ZTRTN="DRIVER^APCM25E"
SET ZTDTH=""
SET ZTDESC="MODIFIED STAGE 2 REPORT"
DO ^%ZTLOAD
DO XIT
QUIT
+6 QUIT
+7 ;
XIT ;
+1 DO ^%ZISC
+2 DO EN^XBVK("APCM")
+3 IF $DATA(ZTQUEUED)
SET ZTREQ="@"
+4 KILL DIRUT,DUOUT,DIR,DOD
+5 KILL DIADD,DLAYGO
+6 DO KILL^AUPNPAT
+7 KILL X,X1,X2,X3,X4,X5,X6
+8 KILL A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,V,W,X,Y,Z
+9 KILL N,N1,N2,N3,N4,N5,N6
+10 KILL BD,ED
+11 DO KILL^AUPNPAT
+12 DO ^XBFMK
+13 QUIT
+14 ;
CTR(X,Y) ;EP - Center X in a field Y wide.
+1 QUIT $JUSTIFY("",$SELECT($DATA(Y):Y,1:IOM)-$LENGTH(X)\2)_X
+2 ;----------
EOP ;EP - End of page.
+1 IF $EXTRACT(IOST)'="C"
QUIT
+2 IF $DATA(ZTQUEUED)!$DATA(IO("S"))
QUIT
+3 NEW DIR
+4 KILL DIR,DIRUT,DFOUT,DLOUT,DTOUT,DUOUT
+5 SET DIR(0)="E"
DO ^DIR
KILL DIR
+6 QUIT
+7 ;----------
USR() ;EP - Return name of current user from ^VA(200.
+1 QUIT $SELECT($GET(DUZ):$SELECT($DATA(^VA(200,DUZ,0)):$PIECE(^(0),U),1:"UNKNOWN"),1:"DUZ UNDEFINED OR 0")
+2 ;----------
LOC() ;EP - Return location name from file 4 based on DUZ(2).
+1 QUIT $SELECT($GET(DUZ(2)):$SELECT($DATA(^DIC(4,DUZ(2),0)):$PIECE(^(0),U),1:"UNKNOWN"),1:"DUZ(2) UNDEFINED OR 0")
+2 ;----------
6 ;EP
C ;EP
+1 SET (APCMVDT,APCMBD,APCMED)=""
+2 KILL DIR
WRITE !
SET DIR(0)="DO^::EXP"
SET DIR("A")="Enter Beginning Date"
+3 DO ^DIR
IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+4 IF Y<0
SET APCMQ=1
QUIT
+5 IF Y>DT
WRITE !!,"Future dates not allowed."
GOTO C
+6 IF Y<APCMLD
WRITE !!,"The beginning date must be within calendar year entered."
GOTO C
+7 SET APCMBD=Y
+8 KILL DIR
SET DIR(0)="DO^:DT:EXP"
SET DIR("A")="Enter Ending Date"
+9 DO ^DIR
IF Y<1
GOTO C
+10 IF Y>APCMHD
WRITE !!,"The ending date must be within calendar year entered."
GOTO C
+11 SET APCMED=Y
+12 ;
+13 IF APCMED<APCMBD
Begin DoDot:1
+14 WRITE !!,$CHAR(7),"Sorry, Ending Date MUST not be earlier than Beginning Date."
End DoDot:1
GOTO C
+15 QUIT
5 ;EP - TEXT
+1 ;W !!,"Enter the start date of the 90-day report period.",!
+2 SET (APCMVDT,APCMBD,APCMED)=""
+3 WRITE !
KILL DIR,X,Y
+4 ;S DIR(0)="DO^"_APCMLD_":"_$$FMADD^XLFDT(APCMHD,-89)_":EP"
+5 SET DIR(0)="D^::E"
+6 SET DIR("A")="Enter Start Date for the 90-Day Report (e.g. 01/01/2015)"
DO ^DIR
KILL DIR
IF $DATA(DUOUT)
SET DIRUT=1
+7 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+8 IF Y<APCMLD
WRITE !!,"The 90 day start and end dates must be within the calendar year entered."
GOTO 5
+9 IF $$FMADD^XLFDT(Y,89)>APCMHD
WRITE !!,"The end date would be ",$$FMTE^XLFDT($$FMADD^XLFDT(Y,89)),".",!,"The 90 day start and end dates must be within the calendar year entered."
GOTO 5
+10 SET APCMBD=Y
SET APCMED=$$FMADD^XLFDT(APCMBD,89)
+11 QUIT
+12 ;
CXIT ;
+1 KILL DIR
+2 QUIT
EPRES ;EP - ask additional exclusion questions for e-prescribing
+1 SET APCMQ=0
+2 SET APCMY=$ORDER(^APCM25OB("B","S2.003.EP",0))
+3 ;measure not being run
IF '$DATA(APCMIND(APCMY))
QUIT
+4 KILL APCMADDQ("ANS",APCMY)
+5 ;display exclusion text/narrative
+6 IF $ORDER(^APCM25OB(APCMY,26,0))
DO ET
+7 IF APCMPLTY="SEL"!(APCMPLTY="TAX")
Begin DoDot:1
+8 SET APCMQ=0
SET APCMIND=0
+9 WRITE !,"The e-Prescribing onsite pharmacy question below may be addressed as a group or"
+10 WRITE !,"by individual provider. Do you want to answer for all selected providers as a"
+11 SET DIR(0)="Y"
SET DIR("A")="group Y/N"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+12 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+13 IF 'Y
SET APCMIND=1
QUIT
+14 WRITE !!,"Do all selected providers included in this report have an onsite"
+15 SET DIR(0)="Y"
SET DIR("A")="pharmacy Y/N"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+16 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+17 IF 'Y
SET APCMIND=1
QUIT
+18 SET APCMP=0
FOR
SET APCMP=$ORDER(APCMPRV(APCMP))
IF APCMP'=+APCMP
QUIT
SET APCMADDQ("ANS",APCMY,24,APCMP)="Yes"
End DoDot:1
IF APCMIND=1
GOTO EIND
QUIT
EIND ;ask individually
+1 SET APCMP=0
FOR
SET APCMP=$ORDER(APCMPRV(APCMP))
IF APCMP'=+APCMP!(APCMQ)
QUIT
Begin DoDot:1
+2 SET APCMZ=0
FOR
SET APCMZ=$ORDER(^APCM25OB(APCMY,24,APCMZ))
IF APCMZ'=+APCMZ
QUIT
WRITE !,^APCM25OB(APCMY,24,APCMZ,0)
+3 WRITE !
SET DIR(0)="Y"
SET DIR("A")=$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_"'s answer"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+4 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+5 SET APCMADDQ("ANS",APCMY,24,APCMP)=$SELECT(Y:"Yes",1:"No")
+6 IF Y
QUIT
+7 WRITE !
SET X=0
FOR
SET X=$ORDER(^APCM25OB(APCMY,25,X))
IF X'=+X
QUIT
WRITE !,^APCM25OB(APCMY,25,X,0)
+8 ;S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP!(APCMQ) D
+9 WRITE !
SET DIR(0)="Y"
SET DIR("A")=$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_"'s answer"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+10 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+11 SET APCMADDQ("ANS",APCMY,25,APCMP)=$SELECT(Y:"Yes",1:"No")
End DoDot:1
+12 QUIT
ET ;
+1 WRITE !
SET APCMZ=0
FOR
SET APCMZ=$ORDER(^APCM25OB(APCMY,26,APCMZ))
IF APCMZ'=+APCMZ
QUIT
WRITE !,^APCM25OB(APCMY,26,APCMZ,0)
+2 WRITE !
+3 QUIT
ATTESTQ ;EP
+1 KILL APCMATTE
+2 SET APCMQ=0
+3 SET Z=0
FOR
SET Z=$ORDER(^APCM25OB("ATT",Z))
IF Z'=+Z
QUIT
SET A=0
FOR
SET A=$ORDER(^APCM25OB("ATT",Z,A))
IF A'=+A
QUIT
IF $DATA(APCMIND(A))
IF $PIECE(^APCM25OB(A,0),U,17)
SET X=$PIECE(^APCM25OB(A,0),U,1)
Begin DoDot:1
+4 SET Y=0
FOR
SET Y=$ORDER(APCMPRV(Y))
IF Y'=+Y
QUIT
SET APCMATTE(X,Y)=""
SET APCMORA(Z,X)=""
End DoDot:1
+5 ;no measures with attestation being run
IF '$DATA(APCMATTE)
QUIT
+6 ;W !!,"Several Stage 2 Meaningful Use Performance Measures require an attestation of "
+7 ;W !,"Yes or No for each provider for which the report is being run.",!
+8 ;S DIR(0)="Y",DIR("A")="Do you wish to continue",DIR("B")="YES" KILL DA D ^DIR KILL DIR
+9 ;I $D(DIRUT) S APCMQ=1 Q
+10 ;I 'Y S APCMQ=1 Q
+11 SET APCMQ=0
+12 IF APCMPLTY="SEL"!(APCMPLTY="TAX")
Begin DoDot:1
+13 WRITE !!,"Each of the questions below may be addressed as a group or individual",!,"attestation.",!
End DoDot:1
+14 SET APCMO=0
FOR
SET APCMO=$ORDER(APCMORA(APCMO))
IF APCMO=""!(APCMQ)
QUIT
SET APCMX=""
FOR
SET APCMX=$ORDER(APCMORA(APCMO,APCMX))
IF APCMX=""!(APCMQ)
QUIT
Begin DoDot:1
+15 ;WRITE QUESTION 1 THEN QUESTION 2
+16 IF APCMX="S2.024.EP"
DO IMMREG
QUIT
+17 IF APCMX="S2.025.EP"
DO IMMREG
QUIT
+18 IF APCMX="S2.030.EP"
DO IMMREG
QUIT
+19 FOR APCMQU=19,31
SET APCMAP=$SELECT(APCMQU=19:1,1:2)
DO ASK
End DoDot:1
+20 QUIT
ASK ;
+1 Begin DoDot:1
+2 SET APCMY=$ORDER(^APCM25OB("B",APCMX,0))
+3 IF '$ORDER(^APCM25OB(APCMY,APCMQU,0))
QUIT
+4 WRITE !
+5 IF APCMX="S2.020.EP.1"
SET Y=$ORDER(^APCM25OB("B","S2.026.EP",0))
IF $DATA(APCMIND(Y))
QUIT
+6 SET X=0
FOR
SET X=$ORDER(^APCM25OB(APCMY,APCMQU,X))
IF X'=+X
QUIT
WRITE !,^APCM25OB(APCMY,APCMQU,X,0)
+7 IF APCMPLTY="SEL"!(APCMPLTY="TAX")
Begin DoDot:2
+8 SET APCMIND=0
+9 IF '$PIECE(^APCM25OB(APCMY,0),U,13)
Begin DoDot:3
+10 WRITE !
SET DIR(0)="Y"
SET DIR("A")="Do all selected providers included in this report"_$$T(APCMY,APCMQU)
+11 SET DIR("B")="YES"
IF $PIECE(^APCM25OB(APCMY,0),U,1)="S2.020.EP.1"
SET DIR("B")="NO"
+12 IF APCMQU=19
IF $PIECE(^APCM25OB(APCMY,0),U,1)="S2.026.EP"
SET DIR("B")="NO"
+13 KILL DA
DO ^DIR
KILL DIR
+14 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+15 IF 'Y
SET APCMIND=1
QUIT
+16 SET APCMP=0
FOR
SET APCMP=$ORDER(APCMPRV(APCMP))
IF APCMP'=+APCMP
QUIT
IF $PIECE(APCMATTE(APCMX,APCMP),U,APCMAP)'="N/A"
SET $PIECE(APCMATTE(APCMX,APCMP),U,APCMAP)="Yes"
End DoDot:3
+17 IF $PIECE(^APCM25OB(APCMY,0),U,13)
Begin DoDot:3
+18 WRITE !
SET DIR(0)="Y"
SET DIR("A")="Will the following response apply to all EPs included in this report"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+19 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+20 IF 'Y
SET APCMIND=1
QUIT
+21 SET DIR(0)="S^Y:YES;N:NO;X:No Registry Available"
SET DIR("A")="All selected providers included in this report attest to (Enter Y, N or X)"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+22 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+23 SET APCMP=0
FOR
SET APCMP=$ORDER(APCMPRV(APCMP))
IF APCMP'=+APCMP
QUIT
SET $PIECE(APCMATTE(APCMX,APCMP),U,APCMAP)=$SELECT(Y="X":"N/A",Y="Y":"Yes",Y="N":"No",Y:"Yes",1:"No")
End DoDot:3
End DoDot:2
IF APCMIND
GOTO ATTIND
QUIT
ATTIND ;
+1 SET APCMP=0
FOR
SET APCMP=$ORDER(APCMPRV(APCMP))
IF APCMP'=+APCMP!(APCMQ)
QUIT
Begin DoDot:2
+2 WRITE !
+3 IF '$PIECE(^APCM25OB(APCMY,0),U,13)
SET DIR(0)="Y"
SET DIR("A")="Does "_$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_$$T(APCMY,APCMQU)
+4 SET DIR("B")="YES"
IF $PIECE(^APCM25OB(APCMY,0),U,1)="S2.020.EP.1"
SET DIR("B")="NO"
+5 IF APCMQU=19
IF $PIECE(^APCM25OB(APCMY,0),U,1)="S2.026.EP"
SET DIR("B")="NO"
+6 KILL DA
DO ^DIR
KILL DIR
+7 IF $PIECE(^APCM25OB(APCMY,0),U,13)
SET DIR(0)="S^Y:YES;N:NO;X:No Registry Available"
Begin DoDot:3
+8 SET DIR("A")="Does "_$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_$$T(APCMY,APCMQU)
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
End DoDot:3
+9 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+10 SET $PIECE(APCMATTE(APCMX,APCMP),U,APCMAP)=$SELECT(Y="X":"N/A",Y="Y":"Yes",Y="N":"No",Y:"Yes",1:"No")
End DoDot:2
End DoDot:1
+11 QUIT
IMMREG ;EP - ask additional exclusion questions for IMM REG
+1 DO IMMREG^APCM25EA
+2 QUIT
SPECREG ;
+1 DO SPECREG^APCM25EA
+2 QUIT
SS DO SS^APCM25EA
+1 QUIT
T(APCMY,APCMQU) ;
+1 IF APCMQU=31
QUIT " attest to this"
+2 NEW %
+3 SET %=$SELECT($PIECE($GET(^APCM25OB(APCMY,11)),U,1)]"":$PIECE(^APCM25OB(APCMY,11),U,1),1:" attest to this")
+4 QUIT %