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

DDGFHBK.m

Go to the documentation of this file.
  1. DDGFHBK ;SFISC/MKO-ADD, EDIT, DELETE HEADER BLOCK ;01:48 PM 22 Nov 1994
  1. ;;22.0;VA FileMan;;Mar 30, 1999
  1. ;Per VHA Directive 10-93-142, this routine should not be modified.
  1. ;
  1. ADD ;Add a header block
  1. ;Check to see if a header block already exists for this page
  1. S DDGFBH=$P(^DIST(.403,+DDGFFM,40,DDGFPG,0),U,2)
  1. I DDGFBH D MSG^DDGF($C(7)_"This page already has a header block.") H 2 D MSG^DDGF() K DDGFBH Q
  1. ;
  1. N B
  1. S DDGFDY=DY,DDGFDX=DX
  1. ;
  1. ;Invoke form to enter block name
  1. K DDGFBNUM,DDGFBNAM
  1. D DDS(.404,"[DDGF HEADER BLOCK SELECT]")
  1. G:$G(DDGFBNUM)=DDGFBH!'$G(DDGFBNUM) ADDQ
  1. ;
  1. I $D(^DIST(.403,+DDGFFM,40,DDGFPG,40,"B",DDGFBNUM)) D DDS(.404,"[DDGF BLOCK ADD]","",21) G ADDQ
  1. ;
  1. S $P(^DIST(.403,+DDGFFM,40,DDGFPG,0),U,2)=DDGFBNUM
  1. ;
  1. ;If this looks like a brand new block, stuff in DD number
  1. I $L(^DIST(.404,DDGFBNUM,0),U)=1,'$O(^(0)) D
  1. . S DIE="^DIST(.404,",DA=DDGFBNUM
  1. . S DR="1////"_$P(^DIST(.403,+DDGFFM,0),U,8)
  1. . D ^DIE K DIE,DA,DR
  1. ;
  1. D:DDGFBH DELETE^DDGFBK(DDGFBH,1)
  1. D BK^DDGFLOAD(DDGFPG,DDGFBNUM,$P(DDGFLIM,U),$P(DDGFLIM,U,2),0,0,1,1)
  1. ;
  1. S DY=DDGFDY,DX=DDGFDX
  1. S B=DDGFBNUM,C=$P(@DDGFREF@("F",DDGFPG,B),U,4)
  1. S DDGFADD=1
  1. K DDGFBNUM,DDGFBNAM
  1. G EDIT
  1. ;
  1. ADDQ ;Abort adding a header block
  1. D REFRESH^DDGF,RC(DDGFDY,DDGFDX)
  1. K DDGFANS,DDGFBH,DDGFBNUM,DDGFBNAM,DDGFDY,DDGFDX
  1. Q
  1. ;
  1. EDIT ;Edit/Delete header block
  1. ;In: B,C
  1. N C1,C2,C3
  1. S DDGFDY=DY,DDGFDX=DX,DDGFBH=B
  1. S (DDGFBKNN,DDGFBKNO)=C
  1. S DDSFILE=.403,DDSFILE(1)=.4031,DA(1)=+DDGFFM,DA=DDGFPG
  1. S DR="[DDGF HEADER BLOCK EDIT]",DDSPARM="KTW"
  1. D ^DDS K DDSFILE,DA,DR,DDSPARM
  1. S DDGFBHN=$P(^DIST(.403,+DDGFFM,40,DDGFPG,0),U,2)
  1. ;
  1. I DDGFBHN'=DDGFBH D
  1. . D DELETE^DDGFBK(DDGFBH,DDGFBHN)
  1. . D:DDGFBHN BK^DDGFLOAD(DDGFPG,DDGFBHN,$P(DDGFLIM,U),$P(DDGFLIM,U,2),0,0,1,1)
  1. ;
  1. S C=DDGFBKNN,B=DDGFBHN
  1. ;
  1. ;Update TMP if coordinates or name changed, or new block
  1. I DDGFBKNN'=DDGFBKNO!$G(DDGFADD) D
  1. . D WRITE^DDGLIBW(DDGFWIDB,$J("",$L(DDGFBKNO)),$P(DDGFLIM,U),$P(DDGFLIM,U,2),"",1)
  1. . D WRITE^DDGLIBW(DDGFWIDB,C,$P(DDGFLIM,U),$P(DDGFLIM,U,2),"",1)
  1. ;
  1. D REFRESH^DDGF,RC(DDGFDY,DDGFDX)
  1. S:'$G(DDGFADD) DDGFE=1
  1. K DDGFADD,DDGFBH,DDGFBHN,DDGFBKNN,DDGFBKNO,DDGFDY,DDGFDX
  1. Q
  1. ;
  1. DDS(DDSFILE,DR,DA,DDSPAGE) ;
  1. ;Call DDS
  1. S DDSPARM="KTW" D ^DDS K DDSPARM
  1. Q
  1. ;
  1. RC(DDGFY,DDGFX) ;Update status line, reset DX and DY, move cursor
  1. N S
  1. I DDGFR D
  1. . S DY=IOSL-6,DX=IOM-9,S="R"_(DDGFY+1)_",C"_(DDGFX+1)
  1. . X IOXY W S_$J("",7-$L(S))
  1. S DY=DDGFY,DX=DDGFX X IOXY
  1. Q