OCXOZ0D ;SLC/RJS,CLA - Order Check Scan ;OCT 30,2024 at 12:49
;;3.0;ORDER ENTRY/RESULTS REPORTING;**32,221,243**;Dec 17,1997;Build 242
;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
;
; ***************************************************************
; ** Warning: This routine is automatically generated by the **
; ** Rule Compiler (^OCXOCMP) and ANY changes to this routine **
; ** will be lost the next time the rule compiler executes. **
; ***************************************************************
;
Q
;
CHK395 ; Look through the current environment for valid Event/Elements for this patient.
; Called from CHK163+16^OCXOZ08.
;
Q:$G(OCXOERR)
;
; Local CHK395 Variables
; OCXDF(62) ---> Data Field: PATIENT AGE (NUMERIC)
; OCXDF(141) --> Data Field: AMITRIPTYLINE TEXT (FREE TEXT)
; OCXDF(142) --> Data Field: CHLORPROPAMIDE TEXT (FREE TEXT)
; OCXDF(144) --> Data Field: DIPYRIDAMOLE TEXT (FREE TEXT)
;
; Local Extrinsic Functions
; MSGTEXT( ---------> MESSAGE TEXT
;
I (OCXDF(62)>64) S OCXDF(141)=$$MSGTEXT("AMITRIPTYLINE"),OCXDF(142)=$$MSGTEXT("CHLORPROPAMIDE"),OCXDF(144)=$$MSGTEXT("DIPYRIDAMOLE") D CHK399
Q
;
CHK399 ; Look through the current environment for valid Event/Elements for this patient.
; Called from CHK395+14.
;
Q:$G(OCXOERR)
;
; Local Extrinsic Functions
; FILE(DFN,125, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: MED ORDER FOR PT > 64)
;
S OCXOERR=$$FILE(DFN,125,"62,141,142,144") Q:OCXOERR
Q
;
CHK407 ; Look through the current environment for valid Event/Elements for this patient.
; Called from CHK1+35^OCXOZ02.
;
Q:$G(OCXOERR)
;
; Local CHK407 Variables
; OCXDF(161) --> Data Field: ORDER TYPE (FREE TEXT)
;
I $L(OCXDF(161)) D CHK408
Q
;
CHK408 ; Look through the current environment for valid Event/Elements for this patient.
; Called from CHK407+8.
;
Q:$G(OCXOERR)
;
; Local CHK408 Variables
; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
; OCXDF(96) ---> Data Field: ORDERABLE ITEM NAME (FREE TEXT)
; OCXDF(147) --> Data Field: PATIENT LOCATION (FREE TEXT)
; OCXDF(161) --> Data Field: ORDER TYPE (FREE TEXT)
;
; Local Extrinsic Functions
; FILE(DFN,127, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: INPATIENT)
; FILE(DFN,128, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: OUTPATIENT)
; ORDITEM( ---------> GET ORDERABLE ITEM FROM ORDER NUMBER
; PATLOC( ----------> PATIENT LOCATION
;
I (OCXDF(161)="I") S OCXDF(96)=$$ORDITEM(OCXDF(34)),OCXDF(147)=$P($$PATLOC(OCXDF(37)),"^",2),OCXOERR=$$FILE(DFN,127,"9,34,96,146,147") Q:OCXOERR
I (OCXDF(161)="O") S OCXDF(96)=$$ORDITEM(OCXDF(34)),OCXDF(147)=$P($$PATLOC(OCXDF(37)),"^",2),OCXOERR=$$FILE(DFN,128,"9,34,96,146,147") Q:OCXOERR
Q
;
CHK416 ; Look through the current environment for valid Event/Elements for this patient.
; Called from CHK58+22^OCXOZ05.
;
Q:$G(OCXOERR)
;
; Local CHK416 Variables
; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
; OCXDF(57) ---> Data Field: MOST RECENT RENAL TEST ABNORMAL FLAG (BOOLEAN)
; OCXDF(58) ---> Data Field: ABNORMAL RENAL BIOCHEM RESULTS (FREE TEXT)
; OCXDF(154) --> Data Field: RECENT CONTRAST MEDIA CREATININE DAYS (NUMERIC)
; OCXDF(155) --> Data Field: RECENT CONTRAST MEDIA CREATININE FLAG (BOOLEAN)
;
; Local Extrinsic Functions
; ABREN( -----------> DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
; RECCREAT( --------> RECENT CREATININE LAB PROCEDURE
;
S OCXDF(57)=$P($$ABREN(OCXDF(37)),"^",1) I $L(OCXDF(57)),(OCXDF(57)) S OCXDF(58)=$P($$ABREN(OCXDF(37)),"^",2),OCXDF(154)=$P($$CMCDAYS^ORKRA(OCXDF(37)),"^",1) D CHK421
S OCXDF(154)=$P($$CMCDAYS^ORKRA(OCXDF(37)),"^",1) I $L(OCXDF(154)) S OCXDF(155)=$P($$RECCREAT(OCXDF(37),OCXDF(154)),"^",1) I $L(OCXDF(155)),'(OCXDF(155)) D CHK452^OCXOZ0E
Q
;
CHK421 ; Look through the current environment for valid Event/Elements for this patient.
; Called from CHK416+16.
;
Q:$G(OCXOERR)
;
; Local Extrinsic Functions
; FILE(DFN,129, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ABNORMAL RENAL RESULTS)
;
S OCXOERR=$$FILE(DFN,129,"58,154") Q:OCXOERR
Q
;
ABREN(DFN) ; Compiler Function: DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
;
N OCXFLAG,OCXVAL,OCXLIST,OCXTEST,UNAV,OCXTLIST,OCXTERM,OCXSLIST,OCXSPEC
S (OCXLIST,OCXTLIST)="",UNAV="0^<Unavailable>"
S OCXSLIST="" Q:'$$TERMLKUP("SERUM SPECIMEN",.OCXSLIST) UNAV
F OCXTERM="SERUM CREATININE","SERUM UREA NITROGEN" D Q:($L(OCXLIST)>130)
.Q:'$$TERMLKUP(OCXTERM,.OCXTLIST)
.S OCXTEST=0 F S OCXTEST=$O(OCXTLIST(OCXTEST)) Q:'OCXTEST D Q:($L(OCXLIST)>130)
..S OCXSPEC=0 F S OCXSPEC=$O(OCXSLIST(OCXSPEC)) Q:'OCXSPEC D Q:($L(OCXLIST)>130)
...S OCXVAL=$$LOCL^ORQQLR1(DFN,OCXTEST,OCXSPEC),OCXFLAG=$P(OCXVAL,U,5)
...I $L(OCXVAL),((OCXFLAG["H")!(OCXFLAG["L")) D
....N OCXY S OCXY=""
....S OCXY=$P(OCXVAL,U,2)_": "_$P(OCXVAL,U,3)_" "_$P(OCXVAL,U,4)
....S OCXY=OCXY_" "_$S($L(OCXFLAG):"["_OCXFLAG_"]",1:"")
....S OCXY=OCXY_" "_$$FMTE^XLFDT($P(OCXVAL,U,7),"2P")
....S:$L(OCXLIST) OCXLIST=OCXLIST_" " S OCXLIST=OCXLIST_OCXY
Q:'$L(OCXLIST) UNAV Q 1_U_OCXLIST
;
;
FILE(DFN,OCXELE,OCXDFL) ; This Local Extrinsic Function logs a validated event/element.
;
N OCXTIMN,OCXTIML,OCXTIMT1,OCXTIMT2,OCXDATA,OCXPC,OCXPC,OCXVAL,OCXSUB,OCXDFI
S DFN=+$G(DFN),OCXELE=+$G(OCXELE)
;
Q:'DFN 1 Q:'OCXELE 1 K OCXDATA
;
S OCXDATA(DFN,OCXELE)=1
F OCXPC=1:1:$L(OCXDFL,",") S OCXDFI=$P(OCXDFL,",",OCXPC) I OCXDFI D
.S OCXVAL=$G(OCXDF(+OCXDFI)),OCXDATA(DFN,OCXELE,+OCXDFI)=OCXVAL
;
M ^TMP("OCXCHK",$J,DFN)=OCXDATA(DFN)
;
Q 0
;
MSGTEXT(ID) ; Compiler Function: MESSAGE TEXT
;
N MSG
S MSG=""
;
I ID="AMITRIPTYLINE" D
.S MSG="Amitriptyline can cause cognitive impairment and loss of"
.S MSG=MSG_" balance in older patients. Consider other antidepressant"
.S MSG=MSG_" medications on formulary."
;
I ID="CHLORPROPAMIDE" D
.S MSG="Older patients may experience hypoglycemia with"
.S MSG=MSG_" Chlorpropamide due to its long duration and variable"
.S MSG=MSG_" renal secretion. They may also be at increased risk for"
.S MSG=MSG_" Chlorpropamide-induced SIADH."
;
I ID="DIPYRIDAMOLE" D
.S MSG="Older patients can experience adverse reactions at high doses"
.S MSG=MSG_" of Dipyridamole (e.g., headache, dizziness, syncope, GI"
.S MSG=MSG_" intolerance.) There is also questionable efficacy at"
.S MSG=MSG_" lower doses."
;
I ID="CLOZWBC30_35" D
.S MSG="WBC between 3.0 and 3.5 with no ANC - pharmacy cannot fill"
.S MSG=MSG_" clozapine order. Please order CBC/Diff with WBC and ANC"
.S MSG=MSG_" immediately."
;
Q MSG
;
ORDITEM(OIEN) ; Compiler Function: GET ORDERABLE ITEM FROM ORDER NUMBER
Q:'$G(OIEN) ""
;
N OITXT,X S OITXT=$$OI^ORQOR2(OIEN) Q:'OITXT "No orderable item found."
S X=$G(^ORD(101.43,+OITXT,0)) Q:'$L(X) "No orderable item found."
Q $P(X,U,1)
;
PATLOC(DFN) ; Compiler Function: PATIENT LOCATION
;
N OCXP1,OCXP2
S OCXP1=$G(^TMP("OCXSWAP",$J,"OCXODATA","PV1",2))
S OCXP2=$P($G(^TMP("OCXSWAP",$J,"OCXODATA","PV1",3)),"^",1)
I OCXP2 D
.S OCXP2=$P($G(^SC(+OCXP2,0)),"^",1,2)
.I $L($P(OCXP2,"^",2)) S OCXP2=$P(OCXP2,"^",2)
.E S OCXP2=$P(OCXP2,"^",1)
.S:'$L(OCXP2) OCXP2="NO LOC"
I $L(OCXP1),$L(OCXP2) Q OCXP1_"^"_OCXP2
;
S OCXP2=$G(^DPT(+$G(DFN),.1))
I $L(OCXP2) Q "I^"_OCXP2
Q "O^OUTPT"
;
RECCREAT(ORDFN,ORDAYS) ;extrinsic function to return most recent
;SERUM CREATININE within <ORDAYS> in format:
; test id^result units flag ref range collection d/t
N BDT,CDT,ORY,ORX,ORZ,X,ORI,ORJ,CREARSLT,LABFILE,SPECFILE
Q:'$L($G(ORDFN)) "0^"
Q:'$L($G(ORDAYS)) "0^"
D NOW^%DTC
S BDT=$$FMADD^XLFDT(%,"-"_ORDAYS,"","","")
K %
Q:'$L($G(BDT)) "0^"
S LABFILE=$$TERMLKUP("SERUM CREATININE",.ORY)
Q:$G(LABFILE)'=60 "0^"
Q:+$D(ORY)<1 "0^"
S SPECFILE=$$TERMLKUP("SERUM SPECIMEN",.ORX)
Q:$G(SPECFILE)'=61 "0^"
Q:+$D(ORX)<1 "0^"
S ORI=0 F S ORI=$O(ORY(ORI)) Q:'ORI I +$G(CREARSLT)<1 D
.S ORJ=0 F S ORJ=$O(ORX(ORJ)) Q:'ORJ I +$G(CREARSLT)<1 D
..S ORZ=$$LOCL^ORQQLR1(ORDFN,ORI,ORJ)
..Q:'$L($G(ORZ))
..S CDT=$P(ORZ,U,7)
..I CDT'<BDT S CREARSLT=1
Q:+$G(CREARSLT)<1 "0^"
Q $P(ORZ,U)_U_$P(ORZ,U,3)_" "_$P(ORZ,U,4)_" "_$P(ORZ,U,5)_" ("_$P(ORZ,U,6)_") "_$$FMTE^XLFDT(CDT,"2P")_U_$P(ORZ,U,3)
;
TERMLKUP(OCXTERM,OCXLIST) ;
Q $$TERM^OCXOZ01(OCXTERM,.OCXLIST)
;
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HOCXOZ0D 8570 printed Dec 13, 2024@02:25:59 Page 2
OCXOZ0D ;SLC/RJS,CLA - Order Check Scan ;OCT 30,2024 at 12:49
+1 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32,221,243**;Dec 17,1997;Build 242
+2 ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
+3 ;
+4 ; ***************************************************************
+5 ; ** Warning: This routine is automatically generated by the **
+6 ; ** Rule Compiler (^OCXOCMP) and ANY changes to this routine **
+7 ; ** will be lost the next time the rule compiler executes. **
+8 ; ***************************************************************
+9 ;
+10 QUIT
+11 ;
CHK395 ; Look through the current environment for valid Event/Elements for this patient.
+1 ; Called from CHK163+16^OCXOZ08.
+2 ;
+3 if $GET(OCXOERR)
QUIT
+4 ;
+5 ; Local CHK395 Variables
+6 ; OCXDF(62) ---> Data Field: PATIENT AGE (NUMERIC)
+7 ; OCXDF(141) --> Data Field: AMITRIPTYLINE TEXT (FREE TEXT)
+8 ; OCXDF(142) --> Data Field: CHLORPROPAMIDE TEXT (FREE TEXT)
+9 ; OCXDF(144) --> Data Field: DIPYRIDAMOLE TEXT (FREE TEXT)
+10 ;
+11 ; Local Extrinsic Functions
+12 ; MSGTEXT( ---------> MESSAGE TEXT
+13 ;
+14 IF (OCXDF(62)>64)
SET OCXDF(141)=$$MSGTEXT("AMITRIPTYLINE")
SET OCXDF(142)=$$MSGTEXT("CHLORPROPAMIDE")
SET OCXDF(144)=$$MSGTEXT("DIPYRIDAMOLE")
DO CHK399
+15 QUIT
+16 ;
CHK399 ; Look through the current environment for valid Event/Elements for this patient.
+1 ; Called from CHK395+14.
+2 ;
+3 if $GET(OCXOERR)
QUIT
+4 ;
+5 ; Local Extrinsic Functions
+6 ; FILE(DFN,125, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: MED ORDER FOR PT > 64)
+7 ;
+8 SET OCXOERR=$$FILE(DFN,125,"62,141,142,144")
if OCXOERR
QUIT
+9 QUIT
+10 ;
CHK407 ; Look through the current environment for valid Event/Elements for this patient.
+1 ; Called from CHK1+35^OCXOZ02.
+2 ;
+3 if $GET(OCXOERR)
QUIT
+4 ;
+5 ; Local CHK407 Variables
+6 ; OCXDF(161) --> Data Field: ORDER TYPE (FREE TEXT)
+7 ;
+8 IF $LENGTH(OCXDF(161))
DO CHK408
+9 QUIT
+10 ;
CHK408 ; Look through the current environment for valid Event/Elements for this patient.
+1 ; Called from CHK407+8.
+2 ;
+3 if $GET(OCXOERR)
QUIT
+4 ;
+5 ; Local CHK408 Variables
+6 ; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
+7 ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
+8 ; OCXDF(96) ---> Data Field: ORDERABLE ITEM NAME (FREE TEXT)
+9 ; OCXDF(147) --> Data Field: PATIENT LOCATION (FREE TEXT)
+10 ; OCXDF(161) --> Data Field: ORDER TYPE (FREE TEXT)
+11 ;
+12 ; Local Extrinsic Functions
+13 ; FILE(DFN,127, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: INPATIENT)
+14 ; FILE(DFN,128, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: OUTPATIENT)
+15 ; ORDITEM( ---------> GET ORDERABLE ITEM FROM ORDER NUMBER
+16 ; PATLOC( ----------> PATIENT LOCATION
+17 ;
+18 IF (OCXDF(161)="I")
SET OCXDF(96)=$$ORDITEM(OCXDF(34))
SET OCXDF(147)=$PIECE($$PATLOC(OCXDF(37)),"^",2)
SET OCXOERR=$$FILE(DFN,127,"9,34,96,146,147")
if OCXOERR
QUIT
+19 IF (OCXDF(161)="O")
SET OCXDF(96)=$$ORDITEM(OCXDF(34))
SET OCXDF(147)=$PIECE($$PATLOC(OCXDF(37)),"^",2)
SET OCXOERR=$$FILE(DFN,128,"9,34,96,146,147")
if OCXOERR
QUIT
+20 QUIT
+21 ;
CHK416 ; Look through the current environment for valid Event/Elements for this patient.
+1 ; Called from CHK58+22^OCXOZ05.
+2 ;
+3 if $GET(OCXOERR)
QUIT
+4 ;
+5 ; Local CHK416 Variables
+6 ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
+7 ; OCXDF(57) ---> Data Field: MOST RECENT RENAL TEST ABNORMAL FLAG (BOOLEAN)
+8 ; OCXDF(58) ---> Data Field: ABNORMAL RENAL BIOCHEM RESULTS (FREE TEXT)
+9 ; OCXDF(154) --> Data Field: RECENT CONTRAST MEDIA CREATININE DAYS (NUMERIC)
+10 ; OCXDF(155) --> Data Field: RECENT CONTRAST MEDIA CREATININE FLAG (BOOLEAN)
+11 ;
+12 ; Local Extrinsic Functions
+13 ; ABREN( -----------> DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
+14 ; RECCREAT( --------> RECENT CREATININE LAB PROCEDURE
+15 ;
+16 SET OCXDF(57)=$PIECE($$ABREN(OCXDF(37)),"^",1)
IF $LENGTH(OCXDF(57))
IF (OCXDF(57))
SET OCXDF(58)=$PIECE($$ABREN(OCXDF(37)),"^",2)
SET OCXDF(154)=$PIECE($$CMCDAYS^ORKRA(OCXDF(37)),"^",1)
DO CHK421
+17 SET OCXDF(154)=$PIECE($$CMCDAYS^ORKRA(OCXDF(37)),"^",1)
IF $LENGTH(OCXDF(154))
SET OCXDF(155)=$PIECE($$RECCREAT(OCXDF(37),OCXDF(154)),"^",1)
IF $LENGTH(OCXDF(155))
IF '(OCXDF(155))
DO CHK452^OCXOZ0E
+18 QUIT
+19 ;
CHK421 ; Look through the current environment for valid Event/Elements for this patient.
+1 ; Called from CHK416+16.
+2 ;
+3 if $GET(OCXOERR)
QUIT
+4 ;
+5 ; Local Extrinsic Functions
+6 ; FILE(DFN,129, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ABNORMAL RENAL RESULTS)
+7 ;
+8 SET OCXOERR=$$FILE(DFN,129,"58,154")
if OCXOERR
QUIT
+9 QUIT
+10 ;
ABREN(DFN) ; Compiler Function: DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
+1 ;
+2 NEW OCXFLAG,OCXVAL,OCXLIST,OCXTEST,UNAV,OCXTLIST,OCXTERM,OCXSLIST,OCXSPEC
+3 SET (OCXLIST,OCXTLIST)=""
SET UNAV="0^<Unavailable>"
+4 SET OCXSLIST=""
if '$$TERMLKUP("SERUM SPECIMEN",.OCXSLIST)
QUIT UNAV
+5 FOR OCXTERM="SERUM CREATININE","SERUM UREA NITROGEN"
Begin DoDot:1
+6 if '$$TERMLKUP(OCXTERM,.OCXTLIST)
QUIT
+7 SET OCXTEST=0
FOR
SET OCXTEST=$ORDER(OCXTLIST(OCXTEST))
if 'OCXTEST
QUIT
Begin DoDot:2
+8 SET OCXSPEC=0
FOR
SET OCXSPEC=$ORDER(OCXSLIST(OCXSPEC))
if 'OCXSPEC
QUIT
Begin DoDot:3
+9 SET OCXVAL=$$LOCL^ORQQLR1(DFN,OCXTEST,OCXSPEC)
SET OCXFLAG=$PIECE(OCXVAL,U,5)
+10 IF $LENGTH(OCXVAL)
IF ((OCXFLAG["H")!(OCXFLAG["L"))
Begin DoDot:4
+11 NEW OCXY
SET OCXY=""
+12 SET OCXY=$PIECE(OCXVAL,U,2)_": "_$PIECE(OCXVAL,U,3)_" "_$PIECE(OCXVAL,U,4)
+13 SET OCXY=OCXY_" "_$SELECT($LENGTH(OCXFLAG):"["_OCXFLAG_"]",1:"")
+14 SET OCXY=OCXY_" "_$$FMTE^XLFDT($PIECE(OCXVAL,U,7),"2P")
+15 if $LENGTH(OCXLIST)
SET OCXLIST=OCXLIST_" "
SET OCXLIST=OCXLIST_OCXY
End DoDot:4
End DoDot:3
if ($LENGTH(OCXLIST)>130)
QUIT
End DoDot:2
if ($LENGTH(OCXLIST)>130)
QUIT
End DoDot:1
if ($LENGTH(OCXLIST)>130)
QUIT
+16 if '$LENGTH(OCXLIST)
QUIT UNAV
QUIT 1_U_OCXLIST
+17 ;
+18 ;
FILE(DFN,OCXELE,OCXDFL) ; This Local Extrinsic Function logs a validated event/element.
+1 ;
+2 NEW OCXTIMN,OCXTIML,OCXTIMT1,OCXTIMT2,OCXDATA,OCXPC,OCXPC,OCXVAL,OCXSUB,OCXDFI
+3 SET DFN=+$GET(DFN)
SET OCXELE=+$GET(OCXELE)
+4 ;
+5 if 'DFN
QUIT 1
if 'OCXELE
QUIT 1
KILL OCXDATA
+6 ;
+7 SET OCXDATA(DFN,OCXELE)=1
+8 FOR OCXPC=1:1:$LENGTH(OCXDFL,",")
SET OCXDFI=$PIECE(OCXDFL,",",OCXPC)
IF OCXDFI
Begin DoDot:1
+9 SET OCXVAL=$GET(OCXDF(+OCXDFI))
SET OCXDATA(DFN,OCXELE,+OCXDFI)=OCXVAL
End DoDot:1
+10 ;
+11 MERGE ^TMP("OCXCHK",$JOB,DFN)=OCXDATA(DFN)
+12 ;
+13 QUIT 0
+14 ;
MSGTEXT(ID) ; Compiler Function: MESSAGE TEXT
+1 ;
+2 NEW MSG
+3 SET MSG=""
+4 ;
+5 IF ID="AMITRIPTYLINE"
Begin DoDot:1
+6 SET MSG="Amitriptyline can cause cognitive impairment and loss of"
+7 SET MSG=MSG_" balance in older patients. Consider other antidepressant"
+8 SET MSG=MSG_" medications on formulary."
End DoDot:1
+9 ;
+10 IF ID="CHLORPROPAMIDE"
Begin DoDot:1
+11 SET MSG="Older patients may experience hypoglycemia with"
+12 SET MSG=MSG_" Chlorpropamide due to its long duration and variable"
+13 SET MSG=MSG_" renal secretion. They may also be at increased risk for"
+14 SET MSG=MSG_" Chlorpropamide-induced SIADH."
End DoDot:1
+15 ;
+16 IF ID="DIPYRIDAMOLE"
Begin DoDot:1
+17 SET MSG="Older patients can experience adverse reactions at high doses"
+18 SET MSG=MSG_" of Dipyridamole (e.g., headache, dizziness, syncope, GI"
+19 SET MSG=MSG_" intolerance.) There is also questionable efficacy at"
+20 SET MSG=MSG_" lower doses."
End DoDot:1
+21 ;
+22 IF ID="CLOZWBC30_35"
Begin DoDot:1
+23 SET MSG="WBC between 3.0 and 3.5 with no ANC - pharmacy cannot fill"
+24 SET MSG=MSG_" clozapine order. Please order CBC/Diff with WBC and ANC"
+25 SET MSG=MSG_" immediately."
End DoDot:1
+26 ;
+27 QUIT MSG
+28 ;
ORDITEM(OIEN) ; Compiler Function: GET ORDERABLE ITEM FROM ORDER NUMBER
+1 if '$GET(OIEN)
QUIT ""
+2 ;
+3 NEW OITXT,X
SET OITXT=$$OI^ORQOR2(OIEN)
if 'OITXT
QUIT "No orderable item found."
+4 SET X=$GET(^ORD(101.43,+OITXT,0))
if '$LENGTH(X)
QUIT "No orderable item found."
+5 QUIT $PIECE(X,U,1)
+6 ;
PATLOC(DFN) ; Compiler Function: PATIENT LOCATION
+1 ;
+2 NEW OCXP1,OCXP2
+3 SET OCXP1=$GET(^TMP("OCXSWAP",$JOB,"OCXODATA","PV1",2))
+4 SET OCXP2=$PIECE($GET(^TMP("OCXSWAP",$JOB,"OCXODATA","PV1",3)),"^",1)
+5 IF OCXP2
Begin DoDot:1
+6 SET OCXP2=$PIECE($GET(^SC(+OCXP2,0)),"^",1,2)
+7 IF $LENGTH($PIECE(OCXP2,"^",2))
SET OCXP2=$PIECE(OCXP2,"^",2)
+8 IF '$TEST
SET OCXP2=$PIECE(OCXP2,"^",1)
+9 if '$LENGTH(OCXP2)
SET OCXP2="NO LOC"
End DoDot:1
+10 IF $LENGTH(OCXP1)
IF $LENGTH(OCXP2)
QUIT OCXP1_"^"_OCXP2
+11 ;
+12 SET OCXP2=$GET(^DPT(+$GET(DFN),.1))
+13 IF $LENGTH(OCXP2)
QUIT "I^"_OCXP2
+14 QUIT "O^OUTPT"
+15 ;
RECCREAT(ORDFN,ORDAYS) ;extrinsic function to return most recent
+1 ;SERUM CREATININE within <ORDAYS> in format:
+2 ; test id^result units flag ref range collection d/t
+3 NEW BDT,CDT,ORY,ORX,ORZ,X,ORI,ORJ,CREARSLT,LABFILE,SPECFILE
+4 if '$LENGTH($GET(ORDFN))
QUIT "0^"
+5 if '$LENGTH($GET(ORDAYS))
QUIT "0^"
+6 DO NOW^%DTC
+7 SET BDT=$$FMADD^XLFDT(%,"-"_ORDAYS,"","","")
+8 KILL %
+9 if '$LENGTH($GET(BDT))
QUIT "0^"
+10 SET LABFILE=$$TERMLKUP("SERUM CREATININE",.ORY)
+11 if $GET(LABFILE)'=60
QUIT "0^"
+12 if +$DATA(ORY)<1
QUIT "0^"
+13 SET SPECFILE=$$TERMLKUP("SERUM SPECIMEN",.ORX)
+14 if $GET(SPECFILE)'=61
QUIT "0^"
+15 if +$DATA(ORX)<1
QUIT "0^"
+16 SET ORI=0
FOR
SET ORI=$ORDER(ORY(ORI))
if 'ORI
QUIT
IF +$GET(CREARSLT)<1
Begin DoDot:1
+17 SET ORJ=0
FOR
SET ORJ=$ORDER(ORX(ORJ))
if 'ORJ
QUIT
IF +$GET(CREARSLT)<1
Begin DoDot:2
+18 SET ORZ=$$LOCL^ORQQLR1(ORDFN,ORI,ORJ)
+19 if '$LENGTH($GET(ORZ))
QUIT
+20 SET CDT=$PIECE(ORZ,U,7)
+21 IF CDT'<BDT
SET CREARSLT=1
End DoDot:2
End DoDot:1
+22 if +$GET(CREARSLT)<1
QUIT "0^"
+23 QUIT $PIECE(ORZ,U)_U_$PIECE(ORZ,U,3)_" "_$PIECE(ORZ,U,4)_" "_$PIECE(ORZ,U,5)_" ("_$PIECE(ORZ,U,6)_") "_$$FMTE^XLFDT(CDT,"2P")_U_$PIECE(ORZ,U,3)
+24 ;
TERMLKUP(OCXTERM,OCXLIST) ;
+1 QUIT $$TERM^OCXOZ01(OCXTERM,.OCXLIST)
+2 ;