File:  [Coherent Logic Development] / freem_fileman / USER / DDGFEL.m
Revision 1.1: download - view: text, annotated - select for diffs
Mon Apr 28 14:13:19 2025 UTC (3 months ago) by snw
Branches: MAIN
CVS tags: HEAD
Restructure repository

    1: DDGFEL	;SFISC/MKO-SELECT OR EDIT ELEMENT ;02:53 PM  12 Oct 1994
    2: 	;;21.0;VA FileMan;;Dec 28, 1994
    3: 	;Per VHA Directive 10-93-142, this routine should not be modified.
    4: 	;
    5: SELECT	;Select an element
    6: 	N B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2
    7: 	D GETELEM(DY,DX) Q:$G(F)=""
    8: 	;
    9: 	I F="P" G ^DDGFAPC
   10: 	;
   11: 	;Clear and/or kill portions of DDGFREF
   12: 	S:T="D" $P(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=""
   13: 	K:T="C" @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C"),@DDGFREF@("F",DDGFPG,B,F)
   14: 	K:$D(D) @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F,"D")
   15: 	;
   16: 	D COVER
   17: 	G ^DDGF2
   18: 	;
   19: EDIT	;Edit a caption or data length
   20: 	N B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2,X,Y
   21: 	D GETELEM(DY,DX) Q:"P"[$G(F)
   22: 	;
   23: 	S DDGFCHG=1
   24: 	I T="C" D
   25: 	. K D,D1,D2,D3,L
   26: 	. S $P(@DDGFREF@("F",DDGFPG,B,F),U,1,4)="^^^"
   27: 	. K @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C")
   28: 	. D COVER
   29: 	. D
   30: 	.. N DX,DY
   31: 	.. S DY=IOSL-6,DX=IOM-9 X IOXY W "EDIT   "
   32: 	. ;
   33: 	. N DDGFCOD,DDGFX
   34: 	. D EN^DIR0(C1,C2,$L(C),1,C,"","","","KWT",.DDGFX,.DDGFCOD)
   35: 	. S X=DDGFX
   36: 	. I $P(DDGFCOD,U)="TO" W $C(7) S X=C
   37: 	. S:X["^" X=C
   38: 	. S C3=C2+$L(X)-1
   39: 	. ;
   40: 	. S @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C")=""
   41: 	. D WRITE^DDGLIBW(DDGFWID,X,C1-P1,C2-P2)
   42: 	. I $L(X)<$L(C) D REPAINT^DDGLIBW(DDGFWID,(C1-P1)_U_(C3+1-P2)_U_1_U_($L(C)-$L(X)))
   43: 	. S $P(@DDGFREF@("F",DDGFPG,B,F),U,1,4)=C1_U_C2_U_C3_U_X,$P(^(F),U,9)=1
   44: 	;
   45: 	I T="D" D
   46: 	. K C,C1,C2,C3
   47: 	. S $P(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=""
   48: 	. K @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F)
   49: 	. D COVER,^DDGFADL
   50: 	. ;
   51: 	. S $P(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=D1_U_D2_U_D3_U_L,$P(^(F),U,9)=1
   52: 	. S @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F,"D")=""
   53: 	. D WRITE^DDGLIBW(DDGFWID,D,D1-P1,D2-P2)
   54: 	;
   55: 	D RC(DY,DX)
   56: 	Q
   57: 	;
   58: GETELEM(DY,DX)	;Which element is the cursor on
   59: 	;Returns P,B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2
   60: 	;If on pop-up page border, return only B="P",F="P",T="PTOP" or "PBRC"
   61: 	;Set P=page,B=Block,F=DDO,T=type ("D" or "C")
   62: 	;If cursor is not on anything, $G(F)=""
   63: 	;
   64: 	Q:'$D(@DDGFREF@("RC",DDGFWID,DY))
   65: 	N X1,X2,F1
   66: 	S X1="" K F
   67: 	F  S X1=$O(@DDGFREF@("RC",DDGFWID,DY,X1)) Q:X1=""!(DX<X1)  D
   68: 	. S X2=""
   69: 	. F  S X2=$O(@DDGFREF@("RC",DDGFWID,DY,X1,X2)) Q:X2=""  D  Q:$G(F)
   70: 	.. Q:DX>X2
   71: 	.. S B=$O(@DDGFREF@("RC",DDGFWID,DY,X1,X2,""))
   72: 	.. S F=$O(@DDGFREF@("RC",DDGFWID,DY,X1,X2,B,""))
   73: 	.. S T=$O(@DDGFREF@("RC",DDGFWID,DY,X1,X2,B,F,""))
   74: 	Q:"P"[$G(F)
   75: 	;
   76: 	S P1=$P(DDGFLIM,U),P2=$P(DDGFLIM,U,2)
   77: 	S F1=$G(@DDGFREF@("F",DDGFPG,B,F))
   78: 	;
   79: 	;Get caption, data, and coordinates
   80: 	S C1=$P(F1,U),C2=$P(F1,U,2),C3=$P(F1,U,3),C=$P(F1,U,4)
   81: 	I $P(F1,U,8)]"" D
   82: 	. S D1=$P(F1,U,5),D2=$P(F1,U,6),D3=$P(F1,U,7)
   83: 	. S L=$P(F1,U,8),D=$TR($J("",L)," ","_")
   84: 	Q
   85: 	;
   86: COVER	;Look for covered (hidden) fields
   87: 	;Input:
   88: 	; T,C,C1,C2,P1,P2
   89: 	;H(DDO) - array of hidden fields
   90: 	;Erase the element we've selected from buffer
   91: 	;Redraw the element(s) that were covered
   92: 	N H,O,X1,X2,Y
   93: 	F Y="C1","D1" D
   94: 	. I Y="C1",T'="C" Q
   95: 	. I Y="D1",'$D(D) Q
   96: 	. S X1=""
   97: 	. F  S X1=$O(@DDGFREF@("RC",DDGFWID,@Y,X1)) Q:X1=""  D
   98: 	.. S X2=""
   99: 	.. F  S X2=$O(@DDGFREF@("RC",DDGFWID,@Y,X1,X2)) Q:X2=""  D
  100: 	... N B
  101: 	... S B=$O(@DDGFREF@("RC",DDGFWID,@Y,X1,X2,""))
  102: 	... S O=$O(@DDGFREF@("RC",DDGFWID,@Y,X1,X2,B,""))
  103: 	... I O]"",$D(H(O))[0 D
  104: 	.... I T="C",$$OVERLAP(C2,C3,X1,X2) S H(O)=DDGFPG_U_B
  105: 	.... E  I $D(D),$$OVERLAP(D2,D3,X1,X2) S H(O)=DDGFPG_U_B
  106: 	;
  107: 	;Clear in buffer area occupied by element(s) selected
  108: 	D:T="C" CLEAR(C,C1,C2,C3)
  109: 	D:$D(D) CLEAR(D,D1,D2,D3)
  110: 	;
  111: 	;Write to buffer the overlapped field(s)
  112: 	I $D(H) S H="" F  S H=$O(H(H)) Q:H=""  D
  113: 	. S O=$G(@DDGFREF@("F",$P(H(H),U),$P(H(H),U,2),H)) Q:O=""
  114: 	. D WRITE^DDGLIBW(DDGFWID,$P(O,U,4),$P(O,U)-P1,$P(O,U,2)-P2,"",1)
  115: 	. I $P(O,U,8)>0 D WRITE^DDGLIBW(DDGFWID,$TR($J("",$P(O,U,8))," ","_"),$P(O,U,5)-P1,$P(O,U,6)-P2,"",1)
  116: 	Q
  117: 	;
  118: OVERLAP(A1,A2,B1,B2)	;Does line with X-coords A1,A2 overlap B1,B2
  119: 	N T
  120: 	I A1<B1 S T=A1,A1=B1,B1=T,T=A2,A2=B2,B2=T
  121: 	Q A1'<B1&(A1'>B2)!(A2'<B1&(A2'>B2))
  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
  130: 	;
  131: CLEAR(C,C1,C2,C3)	;Clear in buffer area occupied by element(s) selected
  132: 	;If on the page border, redraw the lines
  133: 	N L
  134: 	S L=$J("",$L(C)-$S(C3>$P(DDGFLIM,U,4):C3-$P(DDGFLIM,U,4),1:0))
  135: 	D WRITE^DDGLIBW(DDGFWID,L,C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"",1)
  136: 	;
  137: 	I $P(@DDGFREF@("F",DDGFPG),U,3) D
  138: 	. I C1=$P(DDGFLIM,U)!(C1=$P(DDGFLIM,U,3)) D
  139: 	.. S L=$TR(L," ",$P(DDGLGRA,DDGLDEL,3))
  140: 	.. S:C2=$P(DDGFLIM,U,2) $E(L)=$P(DDGLGRA,DDGLDEL,$S(C1=$P(DDGFLIM,U):5,1:7))
  141: 	.. S:C3'<$P(DDGFLIM,U,4) $E(L,$L(L))=$P(DDGLGRA,DDGLDEL,$S(C1=$P(DDGFLIM,U):6,1:8))
  142: 	.. D WRITE^DDGLIBW(DDGFWID,L,C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"G",1)
  143: 	. E  I C2=$P(DDGFLIM,U,2) D
  144: 	.. D WRITE^DDGLIBW(DDGFWID,$P(DDGLGRA,DDGLDEL,4),C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"G",1)
  145: 	. E  I C3'<$P(DDGFLIM,U,4) D
  146: 	.. D WRITE^DDGLIBW(DDGFWID,$P(DDGLGRA,DDGLDEL,4),C1-$P(DDGFLIM,U),$P(DDGFLIM,U,4)-$P(DDGFLIM,U,2),"G",1)
  147: 	Q

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