123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- <?php
- namespace App\Enums;
- /**
- * 订单记录状态枚举类
- */
- enum OrderRecordStatus: int
- {
- /**
- * 记录状态:创建订单
- */
- case CREATED = 1;
- /**
- * 记录状态:支付完成
- */
- case PAID = 2;
- /**
- * 记录状态:已分配技师
- */
- case ASSIGNED = 3;
- /**
- * 记录状态:技师到达
- */
- case ARRIVED = 4;
- /**
- * 记录状态:开始服务
- */
- case STARTED = 5;
- /**
- * 记录状态:服务完成
- */
- case COMPLETED = 6;
- /**
- * 记录状态:已评价
- */
- case EVALUATED = 7;
- /**
- * 记录状态:已取消
- */
- case CANCELLED = 8;
- /**
- * 记录状态:已拒单
- */
- case REJECTED = 9;
- /**
- * 记录状态:技师出发
- */
- case DEPARTED = 10;
- /**
- * 记录状态:技师撤离
- */
- case LEFT = 11;
- /**
- * 记录状态:退款中
- */
- case REFUNDING = 12;
- /**
- * 记录状态:退款完成
- */
- case REFUNDED = 13;
- /**
- * 获取状态的显示文本
- *
- * @return string 状态的中文描述
- */
- public function label(): string
- {
- return match ($this) {
- self::CREATED => '创建订单',
- self::PAID => '支付完成',
- self::ASSIGNED => '已分配技师',
- self::ARRIVED => '技师到达',
- self::STARTED => '开始服务',
- self::COMPLETED => '服务完成',
- self::EVALUATED => '已评价',
- self::CANCELLED => '已取消',
- self::REJECTED => '已拒单',
- self::DEPARTED => '技师出发',
- self::LEFT => '技师撤离',
- self::REFUNDING => '退款中',
- self::REFUNDED => '退款完成',
- };
- }
- /**
- * 获取状态的整数值
- *
- * @return int 状态值
- */
- public function value(): int
- {
- return $this->value;
- }
- /**
- * 检查当前状态是否与指定状态相同
- *
- * @param self $status 要比较的状态
- * @return bool 如果状态相同返回 true,否则返回 false
- */
- public function is(self $status): bool
- {
- return $this === $status;
- }
- /**
- * 根据整数值创建对应的状态枚举实例
- *
- * @param int $value 状态值
- * @return self|null 返回对应的状态枚举实例,如果值无效则返回 null
- */
- public static function fromValue(int $value): ?self
- {
- return match ($value) {
- self::CREATED->value => self::CREATED,
- self::PAID->value => self::PAID,
- self::ASSIGNED->value => self::ASSIGNED,
- self::ARRIVED->value => self::ARRIVED,
- self::STARTED->value => self::STARTED,
- self::COMPLETED->value => self::COMPLETED,
- self::EVALUATED->value => self::EVALUATED,
- self::CANCELLED->value => self::CANCELLED,
- self::REJECTED->value => self::REJECTED,
- self::DEPARTED->value => self::DEPARTED,
- self::LEFT->value => self::LEFT,
- self::REFUNDING->value => self::REFUNDING,
- self::REFUNDED->value => self::REFUNDED,
- default => null
- };
- }
- /**
- * 获取所有状态的值数组
- *
- * @return array 包含所有状态值的数组
- */
- public static function values(): array
- {
- return array_column(self::cases(), 'value');
- }
- /**
- * 获取所有状态的键值对数组
- *
- * @return array 状态值作为键,显示文本作为值的关联数组
- */
- public static function all(): array
- {
- return [
- self::CREATED->value => self::CREATED->label(),
- self::PAID->value => self::PAID->label(),
- self::ASSIGNED->value => self::ASSIGNED->label(),
- self::ARRIVED->value => self::ARRIVED->label(),
- self::STARTED->value => self::STARTED->label(),
- self::COMPLETED->value => self::COMPLETED->label(),
- self::EVALUATED->value => self::EVALUATED->label(),
- self::CANCELLED->value => self::CANCELLED->label(),
- self::REJECTED->value => self::REJECTED->label(),
- self::DEPARTED->value => self::DEPARTED->label(),
- self::LEFT->value => self::LEFT->label(),
- self::REFUNDING->value => self::REFUNDING->label(),
- self::REFUNDED->value => self::REFUNDED->label(),
- ];
- }
- }
|