RechargeStatus.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. namespace App\Enums;
  3. /**
  4. * 充值状态枚举类
  5. */
  6. enum RechargeStatus: int
  7. {
  8. /**
  9. * 充值状态:待充值
  10. */
  11. case PENDING = 1;
  12. /**
  13. * 充值状态:充值中
  14. */
  15. case PROCESSING = 2;
  16. /**
  17. * 充值状态:充值成功
  18. */
  19. case SUCCESS = 3;
  20. /**
  21. * 充值状态:充值失败
  22. */
  23. case FAILED = 4;
  24. /**
  25. * 获取状态的显示文本
  26. *
  27. * @return string 状态的中文描述
  28. */
  29. public function label(): string
  30. {
  31. return match ($this) {
  32. self::PENDING => '待充值',
  33. self::PROCESSING => '充值中',
  34. self::SUCCESS => '充值成功',
  35. self::FAILED => '充值失败',
  36. };
  37. }
  38. /**
  39. * 获取状态的整数值
  40. *
  41. * @return int 状态值
  42. */
  43. public function value(): int
  44. {
  45. return $this->value;
  46. }
  47. /**
  48. * 检查当前状态是否与指定状态相同
  49. *
  50. * @param self $status 要比较的状态
  51. * @return bool 如果状态相同返回 true,否则返回 false
  52. */
  53. public function is(self $status): bool
  54. {
  55. return $this === $status;
  56. }
  57. /**
  58. * 根据整数值创建对应的状态枚举实例
  59. *
  60. * @param int $value 状态值
  61. * @return self|null 返回对应的状态枚举实例,如果值无效则返回 null
  62. */
  63. public static function fromValue(int $value): ?self
  64. {
  65. return match ($value) {
  66. self::PENDING->value => self::PENDING,
  67. self::PROCESSING->value => self::PROCESSING,
  68. self::SUCCESS->value => self::SUCCESS,
  69. self::FAILED->value => self::FAILED,
  70. default => null
  71. };
  72. }
  73. /**
  74. * 获取所有状态的值数组
  75. *
  76. * @return array 包含所有状态值的数组
  77. */
  78. public static function values(): array
  79. {
  80. return array_column(self::cases(), 'value');
  81. }
  82. /**
  83. * 获取所有状态的键值对数组
  84. *
  85. * @return array 状态值作为键,显示文本作为值的关联数组
  86. */
  87. public static function all(): array
  88. {
  89. return [
  90. self::PENDING->value => self::PENDING->label(),
  91. self::PROCESSING->value => self::PROCESSING->label(),
  92. self::SUCCESS->value => self::SUCCESS->label(),
  93. self::FAILED->value => self::FAILED->label(),
  94. ];
  95. }
  96. }