- PSDLBLR2 ;BIR/JPW-CS PF Label Reprt for CS Disp Drug (cont'd) ; 17 May 94
- ;;3.0; CONTROLLED SUBSTANCES ;;13 Feb 97
- START ;entry for compile and print labels
- K ^TMP("PSDLBLR",$J),PSDPRT D NOW^%DTC S PSDT=+$E(%,1,12)
- F JJ=0,1 S @("PSDBAR"_JJ)="" I $D(^%ZIS(2,^%ZIS(1,IOS,"SUBTYPE"),"BAR"_JJ)) S @("PSDBAR"_JJ)=^("BAR"_JJ)
- I PSDBAR1]"",PSDBAR0]"" S PSDPRT=1
- S PSDCNT=1,PSD1="" F S PSD1=$O(PSD1(PSD1)) Q:PSD1="" D LOOP
- PRINT ;print labels
- S (PSD,PSDOUT)=0
- F S PSD=$O(^TMP("PSDLBLR",$J,PSD)) Q:PSD=""!(PSDOUT) D
- .S PSD(1)=$G(^TMP("PSDLBLR",$J,PSD))
- .W !,$P(PSD(1),U,2)
- .I $D(PSDPRT) W !,@PSDBAR1,$P(PSD(1),U),@PSDBAR0
- .W $P(PSD(1),U)," ",$P(PSD(1),U,3),!
- DONE I $E(IOST)'="C" W @IOF
- I $E(IOST,1,2)="C-",'PSDOUT W ! K DIR,DIRUT S DIR(0)="EA",DIR("A")="END OF REPORT! Press <RET> to return to the menu" D ^DIR K DIR
- END ;kill variables and exit
- K %,%DT,%H,%I,%ZIS,DA,DIC,DIE,DIR,DIROUT,DIRUT,DR,DRUG,DTOUT,DUOUT,JJ,JLP1,LIQ,NAOU,NAOUN,NODE,OK
- K POP,PSD,PSD1,PSDA,PSDBAR0,PSDBAR1,PSDCNT,PSDEV,PSDJ,PSDN,PSDPN,PSDOUT,PSDR,PSDRG,PSDPRT,PSDRN,PSDS,PSDSN,PSDT,PSDX1,PSDX2
- K QTY,STAT,TEMP,TEST,TEXT,X,Y,ZTDESC,ZTIO,ZTRTN,ZTSAVE,ZTSK
- K ^TMP("PSDLBLR",$J)
- D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@"
- Q
- PRINT1 ;prints labels
- W ! F PSDX1=0:1:PSDCNT-1 W ?PSDX1*33+1,$E(TEMP(PSDX1+1),1,30)
- I $D(PSDPRT) W !! F PSDX1=1:1:PSDCNT W @PSDBAR1,$P(TEST(PSDX1)," "),@PSDBAR0
- W ! F PSDX1=0:1:PSDCNT-1 W ?PSDX1*32+3,TEST(PSDX1+1)
- W !!
- S PSDCNT=0,PSDX2=PSDX2+1 S:PSDX2=11 PSDX2=1
- Q
- LOOP S PSD=$P(PSD1(PSD1),",",PSDCNT),PSDCNT=PSDCNT+1 I PSD="" S PSDCNT=1 Q
- F PSDJ=0:0 S PSDJ=$O(^PSD(58.81,"D",PSD,PSDJ)) Q:'PSDJ D SET1
- G LOOP
- Q
- SET1 ;sets disp info
- Q:'$D(^PSD(58.81,PSDJ,0)) S NODE=^PSD(58.81,PSDJ,0) Q:+$P(NODE,"^",3)'=+PSDS
- S STAT=+$P(NODE,"^",11) S OK=$S(STAT=3:1,STAT=4:1,1:0) Q:'OK
- S PSDPN=$P(NODE,"^",17) Q:PSDPN']""
- S NAOU=+$P(NODE,"^",18) Q:'NAOU S NAOUN=$P($G(^PSD(58.8,+NAOU,0)),"^")
- S PSDR=+$P(NODE,"^",5) Q:'PSDR
- S PSDA=+$P(NODE,"^",20) Q:'PSDA
- S PSDN=$P($G(^PSDRUG(+PSDR,0)),"^"),QTY=$P($G(^PSD(58.8,+NAOU,1,+PSDR,0)),"^",4)
- S TEXT(PSDR)=PSDN_"^"_NAOUN
- SET ;sets ^tmp
- ;K LIQ S:+$G(^PSD(58.8,+NAOU,1,+PSDR,7)) LIQ="L"
- S ^TMP("PSDLBLR",$J,PSDPN)=PSDPN_"^"_$P(TEXT(PSDR),"^")_"^"_$E($P(TEXT(PSDR),"^",2),1,12)
- DIE ;update label printed
- K DA,DIE,DR S DA=+PSDJ,DIE=58.81,DR="104////"_PSDT D ^DIE K DA,DIE,DR
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSDLBLR2 2375 printed Feb 18, 2025@23:13:05 Page 2
- PSDLBLR2 ;BIR/JPW-CS PF Label Reprt for CS Disp Drug (cont'd) ; 17 May 94
- +1 ;;3.0; CONTROLLED SUBSTANCES ;;13 Feb 97
- START ;entry for compile and print labels
- +1 KILL ^TMP("PSDLBLR",$JOB),PSDPRT
- DO NOW^%DTC
- SET PSDT=+$EXTRACT(%,1,12)
- +2 FOR JJ=0,1
- SET @("PSDBAR"_JJ)=""
- IF $DATA(^%ZIS(2,^%ZIS(1,IOS,"SUBTYPE"),"BAR"_JJ))
- SET @("PSDBAR"_JJ)=^("BAR"_JJ)
- +3 IF PSDBAR1]""
- IF PSDBAR0]""
- SET PSDPRT=1
- +4 SET PSDCNT=1
- SET PSD1=""
- FOR
- SET PSD1=$ORDER(PSD1(PSD1))
- if PSD1=""
- QUIT
- DO LOOP
- PRINT ;print labels
- +1 SET (PSD,PSDOUT)=0
- +2 FOR
- SET PSD=$ORDER(^TMP("PSDLBLR",$JOB,PSD))
- if PSD=""!(PSDOUT)
- QUIT
- Begin DoDot:1
- +3 SET PSD(1)=$GET(^TMP("PSDLBLR",$JOB,PSD))
- +4 WRITE !,$PIECE(PSD(1),U,2)
- +5 IF $DATA(PSDPRT)
- WRITE !,@PSDBAR1,$PIECE(PSD(1),U),@PSDBAR0
- +6 WRITE $PIECE(PSD(1),U)," ",$PIECE(PSD(1),U,3),!
- End DoDot:1
- DONE IF $EXTRACT(IOST)'="C"
- WRITE @IOF
- +1 IF $EXTRACT(IOST,1,2)="C-"
- IF 'PSDOUT
- WRITE !
- KILL DIR,DIRUT
- SET DIR(0)="EA"
- SET DIR("A")="END OF REPORT! Press <RET> to return to the menu"
- DO ^DIR
- KILL DIR
- END ;kill variables and exit
- +1 KILL %,%DT,%H,%I,%ZIS,DA,DIC,DIE,DIR,DIROUT,DIRUT,DR,DRUG,DTOUT,DUOUT,JJ,JLP1,LIQ,NAOU,NAOUN,NODE,OK
- +2 KILL POP,PSD,PSD1,PSDA,PSDBAR0,PSDBAR1,PSDCNT,PSDEV,PSDJ,PSDN,PSDPN,PSDOUT,PSDR,PSDRG,PSDPRT,PSDRN,PSDS,PSDSN,PSDT,PSDX1,PSDX2
- +3 KILL QTY,STAT,TEMP,TEST,TEXT,X,Y,ZTDESC,ZTIO,ZTRTN,ZTSAVE,ZTSK
- +4 KILL ^TMP("PSDLBLR",$JOB)
- +5 DO ^%ZISC
- if $DATA(ZTQUEUED)
- SET ZTREQ="@"
- +6 QUIT
- PRINT1 ;prints labels
- +1 WRITE !
- FOR PSDX1=0:1:PSDCNT-1
- WRITE ?PSDX1*33+1,$EXTRACT(TEMP(PSDX1+1),1,30)
- +2 IF $DATA(PSDPRT)
- WRITE !!
- FOR PSDX1=1:1:PSDCNT
- WRITE @PSDBAR1,$PIECE(TEST(PSDX1)," "),@PSDBAR0
- +3 WRITE !
- FOR PSDX1=0:1:PSDCNT-1
- WRITE ?PSDX1*32+3,TEST(PSDX1+1)
- +4 WRITE !!
- +5 SET PSDCNT=0
- SET PSDX2=PSDX2+1
- if PSDX2=11
- SET PSDX2=1
- +6 QUIT
- LOOP SET PSD=$PIECE(PSD1(PSD1),",",PSDCNT)
- SET PSDCNT=PSDCNT+1
- IF PSD=""
- SET PSDCNT=1
- QUIT
- +1 FOR PSDJ=0:0
- SET PSDJ=$ORDER(^PSD(58.81,"D",PSD,PSDJ))
- if 'PSDJ
- QUIT
- DO SET1
- +2 GOTO LOOP
- +3 QUIT
- SET1 ;sets disp info
- +1 if '$DATA(^PSD(58.81,PSDJ,0))
- QUIT
- SET NODE=^PSD(58.81,PSDJ,0)
- if +$PIECE(NODE,"^",3)'=+PSDS
- QUIT
- +2 SET STAT=+$PIECE(NODE,"^",11)
- SET OK=$SELECT(STAT=3:1,STAT=4:1,1:0)
- if 'OK
- QUIT
- +3 SET PSDPN=$PIECE(NODE,"^",17)
- if PSDPN']""
- QUIT
- +4 SET NAOU=+$PIECE(NODE,"^",18)
- if 'NAOU
- QUIT
- SET NAOUN=$PIECE($GET(^PSD(58.8,+NAOU,0)),"^")
- +5 SET PSDR=+$PIECE(NODE,"^",5)
- if 'PSDR
- QUIT
- +6 SET PSDA=+$PIECE(NODE,"^",20)
- if 'PSDA
- QUIT
- +7 SET PSDN=$PIECE($GET(^PSDRUG(+PSDR,0)),"^")
- SET QTY=$PIECE($GET(^PSD(58.8,+NAOU,1,+PSDR,0)),"^",4)
- +8 SET TEXT(PSDR)=PSDN_"^"_NAOUN
- SET ;sets ^tmp
- +1 ;K LIQ S:+$G(^PSD(58.8,+NAOU,1,+PSDR,7)) LIQ="L"
- +2 SET ^TMP("PSDLBLR",$JOB,PSDPN)=PSDPN_"^"_$PIECE(TEXT(PSDR),"^")_"^"_$EXTRACT($PIECE(TEXT(PSDR),"^",2),1,12)
- DIE ;update label printed
- +1 KILL DA,DIE,DR
- SET DA=+PSDJ
- SET DIE=58.81
- SET DR="104////"_PSDT
- DO ^DIE
- KILL DA,DIE,DR
- +2 QUIT