| [613] | 1 | GMRCIACT ;SLC/JFR - PROCESS ACTIONS ON IFC ;02/10/02 22:13 | 
|---|
|  | 2 | ;;3.0;CONSULT/REQUEST TRACKING;**22,47**;DEC 27, 1997 | 
|---|
|  | 3 | Q  ;don't start here! | 
|---|
|  | 4 | NW(ARRAY) ;process and file new order | 
|---|
|  | 5 | ;Input: | 
|---|
|  | 6 | ; ARRAY  = name of array containing message parts | 
|---|
|  | 7 | ; | 
|---|
|  | 8 | N GMRCFDA,GMRCORC,GMRCDA,GMRCITM,GMRCITER,GMRCROUT,GMRCFCN,GMRCLAC | 
|---|
|  | 9 | K ^TMP("GMRCIN",$J) | 
|---|
|  | 10 | M ^TMP("GMRCIN",$J)=@ARRAY | 
|---|
|  | 11 | S GMRCORC=^TMP("GMRCIN",$J,"ORC") | 
|---|
|  | 12 | D  I $D(GMRCITER) Q  ;Check for order already being on file | 
|---|
|  | 13 | . S GMRCFCN=+$P(GMRCORC,"|",2) | 
|---|
|  | 14 | . S GMRCROUT=$$IEN^XUAF4($P($P(GMRCORC,"|",2),U,2)) | 
|---|
|  | 15 | . I '$O(^GMR(123,"AIFC",GMRCROUT,GMRCFCN,0)) Q  ;no dup | 
|---|
|  | 16 | . S GMRCITER=802 | 
|---|
|  | 17 | . D APPACK^GMRCIAC2(0,"AR",GMRCITER) ;send app. ack w/ error | 
|---|
|  | 18 | . K ^TMP("GMRCIN",$J) Q | 
|---|
|  | 19 | I '$D(^TMP("GMRCIN",$J,"PID")) Q  ;prepare reject message (no PID) | 
|---|
|  | 20 | D  ;get patient DFN from ICN in message | 
|---|
|  | 21 | . N PAT | 
|---|
|  | 22 | . S PAT=$$GETDFN^MPIF001(+$P(^TMP("GMRCIN",$J,"PID"),"|",2)) | 
|---|
|  | 23 | . I +PAT'>1 S GMRCFDA(.02)="" Q | 
|---|
|  | 24 | . S GMRCFDA(.02)=+PAT | 
|---|
|  | 25 | I '$G(GMRCFDA(.02)) D  Q  ;reject message, patient is unknown | 
|---|
|  | 26 | . N STA S STA=$P($P(^TMP("GMRCIN",$J,"ORC"),"|",2),U,2) | 
|---|
|  | 27 | . D PTERRMSG^GMRCIERR(^TMP("GMRCIN",$J,"PID"),STA) | 
|---|
|  | 28 | . D APPACK^GMRCIAC2(0,"AR",201) ; send app. ack w/error | 
|---|
|  | 29 | . K ^TMP("GMRCIN",$J) Q | 
|---|
|  | 30 | D  ;get ordered item and service | 
|---|
|  | 31 | . S GMRCITM=$P(^TMP("GMRCIN",$J,"OBR"),"|",4) | 
|---|
|  | 32 | . I GMRCITM["VA1233" D  ; proc | 
|---|
|  | 33 | .. N PROC | 
|---|
|  | 34 | .. S PROC=$$GETPROC^GMRCIUTL(GMRCITM) | 
|---|
|  | 35 | .. I +PROC'>0!('$P(PROC,U,2)) S GMRCITER=$P(PROC,U,3) Q | 
|---|
|  | 36 | .. S GMRCFDA(4)=$P(PROC,U)_";GMR(123.3," | 
|---|
|  | 37 | .. S GMRCFDA(1)=$P(PROC,U,2) | 
|---|
|  | 38 | . I GMRCITM["VA1235" D | 
|---|
|  | 39 | .. N SERV | 
|---|
|  | 40 | .. S SERV=$$GETSERV^GMRCIUTL(GMRCITM) ;consult | 
|---|
|  | 41 | .. I +SERV'>0 S GMRCITER=$P(SERV,U,3) | 
|---|
|  | 42 | .. S GMRCFDA(1)=SERV | 
|---|
|  | 43 | I $D(GMRCITER) D  Q  ;error in procedure or service, reject new order | 
|---|
|  | 44 | . D APPACK^GMRCIAC2(0,"AR",GMRCITER) ; send app. ACK | 
|---|
|  | 45 | . K ^TMP("GMRCIN",$J) Q | 
|---|
|  | 46 | ; | 
|---|
|  | 47 | S GMRCFDA(.01)=$$NOW^XLFDT | 
|---|
|  | 48 | S GMRCFDA(3)=$$HL7TFM^XLFDT($P(GMRCORC,"|",15)) | 
|---|
|  | 49 | S GMRCFDA(6)=$$FIND1^DIC(101,"","X","GMRCPLACE - ON CALL") | 
|---|
|  | 50 | D  ;get urgency to file | 
|---|
|  | 51 | . N URG | 
|---|
|  | 52 | . S URG=$$URG^GMRCHL7A($P($P(GMRCORC,"|",7),U,6)) | 
|---|
|  | 53 | . S GMRCFDA(5)=$$FIND1^DIC(101,"","X","GMRCURGENCY - "_URG) | 
|---|
|  | 54 | S GMRCFDA(8)=5 | 
|---|
|  | 55 | S GMRCFDA(9)=$S($P(GMRCORC,"|",16)["FI":24,1:23),GMRCLAC=GMRCFDA(9) | 
|---|
|  | 56 | S GMRCFDA(14)=$P(^TMP("GMRCIN",$J,"OBR"),"|",18) | 
|---|
|  | 57 | S GMRCFDA(.05)=$$IEN^XUAF4(+$P(GMRCORC,"|",17)) | 
|---|
|  | 58 | S GMRCFDA(.06)=GMRCFCN | 
|---|
|  | 59 | S GMRCFDA(.07)=GMRCROUT | 
|---|
|  | 60 | D  ;get and set ordering prov info & entering person info | 
|---|
|  | 61 | . N GMRCOP | 
|---|
|  | 62 | . S GMRCOP=$$FMNAME^XLFNAME($P(GMRCORC,"|",12)) | 
|---|
|  | 63 | . Q:'$L(GMRCOP) | 
|---|
|  | 64 | . S GMRCFDA(.126)=GMRCOP | 
|---|
|  | 65 | . Q | 
|---|
|  | 66 | S GMRCFDA(.125)="F" | 
|---|
|  | 67 | I $L($P(GMRCORC,"|",14)) D | 
|---|
|  | 68 | . N GMRCP14 S GMRCP14=$P(GMRCORC,"|",14) | 
|---|
|  | 69 | . S GMRCFDA(.132)=$P(GMRCP14,"B") ; requestor's phone number | 
|---|
|  | 70 | . S GMRCFDA(.133)=$P(GMRCP14,"B",2) ; requestor's dig pager | 
|---|
|  | 71 | S GMRCFDA(13)=$S($D(GMRCFDA(4)):"P",1:"C") | 
|---|
|  | 72 | I $D(^TMP("GMRCIN",$J,"OBX",2)) D | 
|---|
|  | 73 | . S GMRCFDA(30)=$P($P(^TMP("GMRCIN",$J,"OBX",2,1),"|",5),U,2) | 
|---|
|  | 74 | . S GMRCFDA(30.1)=$P($P(^TMP("GMRCIN",$J,"OBX",2,1),"|",5),U) | 
|---|
|  | 75 | M FDA(1,123,"+1,")=GMRCFDA | 
|---|
|  | 76 | D UPDATE^DIE("","FDA(1)","GMRCDA","GMRCERR") | 
|---|
|  | 77 | I '$D(GMRCDA) D  Q  ;couldn't get new consult # | 
|---|
|  | 78 | . D APPACK^GMRCIAC2(0,"AR",901) ; send app. ACK | 
|---|
|  | 79 | . K ^TMP("GMRCIN",$J) Q | 
|---|
|  | 80 | K GMRCFDA,FDA | 
|---|
|  | 81 | D  ; file reason for request | 
|---|
|  | 82 | . D TRIMWP^GMRCIUTL($NA(^TMP("GMRCIN",$J,"OBX",1)),5) | 
|---|
|  | 83 | . D WP^DIE(123,GMRCDA(1)_",",20,"K",$NA(^TMP("GMRCIN",$J,"OBX",1))) | 
|---|
|  | 84 | . Q | 
|---|
|  | 85 | D  ;file activity tracking | 
|---|
|  | 86 | . N GMRCSEG | 
|---|
|  | 87 | . S GMRCSEG("ORC")=GMRCORC | 
|---|
|  | 88 | . S GMRCSEG("OBX",5,1)=^TMP("GMRCIN",$J,"OBX",5,1) | 
|---|
|  | 89 | . D FILEACT^GMRCIAC2(GMRCDA(1),GMRCLAC,,"GMRCSEG") | 
|---|
|  | 90 | D  ;print SF-513 | 
|---|
|  | 91 | . I GMRCLAC=24 Q  ;don't print if part of a FWD to IFC | 
|---|
|  | 92 | . D PRNT^GMRCUTL1("",GMRCDA(1)) | 
|---|
|  | 93 | D  ;send notifications | 
|---|
|  | 94 | . I GMRCLAC=24 Q  ;no alerts yet if part of FWD to IFC | 
|---|
|  | 95 | . N GMRCORTX | 
|---|
|  | 96 | . S GMRCORTX="New remotely ordered consult "_$$ORTX^GMRCAU(+GMRCDA(1)) | 
|---|
|  | 97 | . D MSG^GMRCP($P(^GMR(123,GMRCDA(1),0),U,2),GMRCORTX,GMRCDA(1),27,,1) | 
|---|
|  | 98 | D  ;send appl ack :-( | 
|---|
|  | 99 | . N GMRCRSLT | 
|---|
|  | 100 | . D RESP^GMRCIUTL("AA",HL("MID"),$P(GMRCORC,"|"),GMRCDA(1)) | 
|---|
|  | 101 | . D GENACK^HLMA1(HL("EID"),HLMTIENS,HL("EIDS"),"LM",1,.GMRCRSLT) | 
|---|
|  | 102 | K ^TMP("GMRCIN",$J) | 
|---|
|  | 103 | Q | 
|---|
|  | 104 | ; | 
|---|
|  | 105 | DIS(GMRCAR) ;dis-associate a result from a remote request | 
|---|
|  | 106 | ;Input: | 
|---|
|  | 107 | ; GMRCAR = array name containing message | 
|---|
|  | 108 | ;      e.g.  ^TMP("GMRCIF",$J) | 
|---|
|  | 109 | N GMRCDA,GMRCFDA,FDA,GMRCERR,GMRCORC | 
|---|
|  | 110 | M ^TMP("GMRCID",$J)=@GMRCAR | 
|---|
|  | 111 | S GMRCORC=^TMP("GMRCID",$J,"ORC") | 
|---|
|  | 112 | S GMRCDA=$$GETDA^GMRCIAC2(GMRCORC) | 
|---|
|  | 113 | I '$$LOCKREC^GMRCUTL1(GMRCDA) D  Q  ;couldn't lock record | 
|---|
|  | 114 | . D APPACK^GMRCIAC2(GMRCDA,"AR",901) ;send app. ACK | 
|---|
|  | 115 | . K ^TMP("GMRCID",$J) Q | 
|---|
|  | 116 | ;    v--check to see if a dup transmission | 
|---|
|  | 117 | I $$DUPACT^GMRCIAC2(GMRCDA,12,GMRCORC,^TMP("GMRCID",$J,"OBX",4,1)) Q | 
|---|
|  | 118 | ; | 
|---|
|  | 119 | D FILEACT^GMRCIAC2(GMRCDA,12,,$NA(^TMP("GMRCID",$J))) ; act. tracking | 
|---|
|  | 120 | D FILRES^GMRCIAC2(GMRCDA,^TMP("GMRCID",$J,"OBX",4,1)) ;file results | 
|---|
|  | 121 | K GMRCERR,FDA,GMRCFDA | 
|---|
|  | 122 | I $$STSCHG^GMRCDIS(GMRCDA) S FDA(1,123,GMRCDA_",",8)=6 | 
|---|
|  | 123 | S FDA(1,123,GMRCDA_",",9)=12 | 
|---|
|  | 124 | D UPDATE^DIE("","FDA(1)",,"GMRCERR") ;file last action and status | 
|---|
|  | 125 | D  ;send notifications | 
|---|
|  | 126 | . I $P(^GMR(123,GMRCDA,12),U,5)="F" Q  ;DIS from placer before IFC | 
|---|
|  | 127 | . N GMRCORTX | 
|---|
|  | 128 | . S GMRCORTX="Remote result removed from "_$$ORTX^GMRCAU(+GMRCDA) | 
|---|
|  | 129 | . D MSG^GMRCP($P(^GMR(123,GMRCDA,0),U,2),GMRCORTX,GMRCDA,63,,1) | 
|---|
|  | 130 | D  ;send appl ACK | 
|---|
|  | 131 | . D APPACK^GMRCIAC2(GMRCDA,"AA") ; send app. ACK and unlock record | 
|---|
|  | 132 | K ^TMP("GMRCID",$J) | 
|---|
|  | 133 | Q | 
|---|
|  | 134 | ; | 
|---|
|  | 135 | OTHER(GMRCAR) ;process most IFC actions | 
|---|
|  | 136 | ;will process the receive, schedule, DC, cancel and added comment action | 
|---|
|  | 137 | ; | 
|---|
|  | 138 | ;Input: | 
|---|
|  | 139 | ; GMRCAR = array name containing message | 
|---|
|  | 140 | ;      e.g.  ^TMP("GMRCIF",$J) | 
|---|
|  | 141 | ; | 
|---|
|  | 142 | N GMRCDA,GMRCFDA,GMRCORC,GMRCLAT,GMRCACT,GMRCROL,FDA | 
|---|
|  | 143 | K ^TMP("GMRCIN",$J) | 
|---|
|  | 144 | M ^TMP("GMRCIN",$J)=@GMRCAR | 
|---|
|  | 145 | ; | 
|---|
|  | 146 | S GMRCORC=^TMP("GMRCIN",$J,"ORC") | 
|---|
|  | 147 | S GMRCDA=$$GETDA^GMRCIAC2(GMRCORC)  ;get ien to work on | 
|---|
|  | 148 | S GMRCROL=$P(^GMR(123,GMRCDA,12),U,5) | 
|---|
|  | 149 | I '$$LOCKREC^GMRCUTL1(GMRCDA) D  Q  ;couldn't lock record | 
|---|
|  | 150 | . D APPACK^GMRCIAC2(GMRCDA,"AR",901) ; send app. ACK | 
|---|
|  | 151 | . K ^TMP("GMRCIN",$J) Q | 
|---|
|  | 152 | ; | 
|---|
|  | 153 | I $P(GMRCORC,"|")'="IP" D  ; status update | 
|---|
|  | 154 | . N GMRCOS S GMRCOS=$P(GMRCORC,"|",5) | 
|---|
|  | 155 | . S GMRCFDA(8)=$S(GMRCOS="IP":6,GMRCOS="SC":8,GMRCOS="CA":13,1:1) | 
|---|
|  | 156 | . ; IP=receive, SC=schedule, CA=cancel, DC=discontinue | 
|---|
|  | 157 | D  ; get last action taken | 
|---|
|  | 158 | . I '$G(GMRCFDA(8)) S (GMRCFDA(9),GMRCLAT)=20 Q | 
|---|
|  | 159 | . I GMRCFDA(8)=6 S (GMRCFDA(9),GMRCLAT)=21 Q | 
|---|
|  | 160 | . I GMRCFDA(8)=8 S (GMRCFDA(9),GMRCLAT)=8 Q | 
|---|
|  | 161 | . I GMRCFDA(8)=1 S (GMRCFDA(9),GMRCLAT)=6 Q | 
|---|
|  | 162 | . I GMRCFDA(8)=13 S (GMRCFDA(9),GMRCLAT)=19 Q | 
|---|
|  | 163 | ;                         ^--last action taken | 
|---|
|  | 164 | ;    v-- check to see if a dup transmission | 
|---|
|  | 165 | I $$DUPACT^GMRCIAC2(GMRCDA,GMRCLAT,GMRCORC) Q | 
|---|
|  | 166 | ; | 
|---|
|  | 167 | M FDA(1,123,GMRCDA_",")=GMRCFDA | 
|---|
|  | 168 | D UPDATE^DIE("","FDA(1)",,"GMRCERR") ;file last action and update status | 
|---|
|  | 169 | K GMRCFDA | 
|---|
|  | 170 | D FILEACT^GMRCIAC2(GMRCDA,GMRCLAT,,$NA(^TMP("GMRCIN",$J))) | 
|---|
|  | 171 | D  ;send notifications | 
|---|
|  | 172 | . N GMRCTX,GMRCNOT,GMRCFL | 
|---|
|  | 173 | . S GMRCFL=1 | 
|---|
|  | 174 | . I GMRCLAT=20!(GMRCLAT=8)!(GMRCLAT=21) D | 
|---|
|  | 175 | .. I GMRCLAT=20 D  I '$D(GMRCTX) Q | 
|---|
|  | 176 | ... I $P(^GMR(123,GMRCDA,40,1,0),U,2)'=24 D  Q | 
|---|
|  | 177 | .... S GMRCTX="Comment Added to remote" | 
|---|
|  | 178 | ... N ACT S ACT=1 | 
|---|
|  | 179 | ... F  S ACT=$O(^GMR(123,GMRCDA,40,ACT)) Q:'ACT!($D(GMRCTX))  D | 
|---|
|  | 180 | .... I $P(^GMR(123,GMRCDA,40,ACT,0),U,2)=25,$O(^GMR(123,GMRCDA,40,ACT)) D | 
|---|
|  | 181 | ..... S GMRCTX="Comment Added to remote" | 
|---|
|  | 182 | .. I '$D(GMRCTX),GMRCROL="F" Q  ;sch & rec on filler part of FWD 2 IFC | 
|---|
|  | 183 | .. I GMRCLAT=8 S GMRCTX="Scheduled remote" | 
|---|
|  | 184 | .. I GMRCLAT=21 S GMRCTX="Received remote" | 
|---|
|  | 185 | .. S GMRCTX=GMRCTX_" Consult: "_$$ORTX^GMRCAU(+GMRCDA) | 
|---|
|  | 186 | .. S GMRCNOT=63 | 
|---|
|  | 187 | . I GMRCLAT=6 D | 
|---|
|  | 188 | .. S GMRCFL=$$DCNOTE^GMRCADC(GMRCDA,.5) | 
|---|
|  | 189 | .. S GMRCTX="Discontinued remote Consult: "_$$ORTX^GMRCAU(+GMRCDA) | 
|---|
|  | 190 | .. S GMRCNOT=23 | 
|---|
|  | 191 | . I GMRCLAT=19 D | 
|---|
|  | 192 | .. I GMRCROL="F" Q  ;canc on a filler is part of FWD 2 IFC | 
|---|
|  | 193 | .. S GMRCTX="Cancelled remote Consult: "_$$ORTX^GMRCAU(+GMRCDA) | 
|---|
|  | 194 | .. S GMRCNOT=30 | 
|---|
|  | 195 | . I '$D(GMRCNOT) Q  ;don't send any alerts | 
|---|
|  | 196 | . D MSG^GMRCP($P(^GMR(123,GMRCDA,0),U,2),GMRCTX,GMRCDA,GMRCNOT,,GMRCFL) | 
|---|
|  | 197 | ; | 
|---|
|  | 198 | D  ;send appl ACK | 
|---|
|  | 199 | . D APPACK^GMRCIAC2(GMRCDA,"AA") ;send app. ACK and unlock record | 
|---|
|  | 200 | K ^TMP("GMRCIN",$J) | 
|---|
|  | 201 | Q | 
|---|
|  | 202 | ; | 
|---|