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

ORY195A.m

Go to the documentation of this file.
  1. ORY195A ;SLC/DAN Post-install for patch 195 ;10/7/04 11:49
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**195**;Dec 17, 1997
  1. ;
  1. ;DBIA SECTION
  1. ;10063 - %ZTLOAD
  1. ;10141 - XPDUTL
  1. ;10070 - XMD
  1. ;10035 - ^DPT("CN" references
  1. ;10061 - VADPT
  1. ;
  1. Q ;Entry point to queue process during install
  1. N ZTRTN,ZTDESC,ZTIO,ZTDTH,ZTSK
  1. S ZTRTN="DQ^ORY195A",ZTDESC="OR*3*195 LAB CHILD ORDER CHECK ROUTINE",ZTIO="",ZTDTH=$H
  1. D ^%ZTLOAD I '$G(ZTSK) D BMES^XPDUTL("POST INSTALL NOT QUEUED - RUN DQ^ORY195A AFTER INSTALL FINISHES") Q
  1. D BMES^XPDUTL("Lab Child Order Check queued as task # "_$G(ZTSK))
  1. Q
  1. ;
  1. DQ ;
  1. D SRCH,MAIL
  1. Q
  1. ;
  1. SRCH ;Search for lab orders without locations
  1. N LAB,LOC,IEN,CHD,ORD,SUB,ORLIST
  1. K ^TMP($J,"TEXT"),^TMP($J,"ERR")
  1. S LAB=$O(^ORD(100.98,"B","LAB",0)) Q:'+LAB ;quit if no lab display group
  1. S LOC="" F S LOC=$O(^DPT("CN",LOC)) Q:LOC="" S IEN=0 F S IEN=$O(^DPT("CN",LOC,IEN)) Q:'+IEN D
  1. .K ^TMP("ORR",$J)
  1. .D EN^ORQ1(IEN_";DPT(",LAB,2) ;Get active lab orders
  1. .S SUB=0 F S SUB=$O(^TMP("ORR",$J,ORLIST,SUB)) Q:'+SUB S ORD=+^(SUB) I $D(^OR(100,ORD,2)) D
  1. ..I '$P(^OR(100,ORD,0),U,17) Q ;Quit if not delayed order
  1. ..S CHD=0 F S CHD=$O(^OR(100,ORD,2,CHD)) Q:'+CHD I $P(^OR(100,CHD,0),U,10)="" S ^TMP($J,"ERR",LOC,CHD)=+$P(^OR(100,CHD,0),U,2)
  1. K ^TMP("ORR",$J),^TMP($J,"TEXT")
  1. Q
  1. ;
  1. MAIL ;Send message with findings
  1. N CNT,XMSUB,XMTEXT,XMDUZ,XMY,XMZ,LOC,ORD,DFN,VADM
  1. S CNT=1
  1. S ^TMP($J,"TEXT",CNT)="The search for active lab orders without a location has finished.",CNT=CNT+1
  1. S ^TMP($J,"TEXT",CNT)="",CNT=CNT+1
  1. I '$D(^TMP($J,"ERR")) S ^TMP($J,"TEXT",CNT)="No problems were found so no additional work is required.",CNT=CNT+1
  1. I $D(^TMP($J,"ERR")) D
  1. .S ^TMP($J,"TEXT",CNT)="Complex lab orders (e.g. CBC Q12Hx3) that were delayed were not being",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="assigned a location upon release. As a result, the lab orders were not",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="appearing on the lab collection lists.",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="The following patients have active lab orders without a location.",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="It is very likely that these tests have not been done. Please review",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="each order to ensure that the test has been done. You may need to DC the",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="existing order and enter a new order so the test appears on the",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="collection list.",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="",CNT=CNT+1
  1. .S ^TMP($J,"TEXT",CNT)="Please note that existing delayed complex lab orders will release correctly.",CNT=CNT+1
  1. .S LOC="" F S LOC=$O(^TMP($J,"ERR",LOC)) Q:LOC="" S ^TMP($J,"TEXT",CNT)="",CNT=CNT+1,^TMP($J,"TEXT",CNT)="Location: "_LOC,CNT=CNT+1,^(CNT)="",CNT=CNT+1 S ORD=0 F S ORD=$O(^TMP($J,"ERR",LOC,ORD)) Q:'+ORD D
  1. ..K VADM
  1. ..S DFN=^TMP($J,"ERR",LOC,ORD)
  1. ..D DEM^VADPT
  1. ..S ^TMP($J,"TEXT",CNT)=VADM(1)_" ("_$E(+VADM(2),6,9)_") ORDER #: "_ORD,CNT=CNT+1,^TMP($J,"TEXT",CNT)=" ORDER TEXT: "_$G(^OR(100,ORD,8,1,.1,1,0)),CNT=CNT+1
  1. S XMDUZ="PATCH OR*3*195 LAB CHILD ORDERS CHECK",XMY(.5)="" S:$G(DUZ) XMY(DUZ)=""
  1. S XMTEXT="^TMP($J,""TEXT"",",XMSUB="PATCH OR*3*195 Lab Order Check COMPLETED"
  1. D ^XMD
  1. Q