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

ORY26508.m

Go to the documentation of this file.
  1. ORY26508 ;SLC/JEH - OCX PACKAGE RULE TRANSPORT ROUTINE - PLUS ;NOV 16, 2006 15:00
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**265**;Dec 17,1997;Build 17
  1. ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
  1. ;; ;;Per VHA Directive 2004-038, this routine should not be modified.
  1. ;
  1. ;
  1. SCH ; This code will correct the pointer to imaging.
  1. N DTIME,DLAYGO,DINUM,DIC,Y,X,IX,OLD,RPTID,DONEX
  1. S DIC="^ORD(100.98," ; Find the IEN of IMAGING in the Display File
  1. S DIC(0)="N,O,X"
  1. S X="IMAGING"
  1. D ^DIC
  1. I $G(Y) D ; RPT SCHEDULED/DUE ACTIVITY replace IEN for NURSING (13) (found at some sites) with IMAGING IEN
  1. . S X=+Y
  1. . ;
  1. . S (IX,DONEX,RPTID,OLD)=0
  1. . S RPTID=$O(^ORD(102.21,"B","RPT SCHEDULED/DUE ACTIVITY",0))
  1. . F S IX=$O(^ORD(102.21,RPTID,1,IX)) Q:('IX)!DONEX D
  1. . . I $P(^ORD(102.21,RPTID,1,IX,0),U,4)="IMAGING" D
  1. . . . I ^ORD(102.21,RPTID,1,IX,1,1,0)'=X D
  1. . . . . S OLD=^ORD(102.21,RPTID,1,IX,1,1,0)
  1. . . . . S ^ORD(102.21,RPTID,1,IX,1,1,0)=X
  1. . . . . K ^ORD(102.21,RPTID,1,IX,1,"B",OLD,1)
  1. . . . . S ^ORD(102.21,RPTID,1,IX,1,"B",X,1)="",DONEX=1
  1. W !,"FINISHED: UPDATING CPRS QUERY DEFINITION NAME / RPT SCHEDULED/DUE ACTIVITY"
  1. W !
  1. ;
  1. OCX ; this code updates the expert system to compile code that allows results with "<>=" in matching the threshold limit.
  1. N LINE,UPDATE,TEXT1,TEXT2,ADDTEXT,TTALCNT,CNT
  1. S UPDATE=0
  1. S TEXT1="",TEXT2=""
  1. S TTALCNT=$P(^OCXS(860.8,53,"CODE",0),"^",3)+1
  1. S LINE=1
  1. S ADDTEXT=$P($T(DATA+1),";",3,40)
  1. F S LINE=$O(^OCXS(860.8,53,"CODE",LINE)) Q:(LINE=TTALCNT)!(LINE="")!(LINE]"@") D
  1. . I ^OCXS(860.8,53,"CODE",LINE,0)=ADDTEXT S TTALCNT=LINE+1 Q ; If change has already been made
  1. . I UPDATE=0,^OCXS(860.8,53,"CODE",LINE,0)=" ; Q:'$G(OCXLAB)!'$G(OCXSPEC)!'$G(OCXRSLT)!'$L($G(OCXOP)) 0" D
  1. . . S TEXT1=^OCXS(860.8,53,"CODE",LINE,0)
  1. . . S ^OCXS(860.8,53,"CODE",LINE,0)=$P($T(DATA+1),";",3,40)
  1. . . S UPDATE=1
  1. . . ; Q
  1. . I UPDATE=1 D
  1. . . S TEXT2=TEXT1
  1. . . S CNT=LINE+1
  1. . . S TEXT1=$G(^OCXS(860.8,53,"CODE",CNT,0))
  1. . . S ^OCXS(860.8,53,"CODE",CNT,0)=TEXT2
  1. . . Q:TEXT1=""
  1. I UPDATE=1 D
  1. . S $P(^OCXS(860.8,53,"CODE",0),"^",3)=TTALCNT
  1. . S $P(^OCXS(860.8,53,"CODE",0),"^",4)=TTALCNT
  1. . W !,"FINISHED: UPDATING ORDER CHECK COMPILER FUNCTIONS"
  1. . W !!,"THE EXPERT SYSTEM WILL NEED TO BE RECOMPILED TO COMPLETE THIS PROCESS"
  1. . W !,"PLEASE SEE THE PATCH INSTRUCTION ON RECOMPILING THE EXPERT SYSTEM"
  1. I UPDATE=0 W !,"NO UPDATE NEEDED OR MADE TO EXPERT SYSTEM"
  1. Q
  1. ;
  1. RECOVER ; RESET TO OLD GLOBAL
  1. N LINE,TEXT1,TTALCNT
  1. S TEXT1=""
  1. S TTALCNT=$P(^OCXS(860.8,53,"CODE",0),"^",3)+1
  1. S LINE=0
  1. F S LINE=$O(^OCXS(860.8,53,"CODE",LINE)) Q:(LINE=TTALCNT)!(LINE="")!(LINE]"@") D
  1. . S TEXT1=$P($T(DATA2+LINE),";",3,40)
  1. . S ^OCXS(860.8,53,"CODE",LINE,0)=TEXT1
  1. S ^OCXS(860.8,53,"CODE",0)="^^16^16^3060823^"
  1. Q
  1. ;
  1. DATA ;
  1. ;; ; S OCXRSLT=$TR($G(OCXRSLT),"<>=","")
  1. ;
  1. ;;^OCXS(860.8,53,0)=LAB THRESHOLD EXCEEDED BOOLEAN^LABTHRSB
  1. ;;^OCXS(860.8,53,"CODE",0)=^^17^17^3060823^
  1. ;;^OCXS(860.8,53,"CODE",1,0)= ;LABTHRSB(OCXLAB,OCXPEC,OCXRSLT,OCXOP) ;
  1. ;;^OCXS(860.8,53,"CODE",2,0)= ; ;
  1. ;;^OCXS(860.8,53,"CODE",3,0)= ; S OCXRSLT=$TR($G(OCXRSLT),"<>=","")
  1. ;;^OCXS(860.8,53,"CODE",4,0)= ; Q:'$G(OCXLAB)!'$G(OCXPEC)!'$G(OCXRSLT)!'$L($G(OCXOP)) 0
  1. ;;^OCXS(860.8,53,"CODE",5,0)= ; ;
  1. ;;^OCXS(860.8,53,"CODE",6,0)= ; N OCXX,OCXPENT,OCXERR,OCXLABSP,OCXPVAL,OCXEXCD
  1. ;;^OCXS(860.8,53,"CODE",7,0)= ; S OCXEXCD=0,OCXLABSP=OCXLAB_";"_OCXPEC
  1. ;;^OCXS(860.8,53,"CODE",8,0)= ; D ENVAL^XPAR(.OCXX,"ORB LAB "_OCXOP_" THRESHOLD",OCXLABSP,.OCXERR)
  1. ;;^OCXS(860.8,53,"CODE",9,0)=T+; I $G(OCXTRACE) W !,"Lab parameter values:",! ZW OCXX,OCXERR
  1. ;;^OCXS(860.8,53,"CODE",10,0)= ; Q:+$G(ORERR)'=0 OCXEXCD
  1. ;;^OCXS(860.8,53,"CODE",11,0)= ; Q:+$G(OCXX)=0 OCXEXCD
  1. ;;^OCXS(860.8,53,"CODE",12,0)= ; S OCXPENT="" F S OCXPENT=$O(OCXX(OCXPENT)) Q:'OCXPENT!OCXEXCD=1 D
  1. ;;^OCXS(860.8,53,"CODE",13,0)= ; .S OCXPVAL=OCXX(OCXPENT,OCXLABSP)
  1. ;;^OCXS(860.8,53,"CODE",14,0)= ; .I $L(OCXPVAL) D
  1. ;;^OCXS(860.8,53,"CODE",15,0)= ; ..I $P(OCXPENT,";",2)="VA(200,",@((+OCXRSLT)_OCXOP_OCXPVAL) D
  1. ;;^OCXS(860.8,53,"CODE",16,0)= ; ...S OCXEXCD=1
  1. ;;^OCXS(860.8,53,"CODE",17,0)= ; Q OCXEXCD
  1. ;
  1. DATA2 ;
  1. ;; ;LABTHRSB(OCXLAB,OCXPEC,OCXRSLT,OCXOP) ;
  1. ;; ; ;
  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_";"_OCXPEC
  1. ;; ; D ENVAL^XPAR(.OCXX,"ORB LAB "_OCXOP_" THRESHOLD",OCXLABSP,.OCXERR)
  1. ;;T+; I $G(OCXTRACE) W !,"Lab parameter values:",! ZW OCXX,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. ;