ALPBPWRD ;OIFO-DALLAS MW,SED,KC-PRINT 3-DAY MAR BCMA BCBU REPORT FOR A SELECTED WARD ;01/01/03 ;;3.0;BAR CODE MED ADMIN;**8**;Mar 2004 ; ; NOTE: this routine is designed for hard-copy output. ; Output is formatted for 132-column printing. ; F D Q:$D(DIRUT) .W !,"Inpatient Pharmacy Orders for a selected ward" .S DIR(0)="FAO^2:10" .S DIR("A")="Select WARD: " .S DIR("?")="^D WARDLIST^ALPBUTL(""C"")" .D ^DIR K DIR .I $D(DIRUT) Q .D WARDSEL^ALPBUTL(Y,.ALPBSEL) .I +$G(ALPBSEL(0))=0 D Q ..W $C(7) ..W " ??" ..D WARDLIST^ALPBUTL("C") ..K ALPBSEL .I +$G(ALPBSEL(0))=1 D ..S ALPBWARD=ALPBSEL(1) ..W " ",ALPBWARD ..K ALPBSEL .I +$G(ALPBSEL(0))>1 D I $D(DIRUT) K DIRUT,DTOUT,X,Y Q ..S ALPBX=0 ..F S ALPBX=$O(ALPBSEL(ALPBX)) Q:'ALPBX W !?2,$J(ALPBX,2)," ",ALPBSEL(ALPBX) ..K ALPBX ..S DIR(0)="NA^1:"_ALPBSEL(0) ..S DIR("A")="Select Ward from the list (1-"_ALPBSEL(0)_"): " ..W ! D ^DIR K DIR ..I $D(DIRUT) K ALPBSEL Q ..S ALPBWARD=ALPBSEL(+Y) ..K ALPBSEL .; .; get all or just current orders?... .S DIR(0)="SA^A:ALL;C:CURRENT" .S DIR("A")="Report [A]LL or [C]URRENT orders? " .S DIR("B")="CURRENT" .S DIR("?")="[A]LL=all orders in the file, [C]URRENT=orders not yet expired." .W ! D ^DIR K DIR .I $D(DIRUT) K ALPBWARD,DIRUT,DTOUT,X,Y Q .S ALPBOTYP=Y .; .;SORT BY NAME OR ROOM/BED added 6/23/05 .S DIR(0)="SA^N:Name;R:Room/Bed" .S DIR("A")="Sort Patients by [N]ame or [R]oom/Bed? " .S DIR("B")="Room/bed" .S DIR("?")="Sort by [N]ame or [R]oom Bed" .W ! D ^DIR K DIR .I $D(DIRUT) K ALPBWARD,DIRUT,DTOUT,X,Y Q .S ALPBSORT=Y .; .; print how many days MAR?... .S DIR(0)="NA^1:7" .S DIR("A")="Print how many days MAR? " .S DIR("B")=$$DEFDAYS^ALPBUTL() .S DIR("?")="The default is shown; you may enter 3 or 7." .W ! D ^DIR K DIR .I $D(DIRUT) K ALPBOTYP,DIRUT,DTOUT,X,Y Q .S ALPBDAYS=+Y .; .; BCMA Med Log info for how many ?... .S DIR(0)="NA^1:99" .S DIR("B")=$$DEFML^ALPBUTL3() .S DIR("A")="Select how many BCMA Medication Log history: " .S DIR("A",1)=" " .S DIR("?",1)="Select a number of BCMA Medication log entries" .S DIR("?",2)="for each of the patient's orders" .S DIR("?")="They are listed by the most current entry first" .D ^DIR K DIR .I $D(DIRUT) K ALPBOTYP,ALPBWARD,DIRUT,DTOUT,X,Y Q .S ALPBMLOG=Y .; .S %ZIS="Q" .S %ZIS("B")=$$DEFPRT^ALPBUTL() .I %ZIS("B")="" K %ZIS("B") .W ! D ^%ZIS K %ZIS .I POP D Q ..W $C(7) ..K ALPBMLOG,ALPBOTYP,ALPBWARD,POP .; .; output not queued... .I '$D(IO("Q")) D ..U IO ..D DQ ..I IO'=IO(0) D ^%ZISC .; .; set up the Task... .I $D(IO("Q")) D ..S ZTRTN="DQ^ALPBPWRD" ..S ZTDESC="PSB INPT PHARM ORDERS FOR WARD "_ALPBWARD ..S ZTSAVE("ALPBDAYS")="" ..S ZTSAVE("ALPBWARD")="" ..S ZTSAVE("ALPBMLOG")="" ..S ZTSAVE("ALPBOTYP")="" ..S ZTSAVE("ALPBSORT")="" ..S ZTIO=ION ..D ^%ZTLOAD ..D HOME^%ZIS ..W !,$S($G(ZTSK):"Task number "_ZTSK_" queued.",1:"ERROR -- NOT QUEUED!") ..K IO("Q"),ZTSK .K ALPBDAYS,ALPBMLOG,ALPBOTYP,ALPBWARD K DIRUT,DTOUT,X,Y Q ; DQ ; output entry point... K ^TMP($J) ; ; set report date... SED 11/4/03 S ALPBRDAT=$S(ALPBOTYP="C":$$NOW^XLFDT(),1:"") ; ; loop through ward cross reference in 53.7... S ALPBPTN="" F S ALPBPTN=$O(^ALPB(53.7,"AW",ALPBWARD,ALPBPTN)) Q:ALPBPTN="" D .S ALPBIEN=0 .F S ALPBIEN=$O(^ALPB(53.7,"AW",ALPBWARD,ALPBPTN,ALPBIEN)) Q:'ALPBIEN D ..D ORDS^ALPBUTL(ALPBIEN,ALPBRDAT,.ALPBORDS) ..I +ALPBORDS(0)'>0 K ALPBORDS Q ..I $G(ALPBPDAT(0))="" S ALPBPDAT(0)=$G(^ALPB(53.7,ALPBIEN,0)) ..S ALPBOIEN=0 ..F S ALPBOIEN=$O(ALPBORDS(ALPBOIEN)) Q:'ALPBOIEN D ...S ALPBDATA=$G(^ALPB(53.7,ALPBIEN,2,ALPBOIEN,1)) ...S ALPBOCT=$P($G(^ALPB(53.7,ALPBIEN,2,ALPBOIEN,3)),U,1) ...S:$P($G(^ALPB(53.7,ALPBIEN,2,ALPBOIEN,4)),U,3)["PRN" ALPBOCT=ALPBOCT_"P" ...; if report is for "C"urrent, check stop date and quit if ...; stop date is less than report date... ...I ALPBOTYP="C"&($P(ALPBDATA,U,2)IOSL) D PAGE ...F ALPBX=1:1:ALPBFORM(0) W !,ALPBFORM(ALPBX) ...K ALPBDATA,ALPBFORM,ALPBOIEN,ALPBX ..K ALPBORDN .K ALPBOST K ALPBOCT ; print footer at end of this patient's record... I $Y+10>IOSL D PAGE W !! D FOOT^ALPBFRMU ;Print a blank page between patient W @IOF S ALPBPG=0 K ALPBPDAT Q ;K ALPBIEN,ALPBPDAT KILLING ALPBIEN WILL BREAK SORT BY ROOM/BED ; DONE ; K ALPBDAYS,ALPBMLOG,ALPBOTYP,ALPBPG,ALPBPTN,ALPBRDAT,ALPBWARD,^TMP($J),ALPRM,ALPRM1,ALPBD,ALPBIEN,ALPBSORT I $D(ZTQUEUED) S ZTREQ="@" Q ; PAGE ; print page header for patient... W @IOF S ALPBPG=ALPBPG+1 D HDR^ALPBFRMU(.ALPBPDAT,ALPBPG,.ALPBHDR) F ALPBX=1:1:ALPBHDR(0) W !,ALPBHDR(ALPBX) K ALPBHDR,ALPBX Q