- ORPRS01 ; slc/dcm - Hot'n Summary Report utilities ;6/10/97 15:37
- ;;3.0;ORDER ENTRY/RESULTS REPORTING;**11**;Dec 17, 1997
- P ; Get Patient(s)
- N %X,%Y,C,DIC,DFN,I,ORATTEND,Y
- K ORSCPAT,^XUTL("OR",$J,"ORU"),^("ORV"),^("ORW"),^("ORLP")
- S ORSHORT=$$SHORT^ORPRS02
- D PATIENT^ORU1(.ORSCPAT,,1)
- I $S($D(DIROUT):1,$D(DUOUT):1,1:0) S (OREND,XQORPOP)=1
- Q
- DAY(DAY) ; Get a date for 24 hr printing
- ;DAY=Optional date for default date prompt
- ;Returns: ORSSTRT=Internal Start date/time_"^"_Formatted Start date/time
- ; ORSSTOP=Internal Stop date/time_"^"_Formatted Stop date/time
- ; OREND,XQORPOP=1 if user ^'s or times out
- ; DIROUT=1 if user ^^'s out
- N %,%DT,%I,%T,%H,ORSDFLT,X,Y
- D1 ;
- S OREND=0,ORSDFLT=$S($G(DAY):$S($P(DAY,".",2)=2359:DAY+.7641,1:DAY),1:"T")
- W !!,"Order Entry Date: "_$S(+ORSDFLT>0:$$DATE^ORU(ORSDFLT,"AMTH DD, CCYY"),1:"T")_"// "
- R X:$S($D(DTIME):DTIME,1:300)
- I $S(X="^":1,X="^^":1,'$T:1,1:0) S (OREND,XQORPOP)=1 S:X="^^" DIROUT=1 Q
- S:X="" X=ORSDFLT
- S %DT="EX"
- D ^%DT
- I X["?" K DAY G D1
- I Y<1 W $C(7),?40,"Invalid Date." K DAY G D1
- S ORSSTRT=Y-.7641_"^"_$$FMTE^XLFDT(Y-.7641),ORSSTOP=Y+.2359_"^"_$$FMTE^XLFDT(Y+.2359)
- Q
- RANGE(X1,X2) ; Get a date range for printing
- ;X1=Default Start Date/time
- ;X2=Default Stop Date/time
- N %DT,%T,ORSDFLT,X,Y
- I $D(ORPRES),+ORPRES=6!(+ORPRES=15)!(+ORPRES=16)!(+ORPRES=17) S (ORSSTRT,ORSSTOP)="" Q
- R ;
- S OREND=0,ORSDFLT=$S($G(X1)>0:$S($P(X1,".",2)=2359:X1+.7641,1:X1),1:"T")
- W !!,"Start Date [Time]: "_$S(ORSDFLT>0:$$DATE^ORU(ORSDFLT,"AMTH DD, CCYY"),1:ORSDFLT)_"// "
- R X:$S($D(DTIME):DTIME,1:300)
- S:X="^"!('$T) (OREND,XQORPOP)=1
- Q:OREND
- S:X="" X=ORSDFLT
- S %DT="EXT"
- D ^%DT
- G R:X["?"
- I Y<1 W ?55,"Invalid Start Date/time." G R
- S ORSSTRT=Y
- E ; Get Ending Date/time
- S ORSDFLT=$S($G(X2):$S($P(X2,".",2)'=2359:$P(X2,".")_".2359",1:X2),$G(ORSSTRT):$S($P(ORSSTRT,".",2)=2359:(ORSSTRT+.7641)_".2359",1:$P(ORSSTRT,".")_".2359"),1:"T@2359")
- W !!,"Ending Date [Time] (inclusive): "_$S(+ORSDFLT>0:$$DATE^ORU(ORSDFLT,"AMTH DD, CCYY HR:MIN"),1:ORSDFLT)_"// "
- R X:$S($D(DTIME):DTIME,1:300)
- S:X="^"!('$T) (OREND,XQORPOP)=1
- Q:OREND
- S:X="" X=ORSDFLT
- S %DT="EXT"
- D ^%DT
- G E:X["?"
- I Y<1 W ?57,"Invalid End Date/time." G E
- S ORSSTOP=Y
- I ORSSTOP<ORSSTRT S X=ORSSTOP,ORSSTOP=ORSSTRT,ORSSTRT=X
- S ORSSTOP=$S($L(ORSSTOP,".")=2:ORSSTOP,1:ORSSTOP+1)_"^"_$$FMTE^XLFDT(ORSSTOP)
- S ORSSTRT=$S($L(ORSSTRT,".")=2:ORSSTRT,1:ORSSTRT-.7641)_"^"_$$FMTE^XLFDT(ORSSTRT)
- Q
- CUSTOM ; Selects order status and display group
- N %,%Y,C,DIC,I,X,Y,XQORM,XQORSPEW,XQORNOD
- S ORBUF=1
- I $D(DIROUT)!($D(DTOUT)) S (OREND,XQORPOP)=1 Q
- S:'$D(ORPRES) ORPRES="2;ACTIVE ORDERS"
- D PRES^ORPRS09
- I $G(OREND) S XQORPOP=1 Q
- D SERV^ORPRS09
- I $G(OREND) S XQORPOP=1 Q
- Q
- HSTS(X) ;Help for status descriptions (ORRP STATUS MENU protocol)
- W !,"Valid selections are: "
- I X["???" W ! D HACT1 W ! Q ;show descriptions and quit
- D DISP^XQORM1
- W !
- Q
- HACT1 ;
- K ^TMP("ORRX",$J)
- S Y=0 F I=0:0 S Y=$O(^ORD(101,+XQORNOD,10,Y)) Q:Y'>0 I $D(^ORD(101,+XQORNOD,10,Y,0)) S W=^(0),^TMP("ORRX",$J,$P(W,"^",3))=W
- S Y=0 F I=1:1 S Y=$O(^TMP("ORRX",$J,Y)) Q:Y'>0 S X1=^(Y),W=+X1 D:I=20 READ^ORUTL W !,$P(X1,"^",2),?5 I W,$D(^ORD(101,W,0)) W $P(^(0),"^",2) I $P(^(0),"^",2)'=" ",$D(^ORD(101,W,1,1,0)) W " - "_^(0)
- K W,X,^TMP("ORRX")
- Q
- EN(ORDG,ORSEL) ;Setup/Display groups
- ;ORDG(optional)=ptr to display group to setup (All is the default)
- ;ORSEL(optional)=Line label of action to take (BILD<default>, DISP)
- ;Returns: ORGRP if ORSEL="BILD"
- I $G(ORSEL)'="DISP" S ORSEL="BILD"
- I '$G(ORDG) S ORDG=1 ;All if not specified
- N ORMEM,ORSTK
- S ORSTK=0
- D @ORSEL
- S ORSTK=1,ORSTK(ORSTK)=ORDG_"^0",ORSTK(0)=0,ORMEM=0
- F I=0:0 S ORMEM=$O(^ORD(100.98,+ORSTK(ORSTK),1,ORMEM)) D @$S(+ORMEM'>0:"POP",1:"PROC") Q:ORSTK<1
- Q
- POP ;
- S ORSTK=ORSTK-1,ORMEM=$P(ORSTK(ORSTK),"^",2)
- Q
- PROC ;
- S $P(ORSTK(ORSTK),"^",2)=ORMEM,ORDG=$P(^ORD(100.98,+ORSTK(ORSTK),1,ORMEM,0),"^",1)
- D @ORSEL
- S ORSTK=ORSTK+1,ORSTK(ORSTK)=ORDG_"^0",ORMEM=0
- Q
- DISP ;
- I $Y>(IOSL-4) D READ^ORUTL W @IOF
- S W=^ORD(100.98,ORDG,0)
- W !,?((ORSTK*2)),$P(W,"^")
- Q
- BILD ;
- S ORGRP(ORDG)=""
- Q
- STOP ; Call DIR at bottom of screen
- N DIR,X,Y
- Q:$E(IOST)'="C"
- I IOSL>($Y+5) F W ! Q:IOSL<($Y+6)
- S DIR(0)="FO^1:1",DIR("A")="Press RETURN to continue or '^' to exit"
- S DIR("?")="Enter '^' to quit present report or '^^' to quit to menu"
- D ^DIR
- Q
- TERM(IOST) ;Setup terminal display values
- ;IOST=Terminal type
- ;Returns ORTERM(5)=REVERSE VIDEO ON^REVERSE VIDEO OFF
- ; ORTERM(7)=HIGH INTENSITY^LOW INTENSITY^NORMAL INTENSITY
- S (ORTERM(7),ORTERM(5))=""
- I $D(IOST),$L(IOST) S X=$O(^%ZIS(2,"B",IOST,0)) I X,$D(^%ZIS(2,X)) S ORTERM(5)=$S($D(^(X,5)):$P(^(5),"^",4,5),1:""),ORTERM(7)=$S($D(^(7)):$P(^(7),"^",1,3),1:"") S:'$L($P(ORTERM(7),"^",3)) $P(ORTERM(7),"^",3)=$P(ORTERM(7),"^",2)
- F I=1:2:3 I '$L($P(ORTERM(7),"^",I)) S ORTERM(7)="" Q
- Q
- ORPRS01 ; slc/dcm - Hot'n Summary Report utilities ;6/10/97 15:37
- +1 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**11**;Dec 17, 1997
- P ; Get Patient(s)
- +1 NEW %X,%Y,C,DIC,DFN,I,ORATTEND,Y
- +2 KILL ORSCPAT,^XUTL("OR",$JOB,"ORU"),^("ORV"),^("ORW"),^("ORLP")
- +3 SET ORSHORT=$$SHORT^ORPRS02
- +4 DO PATIENT^ORU1(.ORSCPAT,,1)
- +5 IF $SELECT($DATA(DIROUT):1,$DATA(DUOUT):1,1:0)
- SET (OREND,XQORPOP)=1
- +6 QUIT
- DAY(DAY) ; Get a date for 24 hr printing
- +1 ;DAY=Optional date for default date prompt
- +2 ;Returns: ORSSTRT=Internal Start date/time_"^"_Formatted Start date/time
- +3 ; ORSSTOP=Internal Stop date/time_"^"_Formatted Stop date/time
- +4 ; OREND,XQORPOP=1 if user ^'s or times out
- +5 ; DIROUT=1 if user ^^'s out
- +6 NEW %,%DT,%I,%T,%H,ORSDFLT,X,Y
- D1 ;
- +1 SET OREND=0
- SET ORSDFLT=$SELECT($GET(DAY):$SELECT($PIECE(DAY,".",2)=2359:DAY+.7641,1:DAY),1:"T")
- +2 WRITE !!,"Order Entry Date: "_$SELECT(+ORSDFLT>0:$$DATE^ORU(ORSDFLT,"AMTH DD, CCYY"),1:"T")_"// "
- +3 READ X:$SELECT($DATA(DTIME):DTIME,1:300)
- +4 IF $SELECT(X="^":1,X="^^":1,'$TEST:1,1:0)
- SET (OREND,XQORPOP)=1
- IF X="^^"
- SET DIROUT=1
- QUIT
- +5 IF X=""
- SET X=ORSDFLT
- +6 SET %DT="EX"
- +7 DO ^%DT
- +8 IF X["?"
- KILL DAY
- GOTO D1
- +9 IF Y<1
- WRITE $CHAR(7),?40,"Invalid Date."
- KILL DAY
- GOTO D1
- +10 SET ORSSTRT=Y-.7641_"^"_$$FMTE^XLFDT(Y-.7641)
- SET ORSSTOP=Y+.2359_"^"_$$FMTE^XLFDT(Y+.2359)
- +11 QUIT
- RANGE(X1,X2) ; Get a date range for printing
- +1 ;X1=Default Start Date/time
- +2 ;X2=Default Stop Date/time
- +3 NEW %DT,%T,ORSDFLT,X,Y
- +4 IF $DATA(ORPRES)
- IF +ORPRES=6!(+ORPRES=15)!(+ORPRES=16)!(+ORPRES=17)
- SET (ORSSTRT,ORSSTOP)=""
- QUIT
- R ;
- +1 SET OREND=0
- SET ORSDFLT=$SELECT($GET(X1)>0:$SELECT($PIECE(X1,".",2)=2359:X1+.7641,1:X1),1:"T")
- +2 WRITE !!,"Start Date [Time]: "_$SELECT(ORSDFLT>0:$$DATE^ORU(ORSDFLT,"AMTH DD, CCYY"),1:ORSDFLT)_"// "
- +3 READ X:$SELECT($DATA(DTIME):DTIME,1:300)
- +4 IF X="^"!('$TEST)
- SET (OREND,XQORPOP)=1
- +5 IF OREND
- QUIT
- +6 IF X=""
- SET X=ORSDFLT
- +7 SET %DT="EXT"
- +8 DO ^%DT
- +9 IF X["?"
- GOTO R
- +10 IF Y<1
- WRITE ?55,"Invalid Start Date/time."
- GOTO R
- +11 SET ORSSTRT=Y
- E ; Get Ending Date/time
- +1 SET ORSDFLT=$SELECT($GET(X2):$SELECT($PIECE(X2,".",2)'=2359:$PIECE(X2,".")_".2359",1:X2),$GET(ORSSTRT):$SELECT($PIECE(ORSSTRT,".",2)=2359:(ORSSTRT+.7641)_".2359",1:$PIECE(ORSSTRT,".")_".2359"),1:"T@2359")
- +2 WRITE !!,"Ending Date [Time] (inclusive): "_$SELECT(+ORSDFLT>0:$$DATE^ORU(ORSDFLT,"AMTH DD, CCYY HR:MIN"),1:ORSDFLT)_"// "
- +3 READ X:$SELECT($DATA(DTIME):DTIME,1:300)
- +4 IF X="^"!('$TEST)
- SET (OREND,XQORPOP)=1
- +5 IF OREND
- QUIT
- +6 IF X=""
- SET X=ORSDFLT
- +7 SET %DT="EXT"
- +8 DO ^%DT
- +9 IF X["?"
- GOTO E
- +10 IF Y<1
- WRITE ?57,"Invalid End Date/time."
- GOTO E
- +11 SET ORSSTOP=Y
- +12 IF ORSSTOP<ORSSTRT
- SET X=ORSSTOP
- SET ORSSTOP=ORSSTRT
- SET ORSSTRT=X
- +13 SET ORSSTOP=$SELECT($LENGTH(ORSSTOP,".")=2:ORSSTOP,1:ORSSTOP+1)_"^"_$$FMTE^XLFDT(ORSSTOP)
- +14 SET ORSSTRT=$SELECT($LENGTH(ORSSTRT,".")=2:ORSSTRT,1:ORSSTRT-.7641)_"^"_$$FMTE^XLFDT(ORSSTRT)
- +15 QUIT
- CUSTOM ; Selects order status and display group
- +1 NEW %,%Y,C,DIC,I,X,Y,XQORM,XQORSPEW,XQORNOD
- +2 SET ORBUF=1
- +3 IF $DATA(DIROUT)!($DATA(DTOUT))
- SET (OREND,XQORPOP)=1
- QUIT
- +4 IF '$DATA(ORPRES)
- SET ORPRES="2;ACTIVE ORDERS"
- +5 DO PRES^ORPRS09
- +6 IF $GET(OREND)
- SET XQORPOP=1
- QUIT
- +7 DO SERV^ORPRS09
- +8 IF $GET(OREND)
- SET XQORPOP=1
- QUIT
- +9 QUIT
- HSTS(X) ;Help for status descriptions (ORRP STATUS MENU protocol)
- +1 WRITE !,"Valid selections are: "
- +2 ;show descriptions and quit
- IF X["???"
- WRITE !
- DO HACT1
- WRITE !
- QUIT
- +3 DO DISP^XQORM1
- +4 WRITE !
- +5 QUIT
- HACT1 ;
- +1 KILL ^TMP("ORRX",$JOB)
- +2 SET Y=0
- FOR I=0:0
- SET Y=$ORDER(^ORD(101,+XQORNOD,10,Y))
- IF Y'>0
- QUIT
- IF $DATA(^ORD(101,+XQORNOD,10,Y,0))
- SET W=^(0)
- SET ^TMP("ORRX",$JOB,$PIECE(W,"^",3))=W
- +3 SET Y=0
- FOR I=1:1
- SET Y=$ORDER(^TMP("ORRX",$JOB,Y))
- IF Y'>0
- QUIT
- SET X1=^(Y)
- SET W=+X1
- IF I=20
- DO READ^ORUTL
- WRITE !,$PIECE(X1,"^",2),?5
- IF W
- IF $DATA(^ORD(101,W,0))
- WRITE $PIECE(^(0),"^",2)
- IF $PIECE(^(0),"^",2)'=" "
- IF $DATA(^ORD(101,W,1,1,0))
- WRITE " - "_^(0)
- +4 KILL W,X,^TMP("ORRX")
- +5 QUIT
- EN(ORDG,ORSEL) ;Setup/Display groups
- +1 ;ORDG(optional)=ptr to display group to setup (All is the default)
- +2 ;ORSEL(optional)=Line label of action to take (BILD<default>, DISP)
- +3 ;Returns: ORGRP if ORSEL="BILD"
- +4 IF $GET(ORSEL)'="DISP"
- SET ORSEL="BILD"
- +5 ;All if not specified
- IF '$GET(ORDG)
- SET ORDG=1
- +6 NEW ORMEM,ORSTK
- +7 SET ORSTK=0
- +8 DO @ORSEL
- +9 SET ORSTK=1
- SET ORSTK(ORSTK)=ORDG_"^0"
- SET ORSTK(0)=0
- SET ORMEM=0
- +10 FOR I=0:0
- SET ORMEM=$ORDER(^ORD(100.98,+ORSTK(ORSTK),1,ORMEM))
- DO @$SELECT(+ORMEM'>0:"POP",1:"PROC")
- IF ORSTK<1
- QUIT
- +11 QUIT
- POP ;
- +1 SET ORSTK=ORSTK-1
- SET ORMEM=$PIECE(ORSTK(ORSTK),"^",2)
- +2 QUIT
- PROC ;
- +1 SET $PIECE(ORSTK(ORSTK),"^",2)=ORMEM
- SET ORDG=$PIECE(^ORD(100.98,+ORSTK(ORSTK),1,ORMEM,0),"^",1)
- +2 DO @ORSEL
- +3 SET ORSTK=ORSTK+1
- SET ORSTK(ORSTK)=ORDG_"^0"
- SET ORMEM=0
- +4 QUIT
- DISP ;
- +1 IF $Y>(IOSL-4)
- DO READ^ORUTL
- WRITE @IOF
- +2 SET W=^ORD(100.98,ORDG,0)
- +3 WRITE !,?((ORSTK*2)),$PIECE(W,"^")
- +4 QUIT
- BILD ;
- +1 SET ORGRP(ORDG)=""
- +2 QUIT
- STOP ; Call DIR at bottom of screen
- +1 NEW DIR,X,Y
- +2 IF $EXTRACT(IOST)'="C"
- QUIT
- +3 IF IOSL>($Y+5)
- FOR
- WRITE !
- IF IOSL<($Y+6)
- QUIT
- +4 SET DIR(0)="FO^1:1"
- SET DIR("A")="Press RETURN to continue or '^' to exit"
- +5 SET DIR("?")="Enter '^' to quit present report or '^^' to quit to menu"
- +6 DO ^DIR
- +7 QUIT
- TERM(IOST) ;Setup terminal display values
- +1 ;IOST=Terminal type
- +2 ;Returns ORTERM(5)=REVERSE VIDEO ON^REVERSE VIDEO OFF
- +3 ; ORTERM(7)=HIGH INTENSITY^LOW INTENSITY^NORMAL INTENSITY
- +4 SET (ORTERM(7),ORTERM(5))=""
- +5 IF $DATA(IOST)
- IF $LENGTH(IOST)
- SET X=$ORDER(^%ZIS(2,"B",IOST,0))
- IF X
- IF $DATA(^%ZIS(2,X))
- SET ORTERM(5)=$SELECT($DATA(^(X,5)):$PIECE(^(5),"^",4,5),1:"")
- SET ORTERM(7)=$SELECT($DATA(^(7)):$PIECE(^(7),"^",1,3),1:"")
- IF '$LENGTH($PIECE(ORTERM(7),"^",3))
- SET $PIECE(ORTERM(7),"^",3)=$PIECE(ORTERM(7),"^",2)
- +6 FOR I=1:2:3
- IF '$LENGTH($PIECE(ORTERM(7),"^",I))
- SET ORTERM(7)=""
- QUIT
- +7 QUIT