[613] | 1 | PPPDSP3 ;ALB/DMB - MEDICATION PROFILE DISPLAY ROUTINE ;5/19/92
|
---|
| 2 | ;;V1.0;PHARMACY PRESCRIPTION PRACTICE;**1,17**;APR 7,1995
|
---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
| 4 | ;
|
---|
| 5 | ; These routines control the display of the pharmacy medication
|
---|
| 6 | ; profiles via the list processor from scheduling.
|
---|
| 7 | ;
|
---|
| 8 | DSPMED(PATDFN,ARRAYNM,OBFLAG) ; List processor entry point
|
---|
| 9 | ;
|
---|
| 10 | ; This is the main entry point for calling the list processor.
|
---|
| 11 | ;
|
---|
| 12 | ; Parameters:
|
---|
| 13 | ; PATDFN - The patient internal entry number
|
---|
| 14 | ; ARRAYNM - An array containing the visit info (see GETVIS^PPPGET7).
|
---|
| 15 | ; OBFLAG - A flag containing "O" for profiles form only the other
|
---|
| 16 | ; facilities or "B" for profiles from both local and other.
|
---|
| 17 | ;
|
---|
| 18 | ;K XQORS,VALMEVL
|
---|
| 19 | D EN^VALM("PPP PROFILE")
|
---|
| 20 | Q
|
---|
| 21 | ;
|
---|
| 22 | INIT ; Collect all of the data and build the display array
|
---|
| 23 | ;
|
---|
| 24 | S VALMMENU=0
|
---|
| 25 | S VALMCNT=$$PRPROFIL(ARRAYNM)
|
---|
| 26 | I VALMCNT<1 D NUL
|
---|
| 27 | I OBFLAG="O" S VALM("TITLE")="Medication Profile - Other"
|
---|
| 28 | I OBFLAG="B" S VALM("TITLE")="Medication Profile - Both"
|
---|
| 29 | INITQ Q
|
---|
| 30 | ;
|
---|
| 31 | HDR ; Get header data and build it.
|
---|
| 32 | ;
|
---|
| 33 | N DIC,DA,DR,DIQ,DUOUT,DTOUT,PPPTMP
|
---|
| 34 | S DIC="^DPT(",DA=PATDFN,DR=".01;.03;.09",DIQ="PPPTMP" D EN^DIQ1
|
---|
| 35 | S VALMHDR(1)=""
|
---|
| 36 | S VALMHDR(2)="Patient: "_PPPTMP(2,PATDFN,.01)_" ("_PPPTMP(2,PATDFN,.09)_") DOB: "_PPPTMP(2,PATDFN,.03)
|
---|
| 37 | HDRQ Q
|
---|
| 38 | ;
|
---|
| 39 | NUL ; Set null message
|
---|
| 40 | ;
|
---|
| 41 | ;I '$O(@ARRAYNM@(0)) S @ARRAYNM@(1,0)=" ",@ARRAYNM@(2,0)=" No Data Available.",VALMCNT=2
|
---|
| 42 | S @ARRAYNM@(1,0)=" ",@ARRAYNM@(2,0)=" No Data Available.",VALMCNT=2
|
---|
| 43 | Q
|
---|
| 44 | ;
|
---|
| 45 | FNL ; Clean Up
|
---|
| 46 | ;
|
---|
| 47 | K ^TMP("PPP",$J,"LIST")
|
---|
| 48 | Q
|
---|
| 49 | ;
|
---|
| 50 | PRPROFIL(ARRAYNM) ; Print the med profile
|
---|
| 51 | ;
|
---|
| 52 | ; This function collects the medication profile data and formats it
|
---|
| 53 | ; for display.
|
---|
| 54 | ;
|
---|
| 55 | ; Parameters:
|
---|
| 56 | ; ARRAYNM - An array containing the visit info (see GETVIS^PPPGET7).
|
---|
| 57 | ;
|
---|
| 58 | N ND,PHRMARRY,RVRSDT,RXIDX,STANAME,STAPTR,TMP,Y,LSTARRAY
|
---|
| 59 | N TEXT,TXTLINE,U,LINE
|
---|
| 60 | ;
|
---|
| 61 | S PHRMARRY="^TMP(""PPP"",$J,""PHR"")"
|
---|
| 62 | S LSTARRAY="^TMP(""PPP"",$J,""LIST"")"
|
---|
| 63 | S U="^"
|
---|
| 64 | S LINE=0
|
---|
| 65 | ;
|
---|
| 66 | ; Get the prescription data
|
---|
| 67 | ;
|
---|
| 68 | I OBFLAG="B" S TMP=$$GLPHRM^PPPGET8(PATDFN,PHRMARRY)
|
---|
| 69 | S TMP=$$GETPDX^PPPGET2(ARRAYNM,PHRMARRY)
|
---|
| 70 | ;
|
---|
| 71 | ; If there is anything to print... print it.
|
---|
| 72 | ;
|
---|
| 73 | I $D(@PHRMARRY) D NARRATIV
|
---|
| 74 | K @PHRMARRY
|
---|
| 75 | Q LINE
|
---|
| 76 | ;
|
---|
| 77 | NARRATIV ; Print the narratives
|
---|
| 78 | ;
|
---|
| 79 | S LINE=0
|
---|
| 80 | S TEXT=""
|
---|
| 81 | S STANAME=""
|
---|
| 82 | I $D(@PHRMARRY@(0)) D
|
---|
| 83 | .F S STANAME=$O(@PHRMARRY@(0,STANAME)) Q:STANAME="" D
|
---|
| 84 | ..S LINE=LINE+1
|
---|
| 85 | ..S @LSTARRAY@(LINE,0)=$$SETSTR^VALM1("NARRATIVE FROM "_STANAME,TEXT,1,80)
|
---|
| 86 | ..S LINE=LINE+1
|
---|
| 87 | ..I $L(@PHRMARRY@(0,STANAME))<70 D
|
---|
| 88 | ...S @LSTARRAY@(LINE,0)=$$SETSTR^VALM1(" => "_@PHRMARRY@(0,STANAME),TEXT,1,80)
|
---|
| 89 | ..E D
|
---|
| 90 | ...S @LSTARRAY@(LINE,0)=$$SETSTR^VALM1(" => "_$E(@PHRMARRY@(0,STANAME),1,70)_"...",TEXT,1,80)
|
---|
| 91 | ..S LINE=LINE+1,@LSTARRAY@(LINE,0)=""
|
---|
| 92 | ;
|
---|
| 93 | S RVRSDT=0
|
---|
| 94 | F S RVRSDT=$O(@PHRMARRY@(RVRSDT)) Q:RVRSDT'>0 D
|
---|
| 95 | .S STAPTR=0
|
---|
| 96 | .F S STAPTR=$O(@PHRMARRY@(RVRSDT,STAPTR)) Q:STAPTR="" D
|
---|
| 97 | ..S RXIDX=-1
|
---|
| 98 | ..F S RXIDX=$O(@PHRMARRY@(RVRSDT,STAPTR,RXIDX)) Q:RXIDX=""!(RXIDX="PID") D
|
---|
| 99 | ...S ND=$G(@PHRMARRY@(RVRSDT,STAPTR,RXIDX)) Q:ND=""
|
---|
| 100 | ...S LINE=LINE+1
|
---|
| 101 | ...S TXTLINE=$$SETFLD^VALM1($P(ND,U),TEXT,"RX#")
|
---|
| 102 | ...S TXTLINE=$$SETFLD^VALM1($P(ND,U,2),TXTLINE,"DRUG")
|
---|
| 103 | ...S TXTLINE=$$SETFLD^VALM1($P(ND,U,3),TXTLINE,"STATUS")
|
---|
| 104 | ...S TXTLINE=$$SETFLD^VALM1($P(ND,U,4),TXTLINE,"QTY")
|
---|
| 105 | ...S TXTLINE=$$SETFLD^VALM1($$SLASHDT^PPPCNV1($P(ND,U,5)),TXTLINE,"ISSUED")
|
---|
| 106 | ...S TXTLINE=$$SETFLD^VALM1($$SLASHDT^PPPCNV1($P(ND,U,6)),TXTLINE,"LAST FILLED")
|
---|
| 107 | ...S @LSTARRAY@(LINE,0)=TXTLINE
|
---|
| 108 | ...S LINE=LINE+1
|
---|
| 109 | ...S TXTLINE=$$SETSTR^VALM1("SIG: "_$E($P(ND,U,7),1,25),TEXT,9,30)
|
---|
| 110 | ...S TXTLINE=$$SETSTR^VALM1("ISSUED AT "_$P(ND,U,8)_" ("_$P(ND,U,9)_")",TXTLINE,40,39)
|
---|
| 111 | ...S @LSTARRAY@(LINE,0)=TXTLINE
|
---|
| 112 | ...S LINE=LINE+1
|
---|
| 113 | ...S @LSTARRAY@(LINE,0)=$$SETSTR^VALM1("PROVIDER: "_$P(ND,U,10),TEXT,9,70)
|
---|
| 114 | K @PHRMARRY
|
---|
| 115 | Q
|
---|
| 116 | ;
|
---|