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

TIUFA.m

Go to the documentation of this file.
  1. TIUFA ; SLC/MAM - LM Template A (DDEFs By Attribute) INIT ;10/26/95 15:33
  1. ;;1.0;TEXT INTEGRATION UTILITIES;;Jun 20, 1997
  1. ;
  1. EN ; -- main entry point for Options TIUFA SORT DDEFS CLIN/MGR/NATL
  1. ; Requires TIUFWHO, set in above options
  1. N TIUF,TIUFTMPL,TIUFATTR,TIUFAVAL,TIUFSTRT,TIUFVCN1,TIUFXNOD
  1. N TIUFREDO,X,XQORM,TIUFLFT
  1. S TIUFTMPL="A",TIUFREDO=0
  1. N TIUFPRIV D SETUP^TIUFL S:$D(DTOUT) VALMQUIT=1 G:$G(VALMQUIT) ENX
  1. S TIUFXNOD="^^Sort^"
  1. S X=^TMP("TIUF",$J,"SORT")_";ORD(101," D EN^XQOR
  1. G:$D(DTOUT)!'$D(TIUFSTRT) ENX
  1. I TIUFWHO="C" D EN^VALM("TIUFA SORT DDEFS CLIN")
  1. I "MN"[TIUFWHO D EN^VALM("TIUFA SORT DDEFS MGR")
  1. ENX Q
  1. ;
  1. HDR ; -- header code
  1. ; Requires Attribute TIUFATTR as set in protocols TIUF SORT BY (ALL,
  1. ;TYPE, OWNER, STATUS, WAY USED, PARENTAGE):
  1. ; TIUFATTR = A^ALL, T^TYPE, O^OWNER, S^STATUS, U^WAY USED, P^PARENTAGE;
  1. ; Requires Attribute Value TIUFAVAL as set in TIUF SORT BY ALL;
  1. ;TIUF TYPE /CLASS,DOCUMENT CLASS,MULTIAUTHOR DC,DOCUMENT,COMPONENT,NONE;
  1. ;TIUF OWNER /CLASS,INDIVIDUAL,PERSONAL,NONE; TIUF STATUS /INACTIVE,
  1. ;TEST,ACTIVE,NONE; TIUF USED BY DOCMTS/YES,NO,NA,UNKNOWN; TIUF PARENTAGE/ORPHAN,NONORPHAN.
  1. ; e.g. TIUFAVAL =
  1. ; ALL^ALL if attribute is ALL;
  1. ; CL^CLASS if attribute is Type and Type is Class;
  1. ; NONE^NONE if attr is Type and attr value is NONE.
  1. ; 546^PROVIDER^C if attr is Owner, Kind of Owner is Class Owner,
  1. ; and Class Owner is Provider Class (IFN 546).
  1. ; 0^NONE if attr is Owner, attr value is NONE.
  1. ; 13^INACTIVE if attr is Status and Status is Inactive (IFN 13).
  1. ; 0^NONE if attr is Owner and Owner is NONE.
  1. ; YES if attr is Way Used and Way Used is YES:
  1. ; YES/NO/NA
  1. ; O^ORPHAN if attr is ORPHAN and attr value is Orphan.
  1. ; N^NONORPHAN if attr is ORPHAN and attr value is Nonorphan.
  1. ; Requires TIUFSTRT = e.g. " ^ZZZZZZZZ" as set in SELSTART^TIUFLA.
  1. N ATTR1,HDR2,MODE,OWN,FROM,TO,HDR3,VHDR1,VHDR2
  1. S ATTR1=$P(TIUFATTR,U)
  1. I ATTR1="T" S HDR2=$S($P(TIUFAVAL,U)'="NONE":" of Type "_$P(TIUFAVAL,U,2),1:" with NO Type")
  1. I ATTR1="O" S MODE=$P(TIUFAVAL,U,3),OWN=$P(TIUFAVAL,U,2) D
  1. . S HDR2=$S(MODE="P":" Personally Owned by "_OWN,MODE="C":" Owned by Class "_OWN,MODE="I":" Owned by Individual "_OWN,1:" with No Owner")
  1. I ATTR1="S" S HDR2=$S($P(TIUFAVAL,U)'="N":" of Status "_$P(TIUFAVAL,U,2),1:" with NO Status")
  1. S FROM=$S($P(TIUFSTRT,U)=" ":"FIRST",1:$P(TIUFSTRT,U))
  1. S TO=$S($P(TIUFSTRT,U)=" ":"LAST",$P(TIUFSTRT,U,2)="ZZZZZZZZ":"LAST",1:$P(TIUFSTRT,U,2))
  1. S HDR3=$S(TIUFSTRT'=" ^ZZZZZZZZ":" from "_FROM_" to "_TO,1:"")
  1. I ATTR1="U" S MODE=TIUFAVAL D
  1. . S HDR2=$S(MODE="YES":" In Use",1:" NOT In Use")
  1. . I HDR3'="" S HDR2=HDR2_","
  1. I ATTR1="P" S HDR2=$S($P(TIUFAVAL,U)="O":" which are ORPHANS",1:" which are NOT ORPHANS")
  1. I "TOSUP"[ATTR1 S VALMHDR(1)=$$CENTER^TIUFL("Entries"_HDR2_HDR3,79)
  1. I ATTR1="A" S VALMHDR(1)=$$CENTER^TIUFL("ALL Entries"_$S(HDR3'="":", "_HDR3,1:""),79)
  1. HDRX ;
  1. Q
  1. ;
  1. INIT ; -- init variables and list array. Called by Templates A and J AND by Subtemplates.
  1. ; Requires TIUFATTR, TIUFAVAL, TIUFSTRT. See HDR^TIUFA
  1. K ^TMP("TIUF1",$J),^TMP("TIUF1IDX",$J),^TMP("TIUFB",$J),^TMP("TIUFBIDX",$J)
  1. I '$D(TIUFSTMP) D CLEAN^VALM10 ; Clean IF called from active Template.
  1. N LINENO,STRTNM,ENDNM,FILEDA,NAME,PASTEND
  1. I '$D(TIUFSTMP) S VALM("TITLE")=$S(TIUFTMPL="J":"Objects",$P(TIUFATTR,U)'="A":"Sort by "_$S($P(TIUFATTR,U,2)="WAY USED":"IN USE Value",1:$P(TIUFATTR,U,2)),1:"ALL Document Definitions")
  1. S (TIUFVCN1,LINENO)=0,STRTNM=$P(TIUFSTRT,U),ENDNM=$P(TIUFSTRT,U,2)
  1. I $O(^TIU(8925.1,"B",STRTNM,"")) D
  1. . S FILEDA=""
  1. . F S FILEDA=$O(^TIU(8925.1,"B",STRTNM,FILEDA)) Q:'FILEDA D INIT1
  1. G:$D(DTOUT) INITX
  1. S NAME=STRTNM
  1. F S NAME=$O(^TIU(8925.1,"B",NAME)) Q:NAME="" D Q:$G(PASTEND) G:$D(DTOUT) INITX
  1. . I NAME]ENDNM S PASTEND=1 Q
  1. . S FILEDA=""
  1. . F S FILEDA=$O(^TIU(8925.1,"B",NAME,FILEDA)) Q:'FILEDA D INIT1
  1. . Q
  1. I LINENO D UPDATE^TIUFLLM1("A",LINENO,0) S TIUFVCN1=TIUFVCN1+LINENO
  1. INITX ;
  1. S:$D(DTOUT) VALMQUIT=1
  1. S:'$D(TIUFSTMP) VALMCNT=TIUFVCN1
  1. Q
  1. ;
  1. INIT1 ; Puts FILEDA in Buffer array.
  1. N NODE0,INFO
  1. Q:'$D(^TIU(8925.1,FILEDA,0))
  1. Q:'$$MATCH^TIUFLA(FILEDA)
  1. S LINENO=LINENO+1 ; Needed for NINFO.
  1. D NINFO^TIUFLLM(LINENO,FILEDA,.INFO),PARSE^TIUFLLM(.INFO),NODE0ARR^TIUFLF(FILEDA,.NODE0) Q:$D(DTOUT)
  1. I NODE0="" W !!," Entry "_FILEDA_" in 'B' Cross Reference does not exist in the file; See IRM",! D PAUSE^TIUFXHLX S LINENO=LINENO-1 Q
  1. D BUFENTRY^TIUFLLM2(.INFO,.NODE0,TIUFTMPL) W "."
  1. Q
  1. ;
  1. EXIT ; -- exit code
  1. K ^TMP("TIUF1",$J),^TMP("TIUFB",$J),^TMP("TIUF1IDX",$J),^TMP("TIUFBIDX",$J),^TMP("TIUF",$J),IOELALL
  1. D CLEAN^VALM10
  1. Q
  1. ;