VistA-FOIAVistA/r/E_CLAIMS_MGMT_ENGINE-BPS/BPSRPT3.m

259 lines
7.3 KiB
Mathematica

BPSRPT3 ;BHAM ISC/BEE - ECME REPORTS ;14-FEB-05
;;1.0;E CLAIMS MGMT ENGINE;**1,3,5**;JUN 2004;Build 45
;;Per VHA Directive 2004-038, this routine should not be modified.
;
Q
;
; Select the ECME Pharmacy or Pharmacies
;
; Input Variable -> none
; Return Value -> "" = Valid Entry or Entries Selected
; ^ = Exit
;
; Output Variable -> BPPHARM = 1 One or More Pharmacies Selected
; = 0 User Entered 'ALL'
;
; If BPPHARM = 1 then the BPPHARM array will be defined where:
; BPPHARM(ptr) = ptr ^ BPS PHARMACY NAME and
; ptr = Internal Pointer to BPS PHARMACIES file (#9002313.56)
;
SELPHARM() N DIC,DIR,DIRUT,DTOUT,DUOUT,X,Y
;
;Reset BPPHARM array
K BPPHARM
;
;First see if they want to enter individual divisions or ALL
S DIR(0)="S^D:DIVISION;A:ALL"
S DIR("A")="Select Certain Pharmacy (D)ivisions or (A)LL"
S DIR("L",1)="Select one of the following:"
S DIR("L",2)=""
S DIR("L",3)=" D DIVISION"
S DIR("L",4)=" A ALL"
D ^DIR K DIR
;
;Check for "^" or timeout, otherwise define BPPHARM
I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
E S BPPHARM=$S(Y="A":0,1:1)
;
;If division selected, ask prompt
I $G(BPPHARM)=1 F D Q:Y="^"!(Y="")
.;
.;Prompt for entry
.K X S DIC(0)="QEAM",DIC=9002313.56,DIC("A")="Select ECME Pharmacy Division(s): "
.W ! D ^DIC
.;
.;Check for "^" or timeout
.I ($G(DUOUT)=1)!($G(DTOUT)=1) K BPPHARM S Y="^" Q
.;
.;Check for blank entry, quit if no previous selections
.I $G(X)="" S Y=$S($D(BPPHARM)>9:"",1:"^") K:Y="^" BPPHARM Q
.;
.;Handle Deletes
.I $D(BPPHARM(+Y)) D Q:Y="^" I 1
..N P
..S P=Y ;Save Original Value
..S DIR(0)="S^Y:YES;N:NO",DIR("A")="Delete "_$P(P,U,2)_" from your list?"
..S DIR("B")="NO" D ^DIR
..I ($G(DUOUT)=1)!($G(DTOUT)=1) K BPPHARM S Y="^" Q
..I Y="Y" K BPPHARM(+P),BPPHARM("B",$P(P,U,2),+P)
..S Y=P ;Restore Original Value
..K P
.E D
..;Define new entries in BPPHARM array
..S BPPHARM(+Y)=Y
..S BPPHARM("B",$P(Y,U,2),+Y)=""
.;
.;Display a list of selected divisions
.I $D(BPPHARM)>9 D
..N X
..W !,?2,"Selected:"
..S X="" F S X=$O(BPPHARM("B",X)) Q:X="" W !,?10,X
..K X
.Q
;
K BPPHARM("B")
Q Y
;
; Display (S)ummary or (D)etail Format
;
; Input Variable -> DFLT = 1 Summary
; 2 Detail
;
; Return Value -> 1 = Summary
; 0 = Detail
; ^ = Exit
;
SELSMDET(DFLT) N DIR,DIRUT,DTOUT,DUOUT,X,Y
S DFLT=$S($G(DFLT)=1:"Summary",$G(DFLT)=0:"Detail",1:"Detail")
S DIR(0)="S^S:Summary;D:Detail",DIR("A")="Display (S)ummary or (D)etail Format",DIR("B")=DFLT
D ^DIR
I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
S Y=$S(Y="S":1,Y="D":0,1:Y)
Q Y
;
; Select to Display Single (I)nsurance Company or (A)ll
;
; Input Variable -> DFLT = 1 Single Insurance
; 0 All Insurance
;
; Return Value -> ptr to #36^Insurance Company Name
; 0 = All Insurances
; ^ = Exit
;
SELINSIN(DFLT) N DIC,DIR,DIRUT,DUOUT,INS,X,Y
;
S DFLT=$S($G(DFLT)=1:"Single Insurance",1:"ALL")
S DIR(0)="S^I:Single Insurance;A:ALL"
S DIR("A")="Display Single (I)nsurance Company or (A)LL",DIR("B")=DFLT
D ^DIR
I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
S INS=$S(Y="I":1,Y="A":0,1:Y)
;
;Check for "^" or timeout, otherwise define INS
I ($G(DUOUT)=1)!($G(DTOUT)=1) S (INS,Y)="^"
;
;If single insurance selected, ask prompt
I $G(INS)=1 D
.;
.;Prompt for entry
.W ! S Y=$$SELINS^BPSRPT6()
.;
.;Check for "^", timeout, or blank entry
.I ($G(DUOUT)=1)!($G(DTOUT)=1)!($G(X)="") S (INS,Y)="^" Q
.;
.;If valid entry, setup INS
.I Y'="^" S INS=Y
;
Q INS
;
; Display (C)MOP or (M)ail or (W)indow or (A)ll
;
; Input Variable -> DFLT = C CMOP
; W Window
; M Mail
; A All
;
; Return Value -> C = CMOP
; W = Window
; M = Mail
; A = All
; ^ = Exit
;
SELMWC(DFLT) N DIR,DIRUT,DTOUT,DUOUT,X,Y
S DFLT=$S($G(DFLT)="C":"CMOP",$G(DFLT)="W":"Window",$G(DFLT)="M":"Mail",1:"ALL")
S DIR(0)="S^C:CMOP;M:Mail;W:Window;A:ALL"
S DIR("A")="Display (C)MOP or (M)ail or (W)indow or (A)LL",DIR("B")=DFLT
D ^DIR
I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
Q Y
;
; Display (R)ealTime Fills or (B)ackbills or (A)LL
;
; Input Variable -> DFLT = 3 Backbill
; 2 Real Time Fills
; 1 ALL
;
; Return Value -> 3 = Backbill (manually)
; 2 = Real Time Fills (automatically during FINISH)
; 1 = ALL
; ^ = Exit
;
SELRTBCK(DFLT) N DIR,DIRUT,DTOUT,DUOUT,X,Y
S DFLT=$S($G(DFLT)=2:"Real Time",$G(DFLT)=3:"Backbill",1:"ALL")
S DIR(0)="S^R:Real Time Fills;B:Backbill;A:ALL"
S DIR("A")="Display (R)ealTime Fills or (B)ackbills or (A)LL",DIR("B")=DFLT
D ^DIR
I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
S Y=$S(Y="A":1,Y="R":2,Y="B":3,1:Y)
Q Y
;
; Display Specific (D)rug or Drug (C)lass
;
; Input Variable -> DFLT = 3 Drug Class
; 2 Drug
; 1 ALL
;
; Return Value -> 3 = Drug Class
; 2 = Drug
; 1 = ALL
; ^ = Exit
;
SELDRGAL(DFLT) N DIR,DIRUT,DTOUT,DUOUT,X,Y
S DFLT=$S($G(DFLT)=2:"Drug",$G(DFLT)=3:"Drug Class",1:"ALL")
S DIR(0)="S^D:Drug;C:Drug Class;A:ALL"
S DIR("A")="Display Specific (D)rug or Drug (C)lass or (A)LL",DIR("B")=DFLT
D ^DIR
I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
S Y=$S(Y="A":1,Y="D":2,Y="C":3,1:Y)
Q Y
;
; Select Drug
;
; Input Variable -> none
;
; Return Value -> ptr = pointer to DRUG file (#50)
; ^ = Exit
;
SELDRG() N DIC,DIRUT,DUOUT,X,Y
;
;Prompt for entry
W ! D SELDRG^BPSRPT6
;
;Check for "^", timeout, or blank entry
I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
;
;Check for Valid Entry
I +Y>0 S Y=+Y
;
Q Y
;
; Select Drug Class
;
; Input Variable -> none
;
; Return Value -> ptr = pointer to VA DRUG CLASS file (#50.605)
; ^ = Exit
;
SELDRGCL() N DIC,DIRUT,DUOUT,Y
;
;Prompt for entry
W ! D SELDRGC^BPSRPT6
;
;Check for "^", timeout, or blank entry
I ($G(DUOUT)=1)!($G(DTOUT)=1)!($G(Y)="") S Y="^"
;
Q Y
;
; Enter Date Range
;
; Input Variable -> TYPE = 7 CLOSE REPORT
; 1-6 OTHER REPORTS
;
; Return Value -> P1^P2
;
; where P1 = From Date
; = ^ Exit
; P2 = To Date
; = blank for Exit
;
SELDATE(TYPE) N BPSIBDT,DIR,DIRUT,DTOUT,DUOUT,VAL,X,Y
S TYPE=$S($G(TYPE)=7:"CLOSE",1:"TRANSACTION")
SELDATE1 S VAL="",DIR(0)="DA^:DT:EX",DIR("A")="START WITH "_TYPE_" DATE: ",DIR("B")="T-1"
W ! D ^DIR
;
;Check for "^", timeout, or blank entry
I ($G(DUOUT)=1)!($G(DTOUT)=1)!($G(X)="") S VAL="^"
;
I VAL="" D
.S $P(VAL,U)=Y
.S DIR(0)="DA^"_VAL_":DT:EX",DIR("A")=" GO TO "_TYPE_" DATE: ",DIR("B")="T"
.D ^DIR
.;
.;Check for "^", timeout, or blank entry
.I ($G(DUOUT)=1)!($G(DTOUT)=1)!($G(X)="") S VAL="^" Q
.;
.;Define Entry
.S $P(VAL,U,2)=Y
;
Q VAL