source: ccr/trunk/p/GPLACTOR.m@ 376

Last change on this file since 376 was 376, checked in by George Lilly, 15 years ago

fixed OpenVistA MRN retrieval and Vitals typo

File size: 8.3 KB
RevLine 
[112]1GPLACTOR ; CCDCCR/GPL - CCR/CCD PROCESSING FOR ACTORS ; 7/3/08
[175]2 ;;0.4;CCDCCR;nopatch;noreleasedate
3 ; Copyright 2008 WorldVistA. Licensed under the terms of the GNU
4 ; General Public License See attached copy of the License.
[214]5 ;
[175]6 ; This program is free software; you can redistribute it and/or modify
7 ; it under the terms of the GNU General Public License as published by
8 ; the Free Software Foundation; either version 2 of the License, or
9 ; (at your option) any later version.
[214]10 ;
[175]11 ; This program is distributed in the hope that it will be useful,
12 ; but WITHOUT ANY WARRANTY; without even the implied warranty of
13 ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 ; GNU General Public License for more details.
[214]15 ;
[175]16 ; You should have received a copy of the GNU General Public License along
17 ; with this program; if not, write to the Free Software Foundation, Inc.,
18 ; 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
[60]19 ;
[175]20 ; PROCESS THE ACTORS SECTION OF THE CCR
[60]21 ;
[175]22 ; ===Revision History===
23 ; 0.1 Initial Writing of Skeleton--GPL
24 ; 0.2 Patient Data Extraction--SMH
25 ; 0.3 Information System Info Extraction--SMH
26 ; 0.4 Patient data rouine refactored; adjustments here--SMH
[60]27 ;
[45]28EXTRACT(IPXML,ALST,AXML) ; EXTRACT ACTOR FROM ALST INTO PROVIDED XML TEMPLATE
[175]29 ; IPXML is the Input Actor Template into which we substitute values
30 ; This is straight XML. Values to be substituted are in @@VAL@@ format.
31 ; ALST is the actor list global generated by ACTLST^GPLCCR and has format:
32 ; ^TMP(7542,1,"ACTORS",0)=Count
33 ; ^TMP(7542,1,"ACTORS",n)="ActorID^ActorType^ActorIEN"
34 ; ActorType is an enum containing either "PROVIDER" "PATIENT" "SYSTEM"
35 ; AXML is the output arrary, to contain XML.
36 ;
37 N I,J,AMAP,AOID,ATYP,AIEN
38 D CP^GPLXPATH(IPXML,AXML) ; MAKE A COPY OF ACTORS XML
39 D REPLACE^GPLXPATH(AXML,"","//Actors") ; DELETE THE INSIDES
40 I DEBUG W "PROCESSING ACTORS ",!
41 F I=1:1:@ALST@(0) D ; PROCESS ALL ACTORS IN THE LIST
42 . I @ALST@(I)["@@" Q ; NOT A VALID ACTOR
43 . S AOID=$P(@ALST@(I),"^",1) ; ACTOR OBJECT ID
44 . S ATYP=$P(@ALST@(I),"^",2) ; ACTOR TYPE
45 . S AIEN=$P(@ALST@(I),"^",3) ; ACTOR RECORD NUMBER
[285]46 . I AIEN="" D Q ; IEN CAN'T BE NULL
47 . . W "WARING NUL ACTOR: ",ATYP,!
[175]48 . I ATYP="" Q ; NOT A VALID ACTOR
49 . ;
50 . I DEBUG W AOID_" "_ATYP_" "_AIEN,!
51 . I ATYP="PATIENT" D ; PATIENT ACTOR TYPE
52 . . D QUERY^GPLXPATH(IPXML,"//Actors/ACTOR-PATIENT","ATMP")
53 . . D PATIENT("ATMP",AIEN,AOID,"ATMP2")
54 . ;
55 . I ATYP="SYSTEM" D ; SYSTEM ACTOR TYPE
56 . . D QUERY^GPLXPATH(IPXML,"//Actors/ACTOR-SYSTEM","ATMP")
57 . . D SYSTEM("ATMP",AIEN,AOID,"ATMP2")
58 . ;
59 . I ATYP="NOK" D ; NOK ACTOR TYPE
60 . . D QUERY^GPLXPATH(IPXML,"//Actors/ACTOR-NOK","ATMP")
61 . . D NOK("ATMP",AIEN,AOID,"ATMP2")
62 . ;
63 . I ATYP="PROVIDER" D ; PROVIDER ACTOR TYPE
64 . . D QUERY^GPLXPATH(IPXML,"//Actors/ACTOR-PROVIDER","ATMP")
65 . . D PROVIDER("ATMP",AIEN,AOID,"ATMP2")
66 . ;
67 . I ATYP="ORGANIZATION" D ; PROVIDER ACTOR TYPE
68 . . D QUERY^GPLXPATH(IPXML,"//Actors/ACTOR-ORG","ATMP")
69 . . D ORG("ATMP",AIEN,AOID,"ATMP2")
70 . ;
[284]71 . W "PROCESSING:",ATYP," ",AIEN,!
72 . ;I @ATMP2@(0)=0 Q ; NOTHING RETURNED, SKIP THIS ONE
[175]73 . D INSINNER^GPLXPATH(AXML,"ATMP2") ; INSERT INTO ROOT
[277]74 . K ATYP,AIEN,AOID,ATMP,ATMP2 ; BE SURE TO GET THE NEXT ONE
[175]75 ;
76 N ACTTMP
77 D MISSING^GPLXPATH(AXML,"ACTTMP") ; SEARCH XML FOR MISSING VARS
78 I ACTTMP(0)>0 D ; IF THERE ARE MISSING VARS -
79 . ; STRINGS MARKED AS @@X@@
80 . W "ACTORS Missing list: ",!
81 . F I=1:1:ACTTMP(0) W ACTTMP(I),!
82 Q
83 ;
[75]84PATIENT(INXML,AIEN,AOID,OUTXML) ; PROCESS A PATIENT ACTOR
[175]85 I DEBUG W "PROCESSING ACTOR PATIENT ",AIEN,!
86 N AMAP,ZX
87 S AMAP=$NA(^TMP($J,"AMAP"))
88 K @AMAP
89 S @AMAP@("ACTOROBJECTID")=AOID ;ACTOR OBJECT ID
90 S @AMAP@("ACTORGIVENNAME")=$$GIVEN^CCRDPT(AIEN)
91 S @AMAP@("ACTORMIDDLENAME")=$$MIDDLE^CCRDPT(AIEN)
92 S @AMAP@("ACTORFAMILYNAME")=$$FAMILY^CCRDPT(AIEN)
93 S @AMAP@("ACTORDATEOFBIRTH")=$$DOB^CCRDPT(AIEN)
94 S @AMAP@("ACTORGENDER")=$$GENDER^CCRDPT(AIEN)
95 S @AMAP@("ACTORSSN")=""
96 S @AMAP@("ACTORSSNTEXT")=""
97 S @AMAP@("ACTORSSNSOURCEID")=""
[376]98 I $T(^MSCDPTID)]"" S MRN=$$^MSCDPTID(DFN) ;TEST FOR MRN ON OPENVISTA ;GPL
[371]99 I $D(MRN) D ; IF MRN IS PRESENT
100 . S @AMAP@("ACTORSSN")=MRN
101 . S @AMAP@("ACTORSSNTEXT")="MRN"
[175]102 . S @AMAP@("ACTORSSNSOURCEID")=AOID
[371]103 E D ; NO MRN, USE SSN
104 . S ZX=$$SSN^CCRDPT(AIEN)
105 . I ZX'="" D ; IF THERE IS A SSN IN THE RECORD
106 . . S @AMAP@("ACTORSSN")=ZX
107 . . S @AMAP@("ACTORSSNTEXT")="SSN"
108 . . S @AMAP@("ACTORSSNSOURCEID")=AOID
[175]109 S @AMAP@("ACTORADDRESSTYPE")=$$ADDRTYPE^CCRDPT(AIEN)
110 S @AMAP@("ACTORADDRESSLINE1")=$$ADDR1^CCRDPT(AIEN)
111 S @AMAP@("ACTORADDRESSLINE2")=$$ADDR2^CCRDPT(AIEN)
112 S @AMAP@("ACTORADDRESSCITY")=$$CITY^CCRDPT(AIEN)
113 S @AMAP@("ACTORADDRESSSTATE")=$$STATE^CCRDPT(AIEN)
114 S @AMAP@("ACTORADDRESSZIPCODE")=$$ZIP^CCRDPT(AIEN)
115 S @AMAP@("ACTORRESTEL")=""
116 S @AMAP@("ACTORRESTELTEXT")=""
117 S ZX=$$RESTEL^CCRDPT(AIEN)
118 I ZX'="" D ; IF THERE IS A RESIDENT PHONE IN THE RECORD
119 . S @AMAP@("ACTORRESTEL")=ZX
120 . S @AMAP@("ACTORRESTELTEXT")="Residential Telephone"
121 S @AMAP@("ACTORWORKTEL")=""
122 S @AMAP@("ACTORWORKTELTEXT")=""
123 S ZX=$$WORKTEL^CCRDPT(AIEN)
124 I ZX'="" D ; IF THERE IS A RESIDENT PHONE IN THE RECORD
125 . S @AMAP@("ACTORWORKTEL")=ZX
126 . S @AMAP@("ACTORWORKTELTEXT")="Work Telephone"
127 S @AMAP@("ACTORCELLTEL")=""
128 S @AMAP@("ACTORCELLTELTEXT")=""
129 S ZX=$$CELLTEL^CCRDPT(AIEN)
130 I ZX'="" D ; IF THERE IS A CELL PHONE IN THE RECORD
131 . S @AMAP@("ACTORCELLTEL")=ZX
132 . S @AMAP@("ACTORCELLTELTEXT")="Cell Phone"
133 S @AMAP@("ACTOREMAIL")=$$EMAIL^CCRDPT(AIEN)
134 S @AMAP@("ACTORADDRESSSOURCEID")=AOID
135 S @AMAP@("ACTORIEN")=AIEN
136 S @AMAP@("ACTORSUFFIXNAME")="" ; DOES VISTA STORE THE SUFFIX
137 S @AMAP@("ACTORSOURCEID")="ACTORSYSTEM_1" ; THE SYSTEM IS THE SOURCE
138 D MAP^GPLXPATH(INXML,AMAP,OUTXML) ; MAP THE VARIABLE
139 Q
140 ;
[75]141SYSTEM(INXML,AIEN,AOID,OUTXML) ; PROCESS A SYSTEM ACTOR
[43]142 ;
[45]143 ; N AMAP
144 S AMAP=$NA(^TMP($J,"AMAP"))
[75]145 K @AMAP
[43]146 S @AMAP@("ACTOROBJECTID")=AOID ;ACTOR OBJECT ID
[49]147 S @AMAP@("ACTORINFOSYSNAME")=$$SYSNAME^CCRSYS
[277]148 S @AMAP@("ACTORINFOSYSVER")=$$SYSVER^CCRSYS
[49]149 S @AMAP@("ACTORINFOSYSSOURCEID")=AOID
[43]150 D MAP^GPLXPATH(INXML,AMAP,OUTXML) ; MAP THE VARIABLE
151 Q
152 ;
[75]153NOK(INXML,AIEN,AOID,OUTXML) ; PROCESS A NEXT OF KIN TYPE ACTOR
[43]154 ;
[45]155 ; N AMAP
156 S AMAP=$NA(^TMP($J,"AMAP"))
[75]157 K @AMAP
[43]158 S @AMAP@("ACTOROBJECTID")=AOID ;ACTOR OBJECT ID
159 S @AMAP@("ACTORDISPLAYNAME")=""
160 S @AMAP@("ACTORRELATION")=""
161 S @AMAP@("ACTORRELATIONSOURCEID")=""
[78]162 S @AMAP@("ACTORSOURCEID")="ACTORSYSTEM_1" ; THE SYSTEM IS THE SOURCE
[43]163 D MAP^GPLXPATH(INXML,AMAP,OUTXML) ; MAP THE VARIABLE
164 Q
165 ;
[75]166ORG(INXML,AIEN,AOID,OUTXML) ; PROCESS AN ORGANIZATION TYPE ACTOR
[57]167 ;
168 ; N AMAP
169 S AMAP=$NA(^TMP($J,"AMAP"))
[75]170 K @AMAP
[57]171 S @AMAP@("ACTOROBJECTID")=AOID ;ACTOR OBJECT ID
[71]172 S @AMAP@("ORGANIZATIONNAME")=$P($$SITE^VASITE,U,2)
[57]173 S @AMAP@("ACTORSOURCEID")="ACTORSYSTEM_1"
174 D MAP^GPLXPATH(INXML,AMAP,OUTXML) ; MAP THE VARIABLE
175 Q
176 ;
[75]177PROVIDER(INXML,AIEN,AOID,OUTXML) ; PROCESS A PROVIDER TYPE ACTOR
[43]178 ;
[45]179 ; N AMAP
180 S AMAP=$NA(^TMP($J,"AMAP"))
[75]181 K @AMAP
[284]182 I '$D(^VA(200,AIEN,0)) D Q ; IF NO PROVIDER RECORD (SHOULDN'T HAPPEN)
183 . W "WARNING - MISSING PROVIDER: ",AIEN,!
184 . S @OUTXML@(0)=0 ; SIGNAL NO OUTPUT
[43]185 S @AMAP@("ACTOROBJECTID")=AOID ;ACTOR OBJECT ID
[67]186 S @AMAP@("ACTORGIVENNAME")=$$GIVEN^CCRVA200(AIEN)
187 S @AMAP@("ACTORMIDDLENAME")=$$MIDDLE^CCRVA200(AIEN)
188 S @AMAP@("ACTORFAMILYNAME")=$$FAMILY^CCRVA200(AIEN)
[277]189 S @AMAP@("ACTORTITLE")=$$TITLE^CCRVA200(AIEN)
190 S @AMAP@("IDTYPE")=$P($$NPI^CCRVA200(AIEN),U,1)
191 S @AMAP@("ID")=$P($$NPI^CCRVA200(AIEN),U,2)
192 S @AMAP@("IDDESC")=$P($$NPI^CCRVA200(AIEN),U,3)
[67]193 S @AMAP@("ACTORSPECIALITY")=$$SPEC^CCRVA200(AIEN)
194 S @AMAP@("ACTORADDRESSTYPE")=$$ADDTYPE^CCRVA200(AIEN)
195 S @AMAP@("ACTORADDRESSLINE1")=$$ADDLINE1^CCRVA200(AIEN)
196 S @AMAP@("ACTORADDRESSCITY")=$$CITY^CCRVA200(AIEN)
197 S @AMAP@("ACTORADDRESSSTATE")=$$STATE^CCRVA200(AIEN)
198 S @AMAP@("ACTORPOSTALCODE")=$$POSTCODE^CCRVA200(AIEN)
[78]199 S @AMAP@("ACTORTELEPHONE")=""
200 S @AMAP@("ACTORTELEPHONETYPE")=""
201 S ZX=$$TEL^CCRVA200(AIEN)
202 I ZX'="" D ; THERE IS A PHONE NUMBER AVAILABLE
203 . S @AMAP@("ACTORTELEPHONE")=ZX
204 . S @AMAP@("ACTORTELEPHONETYPE")=$$TELTYPE^CCRVA200(AIEN)
[67]205 S @AMAP@("ACTOREMAIL")=$$EMAIL^CCRVA200(AIEN)
206 S @AMAP@("ACTORADDRESSSOURCEID")="ACTORSYSTEM_1"
[78]207 S @AMAP@("ACTORSOURCEID")="ACTORSYSTEM_1" ; THE SYSTEM IS THE SOURCE
[43]208 D MAP^GPLXPATH(INXML,AMAP,OUTXML) ; MAP THE VARIABLE
209 Q
210 ;
Note: See TracBrowser for help on using the repository browser.