source: WorldVistAEHR/trunk/r/SURGERY-SR/SRSRBW.m@ 1800

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

initial load of WorldVistAEHR

File size: 3.5 KB
RevLine 
[613]1SRSRBW ;B'HAM ISC/MAM - REQUESTS BY WARD ; [ 07/27/98 2:33 PM ]
2 ;;3.0; Surgery ;**50**;24 Jun 93
3BEG W !!,"Do you want requests for all wards ? YES// " R X:DTIME S:'$T X="^" S:X="" X="Y" G:X["^" END S X=$E(X)
4 I "YyNn"'[X W !!,"Enter RETURN if you would like a list of requests for all wards, or 'NO' to",!,"list the requests for a specific ward.",! G BEG
5 I "Yy"[X G ^SRSRBW1
6 W ! K DIC S DIC=42,DIC("A")="List Requests for which Ward ? ",DIC(0)="QEAMZ",DIC("S")="I $$WARD^SROUTL0(+Y,$G(SRSITE(""DIV"")),DT)" D ^DIC K DIC G:Y<0 END S SRW=+Y,SRW("N")=$P(Y(0),"^")
7 W ! K IOP,%ZIS,POP,IO("Q") S %ZIS("A")="Print the Report on which Device: ",%ZIS="Q" D ^%ZIS G:POP END
8 I $D(IO("Q")) K IO("Q") S ZTDESC="Requests by Service",ZTRTN="SER^SRSRBW",(ZTSAVE("DT"),ZTSAVE("SRSITE*"),ZTSAVE("SRW"),ZTSAVE("SRW(""N"")"))="" D ^%ZTLOAD G END
9SER ; entry when queued
10 S X="T-1" D ^%DT S SRSDATE=Y,(DFN,SRTN,SRQ)=0 K ^TMP("SR",$J)
11 F S SRSDATE=$O(^SRF("AR",SRSDATE)) Q:'SRSDATE F S DFN=$O(^SRF("AR",SRSDATE,DFN)) Q:'DFN F S SRTN=$O(^SRF("AR",SRSDATE,DFN,SRTN)) Q:'SRTN I $$DIV^SROUTL0(SRTN),$D(^DPT(DFN,.1)),$P(^(.1),"^")'="" D SETUTL
12WLIST ; get waiting list patients
13 S (COUNT,SRSS)=0
14 F S SRSS=$O(^SRO(133.8,"AWL",SRSS)) Q:'SRSS S SRS=+^SRO(133.8,SRSS,0),SRSDATE=0 F S SRSDATE=$O(^SRO(133.8,"AWL",SRSS,SRSDATE)) Q:'SRSDATE D MOREWL
15UTL ; loop through ^TMP("SR",$J) and print data
16 U IO D HDR S (SRSDATE,SRTN)=0 F S SRSDATE=$O(^TMP("SR",$J,SRSDATE)) Q:SRSDATE=""!SRQ F S SRTN=$O(^TMP("SR",$J,SRSDATE,SRTN)) Q:SRTN=""!SRQ D PRINT
17 I 'SRQ,$E(IOST)'="P" W !!,"Press RETURN to continue " R X:DTIME
18END W:$E(IOST)="P" @IOF I $D(ZTQUEUED) K ^TMP("SR",$J) Q:$G(ZTSTOP) S ZTREQ="@" Q
19 D ^SRSKILL K SRTN D ^%ZISC W @IOF
20 Q
21LOOP ; break procedure if greater than 65 characters
22 S SROPS(M)="" F LOOP=1:1 S MM=$P(SROPER," "),MMM=$P(SROPER," ",2,200) Q:MMM="" Q:$L(SROPS(M))+$L(MM)'<65 S SROPS(M)=SROPS(M)_MM_" ",SROPER=MMM
23 Q
24MOREWL ; continue getting patients on waiting list
25 S SRWL=0 F S SRWL=$O(^SRO(133.8,"AWL",SRSS,SRSDATE,SRWL)) Q:'SRWL D SETUTL1
26 Q
27SETUTL ; set ^TMP("SR",$J)
28 S SRWARD=$P(^DPT(DFN,.1),"^") Q:SRWARD'=SRW("N") D DEM^VADPT
29 S SRS=$P(^SRF(SRTN,0),"^",4) S:SRS="" SRS="NOT ENTERED" S:SRS SRS=$P(^SRO(137.45,SRS,0),"^"),SRS=$P(SRS,"(") S SRNM=VADM(1),SRSSN=VA("PID"),SRSOP=$P(^SRF(SRTN,"OP"),"^"),Y=SRSDATE D D^DIQ S SRDATE=Y
30 S ^TMP("SR",$J,SRSDATE,SRTN)=SRDATE_"^"_SRNM_"^"_SRS_"^"_SRSOP_"^"_SRSSN
31 Q
32SETUTL1 ; set ^TMP("SR",$J) with waiting list info
33 S DFN=+^SRO(133.8,SRSS,1,SRWL,0) Q:'$D(^DPT(DFN,.1)) I $P(^(.1),"^")'=SRW("N") Q
34 D DEM^VADPT S SRS=$P(^SRO(137.45,SRSS,0),"^"),SRS=$P(SRS,"("),SRWARD=$P(^DPT(DFN,.1),"^"),SRNM=VADM(1),SRSSN=VA("PID"),COUNT=COUNT+1
35 S SRSOP=$P(^SRO(133.8,SRSS,1,SRWL,0),"^",2)
36 S ^TMP("SR",$J,"WL","WL"_COUNT)="WAITING LIST^"_SRNM_"^"_SRS_"^"_SRSOP_"^"_SRSSN
37 Q
38PRINT ; print information
39 I $Y+6>IOSL D PAGE Q:SRQ D HDR Q:SRQ
40 S STBY=^TMP("SR",$J,SRSDATE,SRTN),SROPER=$P(STBY,"^",4) K SROPS,MM,MMM S:$L(SROPER)<65 SROPS(1)=SROPER I $L(SROPER)>64 S SROPER=SROPER_" " F M=1:1 D LOOP Q:MMM=""
41 W !,$P(STBY,"^"),?14,$P(STBY,"^",2),?45,$P($P(STBY,"^",3),"("),!,SRTN,?14,$P(STBY,"^",5),!,?14,SROPS(1) I $D(SROPS(2)) W !,?14,SROPS(2) I $D(SROPS(3)) W !,?14,SROPS(3)
42 W ! F LINE=1:1:80 W "-"
43 Q
44HDR ; print heading
45 I $D(ZTQUEUED) D ^SROSTOP I SRHALT S SRQ=1 Q
46 W:$Y @IOF W !,?5,"Operative Requests for "_SRW("N"),!!,"Date",?14,"Patient",?45,"Surgical Specialty",!,"Case Number",?14,"ID #",!,?14,"Operative Procedure",! F LINE=1:1:80 W "="
47 Q
48PAGE ; end of screen
49 I $E(IOST)'="P" W !!,"Press RETURN to continue or '^' to quit. " R X:DTIME I '$T!(X="^") S SRQ=1
50 Q
Note: See TracBrowser for help on using the repository browser.