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

TIUFPR.m

Go to the documentation of this file.
  1. TIUFPR ;SLC/MAM - Action Print List ;;3/7/00
  1. ;;1.0;TEXT INTEGRATION UTILITIES;**2,8,99**;Jun 20, 1997
  1. ;
  1. CAPTION(RMSUFFIX) ; -- set up caption line of header
  1. N X,COL,FLD
  1. S $P(X," ",TIUF("RM"_RMSUFFIX)+1)=""
  1. S COL="" F S COL=$O(VALMDDF(COL)) Q:COL="" S FLD=VALMDDF(COL) D
  1. .S X=$$SETSTR^VALM1($P(FLD,U,4),X,+$P(FLD,U,2),$S($L($P(FLD,U,4))<$P(FLD,U,3):$L($P(FLD,U,4)),1:+$P(FLD,U,3)))
  1. Q X
  1. ;
  1. TBAR(RMSUFFIX) ; -- print caption/top bar
  1. ; Needs TIUFWD,TIUFCAP,RMSUFFIX
  1. N X
  1. D CRT(0,2)
  1. S TIUFCAP=" "_$E(TIUFCAP,2,TIUF("RM"_RMSUFFIX))
  1. S X=$E(TIUFCAP,1,VALM("FIXED"))_$E(TIUFCAP,VALMLFT,VALMLFT+TIUFWD-1-VALM("FIXED"))
  1. W:"DX"'[$G(TIUFSTMP) ! W X
  1. Q
  1. ;
  1. CRT(DX,DY) ;
  1. I DX'<0,DY'<0,$E(IOST,1,2)="C-" W $C(13) X IOXY
  1. Q
  1. ;
  1. PRTL ; Action Print List. Prints whole list of items, but if Template permits right/left scroll, prints only the present right/left portion of each item.
  1. N DIR,DA,X,Y,TIUFANS,TIUFAR,TIUFCAP,RMSUFFIX,WHO,DTOUT,DIRUT,DIROUT
  1. S WHO=$S(TIUFWHO="N":"M",1:TIUFWHO)
  1. S TIUFAR=$S($G(TIUFSTMP)="D"!($G(TIUFSTMP)="X"):"^TMP(""TIUF3"",$J)",$G(TIUFSTMP)="T":"^TMP(""TIUF2"",$J)",1:"^TMP(""TIUF1"",$J)")
  1. S RMSUFFIX=$S($D(TIUFSTMP):TIUFSTMP,1:TIUFTMPL),RMSUFFIX=RMSUFFIX_$S("TD"'[RMSUFFIX:WHO,1:"")
  1. S TIUFCAP=$$CAPTION(RMSUFFIX)
  1. D:VALMCC FULL^VALM1
  1. S DIR("?",1)="You can print only those columns that appear on this screen, or you can print"
  1. S DIR("?")="ALL columns including those you see by scrolling to the right"
  1. D I $D(DIRUT) G PRTLX
  1. . K DIRUT I $G(TIUFSTMP)="D" S TIUFANS=1 Q
  1. . S DIR(0)="Y",DIR("A")=$S($G(TIUFSTMP)="":"Print Name and Type Only",1:"Print Item and Sequence Only"),DIR("B")="YES"
  1. . I $G(TIUFSTMP)="",VALMLFT=49 D ^DIR S TIUFANS=Y Q
  1. . I $G(TIUFSTMP)="T",VALMLFT=32 D ^DIR S TIUFANS=Y Q
  1. . S TIUFANS=1
  1. S %ZIS="Q" D ^%ZIS I POP G PRTLX
  1. I '$D(IO("Q")),IO=IO(0) D CLEAR^VALM1 S X=0 X ^%ZOSF("RM")
  1. I '$D(IO("Q")) G PRTL1
  1. S ZTRTN="PRTL1^TIUFPR",ZTIO=ION,ZTDESC="TIUF Print List -- List Manager Action"
  1. D SAVE,^%ZTLOAD G PRTLX
  1. ;
  1. PRTL1 ;
  1. N TIUFWD,TIUFPGE,TIUFLNS,TIUFHDR,NOSCRNS,NOPGES,TIUFOFPG,TIUFJ,FIRST,LAST,TIUFESC
  1. S TIUFWD=IOM,TIUFPGE=1,TIUFLNS=IOSL-6
  1. S TIUFHDR=VALMHDR(1),TIUFESC=0
  1. I TIUFANS S NOSCRNS=1
  1. E S NOSCRNS=$S($G(TIUFSTMP)="T":2,1:4)
  1. S NOPGES=$$PAGE(VALMCNT,TIUFLNS),TIUFOFPG=NOPGES*NOSCRNS
  1. U IO
  1. F TIUFJ=1:1:NOPGES D Q:TIUFESC
  1. . S FIRST=TIUFLNS*(TIUFJ-1)+1,LAST=FIRST+TIUFLNS-1
  1. . D COLUMNS(FIRST,LAST,NOSCRNS,.TIUFPGE,RMSUFFIX)
  1. PRTLX S VALMBCK="R" N IOSTBM D ^%ZISC D TERM S X=0 X ^%ZOSF("RM")
  1. I $D(ZTQUEUED) S ZTREQ="@"
  1. I $D(DTOUT) S VALMBCK="Q"
  1. Q
  1. ;
  1. TERM ; -- set up term characteristics
  1. D HOME^%ZIS
  1. S X="IORVON;IORVOFF;IOIL;IOSTBM;IOSC;IORC;IOEDEOP;IOINHI;IOINORM;IOUON;IOUOFF;IOBON;IOBOFF;IOSGR0" D ENDR^%ZISS
  1. Q
  1. ;
  1. COLUMNS(FIRST,LAST,NOSCRNS,TIUFPAGE,RMSUFFIX) ; Writes columns for LM entries FIRST through LAST;
  1. ; Returns the display back to far left before quitting.
  1. ; NOSCRNS = Number of (left/right) screens to be printed (depends on LM Template Right Margin) and on users choice to print all or only first left/right screen.
  1. N TIUFI,LINENO,TEXT
  1. ;TIUFESC is newed in PRTL; DON'T new it here.
  1. S TIUFESC=0
  1. F TIUFI=1:1:NOSCRNS D Q:TIUFESC
  1. . D HDR,TBAR(RMSUFFIX)
  1. . F LINENO=FIRST:1:LAST Q:LINENO>VALMCNT Q:TIUFESC S TEXT=$$EXTRACT($G(@TIUFAR@(LINENO,0))) W !,TEXT
  1. . D FTR
  1. . Q:TIUFESC
  1. . D:NOSCRNS>1 RIGHT^TIUFL1("0^0^PL")
  1. . S TIUFPGE=TIUFPGE+1
  1. . Q
  1. D:NOSCRNS>1 LEFT^TIUFL1("0^0^PL")
  1. Q
  1. ;
  1. EXTRACT(X) ; -- extract string
  1. ; Requires TIUFWD
  1. Q $S(X="":X,1:$E($E(X,1,+VALM("FIXED"))_$E(X,VALMLFT,VALMLFT+TIUFWD-1-VALM("FIXED"))_$J("",TIUFWD),1,TIUFWD))
  1. ;
  1. HDR ; -- prt/display header
  1. ; Requires TIUFHDR, TIUFWD, TIUFPGE, TIUFIOFPG, TIUFAR, TITLE
  1. N X,I,DX,DY,TITLE
  1. ; -- prt hdr line
  1. W @IOF
  1. I $E(IOST,1,2)="C-" S DX=0,DY=0 X IOXY ; -- position cursor
  1. S TITLE=$S('$D(VALM("TITLE")):$E($P(TIUFNOD0,U),1,30),1:VALM("TITLE"))
  1. W $J(" ",30-$L(TITLE))
  1. I $E(IOST,1,2)="C-" W $C(13) S DX=30,DY=0 X IOXY ; -- position cursor
  1. W $J("",((TIUFWD-80)/2)),$$MIXED^TIULS($$NOW^TIULO),$J("",10+((TIUFWD-80)/2)),"Page: ",$J(TIUFPGE,4)," of ",$J(TIUFOFPG,4)
  1. W !,TIUFHDR,!
  1. Q
  1. ;
  1. FTR ; -- footer to print
  1. N PAUSEANS
  1. S TIUFESC=0
  1. I $E(IOST,1,2)="C-" D XPAUSE(.PAUSEANS) S TIUFESC='PAUSEANS
  1. Q
  1. ;
  1. XPAUSE(Y) ; Pause with ^ to exit; omits carriage return that scrolls top line off
  1. N DIR,X,DA
  1. W ! S DIR(0)="E" D ^DIR
  1. Q
  1. ;
  1. PAGE(BEG,LINES) ; -- calc page #
  1. ; Requires TIUFAR
  1. S BEG=$S($D(@TIUFAR@(BEG,0)):BEG,1:0)
  1. Q (BEG\LINES)+((BEG#LINES)>0)
  1. ;
  1. SAVE ; -- save to queue for PRTL
  1. ; TIU*1*99: add VALM(, VALMCC to list:
  1. F X="TIUFSTMP","TIUFTMPL","TIUFXNOD","VALMDDF","TIUFWD","TIUF(","VALM(","VALMCC","VALMLFT","VALMWD","VALMCNT","VALMHDR(","TIUFWHO","TIUFANS","TIUFCAP","RMSUFFIX" S ZTSAVE(X)=""
  1. F X="TIUFAR",$E(TIUFAR,1,$L(TIUFAR)-1)_"," S ZTSAVE(X)=""
  1. Q
  1. ;