[613] | 1 | IBECUS21 ;RLM/DVAMC - FILE TRICARE PHARMACY TRANSACTIONS ; 14-AUG-96
|
---|
| 2 | ;;2.0;INTEGRATED BILLING;**52,240,274**;21-MAR-94
|
---|
| 3 | ;
|
---|
| 4 | TRAN ; File a Pharmacy Billing transaction in file #351.5.
|
---|
| 5 | ; Input: DFN -- Pointer to the patient in file #2
|
---|
| 6 | ; IBLINE -- Array of data transmitted to the FI
|
---|
| 7 | ; IBRESP -- Array of data received from the FI
|
---|
| 8 | ; IBKEY -- 1 ; 2, where
|
---|
| 9 | ; 1 = Pointer to the prescription in file #52
|
---|
| 10 | ; 2 = Pointer to the refill in file #52.1, or
|
---|
| 11 | ; 0 for the original fill
|
---|
| 12 | ; IBKEYD -- 1 ^ 2 ^ 3 ^ 4, where
|
---|
| 13 | ; 1 = Rx label printing device
|
---|
| 14 | ; 2 = Pointer to the Pharmacy in file #59
|
---|
| 15 | ; 3 = Pointer to the Pharmacy user in file #200
|
---|
| 16 | ; 4 = Pointer to the billing transaction
|
---|
| 17 | ; in file #351.5 (cancellations only)
|
---|
| 18 | ;
|
---|
| 19 | ; - don't process duplicate transactions
|
---|
| 20 | I $E(IBRESP(1),17)="D" Q
|
---|
| 21 | ;
|
---|
| 22 | ; - find transaction entry or create a new one
|
---|
| 23 | S IBCHTRN=$O(^IBA(351.5,"B",IBKEY,0))
|
---|
| 24 | I 'IBCHTRN D
|
---|
| 25 | .S I=$P(^IBA(351.5,0),"^",3)
|
---|
| 26 | .F S I=I+1 L +^IBA(351.5,I):1 Q:$T&'$D(^IBA(351.5,I)) L -^IBA(351.5,I)
|
---|
| 27 | .S ^IBA(351.5,I,0)=IBKEY,^IBA(351.5,"B",IBKEY,I)=""
|
---|
| 28 | .S ^IBA(351.5,0)=$P(^IBA(351.5,0),"^",1,2)_"^"_I_"^"_($P(^IBA(351.5,0),"^",4)+1)
|
---|
| 29 | .S IBCHTRN=I L -^IBA(351.5,IBCHTRN)
|
---|
| 30 | ;
|
---|
| 31 | ; - prepare i/o for filing
|
---|
| 32 | S IBPROC("I")="" F IBI=1:1:2 S IBPROC("I")=IBPROC("I")_$G(IBRESP(IBI))
|
---|
| 33 | S IBPROC("O")="" F IBI=1:1:5 S IBPROC("O")=IBPROC("O")_$G(IBLINE(IBI))
|
---|
| 34 | S IBPROC("O")=$E(IBPROC("O"),3,999)
|
---|
| 35 | ;
|
---|
| 36 | ; - file transaction data
|
---|
| 37 | S $P(^IBA(351.5,IBCHTRN,0),"^",2,6)=DFN_"^"_$P(IBCDFND,"^",2)_"^"_$TR(IBDRX("NDC"),"-","")_"^"_$J((+IBUAC/100),0,2)_"^"_IBDRX("QTY")
|
---|
| 38 | F IBI=1:1 S IBTABLE=$T(TABLE+IBI) Q:$P(IBTABLE,";",3)="$END" D
|
---|
| 39 | .Q:$P(IBTABLE,";",4)<2
|
---|
| 40 | .;
|
---|
| 41 | .; - file only the 0th node for rejects
|
---|
| 42 | .I $E(IBRESP(1),17)="R",$P(IBTABLE,";",4)>1 Q
|
---|
| 43 | .;
|
---|
| 44 | .S X="" I $P(IBTABLE,";",6)'?1.N X $P(IBTABLE,";",6)
|
---|
| 45 | .I X="" S X=$E(IBPROC($P(IBTABLE,";",3)),$P(IBTABLE,";",6),$P(IBTABLE,";",7))
|
---|
| 46 | .I $P(IBTABLE,";",2)["D" Q:'X D DOLLAR
|
---|
| 47 | .;
|
---|
| 48 | .; - file each field individually
|
---|
| 49 | .I X]"" S $P(^IBA(351.5,IBCHTRN,$P(IBTABLE,";",4)),"^",$P(IBTABLE,";",5))=X
|
---|
| 50 | ;
|
---|
| 51 | ; - delete cancellation authorization number
|
---|
| 52 | S $P(^IBA(351.5,IBCHTRN,6),"^")=""
|
---|
| 53 | ;
|
---|
| 54 | ; - handle rejects, update transaction date and cross reference
|
---|
| 55 | D REJECT
|
---|
| 56 | N DIQUIET S DIQUIET=1 D DT^DICRW S $P(^IBA(351.5,IBCHTRN,0),U,7)=DT
|
---|
| 57 | S DA=IBCHTRN,DIK="^IBA(351.5," D IX^DIK
|
---|
| 58 | Q
|
---|
| 59 | ;
|
---|
| 60 | ;
|
---|
| 61 | DOLLAR ; Convert cents to dollars.
|
---|
| 62 | S X=$E(X,1,($L(X)-2))_"."_$E(X,($L(X)-1),$L(X))
|
---|
| 63 | F Q:$E(X,1)'=0 S X=$E(X,2,999)
|
---|
| 64 | Q
|
---|
| 65 | ;
|
---|
| 66 | ;
|
---|
| 67 | REJECT ; Act on billing rejects.
|
---|
| 68 | ;
|
---|
| 69 | ; - file reject information
|
---|
| 70 | S IBREJ="" I $E(IBRESP(1),17)="R" D
|
---|
| 71 | .F IBJ=20:2 S IBJA=$E(IBRESP(1),IBJ,IBJ+1) Q:IBJA=" "!(IBJA="") D
|
---|
| 72 | ..S IBERRP=$$ERRIEN^IBECUS22("UNIVERSAL",IBJA)
|
---|
| 73 | ..I IBERRP S IBREJ=IBREJ_","_IBERRP
|
---|
| 74 | S:$L(IBREJ) IBREJ=$E(IBREJ,2,999)
|
---|
| 75 | S ^IBA(351.5,IBCHTRN,5)=IBREJ
|
---|
| 76 | ;
|
---|
| 77 | ; - if the transaction was not rejected, delete the existing
|
---|
| 78 | ; reject entry if it exists
|
---|
| 79 | S IBCHREJ=$O(^IBA(351.52,"B",IBKEY,0))
|
---|
| 80 | I IBREJ="" D G REJECTQ
|
---|
| 81 | .I IBCHREJ S DA=IBCHREJ,DIK="^IBA(351.52," D ^DIK K DA,DIK
|
---|
| 82 | ;
|
---|
| 83 | ; - add a new reject entry if necessary
|
---|
| 84 | I 'IBCHREJ D ADDREJ
|
---|
| 85 | ;
|
---|
| 86 | ; - update reject file
|
---|
| 87 | S DA=IBCHTRN,DIE="^IBA(351.52,",DR=".02////"_IBCHTRN_";.03////"_DT
|
---|
| 88 | D ^DIE K DA,DIE,DR
|
---|
| 89 | S ^IBA(351.52,IBCHREJ,1)=IBREJ
|
---|
| 90 | ;
|
---|
| 91 | ; - generate a reject alert
|
---|
| 92 | S XQA("G.IB CHAMP RX REJ")="",XQA(+$P(IBKEYD,"^",3))=""
|
---|
| 93 | S XQAMSG="Prescription #"_IBDRX("RX#")_" rejected for reason #"_IBREJ
|
---|
| 94 | S XQADATA=IBDRX("RX#")_"^"_IBREJ_"^"_DFN,XQAROU="DISP^IBECUS22"
|
---|
| 95 | D SETUP^XQALERT
|
---|
| 96 | ;
|
---|
| 97 | ; - remove prescription from queue
|
---|
| 98 | I $P($G(^IBE(351.51,+IBREJ,0)),"^",2)<89 K ^IBA(351.5,"APOST",IBKEY)
|
---|
| 99 | REJECTQ Q
|
---|
| 100 | ;
|
---|
| 101 | ;
|
---|
| 102 | ADDREJ ; Add stub entry to the Reject file.
|
---|
| 103 | S I=$P(^IBA(351.52,0),"^",3)
|
---|
| 104 | F S I=I+1 L +^IBA(351.52,I):1 Q:$T&'$D(^IBA(351.52,I)) L -^IBA(351.52,I)
|
---|
| 105 | S ^IBA(351.52,I,0)=IBKEY,^IBA(351.52,"B",IBKEY,I)=""
|
---|
| 106 | S ^IBA(351.52,0)=$P(^IBA(351.52,0),"^",1,2)_"^"_I_"^"_($P(^IBA(351.52,0),"^",4)+1)
|
---|
| 107 | S IBCHREJ=I L -^IBA(351.52,I)
|
---|
| 108 | Q
|
---|
| 109 | ;
|
---|
| 110 | ;
|
---|
| 111 | TABLE ; Table of field positions and file locations in file #351.5.
|
---|
| 112 | ;;O;0;2;S X=DFN
|
---|
| 113 | ;;O;0;3;48;65
|
---|
| 114 | ;;O;0;4;268;278
|
---|
| 115 | ;D;O;0;5;280;285
|
---|
| 116 | ;;O;0;6;259;263
|
---|
| 117 | ;D;I;2;1;18;23
|
---|
| 118 | ;D;I;2;2;24;29
|
---|
| 119 | ;D;I;2;3;30;35
|
---|
| 120 | ;D;I;2;4;36;41
|
---|
| 121 | ;D;I;2;5;42;47
|
---|
| 122 | ;;I;2;6;48;61
|
---|
| 123 | ;;I;2;7;62;101
|
---|
| 124 | ;D;I;3;1;102;109
|
---|
| 125 | ;D;I;3;2;110;117
|
---|
| 126 | ;D;I;3;3;118;125
|
---|
| 127 | ;D;I;3;4;126;131
|
---|
| 128 | ;D;I;3;5;132;137
|
---|
| 129 | ;D;I;3;6;138;143
|
---|
| 130 | ;D;I;3;7;144;149
|
---|
| 131 | ;D;I;3;8;150;155
|
---|
| 132 | ;;I;3;9;156;157
|
---|
| 133 | ;D;I;3;10;158;163
|
---|
| 134 | ;;I;7;1;164;323
|
---|
| 135 | ;;I;8;1;324;403
|
---|
| 136 | ;;$END
|
---|