source: Scheduling/trunk/cs/bsdx0200GUISourceCode/DApptSearch.cs@ 1110

Last change on this file since 1110 was 1106, checked in by Sam Habiel, 14 years ago

CalendarGrid:

  • Support for Autoscrolling corrected.
  • A little optimization: Grid is only drawn once now when starting, not twice (don't know why original code did that).

CGAppointment:

  • Added member Patient (new Class)

CGDocument:

  • OnOpenDocument now accepts input of DateTime to decide where to open document.
  • SlotsAvailable algorithm now includes code for scaling according to timescale and code to merge Blocks if they are adjacent.

CGDocumentManager:

  • Fix bug having to do with canceling log-in after first retry. BMX lib threw an exception which was not caught.

CGView: Many changes:

  • SlotsAvailable signature changed in CGDocument. All references to it had to be changed.
  • Opening a node in the tvSchedules by clicking on the plus sign did not select it. Code changes to make it select it.
  • UpdateStatusBar now uses a string builder; and shows a more comprehensive message on the availability in the Status Bar.
  • Focus issues on various controls.
  • Support for printing a slip after an appointment is made automatically has been added.

CustomPrinting:

  • now includes a method to print a single appointment slip

DAppointPage:

  • Checkbox to decide whether to print appt slip added.
  • New readonly property to get the appointment that has been made (of type CGAppointment).

DApptSearch:

  • StartDate and EndDate now autoadjust based on each other.
  • lblMessage added to show user message if no appointments are found.
File size: 43.0 KB
Line 
1using System;
2using System.Collections;
3using System.Collections.Generic;
4using System.Windows.Forms;
5using System.Data;
6using System.Linq;
7//using System.Data.OleDb;
8
9namespace IndianHealthService.ClinicalScheduling
10{
11 /// <summary>
12 /// Modal Dialog for searching for Patient Slots
13 /// </summary>
14 public class DApptSearch : System.Windows.Forms.Form
15 {
16 private System.Windows.Forms.Panel panel1;
17 private System.Windows.Forms.Button cmdCancel;
18 private System.Windows.Forms.Button btnAccept;
19 private System.Windows.Forms.Panel pnlDescription;
20 private System.Windows.Forms.GroupBox grpDescription;
21 private System.Windows.Forms.Label lblDescription;
22 private System.Windows.Forms.GroupBox groupBox1;
23 private System.Windows.Forms.Label label3;
24 private System.Windows.Forms.Label label2;
25 private System.Windows.Forms.CheckedListBox lstAccessTypes;
26 private System.Windows.Forms.ComboBox cboAccessTypeFilter;
27 private System.Windows.Forms.GroupBox grpDayOfWeek;
28 private System.Windows.Forms.CheckBox chkSun;
29 private System.Windows.Forms.CheckBox chkSat;
30 private System.Windows.Forms.CheckBox chkFri;
31 private System.Windows.Forms.CheckBox chkThu;
32 private System.Windows.Forms.CheckBox chkWed;
33 private System.Windows.Forms.CheckBox chkTue;
34 private System.Windows.Forms.CheckBox chkMon;
35 private System.Windows.Forms.GroupBox grpTimeOfDay;
36 private System.Windows.Forms.RadioButton rdoBoth;
37 private System.Windows.Forms.RadioButton rdoPM;
38 private System.Windows.Forms.RadioButton rdoAM;
39 private System.Windows.Forms.Label label1;
40 private System.Windows.Forms.GroupBox groupBox2;
41 private System.Windows.Forms.Button cmdSearch;
42 private ListView lstResults;
43 private ColumnHeader colStartTime;
44 private ColumnHeader colEndTime;
45 private ColumnHeader colResource;
46 private ColumnHeader colSlots;
47 private ColumnHeader colAccessType;
48 private ColumnHeader colDate;
49 private Label lblEnd;
50 private Label lblStart;
51 private DateTimePicker dtEnd;
52 private DateTimePicker dtStart;
53 private ColumnHeader colDOW;
54 private ColumnHeader colID;
55 private Label lblMessage;
56
57 private System.ComponentModel.IContainer components;
58
59 public DApptSearch()
60 {
61 InitializeComponent();
62 }
63
64 #region Fields
65
66 private CGDocumentManager m_DocManager;
67
68 private DataSet m_dsGlobal;
69 DataTable m_dtTypes;
70 DataView m_dvTypes;
71 List<CGAvailability> lstResultantAvailabilities;
72 private CGAvailability _selectedAvailability;
73 DateTime m_dStart;
74 DateTime m_dEnd;
75 ArrayList m_alResources;
76 ArrayList m_alAccessTypes;
77 string m_sWeekDays; //only practical use now is for sending to server
78 string m_sAmpm; // same here.
79
80 #endregion Fields
81
82 #region Methods
83
84 public void LoadListBox(string sGroup)
85 {
86 if (sGroup == "ALL")
87 {
88 //Load the Access Type list box with ALL access types
89 m_dtTypes = m_dsGlobal.Tables["AccessTypes"];
90 m_dvTypes = new DataView(m_dtTypes);
91 lstAccessTypes.DataSource = m_dvTypes;
92 lstAccessTypes.DisplayMember = "ACCESS_TYPE_NAME";
93 lstAccessTypes.Tag = 1; //This holds the column index of the ACCESS_TYPE_NAME column
94 lstAccessTypes.ValueMember = "BMXIEN";
95 }
96 else
97 {
98 //Load the Access Type list box with active access types belonging
99 //to group sGroup
100
101 //Build AccessGroup table containing *active* AccessTypes and their Groups
102 m_dtTypes = m_dsGlobal.Tables["AccessGroupType"];
103 //Create a view that is filterable on Access Group
104 m_dvTypes = new DataView(m_dtTypes);
105 m_dvTypes.RowFilter = "ACCESS_GROUP = '" + this.cboAccessTypeFilter.Text + "'";
106 lstAccessTypes.DataSource = m_dvTypes;
107 lstAccessTypes.DisplayMember = "ACCESS_TYPE";
108 lstAccessTypes.ValueMember = "ACCESS_TYPE_ID";
109 lstAccessTypes.Tag = 4; //This holds the column index of the ACCESS_TYPE column
110 }
111 }
112
113 public void InitializePage(ArrayList alResources, CGDocumentManager docManager)
114 {
115
116 this.Text = "Searching for Appointments in: " + string.Join(" | ", alResources.Cast<string>());
117
118 this.m_DocManager = docManager;
119 this.m_dsGlobal = m_DocManager.GlobalDataSet;
120
121 LoadListBox("ALL");
122
123 m_dStart = DateTime.Today;
124 m_dEnd = new DateTime(9999);
125 this.m_alResources = alResources;
126 this.m_alAccessTypes = new ArrayList();
127 this.m_sAmpm="both";
128 this.m_sWeekDays = "";
129
130 //Load filter combo with list of access type groups
131 DataTable dtGroup = m_dsGlobal.Tables["AccessGroup"];
132 DataSet dsTemp = new DataSet("dsTemp");
133 dsTemp.Tables.Add(dtGroup.Copy());
134 DataTable dtTemp = dsTemp.Tables["AccessGroup"];
135 DataView dvGroup = new DataView(dtTemp);
136 DataRowView drv = dvGroup.AddNew();
137 drv["ACCESS_GROUP"]="<Show All Access Types>";
138 cboAccessTypeFilter.DataSource = dvGroup;
139 cboAccessTypeFilter.DisplayMember = "ACCESS_GROUP";
140 cboAccessTypeFilter.SelectedText = "<Show All Access Types>";
141 cboAccessTypeFilter.SelectedIndex = cboAccessTypeFilter.Items.Count - 1;
142 cboAccessTypeFilter.Refresh();
143
144
145 /* OLD CODE
146 //Create DataGridTableStyle for Result grid
147 DataGridTableStyle tsResult = new DataGridTableStyle();
148 tsResult.MappingName = "Result";
149 tsResult.ReadOnly = true;
150
151 // Add START_TIME column style.
152 DataGridTextBoxColumn colStartTime = new DataGridTextBoxColumn();
153 colStartTime.MappingName = "StartTime";
154 colStartTime.HeaderText = "Start Time";
155 colStartTime.Width = 200;
156 colStartTime.Format = "f";
157 tsResult.GridColumnStyles.Add(colStartTime);
158
159 // Add END_TIME column style.
160 DataGridTextBoxColumn colEndTime = new DataGridTextBoxColumn();
161 colEndTime.MappingName = "EndTime";
162 colEndTime.HeaderText = "End Time";
163 colEndTime.Width = 75;
164 colEndTime.Format = "h:mm tt";
165 tsResult.GridColumnStyles.Add(colEndTime);
166
167 // Add RESOURCE column style.
168 DataGridTextBoxColumn colResource = new DataGridTextBoxColumn();
169 colResource.MappingName = "ResourceList";
170 colResource.HeaderText = "Resource";
171 colResource.Width = 200;
172 tsResult.GridColumnStyles.Add(colResource);
173
174 // Add SLOTS column style.
175 DataGridTextBoxColumn colSlots = new DataGridTextBoxColumn();
176 colSlots.MappingName = "SLOTS";
177 colSlots.HeaderText = "Slots";
178 colSlots.Width = 50;
179 tsResult.GridColumnStyles.Add(colSlots);
180
181 // Add AMPM column style.
182 DataGridTextBoxColumn colAccess = new DataGridTextBoxColumn();
183 colAccess.MappingName = "ACCESSNAME";
184 colAccess.HeaderText = "Access Type";
185 colAccess.Width = 200;
186 tsResult.GridColumnStyles.Add(colAccess);
187 //grdResult.TableStyles.Add(tsResult);
188 */
189
190 this.UpdateDialogData(true);
191
192 }
193
194 /// <summary>
195 /// If b is true, moves member vars into control data
196 /// otherwise, moves control data into member vars
197 /// </summary>
198 /// <param name="b"></param>
199 private void UpdateDialogData(bool b)
200 {
201 if (b == true) //move member vars into controls
202 {
203
204 }
205 else //move control data into member vars
206 {
207
208 //Build AccessType list
209
210 this.m_alAccessTypes.Clear();
211
212 for (int j = 0; j < this.lstAccessTypes.CheckedItems.Count; j++)
213 {
214 DataRowView drv = (DataRowView) lstAccessTypes.CheckedItems[j];
215 int nIndex = (int) lstAccessTypes.Tag;
216 string sItem = drv.Row.ItemArray[nIndex].ToString();
217 m_alAccessTypes.Add(sItem);
218 }
219
220 //AM/PM
221 this.m_sAmpm = (this.rdoAM.Checked == true) ? "AM":"BOTH";
222 if (this.m_sAmpm != "AM")
223 this.m_sAmpm = (this.rdoPM.Checked == true) ? "PM":"BOTH";
224
225
226 //Weekday
227 this.m_sWeekDays = ""; //any
228 if (chkMon.Checked == true)
229 m_sWeekDays += "Monday";
230 if (chkTue.Checked == true)
231 m_sWeekDays += "Tuesday";
232 if (chkWed.Checked == true)
233 m_sWeekDays += "Wednesday";
234 if (chkThu.Checked == true)
235 m_sWeekDays += "Thursday";
236 if (chkFri.Checked == true)
237 m_sWeekDays += "Friday";
238 if (chkSat.Checked == true)
239 m_sWeekDays += "Saturday";
240 if (chkSun.Checked == true)
241 m_sWeekDays += "Sunday";
242
243 //Start
244 this.m_dStart = this.dtStart.Value;
245
246 //End
247 this.m_dEnd = this.dtEnd.Value;
248 }
249 }
250
251
252 /// <summary>
253 /// Clean up any resources being used.
254 /// </summary>
255 protected override void Dispose( bool disposing )
256 {
257 if( disposing )
258 {
259 if(components != null)
260 {
261 components.Dispose();
262 }
263 }
264 base.Dispose( disposing );
265 }
266
267 #endregion Methods
268
269 #region Windows Form Designer generated code
270 /// <summary>
271 /// Required method for Designer support - do not modify
272 /// the contents of this method with the code editor.
273 /// </summary>
274 private void InitializeComponent()
275 {
276 this.panel1 = new System.Windows.Forms.Panel();
277 this.cmdSearch = new System.Windows.Forms.Button();
278 this.cmdCancel = new System.Windows.Forms.Button();
279 this.btnAccept = new System.Windows.Forms.Button();
280 this.pnlDescription = new System.Windows.Forms.Panel();
281 this.grpDescription = new System.Windows.Forms.GroupBox();
282 this.lblDescription = new System.Windows.Forms.Label();
283 this.groupBox1 = new System.Windows.Forms.GroupBox();
284 this.lblEnd = new System.Windows.Forms.Label();
285 this.lblStart = new System.Windows.Forms.Label();
286 this.dtEnd = new System.Windows.Forms.DateTimePicker();
287 this.dtStart = new System.Windows.Forms.DateTimePicker();
288 this.label3 = new System.Windows.Forms.Label();
289 this.label2 = new System.Windows.Forms.Label();
290 this.lstAccessTypes = new System.Windows.Forms.CheckedListBox();
291 this.cboAccessTypeFilter = new System.Windows.Forms.ComboBox();
292 this.grpDayOfWeek = new System.Windows.Forms.GroupBox();
293 this.chkSun = new System.Windows.Forms.CheckBox();
294 this.chkSat = new System.Windows.Forms.CheckBox();
295 this.chkFri = new System.Windows.Forms.CheckBox();
296 this.chkThu = new System.Windows.Forms.CheckBox();
297 this.chkWed = new System.Windows.Forms.CheckBox();
298 this.chkTue = new System.Windows.Forms.CheckBox();
299 this.chkMon = new System.Windows.Forms.CheckBox();
300 this.grpTimeOfDay = new System.Windows.Forms.GroupBox();
301 this.rdoBoth = new System.Windows.Forms.RadioButton();
302 this.rdoPM = new System.Windows.Forms.RadioButton();
303 this.rdoAM = new System.Windows.Forms.RadioButton();
304 this.label1 = new System.Windows.Forms.Label();
305 this.groupBox2 = new System.Windows.Forms.GroupBox();
306 this.lstResults = new System.Windows.Forms.ListView();
307 this.colID = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
308 this.colDate = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
309 this.colDOW = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
310 this.colStartTime = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
311 this.colEndTime = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
312 this.colResource = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
313 this.colSlots = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
314 this.colAccessType = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
315 this.lblMessage = new System.Windows.Forms.Label();
316 this.panel1.SuspendLayout();
317 this.pnlDescription.SuspendLayout();
318 this.grpDescription.SuspendLayout();
319 this.groupBox1.SuspendLayout();
320 this.grpDayOfWeek.SuspendLayout();
321 this.grpTimeOfDay.SuspendLayout();
322 this.groupBox2.SuspendLayout();
323 this.SuspendLayout();
324 //
325 // panel1
326 //
327 this.panel1.Controls.Add(this.lblMessage);
328 this.panel1.Controls.Add(this.cmdSearch);
329 this.panel1.Controls.Add(this.cmdCancel);
330 this.panel1.Controls.Add(this.btnAccept);
331 this.panel1.Dock = System.Windows.Forms.DockStyle.Bottom;
332 this.panel1.Location = new System.Drawing.Point(0, 461);
333 this.panel1.Name = "panel1";
334 this.panel1.Size = new System.Drawing.Size(923, 40);
335 this.panel1.TabIndex = 4;
336 //
337 // cmdSearch
338 //
339 this.cmdSearch.Location = new System.Drawing.Point(33, 6);
340 this.cmdSearch.Name = "cmdSearch";
341 this.cmdSearch.Size = new System.Drawing.Size(72, 24);
342 this.cmdSearch.TabIndex = 2;
343 this.cmdSearch.Text = "Search";
344 this.cmdSearch.Click += new System.EventHandler(this.cmdSearch_Click);
345 //
346 // cmdCancel
347 //
348 this.cmdCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel;
349 this.cmdCancel.Location = new System.Drawing.Point(828, 8);
350 this.cmdCancel.Name = "cmdCancel";
351 this.cmdCancel.Size = new System.Drawing.Size(64, 24);
352 this.cmdCancel.TabIndex = 1;
353 this.cmdCancel.Text = "Cancel";
354 //
355 // btnAccept
356 //
357 this.btnAccept.DialogResult = System.Windows.Forms.DialogResult.OK;
358 this.btnAccept.Location = new System.Drawing.Point(135, 8);
359 this.btnAccept.Name = "btnAccept";
360 this.btnAccept.Size = new System.Drawing.Size(176, 24);
361 this.btnAccept.TabIndex = 0;
362 this.btnAccept.Text = "Select Slot for Appointment";
363 this.btnAccept.Click += new System.EventHandler(this.btnAccept_Click);
364 //
365 // pnlDescription
366 //
367 this.pnlDescription.Controls.Add(this.grpDescription);
368 this.pnlDescription.Dock = System.Windows.Forms.DockStyle.Bottom;
369 this.pnlDescription.Location = new System.Drawing.Point(0, 397);
370 this.pnlDescription.Name = "pnlDescription";
371 this.pnlDescription.Size = new System.Drawing.Size(923, 64);
372 this.pnlDescription.TabIndex = 47;
373 //
374 // grpDescription
375 //
376 this.grpDescription.Controls.Add(this.lblDescription);
377 this.grpDescription.Dock = System.Windows.Forms.DockStyle.Fill;
378 this.grpDescription.Location = new System.Drawing.Point(0, 0);
379 this.grpDescription.Name = "grpDescription";
380 this.grpDescription.Size = new System.Drawing.Size(923, 64);
381 this.grpDescription.TabIndex = 0;
382 this.grpDescription.TabStop = false;
383 this.grpDescription.Text = "Description";
384 //
385 // lblDescription
386 //
387 this.lblDescription.Dock = System.Windows.Forms.DockStyle.Fill;
388 this.lblDescription.Location = new System.Drawing.Point(3, 16);
389 this.lblDescription.Name = "lblDescription";
390 this.lblDescription.Size = new System.Drawing.Size(917, 45);
391 this.lblDescription.TabIndex = 1;
392 this.lblDescription.Text = "Search for available appointment times using this panel. You may narrow your sea" +
393 "rch by selecting an access type or by selecting specific days of the week or tim" +
394 "es of day.";
395 //
396 // groupBox1
397 //
398 this.groupBox1.Controls.Add(this.lblEnd);
399 this.groupBox1.Controls.Add(this.lblStart);
400 this.groupBox1.Controls.Add(this.dtEnd);
401 this.groupBox1.Controls.Add(this.dtStart);
402 this.groupBox1.Controls.Add(this.label3);
403 this.groupBox1.Controls.Add(this.label2);
404 this.groupBox1.Controls.Add(this.lstAccessTypes);
405 this.groupBox1.Controls.Add(this.cboAccessTypeFilter);
406 this.groupBox1.Controls.Add(this.grpDayOfWeek);
407 this.groupBox1.Controls.Add(this.grpTimeOfDay);
408 this.groupBox1.Controls.Add(this.label1);
409 this.groupBox1.Dock = System.Windows.Forms.DockStyle.Top;
410 this.groupBox1.Location = new System.Drawing.Point(0, 0);
411 this.groupBox1.Name = "groupBox1";
412 this.groupBox1.Size = new System.Drawing.Size(923, 208);
413 this.groupBox1.TabIndex = 56;
414 this.groupBox1.TabStop = false;
415 this.groupBox1.Text = "Search Parameters";
416 //
417 // lblEnd
418 //
419 this.lblEnd.AutoSize = true;
420 this.lblEnd.Location = new System.Drawing.Point(12, 124);
421 this.lblEnd.Name = "lblEnd";
422 this.lblEnd.Size = new System.Drawing.Size(153, 13);
423 this.lblEnd.TabIndex = 67;
424 this.lblEnd.Text = "End Date to Search (Inclusive)";
425 //
426 // lblStart
427 //
428 this.lblStart.AutoSize = true;
429 this.lblStart.Location = new System.Drawing.Point(12, 35);
430 this.lblStart.Name = "lblStart";
431 this.lblStart.Size = new System.Drawing.Size(159, 13);
432 this.lblStart.TabIndex = 66;
433 this.lblStart.Text = "Start Date to Search (Inclusive)";
434 //
435 // dtEnd
436 //
437 this.dtEnd.Location = new System.Drawing.Point(12, 141);
438 this.dtEnd.Name = "dtEnd";
439 this.dtEnd.Size = new System.Drawing.Size(200, 20);
440 this.dtEnd.TabIndex = 65;
441 this.dtEnd.ValueChanged += new System.EventHandler(this.dtEnd_ValueChanged);
442 //
443 // dtStart
444 //
445 this.dtStart.Location = new System.Drawing.Point(12, 54);
446 this.dtStart.Name = "dtStart";
447 this.dtStart.Size = new System.Drawing.Size(200, 20);
448 this.dtStart.TabIndex = 64;
449 this.dtStart.ValueChanged += new System.EventHandler(this.dtStart_ValueChanged);
450 //
451 // label3
452 //
453 this.label3.Location = new System.Drawing.Point(684, 64);
454 this.label3.Name = "label3";
455 this.label3.Size = new System.Drawing.Size(80, 16);
456 this.label3.TabIndex = 63;
457 this.label3.Text = "Access Type:";
458 //
459 // label2
460 //
461 this.label2.Location = new System.Drawing.Point(684, 21);
462 this.label2.Name = "label2";
463 this.label2.Size = new System.Drawing.Size(104, 16);
464 this.label2.TabIndex = 62;
465 this.label2.Text = "Access Group:";
466 //
467 // lstAccessTypes
468 //
469 this.lstAccessTypes.CheckOnClick = true;
470 this.lstAccessTypes.HorizontalScrollbar = true;
471 this.lstAccessTypes.Location = new System.Drawing.Point(661, 88);
472 this.lstAccessTypes.MultiColumn = true;
473 this.lstAccessTypes.Name = "lstAccessTypes";
474 this.lstAccessTypes.Size = new System.Drawing.Size(250, 109);
475 this.lstAccessTypes.TabIndex = 61;
476 //
477 // cboAccessTypeFilter
478 //
479 this.cboAccessTypeFilter.Location = new System.Drawing.Point(661, 40);
480 this.cboAccessTypeFilter.Name = "cboAccessTypeFilter";
481 this.cboAccessTypeFilter.Size = new System.Drawing.Size(250, 21);
482 this.cboAccessTypeFilter.TabIndex = 60;
483 this.cboAccessTypeFilter.Text = "cboAccessTypeFilter";
484 this.cboAccessTypeFilter.SelectionChangeCommitted += new System.EventHandler(this.cboAccessTypeFilter_SelectionChangeCommitted);
485 //
486 // grpDayOfWeek
487 //
488 this.grpDayOfWeek.Controls.Add(this.chkSun);
489 this.grpDayOfWeek.Controls.Add(this.chkSat);
490 this.grpDayOfWeek.Controls.Add(this.chkFri);
491 this.grpDayOfWeek.Controls.Add(this.chkThu);
492 this.grpDayOfWeek.Controls.Add(this.chkWed);
493 this.grpDayOfWeek.Controls.Add(this.chkTue);
494 this.grpDayOfWeek.Controls.Add(this.chkMon);
495 this.grpDayOfWeek.Location = new System.Drawing.Point(311, 94);
496 this.grpDayOfWeek.Name = "grpDayOfWeek";
497 this.grpDayOfWeek.Size = new System.Drawing.Size(240, 101);
498 this.grpDayOfWeek.TabIndex = 59;
499 this.grpDayOfWeek.TabStop = false;
500 this.grpDayOfWeek.Text = "Day of the Week";
501 //
502 // chkSun
503 //
504 this.chkSun.Location = new System.Drawing.Point(176, 64);
505 this.chkSun.Name = "chkSun";
506 this.chkSun.Size = new System.Drawing.Size(48, 16);
507 this.chkSun.TabIndex = 6;
508 this.chkSun.Text = "Sun";
509 //
510 // chkSat
511 //
512 this.chkSat.Location = new System.Drawing.Point(128, 64);
513 this.chkSat.Name = "chkSat";
514 this.chkSat.Size = new System.Drawing.Size(48, 16);
515 this.chkSat.TabIndex = 5;
516 this.chkSat.Text = "Sat";
517 //
518 // chkFri
519 //
520 this.chkFri.Location = new System.Drawing.Point(72, 64);
521 this.chkFri.Name = "chkFri";
522 this.chkFri.Size = new System.Drawing.Size(48, 16);
523 this.chkFri.TabIndex = 4;
524 this.chkFri.Text = "Fri";
525 //
526 // chkThu
527 //
528 this.chkThu.Location = new System.Drawing.Point(16, 64);
529 this.chkThu.Name = "chkThu";
530 this.chkThu.Size = new System.Drawing.Size(48, 16);
531 this.chkThu.TabIndex = 3;
532 this.chkThu.Text = "Thu";
533 //
534 // chkWed
535 //
536 this.chkWed.Location = new System.Drawing.Point(128, 32);
537 this.chkWed.Name = "chkWed";
538 this.chkWed.Size = new System.Drawing.Size(48, 16);
539 this.chkWed.TabIndex = 2;
540 this.chkWed.Text = "Wed";
541 //
542 // chkTue
543 //
544 this.chkTue.Location = new System.Drawing.Point(72, 32);
545 this.chkTue.Name = "chkTue";
546 this.chkTue.Size = new System.Drawing.Size(48, 16);
547 this.chkTue.TabIndex = 1;
548 this.chkTue.Text = "Tue";
549 //
550 // chkMon
551 //
552 this.chkMon.Location = new System.Drawing.Point(16, 32);
553 this.chkMon.Name = "chkMon";
554 this.chkMon.Size = new System.Drawing.Size(48, 16);
555 this.chkMon.TabIndex = 0;
556 this.chkMon.Text = "Mon";
557 //
558 // grpTimeOfDay
559 //
560 this.grpTimeOfDay.Controls.Add(this.rdoBoth);
561 this.grpTimeOfDay.Controls.Add(this.rdoPM);
562 this.grpTimeOfDay.Controls.Add(this.rdoAM);
563 this.grpTimeOfDay.Location = new System.Drawing.Point(311, 32);
564 this.grpTimeOfDay.Name = "grpTimeOfDay";
565 this.grpTimeOfDay.Size = new System.Drawing.Size(240, 48);
566 this.grpTimeOfDay.TabIndex = 58;
567 this.grpTimeOfDay.TabStop = false;
568 this.grpTimeOfDay.Text = "Time of Day";
569 //
570 // rdoBoth
571 //
572 this.rdoBoth.Checked = true;
573 this.rdoBoth.Location = new System.Drawing.Point(176, 24);
574 this.rdoBoth.Name = "rdoBoth";
575 this.rdoBoth.Size = new System.Drawing.Size(48, 16);
576 this.rdoBoth.TabIndex = 2;
577 this.rdoBoth.TabStop = true;
578 this.rdoBoth.Text = "Both";
579 //
580 // rdoPM
581 //
582 this.rdoPM.Location = new System.Drawing.Point(96, 24);
583 this.rdoPM.Name = "rdoPM";
584 this.rdoPM.Size = new System.Drawing.Size(72, 16);
585 this.rdoPM.TabIndex = 1;
586 this.rdoPM.Text = "PM Only";
587 //
588 // rdoAM
589 //
590 this.rdoAM.Location = new System.Drawing.Point(16, 24);
591 this.rdoAM.Name = "rdoAM";
592 this.rdoAM.Size = new System.Drawing.Size(72, 16);
593 this.rdoAM.TabIndex = 0;
594 this.rdoAM.Text = "AM Only";
595 //
596 // label1
597 //
598 this.label1.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
599 this.label1.Location = new System.Drawing.Point(6, 16);
600 this.label1.Name = "label1";
601 this.label1.Size = new System.Drawing.Size(136, 16);
602 this.label1.TabIndex = 57;
603 this.label1.Text = "Date Range:";
604 //
605 // groupBox2
606 //
607 this.groupBox2.Controls.Add(this.lstResults);
608 this.groupBox2.Dock = System.Windows.Forms.DockStyle.Fill;
609 this.groupBox2.Location = new System.Drawing.Point(0, 208);
610 this.groupBox2.Name = "groupBox2";
611 this.groupBox2.Size = new System.Drawing.Size(923, 189);
612 this.groupBox2.TabIndex = 57;
613 this.groupBox2.TabStop = false;
614 this.groupBox2.Text = "Search Result";
615 //
616 // lstResults
617 //
618 this.lstResults.Columns.AddRange(new System.Windows.Forms.ColumnHeader[] {
619 this.colID,
620 this.colDate,
621 this.colDOW,
622 this.colStartTime,
623 this.colEndTime,
624 this.colResource,
625 this.colSlots,
626 this.colAccessType});
627 this.lstResults.Dock = System.Windows.Forms.DockStyle.Fill;
628 this.lstResults.FullRowSelect = true;
629 this.lstResults.GridLines = true;
630 this.lstResults.Location = new System.Drawing.Point(3, 16);
631 this.lstResults.MultiSelect = false;
632 this.lstResults.Name = "lstResults";
633 this.lstResults.Size = new System.Drawing.Size(917, 170);
634 this.lstResults.TabIndex = 0;
635 this.lstResults.UseCompatibleStateImageBehavior = false;
636 this.lstResults.View = System.Windows.Forms.View.Details;
637 this.lstResults.DoubleClick += new System.EventHandler(this.lstResults_DoubleClick);
638 //
639 // colID
640 //
641 this.colID.Text = "ID";
642 this.colID.Width = 0;
643 //
644 // colDate
645 //
646 this.colDate.Text = "Date";
647 this.colDate.Width = 91;
648 //
649 // colDOW
650 //
651 this.colDOW.Text = "Day of Week";
652 this.colDOW.Width = 80;
653 //
654 // colStartTime
655 //
656 this.colStartTime.Text = "Start Time";
657 this.colStartTime.Width = 87;
658 //
659 // colEndTime
660 //
661 this.colEndTime.Text = "End Time";
662 this.colEndTime.Width = 116;
663 //
664 // colResource
665 //
666 this.colResource.Text = "Resource";
667 this.colResource.Width = 370;
668 //
669 // colSlots
670 //
671 this.colSlots.Text = "Slots";
672 this.colSlots.Width = 47;
673 //
674 // colAccessType
675 //
676 this.colAccessType.Text = "Access Type";
677 this.colAccessType.Width = 101;
678 //
679 // lblMessage
680 //
681 this.lblMessage.AutoSize = true;
682 this.lblMessage.Font = new System.Drawing.Font("Tahoma", 9.75F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
683 this.lblMessage.ForeColor = System.Drawing.Color.Red;
684 this.lblMessage.Location = new System.Drawing.Point(337, 16);
685 this.lblMessage.Name = "lblMessage";
686 this.lblMessage.Size = new System.Drawing.Size(0, 16);
687 this.lblMessage.TabIndex = 3;
688 //
689 // DApptSearch
690 //
691 this.AutoScaleBaseSize = new System.Drawing.Size(5, 13);
692 this.CancelButton = this.cmdCancel;
693 this.ClientSize = new System.Drawing.Size(923, 501);
694 this.Controls.Add(this.groupBox2);
695 this.Controls.Add(this.groupBox1);
696 this.Controls.Add(this.pnlDescription);
697 this.Controls.Add(this.panel1);
698 this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog;
699 this.Name = "DApptSearch";
700 this.Text = "Find Clinic Availability";
701 this.panel1.ResumeLayout(false);
702 this.panel1.PerformLayout();
703 this.pnlDescription.ResumeLayout(false);
704 this.grpDescription.ResumeLayout(false);
705 this.groupBox1.ResumeLayout(false);
706 this.groupBox1.PerformLayout();
707 this.grpDayOfWeek.ResumeLayout(false);
708 this.grpTimeOfDay.ResumeLayout(false);
709 this.groupBox2.ResumeLayout(false);
710 this.ResumeLayout(false);
711
712 }
713 #endregion
714
715 #region Event Handlers
716
717 private void cmdSearch_Click(object sender, System.EventArgs e)
718 {
719 //Tell user we are processing
720 this.Cursor = Cursors.WaitCursor;
721 this.lblMessage.Text = String.Empty;
722
723 //Get the control data into local vars
724 UpdateDialogData(false);
725 //Resource array, Begin date, Access type array, MTWTF , AM PM
726
727 //Get Availabilities and Appointments from the DB
728 //NB: m_sAmpm and m_sWeekDays don't have an effect on the M side side right now
729 string sSearchInfo = "1|" + m_sAmpm + "|" + m_sWeekDays;
730 DataTable m_availTable = CGSchedLib.CreateAvailabilitySchedule(m_DocManager, m_alResources, m_dStart, m_dEnd, m_alAccessTypes, ScheduleType.Resource, sSearchInfo);
731 DataTable m_apptTable = CGSchedLib.CreateAppointmentSchedule(m_DocManager, m_alResources, m_dStart, m_dEnd);
732
733#if DEBUG
734 System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
735 stopwatch.Start();
736#endif
737 lstResultantAvailabilities = (from rowAV in m_availTable.AsEnumerable()
738
739 // Calculate the number of slots consumed in this availability by appointments
740 let slotsConsumed = (from appt in m_apptTable.AsEnumerable()
741 //If the resource is the same and the user selection overlaps, then...
742 where (rowAV.Field<string>("RESOURCE") == appt.Field<string>("RESOURCENAME")
743 && CalendarGrid.TimesOverlap(rowAV.Field<DateTime>("START_TIME"), rowAV.Field<DateTime>("END_TIME"), appt.Field<DateTime>("START_TIME"), appt.Field<DateTime>("END_TIME")))
744 // if appt starttime is before avail start time, only count against the avail starting from the availability start time
745 let startTimeToCountAgainstBlock = appt.Field<DateTime>("START_TIME") < rowAV.Field<DateTime>("START_TIME") ? rowAV.Field<DateTime>("START_TIME") : appt.Field<DateTime>("START_TIME")
746 // if appt endtime is after the avail ends, only count against the avail up to where the avail ends
747 let endTimeToCountAgainstBlock = appt.Field<DateTime>("END_TIME") > rowAV.Field<DateTime>("END_TIME") ? rowAV.Field<DateTime>("END_TIME") : appt.Field<DateTime>("END_TIME")
748 // theoretical minutes per slot for the availability
749 let minPerSlot = (rowAV.Field<DateTime>("END_TIME") - rowAV.Field<DateTime>("START_TIME")).TotalMinutes / rowAV.Field<int>("SLOTS")
750 // how many minutes does this appointment take away from the slot
751 let minPerAppt = (endTimeToCountAgainstBlock - startTimeToCountAgainstBlock).TotalMinutes
752 // how many slots the appointment takes up using this availability's scale
753 let slotsConsumed = minPerAppt / minPerSlot
754 select slotsConsumed).Sum()
755
756 // Subtract the number consumed from the original ones
757 let slotsLeft = (float)rowAV.Field<int>("SLOTS") - slotsConsumed
758 // filter by that value if it is at least one slot
759 where slotsLeft >= 1
760 // Sort by Start Time, then by Resource Name
761 orderby rowAV.Field<DateTime>("START_TIME"), rowAV.Field<string>("RESOURCE")
762 //return as a CGAvailability
763 select new CGAvailability
764 {
765 ResourceList = rowAV.Field<string>("RESOURCE"),
766 StartTime = rowAV.Field<DateTime>("START_TIME"),
767 EndTime = rowAV.Field<DateTime>("END_TIME"),
768 Slots = (int)slotsLeft,
769 // AccessTypeName is grabbed from the Access Type Table using a psuedojoin syntax.
770 // "ACCESS_TYPE" is the IEN of the AcceesType.
771 // Single or default is b/c we are expecting one result.
772 AccessTypeName = (from at in m_dsGlobal.Tables["AccessTypes"].AsEnumerable()
773 where at.Field<int>("BMXIEN")==Int32.Parse(rowAV.Field<string>("ACCESS_TYPE"))
774 select at.Field<string>("ACCESS_TYPE_NAME")).SingleOrDefault<string>(),
775 AvailabilityType = rowAV.Field<int>("AVAILABILITYID")
776 })
777 // convert to Generic List
778 .ToList<CGAvailability>();
779
780 // if specific access types are chosen, filter the results based on a join against them.
781 if (m_alAccessTypes.Count > 0)
782 lstResultantAvailabilities = (from av in lstResultantAvailabilities
783 join at in m_alAccessTypes.Cast<string>() on av.AccessTypeName equals at
784 select av).ToList<CGAvailability>();
785
786 // if user chose AM radio button, get morning appointments
787 // TimeSpan.FromHours(12) gets the number of ticks since Midnight
788 if (rdoAM.Checked) // less than 12 pm
789 {
790 lstResultantAvailabilities = (from av in lstResultantAvailabilities
791 where av.StartTime.TimeOfDay < TimeSpan.FromHours(12)
792 select av).ToList<CGAvailability>();
793 }
794 // if user chose PM radio button, get morning appointments
795 if (rdoPM.Checked) // after or equal to 12 pm
796 {
797 lstResultantAvailabilities = (from av in lstResultantAvailabilities
798 where av.StartTime.TimeOfDay >= TimeSpan.FromHours(12)
799 select av).ToList<CGAvailability>();
800 }
801
802 // if any of the days of week are checked, create a new list based on them
803 // and clear the original list, and join the new lists together
804 if (chkMon.Checked || chkTue.Checked || chkWed.Checked || chkThu.Checked || chkFri.Checked || chkSat.Checked || chkSun.Checked)
805 {
806
807 var lstMonday = new List<CGAvailability>();
808 var lstTuesday = new List<CGAvailability>();
809 var lstWednesday = new List<CGAvailability>();
810 var lstThursday = new List<CGAvailability>();
811 var lstFriday = new List<CGAvailability>();
812 var lstSaturday = new List<CGAvailability>();
813 var lstSunday = new List<CGAvailability>();
814
815 if (chkMon.Checked == true)
816 {
817 lstMonday = (from av in lstResultantAvailabilities
818 where av.StartTime.DayOfWeek == DayOfWeek.Monday
819 select av).ToList<CGAvailability>();
820 }
821
822 if (chkTue.Checked == true)
823 {
824 lstTuesday = (from av in lstResultantAvailabilities
825 where av.StartTime.DayOfWeek == DayOfWeek.Tuesday
826 select av).ToList<CGAvailability>();
827 }
828
829 if (chkWed.Checked == true)
830 {
831 lstWednesday = (from av in lstResultantAvailabilities
832 where av.StartTime.DayOfWeek == DayOfWeek.Wednesday
833 select av).ToList<CGAvailability>();
834
835 }
836
837 if (chkThu.Checked == true)
838 {
839 lstThursday = (from av in lstResultantAvailabilities
840 where av.StartTime.DayOfWeek == DayOfWeek.Thursday
841 select av).ToList<CGAvailability>();
842
843 }
844
845 if (chkFri.Checked == true)
846 {
847 lstFriday = (from av in lstResultantAvailabilities
848 where av.StartTime.DayOfWeek == DayOfWeek.Friday
849 select av).ToList<CGAvailability>();
850 }
851
852 if (chkSat.Checked == true)
853 {
854 lstSaturday = (from av in lstResultantAvailabilities
855 where av.StartTime.DayOfWeek == DayOfWeek.Saturday
856 select av).ToList<CGAvailability>();
857
858 }
859
860 if (chkSun.Checked == true)
861 {
862 lstSunday = (from av in lstResultantAvailabilities
863 where av.StartTime.DayOfWeek == DayOfWeek.Sunday
864 select av).ToList<CGAvailability>();
865
866 }
867
868
869 lstResultantAvailabilities.Clear();
870 lstResultantAvailabilities.AddRange(lstMonday);
871 lstResultantAvailabilities.AddRange(lstTuesday);
872 lstResultantAvailabilities.AddRange(lstWednesday);
873 lstResultantAvailabilities.AddRange(lstThursday);
874 lstResultantAvailabilities.AddRange(lstFriday);
875 lstResultantAvailabilities.AddRange(lstSaturday);
876 lstResultantAvailabilities.AddRange(lstSunday);
877
878 lstResultantAvailabilities.OrderBy(av => av.StartTime).ThenBy(av => av.ResourceList);
879 }
880
881
882
883#if DEBUG
884 System.Diagnostics.Debug.Write("LINQ took this long: " + stopwatch.ElapsedMilliseconds + "\n");
885 stopwatch = null;
886#endif
887
888 //Then, convert the availabilities to ListViewItems
889 var items = (from item in lstResultantAvailabilities
890 let s = new string[] {item.AvailabilityType.ToString(), item.StartTime.ToShortDateString(), item.StartTime.DayOfWeek.ToString(),item.StartTime.ToShortTimeString() ,item.EndTime.ToShortTimeString() ,item.ResourceList,item.Slots.ToString(),item.AccessTypeName}
891 let lvItem = new ListViewItem(s)
892 select lvItem).ToArray<ListViewItem>();
893
894 //--Updating Listview
895 lstResults.BeginUpdate(); //tell listview to suspend drawing for now
896 lstResults.Items.Clear(); //empty it from old data
897
898 if (items.Length > 0) lstResults.Items.AddRange(items); // add new data
899 else this.lblMessage.Text = "No available Appointment Slots Found!";
900
901 lstResults.EndUpdate(); // ok done adding items, draw now.
902 //--End Update Listview
903
904 //We are done
905 this.Cursor = Cursors.Default;
906 }
907
908 private void cboAccessTypeFilter_SelectionChangeCommitted(object sender, System.EventArgs e)
909 {
910 //Load Access Types listbox & filter
911 string sGroup = cboAccessTypeFilter.Text;
912 if (sGroup == "<Show All Access Types>")
913 {
914 LoadListBox("ALL");
915 }
916 else
917 {
918 LoadListBox("SELECTED");
919 }
920
921 }
922
923
924 private void lstResults_DoubleClick(object sender, EventArgs e)
925 {
926 ProcessChoice(sender, e);
927 }
928
929 private void btnAccept_Click(object sender, EventArgs e)
930 {
931 ProcessChoice(sender, e);
932 }
933
934 /// <summary>
935 /// Shared method to process a user's choice
936 /// </summary>
937 /// <param name="s">sender</param>
938 /// <param name="e">EventArgs</param>
939 private void ProcessChoice(object s, EventArgs e)
940 {
941 if (lstResults.SelectedIndices.Count == 0)
942 {
943 this.DialogResult = DialogResult.None;
944 lblMessage.Text = "No Appointment Slot selected!";
945 return;
946 }
947
948 long availabilityKey = long.Parse(lstResults.SelectedItems[0].SubItems[0].Text);
949 _selectedAvailability = (from av in lstResultantAvailabilities
950 where av.AvailabilityType == availabilityKey
951 select av).Single<CGAvailability>();
952 this.DialogResult = DialogResult.OK;
953 }
954
955 /// <summary>
956 /// Adjust start date based on end date.
957 /// </summary>
958 /// <param name="sender"></param>
959 /// <param name="e"></param>
960 private void dtStart_ValueChanged(object sender, EventArgs e)
961 {
962 if (dtEnd.Value < dtStart.Value) dtEnd.Value = dtStart.Value;
963 }
964
965 /// <summary>
966 /// Adjust end date based on start date.
967 /// </summary>
968 /// <param name="sender"></param>
969 /// <param name="e"></param>
970 private void dtEnd_ValueChanged(object sender, EventArgs e)
971 {
972 if (dtStart.Value > dtEnd.Value) dtStart.Value = dtEnd.Value;
973 }
974
975 #endregion Event Handlers
976
977 #region Properties
978
979 /// <summary>
980 /// Gets the Availability Selected by the User in which to put an appointment
981 /// </summary>
982 public CGAvailability SelectedAvailability
983 {
984 get { return this._selectedAvailability; }
985 }
986
987 #endregion Properties
988
989
990 }
991}
Note: See TracBrowser for help on using the repository browser.