SDXLST ; GENERATED FROM 'SD-AMB-PROC-LIST' PRINT TEMPLATE (#231) ; 06/13/96 ; (FILE 409.72, 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 F X=0:0 S X=$O(^DIPT(231,"DXS",X)) Q:'X S Y=$O(^(X,"")) F X=X:0 Q:Y="" S DXS(X,Y)=^(Y),Y=$O(^(Y))
S X=$G(^SD(409.72,D0,0)) D N:$X>0 Q:'DN W ?0 S Y=$P(X,U,2) S Y=$S(Y="":Y,$D(^SD(409.71,Y,0))#2:$P(^(0),U,1),1:Y) S Y=$S(Y="":Y,$D(^ICPT(Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,5)
X $P(^DD(409.72,.025,0),U,5,99) S DIP(1)=X S X=" - "_DIP(1) K DIP K:DN Y W X
D N:$X>41 Q:'DN W ?41 S DIP(2)=$S($D(^SD(409.72,D0,0)):^(0),1:"") S X=" ",DIP(1)=X S X=$P(DIP(2),U,4),X=X S Y=X,X=DIP(1),X=X S X=X_Y K DIP K:DN Y W X
S X=$G(^SD(409.72,D0,0)) D N:$X>54 Q:'DN W ?54 S Y=$P(X,U,5) W:Y]"" $S($D(DXS(2,Y)):DXS(2,Y),1:Y)
S DICMX="D L^DIWP" D T Q:'DN D N D N:$X>2 Q:'DN S DIWL=3,DIWR=78 X DXS(1,9.3) S DIP(101)=$S($D(^SD(409.71,D0,0)):^(0),1:""),D0=$P(DIP(101),U,1) S:'$D(^ICPT(+D0,0)) D0=-1 X DXS(1,9.2):D0>0 S X="" S D0=I(0,0) K DIP K:DN Y
D A^DIWW
D T Q:'DN D N W ?0 W ""
D N:$X>19 Q:'DN W ?19 W "RAM Reimbursement: "
S %=$O(^SD(409.82,"AIVDT",+$P(^SD(409.72,D0,0),U,4),(9999998-$S($D(SDEFDT):SDEFDT,1:^(0))))) S X=$S('%:0,$D(^SD(409.82,+$O(^(%,0)),0)):$P(^(0),U,3),1:0) S X=$J(X,0,2) W:X'?."*" $J(X,7,2) K Y(409.72,203)
D N:$X>19 Q:'DN W ?19 W " Local Cost: "
S X=$G(^SD(409.72,D0,0)) S Y=$P(X,U,6) W:Y]"" $J(Y,7,2)
D N:$X>52 Q:'DN W ?52 W "Effective Date: "
S Y=$P(X,U,1) D DT
D N:$X>0 Q:'DN W ?0 S X="-",DIP(1)=X,DIP(2)=X,X=$S($D(IOM):IOM,1:80) S X=X,X1=DIP(1) S %=X1 X:%]"" "F X=X:0 S %=%_X1 Q:$L(%)>X" S X=$E(%,1,X) K DIP K:DN Y W X
K Y K DIWF
Q
HEAD ;
W !,?0,"CPT/HCPCS"
W !,?0,"CODE",?41,"RAM GROUP",?54,"STATUS"
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSDXLST 2284 printed Dec 13, 2024@03:03:37 Page 2
SDXLST ; GENERATED FROM 'SD-AMB-PROC-LIST' PRINT TEMPLATE (#231) ; 06/13/96 ; (FILE 409.72, 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
FOR X=0:0
SET X=$ORDER(^DIPT(231,"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 SET X=$GET(^SD(409.72,D0,0))
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET Y=$PIECE(X,U,2)
SET Y=$SELECT(Y="":Y,$DATA(^SD(409.71,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET Y=$SELECT(Y="":Y,$DATA(^ICPT(Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,5)
+4 XECUTE $PIECE(^DD(409.72,.025,0),U,5,99)
SET DIP(1)=X
SET X=" - "_DIP(1)
KILL DIP
if DN
KILL Y
WRITE X
+5 if $X>41
DO N
if 'DN
QUIT
WRITE ?41
SET DIP(2)=$SELECT($DATA(^SD(409.72,D0,0)):^(0),1:"")
SET X=" "
SET DIP(1)=X
SET X=$PIECE(DIP(2),U,4)
SET X=X
SET Y=X
SET X=DIP(1)
SET X=X
SET X=X_Y
KILL DIP
if DN
KILL Y
WRITE X
+6 SET X=$GET(^SD(409.72,D0,0))
if $X>54
DO N
if 'DN
QUIT
WRITE ?54
SET Y=$PIECE(X,U,5)
if Y]""
WRITE $SELECT($DATA(DXS(2,Y)):DXS(2,Y),1:Y)
+7 SET DICMX="D L^DIWP"
DO T
if 'DN
QUIT
DO N
if $X>2
DO N
if 'DN
QUIT
SET DIWL=3
SET DIWR=78
XECUTE DXS(1,9.3)
SET DIP(101)=$SELECT($DATA(^SD(409.71,D0,0)):^(0),1:"")
SET D0=$PIECE(DIP(101),U,1)
if '$DATA(^ICPT(+D0,0))
SET D0=-1
if D0>0
XECUTE DXS(1,9.2)
SET X=""
SET D0=I(0,0)
KILL DIP
if DN
KILL Y
+8 DO A^DIWW
+9 DO T
if 'DN
QUIT
DO N
WRITE ?0
WRITE ""
+10 if $X>19
DO N
if 'DN
QUIT
WRITE ?19
WRITE "RAM Reimbursement: "
+11 SET %=$ORDER(^SD(409.82,"AIVDT",+$PIECE(^SD(409.72,D0,0),U,4),(9999998-$SELECT($DATA(SDEFDT):SDEFDT,1:^(0)))))
SET X=$SELECT('%:0,$DATA(^SD(409.82,+$ORDER(^(%,0)),0)):$PIECE(^(0),U,3),1:0)
SET X=$JUSTIFY(X,0,2)
if X'?."*"
WRITE $JUSTIFY(X,7,2)
KILL Y(409.72,203)
+12 if $X>19
DO N
if 'DN
QUIT
WRITE ?19
WRITE " Local Cost: "
+13 SET X=$GET(^SD(409.72,D0,0))
SET Y=$PIECE(X,U,6)
if Y]""
WRITE $JUSTIFY(Y,7,2)
+14 if $X>52
DO N
if 'DN
QUIT
WRITE ?52
WRITE "Effective Date: "
+15 SET Y=$PIECE(X,U,1)
DO DT
+16 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET X="-"
SET DIP(1)=X
SET DIP(2)=X
SET X=$SELECT($DATA(IOM):IOM,1:80)
SET X=X
SET X1=DIP(1)
SET %=X1
if %]""
XECUTE "F X=X:0 S %=%_X1 Q:$L(%)>X"
SET X=$EXTRACT(%,1,X)
KILL DIP
if DN
KILL Y
WRITE X
+17 KILL Y
KILL DIWF
+18 QUIT
HEAD ;
+1 WRITE !,?0,"CPT/HCPCS"
+2 WRITE !,?0,"CODE",?41,"RAM GROUP",?54,"STATUS"
+3 WRITE !,"--------------------------------------------------------------------------------",!!