Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: RAO7PC4

RAO7PC4.m

Go to the documentation of this file.
  1. RAO7PC4 ;HISC/SWM-utilities ; Apr 28, 2020@14:47:40
  1. ;;5.0;Radiology/Nuclear Medicine;**28,32,31,45,77,157,169**;Mar 16, 1998;Build 2
  1. ;08/10/2006 BAY/KAM Remedy Call 134839 Subscript Error
  1. ;
  1. ;IA Type File Routine Tag
  1. ;------------------------------------------------
  1. ;1362 (C) ORB3 EN
  1. ;
  1. Q
  1. EN1 ; api for CPRS notification alert #67
  1. Q:'$D(XQADATA)
  1. D SET1 ; set up ^TMP nodes
  1. D DISP1 ; convert and display ^TMP nodes
  1. D KIL1 ; kill ^TMP nodes
  1. Q
  1. SET1 N RADFN,RADTI,RACNI,RAPROC1,RAPROC2,RAPHY1,RAPHY2,RAPMOD1,RAPMOD2,RAACNT
  1. N RAPATNAM,RASSN,RASTR,I,J,RACMU,RAOIFN
  1. ; 08/10/2006 BAY/KAM Remedy Call 134839/RA*5*77 - Added next line
  1. Q:$G(XQADATA)=""
  1. S RADFN=$P(XQADATA,"/") ; ien patient
  1. S RAACNT=0 ; counter
  1. S RADTI=$P(XQADATA,"/",2) ; inverse date of exam
  1. S RACNI=$P(XQADATA,"/",3) ; ien case
  1. ;p157/KLM Set the before procedure from order if missing from alert data
  1. S RAPROC1=$P(XQADATA,"/",4) I RAPROC1="" D ; ien 71, before
  1. .S RAOIFN=$P($G(^RADPT(RADFN,"DT",RADTI,"P",RACNI,0)),U,11)
  1. .S:RAOIFN]"" RAPROC1=$P(^RAO(75.1,RAOIFN,0),U,2)
  1. .Q
  1. S RAPROC2=$P(XQADATA,"/",5) ; ien 71, after
  1. S RAPHY1=$P(XQADATA,"/",6) ; ien 200 requesting physician, before
  1. S RAPHY2=$P(XQADATA,"/",7) ; ien 200 requesting physician, after
  1. S RAPMOD1=$P(XQADATA,"/",8) ;string of proc mod iens, before
  1. S RAPMOD2=$P(XQADATA,"/",9) ;string of proc mod iens, after
  1. K ^TMP($J,"RAE4")
  1. Q:'$D(^DPT(RADFN,0))
  1. S RAPATNAM=$P(^DPT(RADFN,0),"^") S RASSN=$$SSN^RAUTL() S:RASSN="" RASSN="Unkn"
  1. S RACMU=$S(+$O(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",0))>0:" (CM w/exam)",1:"")
  1. S ^TMP($J,"RAE4",1)="Imaging Exam for "_RAPATNAM_" ("_RASSN_") changed:"
  1. I 'RAPROC2,RAPROC1 D
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" "
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))="For procedure "_$E($P(^RAMIS(71,RAPROC1,0),"^"),1,53)_RACMU
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" "
  1. I RAPROC2 D
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" Procedure changed"
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" From: "_$S(RAPROC1]"":$E($P(^RAMIS(71,RAPROC1,0),"^"),1,53),1:"UNKNOWN") ;p157/KLM - add $S for 'unknown' procedure
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" To: "_$E($P(^RAMIS(71,RAPROC2,0),"^"),1,53)_RACMU
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=""
  1. I RAPHY2 D
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" Requesting Physician changed"
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" From: "_$$GET1^DIQ(200,RAPHY1,.01)
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" To: "_$$GET1^DIQ(200,RAPHY2,.01)
  1. I RAPMOD2!(('RAPMOD2)&(RAPMOD1)) D
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" Procedure Modifier changed"
  1. .S RASTR=""
  1. .F I=1:1:($L(RAPMOD1)/2) S J=$P(RAPMOD1,",",I) Q:J="" S RASTR=RASTR_$$GET1^DIQ(71.2,J,.01)_", " Q:$L(RASTR)>240
  1. .S RASTR=$E(RASTR,1,$L(RASTR)-2) ;rid trailing comma and blank
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" From: "_RASTR
  1. .S RASTR=""
  1. .F I=1:1:($L(RAPMOD2)/2) S J=$P(RAPMOD2,",",I) Q:J="" S RASTR=RASTR_$$GET1^DIQ(71.2,J,.01)_", " Q:$L(RASTR)>240
  1. .S RASTR=$E(RASTR,1,$L(RASTR)-2) ;rid trailing comma
  1. .S ^TMP($J,"RAE4",$$INCR^RAUTL4(RAACNT))=" To: "_RASTR
  1. Q
  1. DISP1 N RARRAY
  1. MERGE RARRAY=^TMP($J,"RAE4")
  1. D EN^DDIOL(.RARRAY)
  1. Q
  1. KIL1 K ^TMP($J,"RAE4")
  1. Q
  1. ;
  1. SETALERT ;
  1. Q:'$D(RASTRING)
  1. N RAPHY1,RAPHY2,RAPNAM,RAPSSN
  1. S RADFN=$P(RASTRING,"/") ; ien patient
  1. S RAPNAM=$$GET1^DIQ(70,+RADFN,.01) S:RAPNAM="" RAPNAM="UNKNOWN"
  1. S RAPSSN=$$GET1^DIQ(70,+RADFN,.09) S:RAPSSN="" RAPSSN="UNKNOWN"
  1. S RAPHY1=$P(RASTRING,"/",6) ; ien 200 requesting physician, before
  1. S RAPHY2=$P(RASTRING,"/",7) ; ien 200 requesting physician, after
  1. ;
  1. S XQA(RAPHY1)="",XQAID=$J_","_$H S:$G(RAPHY2)]"" XQA(RAPHY2)=""
  1. S XQAMSG=$E(RAPNAM,1,9)_" ("_$E(RAPNAM,1)_$E(RAPSSN,6,9)_"): Imaging Exam Changed: "_$S($P(RASTRING,"/",5):"Proc., ",1:"")_$S($P(RASTRING,"/",7):"Rqstr, ",1:"")_$S($P(RASTRING,"/",9):"Proc Mod",1:"")
  1. S:$E(XQAMSG,($L(XQAMSG)-1))="," XQAMSG=$E(XQAMSG,1,($L(XQAMSG)-2))
  1. S XQADATA=RASTRING
  1. S XQAROU="ZZ^RAO7PC4(XQADATA)"
  1. D SETUP^XQALERT
  1. Q
  1. ;
  1. ZZ(RASTRING) ; Additional text for display when processing alert.
  1. ;
  1. N RADFN,RADTI,RACMU,RACNI,RAPROC1,RAPROC2,RAPHY1,RAPHY2,RAPMOD1,RAPMOD2
  1. N RAPNAM,RAPSSN,I,RAPRFR,RAPRTO,RAPHYFR,RAPHYTO,RASTR
  1. S RADFN=$P(RASTRING,"/") ; ien patient
  1. S RADTI=$P(RASTRING,"/",2) ; inverse date of exam
  1. S RACNI=$P(RASTRING,"/",3) ; ien case
  1. S RAPROC1=$P(RASTRING,"/",4) ; ien 71, before
  1. S RAPROC2=$P(RASTRING,"/",5) ; ien 71, after
  1. S RAPHY1=$P(RASTRING,"/",6) ; ien 200 requesting physician, before
  1. S RAPHY2=$P(RASTRING,"/",7) ; ien 200 requesting physician, after
  1. S RAPMOD1=$P(RASTRING,"/",8) ;string of proc mod iens, before
  1. S RAPMOD2=$P(RASTRING,"/",9) ;string of proc mod iens, after
  1. ;
  1. S RAPNAM=$$GET1^DIQ(70,+RADFN,.01) S:RAPNAM="" RAPNAM="UNKNOWN"
  1. S RAPSSN=$$GET1^DIQ(70,+RADFN,.09) S:RAPSSN="" RAPSSN="UNKNOWN"
  1. D EN^DDIOL("Imaging Exam For "_$E(RAPNAM,1,30)_" ("_RAPSSN_") Changed:",,"!!?4")
  1. ;
  1. S RACMU=$S(+$O(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",0))>0:" (CM w/exam)",1:"")
  1. I 'RAPROC2,RAPROC1 D
  1. .S RAPRFR=$E($$GET1^DIQ(71,+RAPROC1,.01),1,50) S:RAPRFR="" RAPRFR="UNKNOWN"
  1. .S RAPRFR=RAPRFR_RACMU D EN^DDIOL("For procedure "_RAPRFR_RACMU,,"!?4")
  1. .D EN^DDIOL(" ",,"!")
  1. .Q
  1. I RAPROC2 D
  1. .S RAPRFR=$E($$GET1^DIQ(71,+RAPROC1,.01),1,53) S:RAPRFR="" RAPRFR="UNKNOWN"
  1. .S RAPRTO=$E($$GET1^DIQ(71,+RAPROC2,.01),1,53) S:RAPRTO="" RAPRTO="UNKNOWN"
  1. .D EN^DDIOL("Procedure changed",,"!?4")
  1. .D EN^DDIOL("From: "_RAPRFR,,"!?8")
  1. .D EN^DDIOL("To: "_RAPRTO_RACMU,,"!?8")
  1. .Q
  1. I RAPHY2 D
  1. .S RAPHYFR=$$GET1^DIQ(200,RAPHY1,.01) S:RAPHYFR="" RAPHYFR="UNKNOWN"
  1. .S RAPHYTO=$$GET1^DIQ(200,RAPHY2,.01) S:RAPHYTO="" RAPHYTO="UNKNOWN"
  1. .D EN^DDIOL("Requesting Physician changed",,"!?4")
  1. .D EN^DDIOL("From: "_RAPHYFR,,"!?8")
  1. .D EN^DDIOL("To: "_RAPHYTO,,"!?8")
  1. .Q
  1. I RAPMOD2!('(RAPMOD2)&(RAPMOD1)) D
  1. .D EN^DDIOL("Procedure Modifier changed",,"!?4")
  1. .S RASTR=""
  1. .F I=1:1:($L(RAPMOD1)/2) S J=$P(RAPMOD1,",",I) Q:J="" S RASTR=RASTR_$$GET1^DIQ(71.2,J,.01)_", " Q:$L(RASTR)>240
  1. .S RASTR=$E(RASTR,1,$L(RASTR)-2) ;rid trailing comma
  1. .D EN^DDIOL("From: "_RASTR,,"!?8")
  1. .S RASTR=""
  1. .F I=1:1:($L(RAPMOD2)/2) S J=$P(RAPMOD2,",",I) Q:J="" S RASTR=RASTR_$$GET1^DIQ(71.2,J,.01)_", " Q:$L(RASTR)>240
  1. .S RASTR=$E(RASTR,1,$L(RASTR)-2) ;rid trailing comma
  1. .D EN^DDIOL("To: "_RASTR,,"!?8")
  1. .Q
  1. Q
  1. ;
  1. SETNOTIF(RAIEN751) ; called by RAO7XX if patch OR*3.0*112 is installed
  1. ;so that the CPRS notification system can be used to set the alert
  1. Q:'$D(RASTRING)
  1. ;RASTRING is : dfn^invdt^caseien^befproc^aftproc^befphy^aftphy
  1. ; ^befpmodA,pmodF,etc^aftpmodF,pmodH,etc
  1. ;RAIEN751 - IEN file 75.1 RA5P169
  1. ;Notification: #67 - IMAGING REQUEST CHANGED
  1. N RAREQPHY,RAOIFN,RAORIFN
  1. S:+$P(RASTRING,"/",6) RAREQPHY(+$P(RASTRING,"/",6))=""
  1. S:+$P(RASTRING,"/",7) RAREQPHY(+$P(RASTRING,"/",7))=""
  1. S RAMSG="Imaging Exam Changed: "_$S($P(RASTRING,"/",5):"Proc., ",1:"")_$S($P(RASTRING,"/",7):"Rqstr, ",1:"")_$S($L($P(RASTRING,"/",8,9))>1:"Proc Mod",1:"")
  1. S:$E(RAMSG,$L(RAMSG)-1)="," RAMSG=$E(RAMSG,1,($L(RAMSG)-2))
  1. S RAOIFN(0)=$G(^RAO(75.1,RAIEN751,0)),RAORIFN=$P(RAOIFN(0),"^",7) ;CPRS order IFN
  1. D EN^ORB3(67,+RASTRING,RAORIFN,.RAREQPHY,RAMSG,RASTRING)
  1. ;ORN mustbe 67,dfn,IFN #100,reqphys,messagetitle,string for api
  1. Q
  1. ;