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

ABMER60.m

Go to the documentation of this file.
  1. ABMER60 ; IHS/ASDST/DMJ - UB92 EMC RECORD 60 (Inpatient Ancillary Services) ;
  1. ;;2.6;IHS 3P BILLING SYSTEM;;NOV 12, 2009
  1. ;Original;DMJ;07/08/96 4:56 PM
  1. ;
  1. ; IHS/FCS/DRS 09/17/01 ABM*2.4*9
  1. ; Part 17 - Proper init of ancillary charges slots.
  1. ; They demand that even unused slots have 0 in numeric bytes,
  1. ; not spaces.
  1. ;
  1. ; IHS/SD/SDR - v2.5 p10 - IM20395
  1. ; Split out lines bundled by rev code
  1. ;
  1. START ;START HERE
  1. K ABMR(60),ABMREC(60)
  1. S ABME("RTYPE")=60,ABME("S#")=0
  1. S $P(ABME("SPACE1")," ",113)=""
  1. S $P(ABME("SPACE2")," ",57)=""
  1. I $$ENVOY^ABMEF16 D
  1. .N X S X="0000 000000000000000000000000000 000000 "
  1. .S ABME("SPACE1")=X_X,ABME("SPACE2")=X
  1. D SET^ABMERUTL
  1. K ABMP("FLAT") D FRATE^ABMDF11
  1. D ^ABMERGRV
  1. D LOOP
  1. S L=0 F S L=$O(ABMREC(60,L)) Q:'L D S90^ABMERUTL
  1. K ABM,ABME,ABMRV
  1. Q
  1. ;
  1. LOOP ;LOOP HERE
  1. I $$RCID^ABMERUTL(ABMP("INS"))["MAD" D
  1. .K ABMRV(9999)
  1. S L=0
  1. S J=219 F S J=$O(ABMRV(J)) Q:'J D
  1. .S K=-1 F S K=$O(ABMRV(J,K)) Q:K="" D
  1. ..S M=0
  1. ..F S M=$O(ABMRV(J,K,M)) Q:M="" D
  1. ...S L=L+1 I L#3=1 D
  1. ....S ABME("S#")=ABME("S#")+1
  1. ....F I=10:10:30 D @(I_"^ABMER60"),ADD
  1. ...F I=40:10:120 D @(I_"^ABMER60"),ADD
  1. ...Q:J=9999
  1. ...S ABM("ACTOT")=+$P(ABMRV(J,K,M),U,6)
  1. ...S ABM("NCTOT")=+$P(ABMRV(J,K,M),U,7)
  1. ...D ADTT
  1. I '$G(ABMP("NOFMT")) S ABMREC(60,ABME("S#"))=ABMREC(60,ABME("S#"))_$S(L#3=1:ABME("SPACE1"),L#3=2:ABME("SPACE2"),1:"")
  1. Q
  1. ;
  1. ADD ;ADD TO RECORD
  1. I '$G(ABMP("NOFMT")) S ABMREC(60,ABME("S#"))=$G(ABMREC(60,ABME("S#")))_ABMR(60,I)
  1. Q
  1. ;
  1. 10 ;Record type
  1. S ABMR(60,10)=60
  1. Q
  1. ;
  1. 20 ;Sequence
  1. S ABMR(60,20)=ABME("S#")
  1. S ABMR(60,20)=$$FMT^ABMERUTL(ABMR(60,20),"2NR")
  1. Q
  1. ;
  1. 30 ;Patient Control Number, (SOURCE: FILE=9000001.41,FIELD=.02)
  1. S ABMR(60,30)=$$EX^ABMER20(30,ABMP("BDFN"))
  1. S ABMR(60,30)=$$FMT^ABMERUTL(ABMR(60,30),20)
  1. Q
  1. ;
  1. 40 ;Outpatient Revenue Code 1 (SOURCE: FILE=, FIELD=)
  1. S ABMR(60,40)=$P(ABMRV(J,K,M),U)
  1. S ABMR(60,40)=$$FMT^ABMERUTL(ABMR(60,40),"4NR")
  1. Q
  1. ;
  1. 50 ;HCPCS Procedure Code 1
  1. S ABMR(60,50)=$P(ABMRV(J,K,M),U,2)
  1. S ABMR(60,50)=$$FMT^ABMERUTL(ABMR(60,50),5)
  1. Q
  1. ;
  1. 60 ;Modifier 1 (CPT-4 and HCPCS) 1 (SOURCE: FILE=, FIELD=)
  1. S ABMR(60,60)=$P(ABMRV(J,K,M),U,3)
  1. S ABMR(60,60)=$$FMT^ABMERUTL(ABMR(60,60),2)
  1. Q
  1. ;
  1. 70 ;Modifier 2 (CPT-4 and HCPCS) 1 (SOURCE: FILE=, FIELD=)
  1. S ABMR(60,70)=$P(ABMRV(J,K,M),U,4)
  1. S ABMR(60,70)=$$FMT^ABMERUTL(ABMR(60,70),2)
  1. Q
  1. ;
  1. 80 ;Units of Service 1 (SOURCE: FILE= FIELD=)
  1. S ABMR(60,80)=$P(ABMRV(J,K,M),U,5)
  1. S ABMR(60,80)=$$FMT^ABMERUTL(ABMR(60,80),"7NR")
  1. Q
  1. ;
  1. 90 ;Charges Total 1 (SOURCE: FILE= FIELD=)
  1. S ABMR(60,90)=$P(ABMRV(J,K,M),U,6)
  1. S ABMR(60,90)=$$FMT^ABMERUTL(ABMR(60,90),"10NRJ2")
  1. Q
  1. ;
  1. 100 ;Charges Non-Covered 1
  1. S ABMR(60,100)=""
  1. S ABMR(60,100)=$$FMT^ABMERUTL(ABMR(60,100),"10NRJ2")
  1. Q
  1. ;
  1. 110 ;Form Locator 49 1 (SOURCE: FILE= FIELD=)
  1. S ABMR(60,110)=""
  1. S ABMR(60,110)=$$FMT^ABMERUTL(ABMR(60,110),4)
  1. Q
  1. ;
  1. 120 ;Filler (National Use)
  1. S ABMR(60,120)=""
  1. S ABMR(60,120)=$$FMT^ABMERUTL(ABMR(60,120),12)
  1. Q
  1. ;
  1. EX(ABMX,ABMY,ABMZ) ;EXTRINSIC FUNCTION HERE
  1. ;X=data element, Y=bill internal entry number
  1. S ABMP("BDFN")=ABMY D SET^ABMERUTL
  1. I '$G(ABMP("NOFMT")) S ABMP("FMT")=0
  1. D @ABMX
  1. S Y=ABMR(60,ABMX)
  1. I $D(ABMP("FMT")) S ABMP("FMT")=1
  1. K ABMR(60,ABMX),ABME,ABMX,ABMY,ABMZ,ABM
  1. Q Y
  1. ;
  1. ADTT ; EP
  1. ; Add to totals
  1. S ABMRT(90,150)=+$G(ABMRT(90,150))+ABM("ACTOT")
  1. S ABMRT(90,160)=+$G(ABMRT(90,160))+ABM("NCTOT")
  1. S ABMRT(95,100)=+$G(ABMRT(95,100))+ABM("ACTOT")
  1. S ABMRT(95,110)=+$G(ABMRT(95,110))+ABM("NCTOT")
  1. S ABMRT(99,80)=+$G(ABMRT(99,80))+ABM("ACTOT")
  1. S ABMRT(99,90)=+$G(ABMRT(99,90))+ABM("NCTOT")
  1. Q