| 1 | MPIFEXT2 ;SFCIO/CMC-EXTENDED PDAT - RPC ;26 JUN 01
 | 
|---|
| 2 |  ;;1.0; MASTER PATIENT INDEX VISTA ;**20,28**;30 Apr 99
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ;Integration Agreements Utilized:
 | 
|---|
| 5 |  ;  ^DPT( - #2070
 | 
|---|
| 6 |  ;  NOTICE^DGSEC4 - #3027
 | 
|---|
| 7 |  ;  PTSEC^DGSEC4 - #3027
 | 
|---|
| 8 |  ;  D GETS^DIQ(2,DFN_",",".097","I","MPIFAR") - #3581
 | 
|---|
| 9 |  ;
 | 
|---|
| 10 | PATINFO(RETN,ICN,SSN,RPC) ;get patient info array
 | 
|---|
| 11 |  N MPINODE,MPIFAR,DFN,TICN,TSSN,TEXT,CNTD,PICN,XX,X,XXX
 | 
|---|
| 12 |  I $G(ICN)=""&($G(SSN)="") S RETN="-1^NO ICN OR SSN PASSED" Q
 | 
|---|
| 13 |  S TICN=ICN,TSSN=SSN,TEXT=""
 | 
|---|
| 14 |  I $G(SSN)'="" D
 | 
|---|
| 15 |  .S ICN=$$GETICNS^MPIF002(SSN)
 | 
|---|
| 16 |  .I RPC=1 S TEXT="MPI(""SSN USED"")="
 | 
|---|
| 17 |  .S RETN(1,"SSN USED")=TEXT_""""_SSN_""""
 | 
|---|
| 18 |  .; possible to have multiple entries with same SSN
 | 
|---|
| 19 |  S PICN=ICN,CNTD=0
 | 
|---|
| 20 |  F XX=1:1 S ICN=$P(PICN,"^",XX) Q:ICN=""  D
 | 
|---|
| 21 |  .S DFN=$$GETDFN^MPIF001(+ICN),CNTD=CNTD+1
 | 
|---|
| 22 |  .I +DFN=-1 S RETN(XX)="-1^NO SUCH ICN "_ICN Q
 | 
|---|
| 23 |  .I '$D(^DPT(DFN)) S RETN(XX)="-1^BAD AICN X-REF, PT FILE ENTRY DOESN'T EXIST DFN= "_DFN_" ICN= "_ICN Q
 | 
|---|
| 24 |  .; check if this data can be returned and if sensative pt bulletin needed
 | 
|---|
| 25 |  .N SENS D PTSEC^DGSEC4(.SENS,DFN,1,"Remote Procedure from MPI^RPC frm MPI ext PDAT infor")
 | 
|---|
| 26 |  .N NOT D NOTICE^DGSEC4(.NOT,DFN,"Remote Procedure from MPI^RPC frm MPI ext PDAT infor")
 | 
|---|
| 27 |  .I SENS(1)=3!(SENS(1)=4)!(SENS(1)=-1) S RETN(XX)="-1^SENSATIVE PT ISSUE "_SENS(2)_" DFN= "_DFN_" ICN= "_ICN Q
 | 
|---|
| 28 |  .I RPC=1 S TEXT="MPI("_DFN_",""DFN"")="
 | 
|---|
| 29 |  .S RETN(XX,"DFN")=TEXT_""""_DFN_""""
 | 
|---|
| 30 |  .S MPINODE=$$MPINODE^MPIFAPI(DFN)
 | 
|---|
| 31 |  .D GETS^DIQ(2,DFN_",",".097","I","MPIFAR")
 | 
|---|
| 32 |  .I RPC=1 S TEXT="MPI("_DFN_",""ENTERED PT FILE"")="
 | 
|---|
| 33 |  .S RETN(DFN,"ENTERED PT FILE")=TEXT_""""_$$FMTE^XLFDT(MPIFAR(2,DFN_",",.097,"I"),5)_""""
 | 
|---|
| 34 |  .K VADM
 | 
|---|
| 35 |  .D DEM^VADPT
 | 
|---|
| 36 |  .F X=1,2,3,5,6,11,12 D
 | 
|---|
| 37 |  ..I X=1 D
 | 
|---|
| 38 |  ...I RPC=1 S TEXT="MPI("_DFN_",""NAME"")="
 | 
|---|
| 39 |  ...S RETN(DFN,"NAME")=TEXT_""""_VADM(1)_""""
 | 
|---|
| 40 |  ..I X=2 D
 | 
|---|
| 41 |  ...I RPC=1 S TEXT="MPI("_DFN_",""SEX"")="
 | 
|---|
| 42 |  ...S RETN(DFN,"SEX")=TEXT_""""_VADM(5)_""""
 | 
|---|
| 43 |  ..I X=3 D
 | 
|---|
| 44 |  ...I RPC=1 S TEXT="MPI("_DFN_",""DOB"")="
 | 
|---|
| 45 |  ...S RETN(DFN,"DOB")=TEXT_""""_VADM(3)_""""
 | 
|---|
| 46 |  ..I X=12 D
 | 
|---|
| 47 |  ..I RPC=1 S TEXT="MPI("_DFN_",""RACE"","
 | 
|---|
| 48 |  ..S XXX=0
 | 
|---|
| 49 |  ..I VADM(12)=0 S RETN(DFN,"RACE",0)=TEXT_XXX_")="_"""NONE""" Q
 | 
|---|
| 50 |  ..I VADM(12)>0 F  S XXX=$O(VADM(12,XXX)) Q:XXX=""  S RETN(DFN,"RACE",XXX)=TEXT_XXX_")="_""""_$P($G(VADM(12,XXX)),"^",2)_""""
 | 
|---|
| 51 |  ..I X=2 D
 | 
|---|
| 52 |  ...I RPC=1 S TEXT="MPI("_DFN_",""SSN"")="
 | 
|---|
| 53 |  ...S RETN(DFN,"SSN")=TEXT_""""_VADM(2)_""""
 | 
|---|
| 54 |  ..I X=6 D
 | 
|---|
| 55 |  ...I RPC=1 S TEXT="MPI("_DFN_",""DOD"")="
 | 
|---|
| 56 |  ...S RETN(DFN,"DOD")=TEXT_""""_$$FMTE^XLFDT($P(VADM(6),"^"))_""""
 | 
|---|
| 57 |  ..I X=11 D
 | 
|---|
| 58 |  ..I RPC=1 S TEXT="MPI("_DFN_",""ETHNIC"")="
 | 
|---|
| 59 |  ..I VADM(11)=0 S RETN(DFN,"ETHNIC")=TEXT_"""NONE""" Q
 | 
|---|
| 60 |  ..I VADM(11)=1 S RETN(DFN,"ETHNIC")=TEXT_""""_$P($G(VADM(11,1)),"^",2)_""""
 | 
|---|
| 61 |  .K VAPA,VADM
 | 
|---|
| 62 |  .D ADD^VADPT
 | 
|---|
| 63 |  .F X=1,2,3,4,5,6,8,11 D
 | 
|---|
| 64 |  ..I X=1 D
 | 
|---|
| 65 |  ...I RPC=1 S TEXT="MPI("_DFN_",""ADDRESS"")="
 | 
|---|
| 66 |  ...S RETN(DFN,"ADDRESS 1")=TEXT_""""_VAPA(1)_""""
 | 
|---|
| 67 |  ..I X=6 D
 | 
|---|
| 68 |  ...I RPC=1 S TEXT="MPI("_DFN_",""ZIP"")="
 | 
|---|
| 69 |  ...S RETN(DFN,"ZIP")=TEXT_""""_VAPA(6)_""""
 | 
|---|
| 70 |  ..I X=2 D
 | 
|---|
| 71 |  ...I RPC=1 S TEXT="MPI("_DFN_",""ADDRESS 2"")="
 | 
|---|
| 72 |  ...S RETN(DFN,"ADDRESS 2")=TEXT_""""_VAPA(2)_""""
 | 
|---|
| 73 |  ..I X=3 D
 | 
|---|
| 74 |  ...I RPC=1 S TEXT="MPI("_DFN_",""ADDRESS 3"")="
 | 
|---|
| 75 |  ...S RETN(DFN,"ADDRESS 3")=TEXT_""""_VAPA(3)_""""
 | 
|---|
| 76 |  ..I X=5 D
 | 
|---|
| 77 |  ...I RPC=1 S TEXT="MPI("_DFN_",""STATE"")="
 | 
|---|
| 78 |  ...S RETN(DFN,"STATE")=TEXT_""""_$P(VAPA(5),"^",2)_""""
 | 
|---|
| 79 |  ..I X=4 D
 | 
|---|
| 80 |  ...I RPC=1 S TEXT="MPI("_DFN_",""CITY"")="
 | 
|---|
| 81 |  ...S RETN(DFN,"CITY")=TEXT_""""_VAPA(4)_""""
 | 
|---|
| 82 |  ..I X=8 D
 | 
|---|
| 83 |  ...I RPC=1 S TEXT="MPI("_DFN_",""HOME PHONE #"")="
 | 
|---|
| 84 |  ...S RETN(DFN,"HOME PHONE #")=TEXT_""""_VAPA(8)_""""
 | 
|---|
| 85 |  .K VAPA,VAEL
 | 
|---|
| 86 |  .D ELIG^VADPT
 | 
|---|
| 87 |  .I VAEL(4)=1 S VAEL("VET Y/N")="YES"
 | 
|---|
| 88 |  .I VAEL(4)'=1 S VAEL("VET Y/N")="NO"
 | 
|---|
| 89 |  .F X=1,4,7 D
 | 
|---|
| 90 |  ..I X=7 D
 | 
|---|
| 91 |  ...I RPC=1 S TEXT="MPI("_DFN_",""CLAIM #"")="
 | 
|---|
| 92 |  ...S RETN(DFN,"CLAIM #")=TEXT_""""_VAEL(7)_""""
 | 
|---|
| 93 |  ..I X=4 D
 | 
|---|
| 94 |  ...I RPC=1 S TEXT="MPI("_DFN_",""VET Y/N"")="
 | 
|---|
| 95 |  ...S RETN(DFN,"VET Y/N")=TEXT_""""_VAEL("VET Y/N")_""""
 | 
|---|
| 96 |  ..I X=1 D
 | 
|---|
| 97 |  ...I RPC=1 S TEXT="MPI("_DFN_",""PRIM ELIG"")="
 | 
|---|
| 98 |  ...S RETN(DFN,"PRIM ELIG")=TEXT_""""_$P(VAEL(1),"^",2)_""""
 | 
|---|
| 99 |  .K VAEL,VAOA
 | 
|---|
| 100 |  .D OAD^VADPT
 | 
|---|
| 101 |  .I RPC=1 S TEXT="MPI("_DFN_",""NOK NAME"")="
 | 
|---|
| 102 |  .S RETN(DFN,"NOK NAME")=TEXT_""""_VAOA(9)_""""
 | 
|---|
| 103 |  .K VAOA
 | 
|---|
| 104 |  .S VAOA("A")=1
 | 
|---|
| 105 |  .D OAD^VADPT
 | 
|---|
| 106 |  .I RPC=1 S TEXT="MPI("_DFN_",""EMERGENCY POC"")="
 | 
|---|
| 107 |  .S RETN(DFN,"EMERGENCY POC")=TEXT_""""_VAOA(9)_""""
 | 
|---|
| 108 |  .K VAOA
 | 
|---|
| 109 |  .S VAOA("A")=2
 | 
|---|
| 110 |  .D OAD^VADPT
 | 
|---|
| 111 |  .I RPC=1 S TEXT="MPI("_DFN_",""DESIGNEE"")="
 | 
|---|
| 112 |  .S RETN(DFN,"DESIGNEE")=TEXT_""""_VAOA(9)_""""
 | 
|---|
| 113 |  .K VAOA,VAPD
 | 
|---|
| 114 |  .D OPD^VADPT
 | 
|---|
| 115 |  .F X=1,2,3,4,5 D
 | 
|---|
| 116 |  ..I X=5 D
 | 
|---|
| 117 |  ...I RPC=1 S TEXT="MPI("_DFN_",""MMN"")="
 | 
|---|
| 118 |  ...S RETN(DFN,"MMN")=TEXT_""""_VAPD(5)_""""
 | 
|---|
| 119 |  ..I X=1 D
 | 
|---|
| 120 |  ...I RPC=1 S TEXT="MPI("_DFN_",""POBC"")="
 | 
|---|
| 121 |  ...S RETN(DFN,"POBC")=TEXT_""""_VAPD(1)_""""
 | 
|---|
| 122 |  ..I X=2 D
 | 
|---|
| 123 |  ...I RPC=1 S TEXT="MPI("_DFN_",""POBS"")="
 | 
|---|
| 124 |  ...S RETN(DFN,"POBS")=TEXT_""""_$P(VAPD(2),"^",2)_""""
 | 
|---|
| 125 |  ..I X=3 D
 | 
|---|
| 126 |  ...I RPC=1 S TEXT="MPI("_DFN_",""FATHER'S NAME"")="
 | 
|---|
| 127 |  ...S RETN(DFN,"FATHER'S NAME")=TEXT_""""_VAPD(3)_""""
 | 
|---|
| 128 |  ..I X=4 D
 | 
|---|
| 129 |  ...I RPC=1 S TEXT="MPI("_DFN_",""MOTHER'S NAME"")="
 | 
|---|
| 130 |  ...S RETN(DFN,"MOTHER'S NAME")=TEXT_""""_VAPD(4)_""""
 | 
|---|
| 131 |  .K VAPD,VASV
 | 
|---|
| 132 |  .D SVC^VADPT
 | 
|---|
| 133 |  .I RPC=1 S TEXT="MPI("_DFN_",""POW STATUS"")="
 | 
|---|
| 134 |  .I VASV(4)=1 S VASV(4)="YES"
 | 
|---|
| 135 |  .I VASV(4)=0 S VASV(4)="NO"
 | 
|---|
| 136 |  .S RETN(DFN,"POW STATUS")=TEXT_""""_VASV(4)_""""
 | 
|---|
| 137 |  .I RPC=1 S TEXT="MPI("_DFN_",""LAST SRV BRANCH"")="
 | 
|---|
| 138 |  .S RETN(DFN,"LAST SRV BRANCH")=TEXT_""""_$P(VASV(6,1),"^",2)_""""
 | 
|---|
| 139 |  .I RPC=1 S TEXT="MPI("_DFN_",""LAST SRV #"")="
 | 
|---|
| 140 |  .S RETN(DFN,"LAST SRV #")=TEXT_""""_VASV(6,2)_""""
 | 
|---|
| 141 |  .I RPC=1 S TEXT="MPI("_DFN_",""LAST SRV ENT DT"")="
 | 
|---|
| 142 |  .S RETN(DFN,"LAST SRV ENT DT")=TEXT_""""_$$FMTE^XLFDT($P(VASV(6,4),"^"))_""""
 | 
|---|
| 143 |  .I RPC=1 S TEXT="MPI("_DFN_",""LAST SRV SEP DT"")="
 | 
|---|
| 144 |  .S RETN(DFN,"LAST SRV SEP DT")=TEXT_""""_$$FMTE^XLFDT($P(VASV(6,5),"^"))_""""
 | 
|---|
| 145 |  .K VASV
 | 
|---|
| 146 |  .N MPINODE
 | 
|---|
| 147 |  .S MPINODE=$$MPINODE^MPIFAPI(DFN)
 | 
|---|
| 148 |  .I RPC=1 S TEXT="MPI("_DFN_",""SUB CONTROL #"")="
 | 
|---|
| 149 |  .S RETN(DFN,"SUB CONTROL #")=TEXT_""""_$P(MPINODE,"^",5)_""""
 | 
|---|
| 150 |  .I RPC=1 S TEXT="MPI("_DFN_",""SCORE"")="
 | 
|---|
| 151 |  .S RETN(DFN,"SCORE")=TEXT_""""_$P(MPINODE,"^",6)_""""
 | 
|---|
| 152 |  .I RPC=1 S TEXT="MPI("_DFN_",""SCORE DATE"")="
 | 
|---|
| 153 |  .S RETN(DFN,"SCORE DATE")=TEXT_""""_$P(MPINODE,"^",7)_""""
 | 
|---|
| 154 |  .I RPC=1 S TEXT="MPI("_DFN_",""LOCAL ICN"")="
 | 
|---|
| 155 |  .I $P(MPINODE,"^",4)=1 S RETN(DFN,"LOCAL ICN")=TEXT_"""YES"""
 | 
|---|
| 156 |  .I $P(MPINODE,"^",4)="" S RETN(DFN,"LOCAL ICN")=TEXT_"""NO"""
 | 
|---|
| 157 |  .N RESULT,SENS
 | 
|---|
| 158 |  .S SENS="NO"
 | 
|---|
| 159 |  .D PTSEC^DGSEC4(.RESULT,DFN)
 | 
|---|
| 160 |  .I RESULT(1)>0 S SENS="YES"
 | 
|---|
| 161 |  .I RPC=1 S TEXT="MPI("_DFN_",""SENSATIVE PT"")="
 | 
|---|
| 162 |  .S RETN(DFN,"SENSATIVE PT")=TEXT_""""_SENS_""""
 | 
|---|
| 163 |  .D ALIAS^MPIFEXT3(.RETN,DFN,RPC)
 | 
|---|
| 164 |  .D CMORCH^MPIFEXT3(.RETN,DFN,RPC)
 | 
|---|
| 165 |  .D TFLIST^MPIFEXT3(.RETN,DFN,RPC)
 | 
|---|
| 166 |  .D SUBLST^MPIFEXT3(.RETN,DFN,RPC)
 | 
|---|
| 167 |  D ICNSTAT^MPIFRPC(.RETN,TICN,TSSN,RPC)
 | 
|---|
| 168 |  K VA,VAERR
 | 
|---|
| 169 |  Q
 | 
|---|
| 170 |  ;
 | 
|---|