| 1 | LR334PO ;DALOI/FHS/RSH - LR*5.2*334 PATCH POST INSTALL ROUTINE;31-AUG-2001
 | 
|---|
| 2 |  ;;5.2;LAB SERVICE;**334**;Sep 27, 1994;Build 12
 | 
|---|
| 3 | PRE ;
 | 
|---|
| 4 |  ;$$HTE^XLFDT supported by DBIA #10103
 | 
|---|
| 5 |  ;$$HTFE^XLFDT supported by DBIA #10103
 | 
|---|
| 6 |  ;$$NOW^XLFDT supported by DBIA #10103
 | 
|---|
| 7 |  ;$$CJ^XLFSTR supported by DBIA #10104
 | 
|---|
| 8 |  ;^XMD supported by DBIA #10070
 | 
|---|
| 9 |  ;$$PATCH^XPDUTL supported by DBIA #10141
 | 
|---|
| 10 |  ;BMES^XPDUTL supported by DBIA #10141
 | 
|---|
| 11 |  ;SETUP^XQALERT supported by DBIA $10081
 | 
|---|
| 12 |  ;FILE^DIE supported by DBIA #10018
 | 
|---|
| 13 |  ;GETS^DIQ supported by DBIA #2056
 | 
|---|
| 14 |  ;EN^DIU2 supported by DBIA #10014
 | 
|---|
| 15 |  ;$$SITE^VASITE supported by DBIA #10112
 | 
|---|
| 16 |  ;$$FMTE^XLFDT supported by DBIA #10103
 | 
|---|
| 17 |  ;$$THE^XLFDT supported by DBIA #10103
 | 
|---|
| 18 |  ;$$HTFM^XLFDT supported by DBIA #10103
 | 
|---|
| 19 |  Q:'$D(XPDNM)
 | 
|---|
| 20 | VENDOR ;Save the vender pointer name into the VENDOR field.
 | 
|---|
| 21 |  N LRI,LRVEN
 | 
|---|
| 22 |  S LRI=0 F  S LRI=$O(^LAB(64.2,LRI)) Q:LRI<1  S LRVEN=$P($G(^(LRI,0)),U,14) I LRVEN D
 | 
|---|
| 23 |  . S LRVEN=$P($G(^LAB(64.3,+LRVEN,0)),U)
 | 
|---|
| 24 |  . I $L(LRVEN) S $P(^LAB(64.2,LRI,2),U,2)=LRVEN
 | 
|---|
| 25 |  I '$D(^XTMP("LRNLT642")) D
 | 
|---|
| 26 |  . N LRLAST
 | 
|---|
| 27 |  . S LRLAST=$O(^LAB(64.2,99999),-1)
 | 
|---|
| 28 |  . S ^XTMP("LRNLT642",.01)=LRLAST
 | 
|---|
| 29 |  . S ^XTMP("LRNLT642",0)=$$HTFM^XLFDT($H+90,1)_"^"_DT_"^ LAB(64.2 Save"
 | 
|---|
| 30 |  . M ^XTMP("LRNLT642",1)=^LAB(64.2)
 | 
|---|
| 31 |  Q
 | 
|---|
| 32 | EN1 ;Find and correct existing spelling or duplicate numbers errors.
 | 
|---|
| 33 |  N DA,DIC,DIK,DIU,X,Y,DIRUT,DTOUT,DUOUT
 | 
|---|
| 34 | REINDEX ;Reindex LAM to fire new x-refs
 | 
|---|
| 35 |  L +^LAM:999 I '$T G EN1
 | 
|---|
| 36 |  D
 | 
|---|
| 37 |  . N DIK
 | 
|---|
| 38 |  . S DIK="^LAM(" D IXALL^DIK
 | 
|---|
| 39 |  . S $P(^LAM(0),U,3)=99999
 | 
|---|
| 40 |  K ^XTMP("LRNLTERR","LR334") S ^XTMP("LRNLTERR",0)=$$HTFM^XLFDT($H+90,1)_"^"_DT_"^LR52 334 Error Messages"
 | 
|---|
| 41 |  K ^XTMP("LRNLT","LR334")
 | 
|---|
| 42 |  S ^XTMP("LRNLT",0)=$$HTFM^XLFDT($H+90,1)_"^"_DT_"^LR52 334 Messages"
 | 
|---|
| 43 |  N DA,DIK,LRIEN,LRN0,LRN1,LRFILE
 | 
|---|
| 44 |  D POST,ALERT^LR334POA
 | 
|---|
| 45 |  Q
 | 
|---|
| 46 |  ;
 | 
|---|
| 47 | CHK N DIC,X,Y
 | 
|---|
| 48 |  K LRFDA,LRANS,LRNAMX,LRNUMX,LRNAMY,LRNUMY
 | 
|---|
| 49 |  S DIC(0)="ZNMO",(LRNAMX,LRNAMY,X)=$P(LRN0,U)
 | 
|---|
| 50 |  I $G(LRFILE)=64 D
 | 
|---|
| 51 |  . S DIC=64,(LRNUMY,LRNUMX)=$P(LRN0,U,2)
 | 
|---|
| 52 |  . S DIC("S")="I $P(^(0),U,2)=LRNUMX"
 | 
|---|
| 53 |  . D ^DIC I Y<1 D DEL Q
 | 
|---|
| 54 |  . W:$G(LRDBUG) !,Y_" ( "_LRFILE
 | 
|---|
| 55 |  . S LRIENS=+Y_","
 | 
|---|
| 56 |  . I $L($P(LRN0,U,8)) D
 | 
|---|
| 57 |  . . S LRNAMY=$P(LRN0,U,8)
 | 
|---|
| 58 |  . . S LRFDA(LRFILE,LRIENS,.01)=LRNAMY
 | 
|---|
| 59 |  . I $P(LRN0,U,3) D
 | 
|---|
| 60 |  . . S LRNUMY=$P(LRN0,U,3)
 | 
|---|
| 61 |  . . Q:$O(^LAM("C",LRNUMY_" ",0))
 | 
|---|
| 62 |  . . S LRFDA(LRFILE,LRIENS,1)=LRNUMY
 | 
|---|
| 63 |  I $G(LRFILE)=64.2 D
 | 
|---|
| 64 |  . N DIC
 | 
|---|
| 65 |  . S (LRNAMX,LRNAMY,X)=$P(LRN0,U)
 | 
|---|
| 66 |  . S DIC=64.2,LRNUMX=$P(LRN1,U,2)
 | 
|---|
| 67 |  . S DIC("S")="I $P(^(0),U,2)=LRNUMX"
 | 
|---|
| 68 |  . D ^DIC I Y<1 D DEL Q
 | 
|---|
| 69 |  . S LRIENS=+Y_","
 | 
|---|
| 70 |  . I $L($P(LRN0,U,8)) D
 | 
|---|
| 71 |  . . S LRNAMY=$P(LRN0,U,8)
 | 
|---|
| 72 |  . . S LRFDA(LRFILE,LRIENS,.01)=LRNAMY
 | 
|---|
| 73 |  . I $P(LRN1,U,3) D
 | 
|---|
| 74 |  . . S LRNUMY=$P(LRN1,U,3)
 | 
|---|
| 75 |  . . S LRFDA(LRFILE,LRIENS,1)=LRNUMY
 | 
|---|
| 76 |  . I $L($P(LRN1,U,7)) D
 | 
|---|
| 77 |  . . S LRSYN=$P(LRN1,U,7),LRSYNIEN=$O(^LAB(64.2,+LRIENS,1,"B",LRSYN,0))
 | 
|---|
| 78 |  . . Q:'LRSYNIEN
 | 
|---|
| 79 |  . . S LRFDA(64.23,LRSYNIEN_","_LRIENS,.01)="@"
 | 
|---|
| 80 |  . W:$G(LRDBUG) !,Y_" ( "_LRFILE
 | 
|---|
| 81 |  I $D(LRFDA) D SET
 | 
|---|
| 82 |  Q
 | 
|---|
| 83 | SET ;
 | 
|---|
| 84 |  D FILE^DIE("KS","LRFDA","LRANS")
 | 
|---|
| 85 |  I '$D(LRANS) W:$G(LRDBUG) !,"Okay" D  Q
 | 
|---|
| 86 |  . D WRT,DEL
 | 
|---|
| 87 |  Q  ; EDIT ERRORS are left in ^LAB(64.81)
 | 
|---|
| 88 |  ;
 | 
|---|
| 89 | DEL ;
 | 
|---|
| 90 |  N DA,DIK
 | 
|---|
| 91 |  S DA=LRIEN,DIK="^LAB(64.81," D ^DIK
 | 
|---|
| 92 |  Q
 | 
|---|
| 93 | ERR ;
 | 
|---|
| 94 |  W !,LRIEN_" ( "_LRFILE_" ERROR"
 | 
|---|
| 95 |  Q
 | 
|---|
| 96 | WRT ;
 | 
|---|
| 97 |  D SCR(LRNUMX_"    "_LRNAMX)
 | 
|---|
| 98 |  D SCR("Was changed to: "_LRNUMY_"    "_LRNAMY)
 | 
|---|
| 99 |  Q
 | 
|---|
| 100 | POST ;TRANSPORT FILE 64.81 INTO FILE 64 IF REQUIRED
 | 
|---|
| 101 |  N LRREC,LRREC9
 | 
|---|
| 102 |  K ^XTMP("LRNLT","LR334") D
 | 
|---|
| 103 |  . S ^XTMP("LRNLT",0)=$$HTFM^XLFDT($H+90,1)_U_DT_U_"LR334 Added NLT Codes List"
 | 
|---|
| 104 |  . S ^XTMP("LRNLT","LR334",0)=""
 | 
|---|
| 105 |  ;D DSS W !
 | 
|---|
| 106 | P1 F  L +^LAM:10 Q:$T  D BMES^LR334("Attempting to Lock ^LAM Global.")
 | 
|---|
| 107 |  S (LRLAST64,LRNEXT)=$O(^LAM(99999),-1)
 | 
|---|
| 108 |  S:LRNEXT<1 (LRLAST64,LRNEXT)=0
 | 
|---|
| 109 |  S $P(^LAM(0),U,3)=LRNEXT
 | 
|---|
| 110 |  S LRN=$O(^XTMP("LRNLT642",1,99999),-1)
 | 
|---|
| 111 |  S (LRADD,LRCHG,LRDOT)=0
 | 
|---|
| 112 |  D SCR("==========================")
 | 
|---|
| 113 |  D SCR("List of WKLD CODES added to ^LAM  (#64)")
 | 
|---|
| 114 |  D SCR(" ")
 | 
|---|
| 115 |  S LRNEXT=0,LRIEN=50
 | 
|---|
| 116 |  F  S LRNEXT=$O(^LAB(64.81,LRIEN,2,LRNEXT)) Q:LRNEXT<1  D
 | 
|---|
| 117 |  . K LRFDA,LROUT,LRAR1,LRSIXT4
 | 
|---|
| 118 |  . S LRDOT=$G(LRDOT)+1 I LRDOT#50=0 W ". "
 | 
|---|
| 119 |  . S LRREC=^LAB(64.81,LRIEN,2,LRNEXT,0),LRERR=0
 | 
|---|
| 120 |  . S LRREC9=+$G(^LAB(64.81,LRIEN,2,LRNEXT,9))
 | 
|---|
| 121 |  . I $G(LRDBUG) W !,LRREC_" "
 | 
|---|
| 122 |  . S LRTRIEN=$P(LRREC,U)
 | 
|---|
| 123 |  . I $S($P(LRREC,U,2)["~":1,$P($P(LRREC,U,3),".",2):1,1:0) D KREC Q
 | 
|---|
| 124 |  . D CMP
 | 
|---|
| 125 |  . Q:LRERR
 | 
|---|
| 126 |  . I LRCHG D CHGNM
 | 
|---|
| 127 |  . I LRADD D GNDE
 | 
|---|
| 128 |  . I $S($G(LROUT(42,"DIERR")):0,$G(LROUT(45,"DIERR")):0,1:1) D KREC
 | 
|---|
| 129 |  . K LROUT
 | 
|---|
| 130 |  S $P(^LAM(0),U,3)=99999
 | 
|---|
| 131 |  D:'$G(LRDBUG) MAIL^LR334POA
 | 
|---|
| 132 | KIL K LRADD,LRANS,LRAR1,LRBEG,LRCHG,LRCNT,LRCODE,LRCTR,LRDOT,LREND
 | 
|---|
| 133 |  K LRENODE,LRERR,LRFDA,LRFILE,LRFLD,LRFLE,LRFNAM,LRI,LRIEN,LRIENS
 | 
|---|
| 134 |  K LRMLT,LRN,LRN0,LRN1,LRNAMX,LRNAMY,LRNEXT,LRNIEN,LRNODE,LRNUM
 | 
|---|
| 135 |  K LRNUMX,LRNUMY,LRNX,LROUT,LRPROCNM,LRREC,LRSC,LRSCR,LRSEQ,LRSIXT4
 | 
|---|
| 136 |  K LRSUBFLE,LRSYN,LRSYNIEN,LRTRIEN,LRVAL,LRVR,X,Y
 | 
|---|
| 137 |  Q
 | 
|---|
| 138 | CHGNM ; CHANGE THE PROCEDURE NAME IN THE RECORD
 | 
|---|
| 139 |  K LRFDA
 | 
|---|
| 140 |  S LRFDA(42,64,LRCHG_",",.01)=LRPROCNM
 | 
|---|
| 141 |  D FILE^DIE("K","LRFDA(42)","LROUT(42)")
 | 
|---|
| 142 |  I $G(LROUT(42,"DIERR")) D
 | 
|---|
| 143 |  . S LRERR=1
 | 
|---|
| 144 |  . S LRENODE="LROUT(42,""DIERR"")"
 | 
|---|
| 145 |  . D ERMSG
 | 
|---|
| 146 |  I '$G(LROUT(42,"DIERR")) D SCR(LRCODE_"|"_LRPROCNM_"|"_"**Procedure Name Changed**")
 | 
|---|
| 147 |  K LRFDA(42),LRPROCNM
 | 
|---|
| 148 |  Q
 | 
|---|
| 149 | CMP ; COMPARE FOUND CODES AND PROCEDURE NAMES
 | 
|---|
| 150 |  N DIC,X,Y,ANS
 | 
|---|
| 151 |  S (LRADD,LRCHG,LRERR)=0
 | 
|---|
| 152 |  S LRCODE=$P(LRREC,U,3),LRPROCNM=$P(LRREC,U,2)
 | 
|---|
| 153 |  S Y=+$$FIND1^DIC(64,"","XO",LRCODE_" ","C","","ANS")
 | 
|---|
| 154 |  I Y<1 D
 | 
|---|
| 155 |  . S LRADD=1,LRN=$G(LRN)+1
 | 
|---|
| 156 |  . D SCR(LRCODE_"|"_LRPROCNM_"|")
 | 
|---|
| 157 |  I Y>1,$G(LRREC9) D
 | 
|---|
| 158 |  . I $D(^LAM(+Y,0)),$G(^LAM(+Y,9))<1 S $P(^LAM(+Y,9),U)=LRREC9
 | 
|---|
| 159 |  Q
 | 
|---|
| 160 | SCR(LRMSG) ;Store message in ^XTMP("LRNLT" Global
 | 
|---|
| 161 |  S LRSCR=$G(^XTMP("LRNLT","LR334",1,0))+1,^(0)=LRSCR
 | 
|---|
| 162 |  S ^XTMP("LRNLT","LR334",1,LRSCR)=LRSCR_"|"_LRMSG
 | 
|---|
| 163 |  Q
 | 
|---|
| 164 | SETUP ; SETS UP THE FDA ARRAY TO ADD A NODE
 | 
|---|
| 165 |  F  S LRNODE=$Q(@LRNODE) Q:LRNODE=""  D
 | 
|---|
| 166 |  . S LRFLE=$QS(LRNODE,1)
 | 
|---|
| 167 |  . S LRFLD=$QS(LRNODE,3)
 | 
|---|
| 168 |  . I LRFLE=64.8117 D
 | 
|---|
| 169 |  . . S LRSUBFLE=64
 | 
|---|
| 170 |  . . I LRFLD=1 S LRFLD=.01
 | 
|---|
| 171 |  . . I LRFLD>1 S LRFLD=LRFLD-1
 | 
|---|
| 172 |  . . S LRIENS="+"_LRTRIEN_","
 | 
|---|
| 173 |  . I LRFLE'=64.8117 D
 | 
|---|
| 174 |  . .; CONSTRUCT THE SUBFILE NUMBER FOR FILE 64 FROM 64.81
 | 
|---|
| 175 |  . . S LRBEG=$P(LRFLE,"8117")
 | 
|---|
| 176 |  . . S LREND=$P(LRFLE,"8117",2)
 | 
|---|
| 177 |  . . S LRSUBFLE=LRBEG_"0"_LREND
 | 
|---|
| 178 |  . . I LRFLD=.01 S LRSEQ=LRSEQ+1
 | 
|---|
| 179 |  . . S LRIENS="+"_LRSEQ_","_"+"_LRTRIEN_","
 | 
|---|
| 180 |  . S LRVAL=@LRNODE
 | 
|---|
| 181 |  . S LRFDA(45,LRSUBFLE,LRIENS,LRFLD)=LRVAL
 | 
|---|
| 182 |  . ;W !,"LRFDA(45,"_LRSUBFLE_","_LRIENS_LRFLD_")="_LRVAL
 | 
|---|
| 183 |  K LRAR1
 | 
|---|
| 184 |  Q
 | 
|---|
| 185 | GNDE ; RETRIEVES NODES FROM THE TRANSPORT MULTIPLE
 | 
|---|
| 186 |  S LRMLT="",LRCTR=1
 | 
|---|
| 187 |  D GETS^DIQ(64.8117,LRTRIEN_","_LRIEN_",",LRMLT_"*","INZ","LRAR1")
 | 
|---|
| 188 |  S LRNODE="LRAR1(64.8117_LRMLT)"
 | 
|---|
| 189 |  D SETUP
 | 
|---|
| 190 |  I $D(^LAB(64.81,50,2,LRTRIEN,1,0)) S LRNUM=$P(^LAB(64.81,50,2,LRTRIEN,1,0),U,4),LRSEQ=LRNUM+1
 | 
|---|
| 191 |  E  I '$D(^LAB(64.81,50,2,LRTRIEN,1,0)) S LRSEQ=2
 | 
|---|
| 192 |  S LRMLT=18
 | 
|---|
| 193 |  D GETS^DIQ(64.8117,LRTRIEN_","_LRIEN_",",LRMLT_"*","INZ","LRAR1")
 | 
|---|
| 194 |  S LRNODE="LRAR1(64.8117_LRMLT)"
 | 
|---|
| 195 |  D SETUP
 | 
|---|
| 196 |  S LRMLT=19,LRSEQ=1
 | 
|---|
| 197 |  D GETS^DIQ(64.8117,LRTRIEN_","_LRIEN_",",LRMLT_"*","INZ","LRAR1")
 | 
|---|
| 198 |  S LRNODE="LRAR1(64.8117_LRMLT)"
 | 
|---|
| 199 |  D SETUP
 | 
|---|
| 200 |  D AREC I $G(LRDBUG) W !,"NEW IEN=",$G(LRSIXT4(LRTRIEN))
 | 
|---|
| 201 |  K LRSIXT4,LRFDA(45)
 | 
|---|
| 202 |  Q
 | 
|---|
| 203 | AREC ; ADDS ENTRIES FROM THE TRANSPORT MULTIPLE TO FILE 64
 | 
|---|
| 204 |  D UPDATE^DIE("","LRFDA(45)","LRSIXT4","LROUT(45)")
 | 
|---|
| 205 |  I $G(LROUT(45,"DIERR")) D
 | 
|---|
| 206 |  . S LRENODE="LROUT(45,""DIERR"")"
 | 
|---|
| 207 |  . D ERMSG
 | 
|---|
| 208 |  K LRFDA(45)
 | 
|---|
| 209 |  Q
 | 
|---|
| 210 | ERMSG ;STUFF THE TEMP GLOBAL WITH ANY ERROR MESSAGES
 | 
|---|
| 211 |  S LRN=$G(^XTMP("LRNLT642",1,0))+1
 | 
|---|
| 212 |  S ^XTMP("LRNLT642",1,LRN,0)="|"_LRTRIEN_"|"_LRCODE_"|"_LRPROCNM_"|ERR"
 | 
|---|
| 213 |  F  S LRENODE=$Q(@LRENODE) Q:LRENODE=""  D
 | 
|---|
| 214 |  . S LRN=LRN+1
 | 
|---|
| 215 |  . S ^XTMP("LRNLT642",1,LRN,0)="|"_LRENODE_"|="_@LRENODE
 | 
|---|
| 216 |  S ^XTMP("LRNLT642",1,0)=LRN
 | 
|---|
| 217 |  S LRERR=1
 | 
|---|
| 218 |  K LRENODE
 | 
|---|
| 219 |  Q
 | 
|---|
| 220 | KREC ; DELETES THE RECORD FROM THE FILE
 | 
|---|
| 221 |  Q:$G(LRDBUG)
 | 
|---|
| 222 |  N DA,DIK
 | 
|---|
| 223 |  S DA(1)=LRIEN,DA=LRTRIEN
 | 
|---|
| 224 |  S DIK="^LAB(64.81,"_DA(1)_",2," D ^DIK
 | 
|---|
| 225 |  Q
 | 
|---|
| 226 | DSS ;Update WKLD CODE file , DSS Feeder Key (#14) field to 'Yes"
 | 
|---|
| 227 |  ;for those NLT codes used for AP professional services
 | 
|---|
| 228 |  D BMES^LR334("Updating DSS Feeder Key for AP NLT Codes")
 | 
|---|
| 229 |  N ERR,FDA,IEN,LST,OUT,NODE,X
 | 
|---|
| 230 |  S NODE="^LAB(64.81,""AC"")"
 | 
|---|
| 231 |  F  S NODE=$Q(@NODE) Q:$QS(NODE,2)'="AC"  D
 | 
|---|
| 232 |  . S X=$P($$GET1^DIQ(64.8117,$QS(NODE,5)_","_$QS(NODE,4)_",",2,"I","ERR"),".")
 | 
|---|
| 233 |  . Q:'X
 | 
|---|
| 234 |  . K OUT,ERR
 | 
|---|
| 235 |  . D FIND^DIC(64,"","@;1","M",X,"","C","","","OUT","ERR")
 | 
|---|
| 236 |  . Q:$D(ERR)
 | 
|---|
| 237 |  . S LST=0 F  S LST=$O(OUT("DILIST",2,LST)) Q:'LST  D
 | 
|---|
| 238 |  . . S IEN=$G(OUT("DILIST",2,LST))
 | 
|---|
| 239 |  . . Q:'($D(^LAM(IEN,0))#2)
 | 
|---|
| 240 |  . . K FDA,ERR S FDA(1,64,IEN_",",14)=1
 | 
|---|
| 241 |  . . D FILE^DIE("","FDA(1)","ERR")
 | 
|---|
| 242 |  . . I $D(ERR) W !,$C(7),ERR
 | 
|---|
| 243 |  . . W "*"
 | 
|---|
| 244 |  D BMES^LR334("Update DSS AP Feeder Key Complete")
 | 
|---|
| 245 |  Q
 | 
|---|