tourze/operation-system-enum 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

tourze/operation-system-enum

最新稳定版本:1.0.0

Composer 安装命令:

composer require tourze/operation-system-enum

包简介

Operation System Enum

README 文档

README

English | 中文

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 platform
  • Platform::WINDOWS - Microsoft Windows
  • Platform::ANDROID - Android OS
  • Platform::IOS - Apple iOS
  • Platform::MACOS - Apple macOS
  • Platform::ROUTER - Router systems

Features

  • Type Safety: Built on PHP 8.1+ enums with strict typing
  • Labelable: Implements Labelable interface for display labels
  • Itemable: Implements Itemable interface for array conversion
  • Selectable: Implements Selectable interface 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-extra package for trait implementations

API Reference

Methods

  • getLabel(): string - Get display label for the platform
  • toArray(): array - Convert to array with value and label
  • toSelectItem(): array - Convert to select option format
  • static mixFrom(string $value): ?Platform - Create platform from mixed input
  • static genOptions(): array - Generate all platform options for frontend

Interfaces

  • Labelable - Provides label display functionality
  • Itemable - Provides array conversion functionality
  • Selectable - Provides select option generation functionality

License

MIT

统计信息

  • 总下载量: 341
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-05-25