PRCATP5 ; GENERATED FROM 'PRCA 3RD PROFILE' PRINT TEMPLATE (#386) ; 06/27/96 ; (FILE 430, MARGIN=80)
G BEGIN
N W !
T W:$X ! I '$D(DIOT(2)),DN,$D(IOSL),$S('$D(DIWF):1,$P(DIWF,"B",2):$P(DIWF,"B",2),1:1)+$Y'<IOSL,$D(^UTILITY($J,1))#2,^(1)?1U1P1E.E X ^(1)
S DISTP=DISTP+1,DILCT=DILCT+1 D:'(DISTP#100) CSTP^DIO2
Q
DT I $G(DUZ("LANG"))>1,Y W $$OUT^DIALOGU(Y,"DD") Q
I Y W $P("JAN^FEB^MAR^APR^MAY^JUN^JUL^AUG^SEP^OCT^NOV^DEC",U,$E(Y,4,5))_" " W:Y#100 $J(Y#100\1,2)_"," W Y\10000+1700 W:Y#1 " "_$E(Y_0,9,10)_":"_$E(Y_"000",11,12) Q
W Y Q
M D @DIXX
Q
BEGIN ;
S:'$D(DN) DN=1 S DISTP=$G(DISTP),DILCT=$G(DILCT)
I $D(DXS)<9 F X=0:0 S X=$O(^DIPT(386,"DXS",X)) Q:'X S Y=$O(^(X,"")) F X=X:0 Q:Y="" S DXS(X,Y)=^(Y),Y=$O(^(Y))
W ?0 S %=$P($H,",",2),X=DT_(%\60#60/100+(%\3600)+(%#60/10000)/100) S Y=X K DIP K:DN Y S Y=X D DT
W ?20 W " 3RD PARTY ACCOUNTS RECEIVABLE PROFILE"
D N:$X>0 Q:'DN W ?0 S X="=",DIP(1)=X S X=75,X1=DIP(1) S %=X,X="" Q:X1="" S $P(X,X1,%\$L(X1)+1)=X1,X=$E(X,1,%) K DIP K:DN Y W X
D N:$X>0 Q:'DN W ?0 W "PATIENT NAME: "
S X=$G(^PRCA(430,D0,0)) S Y=$P(X,U,7) S Y=$S(Y="":Y,$D(^DPT(Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
D N:$X>39 Q:'DN W ?39 W "BILL #: "
W ?0,$E($P(X,U,1),1,30)
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "CURRENT STATUS: "
S Y=$P(X,U,8) S Y=$S(Y="":Y,$D(^PRCA(430.3,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
D N:$X>39 Q:'DN W ?39 W "CATEGORY: "
S Y=$P(X,U,2) S Y=$S(Y="":Y,$D(^PRCA(430.2,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
D N:$X>0 Q:'DN W ?0 W "CP: "
S X=$G(^PRCA(430,D0,11)) W ?0,$E($P(X,U,1),1,15)
D N:$X>39 Q:'DN W ?39 W "FUND (APPROPRIATION): "
W ?0,$E($P(X,U,17),1,6)
D N:$X>39 Q:'DN W ?39 W "DATE BILL PREPARED: "
S X=$G(^PRCA(430,D0,0)) S Y=$P(X,U,10) D DT
D N:$X>39 Q:'DN W ?39 W "TYPE OF CARE: "
W ?55 S X=D0 D ^DGCRAMS W ?59,$S(Y=-1:"","^249^293^"[("^"_Y_"^"):"OUTPATIENT",1:"INPATIENT") K DIP K:DN Y
D N:$X>39 Q:'DN W ?39 W "DATES OF SERVICE: "
W ?59 S X=$$SVDT^PRCADR(D0) W:+X $$FMTE^XLFDT($P(X,U,3))_" -",!,?59,$$FMTE^XLFDT($P(X,U,4)) K DIP K:DN Y
W ?70 D EN1^PRCADR1 K DIP K:DN Y
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "3RD PARTY: "
S X=$G(^PRCA(430,D0,0)) D N:$X>12 Q:'DN W ?12 S Y=$P(X,U,9) S C=$P(^DD(430,9,0),U,2) D Y^DIQ:Y S C="," W $E(Y,1,27)
W ?41 D EN4^PRCADR K DIP K:DN Y
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "INSURED'S NAME"
D N:$X>25 Q:'DN W ?25 W "S"
D N:$X>28 Q:'DN W ?28 W "ID NO."
D N:$X>45 Q:'DN W ?45 W "GROUP NAME"
D N:$X>60 Q:'DN W ?60 W "GROUP NO."
S X=$G(^PRCA(430,D0,202)) D N:$X>1 Q:'DN W ?1,$E($P(X,U,1),1,30)
D N:$X>25 Q:'DN W ?25 S DIP(1)=$S($D(^PRCA(430,D0,202)):^(202),1:"") S X=$P(DIP(1),U,2),X=X K DIP K:DN Y W X
S X=$G(^PRCA(430,D0,202)) D N:$X>28 Q:'DN W ?28,$E($P(X,U,4),1,20)
D N:$X>45 Q:'DN W ?45,$E($P(X,U,5),1,20)
D N:$X>60 Q:'DN W ?60,$E($P(X,U,6),1,10)
D T Q:'DN W ?2 D EN5^PRCADR Q:$D(PRCA("HALT")) W "" K DIP K:DN Y
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "EMPLOYER NAME"
D N:$X>28 Q:'DN W ?28 W "EMPLOYEE ID"
D N:$X>44 Q:'DN W ?44 W "EMPLOYER LOCATION"
S X=$G(^PRCA(430,D0,202)) D N:$X>1 Q:'DN W ?1,$E($P(X,U,9),1,30)
D N:$X>28 Q:'DN W ?28,$E($P(X,U,10),1,11)
D T Q:'DN W ?44,$E($P(X,U,11),1,40)
D N:$X>0 Q:'DN W ?0 W "SECONDARY INSURANCE COMPANY: "
S X=$G(^PRCA(430,D0,0)) W ?31 S Y=$P(X,U,19) S Y=$S(Y="":Y,$D(^DIC(36,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
D N:$X>0 Q:'DN W ?0 W "TERTIARY INSUANCE COMPANY: "
W ?29 S Y=$P(X,U,20) S Y=$S(Y="":Y,$D(^DIC(36,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
W ?61 D EN3^PRCADR K DIP K:DN Y
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "TRANSACTIONS: "
W ?16 D EN2^PRCADR K DIP K:DN Y
W ?27 Q:$D(PRCA("HALT")) W "" K DIP K:DN Y
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "BILL RESULTING FROM: "
W ?23 X DXS(1,9) K DIP K:DN Y
W ?34 D PRCOMM^PRCAUT3 K DIP K:DN Y
W ?45 Q:'$D(PRCA("WROFF")) W "" K DIP K:DN Y
W ?56 K DXS S D0=PRCA("WROFF") D ^PRCATW1 K DXS K DIP K:DN Y
K Y
Q
HEAD ;
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCATP5 4038 printed Dec 13, 2024@01:41:45 Page 2
PRCATP5 ; GENERATED FROM 'PRCA 3RD PROFILE' PRINT TEMPLATE (#386) ; 06/27/96 ; (FILE 430, MARGIN=80)
+1 GOTO BEGIN
N WRITE !
T if $X
WRITE !
IF '$DATA(DIOT(2))
IF DN
IF $DATA(IOSL)
IF $SELECT('$DATA(DIWF):1,$PIECE(DIWF,"B",2):$PIECE(DIWF,"B",2),1:1)+$Y'<IOSL
IF $DATA(^UTILITY($JOB,1))#2
IF ^(1)?1U1P1E.E
XECUTE ^(1)
+1 SET DISTP=DISTP+1
SET DILCT=DILCT+1
if '(DISTP#100)
DO CSTP^DIO2
+2 QUIT
DT IF $GET(DUZ("LANG"))>1
IF Y
WRITE $$OUT^DIALOGU(Y,"DD")
QUIT
+1 IF Y
WRITE $PIECE("JAN^FEB^MAR^APR^MAY^JUN^JUL^AUG^SEP^OCT^NOV^DEC",U,$EXTRACT(Y,4,5))_" "
if Y#100
WRITE $JUSTIFY(Y#100\1,2)_","
WRITE Y\10000+1700
if Y#1
WRITE " "_$EXTRACT(Y_0,9,10)_":"_$EXTRACT(Y_"000",11,12)
QUIT
+2 WRITE Y
QUIT
M DO @DIXX
+1 QUIT
BEGIN ;
+1 if '$DATA(DN)
SET DN=1
SET DISTP=$GET(DISTP)
SET DILCT=$GET(DILCT)
+2 IF $DATA(DXS)<9
FOR X=0:0
SET X=$ORDER(^DIPT(386,"DXS",X))
if 'X
QUIT
SET Y=$ORDER(^(X,""))
FOR X=X:0
if Y=""
QUIT
SET DXS(X,Y)=^(Y)
SET Y=$ORDER(^(Y))
+3 WRITE ?0
SET %=$PIECE($HOROLOG,",",2)
SET X=DT_(%\60#60/100+(%\3600)+(%#60/10000)/100)
SET Y=X
KILL DIP
if DN
KILL Y
SET Y=X
DO DT
+4 WRITE ?20
WRITE " 3RD PARTY ACCOUNTS RECEIVABLE PROFILE"
+5 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET X="="
SET DIP(1)=X
SET X=75
SET X1=DIP(1)
SET %=X
SET X=""
if X1=""
QUIT
SET $PIECE(X,X1,%\$LENGTH(X1)+1)=X1
SET X=$EXTRACT(X,1,%)
KILL DIP
if DN
KILL Y
WRITE X
+6 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "PATIENT NAME: "
+7 SET X=$GET(^PRCA(430,D0,0))
SET Y=$PIECE(X,U,7)
SET Y=$SELECT(Y="":Y,$DATA(^DPT(Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+8 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "BILL #: "
+9 WRITE ?0,$EXTRACT($PIECE(X,U,1),1,30)
+10 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "CURRENT STATUS: "
+11 SET Y=$PIECE(X,U,8)
SET Y=$SELECT(Y="":Y,$DATA(^PRCA(430.3,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+12 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "CATEGORY: "
+13 SET Y=$PIECE(X,U,2)
SET Y=$SELECT(Y="":Y,$DATA(^PRCA(430.2,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+14 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "CP: "
+15 SET X=$GET(^PRCA(430,D0,11))
WRITE ?0,$EXTRACT($PIECE(X,U,1),1,15)
+16 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "FUND (APPROPRIATION): "
+17 WRITE ?0,$EXTRACT($PIECE(X,U,17),1,6)
+18 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "DATE BILL PREPARED: "
+19 SET X=$GET(^PRCA(430,D0,0))
SET Y=$PIECE(X,U,10)
DO DT
+20 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "TYPE OF CARE: "
+21 WRITE ?55
SET X=D0
DO ^DGCRAMS
WRITE ?59,$SELECT(Y=-1:"","^249^293^"[("^"_Y_"^"):"OUTPATIENT",1:"INPATIENT")
KILL DIP
if DN
KILL Y
+22 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "DATES OF SERVICE: "
+23 WRITE ?59
SET X=$$SVDT^PRCADR(D0)
if +X
WRITE $$FMTE^XLFDT($PIECE(X,U,3))_" -",!,?59,$$FMTE^XLFDT($PIECE(X,U,4))
KILL DIP
if DN
KILL Y
+24 WRITE ?70
DO EN1^PRCADR1
KILL DIP
if DN
KILL Y
+25 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "3RD PARTY: "
+26 SET X=$GET(^PRCA(430,D0,0))
if $X>12
DO N
if 'DN
QUIT
WRITE ?12
SET Y=$PIECE(X,U,9)
SET C=$PIECE(^DD(430,9,0),U,2)
if Y
DO Y^DIQ
SET C=","
WRITE $EXTRACT(Y,1,27)
+27 WRITE ?41
DO EN4^PRCADR
KILL DIP
if DN
KILL Y
+28 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "INSURED'S NAME"
+29 if $X>25
DO N
if 'DN
QUIT
WRITE ?25
WRITE "S"
+30 if $X>28
DO N
if 'DN
QUIT
WRITE ?28
WRITE "ID NO."
+31 if $X>45
DO N
if 'DN
QUIT
WRITE ?45
WRITE "GROUP NAME"
+32 if $X>60
DO N
if 'DN
QUIT
WRITE ?60
WRITE "GROUP NO."
+33 SET X=$GET(^PRCA(430,D0,202))
if $X>1
DO N
if 'DN
QUIT
WRITE ?1,$EXTRACT($PIECE(X,U,1),1,30)
+34 if $X>25
DO N
if 'DN
QUIT
WRITE ?25
SET DIP(1)=$SELECT($DATA(^PRCA(430,D0,202)):^(202),1:"")
SET X=$PIECE(DIP(1),U,2)
SET X=X
KILL DIP
if DN
KILL Y
WRITE X
+35 SET X=$GET(^PRCA(430,D0,202))
if $X>28
DO N
if 'DN
QUIT
WRITE ?28,$EXTRACT($PIECE(X,U,4),1,20)
+36 if $X>45
DO N
if 'DN
QUIT
WRITE ?45,$EXTRACT($PIECE(X,U,5),1,20)
+37 if $X>60
DO N
if 'DN
QUIT
WRITE ?60,$EXTRACT($PIECE(X,U,6),1,10)
+38 DO T
if 'DN
QUIT
WRITE ?2
DO EN5^PRCADR
if $DATA(PRCA("HALT"))
QUIT
WRITE ""
KILL DIP
if DN
KILL Y
+39 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "EMPLOYER NAME"
+40 if $X>28
DO N
if 'DN
QUIT
WRITE ?28
WRITE "EMPLOYEE ID"
+41 if $X>44
DO N
if 'DN
QUIT
WRITE ?44
WRITE "EMPLOYER LOCATION"
+42 SET X=$GET(^PRCA(430,D0,202))
if $X>1
DO N
if 'DN
QUIT
WRITE ?1,$EXTRACT($PIECE(X,U,9),1,30)
+43 if $X>28
DO N
if 'DN
QUIT
WRITE ?28,$EXTRACT($PIECE(X,U,10),1,11)
+44 DO T
if 'DN
QUIT
WRITE ?44,$EXTRACT($PIECE(X,U,11),1,40)
+45 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "SECONDARY INSURANCE COMPANY: "
+46 SET X=$GET(^PRCA(430,D0,0))
WRITE ?31
SET Y=$PIECE(X,U,19)
SET Y=$SELECT(Y="":Y,$DATA(^DIC(36,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+47 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "TERTIARY INSUANCE COMPANY: "
+48 WRITE ?29
SET Y=$PIECE(X,U,20)
SET Y=$SELECT(Y="":Y,$DATA(^DIC(36,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+49 WRITE ?61
DO EN3^PRCADR
KILL DIP
if DN
KILL Y
+50 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "TRANSACTIONS: "
+51 WRITE ?16
DO EN2^PRCADR
KILL DIP
if DN
KILL Y
+52 WRITE ?27
if $DATA(PRCA("HALT"))
QUIT
WRITE ""
KILL DIP
if DN
KILL Y
+53 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "BILL RESULTING FROM: "
+54 WRITE ?23
XECUTE DXS(1,9)
KILL DIP
if DN
KILL Y
+55 WRITE ?34
DO PRCOMM^PRCAUT3
KILL DIP
if DN
KILL Y
+56 WRITE ?45
if '$DATA(PRCA("WROFF"))
QUIT
WRITE ""
KILL DIP
if DN
KILL Y
+57 WRITE ?56
KILL DXS
SET D0=PRCA("WROFF")
DO ^PRCATW1
KILL DXS
KILL DIP
if DN
KILL Y
+58 KILL Y
+59 QUIT
HEAD ;
+1 WRITE !,"--------------------------------------------------------------------------------",!!