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

AG3RDP.m

Go to the documentation of this file.
  1. AG3RDP ;IHS/ASDS/SDH - COUNT 3RD PARTY RESOURCE PATIENTS ;
  1. ;;7.1;IHS PATIENT REGISTRATION;**2,4**;JAN 31, 2007
  1. ;
  1. INTRO ;
  1. ;;
  1. ;;3RD PARTY ELIGIBLITY COUNT PROCESS!
  1. ;;-----------------------------------
  1. ;;This report counts the number of patients that have 3rd Party
  1. ;;insurance on a selected date.
  1. ;;
  1. ;;###
  1. W @IOF
  1. F AG=1:1 W $$CJ^XLFSTR($P($T(INTRO+AG),";",3),IOM) Q:$P($T(INTRO+AG+1),";",3)="###"
  1. ;
  1. DATE ; Input date to check for eligibility.
  1. S AGDT=$$DIR^XBDIR("D","Date for the point in Time you want eligibility for")
  1. I $D(DIRUT) D EOJ Q
  1. VSTCK ; Input check-active flag.
  1. S AGVCK=$$DIR^XBDIR("Y","Want to check if patient is active")
  1. I $D(DIRUT) D EOJ Q
  1. DEV ; Select Device.
  1. W !!
  1. KILL IOP
  1. S %ZIS="PQ"
  1. KILL IO("Q")
  1. D ^%ZIS
  1. I POP D EOJ Q
  1. I $D(IO("Q")) D TASK,EOJ Q
  1. START ;EP - From TaskMan.
  1. ;AG*7.1*2 ALPHA ISSUE ADD DATE/TIME STAMP TO AID IN BEFORE/AFTER COMPARISONS FOR CMS DOWNLOAD
  1. N AGNOW
  1. D NOW^%DTC
  1. S Y=% X ^DD("DD")
  1. S AGNOW=Y
  1. ;AG*7.1*2 END
  1. KILL ^TMP("AG3RDP",$J)
  1. D MCR,MCD,PI,RPT,EOJ
  1. Q
  1. ;
  1. MCR ; Process MediCare file. Record the counts
  1. I '$D(ZTQUEUED),$E(IOST)="C" U IO(0) W !,"Processing Medicare......"
  1. S DFN=0
  1. F S DFN=$O(^AUPNMCR(DFN)) Q:+DFN=0 D
  1. . I $P($G(^DPT(DFN,.35)),U)'="",($P($G(^DPT(DFN,.35)),U)'>AGDT) Q
  1. . S AGM=0
  1. . F S AGM=$O(^AUPNMCR(DFN,11,AGM)) Q:+AGM=0 D
  1. .. S AGST=$P($G(^AUPNMCR(DFN,11,AGM,0)),U)
  1. .. S AGEND=$P($G(^AUPNMCR(DFN,11,AGM,0)),U,2)
  1. .. S AGTY=$P($G(^AUPNMCR(DFN,11,AGM,0)),U,3)
  1. .. S AG("MCR")="N"
  1. .. I (AGDT'<AGST),(AGEND="") S AG("MCR")="Y"
  1. .. E I (AGDT'<AGST),(AGDT'>AGEND) S AG("MCR")="Y"
  1. .. ;I AG("MCR")="Y" S $P(^TMP("AG3RDP",$J,DFN),U,$S(AGTY="B":4,1:3))=1
  1. .. I AG("MCR")="Y" S $P(^TMP("AG3RDP",$J,DFN),U,$S(AGTY="B":4,AGTY="A":3,1:5))=1 ;IHS/SD/TPF 4/12/2006 AG*7.1*2 ITEM 8 PG 11
  1. ..Q
  1. .Q
  1. Q
  1. ;
  1. MCD ; Process MediCaid file. Record the counts
  1. I '$D(ZTQUEUED),$E(IOST)="C" U IO(0) W !!,"Processing Medicaid...."
  1. S AG=0
  1. F S AG=$O(^AUPNMCD(AG)) Q:+AG=0 D
  1. . S DFN=$P($G(^AUPNMCD(AG,0)),U)
  1. . I 'DFN W !,DFN
  1. . Q:'DFN
  1. . I $P($G(^DPT(DFN,.35)),U)'="",($P($G(^DPT(DFN,.35)),U)'>AGDT) Q
  1. . S AGM=0,AG("MCD")="N"
  1. . F S AGM=$O(^AUPNMCD(AG,11,AGM)) Q:+AGM=0 D Q:AG("MCD")="Y"
  1. .. S AGST=$P($G(^AUPNMCD(AG,11,AGM,0)),U)
  1. .. S AGEND=$P($G(^AUPNMCD(AG,11,AGM,0)),U,2)
  1. .. I $E(AGEND,6,7)="00" S AGEND=AGEND+31
  1. .. I (AGDT'<AGST),(AGEND="") S AG("MCD")="Y"
  1. .. E I (AGDT'<AGST),(AGDT'>AGEND) S AG("MCD")="Y"
  1. .. I AG("MCD")="Y" S $P(^TMP("AG3RDP",$J,DFN),U,1)=1
  1. ..Q
  1. .Q
  1. Q
  1. ;
  1. PI ; Process Private Insurance file. Record the counts
  1. I '$D(ZTQUEUED),$E(IOST)="C" U IO(0) W !!,"Processing Private Ins......."
  1. S DFN=0
  1. F S DFN=$O(^AUPNPRVT(DFN)) Q:+DFN=0 I $$PI^AUPNPAT(DFN,AGDT) S $P(^TMP("AG3RDP",$J,DFN),U,2)=1
  1. Q
  1. ;
  1. RPT ;
  1. K AGST,AGEND,AG,AGM,DIR
  1. U IO
  1. D EN
  1. Q
  1. ;
  1. EOJ ;
  1. D ^%ZISC
  1. K AGDT,AGST,AGTY,AGVCK,DIR,DFN
  1. K ^TMP("AG3RDP",$J)
  1. Q
  1. ;
  1. TASK ;
  1. K ZTSAVE
  1. S ZTSAVE("AGDT")="",ZTSAVE("AGVCK")="",ZTIO=ION,ZTRTN="START^AG3RDP",ZTDTH="",ZTDESC="3RD PARTY ELIGIBILITY REPORT"
  1. D ^%ZTLOAD
  1. Q
  1. ;
  1. EN ;
  1. S (AG,AGMCD,AGPI,AGMCR,AGMCRB,AGMMPI,AGMM,AGMDPI,AGMRPI,AGMCRAB)=0
  1. S AGMCRD=0 ;IHS/SD/TPF 4/12/2006 AG*7.1*2 ITEM 8 PAGE 11
  1. S AG("BDT")=9999999-(AGDT-30001),AG("EDT")=9999999-(AGDT-1)
  1. S DFN=0
  1. F S DFN=$O(^TMP("AG3RDP",$J,DFN)) Q:+DFN=0 D
  1. .I $G(AGVCK)=1 D VCHK Q:AG("V")="N"
  1. .S AG=$G(^TMP("AG3RDP",$J,DFN))
  1. .;F %=1:1:4 S @("AG"_%)=+$P(AG,U,%)
  1. .F %=1:1:5 S @("AG"_%)=+$P(AG,U,%) ;IHS/SD/TPF 4/12/2006 AG*7.1*2 ITEM 8 PAGE 11
  1. .;I AG1=0,AG2=0,AG3=0,AG4=0,AG5=1 S AGMCRD=AGMCRD+1 Q
  1. .I AG5=1 S AGMCRD=AGMCRD+1 Q ;AG*7.1*2 ITEM 8 PAGE 11 SPECS CHANGED PER BPD MEETING OF 8/18/2006
  1. .I AG1=1,AG2=0,AG3=0,AG4=0 S AGMCD=AGMCD+1 Q
  1. .I AG1=0,AG2=1,AG3=0,AG4=0 S AGPI=AGPI+1 Q
  1. .I AG1=0,AG2=0,AG3=1,AG4=0 S AGMCR=AGMCR+1 Q
  1. .I AG1=0,AG2=0,AG3=0,AG4=1 S AGMCRB=AGMCRB+1 Q
  1. .I AG1=0,AG2=0,AG3=1,AG4=1 S AGMCRAB=AGMCRAB+1 Q
  1. .I AG1=1,AG2=1,((AG3=1)!(AG4=1)) S AGMMPI=AGMMPI+1 Q
  1. .I AG1=1,((AG3=1)!(AG4=1)) S AGMM=AGMM+1 Q
  1. .I AG1=1,AG2=1 S AGMDPI=AGMDPI+1 Q
  1. .I AG1=0,AG2=1,((AG3=1)!(AG4=1)) S AGMRPI=AGMRPI+1 Q
  1. .Q
  1. REPORT ;
  1. U IO
  1. W !!?10,"3rd Party eligibility Stats"
  1. W !?10,"For Patients with Eligibility: ",$$FMTE^XLFDT(AGDT)
  1. W:$G(AGVCK)=1 !?10,"and having a visit in the past 3 years."
  1. W !?10,"Report Date/Time: ",$G(AGNOW) ;AG*7.1*2 ALPHA ISSUE ADD DATE/TIME STAMP TO AID IN BEFORE/AFTER COMPARISONS FOR CMS DOWNLOAD
  1. W !!?16,"UNDUPLICATED PATIENT COUNTS"
  1. W !!?10,"Medicaid Only: ",?40,$J(AGMCD,6)
  1. W !!?10,"Private Insurance Only: ",?40,$J(AGPI,6)
  1. W !!?10,"Medicare A Only: ",?40,$J(AGMCR,6)
  1. W !!?10,"Medicare B Only: ",?40,$J(AGMCRB,6)
  1. W !!?10,"Medicare Part A & B Only: ",?40,$J(AGMCRAB,6)
  1. W !!?10,"Medicare Part D: ",?40,$J(AGMCRD,6) ;IHS/SD/TPF 4/12/2006 AG*7.1*2 ITEM 8 PAGE 11
  1. W !!?10,"Medicaid & Medicare: ",?40,$J(AGMM,6)
  1. W !!?10,"Medicaid & Private Ins.: ",?40,$J(AGMDPI,6)
  1. W !!?10,"Medicare & Private Ins.: ",?40,$J(AGMRPI,6)
  1. W !!?10,"Medicaid, Medicare, & PI: ",?40,$J(AGMMPI,6)
  1. ;S AGTOT=AGMCD+AGPI+AGMCR+AGMCRB+AGMCRAB+AGMM+AGMDPI+AGMRPI+AGMMPI
  1. S AGTOT=AGMCD+AGPI+AGMCR+AGMCRB+AGMCRAB+AGMM+AGMDPI+AGMRPI+AGMMPI+AGMCRD ;AG*7.1*4 IM26255
  1. W !?40,"------",!!?20,"TOTAL",?40,$J(AGTOT,6)
  1. I '$D(ZTQUEUED),$E(IOST)="C",$$DIR^XBDIR("E","Enter RETURN to continue")
  1. W @IOF
  1. D ^%ZISC
  1. K DFN,AG1,AG2,AG3,AG4,AG,AGTOT,AGMCD,AGPI,AGMCR,AGMCRB,AGMMPI,AGMM,AGMDPI,AGMRPI,AGMCRAB,AGDT
  1. Q
  1. ;
  1. VCHK ;
  1. S AG("V")="N",AGST=0
  1. F S AGST=$O(^AUPNVSIT("AA",DFN,AGST)) Q:AGST="" I (AGST<AG("BDT")),(AGST>AG("EDT")) S AG("V")="Y" Q
  1. Q