WalletRoleType.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <?php
  2. namespace App\Enums;
  3. /**
  4. * 钱包角色类型枚举类
  5. */
  6. enum WalletRoleType: int
  7. {
  8. /**
  9. * 角色类型:平台自有资金钱包
  10. */
  11. case PLATFORM_OWN = 1;
  12. /**
  13. * 角色类型:平台代收代付钱包
  14. */
  15. case PLATFORM_ESCROW = 2;
  16. /**
  17. * 角色类型:用户钱包
  18. */
  19. case USER = 3;
  20. /**
  21. * 角色类型:技师钱包
  22. */
  23. case TECHNICIAN = 4;
  24. /**
  25. * 角色类型:店铺钱包
  26. */
  27. case SHOP = 5;
  28. /**
  29. * 角色类型:代理商钱包
  30. */
  31. case AGENT = 6;
  32. /**
  33. * 角色类型:业务员钱包
  34. */
  35. case SALESMAN = 7;
  36. /**
  37. * 角色类型:其他
  38. */
  39. case OTHER = 8;
  40. /**
  41. * 获取类型的显示文本
  42. *
  43. * @return string 类型的中文描述
  44. */
  45. public function label(): string
  46. {
  47. return match ($this) {
  48. self::PLATFORM_OWN => '平台自有资金钱包',
  49. self::PLATFORM_ESCROW => '平台代收代付钱包',
  50. self::USER => '用户钱包',
  51. self::TECHNICIAN => '技师钱包',
  52. self::SHOP => '店铺钱包',
  53. self::AGENT => '代理商钱包',
  54. self::SALESMAN => '业务员钱包',
  55. self::OTHER => '其他',
  56. };
  57. }
  58. /**
  59. * 获取类型的整数值
  60. *
  61. * @return int 类型值
  62. */
  63. public function value(): int
  64. {
  65. return $this->value;
  66. }
  67. /**
  68. * 检查当前类型是否与指定类型相同
  69. *
  70. * @param self $type 要比较的类型
  71. * @return bool 如果类型相同返回 true,否则返回 false
  72. */
  73. public function is(self $type): bool
  74. {
  75. return $this === $type;
  76. }
  77. /**
  78. * 根据整数值创建对应的类型枚举实例
  79. *
  80. * @param int $value 类型值
  81. * @return self|null 返回对应的类型枚举实例,如果值无效则返回 null
  82. */
  83. public static function fromValue(int $value): ?self
  84. {
  85. return match ($value) {
  86. self::PLATFORM_OWN->value => self::PLATFORM_OWN,
  87. self::PLATFORM_ESCROW->value => self::PLATFORM_ESCROW,
  88. self::USER->value => self::USER,
  89. self::TECHNICIAN->value => self::TECHNICIAN,
  90. self::SHOP->value => self::SHOP,
  91. self::AGENT->value => self::AGENT,
  92. self::SALESMAN->value => self::SALESMAN,
  93. self::OTHER->value => self::OTHER,
  94. default => null
  95. };
  96. }
  97. /**
  98. * 获取所有类型的值数组
  99. *
  100. * @return array 包含所有类型值的数组
  101. */
  102. public static function values(): array
  103. {
  104. return array_column(self::cases(), 'value');
  105. }
  106. /**
  107. * 获取所有类型的键值对数组
  108. *
  109. * @return array 类型值作为键,显示文本作为值的关联数组
  110. */
  111. public static function all(): array
  112. {
  113. return [
  114. self::PLATFORM_OWN->value => self::PLATFORM_OWN->label(),
  115. self::PLATFORM_ESCROW->value => self::PLATFORM_ESCROW->label(),
  116. self::USER->value => self::USER->label(),
  117. self::TECHNICIAN->value => self::TECHNICIAN->label(),
  118. self::SHOP->value => self::SHOP->label(),
  119. self::AGENT->value => self::AGENT->label(),
  120. self::SALESMAN->value => self::SALESMAN->label(),
  121. self::OTHER->value => self::OTHER->label(),
  122. ];
  123. }
  124. }