| 1 | TIUPUTPF ; SLC/JER - PRF Look-up Method - ;10/9/05 | 
|---|
| 2 | ;;1.0;TEXT INTEGRATION UTILITIES;**184**;Jun 20, 1997 | 
|---|
| 3 | ; COPIED FROM TIUPUTPN AND THEN EDITED | 
|---|
| 4 | LOOKUP ; Look-up code used by router/filer | 
|---|
| 5 | ; Required: TIUSSN, TIUVDT | 
|---|
| 6 | ; -- Selected flag action is set in LOOKUP & in GETCHECK^TIUPFFIX; | 
|---|
| 7 | ;    Action is used in post-file code to link note. | 
|---|
| 8 | ;    Kill it before setting it: | 
|---|
| 9 | K ^TMP("TIUPRFUP",$J) | 
|---|
| 10 | N DA,DFN,TIU,TIUDAD,TIUEDIT,TIUEDT,TIULDT,TIUXCRP,TIUTYPE | 
|---|
| 11 | N TIUNEW,TIUEXIST,TIUDPRM,TIUASACT | 
|---|
| 12 | S TIUEXIST=1 | 
|---|
| 13 | I $S('$D(TIUSSN):1,'$D(TIUVDT):1,$G(TIUSSN)?4N:1,$G(TIUSSN)']"":1,1:0) S Y=-1 G LOOKUPX | 
|---|
| 14 | I TIUSSN?3N1P2N1P4N.E S TIUSSN=$TR(TIUSSN,"-/","") | 
|---|
| 15 | I TIUSSN["?" S Y=-1 G LOOKUPX | 
|---|
| 16 | S TIULOC=+$$ILOC(TIULOC) | 
|---|
| 17 | I '$D(^SC(+$G(TIULOC),0)) S Y=-1 G LOOKUPX | 
|---|
| 18 | S TIUINST=+$$DIVISION^TIULC1(TIULOC) | 
|---|
| 19 | S TIUEDT=$$IDATE^TIULC(TIUVDT),TIULDT=$$FMADD^XLFDT(TIUEDT,1) | 
|---|
| 20 | I +TIUEDT'>0 S Y=-1 Q | 
|---|
| 21 | S TIUTYPE=$$WHATITLE(TIUTITLE) | 
|---|
| 22 | I +TIUTYPE'>0 S Y=-1 Q | 
|---|
| 23 | ; -- Abort upload if title is not a PRF title: | 
|---|
| 24 | I '$$ISPFTTL^TIUPRFL(+TIUTYPE) S Y=-1 Q | 
|---|
| 25 | D DOCPRM^TIULC1(+TIUTYPE,.TIUDPRM) | 
|---|
| 26 | I $P($G(^SC(+TIULOC,0)),U,3)="W" D  I 1 | 
|---|
| 27 | . D MAIN^TIUMOVE(.TIU,.DFN,TIUSSN,TIUEDT,TIULDT,1,"LAST",0,TIULOC) | 
|---|
| 28 | E  D MAIN^TIUVSIT(.TIU,.DFN,TIUSSN,TIUEDT,TIULDT,"LAST",0,TIULOC) | 
|---|
| 29 | I $S($D(TIU)'>9:1,+$G(DFN)'>0:1,1:0) S Y=-1 G LOOKUPX | 
|---|
| 30 | I $P(+$G(TIU("EDT")),".")'=$P($$IDATE^TIULC(TIUVDT),".") S Y=-1 G LOOKUPX | 
|---|
| 31 | I '+$$EXIST^TIUEDI3(DFN,+TIUTYPE,TIU("VSTR"),1,DUZ) S TIUEXIST=0 D | 
|---|
| 32 | . ; -- If refiling after filing error, get flag assignment^action | 
|---|
| 33 | . ;    from user: | 
|---|
| 34 | . I $G(PRFILERR) S TIUASACT=$$SELECT^TIUPRF1(+TIUTYPE,DFN) | 
|---|
| 35 | . ; -- If not, try for one available action: | 
|---|
| 36 | . I '$G(PRFILERR) K ^TMP("TIUPRF",$J) S TIUASACT=$$ONEACT(DFN,+TIUTYPE) K ^TMP("TIUPRF",$J) | 
|---|
| 37 | . I TIUASACT S ^TMP("TIUPRFUP",$J)=TIUASACT | 
|---|
| 38 | I 'TIUEXIST,'$G(^TMP("TIUPRFUP",$J)) S Y=-1 G LOOKUPX | 
|---|
| 39 | S TIUTYP(1)=1_U_TIUTYPE_U_$$PNAME^TIULC1(TIUTYPE) | 
|---|
| 40 | S Y=$$GETRECNW^TIUEDI3(DFN,.TIU,TIUTYP(1),.TIUNEW,.TIUDPRM) | 
|---|
| 41 | I +Y'>0 G LOOKUPX | 
|---|
| 42 | ; If record is not new, has text and can be edited, then replace | 
|---|
| 43 | ; existing text | 
|---|
| 44 | I +$G(TIUNEW)'>0 D | 
|---|
| 45 | . S TIUEDIT=$$CANEDIT(+Y) | 
|---|
| 46 | . I +TIUEDIT>0,$D(^TIU(8925,+Y,"TEXT")) D DELTEXT(+Y) | 
|---|
| 47 | . I +TIUEDIT'>0 S TIUDAD=+Y,Y=$$MAKEADD | 
|---|
| 48 | I +Y'>0 Q | 
|---|
| 49 | D STUFREC(Y,+$G(TIUDAD)) | 
|---|
| 50 | I +$G(TIUDAD) D SENDADD^TIUALRT(+Y) | 
|---|
| 51 | K TIUHDR(.01),TIUHDR(.07),TIUHDR(1301) | 
|---|
| 52 | LOOKUPX Q | 
|---|
| 53 | ; | 
|---|
| 54 | ONEACT(DFN,TIUTYPE) ; If there is exactly one Assigment History Action | 
|---|
| 55 | ; available for pat DFN & Title TIUTYPE, return ASSGNIEN^ACTIEN; | 
|---|
| 56 | ; else return 0 | 
|---|
| 57 | ;Count only unlinked, linkable actions | 
|---|
| 58 | ;An action is LINKABLE if it is not ENTERED IN ERROR (EIE) and | 
|---|
| 59 | ; is not taken prior to an EIE action. | 
|---|
| 60 | N TIUDG,TIUASSGN,ONEIEN,RESULT,ARRAYNM | 
|---|
| 61 | S RESULT=0,ARRAYNM="^TMP(""TIUPRFH"",$J)" | 
|---|
| 62 | S TIUDG=$$GETHTIU^DGPFAPI1(DFN,+TIUTYPE,ARRAYNM) | 
|---|
| 63 | I 'TIUDG G ONEACTX | 
|---|
| 64 | S TIUASSGN=+$G(@ARRAYNM@("ASSIGNIEN")) | 
|---|
| 65 | I $$AVAILACT^TIUPRFL(ARRAYNM,,,.ONEIEN)=1 S RESULT=TIUASSGN_U_ONEIEN | 
|---|
| 66 | ONEACTX ; | 
|---|
| 67 | K ^TMP("TIUPRFH",$J) | 
|---|
| 68 | Q RESULT | 
|---|
| 69 | ; | 
|---|
| 70 | ILOC(LOCATION) ; Get pointer to file 44 | 
|---|
| 71 | N DIC,X,Y | 
|---|
| 72 | S DIC=44,DIC(0)="M",X=LOCATION D ^DIC | 
|---|
| 73 | Q Y | 
|---|
| 74 | CANEDIT(DA) ; Check whether or not document is released | 
|---|
| 75 | Q $S(+$P($G(^TIU(8925,+DA,0)),U,5)<4:1,1:0) | 
|---|
| 76 | MAKEADD() ; Create an addendum record | 
|---|
| 77 | N DIE,DR,DA,DIC,X,Y,DLAYGO,TIUATYP,TIUFPRIV S TIUFPRIV=1 | 
|---|
| 78 | S TIUATYP=+$$WHATITLE("ADDENDUM") | 
|---|
| 79 | S (DIC,DLAYGO)=8925,DIC(0)="L",X=""""_"`"_TIUATYP_"""" | 
|---|
| 80 | D ^DIC | 
|---|
| 81 | S DA=+Y | 
|---|
| 82 | I +DA>0 S DIE=DIC,DR=".04////"_$$DOCCLASS^TIULC1(TIUATYP) D ^DIE | 
|---|
| 83 | K TIUHDR(.01) | 
|---|
| 84 | Q +DA | 
|---|
| 85 | STUFREC(DA,PARENT) ; Stuff fixed field data | 
|---|
| 86 | N FDA,FDARR,IENS,FLAGS,TIUMSG | 
|---|
| 87 | S IENS=""""_DA_",""",FDARR="FDA(8925,"_IENS_")",FLAGS="K" | 
|---|
| 88 | I +$G(PARENT)'>0 D | 
|---|
| 89 | . S @FDARR@(.02)=$G(DFN),@FDARR@(.03)=$P($G(TIU("VISIT")),U) | 
|---|
| 90 | . S @FDARR@(.05)=3 | 
|---|
| 91 | . S @FDARR@(.07)=$P($G(TIU("EDT")),U) | 
|---|
| 92 | . S @FDARR@(.08)=$P($G(TIU("LDT")),U) | 
|---|
| 93 | . S @FDARR@(1201)=$$NOW^TIULC | 
|---|
| 94 | . S @FDARR@(1205)=$S(+$P($G(TIU("LOC")),U):$P($G(TIU("LOC")),U),1:$P($G(TIU("VLOC")),U)) | 
|---|
| 95 | . ;S @FDARR@(1211)=$P($G(TIU("VLOC")),U) | 
|---|
| 96 | . S @FDARR@(1404)=$P($G(TIU("SVC")),U) | 
|---|
| 97 | I +$G(PARENT)>0 D | 
|---|
| 98 | . S @FDARR@(.02)=+$P($G(^TIU(8925,+PARENT,0)),U,2) | 
|---|
| 99 | . S @FDARR@(.03)=+$P($G(^TIU(8925,+PARENT,0)),U,3),@FDARR@(.05)=3 | 
|---|
| 100 | . S @FDARR@(.06)=PARENT | 
|---|
| 101 | . S @FDARR@(.07)=$P($G(^TIU(8925,+PARENT,0)),U,7) | 
|---|
| 102 | . S @FDARR@(.08)=$P($G(^TIU(8925,+PARENT,0)),U,8) | 
|---|
| 103 | . S @FDARR@(1205)=$P($G(^TIU(8925,+PARENT,12)),U,5) | 
|---|
| 104 | . S @FDARR@(1404)=$P($G(^TIU(8925,+PARENT,14)),U,4) | 
|---|
| 105 | . S @FDARR@(1201)=$$NOW^TIULC | 
|---|
| 106 | S @FDARR@(1205)=$P($G(TIU("LOC")),U) | 
|---|
| 107 | S @FDARR@(1212)=$P($G(TIU("INST")),U) | 
|---|
| 108 | S @FDARR@(1301)=$S($G(TIUDDT)]"":$$IDATE^TIULC($G(TIUDDT)),1:"") | 
|---|
| 109 | I $S(@FDARR@(1301)'>0:1,$P(@FDARR@(1301),".",2)']"":1,1:0) D | 
|---|
| 110 | . S @FDARR@(1301)=$S($P($G(TIU("VSTR")),";",3)="H":$$NOW^XLFDT,1:$G(@FDARR@(.07))) | 
|---|
| 111 | S @FDARR@(1303)="U" | 
|---|
| 112 | D FILE^DIE(FLAGS,"FDA","TIUMSG") ; File record | 
|---|
| 113 | Q | 
|---|
| 114 | DELTEXT(DA) ; Delete existing text in preparation for replacement | 
|---|
| 115 | N DIE,DR,X,Y | 
|---|
| 116 | S DIE=8925,DR="2///@" D ^DIE | 
|---|
| 117 | Q | 
|---|
| 118 | WHATYPE(X) ; Identify document type | 
|---|
| 119 | ; Receives: X=Document Definition Name | 
|---|
| 120 | ;  Returns: Y=Document Definition IFN | 
|---|
| 121 | N DIC,Y,TIUFPRIV S TIUFPRIV=1 | 
|---|
| 122 | S DIC=8925.1,DIC(0)="M" | 
|---|
| 123 | S DIC("S")="I $D(^TIU(8925.1,+Y,""HEAD""))!$D(^TIU(8295.1,+Y,""ITEM""))" | 
|---|
| 124 | D ^DIC K DIC("S") | 
|---|
| 125 | WHATYPX Q Y | 
|---|
| 126 | WHATITLE(X) ; Identify document title | 
|---|
| 127 | ; Receives: X=Document Definition Name | 
|---|
| 128 | ;  Returns: Y=Document Definition IFN | 
|---|
| 129 | N DIC,Y,TIUFPRIV S TIUFPRIV=1 | 
|---|
| 130 | S DIC=8925.1,DIC(0)="M" | 
|---|
| 131 | S DIC("S")="I $P(^TIU(8925.1,+Y,0),U,4)=""DOC""" | 
|---|
| 132 | D ^DIC K DIC("S") | 
|---|
| 133 | WHATITX Q Y | 
|---|
| 134 | FOLLOWUP(TIUDA) ; Post-filing code for PRF | 
|---|
| 135 | N FDA,FDARR,IENS,FLAGS,TIUMSG,TIU,DFN,TIUTEMP | 
|---|
| 136 | S IENS=""""_TIUDA_",""",FDARR="FDA(8925,"_IENS_")",FLAGS="K" | 
|---|
| 137 | S @FDARR@(1204)=$$WHOSIGNS^TIULC1(TIUDA) | 
|---|
| 138 | I +$P($G(^TIU(8925,TIUDA,12)),U,9),'+$P($G(^(12)),U,8) D | 
|---|
| 139 | . S @FDARR@(1208)=$$WHOCOSIG^TIULC1(TIUDA) | 
|---|
| 140 | D FILE^DIE(FLAGS,"FDA","TIUMSG") | 
|---|
| 141 | I +$P($G(^TIU(8925,+TIUDA,12)),U,8),(+$P($G(^TIU(8925,+TIUDA,12)),U,4)'=+$P($G(^(12)),U,8)) D | 
|---|
| 142 | . S @FDARR@(1506)=1 D FILE^DIE(FLAGS,"FDA","TIUMSG") | 
|---|
| 143 | D RELEASE^TIUT(TIUDA,1) | 
|---|
| 144 | D AUDIT^TIUEDI1(TIUDA,0,$$CHKSUM^TIULC("^TIU(8925,"_+TIUDA_",""TEXT"")")) | 
|---|
| 145 | I $G(^TMP("TIUPRFUP",$J)) D | 
|---|
| 146 | . N TIUDFN S TIUDFN=$P($G(^TIU(8925,TIUDA,0)),U,2) | 
|---|
| 147 | . S TIUTEMP=$$LINK^TIUPRF1(TIUDA,$P($G(^TMP("TIUPRFUP",$J)),U),$P($G(^TMP("TIUPRFUP",$J)),U,2),TIUDFN) | 
|---|
| 148 | . K ^TMP("TIUPRFUP",$J) | 
|---|
| 149 | I '$D(TIU("VSTR")) D | 
|---|
| 150 | . N TIUD0,TIUD12,TIUVLOC,TIUHLOC,TIUEDT,TIULDT | 
|---|
| 151 | . S TIUD0=$G(^TIU(8925,+TIUDA,0)),TIUD12=$G(^(12)) | 
|---|
| 152 | . S DFN=+$P(TIUD0,U,2),TIUEDT=+$P(TIUD0,U,7) | 
|---|
| 153 | . S TIULDT=$$FMADD^XLFDT(TIUEDT,1),TIUHLOC=+$P(TIUD12,U,5) | 
|---|
| 154 | . S TIUVLOC=$S(+$P(TIUD12,U,11):+$P(TIUD12,U,11),1:+TIUHLOC) | 
|---|
| 155 | . I $S(+DFN'>0:1,+TIUEDT'>0:1,+TIULDT'>0:1,+TIUVLOC'>0:1,1:0) Q | 
|---|
| 156 | . D MAIN^TIUVSIT(.TIU,DFN,"",TIUEDT,TIULDT,"LAST",0,+TIUVLOC) | 
|---|
| 157 | Q:'$D(TIU("VSTR")) | 
|---|
| 158 | D ENQ^TIUPXAP1 ; Get/file VISIT | 
|---|
| 159 | Q | 
|---|