Annotation of freem_fileman/DDGFBK.m, revision 1.1.1.1
1.1 snw 1: DDGFBK ;SFISC/MKO-ADD, EDIT, DELETE BLOCK ;01:47 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: ;
5: ADD ;Add a new block
6: N B,C1,C2,C3
7: S DDGFDY=DY,DDGFDX=DX
8: ;
9: ;Invoke form to enter block name
10: K DDGFBNUM,DDGFBNAM
11: D DDS(.404,"[DDGF BLOCK ADD]")
12: G:'$D(DDGFBNUM) ADDQ
13: ;
14: ;Ask whether block should be added or indicate duplicate block
15: K DDGFANS
16: S DDSPAGE=$S($P(^DIST(.403,+DDGFFM,40,DDGFPG,0),U,2)=DDGFBNUM!$D(^(40,"B",DDGFBNUM)):21,1:11)
17: D DDS(.404,"[DDGF BLOCK ADD]","",DDSPAGE)
18: G:DDSPAGE=21!'$G(DDGFANS) ADDQ
19: K DDSPAGE,DDGFANS
20: ;
21: ;Add block to page
22: S DIC="^DIST(.403,+DDGFFM,40,DDGFPG,40,",DIC(0)="L"
23: S DA(2)=+DDGFFM,DA(1)=DDGFPG
24: S DIC("P")=$P(^DD(.4031,40,0),U,2)
25: S (DINUM,X)=DDGFBNUM
26: D FILE^DICN K DINUM,X
27: G:Y=-1 ADDQ
28: ;
29: ;Stuff in values for block order, coordinates, and type
30: S DIE=DIC,DA=+Y
31: S DDGFC=DDGFDY-$P(DDGFLIM,U)+1_","_(DDGFDX-$P(DDGFLIM,U,2)+1)
32: S DR="1////"_($O(^DIST(.403,+DDGFFM,40,DDGFPG,40,"AC",""),-1)+1\1)_";2////"_DDGFC_";3////e"
33: D ^DIE K DA,DIC,DIE,DR,X,Y,DDGFC
34: ;
35: ;If this looks like a brand new block, stuff in DD number
36: I $L(^DIST(.404,DDGFBNUM,0),U)=1,'$O(^(0)) D
37: . S DIE="^DIST(.404,",DA=DDGFBNUM
38: . S DR="1////"_$P(^DIST(.403,+DDGFFM,0),U,8)
39: . D ^DIE K DA,DIE,DR
40: ;
41: D BK^DDGFLOAD(DDGFPG,DDGFBNUM,$P(DDGFLIM,U),$P(DDGFLIM,U,2),DDGFDY,DDGFDX,0,1)
42: ;
43: S DY=DDGFDY,DX=DDGFDX
44: S B=DDGFBNUM,C=$P(@DDGFREF@("F",DDGFPG,B),U,4)
45: S C1=DY,C2=DX,C3=C2+$L(DDGFBNAM)-1
46: S DDGFADD=1
47: K DDGFBNUM,DDGFBNAM
48: S:$G(DDGFBV) DDGFORIG(B)=DY_U_DX
49: G EDIT
50: ;
51: ADDQ ;Adding aborted
52: D REFRESH^DDGF,RC(DDGFDY,DDGFDX)
53: K DDGFANS,DDGFBNAM,DDGFBNUM,DDGFDX,DDGFDY,DDSPAGE,DA,DIC,Y
54: Q
55: ;
56: EDIT ;Edit block
57: ;In: B,C1,C2,C3,C
58: S DDGFDY=DY,DDGFDX=DX
59: S DDGFBK=B,DDGFC1=C1,DDGFC2=C2,DDGFC3=C3
60: S DDGFBKCO=C1-$P(DDGFLIM,U)+1_","_(C2-$P(DDGFLIM,U,2)+1)
61: S DDGFBKNO=C
62: ;
63: ;Invoke form to edit block
64: S DDSFILE=.403,DDSFILE(1)=.4032
65: S DA(2)=+DDGFFM,DA(1)=DDGFPG,DA=B
66: S DR="[DDGF BLOCK EDIT]",DDSPARM="KTW"
67: D ^DDS K DDSFILE,DA,DR,DDSPARM
68: ;
69: ;If block was deleted, remove data from DDGFREF
70: I $D(^DIST(.403,+DDGFFM,40,DDGFPG,40,DDGFBK,0))[0 D DELETE(DDGFBK) G EDITQ
71: ;
72: S:$D(DDGFBKCN)[0 DDGFBKCN=DDGFBKCO
73: S:$D(DDGFBKNN)[0 DDGFBKNN=DDGFBKNO
74: ;
75: S C=DDGFBKNN
76: S C1=$P(DDGFBKCN,",")-1+$P(DDGFLIM,U)
77: S C2=$P(DDGFBKCN,",",2)-1+$P(DDGFLIM,U,2)
78: S C3=C2+$L(C)-1
79: ;
80: ;Update TMP if coordinates or name changed, or new block
81: I DDGFBKCN'=DDGFBKCO!(DDGFBKNN'=DDGFBKNO)!$G(DDGFADD) D
82: . D WRITE^DDGLIBW(DDGFWIDB,$J("",$L(DDGFBKNO)),DDGFC1-$P(DDGFLIM,U),DDGFC2-$P(DDGFLIM,U,2),"",1)
83: . D WRITE^DDGLIBW(DDGFWIDB,C,C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"",1)
84: ;
85: EDITQ D REFRESH^DDGF,RC(DDGFDY,DDGFDX)
86: S:'$G(DDGFADD) DDGFE=1
87: K DDGFADD,DDGFBK,DDGFBKCO,DDGFBKNO,DDGFBKCN,DDGFBKNN
88: K DDGFC1,DDGFC2,DDGFC3,DDGFDX,DDGFDY
89: Q
90: ;
91: DELETE(B,E) ;Remove block from DDGFREF
92: ;E : means don't set DDGFEBV or DDGFBDEL
93: ; (used by EDIT^DDGFHBK when a different header block is chosen)
94: N F,N
95: ;Remove from TMP
96: S F="" F S F=$O(@DDGFREF@("F",DDGFPG,B,F)) Q:F="" D
97: . S N=@DDGFREF@("F",DDGFPG,B,F)
98: . K:$P(N,U,4)]"" @DDGFREF@("RC",DDGFWID,$P(N,U),$P(N,U,2),$P(N,U,3),B)
99: . K:$P(N,U,8)>0 @DDGFREF@("RC",DDGFWID,$P(N,U,5),$P(N,U,6),$P(N,U,7),B)
100: K @DDGFREF@("F",DDGFPG,B)
101: ;
102: ;If no blocks on page, set DDGFEBV to exit Block Viewer
103: ;DDGFBDEL indicates block name should not be painted
104: I $G(DDGFBV) D:'$G(E)
105: . I '$P(^DIST(.403,+DDGFFM,40,DDGFPG,0),U,2),'$O(^(40,0)) S DDGFEBV=1
106: . S DDGFBDEL=1
107: E D PG^DDGFLOAD(+DDGFFM,+DDGFPG,1,1)
108: ;
109: ;If used on no other forms, ask whether to delete from block file
110: I '$O(^DIST(.403,"AB",B,"")),'$O(^DIST(.403,"AC",B,"")) D
111: . K DDGFANS S DDGFBK=B
112: . D DDS(.404,"[DDGF BLOCK DELETE]")
113: . I $G(DDGFANS) S DIK="^DIST(.404,",DA=DDGFBK D ^DIK K DIK,DA
114: . K DDGFANS,DDGFBK
115: Q
116: ;
117: DDS(DDSFILE,DR,DA,DDSPAGE) ;
118: ;Call DDS
119: S DDSPARM="KTW" D ^DDS K DDSPARM
120: Q
121: ;
122: RC(DDGFY,DDGFX) ;Update status line, reset DX and DY, move cursor
123: N S
124: I DDGFR D
125: . S DY=IOSL-6,DX=IOM-9,S="R"_(DDGFY+1)_",C"_(DDGFX+1)
126: . X IOXY W S_$J("",7-$L(S))
127: S DY=DDGFY,DX=DDGFX X IOXY
128: Q
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>