| [613] | 1 | RORRP034 ;HCIOFO/SG - RPC: HIV PATIENT SAVE/CANCEL ; 1/29/07 9:54am
 | 
|---|
 | 2 |  ;;1.5;CLINICAL CASE REGISTRIES;**2**;Feb 17, 2006;Build 6
 | 
|---|
 | 3 |  ;
 | 
|---|
 | 4 |  Q
 | 
|---|
 | 5 |  ;
 | 
|---|
 | 6 |  ;***** UPDATES THE PATIENT'S REGISTRY DATA
 | 
|---|
 | 7 |  ; RPC: [RORICR PATIENT SAVE]
 | 
|---|
 | 8 |  ;
 | 
|---|
 | 9 |  ; .RESULTS      Reference to a local variable where the results
 | 
|---|
 | 10 |  ;               are returned to.
 | 
|---|
 | 11 |  ;
 | 
|---|
 | 12 |  ; REGIEN        Registry IEN
 | 
|---|
 | 13 |  ;
 | 
|---|
 | 14 |  ; PTIEN         IEN of the registry patient (DFN)
 | 
|---|
 | 15 |  ;
 | 
|---|
 | 16 |  ; [CANCEL]      Cancel the update and unlock the registry data
 | 
|---|
 | 17 |  ;
 | 
|---|
 | 18 |  ; .DATA         Reference to a local array that contains the data
 | 
|---|
 | 19 |  ;               in the same format as the output of the RORICR
 | 
|---|
 | 20 |  ;               PATIENT LOAD remote procedure. Only PH, ICR, and
 | 
|---|
 | 21 |  ;               LFV segments are processed; the others are ignored.
 | 
|---|
 | 22 |  ;
 | 
|---|
 | 23 |  ; Return Values:
 | 
|---|
 | 24 |  ;
 | 
|---|
 | 25 |  ; A negative value of the first "^"-piece of the RESULTS(0)
 | 
|---|
 | 26 |  ; indicates an error (see the RPCSTK^RORERR procedure for more
 | 
|---|
 | 27 |  ; details).
 | 
|---|
 | 28 |  ;
 | 
|---|
 | 29 |  ; Otherwise, zero is returned in the RESULTS(0).
 | 
|---|
 | 30 |  ;
 | 
|---|
 | 31 | SAVE(RESULTS,REGIEN,PTIEN,CANCEL,DATA) ;
 | 
|---|
 | 32 |  N IENS,LOCK,RC,RORERRDL
 | 
|---|
 | 33 |  D CLEAR^RORERR("SAVE^RORRP034",1)
 | 
|---|
 | 34 |  K RESULTS  S (RESULTS(0),RC)=0
 | 
|---|
 | 35 |  D
 | 
|---|
 | 36 |  . ;--- Registry IEN
 | 
|---|
 | 37 |  . I $G(REGIEN)'>0  D  Q
 | 
|---|
 | 38 |  . . S RC=$$ERROR^RORERR(-88,,,,"REGIEN",$G(REGIEN))
 | 
|---|
 | 39 |  . S REGIEN=+REGIEN
 | 
|---|
 | 40 |  . ;--- Patient IEN
 | 
|---|
 | 41 |  . I $G(PTIEN)'>0  D  Q
 | 
|---|
 | 42 |  . . S RC=$$ERROR^RORERR(-88,,,,"PTIEN",$G(PTIEN))
 | 
|---|
 | 43 |  . S PTIEN=+PTIEN
 | 
|---|
 | 44 |  . ;--- Get the IENS of the registry record
 | 
|---|
 | 45 |  . S IENS=$$PRRIEN^RORUTL01(PTIEN,REGIEN)_","
 | 
|---|
 | 46 |  . S:IENS>0 (LOCK(798,IENS),LOCK(799.4,IENS))=""
 | 
|---|
 | 47 |  . Q:$G(CANCEL)
 | 
|---|
 | 48 |  . ;--- Save the data
 | 
|---|
 | 49 |  . S RC=$$SAVE1(.IENS)
 | 
|---|
 | 50 |  . I '$D(LOCK)  S:IENS>0 (LOCK(798,IENS),LOCK(799.4,IENS))=""
 | 
|---|
 | 51 |  . S:RC>0 RESULTS(0)=RC
 | 
|---|
 | 52 |  ;
 | 
|---|
 | 53 |  ;--- Do not unlock the records if there are errors in the data
 | 
|---|
 | 54 |  ;    (positive value is returned by the $$SAVE1), since the user
 | 
|---|
 | 55 |  ;--- will have another chance to correct the data and save it.
 | 
|---|
 | 56 |  D:RC'>0 UNLOCK^RORLOCK(.LOCK)
 | 
|---|
 | 57 |  D:RC<0 RPCSTK^RORERR(.RESULTS,RC)
 | 
|---|
 | 58 |  Q
 | 
|---|
 | 59 |  ;
 | 
|---|
 | 60 |  ;***** INTERNAL ENTRY POINT THAT UPDATES THE REGISTRY DATA
 | 
|---|
 | 61 | SAVE1(IENS798) ;
 | 
|---|
 | 62 |  N IENS,LFIEN,LFV,RC,RDI,REGNAME,RORFDA,RORMSG,SEG,TMP
 | 
|---|
 | 63 |  ;
 | 
|---|
 | 64 |  ;=== Add the patient to the registry if necessary
 | 
|---|
 | 65 |  I IENS798'>0  S RC=0  D  Q:RC<0 RC
 | 
|---|
 | 66 |  . S REGNAME=$P($$REGNAME^RORUTL01(REGIEN),U)
 | 
|---|
 | 67 |  . ;--- Add the patient to the registry
 | 
|---|
 | 68 |  . S RC=$$ADDPAT^RORUPD06(PTIEN,REGNAME)  Q:RC<0
 | 
|---|
 | 69 |  . ;--- Get the IENS of the registry record
 | 
|---|
 | 70 |  . S IENS798=$$PRRIEN^RORUTL01(PTIEN,REGIEN)_","
 | 
|---|
 | 71 |  . S:IENS798'>0 RC=$$ERROR^RORERR(-97,,,PTIEN,REGNAME)
 | 
|---|
 | 72 |  ;
 | 
|---|
 | 73 |  ;=== Prepare the data
 | 
|---|
 | 74 |  S (LFCNT,RDI,RC)=0
 | 
|---|
 | 75 |  F  S RDI=$O(DATA(RDI))  Q:RDI'>0  D  Q:RC
 | 
|---|
 | 76 |  . S SEG=$P(DATA(RDI),U)
 | 
|---|
 | 77 |  . ;--- Risk factors
 | 
|---|
 | 78 |  . I SEG="PH"  D  Q
 | 
|---|
 | 79 |  . . S RC=$$CDCFDA^RORRP026(IENS798,"PH^RORRP026",DATA(RDI),.RORFDA)
 | 
|---|
 | 80 |  . ;--- Registry data
 | 
|---|
 | 81 |  . I SEG="ICR"  D  Q
 | 
|---|
 | 82 |  . . S TMP=$P(DATA(RDI),U,3)
 | 
|---|
 | 83 |  . . S RORFDA(799.4,IENS798,.02)=TMP
 | 
|---|
 | 84 |  . . S RORFDA(799.4,IENS798,.03)=$S(TMP:$P(DATA(RDI),U,4),1:"")
 | 
|---|
 | 85 |  . ;--- Local field values
 | 
|---|
 | 86 |  . I SEG="LFV"  D  Q
 | 
|---|
 | 87 |  . . S LFIEN=+$P(DATA(RDI),U,3)
 | 
|---|
 | 88 |  . . S:LFIEN>0 LFV(LFIEN)=DATA(RDI)
 | 
|---|
 | 89 |  Q:RC RC
 | 
|---|
 | 90 |  ;
 | 
|---|
 | 91 |  ;=== Confirm the pending patient
 | 
|---|
 | 92 |  D:$$GET1^DIQ(798,IENS798,3,"I",,"RORMSG")=4
 | 
|---|
 | 93 |  . ;--- Do not clear the DON'T SEND flag for 'test' patients
 | 
|---|
 | 94 |  . S:'$$TESTPAT^RORUTL01(PTIEN) RORFDA(798,IENS798,11)="@"
 | 
|---|
 | 95 |  . ;--- Change the STATUS from 'Pending' to 'Active'
 | 
|---|
 | 96 |  . S RORFDA(798,IENS798,3)=0
 | 
|---|
 | 97 |  ;
 | 
|---|
 | 98 |  ;=== Update local fields
 | 
|---|
 | 99 |  S RC=$$UPDLFV^RORUTL19(IENS798,.LFV)  Q:RC<0 RC
 | 
|---|
 | 100 |  S:RC RORFDA(798,IENS798,5)=1  ; UPDATE LOCAL REGISTRY DATA
 | 
|---|
 | 101 |  ;
 | 
|---|
 | 102 |  ;=== Update the record(s)
 | 
|---|
 | 103 |  I $D(RORFDA)>1  D  Q:RC<0 RC
 | 
|---|
 | 104 |  . S RORFDA(798,IENS798,5)=1  ; UPDATE LOCAL REGISTRY DATA
 | 
|---|
 | 105 |  . D FILE^DIE(,"RORFDA","RORMSG")
 | 
|---|
 | 106 |  . S:$G(DIERR) RC=$$DBS^RORERR("RORMSG",-9,,PTIEN,"798&799.4",IENS798)
 | 
|---|
 | 107 |  ;
 | 
|---|
 | 108 |  ;=== Success
 | 
|---|
 | 109 |  Q 0
 | 
|---|