PRCATP9 ; GENERATED FROM 'PRCAT NEW TRANS' PRINT TEMPLATE (#399) ; 10/02/99 ; (FILE 433, 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)
S I(0)="^PRCA(433,",J(0)=433
D N:$X>0 Q:'DN W ?0 S X="=",DIP(1)=X S X=79,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 "TRANSACTION NO.:"
S X=$G(^PRCA(433,D0,0)) S Y=$P(X,U,1) W:Y]"" $J(Y,7,0)
D N:$X>0 Q:'DN W ?0 W "BILL NO.: "
D N:$X>14 Q:'DN W ?14 S Y=$P(X,U,2) S Y=$S(Y="":Y,$D(^PRCA(430,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
W ?14 S PRCABN=$P(X,U,2) K DIP K:DN Y
S I(100)="^PRCA(430,",J(100)=430 S I(0,0)=D0 S DIP(1)=$S($D(^PRCA(433,D0,0)):^(0),1:"") S X=$P(DIP(1),U,2),X=X S D(0)=+X S D0=D(0) I D0>0 D A1
G A1R
A1 ;
D N:$X>39 Q:'DN W ?39 S DIP(101)=$S($D(^PRCA(430,D0,0)):^(0),1:"") S X="CATEGORY: "_$S('$D(^PRCA(430.2,+$P(DIP(101),U,2),0)):"",1:$P(^(0),U,1)) K DIP K:DN Y W $E(X,1,25)
Q
A1R ;
K J(100),I(100) S:$D(I(0,0)) D0=I(0,0)
D N:$X>0 Q:'DN W ?0 W "TRANS.DATE: "
S X=$G(^PRCA(433,D0,1)) D N:$X>14 Q:'DN W ?14 S Y=$P(X,U,1) D DT
D N:$X>39 Q:'DN W ?39 W "TRANS.TYPE: "
D N:$X>52 Q:'DN W ?52 S Y=$P(X,U,2) S Y=$S(Y="":Y,$D(^PRCA(430.3,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,20)
D T Q:'DN D N D N:$X>1 Q:'DN W ?1 W "FY"
D N:$X>9 Q:'DN W ?9 W "APPROP.SYMBOL"
D N:$X>29 Q:'DN W ?29 W "TRANS.AMOUNT"
S I(1)=4,J(1)=433.01 F D1=0:0 Q:$O(^PRCA(433,D0,4,D1))'>0 X:$D(DSC(433.01)) DSC(433.01) S D1=$O(^(D1)) Q:D1'>0 D:$X>43 T Q:'DN D B1
G B1R
B1 ;
S X=$G(^PRCA(433,D0,4,D1,0)) D N:$X>0 Q:'DN W ?0,$E($P(X,U,1),1,30)
W ?32 D APPR^PRCALM K DIP K:DN Y
S X=$G(^PRCA(433,D0,4,D1,0)) D N:$X>29 Q:'DN W ?29 S Y=$P(X,U,5) W:Y]"" $J(Y,10,2)
Q
B1R ;
D N:$X>0 Q:'DN W ?0 S X="=",DIP(1)=X S X=79,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
K Y
Q
HEAD ;
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCATP9 2430 printed Dec 13, 2024@01:41:48 Page 2
PRCATP9 ; GENERATED FROM 'PRCAT NEW TRANS' PRINT TEMPLATE (#399) ; 10/02/99 ; (FILE 433, 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 SET I(0)="^PRCA(433,"
SET J(0)=433
+3 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET X="="
SET DIP(1)=X
SET X=79
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
+4 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "TRANSACTION NO.:"
+5 SET X=$GET(^PRCA(433,D0,0))
SET Y=$PIECE(X,U,1)
if Y]""
WRITE $JUSTIFY(Y,7,0)
+6 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "BILL NO.: "
+7 if $X>14
DO N
if 'DN
QUIT
WRITE ?14
SET Y=$PIECE(X,U,2)
SET Y=$SELECT(Y="":Y,$DATA(^PRCA(430,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+8 WRITE ?14
SET PRCABN=$PIECE(X,U,2)
KILL DIP
if DN
KILL Y
+9 SET I(100)="^PRCA(430,"
SET J(100)=430
SET I(0,0)=D0
SET DIP(1)=$SELECT($DATA(^PRCA(433,D0,0)):^(0),1:"")
SET X=$PIECE(DIP(1),U,2)
SET X=X
SET D(0)=+X
SET D0=D(0)
IF D0>0
DO A1
+10 GOTO A1R
A1 ;
+1 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
SET DIP(101)=$SELECT($DATA(^PRCA(430,D0,0)):^(0),1:"")
SET X="CATEGORY: "_$SELECT('$DATA(^PRCA(430.2,+$PIECE(DIP(101),U,2),0)):"",1:$PIECE(^(0),U,1))
KILL DIP
if DN
KILL Y
WRITE $EXTRACT(X,1,25)
+2 QUIT
A1R ;
+1 KILL J(100),I(100)
if $DATA(I(0,0))
SET D0=I(0,0)
+2 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "TRANS.DATE: "
+3 SET X=$GET(^PRCA(433,D0,1))
if $X>14
DO N
if 'DN
QUIT
WRITE ?14
SET Y=$PIECE(X,U,1)
DO DT
+4 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "TRANS.TYPE: "
+5 if $X>52
DO N
if 'DN
QUIT
WRITE ?52
SET Y=$PIECE(X,U,2)
SET Y=$SELECT(Y="":Y,$DATA(^PRCA(430.3,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,20)
+6 DO T
if 'DN
QUIT
DO N
if $X>1
DO N
if 'DN
QUIT
WRITE ?1
WRITE "FY"
+7 if $X>9
DO N
if 'DN
QUIT
WRITE ?9
WRITE "APPROP.SYMBOL"
+8 if $X>29
DO N
if 'DN
QUIT
WRITE ?29
WRITE "TRANS.AMOUNT"
+9 SET I(1)=4
SET J(1)=433.01
FOR D1=0:0
if $ORDER(^PRCA(433,D0,4,D1))'>0
QUIT
if $DATA(DSC(433.01))
XECUTE DSC(433.01)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>43
DO T
if 'DN
QUIT
DO B1
+10 GOTO B1R
B1 ;
+1 SET X=$GET(^PRCA(433,D0,4,D1,0))
if $X>0
DO N
if 'DN
QUIT
WRITE ?0,$EXTRACT($PIECE(X,U,1),1,30)
+2 WRITE ?32
DO APPR^PRCALM
KILL DIP
if DN
KILL Y
+3 SET X=$GET(^PRCA(433,D0,4,D1,0))
if $X>29
DO N
if 'DN
QUIT
WRITE ?29
SET Y=$PIECE(X,U,5)
if Y]""
WRITE $JUSTIFY(Y,10,2)
+4 QUIT
B1R ;
+1 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET X="="
SET DIP(1)=X
SET X=79
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
+2 KILL Y
+3 QUIT
HEAD ;
+1 WRITE !,"--------------------------------------------------------------------------------",!!