| 1 | RCCPCPS ;WASH-ISC@ALTOONA,PA/NYB-Build Patient Statement File ;12/19/96  4:14 PM
 | 
|---|
| 2 | V ;;4.5;Accounts Receivable;**34,70,80,48,104,116,149,170,181,190,223,237**;Mar 20, 1995
 | 
|---|
| 3 |  ;;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
| 4 | EN N CCPC,CNT,DAT,DEB,DIK,END,INADFL,LDT1,LDT3,PCC,PRN,RCDATE,RCT,SVADM,SVAMT,SVINT,SVOTH,SITE,TXT,VAR,X,%
 | 
|---|
| 5 |  N RCINFULL,RCINPART
 | 
|---|
| 6 |  K ^RCPS(349.2)
 | 
|---|
| 7 |  F X="PA","IS" S RCT=$O(^RCT(349.1,"B",X,0)) Q:'RCT  K ^RCT(349.1,+RCT,4),^RCT(349.1,+RCT,5)
 | 
|---|
| 8 |  K ^XTMP("RCCPC")
 | 
|---|
| 9 |  D DT^DICRW,SITE^PRCAGU
 | 
|---|
| 10 |  I '$D(SITE) W !!,"AR SITE PARAMETER ENTRIES NOT DEFINED!",?50 D NOW^%DTC S Y=% D DD^%DT W Y W !!,"COULD NOT PROCESS AR PATIENT STATEMENTS" Q
 | 
|---|
| 11 |  D NOW^%DTC S END=%
 | 
|---|
| 12 |  S LDT1=$$FPS^RCAMFN01(DT,-1),RCDATE=DT
 | 
|---|
| 13 |  S (CNT,DEB)=0,PRN=1
 | 
|---|
| 14 |  F  S DEB=$O(^RCD(340,"AB","DPT(",DEB)) Q:DEB=""  D
 | 
|---|
| 15 |  .   N AMT,BBAL,BEG,BN,CAT,DESC,ETY,FC,ND,PAT,PBAL,PC
 | 
|---|
| 16 |  .   N PDAT,PEND,ST,SVINT,SVADM,SVOTH,ADDR
 | 
|---|
| 17 |  .   I $L(+$$SSN^RCFN01(DEB))<5 Q
 | 
|---|
| 18 |  .   ;Check for Emergency Response Indicator (ERI) Flag.
 | 
|---|
| 19 |  .   N RCDFN S RCDFN=$P($G(^RCD(340,DEB,0)),"^",1) I $$EMERES^PRCAUTL(+RCDFN)]"" Q
 | 
|---|
| 20 |  .   S INADFL=0
 | 
|---|
| 21 |  .   S (SVADM,SVAMT,SVINT,SVOTH)=0
 | 
|---|
| 22 |  .   N REF,SBAL,SDT,TBAL,TN,TTY,X,Y
 | 
|---|
| 23 |  .   K ^TMP("PRCAGT",$J)
 | 
|---|
| 24 |  .   S BEG=+$$LST^RCFN01(DEB,2)
 | 
|---|
| 25 |  .   S LDT3=$S(BEG>0:$$FPS^RCAMFN01($P(BEG,"."),-3),1:0)
 | 
|---|
| 26 |  .   I $P(BEG,".")'<$P(RCDATE,".") Q
 | 
|---|
| 27 |  .   D NOW^%DTC S END=%
 | 
|---|
| 28 |  .   I BEG<1 S PDAT="",BEG=0,PBAL=0
 | 
|---|
| 29 |  .   I BEG S PDAT=BEG,BEG=9999999.999999-BEG,PBAL=0 D PBAL^PRCAGU(DEB,.BEG,.PBAL) ;get prev bal
 | 
|---|
| 30 |  .   D EN^PRCAGT(DEB,BEG,.END)
 | 
|---|
| 31 |  .   S TBAL=0 D TBAL^PRCAGT(DEB,.TBAL) ;get trans bal
 | 
|---|
| 32 |  .   S BBAL=0 D BBAL^PRCAGU(DEB,.BBAL) ;get bill bal
 | 
|---|
| 33 |  .   S X=$$PRE^PRCAGU(DEB) S PEND=$P(X,U,2),X=+X I X,BBAL D REF^PRCAGD(DEB,X,$G(REP)) Q
 | 
|---|
| 34 |  .   I BBAL=0,PEND,-PEND=PBAL+TBAL Q
 | 
|---|
| 35 |  .   I BBAL'=(PBAL+TBAL) D EN^PRCAGD(DEB,BBAL,TBAL,PBAL,BEG,$G(REP)) Q
 | 
|---|
| 36 |  .   I BBAL'>0,'$D(^TMP("PRCAGT",$J,DEB)) Q
 | 
|---|
| 37 |  .   I BBAL=0,$G(SITE("ZERO")) Q
 | 
|---|
| 38 |  .   I BBAL<0,BBAL>-.99 Q
 | 
|---|
| 39 |  .   I BBAL'<0,'$$ACT^PRCAGT(DEB,LDT3) Q
 | 
|---|
| 40 |  .   S TBAL=TBAL+PBAL
 | 
|---|
| 41 |  .   I '$D(^RCPS(349.2,0)) S ^(0)="AR CCPC STATEMENTS RECORDS^349.2I^"
 | 
|---|
| 42 |  .   S ^RCPS(349.2,DEB,0)=DEB_"^"_$$SSN^RCFN01(DEB)_"^"
 | 
|---|
| 43 |  .   S ADDR=$$DADD^RCAMADD(DEB,1) ;get patient's address, confidential if applicable
 | 
|---|
| 44 |  .   S ^RCPS(349.2,DEB,1)=$P(ADDR,"^",1,6)
 | 
|---|
| 45 |  .   S ST=$P(ADDR,"^",5)
 | 
|---|
| 46 |  .   S ^RCPS(349.2,DEB,7)=$P(^RCD(340,DEB,0),U,7) ;large print
 | 
|---|
| 47 |  .   I $G(ST)'="" S ST=$O(^DIC(5,"C",ST,0))
 | 
|---|
| 48 |  .   I $G(ST)>90 S FC=$P($G(^DIC(5,ST,0)),"^")
 | 
|---|
| 49 |  .   S $P(^RCPS(349.2,DEB,1),"^",7)=$G(FC) S:$G(FC)]"" $P(^RCPS(349.2,DEB,1),"^",5)="FX"
 | 
|---|
| 50 |  .   S:$G(FC)]"" $P(^RCPS(349.2,DEB,1),"^",6)=$P(ADDR,"^",8)
 | 
|---|
| 51 |  .   D NOW^%DTC S $P(^RCPS(349.2,DEB,0),"^",10)=%
 | 
|---|
| 52 |  .   S $P(^RCPS(349.2,DEB,0),"^",3)=$$NAM^RCFN01(DEB)
 | 
|---|
| 53 |  .   S $P(^RCPS(349.2,DEB,0),"^",4,7)=$S(TBAL'>0:0,1:TBAL)_"^"_PBAL_"^"_TBAL("CH")_"^"_TBAL("PC"),$P(^(0),"^",8)=PBAL+TBAL("CH")+TBAL("PC")+TBAL("RF")
 | 
|---|
| 54 |  .   S $P(^RCPS(349.2,DEB,0),"^",13,17)=BBAL("PB")_"^"_BBAL("INT")_"^"_BBAL("ADM")_"^"_BBAL("MF")_"^"_BBAL("CT")
 | 
|---|
| 55 |  .   ;
 | 
|---|
| 56 |  .   N RCBILLDA,RCDATA1,RCDEBTDA,RCDESC,RCPSDA,RCTOTAL,RCTRANDA,RCTRDATE,VALUE,RCCOM1,RCCOM2,RCCOM3
 | 
|---|
| 57 |  .   S RCDEBTDA=DEB
 | 
|---|
| 58 |  .   I '$D(^RCPS(349.2,RCDEBTDA,2,0)) S ^(0)="^349.21DA^^"
 | 
|---|
| 59 |  .   ;
 | 
|---|
| 60 |  .   S RCCOM1=$E($TR($G(SITE("COM1")),"~|^",""),1,80),(RCCOM2,RCCOM3)=""
 | 
|---|
| 61 |  .   ; Add second comment line for the GMT-reduced status
 | 
|---|
| 62 |  .   I $$GMT^PRCAGST(RCDEBTDA) S RCCOM2="REDUCTION OF INPATIENT COPAYMENT DUE TO GEOGRAPHIC MEANS TEST STATUS"
 | 
|---|
| 63 |  .   I TBAL'>0 S RCCOM3=" *THIS IS NOT A BILL*"
 | 
|---|
| 64 |  .   I RCCOM1'="",RCCOM2'="" S $E(RCCOM1,80)=" " ;Make sure GMT message will be printed on separate line.
 | 
|---|
| 65 |  .   S ^RCPS(349.2,RCDEBTDA,3)=RCCOM1_RCCOM2_RCCOM3
 | 
|---|
| 66 |  .   ;
 | 
|---|
| 67 |  .   S RCPSDA=0 ; this variable used to set the description on the PS segment
 | 
|---|
| 68 |  .   S RCTRDATE=0 F  S RCTRDATE=$O(^TMP("PRCAGT",$J,RCDEBTDA,RCTRDATE)) Q:'RCTRDATE  S RCBILLDA=0 F  S RCBILLDA=$O(^TMP("PRCAGT",$J,RCDEBTDA,RCTRDATE,RCBILLDA)) Q:'RCBILLDA  D
 | 
|---|
| 69 |  .   .   I $P($G(^RCPS(349.2,RCDEBTDA,0)),"^",8)<0 S PC(75)=75
 | 
|---|
| 70 |  .   .   I $P($G(^PRCA(430,RCBILLDA,6)),"^",2)]"",($P($G(^PRCA(430,RCBILLDA,7)),"^")>0) S PC(1)="01"
 | 
|---|
| 71 |  .   .   S CAT=$P($G(^PRCA(430,RCBILLDA,0)),"^",2)
 | 
|---|
| 72 |  .   .   S PC=$P($G(^PRCA(430.2,CAT,0)),"^",14)
 | 
|---|
| 73 |  .   .   F X=1:1:100 I $P(PC,",",X)'="" S PCC=$P(PC,",",X),PC(+PCC)=PCC Q:PCC=""
 | 
|---|
| 74 |  .   .   S PC="",X=0 F  S X=$O(PC(X)) Q:X=""  I $G(PC(X))'="" S PC=PC_PC(X)
 | 
|---|
| 75 |  .   .   S $P(^RCPS(349.2,RCDEBTDA,4),"^")=PC
 | 
|---|
| 76 |  .   .   ;
 | 
|---|
| 77 |  .   .   I $D(^TMP("PRCAGT",$J,RCDEBTDA,RCTRDATE,RCBILLDA,0)) S AMT=+^(0) I AMT D
 | 
|---|
| 78 |  .   .   .   ;  get the description for the bill
 | 
|---|
| 79 |  .   .   .   K RCDESC D BILLDESC^RCCPCPS1(RCBILLDA)
 | 
|---|
| 80 |  .   .   .   ;
 | 
|---|
| 81 |  .   .   .   ;  store the description in file 349.2, PS segment
 | 
|---|
| 82 |  .   .   .   S RCPSDA=RCPSDA+1
 | 
|---|
| 83 |  .   .   .   S $P(^RCPS(349.2,RCDEBTDA,2,RCPSDA,0),"^",1,4)=$P(RCTRDATE,".")_"^"_$G(RCDESC(1))_"^"_$G(AMT)_"^"_$P(^PRCA(430,RCBILLDA,0),"^")
 | 
|---|
| 84 |  .   .   .   F X=2:1 Q:$G(RCDESC(X))=""  S RCPSDA=RCPSDA+1,^RCPS(349.2,RCDEBTDA,2,RCPSDA,0)="^"_RCDESC(X)_"^^"
 | 
|---|
| 85 |  .   .   ;
 | 
|---|
| 86 |  .   .   S RCTRANDA=0 F  S RCTRANDA=$O(^TMP("PRCAGT",$J,RCDEBTDA,RCTRDATE,RCBILLDA,RCTRANDA)) D:'RCTRANDA NO Q:'RCTRANDA  D
 | 
|---|
| 87 |  .   .   .   ;  get the description for the transaction
 | 
|---|
| 88 |  .   .   .   K RCDESC D TRANDESC^RCCPCPS1(RCTRANDA),RCDESC
 | 
|---|
| 89 |  .   .   .   ;  if it is an interest/admin charge, summarize it below
 | 
|---|
| 90 |  .   .   .   I $G(RCDESC(1))["INTEREST" Q
 | 
|---|
| 91 |  .   .   .   ;  get the value of the transaction for the statement
 | 
|---|
| 92 |  .   .   .   S VALUE=$$TRANVALU^RCDPBTLM(RCTRANDA)
 | 
|---|
| 93 |  .   .   .   S VALUE=$P(VALUE,"^",2)+$P(VALUE,"^",3)+$P(VALUE,"^",4)+$P(VALUE,"^",5)+$P(VALUE,"^",6)
 | 
|---|
| 94 |  .   .   .   ;  if it is a suspended (47) or unsuspended (46) transaction, show value
 | 
|---|
| 95 |  .   .   .   ;  make suspended charges appear as negative
 | 
|---|
| 96 |  .   .   .   S RCDATA1=$G(^PRCA(433,RCTRANDA,1))
 | 
|---|
| 97 |  .   .   .   I $P(RCDATA1,"^",2)=47!($P(RCDATA1,"^",2)=46) S VALUE=$P(RCDATA1,"^",5) I $P(RCDATA1,"^",2)=47 S VALUE=-VALUE
 | 
|---|
| 98 |  .   .   .   ;  if it is an amended bill, show value
 | 
|---|
| 99 |  .   .   .   I $P(RCDATA1,"^",2)=33 S VALUE=$P(RCDATA1,"^",5)
 | 
|---|
| 100 |  .   .   .   ;  store the description in file 349.2, PS segment
 | 
|---|
| 101 |  .   .   .   S RCPSDA=RCPSDA+1
 | 
|---|
| 102 |  .   .   .   S $P(^RCPS(349.2,RCDEBTDA,2,RCPSDA,0),"^",1,5)=$P(RCTRDATE,".")_"^"_$G(RCDESC(1))_"^"_VALUE_"^"_$P(^PRCA(430,RCBILLDA,0),"^")
 | 
|---|
| 103 |  .   .   .   F X=2:1 Q:$G(RCDESC(X))=""  S RCPSDA=RCPSDA+1,^RCPS(349.2,RCDEBTDA,2,RCPSDA,0)="^"_RCDESC(X)_"^^"
 | 
|---|
| 104 |  .   .   .   ;
 | 
|---|
| 105 |  .   .   .   ;  for comment transaction ... not sure what this is for ?
 | 
|---|
| 106 |  .   .   .   I $P(RCDATA1,"^",2)=45,$P($G(^PRCA(433,RCTRANDA,5)),"^",2)["your waiver rights" S ^RCPS(349.2,+RCDEBTDA,4)="0150"
 | 
|---|
| 107 |  .   ;
 | 
|---|
| 108 |  .   ;  if interest, admin, or other, add them here
 | 
|---|
| 109 |  .   S X=$G(RCTOTAL("INT"))+$G(RCTOTAL("ADM"))+$G(RCTOTAL("OTH"))
 | 
|---|
| 110 |  .   I X>0 D
 | 
|---|
| 111 |  .   .   S RCDESC="INTEREST/ADM. CHARGE (Int:"_$J($G(RCTOTAL("INT")),1,2)_" Adm:"_$J($G(RCTOTAL("ADM")),1,2)_" Other:"_$J($G(RCTOTAL("OTH")),1,2)_")"
 | 
|---|
| 112 |  .   .   S RCPSDA=RCPSDA+1
 | 
|---|
| 113 |  .   .   S ^RCPS(349.2,RCDEBTDA,2,RCPSDA,0)="^"_RCDESC_"^"_$J(X,1,2)
 | 
|---|
| 114 |  .   .   S ^RCPS(349.2,RCDEBTDA,2,0)="^349.21DA^"_RCPSDA_"^"_RCPSDA
 | 
|---|
| 115 |  .   ;
 | 
|---|
| 116 |  .   ;  set 0th node
 | 
|---|
| 117 |  .   I RCPSDA S ^RCPS(349.2,RCDEBTDA,2,0)="^349.21DA^"_RCPSDA_"^"_RCPSDA
 | 
|---|
| 118 |  .   ;
 | 
|---|
| 119 |  .   I RCPSDA'<287 S ^XTMP("RCCPC",0)=DT,^XTMP("RCCPC",RCDEBTDA)="" Q
 | 
|---|
| 120 |  .   D NO
 | 
|---|
| 121 |  ;
 | 
|---|
| 122 |  S DIK="^RCPS(349.2," D IXALL^DIK
 | 
|---|
| 123 |  S DEB=0 S DEB=$O(^RCPS(349.2,DEB)) Q:DEB=""  S $P(^(DEB,0),"^",18)=1
 | 
|---|
| 124 |  ;
 | 
|---|
| 125 | OSTM ;Process old statements
 | 
|---|
| 126 |  S DIK="^RCPS(349.2,",DA=0 F  S DA=$O(^XTMP("RCCPC",DA)) Q:'DA  D ^DIK
 | 
|---|
| 127 |  K DA
 | 
|---|
| 128 |  ;
 | 
|---|
| 129 | STATMNT ;Print patient statements
 | 
|---|
| 130 |  N IOP,ZTIO,ZTSAVE,ZTRTN,ZTDESC,ZTASK,%ZIS,ZTDTH,PRCADEV
 | 
|---|
| 131 |  S (IOP,PRCADEV)=$P($G(^RC(342,1,0)),"^",8)
 | 
|---|
| 132 |  I IOP]"" D
 | 
|---|
| 133 |  .S ZTRTN="STM^RCCPCSTM",ZTDTH=$H,ZTDESC="Print old AR Statements"
 | 
|---|
| 134 |  .S %ZIS="N0" D ^%ZIS Q:POP
 | 
|---|
| 135 |  .S ZTSAVE("PRCADEV")="" D ^%ZTLOAD,^%ZISC
 | 
|---|
| 136 |  Q
 | 
|---|
| 137 |  ;
 | 
|---|
| 138 | NO ;If there is no activity
 | 
|---|
| 139 |  I $G(^RCPS(349.2,+DEB,4))["0150" D
 | 
|---|
| 140 |  .S ^RCPS(349.2,+DEB,2,1,0)="^NOTICE: You now have delinquent charges. Please^^"
 | 
|---|
| 141 |  .S ^RCPS(349.2,+DEB,2,2,0)="^review Enforcement of Involuntary Collections^^"
 | 
|---|
| 142 |  .S ^RCPS(349.2,+DEB,2,3,0)="^on reverse.^^"
 | 
|---|
| 143 |  .S ^RCPS(349.2,+DEB,2,0)="^^3^3"
 | 
|---|
| 144 |  I $G(^RCPS(349.2,DEB,2,1,0))="" D
 | 
|---|
| 145 |  .S ^RCPS(349.2,DEB,2,1,0)="^No Activity in the Last 30 Days!^^"
 | 
|---|
| 146 |  .S ^RCPS(349.2,DEB,2,2,0)="^Please refer to previous statement of rights.^^"
 | 
|---|
| 147 |  .S ^RCPS(349.2,DEB,2,0)="^^2^2"
 | 
|---|
| 148 |  .I $G(^RCPS(349.2,DEB,4))="" S ^(4)="90"
 | 
|---|
| 149 |  Q
 | 
|---|
| 150 | BUILD ;This is the entry point from the BUILD CCPC file option
 | 
|---|
| 151 |  N TDT,QDT,ZTDESC,ZTASK,ZTSK,ZDTDTH,ZTIO,ZTRTN
 | 
|---|
| 152 |  S TDT=$O(^RCPS(349.2,0)) I TDT D
 | 
|---|
| 153 |  .S TDT=$$ASOF^RCCPCFN($P($G(^RCPS(349.2,+TDT,0)),"^",10))
 | 
|---|
| 154 |  .S TDT=$TR($$SLH^RCFN01(TDT),"/","")
 | 
|---|
| 155 |  .S TDT("T")=$P($G(^RCT(349,1,0)),"^",10),TDT("T")=$E(TDT("T"),1,4)_$E(TDT("T"),7,8)
 | 
|---|
| 156 |  .I TDT("T")=TDT D
 | 
|---|
| 157 |  ..W *7,!,"The current file reflects activity as of ",$E(TDT,1,2)_"/"_$E(TDT,3,4)_"/"_$E(TDT,5,8)_".",!
 | 
|---|
| 158 |  ..W !,"IT WAS TRANSMITTED ON ",$TR($P($P($G(^RCT(349,1,0)),"^"),".",2,4),".","/"),!
 | 
|---|
| 159 |  ..S TDT=$P($G(^RCT(349,1,0)),"^",9)
 | 
|---|
| 160 |  ..W !,"For statement date: ",$E(TDT,1,2)_"/"_$E(TDT,3,4)_"/"_$E(TDT,5,8)
 | 
|---|
| 161 |  ..W !!,"PLEASE CONTACT CUSTOMER SUPPORT BEFORE PROCEEDING.",!!
 | 
|---|
| 162 | TIME S ZTIO="",ZTRTN="EN^RCCPCPS",ZTDESC="Build CCPC Statement File"
 | 
|---|
| 163 |  S ZTDTH="" D ^%ZTLOAD Q:$G(ZTSK)=""
 | 
|---|
| 164 |  S %H=ZTSK("D") D YMD^%DTC S QDT=X_%
 | 
|---|
| 165 |  I (QDT>DT_"."_0800)&(QDT<(DT_"."_1801)) D  G TIME
 | 
|---|
| 166 |  .W !!,*7,"You Can Not Queue this Job Between 8:00am and 6:00pm.",!
 | 
|---|
| 167 |  .D KILL^%ZTLOAD
 | 
|---|
| 168 |  W !,"Queued for Building."
 | 
|---|
| 169 |  Q
 | 
|---|
| 170 |  ;
 | 
|---|
| 171 | RCDESC ;Remove "IN PART" & "IN FULL" from the the bill description
 | 
|---|
| 172 |  QUIT:$G(RCDESC(1))=""
 | 
|---|
| 173 |  S RCINFULL=" (IN FULL)"
 | 
|---|
| 174 |  S RCINPART=" (IN PART)"
 | 
|---|
| 175 |  I RCDESC(1)[RCINFULL S RCDESC(1)=$P(RCDESC(1),RCINFULL)_$P(RCDESC(1),RCINFULL,2)
 | 
|---|
| 176 |  I RCDESC(1)[RCINPART S RCDESC(1)=$P(RCDESC(1),RCINPART)_$P(RCDESC(1),RCINPART,2)
 | 
|---|
| 177 |  Q
 | 
|---|