324 lines
8.8 KiB
Mathematica
324 lines
8.8 KiB
Mathematica
|
SCDXMSG1 ;ALB/JRP - AMB CARE MESSAGE BUILDER UTILS;08-MAY-1996 ; 6/21/05 2:08pm
|
||
|
;;5.3;Scheduling;**44,55,70,77,85,66,143,142,162,172,180,239,245,254,293,325,387,459,472**;AUG 13, 1993
|
||
|
;
|
||
|
;-- Line tags for building HL7 segment
|
||
|
BLDEVN S VAFEVN=$$EN^VAFHLEVN(EVNTHL7,ENCNDT,VAFSTR,HL("Q"),HL("FS"))
|
||
|
;SD*5.3*387 replaced EVNTDATE with ENCNDT
|
||
|
Q
|
||
|
BLDPID S VAFPID=$$EN^VAFHLPID(DFN,VAFSTR)
|
||
|
D SETMAR^SCMSVUT0(.VAFPID,HL("Q"),HL("FS"))
|
||
|
Q
|
||
|
BLDZPD S VAFZPD=$$EN1^VAFHLZPD(DFN,VAFSTR)
|
||
|
D SETPOW^SCMSVUT0(DFN,.VAFZPD,HL("Q"),HL("FS"))
|
||
|
Q
|
||
|
BLDPV1 D SETID^SCMSVUT0(ENCPTR,DELPTR)
|
||
|
S VAFPV1=$$EN^VAFHLPV1(ENCPTR,DELPTR,VAFSTR,1,HL("Q"),HL("FS"))
|
||
|
Q
|
||
|
BLDDG1 K @VAFARRY
|
||
|
D EN^VAFHLDG1(ENCPTR,VAFSTR,HL("Q"),HL("FS"),VAFARRY)
|
||
|
Q
|
||
|
BLDPR1 K @VAFARRY
|
||
|
D SETPRTY^SCMSVUT0(ENCPTR)
|
||
|
D EN^VAFHLPR1(ENCPTR,VAFSTR,HL("Q"),HL("FS"),HL("ECH"),VAFARRY)
|
||
|
Q
|
||
|
BLDZEL N ELCOD,ELIGENC,I,VAFMSTDT
|
||
|
S VAFMSTDT=ENCDT
|
||
|
D EN1^VAFHLZEL(DFN,VAFSTR,1,.VAFZEL)
|
||
|
S ELCOD=$P($G(^SCE(ENCPTR,0)),"^",13),ELIGENC=$P($G(^DIC(8,+ELCOD,0)),"^",9)
|
||
|
S $P(VAFZEL(1),HL("FS"),3)=ELIGENC
|
||
|
Q
|
||
|
BLDZIR K DGREL,DGINC,DGINR,DGDEP
|
||
|
D ALL^DGMTU21(DFN,"V",ENCDT,"R")
|
||
|
S VAFZIR=$$EN^VAFHLZIR(+$G(DGINR("V")),VAFSTR,1,ENCPTR)
|
||
|
K DGREL,DGINC,DGINR,DGDEP
|
||
|
Q
|
||
|
BLDZCL K @VAFARRY
|
||
|
D EN^VAFHLZCL(DFN,ENCPTR,VAFSTR,HL("Q"),HL("FS"),VAFARRY)
|
||
|
Q
|
||
|
BLDZSC K @VAFARRY
|
||
|
D EN^VAFHLZSC(ENCPTR,VAFSTR,HL("Q"),HL("FS"),VAFARRY)
|
||
|
Q
|
||
|
BLDZSP S VAFZSP=$$EN^VAFHLZSP(DFN,1,1)
|
||
|
S VAFZSP=$$SETVSI^SCMSVUT0(DFN,$G(VAFZSP),HL("Q"),HL("FS"))
|
||
|
Q
|
||
|
BLDROL K @VAFARRY
|
||
|
N SCDXPRV,SCDXPAR,SCDXROL,PTRPRV,NODE,PRVNUM,TMP
|
||
|
D GETPRV^SDOE(ENCPTR,"SCDXPRV")
|
||
|
S PTRPRV=0
|
||
|
F PRVNUM=1:1 S PTRPRV=+$O(SCDXPRV(PTRPRV)) Q:('PTRPRV) D
|
||
|
.K SCDXPAR,SCDXROL
|
||
|
.S NODE=SCDXPRV(PTRPRV)
|
||
|
.S SCDXPAR("PTR200")=+NODE
|
||
|
.S SCDXPAR("INSTID")=$$VID4XMIT^SCDXFU11(XMITPTR)_"-"_(+NODE)_"*"_PRVNUM
|
||
|
.S SCDXPAR("ACTION")="CO"
|
||
|
.S SCDXPAR("ALTROLE")=($TR($P(NODE,"^",4),"PS","10"))_$E(HL("ECH"),1)_HL("Q")_$E(HL("ECH"),1)_"VA01"
|
||
|
.S SCDXPAR("CODEONLY")=0
|
||
|
.S SCDXPAR("RDATE")=ENCDT
|
||
|
.D OUTPAT^VAFHLROL("SCDXPAR","SCDXROL",VAFSTR,HL("FS"),HL("ECH"),HL("Q"),240)
|
||
|
.K SCDXROL("ERROR"),SCDXROL("WARNING")
|
||
|
.M @VAFARRY@(PRVNUM)=SCDXROL
|
||
|
Q
|
||
|
BLDPD1 S VAFPD1=$$EN^VAFHLPD1(DFN,VAFSTR)
|
||
|
Q
|
||
|
BLDZEN S VAFZEN=$$EN^VAFHLZEN(DFN,VAFSTR,1,HL("Q"),HL("FS"))
|
||
|
Q
|
||
|
;
|
||
|
;-- Line tags for validating HL7 segments
|
||
|
VLDEVN S ERROR=$$EN^SCMSVEVN(VAFEVN,HL("Q"),HL("FS"),VALERR)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDPID S ERROR=$$EN^SCMSVPID(.VAFPID,HL("Q"),HL("FS"),HL("ECH"),VALERR,ENCDT,EVNTHL7)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDZPD S ERROR=$$EN^SCMSVZPD(.VAFZPD,HL("Q"),HL("FS"),VALERR,ENCDT,NODE)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDPV1 S ERROR=$$EN^SCMSVPV1(VAFPV1,HL("Q"),HL("FS"),VALERR,NODE,EVNTHL7,ENCNDT)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDDG1 S ERROR=$$EN^SCMSVDG1(VAFARRY,HL("Q"),HL("FS"),ENCPTR,VALERR,ENCDT)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDPR1 S ERROR=$$EN^SCMSVPR1(VAFARRY,HL("Q"),HL("FS"),HL("ECH"),VALERR,ENCDT)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDZEL S ERROR=$$EN^SCMSVZEL(.VAFZEL,HL("Q"),HL("FS"),VALERR,DFN)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDZIR S ERROR=$$EN^SCMSVZIR(VAFZIR,HL("Q"),HL("FS"),VALERR)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDZCL S ERROR=$$EN^SCMSVZCL(VAFARRY,HL("Q"),HL("FS"),VALERR,DFN)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDZSC S ERROR=$$EN^SCMSVZSC(VAFARRY,HL("Q"),HL("FS"),VALERR,ENCPTR)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDZSP S ERROR=$$EN^SCMSVZSP(VAFZSP,HL("Q"),HL("FS"),VALERR,DFN)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDROL S ERROR=$$EN^SCMSVROL(VAFARRY,HL("Q"),HL("FS"),HL("ECH"),VALERR)
|
||
|
S:(ERROR>0) ERROR=0
|
||
|
Q
|
||
|
VLDPD1 S ERROR=0
|
||
|
Q
|
||
|
VLDZEN S ERROR=0
|
||
|
Q
|
||
|
;
|
||
|
;-- Line tags for copying HL7 segments into HL7 message
|
||
|
CPYEVN N I
|
||
|
S @XMITARRY@(CURLINE)=VAFEVN
|
||
|
S LINESADD=LINESADD+1
|
||
|
S I=""
|
||
|
F S I=+$O(VAFEVN(I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFEVN(I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
CPYPID N I
|
||
|
S @XMITARRY@(CURLINE)=VAFPID
|
||
|
S LINESADD=LINESADD+1
|
||
|
S I=""
|
||
|
F S I=+$O(VAFPID(I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFPID(I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
CPYZPD N I
|
||
|
S @XMITARRY@(CURLINE)=VAFZPD
|
||
|
S LINESADD=LINESADD+1
|
||
|
S I=""
|
||
|
F S I=+$O(VAFZPD(I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFZPD(I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
CPYPV1 N I
|
||
|
S @XMITARRY@(CURLINE)=VAFPV1
|
||
|
S LINESADD=LINESADD+1
|
||
|
S I=""
|
||
|
F S I=+$O(VAFPV1(I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFPV1(I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
CPYDG1 N I,J,K
|
||
|
S I=""
|
||
|
F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
||
|
.S J=""
|
||
|
.F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
||
|
..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
||
|
..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
||
|
..S LINESADD=LINESADD+1
|
||
|
S CURLINE=CURLINE+K-1
|
||
|
Q
|
||
|
CPYPR1 N I,J,K
|
||
|
S I=""
|
||
|
F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
||
|
.S J=""
|
||
|
.F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
||
|
..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
||
|
..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
||
|
..S LINESADD=LINESADD+1
|
||
|
S CURLINE=CURLINE+K-1
|
||
|
Q
|
||
|
CPYZEL N I
|
||
|
S @XMITARRY@(CURLINE)=VAFZEL(1)
|
||
|
S LINESADD=LINESADD+1
|
||
|
S I=""
|
||
|
F S I=+$O(VAFZEL(1,I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFZEL(1,I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
CPYZIR N I
|
||
|
S @XMITARRY@(CURLINE)=VAFZIR
|
||
|
S LINESADD=LINESADD+1
|
||
|
N I
|
||
|
S I=""
|
||
|
F S I=+$O(VAFZIR(I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFZIR(I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
CPYZCL N I,J,K
|
||
|
S I=""
|
||
|
F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
||
|
.S J=""
|
||
|
.F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
||
|
..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
||
|
..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
||
|
..S LINESADD=LINESADD+1
|
||
|
S CURLINE=CURLINE+K-1
|
||
|
Q
|
||
|
CPYZSC N I,J,K
|
||
|
S I=""
|
||
|
F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
||
|
.S J=""
|
||
|
.F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
||
|
..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
||
|
..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
||
|
..S LINESADD=LINESADD+1
|
||
|
S CURLINE=CURLINE+K-1
|
||
|
Q
|
||
|
CPYZSP N I
|
||
|
S @XMITARRY@(CURLINE)=VAFZSP
|
||
|
S LINESADD=LINESADD+1
|
||
|
S I=""
|
||
|
F S I=+$O(VAFZSP(I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFZSP(I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
CPYROL N I,J,K
|
||
|
S I=""
|
||
|
F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
||
|
.S J=""
|
||
|
.F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
||
|
..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
||
|
..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
||
|
..S LINESADD=LINESADD+1
|
||
|
S CURLINE=CURLINE+K-1
|
||
|
Q
|
||
|
CPYPD1 N I
|
||
|
S @XMITARRY@(CURLINE)=VAFPD1
|
||
|
S LINESADD=LINESADD+1
|
||
|
S I=""
|
||
|
F S I=+$O(VAFPD1(I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFPD1(I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
CPYZEN N I
|
||
|
S @XMITARRY@(CURLINE)=VAFZEN
|
||
|
S LINESADD=LINESADD+1
|
||
|
S I=""
|
||
|
F S I=+$O(VAFZEN(I)) Q:('I) D
|
||
|
.S @XMITARRY@(CURLINE,I)=VAFZEN(I)
|
||
|
.S LINESADD=LINESADD+1
|
||
|
Q
|
||
|
;
|
||
|
;-- Line tags for deleting HL7 segments
|
||
|
DELEVN K VAFEVN
|
||
|
Q
|
||
|
DELPID K VAFPID
|
||
|
Q
|
||
|
DELZPD K VAFZPD
|
||
|
Q
|
||
|
DELPV1 K VAFPV1
|
||
|
Q
|
||
|
DELDG1 K @VAFARRY
|
||
|
Q
|
||
|
DELPR1 K @VAFARRY
|
||
|
Q
|
||
|
DELZEL K VAFZEL
|
||
|
Q
|
||
|
DELZIR K VAFZIR
|
||
|
Q
|
||
|
DELZCL K @VAFARRY
|
||
|
Q
|
||
|
DELZSC K @VAFARRY
|
||
|
Q
|
||
|
DELZSP K VAFZSP
|
||
|
Q
|
||
|
DELROL K @VAFARRY
|
||
|
Q
|
||
|
DELPD1 K VAFPD1
|
||
|
Q
|
||
|
DELZEN K VAFZEN
|
||
|
Q
|
||
|
;
|
||
|
;
|
||
|
SEGMENTS(EVNTTYPE,SEGARRY) ;Build list of HL7 segments for a given
|
||
|
; event type
|
||
|
;
|
||
|
;Input : EVNTTYPE - Event type to build list for
|
||
|
; A08 & A23 are the only types currently supported
|
||
|
; (Defaults to A08)
|
||
|
; SEGARRY - Array to place output in (full global reference)
|
||
|
; (Defaults to ^TMP("SCDX SEGMENTS",$J))
|
||
|
;Output : None
|
||
|
; SEGARRY(Seq,Name) = Fields
|
||
|
; Seq - Sequencing number to order the segments as
|
||
|
; they should be placed in the HL7 message
|
||
|
; Name - Name of HL7 segment
|
||
|
; Fields - List of fields used by Ambulatory Care
|
||
|
; VAFSTR would be set to this value
|
||
|
; : MSH segment is not included
|
||
|
;
|
||
|
;Check input
|
||
|
S EVNTTYPE=$G(EVNTTYPE)
|
||
|
S:(EVNTTYPE'="A23") EVNTTYPE="A08"
|
||
|
S SEGARRY=$G(SEGARRY)
|
||
|
S:(SEGARRY="") SEGARRY="^TMP(""SCDX SEGMENTS"","_$J_")"
|
||
|
;Segments used by A08 & A23
|
||
|
S @SEGARRY@(1,"EVN")="1,2"
|
||
|
S @SEGARRY@(2,"PID")="1,2,3,4,5,6,7,8,10N,11PC,13,14,16,17,19,22N"
|
||
|
S @SEGARRY@(3,"PD1")="3,4"
|
||
|
S @SEGARRY@(4,"PV1")="1,2,4,14,19,39,44,50"
|
||
|
;Building list for A23 - add ZPD segment and quit
|
||
|
I (EVNTTYPE="A23") D Q
|
||
|
.S @SEGARRY@(5,"ZPD")="1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,40"
|
||
|
S @SEGARRY@(5,"DG1")="1,2,3,4,5,15"
|
||
|
S @SEGARRY@(6,"PR1")="1,3,16"
|
||
|
S @SEGARRY@(7,"ROL")="1,2,3,4"
|
||
|
S @SEGARRY@(8,"ZPD")="1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,40"
|
||
|
S @SEGARRY@(9,"ZEL")="1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,29,37,38"
|
||
|
S @SEGARRY@(10,"ZIR")="1,2,3,4,5,6,7,8,9,10,11,12,13"
|
||
|
S @SEGARRY@(11,"ZCL")="1,2,3"
|
||
|
S @SEGARRY@(12,"ZSC")="1,2,3"
|
||
|
S @SEGARRY@(13,"ZSP")="1,2,3,4"
|
||
|
S @SEGARRY@(14,"ZEN")="1,2,3,4,5,6,7,8,9,10"
|
||
|
Q
|
||
|
;
|
||
|
UNWIND(XMITARRY,INSRTPNT) ;Remove all data that was put into HL7 message
|
||
|
;
|
||
|
;Input : XMITARRY - Array containing HL7 message (full global ref)
|
||
|
; (Defaults to ^TMP("HLS",$J))
|
||
|
; INSRTPNT - Where to begin deletion from (Defaults to 1)
|
||
|
;Output : None
|
||
|
;
|
||
|
;Check input
|
||
|
S XMITARRY=$G(XMITARRY)
|
||
|
S:(XMITARRY="") XMITARRY="^TMP(""HLS"","_$J_")"
|
||
|
S INSRTPNT=$G(INSRTPNT)
|
||
|
S:(INSRTPNT="") INSRTPNT=1
|
||
|
;Remove insertion point from array
|
||
|
K @XMITARRY@(INSRTPNT)
|
||
|
;Remove everything from insertion point to end of array
|
||
|
F S INSRTPNT=$O(@XMITARRY@(INSRTPNT)) Q:(INSRTPNT="") K @XMITARRY@(INSRTPNT)
|
||
|
;Done
|
||
|
Q
|