| 1 | RAHLO ;HIRMFO/GJC-Process data set from the bridge program ;11/18/97  12:13
 | 
|---|
| 2 |  ;;5.0;Radiology/Nuclear Medicine;**4,8,27,55,66,84**;Mar 16, 1998;Build 13
 | 
|---|
| 3 |  ; 09/07/2005 Remedy call 108405 - KAM Allow Radiology to accept dx codes from Talk Technology
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  ;Integration Agreements
 | 
|---|
| 6 |  ;----------------------
 | 
|---|
| 7 |  ;DT^DILF(2054); LOCK^DILF(2054); DEM^VADPT(10061); $$DT^XLFDT(10103)
 | 
|---|
| 8 |  ;
 | 
|---|
| 9 | EN1 ; Check the validity of the following data globals:
 | 
|---|
| 10 |  ; Example: '^TMP("RARPT-REC",$J,RASUB,' where RASUB is a
 | 
|---|
| 11 |  ; record in file 772.
 | 
|---|
| 12 |  ;**************** Validates (if data present): ************************
 | 
|---|
| 13 |  ; ^TMP("RARPT-REC",$J,RASUB,"RACNI")=case ien
 | 
|---|
| 14 |  ; ^TMP("RARPT-REC",$J,RASUB,"RADATE")=date reported/entered/verified
 | 
|---|
| 15 |  ; ^TMP("RARPT-REC",$J,RASUB,"RADFN")=patient ien
 | 
|---|
| 16 |  ; ^TMP("RARPT-REC",$J,RASUB,"RADTI")=inverted exam date/time
 | 
|---|
| 17 |  ; ^TMP("RARPT-REC",$J,RASUB,"RADX",#)=Dx codes (could be more than 1)
 | 
|---|
| 18 |  ; ^TMP("RARPT-REC",$J,RASUB,"RAESIG")=Verifier's E-Sig (if present)
 | 
|---|
| 19 |  ; ^TMP("RARPT-REC",$J,RASUB,"RAHIST")=Additional Clinical History
 | 
|---|
| 20 |  ; ^TMP("RARPT-REC",$J,RASUB,"RAIMP",#)=Impression Text
 | 
|---|
| 21 |  ; ^TMP("RARPT-REC",$J,RASUB,"RALONGCN")=Long Case Number
 | 
|---|
| 22 |  ; ^TMP("RARPT-REC",$J,RASUB,"RASSN")=Patient SSN
 | 
|---|
| 23 |  ; ^TMP("RARPT-REC",$J,RASUB,"RASTAT")=A, F or R (amend, final or prelim)
 | 
|---|
| 24 |  ; ^TMP("RARPT-REC",$J,RASUB,"RATXT",#)=Report Text
 | 
|---|
| 25 |  ; ^TMP("RARPT-REC",$J,RASUB,"VENDOR")=vendor
 | 
|---|
| 26 |  ; ^TMP("RARPT-REC",$J,RASUB,"RAVERF")=Verifier ien
 | 
|---|
| 27 |  ; ^TMP("RARPT-REC",$J,RASUB,"RATRANSCRIPT")=transcriptionist (optional)
 | 
|---|
| 28 |  ; ^TMP("RARPT-REC",$J,RASUB,"RASTAFF")=Primary staff
 | 
|---|
| 29 |  ; ^TMP("RARPT-REC",$J,RASUB,"RARESIDENT")=Primary resident
 | 
|---|
| 30 |  ; ^TMP("RARPT-REC",$J,RASUB,"RAWHOCHANGE")=Who changed status to Verify
 | 
|---|
| 31 |  ;**********************************************************************
 | 
|---|
| 32 |  K RAERR S RAQUIET=1
 | 
|---|
| 33 |  ; Check if the minimum data set exists.
 | 
|---|
| 34 |  I '$D(^TMP("RARPT-REC",$J,RASUB,"RACNI")) S RAERR="Missing Case Number" Q
 | 
|---|
| 35 |  I '$D(^TMP("RARPT-REC",$J,RASUB,"RADFN")) S RAERR="Internal Patient ID Missing" Q
 | 
|---|
| 36 |  I '$D(^TMP("RARPT-REC",$J,RASUB,"RADTI")) S RAERR="Missing Exam Date" Q
 | 
|---|
| 37 |  I '$D(^TMP("RARPT-REC",$J,RASUB,"RALONGCN")) S RAERR="Missing Exam Date and/or Case Number" Q
 | 
|---|
| 38 |  I '$D(^TMP("RARPT-REC",$J,RASUB,"RASSN")) S RAERR="Missing Patient ID" Q
 | 
|---|
| 39 |  D CHECK ; check the validity of our data.
 | 
|---|
| 40 | XIT ; Kill and quit
 | 
|---|
| 41 |  K A,B,DFN,K,RACNI,RADX,RADENDUM,RADFN,RADTI,RADUZ,RAIMGTY,RALONGCN,RAMDIV,RAMDV,RAMLC,RAQUIET,RADPIECE,RARPT,RARPTSTS,RASSN,RAVLDT,X,Y,RATRANSC
 | 
|---|
| 42 |  Q
 | 
|---|
| 43 | CHECK ; Check if our data is valid.
 | 
|---|
| 44 |  S RACNI=$G(^TMP("RARPT-REC",$J,RASUB,"RACNI"))
 | 
|---|
| 45 |  S RADATE=$G(^TMP("RARPT-REC",$J,RASUB,"RADATE"))
 | 
|---|
| 46 |  S RADFN=$G(^TMP("RARPT-REC",$J,RASUB,"RADFN"))
 | 
|---|
| 47 |  S RADTI=$G(^TMP("RARPT-REC",$J,RASUB,"RADTI"))
 | 
|---|
| 48 |  S RALONGCN=$G(^TMP("RARPT-REC",$J,RASUB,"RALONGCN"))
 | 
|---|
| 49 |  S RASSN=$G(^TMP("RARPT-REC",$J,RASUB,"RASSN"))
 | 
|---|
| 50 |  S (RAVERF,RADUZ)=$G(^TMP("RARPT-REC",$J,RASUB,"RAVERF"))
 | 
|---|
| 51 |  S RATRANSC=$G(^TMP("RARPT-REC",$J,RASUB,"RATRANSCRIPT"))
 | 
|---|
| 52 |  S RASTAT=$G(^TMP("RARPT-REC",$J,RASUB,"RASTAT")) I RASTAT="A" S RADENDUM=""
 | 
|---|
| 53 |  I $D(^TMP("RARPT-REC",$J,RASUB,"RAESIG")) S RAESIG=$G(^("RAESIG"))
 | 
|---|
| 54 |  I $D(^TMP("RARPT-REC",$J,RASUB,"RAIMP")) D IMPTXT^RAHLO2
 | 
|---|
| 55 |  I RADATE']"" S RAERR="Missing report date" Q
 | 
|---|
| 56 |  I RADFN']"" S RAERR="Missing Internal Patient ID" Q
 | 
|---|
| 57 |  I RACNI']"" S RAERR="Missing Case Number" Q
 | 
|---|
| 58 |  I RADTI']"" S RAERR="Missing Exam Date" Q
 | 
|---|
| 59 |  D DT^DILF("ET",RADATE,.RAVLDT)
 | 
|---|
| 60 |  S:RAVLDT=-1 RAERR="Invalid report date" Q:$D(RAERR)
 | 
|---|
| 61 |  K VA,VADM,VAERR S DFN=RADFN D DEM^VADPT
 | 
|---|
| 62 |  I VADM(1)']"" S RAERR="Unknown Internal patient identifier" K VA,VADM,VAERR Q
 | 
|---|
| 63 |  I RASSN'=$P(VADM(2),"^") S RAERR="Internal patient identifier and SSN don't match" K VA,VADM,VAERR Q
 | 
|---|
| 64 |  I '$D(^RADPT(RADFN,"DT",RADTI,"P",RACNI,0))!(RALONGCN']"") D  Q
 | 
|---|
| 65 |  . S RAERR="Invalid Exam Date and/or Case Number"
 | 
|---|
| 66 |  . Q
 | 
|---|
| 67 |  D EDTCHK^RAHLQ ; is user allowed to edit report for a cancelled case?
 | 
|---|
| 68 |  I RARPT=1 S RAERR="Report for CANCELLED case not permitted." Q
 | 
|---|
| 69 |  I RARPT=2 S RAERR="Please use VISTA to edit CANCELLED printset cases." Q
 | 
|---|
| 70 |  S RARPT=+$P(^RADPT(RADFN,"DT",RADTI,"P",RACNI,0),"^",17)
 | 
|---|
| 71 |  I '$D(^RARPT(RARPT,0)),($D(RADENDUM)#2) S RAERR="Can't add addendum, no report" Q
 | 
|---|
| 72 |  I $D(^RARPT(RARPT,0)),($P(^(0),"^",5)'="V"),($D(RADENDUM)#2) S RAERR="Can't add addendum to an unverified report" Q
 | 
|---|
| 73 |  I $D(^RARPT(RARPT,0)),$P(^(0),"^",5)="V",('$D(RADENDUM)#2) S RAERR="Report already on file" Q
 | 
|---|
| 74 |  I ($D(RADENDUM)#2),'$O(^TMP("RARPT-REC",$J,RASUB,"RAIMP",0)),'$O(^TMP("RARPT-REC",$J,RASUB,"RATXT",0)) S RAERR="Missing addendum report/impression text" Q
 | 
|---|
| 75 |  I $D(^RADPT(RADFN,"DT",RADTI,0)) S RAMDIV=^(0),RAMLC=+$P(RAMDIV,"^",4),RAMDIV=+$P(RAMDIV,"^",3),RAMDV=$S($D(^RA(79,RAMDIV,.1)):^(.1),1:""),RAMDV=$S(RAMDV="":RAMDV,1:$TR(RAMDV,"YyNn",1100))
 | 
|---|
| 76 |  I '($D(RADENDUM)#2) I $P(RAMDV,"^",16),('$D(^TMP("RARPT-REC",$J,RASUB,"RAIMP"))) S RAERR="Missing Impression Text" Q  ; impression req'd for this division
 | 
|---|
| 77 |  I ($D(RADENDUM)#2),($D(^RARPT(RARPT,0))#2),($P(RAMDV,"^",16)),('$O(^RARPT(RARPT,"I",0))),('$D(^TMP("RARPT-REC",$J,RASUB,"RAIMP"))) S RAERR="Impression Text missing for current record." Q  ; impression req'd for this division
 | 
|---|
| 78 |  I $D(RADENDUM)#2 D CKDUPA^RAHLO4 I RADUPA S RAERR="Duplicate Addendum" Q
 | 
|---|
| 79 |  ; check resident and staff
 | 
|---|
| 80 |  N X1,X2,X3 S X2=0,X3=""
 | 
|---|
| 81 |  I '$G(RATELE),+$G(^TMP("RARPT-REC",$J,RASUB,"RARESIDENT"))!(+$G(^("RASTAFF"))) D  Q:$G(RAERR)]""
 | 
|---|
| 82 |  . S X1=+$G(^TMP("RARPT-REC",$J,RASUB,"RARESIDENT"))
 | 
|---|
| 83 |  . I X1 D
 | 
|---|
| 84 |  .. I '$D(^VA(200,"ARC","R",X1)),'$D(^VA(200,"ARC","S",X1)) S X2=1
 | 
|---|
| 85 |  .. I $P($G(^VA(200,X1,"RA")),"^",3),$P(^("RA"),"^",3)'>$$DT^XLFDT S X2=X2+2
 | 
|---|
| 86 |  .. I X2=1 S X3=$E($P($G(^VA(200,X1,0)),"^"),1,20)_" is not class'd as Resident or Staff"
 | 
|---|
| 87 |  .. I X2=2 S X3=$P($G(^VA(200,X1,0)),"^")_"'s INACTIVE DATE is past"
 | 
|---|
| 88 |  .. I X2=3 S X3=$P($G(^VA(200,X1,0)),"^")_" is not class'd as resident and past INACTIVE DATE"
 | 
|---|
| 89 |  .. I X3]"" S RAERR=X3
 | 
|---|
| 90 |  . S X2=0,X3="" S X1=+$G(^TMP("RARPT-REC",$J,RASUB,"RASTAFF"))
 | 
|---|
| 91 |  . I X1 D
 | 
|---|
| 92 |  .. I '$D(^VA(200,"ARC","S",X1)) S X2=1
 | 
|---|
| 93 |  .. I $P($G(^VA(200,X1,"RA")),"^",3),$P(^("RA"),"^",3)'>$$DT^XLFDT S X2=X2+2
 | 
|---|
| 94 |  .. I X2=1 S X3=$E($P($G(^VA(200,X1,0)),"^"),1,20)_" is not class'd as staff"
 | 
|---|
| 95 |  .. I X2=2 S X3=$P($G(^VA(200,X1,0)),"^")_"'s INACTIVE DATE is past"
 | 
|---|
| 96 |  .. I X2=3 S X3=$P($G(^VA(200,X1,0)),"^")_" is not class'd as staff and past INACTIVE DATE"
 | 
|---|
| 97 |  .. I X3]"" S RAERR=$S($G(RAERR)]"":RAERR_", ",1:"")_X3
 | 
|---|
| 98 |  . Q
 | 
|---|
| 99 |  ; raesig is in alphanumeric format, so shouldn't use $g of it here
 | 
|---|
| 100 |  I ($G(RAESIG)]"")!($G(RAVERF)) D:'$G(RATELE) VERCHK^RAHLO3 ; check if provider can verify report
 | 
|---|
| 101 |  ; if verifier fails checks,
 | 
|---|
| 102 |  ;   quit only if vendor is non-kurzweil,
 | 
|---|
| 103 |  ;   if vendor is kurzweil, continue on by deleting raerr, raverf
 | 
|---|
| 104 |  I $D(RAERR) Q:$G(^TMP("RARPT-REC",$J,RASUB,"VENDOR"))'="KURZWEIL"  K RAERR,RAVERF
 | 
|---|
| 105 |  S RAIMGTY=$$IMGTY^RAUTL12("l",RAMLC) I '$L(RAIMGTY) S RAERR="No Imaging Type for Location where exam was performed" Q
 | 
|---|
| 106 |  K RASECDX ;clear secondary dx array because RAHLO2 may not be called
 | 
|---|
| 107 |  ; 09/07/2005 108405 KAM- Removed ('$D(RADENDUM)#2) from next line
 | 
|---|
| 108 |  I $G(RATELE),'$D(RADENDUM),'$D(^TMP("RARPT-REC",$J,RASUB,"RADX")) D  ;Patch 84
 | 
|---|
| 109 |  .I RASTAT="R" S:$D(RATELEDR) ^TMP("RARPT-REC",$J,RASUB,"RADX",1)=RATELEDR Q
 | 
|---|
| 110 |  .S:$D(RATELEDF) ^TMP("RARPT-REC",$J,RASUB,"RADX",1)=RATELEDF
 | 
|---|
| 111 |  D:$D(^TMP("RARPT-REC",$J,RASUB,"RADX")) DIAG^RAHLO2 Q:$D(RAERR)  ; DX code check took out - &('$D(RADENDUM)#2)
 | 
|---|
| 112 |  ; edit sec Dx codes if they exist for non-addendums
 | 
|---|
| 113 |  ; 09/07/2005 108405 KAM - Removed ('$D(RADENDUM)#2)from next line
 | 
|---|
| 114 |  I $D(RASECDX) D SECDX^RAHLO2 Q:$D(RAERR)
 | 
|---|
| 115 |  S B=0 F A="I","R" D  Q:$D(RAERR)
 | 
|---|
| 116 |  . Q:A="R"&('$D(^TMP("RARPT-REC",$J,RASUB,"RATXT")))  ; no rpt text
 | 
|---|
| 117 |  . Q:A="I"&('$D(^TMP("RARPT-REC",$J,RASUB,"RAIMP")))  ; no imp text
 | 
|---|
| 118 |  . S B=$$TEXT^RAHLO3(A)
 | 
|---|
| 119 |  . S:'B RAERR=$$ERR^RAHLO2(A)
 | 
|---|
| 120 |  . Q
 | 
|---|
| 121 |  I $G(RATELE),$G(RARPT) D  Q:$D(RAERR)  ;PATCH 84
 | 
|---|
| 122 |  .I $D(^RARPT(RARPT,0)) D LOCK^DILF($NA(^RARPT(RARPT))) E  S RAERR="Report: "_$P($G(^RARPT(RARPT,0)),"^")_" Locked on VISTA site" Q
 | 
|---|
| 123 |  .L -^RARPT(RARPT)
 | 
|---|
| 124 |  I $G(RATELE),$L($G(RATELEPI)),RATELEPI'?10N S RAERR="Incorrect Teleradiologist's NPI: "_RATELEPI Q
 | 
|---|
| 125 |  D RPTSTAT^RAHLO3 ; determine the status of the report
 | 
|---|
| 126 |  D FILE^RAHLO1:'$D(RAERR)
 | 
|---|
| 127 |  Q
 | 
|---|