1 | BSDX02 ; IHS/OIT/HMW - WINDOWS SCHEDULING RPCS ; 7/6/12 11:09am
|
---|
2 | ;;1.7T2;BSDX;;Jul 11, 2012;Build 18
|
---|
3 | ;Licensed under LGPL
|
---|
4 | ; Change Log
|
---|
5 | ; July 15 2010: UJO/SMH - Pass FM dates in instead of US dates for i18n
|
---|
6 | ; March 21 2011: UJO/SMH (v 1.5) - Return new fields: Patient SEX, PID, and DOB
|
---|
7 | ; April 11 2011: UJO/SMH (v 1.6) - Added Radiology Exam Field, to retrieve Radiology Exam associated with appt
|
---|
8 | ;
|
---|
9 | ;
|
---|
10 | CRSCHD(BSDXY,BSDXRES,BSDXSTART,BSDXEND) ;EP
|
---|
11 | ;Entry point for debugging
|
---|
12 | ;
|
---|
13 | ;D DEBUG^%Serenji("CRSCH^BSDX02(.BSDXY,BSDXRES,BSDXSTART,BSDXEND)")
|
---|
14 | Q
|
---|
15 | ;
|
---|
16 | CRSCH(BSDXY,BSDXRES,BSDXSTART,BSDXEND,BSDXWKIN) ;
|
---|
17 | ;Called by BSDX CREATE APPT SCHEDULE
|
---|
18 | ;Create Resource Appointment Schedule recordset
|
---|
19 | ;On error, returns 0 in APPOINTMENTID field and error text in NOTE field
|
---|
20 | ;
|
---|
21 | ;$O Thru ^BSDXAPPT("ARSRC", RESOURCE, STARTTIME, APPTID)
|
---|
22 | ;BMXRES is a | delimited list of resource names
|
---|
23 | ;BSDXWKIN - If 1, then return walkins, otherwise skip them
|
---|
24 | ;9-27-2004 Added walkin to returned datatable
|
---|
25 | ;TODO: Change BSDXRES from names to IDs
|
---|
26 | ;
|
---|
27 | N BSDXERR,BSDXIEN,BSDXDEPD,BSDXDEPN,BSDXRESD,BSDXI,BSDXJ,BSDXRESN,BSDXS,BSDXAD,BSDXZ,BSDXQ,BSDXNOD
|
---|
28 | N BSDXPAT,BSDXNOT,BSDXZPCD,BSDXPCD
|
---|
29 | K ^BSDXTMP($J)
|
---|
30 | S BSDXERR=""
|
---|
31 | S BSDXY="^BSDXTMP("_$J_")"
|
---|
32 | S ^BSDXTMP($J,0)="I00020APPOINTMENTID^D00030START_TIME^D00030END_TIME^D00030CHECKIN^D00030AUXTIME^I00020PATIENTID^T00030PATIENTNAME^T00030RESOURCENAME"
|
---|
33 | S ^(0)=^(0)_"^I00005NOSHOW^T00020HRN^I00005ACCESSTYPEID^I00005WALKIN^T00250NOTE^T00006SEX^T00040PID^D00030DOB^I00020RADIOLOGY_EXAM"_$C(30)
|
---|
34 | D ^XBKVAR S X="ETRAP^BSDX02",@^%ZOSF("TRAP")
|
---|
35 | ;
|
---|
36 | ; S %DT="T",X=BSDXSTART D ^%DT S BSDXSTART=Y
|
---|
37 | ; I BSDXSTART=-1 S ^BSDXTMP($J,1)=$C(31) Q
|
---|
38 | ; S %DT="T",X=BSDXEND D ^%DT S BSDXEND=Y
|
---|
39 | ; I BSDXEND=-1 S ^BSDXTMP($J,1)=$C(31) Q
|
---|
40 | ;
|
---|
41 | S BSDXI=0
|
---|
42 | D STRES
|
---|
43 | ;
|
---|
44 | S BSDXI=BSDXI+1
|
---|
45 | S ^BSDXTMP($J,BSDXI)=$C(31)
|
---|
46 | Q
|
---|
47 | ;
|
---|
48 | STRES ;
|
---|
49 | F BSDXJ=1:1:$L(BSDXRES,"|") S BSDXRESN=$P(BSDXRES,"|",BSDXJ) D
|
---|
50 | . Q:BSDXRESN=""
|
---|
51 | . Q:'$D(^BSDXRES("B",BSDXRESN))
|
---|
52 | . S BSDXRESD=$O(^BSDXRES("B",BSDXRESN,0))
|
---|
53 | . Q:'+BSDXRESD
|
---|
54 | . Q:'$D(^BSDXAPPT("ARSRC",BSDXRESD))
|
---|
55 | . S BSDXS=BSDXSTART-.0001
|
---|
56 | . F S BSDXS=$O(^BSDXAPPT("ARSRC",BSDXRESD,BSDXS)) Q:'+BSDXS Q:BSDXS>BSDXEND D
|
---|
57 | . . S BSDXAD=0 F S BSDXAD=$O(^BSDXAPPT("ARSRC",BSDXRESD,BSDXS,BSDXAD)) Q:'+BSDXAD D STCOMM(BSDXAD,BSDXRESN)
|
---|
58 | Q
|
---|
59 | ;
|
---|
60 | STCOMM(BSDXAD,BSDXRESN) ;
|
---|
61 | ;BSDXAD is the appointment IEN
|
---|
62 | N BSDXC,BSDXQ,BSDXZ,BSDXSUBC,BSDXHRN,BSDXPATD,BSDXATID,BSDXISWK
|
---|
63 | Q:'$D(^BSDXAPPT(BSDXAD,0))
|
---|
64 | S BSDXNOD=^BSDXAPPT(BSDXAD,0)
|
---|
65 | Q:$P(BSDXNOD,U,12)]"" ;CANCELLED
|
---|
66 | S BSDXISWK=0
|
---|
67 | S:$P(BSDXNOD,U,13)="y" BSDXISWK=1
|
---|
68 | I +$G(BSDXWKIN) Q:BSDXISWK ;Don't return walkins if appt is WALKIN and BSDXWKIN is 1
|
---|
69 | S BSDXZ=BSDXAD_"^"
|
---|
70 | F BSDXQ=1:1:4 D
|
---|
71 | . S Y=$P(BSDXNOD,U,BSDXQ)
|
---|
72 | . X ^DD("DD") S Y=$TR(Y,"@"," ")
|
---|
73 | . S BSDXZ=BSDXZ_Y_"^"
|
---|
74 | S BSDXPATD=$P(BSDXNOD,U,5)
|
---|
75 | S BSDXZ=BSDXZ_BSDXPATD_"^" ;PATIENT ID
|
---|
76 | S BSDXPAT=""
|
---|
77 | I BSDXPATD]"",$D(^DPT(BSDXPATD,0)) S BSDXPAT=$P(^DPT(BSDXPATD,0),U)
|
---|
78 | S BSDXZ=BSDXZ_BSDXPAT_"^" ;PATIENT NAME
|
---|
79 | S BSDXZ=BSDXZ_BSDXRESN_"^" ;RESOURCENAME
|
---|
80 | S BSDXZ=BSDXZ_+$P(BSDXNOD,U,10)_"^" ;NOSHOW
|
---|
81 | S BSDXHRN=""
|
---|
82 | I $D(DUZ(2)),DUZ(2)>0 S BSDXHRN=$P($G(^AUPNPAT(BSDXPATD,41,DUZ(2),0)),U,2) ;HRN
|
---|
83 | S BSDXZ=BSDXZ_BSDXHRN_"^"
|
---|
84 | S BSDXATID=$P(BSDXNOD,U,6)
|
---|
85 | S:'+BSDXATID BSDXATID=0 ;UNKNOWN TYPE
|
---|
86 | S BSDXZ=BSDXZ_BSDXATID_"^"_BSDXISWK_"^"
|
---|
87 | S BSDXI=BSDXI+1
|
---|
88 | S ^BSDXTMP($J,BSDXI)=BSDXZ
|
---|
89 | ;NOTE
|
---|
90 | S BSDXNOT="",BSDXQ=0 F S BSDXQ=$O(^BSDXAPPT(BSDXAD,1,BSDXQ)) Q:'+BSDXQ D
|
---|
91 | . S BSDXNOT=$G(^BSDXAPPT(BSDXAD,1,BSDXQ,0))
|
---|
92 | . S:$E(BSDXNOT,$L(BSDXNOT)-1,$L(BSDXNOT))'=" " BSDXNOT=BSDXNOT_" "
|
---|
93 | . S BSDXI=BSDXI+1
|
---|
94 | . S ^BSDXTMP($J,BSDXI)=BSDXNOT
|
---|
95 | S ^BSDXTMP($J,BSDXI)=^BSDXTMP($J,BSDXI)_U ; Add "^" to separate note from next fields.
|
---|
96 | S BSDXI=BSDXI+1
|
---|
97 | ; new code for V1.5. Extra fields to return.
|
---|
98 | N SEX S SEX=$$GET1^DIQ(2,BSDXPATD,.02) ; SEX
|
---|
99 | N PID S PID=$$GET1^DIQ(2,BSDXPATD,.363) ; PRIMARY LONG ID
|
---|
100 | ; Note strange way I retrieve the value. B/c DOB Output Transform
|
---|
101 | ; Outputs it in MM/DD/YYYY format, which is ambigous for C#.
|
---|
102 | N DOB S DOB=$$FMTE^XLFDT($$GET1^DIQ(2,BSDXPATD,.03,"I")) ; DOB
|
---|
103 | N RADEX S RADEX=$P(BSDXNOD,U,14) ;Radiology exam
|
---|
104 | S ^BSDXTMP($J,BSDXI)=SEX_U_PID_U_DOB_U_RADEX_$C(30)
|
---|
105 | ; end new code
|
---|
106 | Q
|
---|
107 | ;
|
---|
108 | ERR(BSDXI,BSDXERR) ;Error processing
|
---|
109 | S BSDXI=BSDXI+1
|
---|
110 | S ^BSDXTMP($J,BSDXI)="0^^^^^^^^^^^"_BSDXERR_$C(30)
|
---|
111 | S BSDXI=BSDXI+1
|
---|
112 | S ^BSDXTMP($J,BSDXI)=$C(31)
|
---|
113 | Q
|
---|
114 | ;
|
---|
115 | ETRAP ;EP Error trap entry
|
---|
116 | D ^%ZTER
|
---|
117 | I '$D(BSDXI) N BSDXI S BSDXI=999999
|
---|
118 | S BSDXI=BSDXI+1
|
---|
119 | D ERR(BSDXI,"BSDX31 Error: "_$G(%ZTERROR))
|
---|
120 | Q
|
---|