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

OCXOZ0E.m

Go to the documentation of this file.
  1. OCXOZ0E ;SLC/RJS,CLA - Order Check Scan ;JAN 28,2014 at 03:37
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32,221,243**;Dec 17,1997;Build 242
  1. ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
  1. ;
  1. ; ***************************************************************
  1. ; ** Warning: This routine is automatically generated by the **
  1. ; ** Rule Compiler (^OCXOCMP) and ANY changes to this routine **
  1. ; ** will be lost the next time the rule compiler executes. **
  1. ; ***************************************************************
  1. ;
  1. Q
  1. ;
  1. CHK436 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK1+33^OCXOZ02.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK436 Variables
  1. ; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
  1. ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
  1. ; OCXDF(96) ---> Data Field: ORDERABLE ITEM NAME (FREE TEXT)
  1. ; OCXDF(146) --> Data Field: INPT/OUTPT (FREE TEXT)
  1. ; OCXDF(147) --> Data Field: PATIENT LOCATION (FREE TEXT)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; FILE(DFN,127, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: INPATIENT)
  1. ; FILE(DFN,128, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: OUTPATIENT)
  1. ; ORDITEM( ---------> GET ORDERABLE ITEM FROM ORDER NUMBER
  1. ; PATLOC( ----------> PATIENT LOCATION
  1. ;
  1. I (OCXDF(146)="I"),$L(OCXDF(34)) S OCXDF(96)=$$ORDITEM(OCXDF(34)),OCXDF(147)=$P($$PATLOC(OCXDF(37)),"^",2),OCXOERR=$$FILE(DFN,127,"9,96,147") Q:OCXOERR
  1. I (OCXDF(146)="O"),$L(OCXDF(34)) S OCXDF(96)=$$ORDITEM(OCXDF(34)),OCXDF(147)=$P($$PATLOC(OCXDF(37)),"^",2),OCXOERR=$$FILE(DFN,128,"9,96,147") Q:OCXOERR
  1. Q
  1. ;
  1. CHK446 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK58+22^OCXOZ05.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK446 Variables
  1. ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
  1. ; OCXDF(57) ---> Data Field: MOST RECENT RENAL TEST ABNORMAL FLAG (BOOLEAN)
  1. ; OCXDF(58) ---> Data Field: ABNORMAL RENAL BIOCHEM RESULTS (FREE TEXT)
  1. ; OCXDF(154) --> Data Field: RECENT CONTRAST MEDIA CREATININE DAYS (NUMERIC)
  1. ; OCXDF(155) --> Data Field: RECENT CONTRAST MEDIA CREATININE FLAG (BOOLEAN)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; ABREN( -----------> DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
  1. ; RECCREAT( --------> RECENT CREATININE LAB PROCEDURE
  1. ;
  1. 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 CHK451
  1. 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 CHK482^OCXOZ0F
  1. Q
  1. ;
  1. CHK451 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK446+16.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; FILE(DFN,129, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ABNORMAL RENAL RESULTS)
  1. ;
  1. S OCXOERR=$$FILE(DFN,129,"58,154") Q:OCXOERR
  1. Q
  1. ;
  1. CHK458 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK196+15^OCXOZ09.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK458 Variables
  1. ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
  1. ; OCXDF(58) ---> Data Field: ABNORMAL RENAL BIOCHEM RESULTS (FREE TEXT)
  1. ; OCXDF(154) --> Data Field: RECENT CONTRAST MEDIA CREATININE DAYS (NUMERIC)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; ABREN( -----------> DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
  1. ; FILE(DFN,130, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: CONTRAST MEDIA ORDER)
  1. ;
  1. S OCXDF(58)=$P($$ABREN(OCXDF(37)),"^",2),OCXDF(154)=$P($$CMCDAYS^ORKRA(OCXDF(37)),"^",1),OCXOERR=$$FILE(DFN,130,"58,154") Q:OCXOERR
  1. Q
  1. ;
  1. CHK463 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK1+34^OCXOZ02.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK463 Variables
  1. ; OCXDF(12) ---> Data Field: LAB RESULT (FREE TEXT)
  1. ; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
  1. ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
  1. ; OCXDF(96) ---> Data Field: ORDERABLE ITEM NAME (FREE TEXT)
  1. ; OCXDF(113) --> Data Field: LAB TEST ID (NUMERIC)
  1. ; OCXDF(150) --> Data Field: LAB RESULT < THRESHOLD (BOOLEAN)
  1. ; OCXDF(151) --> Data Field: LAB RESULT > THRESHOLD (BOOLEAN)
  1. ; OCXDF(152) --> Data Field: LAB SPECIMEN ID (NUMERIC)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; LABTHRSB( --------> LAB THRESHOLD EXCEEDED BOOLEAN
  1. ; ORDITEM( ---------> GET ORDERABLE ITEM FROM ORDER NUMBER
  1. ;
  1. S OCXDF(151)=$P($$LABTHRSB(OCXDF(113),OCXDF(152),OCXDF(12),">"),"^",1) I $L(OCXDF(151)),(OCXDF(151)),$L(OCXDF(34)) S OCXDF(96)=$$ORDITEM(OCXDF(34)) I $L(OCXDF(37)) D CHK469^OCXOZ0F
  1. S OCXDF(150)=$P($$LABTHRSB(OCXDF(113),OCXDF(152),OCXDF(12),"<"),"^",1) I $L(OCXDF(150)),(OCXDF(150)),$L(OCXDF(34)) S OCXDF(96)=$$ORDITEM(OCXDF(34)) I $L(OCXDF(37)) D CHK476^OCXOZ0F
  1. Q
  1. ;
  1. ABREN(DFN) ; Compiler Function: DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
  1. ;
  1. N OCXFLAG,OCXVAL,OCXLIST,OCXTEST,UNAV,OCXTLIST,OCXTERM,OCXSLIST,OCXSPEC
  1. S (OCXLIST,OCXTLIST)="",UNAV="0^<Unavailable>"
  1. S OCXSLIST="" Q:'$$TERMLKUP("SERUM SPECIMEN",.OCXSLIST) UNAV
  1. F OCXTERM="SERUM CREATININE","SERUM UREA NITROGEN" D Q:($L(OCXLIST)>130)
  1. .Q:'$$TERMLKUP(OCXTERM,.OCXTLIST)
  1. .S OCXTEST=0 F S OCXTEST=$O(OCXTLIST(OCXTEST)) Q:'OCXTEST D Q:($L(OCXLIST)>130)
  1. ..S OCXSPEC=0 F S OCXSPEC=$O(OCXSLIST(OCXSPEC)) Q:'OCXSPEC D Q:($L(OCXLIST)>130)
  1. ...S OCXVAL=$$LOCL^ORQQLR1(DFN,OCXTEST,OCXSPEC),OCXFLAG=$P(OCXVAL,U,5)
  1. ...I $L(OCXVAL),((OCXFLAG["H")!(OCXFLAG["L")) D
  1. ....N OCXY S OCXY=""
  1. ....S OCXY=$P(OCXVAL,U,2)_": "_$P(OCXVAL,U,3)_" "_$P(OCXVAL,U,4)
  1. ....S OCXY=OCXY_" "_$S($L(OCXFLAG):"["_OCXFLAG_"]",1:"")
  1. ....S OCXY=OCXY_" "_$$FMTE^XLFDT($P(OCXVAL,U,7),"2P")
  1. ....S:$L(OCXLIST) OCXLIST=OCXLIST_" " S OCXLIST=OCXLIST_OCXY
  1. Q:'$L(OCXLIST) UNAV Q 1_U_OCXLIST
  1. ;
  1. ;
  1. FILE(DFN,OCXELE,OCXDFL) ; This Local Extrinsic Function logs a validated event/element.
  1. ;
  1. N OCXTIMN,OCXTIML,OCXTIMT1,OCXTIMT2,OCXDATA,OCXPC,OCXPC,OCXVAL,OCXSUB,OCXDFI
  1. S DFN=+$G(DFN),OCXELE=+$G(OCXELE)
  1. ;
  1. Q:'DFN 1 Q:'OCXELE 1 K OCXDATA
  1. ;
  1. S OCXDATA(DFN,OCXELE)=1
  1. F OCXPC=1:1:$L(OCXDFL,",") S OCXDFI=$P(OCXDFL,",",OCXPC) I OCXDFI D
  1. .S OCXVAL=$G(OCXDF(+OCXDFI)),OCXDATA(DFN,OCXELE,+OCXDFI)=OCXVAL
  1. ;
  1. M ^TMP("OCXCHK",$J,DFN)=OCXDATA(DFN)
  1. ;
  1. Q 0
  1. ;
  1. LABTHRSB(OCXLAB,OCXSPEC,OCXRSLT,OCXOP) ; Compiler Function: LAB THRESHOLD EXCEEDED BOOLEAN
  1. ;
  1. S OCXRSLT=$TR($G(OCXRSLT),"<>=","")
  1. Q:'$G(OCXLAB)!'$G(OCXSPEC)!'$G(OCXRSLT)!'$L($G(OCXOP)) 0
  1. ;
  1. N OCXX,OCXPENT,OCXERR,OCXLABSP,OCXPVAL,OCXEXCD
  1. S OCXEXCD=0,OCXLABSP=OCXLAB_";"_OCXSPEC
  1. D ENVAL^XPAR(.OCXX,"ORB LAB "_OCXOP_" THRESHOLD",OCXLABSP,.OCXERR)
  1. Q:+$G(ORERR)'=0 OCXEXCD
  1. Q:+$G(OCXX)=0 OCXEXCD
  1. S OCXPENT="" F S OCXPENT=$O(OCXX(OCXPENT)) Q:'OCXPENT!OCXEXCD=1 D
  1. .S OCXPVAL=OCXX(OCXPENT,OCXLABSP)
  1. .I $L(OCXPVAL) D
  1. ..I $P(OCXPENT,";",2)="VA(200,",@((+OCXRSLT)_OCXOP_OCXPVAL) D
  1. ...S OCXEXCD=1
  1. Q OCXEXCD
  1. ;
  1. ORDITEM(OIEN) ; Compiler Function: GET ORDERABLE ITEM FROM ORDER NUMBER
  1. Q:'$G(OIEN) ""
  1. ;
  1. N OITXT,X S OITXT=$$OI^ORQOR2(OIEN) Q:'OITXT "No orderable item found."
  1. S X=$G(^ORD(101.43,+OITXT,0)) Q:'$L(X) "No orderable item found."
  1. Q $P(X,U,1)
  1. ;
  1. PATLOC(DFN) ; Compiler Function: PATIENT LOCATION
  1. ;
  1. N OCXP1,OCXP2
  1. S OCXP1=$G(^TMP("OCXSWAP",$J,"OCXODATA","PV1",2))
  1. S OCXP2=$P($G(^TMP("OCXSWAP",$J,"OCXODATA","PV1",3)),"^",1)
  1. I OCXP2 D
  1. .S OCXP2=$P($G(^SC(+OCXP2,0)),"^",1,2)
  1. .I $L($P(OCXP2,"^",2)) S OCXP2=$P(OCXP2,"^",2)
  1. .E S OCXP2=$P(OCXP2,"^",1)
  1. .S:'$L(OCXP2) OCXP2="NO LOC"
  1. I $L(OCXP1),$L(OCXP2) Q OCXP1_"^"_OCXP2
  1. ;
  1. S OCXP2=$G(^DPT(+$G(DFN),.1))
  1. I $L(OCXP2) Q "I^"_OCXP2
  1. Q "O^OUTPT"
  1. ;
  1. RECCREAT(ORDFN,ORDAYS) ;extrinsic function to return most recent
  1. ;SERUM CREATININE within <ORDAYS> in format:
  1. ; test id^result units flag ref range collection d/t
  1. N BDT,CDT,ORY,ORX,ORZ,X,ORI,ORJ,CREARSLT,LABFILE,SPECFILE
  1. Q:'$L($G(ORDFN)) "0^"
  1. Q:'$L($G(ORDAYS)) "0^"
  1. D NOW^%DTC
  1. S BDT=$$FMADD^XLFDT(%,"-"_ORDAYS,"","","")
  1. K %
  1. Q:'$L($G(BDT)) "0^"
  1. S LABFILE=$$TERMLKUP("SERUM CREATININE",.ORY)
  1. Q:$G(LABFILE)'=60 "0^"
  1. Q:+$D(ORY)<1 "0^"
  1. S SPECFILE=$$TERMLKUP("SERUM SPECIMEN",.ORX)
  1. Q:$G(SPECFILE)'=61 "0^"
  1. Q:+$D(ORX)<1 "0^"
  1. S ORI=0 F S ORI=$O(ORY(ORI)) Q:'ORI I +$G(CREARSLT)<1 D
  1. .S ORJ=0 F S ORJ=$O(ORX(ORJ)) Q:'ORJ I +$G(CREARSLT)<1 D
  1. ..S ORZ=$$LOCL^ORQQLR1(ORDFN,ORI,ORJ)
  1. ..Q:'$L($G(ORZ))
  1. ..S CDT=$P(ORZ,U,7)
  1. ..I CDT'<BDT S CREARSLT=1
  1. Q:+$G(CREARSLT)<1 "0^"
  1. 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)
  1. ;
  1. TERMLKUP(OCXTERM,OCXLIST) ;
  1. Q $$TERM^OCXOZ01(OCXTERM,.OCXLIST)
  1. ;