- PRCATO2 ; GENERATED FROM 'PRCA DISP AUDIT' PRINT TEMPLATE (#395) ; 03/30/98 ; (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(395,"DXS",X)) Q:'X S Y=$O(^(X,"")) F X=X:0 Q:Y="" S DXS(X,Y)=^(Y),Y=$O(^(Y))
- S DIWF="W"
- D N:$X>0 Q:'DN W ?0 S X="=",DIP(1)=X S X=80,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 "BILL #: "
- S X=$G(^PRCA(430,D0,0)) W ?10,$E($P(X,U,1),1,30)
- D N:$X>29 Q:'DN W ?29 W "CATEGORY: "
- W ?41 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>41 Q:'DN W ?41 S Y=$P(X,U,16) 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 "DATE BILL PREPARED:"
- D N:$X>20 Q:'DN W ?20 S Y=$P(X,U,10) D DT
- W ?33 I $D(PRCAT),PRCAT["T" D PATNM^PRCADR1 K DIP K:DN Y
- D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "DEBTOR: "
- S X=$G(^PRCA(430,D0,0)) D N:$X>9 Q:'DN W ?9 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,30)
- W ?41 S PRCALN=9 D EN2^PRCADR1 K PRCALN K DIP K:DN Y
- W ?52 I $D(PRCAT),PRCAT["T" D EN6^PRCADR1 K DIP K:DN Y
- D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "RECEIVABLE CODE: "
- W ?19 X DXS(1,9.2) S DIP(101)=$S($D(^RCD(340,D0,0)):^(0),1:"") S X=$P($P(DIP(102),$C(59)_$P(DIP(101),U,5)_":",2),$C(59),1) S D0=I(0,0) K DIP K:DN Y W X
- W ?30 D RESULT^PRCAEIN K DIP K:DN Y
- D T Q:'DN D N D N:$X>0 Q:'DN W ?0 X DXS(2,9.2) S DIP(101)=$S($D(^DIC(49,D0,0)):^(0),1:"") S X=$P(DIP(101),U,2),Y=X,X=DIP(1),X=X_Y_" BY : " S D0=I(0,0) K DIP K:DN Y W X
- S X=$G(^PRCA(430,D0,104)) W ?11 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^VA(200,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,35)
- D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "Date"
- D N:$X>11 Q:'DN W ?11 W "Description"
- D N:$X>34 Q:'DN W ?34 W "Quantity"
- D N:$X>45 Q:'DN W ?45 W "Units"
- D N:$X>53 Q:'DN W ?53 W "Cost"
- D N:$X>63 Q:'DN W ?63 W "Total Cost"
- D N:$X>0 Q:'DN W ?0 S X="=",DIP(1)=X S X=80,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
- S I(1)=101,J(1)=430.02 F D1=0:0 Q:$O(^PRCA(430,D0,101,D1))'>0 X:$D(DSC(430.02)) DSC(430.02) S D1=$O(^(D1)) Q:D1'>0 D:$X>11 T Q:'DN D A1
- G A1R
- A1 ;
- D N:$X>0 Q:'DN W ?0 S DIP(1)=$S($D(^PRCA(430,D0,101,D1,0)):^(0),1:"") S X=$P(DIP(1),U,1) S:X X=$E(X,4,5)_"/"_$E(X,6,7)_"/"_(1700+$E(X,1,3)) K DIP K:DN Y W X
- D N:$X>34 Q:'DN W ?34 X DXS(3,9) K DIP K:DN Y W X
- S X=$G(^PRCA(430,D0,101,D1,0)) D N:$X>45 Q:'DN W ?45 S Y=$P(X,U,5) S Y=$S(Y="":Y,$D(^PRCD(420.5,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,5)
- D N:$X>53 Q:'DN W ?53 S DIP(1)=$S($D(^PRCA(430,D0,101,D1,0)):^(0),1:"") S X=$P(DIP(1),U,4),DIP(2)=X S X=1,DIP(3)=X S X=4,X=$J(DIP(2),DIP(3),X) K DIP K:DN Y W X
- D N:$X>63 Q:'DN W ?63 S DIP(1)=$S($D(^PRCA(430,D0,101,D1,0)):^(0),1:"") S X=$P(DIP(1),U,6),DIP(2)=X S X=1,DIP(3)=X S X=2,X=$J(DIP(2),DIP(3),X) K DIP K:DN Y W X
- S I(2)=1,J(2)=430.22 F D2=0:0 Q:$O(^PRCA(430,D0,101,D1,1,D2))'>0 S D2=$O(^(D2)) D:$X>74 T Q:'DN D A2
- G A2R
- A2 ;
- S X=$G(^PRCA(430,D0,101,D1,1,D2,0)) S DIWL=12,DIWR=78 D ^DIWP
- Q
- A2R ;
- D A^DIWW
- Q
- A1R ;
- K Y K DIWF
- Q
- HEAD ;
- W !,"--------------------------------------------------------------------------------",!!
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCATO2 3699 printed Mar 13, 2025@20:46:16 Page 2
- PRCATO2 ; GENERATED FROM 'PRCA DISP AUDIT' PRINT TEMPLATE (#395) ; 03/30/98 ; (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(395,"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 SET DIWF="W"
- +4 if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- SET X="="
- SET DIP(1)=X
- SET X=80
- 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
- +5 if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- WRITE "BILL #: "
- +6 SET X=$GET(^PRCA(430,D0,0))
- WRITE ?10,$EXTRACT($PIECE(X,U,1),1,30)
- +7 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29
- WRITE "CATEGORY: "
- +8 WRITE ?41
- 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)
- +9 if $X>41
- DO N
- if 'DN
- QUIT
- WRITE ?41
- SET Y=$PIECE(X,U,16)
- SET Y=$SELECT(Y="":Y,$DATA(^PRCA(430.2,Y,0))#2:$PIECE(^(0),U,1),1:Y)
- WRITE $EXTRACT(Y,1,30)
- +10 if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- WRITE "DATE BILL PREPARED:"
- +11 if $X>20
- DO N
- if 'DN
- QUIT
- WRITE ?20
- SET Y=$PIECE(X,U,10)
- DO DT
- +12 WRITE ?33
- IF $DATA(PRCAT)
- IF PRCAT["T"
- DO PATNM^PRCADR1
- KILL DIP
- if DN
- KILL Y
- +13 DO T
- if 'DN
- QUIT
- DO N
- if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- WRITE "DEBTOR: "
- +14 SET X=$GET(^PRCA(430,D0,0))
- if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- 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,30)
- +15 WRITE ?41
- SET PRCALN=9
- DO EN2^PRCADR1
- KILL PRCALN
- KILL DIP
- if DN
- KILL Y
- +16 WRITE ?52
- IF $DATA(PRCAT)
- IF PRCAT["T"
- DO EN6^PRCADR1
- KILL DIP
- if DN
- KILL Y
- +17 DO T
- if 'DN
- QUIT
- DO N
- if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- WRITE "RECEIVABLE CODE: "
- +18 WRITE ?19
- XECUTE DXS(1,9.2)
- SET DIP(101)=$SELECT($DATA(^RCD(340,D0,0)):^(0),1:"")
- SET X=$PIECE($PIECE(DIP(102),$CHAR(59)_$PIECE(DIP(101),U,5)_":",2),$CHAR(59),1)
- SET D0=I(0,0)
- KILL DIP
- if DN
- KILL Y
- WRITE X
- +19 WRITE ?30
- DO RESULT^PRCAEIN
- KILL DIP
- if DN
- KILL Y
- +20 DO T
- if 'DN
- QUIT
- DO N
- if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- XECUTE DXS(2,9.2)
- SET DIP(101)=$SELECT($DATA(^DIC(49,D0,0)):^(0),1:"")
- SET X=$PIECE(DIP(101),U,2)
- SET Y=X
- SET X=DIP(1)
- SET X=X_Y_" BY : "
- SET D0=I(0,0)
- KILL DIP
- if DN
- KILL Y
- WRITE X
- +21 SET X=$GET(^PRCA(430,D0,104))
- WRITE ?11
- SET Y=$PIECE(X,U,1)
- SET Y=$SELECT(Y="":Y,$DATA(^VA(200,Y,0))#2:$PIECE(^(0),U,1),1:Y)
- WRITE $EXTRACT(Y,1,35)
- +22 DO T
- if 'DN
- QUIT
- DO N
- if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- WRITE "Date"
- +23 if $X>11
- DO N
- if 'DN
- QUIT
- WRITE ?11
- WRITE "Description"
- +24 if $X>34
- DO N
- if 'DN
- QUIT
- WRITE ?34
- WRITE "Quantity"
- +25 if $X>45
- DO N
- if 'DN
- QUIT
- WRITE ?45
- WRITE "Units"
- +26 if $X>53
- DO N
- if 'DN
- QUIT
- WRITE ?53
- WRITE "Cost"
- +27 if $X>63
- DO N
- if 'DN
- QUIT
- WRITE ?63
- WRITE "Total Cost"
- +28 if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- SET X="="
- SET DIP(1)=X
- SET X=80
- 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
- +29 SET I(1)=101
- SET J(1)=430.02
- FOR D1=0:0
- if $ORDER(^PRCA(430,D0,101,D1))'>0
- QUIT
- if $DATA(DSC(430.02))
- XECUTE DSC(430.02)
- SET D1=$ORDER(^(D1))
- if D1'>0
- QUIT
- if $X>11
- DO T
- if 'DN
- QUIT
- DO A1
- +30 GOTO A1R
- A1 ;
- +1 if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- SET DIP(1)=$SELECT($DATA(^PRCA(430,D0,101,D1,0)):^(0),1:"")
- SET X=$PIECE(DIP(1),U,1)
- if X
- SET X=$EXTRACT(X,4,5)_"/"_$EXTRACT(X,6,7)_"/"_(1700+$EXTRACT(X,1,3))
- KILL DIP
- if DN
- KILL Y
- WRITE X
- +2 if $X>34
- DO N
- if 'DN
- QUIT
- WRITE ?34
- XECUTE DXS(3,9)
- KILL DIP
- if DN
- KILL Y
- WRITE X
- +3 SET X=$GET(^PRCA(430,D0,101,D1,0))
- if $X>45
- DO N
- if 'DN
- QUIT
- WRITE ?45
- SET Y=$PIECE(X,U,5)
- SET Y=$SELECT(Y="":Y,$DATA(^PRCD(420.5,Y,0))#2:$PIECE(^(0),U,1),1:Y)
- WRITE $EXTRACT(Y,1,5)
- +4 if $X>53
- DO N
- if 'DN
- QUIT
- WRITE ?53
- SET DIP(1)=$SELECT($DATA(^PRCA(430,D0,101,D1,0)):^(0),1:"")
- SET X=$PIECE(DIP(1),U,4)
- SET DIP(2)=X
- SET X=1
- SET DIP(3)=X
- SET X=4
- SET X=$JUSTIFY(DIP(2),DIP(3),X)
- KILL DIP
- if DN
- KILL Y
- WRITE X
- +5 if $X>63
- DO N
- if 'DN
- QUIT
- WRITE ?63
- SET DIP(1)=$SELECT($DATA(^PRCA(430,D0,101,D1,0)):^(0),1:"")
- SET X=$PIECE(DIP(1),U,6)
- SET DIP(2)=X
- SET X=1
- SET DIP(3)=X
- SET X=2
- SET X=$JUSTIFY(DIP(2),DIP(3),X)
- KILL DIP
- if DN
- KILL Y
- WRITE X
- +6 SET I(2)=1
- SET J(2)=430.22
- FOR D2=0:0
- if $ORDER(^PRCA(430,D0,101,D1,1,D2))'>0
- QUIT
- SET D2=$ORDER(^(D2))
- if $X>74
- DO T
- if 'DN
- QUIT
- DO A2
- +7 GOTO A2R
- A2 ;
- +1 SET X=$GET(^PRCA(430,D0,101,D1,1,D2,0))
- SET DIWL=12
- SET DIWR=78
- DO ^DIWP
- +2 QUIT
- A2R ;
- +1 DO A^DIWW
- +2 QUIT
- A1R ;
- +1 KILL Y
- KILL DIWF
- +2 QUIT
- HEAD ;
- +1 WRITE !,"--------------------------------------------------------------------------------",!!