| [613] | 1 | FBUCUTL2 ;ALBISC/TET - UTILITY (CONTINUED) ;2/12/2003 | 
|---|
|  | 2 | ;;3.5;FEE BASIS;**23,32,38,52**;JAN 30, 1995 | 
|---|
|  | 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
|  | 4 | ; | 
|---|
|  | 5 | ADDRESS(FBUCA) ;set up address (FBADD) and carbon copy address (FBADDCC) | 
|---|
|  | 6 | ;INPUT:  FBUCA = current (or after) zero node for UC (file #162.7) | 
|---|
|  | 7 | ;OUTPUT: FBADD( array, subscripted by sequential number; FBADD = count | 
|---|
|  | 8 | ;        FBADDCC( array, subscripted by sequential number; FBADDCC=count | 
|---|
|  | 9 | N FBDA,FBGL,FBSUB | 
|---|
|  | 10 | K FBADD,FBADDCC | 
|---|
|  | 11 | S FBSUB=$P(FBUCA,U,23) | 
|---|
|  | 12 | S:FBSUB']"" FBSUB=$P(FBUCA,U,4)_";DPT(" | 
|---|
|  | 13 | S FBDA=+$P(FBSUB,";") | 
|---|
|  | 14 | I FBSUB["FBAAV" D VENADD(FBDA,.FBADD) D VETADD($P(FBUCA,U,4),.FBADDCC) | 
|---|
|  | 15 | I FBSUB["DPT" D VETADD(FBDA,.FBADD) D VENADD($P(FBUCA,U,3),.FBADDCC) | 
|---|
|  | 16 | I FBSUB["VA(200" D OTHADD(FBDA,.FBADD) D VETADD($P(FBUCA,U,4),.FBADDCC) | 
|---|
|  | 17 | Q | 
|---|
|  | 18 | VETADD(DFN,FBARR) ;set up veteran address | 
|---|
|  | 19 | ;INPUT:  DFN = veteran ien | 
|---|
|  | 20 | ;        FBARR array that will hold the address (passed by reference) | 
|---|
|  | 21 | ;VAPA("CD") - date for ADD^VADPT if not defined then NOW will be used | 
|---|
|  | 22 | ;    VAPA will be killed! | 
|---|
|  | 23 | ; | 
|---|
|  | 24 | ;OUTPUT  FBARR array will contain the veteran mailing address, | 
|---|
|  | 25 | ;              subscripted by sequential number; FBARR = line count | 
|---|
|  | 26 | N FBCT,FBI | 
|---|
|  | 27 | K FBARR | 
|---|
|  | 28 | S FBCT=0 | 
|---|
|  | 29 | I $G(DFN)>0 D | 
|---|
|  | 30 | .S FBCT=FBCT+1,FBARR(FBCT)=$$GETNAME^FBUCLET1(DFN,2,"G") | 
|---|
|  | 31 | .D ADD^VADPT I 'VAERR D  K VAPA,VAERR | 
|---|
|  | 32 | . . I $$ACTIVECC^FBAACO0() D  Q | 
|---|
|  | 33 | . . . F FBI=13,14,15 S:$G(VAPA(FBI))]"" FBCT=FBCT+1,FBARR(FBCT)=$G(VAPA(FBI)) | 
|---|
|  | 34 | . . . S FBCT=FBCT+1,FBARR(FBCT)=$S($G(VAPA(16))]"":$G(VAPA(16)),1:"     ")_"  "_$S($P($G(VAPA(17)),U,2)]"":$P($G(VAPA(17)),U,2),1:"  ")_"  "_$P($G(VAPA(18)),U,2) | 
|---|
|  | 35 | ..F FBI=1,2,3 S:VAPA(FBI)]"" FBCT=FBCT+1,FBARR(FBCT)=VAPA(FBI) | 
|---|
|  | 36 | ..S FBCT=FBCT+1,FBARR(FBCT)=$S(VAPA(4)]"":VAPA(4),1:"     ")_"  "_$S($P(VAPA(5),U,2)]"":$P(VAPA(5),U,2),1:"  ")_"  "_$S('+$G(VAPA(11)):VAPA(6),$P(VAPA(11),U,2)]"":$P(VAPA(11),U,2),1:VAPA(6)) | 
|---|
|  | 37 | S FBARR=FBCT | 
|---|
|  | 38 | Q | 
|---|
|  | 39 | ; | 
|---|
|  | 40 | VENADD(FBV,FBARR) ;set up vendor address | 
|---|
|  | 41 | ;INPUT:  FBV = vendor ien (file 161.2) | 
|---|
|  | 42 | ;        FBARR array that will hold the address (passed by reference) | 
|---|
|  | 43 | ;OUTPUT  FBARR array will contain the vendor mailing address, | 
|---|
|  | 44 | ;              subscripted by sequential number; FBARR = line count | 
|---|
|  | 45 | N FBCT,FBP,FBSTATE,FBZ | 
|---|
|  | 46 | K FBARR | 
|---|
|  | 47 | S FBCT=0 | 
|---|
|  | 48 | I $G(FBV)>0 D | 
|---|
|  | 49 | .S FBZ=$G(^FBAAV(FBV,0)) | 
|---|
|  | 50 | .S FBCT=FBCT+1,FBARR(FBCT)=$P(FBZ,U) | 
|---|
|  | 51 | .I FBARR(1)["," S FBARR(1)=$P(FBARR(1),",",2)_" "_$P(FBARR(1),",") | 
|---|
|  | 52 | .S FBSTATE=$P($G(^DIC(5,+$P(FBZ,U,5),0)),U,2) | 
|---|
|  | 53 | .F FBP=3,14 S:$P(FBZ,U,FBP)]"" FBCT=FBCT+1,FBARR(FBCT)=$P(FBZ,U,FBP) | 
|---|
|  | 54 | .S FBCT=FBCT+1,FBARR(FBCT)=$S($P(FBZ,U,4)]"":$P(FBZ,U,4),1:"     ")_"  "_$S(FBSTATE]"":FBSTATE,1:"  ")_"  "_$P(FBZ,U,6) | 
|---|
|  | 55 | S FBARR=FBCT | 
|---|
|  | 56 | Q | 
|---|
|  | 57 | OTHADD(FBDA,FBARR) ;set up other party address | 
|---|
|  | 58 | ;INPUT:  FBDA = other party ien (file 200) | 
|---|
|  | 59 | ;        FBARR array that will hold the address (passed by reference) | 
|---|
|  | 60 | ;OUTPUT  FBARR array will contain the vendor mailing address, | 
|---|
|  | 61 | ;              subscripted by sequential number; FBARR = line count | 
|---|
|  | 62 | N FBCT,FBP,FBSTATE,FBZ11 | 
|---|
|  | 63 | K FBARR | 
|---|
|  | 64 | S FBCT=0 | 
|---|
|  | 65 | I $G(FBDA)>0 D | 
|---|
|  | 66 | .S FBCT=FBCT+1,FBARR(FBCT)=$$GETNAME^FBUCLET1(FBDA,200,"G") | 
|---|
|  | 67 | .S FBZ11=$G(^VA(200,FBDA,.11)) | 
|---|
|  | 68 | .I FBZ11]"" D | 
|---|
|  | 69 | ..S FBSTATE=$P($G(^DIC(5,+$P(FBZ11,U,5),0)),U,2) | 
|---|
|  | 70 | ..F FBP=1,2,3 S:$P(FBZ11,U,FBP)]"" FBCT=FBCT+1,FBARR(FBCT)=$P(FBZ11,U,FBP) | 
|---|
|  | 71 | ..S FBCT=FBCT+1,FBARR(FBCT)=$S($P(FBZ11,U,4)]"":$P(FBZ11,U,4),1:"     ")_"  "_$S(FBSTATE]"":FBSTATE,1:"  ")_"  "_$P(FBZ11,U,6) | 
|---|
|  | 72 | S FBARR=FBCT | 
|---|
|  | 73 | Q | 
|---|
|  | 74 | STATADD ;station address, from fee basis site parameter file | 
|---|
|  | 75 | ;INPUT:  nothing | 
|---|
|  | 76 | ;OUTPUT: FBSADD( array of station name,address, and number | 
|---|
|  | 77 | ;called when printing a letter, used if letterhead not used | 
|---|
|  | 78 | K ^UTILITY("DIQ1",$J) N DIC,DA,DIQ,DR,FBCT,FBP S DIC="^FBAA(161.4,",DA=1,DIQ="FBSADD(" D | 
|---|
|  | 79 | .S DR="1:2;16",DIQ(0)="EN" D EN^DIQ1 | 
|---|
|  | 80 | .S DR="3:5;35.6",DIQ(0)="E" D EN^DIQ1 | 
|---|
|  | 81 | .;S DR=27,DIQ(0)="IN" D EN^DIQ1 | 
|---|
|  | 82 | I $G(FBSADD(161.4,1,16,"E"))]"" S FBSADD(161.4,1,2.5,"E")=FBSADD(161.4,1,16,"E") K FBSADD(161.4,1,16,"E") ;set street address lines together | 
|---|
|  | 83 | S FBSADD(161.4,1,.01,"E")=$G(FBSADD(161.4,1,35.6,"E")) K FBSADD(161.4,1,35.6,"E") ;re-set so name is first | 
|---|
|  | 84 | S (FBCT,FBP)=0 F  S FBP=$O(FBSADD(161.4,1,FBP)) Q:FBP'<3!('FBP)  S:$G(FBSADD(161.4,1,FBP,"E"))]"" FBCT=FBCT+1,FBSADD(FBCT)=FBSADD(161.4,1,FBP,"E") K FBSADD(161.4,1,FBP) | 
|---|
|  | 85 | S FBCT=FBCT+1,FBSADD(FBCT)=$S($G(FBSADD(161.4,1,3,"E"))]"":FBSADD(161.4,1,3,"E"),1:"     ")_"  "_$S($G(FBSADD(161.4,1,4,"E"))]"":FBSADD(161.4,1,4,"E"),1:"  ")_"  "_$G(FBSADD(161.4,1,5,"E")) F FBP=3:1:5 K FBSADD(161.4,1,FBP) | 
|---|
|  | 86 | K ^UTILITY("DIQ1",$J) Q | 
|---|
|  | 87 | STANUM ;get station number | 
|---|
|  | 88 | ;INPUT:  nothing | 
|---|
|  | 89 | ;OUTPUT: FBSTANUM = station number of PSA, as set in FB site parameter | 
|---|
|  | 90 | K ^UTILITY("DIQ1",$J) N DA,DIC,DIQ,DR S DA=1,DIC="^FBAA(161.4,",DIQ="FBSTA(",DR=27,DIQ(0)="IN" D EN^DIQ1 K ^UTILITY("DIQ1",$J) | 
|---|
|  | 91 | S FBSTANUM=$G(FBSTA(161.4,1,27,"I")) I FBSTANUM]"" S FBSTANUM=$P($G(^DIC(4,FBSTANUM,99)),U) | 
|---|
|  | 92 | K FBSTA(161.4) Q | 
|---|
|  | 93 | LETTER(FBORDER,FB1725) ;get letter ien number | 
|---|
|  | 94 | ;INPUT:  FBORDER = order number of status | 
|---|
|  | 95 | ;        FB1725 = (optional) =true to select a 38 U.S.C. 1725 letter | 
|---|
|  | 96 | ;OUTPUT:  ien of letter or 0 | 
|---|
|  | 97 | N Y,PIECE | 
|---|
|  | 98 | S Y=+$O(^FB(162.92,"AO",FBORDER,0)) | 
|---|
|  | 99 | S PIECE=$S($G(FB1725):6,1:5) | 
|---|
|  | 100 | Q +$P($G(^FB(162.92,Y,0)),"^",PIECE) | 
|---|
|  | 101 | ; | 
|---|
|  | 102 | TXT(FBGL,FBIEN,FBN,DIWF,DIWL,FBLET,FBCC,FBCCI,FBLBL) ;write txt | 
|---|
|  | 103 | ;INPUT:  FBGL = global root | 
|---|
|  | 104 | ;        FBIEN = internal entry number of file | 
|---|
|  | 105 | ;        FBN = node where wp info resides | 
|---|
|  | 106 | ;        DIWF = format | 
|---|
|  | 107 | ;        DIWL = left offset | 
|---|
|  | 108 | ;        FBLET = 1 if coming from letter (optional) | 
|---|
|  | 109 | ;        FBCC = 1 if CC address will print at bottom of page (optional) | 
|---|
|  | 110 | ;               passed by reference | 
|---|
|  | 111 | ;        FBCCI = number lines needed for CC address (required if FBCC=1) | 
|---|
|  | 112 | ;        FBLBL = label text to print at beginning of 1st line (optional) | 
|---|
|  | 113 | N FBI,FBNODE,FBTXT,X S FBNODE=FBGL_FBIEN_","_FBN S FBLET=$S('$D(FBLET):0,1:+FBLET) | 
|---|
|  | 114 | I $D(@(FBNODE_")")) S X=$G(FBLBL) D:X]"" ^DIWP S FBI=0 F  S FBI=$O(@(FBNODE_","_FBI_")")) Q:'FBI  S FBTXT=^(FBI,0),X=FBTXT D | 
|---|
|  | 115 | .I $Y+$S($G(FBCCI)>7&$G(FBCC):FBCCI,1:7)>IOSL W:'FBLET @IOF D:FBLET PAGE^FBUCLET1 | 
|---|
|  | 116 | .D ^DIWP | 
|---|
|  | 117 | I $Y+$S($G(FBCCI)>7&$G(FBCC):FBCCI,1:7)>IOSL W:'FBLET @IOF D:FBLET PAGE^FBUCLET1 | 
|---|
|  | 118 | D:$D(FBTXT) ^DIWW | 
|---|
|  | 119 | K FBLET Q | 
|---|
|  | 120 | PAGE ;write page | 
|---|
|  | 121 | W @IOF Q | 
|---|
|  | 122 | PDATE(FBDT) ;output fcn of date, long form | 
|---|
|  | 123 | ;INPUT: FBDT = date for output | 
|---|
|  | 124 | ;OUTPUT: month day, year | 
|---|
|  | 125 | N FBPDT,Y S Y=FBDT D PDATE^FBAAUTL Q $G(FBPDT) | 
|---|
|  | 126 | ; | 
|---|
|  | 127 | FBUC(X) ;unauthorized claim parameters | 
|---|
|  | 128 | ;INPUT:  X = ien of parameter | 
|---|
|  | 129 | ;OUTPUT: "UC" node in parameter file | 
|---|
|  | 130 | Q $G(^FBAA(161.4,X,"UC")) | 
|---|
|  | 131 | ; | 
|---|
|  | 132 | DIE(DIE,DA,DR) ;update a field | 
|---|
|  | 133 | ;INPUT:  DIE = global root | 
|---|
|  | 134 | ;        DA = record to be updated | 
|---|
|  | 135 | ;        DR = field to be updated | 
|---|
|  | 136 | ;OUTPUT: update record in file | 
|---|
|  | 137 | I $S($G(DIE)']"":1,$G(DR)']"":1,'+$G(DA):1,1:0) Q | 
|---|
|  | 138 | N FBLOCK | 
|---|
|  | 139 | D LOCK^FBUCUTL(DIE,DA,1) I FBLOCK D ^DIE L -@(DIE_DA_")") K FBLOCK | 
|---|
|  | 140 | Q | 
|---|