定制 be-interactive/laravel-translation-scanner 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

be-interactive/laravel-translation-scanner

最新稳定版本:v1.1.1

Composer 安装命令:

composer require be-interactive/laravel-translation-scanner

包简介

A package that scans you repo for translations

README 文档

README

This package scans your projects for translations and integrates them into spatie translation loader.

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

Installation

You can install the package via composer:

composer require be-interactive/laravel-translation-scanner

You can optionally publish the config file like this:

php artisan vendor:publish --provider="BeInteractive\TranslationScanner\TranslationScannerServiceProvider" --tag="translation-scanner-config"

This package uses spatie/laravel-translation-loader, this means you will need to publish both their migrations and ours, in that order:

# In this order
php artisan vendor:publish --provider="Spatie\TranslationLoader\TranslationServiceProvider" --tag="translation-loader-migrations"
php artisan vendor:publish --provider="BeInteractive\TranslationScanner\TranslationScannerServiceProvider" --tag="translation-scanner-migrations"

After this you can run the migration:

php artisan migrate

Usage

This package implements a bridge-like architecture to scan your projects for translations. We do this by using Scanners, each of these have their own logic to scan for translations.

Default scanners

By default, we ship with the following Scanners:

  • Laravel translation files (scans in the laravel lang folder).
  • Laravel scanner (scans for trans and __ translations).
  • Filament scanner (scans for everything within make:: functions).
  • Regex scanner (allows you to implement a custom regex to scan your projects).

Basic Implementation

Actual usage of these looks like this:

\BeInteractive\TranslationScanner\Facades\TranslationScanner::laravel()
    ->filament()
    ->regex('/test/')
    // This stores all language lines
    ->store();

You can add options to further improve your scan based on your needs:

\BeInteractive\TranslationScanner\Facades\TranslationScanner::filament()->scanFiles();

Store without deleting

By default, the store() function will also delete records from the language_lines table that were not found during that scan. This might not be what you want so you can disble it:

\BeInteractive\TranslationScanner\TranslationScanner::laravel()
    ->store(deleteLinesThatWereNotScanned: false);

Only fetching the results

Sometimes you may want to execute your very own logic in handling the scanned language lines. To do this you can do the following:

\BeInteractive\TranslationScanner\TranslationScanner::laravel()
    ->getLanguageLines(); // Returns an array of all scanned translations

Custom scanners

You can also create your own scanners to use your own scanning logic. A scanner might look something like this:

use BeInteractive\TranslationScanner\Contracts\Scanner;

class MyCustomScanner implements Scanner
{
    /**
     * @return array{group: string, key: string, text: array{string, string}}
     */
    public function getLanguageLines(): array
    {
        return [
            [ 'group' => 'attributes', 'key' => 'name', 'text' => [ 'en' => 'Name' ] ],
        ];
    }
}

And then you can simply implement it using the facade.

\BeInteractive\TranslationScanner\TranslationScanner::laravel()
    ->with(new MyCustomScanner())
    ->store();

// Or only use a custom scanner
\BeInteractive\TranslationScanner\TranslationScanner::with(new MyCustomScanner())
    ->store();

Changelog

Please see CHANGELOG for more information on what has changed recently.

Credits

License

Please see License File for more information.

统计信息

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

GitHub 信息

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

其他信息

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