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

GMRCHL7P.m

Go to the documentation of this file.
  1. GMRCHL7P ;DSS/MS - HL7 Message Utilities for HCP ;4/29/14
  1. ;;3.0;CONSULT/REQUEST TRACKING;**75**;DEC 27, 1997;Build 22
  1. ;
  1. ;DBIA# Supported Reference
  1. ;----- --------------------------------
  1. ;10106 HLPHONE^HLFNC
  1. ;
  1. ADDR(PROVIEN,HL) ;get address data for Referring Provider
  1. N HL7STRG,COMP,ADD,STATEIEN S COMP=$E(HL("ECH")),ADD=""
  1. S HL7STRG=$$GET1^DIQ(200,PROVIEN_",",.111) D HL7TXT(.HL7STRG,.HL,"\")
  1. S $P(ADD,COMP)=HL7STRG
  1. S HL7STRG=$$GET1^DIQ(200,PROVIEN_",",.112) D HL7TXT(.HL7STRG,.HL,"\")
  1. S $P(ADD,COMP,2)=HL7STRG
  1. S HL7STRG=$$GET1^DIQ(200,PROVIEN_",",.114) D HL7TXT(.HL7STRG,.HL,"\")
  1. S $P(ADD,COMP,3)=HL7STRG
  1. S STATEIEN=$$GET1^DIQ(200,PROVIEN_",",.115,"I") S $P(ADD,COMP,4)=$$GET1^DIQ(5,+STATEIEN_",",1)
  1. S HL7STRG=$$GET1^DIQ(200,PROVIEN_",",.116) D HL7TXT(.HL7STRG,.HL,"\")
  1. S $P(ADD,COMP,5)=HL7STRG
  1. Q ADD
  1. PH(PROVIEN,HL) ;get contact information
  1. N HL7STRG,COMP,PH S COMP=$E(HL("ECH")),PH=""
  1. S HL7STRG=$$GET1^DIQ(200,PROVIEN_",",.151) D HL7TXT(.HL7STRG,.HL,"\")
  1. S $P(PH,COMP,4)=HL7STRG
  1. S HL7STRG=$$GET1^DIQ(200,PROVIEN_",",.132),HL7STRG=$$HLPHONE^HLFNC(HL7STRG)
  1. I HL7STRG["(" S $P(PH,COMP,6)=$E(HL7STRG,2,4),$P(PH,COMP,7)=$P(HL7STRG,")",2)
  1. E S $P(PH,COMP,7)=HL7STRG
  1. Q PH
  1. HL7TXT(HL7STRG,HL,HLES) ; Replace occurrences of embedded HL7 delimiters with
  1. ; HL7 escape sequence
  1. ; copied from VAFCQRY1
  1. ;
  1. ; Inputs: HL7STRG - Data string to be checked
  1. ; HL("ECH") - HL7 delimiter string
  1. ; Delimiters MUST be in the following order,
  1. ; Escape, Field, Component, Repeat, Subcomponent
  1. ; Example: \|^~&
  1. ;
  1. ; Output: HL7XTRG - Data string with escape sequence added (if needed)
  1. ;
  1. N OCHR,RCHR,RCHRI,TYPE,I,HLES2
  1. ;
  1. I $G(HL("COMP"))="" S HL("COMP")=$E(HL("ECH"),1),HL("REP")=$E(HL("ECH"),2),HL("SUBCOMP")=$E(HL("ECH"),4)
  1. ; Set HL7 escape char
  1. S HLES2=HLES_HL("FS")_HL("COMP")_HL("REP")_HL("SUBCOMP")
  1. ;
  1. ; Search for occurrence of each delimiter and replace it with "\<type>\"
  1. F TYPE="E","F","C","R","S" D
  1. . S RCHRI=$S(TYPE="E":1,TYPE="F":2,TYPE="C":3,TYPE="R":4,TYPE="S":5)
  1. . ;
  1. . ; OCHR=original char, RCHR=replacement char
  1. . S OCHR=$E(HLES2,RCHRI),RCHR=$E("EFSRT",RCHRI) Q:'$F(HL7STRG,OCHR)
  1. . F I=1:1 Q:$E(HL7STRG,I)="" I $E(HL7STRG,I)=OCHR S HL7STRG=$E(HL7STRG,1,I-1)_HLES_RCHR_HLES_$E(HL7STRG,I+1,999),I=I+2
  1. Q