[1622] | 1 | C0XPT4 ; VEN/SMH - Encounter Processing;2013-05-06 9:42 AM
|
---|
[1620] | 2 | ;;1.0;FILEMAN TRIPLE STORE;
|
---|
| 3 | ; (c) 2013 Sam Habiel
|
---|
| 4 | ; Currently proprietary code. Stay out!!!
|
---|
| 5 | ;
|
---|
| 6 | ENC(G,DFN) ; Extract and then process encounters; PEP
|
---|
| 7 | ;
|
---|
| 8 | ; ---PRIVATE TO SAM---
|
---|
| 9 | D DELALL(DFN) ; Delete all Encounters period...
|
---|
| 10 | ; ---PRIVATE TO SAM---
|
---|
| 11 | ;
|
---|
| 12 | K ^TMP($J,"ENC") ; data location
|
---|
| 13 | D ONETYPE^C0XGET3($NA(^TMP($J,"ENC")),G,"sp:Encounter") ; extract encounters
|
---|
| 14 | W "Encounters: ",!
|
---|
| 15 | N S F S=0:0 S S=$O(^TMP($J,"ENC",S)) Q:S="" W S," ",^(S) D W !
|
---|
| 16 | . N STARTDATE S STARTDATE=$$GSPO1^C0XGET3(G,S,"sp:startDate")
|
---|
| 17 | . S STARTDATE=$$FMDATE(STARTDATE)
|
---|
| 18 | . W " ",STARTDATE
|
---|
[1622] | 19 | . D ONEENC(STARTDATE,DFN) ; File One Encounter Private API
|
---|
[1621] | 20 | K ^TMP($J,"ENC") ; data location
|
---|
[1620] | 21 | QUIT
|
---|
| 22 | ;
|
---|
| 23 | ;
|
---|
| 24 | FMDATE(STARTDATE) ; Internal to fix start date
|
---|
| 25 | ; Replace 00:00:00 with 00:00:01. Fileman doesn't understand null time for midnight except as .24 for yesterday
|
---|
| 26 | ; and replace the space with an @ because Fileman needs that to figure out that time comes next after date
|
---|
| 27 | I STARTDATE["00:00:00" S $E(STARTDATE,$L(STARTDATE))=1
|
---|
| 28 | S STARTDATE=$P(STARTDATE," ")_"@"_$P(STARTDATE," ",2)
|
---|
| 29 | ; Conv to Fileman
|
---|
| 30 | D
|
---|
| 31 | . N X,Y,%DT
|
---|
| 32 | . S X=STARTDATE,%DT="TS" D ^%DT
|
---|
| 33 | . S STARTDATE=Y
|
---|
| 34 | Q STARTDATE
|
---|
| 35 | ;
|
---|
| 36 | ;
|
---|
[1622] | 37 | ONEENC(DATE,DFN,FTLOC,COMMENT) ; Private Proc; One Encounter Filing into the VISIT file
|
---|
[1620] | 38 | ; Input:
|
---|
| 39 | ; - DATE: FM DATE of VISIT (Scalar) - Required
|
---|
| 40 | ; - DFN (Scalar) - Required
|
---|
[1622] | 41 | ; - FTLOC: (Scalar) Free Text Location - Optional. Defaults to SMART LOCATION
|
---|
| 42 | ; - COMMENT: (Scalar) Free Text Comment - Optional. Defaults to Imported from Smart
|
---|
[1620] | 43 | ; Output:
|
---|
[1622] | 44 | ; - Creates V file entries for encounter
|
---|
[1620] | 45 | ;
|
---|
| 46 | ; Handle required and optional variables...
|
---|
| 47 | N X F X="DATE","DFN" I '$D(@X) S $EC=",U1," ; Check for the present of required input variables
|
---|
| 48 | S FTLOC=$G(FTLOC,"SMART LOCATION") ; Get default if not supplied
|
---|
| 49 | S COMMENT=$G(COMMENT,"Imported from Smart") ; ditto
|
---|
| 50 | ;
|
---|
| 51 | ; Get package name
|
---|
| 52 | N PKG S PKG=$O(^DIC(9.4,"B","FILEMAN TRIPLE STORE",0)) I 'PKG S $EC=",U1,"
|
---|
| 53 | ;
|
---|
| 54 | ; Source
|
---|
| 55 | N SRC S SRC="FMTS PATIENT IMPORTER"
|
---|
| 56 | ;
|
---|
| 57 | ; Input Array for $$DATA2PCE
|
---|
| 58 | N C0XDATA
|
---|
| 59 | S C0XDATA("ENCOUNTER",1,"ENC D/T")=DATE
|
---|
| 60 | S C0XDATA("ENCOUNTER",1,"PATIENT")=DFN
|
---|
[1621] | 61 | S C0XDATA("ENCOUNTER",1,"HOS LOC")=$$HL^C0XPT0()
|
---|
| 62 | S C0XDATA("ENCOUNTER",1,"SERVICE CATEGORY")="A" ; Ambulatory
|
---|
[1622] | 63 | S C0XDATA("ENCOUNTER",1,"OUTSIDE LOCATION")=FTLOC
|
---|
[1620] | 64 | S C0XDATA("ENCOUNTER",1,"ENCOUNTER TYPE")="P" ; Primary
|
---|
[1622] | 65 | S C0XDATA("ENCOUNTER",1,"COMMENT")=COMMENT
|
---|
[1621] | 66 | S C0XDATA("PROVIDER",1,"NAME")=$$NP^C0XPT0()
|
---|
| 67 | ; Diangosis and procedure necessary so visit will show up in ^SDE.
|
---|
[1622] | 68 | ; We invent them here.
|
---|
[1621] | 69 | S C0XDATA("DX/PL",1,"DIAGNOSIS")=$O(^ICD9("BA","V70.3 ",0))
|
---|
[1622] | 70 | S C0XDATA("PROCEDURE",1,"PROCEDURE")=$O(^ICPT("B","99212",0))
|
---|
[1621] | 71 | S C0XDATA("PROCEDURE",1,"QTY")=1
|
---|
[1620] | 72 | ;
|
---|
| 73 | N C0XVISIT,C0XERR ; Visit, Error
|
---|
[1621] | 74 | N XQORMUTE S XQORMUTE=1 ; Unwinder: Shut the hell up. Don't execute disabled protocols rather than whining about them.
|
---|
[1620] | 75 | N OK S OK=$$DATA2PCE^PXAPI($NA(C0XDATA),PKG,SRC,.C0XVISIT,,,.C0XERR)
|
---|
[1622] | 76 | I OK<1 S $EC=",U1," ; Invalid value is -1
|
---|
[1620] | 77 | QUIT
|
---|
| 78 | ;
|
---|
| 79 | ;
|
---|
| 80 | DELALL(DFN) ; Private Proc; Delete ALL ALL ALL encounter information for the patient.
|
---|
| 81 | ; BE VERY CAREFUL USING THIS...
|
---|
| 82 | ; Walk through the C X-Ref for this patient
|
---|
[1622] | 83 | N I S I=9000010 ; Hit the VISIT file LAST as V files point to it!
|
---|
[1620] | 84 | N DIK,DA
|
---|
| 85 | F S I=$O(^DIC(I)) Q:I'<9000011 D ; For each V File...
|
---|
| 86 | . N OR S OR=$$ROOT^DILFD(I,"",0) ; Open Root for ^DIK
|
---|
| 87 | . N CR S CR=$$ROOT^DILFD(I,"",1) ; Closed Root for @CR@("C")
|
---|
| 88 | . ; W OR," ",CR ; DEBUG
|
---|
| 89 | . ; W ": " ; DEBUG
|
---|
| 90 | . S DIK=OR ; File root to kill
|
---|
| 91 | . N J S J="" F S J=$O(@CR@("C",DFN,J)) Q:'J S DA=J D ^DIK ; each entry to kill
|
---|
| 92 | . ; W ! ; DEBUG
|
---|
| 93 | ;
|
---|
[1621] | 94 | ; Visit file
|
---|
[1620] | 95 | N I S I=""
|
---|
[1621] | 96 | S DIK="^AUPNVSIT("
|
---|
| 97 | F S I=$O(^AUPNVSIT("C",DFN,I)) Q:'I S DA=I D ^DIK ;ditto
|
---|
| 98 | ;
|
---|
| 99 | ; Outpatient encounter file
|
---|
| 100 | N I S I=""
|
---|
[1620] | 101 | ; W "SCE: " ; Debug
|
---|
| 102 | S DIK="^SCE(" ; ditto
|
---|
| 103 | F S I=$O(^SCE("C",DFN,I)) Q:'I S DA=I D ^DIK ; ditto
|
---|
| 104 | QUIT
|
---|
| 105 | ;
|
---|
| 106 | ;
|
---|
| 107 | TEST ; Test creating an encounter using DATA2PCE^PXAPI
|
---|
| 108 | ; Thank you Kevin Muldrum!
|
---|
| 109 | ; This code comes from EDP aka EDIS.
|
---|
| 110 | N DFN S DFN=188 ; One of those Ducks
|
---|
| 111 | ;S LOC=$$GET^XPAR(DUZ(2)_";DIC(4,","EDPF LOCATION")
|
---|
[1621] | 112 | N LOC S LOC=2 ; DR OFFICE
|
---|
| 113 | N EDPKG,EDPSRC,OK,EDPDATA,EDPVISIT,ERR
|
---|
[1620] | 114 | S EDPKG=$O(^DIC(9.4,"B","EMERGENCY DEPARTMENT",0))
|
---|
| 115 | S EDPSRC="EDP TRACKING LOG"
|
---|
| 116 | S EDPDATA("ENCOUNTER",1,"PATIENT")=DFN
|
---|
| 117 | S EDPDATA("ENCOUNTER",1,"HOS LOC")=LOC
|
---|
| 118 | S EDPDATA("ENCOUNTER",1,"SERVICE CATEGORY")="A"
|
---|
| 119 | S EDPDATA("ENCOUNTER",1,"ENCOUNTER TYPE")="P"
|
---|
| 120 | S EDPDATA("ENCOUNTER",1,"ENC D/T")=$$NOW^XLFDT
|
---|
| 121 | ;
|
---|
| 122 | S EDPDATA("DX/PL",1,"DIAGNOSIS")=$O(^ICD9("BA","V70.3 ",0))
|
---|
| 123 | S EDPDATA("PROCEDURE",1,"PROCEDURE")=$O(^ICPT("B","99201",0))
|
---|
| 124 | S EDPDATA("PROCEDURE",1,"QTY")=1
|
---|
| 125 | S EDPDATA("PROVIDER",1,"NAME")=23
|
---|
| 126 | ;
|
---|
| 127 | S OK=$$DATA2PCE^PXAPI("EDPDATA",EDPKG,EDPSRC,.EDPVISIT,23,1,.ERR)
|
---|
| 128 | W OK
|
---|
| 129 | Q
|
---|
| 130 | ;
|
---|
| 131 | ;
|
---|
| 132 | TEST2 ; Test creating an historical event
|
---|
| 133 | ;
|
---|
| 134 | N DFN S DFN=188
|
---|
| 135 | N LOC S LOC=1
|
---|
| 136 | N PKG S PKG=$O(^DIC(9.4,"B","FILEMAN TRIPLE STORE",0))
|
---|
| 137 | I 'PKG S $EC=",U1,"
|
---|
| 138 | ;
|
---|
| 139 | N SRC S SRC="FMTS TEST"
|
---|
| 140 | ;
|
---|
| 141 | N C0XDATA
|
---|
| 142 | S C0XDATA("ENCOUNTER",1,"ENC D/T")=$$NOW^XLFDT
|
---|
| 143 | S C0XDATA("ENCOUNTER",1,"PATIENT")=DFN
|
---|
| 144 | S C0XDATA("ENCOUNTER",1,"SERVICE CATEGORY")="E" ; EVENT
|
---|
| 145 | S C0XDATA("ENCOUNTER",1,"OUTSIDE LOCATION")="FROM THE WIDE WORLD"
|
---|
| 146 | S C0XDATA("ENCOUNTER",1,"ENCOUNTER TYPE")="P" ; Primary
|
---|
| 147 | S C0XDATA("ENCOUNTER",1,"COMMENT")="Testing"
|
---|
| 148 | ;
|
---|
[1621] | 149 | N OK,C0XVISIT,ERR
|
---|
[1620] | 150 | S OK=$$DATA2PCE^PXAPI($NA(C0XDATA),PKG,SRC,.C0XVISIT,,,.ERR)
|
---|
| 151 | QUIT
|
---|
[1621] | 152 | TEST3 ; Test creating a real event
|
---|
| 153 | ;
|
---|
| 154 | N DFN S DFN=190
|
---|
| 155 | N LOC S LOC=$$HL^C0XPT0()
|
---|
| 156 | N PKG S PKG=$O(^DIC(9.4,"B","FILEMAN TRIPLE STORE",0))
|
---|
| 157 | I 'PKG S $EC=",U1,"
|
---|
| 158 | ;
|
---|
| 159 | N SRC S SRC="FMTS TEST"
|
---|
| 160 | ;
|
---|
| 161 | N C0XDATA
|
---|
| 162 | S C0XDATA("ENCOUNTER",1,"ENC D/T")=$$NOW^XLFDT
|
---|
| 163 | S C0XDATA("ENCOUNTER",1,"PATIENT")=DFN
|
---|
| 164 | S C0XDATA("ENCOUNTER",1,"HOS LOC")=LOC
|
---|
| 165 | S C0XDATA("ENCOUNTER",1,"SERVICE CATEGORY")="A" ; Ambulatory
|
---|
| 166 | S C0XDATA("ENCOUNTER",1,"OUTSIDE LOCATION")="FROM THE WIDE WORLD"
|
---|
| 167 | S C0XDATA("ENCOUNTER",1,"ENCOUNTER TYPE")="P" ; Primary
|
---|
| 168 | S C0XDATA("PROVIDER",1,"NAME")=$$NP^C0XPT0()
|
---|
| 169 | S C0XDATA("DX/PL",1,"DIAGNOSIS")=$O(^ICD9("BA","V70.3 ",0))
|
---|
| 170 | S C0XDATA("PROCEDURE",1,"PROCEDURE")=$O(^ICPT("B","99201",0))
|
---|
| 171 | S C0XDATA("PROCEDURE",1,"QTY")=1
|
---|
| 172 | ;
|
---|
| 173 | N OK,C0XVISIT,ERR
|
---|
| 174 | S OK=$$DATA2PCE^PXAPI($NA(C0XDATA),PKG,SRC,.C0XVISIT,,,.ERR)
|
---|
| 175 | ;ZWRITE OK,C0XVISIT
|
---|
| 176 | ;ZWRITE:$D(ERR) ERR
|
---|
| 177 | QUIT
|
---|