FBXIP45 ;WOIFO/MJE-PATCH INSTALL ROUTINE ;6/7/02
;;3.5;FEE BASIS;**45**;JAN 30, 1995
;Per VHA Directive 10-93-142, this routine should not be modified.
Q
;
PS ; post-install entry point
; create KIDS checkpoints with call backs
N FBX,Y
F FBX="UPDPOV" D
. S Y=$$NEWCP^XPDUTL(FBX,FBX_"^FBXIP45")
. I 'Y D BMES^XPDUTL("ERROR Creating "_FBX_" Checkpoint.")
Q
;
UPDPOV ; Update Selected Purpose of Visits (POV)
N FBCODE,FBDA,FBFDA,FBI,FBNAME,FBPROG,FBX,X,Y
D BMES^XPDUTL(" Updating selected POVs in the FEE BASIS PURPOSE OF VISIT (161.82) file...")
;
; verify IEN of OUTPATIENT program in FEE BASIS PROGRAM file
I $P($G(^FBAA(161.8,2,0)),U)'="OUTPATIENT" D Q
. D MES^XPDUTL(" ERROR: Fee Program with IEN 2 is not OUTPATIENT.")
. D MES^XPDUTL(" Purpose of Visits could not be updated.")
;
; verify IEN of CONTRACT NURSING HOME in FEE BASIS PROGRAM file
I $P($G(^FBAA(161.8,7,0)),U)'="CONTRACT NURSING HOME" D Q
. D MES^XPDUTL(" ERROR: Fee Program with IEN 7 is not CONTRACT NURSING HOME.")
. D MES^XPDUTL(" Purpose of Visits could not be updated.")
;
; update POVs
K FBFDA
; loop thru POVs
F FBI=1:1 S FBX=$P($T(POV+FBI),";;",2) Q:FBX="END" D
. S FBCODE=$P(FBX,U)
. S FBNAME=$P(FBX,U,2)
. S FBPROG=$P(FBX,U,3)
. ;
. ; locate POV in file
. S FBDA=$$FIND1^DIC(161.82,"","X",FBCODE,"AC")
. ;
. ; if POV found then check and if necessary add to update array
. I FBDA D
. . I $$GET1^DIQ(161.82,FBDA_",",.01)'=FBNAME S FBFDA(161.82,FBDA_",",.01)=FBNAME
. . I $$GET1^DIQ(161.82,FBDA_",",2,"I")'=FBPROG S FBFDA(161.82,FBDA_",",2)=FBPROG
. ;
. ; if POV not found then add it
. I 'FBDA D
. . N DA,DD,DIC,DINUM,DLAYGO,DO,X
. . S DIC="^FBAA(161.82,",DIC(0)="L",DLAYGO=161.82
. . S X=FBNAME Q:X=""
. . S DIC("DR")="2////^S X=FBPROG;3////^S X=FBCODE"
. . I +FBCODE,'$D(^FBAA(161.82,+FBCODE,0)) S DINUM=+FBCODE
. . D FILE^DICN
. . I Y<0 D MES^XPDUTL("ERROR ADDING POV WITH CODE "_FBCODE)
;
; actually update the found POVs
I $D(FBFDA) D FILE^DIE("","FBFDA")
;
D MES^XPDUTL(" Done.")
Q
;
POV ;austin code^name^fee program for Purpose of Visit (POV) code(s)
;;43^CNH HOSPICE^7
;;END
;
;FBXIP45
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HFBXIP45 2214 printed Dec 13, 2024@02:01:51 Page 2
FBXIP45 ;WOIFO/MJE-PATCH INSTALL ROUTINE ;6/7/02
+1 ;;3.5;FEE BASIS;**45**;JAN 30, 1995
+2 ;Per VHA Directive 10-93-142, this routine should not be modified.
+3 QUIT
+4 ;
PS ; post-install entry point
+1 ; create KIDS checkpoints with call backs
+2 NEW FBX,Y
+3 FOR FBX="UPDPOV"
Begin DoDot:1
+4 SET Y=$$NEWCP^XPDUTL(FBX,FBX_"^FBXIP45")
+5 IF 'Y
DO BMES^XPDUTL("ERROR Creating "_FBX_" Checkpoint.")
End DoDot:1
+6 QUIT
+7 ;
UPDPOV ; Update Selected Purpose of Visits (POV)
+1 NEW FBCODE,FBDA,FBFDA,FBI,FBNAME,FBPROG,FBX,X,Y
+2 DO BMES^XPDUTL(" Updating selected POVs in the FEE BASIS PURPOSE OF VISIT (161.82) file...")
+3 ;
+4 ; verify IEN of OUTPATIENT program in FEE BASIS PROGRAM file
+5 IF $PIECE($GET(^FBAA(161.8,2,0)),U)'="OUTPATIENT"
Begin DoDot:1
+6 DO MES^XPDUTL(" ERROR: Fee Program with IEN 2 is not OUTPATIENT.")
+7 DO MES^XPDUTL(" Purpose of Visits could not be updated.")
End DoDot:1
QUIT
+8 ;
+9 ; verify IEN of CONTRACT NURSING HOME in FEE BASIS PROGRAM file
+10 IF $PIECE($GET(^FBAA(161.8,7,0)),U)'="CONTRACT NURSING HOME"
Begin DoDot:1
+11 DO MES^XPDUTL(" ERROR: Fee Program with IEN 7 is not CONTRACT NURSING HOME.")
+12 DO MES^XPDUTL(" Purpose of Visits could not be updated.")
End DoDot:1
QUIT
+13 ;
+14 ; update POVs
+15 KILL FBFDA
+16 ; loop thru POVs
+17 FOR FBI=1:1
SET FBX=$PIECE($TEXT(POV+FBI),";;",2)
if FBX="END"
QUIT
Begin DoDot:1
+18 SET FBCODE=$PIECE(FBX,U)
+19 SET FBNAME=$PIECE(FBX,U,2)
+20 SET FBPROG=$PIECE(FBX,U,3)
+21 ;
+22 ; locate POV in file
+23 SET FBDA=$$FIND1^DIC(161.82,"","X",FBCODE,"AC")
+24 ;
+25 ; if POV found then check and if necessary add to update array
+26 IF FBDA
Begin DoDot:2
+27 IF $$GET1^DIQ(161.82,FBDA_",",.01)'=FBNAME
SET FBFDA(161.82,FBDA_",",.01)=FBNAME
+28 IF $$GET1^DIQ(161.82,FBDA_",",2,"I")'=FBPROG
SET FBFDA(161.82,FBDA_",",2)=FBPROG
End DoDot:2
+29 ;
+30 ; if POV not found then add it
+31 IF 'FBDA
Begin DoDot:2
+32 NEW DA,DD,DIC,DINUM,DLAYGO,DO,X
+33 SET DIC="^FBAA(161.82,"
SET DIC(0)="L"
SET DLAYGO=161.82
+34 SET X=FBNAME
if X=""
QUIT
+35 SET DIC("DR")="2////^S X=FBPROG;3////^S X=FBCODE"
+36 IF +FBCODE
IF '$DATA(^FBAA(161.82,+FBCODE,0))
SET DINUM=+FBCODE
+37 DO FILE^DICN
+38 IF Y<0
DO MES^XPDUTL("ERROR ADDING POV WITH CODE "_FBCODE)
End DoDot:2
End DoDot:1
+39 ;
+40 ; actually update the found POVs
+41 IF $DATA(FBFDA)
DO FILE^DIE("","FBFDA")
+42 ;
+43 DO MES^XPDUTL(" Done.")
+44 QUIT
+45 ;
POV ;austin code^name^fee program for Purpose of Visit (POV) code(s)
+1 ;;43^CNH HOSPICE^7
+2 ;;END
+3 ;
+4 ;FBXIP45