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

ORY21105.m

Go to the documentation of this file.
  1. ORY21105 ;SLC/RJS,CLA - OCX PACKAGE RULE TRANSPORT ROUTINE (Delete after Install of OR*3*211) ;APR 5,2005 at 08:07
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**211**;Dec 17,1997
  1. ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
  1. ;
  1. S ;
  1. ;
  1. D DOT^ORY211ES
  1. ;
  1. ;
  1. K REMOTE,LOCAL,OPCODE,REF
  1. F LINE=1:1:500 S TEXT=$P($T(DATA+LINE),";",2,999) Q:TEXT I $L(TEXT) D Q:QUIT
  1. .S ^TMP("OCXRULE",$J,$O(^TMP("OCXRULE",$J,"A"),-1)+1)=TEXT
  1. ;
  1. G ^ORY21106
  1. ;
  1. Q
  1. ;
  1. DATA ;
  1. ;
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; N OCXYR,OCXLPYR,OCXMON,OCXDAY,OCXHR,OCXMIN,OCXSEC,OCXCYR
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; S (OCXYR,OCXLPYR,OCXMON,OCXDAY,OCXHR,OCXMIN,OCXSEC,OCXAP)=""
  1. ;;R^"860.8:",100,7
  1. ;;D^ ; S OCXSEC=$E(OCXDT#60+100,2,3),OCXDT=OCXDT\60
  1. ;;R^"860.8:",100,8
  1. ;;D^ ; S OCXMIN=$E(OCXDT#60+100,2,3),OCXDT=OCXDT\60
  1. ;;R^"860.8:",100,9
  1. ;;D^ ; S OCXHR=$E(OCXDT#24+100,2,3),OCXDT=OCXDT\24
  1. ;;R^"860.8:",100,10
  1. ;;D^ ; S OCXCYR=($H\1461)*4+1841+(($H#1461)\365)
  1. ;;R^"860.8:",100,11
  1. ;;D^ ; S OCXYR=(OCXDT\1461)*4+1841,OCXDT=OCXDT#1461
  1. ;;R^"860.8:",100,12
  1. ;;D^ ; S OCXLPYR=(OCXDT\365),OCXDT=OCXDT-(OCXLPYR*365),OCXYR=OCXYR+OCXLPYR
  1. ;;R^"860.8:",100,13
  1. ;;D^ ; S OCXCNT="031^059^090^120^151^181^212^243^273^304^334^365"
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; S:(OCXLPYR=3) OCXCNT="031^060^091^121^152^182^213^244^274^305^335^366"
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; F OCXMON=1:1:12 Q:(OCXDT<$P(OCXCNT,U,OCXMON))
  1. ;;R^"860.8:",100,16
  1. ;;D^ ; S OCXDAY=OCXDT-$P(OCXCNT,U,OCXMON-1)+1
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; I OCXF S OCXMON=$P("January^February^March^April^May^June^July^August^September^October^November^December",U,OCXMON)
  1. ;;R^"860.8:",100,18
  1. ;;D^ ; E S OCXMON=$E(OCXMON+100,2,3)
  1. ;;R^"860.8:",100,19
  1. ;;D^ ; S OCXAP=$S('OCXHR:"Midnight",(OCXHR=12):"Noon",(OCXHR<12):"AM",1:"PM")
  1. ;;R^"860.8:",100,20
  1. ;;D^ ; I OCXF S OCXHR=OCXHR#12 S:'OCXHR OCXHR=12
  1. ;;R^"860.8:",100,21
  1. ;;D^ ; Q:'OCXF $E(OCXMON+100,2,3)_"/"_$E(OCXDAY+100,2,3)_$S((OCXCYR=OCXYR):" "_OCXHR_":"_OCXMIN,1:"/"_$E(OCXYR,3,4))
  1. ;;R^"860.8:",100,22
  1. ;;D^ ; Q:(OCXHR+OCXMIN+OCXSEC) OCXMON_" "_OCXDAY_","_OCXYR_" at "_OCXHR_":"_OCXMIN_"."_OCXSEC_" "_OCXAP
  1. ;;R^"860.8:",100,23
  1. ;;D^ ; Q OCXMON_" "_OCXDAY_","_OCXYR
  1. ;;R^"860.8:",100,24
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^ABREN
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;ABREN(DFN) ;
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; N OCXFLAG,OCXVAL,OCXLIST,OCXTEST,UNAV,OCXTLIST,OCXTERM,OCXSLIST,OCXSPEC
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; S (OCXLIST,OCXTLIST)="",UNAV="0^<Unavailable>"
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; S OCXSLIST="" Q:'$$TERMLKUP("SERUM SPECIMEN",.OCXSLIST) UNAV
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; F OCXTERM="SERUM CREATININE","SERUM UREA NITROGEN" D Q:($L(OCXLIST)>130)
  1. ;;R^"860.8:",100,7
  1. ;;D^ ; .Q:'$$TERMLKUP(OCXTERM,.OCXTLIST)
  1. ;;R^"860.8:",100,8
  1. ;;D^ ; .S OCXTEST=0 F S OCXTEST=$O(OCXTLIST(OCXTEST)) Q:'OCXTEST D Q:($L(OCXLIST)>130)
  1. ;;R^"860.8:",100,9
  1. ;;D^ ; ..S OCXSPEC=0 F S OCXSPEC=$O(OCXSLIST(OCXSPEC)) Q:'OCXSPEC D Q:($L(OCXLIST)>130)
  1. ;;R^"860.8:",100,10
  1. ;;D^ ; ...S OCXVAL=$$LOCL^ORQQLR1(DFN,OCXTEST,OCXSPEC),OCXFLAG=$P(OCXVAL,U,5)
  1. ;;R^"860.8:",100,11
  1. ;;D^ ; ...I $L(OCXVAL),((OCXFLAG["H")!(OCXFLAG["L")) D
  1. ;;R^"860.8:",100,12
  1. ;;D^ ; ....N OCXY S OCXY=""
  1. ;;R^"860.8:",100,13
  1. ;;D^ ; ....S OCXY=$P(OCXVAL,U,2)_": "_$P(OCXVAL,U,3)_" "_$P(OCXVAL,U,4)
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; ....S OCXY=OCXY_" "_$S($L(OCXFLAG):"["_OCXFLAG_"]",1:"")
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; ....S OCXY=OCXY_" "_$$FMTE^XLFDT($P(OCXVAL,U,7),"2P")
  1. ;;R^"860.8:",100,16
  1. ;;D^ ; ....S:$L(OCXLIST) OCXLIST=OCXLIST_" " S OCXLIST=OCXLIST_OCXY
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; Q:'$L(OCXLIST) UNAV Q 1_U_OCXLIST
  1. ;;R^"860.8:",100,18
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^ELAPSED ORDER CHECK TIME LOGGER
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^ELAPSED ORDER CHECK TIME LOGGER
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^TIMELOG
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;TIMELOG(OCXMODE,OCXCALL) ; Log an entry in the Elapsed time log.
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; Q 0
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^EQUALS TERM OPERATOR
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^EQUALS TERM OPERATOR
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^EQTERM
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;EQTERM(DATA,TERM) ;
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^T+; I $G(OCXTRACE) W !,"%%%%",?20," Execution trace DATA: ",$G(DATA)," TERM: ",$G(TERM)
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; N OCXF,OCXL
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; S OCXL="",OCXF=$$TERMLKUP(TERM,.OCXL)
  1. ;;R^"860.8:",100,7
  1. ;;D^T-; Q:'OCXF 0
  1. ;;R^"860.8:",100,8
  1. ;;D^T+; I 'OCXF W:$G(OCXTRACE) !,"%%%%",?20," Term '",TERM,"' not in Order Check National Term File" Q 0
  1. ;;R^"860.8:",100,9
  1. ;;D^T+; I '$O(OCXL(0)) W:$G(OCXTRACE) !,"%%%%",?20," There are no local terms listed for the National Term '",TERM,"'." Q 0
  1. ;;R^"860.8:",100,10
  1. ;;D^T+; I ($D(OCXL(DATA))!$D(OCXL("B",DATA))) W:$G(OCXTRACE) !,"%%%%",?20," Data equals Term" Q 1
  1. ;;R^"860.8:",100,11
  1. ;;D^T-; I ($D(OCXL(DATA))!$D(OCXL("B",DATA))) Q 1
  1. ;;R^"860.8:",100,12
  1. ;;D^T-; Q 0
  1. ;;R^"860.8:",100,13
  1. ;;D^T+; W:$G(OCXTRACE) !,"%%%%",?20," Data does not equal Term" Q 0
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^FILE DATA IN PATIENT ACTIVE DATA FILE
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^FILE DATA IN PATIENT ACTIVE DATA FILE
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^FILE
  1. ;;R^"860.8:",1,1
  1. ;;D^ ;FILE(DFN,OCXELE,OCXDFL) ; This Local Extrinsic Function files data
  1. ;;R^"860.8:",1,2
  1. ;;D^ ; ; in the Order Check Patient Data File
  1. ;;R^"860.8:",1,3
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;FILE(DFN,OCXELE,OCXDFL) ; This Local Extrinsic Function logs a validated event/element.
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^T+; I $G(OCXTRACE) W !,"%%%%",?20," Execution trace DFN: ",DFN," OCXELE: ",+$G(OCXELE)," OCXDFL: ",$G(OCXDFL)
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; N OCXTIMN,OCXTIML,OCXTIMT1,OCXTIMT2,OCXDATA,OCXPC,OCXPC,OCXVAL,OCXSUB,OCXDFI
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; S DFN=+$G(DFN),OCXELE=+$G(OCXELE)
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,7
  1. ;;D^ ; Q:'DFN 1 Q:'OCXELE 1 K OCXDATA
  1. ;;R^"860.8:",100,8
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,9
  1. ;;D^ ; S OCXDATA(DFN,OCXELE)=1
  1. ;;R^"860.8:",100,10
  1. ;;D^ ; F OCXPC=1:1:$L(OCXDFL,",") S OCXDFI=$P(OCXDFL,",",OCXPC) I OCXDFI D
  1. ;;R^"860.8:",100,11
  1. ;;D^ ; .S OCXVAL=$G(OCXDF(+OCXDFI)),OCXDATA(DFN,OCXELE,+OCXDFI)=OCXVAL
  1. ;;R^"860.8:",100,12
  1. ;;D^T+; .I $G(OCXTRACE) W !,"%%%%",?20," ",$P($G(^OCXS(860.4,+OCXDFI,0)),U,1)," = """,OCXVAL,""""
  1. ;;R^"860.8:",100,13
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; M ^TMP("OCXCHK",$J,DFN)=OCXDATA(DFN)
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,16
  1. ;;D^ ; Q 0
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^GENERATE STRING CHECKSUM
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^GENERATE STRING CHECKSUM
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^CKSUM
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;CKSUM(STR) ;
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; N CKSUM,PTR,ASC S CKSUM=0
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; S STR=$TR(STR,"abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ")
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; F PTR=$L(STR):-1:1 S ASC=$A(STR,PTR)-42 I (ASC>0),(ASC<51) S CKSUM=CKSUM*2+ASC
  1. ;1;
  1. ;