Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: DGEEREIM

DGEEREIM.m

Go to the documentation of this file.
  1. DGEEREIM ;ALB/BRM;Reimbursable Primary Eligibility Code Report ; 5/23/05 11:04am
  1. ;;5.3;Registration;**672,706**;Aug 13,1993
  1. ;;
  1. ; This routine will identify and report any veteran who has a
  1. ; Reimbursable Insurance Primary Eligibility Code and who is not
  1. ; deceased.
  1. ;
  1. QUETASK ; Queue the DMZ/Reimbursable Stats job
  1. N TXT,ZTRTN,ZTDESC,ZTSK,ZTIO,ZTDTH,POP,IO,IOBS,IOF,IOHG,IOM,ION,IOPAR
  1. N IOS,IOSL,IOST,IOT,IOUPAR,IOXY,%ZIS,ZTSAVE
  1. K ^TMP($J,"DGEEREIM")
  1. S %ZIS="QM" D ^%ZIS I $G(POP) W !,"Job Terminated!" Q
  1. I $D(IO("Q")) D Q
  1. .S ZTRTN="LOOP^DGEEREIM",ZTDTH=$$NOW^XLFDT()
  1. .S ZTDESC="REIMBURSABLE INSURANCE PRIMARY ELIG CODE JOB"
  1. .D ^%ZTLOAD
  1. .S TXT=$S($G(ZTSK):"Task: "_ZTSK_" Queued.",1:"Error: Process not queued!")
  1. .D HOME^%ZIS
  1. .W !,TXT
  1. ;
  1. LOOP ; entry point
  1. N QFLG,DFN,ELIG,QUIT,RCNT,RDT,ZZ
  1. N X,X1,X2,EC81,PRIMEC,%,CRT,DATA,DIRUT,EC8,LINE,NAME,PAGE
  1. ; get local codes assigned to the national Reimbursible code
  1. S EC8=$O(^DIC(8.1,"B","REIMBURSABLE INSURANCE",""))
  1. S EC81=""
  1. F S EC81=$O(^DIC(8,"D",EC8,EC81)) Q:'EC81 S ELIG(EC81)=""
  1. ; loop through patient records
  1. S DFN=0
  1. F S DFN=$O(^DPT(DFN)) Q:'DFN D
  1. .; quit if deceased
  1. .Q:$P($G(^DPT(DFN,.35)),"^")
  1. .;check for Primary EC of Reimbursable Insurance
  1. .S PRIMEC=$P($G(^DPT(DFN,.36)),"^"),EC81="",QFLG=0
  1. .F S EC81=$O(ELIG(EC81)) Q:(QFLG!'EC81) D
  1. ..Q:PRIMEC'=EC81
  1. ..S ^TMP($J,"DGEEREIM","RCNT")=$G(^TMP($J,"DGEEREIM","RCNT"))+1,QFLG=1
  1. ..S SSN=$P($G(^DPT(DFN,0)),"^",9),NAME=$P($G(^DPT(DFN,0)),"^")
  1. ..S ^TMP($J,"DGEEREIM","DATA",SSN)=NAME_"^"_$$EXTERNAL^DILFD(2,.361,"",PRIMEC)
  1. U IO
  1. D PSET,REPORT
  1. D ^%ZISC,HOME^%ZIS
  1. Q
  1. PSET ; set up printer variables
  1. N ZZ
  1. S CRT=$S($E(IOST,1,2)="C-":1,1:0)
  1. S (RDT,Y)=""
  1. F ZZ=1:1:IOM S $P(LINE,"-",ZZ)=""
  1. D NOW^%DTC S Y=% X ^DD("DD")
  1. S RDT=$P(Y,"@",1)_" @ "_$P($P(Y,"@",2),":",1,2)
  1. S RCNT=+$G(^TMP($J,"DGEEREIM","RCNT"))
  1. Q
  1. HDR ; Report Header
  1. W !,?((IOM-40)\2),"Reimbursable Insurance Primary EC Report"
  1. W !,?((IOM-22-$L(RDT))\2),"Date/Time Report Run: ",RDT
  1. W !!,?((IOM-35-$L(RCNT))\2),"Total Patients with RI Primary EC: ",RCNT
  1. W !,LINE
  1. W !!,?5,"SSN",?17,"NAME",?50,"PRIMARY ELIG. CODE"
  1. W !,?5,"---------",?17,"------------------------------"
  1. W ?50,"-------------------"
  1. Q
  1. REPORT ;report results
  1. N SSN
  1. I CRT,+$G(PAGE)=0 W @IOF
  1. S PAGE=1 D HDR
  1. S SSN="" F S SSN=$O(^TMP($J,"DGEEREIM","DATA",SSN)) Q:SSN']""!($G(QUIT)) D
  1. .S DATA=$G(^TMP($J,"DGEEREIM","DATA",SSN))
  1. .I $Y>(IOSL-5) W:'$G(CRT) !,?68,"Page: "_PAGE D:$G(CRT) PAUSE Q:$G(QUIT) W @IOF D HDR S PAGE=PAGE+1
  1. .W !?5,SSN,?17,$P(DATA,"^"),?50,$P(DATA,"^",2)
  1. Q
  1. ;
  1. PAUSE ; Screen pause. Sets QUIT=1 if user decides to quit.
  1. N DIR,X,Y
  1. F Q:$Y>(IOSL-5) W !
  1. W !,?68,"Page: "_PAGE,!
  1. S DIR(0)="E" D ^DIR I ('(+Y))!$D(DIRUT) S QUIT=1
  1. Q