GMRCSTS1 ;SLC/JFR,MA - GROUP UPDATE OF CONSULTS cont'd ;4/18/01 10:31
;;3.0;CONSULT/REQUEST TRACKING;**8,18,21,50**;DEC 27, 1997;Build 8
; Patch 18 modified PRTTSK to stop for acknowledgement between
; printing the report and continuing with the group update.
; Patch 21 moved the ^%ZISC up a few lines to correct a problem
; of menu going to the printer
; This routine invokes IA #2638
PROCESS(GMRCCVT,GMRCMT) ;Update consult status by service and date range
N GMRCO,GMRCSTS,GMRCTRLC,GMRCORNP,GMRCDEV,GMRCFF,GMRCAD,ORIFN
N GMRCOM1,ORIFN
Q:'GMRCCVT
I '$D(^TMP("GMRCLS",$J)) Q ;no entries to update
S GMRCIEN=0 F S GMRCIEN=$O(^TMP("GMRCLS",$J,GMRCIEN)) Q:'GMRCIEN D
. Q:'$L($G(^GMR(123,GMRCIEN,0)))
. D AUDIT(GMRCIEN,+GMRCCVT,.GMRCMT)
. D STSUPD(GMRCIEN,+GMRCCVT)
. D CPRSUPDT(GMRCIEN,+GMRCCVT)
Q
PRINT(GMRCM,GMRCCVT,GMRCSVC,GMRCMT,GMRCSTRT,GMRCSTOP,GMRCDO) ;untasked print of records to update
PRTTSK ; print the report then start the processing
; GMRCM= status of records to find A:active, P:pending, B:Both
; GMRCCVT= status to update records with 1:dc, 2:complete
; GMRCSVC= IEN from file 123.5
; GMRCMT= array (passed by reference) of comment to stuff in records
; GMRCSTRT= first entry date to find/update
; GMRCSTOP= last entry date to find/update
; GMRCDO= 1:print only, 2:print and update records
; GMRCSTAT= Status of consult for the report (P,A,S)
N GMRCIEN,GMRCDFN,GMRCPG,GMRCEND,GMRCSTAT
S GMRCIEN=0
U IO
D HDR(1) S GMRCPG=2
I '$D(^TMP("GMRCLS",$J)) D D END
. W !,"No records found meeting search criteria"
F S GMRCIEN=$O(^TMP("GMRCLS",$J,GMRCIEN)) Q:'GMRCIEN!($G(GMRCEND)) D
. I $Y>(IOSL-5) D HDR(GMRCPG) Q:$G(GMRCEND) S GMRCPG=GMRCPG+1
. Q:'$G(^GMR(123,GMRCIEN,0))
. I $P(^GMR(123,GMRCIEN,0),U,12)=1!($P(^(0),U,12)=2) Q
. W !,GMRCIEN,?8,$$FMTE^XLFDT(+^GMR(123,GMRCIEN,0))
. W ?29,$E($$GET1^DIQ(2,$P(^GMR(123,GMRCIEN,0),U,2),.01),1,26)
. W ?56,$$GET1^DIQ(2,$P(^GMR(123,GMRCIEN,0),U,2),.09)
. S GMRCSTAT=+^TMP("GMRCLS",$J,GMRCIEN)
. W ?70,$S(GMRCSTAT=5:"p",GMRCSTAT=6:"a",GMRCSTAT=8:"s",1:"?")
. W " to ",$S(+GMRCCVT=1:"dc",1:"c")
D ^%ZISC
I GMRCDO=2,'$D(ZTQUEUED) D ; Not task
. S DIR(0)="S^Y:To Update;N:To Quit without Updating"
. S DIR("A")="Enter update status "
. I ($D(DTOUT)!$D(DUOUT)!$D(DIRUT)!$D(DIROUT)) Q
. D ^DIR
. I Y="Y" D PROCESS(+GMRCCVT,.GMRCMT)
I GMRCDO=2,$D(ZTQUEUED) D PROCESS(+GMRCCVT,.GMRCMT) ; Tasked
END K ^TMP("GMRCLS",$J)
Q
;
HDR(PAGE) ; print the header for the report
I PAGE'=1,$E(IOST,1,2)["C-" N Y D I '+Y S GMRCEND=1 Q
. N DIR S DIR(0)="E" D ^DIR
W @IOF
W !,"Group status update of consults in file 123",?70,"Page: ",PAGE W:PAGE'=1 !
I PAGE=1 W !,?49,"Printed: ",$$FMTE^XLFDT($$NOW^XLFDT)
I PAGE=1 D UPDCRIT(GMRCCVT,GMRCM,GMRCSVC,.GMRCMT,GMRCSTRT,GMRCSTOP)
W !,"Consult",?70,"Status"
W !,"Number Requested Patient SSN Change"
W !,$$REPEAT^XLFSTR("-",79)
Q
GETENTS(SERV,STRDT,STPDT,SRCH) ;loop "AE" x-ref and dump into ^TMP
N IDT,IEN,STOPI,STRTI,STS,INDEX
W !!,"Searching database for entries matching search criteria",!
S STOPI=(9999999-STPDT)-1,STRTI=(9999999-STRDT)
F INDEX=1:1 Q:$P(SRCH,",",INDEX)="" D
. I $P(SRCH,",",INDEX)=+4 S SRCH="1,2,3,"
; Convert SRCH from 1,2,3 to 5,6,8 (pending,active,scheduled)
F INDEX=1:1 Q:$P(SRCH,",",INDEX)="" D
. I $P(SRCH,",",INDEX)=+1 S STS=+5 D GETDATA
. I $P(SRCH,",",INDEX)=+2 S STS=+6 D GETDATA
. I $P(SRCH,",",INDEX)=+3 S STS=+8 D GETDATA
GETDATA ; Write ^GMR(123,IEN,0) to TMP
S IDT=STOPI
F S IDT=$O(^GMR(123,"AE",SERV,+STS,IDT)) Q:'IDT!(IDT>STRTI) D
. S IEN=0 F S IEN=$O(^GMR(123,"AE",SERV,+STS,IDT,IEN)) Q:'IEN D
.. S ^TMP("GMRCLS",$J,IEN)=+STS_U_+^GMR(123,IEN,0)
.. W "."
Q
AUDIT(GMRCO,UPDSTS,GMRCOM) ;Update the processing activity of the consult
;GMRCO= IEN from file 123
;UPDSTS= 1 for DC ; 2 for COMPLETE
N DA,DIE,GMRCA,GMRCDT,GMRCSTS
S GMRCDT=$$NOW^XLFDT,GMRCA=$S(UPDSTS=1:6,1:10)
S GMRCSTS=$P(^GMR(123,GMRCO,0),U,12)
S:'$D(^GMR(123,+GMRCO,40,0)) ^(0)="^123.02DA^^"
S DA=$S($P(^GMR(123,+GMRCO,40,0),"^",3):$P(^(0),"^",3)+1,1:1),$P(^GMR(123,GMRCO,40,0),"^",3,4)=DA_"^"_DA
S DIE="^GMR(123,"_+GMRCO_",40,",DA(1)=+GMRCO
S DR=".01////^S X=GMRCDT;1////^S X=GMRCA;2////^S X=GMRCDT;3////^S X=DUZ;4////^S X=DUZ"
D ^DIE
S ^GMR(123,+GMRCO,40,DA,1,0)="^^1^1^"_GMRCDT_"^"
I $D(GMRCOM) D
. M ^GMR(123,+GMRCO,40,DA,1)=GMRCOM
I '$D(GMRCOM) D
. N COMMENT
. S COMMENT="Status updated from "
. S COMMENT=COMMENT_$P(^ORD(100.01,+GMRCSTS,0),"^",1)
. S COMMENT=COMMENT_" to "_$S(+UPDSTS=2:"COMPLETE",1:"DISCONTINUED")
. S COMMENT=COMMENT_" during group status update process."
. S ^GMR(123,+GMRCO,40,DA,1,1,0)=COMMENT
;Check for IFC and update accordingly
I $D(^GMR(123,+GMRCO,12)),$D(^(40,DA)) D TRIGR^GMRCIEVT(GMRCO,DA)
K DIE,GMRCA,GMRCDT
Q
STSUPD(GMRCO,UPDSTS) ;change status of consult to COMPLETE or DC
;GMRCO= IEN from file 123
;UPDSTS= 1 for DC ; 2 for COMPLETE
N DIE,DA,DR,GMRCLST,X
S GMRCLST=$S(UPDSTS=1:$O(^GMR(123.1,"B","DISCONTINUED",0)),UPDSTS=2:$O(^GMR(123.1,"B","COMPLETE/UPDATE",0)),1:99)
S DIE="^GMR(123,",DA=GMRCO
S DR="8////^S X=+UPDSTS;9////"_GMRCLST
D ^DIE
Q
CPRSUPDT(GMRCO,UPDSTS) ;Update CPRS order with new status
;GMRCO= IEN from file 123
;UPDSTS= status to update CPRS with
N GMRCDFN,CTRLCODE
S GMRCDFN=$P(^GMR(123,GMRCO,0),"^",2)
S CTRLCODE=$S(UPDSTS=1:"OD",1:"RE")
; send HL7 message to CPRS to update order status
D EN^GMRCHL7(GMRCDFN,+GMRCO,"","",CTRLCODE,DUZ,"","",1)
Q
UPDCRIT(UPD,STS,SVC,CMT,START,STOP) ;print update criteria on page 1
N INDEX,GMRCSTS
F INDEX=1:1 Q:$P(STS,",",INDEX)="" D
. I STS[+4 S GMRCSTS="Active, Pending, and Scheduled" Q
. I $P(STS,",",INDEX)=+1 S $P(GMRCSTS,",",INDEX)="Pending"
. I $P(STS,",",INDEX)=+2 S $P(GMRCSTS,",",INDEX)="Active"
. I $P(STS,",",INDEX)=+3 S $P(GMRCSTS,",",INDEX)="Scheduled"
W !,"Records will be updated for:"
W !,$$REPEAT^XLFSTR("-",78)
W !," Service: "_$$GET1^DIQ(123.5,SVC,.01)
W !," Beginning: "_$$FMTE^XLFDT(START)
W !," Ending: "_$$FMTE^XLFDT(STOP)
W !," Update: "_GMRCSTS_" "_" Consults"
W !," To: "_$S(+UPD=2:"COMPLETE",1:"DISCONTINUED")
I $D(CMT) W !," Update Comment:" D
. N I S I=0 F S I=$O(CMT(I)) Q:'I D
.. W !,CMT(I,0)
W !,$$REPEAT^XLFSTR("-",78),!
Q
GMRCSTS1 ;SLC/JFR,MA - GROUP UPDATE OF CONSULTS cont'd ;4/18/01 10:31
+1 ;;3.0;CONSULT/REQUEST TRACKING;**8,18,21,50**;DEC 27, 1997;Build 8
+2 ; Patch 18 modified PRTTSK to stop for acknowledgement between
+3 ; printing the report and continuing with the group update.
+4 ; Patch 21 moved the ^%ZISC up a few lines to correct a problem
+5 ; of menu going to the printer
+6 ; This routine invokes IA #2638
PROCESS(GMRCCVT,GMRCMT) ;Update consult status by service and date range
+1 NEW GMRCO,GMRCSTS,GMRCTRLC,GMRCORNP,GMRCDEV,GMRCFF,GMRCAD,ORIFN
+2 NEW GMRCOM1,ORIFN
+3 IF 'GMRCCVT
QUIT
+4 ;no entries to update
IF '$DATA(^TMP("GMRCLS",$JOB))
QUIT
+5 SET GMRCIEN=0
FOR
SET GMRCIEN=$ORDER(^TMP("GMRCLS",$JOB,GMRCIEN))
IF 'GMRCIEN
QUIT
Begin DoDot:1
+6 IF '$LENGTH($GET(^GMR(123,GMRCIEN,0)))
QUIT
+7 DO AUDIT(GMRCIEN,+GMRCCVT,.GMRCMT)
+8 DO STSUPD(GMRCIEN,+GMRCCVT)
+9 DO CPRSUPDT(GMRCIEN,+GMRCCVT)
End DoDot:1
+10 QUIT
PRINT(GMRCM,GMRCCVT,GMRCSVC,GMRCMT,GMRCSTRT,GMRCSTOP,GMRCDO) ;untasked print of records to update
PRTTSK ; print the report then start the processing
+1 ; GMRCM= status of records to find A:active, P:pending, B:Both
+2 ; GMRCCVT= status to update records with 1:dc, 2:complete
+3 ; GMRCSVC= IEN from file 123.5
+4 ; GMRCMT= array (passed by reference) of comment to stuff in records
+5 ; GMRCSTRT= first entry date to find/update
+6 ; GMRCSTOP= last entry date to find/update
+7 ; GMRCDO= 1:print only, 2:print and update records
+8 ; GMRCSTAT= Status of consult for the report (P,A,S)
+9 NEW GMRCIEN,GMRCDFN,GMRCPG,GMRCEND,GMRCSTAT
+10 SET GMRCIEN=0
+11 USE IO
+12 DO HDR(1)
SET GMRCPG=2
+13 IF '$DATA(^TMP("GMRCLS",$JOB))
Begin DoDot:1
+14 WRITE !,"No records found meeting search criteria"
End DoDot:1
DO END
+15 FOR
SET GMRCIEN=$ORDER(^TMP("GMRCLS",$JOB,GMRCIEN))
IF 'GMRCIEN!($GET(GMRCEND))
QUIT
Begin DoDot:1
+16 IF $Y>(IOSL-5)
DO HDR(GMRCPG)
IF $GET(GMRCEND)
QUIT
SET GMRCPG=GMRCPG+1
+17 IF '$GET(^GMR(123,GMRCIEN,0))
QUIT
+18 IF $PIECE(^GMR(123,GMRCIEN,0),U,12)=1!($PIECE(^(0),U,12)=2)
QUIT
+19 WRITE !,GMRCIEN,?8,$$FMTE^XLFDT(+^GMR(123,GMRCIEN,0))
+20 WRITE ?29,$EXTRACT($$GET1^DIQ(2,$PIECE(^GMR(123,GMRCIEN,0),U,2),.01),1,26)
+21 WRITE ?56,$$GET1^DIQ(2,$PIECE(^GMR(123,GMRCIEN,0),U,2),.09)
+22 SET GMRCSTAT=+^TMP("GMRCLS",$JOB,GMRCIEN)
+23 WRITE ?70,$SELECT(GMRCSTAT=5:"p",GMRCSTAT=6:"a",GMRCSTAT=8:"s",1:"?")
+24 WRITE " to ",$SELECT(+GMRCCVT=1:"dc",1:"c")
End DoDot:1
+25 DO ^%ZISC
+26 ; Not task
IF GMRCDO=2
IF '$DATA(ZTQUEUED)
Begin DoDot:1
+27 SET DIR(0)="S^Y:To Update;N:To Quit without Updating"
+28 SET DIR("A")="Enter update status "
+29 IF ($DATA(DTOUT)!$DATA(DUOUT)!$DATA(DIRUT)!$DATA(DIROUT))
QUIT
+30 DO ^DIR
+31 IF Y="Y"
DO PROCESS(+GMRCCVT,.GMRCMT)
End DoDot:1
+32 ; Tasked
IF GMRCDO=2
IF $DATA(ZTQUEUED)
DO PROCESS(+GMRCCVT,.GMRCMT)
END KILL ^TMP("GMRCLS",$JOB)
+1 QUIT
+2 ;
HDR(PAGE) ; print the header for the report
+1 IF PAGE'=1
IF $EXTRACT(IOST,1,2)["C-"
NEW Y
Begin DoDot:1
+2 NEW DIR
SET DIR(0)="E"
DO ^DIR
End DoDot:1
IF '+Y
SET GMRCEND=1
QUIT
+3 WRITE @IOF
+4 WRITE !,"Group status update of consults in file 123",?70,"Page: ",PAGE
IF PAGE'=1
WRITE !
+5 IF PAGE=1
WRITE !,?49,"Printed: ",$$FMTE^XLFDT($$NOW^XLFDT)
+6 IF PAGE=1
DO UPDCRIT(GMRCCVT,GMRCM,GMRCSVC,.GMRCMT,GMRCSTRT,GMRCSTOP)
+7 WRITE !,"Consult",?70,"Status"
+8 WRITE !,"Number Requested Patient SSN Change"
+9 WRITE !,$$REPEAT^XLFSTR("-",79)
+10 QUIT
GETENTS(SERV,STRDT,STPDT,SRCH) ;loop "AE" x-ref and dump into ^TMP
+1 NEW IDT,IEN,STOPI,STRTI,STS,INDEX
+2 WRITE !!,"Searching database for entries matching search criteria",!
+3 SET STOPI=(9999999-STPDT)-1
SET STRTI=(9999999-STRDT)
+4 FOR INDEX=1:1
IF $PIECE(SRCH,",",INDEX)=""
QUIT
Begin DoDot:1
+5 IF $PIECE(SRCH,",",INDEX)=+4
SET SRCH="1,2,3,"
End DoDot:1
+6 ; Convert SRCH from 1,2,3 to 5,6,8 (pending,active,scheduled)
+7 FOR INDEX=1:1
IF $PIECE(SRCH,",",INDEX)=""
QUIT
Begin DoDot:1
+8 IF $PIECE(SRCH,",",INDEX)=+1
SET STS=+5
DO GETDATA
+9 IF $PIECE(SRCH,",",INDEX)=+2
SET STS=+6
DO GETDATA
+10 IF $PIECE(SRCH,",",INDEX)=+3
SET STS=+8
DO GETDATA
End DoDot:1
GETDATA ; Write ^GMR(123,IEN,0) to TMP
+1 SET IDT=STOPI
+2 FOR
SET IDT=$ORDER(^GMR(123,"AE",SERV,+STS,IDT))
IF 'IDT!(IDT>STRTI)
QUIT
Begin DoDot:1
+3 SET IEN=0
FOR
SET IEN=$ORDER(^GMR(123,"AE",SERV,+STS,IDT,IEN))
IF 'IEN
QUIT
Begin DoDot:2
+4 SET ^TMP("GMRCLS",$JOB,IEN)=+STS_U_+^GMR(123,IEN,0)
+5 WRITE "."
End DoDot:2
End DoDot:1
+6 QUIT
AUDIT(GMRCO,UPDSTS,GMRCOM) ;Update the processing activity of the consult
+1 ;GMRCO= IEN from file 123
+2 ;UPDSTS= 1 for DC ; 2 for COMPLETE
+3 NEW DA,DIE,GMRCA,GMRCDT,GMRCSTS
+4 SET GMRCDT=$$NOW^XLFDT
SET GMRCA=$SELECT(UPDSTS=1:6,1:10)
+5 SET GMRCSTS=$PIECE(^GMR(123,GMRCO,0),U,12)
+6 IF '$DATA(^GMR(123,+GMRCO,40,0))
SET ^(0)="^123.02DA^^"
+7 SET DA=$SELECT($PIECE(^GMR(123,+GMRCO,40,0),"^",3):$PIECE(^(0),"^",3)+1,1:1)
SET $PIECE(^GMR(123,GMRCO,40,0),"^",3,4)=DA_"^"_DA
+8 SET DIE="^GMR(123,"_+GMRCO_",40,"
SET DA(1)=+GMRCO
+9 SET DR=".01////^S X=GMRCDT;1////^S X=GMRCA;2////^S X=GMRCDT;3////^S X=DUZ;4////^S X=DUZ"
+10 DO ^DIE
+11 SET ^GMR(123,+GMRCO,40,DA,1,0)="^^1^1^"_GMRCDT_"^"
+12 IF $DATA(GMRCOM)
Begin DoDot:1
+13 MERGE ^GMR(123,+GMRCO,40,DA,1)=GMRCOM
End DoDot:1
+14 IF '$DATA(GMRCOM)
Begin DoDot:1
+15 NEW COMMENT
+16 SET COMMENT="Status updated from "
+17 SET COMMENT=COMMENT_$PIECE(^ORD(100.01,+GMRCSTS,0),"^",1)
+18 SET COMMENT=COMMENT_" to "_$SELECT(+UPDSTS=2:"COMPLETE",1:"DISCONTINUED")
+19 SET COMMENT=COMMENT_" during group status update process."
+20 SET ^GMR(123,+GMRCO,40,DA,1,1,0)=COMMENT
End DoDot:1
+21 ;Check for IFC and update accordingly
+22 IF $DATA(^GMR(123,+GMRCO,12))
IF $DATA(^(40,DA))
DO TRIGR^GMRCIEVT(GMRCO,DA)
+23 KILL DIE,GMRCA,GMRCDT
+24 QUIT
STSUPD(GMRCO,UPDSTS) ;change status of consult to COMPLETE or DC
+1 ;GMRCO= IEN from file 123
+2 ;UPDSTS= 1 for DC ; 2 for COMPLETE
+3 NEW DIE,DA,DR,GMRCLST,X
+4 SET GMRCLST=$SELECT(UPDSTS=1:$ORDER(^GMR(123.1,"B","DISCONTINUED",0)),UPDSTS=2:$ORDER(^GMR(123.1,"B","COMPLETE/UPDATE",0)),1:99)
+5 SET DIE="^GMR(123,"
SET DA=GMRCO
+6 SET DR="8////^S X=+UPDSTS;9////"_GMRCLST
+7 DO ^DIE
+8 QUIT
CPRSUPDT(GMRCO,UPDSTS) ;Update CPRS order with new status
+1 ;GMRCO= IEN from file 123
+2 ;UPDSTS= status to update CPRS with
+3 NEW GMRCDFN,CTRLCODE
+4 SET GMRCDFN=$PIECE(^GMR(123,GMRCO,0),"^",2)
+5 SET CTRLCODE=$SELECT(UPDSTS=1:"OD",1:"RE")
+6 ; send HL7 message to CPRS to update order status
+7 DO EN^GMRCHL7(GMRCDFN,+GMRCO,"","",CTRLCODE,DUZ,"","",1)
+8 QUIT
UPDCRIT(UPD,STS,SVC,CMT,START,STOP) ;print update criteria on page 1
+1 NEW INDEX,GMRCSTS
+2 FOR INDEX=1:1
IF $PIECE(STS,",",INDEX)=""
QUIT
Begin DoDot:1
+3 IF STS[+4
SET GMRCSTS="Active, Pending, and Scheduled"
QUIT
+4 IF $PIECE(STS,",",INDEX)=+1
SET $PIECE(GMRCSTS,",",INDEX)="Pending"
+5 IF $PIECE(STS,",",INDEX)=+2
SET $PIECE(GMRCSTS,",",INDEX)="Active"
+6 IF $PIECE(STS,",",INDEX)=+3
SET $PIECE(GMRCSTS,",",INDEX)="Scheduled"
End DoDot:1
+7 WRITE !,"Records will be updated for:"
+8 WRITE !,$$REPEAT^XLFSTR("-",78)
+9 WRITE !," Service: "_$$GET1^DIQ(123.5,SVC,.01)
+10 WRITE !," Beginning: "_$$FMTE^XLFDT(START)
+11 WRITE !," Ending: "_$$FMTE^XLFDT(STOP)
+12 WRITE !," Update: "_GMRCSTS_" "_" Consults"
+13 WRITE !," To: "_$SELECT(+UPD=2:"COMPLETE",1:"DISCONTINUED")
+14 IF $DATA(CMT)
WRITE !," Update Comment:"
Begin DoDot:1
+15 NEW I
SET I=0
FOR
SET I=$ORDER(CMT(I))
IF 'I
QUIT
Begin DoDot:2
+16 WRITE !,CMT(I,0)
End DoDot:2
End DoDot:1
+17 WRITE !,$$REPEAT^XLFSTR("-",78),!
+18 QUIT