using Hotline.Share.Dtos.File;
using Hotline.Share.Dtos.FlowEngine.Workflow;
using Hotline.Share.Dtos.Hotspots;
using Hotline.Share.Dtos.Org;
using Hotline.Share.Dtos.Users;
using Hotline.Share.Enums.FlowEngine;
using Hotline.Share.Enums.Order;
using Hotline.Share.Enums.Settings;
using Hotline.Share.Requests;
using XF.Utility.EnumExtensions;
namespace Hotline.Share.Dtos.Order
{
public class OrderDto : UpdateOrderDto
{
#region 工单属性
///
/// 工单状态
///
public EOrderStatus Status { get; set; }
public string StatusText => Status.GetDescription();
///
/// 过期状态
///
public EExpiredStatus ExpiredStatus { get; set; }
///
/// 处理方式(直办、交办)
///
public EProcessType ProcessType { get; set; }
/////
///// 进展情况
/////
//public EProgress Progress { get; set; }
///
/// 是否公开
///
public bool IsPublicity { get; set; }
///
/// 工单编码(20220101000001)
///
public string No { get; set; }
///
/// 是否110来的工单
///
public bool IsNo110 { get; set; }
public string? TagNames { get; set; }
#region 流程信息
///
/// 工单开始时间(受理/接办时间=流程开启时间)
///
public DateTime? StartTime { get; set; }
///
/// 过期时间
///
public DateTime? ExpiredTime { get; set; }
///
/// 交办时间(中心交部门办理时间)
///
public DateTime? CenterToOrgTime { get; set; }
///
/// 归档时间(暂为流程结束时间,因流程结束自动归档)
///
public DateTime? FiledTime { get; set; }
///
/// 办结时长(分钟)
/// 办结时间-交办时间
///
public double HandleDuration { get; set; }
///
/// 办结工作日时长(分钟)
///
public double HandleDurationWorkday { get; set; }
///
/// 全流程时长(分钟)
/// 归档时间-创建时间
///
public double AllDuration { get; set; }
///
/// 办理时间限制(如:24小时、7个工作日)
///
public string? TimeLimit { get; set; }
public int? TimeLimitCount { get; set; }
public ETimeType? TimeLimitUnit { get; set; }
#region 实际办理信息(节点,部门,意见)
///
/// 实际办理节点code(会签状态此字段保存最外层会签发起节点code)
///
public string? ActualHandleStepCode { get; set; }
///
/// 实际办理节点名称(会签状态此字段保存最外层会签发起节点名称)
///
public string? ActualHandleStepName { get; set; }
///
/// 到达实际办理节点时间(stepBox创建时间)
///
public DateTime? ActualHandleStepCreateTime { get; set; }
///
/// 实际办理节点签收时间
///
public DateTime? ActualHandleStepAcceptTime { get; set; }
///
/// 实际办理时间
///
public DateTime? ActualHandleTime { get; set; }
///
/// 实际办理人id
///
public string? ActualHandlerId { get; set; }
///
/// 实际办理人名称
///
public string? ActualHandlerName { get; set; }
///
/// 实际办理部门名称
///
public string? ActualHandleOrgName { get; set; }
///
/// 实际办理部门编码
///
public string? ActualHandleOrgCode { get; set; }
///
/// 实际办理部门行政区划编码
///
public string? ActualHandleOrgAreaCode { get; set; }
///
/// 实际办理部门行政区划名称
///
public string? ActualHandleOrgAreaName { get; set; }
///
/// 实际办理意见(办理中...or 最终办理意见)
///
public string ActualOpinion { get; set; } = "办理中...";
///
/// 真实办理人姓名(手动填写)
///
public string? RealHandlerName { get; set; }
///
/// 真实办理人电话(手动填写)
///
public string? RealHandlerPhone { get; set; }
///
/// 沟通方式(手动填写)
///
public ERealCommunicationMode? RealCommunicationMode { get; set; }
///
/// 沟通时间(手动填写)
///
public DateTime? RealCommunicationTime { get; set; }
///
/// 沟通地点(手动填写)
///
public string? RealCommunicationAddress { get; set; }
///
/// 已与市民沟通
///
public bool? RealIsContacted { get; set; }
///
/// 已与市民现场沟通
///
public bool? RealContactLocale { get; set; }
#endregion
#region 当前办理节点信息
///
/// 当前办理节点code(非会签:当前被指派节点,会签:会签发起节点)
///
public string? CurrentStepCode { get; set; }
///
/// 当前节点名称
///
public string? CurrentStepName { get; set; }
///
/// 到达当前节点时间
///
public DateTime? CurrentStepCreateTime { get; set; }
///
/// 实际办理节点签收时间
///
public DateTime? CurrentHandleStepAcceptTime { get; set; }
///
/// 实际办理时间
///
public DateTime? CurrentHandleTime { get; set; }
///
/// 实际办理人id
///
public string? CurrentHandlerId { get; set; }
///
/// 实际办理人名称
///
public string? CurrentHandlerName { get; set; }
///
/// 实际办理部门名称
///
public string? CurrentHandleOrgName { get; set; }
///
/// 实际办理部门编码
///
public string? CurrentHandleOrgCode { get; set; }
///
/// 实际办理部门行政区划编码
///
public string? CurrentHandleOrgAreaCode { get; set; }
///
/// 实际办理部门行政区划名称
///
public string? CurrentHandleOrgAreaName { get; set; }
#endregion
#region 一级部门
///
/// 一级部门code
///
public string? OrgLevelOneCode { get; set; }
///
/// 一级部门名称
///
public string? OrgLevelOneName { get; set; }
#endregion
#region 受理人(开启流程的话务员)
///
/// 受理人id
///
public string? AcceptorId { get; set; }
///
/// 受理人名称
///
public string? AcceptorName { get; set; }
///
/// 受理人工号
///
public string? AcceptorStaffNo { get; set; }
///
/// 受理人部门编码
///
public string? AcceptorOrgCode { get; set; }
///
/// 受理人部门名称
///
public string? AcceptorOrgName { get; set; }
#endregion
///
/// 会签类型
///
public ECounterSignType? CounterSignType { get; set; }
public string? CounterSignTypeText => CounterSignType?.GetDescription() ?? "未会签";
#region 签收
///
/// 签收人id
///
public string? SignerId { get; set; }
///
/// 签收人名称
///
public string? SignerName { get; set; }
#endregion
#endregion
#endregion
public string CreationTime { get; set; }
public string? ContactMask { get; set; }
public string SmsSendedText => SmsSended ? "已发送" : "未发送";
///
/// 市民查询密码
///
public string? Password { get; set; }
public string WorkflowId { get; set; }
public WorkflowDto Workflow { get; set; }
///
/// 来电/信人性别
///
public string FromGenderText => FromGender.GetDescription();
///
/// 来电/信人身份
///
public string IdentityTypeText => IdentityType.GetDescription();
/////
///// 受理类型
/////
////public string AcceptTypeText => AcceptType.GetDescription();
///
/// 紧急程度
///
public string EmergencyLevelText => EmergencyLevel.GetDescription();
///
/// 超期时间描述(需求:超期3天、0.5天后超期)
///
public string ExpiredText => CalculateExpiredText();
///
/// 是否可编辑
///
public bool CanEdit => !string.IsNullOrEmpty(SignerId) &&
(Status is EOrderStatus.WaitForAccept or EOrderStatus.BackToUnAccept);
///
/// 是否可签收
///
public bool CanSign => string.IsNullOrEmpty(SignerId);
private string CalculateExpiredText()
{
//todo 完整处理方案:1.创建待过期表,Id,过期时间,即将过期时间等字段。2.延迟消息通知处理过期,删除子表数据,处理order过期状态字段。3.此处即可采用expiredStatus进行判断
//todo 目前暂时采用过期时间计算
if (!ExpiredTime.HasValue)
return string.Empty;
var days = (DateTime.Now - ExpiredTime.Value).TotalDays;
switch (days)
{
case > 0:
return $"超期{days:N1}天";
case < 0:
return $"{days:N1}天后超期";
default:
return "超期不到1天";
}
}
public HotspotDto? Hotspot { get; set; }
///
/// 延期
///
public List OrderDelays { get; set; }
///
/// 甄别
///
public List OrderScreens { get; set; }
public List RepeatableEventDetails { get; set; } = new();
public List OrderVisits { get; set; }
public List? FileJson { get; set; }
}
public class UpdateOrderDto : AddOrderDto
{
public string Id { get; set; }
}
public class AddOrderDto : Position
{
#region 来电信息
///
/// 来源渠道
///
public string? SourceChannel { get; set; }
public string? SourceChannelCode { get; set; }
///
/// 渠道为电话时,此字段存在
///
public string? CallId { get; set; }
///
/// 来电归属地
///
public string? CallAddress { get; set; }
///
/// 来电号码
///
public string? FromPhone { get; set; }
///
/// 转接号码(转接来源)
///
public string? TransferPhone { get; set; }
///
/// 来电/信人姓名
///
public string? FromName { get; set; }
///
/// 来电/信人性别
///
public EGender FromGender { get; set; }
///
/// 来电/信人身份
///
public EIdentityType? IdentityType { get; set; }
///
/// 证件类型
///
public string? LicenceTypeCode { get; set; }
public string? LicenceType { get; set; }
///
/// 证件号码
///
public string? LicenceNo { get; set; }
///
/// 年龄段
///
public string? AgeRangeCode { get; set; }
public string? AgeRange { get; set; }
///
/// 联系电话
///
public string? Contact { get; set; }
///
/// 是否接受短信,勾选校验手机号
///
public bool AcceptSms { get; set; }
///
/// 是否已发送短信
///
public bool SmsSended { get; set; }
///
/// 是否保密
///
public bool IsSecret { get; set; }
///
/// 工作单位(当“来电/信人身份”为“企业”时必填,其他情况非必填)
///
public string? Company { get; set; }
#endregion
#region 诉求信息
///
/// 受理类型
///
public string? AcceptType { get; set; }
public string? AcceptTypeCode { get; set; }
///
/// 紧急程度
///
public EEmergencyLevel EmergencyLevel { get; set; }
public string Title { get; set; }
#region 热点
///
/// 热点
///
public string? HotspotId { get; set; }
public string? HotspotName { get; set; }
public string? HotspotSpliceName { get; set; }
///
/// 外部数据(为前端提供级联功能)
///
public string? HotspotExternal { get; set; }
#endregion
///
/// 事发时间
///
public DateTime? IncidentTime { get; set; }
///
/// 事件目的
///
public string? IncidentPurpose { get; set; }
///
/// 重复工单Id
///
public List? DuplicateIds { get; set; }
///
/// 推送分类
///
public string? PushTypeCode { get; set; }
public string? PushType { get; set; }
///
/// 附件
///
public List Additions { get; set; } = new();
///
/// 诉求内容
///
public string Content { get; set; }
#endregion
///
/// 来源,区分省平台或110等其他平台同步过来的工单
///
public ESource Source { get; set; } = ESource.Hotline;
///
/// 扩展信息
///
public OrderExtensionDto? OrderExtension { get; set; }
///
/// 附件列表
///
public List Files { get; set; } = new();
///
/// 企业名称
///
public string? EnterpriseName { get; set; }
///
/// 专班名称
///
public string? ZhuanBanMingCheng { get; set; }
#region 重复性事件
public List RepeatableEventDetails { get; set; } = new();
#endregion
///
/// 是否为省工单
///
public bool IsProvince { get; set; }
///
/// 同步省工单编号和省上传下来的工单都用这个字段
///
public string? ProvinceNo { get; set; }
///
/// 省过期时间(省工单才有)
///
public DateTime? ExpiredTimeProvince { get; set; }
///
/// 外部工单唯一标识
///
public string? ExternalId { get; set; }
}
}