| 1 | DDGFFLDA ;SFISC/MKO-ADD A FIELD ;2:22 PM  13 Sep 1995 | 
|---|
| 2 | ;;22.0;VA FileMan;;Mar 30, 1999 | 
|---|
| 3 | ;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | ADD ;Add a field | 
|---|
| 5 | I '$O(^DIST(.403,+DDGFFM,40,DDGFPG,40,0)) D  Q | 
|---|
| 6 | . D MSG^DDGF($C(7)_"There are no blocks defined on this page.  To add a block, press <PF2>B.") | 
|---|
| 7 | . H 2 D MSG^DDGF() | 
|---|
| 8 | S DDGFDY=DY,DDGFDX=DX | 
|---|
| 9 | ; | 
|---|
| 10 | ;Invoke form to select block, field order, field type | 
|---|
| 11 | K DDGFBLCK,DDGFFORD,DDGFTYPE | 
|---|
| 12 | S DDSFILE=.404,DDSFILE(1)=.4044 | 
|---|
| 13 | S DR="[DDGF FIELD ADD]",DDSPARM="KTW" | 
|---|
| 14 | D ^DDS K DDSFILE,DA,DR,DDSPARM | 
|---|
| 15 | ; | 
|---|
| 16 | I '$D(DDGFBLCK)!'$D(DDGFFORD)!'$D(DDGFTYPE) G ADDQ | 
|---|
| 17 | ; | 
|---|
| 18 | ;Get relative field coordinates | 
|---|
| 19 | S (DDGFCAP,DDGFCAP0)="" | 
|---|
| 20 | S (DDGFSUP,DDGFSUP0)="" | 
|---|
| 21 | S (DDGFCC,DDGFCC0)="" | 
|---|
| 22 | ; | 
|---|
| 23 | S DDGFB2=@DDGFREF@("F",DDGFPG,DDGFBLCK) | 
|---|
| 24 | S DDGFB1=$P(DDGFB2,U),DDGFB2=$P(DDGFB2,U,2) | 
|---|
| 25 | ; | 
|---|
| 26 | I DDGFTYPE=1 D | 
|---|
| 27 | . S DDGFCC0=DDGFDY-DDGFB1+1_","_(DDGFDX-DDGFB2+1) | 
|---|
| 28 | E  D | 
|---|
| 29 | . S DDGFD1=DDGFDY-DDGFB1+1,DDGFD2=DDGFDX-DDGFB2+1 | 
|---|
| 30 | . S (DDGFDC,DDGFDC0)=DDGFD1_","_DDGFD2 | 
|---|
| 31 | . S (DDGFDL,DDGFDL0)=1 | 
|---|
| 32 | ; | 
|---|
| 33 | I DDGFTYPE'=1,DDGFD1<1!(DDGFD2<1) D  G ADDQ | 
|---|
| 34 | . D MSG^DDGF($C(7)_"Unable to add a field above or to the left of the block.") | 
|---|
| 35 | . H 2 D MSG^DDGF() | 
|---|
| 36 | ; | 
|---|
| 37 | K DDGFD1,DDGFD2 | 
|---|
| 38 | ; | 
|---|
| 39 | ;Add field order to block file | 
|---|
| 40 | S DIC="^DIST(.404,"_DDGFBLCK_",40,",DIC(0)="L" | 
|---|
| 41 | S DIC("P")=$P(^DD(.404,40,0),U,2) | 
|---|
| 42 | S DA(1)=DDGFBLCK,X=DDGFFORD | 
|---|
| 43 | K DD,DO D FILE^DICN | 
|---|
| 44 | I Y=-1 K DIC,DA,Y D MSG^DDGF($C(7)_"Unable to add field.") H 2 D MSG^DDGF() G ADDQ | 
|---|
| 45 | ; | 
|---|
| 46 | ;Stuff values for field type, data coordinate, and data length | 
|---|
| 47 | ;If form-only field, also stuff in default read type | 
|---|
| 48 | S DIE=DIC,DA(1)=DDGFBLCK,DA=+Y | 
|---|
| 49 | S DR="2////"_DDGFTYPE | 
|---|
| 50 | S:DDGFTYPE'=1 DR=DR_";4.1////"_DDGFDC_";4.2////1" | 
|---|
| 51 | S:DDGFTYPE=2 DR=DR_";20.1////F" | 
|---|
| 52 | D ^DIE K DIC,DIE,DR,Y | 
|---|
| 53 | ; | 
|---|
| 54 | ;Invoke appropriate form | 
|---|
| 55 | S DDSFILE=.404,DDSFILE(1)=.4044,DDSPARM="CKTW" | 
|---|
| 56 | S DDGFDD=$P(^DIST(.404,DDGFBLCK,0),U,2) | 
|---|
| 57 | S DR="[DDGF FIELD "_$P("CAPTION ONLY^FORM ONLY^DD^COMPUTED",U,DDGFTYPE)_"]" | 
|---|
| 58 | D ^DDS K DDSFILE,DR,DDSPARM,DDGFDD | 
|---|
| 59 | ; | 
|---|
| 60 | I $D(DA)#2,DDGFTYPE'=1,$G(DDSCHANG)'=1 D | 
|---|
| 61 | . S DIK="^DIST(.404,"_DA(1)_",40," | 
|---|
| 62 | . D ^DIK K DIK | 
|---|
| 63 | E  I $D(DA)#2 D | 
|---|
| 64 | . D SAVE | 
|---|
| 65 | . D LOADF | 
|---|
| 66 | ; | 
|---|
| 67 | ADDQ ;Refresh and cleanup | 
|---|
| 68 | D REFRESH^DDGF | 
|---|
| 69 | D RC(DDGFDY,DDGFDX) | 
|---|
| 70 | ; | 
|---|
| 71 | K DA,DDSCHANG | 
|---|
| 72 | K DDGFB1,DDGFB2,DDGFD1,DDGFD2 | 
|---|
| 73 | K DDGFSUP,DDGFSUP0,DDGFCAP,DDGFCAP0,DDGFCC,DDGFCC0 | 
|---|
| 74 | K DDGFDL,DDGFDL0,DDGFDC,DDGFDC0 | 
|---|
| 75 | K DDGFDY,DDGFDX,DDGFBLCK,DDGFFORD,DDGFTYPE | 
|---|
| 76 | Q | 
|---|
| 77 | ; | 
|---|
| 78 | SAVE ;Save changes to caption, coordinates, data length, and suppress | 
|---|
| 79 | ;colon flag | 
|---|
| 80 | S:DDGFCAP="" (DDGFSUP,DDGFCC)="" | 
|---|
| 81 | S DR="" | 
|---|
| 82 | ; | 
|---|
| 83 | S:DDGFCAP]"" DR=DR_"1////"_DDGFCAP_";" | 
|---|
| 84 | S:DDGFCC]"" DR=DR_"5.1////"_DDGFCC_";" | 
|---|
| 85 | S:DDGFSUP DR=DR_"5.2////1;" | 
|---|
| 86 | ; | 
|---|
| 87 | I DDGFTYPE'=1 D | 
|---|
| 88 | . S:DDGFDC'=DDGFDC0 DR=DR_"4.1////"_DDGFDC_";" | 
|---|
| 89 | . S:DDGFDL'=DDGFDL0 DR=DR_"4.2////"_DDGFDL_";" | 
|---|
| 90 | I DR="" K DR Q | 
|---|
| 91 | ; | 
|---|
| 92 | S DIE="^DIST(.404,"_DA(1)_",40," | 
|---|
| 93 | S DR=$E(DR,1,$L(DR)-1) | 
|---|
| 94 | D ^DIE K DIE,DR,Y | 
|---|
| 95 | Q | 
|---|
| 96 | ; | 
|---|
| 97 | LOADF ;Set DDGFREF and window buffer | 
|---|
| 98 | N C,C1,C2,C3,D,D1,D2,D3,L | 
|---|
| 99 | ; | 
|---|
| 100 | I DDGFCAP="" D | 
|---|
| 101 | . S (C,C1,C2,C3)="" | 
|---|
| 102 | . K @DDGFREF@("F",DDGFPG,DDGFBLCK,DA) | 
|---|
| 103 | E  D | 
|---|
| 104 | . S C=DDGFCAP_$S(DDGFTYPE'=1&'DDGFSUP:":",1:"") | 
|---|
| 105 | . S C1=$P(DDGFCC,",")-1+DDGFB1 | 
|---|
| 106 | . S C2=$P(DDGFCC,",",2)-1+DDGFB2 | 
|---|
| 107 | . S C3=C2+$L(C)-1 | 
|---|
| 108 | . ; | 
|---|
| 109 | . S @DDGFREF@("F",DDGFPG,DDGFBLCK,DA)=C1_U_C2_U_C3_U_C | 
|---|
| 110 | . S @DDGFREF@("RC",DDGFWID,C1,C2,C3,DDGFBLCK,DA,"C")="" | 
|---|
| 111 | . D WRITE^DDGLIBW(DDGFWID,C,C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"",1) | 
|---|
| 112 | ; | 
|---|
| 113 | I DDGFTYPE'=1 D | 
|---|
| 114 | . S D1=$P(DDGFDC,",")-1+DDGFB1 | 
|---|
| 115 | . S D2=$P(DDGFDC,",",2)-1+DDGFB2 | 
|---|
| 116 | . S D3=D2+DDGFDL-1 | 
|---|
| 117 | . ; | 
|---|
| 118 | . S $P(@DDGFREF@("F",DDGFPG,DDGFBLCK,DA),U,5,8)=D1_U_D2_U_D3_U_DDGFDL | 
|---|
| 119 | . I D1]"",D2]"" S @DDGFREF@("RC",DDGFWID,D1,D2,D3,DDGFBLCK,DA,"D")="" | 
|---|
| 120 | . D:DDGFDL WRITE^DDGLIBW(DDGFWID,$TR($J("",DDGFDL)," ","_"),D1-$P(DDGFLIM,U),D2-$P(DDGFLIM,U,2),"",1) | 
|---|
| 121 | Q | 
|---|
| 122 | ; | 
|---|
| 123 | RC(DDGFY,DDGFX) ;Update status line, reset DX and DY, move cursor | 
|---|
| 124 | N S | 
|---|
| 125 | I DDGFR D | 
|---|
| 126 | . S DY=IOSL-6,DX=IOM-9,S="R"_(DDGFY+1)_",C"_(DDGFX+1) | 
|---|
| 127 | . X IOXY W S_$J("",7-$L(S)) | 
|---|
| 128 | S DY=DDGFY,DX=DDGFX X IOXY | 
|---|
| 129 | Q | 
|---|