SheetCalendar.cs
资源名称:H3_OA.rar [点击查看]
上传用户:li2971742
上传日期:2021-11-18
资源大小:39096k
文件大小:4k
源码类别:
OA系统
开发平台:
C#
- using System;
- using System.Web.UI;
- using System.Web.UI.WebControls;
- using System.ComponentModel;
- using System.Drawing;
- using System.Drawing.Design;
- [assembly:TagPrefix("OThinker.H3.WorkSheet","SheetControls")]
- namespace OThinker.H3.WorkSheet
- {
- /// <summary>
- /// SheetCalendar1 的摘要说明。
- /// </summary>
- [ToolboxBitmap(typeof(SheetCalendar),"OThinker.H3.WorkSheet.SheetCalendar.bmp")]
- [ToolboxData("<{0}:SheetCalendar runat=server></{0}:SheetCalendar>")]
- public class SheetCalendar:System.Web.UI.WebControls.Calendar, ISheetControl
- {
- public SheetCalendar()
- {
- }
- #region 类SheetCalendar属性
- private string _DataField = null;
- [Bindable(true),Category("WorkSheet"),DefaultValue("")]
- [Editor(typeof(DataSelector),typeof(UITypeEditor))]
- public string DataField
- {
- get
- {
- return this._DataField;
- }
- set
- {
- this._DataField = value;
- }
- }
- #endregion
- #region ISheetControl 成员
- public virtual void LoadDataField(OThinker.H3.WorkSheet.SheetPage SheetPage)
- {
- if(this.DataField == null || this.DataField == "")
- {
- }
- else if(SheetPage.Enviroment.InstanceData[this.DataField] == null)
- {
- }
- else if (SheetPage.Enviroment.InstanceData[this.DataField].ItemType != typeof(System.DateTime))
- {
- // 类型不匹配
- }
- else if (SheetPage.Enviroment.InstanceData[this.DataField].Visible == false)
- {
- this.Visible = false;
- }
- else
- {
- this.Enabled = SheetPage.Enviroment.InstanceData[this.DataField].Editable;
- this.SelectedDate = (System.DateTime)SheetPage.Enviroment.InstanceData[this.DataField].Value;
- }
- }
- public virtual bool ValidateDataField(
- OThinker.H3.WorkSheet.SheetPage SheetPage,
- System.Collections.Generic.List<string> Errors)
- {
- if (
- this.DataField != null &&
- this.DataField != "" &&
- SheetPage.Enviroment.InstanceData[this.DataField] != null &&
- SheetPage.Enviroment.InstanceData[this.DataField].Visible &&
- SheetPage.Enviroment.InstanceData[this.DataField].Editable)
- {
- try
- {
- OThinker.Data.Convertor.Convert(
- this.SelectedDate,
- SheetPage.Enviroment.InstanceData[this.DataField].ItemType);
- }
- catch
- {
- Errors.Add(
- "数据格式不正确,发生转换错误,请确认输入数据的格式正确!" +
- "字段名称为:" + this.DataField + "," +
- "类型为:" + OThinker.H3.Data.DataLogicTypeConvertor.ToLogicTypeName(SheetPage.Enviroment.InstanceData[this.DataField].LogicType));
- return false;
- }
- }
- return true;
- }
- public virtual void SaveDataField(OThinker.H3.WorkSheet.SheetPage SheetPage)
- {
- if(
- this.DataField != null &&
- this.DataField != "" &&
- SheetPage.Enviroment.InstanceData[this.DataField] != null &&
- SheetPage.Enviroment.InstanceData[this.DataField].Visible &&
- SheetPage.Enviroment.InstanceData[this.DataField].Editable)
- {
- //写回数据
- object convertedValue;
- try
- {
- convertedValue = OThinker.Data.Convertor.Convert(
- this.SelectedDate,
- SheetPage.Enviroment.InstanceData[this.DataField].ItemType,
- true);
- }
- catch
- {
- SheetPage.Enviroment.NotifyMessage(
- "数据格式不正确,发生转换错误,请确认输入数据的格式正确!" +
- "字段名称为:" + this.DataField + "," +
- "类型为:" + OThinker.H3.Data.DataLogicTypeConvertor.ToLogicTypeName(SheetPage.Enviroment.InstanceData[this.DataField].LogicType));
- return;
- }
- SheetPage.Enviroment.InstanceData[DataField].Value = convertedValue;
- }
- }
- #endregion
- }
- }