- PSGWCPA ;BHAM ISC/PTD,CML-Cost Per AOU for Selected Date Range ; 03 Sep 93 / 12:07 PM
- ;;2.3;Automatic Replenishment/Ward Stock ;**21**;4 JAN 94;Build 6
- W !?5,"Before printing this report, be sure accurate data exists for drug cost.",!?5,"Use ""Prepare AMIS Data"": ""Enter AMIS Data for All Drugs/All AOUs"".",!!
- BDT S %DT="AEX",%DT("A")="BEGINNING date for report: " D ^%DT K %DT G:Y<0 END^PSGWCPA1 S BDT=Y
- EDT S %DT="AEX",%DT(0)=BDT,%DT("A")="ENDING date for report: " D ^%DT K %DT G:Y<0 END^PSGWCPA1 S EDT=Y
- D SEL^PSGWUTL1 G:'$D(SEL) END^PSGWCPA1 G:SEL="I" AOUCNT
- ASKAOU F JJ=0:0 S DIC="^PSI(58.1,",DIC(0)="QEAM" D ^DIC K DIC Q:Y<0 S AOULP(+Y)=""
- I '$D(AOULP)&(X'="^ALL") G END^PSGWCPA1
- I X="^ALL" F AOU=0:0 S AOU=$O(^PSI(58.1,AOU)) Q:'AOU S AOULP(AOU)=""
- AOUCNT G:'$D(AOULP) END^PSGWCPA1 S AOUCNT=0 F JJ=0:0 S JJ=$O(AOULP(JJ)) Q:'JJ S AOUCNT=AOUCNT+1
- W !!,"Do you want to print:",!?5,"(1) A complete report",!?5,"(2) Totals and Summaries only"
- ASKPRT R !!,"Enter '1' or '2': ",FLG:DTIME S:'$T FLG="^" G:"^"[FLG END^PSGWCPA1
- I FLG?1."?"!((FLG'=1)&(FLG'=2)) W *7,!!,"Enter '1' to print a complete report including all items in the AOU.",!,"Enter '2' to print only the totals for the AOU(s) and Cost Summaries." G ASKPRT
- W !!,"The right margin for this report is 80.",!,"You may queue the report to print at a later time.",!!
- DEV K %ZIS,IOP S %ZIS="QM",%ZIS("B")="" D ^%ZIS I POP W !,"NO DEVICE SELECTED OR REPORT PRINTED!" G END^PSGWCPA1
- I $D(IO("Q")) K IO("Q") S PSGWIO=ION,ZTIO="" K ZTSAVE,ZTDTH,ZTSK S ZTRTN="ENQ^PSGWCPA",ZTDESC="Compile Cost per AOU" S:$D(AOULP) ZTSAVE("AOULP(")="" F G="BDT","EDT","FLG","PSGWIO","AOUCNT","SEL","IGDA" S:$D(@G) ZTSAVE(G)=""
- I D ^%ZTLOAD,HOME^%ZIS K ZTSK G END^PSGWCPA1
- U IO
- ;
- ENQ ;ENTRY POINT WHEN QUEUED
- ;CREATE ARRAY OF INVENTORY NUMBERS THAT FALL IN DATE RANGE.
- K ^TMP("PSGWCPA",$J) S (INVN,AOU)=0
- 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("PSGWCPA",$J,"INV",INVN)=""
- AOU S AOU=$O(AOULP(AOU)) G:('AOU)&($D(ZTQUEUED)) PRTQUE G:'AOU EN1^PSGWCPA1
- DRUG ;LOOP THROUGH DRUGS FOR AOU
- S DRGDA=0
- DRGLP S DRGDA=$O(^PSI(58.1,AOU,1,DRGDA)) G:'DRGDA AOU S DRGNM=$P(^PSI(58.1,AOU,1,DRGDA,0),"^"),DRGNAME=$P(^PSDRUG(DRGNM,0),"^")
- ;
- AR ;AUTOMATIC REPLENISHMENT INVENTORIES
- S DRGQD=0,INVDA=0
- INVLP S INVDA=$O(^PSI(58.1,AOU,1,DRGDA,1,INVDA)) G:'INVDA OD
- I $D(^TMP("PSGWCPA",$J,"INV",INVDA)) S QD=$P(^PSI(58.1,AOU,1,DRGDA,1,INVDA,0),"^",5),DRGQD=DRGQD+QD G INVLP
- E G INVLP
- ;
- OD ;ON DEMAND REQUESTS
- S ODA=0
- ODLP 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),"^"),".")
- I (ODT'<BDT)&(ODT'>EDT) S QD=$P(^PSI(58.1,AOU,1,DRGDA,5,ODA,0),"^",2),DRGQD=DRGQD+QD G ODLP
- E G ODLP
- ;
- RET ;RETURNS
- S RETDT=0
- RETLP S RETDT=$O(^PSI(58.1,AOU,1,DRGDA,3,RETDT)) G:'RETDT CHKDTA
- I (RETDT'<BDT)&(RETDT'>EDT) S QD=$P(^PSI(58.1,AOU,1,DRGDA,3,RETDT,0),"^",2),DRGQD=DRGQD-QD G RETLP
- E G RETLP
- ;
- CHKDTA ;DETERMINE TOTAL COST FOR DRGQD OF SELECTED DRUG
- G:DRGQD=0 DRGLP S INC=0 I $D(^PSDRUG(DRGNM,660)) S LOC1=^(660)
- E S INC=1
- I $D(^PSDRUG(DRGNM,"PSG")) S LOC2=^("PSG")
- E S INC=1
- I $D(LOC1),($P(LOC1,"^",6)="") S INC=1
- I $D(LOC2),($P(LOC2,"^",3)="") S INC=1
- ; PSGW*2.3*21 - USE AR/WS AMIS CONVERSION NUMBER
- S PSGWCNM=$S($P($G(LOC2),"^",3)="":1,1:$P(LOC2,"^",3))
- ;
- COST I INC=0 S DRGCST=DRGQD*($P(LOC1,"^",6))*PSGWCNM
- E S DRGCST="NO DATA"
- SETGL S ^TMP("PSGWCPA",$J,AOU,DRGNAME)=DRGQD_"^"_DRGCST G DRGLP
- ;
- PRTQUE ;AFTER DATA IS COMPILED, QUEUE THE PRINT
- K ZTSAVE,ZTIO S ZTIO=PSGWIO,ZTRTN="^PSGWCPA1",ZTDESC="Print Cost per AOU",ZTDTH=$H,ZTSAVE("^TMP(""PSGWCPA"",$J,")="" F G="BDT","EDT","FLG","AOUCNT","SEL","IGDA" S:$D(@G) ZTSAVE(G)=""
- D ^%ZTLOAD K ^TMP("PSGWCPA",$J) G END^PSGWCPA1
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSGWCPA 3820 printed Jan 18, 2025@02:40:23 Page 2
- PSGWCPA ;BHAM ISC/PTD,CML-Cost Per AOU for Selected Date Range ; 03 Sep 93 / 12:07 PM
- +1 ;;2.3;Automatic Replenishment/Ward Stock ;**21**;4 JAN 94;Build 6
- +2 WRITE !?5,"Before printing this report, be sure accurate data exists for drug cost.",!?5,"Use ""Prepare AMIS Data"": ""Enter AMIS Data for All Drugs/All AOUs"".",!!
- BDT SET %DT="AEX"
- SET %DT("A")="BEGINNING date for report: "
- DO ^%DT
- KILL %DT
- if Y<0
- GOTO END^PSGWCPA1
- SET BDT=Y
- EDT SET %DT="AEX"
- SET %DT(0)=BDT
- SET %DT("A")="ENDING date for report: "
- DO ^%DT
- KILL %DT
- if Y<0
- GOTO END^PSGWCPA1
- SET EDT=Y
- +1 DO SEL^PSGWUTL1
- if '$DATA(SEL)
- GOTO END^PSGWCPA1
- if SEL="I"
- GOTO AOUCNT
- ASKAOU FOR JJ=0:0
- SET DIC="^PSI(58.1,"
- SET DIC(0)="QEAM"
- DO ^DIC
- KILL DIC
- if Y<0
- QUIT
- SET AOULP(+Y)=""
- +1 IF '$DATA(AOULP)&(X'="^ALL")
- GOTO END^PSGWCPA1
- +2 IF X="^ALL"
- FOR AOU=0:0
- SET AOU=$ORDER(^PSI(58.1,AOU))
- if 'AOU
- QUIT
- SET AOULP(AOU)=""
- AOUCNT if '$DATA(AOULP)
- GOTO END^PSGWCPA1
- SET AOUCNT=0
- FOR JJ=0:0
- SET JJ=$ORDER(AOULP(JJ))
- if 'JJ
- QUIT
- SET AOUCNT=AOUCNT+1
- +1 WRITE !!,"Do you want to print:",!?5,"(1) A complete report",!?5,"(2) Totals and Summaries only"
- ASKPRT READ !!,"Enter '1' or '2': ",FLG:DTIME
- if '$TEST
- SET FLG="^"
- if "^"[FLG
- GOTO END^PSGWCPA1
- +1 IF FLG?1."?"!((FLG'=1)&(FLG'=2))
- WRITE *7,!!,"Enter '1' to print a complete report including all items in the AOU.",!,"Enter '2' to print only the totals for the AOU(s) and Cost Summaries."
- GOTO ASKPRT
- +2 WRITE !!,"The right margin for this report is 80.",!,"You may queue the report to print at a later time.",!!
- DEV KILL %ZIS,IOP
- SET %ZIS="QM"
- SET %ZIS("B")=""
- DO ^%ZIS
- IF POP
- WRITE !,"NO DEVICE SELECTED OR REPORT PRINTED!"
- GOTO END^PSGWCPA1
- +1 IF $DATA(IO("Q"))
- KILL IO("Q")
- SET PSGWIO=ION
- SET ZTIO=""
- KILL ZTSAVE,ZTDTH,ZTSK
- SET ZTRTN="ENQ^PSGWCPA"
- SET ZTDESC="Compile Cost per AOU"
- if $DATA(AOULP)
- SET ZTSAVE("AOULP(")=""
- FOR G="BDT","EDT","FLG","PSGWIO","AOUCNT","SEL","IGDA"
- if $DATA(@G)
- SET ZTSAVE(G)=""
- +2 IF $TEST
- DO ^%ZTLOAD
- DO HOME^%ZIS
- KILL ZTSK
- GOTO END^PSGWCPA1
- +3 USE IO
- +4 ;
- ENQ ;ENTRY POINT WHEN QUEUED
- +1 ;CREATE ARRAY OF INVENTORY NUMBERS THAT FALL IN DATE RANGE.
- +2 KILL ^TMP("PSGWCPA",$JOB)
- SET (INVN,AOU)=0
- +3 FOR J=0:0
- SET INVN=$ORDER(^PSI(58.19,INVN))
- if 'INVN
- QUIT
- SET INVDT=$PIECE($PIECE(^PSI(58.19,INVN,0),"^"),".")
- IF (INVDT'<BDT)&(INVDT'>EDT)
- SET ^TMP("PSGWCPA",$JOB,"INV",INVN)=""
- AOU SET AOU=$ORDER(AOULP(AOU))
- if ('AOU)&($DATA(ZTQUEUED))
- GOTO PRTQUE
- if 'AOU
- GOTO EN1^PSGWCPA1
- DRUG ;LOOP THROUGH DRUGS FOR AOU
- +1 SET DRGDA=0
- DRGLP SET DRGDA=$ORDER(^PSI(58.1,AOU,1,DRGDA))
- if 'DRGDA
- GOTO AOU
- SET DRGNM=$PIECE(^PSI(58.1,AOU,1,DRGDA,0),"^")
- SET DRGNAME=$PIECE(^PSDRUG(DRGNM,0),"^")
- +1 ;
- AR ;AUTOMATIC REPLENISHMENT INVENTORIES
- +1 SET DRGQD=0
- SET INVDA=0
- INVLP SET INVDA=$ORDER(^PSI(58.1,AOU,1,DRGDA,1,INVDA))
- if 'INVDA
- GOTO OD
- +1 IF $DATA(^TMP("PSGWCPA",$JOB,"INV",INVDA))
- SET QD=$PIECE(^PSI(58.1,AOU,1,DRGDA,1,INVDA,0),"^",5)
- SET DRGQD=DRGQD+QD
- GOTO INVLP
- +2 IF '$TEST
- GOTO INVLP
- +3 ;
- OD ;ON DEMAND REQUESTS
- +1 SET ODA=0
- ODLP SET ODA=$ORDER(^PSI(58.1,AOU,1,DRGDA,5,ODA))
- if 'ODA
- GOTO RET
- SET ODT=$PIECE($PIECE(^PSI(58.1,AOU,1,DRGDA,5,ODA,0),"^"),".")
- +1 IF (ODT'<BDT)&(ODT'>EDT)
- SET QD=$PIECE(^PSI(58.1,AOU,1,DRGDA,5,ODA,0),"^",2)
- SET DRGQD=DRGQD+QD
- GOTO ODLP
- +2 IF '$TEST
- GOTO ODLP
- +3 ;
- RET ;RETURNS
- +1 SET RETDT=0
- RETLP SET RETDT=$ORDER(^PSI(58.1,AOU,1,DRGDA,3,RETDT))
- if 'RETDT
- GOTO CHKDTA
- +1 IF (RETDT'<BDT)&(RETDT'>EDT)
- SET QD=$PIECE(^PSI(58.1,AOU,1,DRGDA,3,RETDT,0),"^",2)
- SET DRGQD=DRGQD-QD
- GOTO RETLP
- +2 IF '$TEST
- GOTO RETLP
- +3 ;
- CHKDTA ;DETERMINE TOTAL COST FOR DRGQD OF SELECTED DRUG
- +1 if DRGQD=0
- GOTO DRGLP
- SET INC=0
- IF $DATA(^PSDRUG(DRGNM,660))
- SET LOC1=^(660)
- +2 IF '$TEST
- SET INC=1
- +3 IF $DATA(^PSDRUG(DRGNM,"PSG"))
- SET LOC2=^("PSG")
- +4 IF '$TEST
- SET INC=1
- +5 IF $DATA(LOC1)
- IF ($PIECE(LOC1,"^",6)="")
- SET INC=1
- +6 IF $DATA(LOC2)
- IF ($PIECE(LOC2,"^",3)="")
- SET INC=1
- +7 ; PSGW*2.3*21 - USE AR/WS AMIS CONVERSION NUMBER
- +8 SET PSGWCNM=$SELECT($PIECE($GET(LOC2),"^",3)="":1,1:$PIECE(LOC2,"^",3))
- +9 ;
- COST IF INC=0
- SET DRGCST=DRGQD*($PIECE(LOC1,"^",6))*PSGWCNM
- +1 IF '$TEST
- SET DRGCST="NO DATA"
- SETGL SET ^TMP("PSGWCPA",$JOB,AOU,DRGNAME)=DRGQD_"^"_DRGCST
- GOTO DRGLP
- +1 ;
- PRTQUE ;AFTER DATA IS COMPILED, QUEUE THE PRINT
- +1 KILL ZTSAVE,ZTIO
- SET ZTIO=PSGWIO
- SET ZTRTN="^PSGWCPA1"
- SET ZTDESC="Print Cost per AOU"
- SET ZTDTH=$HOROLOG
- SET ZTSAVE("^TMP(""PSGWCPA"",$J,")=""
- FOR G="BDT","EDT","FLG","AOUCNT","SEL","IGDA"
- if $DATA(@G)
- SET ZTSAVE(G)=""
- +2 DO ^%ZTLOAD
- KILL ^TMP("PSGWCPA",$JOB)
- GOTO END^PSGWCPA1