定制 headsnet/money-bundle 二次开发

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

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

headsnet/money-bundle

最新稳定版本:v0.2.0

Composer 安装命令:

composer require headsnet/money-bundle

包简介

Integrates moneyphp/money into your Symfony application

README 文档

README

Build Status Latest Stable Version Total Downloads License

Money Bundle

A Symfony bundle to integrate Money PHP into your application.

Summary Of Features

  • Twig Extensions - display and manipulate Money objects in Twig templates

  • Doctrine Support - persist Money objects in your storage layer

  • Custom Serializer - serialize Money objects to and from string or array values

  • Custom Form Type - use Money objects in form data classes

Installation

Simply install with Composer in the usual way.

composer require headsnet/money-bundle

Then add to your bundles.php file.

Headsnet\MoneyBundle\HeadsnetMoneyBundle::class => ['all' => true]

Doctrine

The bundle provides a custom Doctrine Type for the Currency element of the Money object, and then a Doctrine Embeddable for use in your models.

The data type for the amount column is set to integer which is evidently a contentious issue as the Money object uses strings internally, but having the database use an integer type allows native sorting and summing etc.

Forms

The bundle provides a form type with a Data Transformer, that extends the Symfony MoneyType.

The field will render a Money field, with the Money value object converted to readable values.

Twig

Formatters

The bundle provides a Twig filter which formats a Money object in to a number with a currency symbol.

{{ object.amount|money }}        # Renders e.g. "€10.00"

Manipulation

The bundle also provides a Twig utility that allows you to create a Money object directly in the template.

money(AMOUNT, 'CURRENCY_CODE')

This is generally useful for creating a variable which you then add values to in a loop. E.g.

{% set total = money(0, 'EUR') %}

{% for line in order.lines %}

	{% set total = total.add(line.cost) %}

{% endfor %}

Total: {{ total|money }}

Serializer

The bundle provides a Symfony normalizer for the Money object.

$amount = Money::EUR(200);

$serializer->serialize($amount, 'json'); // ==> '{"amount":"200","currency":"EUR"}'

Contributing

Contributions are welcome. Please submit pull requests with one fix/feature per pull request.

Composer scripts are configured for your convenience:

> composer cs         # Run coding standards checks
> composer cs-fix     # Fix coding standards violations

Licence

This code is released under the MIT licence. Please see the LICENSE file for more information.

统计信息

  • 总下载量: 15.89k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 11
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2019-03-12