ABMZBDIC ; IHS/DSD/DMJ - Bill Selection ; [ 04/21/98 3:03 PM ]
;;2.0;IHS 3P BILLING SYSTEM;**1**;MAR 26, 1996
;
BILL ;SELECT BILL
K %P,DIC,ABMP("BDFN"),ABM
S DIR("A")="Select BILL or PATIENT"
S DIR("?")="Enter either the Bill Number or a Patient Identifier (Name, HRN, SSN, DOB)"
W !
S DIR(0)="FO" D ^DIR K DIR
Q:$D(DIRUT)
S ABM("INPUT")=Y
I $D(^ABMDBILL(DUZ(2),"B",Y)),Y'=+Y D
.S X=Y
.S DIC="^ABMDBILL(DUZ(2),",DIC(0)="EM" D ^DIC
.I +Y>0 S ABMP("BDFN")=+Y
I $G(ABMP("BDFN")) K ABM Q
I Y=+Y,$D(^ABMDBILL(DUZ(2),"B",Y)) D
.S X=Y
.S DIC="^ABMDBILL(DUZ(2),",DIC(0)="EM" D ^DIC
.I +Y>0 D
..S ABMP("BDFN")=+Y
..S DIR("A")="Correct Bill",DIR(0)="Y",DIR("B")="YES" D ^DIR K DIR
..I Y='1 K ABMP("BDFN")
I $G(ABMP("BDFN")) K ABM Q
S ABM("STATUS")=$P(^DD(9002274.4,.04,0),"^",3)
NUM ;NUMBER LOOKUP
S Y=ABM("INPUT")
I +Y D
.S J=+Y_" ",ABM("CNT")=0 F S J=$O(^ABMDBILL(DUZ(2),"B",J)) Q:J'[+Y!($G(ABMP("BDFN"))) D
..S I=$O(^ABMDBILL(DUZ(2),"B",J,0))
..S ABMP("PDFN")=$P(^ABMDBILL(DUZ(2),I,0),"^",5)
..D ID
.D:(ABM("CNT")#5) SEL
I $G(ABMP("BDFN")) K ABM Q
PAT ;PATIENT LOOKUP
S X=ABM("INPUT"),DIC="^AUPNPAT(",DIC(0)="EMQ",AUPNLK("ALL")=1
D ^DIC
I +Y<0 G BILL
S ABMP("PDFN")=+Y,ABM("P0")=^DPT(ABMP("PDFN"),0)
S $P(ABM("="),"=",80)=""
D PAT^ABMDUTL(ABMP("PDFN"))
S I="",ABM("CNT")=0
F S I=$O(^ABMDBILL(DUZ(2),"D",ABMP("PDFN"),I)) Q:'I!($G(ABMP("BDFN")))!($D(DIRUT)) D
.Q:$P(^ABMDBILL(DUZ(2),I,0),"^",7)'=111
.Q:$P(^ABMDBILL(DUZ(2),I,0),"^",8)'=ABMINS
.D ID
.I '(ABM("CNT")#5) D SEL
I '$G(ABMP("BDFN")) D SEL
I '$G(ABMP("BDFN")) G BILL
K ABM Q
ID ;BILL IDENTIFIERS
I '(ABM("CNT")#5) D PAT^ABMDUTL(ABMP("PDFN"))
S ABM("CNT")=ABM("CNT")+1
S ABM("CNT",ABM("CNT"))=I
W !!,"(",ABM("CNT"),")"
S ABM("ZERO")=^ABMDBILL(DUZ(2),I,0) N J F J=1:1:12 S ABM(J)=$P(ABM("ZERO"),"^",J)
S ABM(7,1)=$P($G(^ABMDBILL(DUZ(2),I,7)),"^",1),ABM(2,1)=$P($G(^(2)),"^",1)
S ABM(4)=$P(ABM("STATUS"),ABM(4)_":",2),ABM(4)=$P(ABM(4),";",1)
W ?5,"Bill# ",ABM(1)
W ?20,$E(ABM(7,1),4,5),"/",$E(ABM(7,1),6,7),"/",$E(ABM(7,1),2,3)
W ?30,$P($G(^ABMDVTYP(+ABM(7),0)),"^",1)
W ?51,$P($G(^DIC(40.7,+ABM(10),0)),"^",1)
W ?67,$P($G(^AUTTLOC(+ABM(3),0)),"^",2)
W !,?6,$P($G(^ABMDEXP(+ABM(6),0)),"^",1)
W ?18,$E(ABM(4),1,15)
W ?37,$P($G(^AUTNINS(+ABM(8),0)),"^",1)
W ?70,$J($FN(ABM(2,1),",",2),10)
Q
SEL ;SELECT
F W ! Q:$Y+4>IOSL
S DIR(0)="NAO^1:"_ABM("CNT"),DIR("A")="Select 1 to "_ABM("CNT")_": " D ^DIR K DIR
I Y S ABMP("BDFN")=ABM("CNT",Y)
I Y="",'$D(DTOUT) K DIRUT
Q
;
BENT ;EP - for doing Bill File lookup with DIC variables
K ABMP("BDFN")
S AUPNLK("ALL")=1
S DIC("W")="S ABM(0)=^(0),ABM(2)=+$G(^(2)),ABM(7)=$S(+$G(^(7)):^(7),1:+$G(^(6))) D DICW^ABMDBDIC"
D ^DIC K DIC
G XIT:X=""!$D(DUOUT)!$D(DTOUT)
I X="?" W !!,"Enter either the Bill Number or a Patient Identifier (Name, HRN, SSN, DOB)"
G BENT:+Y<1 S ABMP("BDFN")=+Y
G XIT
;
DICW ;EP - for displaying bill identifiers
I $G(DZ)["?",$P(ABM(0),U,5),$D(^DPT($P(ABM(0),U,5),0)) W ?12,$P(^(0),U),?46,$P(^(0),U,2)," ",$E($P(^(0),U,3),4,5),"-",$E($P(^(0),U,3),5,6),"-",$E($P(^(0),U,3),2,3)," ",$P(^(0),U,9)
I I $G(DUZ(2)),$D(^AUPNPAT($P(ABM(0),U,5),41,DUZ(2),0)) W ?68,$P($G(^AUTTLOC(DUZ(2),0)),U,7)," ",$P(^AUPNPAT($P(ABM(0),U,5),41,DUZ(2),0),U,2)
I $G(X)'=$P(ABM(0),U,5)!($G(DZ)["?") W !
W ?17,"Visit: ",$E(ABM(7),4,5),"-",$E(ABM(7),6,7),"-",$E(ABM(7),2,3)," "
I $P(ABM(0),U,7) W $E($P($G(^ABMDVTYP($P(ABM(0),U,7),0)),U),1,14)
I $P(ABM(0),U,10),$P(ABM(0),U,3) W ?49,$E($P($G(^DIC(40.7,$P(ABM(0),U,10),0)),U),1,17),?68,$E($P($G(^AUTTLOC($P(ABM(0),U,3),0)),U,2),1,12)
W !?20,"Bill: ",$P(^AUTNINS($P(ABM(0),U,8),0),U)
I $P(ABM(0),U,6) W ?57,$P($G(^ABMDEXP($P(ABM(0),U,6),0)),U)
W ?68,$J($FN(ABM(2),",",2),10)
S DIW=1
I $G(DZ)["?" W !
K ABM(0),ABM(7)
Q
;
XIT K ABM
Q
;
MULT ;EP for Selecting Multiple Bills
K DIC S ABM("C")=0,DIC="^ABMDBILL(DUZ(2),",DIC(0)="QEAM" W !
F ABM=1:1 W ! D Q:X=""!$D(DUOUT)!$D(DTOUT)
SELO .S ABM("E")=$E(ABM,$L(ABM)),DIC("A")="Select "_ABM_$S(ABM>3&(ABM<21):"th",ABM("E")=1:"st",ABM("E")=2:"nd",ABM("E")=3:"rd",1:"th")_" BILL: ",DIC(0)="QEAM" D ^DIC
.Q:X=""!$D(DUOUT)!$D(DTOUT)
.I +Y<1 G SELO
.S ABMM(+Y)=""
K DIC
G XIT
54 ;get prov number
Q:ABMP("VTYP")'=141
S ABMPROV=$P(ABM("A"),"^",2)
I ABMPROV D
.S ABMPNUM=$P($G(^VA(200,ABMPROV,9999999.18,+ABMP("INS"),0)),"^",2)
I $G(ABMPNUM)="" D
.S ABMPNUM=$P($G(^VA(200,ABMPROV,9999999)),"^",7)
S:$P(ABMF(54),"^",3)'="" $P(ABMF(54),"^",4)=$P(ABMF(54),"^",3)
S $P(ABMF(54),"^",3)=ABMPNUM
Q
ABMZBDIC ; IHS/DSD/DMJ - Bill Selection ; [ 04/21/98 3:03 PM ]
+1 ;;2.0;IHS 3P BILLING SYSTEM;**1**;MAR 26, 1996
+2 ;
BILL ;SELECT BILL
+1 KILL %P,DIC,ABMP("BDFN"),ABM
+2 SET DIR("A")="Select BILL or PATIENT"
+3 SET DIR("?")="Enter either the Bill Number or a Patient Identifier (Name, HRN, SSN, DOB)"
+4 WRITE !
+5 SET DIR(0)="FO"
DO ^DIR
KILL DIR
+6 IF $DATA(DIRUT)
QUIT
+7 SET ABM("INPUT")=Y
+8 IF $DATA(^ABMDBILL(DUZ(2),"B",Y))
IF Y'=+Y
Begin DoDot:1
+9 SET X=Y
+10 SET DIC="^ABMDBILL(DUZ(2),"
SET DIC(0)="EM"
DO ^DIC
+11 IF +Y>0
SET ABMP("BDFN")=+Y
End DoDot:1
+12 IF $GET(ABMP("BDFN"))
KILL ABM
QUIT
+13 IF Y=+Y
IF $DATA(^ABMDBILL(DUZ(2),"B",Y))
Begin DoDot:1
+14 SET X=Y
+15 SET DIC="^ABMDBILL(DUZ(2),"
SET DIC(0)="EM"
DO ^DIC
+16 IF +Y>0
Begin DoDot:2
+17 SET ABMP("BDFN")=+Y
+18 SET DIR("A")="Correct Bill"
SET DIR(0)="Y"
SET DIR("B")="YES"
DO ^DIR
KILL DIR
+19 IF Y='1
KILL ABMP("BDFN")
End DoDot:2
End DoDot:1
+20 IF $GET(ABMP("BDFN"))
KILL ABM
QUIT
+21 SET ABM("STATUS")=$PIECE(^DD(9002274.4,.04,0),"^",3)
NUM ;NUMBER LOOKUP
+1 SET Y=ABM("INPUT")
+2 IF +Y
Begin DoDot:1
+3 SET J=+Y_" "
SET ABM("CNT")=0
FOR
SET J=$ORDER(^ABMDBILL(DUZ(2),"B",J))
IF J'[+Y!($GET(ABMP("BDFN")))
QUIT
Begin DoDot:2
+4 SET I=$ORDER(^ABMDBILL(DUZ(2),"B",J,0))
+5 SET ABMP("PDFN")=$PIECE(^ABMDBILL(DUZ(2),I,0),"^",5)
+6 DO ID
End DoDot:2
+7 IF (ABM("CNT")#5)
DO SEL
End DoDot:1
+8 IF $GET(ABMP("BDFN"))
KILL ABM
QUIT
PAT ;PATIENT LOOKUP
+1 SET X=ABM("INPUT")
SET DIC="^AUPNPAT("
SET DIC(0)="EMQ"
SET AUPNLK("ALL")=1
+2 DO ^DIC
+3 IF +Y<0
GOTO BILL
+4 SET ABMP("PDFN")=+Y
SET ABM("P0")=^DPT(ABMP("PDFN"),0)
+5 SET $PIECE(ABM("="),"=",80)=""
+6 DO PAT^ABMDUTL(ABMP("PDFN"))
+7 SET I=""
SET ABM("CNT")=0
+8 FOR
SET I=$ORDER(^ABMDBILL(DUZ(2),"D",ABMP("PDFN"),I))
IF 'I!($GET(ABMP("BDFN")))!($DATA(DIRUT))
QUIT
Begin DoDot:1
+9 IF $PIECE(^ABMDBILL(DUZ(2),I,0),"^",7)'=111
QUIT
+10 IF $PIECE(^ABMDBILL(DUZ(2),I,0),"^",8)'=ABMINS
QUIT
+11 DO ID
+12 IF '(ABM("CNT")#5)
DO SEL
End DoDot:1
+13 IF '$GET(ABMP("BDFN"))
DO SEL
+14 IF '$GET(ABMP("BDFN"))
GOTO BILL
+15 KILL ABM
QUIT
ID ;BILL IDENTIFIERS
+1 IF '(ABM("CNT")#5)
DO PAT^ABMDUTL(ABMP("PDFN"))
+2 SET ABM("CNT")=ABM("CNT")+1
+3 SET ABM("CNT",ABM("CNT"))=I
+4 WRITE !!,"(",ABM("CNT"),")"
+5 SET ABM("ZERO")=^ABMDBILL(DUZ(2),I,0)
NEW J
FOR J=1:1:12
SET ABM(J)=$PIECE(ABM("ZERO"),"^",J)
+6 SET ABM(7,1)=$PIECE($GET(^ABMDBILL(DUZ(2),I,7)),"^",1)
SET ABM(2,1)=$PIECE($GET(^(2)),"^",1)
+7 SET ABM(4)=$PIECE(ABM("STATUS"),ABM(4)_":",2)
SET ABM(4)=$PIECE(ABM(4),";",1)
+8 WRITE ?5,"Bill# ",ABM(1)
+9 WRITE ?20,$EXTRACT(ABM(7,1),4,5),"/",$EXTRACT(ABM(7,1),6,7),"/",$EXTRACT(ABM(7,1),2,3)
+10 WRITE ?30,$PIECE($GET(^ABMDVTYP(+ABM(7),0)),"^",1)
+11 WRITE ?51,$PIECE($GET(^DIC(40.7,+ABM(10),0)),"^",1)
+12 WRITE ?67,$PIECE($GET(^AUTTLOC(+ABM(3),0)),"^",2)
+13 WRITE !,?6,$PIECE($GET(^ABMDEXP(+ABM(6),0)),"^",1)
+14 WRITE ?18,$EXTRACT(ABM(4),1,15)
+15 WRITE ?37,$PIECE($GET(^AUTNINS(+ABM(8),0)),"^",1)
+16 WRITE ?70,$JUSTIFY($FNUMBER(ABM(2,1),",",2),10)
+17 QUIT
SEL ;SELECT
+1 FOR
WRITE !
IF $Y+4>IOSL
QUIT
+2 SET DIR(0)="NAO^1:"_ABM("CNT")
SET DIR("A")="Select 1 to "_ABM("CNT")_": "
DO ^DIR
KILL DIR
+3 IF Y
SET ABMP("BDFN")=ABM("CNT",Y)
+4 IF Y=""
IF '$DATA(DTOUT)
KILL DIRUT
+5 QUIT
+6 ;
BENT ;EP - for doing Bill File lookup with DIC variables
+1 KILL ABMP("BDFN")
+2 SET AUPNLK("ALL")=1
+3 SET DIC("W")="S ABM(0)=^(0),ABM(2)=+$G(^(2)),ABM(7)=$S(+$G(^(7)):^(7),1:+$G(^(6))) D DICW^ABMDBDIC"
+4 DO ^DIC
KILL DIC
+5 IF X=""!$DATA(DUOUT)!$DATA(DTOUT)
GOTO XIT
+6 IF X="?"
WRITE !!,"Enter either the Bill Number or a Patient Identifier (Name, HRN, SSN, DOB)"
+7 IF +Y<1
GOTO BENT
SET ABMP("BDFN")=+Y
+8 GOTO XIT
+9 ;
DICW ;EP - for displaying bill identifiers
+1 IF $GET(DZ)["?"
IF $PIECE(ABM(0),U,5)
IF $DATA(^DPT($PIECE(ABM(0),U,5),0))
WRITE ?12,$PIECE(^(0),U),?46,$PIECE(^(0),U,2)," ",$EXTRACT($PIECE(^(0),U,3),4,5),"-",$EXTRACT($PIECE(^(0),U,3),5,6),"-",$EXTRACT($PIECE(^(0),U,3),2,3)," ",$PIECE(^(0),U,9)
+2 IF $TEST
IF $GET(DUZ(2))
IF $DATA(^AUPNPAT($PIECE(ABM(0),U,5),41,DUZ(2),0))
WRITE ?68,$PIECE($GET(^AUTTLOC(DUZ(2),0)),U,7)," ",$PIECE(^AUPNPAT($PIECE(ABM(0),U,5),41,DUZ(2),0),U,2)
+3 IF $GET(X)'=$PIECE(ABM(0),U,5)!($GET(DZ)["?")
WRITE !
+4 WRITE ?17,"Visit: ",$EXTRACT(ABM(7),4,5),"-",$EXTRACT(ABM(7),6,7),"-",$EXTRACT(ABM(7),2,3)," "
+5 IF $PIECE(ABM(0),U,7)
WRITE $EXTRACT($PIECE($GET(^ABMDVTYP($PIECE(ABM(0),U,7),0)),U),1,14)
+6 IF $PIECE(ABM(0),U,10)
IF $PIECE(ABM(0),U,3)
WRITE ?49,$EXTRACT($PIECE($GET(^DIC(40.7,$PIECE(ABM(0),U,10),0)),U),1,17),?68,$EXTRACT($PIECE($GET(^AUTTLOC($PIECE(ABM(0),U,3),0)),U,2),1,12)
+7 WRITE !?20,"Bill: ",$PIECE(^AUTNINS($PIECE(ABM(0),U,8),0),U)
+8 IF $PIECE(ABM(0),U,6)
WRITE ?57,$PIECE($GET(^ABMDEXP($PIECE(ABM(0),U,6),0)),U)
+9 WRITE ?68,$JUSTIFY($FNUMBER(ABM(2),",",2),10)
+10 SET DIW=1
+11 IF $GET(DZ)["?"
WRITE !
+12 KILL ABM(0),ABM(7)
+13 QUIT
+14 ;
XIT KILL ABM
+1 QUIT
+2 ;
MULT ;EP for Selecting Multiple Bills
+1 KILL DIC
SET ABM("C")=0
SET DIC="^ABMDBILL(DUZ(2),"
SET DIC(0)="QEAM"
WRITE !
+2 FOR ABM=1:1
WRITE !
Begin DoDot:1
SELO SET ABM("E")=$EXTRACT(ABM,$LENGTH(ABM))
SET DIC("A")="Select "_ABM_$SELECT(ABM>3&(ABM<21):"th",ABM("E")=1:"st",ABM("E")=2:"nd",ABM("E")=3:"rd",1:"th")_" BILL: "
SET DIC(0)="QEAM"
DO ^DIC
+1 IF X=""!$DATA(DUOUT)!$DATA(DTOUT)
QUIT
+2 IF +Y<1
GOTO SELO
+3 SET ABMM(+Y)=""
End DoDot:1
IF X=""!$DATA(DUOUT)!$DATA(DTOUT)
QUIT
+4 KILL DIC
+5 GOTO XIT
54 ;get prov number
+1 IF ABMP("VTYP")'=141
QUIT
+2 SET ABMPROV=$PIECE(ABM("A"),"^",2)
+3 IF ABMPROV
Begin DoDot:1
+4 SET ABMPNUM=$PIECE($GET(^VA(200,ABMPROV,9999999.18,+ABMP("INS"),0)),"^",2)
End DoDot:1
+5 IF $GET(ABMPNUM)=""
Begin DoDot:1
+6 SET ABMPNUM=$PIECE($GET(^VA(200,ABMPROV,9999999)),"^",7)
End DoDot:1
+7 IF $PIECE(ABMF(54),"^",3)'=""
SET $PIECE(ABMF(54),"^",4)=$PIECE(ABMF(54),"^",3)
+8 SET $PIECE(ABMF(54),"^",3)=ABMPNUM
+9 QUIT