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

KMPRP1.m

Go to the documentation of this file.
  1. KMPRP1 ;SFISC/RAK - RUM Data by Option ;4 Nov 1998
  1. ;;1.0;CAPACITY MANAGEMENT - RUM;;Dec 09, 1998
  1. EN ;-- entry point.
  1. ;
  1. N %ZIS,CONT,DIC,IORVOFF,IORVON,KMPRDATE,KMPROPT,OUT,POP
  1. N X,Y,ZTDESC,ZTRTN,ZTSAVE,ZTSK
  1. ;
  1. D ZIS^KMPRUTL
  1. S OUT=0
  1. F D Q:OUT
  1. .W @IOF,!,?30,IORVON," RUM Data by Option ",IORVOFF,!
  1. .K DIC S DIC=19,DIC(0)="AEMQZ",DIC("A")="Select Option: "
  1. .W ! D ^DIC I Y<0 S OUT=1 Q
  1. .S KMPROPT=+Y_"^"_Y(0,0)
  1. .; determine start date from file 8971.1
  1. .D RUMDATES^KMPRUTL(.KMPRDATE)
  1. .Q:'KMPRDATE
  1. .; select output device.
  1. .S %ZIS="Q",%ZIS("A")="Device: ",%ZIS("B")="HOME"
  1. .W ! D ^%ZIS I POP W !,"No action taken." Q
  1. .; if queued.
  1. .I $D(IO("Q")) K IO("Q") D Q
  1. ..S ZTDESC="RUM Data by Option for '"_$P(KMPROPT,U,2)_"'."
  1. ..S ZTRTN="EN1^KMPRP1"
  1. ..S ZTSAVE("KMPRDATE")="",ZTSAVE("KMPROPT")=""
  1. ..D ^%ZTLOAD W:$G(ZTSK) !,"Task #",ZTSK
  1. ..D EXIT
  1. .;
  1. .; if output to terminal display message.
  1. .W:$E(IOST,1,2)="C-" !?3,"...compiling data..."
  1. .D EN1
  1. Q
  1. ;
  1. EN1 ;-- entry point from taskman.
  1. ;
  1. Q:'$G(KMPRDATE)
  1. Q:$G(KMPROPT)=""
  1. ;
  1. N ELEMENT,KMPRARRY,KMPRDAYS
  1. ;
  1. ; set elements data into ELEMENT() array.
  1. D ELEARRY^KMPRUTL("ELEMENT") Q:'$D(ELEMENT)
  1. S KMPRARRY=$NA(^TMP("KMPR OPT DATA",$J))
  1. K @KMPRARRY
  1. D DATA,PRINT,EXIT
  1. K @KMPRARRY
  1. ;
  1. Q
  1. ;
  1. DATA ;-- set data into KMPRARRY
  1. Q:'$D(ELEMENT)
  1. Q:$G(KMPRARRY)=""
  1. Q:'$G(KMPRDATE)
  1. Q:$G(KMPROPT)=""
  1. ;
  1. N DATE,END,I,IEN,OPTION,START
  1. ;
  1. ; start and end dates.
  1. S START=$P(KMPRDATE,U),END=$P(KMPRDATE,U,2)
  1. S DATE=START-.1,KMPRDAYS=0
  1. F S DATE=$O(^KMPR(8971.1,"B",DATE)) Q:'DATE!(DATE>END) D
  1. .S IEN=0,KMPRDAYS=KMPRDAYS+1
  1. .F S IEN=$O(^KMPR(8971.1,"B",DATE,IEN)) Q:'IEN D
  1. ..Q:'$D(^KMPR(8971.1,IEN,0)) S DATA(0)=^(0),DATA(1)=$G(^(1)),DATA(2)=$G(^(2))
  1. ..S OPTION=$P(DATA(0),U,4)
  1. ..Q:OPTION'=$P(KMPROPT,U,2)
  1. ..F I=1:1:8 D
  1. ...S $P(@KMPRARRY@(OPTION),U,I)=$P($G(@KMPRARRY@(OPTION)),U,I)+$P(DATA(1),U,I)
  1. ...S $P(@KMPRARRY@(OPTION),U,I)=$P($G(@KMPRARRY@(OPTION)),U,I)+$P(DATA(2),U,I)
  1. ;
  1. Q
  1. ;
  1. EXIT ;
  1. S:$D(ZTQUEUED) ZTREQ="@"
  1. D ^%ZISC
  1. K KMPUDATE,KMPUNAM
  1. ;
  1. Q
  1. ;
  1. PRINT ;-- print data from KMPRARRY.
  1. Q:'$D(ELEMENT)
  1. Q:$G(KMPRARRY)=""
  1. ;
  1. U IO
  1. ;
  1. N DATA,OCCUR,I,NUMBER,PIECE,SITE
  1. ;
  1. ; facility name.
  1. S SITE=$$SITE^VASITE
  1. S SITE=$P(SITE,U,2)_" ("_$P(SITE,U,3)_")"
  1. ;
  1. I '$D(@KMPRARRY) D Q
  1. .D HDR
  1. .W !!!?28,"<<<No Data to Report>>>"
  1. .W !! D CONTINUE^KMPRUTL("Press RETURN to continue",.CONT)
  1. ;
  1. S OPTION=""
  1. F S OPTION=$O(@KMPRARRY@(OPTION)) Q:OPTION="" D
  1. .D HDR S DATA=@KMPRARRY@(OPTION),I=0,OCCUR=$P(DATA,U,8)
  1. .F S I=$O(ELEMENT(I)) Q:'I D
  1. ..W !,$P(ELEMENT(I),U) S PIECE=$P(ELEMENT(I),U,2)
  1. ..W $$REPEAT^XLFSTR(".",25-$X)
  1. ..S NUMBER=$P(DATA,U,PIECE)
  1. ..; per occurrence.
  1. ..W:PIECE'=8 ?28,$J($FN(NUMBER/OCCUR,",",$S(I<3:2,1:0)),$S(I<3:14,1:11))
  1. ..W ?50,$J($FN(NUMBER,",",$S(I<3:2,1:0)),$S(I<3:18,1:15))
  1. ;
  1. W !! D CONTINUE^KMPRUTL("Press RETURN to continue",.CONT)
  1. ;
  1. Q
  1. ;
  1. HDR ;
  1. N TITLE
  1. W:$Y @IOF
  1. S TITLE="RUM Data for Option: "_$P(KMPROPT,U,2)
  1. W !?(80-$L(TITLE)\2),TITLE
  1. W !?(80-$L($G(SITE))\2),$G(SITE)
  1. W !?23,"For "_$P($G(KMPRDATE),U,3)_" to "_$P($G(KMPRDATE),U,4)
  1. W !
  1. W !?28,"per Occurrence",?50," Totals"
  1. W !
  1. ;
  1. Q