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