forest-lynx/moonshine-decimal-field
最新稳定版本:3.0.0
Composer 安装命令:
composer require forest-lynx/moonshine-decimal-field
包简介
README 文档
README
Поле Decimal для Moonshine
Documentation in English
Поле для работы с десятичными числами в административной панели MoonShine. Наследуется от поля Text. При редактировании к полю применяется маска @money Alpine.js
Note
Редактирование поля в режиме предварительного просмотра осуществляется через всплывающее окно, как это предусмотрено методом полей updateInPopover() админ панели MoonShine.
Note
Валидация для единиц измерения не поддерживается.
Совместимость
| Версия пакета | Версия админ-панели MoonShine |
|---|---|
| ^1.x | ^2.18.0 |
| ^2.x | ^3.x |
| ^3.x | ^4.x |
Содержание
Установка
Команда для установки:
composer require forest-lynx/moonshine-decimal-field
Использование
<?php //... use ForestLynx\MoonShine\Fields\Decimal; //... Decimal::make('Price', 'price');
Note
При формировании поля используется NumberFormatter php-intl.
По умолчанию данные о локали берутся из настроек проекта, для ее переопределения используйте метод locale()
Методы
locale(string $locale):
$locale- принимает строку с локалью, например: 'ru_RU' или 'ru'.
precision(int $precision, ?bool $isNaturalNumber):
$precisionпринимает число, количество знаков дробной части.$isNaturalNumberНе обязательный параметр, по умолчаниюfalse. Отвечает за обработку натуральных чисел, например если у вас в базе данных значения хранятся в виде целых чисел.naturalNumber(?int $precision = 2)$precisionпринимает число, количество знаков дробной части, по умолчанию 2.
Пример с натуральным числом, значение поля в базе данных = 12564. Предположим, что с учетом Ваших потребностей оно должно трансформироваться в 125.64:
<?php use ForestLynx\MoonShine\Fields\Decimal; //... Decimal::make('Sum', 'sum') ->precision(2, true); //or Decimal::make('Sum', 'sum') ->naturalNumber(); //...
Caution
Значения $precision в методах precision(),naturalNumber() перезаписывает данные о количестве знаков дробной части, ранее определенных указанными методами.
Например:
<?php use ForestLynx\MoonShine\Fields\Decimal; //... Decimal::make('Sum', 'sum') ->precision(3) ->naturalNumber(4); //...
Данный код переопределит значение количества знаков после запятой на 4.
Note
При работе с натуральными числами, со значением поля полученным из request перед сохранением происходит обратная трансформация.
Единицы измерения
Для указания поля, где хранятся единицы измерения:
Методы
unit(string $column, \Closure|array|Options|string $data, ?Closure $formatted = null):
$column- связь с полем в базе данных.$data- Для создания поля типа Enum нужно передать название класса (например:App\Enums\Unit::class). Для формирования поля типа Select нужно передать опции, как через методoptions()поля Select.$formatted- замыкание для форматирования значения поля в режиме preview.
unitDefault(mixed $default) идентичен методу default(),
unitNullable() идентичен методу nullable(),
unitSearchable() идентичен методу searchable(),
Примеры использования:
<?php use ForestLynx\MoonShine\Fields\Decimal; use App\Enums\Unit; //... Decimal::make('Price', 'price') ->unit('unit', [0 => 'килограмм.', 1 => 'литр']) ->unitDefault(1); //or Decimal::make('Price', 'price') ->unit('unit', Unit::class) ->unitDefault(Unit::KILOGRAM); //...
Как это выглядит в административной панели:
| Просмотр | Редактирование |
|---|---|
![]() |
![]() |
Лицензия
统计信息
- 总下载量: 454
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 11
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2024-05-20

