- SDMEAN ;ALB/TMP,BOK - TALLY OUTPATIENT VISITS FOR MEANS TEST TRACKING ; 28 JUL 86
- ;;5.3;Scheduling;**132**;Aug 13, 1993
- ;CALLED BY ^DGMT5; DFN,DGSD,DGED passed in; SD passed out
- EN K SDCP S SD="",$P(SD,"0",32)="",SDT=1,SDPCE=16
- F B=DGSD-.1:0 S B=$O(^DPT(DFN,"S",B)) Q:B=""!(B>(DGED_.9)) S SDAY=$P(B,".")#100 I $D(^(B,0)) S SDC=^(0) D T I 'SDIG,$P(SDC,U,2)']"",$D(^SC(+SDC,0)),$P(^(0),U,17)'="Y" D SDCP I 'SDCP,'$E(SD,SDAY),'SDNV D SET S B=$P(B,".")_.9
- ;
- S SDT=2,SD1=DGSD#100,SD2=DGED#100,SDPCE=10
- F B=SD1:1:SD2 I '$E(SD,B),'$D(SDCP(B)) D
- . S (A,SDOEDT)=DGSD\100*100+B D
- . F S SDOEDT=$O(^SCE("B",SDOEDT)) Q:'SDOEDT!($P(SDOEDT,".")'=A) D
- . . S SDOE=0
- . . F S SDOE=$O(^SCE("B",SDOEDT,SDOE)) Q:'SDOE D
- . . . S SDC=$G(^SCE(SDOE,0))
- . . . S SDPAR=+$P(SDC,U,6)
- . . . S SDORG=+$P(SDC,U,8)
- . . . ;
- . . . ; -- do checks
- . . . IF SDPAR Q ; -- must not have a parent
- . . . IF SDORG'=2 ; -- must be a/e
- . . . ;
- . . . D ELIG
- . . . IF $T D
- . . . . S SDAY=B
- . . . . D T
- . . . . IF 'SDIG D SET
- ;
- S SDT=3,SD1=9999999-(DGED_.9),SD2=9999999-(DGSD_.9) F B=SD1:0 S B=$O(^DPT(DFN,"DIS",B)) Q:B>SD2!(B="") I $D(^DPT(DFN,"DIS",B,0)),$P(^(0),"^",2)'=2 S C=$P(9999999-B,".") I '$E(SD,C#100),'$D(SDCP(C#100)) S SDAY=C#100,POP=0 D DISP D:'POP SET
- K A,B,C,D,E,SD1,SD2,SDAP,SDAY,SDC,SDCP,SDT,SDIG,SDPCE,SDISP,SDNV,SDSC Q
- SET S SD=$E(SD,1,SDAY-1)_SDT_$E(SD,SDAY+1,31) Q
- DISP S SDISP=+$P(^DPT(DFN,"DIS",B,0),"^",7),SDISP=$S($D(^DIC(37,SDISP,0)):$P(^(0),"^"),1:"")
- Q:SDISP']"" I SDISP["DEAD"!(SDISP["CANCEL")!(SDISP["FAILED TO COOP")!(SDISP["INELIGIBLE") S POP=1
- Q
- SDCP S SDNV=0 I $P(SDC,"^",7)=1 S SDCP(B)="",SDT=0,SDCP=1,B=$P(B,".")_.9 D SET Q
- S SDCP=0
- I $D(^SC(+SDC,"S",B)) F S=0:0 S S=$O(^SC(+SDC,"S",B,1,S)) Q:S="" I +^(S,0)=DFN S SDAP=^(0) I $P(SDAP,U,9)']"",$P(SDAP,U,10),$P(^DIC(8,$P(SDAP,U,10),0),U,5)="N" S SDNV=1 Q
- K SDCL,S Q
- T S SDIG=$P(SDC,U,SDPCE),SDIG=$S($D(^SD(409.1,+SDIG,0)):$P(^(0),U,2),1:0)
- Q
- ELIG I "NSC"[$S('$D(^DIC(8,+$P(SDC,U,13),0)):$P(SDC,U,13),$D(^DIC(8.1,+$P(^(0),U,9),0)):$P(^(0),U),1:$P(SDC,U,13))
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSDMEAN 2108 printed Mar 13, 2025@22:03:40 Page 2
- SDMEAN ;ALB/TMP,BOK - TALLY OUTPATIENT VISITS FOR MEANS TEST TRACKING ; 28 JUL 86
- +1 ;;5.3;Scheduling;**132**;Aug 13, 1993
- +2 ;CALLED BY ^DGMT5; DFN,DGSD,DGED passed in; SD passed out
- EN KILL SDCP
- SET SD=""
- SET $PIECE(SD,"0",32)=""
- SET SDT=1
- SET SDPCE=16
- +1 FOR B=DGSD-.1:0
- SET B=$ORDER(^DPT(DFN,"S",B))
- if B=""!(B>(DGED_.9))
- QUIT
- SET SDAY=$PIECE(B,".")#100
- IF $DATA(^(B,0))
- SET SDC=^(0)
- DO T
- IF 'SDIG
- IF $PIECE(SDC,U,2)']""
- IF $DATA(^SC(+SDC,0))
- IF $PIECE(^(0),U,17)'="Y"
- DO SDCP
- IF 'SDCP
- IF '$EXTRACT(SD,SDAY)
- IF 'SDNV
- DO SET
- SET B=$PIECE(B,".")_.9
- +2 ;
- +3 SET SDT=2
- SET SD1=DGSD#100
- SET SD2=DGED#100
- SET SDPCE=10
- +4 FOR B=SD1:1:SD2
- IF '$EXTRACT(SD,B)
- IF '$DATA(SDCP(B))
- Begin DoDot:1
- +5 SET (A,SDOEDT)=DGSD\100*100+B
- Begin DoDot:2
- End DoDot:2
- +6 FOR
- SET SDOEDT=$ORDER(^SCE("B",SDOEDT))
- if 'SDOEDT!($PIECE(SDOEDT,".")'=A)
- QUIT
- Begin DoDot:2
- +7 SET SDOE=0
- +8 FOR
- SET SDOE=$ORDER(^SCE("B",SDOEDT,SDOE))
- if 'SDOE
- QUIT
- Begin DoDot:3
- +9 SET SDC=$GET(^SCE(SDOE,0))
- +10 SET SDPAR=+$PIECE(SDC,U,6)
- +11 SET SDORG=+$PIECE(SDC,U,8)
- +12 ;
- +13 ; -- do checks
- +14 ; -- must not have a parent
- IF SDPAR
- QUIT
- +15 ; -- must be a/e
- IF SDORG'=2
- +16 ;
- +17 DO ELIG
- +18 IF $TEST
- Begin DoDot:4
- +19 SET SDAY=B
- +20 DO T
- +21 IF 'SDIG
- DO SET
- End DoDot:4
- End DoDot:3
- End DoDot:2
- End DoDot:1
- +22 ;
- +23 SET SDT=3
- SET SD1=9999999-(DGED_.9)
- SET SD2=9999999-(DGSD_.9)
- FOR B=SD1:0
- SET B=$ORDER(^DPT(DFN,"DIS",B))
- if B>SD2!(B="")
- QUIT
- IF $DATA(^DPT(DFN,"DIS",B,0))
- IF $PIECE(^(0),"^",2)'=2
- SET C=$PIECE(9999999-B,".")
- IF '$EXTRACT(SD,C#100)
- IF '$DATA(SDCP(C#100))
- SET SDAY=C#100
- SET POP=0
- DO DISP
- if 'POP
- DO SET
- +24 KILL A,B,C,D,E,SD1,SD2,SDAP,SDAY,SDC,SDCP,SDT,SDIG,SDPCE,SDISP,SDNV,SDSC
- QUIT
- SET SET SD=$EXTRACT(SD,1,SDAY-1)_SDT_$EXTRACT(SD,SDAY+1,31)
- QUIT
- DISP SET SDISP=+$PIECE(^DPT(DFN,"DIS",B,0),"^",7)
- SET SDISP=$SELECT($DATA(^DIC(37,SDISP,0)):$PIECE(^(0),"^"),1:"")
- +1 if SDISP']""
- QUIT
- IF SDISP["DEAD"!(SDISP["CANCEL")!(SDISP["FAILED TO COOP")!(SDISP["INELIGIBLE")
- SET POP=1
- +2 QUIT
- SDCP SET SDNV=0
- IF $PIECE(SDC,"^",7)=1
- SET SDCP(B)=""
- SET SDT=0
- SET SDCP=1
- SET B=$PIECE(B,".")_.9
- DO SET
- QUIT
- +1 SET SDCP=0
- +2 IF $DATA(^SC(+SDC,"S",B))
- FOR S=0:0
- SET S=$ORDER(^SC(+SDC,"S",B,1,S))
- if S=""
- QUIT
- IF +^(S,0)=DFN
- SET SDAP=^(0)
- IF $PIECE(SDAP,U,9)']""
- IF $PIECE(SDAP,U,10)
- IF $PIECE(^DIC(8,$PIECE(SDAP,U,10),0),U,5)="N"
- SET SDNV=1
- QUIT
- +3 KILL SDCL,S
- QUIT
- T SET SDIG=$PIECE(SDC,U,SDPCE)
- SET SDIG=$SELECT($DATA(^SD(409.1,+SDIG,0)):$PIECE(^(0),U,2),1:0)
- +1 QUIT
- ELIG IF "NSC"[$SELECT('$DATA(^DIC(8,+$PIECE(SDC,U,13),0)):$PIECE(SDC,U,13),$DATA(^DIC(8.1,+$PIECE(^(0),U,9),0)):$PIECE(^(0),U),1:$PIECE(SDC,U,13))
- +1 QUIT