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

OCXOZ04.m

Go to the documentation of this file.
  1. OCXOZ04 ;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. CHK25 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK23+15^OCXOZ03.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK25 Variables
  1. ; OCXDF(25) ---> Data Field: PATIENT MOVEMENT TYPE CURRENT (FREE TEXT)
  1. ; OCXDF(26) ---> Data Field: PATIENT MOVEMENT DATE CURRENT (DATE/TIME)
  1. ; OCXDF(97) ---> Data Field: NEW PATIENT MOVEMENT (BOOLEAN)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; DT2INT( ----------> CONVERT DATE FROM FILEMAN FORMAT TO OCX FORMAT
  1. ; FILE(DFN,56, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: PATIENT DISCHARGE)
  1. ;
  1. I (OCXDF(25)="ADMISSION") S OCXDF(97)=('(+$G(DGPMA)=+$G(DGPM0))&'$L(DGPMP)) I $L(OCXDF(97)),(OCXDF(97)) S OCXDF(26)=$$DT2INT($P($G(DGPMA),"^",1)) D CHK30
  1. I (OCXDF(25)="DISCHARGE") S OCXDF(26)=$$DT2INT($P($G(DGPMA),"^",1)),OCXOERR=$$FILE(DFN,56,"26") Q:OCXOERR
  1. Q
  1. ;
  1. CHK30 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK25+14.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK30 Variables
  1. ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
  1. ; OCXDF(83) ---> Data Field: PATIENT WARD ROOM-BED (FREE TEXT)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; FILE(DFN,21, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: PATIENT ADMISSION)
  1. ; WARDRMBD( --------> WARD ROOM-BED
  1. ;
  1. S OCXDF(37)=$G(DFN) I $L(OCXDF(37)) S OCXDF(83)=$P($$WARDRMBD(OCXDF(37)),"^",2),OCXOERR=$$FILE(DFN,21,"26,83") Q:OCXOERR
  1. Q
  1. ;
  1. CHK34 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK1+28^OCXOZ02.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK34 Variables
  1. ; OCXDF(1) ----> Data Field: CONTROL CODE (FREE TEXT)
  1. ; OCXDF(2) ----> Data Field: FILLER (FREE TEXT)
  1. ; OCXDF(6) ----> Data Field: ABNORMAL FLAG (FREE TEXT)
  1. ; OCXDF(23) ---> Data Field: REQUEST STATUS (OBR) (FREE TEXT)
  1. ; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; LIST( ------------> IN LIST OPERATOR
  1. ;
  1. I $$LIST(OCXDF(6),"H,L") D CHK35
  1. I $$LIST(OCXDF(6),"HH,LL"),$L(OCXDF(23)),$$LIST(OCXDF(23),"F,C"),$L(OCXDF(1)),$$LIST(OCXDF(1),"RE"),$L(OCXDF(2)),($E(OCXDF(2),1,2)="LR"),$L(OCXDF(34)) D CHK324^OCXOZ0B
  1. Q
  1. ;
  1. CHK35 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK34+15.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK35 Variables
  1. ; OCXDF(1) ----> Data Field: CONTROL CODE (FREE TEXT)
  1. ; OCXDF(2) ----> Data Field: FILLER (FREE TEXT)
  1. ; OCXDF(15) ---> Data Field: RESULT STATUS (OBX) (FREE TEXT)
  1. ; OCXDF(23) ---> Data Field: REQUEST STATUS (OBR) (FREE TEXT)
  1. ; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
  1. ; OCXDF(96) ---> Data Field: ORDERABLE ITEM NAME (FREE TEXT)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; LIST( ------------> IN LIST OPERATOR
  1. ; ORDITEM( ---------> GET ORDERABLE ITEM FROM ORDER NUMBER
  1. ;
  1. I $L(OCXDF(23)),$$LIST(OCXDF(23),"F,C"),$L(OCXDF(1)),$$LIST(OCXDF(1),"RE"),$L(OCXDF(2)),($E(OCXDF(2),1,2)="LR"),$L(OCXDF(34)) S OCXDF(96)=$$ORDITEM(OCXDF(34)) D CHK43
  1. I $L(OCXDF(15)),$$LIST(OCXDF(15),"F,C"),$L(OCXDF(1)),$$LIST(OCXDF(1),"RE"),$L(OCXDF(2)),($E(OCXDF(2),1,2)="LR"),$L(OCXDF(34)) S OCXDF(96)=$$ORDITEM(OCXDF(34)) D CHK314^OCXOZ0B
  1. Q
  1. ;
  1. CHK43 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK35+17.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK43 Variables
  1. ; OCXDF(113) --> Data Field: LAB TEST ID (NUMERIC)
  1. ; OCXDF(114) --> Data Field: LAB TEST PRINT NAME (FREE TEXT)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; FILE(DFN,23, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: HL7 LAB ORDER RESULTS ABNORMAL)
  1. ;
  1. I $L(OCXDF(113)) S OCXDF(114)=$$PRINTNAM^ORQQLR1(OCXDF(113)),OCXOERR=$$FILE(DFN,23,"12,13,96,114") Q:OCXOERR
  1. Q
  1. ;
  1. DT2INT(OCXDT) ; This Local Extrinsic Function converts a date into an integer
  1. ; By taking the Years, Months, Days, Hours and Minutes converting
  1. ; Them into Seconds and then adding them all together into one big integer
  1. ;
  1. Q:'$L($G(OCXDT)) ""
  1. N OCXDIFF,OCXVAL S (OCXDIFF,OCXVAL)=0
  1. ;
  1. I $L(OCXDT),'OCXDT,(OCXDT[" at ") D ; EXTERNAL EXPERT SYSTEM FORMAT 1 TO EXTERNAL FORMAT
  1. .N OCXHR,OCXMIN,OCXTIME
  1. .S OCXTIME=$P($P(OCXDT," at ",2),".",1),OCXHR=$P(OCXTIME,":",1),OCXMIN=$P(OCXTIME,":",2)
  1. .S:(OCXDT["Midnight") OCXHR=00
  1. .S:(OCXDT["PM") OCXHR=OCXHR+12
  1. .S OCXDT=$P(OCXDT," at ")_"@"_$E(OCXHR+100,2,3)_$E(OCXMIN+100,2,3)
  1. ;
  1. I $L(OCXDT),(OCXDT?1.2N1"/"1.2N.1" ".2N.1":".2N) D ; EXTERNAL EXPERT SYSTEM FORMAT 2 TO EXTERNAL FORMAT
  1. .N OCXMON
  1. .S OCXMON=$P("January^February^March^April^May^June^July^August^September^October^November^December",U,$P(OCXDT,"/",1))
  1. .I $L($P(OCXDT," ",2)) S OCXDT=OCXMON_" "_$P($P(OCXDT," ",1),"/",2)_"@"_$TR($P(OCXDT," ",2),":","")
  1. .E S OCXDT=OCXMON_" "_$P($P(OCXDT," ",1),"/",2)
  1. ;
  1. I $L(OCXDT),(OCXDT?1.2N1"/"1.2N1"/"1.2N.1" ".2N.1":".2N) D ; EXTERNAL EXPERT SYSTEM FORMAT 3 TO EXTERNAL FORMAT
  1. .N OCXMON
  1. .S OCXMON=$P("January^February^March^April^May^June^July^August^September^October^November^December",U,$P(OCXDT,"/",1))
  1. .I $L($P(OCXDT," ",2)) S OCXDT=OCXMON_" "_$P($P(OCXDT," ",1),"/",2)_","_$P($P(OCXDT," ",1),"/",3)_"@"_$TR($P(OCXDT," ",2),":","")
  1. .E S OCXDT=OCXMON_" "_$P($P(OCXDT," ",1),"/",2)_", "_$P($P(OCXDT," ",1),"/",3)
  1. ;
  1. I $L(OCXDT),'OCXDT D ; EXTERNAL FORMAT TO INTERNAL FILEMAN FORMAT
  1. .I (OCXDT["@0000") S OCXDT=$P(OCXDT,"@",1),OCXDIFF=1
  1. .N %DT,X,Y S X=OCXDT,%DT="" S:(OCXDT["@")!(OCXDT="N") %DT="T" D ^%DT S OCXDT=+Y
  1. ;
  1. I ($L(OCXDT\1)>7) S OCXDT=$$HL7TFM^XLFDT(OCXDT) ; HL7 FORMAT TO INTERNAL FILEMAN FORMAT
  1. ;
  1. I ($L(OCXDT\1)=7) S OCXDT=$$FMTH^XLFDT(+OCXDT) ; INTERNAL FILEMAN FORMAT TO $H FORMAT
  1. ;
  1. I (OCXDT?5N1","1.5N) S OCXVAL=(OCXDT*86400)+$P(OCXDT,",",2) ; $H FORMAT TO EXPERT SYSTEM INTERNAL FORMAT
  1. ;
  1. Q OCXVAL
  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. LIST(DATA,LIST) ; IS THE DATA FIELD IN THE LIST
  1. ;
  1. S:'($E(LIST,1)=",") LIST=","_LIST S:'($E(LIST,$L(LIST))=",") LIST=LIST_"," S DATA=","_DATA_","
  1. Q (LIST[DATA)
  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. WARDRMBD(DFN) ; Compiler Function: WARD ROOM-BED
  1. ;
  1. Q:'$G(DFN) 0
  1. N OUT S OUT=$G(^DPT(DFN,.1)) Q:'$L(OUT) 0
  1. S OUT=1_"^"_OUT_" "_$G(^DPT(DFN,.101)) Q OUT
  1. ;