ONCOXPU ; GENERATED FROM 'ONCO XPATIENT STATUS' PRINT TEMPLATE (#1340) ; 05/26/06 ; (FILE 160, 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(1340,"DXS")
S I(0)="^ONCO(160,",J(0)=160
D N:$X>5 Q:'DN W ?5 W "Patient: "
S X=$G(^ONCO(160,D0,0)) D N:$X>14 Q:'DN W ?14 S Y=$P(X,U,1) S C=$P(^DD(160,.01,0),U,2) D Y^DIQ:Y S C="," W $E(Y,1,26)
D N:$X>43 Q:'DN W ?43 W "Date Last Contact: "
D N:$X>62 Q:'DN W ?62 S X="" D DLC^ONCOCRF,DATEOT^ONCOES W $E(X,1,12) K Y(160,16)
D N:$X>5 Q:'DN W ?5 W "Status: "
S X=$G(^ONCO(160,D0,1)) D N:$X>14 Q:'DN W ?14 S Y=$P(X,U,1) W:Y]"" $S($D(DXS(1,Y)):DXS(1,Y),1:Y)
D N:$X>43 Q:'DN W ?43 W "Follow-up Status: "
D N:$X>62 Q:'DN W ?62 S Y=$P(X,U,7) W:Y]"" $S($D(DXS(2,Y)):DXS(2,Y),1:Y)
K Y
Q
HEAD ;
W !,?14,"NAME"
W !,?62,"DATE LAST"
W !,?62,"CONTACT"
W !,?62,"FOLLOW-UP"
W !,?14,"STATUS",?62,"STATUS"
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HONCOXPU 1469 printed Dec 13, 2024@02:26:37 Page 2
ONCOXPU ; GENERATED FROM 'ONCO XPATIENT STATUS' PRINT TEMPLATE (#1340) ; 05/26/06 ; (FILE 160, 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(1340,"DXS")
+3 SET I(0)="^ONCO(160,"
SET J(0)=160
+4 if $X>5
DO N
if 'DN
QUIT
WRITE ?5
WRITE "Patient: "
+5 SET X=$GET(^ONCO(160,D0,0))
if $X>14
DO N
if 'DN
QUIT
WRITE ?14
SET Y=$PIECE(X,U,1)
SET C=$PIECE(^DD(160,.01,0),U,2)
if Y
DO Y^DIQ
SET C=","
WRITE $EXTRACT(Y,1,26)
+6 if $X>43
DO N
if 'DN
QUIT
WRITE ?43
WRITE "Date Last Contact: "
+7 if $X>62
DO N
if 'DN
QUIT
WRITE ?62
SET X=""
DO DLC^ONCOCRF
DO DATEOT^ONCOES
WRITE $EXTRACT(X,1,12)
KILL Y(160,16)
+8 if $X>5
DO N
if 'DN
QUIT
WRITE ?5
WRITE "Status: "
+9 SET X=$GET(^ONCO(160,D0,1))
if $X>14
DO N
if 'DN
QUIT
WRITE ?14
SET Y=$PIECE(X,U,1)
if Y]""
WRITE $SELECT($DATA(DXS(1,Y)):DXS(1,Y),1:Y)
+10 if $X>43
DO N
if 'DN
QUIT
WRITE ?43
WRITE "Follow-up Status: "
+11 if $X>62
DO N
if 'DN
QUIT
WRITE ?62
SET Y=$PIECE(X,U,7)
if Y]""
WRITE $SELECT($DATA(DXS(2,Y)):DXS(2,Y),1:Y)
+12 KILL Y
+13 QUIT
HEAD ;
+1 WRITE !,?14,"NAME"
+2 WRITE !,?62,"DATE LAST"
+3 WRITE !,?62,"CONTACT"
+4 WRITE !,?62,"FOLLOW-UP"
+5 WRITE !,?14,"STATUS",?62,"STATUS"
+6 WRITE !,"--------------------------------------------------------------------------------",!!