VistA-FOIAVistA/r/ORDER_ENTRY_RESULTS_REPORTI.../OCXOTIME.m

60 lines
1.9 KiB
Mathematica

OCXOTIME ;SLC/RJS,CLA - PROCESS TIME BASED EVENT ;10/29/98 12:37
;;3.0;ORDER ENTRY/RESULTS REPORTING;**32**;Dec 17,1997
;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
;
;
Q
EN ;
;
Q:'$$RTEST
;
N OCXDATE,OCXDFN,OCXELEM,OCXRULE
S OCXRULE=0 F S OCXRULE=$O(^OCXD(860.1,"TIME",OCXRULE)) Q:'OCXRULE D
.S OCXDFN=0 F S OCXDFN=$O(^OCXD(860.1,"TIME",OCXRULE,OCXDFN)) Q:'OCXDFN D
..S OCXDATE=0 F S OCXDATE=$O(^OCXD(860.1,"TIME",OCXRULE,OCXDFN,OCXDATE)) Q:'OCXDATE I '((+OCXDATE)>OCXNOW) D
...N DFN,OCXOSRC,OUTMSG,OCXNOTIF,OCXELEM
...S OCXOSRC="TIMED ORDER CHECK",(OUTMSG,OCXNOTIF)=""
...S OCXORMTR="ORMTIME: Executing D UPDATE^OCXOZ01 DATE: "_OCXDATE
...D LOG(" "_OCXORMTR)
...S OCXORMTR=" RULE: "_(+OCXRULE)_" ("_$P($G(^OCXS(860.2,+OCXRULE,0)),U,1)
...D LOG(" "_OCXORMTR)
...S OCXORMTR=" Patient: "_OCXDFN_" ("_$P($G(^DPT(OCXDFN,0)),U,1)_")"
...D LOG(" "_OCXORMTR)
...S OCXELEM=0 F S OCXELEM=$O(^OCXS(860.2,OCXRULE,"C","C",OCXELEM)) Q:'OCXELEM D
....S:($P($G(^OCXS(860.6,+$P($G(^OCXS(860.3,+OCXELEM,0)),U,2),0)),U,1)="TIMED ORDER CHECK") OCXOSRC("ELEMENT",OCXELEM)=""
...K ^OCXD(860.1,"TIME",OCXRULE,OCXDFN,OCXDATE)
...K ^OCXD(860.1,OCXDFN,2,OCXDATE,1,OCXRULE)
...K ^OCXD(860.1,OCXDFN,2,OCXDATE,1,"B",OCXRULE,OCXRULE)
...I '$O(^OCXD(860.1,OCXDFN,2,0)) K ^OCXD(860.1,OCXDFN,2)
...D LOGOCX("TIMEOC")
...D UPDATE^OCXOZ01(OCXDFN,OCXOSRC,.OUTMSG)
;
Q
;
LOG(TEXT) ;
;
Q
;
LOGOCX(OCXSRC) ;
; Log Messages
Q
ERROR Q
;
ACT(OCXDATE,OCXORD) Q:'$$RTEST D CHECK("ACT") Q
;
EXP(OCXDATE,OCXORD) Q:'$$RTEST D CHECK("EXP") Q
;
CHECK(OCXMODE) ;
;
S OCXDATA("MODE")=OCXMODE
Q
;
RTEST() ;
N DATE,TMOUT
Q:'$L($T(^OCXOZ01)) 1
I '($P($G(^OCXD(861,1,0)),U,1)="SITE PREFERENCES") K ^OCXD(861,1) S ^OCXD(861,1,0)="SITE PREFERENCES"
S DATE=$P($G(^OCXD(861,1,0)),U,3)
I DATE,((+DATE)=(+$H)),(((+$P($H,",",2))-(+$P(DATE,",",2)))<1800) Q 1
Q 0
;