1 | DDGFUPDB ;SFISC/MKO-UPDATE BLOCK COORDINATES ;03:28 PM 17 Aug 1993
|
---|
2 | ;;22.0;VA FileMan;;Mar 30, 1999
|
---|
3 | ;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
4 | BLK(DDGFORIG) ;
|
---|
5 | ;Update image with adjusted block coordinates
|
---|
6 | ; DDGFORIG(B) : defined for all blocks that changed coordinates
|
---|
7 | ; = original $Y^original $X
|
---|
8 | N P,P1,P2,B,B1,B2,F,C1,C2,C3,C,D1,D2,D3,L,X1,Y1,N,I
|
---|
9 | ;
|
---|
10 | ;Get page coordinates
|
---|
11 | S P=DDGFPG
|
---|
12 | S P1=$P(@DDGFREF@("F",P),U),P2=$P(@DDGFREF@("F",P),U,2)
|
---|
13 | ;
|
---|
14 | ;Loop through all blocks on page
|
---|
15 | S B="" F S B=$O(@DDGFREF@("F",P,B)) Q:B="" D BK
|
---|
16 | Q
|
---|
17 | ;
|
---|
18 | BK ;Get block coordinates
|
---|
19 | S B2=@DDGFREF@("F",P,B)
|
---|
20 | S B1=$P(B2,U),B2=$P(B2,U,2)
|
---|
21 | ;
|
---|
22 | ;Get Y1=delta $Y, X1=delta $X
|
---|
23 | I $D(DDGFORIG(B)) S Y1=B1-$P(DDGFORIG(B),U),X1=B2-$P(DDGFORIG(B),U,2)
|
---|
24 | E S (Y1,X1)=0
|
---|
25 | I 'Y1,'X1 K DDGFORIG(B)
|
---|
26 | ;
|
---|
27 | ;Loop through all fields on block
|
---|
28 | S F="" F S F=$O(@DDGFREF@("F",P,B,F)) Q:F="" D FD
|
---|
29 | Q
|
---|
30 | ;
|
---|
31 | FD ;
|
---|
32 | ;Get field data
|
---|
33 | S N=@DDGFREF@("F",P,B,F)
|
---|
34 | S C1=$P(N,U),C2=$P(N,U,2),C3=$P(N,U,3),C=$P(N,U,4)
|
---|
35 | S D1=$P(N,U,5),D2=$P(N,U,6),D3=$P(N,U,7),L=$P(N,U,8)
|
---|
36 | ;
|
---|
37 | I $D(DDGFORIG(B)) D
|
---|
38 | . I Y1 S:C1]"" $P(N,U)=C1+Y1 S:L $P(N,U,5)=D1+Y1
|
---|
39 | . I X1 D
|
---|
40 | .. I C]"" F I=2,3 S $P(N,U,I)=$P(N,U,I)+X1
|
---|
41 | .. I L F I=6,7 S $P(N,U,I)=$P(N,U,I)+X1
|
---|
42 | . S @DDGFREF@("F",P,B,F)=N
|
---|
43 | . ;
|
---|
44 | . I C]"" D
|
---|
45 | .. K @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C")
|
---|
46 | .. S @DDGFREF@("RC",DDGFWID,$P(N,U),$P(N,U,2),$P(N,U,3),B,F,"C")=""
|
---|
47 | . I L D
|
---|
48 | .. K @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F,"D")
|
---|
49 | .. S @DDGFREF@("RC",DDGFWID,$P(N,U,5),$P(N,U,6),$P(N,U,7),B,F,"D")=""
|
---|
50 | ;
|
---|
51 | I C]"" D WRITE^DDGLIBW(DDGFWID,C,$P(N,U)-P1,$P(N,U,2)-P2)
|
---|
52 | I L D WRITE^DDGLIBW(DDGFWID,$TR($J("",L)," ","_"),$P(N,U,5)-P1,$P(N,U,6)-P2)
|
---|
53 | Q
|
---|