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

SDAMODO.m

Go to the documentation of this file.
  1. SDAMODO ;ALB/SCK - PROVIDER DIAGNOSTICS REPORT ;05 Oct 98 8:39 PM
  1. ;;5.3;Scheduling;**25,132,159,586**;Aug 13, 1993;Build 28
  1. ;
  1. ; Reference to $$IMP^ICDEX supported by ICR #5747
  1. ;
  1. START ;
  1. N SORT1,SORT2,SDBEG,SDEND,VAUTD,CLINIC,PATN,PROVDR,STOPC,PDIAG
  1. N ICD10IMPDT S ICD10IMPDT=$$IMP^ICDEX(30) ;SSA ICD-10
  1. D HOME^%ZIS
  1. SORTS ;
  1. I '$$RANGE G EXIT
  1. I (SDBEG<ICD10IMPDT)&(SDEND>=ICD10IMPDT) W !!,$$LINE("Ending Date must be prior to "_$$FMTE^XLFDT(ICD10IMPDT,"5Z")_" for ICD9 diagnosis codes.") G SORTS ;SSA ICD-10
  1. I '$$DIV G EXIT
  1. I '$$SORT1 G EXIT
  1. I '$$SORT2 G EXIT
  1. PICKS ;
  1. I SORT1=1!(SORT2=1) G EXIT:'$$PROV
  1. I SORT1=2!(SORT2=2) G EXIT:'$$DIAG
  1. I SORT1=3!(SORT2=3) G EXIT:'$$PAT
  1. I SORT1=4!(SORT2=4) G EXIT:'$$CLINIC
  1. I SORT1=5!(SORT2=5) G EXIT:'$$STOP
  1. FIN ;
  1. I '$$COMPL G SORTS
  1. PRINT ;
  1. W !,"This report requires 132 columns for printout"
  1. S %ZIS="PMQ" D ^%ZIS G EXIT:POP
  1. I $D(IO("Q")) D QUE G EXIT
  1. W ! D WAIT^DICD
  1. D ^SDAMODO2
  1. EXIT ;
  1. D:'$D(ZTQUEUED) ^%ZISC
  1. K VAUTC,VAUTD,VAUTS,DIC,STR,CHECK,VAUTSTR,VAUTVB,X,Y,VAUTNI,SORT1,SORT2,SDEND,SDBEG
  1. Q
  1. ;
  1. CLINIC() ;
  1. W !!,$$LINE("Clinic Selection")
  1. S DIC="^SC(",VAUTSTR="Clinic",VAUTVB="CLINIC",VAUTNI=2,DIC("S")="I $P(^(0),U,3)[""C"""
  1. D FIRST^VAUTOMA
  1. I Y<0 K CLINIC
  1. Q $D(CLINIC)>0
  1. ;
  1. STOP() ;
  1. W !!,$$LINE("Stop Codes Selection")
  1. S DIC="^DIC(40.7,",VAUTSTR="Stop Code",VAUTVB="STOPC",VAUTNI=2
  1. D FIRST^VAUTOMA
  1. I Y<0 K STOPC
  1. Q $D(STOPC)>0
  1. ;
  1. PAT() ;
  1. W !!,$$LINE("Select Patients")
  1. S DIC="^DPT(",VAUTSTR="Patient",VAUTVB="PATN",VAUTNI=2
  1. D FIRST^VAUTOMA
  1. I Y<0 K PATN
  1. Q $D(PATN)>0
  1. ;
  1. PROV() ; select provider
  1. W !!,$$LINE("Select Providers")
  1. S DIC="^VA(200,",VAUTSTR="Provider",VAUTVB="PROVDR",VAUTNI=2
  1. D FIRST^VAUTOMA
  1. I Y<0 K PROVDR
  1. Q $D(PROVDR)>0
  1. ;
  1. DIAG() ;
  1. ; SSA ICD-10
  1. W !!,$$LINE("Select Diagnosis Code") S DIC="^ICD9(",VAUTSTR="Diagnosis "_$S(SDBEG<ICD10IMPDT:"(ICD9)",1:"(ICD10)"),VAUTVB="PDIAG",VAUTNI=2
  1. D FIRST^VAUTOMA
  1. I Y<0 K PDIAG
  1. Q $D(PDIAG)>0
  1. ;
  1. RANGE() ; select date range for report
  1. W !!,$$LINE("Date Range Selection")
  1. Q $$RANGE^SDAMQ(.SDBEG,.SDEND)
  1. ;
  1. SORT1() ; first level sort
  1. W !!,$$LINE("First level sort will be by Division")
  1. W !,$$LINE("Select Second Sort Level")
  1. S SORT1=$$OPTIONS(0)
  1. Q (Y)
  1. ;
  1. SORT2() ; second level sort
  1. W !!,$$LINE("Sorting by Division and "_$P($T(SORT+SORT1^SDAMODO1),";;",2))
  1. W !,$$LINE("Select Third Sort Level")
  1. S SORT2=$$OPTIONS(SORT1)
  1. Q (Y)
  1. ;
  1. DIV() ;
  1. W:$P($G(^DG(43,1,"GL")),U,2) !!,$$LINE("Division Selection")
  1. D ASK2^SDDIV I Y<0 K VAUTD
  1. Q $D(VAUTD)>0
  1. ;
  1. COMPL() ;
  1. I '$$SHOW^SDAMODO1 S Y=0 G COMPLQ
  1. S DIR(0)="Y",DIR("A")="Continue",DIR("?")="Enter 'Y'es or 'N'o.",DIR("B")="YES" D ^DIR
  1. COMPLQ Q (Y)
  1. ;
  1. LINE(STR) ; print display line
  1. N X
  1. S:STR]"" STR=" "_STR_" "
  1. S $P(X,"_",(IOM/2)-($L(STR)/2))=""
  1. Q X_STR_X
  1. ;
  1. OPTIONS(CHECK) ; display options for sorting reports
  1. S X="S^"
  1. S X=X_$S(CHECK=1:":[Selected];",1:"1:Provider;")
  1. ; SSA ICD-10
  1. I SDBEG<ICD10IMPDT S X=X_$S(CHECK=2:":[Selected];",1:"2:Diagnosis (ICD9) [DX];")
  1. I SDBEG>=ICD10IMPDT S X=X_$S(CHECK=2:":[Selected];",1:"2:Diagnosis (ICD10) [DX];")
  1. S X=X_$S(CHECK=3:":[Selected];",1:"3:Patient;")
  1. S X=X_$S(CHECK=4:":[Selected];",1:"4:Clinic;")
  1. S X=X_$S(CHECK=5:":[Selected]",1:"5:Primary Stop Code")
  1. S DIR(0)=X,DIR("A")="Select Sort Option"
  1. D ^DIR K DIR
  1. Q (+Y)
  1. ;
  1. QUE ;
  1. S ZTRTN="^SDAMODO2",ZTDESC="PROVIDER DX REPORT"
  1. F X="SORT1","SORT2","SDBEG","SDEND","VAUTD(","CLINIC(","PATN(","PROVDR(","STOPC(","PDIAG(","VAUTD","CLINIC","PATN","PROVDR","STOPC","PDIAG","ICD10IMPDT" S ZTSAVE(X)=""
  1. D ^%ZTLOAD W:$D(ZTSK) !,"TASK #: ",ZTSK
  1. D HOME^%ZIS K IO("Q")
  1. Q
  1. ;
  1. ERR ;
  1. W !!,"NOT AVAILABLE"
  1. Q
  1. ;