PaymentMethod.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. namespace App\Enums;
  3. /**
  4. * 支付方式枚举类
  5. */
  6. enum PaymentMethod: int
  7. {
  8. /**
  9. * 支付方式:微信支付
  10. */
  11. case WECHAT = 1;
  12. /**
  13. * 支付方式:支付宝
  14. */
  15. case ALIPAY = 2;
  16. /**
  17. * 支付方式:余额支付
  18. */
  19. case BALANCE = 3;
  20. /**
  21. * 支付方式:混合支付
  22. */
  23. case MIXED = 4;
  24. /**
  25. * 获取方式的显示文本
  26. *
  27. * @return string 方式的中文描述
  28. */
  29. public function label(): string
  30. {
  31. return match ($this) {
  32. self::WECHAT => '微信支付',
  33. self::ALIPAY => '支付宝',
  34. self::BALANCE => '余额支付',
  35. self::MIXED => '混合支付',
  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 $method 要比较的方式
  51. * @return bool 如果方式相同返回 true,否则返回 false
  52. */
  53. public function is(self $method): bool
  54. {
  55. return $this === $method;
  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::WECHAT->value => self::WECHAT,
  67. self::ALIPAY->value => self::ALIPAY,
  68. self::BALANCE->value => self::BALANCE,
  69. self::MIXED->value => self::MIXED,
  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::WECHAT->value => self::WECHAT->label(),
  91. self::ALIPAY->value => self::ALIPAY->label(),
  92. self::BALANCE->value => self::BALANCE->label(),
  93. self::MIXED->value => self::MIXED->label(),
  94. ];
  95. }
  96. }