DVBAXF ; GENERATED FROM 'DVBA FINALIZED REPORT' PRINT TEMPLATE (#519) ; 04/03/98 ; (FILE 396, MARGIN=132)
G BEGIN
CP G CP^DIO2
C S DQ(C)=Y
S S Q(C)=Y*Y+Q(C) S:L(C)>Y L(C)=Y S:H(C)<Y H(C)=Y
P S N(C)=N(C)+1
A S S(C)=S(C)+Y
Q
D I Y=DITTO(C) S Y="" Q
S DITTO(C)=Y
Q
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(519,"DXS",X)) Q:'X S Y=$O(^(X,"")) F X=X:0 Q:Y="" S DXS(X,Y)=^(Y),Y=$O(^(Y))
W ?0 X DXS(1,9) K DIP K:DN Y W X
D N:$X>17 Q:'DN W ?17 X DXS(2,9) K DIP K:DN Y W X
D N:$X>31 Q:'DN W ?31 S DIP(1)=$S($D(^DVB(396,D0,2)):^(2),1:"") S X=$P(DIP(1),U,7),DIP(2)=X S X=1,DIP(3)=X S X=15,X=$E(DIP(2),DIP(3),X) K DIP K:DN Y W X
D N:$X>49 Q:'DN W ?49 S DIP(1)=$S($D(^DVB(396,D0,1)):^(1),1:"") S X=$P(DIP(1),U,12),X1=X,X2=$P(DIP(1),U,1),X="" D:X2 ^%DTC:X1 K DIP K:DN Y W $E(X,1,9) K Y(396,-1) S Y=X,C=1 D A:Y'?."*"
D N:$X>62 Q:'DN W ?62 S DIP(1)=$S($D(^DVB(396,D0,1)):^(1),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>75 Q:'DN W ?75 S DIP(1)=$S($D(^DVB(396,D0,1)):^(1),1:"") S X=$P(DIP(1),U,12) S:X X=$E(X,4,5)_"/"_$E(X,6,7)_"/"_(1700+$E(X,1,3)) K DIP K:DN Y W X
S X=$G(^DVB(396,D0,2)) D N:$X>87 Q:'DN W ?87,$E($P(X,U,6),1,15)
K Y
Q
HEAD ;
W !,?49,"TOTAL"
W !,?0,"PATIENT",?31,"REQUESTING",?49,"DAYS TO",?62,"DATE OF",?75,"FINAL"
W !,?0,"NAME",?17,"SSN",?31,"VARO",?49,"PROCESS",?62,"REQUEST",?75,"DATE",?87,"FINALIZED BY"
W !,"------------------------------------------------------------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HDVBAXF 2058 printed Dec 13, 2024@01:42:51 Page 2
DVBAXF ; GENERATED FROM 'DVBA FINALIZED REPORT' PRINT TEMPLATE (#519) ; 04/03/98 ; (FILE 396, MARGIN=132)
+1 GOTO BEGIN
CP GOTO CP^DIO2
C SET DQ(C)=Y
S SET Q(C)=Y*Y+Q(C)
if L(C)>Y
SET L(C)=Y
if H(C)<Y
SET H(C)=Y
P SET N(C)=N(C)+1
A SET S(C)=S(C)+Y
+1 QUIT
D IF Y=DITTO(C)
SET Y=""
QUIT
+1 SET DITTO(C)=Y
+2 QUIT
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(519,"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
XECUTE DXS(1,9)
KILL DIP
if DN
KILL Y
WRITE X
+4 if $X>17
DO N
if 'DN
QUIT
WRITE ?17
XECUTE DXS(2,9)
KILL DIP
if DN
KILL Y
WRITE X
+5 if $X>31
DO N
if 'DN
QUIT
WRITE ?31
SET DIP(1)=$SELECT($DATA(^DVB(396,D0,2)):^(2),1:"")
SET X=$PIECE(DIP(1),U,7)
SET DIP(2)=X
SET X=1
SET DIP(3)=X
SET X=15
SET X=$EXTRACT(DIP(2),DIP(3),X)
KILL DIP
if DN
KILL Y
WRITE X
+6 if $X>49
DO N
if 'DN
QUIT
WRITE ?49
SET DIP(1)=$SELECT($DATA(^DVB(396,D0,1)):^(1),1:"")
SET X=$PIECE(DIP(1),U,12)
SET X1=X
SET X2=$PIECE(DIP(1),U,1)
SET X=""
if X2
if X1
DO ^%DTC
KILL DIP
if DN
KILL Y
WRITE $EXTRACT(X,1,9)
KILL Y(396,-1)
SET Y=X
SET C=1
if Y'?."*"
DO A
+7 if $X>62
DO N
if 'DN
QUIT
WRITE ?62
SET DIP(1)=$SELECT($DATA(^DVB(396,D0,1)):^(1),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
+8 if $X>75
DO N
if 'DN
QUIT
WRITE ?75
SET DIP(1)=$SELECT($DATA(^DVB(396,D0,1)):^(1),1:"")
SET X=$PIECE(DIP(1),U,12)
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
+9 SET X=$GET(^DVB(396,D0,2))
if $X>87
DO N
if 'DN
QUIT
WRITE ?87,$EXTRACT($PIECE(X,U,6),1,15)
+10 KILL Y
+11 QUIT
HEAD ;
+1 WRITE !,?49,"TOTAL"
+2 WRITE !,?0,"PATIENT",?31,"REQUESTING",?49,"DAYS TO",?62,"DATE OF",?75,"FINAL"
+3 WRITE !,?0,"NAME",?17,"SSN",?31,"VARO",?49,"PROCESS",?62,"REQUEST",?75,"DATE",?87,"FINALIZED BY"
+4 WRITE !,"------------------------------------------------------------------------------------------------------------------------------------",!!