ProfitSource.php 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. namespace App\Enums;
  3. /**
  4. * 分账来源枚举类
  5. */
  6. enum ProfitSource: int
  7. {
  8. /**
  9. * 分账来源:订单分账
  10. */
  11. case ORDER = 1;
  12. /**
  13. * 分账来源:推广分账
  14. */
  15. case PROMOTION = 2;
  16. /**
  17. * 分账来源:团队分账
  18. */
  19. case TEAM = 3;
  20. /**
  21. * 分账来源:其他
  22. */
  23. case OTHER = 4;
  24. /**
  25. * 获取来源的显示文本
  26. *
  27. * @return string 来源的中文描述
  28. */
  29. public function label(): string
  30. {
  31. return match ($this) {
  32. self::ORDER => '订单分账',
  33. self::PROMOTION => '推广分账',
  34. self::TEAM => '团队分账',
  35. self::OTHER => '其他',
  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 $source 要比较的来源
  51. * @return bool 如果来源相同返回 true,否则返回 false
  52. */
  53. public function is(self $source): bool
  54. {
  55. return $this === $source;
  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::ORDER->value => self::ORDER,
  67. self::PROMOTION->value => self::PROMOTION,
  68. self::TEAM->value => self::TEAM,
  69. self::OTHER->value => self::OTHER,
  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::ORDER->value => self::ORDER->label(),
  91. self::PROMOTION->value => self::PROMOTION->label(),
  92. self::TEAM->value => self::TEAM->label(),
  93. self::OTHER->value => self::OTHER->label(),
  94. ];
  95. }
  96. }