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

HLCSRPT1.m

Go to the documentation of this file.
  1. HLCSRPT1 ;ISC-SF/RAH-TRANS LOG PENDING MSG LIST;03/01/2010 14:59 ;08/25/2010
  1. ;;1.6;HEALTH LEVEL SEVEN;**19,50,107,145,151**;Oct 13, 1995;Build 1
  1. ;Per VHA Directive 2004-038, this routine should not be modified.
  1. ;
  1. Q
  1. ;
  1. EN ; Entry Point for Pending Message Search.
  1. D LNKSRCH Q:$D(STOP)
  1. I HLCSLS=1 D SEARCH1 Q
  1. D SEARCH2
  1. Q
  1. ;
  1. ;
  1. SEARCH1 ;
  1. W !!," . . . PLEASE WAIT, THIS CAN TAKE AWHILE . . .",!
  1. S HLCSI=0,HLCSIO="" S HLCSLN=0
  1. F S HLCSIO=$O(^HLMA("AC",HLCSIO)) Q:(HLCSIO="") D
  1. . S HLCSN=HLCSI,HLCSJ=0
  1. . F S HLCSJ=$O(^HLMA("AC",HLCSIO,HLCSLINK,HLCSJ)) Q:(HLCSJ="") D
  1. .. I '$D(^HLMA(HLCSJ,0)) Q
  1. .. I '$D(^HLMA("AG",1,HLCSJ)) Q
  1. .. S HLCSX=^HLMA(HLCSJ,0),HLCSDTE=$P(HLCSX,U,1)
  1. .. S HLCSLNK=" "
  1. .. I $D(^HLCS(870,HLCSLINK,0)) S HLCSLNK=$P(^HLCS(870,HLCSLINK,0),U,1)
  1. .. ; patch HL*1.6*145 start
  1. .. ; S HLCSEVN1=$P(HLCSX,U,13) I HLCSEVN1'="",($D(^HL(771.2,HLCSEVN1,0))) S HLCSEVN1=$P(^HL(771.2,HLCSEVN1,0),U,1)
  1. .. ; S HLCSEVN2=$P(HLCSX,U,14) I HLCSEVN2'="",($D(^HL(779.001,HLCSEVN2,0))) S HLCSEVN2=$P(^HL(779.001,HLCSEVN2,0),U,1)
  1. .. N SEG
  1. .. D HEADSEG(HLCSJ,.SEG)
  1. .. S HLCSEVN1=$G(SEG("MESSAGE TYPE"))
  1. .. S HLCSEVN2=$G(SEG("EVENT TYPE"))
  1. .. ; patch HL*1.6*145 end
  1. .. I HLCSEVN1="" S HLCSEVN1=" "
  1. .. I HLCSEVN2="" S HLCSEVN2=" "
  1. .. I $L(HLCSEVN1)<3 S HLCSEVN1=HLCSEVN1_" ",HLCSEVN1=$E(HLCSEVN1,1,3)
  1. .. I $L(HLCSEVN2)<3 S HLCSEVN2=HLCSEVN2_" ",HLCSEVN2=$E(HLCSEVN2,1,3)
  1. .. S HLCSEVN=HLCSEVN1_":"_HLCSEVN2
  1. .. D FORMAT^HLCSRPT
  1. .. Q
  1. . Q
  1. I '$D(^TMP("TLOG",$J,1)) W !!,HLCSNREC,!! S DIR(0)="E" D ^DIR K DIR Q
  1. I VERS22'="YES" S HLCSTITL="IEN RECORD # MESSAGE ID # Log Link Msg:Evn IO Sndg Apl Rcvr Apl HDR"
  1. E S HLCSTITL="MESSAGE ID # D/T Entered Log Link Msg:Evn IO Sndg Apl Rcvr Apl "
  1. I VERS22'="YES" D FAKR
  1. D DISPLAY^HLCSRPT K ^TMP("TLOG",$J)
  1. Q
  1. ;
  1. SEARCH2 ;
  1. W !!," . . . PLEASE WAIT, THIS CAN TAKE AWHILE . . .",!
  1. S HLCSI=0,HLCSIO="" S HLCSLN=0
  1. F S HLCSIO=$O(^HLMA("AC",HLCSIO)) Q:(HLCSIO="") D
  1. . S HLCSN=HLCSI,HLCSJ=0,HLCSLINK=0
  1. . F S HLCSLINK=$O(^HLMA("AC",HLCSIO,HLCSLINK)) Q:(HLCSLINK="") D
  1. .. F S HLCSJ=$O(^HLMA("AC",HLCSIO,HLCSLINK,HLCSJ)) Q:(HLCSJ="") D
  1. ... I '$D(^HLMA(HLCSJ,0)) Q
  1. ... I '$D(^HLMA("AG",1,HLCSJ)) Q
  1. ... S HLCSX=^HLMA(HLCSJ,0),HLCSDTE=$P(HLCSX,U,1)
  1. ... S HLCSLNK=" "
  1. ... I $D(^HLCS(870,HLCSLINK,0)) S HLCSLNK=$P(^HLCS(870,HLCSLINK,0),U,1)
  1. ... ; patch HL*1.6*145 start
  1. ... ; S HLCSEVN1=$P(HLCSX,U,13) I HLCSEVN1'="",($D(^HL(771.2,HLCSEVN1,0))) S HLCSEVN1=$P(^HL(771.2,HLCSEVN1,0),U,1)
  1. ... ; S HLCSEVN2=$P(HLCSX,U,14) I HLCSEVN2'="",($D(^HL(779.001,HLCSEVN2,0))) S HLCSEVN2=$P(^HL(779.001,HLCSEVN2,0),U,1)
  1. ... N SEG
  1. ... D HEADSEG(HLCSJ,.SEG)
  1. ... S HLCSEVN1=$G(SEG("MESSAGE TYPE"))
  1. ... S HLCSEVN2=$G(SEG("EVENT TYPE"))
  1. ... ; patch HL*1.6*145 end
  1. ... I HLCSEVN1="" S HLCSEVN1=" "
  1. ... I HLCSEVN2="" S HLCSEVN2=" "
  1. ... I $L(HLCSEVN1)<3 S HLCSEVN1=HLCSEVN1_" ",HLCSEVN1=$E(HLCSEVN1,1,3)
  1. ... I $L(HLCSEVN2)<3 S HLCSEVN2=HLCSEVN2_" ",HLCSEVN2=$E(HLCSEVN2,1,3)
  1. ... S HLCSEVN=HLCSEVN1_":"_HLCSEVN2
  1. ... D FORMAT^HLCSRPT
  1. ... Q
  1. .. Q
  1. . Q
  1. I '$D(^TMP("TLOG",$J,1)) W !!,HLCSNREC,!! S DIR(0)="E" D ^DIR K DIR Q
  1. I VERS22'="YES" S HLCSTITL="IEN RECORD # MESSAGE ID # Log Link Msg:Evn IO Sndg Apl Rcvr Apl HDR"
  1. E S HLCSTITL="MESSAGE ID # D/T Entered Log Link Msg:Evn IO Sndg Apl Rcvr Apl "
  1. I VERS22'="YES" D FAKR
  1. D DISPLAY^HLCSRPT K ^TMP("TLOG",$J)
  1. Q
  1. ;
  1. LNKSRCH ; Report pending messages on A logical link.
  1. W @IOF,! S HLCSHDR="Logical Link Selection" D HLCSBAR
  1. S DIR(0)="PAO^870:AEO",DIR("A")="Select Logical Link: ALL//"
  1. D ^DIR S:($D(DTOUT)!($D(DUOUT))) STOP=1 Q:$D(STOP)
  1. I X="" S HLCSLS="" K DIR,X,Y Q
  1. I Y=-1 W !,X_" NOT VALID " K X,Y G LNKSRCH
  1. S HLCSLINK=$P(Y,U,1),HLCSLNK=$P(Y,U,2) K DIR,X,Y
  1. S HLCSLS=1
  1. Q
  1. ;
  1. FAKR ; Build fake record to pass FM21 Browser edits.
  1. S HLCSJ=^TMP("TLOG",$J,1)
  1. S HLCSJ=+$P(HLCSJ," ",1)
  1. S ^TMP($J,"MESSAGE",HLCSJ,0)="^^1^1"
  1. S ^TMP($J,"MESSAGE",HLCSJ,1,0)=" Fake Record to pass Browser edits. "
  1. S HLCSRNO=HLCSJ
  1. Q
  1. ;
  1. SHOWMSG(XXY,XXZ) ;
  1. ; Each node, ^tmp($j,"message",record_ien), invokes this code
  1. ; to compile a 'virtual w-p document' when a message is browsed.
  1. I $D(^HLMA(XXY,"MSH",0)) D
  1. . S ^TMP($J,"MESSAGE",XXY,0)=^HLMA(XXY,"MSH",0)
  1. . S YY1=$P(^HLMA(XXY,"MSH",0),U,3),YY2=$P(^HLMA(XXY,"MSH",0),U,4)
  1. E S ^TMP($J,"MESSAGE",XXY,0)="1^1"
  1. S XLINE=^HLMA(XXY,0)
  1. S LINE="Record #: "_XXY_" ",LINE=$E(LINE,1,30)
  1. S LINE=LINE_"Message #: "_$P(XLINE,U,2)
  1. S ^TMP($J,"MESSAGE",XXY,1,0)=LINE
  1. S DTE=$P(XLINE,U,1) I $P($G(^HL(772,DTE,0)),U,1)'="" S DTE=$P(^HL(772,DTE,0),U,1),DTE=$E(DTE,4,7)_$E(DTE,2,3)_"."_$P(DTE,".",2)_" "
  1. I $D(^HLMA(XXY,"S")),$P(^HLMA(XXY,"S"),U,1)'="" S DTP=$P(^HLMA(XXY,"S"),U,1) S DTP=$E(DTP,4,7)_$E(DTP,2,3)_"."_$P(DTP,".",2)
  1. E S DTP=" "
  1. S LINE="D/T Entered: "_DTE,LINE=$E(LINE,1,30)_"D/T Processed: "_DTP
  1. S ^TMP($J,"MESSAGE",XXY,2,0)=LINE K DTE,DTP
  1. S LINE="Logical Link: " I $P(XLINE,U,7)'="",($D(^HLCS(870,$P(XLINE,U,7),0))) S LINE=LINE_$P(^HLCS(870,$P(XLINE,U,7),0),U,1)
  1. S LINE=LINE_" ",LINE=$E(LINE,1,30)
  1. S LINE=LINE_"Ack To MSG#: " I $P(XLINE,U,6)'="",($D(^HLMA($P(XLINE,U,6),0))) S LINE=LINE_$P(^HLMA($P(XLINE,U,6),0),U,2)
  1. S ^TMP($J,"MESSAGE",XXY,3,0)=LINE
  1. S DTS="" I $P($G(^HLMA(XXY,"P")),U,2)'="" S DTS=$P(^HLMA(XXY,"P"),U,2),DTS=$E(DTS,4,7)_$E(DTS,2,3)_"."_$P(DTS,".",2)
  1. S LINE="D/T STATUS: "_DTS_" ",LINE=$E(LINE,1,30),LINE=LINE_"STATUS: "
  1. I $P(^HLMA(XXY,"P"),U,1)'="" S LINE=LINE_$P(^HL(771.6,+$P(^HLMA(XXY,"P"),U,1),0),U,1)
  1. S ^TMP($J,"MESSAGE",XXY,4,0)=LINE K DTS
  1. S LINE="ERR MSG: " I $P(^HLMA(XXY,"P"),U,3)'="" S LINE=LINE_$E($P(^HLMA(XXY,"P"),U,3),1,20)
  1. S LINE=LINE_" ",LINE=$E(LINE,1,30)_"ERR TYPE: "
  1. I $P(^HLMA(XXY,"P"),U,4)'="" S LINE=LINE_$P(^HL(771.7,+$P(^HLMA(XXY,"P"),U,4),0),U,1)
  1. S ^TMP($J,"MESSAGE",XXY,5,0)=LINE
  1. S LINE="Sending Appl: " I $P(XLINE,U,11)'="",($D(^HL(771,$P(XLINE,U,11),0))) S LINE=LINE_$P(^HL(771,$P(XLINE,U,11),0),U,1)
  1. S ^TMP($J,"MESSAGE",XXY,6,0)=LINE
  1. S LINE="Receiving Appl: " I $P(XLINE,U,12)'="",($D(^HL(771,$P(XLINE,U,12),0))) S LINE=LINE_$P(^HL(771,$P(XLINE,U,12),0),U,1)
  1. S ^TMP($J,"MESSAGE",XXY,7,0)=LINE
  1. ; patch HL*1.6*145 start
  1. ; S LINE="Message Type: " I $P(XLINE,U,13)'="",($D(^HL(771.2,$P(XLINE,U,13),0))) S LINE=LINE_$P(^HL(771.2,$P(XLINE,U,13),0),U,1)
  1. N SEG
  1. D HEADSEG(XXY,.SEG)
  1. S LINE="Message Type: "_$G(SEG("MESSAGE TYPE"))
  1. S LINE=LINE_" ",LINE=$E(LINE,1,30)_"Event Type: "
  1. ; I $P(XLINE,U,14)'="",($D(^HL(779.001,$P(XLINE,U,14),0))) S LINE=LINE_$P(^HL(779.001,$P(XLINE,U,14),0),U,1)
  1. S LINE=LINE_$G(SEG("EVENT TYPE"))
  1. ; patch HL*1.6*145 end
  1. S ^TMP($J,"MESSAGE",XXY,8,0)=LINE K LINE,XLINE
  1. S ^TMP($J,"MESSAGE",XXY,9,0)="MESSAGE HEADER: "
  1. S LN1=.5,LN2=10
  1. I $D(^HLMA(XXY,"MSH",0)) D
  1. . F S LN1=$O(^HLMA(XXY,"MSH",LN1)) Q:LN1="" D
  1. .. S ^TMP($J,"MESSAGE",XXY,LN2,0)=^HLMA(XXY,"MSH",LN1,0)
  1. .. ;HL*1.6*107 start: to fix the multiple lines per segment
  1. .. ;S LN2=LN2+1,LN1=LN1+1
  1. .. S LN2=LN2+1
  1. .. ;HL*1.6*107 end
  1. ..Q
  1. S LN1=.5
  1. S ^TMP($J,"MESSAGE",XXY,LN2,0)="MESSAGE TEXT: ",LN2=LN2+1
  1. I $D(^HL(772,XXZ,"IN",0)) D
  1. . F S LN1=$O(^HL(772,XXZ,"IN",LN1)) Q:(LN1="") D
  1. .. S ^TMP($J,"MESSAGE",XXY,LN2,0)=^HL(772,XXZ,"IN",LN1,0)
  1. .. ;HL*1.6*107 start: to fix the multiple lines per segment
  1. .. ;S LN2=LN2+1,LN1=LN1+1
  1. .. S LN2=LN2+1
  1. .. ;HL*1.6*107 end
  1. ..Q
  1. S (YY1,YY2)=LN2-1
  1. S Y1Y2=YY1_"^"_YY2
  1. S $P(^TMP($J,"MESSAGE",XXY,0),U,3,4)=Y1Y2
  1. K LN1,LN2,Y1Y2,YY1,YY2
  1. Q
  1. ;
  1. HLCSBAR ; Center Title on Top Line of Screen
  1. W RVON,?(80-$L(HLCSHDR)\2),HLCSHDR,$E(SPACE,$X,77),RVOFF,!
  1. Q
  1. ;
  1. HEADSEG(IEN,SEG) ;
  1. ; patch HL*1.6*145
  1. ; input:
  1. ; IEN: ien of message in file #773
  1. ; SEG: passing by reference
  1. ; output:
  1. ; SEG
  1. ;
  1. Q:'$G(IEN)
  1. K SEG
  1. S SEG=$G(^HLMA(IEN,"MSH",1,0))_$G(^HLMA(IEN,"MSH",2,0))
  1. Q:SEG']""
  1. S SEG("CODE")=$E(SEG,1,3)
  1. Q:$L(SEG("CODE"))'=3
  1. S SEG("FIELD")=$E(SEG,4)
  1. Q:SEG("FIELD")=""
  1. S SEG("COMPONENT")=$E(SEG,5)
  1. Q:SEG("COMPONENT")=""
  1. S SEG("SUB-COMPONENT")=$E(SEG,8)
  1. S SEG("ECH-2")=$E(SEG,6)
  1. ;
  1. S SEG("MESSAGE TYPE")=""
  1. S SEG("EVENT TYPE")=""
  1. ;
  1. I SEG("CODE")="MSH" D
  1. . S SEG("SEG-9")=$P(SEG,SEG("FIELD"),9)
  1. . S SEG("MESSAGE TYPE")=$P(SEG("SEG-9"),SEG("COMPONENT"))
  1. . S SEG("EVENT TYPE")=$P(SEG("SEG-9"),SEG("COMPONENT"),2)
  1. ;
  1. I SEG("CODE")="BHS" D
  1. . S SEG("SEG-9")=$P(SEG,SEG("FIELD"),9)
  1. . I SEG("SEG-9")]"" D
  1. .. S SEG("SEG-9-2")=$P(SEG("SEG-9"),SEG("COMPONENT"),3)
  1. .. S SEG("MESSAGE TYPE")=SEG("SEG-9-2")
  1. .. I SEG("SEG-9-2")]"",$L(SEG("ECH-2")),(SEG("SEG-9-2")[SEG("ECH-2")) D
  1. ... S SEG("MESSAGE TYPE")=$P(SEG("SEG-9-2"),SEG("ECH-2"))
  1. ... S SEG("EVENT TYPE")=$P(SEG("SEG-9-2"),SEG("ECH-2"),2)
  1. .. ;
  1. .. Q:SEG("SUB-COMPONENT")=""
  1. .. I SEG("SEG-9-2")]"",(SEG("SEG-9-2")[SEG("SUB-COMPONENT")) D
  1. ... S SEG("MESSAGE TYPE")=$P(SEG("SEG-9-2"),SEG("SUB-COMPONENT"))
  1. ... S SEG("EVENT TYPE")=$P(SEG("SEG-9-2"),SEG("SUB-COMPONENT"),2)
  1. Q
  1. ;