BIREPL1 ;IHS/CMI/MWR - REPORT, ADULT IMM; MAY 10, 2010
;;8.5;IMMUNIZATION;;SEP 01,2011
;;* MICHAEL REMILLARD, DDS * CIMARRON MEDICAL INFORMATICS, FOR IHS *
;; VIEW OR PRINT ADULT IMMUNIZATION REPORT.
;
;
;----------
START(BIX) ;EP
;---> VIEW ADULT Report.
;---> Prepare and display Adult Immunization Report.
;---> Parameters:
; 1 - BIX (req) If BIX="PRINT", then print Adult Report.
; If BIX="VIEW", then view Adult Report (default).
;---> Variables:
; 1 - BIQDT (req) Quarter Ending Date.
; 2 - BICC (req) Current Community array.
; 3 - BIHCF (req) Health Care Facility array.
; 4 - BIBEN (req) Beneficiary Type array.
; 5 - BICPTI (opt) 1=Include CPT Coded Visits, 0=Ignore CPT (default).
; 6 - BIUP (req) User Population/Group
; (Registered, Imm Reg Active, User 1+, Active 2+).
;
;---> Check for required Variables.
I '$G(BIQDT) D ERROR(622) D RESET^BIREPL Q
I '$D(BICC) D ERROR(614) D RESET^BIREPL Q
I '$D(BIHCF) D ERROR(625) D RESET^BIREPL Q
I '$D(BIBEN) D ERROR(662) D RESET^BIREPL Q
I '$D(BICPTI) S BICPTI=0
S:$G(BIUP)="" BIUP="u"
;
D SETVARS^BIUTL5 N VALMCNT
I $G(BIX)="PRINT" D PRINT,RESET^BIREPL Q
;
;---> Set BIRTN in case user runs Patient List then needs to return
;---> to INIT here.
;---> Set BITITL for Report Name in Patient List, if called.
;---> Set BIAG for Age Range in header of report.
N BIAG,BIRTN,BITITL S BIRTN="BIREPL1",BITITL="ADULT",BIAG="19+^1"
D EN
D RESET^BIREPL
Q
;
;
;----------
PRINT ;EP
;---> Main entry point for printing the ADULT Immunization Report.
D DEVICE(.BIPOP)
Q:$G(BIPOP)
;
D:$G(IO)'=$G(IO(0))
.W !!?10,"This may take some time. Please hold on...",!
;
;---> Prepare report.
K ^TMP("BIREPL1",$J),^TMP("BIDUL",$J)
N VALM,VALMHDR
D HDR,START^BIREPL2(BIQDT,.BICC,.BIHCF,.BIBEN,BICPTI,BIUP)
;
D PRTLST^BIUTL8("BIREPL1")
D EXIT,RESET^BIREPL
Q
;
;
;----------
EN ;EP
;---> Main entry point for List Template BI REPORT ADULT IMM1.
D EN^VALM("BI REPORT ADULT IMM1")
Q
;
;
;----------
HDR ;EP
;---> Header code
D HEAD^BIREPL2(BIQDT,.BICC,.BIHCF,.BIBEN,BICPTI,BIUP)
Q
;
;
;----------
INIT ;EP
;---> Initialize variables and list array.
K ^TMP("BIREPL1",$J),^TMP("BIDUL",$J)
S VALM("TITLE")=$$LMVER^BILOGO
S VALMSG="To view patient rosters, select a group below:"
W !!?10,"This may take some time. Please hold on...",!
D START^BIREPL2(BIQDT,.BICC,.BIHCF,.BIBEN,BICPTI,BIUP)
;---> Set up ZTSAVE in case user Queues from PL in List.
D ZSAVES^BIUTL3
Q
;
;
;----------
RESET ;EP
;---> Update partition for return to Listmanager.
I $D(VALMQUIT) S VALMBCK="Q" Q
D TERM^VALM0 S VALMBCK="R"
D INIT,HDR
Q
;
;
;----------
RESET1 ;EP
;---> Update partition for return to Listmanager.
I $D(VALMQUIT) S VALMBCK="Q" Q
D TERM^VALM0 S VALMBCK="R"
S VALM("TITLE")=$$LMVER^BILOGO
S VALMSG="To view patient lists, select a group below:"
D HDR
Q
;
;
;----------
HELP ;EP
N BIX S BIX=X
D FULL^VALM1 N BIPOP
D TITLE^BIUTL5("VIEW ADULT REPORT - HELP")
D TEXT1,DIRZ^BIUTL3()
D:BIX'="??" RE^VALM4
Q
;
;
;----------
TEXT1 ;EP
;;You have chosen to View the Adult Report rather than Print it.
;;(You may print the report from here as well by entering "PL".)
;;
;;Also, you may:
;;
;;Enter "N" to view the list of Patients who were NOT Current
;; or "NOT up-to-date" with their immunizations, according
;; to recommendeded guidelines for their age.
;;
;;Enter "C" to view the list of Patients who were CURRENT or
;; "up-to-date" with their immunizations, according to
;; recommendeded guidelines for their age.
;;
;;Enter "B" to view a list of both groups of patients combined.
;;
;;
D PRINTX("TEXT1")
Q
;
;
;----------
EXIT ;EP
;---> Cleanup, EOJ.
K ^TMP("BIREPL1",$J),^TMP("BIDUL",$J)
D CLEAR^VALM1
D FULL^VALM1
Q
;
;
;----------
DEVICE(BIPOP) ;EP
;---> Get Device and possibly queue to Taskman.
;---> Parameters:
; 1 - BIPOP (ret) If error or Queue, BIPOP=1
;
K %ZIS,IOP S BIPOP=0
S ZTRTN="DEQUEUE^BIREPL1"
D ZSAVES^BIUTL3
D ZIS^BIUTL2(.BIPOP,1)
Q
;
;
;----------
DEQUEUE ;EP
;
;---> Prepare and print ADULT Report.
K VALMHDR,^TMP("BIREPL1",$J)
D HDR^BIREPL1,START^BIREPL2(BIQDT,.BICC,.BIHCF,.BIBEN,BICPTI,BIUP)
D PRTLST^BIUTL8("BIREPL1"),EXIT
Q
;
;
;----------
PRINTX(BILINL,BITAB) ;EP
Q:$G(BILINL)=""
N I,T,X S T="" S:'$D(BITAB) BITAB=5 F I=1:1:BITAB S T=T_" "
F I=1:1 S X=$T(@BILINL+I) Q:X'[";;" W !,T,$P(X,";;",2)
Q
;
;
;----------
ERROR(BIERR) ;EP
;---> Report error, either to screen or print.
;---> Parameters:
; 1 - BIERR (ret) Text of Error Code if any, otherwise null.
;
D ERRCD^BIUTL2($G(BIERR),,1) S BIPOP=1
Q
BIREPL1 ;IHS/CMI/MWR - REPORT, ADULT IMM; MAY 10, 2010
+1 ;;8.5;IMMUNIZATION;;SEP 01,2011
+2 ;;* MICHAEL REMILLARD, DDS * CIMARRON MEDICAL INFORMATICS, FOR IHS *
+3 ;; VIEW OR PRINT ADULT IMMUNIZATION REPORT.
+4 ;
+5 ;
+6 ;----------
START(BIX) ;EP
+1 ;---> VIEW ADULT Report.
+2 ;---> Prepare and display Adult Immunization Report.
+3 ;---> Parameters:
+4 ; 1 - BIX (req) If BIX="PRINT", then print Adult Report.
+5 ; If BIX="VIEW", then view Adult Report (default).
+6 ;---> Variables:
+7 ; 1 - BIQDT (req) Quarter Ending Date.
+8 ; 2 - BICC (req) Current Community array.
+9 ; 3 - BIHCF (req) Health Care Facility array.
+10 ; 4 - BIBEN (req) Beneficiary Type array.
+11 ; 5 - BICPTI (opt) 1=Include CPT Coded Visits, 0=Ignore CPT (default).
+12 ; 6 - BIUP (req) User Population/Group
+13 ; (Registered, Imm Reg Active, User 1+, Active 2+).
+14 ;
+15 ;---> Check for required Variables.
+16 IF '$GET(BIQDT)
DO ERROR(622)
DO RESET^BIREPL
QUIT
+17 IF '$DATA(BICC)
DO ERROR(614)
DO RESET^BIREPL
QUIT
+18 IF '$DATA(BIHCF)
DO ERROR(625)
DO RESET^BIREPL
QUIT
+19 IF '$DATA(BIBEN)
DO ERROR(662)
DO RESET^BIREPL
QUIT
+20 IF '$DATA(BICPTI)
SET BICPTI=0
+21 IF $GET(BIUP)=""
SET BIUP="u"
+22 ;
+23 DO SETVARS^BIUTL5
NEW VALMCNT
+24 IF $GET(BIX)="PRINT"
DO PRINT
DO RESET^BIREPL
QUIT
+25 ;
+26 ;---> Set BIRTN in case user runs Patient List then needs to return
+27 ;---> to INIT here.
+28 ;---> Set BITITL for Report Name in Patient List, if called.
+29 ;---> Set BIAG for Age Range in header of report.
+30 NEW BIAG,BIRTN,BITITL
SET BIRTN="BIREPL1"
SET BITITL="ADULT"
SET BIAG="19+^1"
+31 DO EN
+32 DO RESET^BIREPL
+33 QUIT
+34 ;
+35 ;
+36 ;----------
PRINT ;EP
+1 ;---> Main entry point for printing the ADULT Immunization Report.
+2 DO DEVICE(.BIPOP)
+3 IF $GET(BIPOP)
QUIT
+4 ;
+5 IF $GET(IO)'=$GET(IO(0))
Begin DoDot:1
+6 WRITE !!?10,"This may take some time. Please hold on...",!
End DoDot:1
+7 ;
+8 ;---> Prepare report.
+9 KILL ^TMP("BIREPL1",$JOB),^TMP("BIDUL",$JOB)
+10 NEW VALM,VALMHDR
+11 DO HDR
DO START^BIREPL2(BIQDT,.BICC,.BIHCF,.BIBEN,BICPTI,BIUP)
+12 ;
+13 DO PRTLST^BIUTL8("BIREPL1")
+14 DO EXIT
DO RESET^BIREPL
+15 QUIT
+16 ;
+17 ;
+18 ;----------
EN ;EP
+1 ;---> Main entry point for List Template BI REPORT ADULT IMM1.
+2 DO EN^VALM("BI REPORT ADULT IMM1")
+3 QUIT
+4 ;
+5 ;
+6 ;----------
HDR ;EP
+1 ;---> Header code
+2 DO HEAD^BIREPL2(BIQDT,.BICC,.BIHCF,.BIBEN,BICPTI,BIUP)
+3 QUIT
+4 ;
+5 ;
+6 ;----------
INIT ;EP
+1 ;---> Initialize variables and list array.
+2 KILL ^TMP("BIREPL1",$JOB),^TMP("BIDUL",$JOB)
+3 SET VALM("TITLE")=$$LMVER^BILOGO
+4 SET VALMSG="To view patient rosters, select a group below:"
+5 WRITE !!?10,"This may take some time. Please hold on...",!
+6 DO START^BIREPL2(BIQDT,.BICC,.BIHCF,.BIBEN,BICPTI,BIUP)
+7 ;---> Set up ZTSAVE in case user Queues from PL in List.
+8 DO ZSAVES^BIUTL3
+9 QUIT
+10 ;
+11 ;
+12 ;----------
RESET ;EP
+1 ;---> Update partition for return to Listmanager.
+2 IF $DATA(VALMQUIT)
SET VALMBCK="Q"
QUIT
+3 DO TERM^VALM0
SET VALMBCK="R"
+4 DO INIT
DO HDR
+5 QUIT
+6 ;
+7 ;
+8 ;----------
RESET1 ;EP
+1 ;---> Update partition for return to Listmanager.
+2 IF $DATA(VALMQUIT)
SET VALMBCK="Q"
QUIT
+3 DO TERM^VALM0
SET VALMBCK="R"
+4 SET VALM("TITLE")=$$LMVER^BILOGO
+5 SET VALMSG="To view patient lists, select a group below:"
+6 DO HDR
+7 QUIT
+8 ;
+9 ;
+10 ;----------
HELP ;EP
+1 NEW BIX
SET BIX=X
+2 DO FULL^VALM1
NEW BIPOP
+3 DO TITLE^BIUTL5("VIEW ADULT REPORT - HELP")
+4 DO TEXT1
DO DIRZ^BIUTL3()
+5 IF BIX'="??"
DO RE^VALM4
+6 QUIT
+7 ;
+8 ;
+9 ;----------
TEXT1 ;EP
+1 ;;You have chosen to View the Adult Report rather than Print it.
+2 ;;(You may print the report from here as well by entering "PL".)
+3 ;;
+4 ;;Also, you may:
+5 ;;
+6 ;;Enter "N" to view the list of Patients who were NOT Current
+7 ;; or "NOT up-to-date" with their immunizations, according
+8 ;; to recommendeded guidelines for their age.
+9 ;;
+10 ;;Enter "C" to view the list of Patients who were CURRENT or
+11 ;; "up-to-date" with their immunizations, according to
+12 ;; recommendeded guidelines for their age.
+13 ;;
+14 ;;Enter "B" to view a list of both groups of patients combined.
+15 ;;
+16 ;;
+17 DO PRINTX("TEXT1")
+18 QUIT
+19 ;
+20 ;
+21 ;----------
EXIT ;EP
+1 ;---> Cleanup, EOJ.
+2 KILL ^TMP("BIREPL1",$JOB),^TMP("BIDUL",$JOB)
+3 DO CLEAR^VALM1
+4 DO FULL^VALM1
+5 QUIT
+6 ;
+7 ;
+8 ;----------
DEVICE(BIPOP) ;EP
+1 ;---> Get Device and possibly queue to Taskman.
+2 ;---> Parameters:
+3 ; 1 - BIPOP (ret) If error or Queue, BIPOP=1
+4 ;
+5 KILL %ZIS,IOP
SET BIPOP=0
+6 SET ZTRTN="DEQUEUE^BIREPL1"
+7 DO ZSAVES^BIUTL3
+8 DO ZIS^BIUTL2(.BIPOP,1)
+9 QUIT
+10 ;
+11 ;
+12 ;----------
DEQUEUE ;EP
+1 ;
+2 ;---> Prepare and print ADULT Report.
+3 KILL VALMHDR,^TMP("BIREPL1",$JOB)
+4 DO HDR^BIREPL1
DO START^BIREPL2(BIQDT,.BICC,.BIHCF,.BIBEN,BICPTI,BIUP)
+5 DO PRTLST^BIUTL8("BIREPL1")
DO EXIT
+6 QUIT
+7 ;
+8 ;
+9 ;----------
PRINTX(BILINL,BITAB) ;EP
+1 IF $GET(BILINL)=""
QUIT
+2 NEW I,T,X
SET T=""
IF '$DATA(BITAB)
SET BITAB=5
FOR I=1:1:BITAB
SET T=T_" "
+3 FOR I=1:1
SET X=$TEXT(@BILINL+I)
IF X'[";;"
QUIT
WRITE !,T,$PIECE(X,";;",2)
+4 QUIT
+5 ;
+6 ;
+7 ;----------
ERROR(BIERR) ;EP
+1 ;---> Report error, either to screen or print.
+2 ;---> Parameters:
+3 ; 1 - BIERR (ret) Text of Error Code if any, otherwise null.
+4 ;
+5 DO ERRCD^BIUTL2($GET(BIERR),,1)
SET BIPOP=1
+6 QUIT