Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: ORWDLR33

ORWDLR33.m

Go to the documentation of this file.
  1. ORWDLR33 ; SLC/KCM/REV/JDL - Lab Calls ;7/1/2002 11AM
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**10,85,141,243,315**;Dec 17, 1997;Build 20
  1. ;
  1. ;
  1. ; DBIA 2388 ^LAB(61
  1. ; DBIA 2429 ^LR7OV4
  1. ; DBIA 2992 ^XTV(8989.51
  1. ;
  1. STOP(VAL,X2) ; return a calculated stop date
  1. N X1,X
  1. S X1=DT D C^%DTC S VAL=X
  1. Q
  1. MAXDAYS(Y,LOC,SCHED) ; Return max number of days for a continuing order
  1. N TMP1,TMP2
  1. K ^TMP($J,"ORWDLR33 MAXDAYS")
  1. S TMP1=$$GET^XPAR("ALL^LOC.`"_+LOC,"LR MAX DAYS CONTINUOUS",1,"Q")
  1. I +TMP1=0 S Y="-1" Q
  1. I +$G(SCHED)>0 D ZERO^PSS51P1(SCHED,,,,"ORWDLR33 MAXDAYS") S TMP2=$G(^TMP($J,"ORWDLR33 MAXDAYS",SCHED,2.5)) K ^TMP($J,"ORWDLR33 MAXDAYS")
  1. E S TMP2=0
  1. I +TMP1=0,+TMP2>0 S Y=TMP2 Q
  1. I +TMP2=0,+TMP1>0 S Y=TMP1 Q
  1. S Y=$S(+TMP1>+TMP2:+TMP2,+TMP2>+TMP1:+TMP1,+TMP1=+TMP2:+TMP1,1:0)
  1. K ^TMP($J,"ORWDLR33 MAXDAYS")
  1. Q
  1. ALLSPEC(Y,FROM,DIR) ; Return a set of specimens from topography file
  1. N I,IEN,CNT,A,%,NOW,B
  1. D NOW^%DTC S NOW=$P(%,".")
  1. S I=0,CNT=44
  1. F Q:I'<CNT S FROM=$O(^LAB(61,"B",FROM),DIR) Q:FROM="" D
  1. . S IEN=0 F S IEN=$O(^LAB(61,"B",FROM,IEN)) Q:'IEN D
  1. . . S A=$G(^LAB(61,IEN,64.91)) S B=$P(A,"^",3) I B]"",B'>NOW Q
  1. . . S I=I+1,Y(I)=IEN_U_FROM_" ("_$P($G(^LAB(61,IEN,0)),U,2)_")"
  1. Q
  1. LABCOLTM(ORYN,ORDATE,ORLOC) ; Is this a routine lab collect time for this location?
  1. N ORDA,ORTI,ORDOW,ORCTM,I,X,Y
  1. S ORYN=0 Q:'$G(ORDATE)!($G(ORDATE)<0)!('$G(ORLOC))
  1. S ORDA=$P(ORDATE,".",1),ORTI=$P(ORDATE,".",2)
  1. S I=0 F S I=$L(ORTI) Q:I>3 S ORTI=ORTI_"0"
  1. S X=ORDA D DW^%DTC S ORDOW=X
  1. D GETLST^XPAR(.ORCTM,"ALL","LR PHLEBOTOMY COLLECTION","Q")
  1. S I=0 F S I=$O(ORCTM(I)) Q:'I D
  1. . S:$P(ORCTM(I),U,2)=ORTI ORYN=1
  1. Q:ORYN=0
  1. I $G(ORLOC),$$GET^XPAR(ORLOC_";SC(","LR EXCEPTED LOCATIONS",1,"Q") S ORYN=1 Q
  1. I '$$GET^XPAR("ALL","LR IGNORE HOLIDAYS",1,"Q"),$D(^HOLIDAY(ORDA,0)) S ORYN=0 Q
  1. I $$GET^XPAR("ALL","LR COLLECT "_ORDOW,1,"Q") S ORYN=1 Q
  1. S ORYN=0
  1. Q
  1. IMMCOLL(ORY) ; Return help screen showing immediate collect times
  1. D SHOW^LR7OV4(DUZ(2),.ORY)
  1. Q
  1. ICDEFLT(ORY) ;Return default immediate collect time
  1. S ORY=$$DEFTIME^LR7OV4(DUZ(2))
  1. Q
  1. ICVALID(ORY,ORTIME) ;Is the time a valid immediate collect time?
  1. S ORTIME=$P(ORTIME,".",1)_"."_$E($P(ORTIME,".",2),1,4)
  1. S ORY=$$VALID^LR7OV4(DUZ(2),ORTIME)
  1. Q
  1. GETLABTM(ORY,ORDATE,ORLOC) ;Return list of lab collect times for a date and location
  1. N ORDA,ORTI,ORNOW,ORDOW,ORCTM,ORTI,X,%,%H
  1. S ORY(0)=0 Q:'$G(ORDATE)!($G(ORDATE)<0)!('$G(ORLOC))
  1. S ORDA=$P(ORDATE,".",1)
  1. S ORNOW=$$NOW^XLFDT,ORTI=$P(ORNOW,".",2)
  1. I ORDA<$P(ORNOW,".",1) S ORY(0)="-1^Dates in the past are not allowed." Q
  1. I '+$$GET^XPAR(ORLOC_";SC(","LR EXCEPTED LOCATIONS",1,"Q") D
  1. . S X=ORDA D DW^%DTC S ORDOW=X
  1. . I '+$$GET^XPAR("ALL","LR COLLECT "_ORDOW,1,"Q") S ORY(0)="-1^No collections on "_ORDOW Q
  1. . I '+$$GET^XPAR("ALL","LR IGNORE HOLIDAYS",1,"Q"),$D(^HOLIDAY(ORDA,0)) S ORY(0)="-1^No holiday collections" Q
  1. I +ORY(0)>-1 D
  1. . D GETLST^XPAR(.ORY,"ALL","LR PHLEBOTOMY COLLECTION","Q")
  1. . I +$G(ORY)=0 S ORY(0)="-1^No lab collect times defined for this division" Q
  1. S I=0 F S I=$O(ORY(I)) Q:'I D
  1. . D NOW^%DTC S ORTI=%,%H=+%H_","_+ORY(I) D YMD^%DTC
  1. . I (ORDA=$P(ORTI,".",1)),(+(ORDA+%)<+ORTI) K ORY(I) S ORY=ORY-1 Q ; cutoff time has passed for this collect time
  1. . S ORY(I)=$P(ORY(I),U,2)
  1. I +$G(ORY)=0,('$D(ORY(0))) S ORY(0)="-1^All of today's collection times have passed."
  1. Q
  1. LCFUTR(ORDY,ORLOC,ORDIV) ;Get # of days for future Lab Collects
  1. ; For Event Delay Order
  1. ; --ORLOC Event default location
  1. ; --ORDIV Event default division
  1. S ORDY=0
  1. Q:'$D(^XTV(8989.51,"B","LR LAB COLLECT FUTURE"))
  1. I $G(ORDIV) S ORDY=+$$GET^XPAR(+$G(ORLOC)_";SC("_"^"_+$G(ORDIV)_";DIC(4,^SYS^PKG","LR LAB COLLECT FUTURE",1,"I")
  1. E S ORDY=+$$GET^XPAR(+$G(ORLOC)_";SC("_"^DIV^SYS^PKG","LR LAB COLLECT FUTURE",1,"I")
  1. ;S DUZ(2)=TMPDIV
  1. Q
  1. LASTTIME(ORY) ; Get last collection time used from ^TMP("ORECALL",$J) array
  1. N ORDIALOG,ORTYPE,ORTIME
  1. S ORDIALOG=$O(^ORD(101.41,"B","LR OTHER LAB TESTS",0))
  1. S ORTYPE=$O(^ORD(101.41,"B","OR GTX COLLECTION TYPE",0))
  1. S ORTIME=$O(^ORD(101.41,"B","OR GTX START DATE/TIME",0))
  1. S ORY=$$RECALL^ORCD(ORTYPE,1)_U_$$RECALL^ORCD(ORTIME,1)
  1. Q
  1. LCTOWC(ORTXT,ORLOC) ; return text instructing user when LC changed to WC on accept/release
  1. N ORDIV,ORSVC
  1. S ORDIV=DUZ(2)
  1. S ORSVC=+$G(^VA(200,DUZ,5))
  1. I ORSVC S ORTXT=$$GET^XPAR(+$G(ORLOC)_";SC("_"^"_+$G(ORSVC)_";DIC(49,^"_+$G(ORDIV)_";DIC(4,^SYS^PKG","ORWLR LC CHANGED TO WC",1,"I")
  1. E S ORTXT=$$GET^XPAR(+$G(ORLOC)_";SC("_"^SVC^"_+$G(ORDIV)_";DIC(4,^SYS^PKG","ORWLR LC CHANGED TO WC",1,"I")
  1. Q