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

TIUFH1.m

Go to the documentation of this file.
  1. TIUFH1 ; SLC/MAM - LM Template H (DDEF Hierarchy) Actions Expand/Collapse, Jump to DDEF (EXPDEF(ASK,FILEDA)), EXPAND1(EINFO), COLLAPSE(EINFO) ;10/2/97 21:44
  1. ;;1.0;TEXT INTEGRATION UTILITIES;**11**;Jun 20, 1997
  1. ;
  1. EXPCOLL ; Template A Action Expand/Collapse
  1. N INFO,OXPDLCNT,MISSITEM,FILEDA,MSG,TIUFXNOD,DTOUT,DIRUT,DIROUT
  1. S VALMBCK="R",TIUFXNOD=$G(XQORNOD(0))
  1. D EN^VALM2(TIUFXNOD,"SO") I '$O(VALMY(0)) S VALMBCK="" G EXPCX
  1. S INFO=$G(^TMP("TIUF1IDX",$J,$O(VALMY(0)))) I 'INFO W !!," Missing List Manager Data; See IRM",! D PAUSE^TIUFXHLX S VALMBCK="Q" G EXPCX
  1. S FILEDA=$P(INFO,U,2)
  1. D PARSE^TIUFLLM(.INFO) S OXPDLCNT=INFO("XPDLCNT") ;Old XPDLCNT
  1. I OXPDLCNT D COLLAPSE(.INFO) S VALMCNT=VALMCNT-OXPDLCNT G EXPCX
  1. I '$O(^TIU(8925.1,FILEDA,10,0)) S VALMBCK="",MSG=" Entry has no Items to Expand/Collapse" W !!,MSG,! H 1 G EXPCX
  1. S MISSITEM=$$MISSITEM^TIUFLF4(FILEDA) I MISSITEM W !!," Can't Expand/Collapse: File Entry "_FILEDA_" Has Nonexistent Item "_MISSITEM_"; See IRM.",! D PAUSE^TIUFXHLX S VALMBCK="" G EXPCX
  1. D EXPAND1(.INFO)
  1. S VALMCNT=VALMCNT+INFO("XPDLCNT")
  1. I (+INFO+INFO("XPDLCNT"))>(VALMBG+VALM("LINES")-1) S VALMBG=+INFO
  1. EXPCX I $D(DTOUT) S VALMBCK="Q"
  1. Q
  1. ;
  1. EXPDEF(ASK,FILEDA) ; If ASK, Template H action Jump to Document Def; else Expand to show entry FILEDA
  1. ; Assumes Docmt Def except Shared Components have at most 1 parent
  1. ; Requires ASK=1 to ask which entry to jump to, = 0 to not ask.
  1. ; Requires FILEDA if ASK = 0.
  1. N DIC,X,Y,INFO,NODE0,ORPHAN,PARENT,MSG,OXPDLCNT,TIUJ,ENTRYNO
  1. N EINFO,PFILEDA,MISSITEM,TIUFXNOD,MSG1,LINENO,DTOUT,DIRUT,DIROUT
  1. S TIUFXNOD=$G(XQORNOD(0))
  1. I 'ASK G NOASK
  1. N FILEDA S VALMBCK="R"
  1. D FULL^VALM1
  1. S DIC=8925.1,DIC(0)="AEMNQ"
  1. ASK K PARENT,Y,MSG D ^DIC I Y=-1 G EXPDX
  1. S FILEDA=+Y,NODE0=^TIU(8925.1,FILEDA,0)
  1. S ORPHAN=$$ORPHAN^TIUFLF4(FILEDA,NODE0,.PARENT)
  1. I $P(NODE0,U,4)="O" S MSG=" Objects are not in the Hierarchy: Use SORT Option"
  1. I $P(NODE0,U,10) S MSG=" Shared Components can occur more than once in the hierarchy; Can't Jump to",MSG1="them. To find them, use SORT Option. Edit/View shows their parents."
  1. I ORPHAN="YES" S MSG=" Orphans are not in the Hierarchy: Use SORT Option"
  1. I $D(MSG) W !!,MSG,! W:$D(MSG1) MSG1 K MSG,MSG1 G ASK
  1. NOASK S INFO=^TMP("TIUF1IDX",$J,1) D PARSE^TIUFLLM(.INFO)
  1. I 'ASK S NODE0=^TIU(8925.1,FILEDA,0),ORPHAN=$$ORPHAN^TIUFLF4(FILEDA,NODE0,.PARENT)
  1. S OXPDLCNT=INFO("XPDLCNT") ;Original XPDLCNT
  1. D COLLAPSE(.INFO) S VALMCNT=VALMCNT-OXPDLCNT
  1. F TIUJ=$O(PARENT(1000),-1):-1:1 D I MISSITEM G EXPDX
  1. . S ENTRYNO=$O(^TMP("TIUF1IDX",$J,"DAF",PARENT(TIUJ),0))
  1. . S EINFO=^TMP("TIUF1IDX",$J,ENTRYNO)
  1. . D PARSE^TIUFLLM(.EINFO) S PFILEDA=$P(EINFO,U,2)
  1. . S MISSITEM=$$MISSITEM^TIUFLF4(PFILEDA)
  1. . I MISSITEM W !! W $S(ASK:" Can't Jump",1:"Can't expand to show "_$P(NODE0,U)),": File Entry "_PFILEDA_" Has Nonexistent Item "_MISSITEM_"; See IRM",! D PAUSE^TIUFXHLX Q
  1. . D EXPAND1(.EINFO) S VALMCNT=VALMCNT+EINFO("XPDLCNT")
  1. . Q
  1. S LINENO=$O(^TMP("TIUF1IDX",$J,"DAF",PARENT(0),0))
  1. I ASK,LINENO<VALMBG!(LINENO>(VALMBG+VALM("LINES")-1)) S VALMBG=LINENO
  1. EXPDX I ASK D RESET^TIUFXHLX S VALMBCK="R" I $D(DTOUT) S VALMBCK="Q"
  1. Q
  1. ;
  1. COLLAPSE(EINFO) ; Collapse ENTRYNO
  1. ; Requires EINFO array, where EINFO = ^TMP("TIUFIDX,$J,ENTRYNO), and
  1. ;where EINFO array is as set in PARSE^TIUFLLM(EINFO).
  1. ; Requires TIUFTMPL.
  1. ; Updates array EINFO; Does NOT update VALMCNT.
  1. I ($D(EINFO)'=11) G COLLX
  1. I 'EINFO("XPDLCNT") G COLLX
  1. D UPDATE^TIUFLLM1(TIUFTMPL,-EINFO("XPDLCNT"),+EINFO,.EINFO)
  1. COLLX ;
  1. Q
  1. ;
  1. EXPAND1(EINFO) ; Set items of List Manager array entry ENTRYNO into
  1. ;LM array (ie., expands entry); Updates Plus in front of ENTRYNO.
  1. ; Does NOT update IN USE Column.
  1. ; Requires EINFO array, where EINFO = ^TMP("TIUFIDX,$J,ENTRYNO), and
  1. ;where EINFO array is as set in PARSE^TIUFLLM(EINFO).
  1. ; Requires TIUFTMPL.
  1. ; Requires TIUFWHO, set in Options TIUF/A/C/H EDIT/SORT/CREATE DDEFS CLIN/MGR/NATL.
  1. ; Updates array EINFO.
  1. ; Must check that items exist in file BEFORE calling EXPAND1
  1. N OLDLNO,LINENO,TIUREC
  1. S (OLDLNO,LINENO)=+EINFO
  1. D BUFITEMS^TIUFLT(TIUFTMPL,.EINFO,.LINENO)
  1. ;If no items, update +, QUIT:
  1. I LINENO=OLDLNO Q:TIUFTMPL="C" S TIUREC=^TMP("TIUF1",$J,+EINFO,0),TIUREC=$$PLUSUP^TIUFLLM(.EINFO,TIUREC),^TMP("TIUF1",$J,+EINFO,0)=TIUREC Q
  1. ; Set Buffer items into LM Template array, update entry being expanded:
  1. D UPDATE^TIUFLLM1(TIUFTMPL,LINENO-OLDLNO,OLDLNO,.EINFO)
  1. EXPAX ;
  1. Q
  1. ;