VistA-WorldVistAEHR/r/CONSULT_REQUEST_TRACKING-GM.../GMRCEDIT.m

68 lines
2.9 KiB
Mathematica

GMRCEDIT ;SLC/DCM,JFR - EDIT CANCELLED CONSULT-MAIN DRIVER ; 11/25/2000
;;3.0;CONSULT/REQUEST TRACKING;**1,5,10,18,47**;DEC 27, 1997
; Patch 18 newed variable DFN and added line tag VALPROV
; This routine invokes IA #2638,#2713,#2801,#10060
EN(XQCON,XQDFN) ; -- main entry point for GMRCEDIT
;XQDFN=XQAID XQCON=XQADATA from CPRS alerts
N GMRCNOTF,GMRCCORY,GMRCDA,GMRCO,DFN
S DFN=$P(XQDFN,",",2),GMRCDA=$S(XQCON=+XQCON:+XQCON,+$P($P(XQCON,",",2),";",2):+$P($P(XQCON,",",2),";",2),XQCON?1N.N1",GMRC".E:+XQCON,1:$P($P(XQCON,";",3),",",1))
S GMRCNOTF=+$P(XQDFN,",",3)
I '+GMRCDA S XQAKILL=$$XQAKILL^ORB3F1(GMRCNOTF) D DEL^ORB3FUP1(.GMRCCORY,XQDFN),END Q
S GMRCDAP=GMRCDA
I '$$LOCK^GMRCA1(+GMRCDAP) D END Q
N GMRCLCK S GMRCLCK=1 ;JFR
;S GMRCDAP=GMRCDA I +$P(^GMR(123,+GMRCDA,0),"^",5)
S GMRCOK=$P(^ORD(100.01,$P(^GMR(123,+GMRCDA,0),"^",12),0),"^",1),GMRCOK=$S(GMRCOK["CANCELLED":1,1:0)
I '$D(GMRCOK) S XQAKILL=$$XQAKILL^ORB3F1(GMRCNOTF) D DEL^ORB3FUP1(.GMRCCORY,XQDFN),END Q
S GMRCPNM=$P(^DPT(DFN,0),"^",1)
S GMRCPROV=$P($G(^GMR(123,GMRCDA,0)),"^",14) I 'GMRCPROV S GMRCPROV=$P($G(^GMR(123,GMRCDA,12)),"^",6)
I +GMRCPROV S GMRCPROV=$P(^VA(200,GMRCPROV,0),"^",1)
D EN^VALM("GMRC EDIT CONSULT") ;********* CALL TO LIST MANAGER
I $S($O(GMRCED(0)):1,$D(^TMP("GMRCED",$J)):1,1:0),'$D(GMRCRSUB) D
. N DIR,DTOUT,DUOUT,X,Y
. W !,$C(7),"This Consult Has Not Been Resubmitted!!"
. W !,"Resubmit Or All Edits Will Be Lost!!",!!
. S DIR(0)="Y",DIR("A")="Do you wish to resubmit now? ",DIR("B")="YES"
. D ^DIR I $D(DUOUT)!($D(DTOUT))!(Y<1) W !!,"No changes made!" Q
. D EN^GMRCEDT2(GMRCDAP)
. Q
S XQAKILL=$$XQAKILL^ORB3F1(GMRCNOTF) D DEL^ORB3FUP1(.GMRCCORY,XQDFN)
D END
Q
;
HDR ; -- header code
S VALMHDR(1)="Edit Consult for Patient "_GMRCPNM_" Consult Number: "_GMRCDA
S VALMHDR(2)="Sending Provider: "_GMRCPROV
Q
;
INIT ; -- init variables and list array
K ^TMP("GMRCR",$J,"EDLIST")
S DSPLINE=0,DATA="",VALMAR="^TMP(""GMRCR"",$J,""EDLIST"")"
F LINE=1:1:GMRCLNO S DSPLINE=$O(^TMP("GMRCR",$J,"ED",DSPLINE)) Q:DSPLINE=""!(DSPLINE?1A.E) S DATA=^(DSPLINE,0) D SET^VALM10(LINE,DATA)
S VALMCNT=GMRCLNO,VALMPGE=1,XQORM("A")="Select Action: "
K DSPLINE,DATA,LINE
Q
;
HELP ; -- help code
S X="?" D DISP^XQORM1 W !!
Q
;
VALPROV(GMRCIEN) ; Check Provider or Update authority.
I DUZ=$P(^GMR(123,+GMRCIEN,0),"^",14) Q 1
I $$VALID^GMRCAU($P(^GMR(123,+GMRCIEN,0),"^",5)) Q 1
Q 0
EXIT ;
;Don't kill anything here
Q
END ; -- exit code
I $G(GMRCLCK) D UNLOCK^GMRCA1(+GMRCDAP) ;JFR
K ^TMP("GMRCR",$J,"EDLIST"),^TMP("GMRCR",$J,"ED")
K ^TMP("GMRCED",$J),^TMP("GMRCSUB",$J),^TMP("GMRCFLD20",$J)
K CMDA,DFN,DIC,DIE,DR,DA,FLDA,FLDNM,GMRCA,GMRCATN,GMRCD,GMRCDD,GMRCANS,GMRCDIAG,GMRCED,GMRCEDCM,GMRCIND,GMRCINO,GMRCKEEP,GMRCLNO,GMRCND,GMRCND1,GMRCO,GMRCOK,GMRCPC,GMRCPL,GMRCPR,GMRCPNM,GMRCPROC,GMRCPROV,GMRCREQ,GMRCRQT
K GMRCFLD,GMRCOUNT,GMRCRSUB,GMRCSS,GMRCURG,GMRCDA,GMRCDAP,GMRCDA1,ND,TRKDA,XQAKILL
Q
;
EXPND ; -- expand code
Q
;