RAEDCN ;HISC/CAH,FPT,GJC,SS AISC/MJK,RMO-Edit Exams by Case Number ;1/11/02 11:15 ;;5.0;Radiology/Nuclear Medicine;**5,13,10,18,28,31,34,45,85**;Mar 16, 1998;Build 4 ; ; 06/11/2007 KAM/BAY RA*5*85 Remedy Call 174790 Change Exam Cancel ; to allow only descendent exams with stub report ; ;last modified by SS JUNE 21,2000 for P18 START D SET^RAPSET1 I $D(XQUIT) K XQUIT,RAFLG,RADR,POP,RAQUICK Q START1 D ^RACNLU G Q:X="^" I RADR="[RA DIAGNOSTIC BY CASE]" N RAPRTSET,RAMEMARR,RA3 D EN2^RAUTL20(.RAMEMARR) S RA3=99 I RAPRTSET W ! D WHYMSG2^RASTED G Q ;skip edit because member of set =2 I $D(^RA(72,"AA",RAIMGTY,9,+RAST)),'$D(^XUSEC("RA MGR",+$G(DUZ))) W !!?3,$C(7),"You do not have the appropriate access privileges to edit completed exams." G START1 I $D(^RA(72,"AA",RAIMGTY,0,+RAST)) W !!?3,$C(7),"Exam has been 'cancelled' therefore it cannot be edited." G START1 I RADR="[RA DIAGNOSTIC BY CASE]",$D(^RARPT(RARPT,0)),$P(^(0),"^",5)="V" W !!?3,$C(7),"A report has been verified for this exam, therefore it cannot be edited.",! G START S DA=RADFN,DIE("NO^")="OUTOK",DIE="^RADPT(",DR=RADR I $D(RAFLG("EDIT"))!($D(RAFLG("DIAG"))) D G:+$G(RAXIT) START1 . S RADADA=RADTI,RADIE="^RADPT("_RADFN_",""DT""," . S RAXIT=$$LOCK^RAUTL12(RADIE,RADADA) . Q I RADR="[RA EXAM EDIT]" D . N RADISPLY . S RADISPLY=$G(^RAMIS(71,+$P($G(^RADPT(+RADFN,"DT",+RADTI,"P",+RACNI,0)),U,2),0)) ; set $ZR to 71 for prccpt^radd1, not call raprod since diff col . S RADISPLY=$$PRCCPT^RADD1() . W !,?24,RADISPLY .; .;save 'before' CM data value to compare against the possible 'after' .;value .D TRK70CMB^RAMAINU(RADFN,RADTI,RACNI,.RATRKCMB) ;RA*5*45 .; . Q D:RADR'="[RA NO PURGE SPECIFICATION]" SVBEFOR^RAO7XX(RADFN,RADTI,RACNI) ;P18 save before edit to compare it in RAUTL1 later D ^DIE K DIE("NO^"),DE,DQ,DIE,DR,RAZCM D:RADR'="[RA NO PURGE SPECIFICATION]" UP1^RAUTL1 ; ;1) check data consistency between 'CONTRAST MEDIA USED' & 'CONTRAST ;MEDIA' ;2) check 'before' CM data against 'after' CM data, file in audit log ;if necessary. Remember, contrast media asked when in input template: ;RA EXAM EDIT (RA*5*45) I RADR="[RA EXAM EDIT]" D .S RACMDA=RACNI,RACMDA(1)=RADTI,RACMDA(2)=RADFN .D XCMINTEG^RAMAINU1(.RACMDA) ;1 .D TRK70CMA^RAMAINU(RADFN,RADTI,RACNI,RATRKCMB) ;2 .K RACMDA Q ; I $D(RAFLG("EDIT"))!($D(RAFLG("DIAG"))) D UNLOCK^RAUTL12(RADIE,RADADA) K RATRKCMB,RADUZ,RAZZ W ! G START1:'+$G(RAXIT) ; Q K %,%DT,%W,%X,%Y,%Y1,A,C,D0,D1,D2,DA,DIC,DIE,DIV,DK,I,ORIFN,ORVP,POP,RACN,RACNI,RACS,RACT,RADADA,RADATE,RADFN,RADIE,RADIV,RADR,RADTE,RADTI,RAEXFM,RAEXLBLS,RAFIN,RAFL,RAFLG,RAFLH,RAFLHFL,RAHEAD,RAI,RAJ K RAMES,RANME,RANUM,RAOIFN,RAOR,RAORDIFN,RAOREA,RAORIFN,RAOSEL,RAOSTS,RAPOP,RAPRI,RAPRC,RAQUICK,RAPRIT,RARPT,RARPTZ,RASN,RASSN,RAST,RASTI,RAVW,X,XQUIT,VAINDT,VADMVT,Y,^TMP($J,"RAEX") K %H,%I,D,D3,DDER,DI,DIW,DIWF,DIWI,DIWL,DIWR,DIWT,DIWTC,DIWX,DN,GMRAL K J,SDCLST,R1,RA,RACANC,RACN0,RACPT,RACPTNDE,RADA,RAEND,RAFELIG,RAFST K RAIX,RAN,RAOBR4,RAPRCNDE,RAPROC,RAPROCIT,RAPRV,RAXIT,VA,VADM,VAERR,Z K DFN,DIPGM,DISYS,DQ,DR,HLN,HLRESLT,HLSAN,RAAFTER,RABEFORE,X0 K DLAYGO,DDH,RADFLTP Q ; DIAG N RADIAG,RAXIT S RAXIT=0,RAFLG("DIAG")="",RADR="[RA DIAGNOSTIC BY CASE]" G START ; SAVE S RADR="[RA NO PURGE SPECIFICATION]" G START ; EDIT ; Case No. Exam Edit N RAEDIT,RAXIT N RAREM,RANUZD1,RAPSDRUG,RA00,RADIOPH,RALOW,RAHI,RADRAWN,RAASK,RADOSE,RASKMEDS,RAWHICH ;these are used by the edit template S RAXIT=0,RAFLG("EDIT")="",RAQUICK=1,RADR="[RA EXAM EDIT]" G START ; CANCEL D SET^RAPSET1 I $D(XQUIT) K XQUIT Q S RAXIT=$$CKREASON^RAEDCN1("C") I RAXIT K RAXIT Q ;P18 D ^RACNLU G Q:X="^" I $D(^RA(72,"AA",RAIMGTY,0,+RAST)) W !?3,$C(7),"This exam has already been cancelled!" G Q I $D(^RA(72,+RAST,0)),$P(^(0),"^",6)'="y" W !?3,$C(7),"This exam is in the '",$P(^(0),"^"),"' status and cannot be 'CANCELLED'." G Q ; 06/11/2007 KAM/BAY *85 Added descendent check to next line ASKIMG I RARPT,($$STUB^RAEDCN1(RARPT)),($$PSET^RAEDCN1(RADFN,RADTI,RACNI)) D G:"Nn"[$E(X) Q G:"Yy"[$E(X) ASKCAN W:X'["?" $C(7) W !!?3,"Enter 'YES' to cancel a descendent exam with images, or 'NO' not to." G ASKIMG . S X=RANME_"'s Case No. "_$E(RADTE,4,7)_$E(RADTE,1,2)_"-"_RACN . W !!?10,"----------------------------------",$C(7) . W !?10,X . W !?10,"This descendent exam has associated images.",$C(7) . W !?10,"----------------------------------",$C(7) . I '$D(^XUSEC("RA MGR",DUZ)) D S X="N" Q .. W !!?3,"** You do not have the RA MGR key to cancel an exam with images. **",$C(7) .. R !!?10,"Press RETURN to continue.",X:DTIME .. Q . R !!,"Do you really want to cancel this exam with images? NO//",X:DTIME S:'$T!(X="")!(X["^") X="N" . Q I RARPT W !?3,$C(7),"A report has been filed for this case. Therefore cancellation is not allowed!" G Q ASKCAN R !!,"Do you wish to cancel this exam now? NO// ",X:DTIME S:'$T!(X="")!(X["^") X="N" G Q:"Nn"[$E(X) I "Yy"'[$E(X) W:X'["?" $C(7) W !!?3,"Enter 'YES' to cancel this exam, or 'NO' not to." G ASKCAN N REM ;used for remarks within edit template L +^RADPT(RADFN):1 I '$T W !,$C(7),"Someone else is editing the patient you selected",!,"Please try later" K RADTE,RACN,RAPOP,RADUZ G Q S DA=RADFN,DR="[RA CANCEL]",DIE="^RADPT(" D ^DIE K DE,DQ,DIE,DR K RADTE,RACN,RAPOP,RADUZ ;moved from edit template PACS I '$D(Y),$D(RAFIN) W !?10,"...cancellation complete." D DELPNT^RAUTL20(RADFN,RADTI,RACNI),^RAORDC,CANCEL^RAHLRPC L -^RADPT(RADFN) G Q ; DUP ; Option: RA FLASH N RAREGX,RAYN D SET^RAPSET1 I $D(XQUIT) K XQUIT,POP Q DUP1 D ^RACNLU G Q:X="^" G Q:'$D(^RADPT(RADFN,"DT",RADTI,0)) S RAREGX(0)=$G(^RADPT(RADFN,"DT",RADTI,0)) S RAREGX(4)=+$P(RAREGX(0),"^",4) I +$G(RAMLC)'=RAREGX(4) D I $P(RAYN,"^",2) D Q QUIT . W !!?3,"Your sign-on location is: " . W $P($G(^SC(+$G(^RA(79.1,+$G(RAMLC),0)),0)),"^")_". The location" . W !?3,"of case ",RACN," is " . W $P($G(^SC(+$G(^RA(79.1,RAREGX(4),0)),0)),"^"),".",! . K DIR,DIROUT,DIRUT,DTOUT,DUOUT S DIR(0)="Y",DIR("B")="Yes" . S DIR("?")="Enter 'Y'es to switch locations or 'N'o exit the option." . S DIR("A")="Do you wish to switch Imaging Locations" D ^DIR . S RAYN=+Y_"^"_$S($D(DIRUT):1,1:0) . K DIR,DIROUT,DIRUT,DTOUT,DUOUT Q:'+RAYN ; quit if no . D KILL^RAPSET1,SET^RAPSET1 ; else switch locations . I $D(XQUIT) S $P(RAYN,"^",2)=1 K XQUIT . Q S ION=$P(RAMLC,"^",3) ; imaging location flash card printer (if any) G Q:'$D(^RADPT(RADFN,"DT",RADTI,"P",RACNI,0)) S Y=^(0),Y=$S($D(^RAMIS(71,+$P(Y,"^",2),0)):$P(^(0),"^",3),1:"") ; if Y, then convert the pointer value 'Y' to the .01 value of ; the procedure flash card printer (if any) I Y]"",$D(^%ZIS(1,+Y,0)) D . S Y(0)=$$GET1^DIQ(3.5,+Y,.01) ; .01 value for proc flash card printer . S:Y(0)'=$P(RAMLC,"^",3) ION=Y(0) K Y(0) . ; if flash card printer for the imaging location differs from . ; the procedure flash card printer, default (print to) to the flash . ; card printer for the procedure. . Q S RAMES="W !!,""Duplicates queued to print on "",ION,"".""",RAFLH=$S($P(RAMLC,"^",7):$P(RAMLC,"^",7),1:1),RAEXFM=$S($P(RAMLC,"^",9):$P(RAMLC,"^",9),1:1),RAFLHFL=RACNI FLH ; Flash Cards R !,"How many flash cards? 1// ",X:DTIME G DUP1:'$T!(X["^") S:X="" X=1 S RANUM=X I '(RANUM?.N)!(RANUM>20) W !?3,$C(7),"Must be a whole number less than 21!" G FLH EXM ; Exam Labels R !,"How many exam labels? 1// ",X:DTIME G DUP1:'$T!(X["^") S:X="" X=1 S RAEXLBLS=X I '(RAEXLBLS?.N)!(RAEXLBLS>20) W !?3,$C(7),"Must be a whole number less than 21!" G EXM S IOP="Q" S:ION]"" RADFLTP=ION K RAFL D Q^RAFLH,Q G DUP1 ; SETVARS ; Setup key Rad/Nuc Med variables I $O(RACCESS(DUZ,""))="" D SETVARS^RAPSET1(0) Q:'($D(RACCESS(DUZ))\10) ; user does not have location access I $G(RAIMGTY)="" D SETVARS^RAPSET1(1) K:$G(RAIMGTY)="" XQUIT Q