[1147] | 1 | BMXRPC4 ; IHS/OIT/HMW - BMX REMOTE PROCEDURE CALLS ;
|
---|
| 2 | ;;4.1000;BMX;;Apr 17, 2011
|
---|
| 3 | ;
|
---|
| 4 | PTINFORS(BMXY,BMXIEN) ;EP Patient Info Recordset
|
---|
| 5 | ;
|
---|
| 6 | N BMXDPT,BMXZ,BMXDLIM,BMXXX,BMXRET,BMXAGE,BMXNEXT,BMXSEX,BMXERR,BMXHRN
|
---|
| 7 | S BMXDLIM="^",BMXERR=""
|
---|
| 8 | S BMXRET="T00030NAME^T00030HRN^T00030SSN^D00030DOB^T00030IEN^T00020AGE^T00080NEXT_APPT^T00010SEX"_$C(30)
|
---|
| 9 | I '$D(DUZ(2)) S BMXY=BMXRET_$C(31)_"No DUZ2" Q
|
---|
| 10 | I +$G(DUZ) D
|
---|
| 11 | . S ^DISV(DUZ,"^AUPNPAT(")=BMXIEN
|
---|
| 12 | . S ^DISV(DUZ,"^DPT(")=BMXIEN
|
---|
| 13 | I '$D(^DPT(BMXIEN)) S BMXY=BMXRET_$C(31)_"No such patient" Q
|
---|
| 14 | S BMXDPT=$G(^DPT(BMXIEN,0))
|
---|
| 15 | S BMXZ=$P(BMXDPT,U) ;NAME
|
---|
| 16 | ;S $P(BMXZ,BMXDLIM,2)=$P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,2) ;CHART
|
---|
| 17 | S BMXHRN=$P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,2) ;CHART
|
---|
| 18 | ;I BMXHRN="" Q ;NO CHART AT THIS DUZ2
|
---|
| 19 | I $P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,3) S BMXHRN=BMXHRN_"(*)"
|
---|
| 20 | S $P(BMXZ,BMXDLIM,2)=BMXHRN
|
---|
| 21 | ;
|
---|
| 22 | S $P(BMXZ,BMXDLIM,3)=$P(BMXDPT,U,9) ;SSN
|
---|
| 23 | S Y=$P(BMXDPT,U,3) X ^DD("DD")
|
---|
| 24 | S $P(BMXZ,BMXDLIM,4)=Y ;DOB
|
---|
| 25 | S $P(BMXZ,BMXDLIM,5)=BMXIEN
|
---|
| 26 | S BMXAGE=$$AGEF^BMXUTL1(BMXIEN)
|
---|
| 27 | S $P(BMXZ,BMXDLIM,6)=BMXAGE
|
---|
| 28 | S BMXNEXT=$$NEXTAPPT^BMXUTL2(BMXIEN)
|
---|
| 29 | S $P(BMXZ,BMXDLIM,7)=BMXNEXT
|
---|
| 30 | S BMXSEX=$$SEXW^BMXUTL1(BMXIEN)
|
---|
| 31 | S $P(BMXZ,BMXDLIM,8)=BMXSEX
|
---|
| 32 | S BMXRET=BMXRET_BMXZ
|
---|
| 33 | S BMXY=BMXRET_$C(30)_$C(31)_BMXERR
|
---|
| 34 | Q
|
---|
| 35 | ;
|
---|
| 36 | PTLOOKRS(BMXY,BMXP,BMXC) ;EP Patient Lookup
|
---|
| 37 | ;
|
---|
| 38 | ;Find up to BMXC patients matching BMXP*
|
---|
| 39 | ;Supports DOB Lookup, SSN Lookup
|
---|
| 40 | ;
|
---|
| 41 | ;S ^HW("PTLOOK","INPUT")=BMXP
|
---|
| 42 | ;S ^HW("PTLOOK","DUZ2")=$G(DUZ(2))
|
---|
| 43 | S BMXP=$TR(BMXP,$C(13),"")
|
---|
| 44 | S BMXP=$TR(BMXP,$C(10),"")
|
---|
| 45 | S BMXP=$TR(BMXP,$C(9),"")
|
---|
| 46 | S:BMXC="" BMXC=10
|
---|
| 47 | N BMXHRN,BMXZ,BMXDLIM,BMXRET
|
---|
| 48 | S BMXDLIM="^"
|
---|
| 49 | S BMXRET="T00030NAME^T00030HRN^T00030SSN^D00030DOB^T00030IEN"_$C(30)
|
---|
| 50 | I '+$G(DUZ) S BMXY=BMXRET_$C(31) Q
|
---|
| 51 | I '$D(DUZ(2)) S BMXY=BMXRET_$C(31) Q
|
---|
| 52 | DOB ;DOB Lookup
|
---|
| 53 | I +DUZ(2),((BMXP?1.2N1"/"1.2N1"/"1.4N)!(BMXP?1.2N1" "1.2N1" "1.4N)!(BMXP?1.2N1"-"1.2N1"-"1.4N)) D S BMXY=BMXRET_$C(31) Q
|
---|
| 54 | . S X=BMXP S %DT="P" D ^%DT S BMXP=Y Q:'+Y
|
---|
| 55 | . Q:'$D(^DPT("ADOB",BMXP))
|
---|
| 56 | . S BMXIEN=0,BMXXX=1 F S BMXIEN=$O(^DPT("ADOB",BMXP,BMXIEN)) Q:'+BMXIEN D
|
---|
| 57 | . . Q:'$D(^DPT(BMXIEN,0))
|
---|
| 58 | . . S BMXDPT=$G(^DPT(BMXIEN,0))
|
---|
| 59 | . . S BMXZ=$P(BMXDPT,U) ;NAME
|
---|
| 60 | . . ;S $P(BMXZ,BMXDLIM,2)=$P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,2) ;CHART
|
---|
| 61 | . . S BMXHRN=$P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,2) ;CHART
|
---|
| 62 | . . I BMXHRN="" Q ;NO CHART AT THIS DUZ2
|
---|
| 63 | . . I $P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,3) S BMXHRN=BMXHRN_"(*)"
|
---|
| 64 | . . S $P(BMXZ,BMXDLIM,2)=BMXHRN
|
---|
| 65 | . . ;
|
---|
| 66 | . . S $P(BMXZ,BMXDLIM,3)=$P(BMXDPT,U,9) ;SSN
|
---|
| 67 | . . S Y=$P(BMXDPT,U,3) X ^DD("DD")
|
---|
| 68 | . . S $P(BMXZ,BMXDLIM,4)=Y ;DOB
|
---|
| 69 | . . S $P(BMXZ,BMXDLIM,5)=BMXIEN
|
---|
| 70 | . . S BMXXX=BMXXX+1
|
---|
| 71 | . . ;S $P(BMXRET,$C(30),BMXXX)=BMXZ
|
---|
| 72 | . . S BMXRET=BMXRET_BMXZ_$C(30)
|
---|
| 73 | . . Q
|
---|
| 74 | . Q
|
---|
| 75 | ;
|
---|
| 76 | ;Chart# Lookup
|
---|
| 77 | I +DUZ(2),BMXP]"",$D(^AUPNPAT("D",BMXP)) D S BMXY=BMXRET_$C(30)_$C(31) Q
|
---|
| 78 | . S BMXIEN=0 F S BMXIEN=$O(^AUPNPAT("D",BMXP,BMXIEN)) Q:'+BMXIEN I $D(^AUPNPAT("D",BMXP,BMXIEN,DUZ(2))) D Q
|
---|
| 79 | . . Q:'$D(^DPT(BMXIEN,0))
|
---|
| 80 | . . S BMXDPT=$G(^DPT(BMXIEN,0))
|
---|
| 81 | . . S BMXZ=$P(BMXDPT,U) ;NAME
|
---|
| 82 | . . ;S $P(BMXZ,BMXDLIM,2)=BMXP ;CHART
|
---|
| 83 | . . S BMXHRN=BMXP ;CHART
|
---|
| 84 | . . I $D(^AUPNPAT(BMXIEN,41,DUZ(2),0)),$P(^(0),U,3) S BMXHRN=BMXHRN_"(*)"
|
---|
| 85 | . . S $P(BMXZ,BMXDLIM,2)=BMXHRN
|
---|
| 86 | . . S $P(BMXZ,BMXDLIM,3)=$P(BMXDPT,U,9) ;SSN
|
---|
| 87 | . . S Y=$P(BMXDPT,U,3) X ^DD("DD")
|
---|
| 88 | . . S $P(BMXZ,BMXDLIM,4)=Y ;DOB
|
---|
| 89 | . . S $P(BMXZ,BMXDLIM,5)=BMXIEN
|
---|
| 90 | . . S $P(BMXRET,$C(30),2)=BMXZ
|
---|
| 91 | . . Q
|
---|
| 92 | . Q
|
---|
| 93 | ;
|
---|
| 94 | ;SSN Lookup
|
---|
| 95 | I (BMXP?9N)!(BMXP?3N1"-"2N1"-"4N),$D(^DPT("SSN",BMXP)) D S BMXY=BMXRET_$C(30)_$C(31) Q
|
---|
| 96 | . S BMXIEN=0 F S BMXIEN=$O(^DPT("SSN",BMXP,BMXIEN)) Q:'+BMXIEN D Q
|
---|
| 97 | . . Q:'$D(^DPT(BMXIEN,0))
|
---|
| 98 | . . S BMXDPT=$G(^DPT(BMXIEN,0))
|
---|
| 99 | . . S BMXZ=$P(BMXDPT,U) ;NAME
|
---|
| 100 | . . S BMXHRN=$P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,2) ;CHART
|
---|
| 101 | . . I BMXHRN="" Q ;NO CHART AT THIS DUZ2
|
---|
| 102 | . . I $P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,3) S BMXHRN=BMXHRN_"(*)"
|
---|
| 103 | . . S $P(BMXZ,BMXDLIM,2)=BMXHRN
|
---|
| 104 | . . S $P(BMXZ,BMXDLIM,3)=$P(BMXDPT,U,9) ;SSN
|
---|
| 105 | . . S Y=$P(BMXDPT,U,3) X ^DD("DD")
|
---|
| 106 | . . S $P(BMXZ,BMXDLIM,4)=Y ;DOB
|
---|
| 107 | . . S $P(BMXZ,BMXDLIM,5)=BMXIEN
|
---|
| 108 | . . S $P(BMXRET,$C(30),2)=BMXZ
|
---|
| 109 | . . Q
|
---|
| 110 | . Q
|
---|
| 111 | ;
|
---|
| 112 | S BMXFILE=9000001
|
---|
| 113 | S BMXIENS=""
|
---|
| 114 | S BMXFLDS=".01"
|
---|
| 115 | S BMXFLAGS="M"
|
---|
| 116 | S BMXVALUE=BMXP
|
---|
| 117 | S BMXNMBR=BMXC
|
---|
| 118 | S BMXIXS=""
|
---|
| 119 | S BMXSCRN=$S(+DUZ(2):"I $D(^AUPNPAT(Y,41,DUZ(2),0))",1:"")
|
---|
| 120 | ;I BMXSCRN]"" S DIC("S")=BMXSCRN
|
---|
| 121 | ;S BMXSCRN="I 0"
|
---|
| 122 | S BMXIDEN=""
|
---|
| 123 | S BMXTARG="BMXRSLT"
|
---|
| 124 | S BMXMSG=""
|
---|
| 125 | D FIND^DIC(BMXFILE,BMXIENS,BMXFLDS,BMXFLAGS,BMXVALUE,BMXNMBR,BMXIXS,BMXSCRN,BMXIDEN,BMXTARG,BMXMSG)
|
---|
| 126 | ;S BMXRET=""
|
---|
| 127 | ;B
|
---|
| 128 | I '+$G(BMXRSLT("DILIST",0)) S BMXY=BMXRET_$C(31) Q
|
---|
| 129 | F BMXX=1:1:$P(BMXRSLT("DILIST",0),U) D
|
---|
| 130 | . ;B
|
---|
| 131 | . S BMXIEN=BMXRSLT("DILIST",2,BMXX)
|
---|
| 132 | . S BMXZ=BMXRSLT("DILIST","ID",BMXX,.01) ;NAME
|
---|
| 133 | . ;S $P(BMXZ,BMXDLIM,2)=$P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,2) ;CHART
|
---|
| 134 | . S BMXHRN=$P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,2) ;CHART
|
---|
| 135 | . I BMXHRN="" Q ;NO CHART AT THIS DUZ2
|
---|
| 136 | . I $P($G(^AUPNPAT(BMXIEN,41,DUZ(2),0)),U,3) S BMXHRN=BMXHRN_"(*)"
|
---|
| 137 | . S $P(BMXZ,BMXDLIM,2)=BMXHRN
|
---|
| 138 | . S BMXDPT=$G(^DPT(BMXIEN,0))
|
---|
| 139 | . S $P(BMXZ,BMXDLIM,3)=$P(BMXDPT,U,9) ;SSN
|
---|
| 140 | . S Y=$P(BMXDPT,U,3) X ^DD("DD")
|
---|
| 141 | . S $P(BMXZ,BMXDLIM,4)=Y ;DOB
|
---|
| 142 | . S $P(BMXZ,BMXDLIM,5)=BMXIEN
|
---|
| 143 | . S $P(BMXRET,$C(30),BMXX+1)=BMXZ
|
---|
| 144 | . Q
|
---|
| 145 | ;K BMXRSLT
|
---|
| 146 | S BMXY=BMXRET_$C(30)_$C(31)
|
---|
| 147 | Q
|
---|
| 148 | ZZZ ;
|
---|