BMCRR21 ; IHS/PHXAO/TMJ - PROCESS REFERRAL LIST ;
;;4.0;REFERRED CARE INFO SYSTEM;**9**;JAN 09, 2006;Build 101
;IHS/ITSC/FCJ ADDED TEST FOR SR
;
START ;
S (BMCBT,BMCBTH)=$H,BMCJOB=$J,BMCRCNT=0
D PROCESS,END
Q
;
PROCESS ;
S BMCREF=0 F S BMCREF=$O(^BMCREF(BMCREF)) Q:BMCREF'=+BMCREF D PROC
Q
;
END ;
S BMCET=$H
Q
PROC ;
S BMCRREC=^BMCREF(BMCREF,0),DFN=$P(BMCRREC,U,3)
Q:$P(BMCRREC,U,4)="N"
Q:$P(BMCRREC,U,14)'="I"
;Q:$P(BMCRREC,U,15)'="A" ;QUIT IF NOT ACTIVE ;BMC*4.0*9 IHS.OIT.FCJ
Q:($P(BMCRREC,U,15)="C1")!($P(BMCRREC,U,15)="X") ;QUIT IF NOT ACTIVE OR APPROVED ;BMC*4.0*9 IHS.OIT.FCJ
Q:$$AVDOS^BMCRLU(BMCREF,"I")="" ;QUIT IF NO EST OR ACTUAL BEG DOS
Q:$$AVDOS^BMCRLU(BMCREF,"I")>DT ;QUIT IF DOS IS AFTER TODAY
I $P($G(^BMCREF(BMCREF,11)),U,8)]"",$P(^BMCREF(BMCREF,11),U,8)<DT Q ;if actual ending date of service is present and before today - quit
;get sort value
S BMCSORT=""
D @BMCSTYPE
S:BMCSORT="" BMCSORT="??"
S ^XTMP("BMCRR2",BMCJOB,BMCBTH,"DATA HITS",BMCSORT,BMCREF)="",BMCRCNT=BMCRCNT+1
Q
F ;sort by facility
S BMCSORT=$$FACREF^BMCRLU(BMCREF)
Q
P ;sort by patient name
S BMCSORT=$P(^DPT(DFN,0),U)
Q
C ;sort by case manager
S BMCSORT=$$CASEMAN^BMCRLU(BMCREF)
Q
BMCRR21 ; IHS/PHXAO/TMJ - PROCESS REFERRAL LIST ;
+1 ;;4.0;REFERRED CARE INFO SYSTEM;**9**;JAN 09, 2006;Build 101
+2 ;IHS/ITSC/FCJ ADDED TEST FOR SR
+3 ;
START ;
+1 SET (BMCBT,BMCBTH)=$HOROLOG
SET BMCJOB=$JOB
SET BMCRCNT=0
+2 DO PROCESS
DO END
+3 QUIT
+4 ;
PROCESS ;
+1 SET BMCREF=0
FOR
SET BMCREF=$ORDER(^BMCREF(BMCREF))
IF BMCREF'=+BMCREF
QUIT
DO PROC
+2 QUIT
+3 ;
END ;
+1 SET BMCET=$HOROLOG
+2 QUIT
PROC ;
+1 SET BMCRREC=^BMCREF(BMCREF,0)
SET DFN=$PIECE(BMCRREC,U,3)
+2 IF $PIECE(BMCRREC,U,4)="N"
QUIT
+3 IF $PIECE(BMCRREC,U,14)'="I"
QUIT
+4 ;Q:$P(BMCRREC,U,15)'="A" ;QUIT IF NOT ACTIVE ;BMC*4.0*9 IHS.OIT.FCJ
+5 ;QUIT IF NOT ACTIVE OR APPROVED ;BMC*4.0*9 IHS.OIT.FCJ
IF ($PIECE(BMCRREC,U,15)="C1")!($PIECE(BMCRREC,U,15)="X")
QUIT
+6 ;QUIT IF NO EST OR ACTUAL BEG DOS
IF $$AVDOS^BMCRLU(BMCREF,"I")=""
QUIT
+7 ;QUIT IF DOS IS AFTER TODAY
IF $$AVDOS^BMCRLU(BMCREF,"I")>DT
QUIT
+8 ;if actual ending date of service is present and before today - quit
IF $PIECE($GET(^BMCREF(BMCREF,11)),U,8)]""
IF $PIECE(^BMCREF(BMCREF,11),U,8)<DT
QUIT
+9 ;get sort value
+10 SET BMCSORT=""
+11 DO @BMCSTYPE
+12 IF BMCSORT=""
SET BMCSORT="??"
+13 SET ^XTMP("BMCRR2",BMCJOB,BMCBTH,"DATA HITS",BMCSORT,BMCREF)=""
SET BMCRCNT=BMCRCNT+1
+14 QUIT
F ;sort by facility
+1 SET BMCSORT=$$FACREF^BMCRLU(BMCREF)
+2 QUIT
P ;sort by patient name
+1 SET BMCSORT=$PIECE(^DPT(DFN,0),U)
+2 QUIT
C ;sort by case manager
+1 SET BMCSORT=$$CASEMAN^BMCRLU(BMCREF)
+2 QUIT