source: WorldVistAEHR/trunk/r/FEE_BASIS-FB/FBUCUPD1.m@ 632

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

initial load of WorldVistAEHR

File size: 3.1 KB
Line 
1FBUCUPD1 ;ALBISC/TET - UPDATE AFTER EVENT (CONTINUED) ;4/21/93 20:41
2 ;;3.5;FEE BASIS;;JAN 30, 1995
3 ;;Per VHA Directive 10-93-142, this routine should not be modified.
4 ;called from fbucupd
5AUTH(FBUCP,FBUCA,FBDA,FBACT) ;update authorization in authorization file
6 ;INPUT: ;function call to determine action,
7 ; 0 to kill/1 to set/2 to change/null for no change
8 ; FBUCP - data prior to edit
9 ; FBUCA - data after edit
10 ; FBDA - ien of unauthorized claim, file 162.7
11 ; FBACT - action type
12 ;OUTPUT: -- update patient's authorization
13 ; will add if entry not already there,
14 ; delete or change if entry already there,
15 ; otherwise will quit (based on variables FBAUTH and FBIEN)
16 ; FBOUT = 1 if timed out, otherwise 0
17 N FBAUTH S FBAUTH=$$AUTH^FBUCUTL6(FBUCP,FBUCA) G:FBAUTH']"" AUTHQ
18 N FBAUTHF,FBDCHG,FBIEN,FBLOCK,FBV,FBVET,FBY,DA,DIC,DIE,DIK,DIR,DR,DTOUT,DUOUT,X,Y S FBDCHG=0 S:'$D(FBOUT) FBOUT=0
19 S FBV=FBDA_";FB583(" S:'$D(FBVET) FBVET=+$P(FBUCA,U,4),FBIEN=+$O(^FBAAA("AG",FBV,FBVET,0))
20 I FBAUTH'=1,FBIEN D ;delete or edit & entry exists
21 .I FBAUTH=0,'$$PAY^FBUCUTL(FBDA,"^FB583(") D
22 ..N FBAIEN W !,"Deleting authorization...",!
23 ..S DA(1)=FBVET,DA=FBIEN,DIK="^FBAAA("_DA(1)_",1," D ^DIK K DIK
24 ..S FBAIEN=+$P(FBUCA,U,27) I FBAIEN D UPDATE1("@",FBDA)
25 .I FBAUTH=2 D UPDATE
26 I FBAUTH=1,FBIEN,FBACT="REO" D UPDATE
27 I FBAUTH=1,'FBIEN D ;add & entry not already in file
28 .;check if vet in file, if not add
29 .S Y=0 N FBAIEN,FBVAR I '$D(^FBAAA(FBVET,0)) S Y=$$FILE^FBUCUTL("^FBAAA(",FBVET,1) Q:+Y'>0 S FBVET=+Y,^FBAAA(FBVET,1,0)="^161.01D^^"
30 .I +Y'>0 S:'$D(^FBAAA(FBVET,1,0)) ^FBAAA(FBVET,1,0)="^161.01D^^"
31 .I "^6^7^"[$P(FBUCA,U,2) D
32 ..S DIR(0)="161.01,.06",DIR("B")="DISCHARGE" D ^DIR K DIR S:$D(DUOUT)!($D(DTOUT)) FBOUT=1
33 ..I FBOUT&($P(FBUCA,U,2)=6) W !,*7,"Discharge type is missing! Enter using the Re-open Unauthorized Claim option.",! H 3
34 ..S:'FBOUT FBDCHG=Y
35 .S DIE="^FBAAA("_FBVET_",1,",FBAUTHF=+$P(FBUCA,U,13) I FBAUTHF S Y=$$FILE^FBUCUTL(DIE,FBAUTHF,0,FBVET) Q:+Y'>0 S (FBAIEN,FBIEN)=+Y,DA=FBVET,DR="[FB UNAUTHORIZED UPDATE]",DIE="^FBAAA("
36 .I FBAUTHF D LOCK^FBUCUTL(DIE,FBVET,1) I FBLOCK D ^DIE L -^FBAAA(FBVET) K DA,DIE,DQ,DR,FBLOCK D UPDATE1(FBAIEN,FBDA) ;S:$D(DTOUT) FBOUT=1 I 'FBOUT D UPDATE1(FBAIEN,FBDA)
37AUTHQ K DA,DIC,DIE,DQ,DR,DTOUT,DUOUT,FBDCHG,X,Y Q
38UPDATE ;update if there is a change - keeps 583 and authorization in sync
39 N DA,DIE,DR,FBLOCK
40 S DA=FBVET,DR="[FB UNAUTHORIZED UPDATE1]",DIE="^FBAAA("
41 D LOCK^FBUCUTL(DIE,FBVET,1) I FBLOCK D ^DIE L -^FBAAA(FBVET)
42 Q
43UPDATE1(FBAIEN,FBIEN) ;update authorization field (# 30) for unauthorized claim
44 ;INPUT: FBAIEN = internal entry number of authorization (could be '@' for deletion
45 ; FBIEN = internal entry number of u/c (may be fbda)
46 ; FBALL = flag to update all other claims (1=update all)
47 ;OUTPUT: update field 30 (AUTHORIZAITION) to value of fbaien
48 N DA,DIE,DR,FBLOCK I $S(+$G(FBAIEN)'>0&(FBAIEN'="@"):1,'+$G(FBIEN):1,FBAIEN'?1N.N&(FBAIEN'="@"):1,1:0) Q
49 S DA=FBIEN,DIE="^FB583(",DR="S:FBAIEN=""@"" Y=""@1"";30////^S X=FBAIEN;S Y=""@99"";@1;30///@;@99" D LOCK^FBUCUTL(DIE,DA,1) I FBLOCK D ^DIE L -^FB583(FBIEN)
50 Q
Note: See TracBrowser for help on using the repository browser.