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

SRHLVOOR.m

Go to the documentation of this file.
  1. SRHLVOOR ;B'HAM ISC/DLR - Surgery Interface Outgoing ORU message ; [ 06/02/98 9:04 AM ]
  1. ;;3.0; Surgery ;**41**;24 Jun 93
  1. ; Per VHA Directive 10-93-142, this routine SHOULD NOT be modified.
  1. MSG(CASE,SRSTATUS,SREVENT) ;send ORU message
  1. ;This message is sent for every event point within the surgery options.
  1. ;There will be a ZIU message sent for each of the following surgery
  1. ;events, if SRSTATUS is equal to (NOT COMPLETE), (COMPLETE), or
  1. ;(ABORTED): S12 New Appointment; S13 Reschedule; S14 Modification;
  1. ;S15 Cancellation; and S17 Deletion. The events codes are set to
  1. ;SREVENT within the surgery routine options.
  1. ;
  1. INIT S HLDAP=$O(^HL(771,"B","SR SURGERY",0)) Q:$G(HLDAP)=""
  1. Q:$P($G(^HL(771,HLDAP,0)),U,2)'="a"
  1. ;check for the existence of file 133.2
  1. Q:'$D(^SRO(133.2,0))
  1. I $P(^SRO(133.2,$O(^SRO(133.2,"AC","OPERATION",0)),0),U,4)'["S",$P(^SRO(133.2,$O(^SRO(133.2,"AC","PROCEDURE",0)),0),U,4)'["S" Q
  1. I '$D(SRSTATUS) D STATUS^SROERR0
  1. I SRSTATUS="(REQUESTED)"!(SRSTATUS="(SCHEDULED)")!(SRSTATUS="(DELETED)")!(SRSTATUS="(CANCELLED)") Q
  1. START ;
  1. N SRNAP
  1. K ^TMP("HLS",$J)
  1. N HLCOMP,HLSUB,HLREP,SRI,SRX,UPDATE,PRT,OUT
  1. S (UPDATE,SRI)=1,PRT=0,SRX=$O(^HL(770,"B","SR AAIS",0)) Q:'SRX S SRNAP=$O(^HL(771,"B","SR AAIS",0)) I SRNAP D:$P($G(^HL(771,SRNAP,0)),"^",2)="a"
  1. .S PRT=PRT+1
  1. .S HLNDAP=SRX D INIT^HLTRANS S HLMTN="ORU",HLSDT=1
  1. .S:HLFS="" HLFS="^" S:HLECH="" HLECH="~|\&" S HLQ=""""""
  1. .S HLCOMP=$E(HLECH,1),HLREP=$E(HLECH,2),HLSUB=$E(HLECH,4)
  1. .;check outgoing message for duplication, if OBR segment exists
  1. .D:'$D(^TMP("HLS",$J)) SEG
  1. .I $G(OUT)'=1 D CHECK I $G(UPDATE)=0 S OUT=1
  1. .I $G(OUT)'=1 D DISPLAY,SEND
  1. EXIT ;
  1. D KILL^HLTRANS
  1. Q
  1. SEG ;segments
  1. D PID^SRHLVUO(.SRI)
  1. ;check for OBR, if none exist quit
  1. S OBRCHK=SRI
  1. D OBR^SRHLVUO4(.SRI,CASE)
  1. I OBRCHK=SRI S OUT=1
  1. Q
  1. SEND ;
  1. I $G(UPDATE)=1 D EN^HLTRANS
  1. K HLMTN,HLSDT
  1. Q
  1. DISPLAY ;screen message to user
  1. W !,"Sending an observation result message for case #",CASE
  1. Q
  1. CHECK ;checks ^XTMP for duplicate modification messages
  1. N X
  1. I $D(^XTMP("SRHL7"_CASE,SRNAP_"ORU",0)) D
  1. .S (UPDATE,X)=0 F S X=$O(^TMP("HLS",$J,HLSDT,X)) Q:'X!($G(UPDATE)=1) D
  1. ..I '$D(^XTMP("SRHL7"_CASE,SRNAP_"ORU",X)) S UPDATE=1 Q
  1. ..I ^TMP("HLS",$J,HLSDT,X)'=^XTMP("SRHL7"_CASE,SRNAP_"ORU",X) S UPDATE=1
  1. .I $O(^XTMP("SRHL7"_CASE,SRNAP_"ORU",X)) S UPDATE=1
  1. I '$D(^XTMP("SRHL7"_CASE,SRNAP_"ORU",0))!($G(UPDATE)=1) K ^XTMP("SRHL7"_CASE,SRNAP_"ORU") S ^XTMP("SRHL7"_CASE,SRNAP_"ORU",0)=DT D
  1. .S X=0 F S X=$O(^TMP("HLS",$J,HLSDT,X)) Q:'X S ^XTMP("SRHL7"_CASE,SRNAP_"ORU",X)=^TMP("HLS",$J,HLSDT,X)
  1. Q