PRCATP3 ; GENERATED FROM 'PRCA VENDOR PROFILE' PRINT TEMPLATE (#428) ; 05/04/10 ; (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 M DXS=^DIPT(428,"DXS")
S I(0)="^PRCA(430,",J(0)=430
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 " ACCOUNTS RECEIVABLE PROFILE"
D N:$X>0 Q:'DN W ?0 S X="=",DIP(1)=$G(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 "NAME: "
S X=$G(^PRCA(430,D0,0)) 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)
D N:$X>39 Q:'DN W ?39 W "BILL #: "
W ?0,$E($P(X,U,1),1,30)
W ?49 D EN2^PRCADR1 K DIP K:DN Y
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W "CURRENT STATUS: "
S X=$G(^PRCA(430,D0,0)) S Y=$P(X,U,8) S Y=$S(Y="":Y,$D(^PRCA(430.3,Y,0))#2:$P(^(0),U),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: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
W ?61 D EN1^PRCADR1 K DIP K:DN Y
D T Q:'DN W ?2 D EN3^PRCADR K DIP K:DN Y
W ?13 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 "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
D N:$X>0 Q:'DN W ?0 W " "
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 W "================================================================================"
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>82 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(2,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: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)=$G(X) S X=0,DIP(3)=$G(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)=$G(X) S X=0,DIP(3)=$G(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 0^DIWW
D ^DIWW
Q
A1R ;
D T Q:'DN W ?2 D EN4^PRCADR1 K DIP K:DN Y
W ?13 Q:'$D(PRCA("WROFF")) K DXS S D0=PRCA("WROFF") D ^PRCATW1 K DXS K DIP K:DN Y
K Y K DIWF
Q
HEAD ;
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCATP3 3785 printed Dec 13, 2024@01:41:43 Page 2
PRCATP3 ; GENERATED FROM 'PRCA VENDOR PROFILE' PRINT TEMPLATE (#428) ; 05/04/10 ; (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
MERGE DXS=^DIPT(428,"DXS")
+3 SET I(0)="^PRCA(430,"
SET J(0)=430
+4 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
+5 WRITE ?20
WRITE " ACCOUNTS RECEIVABLE PROFILE"
+6 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET X="="
SET DIP(1)=$GET(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
+7 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "NAME: "
+8 SET X=$GET(^PRCA(430,D0,0))
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)
+9 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "BILL #: "
+10 WRITE ?0,$EXTRACT($PIECE(X,U,1),1,30)
+11 WRITE ?49
DO EN2^PRCADR1
KILL DIP
if DN
KILL Y
+12 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "CURRENT STATUS: "
+13 SET X=$GET(^PRCA(430,D0,0))
SET Y=$PIECE(X,U,8)
SET Y=$SELECT(Y="":Y,$DATA(^PRCA(430.3,Y,0))#2:$PIECE(^(0),U),1:Y)
WRITE $EXTRACT(Y,1,30)
+14 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "CATEGORY: "
+15 SET Y=$PIECE(X,U,2)
SET Y=$SELECT(Y="":Y,$DATA(^PRCA(430.2,Y,0))#2:$PIECE(^(0),U),1:Y)
WRITE $EXTRACT(Y,1,30)
+16 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "CP: "
+17 SET X=$GET(^PRCA(430,D0,11))
WRITE ?0,$EXTRACT($PIECE(X,U,1),1,15)
+18 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "FUND (APPROPRIATION): "
+19 WRITE ?0,$EXTRACT($PIECE(X,U,17),1,6)
+20 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "DATE BILL PREPARED: "
+21 SET X=$GET(^PRCA(430,D0,0))
SET Y=$PIECE(X,U,10)
DO DT
+22 WRITE ?61
DO EN1^PRCADR1
KILL DIP
if DN
KILL Y
+23 DO T
if 'DN
QUIT
WRITE ?2
DO EN3^PRCADR
KILL DIP
if DN
KILL Y
+24 WRITE ?13
DO EN5^PRCADR
if $DATA(PRCA("HALT"))
QUIT
WRITE ""
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 "TRANSACTIONS: "
+26 WRITE ?16
DO EN2^PRCADR
KILL DIP
if DN
KILL Y
+27 WRITE ?27
if $DATA(PRCA("HALT"))
QUIT
WRITE ""
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 "BILL RESULTING FROM: "
+29 WRITE ?23
XECUTE DXS(1,9)
KILL DIP
if DN
KILL Y
+30 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE " "
+31 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "Date"
+32 if $X>11
DO N
if 'DN
QUIT
WRITE ?11
WRITE "Description"
+33 if $X>34
DO N
if 'DN
QUIT
WRITE ?34
WRITE "Quantity"
+34 if $X>45
DO N
if 'DN
QUIT
WRITE ?45
WRITE "Units"
+35 if $X>53
DO N
if 'DN
QUIT
WRITE ?53
WRITE "Cost"
+36 if $X>63
DO N
if 'DN
QUIT
WRITE ?63
WRITE "Total Cost"
+37 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "================================================================================"
+38 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>82
DO T
if 'DN
QUIT
DO A1
+39 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(2,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: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)=$GET(X)
SET X=0
SET DIP(3)=$GET(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)=$GET(X)
SET X=0
SET DIP(3)=$GET(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 0^DIWW
+2 DO ^DIWW
+3 QUIT
A1R ;
+1 DO T
if 'DN
QUIT
WRITE ?2
DO EN4^PRCADR1
KILL DIP
if DN
KILL Y
+2 WRITE ?13
if '$DATA(PRCA("WROFF"))
QUIT
KILL DXS
SET D0=PRCA("WROFF")
DO ^PRCATW1
KILL DXS
KILL DIP
if DN
KILL Y
+3 KILL Y
KILL DIWF
+4 QUIT
HEAD ;
+1 WRITE !,"--------------------------------------------------------------------------------",!!