定制 m-adamski/symfony-phone-number-bundle 二次开发

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

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

m-adamski/symfony-phone-number-bundle

最新稳定版本:4.0.1

Composer 安装命令:

composer require m-adamski/symfony-phone-number-bundle

包简介

Bundle for Symfony which integrates with the libphonenumber library

README 文档

README

Custom PhoneNumber Bundle integrating libphonenumber library into Symfony project. This bundle is inspired by PhoneNumberBundle but simplified and created for own projects.

Installation

Use Composer to install this bundle into Symfony project:

composer require m-adamski/symfony-phone-number-bundle

Configuration

This Bundle provide type template for Bootstrap 5. Register it in config/packages/twig.yaml

twig:
    form_themes:
        - '@PhoneNumber/Form/phone_number_bootstrap_5.html.twig'

How to use it?

Bundle provide additional Doctrine Type and Form Type. First, edit entity to use PhoneNumber Type:

An additional Doctrine Type has been removed from the bundle, because its use caused a problem with logging changes to the entity. Phone number is now stored in the database as string.

use Adamski\Symfony\PhoneNumberBundle\Validator as AssertPhoneNumber;

#[AssertPhoneNumber\PhoneNumber]
#[ORM\Column(type: "string", nullable: true)]
protected ?string $phoneNumber;

Now it's time to provide changes in Form Type:

use Adamski\Symfony\PhoneNumberBundle\Form\PhoneNumberType;

public function buildForm(FormBuilderInterface $builder, array $options) {
    $builder->add("phoneNumber", PhoneNumberType::class, [
        "label"       => "Phone number",
        "preferred"   => "PL",
        "countries_renderer" => function ($countryName, $countryCode, $regionCode) {
            return sprintf("%s (+%d)", $countryName, $countryCode);
        },
        "number_attr" => ["placeholder" => "e.g. 123 123 123"],
        "required"    => false
    ]);
}

There are some additional options that you can use:

  • countries - array of available countries e.g. ["PL", "DE"]
  • preferred - array or string with preferred country or countries
  • country_attr - attributes for country input
  • number_attr - attributes for number input
  • countries_renderer - a function that returns a string displayed as a country selection option. The following parameters are available: countryName, countryCode, regionCode

Twig filter

The displayed phone number in the template can be formatted according to the given pattern. For this purpose, the Twig phone_number filter has been implemented.

{{ current_customer.phoneNumber|phone_number('E164') }}
{{ current_customer.phoneNumber|phone_number('RFC3966') }}
{{ current_customer.phoneNumber|phone_number('NATIONAL') }}
{{ current_customer.phoneNumber|phone_number('INTERNATIONAL') }}

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-11-19

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固