opgginc/codezero-laravel-uri-translator 问题修复 & 功能扩展

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

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

opgginc/codezero-laravel-uri-translator

最新稳定版本:2.0.1

Composer 安装命令:

composer require opgginc/codezero-laravel-uri-translator

包简介

Translate a URI or individual slugs.

README 文档

README

Laravel License Total Downloads

ko-fi

This package registers a macro for the Laravel Translator class. This will allow you to translate individual URI slugs, while ignoring parameter placeholders.

Parameters will not be translated by this macro. That remains the responsibility of your code.

✅ Requirements

  • PHP >= 8.1 (supports up to 8.4)
  • Laravel >= 10.0 (supports up to 12.0)

📦 Install

Install this package with Composer:

composer require opgginc/codezero-laravel-uri-translator

Laravel will automatically register the ServiceProvider.

In your app's lang folder, create subdirectories for every locale you want to have translations for.

Next create a routes.php file in each of those directories.

lang/
  ├── en/
  │    └── routes.php
  └── nl/
       └── routes.php

Return an array of translations from the routes.php files.

🚀 Usage

Use the Lang::uri() macro when registering routes:

Route::get(Lang::uri('hello/world'), [Controller::class, 'index']);

The URI macro accepts 2 additional parameters:

  1. A locale, in case you need translations to a locale other than the current app locale.
  2. A namespace, in case your translation files reside in a package.
Lang::uri('hello/world', 'fr', 'my-package');

You can also use trans()->uri('hello/world') instead of Lang::uri('hello/world').

🔌 Example

Using these example translations:

// lang/nl/routes.php
return [
    'hello' => 'hallo',
    'world' => 'wereld',
    'override/hello/world' => 'something/very/different',
    'hello/world/{parameter}' => 'uri/with/{parameter}',
];

These are possible translation results:

// Translate every slug individually
// Translates to: 'hallo/wereld'
Lang::uri('hello/world');

// Keep original slug when missing translation
// Translates to: 'hallo/big/wereld'
Lang::uri('hello/big/world');

// Translate slugs, but not parameter placeholders
// Translates to: 'hallo/{world}'
Lang::uri('hello/{world}');

// Translate full URIs if an exact translation exists
// Translates to: 'something/very/different'
Lang::uri('override/hello/world');

// Translate full URIs if an exact translation exists (with placeholder)
// Translates to: 'uri/with/{parameter}'
Lang::uri('hello/world/{parameter}');

🚧 Testing

composer test

☕️ Credits

This package is a fork of the original work by Ivan Vermeyen. We are deeply saddened to share that Ivan has passed away. In memory of his excellent contribution to the Laravel community, we have forked this package to maintain and extend its functionality for newer Laravel versions. We extend our condolences to Ivan's family and friends.

🔒 Security

This project is maintained by OP.GG Inc. If you discover any security related issues, please use the issue tracker.

📑 Changelog

This package is a fork of codezero/laravel-uri-translator, updated to support Laravel 12 and PHP 8.4.

📜 License

The MIT License (MIT). Please see License File for more information.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-04-06