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

OCXDI02K.m

Go to the documentation of this file.
  1. OCXDI02K ;SLC/RJS,CLA - OCX PACKAGE DIAGNOSTIC ROUTINES ;SEP 7,1999 at 10:30
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32**;Dec 17,1997
  1. ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
  1. ;
  1. S ;
  1. ;
  1. D DOT^OCXDIAG
  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("OCXDIAG",$J,$O(^TMP("OCXDIAG",$J,"A"),-1)+1)=TEXT
  1. ;
  1. G ^OCXDI02L
  1. ;
  1. Q
  1. ;
  1. DATA ;
  1. ;
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; S ZTSAVE("ORN")="" ; notification identifier (required)
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; S ZTSAVE("ORBDFN")="" ; patient identifier (required)
  1. ;;R^"860.8:",100,16
  1. ;;D^ ; S ZTSAVE("ORNUM")="" ; order number - used to determine ordering provider
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; S ZTSAVE("ORBADUZ")="" ; array of package-identified recipients
  1. ;;R^"860.8:",100,18
  1. ;;D^ ; S ZTSAVE("ORBPMSG")="" ; package-defined message
  1. ;;R^"860.8:",100,19
  1. ;;D^ ; S ZTSAVE("ORBPDATA")="" ; package-defined data for follow-up action
  1. ;;R^"860.8:",100,20
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,21
  1. ;;D^ ; D ^%ZTLOAD
  1. ;;R^"860.8:",100,22
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,23
  1. ;;D^ ; Q 0
  1. ;;R^"860.8:",100,24
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^LOCAL TERM LOOKUP
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^LOCAL TERM LOOKUP
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^TERMLKUP
  1. ;;R^"860.8:",1,1
  1. ;;D^
  1. ;;R^"860.8:",1,2
  1. ;;D^ This function allows a local site to define to Order Checking
  1. ;;R^"860.8:",1,3
  1. ;;D^ a term specific to that site. (ie. Lab Test Name, Radiology
  1. ;;R^"860.8:",1,4
  1. ;;D^ procedure name, etc.)
  1. ;;R^"860.8:",1,5
  1. ;;D^
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;TERMLKUP(OCXTERM,OCXFILE) ;
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; Q
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^GET LOCAL LIST FOR STANDARD TERM
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^GET LOCAL LIST FOR STANDARD TERM
  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. ;;R^"860.8:",100,6
  1. ;;D^ ; Q +CKSUM
  1. ;;R^"860.8:",100,7
  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:^RECENT CREATININE LAB PROCEDURE
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^RECENT CREATININE LAB PROCEDURE
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^RECCREAT
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;RECCREAT(ORDFN,ORDAYS) ;extrinsic function to return most recent
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;SERUM CREATININE within <ORDAYS> in format:
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; ; test id^result units flag ref range collection d/t
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; N BDT,CDT,ORY,ORX,ORZ,X,TEST,ORI,ORJ,CREARSLT,LABFILE,SPECFILE
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; Q:'$L($G(ORDFN)) "0^"
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; Q:'$L($G(ORDAYS)) "0^"
  1. ;;R^"860.8:",100,7
  1. ;;D^ ; D NOW^%DTC
  1. ;;R^"860.8:",100,8
  1. ;;D^ ; S BDT=$$FMADD^XLFDT(%,"-"_ORDAYS,"","","")
  1. ;;R^"860.8:",100,9
  1. ;;D^ ; K %
  1. ;;R^"860.8:",100,10
  1. ;;D^ ; Q:'$L($G(BDT)) "0^"
  1. ;;R^"860.8:",100,11
  1. ;;D^ ; S LABFILE=$$TERMLKUP^ORB31(.ORY,"SERUM CREATININE")
  1. ;;R^"860.8:",100,12
  1. ;;D^ ; Q:$G(LABFILE)'=60 "0^"
  1. ;;R^"860.8:",100,13
  1. ;;D^ ; S SPECFILE=$$TERMLKUP^ORB31(.ORX,"SERUM SPECIMEN")
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; Q:$G(SPECFILE)'=61 "0^"
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; F ORI=1:1:ORY I +$G(CREARSLT)<1 D
  1. ;;R^"860.8:",100,16
  1. ;;D^ ; .S TEST=$P(ORY(ORI),U)
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; .Q:+$G(TEST)<1
  1. ;;R^"860.8:",100,18
  1. ;;D^ ; .F ORJ=1:1:ORX I +$G(CREARSLT)<1 D
  1. ;;R^"860.8:",100,19
  1. ;;D^ ; ..S SPECIMEN=$P(ORX(ORJ),U)
  1. ;;R^"860.8:",100,20
  1. ;;D^ ; ..Q:+$G(SPECIMEN)<1
  1. ;;R^"860.8:",100,21
  1. ;;D^ ; ..S ORZ=$$LOCL^ORQQLR1(ORDFN,TEST,SPECIMEN)
  1. ;;R^"860.8:",100,22
  1. ;;D^ ; ..Q:'$L($G(ORZ))
  1. ;;R^"860.8:",100,23
  1. ;;D^ ; ..S CDT=$P(ORZ,U,7)
  1. ;1;
  1. ;