Annotation of freem_fileman/DDGFFLDA.m, revision 1.1.1.1

1.1       snw         1: DDGFFLDA       ;SFISC/MKO-ADD A FIELD ;01:43 PM  22 Nov 1994
                      2:        ;;21.0;VA FileMan;;Dec 28, 1994
                      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:        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:        S DIE=DIC,DA(1)=DDGFBLCK,DA=+Y
                     48:        S DR="2////"_DDGFTYPE
                     49:        S:DDGFTYPE'=1 DR=DR_";4.1////"_DDGFDC_";4.2////1"
                     50:        D ^DIE K DIC,DIE,DR,Y
                     51:        ;
                     52:        ;Invoke appropriate form
                     53:        S DDSFILE=.404,DDSFILE(1)=.4044,DDSPARM="CKTW"
                     54:        S DDGFDD=$P(^DIST(.404,DDGFBLCK,0),U,2)
                     55:        S DR="[DDGF FIELD "_$P("CAPTION ONLY^FORM ONLY^DD^COMPUTED",U,DDGFTYPE)_"]"
                     56:        D ^DDS K DDSFILE,DR,DDSPARM,DDGFDD
                     57:        ;
                     58:        I $D(DA)#2,DDGFTYPE'=1,$G(DDSCHANG)'=1 D
                     59:        . S DIK="^DIST(.404,"_DA(1)_",40,"
                     60:        . D ^DIK K DIK
                     61:        E  I $D(DA)#2 D
                     62:        . D SAVE
                     63:        . D LOADF
                     64:        ;
                     65: ADDQ   ;Refresh and cleanup
                     66:        D REFRESH^DDGF
                     67:        D RC(DDGFDY,DDGFDX)
                     68:        ;
                     69:        K DA,DDSCHANG
                     70:        K DDGFB1,DDGFB2,DDGFD1,DDGFD2
                     71:        K DDGFSUP,DDGFSUP0,DDGFCAP,DDGFCAP0,DDGFCC,DDGFCC0
                     72:        K DDGFDL,DDGFDL0,DDGFDC,DDGFDC0
                     73:        K DDGFDY,DDGFDX,DDGFBLCK,DDGFFORD,DDGFTYPE
                     74:        Q
                     75:        ;
                     76: SAVE   ;Save changes to caption, coordinates, data length, and suppress
                     77:        ;colon flag
                     78:        S:DDGFCAP="" (DDGFSUP,DDGFCC)=""
                     79:        S DR=""
                     80:        ;
                     81:        S:DDGFCAP]"" DR=DR_"1////"_DDGFCAP_";"
                     82:        S:DDGFCC]"" DR=DR_"5.1////"_DDGFCC_";"
                     83:        S:DDGFSUP DR=DR_"5.2////1;"
                     84:        ;
                     85:        I DDGFTYPE'=1 D
                     86:        . S:DDGFDC'=DDGFDC0 DR=DR_"4.1////"_DDGFDC_";"
                     87:        . S:DDGFDL'=DDGFDL0 DR=DR_"4.2////"_DDGFDL_";"
                     88:        I DR="" K DR Q
                     89:        ;
                     90:        S DIE="^DIST(.404,"_DA(1)_",40,"
                     91:        S DR=$E(DR,1,$L(DR)-1)
                     92:        D ^DIE K DIE,DR,Y
                     93:        Q
                     94:        ;
                     95: LOADF  ;Set DDGFREF and window buffer
                     96:        N C,C1,C2,C3,D,D1,D2,D3,L
                     97:        ;
                     98:        I DDGFCAP="" D
                     99:        . S (C,C1,C2,C3)=""
                    100:        . K @DDGFREF@("F",DDGFPG,DDGFBLCK,DA)
                    101:        E  D
                    102:        . S C=DDGFCAP_$S(DDGFTYPE'=1&'DDGFSUP:":",1:"")
                    103:        . S C1=$P(DDGFCC,",")-1+DDGFB1
                    104:        . S C2=$P(DDGFCC,",",2)-1+DDGFB2
                    105:        . S C3=C2+$L(C)-1
                    106:        . ;
                    107:        . S @DDGFREF@("F",DDGFPG,DDGFBLCK,DA)=C1_U_C2_U_C3_U_C
                    108:        . S @DDGFREF@("RC",DDGFWID,C1,C2,C3,DDGFBLCK,DA,"C")=""
                    109:        . D WRITE^DDGLIBW(DDGFWID,C,C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"",1)
                    110:        ;
                    111:        I DDGFTYPE'=1 D
                    112:        . S D1=$P(DDGFDC,",")-1+DDGFB1
                    113:        . S D2=$P(DDGFDC,",",2)-1+DDGFB2
                    114:        . S D3=D2+DDGFDL-1
                    115:        . ;
                    116:        . S $P(@DDGFREF@("F",DDGFPG,DDGFBLCK,DA),U,5,8)=D1_U_D2_U_D3_U_DDGFDL
                    117:        . I D1]"",D2]"" S @DDGFREF@("RC",DDGFWID,D1,D2,D3,DDGFBLCK,DA,"D")=""
                    118:        . D:DDGFDL WRITE^DDGLIBW(DDGFWID,$TR($J("",DDGFDL)," ","_"),D1-$P(DDGFLIM,U),D2-$P(DDGFLIM,U,2),"",1)
                    119:        Q
                    120:        ;
                    121: RC(DDGFY,DDGFX)        ;Update status line, reset DX and DY, move cursor
                    122:        N S
                    123:        I DDGFR D
                    124:        . S DY=IOSL-6,DX=IOM-9,S="R"_(DDGFY+1)_",C"_(DDGFX+1)
                    125:        . X IOXY W S_$J("",7-$L(S))
                    126:        S DY=DDGFY,DX=DDGFX X IOXY
                    127:        Q

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>