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

TIULA1.m

Go to the documentation of this file.
  1. TIULA1 ; SLC/JER - More interactive functions ;04-Jun-2012 16:19;DU
  1. ;;1.0;TEXT INTEGRATION UTILITIES;**75,113,1009,207,1010**;Jun 20, 1997;Build 24
  1. ;IHS/MSC/MGH Changes made to correspond with IHS division setup
  1. TRAVERSE(DA,RETURN,PARM,TYPE) ; Select Document Type(s)
  1. N C,I,XQORM,Y N:'$D(LEVEL) LEVEL S LEVEL=+$G(LEVEL)+1
  1. S:$G(TYPE)']"" TYPE="D"
  1. S XQORM=DA_";TIU(8925.1,",XQORM(0)=$S($L($G(PARM)):PARM,1:"AD")
  1. I XQORM(0)["D" S XQORM("H")="W !!,$$CENTER^TIULS(""--- ""_$P(^TIU(8925.1,+DA,0),U,3)_"" ---""),!"
  1. S XQORM("B")=$G(^DISV(DUZ,"XQORM",DA_";TIU(8925.1,",1))
  1. S XQORM("A")="Select "_$S(XQORM(0)["D":"Document",1:$P(^TIU(8925.1,+DA,0),U,3))_$S("CD"[$P(^TIU(8925.1,+DA,0),U,4):" Component",1:" Type")_$S(+XQORM(0)'=1:"(s)",1:"")_": "
  1. D EN^XQORM
  1. M RETURN(LEVEL)=Y
  1. S I=0 F S I=$O(Y(I)) Q:+I'>0 D
  1. . S J=+$P(Y(I),U,2)
  1. . I $P(^TIU(8925.1,+J,0),U,4)'=TYPE,$D(^TIU(8925.1,+J,10))'<10 D TRAVERSE(+J,.RETURN,$G(PARM))
  1. Q
  1. ASKSIG() ; Prompt for ES, return encrypted data
  1. N ESNAME,ESTITLE,Y S Y=0
  1. D SIG^XUSESIG I X1']"" S:'$D(X) X=0 D BADSIG^TIULG(X) G ASKX
  1. S ESNAME=$P($G(^VA(200,DUZ,20)),U,2),ESTITLE=$P($G(^(20)),U,3)
  1. S Y=1_U_ESNAME_U_ESTITLE
  1. ASKX Q Y
  1. ASKSUBJ() ; Handle query by subject
  1. N Y
  1. S Y=$$READ^TIUU("FO","Where SUBJECT CONTAINS")
  1. Q $$UPPER^TIULS(Y)
  1. ASKLOC() ; Handle query by location
  1. N Y
  1. S Y=$$READ^TIUU("P^44:AEMQ","Select HOSPITAL LOCATION")
  1. Q Y
  1. TYPMATCH(TYPE,CURTYP) ; Check for type match
  1. N TIUI,TIUY S TIUY=0
  1. I $L(TYPE,"!")=1,TYPE=CURTYP S TIUY=1
  1. E F TIUI=1:1:$L(TYPE,"!") I $P(TYPE,"!",TIUI)=CURTYP S TIUY=1 Q
  1. Q TIUY
  1. DOCLIST(CLASS,Y,PARM,DFLT) ; Get preferred documents for user
  1. N TIUDA,XQORM,X
  1. S TIUDA=+$O(^TIU(8925.98,"AC",DUZ,CLASS,0)),XQORM=TIUDA_";TIU(8925.98,"
  1. I +TIUDA'>0!(+$O(^XUTL("XQORM",XQORM,0))'>0) S Y=-1 Q
  1. I $G(DFLT)="LAST" D
  1. . S DFLT=$O(^DISV(DUZ,"XQORM",XQORM,0))
  1. . S DFLT=$S(+DFLT:$G(^DISV(DUZ,"XQORM",XQORM,DFLT)),1:"")
  1. S XQORM(0)=$S(+$P($G(^TIU(8925.98,+TIUDA,10,0)),U,3)=1:"F",1:PARM)
  1. S XQORM("B")=$S(+$P($G(^TIU(8925.98,+TIUDA,10,0)),U,3)=1:$P($G(^(0)),U,3),1:DFLT)
  1. I XQORM(0)'["A" S X=XQORM("B")
  1. S XQORM("A")=$S(CLASS=3:"",1:"Select ")_$S(CLASS=3:"TITLE",1:"Document")_$S(+XQORM(0)'=1:"(s)",1:"")_": "
  1. I XQORM(0)["D" D
  1. . N LISTNAME,PERSNAME S LISTNAME=$$PNAME^TIULC1(CLASS)
  1. . I $E(LISTNAME,$L(LISTNAME))="Y" D
  1. . . S LISTNAME=$E(LISTNAME,1,($L(LISTNAME)-1))_"IES"
  1. . I $E(LISTNAME,$L(LISTNAME))="y" D
  1. . . S LISTNAME=$E(LISTNAME,1,($L(LISTNAME)-1))_"ies"
  1. . S PERSNAME=$$PERSNAME^TIULC1(DUZ)
  1. . S LISTNAME=""""_"--- "_LISTNAME_" for "_PERSNAME_" ---"_""""
  1. . S XQORM("H")="W !!,$$CENTER^TIULS("_LISTNAME_"),!"
  1. S XQORM("S")="I $$CANPICK^TIULP(+$G(^TIU(8925.98,+DA(1),10,+DA,0)))"
  1. D EN^XQORM
  1. Q
  1. SELCAT(Y,PARM,DFLT,TIUOVER) ; Get preferred documents for user
  1. N TIUI,TIUDA,CATREC,CATLOOK,CATSCRN,CATVAL,XQORM,X ;P75 newed CATVAL
  1. N TIUT1,TIUT2,TIUTSTR,TIUHOLD
  1. S TIUI=0
  1. S XQORM="1;TIU(8925.8,"
  1. I $G(DFLT)="LAST" D
  1. . S DFLT=$O(^DISV(DUZ,"XQORM",XQORM,0))
  1. . S DFLT=$S(+DFLT:$G(^DISV(DUZ,"XQORM",XQORM,DFLT)),1:"")
  1. S XQORM(0)=$G(PARM,"1A")
  1. S XQORM("B")=$G(DFLT,"AUTHOR")
  1. I +$G(ORVP) S XQORM("S")="I $G(^XUTL(""XQORM"",XQORM,+$O(^XUTL(""XQORM"",XQORM,""B"",DA,0)),0))'[""Patient"""
  1. I XQORM(0)'["A" S X=XQORM("B")
  1. S XQORM("A")="Select SEARCH CATEGOR"_$S(+XQORM(0)'=1:"IES",1:"Y")_": "
  1. I XQORM(0)["D" S XQORM("H")="W !!,$$CENTER^TIULS(""--- Search Categories ---""),!"
  1. D EN^XQORM
  1. ; BEGIN TIU207
  1. ; FLAG IF TITLE OR ALL CATEGORIES WERE SELECTED. NEEDED IN HDR^TIURH AS ^TMP("TIUR","TIU OVERRIDE")
  1. S TIUT1="",TIUTSTR=""
  1. F S TIUT1=$O(Y(TIUT1)) Q:TIUT1="" D
  1. .I $P(Y(TIUT1),"^",3)="Title" S TIUTSTR=TIUTSTR_"TITLE"
  1. .I $P(Y(TIUT1),"^",3)="All Categories" S TIUTSTR=TIUTSTR_"ALL"
  1. I TIUTSTR["TITLE" S TIUOVER=TIUTSTR
  1. ; IF SPECIFIC CATEGORY AND ALL CATEGORIES WHERE SELECTED THEN REMOVE ALL CATEGORIES.
  1. I $O(Y(""),-1)>1,TIUTSTR["ALL" D
  1. .M TIUHOLD=Y K Y
  1. .S TIUT1="",TIUT2=1
  1. .F S TIUT1=$O(TIUHOLD(TIUT1)) Q:TIUT1="" D
  1. ..I $P(TIUHOLD(TIUT1),"^",3)="All Categories" Q
  1. ..S Y(TIUT2)=TIUHOLD(TIUT1)
  1. ..S Y=TIUT2
  1. ..S TIUT2=TIUT2+1
  1. ; END TIU207
  1. F S TIUI=$O(Y(TIUI)) Q:+TIUI'>0 D
  1. . S TIUDA=+$P(Y(TIUI),U,2)
  1. . S CATREC=$G(^TIU(8925.8,TIUDA,0))
  1. . S CATSCRN=$G(^TIU(8925.8,TIUDA,1))
  1. . S CATLOOK=$G(^TIU(8925.8,TIUDA,2))
  1. . S CATVAL=-1 ;P75
  1. . I CATLOOK']"",+$P(CATREC,U,4) S CATVAL=$$DICLOOK(CATREC,CATSCRN)
  1. . I CATLOOK]"" S CATVAL=$$LOOK(CATLOOK)
  1. . I +CATVAL'=-1,$L(CATVAL) S Y(TIUI)=$P(CATREC,U,2)_U_CATVAL
  1. . E K Y(TIUI) S Y=+$G(Y)-1
  1. Q
  1. DICLOOK(CATEGORY,SCREEN) ; Call ^DIC to get category value
  1. N DIC,X,Y
  1. S DIC=+$P(CATEGORY,U,4),DIC(0)="AEMQZ"
  1. S DIC("A")="Select "_$P(CATEGORY,U)_": "
  1. I SCREEN]"" X SCREEN
  1. D ^DIC I +$G(DUOUT),(X="^^") S DIROUT=1
  1. Q Y
  1. LOOK(LOOKUP) ; Execute LOOKUP CODE
  1. N X,Y
  1. X LOOKUP
  1. Q Y
  1. GETVSIT(DFN) ; Visit selection code
  1. N X,Y
  1. I +$G(ORVP),'+$G(DFN) S DFN=+$G(ORVP)
  1. D MAIN^TIUVISIT(.Y,$G(DFN))
  1. S Y=$G(Y("VISIT"))
  1. I +Y,+$P(Y,U,2) S $P(Y,U,2)=$$DATE^TIULS($P(Y,U,2),"MM/DD/YY HR:MIN")
  1. Q Y
  1. GETTERM(X) ; Get Lexicon term
  1. N DIC,USEX,Y
  1. S DIC=757.01,DIC(0)="AEMQZ",DIC("A")="Select PROBLEM: "
  1. D ^DIC
  1. I +Y'>0,(X]""),(X'=" "),(X'["^") D
  1. . S USEX=$$READ^TIUU("Y",">>> Use "_X,"Yes")
  1. . I +USEX S Y=1_U_X
  1. Q Y
  1. GETDIV() ; Get Institution Number and Name
  1. N TIUDIV,TIUSTN,Y
  1. ;IHS/MSC/MGH Division changes to be in line with IHS
  1. ;S TIUDIV=$S($P($G(^DG(43,1,"GL")),U,2):$$MULTDIV,1:$$PRIM^VASITE)
  1. D DIVGET^XUSRB2(.IHSDIV,DUZ)
  1. I IHSDIV(2)>1 S TIUDIV=$$MULTDIV
  1. E S TIUDIV=$$PRIM^VASITE
  1. S TIUSTN=$$SITE^VASITE(,TIUDIV)
  1. ; end of IHS mod
  1. S TIUSTN=$$SITE^VASITE(,TIUDIV)
  1. I $P(TIUSTN,U)>0,($P(TIUSTN,U,2)]"") D
  1. . S Y=$P(TIUSTN,U)_U_$P(TIUSTN,U,2)
  1. E D
  1. . S Y=-1
  1. Q Y
  1. MULTDIV() ; User selects from active divisions
  1. N DIR,X,Y
  1. S DIR(0)="PA^40.8:EM"
  1. S DIR("A")="Select DIVISION: "
  1. S DIR("S")="I $$SITE^VASITE(,+Y)>0"
  1. D ^DIR
  1. Q +Y