- BDPPLBC ; IHS/CMI/TMJ - LISTING OF RECORDS BY DATE RANGE & CATEGORY ;
- ;;2.0;IHS PCC SUITE;**2,20**;MAY 14, 2009;Build 25
- ;
- ;
- ;
- D INFORM ;Report Explanation
- CAT ;
- W !
- K BDPPROVC
- S DIR(0)="SO^O:One Provider Category;A:All Provider Categories",DIR("A")="Do you want to report on ",DIR("B")="O" KILL DA D ^DIR KILL DIR
- I $D(DIRUT) D END Q
- I Y="A" G ZIS
- S DIC="^BDPTCAT(",DIC(0)="AEMQ" D ^DIC K DIC,DA
- I Y=-1 G CAT
- S BDPPROVC=+Y
- ZIS ;
- S XBRC="PROC^BDPPLBC",XBRP="PRINT^BDPPLBC",XBNS="BDP",XBRX="END^BDPPLBC"
- D ^XBDBQUE
- D END
- Q
- PROC ;
- ;loop through file and tally by catgegory, skip inactive patients
- S BDPJ=$J,BDPH=$H,BDPTCNT=0 K BDPSCNT
- K ^XTMP("BDPPLBC",BDPJ,BDPH)
- D XTMP^APCLOSUT("BDPPLBC","DESG PROVIDER REPORT")
- S BDPX=0 F S BDPX=$O(^BDPRECN("B",BDPX)) Q:BDPX="" D
- .I $D(BDPPROVC),BDPX'=BDPPROVC Q
- .S BDPIEN=0 F S BDPIEN=$O(^BDPRECN("B",BDPX,BDPIEN)) Q:BDPIEN="" D
- ..S DFN=$P(^BDPRECN(BDPIEN,0),U,2)
- ..Q:$P($G(^AUPNPAT(DFN,41,DUZ(2),0)),U,3) ;inactive patients
- ..S BDPD=$$VAL^XBDIQ1(90360.1,BDPIEN,.01)
- ..Q:$$VAL^XBDIQ1(90360.1,BDPIEN,.03)=""
- ..S ^XTMP("BDPPLBC",BDPJ,BDPH,"HITS",$$VAL^XBDIQ1(90360.1,BDPIEN,.01),$$VAL^XBDIQ1(90360.1,BDPIEN,.03),BDPIEN)=""
- ..S BDPTCNT=BDPTCNT+1 S BDPSCNT(BDPD)=$G(BDPSCNT(BDPD))+1
- ..Q
- .Q
- Q
- PRINT ;PRINT RECORDS BY DATE
- S BDPPG=0 K BDPQUIT
- D PAGEHEAD
- I '$D(^XTMP("BDPPLBC",BDPJ,BDPH,"HITS")) W !,"No data to report." D END Q
- S BDPD="" F S BDPD=$O(^XTMP("BDPPLBC",BDPJ,BDPH,"HITS",BDPD)) Q:BDPD=""!($D(BDPQUIT)) D
- .S BDPPN=0 F S BDPPN=$O(^XTMP("BDPPLBC",BDPJ,BDPH,"HITS",BDPD,BDPPN)) Q:BDPPN=""!($D(BDPQUIT)) D
- ..S BDPI=0 F S BDPI=$O(^XTMP("BDPPLBC",BDPJ,BDPH,"HITS",BDPD,BDPPN,BDPI)) Q:BDPI=""!($D(BDPQUIT)) D
- ...I $Y>(IOSL-3) D PAGEHEAD Q:$D(BDPQUIT)
- ...W !,$E($$VAL^XBDIQ1(90360.1,BDPI,.01),1,20),?22,$E($$VAL^XBDIQ1(90360.1,BDPI,.02),1,20),?44,$E($$VAL^XBDIQ1(90360.1,BDPI,.03),1,20),?68,$$DATE^BDPLMDSP($$VALI^XBDIQ1(90360.1,BDPI,.05))
- .I $Y>(IOSL-3) D PAGEHEAD Q:$D(BDPQUIT)
- .W !,"Subcount: ",BDPSCNT(BDPD),!
- I $D(BDPQUIT) G DONE
- DONE ;
- K ^XTMP("BDPPLBC",BDPJ,BDPH)
- D END
- Q
- END ;
- D EN^XBVK("BDP")
- Q
- ;
- PAGEHEAD ;
- HEAD ;EP;HEADER
- G:$D(BDPDEM)!($D(BDPDEMM)) HEAD2
- I 'BDPPG G HEAD1
- HEAD2 I $E(IOST)="C",IO=IO(0) W ! S DIR(0)="EO" D ^DIR K DIR I Y=0!(Y="^")!($D(DTOUT)) S BDPQUIT="" Q
- HEAD1 ;
- W:$D(IOF) @IOF S BDPPG=BDPPG+1
- W !,$$FMTE^XLFDT(DT),?70,"Page: ",BDPPG
- W !,$$CTR("******************************************************",80)
- W !,$$CTR("* DESIGNATED PROVIDER LIST BY CATEGORY *",80)
- W !,$$CTR("******************************************************",80)
- W !!,"PROVIDER CATEGORY",?22,"PATIENT NAME",?44,"LAST CURRENT PROVIDER",?68,"UPDATE DT"
- W !,$$REPEAT^XLFSTR("-",79)
- Q
- CTR(X,Y) ;EP - Center X in a field Y wide.
- Q $J("",$S($D(Y):Y,1:IOM)-$L(X)\2)_X
- ;
- INFORM ;Report Explanation
- ;
- W !,?25,"******************************",!
- W ?10,"This Report prints a Listing of patients by the provider category."
- W !?10,"The report output includes:",!,?10,"Category Type-Patient Name-Current Provider-Date of Last Update.",!
- W ?25,"*****************************",!
- Q
- BDPPLBC ; IHS/CMI/TMJ - LISTING OF RECORDS BY DATE RANGE & CATEGORY ;
- +1 ;;2.0;IHS PCC SUITE;**2,20**;MAY 14, 2009;Build 25
- +2 ;
- +3 ;
- +4 ;
- +5 ;Report Explanation
- DO INFORM
- CAT ;
- +1 WRITE !
- +2 KILL BDPPROVC
- +3 SET DIR(0)="SO^O:One Provider Category;A:All Provider Categories"
- SET DIR("A")="Do you want to report on "
- SET DIR("B")="O"
- KILL DA
- DO ^DIR
- KILL DIR
- +4 IF $DATA(DIRUT)
- DO END
- QUIT
- +5 IF Y="A"
- GOTO ZIS
- +6 SET DIC="^BDPTCAT("
- SET DIC(0)="AEMQ"
- DO ^DIC
- KILL DIC,DA
- +7 IF Y=-1
- GOTO CAT
- +8 SET BDPPROVC=+Y
- ZIS ;
- +1 SET XBRC="PROC^BDPPLBC"
- SET XBRP="PRINT^BDPPLBC"
- SET XBNS="BDP"
- SET XBRX="END^BDPPLBC"
- +2 DO ^XBDBQUE
- +3 DO END
- +4 QUIT
- PROC ;
- +1 ;loop through file and tally by catgegory, skip inactive patients
- +2 SET BDPJ=$JOB
- SET BDPH=$HOROLOG
- SET BDPTCNT=0
- KILL BDPSCNT
- +3 KILL ^XTMP("BDPPLBC",BDPJ,BDPH)
- +4 DO XTMP^APCLOSUT("BDPPLBC","DESG PROVIDER REPORT")
- +5 SET BDPX=0
- FOR
- SET BDPX=$ORDER(^BDPRECN("B",BDPX))
- IF BDPX=""
- QUIT
- Begin DoDot:1
- +6 IF $DATA(BDPPROVC)
- IF BDPX'=BDPPROVC
- QUIT
- +7 SET BDPIEN=0
- FOR
- SET BDPIEN=$ORDER(^BDPRECN("B",BDPX,BDPIEN))
- IF BDPIEN=""
- QUIT
- Begin DoDot:2
- +8 SET DFN=$PIECE(^BDPRECN(BDPIEN,0),U,2)
- +9 ;inactive patients
- IF $PIECE($GET(^AUPNPAT(DFN,41,DUZ(2),0)),U,3)
- QUIT
- +10 SET BDPD=$$VAL^XBDIQ1(90360.1,BDPIEN,.01)
- +11 IF $$VAL^XBDIQ1(90360.1,BDPIEN,.03)=""
- QUIT
- +12 SET ^XTMP("BDPPLBC",BDPJ,BDPH,"HITS",$$VAL^XBDIQ1(90360.1,BDPIEN,.01),$$VAL^XBDIQ1(90360.1,BDPIEN,.03),BDPIEN)=""
- +13 SET BDPTCNT=BDPTCNT+1
- SET BDPSCNT(BDPD)=$GET(BDPSCNT(BDPD))+1
- +14 QUIT
- End DoDot:2
- +15 QUIT
- End DoDot:1
- +16 QUIT
- PRINT ;PRINT RECORDS BY DATE
- +1 SET BDPPG=0
- KILL BDPQUIT
- +2 DO PAGEHEAD
- +3 IF '$DATA(^XTMP("BDPPLBC",BDPJ,BDPH,"HITS"))
- WRITE !,"No data to report."
- DO END
- QUIT
- +4 SET BDPD=""
- FOR
- SET BDPD=$ORDER(^XTMP("BDPPLBC",BDPJ,BDPH,"HITS",BDPD))
- IF BDPD=""!($DATA(BDPQUIT))
- QUIT
- Begin DoDot:1
- +5 SET BDPPN=0
- FOR
- SET BDPPN=$ORDER(^XTMP("BDPPLBC",BDPJ,BDPH,"HITS",BDPD,BDPPN))
- IF BDPPN=""!($DATA(BDPQUIT))
- QUIT
- Begin DoDot:2
- +6 SET BDPI=0
- FOR
- SET BDPI=$ORDER(^XTMP("BDPPLBC",BDPJ,BDPH,"HITS",BDPD,BDPPN,BDPI))
- IF BDPI=""!($DATA(BDPQUIT))
- QUIT
- Begin DoDot:3
- +7 IF $Y>(IOSL-3)
- DO PAGEHEAD
- IF $DATA(BDPQUIT)
- QUIT
- +8 WRITE !,$EXTRACT($$VAL^XBDIQ1(90360.1,BDPI,.01),1,20),?22,$EXTRACT($$VAL^XBDIQ1(90360.1,BDPI,.02),1,20),?44,$EXTRACT($$VAL^XBDIQ1(90360.1,BDPI,.03),1,20),?68,$$DATE^BDPLMDSP($$VALI^XBDIQ1(90360.1,BDPI,.05))
- End DoDot:3
- End DoDot:2
- +9 IF $Y>(IOSL-3)
- DO PAGEHEAD
- IF $DATA(BDPQUIT)
- QUIT
- +10 WRITE !,"Subcount: ",BDPSCNT(BDPD),!
- End DoDot:1
- +11 IF $DATA(BDPQUIT)
- GOTO DONE
- DONE ;
- +1 KILL ^XTMP("BDPPLBC",BDPJ,BDPH)
- +2 DO END
- +3 QUIT
- END ;
- +1 DO EN^XBVK("BDP")
- +2 QUIT
- +3 ;
- PAGEHEAD ;
- HEAD ;EP;HEADER
- +1 IF $DATA(BDPDEM)!($DATA(BDPDEMM))
- GOTO HEAD2
- +2 IF 'BDPPG
- GOTO HEAD1
- HEAD2 IF $EXTRACT(IOST)="C"
- IF IO=IO(0)
- WRITE !
- SET DIR(0)="EO"
- DO ^DIR
- KILL DIR
- IF Y=0!(Y="^")!($DATA(DTOUT))
- SET BDPQUIT=""
- QUIT
- HEAD1 ;
- +1 IF $DATA(IOF)
- WRITE @IOF
- SET BDPPG=BDPPG+1
- +2 WRITE !,$$FMTE^XLFDT(DT),?70,"Page: ",BDPPG
- +3 WRITE !,$$CTR("******************************************************",80)
- +4 WRITE !,$$CTR("* DESIGNATED PROVIDER LIST BY CATEGORY *",80)
- +5 WRITE !,$$CTR("******************************************************",80)
- +6 WRITE !!,"PROVIDER CATEGORY",?22,"PATIENT NAME",?44,"LAST CURRENT PROVIDER",?68,"UPDATE DT"
- +7 WRITE !,$$REPEAT^XLFSTR("-",79)
- +8 QUIT
- CTR(X,Y) ;EP - Center X in a field Y wide.
- +1 QUIT $JUSTIFY("",$SELECT($DATA(Y):Y,1:IOM)-$LENGTH(X)\2)_X
- +2 ;
- INFORM ;Report Explanation
- +1 ;
- +2 WRITE !,?25,"******************************",!
- +3 WRITE ?10,"This Report prints a Listing of patients by the provider category."
- +4 WRITE !?10,"The report output includes:",!,?10,"Category Type-Patient Name-Current Provider-Date of Last Update.",!
- +5 WRITE ?25,"*****************************",!
- +6 QUIT