- SDRRUTL1 ;10N20/MAH;Recall Reminder-Clinic Utilities ;07/13/06 11:32
- ;;5.3;PIMS;**1016**;JUN 30, 2012;Build 20
- ASKCLIN(SDRRDIV,SDRRST,SDRRND) ;
- N DIR,X,Y,DIRUT,SDRRABORT
- W !!,"Now you'll select the clinics."
- S DIR(0)="SO^R:Range of Clinics;I:Individual Clinics;S:Stop Codes"
- S DIR("A")="Select Clinics by"
- S DIR("?",1)="Choose 'Range of Clinics' if you want to select a group of clinics in"
- S DIR("?",2)="consecutive name order. You'll be asked for the starting clinic and the"
- S DIR("?",3)="ending clinic. All the clinics in that range will be selected for you."
- S DIR("?",4)=""
- S DIR("?",5)="Choose 'Individual Clinics' if you want to select clinics individually."
- S DIR("?",6)="You'll be able to use ranges here, too, as well as wild cards. You'll"
- S DIR("?",7)="even be able to de-select clinics."
- S DIR("?",8)=""
- S DIR("?",9)="Choose 'Stop Codes' if you want to select Stop Codes. All clinics whose"
- S DIR("?",10)="Stop Codes or Credit Stops match the ones you've chosen will be selected"
- S DIR("?")="for you."
- D ^DIR I $D(DIRUT) S SDRRABORT=1 Q
- D @Y
- Q
- STOPCODE(SDRRI) ; Return a clinic stop code
- Q $S('SDRRI:SDRRI,1:$P($G(^DIC(40.7,SDRRI,0)),U,2))
- I ; Select individual clinics
- N SDRRDIC,SDRRNAME,SDRRIEN,SDRRREC
- W !!,"You'll be able to use ranges and wild cards to select clinics."
- W !,"You'll even be able to deselect clinics."
- W !,"Enter '?' at the prompt to see how."
- S SDRRDIC=44
- S SDRRDIC(0)="AEMNQZ"
- S SDRRDIC("A")="Select Clinic: "
- S SDRRDIC("B")="All"
- S SDRRDIC("S")="I $$ACTIVE^SDRRUTL1(+Y,.SDRRDIV,.SDRRST,.SDRRND,^(0))"
- I '$$EN^SDRRSLCT(.SDRRDIC,"SDRR") S SDRRABORT=1 Q
- S (SDRRNAME,SDRRIEN)=""
- F S SDRRNAME=$O(^TMP($J,"SDRR",SDRRNAME)) Q:SDRRNAME="" D
- . F S SDRRIEN=$O(^TMP($J,"SDRR",SDRRNAME,SDRRIEN)) Q:SDRRIEN="" D
- . . S SDRRREC=$G(^SC(SDRRIEN,0))
- . . S ^TMP("SDRR",$J,"DIV",$P(SDRRREC,U,15),"CLIN",$P(SDRRREC,U))=SDRRIEN_U_$$STOPCODE($P(SDRRREC,U,7))_U_$$STOPCODE($P(SDRRREC,U,18))
- K ^TMP($J,"SDRR")
- Q
- R ; Select range of clinics
- N SDRRCLIN,SDRRIEN,SDRRREC,SDRRFROM,SDRRTHRU,SDRRI
- D ASKRANGE(.SDRRCLIN,.SDRRDIV,.SDRRST,.SDRRND)
- I 'SDRRCLIN S SDRRABORT=1 Q
- S SDRRI=0
- F S SDRRI=$O(SDRRCLIN(SDRRI)) Q:'SDRRI D
- . S SDRRFROM=$P($P(SDRRCLIN(SDRRI),":"),U,2)
- . S SDRRFROM=$O(^SC("B",SDRRFROM),-1)
- . S SDRRTHRU=$P($P(SDRRCLIN(SDRRI),":",2),U,2)
- . S SDRRCLIN=SDRRFROM
- . F S SDRRCLIN=$O(^SC("B",SDRRCLIN)) Q:SDRRCLIN="" D Q:SDRRCLIN=SDRRTHRU
- . . S SDRRIEN=$O(^SC("B",SDRRCLIN,0))
- . . S SDRRREC=$G(^SC(SDRRIEN,0))
- . . Q:'$$ACTIVE(SDRRIEN,.SDRRDIV,.SDRRST,.SDRRND,SDRRREC)
- . . S ^TMP("SDRR",$J,"DIV",$P(SDRRREC,U,15),"CLIN",$P(SDRRREC,U))=SDRRIEN_U_$$STOPCODE($P(SDRRREC,U,7))_U_$$STOPCODE($P(SDRRREC,U,18))
- Q
- S ; Select stop codes
- N SDRRDIC,SDRRSC,SDRRSCI,SDRRNDX,SDRRIEN,SDRRREC
- S SDRRDIC=40.7
- S SDRRDIC(0)="AEMQZ"
- S SDRRDIC("A")="Select Stop Code: "
- S SDRRDIC("S")="S %=$P(^(0),U,3) I '%!(%>"_$G(SDRRST,DT)_")"
- I '$$EN^SDRRSLCT(.SDRRDIC,"SDRR") S SDRRABORT=1 Q
- S (SDRRSC,SDRRSCI,SDRRIEN)=""
- F S SDRRSC=$O(^TMP($J,"SDRR",SDRRSC)) Q:SDRRSC="" D
- . F S SDRRSCI=$O(^TMP($J,"SDRR",SDRRSC,SDRRSCI)) Q:'SDRRSCI D
- . . F SDRRNDX="AST","ACST" D ; xrefs on STOP CODE and CREDIT STOP fields
- . . . F S SDRRIEN=$O(^SC(SDRRNDX,SDRRSCI,SDRRIEN)) Q:'SDRRIEN D
- . . . . S SDRRREC=$G(^SC(SDRRIEN,0))
- . . . . Q:'$$ACTIVE(SDRRIEN,.SDRRDIV,.SDRRST,.SDRRND,SDRRREC)
- . . . . S ^TMP("SDRR",$J,"DIV",$P(SDRRREC,U,15),"CLIN",$P(SDRRREC,U))=SDRRIEN_U_$$STOPCODE($P(SDRRREC,U,7))_U_$$STOPCODE($P(SDRRREC,U,18))
- K ^TMP($J,"SDRR")
- Q
- ASKRANGE(SDRRCLIN,SDRRDIV,SDRRST,SDRRND) ;
- ; DBIA #10040; Direct global reference of (#44) file
- N DIC,X,Y,DTOUT,DUOUT,SDRRCNT,SDRRFROM
- S SDRRCNT=0
- S DIC="^SC(",DIC(0)="AEQM"
- W !
- W !,"To select a range of clinics, first you select the start of the range,"
- W !,"or the 'from' clinic. Next, you select the end of the range,"
- W !,"or the 'thru' clinic. We'll select all the clinics in that range for you."
- F D Q:Y<0
- . W !
- . S DIC("A")="From Clinic: "
- . S DIC("S")="I $$ACTIVE^SDRRUTL1(+Y,.SDRRDIV,.SDRRST,.SDRRND,^(0))"
- . D ^DIC Q:Y<0
- . S SDRRFROM=Y ;S SDRRDIV(+Y)=$P(Y,U,2)
- . S DIC("A")="Thru Clinic: "
- . S DIC("S")="I $P(^(0),U)]"""_$O(^SC("B",$P(SDRRFROM,U,2)),-1)_""",$$ACTIVE^SDRRUTL1(+Y,.SDRRDIV,.SDRRST,.SDRRND,^(0))"
- . D ^DIC Q:Y<0
- . S SDRRCNT=SDRRCNT+1
- . S SDRRCLIN(SDRRCNT)=SDRRFROM_":"_Y
- I $D(DTOUT)!$D(DUOUT) K SDRRCLIN S SDRRCLIN=0
- S SDRRCLIN=SDRRCNT
- Q
- ACTIVE(SDRRIEN,SDRRDIV,SDRRST,SDRRND,SDRRREC) ; Is the clinic active?
- ; DBIA #10040; Direct global reference of (#44) file
- ; SDRRIEN - IEN of clinic in HOSPITAL LOCATION (#44) file
- ; SDRRDIV - (optional) clinic must be in Division(s)
- ; SDRRDIV=ien or SDRRDIV(ien)="", where ien is IEN in file 40.8
- ; SDRRST - (optional) date range start date - default=DT
- ; SDRRND - (optional) date range end date - default=SDRRST
- ; SDRRREC - (optional) zero node of clinic
- I '$D(SDRRREC) S SDRRREC=$G(^SC(SDRRIEN,0))
- Q:$P(SDRRREC,U,3)'="C" 0 ; Not a clinic
- Q:$P(SDRRREC,U,1)["*" 0
- I $D(SDRRDIV)=1,$P(SDRRREC,U,15)'=SDRRDIV Q 0
- I $D(SDRRDIV)>9,'$D(SDRRDIV(+$P(SDRRREC,U,15))) Q 0
- S SDRRREC=$G(^SC(SDRRIEN,"I"))
- Q:'SDRRREC 1
- I '$G(SDRRST) S SDRRST=DT
- I '$G(SDRRND) S SDRRND=SDRRST
- I $P(SDRRREC,U,1)<SDRRST Q $S($P(SDRRREC,U,2)="":0,$P(SDRRREC,U,2)>SDRRND:0,1:1)
- Q 1 ; Active
- SDRRUTL1 ;10N20/MAH;Recall Reminder-Clinic Utilities ;07/13/06 11:32
- +1 ;;5.3;PIMS;**1016**;JUN 30, 2012;Build 20
- ASKCLIN(SDRRDIV,SDRRST,SDRRND) ;
- +1 NEW DIR,X,Y,DIRUT,SDRRABORT
- +2 WRITE !!,"Now you'll select the clinics."
- +3 SET DIR(0)="SO^R:Range of Clinics;I:Individual Clinics;S:Stop Codes"
- +4 SET DIR("A")="Select Clinics by"
- +5 SET DIR("?",1)="Choose 'Range of Clinics' if you want to select a group of clinics in"
- +6 SET DIR("?",2)="consecutive name order. You'll be asked for the starting clinic and the"
- +7 SET DIR("?",3)="ending clinic. All the clinics in that range will be selected for you."
- +8 SET DIR("?",4)=""
- +9 SET DIR("?",5)="Choose 'Individual Clinics' if you want to select clinics individually."
- +10 SET DIR("?",6)="You'll be able to use ranges here, too, as well as wild cards. You'll"
- +11 SET DIR("?",7)="even be able to de-select clinics."
- +12 SET DIR("?",8)=""
- +13 SET DIR("?",9)="Choose 'Stop Codes' if you want to select Stop Codes. All clinics whose"
- +14 SET DIR("?",10)="Stop Codes or Credit Stops match the ones you've chosen will be selected"
- +15 SET DIR("?")="for you."
- +16 DO ^DIR
- IF $DATA(DIRUT)
- SET SDRRABORT=1
- QUIT
- +17 DO @Y
- +18 QUIT
- STOPCODE(SDRRI) ; Return a clinic stop code
- +1 QUIT $SELECT('SDRRI:SDRRI,1:$PIECE($GET(^DIC(40.7,SDRRI,0)),U,2))
- I ; Select individual clinics
- +1 NEW SDRRDIC,SDRRNAME,SDRRIEN,SDRRREC
- +2 WRITE !!,"You'll be able to use ranges and wild cards to select clinics."
- +3 WRITE !,"You'll even be able to deselect clinics."
- +4 WRITE !,"Enter '?' at the prompt to see how."
- +5 SET SDRRDIC=44
- +6 SET SDRRDIC(0)="AEMNQZ"
- +7 SET SDRRDIC("A")="Select Clinic: "
- +8 SET SDRRDIC("B")="All"
- +9 SET SDRRDIC("S")="I $$ACTIVE^SDRRUTL1(+Y,.SDRRDIV,.SDRRST,.SDRRND,^(0))"
- +10 IF '$$EN^SDRRSLCT(.SDRRDIC,"SDRR")
- SET SDRRABORT=1
- QUIT
- +11 SET (SDRRNAME,SDRRIEN)=""
- +12 FOR
- SET SDRRNAME=$ORDER(^TMP($JOB,"SDRR",SDRRNAME))
- IF SDRRNAME=""
- QUIT
- Begin DoDot:1
- +13 FOR
- SET SDRRIEN=$ORDER(^TMP($JOB,"SDRR",SDRRNAME,SDRRIEN))
- IF SDRRIEN=""
- QUIT
- Begin DoDot:2
- +14 SET SDRRREC=$GET(^SC(SDRRIEN,0))
- +15 SET ^TMP("SDRR",$JOB,"DIV",$PIECE(SDRRREC,U,15),"CLIN",$PIECE(SDRRREC,U))=SDRRIEN_U_$$STOPCODE($PIECE(SDRRREC,U,7))_U_$$STOPCODE($PIECE(SDRRREC,U,18))
- End DoDot:2
- End DoDot:1
- +16 KILL ^TMP($JOB,"SDRR")
- +17 QUIT
- R ; Select range of clinics
- +1 NEW SDRRCLIN,SDRRIEN,SDRRREC,SDRRFROM,SDRRTHRU,SDRRI
- +2 DO ASKRANGE(.SDRRCLIN,.SDRRDIV,.SDRRST,.SDRRND)
- +3 IF 'SDRRCLIN
- SET SDRRABORT=1
- QUIT
- +4 SET SDRRI=0
- +5 FOR
- SET SDRRI=$ORDER(SDRRCLIN(SDRRI))
- IF 'SDRRI
- QUIT
- Begin DoDot:1
- +6 SET SDRRFROM=$PIECE($PIECE(SDRRCLIN(SDRRI),":"),U,2)
- +7 SET SDRRFROM=$ORDER(^SC("B",SDRRFROM),-1)
- +8 SET SDRRTHRU=$PIECE($PIECE(SDRRCLIN(SDRRI),":",2),U,2)
- +9 SET SDRRCLIN=SDRRFROM
- +10 FOR
- SET SDRRCLIN=$ORDER(^SC("B",SDRRCLIN))
- IF SDRRCLIN=""
- QUIT
- Begin DoDot:2
- +11 SET SDRRIEN=$ORDER(^SC("B",SDRRCLIN,0))
- +12 SET SDRRREC=$GET(^SC(SDRRIEN,0))
- +13 IF '$$ACTIVE(SDRRIEN,.SDRRDIV,.SDRRST,.SDRRND,SDRRREC)
- QUIT
- +14 SET ^TMP("SDRR",$JOB,"DIV",$PIECE(SDRRREC,U,15),"CLIN",$PIECE(SDRRREC,U))=SDRRIEN_U_$$STOPCODE($PIECE(SDRRREC,U,7))_U_$$STOPCODE($PIECE(SDRRREC,U,18))
- End DoDot:2
- IF SDRRCLIN=SDRRTHRU
- QUIT
- End DoDot:1
- +15 QUIT
- S ; Select stop codes
- +1 NEW SDRRDIC,SDRRSC,SDRRSCI,SDRRNDX,SDRRIEN,SDRRREC
- +2 SET SDRRDIC=40.7
- +3 SET SDRRDIC(0)="AEMQZ"
- +4 SET SDRRDIC("A")="Select Stop Code: "
- +5 SET SDRRDIC("S")="S %=$P(^(0),U,3) I '%!(%>"_$GET(SDRRST,DT)_")"
- +6 IF '$$EN^SDRRSLCT(.SDRRDIC,"SDRR")
- SET SDRRABORT=1
- QUIT
- +7 SET (SDRRSC,SDRRSCI,SDRRIEN)=""
- +8 FOR
- SET SDRRSC=$ORDER(^TMP($JOB,"SDRR",SDRRSC))
- IF SDRRSC=""
- QUIT
- Begin DoDot:1
- +9 FOR
- SET SDRRSCI=$ORDER(^TMP($JOB,"SDRR",SDRRSC,SDRRSCI))
- IF 'SDRRSCI
- QUIT
- Begin DoDot:2
- +10 ; xrefs on STOP CODE and CREDIT STOP fields
- FOR SDRRNDX="AST","ACST"
- Begin DoDot:3
- +11 FOR
- SET SDRRIEN=$ORDER(^SC(SDRRNDX,SDRRSCI,SDRRIEN))
- IF 'SDRRIEN
- QUIT
- Begin DoDot:4
- +12 SET SDRRREC=$GET(^SC(SDRRIEN,0))
- +13 IF '$$ACTIVE(SDRRIEN,.SDRRDIV,.SDRRST,.SDRRND,SDRRREC)
- QUIT
- +14 SET ^TMP("SDRR",$JOB,"DIV",$PIECE(SDRRREC,U,15),"CLIN",$PIECE(SDRRREC,U))=SDRRIEN_U_$$STOPCODE($PIECE(SDRRREC,U,7))_U_$$STOPCODE($PIECE(SDRRREC,U,18))
- End DoDot:4
- End DoDot:3
- End DoDot:2
- End DoDot:1
- +15 KILL ^TMP($JOB,"SDRR")
- +16 QUIT
- ASKRANGE(SDRRCLIN,SDRRDIV,SDRRST,SDRRND) ;
- +1 ; DBIA #10040; Direct global reference of (#44) file
- +2 NEW DIC,X,Y,DTOUT,DUOUT,SDRRCNT,SDRRFROM
- +3 SET SDRRCNT=0
- +4 SET DIC="^SC("
- SET DIC(0)="AEQM"
- +5 WRITE !
- +6 WRITE !,"To select a range of clinics, first you select the start of the range,"
- +7 WRITE !,"or the 'from' clinic. Next, you select the end of the range,"
- +8 WRITE !,"or the 'thru' clinic. We'll select all the clinics in that range for you."
- +9 FOR
- Begin DoDot:1
- +10 WRITE !
- +11 SET DIC("A")="From Clinic: "
- +12 SET DIC("S")="I $$ACTIVE^SDRRUTL1(+Y,.SDRRDIV,.SDRRST,.SDRRND,^(0))"
- +13 DO ^DIC
- IF Y<0
- QUIT
- +14 ;S SDRRDIV(+Y)=$P(Y,U,2)
- SET SDRRFROM=Y
- +15 SET DIC("A")="Thru Clinic: "
- +16 SET DIC("S")="I $P(^(0),U)]"""_$ORDER(^SC("B",$PIECE(SDRRFROM,U,2)),-1)_""",$$ACTIVE^SDRRUTL1(+Y,.SDRRDIV,.SDRRST,.SDRRND,^(0))"
- +17 DO ^DIC
- IF Y<0
- QUIT
- +18 SET SDRRCNT=SDRRCNT+1
- +19 SET SDRRCLIN(SDRRCNT)=SDRRFROM_":"_Y
- End DoDot:1
- IF Y<0
- QUIT
- +20 IF $DATA(DTOUT)!$DATA(DUOUT)
- KILL SDRRCLIN
- SET SDRRCLIN=0
- +21 SET SDRRCLIN=SDRRCNT
- +22 QUIT
- ACTIVE(SDRRIEN,SDRRDIV,SDRRST,SDRRND,SDRRREC) ; Is the clinic active?
- +1 ; DBIA #10040; Direct global reference of (#44) file
- +2 ; SDRRIEN - IEN of clinic in HOSPITAL LOCATION (#44) file
- +3 ; SDRRDIV - (optional) clinic must be in Division(s)
- +4 ; SDRRDIV=ien or SDRRDIV(ien)="", where ien is IEN in file 40.8
- +5 ; SDRRST - (optional) date range start date - default=DT
- +6 ; SDRRND - (optional) date range end date - default=SDRRST
- +7 ; SDRRREC - (optional) zero node of clinic
- +8 IF '$DATA(SDRRREC)
- SET SDRRREC=$GET(^SC(SDRRIEN,0))
- +9 ; Not a clinic
- IF $PIECE(SDRRREC,U,3)'="C"
- QUIT 0
- +10 IF $PIECE(SDRRREC,U,1)["*"
- QUIT 0
- +11 IF $DATA(SDRRDIV)=1
- IF $PIECE(SDRRREC,U,15)'=SDRRDIV
- QUIT 0
- +12 IF $DATA(SDRRDIV)>9
- IF '$DATA(SDRRDIV(+$PIECE(SDRRREC,U,15)))
- QUIT 0
- +13 SET SDRRREC=$GET(^SC(SDRRIEN,"I"))
- +14 IF 'SDRRREC
- QUIT 1
- +15 IF '$GET(SDRRST)
- SET SDRRST=DT
- +16 IF '$GET(SDRRND)
- SET SDRRND=SDRRST
- +17 IF $PIECE(SDRRREC,U,1)<SDRRST
- QUIT $SELECT($PIECE(SDRRREC,U,2)="":0,$PIECE(SDRRREC,U,2)>SDRRND:0,1:1)
- +18 ; Active
- QUIT 1