88 lines
3.9 KiB
Mathematica
88 lines
3.9 KiB
Mathematica
TIULQ ; SLC/JER - Record Extract Using FM Retriever ; 3/1/06 3:46pm
|
|
;;1.0;TEXT INTEGRATION UTILITIES;**19,100,157,211**;Jun 20, 1997;Build 26
|
|
EXTRACT(TIUDA,TIUROOT,TIUERR,DR,TIULINE,TIUTEXT,FORMAT,OVRRIDE,ORIGCHLD) ; Gets record & addenda and ID kids
|
|
; Do we need a new DBIA here? MARGY
|
|
N DA,DIC,DIQ,TIULQ,X,Y
|
|
S TIUROOT=$G(TIUROOT,"^TMP(""TIULQ"",$J)")
|
|
S DA=TIUDA,DIC=8925,DIQ="TIULQ",DIQ(0)=$G(FORMAT,"IE")
|
|
I $G(DR)']"" S DR=".01:.1;1201:1701;89261"
|
|
D EN^DIQ1
|
|
I '$D(TIULQ) S TIUERR="1^ Record Extract Failed"
|
|
M @TIUROOT@(TIUDA)=TIULQ(8925,TIUDA)
|
|
D XTRASIGN(DA,+$G(TIULINE))
|
|
D PROBLEMS(DA,+$G(TIULINE))
|
|
I +$G(TIUTEXT) D TEXT(TIUDA,+$G(TIULINE),TIUDA,+$G(OVRRIDE),+$G(ORIGCHLD))
|
|
Q
|
|
XTRASIGN(TIUDA,TIUJ) ; Get Extra Signers
|
|
N TIUI,TIUXTRA,TIUC,DR,DIC,DIQ S TIUI=0
|
|
F S TIUI=$O(^TIU(8925.7,"B",+TIUDA,TIUI)) Q:+TIUI'>0 D
|
|
. N TIUDT,TIUSGN,TIUSNM,TIUSTTL,TIUEIEN,TIUENAME
|
|
. S DA=TIUI,DR=".03:.07",DIC="^TIU(8925.7,",DIQ="TIUXTRA",DIQ(0)="IE"
|
|
. D EN^DIQ1 Q:$D(TIUXTRA)'>9
|
|
. S TIUC=+$G(TIUC)+1
|
|
. S TIUEIEN=$G(TIUXTRA(8925.7,DA,.03,"I"))
|
|
. S TIUENAME=$G(TIUXTRA(8925.7,DA,.03,"E"))
|
|
. S TIUDT=$G(TIUXTRA(8925.7,DA,.04,"I"))
|
|
. S TIUSGN=$G(TIUXTRA(8925.7,DA,.05,"I"))
|
|
. S TIUSNM=$G(TIUXTRA(8925.7,DA,.06,"E"))
|
|
. S TIUSTTL=$G(TIUXTRA(8925.7,DA,.07,"E"))
|
|
. S @TIUROOT@(TIUDA,"EXTRASGNR",(TIUJ+TIUC),"EXPIEN")=TIUEIEN
|
|
. S @TIUROOT@(TIUDA,"EXTRASGNR",(TIUJ+TIUC),"EXPNAME")=TIUENAME
|
|
. S @TIUROOT@(TIUDA,"EXTRASGNR",(TIUJ+TIUC),"DATE")=TIUDT
|
|
. S @TIUROOT@(TIUDA,"EXTRASGNR",(TIUJ+TIUC),"EXTRA")=TIUSGN
|
|
. S @TIUROOT@(TIUDA,"EXTRASGNR",(TIUJ+TIUC),"NAME")=TIUSNM
|
|
. S @TIUROOT@(TIUDA,"EXTRASGNR",(TIUJ+TIUC),"TITLE")=TIUSTTL
|
|
Q
|
|
PROBLEMS(TIUDA,TIUJ) ; Get associated problems
|
|
N TIUI,TIUP,TIUPROB,TIUC,TIUX,DR,DIC,DIQ S TIUI=0
|
|
F S TIUI=$O(^TIU(8925.9,"B",+TIUDA,TIUI)) Q:+TIUI'>0 D
|
|
. S DA=TIUI,DR=".02;.05",DIC="^TIU(8925.9,",DIQ="TIUPROB"
|
|
. D EN^DIQ1 Q:$D(TIUPROB)'>9
|
|
. S TIUC=+$G(TIUC)+1
|
|
. S TIUP=$$MIXED^TIULS($G(TIUPROB(8925.9,TIUI,.05)))
|
|
. S TIUX=$$SETSTR^VALM1($J(TIUC,2)_".",$G(TIUX),1,3)
|
|
. S TIUX=$$SETSTR^VALM1(TIUP,$G(TIUX),5,35)
|
|
. S TIUP=$G(TIUPROB(8925.9,TIUI,.02))
|
|
. S TIUX=$$SETSTR^VALM1(TIUP,$G(TIUX),40,6)
|
|
. S @TIUROOT@(TIUDA,"PROBLEM",(TIUJ+TIUC),0)=TIUX
|
|
Q
|
|
TEXT(TIUDA,TIUJ,TIUDAD,TIUOVR,ORIGCHLD) ; Get each component
|
|
N TIUKID,TIUDADT,TIUI,TIUD0,TIULVL,CANPRINT S TIUI=0
|
|
S TIUD0=$G(^TIU(8925,+TIUDA,0)),TIULVL=$P($G(^TIU(8925.1,+TIUD0,0)),U,4)
|
|
S CANPRINT=$S(TIULVL="DOC":$$CANDO^TIULP(TIUDA,"PRINT RECORD"),1:1)
|
|
I +TIUOVR'>0,(+CANPRINT'>0) D Q
|
|
. S TIUJ=+$G(TIUJ)+1
|
|
. S @TIUROOT@(TIUDAD,"TEXT",TIUJ,0)=$P(CANPRINT,U,2)
|
|
. S @TIUROOT@(TIUDAD,"TEXT",0)="^^"_TIUJ_U_TIUJ_U_DT_"^^"
|
|
F S TIUI=$O(^TIU(8925,+TIUDA,"TEXT",TIUI)) Q:+TIUI'>0 D
|
|
. S TIUJ=+$G(TIUJ)+1
|
|
. S @TIUROOT@(TIUDAD,"TEXT",TIUJ,0)=$G(^TIU(8925,+TIUDA,"TEXT",TIUI,0))
|
|
S @TIUROOT@(TIUDAD,"TEXT",0)="^^"_TIUJ_U_TIUJ_U_DT_"^^"
|
|
; Iterate through children, and get their text fields
|
|
S TIUKID=0
|
|
F S TIUKID=$O(^TIU(8925,"DAD",+TIUDA,TIUKID)) Q:+TIUKID'>0 D
|
|
. I +$$ISADDNDM^TIULC1(TIUKID) D
|
|
. . N TIUADRT
|
|
. . I TIUROOT[")" S TIUADRT=$P(TIUROOT,")")_","_TIUDAD_",""ZADD"")"
|
|
. . E S TIUADRT=TIUROOT_"("_TIUDAD_",""ZADD"")"
|
|
. . D EXTRACT(TIUKID,TIUADRT,.TIUERR,DR,.TIUJ,1) I 1
|
|
. E D TEXT(TIUKID,.TIUJ,TIUDAD,+$G(TIUOVR))
|
|
; Get ID kids in correct sort order; extract data for each kid:
|
|
Q:'$O(^TIU(8925,"GDAD",TIUDA,0))
|
|
N TIUGDATA,TIUSORT,TIUK,TIUIDKID,TIUIDRT,CTR
|
|
S TIUGDATA=$$IDDATA^TIURECL1(TIUDA)
|
|
S TIUSORT=$P(TIUGDATA,U,4)
|
|
D GETIDKID^TIURECL2(TIUDA,TIUSORT)
|
|
S TIUK=0,CTR=0
|
|
F S TIUK=$O(^TMP("TIUIDKID",$J,TIUDA,TIUK)) Q:'TIUK D
|
|
. S TIUIDKID=^TMP("TIUIDKID",$J,TIUDA,TIUK)
|
|
. N TIUIDRT
|
|
. I TIUROOT[")" S TIUIDRT=$P(TIUROOT,")")_","_TIUDAD_",""ZZID"","_TIUK_")"
|
|
. E S TIUIDRT=TIUROOT_"("_TIUDAD_",""ZZID"","_TIUK_")"
|
|
. D EXTRACT(TIUIDKID,TIUIDRT,.TIUERR,DR,.TIUJ,1)
|
|
. S CTR=CTR+1
|
|
I CTR S @TIUROOT@(TIUDAD,"ZZID",0)=CTR ; How many ID kids TIUDAD has
|
|
;I CTR,$G(ORIGCHLD) S @TIUROOT@(TIUDAD,"REASON")="Note included because interdisciplinary child meets criteria."
|
|
K ^TMP("TIUIDKID",$J)
|
|
Q
|