123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- <?php
- namespace App\Enums;
- /**
- * 定时任务类型枚举类
- */
- enum SysTaskType: int
- {
- /**
- * 任务类型:系统任务
- */
- case SYSTEM = 1;
- /**
- * 任务类型:业务任务
- */
- case BUSINESS = 2;
- /**
- * 任务类型:清理任务
- */
- case CLEANUP = 3;
- /**
- * 任务类型:统计任务
- */
- case STATISTICS = 4;
- /**
- * 获取类型的显示文本
- *
- * @return string 类型的中文描述
- */
- public function label(): string
- {
- return match ($this) {
- self::SYSTEM => '系统任务',
- self::BUSINESS => '业务任务',
- self::CLEANUP => '清理任务',
- self::STATISTICS => '统计任务',
- };
- }
- /**
- * 获取类型的整数值
- *
- * @return int 类型值
- */
- public function value(): int
- {
- return $this->value;
- }
- /**
- * 检查当前类型是否与指定类型相同
- *
- * @param self $type 要比较的类型
- * @return bool 如果类型相同返回 true,否则返回 false
- */
- public function is(self $type): bool
- {
- return $this === $type;
- }
- /**
- * 根据整数值创建对应的类型枚举实例
- *
- * @param int $value 类型值
- * @return self|null 返回对应的类型枚举实例,如果值无效则返回 null
- */
- public static function fromValue(int $value): ?self
- {
- return match ($value) {
- self::SYSTEM->value => self::SYSTEM,
- self::BUSINESS->value => self::BUSINESS,
- self::CLEANUP->value => self::CLEANUP,
- self::STATISTICS->value => self::STATISTICS,
- default => null
- };
- }
- /**
- * 获取所有类型的值数组
- *
- * @return array 包含所有类型值的数组
- */
- public static function values(): array
- {
- return array_column(self::cases(), 'value');
- }
- /**
- * 获取所有类型的键值对数组
- *
- * @return array 类型值作为键,显示文本作为值的关联数组
- */
- public static function all(): array
- {
- return [
- self::SYSTEM->value => self::SYSTEM->label(),
- self::BUSINESS->value => self::BUSINESS->label(),
- self::CLEANUP->value => self::CLEANUP->label(),
- self::STATISTICS->value => self::STATISTICS->label(),
- ];
- }
- }
|