source: FOIAVistA/trunk/r/AUTO_REPLENISHMENT_WARD_STOCK-PSGW/PSGWHV0.m@ 1154

Last change on this file since 1154 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 2.4 KB
Line 
1PSGWHV0 ;BHAM ISC/PTD,CML-High Volume for Selected Date Range (Single AOU or Cumulative) - CONTINUED ; 02/13/90 15:32
2 ;;2.3; Automatic Replenishment/Ward Stock ;;4 JAN 94
3ENQ ;ENTRY POINT WHEN QUEUED
4 K ^TMP("PSGWHV",$J) S INVN=0
5 F J=0:0 S INVN=$O(^PSI(58.19,INVN)) Q:'INVN S INVDT=$P($P(^PSI(58.19,INVN,0),"^"),".") I (INVDT'<BDT)&(INVDT'>EDT) S ^TMP("PSGWHV",$J,"INV",INVN)=""
6AOU I ALL=1 S AOU=$O(^PSI(58.1,AOU)) G:'AOU CONV I $P(^PSI(58.1,AOU,0),"^",3)=1 G AOU
7DRUG ;LOOP THROUGH DRUGS FOR AOU
8 S DRGDA=0
9DRGLP S DRGDA=$O(^PSI(58.1,AOU,1,DRGDA)) G:(ALL=0)&('DRGDA) CONV G:(ALL=1)&('DRGDA) AOU S DRGNM=$P(^PSI(58.1,AOU,1,DRGDA,0),"^")
10 ;
11AR ;AUTO REPLENISH INVENTORIES
12 S DRGQD=0,INVDA=0
13INVLP S INVDA=$O(^PSI(58.1,AOU,1,DRGDA,1,INVDA)) G:'INVDA OD
14 I $D(^TMP("PSGWHV",$J,"INV",INVDA)) S QD=$P(^PSI(58.1,AOU,1,DRGDA,1,INVDA,0),"^",5),DRGQD=DRGQD+QD
15 G INVLP
16 ;
17OD ;ON DEMAND REQUESTS
18 S ODA=0
19ODLP S ODA=$O(^PSI(58.1,AOU,1,DRGDA,5,ODA)) G:'ODA RET S ODT=$P($P(^PSI(58.1,AOU,1,DRGDA,5,ODA,0),"^"),".")
20 I (ODT'<BDT)&(ODT'>EDT) S QD=$P(^PSI(58.1,AOU,1,DRGDA,5,ODA,0),"^",2),DRGQD=DRGQD+QD
21 G ODLP
22 ;
23RET ;RETURNS
24 S RETDT=0
25RETLP S RETDT=$O(^PSI(58.1,AOU,1,DRGDA,3,RETDT)) G:'RETDT CHKDTA
26 I (RETDT'<BDT)&(RETDT'>EDT) S QD=$P(^PSI(58.1,AOU,1,DRGDA,3,RETDT,0),"^",2),DRGQD=DRGQD-QD
27 G RETLP
28 ;
29CHKDTA ;DETERMINE TOTAL COST FOR SELECTED DRUG
30 G:DRGQD=0 DRGLP S INC=0 I $D(^PSDRUG(DRGNM,660)) S LOC1=^(660)
31 E S INC=1
32 I $D(^PSDRUG(DRGNM,"PSG")) S LOC2=^("PSG")
33 E S INC=1
34 I $D(LOC1),($P(LOC1,"^",6)="") S INC=1
35 I $D(LOC2),($P(LOC2,"^",3)="") S INC=1
36COST I INC=0 S DRGCST=DRGQD*($P(LOC1,"^",6))
37 E S DRGCST="NO DATA"
38SETGL S ^TMP("PSGWHV",$J,DRGNM,AOU)=DRGQD_"^"_DRGCST G DRGLP
39 ;
40CONV S DRUG=0
41DRUGLP S (AOUN,TOTQD,TOTCST)=0 S DRUG=$O(^TMP("PSGWHV",$J,DRUG)) G:('DRUG)&($D(ZTQUEUED)) PRTQUE G:'DRUG EN1^PSGWHV1
42AOULP S AOUN=$O(^TMP("PSGWHV",$J,DRUG,AOUN)) G:'AOUN HIGH S LOCN=^TMP("PSGWHV",$J,DRUG,AOUN),QUAN=$P(LOCN,"^"),CST=$P(LOCN,"^",2),TOTQD=TOTQD+QUAN,TOTCST=$S(CST'="NO DATA":TOTCST+CST,1:"NO DATA") G AOULP
43 ;
44HIGH S DRN=$P(^PSDRUG(DRUG,0),"^"),CF=100000-TOTQD S:(TOTCST="NO DATA")!(TOTQD'<CUT) ^TMP("PSGWHV",$J,"VL",CF,DRN)=TOTQD_"^"_TOTCST G DRUGLP
45 ;
46PRTQUE ;AFTER DATA IS COMPILED, QUEUE THE PRINT
47 K ZTSAVE,ZTIO S ZTIO=PSGWIO,ZTRTN="^PSGWHV1",ZTDESC="Print High Volume",ZTDTH=$H,ZTSAVE("^TMP(""PSGWHV"",$J,")="" F G="BDT","EDT","AOU","ALL","CUT" S:$D(@G) ZTSAVE(G)=""
48 D ^%ZTLOAD K ^TMP("PSGWHV",$J) G END^PSGWHV1
49 ;
Note: See TracBrowser for help on using the repository browser.