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

VALM4.m

Go to the documentation of this file.
  1. VALM4 ;ALB/MJK - Screen Malipulation Utilities ;02/12/2001 13:45
  1. ;;1.0;List Manager;**4,6**;Aug 13, 1993
  1. NEXT ; -- display next screen (NX)
  1. D START
  1. N VALMLSTO,I,LN
  1. I VALMBG+VALM("LINES")>VALMCNT W $C(7) D FINISH Q
  1. S VALMBG=VALMBG+VALM("LINES")
  1. S VALMLSTO=VALMLST
  1. I VALMCC D LST,SCROLL D
  1. . S DY=VALM("BM")-1 D IOXY(0,.DY)
  1. . S I=VALMLSTO+1 F LN=1:1:VALM("LINES") D WRITE(I,1,1,.DY) S I=I+1
  1. . D PLUS,RESET
  1. D PGUPD
  1. D FINISH
  1. Q
  1. PREV ; -- display previous screen (BU)
  1. D START
  1. N I,LN,X,Y,VALMBGO
  1. I VALMBG=1 W $C(7) D FINISH Q
  1. S Y=VALMBG-VALM("LINES")
  1. S VALMBGO=VALMBG,VALMBG=$S(Y<1:1,1:Y)
  1. I VALMCC D LST,SCROLL D
  1. . S DY=VALM("TM")-1
  1. . S I=VALMBGO-1 F LN=1:1:VALM("LINES") D IOIL(0,.DY),WRITE(I,0,1,.DY) Q:I=1 S I=I-1
  1. . D PLUS,RESET
  1. D PGUPD
  1. D FINISH
  1. Q
  1. FIRST ; -- display first screen (FS)
  1. D START
  1. I VALMBG=1 W $C(7) D FINISH Q
  1. S VALMBG=1
  1. I VALMCC D LST,PAINT
  1. D PGUPD
  1. D FINISH
  1. Q
  1. LAST ; -- display last screen (LS)
  1. D START
  1. N Y,I
  1. I VALMCNT'>VALM("LINES") W $C(7) D FINISH Q
  1. ; first line of the last screen :=
  1. ; (# of full screens less 1 if last screen is also full) x # lines per screen) + 1 line
  1. S Y=(((VALMCNT\VALM("LINES"))-'(VALMCNT#VALM("LINES")))*VALM("LINES"))+1
  1. I Y=VALMBG W $C(7) D FINISH Q
  1. S VALMBG=Y
  1. I VALMCC D LST,PAINT
  1. D PGUPD
  1. D FINISH
  1. Q
  1. START ; -- start action tasks
  1. S:VALMMENU VALMDY=""
  1. W VALMCOFF
  1. Q
  1. FINISH ; -- finish action tasks
  1. S VALMBCK=$S(VALMCC:"",1:"R")
  1. W VALMCON
  1. Q
  1. PAINT ;
  1. N I,LN,X D SCROLL
  1. I $E(IOST,1,4)="C-VT" S DY=VALM("TM")-1 D IOXY(0,.DY) W *27,*91,VALM("LINES"),*77
  1. S I=VALMBG F LN=1:1:VALM("LINES") S DY=VALM("TM")+LN-2 D IOIL(0,.DY),WRITE(I,0,1,.DY) S I=I+1
  1. D PLUS,RESET
  1. Q
  1. IOIL(DX,DY) ; -- position cursor ; insert line ; cr
  1. W ! X IOXY W IOIL,$C(13)
  1. Q
  1. IOXY(DX,DY) ; -- position cursor and tell os
  1. X IOXY ;,VALMIOXY
  1. Q
  1. RE ; -- re-display current screen (RE)
  1. D REFRESH^VALM S VALMBCK=""
  1. Q
  1. RESET ; -- reset scrolling region to bottom of screen
  1. I '$D(VALMDY) D IOXY(0,VALM("BM")+1) W IOEDEOP
  1. S IOTM=VALM("BM")+2,IOBM=IOSL W IOSC W @IOSTBM W IORC
  1. D UND($$HTE^XLFDT($H,1),31+((VALMWD-80)/2),1,21,.IOUON,.IOUOFF,0)
  1. I $D(VALMBCK) D IOXY(0,VALM("BM"))
  1. Q
  1. SCROLL ; -- set scrolling region to list area
  1. S IOTM=VALM("TM"),IOBM=VALM("BM") W IOSC W @IOSTBM W IORC
  1. Q
  1. LST ; -- compute last line on screen
  1. N I
  1. S I=VALMBG+VALM("LINES")-1,VALMLST=$S($D(@VALMAR@(I,0)):I,1:VALMCNT)
  1. Q
  1. WRITE(LINE,LF,CTRL,DY) ;
  1. N TEXT
  1. ;S LINE=+$$GET(LINE)
  1. S TEXT=$$EXTRACT($G(@VALMAR@(LINE,0))),DX=VALMWD
  1. I TEXT?.E1C.E S TEXT=$$CTRL^XMXUTIL1(TEXT)
  1. W:LF !
  1. ; -- write text if no formatting needed or allowed
  1. I 'CTRL!('$O(^TMP("VALM VIDEO",$J,VALMEVL,LINE,0)))!('VALMCC) W TEXT Q
  1. D:VALM("FIXED") FORMAT(.LINE,.TEXT,0,0,1,VALM("FIXED"),.DY)
  1. D FORMAT(.LINE,.TEXT,VALM("FIXED"),VALM("FIXED"),VALMLFT,VALMWD,.DY)
  1. Q
  1. FORMAT(LINE,TEXT,FIXED,PREVCOL,TXTLEFT,RMAR,DY) ;
  1. N ATR,WIDTH,COL,LASTCOL,FIN,CRTLCOL
  1. S COL=0,FIN=0
  1. ; -- scan for attributes
  1. F Q:FIN S COL=$O(^TMP("VALM VIDEO",$J,VALMEVL,LINE,COL)) Q:'COL S WIDTH="" F S WIDTH=$O(^TMP("VALM VIDEO",$J,VALMEVL,LINE,COL,WIDTH)) Q:WIDTH="" S ATR=^(WIDTH) D Q:FIN
  1. . I TXTLEFT>(COL+WIDTH-1) Q
  1. . S CTRLCOL=COL-TXTLEFT+FIXED
  1. . S:CTRLCOL<(PREVCOL+1) CTRLCOL=PREVCOL
  1. . S:CTRLCOL'<RMAR CTRLCOL=RMAR,FIN=1
  1. . W $E(TEXT,PREVCOL+1,CTRLCOL) S PREVCOL=CTRLCOL
  1. . W $C(13)_ATR_$C(13) D IOXY(.CTRLCOL,.DY)
  1. I PREVCOL<RMAR W $E(TEXT,PREVCOL+1,RMAR)
  1. W $C(13)_VALMSGR_$C(13) D IOXY(.RMAR,.DY)
  1. Q
  1. EXTRACT(X) ; -- extract string
  1. Q $S(X="":X,1:$E($E(X,1,+VALM("FIXED"))_$E(X,VALMLFT,VALMLFT+VALMWD-1-VALM("FIXED"))_$J("",VALMWD),1,VALMWD))
  1. GET(LNUM) ; -- get actual line number (may be different if indexed)
  1. Q $S(VALM(0)["I":$G(@VALMIDX@(LNUM)),1:LNUM)
  1. PLUS ; -- add plus indicators to screen
  1. N UP,DN
  1. W $C(13) ; -- needed to prevent extra LF's after FORMAT loops
  1. S UP=(VALMBG'=1),DN=$S('$D(VALMLST):0,VALM(0)["I":$O(@VALMIDX@(+VALMLST))>0,1:$O(@VALMAR@(+VALMLST))>0)
  1. I UP'=VALMUP S VALMUP=UP D UND($S(UP:"+",1:" "),1,VALM("TM")-1,1,.IOUON,.IOUOFF,0)
  1. I DN'=VALMDN S VALMDN=DN D UND($S(DN:"+",1:" "),1,VALM("BM")+1,1,.IORVON,.IORVOFF,0)
  1. Q
  1. PGUPD ; -- update page var and screen
  1. N P
  1. S P=$$PAGE(VALMBG,VALM("LINES")) Q:P=VALMPGE
  1. S VALMPGE=P
  1. D:VALMCC UND($J(P,4),VALMWD-12,1,4,.IOUON,.IOUOFF,0)
  1. Q
  1. PAGE(BEG,LINES) ; -- calc page #
  1. S BEG=$S($D(@VALMAR@(BEG,0)):BEG,1:0)
  1. Q (BEG\LINES)+((BEG#LINES)>0)
  1. UND(STR,X,Y,LEN,ON,OFF,ERASE) ;
  1. W $C(13)_ON_$C(13) D INSTR^VALM1(STR,X,Y,LEN,+$G(ERASE)) W $C(13)_OFF_$C(13)
  1. Q