| 1 | IBCSC5B ;ALB/ARH - ADD/ENTER PROSTHETIC ITEMS ;12/28/93 | 
|---|
| 2 | ;;2.0;INTEGRATED BILLING;**4,52,260,339,389**;21-MAR-94;Build 6 | 
|---|
| 3 | ;;Per VHA Directive 2004-038, this routine should not be modified. | 
|---|
| 4 | ; | 
|---|
| 5 | ; | 
|---|
| 6 | EN ; add/edit prosthetic items for a bill, IBIFN required | 
|---|
| 7 | N IBX,DFN,IBDT1,IBDT2,IBACTION,BIFN,APROS,ALPROS,ABILL,ALBILL | 
|---|
| 8 | S IBX=$$BILL(IBIFN) Q:'IBIFN  S DFN=+IBX,IBDT1=$P(IBX,U,2),IBDT2=$P(IBX,U,3) | 
|---|
| 9 | ; | 
|---|
| 10 | EN1 D PISET(DFN,IBDT1,IBDT2,.APROS,.ALPROS) D SET(IBIFN,.ABILL,.ALBILL,+$G(APROS)) | 
|---|
| 11 | D PIDISP(.APROS,.ALPROS,.ABILL) D DISP(.ABILL,.ALBILL) S BIFN="" | 
|---|
| 12 | ; | 
|---|
| 13 | S IBACTION=$$SELECT(.ALPROS,.ALBILL) Q:'IBACTION | 
|---|
| 14 | I +IBACTION=1 S BIFN=$$ADD(IBIFN,$P(IBACTION,U,2),$P(IBACTION,U,3)) G EN1 | 
|---|
| 15 | I +IBACTION=2 S BIFN=+$G(ABILL(+$P(IBACTION,U,2),$P(IBACTION,U,3))) | 
|---|
| 16 | I +IBACTION=3 S IBX=$$ASKITM(IBDT1,IBDT2) I +IBX S BIFN=$$ADD(IBIFN,+IBX,,$P(IBX,U,2)) | 
|---|
| 17 | I +BIFN D EDIT(BIFN) | 
|---|
| 18 | ; | 
|---|
| 19 | G EN1 | 
|---|
| 20 | Q | 
|---|
| 21 | ; | 
|---|
| 22 | SELECT(ALPROS,ALBILL) ; get which item to add/edit, select from Patient Prosthetics, Bill Items, or add a new one | 
|---|
| 23 | ; returns 1 ^ PD DEL DATE ^ PI IFN - ALPROS(selected item) if item from Prosthetics selected | 
|---|
| 24 | ;         2 ^ PD DEL DATE ^ X      - ALBILL(selected item) if item existing on bill selected | 
|---|
| 25 | ;         3 if add new item, "" if exit, -1 if redo | 
|---|
| 26 | N IBX,IBY,IBZ,DIR,DTOUT,DUOUT,DIRUT,X,Y S IBY="" | 
|---|
| 27 | S DIR("?")="Select the Prosthetics Item to Add or Edit." | 
|---|
| 28 | S DIR("?",1)="Enter the number preceding the Item to Add or Edit." | 
|---|
| 29 | S DIR("?",2)="Or enter the Item name to add an item not in the list and not in Prosthetics.",DIR("?",3)=" " | 
|---|
| 30 | ; | 
|---|
| 31 | S DIR("A")="Select Prosthetics Item",DIR(0)="FO^1:20^K:X?1N1P.NP X" D ^DIR S IBX=Y I $D(DIRUT) G SELECTQ | 
|---|
| 32 | ; | 
|---|
| 33 | S IBZ=$G(ALPROS(IBX)) I +IBZ W "  adding ",IBX S IBY="1^"_IBZ G SELECTQ | 
|---|
| 34 | S IBZ=$G(ALBILL(IBX)) I +IBZ W "  editing ",IBX S IBY="2^"_IBZ G SELECTQ | 
|---|
| 35 | ; | 
|---|
| 36 | S DIR(0)="YO",DIR("A")="Add a New Item",DIR("B")="YES" D ^DIR K DIR S IBY=-1 I Y=1,'$D(DIRUT) S IBY=3 | 
|---|
| 37 | ; | 
|---|
| 38 | SELECTQ Q IBY | 
|---|
| 39 | ; | 
|---|
| 40 | ASKITM(IBDT1,IBDT2) ; Ask for new item data when adding an item not in Prosthetics | 
|---|
| 41 | ; returns:  delivery date ^ prosthetic item name (from 661.1, .02) | 
|---|
| 42 | N DIR,DIC,DIE,DTOUT,DUOUT,DIRUT,X,Y,IBX,IBY S (IBX,IBY)="" I '$G(IBDT1)!'$G(IBDT2) G ASKITMQ | 
|---|
| 43 | ; | 
|---|
| 44 | W !!,"Enter a Prosthetics Item that does not have a Prosthetics Patient record.",! | 
|---|
| 45 | S DIR("A")="Select ITEM DELIVERY DATE",DIR(0)="DO^"_IBDT1_":"_IBDT2_":EX" D ^DIR S IBX=Y I Y'?7N G ASKITMQ | 
|---|
| 46 | ; | 
|---|
| 47 | S DIC="^RMPR(661.1,",DIC(0)="AENOQMZ",DIC("S")="I +$P(^(0),U,5)",DIC("A")="Select PROSTHETICS ITEM: " D ^DIC | 
|---|
| 48 | ; | 
|---|
| 49 | I +Y>0,+IBX S IBY=IBX_U_$P($G(Y(0)),U,2) | 
|---|
| 50 | ; | 
|---|
| 51 | ASKITMQ Q IBY | 
|---|
| 52 | ; | 
|---|
| 53 | ADD(IBIFN,IBDT,PIFN,IBPNAME) ; Add new Item to Bill (#362.5) | 
|---|
| 54 | N IBX,IBY,IBDX,IBHCPCS,DIC,DIE,DA,DR,DLAYGO,X,Y S IBY=0,PIFN=+$G(PIFN) I ($G(IBDT)'?7N)!('$G(IBIFN)) G ADDQ | 
|---|
| 55 | ; | 
|---|
| 56 | I $G(PIFN),$$ONBILLPI(IBIFN,PIFN) G ADDQ ; don't add duplicates | 
|---|
| 57 | I $G(IBPNAME)="" S IBPNAME=$P($$PIN(PIFN),U,2) I IBPNAME="" G ADDQ | 
|---|
| 58 | ; | 
|---|
| 59 | S DIC="^IBA(362.5,",DIC(0)="AQL",DLAYGO=362.5,X=IBDT K DA,DO D FILE^DICN K DA,DO,X | 
|---|
| 60 | I Y>0 S (IBY,DA)=+Y,DIE=DIC,DR=".02////"_IBIFN_";.04////"_+PIFN_";.05///^S X=IBPNAME" D ^DIE K DIE,DA,DR W "... ADDED" | 
|---|
| 61 | ; | 
|---|
| 62 | ;add dx if known | 
|---|
| 63 | I +IBY,+PIFN F IBX=1:1:4 S IBDX=+$G(^RMPR(660,PIFN,"BA"_IBX)) I IBDX,'$O(^IBA(362.3,"AIFN"_IBIFN,IBDX)) D | 
|---|
| 64 | . S DIC="^IBA(362.3,",DIC(0)="L",DLAYGO=362.3,X=IBDX,DIC("DR")=".02////"_IBIFN K DD,DO D FILE^DICN S IBDX(+Y)="" | 
|---|
| 65 | ;add hcpcs if known ;S IBHCPCS=$P($G(^RMPR(660,PIEN,0)),"^",22) I IBHCPCS | 
|---|
| 66 | ; | 
|---|
| 67 | ADDQ Q IBY | 
|---|
| 68 | ; | 
|---|
| 69 | EDIT(BIFN) ; | 
|---|
| 70 | N DIDEL,DIE,DIC,DR,DA,X,Y Q:'$G(BIFN)  W ! S DIDEL=362.5,DIE="^IBA(362.5,",DR=".01;.05",DA=BIFN D ^DIE | 
|---|
| 71 | Q | 
|---|
| 72 | ; | 
|---|
| 73 | SET(IBIFN,ARRB,ARRBL,PICNT) ; setup array of all prosthetic devices on bill (#362.5), array names should be passed by reference | 
|---|
| 74 | ; input:   PICNT - the number of items found in prosthetics (PISET) | 
|---|
| 75 | ; output:  ARRB(PD DELIV DATE, X) = PD IFN (362.5 ptr) ^ Cost,  ARRB = BILL IFN ^ count of items on bill | 
|---|
| 76 | ;          ARRBL(PICNT + count of item on bill) = PD DELIV DATE ^ X | 
|---|
| 77 | ;          where X is the IFN of the Patient Item (660 ptr) or if not defined then a number_"Z" | 
|---|
| 78 | N CNT,IBX,IBY,BIFN,RIFN,IBC,IBRC K ARRB,ARRBL S IBC="AIFN"_$G(IBIFN),ARRB="^0" Q:'$G(IBIFN) | 
|---|
| 79 | D RCITEM^IBCSC5A(IBIFN,"IBRC",5) S CNT=0 | 
|---|
| 80 | ; | 
|---|
| 81 | S IBX=0 F  S IBX=$O(^IBA(362.5,IBC,IBX)) Q:'IBX  S BIFN=0 F  S BIFN=$O(^IBA(362.5,IBC,IBX,BIFN)) Q:'BIFN  D | 
|---|
| 82 | . S IBY=$G(^IBA(362.5,BIFN,0)) Q:IBY=""  S CNT=CNT+1,RIFN=+$P(IBY,U,4),RIFN=$S(+RIFN:+RIFN,1:CNT_"Z") | 
|---|
| 83 | . S ARRB(+IBY,RIFN)=BIFN_U_$$CHG^IBCF4(BIFN,5,.IBRC),ARRB=$G(ARRB)+1 | 
|---|
| 84 | S ARRB=IBIFN_U_+$G(ARRB) | 
|---|
| 85 | ; | 
|---|
| 86 | S CNT=+$G(PICNT),IBX=0 F  S IBX=$O(ARRB(IBX)) Q:'IBX  S IBY=0 F  S IBY=$O(ARRB(IBX,IBY)) Q:'IBY  S CNT=CNT+1,ARRBL(CNT)=IBX_U_IBY | 
|---|
| 87 | Q | 
|---|
| 88 | ; | 
|---|
| 89 | DISP(ABILL,ALBILL) ;screen display of existing prosthetic devices for a bill, arrays should be passed by reference | 
|---|
| 90 | ; input:  ABILL (from SET) list of bill items | 
|---|
| 91 | ;         ALBILL (from SET) list of bill items, in count order | 
|---|
| 92 | N IBC,IBI,BIFN,BIFN0,DDT | 
|---|
| 93 | ; | 
|---|
| 94 | W !!,?5,"-----------------  Existing Prosthetic Items for Bill  -----------------",! | 
|---|
| 95 | S IBC=0 F  S IBC=$O(ALBILL(IBC)) Q:'IBC  D | 
|---|
| 96 | . S DDT=+ALBILL(IBC),IBI=$P(ALBILL(IBC),U,2),BIFN=+$G(ABILL(DDT,IBI)),BIFN0=$G(^IBA(362.5,BIFN,0)) | 
|---|
| 97 | . W !,?1,$J(IBC,2),")",?6,$$DATE(DDT),?16,$E($P(BIFN0,U,5),1,60) | 
|---|
| 98 | W ! | 
|---|
| 99 | Q | 
|---|
| 100 | ; | 
|---|
| 101 | PISET(DFN,DT1,DT2,ARRP,ARRPL) ; get all prosthetic items (660) for a patient and date range, arrays should pass by ref. | 
|---|
| 102 | ; input:   DFN = patient, DT1-DT2 range of dates to search for items | 
|---|
| 103 | ; output:  ARRP(PD DEL DATE (660,10), PI IFN (660 ptr)) = PI IFN (660 ptr),  ARRP = count of items | 
|---|
| 104 | ;          ARRPL(count) = PD DEL DATE (660,10) ^ PI IFN (660 ptr) | 
|---|
| 105 | ; | 
|---|
| 106 | N PIFN,DDT,IBX,IBY,CNT K ARRP,ARRPL Q:'$G(DFN)  S DT1=$G(DT1)-.0001,DT2=$G(DT2) S:'DT2 DT2=9999999 | 
|---|
| 107 | S PIFN=0 F  S PIFN=$O(^RMPR(660,"C",DFN,PIFN)) Q:'PIFN  D | 
|---|
| 108 | . S IBX=$G(^RMPR(660,PIFN,0)) Q:IBX=""  S DDT=+$P(IBX,U,12)\1 I (DDT<DT1)!(DDT>DT2) Q | 
|---|
| 109 | . S ARRP(DDT,PIFN)=PIFN,ARRP=+$G(ARRP)+1 | 
|---|
| 110 | ; | 
|---|
| 111 | S (CNT,IBX)=0 F  S IBX=$O(ARRP(IBX)) Q:'IBX  S IBY=0 F  S IBY=$O(ARRP(IBX,IBY)) Q:'IBY  S CNT=CNT+1,ARRPL(CNT)=IBX_U_IBY | 
|---|
| 112 | Q | 
|---|
| 113 | ; | 
|---|
| 114 | PIDISP(APROS,ALPROS,ABILL) ; display all prosthetic items (#660) for a patient and date range, arrays passed by reference, not changed | 
|---|
| 115 | ; input:  APROS (from PISET) patient's prosthetic items | 
|---|
| 116 | ;         ALPROS (from PISET) patient's prosthetics items, in count order | 
|---|
| 117 | ;         ABILL (from SET) list of bill's prosthetics items, only to check if item on bill | 
|---|
| 118 | N IBC,DDT,PIFN,PNAME,IBY,IBX,IBICD,IBP,IBEX | 
|---|
| 119 | ; | 
|---|
| 120 | W @IOF,?33,"PROSTHETICS SCREEN" | 
|---|
| 121 | W !,"================================================================================",! | 
|---|
| 122 | S IBC=0 F  S IBC=$O(ALPROS(IBC)) Q:'IBC  D | 
|---|
| 123 | . S DDT=+ALPROS(IBC),PIFN=$P(ALPROS(IBC),U,2) | 
|---|
| 124 | . S PNAME=$$PIN(PIFN),IBY=$G(^RMPR(660,PIFN,"AM")),IBX=$G(^RMPR(660,PIFN,0)) K IBEX | 
|---|
| 125 | . ; | 
|---|
| 126 | . F IBICD=1:1:4 Q:$D(IBEX)  I $D(^RMPR(660,PIFN,"BA"_IBICD)) F IBP=2:1:8 I $P(^RMPR(660,PIFN,"BA"_IBICD),"^",IBP) S IBEX="("_$P($T(EXEMPT+(IBP-1)),";",3)_")" Q  ; look for exemption info | 
|---|
| 127 | . ; | 
|---|
| 128 | . W !,$S($D(ABILL(+DDT,PIFN)):"*",1:"") | 
|---|
| 129 | . W ?1,$J(IBC,2),")",?6,$$DATE(DDT),?16,$E($P(PNAME,U,2),1,27),?45,"("_$P(PNAME,U,3),")",?53,$G(IBEX),?59,$E($$EXSET^IBEFUNC($P(IBX,U,14),660,12),1,4),?64,$$EXSET^IBEFUNC($P(IBY,U,3),660,62),?71,$J(+$P(IBX,U,16),8,2) | 
|---|
| 130 | Q | 
|---|
| 131 | ; | 
|---|
| 132 | PIN(P660,P6611) ; given Prosthetic record (#660) or PSAS HCPCS (#661.1) return Item Name | 
|---|
| 133 | ; returns PSAS HCPSC ptr (661.1) ^ SHORT DESCRIPTION (661.1, .02) ^ HCPCS (661.1, .01) | 
|---|
| 134 | N IBX,IBY S IBY="" | 
|---|
| 135 | I +$G(P660) S P6611=+$P($G(^RMPR(660,+P660,1)),U,4) | 
|---|
| 136 | I +$G(P6611) S IBX=$G(^RMPR(661.1,+P6611,0)) I IBX'="" S IBY=P6611_U_$P(IBX,U,2)_U_$P(IBX,U,1) | 
|---|
| 137 | Q IBY | 
|---|
| 138 | ; | 
|---|
| 139 | PINB(P3625) ; given the bill prosthetics item (#362.5) return Item Name (.05) | 
|---|
| 140 | N IBY S IBY=$P($G(^IBA(362.5,+$G(P3625),0)),U,5) | 
|---|
| 141 | Q IBY | 
|---|
| 142 | ; | 
|---|
| 143 | BILL(IBIFN) ; get bill data: returns DFN ^ Statement Covers From ^ Statement Covers To | 
|---|
| 144 | N IBX,IBY S IBIFN=+$G(IBIFN) S IBX=$G(^DGCR(399,IBIFN,0)),IBY=$P(IBX,U,2) | 
|---|
| 145 | S IBX=$G(^DGCR(399,IBIFN,"U")),$P(IBY,U,2)=+IBX,$P(IBY,U,3)=+$P(IBX,U,2) | 
|---|
| 146 | Q IBY | 
|---|
| 147 | ; | 
|---|
| 148 | ONBILLPI(IBIFN,PIFN) ; return Bill Item ptr (#362.5) if the Prosthetics Item (#660) is already assigned to the bill | 
|---|
| 149 | ; input:  PIFN = Patient Prosthetics Item (ptr to 660) | 
|---|
| 150 | ; output: BIFN = Bill Prosthetics Item (ptr to 362.5) or null if not found | 
|---|
| 151 | N IBC,IBX,IBY,BIFN S IBY="" S IBC="AIFN"_$G(IBIFN) | 
|---|
| 152 | S IBX=0 F  S IBX=$O(^IBA(362.5,IBC,IBX)) Q:'IBX  S BIFN=0 F  S BIFN=$O(^IBA(362.5,IBC,IBX,BIFN)) Q:'BIFN  D | 
|---|
| 153 | . I +$G(PIFN),$P($G(^IBA(362.5,BIFN,0)),U,4)=PIFN S IBY=BIFN | 
|---|
| 154 | Q IBY | 
|---|
| 155 | ; | 
|---|
| 156 | DATE(X) ; | 
|---|
| 157 | Q $E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3) | 
|---|
| 158 | ; | 
|---|
| 159 | EXEMPT ; exemption reasons | 
|---|
| 160 | ;;AO | 
|---|
| 161 | ;;IR | 
|---|
| 162 | ;;SC | 
|---|
| 163 | ;;SWA | 
|---|
| 164 | ;;MST | 
|---|
| 165 | ;;HNC | 
|---|
| 166 | ;;CV | 
|---|
| 167 | ; | 
|---|