| 1 | IBCSC5B ;ALB/ARH - ADD/ENTER PROSTHETIC ITEMS ;12/28/93
|
---|
| 2 | ;;2.0;INTEGRATED BILLING;**4,52,260,339**;21-MAR-94;Build 2
|
---|
| 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 | S IBX=$$BILL(IBIFN) Q:'IBIFN S DFN=+IBX,IBDT1=$P(IBX,U,2),IBDT2=$P(IBX,U,3)
|
---|
| 8 | D SET(IBIFN,.IBPDA),PIDISP(DFN,IBDT1,IBDT2,.IBPDE,.IBPDA),DISP(.IBPDA)
|
---|
| 9 | E1 S IBPIFN=0,IBDT=$$ASKDT(IBDT1,IBDT2) G:'IBDT EXIT
|
---|
| 10 | S IBPD=$O(IBPDA(IBDT,0)) S:'IBPD IBPD=$O(IBPDE(IBDT,0)) S IBPD=$$ASKPD(IBPD) G:'IBPD E1
|
---|
| 11 | S IBPIFN=$G(IBPDA(IBDT,+IBPD)) I 'IBPIFN S IBPIFN=$$ADD(IBDT,IBIFN,+IBPD,+$G(IBPDE(IBDT,+IBPD))) I 'IBPIFN W " ??" G E1
|
---|
| 12 | I '$D(IBPDE(IBDT,+IBPD)) W !,"This prosthetic item does not exist in this patients prosthetics record.",!
|
---|
| 13 | D EDIT(+IBPIFN) D SET(IBIFN,.IBPDA) W ! G E1
|
---|
| 14 | ;
|
---|
| 15 | EXIT K IBPIFN,IBX,IBDT1,IBDT2,IBPDA,IBPDE,IBPD,IBDT
|
---|
| 16 | Q
|
---|
| 17 | ;
|
---|
| 18 | ASKDT(IBDT1,IBDT2,IBDT) ;
|
---|
| 19 | I +$G(IBIFN) S DIR("?")="Enter the date the item was delivered to the patient",DIR("??")="^D HELP^IBCSC5B("_IBIFN_")"
|
---|
| 20 | S DIR("A")="Select ITEM DELIVERY DATE",DIR(0)="DO^"_IBDT1_":"_IBDT2_":EX" D ^DIR K DIR,DTOUT,DIRUT
|
---|
| 21 | Q $S(Y?7N:Y,1:0)
|
---|
| 22 | ;
|
---|
| 23 | ASKPD(PD) ;
|
---|
| 24 | N X,Y
|
---|
| 25 | S DIR("A")="Select PROSTHETIC ITEM",DIR(0)="660,4O" S:+$G(PD) DIR("B")=+$G(^RMPR(661,+$G(PD),0)) D ^DIR S:$D(DIRUT)!(Y'>0) Y="" K DIR,DIRUT
|
---|
| 26 | Q Y
|
---|
| 27 | ;
|
---|
| 28 | ADD(IBDT,IFN,IBPD,PIFN) ;
|
---|
| 29 | N IBX,IBY,IBDX,IBHCPCS S IBX=0,DIC="^IBA(362.5,",DIC(0)="AQL",X=IBDT K DA,DO D FILE^DICN K DA,DO,X
|
---|
| 30 | I Y>0 S DIE=DIC,(IBX,DA)=+Y,DR=".02////"_IFN_";.03////"_IBPD_";.04////"_PIFN D ^DIE K DIE,DIC,DA,DR W "... ADDED"
|
---|
| 31 | ;add dx if known
|
---|
| 32 | F IBY=1:1:4 S IBDX=+$G(^RMPR(660,PIFN,"BA"_IBY)) I IBDX,'$O(^IBA(362.3,"AIFN"_IFN,IBDX)) D
|
---|
| 33 | . S DIC="^IBA(362.3,",DIC(0)="L",DLAYGO=362.3,X=IBDX,DIC("DR")=".02////"_IFN K DD,DO D FILE^DICN S IBDX(+Y)=""
|
---|
| 34 | ;add hcpcs if known
|
---|
| 35 | ;S IBHCPCS=$P($G(^RMPR(660,PIEN,0)),"^",22) I IBHCPCS
|
---|
| 36 | ;
|
---|
| 37 | Q IBX
|
---|
| 38 | ;
|
---|
| 39 | EDIT(PIFN) ;
|
---|
| 40 | S DIDEL=362.5,DIE="^IBA(362.5,",DR=".01;.03",DA=PIFN D ^DIE K DIE,DR,DA,DIC,DIDEL
|
---|
| 41 | Q
|
---|
| 42 | ;
|
---|
| 43 | SET(IFN,PDARR) ;setup array of all prosthetic devices for bill, array name should be passed by reference
|
---|
| 44 | ;returns: PDARR(PD DELIV DATE, PD ITEM (661 ptr))=PD IFN (362.5 ptr), PDARR=BILL IFN ^ PD count
|
---|
| 45 | N CNT,IBX,IBY,PIFN,IBC,IBRC K PDARR S IBC="AIFN"_$G(IFN)
|
---|
| 46 | D RCITEM^IBCSC5A(IBIFN,"IBRC",5)
|
---|
| 47 | S (CNT,IBX)=0 F S IBX=$O(^IBA(362.5,IBC,IBX)) Q:'IBX S PIFN=0 F S PIFN=$O(^IBA(362.5,IBC,IBX,PIFN)) Q:'PIFN D
|
---|
| 48 | . S IBY=$G(^IBA(362.5,PIFN,0)) Q:IBY="" S CNT=CNT+1,PDARR(+IBY,$P(IBY,U,3))=PIFN_U_$$CHG^IBCF4(PIFN,5,.IBRC)
|
---|
| 49 | S PDARR=$G(IFN)_"^"_CNT
|
---|
| 50 | Q
|
---|
| 51 | ;
|
---|
| 52 | DISP(PDARR) ;screen display of existing prosthetic devices for a bill,
|
---|
| 53 | ;input should be array returned by SET^IBCSC5B: PDARR(PD DT, PD ITEM)=PD IFN (362.5), pass by reference
|
---|
| 54 | N IBX,IBY,IBZ
|
---|
| 55 | W !!,?5,"----------------- Existing Prosthetic Items for Bill -----------------",!
|
---|
| 56 | S IBX=0 F S IBX=$O(PDARR(IBX)) Q:IBX="" S IBY=0 F S IBY=$O(PDARR(IBX,IBY)) Q:'IBY D
|
---|
| 57 | . S IBZ=$$PIN(IBY) W !,$$DATE(IBX),?12,$P(IBZ,U,1),?20,$P(IBZ,U,2)
|
---|
| 58 | W !
|
---|
| 59 | Q
|
---|
| 60 | ;
|
---|
| 61 | HELP(IFN) ;called for help from prosthetics enter to display existing devices, displays devices from 660 and 399
|
---|
| 62 | I +$G(IFN) N IBX,IBPDA S IBX=$$BILL(IFN) I +IBX D SET(IFN,.IBPDA),PIDISP($P(IBX,U,1),$P(IBX,U,2),$P(IBX,U,3),"",.IBPDA),DISP(.IBPDA)
|
---|
| 63 | Q
|
---|
| 64 | ;
|
---|
| 65 | PIDISP(DFN,DT1,DT2,ARRAY,PDARR) ; display all prosthetic items (660) for a patient and date range
|
---|
| 66 | ;PDARR (as defined by SET^IBCSC5B) passed by ref. only to check if pros. item is on the bill, not necessary, not changed
|
---|
| 67 | ;returns ARRAY(PD DEL DATE (660,10), PD ITEM (660,4=661 ptr))=RECORD (660 ptr), should pass by ref. if desired
|
---|
| 68 | N PIFN,IBX,IBY,PNAME,DDT,PI,IBICD,IBEX,IBP
|
---|
| 69 | K ARRAY S DT1=$G(DT1)-.0001,DT2=$G(DT2) S:'DT2 DT2=9999999 Q:'$G(DFN)
|
---|
| 70 | S PIFN=0 F S PIFN=$O(^RMPR(660,"C",DFN,PIFN)) Q:'PIFN D
|
---|
| 71 | . S IBX=$G(^RMPR(660,PIFN,0)),DDT=+$P(IBX,U,12)\1 I (DDT<DT1)!(DDT>DT2) Q
|
---|
| 72 | . S ARRAY(DDT,+$P(IBX,U,6))=PIFN
|
---|
| 73 | ;
|
---|
| 74 | W @IOF,?33,"PROSTHETICS SCREEN",!,"================================================================================",!
|
---|
| 75 | S DDT=0 F S DDT=$O(ARRAY(DDT)) Q:'DDT S PI=0 F S PI=$O(ARRAY(DDT,PI)) Q:'PI D
|
---|
| 76 | . S PIFN=ARRAY(DDT,PI),PNAME=$$PIN(PI),IBY=$G(^RMPR(660,PIFN,"AM")),IBX=$G(^RMPR(660,PIFN,0)) K IBEX
|
---|
| 77 | . ; look for exemption info
|
---|
| 78 | . 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
|
---|
| 79 | . W !,$S($D(PDARR(+DDT,PI)):"*",1:"")
|
---|
| 80 | . W ?2,$$DATE(DDT),?12,$P(PNAME,U,1),$G(IBEX),?20,$E($P(PNAME,U,2),1,30),?55,$E($$EXSET^IBEFUNC($P(IBX,U,14),660,12),1,4),?62,$$EXSET^IBEFUNC($P(IBY,U,3),660,62),?70,$J(+$P(IBX,U,16),9,2)
|
---|
| 81 | Q
|
---|
| 82 | ;
|
---|
| 83 | PIN(PITEM) ;given the pros item IFN (661 ptr) returns name for printing (661,.01^441,.05)
|
---|
| 84 | N IBX,IBY S IBY="" I +$G(PITEM) S IBX=+$G(^RMPR(661,+PITEM,0)) I +IBX S IBY=IBX_U_$$DESCR^PRCPUX1(0,+IBX)
|
---|
| 85 | Q IBY
|
---|
| 86 | ;
|
---|
| 87 | BILL(IBIFN) ; display all existing prescription refills (52) for a patient and date range
|
---|
| 88 | ; (call is a short cut to calling rxdisp if have bill number)
|
---|
| 89 | N IBX,IBY S IBX=$G(^DGCR(399,+$G(IBIFN),0)),IBY=$P(IBX,U,2)
|
---|
| 90 | S IBX=$G(^DGCR(399,+IBIFN,"U")),$P(IBY,U,2)=+IBX,$P(IBY,U,3)=+$P(IBX,U,2)
|
---|
| 91 | Q IBY
|
---|
| 92 | ;
|
---|
| 93 | DATE(X) ;
|
---|
| 94 | Q $E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3)
|
---|
| 95 | ;
|
---|
| 96 | EXEMPT ; exemption reasons
|
---|
| 97 | ;;AO
|
---|
| 98 | ;;IR
|
---|
| 99 | ;;SC
|
---|
| 100 | ;;SWA
|
---|
| 101 | ;;MST
|
---|
| 102 | ;;HNC
|
---|
| 103 | ;;CV
|
---|
| 104 | ;
|
---|