DDGFEL ;SFISC/MKO-SELECT OR EDIT ELEMENT ;07:25 AM 7 Aug 1995
;;22.2;VA FileMan;;Jan 05, 2016;Build 42
;;Per VA Directive 6402, this routine should not be modified.
;;Submitted to OSEHRA 5 January 2015 by the VISTA Expertise Network.
;;Based on Medsphere Systems Corporation's MSC FileMan 1051.
;;Licensed under the terms of the Apache License, Version 2.0.
;
SELECT ;Select an element
N B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2
D GETELEM(DY,DX) Q:$G(F)=""
;
I F="P" G ^DDGFAPC
;
;Clear and/or kill portions of DDGFREF
S:T="D" $P(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=""
K:T="C" @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C"),@DDGFREF@("F",DDGFPG,B,F)
K:$D(D) @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F,"D")
;
D COVER
G ^DDGF2
;
EDIT ;Edit a caption or data length
N B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2,X,Y
D GETELEM(DY,DX) Q:"P"[$G(F)
;
S DDGFCHG=1
I T="C" D
. K D,D1,D2,D3,L
. S $P(@DDGFREF@("F",DDGFPG,B,F),U,1,4)="^^^"
. K @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C")
. D COVER
. D
.. N DX,DY
.. S DY=IOSL-6,DX=IOM-9 X IOXY W "EDIT "
. ;
. N DDGFCOD,DDGFX
. D EN^DIR0(C1,C2,$L(C),1,C,"","","","KWT",.DDGFX,.DDGFCOD)
. S X=DDGFX
. I $P(DDGFCOD,U)="TO"!(X="!M") W $C(7) S X=C
. E I X["^" S X=C
. E X $P(^DD(.4044,1,0),U,5,999) I '$D(X) W $C(7) S X=C
. S C3=C2+$L(X)-1
. ;
. S @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C")=""
. D WRITE^DDGLIBW(DDGFWID,X,C1-P1,C2-P2)
. I $L(X)<$L(C) D REPAINT^DDGLIBW(DDGFWID,(C1-P1)_U_(C3+1-P2)_U_1_U_($L(C)-$L(X)))
. S $P(@DDGFREF@("F",DDGFPG,B,F),U,1,4)=C1_U_C2_U_C3_U_X,$P(^(F),U,9)=1
;
I T="D" D
. K C,C1,C2,C3
. S $P(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=""
. K @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F)
. D COVER,^DDGFADL
. ;
. S $P(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=D1_U_D2_U_D3_U_L,$P(^(F),U,9)=1
. S @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F,"D")=""
. D WRITE^DDGLIBW(DDGFWID,D,D1-P1,D2-P2)
;
D RC(DY,DX)
Q
;
GETELEM(DY,DX) ;Which element is the cursor on
;Returns P,B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2
;If on pop-up page border, return only B="P",F="P",T="PTOP" or "PBRC"
;Set P=page,B=Block,F=DDO,T=type ("D" or "C")
;If cursor is not on anything, $G(F)=""
;
Q:'$D(@DDGFREF@("RC",DDGFWID,DY))
N X1,X2,F1
S X1="" K F
F S X1=$O(@DDGFREF@("RC",DDGFWID,DY,X1)) Q:X1=""!(DX<X1) D
. S X2=""
. F S X2=$O(@DDGFREF@("RC",DDGFWID,DY,X1,X2)) Q:X2="" D Q:$G(F)
.. Q:DX>X2
.. S B=$O(@DDGFREF@("RC",DDGFWID,DY,X1,X2,""))
.. S F=$O(@DDGFREF@("RC",DDGFWID,DY,X1,X2,B,""))
.. S T=$O(@DDGFREF@("RC",DDGFWID,DY,X1,X2,B,F,""))
Q:"P"[$G(F)
;
S P1=$P(DDGFLIM,U),P2=$P(DDGFLIM,U,2)
S F1=$G(@DDGFREF@("F",DDGFPG,B,F))
;
;Get caption, data, and coordinates
S C1=$P(F1,U),C2=$P(F1,U,2),C3=$P(F1,U,3),C=$P(F1,U,4)
I $P(F1,U,8)]"" D
. S D1=$P(F1,U,5),D2=$P(F1,U,6),D3=$P(F1,U,7)
. S L=$P(F1,U,8),D=$TR($J("",L)," ","_")
Q
;
COVER ;Look for covered (hidden) fields
;Input:
; T,C,C1,C2,P1,P2
;H(DDO) - array of hidden fields
;Erase the element we've selected from buffer
;Redraw the element(s) that were covered
N H,O,X1,X2,Y
F Y="C1","D1" D
. I Y="C1",T'="C" Q
. I Y="D1",'$D(D) Q
. S X1=""
. F S X1=$O(@DDGFREF@("RC",DDGFWID,@Y,X1)) Q:X1="" D
.. S X2=""
.. F S X2=$O(@DDGFREF@("RC",DDGFWID,@Y,X1,X2)) Q:X2="" D
... N B
... S B=$O(@DDGFREF@("RC",DDGFWID,@Y,X1,X2,""))
... S O=$O(@DDGFREF@("RC",DDGFWID,@Y,X1,X2,B,""))
... I O]"",$D(H(O))[0 D
.... I T="C",$$OVERLAP(C2,C3,X1,X2) S H(O)=DDGFPG_U_B
.... E I $D(D),$$OVERLAP(D2,D3,X1,X2) S H(O)=DDGFPG_U_B
;
;Clear in buffer area occupied by element(s) selected
D:T="C" CLEAR(C,C1,C2,C3)
D:$D(D) CLEAR(D,D1,D2,D3)
;
;Write to buffer the overlapped field(s)
I $D(H) S H="" F S H=$O(H(H)) Q:H="" D
. S O=$G(@DDGFREF@("F",$P(H(H),U),$P(H(H),U,2),H)) Q:O=""
. D WRITE^DDGLIBW(DDGFWID,$P(O,U,4),$P(O,U)-P1,$P(O,U,2)-P2,"",1)
. 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)
Q
;
OVERLAP(A1,A2,B1,B2) ;Does line with X-coords A1,A2 overlap B1,B2
N T
I A1<B1 S T=A1,A1=B1,B1=T,T=A2,A2=B2,B2=T
Q A1'<B1&(A1'>B2)!(A2'<B1&(A2'>B2))
;
RC(DDGFY,DDGFX) ;Update status line, reset DX and DY, move cursor
N S
I DDGFR D
. S DY=IOSL-6,DX=IOM-9,S="R"_(DDGFY+1)_",C"_(DDGFX+1)
. X IOXY W S_$J("",7-$L(S))
S DY=DDGFY,DX=DDGFX X IOXY
Q
;
CLEAR(C,C1,C2,C3) ;Clear in buffer area occupied by element(s) selected
;If on the page border, redraw the lines
N L
S L=$J("",$L(C)-$S(C3>$P(DDGFLIM,U,4):C3-$P(DDGFLIM,U,4),1:0))
D WRITE^DDGLIBW(DDGFWID,L,C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"",1)
;
I $P(@DDGFREF@("F",DDGFPG),U,3) D
. I C1=$P(DDGFLIM,U)!(C1=$P(DDGFLIM,U,3)) D
.. S L=$TR(L," ",$P(DDGLGRA,DDGLDEL,3))
.. S:C2=$P(DDGFLIM,U,2) $E(L)=$P(DDGLGRA,DDGLDEL,$S(C1=$P(DDGFLIM,U):5,1:7))
.. S:C3'<$P(DDGFLIM,U,4) $E(L,$L(L))=$P(DDGLGRA,DDGLDEL,$S(C1=$P(DDGFLIM,U):6,1:8))
.. D WRITE^DDGLIBW(DDGFWID,L,C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"G",1)
. E I C2=$P(DDGFLIM,U,2) D
.. D WRITE^DDGLIBW(DDGFWID,$P(DDGLGRA,DDGLDEL,4),C1-$P(DDGFLIM,U),C2-$P(DDGFLIM,U,2),"G",1)
. E I C3'<$P(DDGFLIM,U,4) D
.. D WRITE^DDGLIBW(DDGFWID,$P(DDGLGRA,DDGLDEL,4),C1-$P(DDGFLIM,U),$P(DDGFLIM,U,4)-$P(DDGFLIM,U,2),"G",1)
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HDDGFEL 5251 printed Oct 16, 2024@18:42:54 Page 2
DDGFEL ;SFISC/MKO-SELECT OR EDIT ELEMENT ;07:25 AM 7 Aug 1995
+1 ;;22.2;VA FileMan;;Jan 05, 2016;Build 42
+2 ;;Per VA Directive 6402, this routine should not be modified.
+3 ;;Submitted to OSEHRA 5 January 2015 by the VISTA Expertise Network.
+4 ;;Based on Medsphere Systems Corporation's MSC FileMan 1051.
+5 ;;Licensed under the terms of the Apache License, Version 2.0.
+6 ;
SELECT ;Select an element
+1 NEW B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2
+2 DO GETELEM(DY,DX)
if $GET(F)=""
QUIT
+3 ;
+4 IF F="P"
GOTO ^DDGFAPC
+5 ;
+6 ;Clear and/or kill portions of DDGFREF
+7 if T="D"
SET $PIECE(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=""
+8 if T="C"
KILL @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C"),@DDGFREF@("F",DDGFPG,B,F)
+9 if $DATA(D)
KILL @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F,"D")
+10 ;
+11 DO COVER
+12 GOTO ^DDGF2
+13 ;
EDIT ;Edit a caption or data length
+1 NEW B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2,X,Y
+2 DO GETELEM(DY,DX)
if "P"[$GET(F)
QUIT
+3 ;
+4 SET DDGFCHG=1
+5 IF T="C"
Begin DoDot:1
+6 KILL D,D1,D2,D3,L
+7 SET $PIECE(@DDGFREF@("F",DDGFPG,B,F),U,1,4)="^^^"
+8 KILL @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C")
+9 DO COVER
+10 Begin DoDot:2
+11 NEW DX,DY
+12 SET DY=IOSL-6
SET DX=IOM-9
XECUTE IOXY
WRITE "EDIT "
End DoDot:2
+13 ;
+14 NEW DDGFCOD,DDGFX
+15 DO EN^DIR0(C1,C2,$LENGTH(C),1,C,"","","","KWT",.DDGFX,.DDGFCOD)
+16 SET X=DDGFX
+17 IF $PIECE(DDGFCOD,U)="TO"!(X="!M")
WRITE $CHAR(7)
SET X=C
+18 IF '$TEST
IF X["^"
SET X=C
+19 IF '$TEST
XECUTE $PIECE(^DD(.4044,1,0),U,5,999)
IF '$DATA(X)
WRITE $CHAR(7)
SET X=C
+20 SET C3=C2+$LENGTH(X)-1
+21 ;
+22 SET @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C")=""
+23 DO WRITE^DDGLIBW(DDGFWID,X,C1-P1,C2-P2)
+24 IF $LENGTH(X)<$LENGTH(C)
DO REPAINT^DDGLIBW(DDGFWID,(C1-P1)_U_(C3+1-P2)_U_1_U_($LENGTH(C)-$LENGTH(X)))
+25 SET $PIECE(@DDGFREF@("F",DDGFPG,B,F),U,1,4)=C1_U_C2_U_C3_U_X
SET $PIECE(^(F),U,9)=1
End DoDot:1
+26 ;
+27 IF T="D"
Begin DoDot:1
+28 KILL C,C1,C2,C3
+29 SET $PIECE(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=""
+30 KILL @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F)
+31 DO COVER
DO ^DDGFADL
+32 ;
+33 SET $PIECE(@DDGFREF@("F",DDGFPG,B,F),U,5,8)=D1_U_D2_U_D3_U_L
SET $PIECE(^(F),U,9)=1
+34 SET @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F,"D")=""
+35 DO WRITE^DDGLIBW(DDGFWID,D,D1-P1,D2-P2)
End DoDot:1
+36 ;
+37 DO RC(DY,DX)
+38 QUIT
+39 ;
GETELEM(DY,DX) ;Which element is the cursor on
+1 ;Returns P,B,F,T,C,C1,C2,C3,D,D1,D2,D3,L,P1,P2
+2 ;If on pop-up page border, return only B="P",F="P",T="PTOP" or "PBRC"
+3 ;Set P=page,B=Block,F=DDO,T=type ("D" or "C")
+4 ;If cursor is not on anything, $G(F)=""
+5 ;
+6 if '$DATA(@DDGFREF@("RC",DDGFWID,DY))
QUIT
+7 NEW X1,X2,F1
+8 SET X1=""
KILL F
+9 FOR
SET X1=$ORDER(@DDGFREF@("RC",DDGFWID,DY,X1))
if X1=""!(DX<X1)
QUIT
Begin DoDot:1
+10 SET X2=""
+11 FOR
SET X2=$ORDER(@DDGFREF@("RC",DDGFWID,DY,X1,X2))
if X2=""
QUIT
Begin DoDot:2
+12 if DX>X2
QUIT
+13 SET B=$ORDER(@DDGFREF@("RC",DDGFWID,DY,X1,X2,""))
+14 SET F=$ORDER(@DDGFREF@("RC",DDGFWID,DY,X1,X2,B,""))
+15 SET T=$ORDER(@DDGFREF@("RC",DDGFWID,DY,X1,X2,B,F,""))
End DoDot:2
if $GET(F)
QUIT
End DoDot:1
+16 if "P"[$GET(F)
QUIT
+17 ;
+18 SET P1=$PIECE(DDGFLIM,U)
SET P2=$PIECE(DDGFLIM,U,2)
+19 SET F1=$GET(@DDGFREF@("F",DDGFPG,B,F))
+20 ;
+21 ;Get caption, data, and coordinates
+22 SET C1=$PIECE(F1,U)
SET C2=$PIECE(F1,U,2)
SET C3=$PIECE(F1,U,3)
SET C=$PIECE(F1,U,4)
+23 IF $PIECE(F1,U,8)]""
Begin DoDot:1
+24 SET D1=$PIECE(F1,U,5)
SET D2=$PIECE(F1,U,6)
SET D3=$PIECE(F1,U,7)
+25 SET L=$PIECE(F1,U,8)
SET D=$TRANSLATE($JUSTIFY("",L)," ","_")
End DoDot:1
+26 QUIT
+27 ;
COVER ;Look for covered (hidden) fields
+1 ;Input:
+2 ; T,C,C1,C2,P1,P2
+3 ;H(DDO) - array of hidden fields
+4 ;Erase the element we've selected from buffer
+5 ;Redraw the element(s) that were covered
+6 NEW H,O,X1,X2,Y
+7 FOR Y="C1","D1"
Begin DoDot:1
+8 IF Y="C1"
IF T'="C"
QUIT
+9 IF Y="D1"
IF '$DATA(D)
QUIT
+10 SET X1=""
+11 FOR
SET X1=$ORDER(@DDGFREF@("RC",DDGFWID,@Y,X1))
if X1=""
QUIT
Begin DoDot:2
+12 SET X2=""
+13 FOR
SET X2=$ORDER(@DDGFREF@("RC",DDGFWID,@Y,X1,X2))
if X2=""
QUIT
Begin DoDot:3
+14 NEW B
+15 SET B=$ORDER(@DDGFREF@("RC",DDGFWID,@Y,X1,X2,""))
+16 SET O=$ORDER(@DDGFREF@("RC",DDGFWID,@Y,X1,X2,B,""))
+17 IF O]""
IF $DATA(H(O))[0
Begin DoDot:4
+18 IF T="C"
IF $$OVERLAP(C2,C3,X1,X2)
SET H(O)=DDGFPG_U_B
+19 IF '$TEST
IF $DATA(D)
IF $$OVERLAP(D2,D3,X1,X2)
SET H(O)=DDGFPG_U_B
End DoDot:4
End DoDot:3
End DoDot:2
End DoDot:1
+20 ;
+21 ;Clear in buffer area occupied by element(s) selected
+22 if T="C"
DO CLEAR(C,C1,C2,C3)
+23 if $DATA(D)
DO CLEAR(D,D1,D2,D3)
+24 ;
+25 ;Write to buffer the overlapped field(s)
+26 IF $DATA(H)
SET H=""
FOR
SET H=$ORDER(H(H))
if H=""
QUIT
Begin DoDot:1
+27 SET O=$GET(@DDGFREF@("F",$PIECE(H(H),U),$PIECE(H(H),U,2),H))
if O=""
QUIT
+28 DO WRITE^DDGLIBW(DDGFWID,$PIECE(O,U,4),$PIECE(O,U)-P1,$PIECE(O,U,2)-P2,"",1)
+29 IF $PIECE(O,U,8)>0
DO WRITE^DDGLIBW(DDGFWID,$TRANSLATE($JUSTIFY("",$PIECE(O,U,8))," ","_"),$PIECE(O,U,5)-P1,$PIECE(O,U,6)-P2,"",1)
End DoDot:1
+30 QUIT
+31 ;
OVERLAP(A1,A2,B1,B2) ;Does line with X-coords A1,A2 overlap B1,B2
+1 NEW T
+2 IF A1<B1
SET T=A1
SET A1=B1
SET B1=T
SET T=A2
SET A2=B2
SET B2=T
+3 QUIT A1'<B1&(A1'>B2)!(A2'<B1&(A2'>B2))
+4 ;
RC(DDGFY,DDGFX) ;Update status line, reset DX and DY, move cursor
+1 NEW S
+2 IF DDGFR
Begin DoDot:1
+3 SET DY=IOSL-6
SET DX=IOM-9
SET S="R"_(DDGFY+1)_",C"_(DDGFX+1)
+4 XECUTE IOXY
WRITE S_$JUSTIFY("",7-$LENGTH(S))
End DoDot:1
+5 SET DY=DDGFY
SET DX=DDGFX
XECUTE IOXY
+6 QUIT
+7 ;
CLEAR(C,C1,C2,C3) ;Clear in buffer area occupied by element(s) selected
+1 ;If on the page border, redraw the lines
+2 NEW L
+3 SET L=$JUSTIFY("",$LENGTH(C)-$SELECT(C3>$PIECE(DDGFLIM,U,4):C3-$PIECE(DDGFLIM,U,4),1:0))
+4 DO WRITE^DDGLIBW(DDGFWID,L,C1-$PIECE(DDGFLIM,U),C2-$PIECE(DDGFLIM,U,2),"",1)
+5 ;
+6 IF $PIECE(@DDGFREF@("F",DDGFPG),U,3)
Begin DoDot:1
+7 IF C1=$PIECE(DDGFLIM,U)!(C1=$PIECE(DDGFLIM,U,3))
Begin DoDot:2
+8 SET L=$TRANSLATE(L," ",$PIECE(DDGLGRA,DDGLDEL,3))
+9 if C2=$PIECE(DDGFLIM,U,2)
SET $EXTRACT(L)=$PIECE(DDGLGRA,DDGLDEL,$SELECT(C1=$PIECE(DDGFLIM,U):5,1:7))
+10 if C3'<$PIECE(DDGFLIM,U,4)
SET $EXTRACT(L,$LENGTH(L))=$PIECE(DDGLGRA,DDGLDEL,$SELECT(C1=$PIECE(DDGFLIM,U):6,1:8))
+11 DO WRITE^DDGLIBW(DDGFWID,L,C1-$PIECE(DDGFLIM,U),C2-$PIECE(DDGFLIM,U,2),"G",1)
End DoDot:2
+12 IF '$TEST
IF C2=$PIECE(DDGFLIM,U,2)
Begin DoDot:2
+13 DO WRITE^DDGLIBW(DDGFWID,$PIECE(DDGLGRA,DDGLDEL,4),C1-$PIECE(DDGFLIM,U),C2-$PIECE(DDGFLIM,U,2),"G",1)
End DoDot:2
+14 IF '$TEST
IF C3'<$PIECE(DDGFLIM,U,4)
Begin DoDot:2
+15 DO WRITE^DDGLIBW(DDGFWID,$PIECE(DDGLGRA,DDGLDEL,4),C1-$PIECE(DDGFLIM,U),$PIECE(DDGFLIM,U,4)-$PIECE(DDGFLIM,U,2),"G",1)
End DoDot:2
End DoDot:1
+16 QUIT