Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: IBAMTBU

IBAMTBU.m

Go to the documentation of this file.
IBAMTBU	;ALB/CPM - MEANS TEST BILLING BULLETINS ; 09-DEC-91
	;;Version 2.0 ; INTEGRATED BILLING ;; 21-MAR-94
	;;Per VHA Directive 10-93-142, this routine should not be modified.
	;
PM	; Send bulletin when patient movements for a Category C patient
	; have been edited, deleted, or retro-actively added.
	;        Input:  IBJOB = 3 (Edited, deleted movements)
	;                      = 6 (Retro-actively added movements)
	;                DFN, DUZ, DGPMA, DGPMP
	;
	; - quit if a bulletin is not needed
	Q:'$$APM^IBAMTD2
	;
	; - generate the bulletin
	K IBT
	S IBPT=$$PT^IBEFUNC(DFN)
	S XMSUB=$E($P(IBPT,"^"),1,14)_"  "_$P(IBPT,"^",3)_" - MOVEMENT CHANGE"
	S IBMTYP=$S(DGPMP="":$P(DGPMA,"^",2),1:$P(DGPMP,"^",2))
	I IBJOB=3 S IBT(1)="A"_$S(IBMTYP=1:"n admission",IBMTYP=2:" transfer",IBMTYP=3:" discharge",IBMTYP=6:" treating specialty",1:" lodger movement")_" has been "_$S(DGPMA]"":"edited",1:"deleted")
	I IBJOB=6 S IBT(1)="A "_$S($P(DGPMA,"^",2)=6:"treating specialty",1:"transfer")_" has been retro-actively added"
	S IBT(1)=IBT(1)_" for the following patient:" S IBT(2)=" ",IBC=2
	S IBDUZ=DUZ D PAT^IBAERR1
	S Y=$S(DGPMA:+DGPMA,1:+DGPMP) D DD^%DT
	S IBC=IBC+1,IBT(IBC)=$S(IBMTYP=1:" Adm",IBMTYP=2:"Trnf",IBMTYP=3:"Disc",IBMTYP=6:"Spec",1:"Lodg")_" Date: "_Y
	S IBC=IBC+1,IBT(IBC)=" "
	;
	; - display before/after critical values and instructions
	D DISP^IBAMTBU1
	;
	; - deliver message
	D SEND
	Q
	;
CTPT	; Send bulletin for the discharge of a Continuous Patient.
	;  Input: DGPMA, DFN, DUZ, IBASIH, TRAN
	S IBPT=$$PT^IBEFUNC(DFN),Y=+DGPMA D D^DIQ K IBT
	S XMSUB=$E($P(IBPT,"^"),1,14)_"  "_$P(IBPT,"^",3)_" - CONTINUOUS PATIENT"
	S IBT(1)="The following continuous patient was discharged on  "_Y
	S IBT(2)=" ",IBC=2
	S IBDUZ=DUZ D PAT^IBAERR1
	S IBC=IBC+1,IBT(IBC)=" "
	S IBC=IBC+1,IBT(IBC)="Discharge Type: "_$S($P($G(^DG(405.1,+$P(DGPMA,"^",4),0)),"^")]"":$P(^(0),"^"),1:"TYPE UNKNOWN")
	I TRAN S IBC=IBC+1,IBT(IBC)="Transferred To: "_$S($P($G(^DIC(4,+$P(DGPMA,"^",5),0)),"^")]"":$P(^(0),"^"),1:"FACILITY UNKNOWN")
	S IBC=IBC+1,IBT(IBC)=" "
	; - message for ASIH or non-transfers
	I 'TRAN!(IBASIH) D  G SEND
	. S IBC=IBC+1 I IBASIH S IBT(IBC)="Please note that, since this patient went out on ASIH,"
	. E  S IBT(IBC)="Since the patient was not transferred to another facility,"
	. S IBT(IBC)=IBT(IBC)_" the patient's"
	. S IBC=IBC+1,IBT(IBC)="discharge date was entered into the Continuous Patient file, 'unflagging'"
	. S IBC=IBC+1,IBT(IBC)="the patient as continuous.  The patient will now be charged the Category"
	. S IBC=IBC+1,IBT(IBC)="C copayment (Medicare Deductible) for any future episodes of Hospital or"
	. S IBC=IBC+1,IBT(IBC)="Nursing Home care, if s/he is Category C at that time."
	. Q:IBASIH
	. S IBC=IBC+1,IBT(IBC)=" "
	. S IBC=IBC+1,IBT(IBC)="If the patient was in fact transferred, then the Discharge Date must be"
	. S IBC=IBC+1,IBT(IBC)="deleted from the Continuous Patient file."
	;
	; - message for transferred patients
	S IBC=IBC+1,IBT(IBC)="Please note that, since the patient was transferred to another facility,"
	S IBC=IBC+1,IBT(IBC)="the patient's discharge date was not entered into the Continuous Patient"
	S IBC=IBC+1,IBT(IBC)="file.  If the patient does not receive continuous care while outside of"
	S IBC=IBC+1,IBT(IBC)="your facility, you must manually enter the date on which the patient's"
	S IBC=IBC+1,IBT(IBC)="care was discontinued into the Continuous Patient file."
	;
SEND	; - send message and quit.
	D MAIL^IBAERR1
	K IBVAL,IBT,IBMTYP,IBC,IBI,IBPT,XMSUB,XMY,XMTEXT,XMDUZ
	Q