- 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 Jan 18, 2025@02:42:59 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 !,"--------------------------------------------------------------------------------",!!