OrderStatus.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. <?php
  2. namespace App\Enums;
  3. /**
  4. * 订单状态枚举类
  5. *
  6. * 定义了订单从创建到完成的所有可能状态
  7. * 状态流转顺序:
  8. * 已创建 -> 已支付 -> 已分配 -> 已接单 -> 已出发 -> 已到达 -> 开始服务 -> 服务中 -> 服务结束 -> 撤离中 -> 已撤离 -> 已完成
  9. * 任意状态都可以变为:已取消
  10. */
  11. enum OrderStatus: int
  12. {
  13. /**
  14. * 订单状态:已创建
  15. * 用户创建订单但尚未支付的状态
  16. */
  17. case CREATED = 1; // 订单初始状态
  18. /**
  19. * 订单状态:已支付
  20. * 用户完成支付,等待技师接单
  21. */
  22. case PAID = 2; // 可以进入抢单流程
  23. /**
  24. * 订单状态:已分配
  25. * 技师接受订单,准备提供服务
  26. */
  27. case ASSIGNED = 3; // 技师已分配
  28. /**
  29. * 订单状态:已接单
  30. * 技师接受订单,准备提供服务
  31. */
  32. case ACCEPTED = 4; // 技师已确认接单
  33. /**
  34. * 订单状态:已出发
  35. * 技师已经出发前往服务地点
  36. */
  37. case DEPARTED = 5; // 技师开始前往目的地
  38. /**
  39. * 订单状态:已到达
  40. * 技师已到达服务地点
  41. */
  42. case ARRIVED = 6; // 技师已到达用户位置
  43. /**
  44. * 订单状态:开始服务
  45. * 技师开始提供服务
  46. */
  47. case SERVICE_START = 7; // 正式开始服务
  48. /**
  49. * 订单状态:服务中
  50. * 技师正在提供服务
  51. */
  52. case SERVICING = 8; // 服务进行中
  53. /**
  54. * 订单状态:服务结束
  55. * 技师已完成服务内容
  56. */
  57. case SERVICE_END = 9; // 服务内容已完成
  58. /**
  59. * 订单状态:撤离中
  60. * 技师正在离开服务地点
  61. */
  62. case LEAVING = 10; // 技师正在返程
  63. /**
  64. * 订单状态:已撤离
  65. * 技师已完成服务并离开服务地点
  66. */
  67. case LEFT = 11; // 技师已完成服务并离开服务地点
  68. /**
  69. * 订单状态:已完成
  70. * 订单全部流程结束
  71. */
  72. case COMPLETED = 12; // 订单完成状态
  73. /**
  74. * 订单状态:已取消
  75. * 订单被取消(可能是用户取消或系统取消)
  76. */
  77. case CANCELLED = 13; // 订单终止状态
  78. /**
  79. * 订单状态:已退款
  80. * 订单被取消并已退款
  81. */
  82. case REFUNDED = 14; // 订单已退款
  83. /**
  84. * 订单状态:已拒单
  85. * 技师拒绝接单
  86. */
  87. case REJECTED = 15; // 技师拒单
  88. /**
  89. * 获取状态的显示文本
  90. * 将状态值转换为对应的中文描述
  91. *
  92. * @return string 状态的中文描述
  93. */
  94. public function label(): string
  95. {
  96. return match ($this) {
  97. self::CREATED => '已创建', // 订单创建完成
  98. self::PAID => '已支付', // 支付完成
  99. self::ASSIGNED => '已分配', // 技师分配
  100. self::ACCEPTED => '已接单', // 技师接单
  101. self::DEPARTED => '已出发', // 技师出发
  102. self::ARRIVED => '已到达', // 技师到达
  103. self::SERVICE_START => '开始服务', // 开始提供服务
  104. self::SERVICING => '服务中', // 服务进行中
  105. self::SERVICE_END => '服务结束', // 服务完成
  106. self::LEAVING => '撤离中', // 技师离开
  107. self::LEFT => '已撤离', // 技师已完成服务并离开服务地点
  108. self::COMPLETED => '已完成', // 订单完结
  109. self::CANCELLED => '已取消', // 订单取消
  110. self::REFUNDED => '已退款', // 订单已退款
  111. self::REJECTED => '已拒单', // 技师拒单
  112. };
  113. }
  114. /**
  115. * 获取状态的整数值
  116. *
  117. * @return int 状态值
  118. */
  119. public function value(): int
  120. {
  121. return $this->value;
  122. }
  123. /**
  124. * 检查当前状态是否与指定状态相同
  125. *
  126. * @param self $status 要比较的状态
  127. * @return bool 如果状态相同返回 true,否则返回 false
  128. */
  129. public function is(self $status): bool
  130. {
  131. return $this === $status;
  132. }
  133. /**
  134. * 根据整数值创建对应的状态枚举实例
  135. *
  136. * @param int $value 状态值
  137. * @return self|null 返回对应的状态枚举实例,如果值无效则返回 null
  138. */
  139. public static function fromValue(int $value): ?self
  140. {
  141. return match ($value) {
  142. self::CREATED->value => self::CREATED,
  143. self::PAID->value => self::PAID,
  144. self::ASSIGNED->value => self::ASSIGNED,
  145. self::ACCEPTED->value => self::ACCEPTED,
  146. self::DEPARTED->value => self::DEPARTED,
  147. self::ARRIVED->value => self::ARRIVED,
  148. self::SERVICE_START->value => self::SERVICE_START,
  149. self::SERVICING->value => self::SERVICING,
  150. self::SERVICE_END->value => self::SERVICE_END,
  151. self::LEAVING->value => self::LEAVING,
  152. self::LEFT->value => self::LEFT,
  153. self::COMPLETED->value => self::COMPLETED,
  154. self::CANCELLED->value => self::CANCELLED,
  155. self::REFUNDED->value => self::REFUNDED,
  156. self::REJECTED->value => self::REJECTED,
  157. default => null
  158. };
  159. }
  160. /**
  161. * 获取所有状态的值数组
  162. *
  163. * @return array 包含所有状态值的数组
  164. */
  165. public static function values(): array
  166. {
  167. return array_column(self::cases(), 'value');
  168. }
  169. /**
  170. * 获取所有状态的键值对数组
  171. *
  172. * @return array 状态值作为键,显示文本作为值的关联数组
  173. */
  174. public static function all(): array
  175. {
  176. return [
  177. self::CREATED->value => self::CREATED->label(),
  178. self::PAID->value => self::PAID->label(),
  179. self::ASSIGNED->value => self::ASSIGNED->label(),
  180. self::ACCEPTED->value => self::ACCEPTED->label(),
  181. self::DEPARTED->value => self::DEPARTED->label(),
  182. self::ARRIVED->value => self::ARRIVED->label(),
  183. self::SERVICE_START->value => self::SERVICE_START->label(),
  184. self::SERVICING->value => self::SERVICING->label(),
  185. self::SERVICE_END->value => self::SERVICE_END->label(),
  186. self::LEAVING->value => self::LEAVING->label(),
  187. self::LEFT->value => self::LEFT->label(),
  188. self::COMPLETED->value => self::COMPLETED->label(),
  189. self::CANCELLED->value => self::CANCELLED->label(),
  190. self::REFUNDED->value => self::REFUNDED->label(),
  191. self::REJECTED->value => self::REJECTED->label(),
  192. ];
  193. }
  194. }