OrderRecordStatus.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. <?php
  2. namespace App\Enums;
  3. /**
  4. * 订单记录状态枚举类
  5. */
  6. enum OrderRecordStatus: int
  7. {
  8. /**
  9. * 记录状态:创建订单
  10. */
  11. case CREATED = 1;
  12. /**
  13. * 记录状态:支付完成
  14. */
  15. case PAID = 2;
  16. /**
  17. * 记录状态:已分配技师
  18. */
  19. case ASSIGNED = 3;
  20. /**
  21. * 记录状态:技师到达
  22. */
  23. case ARRIVED = 4;
  24. /**
  25. * 记录状态:开始服务
  26. */
  27. case STARTED = 5;
  28. /**
  29. * 记录状态:服务完成
  30. */
  31. case COMPLETED = 6;
  32. /**
  33. * 记录状态:已评价
  34. */
  35. case EVALUATED = 7;
  36. /**
  37. * 记录状态:已取消
  38. */
  39. case CANCELLED = 8;
  40. /**
  41. * 记录状态:已拒单
  42. */
  43. case REJECTED = 9;
  44. /**
  45. * 记录状态:技师出发
  46. */
  47. case DEPARTED = 10;
  48. /**
  49. * 记录状态:技师撤离
  50. */
  51. case LEFT = 11;
  52. /**
  53. * 记录状态:退款中
  54. */
  55. case REFUNDING = 12;
  56. /**
  57. * 记录状态:退款完成
  58. */
  59. case REFUNDED = 13;
  60. /**
  61. * 获取状态的显示文本
  62. *
  63. * @return string 状态的中文描述
  64. */
  65. public function label(): string
  66. {
  67. return match ($this) {
  68. self::CREATED => '创建订单',
  69. self::PAID => '支付完成',
  70. self::ASSIGNED => '已分配技师',
  71. self::ARRIVED => '技师到达',
  72. self::STARTED => '开始服务',
  73. self::COMPLETED => '服务完成',
  74. self::EVALUATED => '已评价',
  75. self::CANCELLED => '已取消',
  76. self::REJECTED => '已拒单',
  77. self::DEPARTED => '技师出发',
  78. self::LEFT => '技师撤离',
  79. self::REFUNDING => '退款中',
  80. self::REFUNDED => '退款完成',
  81. };
  82. }
  83. /**
  84. * 获取状态的整数值
  85. *
  86. * @return int 状态值
  87. */
  88. public function value(): int
  89. {
  90. return $this->value;
  91. }
  92. /**
  93. * 检查当前状态是否与指定状态相同
  94. *
  95. * @param self $status 要比较的状态
  96. * @return bool 如果状态相同返回 true,否则返回 false
  97. */
  98. public function is(self $status): bool
  99. {
  100. return $this === $status;
  101. }
  102. /**
  103. * 根据整数值创建对应的状态枚举实例
  104. *
  105. * @param int $value 状态值
  106. * @return self|null 返回对应的状态枚举实例,如果值无效则返回 null
  107. */
  108. public static function fromValue(int $value): ?self
  109. {
  110. return match ($value) {
  111. self::CREATED->value => self::CREATED,
  112. self::PAID->value => self::PAID,
  113. self::ASSIGNED->value => self::ASSIGNED,
  114. self::ARRIVED->value => self::ARRIVED,
  115. self::STARTED->value => self::STARTED,
  116. self::COMPLETED->value => self::COMPLETED,
  117. self::EVALUATED->value => self::EVALUATED,
  118. self::CANCELLED->value => self::CANCELLED,
  119. self::REJECTED->value => self::REJECTED,
  120. self::DEPARTED->value => self::DEPARTED,
  121. self::LEFT->value => self::LEFT,
  122. self::REFUNDING->value => self::REFUNDING,
  123. self::REFUNDED->value => self::REFUNDED,
  124. default => null
  125. };
  126. }
  127. /**
  128. * 获取所有状态的值数组
  129. *
  130. * @return array 包含所有状态值的数组
  131. */
  132. public static function values(): array
  133. {
  134. return array_column(self::cases(), 'value');
  135. }
  136. /**
  137. * 获取所有状态的键值对数组
  138. *
  139. * @return array 状态值作为键,显示文本作为值的关联数组
  140. */
  141. public static function all(): array
  142. {
  143. return [
  144. self::CREATED->value => self::CREATED->label(),
  145. self::PAID->value => self::PAID->label(),
  146. self::ASSIGNED->value => self::ASSIGNED->label(),
  147. self::ARRIVED->value => self::ARRIVED->label(),
  148. self::STARTED->value => self::STARTED->label(),
  149. self::COMPLETED->value => self::COMPLETED->label(),
  150. self::EVALUATED->value => self::EVALUATED->label(),
  151. self::CANCELLED->value => self::CANCELLED->label(),
  152. self::REJECTED->value => self::REJECTED->label(),
  153. self::DEPARTED->value => self::DEPARTED->label(),
  154. self::LEFT->value => self::LEFT->label(),
  155. self::REFUNDING->value => self::REFUNDING->label(),
  156. self::REFUNDED->value => self::REFUNDED->label(),
  157. ];
  158. }
  159. }