tourze / operation-system-enum
Operation System Enum
Installs: 276
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/tourze/operation-system-enum
Requires
- tourze/enum-extra: 1.*
Requires (Dev)
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^11.5
- tourze/phpunit-enum: 1.*
This package is auto-updated.
Last update: 2025-11-01 19:19:58 UTC
README
A PHP 8.1+ enum package for representing different operating system platforms with support for label display, array conversion, and compatibility with frontend parameters.
Installation
composer require tourze/operation-system-enum
Quick Start
Basic Usage
use Tourze\OperationSystemEnum\Platform; // Get all platform cases $platforms = Platform::cases(); // Get platform by value $platform = Platform::from('WINDOWS'); // Get platform with fallback $platform = Platform::tryFrom('INVALID'); // returns null // Get platform label echo Platform::WINDOWS->getLabel(); // "Windows" echo Platform::ANDROID->getLabel(); // "安卓"
Advanced Usage
use Tourze\OperationSystemEnum\Platform; // Mixed input support with compatibility $platform = Platform::mixFrom('mac'); // returns Platform::MACOS $platform = Platform::mixFrom('darwin'); // returns Platform::MACOS $platform = Platform::mixFrom('win'); // returns Platform::WINDOWS $platform = Platform::mixFrom('win32'); // returns Platform::WINDOWS // Convert to array format $data = Platform::WINDOWS->toArray(); // Returns: ['value' => 'WINDOWS', 'label' => 'Windows'] // Generate select options for frontend $options = Platform::genOptions(); // Returns array of ['label' => '...', 'text' => '...', 'value' => '...', 'name' => '...']
Available Platforms
Platform::EMPTY- Empty/Unknown platformPlatform::WINDOWS- Microsoft WindowsPlatform::ANDROID- Android OSPlatform::IOS- Apple iOSPlatform::MACOS- Apple macOSPlatform::ROUTER- Router systems
Features
- Type Safety: Built on PHP 8.1+ enums with strict typing
- Labelable: Implements
Labelableinterface for display labels - Itemable: Implements
Itemableinterface for array conversion - Selectable: Implements
Selectableinterface for frontend options - Compatibility: Support for various input formats via
mixFrom()method - Internationalization: Labels in multiple languages (English/Chinese)
Configuration
This package requires no additional configuration. It works out of the box with:
- PHP 8.1 or higher
tourze/enum-extrapackage for trait implementations
API Reference
Methods
getLabel(): string- Get display label for the platformtoArray(): array- Convert to array with value and labeltoSelectItem(): array- Convert to select option formatstatic mixFrom(string $value): ?Platform- Create platform from mixed inputstatic genOptions(): array- Generate all platform options for frontend
Interfaces
Labelable- Provides label display functionalityItemable- Provides array conversion functionalitySelectable- Provides select option generation functionality
License
MIT