' This file implements the TableControl, TableControlRow, and RecordControl classes for the ' ShowPersonalEducation.aspx page. The Row or RecordControl classes are the ' ideal place to add code customizations. For example, you can override the LoadData, ' CreateWhereClause, DataBind, SaveData, GetUIData, and Validate methods. #Region "Imports statements" Option Strict On Imports Microsoft.VisualBasic Imports BaseClasses.Web.UI.WebControls Imports System Imports System.Collections Imports System.Collections.Generic Imports System.Web Imports System.Web.UI Imports System.Web.UI.WebControls Imports BaseClasses Imports BaseClasses.Data Imports BaseClasses.Utils Imports ReportTools.ReportCreator Imports ReportTools.Shared Imports Persons.Business Imports Persons.Data #End Region Namespace Persons.UI.Controls.ShowPersonalEducation #Region "Section 1: Place your customizations here." Public Class PersonalEducationRecordControl Inherits BasePersonalEducationRecordControl ' The BasePersonalEducationRecordControl implements the LoadData, DataBind and other ' methods to load and display the data in a table control. ' This is the ideal place to add your code customizations. For example, you can override the LoadData, ' CreateWhereClause, DataBind, SaveData, GetUIData, and Validate methods. End Class #End Region #Region "Section 2: Do not modify this section." ' Base class for the PersonalEducationRecordControl control on the ShowPersonalEducation page. ' Do not modify this class. Instead override any method in PersonalEducationRecordControl. Public Class BasePersonalEducationRecordControl Inherits Persons.UI.BaseApplicationRecordControl ' To customize, override this method in PersonalEducationRecordControl. Protected Overridable Sub Control_Init(ByVal sender As Object, ByVal e As System.EventArgs) Handles MyBase.Init ' Setup the filter and search events. Me.ClearControlsFromSession() End Sub ' To customize, override this method in PersonalEducationRecordControl. Protected Overridable Sub Control_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles MyBase.Load ' Setup the pagination events. ' Register the event handlers. AddHandler Me.PersonalEducationDialogEditButton.Click, AddressOf PersonalEducationDialogEditButton_Click AddHandler Me.PersonalId.Click, AddressOf PersonalId_Click End Sub Public Overridable Sub LoadData() ' Load the data from the database into the DataSource PersonalEducation record. ' It is better to make changes to functions called by LoadData such as ' CreateWhereClause, rather than making changes here. ' The RecordUniqueId is set the first time a record is loaded, and is ' used during a PostBack to load the record. If Me.RecordUniqueId IsNot Nothing AndAlso Me.RecordUniqueId.Trim <> "" Then Me.DataSource = PersonalEducationTable.GetRecord(Me.RecordUniqueId, True) Return End If ' This is the first time a record is being retrieved from the database. ' So create a Where Clause based on the staic Where clause specified ' on the Query wizard and the dynamic part specified by the end user ' on the search and filter controls (if any). Dim wc As WhereClause = Me.CreateWhereClause() Dim Panel As System.Web.UI.WebControls.Panel = CType(MiscUtils.FindControlRecursively(Me, "PersonalEducationRecordControlPanel"), System.Web.UI.WebControls.Panel) If Not Panel is Nothing Then Panel.visible = True End If ' If there is no Where clause, then simply create a new, blank record. If wc Is Nothing OrElse Not wc.RunQuery Then Me.DataSource = New PersonalEducationRecord() If Not Panel is Nothing Then Panel.visible = False End If Return End If ' Retrieve the record from the database. It is possible Dim recList() As PersonalEducationRecord = PersonalEducationTable.GetRecords(wc, Nothing, 0, 2) If recList.Length = 0 Then ' There is no data for this Where clause. wc.RunQuery = False If Not Panel is Nothing Then Panel.visible = False End If Return End If ' Set DataSource based on record retrieved from the database. Me.DataSource = PersonalEducationTable.GetRecord(recList(0).GetID.ToXmlString(), True) End Sub ' Populate the UI controls using the DataSource. To customize, override this method in PersonalEducationRecordControl. Public Overrides Sub DataBind() ' The DataBind method binds the user interface controls to the values ' from the database record. To do this, it calls the Set methods for ' each of the field displayed on the webpage. It is better to make ' changes in the Set methods, rather than making changes here. MyBase.DataBind() ' Make sure that the DataSource is initialized. If Me.DataSource Is Nothing Then Return End If 'LoadData for DataSource for chart and report if they exist ' Call the Set methods for each controls on the panel SetCommand() SetCommandDate() SetCommandDateLabel() SetCommandLabel() SetCOUNTRY() SetCOUNTRYLabel() SetCourse() SetCourseAbbr() SetCourseAbbrLabel() SetCourseLabel() SetCourseNo() SetCourseNoLabel() SetEducationPeriod() SetEducationPeriodLabel() SetEducationType() SetEducationTypeLabel() SetEdYear() SetEdYearLabel() SetEndDate() SetEndDateLabel() SetFacultry() SetFacultryLabel() SetInstitue() SetInstitueLabel() SetLevelId() SetLevelIdLabel() SetNoAll() SetNoAllLabel() SetPersonalEducationRecordControlCollapsibleRegion() SetPersonalEducationRecordControlIcon() SetPersonalEducationRecordControlPanelExtender() SetPersonalId() SetPersonalIdLabel() SetScore() SetScoreLabel() SetScoreNo() SetScoreNoLabel() SetStartDate() SetStartDateLabel() Me.IsNewRecord = True If Me.DataSource.IsCreated Then Me.IsNewRecord = False Me.RecordUniqueId = Me.DataSource.GetID.ToXmlString() End If ' Now load data for each record and table child UI controls. ' Ordering is important because child controls get ' their parent ids from their parent UI controls. Dim shouldResetControl As Boolean = False End Sub Public Overridable Sub SetCommand() ' Set the Command Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.Command is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetCommand() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.CommandSpecified Then ' If the Command is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.Command) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.Command.Text = formattedValue Else ' Command is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.Command.Text = PersonalEducationTable.Command.Format(PersonalEducationTable.Command.DefaultValue) End If ' If the Command is NULL or blank, then use the value specified ' on Properties. If Me.Command.Text Is Nothing _ OrElse Me.Command.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.Command.Text = " " End If End Sub Public Overridable Sub SetCommandDate() ' Set the CommandDate Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.CommandDate is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetCommandDate() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.CommandDateSpecified Then ' If the CommandDate is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.CommandDate, "d MMM yy") formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.CommandDate.Text = formattedValue Else ' CommandDate is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.CommandDate.Text = PersonalEducationTable.CommandDate.Format(PersonalEducationTable.CommandDate.DefaultValue, "d MMM yy") End If ' If the CommandDate is NULL or blank, then use the value specified ' on Properties. If Me.CommandDate.Text Is Nothing _ OrElse Me.CommandDate.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.CommandDate.Text = " " End If End Sub Public Overridable Sub SetCOUNTRY() ' Set the COUNTRY Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.COUNTRY is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetCOUNTRY() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.COUNTRYSpecified Then ' If the COUNTRY is non-NULL, then format the value. ' The Format method will return the Display Foreign Key As (DFKA) value Dim formattedValue As String = "" Dim _isExpandableNonCompositeForeignKey As Boolean = PersonalEducationTable.Instance.TableDefinition.IsExpandableNonCompositeForeignKey(PersonalEducationTable.COUNTRY) If _isExpandableNonCompositeForeignKey AndAlso PersonalEducationTable.COUNTRY.IsApplyDisplayAs Then formattedValue = PersonalEducationTable.GetDFKA(Me.DataSource.COUNTRY.ToString(),PersonalEducationTable.COUNTRY, Nothing) if (formattedValue Is Nothing) Then formattedValue = Me.DataSource.Format(PersonalEducationTable.COUNTRY) End If Else formattedValue = Me.DataSource.COUNTRY.ToString() End If formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.COUNTRY.Text = formattedValue Else ' COUNTRY is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.COUNTRY.Text = PersonalEducationTable.COUNTRY.Format(PersonalEducationTable.COUNTRY.DefaultValue) End If ' If the COUNTRY is NULL or blank, then use the value specified ' on Properties. If Me.COUNTRY.Text Is Nothing _ OrElse Me.COUNTRY.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.COUNTRY.Text = " " End If End Sub Public Overridable Sub SetCourse() ' Set the Course Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.Course is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetCourse() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.CourseSpecified Then ' If the Course is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.Course) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.Course.Text = formattedValue Else ' Course is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.Course.Text = PersonalEducationTable.Course.Format(PersonalEducationTable.Course.DefaultValue) End If ' If the Course is NULL or blank, then use the value specified ' on Properties. If Me.Course.Text Is Nothing _ OrElse Me.Course.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.Course.Text = " " End If End Sub Public Overridable Sub SetCourseAbbr() ' Set the CourseAbbr Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.CourseAbbr is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetCourseAbbr() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.CourseAbbrSpecified Then ' If the CourseAbbr is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.CourseAbbr) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.CourseAbbr.Text = formattedValue Else ' CourseAbbr is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.CourseAbbr.Text = PersonalEducationTable.CourseAbbr.Format(PersonalEducationTable.CourseAbbr.DefaultValue) End If ' If the CourseAbbr is NULL or blank, then use the value specified ' on Properties. If Me.CourseAbbr.Text Is Nothing _ OrElse Me.CourseAbbr.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.CourseAbbr.Text = " " End If End Sub Public Overridable Sub SetCourseNo() ' Set the CourseNo Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.CourseNo is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetCourseNo() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.CourseNoSpecified Then ' If the CourseNo is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.CourseNo) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.CourseNo.Text = formattedValue Else ' CourseNo is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.CourseNo.Text = PersonalEducationTable.CourseNo.Format(PersonalEducationTable.CourseNo.DefaultValue) End If ' If the CourseNo is NULL or blank, then use the value specified ' on Properties. If Me.CourseNo.Text Is Nothing _ OrElse Me.CourseNo.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.CourseNo.Text = " " End If End Sub Public Overridable Sub SetEducationPeriod() ' Set the EducationPeriod Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.EducationPeriod is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetEducationPeriod() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.EducationPeriodSpecified Then ' If the EducationPeriod is non-NULL, then format the value. ' The Format method will return the Display Foreign Key As (DFKA) value Dim formattedValue As String = "" Dim _isExpandableNonCompositeForeignKey As Boolean = PersonalEducationTable.Instance.TableDefinition.IsExpandableNonCompositeForeignKey(PersonalEducationTable.EducationPeriod) If _isExpandableNonCompositeForeignKey AndAlso PersonalEducationTable.EducationPeriod.IsApplyDisplayAs Then formattedValue = PersonalEducationTable.GetDFKA(Me.DataSource.EducationPeriod.ToString(),PersonalEducationTable.EducationPeriod, Nothing) if (formattedValue Is Nothing) Then formattedValue = Me.DataSource.Format(PersonalEducationTable.EducationPeriod) End If Else formattedValue = Me.DataSource.EducationPeriod.ToString() End If formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.EducationPeriod.Text = formattedValue Else ' EducationPeriod is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.EducationPeriod.Text = PersonalEducationTable.EducationPeriod.Format(PersonalEducationTable.EducationPeriod.DefaultValue) End If ' If the EducationPeriod is NULL or blank, then use the value specified ' on Properties. If Me.EducationPeriod.Text Is Nothing _ OrElse Me.EducationPeriod.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.EducationPeriod.Text = " " End If End Sub Public Overridable Sub SetEducationType() ' Set the EducationType Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.EducationType is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetEducationType() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.EducationTypeSpecified Then ' If the EducationType is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.EducationType) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.EducationType.Text = formattedValue Else ' EducationType is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.EducationType.Text = PersonalEducationTable.EducationType.Format(PersonalEducationTable.EducationType.DefaultValue) End If ' If the EducationType is NULL or blank, then use the value specified ' on Properties. If Me.EducationType.Text Is Nothing _ OrElse Me.EducationType.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.EducationType.Text = " " End If End Sub Public Overridable Sub SetEdYear() ' Set the EdYear Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.EdYear is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetEdYear() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.EdYearSpecified Then ' If the EdYear is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.EdYear) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.EdYear.Text = formattedValue Else ' EdYear is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.EdYear.Text = PersonalEducationTable.EdYear.Format(PersonalEducationTable.EdYear.DefaultValue) End If ' If the EdYear is NULL or blank, then use the value specified ' on Properties. If Me.EdYear.Text Is Nothing _ OrElse Me.EdYear.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.EdYear.Text = " " End If End Sub Public Overridable Sub SetEndDate() ' Set the EndDate Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.EndDate is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetEndDate() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.EndDateSpecified Then ' If the EndDate is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.EndDate, "d MMM yy") formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.EndDate.Text = formattedValue Else ' EndDate is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.EndDate.Text = PersonalEducationTable.EndDate.Format(PersonalEducationTable.EndDate.DefaultValue, "d MMM yy") End If ' If the EndDate is NULL or blank, then use the value specified ' on Properties. If Me.EndDate.Text Is Nothing _ OrElse Me.EndDate.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.EndDate.Text = " " End If End Sub Public Overridable Sub SetFacultry() ' Set the Facultry Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.Facultry is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetFacultry() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.FacultrySpecified Then ' If the Facultry is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.Facultry) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.Facultry.Text = formattedValue Else ' Facultry is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.Facultry.Text = PersonalEducationTable.Facultry.Format(PersonalEducationTable.Facultry.DefaultValue) End If ' If the Facultry is NULL or blank, then use the value specified ' on Properties. If Me.Facultry.Text Is Nothing _ OrElse Me.Facultry.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.Facultry.Text = " " End If End Sub Public Overridable Sub SetInstitue() ' Set the Institue Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.Institue is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetInstitue() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.InstitueSpecified Then ' If the Institue is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.Institue) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.Institue.Text = formattedValue Else ' Institue is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.Institue.Text = PersonalEducationTable.Institue.Format(PersonalEducationTable.Institue.DefaultValue) End If ' If the Institue is NULL or blank, then use the value specified ' on Properties. If Me.Institue.Text Is Nothing _ OrElse Me.Institue.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.Institue.Text = " " End If End Sub Public Overridable Sub SetLevelId() ' Set the LevelId Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.LevelId is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetLevelId() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.LevelIdSpecified Then ' If the LevelId is non-NULL, then format the value. ' The Format method will return the Display Foreign Key As (DFKA) value Dim formattedValue As String = "" Dim _isExpandableNonCompositeForeignKey As Boolean = PersonalEducationTable.Instance.TableDefinition.IsExpandableNonCompositeForeignKey(PersonalEducationTable.LevelId) If _isExpandableNonCompositeForeignKey AndAlso PersonalEducationTable.LevelId.IsApplyDisplayAs Then formattedValue = PersonalEducationTable.GetDFKA(Me.DataSource.LevelId.ToString(),PersonalEducationTable.LevelId, Nothing) if (formattedValue Is Nothing) Then formattedValue = Me.DataSource.Format(PersonalEducationTable.LevelId) End If Else formattedValue = Me.DataSource.LevelId.ToString() End If formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.LevelId.Text = formattedValue Else ' LevelId is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.LevelId.Text = PersonalEducationTable.LevelId.Format(PersonalEducationTable.LevelId.DefaultValue) End If ' If the LevelId is NULL or blank, then use the value specified ' on Properties. If Me.LevelId.Text Is Nothing _ OrElse Me.LevelId.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.LevelId.Text = " " End If End Sub Public Overridable Sub SetNoAll() ' Set the NoAll Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.NoAll is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetNoAll() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.NoAllSpecified Then ' If the NoAll is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.NoAll) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.NoAll.Text = formattedValue Else ' NoAll is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.NoAll.Text = PersonalEducationTable.NoAll.Format(PersonalEducationTable.NoAll.DefaultValue) End If ' If the NoAll is NULL or blank, then use the value specified ' on Properties. If Me.NoAll.Text Is Nothing _ OrElse Me.NoAll.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.NoAll.Text = " " End If End Sub Public Overridable Sub SetPersonalId() ' Set the PersonalId LinkButton on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.PersonalId is the ASP:LinkButton on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetPersonalId() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.PersonalIdSpecified Then ' If the PersonalId is non-NULL, then format the value. ' The Format method will return the Display Foreign Key As (DFKA) value Dim formattedValue As String = "" Dim _isExpandableNonCompositeForeignKey As Boolean = PersonalEducationTable.Instance.TableDefinition.IsExpandableNonCompositeForeignKey(PersonalEducationTable.PersonalId) If _isExpandableNonCompositeForeignKey AndAlso PersonalEducationTable.PersonalId.IsApplyDisplayAs Then formattedValue = PersonalEducationTable.GetDFKA(Me.DataSource.PersonalId.ToString(),PersonalEducationTable.PersonalId, Nothing) if (formattedValue Is Nothing) Then formattedValue = Me.DataSource.Format(PersonalEducationTable.PersonalId) End If Else formattedValue = Me.DataSource.PersonalId.ToString() End If Me.PersonalId.Text = formattedValue Me.PersonalId.ToolTip = "Go to " & Me.PersonalId.Text.Replace("", "") Else ' PersonalId is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.PersonalId.Text = PersonalEducationTable.PersonalId.Format(PersonalEducationTable.PersonalId.DefaultValue) End If End Sub Public Overridable Sub SetScore() ' Set the Score Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.Score is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetScore() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.ScoreSpecified Then ' If the Score is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.Score) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.Score.Text = formattedValue Else ' Score is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.Score.Text = PersonalEducationTable.Score.Format(PersonalEducationTable.Score.DefaultValue) End If ' If the Score is NULL or blank, then use the value specified ' on Properties. If Me.Score.Text Is Nothing _ OrElse Me.Score.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.Score.Text = " " End If End Sub Public Overridable Sub SetScoreNo() ' Set the ScoreNo Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.ScoreNo is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetScoreNo() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.ScoreNoSpecified Then ' If the ScoreNo is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.ScoreNo) formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.ScoreNo.Text = formattedValue Else ' ScoreNo is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.ScoreNo.Text = PersonalEducationTable.ScoreNo.Format(PersonalEducationTable.ScoreNo.DefaultValue) End If ' If the ScoreNo is NULL or blank, then use the value specified ' on Properties. If Me.ScoreNo.Text Is Nothing _ OrElse Me.ScoreNo.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.ScoreNo.Text = " " End If End Sub Public Overridable Sub SetStartDate() ' Set the StartDate Literal on the webpage with value from the ' PersonalEducation database record. ' Me.DataSource is the PersonalEducation record retrieved from the database. ' Me.StartDate is the ASP:Literal on the webpage. ' You can modify this method directly, or replace it with a call to ' MyBase.SetStartDate() ' and add your own code before or after the call to the MyBase function. If Me.DataSource IsNot Nothing AndAlso Me.DataSource.StartDateSpecified Then ' If the StartDate is non-NULL, then format the value. ' The Format method will use the Display Format Dim formattedValue As String = Me.DataSource.Format(PersonalEducationTable.StartDate, "d MMM yy") formattedValue = HttpUtility.HtmlEncode(formattedValue) Me.StartDate.Text = formattedValue Else ' StartDate is NULL in the database, so use the Default Value. ' Default Value could also be NULL. Me.StartDate.Text = PersonalEducationTable.StartDate.Format(PersonalEducationTable.StartDate.DefaultValue, "d MMM yy") End If ' If the StartDate is NULL or blank, then use the value specified ' on Properties. If Me.StartDate.Text Is Nothing _ OrElse Me.StartDate.Text.Trim() = "" Then ' Set the value specified on the Properties. Me.StartDate.Text = " " End If End Sub Public Overridable Sub SetCommandDateLabel() End Sub Public Overridable Sub SetCommandLabel() End Sub Public Overridable Sub SetCOUNTRYLabel() End Sub Public Overridable Sub SetCourseAbbrLabel() End Sub Public Overridable Sub SetCourseLabel() End Sub Public Overridable Sub SetCourseNoLabel() End Sub Public Overridable Sub SetEducationPeriodLabel() End Sub Public Overridable Sub SetEducationTypeLabel() End Sub Public Overridable Sub SetEdYearLabel() End Sub Public Overridable Sub SetEndDateLabel() End Sub Public Overridable Sub SetFacultryLabel() End Sub Public Overridable Sub SetInstitueLabel() End Sub Public Overridable Sub SetLevelIdLabel() End Sub Public Overridable Sub SetNoAllLabel() End Sub Public Overridable Sub SetPersonalEducationRecordControlCollapsibleRegion() End Sub Public Overridable Sub SetPersonalEducationRecordControlIcon() End Sub Public Overridable Sub SetPersonalEducationRecordControlPanelExtender() End Sub Public Overridable Sub SetPersonalIdLabel() End Sub Public Overridable Sub SetScoreLabel() End Sub Public Overridable Sub SetScoreNoLabel() End Sub Public Overridable Sub SetStartDateLabel() End Sub Public Overridable Sub ResetControl() End Sub Public EvaluateFormulaDelegate As BaseClasses.Data.DataSource.EvaluateFormulaDelegate = New BaseClasses.Data.DataSource.EvaluateFormulaDelegate(AddressOf Me.EvaluateFormula) Public Overridable Function EvaluateFormula(ByVal formula As String, ByVal dataSourceForEvaluate As BaseClasses.Data.BaseRecord, ByVal format As String, ByVal variables As System.Collections.Generic.IDictionary(Of String, Object), ByVal includeDS As Boolean, ByVal e As FormulaEvaluator) As String If e Is Nothing Then e = New FormulaEvaluator() End If e.Variables.Clear() ' add variables for formula evaluation If variables IsNot Nothing Then Dim enumerator As System.Collections.Generic.IEnumerator(Of System.Collections.Generic.KeyValuePair(Of String, Object)) = variables.GetEnumerator() While enumerator.MoveNext() e.Variables.Add(enumerator.Current.Key, enumerator.Current.Value) End While End If If includeDS End IF ' Other variables referred to in the formula are expected to be ' properties of the DataSource. For example, referring to ' UnitPrice as a variable will refer to DataSource.UnitPrice If dataSourceForEvaluate Is Nothing Then e.DataSource = Me.DataSource Else e.DataSource = dataSourceForEvaluate End If ' Define the calling control. This is used to add other ' related table and record controls as variables. e.CallingControl = Me Dim resultObj As Object = e.Evaluate(formula) If resultObj Is Nothing Then Return "" End If If Not String.IsNullOrEmpty(format) AndAlso (String.IsNullOrEmpty(formula) OrElse formula.IndexOf("Format(") < 0) Then Return FormulaUtils.Format(resultObj, format) Else Return resultObj.ToString() End If End Function Public Overridable Function EvaluateFormula(ByVal formula As String, ByVal dataSourceForEvaluate as BaseClasses.Data.BaseRecord, ByVal format as String, ByVal variables As System.Collections.Generic.IDictionary(Of String, Object), ByVal includeDS As Boolean) As String Return EvaluateFormula(formula, dataSourceForEvaluate, format,variables ,includeDS, Nothing) End Function Public Overridable Function EvaluateFormula(ByVal formula As String, ByVal dataSourceForEvaluate As BaseClasses.Data.BaseRecord, ByVal format As String, ByVal variables As System.Collections.Generic.IDictionary(Of String, Object)) As String Return EvaluateFormula(formula, dataSourceForEvaluate, format, variables ,True, Nothing) End Function Public Overridable Function EvaluateFormula(ByVal formula As String, ByVal dataSourceForEvaluate As BaseClasses.Data.BaseRecord, ByVal format As String) As String Return Me.EvaluateFormula(formula, dataSourceForEvaluate, format, Nothing, True, Nothing) End Function Public Overridable Function EvaluateFormula(ByVal formula As String, ByVal dataSourceForEvaluate As BaseClasses.Data.BaseRecord, ByVal variables As System.Collections.Generic.IDictionary(Of String, Object), ByVal e as FormulaEvaluator) As String Return Me.EvaluateFormula(formula, dataSourceForEvaluate, Nothing, variables, True, e) End Function Public Overridable Function EvaluateFormula(ByVal formula As String, ByVal dataSourceForEvaluate As BaseClasses.Data.BaseRecord) As String Return Me.EvaluateFormula(formula, dataSourceForEvaluate, Nothing, Nothing, True, Nothing) End Function Public Overridable Function EvaluateFormula(ByVal formula As String, ByVal includeDS as Boolean) As String Return Me.EvaluateFormula(formula, Nothing, Nothing, Nothing, includeDS, Nothing) End Function Public Overridable Function EvaluateFormula(ByVal formula As String) As String Return Me.EvaluateFormula(formula, Nothing, Nothing, Nothing, True, Nothing) End Function Public Overridable Sub RegisterPostback() End Sub ' To customize, override this method in PersonalEducationRecordControl. Public Overridable Sub SaveData() ' Saves the associated record in the database. ' SaveData calls Validate and Get methods - so it may be more appropriate to ' customize those methods. ' 1. Load the existing record from the database. Since we save the entire record, this ensures ' that fields that are not displayed are also properly initialized. Me.LoadData() Dim Panel As System.Web.UI.WebControls.Panel = CType(MiscUtils.FindControlRecursively(Me, "PersonalEducationRecordControlPanel"), System.Web.UI.WebControls.Panel) If ((Not IsNothing(Panel)) AndAlso (Not Panel.Visible)) OrElse IsNothing(Me.DataSource) Then Return End If ' 2. Perform any custom validation. Me.Validate() ' 3. Set the values in the record with data from UI controls. ' This calls the Get() method for each of the user interface controls. Me.GetUIData() ' 4. Save in the database. ' We should not save the record if the data did not change. This ' will save a database hit and avoid triggering any database triggers. If Me.DataSource.IsAnyValueChanged Then ' Save record to database but do not commit yet. ' Auto generated ids are available after saving for use by child (dependent) records. Me.DataSource.Save() End If ' update session or cookie by formula ' Setting the DataChanged to True results in the page being refreshed with ' the most recent data from the database. This happens in PreRender event ' based on the current sort, search and filter criteria. Me.DataChanged = True Me.ResetData = True ' For Master-Detail relationships, save data on the Detail table(s) End Sub ' To customize, override this method in PersonalEducationRecordControl. Public Overridable Sub GetUIData() ' The GetUIData method retrieves the updated values from the user interface ' controls into a database record in preparation for saving or updating. ' To do this, it calls the Get methods for each of the field displayed on ' the webpage. It is better to make changes in the Get methods, rather ' than making changes here. ' Call the Get methods for each of the user interface controls. GetCommand() GetCommandDate() GetCOUNTRY() GetCourse() GetCourseAbbr() GetCourseNo() GetEducationPeriod() GetEducationType() GetEdYear() GetEndDate() GetFacultry() GetInstitue() GetLevelId() GetNoAll() GetPersonalId() GetScore() GetScoreNo() GetStartDate() End Sub Public Overridable Sub GetCommand() End Sub Public Overridable Sub GetCommandDate() End Sub Public Overridable Sub GetCOUNTRY() End Sub Public Overridable Sub GetCourse() End Sub Public Overridable Sub GetCourseAbbr() End Sub Public Overridable Sub GetCourseNo() End Sub Public Overridable Sub GetEducationPeriod() End Sub Public Overridable Sub GetEducationType() End Sub Public Overridable Sub GetEdYear() End Sub Public Overridable Sub GetEndDate() End Sub Public Overridable Sub GetFacultry() End Sub Public Overridable Sub GetInstitue() End Sub Public Overridable Sub GetLevelId() End Sub Public Overridable Sub GetNoAll() End Sub Public Overridable Sub GetPersonalId() End Sub Public Overridable Sub GetScore() End Sub Public Overridable Sub GetScoreNo() End Sub Public Overridable Sub GetStartDate() End Sub ' To customize, override this method in PersonalEducationRecordControl. Public Overridable Function CreateWhereClause() As WhereClause Dim wc As WhereClause PersonalEducationTable.Instance.InnerFilter = Nothing wc = New WhereClause() ' Compose the WHERE clause consiting of: ' 1. Static clause defined at design time. ' 2. User selected filter criteria. ' 3. User selected search criteria. ' Retrieve the record id from the URL parameter. Dim recId As String = Me.Page.Request.QueryString.Item("PersonalEducation") If recId Is Nothing OrElse recId.Trim = "" Then ' Get the error message from the application resource file. Throw New Exception(Page.GetResourceValue("Err:UrlParamMissing", "Persons").Replace("{URL}", "PersonalEducation")) End If HttpContext.Current.Session("QueryString in ShowPersonalEducation") = recId If KeyValue.IsXmlKey(recId) Then ' Keys are typically passed as XML structures to handle composite keys. ' If XML, then add a Where clause based on the Primary Key in the XML. Dim pkValue As KeyValue = KeyValue.XmlToKey(recId) wc.iAND(PersonalEducationTable.EducationId, BaseFilter.ComparisonOperator.EqualsTo, pkValue.GetColumnValueString(PersonalEducationTable.EducationId)) Else ' The URL parameter contains the actual value, not an XML structure. wc.iAND(PersonalEducationTable.EducationId, BaseFilter.ComparisonOperator.EqualsTo, recId) End If Return wc End Function ' This CreateWhereClause is used for loading list of suggestions for Auto Type-Ahead feature. Public Overridable Function CreateWhereClause(ByVal searchText As String, ByVal fromSearchControl As String, ByVal AutoTypeAheadSearch As String, ByVal AutoTypeAheadWordSeparators As String) As WhereClause PersonalEducationTable.Instance.InnerFilter = Nothing Dim wc As WhereClause = New WhereClause() ' Compose the WHERE clause consiting of: ' 1. Static clause defined at design time. ' 2. User selected filter criteria. ' 3. User selected search criteria. Dim appRelativeVirtualPath As String = CType(HttpContext.Current.Session("AppRelativeVirtualPath"), String) ' Adds clauses if values are selected in Filter controls which are configured in the page. Return wc End Function 'Formats the resultItem and adds it to the list of suggestions. Public Overridable Function FormatSuggestions(ByVal prefixText As String, ByVal resultItem As String, _ ByVal columnLength As Integer, ByVal AutoTypeAheadDisplayFoundText As String, _ ByVal autoTypeAheadSearch As String, ByVal AutoTypeAheadWordSeparators As String, _ ByVal resultList As ArrayList) As Boolean Dim index As Integer = resultItem.ToUpper(System.Threading.Thread.CurrentThread.CurrentCulture).IndexOf(prefixText.ToUpper(System.Threading.Thread.CurrentThread.CurrentCulture)) Dim itemToAdd As String = "" Dim isFound As Boolean = False Dim isAdded As Boolean = False ' Get the index where prfixt is at the beginning of resultItem. If not found then, index of word which begins with prefixText. If InvariantLCase(autoTypeAheadSearch).equals("wordsstartingwithsearchstring") and not index = 0 Then ' Expression to find word which contains AutoTypeAheadWordSeparators followed by prefixText Dim regex1 As System.Text.RegularExpressions.Regex = new System.Text.RegularExpressions.Regex( AutoTypeAheadWordSeparators + prefixText, System.Text.RegularExpressions.RegexOptions.IgnoreCase) If regex1.IsMatch(resultItem) Then index = regex1.Match(resultItem).Index isFound = True End If ' If the prefixText is found immediatly after white space then starting of the word is found so don not search any further If not resultItem(index).ToString() = " " Then ' Expression to find beginning of the word which contains AutoTypeAheadWordSeparators followed by prefixText Dim regex As System.Text.RegularExpressions.Regex = new System.Text.RegularExpressions.Regex("\\S*" + AutoTypeAheadWordSeparators + prefixText, System.Text.RegularExpressions.RegexOptions.IgnoreCase) If regex.IsMatch(resultItem) Then index = regex.Match(resultItem).Index isFound = True End If End If End If ' If autoTypeAheadSearch value is wordsstartingwithsearchstring then, extract the substring only if the prefixText is found at the ' beginning of the resultItem (index = 0) or a word in resultItem is found starts with prefixText. If index = 0 Or isFound Or InvariantLCase(autoTypeAheadSearch).Equals("anywhereinstring") then If InvariantLCase(AutoTypeAheadDisplayFoundText).equals("atbeginningofmatchedstring") Then ' Expression to find beginning of the word which contains prefixText Dim regex1 As System.Text.RegularExpressions.Regex = new System.Text.RegularExpressions.Regex("\\S*" + prefixText, System.Text.RegularExpressions.RegexOptions.IgnoreCase) ' Find the beginning of the word which contains prefexText If (StringUtils.InvariantLCase(autoTypeAheadSearch).Equals("anywhereinstring") AndAlso regex1.IsMatch(resultItem)) Then index = regex1.Match(resultItem).Index isFound = True End If ' Display string from the index till end of the string if sub string from index till end is less than columnLength value. If Len(resultItem) - index <= columnLength Then If index = 0 Then itemToAdd = resultItem Else itemToAdd = "..." & resultItem.Substring(index, Len(resultItem) - index) End If Else If index = 0 Then itemToAdd = resultItem.Substring(index, (columnLength - 3)) & "..." Else 'Truncate the string to show only columnLength - 6 characters as begining and trailing "..." has to be appended. itemToAdd = "..." & resultItem.Substring(index , columnLength - 6) & "..." End If End If ElseIf InvariantLCase(AutoTypeAheadDisplayFoundText).equals("inmiddleofmatchedstring") Then Dim subStringBeginIndex As Integer = CType(columnLength/2, Integer) If Len(resultItem) <= columnLength Then itemToAdd = resultItem Else ' Sanity check at end of the string If index + Len(prefixText) = columnLength Then itemToAdd = "..." & resultItem.Substring(index-columnLength,index) ElseIf Len(resultItem) - index < subStringBeginIndex Then ' Display string from the end till columnLength value if, index is closer to the end of the string. itemToAdd = "..." & resultItem.Substring(Len(resultItem)-columnLength,Len(resultItem)) ElseIf index <= subStringBeginIndex Then ' Sanity chet at beginning of the string itemToAdd = resultItem.Substring(0, columnLength) & "..." Else ' Display string containing text before the prefixText occures and text after the prefixText itemToAdd = "..." & resultItem.Substring(index - subStringBeginIndex, columnLength) & "..." End If End If ElseIf InvariantLCase(AutoTypeAheadDisplayFoundText).equals("atendofmatchedstring") Then ' Expression to find ending of the word which contains prefexText Dim regex1 As System.Text.RegularExpressions.Regex = new System.Text.RegularExpressions.Regex("\s", System.Text.RegularExpressions.RegexOptions.IgnoreCase) ' Find the ending of the word which contains prefexText If regex1.IsMatch(resultItem, index + 1) Then index = regex1.Match(resultItem, index + 1).Index Else ' If the word which contains prefexText is the last word in string, regex1.IsMatch returns false. index = resultItem.Length End If If index > Len(resultItem) Then index = Len(resultItem) End If ' If text from beginning of the string till index is less than columnLength value then, display string from the beginning till index. If index <= columnLength Then if index = Len(resultItem) then 'Make decision to append "..." itemToAdd = resultItem.Substring(0,index) Else itemToAdd = resultItem.Substring(0,index) & "..." End If Else If index = Len(resultItem) Then itemToAdd = "..." & resultItem.Substring(index - (columnLength - 3), (columnLength - 3)) Else 'Truncate the string to show only columnLength - 6 characters as begining and trailing "..." has to be appended. itemToAdd = "..." & resultItem.Substring(index - (columnLength - 6), columnLength - 6) & "..." End If End If End If ' Remove newline character from itemToAdd Dim prefixTextIndex As Integer = itemToAdd.IndexOf(prefixText, StringComparison.CurrentCultureIgnoreCase) ' If itemToAdd contains any newline after the search text then show text only till newline Dim regex2 As System.Text.RegularExpressions.Regex = New System.Text.RegularExpressions.Regex("(" & vbCrLf & "|" & vbLf & ")", System.Text.RegularExpressions.RegexOptions.IgnoreCase) Dim newLineIndexAfterPrefix As Integer = -1 If regex2.IsMatch(itemToAdd, prefixTextIndex) Then newLineIndexAfterPrefix = regex2.Match(itemToAdd, prefixTextIndex).Index End If If (newLineIndexAfterPrefix > -1) Then If itemToAdd.EndsWith("...") Then itemToAdd = (itemToAdd.Substring(0, newLineIndexAfterPrefix) + "...") Else itemToAdd = itemToAdd.Substring(0, newLineIndexAfterPrefix) End If End If ' If itemToAdd contains any newline before search text then show text which comes after newline Dim regex3 As System.Text.RegularExpressions.Regex = New System.Text.RegularExpressions.Regex("(" & vbCrLf & "|" & vbLf & ")", (System.Text.RegularExpressions.RegexOptions.IgnoreCase Or System.Text.RegularExpressions.RegexOptions.RightToLeft)) Dim newLineIndexBeforePrefix As Integer = -1 If regex3.IsMatch(itemToAdd, prefixTextIndex) Then newLineIndexBeforePrefix = regex3.Match(itemToAdd, prefixTextIndex).Index End If If (newLineIndexBeforePrefix > -1) Then If itemToAdd.StartsWith("...") Then itemToAdd = ("..." + itemToAdd.Substring((newLineIndexBeforePrefix + regex3.Match(itemToAdd, prefixTextIndex).Length))) Else itemToAdd = itemToAdd.Substring((newLineIndexBeforePrefix + regex3.Match(itemToAdd, prefixTextIndex).Length)) End If End If If Not itemToAdd is nothing AndAlso Not resultList.Contains(itemToAdd) Then resultList.Add(itemToAdd) isAdded = true End If End If Return isAdded End Function ' To customize, override this method in PersonalEducationRecordControl. Public Overridable Sub Validate() ' Add custom validation for any control within this panel. ' Example. If you have a State ASP:Textbox control ' If Me.State.Text <> "CA" Then ' Throw New Exception("State must be CA (California).") ' End If ' The Validate method is common across all controls within ' this panel so you can validate multiple fields, but report ' one error message. End Sub Public Overridable Sub Delete() If Me.IsNewRecord() Then Return End If Dim pkValue As KeyValue = KeyValue.XmlToKey(Me.RecordUniqueId) PersonalEducationTable.DeleteRecord(pkValue) End Sub Protected Overridable Sub Control_PreRender(ByVal sender As Object, ByVal e As System.EventArgs) Handles MyBase.PreRender ' PreRender event is raised just before page is being displayed. Try DbUtils.StartTransaction() Me.RegisterPostback() If Not Me.Page.ErrorOnPage AndAlso (Me.Page.IsPageRefresh OrElse Me.DataChanged OrElse Me.ResetData) Then ' Re-load the data and update the web page if necessary. ' This is typically done during a postback (filter, search button, sort, pagination button). ' In each of the other click handlers, simply set DataChanged to True to reload the data. Me.LoadData() Me.DataBind() End If Catch ex As Exception Utils.MiscUtils.RegisterJScriptAlert(Me, "BUTTON_CLICK_MESSAGE", ex.Message) Finally DbUtils.EndTransaction() End Try End Sub Protected Overrides Sub SaveControlsToSession() MyBase.SaveControlsToSession() 'Save pagination state to session. End Sub Protected Overrides Sub ClearControlsFromSession() MyBase.ClearControlsFromSession() ' Clear pagination state from session. End Sub Protected Overrides Sub LoadViewState(ByVal savedState As Object) MyBase.LoadViewState(savedState) Dim isNewRecord As String = CType(ViewState("IsNewRecord"), String) If Not isNewRecord Is Nothing AndAlso isNewRecord.Trim <> "" Then Me.IsNewRecord = Boolean.Parse(isNewRecord) End If Dim myCheckSum As String = CType(ViewState("CheckSum"), String) If Not myCheckSum Is Nothing AndAlso myCheckSum.Trim <> "" Then Me.CheckSum = myCheckSum End If ' Load view state for pagination control. End Sub Protected Overrides Function SaveViewState() As Object ViewState("IsNewRecord") = Me.IsNewRecord.ToString() ViewState("CheckSum") = Me.CheckSum ' Load view state for pagination control. Return MyBase.SaveViewState() End Function ' Generate the event handling functions for pagination events. ' Generate the event handling functions for filter and search events. ' event handler for ImageButton Public Overridable Sub PersonalEducationDialogEditButton_Click(ByVal sender As Object, ByVal args As ImageClickEventArgs) ' The redirect URL is set on the Properties, Custom Properties or Actions. ' The ModifyRedirectURL call resolves the parameters before the ' Response.Redirect redirects the page to the URL. ' Any code after the Response.Redirect call will not be executed, since the page is ' redirected to the URL. Dim url As String = "../PersonalEducation/EditPersonalEducation.aspx?PersonalEducation={PK}" Dim shouldRedirect As Boolean = True Dim TargetKey As String = Nothing Dim DFKA As String = TargetKey Dim id As String = DFKA Dim value As String = id Try ' Enclose all database retrieval/update code within a Transaction boundary DbUtils.StartTransaction url = Me.ModifyRedirectUrl(url, "",False) url = Me.Page.ModifyRedirectUrl(url, "",False) Catch ex As Exception ' Upon error, rollback the transaction Me.Page.RollBackTransaction(sender) shouldRedirect = False Me.Page.ErrorOnPage = True ' Report the error message to the end user Utils.MiscUtils.RegisterJScriptAlert(Me, "BUTTON_CLICK_MESSAGE", ex.Message) Finally DbUtils.EndTransaction End Try If shouldRedirect Then Me.Page.ShouldSaveControlsToSession = True Me.Page.Response.Redirect(url) ElseIf Not TargetKey Is Nothing AndAlso _ Not shouldRedirect Then Me.Page.ShouldSaveControlsToSession = True Me.Page.CloseWindow(True) End If End Sub ' event handler for LinkButton Public Overridable Sub PersonalId_Click(ByVal sender As Object, ByVal args As EventArgs) ' The redirect URL is set on the Properties, Custom Properties or Actions. ' The ModifyRedirectURL call resolves the parameters before the ' Response.Redirect redirects the page to the URL. ' Any code after the Response.Redirect call will not be executed, since the page is ' redirected to the URL. Dim url As String = "../PersonalId/ShowPersonalId.aspx?PersonalId={PersonalEducationRecordControl:FK:FK_PersonalEducation_PersonalId}" Dim shouldRedirect As Boolean = True Dim TargetKey As String = Nothing Dim DFKA As String = TargetKey Dim id As String = DFKA Dim value As String = id Try ' Enclose all database retrieval/update code within a Transaction boundary DbUtils.StartTransaction url = Me.ModifyRedirectUrl(url, "",False) url = Me.Page.ModifyRedirectUrl(url, "",False) Catch ex As Exception ' Upon error, rollback the transaction Me.Page.RollBackTransaction(sender) shouldRedirect = False Me.Page.ErrorOnPage = True ' Report the error message to the end user Utils.MiscUtils.RegisterJScriptAlert(Me, "BUTTON_CLICK_MESSAGE", ex.Message) Finally DbUtils.EndTransaction End Try If shouldRedirect Then Me.Page.ShouldSaveControlsToSession = True Me.Page.Response.Redirect(url) ElseIf Not TargetKey Is Nothing AndAlso _ Not shouldRedirect Then Me.Page.ShouldSaveControlsToSession = True Me.Page.CloseWindow(True) End If End Sub Private _PreviousUIData As New Hashtable Public Overridable Property PreviousUIData() As Hashtable Get Return _PreviousUIData End Get Set(ByVal value As Hashtable) _PreviousUIData = value End Set End Property Private _IsNewRecord As Boolean = True Public Overridable Property IsNewRecord() As Boolean Get Return Me._IsNewRecord End Get Set(ByVal value As Boolean) Me._IsNewRecord = value End Set End Property Private _DataChanged As Boolean = False Public Overridable Property DataChanged() As Boolean Get Return Me._DataChanged End Get Set(ByVal Value As Boolean) Me._DataChanged = Value End Set End Property Private _ResetData As Boolean = False Public Overridable Property ResetData() As Boolean Get Return Me._ResetData End Get Set(ByVal Value As Boolean) Me._ResetData = Value End Set End Property Public Property RecordUniqueId() As String Get Return CType(Me.ViewState("BasePersonalEducationRecordControl_Rec"), String) End Get Set(ByVal value As String) Me.ViewState("BasePersonalEducationRecordControl_Rec") = value End Set End Property Private _DataSource As PersonalEducationRecord Public Property DataSource() As PersonalEducationRecord Get Return Me._DataSource End Get Set(ByVal value As PersonalEducationRecord) Me._DataSource = value End Set End Property Private _checkSum As String Public Overridable Property CheckSum() As String Get Return Me._checkSum End Get Set(ByVal value As String) Me._checkSum = value End Set End Property Private _TotalPages As Integer Public Property TotalPages() As Integer Get Return Me._TotalPages End Get Set(ByVal value As Integer) Me._TotalPages = value End Set End Property Private _PageIndex As Integer Public Property PageIndex() As Integer Get ' Return the PageIndex Return Me._PageIndex End Get Set(ByVal value As Integer) Me._PageIndex = value End Set End Property Private _PageSize As Integer Public Property PageSize() As Integer Get Return Me._PageSize End Get Set(ByVal value As Integer) Me._PageSize = value End Set End Property Private _TotalRecords As Integer Public Property TotalRecords() As Integer Get Return Me._TotalRecords End Get Set(ByVal value As Integer) If Me.PageSize > 0 Then Me.TotalPages = CInt(Math.Ceiling(value / Me.PageSize)) End If Me._TotalRecords = value End Set End Property Private _DisplayLastPage As Boolean Public Property DisplayLastPage() As Boolean Get Return Me._DisplayLastPage End Get Set(ByVal value As Boolean) Me._DisplayLastPage = value End Set End Property #Region "Helper Properties" Public ReadOnly Property Command() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "Command"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property CommandDate() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "CommandDate"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property CommandDateLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "CommandDateLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property CommandLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "CommandLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property COUNTRY() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "COUNTRY"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property COUNTRYLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "COUNTRYLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property Course() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "Course"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property CourseAbbr() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "CourseAbbr"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property CourseAbbrLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "CourseAbbrLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property CourseLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "CourseLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property CourseNo() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "CourseNo"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property CourseNoLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "CourseNoLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property EducationPeriod() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "EducationPeriod"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property EducationPeriodLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "EducationPeriodLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property EducationType() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "EducationType"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property EducationTypeLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "EducationTypeLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property EdYear() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "EdYear"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property EdYearLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "EdYearLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property EndDate() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "EndDate"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property EndDateLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "EndDateLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property Facultry() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "Facultry"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property FacultryLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "FacultryLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property Institue() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "Institue"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property InstitueLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "InstitueLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property LevelId() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "LevelId"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property LevelIdLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "LevelIdLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property NoAll() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "NoAll"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property NoAllLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "NoAllLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property PersonalEducationDialogEditButton() As System.Web.UI.WebControls.ImageButton Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "PersonalEducationDialogEditButton"), System.Web.UI.WebControls.ImageButton) End Get End Property Public ReadOnly Property PersonalEducationRecordControlCollapsibleRegion() As System.Web.UI.WebControls.Panel Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "PersonalEducationRecordControlCollapsibleRegion"), System.Web.UI.WebControls.Panel) End Get End Property Public ReadOnly Property PersonalEducationRecordControlIcon() As System.Web.UI.WebControls.ImageButton Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "PersonalEducationRecordControlIcon"), System.Web.UI.WebControls.ImageButton) End Get End Property Public ReadOnly Property PersonalEducationRecordControlPanelExtender() As AjaxControlToolkit.CollapsiblePanelExtender Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "PersonalEducationRecordControlPanelExtender"), AjaxControlToolkit.CollapsiblePanelExtender) End Get End Property Public ReadOnly Property PersonalEducationTitle() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "PersonalEducationTitle"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property PersonalId() As System.Web.UI.WebControls.LinkButton Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "PersonalId"), System.Web.UI.WebControls.LinkButton) End Get End Property Public ReadOnly Property PersonalIdLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "PersonalIdLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property Score() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "Score"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property ScoreLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "ScoreLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property ScoreNo() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "ScoreNo"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property ScoreNoLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "ScoreNoLabel"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property StartDate() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "StartDate"), System.Web.UI.WebControls.Literal) End Get End Property Public ReadOnly Property StartDateLabel() As System.Web.UI.WebControls.Literal Get Return CType(BaseClasses.Utils.MiscUtils.FindControlRecursively(Me, "StartDateLabel"), System.Web.UI.WebControls.Literal) End Get End Property #End Region #Region "Helper Functions" Public Overrides Overloads Function ModifyRedirectUrl(ByVal url As String, ByVal arg As String, ByVal bEncrypt As Boolean) As String Return Me.Page.EvaluateExpressions(url, arg, bEncrypt, Me) End Function Public Overrides Overloads Function EvaluateExpressions(ByVal url As String, ByVal arg As String, ByVal bEncrypt As Boolean) As String Dim rec As PersonalEducationRecord = Nothing Try rec = Me.GetRecord() Catch ex As Exception ' Do nothing End Try If rec Is Nothing AndAlso url.IndexOf("{") >= 0 Then ' Localization. Throw New Exception(Page.GetResourceValue("Err:RecDataSrcNotInitialized", "Persons")) End If Return EvaluateExpressions(url, arg, rec, bEncrypt) End Function Public Overridable Function GetRecord() As PersonalEducationRecord If Not Me.DataSource Is Nothing Then Return Me.DataSource End If If Not Me.RecordUniqueId Is Nothing Then Return PersonalEducationTable.GetRecord(Me.RecordUniqueId, True) End If ' Localization. Throw New Exception(Page.GetResourceValue("Err:RetrieveRec", "Persons")) End Function Public Shadows ReadOnly Property Page() As BaseApplicationPage Get Return DirectCast(MyBase.Page, BaseApplicationPage) End Get End Property #End Region End Class #End Region End Namespace