| 1 | SRHLOORU ;B'HAM ISC/DLR - Surgery Interface Outgoing ORU message ; [ 05/19/98  9:33 AM ]
 | 
|---|
| 2 |  ;;3.0; Surgery ;**41**;24 Jun 93
 | 
|---|
| 3 |  ; Per VHA Directive 10-93-142, this routine SHOULD NOT be modified.
 | 
|---|
| 4 | MSG(CASE,SRSTATUS,SREVENT) ;send ORU message
 | 
|---|
| 5 |  ;This message is sent for every event point within the surgery options.
 | 
|---|
| 6 |  ;There will be a ZIU message sent for each of the following surgery
 | 
|---|
| 7 |  ;events, if SRSTATUS is equal to (NOT COMPLETE), (COMPLETE), or 
 | 
|---|
| 8 |  ;(ABORTED): S12 New Appointment; S13 Reschedule; S14 Modification; 
 | 
|---|
| 9 |  ;S15 Cancellation; and S17 Deletion.  The events codes are set to
 | 
|---|
| 10 |  ;SREVENT within the surgery routine options.
 | 
|---|
| 11 |  ;
 | 
|---|
| 12 |  I $$V^SRHLU D MSG^SRHLVOOR(CASE,SRSTATUS,CASE) Q
 | 
|---|
| 13 |  I SRSTATUS="(REQUESTED)"!(SRSTATUS="(SCHEDULED)")!(SRSTATUS="(DELETED)")!(SRSTATUS="(CANCELLED)") Q
 | 
|---|
| 14 | START ;
 | 
|---|
| 15 |  S HLDAP=$O(^HL(771,"B","SR SURGERY",0)) Q:$G(HLDAP)=""
 | 
|---|
| 16 |  Q:$P($G(^HL(771,HLDAP,0)),U,2)'="a"
 | 
|---|
| 17 |  ;check for the existence of file 133.2
 | 
|---|
| 18 |  Q:'$D(^SRO(133.2,0))
 | 
|---|
| 19 |  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
 | 
|---|
| 20 |  K ^TMP("HLS",$J)
 | 
|---|
| 21 |  N HLCOMP,HLSUB,HLREP,SRI,SRX,UPDATE,PRT,OUT
 | 
|---|
| 22 |  ;V. 1.6 interface
 | 
|---|
| 23 |  ;EID - IEN of event protocol
 | 
|---|
| 24 |  ;HL - array of output parameters
 | 
|---|
| 25 |  ;INT - only for VISTA-to-VISTA message exchange
 | 
|---|
| 26 |  ;SRET - Surgery Event Trigger
 | 
|---|
| 27 |  S SRET="SR Unsolicited transmission of VistA Requested Observation"
 | 
|---|
| 28 |  S EID=$O(^ORD(101,"B",SRET,0)),HL="HL",INT=0
 | 
|---|
| 29 |  D INIT^HLFNC2(EID,.HL,INT) S HLCOMP=$E(HL("ECH"),1),HLREP=$E(HL("ECH"),2),HLSUB=$E(HL("ECH"),4),HLFS=HL("FS"),HLQ=HL("Q"),HLECH=HL("ECH")
 | 
|---|
| 30 |  ;Q:'$O(HL("")) ;read HL for the error message
 | 
|---|
| 31 |  D SEG
 | 
|---|
| 32 |  ;SKIP duplicate messages
 | 
|---|
| 33 |  D CHECK I $D(UPDATE) D GEN,DISPLAY
 | 
|---|
| 34 | EXIT ;
 | 
|---|
| 35 |  Q
 | 
|---|
| 36 | GEN ;generate the message
 | 
|---|
| 37 |  ;HLEID - IEN of event protocol
 | 
|---|
| 38 |  ;HLARYTYP - acknowledgement array (see V. 1.6 HL7 doc)
 | 
|---|
| 39 |  ;HLFORMAT - is HLMA is pre-formatted HL7 form
 | 
|---|
| 40 |  ;HLMTIEN - IEN in 772
 | 
|---|
| 41 |  ;HLRESLT - message ID and/or the error message (for output)
 | 
|---|
| 42 |  ;HLP("CONTPTR") - continuation pointer field value (not used)
 | 
|---|
| 43 |  ;HLP("PRIORITY") - priority field value (not used)
 | 
|---|
| 44 |  ;HLP("SECURITY") - security information (not used)
 | 
|---|
| 45 |  S HLEID=EID,HLARYTYP="GM",HLFORMAT=1,HLMTIEN="",HLRESLT=""
 | 
|---|
| 46 |  D GENERATE^HLMA(HLEID,HLARYTYP,HLFORMAT,.HLRESLT,HLMTIEN,.HLP)
 | 
|---|
| 47 |  Q
 | 
|---|
| 48 | SEG ;segments
 | 
|---|
| 49 |  S SRI=1
 | 
|---|
| 50 |  D PID^SRHLUO(.SRI,"HLS")
 | 
|---|
| 51 |  D OBR^SRHLUO4(.SRI,CASE,"HLS")
 | 
|---|
| 52 |  Q
 | 
|---|
| 53 | DISPLAY ;screen message to user
 | 
|---|
| 54 |  W !,"Sending an observation result message for case #",CASE
 | 
|---|
| 55 |  Q
 | 
|---|
| 56 | CHECK ;checks ^XTMP for duplicate modification messages
 | 
|---|
| 57 |  N X
 | 
|---|
| 58 |  I $D(^XTMP("SRHL7"_CASE,EID_"ORU",0)) D
 | 
|---|
| 59 |  .S X=0 F  S X=$O(^TMP("HLS",$J,X)) Q:'X!($D(UPDATE))  D
 | 
|---|
| 60 |  ..I '$D(^XTMP("SRHL7"_CASE,EID_"ORU",X)) S UPDATE=1 Q
 | 
|---|
| 61 |  ..I ^TMP("HLS",$J,X)'=^XTMP("SRHL7"_CASE,EID_"ORU",X) S UPDATE=1
 | 
|---|
| 62 |  .I $O(^XTMP("SRHL7"_CASE,EID_"ORU",X)) S UPDATE=1
 | 
|---|
| 63 |  I '$D(^XTMP("SRHL7"_CASE,EID_"ORU",0))!$D(UPDATE) K ^XTMP("SRHL7"_CASE,EID_"ORU") S UPDATE=1,^XTMP("SRHL7"_CASE,EID_"ORU",0)=DT D
 | 
|---|
| 64 |  .S X=0 F  S X=$O(^TMP("HLS",$J,X)) Q:'X  S ^XTMP("SRHL7"_CASE,EID_"ORU",X)=^TMP("HLS",$J,X)
 | 
|---|
| 65 |  Q
 | 
|---|