APCM24E ; IHS/CMI/LAB - IHS MU ;
;;1.0;IHS MU PERFORMANCE REPORTS;**5,6**;MAR 26, 2012;Build 65
;
;
W:$D(IOF) @IOF
D XIT
INTRO ;
S APCMRPTT=1 ;CONTROL VARIABLE FOR EP REPORT
S APCMRPTC=$O(^APCMMUCN("B","INTERIM STAGE 2 2014",0))
W !!!
S X=0 F S X=$O(^APCMMUCN(APCMRPTC,11,X)) Q:X'=+X W ^APCMMUCN(APCMRPTC,11,X,0),!
W !,"Report may be run for a quarter, 90-days, a one year or a user defined 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(^APCM24OB(X)) Q:X'=+X I $P(^APCM24OB(X,0),U,2)="E" S APCMIND(X)=""
RT ;
S APCMSUM="S"
TP ;
S APCMRPTP=""
;display note
W !
S X=0 F S X=$O(^APCMMUCN(APCMRPTC,17,X)) Q:X'=+X W ^APCMMUCN(APCMRPTC,17,X,0),!
YEAR ;
S (APCMPER,APCMVDT,APCMBD,APCMED)=""
W !!,"Enter the Calendar Year for which report is to be run. Use a 4 digit",!,"year, e.g. 2014."
S DIR(0)="D^::EP"
S DIR("A")="Select Year"
S DIR("?")="This report is compiled for a period. Enter a valid year."
D ^DIR KILL DIR
I $D(DIRUT) G INTRO
I $D(DUOUT) S DIRUT=1 G INTRO
S APCMVDT=Y
I $E(Y,4,7)'="0000" W !!,"Please enter a year only!",! G YEAR
S APCMPER=APCMVDT
S APCMQ=0
I APCMPER'="3150000" D G:APCMQ YEAR
.W !!,"Select one of the following:",!
.W !?10,"1 Quarter: January 1 - March 31"
.W !?10,"2 Quarter: April 1 - June 30"
.W !?10,"3 Quarter: July 1 - September 30"
.W !?10,"4 Quarter: October 1 - December 31"
.W !?10,"5 User Defined 90-Day Report"
.W !?10,"6 User Defined Date Range"
.S DIR(0)="N^1:6:",DIR("A")="Select Report Period" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1
.S APCMRPTP=Y
.I APCMRPTP=1 S APCMBD=$E(APCMPER,1,3)_"0101",APCMED=$E(APCMPER,1,3)_"0331" Q
.I APCMRPTP=2 S APCMBD=$E(APCMPER,1,3)_"0401",APCMED=$E(APCMPER,1,3)_"0630" Q
.I APCMRPTP=3 S APCMBD=$E(APCMPER,1,3)_"0701",APCMED=$E(APCMPER,1,3)_"0930" Q
.I APCMRPTP=4 S APCMBD=$E(APCMPER,1,3)_"1001",APCMED=$E(APCMPER,1,3)_"1231" Q
.I APCMRPTP=5 D 5 Q
.I APCMRPTP=6 D 6 Q
I APCMPER="3150000" D G:APCMQ YEAR
.W !!,"Select one of the following:",!
.W !?10,"1 Year: January 1 - December 31"
.W !?10,"2 User Defined 90-Day Report"
.W !?10,"3 User Defined Date Range"
.S DIR(0)="N^1:3:",DIR("A")="Select Report Period" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1
.S APCMRPTP=Y
.I APCMRPTP=1 S APCMBD=$E(APCMPER,1,3)_"0101",APCMED=$E(APCMPER,1,3)_"1231" Q
.I APCMRPTP=2 D 5 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 A=$O(^APCM24OB("B","S2.008.EP",0))
S B=$O(^APCM24OB("B","S2.003.EP",0))
I '$D(APCMIND(A)),'$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
D VITALS ;ASK ADDITIONAL QUESTIONS FOR VITALS
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 STAGE 2 2014/2015 MEANINGFUL USE 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)
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^APCM24SL
I APCMROT="" G DEMO
ZIS ;call to XBDBQUE
D REPORT^APCM24SL
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="^APCMM24C(" D ^DIK K DIK D XIT Q
I $D(IO("Q")) G TSKMN
DRIVER ;
D PROC^APCM24E1
U IO
D ^APCM24EP
D ^%ZISC
D XIT
Q
;
NODEV ;
S XBRP="",XBRC="NODEV1^APCM24E",XBRX="XIT^APCM24E",XBNS="APCM"
D ^XBDBQUE
Q
;
NODEV1 ;
D PROC^APCM24E1
D ^APCM24EP
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^APCM24E",ZTDTH="",ZTDESC="2014 MU 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")
;----------
;
5 ;EP - CALLED FROM LIST ROUTINE
B ;
W !
S (APCMPER,APCMVDT,APCMBD,APCMED)=""
W ! K DIR,X,Y S DIR(0)="D^::EP",DIR("A")="Enter Start Date for the 90-Day Report (e.g. 01/01/2014)" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
I $D(DIRUT) Q
S (APCMPER,APCMVDT)=Y
S APCMBD=Y,APCMED=$$FMADD^XLFDT(APCMBD,89)
Q
6 ;EP
C ;EP
S (APCMPER,APCMVDT,APCMBD,APCMED)=""
K DIR W ! S DIR(0)="DO^::EXP",DIR("A")="Enter Beginning Date"
D ^DIR G:Y<1 CXIT
I Y>DT W !!,"Future dates not allowed." G C
S APCMBD=Y
K DIR S DIR(0)="DO^:DT:EXP",DIR("A")="Enter Ending Date"
D ^DIR G:Y<1 C S APCMED=Y
;
I APCMED<APCMBD D G C
. W !!,$C(7),"Sorry, Ending Date MUST not be earlier than Beginning Date."
Q
CXIT ;
K DIR
Q
EPRES ;EP - ask additional exclusion questions for e-prescribing
S APCMQ=0
S APCMY=$O(^APCM24OB("B","S2.003.EP",0))
Q:'$D(APCMIND(APCMY)) ;measure not being run
K APCMADDQ("ANS",APCMY)
;display exclusion text/narrative
I $O(^APCM24OB(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(^APCM24OB(APCMY,24,APCMZ)) Q:APCMZ'=+APCMZ W !,^APCM24OB(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(^APCM24OB(APCMY,25,X)) Q:X'=+X W !,^APCM24OB(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(^APCM24OB(APCMY,26,APCMZ)) Q:APCMZ'=+APCMZ W !,^APCM24OB(APCMY,26,APCMZ,0)
W !
Q
VITALS ;EP -VITALS QUESTIONS
S APCMQ=0
S APCMY=$O(^APCM24OB("B","S2.008.EP",0))
Q:'$D(APCMIND(APCMY)) ;measure not being run
K APCMADDQ("ANS",APCMY)
;display exclusion text/narrative
I $O(^APCM24OB(APCMY,26,0)) D ET
VIND ;ask individually
S APCMP=0 F S APCMP=$O(APCMPRV(APCMP)) Q:APCMP'=+APCMP!(APCMQ) D
.W ! S APCMZ=0 F S APCMZ=$O(^APCM24OB(APCMY,24,APCMZ)) Q:APCMZ'=+APCMZ W !,^APCM24OB(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")="NO" 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(^APCM24OB(APCMY,25,X)) Q:X'=+X W !,^APCM24OB(APCMY,25,X,0)
.W ! S DIR(0)="Y",DIR("A")=$E($P(^VA(200,APCMP,0),U,1),1,25)_"'s answer",DIR("B")="NO" 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:Y
.W ! S X=0 F S X=$O(^APCM24OB(APCMY,27,X)) Q:X'=+X W !,^APCM24OB(APCMY,27,X,0)
.W ! S DIR(0)="Y",DIR("A")=$E($P(^VA(200,APCMP,0),U,1),1,25)_"'s answer",DIR("B")="NO" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1 Q
.S APCMADDQ("ANS",APCMY,27,APCMP)=$S(Y:"Yes",1:"No")
.Q:Y
.W ! S X=0 F S X=$O(^APCM24OB(APCMY,28,X)) Q:X'=+X W !,^APCM24OB(APCMY,28,X,0)
.W ! S DIR(0)="Y",DIR("A")=$E($P(^VA(200,APCMP,0),U,1),1,25)_"'s answer",DIR("B")="NO" KILL DA D ^DIR KILL DIR
.I $D(DIRUT) S APCMQ=1 Q
.S APCMADDQ("ANS",APCMY,28,APCMP)=$S(Y:"Yes",1:"No")
Q
ATTESTQ ;EP
K APCMATTE
S APCMQ=0
S Z=0 F S Z=$O(^APCM24OB("ATT",Z)) Q:Z'=+Z S A=0 F S A=$O(^APCM24OB("ATT",Z,A)) Q:A'=+A I $D(APCMIND(A)),$P(^APCM24OB(A,0),U,17) S X=$P(^APCM24OB(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
.W !
.S APCMY=$O(^APCM24OB("B",APCMX,0))
.Q:'$O(^APCM24OB(APCMY,APCMQU,0))
.I APCMX="S2.020.EP.1" D
..S Y=$O(^APCM24OB("B","S2.026.EP",0))
..Q:$D(APCMIND(Y))
..S N=26 W ! S APCMZ=0 F S APCMZ=$O(^APCM24OB(APCMY,26,APCMZ)) Q:APCMZ'=+APCMZ W !,^APCM24OB(APCMY,26,APCMZ,0)
..W !
.S X=0 F S X=$O(^APCM24OB(APCMY,APCMQU,X)) Q:X'=+X W !,^APCM24OB(APCMY,APCMQU,X,0)
.I APCMPLTY="SEL"!(APCMPLTY="TAX") D G:APCMIND ATTIND Q
..S APCMIND=0
..I '$P(^APCM24OB(APCMY,0),U,13) D
...W ! S DIR(0)="Y",DIR("A")="Do all selected providers included in this report"_$S($P($G(^APCM24OB(APCMY,11)),U,1)]"":$P(^APCM24OB(APCMY,11),U,1),1:" attest to this")
...S DIR("B")="YES" I $P(^APCM24OB(APCMY,0),U,1)="S2.026.EP"!($P(^APCM24OB(APCMY,0),U,1)="S2.020.EP.1") S DIR("B")="NO" 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(^APCM24OB(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(^APCM24OB(APCMY,0),U,13) S DIR(0)="Y",DIR("A")="Does "_$E($P(^VA(200,APCMP,0),U,1),1,25)_$S($P($G(^APCM24OB(APCMY,11)),U,1)]"":$P(^APCM24OB(APCMY,11),U,1),1:" attest to this")
..S DIR("B")="YES" I $P(^APCM24OB(APCMY,0),U,1)="S2.026.EP"!($P(^APCM24OB(APCMY,0),U,1)="S2.020.EP.1") S DIR("B")="NO"
..KILL DA D ^DIR KILL DIR
..I $P(^APCM24OB(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)_$S($P($G(^APCM24OB(APCMY,11)),U,1)]"":$P(^APCM24OB(APCMY,11),U,1),1:" attest to this"),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^APCM24EA
Q
SPECREG ;
D SPECREG^APCM24EA
Q
SS D SS^APCM24EA
Q
APCM24E ; IHS/CMI/LAB - IHS MU ;
+1 ;;1.0;IHS MU PERFORMANCE REPORTS;**5,6**;MAR 26, 2012;Build 65
+2 ;
+3 ;
+4 IF $DATA(IOF)
WRITE @IOF
+5 DO XIT
INTRO ;
+1 ;CONTROL VARIABLE FOR EP REPORT
SET APCMRPTT=1
+2 SET APCMRPTC=$ORDER(^APCMMUCN("B","INTERIM STAGE 2 2014",0))
+3 WRITE !!!
+4 SET X=0
FOR
SET X=$ORDER(^APCMMUCN(APCMRPTC,11,X))
IF X'=+X
QUIT
WRITE ^APCMMUCN(APCMRPTC,11,X,0),!
+5 WRITE !,"Report may be run for a quarter, 90-days, a one year or a user defined period.",!!
+6 SET DIR(0)="Y"
SET DIR("A")="Do you wish to continue to report"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+7 IF $DATA(DIRUT)
DO XIT
QUIT
+8 IF 'Y
DO XIT
QUIT
+9 ;gather up measures for this report
+10 WRITE !!
SET X=0
FOR
SET X=$ORDER(^APCM24OB(X))
IF X'=+X
QUIT
IF $PIECE(^APCM24OB(X,0),U,2)="E"
SET APCMIND(X)=""
RT ;
+1 SET APCMSUM="S"
TP ;
+1 SET APCMRPTP=""
+2 ;display note
+3 WRITE !
+4 SET X=0
FOR
SET X=$ORDER(^APCMMUCN(APCMRPTC,17,X))
IF X'=+X
QUIT
WRITE ^APCMMUCN(APCMRPTC,17,X,0),!
YEAR ;
+1 SET (APCMPER,APCMVDT,APCMBD,APCMED)=""
+2 WRITE !!,"Enter the Calendar Year for which report is to be run. Use a 4 digit",!,"year, e.g. 2014."
+3 SET DIR(0)="D^::EP"
+4 SET DIR("A")="Select Year"
+5 SET DIR("?")="This report is compiled for a period. Enter a valid year."
+6 DO ^DIR
KILL DIR
+7 IF $DATA(DIRUT)
GOTO INTRO
+8 IF $DATA(DUOUT)
SET DIRUT=1
GOTO INTRO
+9 SET APCMVDT=Y
+10 IF $EXTRACT(Y,4,7)'="0000"
WRITE !!,"Please enter a year only!",!
GOTO YEAR
+11 SET APCMPER=APCMVDT
+12 SET APCMQ=0
+13 IF APCMPER'="3150000"
Begin DoDot:1
+14 WRITE !!,"Select one of the following:",!
+15 WRITE !?10,"1 Quarter: January 1 - March 31"
+16 WRITE !?10,"2 Quarter: April 1 - June 30"
+17 WRITE !?10,"3 Quarter: July 1 - September 30"
+18 WRITE !?10,"4 Quarter: October 1 - December 31"
+19 WRITE !?10,"5 User Defined 90-Day Report"
+20 WRITE !?10,"6 User Defined Date Range"
+21 SET DIR(0)="N^1:6:"
SET DIR("A")="Select Report Period"
KILL DA
DO ^DIR
KILL DIR
+22 IF $DATA(DIRUT)
SET APCMQ=1
+23 SET APCMRPTP=Y
+24 IF APCMRPTP=1
SET APCMBD=$EXTRACT(APCMPER,1,3)_"0101"
SET APCMED=$EXTRACT(APCMPER,1,3)_"0331"
QUIT
+25 IF APCMRPTP=2
SET APCMBD=$EXTRACT(APCMPER,1,3)_"0401"
SET APCMED=$EXTRACT(APCMPER,1,3)_"0630"
QUIT
+26 IF APCMRPTP=3
SET APCMBD=$EXTRACT(APCMPER,1,3)_"0701"
SET APCMED=$EXTRACT(APCMPER,1,3)_"0930"
QUIT
+27 IF APCMRPTP=4
SET APCMBD=$EXTRACT(APCMPER,1,3)_"1001"
SET APCMED=$EXTRACT(APCMPER,1,3)_"1231"
QUIT
+28 IF APCMRPTP=5
DO 5
QUIT
+29 IF APCMRPTP=6
DO 6
QUIT
End DoDot:1
IF APCMQ
GOTO YEAR
+30 IF APCMPER="3150000"
Begin DoDot:1
+31 WRITE !!,"Select one of the following:",!
+32 WRITE !?10,"1 Year: January 1 - December 31"
+33 WRITE !?10,"2 User Defined 90-Day Report"
+34 WRITE !?10,"3 User Defined Date Range"
+35 SET DIR(0)="N^1:3:"
SET DIR("A")="Select Report Period"
KILL DA
DO ^DIR
KILL DIR
+36 IF $DATA(DIRUT)
SET APCMQ=1
+37 SET APCMRPTP=Y
+38 IF APCMRPTP=1
SET APCMBD=$EXTRACT(APCMPER,1,3)_"0101"
SET APCMED=$EXTRACT(APCMPER,1,3)_"1231"
QUIT
+39 IF APCMRPTP=2
DO 5
QUIT
+40 IF APCMRPTP=3
DO 6
QUIT
End DoDot:1
IF APCMQ
GOTO YEAR
+41 IF APCMBD=""
GOTO TP
+42 IF APCMED=""
GOTO TP
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 A=$ORDER(^APCM24OB("B","S2.008.EP",0))
+3 SET B=$ORDER(^APCM24OB("B","S2.003.EP",0))
+4 IF '$DATA(APCMIND(A))
IF '$DATA(APCMIND(B))
GOTO ATTEST
+5 WRITE !!,"Please answer the following exclusion questions for each provider."
+6 ;ASK ADDITIONAL QUESTIONS FOR E-PRESCRIBING
DO EPRES
+7 IF APCMQ
GOTO DEMO
+8 ;ASK ADDITIONAL QUESTIONS FOR VITALS
DO VITALS
+9 IF APCMQ
GOTO ASKADD
+10 ;D IMMREG
+11 ;I APCMQ G ASKADD
+12 ;D SPECREG
+13 ;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 STAGE 2 2014/2015 MEANINGFUL USE 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 WRITE !!,"Providers: "
+6 SET X=0
FOR
SET X=$ORDER(APCMPRV(X))
IF X'=+X
QUIT
WRITE !?5,$PIECE(^VA(200,X,0),U,1)
+7 DO PT^APCM24SL
+8 IF APCMROT=""
GOTO DEMO
ZIS ;call to XBDBQUE
+1 DO REPORT^APCM24SL
+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="^APCMM24C("
DO ^DIK
KILL DIK
DO XIT
QUIT
+7 IF $DATA(IO("Q"))
GOTO TSKMN
DRIVER ;
+1 DO PROC^APCM24E1
+2 USE IO
+3 DO ^APCM24EP
+4 DO ^%ZISC
+5 DO XIT
+6 QUIT
+7 ;
NODEV ;
+1 SET XBRP=""
SET XBRC="NODEV1^APCM24E"
SET XBRX="XIT^APCM24E"
SET XBNS="APCM"
+2 DO ^XBDBQUE
+3 QUIT
+4 ;
NODEV1 ;
+1 DO PROC^APCM24E1
+2 DO ^APCM24EP
+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^APCM24E"
SET ZTDTH=""
SET ZTDESC="2014 MU 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 ;----------
+3 ;
5 ;EP - CALLED FROM LIST ROUTINE
B ;
+1 WRITE !
+2 SET (APCMPER,APCMVDT,APCMBD,APCMED)=""
+3 WRITE !
KILL DIR,X,Y
SET DIR(0)="D^::EP"
SET DIR("A")="Enter Start Date for the 90-Day Report (e.g. 01/01/2014)"
DO ^DIR
KILL DIR
IF $DATA(DUOUT)
SET DIRUT=1
+4 IF $DATA(DIRUT)
QUIT
+5 SET (APCMPER,APCMVDT)=Y
+6 SET APCMBD=Y
SET APCMED=$$FMADD^XLFDT(APCMBD,89)
+7 QUIT
6 ;EP
C ;EP
+1 SET (APCMPER,APCMVDT,APCMBD,APCMED)=""
+2 KILL DIR
WRITE !
SET DIR(0)="DO^::EXP"
SET DIR("A")="Enter Beginning Date"
+3 DO ^DIR
IF Y<1
GOTO CXIT
+4 IF Y>DT
WRITE !!,"Future dates not allowed."
GOTO C
+5 SET APCMBD=Y
+6 KILL DIR
SET DIR(0)="DO^:DT:EXP"
SET DIR("A")="Enter Ending Date"
+7 DO ^DIR
IF Y<1
GOTO C
SET APCMED=Y
+8 ;
+9 IF APCMED<APCMBD
Begin DoDot:1
+10 WRITE !!,$CHAR(7),"Sorry, Ending Date MUST not be earlier than Beginning Date."
End DoDot:1
GOTO C
+11 QUIT
CXIT ;
+1 KILL DIR
+2 QUIT
EPRES ;EP - ask additional exclusion questions for e-prescribing
+1 SET APCMQ=0
+2 SET APCMY=$ORDER(^APCM24OB("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(^APCM24OB(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(^APCM24OB(APCMY,24,APCMZ))
IF APCMZ'=+APCMZ
QUIT
WRITE !,^APCM24OB(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(^APCM24OB(APCMY,25,X))
IF X'=+X
QUIT
WRITE !,^APCM24OB(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(^APCM24OB(APCMY,26,APCMZ))
IF APCMZ'=+APCMZ
QUIT
WRITE !,^APCM24OB(APCMY,26,APCMZ,0)
+2 WRITE !
+3 QUIT
VITALS ;EP -VITALS QUESTIONS
+1 SET APCMQ=0
+2 SET APCMY=$ORDER(^APCM24OB("B","S2.008.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(^APCM24OB(APCMY,26,0))
DO ET
VIND ;ask individually
+1 SET APCMP=0
FOR
SET APCMP=$ORDER(APCMPRV(APCMP))
IF APCMP'=+APCMP!(APCMQ)
QUIT
Begin DoDot:1
+2 WRITE !
SET APCMZ=0
FOR
SET APCMZ=$ORDER(^APCM24OB(APCMY,24,APCMZ))
IF APCMZ'=+APCMZ
QUIT
WRITE !,^APCM24OB(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")="NO"
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(^APCM24OB(APCMY,25,X))
IF X'=+X
QUIT
WRITE !,^APCM24OB(APCMY,25,X,0)
+8 WRITE !
SET DIR(0)="Y"
SET DIR("A")=$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_"'s answer"
SET DIR("B")="NO"
KILL DA
DO ^DIR
KILL DIR
+9 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+10 SET APCMADDQ("ANS",APCMY,25,APCMP)=$SELECT(Y:"Yes",1:"No")
+11 IF Y
QUIT
+12 WRITE !
SET X=0
FOR
SET X=$ORDER(^APCM24OB(APCMY,27,X))
IF X'=+X
QUIT
WRITE !,^APCM24OB(APCMY,27,X,0)
+13 WRITE !
SET DIR(0)="Y"
SET DIR("A")=$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_"'s answer"
SET DIR("B")="NO"
KILL DA
DO ^DIR
KILL DIR
+14 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+15 SET APCMADDQ("ANS",APCMY,27,APCMP)=$SELECT(Y:"Yes",1:"No")
+16 IF Y
QUIT
+17 WRITE !
SET X=0
FOR
SET X=$ORDER(^APCM24OB(APCMY,28,X))
IF X'=+X
QUIT
WRITE !,^APCM24OB(APCMY,28,X,0)
+18 WRITE !
SET DIR(0)="Y"
SET DIR("A")=$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_"'s answer"
SET DIR("B")="NO"
KILL DA
DO ^DIR
KILL DIR
+19 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+20 SET APCMADDQ("ANS",APCMY,28,APCMP)=$SELECT(Y:"Yes",1:"No")
End DoDot:1
+21 QUIT
ATTESTQ ;EP
+1 KILL APCMATTE
+2 SET APCMQ=0
+3 SET Z=0
FOR
SET Z=$ORDER(^APCM24OB("ATT",Z))
IF Z'=+Z
QUIT
SET A=0
FOR
SET A=$ORDER(^APCM24OB("ATT",Z,A))
IF A'=+A
QUIT
IF $DATA(APCMIND(A))
IF $PIECE(^APCM24OB(A,0),U,17)
SET X=$PIECE(^APCM24OB(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 WRITE !!,"Several Stage 2 Meaningful Use Performance Measures require an attestation of "
+7 WRITE !,"Yes or No for each provider for which the report is being run.",!
+8 SET DIR(0)="Y"
SET DIR("A")="Do you wish to continue"
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
+9 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+10 IF 'Y
SET APCMQ=1
QUIT
+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 WRITE !
+3 SET APCMY=$ORDER(^APCM24OB("B",APCMX,0))
+4 IF '$ORDER(^APCM24OB(APCMY,APCMQU,0))
QUIT
+5 IF APCMX="S2.020.EP.1"
Begin DoDot:2
+6 SET Y=$ORDER(^APCM24OB("B","S2.026.EP",0))
+7 IF $DATA(APCMIND(Y))
QUIT
+8 SET N=26
WRITE !
SET APCMZ=0
FOR
SET APCMZ=$ORDER(^APCM24OB(APCMY,26,APCMZ))
IF APCMZ'=+APCMZ
QUIT
WRITE !,^APCM24OB(APCMY,26,APCMZ,0)
+9 WRITE !
End DoDot:2
+10 SET X=0
FOR
SET X=$ORDER(^APCM24OB(APCMY,APCMQU,X))
IF X'=+X
QUIT
WRITE !,^APCM24OB(APCMY,APCMQU,X,0)
+11 IF APCMPLTY="SEL"!(APCMPLTY="TAX")
Begin DoDot:2
+12 SET APCMIND=0
+13 IF '$PIECE(^APCM24OB(APCMY,0),U,13)
Begin DoDot:3
+14 WRITE !
SET DIR(0)="Y"
SET DIR("A")="Do all selected providers included in this report"_$SELECT($PIECE($GET(^APCM24OB(APCMY,11)),U,1)]"":$PIECE(^APCM24OB(APCMY,11),U,1),1:" attest to this")
+15 SET DIR("B")="YES"
IF $PIECE(^APCM24OB(APCMY,0),U,1)="S2.026.EP"!($PIECE(^APCM24OB(APCMY,0),U,1)="S2.020.EP.1")
SET DIR("B")="NO"
SET DIR("B")="NO"
+16 KILL DA
DO ^DIR
KILL DIR
+17 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+18 IF 'Y
SET APCMIND=1
QUIT
+19 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
+20 IF $PIECE(^APCM24OB(APCMY,0),U,13)
Begin DoDot:3
+21 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
+22 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+23 IF 'Y
SET APCMIND=1
QUIT
+24 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
+25 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+26 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(^APCM24OB(APCMY,0),U,13)
SET DIR(0)="Y"
SET DIR("A")="Does "_$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_$SELECT($PIECE($GET(^APCM24OB(APCMY,11)),U,1)]"":$PIECE(^APCM24OB(APCMY,11),U,1),1:" attest to this")
+4 SET DIR("B")="YES"
IF $PIECE(^APCM24OB(APCMY,0),U,1)="S2.026.EP"!($PIECE(^APCM24OB(APCMY,0),U,1)="S2.020.EP.1")
SET DIR("B")="NO"
+5 KILL DA
DO ^DIR
KILL DIR
+6 IF $PIECE(^APCM24OB(APCMY,0),U,13)
SET DIR(0)="S^Y:YES;N:NO;X:No Registry Available"
Begin DoDot:3
+7 SET DIR("A")="Does "_$EXTRACT($PIECE(^VA(200,APCMP,0),U,1),1,25)_$SELECT($PIECE($GET(^APCM24OB(APCMY,11)),U,1)]"":$PIECE(^APCM24OB(APCMY,11),U,1),1:" attest to this")
SET DIR("B")="YES"
KILL DA
DO ^DIR
KILL DIR
End DoDot:3
+8 IF $DATA(DIRUT)
SET APCMQ=1
QUIT
+9 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
+10 QUIT
IMMREG ;EP - ask additional exclusion questions for IMM REG
+1 DO IMMREG^APCM24EA
+2 QUIT
SPECREG ;
+1 DO SPECREG^APCM24EA
+2 QUIT
SS DO SS^APCM24EA
+1 QUIT