[613] | 1 | RORUTL07 ;HCIOFO/SG - TEST ENTRY POINTS ; 11/1/05 1:12pm
|
---|
| 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006
|
---|
| 3 | ;
|
---|
| 4 | Q
|
---|
| 5 | ;
|
---|
| 6 | ;***** DISPLAYS THE ERRORS
|
---|
| 7 | ERROR ;
|
---|
| 8 | D DSPSTK^RORERR()
|
---|
| 9 | Q
|
---|
| 10 | ;
|
---|
| 11 | ;***** DATA EXTRACTION TEST ENTRY POINT
|
---|
| 12 | EXTRACT ;
|
---|
| 13 | N RORERRDL ; Default error location
|
---|
| 14 | N RORERROR ; Error processing data
|
---|
| 15 | N RORPARM ; Application parameters
|
---|
| 16 | ;
|
---|
| 17 | N RC,REGLST,REGNAME,SDT
|
---|
| 18 | W !,"DATA EXTRACTION & TRANSMISSION IN DEBUG MODE",!
|
---|
| 19 | D KILL^XUSCLEAN
|
---|
| 20 | S RORPARM("DEBUG")=2
|
---|
| 21 | S RORPARM("ERR")=1
|
---|
| 22 | D CLEAR^RORERR("EXTRACT^RORUTL07")
|
---|
| 23 | ;--- Select registries
|
---|
| 24 | Q:$$SELREG(.REGLST)'>0
|
---|
| 25 | ;--- Request a start date
|
---|
| 26 | S SDT=$$GETSDT() G:SDT<0 ERROR
|
---|
| 27 | ;--- Extract the registry data
|
---|
| 28 | S RC=$$EXTRACT^ROREXT(.REGLST,SDT,,"S") G:RC<0 ERROR
|
---|
| 29 | Q
|
---|
| 30 | ;
|
---|
| 31 | ;***** REQESTS A START DATE FROM A USER
|
---|
| 32 | ;
|
---|
| 33 | ; Return Values:
|
---|
| 34 | ; <0 Error Code
|
---|
| 35 | ; "" No start date (default)
|
---|
| 36 | ; >0 Start date
|
---|
| 37 | ;
|
---|
| 38 | GETSDT() ;
|
---|
| 39 | ;;If you enter an empty string then the individual start date
|
---|
| 40 | ;;(from the registry record) will be used for each patient.
|
---|
| 41 | ;
|
---|
| 42 | N DA,DIR,DIROUT,DIRUT,DTOUT,DUOUT,RC,X,Y
|
---|
| 43 | S DIR(0)="DO^:DT:EX"
|
---|
| 44 | S DIR("A")="Start date for data extraction"
|
---|
| 45 | F X=1:1 S Y=$P($T(GETSDT+X),";;",2) Q:Y="" S DIR("?",X)=Y
|
---|
| 46 | S DIR("?")="This response must be a date."
|
---|
| 47 | D ^DIR
|
---|
| 48 | S RC=$S($D(DTOUT):-72,$D(DUOUT):-71,1:0)
|
---|
| 49 | Q $S(RC<0:RC,1:$G(Y))
|
---|
| 50 | ;
|
---|
| 51 | ;***** SELECTS REGISTRIES FROM THE FILE #798.1
|
---|
| 52 | ;
|
---|
| 53 | ; .REGLST Reference to a local variable for the list of
|
---|
| 54 | ; registry names (subscripts) and IENs (values)
|
---|
| 55 | ;
|
---|
| 56 | ; Return Values:
|
---|
| 57 | ; <0 Error code
|
---|
| 58 | ; 0 Nothing selected
|
---|
| 59 | ; >0 Number of selected registries
|
---|
| 60 | ; "" Timeout or "^"
|
---|
| 61 | ;
|
---|
| 62 | SELREG(REGLST) ;
|
---|
| 63 | N CNT,DA,DIC,DLAYGO,DTOUT,DUOUT,X,Y
|
---|
| 64 | K REGLST S CNT=0
|
---|
| 65 | ;--- Select a registry
|
---|
| 66 | S DIC=798.1,DIC(0)="AENQ"
|
---|
| 67 | S DIC("A")="Select a Registry: "
|
---|
| 68 | F D Q:Y'>0 S REGLST($P(Y,U,2))=+Y,CNT=CNT+1
|
---|
| 69 | . D ^DIC
|
---|
| 70 | W !
|
---|
| 71 | Q $S($D(DTOUT)!$D(DUOUT):"",1:CNT)
|
---|
| 72 | ;
|
---|
| 73 | ;***** REGISTRY UPDATE TEST ENTRY POINT
|
---|
| 74 | UPDATE ;
|
---|
| 75 | N RORERRDL ; Default error location
|
---|
| 76 | N RORERROR ; Error processing data
|
---|
| 77 | N RORPARM ; Application parameters
|
---|
| 78 | ;
|
---|
| 79 | N RC,REGLST,REGNAME
|
---|
| 80 | W !,"REGISTRY UPDATE IN DEBUG MODE",!
|
---|
| 81 | D KILL^XUSCLEAN
|
---|
| 82 | S RORPARM("DEBUG")=2
|
---|
| 83 | S RORPARM("ERR")=1
|
---|
| 84 | D CLEAR^RORERR("UPDATE^RORUTL07")
|
---|
| 85 | ;--- Select registries
|
---|
| 86 | Q:$$SELREG(.REGLST)'>0
|
---|
| 87 | ;--- Update the registry
|
---|
| 88 | S RC=$$UPDATE^RORUPD(.REGLST) G:RC<0 ERROR
|
---|
| 89 | Q
|
---|