GMPLEDIT ; SLC/MKB/KER -- VALM Utilities for Edit sub-list ; 04/15/2002 ;;2.0;Problem List;**26**;Aug 25, 1994 ; ; External References ; DBIA 10060 ^VA(200 ; DBIA 10076 ^XUSEC("GMPL ICD CODE" ; DBIA 10009 YN^DICN ; DBIA 10116 $$SETSTR^VALM1 ; DBIA 10117 CLEAN^VALM10 ; DBIA 10117 CNTRL^VALM10 ; DBIA 10103 $$FMTE^XLFDT ; DBIA 10104 $$REPEAT^XLFSTR ; EN ; Init Variables, list array ; Expects GMPIFN IEN of file 900011 (required) ; GMPLNUM Sequence # of Problem Edit (optional) W !!,"Retrieving current data for problem " W $S($G(GMPLNUM):"#"_GMPLNUM_" ",1:"")_"...",! K GMPFLD,GMPORIG ; Set GMPFLD() and GMPORIG() Arrays D GETFLDS^GMPLEDT3(GMPIFN) I '$D(GMPFLD) W !!,"ERROR -- Cannot continue.",! S VALMBCK="Q" G KILL INIT ; Build list from GMPFLD() N LCNT,TEXT,I,SP,LINE,STR,NUM,NOTE,ICD S LCNT=1,ICD=$S($D(^XUSEC("GMPL ICD CODE",DUZ)):1,1:0) S SP="" F I=1.11,1.12,1.13,1.15,1.16 S:GMPFLD(I) SP=SP_$P(GMPFLD(I),U,2)_U S:$L(SP) SP=$E(SP,1,$L(SP)-1) K GMPSAVED,GMPREBLD D CLEAN^VALM10 D WRAP^GMPLX($P(GMPFLD(.05),U,2),65,.TEXT) ; Line 1 S LINE="1 Problem: "_TEXT(1) S ^TMP("GMPLEDIT",$J,LCNT,0)=LINE D HI(LCNT,1) I $D(GMPLUSER),GMPARAM("VER"),GMPFLD(1.02)="T" S LINE=$E(LINE,1,12)_"$"_$E(LINE,14,79),^TMP("GMPLEDIT",$J,LCNT,0)=LINE D HI(LCNT,13) I TEXT>1 F I=2:1:TEXT S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)=" "_TEXT(I) S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)=" " IN1 ; Line 2 S LINE="2 Onset: ",STR=$P(GMPFLD(.13),U,2) S LINE=LINE_$S(STR="":"unknown",1:STR),LCNT=LCNT+1 I GMPVA S STR=$S(ICD:7,1:6)_" SC Condition: "_$S(GMPFLD(1.1)="":"unknown",1:$P(GMPFLD(1.1),U,2)),LINE=$$SETSTR^VALM1(STR,LINE,45,34) S ^TMP("GMPLEDIT",$J,LCNT,0)=LINE F I=1,45 D HI(LCNT,I) IN2 ; Line 3 S LINE="3 Status: "_$P(GMPFLD(.12),U,2),LCNT=LCNT+1 I $E(GMPFLD(.12))="A",$L(GMPFLD(1.14)) S LINE=LINE_"/"_$P(GMPFLD(1.14),U,2) I $E(GMPFLD(.12))="I",GMPFLD(1.07) S LINE=LINE_", Resolved "_$P(GMPFLD(1.07),U,2) I GMPVA S STR=$S(ICD:8,1:7)_" Exposure: "_$S('$L(SP):"",1:$P(SP,U)),LINE=$$SETSTR^VALM1(STR,LINE,45,34) S ^TMP("GMPLEDIT",$J,LCNT,0)=LINE F I=1,45 D HI(LCNT,I) IN3 ; Line 4 S LINE="4 Provider: "_$P(GMPFLD(1.05),U,2),LCNT=LCNT+1 I GMPVA,$L(SP,U)>1 S STR=$P(SP,U,2),LINE=$$SETSTR^VALM1(STR,LINE,60,20) S ^TMP("GMPLEDIT",$J,LCNT,0)=LINE D HI(LCNT,1) ; Line 5 I $E(GMPLVIEW("VIEW"))="S" S LINE="5 Service: "_$P(GMPFLD(1.06),U,2) E S LINE="5 Clinic: "_$P(GMPFLD(1.08),U,2) I GMPVA,$L(SP,U)>2 S STR=$P(SP,U,3),LINE=$$SETSTR^VALM1(STR,LINE,60,20) S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)=LINE D HI(LCNT,1) G:'ICD IN4 ; Line 6 S LINE="6 ICD Code: "_$P(GMPFLD(.01),U,2),LCNT=LCNT+1 S ^TMP("GMPLEDIT",$J,LCNT,0)=LINE D HI(LCNT,1) IN4 ; Line 7/8 S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)=" " S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)="Comments: " D CNTRL^VALM10(LCNT,1,8,IOUON,IOUOFF) S NUM=$S(GMPVA:7,1:5) S:ICD NUM=NUM+1 I GMPFLD(10,0) F I=1:1:GMPFLD(10,0) D . S NUM=NUM+1,NOTE=GMPFLD(10,I) . S LINE=NUM_$E(" ",1,3-$L(NUM))_$J($$EXTDT^GMPLX($P(NOTE,U,5)),8) . I $P(GMPFLD(10,I),U,3)="",$P(GMPORIG(10,I),U,3)'="" S $P(NOTE,U,3)="" . S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)=LINE_": "_$P(NOTE,U,3) . D HI(LCNT,1) Q:'$D(GMPLMGR) . S LINE=" "_$P($G(^VA(200,+$P(NOTE,U,6),0)),U) . S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)=LINE IN5 ; Last Line I $D(GMPFLD(10,"NEW"))>9 S NUM=NUM+1 D . S LINE=NUM_$E(" ",1,3-$L(NUM))_$J($$EXTDT^GMPLX(DT),8)_": " . S I=$O(GMPFLD(10,"NEW",0)),LINE=LINE_GMPFLD(10,"NEW",I) . S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)=LINE D HI(LCNT,1) . F S I=$O(GMPFLD(10,"NEW",I)) Q:I'>0 D . . S LINE=" "_GMPFLD(10,"NEW",I) . . S LCNT=LCNT+1,^TMP("GMPLEDIT",$J,LCNT,0)=LINE S VALMCNT=LCNT,^TMP("GMPLEDIT",$J,0)=NUM_U_LCNT,VALMSG=$$MSG^GMPLEDT3 Q ; HI(LINE,COL) ; Hi-lite # D CNTRL^VALM10(LINE,COL,3,IOINHI,IOINORM) Q ; HDR ; Header code N LASTMOD,PAT S PAT=$P(GMPDFN,U,2)_" ("_$P(GMPDFN,U,3)_")" S LASTMOD=$P(^AUPNPROB(GMPIFN,0),U,3) S LASTMOD="Last Updated: "_$$FMTE^XLFDT(LASTMOD) S VALMHDR(1)=PAT_$$REPEAT^XLFSTR(" ",(79-$L(PAT)-$L(LASTMOD)))_LASTMOD Q ; HELP ; Help code N X,CNT S CNT=+$G(^TMP("GMPLEDIT",$J,0)) W !!?4,"You may change one or more of the above listed values describing" W !?4,"this problem by entering its display number (1-"_CNT_") at the prompt;" W !?4,"you may then enter a new value, or '@' to delete an existing value." W !!?4,"Enter RM to remove this problem from the patient's list completely," W !?4,"SC to save your changes, or Q to simply return to the problem list." W:VALMCNT>11 !?4,"Enter '+' to see more information, as in the problem list." W !!,"Press to continue ... " R X:DTIME S VALMSG=$$MSG^GMPLEDT3,VALMBCK=$S(VALMCC:"",1:"R") Q ; EXIT ; Exit code N DIFFRENT,% G:$D(GMPSAVED) KILL S DIFFRENT=$$EDITED^GMPLEDT2 I 'DIFFRENT G KILL W $C(7),!!,">>> THIS PROBLEM HAS CHANGED!!" EX1 ; Ask to Save Changes on Exit W !?5,"Do you want to save these changes" S %=1 D YN^DICN G:(%<0)!(%=2) KILL I %=0 D G EX1 . W !!?5,"Enter YES or to save the current values listed above" . W !?5,"describing this problem; enter NO to exit without saving.",! W !!,"Saving ..." D EN^GMPLSAVE W " done." KILL ; Clean-up S CNT=+$G(^TMP("GMPLEDIT",$J,0)) F I=1:1:CNT K XQORM("KEY",I) D CLEAN^VALM10 K XQORM("KEY","$") K GMPFLD,GMPORIG,GMPQUIT,DUOUT,DTOUT,I,CNT Q