OrderDto.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666
  1. using Hotline.Share.Dtos.FlowEngine;
  2. using Hotline.Share.Dtos.Hotspots;
  3. using Hotline.Share.Enums.FlowEngine;
  4. using Hotline.Share.Enums.Order;
  5. using Hotline.Share.Enums.Settings;
  6. using XF.Utility.EnumExtensions;
  7. namespace Hotline.Share.Dtos.Order
  8. {
  9. public class OrderDto : UpdateOrderDto
  10. {
  11. #region 工单属性
  12. /// <summary>
  13. /// 工单状态
  14. /// </summary>
  15. public EOrderStatus Status { get; set; }
  16. public string StatusText => Status.GetDescription();
  17. /// <summary>
  18. /// 过期状态
  19. /// </summary>
  20. public EExpiredStatus ExpiredStatus { get; set; }
  21. /// <summary>
  22. /// 处理方式(直办、交办)
  23. /// </summary>
  24. public EProcessType ProcessType { get; set; }
  25. ///// <summary>
  26. ///// 进展情况
  27. ///// </summary>
  28. //public EProgress Progress { get; set; }
  29. /// <summary>
  30. /// 是否公开
  31. /// </summary>
  32. public bool IsPublicity { get; set; }
  33. /// <summary>
  34. /// 是否为省工单
  35. /// </summary>
  36. public bool IsProvince { get; set; }
  37. /// <summary>
  38. /// 工单编码(20220101000001)
  39. /// </summary>
  40. public string No { get; set; }
  41. /// <summary>
  42. /// 省工单编号(冗余)
  43. /// </summary>
  44. public string? FromProvinceNo { get; set; }
  45. /// <summary>
  46. /// 同步省工单编号(按省工单要求生成的编号,冗余)
  47. /// </summary>
  48. public string? ToProvinceNo { get; set; }
  49. /// <summary>
  50. /// 省过期时间(省工单才有)
  51. /// </summary>
  52. public DateTime? ExpiredTimeProvince { get; set; }
  53. /// <summary>
  54. /// 110工单编号(从110来的和推送给110的都用该字段记录唯一标识)
  55. /// </summary>
  56. public string? No110 { get; set; }
  57. /// <summary>
  58. /// 是否110来的工单
  59. /// </summary>
  60. public bool IsNo110 { get; set; }
  61. #region 流程信息
  62. /// <summary>
  63. /// 工单开始时间(受理/接办时间=流程开启时间)
  64. /// </summary>
  65. public DateTime? StartTime { get; set; }
  66. /// <summary>
  67. /// 过期时间
  68. /// </summary>
  69. public DateTime? ExpiredTime { get; set; }
  70. /// <summary>
  71. /// 交办时间(中心交部门办理时间)
  72. /// </summary>
  73. public DateTime? CenterToOrgTime { get; set; }
  74. /// <summary>
  75. /// 归档时间(暂为流程结束时间,因流程结束自动归档)
  76. /// </summary>
  77. public DateTime? FiledTime { get; set; }
  78. /// <summary>
  79. /// 办结时长(分钟)
  80. /// 办结时间-交办时间
  81. /// </summary>
  82. public double HandleDuration { get; set; }
  83. /// <summary>
  84. /// 办结工作日时长
  85. /// </summary>
  86. public double HandleDurationWorkday { get; set; }
  87. /// <summary>
  88. /// 全流程时长(分钟)
  89. /// 归档时间-创建时间
  90. /// </summary>
  91. public double AllDuration { get; set; }
  92. /// <summary>
  93. /// 办理时间限制(如:24小时、7个工作日)
  94. /// </summary>
  95. public string? TimeLimit { get; set; }
  96. public int? TimeLimitCount { get; set; }
  97. public ETimeType? TimeLimitUnit { get; set; }
  98. #region 实际办理信息(节点,部门,意见)
  99. /// <summary>
  100. /// 实际办理节点code(会签状态此字段保存最外层会签发起节点code)
  101. /// </summary>
  102. public string? ActualHandleStepCode { get; set; }
  103. /// <summary>
  104. /// 实际办理节点名称(会签状态此字段保存最外层会签发起节点名称)
  105. /// </summary>
  106. public string? ActualHandleStepName { get; set; }
  107. /// <summary>
  108. /// 到达实际办理节点时间(stepBox创建时间)
  109. /// </summary>
  110. public DateTime? ActualHandleStepCreateTime { get; set; }
  111. /// <summary>
  112. /// 实际办理时间
  113. /// </summary>
  114. public DateTime? ActualHandleTime { get; set; }
  115. /// <summary>
  116. /// 实际办理人id
  117. /// </summary>
  118. public string? ActualHandlerId { get; set; }
  119. /// <summary>
  120. /// 实际办理人名称
  121. /// </summary>
  122. public string? ActualHandlerName { get; set; }
  123. /// <summary>
  124. /// 实际办理部门名称
  125. /// </summary>
  126. public string? ActualHandleOrgName { get; set; }
  127. /// <summary>
  128. /// 实际办理部门编码
  129. /// </summary>
  130. public string? ActualHandleOrgCode { get; set; }
  131. /// <summary>
  132. /// 实际办理部门行政区划编码
  133. /// </summary>
  134. public string? ActualHandleOrgAreaCode { get; set; }
  135. /// <summary>
  136. /// 实际办理部门行政区划名称
  137. /// </summary>
  138. public string? ActualHandleOrgAreaName { get; set; }
  139. /// <summary>
  140. /// 实际办理意见(办理中...or 最终办理意见)
  141. /// </summary>
  142. public string ActualOpinion { get; set; } = "办理中...";
  143. /// <summary>
  144. /// 真实办理人姓名(手动填写)
  145. /// </summary>
  146. public string? RealHandlerName { get; set; }
  147. /// <summary>
  148. /// 真实办理人电话(手动填写)
  149. /// </summary>
  150. public string? RealHandlerPhone { get; set; }
  151. /// <summary>
  152. /// 沟通方式(手动填写)
  153. /// </summary>
  154. public ERealCommunicationMode? RealCommunicationMode { get; set; }
  155. /// <summary>
  156. /// 沟通时间(手动填写)
  157. /// </summary>
  158. public DateTime? RealCommunicationTime { get; set; }
  159. /// <summary>
  160. /// 沟通地点(手动填写)
  161. /// </summary>
  162. public string? RealCommunicationAddress { get; set; }
  163. #endregion
  164. #region 当前办理节点信息
  165. /// <summary>
  166. /// 当前办理节点code(非会签:当前被指派节点,会签:会签发起节点)
  167. /// </summary>
  168. public string? CurrentStepCode { get; set; }
  169. /// <summary>
  170. /// 当前节点名称
  171. /// </summary>
  172. public string? CurrentStepName { get; set; }
  173. /// <summary>
  174. /// 到达当前节点时间(stepBox创建时间)
  175. /// </summary>
  176. public DateTime? CurrentStepCreateTime { get; set; }
  177. #endregion
  178. #region 一级部门
  179. /// <summary>
  180. /// 一级部门code
  181. /// </summary>
  182. public string? OrgLevelOneCode { get; set; }
  183. /// <summary>
  184. /// 一级部门名称
  185. /// </summary>
  186. public string? OrgLevelOneName { get; set; }
  187. #endregion
  188. #region 受理人(开启流程的话务员)
  189. /// <summary>
  190. /// 受理人id
  191. /// </summary>
  192. public string? AcceptorId { get; set; }
  193. /// <summary>
  194. /// 受理人名称
  195. /// </summary>
  196. public string? AcceptorName { get; set; }
  197. /// <summary>
  198. /// 受理人工号
  199. /// </summary>
  200. public string? AcceptorStaffNo { get; set; }
  201. /// <summary>
  202. /// 受理人部门编码
  203. /// </summary>
  204. public string? AcceptorOrgCode { get; set; }
  205. /// <summary>
  206. /// 受理人部门名称
  207. /// </summary>
  208. public string? AcceptorOrgName { get; set; }
  209. #endregion
  210. #endregion
  211. #endregion
  212. public string CreationTime { get; set; }
  213. public string? ContactMask { get; set; }
  214. public string SmsSendedText => SmsSended ? "已发送" : "未发送";
  215. public string WorkflowId { get; set; }
  216. public WorkflowDto Workflow { get; set; }
  217. /// <summary>
  218. /// 来电/信人性别
  219. /// </summary>
  220. public string FromGenderText => FromGender.GetDescription();
  221. /// <summary>
  222. /// 来电/信人身份
  223. /// </summary>
  224. public string IdentityTypeText => IdentityType.GetDescription();
  225. /// <summary>
  226. /// 工单类型
  227. /// </summary>
  228. public string OrderTypeText => OrderType.GetDescription();
  229. /// <summary>
  230. /// 受理类型
  231. /// </summary>
  232. public string AcceptTypeText => AcceptType.GetDescription();
  233. /// <summary>
  234. /// 紧急程度
  235. /// </summary>
  236. public string EmergencyLevelText => EmergencyLevel.GetDescription();
  237. /// <summary>
  238. /// 超期时间描述(需求:超期3天、0.5天后超期)
  239. /// </summary>
  240. public string ExpiredText => CalculateExpiredText();
  241. private string CalculateExpiredText()
  242. {
  243. //todo 完整处理方案:1.创建待过期表,Id,过期时间,即将过期时间等字段。2.延迟消息通知处理过期,删除子表数据,处理order过期状态字段。3.此处即可采用expiredStatus进行判断
  244. //todo 目前暂时采用过期时间计算
  245. if (!ExpiredTime.HasValue)
  246. return string.Empty;
  247. var days = (DateTime.Now - ExpiredTime.Value).TotalDays;
  248. switch (days)
  249. {
  250. case > 0:
  251. return $"超期{days:N1}天";
  252. case < 0:
  253. return $"{days:N1}天后超期";
  254. default:
  255. return "超期不到1天";
  256. }
  257. }
  258. public HotspotDto? Hotspot { get; set; }
  259. }
  260. public class UpdateOrderDto : AddOrderDto
  261. {
  262. public string Id { get; set; }
  263. }
  264. public class AddOrderDto : Position
  265. {
  266. #region 来电信息
  267. /// <summary>
  268. /// 来源渠道
  269. /// </summary>
  270. public string SourceChannel { get; set; }
  271. public string SourceChannelCode { get; set; }
  272. /// <summary>
  273. /// 渠道为电话时,此字段存在
  274. /// </summary>
  275. public string? CallId { get; set; }
  276. /// <summary>
  277. /// 来电归属地
  278. /// </summary>
  279. public string? CallAddress { get; set; }
  280. /// <summary>
  281. /// 来电号码
  282. /// </summary>
  283. public string? FromPhone { get; set; }
  284. /// <summary>
  285. /// 转接号码(转接来源)
  286. /// </summary>
  287. public string? TransferPhone { get; set; }
  288. /// <summary>
  289. /// 来电/信人姓名
  290. /// </summary>
  291. public string FromName { get; set; }
  292. /// <summary>
  293. /// 来电/信人性别
  294. /// </summary>
  295. public EGender FromGender { get; set; }
  296. /// <summary>
  297. /// 来电/信人身份
  298. /// </summary>
  299. public EIdentityType IdentityType { get; set; }
  300. /// <summary>
  301. /// 证件类型
  302. /// </summary>
  303. public string? LicenceTypeCode { get; set; }
  304. public string? LicenceType { get; set; }
  305. /// <summary>
  306. /// 证件号码
  307. /// </summary>
  308. public string? LicenceNo { get; set; }
  309. /// <summary>
  310. /// 年龄段
  311. /// </summary>
  312. public string? AgeRangeCode { get; set; }
  313. public string? AgeRange { get; set; }
  314. /// <summary>
  315. /// 联系电话
  316. /// </summary>
  317. public string? Contact { get; set; }
  318. /// <summary>
  319. /// 是否接受短信,勾选校验手机号
  320. /// </summary>
  321. public bool AcceptSms { get; set; }
  322. /// <summary>
  323. /// 是否已发送短信
  324. /// </summary>
  325. public bool SmsSended { get; set; }
  326. /// <summary>
  327. /// 是否保密
  328. /// </summary>
  329. public bool IsSecret { get; set; }
  330. /// <summary>
  331. /// 工作单位(当“来电/信人身份”为“企业”时必填,其他情况非必填)
  332. /// </summary>
  333. public string? Company { get; set; }
  334. #endregion
  335. #region 诉求信息
  336. /// <summary>
  337. /// 工单类型
  338. /// </summary>
  339. public EOrderType OrderType { get; set; }
  340. /// <summary>
  341. /// 受理类型
  342. /// </summary>
  343. public EAcceptType AcceptType { get; set; }
  344. /// <summary>
  345. /// 紧急程度
  346. /// </summary>
  347. public EEmergencyLevel EmergencyLevel { get; set; } = EEmergencyLevel.Normal;
  348. public string Title { get; set; }
  349. #region 热点
  350. /// <summary>
  351. /// 热点
  352. /// </summary>
  353. public string HotspotId { get; set; }
  354. public string HotspotName { get; set; }
  355. public string HotspotSpliceName { get; set; }
  356. /// <summary>
  357. /// 外部数据(为前端提供级联功能)
  358. /// </summary>
  359. public string HotspotExternal { get; set; }
  360. #endregion
  361. /// <summary>
  362. /// 事发时间
  363. /// </summary>
  364. public DateTime? IncidentTime { get; set; }
  365. /// <summary>
  366. /// 重复工单Id
  367. /// </summary>
  368. public List<string>? DuplicateIds { get; set; }
  369. /// <summary>
  370. /// 推送分类
  371. /// </summary>
  372. public string? PushTypeCode { get; set; }
  373. public string? PushType { get; set; }
  374. /// <summary>
  375. /// 附件
  376. /// </summary>
  377. public List<string> Additions { get; set; } = new();
  378. /// <summary>
  379. /// 诉求内容
  380. /// </summary>
  381. public string Content { get; set; }
  382. #endregion
  383. /// <summary>
  384. /// 来源,区分省平台或110等其他平台同步过来的工单
  385. /// </summary>
  386. public ESource Source { get; set; }
  387. /// <summary>
  388. /// 投诉
  389. /// </summary>
  390. public OrderComplainDto OrderComplain { get; set; }
  391. /// <summary>
  392. /// 举报
  393. /// </summary>
  394. public OrderReportDto OrderReport { get; set; }
  395. }
  396. public class PublishDto : OrderDto
  397. {
  398. /// <summary>
  399. /// 发布范围
  400. /// </summary>
  401. public EPublishState PublishState { get; set; }
  402. /// <summary>
  403. /// 整理内容
  404. /// </summary>
  405. public string ArrangeContent { get; set; }
  406. }
  407. public class PublishOrderPageBaseDto
  408. {
  409. /// <summary>
  410. /// 来源 0:热线平台 1:省平台 2:110
  411. /// </summary>
  412. public string SourceChannel { get; set; }
  413. /// <summary>
  414. /// 工单标题
  415. /// </summary>
  416. public string OrderTitle { get; set; }
  417. /// <summary>
  418. /// 工单内容
  419. /// </summary>
  420. public string Content { get; set; }
  421. /// <summary>
  422. /// 办理结果
  423. /// </summary>
  424. public string ActualOpinion { get; set; }
  425. /// <summary>
  426. /// 实际办理部门名称
  427. /// </summary>
  428. public IdName ActualHandleOrgName { get; set; }
  429. /// <summary>
  430. /// 需回访部门
  431. /// </summary>
  432. public List<IdName>? idNames { get; set; }
  433. }
  434. public class PublishOrderDto
  435. {
  436. /// <summary>
  437. /// 工单ID
  438. /// </summary>
  439. public string Id { get; set; }
  440. /// <summary>
  441. /// 发布范围
  442. /// </summary>
  443. public bool PublishState { get; set; }
  444. /// <summary>
  445. /// 整理标题
  446. /// </summary>
  447. public string ArrangeTitle { get; set; }
  448. /// <summary>
  449. /// 整理内容
  450. /// </summary>
  451. public string ArrangeContent { get; set; }
  452. /// <summary>
  453. /// 整理结果
  454. /// </summary>
  455. public string ArrangeOpinion { get; set; }
  456. /// <summary>
  457. /// 需回访部门
  458. /// </summary>
  459. public List<IdName> IdNames { get; set; }
  460. #region 省工单使用
  461. /// <summary>
  462. /// 省是否公开
  463. /// </summary>
  464. public bool? ProPublishState { get; set; }
  465. /// <summary>
  466. /// 反馈人电话
  467. /// </summary>
  468. public string? FeedBackPhone { get; set; }
  469. /// <summary>
  470. /// 不公开原因
  471. /// </summary>
  472. public string? NoPubReason { get; set; }
  473. #endregion
  474. }
  475. public class PublishVisitDto
  476. {
  477. /// <summary>
  478. /// 工单对象
  479. /// </summary>
  480. public OrderDto Order { get; set; }
  481. /// <summary>
  482. /// 服务工单编号
  483. /// </summary>
  484. public string No { get; set; }
  485. /// <summary>
  486. /// 回访评价方式
  487. /// </summary>
  488. public EVisitType? VisitType { get; set; }
  489. /// <summary>
  490. /// 回访人
  491. /// </summary>
  492. public string VisitName { get; set; }
  493. /// <summary>
  494. /// 回访时间
  495. /// </summary>
  496. public DateTime? VisitTime { get; set; }
  497. /// <summary>
  498. /// 回访评价情况
  499. /// </summary>
  500. public string VisitRemark { get; set; }
  501. /// <summary>
  502. /// 回访结果满意度
  503. /// </summary>
  504. public string SubjectResultSatifyCode { get; set; }
  505. /// <summary>
  506. /// 行政区划代码
  507. /// </summary>
  508. public string AreaCode { get; set; }
  509. /// <summary>
  510. /// 工单回访首次结果满意度
  511. /// </summary>
  512. public string FirstSatisfactionCode { get; set; }
  513. /// <summary>
  514. /// 附件
  515. /// </summary>
  516. public string ClientGuid { get; set; }
  517. }
  518. }