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

OCXOZ06.m

Go to the documentation of this file.
  1. OCXOZ06 ;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
  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. CHK95 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from UPDATE+13^OCXOZ01.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK95 Variables
  1. ; OCXDF(27) ---> Data Field: ORDER FLAGGED FOR CLARIFICATION (BOOLEAN)
  1. ; OCXDF(28) ---> Data Field: ORDER REQ. CHART SIGN. (BOOLEAN)
  1. ; OCXDF(29) ---> Data Field: SERV. ORDER REQ CHART SIG. (BOOLEAN)
  1. ; OCXDF(30) ---> Data Field: ORDER REQ. CO-SIG. (BOOLEAN)
  1. ; OCXDF(31) ---> Data Field: ORDER REQ. ELEC. SIG. (BOOLEAN)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; FILE(DFN,45, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ORDER REQUIRES CHART SIGNATURE)
  1. ; FILE(DFN,46, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: SERVICE ORDER REQUIRES CHART SIGNATURE)
  1. ; FILE(DFN,47, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ORDER REQUIRES CO-SIGNATURE)
  1. ; FILE(DFN,48, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ORDER REQUIRES ELECTRONIC SIGNATURE)
  1. ;
  1. S OCXDF(27)=$P($G(OCXORD),"^",4) I $L(OCXDF(27)) D CHK97
  1. S OCXDF(28)=$P($G(OCXORD),"^",5) I $L(OCXDF(28)),(OCXDF(28)) S OCXOERR=$$FILE(DFN,45,"") Q:OCXOERR
  1. S OCXDF(29)=$P($G(OCXORD),"^",6) I $L(OCXDF(29)),(OCXDF(29)) S OCXOERR=$$FILE(DFN,46,"") Q:OCXOERR
  1. S OCXDF(30)=$P($G(OCXORD),"^",7) I $L(OCXDF(30)),(OCXDF(30)) S OCXOERR=$$FILE(DFN,47,"") Q:OCXOERR
  1. S OCXDF(31)=$P($G(OCXORD),"^",8) I $L(OCXDF(31)),(OCXDF(31)) S OCXOERR=$$FILE(DFN,48,"") Q:OCXOERR
  1. Q
  1. ;
  1. CHK97 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK95+18.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK97 Variables
  1. ; OCXDF(27) ---> Data Field: ORDER FLAGGED FOR CLARIFICATION (BOOLEAN)
  1. ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
  1. ; OCXDF(115) --> Data Field: CURRENT DATE/TIME (FREE TEXT)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; DT2INT( ----------> CONVERT DATE FROM FILEMAN FORMAT TO OCX FORMAT
  1. ; FILE(DFN,134, ----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ORDER UNFLAGGED)
  1. ; FILE(DFN,44, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ORDER FLAGGED)
  1. ; INT2DT( ----------> CONVERT DATE FROM OCX FORMAT TO READABLE FORMAT
  1. ;
  1. I (OCXDF(27)) S OCXDF(37)=$P($G(OCXORD),"^",1),OCXDF(115)=$$INT2DT($$DT2INT("N"),0),OCXOERR=$$FILE(DFN,44,"37,115") Q:OCXOERR
  1. I '(OCXDF(27)) S OCXDF(37)=$P($G(OCXORD),"^",1),OCXDF(115)=$$INT2DT($$DT2INT("N"),0),OCXOERR=$$FILE(DFN,134,"37,115") Q:OCXOERR
  1. Q
  1. ;
  1. CHK113 ; Look through the current environment for valid Event/Elements for this patient.
  1. ; Called from CHK1+32^OCXOZ02.
  1. ;
  1. Q:$G(OCXOERR)
  1. ;
  1. ; Local CHK113 Variables
  1. ; OCXDF(32) ---> Data Field: ORDER FLAGGED FOR RESULTS (BOOLEAN)
  1. ; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
  1. ; OCXDF(96) ---> Data Field: ORDERABLE ITEM NAME (FREE TEXT)
  1. ; OCXDF(105) --> Data Field: ORDER TEXT (51 CHARS) (FREE TEXT)
  1. ; OCXDF(112) --> Data Field: ORDERED BY (FREE TEXT)
  1. ; OCXDF(149) --> Data Field: ORDER CANCELED BY (FREE TEXT)
  1. ;
  1. ; Local Extrinsic Functions
  1. ; CANCELER( --------> ORDER CANCELING PROVIDER
  1. ; FILE(DFN,49, -----> FILE DATA IN PATIENT ACTIVE DATA FILE (Event/Element: ORDER FLAGGED FOR RESULTS)
  1. ; ORDERER( ---------> ORDERING PROVIDER
  1. ; ORDITEM( ---------> GET ORDERABLE ITEM FROM ORDER NUMBER
  1. ;
  1. S OCXDF(32)=$$RSLTFLG^ORQOR2(OCXDF(34)) I $L(OCXDF(32)),(OCXDF(32)) S OCXDF(96)=$$ORDITEM(OCXDF(34)),OCXOERR=$$FILE(DFN,49,"96") Q:OCXOERR
  1. S OCXDF(112)=$$ORDERER(OCXDF(34)),OCXDF(149)=$$CANCELER(OCXDF(34)) I '(OCXDF(112)=OCXDF(149)) S OCXDF(105)=$P($$TEXT^ORKOR(OCXDF(34),51),"^",2) D CHK292^OCXOZ0B
  1. Q
  1. ;
  1. CANCELER(ORNUM) ; Compiler Function: ORDER CANCELING PROVIDER
  1. ;
  1. Q:'$G(ORNUM) ""
  1. S ORNUM=+$G(ORNUM)
  1. N ORQDUZ
  1. Q:'$D(^OR(100,ORNUM,6)) ""
  1. S ORQDUZ=$P(^OR(100,ORNUM,6),U,2)
  1. Q ORQDUZ
  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. INT2DT(OCXDT,OCXF) ; This Local Extrinsic Function converts an OCX internal format
  1. ; date into an Externl Format (Human Readable) date. 'OCXF=SHORT FORMAT OCXF=LONG FORMAT
  1. ;
  1. Q:'$L($G(OCXDT)) "" S OCXF=+$G(OCXF)
  1. N OCXYR,OCXLPYR,OCXMON,OCXDAY,OCXHR,OCXMIN,OCXSEC,OCXCYR
  1. S (OCXYR,OCXLPYR,OCXMON,OCXDAY,OCXHR,OCXMIN,OCXSEC,OCXAP)=""
  1. S OCXSEC=$E(OCXDT#60+100,2,3),OCXDT=OCXDT\60
  1. S OCXMIN=$E(OCXDT#60+100,2,3),OCXDT=OCXDT\60
  1. S OCXHR=$E(OCXDT#24+100,2,3),OCXDT=OCXDT\24
  1. S OCXCYR=($H\1461)*4+1841+(($H#1461)\365)
  1. S OCXYR=(OCXDT\1461)*4+1841,OCXDT=OCXDT#1461
  1. S OCXLPYR=(OCXDT\365),OCXDT=OCXDT-(OCXLPYR*365),OCXYR=OCXYR+OCXLPYR
  1. S OCXCNT="031^059^090^120^151^181^212^243^273^304^334^365"
  1. S:(OCXLPYR=3) OCXCNT="031^060^091^121^152^182^213^244^274^305^335^366"
  1. F OCXMON=1:1:12 Q:(OCXDT<$P(OCXCNT,U,OCXMON))
  1. S OCXDAY=OCXDT-$P(OCXCNT,U,OCXMON-1)+1
  1. I OCXF S OCXMON=$P("January^February^March^April^May^June^July^August^September^October^November^December",U,OCXMON)
  1. E S OCXMON=$E(OCXMON+100,2,3)
  1. S OCXAP=$S('OCXHR:"Midnight",(OCXHR=12):"Noon",(OCXHR<12):"AM",1:"PM")
  1. I OCXF S OCXHR=OCXHR#12 S:'OCXHR OCXHR=12
  1. Q:'OCXF $E(OCXMON+100,2,3)_"/"_$E(OCXDAY+100,2,3)_$S((OCXCYR=OCXYR):" "_OCXHR_":"_OCXMIN,1:"/"_$E(OCXYR,3,4))
  1. Q:(OCXHR+OCXMIN+OCXSEC) OCXMON_" "_OCXDAY_","_OCXYR_" at "_OCXHR_":"_OCXMIN_"."_OCXSEC_" "_OCXAP
  1. Q OCXMON_" "_OCXDAY_","_OCXYR
  1. ;
  1. ORDERER(ORNUM) ; Compiler Function: ORDERING PROVIDER
  1. ;
  1. Q:'$G(ORNUM) ""
  1. S ORNUM=+$G(ORNUM)
  1. N ORQDUZ,ORQI S ORQDUZ=""
  1. I $L($G(^OR(100,ORNUM,8,0))) D
  1. .S ORQI=0,ORQI=$O(^OR(100,ORNUM,8,"C","NW",ORQI))
  1. Q:+$G(ORQI)<1 ""
  1. S ORQDUZ=$P(^OR(100,ORNUM,8,ORQI,0),U,3)
  1. Q ORQDUZ
  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. ;