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

RCRCREC2.m

Go to the documentation of this file.
  1. RCRCREC2 ;ALB/CMS - RC AND DHCP RECONCILIATION REP LOOP ; 16-JUN-00
  1. V ;;4.5;Accounts Receivable;**61,82,63,147,159**;Mar 20, 1995
  1. ;;Per VHA Directive 10-93-142, this routine should not be modified.
  1. ;
  1. ;Called from RCRCREC to loop through the XTMP(RCXTYP) global
  1. ;and the ^PRCA(430,"AD" cross-ref and compare the two. The
  1. ;task execution time is set by the RC RC SERV menu option Server
  1. ;Action. This job may be killed by IRM but notify the MCCR Referral Cord
  1. ;
  1. ;INPUT : RCJOB,RCXTYP,RCVAR,RCSITE,RCXMY
  1. ;OUTPUT: ^TMP("PRCA",$J,MESSAGE TYPE for each message type
  1. ;
  1. D ARLOOP
  1. D RCLOOP
  1. END Q
  1. ;
  1. ARLOOP ;LOOP THROUGH AR CROSS-REF DATE "AD" OF 430
  1. N RCBN,RCBN0,RCCAT,REF,RFDT
  1. S RCCAT="" D RCCAT^RCRCUTL(.RCCAT)
  1. S RFDT=0 F S RFDT=$O(^PRCA(430,"AD",RFDT)) Q:'RFDT D RCBN
  1. Q
  1. RCBN ;GET BN AND CHK FOR BAD CROSS-REF, IF TP SET
  1. N RCS1,RCS2,RCS3
  1. S RCBN=0 F S RCBN=$O(^PRCA(430,"AD",RFDT,RCBN)) Q:'RCBN D
  1. .S REF=$P($G(^PRCA(430,RCBN,6)),U,4,6)
  1. .I REF="" K ^PRCA(430,"AD",RFDT,RCBN) Q
  1. .I $P(REF,U,1)="",$P(REF,U,3)="" K ^PRCA(430,"AD",RFDT,RCBN) Q
  1. .I $P(REF,U,1)="",$P(REF,U,3)]"" S $P(^PRCA(430,RCBN,6),U,4)=RFDT S $P(REF,U,1)=RFDT
  1. .I $P(REF,U,1)'=RFDT S ^PRCA(430,"AD",$P(REF,U,1),RCBN)="" K ^PRCA(430,"AD",RFDT,RCBN)
  1. .S RCBN0=$G(^PRCA(430,RCBN,0))
  1. .I $P(RCBN0,U,8)'=16 Q
  1. .I RCXTYP="PRCADR1",+$P(RCBN0,U,2)'=9 Q
  1. .S RCS1=$G(RCCAT(+$P(RCBN0,U,2))) I RCS1="" Q
  1. .I $O(RCDIV(0)),('$D(RCDIV("RCDOMAIN",RCDOMNM,$$DIV^IBJDF2(RCBN0)))) Q
  1. .S RCS2=$$NAM^RCFN01(+$P(RCBN0,U,9))
  1. .;
  1. .S RCS3=$P($G(^DPT(+$P(RCBN0,U,7),0)),U,1)
  1. .;
  1. .;
  1. .S ^TMP("PRCA",$J,$P(RCBN0,U,1),RCBN)=$P(RCBN0,U,1)_U_RCS2_U_$P(REF,U,1)_U_$P(REF,U,2)_U_RCS3_U_$P(REF,U,3)_U_$P($G(^DPT(+$P(RCBN0,U,7),0)),U,9)_U_$P(RCS1,U,2)
  1. Q
  1. ;
  1. ;
  1. RCLOOP ;LOOP THRU THE XTMP GLOBAL SET FROM RC
  1. ;MR1- Bill referred by medical Center, but not in Regional Counsel
  1. ;MR2- Regional Counsel has bill but, Medical does not show bill as referred
  1. ;MR3- Bill in both RC and VAMC but, dollar amount does not agree
  1. ;MR4- Bill in both RC and VAMC but, a contract/decrease adjustment was made before referred
  1. ;
  1. N ERR,I,RCI,RCLN
  1. S RCI=0 F S RCI=$O(^XTMP(RCXTYP,RCXMZ,RCI)) Q:'RCI D
  1. .S RCLN=^XTMP(RCXTYP,RCXMZ,RCI) K ERR
  1. .I RCLN["$$RC$" Q
  1. .I RCLN'["^" Q
  1. .I $P(RCLN,U,1)="" D MR2 Q
  1. .I $D(^TMP("PRCA",$J,$P(RCLN,U,1))) D MR34 Q
  1. .I '$D(^TMP("PRCA",$J,$P(RCLN,U,1))) D MR2
  1. D MR1
  1. D SORT^RCRCREC3
  1. Q
  1. ;
  1. MR34 ;BILL IS IN BOTH SYSTEMS AS REFERRED
  1. ;MR3. SEE IF DOLLAR AMT IS THE SAME
  1. ;MR4. SEE IF DECREASE/CONTRACT DONE BEFORE REFERRED
  1. N ARLN,ARBAL,BN,CURBAL,MTYP,X S MTYP="MR3" K ERR
  1. S BN=$O(^TMP("PRCA",$J,$P(RCLN,U,1),0)) G MR34Q:BN=""
  1. S ARLN=^TMP("PRCA",$J,$P(RCLN,U,1),BN)
  1. I +$P(ARLN,U,6)'=$P(+$P(RCLN,U,6),".00",1) S ERR("MR3",3)=""
  1. S ARBAL=$G(^PRCA(430,BN,7)),CURBAL=0
  1. I ARBAL]"" F X=1:1:5 S CURBAL=CURBAL+$P(ARBAL,U,X)
  1. I +CURBAL'=+$P(ARLN,U,6) S ERR("MR3",7)=CURBAL
  1. I $P(RCLN,U,7)]"",$P(ARLN,U,7)'=$P(RCLN,U,7) S ERR("MR3",9)=""
  1. I $O(ERR("MR3",0)) S MTYP="MR3" G MR34A
  1. S MTYP="MR4" D L433^RCRCREC3 I $O(ERR("MR4",0)) S RCLN=""
  1. I '$O(ERR("MR4",0)) G MR34B
  1. MR34A K ERR("MR3",3) D SET^RCRCREC3
  1. MR34B K ^TMP("PRCA",$J,$P(ARLN,U,1)),^XTMP(RCXTYP,RCXMZ,RCI)
  1. MR34Q Q
  1. ;
  1. MR2 ;MR2 BILL IS AT RC AS REFERRED BUT NOT IN AR AS REFERRED
  1. N BN,MTYP,REFDT,RCBN0,RFDT S MTYP="MR2"
  1. I $P(RCLN,U,1)="" S ERR("MR2",1)="" G MR2A
  1. I '$D(^PRCA(430,"B",$P(RCLN,U,1))) S ERR("MR2",1)="" G MR2A
  1. S BN=$O(^PRCA(430,"B",$P(RCLN,U,1),0)) S RCBN0=^PRCA(430,BN,0)
  1. I $P(RCBN0,U,8)'=16 S ERR("MR2",2)=$P($G(^PRCA(430.3,+$P(RCBN0,U,8),0)),"^",1) G MR2A
  1. I RCXTYP="PRCADR1",$P(RCBN0,U,2)'=9 S ERR("MR2",6)=$P($G(^PRCA(430.2,+$P(RCBN0,U,2),0)),"^",1) G MR2A
  1. ;I '$G(RCCAT(+$P(RCBN0,U,2))) S ERR("MR2",6)=$P($G(^PRCA(430.2,+$P(RCBN0,U,2),0)),U,1) G MR2A
  1. S RFDT=$P($G(^PRCA(430,BN,6)),U,4) I RFDT="" S ERR("MR2",5)="" G MR2A
  1. I '$D(^PRCA(430,"AD",RFDT,BN)) S ^PRCA(430,"AD",RFDT,BN)="" G MR2B
  1. G MR2B
  1. MR2A D SET^RCRCREC3
  1. MR2B K ^XTMP(RCXTYP,RCXMZ,RCI)
  1. MR2Q Q
  1. ;
  1. MR1 ;BILLS REFERRED IN AR NOT IN RC
  1. N ARBAL,BN,CURBAL,ERR,I,MTYP,RCBNAM,REFDT,X
  1. S RCLN="",RCI="",MTYP="MR1"
  1. S RCBNAM="" F I=1:1 S RCBNAM=$O(^TMP("PRCA",$J,RCBNAM)) Q:'RCBNAM D
  1. .S BN=$O(^TMP("PRCA",$J,RCBNAM,0))
  1. .I $O(RCDIV(0)),('$D(RCDIV("RCDOMAIN",RCDOMNM,$$DIV^IBJDF2(+BN)))) Q
  1. .S ARLN=^TMP("PRCA",$J,RCBNAM,BN)
  1. MR1A .D SET^RCRCREC3
  1. .K ^TMP("PRCA",$J,RCBNAM)
  1. MR1Q Q
  1. ;
  1. ;
  1. ;
  1. ;
  1. ;RCRCREC2