| [613] | 1 | MDRPCU ; HOIFO/DP - Object RPC Utilities ; [05-23-2003 10:16]
 | 
|---|
 | 2 |  ;;1.0;CLINICAL PROCEDURES;**4**;Apr 01, 2004;Build 3
 | 
|---|
 | 3 |  ; Integration Agreements:
 | 
|---|
 | 4 |  ; IA# 10039 [Supported] Ward Location File #42
 | 
|---|
 | 5 |  ; IA# 10035 [Supported] Access to DPT global
 | 
|---|
 | 6 |  ; IA# 10040 [Supported] Access to SC global
 | 
|---|
 | 7 |  ; IA# 1246 [Supported] Call to DGPMDDCF
 | 
|---|
 | 8 |  ; IA# 3266 [Subscription] $$DOB call to DPTLK1
 | 
|---|
 | 9 |  ; IA# 3267 [Subscription] Call to $$SSN of DPTLK1
 | 
|---|
 | 10 |  ; IA# 2692 [Subscription] Calls to ORQPTQ1
 | 
|---|
 | 11 |  ; IA# 3869 [Subscription] SDAMA202 calls
 | 
|---|
 | 12 |  ;
 | 
|---|
 | 13 | BADRPC(RPC,RTN,OPTION) ; [Procedure] When and RPC gets lost
 | 
|---|
 | 14 |  ; Input parameters
 | 
|---|
 | 15 |  ;  1. RPC [Literal/Required] No description
 | 
|---|
 | 16 |  ;  2. RTN [Literal/Required] No description
 | 
|---|
 | 17 |  ;  3. OPTION [Literal/Required] No description
 | 
|---|
 | 18 |  ;
 | 
|---|
 | 19 |  S @RESULTS@(0)="-1^Error calling RPC: "_RPC_" at "_OPTION_U_RTN
 | 
|---|
 | 20 |  Q
 | 
|---|
 | 21 |  ;
 | 
|---|
 | 22 | DUPS(MDD,MDIEN,MDX) ; [Function] Return boolean if dups exist
 | 
|---|
 | 23 |  N MDGBL
 | 
|---|
 | 24 |  S MDGBL=$$GET1^DID(+MDD,"","","GLOBAL NAME")
 | 
|---|
 | 25 |  S X=MDX X ^%ZOSF("UPPERCASE") S MDX=Y
 | 
|---|
 | 26 |  S Y=$O(@(MDGBL_"""UC"",MDX,"""")")) Q:Y&(Y'=MDIEN) 1
 | 
|---|
 | 27 |  S Y=$O(@(MDGBL_"""UC"",MDX,"""")"),-1) Q:Y&(Y'=MDIEN) 1
 | 
|---|
 | 28 |  Q 0
 | 
|---|
 | 29 |  ;
 | 
|---|
 | 30 | LOCK(RESULTS,DD,IENS) ; [Procedure] Lock a record
 | 
|---|
 | 31 |  L @("+"_$$ROOT^DILFD(DD,IENS)_(+IENS)_")"_":2")
 | 
|---|
 | 32 |  I $T S @RESULTS@(0)="1^Lock acquired"
 | 
|---|
 | 33 |  E  S @RESULTS@(0)="-1^Lock *NOT* acquired"
 | 
|---|
 | 34 |  Q
 | 
|---|
 | 35 |  ;
 | 
|---|
 | 36 | UNLOCK(RESULTS,DD,IENS) ; [Procedure] Unlock a record
 | 
|---|
 | 37 |  L @("-"_$$ROOT^DILFD(DD,IENS)_(+IENS)_")")
 | 
|---|
 | 38 |  S @RESULTS@(0)="1^Lock released"
 | 
|---|
 | 39 |  Q
 | 
|---|
 | 40 |  ;
 | 
|---|
 | 41 | CLINICPT ; [Procedure] Return patients by clinic/appt dt
 | 
|---|
 | 42 |  N MD,MDRET
 | 
|---|
 | 43 |  S MDDT=P2\1,MDEND=MDDT+.24
 | 
|---|
 | 44 |  D GETPLIST^SDAMA202(P1,"1;4;","R",MDDT,MDEND,.MDRET,"")
 | 
|---|
 | 45 |  I MDRET<0 S @RESULTS@(0)="0^No patients for this clinic/appt date." Q
 | 
|---|
 | 46 |  F MD=0:0 S MD=$O(^TMP($J,"SDAMA202","GETPLIST",MD)) Q:'MD  D
 | 
|---|
 | 47 |  .; Naked ref from above
 | 
|---|
 | 48 |  .S Y=+$G(^(MD,4)) Q:'Y  S @RESULTS@(Y)=$$GUIPT(Y)
 | 
|---|
 | 49 |  I '$D(@RESULTS) S @RESULTS@(0)="0^No patients for this clinic/appointment date."
 | 
|---|
 | 50 |  E  S @RESULTS@(0)=$D(@RESULTS)
 | 
|---|
 | 51 |  Q
 | 
|---|
 | 52 |  ;
 | 
|---|
 | 53 | CLINICS ; [Procedure] 
 | 
|---|
 | 54 |  F X=0:0 S X=$O(^SC(X)) Q:'X  D:$P(^(X,0),U,3)="C"
 | 
|---|
 | 55 |  .Q:+$G(^SC(X,"OOS"))
 | 
|---|
 | 56 |  .S Y=$G(^SC(X,"I"))
 | 
|---|
 | 57 |  .I Y Q:DT>+Y&($P(Y,U,2)=""!(DT<$P(Y,U,2)))
 | 
|---|
 | 58 |  .S @RESULTS@($O(@RESULTS@(""),-1)+1)="44;"_X_U_$P(^SC(X,0),U)
 | 
|---|
 | 59 |  S @RESULTS@(0)=+$O(@RESULTS@(""),-1)
 | 
|---|
 | 60 |  Q
 | 
|---|
 | 61 |  ;
 | 
|---|
 | 62 | COPY ; [Procedure] Make a copy of an item (Top level data only)
 | 
|---|
 | 63 |  K ^TMP("MDCOPY",$J)
 | 
|---|
 | 64 |  D GETS^DIQ(P1,P2_",","*","NI",$NA(^TMP("MDCOPY",$J)))
 | 
|---|
 | 65 |  S MDFDA(P1,"+1,",.01)=$E("Copy of "_$$GET1^DIQ(P1,P2,.01),1,30)
 | 
|---|
 | 66 |  F X=.01:0 S X=$O(^TMP("MDCOPY",$J,P1,P2_",",X)) Q:'X  D
 | 
|---|
 | 67 |  .S MDFDA(P1,"+1,",X)=$G(^TMP("MDCOPY",$J,P1,P2_",",X,"I"))
 | 
|---|
 | 68 |  K ^TMP("MDCOPY",$J)
 | 
|---|
 | 69 |  D UPDATE^DIE("","MDFDA","MDIEN")
 | 
|---|
 | 70 |  I $G(MDIEN(1))<1 D ERROR(RESULTS) Q
 | 
|---|
 | 71 |  S @RESULTS@(0)=P1_";"_MDIEN(1)_"^"_$$GET1^DIQ(P1,MDIEN(1)_",",.01)
 | 
|---|
 | 72 |  Q
 | 
|---|
 | 73 |  ;
 | 
|---|
 | 74 | DELITEM ; [Procedure] Determines if a file entry can be deleted and deletes it
 | 
|---|
 | 75 |  I P1="702.01" D  ; Procedure File
 | 
|---|
 | 76 |  .I $D(^MDD(702,"ACP",P2)) S @RESULTS@(1)="CP TRANSACTION"
 | 
|---|
 | 77 |  I P1="702.09" D  ; Instrument File
 | 
|---|
 | 78 |  .I $D(^MDS(702.01,"AINST",P2)) S @RESULTS@(1)="CP DEFINITION"
 | 
|---|
 | 79 |  .I $D(^MDS(702,"AINST",P2)) S @RESULTS@(2)="CP TRANSACTION"
 | 
|---|
 | 80 |  .I $D(^MDS(703.1,"AINST",P2)) S @RESULTS@(3)="CP RESULTS"
 | 
|---|
 | 81 |  I $O(@RESULTS@("")) S @RESULTS@(0)="-1^Unable to delete."
 | 
|---|
 | 82 |  E  S @RESULTS@(0)="1^OK"
 | 
|---|
 | 83 |  Q
 | 
|---|
 | 84 |  ;
 | 
|---|
 | 85 | ERROR(TARGET,SOURCE) ; [Procedure] 
 | 
|---|
 | 86 |  ; Input parameters
 | 
|---|
 | 87 |  ;  1. TARGET [Literal/Required] No description
 | 
|---|
 | 88 |  ;  2. SOURCE [Literal/Required] No description
 | 
|---|
 | 89 |  ;
 | 
|---|
 | 90 |  N X,Y
 | 
|---|
 | 91 |  I '$D(SOURCE) M SOURCE("DIERR")=^TMP("DIERR",$J)
 | 
|---|
 | 92 |  I '$D(SOURCE) S @TARGET@(0)="-1^No error message available" Q
 | 
|---|
 | 93 |  S @TARGET@(0)="-1^Error Encountered"
 | 
|---|
 | 94 |  S @TARGET@(1)="The following Error(s) occurred on the server."
 | 
|---|
 | 95 |  S @TARGET@(2)=" "
 | 
|---|
 | 96 |  F X=0:0 S X=$O(SOURCE("DIERR",X)) Q:'X  D
 | 
|---|
 | 97 |  .S Y=$O(@TARGET@(X),-1)+1
 | 
|---|
 | 98 |  .S @TARGET@(Y)="Error #: "_SOURCE("DIERR",X)_" "_$G(SOURCE("DIERR",X,"TEXT",1),"***")
 | 
|---|
 | 99 |  .D:$D(SOURCE("DIERR",X,"PARAM"))
 | 
|---|
 | 100 |  ..S @TARGET@(Y+1)=" ",@TARGET@(Y+2)="Parameters:"
 | 
|---|
 | 101 |  ..S Z=0 F  S Z=$O(SOURCE("DIERR",X,"PARAM",Z)) Q:Z=""  D
 | 
|---|
 | 102 |  ...S @TARGET@($O(@TARGET@(""),-1)+1)="Par: "_Z_" = "_SOURCE("DIERR",X,"PARAM",Z)
 | 
|---|
 | 103 |  Q
 | 
|---|
 | 104 |  ;
 | 
|---|
 | 105 | GETRSLT ; [Procedure] Get result report entries
 | 
|---|
 | 106 |  ; P1=PATIENT, P2=CPDefinition
 | 
|---|
 | 107 |  ; Load valid instruments into MDINST()
 | 
|---|
 | 108 |  F X=0:0 S X=$O(^MDS(702.01,+$G(P2),.1,"B",X)) Q:'X  S MDINST(X)=""
 | 
|---|
 | 109 |  ; Loop on the DFN index in 703.1
 | 
|---|
 | 110 |  F X=0:0 S X=$O(^MDD(703.1,"ADFN",P1,X)) Q:'X  D
 | 
|---|
 | 111 |  .; Make sure it isn't pending CPGateway action
 | 
|---|
 | 112 |  .Q:$P($G(^MDD(703.1,X,0)),U,9)="P"
 | 
|---|
 | 113 |  .; Make sure it is for a valid instrument
 | 
|---|
 | 114 |  .Q:'$D(MDINST(+$P($G(^MDD(703.1,X,0)),U,4)))
 | 
|---|
 | 115 |  .F Y=0:0 S Y=$O(^MDD(703.1,X,.1,Y)) Q:'Y  D
 | 
|---|
 | 116 |  ..S Z="703.11;"_Y_","_X_",^"_$P(^MDD(703.1,X,0),U,1,4)_"^^^^"
 | 
|---|
 | 117 |  ..S $P(Z,U,6)=$P(^MDD(703.1,X,.1,Y,0),U,2)
 | 
|---|
 | 118 |  ..S @RESULTS@(+$O(@RESULTS@(""),-1)+1)=Z
 | 
|---|
 | 119 |  S @RESULTS@(0)=+$O(@RESULTS@(""),-1)
 | 
|---|
 | 120 |  Q
 | 
|---|
 | 121 |  ;
 | 
|---|
 | 122 | GUIPT(X) ; [Procedure] 
 | 
|---|
 | 123 |  ; Input parameters
 | 
|---|
 | 124 |  ;  1. X [Literal/Required] No description
 | 
|---|
 | 125 |  ;
 | 
|---|
 | 126 |  S Y="2;"_X_U_$P(^DPT(X,0),U,1,3)
 | 
|---|
 | 127 |  S $P(Y,U,5)=$P(^DPT(X,0),U,9)
 | 
|---|
 | 128 |  S $P(Y,U,10)=$$DOB^DPTLK1(X)
 | 
|---|
 | 129 |  S $P(Y,U,11)=$$SSN^DPTLK1(X)
 | 
|---|
 | 130 |  Q Y
 | 
|---|
 | 131 |  ;
 | 
|---|
 | 132 | RPC(RESULTS,OPTION,P1,P2,P3,P4,P5,P6) ; [Procedure] Main RPC call
 | 
|---|
 | 133 |  ; RPC: [MD UTILITIES]
 | 
|---|
 | 134 |  ;
 | 
|---|
 | 135 |  ; Input parameters
 | 
|---|
 | 136 |  ;  1. RESULTS [Literal/Required] No description
 | 
|---|
 | 137 |  ;  2. OPTION [Literal/Required] No description
 | 
|---|
 | 138 |  ;  3. P1 [Literal/Required] No description
 | 
|---|
 | 139 |  ;  4. P2 [Literal/Required] No description
 | 
|---|
 | 140 |  ;  5. P3 [Literal/Required] No description
 | 
|---|
 | 141 |  ;  6. P4 [Literal/Required] No description
 | 
|---|
 | 142 |  ;  7. P5 [Literal/Required] No description
 | 
|---|
 | 143 |  ;  8. P6 [Literal/Required] No description
 | 
|---|
 | 144 |  ;
 | 
|---|
 | 145 |  ; Variables:
 | 
|---|
 | 146 |  ;  MDDT: [Private] Scratch
 | 
|---|
 | 147 |  ;  MDEND: [Private] Scratch
 | 
|---|
 | 148 |  ;  MDFDA: [Private] Fileman FDA variable
 | 
|---|
 | 149 |  ;  MDGBL: [Private] Scratch
 | 
|---|
 | 150 |  ;  MDIEN: [Private] Return array from UPDATE~DIE
 | 
|---|
 | 151 |  ;  MDPT: [Private] Scratch
 | 
|---|
 | 152 |  ;  Z: [Private] Scratch
 | 
|---|
 | 153 |  ;
 | 
|---|
 | 154 |  ; New private variables
 | 
|---|
 | 155 |  NEW MDDT,MDEND,MDFDA,MDGBL,MDIEN,MDPT,Z
 | 
|---|
 | 156 |  N MDRET,MDFDA,MDIEN,MDSCRN
 | 
|---|
 | 157 |  D CLEAN^DILF
 | 
|---|
 | 158 |  S RESULTS=$NA(^TMP("MDRPCU",$J)) K @RESULTS
 | 
|---|
 | 159 |  I $T(@OPTION)="" D BADRPC("MD UTILITIES",OPTION,$T(+0)) Q
 | 
|---|
 | 160 |  D @OPTION S:'$D(@RESULTS) @RESULTS@(0)="-1^No return"
 | 
|---|
 | 161 |  D CLEAN^DILF
 | 
|---|
 | 162 |  Q
 | 
|---|
 | 163 |  ;
 | 
|---|
 | 164 | TEAMPTS ; [Procedure] Return patients on a team
 | 
|---|
 | 165 |  D TEAMPTS^ORQPTQ1(.MDRET,P1)
 | 
|---|
 | 166 |  I '+$G(MDRET(1)) D  Q
 | 
|---|
 | 167 |  .S @RESULTS@(0)="0^No patients assigned to this team."
 | 
|---|
 | 168 |  F X=0:0 S X=$O(MDRET(X)) Q:'X  S @RESULTS@(X)=$$GUIPT(+MDRET(X))
 | 
|---|
 | 169 |  S @RESULTS@(0)=+$O(@RESULTS@(""),-1)
 | 
|---|
 | 170 |  Q
 | 
|---|
 | 171 |  ;
 | 
|---|
 | 172 | TEAMS ; [Procedure] Return list of teams
 | 
|---|
 | 173 |  D TEAMS^ORQPTQ1(.MDRET)
 | 
|---|
 | 174 |  F X=0:0 S X=$O(MDRET(X)) Q:'X  S @RESULTS@(X)="120.51;"_MDRET(X)
 | 
|---|
 | 175 |  S @RESULTS@(0)=+$O(@RESULTS@(X))
 | 
|---|
 | 176 |  Q
 | 
|---|
 | 177 |  ;
 | 
|---|
 | 178 | UNIQUE ; [Procedure] Is value P2 unique in file P1
 | 
|---|
 | 179 |  S MDGBL=$$GET1^DID(+P1,"","","GLOBAL NAME")
 | 
|---|
 | 180 |  I MDGBL="" S @RESULTS@(0)="-1^Not a valid DDNumber"
 | 
|---|
 | 181 |  E  S @RESULTS@(0)=($D(@(MDGBL_"P2,P3)"))=0)
 | 
|---|
 | 182 |  Q
 | 
|---|
 | 183 |  ;
 | 
|---|
 | 184 | WARDPTS ; [Procedure] Return pts for a ward
 | 
|---|
 | 185 |  S P1=$P($G(^DIC(42,P1,0)),U)
 | 
|---|
 | 186 |  I '$D(^DPT("CN",P1)) D  Q
 | 
|---|
 | 187 |  .S @RESULTS@(0)="0^No Patients on ward '"_P1_"'."
 | 
|---|
 | 188 |  F X=0:0 S X=$O(^DPT("CN",P1,X)) Q:'X  D
 | 
|---|
 | 189 |  .S Y=$O(@RESULTS@(""),-1)+1
 | 
|---|
 | 190 |  .S @RESULTS@(Y)=$$GUIPT(X)
 | 
|---|
 | 191 |  S @RESULTS@(0)=+$O(@RESULTS@(""),-1)
 | 
|---|
 | 192 |  Q
 | 
|---|
 | 193 |  ;
 | 
|---|
 | 194 | WARDS ; [Procedure] Return Active Set of Wards
 | 
|---|
 | 195 |  N D0,X,Y
 | 
|---|
 | 196 |  F D0=0:0 S D0=$O(^DIC(42,D0)) Q:'D0  D WIN^DGPMDDCF D:'X
 | 
|---|
 | 197 |  .S Y=$O(@RESULTS@(""),-1)+1
 | 
|---|
 | 198 |  .S @RESULTS@(Y)="42;"_D0_U_$P(^DIC(42,D0,0),U)
 | 
|---|
 | 199 |  S @RESULTS@(0)=+$O(@RESULTS@(""),-1)
 | 
|---|
 | 200 |  Q
 | 
|---|
 | 201 |  ;
 | 
|---|