Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: DDBR2

DDBR2.m

Go to the documentation of this file.
  1. DDBR2 ;SFISC/DCL-VA FILEMAN BROWSER ;26AUG2009
  1. ;;22.0;VA FileMan;**162**;Mar 30, 1999;Build 21
  1. ;Per VHA Directive 2004-038, this routine should not be modified.
  1. Q
  1. SWITCH(DDBLST,DDBRET) ;Switch to another document in list or FileMan Database
  1. I $E(DDBSA,1,11)="^DI(.84,920" D EXIT^DDBR0 Q ;!(DDBSA="^XTMP(""DDBDOC"")") Q
  1. I DDBSA=$NA(^TMP("DDWB",$J)) G EXIT^DDBR0:$G(DDBRET)["R",SWITCH^DDBRWB Q
  1. N DDBLN,DDBZ,DIC,DIR,X,Y,DIRUT,DIROUT,DUOUT,DILN
  1. S DILN=DDBRSA(DDBRSA,"DDBSRL")-2
  1. S:$G(DDBLST)="" DDBLST="^TMP(""DDBLST"",$J)" S DDBLN=$S($D(@DDBLST@("A",DDBSA)):^(DDBSA),1:$O(@DDBLST@(" "),-1)+1)
  1. I DDBFLG["R",'$D(@DDBLST) D SFR() G PS
  1. I DDBFLG["A" D SFR() G PS
  1. I $G(DDBRET)["R" D G:$G(Y) PS Q
  1. .Q:DDBPSA'>0
  1. .Q:'$D(@DDBLST@("APSA",DDBPSA)) S X=^(DDBPSA) S:$D(@DDBLST@("A",X)) Y=^(X)
  1. .I $G(Y) S DDBPSA=DDBPSA-1 N DDBPSA D SAVEDDB(DDBLST,DDBLN),USAVEDDB(DDBLST,+Y)
  1. .Q
  1. BRMC D BRM
  1. I $D(@DDBLST) D
  1. .I $O(@DDBLST@(" "),-1)=1,$G(@DDBLST@(1,"DDBSA"))=DDBSA Q
  1. .;W "Current list: ",!
  1. .S DDBZ=$G(@DDBLST@("A",DDBSA),0)
  1. .;S X=0 F S X=$O(@DDBLST@(X)) Q:X'>0 W:X'=DDBZ !,$J(X,3)," ",$E(@DDBLST@(X,0),1,75)
  1. .W !
  1. .K DIR0
  1. .;S DIR(0)="Y",DIR("A")="Do you wish to select from current list? ",DIR("B")="YES" D ^DIR,SFR("to Current List"):Y=0&(DDBFLG["R") Q:$D(DIRUT)!(Y'>0)
  1. .I DDBFLG'["R" S DIR(0)="Y",DIR("A")="Do you wish to select from current list",DIR("B")="YES" D ^DIR Q:$D(DIRUT)!(Y'>0)
  1. .S DIC=$$OREF^DIQGU(DDBLST),DIC(0)="EMQ",DIC("S")="I +Y'=DDBZ",DIC("W")="W:$E(^(0))=U ^(0)",X="??" D ^DIC ;K DIC("S") Q:Y'>0
  1. .S DIC(0)="AEMQ"
  1. .D ^DIC K DIC("S") Q:Y'>0
  1. .D SAVEDDB(DDBLST,DDBLN),USAVEDDB(DDBLST,+Y)
  1. .S DIROUT=1
  1. N DDBLNA
  1. S:DDBFLG["R" DIROUT=1
  1. I '$D(DIROUT) D LIST^DDBR3(.DDBLNA)
  1. I $G(DDBLNA,-1)=-1 G PS
  1. I $G(DDBLNA(6))=DDBSA G PS ;if current document selected again
  1. I $G(DDBLNA(6))]"",$D(@DDBLST@("APSA",DDBSA)) G PS ;if already in list
  1. I DDBLNA'>0 W $C(7),!!,"** NO TEXT** ",DDBLNA(5) H 3
  1. D:DDBLNA>0 SAVEDDB(DDBLST,DDBLN),WP(.DDBLNA)
  1. PS D PSR^DDBR0(1)
  1. Q
  1. ;
  1. WP(DDBX) ;
  1. S DDBSA=DDBX(6)
  1. S DDBPMSG=DDBX(5)
  1. S DDBHDR=$$CTXT^DDBR(DDBPMSG,$J("",IOM+1),IOM)
  1. S DDBTL=$P(@DDBSA@(0),"^",3)
  1. S DDBTPG=DDBTL\DDBSRL+(DDBTL#DDBSRL'<1)
  1. S DDBZN=1
  1. S DDBDM=0
  1. S DDBSF=1
  1. S DDBST=IOM
  1. S DDBC="^TMP(""DDBC"",""DDBC"",$J)"
  1. I '$D(@DDBC) F I=1,22:22:176 S @DDBC@(I)=""
  1. S DDBL=0
  1. Q
  1. ;
  1. SAVEDDB(DDBLIST,IEN,NSAPSA) ;Save local varialbes into ^TMP("DDBLIST",$J,IEN)
  1. ;DDBS array to save list
  1. ;IEN internal entry
  1. ;NSAPSA Not Set "APSA" x-ref if undefined, pass 1 to not set NSAPSA (optional - default is to set "APSA")
  1. S NSAPSA=+$G(NSAPSA)
  1. N I,X
  1. F I="HDR","HDRC","SA","ZN","DM","PMSG","L","C","TL","SF","ST","RE","RPE" S X="DDB"_I,@DDBLIST@(IEN,X)=@X
  1. ;I $D(DDBFNO) S @DDBLIST@(IEN,DDBFNO)=DDBFNO ;decided to keep it the same throughout the browse session (Next Find String)
  1. S @DDBLIST@(IEN,0)=DDBPMSG
  1. S:'$D(@DDBLIST@(0)) ^(0)="CURRENT LIST^1"
  1. S:'$D(@DDBLIST@("A",DDBSA)) @DDBLIST@("A",DDBSA)=IEN
  1. S:'$D(@DDBLIST@("B",DDBPMSG,IEN)) @DDBLIST@("B",DDBPMSG,IEN)=""
  1. I $G(DDBRET)["R",DDBRPE=DDBRE Q
  1. Q:NSAPSA
  1. S X=$O(@DDBLST@("APSA"," "),-1)+1
  1. I $G(@DDBLIST@("APSA",X-1))=DDBSA S DDBPSA=X-1 Q
  1. S @DDBLIST@("APSA",X)=DDBSA,DDBPSA=X
  1. Q
  1. ;
  1. USAVEDDB(DDBLIST,IEN) ;Unsave varialbes in ^TMP("DDBLIST",$J,IEN) to locals
  1. ;DDBS array to save list
  1. ;IEN internal entry
  1. N I,X
  1. F I="HDR","HDRC","SA","ZN","DM","PMSG","L","C","TL","SF","ST","RE","RPE" S X="DDB"_I,@X=@DDBLIST@(IEN,X)
  1. S DDBTPG=DDBTL\DDBSRL+(DDBTL#DDBSRL'<1)
  1. ;I $D(@DDBLIST@(IEN,"DDBFNO")) S DDBFNO=@DDBLIST@(IEN,"DDBFNO")
  1. Q
  1. ;
  1. ;
  1. CTXT(X,T,W) ;Center X in T which is W characters wide (usually spaces) and W for screen width
  1. Q:X="" $G(T)
  1. N HW
  1. S W=$G(W,79),HW=W\2
  1. S $E(T,HW-($L(X)\2),HW-($L(X)\2)+$L(X))=X Q T
  1. OREF(X) N X1,X2 S X1=$P(X,"(")_"(",X2=$$OR2($P(X,"(",2)) Q:X2="" X1 Q X1_X2_","
  1. OR2(%) Q:%=")"!(%=",") "" Q:$L(%)=1 % S:"),"[$E(%,$L(%)) %=$E(%,1,$L(%)-1) Q %
  1. ;
  1. BRM ;BROWSE MANAGER SCREEN
  1. N DX,DY,X
  1. S DX=0,DY=$P(DDBSY,";"),X=$$CTXT^DDBR("BROWSE SWITCH MANAGER",$J("",IOM+1),IOM)
  1. X IOXY
  1. W $P(DDGLVID,DDGLDEL,6) ;rvon
  1. W $P(DDGLVID,DDGLDEL,4) ;uon
  1. W X
  1. W $P(DDGLVID,DDGLDEL,10) ;rvoff
  1. F DY=$P(DDBSY,";",2):1:$P(DDBSY,";",4) X IOXY W $P(DDGLCLR,DDGLDEL)
  1. W $P(DDGLVID,DDGLDEL,6) ;rvon
  1. W $P(DDGLVID,DDGLDEL,4) ;uon
  1. W X
  1. W $P(DDGLVID,DDGLDEL,10) ;rvoff
  1. W @IOSTBM
  1. S DY=$P(DDBSY,";",2)
  1. X IOXY
  1. Q
  1. ;
  1. SFR(Y) N X
  1. S X(1)="",X(2)=$$CTXT^DDBR("<< SWITCH Function Restricted "_$G(Y)_" >>","",IOM)
  1. W $$WS^DDBR1(.X),$C(7)
  1. R X:3
  1. Q