| 1 | IBDFDE5 ;ALB/AAS - AICS Manual Data Entry, Loader routine for 357.6 ; 19-APR-96 | 
|---|
| 2 | ;;3.0;AUTOMATED INFO COLLECTION SYS;**40**;APR 24, 1997 | 
|---|
| 3 | ; | 
|---|
| 4 | % G ^IBDFDE | 
|---|
| 5 | ; | 
|---|
| 6 | ; | 
|---|
| 7 | COMPLST ; -- procedure, compile form list arrays in ^tmp | 
|---|
| 8 | ;    ^tmp("ibd-lText",$j,form,package interface,list,text,cnt,n)=entry number | 
|---|
| 9 | ;    ^tmp("ibd-lCode",$j,form,package interface,list," "_code,cnt,n)= entry number | 
|---|
| 10 | ;    ^tmp("ibd-lst",$j,form,package inteface,list)=display text^display code^input value^ optional caption^ optional term^selectable? | 
|---|
| 11 | ; | 
|---|
| 12 | N IBDI,FORM,PI,IEN,CNT,CH,CODE | 
|---|
| 13 | I '$G(IBDF("PI"))!('$G(IBDF("IEN")))!('$G(IBDFMIEN)) G COMPQ | 
|---|
| 14 | S PI=IBDF("PI"),IEN=IBDF("IEN"),FORM=IBDFMIEN | 
|---|
| 15 | ; | 
|---|
| 16 | ;K ^TMP("IBD-LST",$J,FORM,PI,IEN),^TMP("IBD-LTEXT",$J,FORM,PI,IEN),^TMP("IBD-LCODE",$J,FORM,PI,IEN) | 
|---|
| 17 | K ^TMP("IBD-LTEXT",$J,FORM,PI,IEN),^TMP("IBD-LCODE",$J,FORM,PI,IEN) | 
|---|
| 18 | ; | 
|---|
| 19 | ;M ^TMP("IBD-LST",$J,FORM,PI,IEN)=CHOICE | 
|---|
| 20 | K CHOICE | 
|---|
| 21 | ; | 
|---|
| 22 | ; -- Expand choices | 
|---|
| 23 | S HDR="" | 
|---|
| 24 | S IBDI=0 F  S IBDI=$O(^TMP("IBD-LST",$J,FORM,PI,IEN,IBDI)) Q:'IBDI  S CH=$G(^(IBDI)) D | 
|---|
| 25 | .I $P(CH,"^",7)=0 S HDR=$P(CH,"^") Q | 
|---|
| 26 | .I $P(CH,"^",8)="" S $P(^TMP("IBD-LST",$J,FORM,PI,IEN,IBDI),"^",8)=HDR | 
|---|
| 27 | .; | 
|---|
| 28 | .; -- build array of text | 
|---|
| 29 | .I $P(CH,"^",1)'="" D | 
|---|
| 30 | ..I '$D(^TMP("IBD-LTEXT",$J,FORM,PI,IEN,$E($$UP^XLFSTR($P(CH,"^",1)),1,80))) S ^TMP("IBD-LTEXT",$J,FORM,PI,IEN,$E($$UP^XLFSTR($P(CH,"^",1)),1,80),1)=IBDI Q | 
|---|
| 31 | ..S CNT=$O(^TMP("IBD-LTEXT",$J,FORM,PI,IEN,$E($$UP^XLFSTR($P(CH,"^",1)),1,80),""),-1) | 
|---|
| 32 | ..S ^TMP("IBD-LTEXT",$J,FORM,PI,IEN,$E($$UP^XLFSTR($P(CH,"^",1)),1,80),CNT+1)=IBDI | 
|---|
| 33 | .; | 
|---|
| 34 | .; -- build array of codes | 
|---|
| 35 | .S CODE=$S($P(CH,"^",2)'="":$P(CH,"^",2),1:$P(CH,"^",3)) Q:CODE="" | 
|---|
| 36 | .I '$D(^TMP("IBD-LCODE",$J,FORM,PI,IEN," "_CODE,1)) S ^TMP("IBD-LCODE",$J,FORM,PI,IEN," "_CODE,1)=IBDI Q | 
|---|
| 37 | .S CNT=$O(^TMP("IBD-LCODE",$J,FORM,PI,IEN," "_CODE,""),-1) S ^TMP("IBD-LCODE",$J,FORM,PI,IEN," "_CODE,CNT+1)=IBDI | 
|---|
| 38 | ; | 
|---|
| 39 | COMPQ Q | 
|---|
| 40 | ; | 
|---|
| 41 | MDCOMP(FORM) ; -- compile form for manual data entry into ^xtmp | 
|---|
| 42 | ; -- ^xtmp("ibd"_form,0) := date ^ date | 
|---|
| 43 | ;    ^xtmp("ibd"_form, "ibd-obj", n) := object listing for form | 
|---|
| 44 | ;    ^xtmp("ibd"_form, "ibd-lst", pkg interface, list, n) := listing of each list | 
|---|
| 45 | ;    ^xtmp("ibd"_form, "ibd-lst", pkg interface, list ,"code", " "_code, n) := code index | 
|---|
| 46 | ;    ^xtmp("ibd"_form, "ibd-lst", pkg interface, list "text", text, n) := text index | 
|---|
| 47 | ; | 
|---|
| 48 | ; -- before converting to xtmp must resolve compile issues, | 
|---|
| 49 | ;    such as when form is in use for data entry etc. | 
|---|
| 50 | ;    need schema for locks...think about this | 
|---|
| 51 | ;    remember to check old logic for changes | 
|---|
| 52 | ; | 
|---|
| 53 | N I,J,X,Y,NAM,IBDOBJ | 
|---|
| 54 | G:$G(^IBE(357,+$G(FORM),0))="" MDCQ | 
|---|
| 55 | S NAM="IBD"_FORM | 
|---|
| 56 | L +^XTMP(NAM):10 I '$T W !!,"form is in use, data entry compile failed",! S IBQUIT=1 G MDCQ | 
|---|
| 57 | K ^XTMP(NAM) ; make sure ibdfde locks so doesn't kill when in use | 
|---|
| 58 | S ^XTMP(NAM,0)=$$FMADD^XLFDT(DT,90)_"^"_DT | 
|---|
| 59 | D FRMLSTI^IBDFRPC(.IBDOBJ,FORM,"",1) | 
|---|
| 60 | M ^XTMP(NAM,"IBD-OBJ")=IBDOBJ | 
|---|
| 61 | K IBDOBJ | 
|---|
| 62 | ; | 
|---|
| 63 | ; -- build entry for lists | 
|---|
| 64 | S X=0 F  S X=$O(^XTMP(NAM,"IBD-OBJ",X)) Q:'X  S Y=^(X) D | 
|---|
| 65 | .Q:$P($G(^IBE(357.6,+$P(Y,"^",2),0)),"^",14)  ;dyanamic lists get compiled by ibdfde2 and then killed | 
|---|
| 66 | .I $P(Y,"^",5)="LIST" D MDCLIST(FORM,$P(Y,"^",2),$P(Y,"^",6)) | 
|---|
| 67 | ; | 
|---|
| 68 | MDCQ L -^XTMP(NAM) | 
|---|
| 69 | Q | 
|---|
| 70 | ; | 
|---|
| 71 | MDCLIST(FORM,PI,LIST) ; -- Compile one list | 
|---|
| 72 | N I,J,X,Y,IBDF,CH,CODE | 
|---|
| 73 | G:$G(^IBE(357.6,+$G(PI),0))=""!($G(^IBE(357.2,+$G(LIST),0))="")!($G(^IBE(357,+$G(FORM),0))="") MDCLQ | 
|---|
| 74 | S IBDF("PI")=PI,IBDF("IEN")=LIST,IBDF("TYPE")="LIST" | 
|---|
| 75 | K ^XTMP("IBD"_FORM,"IBD-LST",PI,LIST) | 
|---|
| 76 | D OBJLST^IBDFRPC1(.CH,.IBDF) | 
|---|
| 77 | M ^XTMP("IBD"_FORM,"IBD-LST",PI,LIST)=CH | 
|---|
| 78 | ; | 
|---|
| 79 | ; -- Expand choices | 
|---|
| 80 | S HDR="" | 
|---|
| 81 | S IBDI=0 F  S IBDI=$O(^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,IBDI)) Q:'IBDI  S CH=^(IBDI) D | 
|---|
| 82 | .I $P(CH,"^",7)=0 S HDR=$P(CH,"^") Q | 
|---|
| 83 | .I $P(CH,"^",8)="" S $P(^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,I),"^",8)=HDR | 
|---|
| 84 | .; | 
|---|
| 85 | .; -- build array of text | 
|---|
| 86 | .I $P(CH,"^",1)'="" D | 
|---|
| 87 | ..I '$D(^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,"TEXT",$$UP^XLFSTR($P(CH,"^",1)))) S ^XTMP("IBD"_FORM,PI,LIST,"TEXT",$$UP^XLFSTR($P(CH,"^",1)),1)=IBDI Q | 
|---|
| 88 | ..S CNT=$O(^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,"TEXT",$$UP^XLFSTR($P(CH,"^",1)),""),-1) | 
|---|
| 89 | ..S ^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,"TEXT",$$UP^XLFSTR($P(CH,"^",1)),CNT+1)=IBDI | 
|---|
| 90 | .; | 
|---|
| 91 | .; -- build array of codes | 
|---|
| 92 | .S CODE=$S($P(CH,"^",2)'="":$P(CH,"^",2),1:$P(CH,"^",3)) Q:CODE="" | 
|---|
| 93 | .I '$D(^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,"CODE"," "_CODE,1)) S ^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,"CODE"," "_CODE,1)=IBDI Q | 
|---|
| 94 | .S CNT=$O(^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,"CODE"," "_CODE,""),-1) S ^XTMP("IBD"_FORM,"IBD-LST",PI,LIST,"CODE"," "_CODE,CNT+1)=IBDI | 
|---|
| 95 | .Q | 
|---|
| 96 | ; | 
|---|
| 97 | MDCLQ Q | 
|---|
| 98 | ; | 
|---|
| 99 | 18 ; -- Post init for data entry patch | 
|---|
| 100 | D 14,CLNTMP,XREF,PIDIM,PIUP | 
|---|
| 101 | Q | 
|---|
| 102 | ; | 
|---|
| 103 | 14 ;Populate the .14 FIELD IN FILE 357.96 | 
|---|
| 104 | S ZTIO="",ZTDTH=$H,ZTRTN="DQ^IBDFDE5",ZTDESC="IBD-Patch 2 populate 357.96;.14" D ^%ZTLOAD | 
|---|
| 105 | D BMES^XPDUTL("Queing the Conversion to populate the .14 field (NO APPOINTMENT ENTRY) of file 357.96 ENCOUNTER FORM TRACKING......") | 
|---|
| 106 | Q | 
|---|
| 107 | ; | 
|---|
| 108 | DQ ; | 
|---|
| 109 | N IBDFIFN,IBDFCLIN,IBDFAPPT,IBDFDFN | 
|---|
| 110 | S IBDFIFN=0 | 
|---|
| 111 | F  S IBDFIFN=$O(^IBD(357.96,IBDFIFN)) Q:'IBDFIFN  S IBDFNODE=$G(^IBD(357.96,IBDFIFN,0)) S IBDFDFN=$P(IBDFNODE,"^",2),IBDFAPPT=$P(IBDFNODE,"^",3) I IBDFDFN,IBDFAPPT D | 
|---|
| 112 | .S DIE="^IBD(357.96,",DA=IBDFIFN | 
|---|
| 113 | .I $D(^DPT(+IBDFIFN,"S",IBDFAPPT)) S DR=".14////0" | 
|---|
| 114 | .E  S DR=".14////1" | 
|---|
| 115 | .D ^DIE K DA,DR,DIE | 
|---|
| 116 | ;W !!,"DONE" | 
|---|
| 117 | Q | 
|---|
| 118 | CLNTMP ; -- kill tmp globals, on load, forces rebuild with updates | 
|---|
| 119 | K ^TMP("IBD-LST"),^TMP("IBD-OBJ") | 
|---|
| 120 | Q | 
|---|
| 121 | ; | 
|---|
| 122 | XREF ; | 
|---|
| 123 | D BMES^XPDUTL("Removing 'RECD' cross-reference on PRINTED FORM ID field") | 
|---|
| 124 | S DA=0 | 
|---|
| 125 | F  S DA=$O(^DD(357.96,.01,1,DA)) Q:DA<1  I $G(^(DA,0))="357.96^RECD^MUMPS" S DIK="^DD(357.96,.01,1,",DA(2)=357.96,DA(1)=.01 D ^DIK K DIK | 
|---|
| 126 | ; | 
|---|
| 127 | D BMES^XPDUTL("Removing 'RECD2' cross-reference on DATE/TIME RECEIVED IN VISTA field") | 
|---|
| 128 | S DA=0 | 
|---|
| 129 | F  S DA=$O(^DD(357.96,.06,1,DA)) Q:DA<1  I $G(^(DA,0))="357.96^RECD2^MUMPS" S DIK="^DD(357.96,.06,1,",DA(2)=357.96,DA(1)=.06 D ^DIK K DIK | 
|---|
| 130 | ; | 
|---|
| 131 | D BMES^XPDUTL("Removing 'RECD3' cross-reference on DATE/TIME PRINTED field") | 
|---|
| 132 | S DA=0 | 
|---|
| 133 | F  S DA=$O(^DD(357.96,.05,1,DA)) Q:DA<1  I $G(^(DA,0))="357.96^RECD3^MUMPS" S DIK="^DD(357.96,.05,1,",DA(2)=357.96,DA(1)=.05 D ^DIK K DIK | 
|---|
| 134 | K DA | 
|---|
| 135 | K ^IBD(357.96,"RECD") | 
|---|
| 136 | Q | 
|---|
| 137 | ; | 
|---|
| 138 | PIDIM ; | 
|---|
| 139 | D BMES^XPDUTL("Updating PCE DIM OUTPUT TRANSFORM in file 357.6") | 
|---|
| 140 | N IBD,LINE,PKG,NOD14,IEN | 
|---|
| 141 | F IBD=1:1 S LINE=$P($T(OUTTRANS+IBD),";;",2) Q:LINE=""  D | 
|---|
| 142 | .S PKG=$P(LINE,"^",2) | 
|---|
| 143 | .S NOD14=$P(LINE,"^",3,99) | 
|---|
| 144 | .S IEN=+$O(^IBE(357.6,"B",$E(PKG,1,30),0)) | 
|---|
| 145 | .Q:IEN<1 | 
|---|
| 146 | .I $P($G(^IBE(357.6,IEN,0)),"^")=PKG S ^IBE(357.6,IEN,14)=NOD14 | 
|---|
| 147 | Q | 
|---|
| 148 | OUTTRANS ;; | 
|---|
| 149 | ;;61^INPUT PROVIDER^S Y=$$DSPLYPRV^IBDFN9(Y) | 
|---|
| 150 | ;;62^INPUT VISIT TYPE^S Y=$$DSPLYCPT^IBDFN9(Y) | 
|---|
| 151 | ;;102^PX INPUT VISIT TYPE^S Y=$$DSPLYCPT^IBDFN9(Y) | 
|---|
| 152 | ;; | 
|---|
| 153 | PIUP ; | 
|---|
| 154 | D BMES^XPDUTL("Updating Package Interface File for Data Entry") | 
|---|
| 155 | N PKG,ENT,RTN,DYN,NODE18,IEN | 
|---|
| 156 | F IBD=1:1 S LINE=$P($T(UPDATE+IBD),";;",2) Q:LINE=""  D | 
|---|
| 157 | .S PKG=$P(LINE,"^",2) | 
|---|
| 158 | .S ENT=$P(LINE,"^",3) | 
|---|
| 159 | .S RTN=$P(LINE,"^",4) | 
|---|
| 160 | .S DYN=$P(LINE,"^",5) | 
|---|
| 161 | .S NOD18=$P(LINE,"^",6,99) | 
|---|
| 162 | .S IEN=+$O(^IBE(357.6,"B",$E(PKG,1,30),0)) | 
|---|
| 163 | .Q:IEN<1 | 
|---|
| 164 | .I $P($G(^IBE(357.6,IEN,0)),"^")=PKG D | 
|---|
| 165 | ..S ^IBE(357.6,IEN,18)=NOD18 | 
|---|
| 166 | ..I $G(ENT)'="" S $P(^IBE(357.6,IEN,0),"^",2)=ENT | 
|---|
| 167 | ..I $G(RTN)'="" S $P(^IBE(357.6,IEN,0),"^",3)=RTN | 
|---|
| 168 | ..I $G(DYN)'="" S $P(^IBE(357.6,IEN,0),"^",14)=DYN | 
|---|
| 169 | Q | 
|---|
| 170 | ; | 
|---|
| 171 | UPDATE ;; | 
|---|
| 172 | ;;59^INPUT PROCEDURE CODE (CPT4)^^^^S IBDF("OTHER")="81^I '$P(^(0),U,4)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"CPT Procedure Code") | 
|---|
| 173 | ;;61^INPUT PROVIDER^PRVDR^IBDFN4^1^S IBDF("OTHER")="200^$$SCREEN^IBDFDE10(+Y)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Provider") | 
|---|
| 174 | ;;62^INPUT VISIT TYPE^^^^S IBDF("OTHER")="357.69^I '$P(^(0),U,4)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Visit Type (EM) Code") | 
|---|
| 175 | ;;69^INPUT DIAGNOSIS CODE (ICD9)^^^^S IBDF("OTHER")="80^I '$P(^(0),U,9)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Diagnosis Code") | 
|---|
| 176 | ;;74^PX INPUT PATIENT ACTIVE PROBLEM^DSELECT^GMPLENFM^1^D LIST^IBDFDE2(.IBDSEL,.IBDF,"Active Problem") | 
|---|
| 177 | ;;91^PX INPUT EDUCATION TOPICS^^^^S IBDF("OTHER")="9999999.09^I '$P(^(0),U,3)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Patient Education") | 
|---|
| 178 | ;;92^PX INPUT EXAMS^^^^S IBDF("OTHER")="9999999.15^I '$P(^(0),U,4)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Exam") | 
|---|
| 179 | ;;93^PX INPUT HEALTH FACTORS^^^^S IBDF("OTHER")="9999999.64^I '$P(^(0),U,10),$P(^(0),U,10)=""F"",'$P(^(0),U,11)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Health Factors") | 
|---|
| 180 | ;;94^PX INPUT IMMUNIZATION^^^^S IBDF("OTHER")="9999999.14^I '$P(^(0),U,7)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Immunizations") | 
|---|
| 181 | ;;97^PX INPUT SKIN TESTS^^^^S IBDF("OTHER")="9999999.28^I '$P(^(0),U,3)" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Skin Tests") | 
|---|
| 182 | ;;99^PX INPUT VITALS^^^^D HNDPR^IBDFDE3(.IBDSEL,.IBDF) | 
|---|
| 183 | ;;103^GMP INPUT CLINIC COMMON PROBLEMS^^^^S IBDF("LEXICON")=1,IBDF("OTHER")="757.01^" D LIST^IBDFDE2(.IBDSEL,.IBDF,"Diagnosis, Problem, or Term") | 
|---|
| 184 | ;; | 
|---|
| 185 | ;; -- Example of setting up a date/time prompt | 
|---|
| 186 | ;;95^PX INPUT CHECKOUT TIME^^^^S IBDF("ASKDATE")=1 D HNDPR^IBDFDE3(.IBDSEL,.IBDF) K IBDF("ASKDATE") | 
|---|
| 187 | ;; | 
|---|
| 188 | ;; -- Example of setting up a multiple choice field | 
|---|
| 189 | ;;100^PX INPUT VISIT CLASSIFICATION^^^^D MULT^IBDFDE4(.IBDSEL,.IBDF) | 
|---|
| 190 | ;; | 
|---|