VistA-FOIAVistA/r/SCHEDULING-SD-SC/SCRPW76.m

230 lines
8.6 KiB
Mathematica

SCRPW76 ;BP-OIFO/KEITH,ESW - Clinic appointment availability extract (cont.) ; 5/28/03 4:02pm
;;5.3;Scheduling;**223,291**;AUG 13, 1993
;
HINI ;Initialize header variables
N %,%H,%I,X,X1,X2
S SDLINE="",$P(SDLINE,"-",$S(SDPAST:133,1:(SDIOM+1)))="",SDPAGE=1,SDPG=0
D NOW^%DTC S Y=% X ^DD("DD") S SDPNOW=$P(Y,":",1,2)
S SDTITL="<*> Clinic Appointment Availability Report <*>"
Q
;
HDR(SDTY,SDREPORT,SDIV,SDCP,SC) ;Print header
;Input: SDTY=type of header where:
; '0'=negative report
; '1'=detailed report
; '2'=division summary
; '3'=facility summary
;Input: SDREPORT=report output element where:
; '1'='next ava.' appt. information
; '2'='follow up' appt. information
; '3'='non-follow up' appt. information
;Input: SDIV=division name^division number
;Input: SDCP=credit pair
;Input: SC=clinic ifn
;
Q:SDOUT
I $G(SDXM) D HDRXM(SDREPORT) Q
I $E(IOST)="C",SDPG N DIR S DIR(0)="E" W ! D ^DIR S SDOUT=Y'=1 Q:SDOUT
N SDX,SDI D STOP Q:SDOUT
W:SDPG!($E(IOST)="C") $$XY^SCRPW50(IOF,1,0) W:$X $$XY^SCRPW50("",0,0)
W SDLINE,!?(SDIOM-$L(SDTITL)\2),SDTITL
I SDREPORT=1,'SDPAST S SDX="Clinic availability data"
I SDREPORT=1,SDPAST S SDX="Clinic availability and 'next available' appointment data"
I SDREPORT=2 S SDX="'Follow up' appointment data"
I SDREPORT=3 S SDX="'Non-follow up' appointment data"
I SDREPORT=4 S SDX="Listing of patient appointments"
I SDREPORT=5 S SDX="Listing of appointments for selected patient"
W !?(SDIOM-$L(SDX)\2),SDX
D HDRX(SDTY) Q:SDOUT S SDI=0
I $G(SDREPORT)'=5 F S SDI=$O(SDTIT(SDI)) Q:'SDI W !?(SDIOM-$L(SDTIT(SDI))\2),SDTIT(SDI)
I $G(SDREPORT)=5 Q:'$O(SDTIT("")) D
.N SD F SD=1,2 W !?(SDIOM-$L(SDTIT(SD))\2),SDTIT(SD)
.W !,SDTIT(3),?100,SDTIT(4),!,SDTIT(5),?100,SDTIT(6)
W !,SDLINE
W !,"For clinic availability dates ",SDPBDT," through ",SDPEDT
W !,"Date printed: ",SDPNOW,?(IOM-6-$L(SDPAGE)),"Page: ",SDPAGE
W !,SDLINE
S SDPAGE=SDPAGE+1,SDPG=1 D:SDTY SUBT(SDTY,SDREPORT) Q
;
HDRX(SDTY) ;Extra header lines
K SDTIT
Q:SDTY=0 S SDIV=$G(SDIV)
I SDTY=3 S SDTIT(1)="Facility Summary" Q
N SDDV S SDDV=$P(SDIV,U)_" ("_$P(SDIV,U,2)_")"
I SDTY=2 S SDTIT(1)="Summary for division: "_SDDV Q
S SDTIT(1)="Division: "_SDDV
S:SDSORT="CP" SDTIT(2)="For clinics with credit pair: "_$$OTX^SCRPW73("CP")
I $G(SDREPORT)=5 D
.S:SDSORT="CP" SDTIT(2)="For clinics with selected credit pair"
.S:SDSORT="CA" SDTIT(2)="For all clinics"
.S:SDSORT="CL" SDTIT(2)="For clinics selected by name"
.N DA,DIC,DIQ,DR
.S DIC=2,SDPT=DIC,DA=$G(DFN) F DR=.01,.09 N SDPT,SDARR S DIQ="SDARR(",DIQ(0)="I" D EN^DIQ1 D
..I DR=.01 S SDTIT(3)="Patient: "_SDARR(2,DA,.01,"I")
..I DR=.09 S SDTIT(4)="SSN: "_SDARR(2,DA,.09,"I")
.S SDTIT(5)="Clinic: "_$P(^SC(SC,0),U)
.S SDTIT(6)="Clinic Stop Code Pair: "_SDCP
E S SDTIT(3)="Detail for clinic: "_$$OTX^SCRPW73("CL")
Q
;
SUBT(SDTY,SDREPORT) ;Print subtitles
D:SDREPORT=1 SUBT1 D:SDREPORT=2 SUBT2
D:SDREPORT=3 SUBT3 D:SDREPORT=4 SUBT4
D:SDREPORT=5 SUBT5
Q
;
SUBT1 N SDI
W !?(SDCOL+44),"Ava.",?(SDCOL+51),"Pct."
I SDPAST D
.F SDI=0:1:3 W ?(SDCOL+63+(14*SDI)),"--Type '",SDI,"'---"
.W ?120,"% NNA % NA" Q
W ! W:SDTY>1 ?(SDCOL),"Credit Pair"
W ?(SDCOL+35),"Clinic",?(SDCOL+43),"Appt.",?(SDCOL+50),"Slots"
I SDPAST D
.W ?(SDCOL+56),"Clinic"
.F SDI=0:1:3 W ?(SDCOL+65+(14*SDI)),"Sch. Wait"
.W ?122,"<31 <31" Q
W !?(SDCOL+4),$S(SDTY=1:"Availability Date",1:"Clinic Name")
W ?(SDCOL+33),"Capacity",?(SDCOL+43),"Slots",?(SDCOL+51),"Ava."
I SDPAST D
.W ?(SDCOL+58),"Enc."
.F SDI=0:1:3 W ?(SDCOL+64+(14*SDI)),"Appts Time"
.W ?121,"Days Days"
W !?(SDCOL),$E(SDLINE,1,($S(SDPAST:132,1:58)))
Q
;
SUBT2 N SDI
W !?48,"Next",?54,$E(SDLINE,1,24),"Non-next Available Appointments",$E(SDLINE,1,23)
W !?40,"Next Ava. 0-1 0-1 2-7 2-7 8-30 8-30 31-60 31-60 >60 >60"
W ! W:SDTY>1 "Credit Pair" W ?40,"Ava. Wait"
F SDI=56:16:121 W ?(SDI),"Days Wait"
W !?4,$S(SDTY=1:"Availability Date",1:"Clinic Name")
F SDI=39:16:120 W ?(SDI),"Appts Time"
W !,SDLINE
Q
;
SUBT3 N SDI
W !?38,"Next",?43,$E(SDLINE,1,29),"Non-next Available Appointments",$E(SDLINE,1,29)
W !?32,"Next Ava. 0-1 0-1 0-1 2-7 2-7 2-7 8-30 8-30 8-30 31-60 31-60 31-60 >60 >60 >60"
W ! W:SDTY>1 "Credit Pair" W ?32,"Ava. Wait"
F SDI=44:18:117 W ?(SDI),"Days Wait Wait"
W !?4,$S(SDTY=1:"Availability Date",1:"Clinic Name"),?31,"Appts Time1"
F SDI=43:18:116 W ?(SDI),"Appts Time1 Time2"
W !,SDLINE
Q
;
SUBT4 W !?96,"Next",!,"Date",?96,"Ava. Date Wait Wait"
W !,"Scheduled Patient Name SSN Appointment Date Scheduling Request Type Ind. Desired F/U Time1 Time2"
W !,SDLINE
Q
;
SUBT5 W !?11,"SCHEDULING",?63,"TIME",!,"DATE",?11,"REQUEST",?31,"DATE",?58,"WAIT",?63,"TO",?68,"APPT",?96,"APPT",?102,"COMPLETION"
W !,"SCHEDULED",?11,"TYPE",?31,"DESIRED",?42,"APPT DATE/TIME",?58,"TIME",?63,"APPT",?68,"TYPE",?73,"F/U",?79,"REBOOK DATE",?96,"STAT",?102,"DATE",?113,"SCHEDULER"
W !,SDLINE
Q
HDRXM(SDREPORT) ;Create header in mail message
;Input: SDREPORT=report element to print
;
N SDX,SDI,SDZ
I SDPAGE>1 F SDI=1:1:5 D XMTX("")
D XMTX($E(SDLINE,1,$S('SDPAST:79,1:132)))
S SDZ="",$E(SDZ,($S(SDPAST:132,1:79)-$L(SDTITL)\2))=SDTITL D XMTX(SDZ)
I SDREPORT=1,'SDPAST S SDX="Clinic availability data"
I SDREPORT=1,SDPAST S SDX="Clinic availability and 'next available' appointment data"
I SDREPORT=2 S SDX="'Follow up' appointment data"
I SDREPORT=3 S SDX="'Non-follow up' appointment data"
I SDREPORT=4 S SDX="Listing of patient appointments"
I SDREPORT=5 S SDX="Listing of appointments for selected patient"
S SDZ="",$E(SDZ,($S(SDPAST:132,1:79)-$L(SDX)\2))=SDX D XMTX(SDZ)
D HDRX(SDTY) S SDI=0
F S SDI=$O(SDTIT(SDI)) Q:'SDI S SDZ="" D
.S $E(SDZ,($S(SDPAST:130,1:79)-$L(SDTIT(SDI))\2))=SDTIT(SDI) D XMTX(SDZ)
.Q
D XMTX($E(SDLINE,1,$S('SDPAST:79,1:132)))
D XMTX("For clinic availability dates "_SDPBDT_" through "_SDPEDT)
S SDZ="Date extracted: "_SDPNOW
D XMTX(SDZ),XMTX($E(SDLINE,1,$S('SDPAST:79,1:132)))
S SDPAGE=SDPAGE+1 D:SDTY SUBTXM(SDTY,SDREPORT) Q
;
SUBTXM(SDTY,SDREPORT) ;Create message header subtitles
N SDZ
D:SDREPORT=1 STXM1 D:SDREPORT=2 STXM2
D:SDREPORT=3 STXM3 D:SDREPORT=4 STXM4
Q
;
STXM1 N SDI
S SDZ="",$E(SDZ,45)="Ava.",$E(SDZ,52)="Pct."
I SDPAST D
.F SDI=0:1:3 D
..S $E(SDZ,(SDCOL+64+(14*SDI)))="--Type '"_SDI_"'---"
..Q
.S $E(SDZ,121)="% NNA % NA"
.Q
D XMTX(SDZ)
S SDZ="" I SDTY>1 S SDZ="Credit Pair"
S $E(SDZ,36)="Clinic",$E(SDZ,44)="Appt.",$E(SDZ,51)="Slots"
I SDPAST D
.S $E(SDZ,57)="Clinic"
.F SDI=0:1:3 S $E(SDZ,(SDCOL+66+(14*SDI)))="Sch. Wait"
.S $E(SDZ,123)="<31 <31"
.Q
D XMTX(SDZ)
S SDZ="",$E(SDZ,4)=$S(SDTY=1:"Availability Date",1:"Clinic Name")
S $E(SDZ,34)="Capacity",$E(SDZ,44)="Slots",$E(SDZ,52)="Ava."
I SDPAST D
.S $E(SDZ,59)="Enc."
.F SDI=0:1:3 S $E(SDZ,(SDCOL+65+(14*SDI)))="Appts Time"
.S $E(SDZ,122)="Days Days"
.Q
D XMTX(SDZ)
S SDZ="",$E(SDZ,$S(SDTY>1:1,1:4))=$E(SDLINE,1,$S(SDPAST:132,1:58))
D XMTX(SDZ)
Q
;
STXM2 N SDI S SDZ=""
S $E(SDZ,49)="Next"
S $E(SDZ,55)=$E(SDLINE,1,24)_"Non-next Available Appointments"_$E(SDLINE,1,23)
D XMTX(SDZ) S SDZ=""
S $E(SDZ,41)="Next Ava. 0-1 0-1 2-7 2-7 8-30 8-30 31-60 31-60 >60 >60"
D XMTX(SDZ) S SDZ=""
S:SDTY>1 SDZ="Credit Pair" S $E(SDZ,41)="Ava. Wait"
F SDI=57:16:121 S $E(SDZ,SDI)="Days Wait"
D XMTX(SDZ) S SDZ=""
S $E(SDZ,4)=$S(SDTY=1:"Availability Date",1:"Clinic Name")
F SDI=40:16:120 S $E(SDZ,SDI)="Appts Time"
D XMTX(SDZ) S SDZ=""
S SDZ=SDLINE D XMTX(SDZ)
Q
;
STXM3 N SDI S SDZ=""
S $E(SDZ,39)="Next"
S $E(SDZ,44)=$E(SDLINE,1,29)_"Non-next Available Appointments"_$E(SDLINE,1,29)
D XMTX(SDZ) S SDZ=""
S $E(SDZ,33)="Next Ava. 0-1 0-1 0-1 2-7 2-7 2-7 8-30 8-30 8-30 31-60 31-60 31-60 >60 >60 >60"
D XMTX(SDZ) S SDZ=""
S:SDTY>1 SDZ="Credit Pair" S $E(SDZ,33)="Ava. Wait"
F SDI=45:18:117 S $E(SDZ,SDI)="Days Wait Wait"
D XMTX(SDZ) S SDZ=""
S $E(SDZ,4)=$S(SDTY=1:"Availability Date",1:"Clinic Name") S $E(SDZ,32)="Appts Time1"
F SDI=44:18:116 S $E(SDZ,SDI)="Appts Time1 Time2"
D XMTX(SDZ) S SDZ=""
S SDZ=SDLINE D XMTX(SDZ)
Q
;
STXM4 S SDZ=""
S $E(SDZ,96)="Next"
D XMTX(SDZ) S SDZ=""
S SDZ="Date",$E(SDZ,96)="Ava. Date Wait Wait"
D XMTX(SDZ) S SDZ=""
S SDZ="Scheduled Patient Name SSN Appointment Date Scheduling Request Type Ind. Desired F/U Time1 Time2"
D XMTX(SDZ) S SDZ=""
S SDZ=SDLINE D XMTX(SDZ)
Q
;
STOP ;Check for stop task request
S:$D(ZTQUEUED) (SDOUT,ZTSTOP)=$S($$S^%ZTLOAD:1,1:0) Q
;
XMTX(SDX) ;Set mail message text line
;Input: SDX=text value
S ^TMP("SDXM",$J,SDXM)=SDX,SDXM=SDXM+1 Q