- FBHLZFE ;WCIOFO/SAB-CREATE HL7 ZFE SEGMENTS ;7/21/1998
- ;;3.5;FEE BASIS;**14,78**;JAN 30, 1995
- ;
- ; This routine generates ZFE HL7 segments that contain FEE BASIS
- ; authorization data for a veteran.
- ;
- EN(DFN,FBSTR,FBCUT) ; Returns array of ZFE segments containing FEE BASIS
- ; authorizatiion data for a veteran.
- ; Input:
- ; DFN - internal entry number of the PATIENT (#2) file and
- ; FEE BASIS PATIENT (#161) file
- ; FBSTR - (optional) comma delimited sting of requested fields
- ; DEFAULT: "1,2,3,4,5" (returns all fields)
- ; FBCUT - (optional) cutoff date (fileman format)
- ; Default: "2961001" (Oct 1, 1996)
- ; authorizations with a TO DATE prior to the cutoff will
- ; not be considered.
- ; Also needs HL7 variables defined (HLFS, HLECH and HLQ)
- ; Output:
- ; If an exception did not occur
- ; FBZFE(I) - an array of string(s) forming the ZFE segments for the
- ; patient's FEE authorizations that meet the criteria.
- ; I will be numeric values greater than 0.
- ; OR undefined if no authorizations meet criteria.
- ;
- ; Note: Only the latest authorization for each group is
- ; returned (where group is FEE PROGRAM + TREATMENT TYPE).
- ;
- ; If an exception did occur
- ; FBZFE(0) = -1 ^ exception number ^ exception text
- ;
- N FBA,FBDA1,FBGRP,FBI,FBICN,FBY0
- K FBZFE ; initialize array
- I $G(FBSTR)="" S FBSTR="1,2,3,4,5"
- S FBSTR=","_FBSTR_","
- I $G(FBCUT)="" S FBCUT=2961001
- ;
- ; check for required input
- I $G(FBZFE(0))'<0 D
- . I $G(DFN)="" S FBZFE(0)="-1^103^Patient DFN not specified." Q
- . I '$D(HLFS)!'$D(HLECH)!'$D(HLQ) S FBZFE(0)="-1^201^HL7 variables not defined." Q
- ;
- ; get patient ICN
- I $G(FBZFE(0))'<0 D
- . I $$IFLOCAL^MPIF001(DFN) S FBZFE(0)="-1^104^ICN could not be determined for the specified patient." Q ; must not be local ICN
- . S FBICN=$$GETICN^MPIF001(DFN) I FBICN<0 S FBZFE(0)="-1^104^ICN could not be determined for the specified patient." Q
- ;
- ; check if cutoff date is a valid value
- I $G(FBZFE(0))'<0 D
- . I FBCUT'?7N S FBZFE(0)="-1^101^Valid date not specified." Q
- . I $$FMTHL7^XLFDT(FBCUT)<0 S FBZFE(0)="-1^101^Valid date not specified." Q
- ;
- I $G(FBZFE(0))'<0 D
- . ; find authorizations that meet criteria (if any)
- . ; loop thru authorizations
- . S FBDA1=0 F S FBDA1=$O(^FBAAA(DFN,1,FBDA1)) Q:'FBDA1 D
- . . Q:$P($G(^FBAAA(DFN,1,FBDA1,"ADEL")),U)="Y" ; ignore Austin Deleted
- . . S FBY0=$G(^FBAAA(DFN,1,FBDA1,0))
- . . Q:$P(FBY0,U,3)="" ; FEE Program required
- . . Q:$P(FBY0,U,2)<FBCUT ; before cutoff date
- . . S FBGRP=$P(FBY0,U,3)_U_$P(FBY0,U,13) ; group (Program + Treat. Type)
- . . Q:$P(FBY0,U,2)'>$P($G(FBA(FBGRP)),U,2) ; already have later for grp
- . . ; save as latest found (so far) for a group
- . . S FBA(FBGRP)=FBDA1_U_$P(FBY0,U,2)
- . ;
- . ; build FBZFE array for selected authorizations
- . S FBI=0 ; init number of array elements
- . S FBGRP="" F S FBGRP=$O(FBA(FBGRP)) Q:FBGRP="" D
- . . S FBDA1=$P(FBA(FBGRP),U)
- . . D AUTH
- ;
- QUIT ;
- Q
- ;
- AUTH ; Add node (HL7 ZFE seg.) to FBZFE array for a specified authorization
- ; Input:
- ; DFN - veteran ien (file #2 and #161)
- ; FBDA1 - authorization ien (authorization multiple of #161)
- ; FBI - previous set ID number used for array or 0 when none
- ; FBSTR - comma delimited string of requested fields
- ; Output:
- ; FBI - set ID (modified)
- ; FBZFE(FBI) - output array element for one set ID
- ; ZFE ^ set ID ^ treat. type ^ FEE program ^ From ^ To
- ;
- N FBY0,X
- ;
- S FBY0=$G(^FBAAA(DFN,1,FBDA1,0))
- Q:FBY0="" ; nothing to process
- ;
- S FBI=FBI+1
- ;
- S FBZFE(FBI)="ZFE"
- S $P(FBZFE(FBI),HLFS,6)=""
- I FBSTR[",1," S $P(FBZFE(FBI),HLFS,2)=FBI ; sequential number
- I FBSTR[",2," S X=$$EXTERNAL^DILFD(161.01,.095,"",$P(FBY0,U,13)),$P(FBZFE(FBI),HLFS,3)=$S(X]"":X,1:HLQ)_$E(HLECH)_$E(HLECH)_"VA0033" ; Treatment Type
- I FBSTR[",3," S X=$S($P(FBY0,U,3):$P($G(^FBAA(161.8,$P(FBY0,U,3),0)),U),1:""),$P(FBZFE(FBI),HLFS,4)=$S(X]"":X,1:HLQ)_$E(HLECH)_$E(HLECH)_"VA0034" ; FEE Program
- I FBSTR[",4," S $P(FBZFE(FBI),HLFS,5)=$S($P(FBY0,U)]"":$$HLDATE^HLFNC($P(FBY0,U)),1:HLQ) ; From Date
- I FBSTR[",5," S $P(FBZFE(FBI),HLFS,6)=$S($P(FBY0,U,2)]"":$$HLDATE^HLFNC($P(FBY0,U,2)),1:HLQ) ; To Date
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HFBHLZFE 4407 printed Mar 13, 2025@21:03:26 Page 2
- FBHLZFE ;WCIOFO/SAB-CREATE HL7 ZFE SEGMENTS ;7/21/1998
- +1 ;;3.5;FEE BASIS;**14,78**;JAN 30, 1995
- +2 ;
- +3 ; This routine generates ZFE HL7 segments that contain FEE BASIS
- +4 ; authorization data for a veteran.
- +5 ;
- EN(DFN,FBSTR,FBCUT) ; Returns array of ZFE segments containing FEE BASIS
- +1 ; authorizatiion data for a veteran.
- +2 ; Input:
- +3 ; DFN - internal entry number of the PATIENT (#2) file and
- +4 ; FEE BASIS PATIENT (#161) file
- +5 ; FBSTR - (optional) comma delimited sting of requested fields
- +6 ; DEFAULT: "1,2,3,4,5" (returns all fields)
- +7 ; FBCUT - (optional) cutoff date (fileman format)
- +8 ; Default: "2961001" (Oct 1, 1996)
- +9 ; authorizations with a TO DATE prior to the cutoff will
- +10 ; not be considered.
- +11 ; Also needs HL7 variables defined (HLFS, HLECH and HLQ)
- +12 ; Output:
- +13 ; If an exception did not occur
- +14 ; FBZFE(I) - an array of string(s) forming the ZFE segments for the
- +15 ; patient's FEE authorizations that meet the criteria.
- +16 ; I will be numeric values greater than 0.
- +17 ; OR undefined if no authorizations meet criteria.
- +18 ;
- +19 ; Note: Only the latest authorization for each group is
- +20 ; returned (where group is FEE PROGRAM + TREATMENT TYPE).
- +21 ;
- +22 ; If an exception did occur
- +23 ; FBZFE(0) = -1 ^ exception number ^ exception text
- +24 ;
- +25 NEW FBA,FBDA1,FBGRP,FBI,FBICN,FBY0
- +26 ; initialize array
- KILL FBZFE
- +27 IF $GET(FBSTR)=""
- SET FBSTR="1,2,3,4,5"
- +28 SET FBSTR=","_FBSTR_","
- +29 IF $GET(FBCUT)=""
- SET FBCUT=2961001
- +30 ;
- +31 ; check for required input
- +32 IF $GET(FBZFE(0))'<0
- Begin DoDot:1
- +33 IF $GET(DFN)=""
- SET FBZFE(0)="-1^103^Patient DFN not specified."
- QUIT
- +34 IF '$DATA(HLFS)!'$DATA(HLECH)!'$DATA(HLQ)
- SET FBZFE(0)="-1^201^HL7 variables not defined."
- QUIT
- End DoDot:1
- +35 ;
- +36 ; get patient ICN
- +37 IF $GET(FBZFE(0))'<0
- Begin DoDot:1
- +38 ; must not be local ICN
- IF $$IFLOCAL^MPIF001(DFN)
- SET FBZFE(0)="-1^104^ICN could not be determined for the specified patient."
- QUIT
- +39 SET FBICN=$$GETICN^MPIF001(DFN)
- IF FBICN<0
- SET FBZFE(0)="-1^104^ICN could not be determined for the specified patient."
- QUIT
- End DoDot:1
- +40 ;
- +41 ; check if cutoff date is a valid value
- +42 IF $GET(FBZFE(0))'<0
- Begin DoDot:1
- +43 IF FBCUT'?7N
- SET FBZFE(0)="-1^101^Valid date not specified."
- QUIT
- +44 IF $$FMTHL7^XLFDT(FBCUT)<0
- SET FBZFE(0)="-1^101^Valid date not specified."
- QUIT
- End DoDot:1
- +45 ;
- +46 IF $GET(FBZFE(0))'<0
- Begin DoDot:1
- +47 ; find authorizations that meet criteria (if any)
- +48 ; loop thru authorizations
- +49 SET FBDA1=0
- FOR
- SET FBDA1=$ORDER(^FBAAA(DFN,1,FBDA1))
- if 'FBDA1
- QUIT
- Begin DoDot:2
- +50 ; ignore Austin Deleted
- if $PIECE($GET(^FBAAA(DFN,1,FBDA1,"ADEL")),U)="Y"
- QUIT
- +51 SET FBY0=$GET(^FBAAA(DFN,1,FBDA1,0))
- +52 ; FEE Program required
- if $PIECE(FBY0,U,3)=""
- QUIT
- +53 ; before cutoff date
- if $PIECE(FBY0,U,2)<FBCUT
- QUIT
- +54 ; group (Program + Treat. Type)
- SET FBGRP=$PIECE(FBY0,U,3)_U_$PIECE(FBY0,U,13)
- +55 ; already have later for grp
- if $PIECE(FBY0,U,2)'>$PIECE($GET(FBA(FBGRP)),U,2)
- QUIT
- +56 ; save as latest found (so far) for a group
- +57 SET FBA(FBGRP)=FBDA1_U_$PIECE(FBY0,U,2)
- End DoDot:2
- +58 ;
- +59 ; build FBZFE array for selected authorizations
- +60 ; init number of array elements
- SET FBI=0
- +61 SET FBGRP=""
- FOR
- SET FBGRP=$ORDER(FBA(FBGRP))
- if FBGRP=""
- QUIT
- Begin DoDot:2
- +62 SET FBDA1=$PIECE(FBA(FBGRP),U)
- +63 DO AUTH
- End DoDot:2
- End DoDot:1
- +64 ;
- QUIT ;
- +1 QUIT
- +2 ;
- AUTH ; Add node (HL7 ZFE seg.) to FBZFE array for a specified authorization
- +1 ; Input:
- +2 ; DFN - veteran ien (file #2 and #161)
- +3 ; FBDA1 - authorization ien (authorization multiple of #161)
- +4 ; FBI - previous set ID number used for array or 0 when none
- +5 ; FBSTR - comma delimited string of requested fields
- +6 ; Output:
- +7 ; FBI - set ID (modified)
- +8 ; FBZFE(FBI) - output array element for one set ID
- +9 ; ZFE ^ set ID ^ treat. type ^ FEE program ^ From ^ To
- +10 ;
- +11 NEW FBY0,X
- +12 ;
- +13 SET FBY0=$GET(^FBAAA(DFN,1,FBDA1,0))
- +14 ; nothing to process
- if FBY0=""
- QUIT
- +15 ;
- +16 SET FBI=FBI+1
- +17 ;
- +18 SET FBZFE(FBI)="ZFE"
- +19 SET $PIECE(FBZFE(FBI),HLFS,6)=""
- +20 ; sequential number
- IF FBSTR[",1,"
- SET $PIECE(FBZFE(FBI),HLFS,2)=FBI
- +21 ; Treatment Type
- IF FBSTR[",2,"
- SET X=$$EXTERNAL^DILFD(161.01,.095,"",$PIECE(FBY0,U,13))
- SET $PIECE(FBZFE(FBI),HLFS,3)=$SELECT(X]"":X,1:HLQ)_$EXTRACT(HLECH)_$EXTRACT(HLECH)_"VA0033"
- +22 ; FEE Program
- IF FBSTR[",3,"
- SET X=$SELECT($PIECE(FBY0,U,3):$PIECE($GET(^FBAA(161.8,$PIECE(FBY0,U,3),0)),U),1:"")
- SET $PIECE(FBZFE(FBI),HLFS,4)=$SELECT(X]"":X,1:HLQ)_$EXTRACT(HLECH)_$EXTRACT(HLECH)_"VA0034"
- +23 ; From Date
- IF FBSTR[",4,"
- SET $PIECE(FBZFE(FBI),HLFS,5)=$SELECT($PIECE(FBY0,U)]"":$$HLDATE^HLFNC($PIECE(FBY0,U)),1:HLQ)
- +24 ; To Date
- IF FBSTR[",5,"
- SET $PIECE(FBZFE(FBI),HLFS,6)=$SELECT($PIECE(FBY0,U,2)]"":$$HLDATE^HLFNC($PIECE(FBY0,U,2)),1:HLQ)
- +25 QUIT