| [613] | 1 | RORUPD50 ;HCIOFO/SG - UPDATE THE PATIENT IN THE REGISTRIES  ; 8/2/05 9:14am | 
|---|
|  | 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006 | 
|---|
|  | 3 | ; | 
|---|
|  | 4 | Q | 
|---|
|  | 5 | ; | 
|---|
|  | 6 | ;***** ADDS THE PATIENT TO THE REGISTRY | 
|---|
|  | 7 | ; | 
|---|
|  | 8 | ; PATIEN        Patient IEN | 
|---|
|  | 9 | ; REGIEN        Registry IEN | 
|---|
|  | 10 | ; | 
|---|
|  | 11 | ; [ROR8RULS]    Closed root of a local array containing list of | 
|---|
|  | 12 | ;               triggered selection rules: | 
|---|
|  | 13 | ;                 @ROR8RULS@(RuleIEN)=Date | 
|---|
|  | 14 | ;               If this parameter is not defined or equals to | 
|---|
|  | 15 | ;               an empty string, selection rules are loaded from | 
|---|
|  | 16 | ;               corresponding sub-node of the ^TMP("RORUPD",$J,"U"). | 
|---|
|  | 17 | ; | 
|---|
|  | 18 | ; [[.]DOD]      Date of death. If this parameter is undefined, | 
|---|
|  | 19 | ;               its value will be taken from the ROR PATIENT file. | 
|---|
|  | 20 | ;               If you are going to call this function several times | 
|---|
|  | 21 | ;               for the same patient (for different registries), | 
|---|
|  | 22 | ;               pass a reference to undefined local variable (the | 
|---|
|  | 23 | ;               DOD will be read from the file only once). | 
|---|
|  | 24 | ; | 
|---|
|  | 25 | ; Return values: | 
|---|
|  | 26 | ;       <0  Error code | 
|---|
|  | 27 | ;        0  Ok | 
|---|
|  | 28 | ;        1  Patient has already existed in the registry | 
|---|
|  | 29 | ; | 
|---|
|  | 30 | ADD(PATIEN,REGIEN,ROR8RULS,DOD) ; | 
|---|
|  | 31 | N I,IENS,IENS01,RC,RORFDA,RORIEN,RORMSG,RULEIEN,TMP | 
|---|
|  | 32 | ;--- Quit if the patient is already in the registry | 
|---|
|  | 33 | Q:$$PRRIEN^RORUTL01(PATIEN,REGIEN)>0 1 | 
|---|
|  | 34 | ; | 
|---|
|  | 35 | ;--- Prepare registry data | 
|---|
|  | 36 | K RORFDA  S IENS="+1," | 
|---|
|  | 37 | S RORFDA(798,IENS,.01)=PATIEN           ; Patient Name | 
|---|
|  | 38 | S RORFDA(798,IENS,.02)=REGIEN           ; Registry | 
|---|
|  | 39 | S RORFDA(798,IENS,3)=4                  ; Pending | 
|---|
|  | 40 | S RORFDA(798,IENS,4)=1                  ; Update Demographics | 
|---|
|  | 41 | S RORFDA(798,IENS,5)=1                  ; Update Local Data | 
|---|
|  | 42 | S RORFDA(798,IENS,11)=1                 ; Don't Send | 
|---|
|  | 43 | ;--- Get the date of death | 
|---|
|  | 44 | S:'($D(DOD)#10) DOD=$$GET1^DIQ(798.4,PATIEN_",",.351,"I",,"RORMSG") | 
|---|
|  | 45 | ;--- Load list of triggered rules | 
|---|
|  | 46 | S:$G(ROR8RULS)="" ROR8RULS=$NA(@RORUPDPI@("U",PATIEN,2,REGIEN)) | 
|---|
|  | 47 | S RULEIEN="" | 
|---|
|  | 48 | F I=1:1  S RULEIEN=$O(@ROR8RULS@(RULEIEN))  Q:RULEIEN=""  D | 
|---|
|  | 49 | . S IENS01="+"_(1000+I)_","_IENS | 
|---|
|  | 50 | . S RORFDA(798.01,IENS01,.01)=RULEIEN  ; SELECTION RULE | 
|---|
|  | 51 | . S TMP=$P(@ROR8RULS@(RULEIEN),U)\1 | 
|---|
|  | 52 | . S:TMP>0 RORFDA(798.01,IENS01,1)=TMP  ; DATE | 
|---|
|  | 53 | . S TMP=+$P(@ROR8RULS@(RULEIEN),U,2) | 
|---|
|  | 54 | . S:TMP>0 RORFDA(798.01,IENS01,2)=TMP  ; LOCATION | 
|---|
|  | 55 | ; | 
|---|
|  | 56 | ;--- Registry update transaction | 
|---|
|  | 57 | S RC=0  D | 
|---|
|  | 58 | . ;--- Call "before update" entry point | 
|---|
|  | 59 | . S ENTRY=$G(RORUPD("UPD",REGIEN,1)) | 
|---|
|  | 60 | . I ENTRY'=""  X "S RC="_ENTRY_"(.RORFDA,PATIEN,REGIEN)"  Q:RC<0 | 
|---|
|  | 61 | . ;--- Make sure that the DON'T SEND flag is set for 'test' patient | 
|---|
|  | 62 | . S:$$TESTPAT^RORUTL01(PATIEN) RORFDA(798,IENS,11)=1 | 
|---|
|  | 63 | . ;--- Update the registry | 
|---|
|  | 64 | . D UPDATE^DIE(,"RORFDA","RORIEN","RORMSG") | 
|---|
|  | 65 | . I $G(DIERR)  S RC=$$DBS^RORERR("RORMSG",-9)  Q | 
|---|
|  | 66 | . ;--- Call "after update" entry point | 
|---|
|  | 67 | . S ENTRY=$G(RORUPD("UPD",REGIEN,2)) | 
|---|
|  | 68 | . I ENTRY'=""  X "S RC="_ENTRY_"(RORIEN(1),PATIEN,REGIEN)"  Q:RC<0 | 
|---|
|  | 69 | Q:RC'<0 0 | 
|---|
|  | 70 | ; | 
|---|
|  | 71 | ;--- Rollback the update in case of error(s) | 
|---|
|  | 72 | N DA,DIK | 
|---|
|  | 73 | S DIK=$$ROOT^DILFD(798),DA=$G(RORIEN(1)) | 
|---|
|  | 74 | D:DA>0 ^DIK | 
|---|
|  | 75 | Q RC | 
|---|
|  | 76 | ; | 
|---|
|  | 77 | ;***** ADDS PATIENT DATA TO THE 'ROR PATIENT' FILE | 
|---|
|  | 78 | ; | 
|---|
|  | 79 | ; PATIEN        Patient IEN | 
|---|
|  | 80 | ; | 
|---|
|  | 81 | ; Return values: | 
|---|
|  | 82 | ;       <0  Error code | 
|---|
|  | 83 | ;        0  Ok | 
|---|
|  | 84 | ;        1  Patient data have already existed | 
|---|
|  | 85 | ; | 
|---|
|  | 86 | ADDPDATA(PATIEN) ; | 
|---|
|  | 87 | N IENS,RC,RORBUF,RORPAT,RORIEN,RORMSG | 
|---|
|  | 88 | ;--- Try to find patient data | 
|---|
|  | 89 | D FIND^DIC(798.4,,"@","QUX",PATIEN,1,"B",,,"RORBUF","RORMSG") | 
|---|
|  | 90 | Q:$G(DIERR) $$DBS^RORERR("RORMSG",-9,,,798.4) | 
|---|
|  | 91 | ;--- Patient data already exists in the file | 
|---|
|  | 92 | Q:$G(RORBUF("DILIST",0)) 1 | 
|---|
|  | 93 | ;--- Check if the patient record in the file #2 is valid | 
|---|
|  | 94 | S RC=$$CHKPTR^RORUTL05(PATIEN)  Q:RC<0 RC | 
|---|
|  | 95 | ;--- Prepare patient data | 
|---|
|  | 96 | S IENS="+1," | 
|---|
|  | 97 | S RC=$$PATDATA^RORUPD52(PATIEN_",",.RORPAT,IENS)  Q:RC<0 RC | 
|---|
|  | 98 | S RORIEN(1)=PATIEN                      ; IEN of the new record | 
|---|
|  | 99 | S RORPAT(798.4,IENS,.01)=PATIEN         ; Patient Name | 
|---|
|  | 100 | ;--- Add the patient record to the file | 
|---|
|  | 101 | D UPDATE^DIE(,"RORPAT","RORIEN","RORMSG") | 
|---|
|  | 102 | I $G(DIERR)  D  Q:RC | 
|---|
|  | 103 | . S RC=$$DBS^RORERR("RORMSG",-9,,PATIEN,798.4) | 
|---|
|  | 104 | Q 0 | 
|---|
|  | 105 | ; | 
|---|
|  | 106 | ;***** ADDS THE PATIENT TO MARKED REGISTRIES | 
|---|
|  | 107 | ; | 
|---|
|  | 108 | ; PATIEN        Patient IEN | 
|---|
|  | 109 | ; | 
|---|
|  | 110 | ; Return values: | 
|---|
|  | 111 | ;       <0  Error code | 
|---|
|  | 112 | ;        0  Patient should not be added to the registry | 
|---|
|  | 113 | ;       >0  Patient has been added to the registry | 
|---|
|  | 114 | ; | 
|---|
|  | 115 | UPDREG(PATIEN) ; | 
|---|
|  | 116 | N DOD,ENTRY,INCTVDT,RC,REGIEN | 
|---|
|  | 117 | ;--- Check if patient should be added to any registry | 
|---|
|  | 118 | Q:$D(@RORUPDPI@("U",PATIEN,2))<10 0 | 
|---|
|  | 119 | ;--- Add patient data | 
|---|
|  | 120 | S RC=$$ADDPDATA(PATIEN)  Q:RC<0 RC | 
|---|
|  | 121 | ;--- Update all marked registries | 
|---|
|  | 122 | S REGIEN="",RC=0 | 
|---|
|  | 123 | F  D  Q:REGIEN=""  S RC=$$ADD(PATIEN,REGIEN,,.DOD)  Q:RC<0 | 
|---|
|  | 124 | . S REGIEN=$O(@RORUPDPI@("U",PATIEN,2,REGIEN)) | 
|---|
|  | 125 | Q $S(RC<0:RC,1:1) | 
|---|