- PSAVIN2 ;BIR/LTL-Compares Prices (DA/GIP) ;7/23/97
- ;;3.0; DRUG ACCOUNTABILITY/INVENTORY INTERFACE;**15**; 10/24/97
- ;This routine reviews prices for a drug.
- ;
- ;References to $$DESCR^PRCPUX1 are covered by IA #259
- ;References to $$INVNAME^PRCPUX1 are covered by IA #259
- ;References to $$UNITCODE^PRCPUX1 are covered by IA #259
- ;References to ^PSDRUG( are covered by IA #2095
- ;References to ^PRCP( are covered by IA #214
- ;References to ^DIC(51.5 are covered by IA #1931
- ;
- N DIC,DIR,DTOUT,DUOUT,PSA,PSACNT,PSALOCN,PSAR,PSAU,PSAOUT,PSAT,X,X2,X3,Y S PSAOUT=1,PSAU=0
- LOOK D ^PSADA I '$G(PSALOC) S PSAOUT=1 G END
- I '$O(^PSD(58.8,PSALOC,1,0)) W !!,"There are no drugs in ",PSALOCN G END
- S PSACNT=0 W !!,"You may select one, several, or ^ALL drugs.",!
- CHKD F S DIC="^PSD(58.8,+PSALOC,1,",DIC(0)="AEMQ",DIC("A")="Please Select "_PSALOCN_"'s Drug: ",DIC("S")="I $S($G(^(""I"")):$G(^(""I""))>DT,1:1)" W ! D ^DIC K DIC G:X'="^ALL"&(Y<1)&('PSACNT) END Q:Y<0 S PSA(+Y)="",PSACNT=PSACNT+1
- I X="^ALL" F S PSAU=$O(^PSD(58.8,+PSALOC,1,PSAU)) Q:'PSAU S PSA(PSAU)=""
- DEV ;asks device and queueing info
- K IO("Q") N %ZIS,IOP,POP S %ZIS="Q" W ! D ^%ZIS I POP W !,"NO DEVICE SELECTED OR OUTPUT PRINTED!" Q
- I $D(IO("Q")) N ZTDESC,ZTIO,ZTRTN,ZTSAVE,ZTDTH,ZTSK S ZTRTN="START^PSAVIN2",ZTDESC="Drug price review",ZTSAVE("PSA*")="" D ^%ZTLOAD,HOME^%ZIS S PSAOUT=1 G END
- START ;compiles and prints output
- N %DT,PSALN,PSAR,PSAPG,PSARPDT S (PSAPG,PSAOUT)=0,Y=DT,PSAR="" X ^DD("DD") S PSARPDT=Y,PSAU(1)=$O(PSA(0)) D HEADER S PSAU=0
- F S PSAU=$O(PSA(PSAU)) Q:'PSAU D Q:$G(PSAOUT)
- LOOP .D:$Y+8>IOSL HEADER Q:$G(PSAOUT)
- .W !,$P($G(^PSDRUG(+PSAU,0)),U)
- .S PSAU(9)=$G(^PSDRUG(+PSAU,660))
- .W !!,"DRUG file prices: "
- .S X=$P(PSAU(9),U,3),X2="2$",X3=4 D COMMA^%DTC W X,"/"
- .S PSAU(8)=$P($G(^DIC(51.5,+$P(PSAU(9),U,2),0)),U)
- .W PSAU(8)," (",$P(PSAU(9),U,5)," ",$P(PSAU(9),U,8),"/",PSAU(8)
- .S X=$P(PSAU(9),U,6),X2="3$",X3=4 D COMMA^%DTC
- .W ") => ",X,"/",$P(PSAU(9),U,8),!!
- .Q:'$O(^PSDRUG(+PSAU,441,0))
- .F PSAU(1)=0:0 S PSAU(1)=$O(^PSDRUG(+PSAU,441,PSAU(1))) Q:'PSAU(1) D
- ..S PSAU(2)=$P($G(^PSDRUG(+PSAU,441,+PSAU(1),0)),U) Q:'PSAU(2)
- ..Q:'$O(^PRCP(445,"AE",+PSAU(2),0))
- ..F PSAU(3)=0:0 S PSAU(3)=$O(^PRCP(445,"AE",+PSAU(2),PSAU(3))) Q:'PSAU(3) D:$O(^PSD(58.8,"P",PSAU(3),0))
- ...S PSAU(5)=$G(PSAU(5))+1
- ...W $$DESCR^PRCPUX1(PSAU(3),PSAU(2))
- ...W !!,$$INVNAME^PRCPUX1(PSAU(3)),"'s prices: "
- ...S PSAU(6)=$G(^PRCP(445,+PSAU(3),1,+PSAU(2),0))
- ...S X=$P(PSAU(6),U,15),X2="2$",X3=4 D COMMA^%DTC W X,"/"
- ...S PSAU(11)=$$UNITCODE^PRCPUX1($P(PSAU(6),U,5))
- ...W PSAU(11)," (",$P(PSAU(6),U,29)
- ...W " ",$P(PSAU(6),U,28),"/",PSAU(11),")"
- ...S X=($P(PSAU(6),U,15)/($S(($P(PSAU(6),U,29)>0):$P(PSAU(6),U,29),1:1)))
- ...S X2="3$",X3=4 D COMMA^%DTC W " => ",X,"/",$P(PSAU(6),U,28),!!
- END W:$E(IOST)'="C" @IOF
- I $E(IOST,1,2)="C-",'PSAOUT S DIR(0)="EA",DIR("A")="END OF REPORT! Press <RET> to return to the menu." D ^DIR
- D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@" K IO("Q")
- Q
- I $E(IOST,1,2)'="P-",PSAPG S DIR(0)="E" D ^DIR K DIR I 'Y S PSAOUT=1 Q
- I $$S^%ZTLOAD W !!,"Task #",$G(ZTSK),", ",$G(ZTDESC)," was stopped by ",$P($G(^VA(200,+$G(DUZ),0)),U),"." S PSAOUT=1 Q
- W:$Y @IOF S $P(PSALN,"&",81)="",PSAPG=PSAPG+1 W !?2,"DRUG File/Inventory Price Review",?55,PSARPDT,?70,"PAGE: ",PSAPG,!,PSALN,!
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSAVIN2 3376 printed Mar 13, 2025@20:55:53 Page 2
- PSAVIN2 ;BIR/LTL-Compares Prices (DA/GIP) ;7/23/97
- +1 ;;3.0; DRUG ACCOUNTABILITY/INVENTORY INTERFACE;**15**; 10/24/97
- +2 ;This routine reviews prices for a drug.
- +3 ;
- +4 ;References to $$DESCR^PRCPUX1 are covered by IA #259
- +5 ;References to $$INVNAME^PRCPUX1 are covered by IA #259
- +6 ;References to $$UNITCODE^PRCPUX1 are covered by IA #259
- +7 ;References to ^PSDRUG( are covered by IA #2095
- +8 ;References to ^PRCP( are covered by IA #214
- +9 ;References to ^DIC(51.5 are covered by IA #1931
- +10 ;
- +11 NEW DIC,DIR,DTOUT,DUOUT,PSA,PSACNT,PSALOCN,PSAR,PSAU,PSAOUT,PSAT,X,X2,X3,Y
- SET PSAOUT=1
- SET PSAU=0
- LOOK DO ^PSADA
- IF '$GET(PSALOC)
- SET PSAOUT=1
- GOTO END
- +1 IF '$ORDER(^PSD(58.8,PSALOC,1,0))
- WRITE !!,"There are no drugs in ",PSALOCN
- GOTO END
- +2 SET PSACNT=0
- WRITE !!,"You may select one, several, or ^ALL drugs.",!
- CHKD FOR
- SET DIC="^PSD(58.8,+PSALOC,1,"
- SET DIC(0)="AEMQ"
- SET DIC("A")="Please Select "_PSALOCN_"'s Drug: "
- SET DIC("S")="I $S($G(^(""I"")):$G(^(""I""))>DT,1:1)"
- WRITE !
- DO ^DIC
- KILL DIC
- if X'="^ALL"&(Y<1)&('PSACNT)
- GOTO END
- if Y<0
- QUIT
- SET PSA(+Y)=""
- SET PSACNT=PSACNT+1
- +1 IF X="^ALL"
- FOR
- SET PSAU=$ORDER(^PSD(58.8,+PSALOC,1,PSAU))
- if 'PSAU
- QUIT
- SET PSA(PSAU)=""
- DEV ;asks device and queueing info
- +1 KILL IO("Q")
- NEW %ZIS,IOP,POP
- SET %ZIS="Q"
- WRITE !
- DO ^%ZIS
- IF POP
- WRITE !,"NO DEVICE SELECTED OR OUTPUT PRINTED!"
- QUIT
- +2 IF $DATA(IO("Q"))
- NEW ZTDESC,ZTIO,ZTRTN,ZTSAVE,ZTDTH,ZTSK
- SET ZTRTN="START^PSAVIN2"
- SET ZTDESC="Drug price review"
- SET ZTSAVE("PSA*")=""
- DO ^%ZTLOAD
- DO HOME^%ZIS
- SET PSAOUT=1
- GOTO END
- START ;compiles and prints output
- +1 NEW %DT,PSALN,PSAR,PSAPG,PSARPDT
- SET (PSAPG,PSAOUT)=0
- SET Y=DT
- SET PSAR=""
- XECUTE ^DD("DD")
- SET PSARPDT=Y
- SET PSAU(1)=$ORDER(PSA(0))
- DO HEADER
- SET PSAU=0
- +2 FOR
- SET PSAU=$ORDER(PSA(PSAU))
- if 'PSAU
- QUIT
- Begin DoDot:1
- LOOP if $Y+8>IOSL
- DO HEADER
- if $GET(PSAOUT)
- QUIT
- +1 WRITE !,$PIECE($GET(^PSDRUG(+PSAU,0)),U)
- +2 SET PSAU(9)=$GET(^PSDRUG(+PSAU,660))
- +3 WRITE !!,"DRUG file prices: "
- +4 SET X=$PIECE(PSAU(9),U,3)
- SET X2="2$"
- SET X3=4
- DO COMMA^%DTC
- WRITE X,"/"
- +5 SET PSAU(8)=$PIECE($GET(^DIC(51.5,+$PIECE(PSAU(9),U,2),0)),U)
- +6 WRITE PSAU(8)," (",$PIECE(PSAU(9),U,5)," ",$PIECE(PSAU(9),U,8),"/",PSAU(8)
- +7 SET X=$PIECE(PSAU(9),U,6)
- SET X2="3$"
- SET X3=4
- DO COMMA^%DTC
- +8 WRITE ") => ",X,"/",$PIECE(PSAU(9),U,8),!!
- +9 if '$ORDER(^PSDRUG(+PSAU,441,0))
- QUIT
- +10 FOR PSAU(1)=0:0
- SET PSAU(1)=$ORDER(^PSDRUG(+PSAU,441,PSAU(1)))
- if 'PSAU(1)
- QUIT
- Begin DoDot:2
- +11 SET PSAU(2)=$PIECE($GET(^PSDRUG(+PSAU,441,+PSAU(1),0)),U)
- if 'PSAU(2)
- QUIT
- +12 if '$ORDER(^PRCP(445,"AE",+PSAU(2),0))
- QUIT
- +13 FOR PSAU(3)=0:0
- SET PSAU(3)=$ORDER(^PRCP(445,"AE",+PSAU(2),PSAU(3)))
- if 'PSAU(3)
- QUIT
- if $ORDER(^PSD(58.8,"P",PSAU(3),0))
- Begin DoDot:3
- +14 SET PSAU(5)=$GET(PSAU(5))+1
- +15 WRITE $$DESCR^PRCPUX1(PSAU(3),PSAU(2))
- +16 WRITE !!,$$INVNAME^PRCPUX1(PSAU(3)),"'s prices: "
- +17 SET PSAU(6)=$GET(^PRCP(445,+PSAU(3),1,+PSAU(2),0))
- +18 SET X=$PIECE(PSAU(6),U,15)
- SET X2="2$"
- SET X3=4
- DO COMMA^%DTC
- WRITE X,"/"
- +19 SET PSAU(11)=$$UNITCODE^PRCPUX1($PIECE(PSAU(6),U,5))
- +20 WRITE PSAU(11)," (",$PIECE(PSAU(6),U,29)
- +21 WRITE " ",$PIECE(PSAU(6),U,28),"/",PSAU(11),")"
- +22 SET X=($PIECE(PSAU(6),U,15)/($SELECT(($PIECE(PSAU(6),U,29)>0):$PIECE(PSAU(6),U,29),1:1)))
- +23 SET X2="3$"
- SET X3=4
- DO COMMA^%DTC
- WRITE " => ",X,"/",$PIECE(PSAU(6),U,28),!!
- End DoDot:3
- End DoDot:2
- End DoDot:1
- if $GET(PSAOUT)
- QUIT
- END if $EXTRACT(IOST)'="C"
- WRITE @IOF
- +1 IF $EXTRACT(IOST,1,2)="C-"
- IF 'PSAOUT
- SET DIR(0)="EA"
- SET DIR("A")="END OF REPORT! Press <RET> to return to the menu."
- DO ^DIR
- +2 DO ^%ZISC
- if $DATA(ZTQUEUED)
- SET ZTREQ="@"
- KILL IO("Q")
- +3 QUIT
- +1 IF $EXTRACT(IOST,1,2)'="P-"
- IF PSAPG
- SET DIR(0)="E"
- DO ^DIR
- KILL DIR
- IF 'Y
- SET PSAOUT=1
- QUIT
- +2 IF $$S^%ZTLOAD
- WRITE !!,"Task #",$GET(ZTSK),", ",$GET(ZTDESC)," was stopped by ",$PIECE($GET(^VA(200,+$GET(DUZ),0)),U),"."
- SET PSAOUT=1
- QUIT
- +3 if $Y
- WRITE @IOF
- SET $PIECE(PSALN,"&",81)=""
- SET PSAPG=PSAPG+1
- WRITE !?2,"DRUG File/Inventory Price Review",?55,PSARPDT,?70,"PAGE: ",PSAPG,!,PSALN,!
- +4 QUIT