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

BARMAWO7.m

Go to the documentation of this file.
  1. BARMAWO7 ; IHS/SD/LSL - Automatic Write-off (con't) ;
  1. ;;1.8;IHS ACCOUNTS RECEIVABLE;**1,2,21,24,28**;OCT 26, 2005;Build 92
  1. ;
  1. ;IHS/ASDS/LSL - 06/15/2001 - V1.5 Patch 1 - NOIS HQW-0601-100051 Modifying BARMAWO to extend the expiration date resulted in
  1. ; the routine being too large. Created this routine to break up BARMAWO.
  1. ;IHS/ASDS/LSL - 09/07/01 - V1.5 Patch 2 - Modified to accomodate finance changes as documented in BARMAWO
  1. ;
  1. ;IHS/SD/LSL - 07/24/02 - V1.7 - NOIS CMA-0702-110082 Resolve <UNDEF>WRITEOFF+17^BARMAWO1
  1. ;IHS/SD/LSL - 11/26/02 - V1.7 - NOIS QAA-1200-130051 Quit if error in getting A/R Transaction
  1. ;IHS/SD/LSL - 12/06/02 - V1.7 - NOIS NHA-0601-180049 Find 3P bill correctly.
  1. ;
  1. ;IHS/SD/PKD - 03/28/11 - 1.8*21 Manilaq, Alaska write-offs through 1/1/09 has been approved
  1. ; Heat 19931. Modify to allow Date Range to be entered regardless of Parameter file. Called from BARMAWO6 after asking paramters
  1. ;IHS/SD/POT 1/2/2014 HEAT147266 fixed start / end dates
  1. ;IHS/SD/SDR 1.8*28 CR8349 HEAT293633 - Changed hardcoded adjustment category 3 to use variable instead so user's answer is used. Also
  1. ; added transaction IEN to output for user. Made sure all bills reviewed are captured in some sense, whether as written off, or
  1. ; by what reason they were skipped.
  1. ;
  1. Q
  1. ; **********
  1. LOOPDUZ ; EP
  1. ; Loop A/R Bill File by DUZ(2)
  1. S BARDUZ=0
  1. F S BARDUZ=$O(^BARBL(BARDUZ)) Q:'+BARDUZ D LOOPDT
  1. Q
  1. ; **********
  1. LOOPDT ;
  1. ; Loop A/R Bill File by date of service
  1. S BARVISIT=BARDOS1-0.00001 ;BAR*1.8*24
  1. ;F S BARVISIT=$O(^BARBL(BARDUZ,"E",BARVISIT)) Q:'+BARVISIT!(BARVISIT>BARDOS2) D LOOPBIL ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. F S BARVISIT=$O(^BARBL(BARDUZ,BAR("DTYP"),BARVISIT)) Q:'+BARVISIT!(BARVISIT>BARDOS2) D LOOPBIL ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. Q
  1. ; **********
  1. LOOPBIL ;
  1. ; Loop bills for date of service
  1. S BARBL2=0
  1. ;F S BARBL2=$O(^BARBL(BARDUZ,"E",BARVISIT,BARBL2)) Q:'+BARBL2 D WRITEOFF ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. F S BARBL2=$O(^BARBL(BARDUZ,BAR("DTYP"),BARVISIT,BARBL2)) Q:'+BARBL2 D WRITEOFF ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. Q
  1. ; **********
  1. WRITEOFF ;
  1. ;Write off bills that meet criteria
  1. Q:'$D(^BARBL(BARDUZ,BARBL2)) ;No bill data
  1. S BAR(0)=$G(^BARBL(BARDUZ,BARBL2,0)) ;A/R Bill 0 node
  1. S BAR(1)=$G(^BARBL(BARDUZ,BARBL2,1)) ;A/R Bill 0 node
  1. S BARBAL=$P(BAR(0),U,15) ;Bill Balance
  1. S BARAMT=$P(BAR(0),U,13) ;Billed Amount
  1. S BARVSTL=$P(BAR(1),U,8) ;Visit location
  1. S BARDOSE=$P(BAR(1),U,3) ;1;3 DOS END
  1. ;I BARDOSE>BARDOS2 Q ;P.OTT 1/2/2004 ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633 ;removed - if the begin date is in range it should adjust bill, no matter the end date
  1. ;Q if A/R account is not on bill
  1. ;I $P(BAR(0),U,3)="" S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"NO A/R ACCT",BARBL2)="" Q ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I $P(BAR(0),U,3)="" S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"NO A/R ACCT",BARBL2)=$P(BAR(0),U) Q ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;Q if visit location not in list
  1. ;I $D(BAR("LOC")),'$D(BAR("LOC",BARVSTL)) Q ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I $D(BAR("LOC")),'$D(BAR("LOC",BARVSTL)) S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"NOT VLOC",BARBL2)=$P(BAR(0),U) Q ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633 - capture not visit loc
  1. ;Q if A/R account not in list
  1. ;I $D(BAR("ACCT")),'$D(BAR("ACCT",$P(BAR(0),U,3))) Q ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I $D(BAR("ACCT")),'$D(BAR("ACCT",$P(BAR(0),U,3))) S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"NOT ACCT",BARBL2)=$P(BAR(0),U) Q ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633 - capture not A/R Account
  1. S BARACT=$P(BAR(0),U,3) ;A/R Account
  1. S D0=BARACT ;BAR*1.8*2
  1. S BARITYP=$$VALI^BARVPM(8) ;GET INTERNAL CODE INSTEAD OF 'STANDS FOR'
  1. ;IHS/SD/PKD 1.8*manilaq Allow Non-Bens to be written off
  1. ;Q:BARITYP="N"
  1. ;I 'BENPLUS Q:BARITYP="N" ;BENPLUS=0 IF ONLY NON-BEN IN WRITEOFF ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I 'BENPLUS,BARITYP="N" S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"NON-BEN",BARBL2)=$P(BAR(0),U) Q ;BENPLUS=0 IF ONLY NON-BEN IN WRITEOFF ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. BEN ;
  1. I BARBAL'>0 D Q ;Don't want 0 or credit bal
  1. .;S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"CREDIT",BARBL2)="" ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. .S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"CREDIT",BARBL2)=$P(BAR(0),U) ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;IHS/SD/PKD 5/12/11 removed the $20,000 ceiling on write-off
  1. ;I BARAMT>20000 D Q ;May only write-off $20,000
  1. ;.S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"TOO HIGH",BARBL2)=""
  1. S DUZ(2)=BARDUZ
  1. S BARTRIEN=$$NEW^BARTR ;Create new transaction
  1. I BARTRIEN<1 D MSG^BARTR(BARBL2) Q
  1. S DA=BARTRIEN
  1. S DIE=90050.03
  1. S DR="2////^S X=BARBAL" ;Credit ($$$)
  1. S DR=DR_";4////^S X=BARBL2" ;A/R Bill
  1. S DR=DR_";5////^S X=$P(BAR(1),U)" ;A/R Patient
  1. S DR=DR_";6////^S X=$P(BAR(0),U,3)" ;A/R Account
  1. S DR=DR_";8////^S X=DUZ(2)" ;Parent Location
  1. ;S DR=DR_";9////^S X=DUZ(2)" ;Parent ASUFAC ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633 removed; we don't populate normally and this is wrong; it's the IEN, not ASUFAC
  1. S DR=DR_";10////^S X=BARSECT" ;A/R Section
  1. S DR=DR_";11////^S X=$P(BAR(1),U,8)" ;Visit location
  1. S DR=DR_";12////^S X=DT" ;Date
  1. S DR=DR_";13////^S X=DUZ" ;A/R Entry by
  1. S DR=DR_";101////43" ;Transaction type (Adj)
  1. ;S DR=DR_";102////3" ;Adj Category (Write off) ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. S DR=DR_";102////^S X=BARCAT" ;Adj Category (Write off) ;change from hardcoded 3 to user's answer to prompt ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. S DR=DR_";103////^S X=ADJTYPE" ;Adj Type (Auto write off)
  1. I BARUXMIT'=1 S DR=DR_";112////I" ;ignore transaction if user said no, don't send ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. S DIDEL=90050
  1. D ^DIE ;Populate transaction file
  1. K DIDEL,DIE,DA,DR
  1. D TR^BARTDO(BARTRIEN) ;Post from Trans to files
  1. K BARBL
  1. S BARCNT=BARCNT+1
  1. ;W !,$P(BAR(0),U),?25," for ",$J($FN(BARBAL,",",2),10)," written off." ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W !,$P(BAR(0),U),?25," for ",$J($FN(BARBAL,",",2),10)," with trans ",BARTRIEN ;write trans to screen ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. S ^BARTMP("BARAWO",BARDUZ,DT,DUZ,"WRITEOFF DONE",BARBL2)=$P(BAR(0),U) ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;D ROLLBILL ;Roll info to 3PB ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I BARRBACK=1 D ROLLBILL ;Roll info to 3PB to user answered YES to rollback ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. Q
  1. ; **********
  1. ROLLBILL ;
  1. ; For bills written off, update Payment multiple in 3P and mark bill
  1. ; complete in 3PB. Also mark bill as rolled in A/R
  1. S BARBLDA=BARBL2
  1. D SETVAR^BARROLL ; Set A/R vars to roll to 3PB
  1. S ROLL=0 ;BAR*1.8*1 UFMS WRITE-OFF
  1. D ROLL
  1. Q:'ROLL ;BAR*1.8*1 UFMS WRITE-OFF
  1. D SETBLRL^BARROLL ; Mark bill as rolled
  1. Q
  1. ; **********
  1. ROLL ;EP
  1. ; Changed code NHA-0601-180049 V1.6 Patch 4
  1. ; Roll A/R vars to 3PB
  1. K DIE,DA,DR
  1. S BAR("3P BILL LOC")=$$FIND3PB^BARUTL(DUZ(2),BARBLDA)
  1. S DUZO2=DUZ(2)
  1. S DUZ(2)=$P(BAR("3P BILL LOC"),",")
  1. S Y=$P(BAR("3P BILL LOC"),",",2)
  1. ;BEGIN ;IF CAN'T FIND 3P BILL INFO SKIP ROLL OVER BAR*1.8*1
  1. I DUZ(2)=""!(Y="") S ROLL=0,DUZ(2)=DUZO2 Q
  1. S ROLL=1
  1. ;END
  1. S Y=Y_"^"_DUZ(2)
  1. S DIC=$$DIC^XBDIQ1(9002274.4)
  1. S BARGBL=DIC_+Y_")"
  1. I $D(@BARGBL) D ROLLTPB ; Roll to 3PB
  1. S DUZ(2)=DUZO2
  1. Q
  1. ; **********
  1. ROLLTPB ;
  1. ; File A/R data in payment mult of 3PB
  1. M ABM=BARSUM
  1. S X=Y
  1. ;S Z=BAR3PNM ;IM18173 BAR*1.8*1
  1. S ABMP("BDFN")=+X ; IEN to 3PB BILL
  1. S ABMP("BILL")=$P(^ABMDBILL(DUZ(2),ABMP("BDFN"),0),"^",1) ; Bill #
  1. I 'ABMP("BDFN") Q
  1. ; File A/R data in payment multiple of 3P BILL and complete bill
  1. D FILE^ABMAROLL
  1. Q
  1. ;moved CONTINUE tag from BARMAWO6 to here due to routine size
  1. CONTINUE ;
  1. ;Display choices to user; ask if they wish to continue.
  1. ;Tell them bills written off will scroll on screen if they wish to
  1. ;capture.
  1. W !!!!! ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I $G(BARDOS("E"))="" W !,"Quitting - no date entered" Q
  1. ;W "You have chosen to write off bills meeting the above criteria" ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W "You have chosen to write off bills meeting the following criteria:",! ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;W !,"for dates of service from ",BARDOS1("E")," to ",BARDOS2("E") ;;P.OTT 1/2/2014 ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W !,"for "_$S(BAR("DTYP")="AG":"Approval Dates",1:"Dates of Service")_": ",?25,BARDOS1("E")," to ",BARDOS2("E") ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;W !!,"for the following Locations: " ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W !,"for Locations: " ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;I '$D(BAR("LOC")) W ?40,"ALL" ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I '$D(BAR("LOC")) W ?25,"ALL" ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I $D(BAR("LOC")) D
  1. .S BARTMP=0
  1. .F S BARTMP=$O(BAR("LOC",BARTMP)) Q:'+BARTMP D
  1. ..;W ?40,$P(^DIC(4,BARTMP,0),U),! ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ..W ?25,$P(^DIC(4,BARTMP,0),U),! ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;W !,"for the following A/R accounts: " ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W !,"for A/R accounts: " ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;I '$D(BAR("ACCT")) W ?40,"ALL" I 'BENPLUS W " BENEFICIARY" ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I '$D(BAR("ACCT")) W ?25,"ALL" I 'BENPLUS W " BENEFICIARY" ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. I $D(BAR("ACCT")) D
  1. .S BARTMP=0
  1. .F S BARTMP=$O(BAR("ACCT",BARTMP)) Q:'+BARTMP D
  1. ..;W ?40,$$VAL^XBDIQ1(90050.02,BARTMP,.01),! ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ..W ?25,$$VAL^XBDIQ1(90050.02,BARTMP,.01),! ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W ! ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;start old bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. ;W !,"The Transaction Type will be: Adjustment (43)"
  1. ;W !,"The Adjustment Category will be: ",BARY("ADJ CAT",BARCAT)," (",(BARCAT),")"
  1. ;W !,"The Adjustment Type will be: ",BARY("ADJ TYP",ADJTYPE)," (",(ADJTYPE),")",!!
  1. ;end old start new bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W !?3,"Transaction Type: Adjustment (43)" ;bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W !,"Adjustment Category: ",BARY("ADJ CAT",BARCAT)," (",(BARCAT),")"
  1. W !?4,"Adjustment Type: ",BARY("ADJ TYP",ADJTYPE)," (",(ADJTYPE),")"
  1. W !!,"Bills will "_$S(BARRBACK'=1:"*NOT* ",1:"")_"be rolled back to TPB."
  1. W:+$G(UFMSESID) !!,"Transactions will be in SESSION: ",NEWUSRNM_" "_NEWSESS_" STATUS: ",$$CURSTAT^BARUFUT(NEWDUZ,NEWSESS,"E")
  1. W !,"Transactions will "_$S(BARUXMIT'=1:"*NOT* ",1:"")_"be sent to UFMS."
  1. ;end new bar*1.8*28 CR8349 IHS/SD/SDR HEAT293633
  1. W !!,"The bill number and amount written off will scroll by on the screen."
  1. W !,"If you wish to capture this information, please turn on Screen Capture.",!
  1. ;
  1. K DIR
  1. S DIR(0)="Y"
  1. S DIR("A")="Continue"
  1. S DIR("B")="No"
  1. D ^DIR
  1. K DIR
  1. S:Y=1 BARCONT=1
  1. Q