| 1 | PXRMGECX ;SLC/JVS - GEC Debug Utilities ;08/21/2003  08:54 | 
|---|
| 2 | ;;2.0;CLINICAL REMINDERS;;Feb 04, 2005 | 
|---|
| 3 | ; | 
|---|
| 4 | Q | 
|---|
| 5 | PROMPT ; Prompt for Correct Report | 
|---|
| 6 | N Y,X | 
|---|
| 7 | K DIR | 
|---|
| 8 | S DIR("A")="Select Option or ^ to Exit" | 
|---|
| 9 | S DIR("A",1)="These Reports are to Help with Degugging of Problems" | 
|---|
| 10 | S DIR("A",2)="**It could take 5 minutes !! or more to Complete Reports" | 
|---|
| 11 | I $D(^DISV(DUZ,"PXRMGEC","BG")) S DIR("B")=$G(^DISV(DUZ,"PXRMGEC","BG")) | 
|---|
| 12 | S DIR(0)="S^B:Brief Health Factor Review;D:Detailed Health Factor Review" | 
|---|
| 13 | D ^DIR | 
|---|
| 14 | K DIR("A"),DIR("B"),DIR(0) | 
|---|
| 15 | I Y="B" D PR1 | 
|---|
| 16 | I Y="D" D PR | 
|---|
| 17 | Q:$D(DIRUT)!($D(DIROUT)) | 
|---|
| 18 | S ^DISV(DUZ,"PXRMGEC","BG")=Y | 
|---|
| 19 | Q | 
|---|
| 20 | ; | 
|---|
| 21 | DAS ;GET IENS OF TOP LEVEL DIALOGS WITH GEC IN THE IDENTITY FIELD | 
|---|
| 22 | F GECI="GEC1","GEC2","GEC3","GECF" D | 
|---|
| 23 | .S GECX=0 F  S GECX=$O(^PXRMD(801.41,"AC",GECI,GECX)) Q:GECX=""  S GECDA(GECX,GECI)="" | 
|---|
| 24 | Q | 
|---|
| 25 | ; | 
|---|
| 26 | ; | 
|---|
| 27 | SCREEN(IEN) ;Screen for use in GEC Dialog Group | 
|---|
| 28 | N REFB,REF10,TREE,DGIEN,IENN,GECX,GECI,DGDA,DGNA | 
|---|
| 29 | N DIASYN | 
|---|
| 30 | S DGNA="",DGDA=0,OK=0 | 
|---|
| 31 | S REFB="^PXRMD(801.41,""B"")" | 
|---|
| 32 | S REF10="^PXRMD(801.41)" | 
|---|
| 33 | S DGNA="VA-" F  S DGNA=$O(@REFB@(DGNA)) Q:DGNA'["VA-"  D | 
|---|
| 34 | .S DGDA=$O(@REFB@(DGNA,0)) | 
|---|
| 35 | .I $P($P($G(^PXRMD(801.41,DGDA,1)),"^",5),";",1)=IEN!($$MUL(IEN,DGDA)) D | 
|---|
| 36 | ..I $P($G(^PXRMD(801.41,DGDA,0)),"^",1)["HF GEC "!($P($G(^PXRMD(801.41,DGDA,0)),"^",1)["DG GEC ") S DGIEN=DGDA | 
|---|
| 37 | ..I $D(DGIEN) S TREE(DGIEN)="" | 
|---|
| 38 | Q:'$D(DGIEN) OK | 
|---|
| 39 | ST I $D(^PXRMD(801.41,"AD",DGIEN)) D | 
|---|
| 40 | .S IENN=0 F  S IENN=$O(^PXRMD(801.41,"AD",DGIEN,IENN)) Q:IENN=""!(OK=1)  D | 
|---|
| 41 | ..I $D(GECDA(IENN)) S OK=1,HFDIA(IEN,$O(GECDA(IENN,"")))="" S ^TMP("PXRMGECX",$J,"TEXT",IENN,DGIEN,IEN)="" | 
|---|
| 42 | ..I OK=1 K TREE | 
|---|
| 43 | ..I OK=0 S TREE(IENN)="" | 
|---|
| 44 | REDO I $D(TREE) D | 
|---|
| 45 | .S TIEN=0 F  S TIEN=$O(TREE(TIEN)) Q:TIEN=""!(OK=1)  D  S TIEN=0 | 
|---|
| 46 | ..S IENN=0 F  S IENN=$O(^PXRMD(801.41,"AD",TIEN,IENN)) Q:IENN=""  D | 
|---|
| 47 | ...I $D(GECDA(IENN)) S OK=1,HFDIA(IEN,$O(GECDA(IENN,"")))="" S ^TMP("PXRMGECX",$J,"TEXT",IENN,DGIEN,IEN)="" | 
|---|
| 48 | ...I OK=0,'$D(DONE(IENN)) S TREE(IENN)="" | 
|---|
| 49 | ..K TREE(TIEN) S DONE(TIEN)="" | 
|---|
| 50 | I OK=0&($D(TREE)) G REDO | 
|---|
| 51 | K TREE,IENN,DONE | 
|---|
| 52 | Q OK | 
|---|
| 53 | ; | 
|---|
| 54 | MUL(IEN,DGDA) ;SEARCH ADDITONAL FINDINGS | 
|---|
| 55 | N YES | 
|---|
| 56 | S YES=0 | 
|---|
| 57 | I $D(^PXRMD(801.41,DGDA,3,"B",IEN_";AUTTHF(")) S YES=1 | 
|---|
| 58 | Q YES | 
|---|
| 59 | ; | 
|---|
| 60 | HF ;Gather Health Factors | 
|---|
| 61 | K ^TMP("PXRMGEC",$J,"MAN"),^TMP("PXRMGEC",$J,"MAN1") | 
|---|
| 62 | N IEN,CAT,DIA,CATDA,CATNA,FNA,REF,ANS,STOP | 
|---|
| 63 | S IEN=0 | 
|---|
| 64 | F  S IEN=$O(^AUTTHF(IEN)) Q:IEN<1  D | 
|---|
| 65 | .Q:$P($G(^AUTTHF(IEN,0)),"^",11)=1 | 
|---|
| 66 | .S FNA=$P($G(^AUTTHF(IEN,0)),"^",1) | 
|---|
| 67 | .S CAT=$P($G(^AUTTHF(IEN,0)),"^",10) | 
|---|
| 68 | .I CAT="F" D | 
|---|
| 69 | ..Q:$P($G(^AUTTHF(IEN,0)),"^",11)=1 | 
|---|
| 70 | ..S CATDA=$P($G(^AUTTHF(IEN,0)),"^",3) | 
|---|
| 71 | ..Q:CATDA="" | 
|---|
| 72 | ..Q:$P($G(^AUTTHF(CATDA,0)),"^",11)=1 | 
|---|
| 73 | ..S CATNA=$P($G(^AUTTHF(CATDA,0)),"^",1) | 
|---|
| 74 | ..I CATNA["GEC" D | 
|---|
| 75 | ...I $P($G(^AUTTHF(CATDA,0)),"^",9)'="" D | 
|---|
| 76 | ....Q:$P($G(^AUTTHF(CATDA,0)),"^",11)=1 | 
|---|
| 77 | ....S DIASYN=$P($G(^AUTTHF(CATDA,0)),"^",9) | 
|---|
| 78 | ....S ANS=$P($G(^AUTTHF(IEN,0)),"^",9),VAL=$S(ANS'="":$P(ANS," ",$L(ANS," ")),1:0) | 
|---|
| 79 | ....S ^TMP("PXRMGEC",$J,"MAN",DIASYN,CATNA,FNA,VAL,IEN,$$SCREEN(IEN))="" | 
|---|
| 80 | ....I $D(HFDIA(IEN)) S ^TMP("PXRMGEC",$J,"MAN1",$O(HFDIA(IEN,"")),CATNA,FNA,VAL,IEN,$$SCREEN(IEN))="" | 
|---|
| 81 | Q | 
|---|
| 82 | ; | 
|---|
| 83 | PR ; | 
|---|
| 84 | N REFM,STOPNA,TIEN,VO | 
|---|
| 85 | S REF="^TMP(""PXRMGEC"",$J,""MAN"")" | 
|---|
| 86 | S REFM="^TMP(""PXRMGEC"",$J,""MATCH"")" | 
|---|
| 87 | S X="IOINHI;IOINLOW;IORVON;IORVOFF" | 
|---|
| 88 | D ENDR^%ZISS | 
|---|
| 89 | D DAS,MATCHB^PXRMGECY,MATCHB^PXRMGECZ | 
|---|
| 90 | N DIACNT,CATCNT,FACCNT,IEN,VAL,STOPCNT,NEWFNA,SYN,TERM | 
|---|
| 91 | S (DIACNT,CATCNT,FACCNT,STOPCNT)=0 | 
|---|
| 92 | D HF | 
|---|
| 93 | ; | 
|---|
| 94 | ; | 
|---|
| 95 | S DIASYN="" F  S DIASYN=$O(@REF@(DIASYN)) Q:DIASYN=""  D | 
|---|
| 96 | .S DIACNT=DIACNT+1 | 
|---|
| 97 | .W !!!,DIACNT_". Dialog- GEC REFERRAL "_$P(DIASYN," ",2,4) | 
|---|
| 98 | .S CATNA="" F  S CATNA=$O(@REF@(DIASYN,CATNA)) Q:CATNA=""  D | 
|---|
| 99 | ..K @REFM@(CATNA) | 
|---|
| 100 | ..S CATCNT=CATCNT+1 | 
|---|
| 101 | ..W !!,DIACNT_". Dialog- GEC REFERRAL "_$P(DIASYN," ",2,4) | 
|---|
| 102 | ..W !!,CATCNT_".   Category- ",CATNA | 
|---|
| 103 | ..W !,"      Synonum- "_DIASYN | 
|---|
| 104 | ..W !!,"  Health Factors---" | 
|---|
| 105 | ..S FNA="" F  S FNA=$O(@REF@(DIASYN,CATNA,FNA)) Q:FNA=""  D | 
|---|
| 106 | ...S FACCNT=FACCNT+1 | 
|---|
| 107 | ...S VAL=$O(@REF@(DIASYN,CATNA,FNA,-1)) | 
|---|
| 108 | ...S IEN=$O(@REF@(DIASYN,CATNA,FNA,VAL,0)) | 
|---|
| 109 | ...S STOP=$O(@REF@(DIASYN,CATNA,FNA,VAL,IEN,-1)) | 
|---|
| 110 | ...I STOP=0 S STOPCNT=STOPCNT+1 | 
|---|
| 111 | ...S STOPNA=$S(STOP=0:"(((NOT IN USE)))",1:"") | 
|---|
| 112 | ...S VO=0 | 
|---|
| 113 | ...I STOPNA'="" S VO=1 | 
|---|
| 114 | ...W !,FACCNT_".     " I VO W IORVON | 
|---|
| 115 | ...W FNA,"  ",STOPNA,IORVOFF I $L(FNA)>40 W " ",IORVON,$L(FNA),IORVOFF | 
|---|
| 116 | ...W !,?19,$S('$D(@REFM@(FNA,IEN)):IORVON,1:""),"ien- "_IEN," (",$O(@REFM@(FNA,0))_")",IORVOFF I '$D(@REFM@(FNA)) W ! | 
|---|
| 117 | ...W ?17,IORVON,$S($D(@REFM@(FNA)):"",1:"**NOT Originally Released Name") W IORVOFF K @REFM@(FNA) | 
|---|
| 118 | ...S SYN=$P($G(^AUTTHF($O(^AUTTHF("B",FNA,0)),0)),"^",9) | 
|---|
| 119 | ...S TERM=$O(^PXRMD(811.5,"AF",IEN_";AUTTHF(",0)) | 
|---|
| 120 | ...W !,?18,$S(TERM="":IORVON,1:""),"Term- ",$S(TERM="":"NO TERM",1:$P($G(^PXRMD(811.5,TERM,0)),"^",1)),IORVOFF | 
|---|
| 121 | ...I SYN="" W !,?17,IORVON,$S(SYN="":"**Synonum Missing",1:"syn- "_SYN),IORVOFF | 
|---|
| 122 | ...E  W !,?19,$S(SYN="":"**Synonum Missing",1:"syn- "_SYN) | 
|---|
| 123 | ...W !,?19,"val- "_VAL,! | 
|---|
| 124 | ...W IORVOFF | 
|---|
| 125 | I $D(@REFM) W !!,?7,"**Missing Original GEC Health Factors**" | 
|---|
| 126 | I $D(@REFM) S FNA="" F  S FNA=$O(@REFM@(FNA)) Q:FNA=""  D | 
|---|
| 127 | .W !,?10,FNA | 
|---|
| 128 | W ! | 
|---|
| 129 | W !,"Categories    - "_$J(CATCNT,3) | 
|---|
| 130 | W !,"Health Factors- "_$J(FACCNT,3) | 
|---|
| 131 | W !,"Not in Use    - "_$J(STOPCNT,3) | 
|---|
| 132 | W !,"Used Factors  - ",$J(((FACCNT+CATCNT)-STOPCNT),3) | 
|---|
| 133 | W ! | 
|---|
| 134 | W !,"-----------------------------END OF REPORT ----------------------" | 
|---|
| 135 | K ^TMP("PXRMGEC",$J,"MAN"),^TMP("PXRMGEC",$J,"MAN1"),HFDIA | 
|---|
| 136 | K ^TMP("PXRMGEC",$J,"MATCH") | 
|---|
| 137 | D KILL^%ZISS | 
|---|
| 138 | Q | 
|---|
| 139 | ; | 
|---|
| 140 | ; | 
|---|
| 141 | ; | 
|---|
| 142 | PR1 S REF="^TMP(""PXRMGEC"",$J,""MAN1"")" | 
|---|
| 143 | S X="IOINHI;IOINLOW;IORVON;IORVOFF" | 
|---|
| 144 | D ENDR^%ZISS | 
|---|
| 145 | D DAS,MATCHB^PXRMGECY,MATCHB^PXRMGECZ | 
|---|
| 146 | N DIACNT,CATCNT,FACCNT,IEN,VAL,STOPCNT,XCNT | 
|---|
| 147 | S (DIACNT,CATCNT,FACCNT,STOPCNT)=0 | 
|---|
| 148 | D HF | 
|---|
| 149 | ; | 
|---|
| 150 | DISPLAY ;REPORT DISPLAY | 
|---|
| 151 | ; | 
|---|
| 152 | S DIASYN="" F  S DIASYN=$O(@REF@(DIASYN)) Q:DIASYN=""  D | 
|---|
| 153 | .S DIACNT=DIACNT+1,CATCNT=0 | 
|---|
| 154 | .W !!,DIACNT," Dialog- "_$P($G(^PXRMD(801.41,$O(^PXRMD(801.41,"AC",DIASYN,"")),0)),"^",1) | 
|---|
| 155 | .S CATNA="" F  S CATNA=$O(@REF@(DIASYN,CATNA)) Q:CATNA=""  D | 
|---|
| 156 | ..S CATCNT=CATCNT+1 | 
|---|
| 157 | ..W !!,?2,CATCNT_". Category- ",CATNA | 
|---|
| 158 | ..W !,?7,"    Ref#   (score)  Health Factors---" | 
|---|
| 159 | ..N FNACNT S FNACNT=0 | 
|---|
| 160 | ..S FNA="" F  S FNA=$O(@REF@(DIASYN,CATNA,FNA)) Q:FNA=""  D | 
|---|
| 161 | ...S XCNT=FACCNT,FACCNT=FACCNT+1,FNACNT=FNACNT+1 | 
|---|
| 162 | ...S VAL=$O(@REF@(DIASYN,CATNA,FNA,-1)) | 
|---|
| 163 | ...S IEN=$O(@REF@(DIASYN,CATNA,FNA,VAL,0)) | 
|---|
| 164 | ...S STOP=$O(@REF@(DIASYN,CATNA,FNA,VAL,IEN,-1)) | 
|---|
| 165 | ...I STOP=0 S FACCNT=XCNT | 
|---|
| 166 | ...I STOP=0 S STOPCNT=STOPCNT+1 Q | 
|---|
| 167 | ...S STOPNA=$S(STOP=0:"(((NOT IN USE)))",1:"") | 
|---|
| 168 | ...N COMB S COMB=DIACNT_"."_CATCNT_"."_FNACNT_"  ("_VAL_")" | 
|---|
| 169 | ...S VO=0 | 
|---|
| 170 | ...I STOPNA'="" S VO=1 | 
|---|
| 171 | ...W !,"   " I VO W IORVON | 
|---|
| 172 | ...W ?11,COMB,"     "_FNA,"  ",STOPNA,IORVOFF W " " | 
|---|
| 173 | ...;================================================== | 
|---|
| 174 | ...W IORVOFF | 
|---|
| 175 | W !!,"Health Factors- "_$J(FACCNT,3) | 
|---|
| 176 | W ! | 
|---|
| 177 | W !,"-----------------------------END OF REPORT ----------------------" | 
|---|
| 178 | K ^TMP("PXRMGEC",$J,"MAN"),^TMP("PXRMGEC",$J,"MAN1"),HFDIA | 
|---|
| 179 | K ^TMP("PXRMGEC",$J,"MATCH") | 
|---|
| 180 | D KILL^%ZISS | 
|---|
| 181 | Q | 
|---|
| 182 | ; | 
|---|