jesprofiltenborg/nova-variable-field

Laravel Nova 字段有机会包含可变值。

0.0.1 2023-01-17 17:26 UTC

This package is auto-updated.

Last update: 2024-09-17 21:05:51 UTC


README

此软件包将不再维护。请使用 https://github.com/spatie/nova-translatable 作为替代。如果您不喜欢 spatie 软件包的不同方法,请随意分叉此存储库并发布新的版本。

Nova 可翻译字段

Latest Version on Packagist

添加了显示和编辑由 spatie/laravel-translatable 软件包创建的可翻译字段的特性。

在详情视图中将显示如下

在编辑视图中将显示如下

支持更多字段类型的替代方案

如果您需要支持更多字段类型的可翻译性,请查看 spatie 的官方软件包:https://github.com/spatie/nova-translatable

安装和用法

您可以使用 composer 需求此软件包

composer require mrmonat/nova-translatable

您可以添加以下字段

use MrMonat\Translatable\Translatable;

Translatable::make('Description'),

确保您已经正确设置 Eloquent 模型

  • 首先,您需要添加 Spatie\Translatable\HasTranslations - trait。
  • 接下来,您应该创建一个公开属性 $translatable,它包含所有您希望使其可翻译的属性名称的数组。
  • 最后,您应该确保将所有可翻译属性都设置为数据库中的 text 数据类型。如果您的数据库支持 json 列,请使用该列。

以下是一个准备好的模型的示例

use Illuminate\Database\Eloquent\Model;
use Spatie\Translatable\HasTranslations;

class NewsItem extends Model
{
    use HasTranslations;
    
    public $translatable = ['name'];
}

定义地区

可以通过配置文件 config/translatable.php 定义地区(配置文件可以通过 spatie/laravel-translatable 软件包创建)通过添加一个 locales 数组

// config/translatable.php
return [
    ...
    'locales' => [
        'en' => 'English',
        'de' => 'German',
        'fr' => 'French',
    ],
];

或者,您可以通过 locales(...) 方法“覆盖”配置文件中的地区

Translatable::make('Description')->locales([
    'en' => 'English',
    'de' => 'German',
]),

单行选项

默认情况下,编辑视图上的输入字段是文本区域。如果您想将其更改为单行输入字段,可以添加 singleLine() 选项

Translatable::make('Description')->locales([...])->singleLine(),

Trix 编辑器

您可以使用 trix 编辑器来为您的可翻译字段,使用 trix() 选项

Translatable::make('Description')->trix(),

索引视图

默认情况下,在索引视图中显示字段时使用的地区由 app()->getLocale() 确定。要覆盖此设置,您可以使用 indexLocale($locale) 选项

Translatable::make('Description')->indexLocale('de'),