This repository has been archived by the owner on Sep 19, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
GotoDateForm.ascx.cs
90 lines (86 loc) · 4.76 KB
/
GotoDateForm.ascx.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
{************************************************************************************}
{ }
{ DO NOT MODIFY THIS FILE! }
{ }
{ It will be overwritten without prompting when a new version becomes }
{ available. All your changes will be lost. }
{ }
{ This file contains the default template and is required for the form }
{ rendering. Improper modifications may result in incorrect behavior of }
{ the appointment form. }
{ }
{ In order to create and use your own custom template, perform the following }
{ steps: }
{ 1. Save a copy of this file with a different name in another location. }
{ 2. Specify the file location as the 'OptionsForms.GotoDateFormTemplateUrl' }
{ property of the ASPxScheduler control. }
{ 3. If you need to display and process additional controls, you }
{ should accomplish steps 4-6; otherwise, go to step 7. }
{ 4. Create a class, derived from the GotoDateFormTemplateContainer, }
{ containing additional properties which correspond to your controls. }
{ This class definition can be located within a class file in the App_Code }
{ folder. }
{ 5. Replace GotoDateFormTemplateContainer references in the template page }
{ with the name of the class you've created in step 4. }
{ 6. Handle the GotoDateFormShowing event to create an instance of the }
{ template container class, defined in step 5, and specify it as the }
{ destination container instead of the default one. }
{ 7. Modify the overall appearance of the page and its layout. }
{ }
{************************************************************************************}
*/
using System;
using DevExpress.Web;
using DevExpress.Web.ASPxScheduler;
using DevExpress.Web.ASPxScheduler.Localization;
using System.Web.UI.WebControls;
public partial class GotoDateForm : SchedulerFormControl {
protected override void OnLoad(EventArgs e) {
base.OnLoad(e);
Localize();
//PrepareChildControls();
edtDate.Focus();
}
void Localize() {
lblDate.Text = ASPxSchedulerLocalizer.GetString(ASPxSchedulerStringId.Form_Date);
lblView.Text = ASPxSchedulerLocalizer.GetString(ASPxSchedulerStringId.Form_ShowIn);
btnOk.Text = ASPxSchedulerLocalizer.GetString(ASPxSchedulerStringId.Form_ButtonOk);
btnCancel.Text = ASPxSchedulerLocalizer.GetString(ASPxSchedulerStringId.Form_ButtonCancel);
}
public override void DataBind() {
base.DataBind();
GotoDateFormTemplateContainer container = (GotoDateFormTemplateContainer)Parent;
cbView.Value = container.ActiveViewType.ToString();
btnOk.ClientSideEvents.Click = container.ApplyHandler;
btnCancel.ClientSideEvents.Click = container.CancelHandler;
ASPxScheduler scheduler = container.Control;
string actualSchedulerInstanceName = scheduler.ClientInstanceName;
if(String.IsNullOrEmpty(actualSchedulerInstanceName))
actualSchedulerInstanceName = scheduler.ClientID;
edtDate.ClientSideEvents.LostFocus = String.Format(@"function(s,e) {{
var date = s.GetDate();
if (date == null || date == false) {{
var selectionInterval = {0}.GetSelectedInterval();
var startDate = selectionInterval.GetStart();
s.SetDate(startDate);
}}
}}", actualSchedulerInstanceName);
}
protected override ASPxEditBase[] GetChildEditors() {
ASPxEditBase[] edits = new ASPxEditBase[] {
lblDate, edtDate,
lblView, cbView
};
return edits;
}
protected override ASPxButton[] GetChildButtons() {
ASPxButton[] buttons = new ASPxButton[] {
btnOk, btnCancel
};
return buttons;
}
protected override WebControl GetDefaultButton() {
return btnOk;
}
}