[1206] | 1 | C0CIM2 ; CCDCCR/GPL/CJE - CCR/CCD PROCESSING FOR IMMUNIZATIONS ; 01/27/10
|
---|
| 2 | ;;1.0;C0C;;Feb 16, 2010;Build 38
|
---|
| 3 | ;Copyright 2010 George Lilly, University of Minnesota and others.
|
---|
| 4 | ;Licensed under the terms of the GNU General Public License.
|
---|
| 5 | ;See attached copy of the License.
|
---|
| 6 | ;
|
---|
| 7 | ;This program is free software; you can redistribute it and/or modify
|
---|
| 8 | ;it under the terms of the GNU General Public License as published by
|
---|
| 9 | ;the Free Software Foundation; either version 2 of the License, or
|
---|
| 10 | ;(at your option) any later version.
|
---|
| 11 | ;
|
---|
| 12 | ;This program is distributed in the hope that it will be useful,
|
---|
| 13 | ;but WITHOUT ANY WARRANTY; without even the implied warranty of
|
---|
| 14 | ;MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
---|
| 15 | ;GNU General Public License for more details.
|
---|
| 16 | ;
|
---|
| 17 | ;You should have received a copy of the GNU General Public License along
|
---|
| 18 | ;with this program; if not, write to the Free Software Foundation, Inc.,
|
---|
| 19 | ;51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
---|
| 20 | ;
|
---|
| 21 | W "NO ENTRY FROM TOP",!
|
---|
| 22 | Q
|
---|
| 23 | ;
|
---|
| 24 | EXTRACT(IMMXML,DFN,IMMOUT) ; EXTRACT PROCEDURES INTO XML TEMPLATE
|
---|
| 25 | ; IMMXML AND IMMOUT ARE PASSED BY NAME SO GLOBALS CAN BE USED
|
---|
| 26 | ;
|
---|
| 27 | ; USE THE FOLLOWING TEMPLATE FOR THE RNF2 ARRAYS
|
---|
| 28 | ; THAT GET PASSED TO *GET ROUTINES
|
---|
| 29 | ;C0C[NAME]=$NA(^TMP("C0CCCR",$J,DFN,"C0C(NAME))
|
---|
| 30 | N C0CIMM
|
---|
| 31 | S C0CIMM=$NA(^TMP("C0CCCR",$J,DFN,"C0CIMM"))
|
---|
| 32 | ; USE THE FOLLOWING TEMPLATE FOR GETTING/GENERATING THE RNF2 ARRAYS
|
---|
| 33 | ; THAT GET INSERTED INTO THE XML TEMPLATE
|
---|
| 34 | ; I '$D(@C0CIMM) D GET[VISTA/RPMS](DFN,C0CIMM) ; GET VARS IF NOT THERE
|
---|
| 35 | D GETRPMS(DFN,C0CIMM) ; GET VARS IF NOT THERE
|
---|
| 36 | ; USE THE FOLLOWING TEMPATE FOR MAPPING RNF2 ARRAYS TO XML TEMPLATE
|
---|
| 37 | ; D MAP([NAME]XML,C0C[NAME],[NAME]OUT) ;MAP RESULTS FOR PROCEDURES
|
---|
| 38 | D MAP(IMMXML,C0CIMM,IMMOUT) ;MAP RESULTS FOR PROCEDURES
|
---|
| 39 | Q
|
---|
| 40 | ;
|
---|
| 41 | GETRPMS(DFN,C0CIMM) ; CALLS GET^BGOVIMM TO GET IMMUNIZATIONS.
|
---|
| 42 | ; ERETURNS THEM IN RNF2 ARRAYS PASSED BY NAME
|
---|
| 43 | ; C0CIMM: IMMUNIZATIONS
|
---|
| 44 | ; READY TO BE MAPPED TO XML BY MAP^C0CIMM
|
---|
| 45 | ; THESE RETURN ARRAYS ARE NOT INITIALIZED, BUT ARE ADDED TO IF THEY
|
---|
| 46 | ; EXIST.
|
---|
| 47 | ;
|
---|
| 48 | ; KILL OF ARRAYS IS TAKEN CARE OF IN ^C0CCCR (K ^TMP("C0CCCR",$J))
|
---|
| 49 | ;
|
---|
| 50 | ; SETUP RPC/API CALL HERE
|
---|
| 51 | ; USE START AND END DATES FROM PARAMETERS IF REQUIRED
|
---|
| 52 | N IMMA
|
---|
| 53 | D GET^BGOVIMM(.IMMA,DFN) ; RETURNS ALL RESULTS IN VISIT LOCAL VARIABLE
|
---|
| 54 | ; PREFORM SORT HERE IF NEEDED
|
---|
| 55 | ;
|
---|
| 56 | ; NO SORT REQUIRED FOR IMMUNIZATIONS
|
---|
| 57 | ;
|
---|
| 58 | ; MAP EACH ROW OF RPC/API TO RNF1 ARRAY
|
---|
| 59 | ; RNF1 ARRAY FORMAT:
|
---|
| 60 | ; VAR("NAME_OF_RIM_VARIABLE")=VALUE
|
---|
| 61 | ;
|
---|
| 62 | ; IMMUNIZATIONS ARE DONE DIFFERENTLY DUE TO THE DIFFERENT TYPES OF IMMUNIZATION RESULTS
|
---|
| 63 | ; THIS LOOP WILL GET EACH ROW, DETERMINE THE TYPE, AND CALL THE RESPECTIVE PROCESSING METHOD
|
---|
| 64 | ; THAT WILL DO THE MAPPING TO RNF1 STYLE ARRAYS
|
---|
| 65 | N C0CIM,C0CC,ZRNF
|
---|
| 66 | S C0CIM="" ; INITIALIZE FOR $O
|
---|
| 67 | F C0CC=1:1 S C0CIM=$O(@IMMA@(C0CIM)) Q:C0CIM="" D ; FOR EACH IMMUNE TYPE IN THE LIST
|
---|
| 68 | . I DEBUG W @IMMA@(C0CIM),!
|
---|
| 69 | . ; FIGURE OUT WHICH TYPE OF IMMUNIZATION IT IS (IMMUNIZATION, FORECAST, CONTRAINDICATIONS, REFUSALS)
|
---|
| 70 | . D:$P(@IMMA@(C0CIM),U,1)="I" IMMUN
|
---|
| 71 | . D:$P(@IMMA@(C0CIM),U,1)="F" FORECAST
|
---|
| 72 | . D:$P(@IMMA@(C0CIM),U,1)="C" CONTRA
|
---|
| 73 | . D:$P(@IMMA@(C0CIM),U,1)="R" REFUSE
|
---|
| 74 | . D RNF1TO2^C0CRNF(C0CIMM,"ZRNF") ;ADD THIS ROW TO THE ARRAY
|
---|
| 75 | . K ZRNF
|
---|
| 76 | ; SAVE RIM VARIABLES SEE C0CRIMA
|
---|
| 77 | N ZRIM S ZRIM=$NA(^TMP("C0CRIM","VARS",DFN,"IMMUNE"))
|
---|
| 78 | M @ZRIM=@C0CIMM@("V")
|
---|
| 79 | Q
|
---|
| 80 | ;
|
---|
| 81 | IMMUN ; PARSES IMMUNIZATION TYPE ROWS FOR RPMS
|
---|
| 82 | ; RPC FORMAT
|
---|
| 83 | ; I ^ Imm Name [2] ^ Visit Date [3] ^ V File IEN [4] ^ Other Location [5] ^ Group [6] ^ Imm IEN [7] ^ Lot [8] ^
|
---|
| 84 | ; Reaction [9] ^ VIS Date [10] ^ Age [11] ^ Visit Date [12] ^ Provider IEN~Name [13] ^ Inj Site [14] ^
|
---|
| 85 | ; Volume [15] ^ Visit IEN [16] ^ Visit Category [17] ^ Full Name [18] ^ Location IEN~Name [19] ^ Visit Locked [20]
|
---|
| 86 | ; RETRIEVE IMMUNIZATION RECORD FROM IMMUNIZATION FILE (9999999.14) FOR THIS IMMUNIZATION
|
---|
| 87 | D GETN^C0CRNF("C0CZIM",9999999.14,$P(@IMMA@(C0CIM),U,7)) ; GET IMMUNIZATION RECORD
|
---|
| 88 | ; RETIREVE IMMUNIZATION RECORD FROM V IMMUNIZATION FILE (9000010.11) FOR THIS IMMUNIZATION
|
---|
| 89 | D GETN^C0CRNF("C0CZVI",9000010.11,$P(@IMMA@(C0CIM),U,4)) ; GET V IMMUNIZATION RECORD
|
---|
| 90 | S ZRNF("IMMUNEOBJECTID")="IMMUNIZATION_"_C0CC ;UNIQUE OBJECT ID
|
---|
| 91 | S ZRNF("IMMUNEDATETIMETYPETEXT")="Immunization Date" ; ALL ARE THE SAME
|
---|
| 92 | S ZRNF("IMMUNEDATETIME")=$$FMDTOUTC^C0CUTIL($$ZVALUEI^C0CRNF("EVENT DATE AND TIME","C0CZVI"),"DT")
|
---|
| 93 | S ZRNF("IMMUNESOURCEACTORID")="ACTORPROVIDER_"_$P($P(@IMMA@(C0CIM),U,13),"~",1)
|
---|
| 94 | S ZRNF("IMMUNEPRODUCTNAMETEXT")=$$ZVALUE^C0CRNF("NAME","C0CZIM") ; USE NAME IN IMMUNE RECORD
|
---|
| 95 | S ZRNF("IMMUNEPRODUCTCODE")=$$ZVALUE^C0CRNF("HL7-CVX CODE","C0CZIM") ;CVX CODE
|
---|
| 96 | I $$ZVALUE^C0CRNF("HL7-CVX CODE","C0CZIM")'="" S ZRNF("IMMUNEPRODUCTCODESYSTEM")="CDC Vaccine Code"
|
---|
| 97 | E S ZRNF("IMMUNEPRODUCTCODESYSTEM")="" ;NULL
|
---|
| 98 | ;CLEANUP FROM C0CRNF CALLS
|
---|
| 99 | K C0CZIM,C0CZVI
|
---|
| 100 | Q
|
---|
| 101 | FORECAST ; PARSES FORECAST TYPE ROWS FOR RPMS
|
---|
| 102 | ; CURRENTLY DISABLED
|
---|
| 103 | Q
|
---|
| 104 | CONTRA ; PARSES FORECAST TYPE ROWS FOR RPMS
|
---|
| 105 | ; CURRENTLY DISABLED
|
---|
| 106 | Q
|
---|
| 107 | REFUSE ; PARSES FORECAST TYPE ROWS FOR RPMS
|
---|
| 108 | ; CURRENTLY DISABLED
|
---|
| 109 | Q
|
---|
| 110 | ;
|
---|
| 111 | MAP(IMMXML,C0CIMM,IMMOUT) ; MAP IMMUNIZATION XML
|
---|
| 112 | ;
|
---|
| 113 | N ZTEMP S ZTEMP=$NA(^TMP("C0CCCR",$J,DFN,"IMMTEMP")) ;WORK AREA FOR TEMPLATE
|
---|
| 114 | K @ZTEMP
|
---|
| 115 | N ZBLD
|
---|
| 116 | S ZBLD=$NA(^TMP("C0CCCR",$J,DFN,"IMMBLD")) ; BUILD LIST AREA
|
---|
| 117 | D QUEUE^C0CXPATH(ZBLD,IMMXML,1,1) ; FIRST LINE
|
---|
| 118 | N ZINNER
|
---|
| 119 | ; XPATH NEEDS TO MATCH YOUR SECTION
|
---|
| 120 | D QUERY^C0CXPATH(IMMXML,"//Immunizations/Immunization","ZINNER") ;ONE PROC
|
---|
| 121 | N ZTMP,ZVAR,ZI
|
---|
| 122 | S ZI=""
|
---|
| 123 | F S ZI=$O(@C0CIMM@("V",ZI)) Q:ZI="" D ;FOR EACH IMMUNIZATION
|
---|
| 124 | . S ZTMP=$NA(@ZTEMP@(ZI)) ;THIS IMMUNIZATION XML
|
---|
| 125 | . S ZVAR=$NA(@C0CIMM@("V",ZI)) ;THIS IMMUNIZATION VARIABLES
|
---|
| 126 | . D MAP^C0CXPATH("ZINNER",ZVAR,ZTMP) ; MAP THE IMMUNIZATION
|
---|
| 127 | . D QUEUE^C0CXPATH(ZBLD,ZTMP,1,@ZTMP@(0)) ;QUEUE FOR BUILD
|
---|
| 128 | D QUEUE^C0CXPATH(ZBLD,IMMXML,@IMMXML@(0),@IMMXML@(0))
|
---|
| 129 | N ZZTMP ; IS THIS NEEDED?
|
---|
| 130 | D BUILD^C0CXPATH(ZBLD,IMMOUT) ;BUILD FINAL XML
|
---|
| 131 | K @ZTEMP,@ZBLD
|
---|
| 132 | Q
|
---|
| 133 | ;
|
---|