- MPIFRESS ;BHM/RGY-Process a CMOR result ;FEB 27, 1998
- ;;1.0; MASTER PATIENT INDEX VISTA ;**1,6,11,30**;30 Apr 99
- ;
- ; Integration Agreements Utilized:
- ;
- ; EXC^RGHLLOG IA #2796
- ; START^RGHLLOG IA #2796
- ; STOP^RGHLLOG IA #2796
- ; $$EN^VAFCPID IA #3015
- ;
- EN(REQNO) ;
- N RGL,ID,COMMENTS,STATUS,NDATE,PHONE,REVIEWER,N0,CNT,HL,HLA,XX,ERROR
- S CNT=0,HL=0
- S N0=$G(^MPIF(984.9,REQNO,0))
- I N0="" D Q
- .D START^RGHLLOG()
- .D EXC^RGHLLOG(210,"CMOR Request # "_REQNO_" Does Not Exist attempting to generate approved/not approved msg")
- .D STOP^RGHLLOG()
- S ID=$P(N0,"^")
- S STATUS=$P(N0,"^",6)
- S COMMENTS=$P($G(^MPIF(984.9,REQNO,3)),"^",2)
- I $P($G(^MPIF(984.9,REQNO,3)),"^")]"" S REVIEWER=$P(^(3),"^")
- I $P($G(^MPIF(984.9,REQNO,3)),"^")']"" D
- .N DIC,X,Y
- .S DIC="^VA(200,",DIC(0)="ZMO",X="`"_+$P(^MPIF(984.9,REQNO,2),"^")
- .D ^DIC
- .I $G(Y)>1 S REVIEWER=$G(Y(0,0))
- .I $G(Y)<1 S REVIEWER=""
- S NDATE=$P($G(^MPIF(984.9,REQNO,2)),"^",2)
- S PHONE=$P($G(^MPIF(984.9,REQNO,2)),"^",3)
- S COMMENTS=$P($G(^MPIF(984.9,REQNO,3)),"^",2)
- K HLA
- D INIT^HLFNC2("MPIF CMOR APPROVE/DISAPPROVE",.HL)
- I HL S ERROR=HL D Q
- .D START^RGHLLOG()
- .D EXC^RGHLLOG(220,"Unable to setup HL7 for Change CMOR Request # "_REQNO_" for Approved/Not Approved msg HL Error"_HL,$P(N0,"^",4))
- .D STOP^RGHLLOG()
- K HLL("LINKS") N MPILK
- S MPILK=$$MPILINK^MPIFAPI ;routing all messages through the MPI
- I +MPILK<0 D Q
- .D START^RGHLLOG()
- .D EXC^RGHLLOG(224,"No MPI link found for Change CMOR Request # "_REQNO_" for ICN="_ICN,DFN)
- .D STOP^RGHLLOG()
- .S ERROR="-1^LINK FOR MPI NOT FOUND"
- ;Broadcast MSG to MPI which will send it to the requestor site
- S HLL("LINKS",1)="MPIF CMOR APP/DIS^"_MPILK
- S CNT=CNT+1,HLA("HLS",CNT)="EVN"_HL("FS")_"A31"_HL("FS")_NDATE_HL("FS")_HL("FS")_""_HL("FS")_REVIEWER
- S CNT=CNT+1,HLA("HLS",CNT)="NTE"_HL("FS")_HL("FS")_"P"_HL("FS")_PHONE_HL("FS")_COMMENTS_HL("FS")_STATUS_HL("FS")_ID
- S CNT=CNT+1,HLA("HLS",CNT)=$$EN^VAFCPID(+$P(N0,"^",4),"1,2,4,5,6,7,8,11,12,13,14,16,17,19")
- N RLST
- D GENERATE^HLMA("MPIF CMOR APPROVE/DISAPPROVE","LM",1,.RLST,"",.HL)
- I 'RLST S ERROR=RLST D START^RGHLLOG(),EXC^RGHLLOG(220,"Error Generating HL7 msg for Approve/Not Approved CMOR Request # "_REQNO,$P(N0,"^",4))
- Q
- ;
- IN ;
- ; Processing approve/not approve msg to update Request in 984.9 file
- N DFN,ENT,XMY,XMDUZ,XMTEXT,MPIF,XMSUB,FSITE,CMOR,PHONE,RESULT,REVIEWER,COMMENTS,NDATE,II,ICN
- S (HLQUIT,ID,COMMENTS,PHONE,REVIEWER)=""
- F II=1:1 X HLNEXT Q:HLQUIT'>0 D
- .I $P(HLNODE,HL("FS"),1)="NTE" D
- ..S ID=$P(HLNODE,HL("FS"),7),RESULT=$P(HLNODE,HL("FS"),6)
- ..S PHONE=$P(HLNODE,HL("FS"),4)
- ..S COMMENTS=$P(HLNODE,HL("FS"),5)
- .I $P(HLNODE,HL("FS"),1)="EVN" D
- ..S NDATE=$P(HLNODE,HL("FS"),3)
- ..S REVIEWER=$P(HLNODE,HL("FS"),6)
- .I $P(HLNODE,HL("FS"),1)="PID" D
- ..S ICN=+$P(HLNODE,HL("FS"),3)
- S ENT=$O(^MPIF(984.9,"B",ID,0))
- ;; CHANGE FOR NOIS MAD-0900-42526
- I ENT="" D
- .D START^RGHLLOG()
- .D EXC^RGHLLOG(210,"CMOR Request # "_ID_" Does Not Exist CMORs may be out of sync for ICN "_ICN_". HL7 msg# "_HL("MID"))
- .D STOP^RGHLLOG()
- Q:ENT=""
- Q:'$D(^MPIF(984.9,ENT,0))
- S DFN=$P($G(^MPIF(984.9,ENT,0)),"^",4),FSITE=$P($G(^(0)),"^",7)
- S DIC="^DIC(4,",DIC(0)="MXNZ",X=FSITE D ^DIC
- I $G(Y)>0 S FSITE=$P(Y,"^",2)
- K Y,X,DIC
- S DIE="^MPIF(984.9,",DA=ENT,DR="[MPIF RESULT INCOMING]" D ^DIE K DIE,DA,DR
- S XMDUZ="MPI VISTA Package"
- S XMSUB="Request "_ID_" is "_$S(RESULT=4:"approved",1:"disapproved")
- N REQR S REQR=$P($G(^MPIF(984.9,ENT,0)),"^",2) I REQR="" S REQR="AUTO"
- S XMY(REQR)="",XMTEXT="MPIF(1,"
- S MPIF(1,1)=FSITE_" received CMOR request for "_$P($G(^DPT(+$P(^MPIF(984.9,ENT,0),"^",4),0)),"^")_" ("_$E($P(^(0),"^",9),6,9)_")."
- S MPIF(1,2)=XMSUB_"."
- S MPIF(1,3)="Processed by: "_$G(REVIEWER)
- S MPIF(1,4)="Phone: "_$G(PHONE)
- S MPIF(1,5)="Comments: "_$G(COMMENTS)
- D ^XMD
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMPIFRESS 3886 printed Mar 13, 2025@21:16:21 Page 2
- MPIFRESS ;BHM/RGY-Process a CMOR result ;FEB 27, 1998
- +1 ;;1.0; MASTER PATIENT INDEX VISTA ;**1,6,11,30**;30 Apr 99
- +2 ;
- +3 ; Integration Agreements Utilized:
- +4 ;
- +5 ; EXC^RGHLLOG IA #2796
- +6 ; START^RGHLLOG IA #2796
- +7 ; STOP^RGHLLOG IA #2796
- +8 ; $$EN^VAFCPID IA #3015
- +9 ;
- EN(REQNO) ;
- +1 NEW RGL,ID,COMMENTS,STATUS,NDATE,PHONE,REVIEWER,N0,CNT,HL,HLA,XX,ERROR
- +2 SET CNT=0
- SET HL=0
- +3 SET N0=$GET(^MPIF(984.9,REQNO,0))
- +4 IF N0=""
- Begin DoDot:1
- +5 DO START^RGHLLOG()
- +6 DO EXC^RGHLLOG(210,"CMOR Request # "_REQNO_" Does Not Exist attempting to generate approved/not approved msg")
- +7 DO STOP^RGHLLOG()
- End DoDot:1
- QUIT
- +8 SET ID=$PIECE(N0,"^")
- +9 SET STATUS=$PIECE(N0,"^",6)
- +10 SET COMMENTS=$PIECE($GET(^MPIF(984.9,REQNO,3)),"^",2)
- +11 IF $PIECE($GET(^MPIF(984.9,REQNO,3)),"^")]""
- SET REVIEWER=$PIECE(^(3),"^")
- +12 IF $PIECE($GET(^MPIF(984.9,REQNO,3)),"^")']""
- Begin DoDot:1
- +13 NEW DIC,X,Y
- +14 SET DIC="^VA(200,"
- SET DIC(0)="ZMO"
- SET X="`"_+$PIECE(^MPIF(984.9,REQNO,2),"^")
- +15 DO ^DIC
- +16 IF $GET(Y)>1
- SET REVIEWER=$GET(Y(0,0))
- +17 IF $GET(Y)<1
- SET REVIEWER=""
- End DoDot:1
- +18 SET NDATE=$PIECE($GET(^MPIF(984.9,REQNO,2)),"^",2)
- +19 SET PHONE=$PIECE($GET(^MPIF(984.9,REQNO,2)),"^",3)
- +20 SET COMMENTS=$PIECE($GET(^MPIF(984.9,REQNO,3)),"^",2)
- +21 KILL HLA
- +22 DO INIT^HLFNC2("MPIF CMOR APPROVE/DISAPPROVE",.HL)
- +23 IF HL
- SET ERROR=HL
- Begin DoDot:1
- +24 DO START^RGHLLOG()
- +25 DO EXC^RGHLLOG(220,"Unable to setup HL7 for Change CMOR Request # "_REQNO_" for Approved/Not Approved msg HL Error"_HL,$PIECE(N0,"^",4))
- +26 DO STOP^RGHLLOG()
- End DoDot:1
- QUIT
- +27 KILL HLL("LINKS")
- NEW MPILK
- +28 ;routing all messages through the MPI
- SET MPILK=$$MPILINK^MPIFAPI
- +29 IF +MPILK<0
- Begin DoDot:1
- +30 DO START^RGHLLOG()
- +31 DO EXC^RGHLLOG(224,"No MPI link found for Change CMOR Request # "_REQNO_" for ICN="_ICN,DFN)
- +32 DO STOP^RGHLLOG()
- +33 SET ERROR="-1^LINK FOR MPI NOT FOUND"
- End DoDot:1
- QUIT
- +34 ;Broadcast MSG to MPI which will send it to the requestor site
- +35 SET HLL("LINKS",1)="MPIF CMOR APP/DIS^"_MPILK
- +36 SET CNT=CNT+1
- SET HLA("HLS",CNT)="EVN"_HL("FS")_"A31"_HL("FS")_NDATE_HL("FS")_HL("FS")_""_HL("FS")_REVIEWER
- +37 SET CNT=CNT+1
- SET HLA("HLS",CNT)="NTE"_HL("FS")_HL("FS")_"P"_HL("FS")_PHONE_HL("FS")_COMMENTS_HL("FS")_STATUS_HL("FS")_ID
- +38 SET CNT=CNT+1
- SET HLA("HLS",CNT)=$$EN^VAFCPID(+$PIECE(N0,"^",4),"1,2,4,5,6,7,8,11,12,13,14,16,17,19")
- +39 NEW RLST
- +40 DO GENERATE^HLMA("MPIF CMOR APPROVE/DISAPPROVE","LM",1,.RLST,"",.HL)
- +41 IF 'RLST
- SET ERROR=RLST
- DO START^RGHLLOG()
- DO EXC^RGHLLOG(220,"Error Generating HL7 msg for Approve/Not Approved CMOR Request # "_REQNO,$PIECE(N0,"^",4))
- +42 QUIT
- +43 ;
- IN ;
- +1 ; Processing approve/not approve msg to update Request in 984.9 file
- +2 NEW DFN,ENT,XMY,XMDUZ,XMTEXT,MPIF,XMSUB,FSITE,CMOR,PHONE,RESULT,REVIEWER,COMMENTS,NDATE,II,ICN
- +3 SET (HLQUIT,ID,COMMENTS,PHONE,REVIEWER)=""
- +4 FOR II=1:1
- XECUTE HLNEXT
- if HLQUIT'>0
- QUIT
- Begin DoDot:1
- +5 IF $PIECE(HLNODE,HL("FS"),1)="NTE"
- Begin DoDot:2
- +6 SET ID=$PIECE(HLNODE,HL("FS"),7)
- SET RESULT=$PIECE(HLNODE,HL("FS"),6)
- +7 SET PHONE=$PIECE(HLNODE,HL("FS"),4)
- +8 SET COMMENTS=$PIECE(HLNODE,HL("FS"),5)
- End DoDot:2
- +9 IF $PIECE(HLNODE,HL("FS"),1)="EVN"
- Begin DoDot:2
- +10 SET NDATE=$PIECE(HLNODE,HL("FS"),3)
- +11 SET REVIEWER=$PIECE(HLNODE,HL("FS"),6)
- End DoDot:2
- +12 IF $PIECE(HLNODE,HL("FS"),1)="PID"
- Begin DoDot:2
- +13 SET ICN=+$PIECE(HLNODE,HL("FS"),3)
- End DoDot:2
- End DoDot:1
- +14 SET ENT=$ORDER(^MPIF(984.9,"B",ID,0))
- +15 ;; CHANGE FOR NOIS MAD-0900-42526
- +16 IF ENT=""
- Begin DoDot:1
- +17 DO START^RGHLLOG()
- +18 DO EXC^RGHLLOG(210,"CMOR Request # "_ID_" Does Not Exist CMORs may be out of sync for ICN "_ICN_". HL7 msg# "_HL("MID"))
- +19 DO STOP^RGHLLOG()
- End DoDot:1
- +20 if ENT=""
- QUIT
- +21 if '$DATA(^MPIF(984.9,ENT,0))
- QUIT
- +22 SET DFN=$PIECE($GET(^MPIF(984.9,ENT,0)),"^",4)
- SET FSITE=$PIECE($GET(^(0)),"^",7)
- +23 SET DIC="^DIC(4,"
- SET DIC(0)="MXNZ"
- SET X=FSITE
- DO ^DIC
- +24 IF $GET(Y)>0
- SET FSITE=$PIECE(Y,"^",2)
- +25 KILL Y,X,DIC
- +26 SET DIE="^MPIF(984.9,"
- SET DA=ENT
- SET DR="[MPIF RESULT INCOMING]"
- DO ^DIE
- KILL DIE,DA,DR
- +27 SET XMDUZ="MPI VISTA Package"
- +28 SET XMSUB="Request "_ID_" is "_$SELECT(RESULT=4:"approved",1:"disapproved")
- +29 NEW REQR
- SET REQR=$PIECE($GET(^MPIF(984.9,ENT,0)),"^",2)
- IF REQR=""
- SET REQR="AUTO"
- +30 SET XMY(REQR)=""
- SET XMTEXT="MPIF(1,"
- +31 SET MPIF(1,1)=FSITE_" received CMOR request for "_$PIECE($GET(^DPT(+$PIECE(^MPIF(984.9,ENT,0),"^",4),0)),"^")_" ("_$EXTRACT($PIECE(^(0),"^",9),6,9)_")."
- +32 SET MPIF(1,2)=XMSUB_"."
- +33 SET MPIF(1,3)="Processed by: "_$GET(REVIEWER)
- +34 SET MPIF(1,4)="Phone: "_$GET(PHONE)
- +35 SET MPIF(1,5)="Comments: "_$GET(COMMENTS)
- +36 DO ^XMD
- +37 QUIT