| [613] | 1 | RORAPI01 ;HCIOFO/SG - CLINICAL REGISTRIES API ; 5/12/05 1:59pm | 
|---|
|  | 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006 | 
|---|
|  | 3 | ; | 
|---|
|  | 4 | ;***** EXAMPLE | 
|---|
|  | 5 | ; | 
|---|
|  | 6 | N BUF,IPD,IRD,PATIEN,RC,REGIEN | 
|---|
|  | 7 | W !,"   Patient  Registries" | 
|---|
|  | 8 | W !,"   -------  ----------" | 
|---|
|  | 9 | ;--- Initialize the patient iterator | 
|---|
|  | 10 | S RC=$$PATITER^RORAPI01(.IPD,"VA HEPC") | 
|---|
|  | 11 | I RC<0  W "RC= ",RC,!  Q | 
|---|
|  | 12 | ;--- Browse through the registry patients | 
|---|
|  | 13 | F  S PATIEN=$$NEXTPAT^RORAPI01(.IPD)  Q:PATIEN'>0  D | 
|---|
|  | 14 | . W !,$J(PATIEN,10),"  " | 
|---|
|  | 15 | . ;--- Initialize the registry iterator | 
|---|
|  | 16 | . S RC=$$REGITER^RORAPI01(.IRD,PATIEN) | 
|---|
|  | 17 | . I RC<0  W "RC= ",RC  Q | 
|---|
|  | 18 | . ;--- Browse through the patient's registry records | 
|---|
|  | 19 | . S BUF="" | 
|---|
|  | 20 | . F  S REGIEN=$$NEXTREG^RORAPI01(.IRD)  Q:REGIEN'>0  D | 
|---|
|  | 21 | . . S BUF=BUF_","_REGIEN | 
|---|
|  | 22 | . W $P(BUF,",",2,999) | 
|---|
|  | 23 | ;--- | 
|---|
|  | 24 | W ! | 
|---|
|  | 25 | Q | 
|---|
|  | 26 | ; | 
|---|
|  | 27 | ;***** RETURNS THE NEXT PATIENT IN THE REGISTRY | 
|---|
|  | 28 | ; | 
|---|
|  | 29 | ; .IDESC        Reference to the iterator descriptor created | 
|---|
|  | 30 | ;               by PATITER^RORAPI01 | 
|---|
|  | 31 | ; | 
|---|
|  | 32 | ; Return Values: | 
|---|
|  | 33 | ;       <0  Error code | 
|---|
|  | 34 | ;       ""  No more patients in the registry | 
|---|
|  | 35 | ;       >0  Patient IEN^empty | 
|---|
|  | 36 | ; | 
|---|
|  | 37 | NEXTPAT(IDESC) ; | 
|---|
|  | 38 | N RC | 
|---|
|  | 39 | F  D  Q:$G(RC) | 
|---|
|  | 40 | . ;--- Get IEN of the next registry record | 
|---|
|  | 41 | . S IDESC("IEN")=$O(^RORDATA(798,"AC",IDESC("REGIEN"),IDESC("IEN"))) | 
|---|
|  | 42 | . I IDESC("IEN")'>0  S RC="1^END"  Q | 
|---|
|  | 43 | . Q:'$$ACTIVE^RORDD(IDESC("IEN")) | 
|---|
|  | 44 | . ;--- Load the patient IEN (DFN) | 
|---|
|  | 45 | . S RC=$P($G(^RORDATA(798,IDESC("IEN"),0)),U) | 
|---|
|  | 46 | Q $S(RC="1^END":"",1:RC) | 
|---|
|  | 47 | ; | 
|---|
|  | 48 | ;***** RETURNS THE NEXT REGISTRY FOR THE PATIENT | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | ; .IDESC        Reference to the iterator descriptor created | 
|---|
|  | 51 | ;               by REGITER^RORAPI01 | 
|---|
|  | 52 | ; | 
|---|
|  | 53 | ; Return Values: | 
|---|
|  | 54 | ;       <0  Error code | 
|---|
|  | 55 | ;       ""  No more registries for the patient | 
|---|
|  | 56 | ;       >0  Registry IEN^empty | 
|---|
|  | 57 | ; | 
|---|
|  | 58 | NEXTREG(IDESC) ; | 
|---|
|  | 59 | N RC | 
|---|
|  | 60 | F  D  Q:$G(RC) | 
|---|
|  | 61 | . ;--- Get IEN of the next registry record | 
|---|
|  | 62 | . S IDESC("IEN")=$O(^RORDATA(798,"B",IDESC("PATIEN"),IDESC("IEN"))) | 
|---|
|  | 63 | . I IDESC("IEN")'>0  S RC="1^END"  Q | 
|---|
|  | 64 | . Q:'$$ACTIVE^RORDD(IDESC("IEN")) | 
|---|
|  | 65 | . ;--- Load the registry IEN | 
|---|
|  | 66 | . S RC=$P($G(^RORDATA(798,IDESC("IEN"),0)),U,2) | 
|---|
|  | 67 | Q $S(RC="1^END":"",1:RC) | 
|---|
|  | 68 | ; | 
|---|
|  | 69 | ;***** CREATES AN ITERATOR OF PATIENTS IN THE REGISTRY | 
|---|
|  | 70 | ; | 
|---|
|  | 71 | ; .IDESC        Reference to a local variable where an iterator | 
|---|
|  | 72 | ;               descriptor will be created | 
|---|
|  | 73 | ; REGNAME       Registry name | 
|---|
|  | 74 | ; [MODE]        Bit flags that define iteration mode (3 by default) | 
|---|
|  | 75 | ;                 1  Active patients | 
|---|
|  | 76 | ;                 2  Reserved | 
|---|
|  | 77 | ; | 
|---|
|  | 78 | ; Return Values: | 
|---|
|  | 79 | ;       <0  Error code | 
|---|
|  | 80 | ;        0  Ok | 
|---|
|  | 81 | ; | 
|---|
|  | 82 | PATITER(IDESC,REGNAME,MODE) ; | 
|---|
|  | 83 | N REGIEN  K IDESC | 
|---|
|  | 84 | ;--- Get an IEN of the Registry Parameters | 
|---|
|  | 85 | S REGIEN=$$REGIEN^RORUTL02(REGNAME) | 
|---|
|  | 86 | Q:REGIEN<0 REGIEN | 
|---|
|  | 87 | ;--- Setup the descriptor | 
|---|
|  | 88 | S MODE=$S($G(MODE):MODE,1:3) | 
|---|
|  | 89 | S IDESC("REGNAME")=REGNAME | 
|---|
|  | 90 | S IDESC("REGIEN")=REGIEN | 
|---|
|  | 91 | S IDESC("ACT")=MODE#2 | 
|---|
|  | 92 | S IDESC("ROOT")=$$ROOT^DILFD(798,"",1) | 
|---|
|  | 93 | S IDESC("IEN")=0 | 
|---|
|  | 94 | Q 0 | 
|---|
|  | 95 | ; | 
|---|
|  | 96 | ;***** CREATES AN ITERATOR OF THE PATIENT REGISTRIES | 
|---|
|  | 97 | ; | 
|---|
|  | 98 | ; .IDESC        Reference to a local variable where an iterator | 
|---|
|  | 99 | ;               descriptor will be created | 
|---|
|  | 100 | ; PATIEN        Patient IEN | 
|---|
|  | 101 | ; [MODE]        Bit flags that define iteration mode (3 by default) | 
|---|
|  | 102 | ;                 1  Registries where the patient is active | 
|---|
|  | 103 | ;                 2  Reserved | 
|---|
|  | 104 | ; | 
|---|
|  | 105 | ; Return Values: | 
|---|
|  | 106 | ;       <0  Error code | 
|---|
|  | 107 | ;        0  Ok | 
|---|
|  | 108 | ; | 
|---|
|  | 109 | REGITER(IDESC,PATIEN,MODE) ; | 
|---|
|  | 110 | K IDESC | 
|---|
|  | 111 | ;--- Setup the descriptor | 
|---|
|  | 112 | S MODE=$S($G(MODE):MODE,1:3) | 
|---|
|  | 113 | S IDESC("PATIEN")=PATIEN | 
|---|
|  | 114 | S IDESC("ACT")=MODE#2 | 
|---|
|  | 115 | S IDESC("ROOT")=$$ROOT^DILFD(798,"",1) | 
|---|
|  | 116 | S IDESC("IEN")=0 | 
|---|
|  | 117 | Q 0 | 
|---|