PXBGPL2 ;ISL/JVS - DOUBLE ?? GATHERING OF PATIENT PROBLEM LIST;3/8/96 11:33 ;11/5/96 14:18
;;1.0;PCE PATIENT CARE ENCOUNTER;**11,199**;Aug 12, 1996;Build 51
;
W !,"THIS IS NOT AN ENTRY POINT" Q
;
;
DOUBLE1(FROM) ;--Entry point
;
NEW ;
;
S PNAME=NAME
N FILE,FIELD,TITLE,HEADING,SUB,CODE,NAME,START,SCREEN,CNT,OK,INDEX,CYCLE
N TOTAL,POV,CNT,PXBPMT,SUB2
;---SETUP VARIABLES
S BACK="",INDEX=""
S START=DATA,SUB=0,SUB2=0
;
START1 ;--RECYCLE POINT
S TITLE="PATIENT PROBLEM LIST"
;
D PL^PXBGPL(PATIENT)
;
I '$D(PXBPMT) S TOTAL=0
I $D(PXBPMT) D
.S (POV,CNT)="" F S POV=$O(PXBPMT("PL",POV)) Q:POV="" S CNT=CNT+1 D
..S ^TMP("PXBTOTAL",$J,"DILIST","ID",CNT,.01)=POV
I $D(CNT) S TOTAL=CNT
;
;--DISPLAY IF NO MATCH FOUND
I TOTAL=0 W IOCUU,IOCUU,!,IOELEOL D
.D LOC W !
.W !!! D HELP^PXBUTL0("PLM")
.D HELP1^PXBUTL1("CON") R OK:DTIME
I TOTAL=0 Q TOTAL
;
;
;----DISPLAY LIST TO THE SCREEN
S HEADING="W !,""ITEM"",?6,""NAME"",?16,""DESCRIPTION "",IOINHI,TOTAL,"" MATCHES"",IOINLOW"
LIST ;-DISPLAY LIST TO THE SCREEN
D LOC,HEAD
X HEADING
S SUB=SUB-1
S NUM=0 F S SUB=$O(^TMP("PXBTOTAL",$J,"DILIST","ID",SUB)) S NUM=NUM+1 Q:NUM=11 Q:SUB'>0 S SUB2=SUB2+1 D
.S NAME=$G(^TMP("PXBTOTAL",$J,"DILIST","ID",SUB,.01))
.W !,SUB,?6,$P(NAME," ",1),?16,$E($P(NAME," ",2,$L(NAME," ")),1,63)
;
;----If There is only one selection go to proper prompting
I TOTAL=1 G PRMPT2
I $G(VALL)=1 G PRMPT3
;
PRMPT ;---WRITE PROMPT HERE
D LOC^PXBCC(15,1)
D WIN17^PXBCC(PXBCNT)
W !
I SUB>0 W !,"Enter '^' to quit"
E I TOTAL>10 W !," END OF LIST"
I SUB>0 S DIR("A")="Select a single 'ITEM NUMBER' or 'RETURN' to continue: "
E S DIR("A")="Select a single 'ITEM NUMBER' or 'RETURN' to exit: "
S DIR("?")="^D HELP^PXBUTL0(""PL11"")"
S DIR(0)="N,A,O^0:"_SUB2_":0^I X'?.1""^"".N K X"
D ^DIR
I X="",SUB>0 G LIST
I X="",SUB'>0 S X="^"
VAL ;-----Set the VAL equal to the value
S VAL=$G(^TMP("PXBTOTAL",$J,"DILIST",2,X))_"^"_$G(^TMP("PXBTOTAL",$J,"DILIST","ID",X,.01))
EXITNEW ;--EXIT
K DIR,^TMP("PXBTANA",$J),^TMP("PXBTOTAL",$J)
K TANA,TOTAL
Q VAL
PRMPT3 ;---WRITE PROMPT HERE
D LOC^PXBCC(15,1)
D WIN17^PXBCC(PXBCNT)
W !!
D HELP1^PXBUTL1("CON") R OK:DTIME
I SUB>0 G LIST
I SUB'>0 S X="^"
VALL ;-----Set the VAL equal to the value
S VAL=$G(^TMP("PXBTOTAL",$J,"DILIST",2,X))_"^"_$G(^TMP("PXBTOTAL",$J,"DILIST","ID",X,.01))
EXITNEWW ;--EXIT
K ^TMP("PXBTANA",$J),^TMP("PXBTOTAL",$J)
K TANA,TOTAL
Q VAL
Q
;
;-----------------SUBROUTINES--------------
BACK ;
S START=$G(^TMP("PXBTANA",$J,"DILIST",1,1))
S START("IEN")=$G(^TMP("PXBTANA",$J,"DILIST",2,1))
Q
FORWARD ;
S START=$G(^TMP("PXBTANA",$J,"DILIST",1,10))
S START("IEN")=$G(^TMP("PXBTANA",$J,"DILIST",2,10))
Q
LOC ;--LOCATE CURSOR
D LOC^PXBCC(3,1) ;--LOCATE THE CURSOR
W IOEDEOP ;--CLEAR THE PAGE
Q
HEAD ;--HEAD
W IOINHI,!,IOCUU,?(IOM-$L(TITLE))\2,TITLE,IOINLOW,IOELEOL
Q
SUB ;--DISPLAY LIST TO THE SCREEN
I $P(^TMP("PXBTANA",$J,"DILIST",0),"^",1)=0 W !!," E N D O F L I S T" Q
X HEADING
S SUB=0,CNT=0 F S SUB=$O(^TMP("PXBTANA",$J,"DILIST","ID",SUB)) Q:SUB'>0 S CNT=CNT+1 D
.S NAME=$G(^TMP("PXBTANA",$J,"DILIST","ID",SUB,.01))
.W !,SUB,?6,NAME
Q
SETUP ;-SETP VARIABLES
S FILE=200,FIELD=.01
S HEADING="W !,""ITEM"",?6,""NAME"""
Q
PRMPT2 ;-----Yes and No prompt if only choice
D WIN17^PXBCC(PXBCNT)
D LOC^PXBCC(15,1)
S DIR("A")="Is this the correct entry "
S DIR("B")="YES"
S DIR(0)="Y"
D ^DIR
I Y=0 S X="^"
I Y=1 S X=1
G VAL
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPXBGPL2 3571 printed Dec 13, 2024@02:26:38 Page 2
PXBGPL2 ;ISL/JVS - DOUBLE ?? GATHERING OF PATIENT PROBLEM LIST;3/8/96 11:33 ;11/5/96 14:18
+1 ;;1.0;PCE PATIENT CARE ENCOUNTER;**11,199**;Aug 12, 1996;Build 51
+2 ;
+3 WRITE !,"THIS IS NOT AN ENTRY POINT"
QUIT
+4 ;
+5 ;
DOUBLE1(FROM) ;--Entry point
+1 ;
NEW ;
+1 ;
+2 SET PNAME=NAME
+3 NEW FILE,FIELD,TITLE,HEADING,SUB,CODE,NAME,START,SCREEN,CNT,OK,INDEX,CYCLE
+4 NEW TOTAL,POV,CNT,PXBPMT,SUB2
+5 ;---SETUP VARIABLES
+6 SET BACK=""
SET INDEX=""
+7 SET START=DATA
SET SUB=0
SET SUB2=0
+8 ;
START1 ;--RECYCLE POINT
+1 SET TITLE="PATIENT PROBLEM LIST"
+2 ;
+3 DO PL^PXBGPL(PATIENT)
+4 ;
+5 IF '$DATA(PXBPMT)
SET TOTAL=0
+6 IF $DATA(PXBPMT)
Begin DoDot:1
+7 SET (POV,CNT)=""
FOR
SET POV=$ORDER(PXBPMT("PL",POV))
if POV=""
QUIT
SET CNT=CNT+1
Begin DoDot:2
+8 SET ^TMP("PXBTOTAL",$JOB,"DILIST","ID",CNT,.01)=POV
End DoDot:2
End DoDot:1
+9 IF $DATA(CNT)
SET TOTAL=CNT
+10 ;
+11 ;--DISPLAY IF NO MATCH FOUND
+12 IF TOTAL=0
WRITE IOCUU,IOCUU,!,IOELEOL
Begin DoDot:1
+13 DO LOC
WRITE !
+14 WRITE !!!
DO HELP^PXBUTL0("PLM")
+15 DO HELP1^PXBUTL1("CON")
READ OK:DTIME
End DoDot:1
+16 IF TOTAL=0
QUIT TOTAL
+17 ;
+18 ;
+19 ;----DISPLAY LIST TO THE SCREEN
+20 SET HEADING="W !,""ITEM"",?6,""NAME"",?16,""DESCRIPTION "",IOINHI,TOTAL,"" MATCHES"",IOINLOW"
LIST ;-DISPLAY LIST TO THE SCREEN
+1 DO LOC
DO HEAD
+2 XECUTE HEADING
+3 SET SUB=SUB-1
+4 SET NUM=0
FOR
SET SUB=$ORDER(^TMP("PXBTOTAL",$JOB,"DILIST","ID",SUB))
SET NUM=NUM+1
if NUM=11
QUIT
if SUB'>0
QUIT
SET SUB2=SUB2+1
Begin DoDot:1
+5 SET NAME=$GET(^TMP("PXBTOTAL",$JOB,"DILIST","ID",SUB,.01))
+6 WRITE !,SUB,?6,$PIECE(NAME," ",1),?16,$EXTRACT($PIECE(NAME," ",2,$LENGTH(NAME," ")),1,63)
End DoDot:1
+7 ;
+8 ;----If There is only one selection go to proper prompting
+9 IF TOTAL=1
GOTO PRMPT2
+10 IF $GET(VALL)=1
GOTO PRMPT3
+11 ;
PRMPT ;---WRITE PROMPT HERE
+1 DO LOC^PXBCC(15,1)
+2 DO WIN17^PXBCC(PXBCNT)
+3 WRITE !
+4 IF SUB>0
WRITE !,"Enter '^' to quit"
+5 IF '$TEST
IF TOTAL>10
WRITE !," END OF LIST"
+6 IF SUB>0
SET DIR("A")="Select a single 'ITEM NUMBER' or 'RETURN' to continue: "
+7 IF '$TEST
SET DIR("A")="Select a single 'ITEM NUMBER' or 'RETURN' to exit: "
+8 SET DIR("?")="^D HELP^PXBUTL0(""PL11"")"
+9 SET DIR(0)="N,A,O^0:"_SUB2_":0^I X'?.1""^"".N K X"
+10 DO ^DIR
+11 IF X=""
IF SUB>0
GOTO LIST
+12 IF X=""
IF SUB'>0
SET X="^"
VAL ;-----Set the VAL equal to the value
+1 SET VAL=$GET(^TMP("PXBTOTAL",$JOB,"DILIST",2,X))_"^"_$GET(^TMP("PXBTOTAL",$JOB,"DILIST","ID",X,.01))
EXITNEW ;--EXIT
+1 KILL DIR,^TMP("PXBTANA",$JOB),^TMP("PXBTOTAL",$JOB)
+2 KILL TANA,TOTAL
+3 QUIT VAL
PRMPT3 ;---WRITE PROMPT HERE
+1 DO LOC^PXBCC(15,1)
+2 DO WIN17^PXBCC(PXBCNT)
+3 WRITE !!
+4 DO HELP1^PXBUTL1("CON")
READ OK:DTIME
+5 IF SUB>0
GOTO LIST
+6 IF SUB'>0
SET X="^"
VALL ;-----Set the VAL equal to the value
+1 SET VAL=$GET(^TMP("PXBTOTAL",$JOB,"DILIST",2,X))_"^"_$GET(^TMP("PXBTOTAL",$JOB,"DILIST","ID",X,.01))
EXITNEWW ;--EXIT
+1 KILL ^TMP("PXBTANA",$JOB),^TMP("PXBTOTAL",$JOB)
+2 KILL TANA,TOTAL
+3 QUIT VAL
+4 QUIT
+5 ;
+6 ;-----------------SUBROUTINES--------------
BACK ;
+1 SET START=$GET(^TMP("PXBTANA",$JOB,"DILIST",1,1))
+2 SET START("IEN")=$GET(^TMP("PXBTANA",$JOB,"DILIST",2,1))
+3 QUIT
FORWARD ;
+1 SET START=$GET(^TMP("PXBTANA",$JOB,"DILIST",1,10))
+2 SET START("IEN")=$GET(^TMP("PXBTANA",$JOB,"DILIST",2,10))
+3 QUIT
LOC ;--LOCATE CURSOR
+1 ;--LOCATE THE CURSOR
DO LOC^PXBCC(3,1)
+2 ;--CLEAR THE PAGE
WRITE IOEDEOP
+3 QUIT
HEAD ;--HEAD
+1 WRITE IOINHI,!,IOCUU,?(IOM-$LENGTH(TITLE))\2,TITLE,IOINLOW,IOELEOL
+2 QUIT
SUB ;--DISPLAY LIST TO THE SCREEN
+1 IF $PIECE(^TMP("PXBTANA",$JOB,"DILIST",0),"^",1)=0
WRITE !!," E N D O F L I S T"
QUIT
+2 XECUTE HEADING
+3 SET SUB=0
SET CNT=0
FOR
SET SUB=$ORDER(^TMP("PXBTANA",$JOB,"DILIST","ID",SUB))
if SUB'>0
QUIT
SET CNT=CNT+1
Begin DoDot:1
+4 SET NAME=$GET(^TMP("PXBTANA",$JOB,"DILIST","ID",SUB,.01))
+5 WRITE !,SUB,?6,NAME
End DoDot:1
+6 QUIT
SETUP ;-SETP VARIABLES
+1 SET FILE=200
SET FIELD=.01
+2 SET HEADING="W !,""ITEM"",?6,""NAME"""
+3 QUIT
PRMPT2 ;-----Yes and No prompt if only choice
+1 DO WIN17^PXBCC(PXBCNT)
+2 DO LOC^PXBCC(15,1)
+3 SET DIR("A")="Is this the correct entry "
+4 SET DIR("B")="YES"
+5 SET DIR(0)="Y"
+6 DO ^DIR
+7 IF Y=0
SET X="^"
+8 IF Y=1
SET X=1
+9 GOTO VAL