source: WorldVistAEHR/trunk/r/FEE_BASIS-FB/FBAARR.m@ 1657

Last change on this file since 1657 was 613, checked in by George Lilly, 16 years ago

initial load of WorldVistAEHR

File size: 5.8 KB
Line 
1FBAARR ;AISC/GRR-RE-INITIATE REJECTED LINE ITEMS ;9/9/2003
2 ;;3.5;FEE BASIS;**61**;JAN 30, 1995
3 ;;Per VHA Directive 10-93-142, this routine should not be modified.
4 N FBILM
5 S IOP=$S($D(ION):ION,1:"HOME") D ^%ZIS K IOP
6 S Q="",$P(Q,"=",80)="=",UL="",$P(UL,"-",80)="-",(FBAAOUT,CNT,FBINTOT)=0
7 D DT^DICRW
8BT K QQ W !!
9 S DIC="^FBAA(161.7,",DIC(0)="AEQMN",DIC("A")="Select Batch with Rejects: ",DIC("S")="I $G(^(""ST""))=""V""&($P(^(0),U,17)]"""")" D ^DIC K DIC("S"),DIC("A") G Q:X="^"!(X=""),BT:Y<0 S FBN=+Y,B=FBN,FZ=^FBAA(161.7,FBN,0),FBTYPE=$P(FZ,"^",3)
10 S FBOB=$P(FZ,"^",2),FBEXMPT=$S($P(FZ,"^",18)]"":$P(FZ,"^",18),1:"N")
11 I '$S(FBTYPE="B3":$D(^FBAAC("AH",B)),FBTYPE="B2":$D(^FBAAC("AG",B)),FBTYPE="B5":$D(^FBAA(162.1,"AF",B)),FBTYPE="B9":$D(^FBAAI("AH",B)),1:0) W !!,*7,"No items rejected in this batch!" D G BT
12 .S $P(^FBAA(161.7,B,0),U,17)=""
13 I FBTYPE="B9",$P(FZ,"^",15)="Y" D NEWBT^FBAARR0 G ASKLL
14BTN W !! S DIC("A")="Select New Batch number: ",DIC("S")="I $P(^(0),U,3)=FBTYPE&($P(^(0),U,5)=DUZ)&($G(^(""ST""))=""O"")" D ^DIC K DIC("A"),DIC("S") G BT:X=""!(X="^"),HELP^FBAARR0:X["?",BTN:Y<0 S FBNB=+Y
15 D BATCNT^FBAARR1 I '$D(FBNB) D KILL^FBAARR1 G BT
16 S FBNUM=$P(^FBAA(161.7,B,0),"^",1),FBVD=$P(^(0),"^",12),FBVDUZ=$P(^(0),"^",16),FBNOB=$P(^FBAA(161.7,FBNB,0),"^",2) G:FBNOB'=FBOB CHKOB^FBAARR0
17ASKLL S B=FBN,FBNNP=1 S DIR(0)="Y",DIR("A")="Want line items listed",DIR("B")="NO" D ^DIR K DIR W:Y @IOF D:Y MORE^FBAARJP:FBTYPE="B3",PMORE^FBAARJP:FBTYPE="B5",TMORE^FBAARJP:FBTYPE="B2",CMORE^FBAARJP:FBTYPE="B9" K FBNNP
18RD0 S DIR(0)="Y",DIR("A")="Want to re-initiate all rejected items in the Batch",DIR("B")="NO",DIR("?")="'Yes' will re-initiate all rejected payment items for this batch, 'No' will prompt for re-initiation of specific line items"
19 D ^DIR K DIR G:Y ^FBAARR1
20RD1 S DIR(0)="Y",DIR("A")="Want to re-initiate any line items",DIR("B")="NO" D ^DIR K DIR Q:$D(DIRUT)!'Y D DELT^FBAARR2:FBTYPE="B2",DELM:FBTYPE="B3",DELP^FBAARR2:FBTYPE="B5",DELC^FBAARR0:FBTYPE="B9"
21RDD ;
22FIN S $P(FZ,"^",12)=DT,$P(FZ,"^",16)=DUZ,^FBAA(161.7,FBN,0)=FZ,^FBAA(161.7,FBN,"ST")="V",^FBAA(161.7,"AC","V",FBN)="",^FBAA(161.7,"AF",DT,FBN)="" K ^FBAA(161.7,"AC","T",FBN)
23 S DIC="^FBAA(161.7,",DA=FBN,DR="0;ST" W !! D EN^DIQ G BT
24Q D KILL^FBAARR1
25 Q
26GET W !! S DIC="^FBAAA(",DIC(0)="AEQ" D ^DIC G RDD:X="^"!(X=""),GET:Y<0 S DA=+Y,J=DA Q
27DELM K QQ W !! S DIC="^FBAAA(",DIC(0)="AEQM" D ^DIC G END:X="^"!(X=""),DELM:Y<0 S DA=+Y,J=DA I '$D(^FBAAC("AH",B,J)) W !!,*7,"No payments in this batch for that patient!" G DELM
28 S QQ=0 W @IOF D HED^FBAACCB
29 F K=0:0 S K=$O(^FBAAC("AH",B,J,K)) Q:K'>0 F L=0:0 S L=$O(^FBAAC("AH",B,J,K,L)) Q:L'>0 F M=0:0 S M=$O(^FBAAC("AH",B,J,K,L,M)) Q:M'>0 D WRITM
30RL S ERR=0 S DIR(0)="N^1:"_QQ,DIR("A")="Re-initiate which line item" D ^DIR K DIR G:$D(DIRUT) END S HX=X
31 I '$D(QQ(HX)) W !,*7,"You already did that one!!" G RL
32ASKSU S DIR(0)="Y",DIR("A")="Are you sure you want to re-initiate line item number "_HX,DIR("B")="NO" D ^DIR K DIR G:$D(DIRUT)!'Y RL
33 S J=$P(QQ(HX),"^",1),K=$P(QQ(HX),"^",2),L=$P(QQ(HX),"^",3),M=$P(QQ(HX),"^",4)
34STUFF I $P(^FBAAC(J,1,K,1,L,1,M,0),"^",21)="VP" S FBIN=+$P(^(0),"^",16) D VOID^FBAARR1 G END
35 S $P(^FBAAC(J,1,K,1,L,1,M,0),"^",8)=FBNB,FBAAAP=+$P(^(0),"^",3),FBIN=+$P(^(0),"^",16)
36 S ^FBAAC("AC",FBNB,J,K,L,M)="",^FBAAC("AJ",FBNB,FBIN,J,K,L,M)="" K ^FBAAC("AH",B,J,K,L,M)
37 S $P(^FBAA(161.7,FBNB,0),"^",9)=($P(^FBAA(161.7,FBNB,0),"^",9)+FBAAAP),$P(^(0),"^",11)=($P(^(0),"^",11)+1) K ^FBAAC(J,1,K,1,L,1,M,"FBREJ")
38 ; update list of invoice lines that were moved to the new batch
39 S FBILM(FBIN,M_","_L_","_K_","_J_",")=""
40ASKRI S DIR(0)="Y",DIR("A")=$S($G(FBERR):"",1:"Item Re-initiated. ")_"Want to re-initiate another",DIR("B")="YES" D ^DIR K DIR G ASKRI:$D(DIRUT),DELM:Y,END
41WRITM S QQ=QQ+1,QQ(QQ)=J_"^"_K_"^"_L_"^"_M D SET^FBAACCB Q
42END I '$D(^FBAAC("AH",B)) S $P(^FBAA(161.7,B,0),"^",17)=""
43 ; Assign new invoice number to moved lines if invoice was split
44 I $$CKSPLIT(B,.FBILM) S DIR(0)="E" D ^DIR K DIR
45 Q
46CKSPLIT(B,FBILM) ; Check for/Update split invoice
47 ; Input
48 ; B - ien of original batch before item moved
49 ; FBILM( - array of invoice lines that were moved to a new batch
50 ; passed by reference
51 ; format FBILM(invoice number,iens)=""
52 ; where
53 ; invoice number = invoice number
54 ; iens = iens of subfile 162.03 (a line item)
55 ; Result (0 or 1)
56 ; =0 if no lines were assigned a new invoice number
57 ; =1 if some lines assigned a new invoice number
58 ; May change invoice number of line items in subfile 162.03
59 ; and inform user
60 N FBAAIN,FBFDA,FBIENS,FBIN,FBINL,FBJ,FBK,FBL,FBM,FBRET,FBSPLT
61 S FBRET=0
62 ; loop thru invoice numbers in input array
63 S FBIN="" F S FBIN=$O(FBILM(FBIN)) Q:FBIN="" D
64 . S FBSPLT=0 ; initialize split flag to false
65 . ; check if any unrejected invoice lines still in original batch
66 . I $D(^FBAAC("AJ",B,FBIN)) S FBSPLT=1
67 . ; check if any rejected invoice lines still in original batch
68 . I 'FBSPLT S FBJ=0 F S FBJ=$O(^FBAAC("AH",B,FBJ)) Q:'FBJ D Q:FBSPLT
69 . . S FBK=0
70 . . F S FBK=$O(^FBAAC("AH",B,FBJ,FBK)) Q:'FBK D Q:FBSPLT
71 . . . S FBL=0
72 . . . F S FBL=$O(^FBAAC("AH",B,FBJ,FBK,FBL)) Q:'FBL D Q:FBSPLT
73 . . . . S FBM=0
74 . . . . F S FBM=$O(^FBAAC("AH",B,FBJ,FBK,FBL,FBM)) Q:'FBM D Q:FBSPLT
75 . . . . . S FBINL=$P($G(^FBAAC(FBJ,1,FBK,1,FBL,1,FBM,0)),U,16)
76 . . . . . I FBINL=FBIN S FBSPLT=1
77 . Q:FBSPLT=0 ; invoice was not split
78 . S FBRET=1
79 . ; assign new invoice number to lines moved to the new batch
80 . ; get a new invoice number (FBAAIN)
81 . D GETNXI^FBAAUTL
82 . ; loop thru the moved line items and assign the new invoice number
83 . K FBFDA
84 . S FBIENS="" F S FBIENS=$O(FBILM(FBIN,FBIENS)) Q:FBIENS="" D
85 . . S FBFDA(162.03,FBIENS,14)=FBAAIN
86 . W !!,"FYI: Invoice ",FBIN," was split since entire invoice did not move to the new batch."
87 . W !,"Re-initiated lines are being assigned a new invoice number of ",FBAAIN,"."
88 . ; update the file
89 . I $D(FBFDA) D FILE^DIE("","FBFDA"),MSG^DIALOG()
90 Q FBRET
91 ;
92 ;FBAARR
Note: See TracBrowser for help on using the repository browser.