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

IB20P785.m

Go to the documentation of this file.
  1. IB20P785 ;MNTVBB/DMR - IB MID YEAR 2024 STOP CODES UPDATE ; January 29, 2024 @13:20
  1. ;;2.0;INTEGRATED BILLING;**785**;21-MAR-94;Build 6
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. ; This routine is used as a post-init in a KIDS build to
  1. ; update the IB Stop Code Billable Types file (#352.5).
  1. ;
  1. Q
  1. EN ; Update IB Stop Code Billable Types for Mid Year 2024 in #352.5
  1. ; Call the Global Backup Tag (Backs up entire file to XTMP and sets the GLBRSTR node
  1. ; used to prevent a rerun of the backup and update, that would result in
  1. ; overwriting the backup file unintentionally)
  1. N GLBKUP
  1. D GLBBKUP
  1. I $D(GLBKUP) Q
  1. ; Initiate Update
  1. N IBEFFDT
  1. D START,ADD,UPDATE,FINISH
  1. Q
  1. ;
  1. START D BMES^XPDUTL("DSS Clinic Stop Codes for Mid Year 2024, Post-Install Starting")
  1. Q
  1. ;
  1. FINISH D BMES^XPDUTL("DSS Clinic Stop Codes for Mid Year 2024, Post-Install Complete")
  1. Q
  1. ;
  1. ;
  1. ADD ;add a new code
  1. N Y,IBC,IBT,IBX,IBY,IBCODE,IBTYPE,IBDES,IBOVER
  1. D BMES^XPDUTL(" Adding new codes to file 352.5")
  1. S IBC=0
  1. F IBX=1:1 S IBT=$P($T(NCODE+IBX),";",3) Q:'$L(IBT) D
  1. . S IBCODE=+$P(IBT,U)
  1. . S IBTYPE=$P(IBT,U,2)
  1. . S IBDES=$E($P(IBT,U,3),1,30)
  1. . S IBOVER=$P(IBT,U,4)
  1. . S IBY=$P(IBT,U,5)
  1. . I $D(^IBE(352.5,"AEFFDT",IBCODE,-IBY)) D Q
  1. . . D BMES^XPDUTL(" Duplication of stop code "_IBCODE)
  1. . S Y=+$$ADD3525(IBCODE,IBY,IBTYPE,IBDES,IBOVER) S:Y>0 IBC=IBC+1
  1. D BMES^XPDUTL(" "_IBC_$S(IBC<2:" entry",1:" entries")_" added to 352.5")
  1. Q
  1. ;
  1. UPDATE ;update an old code
  1. N Y,IB1,IBC,IBT,IBX,IBCODE,IBMSG,IBTYPE,IBDES,IBOVER,IBLSTDT
  1. S (IBC,IBMSG(1),IBMSG(2),IBMSG(3))=0
  1. D BMES^XPDUTL(" Updating Stop Code entries in file 352.5")
  1. F IBX=1:1 S IBT=$P($T(OCODE+IBX),";",3) Q:'$L(IBT) D
  1. . S IBCODE=+$P(IBT,U)
  1. . S IBY=$P(IBT,U,5)
  1. . I $D(^IBE(352.5,"AEFFDT",IBCODE,-IBY)) D Q
  1. . . D BMES^XPDUTL(" Duplication of stop code "_IBCODE)
  1. . S IBLSTDT=$O(^IBE(352.5,"AEFFDT",IBCODE,-9999999))
  1. . I +IBLSTDT=0 D Q
  1. . . D BMES^XPDUTL(" Code "_IBCODE_" not found in file 352.5")
  1. . S IB1=$O(^IBE(352.5,"AEFFDT",IBCODE,IBLSTDT,0))
  1. . S IB1=$G(^IBE(352.5,IB1,0))
  1. . S IBTYPE=$S($P(IBT,U,2)'="":$P(IBT,U,2),1:$P(IB1,U,3))
  1. . S IBDES=$S($P(IBT,U,3)'="":$E($P(IBT,U,3),1,30),1:$P(IB1,U,4))
  1. . S IBOVER=$P(IBT,U,4)
  1. . S Y=+$$ADD3525(IBCODE,IBY,IBTYPE,IBDES,IBOVER) S:Y>0 IBC=IBC+1
  1. D BMES^XPDUTL(" "_IBC_$S(IBC<2:" update",1:" updates")_" added to file 352.5")
  1. Q
  1. ;
  1. ADD3525(IBCODE,IBEFFDT,IBTYPE,IBDES,IBOVER) ;
  1. ;add a new entry
  1. D BMES^XPDUTL(" "_IBCODE_" "_IBDES)
  1. N IBIENS,IBFDA,IBER,IBRET
  1. S IBRET=""
  1. S IBIENS="+1,"
  1. S IBFDA(352.5,IBIENS,.01)=IBCODE
  1. S IBFDA(352.5,IBIENS,.02)=IBEFFDT
  1. S IBFDA(352.5,IBIENS,.03)=IBTYPE
  1. S IBFDA(352.5,IBIENS,.04)=IBDES
  1. S:IBOVER IBFDA(352.5,IBIENS,.05)=1
  1. D UPDATE^DIE("","IBFDA","IBRET","IBER")
  1. I $D(IBER) D BMES^XPDUTL(IBER("DIERR",1,"TEXT",1))
  1. Q $G(IBRET(1))
  1. ;
  1. GLBBKUP ; XTMP Backup of file(s)
  1. I $D(^XTMP("IB20P785","GLBRSTR")) W !!,"CANNOT RERUN WITHOUT A RESTORE" S GLBKUP=1 Q
  1. K ^XTMP("IB20P785")
  1. S ^XTMP("IB20P785")=$$FMADD^XLFDT(DT,120)_"^"_DT
  1. M ^XTMP("IB20P785")=^IBE(352.5)
  1. S ^XTMP("IB20P785","GLBRSTR")=1
  1. Q
  1. ;
  1. GLBRSTR ; Restore of Prior version of file using XTMP
  1. K ^XTMP("IB20P785","GLBRSTR")
  1. K ^IBE(352.5)
  1. M ^IBE(352.5)=^XTMP("IB20P785")
  1. Q
  1. ;new stop codes - ADD
  1. NCODE ;;code^billable type^description^override flag^effective date
  1. ;;355^2^HEADACHE CENTER OF EXCELLENCE^^3240401
  1. ;
  1. ;codes updated
  1. OCODE ;;code^billable type^description^override flag
  1. ;;534^1^PCMHI INDIV^^3240401
  1. ;;539^1^PCMHI GROUP^^3240401
  1. ;