- ONCOXCL ; GENERATED FROM 'ONCO XCONTACT LIST' PRINT TEMPLATE (#793) ; 10/06/10 ; (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(793,"DXS")
- S I(0)="^ONCO(160,",J(0)=160
- D T Q:'DN D N D N:$X>9 Q:'DN W ?9 W "AVAILABLE CONTACTS"
- D N:$X>9 Q:'DN W ?9 W "=================="
- S I(1)="""C""",J(1)=160.03 F D1=0:0 Q:$O(^ONCO(160,D0,"C",D1))'>0 X:$D(DSC(160.03)) DSC(160.03) S D1=$O(^(D1)) Q:D1'>0 D:$X>29 T Q:'DN D A1
- G A1R
- A1 ;
- D N:$X>0 Q:'DN W ?0 W " "
- S X=$G(^ONCO(160,D0,"C",D1,0)) D N:$X>9 Q:'DN W ?9 S Y=$P(X,U,1) W:Y]"" $S($D(DXS(2,Y)):DXS(2,Y),1:Y)
- S I(100)="^ONCO(165,",J(100)=165 S I(1,0)=D1 S I(0,0)=D0 S DIP(1)=$S($D(^ONCO(160,D0,"C",D1,0)):^(0),1:"") S X=$P(DIP(1),U,2),X=X S D(0)=+X S D0=D(0) I D0>0 D A2
- G A2R
- A2 ;
- S X=$G(^ONCO(165,D0,0)) D N:$X>29 Q:'DN W ?29,$E($P(X,U,4),1,50)
- D N:$X>29 Q:'DN W ?29,$E($P(X,U,1),1,30)
- S X=$G(^ONCO(165,D0,.13)) D N:$X>29 Q:'DN W ?29,$E($P(X,U,1),1,20)
- D N:$X>29 Q:'DN W ?29,$E($P(X,U,2),1,20)
- D N:$X>29 Q:'DN W ?29,$E($P(X,U,3),1,20)
- D N:$X>29 Q:'DN W ?29,$E($P(X,U,4),1,20)
- S X=$G(^ONCO(165,D0,.11)) D N:$X>29 Q:'DN W ?29,$E($P(X,U,1),1,30)
- D N:$X>29 Q:'DN W ?29,$E($P(X,U,2),1,30)
- D N:$X>29 Q:'DN W ?29,$E($P(X,U,3),1,30)
- D N:$X>29 Q:'DN W ?29 S Y=$P(X,U,9) S Y(0)=Y S Y=$S(Y="":Y,$D(^VIC(5.11,Y,0))#2:$P(^(0),U,2)_","_$P(^DIC(5,$P(^VIC(5.1,$P(^VIC(5.11,Y,0),U,3),0),U,2),0),U,2)_" "_$P(^VIC(5.11,Y,0),U,1),1:"") W $E(Y,1,30)
- D N:$X>0 Q:'DN W ?0 W " "
- Q
- A2R ;
- K J(100),I(100) S:$D(I(0,0)) D0=I(0,0) S:$D(I(1,0)) D1=I(1,0)
- Q
- A1R ;
- D N:$X>0 Q:'DN W ?0 W " "
- X DXS(1,9) K DIP K:DN Y W X
- K Y
- Q
- HEAD ;
- W !,"--------------------------------------------------------------------------------",!!
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HONCOXCL 2231 printed Jan 18, 2025@03:27:42 Page 2
- ONCOXCL ; GENERATED FROM 'ONCO XCONTACT LIST' PRINT TEMPLATE (#793) ; 10/06/10 ; (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(793,"DXS")
- +3 SET I(0)="^ONCO(160,"
- SET J(0)=160
- +4 DO T
- if 'DN
- QUIT
- DO N
- if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- WRITE "AVAILABLE CONTACTS"
- +5 if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- WRITE "=================="
- +6 SET I(1)="""C"""
- SET J(1)=160.03
- FOR D1=0:0
- if $ORDER(^ONCO(160,D0,"C",D1))'>0
- QUIT
- if $DATA(DSC(160.03))
- XECUTE DSC(160.03)
- SET D1=$ORDER(^(D1))
- if D1'>0
- QUIT
- if $X>29
- DO T
- if 'DN
- QUIT
- DO A1
- +7 GOTO A1R
- A1 ;
- +1 if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- WRITE " "
- +2 SET X=$GET(^ONCO(160,D0,"C",D1,0))
- if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- SET Y=$PIECE(X,U,1)
- if Y]""
- WRITE $SELECT($DATA(DXS(2,Y)):DXS(2,Y),1:Y)
- +3 SET I(100)="^ONCO(165,"
- SET J(100)=165
- SET I(1,0)=D1
- SET I(0,0)=D0
- SET DIP(1)=$SELECT($DATA(^ONCO(160,D0,"C",D1,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 A2
- +4 GOTO A2R
- A2 ;
- +1 SET X=$GET(^ONCO(165,D0,0))
- if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,4),1,50)
- +2 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,1),1,30)
- +3 SET X=$GET(^ONCO(165,D0,.13))
- if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,1),1,20)
- +4 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,2),1,20)
- +5 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,3),1,20)
- +6 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,4),1,20)
- +7 SET X=$GET(^ONCO(165,D0,.11))
- if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,1),1,30)
- +8 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,2),1,30)
- +9 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29,$EXTRACT($PIECE(X,U,3),1,30)
- +10 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29
- SET Y=$PIECE(X,U,9)
- SET Y(0)=Y
- SET Y=$SELECT(Y="":Y,$DATA(^VIC(5.11,Y,0))#2:$PIECE(^(0),U,2)_","_$PIECE(^DIC(5,$PIECE(^VIC(5.1,$PIECE(^VIC(5.11,Y,0),U,3),0),U,2),0),U,2)_" "_$PIECE(^VIC(5.11,Y,0),U,1),1:"")
- WRITE $EXTRACT(Y,1,30)
- +11 if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- WRITE " "
- +12 QUIT
- A2R ;
- +1 KILL J(100),I(100)
- if $DATA(I(0,0))
- SET D0=I(0,0)
- if $DATA(I(1,0))
- SET D1=I(1,0)
- +2 QUIT
- A1R ;
- +1 if $X>0
- DO N
- if 'DN
- QUIT
- WRITE ?0
- WRITE " "
- +2 XECUTE DXS(1,9)
- KILL DIP
- if DN
- KILL Y
- WRITE X
- +3 KILL Y
- +4 QUIT
- HEAD ;
- +1 WRITE !,"--------------------------------------------------------------------------------",!!