TIUDD ; slc/KCM - Build menus in XUTL (file 8925.1) ;7/19/94 13:51 ;
;;1.0;TEXT INTEGRATION UTILITIES;;Jun 20, 1997
SET ;From: Cross reference in file 8925.1, field 99 Entry: DA Exit: DA
;NOTE: Lock ^TIU(8925.1,DA) when calling
Q:$D(^TIU(8925.1,DA,0))[0
I $D(^TIU(8925.1,DA,99)),$D(^XUTL("XQORM",DA_";TIU(8925.1,",0)),($P(^TIU(8925.1,DA,99),"^")=$P(^XUTL("XQORM",DA_";TIU(8925.1,",0),"^")) Q
N TIUCOL,TIUCCOL,TIUROW,TIUCROW,TIUPOS,TIUTOT,S1,S2,X,X1
K ^TMP("XQORM",$J) D KILL
S TIUCOL=3
S ^XUTL("XQORM",DA_";TIU(8925.1,","COL")=TIUCOL,(TIUTOT,S2)=0
F S S2=$O(^TIU(8925.1,DA,10,S2)) Q:S2'>0 D
. S X=^TIU(8925.1,DA,10,S2,0) I '$D(^TIU(8925.1,+X,0)) Q
. S X=$S(+$P(X,"^",3):+$P(X,"^",3),+$P(X,"^",2):+$P(X,"^",2),$L($P(X,"^",2)):"M"_$P(X,"^",2),1:"Z"_$P(^TIU(8925.1,+X,0),"^",2))
. S ^TMP("XQORM",$J,X,S2)="",TIUTOT=TIUTOT+1
S TIUROW=TIUTOT\TIUCOL+$S(TIUTOT#TIUCOL:1,1:0),TIUCCOL=1,TIUCROW=0,S1=""
F S S1=$O(^TMP("XQORM",$J,S1)) Q:S1="" S S2=0 D ;S1 is sequence
. F S S2=$O(^TMP("XQORM",$J,S1,S2)) Q:S2'>0 D ;S2 is item subscript
. . S X=^TIU(8925.1,DA,10,S2,0) ; X is the item node
. . I '$D(^TIU(8925.1,+X,0)) K ^TIU(8925.1,DA,10,S2),^("B",+X,S2) S $P(^TIU(8925.1,DA,10,0),"^",3,4)=S2_"^"_($P(^TIU(8925.1,DA,10,0),"^",4)-1) Q
. . S TIUCROW=TIUCROW+1 I TIUCROW>TIUROW S TIUCROW=1,TIUCCOL=TIUCCOL+1
. . S TIUPOS=TIUCROW+(TIUCCOL/10)
. . S X1=$S($L($P(X,"^",4)):$P(X,"^",4),1:$P(^TIU(8925.1,+X,0),"^",3))
. . S X1=$TR(X1,",=;-"," ") Q:'$L(X1)
. . S ^XUTL("XQORM",DA_";TIU(8925.1,",TIUPOS,0)=S2_"^"_+X_"^"_X1_"^"_$P(X,"^",2)
. . S ^XUTL("XQORM",DA_";TIU(8925.1,","B",$$UP(X1),TIUPOS)=""
. . I $L($P(X,"^",2)) S ^XUTL("XQORM",DA_";TIU(8925.1,","B",$$UP($P(X,"^",2)),TIUPOS)=1
S X=$H,^XUTL("XQORM",DA_";TIU(8925.1,",0)=X,^TIU(8925.1,DA,99)=X
K ^TMP("XQORM",$J)
Q
UP(X) ; Convert X to upper case
Q $TR(X,"abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ")
KILL ; From: File 8925.1, Field 99 Entry: DA Exit: DA
K ^XUTL("XQORM",DA_";TIU(8925.1,") Q
REDO ; Update TIMESTAMP on self & parents when Print Name Changes
; From: File 8925.1, Field .03 Entry: DA Exit: DA
N I,X S X=$H I $D(^TIU(8925.1,DA,0)) S ^(99)=X,I=0
F S I=$O(^TIU(8925.1,"AD",DA,I)) Q:I'>0 D
. I $D(^TIU(8925.1,I,0)) S ^(99)=X
Q
REDOX ; From: Subfile 8925.14, Fields .01,2,3 Entry: DA(1) Exit: DA(1)
I $D(^TIU(8925.1,DA(1),0)) S ^(99)=$H Q
TREE ; Look back up tree to make sure item is not ancestor (input xform)
; From: 8925.14,.01 Entry: DA(1),X
S TIUDDA=DA(1) K:X=TIUDDA X D TREE1 K TIUDDA,TIUDD
Q
TREE1 ; Traverse up tree
S TIUDD=0 F Q:'$D(X) S TIUDD=$O(^TIU(8925.1,"AD",TIUDDA,TIUDD)) Q:TIUDD'>0 K:TIUDD=X X Q:'$D(X) D TREE2
Q
TREE2 ; Recurse one level
N TIUDDA S TIUDDA=TIUDD N TIUDD D TREE1
Q
ASUBS(SUBJECT,TIUTYP,TIUSTAT,TIUIDT,DA) ; SET logic for "ASUB" X-ref
N TIUI,TIUWORD S TIUI=0
D PARSE^TIULS(SUBJECT,.TIUWORD)
F S TIUI=$O(TIUWORD(TIUI)) Q:+TIUI'>0 D
. S ^TIU(8925,"ASUB",TIUWORD(TIUI),+TIUTYP,+TIUSTAT,+TIUIDT,+DA)=""
Q
ASUBK(SUBJECT,TIUTYP,TIUSTAT,TIUIDT,DA) ; SET logic for "ASUB" X-ref
N TIUI,TIUWORD S TIUI=0
D PARSE^TIULS(SUBJECT,.TIUWORD)
F S TIUI=$O(TIUWORD(TIUI)) Q:+TIUI'>0 D
. K ^TIU(8925,"ASUB",TIUWORD(TIUI),+TIUTYP,+TIUSTAT,+TIUIDT,+DA)
Q
APRBS(TIUTYP,TIUSTAT,TIUIDT,DA,TIUPROB) ; SET logic for "APRB" X-ref
N TIUI
S TIUI=0 F S TIUI=+$O(^TIU(8925.9,"B",+DA,TIUI)) Q:+TIUI'>0 D
. S:$G(TIUPROB)']"" TIUPROB=$P($G(^TIU(8925.9,+TIUI,0)),U,5)
. I TIUPROB]"" D
. . S ^TIU(8925,"APRB",$$UPPER^TIULS(TIUPROB),+TIUTYP,+TIUSTAT,+TIUIDT,+DA)=""
Q
APRBK(TIUTYP,TIUSTAT,TIUIDT,DA,TIUPROB) ; KILL logic for "APRB" X-ref
N TIUI
S TIUI=0 F S TIUI=+$O(^TIU(8925.9,"B",+DA,TIUI)) Q:+TIUI'>0 D
. S:$G(TIUPROB)']"" TIUPROB=$P($G(^TIU(8925.9,+TIUI,0)),U,5)
. I TIUPROB]"" D
. . K ^TIU(8925,"APRB",$$UPPER^TIULS(TIUPROB),+TIUTYP,+TIUSTAT,+TIUIDT,+DA)
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HTIUDD 3898 printed Oct 16, 2024@18:40:14 Page 2
TIUDD ; slc/KCM - Build menus in XUTL (file 8925.1) ;7/19/94 13:51 ;
+1 ;;1.0;TEXT INTEGRATION UTILITIES;;Jun 20, 1997
SET ;From: Cross reference in file 8925.1, field 99 Entry: DA Exit: DA
+1 ;NOTE: Lock ^TIU(8925.1,DA) when calling
+2 if $DATA(^TIU(8925.1,DA,0))[0
QUIT
+3 IF $DATA(^TIU(8925.1,DA,99))
IF $DATA(^XUTL("XQORM",DA_";TIU(8925.1,",0))
IF ($PIECE(^TIU(8925.1,DA,99),"^")=$PIECE(^XUTL("XQORM",DA_";TIU(8925.1,",0),"^"))
QUIT
+4 NEW TIUCOL,TIUCCOL,TIUROW,TIUCROW,TIUPOS,TIUTOT,S1,S2,X,X1
+5 KILL ^TMP("XQORM",$JOB)
DO KILL
+6 SET TIUCOL=3
+7 SET ^XUTL("XQORM",DA_";TIU(8925.1,","COL")=TIUCOL
SET (TIUTOT,S2)=0
+8 FOR
SET S2=$ORDER(^TIU(8925.1,DA,10,S2))
if S2'>0
QUIT
Begin DoDot:1
+9 SET X=^TIU(8925.1,DA,10,S2,0)
IF '$DATA(^TIU(8925.1,+X,0))
QUIT
+10 SET X=$SELECT(+$PIECE(X,"^",3):+$PIECE(X,"^",3),+$PIECE(X,"^",2):+$PIECE(X,"^",2),$LENGTH($PIECE(X,"^",2)):"M"_$PIECE(X,"^",2),1:"Z"_$PIECE(^TIU(8925.1,+X,0),"^",2))
+11 SET ^TMP("XQORM",$JOB,X,S2)=""
SET TIUTOT=TIUTOT+1
End DoDot:1
+12 SET TIUROW=TIUTOT\TIUCOL+$SELECT(TIUTOT#TIUCOL:1,1:0)
SET TIUCCOL=1
SET TIUCROW=0
SET S1=""
+13 ;S1 is sequence
FOR
SET S1=$ORDER(^TMP("XQORM",$JOB,S1))
if S1=""
QUIT
SET S2=0
Begin DoDot:1
+14 ;S2 is item subscript
FOR
SET S2=$ORDER(^TMP("XQORM",$JOB,S1,S2))
if S2'>0
QUIT
Begin DoDot:2
+15 ; X is the item node
SET X=^TIU(8925.1,DA,10,S2,0)
+16 IF '$DATA(^TIU(8925.1,+X,0))
KILL ^TIU(8925.1,DA,10,S2),^("B",+X,S2)
SET $PIECE(^TIU(8925.1,DA,10,0),"^",3,4)=S2_"^"_($PIECE(^TIU(8925.1,DA,10,0),"^",4)-1)
QUIT
+17 SET TIUCROW=TIUCROW+1
IF TIUCROW>TIUROW
SET TIUCROW=1
SET TIUCCOL=TIUCCOL+1
+18 SET TIUPOS=TIUCROW+(TIUCCOL/10)
+19 SET X1=$SELECT($LENGTH($PIECE(X,"^",4)):$PIECE(X,"^",4),1:$PIECE(^TIU(8925.1,+X,0),"^",3))
+20 SET X1=$TRANSLATE(X1,",=;-"," ")
if '$LENGTH(X1)
QUIT
+21 SET ^XUTL("XQORM",DA_";TIU(8925.1,",TIUPOS,0)=S2_"^"_+X_"^"_X1_"^"_$PIECE(X,"^",2)
+22 SET ^XUTL("XQORM",DA_";TIU(8925.1,","B",$$UP(X1),TIUPOS)=""
+23 IF $LENGTH($PIECE(X,"^",2))
SET ^XUTL("XQORM",DA_";TIU(8925.1,","B",$$UP($PIECE(X,"^",2)),TIUPOS)=1
End DoDot:2
End DoDot:1
+24 SET X=$HOROLOG
SET ^XUTL("XQORM",DA_";TIU(8925.1,",0)=X
SET ^TIU(8925.1,DA,99)=X
+25 KILL ^TMP("XQORM",$JOB)
+26 QUIT
UP(X) ; Convert X to upper case
+1 QUIT $TRANSLATE(X,"abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ")
KILL ; From: File 8925.1, Field 99 Entry: DA Exit: DA
+1 KILL ^XUTL("XQORM",DA_";TIU(8925.1,")
QUIT
REDO ; Update TIMESTAMP on self & parents when Print Name Changes
+1 ; From: File 8925.1, Field .03 Entry: DA Exit: DA
+2 NEW I,X
SET X=$HOROLOG
IF $DATA(^TIU(8925.1,DA,0))
SET ^(99)=X
SET I=0
+3 FOR
SET I=$ORDER(^TIU(8925.1,"AD",DA,I))
if I'>0
QUIT
Begin DoDot:1
+4 IF $DATA(^TIU(8925.1,I,0))
SET ^(99)=X
End DoDot:1
+5 QUIT
REDOX ; From: Subfile 8925.14, Fields .01,2,3 Entry: DA(1) Exit: DA(1)
+1 IF $DATA(^TIU(8925.1,DA(1),0))
SET ^(99)=$HOROLOG
QUIT
TREE ; Look back up tree to make sure item is not ancestor (input xform)
+1 ; From: 8925.14,.01 Entry: DA(1),X
+2 SET TIUDDA=DA(1)
if X=TIUDDA
KILL X
DO TREE1
KILL TIUDDA,TIUDD
+3 QUIT
TREE1 ; Traverse up tree
+1 SET TIUDD=0
FOR
if '$DATA(X)
QUIT
SET TIUDD=$ORDER(^TIU(8925.1,"AD",TIUDDA,TIUDD))
if TIUDD'>0
QUIT
if TIUDD=X
KILL X
if '$DATA(X)
QUIT
DO TREE2
+2 QUIT
TREE2 ; Recurse one level
+1 NEW TIUDDA
SET TIUDDA=TIUDD
NEW TIUDD
DO TREE1
+2 QUIT
ASUBS(SUBJECT,TIUTYP,TIUSTAT,TIUIDT,DA) ; SET logic for "ASUB" X-ref
+1 NEW TIUI,TIUWORD
SET TIUI=0
+2 DO PARSE^TIULS(SUBJECT,.TIUWORD)
+3 FOR
SET TIUI=$ORDER(TIUWORD(TIUI))
if +TIUI'>0
QUIT
Begin DoDot:1
+4 SET ^TIU(8925,"ASUB",TIUWORD(TIUI),+TIUTYP,+TIUSTAT,+TIUIDT,+DA)=""
End DoDot:1
+5 QUIT
ASUBK(SUBJECT,TIUTYP,TIUSTAT,TIUIDT,DA) ; SET logic for "ASUB" X-ref
+1 NEW TIUI,TIUWORD
SET TIUI=0
+2 DO PARSE^TIULS(SUBJECT,.TIUWORD)
+3 FOR
SET TIUI=$ORDER(TIUWORD(TIUI))
if +TIUI'>0
QUIT
Begin DoDot:1
+4 KILL ^TIU(8925,"ASUB",TIUWORD(TIUI),+TIUTYP,+TIUSTAT,+TIUIDT,+DA)
End DoDot:1
+5 QUIT
APRBS(TIUTYP,TIUSTAT,TIUIDT,DA,TIUPROB) ; SET logic for "APRB" X-ref
+1 NEW TIUI
+2 SET TIUI=0
FOR
SET TIUI=+$ORDER(^TIU(8925.9,"B",+DA,TIUI))
if +TIUI'>0
QUIT
Begin DoDot:1
+3 if $GET(TIUPROB)']""
SET TIUPROB=$PIECE($GET(^TIU(8925.9,+TIUI,0)),U,5)
+4 IF TIUPROB]""
Begin DoDot:2
+5 SET ^TIU(8925,"APRB",$$UPPER^TIULS(TIUPROB),+TIUTYP,+TIUSTAT,+TIUIDT,+DA)=""
End DoDot:2
End DoDot:1
+6 QUIT
APRBK(TIUTYP,TIUSTAT,TIUIDT,DA,TIUPROB) ; KILL logic for "APRB" X-ref
+1 NEW TIUI
+2 SET TIUI=0
FOR
SET TIUI=+$ORDER(^TIU(8925.9,"B",+DA,TIUI))
if +TIUI'>0
QUIT
Begin DoDot:1
+3 if $GET(TIUPROB)']""
SET TIUPROB=$PIECE($GET(^TIU(8925.9,+TIUI,0)),U,5)
+4 IF TIUPROB]""
Begin DoDot:2
+5 KILL ^TIU(8925,"APRB",$$UPPER^TIULS(TIUPROB),+TIUTYP,+TIUSTAT,+TIUIDT,+DA)
End DoDot:2
End DoDot:1
+6 QUIT