| 1 | PXRMDLR ;SLC/PJH - DIALOG RESULTS LOADER ;05/15/2007 | 
|---|
| 2 | ;;2.0;CLINICAL REMINDERS;**6**;Feb 04, 2005;Build 123 | 
|---|
| 3 | ; | 
|---|
| 4 | ;Build score related P/N text from score and result group | 
|---|
| 5 | ; | 
|---|
| 6 | ;If not found | 
|---|
| 7 | START(ORY,RESULT,ORES) ; | 
|---|
| 8 | I '$G(RESULT) S ORY(1)="-1^no results for this test" Q | 
|---|
| 9 | ; | 
|---|
| 10 | N ARRAY,ERROR,INSERT,OK,SCORE,SUB,YT,X | 
|---|
| 11 | ; | 
|---|
| 12 | I RESULT["~" S RESULT=$P(RESULT,"~") | 
|---|
| 13 | S ERROR=0 | 
|---|
| 14 | ; | 
|---|
| 15 | ;Get score using API | 
|---|
| 16 | K ^TMP($J,"YSCOR") | 
|---|
| 17 | I ORES("CODE")'="DOM80" D  Q:ERROR | 
|---|
| 18 | .M YT=ORES | 
|---|
| 19 | .F X=1:1:$L(YT("R1")) I $E(YT("R1"),X)'="X" S YT(X)=X_U_$E(YT("R1"),X) | 
|---|
| 20 | .K YT("R1") | 
|---|
| 21 | .D CHECKCR^YTQPXRM4(.ARRAY,.YT) | 
|---|
| 22 | .S OK=0 | 
|---|
| 23 | .;D PREVIEW^YTAPI4(.ARRAY,.YT) | 
|---|
| 24 | .I ^TMP($J,"YSCOR",1)'="[DATA]" S ORY(1)="-1^"_^TMP($J,"YSCOR",1)_^TMP($J,"YSCOD",2),ERROR=1 Q | 
|---|
| 25 | .;I ARRAY(1)'="[DATA]" S ORY(1)="-1^"_ARRAY(1)_ARRAY(2),ERROR=1 Q | 
|---|
| 26 | .I $P($G(^TMP($J,"YSCOR",2)),"=",2)'="" S SCORE=$P($G(^TMP($J,"YSCOR",2)),"=",2),OK=1 | 
|---|
| 27 | .;S SUB=0,OK=0 | 
|---|
| 28 | .;F  S SUB=$O(ARRAY(SUB)) Q:'SUB  D  Q:OK | 
|---|
| 29 | .;.I $P(ARRAY(SUB),U)="S1" S SCORE=$P(ARRAY(SUB),U,3),OK=1 | 
|---|
| 30 | .I 'OK S ORY(1)="-1^[ERROR] no score returned",ERROR=1 Q | 
|---|
| 31 | ; | 
|---|
| 32 | ;Except for DOM80 | 
|---|
| 33 | I ORES("CODE")="DOM80" D | 
|---|
| 34 | .I $E(ORES("R1"))="Y" S SCORE=1 Q | 
|---|
| 35 | .I $E(ORES("R1"),2,3)="YY",($E(ORES("R1"),4)>1) S SCORE=1 Q | 
|---|
| 36 | .S SCORE=0 | 
|---|
| 37 | ; | 
|---|
| 38 | S DFN=$G(ORES("DFN")) | 
|---|
| 39 | S INSERT("SCORE")=SCORE | 
|---|
| 40 | ; | 
|---|
| 41 | ;For AIMS special formatting is required | 
|---|
| 42 | I ORES("CODE")="AIMS" D | 
|---|
| 43 | .N CNT,LITS,RESP,SUM | 
|---|
| 44 | .S LITS(0)="none",LITS(1)="minimal",LITS(2)="mild",LITS(3)="moderate" | 
|---|
| 45 | .S LITS(4)="severe",SUM(2)=0,SUM(3)=0,SUM(4)=0 | 
|---|
| 46 | .F CNT=1:1 S RESP=$E(ORES("R1"),CNT) Q:RESP=""  D | 
|---|
| 47 | ..S INSERT("R"_CNT)=$G(LITS(RESP)) | 
|---|
| 48 | ..I (CNT<8),(234[RESP) S SUM(RESP)=SUM(RESP)+1 | 
|---|
| 49 | .F CNT=2,3,4 S INSERT("SUM"_CNT)=SUM(CNT) | 
|---|
| 50 | ; | 
|---|
| 51 | TEXT ; | 
|---|
| 52 | I RESULT["~" S RESULT=$P(RESULT,"~") | 
|---|
| 53 | ;Load dialog results into ORY array | 
|---|
| 54 | N DATA,DCON,DITEM,DSEQ,DSUB,DTYP,INS,SEP,TEXT | 
|---|
| 55 | ;Get the result elements | 
|---|
| 56 | S DSEQ=0,OCNT=0 | 
|---|
| 57 | F  S DSEQ=$O(^PXRMD(801.41,RESULT,10,"B",DSEQ)) Q:'DSEQ  D | 
|---|
| 58 | .S DSUB=$O(^PXRMD(801.41,RESULT,10,"B",DSEQ,"")) Q:'DSUB | 
|---|
| 59 | .S DITEM=$P($G(^PXRMD(801.41,RESULT,10,DSUB,0)),U,2) Q:'DITEM | 
|---|
| 60 | .;Get the result element | 
|---|
| 61 | .S DTYP=$P($G(^PXRMD(801.41,DITEM,0)),U,4) Q:DTYP'="T" | 
|---|
| 62 | .;Get the result element condition | 
|---|
| 63 | .S DCON=$P($G(^PXRMD(801.41,DITEM,0)),U,13) | 
|---|
| 64 | .;Skip if condition not satisfied | 
|---|
| 65 | .I DCON'="" S DCON=$TR(DCON,"~"," ") Q:'$$TRUE(SCORE,DCON,DFN) | 
|---|
| 66 | .;Get progress note text if defined | 
|---|
| 67 | .N LAST,NULL,SUB,TEXT S SUB=0,LAST=0 | 
|---|
| 68 | .F  S SUB=$O(^PXRMD(801.41,DITEM,35,SUB)) Q:'SUB  D | 
|---|
| 69 | ..;Insert score into text (if neccessary) | 
|---|
| 70 | ..S TEXT=$G(^PXRMD(801.41,DITEM,35,SUB,0)) | 
|---|
| 71 | ..S NULL=0 I ($E(TEXT)=" ")!(TEXT="") S NULL=1 | 
|---|
| 72 | ..;Add line breaks if is or preceded by blank line or starts with space | 
|---|
| 73 | ..I ('NULL),LAST S TEXT="<br>"_TEXT | 
|---|
| 74 | ..S TEXT=$$STRREP^PXRMUTIL(TEXT,"\\","<br>") | 
|---|
| 75 | ..S LAST=0 I NULL S TEXT="<br>"_TEXT,LAST=1 | 
|---|
| 76 | ..;Check for inserts - note there may be embedded TIU markers too | 
|---|
| 77 | ..N INS | 
|---|
| 78 | ..S INS="" | 
|---|
| 79 | ..F  S INS=$O(INSERT(INS)) Q:INS=""  D | 
|---|
| 80 | ...S SEP="|"_INS_"|" I '$F(TEXT,SEP) Q | 
|---|
| 81 | ...S TEXT=$P(TEXT,SEP)_$G(INSERT(INS))_$P(TEXT,SEP,2,99) | 
|---|
| 82 | ..S OCNT=OCNT+1,ORY(OCNT)=7_U_TEXT | 
|---|
| 83 | Q | 
|---|
| 84 | ; | 
|---|
| 85 | MHDLL(ORES,RESULT,SCORE,DFN) ; | 
|---|
| 86 | S INSERT("SCORE")=SCORE | 
|---|
| 87 | D TEXT | 
|---|
| 88 | Q | 
|---|
| 89 | OUT(DATA) ;Display element details | 
|---|
| 90 | N DITEM S DITEM=$P(DATA,U,2) Q:'DITEM | 
|---|
| 91 | W $P($G(^PXRMD(801.41,DITEM,0)),U) | 
|---|
| 92 | W !,$J("Element Condition:  ",19) | 
|---|
| 93 | W $TR($P($G(^PXRMD(801.41,DITEM,0)),U,13),"~"," ") | 
|---|
| 94 | W !,$J("Element text:",17) | 
|---|
| 95 | ;Get progress note text if defined | 
|---|
| 96 | N SUB,TEXT S SUB=0 | 
|---|
| 97 | F  S SUB=$O(^PXRMD(801.41,DITEM,35,SUB)) Q:'SUB  D | 
|---|
| 98 | .S TEXT=$G(^PXRMD(801.41,DITEM,35,SUB,0)) W !,?5,TEXT | 
|---|
| 99 | Q | 
|---|
| 100 | ; | 
|---|
| 101 | TRUE(V,COND,DFN) ; Check if value meets element condition | 
|---|
| 102 | N RESULT,SEX | 
|---|
| 103 | I COND["SEX" D  Q RESULT | 
|---|
| 104 | . S RESULT=0 | 
|---|
| 105 | . S SEX=$P($G(^DPT(DFN,0)),U,2) | 
|---|
| 106 | . X COND I  S RESULT=1 | 
|---|
| 107 | X COND I  Q 1 | 
|---|
| 108 | Q 0 | 
|---|