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

RASTREQ.m

Go to the documentation of this file.
  1. RASTREQ ;HISC/CAH,GJC AISC/MJK-Status Requirements Check Routine ;04 Aug 2017 10:01 AM
  1. ;;5.0;Radiology/Nuclear Medicine;**1,10,23,40,56,99,90,137**;Mar 16, 1998;Build 4
  1. ;Supported IA #10104 UP^XLFSTR
  1. ;Supported IA #1367 LKUP^XPDKEY
  1. ;Supported IA #10060 ^VA(200
  1. ;Supported IA #10076 ^XUSEC(
  1. ;Supported IA #2056 GET1^DIQ and GETS^DIQ
  1. ; Called by
  1. ; (1) Stat Track's [RA STATUS CHANGE]'s fld EXAM STATUS' input transform
  1. ; (2) ASK+22^RASTED, if user "^" out of stat trk editing
  1. ; (3) Cancel an Exam's [RA CANCEL]'s fld EXAM STATUS' input transform
  1. ; (4) Enter Last Past Visit Before DHCP's [RA LAST PAST VISIT]'s ""
  1. ;
  1. ; Instead of using RAIMGTY, recalculate
  1. ; the imaging type using the imaging type on the exam node because
  1. ; status updating through report entry/edit, batch verify, and several
  1. ; other options is NOT screened by sign-on imaging type, so does not
  1. ; stay the same through a user's session.
  1. ;
  1. ; 'RAMES1' is used to display which Exam Status required fields are
  1. ; not populated. This only applies to the 'Status Tracking Of Exams'
  1. ; option.
  1. ;
  1. ; If tracking ^-out, this rtn would be called outside of edt tmpl,
  1. ; and thus the DA vars would not be defined, so we need to set them here
  1. ;
  1. N RASAVY M RASAVY=Y ;save the value of Y, patch #90
  1. S:'$D(DA)#2 DA=RACNI S:'$D(DA(1))#2 DA(1)=RADTI S:'$D(DA(2))#2 DA(2)=RADFN
  1. ; If Fileman enter/edit, we need to define RADFN, RADTI, RACNI so the
  1. ; nuc med checks won't bomb
  1. S:'$D(RACNI)#2 RACNI=DA S:'$D(RADTI)#2 RADTI=DA(1) S:'$D(RADFN)#2 RADFN=DA(2)
  1. ;
  1. S RAIMGTYI=+$P($G(^RADPT(DA(2),"DT",DA(1),0)),U,2),RAIMGTYJ=$P($G(^RA(79.2,+RAIMGTYI,0)),U,1),RASAVTYJ=RAIMGTYJ
  1. S RAMES1="W:$G(K)=$P($G(^RA(72,+$G(RANXT72),0)),U,3)&('$D(ZTQUEUED)#2) !?3,""No '"",RAZ,""'"",?35,"" entered for this exam.""" ; display if at the ranext exm stat level
  1. S RAXX=+$G(X)
  1. I '$D(^RA(72,RAXX,0))!(RAIMGTYJ']"") D M Y=RASAVY Q
  1. . K X W:'$D(ZTQUEUED)#2 !?3,"Error: cannot determine Imaging Type of exam. Contact IRM."
  1. . K RAMES1,RAXX
  1. . Q
  1. N RA,RASN,RASTI,RADES,RAOKAY,RA3
  1. ; RADES = order seq. desired, RAOKAY= actual order seq. okay'd
  1. S X1=$G(^RA(72,RAXX,0)),RADES=$P(X1,U,3)
  1. I $$LKUP^XPDKEY(+$P(X1,"^",4))]"",'$D(^XUSEC($$LKUP^XPDKEY(+$P(X1,"^",4)),DUZ)) K X W:'$D(ZTQUEUED)#2 !?3,"You do not have the proper access privileges to ",!?3,"change this exam to this status" M Y=RASAVY Q
  1. S RAJ=^RADPT(DA(2),"DT",DA(1),"P",DA,0),RAOR=-1
  1. S RABEFORE=$P($G(^RA(72,+$P(RAJ,U,3),0)),U,3) ; current order seq
  1. ; Don't need to set RAORDIFN,RACS,RAPRIT,RAF5
  1. I '$D(^RA(72,"AA",RAIMGTYJ,0,RAXX)) D LOOP^RASTREQ1 S RAIMGTYJ=RASAVTYJ
  1. I $D(^RA(72,"AA",RAIMGTYJ,0,RAXX)) D CANCEL^RASTREQ1
  1. S RAIMGTYJ=RASAVTYJ
  1. ; Can't use X to determine if status change to next was successful
  1. ; due to looping thru all status levels for this img type
  1. ; chk if calculated order is at NEXT or higher level
  1. ; RAAFTER is set in rastreq1; it has 2 meanings :
  1. ; upon return from rastreq1, RAAFTER means highest seq order qualified
  1. ; upon exit from this rtn, RAAFTER means actual seq order used
  1. I RABEFORE<RAAFTER D G MSG
  1. . I RADES<RAAFTER S RAOKAY=RADES
  1. . E S RAOKAY=RAAFTER
  1. . Q
  1. I RAAFTER<RABEFORE D G MSG
  1. . I RADES<RAAFTER S RAOKAY=RADES
  1. . E S RAOKAY=RAAFTER
  1. . Q
  1. ; at this point RAAFTER=RABEFORE
  1. I RADES<RAAFTER S RAOKAY=RADES
  1. E S RAOKAY=RABEFORE
  1. MSG I RAOKAY=RABEFORE K X W:'$D(ZTQUEUED)#2 !?5," ...exam status not changed" G KOUT2
  1. S X=$O(^RA(72,"AA",RAIMGTYJ,RAOKAY,0))
  1. S:$D(RANEXT) RANEXT=^RA(72,+X,0) ;set existing RANEXT to ok'd status
  1. I RAOKAY<RABEFORE W:'$D(ZTQUEUED)#2 !?5," ...exam status backed down to '",$P($G(^RA(72,+X,0)),U),"'" G KOUT2
  1. I RAOKAY<RADES W:'$D(ZTQUEUED)#2 !!?5," ...though upgraded, new status level (",$P($G(^RA(72,+$O(^RA(72,"AA",RAIMGTYJ,RAOKAY,0)),0)),U),")",!?5,"is not as high as the desired level (",$P($G(^RA(72,+$O(^RA(72,"AA",RAIMGTYJ,RADES,0)),0)),U),")",!
  1. KOUT1 ; check for higher qualifying status(es)
  1. G:RAOKAY'<RAAFTER!(RAOKAY=9) KOUT2 S RA3=RAOKAY
  1. W !!,"This case also qualifies for higher status(es) :",!
  1. F S RA3=$O(^RA(72,"AA",RAIMGTYJ,RA3)) Q:RA3="" Q:RA3>RAAFTER W:'$D(ZTQUEUED)#2 ?$X+4,$P($G(^RA(72,$O(^(RA3,0)),0)),U)
  1. W:'$D(ZTQUEUED)#2 !!,"Since Status Tracking can only upgrade one status at a time,",!,"please edit this exam again.",!
  1. KOUT2 S RAAFTER=RAOKAY ;return as actual seq order used, not nec. highest
  1. K RAIMGTYI,RAIMGTYJ,RAMES1,RAZ,RAXX,RAJ,RAS,RAK,RAE,X1,RASAVTYJ
  1. M Y=RASAVY
  1. Q
  1. ;
  1. 1 ;Technologist Check
  1. N DIERR
  1. S RA("TECH")="" I $O(^RADPT(DA(2),"DT",DA(1),"P",DA,"TC",0))>0 S RA("TECH")=+^($O(^(0)),0) S RA("TECH")=$$GET1^DIQ(200,RA("TECH")_",",.01)
  1. I RA("TECH")']"" K X S RAZ="technologist" X:$D(RAMES1) RAMES1
  1. K RA("TECH") Q
  1. ;
  1. 2 ;Interpreting Physician Check
  1. N DIERR
  1. I $$GET1^DIQ(200,$P(RAJ,"^",12)_",",.01)="",$$GET1^DIQ(200,$P(RAJ,"^",15)_",",.01)="" K X S RAZ="interpreting staff or resident" X:$D(RAMES1) RAMES1
  1. Q
  1. ;
  1. 3 ;Detailed Procedure Check
  1. S RAZ="detailed procedure" I '$D(^RAMIS(71,+$P(RAJ,"^",2),0)) K X X:$D(RAMES1) RAMES1 Q
  1. S RAJ1=$G(^RAMIS(71,+$P(RAJ,"^",2),0)) I "DS"'[$P(RAJ1,"^",6) K X X:$D(RAMES1) RAMES1 Q
  1. S RAZ="detailed procedure (no CPT code)" I $P(RAJ1,"^",9)']"" K X X:$D(RAMES1) RAMES1 Q
  1. Q
  1. ;
  1. 4 ;Film Data Check
  1. I '$O(^RADPT(DA(2),"DT",DA(1),"P",DA,"F",0)) K X S RAZ="film data" X:$D(RAMES1) RAMES1
  1. Q
  1. ;
  1. 5 ;Diagnostic Code Check
  1. I '$D(^RA(78.3,+$P(RAJ,"^",13),0)) K X S RAZ="diagnostic code" X:$D(RAMES1) RAMES1
  1. Q
  1. ;
  1. 6 ;Camera/Equipment/Room Check
  1. S RAE=$S($D(RAMDV):$P(RAMDV,"^",9),1:1) I RAE,'$D(^RA(78.6,+$P(RAJ,"^",18),0)) K X S RAZ="camera/equip/room" X:$D(RAMES1) RAMES1
  1. Q
  1. ;
  1. 11 ;Report Entered and not just a stub rec for Img/PACS Check
  1. I '$D(^RARPT(+$P(RAJ,"^",17),0)) G NORPT
  1. ; since there's a rpt ptr, must check if the rpt is just a stub rpt
  1. N RA17,RA0 ; use logic from RAREG
  1. S RA17=+$P(RAJ,"^",17)
  1. I $$STUB^RAEDCN1(RA17) G NORPT ; rpt is an image stub
  1. Q
  1. NORPT ; either no report yet, or report is stub
  1. K X S RAZ="report" X:$D(RAMES1) RAMES1
  1. Q
  1. ;
  1. 12 ;Report Verified Check
  1. D 11:$P(RAS,"^",11)'="Y" I $D(^RARPT(+$P(RAJ,"^",17),0)),$P(^(0),"^",5)'="V" K X S RAZ="report verification" X:$D(RAMES1) RAMES1
  1. Q
  1. ;
  1. 16 ;Impression Entry Check
  1. ; In Phase 1, for Elec. filed rpts, skip this even if div. param requires it
  1. I $D(^RARPT(+$P(RAJ,"^",17),0)),$P(^(0),"^",5)="EF" Q
  1. I $O(^RARPT(+$P(RAJ,"^",17),"I",0))'>0 K X S RAZ="impression" X:$D(RAMES1) RAMES1
  1. Q
  1. 13 ;Procedure Modifers Check
  1. I '$O(^RADPT(DA(2),"DT",DA(1),"P",DA,"M",0)) K X S RAZ="procedure modifier" X:$D(RAMES1) RAMES1
  1. Q
  1. 14 ;CPT Modifiers Check
  1. I '$O(^RADPT(DA(2),"DT",DA(1),"P",DA,"CMOD",0)) K X S RAZ="CPT modifiers" X:$D(RAMES1) RAMES1
  1. Q
  1. ;
  1. 32 ;Pregnancy screen check - P137/KLM
  1. I $$PTSEX^RAUTL8(DA(2))'="F" Q
  1. N RAPTAGE
  1. S RAPTAGE=$$PTAGE^RAUTL8(DA(2),"") I ((RAPTAGE<12)!(RAPTAGE>55)) Q
  1. I $D(^RARPT(+$P(RAJ,"^",17),0)),$P(^(0),"^",5)="EF" D Q ;outside report
  1. .N RAFDA
  1. .;If this is an outside report and nothing is entered
  1. .;for pregnancy screen, we stuff a 'u'(unknown) and
  1. .;'OUTSIDE STUDY' to keep it consistent with the importer.
  1. .Q:$P(^RADPT(DA(2),"DT",DA(1),"P",DA,0),U,32)]""
  1. .S RAFDA(70.03,DA_","_DA(1)_","_DA(2)_",",32)="u"
  1. .S RAFDA(70.03,DA_","_DA(1)_","_DA(2)_",",80)="OUTSIDE STUDY"
  1. .D FILE^DIE("K","RAFDA")
  1. .K RAFDA
  1. .Q ;end outside report logic
  1. ;otherwise, if not defined, don't complete
  1. I $$GET1^DIQ(70.03,DA_","_DA(1)_","_DA(2),32)']"" K X S RAZ="Pregnancy screen" X:$D(RAMES1) RAMES1
  1. K RAPTAGE
  1. Q
  1. ;
  1. HELP ; Called from 'Help Text' node in DD(70.03,3,4).
  1. N E,RA
  1. S RAJ=$G(^RADPT(DA(2),"DT",DA(1),"P",DA,0))
  1. S RAIMGTYI=+$P($G(^RADPT(DA(2),"DT",DA(1),0)),U,2),RAIMGTYJ=$P($G(^RA(79.2,+RAIMGTYI,0)),U,1)
  1. I RAIMGTYJ']"" W !,"ERROR: Cannot determine imaging type of exam!" K FL,K,N,RAIMGTYI,RAIMGTYJ,RAS,RAJ Q
  1. W !,"This exam meets the requirements for the following statuses:"
  1. F K=0:0 S K=$O(^RA(72,"AA",RAIMGTYJ,K)) Q:K'>0 D
  1. . S X="",E=+$O(^RA(72,"AA",RAIMGTYJ,K,0)) Q:E'>0
  1. . I $D(^RA(72,E,0)) D
  1. .. S RA(0)=$G(^RA(72,E,0)),N=$P(RA(0),U),RAS=$G(^RA(72,E,.1))
  1. .. I $L(RAS) D HELP1 I $D(X) W !?10,N S FL="" ;removed D 3, done inside HELP1
  1. .. Q
  1. . Q
  1. W:'$D(FL) !?10,"Does not meet the requirements of any status."
  1. W ! K RAS,RAJ,N,K,FL,RAIMGTYI,RAIMGTYJ
  1. Q
  1. HELP1 ; Called from 'HELP' above and 'STUFF^RASTREQ1'
  1. ; 'RAJ' -> 0 node of the examination
  1. ; 'E' -> ien of the examination status
  1. ; Both 'RAJ' & 'E' set in 'HELP' & 'STUFF^RASTREQ1'
  1. ;
  1. N RADIO,RADIOUZD,RAS5 S RADIO=$S($G(^RA(72,E,.5))]"":$G(^(.5)),1:"N")
  1. S:$P($G(^RA(79.2,+RAIMGTYI,0)),"^",5)="Y" RADIOUZD=""
  1. ;
  1. ; Phase 1 Outside Reporting 100% outside work, skip all except Diag. Code
  1. I $D(^RARPT(+$P(RAJ,"^",17),0)),$P(^(0),"^",5)="EF" S RAS5=$P(RAS,U,5),RAS="",$P(RAS,U,5)=RAS5 K RADIOUZD
  1. ;
  1. F RAK=1:1 Q:$P(RAS,"^",RAK,99)']"" D:$P(RAS,"^",RAK)="Y" @RAK
  1. I $D(X),$P(RAS,"^",3)'="Y",$D(^RA(72,"AA",RAIMGTYJ,9,E)) D 3
  1. I $D(X),$P(RAS,"^",16)'="Y",$D(^RA(72,"AA",RAIMGTYJ,9,E)),$D(^RA(79,+$P(^RADPT(DA(2),"DT",DA(1),0),"^",3),.1)),$P(^(.1),"^",16)="Y" D 16
  1. I $D(X),$D(^RA(72,"AA",RAIMGTYJ,9,E)) D 32 ;Check Preg screen -P137 /KLM
  1. I $D(RADIOUZD) D ;if Radiopharm Used, then check req'd NucMed flds
  1. . D EN1^RASTREQN(RADIO,RAJ)
  1. . I $D(X),($$UP^XLFSTR($P($G(^RA(72,E,.6)),"^",11)="Y")) D EN1^RADOSTIK(RADFN,RADTI,RACNI)
  1. . Q
  1. Q