| 1 | PRCPRUSE ;WISC/RFJ,DWA,VAC-usage demand item report  ; 10/19/06 9:53am | 
|---|
| 2 | V ;;5.1;IFCAP;**1,27,84,98**;Oct 20, 2000;Build 37 | 
|---|
| 3 | ;Per VHA Directive 2004-038, this routine should not be modified. | 
|---|
| 4 | D ^PRCPUSEL Q:'$G(PRCP("I")) | 
|---|
| 5 | ; | 
|---|
| 6 | N DATEEND,DATEENDD,DATESTRD,DATESTRT,DIR,GROUPALL,PRCPALLI,PRCPEND,PRCPSTRT,TOTALDAY,X,X1,X2,Y | 
|---|
| 7 | N ODIFLG,ODITEM,REORDER,PRCPSORT | 
|---|
| 8 | ; | 
|---|
| 9 | K X S X(1)="The Usage Demand Item Report will show the quantity of items used within a specified date period." | 
|---|
| 10 | D DISPLAY^PRCPUX2(40,79,.X) | 
|---|
| 11 | ; | 
|---|
| 12 | K X S X(1)="Select the date range which should be used for displaying the usage.        *** Select by month & year only. ***" | 
|---|
| 13 | D DISPLAY^PRCPUX2(2,40,.X) | 
|---|
| 14 | D MONTHSEL^PRCPURS2 | 
|---|
| 15 | I '$G(DATEEND) Q | 
|---|
| 16 | ; | 
|---|
| 17 | S X1=DATEEND,X2=DATESTRT D ^%DTC S TOTALDAY=X+1 | 
|---|
| 18 | S Y=DATEEND D DD^%DT | 
|---|
| 19 | S DATEENDD=Y,Y=DATESTRT D DD^%DT | 
|---|
| 20 | S DATESTRD=Y | 
|---|
| 21 | W !?5,"-- TOTAL NUMBER OF DAYS: ",TOTALDAY | 
|---|
| 22 | ; | 
|---|
| 23 | ;  item(s) | 
|---|
| 24 | K X S X(1)="Select specific items to display." | 
|---|
| 25 | D DISPLAY^PRCPUX2(2,40,.X) | 
|---|
| 26 | D ITEMSEL^PRCPURS4 | 
|---|
| 27 | I '$G(PRCPALLI),'$O(^TMP($J,"PRCPURS4","")) Q | 
|---|
| 28 | I '$G(PRCPALLI) D  G SORT | 
|---|
| 29 | .   S GROUPALL=1 | 
|---|
| 30 | ; | 
|---|
| 31 | ;  whse sort | 
|---|
| 32 | I PRCP("DPTYPE")="W" D  I '$D(PRCPSTRT) Q | 
|---|
| 33 | .   K X S X(1)="Select the range of NSNs to display" D DISPLAY^PRCPUX2(2,40,.X) | 
|---|
| 34 | .   D NSNSEL^PRCPURS0 | 
|---|
| 35 | ; | 
|---|
| 36 | ;  prim/seco sort | 
|---|
| 37 | I PRCP("DPTYPE")'="W" D  I '$G(GROUPALL),'$O(^TMP($J,"PRCPURS1","YES",0)) W !,"*** NO GROUP CATEGORIES SELECTED !" Q | 
|---|
| 38 | .   K X S X(1)="Select the Group Categories to display" D DISPLAY^PRCPUX2(2,40,.X) | 
|---|
| 39 | .   D GROUPSEL^PRCPURS1(PRCP("I")) | 
|---|
| 40 | ; | 
|---|
| 41 | SORT S ODIFLG=3 | 
|---|
| 42 | I PRCP("DPTYPE")'="W" D | 
|---|
| 43 | .Q:$G(PRCPALLI)="" | 
|---|
| 44 | .S ODIFLG=$$ODIPROM^PRCPUX2(0) | 
|---|
| 45 | Q:ODIFLG=0 | 
|---|
| 46 | S PRCPSORT=$$SRTPRMP^PRCPUX2(0) | 
|---|
| 47 | Q:PRCPSORT=0 | 
|---|
| 48 | ; | 
|---|
| 49 | QUEUE S %ZIS="Q" D ^%ZIS Q:POP  I $D(IO("Q")) D  Q | 
|---|
| 50 | .   S ZTDESC="Usage Demand Item Report",ZTRTN="DQ^PRCPRUSE" | 
|---|
| 51 | .   S ZTSAVE("^TMP($J,""PRCPURS4"",")="",ZTSAVE("^TMP($J,""PRCPURS1"",")="",ZTSAVE(ODIFLG)="" | 
|---|
| 52 | .   S ZTSAVE("DATE*")="",ZTSAVE("GROUP*")="",ZTSAVE("PRCP*")="",ZTSAVE("TOTALDAY")="",ZTSAVE("ZTREQ")="@" | 
|---|
| 53 | .   S ZTSAVE("O*")="" | 
|---|
| 54 | .   D ^%ZTLOAD | 
|---|
| 55 | W !!,"<*> please wait <*>" | 
|---|
| 56 | ; | 
|---|
| 57 | DQ ;  queue starts here | 
|---|
| 58 | N %,%H,%I,COLUMN,DATA,DATE,DESCR,GROUP,GROUPNM,ITEMDA,MONYR,NOW,NSN,PAGE,PRCPFLAG,SCREEN,TOTCOST,TOTUSED,TTOTCOST,TTOTUSED,VALUE,X,Y | 
|---|
| 59 | K ^TMP($J,"PRCPRUSE") | 
|---|
| 60 | S ITEMDA=0 | 
|---|
| 61 | I $G(PRCPALLI) F  S ITEMDA=$O(^PRCP(445,PRCP("I"),1,ITEMDA)) Q:'ITEMDA  S DATA=$G(^(ITEMDA,0)) I DATA'="" D | 
|---|
| 62 | .   S DESCR=$$DESCR^PRCPUX1(PRCP("I"),ITEMDA) | 
|---|
| 63 | .   S VALUE=DESCR_"^"_$$UNIT^PRCPUX1(PRCP("I"),ITEMDA,"/")_"^"_$P(DATA,"^",15)_"^"_$P(DATA,"^",22)_"^"_($P(DATA,"^",7)+$P(DATA,"^",19)) | 
|---|
| 64 | .   ; | 
|---|
| 65 | .   ;  sort for whse | 
|---|
| 66 | .   I PRCP("DPTYPE")="W" D  Q | 
|---|
| 67 | .   .   S NSN=$$NSN^PRCPUX1(ITEMDA) S:NSN="" NSN=" " | 
|---|
| 68 | .   .   I $E(NSN,1,$L(PRCPSTRT))'=PRCPSTRT,$E(NSN,1,$L(PRCPEND))'=PRCPEND I NSN']PRCPSTRT!(PRCPEND']NSN) Q | 
|---|
| 69 | .   .   I PRCPSORT=1 S ^TMP($J,"PRCPRUSE",NSN,$E(DESCR,1,15),ITEMDA)=VALUE | 
|---|
| 70 | .   .   I PRCPSORT=2 S ^TMP($J,"PRCPRUSE",NSN,$E("000000000",$L(ITEMDA)+1,9)_ITEMDA,ITEMDA)=VALUE | 
|---|
| 71 | .   ; | 
|---|
| 72 | .   ;  sort for primary and secondary | 
|---|
| 73 | .   S GROUP=+$P(DATA,"^",21) | 
|---|
| 74 | .   I 'GROUP,'$G(GROUPALL) Q | 
|---|
| 75 | .   I $G(GROUPALL),$D(^TMP($J,"PRCPURS1","NO",GROUP)) Q | 
|---|
| 76 | .   I '$G(GROUPALL),'$D(^TMP($J,"PRCPURS1","YES",GROUP)) Q | 
|---|
| 77 | .   S GROUPNM=$$GROUPNM^PRCPEGRP(GROUP) | 
|---|
| 78 | .   I GROUPNM'="" S GROUPNM=$E(GROUPNM,1,20)_" (#"_GROUP_")" | 
|---|
| 79 | .   S:GROUPNM="" GROUPNM=" " | 
|---|
| 80 | .   I PRCPSORT=1 S ^TMP($J,"PRCPRUSE",GROUPNM,$E(DESCR,1,15),ITEMDA)=VALUE | 
|---|
| 81 | .   I PRCPSORT=2 S ^TMP($J,"PRCPRUSE",GROUPNM,$E("000000000",$L(ITEMDA)+1,9)_ITEMDA,ITEMDA)=VALUE | 
|---|
| 82 | ; | 
|---|
| 83 | I '$G(PRCPALLI) F  S ITEMDA=$O(^TMP($J,"PRCPURS4",ITEMDA)) Q:'ITEMDA  S DATA=$G(^PRCP(445,PRCP("I"),1,ITEMDA,0)) I DATA'="" D | 
|---|
| 84 | .   S DESCR=$$DESCR^PRCPUX1(PRCP("I"),ITEMDA) | 
|---|
| 85 | .   S VALUE=DESCR_"^"_$$UNIT^PRCPUX1(PRCP("I"),ITEMDA,"/")_"^"_$P(DATA,"^",15)_"^"_$P(DATA,"^",22)_"^"_($P(DATA,"^",7)+$P(DATA,"^",19)) | 
|---|
| 86 | .   ; | 
|---|
| 87 | .   ;  sort for whse | 
|---|
| 88 | .   I PRCP("DPTYPE")="W" D  Q | 
|---|
| 89 | .   .   S NSN=$$NSN^PRCPUX1(ITEMDA) S:NSN="" NSN=" " | 
|---|
| 90 | .   .   I PRCPSORT=1 S ^TMP($J,"PRCPRUSE",NSN,$E(DESCR,1,15),ITEMDA)=VALUE | 
|---|
| 91 | .   .   I PRCPSORT=2 S ^TMP($J,"PRCPRUSE",NSN,$E("000000000",$L(ITEMDA)+1,9)_ITEMDA,ITEMDA)=VALUE | 
|---|
| 92 | .   ; | 
|---|
| 93 | .   ;  sort for primary and secondary | 
|---|
| 94 | .   S GROUP=+$P(DATA,"^",21) | 
|---|
| 95 | .   I 'GROUP,'$G(GROUPALL) Q | 
|---|
| 96 | .   I $G(GROUPALL),$D(^TMP($J,"PRCPURS1","NO",GROUP)) Q | 
|---|
| 97 | .   I '$G(GROUPALL),'$D(^TMP($J,"PRCPURS1","YES",GROUP)) Q | 
|---|
| 98 | .   S GROUPNM=$$GROUPNM^PRCPEGRP(GROUP) | 
|---|
| 99 | .   I GROUPNM'="" S GROUPNM=$E(GROUPNM,1,20)_" (#"_GROUP_")" | 
|---|
| 100 | .   S:GROUPNM="" GROUPNM=" " | 
|---|
| 101 | .   I PRCPSORT=1 S ^TMP($J,"PRCPRUSE",GROUPNM,$E(DESCR,1,15),ITEMDA)=VALUE | 
|---|
| 102 | .   I PRCPSORT=2 S ^TMP($J,"PRCPRUSE",GROUPNM,$E("000000000",$L(ITEMDA)+1,9)_ITEMDA,ITEMDA)=VALUE | 
|---|
| 103 | ; | 
|---|
| 104 | D PRINT^PRCPRUSP | 
|---|
| 105 | Q | 
|---|