| 1 | MPIFEDIT ;BHM/RGY-Request a CMOR for patient ;FEB 20, 1998
 | 
|---|
| 2 |  ;;1.0; MASTER PATIENT INDEX VISTA ;**11,22,30,34**;30 Apr 99
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ; Integration Agreements Utilized:
 | 
|---|
| 5 |  ;
 | 
|---|
| 6 |  ;   EXC^RGHLLOG     IA #2796
 | 
|---|
| 7 |  ;   START^RGHLLOG   IA #2796
 | 
|---|
| 8 |  ;   STOP^RGHLLOG    IA #2796
 | 
|---|
| 9 |  ;   $$EN^VAFCPID    IA #3015
 | 
|---|
| 10 |  ;
 | 
|---|
| 11 | NEW ;
 | 
|---|
| 12 |  ;Entry point for option: MPIF NEW REQUEST - create a new request
 | 
|---|
| 13 |  ; to change CMOR.  No input or output variables.
 | 
|---|
| 14 |  ;
 | 
|---|
| 15 |  ;Only if the site is not the CMOR can this option be used
 | 
|---|
| 16 |  N DIC,X,Y,DTOUT,DUOUT,PAT
 | 
|---|
| 17 |  S DIC="^DPT(",DIC(0)="QEAMZ",DIC("A")="Select PATIENT: "
 | 
|---|
| 18 |  D ^DIC
 | 
|---|
| 19 |  Q:$D(DTOUT)!$D(DUOUT)!(Y=-1)
 | 
|---|
| 20 |  S PAT=+Y
 | 
|---|
| 21 |  I +$$GETICN^MPIF001(PAT)<0 W !!,"Patient doesn't have ICN, try again" G NEW
 | 
|---|
| 22 |  I $$GETVCCI^MPIF001(PAT)<0 W !!,"Patient doesn't have a CMOR, try again" G NEW
 | 
|---|
| 23 |  I $$GETVCCI^MPIF001(PAT)=$P($$SITE^VASITE(),"^",3) W !!,"You are the CMOR, to push the CMOR to another site use option: PUSH CMOR REQUEST" G NEW
 | 
|---|
| 24 |  ; CHECK IF ALREADY OPEN/PENDING REQUEST
 | 
|---|
| 25 |  N ENT,STOP
 | 
|---|
| 26 |  S ENT=0,STOP=0 F  S ENT=$O(^MPIF(984.9,"C",PAT,ENT)) Q:ENT=""!(STOP)  D
 | 
|---|
| 27 |  .I $P($G(^MPIF(984.9,ENT,0)),"^",6)<4 S STOP=1
 | 
|---|
| 28 |  I STOP W !!,"Already have request for this patient" G NEW
 | 
|---|
| 29 |  ;
 | 
|---|
| 30 |  N N0,PHONE,DA,DIE,DR,DIR,ERROR,DIK,Y,DIRUT,REQ,CMOR,MPIFREQ,CMORI
 | 
|---|
| 31 |  S DA=$$ADD^MPIFNEW()
 | 
|---|
| 32 |  S DIE="^MPIF(984.9,",DR=".04///`"_PAT D ^DIE
 | 
|---|
| 33 |  S REQ=$P($G(^MPIF(984.9,DA,0)),"^")
 | 
|---|
| 34 |  W !,"REQUEST NUMBER:",REQ
 | 
|---|
| 35 |  S CMOR=$$HL7CMOR^MPIF001($P($G(^MPIF(984.9,DA,0)),"^",4),"^")
 | 
|---|
| 36 |  ;station # ^ Station Name
 | 
|---|
| 37 |  S CMORI=$$IEN^XUAF4($P(CMOR,"^"))
 | 
|---|
| 38 |  W !,"*** Current CMOR: "_$P(CMOR,"^",2)_" ("_$P(CMOR,"^")_") ***"
 | 
|---|
| 39 |  S DIE="^MPIF(984.9,",DR=".07///`"_CMORI_";1.03///1;.09///`"_+$$SITE^VASITE() D ^DIE
 | 
|---|
| 40 |  ; ^ update site, type of action, and cmor after approval
 | 
|---|
| 41 |  ;
 | 
|---|
| 42 |  S REQ=DA
 | 
|---|
| 43 | EDIT I $D(DUZ) D
 | 
|---|
| 44 |  .S PHONE=$P($G(^MPIF(984.9,+$O(^MPIF(984.9,"AD",DUZ,""),-1),0)),"^",5)
 | 
|---|
| 45 |  .N DA,DIC,DIQ S DIQ="MPIFREQ",DR=".01",DIQ(0)="E",DIC="^VA(200,",DA=DUZ
 | 
|---|
| 46 |  .D EN^DIQ1
 | 
|---|
| 47 |  .S MPIFREQ=MPIFREQ(200,DUZ,.01,"E")
 | 
|---|
| 48 |  I '$D(DUZ) S (MPIFREQ,PHONE)=""
 | 
|---|
| 49 |  ;
 | 
|---|
| 50 | REASON S DIR("A")="Reason for Request",DIR("?")="Answer must be 3-60 characters in length.",DIR(0)="F^3:60" D ^DIR
 | 
|---|
| 51 |  I Y="" W !,"Answer must be 3-60 characters in length." G REASON
 | 
|---|
| 52 |  I Y="^" S DIK="^MPIF(984.9," D ^DIK W "... Request deleted" Q
 | 
|---|
| 53 |  S DIE="^MPIF(984.9,",DR="1.02///"_X D ^DIE
 | 
|---|
| 54 | REQNM S DIR("A")="Requestor's Name:",DIR("B")=MPIFREQ,DIR("?")="Answer must be a valid user",DIR(0)="P^200:EQZ" D ^DIR K DIR("B")
 | 
|---|
| 55 |  I Y="" W !,"Must pick valid user" G REQNM
 | 
|---|
| 56 |  I Y="^" S DIK="^MPIF(984.9," D ^DIK W "... Request deleted" Q
 | 
|---|
| 57 |  S DIE="^MPIF(984.9,",DR=".02///`"_+Y D ^DIE
 | 
|---|
| 58 | PHONE S DIR("A")="Requestor Phone:",DIR("B")=PHONE,DIR("?")="Answer must be 4-20 charaters in length.",DIR(0)="F" D ^DIR K DIR("B")
 | 
|---|
| 59 |  I Y="" W !,"Answer must be 4-20 charaters in length."  G PHONE
 | 
|---|
| 60 |  I Y="^" S DIK="^MPIF(984.9," D ^DIK W "... Request deleted" Q
 | 
|---|
| 61 |  S DIE="^MPIF(984.9,",DR=".05///"_X D ^DIE
 | 
|---|
| 62 |  I $$CHK^MPIFEDIT(DA) W !,"This request is missing required data." G EDIT
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 | APP S DIR("A")="Select Request Action (SEND/EDIT/DELETE)? ",DIR("B")="SEND",DIR(0)="SAO^SEND:SEND;EDIT:EDIT;DELETE:DELETE"
 | 
|---|
| 65 |  D ^DIR K DIR
 | 
|---|
| 66 |  I $E(Y)="D"!$D(DIRUT) D  Q
 | 
|---|
| 67 |  .S DIK="^MPIF(984.9," D ^DIK W "... Request deleted"
 | 
|---|
| 68 |  .Q
 | 
|---|
| 69 |  I $E(Y)="E" G REASON
 | 
|---|
| 70 |  S DR=".08////^S X=2;.06////^S X=2",DIE="^MPIF(984.9," D ^DIE W !,"... Request will be sent"
 | 
|---|
| 71 |  ;
 | 
|---|
| 72 |  I '$D(REQ) S REQ=DA
 | 
|---|
| 73 |  S N0=$G(^MPIF(984.9,REQ,0)),CNT=0
 | 
|---|
| 74 |  I N0="" S ERROR="Node for request #"_REQ_" is not defined" Q
 | 
|---|
| 75 |  S INST=$P($$SITE^VASITE(),"^",3)
 | 
|---|
| 76 |  N X,Y,DIC
 | 
|---|
| 77 |  S DIC="^VA(200,",DIC(0)="MZO",X="`"_+$P(N0,"^",2)
 | 
|---|
| 78 |  D ^DIC
 | 
|---|
| 79 |  I $G(Y)<1 S USER=""
 | 
|---|
| 80 |  I $G(Y)>0 S USER=$G(Y(0,0))
 | 
|---|
| 81 |  S REASON=$P($G(^MPIF(984.9,REQ,1)),"^",2)
 | 
|---|
| 82 |  S NDATE=$P(N0,"^",3)
 | 
|---|
| 83 |  S ICN=$$ICN^MPIFNQ(+$P(N0,"^",4))
 | 
|---|
| 84 |  S PHONE=$P(N0,"^",5)
 | 
|---|
| 85 |  S ID=$P(N0,"^")
 | 
|---|
| 86 |  K HLA
 | 
|---|
| 87 |  D INIT^HLFNC2("MPIF CMOR REQUEST",.HL)
 | 
|---|
| 88 |  I $O(HL(""))="" D START^RGHLLOG(),EXC^RGHLLOG(220,"Unable to setup HL7 for sending Change of CMOR Request # "_REQ_" FOR ICN= "_ICN,$P(N0,"^",4)),STOP^RGHLLOG() D RESET^MPIFREQ(REQ) Q
 | 
|---|
| 89 |  K HLL("LINKS") N MPILK
 | 
|---|
| 90 |  S MPILK=$$MPILINK^MPIFAPI ;routing all messages through the MPI
 | 
|---|
| 91 |  I +MPILK<0 D  Q
 | 
|---|
| 92 |  .D START^RGHLLOG()
 | 
|---|
| 93 |  .D EXC^RGHLLOG(224,"No MPI link found for Change CMOR Request # "_REQ_" for ICN="_ICN,$P(N0,"^",4))
 | 
|---|
| 94 |  .D STOP^RGHLLOG()
 | 
|---|
| 95 |  .D RESET^MPIFREQ(REQ)
 | 
|---|
| 96 |  .S ERROR="-1^No Links found"
 | 
|---|
| 97 |  ;Broadcast new CMOR to MPI which will send it out to all sites
 | 
|---|
| 98 |  S HLL("LINKS",1)="MPIF CMOR RESPONSE^"_MPILK
 | 
|---|
| 99 |  S CNT=CNT+1,PID=$$EN^VAFCPID(+$P(N0,"^",4),"1,2,4,5,6,7,8,11,12,13,14,16,17,19")
 | 
|---|
| 100 |  S HLA("HLS",CNT)=PID
 | 
|---|
| 101 |  S CNT=CNT+1
 | 
|---|
| 102 |  S CMOR=$P($$HL7CMOR^MPIF001($P($G(^MPIF(984.9,DA,0)),"^",4),"^"),"^")
 | 
|---|
| 103 |  S HLA("HLS",CNT)="NTE"_HL("FS")_HL("FS")_"P"_HL("FS")_PHONE_HL("FS")_REASON_HL("FS")_HL("FS")_ID_HL("FS")_INST_HL("FS")_HL("FS")_CMOR
 | 
|---|
| 104 |  S CNT=CNT+1
 | 
|---|
| 105 |  S HLA("HLS",CNT)="EVN"_HL("FS")_"A31"_HL("FS")_NDATE_HL("FS")_HL("FS")_""_HL("FS")_USER
 | 
|---|
| 106 |  N RLST
 | 
|---|
| 107 |  D GENERATE^HLMA("MPIF CMOR REQUEST","LM",1,.RLST,"",.HL)
 | 
|---|
| 108 |  I 'RLST D START^RGHLLOG(),EXC^RGHLLOG(220,"Unable to setup HL7 for sending Change of CMOR Request # "_REQ_" for ICN= "_ICN,$P(N0,"^",4)),STOP^RGHLLOG(),RESET^MPIFREQ(REQ)
 | 
|---|
| 109 |  K CNT,ICN,INST,NDATE,PID,REASON,RGL,USER,XX,ID
 | 
|---|
| 110 |  Q
 | 
|---|
| 111 |  ;
 | 
|---|
| 112 | CHK(IEN) ;
 | 
|---|
| 113 |  N N0,X,ERROR
 | 
|---|
| 114 |  S ERROR=0
 | 
|---|
| 115 |  S N0=$G(^MPIF(984.9,IEN,0))
 | 
|---|
| 116 |  F X=1:1:7 I $P(N0,"^",X)="" S ERROR=1 Q
 | 
|---|
| 117 |  I $P($G(^MPIF(984.9,IEN,1)),"^",2)="" S ERROR=1
 | 
|---|
| 118 |  Q ERROR
 | 
|---|