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

SDWLRQ2.m

Go to the documentation of this file.
  1. SDWLRQ2 ;;IOFO BAY PINES/TEH - ADHOC WAIT LIST REPORT PRIM CARE TEAM AND POSITION ASSIGNMENTS;06/12/2002 ; 29 Aug 2002 2:53 PM
  1. ;;5.3;scheduling;**263,425,482**;AUG 13 1993
  1. ;
  1. ;
  1. ;******************************************************************
  1. ; CHANGE LOG
  1. ;
  1. ; DATE PATCH DESCRIPTION
  1. ; ---- ----- -----------
  1. ;
  1. ;
  1. ;
  1. ;
  1. EN ;Header
  1. N ZCODE,ZTDESC,ZTDTH,ZTIO,ZTQUEDED,ZTREQ,ZTRTN,ZTSAVE,ZTSK
  1. N SDTEAM,SDHIST,SDACTIVE
  1. D HD
  1. 1 S SDWLINST="",SDWLERR=0,SDWLE=0 K ^TMP("SDWLRQ2",$J),DIC,DIR,DR,DIE
  1. D INS G END:SDWLERR
  1. 2 D CAT G 1:SDWLERR
  1. 3 D OPEN G 2:SDWLERR
  1. S ^TMP("SDWLRQ2",$J,"DATE")=""
  1. 4 I %=2 D DATE G 3:SDWLERR
  1. 6 D FORM G 4:SDWLERR,END:$D(DUOUT)
  1. 7 D DIS G EN:SDWLERR=1,END:SDWLERR=2
  1. D QUE
  1. Q
  1. INS ;Get Institution
  1. S SDWLPROM="Select Institution ALL // ",SDWLERR=0
  1. IN W ! S DIC(0)="QEMA",DIC("A")=SDWLPROM,DIC=4,DIC("S")="I $D(^SCTM(404.51,""AINST"",+Y))" D ^DIC I Y<0,'SDWLE D
  1. .S (SDWLINS,SDWLINST)="" F S SDWLINS=$O(^SCTM(404.51,"AINST",SDWLINS)) Q:SDWLINS="" S SDWLINST=SDWLINST_SDWLINS_";"
  1. I X="^" S SDWLERR=1 Q
  1. G IN2:Y<0,END:$D(DUOUT)
  1. I Y="All"!(Y="")!(Y="all")!(Y="ALL") S ^TMP("SDWLRQ2",$J,"INS")=SDWLINST G IN3
  1. S SDWLINST=SDWLINST_+Y_";",SDWLPROM="Another Institution: ",SDWLE=1 G IN
  1. IN2 S ^TMP("SDWLRQ2",$J,"INS")=SDWLINST
  1. IN3 Q
  1. DATE ;Date range selection
  1. S %=1 W !,"Print Report for ALL dates? " D YN^DICN
  1. I %=1 S ^TMP("SDWLRQ2",$J,"DATE")="ALL" G E1
  1. Q:%=0
  1. Q:%=-1
  1. S SDWLERR=0 W ! S %DT="AE",%DT("A")="Start with Date Entered: " D ^%DT G E1:Y<1 S SDWLBDT=Y
  1. S %DT(0)=SDWLBDT,%DT("A")="End with Date Entered: " D ^%DT
  1. I X["^" S SDWLERR=1 Q
  1. G E1:Y<1 S SDWLEDT=Y K %DT(0),%DT("A")
  1. I SDWLEDT<SDWLBDT W !,"Beginning Date must be greater than Ending Date." G DATE
  1. S ^TMP("SDWLRQ2",$J,"DATE")=SDWLBDT_"^"_SDWLEDT Q
  1. E1 Q
  1. CAT ;Report category selection
  1. W !!," *** Report Category Selection ***" S SDWLERR=0
  1. S SDWLERR=0,SDWLCAT="",DIR(0)="S0^1:Team;2:Position",DIR("L",1)=" 1. Team",DIR("L")=" 2. Position"
  1. D ^DIR
  1. I X="^" S SDWLERR=1 Q
  1. S X=$S(X["T":"T",X["t":"T",X["P":"P",X["p":"P",X=1:"T",X=2:"P",1:"")
  1. I X="" W *7," Invalid Selection." G CAT
  1. W !!,"Select Category for Report Output",!
  1. S SDWLX=$S(X="T":"Team: ALL/ ",X="P":"Position: ALL/ ")
  1. S SDWLF=$S(X="T":404.51,X="P":404.57)
  1. K DIR,DIC,DR
  1. S ^TMP("SDWLRQ2",$J,"CT1")=X_"^"_SDWLF
  1. S DIC("A")=SDWLX
  1. I SDWLF=404.51 D
  1. .S DIC("S")="I $$ACTIVE^SDWLRQ2(Y),SDWLINST[+$P($G(^SCTM(404.51,+Y,0)),""^"",7)"
  1. CT1 W ! S DIC(0)="QEMNZA",DIC=SDWLF D ^DIC
  1. I X="^" S SDWLERR=1 Q
  1. I Y<1,SDWLCAT="" S ^TMP("SDWLRQ2",$J,"CT2")="ALL" G CT3
  1. I Y<0,'$D(^TMP("SDWLRQ2",$J,"CT1")) W !,"This Entry is Required." G CAT
  1. G CT2:Y<0
  1. S SDWLCAT=SDWLCAT_Y_";",DIC("A")="Another "_$P(SDWLX,":",1)_": ",SDWLE=1 G CT1
  1. CT2 G CT1:'$D(SDWLCAT) S ^TMP("SDWLRQ2",$J,"CT2")=SDWLCAT
  1. CT3 Q
  1. OPEN ;OPEN Wait List Entries
  1. S %=1 W !!,"Do you want only 'OPEN' Wait List Entries " D YN^DICN
  1. I '% W *7,"Must Enter 'YES' or 'NO'." G OPEN
  1. I %=-1 S SDWLERR=1
  1. S ^TMP("SDWLRQ2",$J,"OPEN")=$S(%=1:"O",1:"C")
  1. Q
  1. FORM ;Report Format
  1. S SDWLERR=0,DIR(0)="SO^1:Detailed;2:Summary",DIR("L",2)=" 1. Detailed"
  1. S DIR("L")=" 2. Summary",DIR("L",1)="Select One of the Following: "
  1. D ^DIR
  1. I X="^" S DUOUT=1 Q
  1. S X=$S(X["S":"S",X["s":"S",X["D":"D",X["d":"D",X=1:"D",X=2:"S",1:"")
  1. I X="" W *7," Invalid Response" G FORM
  1. S ^TMP("SDWLRQ2",$J,"FORM")=X
  1. Q
  1. DIS ;Display Parameters
  1. S SDWLERR=0 W !!,?80-$L("*** Selected Report Parameters ***")\2,"*** Selected Report Parameters ***",!
  1. F SDWLI="INS","CT1","CT2","FORM","OPEN" D
  1. .S X="SDWL"_SDWLI,@X=$G(^TMP("SDWLRQ2",$J,SDWLI))
  1. F SDWLTAG="IS","CT","OP","PR" D @SDWLTAG
  1. Q
  1. IS I SDWLINS'["ALL" D
  1. .K SDWLY F I=1:1 S SDWLY=$P($P(SDWLINS,";",I),U,1) Q:SDWLY="" S SDWLY(I)=SDWLY
  1. .W !,?20,"Institution: "
  1. .I $D(SDWLY) S I="" F S I=$O(SDWLY(I)) Q:I="" W:I>1 !,?33 W $P($G(^DIC(4,SDWLY(I),0)),U,1)
  1. .K SDWLY
  1. I SDWLINS["ALL" W !,?20,"Institution: ALL "
  1. Q
  1. CT I SDWLCT2'["ALL" D
  1. .S SDWLF=$P(SDWLCT1,U,2)
  1. .K SDWLY F I=1:1 S SDWLY=$P($P(SDWLCT2,";",I),U,2) Q:SDWLY="" S SDWLY(I)=SDWLY
  1. .W !,?16,"Report Category: " W $S(SDWLCT1["T":"Team",1:"Position"),!,?36 I @X="ALL" W "All "
  1. .I $D(SDWLY) S I="" F S I=$O(SDWLY(I)) Q:I="" W:I>1 !,?35 W $$EXTERNAL^DILFD(SDWLF,.01,,SDWLY(I))
  1. I SDWLCT2["ALL" W !,?16,"Report Category: " W $S(SDWLCT1["T":"Team",1:"Position"),!,?36 W "ALL "
  1. Q
  1. OP W !,?18,"Output Format: ",$S(SDWLFORM="D":" Detailed",1:" Summary")
  1. Q
  1. PR I SDWLOPEN="O" W !,?25,"Printing 'OPEN' Entries Only."
  1. E W !,?25,"Printing ALL Entries."
  1. S %=1 W !!,"Are these Parameters Correct " D YN^DICN I %=2 S SDWLERR=1 W !," This Report will NOT be queued to print."
  1. I SDWLERR S DIR(0)="E" D ^DIR I X["^" S SDWLERR=2
  1. Q
  1. ACTIVE(Y) ;Active Team
  1. S SDTEAM="",SDHIST="",SDACTIVE=""
  1. I SDWLF="404.51" D
  1. .S SDHIST=$O(^SCTM(404.58,"B",+Y,SDHIST),-1)
  1. .S SDACTIVE=$P($G(^SCTM(404.58,+SDHIST,0)),"^",3)
  1. Q +SDACTIVE
  1. QUE ;Queue Report
  1. N ZTQUEUED,POP
  1. K %ZIS,IOP,IOC,ZTIO,SDWLSPT S %ZIS="MQ" D ^%ZIS G:POP QUE1
  1. S ZTRTN=$S(SDWLFORM="D":"EN^SDWLRPT2",1:"EN^SDWLRPS2"),ZTDTH=$H,ZTDESC="WAIT LIST REPORT FORMAT 2"
  1. S SDWLTASK="" F S SDWLTASK=$O(^TMP("SDWLRQ2",$J,SDWLTASK)) Q:SDWLTASK="" D
  1. .S SDWLTK=$G(^TMP("SDWLRQ2",$J,SDWLTASK))
  1. .S ZTSAVE(SDWLTASK)=SDWLTK
  1. I $D(IO("Q")) K IO("Q") D ^%ZTLOAD W !,"REQUEST QUEUED" G END
  1. QUE1 S:$E(IOST,1,2)="C-" SDWLSPT=1 I $D(ZTRTN) U IO D @ZTRTN K SDWLSPT
  1. ;
  1. END K SDWLTASK,SDWLY,SDWLED,WDWLBD,SDWLOPEN,SDWLDATE,SDWLFORM,SDWLPRI
  1. K DIR,DIC,DR,DIE,SDWLSPT,I
  1. D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@"
  1. Q
  1. HD W:$D(IOF) @IOF W !,?80-$L("Primary Care Team/Position Assignment Wait List Report")\2,"Primary Care Team/Position Assignment Wait List Report"