| 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 | 
|---|