| 1 | RORUPD07 ;HCIOFO/SG - PROCESSING OF THE 'PROBLEM' FILE  ; 8/3/05 9:46am
 | 
|---|
| 2 |  ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ; This routine uses the following IAs:
 | 
|---|
| 5 |  ;
 | 
|---|
| 6 |  ; #928          ACTIVE^GMPLUTL
 | 
|---|
| 7 |  ; #2977         GETFLDS^GMPLEDT3
 | 
|---|
| 8 |  ;
 | 
|---|
| 9 |  Q
 | 
|---|
| 10 |  ;
 | 
|---|
| 11 |  ;***** LOADS DATA ELEMENT VALUES
 | 
|---|
| 12 |  ;
 | 
|---|
| 13 |  ; IENS          IENS of the current record
 | 
|---|
| 14 |  ;
 | 
|---|
| 15 |  ; Return values:
 | 
|---|
| 16 |  ;       <0  Error code
 | 
|---|
| 17 |  ;        0  Ok
 | 
|---|
| 18 |  ;
 | 
|---|
| 19 | LOAD(IENS) ;
 | 
|---|
| 20 |  N RC  S RC=0
 | 
|---|
| 21 |  ;--- API #1
 | 
|---|
| 22 |  I $D(RORUPD("SR",RORFILE,"F",1))  D  Q:RC<0 RC
 | 
|---|
| 23 |  . S RC=$$LOADFLDS^RORUPDUT(RORFILE,IENS)
 | 
|---|
| 24 |  ;--- API #2
 | 
|---|
| 25 |  I $D(RORUPD("SR",RORFILE,"F",2))  D  Q:RC<0 RC
 | 
|---|
| 26 |  . N DE,GMPFLD,GMPORIG,GMPROV,GMVAMC,IN,IP,VT
 | 
|---|
| 27 |  . S (GMPVAMC,GMPROV)=0
 | 
|---|
| 28 |  . D GETFLDS^GMPLEDT3(+IENS)
 | 
|---|
| 29 |  . ;---
 | 
|---|
| 30 |  . S DE=""
 | 
|---|
| 31 |  . F  S DE=$O(RORUPD("SR",RORFILE,"F",2,DE))  Q:DE=""  D
 | 
|---|
| 32 |  . . S VT=""
 | 
|---|
| 33 |  . . F  S VT=$O(RORUPD("SR",RORFILE,"F",2,DE,VT))  Q:VT=""  D
 | 
|---|
| 34 |  . . . S IP=+$P(RORUPD("SR",RORFILE,"F",2,DE,VT),U,1)  Q:IP'>0
 | 
|---|
| 35 |  . . . S IN=+$P(RORUPD("SR",RORFILE,"F",2,DE,VT),U,2)
 | 
|---|
| 36 |  . . . S RORVALS("DV",RORFILE,DE,VT)=$P($G(GMPFLD(IN)),U,IP)
 | 
|---|
| 37 |  Q 0
 | 
|---|
| 38 |  ;
 | 
|---|
| 39 |  ;***** PROCESSING OF THE 'PROBLEM' FILE
 | 
|---|
| 40 |  ;
 | 
|---|
| 41 |  ; UPDSTART      Date of the earliest update
 | 
|---|
| 42 |  ; PATIEN        Patient IEN
 | 
|---|
| 43 |  ;
 | 
|---|
| 44 |  ; Return values:
 | 
|---|
| 45 |  ;       <0  Error code
 | 
|---|
| 46 |  ;        0  Continue processing of the current patient
 | 
|---|
| 47 |  ;        1  Stop processing
 | 
|---|
| 48 |  ;
 | 
|---|
| 49 | PROBLEM(UPDSTART,PATIEN) ;
 | 
|---|
| 50 |  N RORFILE       ; File number
 | 
|---|
| 51 |  N RORPLST       ; List of patient problems
 | 
|---|
| 52 |  ;
 | 
|---|
| 53 |  N DATE,IS,LOCATION,PROBIENS,RC,TMP
 | 
|---|
| 54 |  S RORFILE=9000011
 | 
|---|
| 55 |  ;--- Check if the problem list has been modified in
 | 
|---|
| 56 |  ;    the data scan period of the patient.
 | 
|---|
| 57 |  Q:$$MOD^GMPLUTL3(PATIEN)<UPDSTART 0
 | 
|---|
| 58 |  ;--- Load a list of active problems
 | 
|---|
| 59 |  D ACTIVE^GMPLUTL(PATIEN,.RORPLST)
 | 
|---|
| 60 |  ;
 | 
|---|
| 61 |  ;--- Browse through the problems
 | 
|---|
| 62 |  S (IS,RC)=0
 | 
|---|
| 63 |  F  S IS=$O(RORPLST(IS))  Q:IS=""  D  Q:RC
 | 
|---|
| 64 |  . S PROBIENS=+RORPLST(IS,0)_","
 | 
|---|
| 65 |  . ;--- Load necessary data elements
 | 
|---|
| 66 |  . I $D(RORUPD("SR",RORFILE,"F"))>1  D  I TMP<0 D INCEC^RORUPDUT() Q
 | 
|---|
| 67 |  . . S TMP=$$LOAD(PROBIENS)  Q:TMP<0
 | 
|---|
| 68 |  . . S TMP=$$GETDE^RORUPDUT(RORFILE,130)
 | 
|---|
| 69 |  . . S LOCATION=$S(TMP>0:$$IEN4^RORUTL18(TMP),1:"")
 | 
|---|
| 70 |  . ;--- Ignore problems entered not in the data scan period
 | 
|---|
| 71 |  . S DATE=$$GETDE^RORUPDUT(RORFILE,118)
 | 
|---|
| 72 |  . Q:(DATE<UPDSTART)!(DATE'<RORUPD("DSEND"))
 | 
|---|
| 73 |  . ;--- Apply "before" rules
 | 
|---|
| 74 |  . S RC=$$APLRULES^RORUPDUT(RORFILE,PROBIENS,"B",DATE,$G(LOCATION))
 | 
|---|
| 75 |  . I RC  D INCEC^RORUPDUT(.RC)  Q
 | 
|---|
| 76 |  . ;--- Apply "after" rules
 | 
|---|
| 77 |  . S RC=$$APLRULES^RORUPDUT(RORFILE,PROBIENS,"A",DATE,$G(LOCATION))
 | 
|---|
| 78 |  . I RC  D INCEC^RORUPDUT(.RC)  Q
 | 
|---|
| 79 |  ;
 | 
|---|
| 80 |  D CLRDES^RORUPDUT(RORFILE)
 | 
|---|
| 81 |  Q RC
 | 
|---|